Datawhale AI冬令营(第二期)动手学AI Agent--Task3:学Agent工作流搭建,创作进阶Agent

目录

一、工作流:制作复杂Agent的福音!

二、支付宝百宝箱中工作流介绍

三、设计工作流

3.1 准备功能模块

3.2组合工作流

3.3 模块测试需要注意什么

3.4迭代优化

四、高中学习小助手工作流设计

4.1 选题调研

4.2 功能模块设计

4.3 组合完整工作流

4.4 模块测试

4.5 应用发布与体验


一、工作流:制作复杂Agent的福音!

通过前面的学习大家已经可以制作一些agent应用,但大家可能会发现,好像就是一个Prompt工程,好像并没有完成Agent整体框架的搭建?是不是缺点什么?

可以回顾一下,Lilian Weng定义的Agent结构图

可以回顾一下,Lilian Weng定义的Agent结构图

所以,这一节我们将通过 工作流 拼上 agent开发 的完整拼图 —— 把 记忆、工具调用、步骤规划等 丝滑地结合、搭建起来!工作流开发模式的加入,对于agent开发来说是一个里程碑事件。支付宝百宝箱支持通过低代码模式,把原先代码开发的任务转换成节点的拼接,省去了编写代码的烦恼。不同的节点组合也能让agent具备更强大的功能。

在支付宝百宝箱里你可以无限使用夸克搜索、知识库、代码、分支等 插件或节点(可以理解为通用的内置功能模块) 组合和套娃 ,实现复杂功能!

图一、工作流示例

二、支付宝百宝箱中工作流介绍

需要新建工作流模式的应用

这里和创建其他应用一致,点击新建应用就可以创建一个工作流。

图二、界面介绍

  • 左上角是题目区域,大家可以随时修改

  • 旁边是设置任务类型的地方,目前有任务模式、对话模式两种。但是设置了对话模式就切不回来咯请大家注意。

这里任务模式是指完成某项任务,不会重复对话。对话模式指用户可以多轮对话与 Agent做交互。

  • 左侧这个区域是节点区域,将工作流需要的功能模块化列在这里。下面我们会对节点一一介绍。

  • 最中间部分区域是工作流的画布,你可以在这个区域将节点拖拽到画布中,然后使用节点连线将节点们串起来。

注意,创作时必须有开始节点和结束节点,而且开始和结束节点是唯一的。开始节点只能往出引节点连线,而结束节点只能接受节点连线,中间的节点必须有出入连线,如果没有出入节点连线,设计的节点就不会被使用。这里大家可以理解为画电路图,有出和入电路才会通路。

  • 右上角有一部分是画布调整区域,可以放大缩小等。

  • 最右上角是运行和发布区域,运行按钮用于测试整个工作流。如果测试无误大家就可以点击发布进行应用发布。

点击查看不同的节点介绍

三、设计工作流

  1. 做选题调研 :明确整个模型的输入输出。

  2. 功能模块设计 :思考需要用到功能模块,比如会用到什么知识库、插件、代码的组合、意图识别。

  3. 组合完整工作流 :明确数据从输入到输出的整个过程,具体需要由什么节点到什么节点。

如果需要的功能较为复杂可以将一个工作流拆分成多个工作流,最后将多个工作流作为独立节点组合在一个总工作流中。

  1. 模块测试 :需要测试prompt稳定性测试及每个节点的测试。

  2. 应用发布

3.1 准备功能模块

功能模块的思考来源于你在完成选题任务时需要哪些工具。

比如我需要制作法律大模型,我需要准备好法律的知识库。

再比如我要做地图类应用我需要使用地图的api,我需要高德地图插件。

Agent = LLM大脑 + 执行器

3.2组合工作流

把数据当做水源,工作流理解为将水从水库引入需要灌溉的田野的人工渠道。

想做工作流,需要想好怎么将选题阶段准备的输入数据经过功能模块处理后得到输出数据。

中间我们需要大模型做什么?需要插件做什么?哪个在前哪个在后?

3.3 模块测试需要注意什么

模块测试大家应该都会做,我们简单介绍一些注意点。

  • 测试时对于文本大模型需要测一下promopt的稳定性。

  • 对于插件需要测试输入与输出,明确格式与数据规范。

  • 对于开始测试变量是否满足后续使用。

  • 对于知识库测试需要测试关键字是否能被命中,返回的知识是否满意,是否需要对知识库调优。

