Skip to main content

A very simple Python framework for building AI Agents

Project description

agente

A very simple Python framework for building AI Agents.

Overview

Agente is a Python framework that allows you to create AI agents just like you create Python classes and methods.

Each method can be converted to into a function calling tool using a simple decorator. This allow you to think the tools as regular class methods within the instante namespace of the agent.

Multi-agent orchestration is supported in an hierarchical way, starting from a main agent that can delegate tasks to specialized agents.

Features

  • Simple agent creation and easily customizable
  • Support for streaming responses
  • Multi-agent orchestration (hierarchical)
  • Autonomous agent tool that allows an agent to create its own tools (experimental)

Installation

Install the package:

pip install agente

For running the examples with Gradio UI:

pip install agente[examples]

Note: The frameworks works on top of litellm, so you need to set your provider API key in the environment variables.

Quick Start

Here's a simple example of creating a conversational agent:

import os 
os.environ["OPENAI_API_KEY"] = "your_api_key" #load your provider API key
from agente.core.base import BaseAgent


class SimpleAgent(BaseAgent):
    agent_name: str = "SimpleAgent"
    system_prompt: str = "You are a helpful AI assistant."
    silent: bool = True #while running the agent, it will not print execution logs
    completion_kwargs: dict = {
        "model": "gpt-4.1-mini",
        "stream": False,
        "temperature": 1.0,
        "max_tokens": 500,
    }

# Create agent instance
agent = SimpleAgent()

# Add a message
agent.add_message(role = "user", content =  "Tell me a joke about programming.")

# Run the agent and get responses
responses = await agent.run()

# by default the response have litellm format
print(responses[0].choices[0].message.content)

Using agente response format

# Add a message
agent.add_message(role = "user", content =  "Another one, please.")

# Now with agente response format
responses = await agent.run(output_format = "agente")

print(responses[0].content)

To access the conversation history

conversation_history = agent.conv_history

print(conversation_history.model_dump())

To access the logs

# Get the logs
logs = agent.log_calls
print(logs)

logs = agent.log_completions
print(logs)

Advanced Usage

Adding Tools

Agents can be enhanced with tools using the @function_tool decorator. The decorator will automatically generate a tool schema for the function based on the docstring and the Annotated type hints.

import os
os.environ["OPENAI_API_KEY"] = "your_api_key" #load your provider API key
from agente.core.base import BaseAgent
from agente.core.decorators import function_tool
from typing import Annotated

class AddAgent(BaseAgent):
    agent_name: str = "add_agent"

    @function_tool
    async def calculate_sum(self, a: Annotated[int,"The first number"], b: Annotated[int,"The second number"]) -> int:
        """Calculate the sum of two numbers."""
        return a + b

agent = AddAgent()
agent.completion_kwargs['model'] = 'gpt-4.1-mini'
agent.add_message(role = "user", content = "How much is 10 + 10?")
responses = await agent.run()
print(responses[-1].choices[0].message.content)

Creating Multi-Agent Systems

You can create complex multi-agent systems where agents can call other agents using the @agent_tool decorator.

For now the framework was designed to work with a hierarchical structure, where a main agent can call other specialized agents that can call other agents and so on. These sub-agents must be TaskAgents that inherit from BaseTaskAgent and must have a task_completed method that returns the result of the task.

import os
os.environ["OPENAI_API_KEY"] = "your_api_key" #load your provider API key
from agente.core.base import BaseAgent,BaseTaskAgent
from agente.core.decorators import function_tool,agent_tool
import random

class JokeTeller(BaseTaskAgent):
    agent_name: str = "JokeTeller"
    system_prompt:str = "Your task is to write a funny joke."
    completion_kwargs: dict = {
        "model": "gpt-4o-mini",
        "stream": False,
    }

    @function_tool
    def task_completed(self,joke:Annotated[str,"The joke to return"]):
        """To be used as a tool to complete the task."""
        return joke



class MainAgent(BaseAgent):
    agent_name: str = "main_agent"
    
    @function_tool(next_tool = "get_joke") # To make sure the agent calls the get_joke tool we add the next_tool argument to force it.
    def random_topic(self):
        """Tool to get a random topic.
        """
        topics = ["programming","science","animals","food","sports"]
        topic = random.choice(topics)

        return topic


    @agent_tool()
    def get_joke(self,joke_topic:Annotated[str,"The topic of the joke"]):
        """Tool to get a joke."""
        joke_agent = JokeTeller()
        joke_agent.add_message(role = "user", content = "Tell me a joke about " + joke_topic)
        return joke_agent
    
example_agent = MainAgent()
example_agent.add_message(role = "user", content = "Call the tool random_topic to get a random topic and then tell  me a joke about it")
responses = await example_agent.run()
print(responses[-1].choices[0].message.content)

Examples

For more examples, check out the examples directory:

  1. Simple Conversational Agent
  2. Data Analysis Agent
  3. Scientific Paper Research Agent
  4. Autonomous Agent with Dynamic Tools

License

Apache License 2.0

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

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

agente-0.3.3.tar.gz (64.2 kB view details)

Uploaded Source

Built Distribution

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

agente-0.3.3-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

File details

Details for the file agente-0.3.3.tar.gz.

File metadata

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

File hashes

Hashes for agente-0.3.3.tar.gz
Algorithm Hash digest
SHA256 2f3ddb5d9b4aa39befbaceeb7ab0ca06d3d539cf7e0e390f6a666676d5e92032
MD5 4b504c01fb2cc2ac290fead65826bb53
BLAKE2b-256 cecec5ecd0b8e3d77b11e7f4fb49160552711afdc8707d885c04e12190449fa7

See more details on using hashes here.

File details

Details for the file agente-0.3.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for agente-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 ddb325ea3e674f51a9d604a6a1e0384556a5e3171ffa224cd76fb514813d3b6c
MD5 80a5c93eeb01a266ded98532a81a6aa9
BLAKE2b-256 063e5cc70fe65db1689fcc67e93cb5f066c75d461cbf07f9dae1ea19b8dc663a

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