朴素贝叶斯算法的python实现方法

本文实例讲述了朴素贝叶斯算法的python实现方法。分享给大家供大家参考。具体实现方法如下:

朴素贝叶斯算法优缺点

优点:在数据较少的情况下依然有效,可以处理多类别问题

缺点:对输入数据的准备方式敏感

适用数据类型:标称型数据

算法思想:

比如我们想判断一个邮件是不是垃圾邮件,那么我们知道的是这个邮件中的词的分布,那么我们还要知道:垃圾邮件中某些词的出现是多少,就可以利用贝叶斯定理得到。

朴素贝叶斯分类器中的一个假设是:每个特征同等重要

函数

loadDataSet()

创建数据集,这里的数据集是已经拆分好的单词组成的句子,表示的是某论坛的用户评论,标签1表示这个是骂人的

createVocabList(dataSet)

找出这些句子中总共有多少单词,以确定我们词向量的大小

setOfWords2Vec(vocabList, inputSet)

将句子根据其中的单词转成向量,这里用的是伯努利模型,即只考虑这个单词是否存在

bagOfWords2VecMN(vocabList,
inputSet)

这个是将句子转成向量的另一种模型,多项式模型,考虑某个词的出现次数

trainNB0(trainMatrix,trainCatergory)

计算P(i)和P(w[i]|C[1])和P(w[i]|C[0]),这里有两个技巧,一个是开始的分子分母没有全部初始化为0是为了防止其中一个的概率为0导致整体为0,另一个是后面乘用对数防止因为精度问题结果为0

classifyNB(vec2Classify, p0Vec, p1Vec,
pClass1)

根据贝叶斯公式计算这个向量属于两个集合中哪个的概率高

代码如下:

#coding=utf-8

from numpy import *

def loadDataSet():

   
postingList=[['my', 'dog', 'has', 'flea', 'problems', 'help',
'please'],

                
['maybe', 'not', 'take', 'him', 'to', 'dog', 'park',
'stupid'],

                
['my', 'dalmation', 'is', 'so', 'cute', 'I', 'love', 'him'],

                
['stop', 'posting', 'stupid', 'worthless', 'garbage'],

                
['mr', 'licks', 'ate', 'my', 'steak', 'how', 'to', 'stop',
'him'],

                
['quit', 'buying', 'worthless', 'dog', 'food', 'stupid']]

    classVec =
[0,1,0,1,0,1]   
#1 is abusive, 0 not

    return
postingList,classVec

#创建一个带有所有单词的列表

def createVocabList(dataSet):

    vocabSet =
set([])

    for document
in dataSet:

       
vocabSet = vocabSet | set(document)

    return
list(vocabSet)

   

def setOfWords2Vec(vocabList, inputSet):

    retVocabList
= [0] * len(vocabList)

    for word in
inputSet:

       
if word in vocabList:

           
retVocabList[vocabList.index(word)] = 1

       
else:

           
print 'word ',word ,'not in dict'

    return
retVocabList

#另一种模型   

def bagOfWords2VecMN(vocabList, inputSet):

    returnVec =
[0]*len(vocabList)

    for word in
inputSet:

       
if word in vocabList:

           
returnVec[vocabList.index(word)] = 1

    return
returnVec

def trainNB0(trainMatrix,trainCatergory):

    numTrainDoc
= len(trainMatrix)

    numWords =
len(trainMatrix[0])

    pAbusive =
sum(trainCatergory)/float(numTrainDoc)

   
#防止多个概率的成绩当中的一个为0

    p0Num =
ones(numWords)

    p1Num =
ones(numWords)

    p0Denom =
2.0

    p1Denom =
2.0

    for i in
range(numTrainDoc):

       
if trainCatergory[i] == 1:

           
p1Num =trainMatrix[i]

           
p1Denom = sum(trainMatrix[i])

       
else:

           
p0Num =trainMatrix[i]

           
p0Denom = sum(trainMatrix[i])

    p1Vect =
log(p1Num/p1Denom)#处于精度的考虑,否则很可能到限归零

    p0Vect =
log(p0Num/p0Denom)

    return
p0Vect,p1Vect,pAbusive

   

def classifyNB(vec2Classify, p0Vec, p1Vec, pClass1):

    p1 =
sum(vec2Classify * p1Vec)
log(pClass1)   
#element-wise mult

    p0 =
sum(vec2Classify * p0Vec) log(1.0 - pClass1)

    if p1
> p0:

       
return 1

    else:

       
return 0

def testingNB():

   
listOPosts,listClasses = loadDataSet()

    myVocabList
= createVocabList(listOPosts)

   
trainMat=[]

    for
postinDoc in listOPosts:

       
trainMat.append(setOfWords2Vec(myVocabList, postinDoc))

    p0V,p1V,pAb
= trainNB0(array(trainMat),array(listClasses))

    testEntry =
['love', 'my', 'dalmation']

    thisDoc =
array(setOfWords2Vec(myVocabList, testEntry))

    print
testEntry,'classified as: ',classifyNB(thisDoc,p0V,p1V,pAb)

    testEntry =
['stupid', 'garbage']

    thisDoc =
array(setOfWords2Vec(myVocabList, testEntry))

    print
testEntry,'classified as: ',classifyNB(thisDoc,p0V,p1V,pAb)

   

   

def main():

   
testingNB()

   

if __name__ == '__main__':

    main()

希望本文所述对大家的Python程序设计有所帮助。

