No project description provided
Project description
Lamoom
Introduction
Lamoom is a dynamic, all-in-one library designed for managing and optimizing prompts and making tests based on the ideal answer for large language models (LLMs) in production and R&D. It facilitates dynamic data integration, latency and cost metrics visibility, and efficient load distribution across multiple AI models.
Features
- CI/CD testing: Generates tests based on the context and ideal answer (usually written by the human).
- Dynamic Prompt Development: Avoid budget exceptions with dynamic data.
- Multi-Model Support: Seamlessly integrate with various LLMs like OpenAI, Anthropic, and more.
- Real-Time Insights: Monitor interactions, request/response metrics in production.
- Prompt Testing and Evolution: Quickly test and iterate on prompts using historical data.
Installation
Install Flow Prompt using pip:
pip install lamoom
Obtain an API token from Lamoom and add it as an env variable: LAMOOM_API_TOKEN ;
Authentication
Add Keys depending on models you're using:
# Add LAMOOM_API_TOKEN as an environment variable:
os.setenv('LAMOOM_API_TOKEN', 'your_token_here')
# add OPENAI_API_KEY
os.setenv('OPENAI_API_KEY', 'your_key_here')
# add Azure Keys
os.setenv('AZURE_KEYS', '{"name_realm":{"url": "https://baseurl.azure.com/","key": "secret"}}')
# or creating flow_prompt obj
Lamoom(azure_keys={"realm_name":{"url": "https://baseurl.azure.com/", "key": "your_secret"}})
Model Agnostic:
Mix models easily, and districute the load across models. The system will automatically distribute your load based on the weights. We support:
- Claude
- Gemini
- OpenAI (w/ Azure OpenAI models)
- Nebius with (Llama, DeepSeek, Mistral, Mixtral, dolphin, Qwen and others)
Model string format is the following for Claude, Gemini, OpenAI, Nebius:
"{model_provider}/{model_name}"
For Azure models format is the following:
"azure/{realm}/{model_name}"
response_llm = client.call(agent.id, context, model = "openai/gpt-4o")
response_llm = client.call(agent.id, context, model = "azure/useast/gpt-4o")
Lamoom Keys
Obtain an API token from Flow Prompt and add it:
# As an environment variable:
os.setenv('LAMOOM_API_TOKEN', 'your_token_here')
# Via code:
Lamoom(api_token='your_api_token')
Usage Examples:
from lamoom import Lamoom, Prompt
# Initialize and configure Lamoom
client = Lamoom(openai_key='your_api_key', openai_org='your_org')
# Create a prompt
prompt = Prompt('greet_user')
prompt.add("You're {name}. Say Hello and ask what's their name.", role="system")
# Call AI model with Lamoom
context = {"name": "John Doe"}
# test_data - optional parameter used for generating tests
response = client.call(prompt.id, context, "openai/gpt-4o", test_data={
'ideal_answer': "Hello, I'm John Doe. What's your name?",
'behavior_name': "gemini"
}
)
print(response.content)
-
To review your created tests and score please go to https://cloud.lamoom.com/tests. You can update there Prompt and rerun tests for a published version, or saved version. If you will update and publish version online - library will automatically use the new updated version of the prompt. It's made for updating prompt without redeployment of the code, which is costly operation to do if it's required to update just prompt.
-
To review logs please proceed to https://cloud.lamoom.com/logs, there you can see metrics like latency, cost, tokens;
Best Security Practices
For production environments, it is recommended to store secrets securely and not directly in your codebase. Consider using a secret management service or encrypted environment variables.
Contributing
We welcome contributions! Please see our Contribution Guidelines for more information on how to get involved.
License
This project is licensed under the Apache2.0 License - see the LICENSE file for details.
Contact
For support or contributions, please contact us via GitHub Issues.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file lamoom-0.1.35.tar.gz.
File metadata
- Download URL: lamoom-0.1.35.tar.gz
- Upload date:
- Size: 72.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.5 CPython/3.11.11 Linux/6.8.0-1021-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9224c390fa8135fd703b1918192acfe8baa3b416fb47ded89611ad097616428b
|
|
| MD5 |
04db37e46362ae7694b0e0bdd6ab6710
|
|
| BLAKE2b-256 |
a30dd418162b5e71f48e3982366a8b1bab322cd58d662a318da26af6ce620774
|
File details
Details for the file lamoom-0.1.35-py3-none-any.whl.
File metadata
- Download URL: lamoom-0.1.35-py3-none-any.whl
- Upload date:
- Size: 33.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.5 CPython/3.11.11 Linux/6.8.0-1021-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
acd502d4e8793a23514cdae1e937be316d4ef595600c39f745cae5ef04524795
|
|
| MD5 |
283990080f21fdae52ae65fe05907227
|
|
| BLAKE2b-256 |
243494bc6cac7226579e887fedcf17efe81a7124c751f7435c033b379d501717
|