From c091da9a9dbd79e1d1a2834e4189cd07ea22b786 Mon Sep 17 00:00:00 2001 From: ryjiang Date: Wed, 6 Nov 2024 16:53:23 +0800 Subject: [PATCH] support group size and strict_group_size Signed-off-by: ryjiang --- milvus/types/Data.ts | 4 ++++ milvus/utils/Format.ts | 6 +++++ proto | 2 +- test/grpc/Data.spec.ts | 1 + test/utils/Format.spec.ts | 50 +++++++++++++++++++++++++++++++++++++++ 5 files changed, 62 insertions(+), 1 deletion(-) diff --git a/milvus/types/Data.ts b/milvus/types/Data.ts index fd817ce4..f36707fc 100644 --- a/milvus/types/Data.ts +++ b/milvus/types/Data.ts @@ -283,6 +283,8 @@ export interface SearchParam { round_decimal?: number; // round decimal ignore_growing?: boolean; // ignore growing group_by_field?: string; // group by field + group_size?: number; // group size + strict_group_size?: boolean; // if strict group size } // old search api parameter type, deprecated @@ -333,6 +335,8 @@ export interface SearchSimpleReq extends collectionNameReq { consistency_level?: ConsistencyLevelEnum; // consistency level ignore_growing?: boolean; // ignore growing group_by_field?: string; // group by field + group_size?: number; // group size + strict_group_size?: boolean; // if strict group size round_decimal?: number; // round decimal transformers?: OutputTransformers; // provide custom data transformer for specific data type like bf16 or f16 vectors } diff --git a/milvus/utils/Format.ts b/milvus/utils/Format.ts index 91c9d071..a524c255 100644 --- a/milvus/utils/Format.ts +++ b/milvus/utils/Format.ts @@ -658,6 +658,12 @@ export const buildSearchParams = ( if (data.group_by_field) { search_params.group_by_field = data.group_by_field; } + if (data.strict_group_size) { + search_params.strict_group_size = data.strict_group_size; + } + if (data.group_size) { + search_params.group_size = data.group_size; + } return search_params; }; diff --git a/proto b/proto index 7e04a1bc..393a0da3 160000 --- a/proto +++ b/proto @@ -1 +1 @@ -Subproject commit 7e04a1bcb0d6c20d33bf7353c4dde0fea93b34d6 +Subproject commit 393a0da3769140b6213c438ee744ad495a8a3aa2 diff --git a/test/grpc/Data.spec.ts b/test/grpc/Data.spec.ts index a0d18f82..8291e0c9 100644 --- a/test/grpc/Data.spec.ts +++ b/test/grpc/Data.spec.ts @@ -266,6 +266,7 @@ describe(`Data.API`, () => { data: [1, 2, 3, 4], limit: limit, group_by_field: 'varChar2', + group_size: 2, }); expect(searchWithData.status.error_code).toEqual(ErrorCode.SUCCESS); diff --git a/test/utils/Format.spec.ts b/test/utils/Format.spec.ts index dc0ad36f..4a00d05a 100644 --- a/test/utils/Format.spec.ts +++ b/test/utils/Format.spec.ts @@ -29,6 +29,8 @@ import { formatSearchData, buildSearchRequest, FieldSchema, + buildSearchParams, + SearchSimpleReq, } from '../../milvus'; describe('utils/format', () => { @@ -937,4 +939,52 @@ describe('utils/format', () => { } ); }); + + it('should build search params correctly', () => { + const data: SearchSimpleReq = { + collection_name: 'test', + data: [1, 2, 3, 4, 5, 6, 7, 8], + params: { nprobe: 2 }, + limit: 2, + output_fields: ['vector', 'vector1'], + }; + const anns_field = 'anns_field2'; + + const newSearchParams = buildSearchParams(data, anns_field); + + expect(newSearchParams).toEqual({ + anns_field: 'anns_field2', + params: '{"nprobe":2}', + topk: 2, + offset: 0, + metric_type: '', + ignore_growing: false, + }); + + const data2: SearchSimpleReq = { + collection_name: 'test', + data: [1, 2, 3, 4, 5, 6, 7, 8], + anns_field: 'vector', + params: { nprobe: 2 }, + limit: 2, + output_fields: ['vector', 'vector1'], + group_by_field: 'group_by_field_value', + group_size: 5, + strict_group_size: true, + }; + + const newSearchParams2 = buildSearchParams(data2, anns_field); + + expect(newSearchParams2).toEqual({ + anns_field: 'vector', + params: '{"nprobe":2}', + topk: 2, + offset: 0, + metric_type: '', + ignore_growing: false, + group_by_field: 'group_by_field_value', + group_size: 5, + strict_group_size: true, + }); + }); });