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

net.sourceforge.cilib.functions.continuous.unconstrained.Step Maven / Gradle / Ivy

/**           __  __
 *    _____ _/ /_/ /_    Computational Intelligence Library (CIlib)
 *   / ___/ / / / __ \   (c) CIRG @ UP
 *  / /__/ / / / /_/ /   http://cilib.net
 *  \___/_/_/_/_.___/
 */
package net.sourceforge.cilib.functions.continuous.unconstrained;

import net.sourceforge.cilib.functions.ContinuousFunction;
import net.sourceforge.cilib.type.types.container.Vector;

/**
 * TODO: Complete this javadoc.
 *
 * R(-100.0, 100.0)^6
 */
public class Step extends ContinuousFunction {

    private static final long serialVersionUID = -3888436745417400797L;

    /**
     * {@inheritDoc}
     */
    @Override
    public Double f(Vector input) {
        double sum = 0.0;

        for (int i = 0; i < input.size(); i++) {
            double val = Math.floor(input.doubleValueOf(i) + 0.5);
            sum += val * val;
        }

        return sum;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy