マルチカノニカル法
マルチカノニカル法(テンプレート:Lang-en-short)とは、統計学および物理学において、マルコフ連鎖モンテカルロ法におけるサンプリング法の一つで、メトロポリス・ヘイスティングス法により複数の局所安定点を持つ被積分関数を積分するときに用いられる。サンプリングを状態密度の逆数に従って行う[1]。状態密度はあらかじめワン・ランダウ法などの他の方法により計算しておく。[2]イジングモデルやスピングラスなどのスピン系において重要なアルゴリズムである[1][3][4]。マルチカノニカルアンサンブル(テンプレート:Lang-en-short)、マルチカノニカルサンプリング(テンプレート:Lang-en-short)、フラットヒストグラム法(テンプレート:Lang-en-short)とも。
背景
たとえばスピン系などの自由度の大きい系をシミュレートする場合、テンプレート:仮リンクが必要とされる。この積分法では、テンプレート:仮リンク、とくにメトロポリス法が非常に重要である[3]。しかし、メトロポリス法では テンプレート:Mvar を逆温度として に従ってサンプリングを行なうため、エネルギー障壁 を乗り越えることはその大きさに対して指数関数的に困難となる[1]。テンプレート:仮リンクのような複数の局所安定点を持つ系では、このメトロポリス法はある特定の局所安定点に囚われてしまい、取り扱いが困難となる[3]。このため、他のサンプリング法によるアプローチが必要となる。
概要
マルチカノニカル法では、メトロポリス・ヘイスティングス法を用いるが、メトロポリス法におけるサンプリング分布 の代わりに、状態密度の逆数を用いる[1]。このように選ぶことで、平均的な意味において、エネルギー毎に等しい状態数をサンプリングできる。言い換えれば、エネルギーに対して「フラットなヒストグラム」を得ることができる。このことから、エネルギー障壁を乗り越えることが困難ではなくなる。メトロポリス法と比べて優れている点としてもう一つ、サンプリングが系の温度によらないことから、全ての温度における熱力学的変数を推計することができる(「マルチカノニカル」とはここから来ている)。このことは一次相転移を研究する上において大きな利点となる[1]。
マルチカノニカル法の実行上において最大の問題は、状態密度を予め知る必要があることである[2][3]。マルチカノニカルサンプリングにおいて重要な貢献の一つとして、ワン・ランダウ法が挙げられる。このアルゴリズムは、収束するまで状態密度を計算しつづけることで、漸近的にマルチカノニカル集合を得ることができる[2]。
マルチカノニカル法の応用範囲は物理系のみに留まらない。コスト関数 テンプレート:Mvar が定義できる抽象的な系にも適用することができる。 テンプレート:Mvar に対する状態密度を用いることにより、多次元空間上の積分や最小値探索に用いることができる[5]。
動機
ある系とその位相空間 (系のコンフィギュレーション により張られる空間)とその位相空間上定義される「コスト」関数 テンプレート:Mvar 、 そのスペクトル : を考える。
ある量の位相空間上の平均値 を計算するには、以下のような積分を実行する必要がある。
ここで は体積あたりの重み、
である。 テンプレート:Mvar に対する状態密度は以下のように与えられる。
これは、もし テンプレート:Mvar と テンプレート:Mvar の両方が特定の状態には依存せず、以下のようにその状態における テンプレート:Mvar の値 にのみ依存するならば、
の定義式をデルタ関数と f についての積分を追加することにより以下のように書き換えることができる。
つまり、状態密度を知っていれば、それは 上の状態数の への射影であるから、 テンプレート:Mvar の値についての一次元積分により、位相空間上の多次元積分そすることなく平均値が計算できることになる。
自由度の高い系については状態数が大きくなるため、解析的な表式を得ることは難しく、 の計算も困難となる。この問題は多次元積分であるから、モンテカルロ積分がよく用いられる。最も単純な表式では、一様分布に従う テンプレート:Mvar 個のランダムな状態 を生成し、推定量
を用いて を計算することができる。 は強い大数の法則により、ほぼ確実に に収束する。
収束に関するよくある問題のひとつとして、 テンプレート:Mvar の分散が非常に大きい場合、妥当な結果を得るまでの計算コストが大きくなってしまうという問題がある。
収束を速くするための方法として、メトロポリス・ヘイスティングス法がある。モンテカルロ法は一般的に重点サンプリングを用いて推定量の収束を加速する。つまり、 を適当な分布 (上述の テンプレート:Mvar とは異なることに注意)を用いて以下のように定義しなおす。
ここで、 である。
当然、 テンプレート:Mvar が一様分布のとき、推定量は一様サンプリングを用いた推定量と一致する。
重要な例として、コスト関数をエネルギーとみて P をある温度に対するボルツマン因子と一致させる選び方がある。
このように選ぶと、コスト関数が低いような状態がよりサンプルされやすくなる。
歴史的には、テンプレート:仮リンク[6]ではメトロポリス・ヘイスティングス法は熱浴に接続された系における平均値を計算するために用いていたため、状態の重みはボルツマン因子と一致していた。このような系では、上述した状態の選び方により物理系の研究がずいぶん進展した[3]。
しかし、サンプリング分布を重み関数と一致させる必要は必ずしもない。重み関数と一致しないサンプリング分布を用いる理由の一つは、メトロポリス・ヘイスティングス法はコスト関数が複数の極小値を持つ場合に収束しないことである[1]。これは、このアルゴリズムが局所的ステップによるランダムウォークを用いているためである。つまり、ランダムウォークは通常、エネルギーの差分がオーダーひとつ分であるようなステップを実行する。このことから、このアルゴリズムにおいてある極小値近傍の領域から抜け出すための計算コストはコスト関数の極小値の値に対して指数関数的に増加する。つまり、極小値が深ければ深いほど、このアルゴリズムはそこに長く留まってしまい、そこから抜け出すのは(深さに対して指数関数的に)難しくなる。
これがマルチカノニカル法を導入する動機である。サンプル時にはコスト関数の極小値の存在を「見えなく」してやることによって、最小値近傍に囚われてしまうのを防ぐというアイデアである。
マルチカノニアルアンサブル
マルチカノニカルアンサンブルとは、次のような重み関数を用いて重みづけサンプリングして得られるような統計集団である。
ここで、
はコスト関数に対する状態密度である(テンプレート:Mvar は位相空間体積)。このような重み関数を選ぶことで、サンプリングされた状態に対応するコスト関数の値が テンプレート:Mvar になるような確率密度関数は以下のようになる。
このため、「フラットヒストグラム」法と呼ばれることもある。つまり、コスト関数のあらゆる値が均一にサンプリングされ、障壁は存在しなくなる。熱浴に接続された系の場合、次のような重要な利点も存在する。すなわち、サンプリングが温度に依存しないため、一回のシミュレーションにより全ての温度について研究することができる。このゆえに、マルチカノニカル(複数の温度)の名がある。
トンネリング時間と致命的スローダウン
どんなモンテカルロ法もそうであるように、 に従ってサンプリングされるサンプルには相関がある。相関の尺度として「トンネル時間」がよく使われる。トンネリング時間は、シミュレーションが テンプレート:Mvar のスペクトルの極小値と極大値の間を往復するまでにかかるマルコフ連鎖のステップ数と定義される。トンネリング時間を用いる動機の一つは、スペクトルを横断するならば状態密度の極大領域を通過するため、プロセスが脱相関されることである。また、往復させることでシミュレーションがスペクトルの全域を通過することを保証している。
テンプレート:Mvar に対するヒストグラムは平坦であるため、マルチカノニカル法は テンプレート:Mvar の値という一次元の線上における拡散過程(つまりランダムウォーク)とみることができる。このようなプロセスにおいては、詳細釣り合い条件によりテンプレート:仮リンクがないことが保証される[7]。このことから、局所的なダイナミクスにおいてはトンネリング時間は拡散プロセスと同じようにスケールすることになり、したがってトンネリング時間はスペクトルのサイズ テンプレート:Mvar の二乗に比例してスケールする。
しかし、イジングモデルを初めとするいくつかの系では、スケーリングが致命的にスローダウンし、 (ここで は系に依存する数)に比例してスケールするようになる[4]。
スケーリングを改善し、致命的スローダウンを克服するため、非局所的ダイナミクスが開発されている[8](ウォルフのアルゴリズムを参照)。しかし、イジングモデルのようなスピン系において致命的スローダウンに陥いらないような局所的ダイナミクスが存在するのかどうかという疑問はいまだに答えの出ない問題である。
出典
- ↑ 1.0 1.1 1.2 1.3 1.4 1.5 引用エラー: 無効な
<ref>タグです。「Berg」という名前の注釈に対するテキストが指定されていません - ↑ 2.0 2.1 2.2 引用エラー: 無効な
<ref>タグです。「Landau」という名前の注釈に対するテキストが指定されていません - ↑ 3.0 3.1 3.2 3.3 3.4 引用エラー: 無効な
<ref>タグです。「Newmann」という名前の注釈に対するテキストが指定されていません - ↑ 4.0 4.1 引用エラー: 無効な
<ref>タグです。「Dayal」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Lee」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Metropolis」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Robert」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Wolff」という名前の注釈に対するテキストが指定されていません