国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

你要的 AI Agent 工具都在這里

人工智能
本文主要聊了AI Agent的工具規范,以及常用工具。AI Agent只有借助工具才能發揮威力。

只有讓LLM(大模型)學會使用工具,才能做出一系列實用的AI Agent,才能發揮出LLM真正的實力。本篇,我們讓AI Agent使用更多的工具,比如:外部搜索、分析CSV、文生圖、執行代碼等。

一、使用工具的必要性

LLM(大模型)如果沒有使用工具的能力,那就相當于一個有著聰明大腦 但四肢僵硬的 漸凍人,什么事兒也做不了。人類之所以區別于動物,正是因為學會了使用工具。因此,賦予LLM使用工具的能力至關重要。

我們需要 LLM去幫助執行各種任務。而Tool(工具)就是LLM 在執行任務過程中,能夠調用的外部能力。比如:需要檢索外部資料時,可以調用檢索工具;需要執行一段代碼時,可以調用自定義函數去執行。

二、LangChain的Tool規范

所有的工具肯定要遵守一套規范,才能讓LLM隨意調用。為此,LangChain 抽象出一個Tool 層,只要是遵守這套規范的函數就是 Tool 對象,就可以被 LLM調用。

1. Tool規范

Tool的規范也簡單,只要有三個屬性就行:name、description和function。

  • name:工具的名稱。
  • description:對工具的功能描述,后續這個描述文本會添加到Prompt(提示詞)中,LLM 將根據description來決定是否調用該工具。
  • function:此工具實際運行的函數。

只要遵守這個規范就行,使用形式可以有多種,下文的實踐代碼會介紹到。

2. Agent使用工具的流程

讓AI Agent使用工具,需要定義Agent和AgentExecutor。AgentExecutor維護了Tool.name到Tool的Map 結構。

LLM根據Prompt(包含了Tool的描述) 和  用戶的問題,判斷是否需要調用工具,確定某個工具后,在根據Tool的名稱 和 調用參數,到映射Map 中獲找Tool實例,找到之后調用Tool實例的function。

三、如何使用各種Tool

自定義Tool只需要遵守以上規范就可以,下面以幾個常用的工具做示例。

下文有些工具用到了toolkits。toolkits是LangChain提供的工具包,旨在簡化使用工具的成本,toolkits里提供了豐富的工具,還在不斷疊加,大部分的工具都可以在里面找到。

1. 外部搜索

使用外部搜索工具。本文使用的是serpapi,serpapi集成了Google、百度等多家搜索引擎,通過api的形式調用,非常方便。

官網地址:https://serpapi.com/。可以自行注冊,有一些免費額度。外部搜索工具定義如下:

# 1. 使用@tool裝飾器,定義搜索工具
@tool
def search(query: str) -> str:
    """只有在需要了解實時信息 或 不知道的事情的時候 才會使用這個工具,需要傳入要搜索的內容。"""
    serp = SerpAPIWrapper()
    result = serp.run(query)
    return result

2. 文生圖

文生圖工具是使用LangChain社區提供的DallEAPIWrapper類,本文使用OpenAI的圖片生成模型Dall-E-3,具體代碼如下:

# 2. 使用Tool工具類,定義圖片生成工具
dalle_image_generator = Tool(
    name="基于OpenAI Dall-E-3的圖片生成器",
    func=DallEAPIWrapper(model="dall-e-3").run,
    description="OpenAI DALL-E API 的包裝器。當你需要根據 描述的文本 生成圖像時 使用此工具,需要傳入 對于圖像的描述。",
)

這里的DallEAPIWrapper(model="dall-e-3").run方法就是個函數,實際是去調用了OpenAI的接口。

3. 代碼執行器

代碼執行器工具,可以執行代碼 或者 根據自然語言生成代碼。主要使用LangChain提供的PythonREPLTool 和 LangChain提供的toolkits。

比如create_python_agent就簡化了創建Python解釋器工具的過程。代碼如下:

# 3. 使用toolkit,定義執行Python代碼工具
python_agent_executor = create_python_agent(
    llm=model,
    tool=PythonREPLTool(),
    verbose=True,
    agent_executor_kwargs={"handle_parsing_errors": True},
)

4. 分析CSV

CSV工具,用來分析csv文件。依舊是使用toolkits工具包里的create_csv_agent函數快出創建工具。代碼如下:

