📄 zdt6.java
字号:
/** * ZDT6.java * * @author Antonio J. Nebro * @author Juanjo Durillo * @version 1.0 */package jmetal.problems.ZDT;import jmetal.base.*;import jmetal.base.Configuration.SolutionType_;import jmetal.base.Configuration.VariableType_;import jmetal.util.JMException;/** * Class representing problem ZDT6 */public class ZDT6 extends Problem { /** * Creates a default instance of problem ZDT6 (10 decision variables) * @param representation The solution type must "Real" or "BinaryReal". */ public ZDT6(String representation) { this(10,representation); // 10 variables by default } // ZDT6 /** * Creates a instance of problem ZDT6 * @param numberOfVariables Number of variables * @param solutionType The solution type must "Real" or "BinaryReal". */ public ZDT6(Integer numberOfVariables, String solutionType) { numberOfVariables_ = numberOfVariables.intValue(); numberOfObjectives_ = 2; numberOfConstraints_= 0; problemName_ = "ZDT6"; lowerLimit_ = new double[numberOfVariables_]; upperLimit_ = new double[numberOfVariables_]; for (int var = 0; var < numberOfVariables_; var++) { lowerLimit_[var] = 0.0; upperLimit_[var] = 1.0; } //for solutionType_ = Enum.valueOf(SolutionType_.class, solutionType) ; // All the variables are of the same type, so the solutionType name is the // same than the variableType name variableType_ = new VariableType_[numberOfVariables_]; for (int var = 0; var < numberOfVariables_; var++){ variableType_[var] = Enum.valueOf(VariableType_.class, solutionType) ; } // for } //ZDT6 /** * Evaluates a solution * @param solution The solution to evaluate * @throws JMException */ public void evaluate(Solution solution) throws JMException { DecisionVariables decisionVariables = solution.getDecisionVariables(); double x1 = decisionVariables.variables_[0].getValue() ; double [] f = new double[numberOfObjectives_] ; f[0] = 1.0 - Math.exp((-4.0)*x1) * Math.pow(Math.sin(6.0*Math.PI*x1),6.0); double g = this.evalG(decisionVariables) ; double h = this.evalH(f[0],g) ; f[1] = h * g ; solution.setObjective(0,f[0]); solution.setObjective(1,f[1]); } //evaluate /** * Returns the value of the ZDT6 function G. * @param decisionVariables The decision variables of the solution to * evaluate. * @throws JMException */ public double evalG(DecisionVariables decisionVariables) throws JMException{ double g = 0.0; for (int var = 1; var < this.numberOfVariables_; var++) g += decisionVariables.variables_[var].getValue(); g = g / (numberOfVariables_ - 1); g = java.lang.Math.pow(g,0.25); g = 9.0 * g; g = 1.0 + g; return g; } // evalG /** * Returns the value of the ZDT6 function H. * @param f First argument of the function H. * @param g Second argument of the function H. */ public double evalH(double f, double g){ return 1.0 - Math.pow((f/g),2.0); } // evalH } //ZDT6
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -