Skip to main content

AAF (Agentic AI Framework)

Project description

AAF (Agentic AI Framework)

AAF is a versatile and extensible framework for building and managing agentic AI models. It provides a unified interface for various language model providers and implements advanced virtual models for complex, agent-like conversational scenarios.

Note that AAF is primarily a personal learning project focused on exploring agentic AI and LLM use, including complex multi-step interactions. While it can be useful for actual use cases like autonomous chat agents and multi-stage task completion, please exercise caution when considering it for anything even remotely important.

Features

  • Support for multiple LLM providers (OpenAI, Anthropic, Ollama, LiteLLM) to act as the foundation for AI agents
  • Advanced conversation management with Threads and Sessions for maintaining agent state
  • Virtual models for complex, multi-step agent behaviors:
    • TwoPhase: For agents that plan before acting
    • Multiphase: For agents that can break down and tackle complex tasks
    • Router: For meta-agents that can delegate to specialized sub-agents
  • Tool integration for function calling capabilities
  • Cost and token usage tracking

Installation

pip install aaf

Quick Start

from aaf.threads import Session

thread = Session().create_thread("gpt-4o", system="You are a helpful assistant.")
thread.add_message("user", "What is the capital of France?")

async with thread.run() as stream:
    async for chunk in stream.text_chunks():
        print(chunk.content, end="", flush=True)
    print()

print(thread.cost_and_usage().pretty())

Usage

LLM Providers

AAF supports multiple LLM providers. To use a specific provider, specify the model name when creating a thread:

thread = session.create_thread("gpt-4o")  # OpenAI
thread = session.create_thread("claude-3-5-sonnet-20240620")  # Anthropic
thread = session.create_thread("llama3.1:8b")  # Ollama

Virtual Models

AAF implements several virtual models for advanced use cases:

  • TwoPhase: Generates a prompt and then uses it to create a response
  • Multiphase: Multi-step process for complex questions, including drafting, feedback, and refinement
  • Router: Selects the appropriate model based on the user's request

Using a virtual model is same as with standard models:

from aaf.virtual_models.two_phase import TwoPhaseModel
from aaf.threads import Session

thread = Session().create_thread(model="two-phase", runner=TwoPhaseModel())
thread.add_message("user", "What is the capital of France?")

async with thread.run() as stream:
    async for chunk in stream.text_chunks():
        print(chunk.content, end="", flush=True)
    print()

print(thread.cost_and_usage().pretty())

Project Structure

  • aaf/: Main package directory
    • llms/: LLM provider implementations
    • virtual_models/: Virtual model implementations
    • tools/: Tool definitions
    • threads.py: Thread and Session management
    • logging.py: Custom logging implementation
    • utils.py: Utility functions

License

This project is licensed under the MIT License. See the LICENSE file for details.

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

aaf-0.3.10.tar.gz (106.3 kB view details)

Uploaded Source

Built Distribution

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

aaf-0.3.10-py3-none-any.whl (39.8 kB view details)

Uploaded Python 3

File details

Details for the file aaf-0.3.10.tar.gz.

File metadata

  • Download URL: aaf-0.3.10.tar.gz
  • Upload date:
  • Size: 106.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for aaf-0.3.10.tar.gz
Algorithm Hash digest
SHA256 06c6c12adbbde9454f3ac0a0129b55a8de4f97ee4c0ab221b2f40316a4f15d9a
MD5 8315cf5d12986bbe14df187b927ca2ad
BLAKE2b-256 7f31b03da483a7eadc4dde88b90142cf7171160c42c8f57c50d1a722892a84ee

See more details on using hashes here.

File details

Details for the file aaf-0.3.10-py3-none-any.whl.

File metadata

  • Download URL: aaf-0.3.10-py3-none-any.whl
  • Upload date:
  • Size: 39.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for aaf-0.3.10-py3-none-any.whl
Algorithm Hash digest
SHA256 f13df070b21f12a25486b4227ae1f6a6f21b8bb57d5c39d37259743a73890fdf
MD5 03116b5c4192f47c0e411c8ae1c247dc
BLAKE2b-256 f05d31c051e1313db343cc516e45dada9d8adf734ba9688ede31264a5f0f2461

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