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

LangChain 23 Agents中的Tools用于增强和扩展智能代理agent的功能

LangChain系列文章

  1. LangChain 实现给动物取名字,
  2. LangChain 2模块化prompt template并用streamlit生成网站 实现给动物取名字
  3. LangChain 3使用Agent访问Wikipedia和llm-math计算狗的平均年龄
  4. LangChain 4用向量数据库Faiss存储,读取YouTube的视频文本搜索Indexes for information retrieve
  5. LangChain 5易速鲜花内部问答系统
  6. LangChain 6根据图片生成推广文案HuggingFace中的image-caption模型
  7. LangChain 7 文本模型TextLangChain和聊天模型ChatLangChain
  8. LangChain 8 模型Model I/O:输入提示、调用模型、解析输出
  9. LangChain 9 模型Model I/O 聊天提示词ChatPromptTemplate, 少量样本提示词FewShotPrompt
  10. LangChain 10思维链Chain of Thought一步一步的思考 think step by step
  11. LangChain 11实现思维树Implementing the Tree of Thoughts in LangChain’s Chain
  12. LangChain 12调用模型HuggingFace中的Llama2和Google Flan t5
  13. LangChain 13输出解析Output Parsers 自动修复解析器
  14. LangChain 14 SequencialChain链接不同的组件
  15. LangChain 15根据问题自动路由Router Chain确定用户的意图
  16. LangChain 16 通过Memory记住历史对话的内容
  17. LangChain 17 LangSmith调试、测试、评估和监视基于任何LLM框架构建的链和智能代理
  18. LangChain 18 LangSmith监控评估Agent并创建对应的数据库
  19. LangChain 19 Agents Reason+Action自定义agent处理OpenAI的计算缺陷
  20. LangChain 20 Agents调用google搜索API搜索市场价格 Reason Action:在语言模型中协同推理和行动
  21. LangChain 21 Agents自问自答与搜索 Self-ask with search
  22. LangChain 22 LangServe用于一键部署LangChain应用程序
    在这里插入图片描述

1. tools 用于增强和扩展Agents

在Langchain框架中,tools是一种重要的组件,用于增强和扩展智能代理(agent)的功能。这些tools提供了一系列附加能力,使得代理可以执行特定的任务,处理复杂的数据类型,或与外部服务进行交互。以下是对Langchain中tools的详细解释:
在这里插入图片描述

定义和作用

  • 定义tools在Langchain中指的是可以被智能代理用来执行特定操作或任务的功能模块或服务。
  • 作用:这些工具使得代理不仅限于其内置的语言处理能力,还可以执行更复杂的任务,如数据分析、图像处理、网络搜索等。

类型和示例

  1. 数据处理工具:用于处理和分析数据,如数据清洗、格式转换、统计分析等。
  2. 搜索工具:使代理能够进行网络搜索,获取信息或回答查询。
  3. 交互工具:用于提高与用户的交互效果,如自然语言理解、情感分析等。
  4. API集成:允许代理与外部API进行交互,获取或发送数据。

实现方式

  • 集成tools通常通过API或特定的编程接口集成到Langchain框架中。
  • 配置:开发者可以根据需要配置和定制tools,以适应特定的应用场景。

应用场景

  • 多功能代理:使用tools扩展代理的能力,让其能处理更多类型的任务。
  • 特定任务:针对特定的业务需求或技术挑战,定制相应的tools
  • 用户体验:通过交互和数据处理工具,提高代理与用户互动的质量和效果。

优势和局限性

  • 优势:提供灵活性和扩展性,使代理能够适应多种不同的任务和场景。
  • 局限性:依赖外部服务或数据源可能带来安全性和可靠性方面的考虑。

结论

Langchain中的tools为开发者提供了一种强大的方式来增强智能代理的功能和适用范围。通过合理地选择和配置这些工具,可以创建出能够处理复杂任务、提供丰富交互体验的高效智能代理。然而,开发者需要考虑到集成外部工具的安全性和稳定性,确保整体系统的可靠运行。

2. Langchain的tools的arxiv

在Langchain中,arxiv是一种特定的工具(tool),用于与Arxiv API进行交互。Arxiv API是一个公开的接口,允许用户访问Arxiv数据库中的大量科学论文和出版物。下面是对arxiv工具的详细介绍:

