醉了~~~

package edu.dcy.weka;

import java.io.FileWriter;
import java.util.ArrayList;
import java.util.List; import weka.classifiers.Classifier;
import weka.classifiers.Evaluation;
import weka.classifiers.misc.InputMappedClassifier;
import weka.core.Attribute;
import weka.core.Instance;
import weka.core.Instances;
import weka.core.SerializationHelper;
import weka.core.Utils;
import weka.core.converters.ConverterUtils.DataSource; public class PredictModel {
public static void main(String[] args) throws Exception {
if(args.length!=3){
System.err.println("Usage: <model file> <test file > < output dir>");
System.exit(1);
}
// load data
System.out.println("loading data.....");
DataSource dstest = new DataSource(args[1]);
Instances test = dstest.getDataSet();
int attrnums=test.numAttributes();
// lack of the class lable 'Y'
if(attrnums==283){
List<String> strname = new ArrayList<String>();
strname.add("false");
strname.add("true");
Attribute attr = new Attribute("Y", strname);
test.insertAttributeAt(attr, test.numAttributes());
}
test.setClassIndex(test.numAttributes() - 1);
System.out.println("loading done.....");
System.out.println("loading predict model....."); // load classifier
Object objs[]=SerializationHelper.readAll(args[0]);
Classifier cls=(Classifier) objs[0];
InputMappedClassifier mapper =new InputMappedClassifier();
mapper.setClassifier((Classifier) objs[0]);
mapper.setModelHeader((Instances) objs[1]);
mapper.setTestStructure(test);
cls=mapper;
// output predictions
System.out.println("execute ...");
FileWriter fw=new FileWriter(args[2]);
StringBuffer sb=new StringBuffer();
sb.append("#,actual,predicted,error,p_false,p_true \n");
for (int i = 0; i < test.numInstances(); i++) {
Instance ins=test.instance(i);
double pred = cls.classifyInstance(ins);
double[] dist = cls.distributionForInstance(ins); sb.append(i+1).append(",")
.append(ins.toString(test.classIndex()))
.append(",")
.append(test.classAttribute().value((int) pred))
.append(","); if (pred != test.instance(i).classValue()) {
sb.append("yes");
} else {
sb.append("no");
} sb.append(",").append(Utils.arrayToString(dist)).append("\n"); // System.out.println(sb.toString());
fw.write(sb.toString());
fw.flush();
sb.delete(0, sb.length());
}
fw.close(); System.out.println("finished,please check the outfile .....");
// print the summary
if(attrnums==284){
Evaluation eval = new Evaluation(test);
eval.evaluateModel(cls, test);
System.out.println(eval.toClassDetailsString());
System.out.println(eval.toSummaryString());
System.out.println(eval.toMatrixString());
}
}
}

weka属性选择使用的更多相关文章

  1. CSS属性选择符

    属性选择符: E[att] 选择具有att属性的E元素. <style type="text/css"> a[class]{ background-color: red ...

  2. #8.10.16总结# 属性选择符 伪对象选择符 CSS的常用样式

    属性选择符 E[att] E[att="val"] E[att~="val"] E[att^="val"] E[att$="val ...

  3. CSS3初学篇章_3(属性选择符/字体样式/元素样式)

    属性选择符  选择符  说明  E[att]  选择具有att属性的E元素.  E[att="val"]  选择具有att属性且属性值等于val的E元素.  E[att~=&quo ...

  4. CSS3添加属性选择: [attribute*=value] 、[attribute^=value] 和[attribute$=value]

    在CSS3新的 [attribute*=value] .[attribute^=value] 和[attribute$=value] 三个选择.使得属性选择使用通配符概念. 下面是利用这三个属性样本代 ...

  5. 强大的CSS 属性选择符 配合 stylish 屏蔽新浪微博信息流广告

    新建一条微博域名下的规则: @-moz-document domain("weibo.com") { #v6_pl_rightmod_rank,#v6_pl_rightmod_ad ...

  6. Vue实现仿淘宝商品详情属性选择的功能

    Vue实现仿淘宝商品详情属性选择的功能 先看下效果图:(同个属性内部单选,属性与属性之间可以多选) 主要实现过程: 所使用到的数据类型是(一个大数组里面嵌套了另一个数组)具体格式如下:   attrA ...

  7. JQuery 多属性选择节点

    JQuery 1.6.0+以后用prop()代替attr(); 多属性选择节点 $("input[type=checkbox][name='first2'][value='first4']& ...

  8. 前端实现商品sku属性选择

    一.效果图 二.后台返回的数据格式 [{ "saleName": "颜色", "dim": 1, "saleAttrList&qu ...

  9. CSS选择符-----属性选择符

       Element[att] 选择具有att属性的E元素 <!DOCTYPE html> <html> <head> <meta charset=" ...

随机推荐

  1. fatal: Authentication failed (二)

    一.前言 前面一段时间写了一篇解决 git 上传代码出现的权限验证问题,还是没有很好的解决.现在还了方式,具体步骤如下: 二.操作流程 我们在上传代码到服务器,我们都需要安装 Git 版本控制.在安装 ...

  2. struts2学习笔记——第一个struts2应用配置

    说实在的,随着Java学习的不断深入,特别是Java web框架部分,调bug让人很心累,但是每征服一个bug,内心的成就感也是难以言说的.第一个struts2应用的配置,我昨天折腾了快2个小时,最后 ...

  3. 在JAVA中自定义连接数据库的工具类

    为什么要自定义数据库连接的工具类: 在开发中,我们在对数据库进行操作时,必须要先获取数据库的连接,在上一篇随笔中提到的获取数据库连接的步骤为: 1.定义好4个参数并赋值 2.加载驱动类 3.获取数据库 ...

  4. 使用poi导出Excel表格,jar包冲突

    HTTP Status 500 – Internal Server Error Type Exception Report Message Handler processing failed; nes ...

  5. 帝都Day4(1)——还是dp

    其实是day4 一.洛谷P1018 乘积最大 f[i][j]表示前i个数 切成j块 用f[i][j]而不用f[i][j][k](i到j切成k块)呢? Luogu1043 前缀和(好算一段里的数的和)+ ...

  6. 小K的农场 差分约束

    题目描述 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三种形式描述: 农场a比农场b至少多种植了c个单位的作 ...

  7. FZU Problem 2238 Daxia & Wzc's problem

    Daxia在2016年5月期间去瑞士度蜜月,顺便拜访了Wzc,Wzc给他出了一个问题: Wzc给Daxia等差数列A(0),告诉Daxia首项a和公差d; 首先让Daxia求出数列A(0)前n项和,得 ...

  8. 牛客网Java刷题知识点之匿名对象

    不多说,直接上干货! 匿名对象的两种用途: 1.当对象对方法仅进行一次调用的时候,就可以简化成匿名对象. 2.匿名对象可以作为实际参数进行传递. 匿名对象顾名思义就是没有名字的对象. new Car( ...

  9. smarty模板引擎之if, elseif else

    Smarty 中的 if 语句和 php 中的 if 语句一样灵活易用,并增加了几个特性以适宜模板引擎. if 必须于 /if 成对出现. 可以使用 else 和 elseif 子句. 可以使用以下条 ...

  10. pat1061. Dating (20)

    1061. Dating (20) 时间限制 50 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Sherlock Holmes ...