75 lines
3.3 KiB
Markdown
75 lines
3.3 KiB
Markdown
---
|
||
title: "StreamingLLM: 基于注意力汇的高效流式语言模型"
|
||
created: 2026-05-14
|
||
updated: 2026-05-14
|
||
type: paper
|
||
tags: [llm, attention, streaming, kv-cache, inference-optimization]
|
||
sources: ["https://arxiv.org/abs/2309.17453"]
|
||
venue: "ICLR 2024"
|
||
authors: ["Guangxuan Xiao", "Yuandong Tian", "Beidi Chen", "Song Han", "Mike Lewis"]
|
||
---
|
||
|
||
# StreamingLLM: 基于注意力汇的高效流式语言模型
|
||
|
||
Efficient Streaming Language Models with Attention Sinks
|
||
|
||
[[guangxuan-xiao]], [[yuandong-tian]], [[beidi-chen]], [[song-han]], [[mike-lewis]] — ICLR 2024
|
||
|
||
## 核心问题
|
||
|
||
如何让 LLM 在流式场景(多轮对话、实时生成)中处理**无限长**输入序列,同时保持效率和性能?
|
||
|
||
现有方案的问题:
|
||
- **Dense Attention**:O(T²) 复杂度,且超出预训练窗口后性能崩溃
|
||
- **Window Attention**:只缓存最近 Token 的 KV,但当初始 Token 被逐出时模型崩溃
|
||
- **Sliding Window + Re-computation**:性能好但太慢,每个新 Token 都要重建 KV
|
||
|
||
## 核心发现:Attention Sink(注意力汇)
|
||
|
||
作者发现了一个关键现象:**LLM 的初始 Token 在所有层和注意力头上都吸引了不成比例的高注意力分数**,无论其语义是否相关。
|
||
|
||
**原因**:SoftMax 函数要求所有 token 的注意力分数之和为 1。即使当前 query 没有强语义匹配,模型也必须把多余的注意力值 "倾倒" 到某处。由于自回归建模的特性,初始 Token 对所有后续 Token 都可见,因此被自然训练为注意力的 "汇" (sink)。
|
||
|
||
→ 这就是为什么 Window Attention 一旦驱逐初始 Token 就会崩溃:它破坏了 SoftMax 分母的分布。
|
||
|
||
详见 [[attention-sinks|注意力汇]]。
|
||
|
||
## 方法:StreamingLLM
|
||
|
||
基于上述洞察,StreamingLLM 的 KV 缓存分为两部分:
|
||
|
||
1. **Attention Sinks**(4 个初始 Token):稳定注意力计算,锚定 SoftMax 分布
|
||
2. **Rolling KV Cache**(最近 Token):负责语言建模的语义内容
|
||
|
||
**关键设计**:位置编码在 **cache 内部**分配(而非原始文本),这对 RoPE 和 ALiBi 的性能至关重要。
|
||
|
||
- **无需微调**,直接适用于任何使用相对位置编码的自回归 LLM
|
||
- 支持 RoPE(Llama-2, Falcon, Pythia)和 ALiBi(MPT)
|
||
- 与上下文窗口扩展方法**正交**,可互补使用
|
||
|
||
## 关键结果
|
||
|
||
- 在 Llama-2 (7/13/70B)、MPT (7/30B)、Falcon (7/40B)、Pythia (2.9/6.9/12B) 上验证
|
||
- 稳定语言建模至 **400 万 Token** 以上
|
||
- 相比 Sliding Window + Re-computation 加速 **最高 22.2×**
|
||
- 4 个初始 Token 即可恢复性能,更多 Token 边际收益递减
|
||
|
||
## Sink Token 预训练
|
||
|
||
- 用 1.6 亿参数模型从头预训练验证
|
||
- 在所有训练样本前添加一个可学习的专用 **Sink Token** → 只需要这一个 Token 即可稳定流式推理
|
||
- 相比之下,Vanilla 模型需要 4 个初始 Token 作为 attention sinks
|
||
- SoftMax-off-by-One(Zero Sink)有改善但不够充分
|
||
|
||
→ 建议未来的 LLM 预训练统一加入 Sink Token
|
||
|
||
## 概念网络
|
||
|
||
- [[attention-sinks|注意力汇]] — 核心现象
|
||
- [[window-attention|窗口注意力]] — 失败的基线
|
||
- [[length-extrapolation|长度外推]] — 问题域
|
||
- [[rolling-kv-cache|滚动 KV 缓存]] — StreamingLLM 机制
|
||
- [[sink-token|汇 Token]] — 预训练改进
|
||
- [[kv-cache-bottleneck|KV 缓存瓶颈]] — 相关优化
|
||
- [[rotary-position-embedding|RoPE]] — 位置编码
|