最大似然估计

  一个栗子:假如去赌场,但是不知道能不能赚钱,你就在门口堵着出来一个人就问一个赚了还是赔了,如果问了5个人都说赚了,那么你就会认为,赚钱的概率肯定是非常大的。

  已知:(1)样本服从分部的模型,(2)观测到的样本

  求解:模型的参数

  总的来说:极大似然估计就是用来估计模型参数的统计学方法

最大似然的数学问题(100名学生的身高问题)

  样本集X = {x1, x2 ,...,xN} N = 100

  概率密度:p(xi|θ)抽到男生i(的身高)的概率

  θ是服从分部的参数

  独立同分布:同时抽到这100个男生的概率就是他们各自概率的乘积

  最大似然函数:

   (对数是为了乘法转加法)

  什么样的参数θ能够使得出现当前这批样本的概率最大

  已知某个随机样本满足某种概率分布,但是其中具体的参数不清楚,参数估计就是通过若干次试验,观察其结果,利用结果推出参数的大概值。

问题又难了一步

  现在这100个人中,不光有男生,还有女生(2个类别,2种参数)

  男生和女生的身高都服从高斯分布,但是参数不同(均值,方差)

  用数学的语言描述:抽取得到的每个样本都不知道是从哪个分布抽取的

  求解目标:男生和女生对应的身高的高斯分布的参数是多少

  加入隐变量

    用Z = 0或Z = 1标记样本来自哪个分部,则Z就是隐变量

    最大似然函数:

      

    求解:在给定初始值情况下进行迭代求解

EM算法

  EM算法推导:

  问题:样本集{x(1),...,x(m)},包含m个独立的样本。其中每个样本i对应的类别z(i)是未知的,所以很难用最大似然求解。

  

  上式中,要考虑每个样本在各个分布中的情况。本来正常求偏导就可以了,但是现在log后面还有求和,这就难解了!

  右式分子分母同时乘:

    

  这么做就是为了凑Jensen不等式(Q(z)是Z的分布函数)

Jensen不等式

  设f是定义域为实数的函数,如果对于所有的实数x。

  如果对于所有的实数x,f(x)的二次导数大于等于0,那么f是凸函数。

  如果f是凸函数,X是随机变量,那么:E[f(X)] > = f(E[X])

  

  实线f是凸函数,X有0.5的概率是a,有0.5的概率是b,X的期望值就是a和b的中值了

  Jensen不等式应用于凹函数时,不等号方向反向

  由于:

    是 的期望

  假设则:

  可得:

    

  结论:

    

  下届比较好求,所以我们要优化这个下界来使得似然函数最大

  优化下届,迭代到收敛

    

  Jensen中等式成立的条件是随机变量是常数:

    

  Q(z)是z的分部函数:

    

  所有的分子和等于常数C(分母相同)

Q(z)求解

  

  由上式可得C就是p(xi,z)对z求和

  

  Q(z)代表第i个数据是来自zi的概率

EM算法流程

  初始化分布参数Θ

  E-step:根据参数Θ计算每个样本属于zi的概率(也就是Q)

  M-step:根据Q,求出含有Θ的似然函数的下界并最大化它,得到新的参数Θ

  不断的迭代更新

GMM(高斯混合模型)

  数据可以看作是从数个Gaussian Distribution中生成出来的

  GMM由K个Gaussian分布组成,每个Gaussian称为一个“Component”

  类似k-means方法,求解方式跟EM一样

  不断的迭代更新 

EM算法——Expectation-Maximization的更多相关文章

  1. EM算法(Expectation Maximization Algorithm)

    EM算法(Expectation Maximization Algorithm) 1. 前言   这是本人写的第一篇博客(2013年4月5日发在cnblogs上,现在迁移过来),是学习李航老师的< ...

  2. EM算法(Expectation Maximization)

    1 极大似然估计     假设有如图1的X所示的抽取的n个学生某门课程的成绩,又知学生的成绩符合高斯分布f(x|μ,σ2),求学生的成绩最符合哪种高斯分布,即μ和σ2最优值是什么? 图1 学生成绩的分 ...

  3. EM算法(Expectation Maximization Algorithm)初探

    1. 通过一个简单的例子直观上理解EM的核心思想 0x1: 问题背景 假设现在有两枚硬币Coin_a和Coin_b,随机抛掷后正面朝上/反面朝上的概率分别是 Coin_a:P1:-P1 Coin_b: ...

  4. 简单理解EM算法Expectation Maximization

    1.EM算法概念 EM 算法,全称 Expectation Maximization Algorithm.期望最大算法是一种迭代算法,用于含有隐变量(Hidden Variable)的概率参数模型的最 ...

  5. EM 算法 Expectation Maximization

  6. EM(Expectation Maximization)算法

    EM(Expectation Maximization)算法  参考资料: [1]. 从最大似然到EM算法浅解 [2]. 简单的EM算法例子 [3]. EM算法)The EM Algorithm(详尽 ...

  7. 最大期望算法 Expectation Maximization概念

    在统计计算中,最大期望(EM,Expectation–Maximization)算法是在概率(probabilistic)模型中寻找参数最大似然估计的算法,其中概率模型依赖于无法观测的隐藏变量(Lat ...

  8. 机器学习-EM算法

    最大期望算法 EM算法的正式提出来自美国数学家Arthur Dempster.Nan Laird和Donald Rubin,其在1977年发表的研究对先前出现的作为特例的EM算法进行了总结并给出了标准 ...

  9. 数据挖掘十大经典算法(5) 最大期望(EM)算法

    在统计计算中,最大期望(EM,Expectation–Maximization)算法是在概率(probabilistic)模型中寻找参数最大似然估计的算法,其中概率模型依赖于无法观测的隐藏变量(Lat ...

  10. EM算法及其推广

    概述 EM算法是一种迭代算法,用于含有隐变量(hidden variable)的概率模型参数的极大似然估计,或极大后验概率估计. EM算法的每次迭代由两步组成:E步,求期望(expectation): ...

随机推荐

  1. WebSocket和long poll、ajax轮询的区别,ws协议测试

    WebSocket和long poll.ajax轮询的区别,ws协议测试 WebSocket是HTML5出的东西(协议),也就是说HTTP协议没有变化,或者说没关系,但HTTP是不支持持久连接的(长连 ...

  2. [转载]asp.net中,<%#%>,<%=%>和<%%>分别是什么意思,有什么区别

    在asp.net中经常出现包含这种形式<%%>的html代码,总的来说包含下面这样几种格式: 一. <%%> 这种格式实际上就是和asp的用法一样的,只是asp中里面是vbsc ...

  3. Centos搭建Seafile个人网盘

    1.安装依赖环境 yum install python python-setuptools python-imaging python-ldap python-memcached MySQL-pyth ...

  4. JVM 一套卷,助你快速掌握优化法则

    一:虚拟机内存图解 JAVA 程序运行与虚拟机之上,运行时需要内存空间.虚拟机执行 JAVA 程序的过程中会把它管理的内存划分为不同的数据区域方便管理. 虚拟机管理内存数据区域划分如下图: 数据区域分 ...

  5. linux下的ifconfig命令

    ifconfig工具不仅可以被用来简单地获取网络接口配置信息,还可以修改这些配置. 1.命令格式: ifconfig [网络设备] [参数] 2.命令功能: ifconfig 命令用来查看和配置网络设 ...

  6. use right spindle drive

    Hardware software interface: HallSupplyLeft: E_BSW_DO_SUP_HCOM_A Left Hall Sensor: E_BSW_DI_HALL_A_1 ...

  7. 开启redis-server提示 # Creating Server TCP listening socket *:6379: bind: Address already in use--解决方法

    在bin目录中开启Redis服务器,完整提示如下: 3496:C 25 Apr 00:56:48.717 # Warning: no config file specified, using the  ...

  8. modelform添加属性

    暗暗啊

  9. bzoj4861 / P3715 [BJOI2017]魔法咒语

    P3715 [BJOI2017]魔法咒语 AC自动机+dp+矩阵乘法 常规思路是按基本串建立AC自动机 然鹅这题是按禁忌串建立AC自动机 对后缀是禁忌的点以及它的失配点做上标记$(a[i].ed)$, ...

  10. MySQL乐观锁和悲观锁的概念和原理

    乐观锁:在取数据时不加锁,等处理完逻辑的时候,查看是否与上一次相同,若相同则更新,若不同则拒绝. 悲观锁:在取数据时就加上锁,只有更新完数据之后,别的用户才可以进行读. (个人总结)