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

it.unibo.alchemist.boundary.variables.LinearVariable Maven / Gradle / Ivy

/*
 * Copyright (C) 2010-2023, Danilo Pianini and contributors
 * listed, for each module, in the respective subproject's build.gradle.kts file.
 *
 * This file is part of Alchemist, and is distributed under the terms of the
 * GNU General Public License, with a linking exception,
 * as described in the file LICENSE in the Alchemist distribution's top directory.
 */
package it.unibo.alchemist.boundary.variables;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.stream.DoubleStream;
import java.util.stream.Stream;

/**
 * This class represents a linear variable, namely a variable whose values span
 * linearly between minimum and maximum.
 */
public final class LinearVariable extends PrintableVariable {

    private static final long serialVersionUID = 2462199794377640948L;
    private static final Logger L = LoggerFactory.getLogger(LinearVariable.class);
    private final double min, max, step, def;

    /**
     * @param def default value
     * @param min minimum (inclusive)
     * @param max maximum (inclusive)
     * @param step number of steps
     */
    public LinearVariable(final double def, final double min, final double max, final double step) {
        if (max < min) {
            throw new IllegalArgumentException("The maximum value is smaller than the minimum.");
        }
        if (def > max || def < min) {
            L.warn("The provided default value for a linear variable ({}) is out of bounds: [{}, {}]", def, min, max);
        }
        this.min = min;
        this.max = max;
        this.step = step;
        this.def = def;
    }

    @Override
    public Double getDefault() {
        return def;
    }

    @Override
    public long steps() {
        final long num = (long) Math.ceil((max - min) / step);
        if (min + step * num <= max) {
            return num + 1;
        }
        return num;
    }

    @Override
    public Stream stream() {
        return DoubleStream.iterate(min, x -> x + step).limit(steps()).boxed();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy