Skip to main content

Adapters as API gateways to Different LLM Models

Project description

LLM Adapters Package Documentation

List of currently supported models

Overview

The Adapters package facilitates communication between different language model APIs by providing a unified interface for interaction. This ensures ease of use and flexibility in integrating multiple models from various providers.

The package can be installed an used via pip:

pip install martian-adapters

Getting Started

Prerequisites

  • Python version: 3.11.10
  • Poetry

Installation

poetry install
poetry run pre-commit install

Setting Up Pre-commit

To run pre-commit manually:

poetry run pre-commit run --all-files

Semantic Versioning

For versioning we follow Semantic Versioning

Environment Configuration

The package requires certain environment variables to be set by the users:

  • Copy .env-example to .env and populate it with appropriate values.

Running Tests

poetry run pytest

Quickstart

from adapters import AdapterFactory

# First component in model path is Provider, then Vendor, and last model name itself
adapter = AdapterFactory.get_adapter_by_path("openai/openai/gpt-4o-mini")

adapter.execute_sync(
    [
        {role: "system", content: "You are a helpful assistant."},
        {
            role: "user",
            content: "Write a haiku about recursion in programming.",
        },
    ]
)

Adapter paths follows the format provider/vendor/model_name. Use AdapterFactory.get_supported_models() to retrieve all supported models. For a given model, model.get_path() returns the adapter path.

Contributing

Adding New Models

  1. Existing Providers: Add new models to the MODELS array if the provider is already supported.

  2. New Providers:

    • If the provider follows the OpenAI format, model integration is straightforward. See the "Fireworks" provider class as an example.
    • For providers with different schemas, see the "Anthropic" provider class for guidance.

Development Steps

  1. Add the Provider and Model: Update provider_adapters/__init__.py and test files accordingly.

  2. Write Tests: Add tests in the relevant directories. Use @pytest.mark.vcr for tests making network requests.

  3. Run Tests:

    poetry run pytest
    
  4. Check-in Cassette Files: Include any new cassette YAML files in your commit.

  5. Send a Pull Request: Ensure all tests pass before requesting a review.

Re-creating Cassette Files

Use the poetry run pytest --record-mode=rewrite option with pytest to update cassette files.

Additional Notes

Some models may only be accessible from specific locations (e.g., the U.S.). In such cases, running tests might require access to a U.S.-based server.

This documentation provides a streamlined approach to using and contributing to the Adapters package, emphasizing practical steps and clear examples.

Misclenous

HTTP Client configuration

To optimize throughput and performance, we provide options to configure HTTP networking parameters:

ADAPTERS_MAX_KEEPALIVE_CONNECTIONS_PER_PROCESS = 100
ADAPTERS_MAX_CONNECTIONS_PER_PROCESS = 1000
ADAPTERS_HTTP_CONNECT_TIMEOUT = 5
ADAPTERS_HTTP_TIMEOUT = 600

Base URL overriding

For stress testing or other purposes, you can override all base URLs by setting the following in your .env file:

_ADAPTERS_OVERRIDE_ALL_BASE_URLS_ = "https://new-base-url.com/api"

This setting ensures that all LLM API calls will route to the specified new base URL.

Project details


Release history Release notifications | RSS feed

This version

7.4.0

Download files

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

Source Distribution

martian_adapters-7.4.0.tar.gz (37.9 kB view details)

Uploaded Source

Built Distribution

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

martian_adapters-7.4.0-py3-none-any.whl (55.5 kB view details)

Uploaded Python 3

File details

Details for the file martian_adapters-7.4.0.tar.gz.

File metadata

  • Download URL: martian_adapters-7.4.0.tar.gz
  • Upload date:
  • Size: 37.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.0 CPython/3.11.11 Linux/6.8.0-1017-azure

File hashes

Hashes for martian_adapters-7.4.0.tar.gz
Algorithm Hash digest
SHA256 f7a5a5de9d4ae6e332a415d01ddec4a9def4e06ddb1e61e2c6f6162c8f172af3
MD5 e09327fe47fcd7f2b040325ca84ff9c2
BLAKE2b-256 531f8983a22e57606b4d324a7ef7a1bce520e185c4383383c26b45f180cdacf4

See more details on using hashes here.

File details

Details for the file martian_adapters-7.4.0-py3-none-any.whl.

File metadata

  • Download URL: martian_adapters-7.4.0-py3-none-any.whl
  • Upload date:
  • Size: 55.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.0 CPython/3.11.11 Linux/6.8.0-1017-azure

File hashes

Hashes for martian_adapters-7.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d639c97f7fa920799b41c4203611bbfa062a47aa17d0747e31e595777eae17a8
MD5 907c237585e4fe2c01188c0d42094cd1
BLAKE2b-256 cab862412725c79875c47ab2602877d6a480865f591332b56f16cb38e69d7ec9

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