OSMEnvironment

This class serves as template for more specific implementations of environments using a map. It encloses the navigation logic, but leaves the subclasses to decide how to provide map data (e.g. loading from disk or rely on online services). The data is then stored in-memory for performance reasons.

Parameters

<T>

concentration type

Constructors

Link copied to clipboard
constructor(incarnation: Incarnation<T, GeoPosition>)
Builds a new OSMEnvironment without an actual backing map.
constructor(incarnation: Incarnation<T, GeoPosition>, file: String)
Builds a new OSMEnvironment, with nodes not forced on streets.
constructor(incarnation: Incarnation<T, GeoPosition>, file: String, onStreets: Boolean)
constructor(incarnation: Incarnation<T, GeoPosition>, file: String, onStreets: Boolean, onlyOnStreets: Boolean)
constructor(incarnation: Incarnation<T, GeoPosition>, file: String, approximation: Int)
constructor(incarnation: Incarnation<T, GeoPosition>, file: String, approximation: Int, onStreets: Boolean, onlyOnStreets: Boolean)

Properties

Link copied to clipboard
The default value for approximating the positions comparison.
Link copied to clipboard
The default value for the discard of nodes too far from streets option.
Link copied to clipboard
The default value for the force nodes on streets option.
Link copied to clipboard
val globalReactions: ListSet<GlobalReaction<T>>
Link copied to clipboard
Link copied to clipboard
val nodes: ListSet<Node<T>>
Link copied to clipboard
open var simulation: Simulation<T, P>

Functions

Link copied to clipboard
abstract fun addGlobalReaction(reaction: GlobalReaction<T>)
open fun addGlobalReaction(reaction: GlobalReaction<T>)
Link copied to clipboard
abstract fun addLayer(molecule: Molecule, layer: Layer<T, P>)

Add a Layer to the Environment.

fun addLayer(molecule: Molecule, layer: Layer<T, P>)
Add a Layer to the Environment.
Link copied to clipboard
abstract fun addNode(node: Node<T>, position: P): Boolean

This method allows to add a new node to this environment in a specific position. The environment is responsible to call the right method of the simulation in order to ensure that the reaction is properly scheduled. The function returns true if the node is added to the environment.

fun addNode(node: Node<T>, p: P): Boolean
This method allows to add a new node to this environment in a specific position.
Link copied to clipboard
abstract fun addTerminator(terminator: TerminationPredicate<T, P>)

Add a terminator indicating whether the simulation should be considered finished.

open fun addTerminator(terminator: TerminationPredicate<T, P>)
Adds to the simulation a predicate that determines whether a simulation should be terminated.
Link copied to clipboard
open fun computeRoute(node: Node<T>, coord: GeoPosition): Route<GeoPosition>
open fun computeRoute(node: Node<T>, node2: Node<T>): Route<GeoPosition>
open fun computeRoute(node: Node<T>, coord: GeoPosition, options: GraphHopperOptions): Route<GeoPosition>
This method relies on the map data, and computes a route towards some absolute coordinate solving a TSP problem.
Link copied to clipboard
open fun enableBenchmark()
Call this method to tell this environment that it should record its performances.
Link copied to clipboard
fun forEach(action: Consumer<in Node<T>>)
open fun forEach(p: Consumer<in T>)
Link copied to clipboard
Link copied to clipboard
abstract fun getDimensions(): Int

The number of dimensions of this environment.

The number of dimensions of this environment.
Link copied to clipboard
abstract fun getDistanceBetweenNodes(n1: Node<T>, n2: Node<T>): Double

Measures the distance between two nodes (n1, n2) in the environment.

Measures the distance between two nodes (n1, n2) in the environment.
Link copied to clipboard
abstract fun getGlobalReactions(): NonExistentClass
Link copied to clipboard
abstract fun getIncarnation(): Incarnation<T, P>

Return the Incarnation used to initialize the entities of this Environment, if it has been set.

Link copied to clipboard
abstract fun getLayer(molecule: Molecule): Layer<T, P>

Get the Layer associate to the given molecule. If no Layer is associated with the given molecule, return null.

fun getLayer(molecule: Molecule): Layer<T, P>
Get the Layer associate to the given molecule.
Link copied to clipboard
abstract fun getLayers(): NonExistentClass

Return all the Layers in this Environment.

fun getLayers(): ListSet<Layer<T, P>>
Return all the Layers in this Environment.
Link copied to clipboard
abstract fun getLinkingRule(): LinkingRule<T, P>

Returns the current LinkingRule.

Returns the current LinkingRule.
Link copied to clipboard
abstract fun getNeighborhood(node: Node<T>): Neighborhood<T>

Given a node, this method returns its neighborhood.

Given a node, this method returns its neighborhood.
Link copied to clipboard
abstract fun getNodeByID(id: Int): Node<T>

Allows to access a Node in this Environment 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).

fun getNodeByID(id: Int): Node<T>
Allows to access a Node in this Environment known its id.
Link copied to clipboard
abstract fun getNodeCount(): Int

Returns the number of Nodes currently in the Environment.

Returns the number of Nodes currently in the Environment.
Link copied to clipboard
abstract fun getNodes(): NonExistentClass

Returns all the Nodes that exist in current Environment.

Link copied to clipboard
abstract fun getNodesWithinRange(node: Node<T>, range: Double): NonExistentClass

Given a node 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 Environment.getNeighborhood and filter the neighborhood if you are sure that all the nodes within the range are connected to the center.

fun getNodesWithinRange(position: P, range: Double): ListSet<Node<T>>
Given a position this method returns a list of all the surroundings nodes within the given range.
fun getNodesWithinRange(node: Node<T>, range: Double): ListSet<Node<T>>
Given a node this method returns a list of all the surroundings nodes within the given range.
Link copied to clipboard
abstract fun getOffset(): Array<Double>

This method allows to know which are the smallest coordinates represented. Return an array of length dimensions containing the smallest coordinates for each dimension.

This method allows to know which are the smallest coordinates represented.
Link copied to clipboard
abstract fun getPosition(node: Node<T>): P

Calculates the position of a node.

fun getPosition(node: Node<T>): P
Calculates the position of a node.
Link copied to clipboard
Link copied to clipboard
abstract fun getSimulation(): Simulation<T, P>

Return the current Simulation, if present, or throws an IllegalStateException otherwise.

Link copied to clipboard
abstract fun getSimulationOrNull(): Simulation<T, P>

Return the current Simulation, if present, or null otherwise.

Return the current Simulation, if present, or null otherwise.
Link copied to clipboard
abstract fun getSize(): Array<Double>

The size of the environment as an array of length getDimensions(). This method must return distance measured with the same unit used by the positions. No non-euclidean distance metrics are allowed.

The size of the environment as an array of length getDimensions().
Link copied to clipboard
Override this method if units measuring distance do not match with units used for coordinates.
Link copied to clipboard
abstract fun isTerminated(): Boolean

Return true if all the terminators are true.

Return true if all the terminators are true.
Link copied to clipboard
abstract fun iterator(): Iterator<T>
Link copied to clipboard
open fun makePosition(coordinates: Array<Number>): GeoPosition
Given the coordinates of the point, returns a Position compatible with this environment.
Link copied to clipboard
abstract fun moveNodeToPosition(node: Node<T>, position: P)

This method moves a node in the environment to some position. If node move is unsupported, it does nothing.

open fun moveNodeToPosition(node: Node<T>, newpos: P)
Subclasses may override this method if they want to change the way a node moves towards some absolute position.
Link copied to clipboard
fun <R> Iterable<R>.randomElement(randomGenerator: <Error class: unknown class>): R

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

Link copied to clipboard
abstract fun removeGlobalReaction(reaction: GlobalReaction<T>)

Remove a GlobalReaction from the Environment.

Remove a GlobalReaction from the Environment.
Link copied to clipboard
abstract fun removeNode(node: Node<T>)

This method allows to remove a node. If node removal is unsupported, it does nothing.

fun removeNode(node: Node<T>)
This method allows to remove a node.
Link copied to clipboard
abstract fun setLinkingRule(<set-?>: LinkingRule<T, P>)

Returns the current LinkingRule.

Returns the current LinkingRule.
Link copied to clipboard
abstract fun setSimulation(<set-?>: Simulation<T, P>)

Return the current Simulation, if present, or throws an IllegalStateException otherwise.

Link copied to clipboard
fun <R> Iterable<R>.shuffled(randomGenerator: <Error class: unknown class>): Iterable<R>

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

Link copied to clipboard
Link copied to clipboard
fun <T, P : Position<out P>, TS : Any> Environment<T, P>.toEnvironmentSurrogate(toConcentrationSurrogate: (T) -> TS): EnvironmentSurrogate<TS, PositionSurrogate>

A function that maps an Environment to its surrogate class (EnvironmentSurrogate). Use the toSuitablePositionSurrogate strategy for PositionSurrogate mapping.

fun <T, P : Position<out P>, TS : Any, PS : PositionSurrogate> Environment<T, P>.toEnvironmentSurrogate(toConcentrationSurrogate: (T) -> TS, toPositionSurrogate: (P) -> PS): EnvironmentSurrogate<TS, PS>

A function that maps an Environment to its surrogate class (EnvironmentSurrogate).

Link copied to clipboard
open fun toString(): String
Not used internally.