2020-11-13 14:12:03 -05:00
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
/* Copyright (c) 2019-2020 FIRST. All Rights Reserved. */
|
|
|
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
|
|
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
|
|
|
|
/* the project. */
|
|
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <frc/AnalogGyro.h>
|
|
|
|
|
#include <frc/Encoder.h>
|
|
|
|
|
#include <frc/PWMVictorSPX.h>
|
|
|
|
|
#include <frc/SpeedControllerGroup.h>
|
|
|
|
|
#include <frc/drive/DifferentialDrive.h>
|
|
|
|
|
#include <frc/geometry/Pose2d.h>
|
|
|
|
|
#include <frc/kinematics/DifferentialDriveOdometry.h>
|
|
|
|
|
#include <frc/simulation/AnalogGyroSim.h>
|
|
|
|
|
#include <frc/simulation/DifferentialDrivetrainSim.h>
|
|
|
|
|
#include <frc/simulation/EncoderSim.h>
|
2020-10-30 13:55:38 -07:00
|
|
|
#include <frc/smartdashboard/Field2d.h>
|
2020-11-13 14:12:03 -05:00
|
|
|
#include <frc2/command/SubsystemBase.h>
|
|
|
|
|
#include <units/voltage.h>
|
|
|
|
|
|
|
|
|
|
#include "Constants.h"
|
|
|
|
|
|
|
|
|
|
class DriveSubsystem : public frc2::SubsystemBase {
|
|
|
|
|
public:
|
|
|
|
|
DriveSubsystem();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Will be called periodically whenever the CommandScheduler runs.
|
|
|
|
|
*/
|
|
|
|
|
void Periodic() override;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Will be called periodically during simulation.
|
|
|
|
|
*/
|
|
|
|
|
void SimulationPeriodic() override;
|
|
|
|
|
|
|
|
|
|
// Subsystem methods go here.
|
|
|
|
|
|
|
|
|
|
units::ampere_t GetCurrentDraw() const;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Drives the robot using arcade controls.
|
|
|
|
|
*
|
|
|
|
|
* @param fwd the commanded forward movement
|
|
|
|
|
* @param rot the commanded rotation
|
|
|
|
|
*/
|
|
|
|
|
void ArcadeDrive(double fwd, double rot);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Controls each side of the drive directly with a voltage.
|
|
|
|
|
*
|
|
|
|
|
* @param left the commanded left output
|
|
|
|
|
* @param right the commanded right output
|
|
|
|
|
*/
|
|
|
|
|
void TankDriveVolts(units::volt_t left, units::volt_t right);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Resets the drive encoders to currently read a position of 0.
|
|
|
|
|
*/
|
|
|
|
|
void ResetEncoders();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Gets the average distance of the TWO encoders.
|
|
|
|
|
*
|
|
|
|
|
* @return the average of the TWO encoder readings
|
|
|
|
|
*/
|
|
|
|
|
double GetAverageEncoderDistance();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Gets the left drive encoder.
|
|
|
|
|
*
|
|
|
|
|
* @return the left drive encoder
|
|
|
|
|
*/
|
|
|
|
|
frc::Encoder& GetLeftEncoder();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Gets the right drive encoder.
|
|
|
|
|
*
|
|
|
|
|
* @return the right drive encoder
|
|
|
|
|
*/
|
|
|
|
|
frc::Encoder& GetRightEncoder();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Sets the max output of the drive. Useful for scaling the drive to drive
|
|
|
|
|
* more slowly.
|
|
|
|
|
*
|
|
|
|
|
* @param maxOutput the maximum output to which the drive will be constrained
|
|
|
|
|
*/
|
|
|
|
|
void SetMaxOutput(double maxOutput);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the heading of the robot.
|
|
|
|
|
*
|
|
|
|
|
* @return the robot's heading in degrees, from -180 to 180
|
|
|
|
|
*/
|
|
|
|
|
units::degree_t GetHeading() const;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the turn rate of the robot.
|
|
|
|
|
*
|
|
|
|
|
* @return The turn rate of the robot, in degrees per second
|
|
|
|
|
*/
|
|
|
|
|
double GetTurnRate();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the currently-estimated pose of the robot.
|
|
|
|
|
*
|
|
|
|
|
* @return The pose.
|
|
|
|
|
*/
|
|
|
|
|
frc::Pose2d GetPose();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns the current wheel speeds of the robot.
|
|
|
|
|
*
|
|
|
|
|
* @return The current wheel speeds.
|
|
|
|
|
*/
|
|
|
|
|
frc::DifferentialDriveWheelSpeeds GetWheelSpeeds();
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Resets the odometry to the specified pose.
|
|
|
|
|
*
|
|
|
|
|
* @param pose The pose to which to set the odometry.
|
|
|
|
|
*/
|
|
|
|
|
void ResetOdometry(frc::Pose2d pose);
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
// Components (e.g. motor controllers and sensors) should generally be
|
|
|
|
|
// declared private and exposed only through public methods.
|
|
|
|
|
|
|
|
|
|
// The motor controllers
|
|
|
|
|
frc::PWMVictorSPX m_left1{DriveConstants::kLeftMotor1Port};
|
|
|
|
|
frc::PWMVictorSPX m_left2{DriveConstants::kLeftMotor2Port};
|
|
|
|
|
frc::PWMVictorSPX m_right1{DriveConstants::kRightMotor1Port};
|
|
|
|
|
frc::PWMVictorSPX m_right2{DriveConstants::kRightMotor2Port};
|
|
|
|
|
|
|
|
|
|
// The motors on the left side of the drive
|
|
|
|
|
frc::SpeedControllerGroup m_leftMotors{m_left1, m_left2};
|
|
|
|
|
|
|
|
|
|
// The motors on the right side of the drive
|
|
|
|
|
frc::SpeedControllerGroup m_rightMotors{m_right1, m_right2};
|
|
|
|
|
|
|
|
|
|
// The robot's drive
|
|
|
|
|
frc::DifferentialDrive m_drive{m_leftMotors, m_rightMotors};
|
|
|
|
|
|
|
|
|
|
// The left-side drive encoder
|
|
|
|
|
frc::Encoder m_leftEncoder{DriveConstants::kLeftEncoderPorts[0],
|
|
|
|
|
DriveConstants::kLeftEncoderPorts[1]};
|
|
|
|
|
|
|
|
|
|
// The right-side drive encoder
|
|
|
|
|
frc::Encoder m_rightEncoder{DriveConstants::kRightEncoderPorts[0],
|
|
|
|
|
DriveConstants::kRightEncoderPorts[1]};
|
|
|
|
|
|
|
|
|
|
// The gyro sensor
|
|
|
|
|
frc::AnalogGyro m_gyro{0};
|
|
|
|
|
|
|
|
|
|
// Odometry class for tracking robot pose
|
|
|
|
|
frc::DifferentialDriveOdometry m_odometry{m_gyro.GetRotation2d()};
|
|
|
|
|
|
|
|
|
|
// These classes help simulate our drivetrain.
|
|
|
|
|
frc::sim::DifferentialDrivetrainSim m_drivetrainSimulator{
|
2020-12-04 18:46:50 -08:00
|
|
|
DriveConstants::kDrivetrainPlant,
|
|
|
|
|
DriveConstants::kTrackwidth,
|
|
|
|
|
DriveConstants::kDrivetrainGearbox,
|
|
|
|
|
DriveConstants::kDrivetrainGearing,
|
|
|
|
|
DriveConstants::kWheelDiameter / 2,
|
|
|
|
|
{0.001, 0.001, 0.0001, 0.1, 0.1, 0.005, 0.005}};
|
2020-11-13 14:12:03 -05:00
|
|
|
|
|
|
|
|
frc::sim::EncoderSim m_leftEncoderSim{m_leftEncoder};
|
|
|
|
|
frc::sim::EncoderSim m_rightEncoderSim{m_rightEncoder};
|
|
|
|
|
frc::sim::AnalogGyroSim m_gyroAngleSim{m_gyro};
|
|
|
|
|
|
2020-10-30 13:55:38 -07:00
|
|
|
// The Field2d class shows the field in the sim GUI.
|
2020-11-13 14:12:03 -05:00
|
|
|
frc::Field2d m_fieldSim;
|
|
|
|
|
};
|