All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sourceforge.cilib.measurement.single.EuclideanDiversityAroundGBest Maven / Gradle / Ivy

Go to download

A library of composable components enabling simpler Computational Intelligence

There is a newer version: 0.8
Show newest version
/**           __  __
 *    _____ _/ /_/ /_    Computational Intelligence Library (CIlib)
 *   / ___/ / / / __ \   (c) CIRG @ UP
 *  / /__/ / / / /_/ /   http://cilib.net
 *  \___/_/_/_/_.___/
 */
package net.sourceforge.cilib.measurement.single;

import net.sourceforge.cilib.algorithm.Algorithm;
import net.sourceforge.cilib.algorithm.population.PopulationBasedAlgorithm;
import net.sourceforge.cilib.entity.Entity;
import net.sourceforge.cilib.entity.Topology;
import net.sourceforge.cilib.measurement.Measurement;
import net.sourceforge.cilib.type.types.Real;
import net.sourceforge.cilib.type.types.container.Vector;
import net.sourceforge.cilib.util.distancemeasure.DistanceMeasure;
import net.sourceforge.cilib.util.distancemeasure.EuclideanDistanceMeasure;

/**
 * TODO: Complete this javadoc.
 */
public class EuclideanDiversityAroundGBest implements Measurement {

    private static final long serialVersionUID = 8221420456303029095L;

    @Override
    public EuclideanDiversityAroundGBest getClone() {
        return this;
    }

    @Override
    public Real getValue(Algorithm algorithm) {
        PopulationBasedAlgorithm populationBasedAlgorithm = (PopulationBasedAlgorithm) algorithm;

        Vector center = (Vector) algorithm.getBestSolution().getPosition();
        DistanceMeasure distance = new EuclideanDistanceMeasure();
        double diameter = 0;

        Topology topology = populationBasedAlgorithm.getTopology();
        for (Entity entity : topology) {
            diameter += distance.distance(center, (Vector) entity.getCandidateSolution());
        }

        return Real.valueOf(diameter / topology.size());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy