Class SpeedLimiter

Class Documentation

class SpeedLimiter

Public Functions

inline explicit SpeedLimiter(bool has_velocity_limits = true, bool has_acceleration_limits = true, bool has_jerk_limits = true, double min_velocity = std::numeric_limits<double>::quiet_NaN(), double max_velocity = std::numeric_limits<double>::quiet_NaN(), double max_deceleration = std::numeric_limits<double>::quiet_NaN(), double max_acceleration = std::numeric_limits<double>::quiet_NaN(), double min_jerk = std::numeric_limits<double>::quiet_NaN(), double max_jerk = std::numeric_limits<double>::quiet_NaN())

Constructor.

Parameters:
  • has_velocity_limits[in] if true, applies velocity limits

  • has_acceleration_limits[in] if true, applies acceleration limits

  • has_jerk_limits[in] if true, applies jerk limits

  • min_velocity[in] Minimum velocity [m/s], usually <= 0

  • max_velocity[in] Maximum velocity [m/s], usually >= 0

  • max_deceleration[in] Maximum deceleration [m/s^2], usually <= 0

  • max_acceleration[in] Maximum acceleration [m/s^2], usually >= 0

  • min_jerk[in] Minimum jerk [m/s^3], usually <= 0

  • max_jerk[in] Maximum jerk [m/s^3], usually >= 0

inline explicit SpeedLimiter(double min_velocity, double max_velocity, double max_acceleration_reverse, double max_acceleration, double max_deceleration, double max_deceleration_reverse, double min_jerk, double max_jerk)

Constructor.

Note

If max_* values are NAN, the respective limit is deactivated If min_* values are NAN (unspecified), defaults to -max If min_first_derivative_pos/max_first_derivative_neg values are NAN, symmetric limits are used

Parameters:
  • min_velocity[in] Minimum velocity [m/s], usually <= 0

  • max_velocity[in] Maximum velocity [m/s], usually >= 0

  • max_acceleration_reverse[in] Maximum acceleration in reverse direction [m/s^2], usually <= 0

  • max_acceleration[in] Maximum acceleration [m/s^2], usually >= 0

  • max_deceleration[in] Maximum deceleration [m/s^2], usually <= 0

  • max_deceleration_reverse[in] Maximum deceleration in reverse direction [m/s^2], usually >= 0

  • min_jerk[in] Minimum jerk [m/s^3], usually <= 0

  • max_jerk[in] Maximum jerk [m/s^3], usually >= 0

inline double limit(double &v, double v0, double v1, double dt)

Limit the velocity and acceleration.

Parameters:
  • v[inout] Velocity [m/s]

  • v0[in] Previous velocity to v [m/s]

  • v1[in] Previous velocity to v0 [m/s]

  • dt[in] Time step [s]

Returns:

Limiting factor (1.0 if none)

inline double limit_velocity(double &v)

Limit the velocity.

Parameters:

v[inout] Velocity [m/s]

Returns:

Limiting factor (1.0 if none)

inline double limit_acceleration(double &v, double v0, double dt)

Limit the acceleration.

Parameters:
  • v[inout] Velocity [m/s]

  • v0[in] Previous velocity [m/s]

  • dt[in] Time step [s]

Returns:

Limiting factor (1.0 if none)

inline double limit_jerk(double &v, double v0, double v1, double dt)

Limit the jerk.

Parameters:
  • v[inout] Velocity [m/s]

  • v0[in] Previous velocity to v [m/s]

  • v1[in] Previous velocity to v0 [m/s]

  • dt[in] Time step [s]

Returns:

Limiting factor (1.0 if none)