From 3d1c9a8cae44091f3676cfcd99038c608e8dc8de Mon Sep 17 00:00:00 2001 From: Yinzuo Jiang Date: Fri, 29 Nov 2024 16:08:30 +0800 Subject: [PATCH] Update Float16VectorExample.java (#1203) milvus-sdk-java has already implemented fp32 <-> fp16/bf16 conversion methods, this PR just updates the related example. issue: https://github.com/milvus-io/milvus/issues/37448 Signed-off-by: Yinzuo Jiang Signed-off-by: Yinzuo Jiang --- .../java/io/milvus/v2/Float16VectorExample.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/examples/main/java/io/milvus/v2/Float16VectorExample.java b/examples/main/java/io/milvus/v2/Float16VectorExample.java index dc095dce4..0ae38293b 100644 --- a/examples/main/java/io/milvus/v2/Float16VectorExample.java +++ b/examples/main/java/io/milvus/v2/Float16VectorExample.java @@ -44,7 +44,6 @@ import java.nio.ByteBuffer; import java.util.*; - public class Float16VectorExample { private static final String COLLECTION_NAME = "java_sdk_example_float16_vector_v2"; private static final String ID_FIELD = "id"; @@ -89,8 +88,8 @@ private static void createCollection() { .build()); List indexes = new ArrayList<>(); - Map extraParams = new HashMap<>(); - extraParams.put("nlist",64); + Map extraParams = new HashMap<>(); + extraParams.put("nlist", 64); indexes.add(IndexParam.builder() .fieldName(FP16_VECTOR_FIELD) .indexType(IndexParam.IndexType.IVF_FLAT) @@ -118,6 +117,8 @@ private static void prepareData(int count) { for (long i = 0; i < count; i++) { JsonObject row = new JsonObject(); row.addProperty(ID_FIELD, i); + // The method for converting float32 vector to float16 vector can be found in + // CommonUtils. ByteBuffer buf1 = CommonUtils.generateFloat16Vector(VECTOR_DIM, false); row.add(FP16_VECTOR_FIELD, gson.toJsonTree(buf1.array())); ByteBuffer buf2 = CommonUtils.generateFloat16Vector(VECTOR_DIM, true); @@ -164,9 +165,16 @@ private static void searchVectors(List taargetIDs, List target if (!vectorBuf.equals(targetVectors.get(i).getData())) { throw new RuntimeException("The top1 output vector is incorrect"); } + // The method for converting float16 vector to float32 vector can be found in + // CommonUtils. + List decodedFpVector = CommonUtils.decodeFloat16Vector(vectorBuf, + BF16_VECTOR_FIELD.equals(vectorFieldName)); + if (decodedFpVector.size() != VECTOR_DIM) { + throw new RuntimeException("The decoded vector dimension is incorrect"); + } System.out.println(results.get(0)); } - System.out.println("Search result of float16 vector is correct"); + System.out.println("Search result of " + vectorFieldName + " is correct"); } private static void search() { @@ -208,7 +216,6 @@ private static void dropCollection() { System.out.println("Collection dropped"); } - public static void main(String[] args) { createCollection(); prepareData(10000);