mirror of
https://github.com/farcasclaudiu/TradingAgents.git
synced 2026-06-22 09:01:24 +03:00
d4dadb82fc
Models added: - OpenAI: GPT-5.2, GPT-5.1, GPT-5, GPT-5 Mini, GPT-5 Nano, GPT-4.1 - Anthropic: Claude Opus 4.5/4.1, Claude Sonnet 4.5/4, Claude Haiku 4.5 - Google: Gemini 3 Pro/Flash, Gemini 2.5 Flash/Flash Lite - xAI: Grok 4, Grok 4.1 Fast (Reasoning/Non-Reasoning) Configs updated: - Add unified thinking_level for Gemini (maps to thinking_level for Gemini 3, thinking_budget for Gemini 2.5; handles Pro's lack of "minimal" support) - Add OpenAI reasoning_effort configuration - Add NormalizedChatGoogleGenerativeAI for consistent response handling Fixes: - Fix Bull/Bear researcher display truncation - Replace ChromaDB with BM25 for memory retrieval
83 lines
2.1 KiB
Python
83 lines
2.1 KiB
Python
"""Model name validators for each provider.
|
|
|
|
Only validates model names - does NOT enforce limits.
|
|
Let LLM providers use their own defaults for unspecified params.
|
|
"""
|
|
|
|
VALID_MODELS = {
|
|
"openai": [
|
|
# GPT-5 series (2025)
|
|
"gpt-5.2",
|
|
"gpt-5.1",
|
|
"gpt-5",
|
|
"gpt-5-mini",
|
|
"gpt-5-nano",
|
|
# GPT-4.1 series (2025)
|
|
"gpt-4.1",
|
|
"gpt-4.1-mini",
|
|
"gpt-4.1-nano",
|
|
# o-series reasoning models
|
|
"o4-mini",
|
|
"o3",
|
|
"o3-mini",
|
|
"o1",
|
|
"o1-preview",
|
|
# GPT-4o series (legacy but still supported)
|
|
"gpt-4o",
|
|
"gpt-4o-mini",
|
|
],
|
|
"anthropic": [
|
|
# Claude 4.5 series (2025)
|
|
"claude-opus-4-5",
|
|
"claude-sonnet-4-5",
|
|
"claude-haiku-4-5",
|
|
# Claude 4.x series
|
|
"claude-opus-4-1-20250805",
|
|
"claude-sonnet-4-20250514",
|
|
# Claude 3.7 series
|
|
"claude-3-7-sonnet-20250219",
|
|
# Claude 3.5 series (legacy)
|
|
"claude-3-5-haiku-20241022",
|
|
"claude-3-5-sonnet-20241022",
|
|
],
|
|
"google": [
|
|
# Gemini 3 series (preview)
|
|
"gemini-3-pro-preview",
|
|
"gemini-3-flash-preview",
|
|
# Gemini 2.5 series
|
|
"gemini-2.5-pro",
|
|
"gemini-2.5-flash",
|
|
"gemini-2.5-flash-lite",
|
|
# Gemini 2.0 series
|
|
"gemini-2.0-flash",
|
|
"gemini-2.0-flash-lite",
|
|
],
|
|
"xai": [
|
|
# Grok 4.1 series
|
|
"grok-4-1-fast",
|
|
"grok-4-1-fast-reasoning",
|
|
"grok-4-1-fast-non-reasoning",
|
|
# Grok 4 series
|
|
"grok-4",
|
|
"grok-4-0709",
|
|
"grok-4-fast-reasoning",
|
|
"grok-4-fast-non-reasoning",
|
|
],
|
|
}
|
|
|
|
|
|
def validate_model(provider: str, model: str) -> bool:
|
|
"""Check if model name is valid for the given provider.
|
|
|
|
For ollama, openrouter, vllm - any model is accepted.
|
|
"""
|
|
provider_lower = provider.lower()
|
|
|
|
if provider_lower in ("ollama", "openrouter", "vllm"):
|
|
return True
|
|
|
|
if provider_lower not in VALID_MODELS:
|
|
return True
|
|
|
|
return model in VALID_MODELS[provider_lower]
|