# 4. 使用toolkit,定義分析CSV文件工具
csv_agent_executor = create_csv_agent(
    llm=model,
    path="course_price.csv",
    verbose=True,
    agent_executor_kwargs={"handle_parsing_errors": True},
    allow_dangerous_code=True,
)

5. 完整代碼

上面介紹了AI Agent的常用工具,定義好工具之后,在把工具放入到工具集中,最后在定義Agent 和 AgentExecutor就算完成了。短短幾十行代碼,就可以讓LLM使用這么多工具了。

完整代碼如下:

import os
from langchain import hub
from langchain_openai import ChatOpenAI
from langchain.agents import create_structured_chat_agent, AgentExecutor, Tool
from langchain.tools import BaseTool, StructuredTool, tool
from langchain_experimental.agents.agent_toolkits import (
    create_python_agent,
    create_csv_agent,
)
from langchain_community.utilities import SerpAPIWrapper
from langchain_experimental.tools import PythonREPLTool
from langchain_community.utilities.dalle_image_generator import DallEAPIWrapper

# 需要先安裝serpapi, pip install serpapi, 還需要到 https://serpapi.com/ 去注冊賬號

# SERPAPI_API_KEY 和 OPENAI 相關密鑰,注冊到環境變量
os.environ["SERPAPI_API_KEY"] = (
    "9dd2b2ee429ed996c75c1daf7412df16336axxxxxxxxxxxxxxx"
)
os.environ["OPENAI_API_KEY"] = "sk-a3rrW46OOxLBv9hdfQPBKFZtY7xxxxxxxxxxxxxxxx"
os.environ["OPENAI_API_BASE"] = "https://api.302.ai/v1"

model = ChatOpenAI(model_name="gpt-3.5-turbo")


# 基于reAct機制的Prompt模板
prompt = hub.pull("hwchase17/structured-chat-agent")



# 各種方式定義工具

# 1. 使用@tool裝飾器,定義搜索工具
@tool
def search(query: str) -> str:
    """只有在需要了解實時信息 或 不知道的事情的時候 才會使用這個工具,需要傳入要搜索的內容。"""
    serp = SerpAPIWrapper()
    result = serp.run(query)
    return result


# 2. 使用Tool工具類,定義圖片生成工具
dalle_image_generator = Tool(
    name="基于OpenAI Dall-E-3的圖片生成器",
    func=DallEAPIWrapper(model="dall-e-3").run,
    description="OpenAI DALL-E API 的包裝器。當你需要根據 描述的文本 生成圖像時 使用此工具,需要傳入 對于圖像的描述。",
)

# 3. 使用toolkit,定義執行Python代碼工具
python_agent_executor = create_python_agent(
    llm=model,
    tool=PythonREPLTool(),
    verbose=True,
    agent_executor_kwargs={"handle_parsing_errors": True},
)

# 4. 使用toolkit,定義分析CSV文件工具
csv_agent_executor = create_csv_agent(
    llm=model,
    path="course_price.csv",
    verbose=True,
    agent_executor_kwargs={"handle_parsing_errors": True},
    allow_dangerous_code=True,
)

# 定義工具集合
tool_list = [
    search,
    dalle_image_generator,
    Tool(
        name="Python代碼工具",
        description="""
        當你需要借助Python解釋器時,使用這個工具。
        比如當你需要執行python代碼時,
        或者,當你想根據自然語言的描述生成對應的代碼時,讓它生成Python代碼,并返回代碼執行的結果。
        """,
        func=python_agent_executor.invoke,
    ),
    Tool(
        name="CSV分析工具",
        description="""
        當你需要回答有關course_price.csv文件的問題時,使用這個工具。
        它接受完整的問題作為輸入,在使用Pandas庫計算后,返回答案。
        """,
        func=csv_agent_executor.invoke,
    ),
]


# 將工具丟給Agent
agent = create_structured_chat_agent(
    llm=model,
    tools=tool_list,
    prompt=prompt
)

# 定義AgentExecutor
agent_executor = AgentExecutor.from_agent_and_tools(
    agent=agent, 
    tools=tool_list, 
    verbose=True, # 打印詳細的 選擇工具的過程 和 reAct的分析過程
    handle_parsing_errors=True
)



# 不會使用工具
agent_executor.invoke({"input": "你是誰?"})

# 使用查詢工具
# agent_executor.invoke({"input": "南京今天的溫度是多少攝氏度?現在外面下雨嗎?"})

# 使用Python代碼工具
# agent_executor.invoke(
#     {
#         "input": """
#         幫我執行```號里的python代碼,
        
#         ```python
            
#             def add(a,b):
#                 return a+b
            
#             print("hello world : ", add(100,200))
#         ```
#         """
#     }
# )

# 使用圖片生成工具
# agent_executor.invoke(
#     {
#         "input": "幫我生成一副圖片,圖片描述如下:一個非常忙碌的中國高中生在準備中國的高考,夜已經很深了,旁邊他的媽媽一邊看書一邊在陪伴他,窗外是模糊的霓虹燈。"
#     }
# )

# 使用CSV分析工具
# agent_executor.invoke({"input": "course_price數據集里,一共有哪幾個城市?用中文回答"})

一起看下使用工具后,reAct的整個過程。

以上代碼經過完整調試,更換下openai和serpapi的密鑰即可直接運行。

責任編輯:趙寧寧 來源: 程序員半支煙
相關推薦

2017-10-24 14:57:58

AI人工智能機器學習

2021-12-09 08:16:40

JVM參數系統

2025-05-16 09:34:10

2018-11-25 20:41:03

2020-06-02 07:00:00

會話安全黑客攻擊

2017-08-29 11:21:03

微軟

2018-04-26 16:15:02

數據庫MySQLMySQL 8.0

2018-03-19 14:43:28

2021-07-01 09:00:00

安全數字化轉型滲透

2021-02-01 08:39:26

JTAG接口Jlink

2019-11-04 09:07:48

DevOps互聯網IT

2020-04-03 15:09:54

iPhone SE蘋果手機

2021-05-17 07:04:07

動態代理面試

2021-07-19 08:33:56

時間復雜度大O

2020-12-08 11:08:55

時間復雜度軟件

2023-09-11 08:51:23

LinkedList雙向鏈表線程

2023-12-11 21:59:01

時序分析深度學習自回歸模型

2021-06-17 13:40:47

區塊鏈比特幣公有鏈

2021-10-06 16:21:32

類型對象Typescript

2017-12-26 15:24:18

智慧停車大數據停車場
點贊
收藏

51CTO技術棧公眾號

亚洲伦理中文字幕| 成人免费观看www在线| 久久综合一区| 午夜老司机在线观看| 色综合久久九月婷婷色综合| 久久久精品视频在线观看| 国产精品9999久久久久仙踪林| 从欧美一区二区三区| 久久伊人免费视频| 一本一道波多野毛片中文在线| 91久色porny| 中文字幕av日韩精品| 国内精品久久久久久久97牛牛| 精品国产伦一区二区三区观看方式| 亚洲 自拍 另类小说综合图区| 自拍亚洲一区| 精品视频—区二区三区免费| 国产一级二级在线| 懂色中文一区二区在线播放| 国产美女久久精品香蕉69| h片在线观看下载| 亚洲国产日韩在线一区模特| 影音先锋亚洲视频| 欧美阿v一级看视频| 欧美激情精品久久久久久| 英国三级经典在线观看| 欧美日韩视频在线观看一区二区三区| 四虎最新地址发布| 欧美国产日本视频| 久久久久狠狠高潮亚洲精品| 久久99精品久久只有精品| 蜜桃av噜噜一区二区三| 激情综合自拍| 亚洲综合在线小说| 久久99免费视频| 97在线精品国自产拍中文| 欧美日韩精品一区二区三区视频| 精品人在线二区三区| 国产丝袜在线观看视频| 日韩欧美中文字幕一区| 日本在线免费看| 精品国产免费人成电影在线观看四季 | 四虎影院一区二区| 在线成人h网| 精品欧美日韩在线| 国产日韩欧美一区| 亚洲精品蜜桃久久久久久| 成人免费黄色在线| 国产第一页视频| 欧美色道久久88综合亚洲精品| 户外极限露出调教在线视频| 欧美一区二区三区男人的天堂| 二区三区四区高清视频在线观看| 日韩精品一区二区在线| 性欧美18~19sex高清播放| 精品国产青草久久久久福利| 一本大道色婷婷在线| 亚洲系列中文字幕| caoporn成人| 波多野结衣精品久久| 久久精品国产一区二区三区免费看| 欧洲精品一区二区三区久久| 中文字幕制服丝袜一区二区三区| 污污的网站在线观看| 亚洲国产日韩精品在线| 久久精品福利| 99re6在线| 久久综合九色综合欧美98| 亚洲精品少妇久久久久久| 国产一区二区三区在线观看视频 | 国产精品久99| 国产黄色在线观看| 久久久久久久久久久国产| 亚洲欧美偷拍自拍| 轻点好疼好大好爽视频| 色欧美片视频在线观看| 91精品日本| 日本一区二区三区四区高清视频 | 日韩欧美综合在线| 欧美激情电影| 中国黄色片免费看| 国产丝袜一区二区三区免费视频 | 国产婷婷精品av在线| 国产成人天天5g影院在线观看 | 高清免费电影在线观看| 国产精品夜间视频香蕉| 欧美视频一区二区三区四区 | 国产福利a级| 一区二区三区中文在线观看| 岛国大片在线播放| 在线精品国产| 国产999精品久久久影片官网| 狠狠入ady亚洲精品经典电影| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 国产精品1区2区3区| 爱情岛论坛亚洲入口| 国产乱色国产精品免费视频| 分分操这里只有精品| 亚洲激情另类| 国产精品swag| 一本久道综合久久精品| 日本高清久久天堂| 日韩精品永久网址| 免费在线观看羞羞视频| 欧美成人蜜桃| 91精品国产91久久久| 色综合天天综合网国产成人综合天 | 簧片在线免费看| 欧美日韩国产高清一区二区三区| 葵司免费一区二区三区四区五区| 国产精品迅雷| 国产日本在线播放| 成人a在线视频| 精品网站999www| 久久影院午夜论| 国产精品一区二区av交换| 一级毛片免费观看| 女同一区二区| 国模叶桐国产精品一区| 欧美色欧美亚洲另类二区| 国产资源在线一区| 久久精品影视| 爱看av在线| 亚洲欧美国产中文| 国产一区二区不卡视频在线观看| 久久久av一区| 欧美日韩免费在线视频| 久久一二三国产| 国产精品99一区二区三| 涩涩涩在线视频| 国产精品青青草| 亚洲精品一卡二卡| 羞羞答答一区二区| 欧美视频在线播放一区| 色999日韩国产欧美一区二区| 久久精品99久久无色码中文字幕| 国产原创中文在线观看| 91 com成人网| 亚洲国产日韩欧美一区二区三区| 成人美女大片| 男男激情在线| 国产专区中文字幕| 男女视频网站在线观看| 国产偷国产偷亚洲高清97cao| 欧美老女人性视频| 亚洲一区二区久久| 亚洲图片欧美色图| 日本aⅴ亚洲精品中文乱码| 国产精品任我爽爆在线播放| 毛片电影在线| 国产一二三区在线视频| 99在线免费观看| 日韩日韩日韩日韩日韩| 国产一区二区视频在线免费观看| 欧美精品免费播放| 欧美激情免费看| 欧美激情精品久久久久| 午夜精品在线观看| 欧美激情亚洲视频| 日本高清久久天堂| 久久久中文字幕| 久久久久国产一区二区三区| 中日韩美女免费视频网址在线观看| 亚洲欧洲一区二区三区久久| 亚洲欧洲一区二区三区在线观看| 日韩午夜中文字幕| 亚洲欧美中文日韩在线| 日韩欧美的一区| 欧美mv日韩mv| 精品国一区二区三区| 成人午夜小视频| 视频在线91| 日本精品三区| 一区二区三区精密机械公司| 久久精品中文字幕| 轻点好疼好大好爽视频| 国产精品69xx| 久久精品三级| 欧美肥妇毛茸茸| 99r国产精品视频| 又黄又爽在线观看| 日韩三级久久| www久久精品| 日韩在线小视频| 男人添女人下部视频免费| 欧洲黄色一区| 性欧美猛交videos| 国产人与zoxxxx另类91| 日本大胆欧美人术艺术动态| 亚洲人午夜精品天堂一二香蕉| 欧美丝袜第三区| www欧美日韩| 日韩精品久久久| 午夜影院观看视频免费| 91探花在线观看| 亚洲欧美一区在线| 一区二区视频免费在线观看| 社区色欧美激情 | 99久久精品免费看国产一区二区三区 | 亚洲天堂免费观看|