package org.opentrafficsim.road.gtu.lane.control; import org.djunits.value.vdouble.scalar.Acceleration; import org.djunits.value.vdouble.scalar.Duration; import org.opentrafficsim.base.parameters.ParameterTypeDuration; import org.opentrafficsim.base.parameters.constraint.NumericConstraint; import org.opentrafficsim.road.gtu.lane.LaneBasedGTU; /** * Delays the actuation of acceleration. This is not part of the vehicle model as that is used for both human and automated * control, which follow different vehicle capability semantics. *
* Copyright (c) 2013-2022 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
* BSD-style license. See OpenTrafficSim License.
*
* @version $Revision$, $LastChangedDate$, by $Author$, initial version Mar 12, 2019
* @author Alexander Verbraeck
* @author Peter Knoppers
* @author Wouter Schakel
*/
public interface DelayedActuation
{
/** No delayed actuation. */
DelayedActuation NONE = new DelayedActuation()
{
/** {@inheritDoc} */
@Override
public Acceleration delayActuation(final Acceleration desiredAcceleration, final LaneBasedGTU gtu)
{
return desiredAcceleration;
}
};
/** Parameter for actuation delay. */
ParameterTypeDuration TAU =
new ParameterTypeDuration("tau_actuation", "Actuation delay", Duration.instantiateSI(0.1), NumericConstraint.POSITIVE);
/** Tau delayed actuation. */
DelayedActuation TAUDELAYED = new DelayedActuation()
{
/** {@inheritDoc} */
@Override
public Acceleration delayActuation(final Acceleration desiredAcceleration, final LaneBasedGTU gtu)
{
// TODO: numerical implementation of tau rule
return desiredAcceleration.minus(gtu.getAcceleration());
}
};
/**
* Delays the actuation of acceleration.
* @param desiredAcceleration Acceleration; desired acceleration
* @param gtu LaneBasedGTU; gtu
* @return Acceleration; delayed acceleration
*/
Acceleration delayActuation(Acceleration desiredAcceleration, LaneBasedGTU gtu);
}