Class PerFieldKnnVectorsFormat
java.lang.Object
org.apache.lucene.codecs.KnnVectorsFormat
org.apache.lucene.codecs.perfield.PerFieldKnnVectorsFormat
- All Implemented Interfaces:
- NamedSPILoader.NamedSPI
Enables per field numeric vector support.
 
Note, when extending this class, the name (KnnVectorsFormat.getName()) is written into the index. In
 order for the field to be read, the name must resolve to your implementation via KnnVectorsFormat.forName(String). This method uses Java's Service Provider Interface to
 resolve format names.
 
Files written by each numeric vectors format have an additional suffix containing the format
 name. For example, in a per-field configuration instead of _1.dat filenames would
 look like _1_Lucene40_0.dat.
- See Also:
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classVectorReader that can wrap multiple delegate readers, selected by field.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringFieldInfoattribute name used to store the format name for each field.static final StringName of thisKnnVectorsFormat.static final StringFieldInfoattribute name used to store the segment suffix name for each field.Fields inherited from class org.apache.lucene.codecs.KnnVectorsFormatDEFAULT_MAX_DIMENSIONS, EMPTY
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionfieldsReader(SegmentReadState state) Returns aKnnVectorsReaderto read the vectors from the index.fieldsWriter(SegmentWriteState state) Returns aKnnVectorsWriterto write the vectors to the index.abstract KnnVectorsFormatReturns the numeric vector format that should be used for writing new segments offield.intgetMaxDimensions(String fieldName) Returns the maximum number of vector dimensions supported by this codec for the given field nameMethods inherited from class org.apache.lucene.codecs.KnnVectorsFormatavailableKnnVectorsFormats, forName, getName, reloadKnnVectorsFormat
- 
Field Details- 
PER_FIELD_NAMEName of thisKnnVectorsFormat.- See Also:
 
- 
PER_FIELD_FORMAT_KEYFieldInfoattribute name used to store the format name for each field.
- 
PER_FIELD_SUFFIX_KEYFieldInfoattribute name used to store the segment suffix name for each field.
 
- 
- 
Constructor Details- 
PerFieldKnnVectorsFormatprotected PerFieldKnnVectorsFormat()Sole constructor.
 
- 
- 
Method Details- 
fieldsWriterDescription copied from class:KnnVectorsFormatReturns aKnnVectorsWriterto write the vectors to the index.- Specified by:
- fieldsWriterin class- KnnVectorsFormat
- Throws:
- IOException
 
- 
fieldsReaderDescription copied from class:KnnVectorsFormatReturns aKnnVectorsReaderto read the vectors from the index.- Specified by:
- fieldsReaderin class- KnnVectorsFormat
- Throws:
- IOException
 
- 
getMaxDimensionsDescription copied from class:KnnVectorsFormatReturns the maximum number of vector dimensions supported by this codec for the given field nameCodecs implement this method to specify the maximum number of dimensions they support. - Specified by:
- getMaxDimensionsin class- KnnVectorsFormat
- Parameters:
- fieldName- the field name
- Returns:
- the maximum number of vector dimensions.
 
- 
getKnnVectorsFormatForFieldReturns the numeric vector format that should be used for writing new segments offield.The field to format mapping is written to the index, so this method is only invoked when writing, not when reading. 
 
-