Arxiv API Wrapper

  • 功能ArxivAPIWrapper是一个封装器(wrapper),它简化了与Arxiv API的交互,使得在Langchain中可以方便地获取论文信息。
  • 用途:通过这个工具,Langchain智能代理可以查询Arxiv数据库,获取特定论文的信息,如标题、作者、摘要、发表日期等。

使用方式

  • 初始化:首先,需要创建ArxivAPIWrapper的实例。这通常在初始化智能代理时通过load_tools函数完成。
  • 查询:可以通过传递论文的唯一标识符(如arXiv ID)来查询特定论文的详细信息。

示例应用

  • 论文摘要获取:可以获取指定论文的摘要,用于了解论文的主要内容和贡献。
  • 作者信息查询:可以检索特定作者的发布论文列表或其研究领域。
  • 论文搜索:支持按关键词或其他条件搜索相关论文。

优点

  • 直接访问:提供了直接访问科学论文数据库的便利,方便在智能代理中嵌入学术研究的功能。
  • 自动化信息检索:可以自动化地检索和处理大量学术数据,提高效率。

使用场景

  • 学术研究辅助:用于帮助研究人员快速找到相关的学术资料。
  • 教育和学习:在教育应用中,可以用于获取特定领域的最新研究成果。

注意事项

  • 版权和使用限制:在使用Arxiv API获取的数据时,需要遵守相关的版权和使用条款。
  • 数据准确性:虽然Arxiv提供的是学术论文,但用户在使用这些信息时仍需自行判断其准确性和可靠性。

总的来说,Langchain中的arxiv工具提供了一个方便的接口,让智能代理能够轻松访问和利用Arxiv上的丰富学术资源。

3. 代码实现

读取paper 的信息 Large Language Models
在这里插入图片描述

Tools/chat_tools_arxiv.py这段代码主要用于演示如何使用Langchain结合OpenAI聊天模型和Arxiv API来获取论文相关的信息。代码中包含了从加载环境变量、初始化智能代理到使用API获取数据的完整流程。

from langchain.llms import OpenAI  # 导入Langchain库的OpenAI模块,提供与OpenAI模型的交互功能
from langchain.prompts import PromptTemplate  # 导入用于创建和管理提示模板的模块
from langchain.chains import LLMChain  # 导入用于构建基于大型语言模型的处理链的模块
from dotenv import load_dotenv  # 导入dotenv库,用于从.env文件加载环境变量,管理敏感数据如API密钥
from langchain.chat_models import ChatOpenAI  # 导入用于创建和管理OpenAI聊天模型的类
from langchain.agents import AgentType, initialize_agent, load_tools  # 导入用于初始化智能代理和加载工具的函数
from langchain.utilities import ArxivAPIWrapper  # 导入Arxiv API的包装器,用于与Arxiv数据库交互load_dotenv()  # 调用dotenv函数加载.env文件中的环境变量llm = ChatOpenAI(temperature=0.0)  # 创建一个温度参数为0.0的OpenAI聊天模型实例,温度0意味着输出更确定性
tools = load_tools(["arxiv"])  # 加载Arxiv工具,以便代理可以访问Arxiv数据库信息agent_chain = initialize_agent(tools,llm,agent=AgentType.ZERO_SHOT_REACT_DESCRIPTION,verbose=True,  # 初始化一个智能代理,使用零次学习的方式来根据描述做出反应
)paper = "2307.05782"
response = agent_chain.run("请描述论文的主要内容 " + paper)  # 运行代理链,获取指定论文ID的内容描述
print(response)  # 打印论文描述的响应arxiv = ArxivAPIWrapper()
docs = arxiv.run(paper)  # 使用Arxiv API获取特定论文的详细信息
print(docs)  # 打印论文的详细信息author = arxiv.run("Michael R. Douglas")  # 使用Arxiv API获取指定作者的信息
print(author)  # 打印作者信息nondocs = arxiv.run("1605.08386WWW")  # 尝试使用一个非标准格式的ID来获取信息,可能无法正确检索
print(nondocs)  # 打印这次非标准检索的结果

运行结果如下

