Skip to main content

A lightweight Python library that provides easy access to popular LLM model names and allows you to define which models your application supports.

Project description

LLM Relic

A lightweight Python library that provides easy access to popular LLM model names and allows you to define which models your application supports.

Why LLM Relic?

  • No more hardcoded model names: Access standardized model names from major providers
  • Easy support definition: Fluent interface to define which models your app supports
  • Validation: Built-in validation to ensure only supported models are used
  • Zero dependencies: Lightweight library with no external dependencies
  • Type hints: Full type hint support for better IDE experience

Installation

pip install llmrelic

Quick Start

Access Model Names

from llmrelic import OpenAI, Anthropic, Google

# Access model names directly
print(OpenAI.gpt_4)  # "gpt-4"
print(Anthropic.claude_3_opus)  # "claude-3-opus-20240229"
print(Google.gemini_pro)  # "gemini-pro"

# List all models from a provider
print(OpenAI.list_models())

Define Supported Models

from llmrelic import SupportedModels

# Define which models your app supports
supported = (SupportedModels.create()
             .openai()  # All OpenAI models
             .anthropic(["claude-3-opus-20240229", "claude-3-sonnet-20240229"])  # Specific models
             .google()  # All Google models
             .custom(["my-custom-model"])  # Your custom models
             .build())

# Validate model support
if supported.is_supported("gpt-4"):
    print("GPT-4 is supported!")

# Get all supported models
print(supported.get_supported_models())

Use in Your Application

from llmrelic import OpenAI, SupportedModels

class MyLLMApp:
    def __init__(self):
        # Define what models your app supports
        self.supported_models = (SupportedModels.create()
                                .openai(["gpt-4", "gpt-3.5-turbo"])
                                .anthropic()
                                .build())
    
    def chat(self, model_name: str, message: str):
        if not self.supported_models.is_supported(model_name):
            available = ", ".join(self.supported_models.get_supported_models())
            raise ValueError(f"Model {model_name} not supported. Available: {available}")
        
        # Your chat logic here
        return f"Response from {model_name}"

# Usage
app = MyLLMApp()
app.chat(OpenAI.gpt_4, "Hello!")  # Works
app.chat("gpt-4", "Hello!")  # Works
# app.chat("unsupported-model", "Hello!")  # Raises ValueError

Supported Providers

  • OpenAI: GPT-4, GPT-3.5-turbo, and more
  • Anthropic: Claude 3 Opus, Sonnet, Haiku, and more
  • Google: Gemini Pro, Bard, PaLM-2, and more
  • Cohere: Command, Command-Light, Command-R, and more
  • Mistral: Mistral 7B, Mixtral 8x7B, and more
  • Meta: Llama 2, Code Llama, and more
  • Hugging Face: Popular open-source models

API Reference

Model Providers

Each provider exposes models as attributes:

from llmrelic import OpenAI, Anthropic, Google, Cohere, Mistral, Meta, Huggingface

# Access models
OpenAI.gpt_4  # "gpt-4"
Anthropic.claude_3_opus  # "claude-3-opus-20240229"
Google.gemini_pro  # "gemini-pro"

# List all models
OpenAI.list_models()

# Check if model exists
"gpt-4" in OpenAI  # True

SupportedModels (Fluent Interface)

from llmrelic import SupportedModels

supported = (SupportedModels.create()
             .openai()  # All OpenAI models
             .openai(["gpt-4", "gpt-3.5-turbo"])  # Specific OpenAI models
             .anthropic()  # All Anthropic models
             .google(["gemini-pro"])  # Specific Google models
             .custom(["my-model"])  # Custom models
             .build())

# Check support
supported.is_supported("gpt-4")  # True

# Get models
supported.get_models()  # List of all supported models

ModelRegistry (Direct Interface)

from llmrelic import ModelRegistry

registry = ModelRegistry()
registry.add_provider("openai")
registry.add_models(["custom-model-1", "custom-model-2"])
registry.add_model("another-model")

# Check support
registry.is_supported("gpt-4")  # True
"gpt-4" in registry  # True

# Get models
registry.get_supported_models()
registry.get_supported_by_provider()

# Iterate
for model in registry:
    print(model)

Utility Functions

from llmrelic import get_all_models, find_model

# Get all available models by provider
all_models = get_all_models()

# Find which provider a model belongs to
provider = find_model("gpt-4")  # "openai"

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Add your changes
  4. Run tests: pytest
  5. Submit a pull request

License

MIT License

Changelog

0.1.0

  • Initial release
  • Basic model name access
  • Fluent interface for defining supported models
  • Model validation and registry functionality

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

llmrelic-0.1.1.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

llmrelic-0.1.1-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

Details for the file llmrelic-0.1.1.tar.gz.

File metadata

  • Download URL: llmrelic-0.1.1.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for llmrelic-0.1.1.tar.gz
Algorithm Hash digest
SHA256 8c98b3b0ae1797515f38f79b36f87f1be9058b5d7f2d22624c6fcd942a040b0c
MD5 b2b741575b5d177eeec9afa015e2145e
BLAKE2b-256 4cae79d0ceb2f33fdb1db3707e5ece0c3fc09545c3d541bd4ac373386c0c67ae

See more details on using hashes here.

File details

Details for the file llmrelic-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: llmrelic-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 6.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for llmrelic-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 39aa9488b7d7709d020a6f8c8ec204d295ab45bbfd5bdcb795ea3cf9677acc0a
MD5 f1b5b99d29d61260be9245164cb4cac8
BLAKE2b-256 9593ea7e573829648b3d9050c6bfdbe7d715b83e9b04b45a6ea3d3d67cfc1e97

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page