3.4迭代优化

完成功能模块测试后可能会遇到一些卡点,有些功能模块设计不合理时我们需要回过头来重新调整模块间的位置以及数据传输链路。这里就需要大家回到功能模块设计对工作流重构,迭代升级工作流项目。如果觉得测试效果已经达到预期,就可以考虑去上线项目啦~

要加油哦~

四、高中学习小助手工作流设计

4.1 选题调研

在高中学习阶段,学生面临着繁重的学习任务和多元化的学科要求。对于希望全面提升自己学术能力的同学来说,制定一个既符合个人学习节奏又能充分发挥潜力的学习计划至关重要。本项目针对一位特定的学生,其学习科目涵盖了语文、英语、数学以及其他副科,旨在通过深入分析和理解该学生的学习需求、学习科目以及学习偏好,为其量身定制一个详细且高效的学习计划。该学生在语文、英语、数学和其他副科的学习过程中遇到了一些困难,这些困难可能包括知识点掌握不牢固、学习方法不当、时间管理不合理等。同时,学生也有自己独特的学习偏好,比如更喜欢通过互动式学习来加深理解,或者更偏爱使用某种类型的学习资源。

4.2 功能模块设计

①开始节点

开始: 大家点击到开始即可进行编辑,点击小加号进行添加~首先需要用户手动输入字段。

细节可以按照如下配置。

数学和英语同上,因为是主科都需要花很多时间准备这是比选项目 

②数据整理

数据整理: 由于我们需要使用插件——夸克搜索,目前只支持单个数据引用,所以我们需要将输入内容进行拼接后再使用夸克搜索。

那么我们使用函数完成数据整理工作。这个思路也很简单,说是Python代码,其实类似拼积木。大家跟着我的思路来不用会代码也可以完成数据的拼接~

  1. 请大家将代码拖动到画布中,我们需要将开始后面的连线X掉(删除掉),然后将连线从开始重新引出~

    拖拽样例

    接着我们开始编辑代码模块。

  2. 请大家根据输入的内容做好 变量名称 以及 输入值 的映射,输入值也可以通过小“+”号进行添加。添加后如图中找一个字母代替。比如我们用param_english代替我们的英语学科。然后将所有输入值都逐个代替一遍。等下我们会将这样的字符写入代码中完成拼接任务。

  3. 接着我们开始完善代码部分:

    import requestsdef main(params: dict | str, context: dict) -> dict:"""@param params: dict | str - 代码节点入参配置@param context: dict - 可通过context.get('alipayContext')拿到上下文对象,其中包含 requestId、traceId 等信息"""# 学习语文param_yw= params.get('param_yw', {}) if isinstance(params, dict) else params# 学习数学param_math = params.get('param_math', {}) if isinstance(params, dict) else params# 学习英语param_english = params.get('param_english', {}) if isinstance(params, dict) else params# 其他副科param_fk = params.get('param_fk', {}) if isinstance(params, dict) else params# 遇到的困难param_problem = params.get('param_problem', {}) if isinstance(params, dict) else params# 学习的偏好param_ph = params.get('param_ph', {}) if isinstance(params, dict) else paramsparam =  f"{param_yw},{param_math},{param_english}以及{param_fk}中根据{param_yw}以及遇到{param_problem}的解决攻略"return param

    代码部分由于嵌套在百宝箱的系统里,与直接编程有些区别,建议尽量不要写太复杂的代码。

    这里面我们完成两个步骤,获取和拼接。获取是通过params变量从外部获取传入的数据,大家可以参考这样的模版:

    只需要替换橙色的内容(param_math)即可做到数据的获取~

    由于代码语法问题,请记得前面打四个空格,保证和最后的return统一缩进哦。

    最后我们组合输出值,这里我们统一用param。组合输出我们也可用下面的模版:              param =  f"{param_yw},{param_math},{param_english}以及{param_fk}中根据{param_yw}以及遇到{param_problem}的解决攻略"

    param = f"xxxx"是固定写法。然后我们可以借助刚才的替换思路,将我们代替内容的字符理解为我们传上来的数据。因为需要遵循python语法格式,我们需要将字符带上{}

    例如{param_yw}学习语文,{param_math}学习数学,{param_english}学习英语以及{param_fk}中根据{param_yw}这一情况以及遇到{param_problem}的解决攻略"

    学习语文,学习数学,学习英语以及学习副科(史/地/生/物理/化学/政治)中根据以逸待劳以及遇到数学公式记不住,英语单词记不住等的解决攻略

    注意:这里如果没有学过编程的小伙伴看到代码部分可能比较懵,别灰心我们可以克服的!有问题可以求助助教大大!加!油!

  4. 接下来我们配置一下代码的其他部分,有一点细节需要注意。最后这里我们数据类型请换为字符串,如果是其他类型不方便传入夸克搜索插件呢。

