博客專欄

EEPW首頁 > 博客 > CVPR 2022|解耦知識蒸餾,讓Hinton在7年前提出的方法重回SOTA行列

CVPR 2022|解耦知識蒸餾,讓Hinton在7年前提出的方法重回SOTA行列

發(fā)布人:機器之心 時間:2022-04-09 來源:工程師 發(fā)布文章
與主流的feature蒸餾方法不同,本研究將重心放回到logits蒸餾上,提出了一種新的方法「解耦知識蒸餾」,重新達到了SOTA結(jié)果,為保證復現(xiàn)該研究還提供了開源的蒸餾代碼庫:MDistiller。

1 研究摘要

近年來頂會的 SOTA 蒸餾方法多基于 CNN 的中間層特征,而基于輸出 logits 的方法被嚴重忽視了。飲水思源,本文中來自曠視科技 (Megvii)、早稻田大學、清華大學的研究者將研究重心放回到 logits 蒸餾上,對 7 年前 Hinton 提出的知識蒸餾方法(Knowledge Distillation,下文簡稱 KD)[1] 進行了解耦和分析,發(fā)現(xiàn)了一些限制 KD 性能的重要因素,進而提出了一種新的方法「解耦知識蒸餾」(Decoupled Knowledge Distillation,下文簡稱 DKD)[2],使得 logits 蒸餾重回 SOTA 行列。
同時,為了保證復現(xiàn)和支持進一步研究,該研究提供了一個全新的開源代碼庫 MDistiller,該庫涵蓋了 DKD 和大部分的 SOTA 方法,并不斷進行更新維護,歡迎大家試用并提供寶貴的反饋意見。

圖片


  • 論文鏈接:https://arxiv.org/abs/2203.08679

  • 代碼鏈接:https://github.com/megvii-research/mdistiller


2 研究動機

圖片


上圖是大家熟知的 KD 方法,KD 用 Teacher 網(wǎng)絡(luò)和 Student 網(wǎng)絡(luò)的輸出 logits 來計算 KL Loss,從而實現(xiàn) dark knowledge 的傳遞,利用 Teacher 已經(jīng)學到的知識幫助 Student 收斂得更好。在 KD 之后,更多的基于中間特征的蒸餾方法不斷涌現(xiàn),不斷刷新知識蒸餾的 SOTA。但該研究認為,KD 這樣的 logits 蒸餾方法具備兩點好處:
1. 基于 feature 的蒸餾方法需要更多復雜的結(jié)構(gòu)來拉齊特征的尺度和網(wǎng)絡(luò)的表示能力,而 logits 蒸餾方法更簡單高效;2. 相比中間 feature,logits 的語義信息是更 high-level 且更明確的,基于 logits 信號的蒸餾方法也應(yīng)該具備更高的性能上限,因此,對 logits 蒸餾進行更多的探索是有意義的。
該研究嘗試一種拆解的方法來更深入地分析 KD:將 logits 分成兩個部分(如圖),藍色部分代表目標類別(target class)的 score,綠色部分代表非目標類別(Non-target class)的 score。這樣的拆解使得我們可以重新推導 KD 的 Loss 公式,得到一個新的等價表達式,進而做更多的實驗和分析。
2.1 符號定義
這里只寫出關(guān)鍵符號定義,更具體的定義請參考論文正文。
首先,該研究將第 i 類的分類概率表示為(其中圖片表示網(wǎng)絡(luò)輸出的 logits):

圖片


為了拆解分類網(wǎng)絡(luò)輸出的 logits,該研究接下來定義了兩種新的概率分布圖片
1. 目標類 vs 非目標類的二分類分布,該概率分布和分類監(jiān)督信號高度耦合。該分布包含兩個元素:目標類概率和全部非目標類概率,分別表示為:

圖片


2. 非目標類內(nèi)部競爭的多分類分布圖片,也就是在預測樣本為非目標類的前提下每個類各自的概率(總和為 1)。這個概率分布和分類的監(jiān)督信號是不相關(guān)的,換句話說,從這個概率分布中無法得知目標類上的預測置信度,其表達式為:

圖片


根據(jù)上述定義,可以得到一個顯然的數(shù)學關(guān)系:圖片。這些定義和數(shù)學關(guān)系將幫助我們得到 KD Loss 的一個新的表達形式。
2.2 重新推導 KD Loss
首先,KD 的 Loss 定義如下:

圖片


然后根據(jù)公式(1)和(2),我們可以將其改寫為:

圖片


