??Abstract:最近課業(yè)內(nèi)的任務(wù)不是很多,又臨近暑假了,就在網(wǎng)上搜了一些有關(guān)于機(jī)器學(xué)習(xí)和深度學(xué)習(xí)的課程進(jìn)行學(xué)習(xí)。網(wǎng)上的資料非常繁多,很難甄別,我也是貨比三家進(jìn)行學(xué)習(xí)。這是這個(gè)系列的第一個(gè)筆記,是關(guān)于貝葉斯和MCMC一些數(shù)學(xué)原理的講解和代碼的實(shí)現(xiàn),希望能夠深入淺出,敘述的容易讓人理解。…
淺談貝葉斯
不論是學(xué)習(xí)概率統(tǒng)計(jì)還是機(jī)器學(xué)習(xí)的過程中,貝葉斯總是是繞不過去的一道坎,大部分人在學(xué)習(xí)的時(shí)候都是在強(qiáng)行地背公式和套用方法,沒有真正去理解其牛逼的思想內(nèi)涵。我看了一下 Chalmers 一些涉及到貝葉斯統(tǒng)計(jì)的課程,content 里的第一條都是Philosophy of Bayesian statistics。
歷史背景
什么事都要從頭說起,貝葉斯全名為托馬斯·貝葉斯(Thomas Bayes,1701-1761),是一位與牛頓同時(shí)代的牧師,是一位業(yè)余數(shù)學(xué)家,平時(shí)就思考些有關(guān)上帝的事情,當(dāng)然,統(tǒng)計(jì)學(xué)家都認(rèn)為概率這個(gè)東西就是上帝在擲骰子。當(dāng)時(shí)貝葉斯發(fā)現(xiàn)了古典統(tǒng)計(jì)學(xué)當(dāng)中的一些缺點(diǎn),從而提出了自己的“貝葉斯統(tǒng)計(jì)學(xué)”,但貝葉斯統(tǒng)計(jì)當(dāng)中由于引入了一個(gè)主觀因素(先驗(yàn)概率,下文會(huì)介紹),一點(diǎn)都不被當(dāng)時(shí)的人認(rèn)可。直到20世紀(jì)中期,也就是快200年后了,統(tǒng)計(jì)學(xué)家在古典統(tǒng)計(jì)學(xué)中遇到了瓶頸,伴隨著計(jì)算機(jī)技術(shù)的發(fā)展,當(dāng)統(tǒng)計(jì)學(xué)家使用貝葉斯統(tǒng)計(jì)理論時(shí)發(fā)現(xiàn)能解決很多之前不能解決的問題,從而貝葉斯統(tǒng)計(jì)學(xué)一下子火了起來,兩個(gè)統(tǒng)計(jì)學(xué)派從此爭(zhēng)論不休。
什么是概率?
什么是概率這個(gè)問題似乎人人都覺得自己知道,卻有很難說明白。比如說我問你擲一枚硬幣為正面的概率為多少?,大部分人第一反應(yīng)就是50%的幾率為正。不好意思,首先這個(gè)答案就不正確,只有當(dāng)材質(zhì)均勻時(shí)硬幣為正面的幾率才是50%(所以不要覺得打麻將的時(shí)候那個(gè)骰子每面的幾率是相等的,萬一被做了手腳呢)。好,那現(xiàn)在假設(shè)硬幣的材質(zhì)是均勻的,那么為什么正面的幾率就是50%呢?有人會(huì)說是因?yàn)槲覕S了1000次硬幣,大概有492次是正面,508次是反面,所以近似認(rèn)為是50%,說得很好(擲了1000次我也是服你)。
擲硬幣的例子說明了古典統(tǒng)計(jì)學(xué)的思想,就是概率是基于大量實(shí)驗(yàn)的,也就是大數(shù)定理。那么現(xiàn)在再問你,有些事件,例如:明天下雨的概率是30%;A地會(huì)發(fā)生地震的概率是 5%;一個(gè)人得心臟病的概率是 40%……這些概率怎么解釋呢?難道是A地真的 100 次的機(jī)會(huì)里,地震了 5 次嗎?肯定不是這樣,所以古典統(tǒng)計(jì)學(xué)就無法解釋了。再回到擲硬幣的例子中,如果你沒有機(jī)會(huì)擲 1000 次這么多次,而是只擲了 3 次,可這 3 次又都是正面,那該怎么辦?難道這個(gè)正面的概率就是 100% 了嗎?這也是古典統(tǒng)計(jì)學(xué)的弊端。
舉個(gè)例子:生病的幾率
一種癌癥,得了這個(gè)癌癥的人被檢測(cè)出為陽性的幾率為 90%,未得這種癌癥的人被檢測(cè)出陰性的幾率為 90%,而人群中得這種癌癥的幾率為 1%,一個(gè)人被檢測(cè)出陽性,問這個(gè)人得癌癥的幾率為多少?
猛地一看,被檢查出陽性,而且得癌癥的話陽性的概率是 90%,那想必這個(gè)人應(yīng)該是難以幸免了。那我們接下來就算算看。
我們用A表示事件 “測(cè)出為陽性”, 用B1表示“得癌癥”,B2表示“未得癌癥”。根據(jù)題目,我們知道如下信息:
那么我們現(xiàn)在想得到的是已知為陽性的情況下,得癌癥的幾率P(B1,A):
P(B1,A)表示的是聯(lián)合概率,得癌癥且檢測(cè)出陽性的概率是人群中得癌癥的概率乘上得癌癥時(shí)測(cè)出是陽性的幾率,是 0.009。同理可得得癌癥且檢測(cè)出陽性的概率:
這個(gè)概率是什么意思呢?其實(shí)是指如果人群中有 1000 個(gè)人,檢測(cè)出陽性并且得癌癥的人有 9 個(gè),檢測(cè)出陽性但未得癌癥的人有 99 個(gè)。可以看出,檢測(cè)出陽性并不可怕,不得癌癥的是絕大多數(shù)的,這跟我們一開始的直覺判斷是不同的!可直到現(xiàn)在,我們并沒有得到所謂的“在檢測(cè)出陽性的前提下得癌癥的概率”,怎么得到呢?很簡(jiǎn)單,就是看被測(cè)出為陽性的這 108(9+99) 人里,9 人和 99 人分別占的比例就是我們要的,也就是說我們只需要添加一個(gè)歸一化因子(normalization)就可以了。所以陽性得癌癥的概率P(B1|A)為:
陽性未得癌癥的概率P(B2|A)為:
這里P(B1|A),P(B2|A)中間多了這一豎線||成為了條件概率,而這個(gè)概率就是貝葉斯統(tǒng)計(jì)中的后驗(yàn)概率!而人群中患癌癥與否的概率P(B1),P(B2)就是先驗(yàn)概率!我們知道了先驗(yàn)概率,根據(jù)觀測(cè)值(observation),也可稱為 test evidence:是否為陽性,來判斷得癌癥的后驗(yàn)概率,這就是基本的貝葉斯思想,我們現(xiàn)在就能得出本題的后驗(yàn)概率的公式為:
由此就能得到如下的貝葉斯公式的一般形式。
貝葉斯公式
我們把上面例題中的A變成樣本(sample)x, 把B變成參數(shù)(parameter)θ, 我們便得到我們的貝葉斯公式:
??可以看出上面這個(gè)例子中,B事件的分布是離散的,所以在分母用的是求和符號(hào)∑。那如果我們的參數(shù)θ的分布是連續(xù)的呢?沒錯(cuò),那就要用積分,于是我們終于得到了真正的貝葉斯公式:
其中 π 指的是參數(shù)的概率分布,π(θ) 指的是先驗(yàn)概率,π(θ|x) 指的是后驗(yàn)概率,f(x|θ)指的是我們觀測(cè)到的樣本的分布,也就是似然函數(shù)(likelihood),記住豎線 |左邊的才是我們需要的。其中積分求的區(qū)間指的是參數(shù) θ 所有可能取到的值的域,所以可以看出后驗(yàn)概率 π(θ|x) 是在知道 x 的前提下在域內(nèi)的一個(gè)關(guān)于θ 的概率密度分布,每一個(gè)θ 都有一個(gè)對(duì)應(yīng)的可能性(也就是概率)。
理解貝葉斯公式
這個(gè)公式應(yīng)該在概率論書中就有提到,反正當(dāng)時(shí)我也只是死記硬背住,然后遇到題目就套用。甚至在 Chalmers 學(xué)了一門統(tǒng)計(jì)推斷的課講了貝葉斯,大部分時(shí)間我還是在套用公式,直到后來結(jié)合了一些專門講解貝葉斯的課程和資料才有了一些真正的理解。要想理解這個(gè)公式,首先要知道這個(gè)豎線 | 的兩側(cè)一會(huì)是 x|θ ,一會(huì)是 θ|x 到底指的是什么,或者說似然函數(shù)和參數(shù)概率分布到底指的是什么。
似然函數(shù)
首先來看似然函數(shù) f(x|θ),似然函數(shù)聽起來很陌生,其實(shí)就是我們?cè)诟怕收摦?dāng)中看到的各種概率分布 f(x),那為什么后面要加個(gè)參數(shù)|θ 呢?我們知道,擲硬幣這個(gè)事件是服從伯努利分布的 Ber(p) , n次的伯努利實(shí)驗(yàn)就是我們熟知的二項(xiàng)分布 Bin(n,p), 這里的p就是一個(gè)參數(shù),原來我們?cè)谧鰧?shí)驗(yàn)之前,這個(gè)參數(shù)就已經(jīng)存在了(可以理解為上帝已經(jīng)定好了),我們抽樣出很多的樣本 x 是為了找出這個(gè)參數(shù),我們上面所說的擲硬幣的例子,由于我們擲了 1000 次有 492 次是正面,根據(jù)求期望的公式 n?p=μ (492就是我們的期望)可以得出參數(shù) p 為
所以我們才認(rèn)為正面的概率是近似 50% 的。
現(xiàn)在我們知道了,其實(shí)我們觀測(cè)到樣本 x 的分布是在以某個(gè)參數(shù) θ 為前提下得出來的,所以我們記為 f(x|θ),只是我們并不知道這個(gè)參數(shù)是多少。所以參數(shù)估計(jì)成為了統(tǒng)計(jì)學(xué)里很大的一個(gè)課題,古典統(tǒng)計(jì)學(xué)中常用的方法有兩種:矩方法(momnet)和最大似然估計(jì)(maximum likelihood estimate, mle),我們常用的像上面擲硬幣例子中求均值的方法,本質(zhì)就是矩估計(jì)方法,這是基于大數(shù)定理的。而統(tǒng)計(jì)學(xué)中更廣泛的是使用最大似然估計(jì)的方法,原理其實(shí)很簡(jiǎn)單,在這簡(jiǎn)單說一下:假設(shè)我們有 n 個(gè)樣本 x1,x2,x3,…,xn,它們每一個(gè)變量都對(duì)應(yīng)一個(gè)似然函數(shù):
我們現(xiàn)在把這些似然函數(shù)乘起來:
我們只要找到令 lik(θ) 這個(gè)函數(shù)最大的 θ 值,便是我們想要的參數(shù)值(具體計(jì)算參考[2]中p184)。
后驗(yàn)分布(Posterior distribution)
現(xiàn)在到了貝葉斯的時(shí)間了。以前我們想知道一個(gè)參數(shù),要通過大量的觀測(cè)值才能得出,而且是只能得出一個(gè)參數(shù)值。而現(xiàn)在運(yùn)用了貝葉斯統(tǒng)計(jì)思想,這個(gè)后驗(yàn)概率分布 π(θ|x) 其實(shí)是一系列參數(shù)值 θ 的概率分布,再說簡(jiǎn)單點(diǎn)就是我們得到了許多個(gè)參數(shù) θ 及其對(duì)應(yīng)的可能性,我們只需要從中選取我們想要的值就可以了:有時(shí)我們想要概率最大的那個(gè)參數(shù),那這就是后驗(yàn)眾數(shù)估計(jì)(posterior mode estimator);有時(shí)我們想知道參數(shù)分布的中位數(shù),那這就是后驗(yàn)中位數(shù)估計(jì)(posterior median estimator);有時(shí)我們想知道的是這個(gè)參數(shù)分布的均值,那就是后驗(yàn)期望估計(jì)。這三種估計(jì)沒有誰好誰壞,只是提供了三種方法得出參數(shù),看需要來選擇。現(xiàn)在這樣看來得到的參數(shù)是不是更具有說服力?
置信區(qū)間和可信區(qū)間
在這里我想提一下置信區(qū)間(confidence interval, CI) 和可信區(qū)間(credibility interval,CI),我覺得這是剛學(xué)貝葉斯時(shí)候非常容易弄混的概念。
再舉個(gè)例子:一個(gè)班級(jí)男生的身高可能服從某種正態(tài)分布 N(μ,σ2),然后我們把全班男生的身高給記錄下來,用高中就學(xué)過的求均值和方差的公式就可以算出來這兩個(gè)參數(shù),要知道我們真正想知道的是這個(gè)參數(shù) μ,σ2,當(dāng)然樣本越多,得出的結(jié)果就接近真實(shí)值(其實(shí)并沒有人知道什么是真實(shí)值,可能只有上帝知道)。等我們算出了均值和方差,我們這時(shí)候一般會(huì)構(gòu)建一個(gè)95%或者90%的置信區(qū)間,這個(gè)置信區(qū)間是對(duì)于樣本 x來說的,我只算出了一個(gè) μ 和 一個(gè) σ 參數(shù)值的情況下,95% 的置信區(qū)間意味著在這個(gè)區(qū)間里的樣本是可以相信是服從以 μ,σ 為參數(shù)的正態(tài)分布的,一定要記住置信區(qū)間的概念中是指一個(gè)參數(shù)值的情況下!
而我們也會(huì)對(duì)我們得到的后驗(yàn)概率分布構(gòu)造一個(gè) 90% 或 95% 的區(qū)間,稱之為可信區(qū)間。這個(gè)可信區(qū)間是對(duì)于參數(shù) θ來說的,我們的到了 很多的參數(shù)值,取其中概率更大一些的90%或95%,便成了可信區(qū)間。
先驗(yàn)分布(Prior distribution)
說完了后驗(yàn)分布,現(xiàn)在就來說說先驗(yàn)分布。先驗(yàn)分布就是你在取得實(shí)驗(yàn)觀測(cè)值以前對(duì)一個(gè)參數(shù)概率分布的主觀判斷,這也就是為什么貝葉斯統(tǒng)計(jì)學(xué)一直不被認(rèn)可的原因,統(tǒng)計(jì)學(xué)或者數(shù)學(xué)都是客觀的,怎么能加入主觀因素呢?但事實(shí)證明這樣的效果會(huì)非常好!
再拿擲硬幣的例子來看(怎么老是拿這個(gè)舉例,是有多愛錢。。。),在扔之前你會(huì)有判斷正面的概率是50%,這就是所謂的先驗(yàn)概率,但如果是在打賭,為了讓自己的描述準(zhǔn)確點(diǎn),我們可能會(huì)說正面的概率為 0.5 的可能性最大,0.45 的幾率小點(diǎn),0.4 的幾率再小點(diǎn),0.1 的幾率幾乎沒有等等,這就形成了一個(gè)先驗(yàn)概率分布。
那么現(xiàn)在又有新的問題了,如果我告訴你這個(gè)硬幣的材質(zhì)是不均勻的,那正面的可能性是多少呢?這就讓人犯糊涂了,我們想有主觀判斷也無從下手,于是我們就想說那就先認(rèn)為 0~1 之間每一種的可能性都是相同的吧,也就是設(shè)置成 0~1 之間的均勻分布Uni(0,1) 作為先驗(yàn)分布吧,這就是貝葉斯統(tǒng)計(jì)學(xué)當(dāng)中的無信息先驗(yàn)(noninformative prior)!那么下面我們就通過不斷擲硬幣來看看,這個(gè)概率到是多少,貝葉斯過程如下:
從圖中我們可以看出,0 次試驗(yàn)的時(shí)候就是我們的先驗(yàn)假設(shè)——均勻分布,然后擲了第一次是正面,于是概率分布傾向于 1,第二次又是正,概率是 1的可能性更大了,但注意:這時(shí)候在 0.5 的概率還是有的,只不過概率很小,在 0.2 的概率變得更小。第三次是反面,于是概率分布被修正了一下,從為1的概率最大變成了 2/3 左右最大(3次試驗(yàn),2 次正 1 次反當(dāng)然概率是2/3的概率最大)。再下面就是進(jìn)行更多次的試驗(yàn),后驗(yàn)概率不斷根據(jù)觀測(cè)值在改變,當(dāng)次數(shù)很大的時(shí)候,結(jié)果趨向于 0.5 (哈哈,結(jié)果這還是一枚普通的硬幣,不過這個(gè)事件告訴我們,直覺是不可靠的,一定親自實(shí)驗(yàn)才行~)。
有的人會(huì)說,這還不是在大量數(shù)據(jù)下得到了正面概率為 0.5 嘛,有什么好稀奇的?注意了!畫重點(diǎn)了!(敲黑板) 記住,不要和一個(gè)統(tǒng)計(jì)學(xué)家或者數(shù)學(xué)家打賭!跑題了,跑題了。。。說回來,我們上面就說到了古典概率學(xué)的弊端就是如果擲了 2 次都是正面,那我們就會(huì)認(rèn)為正面的概率是 1,而在貝葉斯統(tǒng)計(jì)學(xué)中,如果我們擲了 2 次都是正面,只能說明正面是1的可能性最大,但還是有可能為 0.5, 0.6, 0.7 等等的,這就是對(duì)古典統(tǒng)計(jì)學(xué)的一種完善和補(bǔ)充,于是我們也就是解釋了,我們所謂的地震的概率為 5%;生病的概率為 10% 等等這些概率的意義了,這就是貝葉斯統(tǒng)計(jì)學(xué)的哲學(xué)思想。
共軛先驗(yàn)(Conjugate prior)
共軛先驗(yàn)應(yīng)該是每一個(gè)貝葉斯統(tǒng)計(jì)初學(xué)者最頭疼的問題,我覺得沒有“之一”。這是一個(gè)非常大的理論體系,我試著用一些簡(jiǎn)單的語言進(jìn)行描述,關(guān)鍵是去理解其思想。
繼續(xù)拿擲硬幣的例子,這是一個(gè)二項(xiàng)試驗(yàn) Bin(n,p),所以其似然函數(shù)為:
在我們不知道情況時(shí)就先假設(shè)其先驗(yàn)分布為均勻分布 Uni(0,1),即:
那現(xiàn)在根據(jù)貝葉斯公式求后驗(yàn)概率分布:
我們得到結(jié)果為:
這么一大串是什么呢?其實(shí)就是大名鼎鼎的貝塔分布(Beta distribution)。 簡(jiǎn)寫就是 Be(x+1,n?x+1)。 比如我擲了10 次(n=10),5次正(x=5),5 次反,那么結(jié)果就是 Be(6,6), 這個(gè)分布的均值就是
很符合我們想要的結(jié)果。
現(xiàn)在可以說明,我們把主觀揣測(cè)的先驗(yàn)概率定為均勻分布是合理的,因?yàn)槲覀冊(cè)趯?duì)一件事物沒有了解的時(shí)候,先認(rèn)為每種可能性都一樣是非常說得通的。有人會(huì)認(rèn)為,既然無信息先驗(yàn)是說得通的,而且貝葉斯公式會(huì)根據(jù)我們的觀測(cè)值不斷更新后驗(yàn)概率,那是不是我們隨便給一個(gè)先驗(yàn)概率都可以呢?當(dāng)然……不行!!這個(gè)先驗(yàn)概率是不能瞎猜的,是需要根據(jù)一些前人的經(jīng)驗(yàn)和常識(shí)來判斷的。比如我隨便猜先驗(yàn)為一個(gè)分段函數(shù):
靠,是不是很變態(tài)的一個(gè)函數(shù)…就是假設(shè)一個(gè)極端的情況,如果你把這個(gè)情況代入貝葉斯公式,結(jié)果是不會(huì)好的(當(dāng)然我也不知道該怎么計(jì)算)。
這個(gè)例子中,我看到了可能的后驗(yàn)分布是 Beta 分布,看起來感覺有點(diǎn)像正態(tài)分布啊,那我們用正態(tài)分布作為先驗(yàn)分布可以嗎?這個(gè)是可以的(所以要學(xué)會(huì)觀察)。可如果我們把先驗(yàn)分布為正態(tài)分布代入到貝葉斯公式,那計(jì)算會(huì)非常非常麻煩,雖然結(jié)果可能是合理的。那怎么辦?不用擔(dān)心,因?yàn)槲覀冇泄曹椣闰?yàn)分布!
繼續(xù)拿上面這個(gè)例子,如果我們把先驗(yàn)分布 π(θ) 設(shè)為貝塔分布 Beta(a,b),結(jié)果是什么呢?我就不寫具體的計(jì)算過程啦,直接給結(jié)果:
有沒有看到,依然是貝塔分布,結(jié)果只是把之前的 1 換成了 a 和 b(聰明的你可能已經(jīng)發(fā)現(xiàn),其實(shí)我們所說的均勻分布 Uni(0,1) 等價(jià)于 Beta(1,1),兩者是一樣的)。
由此我們便可以稱二項(xiàng)分布的共軛先驗(yàn)分布為貝塔分布!注意!接著畫重點(diǎn)!:共軛先驗(yàn)這個(gè)概念必須是基于似然函數(shù)來討論的,否則沒有意義!好,那現(xiàn)在有了共軛先驗(yàn),然后呢?作用呢?這應(yīng)該是很多初學(xué)者的疑問。
現(xiàn)在我們來看,如果你知道了一個(gè)觀測(cè)樣本的似然函數(shù)是二項(xiàng)分布的,那我們把先驗(yàn)分布直接設(shè)為 Beta(a,b) ,于是我們就不用計(jì)算復(fù)雜的含有積分的貝葉斯公式便可得到后驗(yàn)分布 Beta (x+a,n?x+b) 了!!!只需要記住試驗(yàn)次數(shù)n,和試驗(yàn)成功事件次數(shù)x就可以了!互為共軛的分布還有一些,但都很復(fù)雜,用到的情況也很少,推導(dǎo)過程也極其復(fù)雜,有興趣的可以自行搜索。我說的這個(gè)情況是最常見的!
注意一下,很多資料里會(huì)提到一個(gè)概念叫偽計(jì)數(shù)(pseudo count),這里的偽計(jì)數(shù)值得就是a,b對(duì)后驗(yàn)概率分布的影響,我們會(huì)發(fā)現(xiàn)如果我們?nèi)?Beta(1,1) ,這個(gè)先驗(yàn)概率對(duì)結(jié)果的影響會(huì)很小,可如果我們?cè)O(shè)為 Beta(100,100),那么我們做 10 次試驗(yàn)就算是全是正面的,后驗(yàn)分布都沒什么變化。
樸素貝葉斯分類器(Naive Bayes classifier)和scikit-learn的簡(jiǎn)單使用
在機(jī)器學(xué)習(xí)中你應(yīng)該會(huì)看到有一個(gè)章節(jié)是講樸素貝葉斯分類器的(把naive翻譯成樸素我也是服了啊,以后我們可以“夸”某某人好樸素啊)。具體的數(shù)學(xué)原理在周志華老師的西瓜書《機(jī)器學(xué)習(xí)》的第7章有詳細(xì)解釋,其實(shí)就是利用了基本的貝葉斯理論,跟上面說的差不多,只不過更加說明的怎樣去實(shí)踐到機(jī)器學(xué)習(xí)中。下面就直接簡(jiǎn)單說一下Python中有個(gè)機(jī)器學(xué)習(xí)庫 scikit-learn 中樸素貝葉斯分類器的簡(jiǎn)單實(shí)用。例子參考的是 scikit-learn 官網(wǎng)的GaussianNB 頁面。
直接看代碼:
import numpy as npX = np.array([[-1, -1], [-2, -1], [-3, -2], [1, 1], [2, 1], [3, 2]])Y = np.array([1, 1, 1, 2, 2, 2])from sklearn.naive_bayes import GaussianNB #導(dǎo)入GaussianNBclf = GaussianNB() #設(shè)置clf為高斯樸素貝葉斯分類器clf.fit(X, Y) #訓(xùn)練數(shù)據(jù)print(clf.predict([[-1, 0]])) #預(yù)測(cè)數(shù)據(jù)[-1,0]屬于哪一類
輸出結(jié)果為: [1]。 這里面我們可以看到有 X,Y 兩個(gè)變量,X是我們要訓(xùn)練的數(shù)據(jù)特征,而Y給的是對(duì)應(yīng)數(shù)據(jù)的標(biāo)簽,分成 [1],[2] 兩類。用 clf.fit 訓(xùn)練好了之后,用 clf.predict 預(yù)測(cè)新數(shù)據(jù)[-1,0],結(jié)果是被分為第一類,說明結(jié)果是令人滿意的。
MCMC(Markov chain Monte Carlo)
你以為說到這貝葉斯的事情就結(jié)束了?那你真的就是太 naive 了。貝葉斯公式里的 θ 只是一個(gè)參數(shù),有沒有想過有兩個(gè)參數(shù)怎么辦?還能怎么辦,分布的積分改成雙重積分唄。可以可以,那如果有 3個(gè)、5個(gè)、10 個(gè)參數(shù)呢?還有十重積分嘛?很顯然積分這個(gè)工具只適合我們?cè)谝痪S和二維的情況下進(jìn)行計(jì)算,三維以上的效果就已經(jīng)不好了;其實(shí)不僅僅在于多維情況,就算是在一維情況很多積分也很難用數(shù)值方法計(jì)算出來,那該怎么辦?于是便有了 MCMC 方法,全稱是馬爾科夫鏈蒙特卡洛方法。大家別指望在下文里看到詳細(xì)的計(jì)算過程和推導(dǎo),我還是按照我的理解,簡(jiǎn)單地從原理出發(fā)進(jìn)行描述,讓大家有一個(gè)感性的認(rèn)識(shí)。
第二個(gè)MC:蒙特卡洛方法
雖然蒙特卡洛方法是 MCMC 中的第二個(gè) MC,但先解釋蒙特卡洛方法會(huì)更加容易理解。蒙特卡洛方法也稱蒙特卡洛抽樣方法,其基本思想是通過大量取樣來近似得到想要的答案。有一個(gè)經(jīng)典的試驗(yàn)就是計(jì)算圓周率,在一個(gè)邊上為1的正方形中畫一個(gè)內(nèi)切圓,圓的面積就是 π,圓面積比上整體的正方形面積也是 ππ, 現(xiàn)在在正方形內(nèi)產(chǎn)生大量隨機(jī)數(shù),最后我們只需要計(jì)算在圓內(nèi)點(diǎn)的個(gè)數(shù)比上總體點(diǎn)的個(gè)數(shù),便近似得到了圓周率 π 的值(這些統(tǒng)計(jì)學(xué)家是真聰明啊。。。)。
現(xiàn)在回到貝葉斯公式,我們現(xiàn)在有一個(gè)后驗(yàn)概率 π(θ|x) ,但我們其實(shí)最想知道的是 h(θ) 的后驗(yàn)期望:
怎么又跑出來一個(gè) h(θ) ?不要著急,如果我們令 h(θ)=θ , 那上面這個(gè)積分求得就是我們想要的后驗(yàn)期望估計(jì)了!(當(dāng)然 h(θ) 還可以是其他情況,會(huì)得到其他我們想要的結(jié)果,例如后驗(yàn)最大估計(jì),后驗(yàn)方差等等,這里就不贅述了) 蒙特卡洛方法指出:如果我們可以從后驗(yàn)概率分布 π(θ|x) 中抽取大量的獨(dú)立同分布(i.i.d)的觀測(cè)值 θ1,θ2,…,θm ,于是我們可以用如下公式:
在大數(shù)定理的支持下,hm 就可看作是 E[h(θ)|x] 的近似值。但是這個(gè)方法在多維和后驗(yàn)分布形式未知的情況下,很難抽樣,于是便有了第一個(gè) MC,馬爾科夫鏈的方法。
第一個(gè)MC:馬爾科夫鏈
馬爾科夫鏈也稱之為馬氏鏈,先來看一下數(shù)學(xué)定義:
意思就是,從 Xn,Xn?1,…,X0 到 Xn+1 的轉(zhuǎn)移概率只與 Xn+1 的前一個(gè)狀態(tài) Xn 有關(guān)。
如果條件概率 P(Xn+1|Xn) 與 n 無關(guān),成為一個(gè)固定值,那么就稱這個(gè)馬氏鏈有平穩(wěn)轉(zhuǎn)移概率,記為 pij 。并且我們稱 P=(pij) 為馬氏鏈的轉(zhuǎn)移矩陣,且滿足條件:
怎么一個(gè)概率變成一個(gè)矩陣了???其實(shí)這個(gè)轉(zhuǎn)移概率 pij 指的只是狀態(tài) i 中的一個(gè)觀測(cè)值 Xn 到狀態(tài) j 中的另一個(gè)觀測(cè)值 Xn+1 的概率,其實(shí)我們?cè)诿總€(gè)狀態(tài)下許許多多的觀測(cè)值。我隨便舉一例子:
現(xiàn)有一個(gè)轉(zhuǎn)換矩陣:
可以看出狀態(tài) i 中的一個(gè)觀測(cè)值轉(zhuǎn)移到下個(gè)狀態(tài) j 的分別三個(gè)觀測(cè)值的概率和為1。
下面就是最最重要的馬氏鏈的平穩(wěn)性(也可稱之為收斂性):
設(shè)馬爾科夫鏈有轉(zhuǎn)移概率矩陣, 一個(gè)概率分布如果滿足?則稱之為此馬爾科夫鏈的平穩(wěn)分布。(取自[1]中定義6.3.2)
可能這么看這個(gè)定義還是有點(diǎn)繞,這里的 i,j 并不是指從 i 一步就到了 j ,求和符號(hào) ∑ 的意思就是能讓概率分布 π(i) 經(jīng)過 n 步之后成為平穩(wěn)分布 π(j) 。我們得到的平穩(wěn)分布 π(j)=[π(1),π(2),…,π(j)] 里面各個(gè)概率的和也為1。
現(xiàn)在我們就要把這個(gè)馬爾科夫鏈和貝葉斯聯(lián)系起來,按照我的理解,π(i) 就是我們的先驗(yàn)分布,如果我們能找到一個(gè)轉(zhuǎn)移矩陣,那么我們就會(huì)在n步之后就會(huì)收斂到一個(gè)平穩(wěn)分布,而這個(gè)分布就是我們要的后驗(yàn)分布。得到平穩(wěn)分布后,根據(jù)平穩(wěn)性,繼續(xù)乘上這個(gè)轉(zhuǎn)移概率矩陣,平穩(wěn)分布依然不會(huì)改變,所以我們就從得到平穩(wěn)分布開始每次對(duì)其中抽樣 1 個(gè)出來,再經(jīng)過 m 步之后,我們就得到了 m 個(gè)服從后驗(yàn)分布的 i.i.d 樣本,便可按照第二個(gè) MC 蒙特卡洛方法進(jìn)行計(jì)算了!
當(dāng)然,還有很多理論是關(guān)于如何找這個(gè)轉(zhuǎn)移概率矩陣的,和算法如何實(shí)現(xiàn)的,但這些都太復(fù)雜了,就不在這里說了。MCMC 是一個(gè)有著完整體系的東西,市面上都很少有詳細(xì)介紹其理論過程的資料,有的話那都不是幾十頁紙能講完的。有一些很好的講解可參考資料[1][4],尤其是[4]是個(gè)很有名的文檔,講得非常通俗易懂、深入淺出,我在這兩個(gè)部分寫的少的原因就是如果寫多了也就是把這些資料對(duì)應(yīng)部分重新說一遍,所以有興趣的就直接看這些資料吧。
MCMC 的 Python 實(shí)現(xiàn)——Pymc
原本想在這里詳細(xì)介紹一個(gè)例子的,但終究還是別人的例子,還是去看原資料比較好,見[4]。注意文件的文件是 ipython 的格式,用 anaconda 里的 Jupyter notebook 打開就行。還有要注意的是每個(gè)章節(jié)的內(nèi)容分為了pymc2 和 pymc3 兩個(gè)庫的實(shí)現(xiàn)。pymc3 需要依賴項(xiàng) theano 才行,我一開始就一直運(yùn)行不起來,原來 theano 只能在Python<3.6和scipy<0.17.1 才能運(yùn)行。
結(jié)尾
這篇文章主要介紹了貝葉斯統(tǒng)計(jì)的數(shù)學(xué)思想,這篇文章從頭到尾寫了有近十個(gè)小時(shí)了,希望能對(duì)大家有所幫助,如果有任何錯(cuò)誤和解釋不當(dāng)?shù)牡胤剑?qǐng)給我評(píng)論,我也只是個(gè)初學(xué)者,也希望能得到大神的指點(diǎn)。
-
貝葉斯
+關(guān)注
關(guān)注
0文章
77瀏覽量
12579 -
機(jī)器學(xué)習(xí)
+關(guān)注
關(guān)注
66文章
8424瀏覽量
132765 -
MCMC
+關(guān)注
關(guān)注
0文章
3瀏覽量
6613
原文標(biāo)題:機(jī)器學(xué)習(xí) —— 淺談貝葉斯和MCMC
文章出處:【微信號(hào):AI_Thinker,微信公眾號(hào):人工智能頭條】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論