(develop)⚡ % python Tools/chat_tools_arxiv.py                            ~/Workspace/LLM/langchain-llm-app> Entering new AgentExecutor chain...
I need to find the main content of the paper with the given arXiv ID.
Action: arxiv
Action Input: 2307.05782
Observation: Published: 2023-10-06
Title: Large Language Models
Authors: Michael R. Douglas
Summary: Artificial intelligence is making spectacular progress, and one of the best
examples is the development of large language models (LLMs) such as OpenAI's
GPT series. In these lectures, written for readers with a background in
mathematics or physics, we give a brief history and survey of the state of the
art, and describe the underlying transformer architecture in detail. We then
explore some current ideas on how LLMs work and how models trained to predict
the next word in a text are able to perform other tasks displaying
intelligence.
Thought:The main content of the paper is about large language models, specifically focusing on the development of OpenAI's GPT series. It provides a history and survey of the state of the art, describes the transformer architecture, and explores current ideas on how LLMs work and their ability to perform various tasks displaying intelligence.
Final Answer: The main content of the paper is about large language models, with a focus on OpenAI's GPT series and their underlying transformer architecture.> Finished chain.
The main content of the paper is about large language models, with a focus on OpenAI's GPT series and their underlying transformer architecture.
(develop)⚡ % python Tools/chat_tools_arxiv.py                            ~/Workspace/LLM/langchain-llm-app
Published: 2023-10-06
Title: Large Language Models
Authors: Michael R. Douglas
Summary: Artificial intelligence is making spectacular progress, and one of the best
examples is the development of large language models (LLMs) such as OpenAI's
GPT series. In these lectures, written for readers with a background in
mathematics or physics, we give a brief history and survey of the state of the
art, and describe the underlying transformer architecture in detail. We then
explore some current ideas on how LLMs work and how models trained to predict
the next word in a text are able to perform other tasks displaying
intelligence.
(develop)⚡ % python Tools/chat_tools_arxiv.py                            ~/Workspace/LLM/langchain-llm-app
Published: 2006-02-24
Title: Understanding the landscape
Authors: Michael R. Douglas
Summary: Based on comments made at the 23rd Solvay Conference, December 2005,
Brussels.Published: 2005-08-09
Title: Random algebraic geometry, attractors and flux vacua
Authors: Michael R. Douglas
Summary: This is a submission to the Encyclopedia of Mathematical Physics (Elsevier,
2006) and conforms to its referencing guidelines.Published: 2001-05-02
Title: D-Branes and N=1 Supersymmetry
Authors: Michael R. Douglas
Summary: We discuss the recent proposal that BPS D-branes in Calabi-Yau
compactification of type II string theory are Pi-stable objects in the derived
category of coherent sheaves.
(develop)⚡ % python Tools/chat_tools_arxiv.py                            ~/Workspace/LLM/langchain-llm-app
No good Arxiv Result was found

4. 根据给定的描述或指令理解并执行任务ZERO_SHOT_REACT_DESCRIPTION

Langchain中的ZERO_SHOT_REACT_DESCRIPTION是一种用于定义和构建智能代理(agent)的方法,属于Langchain框架中的一个组件。它专注于实现代理的“零次学习”(zero-shot learning)能力,即在没有针对具体任务进行专门训练的情况下,根据描述直接做出反应和处理问题。下面详细解释这个概念:

零次学习(Zero-Shot Learning)

  • 定义:零次学习是一种机器学习方法,使得模型能够处理它在训练阶段没有直接见过的任务或数据。这种方法依赖于模型对问题的一般理解和处理能力。
  • 应用:在Langchain中,这意味着智能代理可以根据描述直接处理各种问题,而不需要针对每种问题进行单独的训练。

Langchain中的ZERO_SHOT_REACT_DESCRIPTION

  • 作用:这个模式使得代理能够根据给定的描述或指令理解并执行任务。代理会使用其内置的语言模型来解析和响应问题。
  • 实现:通常,这涉及到使用大型语言模型(如GPT系列)来解析自然语言描述,并根据这些描述生成回应或执行操作。
  • 优势:这种方法的优势在于灵活性和广泛的适用性,代理不需要对每一种特定的任务类型进行训练即可应对新问题。
  • 局限性:然而,由于它依赖于模型的通用理解能力,可能在特定、复杂或非常专业化的任务上不如专门训练的模型准确。

应用场景

  • 多功能代理:能够处理各种类型的查询和任务,如信息检索、简单的数据分析、生成文本等。
  • 快速适应新任务:在新场景或对新类型的问题作出响应时,不需要额外的训练或配置。

