Recently announced by Andrew Ng, aisuite aims to provide an OpenAI-like API around the most popular large language models (LLMs) currently available to make it easy for developers to try them out and compare results or switch from one LLM to another without having to change their code.

According to Andrew Ng, using multiple LLM providers in the same application can be a hassle, whereas aisuite aims to make it so easy as changing one single string when instantiating it main component to select the desired LLM provider. For example, to use OpenAI GPT-4o, you would pass "openai:gpt-4o" as the model argument into the call to create aisuite chat completion agent. This is further shown in the following code snippet:

import aisuite as ai
client = ai.Client()

messages = [
    {"role": "system", "content": "Respond in Pirate English."},
    {"role": "user", "content": "Tell me a joke."},
]

response = client.chat.completions.create(
    model="openai:gpt-4o",
    messages=messages,
    temperature=0.75
)
print(response.choices[0].message.content)

response = client.chat.completions.create(
    model="anthropic:claude-3-5-sonnet-20240620",
    messages=messages,
    temperature=0.75
)
print(response.choices[0].message.content)

To install aisuite you just run pip install aisuite. The library also provides shortcuts to install LLM provider libraries. For example, you run pip install 'aisuite[anthropic]' to install the base library plus Anthropic support.

Several X users replied to Ng's announcement, echoing the same feeling that aisuite actually addresses real pain points when deploying LLMs. Reddit users compared the availability of proxy libraries, such as aisuite to database abstraction layers enabling the switch from, e.g., sqlite in testing to another database in production.

While the overall reception was generally positive, some X and Reddit users highlighted a few limitations of aisuite, including the fact it does not yet support streaming nor other fine points such as rate limits, token usage monitoring, and so on. Likewise, it is unclear how well aisuite currently supports using custom Cloud-deployed LLMs. Anyhow, it is worth remembering that the library is still in its infancy and under active development.

aisuite is not the only solution currently available to address LLM cross-compatibility. Specifically, LiteLLM appears to be a rather more mature and feature-complete solution enabling to call multiple LLMs using the same OpenAI-like API, including support for rate and budget limits on a project-by-project basis. Also worth mentioning is OpenRouter, which furthermore provides its own Web-based UI.

aisuite currently supports OpenAI, Anthropic, Azure, Google, AWS, Groq, Mistral, HuggingFace and Ollama. The library is written in Python and requires developers to own API keys for any LLM providers they would like to use. The library uses either the API or the SDK published by each LLM provider to maximize stability. Currently, it is mostly focused on chat completions, but new use cases will be covered in future, say its maintainers.

微信扫一扫