Xu Tong e429965f32
Add float16 approve for multi-type part (#28427)
issue:https://github.com/milvus-io/milvus/issues/22837

Add bfloat16 vector, add the index part of float16 vector.

Signed-off-by: Writer-X <1256866856@qq.com>
2024-01-11 15:48:51 +08:00

126 lines
2.6 KiB
Go

package indexcgowrapper
import (
"github.com/milvus-io/milvus-proto/go-api/v2/schemapb"
"github.com/milvus-io/milvus/internal/storage"
)
const (
keyRawArr = "key_raw_arr"
)
type Dataset struct {
DType schemapb.DataType
Data map[string]interface{}
}
func GenFloatVecDataset(vectors []float32) *Dataset {
return &Dataset{
DType: schemapb.DataType_FloatVector,
Data: map[string]interface{}{
keyRawArr: vectors,
},
}
}
func GenFloat16VecDataset(vectors []byte) *Dataset {
return &Dataset{
DType: schemapb.DataType_Float16Vector,
Data: map[string]interface{}{
keyRawArr: vectors,
},
}
}
func GenBFloat16VecDataset(vectors []byte) *Dataset {
return &Dataset{
DType: schemapb.DataType_BFloat16Vector,
Data: map[string]interface{}{
keyRawArr: vectors,
},
}
}
func GenBinaryVecDataset(vectors []byte) *Dataset {
return &Dataset{
DType: schemapb.DataType_BinaryVector,
Data: map[string]interface{}{
keyRawArr: vectors,
},
}
}
func GenDataset(data storage.FieldData) *Dataset {
switch f := data.(type) {
case *storage.BoolFieldData:
return &Dataset{
DType: schemapb.DataType_Bool,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.Int8FieldData:
return &Dataset{
DType: schemapb.DataType_Int8,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.Int16FieldData:
return &Dataset{
DType: schemapb.DataType_Int16,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.Int32FieldData:
return &Dataset{
DType: schemapb.DataType_Int32,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.Int64FieldData:
return &Dataset{
DType: schemapb.DataType_Int64,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.FloatFieldData:
return &Dataset{
DType: schemapb.DataType_Float,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.DoubleFieldData:
return &Dataset{
DType: schemapb.DataType_Double,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.StringFieldData:
return &Dataset{
DType: schemapb.DataType_VarChar,
Data: map[string]interface{}{
keyRawArr: f.Data,
},
}
case *storage.BinaryVectorFieldData:
return GenBinaryVecDataset(f.Data)
case *storage.FloatVectorFieldData:
return GenFloatVecDataset(f.Data)
case *storage.Float16VectorFieldData:
return GenFloat16VecDataset(f.Data)
case *storage.BFloat16VectorFieldData:
return GenBFloat16VecDataset(f.Data)
default:
return &Dataset{
DType: schemapb.DataType_None,
Data: nil,
}
}
}