在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

FlashAttention2詳解(性能比FlashAttention提升200%)

jf_pmFSk4VX ? 來源:GiantPandaCV ? 2023-11-24 16:21 ? 次閱讀

摘要

在過去幾年中,如何擴展Transformer使之能夠處理更長的序列一直是一個重要問題,因為這能提高Transformer語言建模性能和高分辨率圖像理解能力,以及解鎖代碼、音頻視頻生成等新應用。然而增加序列長度,注意力層是主要瓶頸,因為它的運行時間和內(nèi)存會隨序列長度的增加呈二次(平方)增加。FlashAttention利用GPU非勻稱的存儲器層次結構,實現(xiàn)了顯著的內(nèi)存節(jié)省(從平方增加轉為線性增加)和計算加速(提速2-4倍),而且計算結果保持一致。但是,F(xiàn)lashAttention仍然不如優(yōu)化的矩陣乘法(GEMM)操作快,只達到理論最大FLOPs/s的25-40%。作者觀察到,這種低效是由于GPU對不同thread blocks和warps工作分配不是最優(yōu)的,造成了利用率低和不必要的共享內(nèi)存讀寫。因此,本文提出了FlashAttention-2以解決這些問題。

簡介

如何擴展Transformer使之能夠處理更長的序列一直是一個挑戰(zhàn),**因為其核心注意力層的運行時間和內(nèi)存占用量隨輸入序列長度成二次增加。**我們希望能夠打破2k序列長度限制,從而能夠訓練書籍、高分辨率圖像和長視頻。此外,寫作等應用也需要模型能夠處理長序列。過去一年中,業(yè)界推出了一些遠超之前長度的語言模型:GPT-4為32k,MosaicML的MPT為65k,以及Anthropic的Claude為100k。

雖然相比標準Attention,F(xiàn)lashAttention快了2~4倍,節(jié)約了10~20倍內(nèi)存,但是離設備理論最大throughput和flops還差了很多。本文提出了FlashAttention-2,它具有更好的并行性和工作分區(qū)。實驗結果顯示,F(xiàn)lashAttention-2在正向傳遞中實現(xiàn)了約2倍的速度提升,達到了理論最大吞吐量的73%,在反向傳遞中達到了理論最大吞吐量的63%。在每個A100 GPU上的訓練速度可達到225 TFLOPs/s。

本文主要貢獻和創(chuàng)新點為:

1. 減少了non-matmul FLOPs的數(shù)量(消除了原先頻繁rescale)。雖然non-matmul FLOPs僅占總FLOPs的一小部分,但它們的執(zhí)行時間較長,這是因為GPU有專用的矩陣乘法計算單元,其吞吐量高達非矩陣乘法吞吐量的16倍。因此,減少non-matmul FLOPs并盡可能多地執(zhí)行matmul FLOPs非常重要。

2. 提出了在序列長度維度上并行化。該方法在輸入序列很長(此時batch size通常很小)的情況下增加了GPU利用率。即使對于單個head,也在不同的thread block之間進行并行計算。

3. 在一個attention計算塊內(nèi),將工作分配在一個thread block的不同warp上,以減少通信和共享內(nèi)存讀/寫。

動機

為了解決這個問題,研究者們也提出了很多近似的attention算法,然而目前使用最多的還是標準attention。FlashAttention利用tiling、recomputation等技術顯著提升了計算速度(提升了2~4倍),并且將內(nèi)存占用從平方代價將為線性代價(節(jié)約了10~20倍內(nèi)存)。雖然FlashAttention效果很好,但是仍然不如其他基本操作(如矩陣乘法)高效。例如,其前向推理僅達到GPU(A100)理論最大FLOPs/s的30-50%(下圖);反向傳播更具挑戰(zhàn)性,在A100上僅達到最大吞吐量的25-35%。相比之下,優(yōu)化后的GEMM(矩陣乘法)可以達到最大吞吐量的80-90%。通過觀察分析,這種低效是由于GPU對不同thread blocks和warps工作分配不是最優(yōu)的,造成了利用率低和不必要的共享內(nèi)存讀寫。

959fa84a-76f8-11ee-939d-92fbcf53809c.jpg

Attention forward speed on A100 GPU. (Source: Figure 5 of the paper.)

背景知識

下面介紹一些關于GPU的性能和計算特點,有關Attention和FlashAttention的詳細內(nèi)容請參考第一篇文章

FlashAttention圖解(如何加速Attention)

GPU

