LlamaIndex 实现 React Agent

React Agent 是指 LLM 对问题自行推理并调用外部工具解决问题,如下图所示,通过一些推理步骤最终找到想要的答案。

LlamaIndex 提供了实现 React Agent 的框架,通过框架可以轻松的实现上图中的步骤。那么,如果不用 LlamaIndex 应该如何实现一个 Agent 呢?首先,需要将需要调用的外部 API 和问题提供给LLM,LLM 判断得到结果是否需要调用API,如果需要调用,将 API 名称和参数相关信息返回到应用端,应用端执行API 并将结果再次传给 LLM,LLM 再次判断是否需要调用外部工具,这是个循环的过程,直到 LLM 得到答案。通过代码,分析一下 LlamaIndex 是如何实现 ReactAgent 多轮对话的。

用 LlamaIndex 实现 ReactAgent 代码如下:

from llama_index.core.agent import ReActAgent
from llama_index.llms.openai import OpenAI
from llama_index.core.tools import BaseTool, FunctionTool

from utils import init_model

import sys, os
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..', 'parent_directory')))


def multiply(a: int, b: int) -> int:
    """Multiply two integers and returns the result integer"""
    return a * b


multiply_tool = FunctionTool.from_defaults(fn=multiply)

def add(a: int, b: int) -> int:
    """Add two integers and returns the result integer"""
    return a + b


add_tool = FunctionTool.from_defaults(fn=add)


init_model()


agent = ReActAgent.from_tools([multiply_tool, add_tool], verbose=True)

response = agent.chat("What is 20+(2*4)? Calculate step by step ")

实现 Agent 主要通过 FunctionTool 和 ReactAgent,分别看一下两个类的主要作用。

FunctionTool

FunctionTool 用来定义外部工具,包括 Function 的详细信息,功能描述、入参和出参等信息,通过跟踪可以看到,代码首先创建了两个 FunctionTool,ToolMetadata 定义了工具的详细信息。


ReactAgent

创建 ReactAgent,传入 tools、llm,max_iteration 是指最大推理次数,默认为 10 次。

调用 self._react_chat_formatter 准备提示词,提示词准备完成之后,调用 LLM大模型进行处理。

解析大模型返回结果并调用对应 Function。

每一步的结果都会存储在 Memory 中,作为历史在下一步中传给 LLM 进行处理。

总结

LlamaIndex 通过提示词将问题与工具进行关联,通过多轮推理得到最终答案。核心还是在提示词,无论 RAG 还是 Agent,都是作为桥梁,底层逻辑还是通过提示词的方式把大模型的能力外部应用能力打通并进行整合。

相关推荐
Neo Wordsworth27 分钟前
通义灵码在Visual Studio上
windows·ai·visual studio
aiwisland4 小时前
亲测好用,ChatGPT 3.5/4.0新手使用手册~
人工智能·ai·语言模型·chatgpt·ai编程·ai写作
virtaitech1 天前
OrionX vGPU 研发测试场景下最佳实践之Jupyter模式
ide·人工智能·python·ai·jupyter·ai算力·ai算力资源池化
佛州小李哥1 天前
沉浸式体验和评测Meta最新超级大语言模型405B
人工智能·机器学习·ai·语言模型·云计算·aws·亚马逊云科技
营赢盈英2 天前
Trying to install openai in chaquopy in android studio but getting build failed
android·ide·ai·android studio·openai api·chaquopy
老艾的AI世界2 天前
AI老照片修复神器,Anole下载介绍
图像处理·人工智能·深度学习·神经网络·目标检测·机器学习·ai·老照片上色·老照片修复·ai老照片修复
安冬的码畜日常2 天前
Humanize AI 简介
人工智能·ai·文本生成·内容生成·ai检测
豌豆花下猫2 天前
Python 潮流周刊#69:是时候停止使用 Python 3.8了(摘要)
后端·python·ai
人工智能培训咨询叶梓2 天前
全球和局部精细化:提升大模型推理能力的新方法
人工智能·数学·ai·语言模型·自然语言处理·多模态·推理
陈敬雷-充电了么-CEO兼CTO2 天前
自然语言处理系列六十八》搜索引擎项目实战》搜索引擎系统架构设计
人工智能·gpt·搜索引擎·ai·自然语言处理·chatgpt·aigc