メトロポリス・ヘイスティングス法

提供: testwiki
ナビゲーションに移動 検索に移動

テンプレート:参照方法

提案分布 Qランダムウォークの粒子が次に移動する候補点を提案する。

数学物理において、メトロポリス・ヘイスティングス法(もしくは M-H アルゴリズム)(メトロポリス・ヘイスティングスほう、Metropolis-Hastings algorithm) はマルコフ連鎖モンテカルロ法の一つで、直接的に乱数の生成が難しい確率分布に対し、その確率分布に収束するマルコフ連鎖を生成する手法である。生成されたマルコフ連鎖は、確率分布の近似(ヒストグラム)などの期待値、すなわち積分の近似計算に用いられる。

歴史

このアルゴリズムは1953年にボルツマン分布のための特殊形で発表したニコラス・メトロポリスらによって提案され.[1] 、1970年に W.K. ヘイスティングスによって一般化された[2]ギブスサンプリング法は棄却されることのないM-H アルゴリズムと捉えることが出来て、調整パラメータが少ない点で構成が容易であるが、応用範囲は狭まる。

アルゴリズムの説明

M-H アルゴリズムを用いると、確率分布P(x) の確率密度関数もしくは確率関数(煩雑なので、以下では「確率密度関数」に統一する)に比例する関数が計算できるならば、 いかなる確率分布 P(x) からでも、基本的には乱数列を得ることができる。

統計学や統計物理学では、しばしば興味のある確率密度関数の定数倍しかわからないことがある。定数倍部分がわからなくても乱数の生成が可能である点はM-H アルゴリズムの大きな長所である。

M-H アルゴリズムは乱数列を生成する。 乱数列の長さが長ければ長いほど、その乱数列は目標の分布P(x)を近似することになる。 乱数は反復計算によって生成される。次の乱数が従う確率分布は現在の乱数の値にのみ依存する。すなわち、乱数列はマルコフ連鎖である。

乱数列を生成する反復計算方法がアルゴリズムの重要な点である。反復計算は、次の状態となる候補を計算することと、それを採択、もしくは棄却する手続きで構成される。 採択とは候補となった状態が次の反復計算の際に使用されることで、棄却とは次の反復計算でも現在の状態が使用されることである。採択、もしくは棄却を決定する採択確率は、P(x)に関する現在の状態と次の状態の確率密度関数を比較して決定される。

以下では簡単のために、M-H アルゴリズムの最も基本的な例である、メトロポリスアルゴリズムを示す。

メトロポリスアルゴリズム

f(x)を目標分布P(x)の確率密度関数に比例する関数とする。

  1. 初期化: 初期値x0と任意の確率密度関数Q(x|y)を決める。
    • 関数Q(x|y)は過去の状態yが与えられたときに、候補となる状態xを生成する関数である。メトロポリスアルゴリズムではQは対称でなければならない。つまりQ(x|y)=Q(y|x)を満たさなければならない。典型的なQ(x|y)の選択として、yを平均としたガウス分布があり、この場合、yの近くは次も選択しやすいことになる。Q提案分布と呼ばれる。
  2. t番目の更新:
    • 確率分布Q(x*|xt)から次の状態となる候補x* を生成する。
    • 採択率α=f(x*)f(xt)を計算する。採択率を使って、候補を採択するか棄却するかを決定する。Pの確率密度関数はfに比例しているため、α=f(x*)f(xt)=P(x*)P(xt)である。
    • α1である場合、候補x* は確実に採択され、次の状態はxt+1=x*となる。そうでなければ確率αで候補を採択する。候補が棄却されれば次の状態も現在と変わらずxt+1=xtとする。

この反復計算により、乱数はある状態にとどまったり、動いたりを繰り返し、ランダムに状態空間を動きまわる。採択率は、現在の状態と次の状態の候補の確率密度関数を比べることで、生成された候補がどれだけ採択されうるかを表す。現在の状態よりも次の候補の確率密度関数が高ければ、必ず次の状態を採択する。しかし次の候補の確率密度関数が高くない場合、ある確率で移動せずに候補を棄却する。このため、高い確率密度関数の領域からは多くの乱数を、また低い確率密度関数の領域は少ない乱数を生成することになる。直感的にはこれがアルゴリズムの仕組みであり、目的の確率分布に従った乱数を近似的に生成する方法である。