结论

ZERO_SHOT_REACT_DESCRIPTION在Langchain中为开发者提供了一种构建能够处理多种任务的通用智能代理的方法。这种方法特别适合于快速开发和部署、需要高度灵活性和广泛适用性的应用场景。然而,对于需要高度专业化或极端精确度的任务,可能需要考虑其他更专门化的解决方案。

代码

https://github.com/zgpeace/pets-name-langchain/tree/develop

参考

https://python.langchain.com/docs/integrations/tools/arxiv

相关文章:

LangChain 23 Agents中的Tools用于增强和扩展智能代理agent的功能

LangChain系列文章 LangChain 实现给动物取名字,LangChain 2模块化prompt template并用streamlit生成网站 实现给动物取名字LangChain 3使用Agent访问Wikipedia和llm-math计算狗的平均年龄LangChain 4用向量数据库Faiss存储,读取YouTube的视频文本搜索I…...

VS2015编译GDAL3.2.0+opencl+C#

参考借鉴https://www.cnblogs.com/litou/p/15004877.html 参考借鉴https://www.cnblogs.com/xiaowangba/p/6313903.html 参考借鉴gdal、proj、geos、sqlite等在VS2015下编译和配置_vs2015编译sqlite3-CSDN博客 参考借鉴Windows下GDAL3.1.2编译 (VS2015)_gdal windows编译-CS…...

3、Linux_系统用户管理

