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

it.unibo.alchemist.model.interfaces.Environment Maven / Gradle / Ivy

There is a newer version: 20.0.1
Show newest version
/*
 * Copyright (C) 2010-2019, Danilo Pianini and contributors listed in the main project's alchemist/build.gradle 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.interfaces;

import java.io.Serializable;
import java.util.Optional;
import java.util.function.Predicate;

import org.danilopianini.util.ListSet;

import it.unibo.alchemist.core.interfaces.Simulation;

/**
 * Interface for an environment. Every environment must implement this
 * specification.
 * 
 * @param 

* Concentration type * @param * Position type */ public interface Environment> extends Serializable, Iterable> { /** * Add a {@link Layer} to the {@link Environment}. * * @param m * the {@link Molecule} of the {@link Layer} * @param l * the {@link Layer} */ void addLayer(Molecule m, Layer l); /** * This method allows to add a new node to this environment. The environment * is responsible to call the right method of the simulation in order to * ensure that the reaction is properly scheduled. * * @param node * The node to add * @param p * The position where to place it */ void addNode(Node node, P p); /** * @param terminator * a {@link Predicate} indicating whether the simulation should * be considered finished */ void addTerminator(Predicate> terminator); /** * The number of dimensions of this environment. * * @return the number of dimensions of this environment */ int getDimensions(); /** * Measures the distance between two nodes in the environment. * * @param n1 * the first node * @param n2 * the second node * @return the distance between the two nodes */ double getDistanceBetweenNodes(Node n1, Node n2); /** * @return the {@link Incarnation} used to initialize the entities of this {@link Environment}, if it has been set. */ Optional> getIncarnation(); /** * Get the layer associate to the given molecule. If no Layer is associated * with the given molecule, return an empty optional. * * @param m * the {@link Molecule} * @return the {@link Optional} containing the {@link Layer} associated with * the requested molecule */ Optional> getLayer(Molecule m); /** * Return all the Layers in this {@link Environment}. * * @return a {@link ListSet} of {@link Layer}. */ ListSet> getLayers(); /** * @return the current linking rule */ LinkingRule getLinkingRule(); /** * Given a node, this method returns its neighborhood. * * @param center * The node you want the neighbors to be found * @return the neighborhood */ Neighborhood getNeighborhood(Node center); /** * Allows to access a node known its id. Depending on the implementation, this method may or not be optimized * (namely, id could run in constant or linear time with the number of nodes). * * @param id * the node's ID * @return the node with that id, or null if it does not exist in this * environment */ Node getNodeByID(int id); /** * All the nodes that exist in current environment. * * @return All the nodes that exist in current environment */ ListSet> getNodes(); /** * @return the number of nodes currently in the environment */ int getNodesNumber(); /** * Given a node (center) this method returns a list of all the surroundings * nodes within the given range. Note that this method (depending on the * implementation) might be not optimized and it's consequently much * better to use {@link Environment#getNeighborhood(Node)} and filter the * neighborhood if you are sure that all the nodes within the range are * connected to the center. * * @param center * the node to consider as center * @param range * the exploration range * @return the list of nodes within the range */ ListSet> getNodesWithinRange(Node center, double range); /** * Given a {@link Position}(center) this method returns a list of all the * surroundings nodes within the given range. Note that this method * (depending on the implementation) might be not optimized. * * @param center * the {@link Position} to consider as center * @param range * the exploration range * @return the list of nodes within the range */ ListSet> getNodesWithinRange(P center, double range); /** * This method allows to know which are the smallest coordinates * represented. * * @return an array of length getDimensions() containing the smallest * coordinates for each dimension. */ double[] getOffset(); /** * Calculates the position of a node. * * @param node * the node you want to know the position * @return The position */ P getPosition(Node node); /** * @return the current simulation, if present, or throws an * {@link IllegalStateException} otherwise */ Simulation getSimulation(); /** * This method returns the size of the environment as an array of length * {@link #getDimensions()}. This method must return distance measured with * the same unit used by the positions. No non-euclidean distance metrics * are allowed. * * @return the size of this environment */ double[] getSize(); /** * This method returns the size of the environment as an array of length * {@link #getDimensions()}. This method must return distance measured with * the same unit used for measuring distances. It may or may not return the * same result of {@link #getSize()} * * @return the size of this environment */ double[] getSizeInDistanceUnits(); /** * @return true if all the terminators are true */ boolean isTerminated(); /** * @param coordinates * the coordinates of the point * @return a {@link Position} compatible with this environment */ P makePosition(Number... coordinates); /** * This method moves a node in the environment toward some direction. If * node move is unsupported, it does nothing. * * @param node * The node to move * @param direction * The position which will be summed to the current position to * move the node in the right place. */ void moveNode(Node node, P direction); /** * This method moves a node in the environment to some position. If node * move is unsupported, it does nothing. * * @param node * The node to move * @param position * The absolute position in which this node will be moved. */ void moveNodeToPosition(Node node, P position); /** * This method allows to remove a node. If node removal is unsupported, it * does nothing. * * @param node * the node to remove */ void removeNode(Node node); /** * @param incarnation * the {@link Incarnation} that will be used for creating the * entities of this environment */ void setIncarnation(Incarnation incarnation); /** * @param rule * the rule to set */ void setLinkingRule(LinkingRule rule); /** * @param s * the simulation */ void setSimulation(Simulation s); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy