Skip to main content

Adapters as API gateways to Different LLM Models

Project description

Adapters Package Documentation

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

Pre-commit hooks help maintain code quality and standards. Install them with the following command:

poetry run pre-commit install

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

Ensure Python 3.11 is used:

poetry run pytest

Quickstart

from adapters import AdapterFactory, Prompt
from adapters.types import Conversation, ConversationRole, Turn

adapter = AdapterFactory.get_adapter_by_path("openai/openai/gpt-4o-mini")

conversation = Conversation(
    [Turn(role=ConversationRole.user, content="Hi")]
)

adapter.execute_sync(conversation)

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 SUPPORTED_MODELS array if the provider is already supported.

  2. New Providers:

    • If the provider follows the OpenAI format, model integration is straightforward. See the "Together" 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 --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 achieve maximing throuput and performance of your applications we also offer way to configuare HTTP networking paramters:

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

In order to override all base urls to do stress testing or for any other reason you can specify in your .env

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

This will make sure all LLM API calls are resolved to this new url

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

martian_adapters-6.11.0.tar.gz (36.7 kB view details)

Uploaded Source

Built Distribution

martian_adapters-6.11.0-py3-none-any.whl (53.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: martian_adapters-6.11.0.tar.gz
  • Upload date:
  • Size: 36.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.5 Linux/5.15.0-1057-aws

File hashes

Hashes for martian_adapters-6.11.0.tar.gz
Algorithm Hash digest
SHA256 0f5b5dcb8da85a80ef489fad1eff25737df3449526212fc9327da314baeb7a45
MD5 a67123a23a758efb273bad674484aee0
BLAKE2b-256 768a131b38aa71bc54cbb2fe6a1fb09e92ad02eb8e30e69879c55bfcab5e96ff

See more details on using hashes here.

File details

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

File metadata

  • Download URL: martian_adapters-6.11.0-py3-none-any.whl
  • Upload date:
  • Size: 53.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.5 Linux/5.15.0-1057-aws

File hashes

Hashes for martian_adapters-6.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 eb36a2531ab4189fe97161c35100814b91c936375587bbd5dbed7d757460260a
MD5 7987341f9d41b43ad1daf9a60d6ba08e
BLAKE2b-256 35db2a8cdcf72b9fdf0449c763908ba4fc728293d1f32a099902712c71cf4c95

See more details on using hashes here.

Supported by

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