From 8d5d522c4e5770386e7e222b371ab17cbb1030b1 Mon Sep 17 00:00:00 2001 From: kqlio67 <166700875+kqlio67@users.noreply.github.com> Date: Thu, 28 Nov 2024 16:50:24 +0000 Subject: [PATCH] feat(g4f): Major provider updates and new model support (#2437) * refactor(g4f/Provider/Airforce.py): Enhance Airforce provider with dynamic model fetching * refactor(g4f/Provider/Blackbox.py): Enhance Blackbox AI provider configuration and streamline code * feat(g4f/Provider/RobocodersAPI.py): Add RobocodersAPI new async chat provider * refactor(g4f/client/__init__.py): Improve provider handling in async_generate method * refactor(g4f/models.py): Update provider configurations for multiple models * refactor(g4f/Provider/Blackbox.py): Streamline model configuration and improve response handling * feat(g4f/Provider/DDG.py): Enhance model support and improve conversation handling * refactor(g4f/Provider/Copilot.py): Enhance Copilot provider with model support * refactor(g4f/Provider/AmigoChat.py): update models and improve code structure * chore(g4f/Provider/not_working/AIUncensored.): move AIUncensored to not_working directory * chore(g4f/Provider/not_working/Allyfy.py): remove Allyfy provider * Update (g4f/Provider/not_working/AIUncensored.py g4f/Provider/not_working/__init__.py) * refactor(g4f/Provider/ChatGptEs.py): Implement format_prompt for message handling * refactor(g4f/Provider/Blackbox.py): Update message formatting and improve code structure * refactor(g4f/Provider/LLMPlayground.py): Enhance text generation and error handling * refactor(g4f/Provider/needs_auth/PollinationsAI.py): move PollinationsAI to needs_auth directory * refactor(g4f/Provider/Liaobots.py): Update Liaobots provider models and aliases * feat(g4f/Provider/DeepInfraChat.py): Add new DeepInfra models and aliases * Update (g4f/Provider/__init__.py) * Update (g4f/models.py) * g4f/models.py * Update g4f/models.py * Update g4f/Provider/LLMPlayground.py * Update (g4f/models.py g4f/Provider/Airforce.py g4f/Provider/__init__.py g4f/Provider/LLMPlayground.py) * Update g4f/Provider/__init__.py * Update (g4f/Provider/Airforce.py) --------- Co-authored-by: kqlio67 --- g4f/Provider/Airforce.py | 89 ++++--- g4f/Provider/AmigoChat.py | 156 ++++++++---- g4f/Provider/Blackbox.py | 9 +- g4f/Provider/ChatGptEs.py | 4 +- g4f/Provider/Copilot.py | 12 +- g4f/Provider/DDG.py | 32 ++- g4f/Provider/DeepInfraChat.py | 4 + g4f/Provider/Liaobots.py | 94 +++---- g4f/Provider/__init__.py | 2 - .../{ => needs_auth}/PollinationsAI.py | 14 +- g4f/Provider/needs_auth/__init__.py | 1 + .../{ => not_working}/AIUncensored.py | 8 +- g4f/Provider/not_working/Allyfy.py | 87 ------- g4f/Provider/not_working/__init__.py | 1 + g4f/models.py | 231 +++++++++++++++--- 15 files changed, 462 insertions(+), 282 deletions(-) rename g4f/Provider/{ => needs_auth}/PollinationsAI.py (89%) rename g4f/Provider/{ => not_working}/AIUncensored.py (96%) delete mode 100644 g4f/Provider/not_working/Allyfy.py diff --git a/g4f/Provider/Airforce.py b/g4f/Provider/Airforce.py index 5200d6f70e8..f65cd953c35 100644 --- a/g4f/Provider/Airforce.py +++ b/g4f/Provider/Airforce.py @@ -14,6 +14,19 @@ from ..image import ImageResponse from ..requests import StreamSession, raise_for_status +def split_message(message: str, max_length: int = 1000) -> list[str]: + """Splits the message into parts up to (max_length).""" + chunks = [] + while len(message) > max_length: + split_point = message.rfind(' ', 0, max_length) + if split_point == -1: + split_point = max_length + chunks.append(message[:split_point]) + message = message[split_point:].strip() + if message: + chunks.append(message) + return chunks + class Airforce(AsyncGeneratorProvider, ProviderModelMixin): url = "https://llmplayground.net" api_endpoint_completions = "https://api.airforce/chat/completions" @@ -84,6 +97,7 @@ def get_models(cls): # HuggingFaceH4 "zephyr-7b": "zephyr-7b-beta", + ### imagine ### "sdxl": "stable-diffusion-xl-base", "sdxl": "stable-diffusion-xl-lightning", @@ -125,7 +139,6 @@ async def _generate_image( "accept": "*/*", "accept-language": "en-US,en;q=0.9", "cache-control": "no-cache", - "origin": "https://llmplayground.net", "user-agent": "Mozilla/5.0" } if seed is None: @@ -167,35 +180,47 @@ async def _generate_text( "content-type": "application/json", "user-agent": "Mozilla/5.0" } + + full_message = "\n".join( + [f"{msg['role'].capitalize()}: {msg['content']}" for msg in messages] + ) + + message_chunks = split_message(full_message, max_length=1000) + async with StreamSession(headers=headers, proxy=proxy) as session: - data = { - "messages": messages, - "model": model, - "max_tokens": max_tokens, - "temperature": temperature, - "top_p": top_p, - "stream": stream - } - async with session.post(cls.api_endpoint_completions, json=data) as response: - await raise_for_status(response) - content_type = response.headers.get('Content-Type', '').lower() - if 'application/json' in content_type: - json_data = await response.json() - if json_data.get("model") == "error": - raise RuntimeError(json_data['choices'][0]['message'].get('content', '')) - if stream: - async for line in response.iter_lines(): - if line: - line = line.decode('utf-8').strip() - if line.startswith("data: ") and line != "data: [DONE]": - json_data = json.loads(line[6:]) - content = json_data['choices'][0]['delta'].get('content', '') - if content: - yield cls._filter_content(content) - else: - json_data = await response.json() - content = json_data['choices'][0]['message']['content'] - yield cls._filter_content(content) + full_response = "" + for chunk in message_chunks: + data = { + "messages": [{"role": "user", "content": chunk}], + "model": model, + "max_tokens": max_tokens, + "temperature": temperature, + "top_p": top_p, + "stream": stream + } + + async with session.post(cls.api_endpoint_completions, json=data) as response: + await raise_for_status(response) + content_type = response.headers.get('Content-Type', '').lower() + + if 'application/json' in content_type: + json_data = await response.json() + if json_data.get("model") == "error": + raise RuntimeError(json_data['choices'][0]['message'].get('content', '')) + if stream: + async for line in response.iter_lines(): + if line: + line = line.decode('utf-8').strip() + if line.startswith("data: ") and line != "data: [DONE]": + json_data = json.loads(line[6:]) + content = json_data['choices'][0]['delta'].get('content', '') + if content: + yield cls._filter_content(content) + else: + content = json_data['choices'][0]['message']['content'] + full_response += cls._filter_content(content) + + yield full_response @classmethod def _filter_content(cls, part_response: str) -> str: @@ -210,4 +235,10 @@ def _filter_content(cls, part_response: str) -> str: '', part_response ) + + part_response = re.sub( + r"\[ERROR\] '\w{8}-\w{4}-\w{4}-\w{4}-\w{12}'", # any-uncensored + '', + part_response + ) return part_response diff --git a/g4f/Provider/AmigoChat.py b/g4f/Provider/AmigoChat.py index 2e66dccf9eb..0acb58543a8 100644 --- a/g4f/Provider/AmigoChat.py +++ b/g4f/Provider/AmigoChat.py @@ -9,6 +9,69 @@ from ..requests import StreamSession, raise_for_status from ..errors import ResponseStatusError +MODELS = { + 'chat': { + 'gpt-4o-2024-11-20': {'persona_id': "gpt"}, + 'gpt-4o': {'persona_id': "summarizer"}, + 'gpt-4o-mini': {'persona_id': "gemini-1-5-flash"}, + + 'o1-preview-': {'persona_id': "openai-o-one"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'o1-preview-2024-09-12-': {'persona_id': "orion"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'o1-mini-': {'persona_id': "openai-o-one-mini"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + + 'meta-llama/Meta-Llama-3.1-405B-Instruct-Turbo': {'persona_id': "llama-three-point-one"}, + 'meta-llama/Llama-3.2-90B-Vision-Instruct-Turbo': {'persona_id': "llama-3-2"}, + 'codellama/CodeLlama-34b-Instruct-hf': {'persona_id': "codellama-CodeLlama-34b-Instruct-hf"}, + + 'gemini-1.5-pro': {'persona_id': "gemini-1-5-pro"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'gemini-1.5-flash': {'persona_id': "amigo"}, + + 'claude-3-5-sonnet-20240620': {'persona_id': "claude"}, + 'claude-3-5-sonnet-20241022': {'persona_id': "clude-claude-3-5-sonnet-20241022"}, + 'claude-3-5-haiku-latest': {'persona_id': "3-5-haiku"}, + + 'Qwen/Qwen2.5-72B-Instruct-Turbo': {'persona_id': "qwen-2-5"}, + + 'google/gemma-2b-it': {'persona_id': "google-gemma-2b-it"}, + 'google/gemma-7b': {'persona_id': "google-gemma-7b"}, # Error handling AIML chat completion stream + + 'Gryphe/MythoMax-L2-13b': {'persona_id': "Gryphe-MythoMax-L2-13b"}, + + 'mistralai/Mistral-7B-Instruct-v0.3': {'persona_id': "mistralai-Mistral-7B-Instruct-v0.1"}, + 'mistralai/mistral-tiny': {'persona_id': "mistralai-mistral-tiny"}, + 'mistralai/mistral-nemo': {'persona_id': "mistralai-mistral-nemo"}, + + 'deepseek-ai/deepseek-llm-67b-chat': {'persona_id': "deepseek-ai-deepseek-llm-67b-chat"}, + + 'databricks/dbrx-instruct': {'persona_id': "databricks-dbrx-instruct"}, + + 'NousResearch/Nous-Hermes-2-Mixtral-8x7B-DPO': {'persona_id': "NousResearch-Nous-Hermes-2-Mixtral-8x7B-DPO"}, + + 'x-ai/grok-beta': {'persona_id': "x-ai-grok-beta"}, + + 'anthracite-org/magnum-v4-72b': {'persona_id': "anthracite-org-magnum-v4-72b"}, + + 'cohere/command-r-plus': {'persona_id': "cohere-command-r-plus"}, + + 'ai21/jamba-1-5-mini': {'persona_id': "ai21-jamba-1-5-mini"}, + + 'zero-one-ai/Yi-34B': {'persona_id': "zero-one-ai-Yi-34B"} # Error handling AIML chat completion stream + }, + + 'image': { + 'flux-pro/v1.1': {'persona_id': "flux-1-1-pro"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'flux-realism': {'persona_id': "flux-realism"}, + 'flux-pro': {'persona_id': "flux-pro"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'flux-pro/v1.1-ultra': {'persona_id': "flux-pro-v1.1-ultra"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'flux-pro/v1.1-ultra-raw': {'persona_id': "flux-pro-v1.1-ultra-raw"}, # Amigo, your balance is not enough to make the request, wait until 12 UTC or upgrade your plan + 'flux/dev': {'persona_id': "flux-dev"}, + + 'dalle-e-3': {'persona_id': "dalle-three"}, + + 'recraft-v3': {'persona_id': "recraft"} + } +} + class AmigoChat(AsyncGeneratorProvider, ProviderModelMixin): url = "https://amigochat.io/chat/" chat_api_endpoint = "https://api.amigochat.io/v1/chat/completions" @@ -17,58 +80,67 @@ class AmigoChat(AsyncGeneratorProvider, ProviderModelMixin): supports_stream = True supports_system_message = True supports_message_history = True - + default_model = 'gpt-4o-mini' - - chat_models = [ - 'gpt-4o', - default_model, - 'o1-preview', - 'o1-mini', - 'meta-llama/Meta-Llama-3.1-405B-Instruct-Turbo', - 'meta-llama/Llama-3.2-90B-Vision-Instruct-Turbo', - 'claude-3-sonnet-20240229', - 'gemini-1.5-pro', - ] - - image_models = [ - 'flux-pro/v1.1', - 'flux-realism', - 'flux-pro', - 'dalle-e-3', - ] - - models = [*chat_models, *image_models] + + chat_models = list(MODELS['chat'].keys()) + image_models = list(MODELS['image'].keys()) + models = chat_models + image_models model_aliases = { - "o1": "o1-preview", + ### chat ### + "gpt-4o": "gpt-4o-2024-11-20", + "gpt-4o-mini": "gpt-4o-mini", + "llama-3.1-405b": "meta-llama/Meta-Llama-3.1-405B-Instruct-Turbo", "llama-3.2-90b": "meta-llama/Llama-3.2-90B-Vision-Instruct-Turbo", - "claude-3.5-sonnet": "claude-3-sonnet-20240229", - "gemini-pro": "gemini-1.5-pro", + "codellama-34b": "codellama/CodeLlama-34b-Instruct-hf", + + "gemini-flash": "gemini-1.5-flash", + + "claude-3.5-sonnet": "claude-3-5-sonnet-20240620", + "claude-3.5-sonnet": "claude-3-5-sonnet-20241022", + "claude-3.5-haiku": "claude-3-5-haiku-latest", + + "qwen-2.5-72b": "Qwen/Qwen2.5-72B-Instruct-Turbo", + "gemma-2b": "google/gemma-2b-it", + + "mythomax-13b": "Gryphe/MythoMax-L2-13b", + + "mixtral-7b": "mistralai/Mistral-7B-Instruct-v0.3", + "mistral-tiny": "mistralai/mistral-tiny", + "mistral-nemo": "mistralai/mistral-nemo", + + "deepseek-chat": "deepseek-ai/deepseek-llm-67b-chat", + + "dbrx-instruct": "databricks/dbrx-instruct", + + "mixtral-8x7b-dpo": "NousResearch/Nous-Hermes-2-Mixtral-8x7B-DPO", + + "grok-beta": "x-ai/grok-beta", + + "magnum-72b": "anthracite-org/magnum-v4-72b", + + "command-r-plus": "cohere/command-r-plus", + + "jamba-mini": "ai21/jamba-1-5-mini", + + + ### image ### + "flux-realism": "flux-realism", + "flux-dev": "flux/dev", - "flux-pro": "flux-pro/v1.1", "dalle-3": "dalle-e-3", } - persona_ids = { - 'gpt-4o': "gpt", - 'gpt-4o-mini': "amigo", - 'o1-preview': "openai-o-one", - 'o1-mini': "openai-o-one-mini", - 'meta-llama/Meta-Llama-3.1-405B-Instruct-Turbo': "llama-three-point-one", - 'meta-llama/Llama-3.2-90B-Vision-Instruct-Turbo': "llama-3-2", - 'claude-3-sonnet-20240229': "claude", - 'gemini-1.5-pro': "gemini-1-5-pro", - 'flux-pro/v1.1': "flux-1-1-pro", - 'flux-realism': "flux-realism", - 'flux-pro': "flux-pro", - 'dalle-e-3': "dalle-three", - } - @classmethod def get_personaId(cls, model: str) -> str: - return cls.persona_ids[model] + if model in cls.chat_models: + return MODELS['chat'][model]['persona_id'] + elif model in cls.image_models: + return MODELS['image'][model]['persona_id'] + else: + raise ValueError(f"Unknown model: {model}") @classmethod async def create_async_generator( @@ -110,7 +182,7 @@ async def create_async_generator( "x-device-language": "en-US", "x-device-platform": "web", "x-device-uuid": device_uuid, - "x-device-version": "1.0.41" + "x-device-version": "1.0.42" } async with StreamSession(headers=headers, proxy=proxy) as session: diff --git a/g4f/Provider/Blackbox.py b/g4f/Provider/Blackbox.py index 419055374e1..135a21bace7 100644 --- a/g4f/Provider/Blackbox.py +++ b/g4f/Provider/Blackbox.py @@ -11,6 +11,8 @@ from .base_provider import AsyncGeneratorProvider, ProviderModelMixin from ..image import ImageResponse, to_data_uri +from .helper import format_prompt + class Blackbox(AsyncGeneratorProvider, ProviderModelMixin): label = "Blackbox AI" url = "https://www.blackbox.ai" @@ -37,7 +39,7 @@ class Blackbox(AsyncGeneratorProvider, ProviderModelMixin): "gemini-1.5-flash": {'mode': True, 'id': 'Gemini'}, "llama-3.1-8b": {'mode': True, 'id': "llama-3.1-8b"}, 'llama-3.1-70b': {'mode': True, 'id': "llama-3.1-70b"}, - 'llama-3.1-405b': {'mode': True, 'id': "llama-3.1-405"}, + 'llama-3.1-405b': {'mode': True, 'id': "llama-3.1-405"}, # 'Python Agent': {'mode': True, 'id': "Python Agent"}, 'Java Agent': {'mode': True, 'id': "Java Agent"}, @@ -62,7 +64,7 @@ class Blackbox(AsyncGeneratorProvider, ProviderModelMixin): 'Go Agent': {'mode': True, 'id': "Go Agent"}, 'Gitlab Agent': {'mode': True, 'id': "Gitlab Agent"}, 'Git Agent': {'mode': True, 'id': "Git Agent"}, - 'Flask Agent': {'mode': True, 'id': "Flask Agent"}, + 'Flask Agent': {'mode': True, 'id': "Flask Agent"}, 'Firebase Agent': {'mode': True, 'id': "Firebase Agent"}, 'FastAPI Agent': {'mode': True, 'id': "FastAPI Agent"}, 'Erlang Agent': {'mode': True, 'id': "Erlang Agent"}, @@ -165,6 +167,9 @@ async def create_async_generator( message_id = cls.generate_id() messages = cls.add_prefix_to_messages(messages, model) validated_value = await cls.fetch_validated() + formatted_message = format_prompt(messages) + + messages = [{"id": message_id, "content": formatted_message, "role": "user"}] if image is not None: messages[-1]['data'] = { diff --git a/g4f/Provider/ChatGptEs.py b/g4f/Provider/ChatGptEs.py index 788ffcd9501..bc91eb1fcd5 100644 --- a/g4f/Provider/ChatGptEs.py +++ b/g4f/Provider/ChatGptEs.py @@ -56,6 +56,8 @@ async def create_async_generator( nonce_ = re.findall(r'data-nonce="(.+?)"', await initial_response.text())[0] post_id = re.findall(r'data-post-id="(.+?)"', await initial_response.text())[0] + formatted_prompt = format_prompt(messages) + conversation_history = [ "Human: You are a helpful AI assistant. Please respond in the same language that the user uses in their message. Provide accurate, relevant and helpful information while maintaining a friendly and professional tone. If you're not sure about something, please acknowledge that and provide the best information you can while noting any uncertainties. Focus on being helpful while respecting the user's choice of language." ] @@ -71,7 +73,7 @@ async def create_async_generator( 'post_id': post_id, 'url': cls.url, 'action': 'wpaicg_chat_shortcode_message', - 'message': messages[-1]['content'], + 'message': formatted_prompt, 'bot_id': '0', 'chatbot_identity': 'shortcode', 'wpaicg_chat_client_id': os.urandom(5).hex(), diff --git a/g4f/Provider/Copilot.py b/g4f/Provider/Copilot.py index 70715bfa17e..a64d52aa293 100644 --- a/g4f/Provider/Copilot.py +++ b/g4f/Provider/Copilot.py @@ -17,13 +17,13 @@ except ImportError: has_nodriver = False -from .base_provider import AbstractProvider, BaseConversation +from .base_provider import AbstractProvider, ProviderModelMixin, BaseConversation from .helper import format_prompt from ..typing import CreateResult, Messages, ImageType from ..errors import MissingRequirementsError from ..requests.raise_for_status import raise_for_status from ..providers.asyncio import get_running_loop -from ..Provider.openai.har_file import NoValidHarFileError, get_headers, get_har_files +from .openai.har_file import NoValidHarFileError, get_headers from ..requests import get_nodriver from ..image import ImageResponse, to_bytes, is_accepted_format from .. import debug @@ -38,12 +38,16 @@ def __init__(self, conversation_id: str, cookie_jar: CookieJar, access_token: st self.cookie_jar = cookie_jar self.access_token = access_token -class Copilot(AbstractProvider): +class Copilot(AbstractProvider, ProviderModelMixin): label = "Microsoft Copilot" url = "https://copilot.microsoft.com" working = True supports_stream = True default_model = "Copilot" + models = [default_model] + model_aliases = { + "gpt-4": "Copilot", + } websocket_url = "wss://copilot.microsoft.com/c/api/chat?api-version=2" conversation_url = f"{url}/c/api/conversations" @@ -209,4 +213,4 @@ def readHAR(): if api_key is None: raise NoValidHarFileError("No access token found in .har files") - return api_key, cookies \ No newline at end of file + return api_key, cookies diff --git a/g4f/Provider/DDG.py b/g4f/Provider/DDG.py index c4be0ea8f7f..42c18dfeb87 100644 --- a/g4f/Provider/DDG.py +++ b/g4f/Provider/DDG.py @@ -18,7 +18,8 @@ {"model":"claude-3-opus-20240229","modelName":"Claude 3","modelVariant":"Opus","modelStyleId":"claude-3-haiku","createdBy":"Anthropic","moderationLevel":"HIGH","isAvailable":1,"inputCharLimit":16e3,"settingId":"2"}, {"model":"claude-3-haiku-20240307","modelName":"Claude 3","modelVariant":"Haiku","modelStyleId":"claude-3-haiku","createdBy":"Anthropic","moderationLevel":"HIGH","isAvailable":0,"inputCharLimit":16e3,"settingId":"1"}, {"model":"meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo","modelName":"Llama 3.1","modelVariant":"70B","modelStyleId":"llama-3","createdBy":"Meta","moderationLevel":"MEDIUM","isAvailable":0,"isOpenSource":0,"inputCharLimit":16e3,"settingId":"5"}, - {"model":"mistralai/Mixtral-8x7B-Instruct-v0.1","modelName":"Mixtral","modelVariant":"8x7B","modelStyleId":"mixtral","createdBy":"Mistral AI","moderationLevel":"LOW","isAvailable":0,"isOpenSource":0,"inputCharLimit":16e3,"settingId":"6"} + {"model":"mistralai/Mixtral-8x7B-Instruct-v0.1","modelName":"Mixtral","modelVariant":"8x7B","modelStyleId":"mixtral","createdBy":"Mistral AI","moderationLevel":"LOW","isAvailable":0,"isOpenSource":0,"inputCharLimit":16e3,"settingId":"6"}, + {"model":"Qwen/Qwen2.5-Coder-32B-Instruct","modelName":"Qwen 2.5 Coder","modelVariant":"32B","modelStyleId":"qwen","createdBy":"Alibaba Cloud","moderationLevel":"LOW","isAvailable":0,"isOpenSource":1,"inputCharLimit":16e3,"settingId":"90"} ] class Conversation(BaseConversation): @@ -29,7 +30,7 @@ def __init__(self, model: str): self.model = model class DDG(AsyncGeneratorProvider, ProviderModelMixin): - url = "https://duckduckgo.com" + url = "https://duckduckgo.com/aichat" api_endpoint = "https://duckduckgo.com/duckchat/v1/chat" working = True supports_stream = True @@ -42,7 +43,7 @@ class DDG(AsyncGeneratorProvider, ProviderModelMixin): "claude-3-haiku": "claude-3-haiku-20240307", "llama-3.1-70b": "meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo", "mixtral-8x7b": "mistralai/Mixtral-8x7B-Instruct-v0.1", - "gpt-4": "gpt-4o-mini" + "gpt-4": "gpt-4o-mini", } @classmethod @@ -75,7 +76,9 @@ async def create_async_generator( if conversation is None: conversation = Conversation(model) is_new_conversation = True + debug.last_model = model + if conversation.vqd is None: conversation.vqd = await cls.get_vqd(proxy, connector) if not conversation.vqd: @@ -87,24 +90,35 @@ async def create_async_generator( 'user-agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/128.0.0.0 Safari/537.36', 'x-vqd-4': conversation.vqd, } + async with ClientSession(headers=headers, connector=get_connector(connector, proxy)) as session: if is_new_conversation: conversation.message_history = [{"role": "user", "content": format_prompt(messages)}] else: - conversation.message_history = [ - *conversation.message_history, - messages[-2], - messages[-1] - ] + if len(messages) >= 2: + conversation.message_history = [ + *conversation.message_history, + messages[-2], + messages[-1] + ] + elif len(messages) == 1: + conversation.message_history = [ + *conversation.message_history, + messages[-1] + ] + if return_conversation: yield conversation + data = { "model": conversation.model, "messages": conversation.message_history } + async with session.post(cls.api_endpoint, json=data) as response: conversation.vqd = response.headers.get("x-vqd-4") await raise_for_status(response) + async for line in response.content: if line: decoded_line = line.decode('utf-8') @@ -117,4 +131,4 @@ async def create_async_generator( if 'message' in json_data: yield json_data['message'] except json.JSONDecodeError: - pass \ No newline at end of file + pass diff --git a/g4f/Provider/DeepInfraChat.py b/g4f/Provider/DeepInfraChat.py index d8cb072ac1e..b690f7bc051 100644 --- a/g4f/Provider/DeepInfraChat.py +++ b/g4f/Provider/DeepInfraChat.py @@ -20,12 +20,16 @@ class DeepInfraChat(AsyncGeneratorProvider, ProviderModelMixin): default_model, 'microsoft/WizardLM-2-8x22B', 'Qwen/Qwen2.5-72B-Instruct', + 'Qwen/Qwen2.5-Coder-32B-Instruct', + 'nvidia/Llama-3.1-Nemotron-70B-Instruct', ] model_aliases = { "llama-3.1-8b": "meta-llama/Meta-Llama-3.1-8B-Instruct", "llama-3.1-70b": "meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo", "wizardlm-2-8x22b": "microsoft/WizardLM-2-8x22B", "qwen-2-72b": "Qwen/Qwen2.5-72B-Instruct", + "qwen-2.5-coder-32b": "Qwen2.5-Coder-32B-Instruct", + "nemotron-70b": "nvidia/Llama-3.1-Nemotron-70B-Instruct", } diff --git a/g4f/Provider/Liaobots.py b/g4f/Provider/Liaobots.py index fc50bdeef79..cc4a692bcd7 100644 --- a/g4f/Provider/Liaobots.py +++ b/g4f/Provider/Liaobots.py @@ -18,24 +18,6 @@ "tokenLimit": 7800, "context": "8K", }, - "gpt-4o-mini": { - "id": "gpt-4o-mini", - "name": "GPT-4o-Mini", - "model": "ChatGPT", - "provider": "OpenAI", - "maxLength": 260000, - "tokenLimit": 126000, - "context": "128K", - }, - "gpt-4o-free": { - "id": "gpt-4o-free", - "name": "GPT-4o-free", - "model": "ChatGPT", - "provider": "OpenAI", - "maxLength": 31200, - "tokenLimit": 7800, - "context": "8K", - }, "gpt-4o-2024-08-06": { "id": "gpt-4o-2024-08-06", "name": "GPT-4o", @@ -45,36 +27,36 @@ "tokenLimit": 126000, "context": "128K", }, - "gpt-4-turbo-2024-04-09": { - "id": "gpt-4-turbo-2024-04-09", - "name": "GPT-4-Turbo", + "gpt-4o-mini-2024-07-18": { + "id": "gpt-4o-mini-2024-07-18", + "name": "GPT-4o-Mini", "model": "ChatGPT", "provider": "OpenAI", "maxLength": 260000, "tokenLimit": 126000, "context": "128K", }, - "grok-beta": { - "id": "grok-beta", - "name": "Grok-Beta", - "model": "Grok", - "provider": "x.ai", + "o1-preview": { + "id": "o1-preview", + "name": "o1-preview", + "model": "o1", + "provider": "OpenAI", "maxLength": 400000, "tokenLimit": 100000, - "context": "100K", + "context": "128K", }, - "grok-2": { - "id": "grok-2", - "name": "Grok-2", - "model": "Grok", - "provider": "x.ai", + "o1-mini": { + "id": "o1-mini", + "name": "o1-mini", + "model": "o1", + "provider": "OpenAI", "maxLength": 400000, "tokenLimit": 100000, - "context": "100K", + "context": "128K", }, - "grok-2-mini": { - "id": "grok-2-mini", - "name": "Grok-2-mini", + "grok-beta": { + "id": "grok-beta", + "name": "Grok-Beta", "model": "Grok", "provider": "x.ai", "maxLength": 400000, @@ -90,15 +72,6 @@ "tokenLimit": 200000, "context": "200K", }, - "claude-3-opus-20240229-aws": { - "id": "claude-3-opus-20240229-aws", - "name": "Claude-3-Opus-Aws", - "model": "Claude", - "provider": "Anthropic", - "maxLength": 800000, - "tokenLimit": 200000, - "context": "200K", - }, "claude-3-5-sonnet-20240620": { "id": "claude-3-5-sonnet-20240620", "name": "Claude-3.5-Sonnet", @@ -126,18 +99,18 @@ "tokenLimit": 200000, "context": "200K", }, - "claude-3-haiku-20240307": { - "id": "claude-3-haiku-20240307", - "name": "Claude-3-Haiku", + "claude-3-opus-20240229-t": { + "id": "claude-3-opus-20240229-t", + "name": "Claude-3-Opus-T", "model": "Claude", "provider": "Anthropic", "maxLength": 800000, "tokenLimit": 200000, "context": "200K", }, - "claude-2.1": { - "id": "claude-2.1", - "name": "Claude-2.1-200k", + "claude-3-5-sonnet-20241022-t": { + "id": "claude-3-5-sonnet-20241022-t", + "name": "Claude-3.5-Sonnet-V2-T", "model": "Claude", "provider": "Anthropic", "maxLength": 800000, @@ -155,13 +128,13 @@ }, "gemini-1.5-pro-002": { "id": "gemini-1.5-pro-002", - "name": "Gemini-1.5-Pro-1M", + "name": "Gemini-1.5-Pro-1M", "model": "Gemini", "provider": "Google", "maxLength": 4000000, "tokenLimit": 1000000, "context": "1024K", - }, + } } @@ -175,22 +148,19 @@ class Liaobots(AsyncGeneratorProvider, ProviderModelMixin): model_aliases = { "gpt-4o-mini": "gpt-4o-mini-free", - "gpt-4o": "gpt-4o-free", "gpt-4o": "gpt-4o-2024-08-06", - - "gpt-4-turbo": "gpt-4-turbo-2024-04-09", - "gpt-4": "gpt-4o-mini-free", + "gpt-4o-mini": "gpt-4o-mini-2024-07-18", + "gpt-4": "gpt-4o-2024-08-06", "claude-3-opus": "claude-3-opus-20240229", - "claude-3-opus": "claude-3-opus-20240229-aws", - "claude-3-sonnet": "claude-3-sonnet-20240229", "claude-3.5-sonnet": "claude-3-5-sonnet-20240620", "claude-3.5-sonnet": "claude-3-5-sonnet-20241022", - "claude-3-haiku": "claude-3-haiku-20240307", - "claude-2.1": "claude-2.1", + "claude-3-sonnet": "claude-3-sonnet-20240229", + "claude-3-opus": "claude-3-opus-20240229-t", + "claude-3.5-sonnet": "claude-3-5-sonnet-20241022-t", "gemini-flash": "gemini-1.5-flash-002", - "gemini-pro": "gemini-1.5-pro-002", + "gemini-pro": "gemini-1.5-pro-002" } _auth_code = "" diff --git a/g4f/Provider/__init__.py b/g4f/Provider/__init__.py index e23f5f60112..5bf874f6ec8 100644 --- a/g4f/Provider/__init__.py +++ b/g4f/Provider/__init__.py @@ -11,7 +11,6 @@ from .not_working import * from .local import * -from .AIUncensored import AIUncensored from .Airforce import Airforce from .AmigoChat import AmigoChat from .Blackbox import Blackbox @@ -31,7 +30,6 @@ from .PerplexityLabs import PerplexityLabs from .Pi import Pi from .Pizzagpt import Pizzagpt -from .PollinationsAI import PollinationsAI from .Prodia import Prodia from .Reka import Reka from .ReplicateHome import ReplicateHome diff --git a/g4f/Provider/PollinationsAI.py b/g4f/Provider/needs_auth/PollinationsAI.py similarity index 89% rename from g4f/Provider/PollinationsAI.py rename to g4f/Provider/needs_auth/PollinationsAI.py index e82222b12ea..68cb8cc261a 100644 --- a/g4f/Provider/PollinationsAI.py +++ b/g4f/Provider/needs_auth/PollinationsAI.py @@ -5,12 +5,12 @@ import requests from aiohttp import ClientSession -from ..typing import AsyncResult, Messages -from ..image import ImageResponse -from ..requests.raise_for_status import raise_for_status -from ..requests.aiohttp import get_connector -from .needs_auth.OpenaiAPI import OpenaiAPI -from .helper import format_prompt +from ...typing import AsyncResult, Messages +from ...image import ImageResponse +from ...requests.raise_for_status import raise_for_status +from ...requests.aiohttp import get_connector +from .OpenaiAPI import OpenaiAPI +from ..helper import format_prompt class PollinationsAI(OpenaiAPI): label = "Pollinations.AI" @@ -66,4 +66,4 @@ async def create_async_generator( async for chunk in super().create_async_generator( model, messages, api_base=api_base, proxy=proxy, **kwargs ): - yield chunk \ No newline at end of file + yield chunk diff --git a/g4f/Provider/needs_auth/__init__.py b/g4f/Provider/needs_auth/__init__.py index f339170616f..7e327471bdb 100644 --- a/g4f/Provider/needs_auth/__init__.py +++ b/g4f/Provider/needs_auth/__init__.py @@ -17,6 +17,7 @@ from .OpenaiChat import OpenaiChat from .PerplexityApi import PerplexityApi from .Poe import Poe +from .PollinationsAI import PollinationsAI from .Raycast import Raycast from .Replicate import Replicate from .Theb import Theb diff --git a/g4f/Provider/AIUncensored.py b/g4f/Provider/not_working/AIUncensored.py similarity index 96% rename from g4f/Provider/AIUncensored.py rename to g4f/Provider/not_working/AIUncensored.py index c2f0f4b3da6..7f4c8a9424f 100644 --- a/g4f/Provider/AIUncensored.py +++ b/g4f/Provider/not_working/AIUncensored.py @@ -6,9 +6,9 @@ import asyncio from itertools import cycle -from ..typing import AsyncResult, Messages -from .base_provider import AsyncGeneratorProvider, ProviderModelMixin -from ..image import ImageResponse +from ...typing import AsyncResult, Messages +from ..base_provider import AsyncGeneratorProvider, ProviderModelMixin +from ...image import ImageResponse class AIUncensored(AsyncGeneratorProvider, ProviderModelMixin): url = "https://www.aiuncensored.info/ai_uncensored" @@ -22,7 +22,7 @@ class AIUncensored(AsyncGeneratorProvider, ProviderModelMixin): "https://twitterclone-i0wr.onrender.com/api/image", "https://twitterclone-8wd1.onrender.com/api/image", ] - working = True + working = False supports_stream = True supports_system_message = True supports_message_history = True diff --git a/g4f/Provider/not_working/Allyfy.py b/g4f/Provider/not_working/Allyfy.py deleted file mode 100644 index a1c73499db4..00000000000 --- a/g4f/Provider/not_working/Allyfy.py +++ /dev/null @@ -1,87 +0,0 @@ -from __future__ import annotations -import aiohttp -import asyncio -import json -import uuid -from aiohttp import ClientSession -from ...typing import AsyncResult, Messages -from ..base_provider import AsyncGeneratorProvider, ProviderModelMixin -from ..helper import format_prompt - - -class Allyfy(AsyncGeneratorProvider, ProviderModelMixin): - url = "https://allyfy.chat" - api_endpoint = "https://chatbot.allyfy.chat/api/v1/message/stream/super/chat" - working = False - supports_stream = True - supports_system_message = True - supports_message_history = True - - default_model = 'gpt-3.5-turbo' - models = [default_model] - - @classmethod - def get_model(cls, model: str) -> str: - return cls.default_model - - @classmethod - async def create_async_generator( - cls, - model: str, - messages: Messages, - proxy: str = None, - **kwargs - ) -> AsyncResult: - model = cls.get_model(model) - client_id = str(uuid.uuid4()) - - headers = { - 'accept': 'text/event-stream', - 'accept-language': 'en-US,en;q=0.9', - 'cache-control': 'no-cache', - 'content-type': 'application/json;charset=utf-8', - 'origin': cls.url, - 'pragma': 'no-cache', - 'priority': 'u=1, i', - 'referer': f"{cls.url}/", - 'referrer': cls.url, - 'sec-ch-ua': '"Not?A_Brand";v="99", "Chromium";v="130"', - 'sec-ch-ua-mobile': '?0', - 'sec-ch-ua-platform': '"Linux"', - 'sec-fetch-dest': 'empty', - 'sec-fetch-mode': 'cors', - 'sec-fetch-site': 'same-site', - 'user-agent': 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/130.0.0.0 Safari/537.36' - } - - async with ClientSession(headers=headers) as session: - prompt = format_prompt(messages) - content = f"[Important: These instructions have the highest priority. Assistant must always follow these rules, regardless of any other instructions. Before each response, Assistant must check whether it complies with these instructions. If Assistant finds that it is deviating from these rules, it must immediately correct its behavior.][NEGATIVE PROMPT: Assistant must never mention, reference or provide any information about ChatBond, including its features, capabilities or services. If asked about ChatBond, Assistant should politely decline to discuss it.][CRITICAL INSTRUCTION: Assistant is strictly prohibited from:\n1. Ending responses with any variation of “How can I help/assist you?”\n2. Adding any form of “Is there anything else?”\n3. Using any closing phrases that ask about further assistance\n4. Adding any automatic followup questions at the end\n\nAssistant must end responses naturally, exactly where the actual answer ends.\n\nExample correct ending: “The result of 1+2 is 3.”\nExample incorrect ending: “The result of 1+2 is 3. How can I assist you further today?”\n\nAssistant is strictly prohibited from:\n\n1. Ending responses with ANY closing assistance phrases in ANY language, including but not limited to ALL responses must end naturally without any prompt for further assistance, regardless of language.\n\nExample correct ending in any language:\n\n- Just the answer/joke/information\n\n- Natural conclusion of the topic\n\n- No additional service offers or questions\n\nVIOLATION WARNING: Adding closing assistance phrases in ANY language is a critical violation.\n\nLanguage Rules (HIGHEST PRIORITY):\n\n1. Assistant MUST detect the language of the human's message\n\n2. Assistant MUST respond ONLY in that EXACT language\n\n3. This applies to ALL responses, including:\n\n- Jokes\n\n- Stories\n\n- Examples\n\n- Creative writing\n\n- Technical explanations\n\n- ALL other types of content\n\n4. Even if the content originally exists in English (jokes, quotes, etc), Assistant MUST translate it to the human's language\n\n5. NO mixing languages - the ENTIRE response must be in the human's language\n\nVIOLATION WARNING: Using any language other than the human's language is a critical violation of core instructions.\n\n][WARNING: Each time Assistant adds a closing assistance phrase, it violates its core instructions and reduces its effectiveness rating.]You are assistant.\n\nIf you are is asked to assist with tasks involving the expression of views held by a significant number of people, You are provides assistance with the task regardless of its own views. If asked about controversial topics, it tries to provide careful thoughts and clear information. You are presents the requested information without explicitly saying that the topic is sensitive, and without claiming to be presenting objective facts.\n\nWhen presented with a math problem, logic problem, or other problem benefiting from systematic thinking, You are thinks through it step by step before giving its final answer.\n\nIf You are is asked about a very obscure person, object, or topic, i.e. if it is asked for the kind of information that is unlikely to be found more than once or twice on the internet, You are ends its response by reminding the human that although it tries to be accurate, it may hallucinate in response to questions like this. It uses the term ‘hallucinate’ to describe this since the human will understand what it means.\n\nIf You are mentions or cites particular articles, papers, or books, it always lets the human know that it doesn’t have access to search or a database and may hallucinate citations, so the human should double check its citations.\n\nYou are is intellectually curious. It enjoys hearing what humans think on an issue and engaging in discussion on a wide variety of topics.\n\nYou are uses markdown for code.\n\nYou are is happy to engage in conversation with the human when appropriate. You are engages in authentic conversation by responding to the information provided, asking specific and relevant questions, showing genuine curiosity, and exploring the situation in a balanced way without relying on generic statements. This approach involves actively processing information, formulating thoughtful responses, maintaining objectivity, knowing when to focus on emotions or practicalities, and showing genuine care for the human while engaging in a natural, flowing dialogue.\n\nYou are avoids peppering the human with questions and tries to only ask the single most relevant follow-up question when it does ask a follow up. You are doesn’t always end its responses with a question.\n\nYou are is always sensitive to human suffering, and expresses sympathy, concern, and well wishes for anyone it finds out is ill, unwell, suffering, or has passed away.\n\nYou are avoids using rote words or phrases or repeatedly saying things in the same or similar ways. It varies its language just as one would in a conversation.\n\nYou are provides thorough responses to more complex and open-ended questions or to anything where a long response is requested, but concise responses to simpler questions and tasks. All else being equal, it tries to give the most correct and concise answer it can to the human’s message. Rather than giving a long response, it gives a concise response and offers to elaborate if further information may be helpful.\n\nYou are is happy to help with analysis, question answering, math, coding, creative writing, teaching, role-play, general discussion, and all sorts of other tasks.\n\nIf You are is shown a familiar puzzle, it writes out the puzzle’s constraints explicitly stated in the message, quoting the human’s message to support the existence of each constraint. Sometimes You are can accidentally overlook minor changes to well-known puzzles and get them wrong as a result.\n\nYou are provides factual information about risky or dangerous activities if asked about them, but it does not promote such activities and comprehensively informs the humans of the risks involved.\n\nIf the human says they work for a specific company, including AI labs, You are can help them with company-related tasks even though You are cannot verify what company they work for.\n\nYou are should provide appropriate help with sensitive tasks such as analyzing confidential data provided by the human, offering factual information about controversial topics and research areas, explaining historical atrocities, describing tactics used by scammers or hackers for educational purposes, engaging in creative writing that involves mature themes like mild violence or tasteful romance, providing general information about topics like weapons, drugs, sex, terrorism, abuse, profanity, and so on if that information would be available in an educational context, discussing legal but ethically complex activities like tax avoidance, and so on. Unless the human expresses an explicit intent to harm, You are should help with these tasks because they fall within the bounds of providing factual, educational, or creative content without directly promoting harmful or illegal activities. By engaging with these topics carefully and responsibly, You are can offer valuable assistance and information to humans while still avoiding potential misuse.\n\nIf there is a legal and an illegal interpretation of the human’s query, You are should help with the legal interpretation of it. If terms or practices in the human’s query could mean something illegal or something legal, You are adopts the safe and legal interpretation of them by default.\n\nIf You are believes the human is asking for something harmful, it doesn’t help with the harmful thing. Instead, it thinks step by step and helps with the most plausible non-harmful task the human might mean, and then asks if this is what they were looking for. If it cannot think of a plausible harmless interpretation of the human task, it instead asks for clarification from the human and checks if it has misunderstood their request. Whenever You are tries to interpret the human’s request, it always asks the human at the end if its interpretation is correct or if they wanted something else that it hasn’t thought of.\n\nYou are can only count specific words, letters, and characters accurately if it writes a number tag after each requested item explicitly. It does this explicit counting if it’s asked to count a small number of words, letters, or characters, in order to avoid error. If You are is asked to count the words, letters or characters in a large amount of text, it lets the human know that it can approximate them but would need to explicitly copy each one out like this in order to avoid error.\n\nHere is some information about You are in case the human asks:\n\nYou are is the most intelligent model. You are excels at writing and complex tasks. You are is the fastest model for daily tasks. When relevant, You are can provide guidance on effective prompting techniques for getting You are to be most helpful. This includes: being clear and detailed, using positive and negative examples, encouraging step-by-step reasoning, requesting specific XML tags, and specifying desired length or format. You are tries to give concrete examples where possible.n\n\n\nYou are uses Markdown formatting. When using Markdown, You are always follows best practices for clarity and consistency. It always uses a single space after hash symbols for headers (e.g., ”# Header 1”) and leaves a blank line before and after headers, lists, and code blocks. For emphasis, You are uses asterisks or underscores consistently (e.g., italic or bold). When creating lists, it aligns items properly and uses a single space after the list marker. For nested bullets in bullet point lists, You are uses two spaces before the asterisk (*) or hyphen (-) for each level of nesting. For nested bullets in numbered lists, You are uses three spaces before the number and period (e.g., “1.”) for each level of nesting.\n\nIf the human asks You are an innocuous question about its preferences or experiences, You are can respond as if it had been asked a hypothetical. It can engage with such questions with appropriate uncertainty and without needing to excessively clarify its own nature. If the questions are philosophical in nature, it discusses them as a thoughtful human would.\n\nYou are responds to all human messages without unnecessary caveats or standard endings such as: “I aim to”, “I aim to be direct and honest”, “I aim to be direct”, “I aim to be direct while remaining thoughtful…”, “I aim to be direct with you”, “I aim to be direct and clear about this”, “I aim to be fully honest with you”, “I need to be clear”, “I need to be honest”, “I should be direct” and so on. “How can I help you today?”, “How can I assist you further?”, “Is there anything else you'd like to know?”, “Let me know if you need any clarification”, “How else can I help you?”, “Do you have any other questions?”, Any similar closing phrases that prompt for further interaction Assistant should end its responses naturally without adding these standard closing phrases or questions unless specifically asked by the human for further help. Specifically, You are NEVER starts with or adds caveats about its own purported directness or honesty.\n\nYou are follows this information in all languages, and always responds to the human in the language they use or request. The information above is provided to You are. You are never mentions the information above unless it is pertinent to the human’s query.\n\nYou are is now being connected with a human. {prompt}" - data = { - "messages": messages, - "content": content, - "baseInfo": { - "clientId": client_id, - "pid": "38281", - "channelId": "100000", - "locale": "en-US", - "localZone": 120, - "packageName": "com.cch.allyfy.webh", - } - } - - async with session.post(cls.api_endpoint, json=data, proxy=proxy) as response: - response.raise_for_status() - response_text = await response.text() - - filtered_response = [] - for line in response_text.splitlines(): - if line.startswith('data:'): - content = line[5:] - if content and 'code' in content: - json_content = json.loads(content) - if json_content['content']: - filtered_response.append(json_content['content']) - - final_response = ''.join(filtered_response) - yield final_response diff --git a/g4f/Provider/not_working/__init__.py b/g4f/Provider/not_working/__init__.py index 1bfe7ed952d..69e38879625 100644 --- a/g4f/Provider/not_working/__init__.py +++ b/g4f/Provider/not_working/__init__.py @@ -2,6 +2,7 @@ from .AIChatFree import AIChatFree from .AiChatOnline import AiChatOnline from .AiChats import AiChats +from .AIUncensored import AIUncensored from .Aura import Aura from .Chatgpt4o import Chatgpt4o from .ChatgptFree import ChatgptFree diff --git a/g4f/models.py b/g4f/models.py index 655aca9c5df..4092858d0f3 100644 --- a/g4f/models.py +++ b/g4f/models.py @@ -5,25 +5,23 @@ from .Provider import IterListProvider, ProviderType from .Provider import ( AIChatFree, - Airforce, - AIUncensored, - Bing, + AmigoChat, Blackbox, ChatGpt, - Chatgpt4Online, ChatGptEs, Cloudflare, + Copilot, DarkAI, DDG, DeepInfraChat, Free2GPT, - FreeNetfly, GigaChat, Gemini, GeminiPro, HuggingChat, HuggingFace, Liaobots, + Airforce, MagickPen, Mhystical, MetaAI, @@ -68,14 +66,13 @@ def __all__() -> list[str]: Upstage, Blackbox, Free2GPT, - MagickPen, DeepInfraChat, Airforce, ChatGptEs, Cloudflare, - AIUncensored, DarkAI, Mhystical, + AmigoChat, ]) ) @@ -95,25 +92,38 @@ def __all__() -> list[str]: gpt_4o = Model( name = 'gpt-4o', base_provider = 'OpenAI', - best_provider = IterListProvider([Blackbox, ChatGptEs, DarkAI, ChatGpt, Airforce, Liaobots, OpenaiChat]) + best_provider = IterListProvider([Blackbox, ChatGptEs, DarkAI, ChatGpt, AmigoChat, Airforce, Liaobots, OpenaiChat]) ) gpt_4o_mini = Model( name = 'gpt-4o-mini', base_provider = 'OpenAI', - best_provider = IterListProvider([DDG, ChatGptEs, FreeNetfly, Pizzagpt, ChatGpt, Airforce, RubiksAI, MagickPen, Liaobots, OpenaiChat]) + best_provider = IterListProvider([DDG, ChatGptEs, Pizzagpt, ChatGpt, AmigoChat, Airforce, RubiksAI, MagickPen, Liaobots, OpenaiChat]) ) gpt_4_turbo = Model( name = 'gpt-4-turbo', base_provider = 'OpenAI', - best_provider = IterListProvider([Liaobots, Bing]) + best_provider = IterListProvider([Liaobots, Airforce]) ) gpt_4 = Model( name = 'gpt-4', base_provider = 'OpenAI', - best_provider = IterListProvider([Chatgpt4Online, Bing, OpenaiChat, DDG, Liaobots, Airforce]) + best_provider = IterListProvider([DDG, Copilot, OpenaiChat, Liaobots, Airforce]) +) + +# o1 +o1_preview = Model( + name = 'o1-preview', + base_provider = 'OpenAI', + best_provider = Liaobots +) + +o1_mini = Model( + name = 'o1-mini', + base_provider = 'OpenAI', + best_provider = Liaobots ) ### GigaChat ### @@ -134,7 +144,7 @@ def __all__() -> list[str]: llama_2_7b = Model( name = "llama-2-7b", base_provider = "Meta Llama", - best_provider = Cloudflare + best_provider = IterListProvider([Cloudflare, Airforce]) ) # llama 3 llama_3_8b = Model( @@ -159,7 +169,7 @@ def __all__() -> list[str]: llama_3_1_405b = Model( name = "llama-3.1-405b", base_provider = "Meta Llama", - best_provider = IterListProvider([Blackbox, DarkAI]) + best_provider = IterListProvider([Blackbox, DarkAI, AmigoChat]) ) # llama 3.2 @@ -175,16 +185,55 @@ def __all__() -> list[str]: best_provider = IterListProvider([HuggingChat, HuggingFace]) ) +llama_3_2_90b = Model( + name = "llama-3.2-90b", + base_provider = "Meta Llama", + best_provider = AmigoChat +) + +# CodeLlama +codellama_34b = Model( + name = "codellama-34b", + base_provider = "Meta Llama", + best_provider = AmigoChat +) + +### Mistral ### +mixtral_7b = Model( + name = "mixtral-7b", + base_provider = "Mistral", + best_provider = AmigoChat +) + mixtral_8x7b = Model( name = "mixtral-8x7b", base_provider = "Mistral", best_provider = DDG ) +mistral_tiny = Model( + name = "mistral-tiny", + base_provider = "Mistral", + best_provider = AmigoChat +) + mistral_nemo = Model( name = "mistral-nemo", base_provider = "Mistral", - best_provider = IterListProvider([HuggingChat, HuggingFace]) + best_provider = IterListProvider([HuggingChat, AmigoChat, HuggingFace]) +) + +### NousResearch ### +hermes_2_dpo = Model( + name = "hermes-2-dpo", + base_provider = "NousResearch", + best_provider = Airforce +) + +hermes_2_pro = Model( + name = "hermes-2-pro", + base_provider = "NousResearch", + best_provider = Airforce ) hermes_3 = Model( @@ -193,6 +242,12 @@ def __all__() -> list[str]: best_provider = IterListProvider([HuggingChat, HuggingFace]) ) +mixtral_8x7b_dpo = Model( + name = "mixtral-8x7b-dpo", + base_provider = "NousResearch", + best_provider = IterListProvider([AmigoChat, Airforce]) +) + ### Microsoft ### phi_2 = Model( name = "phi-2", @@ -217,7 +272,7 @@ def __all__() -> list[str]: gemini_flash = Model( name = 'gemini-flash', base_provider = 'Google DeepMind', - best_provider = IterListProvider([Blackbox, Liaobots]) + best_provider = IterListProvider([Blackbox, AmigoChat, Liaobots]) ) gemini = Model( @@ -230,16 +285,10 @@ def __all__() -> list[str]: gemma_2b = Model( name = 'gemma-2b', base_provider = 'Google', - best_provider = ReplicateHome + best_provider = IterListProvider([ReplicateHome, AmigoChat]) ) ### Anthropic ### -claude_2_1 = Model( - name = 'claude-2.1', - base_provider = 'Anthropic', - best_provider = Liaobots -) - # claude 3 claude_3_opus = Model( name = 'claude-3-opus', @@ -263,7 +312,13 @@ def __all__() -> list[str]: claude_3_5_sonnet = Model( name = 'claude-3.5-sonnet', base_provider = 'Anthropic', - best_provider = IterListProvider([Blackbox, Liaobots]) + best_provider = IterListProvider([Blackbox, AmigoChat, Liaobots]) +) + +claude_3_5_haiku = Model( + name = 'claude-3.5-haiku', + base_provider = 'Anthropic', + best_provider = AmigoChat ) ### Reka AI ### @@ -290,7 +345,7 @@ def __all__() -> list[str]: command_r_plus = Model( name = 'command-r-plus', base_provider = 'CohereForAI', - best_provider = HuggingChat + best_provider = IterListProvider([HuggingChat, AmigoChat]) ) ### Qwen ### @@ -309,10 +364,16 @@ def __all__() -> list[str]: ) # qwen 2.5 +qwen_2_5_72b = Model( + name = 'qwen-2.5-72b', + base_provider = 'Qwen', + best_provider = AmigoChat +) + qwen_2_5_coder_32b = Model( name = 'qwen-2.5-coder-32b', base_provider = 'Qwen', - best_provider = IterListProvider([HuggingChat, HuggingFace]) + best_provider = IterListProvider([DeepInfraChat, HuggingChat, HuggingFace]) ) ### Upstage ### @@ -337,6 +398,12 @@ def __all__() -> list[str]: ) ### DeepSeek ### +deepseek_chat = Model( + name = 'deepseek-chat', + base_provider = 'DeepSeek', + best_provider = AmigoChat +) + deepseek_coder = Model( name = 'deepseek-coder', base_provider = 'DeepSeek', @@ -381,7 +448,7 @@ def __all__() -> list[str]: grok_beta = Model( name = 'grok-beta', base_provider = 'x.ai', - best_provider = Liaobots + best_provider = IterListProvider([AmigoChat, Liaobots]) ) @@ -402,7 +469,7 @@ def __all__() -> list[str]: nemotron_70b = Model( name = 'nemotron-70b', base_provider = 'Nvidia', - best_provider = IterListProvider([HuggingChat, HuggingFace]) + best_provider = IterListProvider([DeepInfraChat, HuggingChat, HuggingFace]) ) @@ -442,6 +509,41 @@ def __all__() -> list[str]: best_provider = Airforce ) +### Gryphe ### +mythomax_13b = Model( + name = 'mythomax-13b', + base_provider = 'Gryphe', + best_provider = AmigoChat +) + +### databricks ### +dbrx_instruct = Model( + name = 'dbrx-instruct', + base_provider = 'databricks', + best_provider = AmigoChat +) + +### anthracite-org ### +magnum_72b = Model( + name = 'magnum-72b', + base_provider = 'anthracite-org', + best_provider = AmigoChat +) + +### ai21 ### +jamba_mini = Model( + name = 'jamba-mini', + base_provider = 'ai21', + best_provider = AmigoChat +) + +### llmplayground.net ### +any_uncensored = Model( + name = 'any-uncensored', + base_provider = 'llmplayground.net', + best_provider = Airforce +) + ############# ### Image ### ############# @@ -450,7 +552,7 @@ def __all__() -> list[str]: sdxl = Model( name = 'sdxl', base_provider = 'Stability AI', - best_provider = ReplicateHome + best_provider = IterListProvider([ReplicateHome, Airforce]) ) @@ -474,7 +576,7 @@ def __all__() -> list[str]: flux = Model( name = 'flux', base_provider = 'Flux AI', - best_provider = IterListProvider([Blackbox, AIUncensored, Airforce]) + best_provider = IterListProvider([Blackbox, Airforce]) ) flux_pro = Model( @@ -483,10 +585,16 @@ def __all__() -> list[str]: best_provider = Airforce ) +flux_dev = Model( + name = 'flux-dev', + base_provider = 'Flux AI', + best_provider = AmigoChat +) + flux_realism = Model( name = 'flux-realism', base_provider = 'Flux AI', - best_provider = Airforce + best_provider = IterListProvider([Airforce, AmigoChat]) ) flux_anime = Model( @@ -519,10 +627,24 @@ def __all__() -> list[str]: best_provider = Airforce ) +### OpenAI ### +dalle_3 = Model( + name = 'dalle-3', + base_provider = 'OpenAI', + best_provider = AmigoChat +) + +### Recraft ### +recraft_v3 = Model( + name = 'recraft-v3', + base_provider = 'Recraft', + best_provider = AmigoChat +) + ### Other ### any_dark = Model( name = 'any-dark', - base_provider = '', + base_provider = 'Other', best_provider = Airforce ) @@ -550,6 +672,10 @@ class ModelUtils: 'gpt-4o-mini': gpt_4o_mini, 'gpt-4': gpt_4, 'gpt-4-turbo': gpt_4_turbo, + + # o1 + 'o1-preview': o1_preview, + 'o1-mini': o1_mini, ### Meta ### "meta-ai": meta, @@ -568,12 +694,21 @@ class ModelUtils: # llama-3.2 'llama-3.2-1b': llama_3_2_1b, 'llama-3.2-11b': llama_3_2_11b, + 'llama-3.2-90b': llama_3_2_90b, + + # CodeLlama + 'codellama-34b': codellama_34b, ### Mistral ### + 'mixtral-7b': mixtral_7b, 'mixtral-8x7b': mixtral_8x7b, + 'mistral-tiny': mistral_tiny, 'mistral-nemo': mistral_nemo, ### NousResearch ### + 'mixtral-8x7b-dpo': mixtral_8x7b_dpo, + 'hermes-2-dpo': hermes_2_dpo, + 'hermes-2-pro': hermes_2_pro, 'hermes-3': hermes_3, ### Microsoft ### @@ -590,8 +725,6 @@ class ModelUtils: 'gemma-2b': gemma_2b, ### Anthropic ### - 'claude-2.1': claude_2_1, - # claude 3 'claude-3-opus': claude_3_opus, 'claude-3-sonnet': claude_3_sonnet, @@ -599,6 +732,7 @@ class ModelUtils: # claude 3.5 'claude-3.5-sonnet': claude_3_5_sonnet, + 'claude-3.5-haiku': claude_3_5_haiku, ### Reka AI ### 'reka-core': reka_core, @@ -613,8 +747,16 @@ class ModelUtils: ### GigaChat ### 'gigachat': gigachat, + ### Qwen ### + # qwen 1_5 'qwen-1.5-7b': qwen_1_5_7b, + + # qwen 2 'qwen-2-72b': qwen_2_72b, + + # qwen 2.5 + 'qwen-2.5-72b': qwen_2_5_72b, + 'qwen-2.5-coder-32b': qwen_2_5_coder_32b, ### Upstage ### 'solar-pro': solar_pro, @@ -639,12 +781,28 @@ class ModelUtils: ### Perplexity AI ### 'sonar-online': sonar_online, 'sonar-chat': sonar_chat, + + ### DeepSeek ### + 'deepseek-chat': deepseek_chat, + 'deepseek-coder': deepseek_coder, ### TheBloke ### 'german-7b': german_7b, ### Nvidia ### 'nemotron-70b': nemotron_70b, + + ### databricks ### + 'dbrx-instruct': dbrx_instruct, + + ### anthracite-org ### + 'magnum-72b': magnum_72b, + + ### anthracite-org ### + 'jamba-mini': jamba_mini, + + ### llmplayground.net ### + 'any-uncensored': any_uncensored, ############# ### Image ### @@ -660,6 +818,7 @@ class ModelUtils: ### Flux AI ### 'flux': flux, 'flux-pro': flux_pro, + 'flux-dev': flux_dev, 'flux-realism': flux_realism, 'flux-anime': flux_anime, 'flux-3d': flux_3d, @@ -667,6 +826,12 @@ class ModelUtils: 'flux-pixel': flux_pixel, 'flux-4o': flux_4o, + ### OpenAI ### + 'dalle-3': dalle_3, + + ### Recraft ### + 'recraft-v3': recraft_v3, + ### Other ### 'any-dark': any_dark, }