微信扫码
与创始人交个朋友
我要投稿
本文3095字,预计7分钟读完。
上篇文章《一文读懂RAG(检索增强生成)》中,笔者分享了有关RAG技术的看法。
RAG在to B领域一般应用在知识库问答,智能客服等场景,大概流程是:把知识内容进行分块,建立索引后存储于向量数据库中,通过相似度检索的方式,召回与提问匹配度较高的知识片段后输入给大模型,再让大模型基于提问进行针对性的回答。
RAG+大模型构建的机器人相比于传统机器人,有更强的语义理解能力与生成组织能力,在“解决问题”层面上整体表现更加“拟人化”。
除了以上两个场景外,RAG在to B软件领域中仍存在很多值得探索的应用场景。
本篇文章,计划通过笔者在产品工作中落地的一个项目跟大家分享如何基于RAG构建一款to B智能体(Agent)应用。
① 基础信息:客户名称、标签、来源等
为了支持用户能够灵活筛选出客户,并展开针对性的管理跟进,以往做法是:把客户信息维度拆解出不同的过滤条件供用户进行筛选操作。
举个例子:“筛选本月从百度来源创建但至今仍没联系过的客户”,操作流程大致如下:
(1)客户列表点击【添加过滤条件】,从数百个条件中找到“创建客户时间”、“最后联系时间”、“来源”三个的过滤条件。
(4)点击【过滤】,执行筛选操作。
看似简单的四步操作,却存在不少的问题:
虽然团队后期也推出了“基础过滤”模式,有效减少了第二步的操作(条件只有“包含”关系)
但其余的操作仍然给用户造成不少的操作负担,毕竟让用户在短时间内把筛选需求转化成过滤条件,并搭配形成条件组合是一件相当困难的事情。
三、智能体(Agent)的框架设计
那么,是否可以基于大模型强大的语义理解能力,让用户更便捷查询到客户呢?
比方说:用户只需要把筛选需求描述清楚,至于“查找、组合过滤条件”这些重复且繁琐的操作步骤交给大模型来处理。
经过了可行性分析后,团队立项了【视图助手】Agent项目。
首先,根据对上文的筛选操作进行提炼,“筛选客户”步骤基本是:
“需求识别” -> “条件检索与选择” ->“选择条件关系” -> “确定条件参数” -> “执行筛选”
基于提炼的这个基本步骤,可以抽象出Agent的主要框架,如下图所示:
根据用户的提问判断当前场景是否为客户筛选,是否需要进入到Agent的逻辑。
条件提炼:让大模型识别当前用户的提问和提供的条件列表后,从条件列表中提炼出与提问相匹配的条件信息。
条件组装:获取到条件相关参数后,组装条件组,并生成调用筛选API接口所需的入参结构,如:JSON结构。
参数判断:判断调用筛选API接口所需的条件参数是否有效,如果无效,需要向用户“反问”获取信息。
动作执行(Tools+Action)
基于上一步确定的条件组合以及参数,调用客户筛选API,执行筛选操作。
简而言之,【视图助手】所需要实现出来的效果是:用户一句话描述筛选需求,Agent应用解析出过滤条件后执行筛选,从而把原本的四步操作缩短为一步。
四、基于RAG的智能体(Agent)
但很快就发现了问题,只是简单地把数百个条件名称罗列在Prompt中,不涉及到条件参数的描述。当遇到提问涉及到语义接近的词汇或者需要特定业务含义参数匹配时,大模型会出现幻觉。
打个比方说:“关系一般的新入库客户”。
标签="关系一般"
客户进展="新入库"
结果可想而知,返回的条件参数无法映射至业务系统又或者多识别了无效条件。
后来考虑过,通过长文本(128K)的方式,把条件名称及参数都存储于Prompt中,让大模型自我学习,并做精准匹配。但出于响应时长以及Token消耗成本的考虑,没有采取这种方式。
最终,我们确定通过RAG(检索增强生成)技术解决以上所遇到的问题。流程如下:
条件检索区别于知识库问答,并不需要复杂的知识分块规则,一般以单个过滤条件为最小单位进行切分。但直接把条件名称进行向量化存储,会导致相似检索时,产生一定的近似误差从而影响检索准确度。
因此,需要把过滤条件的描述以及具体参数一同向量化建立索引。
因此方案中,采用了“混合检索”的方式,利用“关键词检索”作为补充,对两种检索方式召回的结果经过精排,最终筛选出满足需要的条件。
在第二步中,召回与用户提问相似度最高的10个过滤条件,把条件名称及参数+用户提问组合成Prompt后,输入给大模型进行处理。要求大模型从用户提问中提取出匹配的过滤条件,并遵循指定的格式进行返回。
为了确保大模型返回的结果可以与业务系统中的条件参数进行匹配,还需要对大模型返回的内容进行二次清洗处理,比方说:通过模糊检索的方式校验参数的有效性。
五、Agent实际落地效果
六、结语
【视图助手】应用并不局限于筛选客户场景,类似于线索、商机、订单等业务对象的筛选场景均可以接入。可见,RAG技术在基于大模型的Agent构建过程中,主要起到“工具”的作用,能够有效弥补大模型如:知识局限性、幻觉、时效性等问题。
在to B软件领域中,智能体(Agent)方向还有很多的场景值得我们去探索,但一开始可以尝试从优化用户以往重复且繁琐的产品交互作为切入点。
以上是笔者近阶段个人的学习与思考,希望能帮到你。
53AI,企业落地应用大模型首选服务商
产品:大模型应用平台+智能体定制开发+落地咨询服务
承诺:先做场景POC验证,看到效果再签署服务协议。零风险落地应用大模型,已交付160+中大型企业
2024-11-23
FastRAG半结构化RAG实现思路及OpenAI O1-long COT蒸馏路线思考
2024-11-23
检索增强生成(RAG):解密AI如何融合记忆与搜索
2024-11-23
如何提高RAG系统准确率?12大常见痛点及巧妙解!
2024-11-23
RAG 2.0性能提升:优化索引与召回机制的策略与实践
2024-11-22
RAG技术在实际应用中的挑战与解决方案
2024-11-22
从普通RAG到RAPTOR,10个最新的RAG框架
2024-11-22
如何使用 RAG 提高 LLM 成绩
2024-11-21
提升RAG性能的全攻略:优化检索增强生成系统的策略大揭秘 | 深度好文
2024-07-18
2024-05-05
2024-07-09
2024-05-19
2024-07-09
2024-06-20
2024-07-07
2024-07-07
2024-07-08
2024-07-09
2024-11-06
2024-11-06
2024-11-05
2024-11-04
2024-10-27
2024-10-25
2024-10-21
2024-10-21