All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jmaxent.Evaluation Maven / Gradle / Ivy

/*
 Copyright (C) 2010 by
 * 
 * 	Cam-Tu Nguyen 
 *  [email protected] or [email protected]
 *
 *  Xuan-Hieu Phan  
 *  [email protected] 
 *
 *  College of Technology, Vietnamese University, Hanoi
 * 	Graduate School of Information Sciences, Tohoku University
 *
 * JVnTextPro-v.2.0 is a free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published
 * by the Free Software Foundation; either version 2 of the License,
 * or (at your option) any later version.
 *
 * JVnTextPro-v.2.0 is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with  JVnTextPro-v.2.0); if not, write to the Free Software Foundation,
 * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
 */

package jmaxent;

import java.io.*;
import java.text.*;

// TODO: Auto-generated Javadoc
/**
 * The Class Evaluation.
 */
public class Evaluation {

    /** The model. */
    public Model model = null;        
    
    /** The num labels. */
    public int numLabels = 0;
    
    /** The human label counts. */
    int[] humanLabelCounts = null;
    
    /** The model label counts. */
    int[] modelLabelCounts = null;
    
    /** The human model counts. */
    int[] humanModelCounts = null;
    
    /**
     * Instantiates a new evaluation.
     */
    public Evaluation() {
	// do nothing	
    }
    
    /**
     * Inits the.
     */
    public void init() {
	numLabels = model.data.numLabels();

	humanLabelCounts = new int[numLabels];
	modelLabelCounts = new int[numLabels];
	humanModelCounts = new int[numLabels];
    }
    
    /**
     * Evaluate.
     *
     * @return the double
     */
    public double evaluate() {
	if (model.data.tstData.size() <= 0) {
	    return 0.0;
	}
	
	for (int i = 0; i < humanLabelCounts.length; i++) {
	    humanLabelCounts[i] = 0;	    
	    modelLabelCounts[i] = 0;	    
	    humanModelCounts[i] = 0;	    
	}
    
	int matchingCount = 0;
    
	for (int i = 0; i < model.data.tstData.size(); i++) {
	    Observation obsr = (Observation)model.data.tstData.get(i);
	    if (obsr.humanLabel == obsr.modelLabel) {
		matchingCount++;
	    }
	}
    
	return (double)(matchingCount * 100) / model.data.tstData.size();   
    }
    
