2024-04-25 00:19:02 +02:00
|
|
|
package backend
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
|
2024-06-23 01:24:36 -07:00
|
|
|
"github.com/mudler/LocalAI/core/config"
|
|
|
|
"github.com/mudler/LocalAI/pkg/grpc/proto"
|
|
|
|
model "github.com/mudler/LocalAI/pkg/model"
|
2024-04-25 00:19:02 +02:00
|
|
|
)
|
|
|
|
|
2024-10-02 08:55:58 +02:00
|
|
|
func Rerank(modelFile string, request *proto.RerankRequest, loader *model.ModelLoader, appConfig *config.ApplicationConfig, backendConfig config.BackendConfig) (*proto.RerankResult, error) {
|
2024-04-25 00:19:02 +02:00
|
|
|
|
2024-11-08 21:54:25 +01:00
|
|
|
opts := ModelOptions(backendConfig, appConfig, model.WithModel(modelFile))
|
|
|
|
rerankModel, err := loader.Load(opts...)
|
2024-04-25 00:19:02 +02:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if rerankModel == nil {
|
|
|
|
return nil, fmt.Errorf("could not load rerank model")
|
|
|
|
}
|
|
|
|
|
|
|
|
res, err := rerankModel.Rerank(context.Background(), request)
|
|
|
|
|
|
|
|
return res, err
|
|
|
|
}
|