WPILibC++  2020.3.2-60-g3011ebe
frc::DifferentialDriveOdometry Class Reference

Class for differential drive odometry. More...

#include <DifferentialDriveOdometry.h>

## Public Member Functions

DifferentialDriveOdometry (const Rotation2d &gyroAngle, const Pose2d &initialPose=Pose2d())
Constructs a DifferentialDriveOdometry object. More...

void ResetPosition (const Pose2d &pose, const Rotation2d &gyroAngle)
Resets the robot's position on the field. More...

const Pose2dGetPose () const
Returns the position of the robot on the field. More...

const Pose2dUpdate (const Rotation2d &gyroAngle, units::meter_t leftDistance, units::meter_t rightDistance)
Updates the robot position on the field using distance measurements from encoders. More...

## Detailed Description

Class for differential drive odometry.

Odometry allows you to track the robot's position on the field over the course of a match using readings from 2 encoders and a gyroscope.

Teams can use odometry during the autonomous period for complex tasks like path following. Furthermore, odometry can be used for latency compensation when using computer-vision systems.

It is important that you reset your encoders to zero before using this class. Any subsequent pose resets also require the encoders to be reset to zero.

## ◆ DifferentialDriveOdometry()

 frc::DifferentialDriveOdometry::DifferentialDriveOdometry ( const Rotation2d & gyroAngle, const Pose2d & initialPose = Pose2d() )
explicit

Constructs a DifferentialDriveOdometry object.

Parameters
 gyroAngle The angle reported by the gyroscope. initialPose The starting position of the robot on the field.

## ◆ GetPose()

 const Pose2d& frc::DifferentialDriveOdometry::GetPose ( ) const
inline

Returns the position of the robot on the field.

Returns
The pose of the robot.

## ◆ ResetPosition()

 void frc::DifferentialDriveOdometry::ResetPosition ( const Pose2d & pose, const Rotation2d & gyroAngle )
inline

Resets the robot's position on the field.

You NEED to reset your encoders (to zero) when calling this method.

The gyroscope angle does not need to be reset here on the user's robot code. The library automatically takes care of offsetting the gyro angle.

Parameters
 pose The position on the field that your robot is at. gyroAngle The angle reported by the gyroscope.

## ◆ Update()

 const Pose2d& frc::DifferentialDriveOdometry::Update ( const Rotation2d & gyroAngle, units::meter_t leftDistance, units::meter_t rightDistance )

Updates the robot position on the field using distance measurements from encoders.

This method is more numerically accurate than using velocities to integrate the pose and is also advantageous for teams that are using lower CPR encoders.

Parameters
 gyroAngle The angle reported by the gyroscope. leftDistance The distance traveled by the left encoder. rightDistance The distance traveled by the right encoder.
Returns
The new pose of the robot.

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