/home/ooechs/Ecj2Java/src/ac/essex/ooechs/ecj/ecj2java/example/util/StatisticsPrinter.java
|
package ac.essex.ooechs.ecj.ecj2java.example.util;
import ec.gp.koza.KozaStatistics;
import ec.EvolutionState;
import ec.util.Output;
import ec.simple.SimpleProblemForm;
/**
*
* <p>
* Causes the descibe method on the MathsProblem class to fire
* at the end of every generation, allowing the JavaWriter
* to output the best individual as a Java file
* </p>
*
* <p/>
* This program is 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,
* provided that any use properly credits the author.
* This program 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 at http://www.gnu.org
* </p>
*
* @author Olly Oechsle, University of Essex, Date: 05-Sep-2006
* @version 1.0
*/
public class StatisticsPrinter extends KozaStatistics {
public void postEvaluationStatistics(EvolutionState state) {
super.postEvaluationStatistics(state);
System.out.println();
// we have only one population, so this is kosher
// call the describe method which allows us to process the best individual
// at the end of every generation. In this case we'd like to convert that individual
// into Java and save it for later use.
((SimpleProblemForm) (state.evaluator.p_problem.protoCloneSimple())).describe(best_of_run[0], state, 0, statisticslog, Output.V_NO_GENERAL);
}
}