~

③夸克搜索节点

夸克搜索: 完成字符串拼接完全是为了辅助夸克搜索。(好大排面!)当然夸克搜索也不会让大家失望的~还是一样首先我们将插件拖动到画布,找到夸克搜索。接着需要从代码后侧引出一条线,接到夸克搜索上。然后再输入值后面选中代码-结果。(简简单单是不是~)

④文本大模型

文本大模型:

这里请大家拖动一个文本大模型模块接到夸克后面。咱们对文本模型配置~

然后我们根据需求设计提示词~下面的输出名称改成方案初步生成,这次生产完还不够完美,后面我们小修一下。

作为一个高中学习小助手,你的任务是根据用户的学习需求、学习科目以及学习偏好,定制一个详细且高效的学习计划。用户的学习科目是开始/学习语文开始/学习英语开始/学习数学开始/其他副科。遇到的困难是开始/遇到的困难,学习的偏好是开始/学习的偏好是。请根据以下信息,为用户提供一个既符合其学习节奏又能够充分发挥其学习潜力的学习计划。计划应包括以下内容:1. **科目概述**:简要介绍开始/学习语文开始/学习英语开始/学习数学开始/其他副科的学习内容、在高中阶段的重要性以及学习这些科目的意义。
2. **时间安排**:为每天的上午、下午和晚上(或根据用户的实际作息时间调整)安排具体的学习任务,确保学习时间的合理分配和高效利用。
3. **学习资源推荐**:根据用户的学习偏好,推荐适合的教材、参考书、在线课程、学习APP、练习题集等学习资源,特别是针对开始/学习语文开始/学习英语开始/学习数学开始/其他副科的资源。
4. **学习方法与策略**:结合用户的学习偏好,提供有效的学习方法与策略,如如何通过动手实践来加深理解、如何运用互动式学习方式提高学习效率等,特别是在开始/学习语文开始/学习英语开始/学习数学开始/其他副科方面的策略。
5. **食宿与休息建议**:提供关于如何合理安排饮食、保证充足睡眠以及适时进行休息和娱乐的建议,以保持良好的身体状态和学习状态。
6. **学习进度与反馈**:设定明确的学习进度目标和里程碑,如每周完成一定量的学习任务、每月进行一次知识测试等,并提供如何获取学习反馈和调整学习计划的建议。
7. **推荐活动与实践**:根据用户的学习偏好,推荐与学科相关的实践活动或项目,如参加科学展览、参与文学社团、进行数学竞赛等,以丰富学习体验并提升学习兴趣。
8. **学习小贴士**:提供与学习相关的实用信息,如如何有效管理学习时间、如何应对学习压力、如何保持学习动力等,类比于旅行中的交通、天气、安全等提示。请根据以上信息,为用户提供一个详细且高效的学习计划。

完整的Prompt 

⑤方案输出-文本大模型

其实到这里就可以结束了,但是为了保证输出的效果我们拆出来了一个风格化的部分。如果让一个文本大模型做太多任务很容易导致效果不佳,这里也是做工作流对于使用文本大模型的一个tip。

那么我们再生成一个文本大模型节点,将刚才的大模型节点输出引到这里。选择智谱大模型,然后输出:方案结果~

4.3 组合完整工作流

整体的工作流如图所示。

从开始到函数做数据拼接,到夸克搜索获取相关知识,到文本大模型整理知识,到第二个文本大模型对方案风格化最后输出~

4.4 模块测试

