com.edduarte.vokter.document.Occurrence.java Source code

Java tutorial

Introduction

Here is the source code for com.edduarte.vokter.document.Occurrence.java

Source

/*
 * Copyright 2015 Eduardo Duarte
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.edduarte.vokter.document;

import com.mongodb.BasicDBObject;
import com.mongodb.DBObject;

import java.io.Serializable;
import java.util.Comparator;

/**
 * An occurrence represents a position within a document where a occurrence occurs.
 * This occurrence is implemented to allow phrase queries, using a word-based
 * counter, and to allow snippet printing, using character-based counters.
 *
 * @author Eduardo Duarte (<a href="mailto:hello@edduarte.com">hello@edduarte.com</a>)
 * @version 1.3.2
 * @since 1.0.0
 */
public class Occurrence extends BasicDBObject implements Comparable<Occurrence>, Serializable {

    public static final String TEXT = "text";

    public static final String WORD_COUNT = "word_count";

    public static final String START_INDEX = "start_index";

    public static final String END_INDEX = "end_index";

    private static final long serialVersionUID = 1L;

    public Occurrence(String text, int wordCount, int startIndex, int endIndex) {
        super(TEXT, text);
        append(WORD_COUNT, wordCount);
        append(START_INDEX, startIndex);
        append(END_INDEX, endIndex);
    }

    public Occurrence(BasicDBObject mongoObject) {
        super(mongoObject);
    }

    public Occurrence(DBObject mongoObject) {
        super(mongoObject.toMap());
    }

    /**
     * Returns the word-based position of this occurrence in the parent document.
     */
    public int getWordCount() {
        return getInt(WORD_COUNT);
    }

    /**
     * Returns the starting, character-based index of this occurrence in the parent
     * document.
     */
    public int getStartIndex() {
        return getInt(START_INDEX);
    }

    /**
     * Returns the ending, character-based index of this occurrence in the parent
     * document.
     */
    public int getEndIndex() {
        return getInt(END_INDEX);
    }

    /**
     * Returns the text that representsoccurrences term.
     */
    @Override
    public String toString() {
        return getString(TEXT);
    }

    /**
     * Verifies if the specified occurrence is contained in this one.
     *
     * @param a the occurrence to test if it is contained in this one
     * @return <code>true</code> if the specified occurrence is contained
     * in this one, and <code>false</code> in case otherwise.
     */
    public boolean contains(Occurrence a) {

        if (this.equals(a)) {
            return false;
        }

        return this.getStartIndex() <= a.getStartIndex() && this.getEndIndex() >= a.getEndIndex();
    }

    /**
     * Verifies if the specified occurrence is intersected with this one.
     *
     * @param a the occurrence that should be intersected with this one.
     * @return <code>true</code> if the specified occurrence is intersected
     * in this one, and <code>false</code> in case otherwise.
     */
    public boolean intersects(Occurrence a) {

        if (this.nests(a) || a.nests(this)) {
            return false;
        }

        if (this.getStartIndex() >= a.getStartIndex() && this.getStartIndex() <= a.getEndIndex()
                && this.getEndIndex() > a.getEndIndex()) {
            return true;
        }

        if (this.getEndIndex() >= a.getStartIndex() && this.getEndIndex() <= a.getEndIndex()
                && this.getStartIndex() < a.getStartIndex()) {
            return true;
        }

        if (a.getStartIndex() >= this.getStartIndex() && a.getStartIndex() <= this.getEndIndex()
                && a.getEndIndex() > this.getEndIndex()) {
            return true;
        }

        if (a.getEndIndex() >= this.getStartIndex() && a.getEndIndex() <= this.getEndIndex()
                && a.getStartIndex() < this.getStartIndex()) {
            return true;
        }

        return false;
    }

    /**
     * Verifies if the specified occurrence is nested in this one.
     *
     * @param a the occurrence that should be nested in this one.
     * @return <code>true</code> if the specified occurrence is nested
     * in this one, and <code>false</code> otherwise.
     */
    public boolean nests(Occurrence a) {

        if (this.equals(a)) {
            return false;
        }

        return (this.getStartIndex() >= a.getStartIndex()) && (this.getStartIndex() <= a.getEndIndex())
                && (this.getEndIndex() >= a.getStartIndex()) && (this.getEndIndex() <= a.getEndIndex());
    }

    /**
     * Compares this occurrence with the specified one in tokens of their positions.
     *
     * @param o the other occurrence to compare with this
     * @return the result of the comparison
     */
    @Override
    public int compareTo(Occurrence o) {
        return new OccurrenceComparator().compare(this, o);
    }

    /**
     * Checks the equality between this occurrence and the specified one.
     *
     * @param o the occurrence to be compared with.
     * @return <code>true</code> if the two annotations are equal, and
     * <code>false</code> otherwise.
     */
    @Override
    public boolean equals(Object o) {
        if (this == o)
            return true;
        if (o == null || getClass() != o.getClass())
            return false;

        Occurrence that = (Occurrence) o;
        return this.getWordCount() == that.getWordCount() && this.getStartIndex() == that.getStartIndex()
                && this.getEndIndex() == that.getEndIndex();
    }

    /**
     * Override the hashCode method to consider all the internal variables.
     *
     * @return unique number for each occurrence
     */
    @Override
    public int hashCode() {
        int hash = 7;
        hash = 79 * hash + this.getWordCount();
        hash = 79 * hash + this.getStartIndex();
        hash = 79 * hash + this.getEndIndex();
        return hash;
    }

    /**
     * Comparator used to sort a set of {@link Occurrence} objects.
     */
    public static class OccurrenceComparator implements Comparator<Occurrence> {

        /**
         * Compares two occurrences considering their positions in the sentence,
         * comparing the initialize and end pointer.
         *
         * @param a1 1st occurrence to be compared.
         * @param a2 2nd occurrence to be compared.
         * @return <code>1</code> if the 1st occurrence appears latter in the
         * sentence, and <code>-1</code> if the 2nd occurrence appears latter
         * in the sentence.
         */
        @Override
        public int compare(final Occurrence a1, final Occurrence a2) {

            if (a1.getStartIndex() > a2.getStartIndex()) {
                return 1;
            }
            if (a1.getStartIndex() < a2.getStartIndex()) {
                return -1;
            }

            if (a1.getEndIndex() > a2.getEndIndex()) {
                return 1;
            }
            if (a1.getEndIndex() < a2.getEndIndex()) {
                return -1;
            }
            return 0;
        }
    }
}