All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.zulia.server.analysis.frequency.TermFreq Maven / Gradle / Ivy

There is a newer version: 1.6.4
Show newest version
package io.zulia.server.analysis.frequency;

import com.google.common.collect.Ordering;
import io.zulia.message.ZuliaBase.Term;
import io.zulia.message.ZuliaQuery.AnalysisRequest;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;

/**
 * Created by mdavis on 6/28/16.
 */
public class TermFreq {

	private final DocFreq docFreq;
	private final HashMap tokenCount;
	private List terms;

	public TermFreq(DocFreq docFreq) {
		this.docFreq = docFreq;
		this.tokenCount = new HashMap<>();
	}

	public void addTerm(String term) throws IOException {

		Term.Builder lmTerm = tokenCount.get(term);
		if (lmTerm == null) {
			lmTerm = Term.newBuilder().setTermFreq(0).setValue(term);
			tokenCount.put(term, lmTerm);
			if (docFreq != null) {
				int docFreq = this.docFreq.getDocFreq(term);
				lmTerm.setDocFreq(docFreq);
			}
		}

		lmTerm.setTermFreq(lmTerm.getTermFreq() + 1);
	}

	public void addTerm(Term.Builder term) {
		Term.Builder lmTerm = tokenCount.get(term.getValue());
		if (lmTerm == null) {
			lmTerm = Term.newBuilder(term.buildPartial());
			tokenCount.put(term.getValue(), lmTerm);
		}
		else {
			lmTerm.setTermFreq(lmTerm.getTermFreq() + term.getTermFreq());
		}
	}

	public List getTopTerms(int topN, AnalysisRequest.TermSort termSort) {

		if (terms == null) {
			terms = new ArrayList<>(tokenCount.values());
		}

		if (AnalysisRequest.TermSort.TFIDF.equals(termSort)) {
			if (docFreq != null) {
				for (Term.Builder term : terms) {
					double score = docFreq.getScoreForTerm(term.getTermFreq(), term.getDocFreq());
					term.setScore(score);
				}
			}
		}

		return getTopTerms(terms, topN, termSort);

	}

	public static List getTopTerms(List terms, int n, AnalysisRequest.TermSort termSort) {
		Comparator ordering = (Term.Builder o1, Term.Builder o2) -> {
			if (AnalysisRequest.TermSort.TF.equals(termSort)) {
				return Long.compare(o1.getTermFreq(), o2.getTermFreq());
			}
			else if (AnalysisRequest.TermSort.TFIDF.equals(termSort)) {
				return Double.compare(o1.getScore(), o2.getScore());
			}
			else if (AnalysisRequest.TermSort.ABC.equals(termSort)) {
				return o2.getValue().compareTo(o1.getValue());
			}
			else {
				return 0;
			}
		};

		if (n != 0) {
			//seems to be the most efficient according to
			//http://www.michaelpollmeier.com/selecting-top-k-items-from-a-list-efficiently-in-java-groovy/
			return Ordering.from(ordering).greatestOf(terms, n);
		}
		else {
			terms.sort(ordering.reversed());
			return terms;
		}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy