KDD 2021 | 用NAS實現(xiàn)任務(wù)無關(guān)且可動態(tài)調(diào)整尺寸的BERT壓縮(1)
編者按:如今,基于 Transformer 的大規(guī)模預(yù)訓(xùn)練語言模型,如 BERT、XLNE、RoBERTa 和 GPT-3 等,已經(jīng)在很多自然語言處理任務(wù)中都取得了十分驚人的效果。但是巨大的模型尺寸,使其在眾多不同的下游任務(wù)中進(jìn)行部署時非常困難。而且由于存在大量復(fù)雜的場景以及不同的下游任務(wù),單獨為不同場景設(shè)計一種壓縮過的 BERT 模型既耗時又耗力。
因此,微軟亞洲研究院的研究員們針對這些問題展開了研究,并提出了 NAS-BERT 技術(shù)。相關(guān)研究論文“NAS-BERT:Task-Agnostic and Adaptive-Size BERT Compression with Neural Architechture Search”已被跨學(xué)科數(shù)據(jù)科學(xué)會議 KDD 2021 收錄。歡迎感興趣的讀者點擊閱讀原文,查看論文全文。
不同設(shè)備往往對訓(xùn)練的模型有不同的要求,如模型占用內(nèi)存的大小、推理時延等。為了滿足設(shè)備的要求,技術(shù)人員往往需要對大規(guī)模的預(yù)訓(xùn)練模型進(jìn)行壓縮處理。但是由于存在大量復(fù)雜的場景和不同的下游任務(wù),專門為每一種場景設(shè)計壓縮過的BERT模型,需要投入大量的人力和計算資源。
對此,微軟亞洲研究院的研究員們提出了 NAS-BERT 技術(shù)(相關(guān)論文已發(fā)表在 KDD 2021 大會上),可以直接在上游預(yù)訓(xùn)練任務(wù)中進(jìn)行壓縮訓(xùn)練,使壓縮模型不再依賴于下游的具體任務(wù)。并且 NAS-BERT 只需通過一次搜索就可以直接產(chǎn)生不同尺寸的模型,進(jìn)而滿足不同設(shè)備的要求。所以即使是資源受限的設(shè)備,也可以動態(tài)選擇合適的架構(gòu)。相較于傳統(tǒng)方法,NAS-BERT 極大地提高了訓(xùn)練效率。
論文鏈接:https://arxiv.org/abs/2105.14444
如表1所示,之前大部分的壓縮工作都是針對具體任務(wù)本身而設(shè)計方法實現(xiàn)的。比如,DisilBERT 等工作會直接在上游模型進(jìn)行壓縮學(xué)習(xí),對下游任務(wù)無關(guān),但不能適應(yīng)各種不同受限資源的場景。DynaBERT 則可以在下游任務(wù)中通過一次訓(xùn)練產(chǎn)生多種不同大小的模型,以達(dá)到動態(tài)調(diào)整尺寸的目的。而 NAS-BERT 與其他幾種工作不同,它可以同時做到任務(wù)無關(guān)和動態(tài)調(diào)整尺寸,并且達(dá)到優(yōu)越的性能。
表1:之前的 BERT 壓縮工作
為了讓 NAS-BERT 實現(xiàn)上述目的,研究員們直接在上游預(yù)訓(xùn)練階段對 NAS-BERT 進(jìn)行了架構(gòu)搜索(NAS)與訓(xùn)練,并且一次性搜索出各種大小的模型,以方便各種場景的部署。通過嘗試架構(gòu)層面的組合方式,NAS-BERT 不僅能夠探索模型本身的潛力,還可以搜索出更加優(yōu)越的架構(gòu)。
具體而言,NAS-BERT 首先在上游預(yù)訓(xùn)練任務(wù)上訓(xùn)練一個超網(wǎng)絡(luò)。其中,超網(wǎng)絡(luò)中的一個有向無環(huán)圖就是一個架構(gòu),不同的架構(gòu)在超網(wǎng)絡(luò)中共享參數(shù)來降低訓(xùn)練成本。然后研究員們再通過自動架構(gòu)搜索技術(shù)去訓(xùn)練這個超網(wǎng)絡(luò)。由于超網(wǎng)絡(luò)中包括各種尺寸的模型,因此可以覆蓋到各種不同的模型大小。最后,在用超網(wǎng)絡(luò)去評價每個架構(gòu)的性能并選擇出優(yōu)越的架構(gòu)。
然而在 BERT 預(yù)訓(xùn)練任務(wù)上做自動架構(gòu)搜索是具有挑戰(zhàn)性的。其主要原因有:1. BERT 預(yù)訓(xùn)練本身收斂慢并且需要巨大的計算資源;2. 巨大的搜索空間會進(jìn)一步導(dǎo)致訓(xùn)練超網(wǎng)絡(luò)變得困難。為了解決這兩個問題,NAS-BERT 主要采用了模塊化搜索和逐漸縮小搜索空間的技術(shù)。同時,為了在縮小搜索空間的基礎(chǔ)上能夠給出各種不同的架構(gòu),NAS-BERT 還使用了分桶搜索把搜索空間分成眾多不同的桶,不同桶中的架構(gòu)有著不同的模型大小和延遲,桶中的架構(gòu)相互競爭,從而選出最優(yōu)越的架構(gòu)。并且不同桶的架構(gòu)通過權(quán)重共享,以降低架構(gòu)搜索的代價。通過使用這些技術(shù),NAS-BERT 才得以快速地搜索出各種不同的優(yōu)越架構(gòu)。
搜索空間的架構(gòu)設(shè)計
NAS-BERT 的架構(gòu)設(shè)計(如圖1所示),首先使用了一個預(yù)訓(xùn)練的 BERT 模型作為教師模型,然后用教師模型指導(dǎo)超網(wǎng)絡(luò)的搜索。為了降低搜索空間,NAS-BERT 把學(xué)生模型(超網(wǎng)絡(luò))分成了幾個不同的搜索模塊,然后每個搜索模塊會進(jìn)行單獨的訓(xùn)練。超網(wǎng)絡(luò)模塊的監(jiān)督信號由教師模型的相應(yīng)模塊給出。換言之,就是給定一批數(shù)據(jù),可以得到教師模型的每個模塊輸入輸出的隱藏表征,再用這些輸入輸出的隱藏表征去訓(xùn)練搜索模塊。這樣,不同的搜索模塊可以分開搜索且并行訓(xùn)練,指數(shù)級地降低了搜索空間。
對于每一個搜索模塊,網(wǎng)絡(luò)設(shè)計如圖1(a)所示,網(wǎng)絡(luò)的每一層包括了所有可能的搜索的候選操作(例如卷積、注意力網(wǎng)絡(luò))。一個架構(gòu)就是一條從底部到最上層的單向路徑,不同的架構(gòu)(路徑)共享權(quán)重以降低訓(xùn)練所需要的資源。
圖1:NAS-BERT 方法框架圖
為了使搜索的架構(gòu)多樣化,研究員們分別采用了三種不同的操作方法:注意力網(wǎng)絡(luò) MHA,前饋網(wǎng)絡(luò) FFN 和可分離卷積 CONV。MHA 和 FFN 是 Transformer 模型中的操作方法,采用這兩種方法,可以使 Transformer 容納在搜索空間中。由于 CONV 已經(jīng)在很多自然語言任務(wù)中取得了不錯的效果,因此研究員們也將其加入了搜索空間,以探索卷積和其他操作組合的潛力(操作設(shè)計請見圖2)。同時,為了使搜索的架構(gòu)具有各種不同的模型大小,研究員們讓每一種操作都有128/192/256/384/512這5種不同的隱藏層大小,如表2所示。與此同時,還加入了 Identity(無操作),使其能搜索出各種不同層的架構(gòu)。
表2:操作集合的設(shè)計
圖2:卷積操作的設(shè)計
通過采用這種設(shè)計,可以使一個6層的搜索模塊中有超過20萬種可能的架構(gòu)。如果采用4個搜索模塊,架構(gòu)的組合方式將超過10^20種。為了訓(xùn)練這個超網(wǎng)絡(luò),每次得到一批數(shù)據(jù),就要隨機采樣一個架構(gòu)進(jìn)行訓(xùn)練,進(jìn)而監(jiān)督和學(xué)習(xí)教師模塊的隱藏表征。由于搜索模塊采樣出來的架構(gòu)輸入輸出的隱藏層大小可能和教師模塊不一致,所以可以直接引入一個可學(xué)習(xí)的線性層進(jìn)行轉(zhuǎn)換,并和超網(wǎng)絡(luò)一起訓(xùn)練。
*博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點,如有侵權(quán)請聯(lián)系工作人員刪除。