码迷,mamicode.com
首页 > 其他好文 > 详细

数据挖掘算法学习(三)NaiveBayes算法

时间:2014-07-28 16:17:13      阅读:412      评论:0      收藏:0      [点我收藏+]

标签:数据挖掘   机器学习   naivebayes   垃圾邮件   

算法简介

NBC是应用最广的分类算法之一。朴素贝叶斯模型发源于古典数学理论,有着坚实的数学基础,以及稳定的分类效率。同时,NBC模型所需估计的参数很少,对缺失数据不太敏感,算法也比较简单

算法假设

给定目标值时属性之间互相条件独立。

算法输入

训练数据   T={(x1,y1),(x2,y2),……,(xn,yn)}
待分类数据x0=(x0(1),x0(2),……,x0(n))T

算法输出
待分类数据
x0的分类结果y0∈{c1,c2,……,ck}

算法思想
bubuko.com,布布扣
bubuko.com,布布扣

weka运行
以weather.nominal.arff为例运行结果部分截图如下:
bubuko.com,布布扣
bubuko.com,布布扣
从结果中可以看出,有两个分类,因此生成一个2*2的混淆矩阵。

函数调用代码

//读入样本

Filefile= new File("F:\\Program Files (x86)\\Weka-3-7\\data\\weather.nominal.arff");

ArffLoaderloader = newArffLoader();

loader.setFile(file);

ins= loader.getDataSet();

ins.setClassIndex(ins.numAttributes()-1);

//初始化分类器并训练

 cfs= (Classifier)Class.forName("weka.classifiers.bayes.NaiveBayes").newInstance();

cfs.buildClassifier(ins);

//获取分类器结果

testingEvaluation.evaluateModelOnceAndRecordPrediction(cfs,testInst);

//打印分类结果

System.out.println("分类器的正确率:"+ (1-testingEvaluation.errorRate()));


运行结果如下:

分类器的正确率:0.9583333333333334


算法应用

?垃圾邮件过滤系统
?分类web网页
?分类文本

垃圾邮件过滤系统可以参考论文:周威成 马素霞 齐林海,一种基于机器学习的垃圾邮件智能过滤方法。


原创文章,转载请注明出处,谢谢。



数据挖掘算法学习(三)NaiveBayes算法,布布扣,bubuko.com

数据挖掘算法学习(三)NaiveBayes算法

标签:数据挖掘   机器学习   naivebayes   垃圾邮件   

原文地址:http://blog.csdn.net/iemyxie/article/details/38224753

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