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

it.unibo.alchemist.model.biochemistry.properties.Cell.kt Maven / Gradle / Ivy

There is a newer version: 35.0.2
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.model.biochemistry.properties

import it.unibo.alchemist.model.Environment
import it.unibo.alchemist.model.Node
import it.unibo.alchemist.model.biochemistry.CellProperty
import it.unibo.alchemist.model.biochemistry.molecules.Junction
import it.unibo.alchemist.model.positions.Euclidean2DPosition
import it.unibo.alchemist.model.properties.AbstractNodeProperty
import org.apache.commons.math3.util.FastMath
import kotlin.math.nextDown
import kotlin.math.nextUp

/**
 * Base implementation of a [CellProperty].
 */
class Cell @JvmOverloads constructor(
    /**
     * The environment in which [node] is moving.
     */
    val environment: Environment,
    override val node: Node,
    override val junctions: MutableMap, Int>> = LinkedHashMap(),
) : AbstractNodeProperty(node), CellProperty {

    override var polarizationVersor: Euclidean2DPosition = Euclidean2DPosition.zero

    override fun addPolarizationVersor(versor: Euclidean2DPosition) {
        val tempCor = (polarizationVersor + versor.coordinates).coordinates
        val module = FastMath.hypot(tempCor[0], tempCor[1])
        polarizationVersor = when (module) {
            in 0.0.nextDown()..0.0.nextUp() -> Euclidean2DPosition.zero
            else -> Euclidean2DPosition(tempCor[0] / module, tempCor[1] / module)
        }
    }

    override fun cloneOnNewNode(node: Node) = Cell(environment, node)
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy