基于weka数据分类分析实验报告Word文档格式.docx
《基于weka数据分类分析实验报告Word文档格式.docx》由会员分享,可在线阅读,更多相关《基于weka数据分类分析实验报告Word文档格式.docx(13页珍藏版)》请在冰豆网上搜索。
然后,打开Weka的Exporler,点击Openfile按钮,打开刚才得到的“total_data”文件,点击“save”按钮,在弹出的对话框中,文件名输入“total_data”,文件类型选择“Arffdatafiles(*.arff)”,这样得到的数据文件为“total_data.arff”。
2.2如何建立数据训练集,校验集和测试集
数据的预处理过程中,为了在训练模型、评价模型和使用模型对数据进行预测能保证一致性和完整性,首先要把movie_given.xslx和test.xslx合并在一起,因为在生成arff文件的时候,可能会出现属性值不一样的情况,否则将为后来的测试过程带来麻烦。
通过统计数据信息,发现带有类标号的数据一共有100行,为了避免数据的过度拟合,必须把数据训练集和校验集分开,目前的拆分策略是各50行。
类标号为‘female’的数据有21条,而类标号为‘male’的数据有79条,这样目前遇到的问题是,究竟如何处理仅有的21条female数据?
为了能在训练分类模型时有更全面的信息,所以决定把包含21条female类标号数据和29条male类标号数据作为模型训练数据集,而剩下的另49条类标号类male的数据将全部用于校验数据集,这是因为在校验的时候,两种类标号的数据的作用区别不大,而在训练数据模型时,则更需要更全面的信息,特别是不同类标号的数据的合理比例对训练模型的质量有较大的影响。
2.3预处理具体步骤
第一步:
合并movie_given.xlsx和test.xlsx,保存为total_data.xlsx;
第二步:
在total_data.xlsx中删除多余的ID列信息;
第三步:
在excel中打开“total_data.xlsx”,选择菜单文件->
另存为,在弹出的对话框中,文件名输入“total_data”,保存类型选择“CSV(逗号分隔)”;
第四步:
使用UltraEdit工具把total_data.csv中的数据缺失部分补上全局常量‘?
’;
第五步:
打开Weka的Exporler,点击Openfile按钮,打开刚才得到的“total_data.csv”文件,点击“save”按钮,在弹出的对话框中,文件名输入“total_data”,文件类型选择“Arffdatafiles(*.arff)”,这样得到的数据文件为“total_data.arff”。
第六步:
从total_data.arff文件里面剪切所有没有分类标号的数据作为预测数据集(test.arff),共26项。
第七步:
把剩下含有类标号数据的total_data.arff文件复制一份,作为总的训练数据集。
文件名称为build_model.arff。
第八步:
从total_data.arff文件中剩下的数据里面选取所有分类标号为male的49行数据作为校验数据集(validate_data.arff)。
第九步:
从把剩下的total_data.arff文件改名为train_data.arff。
3.实验过程及结果截图
3.1决策树分类
用“Explorer”打开刚才得到的“train-data.arff”,并切换到“Class”。
点“Choose”按钮选择“tree(weka.classifiers.trees.j48)”,这是WEKA中实现的决策树算法。
选择Cross-Validatioinfolds=10,然后点击“start”按钮:
训练数据集训练决策树得出的结果
使用不同配置训练参数,得到的实验数据:
配置不同的叶子节点的实例个数
实例数/叶节点
2
3
4
5
6
准确率
54%
60%
56%
结果分析:
使用决策树时,每个叶子节点最优的实例个数为3。
校验数据集校验决策树得出的结果
初步结果分析:
使用决策树进行分类,对于已知的49个类标号为male的数据都进行了准确的分类,并且达到100%;
虽然是个很好的数据,但是完美背后隐藏了缺陷,是以对female类的低准确率作为代价的,因为这样会说明该分类器很有可能偏向male类。
3.2K最近邻算法分类
点“Choose”按钮选择“laze->
ibk”,这是WEKA中实现的决策树算法。
训练数据集训练KNN得出的结果
K值
1
7
8
9
10
52%
58%
68%
62%
使用KNN算法分类时,K最优值为8。
校验数据集校验KNN得出的结果
对使用k=8训练出来的分类模型进行校验的结果,准确率达到77.6%,算是一个比较合理的分类结果。
3.3朴素贝叶斯分类
点“Choose”按钮选择“bayes”,这是WEKA中实现的决策树算法。
训练数据集训练Naï
veBayes得出的结果
校验数据集校验Naï
评价结果中准确率仅仅达到59.1%,结果不是很让人满意。
3.4三类分类方法的校验结果比较
决策树
K最近邻
朴素贝叶斯
校验准确率
100%
77.55%
59.18%
训练
混淆矩阵
校验
标准误差
0.42
0.4654
0.5918
比较结果分析:
根据上述数据,虽然决策树有最高的完美的准确率和相对较好的标准误差,但是这种完美的背后,很有可能是以类标号female的较大错误率作为代价,这点可以从训练混淆矩阵中得到印证;
而朴素贝叶斯分类算法的准确率相对较低,而标准误差也较高,综合评价可以得知,当前最好的分类算法是KNN算法,并且它是最优设置参数为k=8。
3.5训练最优模型
使用预处理中的buildmodel_data.arff数据文件训练分类模型,算法为k=8的KNN。
数据集训练KNN得出的结果
使用最终模型对测试集进行预测结果
4.三种算法在进行测试的性能比较
4.1实验结果
决策树的测试结果:
KNN测试结果:
朴素贝叶斯测试结果:
比较分析结论:
性能分析应该包括两个部分,一个部分是测试速度,另一个部分是测试的质量。
由于本次使用所使用的数据量太少,在测试速度的对比上相差太少,无法进行准确的分析。
而在测试质量上,可以从上述数据中得到,决策树依然是由于它对与male类标号的偏爱,导致质量的降低;
而KNN与朴素贝叶斯相比,KNN具有较高的准确率,从性能角度上讲,KNN算法略胜一筹。
5.实验总结
本次实验进行比较顺利,使我对如何在Weka中进行分类分析有了更深刻的了解,对Weka中进行分类分析的KNN算法,朴素贝叶斯算法和决策树算法都有了进一步的理解,同时也深刻体会到数据预处理对于数据挖掘的重要性。