Class Lucene99ScalarQuantizedVectorsFormat
java.lang.Object
org.apache.lucene.codecs.KnnVectorsFormat
org.apache.lucene.codecs.hnsw.FlatVectorsFormat
org.apache.lucene.codecs.lucene99.Lucene99ScalarQuantizedVectorsFormat
- All Implemented Interfaces:
- NamedSPILoader.NamedSPI
Format supporting vector quantization, storage, and retrieval
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final floatDynamic confidence intervalstatic final Stringstatic final StringFields inherited from class org.apache.lucene.codecs.KnnVectorsFormatDEFAULT_MAX_DIMENSIONS, EMPTY
- 
Constructor SummaryConstructorsConstructorDescriptionConstructs a format using default graph construction parametersLucene99ScalarQuantizedVectorsFormat(Float confidenceInterval, int bits, boolean compress) Constructs a format using the given graph construction parameters.
- 
Method SummaryModifier and TypeMethodDescriptionstatic floatcalculateDefaultConfidenceInterval(int vectorDimension) fieldsReader(SegmentReadState state) Returns aKnnVectorsReaderto read the vectors from the index.fieldsWriter(SegmentWriteState state) Returns aFlatVectorsWriterto write the vectors to the index.toString()Methods inherited from class org.apache.lucene.codecs.hnsw.FlatVectorsFormatgetMaxDimensionsMethods inherited from class org.apache.lucene.codecs.KnnVectorsFormatavailableKnnVectorsFormats, forName, getName, reloadKnnVectorsFormat
- 
Field Details- 
QUANTIZED_VECTOR_COMPONENT- See Also:
 
- 
NAME- See Also:
 
- 
DYNAMIC_CONFIDENCE_INTERVALpublic static final float DYNAMIC_CONFIDENCE_INTERVALDynamic confidence interval- See Also:
 
 
- 
- 
Constructor Details- 
Lucene99ScalarQuantizedVectorsFormatpublic Lucene99ScalarQuantizedVectorsFormat()Constructs a format using default graph construction parameters
- 
Lucene99ScalarQuantizedVectorsFormatConstructs a format using the given graph construction parameters.- Parameters:
- confidenceInterval- the confidenceInterval for scalar quantizing the vectors, when `null` it is calculated based on the vector dimension. When `0`, the quantiles are dynamically determined by sampling many confidence intervals and determining the most accurate pair.
- bits- the number of bits to use for scalar quantization (must be between 1 and 8, inclusive)
- compress- whether to compress the quantized vectors by another 50% when bits=4. If `true`, pairs of (4 bit quantized) dimensions are packed into a single byte. This must be `false` when bits=7. This provides a trade-off of 50% reduction in hot vector memory usage during searching, at some decode speed penalty.
 
 
- 
- 
Method Details- 
calculateDefaultConfidenceIntervalpublic static float calculateDefaultConfidenceInterval(int vectorDimension) 
- 
toString
- 
fieldsWriterDescription copied from class:FlatVectorsFormatReturns aFlatVectorsWriterto write the vectors to the index.- Specified by:
- fieldsWriterin class- FlatVectorsFormat
- Throws:
- IOException
 
- 
fieldsReaderDescription copied from class:FlatVectorsFormatReturns aKnnVectorsReaderto read the vectors from the index.- Specified by:
- fieldsReaderin class- FlatVectorsFormat
- Throws:
- IOException
 
 
-