【十大经典数据挖掘算法】系列html
极大似然(Maximum Likelihood)估计为用于已知模型的参数估计的统计学方法。好比,咱们想了解抛硬币是正面(head)的几率分布\(\theta\);那么能够经过最大似然估计方法求得。假如咱们抛硬币\(10\)次,其中\(8\)次正面、\(2\)次反面;极大似然估计参数\(\theta\)值:git
\[ \hat{\theta} = \arg\underset{\theta}{\max}\, l(\theta) = \arg\underset{\theta}{\max}\, \theta^8(1-\theta)^2 \]github
其中,\(l(\theta)\)为观测变量序列的似然函数(likelihood function of the observation sequence)。对\(l(\theta)\)求偏导算法
\[ \frac{\partial l(\theta)}{\partial \theta} = \theta^7(1-\theta)(8-10\theta) \Rightarrow \hat{\theta} = 0.8 \]机器学习
由于似然函数\(l(\theta)\)不是凹函数(concave),求解极大值困难。通常地,使用与之具备相同单调性的log-likelihood,如图所示
ide
凹函数(concave)与凸函数(convex)的定义如图所示:
函数
从图中能够看出,凹函数“容易”求解极大值,凸函数“容易”求解极小值。学习
EM算法(Expectation Maximization)是在含有隐变量(latent variable)的模型下计算最大似然的一种算法。所谓隐变量,是指咱们没有办法观测到的变量。好比,有两枚硬币A、B,每一次随机取一枚进行抛掷,咱们只能观测到硬币的正面与反面,而不能观测到每一次取的硬币是否为A;则称每一次的选择抛掷硬币为隐变量。spa
用Y表示观测数据,Z表示隐变量;Y和Z连在一块儿称为彻底数据( complete-data ),观测数据Y又称为不彻底数据(incomplete-data)。观测数据的似然函数:3d
\[ P(Y | \theta) = \sum_{Z} P(Z|\theta)P(Y|Z,\theta) \]
求模型参数的极大似然估计:
\[ \hat{\theta} = \arg\underset{\theta}{\max}\, \log P(Y | \theta) \]
由于含有隐变量,此问题没法求解。所以,Dempster等人提出EM算法用于迭代求解近似解。EM算法比较简单,分为两个步骤:
\[ Q(\theta, \theta^{(i)}) = \mathbb{E}_Z[\log P(Y,X|\theta)| Y, \theta^{(i)}] \]
\[ \theta^{(i+1)} = \arg\underset{\theta}{\max}\, Q(\theta, \theta^{(i)}) \]
如此迭代直至算法收敛。关于算法的推导及收敛性证实,可参看李航的《统计学习方法》及Andrew Ng的《CS229 Lecture notes》。这里有一些极大似然以及EM算法的生动例子。
[2]中给出极大似然与EM算法的实例。如图所示,有两枚硬币A、B,每个实验随机取一枚抛掷10次,共5个实验,咱们能够观测到每一次所取的硬币,估计参数A、B为正面的几率\(\theta = (\theta_A, \theta_B)\),根据极大似然估计求解
若是咱们不能观测到每一次所取的硬币,只能用EM算法估计模型参数,算法流程如图所示:
隐变量\(Z\)为每次实验中选择A或B的几率,则第一个实验选择A的几率为
\[ P(z_1 = A |y_1, \theta^{(0)}) = \frac{P(z_1 = A |y_1, \theta^{(0)})}{P(z_1 = A |y_1, \theta^{(0)}) + P(z_1 = B |y_1, \theta^{(0)})} = \frac{0.6^5*0.4^5}{0.6^5*0.4^5 + 0.5^{10}} = 0.45 \]
按照上面的计算方法可依次求出隐变量\(Z\),而后计算极大化的\(\theta^{(i)}\)。通过10次迭代,最终收敛。
[1] 李航,《统计学习方法》.
[2] Chuong B Do & Serafim Batzoglou, What is the expectation maximization algorithm?
[3] Pieter Abbeel, Maximum Likelihood (ML), Expectation Maximization (EM).
[4] Rudan Chen,【机器学习算法系列之一】EM算法实例分析.