news 2026/4/18 12:01:15

深度解析 Max-Min 语义分块策略对 RAG 的重构与优化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深度解析 Max-Min 语义分块策略对 RAG 的重构与优化

摘要

在检索增强生成(RAG)系统的构建过程中,文档分块(Chunking)的质量直接决定了检索的精度与生成内容的连贯性。传统的固定长度或基于结构的分割方法,往往因忽略文本内在语义逻辑而导致上下文断裂或噪声引入。今天一起看下论文《Max–Min semantic chunking of documents for RAG application》,看下动态语义分块算法——Max-Min 语义分块,如何作用提升 RAG 性能的底层优化。


1. RAG 的分块困境

RAG 系统的高效运行依赖于一个核心假设:检索到的 Top-K 文档片段应包含回答问题所需的完整且纯净的语义信息。然而,实现这一假设的基石——文档分块,却长期面临以下技术挑战:

  • 语义断裂 (Semantic Fragmentation):固定长度(如每 500 tokens 一块)的分割,往往在句子中间或逻辑转折处生硬切断,导致检索到的片段失去关键上下文。
  • 上下文噪声 (Contextual Noise):过大的块虽然包含更多背景,但也引入了大量不相关信息,干扰 LLM 的注意力。
  • 固定窗口的局限 (Fixed-Window Limitations):现有的语义分块方法(如 LlamaIndex 的语义切分器)通常采用固定大小的滑动窗口来比较句子组,难以处理插入语、引用或脚注等非线性的文本结构。

2. 超越固定窗口:语义分块的范式演进

为了解决上述问题,业界提出了语义分块 (Semantic Chunking)。其演进路径如下:

  1. 基于相似度的滑动窗口:通过滑动窗口计算相邻句子间的余弦相似度,相似度低于阈值时切分。
  2. 百分比/分位数切分:不再依赖固定阈值,而是根据文档整体相似度分布的百分位来决定边界。
  3. Max-Min 动态聚类(本文重点):将分块视为一种尊重时间顺序的动态聚类问题。它不再使用固定窗口,而是通过评估新句子与当前已形成分块(Cluster)的整体契合度,动态决定边界。

3. 深度解析:Max-Min 语义分块设计方案

Max–Min 语义分块的核心在于:它不仅考虑新句子与前一个句子的局部相似度,更考虑其与当前分块内所有句子的全局一致性。

3.1 核心思想:作为动态聚类的分块

算法将分块过程抽象为:按顺序处理句子s1,s2,…,sns_1, s_2, \dots, s_ns1,s2,,sn,对每个句子sks_ksk,决定是将其加入当前分块CCC,还是开启一个新分块。这种方法保留了文档的线性结构(Temporal Nature),确保分块内的句子是连续的。

3.2 逻辑结构:Max-Min 相似度策略

算法通过两个关键指标进行决策:

  1. 块内最小相似度 (min_sim(C)min\_sim(C)min_sim(C))
    衡量当前块CCC内最不相似的两个句子之间的距离,代表了该块的“容忍度底线”。
    min_sim(C)=min⁡s,t∈Csimcos⁡(E(s),E(t))min\_sim(C) = \min_{s,t \in C} \text{sim}_{\cos}(E(s), E(t))min_sim(C)=s,tC

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 3:46:48

KeymouseGo终极指南:从零基础到精通自动化操作

KeymouseGo终极指南:从零基础到精通自动化操作 【免费下载链接】KeymouseGo 类似按键精灵的鼠标键盘录制和自动化操作 模拟点击和键入 | automate mouse clicks and keyboard input 项目地址: https://gitcode.com/gh_mirrors/ke/KeymouseGo 厌倦了日复一日的…

作者头像 李华
网站建设 2026/4/18 1:56:11

Umi-OCR Windows系统兼容性终极指南:让旧设备重获新生

Umi-OCR Windows系统兼容性终极指南:让旧设备重获新生 【免费下载链接】Umi-OCR Umi-OCR: 这是一个免费、开源、可批量处理的离线OCR软件,适用于Windows系统,支持截图OCR、批量OCR、二维码识别等功能。 项目地址: https://gitcode.com/GitH…

作者头像 李华
网站建设 2026/4/18 3:27:16

高效测试设计:边界值+等价类全覆盖

用最少的测试用例,覆盖最多的输入风险。思路:把输入分成等价类(Equivalence Class) ,在每个关键范围处做边界值(Boundary Value)验证,并补齐格式/编码/跨字段的关键约束。Treeify 专…

作者头像 李华
网站建设 2026/4/18 3:26:11

nginx(更新中)

Linux安装Nginx 上传nginx-1.21.6.tar.gz yum install -y gcc-c zlib zlib-devel openssl openssl-devel pcre pcre-devel tar -zxvf nginx-1.21.6.tar.gz cd nginx-1.21.6/ # 执行配置脚本 ./configure --prefix/usr/local/nginx # 编译安装 make & make install # 启动ng…

作者头像 李华
网站建设 2026/4/18 0:00:36

Lumafly模组管理器:解决空洞骑士模组管理的终极方案

Lumafly模组管理器:解决空洞骑士模组管理的终极方案 【免费下载链接】Lumafly A cross platform mod manager for Hollow Knight written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/lu/Lumafly 还在为《空洞骑士》模组安装的繁琐步骤而烦恼吗…

作者头像 李华
网站建设 2026/4/18 3:29:10

【TCC分布式事务】

TCC实现指令原子性的原理 TCC(Try-Confirm-Cancel)通过三阶段操作实现业务层面分布式事务的原子性,其核心在于资源预留和状态管理的设计: Try阶段(预留) 对涉及的所有业务操作预先检查并预留资源&#xff0…

作者头像 李华