作者 | Ben Shaver
翻译 | 刘畅
编辑 | Donna
大多数时候,贝叶斯统计在结果在最好的情况下是魔法,在最糟糕时是一种完全主观的废话。在用到贝叶斯方法的理论体系中,马尔可夫链蒙特卡洛方法尤其神秘。
首先,什么是马尔可夫链蒙特卡洛(MCMC)方法呢?
最简短的回答就是:
“MCMC就是一种通过在概率空间中随机采样来近似感兴趣参数的后验分布的方法”
在这篇文章中,我不用任何数学知识就可以解释上面这个简短的答案。
贝叶斯理论体系基本术语
首先是一些术语。
最好的例子就是钟形曲线:
在贝叶斯统计方式中,分布还有另一个解释。贝叶斯不仅仅代表参数的值和每个参数的真实值有多大,而是认为分布描述了我们对参数的确信度。因此,上面的钟形曲线可以表明我们非常确定参数的值接近于零,同时我们认为真实值高于或低于该值的可能性是相等的。
事实上,人的身高是遵循一个正态分布的,所以我们假设平均人体高度的真实值遵循如下的钟形曲线:
显然,这个图表显示这个人群以巨人的身高生活了很多年,因为据调查所知,最有可能的平均成年身高是6'2''英寸。
让我们想象某人去收集了一些数据,然后他们观察到了一批5英寸和6英寸之间的人。 我们可以用另一个正态分布曲线来表示这些数据,这个曲线显示了哪个人体平均身高值最能解释数据:
在上面的图中,红线表示后验分布。你可以把它看作一种先验和可能性分布的平均值。由于先验分布较短且较为分散,所以它代表了一组关于平均人体身高真实值“不太确定”的概率。 同时,可能性分布在相对较窄的范围内就可以总结数据,因此它代表了对真实参数值“更确定”的概率。
当先验和可能性结合在一起时,数据(可能性分布表示)弱化了个体在巨人中长大的可能性。 尽管那个人仍然认为人的平均身高比数据告诉他的稍高一些,但是他最相信的还是数据。
在两条钟形曲线的情况下,求解后验分布是非常容易的。 有一个简单的方程来结合这两者。 但是如果我们的先验分布和可能性分布不那么好呢?
有时,使用不是常规形状的分布来模型化我们的数据或我们先验信息是最准确的。如果我们的可能性分布用两个峰值来表示更好,而且由于某种原因,我们想要解释一些非常古怪的先验分布时该怎么办呢?我已经通过手工绘制了一个丑陋的先验分布:
在Matplotlib中呈现的可视化,使用MS Paint进行了增强
如之前所讲,有一些后验分布可以给出每个参数值的可能性。但是很难确定分布曲线的具体样子,而且通过分析也无法解决。
MCMC方法
蒙特卡洛估计
假设我们想估计下面圆圈的面积:
由于圆是在边长为10英寸的正方形内,因此可以容易地计算出它的面积为78.5平方英寸。 另一种方式,我们可以在正方形内随机抽取20个点。然后,我们计算在圆内的点的比例,并乘以正方形的面积。而这个数字是一个非常好的圆圈面积的近似值。
由于20个点中有15个都位于圆内,所以看起来圆的面积大约是75平方英寸。这个结果对于只有20个随机点的蒙特卡罗模拟方法来说也不算太坏。
现在,想象一下我们想要计算蝙蝠侠曲线方程(Batman Equation)绘制的形状的面积:
这是一个我们从来没有学过的方程的形状!因此,找到蝙蝠信号的区域非常困难。不过,通过在包含蝙蝠形状的矩形内随机地打点,蒙特卡罗模拟方法就可以非常容易地找到该形状面积的近似值!
蒙特卡罗模拟不仅仅是用于估计复杂形状的面积。通过生成大量的随机数,它们可以用来模拟非常复杂的过程。在实践中,习惯用该方法来预测天气,或者估计赢得选举的可能性。
马尔可夫链
安德烈·马尔可夫试图证明非独立事件也有可能符合这种模式。他最著名的实验例子之一就是要从俄罗斯诗歌作品中计算数以千计的两个字符对。使用这些字符对,他计算出了每个角色的条件概率。也就是说,给定某个前面的字母或空格,下一个字母就有可能是一个A,一个T或一个空格。
使用这些概率,马尔可夫能够模拟任意长的字符序列。这就是一个马尔可夫链。
尽管前几个字母很大程度上取决于起始字符的选择,但是马尔可夫表明,从长远来看,字符的分布是一种模式。因此,即使是相互依赖的事件,如果它们受到固定概率的影响,也是一致的。
举一个更有说服力的例子,假设你住在一个有五个房间的房子里,其中有一间卧室,卫生间,客厅,饭厅和厨房。
让我们收集一些数据,假设你在任何时间点所在的房间都是我们认为的下一个可能进入的房间。例如,如果你在厨房,你有30%的机会留在厨房,30%的机会进入餐厅,20%的机会进入客厅,10%的机会去浴室,有10%的机会进入卧室。利用每个房间的进入的概率,我们可以构建一个预测你下一个可能去的房间的马尔可夫链。
如果我们想要预测房子里某个人在厨房里待一小会儿后会去哪里,那么马尔可夫链可以用于这一类预测。但是由于我们的预测只是基于一个人在家里的一个观察,所以这类预测结果并不可靠。
例如,如果有人从卧室走到浴室,那么他们更有可能直接回到卧室,而不是从厨房里出来。所以马尔可夫属性通常不适用于现实世界。
然而,将马尔可夫链进行数千次迭代,确实能够长期的预测你接下来可能会进入哪个房间。更重要的是,这个预测并没有受到人们从哪个房间开始的影响!直观地说,这是有道理的:为了模拟和描述他们可能长期或通常所在地在哪里,某个时间点某人在家里的位置并不重要。
因此,在一段时期内对随机变量建模并不合理的马尔可夫链方法,却可以用来计算该变量的长期趋势。
MCMC方法
有了蒙特卡洛模拟和马尔可夫链的一些知识,我希望MCMC方法的零数学解释是非常直观的。
回想一下,我们试图估计我们感兴趣参数的后验分布,即人均身高:
我不是一个可视化的专家,我也没有把我的例子放在常识的范围之内:我这个后验分布的例子严重地高估了人的平均身高。
我们知道后验分布在先验分布和似然分布范围内,但是,我们很难直接计算它。 使用MCMC方法,我们就可以有效地从后验分布中抽取样本,然后计算比如抽样样本的平均值。
首先,MCMC方法考虑选择一个随机参数值。然后模拟会继续生成随机值(这是蒙特卡罗的一部分),但要根据一些规则来确定什么是一个好的参数值。这个诀窍就是,对于一对参数值,基于先验信息,通过计算每个值在解释数据时的可能性有多大,来计算哪个参数值更好。如果随机生成的参数值比最后一个参数值更好,则以一定的概率值将其添加到参数值链中(这是马尔科夫链部分)。
分布中某个值的高度代表了观察该值的概率。因此,我们可以想象我们的参数值(x轴)在y轴上呈现出高低概率的区域。对于单个参数,MCMC方法是沿x轴开始随机采样:
红点是随机参数样本
由于随机样本受到固定概率的影响,经过一段时间之后,它们往往会在我们感兴趣参数概率最高的区域收敛:
蓝点只代表当预计会出现收敛时的随机样本。注意:为了说明的目的,我垂直叠加了点。
在数据收敛之后,MCMC抽样产生一组来自后验分布的样本点。 在这些点周围绘制直方图,并计算任何您喜欢的统计数据:
根据MCMC模拟生成的样本集计算出的任何统计量就是我们对该真实后验分布统计量的最佳预测。
MCMC方法也可以用来估计多个参数的后验分布(比如说人的身高和体重)。
回想一下“什么是马尔可夫链蒙特卡罗方法?”这个问题的简短答案。那就是:
“MCMC就是一种通过在概率空间中随机采样来接近感兴趣参数的后验分布的方法”
原文链接:https://towardsdatascience.com/a-zero-math-introduction-to-markov-chain-monte-carlo-methods-dcba889e0c50
热文精选
干货 | AI 工程师必读,从实践的角度解析一名合格的AI工程师是怎样炼成的
AI校招程序员最高薪酬曝光!腾讯80万年薪领跑,还送北京户口
谷歌AI正式来中国了,机器学习三大职位正在招聘...如果你想跟李飞飞一起工作的话
算法还是算力?周志华微博引爆深度学习的“鸡生蛋,蛋生鸡”问题