GraphRAG与传统RAG怎么选?二者的融合方案是什么

最近工作比较忙,一直在重构公司现有的RAG推荐系统。在给GraphRAG提交了几个PR并成功合并后,暂时没有继续对GraphRAG做出更多贡献。然而,最近同事和粉丝纷纷私信我,他们最常问的问题有:“什么时候应该使用GraphRAG?”,“在哪些场景下应该使用传统的RAG"以及"我们目前在公司使用的是传统RAG,那要如何与GraphRAG相结合呢?”。为了系统地解答这些问题,我决定写一篇文章,对这些问题进行详细的探讨。我将先从多个方面解释GraphRAG和传统RAG的区别,然后给出二者如何结合的简单思路。

知识库数据特征

GraphRAG

在GraphRAG框架下,我们能够将产品、品牌、类别以及用户兴趣视作相互联系的实体,也即图形的节点。例如:

  • 产品:华为P50 Pro

  • 摄像头:莱卡四摄

  • 品牌:华为

  • 类别:智能手机

  • 用户兴趣:高清摄影、适合游戏、旗舰机型

华为P50 Pro 可被关联至“华为”这一品牌、“智能手机”这一类别,“高清摄影”、“游戏”以及“旗舰机型”这些用户兴趣点上,这种图形化的表示方式对于推荐相关产品十分有用

传统RAG

传统的RAG可能会选择将以上数据以一个文本块的形式进行存储:

HUAWEI P50 Pro是一款具备徕卡四射的华为旗舰机,搭载有XD Fusion Pro原色引擎、XD Optics计算光学技术、XD Fusion Pro超级滤光系统等华为影像技术,可以提升手机在拍摄时的成像质量。主摄采用了5000万像素原色镜头,可以记录拍摄场景的肉眼色彩观感。   

因此,当用户搜寻“优秀摄影效果的手机”时,系统会基于语义匹配来找出这个文本块。

然而,GraphRAG的优势就体现在,它可以轻松地在图形结构中寻找“其他使用莱卡摄像头的手机”。相较之下,传统的RAG如果没有明确符合这一需求的文本块,就需要依赖编程来进行查询分解与处理计划。

知识库检索

拿产品推荐系统举例,考虑一个用户的查询:“有哪些适合长时间佩戴并且具有降噪功能的耳机?”

  • GraphRAG系统中,这个查询可以从“耳机”节点出发,探索多个与耳机相关的产品节点。系统会首先检索这些产品的“特性”节点,寻找那些与“长时间佩戴舒适性”相关的耳机;然后,系统会进一步检索与“降噪功能”相关的特性节点,找到符合条件的耳机产品。通过这种多维度的关联筛选,GraphRAG能够为用户推荐既舒适又具备降噪功能的耳机,精确满足用户的需求。

  • 在**传统的 RAG **系统中,系统会尝试通过关键词如“智能手机”、“高质量视频”、“良好口碑”等来搜索对应的文本块。然而,如果存储的文本块中没有同时包含这些关键词的相关信息,系统可能会返回一些只与部分关键词匹配的内容,这样的推荐可能并不能完全满足用户的需求。比如,系统可能会推荐一款虽然具备高质量视频功能,但在用户评价方面表现平平的智能手机。

所以我们可以得出结论:GraphRAG 在应对复杂查询、跨越多个特性进行检索时,具有显著优势。

知识库治理

随着数据量的不断增加,GraphRAG 能够通过自然地新增节点与关系,将新信息无缝集成到现有的知识图谱中,无需对已有数据进行大规模重组。其结构化和层次化的特性使得数据检索更加高效。GraphRAG 利用先进的图遍历算法和层次化导航技术,能够迅速缩小检索范围,提升查询速度。

例如,一个用户可能会从广泛的“电子产品”开始查询,然后逐步缩小范围到“智能手机”,再进一步到“适合游戏的高性能智能手机”。这种层次化的检索方式,即便在面对庞大的数据集,也能通过有效的导航快速定位到相关信息。此外,GraphRAG 还可以利用社区反馈和用户行为数据进一步优化检索路径,提高命中率。但是GraphRAG对于新增的数据会重新进行社区检测,这一步还是比较耗费资源的。

相比之下,传统的 RAG 系统主要依赖于文本块来存储数据,这些数据块往往是非结构化或半结构化的。随着知识库的扩展,新增的数据可能需要重新组织现有的文本块,甚至可能导致相似内容的多版本重复存储,存储效率较低且管理困难。数据规模的增加还显著影响系统的检索性能,面对复杂或模糊的查询时,容易受到噪音数据的干扰。

