Package org.apache.lucene.search
Class BM25FQuery
- java.lang.Object
-
- org.apache.lucene.search.Query
-
- org.apache.lucene.search.BM25FQuery
-
- All Implemented Interfaces:
Accountable
public final class BM25FQuery extends Query implements Accountable
AQuerythat treats multiple fields as a single stream and scores terms as if you had indexed them as a single term in a single field. For scoring purposes this query implements the BM25F's simple formula described in: http://www.staff.city.ac.uk/~sb317/papers/foundations_bm25_review.pdf The per-field similarity is ignored but to be compatible each field must use aSimilarityat index time that encodes norms the same way asSimilarityBase.computeNorm(org.apache.lucene.index.FieldInvertState).
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private static classBM25FQuery.BM25FScorer(package private) classBM25FQuery.BM25FWeightstatic classBM25FQuery.BuilderA builder forBM25FQuery.(package private) static classBM25FQuery.FieldAndWeightprivate static classBM25FQuery.WeightedDisiWrapper
-
Field Summary
Fields Modifier and Type Field Description private static longBASE_RAM_BYTESprivate java.util.TreeMap<java.lang.String,BM25FQuery.FieldAndWeight>fieldAndWeightsprivate Term[]fieldTermsprivate longramBytesUsedprivate BM25Similaritysimilarityprivate BytesRef[]terms-
Fields inherited from interface org.apache.lucene.util.Accountable
NULL_ACCOUNTABLE
-
-
Constructor Summary
Constructors Modifier Constructor Description privateBM25FQuery(BM25Similarity similarity, java.util.TreeMap<java.lang.String,BM25FQuery.FieldAndWeight> fieldAndWeights, BytesRef[] terms)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description WeightcreateWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost)Expert: Constructs an appropriate Weight implementation for this query.booleanequals(java.lang.Object other)Override and implement query instance equivalence properly in a subclass.java.util.List<Term>getTerms()inthashCode()Override and implement query hash code properly in a subclass.longramBytesUsed()Return the memory usage of this object in bytes.Queryrewrite(IndexReader reader)Expert: called to re-write queries into primitive queries.private BooleanQueryrewriteToBoolean()java.lang.StringtoString(java.lang.String field)Prints a query to a string, withfieldassumed to be the default field and omitted.voidvisit(QueryVisitor visitor)Recurse through the query tree, visiting any child queries-
Methods inherited from class org.apache.lucene.search.Query
classHash, sameClassAs, toString
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.lucene.util.Accountable
getChildResources
-
-
-
-
Field Detail
-
BASE_RAM_BYTES
private static final long BASE_RAM_BYTES
-
similarity
private final BM25Similarity similarity
-
fieldAndWeights
private final java.util.TreeMap<java.lang.String,BM25FQuery.FieldAndWeight> fieldAndWeights
-
terms
private final BytesRef[] terms
-
fieldTerms
private final Term[] fieldTerms
-
ramBytesUsed
private final long ramBytesUsed
-
-
Constructor Detail
-
BM25FQuery
private BM25FQuery(BM25Similarity similarity, java.util.TreeMap<java.lang.String,BM25FQuery.FieldAndWeight> fieldAndWeights, BytesRef[] terms)
-
-
Method Detail
-
getTerms
public java.util.List<Term> getTerms()
-
toString
public java.lang.String toString(java.lang.String field)
Description copied from class:QueryPrints a query to a string, withfieldassumed to be the default field and omitted.
-
hashCode
public int hashCode()
Description copied from class:QueryOverride and implement query hash code properly in a subclass. This is required so thatQueryCacheworks properly.- Specified by:
hashCodein classQuery- See Also:
Query.equals(Object)
-
equals
public boolean equals(java.lang.Object other)
Description copied from class:QueryOverride and implement query instance equivalence properly in a subclass. This is required so thatQueryCacheworks properly. Typically a query will be equal to another only if it's an instance of the same class and its document-filtering properties are identical that other instance. Utility methods are provided for certain repetitive code.- Specified by:
equalsin classQuery- See Also:
Query.sameClassAs(Object),Query.classHash()
-
ramBytesUsed
public long ramBytesUsed()
Description copied from interface:AccountableReturn the memory usage of this object in bytes. Negative values are illegal.- Specified by:
ramBytesUsedin interfaceAccountable
-
rewrite
public Query rewrite(IndexReader reader) throws java.io.IOException
Description copied from class:QueryExpert: called to re-write queries into primitive queries. For example, a PrefixQuery will be rewritten into a BooleanQuery that consists of TermQuerys.
-
visit
public void visit(QueryVisitor visitor)
Description copied from class:QueryRecurse through the query tree, visiting any child queries
-
rewriteToBoolean
private BooleanQuery rewriteToBoolean()
-
createWeight
public Weight createWeight(IndexSearcher searcher, ScoreMode scoreMode, float boost) throws java.io.IOException
Description copied from class:QueryExpert: Constructs an appropriate Weight implementation for this query.Only implemented by primitive queries, which re-write to themselves.
- Overrides:
createWeightin classQueryscoreMode- How the produced scorers will be consumed.boost- The boost that is propagated by the parent queries.- Throws:
java.io.IOException
-
-