码迷,mamicode.com
首页 > 编程语言 > 详细

斯坦福《机器学习》Lesson5感想———2、朴素贝叶斯算法

时间:2015-07-24 13:04:49      阅读:215      评论:0      收藏:0      [点我收藏+]

标签:

     朴素贝叶斯算法与上篇中写到到生成学习算法的思想是一致的。它不需要像线性回归等算法一样去拟合各种假设的可能,只需要计算各种假设的概率,然后选择概率最高的那种假设分类类别。其中还添入了一个贝叶斯假定:在给定目标值y时属性值x之间相互独立。这样的分类算法被称为朴素贝叶斯分类器(Naive Bayes classifier)  。

1、朴素贝叶斯算法

    在朴素贝叶斯算法的模型里,给定的训练集为技术分享, 可计算技术分享技术分享。因为贝叶斯假定,可以计算出联合似然概率函数:

技术分享

最大化联合似然概率函数可得到:

技术分享

然后我们就可以对新的数据进行预测。预测公式为:

技术分享

如果x只取两种值,则p(x|y)服从伯努力分布。如果 x取多种值,则p(x|y)服从多项分布。当x的取值是连续的时候,可以将y值区间离散化,再分别对各个区间分类命名为特定值。

技术分享

2、拉普拉斯平滑

 在给定的训练集技术分享技术分享中,假设x的取值有k种{1,…,k},所以φi = p(z = i)。在未使用拉普拉斯平滑的情况下,

技术分享
而当某一个特征属性x在训练集中未曾出现过,则
技术分享
为了避免此种情况的出现,我们使用拉普拉斯平滑。因此可得到:

技术分享

3、Naive Bayes和Multinomial event model的比较

 在垃圾邮件的分类中,先设定一个垃圾词语字典索引,然后通过对邮件中是否含有垃圾词语字典索引中的词判断一封邮件是垃圾邮件的概率。在Naive Bayes中只需计算每个训练邮件文本中是否含有垃圾词语字典索引中的某一个词来计算垃圾邮件的概率,而在Multinomial event model中需要考虑垃圾字典索引中的某一个词在每个训练邮件文本中出现的次数来计算垃圾邮件的概率。

 例如,一封邮件是“a nip...”,垃圾词语字典索引为{a,....,nip,....}(a为字典中第1个词语,nip为第35000个词语)。所以对于Naive Bayes来说,可表示为如下矩阵(矩阵第1元素为1,第35000个元素也为1)

     技术分享

而在Multinomial event model中,表示为技术分享技术分享。这表示邮件的第1个词语是a,第35000个词语是nip。这样的话,如果邮件中第3个词语是a的话,Naive的表示不变,但是Multinomial event model中的表示会有x3=1。通过这样就可以计算在邮件中每个垃圾字典索引中的词语出现的次数。这样评估的概率比朴素贝叶斯算法的概率更为理想。具体比较如下:技术分享



版权声明:本文为博主原创文章,未经博主允许不得转载。

斯坦福《机器学习》Lesson5感想———2、朴素贝叶斯算法

标签:

原文地址:http://blog.csdn.net/adeleamily/article/details/47035569

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!