it.unibo.alchemist.model.movestrategies.RoutingStrategy Maven / Gradle / Ivy
Show all versions of alchemist-implementationbase Show documentation
/*
* 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.model.movestrategies;
import java.io.Serializable;
import it.unibo.alchemist.model.Node;
import it.unibo.alchemist.model.Position;
import it.unibo.alchemist.model.Reaction;
import it.unibo.alchemist.model.Route;
/**
* Strategy interface describing how the routing between two points happens.
*
* @param Concentration type
* @param position type
*/
@FunctionalInterface
public interface RoutingStrategy> extends Serializable {
/**
* Computes a route between two positions.
*
* @param currentPos starting {@link Position}
* @param finalPos ending {@link Position}
* @return a {@link Route} connecting the two points
*/
Route computeRoute(P currentPos, P finalPos);
/**
* @param destination the {@link Node} where the strategy is being cloned
* @param reaction the {@link Reaction} where strategy is being cloned
*
* @return A copy of the strategy if the strategy is stateful, and this object otherwise.
* The default implementation assumes a stateless strategy.
*/
default RoutingStrategy cloneIfNeeded(final Node destination, final Reaction reaction) {
return this;
}
}