package jcgp.backend.modules.mutator;
import jcgp.backend.resources.Resources;
import jcgp.backend.resources.parameters.BooleanParameter;
import jcgp.backend.resources.parameters.IntegerParameter;
import jcgp.backend.resources.parameters.Parameter;
import jcgp.backend.resources.parameters.ParameterStatus;
/**
* Fixed point mutator
*
* This operator uses the point mutator
* algorithm to mutate a user-defined fixed
* number of genes.
*
*
* @see PointMutator
* @author Eduardo Pedroni
*
*/
public class FixedPointMutator extends PointMutator {
private IntegerParameter geneMutated;
private BooleanParameter report;
/**
* Creates a new instance of FixedPointMutator.
*
* @param resources a reference to the experiment's resources.
*/
public FixedPointMutator(final Resources resources) {
geneMutated = new IntegerParameter(5, "Genes mutated", false, false) {
@Override
public void validate(Number newValue) {
if (newValue.intValue() <= 0) {
status = ParameterStatus.INVALID;
status.setDetails("At least 1 mutation must take place.");
} else if (newValue.intValue() > (resources.nodes() * (resources.arity() + 1)) + resources.outputs()) {
status = ParameterStatus.WARNING;
status.setDetails("More genes are mutated than there are genes in the genotype.");
} else {
status = ParameterStatus.VALID;
}
}
};
report = new BooleanParameter(false, "Report") {
@Override
public void validate(Boolean newValue) {
// blank
}
};
}
@Override
public Parameter>[] getLocalParameters() {
return new Parameter[] {geneMutated, report};
}
@Override
public String toString() {
return "Fixed point mutation";
}
}