2020-12-26 14:12:05 -08:00
|
|
|
// Copyright (c) FIRST and other WPILib contributors.
|
|
|
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
|
|
|
// the WPILib BSD license file in the root directory of this project.
|
2020-11-28 17:35:35 -05:00
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <frc/AnalogGyro.h>
|
|
|
|
|
#include <frc/Encoder.h>
|
|
|
|
|
#include <frc/controller/PIDController.h>
|
|
|
|
|
#include <frc/controller/SimpleMotorFeedforward.h>
|
|
|
|
|
#include <frc/estimator/DifferentialDrivePoseEstimator.h>
|
|
|
|
|
#include <frc/kinematics/DifferentialDriveKinematics.h>
|
2021-04-17 11:27:16 -07:00
|
|
|
#include <frc/motorcontrol/MotorControllerGroup.h>
|
|
|
|
|
#include <frc/motorcontrol/PWMSparkMax.h>
|
2020-11-28 17:35:35 -05:00
|
|
|
#include <units/angle.h>
|
|
|
|
|
#include <units/angular_velocity.h>
|
|
|
|
|
#include <units/length.h>
|
|
|
|
|
#include <units/velocity.h>
|
2021-05-26 00:09:36 -07:00
|
|
|
#include <wpi/numbers>
|
2020-11-28 17:35:35 -05:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Represents a differential drive style drivetrain.
|
|
|
|
|
*/
|
|
|
|
|
class Drivetrain {
|
|
|
|
|
public:
|
|
|
|
|
Drivetrain() {
|
2021-06-13 18:43:16 -04:00
|
|
|
// We need to invert one side of the drivetrain so that positive voltages
|
|
|
|
|
// result in both sides moving forward. Depending on how your robot's
|
|
|
|
|
// gearbox is constructed, you might have to invert the left side instead.
|
|
|
|
|
m_rightGroup.SetInverted(true);
|
|
|
|
|
|
2020-11-28 17:35:35 -05:00
|
|
|
m_gyro.Reset();
|
|
|
|
|
// Set the distance per pulse for the drive encoders. We can simply use the
|
|
|
|
|
// distance traveled for one rotation of the wheel divided by the encoder
|
|
|
|
|
// resolution.
|
|
|
|
|
m_leftEncoder.SetDistancePerPulse(
|
2021-10-25 08:58:12 -07:00
|
|
|
2 * wpi::numbers::pi * kWheelRadius.value() / kEncoderResolution);
|
2020-11-28 17:35:35 -05:00
|
|
|
m_rightEncoder.SetDistancePerPulse(
|
2021-10-25 08:58:12 -07:00
|
|
|
2 * wpi::numbers::pi * kWheelRadius.value() / kEncoderResolution);
|
2020-11-28 17:35:35 -05:00
|
|
|
|
|
|
|
|
m_leftEncoder.Reset();
|
|
|
|
|
m_rightEncoder.Reset();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static constexpr units::meters_per_second_t kMaxSpeed =
|
|
|
|
|
3.0_mps; // 3 meters per second
|
|
|
|
|
static constexpr units::radians_per_second_t kMaxAngularSpeed{
|
2021-05-26 00:09:36 -07:00
|
|
|
wpi::numbers::pi}; // 1/2 rotation per second
|
2020-11-28 17:35:35 -05:00
|
|
|
|
|
|
|
|
void SetSpeeds(const frc::DifferentialDriveWheelSpeeds& speeds);
|
|
|
|
|
void Drive(units::meters_per_second_t xSpeed,
|
|
|
|
|
units::radians_per_second_t rot);
|
|
|
|
|
void UpdateOdometry();
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
static constexpr units::meter_t kTrackWidth = 0.381_m * 2;
|
|
|
|
|
static constexpr units::meter_t kWheelRadius = 0.0508_m;
|
|
|
|
|
static constexpr int kEncoderResolution = 4096;
|
|
|
|
|
|
2021-02-13 01:14:56 -05:00
|
|
|
frc::PWMSparkMax m_leftLeader{1};
|
|
|
|
|
frc::PWMSparkMax m_leftFollower{2};
|
|
|
|
|
frc::PWMSparkMax m_rightLeader{3};
|
|
|
|
|
frc::PWMSparkMax m_rightFollower{4};
|
2020-11-28 17:35:35 -05:00
|
|
|
|
2021-04-17 11:27:16 -07:00
|
|
|
frc::MotorControllerGroup m_leftGroup{m_leftLeader, m_leftFollower};
|
|
|
|
|
frc::MotorControllerGroup m_rightGroup{m_rightLeader, m_rightFollower};
|
2020-11-28 17:35:35 -05:00
|
|
|
|
|
|
|
|
frc::Encoder m_leftEncoder{0, 1};
|
|
|
|
|
frc::Encoder m_rightEncoder{2, 3};
|
|
|
|
|
|
|
|
|
|
frc2::PIDController m_leftPIDController{1.0, 0.0, 0.0};
|
|
|
|
|
frc2::PIDController m_rightPIDController{1.0, 0.0, 0.0};
|
|
|
|
|
|
|
|
|
|
frc::AnalogGyro m_gyro{0};
|
|
|
|
|
|
|
|
|
|
frc::DifferentialDriveKinematics m_kinematics{kTrackWidth};
|
|
|
|
|
|
|
|
|
|
// Gains are for example purposes only - must be determined for your own
|
|
|
|
|
// robot!
|
|
|
|
|
frc::DifferentialDrivePoseEstimator m_poseEstimator{
|
2022-08-17 13:42:36 -07:00
|
|
|
frc::Rotation2d{},
|
|
|
|
|
frc::Pose2d{},
|
2020-11-28 17:35:35 -05:00
|
|
|
{0.01, 0.01, 0.01, 0.01, 0.01},
|
|
|
|
|
{0.1, 0.1, 0.1},
|
|
|
|
|
{0.1, 0.1, 0.1}};
|
|
|
|
|
|
|
|
|
|
// Gains are for example purposes only - must be determined for your own
|
|
|
|
|
// robot!
|
|
|
|
|
frc::SimpleMotorFeedforward<units::meters> m_feedforward{1_V, 3_V / 1_mps};
|
|
|
|
|
};
|