Helper class that converts a chassis velocity (dx, dy, and dtheta components) into individual module states (speed and angle).  
 More...
|  | 
| template<std::convertible_to< Translation2d >... ModuleTranslations> requires (sizeof...(ModuleTranslations) == NumModules)
 | 
|  | SwerveDriveKinematics (ModuleTranslations &&... moduleTranslations) | 
|  | Constructs a swerve drive kinematics object. 
 | 
|  | 
|  | SwerveDriveKinematics (const wpi::array< Translation2d, NumModules > &modules) | 
|  | 
|  | SwerveDriveKinematics (const SwerveDriveKinematics &)=default | 
|  | 
| template<std::convertible_to< Rotation2d >... ModuleHeadings> requires (sizeof...(ModuleHeadings) == NumModules)
 | 
| void | ResetHeadings (ModuleHeadings &&... moduleHeadings) | 
|  | Reset the internal swerve module headings. 
 | 
|  | 
| void | ResetHeadings (wpi::array< Rotation2d, NumModules > moduleHeadings) | 
|  | Reset the internal swerve module headings. 
 | 
|  | 
| wpi::array< SwerveModuleState, NumModules > | ToSwerveModuleStates (const ChassisSpeeds &chassisSpeeds, const Translation2d ¢erOfRotation=Translation2d{}) const | 
|  | Performs inverse kinematics to return the module states from a desired chassis velocity. 
 | 
|  | 
| wpi::array< SwerveModuleState, NumModules > | ToWheelSpeeds (const ChassisSpeeds &chassisSpeeds) const override | 
|  | Performs inverse kinematics to return the wheel speeds from a desired chassis velocity. 
 | 
|  | 
| template<std::convertible_to< SwerveModuleState >... ModuleStates> requires (sizeof...(ModuleStates) == NumModules)
 | 
| ChassisSpeeds | ToChassisSpeeds (ModuleStates &&... moduleStates) const | 
|  | Performs forward kinematics to return the resulting chassis state from the given module states. 
 | 
|  | 
| ChassisSpeeds | ToChassisSpeeds (const wpi::array< SwerveModuleState, NumModules > &moduleStates) const override | 
|  | Performs forward kinematics to return the resulting chassis state from the given module states. 
 | 
|  | 
| template<std::convertible_to< SwerveModulePosition >... ModuleDeltas> requires (sizeof...(ModuleDeltas) == NumModules)
 | 
| Twist2d | ToTwist2d (ModuleDeltas &&... moduleDeltas) const | 
|  | Performs forward kinematics to return the resulting Twist2d from the given module position deltas. 
 | 
|  | 
| Twist2d | ToTwist2d (wpi::array< SwerveModulePosition, NumModules > moduleDeltas) const | 
|  | Performs forward kinematics to return the resulting Twist2d from the given module position deltas. 
 | 
|  | 
| Twist2d | ToTwist2d (const wpi::array< SwerveModulePosition, NumModules > &start, const wpi::array< SwerveModulePosition, NumModules > &end) const override | 
|  | Performs forward kinematics to return the resulting Twist2d from the given change in wheel positions. 
 | 
|  | 
| wpi::array< SwerveModulePosition, NumModules > | Interpolate (const wpi::array< SwerveModulePosition, NumModules > &start, const wpi::array< SwerveModulePosition, NumModules > &end, double t) const override | 
|  | Performs interpolation between two values. 
 | 
