Weka里面各种分类器的使用(Java)

1.配置

MyEclipse2013+Weka3.6+libsvm3.18+Jdk1.7+Win8.1

2.Tips

1). Java使用Weka

实现:

将安装文件夹里的weka.jar加入项目编译路径中

2). CSV文件可以转换成Arff文件

实现:

运行WekaExplorer界面,打开csv文件,保存为arff文件。

注意:

如果有训练集和测试集,将训练集的Arff文件的标签头复制到测试集的Arff文件!

3). Java通过Weka使用LibSVM

实现:

LibSVM文件夹里的libsvm.jar加入项目编译路径中

3.示例

public static void main(String[] args) {

       try {

          

           Classifier classifier1;

           Classifier classifier2;

           Classifier classifier3;

           Classifier classifier4;

 

           File inputFile = new File(

            "C:\\Users\\zhangzhizhi\\Documents\\Everyone\\张志智\\总结积累\\Weka\\change_train.arff");// 训练语料文件

           ArffLoader atf = new ArffLoader();

           atf.setFile(inputFile);

           Instances instancesTrain = atf.getDataSet(); // 读入训练文件

          

           inputFile = new File(

           "C:\\Users\\zhangzhizhi\\Documents\\Everyone\\张志智\\总结积累\\Weka\\change_test.arff");// 测试语料文件

           atf.setFile(inputFile);

           Instances instancesTest = atf.getDataSet(); // 读入测试文件     

           instancesTest.setClassIndex(0);

           instancesTrain.setClassIndex(0);

        

           // 朴素贝叶斯算法

           classifier1 = (Classifier) Class.forName(

                  "weka.classifiers.bayes.NaiveBayes").newInstance();

           // 决策树

           classifier2 = (Classifier) Class.forName(

                  "weka.classifiers.trees.J48").newInstance();

           // Zero

           classifier3 = (Classifier) Class.forName(

                  "weka.classifiers.rules.ZeroR").newInstance();

           // LibSVM

           classifier4 = (Classifier) Class.forName(

                  "weka.classifiers.functions.LibSVM").newInstance();

  

           classifier4.buildClassifier(instancesTrain);

           classifier1.buildClassifier(instancesTrain);

           classifier2.buildClassifier(instancesTrain);

           classifier3.buildClassifier(instancesTrain);

                   

           Evaluation eval = new Evaluation(instancesTrain);         

           eval.evaluateModel(classifier4, instancesTest);

           System.out.println(eval.errorRate());

           eval.evaluateModel(classifier1, instancesTest);

           System.out.println(eval.errorRate());

           eval.evaluateModel(classifier2, instancesTest);

           System.out.println(eval.errorRate());

           eval.evaluateModel(classifier3, instancesTest);

           System.out.println(eval.errorRate());

       } catch (Exception e) {

           e.printStackTrace();

       }

    }

如果只有训练集,采用十交叉验证的方法,将上面的第5步和第6步更改为如下代码:

          

           Evaluation eval = new Evaluation(instancesTrain);

           eval.crossValidateModel(classifier4, instancesTrain, 10, new Random(1));

           System.out.println(eval.errorRate());

           eval.crossValidateModel(classifier1, instancesTrain, 10, new Random(1));

           System.out.println(eval.errorRate());

           eval.crossValidateModel(classifier2, instancesTrain, 10, new Random(1));

           System.out.println(eval.errorRate());

           eval.crossValidateModel(classifier3, instancesTrain, 10, new Random(1));

           System.out.println(eval.errorRate());

如果需要保存和加载分类器模型参数,在第5步和第6步之间加入如下代码:

          

           SerializationHelper.write("LibSVM.model", classifier4);

           SerializationHelper.write("NaiveBayes.model", classifier1);

           SerializationHelper.write("J48.model", classifier2);

           SerializationHelper.write("ZeroR.model", classifier3);

          

           Classifier classifier8 = (Classifier) weka.core.SerializationHelper.read("LibSVM.model");

           Classifier classifier5 = (Classifier) weka.core.SerializationHelper.read("NaiveBayes.model");

           Classifier classifier6 = (Classifier) weka.core.SerializationHelper.read("J48.model");

           Classifier classifier7 = (Classifier) weka.core.SerializationHelper.read("ZeroR.model");


  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WEKA是一个流行的机学习工具,而Shapelet分类是一种特殊的时间序列分类算法。在Python中,可以使用weka库来调用WEKA和Shapelet分类。 首先,确保已经安装了weka库。可以使用pip命令进行安装: ``` pip install python-weka-wrapper3 ``` 接下来,我们将使用weka库来调用WEKA和Shapelet分类。以下是一个示例代码: ```python import weka.core.jvm as jvm from weka.core.converters import Loader from weka.classifiers import Classifier from weka.classifiers import Evaluation # 启动JVM jvm.start() # 加载数据集 loader = Loader(classname="weka.core.converters.ArffLoader") data = loader.load_file("data.arff") data.class_is_last() # 构建Shapelet分类 classifier = Classifier(classname="weka.classifiers.lazy.DTW_1NN") classifier.build_classifier(data) # 进行交叉验证评估 evaluation = Evaluation(data) evaluation.crossvalidate_model(classifier, data, 10, Random(1)) # 输出评估结果 print(evaluation.summary()) # 关闭JVM jvm.stop() ``` 在上述代码中,我们首先启动了WEKAJava虚拟机(JVM)。然后,使用weka库中的Loader类加载数据集。接着,使用Classifier类构建Shapelet分类,并使用build_classifier方法训练模型。最后,使用Evaluation类进行交叉验证评估,并输出评估结果。 请注意,上述代码中的"data.arff"是一个示例数据集的文件名。你需要将代码中的数据集文件名替换为你自己的数据集文件名,并确保数据集的格式正确。 这样,你就可以使用weka库调用WEKA和Shapelet分类进行时间序列分类任务了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值