mirror of https://github.com/apache/lucene.git
Remove KnnVectorsFormat#currentVersion (#1077)
These internal versions only make sense within a codec definition, and aren't meant to be exposed and compared across codecs. Since this method is only used in tests, we can move the check to the test classes instead.
This commit is contained in:
parent
daa56d30f0
commit
653d2ebf71
|
@ -22,6 +22,7 @@ import static org.apache.lucene.backward_codecs.lucene90.Lucene90HnswVectorsForm
|
|||
|
||||
import org.apache.lucene.codecs.Codec;
|
||||
import org.apache.lucene.codecs.KnnVectorsFormat;
|
||||
import org.apache.lucene.index.VectorEncoding;
|
||||
import org.apache.lucene.tests.index.BaseKnnVectorsFormatTestCase;
|
||||
|
||||
public class TestLucene90HnswVectorsFormat extends BaseKnnVectorsFormatTestCase {
|
||||
|
@ -30,6 +31,12 @@ public class TestLucene90HnswVectorsFormat extends BaseKnnVectorsFormatTestCase
|
|||
return new Lucene90RWCodec();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected VectorEncoding randomVectorEncoding() {
|
||||
// Older formats only support float vectors
|
||||
return VectorEncoding.FLOAT32;
|
||||
}
|
||||
|
||||
public void testToString() {
|
||||
int maxConn = randomIntBetween(DEFAULT_MAX_CONN - 10, DEFAULT_MAX_CONN + 10);
|
||||
int beamWidth = randomIntBetween(DEFAULT_BEAM_WIDTH - 50, DEFAULT_BEAM_WIDTH + 50);
|
||||
|
|
|
@ -22,6 +22,7 @@ import static org.apache.lucene.backward_codecs.lucene91.Lucene91HnswVectorsForm
|
|||
|
||||
import org.apache.lucene.codecs.Codec;
|
||||
import org.apache.lucene.codecs.KnnVectorsFormat;
|
||||
import org.apache.lucene.index.VectorEncoding;
|
||||
import org.apache.lucene.tests.index.BaseKnnVectorsFormatTestCase;
|
||||
|
||||
public class TestLucene91HnswVectorsFormat extends BaseKnnVectorsFormatTestCase {
|
||||
|
@ -30,6 +31,12 @@ public class TestLucene91HnswVectorsFormat extends BaseKnnVectorsFormatTestCase
|
|||
return new Lucene91RWCodec();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected VectorEncoding randomVectorEncoding() {
|
||||
// Older formats only support float vectors
|
||||
return VectorEncoding.FLOAT32;
|
||||
}
|
||||
|
||||
public void testToString() {
|
||||
int maxConn = randomIntBetween(DEFAULT_MAX_CONN - 10, DEFAULT_MAX_CONN + 10);
|
||||
int beamWidth = randomIntBetween(DEFAULT_BEAM_WIDTH - 50, DEFAULT_BEAM_WIDTH + 50);
|
||||
|
|
|
@ -18,6 +18,7 @@ package org.apache.lucene.backward_codecs.lucene92;
|
|||
|
||||
import org.apache.lucene.codecs.Codec;
|
||||
import org.apache.lucene.codecs.KnnVectorsFormat;
|
||||
import org.apache.lucene.index.VectorEncoding;
|
||||
import org.apache.lucene.tests.index.BaseKnnVectorsFormatTestCase;
|
||||
|
||||
public class TestLucene92HnswVectorsFormat extends BaseKnnVectorsFormatTestCase {
|
||||
|
@ -26,6 +27,12 @@ public class TestLucene92HnswVectorsFormat extends BaseKnnVectorsFormatTestCase
|
|||
return new Lucene92RWCodec();
|
||||
}
|
||||
|
||||
@Override
|
||||
protected VectorEncoding randomVectorEncoding() {
|
||||
// Older formats only support float vectors
|
||||
return VectorEncoding.FLOAT32;
|
||||
}
|
||||
|
||||
public void testToString() {
|
||||
Codec customCodec =
|
||||
new Lucene92RWCodec() {
|
||||
|
|
|
@ -18,7 +18,6 @@
|
|||
package org.apache.lucene.codecs;
|
||||
|
||||
import java.io.IOException;
|
||||
import org.apache.lucene.codecs.lucene94.Lucene94HnswVectorsFormat;
|
||||
import org.apache.lucene.index.SegmentReadState;
|
||||
import org.apache.lucene.index.SegmentWriteState;
|
||||
import org.apache.lucene.index.VectorValues;
|
||||
|
@ -78,15 +77,6 @@ public abstract class KnnVectorsFormat implements NamedSPILoader.NamedSPI {
|
|||
/** Returns a {@link KnnVectorsReader} to read the vectors from the index. */
|
||||
public abstract KnnVectorsReader fieldsReader(SegmentReadState state) throws IOException;
|
||||
|
||||
/**
|
||||
* Returns the current KnnVectorsFormat version number. Indexes written using the format will be
|
||||
* "stamped" with this version.
|
||||
*/
|
||||
public int currentVersion() {
|
||||
// return the version supported by older codecs that did not override this method
|
||||
return Lucene94HnswVectorsFormat.VERSION_START;
|
||||
}
|
||||
|
||||
/**
|
||||
* EMPTY throws an exception when written. It acts as a sentinel indicating a Codec that does not
|
||||
* support vectors.
|
||||
|
|
|
@ -99,11 +99,6 @@ public class Lucene94Codec extends Codec {
|
|||
public KnnVectorsFormat getKnnVectorsFormatForField(String field) {
|
||||
return Lucene94Codec.this.getKnnVectorsFormatForField(field);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int currentVersion() {
|
||||
return Lucene94HnswVectorsFormat.VERSION_CURRENT;
|
||||
}
|
||||
};
|
||||
|
||||
private final StoredFieldsFormat storedFieldsFormat;
|
||||
|
|
|
@ -157,11 +157,6 @@ public final class Lucene94HnswVectorsFormat extends KnnVectorsFormat {
|
|||
return new Lucene94HnswVectorsReader(state);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int currentVersion() {
|
||||
return VERSION_CURRENT;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return "Lucene94HnswVectorsFormat(name=Lucene94HnswVectorsFormat, maxConn="
|
||||
|
|
|
@ -670,14 +670,12 @@ public abstract class BaseKnnVectorsFormatTestCase extends BaseIndexFileFormatTe
|
|||
random().nextInt(VectorSimilarityFunction.values().length)];
|
||||
}
|
||||
|
||||
private VectorEncoding randomVectorEncoding() {
|
||||
Codec codec = getCodec();
|
||||
if (codec.knnVectorsFormat().currentVersion()
|
||||
>= Codec.forName("Lucene94").knnVectorsFormat().currentVersion()) {
|
||||
/**
|
||||
* This method is overrideable since old codec versions only support {@link
|
||||
* VectorEncoding#FLOAT32}.
|
||||
*/
|
||||
protected VectorEncoding randomVectorEncoding() {
|
||||
return VectorEncoding.values()[random().nextInt(VectorEncoding.values().length)];
|
||||
} else {
|
||||
return VectorEncoding.FLOAT32;
|
||||
}
|
||||
}
|
||||
|
||||
public void testIndexedValueNotAliased() throws Exception {
|
||||
|
|
Loading…
Reference in New Issue