摘要:为什么要构建通用 Agent?因为这是一个很好的工具,可以为我们的目标使用场景提供原型,并为设计我们自己的定制 Agent 架构奠定基础。
LLM Agent 高层次概述(图片由原文作者提供)
为什么要构建通用 Agent?因为这是一个很好的工具,可以为我们的目标使用场景提供原型,并为设计我们自己的定制 Agent 架构奠定基础。
在我们继续深入之前,先快速介绍一下 LLM Agent。如果您已经了解,可以跳过这部分。
01
LLM Agent 是一种程序,其执行逻辑由底层模型控制。
从独立的 LLM 到具备 Agent 功能的系统。(图片由原文作者提供)
LLM Agent 与简单的少量样本提示(few-shot prompting)或预设工作流程的不同之处在于,它能够制定并调整执行用户查询所需的步骤。当拥有诸如代码执行或网络搜索等工具集的访问权限时,Agent 能够自主决定使用何种工具、如何使用,并依据输出结果进行迭代优化。这种灵活性使得系统能够以极低的配置需求应对多样化的场景。
LLM Agent 架构谱系。(图片由原文作者提供)
Agent 架构存在于一个连续的变化范围内,从固定工作流程的可靠性到 autonomous agents 的高度灵活性。例如,像检索增强生成(RAG)[1]这样的预设流程,可以通过加入自我反思循环(self-reflection loop)来提升改进,使得程序在初次响应不充分时能够进行改进。另一方面,ReAct[2] Agent 可以配备预设流程作为其工具之一,实现一种既灵活又有条理的处理方式。架构的选择最终应根据具体应用场景以及可靠性与灵活性之间的平衡需求来决定。
想要更全面的了解,请观看此视频[3]。
02
挑选合适的模型是实现预期性能的关键。在决策时,需考虑多个因素,如版权许可、成本和语言支持。对于构建 LLM Agent 来说,最关键的考虑因素是模型在核心任务上的表现,例如编程、调用工具和逻辑推理。以下是一些评估标准:
此外,模型的处理窗口大小也非常重要。Agent 的工作流程可能会消耗大量 Token —— 有时甚至超过 10 万个 —— 因此,更大的处理窗口将大大提高处理效率。
当前值得关注的模型(本文撰写时)包括:
前沿模型:GPT4-o[8],Claude 3.5[9]开源模型:Llama 3.2[10],Qwen 2.5[11]一般来说,模型越大,性能越优越。但能够在本地运行的小型模型也是一个不错的选择。小型模型通常适用于较为简单的场景,并且可能只能与一到两个基础工具对接。
单智能体(single Agent)架构图示。(图片由原文作者创作)
就 LLM 而言,系统提示词[12]是指在模型开始处理用户查询前,提供给模型的一系列指令和背景信息。
我们可以通过系统提示词来编码大语言模型应展现的智能体行为。
以下是一些常见的智能体行为模式,它们可以根据您的具体需求进行调整:
工具运用:智能体判断何时应将问题转交给适当的工具处理,或是依赖自身知识库。自我反思:智能体在回复用户前,会审视并修正自己的答案。大多数 LLM 系统也可以加入这一反思过程。Reason-then-Act(ReAct):智能体通过反复推理来确定解决问题的方法,执行操作,观察结果,并决定是否需要进一步行动或直接给出回答。Plan-then-Execute:智能体通过将任务细分为多个子步骤(如有必要)来进行事前规划,然后逐一执行这些步骤。在构建通用单智能体时,ReAct 和 Plan-then-Execute 这两种模式通常是起步的最佳选择。
常见智能体行为模式概览。(图片由原文作者创作)
为了有效地实现这些行为模式,我们需要对提示词进行精心设计。可能还需要采用结构化生成技术[13],这意味着会调整 LLM 的输出,使其符合特定的格式或架构,从而确保智能体的回复与我们所追求的沟通风格保持一致。
举例:下面是 Bee Agent Framework[14] 中一个 ReAct 风格智能体的系统提示词片段。
我们往往会想当然地认为,大语言模型(LLMs)一开箱就能提供一系列功能。虽然其中某些功能非常出色,但并非所有功能都能满足我们的具体需求。要想实现期望的性能表现,就需要在系统提示词中详细列出应该包含以及不应该包含的功能。
这可能涉及以下指令:
智能体的名称与职责:智能体的命名及其预期执行的任务。语言风格与简洁性:智能体在交流时应该保持的正式或随意程度,以及信息传达的简洁性。工具使用时机:确定何时应该利用外部工具,何时依赖模型自身的知识库。错误处理:当工具使用或流程执行出现问题时,智能体应采取的行动。示例:以下摘录自 Bee Agent Framework[14] 的操作指南部分。
工具就是赋予智能体超能力的魔法。只需一套定义明确的工具,就能实现广泛的应用功能。重要的工具包括代码执行、网络检索、文档读取和数据解析等。
对于每一项工具,都需要定义以下信息,并将其融入系统提示词之中:
Tool Name:为这项功能起一个独特且具描述性的名称。Tool Description:清晰地阐述该工具的作用及其使用时机。这有助于智能体判断何时选用合适的工具。Tool Input Schema:这是一个框架,它规定了必需和可选的参数、参数类型以及所有约束条件。智能体根据用户的提问,利用这个框架来填充所需的输入。提供一个指示或者指南,告诉用户或者开发者这个工具应该在哪里以及如何被运行。例如:以下是从 Langchain 社区摘录的 Arxiv 工具实现片段[15],需要 ArxivAPIWrapper[16] 的支持。
在某些场景下,为了达到预期的性能,我们需要对工具进行优化。这可能需要通过微调工具名称或描述来进行提示词工程,设置高级配置来处理常见问题,或是过滤、筛选工具的输出结果。
大语言模型(LLMs)受限于它们的上下文窗口大小 —— 也就是它们一次性能够“记下”的 tokens 数量。在多轮对话中,过往互动、工具输出的长文本或者是 Agent 所依赖的额外上下文信息,都可能迅速占满内存空间。因此,制定一个有效的内存管理策略是非常重要的。
在这里,所谓的“内存”是指智能体(Agent)存储、调用并利用历史交互信息的能力。这种能力使得智能体能够持续跟踪对话上下文,基于之前的对话来优化回答,从而提供更加定制化的用户体验。
常见的内存管理策略包括:
Sliding Memory:只保留最近 k 轮对话的记忆,较早的对话则被舍弃。Token Memory:只记下最近 n 个 tokens,其余的则被遗忘。Summarized Memory:每轮对话后,使用 LLM 对对话内容进行总结摘要,并丢弃原始信息。另外,我们还可以利用 LLM 来识别关键信息(key moments),并将其存储在长期记忆中。这样,智能体就能“记住”用户的重要信息,使用户体验更加个性化。
我们目前所讨论的五个步骤为创建智能体奠定了基础。那么,如果在这个阶段我们通过 LLM 处理用户查询,会发生什么呢?
答案是:你会得到一段未经处理的文本输出。(图片由作者提供)
示例如下:
此时,智能体会生成一段原始的文本输出。那么,我们如何确保智能体能够执行后续操作呢?这就需要引入解析和编排机制了。
解析器的作用是将原始数据转换成应用程序能够识别和使用的数据格式(例如,带有特定属性的对象)。
对于我们正在构建的智能体,解析器必须能够辨认出我们在第二步中设定的通信结构,并将其转换成结构化数据输出,例如 JSON 格式。这样做可以让应用程序更加便捷地处理和执行智能体的后续动作。
备注:某些模型供应商,例如 OpenAI,可以默认提供可直接解析的输出。而对于其他模型,尤其是那些开源模型,可能需要额外进行解析配置。
最后一步是建立编排逻辑。这一逻辑决定了 LLM 输出内容结果之后的处理流程。依据输出内容,系统将执行以下任一操作:
执行工具调用,或者给出回应 —— 这可能是对用户查询的直接回答,也可能是为了获取更多信息而提出的后续问题。扩展的单智能体架构图示。(图片由原文作者提供)
如果触发了工具调用,工具的输出信息会被送回 LLM(作为其工作记忆的一部分)。LLM 将据此决定如何利用这些新数据:是继续进行工具调用,还是直接向用户返回答案。
以下是在代码中实现这种编排逻辑的一个示例:
大功告成!现在,你已经有了一个能够应对多种场景的智能体系统 —— 无论是进行竞争分析、深入研究,还是实现复杂工作流程的自动化。
03
尽管当前 LLM 的表现令人印象深刻,但它们在处理海量信息时却显得力不从心[17]。一旦上下文过多或工具使用过杂,模型便可能不堪重负,导致性能下滑。面向多种用途的单智能体系统最终会触及这一上限,尤其是在它们对 token 的消耗量之大已是众所周知。
对于某些使用场景,部署多智能体系统或许更为合适。通过将任务分摊给多个智能体,可以有效避免单一 LLM Agent 的上下文负载过重,从而提高整体的执行效率。
尽管如此,通用的单智能体系统仍然是原型开发的一个极好起点。它能帮助我们迅速验证使用场景,并发现系统何时开始出现故障。在这个过程中,你将能够:
洞察哪些任务环节确实能通过 Agent 模式得到优化。确定可以作为独立流程分离出来,成为更大工作流程中一环的部分。从单智能体起步,这样能够获得他人宝贵的经验、见解,以便在构建更复杂系统时调整和优化策略。04
已经迫不及待想要开始构建智能体了吗?使用框架是快速测试和迭代智能体配置的好方法。
如果你打算使用 Llama 3 这样的开源模型,不妨试试 Bee Agent Framework[18] 提供的初始模板[19]。如果你打算使用 OpenAI 这样的前沿模型,试试 LangGraph[20] 提供的教程[21]可能会给你带来帮助。Thanks for reading!
Hope you have enjoyed and learned new things from this blog!
Interdisciplinary techie currently tinkering with LLM agents. I write about AI, innovation ecosystems, and my creative coding experiments.
END
本期互动内容
❓你在构建通用智能体(general-purpose agents)方面积累了哪些经验?欢迎在评论区留言分享你的心得!
文中链接
[1]https://research.ibm.com/blog/retrieval-augmented-generation-RAG
[2]https://www.promptingguide.ai/techniques/react
[3]https://www.youtube.com/watch?v=F8NKVhkZZWI&t=1s
[4]https://paperswithcode.com/sota/multi-task-language-understanding-on-mmlu
[5]https://gorilla.cs.berkeley.edu/leaderboard.html
[6]https://evalplus.github.io/leaderboard.html
[7]https://huggingface.co/spaces/bigcode/bigcode-models-leaderboard
[8]https://platform.openai.com/docs/models#gpt-4o
[9]https://www.anthropic.com/news/claude-3-5-sonnet
[10]https://huggingface.co/collections/meta-llama/llama-32-66f448ffc8c32f949b04c8cf
[11]https://huggingface.co/collections/Qwen/qwen25-66e81a666513e518adb90d9e
[12]https://promptengineering.org/system-prompts-in-large-language-models/
[13]https://python.langchain.com/v0.1/docs/modules/model_io/chat/structured_output/
[14]https://github.com/i-am-bee/bee-agent-framework/blob/main/src/agents/bee/prompts.ts
[15]https://github.com/langchain-ai/langchain/blob/master/libs/community/langchain_community/tools/arxiv/tool.py
[16]https://github.com/langchain-ai/langchain/blob/master/libs/community/langchain_community/utilities/arxiv.py
[17]https://arxiv.org/html/2410.18745v1
[18]https://github.com/i-am-bee/bee-agent-framework
[19]https://github.com/i-am-bee/bee-agent-framework-starter
[20]https://langchain-ai.github.io/langgraph/
[21]https://langchain-ai.github.io/langgraph/how-tos/react-agent-from-scratch/
来源:ChatGPT扫地僧一点号