随着大语言模型(LLM)技术的发展,RAG(Retrieval Augmented Generation)技术得到了广泛探讨和研究,越来越多的高级 RAG 检索方法也随之被人发现,相对于普通的 RAG 检索,高级 RAG 通过更深化的技术细节、更复杂的搜索策略,提供出了更准确、更相关、更丰富的信息检索结果。本文首先讨论这些技术,国产 向量数据库并基于 Milvus 给出一个实现案例。
( A; w6 n+ L0 v* }: R: G% n3 Z. b- A# }* E6 r3 y& T
I7 I, ?5 I9 ]! r$ ]8 _5 Q 01.初级 RAG' ^ q0 C0 l0 e+ M' {
4 q' o0 n) R6 L+ @+ Q k* `3 X. v
1 b# B/ \: x6 s8 Y0 t 初级 RAG 的定义
3 ^3 v/ x2 S6 X3 C \% x" h J# M9 o
7 d/ t: s4 G% e; q* A+ F 初级 RAG 研究范式代表了最早的方法论,在 ChatGPT 广泛采用后不久就取得了重要地位。初级 RAG 遵循传统的流程,包括索引创建(Indexing)、检索(Retrieval)和生成(Generation),常常被描绘成一个“检索—读取”框架,其工作流包括三个关键步骤:
" }% M" N. P u4 _: u- I
" Z0 G1 a& h8 s9 M" c# G9 Z, }% ?2 ^, }& r7 }
语料库被划分为离散的块,然后使用编码器模型构建向量索引。
4 ?& h9 F& { J
( J2 ?8 M: \2 \9 v) L; E$ c( }. ]" { g5 i( T- ]& [7 F* _
RAG 根据查询与索引块(Indexed Chunk)的向量相似度识别并对块进行检索。7 B6 g# V& ?+ B$ I7 e3 Y
/ L: M: B8 a2 l& b4 g1 s8 t$ N
& \% w- j8 n5 v
模型根据检索块(Retrieved Chunk)中获取的上下文信息生成答案。" k/ ~3 O* |/ s$ e: l! R7 [+ f
# Y# M; Z9 U1 j' F' p; S
0 O) |- y; G: g: r& x; k( M
初级 RAG 的局限性
5 g5 \7 T" g# w0 u2 @! v: U W" h( N+ R* U
9 e, _5 y. J* {
初级 RAG 在三个关键领域面临着显著挑战:"检索"、"生成"和"增强"。' O5 {% Z1 P' ^* c
" A( Q) m9 W7 ]4 M! |0 O$ p X/ V# _/ S
初级 RAG 的检索质量存在许多问题,例如低精度和低召回率等。低精度会导致检索到的块无法对齐,以及幻觉等潜在问题。低召回率会导致无法检索到所有的相关块,从而导致LLM的回复不够全面。此外,使用老旧的信息进一步加剧了问题,可能导致不准确的检索结果。
8 G* \& W8 z' l; k' R8 t) b) T. ]* k7 c9 p$ |: ?* N9 O r
: f) c7 g$ y; q6 E( l5 i M& Q 生成回复质量面临着幻觉挑战,即 LLM 生成的答案并没有基于所提供的上下文,和上下文不相关,或者生成的回复存在着包含有害或歧视内容的潜在风险。* h3 @/ W; g4 v( o3 w+ ^; D8 s
* m0 `9 t" d/ [6 z4 o1 G3 B
4 C* W* _3 V' A 在增强过程中,初级 RAG 在如何有效地将检索到的段落的上下文与当前生成任务进行整合方面也面临着不小的挑战。低效的整合可能导致输出不连贯或破碎化。冗余和重复也是一个棘手的问题,特别是当多个检索到的段落包含相似信息时,生成的回复中可能会出现重复的内容。4 l ~: |! P- \- Q# C% c# M
! m' h! M2 A1 w8 a& d- F7 y# I3 @/ D$ V( x+ c7 m1 D/ q1 D' j4 E
02.高级 RAG5 V; L& p6 ` H5 X$ W3 N
$ T- e% Z( Q$ t, M1 z0 y
% x# y( T! d% [: ]/ q( ^ 为了解决初级 RAG 的不足,高级 RAG 诞生了,并有针对性地进行了功能增强。首先讨论这些技术,这些技术可被归类为检索前优化、检索中优化和检索后优化。6 K# C* L6 J H# t2 A4 s; }% I8 V
2 e& m/ n. Q9 w% I7 C: l% y* S
" q' Y5 U* d% _
检索前优化- I# R) i4 v& l& b- G3 H
" C, P3 J; |* d, t4 V8 ?# L
/ V7 x" ^6 K, @( q
检索前的优化关注数据索引优化以及查询优化,数据索引优化技术旨在以提高检索效率的方式存储数据:3 Y4 ^7 n) @' }3 c! ]
0 N T/ L/ @" Z5 ]$ F4 I" m7 D& _
3 ^$ \9 T- u7 Z 滑动窗口:在数据块之间使用重叠,这是最简单的技术之一。
1 H! g- k9 p2 }5 `3 j+ C: ?( m
4 m9 G1 g/ J+ ~3 X
/ s: p8 s3 t* [* u4 g' l 增强数据粒度:应用数据清理技术,例如移除不相关信息、确认事实准确性、更新过时信息等。2 N% K9 K. [' J1 e# v7 W
; P% W0 Y Z/ R) |& T0 Y/ F u8 l3 L$ W u4 Z
添加元数据:如用于过滤的日期、目的或章节信息等。
% A: r. `- v( x! B5 d
6 `7 m4 s; \0 T5 s2 `0 M" X z, v3 s0 p( A' O
优化索引结构涉及不同的数据索引策略:如调整块大小或使用多索引策略。本文我们将实现的一种技术是句子窗口检索,它在检索时嵌入单个句子,并在推断时用更大的文本窗口替换它们。& G7 r1 {5 T2 R9 G" U: a: n
5 l f* Q8 t8 C6 F1 X* C: G" T
. [5 l( P$ d# }2 T0 }, g 检索中优化8 V6 D0 \4 n; [
# q0 M; ^* j2 ^4 A- {4 r8 J" Q; W8 @6 G- M4 {9 j
检索阶段主要是识别最相关的上下文。通常,检索是基于向量搜索,它计算查询和索引数据之间的语义相似性。因此,大多数检索优化技术都围绕着 embedding 模型:
3 {8 @* B3 n6 [/ [) v$ ~+ U1 a7 Z! f) E$ I6 W" X, x/ z) ^
6 J6 J9 O$ U7 I" V. k
微调 embedding 模型:定制化 embedding 模型到特定领域上下文,特别是针对具有发展性或罕见术语的领域。例如,BAAI/bge-small-en 是一个高性能 embedding 模型,可以进行微调。
/ c; q$ p% ]' S, x8 M! X, U
: n" G# s! ~' ~6 @7 i. S) @
: m* x- d' X& Q1 T' N1 c- w ^. J 动态 embedding:适应词语使用中的上下文,不同于使用每个词一个向量的静态embedding。例如,OpenAI 的 embeddings-ada-02 是一个复杂的动态embedding模型,捕捉到上下文理解。除了向量搜索之外,还有其他检索技术,如混合搜索(hybrid search),通常指的是将向量搜索与基于关键词的搜索相结合的概念。如果检索需要精确的关键词匹配,这种检索技术很有益处。
& J0 d7 i& h4 }$ R* t$ g( I3 z" }8 r' T/ W: M& q
|