可以觀察到,式中的第一項圖片只牽涉到了目標類別 vs 非目標類別的二分類概率分布圖片,第二項圖片牽涉到了非目標類概率分布的 KL 散度圖片和權(quán)重圖片。該研究將第一項命名為目標類別知識蒸餾 Target Class Knowledge Distillation(下文簡稱 TCKD),將第二項中的 KL 散度命名為非目標類別知識蒸餾 Non-target Class Knowledge Distillation(下文簡稱 NCKD)。至此,該研究完成了對 KD Loss 的拆分,將其分成了兩個可單獨使用的部分,并可以分析其各自的作用:

圖片


3 啟發(fā)式探索
首先,該研究對 TCKD 和 NCKD 做了消融實驗,觀察它們對蒸餾性能的影響;接著,他們分別探索 TCKD 和 NCKD 的作用;最后,研究者做了一些啟發(fā)式的討論。
3.1 單獨使用 TCKD/NCKD 訓練

圖片


如表 1 所示,我們可以觀察到:
1. 同時使用 TCKD 和 NCKD(等同于 KD),有不錯的性能提升;2. 單獨使用 TCKD 進行蒸餾,會對蒸餾效果產(chǎn)生較大的損害(這一點在補充材料中有詳細討論,主要和蒸餾溫度 T 相關(guān));3. 單獨使用 NCKD 進行蒸餾,和 KD 的效果是差不多的,甚至有時會更好;
基于這些觀察可以推出兩個初步結(jié)論:
1.TCKD 是沒用的,甚至在單獨使用時可能是有害的;2.NCKD 可能是 KD 生效的主要原因;
接下來該研究就這兩個初步的結(jié)論進行了進一步的分析。
3.2 TCKD:傳遞樣本難度相關(guān)的知識
TCKD 作用于目標類的二分類概率分布上,這個概率的物理含義是「網(wǎng)絡(luò)對樣本的置信度」。比如:如果一個樣本被 Teacher 學會了,會產(chǎn)生類似[0.99, 0.01] 的 binary 概率,而如果一個樣本比較難擬合,則會產(chǎn)生類似 [0.6, 0.4] 的 binary 概率。所以該研究猜測:TCKD 傳遞了和樣本擬合難度相關(guān)的知識,當訓練集擬合難度高時才會起到作用。為了證明這一點,該研究設(shè)計了三組實驗來增加 CIFAR-100 的訓練難度,觀察 TCKD 是否有效:
更強的數(shù)據(jù)增廣:

圖片


以表 2 中的 ShuffleNet-V1 為例,在使用 AutoAugment 的情況下,訓練集難度有了明顯提升,此時僅僅使用 NCKD 只能達到 73.8% 的 student 準確率,而同時使用 TCKD 和 NCKD 可以將 student 準確率提升至 75.3%。
更 Noisy 的標簽:

圖片


表 3 中,該研究通過控制 noisy ratio 對數(shù)據(jù)集的標簽引入不同程度噪聲,ratio 越大表示噪聲越大??梢钥吹剑S著數(shù)據(jù)集的噪聲變大,單獨使用 NCKD 的效果變得越來越差,同時引入 TCKD 的增益也越來越大。說明在越難學的數(shù)據(jù)上,TCKD 的作用就會越明顯。
更難的數(shù)據(jù)集:

圖片


ImageNet 是一個比 CIFAR-100 更困難的數(shù)據(jù)集,所以該研究在 ImageNet 上也進行了嘗試。從表 4 可以看出,在 ImageNet 上只使用 NCKD 的效果也是沒有同時使用 TCKD 和 NCKD 要好的。
總結(jié)
三組實驗都反映出,當訓練數(shù)據(jù)擬合難度變高時(無論是數(shù)據(jù)本身難度、還是噪聲和增廣帶來的難度),TCKD 能提供更有效的知識,對蒸餾性能的提升也越高,這些實驗在一定程度上說明了 TCKD 確實是在傳遞有關(guān)樣本擬合難度的知識,印證了該研究的想法。
3.3 NCKD:被抑制的重要成分
表 1 中反映出的另一個有趣的現(xiàn)象是:只使用 NCKD 也能取得令人滿意的蒸餾效果,甚至可能比 KD 更好。這樣的現(xiàn)象反映出:非目標類別上的 logits 中蘊含的信息,才是最主要的 dark knowledge 成分。
然而當回顧 KD 的新表達式時,發(fā)現(xiàn) NCKD 對應(yīng)的 loss 是和權(quán)重圖片耦合在一起的。換言之,如果 teacher 網(wǎng)絡(luò)的預測越置信,NCKD 的 loss 權(quán)重就更低,其作用就會越小。而該研究認為,teacher 更置信的樣本能夠提供更有益的 dark knowledge,和 NCKD 耦合的圖片權(quán)重會嚴重抑制高置信度樣本的知識遷移,使得知識蒸餾的效率大幅降低。為了證明這一點,該研究做了如下實驗:
1. 依據(jù) teacher 模型的置信度,該研究對訓練集上的樣本做了排序,并將排序后的樣本分成置信(置信度 top-50%)和非置信 (剩余) 兩個批次;2. 訓練時,對全部樣本使用分類 Loss,并只對置信批次 / 非置信批次使用 NCKD Loss;

