【DataWhale】灵境Agent开发——低代码创建AI智能体

2024-03-24 01:12

本文主要是介绍【DataWhale】灵境Agent开发——低代码创建AI智能体,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

灵境Agent开发——低代码创建AI智能体

3 灵境 Agent 低代码开发

​ 低代码模式支持开发者通过编排工作流的方式快速构建智能体,您可以通过拖拽和组合模型、提示词、代码等模块,实现准确的、复杂的业务流程。

​ 个人体验下来,目前这个低代码开发功能还不是很完善,许多组件功能都十分有限,没法增加更多自定义的功能。可以说,体验效果并不是很好,不如零代码开发方便,灵活。

参考:快速入门 - 灵境矩阵文档中心 (baidu.com)

3.1 开发套件

​ 套件是可视化编排流程的构建块。它们由定义其功能的输入、输出和参数组成,为构建智能体提供了一种方便、直接的方法。

  1. 套件类型

    • 链:用于编排主流程,智能体将遵循链的顺序执行后输出结果; 平台提供大模型链、分支链等多种类型,用于表达智能体的业务逻辑。

    • 普通套件:除链外所有套件均为普通套件,可以与对应的链连接,连接后将生效为链的基础属性

  2. 套件操作

    在流程创建过程中,您会注意到连接到套件一侧或两侧的连接点(蓝色圆形 ○ 或紫色菱形 ◇ )。这些连接点代表连接到其他套件的可用性,将鼠标悬停在连接点上可查看连接详细信息。其中紫色菱形代表链与链的连接点,左侧为输入,右侧为输出;蓝色圆形代表链与其他套件,或其他套件之间的连接点,左侧为输入,右侧为输出。

    示例说明:

    如果您选择一个大模型链套件,您将看到蓝色 ○ 和紫色 ◇ 连接点。它们表明该链套件接受模型和提示词套件作为输入,红色星号 * 表示必须连接该类型的输入;同时接受与其他的链通过紫色 ◇ 连接。

    c3jpe9gg

    套件卡片的右上角为套件状态图标。在建立必要的连接,发起测试并验证通过后,每个已验证套件的状态应呈绿色;当验证失败时遇到错误的套件的状态应呈红色,将鼠标悬停在失败状态上可显示检测到的错误。

3.1.1 链(Chains)

在详细了解每个套件之前,先来明确一些概念,以便于更好地理解套件的具体功能~

  • 传入对话历史记录:常见配置项,控制是否要将历史对话记录传入模型作为上下文;
  • 输出关键词:常见配置项,当前链的输出结果,您可以通过 {variable_name} 的格式表达希望传入下个链的变量们;
  • 默认变量:{_input_}代表用户输入,此变量可以生效于画布内所有套件。
  1. 大模型链(LLMChain)

    大模型链(LLMChain)可以将多个输入转化为模型提示,支持进一步格式化输出。

    image-20240323223520970

    参数说明:

    1)输入连接点:模型、提示词
    2)输出连接点:无
    3)配置项:

    • 传入对话历史记录:开关,控制是否要将历史对话记录传入模型作为上下文
    • 输出关键词:非必填,设置链的输出结果说明

    4)链连接点:有链输入/输出连接点,可以与其他任意链相连。

  2. 分支链(RouterChain)

    分支链(RouterChain)的主要功能是动态选择下一个要调用的链,可以根据输入内容路由到不同的子链。

    image-20240323223642822

    参数说明:

    1)输入连接点:模型、提示词
    2)输出连接点:无
    3)配置项:

    • 传入对话历史记录:开关,控制是否要将历史对话记录传入模型作为上下文
    • 输出关键词:非必填,设置链的输出结果说明

    4)链连接点:

    • 链输入连接点:可以与其他任意链相连
    • 链输出连接点:需要配置意图,每个意图对应一个链输出连接点
      • 普通意图:必填,支持添加多条。用来表达不同的意图对应关系,基于意图分流到其他子链;
      • 默认意图:必填,未命中普通意图时,将按默认意图执行
  3. 检索链(RetrievalChain)

    检索链(RetrievalChain)可调用知识库文件,并基于模型能力进行查询。

    image-20240323223751588

    参数说明:

    1)输入连接点:模型、提示词、知识库
    2)输出连接点:无
    3)配置项:

    • 传入对话历史记录:开关,控制是否要将历史对话记录传入模型作为上下文

    4)链连接点:有链输入/输出连接点,可以与其他任意链相连

  4. 工具链(ToolChain)

    工具链(ToolChain)可调用工具进行查询。

    image-20240323223910595

    参数说明:

    1)输入连接点:工具
    2)输出连接点:无
    3)配置项:

    • 输出关键词:非必填,设置链的输出结果说明

    4)链连接点:有链输入/输出连接点,可以与其他任意链相连

  5. 提问链(AskChain)

    提问链(AskChain)用于指定意图,调用提问组件引导用户补充提问。

    image-20240323224015892

    参数说明:

    1)输入连接点:提问气泡
    2)输出连接点:无
    3)配置项:

    • 强制意图:必填,设置用户按照引导完成补充提问后,模型应该执行的意图;强制意图必须在其连接的分支链意图列表内,以保证用户回复的内容可以回到主流程;

    4)链连接点:

    • 输入连接点必须为分支链;
    • 无输出连接点;
