001// Copyright (c) FIRST and other WPILib contributors. 002// Open Source Software; you can modify and/or share it under the terms of 003// the WPILib BSD license file in the root directory of this project. 004 005package edu.wpi.first.math.kinematics; 006 007import edu.wpi.first.math.MathSharedStore; 008import edu.wpi.first.math.MathUsageId; 009import edu.wpi.first.math.geometry.Pose2d; 010import edu.wpi.first.math.geometry.Rotation2d; 011 012/** 013 * Class for mecanum drive odometry. Odometry allows you to track the robot's position on the field 014 * over a course of a match using readings from your mecanum wheel encoders. 015 * 016 * <p>Teams can use odometry during the autonomous period for complex tasks like path following. 017 * Furthermore, odometry can be used for latency compensation when using computer-vision systems. 018 */ 019public class MecanumDriveOdometry extends Odometry<MecanumDriveWheelPositions> { 020 /** 021 * Constructs a MecanumDriveOdometry object. 022 * 023 * @param kinematics The mecanum drive kinematics for your drivetrain. 024 * @param gyroAngle The angle reported by the gyroscope. 025 * @param wheelPositions The distances driven by each wheel. 026 * @param initialPoseMeters The starting position of the robot on the field. 027 */ 028 public MecanumDriveOdometry( 029 MecanumDriveKinematics kinematics, 030 Rotation2d gyroAngle, 031 MecanumDriveWheelPositions wheelPositions, 032 Pose2d initialPoseMeters) { 033 super(kinematics, gyroAngle, wheelPositions, initialPoseMeters); 034 MathSharedStore.reportUsage(MathUsageId.kOdometry_MecanumDrive, 1); 035 } 036 037 /** 038 * Constructs a MecanumDriveOdometry object with the default pose at the origin. 039 * 040 * @param kinematics The mecanum drive kinematics for your drivetrain. 041 * @param gyroAngle The angle reported by the gyroscope. 042 * @param wheelPositions The distances driven by each wheel. 043 */ 044 public MecanumDriveOdometry( 045 MecanumDriveKinematics kinematics, 046 Rotation2d gyroAngle, 047 MecanumDriveWheelPositions wheelPositions) { 048 this(kinematics, gyroAngle, wheelPositions, Pose2d.kZero); 049 } 050}