棄却法など、確率分布から直接独立に乱数を生成する方法と異なり、M-H アルゴリズムなどのマルコフ連鎖モンテカルロ法はいくつかの短所がある。

  • 乱数列が相関していること。長い乱数列を生成しても、近接した乱数は相関をもち、確率分布を正しく反映したものではない。相関が高ければ、目標となる確率分布を近似するのに、多くの反復計算が必要になる。相関を小さくする工夫はいくつかある。ひとつは、あらかじめ決めた整数nに対し、n個飛ばしで乱数を集める方法である。整数nの値は、しばしば乱数列を用いて計算した自己相関関数をもとに決められる。しかし整数nの値が大きすぎると、その分反復計算が増えてしまう。もうひとつは、次の状態の候補を現在時点より、適度に遠くへ提案する方法である。しかしあまり遠くへ提案しすぎれば棄却確率が増加してかえって相関が小さくなる。
  • 反復計算で生成されたマルコフ連鎖は、ゆるい十分条件のもとで、目標の分布に収束されることが保証されている。初期値が確率密度関数の小さい領域にあると、目標の分布に近づくのが遅れ、目標の分布の近似に大きなバイアスを生む危険がある。その対策として、反復計算の最初の方の部分を切り捨てる、burn-inがしばしば有効である。

確率分布の近似に使われる基本的な棄却法は、その棄却確率が次元数の関数として指数関数的に増加する、次元の呪いの影響を受ける。M-Hアルゴリズムなどマルコフ連鎖モンテカルロ法では、次元の影響が同程度には起きないことが多い。そのため、確率分布が定義されている状態空間の次元が高い場合、マルコフ連鎖モンテカルロ法を用いることは自然である。そのためマルコフ連鎖モンテカルロ法は、多くの分野で使用されている階層ベイズモデルや高次元な統計モデルの事後分布の近似方法としてよく選ばれている。

次元が高い場合には、個々の次元ごとに異なった振る舞いをすることや、遅い混合を避けるためにすべての次元に関して適切なジャンプの大きさを決定することが問題となるため、提案分布を適切に選択することが自体が困難である。 そのような状況でしばしば取られる代替案としてはギブスサンプリングがある。ギブスサンプリングは、すべての次元から一度にサンプルするのではなく、個々の次元に関してサンプリングを行う。 これは多くの典型な階層モデルにあるように、少数の変数が他の変数を条件付けている場合には有効な方法である。 個々の変数は他の変数に関して条件づけされて1度にサンプリングされる。 他には適応的棄却サンプリング、一次元M-H ステップ、スライスサンプリングが考えられる。

提案密度 Q(x|xt)xt に一切依存しないことも可能であり、その場合はアルゴリズムは「独立型メトロポリス・ヘイスティングス法」という。 ふさわしい提案分布を持った独立型メトロポリス・ヘイスティングス法は高い精度が期待されるが、目標となる確率分布の事前の知識を必要とするし、次元の呪いを強く受ける危険がある。

定式化

M-H アルゴリズムは目標確率分布P(x)に従ったサンプルの生成を行うことが目的である。 これを達成するために、漸近的に唯一の定常分布π(x)に収束するマルコフ連鎖を用いる[3]

ここでは簡単のため、離散の状態空間を考えることにする。マルコフ連鎖は、2つの状態間の遷移確率P(x|x)によって一意に定義される。 次の2つの条件が満たされるとき、マルコフ連鎖は定常分布に収束する[3]。このとき、マルコフ連鎖はエルゴード性をもつという。

  1. 定常分布の存在:定常である確率分布π(x)が存在しなければならない。一つの十分条件として、詳細釣り合い条件がある。詳細釣り合い条件とは、状態xπ(x)からの乱数であるとき、状態xから状態xへの遷移確率が状態xから状態xへの遷移確率と等しいこと、つまり、π(x)P(x|x)=π(x)P(x|x)となることである。
  2. 定常分布の一意性: 定常分布π(x)は一意でなければならない。十分条件の一つは、P(x|x)がすべてのx,xについて正になることである[4]

M-H アルゴリズムは遷移確率の構成により、上記の2つの条件を満たすようにマルコフ過程を設計することができる。

詳細釣り合い条件を確認しよう。π(x)=P(x)として

P(x)P(x|x)=P(x)P(x|x)

が成り立つ必要がある。これは、以下のように書き換えられる。

P(x|x)P(x|x)=P(x)P(x).

通常の手法として遷移確率を提案確率分布と採択確率分布に分解する。提案分布Q(x|x)xが与えられたときの状態xを提案する条件付き確率であり、採択確率A(x,x)xが与えられたときの状態xを採択する条件付き確率である。

