AI大模型精准升级!揭秘高级RAG架构,让回答更精准、更可靠!

什么是 RAG?

当然,本文依然会讲解一部分 RAG 的基础知识,让你能够对文章的上下文有个初步了解。

“检索增强生成” (Retrieval Augmented Generation),简称 RAG,这一概念首次出现在 2020 年 Meta 发布的一项学术研究中。

RAG 通过将大量外部数据与基础模型相结合,增强了 LLM 的能力,使 AI 的回应更加真实、个性化和可靠。

可以说 RAG 是一个旨在提高 LLM 性能的框架。短短三年内,RAG 在企业领域的 LLM 应用中取得了显著的增长。

本文将对 RAG 技术进行进一步的探索,同时会介绍几种更进阶的 RAG 技术。

RAG 的工作原理

查询

通过虚拟助手或者界面(也就是我们日常与 AI 对话的界面),将文本格式的问题发送到 RAG 流程中。

文档搜索 (即 Retrieval)

LLM 开始从外部资源中搜集相关信息。

这些资源可能包括数据库、文档,甚至是搜索引擎结果。

搜索过程是为了找到与输入相关的文本片段或文档。

增强 (Augmentation)

在搜索阶段获取到的信息会与原始的输入或者提示语结合,并通过提示工程技术将其转换为 LLM 可以理解和处理的格式,这样 LLM 可以生成更好的回答。

生成 (Generation)

LLM 会将接收到的信息和原始的输入(即提示语)一起评估来生成准确的输出文本。

具体来说就是,RAG 系统会结合用户的问题初始形式、从向量数据库获取的文档以及其他相关参数,确保 LLM 能够生成最准确和相关的答案。

回答

LLM 将生成的最终回答发送给用户。

RAG 在各种自然语言处理任务中都很有用,比如问答、对话生成、总结摘要等。

通过整合外部信息,RAG 可以提供比传统的模型更准确和信息丰富的回答,而传统模型仅依赖于其预训练数据。

RAG 与传统方法的区别

基于分类的传统模型

传统的自然语言模型通过输入查询,从预定义的响应集中选择一个适当的响应。

这些模型通过将输入文本(比如问题)与一组预定义的答案进行比较然后返回最合适的答案。

系统通过使用监督学习算法或其他语义匹配方法,测量输入和标记响应之间的相似性来确定最适合的响应。

对于问答这样的任务,使用这样的模型是没问题的,因为答案通常基于固定的回答类型,并且可以轻松地以结构化形式找到。

基于 RAG 的模型

与传统的模型不同,生成式 AI 是从头开始创建答案或内容,而不是匹配现有内容。

这些模型使用更复杂的算法,通常基于神经网络,来生成更接近真人表达的的文本或响应。

与我们习惯的方法不同,它们不需要将其与任何现有类关联,因为它们创建了新的内容。

这带来了无监督学习的所有优势和强项。

这些模型可以预测下一个单词或一系列单词来学习并生成新的并且是上下文相关的回答。

无监督学习是一种机器学习方法,与监督学习不同,它不依赖于标注数据(即带有明确标签的数据)。相反,无监督学习算法通过分析和寻找数据中的模式、结构或关系,自动从未标注的数据中学习。

RAG 的优势

RAG 在许多需要访问外部信息和当前数据的场景中具有显著优势。

上下文相关性

RAG 系统能够生成更具有上下文相关性和信息更加丰富的回答。

通过结合外部来源的信息创建的文本更能反映当前的实际情况,从而提供更准确的回答。

事实核查与验证

由于 RAG 系统从可靠的外部来源获取信息,它们可以在生成过程中进行事实核查与验证。这有助于减少错误或误导性信息的产生,并确保内容的准确性。

优化知识整合

RAG 系统能够有效利用外部知识库或文档来优化其回答。这在问答任务中特别有用,模型可以从广泛的资源中搜索相关信息,从而提供见多识广且准确的回答。

灵活性和适应性

通过从各种资源或者去到获取信息,RAG 系统更具灵活性和适应性。

只要搜索机制设计得当,它们无需针对每个特定场景进行明确的微调,就能处理广泛的主题和任务。

处理分布外输入

分布外输入(Out-of-Distribution Input, OOD Input)通常是指在训练过程中未见过的、与训练数据分布不一致的数据。

传统文本生成模型在面对训练数据中不存在的分布外或不常见输入时可能会遇到困难。

RAG 系统则可以利用向量数据库中的文档堆栈,即使对于未见过或不常见的输入,也能找到相关信息。

控制内容生成

RAG 系统还可以用于控制内容的生成。通过引导文档搜索过程并指定来源,开发人员可以控制模型用来生成响应的信息类型和质量。

减少偏见

文档搜索机制可以帮助减少内容中的偏见。

通过结合多种信息来源,模型可以提供比传统模型更为平衡的回答,而传统模型可能会受到训练数据中存在的偏见影响。

尽管 RAG 具有显著优势,但也需要注意潜在的挑战和考虑因素,如处理不同来源的复杂信息以及平衡文档搜索结果的准确性和效率。

RAG 与其他生成式 AI 的不同之处

主要区别在于数据的存储和使用方式。

以使用公司数据为例。

当对模型进行微调时,是使用公司数据重新训练一个已知的 LLM,并更改模型配置来满足需求。

而 RAG 则是从外部存储的公司文档中检索数据,并将其提供给 LLM 来指导生成回答。

微调是一个耗时且昂贵的过程,并不适合处理频繁变更的公司文档。

RAG 实施挑战

尽管 RAG 非常强大,但在实施和管理方面也带来了一些挑战:

多渠道/来源整合

当有多个不同格式的外部数据源时,复杂性会增加。

为了克服这个问题,重要的是要对这些数据进行预处理或检查,以避免数据集之间的重复。

数据质量

数据应保持一致并能良好地传达信息。

如果数据本身的质量就不高,那么生成的回答也肯定是不准确的。因此,在整合数据源之前,需要确保高质量的数据。

可扩展性

随着数据量的增加,管理 RAG 系统的性能变得困难。为更容易地管理这一问题,应使用如向量数据库等解决方案。

向量数据库是一种专门存储和处理向量(高维数据)的数据库。它可以快速找到与某个向量最相似的其他向量,广泛用于人工智能、图像搜索、推荐系统等需要高效相似度搜索的场景。简单来说,它帮助我们快速找到“最相像的”数据。

搜索优化

为了使模型生成准确的输出,从向量数据库进行相似性搜索这一步必须具有高性能,而这也是第一步。

如果向量搜索的结果选择了缺失或者不正确的内容,那么,在下一步增强的时候,就无法将其转换为合适的、并且可以让 LLM 理解和处理的格式。

更复杂的 RAG 系统

文档分块 Document Chunking

在自然语言处理中,“分块”是指将文本分割成小的、简明的、有意义的部分。

RAG 系统可以在较小的文本片段中更快、更准确地找到相关上下文。

那么,如何确保选择正确的部分呢?分块策略的有效性在很大程度上取决于这些片段的质量和结构。

为了确定最佳块的大小,需要在捕获所有重要信息和保证处理速度之间取得平衡。

虽然较大的块可以捕获更多的上下文,但它们也会引入更多的噪音,并需要更多的时间和计算成本来处理。

较小的块噪音较少,但可能无法完全捕获所需的上下文。重叠部分是一种平衡这两种约束的方法。

噪音通常指那些与当前任务无关或不重要的信息,这些信息可能会干扰模型的理解和处理,导致生成的结果不准确或不相关。

通过重叠部分,一个查询很可能通过多个向量集检索到足够相关的数据来创建一个正确关联的答案。

其中的一个限制就是:这种策略假设所有需要的信息都可以在单一文档中找到。

如果所需的上下文分散在多个不同的文档中,可能需要考虑如文档层次结构和知识图谱等解决方案。

CRAG

CRAG,C 代表的是 “Check” 或 “Cross-Check”。

我们可以将 CRAG 视为验证或改进搜索结果,这是 RAG 工作流程中的第一步。

RAG 过程中的普遍问题是,在搜索阶段无法从文档堆栈中获得预期结果。

如果没有能够获得所需的最准确文档会导致发送给 LLM 的表达不完整,并在最后一步,即在 LLM 中误导语言模型。

如果一开始的搜索就有问题,那么在随后的步骤中,产生的结果的区别和偏差会更加明显。在这种情况下,检查搜索结果是否实际生成了正确的文档至关重要。

CRAG 就可以作为这类问题的解决方案。

通过为所有搜索结果定义阈值的上限和下限,将结果分类为“正确”、“错误”或者“不确定”。

如果至少一个文档与查询的接近度超过阈值,搜索过程被视为正确。

如果找到的所有文档的得分都低于下限阈值,则认为搜索过程不正确。

不确定状态涵盖介于上限阈值和下限阈值之间的其他情况。

对于假设搜索结果正确的文档,应用另一个分块,并通过清理包含噪音的文本和丰富内容来强化文档。

在结果不正确的情况下,使用内容和查询进行网络搜索,并从在线环境中获取更多详细信息,对分类错误的文档进行修正。

在不确定的情况下,同时重复并进行正确和错误的处理过程。

CRAG 确保只使用相关和可靠的信息,并将错误或误导性结果的风险降至最低,从而产生更准确和可靠的回答。

RAG 融合 RAG Fusion

在传统的搜索系统中,用户通常输入单个查询来查找信息。

尽管这种方法简单,但它存在一些限制。单个查询可能无法涵盖用户兴趣主题的全部范围,或者可能过于狭窄,无法产生全面的结果。

在这种情况下,从不同角度创建多个查询就显得尤为重要。

RAG Fusion 通过创建多个查询并重新排序结果来解决 RAG 的固有局限性。它可以弥补用户提出的问题与他们真正想问的问题之间的差距。

它通过大量的多样化的问题来提供对问题的最佳理解。简而言之,可以将 RAG Fusion 比作在做决定前坚持听取每个人意见的人。

RAG Fusion 利用互惠序列融合技术(RRF)来提供强大的支持。

互惠排名融合(Reciprocal Rank Fusion,RRF)是一种用于组合多个搜索结果列表的技术。它通过将不同搜索系统或算法产生的排名列表融合在一起,创建一个综合的排名列表,从而提供更可靠和优质的搜索结果。

可以想想那些我们不知道自己确实需要的信息,直到遇到它们。

通过使用更广泛的查询,系统可以发现那些尽管不是明确寻找的但却是很关键的信息。这使得 RAG Fusion 区别于其他传统的搜索模型。

不过,RAG Fusion 的深度有时会导致信息泛滥。

输出可能非常详细,以至于令人不知所措。可以将 RAG Fusion 比作一个过度解释事情的信息伴侣,可能会分散用户对于原始意图的注意力。

为了减轻这一问题,可以通过在请求工程中指示模型给予原始查询更多的权重来加以控制。

HyDE

HyDE 是一种在自然语言处理领域中使用的技术,其核心思想是通过生成临时的虚拟答案或文档来帮助理解和处理输入问题。

这个方法特别适用于那些问题描述不清晰、细节不足或缺乏明显可识别元素的情况。

比如,假设用户问了一个模糊的问题:“能拍出好照片的手机价格是多少?”

这句话虽然是在问价格,但是主体肯定是手机,HyDE 系统会生成一个虚拟文档,其中可能包含对于能够拍出好照片的手机的描述。

然后,系统利用这个虚拟文档在数据库中查找相关信息,最终返回一个更相关的回答。

然而,这种方法也有一个缺点:因为它并不总能给出好的结果。

如果讨论的话题完全超出语言模型的知识范围,这种方法就无效,甚至还有可能导致错误信息的增加。

层次索引 Hierarchical Indexing

层次索引(Hierarchical Indexing)是一种用于组织和管理文档或数据的结构化方法,通过将信息分层次进行分类来提高数据检索的效率和准确性。

这种方法特别适用于需要处理大量文档或复杂数据集的场景。

可以将文档层次结构视为 RAG 系统的目录。它以一种结构化的方式组织各个部分的内容,使 RAG 系统能够有效地检索和处理相关数据。

那么,如果 LLM 能够理解文档中的内容,我们为什么还需要文档层次结构?

上文提到:将文档层次结构视为目录或文件目录。尽管 LLM 可以从向量数据库中提取相关的文本片段,但使用文档层次结构作为预处理步骤来找到最相关的文本片段,可以提高搜索过程的速度和可靠性。

这种策略可以减少由于片段提取问题引起的幻觉。

LLM 的“幻觉”是指 LLM 在生成文本时,提供了看似合理但实际上错误、不准确或完全虚构的信息。这是当前自然语言处理技术中一个已知的问题。

总结

本文介绍了更高级的 RAG 架构,也详细介绍了更多的 RAG 技术,希望对你有所帮助。

RAG 技术依然还在快速发展中,也还存在诸多挑战。

前段时间微软发布了 GraphRAG 让 RAG 的应用延伸到了图领域。我相信,在今后 RAG 的应用将会越来越广泛,与 LLM 的结合越来越紧密,我们所使用的 AI 功能也肯定会更加强大。

如何学习大模型 AI ?

由于新岗位的生产效率,要优于被取代岗位的生产效率,所以实际上整个社会的生产效率是提升的。

但是具体到个人,只能说是:

“最先掌握AI的人,将会比较晚掌握AI的人有竞争优势”。

这句话,放在计算机、互联网、移动互联网的开局时期,都是一样的道理。

我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。

我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在人工智能学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。但苦于知识传播途径有限,很多互联网行业朋友无法获得正确的资料得到学习提升,故此将并将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

😝有需要的小伙伴,可以Vx扫描下方二维码免费领取🆓

👉1.大模型入门学习思维导图👈

要学习一门新的技术,作为新手一定要先学习成长路线图,方向不对,努力白费。

对于从来没有接触过AI大模型的同学,我们帮你准备了详细的学习成长路线图&学习规划。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。(全套教程文末领取哈)
在这里插入图片描述

👉2.AGI大模型配套视频👈

很多朋友都不喜欢晦涩的文字,我也为大家准备了视频教程,每个章节都是当前板块的精华浓缩。

在这里插入图片描述
在这里插入图片描述

👉3.大模型实际应用报告合集👈

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。(全套教程文末领取哈)

在这里插入图片描述

👉4.大模型落地应用案例PPT👈

光学理论是没用的,要学会跟着一起做,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(全套教程文末领取哈)

在这里插入图片描述

👉5.大模型经典学习电子书👈

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。

img

在这里插入图片描述

👉6.大模型面试题&答案👈

截至目前大模型已经超过200个,在大模型纵横的时代,不仅大模型技术越来越卷,就连大模型相关的岗位和面试也开始越来越卷了。为了让大家更容易上车大模型算法赛道,我总结了大模型常考的面试题。

在这里插入图片描述

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

😝有需要的小伙伴,可以Vx扫描下方二维码免费领取🆓

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

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

相关文章

中国《人工智能安全治理框架》1.0版正式发布 规范各类AI、算法

今日,全国网络安全标准化技术委员会发布《人工智能安全治理框架》1.0版。《框架》提出了包容审慎、确保安全,风险导向、敏捷治理,技管结合、协同应对,开放合作、共治共享等人工智能安全治理的原则。 针对模型算法安全、数据安全和…

RK3576芯片在智能家居里中型智慧屏产品的应用方案分析

智能家居在近年来得到了快速发展,AI技术不断发展,人机交互十分成熟,各种家电也都迎来了智能化浪潮,智能家居为人们提供了优秀的产品体验,受到主流消费者的青睐,智能家居里的中型智慧屏产品也随之兴起。 瑞芯…

RedisTemplate操作String的API

文章目录 1 String 介绍2 命令3 对应 RedisTemplate API❄️❄️ 3.1 添加缓存❄️❄️ 3.2 设置过期时间(单独设置)❄️❄️ 3.3 获取缓存值❄️❄️ 3.4 删除key❄️❄️ 3.5 顺序递增❄️❄️ 3.6 顺序递减 ⛄4 以下是一些常用的API⛄5 应用场景 1 String 介绍 String 类型…

anaconda启动jupyter notebook

1.在Windows搜索框搜索anaconda prompt点击打开 2.然后输入命令jupyter notebook 3.在这个页面编写你的程序

MATLAB实现PID参数自动整定

目录 1、项目说明 2、文件说明 1、项目说明 本项目旨在通过 MATLAB 语言实现 PID 参数的自动整定,并设计了一个直观易用的 GUI 界面。该系统特别适用于实验室环境下的 PID 参数自整定任务。整定的核心原则在于优化系统性能,使系统的衰减比尽可能接近理…

2025考公最新视频免费分享花生十三、齐麟、葛欣、阿里木江、龙飞、袁东、飞扬、李梦娇等

🎉备战公考不用愁,我的小程序为你助力🎉 这里汇聚了花生十三、齐麟、葛欣、阿里木江、龙飞、彬彬、袁东、飞扬、李梦娇、高照等几十位公考名师。他们的视频课程精彩纷呈,搭配详细讲义,让你轻松掌握公考要点。 作为一…

Java | Leetcode Java题解之第395题至少有K个重复字符的最长子串

题目&#xff1a; 题解&#xff1a; class Solution {public int longestSubstring(String s, int k) {int ret 0;int n s.length();for (int t 1; t < 26; t) {int l 0, r 0;int[] cnt new int[26];int tot 0;int less 0;while (r < n) {cnt[s.charAt(r) - a];…

自然语言处理系列六十一》分布式深度学习实战》TensorFlow深度学习框架

注&#xff1a;此文章内容均节选自充电了么创始人&#xff0c;CEO兼CTO陈敬雷老师的新书《自然语言处理原理与实战》&#xff08;人工智能科学与技术丛书&#xff09;【陈敬雷编著】【清华大学出版社】 文章目录 自然语言处理系列六十一分布式深度学习实战》TensorFlow深度学习…

