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

it.unibo.alchemist.protelis.properties.ProtelisDevice.kt Maven / Gradle / Ivy

Go to download

Implementation of the Alchemist's meta-meta model supporting execution of Protelis programs

There is a newer version: 35.0.0
Show newest version
/*
 * 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.protelis.properties

import it.unibo.alchemist.model.Environment
import it.unibo.alchemist.model.Node
import it.unibo.alchemist.model.NodeProperty
import it.unibo.alchemist.model.Position
import it.unibo.alchemist.model.protelis.ProtelisIncarnation
import it.unibo.alchemist.protelis.AlchemistNetworkManager
import it.unibo.alchemist.protelis.actions.RunProtelisProgram
import org.protelis.lang.datatype.DeviceUID
import org.protelis.lang.datatype.Field
import org.protelis.vm.ExecutionEnvironment

/**
 * Base implementation of [ProtelisDevice]. Requires an [environment] to work.
 */
class ProtelisDevice

> @JvmOverloads constructor( val environment: Environment, override val node: Node, networkManagers: Map, AlchemistNetworkManager> = mapOf(), ) : NodeProperty, ExecutionEnvironment, DeviceUID { private val incarnation: ProtelisIncarnation<*> = environment.incarnation as? ProtelisIncarnation

?: ProtelisIncarnation.INSTANCE /** * The node's id. */ val id: Int get() = node.id /** * All the [AlchemistNetworkManager]s in this node. */ var networkManagers: Map, AlchemistNetworkManager> = networkManagers private set /** * Adds a new [AlchemistNetworkManager]. * * @param program * the [RunProtelisProgram] * @param networkManager * the [AlchemistNetworkManager] */ fun addNetworkManger(program: RunProtelisProgram<*>, networkManager: AlchemistNetworkManager) { networkManagers = networkManagers + (program to networkManager) } /** * Finds all the [RunProtelisProgram]s installed on this node. */ fun allProtelisPrograms(): List> = node.reactions.asSequence() .flatMap { it.actions } .filterIsInstance>() .toList() override fun cloneOnNewNode(node: Node) = ProtelisDevice(environment, node) /** * Returns the value associated with [id]. */ override fun get(id: String): Any = incarnation.createMolecule(id).let { molecule -> when { node.contains(molecule) -> node.getConcentration(molecule) else -> environment.getLayer(molecule).map { it.getValue(environment.getPosition(node)) }.orElseThrow { IllegalArgumentException( "Molecule (variable) \"$id\" not found in $this, nor a layer with the same name exists", ) } } } /** * Returns the value associated with [id]. */ override fun get(id: String, defaultValue: Any): Any = get(id) /** * @param program * the [RunProtelisProgram] * @return the [AlchemistNetworkManager] for this specific * [RunProtelisProgram] */ fun getNetworkManager(program: RunProtelisProgram<*>) = requireNotNull(networkManagers[program]) { "No network manager found for $program" } /** * Returns true if node contains [id]. */ override fun has(id: String): Boolean = node.contains(incarnation.createMolecule(id)) /** * Stores a [value] associated with [key]. */ override fun put(key: String, value: Any): Boolean { node.setConcentration(incarnation.createMolecule(key), value) return true } /** * Stores a [value] associated with [key]. */ fun putField(key: String, value: Field<*>): Boolean { node.setConcentration(incarnation.createMolecule(key), value) return true } /** * Removes the value associated with [id]. */ override fun remove(id: String): Any { val value = get(id) node.removeConcentration(incarnation.createMolecule(id)) return value } /** * Return all stored variables names. */ override fun keySet(): Set = node.contents.keys.mapNotNull { it.name }.toSet() /** * Called just after the VM is executed, to finalize information of the execution for the environment. */ override fun commit() { /* Nothing to do */ } /** * Called just before the VM is executed, to enable and preparations needed in the environment. */ override fun setup() { /* Nothing to do */ } override fun toString(): String = "PtDevice${node.id}" private companion object { private const val serialVersionUID: Long = 1L } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy