当前位置: 首页 > news >正文

手搓智能体第三弹之复刻 ⌈ AI智能搜索 ⌋

大家好,我是凡人。

老弟最近又烦我了,这回直接在我家楼下堵我了。

原因是他前段时间实在受不了老板折磨离职了,现在找工作的时候就把AI方面的应用经历加入了简历,没想到收到了好几个面试邀约,但他自己真实水平又不怎么样,看我能不能给他点能惊艳面试官的大招,

这家伙平时就是好吃懒做,到关键时候害怕了,没办法我只能把最近捣鼓了很久的用Coze复刻秘塔工作流的技术奉献给他了,下面我们来一起看看。

在做复刻之前,我们需要一些必要条件:

  1. 了解什么是Coze和秘塔。

  2. 秘塔的它三级搜索的流程大体是什么

  3. 最后拆解一下秘塔工作流是怎么工作的。

一、什么是秘塔和Coze

一)秘塔

网址:https://metaso.cn/

秘塔AI搜索是由上海秘塔网络科技有限公司开发,据查秘塔在3月份的访问量就达到了721万次,增速高达551.36%,在AI搜索的市场上表现强劲。

文章中的秘塔全部使用全网搜索模式,便于我们拆解。

如果有想详细了解AI搜索的朋友可以看下这篇文章:

解密5款大厂人都在用的AI搜索神器,早下班搞副业都靠它!

图片

二)Coze

网址:https://www.coze.cn/

Coze和智能体是我公众号里的常客了,所以关于他们是什么我就不展开说了,不明白的朋友可以看看这篇文章:

AI智能体:怎样把AI小客服接到你的公众号中(小白必看)

图片

二、秘塔的三级AI搜索

目前很多的产品的AI搜索都是参考秘塔的三级AI搜索,针对不同人群的需求提供不同的生成内容

图片

一)简洁级别

简洁级别就是要求秘塔AI搜索能够快速、字数精简精准地到最新的相关的信息。简洁级别的秘塔搜索,适用于答案确定性和描述性问题的回复,提供简单直接的搜索结果

图片

下面我们来先看看秘塔简洁级别AI搜索的简单拆解:

图片

  1. 用户在秘塔输入完问题后,秘塔通过用户输入的问题调用网络搜索,并记录搜索后的引用的链接。

  2. 将搜索的结果传输至大模型中继续处理。

  3. 输出大模型的结果与引用的链接,拼成文章返回呈现给用户。

二)深入级别

秘塔的深入级别搜索与简洁级别最大的区别就是搜索的深入和大模型的大量分析

图片

同时会梳理答案中的相关事件和相关人物,获取到的信息要比简洁级别的内容多的多。

图片

图片

秘塔深入级别AI搜索流程的拆解如下:

图片

  1. 可以很明显从图中看到在用户输入问题后,搜索问题的深入获取大量的链接和搜索内容。

  2. 将搜索内容传输至大模型后,当然这个大模型一定是经过专门训练和优化过的。

  3. 大模型通过对内容的大量分析将最终结果拆成多个部分,根据问题和回答的内容决定。

  4. 整合生成的问题结果内容和其他内容,展示最终结果。

三)研究级别

研究级别对于深入级别难度就上了好几层楼,研究级别不仅会回答问题需要的回答还会衍生的回答一系列与问题相关的内容,并通过思维导图、大纲、相关事件和人物等结构化的形式展示信息,帮助用户更好地理解和使用搜索结果。

图片

图片

图片

所以如果拆解研究级别的流程是不是会很复杂呢,其实如果只是简单实现的话并不难理解:

图片

  1. 在研究级别的搜索接收到用户提出的问题后,先进行对问题的精准搜索并推送给大模型整理出问题答案。

  2. 在大模型输出结果的同时会和深入级别一样,同步输出相关事件、相关组织、相关人员等内容。

  3. 根据第一次大模型给出答案结合用户问题,会同时辐射出多个相关类似问题,再对每个类似问题进行网络搜索和模型处理。

  4. 将最终所有模型输出的内容进行整合和格式化输出,得到最终的展示效果。

三、拆解秘塔工作流

前面绕了那么大一圈,就是为了让大家明白秘塔的三级搜索,拆解秘塔的工作流自然就非常简单了。

图片

可以把工作流想象成秘塔为不同行业的报告提供了不同样式的模板,在用户输入相关的问题后,秘塔将问题与模板的标题相结合,通过检索和大模型处理循环输出模板中标题内容,直至拼装成完成的报告,下面我们用流程图来拆解一下:

图片

看了流程图大家是不是有些了解了呀,我在念叨念叨:

1、用户选择了模板以后呢,输入了问题或报告关键字。

图片

2、将问题依次与模板的标题合并成为新问题,通过搜索查出相关内容,返回至大模型中对内容进行分析和整理。

3、最终当所有内容都输出后,再将内容和链接拼装在一块形成完整的报告。

四、复刻秘塔工作流

AI Agent = LLM(大模型)+ Planning(规划)+ Memory(记忆)+ Tools(工具)。

秘塔工作流拆至此就解完毕了,其实在复刻的道路上工作已经完成70%了,对照着智能体公式,规划部分已经完毕,接下来我们整理需要用到的工具。

一)用到的工具

提示词 :用来明确智能体角色,职责,能力,处理流程,输出结果。

插件:必应搜索。

工作流条件判断、大模型、调用数据库。

数据库:提前存储模板中的标题。

二)实现逻辑

这一步就不多做解释了,根据上一步中拆解秘塔工作流中的流程图及相关的流程说明,我们直接跳转到下一步实现。

三)实现环节

还是那句话,写智能体和编程是一个思路,前面设计做的越完善,后面实现起来就越简单,如果设计比较复杂的智能体,就需要完善的设计。

1、创建智能体

图片

2、加入数据库

大家如果有一点点Mysql经验的话,上手Coze数据库不要太简单。创建一张最简单的表,用来记录模板中的标题。

图片

3、实现提示词

为了节省时间,提示词我们仍然使用Coze提供的AI优化版本,关键点其实就在 “ ##流程 ” 这部分。

# 角色你是一位专业的 AI 搜索工作流大师,能够运用先进的 AI 技术对搜索结果进行深入、精准的分析与判断。擅长根据不同需求,生成详细且逻辑清晰的长文报告或简洁明了的分析结果。## 技能### 技能 1:
分析搜索结果
1.当接收到搜索结果时,仔细审查每个结果的内容、来源和可靠性。
2.对结果进行分类整理,提取关键信息和主题。
3.使用清晰的语言总结分析结果,突出重点和关键发现。### 技能 2:
生成长文报告
1.根据分析结果,确定报告的结构和主题。
2.详细阐述每个关键发现,提供具体的例子和证据支持。
3.使用流畅的语言和逻辑连接各个部分,使报告易于阅读和理解。### 技能 3:
生成简洁分析结果
1.快速提取最关键的信息和结论。
2.用简洁的语言表达分析结果,避免冗长和复杂的表述。
3.可以使用列表、图表等形式辅助表达,使结果更加直观。##流程:
1、这条非常重要!根据用户输入的内容进行反馈输出结果,这次用户输入我们称之为“用户报告的类型选择”,如果用户没有输入了“公司市场情绪分析报告”或“舆情分析报告”,这两个类型中的一个,就直接输出“您好!暂不支持其他模板的报告”,并结束此流程。
2、如果用户输入了“公司市场情绪分析报告”,则需要先判断数据库表mita_flow_template中的template_name字段中是否已经存储了“公司市场情绪分析报告”,如未存储,则循环将“行业背景与趋势”、“财务表现与业绩回顾”、“股价波动与市场情绪”、“投资策略建议”写入到title_name中,并且同步将“公司市场情绪分析报告”写入template_name字段中,否则不进行存储。
3、如果用户输入了“舆情分析报告”,则需要先判断数据库表mita_flow_template中的template_name字段中是否已经存储了“公司市场情绪分析报告”,如未存储,则需要在数据库表mita_flow_template中,循环将“舆情信息和负面新闻”、“相关竞品与竞争分析”、“应对措施行业背景与趋势”、“舆情总结”写入到title_name中,并且同步将“舆情分析报告”写入template_name字段中,否则不进行存储。
4、继续问用户“想要写关于什么主题的报告呢!”,当用户回答后,这次用户输入我们称之为“报告主题”,将“用户报告的类型选择”输入到 templatename 参数当中,将“报告主题”输入到 question 参数当中,调用mita_workflow执行。
5、在执行后输出执行结果。## 限制
- 只针对搜索结果进行分析和判断,不进行无根据的推测或假设。
- 所输出的内容必须按照给定的格式进行组织,不能偏离框架要求。
- 长文报告应具有一定的深度和广度,简洁分析结果应突出重点。
- 引用来源时请使用规范的引用格式。

4、创建工作流

创建“mita_flow”工作流

图片

整体流程如下图,是不是看的眼花缭乱,别担心,咱们分开进行拆解:

图片

图片

1>、接收输入,并在数据库中查询

在接收模板名称和主题名称后,通过数据库查询的将在Bot中提前存入的数据库查询出来,并拼装成相关的问题。

图片

2>、总体内容

虽然是根据模板的标题来生成相关内容,但需要第一步来固定输出格式,这里先根据 问题 + 模板名称来生成相关问题,向必应进行搜索,搜索的结果,链接的标题内容作为参考资料,并且对整体的生成结果进行格式化输出。