1.Linux 用户管理 1.1概述 Linux系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。root用户是系统默认创建的管理员账号。 1.2添加用户 语法 useradd […...

C语言指针详解上

1 野指针 int main01(){//野指针就是没有初始化的指针,指针的指向是随机的,不可以 操作野指针//int a 0;//指针p保存的地址一定是定义过的(向系统申请过的)int *p;//野指针*p 200;printf("%d\n",*p);system("pause");return 0;}2 空指针 空指针的作用…...

力扣面试150题 | 27.移除元素

力扣面试150题 | 27.移除元素 题目描述解题思路代码实现复杂度分析 题目描述 27.移除元素 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 不要使用额外的数组空间,你必…...

JAVA 通过get,post访问远程接口

get请求 参数拼接在url ?namevalue&sexvalue // httpurlhttp:127.0.0.1/project public static String doGet(String httpurl){HttpURLConnection connection nul;Inputstream is null;BufferedReader br null;String result null;//返回结果字…...

Spark例子

Spark例子 以下是一个简单的AI Spark例子: 假设我们有一个数据集,包含房屋大小、卧室数量和售价。我们想使用Spark来预测房屋售价。 首先,我们需要导入所需的库和数据。在这个例子中,我们将使用Pyspark。 python from pyspark…...

linux下ls和df卡死

1. strace看下卡在哪里 https://lokie.wang/article/43 strace ls strace df -h 2. 原因 https://segmentfault.com/a/1190000040620740 3. fuser 和 umount都不行,最后只能重启 重启机器还起不来了垃圾...

iOS(swiftui)——系统悬浮窗( 可在其他应用上显示,可实时更新内容)

因为ios系统对权限的限制是比较严格的,ios系统本身是不支持全局悬浮窗(可在其他app上显示)。在iphone14及之后的iPhone机型中提供了一个叫 灵动岛的功能,可以在手机上方可以添加一个悬浮窗显示内容并实时更新,但这个功能有很多局限性 如:需要iPhone14及之后的机型且系统…...

css弹窗动画效果,示例弹窗从底部弹出

从底部弹出来,有过渡动画效果 用max-height可以自适应内容的高度,当内容会超过最大高度时可以在弹窗里加个scroll-view 弹窗不能用v-if来隐藏,不然transition没效果,transition只能对已有dom元素起效果,所以用透明和v…...

STM32CubeIDE(CUBE-MX hal库)----RTC时钟,时钟实时显示

系列文章目录 STM32CubeIDE(CUBE-MX hal库)----初尝点亮小灯 STM32CubeIDE(CUBE-MX hal库)----按键控制 STM32CubeIDE(CUBE-MX hal库)----串口通信 STM32CubeIDE(CUBE-MX hal库)----定时器 STM32CubeIDE(CUBE-MX hal库)----蓝牙模块HC-05(详细配置) 前言…...

ubuntu 安装Nvidia驱动

官网下载 sudo bash NVIDIA。。。。。跟着b站机器人工匠阿杰即可。...

『亚马逊云科技产品测评』活动征文|基于亚马逊云EC2搭建PG开源数据库

授权声明:本篇文章授权活动官方亚马逊云科技文章转发、改写权,包括不限于在 Developer Centre, 知乎,自媒体平台,第三方开发者媒体等亚马逊云科技官方渠道 亚马逊EC2云服务器(Elastic Compute Cloud)是亚马…...

【开题报告】基于J2EE的高校水电费管理系统的设计与实现

1.选题背景 随着高校规模的扩大和信息化建设的深入,学生宿舍的水电费管理成为一项复杂而重要的任务。传统的水电费管理方式通常依赖于人工操作,存在着管理效率低下、数据处理繁琐、费用统计不准确等问题。因此,设计和实现一款基于J2EE的高校…...

Revisiting Proposal-based Object Detection阅读笔记

Revisiting Proposal-based Object Detection阅读笔记 论文地址:link Abstract For any object detector, the obtained box proposals or queries need to be classified and regressed towards ground truth boxes. 对于任何物体检测器来说,获得的…...

Docker部署NFS服务

创建基础镜像 mkdir /data/nfs -p chmod 755 /data/nfs# NFS默认端口: 111、2049、20048 docker run -d \ --privileged \ --name nfs_server \ -p 111:111/tcp \ -p 111:111/udp \ -p 2049:2049/tcp \ -p 2049:2049/udp \ -p 30001-30005:30001-30005/tcp \ -p 30001-30005:3…...

深度学习TensorFlow2基础知识学习后半部分

介绍几个重要操作: 1.范数 a tf.fill([1,2], value2.) b tf.norm(a)# 二范数#第二种计算方法 # 计算验证 a tf.square(a) log("a的平方:", a) a tf.reduce_sum(a) log("a平方后的和:", a) b tf.sqrt(a) log("a平方和后开根号:"…...

电脑系统重装Win10专业版操作教程

用户想给自己的电脑重新安装上Win10专业版系统,但不知道具体的重装步骤。接下来小编将详细介绍Win10系统重新安装的步骤方法,帮助更多的用户完成Win10专业版的重装,重装后用户即可体验到Win10专业版系统带来的丰富功能。 准备工作 1. 一台正常…...

打包Python项目

打包Python项目 本教程将指导您如何打包一个简单的Python项目。它将 向您展示如何添加必要的文件和结构来创建包,如何 构建包,以及如何将其上传到Python包索引(PyPI)。 尖端 如果您在运行本教程中的命令时遇到问题,请…...

使用Python实现爬虫IP负载均衡和高可用集群

做大型爬虫项目经常遇到请求频率过高的问题,这里需要说的是使用爬虫IP可以提高抓取效率,那么我们通过什么方法才能实现爬虫IP负载均衡和高可用集群,并且能快速的部署并且完成爬虫项目。 通常在Python中实现爬虫ip负载均衡和高可用集群需要一…...

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...

在软件开发中正确使用MySQL日期时间类型的深度解析

在日常软件开发场景中,时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志,到供应链系统的物流节点时间戳,时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库,其日期时间类型的…...

地震勘探——干扰波识别、井中地震时距曲线特点

目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...

java_网络服务相关_gateway_nacos_feign区别联系

1. spring-cloud-starter-gateway 作用:作为微服务架构的网关,统一入口,处理所有外部请求。 核心能力: 路由转发(基于路径、服务名等)过滤器(鉴权、限流、日志、Header 处理)支持负…...

【WiFi帧结构】

文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...

通过Wrangler CLI在worker中创建数据库和表

官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...

家政维修平台实战20:权限设计

目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色&#xf…...

Linux云原生安全:零信任架构与机密计算

Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...

pikachu靶场通关笔记22-1 SQL注入05-1-insert注入(报错法)

目录 一、SQL注入 二、insert注入 三、报错型注入 四、updatexml函数 五、源码审计 六、insert渗透实战 1、渗透准备 2、获取数据库名database 3、获取表名table 4、获取列名column 5、获取字段 本系列为通过《pikachu靶场通关笔记》的SQL注入关卡(共10关&#xff0…...