GPU performance characteristics.GPU主要計算單元(如浮點運算單元)和內(nèi)存層次結構。大多數(shù)現(xiàn)代GPU包含專用的低精度矩陣乘法單元(如Nvidia GPU的Tensor Core用于FP16/BF16矩陣乘法)。內(nèi)存層次結構分為高帶寬內(nèi)存(High Bandwidth Memory, HBM)和片上SRAM(也稱為shared memory)。以A100 GPU為例,它具有40-80GB的HBM,帶寬為1.5-2.0TB/s,每個108個streaming multiprocessors共享的SRAM為192KB,帶寬約為19TB/s。

這里忽略了L2緩存,因為不能直接被由程序員控制。

95acec58-76f8-11ee-939d-92fbcf53809c.jpg

CUDA的軟件和硬件架構

從Hardware角度來看:

Streaming Processor(SP):是最基本的處理單元,從fermi架構開始被叫做CUDA core。

Streaming MultiProcessor(SM):一個SM由多個CUDA core(SP)組成,每個SM在不同GPU架構上有不同數(shù)量的CUDA core,例如Pascal架構中一個SM有128個CUDA core。

SM還包括特殊運算單元(SFU),共享內(nèi)存(shared memory),寄存器文件(Register File)和調度器(Warp Scheduler)等。register和shared memory是稀缺資源,這些有限的資源就使每個SM中active warps有非常嚴格的限制,也就限制了并行能力。

從Software(編程)角度來看:

95b87a46-76f8-11ee-939d-92fbcf53809c.jpg

CUDA軟件示例

thread是最基本的執(zhí)行單元(the basic unit of execution)。

warp是SM中最小的調度單位(the smallest scheduling unit on an SM),一個SM可以同時處理多個warp

thread block是GPU執(zhí)行的最小單位(the smallest unit of execution on the GPU)。

一個warp中的threads必然在同一個block中,如果block所含thread數(shù)量不是warp大小的整數(shù)倍,那么多出的那個warp中會剩余一些inactive的thread。也就是說,即使warp的thread數(shù)量不足,硬件也會為warp湊足thread,只不過這些thread是inactive狀態(tài),但也會消耗SM資源。

thread:一個CUDA并行程序由多個thread來執(zhí)行

warp:一個warp通常包含32個thread。每個warp中的thread可以同時執(zhí)行相同的指令,從而實現(xiàn)SIMT(單指令多線程)并行。

thread block:一個thread block可以包含多個warp,同一個block中的thread可以同步,也可以通過shared memory進行通信。

grid:在GPU編程中,grid是一個由多個thread block組成的二維或三維數(shù)組。grid的大小取決于計算任務的規(guī)模和thread block的大小,通常根據(jù)計算任務的特點和GPU性能來進行調整。

Hardware和Software的聯(lián)系:

SM采用的是Single-Instruction Multiple-Thread(SIMT,單指令多線程)架構,warp是最基本的執(zhí)行單元,一個warp包含32個并行thread,這些thread以不同數(shù)據(jù)資源執(zhí)行相同的指令。

當一個kernel被執(zhí)行時,grid中的thread block被分配到SM上,大量的thread可能被分到不同的SM上,但是一個線程塊的thread只能在一個SM上調度,SM一般可以調度多個block。每個thread擁有自己的程序計數(shù)器和狀態(tài)寄存器,并且可以使用不同的數(shù)據(jù)來執(zhí)行指令,從而實現(xiàn)并行計算,這就是所謂的Single Instruction Multiple Thread。

一個CUDA core可以執(zhí)行一個thread,一個SM中的CUDA core會被分成幾個warp,由warp scheduler負責調度。GPU規(guī)定warp中所有thread在同一周期執(zhí)行相同的指令,盡管這些thread執(zhí)行同一程序地址,但可能產(chǎn)生不同的行為,比如分支結構。一個SM同時并發(fā)的warp是有限的,由于資源限制,SM要為每個block分配共享內(nèi)存,也要為每個warp中的thread分配獨立的寄存器,所以SM的配置會影響其所支持的block和warp并發(fā)數(shù)量。

GPU執(zhí)行模型小結:

GPU有大量的threads用于執(zhí)行操作(an operation,也稱為a kernel)。這些thread組成了thread block,接著這些blocks被調度在SMs上運行。在每個thread block中,threads被組成了warps(32個threads為一組)。一個warp內(nèi)的threads可以通過快速shuffle指令進行通信或者合作執(zhí)行矩陣乘法。在每個thread block內(nèi)部,warps可以通過讀取/寫入共享內(nèi)存進行通信。每個kernel從HBM加載數(shù)據(jù)到寄存器和SRAM中,進行計算,最后將結果寫回HBM中。

