Dify 内置了两种 Agent 策略:Function Calling 和 ReAct,但二者有什么区别呢?在使用时又该如何选择呢?接下来我们一起来看。

1.Function Calling

Function Call 会通过将用户指令映射到预定义函数或工具,LLM 先识别用户意图,再决定调用哪个函数并提取所需参数。

它的核心是调用外部函数或工具,属于一种明确的工具调用机制

优点

  • 精确:对于明确的任务,可以直接调用相应的工具,无需复杂的推理过程。
  • 易于集成外部功能可以将各种外部 API 或工具封装成函数供模型调用。
  • 结构化输出:模型输出的是结构化的函数调用信息,方便下游节点处理。
  • 执行效率高:对于简单、明确的任务,执行速度快。

缺点

  • 如果任务定义不明确或用户意图模糊,LLM 可能难以准确选择工具或提取参数。
  • 对于需要多轮推理才能确定调用哪个工具的任务,不够灵活。

适用场景

  • 需要根据用户意图精确调用特定工具的自动化任务。
  • 需要与外部 API 或服务进行交互的场景。
  • 数据检索、信息查询并以特定格式呈现的应用

2.ReAct

ReAct=Reason+Act,推理+行动,LLM 首先思考当前状态和目标,然后选择并调用合适的工具,工具的输出结果又将引导 LLM 进行下一步的思考和行动,如此循环,直到问题解决。

举例说明

举个例子,正常情况下,当我们在计算一个商品的价格时,它的执行步骤是这样的:

  1. 查询商品原价。
  2. 计算商品优惠价。
  3. 计算商品最终价格=商品原价-优惠价。

但某个商品情况比较特殊,它在以上第二步中存储的不是优惠价,而是折扣价(例如 8 折优惠),那么此时商品的最终价格的计算公式就变成了以下方式:

  1. 查询商品原价。
  2. 查询商品折扣价。
  3. 计算商品最终价格=商品原价 X 商品折扣价。

在这种情况下就要使用 ReAct 策略了,因为 ReAct 策略会根据第二步的观测结果,分析并改变第三步的计算公式,保证任务的精准执行,这种情况下就要使用 React 策略。

核心机制

  • ReAct 是一个迭代过程,LLM 在“思考(Reason)-> 行动(Act)-> 观察(Observe)”的循环中逐步推进任务。
  • LLM 首先分析当前状态和目标,选择并调用工具,然后根据工具的输出进行下一步的思考和行动,直到问题解决。

优点

  • 利用外部信息:可以有效使用外部工具来收集模型单独无法处理的任务所需的信息。
  • 可解释性好:推理和行动步骤交织在一起,允许一定程度上跟踪 Agent 的过程。
  • 广泛适用性:适用于需要外部知识或特定行动的任务,例如问答、信息检索和任务执行。
  • 灵活性高:对于复杂、多步骤的任务,以及需要探索和动态调整策略的场景,具有更好的适应性。

缺点

  • 执行速度和成本:由于涉及多次 LLM 调用,ReAct 通常比 Function Calling 更慢,并且消耗更多的 tokens。
  • 推理稳定性:在很大程度上取决于 LLM 的推理能力以及提示(Instruction)的质量。
  • 输出解析复杂:ReAct 过程中 LLM 产生的“思考”文本格式可能不一致,给解析和提取关键信息带来挑战。

适用场景

  • 需要进行探索性研究、从多个来源收集和综合信息的任务。
  • 问题解决方案路径不明确,需要通过迭代尝试和调整来找到答案的复杂问题。
  • 需要较高可解释性,希望了解 Agent 决策过程的场景。

3.Function Calling VS React

Function Calling 和 React 区别如下:

  • Function Calling 更适合简单、明确的任务,强调直接调用工具的高效性。
  • ReAct 更适合复杂、多步骤的任务,强调推理过程的灵活性和可解释性。

本文已收录到我的技术小站 www.javacn.site,其中包含的内容有:Spring AI、LangChain4j、Dify、AI Agent、MCP、Function Call、RAG、向量数据库、Prompt、多模态、向量数据库、嵌入模型等内容。

