《電子技術(shù)應用》
您所在的位置:首頁 > 可編程邏輯 > 解決方案 > 自適應學習率調(diào)度器了解一下?

自適應學習率調(diào)度器了解一下?

2019-02-28

傳統(tǒng)觀點認為,太大的學習率不利于優(yōu)化深度神經(jīng)網(wǎng)絡,而相比固定的學習率而言,變化的學習率更能提供快速的收斂。基于此,本文作者基于理論基礎提出了一個計算深度神經(jīng)網(wǎng)絡學習率的新方法。實驗結(jié)果證明了該方法的有效性。


訓練神經(jīng)網(wǎng)絡受到幾個問題的困擾。這些問題包括梯度消失、梯度爆炸 [7,3] 和過擬合。包括不同激活函數(shù) [14,17]、批歸一化 [12]、新穎的初始化方案 [9] 以及 Dropout[26] 在內(nèi)的多種進展都為這些問題提供了解決方案。


但是,一個更基本的問題是為不同的超參數(shù)尋找最優(yōu)值,而對這個問題而言學習率可以說是最重要的。眾所周知,學習率太小會導致收斂變慢,但是太大的學習率又會導致發(fā)散 [2]。近期的研究一致認為,與固定的學習率相比,變化的學習率調(diào)度系統(tǒng)能夠提供更快的收斂 [20,23]。而覺得不應使用較大學習率的傳統(tǒng)經(jīng)驗也被認為有問題,可能導致「超收斂」和規(guī)則效應(regularizing effect)[25]。本文的實驗結(jié)果和這個說法是一致的;但是作者沒有使用循環(huán)的學習率,而是提出了一種基于理論基礎來計算自適應學習率的新方法。


據(jù)作者所知,這是首次提出具有理論基礎的自適應學習率調(diào)度器并且在標準數(shù)據(jù)集和網(wǎng)絡架構(gòu)上進行實證研究。所以,本文的貢獻是雙重的。首先,作者基于損失函數(shù)的利普希茨常數(shù)(Lipschitz),提出了一個用于在深度神經(jīng)網(wǎng)絡的隨機梯度下降中計算最優(yōu)學習率的新理論框架。其工作表明,在激活函數(shù)的特定選擇方面,僅最后兩層的激活函數(shù)是計算學習率時所需要的。其次,作者為幾個常用的損失函數(shù)計算了理想的學習率,并用這些公式實驗性地證明了其方法的有效性。


本文方法利用了損失函數(shù)的函數(shù)屬性,僅對損失函數(shù)做了兩個最小限度的假設:它必須是利普希茨連續(xù)的 [19], 且至少是一階可微的。常用的損失函數(shù)都滿足這兩個條件。


論文:A novel adaptive learning rate scheduler for deep neural networks

微信圖片_20190228181427.jpg


論文地址:https://arxiv.org/abs/1902.07399


摘要:優(yōu)化深度神經(jīng)網(wǎng)絡在很大程度上被認為是一個經(jīng)驗過程,它需要手動調(diào)節(jié)幾個參數(shù),例如學習率、權(quán)重衰減以及隨機失活率(dropout rate)??梢哉f,學習率是這些需要調(diào)節(jié)的參數(shù)中最重要的一個,它在最近的工作中也得到了更多的關(guān)注。在本文中,我們提出了一個計算深度神經(jīng)網(wǎng)絡學習率的新方法。我們推導了動態(tài)計算學習率的理論框架,然后展示了在標準數(shù)據(jù)集和模型架構(gòu)上的實驗結(jié)果來證明該方法的有效性。


理論框架


對一個使用 Sigmoid、ReLU 或者 softmax 激活函數(shù)的神經(jīng)網(wǎng)絡來說,很容易表現(xiàn)出這樣的現(xiàn)象:反向傳播時朝著淺層的方向梯度會越來越小。因此,最后一層的梯度是反向傳播過程中計算出的梯度中最大的一個。如果微信圖片_20190228181518.jpg 是第 l 層節(jié)點 i 到節(jié)點 j 的權(quán)重,并且 L 是總的層數(shù),那么:

微信圖片_20190228181450.jpg


本質(zhì)上,公式 (1) 表示誤差對最后一層權(quán)重的最大梯度比誤差對網(wǎng)絡中任何權(quán)重的梯度都要大。顯然這也可以擴展到偏置(bias)。換句話說,找到最后一層的最大梯度就確定了誤差的利普希茨常數(shù)的上確界,這里的梯度都是根據(jù)每一層的權(quán)重參數(shù)來取的。


我們現(xiàn)在分析得出了不同類型問題的理論上確界。這些數(shù)值的倒數(shù)可以用作梯度下降的學習率。在任何一層中,我們都會有這種計算:


微信圖片_20190228181540.jpg


因此,最后一層中任何權(quán)重的梯度都是通過下面的鏈式法則來計算的:

微信圖片_20190228181600.jpg


第三部分是不能解析計算的;我們將它記作 K_z?,F(xiàn)在看一下不同類型的問題,并計算這些組成部分。


實驗


下面我們展示了在一些公開數(shù)據(jù)集上的實驗結(jié)果和細節(jié)。雖然我們的結(jié)果不是最先進的,但我們的重點是憑經(jīng)驗證明隨機梯度下降是可以通過更大的學習率來進行的,而不是像通常理解的那樣只能用小一些的學習率。我們所有的實驗都是在特斯拉 P100 GPU 上運行的,如果沒有特殊說明,模型也是使用(沒有動量或者權(quán)重衰減的)隨機梯度下降優(yōu)化器進行優(yōu)化的。在 CIFAR 數(shù)據(jù)集上,我們和 [10] 一樣僅使用了翻轉(zhuǎn)和平移增強方案。在所有實驗中,原始圖像的像素數(shù)值都除以 255。


在 MNIST 上的實驗只使用了一個自適應學習率,而因為利普希茨常數(shù),學習率在每個 epoch 中都會被重新計算。


圖 1 展示了訓練集和驗證集上準確率和損失函數(shù)隨著 epoch 的變化而變化。圖 2 展示了在各個 epoch 計算的學習率。請注意,與 CIFAR-10(圖 5)和 CIFAR-100(圖 6)中計算的自適應學習率不同,MNIST 的學習率從高得多的值開始。

微信圖片_20190228181630.jpg


圖 5 展示了不同時間的學習率隨。正如相關(guān)文獻所表明的,自適應方案會自動選擇一個衰減的學習率。

微信圖片_20190228181653.jpg

圖 5:CIFAR-10 上自適應學習率隨著時間的變化而變化


圖 6 展示了在各個 epoch 的學習率。與 CIFAR-10 一樣,前兩個 epoch 會以很小的學習率開始(10^(-8)),但是模型會快速適應不斷變化的權(quán)重。

微信圖片_20190228181711.jpg

圖 6: CIFAR-100 上隨著時間變化的自適應學習率。


本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。