例如,当用户查询“高性能智能手机”和“游戏”相关的内容时,如果数据库中存在大量类似但不相关的文本块,系统可能会返回大量冗余结果。要过滤这些不相关的内容,传统的 RAG 系统可能需要引入复杂的重排序算法,这不仅增加了系统的复杂性,也显著降低了检索效率。

概要性(QFS)查询

GraphRAG

知识图谱的结构化特征使其在处理数据本身的“元”问题时表现出色,例如“2023年市场上新发布了多少款搭载骁龙8Gen2芯片的手机?”。

Microsoft GraphRAG 针对非结构化文本构建了一个专门的框架,其设计的核心目标之一是能够更好地回答基于高层语义理解的总结性问题。通过社区检测算法,GraphRAG 可以识别并划分知识图谱中的多个社区,然后利用大规模语言模型(LLM)对这些社区进行总结和概括。Microsoft GraphRAG 会先通过Map-Reduce算法从多个关联社区(例如不同年份的社区)中搜集有关“高端智能手机”的信息(Map),然后汇总这些信息以生成全面的答案(Reduce)。

“元信息”(Metadata)是关于数据的数据。在计算机科学中,元信息用于描述其他数据的属性,包括创建日期、作者、位置和文件大小等。这样的信息对数据的管理和处理非常有用。

"元信息问题"则是指那些需要查询或处理元信息的问题。例如,“这张照片是谁拍的?”、“这份报告是何时编写的?”等。在知识图谱中,元信息可能包括实体的类型、属性、以及它们之间的关系等,因此,“元信息问题”可能涉及到的是如何从知识图谱中抽取或推导出有关这些元信息的问题。

传统RAG

传统的RAG方法可能会检索到包含“高端智能手机”、“发展”或“最近几年”等关键词的文本片段,但难以将这些片段有机地串联起来,形成一个连贯的趋势叙述。结果往往是片段化的信息,难以全面回答查询。

隐藏关系

GraphRAG其更容易通过图谱中的隐形关系来理解上下文;而传统RAG则更依赖在明确的文本块中显性的匹配关联,在理解隐性关系时存在局限。

GraphRAG

在 GraphRAG 中,“iPhone 15 Pro” 和 “三星S24” 可能被理解为是相关的,即使在任何文本块中没有直接将它们进行比较。因为它们都属于“高端智能手机”类别,并且在”手机摄影”特性上表现突出。GraphRAG 可以理解这些产品的共同特性,将它们自然地联系起来。

在这里插入图片描述

因此当用户查询“和iphone15 pro有相同能力的手机”时,GraphRAG 可以基于这些隐性关联提供更全面的推荐。

传统RAG

而在传统 RAG 中,系统只能根据文本块中明确提到的内容进行理解。如果某个文本块没有同时提到 “iPhone 15 Pro” 和“三星S24”,传统 RAG 可能无法将这两个产品联系起来。

应用场景

选择使用传统RAG还是GraphRAG主要取决于数据特征和查询需求,这两者构成了其适用性上的关键区别。一般来说,以下特征的数据更适合使用GraphRAG:

数据中包含大量相互关联的实体和复杂的关系,并且结构较为清晰。例如:

  • 社交网络中的用户关系:如朋友、家庭成员、同事之间的联系。

  • 企业内部的复杂关系:包括部门架构、供应链网络、客户关系等。

  • 医疗数据:涵盖疾病、症状、治疗方法、药品以及病例等复杂关联。

  • 法律数据:涉及法律条文、判例之间的引用关系、解释与适用情况等。

  • 产品推荐系统:涉及到产品、用户、浏览内容、不同产品之间的关联、用户之间的关系等。

除了数据特征外,查询需求也是选择算法的重要考量。GraphRAG更擅长处理涉及复杂关系、语义推理和多步逻辑关联的查询,或者关于知识本身元数据的问题。。例如:

  • 多跳关系查询:如“某人的同事的朋友中,谁在某公司工作?”

  • 语义关联查询:如“哪些公司提供某类产品并已获得官方认证?”

  • 知识推理查询:如“根据患者的症状和病史,推断可能的疾病并建议治疗方案。”

  • 时序关联查询:如“查询某公司过去十年的投资和并购情况?”

对于这些复杂查询,GraphRAG提供了更强的导航与综合分析能力。而传统RAG则更适合处理基于数据内容的具体事实性问题,对复杂关系的处理则较为有限。

性能成本

虽然GraphRAG在数据扩展性方面表现出色,但在实际应用中,其在索引创建和查询处理过程中引入的复杂性和计算开销不容忽视。特别是在索引阶段,GraphRAG需要进行实体和关系的提取与识别,生成必要的描述信息,识别社区并生成摘要;而在查询处理阶段,则需检索更多关联的节点、关系和社区信息。这些额外的步骤对简单查询任务来说,尤其是那些传统RAG也能有效处理的问题,可能显得不太经济。

尽管GraphRAG生成的结果更为详尽,但其所需的时间和token数量(LLM调用)几乎是传统RAG的十倍。因此,使用GraphRAG时,务必权衡其性能与成本,确保在合适的场景下发挥其优势。

GraphRAG和传统RAG如何结合

总的来看,GraphRAG在处理复杂且高度相互联系的数据集和需要深度关联理解的查询上,显示出了强大的效能。它可以显著提升信息查找的准确性和深入程度,尤其是在需要进行多级分析和推导的情况下。然而,这种性能提升也带来了系统复杂度和资源使用量的增加。因此,在决定是否采用 GraphRAG 之前,必须仔细分析具体的应用场景、数据结构以及典型的查询模式。

在以下情况下,传统 RAG 仍然是更理想的选择:

  • 简单且基于事实的查询:例如,对于“iPhone 13 的发布日期是什么?”这样的简单问题,传统 RAG 能够更迅速和明确地给出答案。

  • 较低的实施难度:在数据集较小或应用场景不复杂时,传统RAG的配置与维护过程较为简单,便于快速实施和操作。

在实际使用场景中,往往一个单一的搜索策略难以覆盖所有需求。为了达到最优效果和准确率,我们可以考虑创建一个智能路由系统,这个系统会根据问题的类别和可获得数据的属性,动态地挑选出最适合的搜索策略。关键点在于搭建一套强大的路由系统(通常需要借助LLM来完成),这样就能够聪明地将查询指向最佳的搜索路径。

如何学习大模型 AI ?

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

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

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

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

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

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

在这里插入图片描述

第一阶段(10天):初阶应用

该阶段让大家对大模型 AI有一个最前沿的认识,对大模型 AI 的理解超过 95% 的人,可以在相关讨论时发表高级、不跟风、又接地气的见解,别人只会和 AI 聊天,而你能调教 AI,并能用代码将大模型和业务衔接。

  • 大模型 AI 能干什么?
  • 大模型是怎样获得「智能」的?
  • 用好 AI 的核心心法
  • 大模型应用业务架构
  • 大模型应用技术架构
  • 代码示例:向 GPT-3.5 灌入新知识
  • 提示工程的意义和核心思想
  • Prompt 典型构成
  • 指令调优方法论
  • 思维链和思维树
  • Prompt 攻击和防范

第二阶段(30天):高阶应用

该阶段我们正式进入大模型 AI 进阶实战学习,学会构造私有知识库,扩展 AI 的能力。快速开发一个完整的基于 agent 对话机器人。掌握功能最强的大模型开发框架,抓住最新的技术进展,适合 Python 和 JavaScript 程序员。

  • 为什么要做 RAG
  • 搭建一个简单的 ChatPDF
  • 检索的基础概念
  • 什么是向量表示(Embeddings)
  • 向量数据库与向量检索
  • 基于向量检索的 RAG
  • 搭建 RAG 系统的扩展知识
  • 混合检索与 RAG-Fusion 简介
  • 向量模型本地部署

第三阶段(30天):模型训练

恭喜你,如果学到这里,你基本可以找到一份大模型 AI相关的工作,自己也能训练 GPT 了!通过微调,训练自己的垂直大模型,能独立训练开源多模态大模型,掌握更多技术方案。

到此为止,大概2个月的时间。你已经成为了一名“AI小子”。那么你还想往下探索吗?

  • 为什么要做 RAG
  • 什么是模型
  • 什么是模型训练
  • 求解器 & 损失函数简介
  • 小实验2:手写一个简单的神经网络并训练它
  • 什么是训练/预训练/微调/轻量化微调
  • Transformer结构简介
  • 轻量化微调
  • 实验数据集的构建

第四阶段(20天):商业闭环

对全球大模型从性能、吞吐量、成本等方面有一定的认知,可以在云端和本地等多种环境下部署大模型,找到适合自己的项目/创业方向,做一名被 AI 武装的产品经理。

  • 硬件选型
  • 带你了解全球大模型
  • 使用国产大模型服务
  • 搭建 OpenAI 代理
  • 热身:基于阿里云 PAI 部署 Stable Diffusion
  • 在本地计算机运行大模型
  • 大模型的私有化部署
  • 基于 vLLM 部署大模型
  • 案例:如何优雅地在阿里云私有部署开源大模型
  • 部署一套开源 LLM 项目
  • 内容安全
  • 互联网信息服务算法备案

学习是一个过程,只要学习就会有挑战。天道酬勤,你越努力,就会成为越优秀的自己。

如果你能在15天内完成所有的任务,那你堪称天才。然而,如果你能完成 60-70% 的内容,你就已经开始具备成为一名大模型 AI 的正确特征了。

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

在这里插入图片描述

  • 18
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值