boa.aggregators.DecisionTreeAggregator.java Source code

Java tutorial

Introduction

Here is the source code for boa.aggregators.DecisionTreeAggregator.java

Source

/*
 * Copyright 2014, Hridesh Rajan, Robert Dyer,
 *                 and Iowa State University of Science and Technology
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package boa.aggregators;

import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import weka.classifiers.trees.J48;
import weka.core.Attribute;
import weka.core.FastVector;
import weka.core.Instance;
import weka.core.Instances;
import weka.core.Utils;

/**
 * A Boa aggregator for training the model using Decision Tree.
 * 
 * @author ankuraga
 *
 * Modified by @abshakiba
 *
 */
@AggregatorSpec(name = "DecisionTree", formalParameters = { "string" })
public class DecisionTreeAggregator extends MLAggregator {
    private Map<String, List<Double>> vectors = new HashMap<String, List<Double>>();
    private ArrayList<Double> vector = new ArrayList<Double>();
    private String[] options;
    private int count = 0;
    private int inc = 0;
    private J48 model;

    public DecisionTreeAggregator(final String s) {
        super(s);
        try {
            options = Utils.splitOptions(s);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    // TODO: What about metadata?
    public void aggregate(final String data, final String metadata) throws IOException, InterruptedException {
        if (this.count != this.getVectorSize()) {
            this.vector.add(Double.parseDouble(data));
            this.count++;
        }

        if (this.count == this.getVectorSize()) {
            this.vectors.put("Vector " + this.inc, this.vector);
            this.inc++;
            this.vector = new ArrayList<Double>();
            this.count = 0;
        }
    }

    /** {@inheritDoc} */
    @Override
    public void finish() throws IOException, InterruptedException {
        int NumOfAttributes = this.getVectorSize();
        List<Attribute> attributes = new ArrayList<Attribute>();
        FastVector fvAttributes = new FastVector(NumOfAttributes);

        for (int i = 0; i < NumOfAttributes; i++) {
            attributes.add(new Attribute("Attribute" + i));
            fvAttributes.addElement(attributes.get(i));
        }

        Instances trainingSet = new Instances("DecisionTree", fvAttributes, 1);
        trainingSet.setClassIndex(NumOfAttributes - 1);

        for (List<Double> vector : this.vectors.values()) {
            Instance instance = new Instance(NumOfAttributes);
            for (int i = 0; i < vector.size(); i++) {
                instance.setValue((Attribute) fvAttributes.elementAt(i), vector.get(i));
            }
            trainingSet.add(instance);
        }

        try {
            this.model = new J48();
            this.model.setOptions(options);
            this.model.buildClassifier(trainingSet);
        } catch (Exception ex) {
        }

        this.saveModel(this.model);
    }
}