SpringBoot2:请求处理原理分析-接口参数的常用注解

1、PathVariable 作用说明&#xff1a;获取路径参数 案例&#xff1a; 接口收参形式&#xff1a; GetMapping("/car/{id}/owner/{username}")public Map<String,Object> getCar(PathVariable("id") Integer id,PathVariable("username")…

【uml】graph_legend中的类图怎么看

上图中的方框具有以下含义&#xff1a; 实心灰色方框表示生成图表的结构或类。 带黑色边框的方框表示已记录的结构或类。 带灰色边框的方框表示未记录的结构或类。 带红色边框的方框表示未显示所有继承/包含关系的已记录的结构或类。如果图表不适合指定的边界&#xff0c;则图…

雷电9模拟器安装magisk和lsposed

模拟器环境配置 1、开启root 2、开启System.vmdk可写入 安装magisk 1、新建模拟器、开启root权限、并安装debug版magisk 下载地址去上面吾爱论坛作者文章下载吧&#xff01;支持他一下&#xff01; 2、打开magisk的app&#xff0c;点击安装 如果弹出获取权限&#xff0c;直接…

《A Few Useful Things to Know about Machine Learning》论文导读

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl机器学习作为人工智能领域的重要分支,近年来得到了广泛的关注和应用。Pedro Domingos的经典论文《A Few Useful Things to Know about Machine Learning》为我们提供了对机器学习深入且全面的理解…

前端代码规范- Commit 提交规范

什么是约定式提交 约定式提交&#xff08;Conventional Commits&#xff09;是一种用于代码版本控制的规范&#xff0c;旨在通过明确和标准化提交信息来提高代码协作质量和效率。其基本原则是通过规定提交信息的结构和语义来提高代码版本控制的可读性、可维护性和自动化程度。…

蚁剑webshell连接报错A JavaScript error occurred in the main process

报错如图&#xff1a; 已知解决方式&#xff1a; 将上传shell中文文件名修改为任意的英文文件名即可连接。

uniapp对tabbar封装,简单好用

第一种&#xff0c;效果展示 上代码&#xff0c;新建一个公用组件&#xff0c;tabbar.vue <template><view class"tabbar"><view class"tabbar-item" click"tabbarbtn(0)"><image class"item-image" v-if"…

Unreal Fest 2024 虚幻引擎影视动画制作的普遍问题

一 毛发缓存数据巨大的问题&#xff08;及5个解决方案&#xff09; 在引擎里模拟毛发&#xff0c;并且把它缓存下来&#xff0c;我们就不需要从外部导入了&#xff0c;所以我们要解决的问题就是怎么样在引擎里自由地控制毛发 1.物理场控制 延申 [技术分享]《UE中的世界物理场…

第三天旅游线路预览——从贾登峪到禾木风景区入口

第三天&#xff1a;从贾登峪到禾木风景区&#xff0c;晚上住宿贾登峪&#xff1b; 从贾登峪到禾木风景区入口&#xff1a; 1&#xff09;早上9&#xff1a;00起床&#xff0c;吃完早饭&#xff0c;9&#xff1a;30出发&#xff1b; 2&#xff09;从贾登峪到禾木景区售票厅&am…

CSDN文章无水印转成PDF

文章目录 一、打开检查二、点击进入控制台三、在控制台中输入代码 一、打开检查 f11或者右键打开检查 二、点击进入控制台 三、在控制台中输入代码 (function(){ use strict;var articleBox $("div.article_content");articleBox.removeAttr("style&quo…

云计算之大数据(上)

目录 一、Elasticsearch 1.1 产品组件 1.1.1 X-Pack 1.1.2 Beats数据采集中心 1.1.3 Logstash 1.1.4 Kibana 1.2 架构特性 1.2.1 性能 1.2.2 安全性 1.2.3 可用性 1.2.4 可扩展性 1.2.5 可维护性 1.2.6 国际化 1.3 综合检索分析 1.4 全观测 1.5 大数据检索加速…

斑马鱼的超级大脑,光学脑机接口能否解锁生物行为的终极控制?

今天&#xff0c;让我们一起走进一个令人兴奋的科学领域——光学脑机接口&#xff0c;看看科学家们是如何通过这项技术&#xff0c;首次实现了对斑马鱼全脑活动的实时监控和控制。 从科幻到现实的一步之遥 想象一下&#xff0c;如果能够直接读取和影响生物大脑的神经活动&#…