FlashAttention

FlashAttention應用了tiling技術來減少內(nèi)存訪問,具體來說:

1. 從HBM中加載輸入數(shù)據(jù)(K,Q,V)的一部分到SRAM中

2. 計算這部分數(shù)據(jù)的Attention結果

3. 更新輸出到HBM,但是無需存儲中間數(shù)據(jù)S和P

下圖展示了一個示例:首先將K和V分成兩部分(K1和K2,V1和V2,具體如何劃分根據(jù)數(shù)據(jù)大小和GPU特性調整),根據(jù)K1和Q可以計算得到S1和A1,然后結合V1得到O1。接著計算第二部分,根據(jù)K2和Q可以計算得到S2和A2,然后結合V2得到O2。最后O2和O1一起得到Attention結果。

95d09586-76f8-11ee-939d-92fbcf53809c.jpg

值得注意的是,輸入數(shù)據(jù)K、Q、V是存儲在HBM上的,中間結果S、A都不需要存儲到HBM上。通過這種方式,F(xiàn)lashAttention可以將內(nèi)存開銷降低到線性級別,并實現(xiàn)了2-4倍的加速,同時避免了對中間結果的頻繁讀寫,從而提高了計算效率。

FlashAttention-2

經(jīng)過鋪墊,正式進入正文。我們先講述FlashAttention-2對FlashAttention的改進,從而減少了非矩陣乘法運算(non-matmul)的FLOPs。然后說明如何將任務分配給不同的thread block進行并行計算,充分利用GPU資源。最后描述了如何在一個thread block內(nèi)部分配任務給不同的warps,以減少訪問共享內(nèi)存次數(shù)。這些優(yōu)化方案使得FlashAttention-2的性能提升了2-3倍。

Algorithm

FlashAttention在FlashAttention算法基礎上進行了調整,減少了非矩陣乘法運算(non-matmul)的FLOPs。這是因為現(xiàn)代GPU有針對matmul(GEMM)專用的計算單元(如Nvidia GPU上的Tensor Cores),效率很高。以A100 GPU為例,其FP16/BF16矩陣乘法的最大理論吞吐量為312 TFLOPs/s,但FP32非矩陣乘法僅有19.5 TFLOPs/s,即每個no-matmul FLOP比mat-mul FLOP昂貴16倍。為了確保高吞吐量(例如超過最大理論TFLOPs/s的50%),我們希望盡可能將時間花在matmul FLOPs上。

Forward pass

通常實現(xiàn)Softmax算子為了數(shù)值穩(wěn)定性(因為指數(shù)增長太快,數(shù)值會過大甚至溢出),會減去最大值:

95d47dae-76f8-11ee-939d-92fbcf53809c.png

這樣帶來的代價就是要對95df671e-76f8-11ee-939d-92fbcf53809c.png遍歷3次。

為了減少non-matmul FLOPs,本文在FlashAttention基礎上做了兩點改進:

95ed1a30-76f8-11ee-939d-92fbcf53809c.png

95f7f234-76f8-11ee-939d-92fbcf53809c.png

960c8b2c-76f8-11ee-939d-92fbcf53809c.png

簡單示例的FlashAttention完整計算步驟(紅色部分表示V1和V2區(qū)別):

9615dea2-76f8-11ee-939d-92fbcf53809c.jpg

FlashAttention-2的完整計算步驟(紅色部分表示V1和V2區(qū)別):

962181e4-76f8-11ee-939d-92fbcf53809c.png

962a8410-76f8-11ee-939d-92fbcf53809c.jpg

有了上面分析和之前對FlashAttention的講解,再看下面?zhèn)未a就沒什么問題了。

962e598c-76f8-11ee-939d-92fbcf53809c.jpg

Causal masking是attention的一個常見操作,特別是在自回歸語言建模中,需要對注意力矩陣S應用因果掩碼(即任何S ,其中 > 的條目都設置為?∞)。

1. 由于FlashAttention和FlashAttention-2已經(jīng)通過塊操作來實現(xiàn),對于所有列索引都大于行索引的塊(大約占總塊數(shù)的一半),我們可以跳過該塊的計算。這比沒有應用因果掩碼的注意力計算速度提高了1.7-1.8倍。

