EM算法

下面是《统计学习方法》EM算法的笔记。
EM算法是一种针对含有隐变量的模型的参数估计方法,具体来说是极大似然估计和最大后验概率估计。

该算法分为两步,第一步求期望,第二步对期望进行最大化。

首先,我们定义Y是观测变量,Z是隐变量。其中Y又称为不完全数据,Y、Z在一起称为完全数据。

第一步求的是下面这个函数的期望:

Q(θ,θi)=EZ[logP(Y,Z|θ)|Y,θi]=zlogP(Y,Z|θ)P(Z|Y,θi)

即求完全数据的对数似然函数关于在给定观测数据Y和当前估计参数 θ(i) 下对未观测数据Z的条件概率分布 p(Z|Y,θ(i)) 的期望。

下面介绍EM算法是怎么来的

对于含有隐变量的概率模型,我们的目标是最大化观测数据的对数似然函数:

L(θ)=logP(Y|θ)=logzP(Y,Z|θ)=logzP(Y|Z,θ)P(Z,θ)

这个问题极大化的难度在于含有和的对数形式,这样在进行求导时还是包含这个东西。

EM算法的思想是通过迭代的方式来近似地极大化 L(θ)

假设第i次迭代后 θ 的估计值为 θi .我们希望新的估计值可以使 L(θ) 增大,即 L(θ)>L(θi) ,并逐步达到最大值。
我们考虑这二者的差

L(θ)L(θi)=log(zP(Y|Z,θ)P(Z|θ))logP(Y|θi)

利用jensen不等式得到下界。

L(θ)L(θi)=log(zP(Z|Y,θi)P(Y|Z,θ)P(Z|θ)P(Z|Y,θi)logP(Y|θi))zP(Z|Y,θi)logP(Y|Z,θ)P(Z|θ)P(Z|Y,θi)zP(Z|Y,θi)logP(Y|θi)=P(Z|Y,θi)logP(Y|Z,θ)P(Z|θ)P(Z|Y,θi)P(Y|θi)


B(θ,θi)=L(θi)+P(Z|Y,θi)logP(Y|Z,θ)P(Z|θ)P(Z|Y,θi)P(Y|θi)


L(θ)B(θ,θi)

B(θ,θi) L(θ) 的一个下界。那么任何可以让 B(θ,θi) 增大的 θ 也同时可以让 L(θ) 增大。所以我们最大化 B(θ,θi) 的话 L(θ) 也会有相当程度的增大,即

θi+1=argmaxB(θ,θi)=argmax(L(θi)+P(Z|Y,θi)logP(Y|Z,θ)P(Z|θ)P(Z|Y,θi)P(Y|θi))=argmax(P(Z|Y,θi)logP(Y|Z,θ)P(Z|θ))=argmax(Q(θ,θi))

其中第二步是把所有常数项都去掉了。

至此,我们就导出了EM算法的目标函数了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值