Skip to main content

Official Python bindings for AutoAgents Llama.cpp backend (CUDA)

Project description

Python Bindings

Repository: https://github.com/liquidos-ai/AutoAgents

The Python bindings exist to make it easy to explore new ideas quickly without giving up the Rust core that powers AutoAgents.

Python stays focused on agent definition, orchestration, experimentation, and callback glue. Rust owns the runtime, scheduling, streaming, concurrency, and core execution model.

Stable vs Experimental

The production path is:

  • Rust-owned executors (BasicAgent, ReActAgent)
  • Rust-owned memory (SlidingWindowMemory and future Rust-backed providers)
  • Python tools
  • Python hooks

Explicit extension paths live under autoagents.experimental:

  • ExperimentalAgentBuilder
  • CustomExecutor
  • Python-backed memory adapters

Those extension APIs are experimental in the Python bindings specifically because they rely on Python-native execution or Python-native memory behavior. That boundary exists to keep production runtime ownership in Rust rather than re-centering the architecture on Python callbacks.

The same categories of capability are production-grade in the Rust-native implementation. What is experimental here is the Python extension path, not the underlying AutoAgents model when implemented natively in Rust.

Why This Matters

  • Rapid iteration in Python is useful when you are prototyping agent flows, hooks, memory adapters, and pipeline layers.
  • Performance-sensitive and safety-critical behavior still comes from the Rust implementation underneath.
  • Moving a successful prototype to production Rust is easier because the Python layer is orchestration-oriented rather than a separate runtime.

Practical Outcome

You can prototype in Python with:

  • the same LLMProvider model
  • the same pipeline composition model
  • the same agent builder structure
  • the same runtime concepts used by the Rust crates

When you decide to harden something for production, the path to Rust is much smaller because the architecture is already aligned.

Installation from PyPI

Install the base package:

pip install autoagents-py

Install with a local backend or guardrails using extras:

pip install "autoagents-py[llamacpp]"           # llama.cpp CPU
pip install "autoagents-py[llamacpp-cuda]"      # llama.cpp CUDA
pip install "autoagents-py[llamacpp-metal]"     # llama.cpp Metal (macOS)
pip install "autoagents-py[llamacpp-vulkan]"    # llama.cpp Vulkan
pip install "autoagents-py[mistralrs]"          # mistral-rs CPU
pip install "autoagents-py[mistralrs-cuda]"     # mistral-rs CUDA
pip install "autoagents-py[mistralrs-metal]"    # mistral-rs Metal (macOS)
pip install "autoagents-py[guardrails]"         # Guardrails
pip install "autoagents-py[llamacpp-cuda,guardrails]"  # Multiple extras

Local Development

From the repository root:

uv venv --python=3.12
source .venv/bin/activate
uv pip install -U pip maturin pytest pytest-asyncio pytest-cov

make python-bindings-build

For local backend work:

make python-bindings-build-llamacpp-only
make python-bindings-build-mistralrs-only

Backend-specific distributables now live in dedicated package directories under bindings/python/ such as autoagents-llamacpp-cuda and autoagents-mistralrs-metal, so local builds and release builds use the same checked-in package metadata.

For full setup and usage details, see:

  • README.md
  • docs/src/getting-started/python-bindings.md

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

autoagents_llamacpp_cuda-0.3.7.tar.gz (362.9 kB view details)

Uploaded Source

File details

Details for the file autoagents_llamacpp_cuda-0.3.7.tar.gz.

File metadata

  • Download URL: autoagents_llamacpp_cuda-0.3.7.tar.gz
  • Upload date:
  • Size: 362.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for autoagents_llamacpp_cuda-0.3.7.tar.gz
Algorithm Hash digest
SHA256 30c4bc1125410a851fb88852ef50970b44f324ae45ebcb13a51efb1e1ef1efae
MD5 de8dc141a65f3932956ade66c6b567c6
BLAKE2b-256 7d32ef8c439e661ec113f499ebd0f212fd9f8eb3ac29ba7b9c9cb10f9ceb2603

See more details on using hashes here.

Provenance

The following attestation bundles were made for autoagents_llamacpp_cuda-0.3.7.tar.gz:

Publisher: python-bindings.yml on liquidos-ai/AutoAgents

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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