AbstractEnvironment

abstract class AbstractEnvironment<T, P : Position<P>> : Environment<T, P> (source)

Very generic and basic implementation for an environment. Basically, only manages an internal set of nodes and their position.

Parameters

[it.unibo.alchemist.model.Position] type

Inheritors

Properties

Link copied to clipboard
abstract val dimensions: Int
Link copied to clipboard
open override val globalReactions: ListSet<GlobalReaction<T>>
Link copied to clipboard
Link copied to clipboard
open override val isTerminated: Boolean
Link copied to clipboard
open override val layers: ListSet<Layer<T, P>>
Link copied to clipboard
override var linkingRule: LinkingRule<T, P>
Link copied to clipboard
override val nodeCount: Int
Link copied to clipboard
open override val nodes: ListSet<Node<T>>
Link copied to clipboard
abstract val offset: DoubleArray
Link copied to clipboard
override var simulation: Simulation<T, P>
Link copied to clipboard
Link copied to clipboard
abstract val size: DoubleArray
Link copied to clipboard
open override val sizeInDistanceUnits: DoubleArray

Override this property if units measuring distance do not match with units used for coordinates. For instance, if your space is non-Euclidean, or if you are using polar coordinates. A notable example is using geographical latitude-longitude as y-x coordinates and meters as distance measure.

Functions

Link copied to clipboard
open override fun addGlobalReaction(reaction: GlobalReaction<T>)
Link copied to clipboard
open override fun addLayer(molecule: Molecule, layer: Layer<T, P>)
Link copied to clipboard
open override fun addNode(node: Node<T>, position: P): Boolean
Link copied to clipboard
open fun addTerminator(terminator: (Environment<T, P>) -> Boolean)

open override fun addTerminator(terminator: TerminationPredicate<T, P>)

Adds to the simulation a predicate that determines whether a simulation should be terminated.

Link copied to clipboard

Calculates the shortest paths using the Floyd-Warshall algorithm calculating the Hop Distance between nodes.

Link copied to clipboard
fun <T> Environment<T, *>.allShortestPaths(computeDistance: (Node<T>, Node<T>) -> Double = neighborDistanceMetric { n1, n2 -> getDistanceBetweenNodes(n1, n2) }): Map<Environments.UndirectedEdge<T>, Double>

Computes all the minimum distances with the provided metric using the Floyd–Warshall algorithm.

Link copied to clipboard
fun <T> Environment<T, *>.allSubNetworks(computeDistance: (Node<T>, Node<T>) -> Double = environmentMetricDistance()): Set<Network<T>>

Computes the diameter of all subnetworks in the environment. The diameter is the longest shortest path between any two nodes. Returns a Set containing the SubNetworks.

Link copied to clipboard
fun <T> Environment<T, *>.allSubNetworksByNode(computeDistance: (Node<T>, Node<T>) -> Double = environmentMetricDistance()): Map<Node<T>, Network<T>>

Computes the diameter of all subnetworks in the environment. The diameter is the longest shortest path between any two nodes. Returns a Set containing the SubNetworks.

Link copied to clipboard

Computes the diameter of all subnetworks in the environment. The diameter is the longest shortest path between any two nodes, evaluated using the allShortestHopPaths method. Returns a Set containing the SubNetworks.

Link copied to clipboard

Computes the diameter of all subnetworks in the environment. The diameter is the longest shortest path between any two nodes, evaluated using the allShortestHopPaths method. Returns a Set containing the SubNetworks.

Link copied to clipboard
open override fun forEach(action: Consumer<in Node<T>?>?)
Link copied to clipboard
open override fun getDistanceBetweenNodes(n1: Node<T>, n2: Node<T>): Double
Link copied to clipboard
open override fun getLayer(molecule: Molecule): Layer<T, P>?
Link copied to clipboard
open override fun getNeighborhood(node: Node<T>): Neighborhood<T>
Link copied to clipboard
open override fun getNodeByID(id: Int): Node<T>
Link copied to clipboard
open override fun getNodesWithinRange(position: P, range: Double): ListSet<Node<T>>
open override fun getNodesWithinRange(node: Node<T>, range: Double): ListSet<Node<T>>
Link copied to clipboard
open override fun getPosition(node: Node<T>): P
Link copied to clipboard

Returns true the network is segmented, false otherwise.

Link copied to clipboard
open operator override fun iterator(): MutableIterator<Node<T>>
Link copied to clipboard
abstract fun makePosition(vararg coordinates: Number): P
abstract fun makePosition(coordinates: DoubleArray): P
open fun makePosition(coordinates: List<Number>): P
Link copied to clipboard
abstract fun moveNodeToPosition(node: Node<T>, newPosition: P)
Link copied to clipboard

Returns the diameter of the network in environment units if it is not segmented, and NaN otherwise.

Link copied to clipboard

Returns the hop-distance diameter of the network if it is not segmented, and NaN otherwise.

Computes the network diameter of the segment containing node.

Link copied to clipboard
fun <R> Iterable<R>.randomElement(randomGenerator: RandomGenerator): R

Returns a random element of the Iterable using the provided randomGenerator.

Link copied to clipboard
open override fun removeGlobalReaction(reaction: GlobalReaction<T>)
Link copied to clipboard
open override fun removeNode(node: Node<T>)
Link copied to clipboard
fun <R> Iterable<R>.shuffled(randomGenerator: RandomGenerator): Iterable<R>

Fisher–Yates shuffle algorithm using a RandomGenerator. More information on Wikipedia.

Link copied to clipboard
open override fun spliterator(): Spliterator<Node<T>>
Link copied to clipboard
open override fun toString(): String

Not used internally. Override as you please.