当前位置: 首页 > news >正文

经典Agent架构实战之工具使用 (Tool Use)


欢迎关注公众号:AI开发的后端厨师,知乎:巴塞罗那的风
及时获取更新内容,每周更新一个经典Agent架构

介绍

工具使用架构是连接大型语言模型(LLM)推理能力与真实、动态世界的 桥梁。它赋予智能体查询 API、搜索数据库和访问实时信息的能力,从而克服了 LLM 知识的静态局限性。

定义

工具使用 架构为 LLM 驱动的智能体配备了调用外部函数或 API(即 “工具”)的能力。智能体能够自主判断用户查询是否需要外部信息,并决定调用哪个工具来获取所需数据。

工作流程

接收查询 (Receive Query): 智能体接收用户的请求。
决策 (Decision): 智能体分析查询和可用工具,判断是否需要工具。
行动 (Action): 如果需要,智能体格式化对工具的调用(例如,带正确参数的特定函数)。
观察 (Observation): 系统执行工具调用,并将结果(“观察结果”)返回给智能体。
合成 (Synthesis): 智能体将工具的输出整合到其推理过程中,生成一个最终的、有事实依据 的答案。

和react的区别

大家都是要调工具,都是要总结合成,二者的区别在哪?tool use架构是只调用一次工具,不需要把调用的结果再交给模型进行下一步动作的思考,换句话说就是tool use适合一锤子买卖或者是普通的work flow;react适合更复杂问题的解决

代码

本文章是对这篇公众号文章的复刻
完整代码已上传github:地址

核心代码解释

prompt

funcDraftCodeTemplate()prompt.DefaultChatTemplate{systemTpl:=` 角色:你是一个精于解决用户问题的问题解答师。 任务:根据用户的需求,回答问题,必要时使用提供给你的工具进行问题回答。 要求:如果你已知了工具的查询结果,则无需继续调用工具,而应该结果整合进最终的回答中,确保回答的准确性和完整性。 `chatTpl:=prompt.FromMessages(schema.FString,schema.SystemMessage(systemTpl),schema.UserMessage("{user_query}"),)return*chatTpl}

告诉模型职责,限制仅调用一次工具,不过这里更应在使用场景上进行限制

编排部分

typestatestruct{Messages[]*schema.Message}funcGetToolUseRunnable()(compose.Runnable[map[string]any,*schema.Message],error){sg:=compose.NewGraph[map[string]any,*schema.Message](compose.WithGenLocalState(func(ctx context.Context)*state{return&state{Messages:make([]*schema.Message,0)}}))ctx:=context.Background()model,err:=GetModel()iferr!=nil{returnnil,err}tools:=GetBaiDuMapTool(ctx,[]string{MapServer})toolNode,err:=compose.NewToolNode(ctx,&compose.ToolsNodeConfig{Tools:tools,})iferr!=nil{returnnil,err}toolsInfo,err:=genToolInfos(ctx,tools)iferr!=nil{returnnil,err}model,err=model.WithTools(toolsInfo)iferr!=nil{returnnil,err}modelPreHandle:=func(ctx context.Context,input[]*schema.Message,state*state)([]*schema.Message,error){state.Messages=append(state.Messages,input...)returnstate.Messages,nil}toolsNodePreHandle:=func(ctx context.Context,input*schema.Message,state*state)(*schema.Message,error){ifinput==nil{returnstate.Messages[len(state.Messages)-1],nil// used for rerun interrupt resume}state.Messages=append(state.Messages,input)returninput,nil}makeAnswerTemplate:=DraftCodeTemplate()sg.AddChatTemplateNode("MakeAnswerTemplate",&makeAnswerTemplate,compose.WithNodeName("MakeAnswerTemplate"))sg.AddChatModelNode("MakeAnswerModel",model,compose.WithNodeName("MakeAnswerModel"),compose.WithStatePreHandler(modelPreHandle))sg.AddToolsNode("ToolsNode",toolNode,compose.WithNodeName("ToolsNode"),compose.WithStatePreHandler(toolsNodePreHandle))sg.AddChatModelNode("Synthesis",model,compose.WithNodeName("Synthesis"),compose.WithStatePreHandler(modelPreHandle))sg.AddEdge(compose.START,"MakeAnswerTemplate")sg.AddEdge("MakeAnswerTemplate","MakeAnswerModel")sg.AddEdge("MakeAnswerModel","ToolsNode")sg.AddEdge("ToolsNode","Synthesis")sg.AddEdge("Synthesis",compose.END)reflectionRunnable,err:=sg.Compile(context.Background())returnreflectionRunnable,err}

最终实现了如下的graph

MakeAnswerTemplate ->MakeAnswerModel ->ToolsNode ->Synthesis

handler的作用

可以看到在调用模型及工具之前写了两个handler,作用都是追加对话历史,如果没有这两个handler会出现什么问题呢?
工具调用完整,进行总结的时候 模型仅仅拿到tool call的结果,但是他不知道自己是谁,不知道自己该干什么
所以这里通过两个prehandler对state进行修改,实现对话记录在全节点上的透传

小坑

  1. 没有prehandler会导致最后输出的结果很奇怪

  2. 调用WithTools方法进行工具和模型的绑定时,这个方法会返回新的model,注意看官方的函数说明
    // WithTools returns a new ToolCallingChatModel instance with the specified tools bound. // This method does not modify the current instance, making it safer for concurrent use.

    运行结果

    工具调用结果

    最终结果

http://www.cnnetsun.cn/news/51634.html

相关文章:

  • 如何通过AutoGPT生成高质量技术博客为GPU算力引流
  • 多目标蜣螂优化算法NSDBO:微电网多目标优化调度的利器
  • 本研究基于分形纤维丛统一场论,构建了黑洞时空的几何模型,揭示了奇点消解、霍金辐射修正及信息守恒的新机制。该模型的优势在于将宏观时空的广义相对论效应与微观量子的分形特性实现了有机融合。
  • 好写作AI语言侦探:你的论文严谨性“隐形把关人”
  • 解放双手!钉钉智能打卡神器完全上手手册
  • DMXAPI全球模型API调用完全指南:从入门到精通
  • 告别“翻墙“烦恼:DMXAPI让Gemini-3-pro-thinking调用快如闪电
  • leetcode 744. Find Smallest Letter Greater Than Target 寻找比目标字母大的最小字母-耗时100%
  • Home Assistant通知系统:3步打造智能家居提醒中心
  • 学Simulink——机器人轨迹跟踪场景实例:基于Simulink的永磁同步电机笛卡尔空间圆弧轨迹跟踪仿真
  • 【毕业设计/课程设计】基于Java的高校学科竞赛平台的设计与实现/源码+论文+PPT+数据
  • java计算机毕业设计摄影爱好者交流平台 基于SpringBoot的影像作品分享与互动社区 摄影圈层社交与作品点评一体化平台
  • “AI 写的论文,参考文献靠谱吗?”—— 虎贲等考 AI 给出答案:所有参考文献均来自知网、维普,全程可查、合规可溯
  • 2025年AI降重工具深度评测:10款零风险智能改写方案(askpaper与aibiiye实测)
  • java计算机毕业设计社团管理系统 高校学生社团数字化运营平台 校园社团协同管理与活动发布系统
  • 缩短启动时间的定制支持成为采用关键——持续选用Silex希来科无线模块逾十年~
  • NAT技术和链路层概述
  • 数据库约束
  • Blender主题定制终极指南:如何快速打造个性化界面
  • 【无标题】web第三周
  • Holo1.5开源:小模型颠覆UI智能交互,企业级AI代理成本骤降80%
  • 如何快速掌握umy-ui:面向Vue开发者的终极性能优化指南
  • 【流程】——若依项目前后端打包发布到服务器
  • Velero压缩引擎深度解析:从架构原理到实战调优
  • DolphinScheduler 2025技术生态:从零开始掌握分布式调度系统
  • 5大WebGPU错误终极解决方案:让WebLLM硬件加速不再失败
  • 一步成图革命:OpenAI一致性模型如何重塑2025生成式AI生态
  • GDevelop游戏引擎终极指南:从零基础到专业开发全流程
  • 生成对抗网络创建测试数据
  • java计算机毕业设计社区医疗服务管理系统 街区智慧健康服务管理平台 基层医疗信息综合管理系统