AI智能体策略FunctionCalling和ReAct有什么区别?的更多相关文章

  1. 伯克利推出「看视频学动作」的AI智能体

    伯克利曾经提出 DeepMimic框架,让智能体模仿参考动作片段来学习高难度技能.但这些参考片段都是经过动作捕捉合成的高度结构化数据,数据本身的获取需要很高的成本.而近日,他们又更进一步,提出了可以直 ...

  2. 揭秘阿里云WAF背后神秘的AI智能防御体系

    背景 应用安全领域,各类攻击长久以来都危害着互联网上的应用,在web应用安全风险中,各类注入.跨站等攻击仍然占据着较前的位置.WAF(Web应用防火墙)正是为防御和阻断这类攻击而存在,也正是这些针对W ...

  3. TensorFlow利用A3C算法训练智能体玩CartPole游戏

    本教程讲解如何使用深度强化学习训练一个可以在 CartPole 游戏中获胜的模型.研究人员使用 tf.keras.OpenAI 训练了一个使用「异步优势动作评价」(Asynchronous Advan ...

  4. DRL 教程 | 如何保持运动小车上的旗杆屹立不倒?TensorFlow利用A3C算法训练智能体玩CartPole游戏

    本教程讲解如何使用深度强化学习训练一个可以在 CartPole 游戏中获胜的模型.研究人员使用 tf.keras.OpenAI 训练了一个使用「异步优势动作评价」(Asynchronous Advan ...

  5. 多智能体系统(MAS)简介

    1.背景   自然界中大量个体聚集时往往能够形成协调.有序,甚至令人感到震撼的运动场景,比如天空中集体翱翔的庞大的鸟群.海洋中成群游动的鱼群,陆地上合作捕猎的狼群.这些群体现象所表现出的分布.协调.自 ...

  6. 【SerpentAI:Python开源游戏智能体开发框架——相比OpenAI Universe可导入自己的游戏、可脱离Docker/VNC运行】

    https://weibo.com/fly51fly?from=myfollow_all&is_all=1#1514439335614 [SerpentAI:Python开源游戏智能体开发框架 ...

  7. AI智能外呼机器人网络拓扑结构笔记

    最近开发了一套AI智能外呼机器人系统,系统主要有3部分组成:web管理平台:呼叫机器人:SIP软交换.具体网络拓扑结构如下图: 三部分主要功能如下: 1.web管理平台:话术管理.任务管理.线路管理. ...

  8. STM32W108无线传感器网络节点自组织与移动智能体导航技术

    使用STM32W108无线开发板及节点完毕大规模网络的自组建,网络模型选择树型,网络组建完毕之后,使用基于接收信号强度指示RSSI(ReceivedSignal Strength Indication ...

  9. 用电销机器人让电销企业迈入AI智能时代

    2019年是AI智能快速发展的一年,有非常多的企业已经用AI智能代替原有的传统员工做重复性高的工作,就拿销售行业来说,为了让电销员工提升工作效率,拥有更多的成单,大部分有电销岗位的公司都会把重复率较高 ...

  10. 基于ROBO-MAS多智能体自主协同 高频投影定位系统

随机推荐

  1. Week09_day05(Java API操作Hbase)

    package com.wyh.HbaseAPI; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hbas ...

  2. Coordinate Spaces

    Coordinate Spaces 本主题包含以下部分: 根空间 用户空间 像素空间 任何VisionPro图像支持一系列坐标空间,以提供一个数值框架来表达特定特征的位置.最有用的空间是根空间,它将点 ...

  3. sql server 2017 STRING_AGG() 替代方案

    SELECT @StuId='"'+STRING_AGG(Id,'","')+'"'FROM( SELECT 'a'+cast(Id as varchar) I ...

  4. 不止排名,Google SEO 10 大核心心得分享

    原博客:https://bysocket.com/seo-tips-2025/ 在过去的一年中,我深入实践了 Google SEO,积累了自己一些经验和看法.以下是我的实操心得,希望对大家有所帮助. ...

  5. ppt 字少怎么办

    1.加图标 2.加色块 3.加图片 最终效果

  6. bp安装+匹配规则(防止抓火狐的多余包)

    bp安装使用 BurpLoaderKeygen.jar: 2c8c7b95640f31985f83580402f26a06b78c55877fa33ef1f9d14d2ebb2d8ecd burpsu ...

  7. 用DeepSeek+可灵AI+剪映制作哪吒2走T台秀AI视频 (保姆级教程)

    内容首发周老师的付费社群,挑其中部分内容免费同步给公号读者 今天给大家分享如何利用DeepSeek这类AI工具,制作哪吒2走T台秀视频,保姆级的制作方法,简单易懂,小白也能轻松上手. 关键操作,分为四 ...

  8. 超级详细的mysql数据库安装指南

    https://zhuanlan.zhihu.com/p/37152572 2,073 人赞同了该文章 如果你的电脑是mac,参考社群会员 @奔跑的土豆 的分享: mac下mysql的安装步骤 227 ...

  9. 基础指令:mkdir、ls、cd、pwd、touch、rm、mv、cp、echo、cat、关机与重启

    目录 1. 创建目录 2. 查看目录内容 3. 进入指定目录(传送) 4. 显示当前所在位置 5. 创建文件 6. 删除文件或目录 7. 移动文件 8. 复制文件或目录 9. echo输出信息到屏幕 ...

  10. 出现TypeError: float() argument must be a string or a number, not _NoValueType(机器学习 Win11)

    博客地址:https://www.cnblogs.com/zylyehuo/ 如果出现以下报错 则说明是torch.numpy等库的版本不匹配 可以去以下网站寻找匹配的版本 https://mirro ...