20260514:增加新内容

This commit is contained in:
2026-05-14 13:54:52 +08:00
parent 56c4d3ef7c
commit b116710e4c
294 changed files with 10682 additions and 255 deletions

74
papers/streaming-llm.md Normal file
View File

@@ -0,0 +1,74 @@
---
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
- 支持 RoPELlama-2, Falcon, Pythia和 ALiBiMPT
- 与上下文窗口扩展方法**正交**,可互补使用
## 关键结果
- 在 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-OneZero 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]] — 位置编码