3.1.2 普通套件
  1. 提示词模板(PromptTemplate)

    提示词模板(PromptTemplate)用于创建提示并定义输出格式,作为指令提供给模型。

    image-20240323224213021

    参数说明:

    1)输入连接点:无
    2)输出连接点:链(支持大模型链、分支链、检索链)
    3)配置项:

    • 模板:必填,您可以创建提示模板并定义变量来控制指示模型。变量可用于定义模型的指令、问题、上下文、输入或示例,并且可以使用大括号中的任何选定名称来创建,例如{variable_name}。它们充当可以轻松修改的文本部分的占位符。在交互式流程中,可以使用默认变量 {_input_} 来充当用户的聊天输入)
    • 输出格式:您可以使用 json 编辑器编写内容,来指定回答结果的输出格式
  2. 文心模型(ERNIE)

    文心一言(ERNIE)是百度发布的知识增强大语言模型。

    image-20240323224327796

    参数说明:

    1)输入连接点:无
    2)输出连接点:链(支持大模型链、分支链、检索链)
    3)配置项:

    • 模型名称:当前流程需使用的模型,目前可选ERNIE-bot、ERNIE-bot-turbo、ERNIE-bot 4:
    • 温度:即 Temperature,数值越高,输出内容越随机;反之,数值越低,输出内容越集中和确定
    • 多样性:即 Top-P,数值越高,输出内容越特殊;反之,数值越低,输出内容越常规
  3. 数据集(VectorStore)

    数据集(VectorStore)用于调用您已上传并完成处理的数据文件,作为模型查询的来源。

    image-20240323224430765

    参数说明:

    1)输入连接点:无
    2)输出连接点:检索链
    3)配置项:

    • 数据集选择:您可以在此选择已经上传并处理成功的数据集,或点击“新建”跳转至数据集管理模块进行新增。注意,只有已处理成功的数据集才会展示在列表中供选择
  4. HTTP 请求工具(RequestTool)

    HTTP 请求工具(RequestTool),用于发起请求并返回结果。

    image-20240323224526604

    参数说明:

    1)输入连接点:无
    2)输出连接点:工具链
    3)配置项:

    • 请求链接:必填,请求的 URL
    • 请求方法:目前平台支持 GET 和 POST 方法,更多方法敬请期待
    • Headers:可通过 key-value 的形式输入
    • Query:可通过 key-value 的形式输入
    • Body:可通过 json 编辑器输入
  5. 百度搜索工具(BaiduSearchTool)

    百度搜索工具(BaiduSearchTool),用于查询百度搜索结果,返回结果标题、链接、摘要等内容。

    image-20240323224618787

    参数说明:

    1)输入连接点:无
    2)输出连接点:工具链
    3)配置项:

    • 搜索词:必填,输入需要请求百度搜索的关键词
  6. 提问气泡(AskUI)

    提问气泡(AskUI)提供了一系列 GUI 组件,以更直观的方式引导用户提问。

    image-20240323224712898

    参数说明:

    1)输入连接点:无
    2)输出连接点:提问链
    3)配置项:

    • 组件选择:必填,用于选择要使用的 UI 组件,目前仅提供 “选择器”,更多组件完善中,敬请期待
    • 组件配置:必填,配置内容与组件类型关联,现介绍选择器配置如下:
      • 标题:需要用户补充输入的问题
      • 选项:最多可添加 6 个选项,目前仅支持单选
    • 输出变量:必填,设置提问气泡组件输出结果的变量名称,可用于被下游或提示词模板中引用,默认值为 “value”
    • 提示词模板:您可以创建提示模板并定义变量来控制指示模型。变量可用于定义模型的指令、问题、上下文、输入或示例,并且可以使用大括号中的任何选定名称来创建。例如{variable_name}格式可以作为变量使用,还可以使用默认变量{_input_}来充当用户的聊天输入)

