一文带你了解RAG(检索增强生成) | 概念理论介绍+ 代码实操
共 16581字,需浏览 34分钟
·
2024-08-07 06:00
大模型 RAG 实战教程 之 RAG潘多拉宝盒 https://github.com/km1994/AwesomeRAG
一、LLMs 已经具备了较强能力了,为什么还需要 RAG(检索增强生成)?
-
幻觉问题:LLM 采用基于统计的概率方法逐词生成文本,这一机制内在地导致其可能出现看似逻辑严谨实则缺乏事实依据的输出,即所谓的“郑重其事的虚构陈述”; -
时效性问题:随着 LLM 规模扩大,训练成本与周期相应增加。鉴于此,包含最新信息的数据难以融入模型训练过程,导致 LLM 在应对诸如“请推荐当前热门影片”等时间敏感性问题时力有未逮; -
数据安全问题:通用的 LLM 没有企业内部数据和用户数据,那么企业想要在保证安全的前提下使用 LLM,最好的方式就是把数据全部放在本地,企业数据的业务计算全部在本地完成。而在线的大模型仅仅完成一个归纳的功能;
二、介绍一下 RAG?
RAG 技术架构图
三、RAG 主要包含哪些模块?
-
模块一:版面分析 -
本地知识文件读取(pdf、txt、html、doc、excel、png、jpg、语音等) -
知识文件复原 -
模块二:知识库构建 -
知识文本分割,并构建Doc文本 -
Doc文本 embedding -
Doc文本 构建索引 -
模块三:大模型微调 -
模块四:基于RAG的知识问答 -
用户query embedding -
query 召回 -
query 排序 -
将 Top K 个相关的 Doc 进行拼接,构建 context -
基于 query 和 context 构建 Prompt -
将 prompt 喂给大模型生成答案
四、RAG 相较于直接使用 LLMs进行问答 有哪些优点?
-
可扩展性:减小模型规模及训练开销,同时简化知识库的扩容更新过程。 -
准确性:通过引用信息源,用户能够核查答案的可信度,进而增强对模型输出结果的信任感。 -
可控性:支持知识内容的灵活更新与个性化配置。 -
可解释性:展示模型预测所依赖的检索条目,增进理解与透明度。 -
多功能性:RAG 能够适应多种应用场景的微调与定制,涵盖问答、文本摘要、对话系统等领域。 -
时效性:运用检索技术捕捉最新信息动态,确保回答既即时又准确,相比仅依赖固有训练数据的语言模型具有明显优势。 -
领域定制性:通过对接特定行业或领域的文本数据集,RAG 能够提供针对性的专业知识支持。 -
安全性:通过在数据库层面实施角色划分与安全管控,RAG 有效强化了对数据使用的管理,相较于微调模型在数据权限管理上的潜在模糊性,展现出更高的安全性。
五、对比一下 RAG 和 SFT,说一下两者有哪些区别?
模块一:版面分析
为什么 需要 版面分析?
尽管RAG(检索增强生成)技术的核心价值在于其结合检索与生成手段以提升文本内容的精确度与连贯性,然而在一些具体应用领域,如文档解析、智能化写作及对话系统构建中,特别是在面对结构化或半结构化信息的处理需求时,其功能边界可能拓展至版面分析。
这是由于此类信息往往嵌于特定的布局结构中,需要对页面元素及其相互关系进行深入理解。
step 1:本地知识文件获取
q1:如何进行 本地知识文件获取?
本地知识文件获取涉及从多种数据源(如.txt、.pdf、.html、.doc、.xlsx、.png、.jpg、音频文件等)提取信息的过程。针对不同类型的文件,需要采取特定的访问与解析策略来有效获取其中蕴含的知识。下面我们将介绍对于不同数据源数据的获取方式和难点。
q2:如何获取 富文本txt 中内容?
-
介绍:富文本 主要存储于 txt 文件中,因为排版比较整洁,所以获取方式比较简单 -
实战技巧: -
【版面分析——富文本txt读取】
q3:如何获取 PDF文档 中内容?
-
介绍:PDF文档中数据比较复杂,包含文本、图片、表格等不同样式的数据,所以解析过程中会比较复杂 -
实战技巧: -
【版面分析——PDF 解析神器 pdfplumber】 -
【版面分析——PDF 解析神器 PyMuPDF】
q4:如何获取 HTML文档 中内容?
-
介绍:PDF文档中数据比较复杂,包含文本、图片、表格等不同样式的数据,所以解析过程中会比较复杂 -
实战技巧: -
【版面分析——网页HTML解析 BeautifulSoup】
q5:如何获取 Doc文档 中内容?
-
介绍:Doc文档中数据比较复杂,包含文本、图片、表格等不同样式的数据,所以解析过程中会比较复杂 -
实战技巧: -
【版面分析——Docx 解析神器 python-docx】
q6:如何使用 OCR 获取图片内容?
-
介绍:光学字符识别(Optical Character Recognition, OCR)是指对文本资料的图像文件进行分析识别处理,获取文字及版面信息的过程。亦即将图像中的文字进行识别,并以文本的形式返回。 -
思路: -
文字识别:对定位好的文字区域进行识别,主要解决的问题是每个文字是什么,将图像中的文字区域进转化为字符信息。 -
文字检测:解决的问题是哪里有文字,文字的范围有多少; -
目前开源的OCR项目 -
Tesseract -
PaddleOCR -
EasyOCR -
chineseocr -
chineseocr_lite -
TrWebOCR -
cnocr -
hn_ocr -
理论学习: -
【版面分析——图片解析神器 OCR】 -
实战技巧: -
【版面分析——OCR神器 tesseract】 -
【版面分析——OCR神器 PaddleOCR】 -
【版面分析——OCR神器 hn_ocr】
q7:如何使用 ASR 获取语音内容?
-
别称:自动语音识别AutomaTlc Speech RecogniTlon,(ASR) -
介绍:将一段语音信号转换成相对应的文本信息,好比"机器的听觉系统”,它让机器通过识别和理解,把语音信号转变为相应的文本或命令。 -
目标:将人类的语音中的词汇内容转换为计算机可读的输入(eg:按键、二进制编码或者字符序列) -
思路: -
声学信号预处理:为了更有效地提取特征往往还需要对所采集到的声音信号进行滤波、分帧等预处理工作,把要分析的信号从原始信号中提取出来; -
特征提取:将声音信号从时域转换到频域,为声学模型提供合适的特征向量; -
声学模型:根据声学特性计算每一个特征向量在声学特征上的得分; -
语言模型:根据语言学相关的理论,计算该声音信号对应可能词组序列的概率; -
字典与解码:根据已有的字典,对词组序列进行解码,得到最后可能的文本表示 -
理论教程: -
【版面分析 之 语音识别】 -
实战技巧: -
【版面分析 之 Speech-to-Text】 -
【版面分析 之 WeTextProcessing】 -
【版面分析——ASR神器 Wenet】 -
【版面分析 之 ASR神器训练】
step 2:知识文件复原
q1:为什么需要进行 知识文件复原?
q2:如何对 知识文件进行复原?
-
方法一:基于规则的知识文件复原 -
方法二:基于 Bert NSP 进行上下句拼接
step 3:版面分析———优化策略篇
-
理论学习: -
【版面分析———优化策略篇】
step 4:Homework
-
任务描述:使用上述方法对 【SMP 2023 ChatGLM金融大模型挑战赛】的 【ChatGLM评估挑战赛-金融赛道数据集】进行版面分析 -
任务效果:分析各种方法效果和性能
模块二:知识库构建
为什么 需要 知识库构建?
-
扩展模型能力:大规模语言模型如GPT系列虽然具有强大的语言生成和理解能力,但受限于训练数据集的覆盖范围,它们可能无法准确回答一些基于特定事实或详细背景信息的问题。通过构建知识库,RAG可以补充模型自身的知识局限性,允许模型检索到最新、最准确的信息来生成答案。 -
实时更新信息:知识库可以实时更新和扩充,确保模型能够获取最新的知识内容,这对于处理时效性强的信息尤为关键,比如新闻事件、科技进展等。 -
提高准确性:RAG结合了检索与生成两个过程,在生成回答前先检索相关文档,从而提高了回答问题时的准确性。这样,模型生成的答案不仅基于其内部参数化的知识,还基于外部可靠来源的知识库。 -
减少过拟合与hallucination(幻觉生成):大模型有时会因为过度依赖内在模式而出现hallucination现象,即生成看似合理实则无依据的答案。通过引用知识库中的确切证据,RAG可以降低此类错误产生的可能性。 -
增强可解释性:RAG不仅能提供答案,还能指出答案的来源,增强了模型生成结果的透明度和可信度。 -
支持个性化及私有化需求:对于企业或个人用户,可以通过构建专属知识库满足特定领域或私人定制的需求,使得大模型能更好地服务于特定场景和业务。
step 1:知识文本分块
-
为什么需要对文本分块? -
信息丢失的风险:试图一次性提取整个文档的嵌入向量,虽然可以捕捉到整体的上下文,但也可能会忽略掉许多针对特定主题的重要信息,这可能会导致生成的信息不够精确或者有所缺失。 -
分块大小的限制:在使用如OpenAI这样的模型时,分块大小是一个关键的限制因素。例如,GPT-4模型有一个32K的窗口大小限制。尽管这个限制在大多数情况下不是问题,但从一开始就考虑到分块大小是很重要的。 -
主要考虑两个因素: -
embedding模型的Tokens限制情况; -
语义完整性对整体的检索效果的影响; -
实战技巧: -
【知识库构建——知识文本分块】 -
【知识库构建——文档切分优化策略篇】
step 2:Docs 向量化(embdeeing)
q1:什么是Docs 向量化(embdeeing)?
例如,如果两个文本相似,则它们的向量表示也应该相似,这一组向量空间内的数组表示描述了文本之间的细微特征差异。
q2:Embedding 是如何工作的?
-
“The cat chases the mouse” “猫追逐老鼠” -
“The kitten hunts rodents” 小猫捕猎老鼠。 -
“I like ham sandwiches” 我喜欢火腿三明治。
q3:Embedding 的语义检索方式对比关键词检索的优势?
-
语义理解:基于 Embedding 的检索方法通过词向量来表示文本,这使得模型能够捕捉到词汇之间的语义联关系,相比之下,基于关键词的检索往往关注字面匹配,可能忽略了词语之间的语义联系。 -
容错性:由于基于 Embedding 的方法能够理解词汇之间的关系,所以在处理拼写错误、同义词、近义词等情况时更具优势。而基于关键词的检索方法对这些情况的处理相对较弱。 -
多语言支持:许多 Embedding 方法可以支持多种语言,有助于实现跨语言的文本检索。比如你可以用中文输入来查询英文文本内容,而基于关键词的检索方法很难做到这一点。 -
语境理解:基于 Embedding 的方法在处理一词多义的情况时更具优势,因为它能够根据上下文为词语赋予不同的向量表示。而基于关键词的检索方法可能无法很好地区分同一个词在不同语境下的含义。
q4:Embedding检索存在哪些限制?
-
输入词数限制:即便借助Embedding技术选取与查询最为匹配的文本片段供大型模型参考,词汇数量的约束依然存在。当检索覆盖的文本范围广泛时,为了控制注入模型的上下文词汇量,通常会对检索结果设定TopK的阈值K,但这不可避免地引发了信息遗漏的问题。 -
仅支持文本数据:现阶段的GPT-3.5及诸多大型语言模型尚不具备图像识别功能,然而,在知识检索过程中,许多关键信息往往依赖于图文结合来充分理解。例如,学术论文中的示意图、财务报告中的数据图表,仅凭文本难以精准把握其内涵。 -
大模型的胡编乱造:当检索到的相关文献资料不足以支撑大型模型准确回答问题时,为尽力完成响应,模型可能会出现一定程度的“即兴创作”,即在有限信息基础上进行推测与补充。
-
理论学习: -
【知识库构建—Doc 向量化】 -
实战技巧: -
【Docs向量化——腾讯词向量】 -
【Docs向量化——sbert】 -
【Docs向量化——SimCSE】 -
【Docs向量化——text2vec】 -
【Docs向量化——SGPT】 -
【Docs向量化——BGE —— 智源开源最强语义向量模型】 -
【Docs向量化——M3E:一种大规模混合embedding】
step 3:Docs 构建索引
-
介绍 -
实战技巧: -
【Docs构建索引——Faiss】 -
【Docs构建索引——milvus】 -
【Docs构建索引—— Elasticsearch】
模块三:大模型微调
为什么 需要 大模型微调?
-
第一个原因是,因为大模型的参数量非常大,训练成本非常高,每家公司都去从头训练一个自己的大模型,这个事情的性价比非常低; -
第二个原因是,Prompt Engineering的方式是一种相对来说容易上手的使用大模型的方式,但是它的缺点也非常明显。因为通常大模型的实现原理,都会对输入序列的长度有限制,Prompt Engineering 的方式会把Prompt搞得很长。
-
第三个原因是,Prompt Engineering的效果达不到要求,企业又有比较好的自有数据,能够通过自有数据,更好的提升大模型在特定领域的能力。这时候微调就非常适用。 -
第四个原因是,要在个性化的服务中使用大模型的能力,这时候针对每个用户的数据,训练一个轻量级的微调模型,就是一个不错的方案。 -
第五个原因是,数据安全的问题。如果数据是不能传递给第三方大模型服务的,那么搭建自己的大模型就非常必要。通常这些开源的大模型都是需要用自有数据进行微调,才能够满足业务的需求,这时候也需要对大模型进行微调。
如何对大模型进行微调?
q1:大模型的微调技术路线问题
-
技术路线一:对全量的参数,进行全量的训练,这条路径叫全量微调FFT(Full Fine Tuning)。 -
技术路线二:只对部分的参数进行训练,这条路径叫PEFT(Parameter-Efficient Fine Tuning)。
q2:大模型的全量微调FFT 技术存在哪些问题
-
问题一:训练的成本会比较高,因为微调的参数量跟预训练的是一样的多的; -
问题二:灾难性遗忘(Catastrophic Forgetting),用特定训练数据去微调可能会把这个领域的表现变好,但也可能会把原来表现好的别的领域的能力变差。
q3:大模型的 PEFT(Parameter-Efficient Fine Tuning) 解决哪些问题
-
技术路线一:监督式微调SFT(Supervised Fine Tuning),这个方案主要是用人工标注的数据,用传统机器学习中监督学习的方法,对大模型进行微调; -
技术路线二:基于人类反馈的强化学习微调RLHF(Reinforcement Learning with Human Feedback),这个方案的主要特点是把人类的反馈,通过强化学习的方式,引入到对大模型的微调中去,让大模型生成的结果,更加符合人类的一些期望; -
技术路线三:基于AI反馈的强化学习微调RLAIF(Reinforcement Learning with AI Feedback),这个原理大致跟RLHF类似,但是反馈的来源是AI。这里是想解决反馈系统的效率问题,因为收集人类反馈,相对来说成本会比较高、效率比较低。
大模型LLM进行SFT操作的时候在学习什么?
-
预训练->在大量无监督数据上进行预训练,得到基础模型-->将预训练模型作为SFT和RLHF的起点。 -
SFT-->在有监督的数据集上进行SFT训练,利用上下文信息等监督信号进一步优化模型-->将SFT训练后的模型作为RLHF的起点。 -
RLHF-->利用人类反馈进行强化学习,优化模型以更好地适应人类意图和偏好-->将RLHF训练后的模型进行评估和验证,并进行必要的调整。
step 1:大模型微调训练数据构建
-
介绍:如何构建 训练数据? -
实战技巧: -
【大模型(LLMs)LLM生成SFT数据方法篇】
step 2:大模型指令微调篇
-
介绍:如何构建 训练数据? -
实战技巧: -
【大模型(LLMs)继续预训练篇】 -
【大模型(LLMs)指令微调篇】 -
【大模型(LLMs)奖励模型训练篇】 -
【大模型(LLMs)强化学习——PPO训练篇】 -
【大模型(LLMs)强化学习——DPO训练篇】
模块四:文档检索
为什么 需要 文档检索?
step 1:文档检索负样本样本挖掘
-
介绍:在各类检索任务中,为训练好一个高质量的检索模型,往往需要从大量的候选样本集合中采样高质量的负例,配合正例一起进行训练。 -
实战技巧: -
【文档检索——负样本样本挖掘篇】
step 2:文档检索优化策略
-
介绍:文档检索优化策略 -
实战技巧: -
【文档检索——文档检索优化策略篇】
模块五:Reranker
为什么 需要 Reranker?
-
Embedding 模型:用于将外部文档和用户查询转换成 Embedding 向量 -
向量数据库:用于存储 Embedding 向量和执行向量相似性检索(检索出最相关的 Top-K 个信息) -
提示词工程(Prompt engineering):用于将用户的问题和检索到的上下文组合成大模型的输入 -
大语言模型(LLM):用于生成回答
什么是 Reranker?
step 1:Reranker 篇
-
理论学习: -
【RAG文档检索——Reranker 篇】 -
实战技巧: -
【Reranker——bge-reranker篇】
模块六:RAG 评测面
为什么需要 对 RAG 进行评测?
step 1:RAG 评测 篇
-
理论学习: -
【RAG评测篇】
模块七:RAG 开源项目推荐学习
为什么 需要 RAG 开源项目推荐学习?
RAG 开源项目推荐 —— RAGFlow 篇
-
介绍:RAGFlow 是一款基于深度文档理解构建的开源 RAG(Retrieval-Augmented Generation)引擎。RAGFlow 可以为各种规模的企业及个人提供一套精简的 RAG 工作流程,结合大语言模型(LLM)针对用户各类不同的复杂格式数据提供可靠的问答以及有理有据的引用。 -
项目学习: -
【RAG 项目推荐——RagFlow 篇(一)——RagFlow docker 部署】 -
【RAG 项目推荐——RagFlow 篇(二)——RagFlow 知识库构建】 -
【RAG 项目推荐——RagFlow 篇(三)——RagFlow 模型供应商选择】 -
【RAG 项目推荐——RagFlow 篇(四)——RagFlow 对话】 -
【RAG 项目推荐——RagFlow 篇(五)——RAGFlow Api 接入(以 ollama 为例)】 -
【RAG 项目推荐——RagFlow 篇(六)——RAGFlow 源码学习】
RAG 开源项目推荐 —— QAnything 篇
-
介绍:QAnything(Question and Answer based on Anything)是一个本地知识库问答系统,旨在支持多种文件格式和数据库,允许离线安装和使用。使用QAnything,您可以简单地删除本地存储的任何格式的文件,并获得准确、快速和可靠的答案。QAnything目前支持的知识库文件格式包括:PDF(pdf) , Word(docx) , PPT(pptx) , XLS(xlsx) , Markdown(md) , Email(eml) , TXT(txt) , Image(jpg,jpeg,png) , CSV (csv)、网页链接(html)等。 -
项目学习: -
【RAG 开源项目推荐 —— QAnything 篇】
RAG 开源项目推荐 —— ElasticSearch-Langchain 篇
-
介绍:受langchain-ChatGLM项目启发,由于Elasticsearch可实现文本和向量两种方式混合查询,且在业务场景中使用更广泛,因此本项目用Elasticsearch代替Faiss作为知识存储库,利用Langchain+Chatglm2实现基于自有知识库的智能问答。 -
项目学习: -
【【LLMs 入门实战】基于 本地知识库 的高效 🤖ElasticSearch-Langchain-Chatglm2】
RAG 开源项目推荐 —— Langchain-Chatchat 篇
-
介绍:Langchain-Chatchat(原Langchain-ChatGLM)基于 Langchain 与 ChatGLM 等语言模型的本地知识库问答 | Langchain-Chatchat (formerly langchain-ChatGLM), local knowledge based LLM (like ChatGLM) QA app with langchain -
项目学习: -
【【LLMs 入门实战】基于 本地知识库 的高效 🤖Langchain-Chatchat】
评论