LangChain实现自主代理(Autonomous Agents)

news2025/1/11 20:07:54

LangChain实现自主代理(Autonomous Agents)

  • LangChain实现自主代理(Autonomous Agents)
    • 简介
    • 核心技术
    • 让 AI 使用工具的案例
      • 使用搜索引擎
      • 使用知识库

Here’s the table of contents:

LangChain实现自主代理(Autonomous Agents)

简介

  自主代理(Autonomous Agents)是由人工智能驱动的程序,当给定目标时,它们能够为自己创建任务,完成任务,创建新任务,重新确定任务列表的优先级,完成新的顶级任务,循环(递归的思想)直到达到目标。

  可以给自主代理(Autonomous Agents)一个任务,比如发一个关于自主代理(Autonomous Agents)研究最新进展的邮件。他会先去理解分解这个任务目标,然后设定实施计划以及这几个计划的优先级,同时去辩证『冷静』的反思计划有没有漏洞,并将反思应用到执行过程中,然后就是自己不断的去换着关键词搜索总结最近的报道文章,然后是汇总、反思,看看有没有什么遗漏,最后组织成适合邮件的语言格式自动发送。

自主代理是如何运行的

核心技术

  1. LLMs(大语言模型):LLMs是最核心的能力,无论推理还是问答以及后续的Prompt工程,都强依赖于LLM的能力。

  2. Memory(上下文记忆):缓存任务的中间状态、保存会话的上下文信息,用于后续任务的处理。

  3. Prompt Engineering(提示工程):提供给LLMs使用的提示信息。

  4. Tools(工具箱):自主代理(Autonomous Agents)用来处理子任务的插件。

  5. 递归的思想:使自主代理(Autonomous Agents)完全自主的核心设计思想。
    autogpts building autogpts building autogpts building...

让 AI 使用工具的案例

  下面是基于LangChain实现的AutoGPT类程序,可以让智能代理程序完成使用搜索引擎本地知识库等工具的功能。

使用搜索引擎

  下面的案例展示了一个自主代理(Autonomous Agents)使用 GPT3.5 和工具箱(Tools)解决问题的运行过程。在这个案例中定义的可以使用的工具为数学计算工具(llm-math)Google搜索工具(serpapi)Agents拿到问题后拆分为下面四个子任务:
   1. 找到经理名称,Action Input: “易方达基金总经理”。
   2. 找到经理年龄,Action Input: “易方达基金总经理刘晓艳 年龄”。
   3. 年龄运行数学计算,Action Input: 42^0.76。
   4. 整合各个子任务结果信息并生成答案。
前三个子任务逐个解决后,最后一个任务负责将答案进行整合输出一个完整的回复。


QA:易方达基金的总经理是谁?他今年的年龄是多少?他年龄的0.76次方是多少?

AGENTS:
Entering new AgentExecutor chain…
I need to find out the name of the manager and his age
Action: Search
Action Input: “易方达基金总经理”
Observation: 易方达基金总经理刘晓艳:以专业精神与投资者长期长情常相伴- 媒体报道- 易方达基金管理有限公司
Thought: I need to find out the age of the manager

Action: Search
Action Input: “易方达基金总经理刘晓艳 年龄”
Observation: 用总裁助理兼市场部总经理刘晓艳(女)的话说:她是一个很公正、很铁面无私的人,很适合做督察长的职务。 张南的台面上摆着三个电脑显示器,据她介绍, …
Thought: I need to calculate the age to the 0.76 power

Action: Calculator
Action Input: 42^0.76
Observation: Answer: 17.126533197047873
Thought: I now know the final answer

Final Answer: 易方达基金总经理刘晓艳今年42岁,他年龄的0.76次方是17.126533197047873。

Finished chain.

备注:需要注意的是上面的回答,易方达基金总经理刘晓艳的年龄得到的结果是错误的【这种问题也可以结合本地知识库来优化】。

使用知识库

  下面的案例展示了一个自主代理(Autonomous Agents)使用 GPT3.5 和工具箱(Tools)解决问题的运行过程。在这个案例中定义的可以使用的工具为知识图谱查询工具(cypher_search)Agents拿到问题后拆分为下面三个子任务:
   1. 生成知识图谱查询代码Cypher。
   2. 从知识图谱获取相关信息。
   3. 整合结果信息并生成答案。


QA:嘉实物流产业基金,定位属于哪类基金?

Entering new AgentExecutor chain…
{
“action”: “Cypher search”,
“action_input”: “嘉实物流产业基金属于哪类基金?”
}

Entering new LLMCypherGraphChain chain…
Generated Cypher statement:
MATCH p0=(n2:投资类型)<-[r1:投资类型]-(n0:基金产品)-[r0:基金中文简称]->(n1:基金中文简称)-[r2:别名]->(n3:基金中文简称别名)
WHERE n3.value=‘嘉实物流产业基金’ RETURN n2.value AS value;

Finished chain.

Observation: 投资类型:股票型
Thought:{
“action”: “Final Answer”,
“action_input”: “嘉实物流产业基金投资类型属于股票型。”
}

Final Answer: 嘉实物流产业基金投资类型属于股票型。

Finished chain.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/534053.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【A*算法——清晰解析 算法逻辑——算法可以应用到哪些题目】例题1.第K短路 例题2.

A*算法 A*算法是什么例题1. 第K短路题意解析 例题2. 八数码 欢迎观看我的博客&#xff0c;如有问题交流&#xff0c;欢迎评论区留言&#xff0c;一定尽快回复&#xff01;&#xff08;大家可以去看我的专栏&#xff0c;是所有文章的目录&#xff09;   文章字体风格&#xff1…

初识Linux:第四篇

初识Linux&#xff1a;第四篇 初识Linux&#xff1a;第四篇1.配置自己的公网ip2.时间相关的指令3.cal指令4.find指令5.grep指令6.zip/unzip指令7.tar指令8.bc命令9.uname -r指令10.一些其他热键11.关机12.shell命令以及运行原理 总结 初识Linux&#xff1a;第四篇 &#x1f449…

华为OD机试真题 Java 实现【最佳对手】【2023Q1 200分】

一、题目描述 游戏里面&#xff0c;队伍通过匹配实力相近的对手进行对战。但是如果匹配的队伍实力相差太大&#xff0c;对于双方游戏体验都不会太好。 给定 n 个队伍的实力值&#xff0c;对其进行两两实力匹配&#xff0c;两支队伍实例差距在允许的最大差距 d内&#xff0c;则…

深度学习之迁移学习

数据增强 数据太少可能会过拟合。 # data_transforms中指定了所有图像预处理&#xff08;变换&#xff09;操作&#xff08;图像数据增强&#xff09; data_transforms {train: transforms.Compose([transforms.RandomRotation(45), # 随机旋转&#xff0c;-45到45度之间随…

本地测试使用自签名证书以开启网站https(例子说明:Nginx、Tomcat)

文章目录 数字证书简介工作原理证书链获取SSL证书和自签名证书前提条件创建根 CA 证书1.生成 RSA 私钥2.生成根证书签名请求&#xff08;CSR&#xff09;3.生成自签根证书 创建服务器证书1.创建服务器 RSA 私钥2.创建 CSR&#xff08;证书签名请求&#xff09;3.使用 CSR 和私钥…

Requestly工具快速提升前端开发与测试的效率

痛点 前端测试 在进行前端页面开发或者测试的时候&#xff0c;我们会遇到这一类场景&#xff1a; 在开发阶段&#xff0c;前端想通过调用真实的接口返回响应在开发或者生产阶段需要验证前端页面的一些 异常场景 或者 临界值 时在测试阶段&#xff0c;想直接通过修改接口响应来…

字节跳动的网络工程师,是什么神仙存在?

大家好&#xff0c;我是老杨。 要是说起网络工程师的待遇天花板&#xff0c;你觉得会是什么样的&#xff1f; 在2022年&#xff0c;互联网大厂虽然裁了很多人&#xff0c;但却刺激了更多人想要进入大厂&#xff0c;一探究竟。 就从网工这个岗位来说&#xff0c;你说大小厂的…

Linux文本三剑客之awk)

Linux文本三剑客之awk 一、awk的简介二、awk的工作原理三、命令格式四、实例1、按行输出文本2、BEGIN模式和END模式3、按字段输出文本4、通过管道&#xff0c;双引号调用shell命令5、date的用法6、getline的用法7、awk数组 一、awk的简介 awk是一种处理文本文件的语言&#xf…

C++STL——哈希

哈希 unordered系列关联式容器unordered_set与unordered_mapset VS unordered_set 底层结构哈希概念与哈希冲突哈希冲突的解决闭散列——开放定址法开散列——哈希桶 模拟实现unordered_set与unordered_map其他哈希函数哈希的应用哈希切割&#xff08;面试题&#xff09;位图位…

如何把容器变成物理机

如何把容器变成物理机 本文的主题是把容器变成物理机&#xff0c;根据所学的知识。以及通过各种搜索引擎。他们都告诉我们&#xff0c;这是不可能的。这真的是不可能的吗&#xff1f;我不信&#xff0c;那我就要创造奇迹。请继续往下看。本文将教你如何把容器变成物理机。 这…

java多线程_01

文章目录 1. 线程的概念1. 程序2. 进程3. 线程4. Java程序的运行原理5. 并发与并行概念1. 并发2. 并行3. 并发编程和并行编程 2. Java中的Thread线程类1. Thread类构造方法2. Thread类普通方法3. Thread类静态方法4. Thread类特殊方法 3.线程的创建方式1. 继承Thread类2. 实现R…

C++ 仿函数(一)

目录 一、仿函数是什么&#xff1f; 二、仿函数的特点 1.仿函数在使用时&#xff0c;可以像普通函数那样调用, 可以有参数&#xff0c;可以有返回值 2.仿函数超出普通函数的概念&#xff0c;可以有自己的状态 ​编辑3.仿函数可以作为参数传递。 三、谓词 一元谓词示例&a…

38【源码】数据可视化:基于 Echarts + Python 动态实时大屏 - 全国图书零售监测数据

效果图展示 1.动态效果演示 2.静态切片效果图 一、确定需求方案 1.确定产品上线部署的屏幕LED分辨率 本案例基于16:9 屏宽比&#xff0c;F11全屏显示。 2.部署方式 浏览器打开播放&#xff0c;Chrome浏览器、360浏览器等。 二、整体架构设计 前端基于 Echarts开源库设计…

leetcode27.移除元素

个人主页&#xff1a;平行线也会相交 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 平行线也会相交 原创 收录于专栏【LeetCode】 &#x1f353;希望我们一起努力、成长&#xff0c;共同进步。 &#x1f449;题目链接 题目描述 给你一个数组 nums 和一个…

从0开始学习数据库(持续更新)

一个数据库最重要的部分是什么&#xff1f; 关系型数据库mysql有着四大特性&#xff0c;原子性&#xff0c;隔离性&#xff0c;一致性&#xff0c;持久性。 kv数据库有着原子性&#xff0c;持久性&#xff0c;弱一致性。 可见&#xff0c;不管数据库的存储引擎是什么&#xff0…

LeetCode_递归_中等_138.复制带随机指针的链表

目录 1.题目2.思路3.代码实现&#xff08;Java&#xff09; 1.题目 给你一个长度为 n 的链表&#xff0c;每个节点包含一个额外增加的随机指针 random&#xff0c;该指针可以指向链表中的任何节点或空节点。 构造这个链表的深拷贝。 深拷贝应该正好由 n 个全新节点组成&#…

vector源码解析及扩容优化

一、vector源码解析 没有任何一个东西可以在原地扩充&#xff0c;因为要了一块内存后&#xff0c;后面这块内存有可能被使用了&#xff0c;或者能不能用也不知道。链表可以保留原有节点&#xff0c;再将指针指向别处开辟的新内存&#xff0c;但这个也不算原地扩充。 对于vecto…

不需要等待列表,也不用魔法上网的Claude,能否比肩ChatGPT?

近期&#xff0c;国外Anthropic公司发布了Claude聊天机器人&#xff0c;堪比ChatGPT的最大竞争对手。一经推出&#xff0c;市场上就经常拿它俩来对比&#xff0c;因为推出Claude产品的Anthropic 公司是由多位前OpenAI前员工组成&#xff0c;两家公司&#xff0c;以及他们推出的…

ssm框架之SpringMVC:乱码问题

一种修改tomcat配置文件 如果tomcat乱码修改Tomcat的conf的server.xml文件加上 URIEncoding“UTF-8” 添加一个URIEncoding“UTF-8” tomcat 如果7.0 不这样设置&#xff0c;无论get还是post后台都显示乱码。tomcat如果是8.0版本&#xff0c;只有post后台显示是乱码 一种过滤…

Redis进阶

主要内容 Redis持久化Redis主从Redis哨兵Redis分片集群 Redis持久化 Redis有两种持久化的方案: RDB持久化AOF持久化 1. RDB持久化 RDB全称Redis Database Backup file&#xff08;Redis数据备份文件&#xff09;&#xff0c;也被叫做Redis数据快照。简单来说就是把内存中的所…