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

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

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

import io.zulia.server.index.ShardReader;
import org.apache.lucene.search.similarities.ClassicSimilarity;
import org.apache.lucene.search.similarities.TFIDFSimilarity;

import java.io.IOException;
import java.util.HashMap;

/**
 * Created by Matt Davis on 6/28/16.
 * @author mdavis
 */
public class DocFreq {

	private final HashMap docFreqMap;
	private final ShardReader shardReader;
	private final String field;
	private final TFIDFSimilarity similarity;
	private final int numDocs;

	public DocFreq(ShardReader shardReader, String field) {
		this.shardReader = shardReader;
		this.field = field;
		this.docFreqMap = new HashMap<>();
		this.similarity = new ClassicSimilarity();
		this.numDocs = shardReader.numDocs();
	}

	public int getDocFreq(String term) throws IOException {
		Integer termDocFreq = this.docFreqMap.get(term);
		if (termDocFreq == null) {
			termDocFreq = shardReader.docFreq(field, term);
			docFreqMap.put(term, termDocFreq);
		}

		return termDocFreq;

	}

	public double getScoreForTerm(long termFreq, long docFreq) {
		return similarity.tf(termFreq) * similarity.idf(docFreq, numDocs);
	}

	public int getNumDocsForPercent(float percent) {
		return Math.round(numDocs * percent);
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy