RAG Foundry:一个用于增强大语言模型以实现检索增强生成的框架

news2024/11/24 12:26:32

一、结论写在前面

论文来自Intel Labs。

论文标题:RAG Foundry: A Framework for Enhancing LLMs for Retrieval Augmented Generation

论文链接:https://arxiv.org/pdf/2408.02545

代码:https://github.com/IntelLabs/RAGFoundry

实现检索增强生成(RAG)系统本质上复杂,需要深入理解数据、用例及复杂的设计决策。此外,评估这些系统面临重大挑战,需通过多方面方法评估检索准确性和生成质量。

论文引入RAG FOUNDRY,一个用于增强大型语言模型以适应RAG用例的开源框架。RAG FOUNDRY将数据创建、训练、推理和评估整合到一个工作流程中,便于在RAG环境中为训练和评估大型语言模型创建数据增强数据集。这种整合使得快速原型设计和实验各种RAG技术成为可能,允许用户轻松生成数据集并利用内部或专业知识源训练RAG模型。

为了展示该框架的实用性,论文进行了涉及检索、微调、链式思考(CoT)推理和负干扰文档技术的实验。论文通过三种知识密集型问答任务,使用多种增强方法比较了两个广泛认可的基线模型,展示了 RAG FOUNDRY 的有效性。

二、论文的简单介绍

2.1 论文的背景

LLMs存在固有限制。这些模型可能产生听起来合理但不正确或无意义的答案,难以确保事实准确性,无法访问训练截止后的最新信息,并且在处理大型上下文时难以关注相关信息。

、

图1 展示了RAG FOUNDRY框架的概览:数据增强模块将RAG交互持久化为专用数据集,随后用于训练、推理和评估

检索增强生成(RAG)通过集成利用检索机制的外部信息来提升大型语言模型(LLMs)的性能。结合利用模型知识之外的庞大知识库的检索技术,有效地解决了知识局限性,能够减少幻觉现象,提高生成内容的相关性,提供可解释性,并且可能大幅降低成本。此外,最近的研究表明,针对RAG对LLMs进行微调可以实现最先进的性能,超越更大规模的专有模型。

然而,RAG系统的实施本质上复杂,需要一系列精细的决策,这些决策会显著影响系统性能。这一过程要求对数据和使用场景有深入的理解,而且通常解决方案在其他领域泛化效果不佳。一些关键的RAG设计决策包括文本嵌入、索引参数、检索算法、查询构建和提示设计,以及其他超出LLM配置的考虑因素。

另一个问题是可重复性:在不同运行、数据集和任务中实现一致且可比较的结果。训练数据的差异、预处理步骤、模型配置和硬件可能导致性能差异,使得研究人员和从业者难以复现研究成果并在此基础上构建新工作。此外,评估RAG系统也面临挑战,因为它们同时依赖于检索准确性和生成质量。这些系统需要一个复杂的评估套件,考虑到检索信息、数据形式化以及生成输出之间的相互作用。

论文介绍 RAG FOUNDRY,一个用于开发针对 RAG 应用场景的复杂检索增强型 LLM 的开源 Python 框架。该库支持研究人员和从业者在增强 LLM 在 RAG 应用场景中的能力这一精细任务中发挥作用。它高度可定制,便于在 RAG 的各个方面(包括数据选择、聚合与过滤、检索、文本处理、文档排序、少样本生成、使用模板进行提示设计、微调、推理和评估)进行快速原型设计和实验。

为了满足研究人员的特定需求,论文将框架设计为端到端实验环境。该库的核心由四个独立模块组成:数据创建、训练、推理和评估。每个模块都通过配置文件进行封装和控制,确保一个模块的输出与下一个模块的输入兼容。这种模块化方法允许每个步骤被隔离并独立实验,实现多个输出和同时执行多项实验。评估可以在生成的输出上进行,也可以在数据的任何特征上进行,包括检索、排序和推理。

2.2 论文的方法–RAG Foundry

RAG FOUNDRY框架促进了各种RAG设置和配置的快速原型设计和实验。该库由四个模块组成:数据集创建、训练、推理和评估。以下论文将详细介绍每个模块,并提供运行它们的示例配置

2.2.1 数据创建和处理

处理模块通过保存RAG交互来促进上下文增强数据集的创建,这对于面向RAG的训练和推理至关重要。这些交互包括数据集加载、列标准化、数据聚合、信息检索、基于模板的提示创建以及各种其他形式的预处理。处理后的数据可以以一致的、与模型无关的格式保存,连同所有相关的元数据一起,确保在不同模型和实验之间的兼容性和可重复性。

处理模块由一个抽象管道组成,包含多个步骤,每个步骤由实现特定数据处理功能的Python类定义。这些步骤分为两类:

•全局步骤:可以作用于整个数据集,适用于聚合、分组、示例过滤、连接操作等。

•局部步骤:作用于单个示例,适用于检索、文本处理和字段操作等任务。

这种模块化设计允许构建灵活高效的数据处理流程,以适应面向RAG的训练和推理需求。步骤可以分为以下非排他性类别:

•加载器:从Hugging Face1平台或本地源加载数据集。

•选择器:过滤示例、打乱数据集和选择子集数据集。

•检索器:集成来自外部数据库、工具、库和管道的信息。

•采样器:从任何数据集中收集随机示例或特征,以编译少样本或负面示例。

•提示生成器:使用自定义模板和关键字映射格式化提示。

处理模块支持同时处理多个数据集,通过全局数据集共享。这一特性允许流水线的每一步访问任何已加载的数据集,增强了灵活性并允许复杂的处理流程。此外,模块包括步骤缓存,缓存每个流水线步骤到本地。这提高了计算效率,并便于结果的轻松复现。

2.2.1.1 示例:增强问答数据集

为了展示处理模块的有效性,论文演示如何使用检索管道获取外部信息来丰富问答数据集,准备少样本示例,并使用提示模板将所有内容组合在一起。清单1演示了如何使用YAML配置定义这样的处理管道。

文件的主要结构是一系列步骤,每个步骤由指向步骤实现的target定义。每个步骤都有输入(inputs),可以是一个或多个要处理的数据集名称。步骤中的其他键与特定的步骤逻辑相关。

清单1中的前两个步骤从Hugging Face平台和本地路径加载数据集。第三个步骤从主数据集中随机打乱并选择10,000个示例。第四个步骤运行基于Haystack的检索管道,使用加载的数据集中的问题作为查询来检索相关段落,并将它们存储在docs_key中。论文注意到,在检索步骤中可以使用不同的检索过程或框架。第五步从次要数据集中选择3个少样本示例,之后是提示生成器步骤,该步骤加载提示模板并根据定义的映射字典替换所有给定信息。最后,数据集被保存到本地路径。

2.2.2 训练

论文提供了一个训练模块,用于根据前面处理模块创建的数据集对模型进行微调。训练模块依赖于成熟的训练框架TRL,并支持先进和高效的训练技术,例如LoRA。清单2展示了一个训练配置的例子。

2.2.3 推理

推理模块在给定由处理模块创建的已处理数据集的情况下生成预测。推理在概念上与评估步骤分离,因为它比评估在计算上要求更高。此外,可以在一个准备好的推理结果文件上运行多次评估。给定数据集生成预测的配置示例在清单 3 中展示。

2.2.4 评估

该框架的目标是增强LLMs用于RAG。评估模块允许用户运行一系列指标来评估RAG技术和调优过程。评估模块加载推理模块的输出并运行一个可配置的指标列表。指标是库中实现的类。这些类可以像其他评估库的包装器一样简单,也可以由用户实现。本地指标可以在单个示例上运行,如精确匹配(EM),而全局指标在整个数据集上运行,例如召回率(用于基于分类的指标)。指标可以使用数据集中的任何字段和元数据,而不仅仅是输入-输出对。库中实现的一些指标包括:Hugging Face评估库的包装器(wrapper for the Hugging Face evaluate library)、EM、F1、分类指标、BERTScore、语义相似性和DeepEval的包装器(wrapper for DeepEval,用于RAGAS 指标)。评估完成后,结果文件会写入磁盘,包含本地和全局指标结果。

清单 4 : 评估配置的示例;它包含一个答案处理器,以及要运行的指标列表,带有可选参数。

此外,评估模块使用一个称为“答案处理器”的处理步骤,该步骤可以实现自定义逻辑并服务于多种目的,包括清理和对齐输出;例如,使用正则表达式,可以隔离答案、移除停用词、进行思维链推理、定义停止标准、处理引用和归属以及任何其他给定评估所需的处理。

参见清单 4 以获取配置示例;它包含一个从输出中提取答案的答案处理器,以及一系列要运行的指标。

2.3 论文的效果–RAG 调优

为了展示 RAG FOUNDRY 库的使用和实用性,论文对 LLM 进行了几种可能的 RAG 改进实验,并在三个知识密集型任务上评估了结果。

2.3.1RAG 增强技术

