深入浅出ColBERT模型——实现高效精确的信息检索
ColBERT” 指"基于 BERT 的上下文化延迟交互" (Contextualized Late Interaction over BERT),这是一个由斯坦福大学开发的模型。它充分利用了 BERT 的深度语言理解能力,同时引入了一种被称为"延迟交互"的交互机制,通过在检索过程的最后阶段之前分别处理查询和文档,实现了高效而精确的检索。目前,ColBERT 主要有两个版本:ColBERT: 由
为什么看这个论文
最近鼓捣RAG,RAG里面有一个重要部分就是,需要计算prompt和知识库中存储知识的相似度,从而找到最相关知识,因此翻了一下提升检索效果的相关论文。
什么是 ColBERT?
“ColBERT” 指"基于 BERT 的上下文化延迟交互" (Contextualized Late Interaction over BERT),这是一个由斯坦福大学开发的模型。它充分利用了 BERT 的深度语言理解能力,同时引入了一种被称为"延迟交互"的交互机制,通过在检索过程的最后阶段之前分别处理查询和文档,实现了高效而精确的检索。目前,ColBERT 主要有两个版本:
ColBERT: 由 Omar Khattab 和 Matei Zaharia 发表,发表在 SIGIR 2020 上。这篇 ColBERT 论文首次介绍了"延迟交互"的概念。
ColBERTv2: 在初代 ColBERT 的基础上,Omar Khattab 继续深入研究,与 Barlas Oguz、Matei Zaharia 和 Michael S. Bernstein 合作,在 SIGIR 2021 会议上提出了ColBERTv2。这个 ColBERT 的升级版本引入了去噪监督和残差压缩,提高了模型的检索效果和存储效率。
解析 ColBERT 的设计理念
尽管 ColBERTv2 在架构上与原始 ColBERT 极为相似,其创新在训练技术和压缩机制上,我们先深入了解一下原始 ColBERT 的基本概念。
ColBERT 中的延迟交互
在信息检索领域,“交互” (interaction) 指的是通过比较查询(query)和文档(document)的表示(representations)来评估它们之间相关性的过程。
“延迟交互” (late interaction) 是 ColBERT 的核心创新:查询和文档表示之间的交互被推迟到处理的最后阶段,即在两者被独立编码之后才进行。这与"早期交互" (early interaction) 模型形成鲜明对比,后者在模型编码过程中或之前就进行查询和文档嵌入的交互。
交互类型 | 对应模型 |
---|---|
早期交互 | BERT, ANCE, DPR, Sentence-BERT, DRMM, KNRM, Conv-KNRM |
延迟交互 | ColBERT, ColBERTv2 |
早期交互模型虽然可能更精确,但计算复杂度高,因为它需要考虑所有可能的查询-文档组合。
相比之下,ColBERT 这类延迟交互模型通过预先计算文档表示,并在最后采用更轻量级的交互步骤,大大提高了效率和可扩展性。这种设计使得检索速度更快,计算需求更低,特别适合处理海量文档集合。
(a) 基于表示的相似性 (Representation-based Similarity): 在这种方法中,文档片段通过某些深度神经网络进行离线编码 (即预先处理),而查询片段则以类似的方式进行在线编码 (即实时处理)。然后计算查询与所有文档之间的成对相似性(通常是cos相似度)得分,并返回得分最高的几个文档。
(b) 查询-文档交互 (Query-Document Interaction): 在这种方法中,通过使用 n-gram (即连续的 n 个词组成的序列) 计算查询和文档中所有单词之间的词语和短语级关系,作为一种特征工程的形式。这些关系被转换为交互矩阵,然后作为输入提供给卷积网络。
© 全对全交互 (All-to-all Interaction): 这可以被视为方法 (b) 的泛化,它考虑了查询和文档内部以及彼此之间的所有成对交互。这是通过自注意力机制 (self-attention) 实现的。在实践中,通常使用 BERT (Bidirectional Encoder Representations from Transformers) 来实现,因为它是双向的,因此能够真正模拟所有成对交互,而不仅仅是因果关系。
(d) 后期交互 (Late Interaction): 这是该论文引入的新方法。在这种方法中,可以使用 BERT 离线计算文档嵌入,然后在线计算查询嵌入。之后,他们在查询和文档的嵌入之间应用了一个称为 MaxSim 运算符 (最大相似度运算符,具体解释将在后文给出) 的操作。这种架构的可视化如下所示:
ColBERT 的查询和文档编码器
ColBERT 的编码策略基于 BERT 模型。ColBERT 为查询或文档中的每个标记 (token) 生成密集的向量表示,分别为查询和文档创建一系列考虑上下文的嵌入向量。这种设计为后续的延迟交互阶段提供了细致入微的比较基础。
ColBERT 的查询编码过程
假设有一个查询 Q,其标记(token)为 q1, q2, …, ql,处理步骤如下:
- 将 Q 转换为 BERT 使用的 WordPiece 标记(token) (一种子词分词方法)。
- 在序列开头添加一个特殊的 [Q] 标记(token),紧随 BERT 的 [CLS] 标记(token)之后,用于标识查询的开始。
- 如果查询长度不足预设的 Nq 个标记(token),用 [mask] 标记(token)填充;若超过则截断。
- 将处理后的序列输入 BERT,然后通过卷积神经网络 (CNN) 处理,最后进行归一化。
最终输出的查询嵌入向量集合 Eq 可表示为:
Eq:=Normalize(BERT([Q],q0,q1,…,ql,[mask],[mask],…,[mask]))Eq := Normalize(BERT([Q], q0, q1, …, ql, [mask], [mask], …, [mask]))Eq:=Normalize(BERT([Q],q0,q1,…,ql,[mask],[mask],…,[mask]))
ColBERT 的文档编码过程
对于包含标记 d1, d2, …, dn 的文档 D,处理步骤类似:
- 在序列开头添加 [D] 标记,标识文档开始。
- 无需填充,直接输入 BERT 进行处理。
文档嵌入向量集合 Ed 可表示为: Ed := Filter(Normalize(BERT([D], d0, d1, …, dn)))
Filter用于去除与标点符号对应的嵌入,从而提升分析速度。这里的查询填充策略 (论文中称为"查询增强")确保了所有查询长度一致,有利于批量处理。而 [Q] 和 [D] 标记则帮助模型区分输入类型,提高了处理效率。
使用 ColBERT 查找最相关的前 K 个文档
一旦我们获得了查询和文档的嵌入 (embeddings,即将文本转换为数值向量的表示),找到最相关的前 K 个文档就变得相对简单.
计算过程包括:
- 批量点积计算:用于计算词语级别的相似度。每一个词都和整个文档进行计算
- 最大池化 (max-pooling):在文档词语上进行操作,找出每个查询词语的最高相似度。
- 求和:对查询词语的相似度分数进行累加,得出文档的总体相关性分数。
- 排序:根据总分对文档进行排序。
以下是用 PyTorch 实现这些操作的伪代码:
import torch
def compute_relevance_scores(query_embeddings, document_embeddings, k):
"""
计算给定查询的前 k 个最相关文档。
参数:
query_embeddings: 表示查询嵌入的张量 (tensor),形状: [查询词数, 嵌入维度]
document_embeddings: 表示 k 个文档嵌入的张量,形状: [k, 文档最大长度, 嵌入维度]
k: 需要重新排序的顶部文档数量
返回: 基于相关性分数排序的文档索引
"""
# 注: 假设 document_embeddings 已经进行了适当的填充并转移到 GPU
# 1. 计算查询嵌入和文档嵌入的批量点积
scores = torch.matmul(query_embeddings.unsqueeze(0), document_embeddings.transpose(1, 2))
# 2. 在文档词语维度上应用最大池化,找出每个查询词语的最大相似度
max_scores_per_query_term = scores.max(dim=2).values
# 3. 对查询词语的分数求和,得到每个文档的总分
total_scores = max_scores_per_query_term.sum(dim=1)
# 4. 根据总分对文档进行降序排序
sorted_indices = total_scores.argsort(descending=True)
return sorted_indices
这个过程在模型的训练和推理阶段都会用到。ColBERT 模型的训练采用了成对排序损失 (pairwise ranking loss) 。训练数据由三元组 (q, d+, d−) 组成,其中:
- q 表示查询
- d+ 是与查询相关的正面文档
- d− 是与查询不相关的负面文档
模型的目标是学习出这样的表示:查询 q 与相关文档 d+ 之间的相似度分数应该高于 q 与不相关文档 d− 之间的分数。 这个训练目标可以数学化表示为最小化以下损失函数:
Loss = max(0, 1 − S(q, d+) + S(q, d−))
其中 S(q, d) 表示 ColBERT 计算的查询 q 和文档 d 之间的相似度分数。这个分数是通过聚合查询和文档中最佳匹配词语嵌入的最大相似度得到的,遵循了模型架构中描述的"后期交互"模式。
这种方法确保了模型能够有效区分给定查询的相关和不相关文档,通过鼓励相关文档对和不相关文档对之间的相似度分数有更大的差距。这样,ColBERT 就能在实际应用中更准确地检索出与用户查询最相关的文档。
ColBERT 的索引策略与效率提升
与传统的将整个文档压缩成单一向量的方法不同,ColBERT 为文档 (和查询) 中的每个词元 (token) 都创建独立的嵌入 (embedding) 向量。这种方法虽然增加了存储需求,也带来了显著的性能提升。 为了有效管理大量的嵌入向量,ColBERT 采用了以下策略:
- 使用向量数据库 (如 FAISS,Facebook AI Similarity Search) 进行高效索引和检索。
- 离线处理文档嵌入:预先计算并存储文档的嵌入向量,充分利用批处理和 GPU 加速。
- 灵活的存储方案:可以选择使用 32 位或 16 位数值存储每个维度,在精度和存储空间之间取得平衡。
ColBERTv2 进一步改进了存储效率,引入了"残差压缩"技术。这种方法通过只存储嵌入向量与预定义参考点之间的差异,将模型的空间占用减少了 6 到 10 倍,同时保持了检索质量。
那么,如何系统的去学习大模型LLM?
我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。
作为一名热心肠的互联网老兵,我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在人工智能学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。
但苦于知识传播途径有限,很多互联网行业朋友无法获得正确的资料得到学习提升,故此将并将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。
所有资料 ⚡️ ,朋友们如果有需要全套 《LLM大模型入门+进阶学习资源包》,扫码获取~
篇幅有限,部分资料如下:
👉LLM大模型学习指南+路线汇总👈
💥大模型入门要点,扫盲必看!
💥既然要系统的学习大模型,那么学习路线是必不可少的,这份路线能帮助你快速梳理知识,形成自己的体系。
👉大模型入门实战训练👈
💥光学理论是没用的,要学会跟着一起做,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
👉国内企业大模型落地应用案例👈
💥《中国大模型落地应用案例集》 收录了52个优秀的大模型落地应用案例,这些案例覆盖了金融、医疗、教育、交通、制造等众多领域,无论是对于大模型技术的研究者,还是对于希望了解大模型技术在实际业务中如何应用的业内人士,都具有很高的参考价值。 (文末领取)
💥《2024大模型行业应用十大典范案例集》 汇集了文化、医药、IT、钢铁、航空、企业服务等行业在大模型应用领域的典范案例。
👉LLM大模型学习视频👈
💥观看零基础学习书籍和视频,看书籍和视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。 (文末领取)
👉640份大模型行业报告👈
💥包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。
👉获取方式:
这份完整版的大模型 LLM 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费
】
😝有需要的小伙伴,可以Vx扫描下方二维码免费领取🆓
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)