机器学习(西瓜书)7、贝叶斯分类器(上)

贝叶斯分类器是一种概率框架下的统计学习分类器,对分类任务而言,假设在相关概率都已知的情况下,贝叶斯分类器考虑如何基于这些概率为样本判定最优的类标。在开始介绍贝叶斯决策论之前,我们首先来回顾下贝叶斯公式

机器学习(西瓜书)7、贝叶斯分类器(上)_第1张图片

7.1 贝叶斯决策论

若将上述定义中样本空间的划分Bi看做为类标,A看做为一个新的样本,则很容易将条件概率理解为样本A是类别Bi的概率。在机器学习训练模型的过程中,往往我们都试图去优化一个风险函数,因此在概率框架下我们也可以为贝叶斯定义“条件风险”(conditional risk)。(真实标记Cj,误分类Ci)

机器学习(西瓜书)7、贝叶斯分类器(上)_第2张图片

 我们的任务就是寻找一个判定准则最小化所有样本的条件风险总和,因此就有了贝叶斯判定准则(Bayes decision rule):为最小化总体风险,只需在每个样本上选择那个使得条件风险最小的类标。

若损失函数λ取0-1损失,则有:

机器学习(西瓜书)7、贝叶斯分类器(上)_第3张图片

即对于每个样本x,选择其后验概率P(c | x)最大所对应的类标,能使得总体风险函数最小,从而将原问题转化为估计后验概率P(c | x)。一般这里有两种策略来对后验概率进行估计:

* 判别式模型:直接对 P(c | x)进行建模求解。例我们前面所介绍的决策树、神经网络、SVM都是属于判别式模型。  
* 生成式模型:通过先对联合分布P(x,c)建模,从而进一步求解 P(c | x)。  

贝叶斯分类器就属于生成式模型,基于贝叶斯公式对后验概率P(c | x) 进行变换:

机器学习(西瓜书)7、贝叶斯分类器(上)_第4张图片

对于给定的样本x,P(x)与类标无关,P(c)称为类先验概率,p(x | c )称为类条件概率。这时估计后验概率P(c | x)就变成为估计类先验概率和类条件概率的问题。对于先验概率和后验概率,这里普及一下它们的基本概念。

* 先验概率:根据以往经验和分析得到的概率。  
* 后验概率:后验概率是基于新的信息,修正原来的先验概率后所获得的更接近实际情况的概率估计。  

实际上先验概率就是在没有任何结果出来的情况下估计的概率,而后验概率则是在有一定依据后的重新估计,直观意义上后验概率就是条件概率。下面直接上Wiki上的一个例子,简单粗暴快速完事...

机器学习(西瓜书)7、贝叶斯分类器(上)_第5张图片

回归正题,对于类先验概率P(c),p(c)就是样本空间中各类样本所占的比例,根据大数定理(当样本足够多时,频率趋于稳定等于其概率),这样当训练样本充足时,p(c)可以使用各类出现的频率来代替。因此只剩下类条件概率p(x | c ),它表达的意思是在类别c中出现x的概率,它涉及到属性的联合概率问题,若只有一个离散属性还好,当属性多时采用频率估计起来就十分困难,因此这里一般采用极大似然法进行估计。

7.2 极大似然法

极大似然估计(Maximum Likelihood Estimation,简称MLE),是一种根据数据采样来估计概率分布的经典方法。常用的策略是先假定总体具有某种确定的概率分布,再基于训练样本对概率分布的参数进行估计。运用到类条件概率p(x | c )中,假设p(x | c )服从一个参数为θ的分布,问题就变为根据已知的训练样本来估计θ。极大似然法的核心思想就是:估计出的参数使得已知样本出现的概率最大,即使得训练数据的似然最大。

机器学习(西瓜书)7、贝叶斯分类器(上)_第6张图片

所以,贝叶斯分类器的训练过程就是参数估计。总结最大似然法估计参数的过程,一般分为以下四个步骤:

* 1.写出似然函数;  
* 2.对似然函数取对数,并整理;  
* 3.求导数,令偏导数为0,得到似然方程组;  
* 4.解似然方程组,得到所有参数即为所求。  

例如:假设样本属性都是连续值,p(x | c )服从一个多维高斯分布,则通过MLE计算出的参数刚好分别为:

机器学习(西瓜书)7、贝叶斯分类器(上)_第7张图片

上述结果看起来十分合乎实际,但是采用最大似然法估计参数的效果很大程度上依赖于作出的分布假设是否合理,是否符合潜在的真实数据分布。这就需要大量的经验知识,搞统计越来越值钱也是这个道理,大牛们掐指一算比我们搬砖几天更有效果。

7.3 朴素贝叶斯分类器

不难看出:原始的贝叶斯分类器最大的问题在于联合概率密度函数的估计,首先需要根据经验来假设联合概率分布,其次当属性很多时,训练样本往往覆盖不够,参数的估计会出现很大的偏差。为了避免这个问题,朴素贝叶斯分类器(naive Bayes classifier)采用了“属性条件独立性假设”,即样本数据的所有属性之间相互独立。这样类条件概率p(x | c )可以改写为:

 这样,为每个样本估计类条件概率变成为每个样本的每个属性估计类条件概率。

对于所有的类别P(x)相同,则贝叶斯判定准则(用于最小化所有样本的条件风险总和)为:

机器学习(西瓜书)7、贝叶斯分类器(上)_第8张图片

 这就是朴素贝叶斯分类选择器的表达式。

朴素贝叶斯分类器的训练过程就是基于训练集 D 来估计类先验概率P(c) , 并为每个属性估计条件概率 P(Xi I C)。

令 Dc 表示训练集D 中第 c 类样本组成的集合,若有充足的独立同分布样本,则可容易地估计出类先验概率:

机器学习(西瓜书)7、贝叶斯分类器(上)_第9张图片

相比原始贝叶斯分类器,朴素贝叶斯分类器基于单个的属性计算类条件概率更加容易操作,需要注意的是:若某个属性值在训练集中和某个类别没有一起出现过,这样会抹掉其它的属性信息,因为该样本的类条件概率被计算为0。因此在估计概率值时,常常用进行平滑(smoothing)处理,拉普拉斯修正(Laplacian correction)就是其中的一种经典方法,具体计算方法如下:

机器学习(西瓜书)7、贝叶斯分类器(上)_第10张图片

当训练集越大时,拉普拉斯修正引入的影响越来越小。

现实任务中:

  • 对于贝叶斯分类器,若任务对预测速度要求较高,模型的训练就是参数估计,因此可以事先将所有的概率储存好,当有新样本需要判定时,直接查表计算即可。
  • 若任务数据更替频繁,则可采用"懒惰学习" (lazy learning) 方式,先不进行任何训练, 待收到预测请求时再根据当前数据集进行概率估值。
  • 若数据不断增加,则可在现有估值基础上,仅对新增样本的属性值所涉及的概率估值进行计数修正即可实现增量学习.

你可能感兴趣的:(机器学习,机器学习,概率论,python)