mirror of
https://github.com/mudler/LocalAI.git
synced 2025-01-04 11:54:12 +00:00
48 lines
923 B
Go
48 lines
923 B
Go
|
package langchain
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
|
||
|
"github.com/tmc/langchaingo/llms"
|
||
|
"github.com/tmc/langchaingo/llms/huggingface"
|
||
|
)
|
||
|
|
||
|
type HuggingFace struct {
|
||
|
modelPath string
|
||
|
}
|
||
|
|
||
|
func NewHuggingFace(repoId string) (*HuggingFace, error) {
|
||
|
return &HuggingFace{
|
||
|
modelPath: repoId,
|
||
|
}, nil
|
||
|
}
|
||
|
|
||
|
func (s *HuggingFace) PredictHuggingFace(text string, opts ...PredictOption) (*Predict, error) {
|
||
|
po := NewPredictOptions(opts...)
|
||
|
|
||
|
// Init client
|
||
|
llm, err := huggingface.New()
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
// Convert from LocalAI to LangChainGo format of options
|
||
|
co := []llms.CallOption{
|
||
|
llms.WithModel(po.Model),
|
||
|
llms.WithMaxTokens(po.MaxTokens),
|
||
|
llms.WithTemperature(po.Temperature),
|
||
|
llms.WithStopWords(po.StopWords),
|
||
|
}
|
||
|
|
||
|
// Call Inference API
|
||
|
ctx := context.Background()
|
||
|
completion, err := llm.Call(ctx, text, co...)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
return &Predict{
|
||
|
Completion: completion,
|
||
|
}, nil
|
||
|
}
|