2023-07-14 23:19:43 +00:00
|
|
|
package backend
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2024-06-23 08:24:36 +00:00
|
|
|
"github.com/mudler/LocalAI/core/config"
|
2024-03-01 15:19:53 +00:00
|
|
|
|
2024-06-23 08:24:36 +00:00
|
|
|
"github.com/mudler/LocalAI/pkg/grpc"
|
|
|
|
model "github.com/mudler/LocalAI/pkg/model"
|
2023-07-14 23:19:43 +00:00
|
|
|
)
|
|
|
|
|
2024-04-17 21:33:49 +00:00
|
|
|
func ModelEmbedding(s string, tokens []int, loader *model.ModelLoader, backendConfig config.BackendConfig, appConfig *config.ApplicationConfig) (func() ([]float32, error), error) {
|
2023-07-14 23:19:43 +00:00
|
|
|
|
2024-11-08 20:54:25 +00:00
|
|
|
opts := ModelOptions(backendConfig, appConfig)
|
2023-07-14 23:19:43 +00:00
|
|
|
|
2024-11-08 20:54:25 +00:00
|
|
|
inferenceModel, err := loader.Load(opts...)
|
2023-07-14 23:19:43 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var fn func() ([]float32, error)
|
|
|
|
switch model := inferenceModel.(type) {
|
2024-01-23 07:56:36 +00:00
|
|
|
case grpc.Backend:
|
2023-07-14 23:19:43 +00:00
|
|
|
fn = func() ([]float32, error) {
|
2024-03-01 15:19:53 +00:00
|
|
|
predictOptions := gRPCPredictOpts(backendConfig, loader.ModelPath)
|
2023-07-14 23:19:43 +00:00
|
|
|
if len(tokens) > 0 {
|
|
|
|
embeds := []int32{}
|
|
|
|
|
|
|
|
for _, t := range tokens {
|
|
|
|
embeds = append(embeds, int32(t))
|
|
|
|
}
|
|
|
|
predictOptions.EmbeddingTokens = embeds
|
|
|
|
|
2024-03-01 15:19:53 +00:00
|
|
|
res, err := model.Embeddings(appConfig.Context, predictOptions)
|
2023-07-14 23:19:43 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return res.Embeddings, nil
|
|
|
|
}
|
|
|
|
predictOptions.Embeddings = s
|
|
|
|
|
2024-03-01 15:19:53 +00:00
|
|
|
res, err := model.Embeddings(appConfig.Context, predictOptions)
|
2023-07-14 23:19:43 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return res.Embeddings, nil
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
fn = func() ([]float32, error) {
|
|
|
|
return nil, fmt.Errorf("embeddings not supported by the backend")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return func() ([]float32, error) {
|
|
|
|
embeds, err := fn()
|
|
|
|
if err != nil {
|
|
|
|
return embeds, err
|
|
|
|
}
|
|
|
|
// Remove trailing 0s
|
|
|
|
for i := len(embeds) - 1; i >= 0; i-- {
|
|
|
|
if embeds[i] == 0.0 {
|
|
|
|
embeds = embeds[:i]
|
|
|
|
} else {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return embeds, nil
|
|
|
|
}, nil
|
|
|
|
}
|