|  | 
| const wpi::array< Translation2d, NumModules > & | GetModules () const | 
|  | 
| virtual | ~Kinematics () noexcept=default | 
|  | 
template<size_t NumModules>
class frc::SwerveDriveKinematics< NumModules >
Helper class that converts a chassis velocity (dx, dy, and dtheta components) into individual module states (speed and angle). 
The inverse kinematics (converting from a desired chassis velocity to individual module states) uses the relative locations of the modules with respect to the center of rotation. The center of rotation for inverse kinematics is also variable. This means that you can set your set your center of rotation in a corner of the robot to perform special evasion maneuvers.
Forward kinematics (converting an array of module states into the overall chassis motion) is performs the exact opposite of what inverse kinematics does. Since this is an overdetermined system (more equations than variables), we use a least-squares approximation.
The inverse kinematics: [moduleStates] = [moduleLocations] * [chassisSpeeds] We take the Moore-Penrose pseudoinverse of [moduleLocations] and then multiply by [moduleStates] to get our chassis speeds.
Forward kinematics is also used for odometry – determining the position of the robot on the field using encoders and a gyro. 
template<size_t NumModules> 
  
  | 
        
          | static void frc::SwerveDriveKinematics< NumModules >::DesaturateWheelSpeeds | ( | wpi::array< SwerveModuleState, NumModules > * | moduleStates, |  
          |  |  | ChassisSpeeds | desiredChassisSpeed, |  
          |  |  | units::meters_per_second_t | attainableMaxModuleSpeed, |  
          |  |  | units::meters_per_second_t | attainableMaxRobotTranslationSpeed, |  
          |  |  | units::radians_per_second_t | attainableMaxRobotRotationSpeed ) |  | inlinestatic | 
 
Renormalizes the wheel speeds if any individual speed is above the specified maximum, as well as getting rid of joystick saturation at edges of joystick. 
Sometimes, after inverse kinematics, the requested speed from one or more modules may be above the max attainable speed for the driving motor on that module. 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 modules.
Scaling down the module speeds rotates the direction of net motion in the opposite direction of rotational velocity, which makes discretizing the chassis speeds inaccurate because the discretization did not account for this translational skew.
- Parameters
- 
  
    | moduleStates | Reference to array of module states. The array will be mutated with the normalized speeds! |  | desiredChassisSpeed | The desired speed of the robot |  | attainableMaxModuleSpeed | The absolute max speed a module can reach |  | attainableMaxRobotTranslationSpeed | The absolute max speed the robot can reach while translating |  | attainableMaxRobotRotationSpeed | The absolute max speed the robot can reach while rotating |  
 
 
 
template<size_t NumModules> 
 
Renormalizes the wheel speeds if any individual speed is above the specified maximum. 
Sometimes, after inverse kinematics, the requested speed from one or more modules may be above the max attainable speed for the driving motor on that module. 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 modules.
Scaling down the module speeds rotates the direction of net motion in the opposite direction of rotational velocity, which makes discretizing the chassis speeds inaccurate because the discretization did not account for this translational skew.
- Parameters
- 
  
    | moduleStates | Reference to array of module states. The array will be mutated with the normalized speeds! |  | attainableMaxSpeed | The absolute max speed that a module can reach. |  
 
 
 
template<size_t NumModules> 
 
Performs inverse kinematics to return the module states from a desired chassis velocity. 
This method is often used to convert joystick values into module speeds and angles.
This function also supports variable centers of rotation. During normal operations, the center of rotation is usually the same as the physical center of the robot; therefore, the argument is defaulted to that use case. However, if you wish to change the center of rotation for evasive maneuvers, vision alignment, or for any other use case, you can do so.
In the case that the desired chassis speeds are zero (i.e. the robot will be stationary), the previously calculated module angle will be maintained.
- Parameters
- 
  
    | chassisSpeeds | The desired chassis speed. |  | centerOfRotation | The center of rotation. For example, if you set the center of rotation at one corner of the robot and provide a chassis speed that only has a dtheta component, the robot will rotate around that corner. |  
 
- Returns
- An array containing the module states. Use caution because these module states are not normalized. Sometimes, a user input may cause one of the module speeds to go above the attainable max velocity. Use the DesaturateWheelSpeeds(wpi::array<SwerveModuleState, NumModules>*,
units::meters_per_second_t) function to rectify this issue. In addition, you can leverage the power of C++17 to directly assign the module states to variables:
auto [fl, fr, bl, br] = kinematics.ToSwerveModuleStates(chassisSpeeds);