    /**
     * Evaluate.
     *
     * @param fout the fout
     * @return the double
     */
    public double evaluate(PrintWriter fout) {
	int i;    
	
	if (model.data.tstData.size() <= 0) {
	    return 0.0;
	}

	for (i = 0; i < humanLabelCounts.length; i++) {
	    humanLabelCounts[i] = 0;	    
	    modelLabelCounts[i] = 0;	    
	    humanModelCounts[i] = 0;	    
	}

	for (i = 0; i < model.data.tstData.size(); i++) {
	    Observation obsr = (Observation)model.data.tstData.get(i);
	    
	    humanLabelCounts[obsr.humanLabel]++;
	    modelLabelCounts[obsr.modelLabel]++;
	    if (obsr.humanLabel == obsr.modelLabel) {
		humanModelCounts[obsr.humanLabel]++;
	    }
	}
	
	NumberFormat fm = new DecimalFormat("#.00");
	
	System.out.println();
	System.out.println("\tPer-class performance evaluation:");
	System.out.println();
	System.out.println("\t\tClass\tHuman\tModel\tMatch\tPre.(%)\tRec.(%)\tF1-score");
	System.out.println("\t\t-----\t-----\t-----\t-----\t-------\t-------\t--------");
	if (fout != null && model.option.isLogging) {
	    fout.println();
	    fout.println("\tPer-class performance evaluation:");
	    fout.println();
	    fout.println("\t\tClass\tHuman\tModel\tMatch\tPre.(%)\tRec.(%)\tF1-score");
	    fout.println("\t\t-----\t-----\t-----\t-----\t-------\t-------\t--------");
	}
	
	int count = 0;
	double precision = 0.0, recall = 0.0, f1, 
	       total1Pre = 0.0, total1Rec = 0.0, total1F1 = 0.0, 
	       total2Pre = 0.0, total2Rec = 0.0, total2F1 = 0.0;
	int totalHuman = 0, totalModel = 0, totalMatch = 0;
	
	for (i = 0; i < numLabels; i++) {
	    if (modelLabelCounts[i] > 0) {
		precision = (double)humanModelCounts[i] / modelLabelCounts[i];
		totalModel += modelLabelCounts[i];
		total1Pre += precision;
	    } else {
		precision = 0.0;
	    }
	    
	    if (humanLabelCounts[i] > 0) {
		recall = (double)humanModelCounts[i] / humanLabelCounts[i];
		totalHuman += humanLabelCounts[i];
		total1Rec += recall;
		count++;
	    } else {
		recall = 0.0;
	    }   
	    
	    totalMatch += humanModelCounts[i];
	    
	    if (recall + precision > 0) {
		f1 = (double) 2 * precision * recall / (precision + recall);		
	    } else {
		f1 = 0.0;
	    }
	    
	    String classStr = Integer.toString(i);	    
	    String labelStr = (String)model.data.lbInt2Str.get(new Integer(i));
	    if (labelStr != null) {
		classStr = labelStr;
	    }
	    
	    System.out.println("\t\t" + classStr + "\t" + Integer.toString(humanLabelCounts[i]) + 
			"\t" + Integer.toString(modelLabelCounts[i]) + "\t" +
			Integer.toString(humanModelCounts[i]) + "\t" + 
			fm.format(precision * 100) + "\t" + 
			fm.format(recall * 100) + "\t" +
			fm.format(f1 * 100));
	    if (fout != null && model.option.isLogging) {
		fout.println("\t\t" + classStr + "\t" + Integer.toString(humanLabelCounts[i]) + 
			    "\t" + Integer.toString(modelLabelCounts[i]) + "\t" +
			    Integer.toString(humanModelCounts[i]) + "\t" + 
			    fm.format(precision * 100) + "\t" + 
			    fm.format(recall * 100) + "\t" +
			    fm.format(f1 * 100));	    
	    }	    
	}
	
	total1Pre /= count;
	total1Rec /= count;
	total1F1 = 2 * total1Pre * total1Rec / (total1Pre + total1Rec);
	
	total2Pre = (double)totalMatch / totalModel;
	total2Rec = (double)totalMatch / totalHuman;
	total2F1 = 2 * total2Pre * total2Rec / (total2Pre + total2Rec);

	System.out.println("\t\t-----\t-----\t-----\t-----\t-------\t-------\t--------");
	System.out.println("\t\tAvg.1\t\t\t\t" + 
		    fm.format(total1Pre * 100) + "\t" + 
		    fm.format(total1Rec * 100) + "\t" + 
		    fm.format(total1F1 * 100));
	System.out.println("\t\tAvg.2\t" + 
		    Integer.toString(totalHuman) + "\t" +
		    Integer.toString(totalModel) + "\t" +
		    Integer.toString(totalMatch) + "\t" + 
		    fm.format(total2Pre * 100) + "\t" + 
		    fm.format(total2Rec * 100) + "\t" + 
		    fm.format(total2F1 * 100));
	System.out.println();
	if (fout != null && model.option.isLogging) {
	    fout.println();
	    fout.println("\t\t-----\t-----\t-----\t-----\t-------\t-------\t--------");
	    fout.println("\t\tAvg.1\t\t\t\t" + 
			fm.format(total1Pre * 100) + "\t" + 
			fm.format(total1Rec * 100) + "\t" + 
			fm.format(total1F1 * 100));
	    fout.println("\t\tAvg.2\t" + 
			Integer.toString(totalHuman) + "\t" +
			Integer.toString(totalModel) + "\t" +
			Integer.toString(totalMatch) + "\t" + 
			fm.format(total2Pre * 100) + "\t" + 
			fm.format(total2Rec * 100) + "\t" + 
			fm.format(total2F1 * 100));
	}
	
	return total2F1 * 100;
    }

} // end of class Evaluation





© 2015 - 2025 Weber Informatics LLC | Privacy Policy