AI Agent Iterative Manager - Supervisor/Worker agent pattern for task completion
Project description
AIAIM - AI Agent Iterative Manager
一个基于 Supervisor/Worker 模式的 AI Agent 迭代任务管理器。
概述
AIAIM 实现了一个简单但强大的模式:
- 创建会话 - 启动时创建共享的 chat session,全程使用同一个 chat_id
- Worker Agent 执行用户指定的任务(实时输出到屏幕)
- Supervisor Agent 检查任务是否完成,并列出未完成的项目
- 如果任务未完成,Worker 继续处理未完成项目
- 循环直到任务完成或达到最大迭代次数
┌─────────────────────────────────────────────────────────┐
│ TaskRunner │
│ │
│ ┌──────────┐ 执行任务 ┌──────────────────┐ │
│ │ Worker │ ───────────────→ │ 实际工作环境 │ │
│ │ Agent │ ←─────────────── │ (cursor-cli等) │ │
│ └──────────┘ 执行结果 └──────────────────┘ │
│ │ │
│ │ 完成后 │
│ ▼ │
│ ┌──────────┐ 检查状态 ┌──────────────────┐ │
│ │Supervisor│ ───────────────→ │ 实际工作环境 │ │
│ │ Agent │ ←─────────────── │ (cursor-cli等) │ │
│ └──────────┘ 完成/未完成清单 └──────────────────┘ │
│ │ │
│ │ 如果未完成 │
│ └──────────→ 返回 Worker 继续处理 │
│ │
└─────────────────────────────────────────────────────────┘
安装
pip install aiaim
或从源码安装:
git clone https://github.com/aiaim/aiaim.git
cd aiaim
pip install -e .
前置条件
- Python 3.9+
cursor-cli命令行工具(或其他配置的 agent CLI)
快速开始
命令行使用
# 运行一个任务
aiaim run "创建一个计算斐波那契数列的 Python 函数"
# 仅检查任务状态(不执行)
aiaim check "创建一个计算斐波那契数列的 Python 函数"
# 运行单步迭代
aiaim step "创建一个 Python 函数" -p "添加错误处理" -p "添加文档字符串"
# 带选项运行
aiaim run "完成任务描述" \
--agent-type cursor-cli \
--model claude-4.5-opus-high-thinking \
--max-iterations 5 \
--delay 2.0 \
--output result.json
Python API 使用
from aiaim import TaskRunner, AgentType
# 创建任务运行器
runner = TaskRunner(
agent_type=AgentType.CURSOR_CLI,
model="claude-4.5-opus-high-thinking",
max_iterations=10,
)
# 运行任务
result = runner.run("创建一个计算斐波那契数列的 Python 函数")
# 检查结果
if result.completed:
print("任务完成!")
print(f"迭代次数: {result.iterations}")
print(f"总耗时: {result.total_time:.2f}秒")
else:
print("任务未完成")
print(f"错误: {result.error}")
自定义 Agent
from aiaim import AgentCLI, AgentResponse, SupervisorAgent, WorkerAgent
# 使用自定义配置创建 agent
class MyCustomCLI(AgentCLI):
def create_chat(self) -> str:
# 创建会话并返回 chat_id
...
def execute(self, prompt: str, on_output=None) -> AgentResponse:
# 自定义执行逻辑
# on_output 回调用于实时输出
...
# 使用自定义 agent
supervisor = SupervisorAgent(agent_cli=MyCustomCLI())
worker = WorkerAgent(agent_cli=MyCustomCLI())
runner = TaskRunner(
supervisor_agent=supervisor,
worker_agent=worker,
)
实时输出回调
def my_output_handler(line: str):
print(f"[AGENT] {line}", end="")
runner = TaskRunner(
on_agent_output=my_output_handler, # 实时输出回调
)
CLI 命令
aiaim run
运行完整的任务循环。
aiaim run [OPTIONS] TASK
Options:
-a, --agent-type [cursor-cli] Agent 类型
-m, --model TEXT 模型名称
-n, --max-iterations INTEGER 最大迭代次数
-d, --delay FLOAT 迭代间隔(秒)
-o, --output PATH 输出文件路径(JSON)
-q, --quiet 静默模式
aiaim check
仅检查任务状态,不执行任何操作。
aiaim check [OPTIONS] TASK
Options:
-a, --agent-type [cursor-cli] Agent 类型
-m, --model TEXT 模型名称
aiaim step
运行单步迭代(一次 Worker + Supervisor)。
aiaim step [OPTIONS] TASK
Options:
-a, --agent-type [cursor-cli] Agent 类型
-m, --model TEXT 模型名称
-p, --pending TEXT 待完成项目(可多次指定)
配置
默认值
- Agent 类型:
cursor-cli - 模型:
claude-4.5-opus-high-thinking - 最大迭代次数:
10 - 迭代间隔:
1.0秒
支持的 Agent 类型
| 类型 | 说明 |
|---|---|
cursor-cli |
Cursor CLI 命令行工具 |
API 参考
TaskRunner
主任务运行器,协调 Supervisor 和 Worker 的工作循环。
TaskRunner(
agent_type: AgentType = AgentType.CURSOR_CLI,
model: str = "claude-4.5-opus-high-thinking",
max_iterations: int = 10,
delay_between_iterations: float = 1.0,
supervisor_agent: Optional[SupervisorAgent] = None,
worker_agent: Optional[WorkerAgent] = None,
on_iteration_complete: Optional[Callable] = None,
on_status_update: Optional[Callable] = None,
)
SupervisorAgent
负责检查任务完成状态的 Agent。
SupervisorAgent(
agent_cli: Optional[AgentCLI] = None,
agent_type: AgentType = AgentType.CURSOR_CLI,
model: str = "claude-4.5-opus-high-thinking",
check_prompt_template: Optional[str] = None,
)
WorkerAgent
负责执行具体任务的 Agent。
WorkerAgent(
agent_cli: Optional[AgentCLI] = None,
agent_type: AgentType = AgentType.CURSOR_CLI,
model: str = "claude-4.5-opus-high-thinking",
execute_prompt_template: Optional[str] = None,
)
AgentCLI
Agent CLI 的抽象基类。
AgentCLI.create(
agent_type: AgentType = AgentType.CURSOR_CLI,
model: str = "claude-4.5-opus-high-thinking",
chat_id: Optional[str] = None, # 可选的 chat ID
**kwargs,
) -> AgentCLI
主要方法:
create_chat() -> str: 创建会话并返回 chat_idexecute(prompt, on_output=None) -> AgentResponse: 执行 prompt,支持实时输出回调
对于 CursorCLI:
create_chat()调用cursor-cli create-chatexecute()在有 chat_id 时会使用cursor-cli --resume <chat_id> "<prompt>"
开发
# 安装开发依赖
pip install -e ".[dev]"
# 运行测试
pytest
# 代码格式化
black aiaim/
ruff check aiaim/
许可证
MIT License
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
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 aiaim-0.2.0.tar.gz.
File metadata
- Download URL: aiaim-0.2.0.tar.gz
- Upload date:
- Size: 25.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4db0b2e22edf5b5c0b85171c64ee3e61fb342c8f93b471077104964112800dc8
|
|
| MD5 |
ebf2f4a40d6b858235d37af5e53ca1ca
|
|
| BLAKE2b-256 |
416bf8e70dae22912fd6c891ff2ab1a3f9b63472ecb47696c97fd0aaded4353a
|
File details
Details for the file aiaim-0.2.0-py3-none-any.whl.
File metadata
- Download URL: aiaim-0.2.0-py3-none-any.whl
- Upload date:
- Size: 26.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e005b21ddaef2df9e1f4a7680ff04f533765e6d78964f7215a0d13ff7ab461cf
|
|
| MD5 |
9712e59e3df920d78151048904b3aea8
|
|
| BLAKE2b-256 |
4d223ff49f6b8bfe0437cc628ec91e4c2252b6f4524a49f5fd43e742b5521100
|