Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

FlashAttention-2: Faster Attention with Better Parallelism and Work Partitioning

About

Scaling Transformers to longer sequence lengths has been a major problem in the last several years, promising to improve performance in language modeling and high-resolution image understanding, as well as to unlock new applications in code, audio, and video generation. The attention layer is the main bottleneck in scaling to longer sequences, as its runtime and memory increase quadratically in the sequence length. FlashAttention exploits the asymmetric GPU memory hierarchy to bring significant memory saving (linear instead of quadratic) and runtime speedup (2-4$\times$ compared to optimized baselines), with no approximation. However, FlashAttention is still not nearly as fast as optimized matrix-multiply (GEMM) operations, reaching only 25-40\% of the theoretical maximum FLOPs/s. We observe that the inefficiency is due to suboptimal work partitioning between different thread blocks and warps on the GPU, causing either low-occupancy or unnecessary shared memory reads/writes. We propose FlashAttention-2, with better work partitioning to address these issues. In particular, we (1) tweak the algorithm to reduce the number of non-matmul FLOPs (2) parallelize the attention computation, even for a single head, across different thread blocks to increase occupancy, and (3) within each thread block, distribute the work between warps to reduce communication through shared memory. These yield around 2$\times$ speedup compared to FlashAttention, reaching 50-73\% of the theoretical maximum FLOPs/s on A100 and getting close to the efficiency of GEMM operations. We empirically validate that when used end-to-end to train GPT-style models, FlashAttention-2 reaches training speed of up to 225 TFLOPs/s per A100 GPU (72\% model FLOPs utilization).

Tri Dao• 2023

Related benchmarks

TaskDatasetResultRank
Long-context Language UnderstandingLongBench
M-Avg49.28
219
Video UnderstandingVideoMME
Overall Score71.22
192
Long-context Language UnderstandingLongBench (test)
Average Score40.24
133
Long-context UnderstandingLongBench
Overall Average Score41.47
115
Video GenerationVBench--
102
Long-context UnderstandingRULER
Performance @ 4K Context95.82
65
End-to-end throughputCloud Inference Workloads
Throughput (tokens/s)145.9
32
Attention Operator ThroughputLlama2 7B (32 Q-heads/32 KV-heads/128 Head-dimension)
Attention TFLOPS207.3
30
Attention Operator ThroughputQwen2.5 72B (64 Q-heads/8 KV-heads/128 Head-dimension)
Attention Throughput (TFLOPS)222.5
29
Attention Operator ThroughputLlama 405B (128 Q-heads/8 KV-heads/128 Head-dimension) 3.1
TFLOPS225.3
28
Showing 10 of 32 rows

Other info

Follow for update