2024-02-20 20:21:19 -05:00
package config
2023-07-15 01:19:43 +02:00
import (
2024-04-17 23:33:49 +02:00
"os"
2024-03-01 10:19:53 -05:00
"github.com/go-skynet/LocalAI/core/schema"
2024-04-17 23:33:49 +02:00
"github.com/go-skynet/LocalAI/pkg/downloader"
2024-04-18 22:43:12 +02:00
"github.com/go-skynet/LocalAI/pkg/functions"
2024-04-17 23:33:49 +02:00
"github.com/go-skynet/LocalAI/pkg/utils"
2023-07-15 01:19:43 +02:00
)
2024-04-03 22:25:47 +02:00
const (
RAND_SEED = - 1
)
2024-03-01 10:19:53 -05:00
type BackendConfig struct {
schema . PredictionOptions ` yaml:"parameters" `
Name string ` yaml:"name" `
2023-08-09 08:38:51 +02:00
2024-03-13 10:05:30 +01:00
F16 * bool ` yaml:"f16" `
Threads * int ` yaml:"threads" `
Debug * bool ` yaml:"debug" `
2023-08-09 08:38:51 +02:00
Roles map [ string ] string ` yaml:"roles" `
Embeddings bool ` yaml:"embeddings" `
Backend string ` yaml:"backend" `
TemplateConfig TemplateConfig ` yaml:"template" `
PromptStrings , InputStrings [ ] string ` yaml:"-" `
InputToken [ ] [ ] int ` yaml:"-" `
functionCallString , functionCallNameString string ` yaml:"-" `
2023-07-15 01:19:43 +02:00
2024-04-18 22:43:12 +02:00
FunctionsConfig functions . FunctionsConfig ` yaml:"function" `
2023-07-22 11:31:39 -04:00
2023-08-19 16:15:22 +02:00
FeatureFlag FeatureFlag ` yaml:"feature_flags" ` // Feature Flag registry. We move fast, and features may break on a per model/backend basis. Registry for (usually temporary) flags that indicate aborting something early.
2023-08-09 08:38:51 +02:00
// LLM configs (GPT4ALL, Llama.cpp, ...)
LLMConfig ` yaml:",inline" `
// AutoGPTQ specifics
AutoGPTQ AutoGPTQ ` yaml:"autogptq" `
2023-08-03 00:51:08 +02:00
2023-08-09 08:38:51 +02:00
// Diffusers
Diffusers Diffusers ` yaml:"diffusers" `
2023-12-13 13:20:22 -05:00
Step int ` yaml:"step" `
2023-08-16 01:11:32 +02:00
// GRPC Options
GRPC GRPC ` yaml:"grpc" `
2023-09-04 19:25:23 +02:00
// Vall-e-x
VallE VallE ` yaml:"vall-e" `
2023-12-08 15:45:04 +01:00
// CUDA
// Explicitly enable CUDA or not (some backends might need it)
CUDA bool ` yaml:"cuda" `
2024-01-01 08:39:13 -05:00
DownloadFiles [ ] File ` yaml:"download_files" `
2024-01-08 00:37:02 +01:00
Description string ` yaml:"description" `
Usage string ` yaml:"usage" `
2024-01-01 08:39:13 -05:00
}
type File struct {
Filename string ` yaml:"filename" json:"filename" `
SHA256 string ` yaml:"sha256" json:"sha256" `
URI string ` yaml:"uri" json:"uri" `
2023-09-04 19:25:23 +02:00
}
type VallE struct {
AudioPath string ` yaml:"audio_path" `
2023-08-16 01:11:32 +02:00
}
2023-08-19 16:15:22 +02:00
type FeatureFlag map [ string ] * bool
func ( ff FeatureFlag ) Enabled ( s string ) bool {
v , exist := ff [ s ]
return exist && v != nil && * v
}
2023-08-16 01:11:32 +02:00
type GRPC struct {
Attempts int ` yaml:"attempts" `
AttemptsSleepTime int ` yaml:"attempts_sleep_time" `
2023-08-09 08:38:51 +02:00
}
type Diffusers struct {
2023-12-15 18:06:20 -05:00
CUDA bool ` yaml:"cuda" `
2023-08-16 01:11:42 +02:00
PipelineType string ` yaml:"pipeline_type" `
SchedulerType string ` yaml:"scheduler_type" `
EnableParameters string ` yaml:"enable_parameters" ` // A list of comma separated parameters to specify
CFGScale float32 ` yaml:"cfg_scale" ` // Classifier-Free Guidance Scale
2023-08-17 23:38:59 +02:00
IMG2IMG bool ` yaml:"img2img" ` // Image to Image Diffuser
ClipSkip int ` yaml:"clip_skip" ` // Skip every N frames
ClipModel string ` yaml:"clip_model" ` // Clip model to use
ClipSubFolder string ` yaml:"clip_subfolder" ` // Subfolder to use for clip model
2023-12-13 13:20:22 -05:00
ControlNet string ` yaml:"control_net" `
2023-08-09 08:38:51 +02:00
}
type LLMConfig struct {
SystemPrompt string ` yaml:"system_prompt" `
TensorSplit string ` yaml:"tensor_split" `
MainGPU string ` yaml:"main_gpu" `
RMSNormEps float32 ` yaml:"rms_norm_eps" `
NGQA int32 ` yaml:"ngqa" `
PromptCachePath string ` yaml:"prompt_cache_path" `
PromptCacheAll bool ` yaml:"prompt_cache_all" `
PromptCacheRO bool ` yaml:"prompt_cache_ro" `
2024-03-13 10:05:30 +01:00
MirostatETA * float64 ` yaml:"mirostat_eta" `
MirostatTAU * float64 ` yaml:"mirostat_tau" `
Mirostat * int ` yaml:"mirostat" `
NGPULayers * int ` yaml:"gpu_layers" `
MMap * bool ` yaml:"mmap" `
MMlock * bool ` yaml:"mmlock" `
LowVRAM * bool ` yaml:"low_vram" `
2023-08-09 08:38:51 +02:00
Grammar string ` yaml:"grammar" `
StopWords [ ] string ` yaml:"stopwords" `
Cutstrings [ ] string ` yaml:"cutstrings" `
TrimSpace [ ] string ` yaml:"trimspace" `
2024-01-01 08:39:42 -05:00
TrimSuffix [ ] string ` yaml:"trimsuffix" `
2024-03-13 10:05:30 +01:00
ContextSize * int ` yaml:"context_size" `
2024-03-01 16:48:53 -05:00
NUMA bool ` yaml:"numa" `
LoraAdapter string ` yaml:"lora_adapter" `
LoraBase string ` yaml:"lora_base" `
LoraScale float32 ` yaml:"lora_scale" `
NoMulMatQ bool ` yaml:"no_mulmatq" `
DraftModel string ` yaml:"draft_model" `
NDraft int32 ` yaml:"n_draft" `
Quantization string ` yaml:"quantization" `
GPUMemoryUtilization float32 ` yaml:"gpu_memory_utilization" ` // vLLM
TrustRemoteCode bool ` yaml:"trust_remote_code" ` // vLLM
EnforceEager bool ` yaml:"enforce_eager" ` // vLLM
SwapSpace int ` yaml:"swap_space" ` // vLLM
MaxModelLen int ` yaml:"max_model_len" ` // vLLM
2024-04-29 13:42:37 -04:00
TensorParallelSize int ` yaml:"tensor_parallel_size" ` // vLLM
2024-03-01 16:48:53 -05:00
MMProj string ` yaml:"mmproj" `
2023-11-11 18:40:48 +01:00
2024-01-26 00:13:21 +01:00
RopeScaling string ` yaml:"rope_scaling" `
ModelType string ` yaml:"type" `
2023-11-11 18:40:48 +01:00
YarnExtFactor float32 ` yaml:"yarn_ext_factor" `
YarnAttnFactor float32 ` yaml:"yarn_attn_factor" `
YarnBetaFast float32 ` yaml:"yarn_beta_fast" `
YarnBetaSlow float32 ` yaml:"yarn_beta_slow" `
2023-08-09 08:38:51 +02:00
}
2023-08-07 22:39:10 +02:00
2023-08-09 08:38:51 +02:00
type AutoGPTQ struct {
2023-08-08 01:10:05 +02:00
ModelBaseName string ` yaml:"model_base_name" `
Device string ` yaml:"device" `
Triton bool ` yaml:"triton" `
UseFastTokenizer bool ` yaml:"use_fast_tokenizer" `
2023-07-15 01:19:43 +02:00
}
type TemplateConfig struct {
2024-04-11 13:20:22 -04:00
Chat string ` yaml:"chat" `
ChatMessage string ` yaml:"chat_message" `
Completion string ` yaml:"completion" `
Edit string ` yaml:"edit" `
Functions string ` yaml:"function" `
UseTokenizerTemplate bool ` yaml:"use_tokenizer_template" `
2023-07-15 01:19:43 +02:00
}
2024-03-01 10:19:53 -05:00
func ( c * BackendConfig ) SetFunctionCallString ( s string ) {
2023-07-15 01:19:43 +02:00
c . functionCallString = s
}
2024-03-01 10:19:53 -05:00
func ( c * BackendConfig ) SetFunctionCallNameString ( s string ) {
2023-07-15 01:19:43 +02:00
c . functionCallNameString = s
}
2024-03-01 10:19:53 -05:00
func ( c * BackendConfig ) ShouldUseFunctions ( ) bool {
2023-07-15 01:19:43 +02:00
return ( ( c . functionCallString != "none" || c . functionCallString == "" ) || c . ShouldCallSpecificFunction ( ) )
}
2024-03-01 10:19:53 -05:00
func ( c * BackendConfig ) ShouldCallSpecificFunction ( ) bool {
2023-07-15 01:19:43 +02:00
return len ( c . functionCallNameString ) > 0
}
2024-04-28 23:42:46 +02:00
// MMProjFileName returns the filename of the MMProj file
// If the MMProj is a URL, it will return the MD5 of the URL which is the filename
func ( c * BackendConfig ) MMProjFileName ( ) string {
modelURL := downloader . ConvertURL ( c . MMProj )
if downloader . LooksLikeURL ( modelURL ) {
return utils . MD5 ( modelURL )
}
return c . MMProj
}
func ( c * BackendConfig ) IsMMProjURL ( ) bool {
return downloader . LooksLikeURL ( downloader . ConvertURL ( c . MMProj ) )
}
func ( c * BackendConfig ) IsModelURL ( ) bool {
return downloader . LooksLikeURL ( downloader . ConvertURL ( c . Model ) )
}
// ModelFileName returns the filename of the model
// If the model is a URL, it will return the MD5 of the URL which is the filename
func ( c * BackendConfig ) ModelFileName ( ) string {
modelURL := downloader . ConvertURL ( c . Model )
if downloader . LooksLikeURL ( modelURL ) {
return utils . MD5 ( modelURL )
}
return c . Model
}
2024-03-01 10:19:53 -05:00
func ( c * BackendConfig ) FunctionToCall ( ) string {
2024-04-01 19:39:54 +02:00
if c . functionCallNameString != "" &&
c . functionCallNameString != "none" && c . functionCallNameString != "auto" {
return c . functionCallNameString
}
return c . functionCallString
2023-07-15 01:19:43 +02:00
}
2024-03-22 20:55:11 +01:00
func ( cfg * BackendConfig ) SetDefaults ( opts ... ConfigLoaderOption ) {
2024-04-17 23:33:49 +02:00
lo := & LoadOptions { }
2024-03-22 20:55:11 +01:00
lo . Apply ( opts ... )
ctx := lo . ctxSize
threads := lo . threads
f16 := lo . f16
debug := lo . debug
2024-04-06 22:56:45 +02:00
// https://github.com/ggerganov/llama.cpp/blob/75cd4c77292034ecec587ecb401366f57338f7c0/common/sampling.h#L22
defaultTopP := 0.95
defaultTopK := 40
2024-03-13 10:05:30 +01:00
defaultTemp := 0.9
defaultMirostat := 2
defaultMirostatTAU := 5.0
defaultMirostatETA := 0.1
2024-04-06 22:56:45 +02:00
defaultTypicalP := 1.0
defaultTFZ := 1.0
2024-04-21 16:34:00 +02:00
defaultZero := 0
2024-03-13 10:05:30 +01:00
// Try to offload all GPU layers (if GPU is found)
2024-04-20 20:20:10 +02:00
defaultHigh := 99999999
2024-03-13 10:05:30 +01:00
trueV := true
falseV := false
if cfg . Seed == nil {
// random number generator seed
2024-04-03 22:25:47 +02:00
defaultSeed := RAND_SEED
2024-03-13 10:05:30 +01:00
cfg . Seed = & defaultSeed
}
if cfg . TopK == nil {
cfg . TopK = & defaultTopK
}
2024-04-06 22:56:45 +02:00
if cfg . TypicalP == nil {
cfg . TypicalP = & defaultTypicalP
}
if cfg . TFZ == nil {
cfg . TFZ = & defaultTFZ
}
2024-03-13 10:05:30 +01:00
if cfg . MMap == nil {
// MMap is enabled by default
2024-04-27 09:08:33 +02:00
// Only exception is for Intel GPUs
if os . Getenv ( "XPU" ) != "" {
cfg . MMap = & falseV
} else {
cfg . MMap = & trueV
}
2024-03-01 10:19:53 -05:00
}
2024-03-13 10:05:30 +01:00
if cfg . MMlock == nil {
// MMlock is disabled by default
cfg . MMlock = & falseV
}
if cfg . TopP == nil {
cfg . TopP = & defaultTopP
}
if cfg . Temperature == nil {
cfg . Temperature = & defaultTemp
}
if cfg . Maxtokens == nil {
2024-04-21 16:34:00 +02:00
cfg . Maxtokens = & defaultZero
2024-03-13 10:05:30 +01:00
}
if cfg . Mirostat == nil {
cfg . Mirostat = & defaultMirostat
}
if cfg . MirostatETA == nil {
cfg . MirostatETA = & defaultMirostatETA
}
if cfg . MirostatTAU == nil {
cfg . MirostatTAU = & defaultMirostatTAU
}
if cfg . NGPULayers == nil {
2024-04-20 20:20:10 +02:00
cfg . NGPULayers = & defaultHigh
2024-03-13 10:05:30 +01:00
}
if cfg . LowVRAM == nil {
cfg . LowVRAM = & falseV
}
// Value passed by the top level are treated as default (no implicit defaults)
// defaults are set by the user
if ctx == 0 {
ctx = 1024
}
if cfg . ContextSize == nil {
cfg . ContextSize = & ctx
}
if threads == 0 {
// Threads can't be 0
threads = 4
}
if cfg . Threads == nil {
cfg . Threads = & threads
}
if cfg . F16 == nil {
cfg . F16 = & f16
}
2024-03-18 18:59:39 +01:00
if cfg . Debug == nil {
cfg . Debug = & falseV
}
2024-03-13 10:05:30 +01:00
if debug {
2024-03-18 18:59:39 +01:00
cfg . Debug = & trueV
2024-03-01 10:19:53 -05:00
}
}