ボルツマンマシン(英: Boltzmann machine)は、1985年にジェフリー・ヒントンとテリー・セジュノスキー(英語版)によって開発された確率的(英語版)回帰結合型ニューラルネットワークの一種である。
ボルツマンマシンは、統計的な変動を用いたホップフィールド・ネットワークの一種と見なすことができる。これらはニューラル ネットワークの内部についてを学ぶことができる最初のニューラル ネットワークの 一つで、(十分な時間を与えられれば) 難しい組合せに関する問題を解くことができる。ただしボルツマン・マシンには後述される事柄を含む数々の問題があり、接続制限をもたないボルツマン・マシンは機械学習や推論のためには実用的であるとは証明されていない。しかしながらボルツマン・マシンは、その局所性とその学習アルゴリズムのヘッブ的性質またその並列処理やその動的力学と単純な物理的プロセスとの類似のため、理論として魅力的である。ボルツマンマシンは確率密度関数自体を計算する。
ボルツマン・マシンは、それらに使用されているサンプリング関数(統計力学においてのボルツマン分布、つまり、ソフトマックス関数)にちなんで名づけられた。
ボルツマン・マシンはホップフィールド・ネットと同様、結び付けられたユニットたちのネットワークでありそのネットワークの持つエネルギーが定義される。それらのユニットもまたホップフィールド・ネット同様1もしくは0(活発もしくは不活発)の出力値をとるが、ホップフィールド・ネットとは違い、不規則過程によってその値は決まる。ネットワーク全体のエネルギー における意味合いは、ホップフィールド・ネットのものと同様である。グローバルエネルギーの定義はホップフィールド・ネットと同様、以下のようになる:
- は 番目ユニットと 番目ユニットの間の結合係数
- は 番目ユニットの状態、
- は における 番目ユニットのバイアス。( は 番目ユニットの閾値)
コネクションについては2つの制約がある:
- (自分自身とはコネクションがない)
- (全てのコネクションは対称である)
したがって重みは対角成分に0が並ぶ対称行列 によって与えられる。
一つのユニットが0または1の値をとることによりもたらされるグローバルエネルギーの差 は:
で与えられ、これは二つのエネルギー状態の差:
である。これにそれぞれのシステムの状態におけるエネルギーとボルツマン因子より得られた相関的な確率を代入すると:
ここでボルツマン因子 は温度に吸収されるとする。各項を移項し、確率の合計が1でなければならないとして:
となる。定数 は各システムの温度であるとし、番目ユニットが1である確率 は:
となる。 は標準シグモイド関数。このような関係がボルツマン・マシンにおける確率式らにみられる理論関数の基礎となっている。
ボルツマン・マシンは、理論的にはむしろ一般的な計算媒体である。ボルツマン・マシンは不規則過程より平衡統計を算出し、そこにみられる分布を理論的にモデル化し、そのモデルを使ってある全体像の一部分を完成させることができる。だが、ボルツマン・マシンの実用化においては、マシンの規模がある程度まで拡大されると学習が正確に行えなくなるという深刻な問題がある。これにはいくつかの原因があり、最も重要なものとして下記のものがある:
- マシンが大きくなると、または接続の強度に依り、マシンが平衡統計を収集するために作動しなければならない時間が指数的に長くなる。
- 接続されたユニットたちの活発化の可能性が0と1の中間をとるほど接続の強さが変動しやすい。総合的な影響としては、それらが0か1に落ち着くまで、接続の強度はノイズによりバラバラに変動してしまう。
一般的なボルツマン・マシンの学習はnの指数時間かかるため非実用的であるが、同一層間の接続を認めない「制限ボルツマン・マシン(英語版) (RBM)」では効率的な計算ができるコントラスティブ・ダイバージェンス(Contrastive Divergence)法が提案されている。制限ボルツマンマシンでは隠れ変数を定義しているが、可視変数の周辺分布を近似することを目的としているため、意味合いとしてはほとんど変わらない。
RBMを1段分学習させた後、その不可視ユニットの活性(ユニットの値に相当)を,より高階層のRBMの学習データとみなす。このRBMを重ねる学習方法は、多階層になっている不可視ユニットを効率的に学習させることができる.この方法は、深層学習のための一般的な方法の一つとなっている。この方式では一つの新しい階層が加えられることで全体としての生成モデルが改善されていく。また拡張されたボルツマン・マシンの型として、バイナリ値だけでなく実数を使うことのできるRBMがある[1]。
RBMの実用例の一つとしては、音声認識ソフトウェアの性能の向上があげられる。
- ^ "A Learning Algorithm for Boltzmann Machines" Archived 2011年7月18日, at the Wayback Machine., Ackley, David H.; Hinton, Geoffrey E.; Sejnowski, Terrence J. (1985).