机器学习和生物信息学实验室联盟

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 5376|回复: 1
打印 上一主题 下一主题

eclipse中Java程序调用weka

[复制链接]
跳转到指定楼层
楼主
发表于 2011-3-7 20:42:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
要使用程序方式使用weka,步骤如下:
一、在eclipse里新建一个java project:
1.      建立工程:单击菜单中file->new->java project,在弹出对话框的project name中起任意一个名字,此处假设是wekaTest。单击Finish按钮(在对话框底部)。
2.      建立package:在package Explorer中找到刚才新建的工程,在其上右键->New->package。在Name文本框里面输入名称,此处假设为Test。单击Finish按钮。
3.      建立程序文件:在刚才新建的package上面右键->New->class,选中public static void main(String[] args)多选框,单击Finish。
二、在该工程中添加weka的引用:
1.    package Explorer中工程名上右键,选择弹出菜单最后一项properties->在左面选中java Build Path->在右面的Library页面->单击Add External JARs…->浏览weka所在目录,将weka.jar添加进来,然后单击ok。
2.      在package Explorer中在双击Test文件,然后在package wekaTest;一句下面添加四句代码:
import java.io.File;
import weka.classifiers.Classifier;
import weka.classifiers.trees.J48;
import weka.core.Instances;
import weka.core.converters.ArffLoader;
三、在程序中添加weka调用代码:
将以下代码添加到Main函数中(在// TODO Auto-generated method stub下面):
    Classifier m_classifier = new J48();
        File inputFile = new File("D:\\Program Files\\Weka-3-6\\data\\cpu.with.vendor.arff");//训练语料文件
        ArffLoader atf = new ArffLoader();
        atf.setFile(inputFile);
        Instances instancesTrain = atf.getDataSet(); // 读入训练文件   
        inputFile = new File("D:\\Program Files\\Weka-3-6\\data\\cpu.with.vendor.arff");//测试语料文件
        atf.setFile(inputFile);         
        Instances instancesTest = atf.getDataSet(); // 读入测试文件
        instancesTest.setClassIndex(0); //设置分类属性所在行号(第一行为0号),instancesTest.numAttributes()可以取得属性总数
        double sum = instancesTest.numInstances(),//测试语料实例数
        right = 0.0f;
        instancesTrain.setClassIndex(0);
         m_classifier.buildClassifier(instancesTrain); //训练           
        for(int  i = 0;i<sum;i++)//测试分类结果
        {
            if(m_classifier.classifyInstance(instancesTest.instance(i))==instancesTest.instance(i).classValue())//如果预测值和答案值相等(测试语料中的分类列提供的须为正确答案,结果才有意义)
            {
              right++;//正确值加1
            }
        }
        System.out.println("J48 classification precision:"+(right/sum));
四、运行一下试试。
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享
回复

使用道具 举报

沙发
发表于 2012-9-27 17:01:38 | 只看该作者
  1. package com.endual.paper.service.impls;
  2. import weka.attributeSelection.*;
  3. import weka.core.*;
  4. import weka.core.converters.ConverterUtils.*;
  5. import weka.classifiers.*;
  6. import weka.classifiers.meta.*;
  7. import weka.classifiers.trees.*;
  8. import weka.filters.*;

  9. import java.util.*;

  10. /**
  11. * performs attribute selection using CfsSubsetEval and GreedyStepwise
  12. * (backwards) and trains J48 with that. Needs 3.5.5 or higher to compile.
  13. *
  14. * @author FracPete (fracpete at waikato dot ac dot nz)
  15. */
  16. public class AttributeSelectionTest {

  17.   /**
  18.    * uses the meta-classifier
  19.    */
  20.   protected static void useClassifier(Instances data) throws Exception {
  21.     System.out.println("\n1. Meta-classfier");
  22.     AttributeSelectedClassifier classifier = new AttributeSelectedClassifier();
  23.     CfsSubsetEval eval = new CfsSubsetEval();
  24.     GreedyStepwise search = new GreedyStepwise();
  25.     search.setSearchBackwards(true);
  26.     J48 base = new J48();
  27.     classifier.setClassifier(base);
  28.     classifier.setEvaluator(eval);
  29.     classifier.setSearch(search);
  30.     Evaluation evaluation = new Evaluation(data);
  31.     evaluation.crossValidateModel(classifier, data, 10, new Random(1));
  32.     System.out.println(evaluation.toSummaryString());
  33.   }

  34.   /**
  35.    * uses the filter
  36.    */
  37.   protected static void useFilter(Instances data) throws Exception {
  38.     System.out.println("\n2. Filter");
  39.     weka.filters.supervised.attribute.AttributeSelection filter = new weka.filters.supervised.attribute.AttributeSelection();
  40.     CfsSubsetEval eval = new CfsSubsetEval();
  41.     GreedyStepwise search = new GreedyStepwise();
  42.     search.setSearchBackwards(true);
  43.     filter.setEvaluator(eval);
  44.     filter.setSearch(search);
  45.     filter.setInputFormat(data);
  46.     Instances newData = Filter.useFilter(data, filter);
  47.     System.out.println(newData);
  48.   }

  49.   /**
  50.    * uses the low level approach
  51.    */
  52.   protected static void useLowLevel(Instances data) throws Exception {
  53.     System.out.println("\n3. Low-level");
  54.     AttributeSelection attsel = new AttributeSelection();
  55.     CfsSubsetEval eval = new CfsSubsetEval();
  56.     GreedyStepwise search = new GreedyStepwise();
  57.     search.setSearchBackwards(true);
  58.     attsel.setEvaluator(eval);
  59.     attsel.setSearch(search);
  60.     attsel.SelectAttributes(data);
  61.     int[] indices = attsel.selectedAttributes();
  62.     System.out.println("selected attribute indices (starting with 0):\n" + Utils.arrayToString(indices));
  63.   }

  64.   /**
  65.    * takes a dataset as first argument
  66.    *
  67.    * @param args        the commandline arguments
  68.    * @throws Exception  if something goes wrong
  69.    */
  70.   public static void main(String[] args) throws Exception {
  71.        
  72.          args = new String[1] ;
  73.          args[0] = "weka_data\\data\\src_data\\paper.arff" ; //导入文件
  74.           
  75.     // load data
  76.     System.out.println("\n0. Loading data");
  77.     DataSource source = new DataSource(args[0]);
  78.     Instances data = source.getDataSet();
  79.     if (data.classIndex() == -1)
  80.       data.setClassIndex(data.numAttributes() - 1);

  81.     // 1. meta-classifier
  82.     useClassifier(data);

  83.     // 2. filter
  84.     useFilter(data);

  85.     // 3. low-level
  86.     useLowLevel(data);
  87.   }
  88. }
复制代码
我这个是网上抄来的,有分类,过滤属性,降低维度的调用代码,仅供参考。

回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

机器学习和生物信息学实验室联盟  

GMT+8, 2024-5-19 04:18 , Processed in 0.064887 second(s), 18 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表