ワン・ランダウ法
ワン・ランダウ法(ワン・ランダウほう、テンプレート:Lang-en-short)は、Fugao Wangとテンプレート:仮リンクにより発案された[1]、系の状態密度を計算するために用いられるモンテカルロ法のひとつである。このアルゴリズムでは状態密度の計算に必要な、系の取り得る全ての状態のエネルギーを迅速に計算するため、非マルコフ連鎖ランダムウォークを行う。マルチカノニカル法の実行に必要となる、状態密度を計算するために重要である。
ワンランダウ法はコスト(エネルギー)関数により特徴づけられるどのような系にも応用可能である。たとえば、数値積分[2]やタンパク質フォールディング[3][4]への応用が知られている。ワン・ランダウサンプリングはメタダイナミクス法とも関連する[5]。
概要
ワン・ランダウ法により、コスト関数で特徴づけられる系の状態密度を得ることができる。非マルコフ連鎖確率過程を用いて、漸近的にマルチカノニカルアンサンブルを得る(サンプル分布が状態密度の逆数となるようなメトロポリス・ヘイスティングス法に漸近する)[1]。このことの帰結として、エネルギー障壁を無視したシミュレーションを行うことができる。つまり、このアルゴリズムは(コスト関数的に良いものも悪いものも含めた)系の取り得る全ての状態をメトロポリス法よりも非常に速く網羅することができるのである[6]。
アルゴリズム
位相空間 上に定義される系と、そのコスト関数(例えばエネルギー) テンプレート:Mvar を考える。 テンプレート:Mvar のスペクトルは の範囲に限定されるものとし、付随する状態密度 を計算する。 ワン・ランダウ法は離散スペクトルを扱うため[1]、スペクトル をそれぞれ だけ異なる テンプレート:Mvar 個の離散値で分割する。
このような離散スペクトルに対し、まず次の初期化を行う。
- 全ての区間のミクロカノニカルエントロピーをゼロとする。
- テンプレート:Math とする。
- 系の初期配置 をランダムに選ぶ。
次に、マルチカノニカルアンサンブルシミュレーションを行う[1]。つまり、位相空間上でランダムウォークを行い、確率分布
を再現するような遷移確率 でメトロポリスシミューレーションを行う。このとき、訪れた状態のエネルギーをヒストグラム に記録する。そしてメトロポリス法と同様に新たな配置の生成と採択/棄却プロセスを実行する。
- 新たな配置 を任意の遷移確率分布 に従って生成する。
- 新たな配置を次の確率で採択/棄却する。
- ここで、 および とする。
このステップを終えたとき、系の遷移先が だったとすると を 1 だけ増やし、エントロピーを以下のように更新する。
このステップが本アルゴリズムの中心である。また、このステップが存在するため確率過程が過程の履歴に依存し、ワン・ランダウ法は非マルコフ連鎖となる。したがって、このエネルギー を持つ状態が次に生成された際にはより棄却されやすくなる。このようにして、本アルゴリズムはスペクトル全域を等しく訪れるよう強制する[1]。この帰結として、ヒストグラム はシミュレーションを進めるにつれてより平坦となる。しかし、この平坦さは計算されたエントロピーがどれだけ実際のエントロピーを近似できているかに依存する。そして、近似の良さは テンプレート:Mvar に依存する[7]。実際のエントロピーに近づくため(すなわちヒストグラムを平坦にするため)に、 テンプレート:Mvar を テンプレート:Mvar ステップごとに次のように減らす。
後に、 テンプレート:Mvar を常に半分にし続けると飽和誤差を招くことが明らかとなった[7]。この問題を避けるため、テンプレート:Mvar をシミュレーションの総ステップ数として、 テンプレート:Mvar を テンプレート:Math にする変更がアルゴリズムに加えられた[7]。
アルゴリズムのテスト
今、次のような調和振動子ポテンシャルの DOS を求めたいとする。
解析的には DOS は次のように与えられる。
最後の積分を解くと位相空間の次元によって次のような結果が得られる。
一般的に、多次元調和振動子の DOS は テンプレート:Mvar のべき乗で与えられ、その指数は系の次元の関数となる。
このように単純な調和振動子ポテンシャルに対する状態密度は既に分かっているので、このポテンシャルに対してワン・ランダウ法を行い、 得られた状態密度 と を比べることによりワン・ランダウ法の精度を確かめることができる。
サンプルコード
次に示すのはPythonで実装されたワン・ランダウ法のサンプルコードである。遷移確率密度は対称であることを仮定している。
このコードにおいて、対象となる系は "system" により表されるものとしている。
currentEnergy = system.randomConfiguration() # a random initial configuration
while (f > epsilon):
system.proposeConfiguration() # a proposed configuration is proposed
proposedEnergy = system.proposedEnergy() # the energy of the proposed configuration computed
if (random() < exp(entropy[currentEnergy]-entropy[proposedEnergy])):
# if accepted, update the energy and the system:
currentEnergy = proposedEnergy
system.acceptProposedConfiguration()
else:
# if rejected
system.rejectProposedConfiguration()
H[currentEnergy] += 1
entropy[currentEnergy] += f
if (isFlat(H)): # isFlat tests whether the histogram is flat (e.g. 95% flatness)
H[:] = 0
f *= 0.5 # refine the f parameter
ワン・ランダウ分子動力学法
ワン・ランダウ法はモンテカルロ法のみならず分子動力学法にも適用することができる。そのためには、系の温度を次のように制御する。
ここで テンプレート:Math は系のエントロピー、 テンプレート:Math はミクロカノニカル温度、 テンプレート:Math は分子動力学シミュレーションに実際用いられる「スケールされた」温度である。
出典
- ↑ 1.0 1.1 1.2 1.3 1.4 引用エラー: 無効な
<ref>タグです。「WangLandau」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Belardinelli_Integrals」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Ojeda1」という名前の注釈に対するテキストが指定されていません - ↑ 引用エラー: 無効な
<ref>タグです。「Ojeda2」という名前の注釈に対するテキストが指定されていません - ↑ Junghans, Christoph, Danny Perez, and Thomas Vogel.
- ↑ 引用エラー: 無効な
<ref>タグです。「Berg」という名前の注釈に対するテキストが指定されていません - ↑ 7.0 7.1 7.2 引用エラー: 無効な
<ref>タグです。「Belardinelli_Saturation」という名前の注釈に対するテキストが指定されていません