P(x|x)=Q(x|x)A(x,x)

この関係を以前の式に代入して以下の式を得る。

A(x,x)A(x,x)=P(x)P(x)Q(x|x)Q(x|x) .

次のステップとして、この式を満たす採択率を選ぶことが必要である。よくある選択として、メトロポリス選択が知られ以下の式で得られる。この値はアルゴリズムの実装に必要な値である。

A(x,x)=min(1,P(x)P(x)Q(x|x)Q(x|x))

この式が前の式を満たすことは、A(x,x) /A(x,x)A(x,x)/A(x,x) の少なくとも片方 が1以上になることから確認できる。

また、これはA(x,x)A(x,x)を一般性を失うことなく入れ替えることができるからである。

実装の観点からはMetropolis–Hastings アルゴリズムは以下のステップから成り立っている。

  1. 初期化: ランダムにxを設定する
  2. Q(x|x)に従いxを生成する
  3. A(x,x)に従い採択しxに遷移する。採択されない場合は、x=xとなり値を更新しない。
  4. T回以下であれば2に戻る
  5. 値を保存する。2に戻る。

サンプルを適切に集めるためには、Tは提案分布や採択率とが別に決められ、ステップ4においてサンプルが相関していないことが必要である。マルコフ過程の自己相関時間の時間のオーダーによる[5]

一般的にこのパラメータの決定は簡単ではないことは重要な点である。問題に対して適切にパラメータは決定されるべきである。分布に関する知識が全くない場合には一様分布が提案分布として選ばれることもある。この場合、状態xと状態xはいつも相関しないためにTの値は1に設定される。

アルゴリズムの手順

現時点のサンプル値は xt であるとする。 メトロポリス・ヘイスティングス法では、次のサンプルxは 確率密度関数 Q(x|xt) に従い生成される。 そして以下の値を計算する。

a=a1a2

ここで、

a1=P(x)P(xt)

はサンプルの候補 x とその一つ前のサンプル xt の尤度比であり、

a2=Q(xt|x)Q(x|xt)

は2つの提案分布(xt から x へとその逆方向)の比率である。 提案分布が状態に関して対称の場合は a2 は 1 となる。

次に、以下のルールにもとづき新しい状態 xt+1 が選択される。

a1 の場合:

xt+1=x

a<1 の場合:

a の確率で xt+1=x
1a の確率で xt+1=xt

マルコフ連鎖はランダムな初期値 x0 から開始され、初期値が「忘れられる」まで、多くの試行を繰り返す。この間の標本は棄てられ、burn-in(機械や回路を通電した直後の安定しない状態からの比喩、初期通電)とよばれる。 burn-in'後の値 x の集合は、分布 P(x) からのサンプルを表す。


M-Hアルゴリズムは提案分布 Q(x;xt)の形が、直接サンプリングが困難である目標分布 P(x) の形と類似している場合、つまり Q(x|xt)P(x) のときにうまくアルゴリズムが動作する。 しかし、多くの場合目標分布の形は未知である。

ガウス分布の提案分布 Q が用いられる場合は、分散パラメータの σ2 が burn-in 期間のうちに調整される必要がある。これは通常、採択率を計算することで行われる。採択率とは N個のサンプルのうち採択されたサンプルの割合である。要求される採択率は目標分布によって異なる。理論的には、一次元ガウス分布を目標分布とすると理想的な採択率は約50% であり、N次元ガウス分布の目標分布では約 23% であることが知られている。

σ2 が小さすぎるとサンプリング列は低速混合をおこす。 つまり採択率が高くなり標本空間の移動が遅くなる。 そのため P(x) への収束が遅くなる。 逆に σ2 が大きすぎると、 採択率が低すぎサンプルが確率密度の低い所に移動してしまい a1 が非常に小さくなってしまう。 このため P(x) への収束が遅くなる。 したがって、提案分布のパラメータを調整し採択率を適切にする必要がある。

関連記事

M-H アルゴリズムの一例として

MCMCではない方法

モンテカルロEMアルゴリズム:EステップをサンプリングにしたEMアルゴリズム。

関連書籍

  • Bernd A. Berg. Markov Chain Monte Carlo Simulations and Their Statistical Analysis. Singapore, World Scientific 2004.
  • Siddhartha Chib and Edward Greenberg: "Understanding the Metropolis–Hastings Algorithm". American Statistician, 49(4), 327–335, 1995

脚注

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

外部リンク

テンプレート:確率分布の一覧