WPILibC++ 2025.2.1
|
A Exponential-shaped velocity profile. More...
#include <frc/trajectory/ExponentialProfile.h>
Classes | |
class | Constraints |
Profile constraints. More... | |
class | ProfileTiming |
Profile timing. More... | |
class | State |
Profile state. More... | |
Public Types | |
using | Distance_t = units::unit_t<Distance> |
using | Velocity |
using | Velocity_t = units::unit_t<Velocity> |
using | Acceleration |
using | Input_t = units::unit_t<Input> |
using | A_t = units::unit_t<units::inverse<units::seconds>> |
using | B_t |
using | KV = units::compound_unit<Input, units::inverse<Velocity>> |
using | kV_t = units::unit_t<KV> |
using | KA = units::compound_unit<Input, units::inverse<Acceleration>> |
using | kA_t = units::unit_t<KA> |
Public Member Functions | |
constexpr | ExponentialProfile (Constraints constraints) |
Constructs a ExponentialProfile. | |
constexpr | ExponentialProfile (const ExponentialProfile &)=default |
constexpr ExponentialProfile & | operator= (const ExponentialProfile &)=default |
constexpr | ExponentialProfile (ExponentialProfile &&)=default |
constexpr ExponentialProfile & | operator= (ExponentialProfile &&)=default |
constexpr State | Calculate (const units::second_t &t, const State ¤t, const State &goal) const |
Calculates the position and velocity for the profile at a time t where the current state is at time t = 0. | |
constexpr State | CalculateInflectionPoint (const State ¤t, const State &goal) const |
Calculates the point after which the fastest way to reach the goal state is to apply input in the opposite direction. | |
constexpr units::second_t | TimeLeftUntil (const State ¤t, const State &goal) const |
Calculates the time it will take for this profile to reach the goal state. | |
constexpr ProfileTiming | CalculateProfileTiming (const State ¤t, const State &goal) const |
Calculates the time it will take for this profile to reach the inflection point, and the time it will take for this profile to reach the goal state. | |
A Exponential-shaped velocity profile.
While this class can be used for a profiled movement from start to finish, the intended usage is to filter a reference's dynamics based on ExponentialProfile velocity constraints. To compute the reference obeying this constraint, do the following.
Initialization:
Run on update:
where unprofiledReference
is free to change between calls. Note that when the unprofiled reference is within the constraints, Calculate()
returns the unprofiled reference unchanged.
Otherwise, a timer can be started to provide monotonic values for Calculate()
and to determine when the profile has completed via IsFinished()
.
using frc::ExponentialProfile< Distance, Input >::A_t = units::unit_t<units::inverse<units::seconds>> |
using frc::ExponentialProfile< Distance, Input >::Acceleration |
using frc::ExponentialProfile< Distance, Input >::B_t |
using frc::ExponentialProfile< Distance, Input >::Distance_t = units::unit_t<Distance> |
using frc::ExponentialProfile< Distance, Input >::Input_t = units::unit_t<Input> |
using frc::ExponentialProfile< Distance, Input >::KA = units::compound_unit<Input, units::inverse<Acceleration>> |
using frc::ExponentialProfile< Distance, Input >::kA_t = units::unit_t<KA> |
using frc::ExponentialProfile< Distance, Input >::KV = units::compound_unit<Input, units::inverse<Velocity>> |
using frc::ExponentialProfile< Distance, Input >::kV_t = units::unit_t<KV> |
using frc::ExponentialProfile< Distance, Input >::Velocity |
using frc::ExponentialProfile< Distance, Input >::Velocity_t = units::unit_t<Velocity> |
|
inlineexplicitconstexpr |
Constructs a ExponentialProfile.
constraints | The constraints on the profile, like maximum input. |
|
constexprdefault |
|
constexprdefault |
|
inlineconstexpr |
Calculates the position and velocity for the profile at a time t where the current state is at time t = 0.
t | How long to advance from the current state toward the desired state. |
current | The current state. |
goal | The desired state when the profile is complete. |
|
inlineconstexpr |
Calculates the point after which the fastest way to reach the goal state is to apply input in the opposite direction.
current | The current state. |
goal | The desired state when the profile is complete. |
|
inlineconstexpr |
Calculates the time it will take for this profile to reach the inflection point, and the time it will take for this profile to reach the goal state.
current | The current state. |
goal | The desired state when the profile is complete. |
|
constexprdefault |
|
constexprdefault |
|
inlineconstexpr |
Calculates the time it will take for this profile to reach the goal state.
current | The current state. |
goal | The desired state when the profile is complete. |