56 lines
2.0 KiB
Markdown
56 lines
2.0 KiB
Markdown
---
|
||
title: "SoftMax-off-by-One"
|
||
created: 2026-05-14
|
||
updated: 2026-05-14
|
||
type: concept
|
||
tags: [attention, softmax, llm, streaming]
|
||
sources: ["https://arxiv.org/abs/2309.17453"]
|
||
---
|
||
|
||
# SoftMax-off-by-One
|
||
|
||
## 定义
|
||
|
||
SoftMax-off-by-One(SoftMax₁)是 Miller (2023) 提出的 SoftMax 变体,在分母中加 1,使模型不必将注意力分数分配到不相关的 Token 上:
|
||
|
||
$$\text{SoftMax}_1(x)_i = \frac{e^{x_i}}{1 + \sum_{j=1}^N e^{x_j}}$$
|
||
|
||
## 动机
|
||
|
||
标准 SoftMax 强制 $\sum_i \text{SoftMax}(x)_i = 1$,这意味着即使所有上下文 Token 都与当前 query 不相关,模型也必须分配注意力值——导致了 [[attention-sinks|注意力汇]] 现象。
|
||
|
||
SoftMax₁ 允许模型将多余的注意力"丢弃"到分母的 +1 项中,理论上消除对注意力汇的需求。
|
||
|
||
## 等价表示
|
||
|
||
SoftMax₁ 在注意力计算中等价于**前置一个全零 Key 和 Value 的虚拟 Token**:
|
||
|
||
$$\text{Attention}(Q, K, V) = \text{SoftMax}_1(QK^T)V = \text{SoftMax}(\tilde{Q}\tilde{K}^T)\tilde{V}$$
|
||
|
||
其中 $\tilde{K} = [0, K]$, $\tilde{V} = [0, V]$。
|
||
|
||
这在 [[streaming-llm|StreamingLLM]] 论文中被称为 **Zero Sink**。
|
||
|
||
## 实验评估
|
||
|
||
Xiao et al. (2024) 的预训练实验表明:
|
||
|
||
- Zero Sink (SoftMax₁) **部分改善**了注意力汇问题
|
||
- 但模型**仍然依赖其他初始 Token** 作为注意力汇
|
||
- 仅 Sink Token 时 PPL = 29,214(远差于 Learnable Sink 的 18.01)
|
||
|
||
→ SoftMax₁ 不足以完全替代专用的 [[sink-token|可学习汇 Token]]
|
||
|
||
## 与 Learnable Sink Token 的对比
|
||
|
||
| 方案 | 机制 | 有效性 |
|
||
|------|------|--------|
|
||
| SoftMax₁ (Zero Sink) | 修改 SoftMax 函数,允许丢弃注意力 | 部分改善,不够充分 |
|
||
| Learnable Sink Token | 预训练时添加专用可学习 Token | 完全有效,仅需 1 个 Token |
|
||
|
||
## 相关概念
|
||
|
||
- [[attention-sinks|注意力汇]] — 此方案试图解决的问题
|
||
- [[sink-token|汇 Token]] — 更有效的替代方案
|
||
- [[streaming-llm|StreamingLLM]] — 应用背景
|