AgentKit

GitHub
520 62 简单 1 次阅读 6天前CC-BY-4.0语言模型开发框架Agent
AI 解读 由 AI 自动生成,仅供参考

AgentKit 是一个直观的大语言模型(LLM)提示框架,旨在帮助用户通过简单的自然语言指令,构建出具备复杂“思维过程”的多功能智能体。它核心解决了传统开发中过度依赖代码来实现复杂逻辑的痛点,让用户无需编写繁琐的程序,就能设计出结构清晰、逻辑严密的智能工作流。

该工具特别适合希望快速原型验证的研究人员、缺乏深厚编程背景的设计师,以及想要灵活定制智能体行为的开发者。其独特的技术亮点在于引入了“图工程”理念:用户只需像搭乐高积木一样组合不同的“节点”,每个节点代表一个具体的子任务提示词。AgentKit 会自动将这些节点组织成有向无环图(DAG),按指定顺序执行推理,从而显式地模拟人类解决问题的结构化思维。这种设计不仅降低了构建多功能智能体的门槛,还让非技术人员也能轻松参与智能体的设计与调优,真正实现了“用图表而非代码”来驱动人工智能。

使用场景

某电商公司的运营团队需要快速生成针对“双十一”大促的个性化营销文案,要求先分析用户画像,再提炼商品卖点,最后组合成不同风格的推广短文。

没有 AgentKit 时

  • 开发人员必须编写复杂的 Python 代码来串联多个 API 调用,手动管理每一步的输入输出依赖关系。
  • 当需要调整文案生成的逻辑顺序(例如先写卖点再分析用户)时,必须修改代码逻辑并重新部署,迭代周期长。
  • 非技术背景的运营人员无法直接参与流程设计,只能提出模糊需求,导致最终产出与预期偏差大。
  • 一旦中间某个环节(如用户画像分析)出错,缺乏可视化的调试机制,排查问题如同“黑盒”摸索。

使用 AgentKit 后

  • 运营人员只需像搭乐高一样,通过自然语言提示词定义“分析用户”、“提炼卖点”、“撰写文案”三个节点,无需编写任何代码。
  • 调整策略变得极其灵活,只需在配置中拖拽或修改节点顺序,即可立即测试新的思维链条,实现分钟级迭代。
  • 业务专家直接构建复杂的“思考过程”,确保 AI 严格遵循“先分析后创作”的结构化逻辑,大幅提升文案精准度。
  • 系统以有向无环图(DAG)形式清晰展示执行流,每个节点的输入输出透明可见,快速定位并优化效果不佳的环节。

AgentKit 将复杂的智能体开发转化为直观的流程设计,让业务专家能直接驾驭大模型的多步推理能力,彻底打破了技术与应用之间的壁垒。

运行环境要求

操作系统
  • 未说明
GPU

未说明

内存

未说明

依赖
notes该工具主要作为 LLM API 的编排框架,本身不强制要求本地 GPU 运行(取决于调用的后端模型)。若使用 OpenAI、Anthropic 等云端模型,需配置相应的 API Key 环境变量;若使用本地 Ollama 模型,需自行安装 Ollama 服务并配置 URL 及分词器路径。支持通过 pip 安装不同功能包(如日志记录、专有模型支持或全量支持)。
python3.8+
openai
anthropic
ollama
AgentKit hero image

快速开始

AgentKit:用图而非编码进行流程工程

[Arxiv论文] [PDF] [文档]

PyPI - Python版本 PyPI PyPI热度 文档 GitHub许可证


提供了一个统一的框架,能够从简单的自然语言提示中显式地构建复杂的人类“思维过程”。 用户可以像拼搭乐高积木一样,将一系列节点组合起来。这些节点链可以被设计成明确地遵循一种自然的结构化“思维过程”。

不同排列方式的节点可以代表不同的功能,从而允许用户整合多种功能来构建多功能智能体。

一个基础智能体的实现可能只需要一个子任务提示列表即可,因此即使是没有编程经验的人也能设计和调整它。

目录

安装

安装稳定版AgentKit非常简单:

pip install agentkit-llm

若要安装带有wandb支持的AgentKit:

pip install agentkit-llm[logging]

若要安装支持OpenAI和Claude LLM-API的AgentKit:

pip install agentkit-llm[proprietary]

若要安装具有完整内置LLM-API支持的AgentKit(包括Llama):

pip install agentkit-llm[all]

或者,若要从本仓库的主分支安装最新版本,运行以下命令:

git clone https://github.com/holmeswww/AgentKit && cd AgentKit
pip install -e .

快速入门

AgentKit中的基本构建块是节点,每个节点包含针对特定子任务的自然语言提示。这些节点通过依赖关系规范连接在一起,以指定评估顺序。不同的节点排列方式可以表示不同的逻辑和思维过程。

在推理时,AgentKit会按照指定的顺序以有向无环图(DAG)的形式评估所有节点。

import agentkit
from agentkit import Graph, BaseNode

import agentkit.llm_api

LLM_API_FUNCTION = agentkit.llm_api.get_query("gpt-4-turbo")

LLM_API_FUNCTION.debug = True # 关闭此选项以启用API级别的错误处理与重试

graph = Graph()

subtask1 = "使用LLM智能体作为游戏AI有哪些优缺点?" 
node1 = BaseNode(subtask1, subtask1, graph, LLM_API_FUNCTION, agentkit.compose_prompt.BaseComposePrompt(), verbose=True)
graph.add_node(node1)

subtask2 = "请为题为‘游戏中的LLM智能体’的文章提供一个提纲。"
node2 = BaseNode(subtask2, subtask2,graph,LLM_API_FUNCTION,agentkit.compose_prompt.BaseComposePrompt(), verbose=True)
graph.add_node(node2)

subtask3 = "现在,请围绕‘游戏中的LLM智能体’这一主题撰写一篇完整的文章。"
node3 = BaseNode(subtask3,subtask3,graph,LLM_API_FUNCTION,agentkit.compose_prompt.BaseComposePrompt(), verbose=True)
graph.add_node(node3)

# 添加节点之间的依赖关系
graph.add_edge(subtask1, subtask2)
graph.add_edge(subtask1, subtask3)
graph.add_edge(subtask2, subtask3)

result = graph.evaluate() # 输出一个包含提示与回答对的字典

LLM_API_FUNCTION 可以是任何接受 msg:listshrink_idx:int 作为输入,并输出 llm_result:strusage:dict 的LLM API函数。其中,msg 是提示(默认采用OpenAI格式),而 shrink_idx:int 是当提示过长时,LLM应缩短提示长度的索引。

AgentKit通过LLM_API_FUNCTION跟踪每个节点的token使用情况:

usage = {
    'prompt': $提示token计数,
    'completion': $完成token计数,
}

内置LLM-API

内置的agentkit.llm_api函数需要使用[proprietary][all]设置进行安装。详情请参阅安装指南

目前,内置API支持OpenAI和Anthropic,详情请参见https://pypi.org/project/openai/https://pypi.org/project/anthropic/。

要使用OpenAI模型,需设置环境变量 OPENAI_KEYOPENAI_ORG。或者,您也可以将OpenAI的“密钥”和“组织ID”分别写入~/.openai/openai.key文件的前两行。

要使用Azure OpenAI模型,需设置环境变量 AZURE_OPENAI_API_KEYAZURE_OPENAI_API_VERSIONAZURE_OPENAI_ENDPOINTAZURE_DEPLOYMENT_NAME。或者,您可以将Azure OpenAI的API密钥、API版本、端点和部署名称存储在~/.openai/azure_openai.key文件的前四行。

要使用Anthropic模型,需设置环境变量 ANTHROPIC_KEY。或者,您也可以将Anthropic的“密钥”写入~/.openai/openai.key文件的第三行。

要使用Ollama模型,请参阅https://github.com/ollama/ollama获取安装说明。然后设置 OLLAMA_URLOLLAMA_TOKENIZER_PATH,或者将OLLAMA_TOKENIZER_PATHOLLAMA_URL存储在~/.ollama/ollama_model.info文件的前两行。

LLM_API_FUNCTION = agentkit.llm_api.get_query("ollama-llama3")

无需编程经验使用AgentKit

首先,按照安装指南使用[all]设置安装AgentKit。

然后,设置环境变量 OPENAI_KEYOPENAI_ORG,填入您的OpenAI密钥和组织ID。

接着,运行以下命令以调用命令行界面(CLI):

git clone https://github.com/holmeswww/AgentKit && cd AgentKit
cd examples/prompt_without_coding
python generate_graph.py

节点组件

在每个节点内部(如图左侧所示),AgentKit 会运行一个内置流程,该流程会对输入进行预处理(Compose),然后使用预处理后的输入和提示 $q_v$ 向 LLM 发起查询,并可选地对 LLM 的输出进行后处理(After-query)。