2. 不需要對那些行索引嚴格小于列索引的塊應用因果掩碼。這意味著對于每一行,我們只需要對1個塊應用因果掩碼。

Parallelism

FlashAttention在batch和heads兩個維度上進行了并行化:使用一個thread block來處理一個attention head,總共需要thread block的數(shù)量等于batch size × number of heads。每個block被調到到一個SM上運行,例如A100 GPU上有108個SMs。當block數(shù)量很大時(例如≥80),這種調度方式是高效的,因為幾乎可以有效利用GPU上所有計算資源。

但是在處理長序列輸入時,由于內(nèi)存限制,通常會減小batch size和head數(shù)量,這樣并行化成都就降低了。因此,F(xiàn)lashAttention-2還在序列長度這一維度上進行并行化,顯著提升了計算速度。此外,當batch size和head數(shù)量較小時,在序列長度上增加并行性有助于提高GPU占用率。

96415c80-76f8-11ee-939d-92fbcf53809c.png

Work Partitioning Between Warps

上一節(jié)討論了如何分配thread block,然而在每個thread block內(nèi)部,我們也需要決定如何在不同的warp之間分配工作。我們通常在每個thread block中使用4或8個warp,如下圖所示。

964a3526-76f8-11ee-939d-92fbcf53809c.jpg

Work partitioning between different warps in the forward pass

964e7a6e-76f8-11ee-939d-92fbcf53809c.png

論文中原話是”However, this is inefficient since all warps need to write their intermediate results out toshared memory, synchronize, then add up the intermediate results.”,說的是shared memory而非HBM,但是結合下圖黃色框部分推斷,我認為是HBM。

966cc258-76f8-11ee-939d-92fbcf53809c.jpg

96714378-76f8-11ee-939d-92fbcf53809c.png

967ddbe2-76f8-11ee-939d-92fbcf53809c.jpg

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 存儲器
    +關注

    關注

    38

    文章

    7492

    瀏覽量

    163843
  • gpu
    gpu
    +關注

    關注

    28

    文章

    4740

    瀏覽量

    128951
  • 矩陣
    +關注

    關注

    0

    文章

    423

    瀏覽量

    34548

原文標題:FlashAttention2詳解(性能比FlashAttention提升200%)

文章出處:【微信號:GiantPandaCV,微信公眾號:GiantPandaCV】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    不同材質的阻尼器性能比

    能量耗散能力和耐久性。 不同材質阻尼器的性能比較 1. 粘彈性阻尼器 粘彈性材料,如橡膠和聚合物,因其高阻尼和良好的粘彈性特性而被廣泛用于阻尼器的制造。這些材料能夠在較寬的溫度范圍內(nèi)保持性能穩(wěn)定,且具有較好的耐老
    的頭像 發(fā)表于 11-14 10:46 ?535次閱讀

    電流斜坡和電壓斜坡熱插拔控制器IC的性能比

    電子發(fā)燒友網(wǎng)站提供《電流斜坡和電壓斜坡熱插拔控制器IC的性能比較.pdf》資料免費下載
    發(fā)表于 10-12 10:02 ?0次下載
    電流斜坡和電壓斜坡熱插拔控制器IC的<b class='flag-5'>性能比</b>較

    集成FET與外部FET:電機驅動器的性能比

    電子發(fā)燒友網(wǎng)站提供《集成FET與外部FET:電機驅動器的性能比較.pdf》資料免費下載
    發(fā)表于 09-10 10:54 ?1次下載
    集成FET與外部FET:電機驅動器的<b class='flag-5'>性能比</b>較

    ARM發(fā)布旗艦手機芯片:性能提升、AI性能增強、節(jié)能減耗

    ARM為Cortex-X系列CPU重新命名,以強調其性能的顯著提升。據(jù)稱,X925的單核性能較X4提升了36%(依據(jù)Geekbench測試結果)。此外,由于配備了高達3MB的私有L
    的頭像 發(fā)表于 05-30 11:26 ?680次閱讀

    如何修改Kernel Affinity提升openplc性能

    如何修改Kernel Affinity提升openplc性能
    發(fā)表于 05-22 06:36

    英偉達H200性能顯著提升,年內(nèi)將推出B200新一代AI半導體

    同一天,NVIDIA發(fā)布了H200性能評估報告,表明在與美國Meta公司的大型語言模型——LLM“Llama 2”的對比中,H200使AI導出答案的處理速度最高
    的頭像 發(fā)表于 04-01 09:36 ?1418次閱讀

    英偉達發(fā)布性能大幅提升的新款B200 AI GPU

    英偉達宣稱,B200性能以往最好的GPU快30倍不止。由它構成的服務器集群相比上一代,運算能力飛躍性提升,甚至能使大語言模型的訓練速度翻番。
    的頭像 發(fā)表于 03-20 09:37 ?801次閱讀

    斯坦福繼Flash Attention V1和V2又推出Flash Decoding

    斯坦福大學此前提出的FlashAttention算法,能夠在BERT-large訓練中節(jié)省15%,將GPT訓練速度提高2/3。
    的頭像 發(fā)表于 03-13 15:23 ?767次閱讀

    蘋果M3芯片性能提升

    蘋果在2023年發(fā)布的M3芯片系列,在CPU性能和效率內(nèi)核方面相較于M1系列有了顯著的提升。具體來說,M3 CPU的性能核心M1系列快30%,效率核心更是
    的頭像 發(fā)表于 03-11 17:13 ?1231次閱讀

    M3芯片M2芯片快多少

    M3芯片相較于M2芯片,在性能上有了顯著的提升。具體來說,M3芯片在GPU速度上達到了M2芯片的1.8倍,這意味著在處理圖形密集型任務時,M3芯片能夠展現(xiàn)出更高的效率和流暢度。此外,在
    的頭像 發(fā)表于 03-08 17:04 ?3275次閱讀

    英偉達H200帶寬狂飆

    英偉達H200帶寬的顯著提升主要得益于其強大的硬件配置和先進的技術創(chuàng)新。H200配備了高達141GB的HBM3e顯存,與前代產(chǎn)品H100相,內(nèi)存容量
    的頭像 發(fā)表于 03-07 16:44 ?956次閱讀

    英偉達H200性能怎么樣

    英偉達H200性能卓越,集成了高性能CPU和GPU,通過高速NVLink連接,消除了傳統(tǒng)計算瓶頸。其配備了高達141GB的HBM3e高帶寬內(nèi)存,大幅提升了數(shù)據(jù)處理能力。H
    的頭像 發(fā)表于 03-07 16:39 ?1039次閱讀

    EMC測試整改:提升產(chǎn)品合規(guī)性和市場競爭力?|深圳創(chuàng)達電子

    EMC測試整改:提升產(chǎn)品合規(guī)性和市場競爭力?|深圳創(chuàng)達電子在當前的產(chǎn)品研發(fā)和制造領域,電磁兼容(EMC)測試是確保產(chǎn)品符合法規(guī)要求并能夠在各種電磁環(huán)境下正常工作的重要環(huán)節(jié)。然而,很多企業(yè)在進行
    發(fā)表于 03-07 09:50

    電感器磁芯材料性能比較表

    電子發(fā)燒友網(wǎng)站提供《電感器磁芯材料性能比較表.doc》資料免費下載
    發(fā)表于 02-27 15:57 ?1次下載

    差分探頭和單端探頭的性能比

    差分探頭和單端探頭的性能比較? 差分探頭和單端探頭是電子測試領域中常見的兩類測量傳感器。它們具有不同的工作原理和特點,不同的應用場景下具有不同的性能優(yōu)劣勢。本文將對差分探頭和單端探頭的性能進行比較
    的頭像 發(fā)表于 01-08 11:19 ?831次閱讀
    主站蜘蛛池模板: 一级做a免费视频| 奇米影视777四色米奇影院| 久久午夜网| 日本aaaaa| 欧美一级片在线视频| 悠悠影院欧美日韩国产| 欧美高清另类| 四虎影院新地址| ww欧洲ww欧洲视频| 欧美另类高清xxxxx| 天堂资源wwww在线看| 二级黄绝大片中国免费视频0| 国内黄色精品| 亚洲人成网站色在线观看| 国产专区视频| seetube18日本第一次| 亚洲jizzjizz在线播放久| 国产高清免费| 1024手机免费看| 四虎影院免费在线播放| 8000av在线| 在线观看亚洲一区二区| 日韩毛片在线视频| 天天操天天干天天射| 免费精品99久久国产综合精品 | 台湾黄色毛片| 狠狠色噜噜狠狠狠狠黑人| 久精品视频村上里沙| 操日本美女视频| 色老头免费视频| 色综合天天五月色| 亚洲综合亚洲综合网成人| jiuma和我啪啪| 男人一级片| 国产一级毛片外aaaa| 国产操女人| 免费的黄色的视频| 3344免费播放观看视频| 日本a级片在线播放| 九九福利视频| 色播五月综合|