maxfunction.java
来自「一个开源的用java开发的遗传算法的封装好的工程」· Java 代码 · 共 61 行
JAVA
61 行
/*
* This file is part of JGAP.
*
* JGAP offers a dual license model containing the LGPL as well as the MPL.
*
* For licencing 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 examples.simpleBooleanThreaded;
import org.jgap.*;
import org.jgap.impl.*;
/**
* Fitness function for our example. See evolve() method for details
*
* @author Klaus Meffert
* @since 3.01
*/
public class MaxFunction
extends FitnessFunction {
/** String containing the CVS revision. Read out via reflection!*/
private final static String CVS_REVISION = "$Revision: 1.1 $";
/**
* This example implementation calculates the fitness value of Chromosomes
* using BooleanAllele implementations.
*
* @param a_subject the Chromosome to be evaluated
* @return defect rate of our problem
*
* @author Klaus Meffert
* @since 3.01
*/
public double evaluate(IChromosome a_subject) {
int total = 0;
for (int i = 0; i < a_subject.size(); i++) {
BooleanGene value = (BooleanGene) a_subject.getGene(a_subject.size() -
(i + 1));
if (value.booleanValue()) {
if (i % 3 == 0) {
total += Math.pow(1.3, (double) i);
}
else if (i % 3 == 1) {
total -= Math.pow(1.7, (double) i);
}
else {
total += Math.pow(1.9, (double) i);
}
}
if (total < 0) {
total = 0;
}
}
return total;
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?