Flash Attention V1和V2的作者又推出了Flash Decoding,真是太強了!
Flash-Decoding借鑒了FlashAttention的優(yōu)點,將并行化維度擴展到keys/values序列長度。這種方法幾乎不收序列長度影響(這對LLM模型能力很重要),可以充分利用GPU,即使在batch size較小時(inference特點),也可以極大提高了encoding速度。
相關背景知識先推薦閱讀:
FlashAttention圖解(如何加速Attention)
FlashAttention2詳解(性能比FlashAttention提升200%)
Motivation
最近,像ChatGPT或Llama這樣的LLM模型受到了空前的關注。然而,它們的運行成本卻非常高昂。雖然單次回復的成本約為0.01美元(例如在AWS 8塊A100上運行幾秒鐘),但是當擴展到數(shù)十億用戶的多次交互時,成本會迅速上升。而且一些場景的成本更高,例如代碼自動補全,因為只要用戶輸入一個新字符就會執(zhí)行。由于LLM應用非常廣泛且還在迅速增長,即使稍微提升其運行效率也會產生巨大的收益。
LLM inference(或稱為decoding)是一個迭代的過程:預測的tokens是逐個生成的。如果生成的句子有N個單詞,那么模型需要進行N次forward。一個常用的優(yōu)化技巧是KV Cache,該方法緩存了之前forward的一些中間結果,節(jié)約了大部分運算(如MatMul),但是attention操作是個例外。隨著輸出tokens長度增加,attention操作的復雜度也極具上升。
然而我們希望LLM能處理長上下文。增加了上下文長度,LLM可以輸出更長的文檔、跟蹤更長的對話,甚至在編寫代碼之前處理整個代碼庫。例如,2022年大多數(shù)LLM的上下文長度最多為2k(如GPT-3),但現(xiàn)在LLM上下文長度可以擴展到32k(Llama-2-32k),甚至最近達到了100k(CodeLlama)。在這種情況下,attention操作在推理過程中占據(jù)了相當大的時間比例。此外,當batch size增加時,即使在相對較小的上下文中,attention操作也可能成為瓶頸。這是因為該操作需要對內存的訪問會隨著batch size增加而增加,而模型中其他操作只和模型大小相關。
因此,本文提出了Flash-Decoding,可以推理過程中顯著加速attention操作(例如長序列生成速度提高8倍)。其主要思想是最大化并行加載keys和values的效率,通過重新縮放組合得到正確結果。
Multi-head attention for decoding
在decoding過程中,每個生成的新token需要與先前的tokens合并后,才能繼續(xù)執(zhí)行attention操作,即。Attention操作在訓練過程的瓶頸主要卡在訪問內存讀寫中間結果(例如)的帶寬,相關加速方案可以參考FlashAttention和FlashAttention2。
然而,上述優(yōu)化不適合直接應用于推理過程。因為在訓練過程中,F(xiàn)lashAttention對batch size和query length進行了并行化加速。而在推理過程中,query length通常為1,這意味著如果batch size小于GPU上的SM數(shù)量(例如A100上有108個SMs),那么整個計算過程只使用了GPU的一小部分!特別是當上下文較長時,通常會減小batch size來適應GPU內存。例如batch size = 1時,F(xiàn)lashAttention對GPU利用率小于1%!
下面展示了FlashAttention的計算示意圖,該示例將keys和values分為了2個block:
FlashAttention示意圖
對應的計算公式:
FlashAttention示意圖對應的計算公式
注意的計算過程依賴,從下圖也可以看出,F(xiàn)lashAttention是按順序更新output的,其實當時我在看FlashAttention這篇文章時就覺得這個順序操作可以優(yōu)化的,因為反正都要rescale,不如最后統(tǒng)一rescale,沒必要等之前block計算完(為了獲取上一個block的max值)
flashattention計算過程
A faster attention for decoding: Flash-Decoding
上面提到FlashAttention對batch size和query length進行了并行化加速,F(xiàn)lash-Decoding在此基礎上增加了一個新的并行化維度:keys/values的序列長度。即使batch size很小,但只要上下文足夠長,它就可以充分利用GPU。與FlashAttention類似,F(xiàn)lash-Decoding幾乎不用額外存儲大量數(shù)據(jù)到全局內存中,從而減少了內存開銷。
flashdecoding計算過程
Flash Decoding主要包含以下三個步驟(可以結合上圖來看):
將keys和values分成較小的block
使用FlashAttention并行計算query與每個block的注意力(這是和FlashAttention最大的區(qū)別)。對于每個block的每行(因為一行是一個特征維度),F(xiàn)lash Decoding會額外記錄attention values的log-sum-exp(標量值,用于第3步進行rescale)
對所有output blocks進行reduction得到最終的output,需要用log-sum-exp值來重新調整每個塊的貢獻
實際應用中,第1步中的數(shù)據(jù)分塊不涉及GPU操作(因為不需要在物理上分開),只需要對第2步和第3步執(zhí)行單獨的kernels。雖然最終的reduction操作會引入一些額外的計算,但在總體上,F(xiàn)lash-Decoding通過增加并行化的方式取得了更高的效率。
Benchmarks on CodeLlama 34B
作者對CodeLLaMa-34b的decoding throughput進行了基準測試。該模型與Llama 2具有相同的架構。作者在各種序列長度(從512到64k)上測試了decoding速度,并比較了多種attention計算方法:
PyTorch:使用純PyTorch primitives運行注意力計算(不使用FlashAttention)。
FlashAttention v2(v2.2之前的版本)。
FasterTransformer:使用FasterTransformer attention kernel
Flash-Decoding
將從內存中讀取整個模型和KV Cache所需的時間作為上限
Untitled
從上圖可以看出,F(xiàn)lash-Decoding在處理非常大的序列時速度可以提高8倍,并且比其他方法具有更好的可擴展性。所有方法在處理small prompts時表現(xiàn)相似,但隨著序列長度從512增加到64k,其他方法的性能都變差了,而Flash-Decoding對序列長度的增加并不敏感(下圖也是很好的證明)
micro-benchmark on A100
Using Flash-Decoding
作者還通了Flash-Decoding使用方式:
基于FlashAttention package ,從版本2.2開始。
xFormers,在版本0.0.22中提供了xformers.ops.memory_efficient_attention模塊
作者也提供了LLaMa v2/CodeLLaMa的repo1和xFormers repo2。此外,作者還提供了一個針對LLaMa v1/v2的最小示例。
個人總結
Flash-Decoding對LLM在GPU上inference進行了顯著加速(尤其是batch size較小時),并且在處理長序列時具有更好的可擴展性。
-
gpu
+關注
關注
28文章
4760瀏覽量
129135 -
模型
+關注
關注
1文章
3279瀏覽量
48974 -
LLM
+關注
關注
0文章
297瀏覽量
357
原文標題:FlashAttenion-V3: Flash Decoding詳解
文章出處:【微信號:GiantPandaCV,微信公眾號:GiantPandaCV】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論