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

Post-Training Sparse Attention with Double Sparsity

About

The inference process for large language models is slow and memory-intensive, with one of the most critical bottlenecks being excessive Key-Value (KV) cache accesses. This paper introduces "Double Sparsity," a novel post-training sparse attention technique designed to alleviate this bottleneck by reducing KV cache access. Double Sparsity combines token sparsity, which focuses on utilizing only the important tokens for computing self-attention, with channel sparsity, an approach that uses important feature channels for identifying important tokens. Our key insight is that the pattern of channel sparsity is relatively static, allowing us to use offline calibration to make it efficient at runtime, thereby enabling accurate and efficient identification of important tokens. Moreover, this method can be combined with offloading to achieve significant memory usage reduction. Experimental results demonstrate that Double Sparsity can achieve $\frac{1}{16}$ token and channel sparsity with minimal impact on accuracy across various tasks, including wiki-2 perplexity, key-value retrieval, and long context benchmarks with models including Llama-2-7B, Llama-2-70B, and Mixtral-8x7B. It brings up to a 14.1$\times$ acceleration in attention operations and a 1.9$\times$ improvement in end-to-end inference on GPUs. With offloading, it achieves a decoding speed acceleration of 16.3$\times$ compared to state-of-the-art solutions at a sequence length of 256K. Our code is publicly available at https://github.com/andy-yang-1/DoubleSparse.

Shuo Yang, Ying Sheng, Joseph E. Gonzalez, Ion Stoica, Lianmin Zheng• 2024

Related benchmarks

TaskDatasetResultRank
End-to-end throughputLLaMA-2-7B-Chat
Throughput (tokens/sec)423
60
Attention Operator LatencyLLaMA-2 Chat 7B
Attention Latency (ms)0.141
60
Conversational Question AnsweringCoQA zero-shot (test)
Exact Match (EM)70.45
32
Mathematics Question AnsweringGSM8K zero-shot (test)
Flexible EM74.15
32
Long-context Language UnderstandingRULER 32k context length
Average Score85.3
30
Long-context UnderstandingLongBench English
MultiNews Score26.3
12
Showing 6 of 6 rows

Other info

Follow for update