ADORe
ADORe is a modular open source software library and toolkit for decision making, planning, control and simulation of automated vehicles
adore::fun::LaneWidthSpeedLimitLFV Class Reference

#include <basicconstraintsandreferences.h>

Inheritance diagram for adore::fun::LaneWidthSpeedLimitLFV:
Inheritance graph
Collaboration diagram for adore::fun::LaneWidthSpeedLimitLFV:
Collaboration graph

Public Member Functions

 LaneWidthSpeedLimitLFV (adore::view::ALane *lfv, const adore::params::APLongitudinalPlanner *plon)
 
virtual double getValue (double t, double s, double ds) const override
 
virtual void update (double t0, double s0, double ds0) override
 
virtual ConstraintDirection getDirection () override
 
virtual int getDimension () override
 
virtual int getDerivative () override
 

Private Attributes

adore::view::ALanelfv_
 
const adore::params::APLongitudinalPlannerplon_
 
double min_width_stop_
 
double min_width_slow_
 
double min_width_slow_speed_
 
double min_width_fast_
 
double min_width_fast_speed_
 

Additional Inherited Members

- Public Types inherited from adore::fun::ANominalConstraint
enum  ConstraintDirection { LB , UB }
 

Detailed Description

LaneWidthSpeedLimitLFV - constrain speed according to available space on lane

Constructor & Destructor Documentation

◆ LaneWidthSpeedLimitLFV()

adore::fun::LaneWidthSpeedLimitLFV::LaneWidthSpeedLimitLFV ( adore::view::ALane lfv,
const adore::params::APLongitudinalPlanner plon 
)
inline

Member Function Documentation

◆ getDerivative()

virtual int adore::fun::LaneWidthSpeedLimitLFV::getDerivative ( )
inlineoverridevirtual

Determine for which derivative of given dimension this constraint is responsible.

Returns
applicable to which state derivative

Implements adore::fun::ANominalConstraint.

◆ getDimension()

virtual int adore::fun::LaneWidthSpeedLimitLFV::getDimension ( )
inlineoverridevirtual

Determine for which dimension this constraint is responsible (e.g. longitudinal, lateral, etc.)

Returns
applicable to which dimension, depends on setup of planner

Implements adore::fun::ANominalConstraint.

◆ getDirection()

virtual ConstraintDirection adore::fun::LaneWidthSpeedLimitLFV::getDirection ( )
inlineoverridevirtual

Determine whether this constraint is an upper or lower bound.

Returns
lb or ub

Implements adore::fun::ANominalConstraint.

◆ getValue()

virtual double adore::fun::LaneWidthSpeedLimitLFV::getValue ( double  t,
double  s,
double  ds 
) const
inlineoverridevirtual

return the value of the constraint at a certain time and position

Parameters
tthe time
sprogress along the road-relative coordinate system
dsderivative of s
Returns
value of the constraint (e.g. vmax for a speed limit)

Implements adore::fun::ANominalConstraint.

Here is the call graph for this function:

◆ update()

virtual void adore::fun::LaneWidthSpeedLimitLFV::update ( double  t0,
double  s0,
double  ds0 
)
inlineoverridevirtual

Refresh values of the constraint object. Allows parameters and precomputations to buffered for one planning cycle.

Parameters
t0start time for planning
s0start progress in road-relative coordinate system
ds0derivative of s at t0

Implements adore::fun::ANominalConstraint.

Here is the call graph for this function:

Member Data Documentation

◆ lfv_

adore::view::ALane* adore::fun::LaneWidthSpeedLimitLFV::lfv_
private

◆ min_width_fast_

double adore::fun::LaneWidthSpeedLimitLFV::min_width_fast_
private

◆ min_width_fast_speed_

double adore::fun::LaneWidthSpeedLimitLFV::min_width_fast_speed_
private

◆ min_width_slow_

double adore::fun::LaneWidthSpeedLimitLFV::min_width_slow_
private

◆ min_width_slow_speed_

double adore::fun::LaneWidthSpeedLimitLFV::min_width_slow_speed_
private

◆ min_width_stop_

double adore::fun::LaneWidthSpeedLimitLFV::min_width_stop_
private

◆ plon_

const adore::params::APLongitudinalPlanner* adore::fun::LaneWidthSpeedLimitLFV::plon_
private

The documentation for this class was generated from the following file: