现有 RAG 框架几乎完全局限于文本内容。真实的知识库本质上是多模态的,包含文本、视觉元素(图表、图像)、结构化表格和数学表达式的丰富组合。

RAG-Anything 建立了一种新的多模态知识访问范式,消除了现有系统中的架构碎片化,为处理复杂、真实的知识环境提供了全面的解决方案。RAG-Anything作出了如下改进:

  1. 统一的多模态表示:双图构建 (Dual-Graph Construction)
  2. 跨模态检索机制:跨模态混合检索 (Cross-Modal Hybrid Retrieval)

unsetunsetRAG-Anything 框架概述unsetunset

RAG-Anything 是一个统一的 RAG 框架,专门为解决现有系统仅限于文本的限制而设计,使 LLMs 能够利用来自图像、表格、公式和各种文本的异构多模态知识。

该框架由三个核心组件构成:

  1. 通用索引(Universal Indexing):用于多模态知识的统一表示。
  2. 跨模态自适应检索(Cross-Modal Adaptive Retrieval):结合结构导航和语义匹配。
  3. 知识增强的响应生成(Knowledge-Enhanced Response Generation):利用 VLM 进行信息合成。

1. 通用异构知识表示 (Universal Representation)

传统方法只是将文档解析为文本段落,而 RAG-Anything 引入了多模态知识统一 (Multimodal Knowledge Unification) 过程。

  • 原子知识单元分解: 将原始输入分解为原子内容单元 ,其中 是模态类型(如 text, image, table, equation), 是相应的内容。
  • 结构和语义完整性: 确保非文本元素(如图表、公式)与其标题、周围定义保持结构上的关联。
  • 专业解析器: 使用专门的解析器处理不同内容类型(例如,LaTeX 公式识别、表格结构解析),以保证高保真提取。

RAG-Anything 采用双图策略来整合结构和语义信息:

图类型 目的 关键机制
跨模态知识图 (Cross-Modal KG) 非文本模态(图像、表格、公式)与其上下文环境可靠地关联起来。 1. 利用 VLM/LLM 为非文本单元生成详细描述 () 和实体摘要 ()。
2. 以非文本单元为锚点 (),构建图结构,包含belongs_to等边,实现模态特定性关联
基于文本的知识图 (Text-based KG) 捕获文本中的显式知识语义连接 遵循传统的 NER/RE 方法,直接从纯文本内容中提取实体和关系。

2. 跨模态混合检索 (Cross-Modal Hybrid Retrieval)

检索阶段结合了结构和语义两种互补机制,克服了传统 RAG 仅依赖单一模态语义匹配的限制:

机制一:结构化知识导航 (Structural Knowledge Navigation)
  • 目标: 捕捉显式关系多跳推理模式,特别是跨模态的连接。
  • 方法: 从用户查询中识别关键词和实体,在统一知识图 上进行精确实体匹配,并进行策略性的邻域扩展(在指定跳数内)。
  • 结果: 得到候选集 ,提供高层语义连接和结构性上下文。
机制二:语义相似性匹配 (Semantic Similarity Matching)
  • 目标: 识别缺乏显式结构连接的语义相关知识
  • 方法: 在所有组件(块、实体、关系)的嵌入表 上,使用查询嵌入 进行密集向量相似性搜索
  • 结果: 返回按余弦相似度排名的 top-k 语义相似块 。
融合与排序 (Fusion and Ranking)
  • 将两个机制的候选集合并:。
  • 应用多信号融合评分 (Multi-Signal Fusion Scoring),整合结构重要性、语义相似度得分以及查询推断的模态偏好,以生成最终的排名结果 。

3. 从检索到合成 (From Retrieval to Synthesis)

  • 构建文本上下文: 将检索到的所有组件(实体摘要、关系描述、块内容)的文本表示连接起来,并加入模态类型和层级来源的分隔符,作为 LLM 的输入。
  • 恢复视觉内容: 对于多模态块,进行解引用 (dereferencing) 以恢复原始的**视觉内容 **。
  • 联合条件生成: 响应由视觉-语言模型 (VLM) 联合生成,模型同时以查询 、组装的文本上下文 和解引用的视觉内容 为条件:

unsetunset实验设置与评估unsetunset

所有方法均使用 GPT-4o-mini 作为生成骨干 LLM;使用 text-embedding-3-large 嵌入模型和 bge-reranker-v2-m3 重排序模型。

  • GPT-4o-mini: 强大的多模态 LLM,具有 128K Token 上下文窗口,可直接处理长文档,作为强基线。
  • LightRAG: 一种图增强的 RAG 系统,但仅限于文本处理。
  • MMGraphRAG: 一种多模态检索框架,构建统一知识图,但对表格和公式处理不够完善。

RAG-Anything 将文本、图像、表格和公式视为一等实体进行处理,而 LightRAG 仅处理文本,MMGraphRAG 缺乏对表格和公式结构信息的处理。RAG-Anything 通过双图构建策略保留了所有模态的结构关系。

RAG-Anything 优势构建视觉布局图**,节点包含面板、轴标题、图例和标题,边编码了层级关系。这引导检索器精确聚焦到**风格空间面板**,避免了混淆,得到了正确答案。

RAG-Anything 将表格转换为结构化图,节点包含行标题、列标题(年份)、数据单元格和单位,边捕获了 行-列-单元格 的关系。这使得系统能够精确导航到“Wages and salaries”行和“2020”列的交集单元格,确保了准确的数值提取。

unsetunsetRAG-Anything 代码解析unsetunset

使用的外部工具

  • MinerU 是 RAG-Anything 的主要文档解析引擎,负责从 PDF 和图像文档中高保真提取文本、图像、表格和公式。
  • LibreOffice 是处理 Office 文件(.doc, .docx, .ppt, .pptx, .xls, .xlsx)的关键。
  • Pillow(Python Imaging Library)用于处理 MinerU 原生不支持的非标准图像格式。
  • Docling: 作为 MinerU 的替代解析器,可以通过配置 PARSER 环境变量或 RAGAnythingConfig.parser 来启用。

文档处理过程

文档解析 (Document Parsing) 处理文件格式、应用格式特定的转换(例如,Office 文件转 PDF),然后调用核心解析器(如 MinerUDocling)提取内容。

内容理解与处理 (Content Understanding & Processing) 将内容明确区分为纯文本内容和多模态元素(图像、表格、公式等)。

多模态分析引擎 (Multimodal Analysis Engine) 对 每个多模态项目(如图像、表格)都由相应的处理器并发处理。例如,图像可能需要 VLM 来生成详细描述,表格可能需要结构化解析。

知识图谱构建 (Knowledge Graph Construction) 从文本和多模态内容的增强描述中,提取实体和它们之间的关系。

将处理后的内容合并到 LightRAG 的存储系统中。这包括将分块的嵌入存储到向量数据库(VDB),并将实体和关系存储到图数据库(KG)。

知识图谱构建与检索

调用 LightRAG 的 extract_entities 函数,对多模态分块进行批量实体和关系提取。这个过程利用 LLM 根据分块的增强描述来识别语义实体和关系。

  • 节点 (Node) 结构: 提取的节点包含 entity_nameentity_typedescription 和一个指向其原始分块 ID 的 source_id
  • 边 (Edge) 结构: 提取的边包含 src_idtgt_id、关系描述 (description)、关键词 (keywords) 和一个权重 (weight),用于表示关系的强度。

知识图谱的数据被分散存储在多个 LightRAG 后端,以优化不同的检索需求:

存储位置 存储内容 用途
chunk_entity_relation_graph 节点(实体)和边(关系) 图遍历 和结构化检索的来源。
entities_vdb 实体描述的嵌入 用于实体名称的向量相似性搜索
relationships_vdb 关系描述的嵌入 用于关系类型的向量相似性搜索。
full_entities 文档 ID 关联的所有实体列表 用于文档级实体跟踪和去重。

混合检索机制

RAG-Anything 利用知识图谱启用跨模态混合检索,支持复杂的问答任务。检索策略战略性地结合了向量相似性搜索图遍历

  • 结构化知识导航: 利用图遍历来探索实体之间的显式关系(包括 belongs_to)和多跳推理路径
  • 语义相似性匹配: 利用 chunks_vdbentities_vdb 进行密集的向量搜索,捕获隐式语义联系

检索结果通过一个模态感知的融合评分机制进行排序,不同的关系类型被赋予不同的权重,例如:

  • belongs_to 关系:权重 10.0(最高优先级)。
  • 跨模态关系:权重 5.0-8.0(中高优先级)。
  • 模态内关系:权重 3.0-5.0(标准优先级)。

那么,如何系统的去学习大模型LLM?

作为一名深耕行业的资深大模型算法工程师,我经常会收到一些评论和私信,我是小白,学习大模型该从哪里入手呢?我自学没有方向怎么办?这个地方我不会啊。如果你也有类似的经历,一定要继续看下去!这些问题啊,也不是三言两语啊就能讲明白的。

所以我综合了大模型的所有知识点,给大家带来一套全网最全最细的大模型零基础教程。在做这套教程之前呢,我就曾放空大脑,以一个大模型小白的角度去重新解析它,采用基础知识和实战项目相结合的教学方式,历时3个月,终于完成了这样的课程,让你真正体会到什么是每一秒都在疯狂输出知识点。

由于篇幅有限,⚡️ 朋友们如果有需要全套 《2025全新制作的大模型全套资料》,扫码获取~
在这里插入图片描述

👉大模型学习指南+路线汇总👈

我们这套大模型资料呢,会从基础篇、进阶篇和项目实战篇等三大方面来讲解。
在这里插入图片描述
在这里插入图片描述

👉①.基础篇👈

基础篇里面包括了Python快速入门、AI开发环境搭建及提示词工程,带你学习大模型核心原理、prompt使用技巧、Transformer架构和预训练、SFT、RLHF等一些基础概念,用最易懂的方式带你入门大模型。
在这里插入图片描述

👉②.进阶篇👈

接下来是进阶篇,你将掌握RAG、Agent、Langchain、大模型微调和私有化部署,学习如何构建外挂知识库并和自己的企业相结合,学习如何使用langchain框架提高开发效率和代码质量、学习如何选择合适的基座模型并进行数据集的收集预处理以及具体的模型微调等等。
在这里插入图片描述

👉③.实战篇👈

实战篇会手把手带着大家练习企业级的落地项目(已脱敏),比如RAG医疗问答系统、Agent智能电商客服系统、数字人项目实战、教育行业智能助教等等,从而帮助大家更好的应对大模型时代的挑战。
在这里插入图片描述

👉④.福利篇👈

最后呢,会给大家一个小福利,课程视频中的所有素材,有搭建AI开发环境资料包,还有学习计划表,几十上百G素材、电子书和课件等等,只要你能想到的素材,我这里几乎都有。我已经全部上传到CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】
在这里插入图片描述
相信我,这套大模型系统教程将会是全网最齐全 最易懂的小白专用课!!

Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