確率的勾配降下法

提供: testwiki
2025年3月8日 (土) 15:11時点におけるimported>Oyyo37による版 (校正)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動
ミニバッチを使い上下に行ったり来たりしながら目的関数の値が減少していく例

確率的勾配降下法(かくりつてきこうばいこうかほう、テンプレート:Lang-en-short)は、連続最適化問題に対する勾配法乱択アルゴリズム。バッチ学習である最急降下法をオンライン学習に改良したアルゴリズムである。目的関数が微分可能な和の形であることを必要とする。

背景

下記の和の形の目的関数を最小化する問題を扱う。

Q(w)=i=1nQi(w)

パラメータ w* はQ(w) を最小化するように推定する。典型的には、Qi は i 番目の訓練データ。

古典的な統計学において、和の最小化問題は、最小二乗問題最尤推定問題などにあらわれる。一般的なケースでは、和を最小化する推定量はM推定量と呼ぶ。しかしながら、Thomas S. Fergusonの例[1]などで示されるように、いくつかの最尤推定の問題において、最小解ではなく局所解を要求するだけでも制限が厳しすぎると長い間認識され続けてきた。それゆえ、現代の統計理論家は最尤関数の停留点(微分がゼロになる点)を考慮する事が多くなった。

和の最小化問題はテンプレート:仮リンクの問題にも現れる。Qi(w) の値が i 番目の訓練データであるならば、Q(w) が経験損失である。

上記の関数 Q を最小化する際、標準的な最急降下法(バッチ学習)では、下記の反復を繰り返す。

w:=wηQ(w)=wηi=1nQi(w)

η はステップサイズと呼ばれる。機械学習においてはテンプレート:仮リンクとも呼ばれる。

確率分布がパラメータが一つの指数型分布族などで、勾配の総和の計算が、小さな計算量で出来てしまう事もあるが、一つ一つの勾配を計算して総和を取らないといけない事も多い。そのような場合、和の全体ではなく、和の一部分だけを計算する事で、1回の反復の計算量を小さくする事ができる。これは大規模な機械学習の問題で効果的である[2]

反復法

確率的勾配降下法(オンライン学習)では、Q(w) の勾配は、1つの訓練データから計算した勾配で近似する。

上記の更新を1つ1つの訓練データで行い、訓練データ集合を一周する。収束するまで訓練データ集合を何周もする。一周するたびに訓練データはランダムにシャッフルする。AdaGrad などの適応学習率のアルゴリズムを使用すると収束が速くなる。

擬似コードでは、確率的勾配降下法は下記になる。

パラメータ w と学習率 η の初期値を選ぶ
while 収束するか所定の反復回数まで反復する do
    Qi(訓練データ)をランダムにシャッフルする
    for each i = 1, 2, ..., n do
        w:=wηQi(w)

全てではないが複数の訓練データで勾配を計算する方法をミニバッチと言う。この方法は、コンピュータのSIMDを有効活用でき計算を高速化できる。また、複数の訓練データを使うので収束がよりなめらかになる事もある。

確率的勾配降下法の収束性は凸最適化と確率近似の理論を使い解析されている。目的関数が凸関数もしくは疑似凸関数であり、学習率が適切な速度で減衰し、さらに、比較的緩い制約条件を付ければ、確率的勾配降下法はほとんど確実に最小解に収束する。目的関数が凸関数でない場合でも、ほとんど確実に局所解に収束する[3][4]。これは Robbins-Siegmund の定理による[5]

Qi(訓練データ)がランダムにシャッフルされる事により、確率的に局所解にはまりにくくなる効果がある。

学習率の調整方法および変種

基本的な確率的勾配降下法に対して多くの改良が提案されている。特に、機械学習において、ステップサイズ(学習率)の調整は重要問題として認識されている。学習率を大きくしすぎると発散し、小さくしすぎると収束まで遅くなる。

確率的近似法

1951年に Herbert Robbins と Sutton Monro が発表[6]。学習率をイテレーション回数の逆数で減衰させる方法。Robbins-Monro法とも言われる。

ηt=η0t

Nesterovの加速勾配降下法

1983年に Yurii Nesterov が発表[7]

x0=w0xt=wt1ηQi(wt1)wt=xt+t1t+2(xtxt1)

モメンタム法

1986年にデビッド・ラメルハートらがバックプロパゲーションと共に提案した方法[8]

Δw:=ηQi(w)+αΔww:=wΔw

平均化法

1988年に David Ruppert が提案した方法[9]

w¯=1ti=1twi

を計算し、最終的にパラメータの平均値を学習結果とする。

Truncated Gradient

2009年に John Langford らが発表した方法[10]。L1 正則化を含む場合、確率的勾配降下法だとパラメータが 0 になりにくいが、K 回毎にパラメータの大きさが θ 以下であれば、0にする方法。

正則化双対平均化法(Regularized Dual Averaging Method)

