| package ratio_setting |
|
|
| import ( |
| "github.com/QuantumNous/new-api/types" |
| ) |
|
|
| var defaultCacheRatio = map[string]float64{ |
| "gemini-3-flash-preview": 0.1, |
| "gemini-3-pro-preview": 0.1, |
| "gemini-3.1-pro-preview": 0.1, |
| "gpt-4": 0.5, |
| "o1": 0.5, |
| "o1-2024-12-17": 0.5, |
| "o1-preview-2024-09-12": 0.5, |
| "o1-preview": 0.5, |
| "o1-mini-2024-09-12": 0.5, |
| "o1-mini": 0.5, |
| "o3-mini": 0.5, |
| "o3-mini-2025-01-31": 0.5, |
| "gpt-4o-2024-11-20": 0.5, |
| "gpt-4o-2024-08-06": 0.5, |
| "gpt-4o": 0.5, |
| "gpt-4o-mini-2024-07-18": 0.5, |
| "gpt-4o-mini": 0.5, |
| "gpt-4o-realtime-preview": 0.5, |
| "gpt-4o-mini-realtime-preview": 0.5, |
| "gpt-4.5-preview": 0.5, |
| "gpt-4.5-preview-2025-02-27": 0.5, |
| "gpt-4.1": 0.25, |
| "gpt-4.1-mini": 0.25, |
| "gpt-4.1-nano": 0.25, |
| "gpt-5": 0.1, |
| "gpt-5-2025-08-07": 0.1, |
| "gpt-5-chat-latest": 0.1, |
| "gpt-5-mini": 0.1, |
| "gpt-5-mini-2025-08-07": 0.1, |
| "gpt-5-nano": 0.1, |
| "gpt-5-nano-2025-08-07": 0.1, |
| "deepseek-chat": 0.25, |
| "deepseek-reasoner": 0.25, |
| "deepseek-coder": 0.25, |
| "claude-3-sonnet-20240229": 0.1, |
| "claude-3-opus-20240229": 0.1, |
| "claude-3-haiku-20240307": 0.1, |
| "claude-3-5-haiku-20241022": 0.1, |
| "claude-haiku-4-5-20251001": 0.1, |
| "claude-3-5-sonnet-20240620": 0.1, |
| "claude-3-5-sonnet-20241022": 0.1, |
| "claude-3-7-sonnet-20250219": 0.1, |
| "claude-3-7-sonnet-20250219-thinking": 0.1, |
| "claude-sonnet-4-20250514": 0.1, |
| "claude-sonnet-4-20250514-thinking": 0.1, |
| "claude-opus-4-20250514": 0.1, |
| "claude-opus-4-20250514-thinking": 0.1, |
| "claude-opus-4-1-20250805": 0.1, |
| "claude-opus-4-1-20250805-thinking": 0.1, |
| "claude-sonnet-4-5-20250929": 0.1, |
| "claude-sonnet-4-5-20250929-thinking": 0.1, |
| "claude-opus-4-5-20251101": 0.1, |
| "claude-opus-4-5-20251101-thinking": 0.1, |
| "claude-opus-4-6": 0.1, |
| "claude-opus-4-6-thinking": 0.1, |
| "claude-opus-4-6-max": 0.1, |
| "claude-opus-4-6-high": 0.1, |
| "claude-opus-4-6-medium": 0.1, |
| "claude-opus-4-6-low": 0.1, |
| } |
|
|
| var defaultCreateCacheRatio = map[string]float64{ |
| "claude-3-sonnet-20240229": 1.25, |
| "claude-3-opus-20240229": 1.25, |
| "claude-3-haiku-20240307": 1.25, |
| "claude-3-5-haiku-20241022": 1.25, |
| "claude-haiku-4-5-20251001": 1.25, |
| "claude-3-5-sonnet-20240620": 1.25, |
| "claude-3-5-sonnet-20241022": 1.25, |
| "claude-3-7-sonnet-20250219": 1.25, |
| "claude-3-7-sonnet-20250219-thinking": 1.25, |
| "claude-sonnet-4-20250514": 1.25, |
| "claude-sonnet-4-20250514-thinking": 1.25, |
| "claude-opus-4-20250514": 1.25, |
| "claude-opus-4-20250514-thinking": 1.25, |
| "claude-opus-4-1-20250805": 1.25, |
| "claude-opus-4-1-20250805-thinking": 1.25, |
| "claude-sonnet-4-5-20250929": 1.25, |
| "claude-sonnet-4-5-20250929-thinking": 1.25, |
| "claude-opus-4-5-20251101": 1.25, |
| "claude-opus-4-5-20251101-thinking": 1.25, |
| "claude-opus-4-6": 1.25, |
| "claude-opus-4-6-thinking": 1.25, |
| "claude-opus-4-6-max": 1.25, |
| "claude-opus-4-6-high": 1.25, |
| "claude-opus-4-6-medium": 1.25, |
| "claude-opus-4-6-low": 1.25, |
| } |
|
|
| |
|
|
| var cacheRatioMap = types.NewRWMap[string, float64]() |
| var createCacheRatioMap = types.NewRWMap[string, float64]() |
|
|
| |
| func GetCacheRatioMap() map[string]float64 { |
| return cacheRatioMap.ReadAll() |
| } |
|
|
| |
| func CacheRatio2JSONString() string { |
| return cacheRatioMap.MarshalJSONString() |
| } |
|
|
| |
| func CreateCacheRatio2JSONString() string { |
| return createCacheRatioMap.MarshalJSONString() |
| } |
|
|
| |
| func UpdateCacheRatioByJSONString(jsonStr string) error { |
| return types.LoadFromJsonStringWithCallback(cacheRatioMap, jsonStr, InvalidateExposedDataCache) |
| } |
|
|
| |
| func UpdateCreateCacheRatioByJSONString(jsonStr string) error { |
| return types.LoadFromJsonStringWithCallback(createCacheRatioMap, jsonStr, InvalidateExposedDataCache) |
| } |
|
|
| |
| func GetCacheRatio(name string) (float64, bool) { |
| ratio, ok := cacheRatioMap.Get(name) |
| if !ok { |
| return 1, false |
| } |
| return ratio, true |
| } |
|
|
| func GetCreateCacheRatio(name string) (float64, bool) { |
| ratio, ok := createCacheRatioMap.Get(name) |
| if !ok { |
| return 1.25, false |
| } |
| return ratio, true |
| } |
|
|
| func GetCacheRatioCopy() map[string]float64 { |
| return cacheRatioMap.ReadAll() |
| } |
|
|
| func GetCreateCacheRatioCopy() map[string]float64 { |
| return createCacheRatioMap.ReadAll() |
| } |
|
|