为了支持分支等高级功能,AgentKit 提供了 API,允许在推理时动态修改 DAG(如图右侧所示)。根据某些祖先节点的 LLM 响应,可以动态添加或移除节点和边。

常见问题解答

问: 我正在使用默认的 agentkit.llm_api,但调用 graph.evaluate() 时程序似乎卡住了。

答: 默认情况下,LLM_API 函数会捕获并重试所有 API 错误。请为每个节点设置 verbose=True,以查看具体是哪个节点卡住了;同时将 LLM_API_FUNCTION.debug=True,以便了解导致错误的具体原因。

引用 AgentKit

@inproceedings{agentkit,
  title = {AgentKit: Flow Engineering with Graphs, not Coding},
  author = {Wu, Yue and Fan, Yewen and Min, So Yeon and Prabhumoye, Shrimai and McAleer, Stephen and Bisk, Yonatan and Salakhutdinov, Ruslan and Li, Yuanzhi and Mitchell, Tom},
  year = {2024},
  booktitle = {COLM},
}

星标历史

星标历史图表

版本历史

v0.1.8.12024/10/09
v0.1.82024/07/09
v0.1.72024/05/06
v0.1.62024/04/24
v0.1.52024/04/22
v0.1.42024/04/18
v0.1.22024/04/16

常见问题

相似工具推荐

openclaw

OpenClaw 是一款专为个人打造的本地化 AI 助手,旨在让你在自己的设备上拥有完全可控的智能伙伴。它打破了传统 AI 助手局限于特定网页或应用的束缚,能够直接接入你日常使用的各类通讯渠道,包括微信、WhatsApp、Telegram、Discord、iMessage 等数十种平台。无论你在哪个聊天软件中发送消息,OpenClaw 都能即时响应,甚至支持在 macOS、iOS 和 Android 设备上进行语音交互,并提供实时的画布渲染功能供你操控。 这款工具主要解决了用户对数据隐私、响应速度以及“始终在线”体验的需求。通过将 AI 部署在本地,用户无需依赖云端服务即可享受快速、私密的智能辅助,真正实现了“你的数据,你做主”。其独特的技术亮点在于强大的网关架构,将控制平面与核心助手分离,确保跨平台通信的流畅性与扩展性。 OpenClaw 非常适合希望构建个性化工作流的技术爱好者、开发者,以及注重隐私保护且不愿被单一生态绑定的普通用户。只要具备基础的终端操作能力(支持 macOS、Linux 及 Windows WSL2),即可通过简单的命令行引导完成部署。如果你渴望拥有一个懂你

349.3k|★★★☆☆|2周前
Agent开发框架图像

n8n

n8n 是一款面向技术团队的公平代码(fair-code)工作流自动化平台,旨在让用户在享受低代码快速构建便利的同时,保留编写自定义代码的灵活性。它主要解决了传统自动化工具要么过于封闭难以扩展、要么完全依赖手写代码效率低下的痛点,帮助用户轻松连接 400 多种应用与服务,实现复杂业务流程的自动化。 n8n 特别适合开发者、工程师以及具备一定技术背景的业务人员使用。其核心亮点在于“按需编码”:既可以通过直观的可视化界面拖拽节点搭建流程,也能随时插入 JavaScript 或 Python 代码、调用 npm 包来处理复杂逻辑。此外,n8n 原生集成了基于 LangChain 的 AI 能力,支持用户利用自有数据和模型构建智能体工作流。在部署方面,n8n 提供极高的自由度,支持完全自托管以保障数据隐私和控制权,也提供云端服务选项。凭借活跃的社区生态和数百个现成模板,n8n 让构建强大且可控的自动化系统变得简单高效。

184.7k|★★☆☆☆|昨天
数据工具开发框架Agent

AutoGPT