2009年に Lin Xiao が発表した方法[11][12]。目的関数が下記のように汎化能力を高めるために L1 正則化を含む場合、確率的勾配降下法だとパラメータが 0 になりにくく、そのための対策をした方法。以下、この手法では Q(w) には λw1 を含めずに、L1 正則化の効果を実現する。

Q(w)+λw1

まず、勾配の平均を計算する。

gt=1tt=1tQ(w)t

その上で、パラメータの更新は以下の通り。ここでパラメータの初期値は0としている。

wi:={0if |gt,i|λ,tγ(gt,iλsgn(gt,i))otherwise.

L1 正則化と L2 正則化を

Q(w)+λw1+σ2w22

の形で混ぜる場合は、このようになる。

wi:={0if |gt,i|λ,1σ(gt,iλsgn(gt,i))otherwise.

以下のように、λ を少しずつ大きくしていくと、疎になる度合いを徐々に高めていける。

λ=λ0+ρ/t

AdaGrad

2011年に John Duchi らが発表した方法[13]アダマール積(要素ごとの積)。下記計算、全てパラメータごと(要素ごと)に計算する。ϵ は無限大に発散させないための正の小さな定数。

r0=ϵrt=rt1+Qi(w)Qi(w)ηt=η0rtwt+1=wtηtQi(w)

正則化双対平均化法と AdaGrad を組み合わせる方法が、AdaGrad の発表と共に2011年に出ている[12]

u:=u+Q(w)r:=r+Qi(w)Qi(w)wi:={0if |ui|/tλ,sgn(ui)ηtri(|ui|tλ)otherwise.

RMSProp

2012年に Tijmen Tieleman らが発表した方法[14]。AdaGrad の変形。勾配の2乗の指数移動平均を取るように変更。β=0.9 などを使用。

rt=βrt1+(1β)Qi(w)Qi(w)ηt=η0rt+ϵwt+1=wtηtQi(w)

AdaDelta

2012年に Matthew D. Zeiler が発表した方法[15]。AdaGrad や RMSProp の変形。初期学習率のハイパーパラメータがなくなっている。

rt=βrt1+(1β)Qi(w)Qi(w)vt=st+ϵrt+ϵQi(w)st+1=βst+(1β)vtvtwt+1=wtvt

Sum of Functions Optimizer

2014年に Jascha Sohl-Dickstein らが発表した方法[16]。確率的勾配降下法と記憶制限準ニュートン法の L-BFGS を組み合わせた方法。二次収束するようになり、収束が AdaGrad などよりも速くなった。

Adam

2015年に Diederik P. Kingma らが発表した方法[17]。AdaGrad, RMSProp, AdaDelta の変形。AdaGrad や Sum of Functions Optimizer よりも収束が速くなった。ハイパーパラメータは α=0.001,β1=0.9,β2=0.999,ϵ=108 を推奨。イテレーション回数 t は 1 から始める。

m0=v0=0mt=β1mt1+(1β1)Qi(w)vt=β2vt1+(1β2)Qi(w)Qi(w)m^t=mt1β1tv^t=vt1β2twt=wt1αm^tv^t+ϵ

AdaBound

2019年のICLRでLiangchen Luoらが発表した方法[18]。 Adamに学習率の制限(Bound)を加え、ステップごとにSGDへ連続的に変化させることによって、Adamの収束速度とSGDの汎化性能の両立を目指した。論文中でのハイパーパラメータと学習率の下限・上限は α=0.001,β1=0.9,β2=0.999,ηl(t)=0.10.1(1β2)t+1,ηu(t)=0.1+0.1(1β2)tであり、Adamと同様にt=1から始める。

m0=v0=0gt=Qi(w)mt=β1mt1+(1β1)gtvt=β2vt1+(1β2)gt2,and Vt=diag(vt)η^t=Clip(αVt,ηl(t),ηu(t))wt=wt1η^ttmt

パラメータの初期値

パラメータ w の初期値はなんらかの確率分布からランダムに選ぶ。どの確率分布を使うかは、最小値の近傍に収束する確率に影響がある。しかし、何が適切な確率分布かはモデル次第である。ニューラルネットワークの場合についてはバックプロパゲーションの項目を参照。

平均・分散の調整

確率的勾配降下法は入力の値に極端に平均・分散が異なる物が混じると、うまく行かなくなる確率が上がる。よって、モデル自体に線形変換をかけるなどして、訓練データの正規化をして、平均0分散1になるように調整する方が良い。

正規化オンライン学習

学習データがリアルタイムで手に入るなど、事前に平均0分散1に調整できない場合のために、2013年に Stephane Ross らが正規化オンライン学習を発表している[19]。データの絶対値の最大値を追跡して、それを元に調整する。

脚注

テンプレート:脚注ヘルプ テンプレート:Reflist

関連項目

テンプレート:最適化アルゴリズム