3.2 工作流

​ 以下工作流示例供您参考,以便于更好的理解各个套件的连接方式和功能。

  1. 大模型链 的使用

    使用模型链,通过模型和提示词构建笑话生成器

    默认变量{_input_}用于获取用户输入,您可以在提示词中使用{_input_}来定义模型如何基于用户输入,输出指定内容。

    1711205430120

  2. 检索链 的使用

使用检索链,通过外挂数据集和模型能力,构建 mysql 知识查询助手

通过构建的数据集,使用检索链进行输出。

1711205463435

  1. 工具链 的使用

    使用大模型链和工具链,构建天气查询助手

    通过输出关键词,实现多个链之间的数据传递:下游链可以通过上游链的输出关键词来获取上游链的输出;

    注意:输出关键词只能在相邻的两个链传递

    1711205770365

  2. 提示词模版 的使用

    使用多个模型链,制作可以输出指定格式的笑话生成器

    • 通过提示词模板中的输出格式功能,指定笑话内容输出的格式;

      1711205847996

    • 下游链引用上游多变量可以使用 outputKey 组合语法来获取

      1711205875645

  3. 分支链与提问链 的使用

    使用分支链和提问链,搭建可以根据用户不同意图输出内容的综合助手

    • 分支链可以配置多个意图,当用户输入命中意图时,将执行对应分支;识别到不存在的意图则执行默认意图;
    • 提问链可以连接选择器气泡样式,用户完成交互后,会直接执行分支链关联的强制意图。

    1711205931905

3.3 低代码开发流程

​ 低代码模式支持开发者通过编排工作流的方式快速构建智能体,您可以通过拖拽和组合模型、提示词、代码等模块,实现准确的、复杂的业务流程。
​ 戳此观看视频课程《低代码智能体开发实战》。

  1. 创建

    登录平台后,从左侧点击"创建智能体",选择"低代码" 立即创建。

    1711206047075

    在可视化编排面板中填写名称和简介,并上传头像图片,即可完成创建。

    1711206078285

  2. 流程搭建

    使用可视化编排创建智能体工作流非常简单,将侧边栏套件拖到画布上并将它们连接在一起以创建通路。灵境矩阵提供了一系列开发套件可供选择,包括链、模型、提示词等。

    1711206101895

  3. 流程测试

    测试流程是为了验证套件是否完成配置并正确搭建通路。测试成功后,可在预览界面发送聊天消息,运行智能体验证效果。

    1711206127715

    新增或删除画布中的组件,修改组件的连接关系、组件参数,需要重新点击测试,当展示错误提示时,表示当前画布中存在构建错误,可以根据提示信息以及《开发套件》文档修改,修改后需重新测试验证错误是否修复。

    1711206153446

    画布中的测试问题,全部保存在错误报告中,已修复的错误会自动删除。

  4. 预览

    聊天界面提供了与智能体交互的友好体验,可以模拟用户与智能体对话的实际场景,获取真实反馈。

    测试成功后才能支持预览,若当前测试存在错误报告,或未进行测试验证,则无法进行预览。

    注意:每次测试成功后,可以预览 8 小时,8 小时后需要重新点击测试发起预览。

    1711206192861

这篇关于【DataWhale】灵境Agent开发——低代码创建AI智能体的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/840090

相关文章

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android开发环境配置避坑指南

《Android开发环境配置避坑指南》本文主要介绍了Android开发环境配置过程中遇到的问题及解决方案,包括VPN注意事项、工具版本统一、Gerrit邮箱配置、Git拉取和提交代码、MergevsR... 目录网络环境:VPN 注意事项工具版本统一:android Studio & JDKGerrit的邮

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模