大模型从入门到应用——LangChain:代理(Agents)-[计划与执行]

分类目录:《大模型从入门到应用》总目录

LangChain系列文章:


计划与执行代理通过首先规划要做的事情,然后执行子任务来实现目标。这个想法在很大程度上受到了BabyAGI以及《Plan-and-Solve》论文的启发。

  • 规划几乎总是由一个LLM(语言模型)来完成。
  • 执行通常由一个单独的代理(配备工具)来完成。
csharp 复制代码
# 导入模块
from langchain.chat_models import ChatOpenAI
from langchain.experimental.plan_and_execute import PlanAndExecute, load_agent_executor, load_chat_planner
from langchain.llms import OpenAI
from langchain import SerpAPIWrapper
from langchain.agents.tools import Tool
from langchain import LLMMathChain

# 工具
search = SerpAPIWrapper()
llm = OpenAI(temperature=0)
llm_math_chain = LLMMathChain.from_llm(llm=llm, verbose=True)
tools = [
    Tool(
        name = "Search",
        func=search.run,
        description="useful for when you need to answer questions about current events"
    ),
    Tool(
        name="Calculator",
        func=llm_math_chain.run,
        description="useful for when you need to answer questions about math"
    ),
]

# 规划器(Planner)、执行器(Executor)和代理(Agent)
model = ChatOpenAI(temperature=0)
planner = load_chat_planner(model)
executor = load_agent_executor(model, tools, verbose=True)
agent = PlanAndExecute(planner=planner, executor=executor, verbose=True)

# 执行示例
agent.run("Who is Leo DiCaprio's girlfriend? What is her current age raised to the 0.43 power?")
Entering new PlanAndExecute chain...
steps=[Step(value="Search for Leo DiCaprio's girlfriend on the internet."), Step(value='Find her current age.'), Step(value='Raise her current age to the 0.43 power using a calculator or programming language.'), Step(value='Output the result.'), Step(value="Given the above steps taken, respond to the user's original question.\n\n")]

日志输出:

复制代码
日志输出:
Entering new AgentExecutor chain...
Action:

```{
  "action": "Search",
  "action_input": "Who is Leo DiCaprio's girlfriend?"
}```


Observation: DiCaprio broke up with girlfriend Camila Morrone, 25, in the summer of 2022, after dating for four years. He's since been linked to another famous supermodel -- Gigi Hadid. The power couple were first supposedly an item in September after being spotted getting cozy during a party at New York Fashion Week.
Thought:Based on the previous observation, I can provide the answer to the current objective. 
Action:
```{
  "action": "Final Answer",
  "action_input": "Leo DiCaprio is currently linked to Gigi Hadid."
}```


Finished chain.
*****

Step: Search for Leo DiCaprio's girlfriend on the internet.

Response: Leo DiCaprio is currently linked to Gigi Hadid.

Entering new AgentExecutor chain...
Action:
```{
  "action": "Search",
  "action_input": "What is Gigi Hadid's current age?"
}```

Observation: 28 years
Thought:Previous steps: steps=[(Step(value="Search for Leo DiCaprio's girlfriend on the internet."), StepResponse(response='Leo DiCaprio is currently linked to Gigi Hadid.'))]

Current objective: value='Find her current age.'

Action:
```{
  "action": "Search",
  "action_input": "What is Gigi Hadid's current age?"
}```


Observation: 28 years
Thought:Previous steps: steps=[(Step(value="Search for Leo DiCaprio's girlfriend on the internet."), StepResponse(response='Leo DiCaprio is currently linked to Gigi Hadid.')), (Step(value='Find her current age.'), StepResponse(response='28 years'))]

Current objective: None

Action:
```{
  "action": "Final Answer",
  "action_input": "Gigi Hadid's current age is 28 years."
}```



Finished chain.
*****

Step: Find her current age.

Response: Gigi Hadid's current age is 28 years.

Entering new AgentExecutor chain...
Action:
```{
  "action": "Calculator",
  "action_input": "28 ** 0.43"
}```


Entering new LLMMathChain chain...
28 ** 0.43
```text28 ** 0.43```
...numexpr.evaluate("28 ** 0.43")...

Answer: 4.1906168361987195
Finished chain.

Observation: Answer: 4.1906168361987195
Thought:The next step is to provide the answer to the user's question.

Action:
```{
  "action": "Final Answer",
  "action_input": "Gigi Hadid's current age raised to the 0.43 power is approximately 4.19."
}```



Finished chain.
*****

Step: Raise her current age to the 0.43 power using a calculator or programming language.

Response: Gigi Hadid's current age raised to the 0.43 power is approximately 4.19.

Entering new AgentExecutor chain...
Action:
```{
  "action": "Final Answer",
  "action_input": "The result is approximately 4.19."
}```


Finished chain.
*****

Step: Output the result.

Response: The result is approximately 4.19.

Entering new AgentExecutor chain...
Action:
```{
  "action": "Final Answer",
  "action_input": "Gigi Hadid's current age raised to the 0.43 power is approximately 4.19."
}```


Finished chain.
*****

Step: Given the above steps taken, respond to the user's original question.



Response: Gigi Hadid's current age raised to the 0.43 power is approximately 4.19.
Finished chain.

输出:

复制代码
"Gigi Hadid's current age raised to the 0.43 power is approximately 4.19."

参考文献:

1\] LangChain官方网站:https://www.langchain.com/ \[2\] LangChain 🦜️🔗 中文网,跟着LangChain一起学LLM/GPT开发:https://www.langchain.com.cn/ \[3\] LangChain中文网 - LangChain 是一个用于开发由语言模型驱动的应用程序的框架:http://www.cnlangchain.com/

相关推荐
河南博为智能科技有限公司7 分钟前
RS485转以太网串口服务器-串口设备联网的理想选择
大数据·服务器·人工智能·单片机·嵌入式硬件·物联网
算家计算21 分钟前
英伟达谷歌打响“太空算力争夺战”,下一战场竟是星辰大海?
人工智能·芯片·资讯
HyperAI超神经37 分钟前
在线教程丨端侧TTS新SOTA!NeuTTS-Air基于0.5B模型实现3秒音频克隆
人工智能·深度学习·机器学习·音视频·tts·音频克隆·neutts-air
wwwzhouhui41 分钟前
2025年11月1日-AI 驱动教学革命:3 分钟生成专业级动画课件,还能导出视频 GIF!
人工智能·音视频·ai动画教学
国科安芯1 小时前
抗辐照MCU芯片在无人叉车领域的性能评估与选型建议
网络·人工智能·单片机·嵌入式硬件·安全
用户5191495848451 小时前
原型污染攻击工具揭秘:Prototype Pollution Gadgets Finder
人工智能·aigc
钢蛋1 小时前
LangChain v1.0 的 Agents:让 AI 真正"动起来"
langchain
VXHAruanjian8881 小时前
以智促效,释放创新力量,RPA助力企业全面自动化变革
大数据·人工智能
Godspeed Zhao1 小时前
自动驾驶中的传感器技术76——Navigation(13)
人工智能·机器学习·自动驾驶
CoovallyAIHub1 小时前
首届AI交易大赛对决!中国模型包揽冠亚军,GPT-5亏损62%垫底
人工智能·google·数据分析