crowdingdistancecomparator.java
来自「关于多目标优化的代码」· Java 代码 · 共 41 行
JAVA
41 行
/**
* CrowdingDistanceComparator.java
*
* @author Juan J. Durillo
* @version 1.0
*/
package jmetal.base.operator.comparator;
import jmetal.base.Solution;
import java.util.Comparator;
/**
* This class implements a <code>Comparator</code> (a method for comparing
* <code>Solution</code> objects) based on the crowding distance, as in NSGA-II.
*/
public class CrowdingDistanceComparator implements Comparator{
/**
* Compares two solutions.
* @param o1 Object representing the first <code>Solution</code>.
* @param o2 Object representing the second <code>Solution</code>.
* @return -1, or 0, or 1 if o1 is less than, equal, or greater than o2,
* respectively.
*/
public int compare(Object o1, Object o2) {
if (o1==null)
return 1;
else if (o2 == null)
return -1;
double distance1 = ((Solution)o1).getCrowdingDistance();
double distance2 = ((Solution)o2).getCrowdingDistance();
if (distance1 > distance2)
return -1;
if (distance1 < distance2)
return 1;
return 0;
} // compare
} // CrowdingDistanceComparator
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?