Class KnnVectorsReader
- java.lang.Object
- 
- org.apache.lucene.codecs.KnnVectorsReader
 
- 
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- Accountable
 - Direct Known Subclasses:
- Lucene95HnswVectorsReader,- PerFieldKnnVectorsFormat.FieldsReader
 
 public abstract class KnnVectorsReader extends Object implements Closeable, Accountable Reads vectors from an index.
- 
- 
Field Summary- 
Fields inherited from interface org.apache.lucene.util.AccountableNULL_ACCOUNTABLE
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedKnnVectorsReader()Sole constructor
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description abstract voidcheckIntegrity()Checks consistency of this reader.abstract ByteVectorValuesgetByteVectorValues(String field)Returns theByteVectorValuesfor the givenfield.abstract FloatVectorValuesgetFloatVectorValues(String field)Returns theFloatVectorValuesfor the givenfield.KnnVectorsReadergetMergeInstance()Returns an instance optimized for merging.abstract TopDocssearch(String field, byte[] target, int k, Bits acceptDocs, int visitedLimit)Return the k nearest neighbor documents as determined by comparison of their vector values for this field, to the given vector, by the field's similarity function.abstract TopDocssearch(String field, float[] target, int k, Bits acceptDocs, int visitedLimit)Return the k nearest neighbor documents as determined by comparison of their vector values for this field, to the given vector, by the field's similarity function.- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.apache.lucene.util.AccountablegetChildResources, ramBytesUsed
 
- 
 
- 
- 
- 
Method Detail- 
checkIntegritypublic abstract void checkIntegrity() throws IOExceptionChecks consistency of this reader.Note that this may be costly in terms of I/O, e.g. may involve computing a checksum value against large data files. - Throws:
- IOException
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
 - 
getFloatVectorValuespublic abstract FloatVectorValues getFloatVectorValues(String field) throws IOException Returns theFloatVectorValuesfor the givenfield. The behavior is undefined if the given field doesn't have KNN vectors enabled on itsFieldInfo. The return value is nevernull.- Throws:
- IOException
 
 - 
getByteVectorValuespublic abstract ByteVectorValues getByteVectorValues(String field) throws IOException Returns theByteVectorValuesfor the givenfield. The behavior is undefined if the given field doesn't have KNN vectors enabled on itsFieldInfo. The return value is nevernull.- Throws:
- IOException
 
 - 
searchpublic abstract TopDocs search(String field, float[] target, int k, Bits acceptDocs, int visitedLimit) throws IOException Return the k nearest neighbor documents as determined by comparison of their vector values for this field, to the given vector, by the field's similarity function. The score of each document is derived from the vector similarity in a way that ensures scores are positive and that a larger score corresponds to a higher ranking.The search is allowed to be approximate, meaning the results are not guaranteed to be the true k closest neighbors. For large values of k (for example when k is close to the total number of documents), the search may also retrieve fewer than k documents. The returned TopDocswill contain aScoreDocfor each nearest neighbor, in order of their similarity to the query vector (decreasing scores). TheTotalHitscontains the number of documents visited during the search. If the search stopped early because it hitvisitedLimit, it is indicated through the relationTotalHits.Relation.GREATER_THAN_OR_EQUAL_TO.The behavior is undefined if the given field doesn't have KNN vectors enabled on its FieldInfo. The return value is nevernull.- Parameters:
- field- the vector field to search
- target- the vector-valued query
- k- the number of docs to return
- acceptDocs-- Bitsthat represents the allowed documents to match, or- nullif they are all allowed to match.
- visitedLimit- the maximum number of nodes that the search is allowed to visit
- Returns:
- the k nearest neighbor documents, along with their (similarity-specific) scores.
- Throws:
- IOException
 
 - 
searchpublic abstract TopDocs search(String field, byte[] target, int k, Bits acceptDocs, int visitedLimit) throws IOException Return the k nearest neighbor documents as determined by comparison of their vector values for this field, to the given vector, by the field's similarity function. The score of each document is derived from the vector similarity in a way that ensures scores are positive and that a larger score corresponds to a higher ranking.The search is allowed to be approximate, meaning the results are not guaranteed to be the true k closest neighbors. For large values of k (for example when k is close to the total number of documents), the search may also retrieve fewer than k documents. The returned TopDocswill contain aScoreDocfor each nearest neighbor, in order of their similarity to the query vector (decreasing scores). TheTotalHitscontains the number of documents visited during the search. If the search stopped early because it hitvisitedLimit, it is indicated through the relationTotalHits.Relation.GREATER_THAN_OR_EQUAL_TO.The behavior is undefined if the given field doesn't have KNN vectors enabled on its FieldInfo. The return value is nevernull.- Parameters:
- field- the vector field to search
- target- the vector-valued query
- k- the number of docs to return
- acceptDocs-- Bitsthat represents the allowed documents to match, or- nullif they are all allowed to match.
- visitedLimit- the maximum number of nodes that the search is allowed to visit
- Returns:
- the k nearest neighbor documents, along with their (similarity-specific) scores.
- Throws:
- IOException
 
 - 
getMergeInstancepublic KnnVectorsReader getMergeInstance() Returns an instance optimized for merging. This instance may only be consumed in the thread that calledgetMergeInstance().The default implementation returns this
 
- 
 
-