朴素贝叶斯算法的python实现方法的更多相关文章

  1. 朴素贝叶斯算法的python实现

    朴素贝叶斯 算法优缺点 优点:在数据较少的情况下依然有效,可以处理多类别问题 缺点:对输入数据的准备方式敏感 适用数据类型:标称型数据 算法思想: 朴素贝叶斯比如我们想判断一个邮件是不是垃圾邮件,那么 ...

  2. 朴素贝叶斯算法的python实现-乾颐堂

    算法优缺点 优点:在数据较少的情况下依然有效,可以处理多类别问题 缺点:对输入数据的准备方式敏感 适用数据类型:标称型数据 算法思想: 朴素贝叶斯 比如我们想判断一个邮件是不是垃圾邮件,那么我们知道的 ...

  3. 朴素贝叶斯算法的python实现 -- 机器学习实战

    import numpy as np import re #词表到向量的转换函数 def loadDataSet(): postingList = [['my', 'dog', 'has', 'fle ...

  4. 朴素贝叶斯算法原理及Spark MLlib实例(Scala/Java/Python)

    朴素贝叶斯 算法介绍: 朴素贝叶斯法是基于贝叶斯定理与特征条件独立假设的分类方法. 朴素贝叶斯的思想基础是这样的:对于给出的待分类项,求解在此项出现的条件下各个类别出现的概率,在没有其它可用信息下,我 ...

  5. 朴素贝叶斯算法--python实现

    朴素贝叶斯算法要理解一下基础:    [朴素:特征条件独立   贝叶斯:基于贝叶斯定理] 1朴素贝叶斯的概念[联合概率分布.先验概率.条件概率**.全概率公式][条件独立性假设.]   极大似然估计 ...

  6. Python机器学习笔记:朴素贝叶斯算法

    朴素贝叶斯是经典的机器学习算法之一,也是为数不多的基于概率论的分类算法.对于大多数的分类算法,在所有的机器学习分类算法中,朴素贝叶斯和其他绝大多数的分类算法都不同.比如决策树,KNN,逻辑回归,支持向 ...

  7. Python机器学习算法 — 朴素贝叶斯算法(Naive Bayes)

    朴素贝叶斯算法 -- 简介 朴素贝叶斯法是基于贝叶斯定理与特征条件独立假设的分类方法.最为广泛的两种分类模型是决策树模型(Decision Tree Model)和朴素贝叶斯模型(Naive Baye ...

  8. 机器学习:python中如何使用朴素贝叶斯算法

    这里再重复一下标题为什么是"使用"而不是"实现": 首先,专业人士提供的算法比我们自己写的算法无论是效率还是正确率上都要高. 其次,对于数学不好的人来说,为了实 ...

  9. 机器学习---用python实现朴素贝叶斯算法(Machine Learning Naive Bayes Algorithm Application)

    在<机器学习---朴素贝叶斯分类器(Machine Learning Naive Bayes Classifier)>一文中,我们介绍了朴素贝叶斯分类器的原理.现在,让我们来实践一下. 在 ...

随机推荐

  1. 天道神诀---防火墙以及selinux(上篇)

    Linux防火墙 linux6.x 防火墙会影响通信,默认是拒绝所有. [root@redhat6 sysconfig]# chkconfig iptables --listiptables      ...

  2. Codeforces Round #525 D - Ehab and another another xor problem /// 构造

    题目大意: 本题有两个隐藏起来的a b(1<=a,b<=1e30) 每次可 printf("? %d %d\n",c,d); 表示询问 a^c 与 b^d 的相对大小 ...

  3. USACO2012 Haybale stacking /// 区间表示法 oj21556

    题目大意:N个方块 标号1~N  K个操作 操作a b 表示标号a~b区间每位多加一个方块 Input * Line 1: Two space-separated integers, N  K. * ...

  4. 【POJ】1182 食物链

    这是<挑战设计程序竞赛>中的例题. 题目链接:http://poj.org/problem?id=1182 题意:中文题面.不赘述. 题解: 代码: //带权并查集 #include< ...

  5. JS事件 失焦事件(onblur)onblur事件与onfocus是相对事件,当光标离开当前获得聚焦对象的时候,触发onblur事件,同时执行被调用的程序。

    失焦事件(onblur) onblur事件与onfocus是相对事件,当光标离开当前获得聚焦对象的时候,触发onblur事件,同时执行被调用的程序. 如下代码, 网页中有用户和密码两个文本框.当前光标 ...

  6. [JZOJ3339]【NOI2013模拟】wyl8899和法法塔的游戏

    题目 题目大意 给你一个数列,每次给出\(r,a,b\),你要找到\(l\in [a,b]\)使得\([l,r-1]\)的异或和最小, 并且要修改\(r\)位置的数. 思考历程 当我看到这题的时候,已 ...

  7. 期望dp+高斯消元——bzoj3143

    比较经典的题,题解看网上的..https://www.cnblogs.com/GXZlegend/p/7054536.html 自己sort弄错了..还以为是高斯消元写歪了.. #include< ...

  8. Ubuntu下github pages+hexo搭建自己的博客

    hexo 是一个基于Node.js的静态博客程序,可以方便的生成静态网页托管在github上.Hexo简单优雅, 而且风格多变, 适合搭建个人博客,而且支持多平台的搭建. 平台 Ubuntu14.04 ...

  9. window.location 对象中各种方法的用途

    一.简介 属性 描述 hash 从井号 (#) 开始的 URL(锚) host 主机名和当前 URL 的端口号 hostname 当前 URL 的主机名 href 完整的 URL pathname 当 ...

  10. 牛客多校第五场 G subsequence 1 最长公共子序列/组合数

    题意: 给定两个由数字组成的序列s,t,找出s所有数值大于t的子序列.注意不是字典序大. 题解: 首先特判s比t短或一样长的情况. 当s比t长时,直接用组合数计算s不以0开头的,长度大于t的所有子序列 ...