確率伝搬法

提供: miniwiki
2018/8/19/ (日) 16:56時点におけるAdmin (トーク | 投稿記録)による版 (1版 をインポートしました)
(差分) ← 古い版 | 最新版 (差分) | 新しい版 → (差分)
移動先:案内検索

確率伝搬法(Belief Propagation)あるいはSum-productメッセージ伝達法sum-product message passing)とは、ベイジアンネットワークマルコフ確率場などのグラフィカルモデル上で作用する、メッセージ伝達のアルゴリズムである。このアルゴリズムは、既に観測されているノードの状態を基に、観測されていないノードの周辺分布をそれぞれ計算する。確率伝搬法は主に人工知能情報理論の分野で広く用いられており、低密度パリティ検査符号ターボ符号自由エネルギー近似充足可能性問題を含む、数多くの応用の成功が経験的に確かめられている。

このアルゴリズムは1982年にジューディア・パール[1]により提案されたもので、当初は木構造上のグラフィカルモデルで作用するアルゴリズムであったものを、後に一般的な構造のモデルにおいても作用できるように拡張した[2]。現在では、このアルゴリズムがループを含む一般のグラフ構造においても良い近似を与えることが示されている[3]

一例を示す。X=(Xv)を結合確率質量関数pをもつ離散的な確率変数の集合とすると、単体のノードの確率を表す周辺分布Xiは、単純にpXi以外のノードについて和をとることで表現できる:

[math]p_{X_i}(x_i) = \sum_{\mathbf{x}': x'_i=x_i} p(\mathbf{x}').[/math]

しかし、この計算は仮に確率変数が100個の二値変数であったとしても、この確率変数全体の場合の数は299 ≈ 6.338 × 1029と非常に多くなるため、コンピュータ上で計算することは大変困難である。確率伝搬法では対象の確率変数のグラフ構造を利用することによって、この周辺分布の計算をより効率的に行う。

Sum-productアルゴリズムの概要

確率伝搬法は因子グラフ上で実行するアルゴリズムである。ここで、因子グラフとは変数Vと因子Uによって構成されている2部グラフであり、変数と因子の間にはエッジが張られている。このグラフを用いることで、以下の結合確率質量関数を書き下せる。

[math]p(\mathbf{x}) = \prod_{u \in U} f_u (\mathbf{x}_u)[/math]

ここで、xuは因子ノードuに隣接している変数を表すベクトルである。任意のベイジアンネットワークマルコフ確率場は因子グラフの形で表現できる。

このアルゴリズムはメッセージと呼ばれる、変数xvを引数にとる関数をノード間のエッジに沿って伝播させる。これらのメッセージはある変数が他の変数に影響を与える『相互作用』を含む。メッセージには2種類存在する:

  • 変数ノードvから因子ノードuへ渡すメッセージ。メッセージの計算は隣接しているすべての因子グラフの積を取ることによって表現される(ただし、対象の因子ノードからのメッセージは除くものとする。除く代わりに、対象の因子ノードからのメッセージは"1"を送るものとして計算することもできる):
[math]\mu_{v \to u} (x_v) = \prod_{u^* \in N(v)\setminus\{u\} } \mu_{u^* \to v} (x_v).[/math]
ここで、N(v)は変数ノードvに隣接する、すべての因子ノードの集合とする。[math]N(v)\setminus\{u\}[/math]が空集合であるならば、[math]\mu_{v \to u}(x_v)[/math]は一様分布として計算する。
  • 因子ノードuから変数ノードvへ渡すメッセージ。メッセージの計算は隣接している他のノードからのメッセージの積をとり、xv以外のすべての変数について周辺化を行うことで表現される:
[math]\mu_{u \to v} (x_v) = \sum_{\mathbf{x}'_u:x'_v=x_v } f_u (\mathbf{x}'_u) \prod_{v^* \in N(u) \setminus \{v\}} \mu_{v^* \to u} (x'_{v^*}).[/math]
ここで、N(u)は因子ノードuに隣接する、すべての変数ノードの集合とする。[math]N(u) \setminus \{v\}[/math]が空集合であるならば、[math]\mu_{u \to v} (x_v) = f_u(x_v)[/math]とする。

明らかに、確率伝搬法の名前の由来は上の公式から来るものである。このアルゴリズムによって、結合確率分布に対する周辺分布の計算という困難な問題が、単純なメッセージの積と和の計算に減少できる。

木構造である場合の厳密解

確率伝搬法の最も簡単な形は、対象の因子グラフが木構造となる場合である。この場合、確率伝搬法は周辺分布の厳密解を計算でき、以下の2段階のステップの後に終了する。

まずこのアルゴリズムを開始する前に、対象のグラフの内一つのノードをとして定める。また、任意の根でない、一つのノードしか接続されていないノードをと呼ぶ。

一段階目のステップでは、メッセージの計算を葉ノードから始める。各々のノードはエッジを通して、受けとったメッセージを根ノードに向けて伝播する。グラフは木構造であるため、対象のノードにメッセージを渡す前に、他のすべての近接ノードからメッセージを受けとれることが保証される。この伝播則は、根ノードがすべての近接ノードからメッセージを受け取るまで繰り返される。

二段階目のステップでは、根ノードから葉ノードに向けてメッセージを送信する。この場合、メッセージは前回とは逆の方向から伝播される。すべての葉ノードがメッセージを受け取った際に、このアルゴリズムは終了する。

計算が完了した後、各々のノードの周辺分布は隣接している因子ノードからのメッセージの積に比例する:

[math] p_{X_v} (x_v) \propto \prod_{u \in N(v)} \mu_{u \to v} (x_v). [/math]

同様に、ある因子に属している変数の集合の周辺分布は、変数からのメッセージとその因子の積に比例する:

[math] p_{X_u} (\mathbf{x}_u) \propto f_u(\mathbf{x}_u) \prod_{v \in N(u)} \mu_{v \to u} (x_u). [/math]

これらの計算は数学的帰納法によって証明できる。

一般的なグラフに関しての近似アルゴリズム

奇妙な事に、一般的なグラフに関しても木構造と同様のアルゴリズムを用いることができる。このアルゴリズムは対象のグラフが一般にループを含むことから"loopy" belief propagationアルゴリズムと呼ばれることもある。対象のグラフが葉を含んでいないため、このアルゴリズムは確率伝搬法の伝播規則は僅かながら修正される必要がある。まず、最初にすべての変数間のメッセージを1に初期化する。次に、各反復回数ごとに上の定義を用いたメッセージの更新を、(たとえ十分な反復によって、葉や木構造の部分グラフから既知のメッセージが来た場合においても)すべてのメッセージに対して行う。対象のグラフが木構造である場合、loopy belief propagationの手続きは、対象のグラフの直径に等しい反復回数以内で、本来の確率伝搬法で得られるメッセージへ収束する。

loopy belief propagationアルゴリズムの正確な収束条件は未だに明らかでないが、単一のループを含むグラフにおいては厳密解ではないにしろ常に収束することが知られている[4]。また、その他にもloopy belief propagationが唯一の固定点に収束するための十分条件(必要条件でない)がいくつか存在する[5]。一方で、メッセージが発散したり、各反復回数毎に解が振動するようなグラフも存在する。EXITチャートのような手法を用いて、確率伝搬法の経過やその収束状況について近似的に可視化し、調査することもできる。

周辺化のための近似手法としては、他にも変分法モンテカルロ法を含むいくつかの手法が提案されている。

一般的なグラフ上で厳密な周辺分布解を求めるための一つとしてジャンクションツリーアルゴリズムが挙げられる。これは対象のグラフを木構造へ修正し、その後に確率伝搬法を適用する。ジャンクションツリーではループを含むクラスタを単一のノードにまとめループを消去することで、確率伝搬法の収束性を保証している。

類似アルゴリズムと複雑性

類似のアルゴリズムとしては一般にビタビアルゴリズムが挙げられる。ビタビアルゴリズムはmax-productあるいはmin-sumアルゴリズムとしても知られており、関連するモデルの最大化問題を解く。具体的には、このアルゴリズムは周辺分布を求めるのではなく、大域的関数を最大化される値[math]\mathbf{x}[/math]を求める。これは確率的に尤も起こりうる値を選択することと等価であり、arg max記号を用いて定義できる:

[math]\arg\max_{\mathbf{x}} g(\mathbf{x}).[/math]

この問題の解法としては確率伝搬法とほぼ等価であり、和の記号を最大値に置き換えるだけでよい。

グラフィカルモデル上での周辺化や最大化のような推定問題は、厳密解や相対誤差以下の近似解を得ようとした場合においてNP困難な問題である。正確には、上で定義された周辺化の問題は#P完全であり、最大化はNP完全である。

自由エネルギーとの関係

sum-productアルゴリズムは熱力学における自由エネルギーと関連がある。Z分配関数とすると、因子グラフで表現された確率分布

[math]P(\mathbf{X}) = \frac{1}{Z} \prod_{f_j} f_j(x_j)[/math]

は、ある系における内部エネルギーの測度として見ることができる。すなわち

[math]E(\mathbf{X}) = \log \prod_{f_j} f_j(x_j).[/math]

である。対象の系における自由エネルギーは以下の通りである:

[math]F = U - H = \sum_{\mathbf{X}} P(\mathbf{X}) E(\mathbf{X}) + \sum_{\mathbf{X}} P(\mathbf{X}) \log P(\mathbf{X}).[/math]

つまり、sum-productアルゴリズムの収束点は、対象の系の自由エネルギーを最小化する点としても表せることを意味している。同様に、ループを含む反復的な確率伝搬法アルゴリズムの固定点は、近似された自由エネルギーの定留点とも見なせる。

一般化された確率伝搬法(Generalized belief propagation, GBP)

確率伝搬法は通常の場合、因子グラフ上でのメッセージを更新するアルゴリズムとして表現される。メッセージは変数ノードとその近傍である因子ノード間、もしくはその逆を含む。ここで、グラフ上でのクラスター間におけるメッセージを考える。これが一般化された確率伝搬法アルゴリズムの一つである。そのようなメッセージを伝播させる際にはまず対象のグラフ上におけるクラスターの集合を定義する必要があるが、それにはいくつかの方法がある。クラスター間でメッセージを交換するというアイデアは初めに物理学者である菊池が導入し、現在では菊池のクラスター変分法という名前で知られている。

確率伝搬法の精度を改良する際のもう一つの手法として、対象の場(メッセージ)の分布のレプリカ対称性を破る方法がある。この一般化によってsurvey propagation(SP)と呼ばれる新しい手法が導かれており、充足性[6]グラフ彩色問題などといったNP完全な問題に対して非常に効率的に解くことができる。

クラスター変分法とsurvey propagationは、確率伝搬法を2つの異なるアプローチによって発展させたアルゴリズムである。

ガウシアン確率伝搬法(Gaussian Belief Propagation, GaBP)

ガウシアン確率伝搬法は確率伝搬法アルゴリズムの別形であり、対象の分布がガウス分布である場合の確率伝搬法を指している。このようなモデルに対する解析は、初めにWeissとFreeman[7]によって行われた。

まず、GaBPアルゴリズムでは以下の周辺化問題について解く:

[math] P(x_i) = \frac{1}{Z} \int_{j \ne i} \exp(-1/2x^TAx + b^Tx)\,dx_j[/math]

ここでZは正規化定数、Aは対称正定値行列(分散共分散の逆行列や精度行列としても知られている)、bはシフトベクトルとする。

このようなガウシアンモデルの下では、周辺分布の最大値を推定値とする問題はMAP推定問題と等価である:

[math]\underset{x}{\operatorname{argmax}}\ P(x) = \frac{1}{Z} \exp(-1/2x^TAx + b^Tx).[/math]

同様に、このMAP推定問題は以下の二次形式の最小化問題と等価である:

[math] \underset{x}{\operatorname{min}}\ 1/2x^TAx - b^Tx.[/math]

最終的に、これは以下の線形方程式の解と等価である:

[math] Ax = b.[/math]

GaBPアルゴリズムの収束性は(一般的な確率伝搬法の場合と比較して)解析が容易であり、2種類の十分条件が知られている。一つはWeissが2000年に定式化した条件であり、Aが対角優位行列である場合に関して収束性が保証されている。二つめは2006年にJohnsonら[8]が定式化した条件であり、行列のスペクトル半径が下式を満たしている場合に収束する。

[math]\rho (I - |D^{-1/2}AD^{-1/2}|) \lt 1 \, [/math]

ここで、D = diag(A)である。

GaBPアルゴリズムは線形代数の領域と関連がある[9]。具体的には、GaBPアルゴリズムはAが情報行列でbがシフトベクトルである場合の線形方程式Ax=bを解くための反復アルゴリズムとして見ることができる。GaBPアルゴリズムの収束条件はヤコビ法の十分条件と等価であり、かつ、GaBPアルゴリズムの収束速度はヤコビ法、ガウス=ザイデル法SOR法などといった古典的な反復手法よりも早いことが経験的に知られている[10]。さらに、GaBPアルゴリズムは共役勾配法の条件下で発生する、計算上の問題に対して耐性があることが示されている[11]

注釈

  1. Pearl, Judea (1982). “Reverend Bayes on inference engines: A distributed hierarchical approach”. Proceedings of the Second National Conference on Artificial Intelligence. AAAI-82: Pittsburgh, PA. Menlo Park, California: AAAI Press. pp. 133–136. https://www.aaai.org/Papers/AAAI/1982/AAAI82-032.pdf . 2009閲覧. 
  2. Kim, Jin H.; Pearl, Judea (1983). “A computational model for combined causal and diagnostic reasoning in inference systems”. Proceedings of the Eighth International Joint Conference on Artificial Intelligence. 1. IJCAI-83: Karlsruhe, Germany. pp. 190–193. http://dli.iiit.ac.in/ijcai/IJCAI-83-VOL-1/PDF/041.pdf . 2009閲覧. 
  3. (1988) Probabilistic Reasoning in Intelligent Systems: Networks of Plausible Inference, 2nd, San Francisco, CA: Morgan Kaufmann. ISBN 1-55860-479-0. 
  4. Weiss, Yair (2000). “Correctness of Local Probability Propagation in Graphical Models with Loops”. Neural Computation 12 (1): 1–41. doi:10.1162/089976600300015880. 
  5. Mooij, J; Kappen, H (2007). “Sufficient Conditions for Convergence of the Sum–Product Algorithm”. IEEE Transactions on Information Theory 53 (12): 4422–4437. doi:10.1109/TIT.2007.909166. 
  6. Braunstein, A.; Mézard, R.; Zecchina, R. (2005). “Survey propagation: An algorithm for satisfiability”. Random Structures & Algorithms 27 (2): 201–226. doi:10.1002/rsa.20057. 
  7. Weiss, Yair; Freeman, William T. (October 2001). “Correctness of Belief Propagation in Gaussian Graphical Models of Arbitrary Topology”. Neural Computation 13 (10): 2173–2200. doi:10.1162/089976601750541769. PMID 11570995. 
  8. Malioutov, Dmitry M.; Johnson, Jason K.; Willsky, Alan S. (October 2006). “Walk-sums and belief propagation in Gaussian graphical models”. Journal of Machine Learning Research 7: 2031–2064. http://jmlr.csail.mit.edu/papers/v7/malioutov06a.html . 2009閲覧.. 
  9. Gaussian belief propagation solver for systems of linear equations. By O. Shental, D. Bickson, P. H. Siegel, J. K. Wolf, and D. Dolev, IEEE Int. Symp. on Inform. Theory (ISIT), Toronto, Canada, July 2008. http://www.cs.huji.ac.il/labs/danss/p2p/gabp/
  10. Linear Detection via Belief Propagation. Danny Bickson, Danny Dolev, Ori Shental, Paul H. Siegel and Jack K. Wolf. In the 45th Annual Allerton Conference on Communication, Control, and Computing, Allerton House, Illinois, Sept. 07. http://www.cs.huji.ac.il/labs/danss/p2p/gabp/
  11. Distributed large scale network utility maximization. D. Bickson, Y. Tock, A. Zymnis, S. Boyd and D. Dolev. In the International symposium on information theory (ISIT), July 2009. http://www.cs.huji.ac.il/labs/danss/p2p/gabp/

参考文献

{{ safesubst:#invoke:Unsubst||$N=Use dmy dates |date=__DATE__ |$B= }}