// Distributed Decision making system framework
// Copyright (c) 2014, Jordi Coll Corbilla
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// - Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// - Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// - Neither the name of this library nor the names of its contributors may be
// used to endorse or promote products derived from this software without
// specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
package ddm.factory.classifiers;
/**
*
* @author jordi Corbilla
* Class that executes a Neuronal Network algorithm
*/
public class NeuronalNetworkClassifier extends ClassifierInstance {
private weka.classifiers.functions.MultilayerPerceptron multiLayerPerceptron;
/**
* Method that trains the classifier
*/
@Override
public void TrainClassifier() {
// Load Training data
weka.core.Instances trainingInstances = null;
try {
trainingInstances = new weka.core.Instances(new java.io.FileReader(
getTrainingDataFile()));
} catch (Exception e1) {
e1.printStackTrace();
}
if (trainingInstances.classIndex() == -1)
trainingInstances
.setClassIndex(trainingInstances.numAttributes() - 1);
setTrainingSetSize(trainingInstances.numInstances());
long startTimeMillis = System.currentTimeMillis();
setMultiLayerPerceptron(new weka.classifiers.functions.MultilayerPerceptron());
try {
getMultiLayerPerceptron().buildClassifier(trainingInstances);
} catch (Exception e) {
e.printStackTrace();
}
long finishTimeMillis = System.currentTimeMillis();
setDurationTrainingTimeMs(finishTimeMillis - startTimeMillis);
}
/**
* Method that classifies an individual instance
*/
@Override
public void ClassifyInstances() {
// Load data to classify
weka.core.Instances dataInstances = null;
try {
dataInstances = new weka.core.Instances(new java.io.FileReader(
getDataFile()));
} catch (Exception e1) {
e1.printStackTrace();
}
if (dataInstances.classIndex() == -1)
dataInstances.setClassIndex(dataInstances.numAttributes() - 1);
setInstanceValue(dataInstances.firstInstance().stringValue(
dataInstances.numAttributes() - 1));
setDataSetSize(dataInstances.numInstances());
long startTimeMillis = System.currentTimeMillis();
int numCorrect = 0;
for (int i = 0; i < getDataSetSize(); i++) {
weka.core.Instance currentInst = dataInstances.instance(i);
double predictedClass = 0;
try {
predictedClass = getMultiLayerPerceptron().classifyInstance(
currentInst);
} catch (Exception e) {
e.printStackTrace();
}
setInstanceClassification(dataInstances.instance(i).classValue());
setInstancePredictedClass(predictedClass);
setPredictedInstanceValue(dataInstances.classAttribute().value(
(int) predictedClass));
if (predictedClass == dataInstances.instance(i).classValue()) {
numCorrect++;
}
}
long finishTimeMillis = System.currentTimeMillis();
setDurationTimeMs(finishTimeMillis - startTimeMillis);
setPercentage((double) numCorrect / (double) getDataSetSize() * 100.0);
setCorrectIntances(numCorrect);
}
/**
* Returns the classifier
* @return MLP
*/
public weka.classifiers.functions.MultilayerPerceptron getMultiLayerPerceptron() {
return multiLayerPerceptron;
}
/**
* Sets the classifier
* @param multiLayerPerceptron
*/
public void setMultiLayerPerceptron(
weka.classifiers.functions.MultilayerPerceptron multiLayerPerceptron) {
this.multiLayerPerceptron = multiLayerPerceptron;
}
/**
* Returns the description of the weka algorithm
*/
@Override
public String type() {
// TODO Auto-generated method stub
return "weka.classifiers.functions.MultilayerPerceptron";
}
}