FastRAG半结构化RAG实现思路及OpenAI O1-long COT蒸馏路线思考

360影视 2024-12-18 14:01 4

摘要:另一个是还是回归到RAG上,最近同名的RAG框架很多,例如fastRAG(https://github.com/IntelLabs/fastRAG.git,朴素rag的一个模块化)和FastRAG(https://arxiv.org/html/2411.137

文章转自公众号老刘说NLP

本文看两个问题,一个是最近模仿openaiAI O1现有路线-long COT蒸馏路线,有些有趣的点。

另一个是还是回归到RAG上,最近同名的RAG框架很多,例如fastRAG(https://github.com/IntelLabs/fastRAG.git,朴素rag的一个模块化)和FastRAG(https://arxiv.org/html/2411.13773)。我们来看看具体后者,其重点是面向半结构化数据做的,也可以再次温习下GraphRAG。

我们可以从中找到一些思路,多思考,多总结,多实践;

一、最近模仿OpenAI O1现有路线-long COT蒸馏路线

最近模仿openAI O1的工作很多,例如DeepSeek-R1-Lite-Preview(techreport还未出,技术细节不明确)、Marco-o1(https://arxiv.org/abs/2411.14405,结合了CoT微调、蒙特卡洛树搜索MCTS、反思机制)。

但很多工作都是基于蒸馏cot(应该叫long-cot) 的方式来做的,例如前几写的文章,其实,回过头来讲,o1这个还是不能盲目模仿,技术这东西还是参透本质后做出来才更扎实。 目前想做o1的比较快的就是合成一些思维链 ,使用更大的模型蒸馏一把。大的,正确率也不高。 或者全靠人工step by step的去标,成本也比较高。

但是,蒸馏这个事情,蒸馏的上限是base,这个提升是怎么来的,这个很其妙。

最近有个工作,https://github.com/GAIR-NLP/O1-Journey#about-the-team,发现,通过简单的知识蒸馏方法,以Qwen2.5-Math-72B作为基础模型,经过精心设计数据筛选和处理流程(从开源数据集NuminaMath-CoT上选取部分奥林匹克级别的问题作为起点,并设计规则移除依赖图像的问题、缺乏明确标注答案的问题以及所有证明题,仅保留答案类型为数值的问题。此外,还利用GPT-4o-mini重写原始解答。重写过程遵循特定的标准,确保解答的步骤是细粒度的、高度详细的,并且篇幅更长,并还规范化输出格式),使用数万个从o1蒸馏的 长思考链样本(注意,现在有个新名词,叫long-cot) 进行训练。

最后,在美国高中数学邀请赛 (AIME) 等权威测试中,模型表现优于o1-preview,这种复现秀,改工作也抛出来了一个新问题,很赞同,也就是,蒸馏方法成为了一条捷径。

二、FastRAG的半结构化RAG提速实现思路

关注RAG进展,半结构化数据的检索增强生成,《FastRAG: Retrieval Augmented Generation for Semi-structured Data 》(https://arxiv.org/html/2411.13773),其核心宣传点,就是它的“快”,并且与GraphRAG(“From local to global: A graph rag approach to query-focused summarizatio)进行对比,但其实没有太多可比性,因为目的不同,处理的任务不同,后者做了大量实体抽取、摘要生成、社区生成等,有个对比结果,仅供参考:

在具体表现上,FastRAG在处理日志数据集时总时间为3.9分钟,而GraphRAG为40.0分钟;在处理配置文件数据集时,FastRAG总时间为2.0分钟,而GraphRAG为6.3分钟。

另一个就是,对于Glocalsearch方面,在处理包含具体值(如名称或类型)的查询时表现不佳,因为它难以精确匹配这些值。这导致在某些情况下,GraphRAG无法提供有用的答案。

对于globalsearch方面,GraphRAG在总结和报告任务中表现高效,但在处理复杂的网络数据时,可能会遇到资源消耗和延迟的问题,这可能限制其在更大规模网络数据中的可扩展性。

既然说到快,那么,如何快的?

整体流程如下

核心点在于四个点:

1、样本选择 Samples Selection(包括关键词提取和块选择两个步骤。关键词提取通过K-means聚类算法从源数据中提取关键词,块选择则基于块的信息多样性选择样本块),这么做是为了减少处理时间和成本,所以选择代表性的块进行学习提示。但其实这块有依赖于样本选择,存在遗漏小部分信息的风险。

2、模式学习Schema learning(使用LLM生成JSON模式,即顶层实体类型和属性的JSON模式),这块其实也有损;

3、脚本学习Script learning(类似于模式学习,脚本学习通过迭代提示LLM生成解析函数,并逐步优化这些函数),如下图所示,使用第一个样本块提示LLM生成解析函数。通过提交新的样本块,迭代优化解析函数的语法和功能正确性。每个部分独立处理,使用相应的解析函数,确保LLM能够集中注意力在每个实体类型上,并进行有针对性的优化,这个点比较重要,其目的是为了让这个模式尽可能覆盖住所有chunk),如下图,Schema learning (top) and script learning (bottom)

4、信息检索Information Retrieval(包括文本搜索Text Search(利用NLP方法进行文本搜索,优点是能够处理模糊查询,缺点是可能无法返回足够详细的信息);知识图谱查询KG Querying(将提取的实体插入到知识图谱中,并使用图查询语言(GQL)进行信息检索。优点是可以提供结构化且精确的信息检索,缺点是在处理具体值查询时可能不够灵活);组合查询Combined Querying(同时使用KG查询和文本搜索,通过LLM生成一个结合两种方法的GQL语句,优点是能够提供丰富且详细的答案,缺点是可能需要更多的计算资源)和混合查询Hybrid Querying(合并KG查询和文本搜索的能力,生成一个能够利用任何相关特征的GQL语句。优点是能够提供全面的答案,缺点是对查询的构建要求较高,偶尔可能会出现不准确的情况)。

其实,其中有个很重要的点,就是,它为啥叫"Semi-structured Data"(半结构化数据)?它主打的点是这块。

一般来说,半结构化数据指那些不完全遵循预定义模式或格式的数据,但仍然包含某种程度的组织或结构。与完全无结构的数据(如纯文本或图像)相比,半结构化数据通常包含一些标记、标签或其他元数据,这些元素可以帮助识别和提取有用的信息。

例如,在网络管理中,日志文件和配置文件通常被视为半结构化数据,所以FastRAG也是针对这类数据做的。

总结

本文看两个问题,一个是最近模仿openaiAI O1现有路线-long COT蒸馏路线,有些有趣的点。

另一个是FastRAG(https://arxiv.org/html/2411.13773,其重点是面向半结构化数据做的,也可以再次温习下GraphRAG。

我们越来越认识到,技术在不断变化,但总会有很多阵痛,现在自媒体的内容创作很混乱,有其实技术类的同质化、夸大标题党,翻车的事情层出不穷(这会让很多人产生误导和误判,本身具有判断力的人其实并不占多数,并不好啊),技术是个严谨的事儿,我们需要保持一定专业性和严谨性。

对技术保持崇敬,总是会好的,大家一起共勉。

乐观、长期地看待一些技术点,一些趋势,将会更加美好。

参考文献

1、https://arxiv.org/html/2411.13773

2https://github.com/GAIR-NLP/O1-Journey#about-the-team



来源:360亿方云

相关推荐