论文探索了几种 RAG 增强技术,并使用 RAG FOUNDRY 轻松实现并评估其效益。作为初始步骤,论文评估了未经修改的模型;论文将基准设置为定义为运行未经修改的模型且不使用任何外部知识的配置。论文定义了一个 RAG 设置,该设置引入顶部相关文档,并以一致的提示模板格式与系统指令一起,以及一个指导模型使用检索到的上下文、解释步骤、引用相关部分并生成最终答案的 CoT 方案。

此外,论文探索了微调方案。论文在 RAG 设置中对模型进行微调,并将其表示为 RAG-sft。为了补充 CoT,论文实现了一个微调方案,记为 CoT-sft,引入于(Zhang et al., 2024),其中在提示中使用黄金文档和纯干扰文档,由概率决定,并与 CoT 提示一起使用。

2.3.2 数据集

论文在TriviaQA、PubmedQA和ASQA这三个知识密集型问答数据集上评估论文的模型,这些数据集受益于外部资源。TriviaQA和PubmedQA数据集包含相关上下文;对于ASQA,检索是在一个维基百科语料库上通过密集检索器完成的。

2.3.3 模型

论文实验了两种代表性模型:Llama-3和Phi-3,因为它们代表了强大的能力,并且是RAG用例部署的理想候选模型。

2.3.4 评估

论文测量并报告TriviaQA的精确匹配(EM),ASQA的STR-EM,PubmedQA的准确率和F1。此外,论文评估了两个RAGAS指标:忠实度和相关性。忠实度衡量生成文本与上下文之间的关系。相关性衡量生成文本与查询之间的关系。这两个指标使用上下文作为LLM批评器的输入,因此仅在RAG设置中相关。所使用的批评LLM是GPT4-32k,版本0613。相关性评估需要一个“嵌入器”。

2.3.5 结果

论文在TriviaQA、ASQA和PubmedQA数据集上进行了RAG增强技术的比较研究。结果如表1所示:主要指标针对每个数据集进行了展示,同时还包括了忠实度和相关性评分,如(Es et al., 2024)中所定义。对于TriviaQA,论文观察到以下情况:检索上下文改善了结果,微调RAG设置改善了结果,而在CoT推理上进行微调(包括在黄金段落和干扰段落的组合上进行训练)降低了性能。最佳方法取决于该数据集的模型。

对于ASQA,论文同样观察到每种方法都优于基线,CoT推理在两个模型中均产生了持续改进,同时对CoT配置进行微调也表现出最佳性能。最后,对于PubmedQA,论文观察到几乎所有方法都优于基线(有一个例外);CoT推理在未经训练的RAG设置上有所改进,但在微调后,RAG方法在两个模型中似乎表现最佳。

表1:基线和不同RAG设置的评估结果,针对三个数据集和两个测试模型。除了每个数据集的主要指标外,忠实度和相关性也针对相关配置进行了报告。根据主要指标,每个数据集的最佳配置以粗体显示

检查忠实度和相关性评分时,注意到并非所有配置都适合进行测量:这些指标需要上下文,因此与基线方法无关。此外,在PubmedQA数据集中,答案是二元的“是/否”;只有在CoT配置中,LLMs才会产生可以评估的推理。最后,忠实度和相关性评分往往与主要指标不相关,彼此之间也不相关,这可能表明它们捕捉了检索和生成结果的不同方面,并在性能上呈现出一种权衡。

结果表明,RAG技术对于提升性能是有用的,同时也需要在多样化的数据集上仔细评估RAG系统的不同方面,因为开发通用技术的努力仍在进行中。

如何学习AI大模型?

大模型时代,火爆出圈的LLM大模型让程序员们开始重新评估自己的本领。 “AI会取代那些行业?”“谁的饭碗又将不保了?”等问题热议不断。

不如成为「掌握AI工具的技术人」,毕竟AI时代,谁先尝试,谁就能占得先机!

但是LLM相关的内容很多,现在网上的老课程老教材关于LLM又太少。所以现在小白入门就只能靠自学,学习成本和门槛很高

针对所有自学遇到困难的同学们,我帮大家系统梳理大模型学习脉络,将这份 LLM大模型资料 分享出来:包括LLM大模型书籍、640套大模型行业报告、LLM大模型学习视频、LLM大模型学习路线、开源大模型学习教程等, 😝有需要的小伙伴,可以 扫描下方二维码领取🆓↓↓↓

👉[CSDN大礼包🎁:全网最全《LLM大模型入门+进阶学习资源包》免费分享(安全链接,放心点击)]()👈

学习路线

在这里插入图片描述

第一阶段: 从大模型系统设计入手,讲解大模型的主要方法;

第二阶段: 在通过大模型提示词工程从Prompts角度入手更好发挥模型的作用;

第三阶段: 大模型平台应用开发借助阿里云PAI平台构建电商领域虚拟试衣系统;

第四阶段: 大模型知识库应用开发以LangChain框架为例,构建物流行业咨询智能问答系统;

第五阶段: 大模型微调开发借助以大健康、新零售、新媒体领域构建适合当前领域大模型;

第六阶段: 以SD多模态大模型为主,搭建了文生图小程序案例;

第七阶段: 以大模型平台应用与开发为主,通过星火大模型,文心大模型等成熟大模型构建大模型行业应用。

在这里插入图片描述

👉学会后的收获:👈

• 基于大模型全栈工程实现(前端、后端、产品经理、设计、数据分析等),通过这门课可获得不同能力;

• 能够利用大模型解决相关实际项目需求: 大数据时代,越来越多的企业和机构需要处理海量数据,利用大模型技术可以更好地处理这些数据,提高数据分析和决策的准确性。因此,掌握大模型应用开发技能,可以让程序员更好地应对实际项目需求;

• 基于大模型和企业数据AI应用开发,实现大模型理论、掌握GPU算力、硬件、LangChain开发框架和项目实战技能, 学会Fine-tuning垂直训练大模型(数据准备、数据蒸馏、大模型部署)一站式掌握;

• 能够完成时下热门大模型垂直领域模型训练能力,提高程序员的编码能力: 大模型应用开发需要掌握机器学习算法、深度学习框架等技术,这些技术的掌握可以提高程序员的编码能力和分析能力,让程序员更加熟练地编写高质量的代码。

在这里插入图片描述

1.AI大模型学习路线图
2.100套AI大模型商业化落地方案
3.100集大模型视频教程
4.200本大模型PDF书籍
5.LLM面试题合集
6.AI产品经理资源合集

👉获取方式:
😝有需要的小伙伴,可以保存图片到wx扫描二v码免费领取【保证100%免费】🆓

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

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

相关文章

这一定是魔法!5个绝招解决苹果微信照片删除了怎么恢复问题

情景一:更新苹果手机系统后,重新打开微信却发现聊天记录中的照片不见了。 情景二:清理微信缓存数据以释放手机空间,再次打开微信发现聊天中的微信照片找不到了。 …… …… 类似于上述的情景在日常生活中时有发生,但…

【数据分享】1929-2024年全球站点的逐日降水量数据(Shp\Excel格式\1万多个站点)

气象数据是在各项研究中都经常使用的数据,气象指标包括气温、风速、降水、湿度等指标,说到常用的降水数据,最详细的降水数据是具体到气象监测站点的降水数据! 有关气象指标的监测站点数据,之前我们分享过1929-2024年全…

AI时代的价值盈利②:人工智能将如何改变SaaS应用的定价指标

介绍 随着行业和企业走上人工智能之旅,对每个投资者和商业领袖来说,最紧迫的问题之一是这种变革性技术将如何重塑他们的商业模式。GenAI有望释放巨大的价值,并有可能彻底改变消费者与服务或应用程序的交互方式。虽然它可能会带来巨大的成本&…

热门的蓝牙耳机中,哪种类型更受欢迎?四款热度高的开放式耳机

在如今的耳机市场中,开放式耳机异军突起,成为了众多消费者的新宠。如果你还在为传统入耳式耳机带来的不适而烦恼,那么开放式耳机绝对值得你一试。它不仅能让你在享受音乐的同时,依然可以清晰感知周围环境,保障你的安全…

函数与二元关系在编程中的应用

目录 引言 函数的基本概念与编程应用 二元关系与其在编程中的实现 函数与关系的高级编程应用 总结与应用 引言 函数与二元关系是计算机科学中描述元素间相互作用的核心工具。它们在算法设计、数据库管理、图论及各种建模任务中发挥着不可或缺的作用。掌握函数与二元关系的…

【代码】Swan-Transformer 代码详解(待完成)