请大家点击右上角的运行,然后输出测试值:

  • 学习语文:语文

  • 学习英语:英语

  • 学习数学:数学

  • 其他副科:化学

  • 遇到的困难:语文文言文理解不到位,英语作文得分不高,阅读理解也需要提高,数学公式证明需要加强,生物很多概念死记硬背缺乏理解

  • 学习的偏好是:以逸待劳

接着能看到中间的模块逐个亮起绿灯~一路顺利通行。

我们来看看测试数据的效果。

测试效果

这里我们可以看到,函数顺利完成了拼接工作、夸克搜索对问题搜索并给出了结果、第一个大模型给出了方案后第二个大模型进行风格化调整,最后输出我们的学习计划~

4.5 应用发布与体验

点击右上角发布。

同意协议确认发布~

选择web服务并开启公开访问,点击预览即可~

点击:快速体验

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/500831.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Postman[8] 断言

1.常见的断言类型 status code: code is 200 //检查返回的状态码是否为200 Response body: contain string //检查响应中包含指定字符串包含指定的值 response body:json value check/ /检查响应中其中json的值 Response body: is equal to string …

python openyxl 用法 教程

Python自动化办公:openpyxl教程(基础)-CSDN博客 https://zhuanlan.zhihu.com/p/342422919 https://openpyxl-chinese-docs.readthedocs.io/zh-cn/latest/tutorial.html 列标题,是这一列 对应的单元格的格式,默认是常规,设置之后…

深入解析 Wireshark 的 TLS 设置:应用场景与实操技巧

简述 在网络数据分析中,传输层安全(TLS)协议的流量解密和分析是一项重要的技能。Wireshark 提供了专门的设置选项,帮助用户处理 TLS 流量,例如解密会话、重组分片等。本文将详细解析上图所示的 Wireshark TLS 设置功能…

每天五分钟机器学习:凸集

本文重点 在SVM中,目标函数是一个凸函数,约束集合是一个凸集。因此,SVM问题可以转化为一个凸规划问题来求解。这使得SVM在实际应用中具有较高的计算效率和准确性。 凸集的定义 凸集是指一个集合中的任意两点之间的线段都完全包含在这个集合中。换句话说,给定集合C中的两…

stm32 智能语音电梯系统

做了个stm32智能语音控制的电梯模型,总结一下功能,源码用ST的HAL库写的,整体流程分明。 实物图 这个是整个板子的图片,逻辑其实并不复杂,只是功能比较多,在我看来都是一些冗余的功能,但也可能是…

AI 助力游戏开发中的常用算法实现

在当今的游戏开发领域,人工智能(AI)技术的应用已经成为推动行业发展的关键力量。AI不仅能够提升游戏的智能化水平,还能够增强玩家的沉浸感和游戏体验。随着技术的进步,AI在游戏设计、开发和测试中的应用越来越广泛&…

计算机的错误计算(一百九十九)

摘要 用大模型判断下面四个函数 有何关系?并计算它们在 x0.00024时的值,结果保留10位有效数字。两个大模型均认为它们是等价的。实际上,还有点瑕疵。关于计算函数值,大模型一只是纸上谈兵,没计算;大模型二…

HTML——57. type和name属性

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>type和name属性</title></head><body><!--1.input元素是最常用的表单控件--><!--2.input元素不仅可以在form标签内使用也可以在form标签外使用-…

基于SpringBoot和OAuth2,实现通过Github授权登录应用

基于SpringBoot和OAuth2&#xff0c;实现通过Github授权登录应用 文章目录 基于SpringBoot和OAuth2&#xff0c;实现通过Github授权登录应用0. 引言1. 创建Github应用2. 创建SpringBoot测试项目2.1 初始化项目2.2 设置配置文件信息2.3 创建Controller层2.4 创建Html页面 3. 启动…

LVGL 移植到 Arduino IDE(适用SP32 Arduino RP系列)

1.因为我们需要移植相关LVGL配置文件&#xff0c;否则IDE会报错&#xff0c;因此 先找到LVGL官方的GITHUB处&#xff0c;如下图所示&#xff1a; 2.值得注意的是&#xff0c;你需要知你的 Arduino IDE 用的是哪个版本的LVGL&#xff0c;要与我们在GITHUB处的版本号一致&#xf…

Ubuntu 24.04 LTS 解决网络连接问题

