面试-并行前缀和优化 Linear Attention

1 什么是前缀和?

定义:k 个元素的状态依赖于第 k-1 个元素;

公式: 前缀和 = 从第 1 个,一直加到当前位置;

例子:

比如有 4 个数:
ABCD

那么前缀和的结果为:

txt 复制代码
S1 = A
S2 = A + B
S3 = A + B + C
S4 = A + B + C + D

Linear Attention 中有所体现,即,S2 依赖 S1,S3 依赖 S2,必须串行。

2 问题

如果串行计算的话,时间复杂度相当高;能不能将 O(n)的时间复杂度优化到O(1)呢?

3 并行前缀和加速

第一步:看这个下三角全 1 矩阵

txt 复制代码
1  0  0  0
1  1  0  0
1  1  1  0
1  1  1  1

第二步: 让它 乘以向量 A,B,C,D

结果就是:

txt 复制代码
第1行:1*A + 0*B + 0*C + 0*D = A       → S1
第2行:1*A + 1*B + 0*C + 0*D = A+B     → S2
第3行:1*A + 1*B + 1*C + 0*D = A+B+C   → S3
第4行:1*A + 1*B + 1*C + 1*D = A+B+C+D → S4

结果

✅ 一次性得到 S1、S2、S3、S4!

✅ 没有循环!没有等待!全部并行!

4 结论

并行前缀和的本质就是:

用下三角矩阵,模拟 "只累加前面所有值" 的效果,一次性输出所有结果。

对应到 Linear Attention 的 Chunk 加速中:

公式
St=eΔt⋅∑i=1t(eγi−Δi⋅ki⊤vi) S_t = e^{\Delta_t} \cdot \sum_{i=1}^t \left( e^{\gamma_i - \Delta_i} \cdot k_i^\top v_i \right) St=eΔt⋅i=1∑t(eγi−Δi⋅ki⊤vi)

里面每一项:

  • Δt\Delta_tΔt:可以用 cumsum 并行算
  • eΔte^{\Delta_t}eΔt、e−Δie^{-\Delta_i}e−Δi:并行指数
  • eγi−Δiki⊤vie^{\gamma_i - \Delta_i} k_i^\top v_ieγi−Δiki⊤vi:全部并行
  • ∑i=1t\sum_{i=1}^t∑i=1t:用 下三角矩阵(tril) 并行前缀和

后面这累加的一串就可以用并行前缀和。

对应代码:

python 复制代码
decay_mask = tril(...)  # 下三角矩阵
attn = k_beta @ k.T * decay_mask  # 并行前缀和

这一行 = 一次性算出所有 S_t,不需要循环!

相关推荐
jinxindeep1 分钟前
超越VLA与世界模型:构建下一代物理智能系统的四大支柱
人工智能
L_Jason先生4 分钟前
给 AI 一张地图,而不是一本手册——AGENTS.md 内容策略完全指南
人工智能
珠***格6 分钟前
Ⅱ型边缘网关|易部署、易扩容、易改造
大数据·人工智能·分布式·能源·边缘计算
千百元14 分钟前
codex不同档位大概费用
人工智能
机汇五金_18 分钟前
矩阵机箱为什么越来越强调模块化设计?
人工智能·线性代数·矩阵
AI_yangxi19 分钟前
短视频矩阵系统哪个好
大数据·人工智能·矩阵
云智慧AIOps社区19 分钟前
云智慧Cloudwise 亮相华为云 × 霞光社中企私享会,Qreel 重构 AI 短剧出海新范式
人工智能·华为云·ai短剧·短剧创作
ar012319 分钟前
工业AI质检:智能化时代的质量革命
人工智能·ar
码农翻身20 分钟前
英伟达向左,华为云向右:AI数据中心该走哪条路?
人工智能·华为云
AI大法师21 分钟前
老牌媒体怎么从“出版物更新”走到“品牌系统升级”
大数据·人工智能·设计模式·新媒体运营