2026年7月2日 周四晚上19:30,报名腾讯会议了解“如何构建自进化的动态知识库(Brain)”(限30人)
免费POC, 零成本试错
FDE知识库

FDE知识库

学习大模型的前沿技术与行业落地应用


收藏

探索AI智能体Agent的核心架构:记忆、工具与行动

发布日期:2024-07-15 08:45:19 浏览次数: 6033
作者:智能体AI

微信搜一搜,关注“智能体AI”

近年来,人工智能技术不断发展,智能体Agent在各种应用场景中发挥着越来越重要的作用。这篇文章将详细解析智能体Agent的记忆与决策框架,探讨其多模态感知、记忆、规划决策等各个环节的实现与应用。智能体Agent是人工智能领域的重要研究方向,广泛应用于自动驾驶、智能家居、金融分析等多个领域。本文将以一幅示意图为基础,详细解析智能体Agent在记忆与决策过程中各个模块的功能及其相互关系。并通过实际代码案例进行讲解。


一、多模态感知

多模态感知是智能体Agent理解世界的基础,它包括对文字、图像、声音等多种信息的感知与处理。在本框架中,多模态感知模块接收外界的提示词和图像信息,为智能Agent提供原始数据输入。
  • 多模态感知的定义 多模态感知指的是系统能够同时处理来自不同感官的信息,如视觉、听觉和语言输入。这使得智能Agent能够更全面地理解复杂的环境和任务需求。
  • 多模态感知的实现 多模态感知需要使用多种传感器和处理器。例如,摄像头、麦克风和文本输入设备。通过深度学习算法,智能Agent能够将这些感知数据转换为有用的信息。


二、记忆模块

记忆模块是智能Agent的大脑,它负责存储和管理短期和长期记忆。在本框架中,记忆模块分为短期记忆和长短期记忆两个部分。
  • 短期记忆 短期记忆类似于人类的大脑在处理当前任务时的临时记忆,用于快速响应和处理即时信息。
  • 长短期记忆 长短期记忆结合了短期记忆和长期记忆的优势,用于在完成任务过程中保持和利用重要信息。


三、规划与决策

智能Agent的规划与决策模块是其核心功能之一。它根据记忆模块中的信息,制定合理的行动计划,并进行思维链、反思和自我批评等过程。
  • 思维链 思维链是智能Agent在决策过程中,逐步推理和演绎的过程。通过不断地思考和分析,Agent能够得出最优的解决方案。
  • 反思与自我批评 反思与自我批评是智能Agent在任务完成后,回顾和评估自身表现的过程。这一过程能够帮助Agent不断改进和优化自身算法和策略。
  • 子目标分解 在复杂任务中,智能Agent需要将整体目标分解为若干子目标,并逐一实现。这一过程需要Agent具备良好的规划和协调能力。


四、工具模块

工具模块是智能Agent执行任务时所依赖的外部资源。在本框架中,工具模块包括搜索引擎、计算器、代码解释器和日历等。
  • 搜索引擎 搜索引擎为智能Agent提供了强大的信息检索能力,能够快速查找和获取所需的信息。
  • 计算器 计算器为智能Agent提供了复杂计算能力,能够进行各种数学运算和数据处理。
  • 代码解释器 代码解释器帮助智能Agent理解和执行代码,实现自动化任务和编程操作。
  • 日历 日历工具帮助智能Agent管理时间和任务,提高工作效率。


五、行动模块

行动模块是智能Agent执行具体任务和操作的最终环节。在本框架中,行动模块通过调用工具模块中的资源,完成预定的任务和目标。

六、ReAct 核心思想是:推理+操作

接下来以Google Search 和 LLM Math等作为可选操作集合(toolkits),实现 ReAct 功能

1、实现 ReAct 算法的测试函数:使用 LangChain 库和 OpenAI API 来执行推理和操作。

# 以下`SERPAPI_API_KEY`仅为示例,请访问 https://serpapi.com 注册账号并替换为自己的 `API_KEY`(每月100次免费调用)def react_test():"""实现 ReAct 算法的测试函数。使用 LangChain 库和 OpenAI API 来执行推理和操作。"""os.environ["SERPAPI_API_KEY"] = os.getenv('SERPAPI_API_KEY')# 加载 LangChain 内置的 Toolstools = load_tools(["serpapi", "llm-math"], llm=llm)# 实例化 ZERO_SHOT_REACT Agentagent = initialize_agent(tools, llm, agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True)print(agent.run("谁是莱昂纳多·迪卡普里奥的女朋友?她现在年龄的0.43次方是多少"))


2、测试自我提问与搜索功能的函数:使用 SerpAPI 来执行搜索操作,并结合 LangChain 的工具和LLM进行问答。

def self_ask_with_search_test():"""测试自我提问与搜索功能的函数。使用 SerpAPI 来执行搜索操作,并结合 LangChain 的工具和LLM进行问答。"""os.environ["SERPAPI_API_KEY"] = os.getenv('SERPAPI_API_KEY')# 实例化查询工具search = SerpAPIWrapper()tools = [Tool(name="Intermediate Answer",func=search.run,description="useful for when you need to ask with search",)]# 实例化 SELF_ASK_WITH_SEARCH Agentself_ask_with_search = initialize_agent(tools, llm, agent=AgentType.SELF_ASK_WITH_SEARCH, verbose=True,handle_parsing_errors=True)# 实际运行 Agent,查询问题(正确)self_ask_with_search.run("成都举办的大运会是第几届大运会?")

3、测试函数工具的函数使用 LangChain 和 OpenAI 来执行特定的函数操作。

@tooldef get_word_length(word: str) -> int:"""计算单词长度的工具函数。参数:word: 要计算长度的单词。返回:单词的长度。""""""Returns the length of a word."""return len(word)
tools = [get_word_length]def function_test():"""测试函数工具的函数。使用 LangChain 和 OpenAI 来执行特定的函数操作。"""system_message = SystemMessage(content="你是非常强大的AI助手,但在计算单词长度方面不擅长。")prompt = OpenAIFunctionsAgent.create_prompt(system_message=system_message)agent = OpenAIFunctionsAgent(llm=llm, tools=tools, prompt=prompt)# 实例化 OpenAIFunctionsAgentagent_executor = AgentExecutor(agent=agent, tools=tools, verbose=True)agent_executor.run("单词“educa”中有多少个字母?")

4、测试函数记忆功能的函数使用 LangChain 的记忆机制来保持对话上下文。

def function_memory_test():"""测试函数记忆功能的函数。使用 LangChain 的记忆机制来保持对话上下文。"""system_message = SystemMessage(content="你是非常强大的AI助手,但在计算单词长度方面不擅长。")MEMORY_KEY = "chat_history"prompt = OpenAIFunctionsAgent.create_prompt(system_message=system_message,extra_prompt_messages=[MessagesPlaceholder(variable_name=MEMORY_KEY)])memory = ConversationBufferMemory(memory_key=MEMORY_KEY, return_messages=True)agent = OpenAIFunctionsAgent(llm=llm, tools=tools, prompt=prompt)# 实例化 OpenAIFunctionsAgentagent_executor = AgentExecutor(agent=agent, tools=tools, verbose=True)agent_executor.run("单词“educa”中有多少个字母?")#agent_executor.run("那是一个真实的单词吗?")

5、完整代码

# 加载环境变量import openaiimport osimport tiktoken# 加载 .env 文件from dotenv import load_dotenv, find_dotenvfrom langchain.prompts import PromptTemplatefrom langchain.llms import OpenAIfrom langchain.chains import LLMChain#from langchain.chat_models import AzureChatOpenAIfrom langchain.chat_models import ChatOpenAI #直接访问OpenAI的GPT服务from langchain.agents import load_toolsfrom langchain.agents import initialize_agentfrom langchain.agents import AgentType,Toolfrom langchain.utilities import SerpAPIWrapperfrom langchain.schema import SystemMessagefrom langchain.agents import OpenAIFunctionsAgentfrom langchain.agents import AgentExecutorfrom langchain.agents import toolfrom langchain.prompts import MessagesPlaceholderfrom langchain.memory import ConversationBufferMemory
# 加载环境变量_ = load_dotenv(find_dotenv())# 从环境变量中获得你的 OpenAI Key和配置URLopenai.api_key = os.getenv('OPENAI_API_KEY')openai.api_base = os.getenv('OPENAI_API_URL')model = os.getenv('OPENAI_API_MODEL')
# 初始化LLM链llm = ChatOpenAI(model_name=model, temperature=0) #直接访问OpenAI的GPT服务
# ReAct 核心思想是 推理+操作,本示例以` Google Search` 和 `LLM Math` 作为可选操作集合(toolkits),实现 ReAct 功能。# 以下`SERPAPI_API_KEY`仅为示例,请访问 https://serpapi.com 注册账号并替换为自己的 `API_KEY`(每月100次免费调用)def react_test():"""实现 ReAct 算法的测试函数。使用 LangChain 库和 OpenAI API 来执行推理和操作。"""os.environ["SERPAPI_API_KEY"] = os.getenv('SERPAPI_API_KEY')# 加载 LangChain 内置的 Toolstools = load_tools(["serpapi", "llm-math"], llm=llm)# 实例化 ZERO_SHOT_REACT Agentagent = initialize_agent(tools, llm, agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION, verbose=True)print(agent.run("谁是莱昂纳多·迪卡普里奥的女朋友?她现在年龄的0.43次方是多少"))
def self_ask_with_search_test():"""测试自我提问与搜索功能的函数。使用 SerpAPI 来执行搜索操作,并结合 LangChain 的工具和LLM进行问答。"""os.environ["SERPAPI_API_KEY"] = os.getenv('SERPAPI_API_KEY')# 实例化查询工具search = SerpAPIWrapper()tools = [Tool(name="Intermediate Answer",func=search.run,description="useful for when you need to ask with search",)]# 实例化 SELF_ASK_WITH_SEARCH Agentself_ask_with_search = initialize_agent(tools, llm, agent=AgentType.SELF_ASK_WITH_SEARCH, verbose=True,handle_parsing_errors=True)# 实际运行 Agent,查询问题(正确)self_ask_with_search.run("成都举办的大运会是第几届大运会?")
@tooldef get_word_length(word: str) -> int:"""计算单词长度的工具函数。参数:word: 要计算长度的单词。返回:单词的长度。""""""Returns the length of a word."""return len(word)
tools = [get_word_length]def function_test():"""测试函数工具的函数。使用 LangChain 和 OpenAI 来执行特定的函数操作。"""system_message = SystemMessage(content="你是非常强大的AI助手,但在计算单词长度方面不擅长。")prompt = OpenAIFunctionsAgent.create_prompt(system_message=system_message)agent = OpenAIFunctionsAgent(llm=llm, tools=tools, prompt=prompt)# 实例化 OpenAIFunctionsAgentagent_executor = AgentExecutor(agent=agent, tools=tools, verbose=True)agent_executor.run("单词“educa”中有多少个字母?")
def function_memory_test():"""测试函数记忆功能的函数。使用 LangChain 的记忆机制来保持对话上下文。"""system_message = SystemMessage(content="你是非常强大的AI助手,但在计算单词长度方面不擅长。")MEMORY_KEY = "chat_history"prompt = OpenAIFunctionsAgent.create_prompt(system_message=system_message,extra_prompt_messages=[MessagesPlaceholder(variable_name=MEMORY_KEY)])memory = ConversationBufferMemory(memory_key=MEMORY_KEY, return_messages=True)agent = OpenAIFunctionsAgent(llm=llm, tools=tools, prompt=prompt)# 实例化 OpenAIFunctionsAgentagent_executor = AgentExecutor(agent=agent, tools=tools, verbose=True)agent_executor.run("单词“educa”中有多少个字母?")#agent_executor.run("那是一个真实的单词吗?")
# python 入口函数if __name__ == '__main__':#react_test()#self_ask_with_search_test()#function_test()function_memory_test()

七、总结

通过以上分析和案例,我们可以看出智能Agent在记忆与决策过程中,各个模块之间紧密配合,相互支持,形成了一个完整的智能系统。多模态感知为Agent提供了丰富的输入信息,记忆模块存储和管理这些信息,规划与决策模块制定合理的行动计划,工具模块提供必要的资源支持,最终通过行动模块完成任务。这一框架不仅为我们理解智能Agent的工作原理提供了有力支持,也为实际应用中的智能系统设计和开发提供了宝贵的参考。未来,随着技术的不断进步,智能Agent必将在更多领域中发挥重要作用,为我们的生活和工作带来更多便利和创新。

53AI,企业落地大模型首选服务商

产品:场景落地咨询+大模型应用平台+行业解决方案

承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业

联系我们

售前咨询
186 6662 7370
预约演示
185 8882 0121

微信扫码

添加专属顾问

回到顶部

加载中...

扫码咨询

扫码登录
登录即表示您同意《53AI网站服务协议》
服务协议

欢迎您使用【53AI 官方网站】(以下简称“本网站”或“我们”)。本《会员服务协议》(以下简称“本协议”)是您(以下简称“会员”或“用户”)与【深圳市博思协创网络科技有限公司】之间关于注册、登录及使用本网站会员服务所订立的法律协议。

在您注册或登录前,请务必审慎阅读、充分理解各条款内容,特别是免除或限制责任的条款、知识产权条款、争议解决条款等。此类条款将以加粗形式提示您注意。 当您通过微信公众号授权、手机验证码验证或其他方式成功登录本网站时,即视为您已完全理解并同意接受本协议的全部内容。

一、 定义

本网站:指由【深圳市博思协创网络科技有限公司】运营的,域名为【53ai.com】的网站及相关移动端页面。

会员服务:指本网站向注册会员提供的知识库文章查阅、内容检索及其他相关增值服务。

知识库内容:指本网站发布的包括但不限于文字、图表、数据、研究报告、行业分析等数字化内容资源。

二、 账号注册与登录

登录方式:本网站支持以下登录方式,您可根据实际情况选择:

微信公众号授权登录:您同意将您的微信OpenID信息授权给本网站,用于创建或关联会员账号。

手机验证码登录:您需提供真实有效的手机号码,并通过短信验证码完成身份验证与登录/注册。

账号安全:您的账号仅限您本人使用,禁止赠与、借用、租用、转让或售卖。因您保管不善导致的账号被盗、密码泄露等损失,由您自行承担。

实名认证:根据相关法律法规要求,我们可能要求您在特定功能下完成实名认证。如您拒绝提供,可能无法使用部分或全部服务。

未成年人保护:若您未满18周岁,请在法定监护人的陪同下阅读本协议,并在征得监护人同意后使用本服务。

三、 服务内容与规范

知识库查阅权限:会员登录后,有权按照其会员等级对应的权限范围,在线浏览、检索本网站知识库中的相关文章及内容。

服务变更:我们有权根据业务发展需要,调整、变更或终止部分服务内容,并将以网站公告、公众号消息等方式提前通知。

禁止行为:您在使用服务时不得实施以下行为:

利用技术手段批量爬取、下载、转存知识库内容;

将知识库内容用于商业目的或未经授权地向第三方传播;

干扰本网站正常运行或侵犯其他用户合法权益;

发布违法违规信息或从事违反公序良俗的活动。

四、 知识产权声明

权利归属:本网站知识库中的排版设计、软件代码等内容的知识产权均归【公司全称】或原权利人所有,受《中华人民共和国著作权法》等法律保护。

有限许可:本网站授予会员一项非独占、不可转让、不可转授权的普通许可,仅限于个人学习、研究之目的在线查阅知识库内容。

侵权追责:未经书面许可,任何单位或个人不得以任何形式复制、转载、摘编、镜像、汇编或以其他方式使用上述内容。一经发现,我们保留追究其法律责任的权利。

五、 个人信息保护

我们重视对您个人信息的保护。关于我们如何收集、使用、存储和保护您的个人信息,请单独阅读 《隐私政策》。

您通过微信公众号授权或手机号验证所提供的信息,我们将严格按照《个人信息保护法》的规定处理,仅用于身份识别、服务提供及安全验证等必要用途。

您可以随时通过网站设置或联系客服行使查阅、更正、删除个人信息及撤回授权同意的权利。

六、 免责声明

内容准确性:知识库内容仅供参考,不构成专业建议。我们不对其完整性、准确性、时效性作任何明示或暗示的保证,您应自行判断并承担使用风险。

不可抗力:因自然灾害、政策法规变化、网络故障、第三方平台接口异常(如微信接口维护、运营商短信通道故障)等不可抗力导致的服务中断或延迟,我们不承担违约责任。

第三方链接:本网站可能包含指向第三方网站的链接,该等网站的内容和服务不受我们控制,请您自行甄别风险。

七、 违约责任

如您违反本协议约定,我们有权视情节采取警告、限制功能、暂停服务、注销账号等措施,并保留要求赔偿损失的权利。

如因您的违约行为导致我们遭受行政处罚、第三方索赔或商誉损失,您应承担全部赔偿责任(包括但不限于罚款、赔偿金、律师费、公证费等)。

八、 法律适用与争议解决

本协议的订立、执行和解释均适用中华人民共和国大陆地区法律。

因本协议产生的或与本协议有关的任何争议,双方应友好协商解决;协商不成的,任何一方均可向【公司所在地】有管辖权的人民法院提起诉讼。

九、 其他

本协议构成双方就本服务达成的完整协议,取代此前任何口头或书面约定。

本协议任一条款被认定为无效或不可执行的,不影响其他条款的效力。

我们对本协议享有最终解释权,并在法律允许的范围内保留随时修改的权利。修改后的协议一经公布即生效,继续使用服务即视为同意修订内容。


已查阅