馬可夫鏈蒙地卡羅(英語:Markov chain Monte CarloMCMC)方法(含隨機漫步蒙地卡羅方法)是一組用馬氏鏈從隨機分布取樣的演算法,之前步驟的作為底本。步數越多,結果越好。

建立一個具有期望值屬性的馬氏鏈並非難事,難的是如何決定通過多少步可以達到在許可誤差內的穩定分布。一個好的馬氏鏈具有快速混合——從開始階段迅速獲得的一個穩定狀態——請參考馬氏鏈最大時間

因於初始樣本,最常見的MCMC取樣只能近似得到分布。複雜的MCMC改進演算法如過往耦合,但是會消耗更多的計算資源和時間。

典型用法是類比一個隨機行走的行人來進行路徑最佳化等。每一步都算作是一個狀態。而統計經過次數最多的地方將在下一步中更有可能為目的地。馬氏蒙地卡羅方法是一種結合了蒙特卡羅法的解決方案。但不同於以往的蒙地卡羅integration是統計獨立的,MCMC中的是統計相關的

本方法的相關應用包括:貝氏統計計算物理計算生物以及計算語言學,此外還有Gill先生的一些著作。

Jeff Gill. Bayesian methods: a social and behavioral sciences approach Second Edition. London: Chapman and Hall/CRC. 2008 [2012-02-07]. ISBN 1-58488-562-9. (原始內容存檔於2009-05-23). </ref> and Robert & Casella.[1]

隨機漫步演算法

馬氏鏈性質決定了下一個方位取決於當前狀態和隨機變數。這樣的性質決定了最終所有的空間將被覆蓋但是卻需要花費較長時間。下面給出MCMC方法:

基本原理

設非週期正常返的馬可夫鏈的平穩分布為為馬可夫鏈的狀態,對於任意上有界函數有: ,也就是說,該馬可夫鏈在取的變數比較大時會趨向於服從機率分布

在設計一個馬可夫鏈滿足細緻平衡的條件下,對馬爾科夫鏈的類比就可以看作對機率分布的採樣。[2]

基本步驟

MCMC方法是使用馬爾科夫鏈的蒙地卡羅積分,其基本思想是:構造一條Markov鏈使其平穩分布為待估參數的事後分布,通過這條馬爾科夫鏈產生事後分布的樣本,並基於馬爾科夫鏈達到平穩分布時的樣本(有效樣本)進行蒙特卡羅積分。設為產生的總樣本數,為Markov鏈達到平穩時的樣本數則MCMC方法的基本思路可概括為:

  • 構造Markov鏈。構造一條Markov鏈,給定馬爾科夫鏈狀態轉移矩陣,使其收斂到平穩分布
  • 產生樣本:從初始狀態出發,利用從條件機率分布生成樣本,並通過轉移條件判斷是否轉移,通過次更新達到平穩,此後生成的即為的樣本,我們記為
  • 蒙特卡羅積分。任一函數的期望值估計為:

在採用MCMC方法時馬爾科夫鏈轉移核的構造至關重要,不同的轉移核構造方法將產生不同的MCMC方法,目前常用的MCMC方法主要有兩種Gibbs抽樣和Metropolis-Hastings演算法。

抽樣演算法

l Gibbs '抽樣'

Gibbs抽樣是現實中最簡單應用最廣泛的MCMC方法,由Geman最初命名提出其基礎思路如下:

給定任意的初始向量;

從中抽取樣本

從中抽取樣本

從中抽取樣本

從中抽取樣本

至此,完成的轉移。經過n次迭代,可得後驗樣本。根據後驗樣本可計算事後分布的各階矩,進行相應的統計推論。

  • Metropolis-Hastings '演算法'

Metropolis-Hastings演算法是較早出現且比較一般化的MCMC方法,最初由Metropolis等人在1953年提出之後由Hastings對其加以推廣形成了,Metropolis-Hastings方法。該方法的基本思路是:選擇一轉移函數和初始值,若第次迭代開始時的參數值為

,則第次迭代過程為:

  • 從中抽取一個備選值
  • 計算接受機率
  • 以機率,置,以機率,置;
  • 重複i –iii 次,則可得後驗樣本。根據後驗樣本可計算事後分布的各階矩,進行相應的統計推論。

參見

注釋

參考文獻

外部連結

Wikiwand in your browser!

Seamless Wikipedia browsing. On steroids.

Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.

Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.