1. 局部注意力 Window Attention (W-MSA Module) class WindowAttention(nn.Module):r""" Window based multi-head self attention (W-MSA) module with relative position bias.It supports both of shifted and non-shifted window.Args:dim (int): Number…

汽车的UDS诊断01

UDS(Unified Diagnostic Services):ISO14229中定义了汽车通用诊断协议;ISO15765规定了帧的格式; 1)UDS中的四种帧 UDS中的四种帧:单帧、首帧、流空帧、连续帧 图1 …

美团面试题:new Integer(“127“)和Integer.valueOf(“128“)有什么

🍅 作者简介:哪吒,CSDN2021博客之星亚军🏆、新星计划导师✌、博客专家💪 🍅 哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师 🍅 技术交流:定期更新…

Windosw下Visual Studio2022编译安装VTK(支持QT),ITK

VTK(Visualization Toolkit)是一个开源的、跨平台的三维可视化开发库,用于处理和可视化三维数据。它提供了一系列算法和工具,用于创建、操作和渲染复杂的三维图形,并支持多种数据表示方式,包括点、线、面、…

桔子哥/基于云快充协议1.5版本的充电桩系统软件-充电桩系统 -新能源车充电平台源码

基于云快充协议1.5版本的充电桩系统软件 介绍 SpringBoot 框架,充电桩平台充电桩系统充电平台充电桩互联互通协议云快充协议1.5-1.6协议新能源汽车二轮车公交车二轮车充电-四轮车充电充电源代码充电平台源码Java源码 软件功能 小程序端:城市切换、附…

植物神经紊乱也不怕!吃出好心情,饮食调整秘籍大公开

Hey小伙伴们~👋 今天我们来聊聊一个可能听起来有点陌生但又挺常见的健康问题——植物神经紊乱。是不是有时候感觉心跳加速、呼吸不畅、还容易失眠多梦?别怕,除了专业治疗,饮食调整也是超级重要的一环哦!🍽️…

想要不得痉挛性斜颈?做这六件事!

一、保持良好的坐姿和站姿 长期不正确的姿势会给颈部肌肉带来过大的压力,增加痉挛性斜颈的发病风险。无论是工作还是休息,都要时刻提醒自己保持挺胸抬头、肩膀放松、颈椎正直的姿势。比如,在办公时,调整电脑屏幕的高度和角度&…

2024东湖高新区下半年水测报名开始啦

东湖高新区下半年职称评审水测报名开始啦,报名时间8月3--8月16号,马上报名截止了!! 请想明年拿证的需要先准备论文和软著 中级工程师职称基本评审条件:1、专科及以上学历2、大学理工类专业3、专科工作满七年&#xf…

【FreeRTOS】队列实验-多设备玩游戏(旋转编码器)

目录 0 前言1 任务1.1 本节源码1.2实验目的1.3实现方案 2 code2.1 创建队列2.2 写队列2.3 创建任务 3 勘误 0 前言 学习视频: 【FreeRTOS入门与工程实践 --由浅入深带你学习FreeRTOS(FreeRTOS教程 基于STM32,以实际项目为导向)】…

基于SpringBoot+Vu e.js校园疫情防控系统的设计与实现

文章目录 前言具体实现截图详细视频演示技术栈系统测试为什么选择我官方认证玩家,服务很多代码文档,百分百好评,战绩可查!!入职于互联网大厂,可以交流,共同进步。有保障的售后 代码参考数据库参…

轮换IP与固定IP,如何抉择?

IP地址相信大家都知道,它是标识我们网络身份的重要凭证。从访问网站到数据抓取,都能看到IP地址的身影。那么,轮换IP和固定IP该怎么理解呢?本文将详细介绍这两种IP类型,旨在帮助你根据需求做出合适的选择。 什么是固定I…

VM Ubuntu22.04 ROS2 从头安装

目录 前言安装步骤1 设置编码2 添加ROS2软件源(从哪去下载ros2相关软件)报错解决方法 3 安装报错解决方法1解决方法2 报错 4 设置环境变量5 Ros2 测试Hello World 发送和监听小海龟键盘控制 成功 Hello World 发送和监听界面成功控制小海龟界面 前言 本…

OpenAI发布微调功能 允许企业客户定制AI模型

当地时间8月20日,OpenAI发布了一项新功能,允许企业客户使用他们自己的公司数据来定制其最强大的模型GPT-4o,这将大大提高应用程序的性能和准确性。此举出台之际,初创企业在人工智能(AI)产品上面临着日益激烈…

MySQL 高阶三 (索引性能分析)

执行过程 Explain explain select * from student s, course c , student_coure sc where s.id sc.studentid and c.id sc.courseid;EXPLAIN执行计划各字段含义: 【ld】 id相同,执行顺序从上到下; id不同,值越大,越先执行)。 【select_type…

【论文学习与撰写】快捷搜索指令filetype:pdf,搜索引擎关键词搜索pdf格式文件或者word格式文件。文献搜索方法大全。

1、使用快捷搜索指令 在搜索框中输入:关键词空格filetype英文冒号文件格式 (如:关键词 filetype:pdf)。 通过这种方式,搜索引擎会限定搜索结果只显示 PDF 格式的文件。 比如搜索“2018 年考研英语真题 filetype:pd…