GraphRAG:基于知识图谱的RAG,好用,贼贵!

news/2025/2/28 19:40:41/文章来源:https://www.cnblogs.com/caituotuo/p/18606738

转载请注明出处❤️

作者:测试蔡坨坨

原文链接:caituotuo.top/7d21f69b.html


你好,我是测试蔡坨坨。

在往期文章中,我们探讨了RAG的应用。然而,在实际使用过程中,我们发现传统RAG的表现并未完全满足预期(例如:在处理数据时,使用默认效果不佳,切片乱七八糟。因此需要花费很大精力去处理数据,比如编写文档时统一规范、使用一些工具/脚本对数据源进行预处理和清洗,这些比起AI本身的价值更大)。

为解决传统RAG的局限性,一种基于图结构的RAG应用应运而生,它被称为GraphRAG

本篇文章,我们就来探索GraphRAG的魅力,看它是否真的能带来意想不到的惊喜。

什么是GraphRAG?

官网:https://microsoft.github.io/graphrag

微软开源的一项结合了知识图谱检索增强生成技术

简单来说,它可以显著提升AI知识库的性能,让AI能根据你提供的文档,更准确地回答你提出的复杂问题。

为什么需要GraphRAG?

关于AI知识库,传统的RAG即使结合了私有知识库,但是在使用过程中还是有很多值得吐槽的点,比如:精确度不够、AI总是回答不到点上。

这个问题的根源之一其实是传统RAG的局限性,当我们用这套技术去搭建知识库时,整个索引和检索的过程,都是基于文本块的。简单来说,就是我们把一个大的文档给切碎,变成一个又一个小的文本块,当有请求过来的时候,就根据请求去寻找哪些文本块是最相关、最匹配的,最后把找到的文本块作为参考资料,连同请求一起给到大模型。

这套技术有两个局限性:

  1. 无法有效捕捉实体之间的复杂关系和层次结构
  2. 通常只能检索固定数量的、最相关的文本块

也就导致了传统RAG在面对复杂查询的时候特别吃力。

为了补上传统RAG的短板,微软推出并且开源了GraphRAG,它的优势就是全局性

Github:https://github.com/microsoft/graphrag

GraphRAG在对数据集建立索引的时候,会做两件事:

  1. 提取实体 Entity
  2. 提取实体之间的关系

从视觉上看,这些实体就是一个又一个的点,而有关联的两个实体,它会用线连接起来,于是一张庞大的知识图谱就形成了,这也是它名字里Graph的来源。

因为要表达复杂的关系,一个有效的手段就是利用图谱。

使用了知识图谱,GraphRAG能够把握复杂的、细微的数据关系,所以它才能构建一种全局性的优势,从而提升RAG的精确度。

如何使用GraphRAG?

官方文档:https://microsoft.github.io/graphrag/get_started

1. 安装GraphRAG

pip install graphrag

要下载的东西贼多,得耐心等待……

2. 创建目录

mkdir -p ./ragtest/input

3. 在ragtest/input文件夹中存入文档

在这里放入你的文档,目前只支持txt、csv。

官网给的示例文档查尔斯·狄更斯的《圣诞颂歌》:

curl https://www.gutenberg.org/cache/epub/24022/pg24022.txt -o ./ragtest/input/book.txt

PS:如果你用的OpenAI,不要跑这个文件,200页 11$ 贼贵…… 就…… 离谱

4. 初始化项目

graphrag init --root ./ragtest

运行完命令后会看到多了几个文件,其中最重要的两个文件:

  1. .env文件,在里面填上OpenAI API Key
  2. settings.yaml文件,用来设置encoding和embedding所需要的模型及各种参数,使用本地大模型的话就在这里配置

5. 开始创建索引

graphrag index --root ./ragtest

6. 开始进行问答

graphrag query \
--root ./ragtest \
--method global \
--query "What are the top themes in this story?"
graphrag query \
--root ./ragtest \
--method local \
--query "Who is Scrooge and what are his main relationships?"

使用本地大模型

settings.yaml文件中修改大语言模型和嵌入式模型:

本地大模型在配置上没什么问题,但是在运行时贼慢,一个是建立索引时提取时间非常漫长,另一个是嵌入时也非长漫长,相比于GPT4几分钟就完成了,本地llama3 8b体量上还是有点差距的。在实际应用中一个200页的大文档要处理半个小时,显然也是不合理的。也许这就是微软要开源的原因?依靠社群的力量去优化它。

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

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

相关文章

2024-2025-1 学号20241315《计算机基础与程序设计》第十二周学习总结

作业信息这个作业属于哪个课程 2024-2025-1-计算机基础与程序设计)这个作业要求在哪里 <作业要求的链接>https://www.cnblogs.com/rocedu/p/9577842.html#WEEK12这个作业的目标 <写上具体方面>《C语言程序设计》第11章并完成云班课测试作业正文 https://www.cnblo…

2024-2025-1 20241318 《计算机基础与程序设计》第十二周学习总结

这个作业属于哪个课程 https://edu.cnblogs.com/campus/besti/2024-2025-1-CFAP这个作业要求在哪里 https://www.cnblogs.com/rocedu/p/9577842.html#WEEK12这个作业的目标 <自学教材《C语言程序设计》第11章并完成云班课测试>| |作业正文|https://i.cnblogs.com/posts/e…

集合的数据筛选

1.集合的数据筛选 1.创建集合,并封装数据2.许愿有一个方法,可以判断年龄,然后alt+回车创建该方法(忽略这里未封装数据)3.在方法中,创建新的集合,存储年龄小于18的对象4.遍历list集合,每一个元素都有可能小于18,再使用if判断,将满足条件的元素存入newlist集合5.在主方法…

转载:【AI系统】动手实现自动微分

在这章内容,会介绍是怎么实现自动微分的,因为代码量非常小,也许你也可以写一个玩玩。前面的文章当中,已经把自动微分的原理深入浅出的讲了一下,也引用了非常多的论文。有兴趣的可以顺着综述 A survey 这篇深扒一下。 前向自动微分原理 了解自动微分的不同实现方式非常有用…

基于.NET8+Vue3开发的权限管理个人博客系统

前言 今天大姚给大家分享一个基于.NET8+Vue3开发的权限管理&个人博客系统:Easy.Admin。 项目介绍 Easy.Admin是一个基于.NET8+Vue3+TypeScript开发的权限管理&个人博客系统,分为普通版本和SSR(服务端渲染,支持SEO),服务端渲染框架基于vite-plugin-ssr实现,并且支…

spring-boot-devtools 实现热部署

1.devtoolsspring为开发者提供了一个名为spring-boot-devtools的模块来使Spring Boot应用支持热部署,提高开发者的开发效率,无需手动重启Spring Boot应用。 2.项目搭建本文是采用IDEA搭建的Spring Boot应用,通过spring-boot-devtools配置,可以支持修改java文件会自动重启程…

IDEA bean json互转换插件

插件安装步骤:File->Settings->Plugins—>查找所需插件—>Install 或 File->Settings->Plugins—>Install plug from disk —>选择下载好的插件安装 一般插件安装后重启idea即可生效。 一、Java bean 转换 json 的插件 java-bean-to-json 下面详细安装…

转载:【AI系统】计算图的调度与执行

在前面的内容介绍过,深度学习的训练过程主要分为以下三个部分:1)前向计算、2)计算损失、3)更新权重参数。在训练神经网络时,前向传播和反向传播相互依赖。对于前向传播,沿着依赖的方向遍历计算图并计算其路径上的所有变量。然后将这些用于反向传播,其中计算顺序与计算图…

转载:【AI系统】微分实现方式

上一篇文章简单了解计算机中常用几种微分方式。本文将深入介绍 AI 框架离不开的核心功能:自动微分。 而自动微分则是分为前向微分和后向微分两种实现模式,不同的实现模式有不同的机制和计算逻辑,而无论哪种模式都离不开雅克比矩阵,所以我们也会深入了解一下雅克比矩阵的原理…

React16

React16免费基础视频教程 https://www.bilibili.com/video/BV1g4411i7po P1 01_React免费视频课程介绍 https://jspang.com 2019 5年前 react16 16.8.6 https://react.dev/ P2 02_React简介和Vue的对比 P3 03_React开发环境的搭建 npm i -g create-react-app@3.0.0 create-reac…

Input type (torch.cuda.FloatTensor) and weight type (torch.FloatTensor) should be the same

错误报在了forward里的Conv2d处。原因是函数写在forward里可能默认cpu,如果写在init构造函数里,就不需要再指定cuda。 修改为箭头指示就不再报错了。 【参考】 Input type (torch.cuda.FloatTensor) and weight type (torch.FloatTensor) should be the same-CSDN博客

jquery半透明拖拽窗口插件

这是一款jquery半透明拖拽窗口插件。该插件可以在页面生成可以拖拽、最大化、最小化的浮动窗口。在线演示 下载使用方法 在页面中引入style.css、jquery和jquery-translucent.js文件。<link rel="stylesheet" type="text/css" href="style.css&quo…