2023-07-03 15:22:44 -04:00
|
|
|
package api
|
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
import "runtime"
|
|
|
|
|
2023-07-06 12:24:49 -04:00
|
|
|
type PullRequest struct {
|
|
|
|
Model string `json:"model"`
|
|
|
|
}
|
|
|
|
|
2023-07-06 14:18:40 -04:00
|
|
|
type PullProgress struct {
|
2023-07-06 14:05:55 -07:00
|
|
|
Total int64 `json:"total"`
|
|
|
|
Completed int64 `json:"completed"`
|
2023-07-06 14:18:40 -04:00
|
|
|
Percent float64 `json:"percent"`
|
|
|
|
}
|
|
|
|
|
2023-07-03 15:22:44 -04:00
|
|
|
type GenerateRequest struct {
|
|
|
|
Model string `json:"model"`
|
|
|
|
Prompt string `json:"prompt"`
|
2023-07-06 17:09:48 -07:00
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
Options `json:"options"`
|
2023-07-06 17:09:48 -07:00
|
|
|
}
|
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
type GenerateResponse struct {
|
|
|
|
Response string `json:"response"`
|
2023-07-06 17:09:48 -07:00
|
|
|
}
|
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
type Options struct {
|
|
|
|
Seed int `json:"seed,omitempty"`
|
2023-07-06 17:09:48 -07:00
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
// Backend options
|
|
|
|
UseNUMA bool `json:"numa,omitempty"`
|
|
|
|
|
|
|
|
// Model options
|
|
|
|
NumCtx int `json:"num_ctx,omitempty"`
|
|
|
|
NumBatch int `json:"num_batch,omitempty"`
|
|
|
|
NumGPU int `json:"num_gpu,omitempty"`
|
|
|
|
MainGPU int `json:"main_gpu,omitempty"`
|
|
|
|
LowVRAM bool `json:"low_vram,omitempty"`
|
|
|
|
F16KV bool `json:"f16_kv,omitempty"`
|
|
|
|
LogitsAll bool `json:"logits_all,omitempty"`
|
|
|
|
VocabOnly bool `json:"vocab_only,omitempty"`
|
|
|
|
UseMMap bool `json:"use_mmap,omitempty"`
|
|
|
|
UseMLock bool `json:"use_mlock,omitempty"`
|
|
|
|
EmbeddingOnly bool `json:"embedding_only,omitempty"`
|
|
|
|
|
|
|
|
// Predict options
|
|
|
|
RepeatLastN int `json:"repeat_last_n,omitempty"`
|
|
|
|
RepeatPenalty float32 `json:"repeat_penalty,omitempty"`
|
|
|
|
FrequencyPenalty float32 `json:"frequency_penalty,omitempty"`
|
|
|
|
PresencePenalty float32 `json:"presence_penalty,omitempty"`
|
|
|
|
Temperature float32 `json:"temperature,omitempty"`
|
|
|
|
TopK int `json:"top_k,omitempty"`
|
|
|
|
TopP float32 `json:"top_p,omitempty"`
|
|
|
|
TFSZ float32 `json:"tfs_z,omitempty"`
|
|
|
|
TypicalP float32 `json:"typical_p,omitempty"`
|
|
|
|
Mirostat int `json:"mirostat,omitempty"`
|
|
|
|
MirostatTau float32 `json:"mirostat_tau,omitempty"`
|
|
|
|
MirostatEta float32 `json:"mirostat_eta,omitempty"`
|
2023-07-06 17:09:48 -07:00
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
NumThread int `json:"num_thread,omitempty"`
|
2023-07-03 15:22:44 -04:00
|
|
|
}
|
|
|
|
|
2023-07-07 15:29:17 -07:00
|
|
|
func DefaultOptions() Options {
|
|
|
|
return Options{
|
|
|
|
Seed: -1,
|
|
|
|
|
|
|
|
UseNUMA: false,
|
|
|
|
|
|
|
|
NumCtx: 512,
|
|
|
|
NumBatch: 512,
|
|
|
|
NumGPU: 1,
|
|
|
|
LowVRAM: false,
|
|
|
|
F16KV: true,
|
|
|
|
UseMMap: true,
|
|
|
|
UseMLock: false,
|
|
|
|
|
|
|
|
RepeatLastN: 512,
|
|
|
|
RepeatPenalty: 1.1,
|
|
|
|
FrequencyPenalty: 0.0,
|
|
|
|
PresencePenalty: 0.0,
|
|
|
|
Temperature: 0.8,
|
|
|
|
TopK: 40,
|
|
|
|
TopP: 0.9,
|
|
|
|
TFSZ: 1.0,
|
|
|
|
TypicalP: 1.0,
|
|
|
|
Mirostat: 0,
|
|
|
|
MirostatTau: 5.0,
|
|
|
|
MirostatEta: 0.1,
|
|
|
|
|
|
|
|
NumThread: runtime.NumCPU(),
|
|
|
|
}
|
2023-07-03 15:22:44 -04:00
|
|
|
}
|