多層パーセプトロン

提供: testwiki
2022年2月13日 (日) 00:44時点におけるimported>Phwによる版 (応用: サポートベクトルマシンを一般的な用語に変更)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
ナビゲーションに移動 検索に移動

テンプレート:Machine learning bar 多層パーセプトロン(たそうパーセプトロン、テンプレート:Lang-en-short、略称: MLP)は、テンプレート:仮リンクニューラルネットワークの一分類である。MLPは少なくとも3つのノードの層からなる。入力ノードを除けば、個々のノードは非線形活性化関数を使用するニューロンである。MLPは学習のために誤差逆伝播法(バックプロパゲーション)と呼ばれる教師あり学習手法を利用する[1][2]。その多層構造と非線形活性化関数が、MLPと線形パーセプトロンを区別している。MLPは線形分離可能ではないデータを識別できる[3]

多層パーセプトロンは時折、特に単一の隠れ層を持つ時、「バニラ」ニューラルネットワークと口語的に呼ばれることがある[4]

理論

<section begin=theory />

活性化関数

多層パーセプトロンが全てのニューロンにおいて線形活性化関数、すなわち、個々のニューロンの出力にテンプレート:仮リンクをマップする線形関数を持つとすると、線形代数から、いかなる数の層も2層からなる入力-出力モデルに削減することができることが示される。MLPでは、一部のニューロンは、生物学的ニューロンの活動電位の頻度および発火をモデル化するために開発された「非線形」活性化関数を用いる。

一般的な2つの活性化関数はどちらもシグモイドであり、以下の式で表わされる。

y(vi)=tanh(vi)andy(vi)=(1+evi)1

1つ目の式は−1から1の範囲の双曲線正接(tanh)関数であり、2つ目の式はロジスティック関数である。ロジスティック関数は双曲線正接関数と形状が似ているが範囲は0から1である。ここで、yii番目のノード(ニューロン)の出力であり、viは入力接続の加重和である。他に、Rectifierおよびsoftplus関数を含む活性化関数が提案されている。より専門分野に特化した活性化関数に放射基底関数がある(教師ありニューラルネットワークモデルの一分類であるテンプレート:仮リンクで使われる)。

MLPは、非線形的に活性化されるノードの3つ以上の層(入力層と出力層と1つ以上の「隠れ層」)からなり、ディープニューラルネットワークを作り出す。MLPは全結合(fully connected)のため、1つの層中のそれぞれのノードは次の層中の全てのノードと任意の重みwijで結合している。

学習

学習は、個々のデータが処理された後に、期待される結果と比較した出力中の誤差の大きさに基づいて、結合加重を変化させることによってMLPにおいて起こる。これは教師あり学習の一例であり、誤差逆伝播法(バックプロパゲーション)を用いて実行される。誤差逆伝播法は、線形パーセプトロンにおける最小二乗法アルゴリズムの一般化である。

n番目のデータポイント(訓練例)における出力ノードjの誤差は、ej(n)=dj(n)yj(n)と表わされる。上式において、dは目標値、yはパーセプトロンによって作り出される値である。ノードの重みは、全出力における誤差

(n)=12jej2(n)

を最小化する補正に基づいて調整される。

最急降下法を用いると、それぞれの重みにおける変化は以下の式で表わされる。

Δwji(n)=η(n)vj(n)yi(n)

上式において、yiは一つ前のニューロンの出力、ηは「学習率」である。学習率は、重みが振動することなく反応に対してすばやく収束するように選択される。

計算される導関数はinduced local field vjに依存し、それ自身も変動する。出力ノードについて、この導関数が

(n)vj(n)=ej(n)ϕ(vj(n))

と単純化できることを証明するのは容易である。上式において、ϕは上述した活性化関数の導関数であり、それ自身は変化しない。隠れ層への重みの変化についての解析はより難しいが、 関連のある導関数は以下のように表わすことができる。

(n)vj(n)=ϕ(vj(n))k(n)vk(n)wkj(n).

これは、出力層を表わすk番目のノードの重みの変化に依存する。したがって隠れ層の重みを変化させるには、活性化関数の導関数にしたがって出力層の重みを変化させる。したがってこのアルゴリズムは活性化関数の逆伝播(バックプロパゲーション)に相当する[5] <section end=theory />。

用語

「多層パーセプトロン」という用語は、複数の層を持つ単一のパーセプトロンを意味しない。むしろ、層へと組織化された多くのパーセプトロンを含む。代替用語は「多層パーセプトロンネットワーク」である。さらに、MLP「パーセプトロン」は、最も厳密に言えばパーセプトロンではない。真のパーセプトロンは正式には、ヘヴィサイドの階段関数といった閾値活性化関数を用いる人工ニューロンの特殊な場合である。MLPパーセプトロンは任意の活性化関数を用いることができる。真のパーセプトロンは二項分類を実行する。対して、MLPニューロンは、その活性化関数に依存して分類あるいは回帰のどちらを実行するかは自由である。

「多層パーセプトロン」という用語は後に、ノード/層の特性に関係なく適用されるようになった。ノード/層は、パーセプトロンに限定されず、任意に定義されたニューロンから構成することができる。この解釈は、一般に人工ニューロンを意味するところの「パーセプトロン」の定義の緩和を避けている。

応用

MLPは、確率的に問題を解くことができるため研究において有用である。MLPはテンプレート:仮リンクのような極めて複雑な問題に対する近似解をしばしば与える。

MLPはテンプレート:仮リンクによって示されているように普遍的な関数近似器であるため[3]、回帰分析によって数理モデルを作成するために使うことができる。分類は、応答変数がテンプレート:仮リンクである時の回帰の特殊な例であり、MLPはよい分類アルゴリズムを作る。

MLPは1980年代に人気のある機械学習法であり、音声認識画像認識機械翻訳ソフトウェアといった多様な分野に応用されたが[6]、その後より単純な(そして関連する[7]サポートベクターマシンとの激しい競争に直面した。ディープラーニングの成功によってバックプロパゲーションネットワークへの関心が戻った。

脚注

テンプレート:Reflist

外部リンク

de:Perzeptron#Mehrlagiges Perzeptron