Package org.apache.lucene.search
Class KnnByteVectorQuery
- java.lang.Object
-
- org.apache.lucene.search.Query
-
- org.apache.lucene.search.KnnByteVectorQuery
-
public class KnnByteVectorQuery extends Query
UsesKnnVectorsReader.search(String, byte[], int, Bits, int)to perform nearest neighbour search.This query also allows for performing a kNN search subject to a filter. In this case, it first executes the filter for each leaf, then chooses a strategy dynamically:
- If the filter cost is less than k, just execute an exact search
- Otherwise run a kNN search subject to the filter
- If the kNN search visits too many vectors without completing, stop and run an exact search
-
-
Constructor Summary
Constructors Constructor Description KnnByteVectorQuery(String field, byte[] target, int k)Find theknearest documents to the target vector according to the vectors in the given field.KnnByteVectorQuery(String field, byte[] target, int k, Query filter)Find theknearest documents to the target vector according to the vectors in the given field.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected TopDocsapproximateSearch(LeafReaderContext context, Bits acceptDocs, int visitedLimit)booleanequals(Object o)Override and implement query instance equivalence properly in a subclass.protected TopDocsexactSearch(LeafReaderContext context, DocIdSetIterator acceptIterator)StringgetField()QuerygetFilter()intgetK()byte[]getTargetCopy()inthashCode()Override and implement query hash code properly in a subclass.Queryrewrite(IndexReader reader)Expert: called to re-write queries into primitive queries.StringtoString(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, createWeight, sameClassAs, toString
-
-
-
-
Field Detail
-
field
protected final String field
-
k
protected final int k
-
-
Constructor Detail
-
KnnByteVectorQuery
public KnnByteVectorQuery(String field, byte[] target, int k)
Find theknearest documents to the target vector according to the vectors in the given field.targetvector.- Parameters:
field- a field that has been indexed as aKnnFloatVectorField.target- the target of the searchk- the number of documents to find- Throws:
IllegalArgumentException- ifkis less than 1
-
KnnByteVectorQuery
public KnnByteVectorQuery(String field, byte[] target, int k, Query filter)
Find theknearest documents to the target vector according to the vectors in the given field.targetvector.- Parameters:
field- a field that has been indexed as aKnnFloatVectorField.target- the target of the searchk- the number of documents to findfilter- a filter applied before the vector search- Throws:
IllegalArgumentException- ifkis less than 1
-
-
Method Detail
-
approximateSearch
protected TopDocs approximateSearch(LeafReaderContext context, Bits acceptDocs, int visitedLimit) throws IOException
- Throws:
IOException
-
toString
public String toString(String field)
Description copied from class:QueryPrints a query to a string, withfieldassumed to be the default field and omitted.
-
equals
public boolean equals(Object o)
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.
- See Also:
Query.sameClassAs(Object),Query.classHash()
-
hashCode
public int hashCode()
Description copied from class:QueryOverride and implement query hash code properly in a subclass. This is required so thatQueryCacheworks properly.- See Also:
Query.equals(Object)
-
getTargetCopy
public byte[] getTargetCopy()
- Returns:
- the target query vector of the search. Each vector element is a byte.
-
rewrite
public Query rewrite(IndexReader reader) throws 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.Callers are expected to call
rewritemultiple times if necessary, until the rewritten query is the same as the original query.- Overrides:
rewritein classQuery- Throws:
IOException- See Also:
IndexSearcher.rewrite(Query)
-
exactSearch
protected TopDocs exactSearch(LeafReaderContext context, DocIdSetIterator acceptIterator) throws IOException
- Throws:
IOException
-
visit
public void visit(QueryVisitor visitor)
Description copied from class:QueryRecurse through the query tree, visiting any child queries
-
getField
public String getField()
- Returns:
- the knn vector field where the knn vector search happens.
-
getK
public int getK()
- Returns:
- the max number of results the KnnVector search returns.
-
getFilter
public Query getFilter()
- Returns:
- the filter that is executed before the KnnVector search happens. Only the results accepted by this filter are returned by the KnnVector search.
-
-