/*
* This file is part of JGAP.
*
* JGAP offers a dual license model containing the LGPL as well as the MPL.
*
* For licensing information please see the file license.txt included with JGAP
* or have a look at the top of class org.jgap.Chromosome which representatively
* includes the JGAP license policy applicable for any file delivered with JGAP.
*/
package org.jgap.gp.impl;
import org.jgap.gp.*;
/**
* A default implementation of a fitness evaluator. This implementation is
* straight forward: a higher fitness value is seen as fitter.
*
* @author Klaus Meffert
* @since 3.0
*/
public class DefaultGPFitnessEvaluator
implements IGPFitnessEvaluator, Cloneable {
/** String containing the CVS revision. Read out via reflection!*/
private final static String CVS_REVISION = "$Revision: 1.8 $";
/**
* Compares the first given fitness value with the second and returns true
* if the first one is greater than the second one. Otherwise returns false
* @param a_fitness_value1 first fitness value
* @param a_fitness_value2 second fitness value
* @return true: first fitness value greater than second
*
* @author Klaus Meffert
* @since 2.0 (until 1.1: input types int)
*/
public boolean isFitter(final double a_fitness_value1,
final double a_fitness_value2) {
if (!Double.isNaN(a_fitness_value1) &&
!Double.isNaN(a_fitness_value2)) {
return a_fitness_value1 > a_fitness_value2;
}
else if (Double.isNaN(a_fitness_value1)) {
return false;
}
return true;
}
/*
* @author Klaus Meffert
* @since 3.1
*/
public boolean isFitter(IGPProgram a_prog1, IGPProgram a_prog2) {
if (a_prog1 == null) {
return false;
}
else if (a_prog2 == null) {
return true;
}
else {
// Calculate fitness, consider illegal programs.
// ---------------------------------------------
double fitness1;
double fitness2;
try {
fitness1 = a_prog1.getFitnessValue();
}
catch (IllegalStateException iex) {
// Illegal program.
// ----------------
fitness1 = Double.NaN;
}
try {
fitness2 = a_prog2.getFitnessValue();
}
catch (IllegalStateException iex) {
// Illegal program.
// ----------------
fitness2 = Double.NaN;
}
return isFitter(fitness1, fitness2);
}
}
/*
* @author Klaus Meffert
* @since 3.1
*/
public boolean equals(Object a_object) {
DefaultGPFitnessEvaluator eval = (DefaultGPFitnessEvaluator) a_object;
return true;
}
/*
* @author Klaus Meffert
* @since 3.1
*/
public int compareTo(Object a_object) {
DefaultGPFitnessEvaluator eval = (DefaultGPFitnessEvaluator) a_object;
return 0;
}
/**
* @return deep clone of this instance
*
* @author Klaus Meffert
* @since 3.2
*/
public Object clone() {
DefaultGPFitnessEvaluator result = new DefaultGPFitnessEvaluator();
return result;
}
}