服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - 高斯混合模型与EM算法图文详解

高斯混合模型与EM算法图文详解

2021-11-13 11:28Dominic221 Java教程

高斯模型就是用高斯概率密度函数(正态分布曲线)精确地量化事物,将一个事物分解为若干的基于高斯概率密度函数(正态分布曲线)形成的模型

一、前言 

高斯混合模型(gaussian mixture model)简称gmm,是一种业界广泛使用的聚类算法。它是多个高斯分布函数的线性组合,理论上gmm可以拟合出任意类型的分布,通常用于解决同一集合下的数据包含多种不同的分布的情况。高斯混合模型使用了期望最大(expectation maximization, 简称em)算法进行训练,故此我们在了解gmm之后,也需要了解如何通过em算法训练(求解)gmm。

二、高斯混合模型(gmm) 

在了解高斯混合模型之前,我们先了解一下这种模型的具体参数模型-高斯分布。高斯分布又称正态分布,是一种在自然界中大量存在的,最为常见的分布形式。

高斯混合模型与EM算法图文详解

如上图,这是一个关于身高的生态分布曲线,关于175-180对称,中间高两边低,相信大家在高中已经很了解了,这里就不再阐述。

现在,我们引用《统计学习方法》-李航 书中的定义,如下图:

高斯混合模型与EM算法图文详解

根据定义,我们可以理解为,gmm是多个高斯分布的加权和,并且权重α之和等于1。这里不难理解,因为gmm最终反映出的是一个概率,而整个模型的概率之和为1,所以权重之和即为1。高斯混合模型实则不难理解,接下来我们介绍gmm的训练(求解)方法。

ps.从数学角度看,对于一个概率模型的求解,即为求其最大值。从深度学习角度看,我们希望降低这个概率模型的损失函数,也就是希望训练模型,获得最大值。训练和求解是不同专业,但相同目标的术语。

三、最大似然估计 

想要了解em算法,我们首先需要了解最大似然估计这个概念。我们通过一个简单的例子来解释一下。

假设,我们需要调查学校男女生的身高分布。我们用抽样的思想,在校园里随机抽取了100男生和100女生,共计200个人(身高样本数据)。我们假设整个学校的身高分布服从于高斯分布。但是这个高斯分布的均值u和方差∂2我们不知道,这两个参数就是我们需要估计的值。记作θ=[u, ∂]t。

由于每个样本都是独立地从p(x|θ)中抽取的,并且所有的样本都服从于同一个高斯分布p(x|θ)。那么我们从整个学校中,那么我抽到男生a(的身高)的概率是p(xa|θ),抽到男生b的概率是p(xb|θ)。而恰好抽取出这100个男生的概率,就是每个男生的概率乘积。用下式表示:

    高斯混合模型与EM算法图文详解

这个概率反映了,在概率密度函数的参数是θ时,得到x这组样本的概率。在公式中,x已知,而θ是未知,所以它是θ的函数。这个函数放映的是在不同的参数θ取值下,取得当前这个样本集的可能性,因此称为参数θ相对于样本集x的似然函数(likehood function)。记为l(θ)。

我们先穿插一个小例子,来阐述似然的概念。 

某位同学与一位猎人一起外出打猎,一只野兔从前方窜过。只听一声枪响,野兔应声到下,如果要你推测,这一发命中的子弹是谁打的?你就会想,只发一枪便打中,由于猎人命中的概率一般大于这位同学命中的概率,看来这一枪是猎人射中的。

这个例子所作的推断就体现了极大似然法的基本思想,我们并不知道具体是谁打的兔子,但是我们可以估计到一个看似正确的参数。回到男生身高的例子中。在整个学校中我们一次抽到这100个男生(样本),而不是其他的人,那么我们可以认为这100个男生(样本)出现的概率最大,用上面的似然函数l(θ)来表示。

所以,我们就只需要找到一个参数θ,其对应的似然函数l(θ)最大,也就是说抽到这100个男生(的身高)概率最大。这个叫做θ的最大似然估计量,记为:

高斯混合模型与EM算法图文详解

因为l(θ)是一个连乘函数,我们为了便于分析,可以定义对数似然函数,运用对数的运算规则,把连乘转变为连加:

高斯混合模型与EM算法图文详解

ps.这种数学方法在mfcc中我们曾经用过,可以回溯一下上一篇文章。

此时,我们要求θ,只需要使θ的似然函数l(θ)极大化,然后极大值对应的θ就是我们的估计。在数学中求一个函数的最值问题,即为求导,使导数为0,解方程式即可(前提是函数l(θ)连续可微)。在深度学习中,θ是包含多个参数的向量,运用高等数学中的求偏导,固定其中一个变量的思想,即可求出极致点,解方程。

总结而言:

最大似然估计,只是一种概率论在统计学的应用,它是参数估计的方法之一。说的是已知某个随机样本满足某种概率分布,但是其中具体的参数不清楚,参数估计就是通过若干次试验,观察其结果,利用结果推出参数的大概值。最大似然估计是建立在这样的思想上:已知某个参数能使这个样本出现的概率最大,我们当然不会再去选择其他小概率的样本,所以干脆就把这个参数作为估计的真实值。

求最大似然函数估计值的一般步骤:

  • 写出似然函数;
  • 对似然函数取对数,并整理;(化乘为加)
  • 求导数,令导数为0,得到似然方程;
  • 解似然方程,得到的参数即为所求。

四、em算法 

期望最大(expectation maximization, 简称em)算法,称为机器学习十大算法之一。它是一种从不完全数据或有数据丢失的数据集(存在隐含变量)中求解概率模型参数的最大似然估计方法。

现在,我们重新回到男女生身高分布的例子。我们通过抽取100个男生身高,并假设身高分布服从于高斯分布,我们通过最大化其似然函数,可以求的高斯分布的参数θ=[u, ∂]t了,对女生同理。但是,假如这200人,我们只能统计到其身高数据,但是没有男女信息(其实就是面对200个样本,抽取得到的每个样本都不知道是从哪个分布抽取的,这对于深度学习的样本分类很常见)。这个时候,我们需要对样本进行两个东西的猜测或者估计了。

em算法就可以解决这个问题。假设我们想估计知道a和b两个参数,在开始状态下二者都是未知的,但如果知道了a的信息就可以得到b的信息,反过来知道了b也就得到了a。可以考虑首先赋予a某种初值,以此得到b的估计值,然后从b的当前值出发,重新估计a的取值,这个过程一直持续到收敛为止。

在男女生身高分布的例子中,我们运用em算法的思想。首先随便猜一下男生的高斯分布参数:均值和方差。假设均值是1.7米,方差是0.1米,然后计算出每个人更可能属于第一个还是第二个正态分布中。这是第一步,expectation。在分开了两类之后,我们可以通过之前用的最大似然,通过这两部分,重新估算第一个和第二个分布的高斯分布参数:均值和方差。这是第二步,maximization。然后更新这两个分布的参数。这是可以根据更新的分布,重新调整e(expectation)步骤...如此往复,迭代到参数基本不再发生变化。

这里原作者提到了一个数学思维,很受启发,转给大家看一眼(比较鸡汤和啰嗦,大家可以跳过)

这时候你就不服了,说你老迭代迭代的,你咋知道新的参数的估计就比原来的好啊?为什么这种方法行得通呢?有没有失效的时候呢?什么时候失效呢?用到这个方法需要注意什么问题呢?呵呵,一下子抛出那么多问题,搞得我适应不过来了,不过这证明了你有很好的搞研究的潜质啊。呵呵,其实这些问题就是数学家需要解决的问题。在数学上是可以稳当的证明的或者得出结论的。那咱们用数学来把上面的问题重新描述下。(在这里可以知道,不管多么复杂或者简单的物理世界的思想,都需要通过数学工具进行建模抽象才得以使用并发挥其强大的作用,而且,这里面蕴含的数学往往能带给你更多想象不到的东西,这就是数学的精妙所在啊)

五、em算法的简单理解方式 

在提出em算法的推导过程之前,先提出中形象的理解方式,便于大家理解整个em算法,如果只是实现深度学习模型,个人认为可以不需要去看后面的算法推导,看这个就足够了。

坐标上升法(coordinate ascent):

高斯混合模型与EM算法图文详解

图中的直线式迭代优化的途径,可以看到每一步都会向最优值靠近,而每一步前进的路线都平行于坐标轴。那么我们可以将其理解为两个未知数的方程求解。俩个未知数求解的方式,其实是固定其中一个未知数,求另一个未知数的偏导数,之后再反过来固定后者,求前者的偏导数。em算法的思想,其实也是如此。使用坐标上升法,一次固定一个变量,对另外的求极值,最后逐步逼近极值。对应到em上,e步:固定θ,优化q;m步:固定q,优化θ;交替将极值推向最大。 

六、em算法推导 

现在很多深度学习框架可以简单调用em算法,实际上这一段大家可以不用看,直接跳过看最后的总结即可。但是如果你希望了解一些内部的逻辑,可以看一下这一段推导过程。

假设我们有一个样本集{x(1),…,x(m)},包含m个独立的样本(右上角为样本序号)。但每个样本i对应的类别z(i)是未知的(相当于聚类),也即隐含变量。故我们需要估计概率模型p(x,z)的参数θ(在文中可理解为高斯分布),但是由于里面包含隐含变量z,所以很难用最大似然求解,但如果z知道了,那我们就很容易求解了。

首先放出似然函数公式,我们接下来对公式进行化简:

高斯混合模型与EM算法图文详解

对于参数估计,我们本质上的思路是想获得一个使似然函数最大化的参数θ,现在多出一个未知变量z,公式(1)。那么我们的目标就转变为:找到适合的θ和z让l(θ)最大。

对于多个未知数的方程分别对未知的θ和z分别求偏导,再设偏导为0,即可解方程。

因为(1)式是和的对数,当我们在求导的时候,形式会很复杂。

这里我们需要做一个数学转化。我们对和的部分,乘以一个相等的函数,得到(2)式,利用jensen不等式的性质,将(2)式转化为(3)式。(jensen不等式数学推到比较复杂,知道结果即可)

note:

jensen不等式表述如下:

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

特别地,如果f是严格凸函数,当且仅当x是常量时,上式取等号。参考链接: https://blog.csdn.net/zouxy09/article/details/8537620

至此,上面的式(2)和式(3)不等式可以写成:似然函数l(θ)>=j(z,q),那么我们可以通过不断的最大化这个下界j(z,q)函数,来使得l(θ)不断提高,最终达到它的最大值。

现在,我们推导出了在固定参数θ后,使下界拉升的q(z)的计算公式就是后验概率,解决了q(z)如何选择的问题。这一步就是e步,建立l(θ)的下界。接下来的m步,就是在给定q(z)后,调整θ,去极大化l(θ)的下界j(在固定q(z)后,下界还可以调整的更大)。

总结而言

em算法是一种从不完全数据或有数据丢失的数据集(存在隐藏变量)中,求解概率模型参数的最大似然估计方法。

em的算法流程:

1>初始化分布参数θ;

重复2>, 3>直到收敛:

2>e步骤(expectation):根据参数初始值或上一次迭代的模型参数来计算出隐性变量的后验概率,其实就是隐性变量的期望。作为隐藏变量的现估计值:

高斯混合模型与EM算法图文详解

3>m步骤(maximization):将似然函数最大化以获得新的参数值:

高斯混合模型与EM算法图文详解

这个不断迭代的过程,最终会让e、m步骤收敛,得到使似然函数l(θ)最大化的参数θ。

在l(θ)的收敛证明:

高斯混合模型与EM算法图文详解

 总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注服务器之家的更多内容!

原文链接:https://blog.csdn.net/weixin_38206214/article/details/81064625

延伸 · 阅读

精彩推荐
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7482021-02-04
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17