mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-12-02 03:48:37 +08:00
159 lines
4.8 KiB
Go
159 lines
4.8 KiB
Go
|
// Licensed to the LF AI & Data foundation under one
|
||
|
// or more contributor license agreements. See the NOTICE file
|
||
|
// distributed with this work for additional information
|
||
|
// regarding copyright ownership. The ASF licenses this file
|
||
|
// to you under the Apache License, Version 2.0 (the
|
||
|
// "License"); you may not use this file except in compliance
|
||
|
// with the License. You may obtain a copy of the License at
|
||
|
//
|
||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||
|
//
|
||
|
// Unless required by applicable law or agreed to in writing, software
|
||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
// See the License for the specific language governing permissions and
|
||
|
// limitations under the License.
|
||
|
|
||
|
package column
|
||
|
|
||
|
import (
|
||
|
"github.com/cockroachdb/errors"
|
||
|
"github.com/samber/lo"
|
||
|
|
||
|
"github.com/milvus-io/milvus-proto/go-api/v2/schemapb"
|
||
|
"github.com/milvus-io/milvus/client/v2/entity"
|
||
|
)
|
||
|
|
||
|
type vectorBase[T entity.Vector] struct {
|
||
|
*genericColumnBase[T]
|
||
|
dim int
|
||
|
}
|
||
|
|
||
|
func (b *vectorBase[T]) Dim() int {
|
||
|
return b.dim
|
||
|
}
|
||
|
|
||
|
func (b *vectorBase[T]) FieldData() *schemapb.FieldData {
|
||
|
fd := b.genericColumnBase.FieldData()
|
||
|
vectors := fd.GetVectors()
|
||
|
vectors.Dim = int64(b.dim)
|
||
|
return fd
|
||
|
}
|
||
|
|
||
|
func newVectorBase[T entity.Vector](fieldName string, dim int, vectors []T, fieldType entity.FieldType) *vectorBase[T] {
|
||
|
return &vectorBase[T]{
|
||
|
genericColumnBase: &genericColumnBase[T]{
|
||
|
name: fieldName,
|
||
|
fieldType: fieldType,
|
||
|
values: vectors,
|
||
|
},
|
||
|
dim: dim,
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/* float vector */
|
||
|
|
||
|
type ColumnFloatVector struct {
|
||
|
*vectorBase[entity.FloatVector]
|
||
|
}
|
||
|
|
||
|
func NewColumnFloatVector(fieldName string, dim int, data [][]float32) *ColumnFloatVector {
|
||
|
vectors := lo.Map(data, func(row []float32, _ int) entity.FloatVector { return entity.FloatVector(row) })
|
||
|
return &ColumnFloatVector{
|
||
|
vectorBase: newVectorBase(fieldName, dim, vectors, entity.FieldTypeFloatVector),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AppendValue appends vector value into values.
|
||
|
// override default type constrains, add `[]float32` conversion
|
||
|
func (c *ColumnFloatVector) AppendValue(i interface{}) error {
|
||
|
switch vector := i.(type) {
|
||
|
case entity.FloatVector:
|
||
|
c.values = append(c.values, vector)
|
||
|
case []float32:
|
||
|
c.values = append(c.values, vector)
|
||
|
default:
|
||
|
return errors.Newf("unexpected append value type %T, field type %v", vector, c.fieldType)
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
/* binary vector */
|
||
|
|
||
|
type ColumnBinaryVector struct {
|
||
|
*vectorBase[entity.BinaryVector]
|
||
|
}
|
||
|
|
||
|
func NewColumnBinaryVector(fieldName string, dim int, data [][]byte) *ColumnBinaryVector {
|
||
|
vectors := lo.Map(data, func(row []byte, _ int) entity.BinaryVector { return entity.BinaryVector(row) })
|
||
|
return &ColumnBinaryVector{
|
||
|
vectorBase: newVectorBase(fieldName, dim, vectors, entity.FieldTypeBinaryVector),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AppendValue appends vector value into values.
|
||
|
// override default type constrains, add `[]byte` conversion
|
||
|
func (c *ColumnBinaryVector) AppendValue(i interface{}) error {
|
||
|
switch vector := i.(type) {
|
||
|
case entity.BinaryVector:
|
||
|
c.values = append(c.values, vector)
|
||
|
case []byte:
|
||
|
c.values = append(c.values, vector)
|
||
|
default:
|
||
|
return errors.Newf("unexpected append value type %T, field type %v", vector, c.fieldType)
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
/* fp16 vector */
|
||
|
|
||
|
type ColumnFloat16Vector struct {
|
||
|
*vectorBase[entity.Float16Vector]
|
||
|
}
|
||
|
|
||
|
func NewColumnFloat16Vector(fieldName string, dim int, data [][]byte) *ColumnFloat16Vector {
|
||
|
vectors := lo.Map(data, func(row []byte, _ int) entity.Float16Vector { return entity.Float16Vector(row) })
|
||
|
return &ColumnFloat16Vector{
|
||
|
vectorBase: newVectorBase(fieldName, dim, vectors, entity.FieldTypeFloat16Vector),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AppendValue appends vector value into values.
|
||
|
// override default type constrains, add `[]byte` conversion
|
||
|
func (c *ColumnFloat16Vector) AppendValue(i interface{}) error {
|
||
|
switch vector := i.(type) {
|
||
|
case entity.Float16Vector:
|
||
|
c.values = append(c.values, vector)
|
||
|
case []byte:
|
||
|
c.values = append(c.values, vector)
|
||
|
default:
|
||
|
return errors.Newf("unexpected append value type %T, field type %v", vector, c.fieldType)
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
type ColumnBFloat16Vector struct {
|
||
|
*vectorBase[entity.BFloat16Vector]
|
||
|
}
|
||
|
|
||
|
func NewColumnBFloat16Vector(fieldName string, dim int, data [][]byte) *ColumnBFloat16Vector {
|
||
|
vectors := lo.Map(data, func(row []byte, _ int) entity.BFloat16Vector { return entity.BFloat16Vector(row) })
|
||
|
return &ColumnBFloat16Vector{
|
||
|
vectorBase: newVectorBase(fieldName, dim, vectors, entity.FieldTypeBFloat16Vector),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AppendValue appends vector value into values.
|
||
|
// override default type constrains, add `[]byte` conversion
|
||
|
func (c *ColumnBFloat16Vector) AppendValue(i interface{}) error {
|
||
|
switch vector := i.(type) {
|
||
|
case entity.BFloat16Vector:
|
||
|
c.values = append(c.values, vector)
|
||
|
case []byte:
|
||
|
c.values = append(c.values, vector)
|
||
|
default:
|
||
|
return errors.Newf("unexpected append value type %T, field type %v", vector, c.fieldType)
|
||
|
}
|
||
|
return nil
|
||
|
}
|