圖片


實驗結(jié)果如表 5 所示,0-50% 表示置信批次,50-100% 表示非置信批次。第一行是在整個訓練集上做 NCKD 的結(jié)果,第二行表示只對置信批次做 NCKD,第三行表示只對非置信批次做 NCKD。顯然,置信批次上使用 NCKD 帶來了更主要的漲點,說明置信度更高的樣本對蒸餾的訓練過程是更有益的,因此是不應(yīng)該被抑制的。
3.4 啟發(fā)
至此,該研究完成了對 KD Loss 的解耦,并且分析了兩個部分各自的作用。所有結(jié)果都表明,TCKD 和 NCKD 都有自己的重要作用,然而,研究注意到了在原始的 KD Loss 中,TCKD 和 NCKD 是存在不合理的耦合的:
1. 一方面,NCKD 和圖片耦合,會導致高置信度樣本的蒸餾效果大打折扣;2. 另一方面,TCKD 和 NCKD 是耦合的。然而這兩個部分傳遞的知識是不同的,這樣的耦合導致了他們各自的重要性沒有辦法靈活調(diào)整。
4 Decoupled Knowledge Distillation

圖片


根據(jù)推導和啟發(fā)式探索,該研究提出了一種新的 logits 蒸餾方法“解耦知識蒸餾(DKD)”,來解決上一章提出的兩個問題,如上圖所示。DKD 的 Loss 表達式如下:

圖片


和 KD Loss 相比,該研究將限制 NCKD 的權(quán)重圖片替換為了圖片,并給 TCKD 設(shè)置了一個權(quán)重圖片DKD 可以很好地解決剛才提到的兩個問題:一方面,TCKD 和 NCKD 被解耦,它們各自的重要性可以獨立調(diào)節(jié);另一方面,對于蒸餾更重要的 NCKD 也不會再被 Teacher 產(chǎn)生的高置信度抑制,大大提高了蒸餾的靈活性和有效性。DKD 的偽代碼如下:

圖片


5 實驗結(jié)果
5.1 Decoupling 帶來的好處

圖片


首先該研究通過 ablation study 驗證了 DKD 的有效性,上面的表格表明:
1. 解耦圖片和 NCKD,也就是把圖片設(shè)置為 1.0,可以將 top-1 accuracy 從 73.6% 提升至 74.8%;2. 解耦 NCKD 和 TCKD 的權(quán)重,即進一步調(diào)節(jié)圖片的數(shù)值,可以將 top-1 accuracy 從 74.8% 進一步提升至 76.3%;
這些實驗結(jié)果說明 DKD 的解耦確實能帶來顯著的性能增益,這一方面證明了 KD 確實存在剛才提到的兩個問題,另一方面也證明了 DKD 的有效性。此外,這個表格也證明了圖片對超參數(shù)是不敏感的,把圖片設(shè)置為 1.0 就可以取得令人滿意的效果,所以在實際應(yīng)用中只需要調(diào)節(jié)圖片即可。同時,圖片也不是一個敏感的超參數(shù),在 4.0-10.0 的范圍內(nèi),都可以取得令人滿意的蒸餾效果。
5.2 圖像分類

圖片

圖片


表 6~9 中提供了 DKD 在 CIFAR-100 和 ImageNet-1K 兩個分類數(shù)據(jù)集上的蒸餾效果。和 KD 相比,DKD 在所有數(shù)據(jù)集和網(wǎng)絡(luò)結(jié)構(gòu)上都有明顯的性能提升。此外,與過去最好的特征蒸餾方法(ReviewKD)相比,DKD 也取得了接近甚至更好的結(jié)果。DKD 成功使得 logits 蒸餾方法重新回到了 SOTA 的陣營中。
5.3 目標檢測

圖片


該研究也在目標檢測任務(wù)(MS-COCO)上驗證了 DKD 的性能。如表 10 所示,在 Detector 蒸餾中,DKD 的結(jié)果雖不如特征蒸餾的 SOTA 性能,但是依然穩(wěn)定地超過了 KD 的性能。而將 DKD 和特征蒸餾方法組合起來,也可以進一步提高 SOTA 結(jié)果。
關(guān)于這一點:過去的一些工作證明了,Detection 任務(wù)非常依賴特征的定位能力,這在 Detector 蒸餾中也是成立的(如 [5] 中提到了,feature mimicking 是非常重要的)。而 logits 并不能提供 location 相關(guān)的信息,無法對 Student 的定位能力產(chǎn)生幫助,因此在 Detection 任務(wù)中,特征蒸餾相比 logits 蒸餾存在機制上的優(yōu)勢,這也是 DKD 無法超過特征蒸餾 SOTA 的原因。
6 擴展性實驗和可視化
6.1 訓練效率

圖片


logits 蒸餾的好處之一是訓練效率高。為了證明這一點,該研究可視化了 SOTA 蒸餾方法的訓練開銷。圖 2 的 X 軸是每個 batch 的訓練時間,Y 軸是 student 的 top-1 accuracy。顯然,logits 蒸餾(KD 和 DKD)所需的訓練時間是最少的,并且 DKD 用了最少的時間獲得了最好的蒸餾效果。圖 2 中的表格也提供了訓練時間和訓練所需的額外參數(shù)量,和 KD 一樣,DKD 也并沒有額外引入?yún)?shù)量,同時訓練時間也幾乎沒有增加。logits 蒸餾的優(yōu)越性顯而易見。
6.2 提升大 Teacher 模型蒸餾效果

圖片


過去的一些蒸餾工作發(fā)現(xiàn)了一個有趣的現(xiàn)象:大模型并不一定是好的 Teacher 網(wǎng)絡(luò)。對于該現(xiàn)象,研究者提供了一個可能的解釋:大模型的 model capacity 很大,這會導致大模型產(chǎn)生更高的圖片,進而導致的 NCKD 被抑制得更嚴重。過去的一些工作也可以基于這一點解釋,如 ESKD [4] 引入了 early-stopped teacher 來緩解這一問題,這可能是因為 early-stopped 模型還沒有充分擬合訓練集,圖片還比較小,所以對 NCKD 的抑制不是很嚴重。
為了證明該觀點,研究者也進行了一系列的對比實驗。如表 11 和表 12 所示,當使用 DKD 時,大模型蒸餾效果變差的問題被顯著改善。該研究希望這一點可以為后續(xù)的工作提供一些 insight。
6.3 特征遷移性

圖片


這里該研究嘗試將 DKD 訓練得到的 student 網(wǎng)絡(luò)進行特征遷移。如表 13 所示,研究者將在 CIFAR-100 上訓練的 student 遷移到了 STL-10 和 TinyImageNet 兩個數(shù)據(jù)集上,在眾多的蒸餾方法中,DKD 取得了最好的遷移效果。
6.4 可視化
這里研究者提供了兩種可視化。圖 3 中,與 KD 相比,DKD 的樣本聚得更加緊湊,說明 DKD 幫助 student 網(wǎng)絡(luò)學到了更加可區(qū)分的特征。圖 4 中,研究者計算了 teacher 網(wǎng)絡(luò)和 student 網(wǎng)絡(luò)輸出 logits 的相似度,和 KD 相比,DKD 訓練后的 student 產(chǎn)生的 logits 會更像 teacher 產(chǎn)生的 logits,說明 teacher 的知識被更好地利用了。

圖片


7 改進方向
圖片自適應(yīng)調(diào)整:DKD 目前還需要手工調(diào)整圖片的值才能達到最佳的蒸餾效果,該研究希望可以通過一些訓練過程中的統(tǒng)計量實現(xiàn)對圖片自適應(yīng)調(diào)節(jié)(對于這一點,該研究已經(jīng)有了初步的探索,詳情可見補充材料)。
8 開源代碼庫 MDistiller

圖片


為了保證復現(xiàn)和進一步的探索,該研究還開源了一個知識蒸餾的 codebase MDistiller。該 codebase 涵蓋了大部分的 SOTA 方法,同時支持兩種蒸餾關(guān)注的主要任務(wù),圖像分類和目標檢測。該研究希望 MDistiller 可以為后續(xù)的研究者們提供一套可靠的 baseline,因此會提供長期支持。
參考文獻
[1] Geoffrey Hinton, Oriol Vinyals, and Jeff Dean. Distilling the knowledge in a neural network. In arXiv:1503.02531, 2015.[2] Borui Zhao, Quan Cui, Renjie Song, Yiyu Qiu, and Jiajun Liang. Decoupled knowledge distillation. In CVPR, 2022. [3] Pengguang Chen, Shu Liu, Hengshuang Zhao, and Jiaya Jia. Distilling knowledge via knowledge review. In CVPR, 2021. [4] Jang Hyun Cho and Bharath Hariharan. On the efficacy of knowledge distillation. In ICCV, 2019. [5] Tao Wang, Li Yuan, Xiaopeng Zhang, and Jiashi Feng. Distilling object detectors with fine-grained feature imitation. In CVPR, 2019. 


*博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點,如有侵權(quán)請聯(lián)系工作人員刪除。



關(guān)鍵詞: AI

相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