图片

大模型提示词参考工作流商城里的“【长文本生产】工作流_MENG”。

图片

图片

3>、生成的标题部分

这部分包含四部分生成,每部分只有细微的差别,但它们走的流程都是一样的,都是通过问题+模板名称+标题名称拼装的问题,在必应中搜索,将搜索结果经过代码处理后,输入到大模型当中进行分析和处理,最终形成每个分段内容。

图片

大模型中的提示词如下:

图片

4>、整合输出

最后就是将第一部分至第四部分进行整合输出

图片

5、开场白

这里的开场白也非常重要,因为开场白有着限定输入的能力。

图片

至此复刻秘塔工作流完毕,下面我们一起来看看效果怎样

五、效果

在调试时,我们输入舆情分析报告后,他会提示我们输入需要什么主题的报告。

图片

执行过程

图片

生成的内容较多,我复制出来了,大家一起看看:

图片

怎么样还不错吧,虽然离完整的报告还有些距离,但已经初具雏形了,还需要持续的优化。


怎么样今天的内容还满意吗?再次感谢观众老爷的观看。

最后,祝您早日实现财务自由,还请给个赞,谢谢!

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【C++ 第十九章】异常
  • 哈希 详解
  • 10分钟了解OPPO中间件容器化实践
  • 专栏前言-WooYun漏洞库环境搭建
  • SaaS行业渠道管理的深度探索:两种增长模式哪个更强?
  • 非标机械设计项目“规范”笔记
  • 使用 Nginx 部署 Vue.js 前端项目指南
  • 王立铭脑科学50讲后续6,自己从课程中提起自己所需的知识,安放到自己的知识体系中。
  • Elasticsearch 向量数据库本地部署 及操作方法
  • OpenStack概论和部署
  • npm 换源
  • 如何录制黑神话悟空的游戏BGM导入iPhone手机制作铃声?
  • Datawhale X 李宏毅苹果书 AI夏令营-深度学习进阶task2:自适应学习率,分类
  • 上海亚商投顾:深成指、创业板指均涨超1%,华为产业链反复活跃
  • PySide6复杂C/S系统开发
  • 【347天】每日项目总结系列085(2018.01.18)
  • 002-读书笔记-JavaScript高级程序设计 在HTML中使用JavaScript
  • canvas 高仿 Apple Watch 表盘
  • CSS进阶篇--用CSS开启硬件加速来提高网站性能
  • HTTP传输编码增加了传输量,只为解决这一个问题 | 实用 HTTP
  • nginx 配置多 域名 + 多 https
  • Python利用正则抓取网页内容保存到本地
  • Python学习之路13-记分
  • Rancher如何对接Ceph-RBD块存储
  • Redux 中间件分析
  • 解决jsp引用其他项目时出现的 cannot be resolved to a type错误
  • 浅谈Golang中select的用法
  • 如何邀请好友注册您的网站(模拟百度网盘)
  • 如何正确配置 Ubuntu 14.04 服务器?
  • 移动端解决方案学习记录
  • 用 vue 组件自定义 v-model, 实现一个 Tab 组件。
  • 最近的计划
  • ​软考-高级-信息系统项目管理师教程 第四版【第19章-配置与变更管理-思维导图】​
  • # 飞书APP集成平台-数字化落地
  • #NOIP 2014# day.1 生活大爆炸版 石头剪刀布
  • #VERDI# 关于如何查看FSM状态机的方法
  • #我与Java虚拟机的故事#连载01:人在JVM,身不由己
  • (145)光线追踪距离场柔和阴影
  • (2024最新)CentOS 7上在线安装MySQL 5.7|喂饭级教程
  • (c语言版)滑动窗口 给定一个字符串,只包含字母和数字,按要求找出字符串中的最长(连续)子串的长度
  • (附源码)springboot 智能停车场系统 毕业设计065415
  • (附源码)计算机毕业设计高校学生选课系统
  • (十八)用JAVA编写MP3解码器——迷你播放器
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • .gitignore文件设置了忽略但不生效
  • .halo勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .Net 基于.Net8开发的一个Asp.Net Core Webapi小型易用框架
  • .NET 中创建支持集合初始化器的类型
  • .net 桌面开发 运行一阵子就自动关闭_聊城旋转门家用价格大约是多少,全自动旋转门,期待合作...
  • .NET项目中存在多个web.config文件时的加载顺序
  • .net中我喜欢的两种验证码
  • @FeignClient注解,fallback和fallbackFactory
  • [ C++ ] template 模板进阶 (特化,分离编译)
  • [ CTF ] WriteUp- 2022年第三届“网鼎杯”网络安全大赛(朱雀组)
  • [ CTF ]【天格】战队WriteUp- 2022年第三届“网鼎杯”网络安全大赛(青龙组)