期望极大算法:Expectation Maximization Algorithm

EM

EM算法是一种迭代的算法,也可以说是一类算法的范式。概率模型中,有时候不仅存在观测变量,还可能存在隐含变量或者潜在变量。如果模型中的变量都是观测变量,那么直接使用极大似然估计或者贝叶斯估计来估计参数;当变量中含有隐变量时,就可以采用EM算法来进行能够参数的估计。EM算法主要分为两步:E步,求期望;M步,求极大。

一般情况下,用 Y 表示观测随机变量的数据,Z表示隐随机变量的数据。 Y Z连在一起称为完全数据,观测数据 Y 又称之为不完全数据。假设给定观测数据Y,其概率分布为 P(Yθ) θ 是需要估计的模型参数,假设 Y Z的联合概率密度分布是 P(Y,Zθ) 。EM算法是通过迭代求取 L(θ)=logP(Y,Zθ) 的极大似然估计。

算法流程
输入:观测变量数据 Y ,隐含变量数据Z,联合分布 P(Y,Zθ) ,条件分布 P(ZY,θ)
输出:模型参数 θ
(1) 选择参数的初值 θ(0) ,开始迭代;
(2) E步:记 θ(i) 为第 i 的迭代参数θ的估计值,在第 i+1 次迭代的E步,计算:

Q(θ,θ(i))=EZ[logP(Y,Zθ)Y,θ(i)]=ZlogP(Y,Zθ)P(ZY,θ(i))

(3)M步:求使得 Q(θ,θ(i)) 极大化的 θ ,确定第 i+1 次迭代的参数估计值:
θ(i+1)=argmaxθQ(θ,θ(i))

(4)重复上述E步和M步,直至算法收敛。

EM


推导

对于一个含有隐含变量的概率模型,目标是是极大化观测数据 Y 关于参数θ的对数似然函数 L(θ)=logP(Yθ) 。每一次迭代之后,该似然函数应该都会增大,即:

L(θ)L(θ(i))=log(ZP(YZ,θ)P(Zθ))logP(Yθ(i))=log(ZP(YZ,θ(i))P(YZ,θ)P(Zθ)P(YZ,θ(i)))logP(Yθ(i))ZP(YZ,θ(i))logP(YZ,θ)P(Zθ)P(YZ,θ(i))logP(Yθ(i))=ZP(YZ,θ(i))logP(YZ,θ)P(Zθ)P(YZ,θ(i))logP(Yθ(i))P(YZ,θ(i))=ZP(YZ,θ(i))logP(YZ,θ)P(Zθ)P(YZ,θ(i))P(YZ,θ(i))logP(Yθ(i))=ZP(YZ,θ(i))(logP(YZ,θ)P(Zθ)P(YZ,θ(i))logP(Yθ(i)))=ZP(YZ,θ(i))logP(YZ,θ)P(Zθ)P(YZ,θ(i))P(Yθ(i))=ZP(YZ,θ(i))logP(Y,Zθ)P(Y,Zθ(i))

那么由上式可以得到一个 L(θ) 的下界,即:
L(θ)B(θ,θ(i))=L(θ(i))+ZP(YZ,θ(i))logP(Y,Zθ)P(Y,Zθ(i))

那么:
θ(i+1)=argmaxθB(θ,θ(i))=argmaxθZP(YZ,θ(i))logP(Y,Zθ)P(Y,Zθ(i))=argmaxθZP(YZ,θ(i))logP(Y,Zθ)=argmaxθQ(θ,θ(i))

从上式可以看出,EM算法是通过不断极大化下界来来逼近对数似然函数的极大值的算法,但不能保证得到全局最优值。


应用

1)在非监督学习中的使用:一种典型的应用就是在分类问题中,将样本的类别作为一个隐含的变量,然后可以使用EM算法求解。例如kmeas算法。
2)混合高斯模型的参数求解。


References:
[1]李航:《统计学习方法》

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值