cherry-studio/src/renderer/src/config/models.ts
Chen Tao 96ef98e35c feat(knowledge): support Voyage AI (#3810)
* feat(knowledge): support Voyage AI

* chore
2025-03-23 19:31:18 +08:00

2139 lines
56 KiB
TypeScript

import Ai360ModelLogo from '@renderer/assets/images/models/360.png'
import Ai360ModelLogoDark from '@renderer/assets/images/models/360_dark.png'
import AdeptModelLogo from '@renderer/assets/images/models/adept.png'
import AdeptModelLogoDark from '@renderer/assets/images/models/adept_dark.png'
import Ai21ModelLogo from '@renderer/assets/images/models/ai21.png'
import Ai21ModelLogoDark from '@renderer/assets/images/models/ai21_dark.png'
import AimassModelLogo from '@renderer/assets/images/models/aimass.png'
import AimassModelLogoDark from '@renderer/assets/images/models/aimass_dark.png'
import AisingaporeModelLogo from '@renderer/assets/images/models/aisingapore.png'
import AisingaporeModelLogoDark from '@renderer/assets/images/models/aisingapore_dark.png'
import BaichuanModelLogo from '@renderer/assets/images/models/baichuan.png'
import BaichuanModelLogoDark from '@renderer/assets/images/models/baichuan_dark.png'
import BgeModelLogo from '@renderer/assets/images/models/bge.webp'
import BigcodeModelLogo from '@renderer/assets/images/models/bigcode.webp'
import BigcodeModelLogoDark from '@renderer/assets/images/models/bigcode_dark.webp'
import ChatGLMModelLogo from '@renderer/assets/images/models/chatglm.png'
import ChatGLMModelLogoDark from '@renderer/assets/images/models/chatglm_dark.png'
import ChatGptModelLogo from '@renderer/assets/images/models/chatgpt.jpeg'
import ClaudeModelLogo from '@renderer/assets/images/models/claude.png'
import ClaudeModelLogoDark from '@renderer/assets/images/models/claude_dark.png'
import CodegeexModelLogo from '@renderer/assets/images/models/codegeex.png'
import CodegeexModelLogoDark from '@renderer/assets/images/models/codegeex_dark.png'
import CodestralModelLogo from '@renderer/assets/images/models/codestral.png'
import CohereModelLogo from '@renderer/assets/images/models/cohere.png'
import CohereModelLogoDark from '@renderer/assets/images/models/cohere_dark.png'
import CopilotModelLogo from '@renderer/assets/images/models/copilot.png'
import CopilotModelLogoDark from '@renderer/assets/images/models/copilot_dark.png'
import DalleModelLogo from '@renderer/assets/images/models/dalle.png'
import DalleModelLogoDark from '@renderer/assets/images/models/dalle_dark.png'
import DbrxModelLogo from '@renderer/assets/images/models/dbrx.png'
import DeepSeekModelLogo from '@renderer/assets/images/models/deepseek.png'
import DeepSeekModelLogoDark from '@renderer/assets/images/models/deepseek_dark.png'
import DianxinModelLogo from '@renderer/assets/images/models/dianxin.png'
import DianxinModelLogoDark from '@renderer/assets/images/models/dianxin_dark.png'
import DoubaoModelLogo from '@renderer/assets/images/models/doubao.png'
import DoubaoModelLogoDark from '@renderer/assets/images/models/doubao_dark.png'
import EmbeddingModelLogo from '@renderer/assets/images/models/embedding.png'
import EmbeddingModelLogoDark from '@renderer/assets/images/models/embedding.png'
import FlashaudioModelLogo from '@renderer/assets/images/models/flashaudio.png'
import FlashaudioModelLogoDark from '@renderer/assets/images/models/flashaudio_dark.png'
import FluxModelLogo from '@renderer/assets/images/models/flux.png'
import FluxModelLogoDark from '@renderer/assets/images/models/flux_dark.png'
import GeminiModelLogo from '@renderer/assets/images/models/gemini.png'
import GeminiModelLogoDark from '@renderer/assets/images/models/gemini_dark.png'
import GemmaModelLogo from '@renderer/assets/images/models/gemma.png'
import GemmaModelLogoDark from '@renderer/assets/images/models/gemma_dark.png'
import GoogleModelLogo from '@renderer/assets/images/models/google.png'
import GoogleModelLogoDark from '@renderer/assets/images/models/google.png'
import ChatGPT35ModelLogo from '@renderer/assets/images/models/gpt_3.5.png'
import ChatGPT4ModelLogo from '@renderer/assets/images/models/gpt_4.png'
import ChatGptModelLogoDakr from '@renderer/assets/images/models/gpt_dark.png'
import ChatGPT35ModelLogoDark from '@renderer/assets/images/models/gpt_dark.png'
import ChatGPT4ModelLogoDark from '@renderer/assets/images/models/gpt_dark.png'
import ChatGPTo1ModelLogoDark from '@renderer/assets/images/models/gpt_dark.png'
import ChatGPTo1ModelLogo from '@renderer/assets/images/models/gpt_o1.png'
import GrokModelLogo from '@renderer/assets/images/models/grok.png'
import GrokModelLogoDark from '@renderer/assets/images/models/grok_dark.png'
import GrypheModelLogo from '@renderer/assets/images/models/gryphe.png'
import GrypheModelLogoDark from '@renderer/assets/images/models/gryphe_dark.png'
import HailuoModelLogo from '@renderer/assets/images/models/hailuo.png'
import HailuoModelLogoDark from '@renderer/assets/images/models/hailuo_dark.png'
import HuggingfaceModelLogo from '@renderer/assets/images/models/huggingface.png'
import HuggingfaceModelLogoDark from '@renderer/assets/images/models/huggingface_dark.png'
import HunyuanModelLogo from '@renderer/assets/images/models/hunyuan.png'
import HunyuanModelLogoDark from '@renderer/assets/images/models/hunyuan_dark.png'
import IbmModelLogo from '@renderer/assets/images/models/ibm.png'
import IbmModelLogoDark from '@renderer/assets/images/models/ibm_dark.png'
import InternlmModelLogo from '@renderer/assets/images/models/internlm.png'
import InternlmModelLogoDark from '@renderer/assets/images/models/internlm_dark.png'
import InternvlModelLogo from '@renderer/assets/images/models/internvl.png'
import JinaModelLogo from '@renderer/assets/images/models/jina.png'
import JinaModelLogoDark from '@renderer/assets/images/models/jina_dark.png'
import KeLingModelLogo from '@renderer/assets/images/models/keling.png'
import KeLingModelLogoDark from '@renderer/assets/images/models/keling_dark.png'
import LlamaModelLogo from '@renderer/assets/images/models/llama.png'
import LlamaModelLogoDark from '@renderer/assets/images/models/llama_dark.png'
import LLavaModelLogo from '@renderer/assets/images/models/llava.png'
import LLavaModelLogoDark from '@renderer/assets/images/models/llava_dark.png'
import LumaModelLogo from '@renderer/assets/images/models/luma.png'
import LumaModelLogoDark from '@renderer/assets/images/models/luma_dark.png'
import MagicModelLogo from '@renderer/assets/images/models/magic.png'
import MagicModelLogoDark from '@renderer/assets/images/models/magic_dark.png'
import MediatekModelLogo from '@renderer/assets/images/models/mediatek.png'
import MediatekModelLogoDark from '@renderer/assets/images/models/mediatek_dark.png'
import MicrosoftModelLogo from '@renderer/assets/images/models/microsoft.png'
import MicrosoftModelLogoDark from '@renderer/assets/images/models/microsoft_dark.png'
import MidjourneyModelLogo from '@renderer/assets/images/models/midjourney.png'
import MidjourneyModelLogoDark from '@renderer/assets/images/models/midjourney_dark.png'
import MinicpmModelLogo from '@renderer/assets/images/models/minicpm.webp'
import MinicpmModelLogoDark from '@renderer/assets/images/models/minicpm.webp'
import MinimaxModelLogo from '@renderer/assets/images/models/minimax.png'
import MinimaxModelLogoDark from '@renderer/assets/images/models/minimax_dark.png'
import MistralModelLogo from '@renderer/assets/images/models/mixtral.png'
import MistralModelLogoDark from '@renderer/assets/images/models/mixtral_dark.png'
import MoonshotModelLogo from '@renderer/assets/images/models/moonshot.png'
import MoonshotModelLogoDark from '@renderer/assets/images/models/moonshot_dark.png'
import NousResearchModelLogo from '@renderer/assets/images/models/nousresearch.png'
import NousResearchModelLogoDark from '@renderer/assets/images/models/nousresearch.png'
import NvidiaModelLogo from '@renderer/assets/images/models/nvidia.png'
import NvidiaModelLogoDark from '@renderer/assets/images/models/nvidia_dark.png'
import PalmModelLogo from '@renderer/assets/images/models/palm.png'
import PalmModelLogoDark from '@renderer/assets/images/models/palm_dark.png'
import PerplexityModelLogo from '@renderer/assets/images/models/perplexity.png'
import PerplexityModelLogoDark from '@renderer/assets/images/models/perplexity.png'
import PixtralModelLogo from '@renderer/assets/images/models/pixtral.png'
import PixtralModelLogoDark from '@renderer/assets/images/models/pixtral_dark.png'
import QwenModelLogo from '@renderer/assets/images/models/qwen.png'
import QwenModelLogoDark from '@renderer/assets/images/models/qwen_dark.png'
import RakutenaiModelLogo from '@renderer/assets/images/models/rakutenai.png'
import RakutenaiModelLogoDark from '@renderer/assets/images/models/rakutenai_dark.png'
import SparkDeskModelLogo from '@renderer/assets/images/models/sparkdesk.png'
import SparkDeskModelLogoDark from '@renderer/assets/images/models/sparkdesk_dark.png'
import StabilityModelLogo from '@renderer/assets/images/models/stability.png'
import StabilityModelLogoDark from '@renderer/assets/images/models/stability_dark.png'
import StepModelLogo from '@renderer/assets/images/models/step.png'
import StepModelLogoDark from '@renderer/assets/images/models/step_dark.png'
import SunoModelLogo from '@renderer/assets/images/models/suno.png'
import SunoModelLogoDark from '@renderer/assets/images/models/suno_dark.png'
import TeleModelLogo from '@renderer/assets/images/models/tele.png'
import TeleModelLogoDark from '@renderer/assets/images/models/tele_dark.png'
import UpstageModelLogo from '@renderer/assets/images/models/upstage.png'
import UpstageModelLogoDark from '@renderer/assets/images/models/upstage_dark.png'
import ViduModelLogo from '@renderer/assets/images/models/vidu.png'
import ViduModelLogoDark from '@renderer/assets/images/models/vidu_dark.png'
import VoyageModelLogo from '@renderer/assets/images/models/voyageai.png'
import WenxinModelLogo from '@renderer/assets/images/models/wenxin.png'
import WenxinModelLogoDark from '@renderer/assets/images/models/wenxin_dark.png'
import XirangModelLogo from '@renderer/assets/images/models/xirang.png'
import XirangModelLogoDark from '@renderer/assets/images/models/xirang_dark.png'
import YiModelLogo from '@renderer/assets/images/models/yi.png'
import YiModelLogoDark from '@renderer/assets/images/models/yi_dark.png'
import { getProviderByModel } from '@renderer/services/AssistantService'
import { Assistant, Model } from '@renderer/types'
import OpenAI from 'openai'
import { getWebSearchTools } from './tools'
// Vision models
const visionAllowedModels = [
'llava',
'moondream',
'minicpm',
'gemini-1\\.5',
'gemini-2\\.0',
'gemini-exp',
'claude-3',
'vision',
'glm-4v',
'qwen-vl',
'qwen2-vl',
'qwen2.5-vl',
'qvq',
'internvl2',
'grok-vision-beta',
'pixtral',
'gpt-4(?:-[\\w-]+)',
'gpt-4o(?:-[\\w-]+)?',
'chatgpt-4o(?:-[\\w-]+)?',
'o1(?:-[\\w-]+)?',
'deepseek-vl(?:[\\w-]+)?',
'kimi-latest',
'gemma-3(?:-[\\w-]+)'
]
const visionExcludedModels = ['gpt-4-\\d+-preview', 'gpt-4-turbo-preview', 'gpt-4-32k', 'gpt-4-\\d+']
export const VISION_REGEX = new RegExp(
`\\b(?!(?:${visionExcludedModels.join('|')})\\b)(${visionAllowedModels.join('|')})\\b`,
'i'
)
// Text to image models
export const TEXT_TO_IMAGE_REGEX = /flux|diffusion|stabilityai|sd-|dall|cogview|janus/i
// Reasoning models
export const REASONING_REGEX =
/^(o\d+(?:-[\w-]+)?|.*\b(?:reasoner|thinking)\b.*|.*-[rR]\d+.*|.*\bqwq(?:-[\w-]+)?\b.*|.*\bhunyuan-t1(?:-[\w-]+)?\b.*)$/i
// Embedding models
export const EMBEDDING_REGEX =
/(?:^text-|embed|bge-|e5-|LLM2Vec|retrieval|uae-|gte-|jina-clip|jina-embeddings|voyage-)/i
// Rerank models
export const RERANKING_REGEX = /(?:rerank|re-rank|re-ranker|re-ranking|retrieval|retriever)/i
export const NOT_SUPPORTED_REGEX = /(?:^tts|whisper|speech)/i
// Tool calling models
export const FUNCTION_CALLING_MODELS = [
'gpt-4o',
'gpt-4o-mini',
'gpt-4',
'gpt-4.5',
'claude',
'qwen',
'hunyuan',
'glm-4(?:-[\\w-]+)?',
'learnlm(?:-[\\w-]+)?',
'gemini(?:-[\\w-]+)?' // 提前排除了gemini的嵌入模型
]
const FUNCTION_CALLING_EXCLUDED_MODELS = ['aqa(?:-[\\w-]+)?', 'imagen(?:-[\\w-]+)?']
export const FUNCTION_CALLING_REGEX = new RegExp(
`\\b(?!(?:${FUNCTION_CALLING_EXCLUDED_MODELS.join('|')})\\b)(?:${FUNCTION_CALLING_MODELS.join('|')})\\b`,
'i'
)
export function isFunctionCallingModel(model: Model): boolean {
if (model.type?.includes('function_calling')) {
return true
}
if (isEmbeddingModel(model)) {
return false
}
if (['deepseek', 'anthropic'].includes(model.provider)) {
return true
}
return FUNCTION_CALLING_REGEX.test(model.id)
}
export function getModelLogo(modelId: string) {
const isLight = true
if (!modelId) {
return undefined
}
const logoMap = {
pixtral: isLight ? PixtralModelLogo : PixtralModelLogoDark,
jina: isLight ? JinaModelLogo : JinaModelLogoDark,
abab: isLight ? MinimaxModelLogo : MinimaxModelLogoDark,
minimax: isLight ? MinimaxModelLogo : MinimaxModelLogoDark,
o3: isLight ? ChatGPTo1ModelLogo : ChatGPTo1ModelLogoDark,
o1: isLight ? ChatGPTo1ModelLogo : ChatGPTo1ModelLogoDark,
'gpt-3': isLight ? ChatGPT35ModelLogo : ChatGPT35ModelLogoDark,
'gpt-4': isLight ? ChatGPT4ModelLogo : ChatGPT4ModelLogoDark,
gpts: isLight ? ChatGPT4ModelLogo : ChatGPT4ModelLogoDark,
'text-moderation': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'babbage-': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'sora-': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'(^|/)omni-': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'Embedding-V1': isLight ? WenxinModelLogo : WenxinModelLogoDark,
'text-embedding-v': isLight ? QwenModelLogo : QwenModelLogoDark,
'text-embedding': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'davinci-': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
glm: isLight ? ChatGLMModelLogo : ChatGLMModelLogoDark,
deepseek: isLight ? DeepSeekModelLogo : DeepSeekModelLogoDark,
'(qwen|qwq-|qvq-)': isLight ? QwenModelLogo : QwenModelLogoDark,
gemma: isLight ? GemmaModelLogo : GemmaModelLogoDark,
'yi-': isLight ? YiModelLogo : YiModelLogoDark,
llama: isLight ? LlamaModelLogo : LlamaModelLogoDark,
mixtral: isLight ? MistralModelLogo : MistralModelLogo,
mistral: isLight ? MistralModelLogo : MistralModelLogoDark,
codestral: CodestralModelLogo,
ministral: isLight ? MistralModelLogo : MistralModelLogoDark,
moonshot: isLight ? MoonshotModelLogo : MoonshotModelLogoDark,
kimi: isLight ? MoonshotModelLogo : MoonshotModelLogoDark,
phi: isLight ? MicrosoftModelLogo : MicrosoftModelLogoDark,
baichuan: isLight ? BaichuanModelLogo : BaichuanModelLogoDark,
claude: isLight ? ClaudeModelLogo : ClaudeModelLogoDark,
gemini: isLight ? GeminiModelLogo : GeminiModelLogoDark,
bison: isLight ? PalmModelLogo : PalmModelLogoDark,
palm: isLight ? PalmModelLogo : PalmModelLogoDark,
step: isLight ? StepModelLogo : StepModelLogoDark,
hailuo: isLight ? HailuoModelLogo : HailuoModelLogoDark,
doubao: isLight ? DoubaoModelLogo : DoubaoModelLogoDark,
'ep-202': isLight ? DoubaoModelLogo : DoubaoModelLogoDark,
cohere: isLight ? CohereModelLogo : CohereModelLogoDark,
command: isLight ? CohereModelLogo : CohereModelLogoDark,
minicpm: isLight ? MinicpmModelLogo : MinicpmModelLogoDark,
'360': isLight ? Ai360ModelLogo : Ai360ModelLogoDark,
aimass: isLight ? AimassModelLogo : AimassModelLogoDark,
codegeex: isLight ? CodegeexModelLogo : CodegeexModelLogoDark,
copilot: isLight ? CopilotModelLogo : CopilotModelLogoDark,
creative: isLight ? CopilotModelLogo : CopilotModelLogoDark,
balanced: isLight ? CopilotModelLogo : CopilotModelLogoDark,
precise: isLight ? CopilotModelLogo : CopilotModelLogoDark,
dalle: isLight ? DalleModelLogo : DalleModelLogoDark,
'dall-e': isLight ? DalleModelLogo : DalleModelLogoDark,
dbrx: isLight ? DbrxModelLogo : DbrxModelLogo,
flashaudio: isLight ? FlashaudioModelLogo : FlashaudioModelLogoDark,
flux: isLight ? FluxModelLogo : FluxModelLogoDark,
grok: isLight ? GrokModelLogo : GrokModelLogoDark,
hunyuan: isLight ? HunyuanModelLogo : HunyuanModelLogoDark,
internlm: isLight ? InternlmModelLogo : InternlmModelLogoDark,
internvl: InternvlModelLogo,
llava: isLight ? LLavaModelLogo : LLavaModelLogoDark,
magic: isLight ? MagicModelLogo : MagicModelLogoDark,
midjourney: isLight ? MidjourneyModelLogo : MidjourneyModelLogoDark,
'mj-': isLight ? MidjourneyModelLogo : MidjourneyModelLogoDark,
'tao-': isLight ? WenxinModelLogo : WenxinModelLogoDark,
'ernie-': isLight ? WenxinModelLogo : WenxinModelLogoDark,
voice: isLight ? FlashaudioModelLogo : FlashaudioModelLogoDark,
'tts-1': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'whisper-': isLight ? ChatGptModelLogo : ChatGptModelLogoDakr,
'stable-': isLight ? StabilityModelLogo : StabilityModelLogoDark,
sd2: isLight ? StabilityModelLogo : StabilityModelLogoDark,
sd3: isLight ? StabilityModelLogo : StabilityModelLogoDark,
sdxl: isLight ? StabilityModelLogo : StabilityModelLogoDark,
sparkdesk: isLight ? SparkDeskModelLogo : SparkDeskModelLogoDark,
generalv: isLight ? SparkDeskModelLogo : SparkDeskModelLogoDark,
wizardlm: isLight ? MicrosoftModelLogo : MicrosoftModelLogoDark,
microsoft: isLight ? MicrosoftModelLogo : MicrosoftModelLogoDark,
hermes: isLight ? NousResearchModelLogo : NousResearchModelLogoDark,
gryphe: isLight ? GrypheModelLogo : GrypheModelLogoDark,
suno: isLight ? SunoModelLogo : SunoModelLogoDark,
chirp: isLight ? SunoModelLogo : SunoModelLogoDark,
luma: isLight ? LumaModelLogo : LumaModelLogoDark,
keling: isLight ? KeLingModelLogo : KeLingModelLogoDark,
'vidu-': isLight ? ViduModelLogo : ViduModelLogoDark,
ai21: isLight ? Ai21ModelLogo : Ai21ModelLogoDark,
'jamba-': isLight ? Ai21ModelLogo : Ai21ModelLogoDark,
mythomax: isLight ? GrypheModelLogo : GrypheModelLogoDark,
nvidia: isLight ? NvidiaModelLogo : NvidiaModelLogoDark,
dianxin: isLight ? DianxinModelLogo : DianxinModelLogoDark,
tele: isLight ? TeleModelLogo : TeleModelLogoDark,
adept: isLight ? AdeptModelLogo : AdeptModelLogoDark,
aisingapore: isLight ? AisingaporeModelLogo : AisingaporeModelLogoDark,
bigcode: isLight ? BigcodeModelLogo : BigcodeModelLogoDark,
mediatek: isLight ? MediatekModelLogo : MediatekModelLogoDark,
upstage: isLight ? UpstageModelLogo : UpstageModelLogoDark,
rakutenai: isLight ? RakutenaiModelLogo : RakutenaiModelLogoDark,
ibm: isLight ? IbmModelLogo : IbmModelLogoDark,
'google/': isLight ? GoogleModelLogo : GoogleModelLogoDark,
xirang: isLight ? XirangModelLogo : XirangModelLogoDark,
hugging: isLight ? HuggingfaceModelLogo : HuggingfaceModelLogoDark,
embedding: isLight ? EmbeddingModelLogo : EmbeddingModelLogoDark,
perplexity: isLight ? PerplexityModelLogo : PerplexityModelLogoDark,
sonar: isLight ? PerplexityModelLogo : PerplexityModelLogoDark,
'bge-': BgeModelLogo,
'voyage-': VoyageModelLogo
}
for (const key in logoMap) {
const regex = new RegExp(key, 'i')
if (regex.test(modelId)) {
return logoMap[key]
}
}
return undefined
}
export const SYSTEM_MODELS: Record<string, Model[]> = {
aihubmix: [
{
id: 'gpt-4o',
provider: 'aihubmix',
name: 'GPT-4o',
group: 'GPT-4o'
},
{
id: 'claude-3-5-sonnet-latest',
provider: 'aihubmix',
name: 'Claude 3.5 Sonnet',
group: 'Claude 3.5'
},
{
id: 'gemini-2.0-flash-exp-search',
provider: 'aihubmix',
name: 'Gemini 2.0 Flash Exp Search',
group: 'Gemini 2.0'
},
{
id: 'deepseek-chat',
provider: 'aihubmix',
name: 'DeepSeek Chat',
group: 'DeepSeek Chat'
},
{
id: 'aihubmix-Llama-3-3-70B-Instruct',
provider: 'aihubmix',
name: 'Llama-3.3-70b',
group: 'Llama 3.3'
},
{
id: 'Qwen/QVQ-72B-Preview',
provider: 'aihubmix',
name: 'Qwen/QVQ-72B',
group: 'Qwen'
}
],
o3: [
{
id: 'gpt-4o',
provider: 'o3',
name: 'GPT-4o',
group: 'OpenAI'
},
{
id: 'o1-mini',
provider: 'o3',
name: 'o1-mini',
group: 'OpenAI'
},
{
id: 'o1-preview',
provider: 'o3',
name: 'o1-preview',
group: 'OpenAI'
},
{
id: 'o3-mini',
provider: 'o3',
name: 'o3-mini',
group: 'OpenAI'
},
{
id: 'o3-mini-high',
provider: 'o3',
name: 'o3-mini-high',
group: 'OpenAI'
},
{
id: 'claude-3-7-sonnet-20250219',
provider: 'o3',
name: 'claude-3-7-sonnet-20250219',
group: 'Anthropic'
},
{
id: 'claude-3-5-sonnet-20241022',
provider: 'o3',
name: 'claude-3-5-sonnet-20241022',
group: 'Anthropic'
},
{
id: 'claude-3-5-haiku-20241022',
provider: 'o3',
name: 'claude-3-5-haiku-20241022',
group: 'Anthropic'
},
{
id: 'claude-3-opus-20240229',
provider: 'o3',
name: 'claude-3-opus-20240229',
group: 'Anthropic'
},
{
id: 'claude-3-haiku-20240307',
provider: 'o3',
name: 'claude-3-haiku-20240307',
group: 'Anthropic'
},
{
id: 'claude-3-5-sonnet-20240620',
provider: 'o3',
name: 'claude-3-5-sonnet-20240620',
group: 'Anthropic'
},
{
id: 'deepseek-ai/Deepseek-R1',
provider: 'o3',
name: 'DeepSeek R1',
group: 'DeepSeek'
},
{
id: 'deepseek-reasoner',
provider: 'o3',
name: 'deepseek-reasoner',
group: 'DeepSeek'
},
{
id: 'deepseek-chat',
provider: 'o3',
name: 'deepseek-chat',
group: 'DeepSeek'
},
{
id: 'deepseek-ai/DeepSeek-V3',
provider: 'o3',
name: 'DeepSeek V3',
group: 'DeepSeek'
},
{
id: 'text-embedding-3-small',
provider: 'o3',
name: 'text-embedding-3-small',
group: '嵌入模型'
},
{
id: 'text-embedding-3-small',
provider: 'o3',
name: 'text-embedding-3-small',
group: '嵌入模型'
},
{
id: 'text-embedding-ada-002',
provider: 'o3',
name: 'text-embedding-ada-002',
group: '嵌入模型'
},
{
id: 'text-embedding-v2',
provider: 'o3',
name: 'text-embedding-v2',
group: '嵌入模型'
},
{
id: 'Doubao-embedding',
provider: 'o3',
name: 'Doubao-embedding',
group: '嵌入模型'
},
{
id: 'Doubao-embedding-large',
provider: 'o3',
name: 'Doubao-embedding-large',
group: '嵌入模型'
}
],
ollama: [],
lmstudio: [],
silicon: [
{
id: 'deepseek-ai/DeepSeek-R1',
name: 'deepseek-ai/DeepSeek-R1',
provider: 'silicon',
group: 'deepseek-ai'
},
{
id: 'deepseek-ai/DeepSeek-V3',
name: 'deepseek-ai/DeepSeek-V3',
provider: 'silicon',
group: 'deepseek-ai'
},
{
id: 'Qwen/Qwen2.5-7B-Instruct',
provider: 'silicon',
name: 'Qwen2.5-7B-Instruct',
group: 'Qwen'
},
{
id: 'meta-llama/Llama-3.3-70B-Instruct',
name: 'meta-llama/Llama-3.3-70B-Instruct',
provider: 'silicon',
group: 'meta-llama'
},
{
id: 'BAAI/bge-m3',
name: 'BAAI/bge-m3',
provider: 'silicon',
group: 'BAAI'
}
],
ppio: [
{
id: 'deepseek/deepseek-r1/community',
name: 'DeepSeek: DeepSeek R1 (Community)',
provider: 'ppio',
group: 'deepseek'
},
{
id: 'deepseek/deepseek-v3/community',
name: 'DeepSeek: DeepSeek V3 (Community)',
provider: 'ppio',
group: 'deepseek'
},
{
id: 'deepseek/deepseek-r1',
provider: 'ppio',
name: 'DeepSeek R1',
group: 'deepseek'
},
{
id: 'deepseek/deepseek-v3',
provider: 'ppio',
name: 'DeepSeek V3',
group: 'deepseek'
},
{
id: 'qwen/qwen-2.5-72b-instruct',
provider: 'ppio',
name: 'Qwen2.5-72B-Instruct',
group: 'qwen'
},
{
id: 'qwen/qwen2.5-32b-instruct',
provider: 'ppio',
name: 'Qwen2.5-32B-Instruct',
group: 'qwen'
},
{
id: 'meta-llama/llama-3.1-70b-instruct',
provider: 'ppio',
name: 'Llama-3.1-70B-Instruct',
group: 'meta-llama'
},
{
id: 'meta-llama/llama-3.1-8b-instruct',
provider: 'ppio',
name: 'Llama-3.1-8B-Instruct',
group: 'meta-llama'
},
{
id: '01-ai/yi-1.5-34b-chat',
provider: 'ppio',
name: 'Yi-1.5-34B-Chat',
group: '01-ai'
},
{
id: '01-ai/yi-1.5-9b-chat',
provider: 'ppio',
name: 'Yi-1.5-9B-Chat',
group: '01-ai'
}
],
alayanew: [],
openai: [
{ id: 'gpt-4.5-preview', provider: 'openai', name: ' gpt-4.5-preview', group: 'gpt-4.5' },
{ id: 'gpt-4o', provider: 'openai', name: ' GPT-4o', group: 'GPT 4o' },
{ id: 'gpt-4o-mini', provider: 'openai', name: ' GPT-4o-mini', group: 'GPT 4o' },
{ id: 'o1-mini', provider: 'openai', name: ' o1-mini', group: 'o1' },
{ id: 'o1-preview', provider: 'openai', name: ' o1-preview', group: 'o1' }
],
'azure-openai': [
{
id: 'gpt-4o',
provider: 'azure-openai',
name: ' GPT-4o',
group: 'GPT 4o'
},
{
id: 'gpt-4o-mini',
provider: 'azure-openai',
name: ' GPT-4o-mini',
group: 'GPT 4o'
}
],
gemini: [
{
id: 'gemini-1.5-flash',
provider: 'gemini',
name: 'Gemini 1.5 Flash',
group: 'Gemini 1.5'
},
{
id: 'gemini-1.5-flash-8b',
provider: 'gemini',
name: 'Gemini 1.5 Flash (8B)',
group: 'Gemini 1.5'
},
{
id: 'gemini-1.5-pro',
name: 'Gemini 1.5 Pro',
provider: 'gemini',
group: 'Gemini 1.5'
},
{
id: 'gemini-2.0-flash',
provider: 'gemini',
name: 'Gemini 2.0 Flash',
group: 'Gemini 2.0'
}
],
anthropic: [
{
id: 'claude-3-7-sonnet-20250219',
provider: 'anthropic',
name: 'Claude 3.7 Sonnet',
group: 'Claude 3.7'
},
{
id: 'claude-3-5-sonnet-20241022',
provider: 'anthropic',
name: 'Claude 3.5 Sonnet',
group: 'Claude 3.5'
},
{
id: 'claude-3-5-haiku-20241022',
provider: 'anthropic',
name: 'Claude 3.5 Haiku',
group: 'Claude 3.5'
},
{
id: 'claude-3-5-sonnet-20240620',
provider: 'anthropic',
name: 'Claude 3.5 Sonnet (Legacy)',
group: 'Claude 3.5'
},
{
id: 'claude-3-opus-20240229',
provider: 'anthropic',
name: 'Claude 3 Opus',
group: 'Claude 3'
},
{
id: 'claude-3-haiku-20240307',
provider: 'anthropic',
name: 'Claude 3 Haiku',
group: 'Claude 3'
}
],
'gitee-ai': [
{
id: 'DeepSeek-R1-Distill-Qwen-32B',
name: 'DeepSeek-R1-Distill-Qwen-32B',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'DeepSeek-R1-Distill-Qwen-1.5B',
name: 'DeepSeek-R1-Distill-Qwen-1.5B',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'DeepSeek-R1-Distill-Qwen-14B',
name: 'DeepSeek-R1-Distill-Qwen-14B',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'DeepSeek-R1-Distill-Qwen-7B',
name: 'DeepSeek-R1-Distill-Qwen-7B',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'DeepSeek-V3',
name: 'DeepSeek-V3',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'DeepSeek-R1',
name: 'DeepSeek-R1',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'deepseek-coder-33B-instruct',
name: 'deepseek-coder-33B-instruct',
provider: 'gitee-ai',
group: 'DeepSeek'
},
{
id: 'Qwen2.5-72B-Instruct',
name: 'Qwen2.5-72B-Instruct',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'Qwen2.5-14B-Instruct',
name: 'Qwen2.5-14B-Instruct',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'Qwen2-7B-Instruct',
name: 'Qwen2-7B-Instruct',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'Qwen2.5-32B-Instruct',
name: 'Qwen2.5-32B-Instruct',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'Qwen2-72B-Instruct',
name: 'Qwen2-72B-Instruct',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'Qwen2-VL-72B',
name: 'Qwen2-VL-72B',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'QwQ-32B-Preview',
name: 'QwQ-32B-Preview',
provider: 'gitee-ai',
group: 'Qwen'
},
{
id: 'Yi-34B-Chat',
name: 'Yi-34B-Chat',
provider: 'gitee-ai',
group: '01-ai'
},
{
id: 'glm-4-9b-chat',
name: 'glm-4-9b-chat',
provider: 'gitee-ai',
group: 'THUDM'
},
{
id: 'codegeex4-all-9b',
name: 'codegeex4-all-9b',
provider: 'gitee-ai',
group: 'THUDM'
},
{
id: 'InternVL2-8B',
name: 'InternVL2-8B',
provider: 'gitee-ai',
group: 'OpenGVLab'
},
{
id: 'InternVL2.5-26B',
name: 'InternVL2.5-26B',
provider: 'gitee-ai',
group: 'OpenGVLab'
},
{
id: 'InternVL2.5-78B',
name: 'InternVL2.5-78B',
provider: 'gitee-ai',
group: 'OpenGVLab'
},
{
id: 'bge-large-zh-v1.5',
name: 'bge-large-zh-v1.5',
provider: 'gitee-ai',
group: 'BAAI'
},
{
id: 'bge-small-zh-v1.5',
name: 'bge-small-zh-v1.5',
provider: 'gitee-ai',
group: 'BAAI'
},
{
id: 'bge-m3',
name: 'bge-m3',
provider: 'gitee-ai',
group: 'BAAI'
},
{
id: 'bce-embedding-base_v1',
name: 'bce-embedding-base_v1',
provider: 'gitee-ai',
group: 'netease-youdao'
}
],
deepseek: [
{
id: 'deepseek-chat',
provider: 'deepseek',
name: 'DeepSeek Chat',
group: 'DeepSeek Chat'
},
{
id: 'deepseek-reasoner',
provider: 'deepseek',
name: 'DeepSeek Reasoner',
group: 'DeepSeek Reasoner'
}
],
together: [
{
id: 'meta-llama/Llama-3.2-11B-Vision-Instruct-Turbo',
provider: 'together',
name: 'Llama-3.2-11B-Vision',
group: 'Llama-3.2'
},
{
id: 'meta-llama/Llama-3.2-90B-Vision-Instruct-Turbo',
provider: 'together',
name: 'Llama-3.2-90B-Vision',
group: 'Llama-3.2'
},
{
id: 'google/gemma-2-27b-it',
provider: 'together',
name: 'gemma-2-27b-it',
group: 'Gemma'
},
{
id: 'google/gemma-2-9b-it',
provider: 'together',
name: 'gemma-2-9b-it',
group: 'Gemma'
}
],
ocoolai: [
{
id: 'deepseek-chat',
provider: 'ocoolai',
name: 'deepseek-chat',
group: 'DeepSeek'
},
{
id: 'deepseek-reasoner',
provider: 'ocoolai',
name: 'deepseek-reasoner',
group: 'DeepSeek'
},
{
id: 'deepseek-ai/DeepSeek-R1',
provider: 'ocoolai',
name: 'deepseek-ai/DeepSeek-R1',
group: 'DeepSeek'
},
{
id: 'HiSpeed/DeepSeek-R1',
provider: 'ocoolai',
name: 'HiSpeed/DeepSeek-R1',
group: 'DeepSeek'
},
{
id: 'ocoolAI/DeepSeek-R1',
provider: 'ocoolai',
name: 'ocoolAI/DeepSeek-R1',
group: 'DeepSeek'
},
{
id: 'Azure/DeepSeek-R1',
provider: 'ocoolai',
name: 'Azure/DeepSeek-R1',
group: 'DeepSeek'
},
{
id: 'gpt-4o',
provider: 'ocoolai',
name: 'gpt-4o',
group: 'OpenAI'
},
{
id: 'gpt-4o-all',
provider: 'ocoolai',
name: 'gpt-4o-all',
group: 'OpenAI'
},
{
id: 'gpt-4o-mini',
provider: 'ocoolai',
name: 'gpt-4o-mini',
group: 'OpenAI'
},
{
id: 'gpt-4',
provider: 'ocoolai',
name: 'gpt-4',
group: 'OpenAI'
},
{
id: 'o1-preview',
provider: 'ocoolai',
name: 'o1-preview',
group: 'OpenAI'
},
{
id: 'o1-mini',
provider: 'ocoolai',
name: 'o1-mini',
group: 'OpenAI'
},
{
id: 'claude-3-5-sonnet-20240620',
provider: 'ocoolai',
name: 'claude-3-5-sonnet-20240620',
group: 'Anthropic'
},
{
id: 'claude-3-5-haiku-20241022',
provider: 'ocoolai',
name: 'claude-3-5-haiku-20241022',
group: 'Anthropic'
},
{
id: 'gemini-pro',
provider: 'ocoolai',
name: 'gemini-pro',
group: 'Gemini'
},
{
id: 'gemini-1.5-pro',
provider: 'ocoolai',
name: 'gemini-1.5-pro',
group: 'Gemini'
},
{
id: 'meta-llama/Llama-3.2-90B-Vision-Instruct-Turbo',
provider: 'ocoolai',
name: 'Llama-3.2-90B-Vision-Instruct-Turbo',
group: 'Llama-3.2'
},
{
id: 'meta-llama/Llama-3.2-11B-Vision-Instruct-Turbo',
provider: 'ocoolai',
name: 'Llama-3.2-11B-Vision-Instruct-Turbo',
group: 'Llama-3.2'
},
{
id: 'meta-llama/Llama-3.2-3B-Vision-Instruct-Turbo',
provider: 'ocoolai',
name: 'Llama-3.2-3B-Vision-Instruct-Turbo',
group: 'Llama-3.2'
},
{
id: 'google/gemma-2-27b-it',
provider: 'ocoolai',
name: 'gemma-2-27b-it',
group: 'Gemma'
},
{
id: 'google/gemma-2-9b-it',
provider: 'ocoolai',
name: 'gemma-2-9b-it',
group: 'Gemma'
},
{
id: 'Doubao-embedding',
provider: 'ocoolai',
name: 'Doubao-embedding',
group: 'Doubao'
},
{
id: 'text-embedding-3-large',
provider: 'ocoolai',
name: 'text-embedding-3-large',
group: 'Embedding'
},
{
id: 'text-embedding-3-small',
provider: 'ocoolai',
name: 'text-embedding-3-small',
group: 'Embedding'
},
{
id: 'text-embedding-v2',
provider: 'ocoolai',
name: 'text-embedding-v2',
group: 'Embedding'
}
],
github: [
{
id: 'gpt-4o',
provider: 'github',
name: 'OpenAI GPT-4o',
group: 'OpenAI'
}
],
copilot: [
{
id: 'gpt-4o-mini',
provider: 'copilot',
name: 'OpenAI GPT-4o-mini',
group: 'OpenAI'
}
],
yi: [
{ id: 'yi-lightning', name: 'Yi Lightning', provider: 'yi', group: 'yi-lightning', owned_by: '01.ai' },
{ id: 'yi-vision-v2', name: 'Yi Vision v2', provider: 'yi', group: 'yi-vision', owned_by: '01.ai' }
],
zhipu: [
{
id: 'glm-zero-preview',
provider: 'zhipu',
name: 'GLM-Zero-Preview',
group: 'GLM-Zero'
},
{
id: 'glm-4-0520',
provider: 'zhipu',
name: 'GLM-4-0520',
group: 'GLM-4'
},
{
id: 'glm-4-long',
provider: 'zhipu',
name: 'GLM-4-Long',
group: 'GLM-4'
},
{
id: 'glm-4-plus',
provider: 'zhipu',
name: 'GLM-4-Plus',
group: 'GLM-4'
},
{
id: 'glm-4-air',
provider: 'zhipu',
name: 'GLM-4-Air',
group: 'GLM-4'
},
{
id: 'glm-4-airx',
provider: 'zhipu',
name: 'GLM-4-AirX',
group: 'GLM-4'
},
{
id: 'glm-4-flash',
provider: 'zhipu',
name: 'GLM-4-Flash',
group: 'GLM-4'
},
{
id: 'glm-4-flashx',
provider: 'zhipu',
name: 'GLM-4-FlashX',
group: 'GLM-4'
},
{
id: 'glm-4v',
provider: 'zhipu',
name: 'GLM 4V',
group: 'GLM-4v'
},
{
id: 'glm-4v-flash',
provider: 'zhipu',
name: 'GLM-4V-Flash',
group: 'GLM-4v'
},
{
id: 'glm-4v-plus',
provider: 'zhipu',
name: 'GLM-4V-Plus',
group: 'GLM-4v'
},
{
id: 'glm-4-alltools',
provider: 'zhipu',
name: 'GLM-4-AllTools',
group: 'GLM-4-AllTools'
},
{
id: 'embedding-3',
provider: 'zhipu',
name: 'Embedding-3',
group: 'Embedding'
}
],
moonshot: [
{
id: 'moonshot-v1-auto',
name: 'moonshot-v1-auto',
provider: 'moonshot',
group: 'moonshot-v1',
owned_by: 'moonshot'
}
],
baichuan: [
{
id: 'Baichuan4',
provider: 'baichuan',
name: 'Baichuan4',
group: 'Baichuan4'
},
{
id: 'Baichuan3-Turbo',
provider: 'baichuan',
name: 'Baichuan3 Turbo',
group: 'Baichuan3'
},
{
id: 'Baichuan3-Turbo-128k',
provider: 'baichuan',
name: 'Baichuan3 Turbo 128k',
group: 'Baichuan3'
}
],
modelscope: [
{
id: 'Qwen/Qwen2.5-72B-Instruct',
name: 'Qwen/Qwen2.5-72B-Instruct',
provider: 'modelscope',
group: 'Qwen'
},
{
id: 'Qwen/Qwen2.5-VL-72B-Instruct',
name: 'Qwen/Qwen2.5-VL-72B-Instruct',
provider: 'modelscope',
group: 'Qwen'
},
{
id: 'Qwen/Qwen2.5-Coder-32B-Instruct',
name: 'Qwen/Qwen2.5-Coder-32B-Instruct',
provider: 'modelscope',
group: 'Qwen'
},
{
id: 'deepseek-ai/DeepSeek-R1',
name: 'deepseek-ai/DeepSeek-R1',
provider: 'modelscope',
group: 'deepseek-ai'
},
{
id: 'deepseek-ai/DeepSeek-V3',
name: 'deepseek-ai/DeepSeek-V3',
provider: 'modelscope',
group: 'deepseek-ai'
}
],
bailian: [
{ id: 'qwen-vl-plus', name: 'qwen-vl-plus', provider: 'dashscope', group: 'qwen-vl', owned_by: 'system' },
{ id: 'qwen-coder-plus', name: 'qwen-coder-plus', provider: 'dashscope', group: 'qwen-coder', owned_by: 'system' },
{ id: 'qwen-turbo', name: 'qwen-turbo', provider: 'dashscope', group: 'qwen-turbo', owned_by: 'system' },
{ id: 'qwen-plus', name: 'qwen-plus', provider: 'dashscope', group: 'qwen-plus', owned_by: 'system' },
{ id: 'qwen-max', name: 'qwen-max', provider: 'dashscope', group: 'qwen-max', owned_by: 'system' }
],
stepfun: [
{
id: 'step-1-8k',
provider: 'stepfun',
name: 'Step 1 8K',
group: 'Step 1'
},
{
id: 'step-1-flash',
provider: 'stepfun',
name: 'Step 1 Flash',
group: 'Step 1'
}
],
doubao: [],
minimax: [
{
id: 'abab6.5s-chat',
provider: 'minimax',
name: 'abab6.5s',
group: 'abab6'
},
{
id: 'abab6.5g-chat',
provider: 'minimax',
name: 'abab6.5g',
group: 'abab6'
},
{
id: 'abab6.5t-chat',
provider: 'minimax',
name: 'abab6.5t',
group: 'abab6'
},
{
id: 'abab5.5s-chat',
provider: 'minimax',
name: 'abab5.5s',
group: 'abab5'
},
{
id: 'minimax-text-01',
provider: 'minimax',
name: 'minimax-01',
group: 'minimax-01'
}
],
hyperbolic: [
{
id: 'Qwen/Qwen2-VL-72B-Instruct',
provider: 'hyperbolic',
name: 'Qwen2-VL-72B-Instruct',
group: 'Qwen2-VL'
},
{
id: 'Qwen/Qwen2-VL-7B-Instruct',
provider: 'hyperbolic',
name: 'Qwen2-VL-7B-Instruct',
group: 'Qwen2-VL'
},
{
id: 'mistralai/Pixtral-12B-2409',
provider: 'hyperbolic',
name: 'Pixtral-12B-2409',
group: 'Pixtral'
},
{
id: 'meta-llama/Meta-Llama-3.1-405B',
provider: 'hyperbolic',
name: 'Meta-Llama-3.1-405B',
group: 'Meta-Llama-3.1'
}
],
grok: [
{
id: 'grok-beta',
provider: 'grok',
name: 'Grok Beta',
group: 'Grok'
},
{
id: 'grok-vision-beta',
provider: 'grok',
name: 'Grok Vision Beta',
group: 'Grok'
}
],
mistral: [
{
id: 'pixtral-12b-2409',
provider: 'mistral',
name: 'Pixtral 12B [Free]',
group: 'Pixtral'
},
{
id: 'pixtral-large-latest',
provider: 'mistral',
name: 'Pixtral Large',
group: 'Pixtral'
},
{
id: 'ministral-3b-latest',
provider: 'mistral',
name: 'Mistral 3B [Free]',
group: 'Mistral Mini'
},
{
id: 'ministral-8b-latest',
provider: 'mistral',
name: 'Mistral 8B [Free]',
group: 'Mistral Mini'
},
{
id: 'codestral-latest',
provider: 'mistral',
name: 'Mistral Codestral',
group: 'Mistral Code'
},
{
id: 'mistral-large-latest',
provider: 'mistral',
name: 'Mistral Large',
group: 'Mistral Chat'
},
{
id: 'mistral-small-latest',
provider: 'mistral',
name: 'Mistral Small',
group: 'Mistral Chat'
},
{
id: 'open-mistral-nemo',
provider: 'mistral',
name: 'Mistral Nemo',
group: 'Mistral Chat'
},
{
id: 'mistral-embed',
provider: 'mistral',
name: 'Mistral Embedding',
group: 'Mistral Embed'
}
],
jina: [
{
id: 'jina-clip-v1',
provider: 'jina',
name: 'jina-clip-v1',
group: 'Jina Clip'
},
{
id: 'jina-clip-v2',
provider: 'jina',
name: 'jina-clip-v2',
group: 'Jina Clip'
},
{
id: 'jina-embeddings-v2-base-en',
provider: 'jina',
name: 'jina-embeddings-v2-base-en',
group: 'Jina Embeddings V2'
},
{
id: 'jina-embeddings-v2-base-es',
provider: 'jina',
name: 'jina-embeddings-v2-base-es',
group: 'Jina Embeddings V2'
},
{
id: 'jina-embeddings-v2-base-de',
provider: 'jina',
name: 'jina-embeddings-v2-base-de',
group: 'Jina Embeddings V2'
},
{
id: 'jina-embeddings-v2-base-zh',
provider: 'jina',
name: 'jina-embeddings-v2-base-zh',
group: 'Jina Embeddings V2'
},
{
id: 'jina-embeddings-v2-base-code',
provider: 'jina',
name: 'jina-embeddings-v2-base-code',
group: 'Jina Embeddings V2'
},
{
id: 'jina-embeddings-v3',
provider: 'jina',
name: 'jina-embeddings-v3',
group: 'Jina Embeddings V3'
}
],
fireworks: [
{
id: 'accounts/fireworks/models/mythomax-l2-13b',
provider: 'fireworks',
name: 'mythomax-l2-13b',
group: 'Gryphe'
},
{
id: 'accounts/fireworks/models/llama-v3-70b-instruct',
provider: 'fireworks',
name: 'Llama-3-70B-Instruct',
group: 'Llama3'
}
],
zhinao: [
{
id: '360gpt-pro',
provider: 'zhinao',
name: '360gpt-pro',
group: '360Gpt'
},
{
id: '360gpt-turbo',
provider: 'zhinao',
name: '360gpt-turbo',
group: '360Gpt'
}
],
hunyuan: [
{
id: 'hunyuan-pro',
provider: 'hunyuan',
name: 'hunyuan-pro',
group: 'Hunyuan'
},
{
id: 'hunyuan-standard',
provider: 'hunyuan',
name: 'hunyuan-standard',
group: 'Hunyuan'
},
{
id: 'hunyuan-lite',
provider: 'hunyuan',
name: 'hunyuan-lite',
group: 'Hunyuan'
},
{
id: 'hunyuan-standard-256k',
provider: 'hunyuan',
name: 'hunyuan-standard-256k',
group: 'Hunyuan'
},
{
id: 'hunyuan-vision',
provider: 'hunyuan',
name: 'hunyuan-vision',
group: 'Hunyuan'
},
{
id: 'hunyuan-code',
provider: 'hunyuan',
name: 'hunyuan-code',
group: 'Hunyuan'
},
{
id: 'hunyuan-role',
provider: 'hunyuan',
name: 'hunyuan-role',
group: 'Hunyuan'
},
{
id: 'hunyuan-turbo',
provider: 'hunyuan',
name: 'hunyuan-turbo',
group: 'Hunyuan'
},
{
id: 'hunyuan-turbos-latest',
provider: 'hunyuan',
name: 'hunyuan-turbos-latest',
group: 'Hunyuan'
},
{
id: 'hunyuan-embedding',
provider: 'hunyuan',
name: 'hunyuan-embedding',
group: 'Embedding'
}
],
nvidia: [
{
id: '01-ai/yi-large',
provider: 'nvidia',
name: 'yi-large',
group: 'Yi'
},
{
id: 'meta/llama-3.1-405b-instruct',
provider: 'nvidia',
name: 'llama-3.1-405b-instruct',
group: 'llama-3.1'
}
],
openrouter: [
{
id: 'google/gemma-2-9b-it:free',
provider: 'openrouter',
name: 'Google: Gemma 2 9B',
group: 'Gemma'
},
{
id: 'microsoft/phi-3-mini-128k-instruct:free',
provider: 'openrouter',
name: 'Phi-3 Mini 128K Instruct',
group: 'Phi'
},
{
id: 'microsoft/phi-3-medium-128k-instruct:free',
provider: 'openrouter',
name: 'Phi-3 Medium 128K Instruct',
group: 'Phi'
},
{
id: 'meta-llama/llama-3-8b-instruct:free',
provider: 'openrouter',
name: 'Meta: Llama 3 8B Instruct',
group: 'Llama3'
},
{
id: 'mistralai/mistral-7b-instruct:free',
provider: 'openrouter',
name: 'Mistral: Mistral 7B Instruct',
group: 'Mistral'
}
],
groq: [
{
id: 'llama3-8b-8192',
provider: 'groq',
name: 'LLaMA3 8B',
group: 'Llama3'
},
{
id: 'llama3-70b-8192',
provider: 'groq',
name: 'LLaMA3 70B',
group: 'Llama3'
},
{
id: 'mixtral-8x7b-32768',
provider: 'groq',
name: 'Mixtral 8x7B',
group: 'Mixtral'
},
{
id: 'gemma-7b-it',
provider: 'groq',
name: 'Gemma 7B',
group: 'Gemma'
}
],
'baidu-cloud': [
{
id: 'deepseek-r1',
provider: 'baidu-cloud',
name: 'DeepSeek R1',
group: 'DeepSeek'
},
{
id: 'deepseek-v3',
provider: 'baidu-cloud',
name: 'DeepSeek V3',
group: 'DeepSeek'
},
{
id: 'ernie-4.0-8k-latest',
provider: 'baidu-cloud',
name: 'ERNIE-4.0',
group: 'ERNIE'
},
{
id: 'ernie-4.0-turbo-8k-latest',
provider: 'baidu-cloud',
name: 'ERNIE 4.0 Trubo',
group: 'ERNIE'
},
{
id: 'ernie-speed-8k',
provider: 'baidu-cloud',
name: 'ERNIE Speed',
group: 'ERNIE'
},
{
id: 'ernie-lite-8k',
provider: 'baidu-cloud',
name: 'ERNIE Lite',
group: 'ERNIE'
},
{
id: 'bge-large-zh',
provider: 'baidu-cloud',
name: 'BGE Large ZH',
group: 'Embedding'
},
{
id: 'bge-large-en',
provider: 'baidu-cloud',
name: 'BGE Large EN',
group: 'Embedding'
}
],
dmxapi: [
{
id: 'Qwen/Qwen2.5-7B-Instruct',
provider: 'dmxapi',
name: 'Qwen/Qwen2.5-7B-Instruct',
group: '免费模型'
},
{
id: 'ERNIE-Speed-128K',
provider: 'dmxapi',
name: 'ERNIE-Speed-128K',
group: '免费模型'
},
{
id: 'THUDM/glm-4-9b-chat',
provider: 'dmxapi',
name: 'THUDM/glm-4-9b-chat',
group: '免费模型'
},
{
id: 'glm-4-flash',
provider: 'dmxapi',
name: 'glm-4-flash',
group: '免费模型'
},
{
id: 'hunyuan-lite',
provider: 'dmxapi',
name: 'hunyuan-lite',
group: '免费模型'
},
{
id: 'gpt-4o',
provider: 'dmxapi',
name: 'gpt-4o',
group: 'OpenAI'
},
{
id: 'gpt-4o-mini',
provider: 'dmxapi',
name: 'gpt-4o-mini',
group: 'OpenAI'
},
{
id: 'DMXAPI-DeepSeek-R1',
provider: 'dmxapi',
name: 'DMXAPI-DeepSeek-R1',
group: 'DeepSeek'
},
{
id: 'DMXAPI-DeepSeek-V3',
provider: 'dmxapi',
name: 'DMXAPI-DeepSeek-V3',
group: 'DeepSeek'
},
{
id: 'claude-3-5-sonnet-20241022',
provider: 'dmxapi',
name: 'claude-3-5-sonnet-20241022',
group: 'Claude'
},
{
id: 'gemini-2.0-flash',
provider: 'dmxapi',
name: 'gemini-2.0-flash',
group: 'Gemini'
}
],
perplexity: [
{
id: 'sonar-reasoning-pro',
provider: 'perplexity',
name: 'sonar-reasoning-pro',
group: 'Sonar'
},
{
id: 'sonar-reasoning',
provider: 'perplexity',
name: 'sonar-reasoning',
group: 'Sonar'
},
{
id: 'sonar-pro',
provider: 'perplexity',
name: 'sonar-pro',
group: 'Sonar'
},
{
id: 'sonar',
provider: 'perplexity',
name: 'sonar',
group: 'Sonar'
}
],
infini: [
{
id: 'deepseek-r1',
provider: 'infini',
name: 'deepseek-r1',
group: 'DeepSeek'
},
{
id: 'deepseek-r1-distill-qwen-32b',
provider: 'infini',
name: 'deepseek-r1-distill-qwen-32b',
group: 'DeepSeek'
},
{
id: 'deepseek-v3',
provider: 'infini',
name: 'deepseek-v3',
group: 'DeepSeek'
},
{
id: 'qwen2.5-72b-instruct',
provider: 'infini',
name: 'qwen2.5-72b-instruct',
group: 'Qwen'
},
{
id: 'qwen2.5-32b-instruct',
provider: 'infini',
name: 'qwen2.5-32b-instruct',
group: 'Qwen'
},
{
id: 'qwen2.5-14b-instruct',
provider: 'infini',
name: 'qwen2.5-14b-instruct',
group: 'Qwen'
},
{
id: 'qwen2.5-7b-instruct',
provider: 'infini',
name: 'qwen2.5-7b-instruct',
group: 'Qwen'
},
{
id: 'qwen2-72b-instruct',
provider: 'infini',
name: 'qwen2-72b-instruct',
group: 'Qwen'
},
{
id: 'qwq-32b-preview',
provider: 'infini',
name: 'qwq-32b-preview',
group: 'Qwen'
},
{
id: 'qwen2.5-coder-32b-instruct',
provider: 'infini',
name: 'qwen2.5-coder-32b-instruct',
group: 'Qwen'
},
{
id: 'llama-3.3-70b-instruct',
provider: 'infini',
name: 'llama-3.3-70b-instruct',
group: 'Llama'
},
{
id: 'bge-m3',
provider: 'infini',
name: 'bge-m3',
group: 'BAAI'
},
{
id: 'gemma-2-27b-it',
provider: 'infini',
name: 'gemma-2-27b-it',
group: 'Gemma'
},
{
id: 'jina-embeddings-v2-base-zh',
provider: 'infini',
name: 'jina-embeddings-v2-base-zh',
group: 'Jina'
},
{
id: 'jina-embeddings-v2-base-code',
provider: 'infini',
name: 'jina-embeddings-v2-base-code',
group: 'Jina'
}
],
xirang: [],
'tencent-cloud-ti': [
{
id: 'deepseek-r1',
provider: 'tencent-cloud-ti',
name: 'DeepSeek R1',
group: 'DeepSeek'
},
{
id: 'deepseek-v3',
provider: 'tencent-cloud-ti',
name: 'DeepSeek V3',
group: 'DeepSeek'
}
],
gpustack: [],
voyageai: [
{
id: 'voyage-3-large',
provider: 'voyageai',
name: 'voyage-3-large',
group: 'Voyage Embeddings V3'
},
{
id: 'voyage-3',
provider: 'voyageai',
name: 'voyage-3',
group: 'Voyage Embeddings V3'
},
{
id: 'voyage-3-lite',
provider: 'voyageai',
name: 'voyage-3-lite',
group: 'Voyage Embeddings V3'
},
{
id: 'voyage-code-3',
provider: 'voyageai',
name: 'voyage-code-3',
group: 'Voyage Embeddings V3'
},
{
id: 'voyage-finance-3',
provider: 'voyageai',
name: 'voyage-finance-3',
group: 'Voyage Embeddings V2'
},
{
id: 'voyage-law-2',
provider: 'voyageai',
name: 'voyage-law-2',
group: 'Voyage Embeddings V2'
},
{
id: 'voyage-code-2',
provider: 'voyageai',
name: 'voyage-code-2',
group: 'Voyage Embeddings V2'
},
{
id: 'rerank-2',
provider: 'voyageai',
name: 'rerank-2',
group: 'Voyage Rerank V2'
},
{
id: 'rerank-2-lite',
provider: 'voyageai',
name: 'rerank-2-lite',
group: 'Voyage Rerank V2'
}
]
}
export const TEXT_TO_IMAGES_MODELS = [
{
id: 'black-forest-labs/FLUX.1-schnell',
provider: 'silicon',
name: 'FLUX.1 Schnell',
group: 'FLUX'
},
{
id: 'black-forest-labs/FLUX.1-dev',
provider: 'silicon',
name: 'FLUX.1 Dev',
group: 'FLUX'
},
{
id: 'black-forest-labs/FLUX.1-pro',
provider: 'silicon',
name: 'FLUX.1 Pro',
group: 'FLUX'
},
{
id: 'Pro/black-forest-labs/FLUX.1-schnell',
provider: 'silicon',
name: 'FLUX.1 Schnell Pro',
group: 'FLUX'
},
{
id: 'LoRA/black-forest-labs/FLUX.1-dev',
provider: 'silicon',
name: 'FLUX.1 Dev LoRA',
group: 'FLUX'
},
{
id: 'deepseek-ai/Janus-Pro-7B',
provider: 'silicon',
name: 'Janus-Pro-7B',
group: 'deepseek-ai'
},
{
id: 'stabilityai/stable-diffusion-3-5-large',
provider: 'silicon',
name: 'Stable Diffusion 3.5 Large',
group: 'Stable Diffusion'
},
{
id: 'stabilityai/stable-diffusion-3-5-large-turbo',
provider: 'silicon',
name: 'Stable Diffusion 3.5 Large Turbo',
group: 'Stable Diffusion'
},
{
id: 'stabilityai/stable-diffusion-3-medium',
provider: 'silicon',
name: 'Stable Diffusion 3 Medium',
group: 'Stable Diffusion'
},
{
id: 'stabilityai/stable-diffusion-2-1',
provider: 'silicon',
name: 'Stable Diffusion 2.1',
group: 'Stable Diffusion'
},
{
id: 'stabilityai/stable-diffusion-xl-base-1.0',
provider: 'silicon',
name: 'Stable Diffusion XL Base 1.0',
group: 'Stable Diffusion'
}
]
export const TEXT_TO_IMAGES_MODELS_SUPPORT_IMAGE_ENHANCEMENT = [
'stabilityai/stable-diffusion-2-1',
'stabilityai/stable-diffusion-xl-base-1.0'
]
export const GENERATE_IMAGE_MODELS = ['gemini-2.0-flash-exp-image-generation', 'gemini-2.0-flash-exp']
export function isTextToImageModel(model: Model): boolean {
return TEXT_TO_IMAGE_REGEX.test(model.id)
}
export function isEmbeddingModel(model: Model): boolean {
if (!model) {
return false
}
if (['anthropic'].includes(model?.provider)) {
return false
}
if (model.provider === 'doubao') {
return EMBEDDING_REGEX.test(model.name)
}
if (isRerankModel(model)) {
return false
}
return EMBEDDING_REGEX.test(model.id) || model.type?.includes('embedding') || false
}
export function isRerankModel(model: Model): boolean {
return model ? RERANKING_REGEX.test(model.id) || false : false
}
export function isVisionModel(model: Model): boolean {
if (!model) {
return false
}
if (model.provider === 'copilot') {
return false
}
if (model.provider === 'doubao') {
return VISION_REGEX.test(model.name) || model.type?.includes('vision') || false
}
return VISION_REGEX.test(model.id) || model.type?.includes('vision') || false
}
export function isOpenAIoSeries(model: Model): boolean {
return ['o1', 'o1-2024-12-17'].includes(model.id) || model.id.includes('o3')
}
export function isReasoningModel(model?: Model): boolean {
if (!model) {
return false
}
if (model.provider === 'doubao') {
return REASONING_REGEX.test(model.name) || model.type?.includes('reasoning') || false
}
if (model.id.includes('claude-3-7-sonnet') || model.id.includes('claude-3.7-sonnet') || isOpenAIoSeries(model)) {
return true
}
return REASONING_REGEX.test(model.id) || model.type?.includes('reasoning') || false
}
export function isSupportedModel(model: OpenAI.Models.Model): boolean {
if (!model) {
return false
}
return !NOT_SUPPORTED_REGEX.test(model.id)
}
export function isWebSearchModel(model: Model): boolean {
if (!model) {
return false
}
const provider = getProviderByModel(model)
if (!provider) {
return false
}
const isEmbedding = isEmbeddingModel(model)
if (isEmbedding) {
return false
}
if (provider?.type === 'openai') {
if (model?.id?.includes('gemini-2.0-flash-exp')) {
return true
}
}
if (provider.id === 'gemini' || provider?.type === 'gemini') {
const models = [
'gemini-2.0-flash',
'gemini-2.0-flash-exp',
'gemini-2.0-flash-001',
'gemini-2.0-pro-exp-02-05',
'gemini-2.0-pro-exp'
]
return models.includes(model?.id)
}
if (provider.id === 'hunyuan') {
return model?.id !== 'hunyuan-lite'
}
if (provider.id === 'aihubmix') {
const models = ['gemini-2.0-flash-search', 'gemini-2.0-flash-exp-search', 'gemini-2.0-pro-exp-02-05-search']
return models.includes(model?.id)
}
if (provider.id === 'zhipu') {
return model?.id?.startsWith('glm-4-')
}
if (provider.id === 'dashscope') {
const models = ['qwen-turbo', 'qwen-max', 'qwen-plus']
// matches id like qwen-max-0919, qwen-max-latest
return models.some((i) => model.id.startsWith(i))
}
if (provider.id === 'openrouter') {
return true
}
return false
}
export function isGenerateImageModel(model: Model): boolean {
if (!model) {
return false
}
const provider = getProviderByModel(model)
if (!provider) {
return false
}
const isEmbedding = isEmbeddingModel(model)
if (isEmbedding) {
return false
}
if (GENERATE_IMAGE_MODELS.includes(model.id)) {
return true
}
return false
}
export function getOpenAIWebSearchParams(assistant: Assistant, model: Model): Record<string, any> {
if (isWebSearchModel(model)) {
if (assistant.enableWebSearch) {
const webSearchTools = getWebSearchTools(model)
if (model.provider === 'hunyuan') {
return { enable_enhancement: true }
}
if (model.provider === 'dashscope') {
return {
enable_search: true,
search_options: {
forced_search: true
}
}
}
if (model.provider === 'openrouter') {
return {
plugins: [{ id: 'web' }]
}
}
return {
tools: webSearchTools
}
} else {
if (model.provider === 'hunyuan') {
return { enable_enhancement: false }
}
}
}
return {}
}
export function isGemmaModel(model?: Model): boolean {
if (!model) {
return false
}
return model.id.includes('gemma-') || model.group === 'Gemma'
}