WPILibC++ 2025.2.1
|
Represents the wheel speeds for a differential drive drivetrain. More...
#include <frc/kinematics/DifferentialDriveWheelSpeeds.h>
Public Member Functions | |
constexpr void | Desaturate (units::meters_per_second_t attainableMaxSpeed) |
Renormalizes the wheel speeds if either side is above the specified maximum. | |
constexpr DifferentialDriveWheelSpeeds | operator+ (const DifferentialDriveWheelSpeeds &other) const |
Adds two DifferentialDriveWheelSpeeds and returns the sum. | |
constexpr DifferentialDriveWheelSpeeds | operator- (const DifferentialDriveWheelSpeeds &other) const |
Subtracts the other DifferentialDriveWheelSpeeds from the current DifferentialDriveWheelSpeeds and returns the difference. | |
constexpr DifferentialDriveWheelSpeeds | operator- () const |
Returns the inverse of the current DifferentialDriveWheelSpeeds. | |
constexpr DifferentialDriveWheelSpeeds | operator* (double scalar) const |
Multiplies the DifferentialDriveWheelSpeeds by a scalar and returns the new DifferentialDriveWheelSpeeds. | |
constexpr DifferentialDriveWheelSpeeds | operator/ (double scalar) const |
Divides the DifferentialDriveWheelSpeeds by a scalar and returns the new DifferentialDriveWheelSpeeds. | |
Public Attributes | |
units::meters_per_second_t | left = 0_mps |
Speed of the left side of the robot. | |
units::meters_per_second_t | right = 0_mps |
Speed of the right side of the robot. | |
Represents the wheel speeds for a differential drive drivetrain.
|
inlineconstexpr |
Renormalizes the wheel speeds if either side is above the specified maximum.
Sometimes, after inverse kinematics, the requested speed from one or more wheels may be above the max attainable speed for the driving motor on that wheel. To fix this issue, one can reduce all the wheel speeds to make sure that all requested module speeds are at-or-below the absolute threshold, while maintaining the ratio of speeds between wheels.
attainableMaxSpeed | The absolute max speed that a wheel can reach. |
|
inlineconstexpr |
Multiplies the DifferentialDriveWheelSpeeds by a scalar and returns the new DifferentialDriveWheelSpeeds.
For example, DifferentialDriveWheelSpeeds{2.0, 2.5} * 2 = DifferentialDriveWheelSpeeds{4.0, 5.0}
scalar | The scalar to multiply by. |
|
inlineconstexpr |
Adds two DifferentialDriveWheelSpeeds and returns the sum.
For example, DifferentialDriveWheelSpeeds{1.0, 0.5} + DifferentialDriveWheelSpeeds{2.0, 1.5} = DifferentialDriveWheelSpeeds{3.0, 2.0}
other | The DifferentialDriveWheelSpeeds to add. |
|
inlineconstexpr |
Returns the inverse of the current DifferentialDriveWheelSpeeds.
This is equivalent to negating all components of the DifferentialDriveWheelSpeeds.
|
inlineconstexpr |
Subtracts the other DifferentialDriveWheelSpeeds from the current DifferentialDriveWheelSpeeds and returns the difference.
For example, DifferentialDriveWheelSpeeds{5.0, 4.0} - DifferentialDriveWheelSpeeds{1.0, 2.0} = DifferentialDriveWheelSpeeds{4.0, 2.0}
other | The DifferentialDriveWheelSpeeds to subtract. |
|
inlineconstexpr |
Divides the DifferentialDriveWheelSpeeds by a scalar and returns the new DifferentialDriveWheelSpeeds.
For example, DifferentialDriveWheelSpeeds{2.0, 2.5} / 2 = DifferentialDriveWheelSpeeds{1.0, 1.25}
scalar | The scalar to divide by. |
units::meters_per_second_t frc::DifferentialDriveWheelSpeeds::left = 0_mps |
Speed of the left side of the robot.
units::meters_per_second_t frc::DifferentialDriveWheelSpeeds::right = 0_mps |
Speed of the right side of the robot.