Files
RiseOfRidgebotics2020/src/main/java/frc4388/robot/subsystems/Drive.java
T

544 lines
26 KiB
Java
Raw Normal View History

2020-01-09 23:55:46 +00:00
/*----------------------------------------------------------------------------*/
/* Copyright (c) 2018 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. */
/*----------------------------------------------------------------------------*/
package frc4388.robot.subsystems;
2020-02-07 21:49:04 -07:00
import com.ctre.phoenix.motorcontrol.ControlMode;
2020-01-23 16:42:20 -07:00
import com.ctre.phoenix.motorcontrol.DemandType;
2020-01-18 16:12:56 -07:00
import com.ctre.phoenix.motorcontrol.FeedbackDevice;
2020-01-23 16:42:20 -07:00
import com.ctre.phoenix.motorcontrol.FollowerType;
2020-01-09 23:55:46 +00:00
import com.ctre.phoenix.motorcontrol.InvertType;
import com.ctre.phoenix.motorcontrol.NeutralMode;
2020-01-20 10:40:12 -07:00
import com.ctre.phoenix.motorcontrol.RemoteSensorSource;
2020-01-18 16:12:56 -07:00
import com.ctre.phoenix.motorcontrol.SensorTerm;
2020-01-20 10:40:12 -07:00
import com.ctre.phoenix.motorcontrol.StatusFrame;
2020-01-16 17:56:18 -07:00
import com.ctre.phoenix.motorcontrol.TalonFXControlMode;
2020-01-10 23:13:59 -07:00
import com.ctre.phoenix.motorcontrol.can.WPI_TalonFX;
2020-01-09 18:05:16 -07:00
import com.ctre.phoenix.sensors.PigeonIMU;
2020-01-23 16:42:20 -07:00
import com.ctre.phoenix.sensors.PigeonIMU_StatusFrame;
2020-01-09 23:55:46 +00:00
import edu.wpi.first.wpilibj.DoubleSolenoid;
2020-01-09 23:55:46 +00:00
import edu.wpi.first.wpilibj.drive.DifferentialDrive;
2020-02-10 20:13:15 -07:00
import edu.wpi.first.wpilibj.geometry.Pose2d;
import edu.wpi.first.wpilibj.geometry.Rotation2d;
import edu.wpi.first.wpilibj.kinematics.DifferentialDriveOdometry;
import edu.wpi.first.wpilibj.kinematics.DifferentialDriveWheelSpeeds;
2020-01-20 11:59:23 -07:00
import edu.wpi.first.wpilibj.shuffleboard.Shuffleboard;
import edu.wpi.first.wpilibj.smartdashboard.SendableChooser;
2020-01-11 10:30:37 -07:00
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
2020-01-09 23:55:46 +00:00
import edu.wpi.first.wpilibj2.command.SubsystemBase;
import frc4388.robot.Constants.DriveConstants;
import frc4388.robot.Gains;
2020-01-09 23:55:46 +00:00
/**
* Add your docs here.
*/
2020-01-13 17:53:42 -07:00
public class Drive extends SubsystemBase {
2020-01-09 23:55:46 +00:00
// Put methods for controlling this subsystem
// here. Call these from Commands.
2020-02-01 15:30:41 -07:00
public WPI_TalonFX m_leftFrontMotor = new WPI_TalonFX(DriveConstants.DRIVE_LEFT_FRONT_CAN_ID);
public WPI_TalonFX m_rightFrontMotor = new WPI_TalonFX(DriveConstants.DRIVE_RIGHT_FRONT_CAN_ID);
public WPI_TalonFX m_leftBackMotor = new WPI_TalonFX(DriveConstants.DRIVE_LEFT_BACK_CAN_ID);
public WPI_TalonFX m_rightBackMotor = new WPI_TalonFX(DriveConstants.DRIVE_RIGHT_BACK_CAN_ID);
2020-01-09 18:05:16 -07:00
public static PigeonIMU m_pigeon = new PigeonIMU(DriveConstants.PIGEON_ID);
2020-01-09 23:55:46 +00:00
2020-02-01 15:30:41 -07:00
public DifferentialDrive m_driveTrain = new DifferentialDrive(m_leftFrontMotor, m_rightFrontMotor);
2020-01-09 23:55:46 +00:00
2020-01-20 11:59:23 -07:00
SendableChooser<Gains> m_chooser = new SendableChooser<Gains>();
2020-01-20 09:55:14 -08:00
public static Gains m_gainsDistance = DriveConstants.DRIVE_DISTANCE_GAINS;
public static Gains m_gainsVelocity = DriveConstants.DRIVE_VELOCITY_GAINS;
public static Gains m_gainsTurning = DriveConstants.DRIVE_TURNING_GAINS;
public static Gains m_gainsMotionMagic = DriveConstants.DRIVE_MOTION_MAGIC_GAINS;
2020-02-10 20:13:15 -07:00
public final DifferentialDriveOdometry m_odometry;
public DoubleSolenoid speedShift;
2020-02-10 20:13:15 -07:00
2020-01-09 23:55:46 +00:00
/**
* Add your docs here.
*/
2020-01-10 21:29:45 -07:00
public Drive() {
2020-01-09 23:55:46 +00:00
/* factory default values */
m_leftFrontMotor.configFactoryDefault();
m_rightFrontMotor.configFactoryDefault();
m_leftBackMotor.configFactoryDefault();
m_rightBackMotor.configFactoryDefault();
2020-02-07 17:50:23 -07:00
m_pigeon.configFactoryDefault();
resetGyroYaw();
2020-01-09 23:55:46 +00:00
2020-02-10 20:13:15 -07:00
m_odometry = new DifferentialDriveOdometry(Rotation2d.fromDegrees(getHeading()));
2020-02-08 16:10:21 -07:00
speedShift = new DoubleSolenoid(7,0,1);
2020-01-09 23:55:46 +00:00
/* set back motors as followers */
2020-02-01 15:30:41 -07:00
m_leftBackMotor.follow(m_leftFrontMotor);
m_rightBackMotor.follow(m_rightFrontMotor);
2020-02-01 13:48:52 -07:00
2020-02-01 16:10:39 -07:00
setDriveTrainNeutralMode(NeutralMode.Coast);
/* deadbands */
m_leftBackMotor.configNeutralDeadband(0.0, DriveConstants.DRIVE_TIMEOUT_MS); // DO NOT CHANGE
2020-02-10 20:13:15 -07:00
m_rightBackMotor.configNeutralDeadband(0.0, DriveConstants.DRIVE_TIMEOUT_MS); // Ensures motors run at the same
// speed
2020-02-01 16:10:39 -07:00
/* flip input so forward becomes back, etc */
m_leftFrontMotor.setInverted(false);
m_rightFrontMotor.setInverted(true);
m_driveTrain.setRightSideInverted(false);
m_leftBackMotor.setInverted(InvertType.FollowMaster);
m_rightBackMotor.setInverted(InvertType.FollowMaster);
2020-02-01 13:48:52 -07:00
2020-02-03 17:31:09 -07:00
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_VELOCITY, DriveConstants.PID_PRIMARY);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_VELOCITY, m_gainsVelocity.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_VELOCITY, m_gainsVelocity.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_VELOCITY, m_gainsVelocity.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_VELOCITY, m_gainsVelocity.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configClosedLoopPeakOutput(DriveConstants.SLOT_VELOCITY, m_gainsVelocity.m_kPeakOutput,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 10:40:12 -07:00
2020-02-06 18:36:04 -07:00
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_TURNING, DriveConstants.PID_TURN);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_TURNING, m_gainsTurning.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_TURNING, m_gainsTurning.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_TURNING, m_gainsTurning.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_TURNING, m_gainsTurning.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configClosedLoopPeakOutput(DriveConstants.SLOT_TURNING, m_gainsTurning.m_kPeakOutput,
DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_DISTANCE, DriveConstants.PID_PRIMARY);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_DISTANCE, m_gainsDistance.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_DISTANCE, m_gainsDistance.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_DISTANCE, m_gainsDistance.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_DISTANCE, m_gainsDistance.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configClosedLoopPeakOutput(DriveConstants.SLOT_DISTANCE, m_gainsDistance.m_kPeakOutput,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-06 18:36:04 -07:00
2020-02-07 21:49:04 -07:00
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_MOTION_MAGIC, DriveConstants.PID_PRIMARY);
m_rightFrontMotor.config_kF(DriveConstants.SLOT_MOTION_MAGIC, m_gainsMotionMagic.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_MOTION_MAGIC, m_gainsMotionMagic.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_MOTION_MAGIC, m_gainsMotionMagic.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_MOTION_MAGIC, m_gainsMotionMagic.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configMotionCruiseVelocity(DriveConstants.DRIVE_CRUISE_VELOCITY, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configMotionAcceleration(DriveConstants.DRIVE_ACCELERATION, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configMotionSCurveStrength(0, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-01 15:30:41 -07:00
/* Setup Sensors for WPI_TalonFXs */
2020-02-10 20:13:15 -07:00
resetEncoders();
2020-02-06 18:36:04 -07:00
2020-01-20 10:40:12 -07:00
/* Configure the left Talon's selected sensor as local QuadEncoder */
2020-02-10 20:13:15 -07:00
m_leftFrontMotor.configSelectedFeedbackSensor(FeedbackDevice.IntegratedSensor, // Local Feedback Source
DriveConstants.PID_PRIMARY, // PID Index for Source [0, 1]
DriveConstants.DRIVE_TIMEOUT_MS); // Configuration Timeout
/*
* m_rightFrontMotor.configSelectedFeedbackSensor(
* FeedbackDevice.IntegratedSensor, // Local Feedback Source
* DriveConstants.PID_PRIMARY, // PID Index for Source [0, 1]
* DriveConstants.DRIVE_TIMEOUT_MS);
*/ // Configuration Timeout
/*
* Configure the Remote Talon's selected sensor as a remote sensor for the right
* Talon
*/
m_rightFrontMotor.configRemoteFeedbackFilter(m_leftFrontMotor.getDeviceID(), // Device ID of Source
RemoteSensorSource.TalonSRX_SelectedSensor, DriveConstants.REMOTE_0, // Source number [0, 1]
DriveConstants.DRIVE_TIMEOUT_MS); // Configuration Timeout
/*
* Configure the Pigeon IMU to the other Remote Slot available on the right
* Talon
*/
m_rightFrontMotor.configRemoteFeedbackFilter(m_pigeon.getDeviceID(), RemoteSensorSource.Pigeon_Yaw,
DriveConstants.REMOTE_1, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-23 16:42:20 -07:00
2020-01-20 10:40:12 -07:00
/* Setup Sum signal to be used for Distance */
2020-02-06 18:36:04 -07:00
m_rightFrontMotor.configSensorTerm(SensorTerm.Sum0, FeedbackDevice.RemoteSensor0, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configSensorTerm(SensorTerm.Sum1, FeedbackDevice.IntegratedSensor,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 10:40:12 -07:00
2020-02-06 18:36:04 -07:00
/* Diff Signal */
2020-02-07 20:03:13 -07:00
m_rightFrontMotor.configSensorTerm(SensorTerm.Diff1, FeedbackDevice.RemoteSensor0, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configSensorTerm(SensorTerm.Diff0, FeedbackDevice.IntegratedSensor, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 10:40:12 -07:00
2020-02-06 18:36:04 -07:00
/* Configure Sum [Sum of both QuadEncoders] to be used for Primary PID Index */
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configSelectedFeedbackSensor(FeedbackDevice.SensorDifference, DriveConstants.PID_PRIMARY,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-07 17:50:23 -07:00
/* Don't scale the Feedback Sensor (use 1 for 1:1 ratio) */
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configSelectedFeedbackCoefficient(1, // Coefficient
DriveConstants.PID_PRIMARY, // PID Slot of Source
DriveConstants.DRIVE_TIMEOUT_MS); // Configuration Timeout
2020-01-27 19:06:23 -07:00
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configSelectedFeedbackSensor(FeedbackDevice.RemoteSensor1, DriveConstants.PID_TURN,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 10:40:12 -07:00
2020-01-23 16:42:20 -07:00
/* Don't scale the Feedback Sensor (use 1 for 1:1 ratio) */
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configSelectedFeedbackCoefficient(1, DriveConstants.PID_TURN, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-23 16:42:20 -07:00
2020-02-06 18:36:04 -07:00
/* Don't scale the Feedback Sensor (use 1 for 1:1 ratio) */
2020-02-10 20:13:15 -07:00
m_leftFrontMotor.configSelectedFeedbackCoefficient(1, DriveConstants.PID_PRIMARY, DriveConstants.DRIVE_TIMEOUT_MS);
/* Set status frame periods to ensure we don't have stale data */
m_rightFrontMotor.setStatusFramePeriod(StatusFrame.Status_12_Feedback1, 20, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.setStatusFramePeriod(StatusFrame.Status_13_Base_PIDF0, 20, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.setStatusFramePeriod(StatusFrame.Status_14_Turn_PIDF1, 20, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-06 18:36:04 -07:00
m_leftFrontMotor.setStatusFramePeriod(StatusFrame.Status_2_Feedback0, 5, DriveConstants.DRIVE_TIMEOUT_MS);
m_pigeon.setStatusFramePeriod(PigeonIMU_StatusFrame.CondStatus_9_SixDeg_YPR, 5, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-13 19:55:53 -07:00
/* Smart Dashboard Initial Values */
2020-02-01 16:10:39 -07:00
2020-02-10 20:13:15 -07:00
/* Set up Chooser */
2020-02-06 18:36:04 -07:00
m_chooser.setDefaultOption("Distance PID", m_gainsDistance);
2020-02-10 20:13:15 -07:00
// setDriveTrainGains("Distance PID", m_gainsDistance);
2020-02-06 18:36:04 -07:00
m_chooser.addOption("Velocity PID", m_gainsVelocity);
2020-02-10 20:13:15 -07:00
// setDriveTrainGains("Velocity PID", m_gainsVelocity);
2020-02-06 18:36:04 -07:00
m_chooser.addOption("Turning PID", m_gainsTurning);
2020-02-10 20:13:15 -07:00
// setDriveTrainGains("Turning PID", m_gainsTurning);
2020-02-06 18:36:04 -07:00
m_chooser.addOption("Motion Magic PID", m_gainsMotionMagic);
2020-02-10 20:13:15 -07:00
// setDriveTrainGains("Motion Magic PID", m_gainsMotionMagic);
2020-02-06 18:36:04 -07:00
Shuffleboard.getTab("PID").add(m_chooser);
2020-01-20 11:59:23 -07:00
2020-02-10 20:13:15 -07:00
/* Gyro */
2020-02-06 18:36:04 -07:00
SmartDashboard.putNumber("Pigeon Yaw", getGyroYaw());
SmartDashboard.putNumber("Pigeon Pitch", getGyroPitch());
SmartDashboard.putNumber("Pigeon Roll", getGyroRoll());
2020-01-13 19:55:53 -07:00
2020-02-10 20:13:15 -07:00
/* Sensor Values */
2020-02-06 18:36:04 -07:00
SmartDashboard.putNumber("Left Motor Velocity Raw", m_leftFrontMotor.getSelectedSensorVelocity(0));
SmartDashboard.putNumber("Right Motor Velocity Raw", m_rightFrontMotor.getSelectedSensorVelocity());
SmartDashboard.putNumber("Left Motor Position Raw", m_leftFrontMotor.getSelectedSensorPosition(0));
SmartDashboard.putNumber("Right Motor Position Raw", m_rightFrontMotor.getSelectedSensorPosition());
2020-01-13 19:55:53 -07:00
2020-02-10 20:13:15 -07:00
/* PID */
2020-02-06 18:36:04 -07:00
Gains gains = m_chooser.getSelected();
2020-02-07 17:50:23 -07:00
Shuffleboard.getTab("PID").add("P Value Drive", gains.m_kP);
Shuffleboard.getTab("PID").add("I Value Drive", gains.m_kI);
Shuffleboard.getTab("PID").add("D Value Drive", gains.m_kD);
Shuffleboard.getTab("PID").add("F Value Drive", gains.m_kF);
2020-02-06 18:36:04 -07:00
2020-02-10 20:13:15 -07:00
/**
* Max out the peak output (for all modes). However you can limit the output of
* a given PID object with configClosedLoopPeakOutput().
*/
m_leftFrontMotor.configPeakOutputForward(+1, DriveConstants.DRIVE_TIMEOUT_MS);
m_leftFrontMotor.configPeakOutputReverse(-1, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configPeakOutputForward(+1, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configPeakOutputReverse(-1, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-23 16:42:20 -07:00
2020-01-20 10:40:12 -07:00
/**
2020-02-10 20:13:15 -07:00
* 1ms per loop. PID loop can be slowed down if need be. For example, - if
* sensor updates are too slow - sensor deltas are very small per update, so
* derivative error never gets large enough to be useful. - sensor movement is
* very slow causing the derivative error to be near zero.
*/
2020-02-06 18:36:04 -07:00
int closedLoopTimeMs = 1;
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configClosedLoopPeriod( DriveConstants.PID_PRIMARY,
closedLoopTimeMs,
DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.configClosedLoopPeriod( DriveConstants.PID_TURN,
closedLoopTimeMs,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 10:40:12 -07:00
/**
2020-02-10 20:13:15 -07:00
* configAuxPIDPolarity(boolean invert, int timeoutMs) false means talon's local
* output is PID0 + PID1, and other side Talon is PID0 - PID1 true means talon's
* local output is PID0 - PID1, and other side Talon is PID0 + PID1
*/
2020-02-06 18:36:04 -07:00
m_rightFrontMotor.configAuxPIDPolarity(false, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-09 23:55:46 +00:00
}
2020-01-11 10:30:37 -07:00
@Override
public void periodic() {
try {
2020-02-06 18:36:04 -07:00
SmartDashboard.putNumber("Pigeon Yaw", getGyroYaw());
SmartDashboard.putNumber("Pigeon Pitch", getGyroPitch());
SmartDashboard.putNumber("Pigeon Roll", getGyroRoll());
SmartDashboard.putNumber("Left Motor Velocity Raw", m_leftFrontMotor.getSelectedSensorVelocity(0));
SmartDashboard.putNumber("Right Motor Velocity Raw", m_rightFrontMotor.getSelectedSensorVelocity());
SmartDashboard.putNumber("Left Motor Position Raw", m_leftFrontMotor.getSelectedSensorPosition());
SmartDashboard.putNumber("Right Motor Position Raw", m_rightFrontMotor.getSelectedSensorPosition(0));
SmartDashboard.putNumber("Right Motor Velocity Int Sensor", m_rightFrontMotor.getSensorCollection().getIntegratedSensorVelocity());
SmartDashboard.putNumber("Left Motor Velocity Int Sensor", m_leftFrontMotor.getSensorCollection().getIntegratedSensorVelocity());
SmartDashboard.putNumber("Right Front Motor Current", m_rightFrontMotor.getSupplyCurrent());
SmartDashboard.putNumber("Left Front Motor Current", m_leftFrontMotor.getSupplyCurrent());
SmartDashboard.putNumber("Right Back Motor Current", m_rightFrontMotor.getSupplyCurrent());
SmartDashboard.putNumber("Left Back Motor Current", m_leftFrontMotor.getSupplyCurrent());
SmartDashboard.putNumber("PID 0 Error", m_rightFrontMotor.getClosedLoopError(DriveConstants.PID_PRIMARY));
SmartDashboard.putNumber("PID 1 Error", m_rightFrontMotor.getClosedLoopError(DriveConstants.PID_TURN));
SmartDashboard.putNumber("PID 0 Target", m_rightFrontMotor.getClosedLoopTarget(DriveConstants.PID_PRIMARY));
SmartDashboard.putNumber("PID 1 Target", m_rightFrontMotor.getClosedLoopTarget(DriveConstants.PID_TURN));
SmartDashboard.putNumber("PID 0 Pos", m_rightFrontMotor.getSelectedSensorPosition(DriveConstants.PID_PRIMARY));
SmartDashboard.putNumber("PID 1 Pos", m_rightFrontMotor.getSelectedSensorPosition(DriveConstants.PID_TURN));
2020-01-13 19:34:25 -07:00
2020-01-11 10:30:37 -07:00
} catch (Exception e) {
2020-02-01 13:48:52 -07:00
System.err.println("Error in the Drive Subsystem");
2020-02-10 20:13:15 -07:00
// e.printStackTrace(System.err);
2020-01-11 10:30:37 -07:00
}
2020-02-10 20:13:15 -07:00
m_odometry.update(Rotation2d.fromDegrees(getHeading()),
m_leftFrontMotor.getSensorCollection().getIntegratedSensorPosition(),
m_rightFrontMotor.getSensorCollection().getIntegratedSensorPosition());
2020-01-11 10:30:37 -07:00
}
2020-01-11 13:00:14 -07:00
/**
* Sets Motors to a NeutralMode.
2020-02-10 20:13:15 -07:00
*
2020-01-11 13:00:14 -07:00
* @param mode NeutralMode to set motors to
*/
2020-01-11 11:51:21 -07:00
public void setDriveTrainNeutralMode(NeutralMode mode) {
m_leftFrontMotor.setNeutralMode(mode);
m_rightFrontMotor.setNeutralMode(mode);
2020-01-18 09:27:53 -08:00
m_leftBackMotor.setNeutralMode(mode);
m_rightBackMotor.setNeutralMode(mode);
2020-01-11 11:51:21 -07:00
}
2020-01-16 18:22:01 -07:00
/**
2020-02-07 17:02:43 -07:00
* Initializes the drive train gains kP, kI, kD, and kF
2020-02-10 20:13:15 -07:00
*
* @param slot Either "Distance PID", "Velocity PID", "Motion Magic PID", or
* "Turning PID"
2020-02-07 17:02:43 -07:00
* @param gains A gains object which is the gains that are set for the slot
2020-01-16 18:22:01 -07:00
*/
2020-02-10 20:13:15 -07:00
public void setDriveTrainGains(String slot, Gains gains) {
2020-01-18 16:12:56 -07:00
/* Distance */
2020-01-20 11:59:23 -07:00
if (slot.equals("Distance PID")) {
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_DISTANCE, DriveConstants.PID_PRIMARY);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_DISTANCE, gains.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_DISTANCE, gains.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_DISTANCE, gains.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_DISTANCE, gains.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 11:59:23 -07:00
}
2020-01-20 09:55:14 -08:00
/* Velocity */
2020-01-20 11:59:23 -07:00
if (slot.equals("Velocity PID")) {
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_VELOCITY, DriveConstants.PID_PRIMARY);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_VELOCITY, gains.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_VELOCITY, gains.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_VELOCITY, gains.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_VELOCITY, gains.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configClosedLoopPeakOutput(DriveConstants.SLOT_VELOCITY, gains.m_kPeakOutput,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 11:59:23 -07:00
}
2020-01-20 09:55:14 -08:00
/* Turning */
2020-01-20 11:59:23 -07:00
if (slot.equals("Turning PID")) {
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_TURNING, DriveConstants.PID_TURN);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_TURNING, gains.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_TURNING, gains.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_TURNING, gains.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_TURNING, gains.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configClosedLoopPeakOutput(DriveConstants.SLOT_TURNING, gains.m_kPeakOutput,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 11:59:23 -07:00
}
2020-01-18 16:12:56 -07:00
/* Motion Magic */
2020-01-20 11:59:23 -07:00
if (slot.equals("Motion Magic PID")) {
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_MOTION_MAGIC, DriveConstants.PID_PRIMARY);
2020-02-07 17:50:23 -07:00
m_rightFrontMotor.config_kF(DriveConstants.SLOT_MOTION_MAGIC, gains.m_kF, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kP(DriveConstants.SLOT_MOTION_MAGIC, gains.m_kP, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kI(DriveConstants.SLOT_MOTION_MAGIC, gains.m_kI, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.config_kD(DriveConstants.SLOT_MOTION_MAGIC, gains.m_kD, DriveConstants.DRIVE_TIMEOUT_MS);
2020-02-10 20:13:15 -07:00
m_rightFrontMotor.configMotionCruiseVelocity(DriveConstants.DRIVE_CRUISE_VELOCITY,
DriveConstants.DRIVE_TIMEOUT_MS);
2020-01-20 11:59:23 -07:00
m_rightFrontMotor.configMotionAcceleration(DriveConstants.DRIVE_ACCELERATION, DriveConstants.DRIVE_TIMEOUT_MS);
}
2020-01-16 18:22:01 -07:00
}
2020-01-09 23:55:46 +00:00
/**
2020-02-12 20:28:55 -07:00
* Runs percent output control on the moving and steering of the drive train,
* using the Differential Drive class to manage the two inputs
2020-01-09 23:55:46 +00:00
*/
2020-02-10 20:13:15 -07:00
public void driveWithInput(double move, double steer) {
2020-02-01 15:30:41 -07:00
m_driveTrain.arcadeDrive(move, steer);
2020-01-09 23:55:46 +00:00
}
2020-02-07 17:50:23 -07:00
2020-02-07 17:02:43 -07:00
/**
2020-02-12 20:28:55 -07:00
* Runs percent output control on the drive train while using an AUX PID for rotation
* @param targetPos The position to drive to in units
* @param targetGyro The angle to drive at in units
*/
2020-02-08 12:37:48 -07:00
public void driveWithInputAux(double move, double targetGyro) {
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_TURNING, DriveConstants.PID_TURN);
m_rightFrontMotor.set(TalonFXControlMode.PercentOutput, move, DemandType.AuxPID, targetGyro);
m_leftFrontMotor.follow(m_rightFrontMotor, FollowerType.AuxOutput1);
m_driveTrain.feedWatchdog();
}
2020-02-07 17:02:43 -07:00
* @param targetGyro The angle to drive at in units
*/
public void runDriveStraightPositionPID(double targetPos, double targetGyro) {
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_DISTANCE, DriveConstants.PID_PRIMARY);
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_TURNING, DriveConstants.PID_TURN);
m_rightFrontMotor.set(TalonFXControlMode.Position, targetPos, DemandType.AuxPID, targetGyro);
m_leftFrontMotor.follow(m_rightFrontMotor, FollowerType.AuxOutput1);
2020-02-01 15:30:41 -07:00
m_driveTrain.feedWatchdog();
2020-01-16 20:11:48 -07:00
}
2020-02-07 17:50:23 -07:00
2020-02-07 17:02:43 -07:00
/**
* Runs velocity PID while driving straight
2020-02-10 20:13:15 -07:00
*
* @param targetVel The velocity to drive at in units
2020-02-07 17:02:43 -07:00
* @param targetGyro The angle to drive at in units
*/
public void runDriveStraightVelocityPID(double targetVel, double targetGyro) {
2020-02-06 18:36:04 -07:00
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_VELOCITY, DriveConstants.PID_PRIMARY);
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_TURNING, DriveConstants.PID_TURN);
m_rightFrontMotor.set(TalonFXControlMode.Velocity, targetVel, DemandType.AuxPID, targetGyro);
m_leftFrontMotor.follow(m_rightFrontMotor, FollowerType.AuxOutput1);
2020-02-01 15:30:41 -07:00
m_driveTrain.feedWatchdog();
2020-01-16 20:11:48 -07:00
}
2020-02-07 17:50:23 -07:00
2020-02-07 17:02:43 -07:00
/**
2020-02-12 20:28:55 -07:00
* Runs motion magic PID while driving straight
2020-02-07 17:02:43 -07:00
* @param targetPos The position to drive to in units
* @param targetGyro The angle to drive at in units
*/
2020-02-10 20:13:15 -07:00
public void runMotionMagicPID(double targetPos, double targetGyro) {
2020-01-31 17:50:43 -07:00
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_MOTION_MAGIC, DriveConstants.PID_PRIMARY);
m_rightFrontMotor.selectProfileSlot(DriveConstants.SLOT_TURNING, DriveConstants.PID_TURN);
2020-02-10 20:13:15 -07:00
2020-02-07 21:49:04 -07:00
m_rightFrontMotor.set(ControlMode.MotionMagic, targetPos, DemandType.AuxPID, targetGyro);
2020-01-31 17:50:43 -07:00
m_leftFrontMotor.follow(m_rightFrontMotor, FollowerType.AuxOutput1);
2020-02-10 20:13:15 -07:00
2020-02-01 15:30:41 -07:00
m_driveTrain.feedWatchdog();
2020-01-16 20:22:50 -07:00
}
2020-01-30 21:46:56 -07:00
/**
* Runs a Turning PID to rotate a to a target angle
2020-02-10 20:13:15 -07:00
*
2020-01-30 21:46:56 -07:00
* @param targetAngle target angle in degrees
*/
2020-02-10 20:13:15 -07:00
public void runTurningPID(double targetAngle) {
double targetGyro = (targetAngle / 360) * DriveConstants.TICKS_PER_GYRO_REV;
runDriveStraightVelocityPID(0, targetGyro);
2020-01-23 16:42:20 -07:00
}
2020-02-07 17:50:23 -07:00
/**
* Returns the current yaw of the pigeon
*/
2020-01-09 18:05:16 -07:00
public double getGyroYaw() {
double[] ypr = new double[3];
2020-02-10 20:13:15 -07:00
2020-01-09 18:05:16 -07:00
m_pigeon.getYawPitchRoll(ypr);
return ypr[0];
}
2020-02-07 17:50:23 -07:00
/**
* Returns the current pitch of the pigeon
*/
2020-01-09 18:05:16 -07:00
public double getGyroPitch() {
double[] ypr = new double[3];
2020-02-10 20:13:15 -07:00
2020-01-09 18:05:16 -07:00
m_pigeon.getYawPitchRoll(ypr);
return ypr[1];
}
2020-01-10 21:29:45 -07:00
2020-02-07 17:50:23 -07:00
/**
* Returns the current roll of the pigeon
*/
2020-01-09 18:05:16 -07:00
public double getGyroRoll() {
double[] ypr = new double[3];
2020-02-10 20:13:15 -07:00
2020-01-09 18:05:16 -07:00
m_pigeon.getYawPitchRoll(ypr);
return ypr[2];
}
2020-02-07 17:50:23 -07:00
/**
* Resets the yaw of the pigeon
*/
2020-01-09 18:05:16 -07:00
public void resetGyroYaw() {
m_pigeon.setYaw(0);
m_pigeon.setAccumZAngle(0);
}
2020-02-10 20:13:15 -07:00
/**
* Returns the heading of the robot
*
* @return The robot's heading in degrees, from -180 to 180
*/
public double getHeading() {
return Math.IEEEremainder(getGyroYaw(), 360);
}
/**
* Returns the currently-estimated pose of the robot.
* @return The pose.
*/
public Pose2d getPose() {
return m_odometry.getPoseMeters();
}
/**
* Returns current wheel speeds of robot.
* @return The current wheel speeds.
*/
public DifferentialDriveWheelSpeeds getWheelSpeeds() {
return new DifferentialDriveWheelSpeeds( m_leftFrontMotor.getSensorCollection().getIntegratedSensorVelocity(),
m_rightFrontMotor.getSensorCollection().getIntegratedSensorVelocity());
}
/**
* Resets the encoders for both motors.
*/
public void resetEncoders() {
m_leftFrontMotor.getSensorCollection().setIntegratedSensorPosition(0, DriveConstants.DRIVE_TIMEOUT_MS);
m_rightFrontMotor.getSensorCollection().setIntegratedSensorPosition(0, DriveConstants.DRIVE_TIMEOUT_MS);
}
/**
* Resets the odometry to the specified pose.
*
* @param pose The pose to which to set the odometry.
*/
public void setOdometry(Pose2d pose) {
resetEncoders();
m_odometry.resetPosition(pose, Rotation2d.fromDegrees(getHeading()));
}
/**
* Gets the encoder value (position) of a motor
* @param falcon The motor to get the position of
* @return The position of the motor in inches
*/
public double getDistanceInches(WPI_TalonFX falcon) {
return ticksToInches(falcon.getSensorCollection().getIntegratedSensorPosition());
}
/**
* Converts a value in ticks to inches.
* @param ticks The value in ticks to convert
* @return The converted value in inches
*/
public double ticksToInches(double ticks) {
return ticks * DriveConstants.INCHES_PER_TICK;
}
/*
* Set to high or low gear based on boolean state, true = high, false = low
* @param state Chooses between high or low gear
*/
public void setShiftState(boolean state) {
if (state == true) {
speedShift.set(DoubleSolenoid.Value.kForward);
}
if (state == false) {
speedShift.set(DoubleSolenoid.Value.kReverse);
}
}
2020-01-09 23:55:46 +00:00
}