๐Ÿš… LiteLLM

Call all LLM APIs using the OpenAI format [Anthropic, Huggingface, Cohere, TogetherAI, Azure, OpenAI, etc.]

Schedule Demo ยท Feature Request

PyPI Version CircleCI Y Combinator W23 Whatsapp Discord

Docs 100+ Supported Models Demo Video
LiteLLM manages - Translating inputs to the provider's completion and embedding endpoints - Guarantees [consistent output](https://docs.litellm.ai/docs/completion/output), text responses will always be available at `['choices'][0]['message']['content']` - Exception mapping - common exceptions across providers are mapped to the OpenAI exception types. **10/05/2023:** LiteLLM is adopting Semantic Versioning for all commits. [Learn more](https://github.com/BerriAI/litellm/issues/532) **10/16/2023:** **Self-hosted OpenAI-proxy server** [Learn more](https://docs.litellm.ai/docs/proxy_server#deploy-proxy) # Usage Open In Colab ``` pip install litellm ``` ```python from litellm import completion import os ## set ENV variables os.environ["OPENAI_API_KEY"] = "your-openai-key" os.environ["COHERE_API_KEY"] = "your-cohere-key" messages = [{ "content": "Hello, how are you?","role": "user"}] # openai call response = completion(model="gpt-3.5-turbo", messages=messages) # cohere call response = completion(model="command-nightly", messages=messages) print(response) ``` ## Streaming ([Docs](https://docs.litellm.ai/docs/completion/stream)) liteLLM supports streaming the model response back, pass `stream=True` to get a streaming iterator in response. Streaming is supported for OpenAI, Azure, Anthropic, Huggingface models ```python response = completion(model="gpt-3.5-turbo", messages=messages, stream=True) for chunk in response: print(chunk['choices'][0]['delta']) # claude 2 result = completion('claude-2', messages, stream=True) for chunk in result: print(chunk['choices'][0]['delta']) ``` ## OpenAI Proxy Server ([Docs](https://docs.litellm.ai/docs/proxy_server)) Create an OpenAI API compatible server to call any non-openai model (e.g. Huggingface, TogetherAI, Ollama, etc.) This works for async + streaming as well. ```python litellm --model #INFO: litellm proxy running on http://0.0.0.0:8000 ``` Running your model locally or on a custom endpoint ? Set the `--api-base` parameter [see how](https://docs.litellm.ai/docs/proxy_server) ### Self-host server ([Docs](https://docs.litellm.ai/docs/proxy_server#deploy-proxy)) 1. Clone the repo ```shell git clone https://github.com/BerriAI/litellm.git ``` 2. Modify `template_secrets.toml` ```shell [keys] OPENAI_API_KEY="sk-..." [general] default_model = "gpt-3.5-turbo" ``` 3. Deploy ```shell docker build -t litellm . && docker run -p 8000:8000 litellm ``` ## Supported Provider ([Docs](https://docs.litellm.ai/docs/providers)) | Provider | [Completion](https://docs.litellm.ai/docs/#basic-usage) | [Streaming](https://docs.litellm.ai/docs/completion/stream#streaming-responses) | [Async Completion](https://docs.litellm.ai/docs/completion/stream#async-completion) | [Async Streaming](https://docs.litellm.ai/docs/completion/stream#async-streaming) | | ------------- | ------------- | ------------- | ------------- | ------------- | | [openai](https://docs.litellm.ai/docs/providers/openai) | โœ… | โœ… | โœ… | โœ… | | [cohere](https://docs.litellm.ai/docs/providers/cohere) | โœ… | โœ… | โœ… | โœ… | | [anthropic](https://docs.litellm.ai/docs/providers/anthropic) | โœ… | โœ… | โœ… | โœ… | | [replicate](https://docs.litellm.ai/docs/providers/replicate) | โœ… | โœ… | โœ… | โœ… | | [huggingface](https://docs.litellm.ai/docs/providers/huggingface) | โœ… | โœ… | โœ… | โœ… | | [together_ai](https://docs.litellm.ai/docs/providers/togetherai) | โœ… | โœ… | โœ… | โœ… | | [openrouter](https://docs.litellm.ai/docs/providers/openrouter) | โœ… | โœ… | โœ… | โœ… | | [vertex_ai](https://docs.litellm.ai/docs/providers/vertex) | โœ… | โœ… | โœ… | โœ… | | [palm](https://docs.litellm.ai/docs/providers/palm) | โœ… | โœ… | โœ… | โœ… | | [ai21](https://docs.litellm.ai/docs/providers/ai21) | โœ… | โœ… | โœ… | โœ… | | [baseten](https://docs.litellm.ai/docs/providers/baseten) | โœ… | โœ… | โœ… | โœ… | | [azure](https://docs.litellm.ai/docs/providers/azure) | โœ… | โœ… | โœ… | โœ… | | [sagemaker](https://docs.litellm.ai/docs/providers/aws_sagemaker) | โœ… | โœ… | โœ… | โœ… | | [bedrock](https://docs.litellm.ai/docs/providers/bedrock) | โœ… | โœ… | โœ… | โœ… | | [vllm](https://docs.litellm.ai/docs/providers/vllm) | โœ… | โœ… | โœ… | โœ… | | [nlp_cloud](https://docs.litellm.ai/docs/providers/nlp_cloud) | โœ… | โœ… | โœ… | โœ… | | [aleph alpha](https://docs.litellm.ai/docs/providers/aleph_alpha) | โœ… | โœ… | โœ… | โœ… | | [petals](https://docs.litellm.ai/docs/providers/petals) | โœ… | โœ… | โœ… | โœ… | | [ollama](https://docs.litellm.ai/docs/providers/ollama) | โœ… | โœ… | โœ… | โœ… | | [deepinfra](https://docs.litellm.ai/docs/providers/deepinfra) | โœ… | โœ… | โœ… | โœ… | [**Read the Docs**](https://docs.litellm.ai/docs/) ## Logging Observability - Log LLM Input/Output ([Docs](https://docs.litellm.ai/docs/observability/callbacks)) LiteLLM exposes pre defined callbacks to send data to LLMonitor, Langfuse, Helicone, Promptlayer, Traceloop, Slack ```python from litellm import completion ## set env variables for logging tools os.environ["PROMPTLAYER_API_KEY"] = "your-promptlayer-key" os.environ["LLMONITOR_APP_ID"] = "your-llmonitor-app-id" os.environ["OPENAI_API_KEY"] # set callbacks litellm.success_callback = ["promptlayer", "llmonitor"] # log input/output to promptlayer, llmonitor, supabase #openai call response = completion(model="gpt-3.5-turbo", messages=[{"role": "user", "content": "Hi ๐Ÿ‘‹ - i'm openai"}]) ``` ## Contributing To contribute: Clone the repo locally -> Make a change -> Submit a PR with the change. Here's how to modify the repo locally: Step 1: Clone the repo ``` git clone https://github.com/BerriAI/litellm.git ``` Step 2: Navigate into the project, and install dependencies: ``` cd litellm poetry install ``` Step 3: Test your change: ``` cd litellm/tests # pwd: Documents/litellm/litellm/tests pytest . ``` Step 4: Submit a PR with your changes! ๐Ÿš€ - push your fork to your GitHub repo - submit a PR from there # Support / talk with founders - [Schedule Demo ๐Ÿ‘‹](https://calendly.com/d/4mp-gd3-k5k/berriai-1-1-onboarding-litellm-hosted-version) - [Community Discord ๐Ÿ’ญ](https://discord.gg/wuPM9dRgDw) - Our numbers ๐Ÿ“ž +1 (770) 8783-106 / โ€ญ+1 (412) 618-6238โ€ฌ - Our emails โœ‰๏ธ ishaan@berri.ai / krrish@berri.ai # Why did we build this - **Need for simplicity**: Our code started to get extremely complicated managing & translating calls between Azure, OpenAI and Cohere. # Contributors