Package org.apache.lucene.search.join
Class DiversifyingChildrenFloatKnnVectorQuery
java.lang.Object
org.apache.lucene.search.Query
org.apache.lucene.search.KnnFloatVectorQuery
org.apache.lucene.search.join.DiversifyingChildrenFloatKnnVectorQuery
kNN float vector query that joins matching children vector documents with their parent doc id.
 The top documents returned are the child document ids and the calculated scores. Here is how to
 use this in conjunction with 
ToParentBlockJoinQuery.
 Query knnQuery = new DiversifyingChildrenFloatKnnVectorQuery(fieldName, queryVector, ...); // Rewrite executes kNN search and collects nearest children docIds and their scores Query rewrittenKnnQuery = searcher.rewrite(knnQuery); // Join the scored children docs with their parents and score the parents Query childrenToParents = new ToParentBlockJoinQuery(rewrittenKnnQuery, parentsFilter, ScoreMode.MAX);
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final Stringprotected final Queryprotected final KnnSearchStrategyFields inherited from class org.apache.lucene.search.KnnFloatVectorQuerytarget
- 
Constructor SummaryConstructorsConstructorDescriptionDiversifyingChildrenFloatKnnVectorQuery(String field, float[] query, Query childFilter, int k, BitSetProducer parentsFilter) Create a DiversifyingChildrenFloatKnnVectorQuery.DiversifyingChildrenFloatKnnVectorQuery(String field, float[] query, Query childFilter, int k, BitSetProducer parentsFilter, KnnSearchStrategy searchStrategy) Create a DiversifyingChildrenFloatKnnVectorQuery.
- 
Method SummaryModifier and TypeMethodDescriptionprotected TopDocsapproximateSearch(LeafReaderContext context, Bits acceptDocs, int visitedLimit, KnnCollectorManager knnCollectorManager) booleanprotected TopDocsexactSearch(LeafReaderContext context, DocIdSetIterator acceptIterator, QueryTimeout queryTimeout) getField()intgetK()protected KnnCollectorManagergetKnnCollectorManager(int k, IndexSearcher searcher) inthashCode()protected TopDocsmergeLeafResults(TopDocs[] arg0) rewrite(IndexSearcher arg0) voidvisit(QueryVisitor arg0) Methods inherited from class org.apache.lucene.search.KnnFloatVectorQuerygetTargetCopyMethods inherited from class org.apache.lucene.search.QueryclassHash, createWeight, sameClassAs, toString
- 
Field Details- 
field
- 
filter
- 
searchStrategy
 
- 
- 
Constructor Details- 
DiversifyingChildrenFloatKnnVectorQuerypublic DiversifyingChildrenFloatKnnVectorQuery(String field, float[] query, Query childFilter, int k, BitSetProducer parentsFilter) Create a DiversifyingChildrenFloatKnnVectorQuery.- Parameters:
- field- the query field
- query- the vector query
- childFilter- the child filter
- k- how many parent documents to return given the matching children
- parentsFilter- Filter identifying the parent documents.
 
- 
DiversifyingChildrenFloatKnnVectorQuerypublic DiversifyingChildrenFloatKnnVectorQuery(String field, float[] query, Query childFilter, int k, BitSetProducer parentsFilter, KnnSearchStrategy searchStrategy) Create a DiversifyingChildrenFloatKnnVectorQuery.- Parameters:
- field- the query field
- query- the vector query
- childFilter- the child filter
- k- how many parent documents to return given the matching children
- parentsFilter- Filter identifying the parent documents.
- searchStrategy- the search strategy to use. If null, the default strategy will be used. The underlying format may not support all strategies and is free to ignore the requested strategy.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
 
 
- 
- 
Method Details- 
exactSearchprotected TopDocs exactSearch(LeafReaderContext context, DocIdSetIterator acceptIterator, QueryTimeout queryTimeout) throws IOException - Throws:
- IOException
 
- 
getKnnCollectorManager
- 
approximateSearchprotected TopDocs approximateSearch(LeafReaderContext context, Bits acceptDocs, int visitedLimit, KnnCollectorManager knnCollectorManager) throws IOException - Overrides:
- approximateSearchin class- KnnFloatVectorQuery
- Throws:
- IOException
 
- 
toString- Overrides:
- toStringin class- KnnFloatVectorQuery
 
- 
equals- Overrides:
- equalsin class- KnnFloatVectorQuery
 
- 
hashCodepublic int hashCode()- Overrides:
- hashCodein class- KnnFloatVectorQuery
 
- 
rewrite- Overrides:
- rewritein class- Query
- Throws:
- IOException
 
- 
mergeLeafResults
- 
visit
- 
getField
- 
getKpublic int getK()
- 
getFilter
 
-