1. 问题描述 现象&#xff1a;ens33 网络接口无法获取 IPv4 地址&#xff0c;导致网络不可用。初步排查&#xff1a; 运行 ip a&#xff0c;发现 ens33 接口没有分配 IPv4 地址。运行 ping www.baidu.com&#xff0c;提示“网络不可达”。查看 NetworkManager 日志&#xff0c…

C语言----指针数组

目录 1. 定义&#xff1a; 2. 格式&#xff1a; 应用示例 1) 用于存放普通变量的地址 2) 用于存放二维数组的每一行第一个元素的地址&#xff08;列地址&#xff09; 3) 用于存放字符串 4) 命令行参数 补充&#xff1a;开辟堆区空间&#xff08;动态空间开辟&#xff0…

单区域OSPF配置实验

1、绘制拓扑图 2、配置ip地址 R0 Router(config)#interface FastEthernet0/0 Router(config-if)#ip address 192.168.1.1 255.255.255.0 Router(config-if)#no shutdown Router(config-if)#exit Router(config)#interface FastEthernet0/1 Router(config-if)#ip address 192.16…

【玩转OCR | 基于腾讯云智能结构化OCR的技术应用实践】

目录 背景与业务挑战 腾讯云智能结构化OCR的核心优势 1. 全面的行业覆盖能力 2. 高识别精度与版式适应性 3. 个性化模板定制 4. 便捷接入与资源优化 应用实践案例&#xff1a;物流行业的单据自动化处理 1. 应用背景 2. 引入腾讯云智能结构化OCR的解决方案 1) 定制化模…

2024 年发布的 Android AI 手机都有什么功能?

大家好&#xff0c;我是拭心。 2024 年是 AI 快速发展的一年&#xff0c;这一年 AI 再获诺贝尔奖&#xff0c;微软/苹果/谷歌等巨头纷纷拥抱 AI&#xff0c;多款强大的 AI 手机进入我们的生活。 今年全球 16% 的智能手机出货量为 AI 手机&#xff0c;到 2028 年&#xff0c;这…

铁路轨道缺陷数据集,4278张原始图片,支持YOLO,PASICAL VOC XML,COCO JSON格式的标注,可识别是否有裂缝,和间隙缺陷

铁路轨道缺陷数据集&#xff0c;4278张原始图片&#xff0c;支持YOLO&#xff0c;PASICAL VOC XML&#xff0c;COCO JSON格式的标注&#xff0c;可识别是否有裂缝&#xff0c;间隙缺陷 可识别的标签信息如下&#xff1a; 裂缝 &#xff08;crack&#xff09; 间隙 &#…

Docker学习相关笔记,持续更新

如何推送到Docker Hub仓库 在Docker Hub新建一个仓库&#xff0c;我的用户名是 leilifengxingmw&#xff0c;我建的仓库名是 hello_world。 在本地的仓库构建镜像&#xff0c;注意要加上用户名 docker build -t leilifengxingmw/hello_world:v1 .构建好以后&#xff0c;本地会…

2025差旅平台推荐:一体化降本30%

医药行业因其高度专业化的特点&#xff0c;同时在运营过程中又极为依赖供应链和销售网络&#xff0c;因此差旅管理往往成为成本控制的重要环节。本期&#xff0c;我们以差旅平台分贝通签约伙伴——某知名药企为例&#xff0c;探讨企业如何通过差旅一体化管理&#xff0c;在全流…

LLM(十二)| DeepSeek-V3 技术报告深度解读——开源模型的巅峰之作

近年来&#xff0c;大型语言模型&#xff08;LLMs&#xff09;的发展突飞猛进&#xff0c;逐步缩小了与通用人工智能&#xff08;AGI&#xff09;的差距。DeepSeek-AI 团队最新发布的 DeepSeek-V3&#xff0c;作为一款强大的混合专家模型&#xff08;Mixture-of-Experts, MoE&a…

AWS re:Invent 2024 - Dr. Werner Vogels 主题演讲

今年&#xff0c;我有幸亲临现场参加了所有的 keynote&#xff0c;每一场都让我感受到深深的震撼。无论是全新的功能发布&#xff0c;还是令人眼前一亮的新特性展示&#xff0c;每一场 keynote 都精彩纷呈&#xff0c;充满干货&#xff0c;值得反复学习和回味。 恰好&#xff…