【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

版权声明:本文为博主作者:住在天上的云原创文章,版权归属原作者,如果侵权,请联系我们删除!

原文链接:https://blog.csdn.net/weixin_48024605/article/details/136977467

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
扎眼的阳光的头像扎眼的阳光普通用户
上一篇 2024年4月16日
下一篇 2024年4月16日

相关推荐