AutoGPT 是一个旨在让每个人都能轻松使用和构建 AI 的强大平台,核心功能是帮助用户创建、部署和管理能够自动执行复杂任务的连续型 AI 智能体。它解决了传统 AI 应用中需要频繁人工干预、难以自动化长流程工作的痛点,让用户只需设定目标,AI 即可自主规划步骤、调用工具并持续运行直至完成任务。 无论是开发者、研究人员,还是希望提升工作效率的普通用户,都能从 AutoGPT 中受益。开发者可利用其低代码界面快速定制专属智能体;研究人员能基于开源架构探索多智能体协作机制;而非技术背景用户也可直接选用预置的智能体模板,立即投入实际工作场景。 AutoGPT 的技术亮点在于其模块化“积木式”工作流设计——用户通过连接功能块即可构建复杂逻辑,每个块负责单一动作,灵活且易于调试。同时,平台支持本地自托管与云端部署两种模式,兼顾数据隐私与使用便捷性。配合完善的文档和一键安装脚本,即使是初次接触的用户也能在几分钟内启动自己的第一个 AI 智能体。AutoGPT 正致力于降低 AI 应用门槛,让人人都能成为 AI 的创造者与受益者。

183.6k|★★★☆☆|今天
Agent语言模型插件

stable-diffusion-webui

stable-diffusion-webui 是一个基于 Gradio 构建的网页版操作界面,旨在让用户能够轻松地在本地运行和使用强大的 Stable Diffusion 图像生成模型。它解决了原始模型依赖命令行、操作门槛高且功能分散的痛点,将复杂的 AI 绘图流程整合进一个直观易用的图形化平台。 无论是希望快速上手的普通创作者、需要精细控制画面细节的设计师,还是想要深入探索模型潜力的开发者与研究人员,都能从中获益。其核心亮点在于极高的功能丰富度:不仅支持文生图、图生图、局部重绘(Inpainting)和外绘(Outpainting)等基础模式,还独创了注意力机制调整、提示词矩阵、负向提示词以及“高清修复”等高级功能。此外,它内置了 GFPGAN 和 CodeFormer 等人脸修复工具,支持多种神经网络放大算法,并允许用户通过插件系统无限扩展能力。即使是显存有限的设备,stable-diffusion-webui 也提供了相应的优化选项,让高质量的 AI 艺术创作变得触手可及。

162.1k|★★★☆☆|2周前
开发框架图像Agent

everything-claude-code

everything-claude-code 是一套专为 AI 编程助手(如 Claude Code、Codex、Cursor 等)打造的高性能优化系统。它不仅仅是一组配置文件,而是一个经过长期实战打磨的完整框架,旨在解决 AI 代理在实际开发中面临的效率低下、记忆丢失、安全隐患及缺乏持续学习能力等核心痛点。 通过引入技能模块化、直觉增强、记忆持久化机制以及内置的安全扫描功能,everything-claude-code 能显著提升 AI 在复杂任务中的表现,帮助开发者构建更稳定、更智能的生产级 AI 代理。其独特的“研究优先”开发理念和针对 Token 消耗的优化策略,使得模型响应更快、成本更低,同时有效防御潜在的攻击向量。 这套工具特别适合软件开发者、AI 研究人员以及希望深度定制 AI 工作流的技术团队使用。无论您是在构建大型代码库,还是需要 AI 协助进行安全审计与自动化测试,everything-claude-code 都能提供强大的底层支持。作为一个曾荣获 Anthropic 黑客大奖的开源项目,它融合了多语言支持与丰富的实战钩子(hooks),让 AI 真正成长为懂上

161.7k|★★☆☆☆|今天
开发框架Agent语言模型

opencode

OpenCode 是一款开源的 AI 编程助手(Coding Agent),旨在像一位智能搭档一样融入您的开发流程。它不仅仅是一个代码补全插件,而是一个能够理解项目上下文、自主规划任务并执行复杂编码操作的智能体。无论是生成全新功能、重构现有代码,还是排查难以定位的 Bug,OpenCode 都能通过自然语言交互高效完成,显著减少开发者在重复性劳动和上下文切换上的时间消耗。 这款工具专为软件开发者、工程师及技术研究人员设计,特别适合希望利用大模型能力来提升编码效率、加速原型开发或处理遗留代码维护的专业人群。其核心亮点在于完全开源的架构,这意味着用户可以审查代码逻辑、自定义行为策略,甚至私有化部署以保障数据安全,彻底打破了传统闭源 AI 助手的“黑盒”限制。 在技术体验上,OpenCode 提供了灵活的终端界面(Terminal UI)和正在测试中的桌面应用程序,支持 macOS、Windows 及 Linux 全平台。它兼容多种包管理工具,安装便捷,并能无缝集成到现有的开发环境中。无论您是追求极致控制权的资深极客,还是渴望提升产出的独立开发者,OpenCode 都提供了一个透明、可信

144.3k|★☆☆☆☆|4天前
Agent插件