Minimal Python library to connect to LLMs (OpenAI, Anthropic, AI21), with a built-in model performance benchmark.
Project description
PyLLMs
PyLLMs is a minimal Python library to connect to LLMs (OpenAI, Anthropic, AI21), with a built-in model performance benchmark.
It is ideal for fast prototyping and evaluationg different models thanks to:
- Connect to top LLMs in few lines of code (currenly OpenAI, Anthropic and AI21 are supported)
- Response meta includes tokens processed, cost and latency standardized across the models
- Multi-model support: Get completitions from different models at the same time
- LLM benchmark: Eevaluate models on quality, speed and cost
Feel free to reuse and expand. Pull requests are welcome.
Installation
Clone this repository and install the package using pip:
pip3 install pyllms
Usage
import llms
model = llms.init()
result = model.complete("what is 5+5")
print(result.text)
Library will attempt to read the API keys and the default model from environment variables, which you can set like this:
export OPENAI_API_KEY="your_api_key_here"
export ANTHROPIC_API_KEY="your_api_key_here"
export AI21_API_KEY="your_api_key_here"
export LLMS_DEFAULT_MODEL="gpt-3.5-turbo"
Alternatively, you can pass initialization values to the init() method:
model=llms.init(openai_api_key='your_api_key_here', model='gpt-4')
You can also pass optional parameters to the complete method. 'temperature' and 'max_tokens' are standardized across all APIs and get converted to the corresponding API params.
Any other parameters accepted by the original model are supported in their verbatim form.
result = model.complete(
"what is the capital of country where mozzart was born",
temperature=0.1,
max_tokens=200
)
Note: By default, temperature for all models is set to 0, and max_tokens to 300.
The result meta will contain helpful information like tokens used, cost (which is automatically calculated using current pricing), and response latency:
>>> print(result.meta)
{'model': 'gpt-3.5-turbo', 'tokens': 15, 'tokens_prompt': 14, 'tokens_completion': 1, 'cost': 3e-05, 'latency': 0.48232388496398926}
Multi-model usage
You can also initialize multiple models at once! This is very useful for testing and comparing output of different models in parallel.
>>> models=llms.init(model=['gpt-3.5-turbo','claude-instant-v1'])
>>> result=models.complete('what is the capital of country where mozzart was born')
>>> print(result.text)
['The capital of the country where Mozart was born is Vienna, Austria.', 'Wolfgang Amadeus Mozart was born in Salzburg, Austria.\n\nSo the capital of the country where Mozart was born is Vienna, Austria.']
>>> print(result.meta)
[{'model': 'gpt-3.5-turbo', 'tokens': 34, 'tokens_prompt': 20, 'tokens_completion': 14, 'cost': 6.8e-05, 'latency': 0.7097790241241455}, {'model': 'claude-instant-v1', 'tokens': 54, 'tokens_prompt': 20, 'tokens_completion': 34, 'cost': 5.79e-05, 'latency': 0.7291600704193115}]
Streaming support
PyLLMs supports streaming from compatible models. 'complete_stream' method will return generator object and all you have to do is iterate through it:
>>> model= llms.init('claude-v1')
>>> result = model.complete_stream("write an essay on civil war")
>>> for chunk in result:
... if chunk is not None:
... print(chunk, end='')
...
Here is a paragraph about civil rights:
Civil rights are the basic rights and freedoms that all citizens should have in a society. They include fundamental rights like the right to vote, the right to free speech, the right to practice the religion of one's choice, the right to equal treatment under the law, and the right to live free from discrimination. The civil rights movement in the United States fought to secure these rights for African Americans and other minorities in the face of institutionalized racism and discrimination. Leaders like Martin Luther King Jr. helped pass laws like the Civil Rights Act of 1964 and the Voting Rights Act of 1965 which outlawed discrimination and dismantled barriers to voting. The struggle for civil rights continues today as more work is still needed to promote racial equality and protect the rights of all citizens.
Current limitations:
- When streaming, 'meta' is not available
- Multi-models are not supported for streaming
Tip: if you are testing this in python3 CLI, run it with -u parameter to disable buffering:
python3 -u
Other methods
You can count tokens using the model's tokenizer:
count=model.count_tokens('the quick brown fox jumped over the lazy dog')
Model Benchmarks
Models are appearing like mushrooms after rain and everyone is interested in three things:
- Quality
- Speed
- Cost
PyLLMs icludes an automated benchmark system. The quality of models is evaluated using a powerful model (for example gpt-4) on a range of predefined questions, or you can supply your own.
models=llms.init(model=['gpt-3.5-turbo', 'claude-instant-v1', 'j2-jumbo-instruct'])
gpt4=llms.init('gpt-4') # optional, evaluator can be ommited and in that case only speed and cost will be evaluated
models.benchmark(evaluator=gpt4)
+---------------------------------------+--------------------+---------------------+-----------------------+---------------------------+-----------------+
| Model | Tokens | Cost ($) | Latency (s) | Speed (tokens/sec) | Evaluation |
+---------------------------------------+--------------------+---------------------+-----------------------+---------------------------+-----------------+
| AnthropicProvider (claude-instant-v1) | 33 | 0.00003 | 0.40 | 82.19 | 3 |
| AnthropicProvider (claude-instant-v1) | 152 | 0.00019 | 1.65 | 91.89 | 10 |
| AnthropicProvider (claude-instant-v1) | 248 | 0.00031 | 2.18 | 113.74 | 9 |
| AnthropicProvider (claude-instant-v1) | 209 | 0.00021 | 1.86 | 112.11 | 10 |
| AnthropicProvider (claude-instant-v1) | 59 | 0.00006 | 0.87 | 68.18 | 10 |
| AnthropicProvider (claude-instant-v1) | 140 | 0.00018 | 1.46 | 96.10 | 10 |
| AnthropicProvider (claude-instant-v1) | 245 | 0.00031 | 2.45 | 100.16 | 9 |
| AnthropicProvider (claude-instant-v1) | 250 | 0.00031 | 2.29 | 109.35 | 9 |
| AnthropicProvider (claude-instant-v1) | 248 | 0.00031 | 2.17 | 114.50 | 9 |
| AnthropicProvider (claude-instant-v1) | 323 | 0.00034 | 1.95 | 165.57 | 8 |
| AnthropicProvider (claude-instant-v1) | 172 | 0.00014 | 0.97 | 177.63 | 10 |
| AnthropicProvider (claude-instant-v1) | Total Tokens: 2079 | Total Cost: 0.00240 | Median Latency: 1.86 | Aggregrated speed: 113.98 | Total Score: 97 |
| OpenAIProvider (gpt-3.5-turbo) | 37 | 0.00007 | 1.20 | 30.86 | 7 |
| OpenAIProvider (gpt-3.5-turbo) | 93 | 0.00019 | 2.89 | 32.19 | 1 |
| OpenAIProvider (gpt-3.5-turbo) | 451 | 0.00090 | 18.10 | 24.91 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 204 | 0.00041 | 5.60 | 36.45 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 366 | 0.00073 | 16.51 | 22.17 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 109 | 0.00022 | 3.69 | 29.51 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 316 | 0.00063 | 11.96 | 26.43 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 294 | 0.00059 | 10.47 | 28.09 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 275 | 0.00055 | 10.02 | 27.45 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 501 | 0.00100 | 16.28 | 30.77 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | 180 | 0.00036 | 3.23 | 55.79 | 10 |
| OpenAIProvider (gpt-3.5-turbo) | Total Tokens: 2826 | Total Cost: 0.00565 | Median Latency: 10.02 | Aggregrated speed: 28.28 | Total Score: 98 |
| AI21Provider (j2-jumbo-instruct) | 27 | 0.00040 | 0.95 | 28.31 | 3 |
| AI21Provider (j2-jumbo-instruct) | 114 | 0.00171 | 3.10 | 36.81 | 1 |
| AI21Provider (j2-jumbo-instruct) | 195 | 0.00293 | 5.62 | 34.73 | 10 |
| AI21Provider (j2-jumbo-instruct) | 117 | 0.00176 | 2.08 | 56.12 | 10 |
| AI21Provider (j2-jumbo-instruct) | 216 | 0.00324 | 6.12 | 35.27 | 7 |
| AI21Provider (j2-jumbo-instruct) | 67 | 0.00101 | 2.01 | 33.39 | 10 |
| AI21Provider (j2-jumbo-instruct) | 229 | 0.00344 | 6.14 | 37.27 | 10 |
| AI21Provider (j2-jumbo-instruct) | 225 | 0.00337 | 6.21 | 36.26 | 5 |
| AI21Provider (j2-jumbo-instruct) | 218 | 0.00327 | 5.90 | 36.95 | 1 |
| AI21Provider (j2-jumbo-instruct) | 281 | 0.00421 | 6.25 | 44.97 | 1 |
| AI21Provider (j2-jumbo-instruct) | 149 | 0.00224 | 1.56 | 95.81 | 10 |
| AI21Provider (j2-jumbo-instruct) | Total Tokens: 1838 | Total Cost: 0.02757 | Median Latency: 5.62 | Aggregrated speed: 40.01 | Total Score: 68 |
+---------------------------------------+--------------------+---------------------+-----------------------+---------------------------+-----------------+
To evaluate models on your own prompts, simply pass a list of questions. The evaluator will automatically evaluate the responses:
models.benchmark(prompts=["what is the capital of finland", "who won superbowl in the year justin bieber was born"], evaluator=gpt4)
Supported Models
To get a list of supported models, call list(). Models will be shown in the order of least expensive to most expensive.
>>> model=llms.init()
>>> model.list()
[{'provider': 'AnthropicProvider', 'name': 'claude-instant-v1', 'cost': {'prompt': 0.43, 'completion': 1.45}}, {'provider': 'OpenAIProvider', 'name': 'gpt-3.5-turbo', 'cost': {'prompt': 2.0, 'completion': 2.0}}, {'provider': 'AI21Provider', 'name': 'j2-large', 'cost': {'prompt': 3.0, 'completion': 3.0}}, {'provider': 'AnthropicProvider', 'name': 'claude-v1', 'cost': {'prompt': 2.9, 'completion': 8.6}}, {'provider': 'AI21Provider', 'name': 'j2-grande', 'cost': {'prompt': 10.0, 'completion': 10.0}}, {'provider': 'AI21Provider', 'name': 'j2-grande-instruct', 'cost': {'prompt': 10.0, 'completion': 10.0}}, {'provider': 'AI21Provider', 'name': 'j2-jumbo', 'cost': {'prompt': 15.0, 'completion': 15.0}}, {'provider': 'AI21Provider', 'name': 'j2-jumbo-instruct', 'cost': {'prompt': 15.0, 'completion': 15.0}}, {'provider': 'OpenAIProvider', 'name': 'gpt-4', 'cost': {'prompt': 30.0, 'completion': 60.0}}]
>>> model.list("gpt') # lists only models with 'gpt' in name/provider name
Useful links:
OpenAI documentation
Anthropic documentation
AI21 documentation
License
This project is licensed under the MIT License.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pyllms-0.1.8.tar.gz
.
File metadata
- Download URL: pyllms-0.1.8.tar.gz
- Upload date:
- Size: 17.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4986349da0e8a89c60835cffaf1fb0f6ebbd5985cbb3c86731d3605fdf744764 |
|
MD5 | 2f7f28a7a71353b8a9608560c0c1b8ae |
|
BLAKE2b-256 | 7d2a292bf64c6b4481cf30df50392f3daae116bae163f4f4eaa9171a9f4e1284 |
File details
Details for the file pyllms-0.1.8-py3-none-any.whl
.
File metadata
- Download URL: pyllms-0.1.8-py3-none-any.whl
- Upload date:
- Size: 15.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c395e47619d4820dc0e98531b40f237a3b3ae4651766ec02dff95e24b357797f |
|
MD5 | 3714e432f99744f139b7b726b272ca7c |
|
BLAKE2b-256 | 9c3cd0658468e86afffefc84a3c785fc6f32cacf8907b7fb5195966a6598eaf9 |