it.unibo.alchemist.model.cognitive.reactions.NavigationPrioritizedSteering.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of alchemist-cognitive-agents Show documentation
Show all versions of alchemist-cognitive-agents Show documentation
Abstraction for group of pedestrians capable of influence each other emotionally.
/*
* 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.cognitive.reactions
import it.unibo.alchemist.model.TimeDistribution
import it.unibo.alchemist.model.cognitive.PedestrianProperty
import it.unibo.alchemist.model.cognitive.SteeringAction
import it.unibo.alchemist.model.cognitive.actions.NavigationAction2D
import it.unibo.alchemist.model.cognitive.steering.SinglePrevalent
import it.unibo.alchemist.model.environments.Euclidean2DEnvironmentWithGraph
import it.unibo.alchemist.model.geometry.ConvexPolygon
import it.unibo.alchemist.model.positions.Euclidean2DPosition
/**
* A [SteeringBehavior] using [SinglePrevalent] steering strategy and accepting a collection of actions
* containing a single [NavigationAction2D], which is used as the prevalent one.
*
* @param T concentration type
* @param N type of nodes of the environment's graph.
*/
open class NavigationPrioritizedSteering @JvmOverloads constructor(
environment: Euclidean2DEnvironmentWithGraph<*, T, N, *>,
override val pedestrian: PedestrianProperty,
timeDistribution: TimeDistribution,
/**
* Tolerance angle in degrees (see [SinglePrevalent]).
*/
toleranceAngle: Double = Math.toDegrees(SinglePrevalent.DEFAULT_TOLERANCE_ANGLE),
/**
* Alpha value for exponential smoothing (see [SinglePrevalent]).
*/
alpha: Double = SinglePrevalent.DEFAULT_ALPHA,
) : SteeringBehavior(
environment,
pedestrian,
timeDistribution,
SinglePrevalent(
environment,
pedestrian.node,
prevalent = { singleNavigationAction() },
maxWalk = { pedestrian.speed() / timeDistribution.rate },
toleranceAngle = Math.toRadians(toleranceAngle),
alpha = alpha,
),
) {
private companion object {
/**
* @returns the only navigation action contained in the list or throws an exception.
*/
private fun ActionList.singleNavigationAction(): NaviAction = this
.filterIsInstance>()
.let {
check(it.size == 1) { "There should be exactly one navigation action" }
it.first()
}
}
}
/*
* Just for readability.
*/
private typealias ActionList = List>
private typealias NaviAction = NavigationAction2D