No project description provided
Project description
gpt_agents.py
Unique: This is a single-file, multi-agent framework for LLMs—everything is implemented in one core file with no dependencies for maximum clarity and hackability. See the main implementation here:
gpt_agents.py
A minimal, modular Python framework for building and running multi-agent LLM workflows with tool use, validation, and orchestration.
Project Overview
gpt_agents.py provides abstractions for:
- Agent: An LLM-powered entity with a goal, backstory, tasks, and tools.
- Task: A unit of work for an agent, with a description and expected output.
- Tool: A callable function the agent can use, with a name, description, and argument schema.
- Organization: A group of agents working together, passing results between them.
The framework manages LLM prompting, tool execution, validation, and robust control flow to maximize correct answers. See tests/test_integration.py for advanced usage and testing patterns.
Requirements
- Python 3.11+ (standard library only)
- OpenAI API Key in
api_key.jsonat the project root:{ "openai": "sk-..." }
Installation
git clone <repository-url>
cd gpt_agents.py
No pip or poetry installation required for runtime. This project has zero runtime dependencies and uses only the Python standard library.
For development (linting, formatting, type checking, testing), install dev dependencies:
pip install black isort mypy flake8
Or, if using Poetry:
poetry install --with dev
Usage
Running the example
Runnable demos are located in the examples/ directory. To run the basic usage example:
python examples/basic_usage.py # Normal mode
python examples/basic_usage.py --debug # Step-through debug mode for agent reasoning
python examples/basic_usage.py --trace # Log all LLM prompts and responses to file.txt
python examples/basic_usage.py --trace --trace-filename mylog.txt # Log LLM traces to custom file
python examples/basic_usage.py --debug --trace # Combine step-through and trace logging
- The
--debugflag enables step-through mode, which pauses execution at each agent reasoning step for inspection. - The
--traceflag logs all LLM prompts and responses to a file (default:file.txt). - The
--trace-filenameflag lets you specify a custom trace log file (used with--trace). - Both flags can be combined.
Customizing Prompts at Runtime
You can override any prompt template used by the agent at runtime without modifying the source code. This is useful for adapting the agent's behavior, tone, or instructions for different use cases.
Use the set_prompt_value function from gpt_agents.py:
from gpt_agents_py.gpt_agents import set_prompt_value
# Example: Change the system instruction prompt
set_prompt_value('instruction_prompt', 'You are a helpful assistant. Always explain your reasoning.')
See the Prompts NamedTuple in gpt_agents.py for all available prompt keys you can override.
- By default, both are off and the trace filename is
file.txt.
Running Tests
Integration tests are provided using Python's unittest framework:
python -m unittest discover tests
Development checks (run from project root):
black --check gpt_agents_py examples tests
isort --check gpt_agents_py examples tests
flake8 gpt_agents_py examples tests
mypy gpt_agents_py examples tests
Continuous Integration
This project uses GitHub Actions to automatically lint, type-check, and run tests on pushes and pull requests to main, across Python 3.11 and 3.12.
Example: Defining Agents, Tools, and Running an Organization
from gpt_agents_py.gpt_agents import Agent, Organization, Task, Tool, organization_executor
def population_tool(args):
country = args.get("country")
return {"france": 67000000, "germany": 83000000}.get(country.lower(), "unknown")
def calculator_tool(args):
op = args["operation"]
a, b = float(args["a"]), float(args["b"])
if op == "add": return str(a + b)
if op == "subtract": return str(a - b)
if op == "multiply": return str(a * b)
if op == "divide": return str(a / b)
return "unknown"
agent = Agent(
role="Researcher",
goal="Find population and add 1000",
backstory="Expert in demographics.",
tasks=[Task(name="GetPop", description="Get France's population", expected_output="67000000")],
tools=[
Tool(name="PopulationTool", description="Returns country population", args_schema="country:str", func=population_tool),
Tool(name="Calculator", description="Performs arithmetic", args_schema="operation:str, a:str, b:str", func=calculator_tool)
]
)
org = Organization(agents=[agent])
result = organization_executor(org)
print(result)
See gpt_agents_py/examples.py for a more complete demo.
Testing
Integration tests are provided in the tests/ directory. LLM calls are mocked for deterministic testing, and real tool logic is exercised.
To run all tests:
python -m unittest discover tests
See tests/test_integration.py for an example of integration testing with mocked LLM calls.
License
MIT
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gpt_agents_py-0.1.3.tar.gz.
File metadata
- Download URL: gpt_agents_py-0.1.3.tar.gz
- Upload date:
- Size: 15.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.3 CPython/3.11.2 Linux/6.1.0-37-amd64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4e6502f01c1fd0719edbcbb17813458e94e25c61ffdce20533c94366e6719762
|
|
| MD5 |
b32e7cf24010412b2772cc001c16a8ef
|
|
| BLAKE2b-256 |
c67bea9fe35297a3abf34f0fcde264c9e167f2645ffbcb9c65922c5c805fde2c
|
File details
Details for the file gpt_agents_py-0.1.3-py3-none-any.whl.
File metadata
- Download URL: gpt_agents_py-0.1.3-py3-none-any.whl
- Upload date:
- Size: 14.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.3 CPython/3.11.2 Linux/6.1.0-37-amd64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5a74f530d48ee74a17ccc90e84ded8e373a6e5dc127f0e4166920ca3efb01a6a
|
|
| MD5 |
00c295844020ae5597133fae265a4f34
|
|
| BLAKE2b-256 |
7a1d9d4da0d795a74bfbb88c7a124b7fe7974f6e1c473e511cbfbfea83a437a0
|