2020-01-16 20:11:48 -07:00
|
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
|
/* Copyright (c) 2019 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.commands;
|
|
|
|
|
|
2020-01-17 19:44:54 -07:00
|
|
|
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
|
2020-01-16 20:11:48 -07:00
|
|
|
import edu.wpi.first.wpilibj2.command.CommandBase;
|
2020-01-18 15:12:48 -07:00
|
|
|
import frc4388.robot.Constants.DriveConstants;
|
2020-01-16 20:11:48 -07:00
|
|
|
import frc4388.robot.subsystems.Drive;
|
|
|
|
|
|
2020-02-06 18:36:04 -07:00
|
|
|
public class DriveStraightToPositionPID extends CommandBase {
|
2020-01-16 20:11:48 -07:00
|
|
|
Drive m_drive;
|
2020-02-07 20:03:13 -07:00
|
|
|
double m_targetPosIn;
|
|
|
|
|
double m_targetPosOut;
|
2020-02-06 19:43:37 -07:00
|
|
|
double m_targetGyro;
|
2020-02-07 20:03:13 -07:00
|
|
|
int i;
|
2020-01-16 20:11:48 -07:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Creates a new DriveToDistancePID.
|
2020-01-18 15:12:48 -07:00
|
|
|
* @param subsystem drive subsystem
|
2020-02-06 19:43:37 -07:00
|
|
|
* @param targetPos distance to travel in inches
|
2020-01-16 20:11:48 -07:00
|
|
|
*/
|
2020-02-06 19:43:37 -07:00
|
|
|
public DriveStraightToPositionPID(Drive subsystem, double targetPos) {
|
2020-01-16 20:11:48 -07:00
|
|
|
// Use addRequirements() here to declare subsystem dependencies.
|
|
|
|
|
m_drive = subsystem;
|
2020-02-28 19:13:38 -07:00
|
|
|
m_targetPosIn = targetPos * DriveConstants.TICKS_PER_INCH_LOW * 2;
|
2020-01-16 20:11:48 -07:00
|
|
|
addRequirements(m_drive);
|
2020-02-07 20:03:13 -07:00
|
|
|
//SmartDashboard.putNumber("Distance Target Inches", targetPos);
|
2020-01-16 20:11:48 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Called when the command is initially scheduled.
|
|
|
|
|
@Override
|
|
|
|
|
public void initialize() {
|
2020-02-07 20:03:13 -07:00
|
|
|
//System.err.println("PID START \n | \n |");
|
2020-02-06 19:43:37 -07:00
|
|
|
m_targetGyro = m_drive.m_rightFrontMotor.getSelectedSensorPosition(DriveConstants.PID_TURN);
|
2020-02-07 20:03:13 -07:00
|
|
|
m_targetPosOut = m_targetPosIn + m_drive.m_rightFrontMotor.getSelectedSensorPosition(DriveConstants.PID_PRIMARY);
|
|
|
|
|
i = 0;
|
2020-01-16 20:11:48 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Called every time the scheduler runs while the command is scheduled.
|
|
|
|
|
@Override
|
|
|
|
|
public void execute() {
|
2020-02-07 20:03:13 -07:00
|
|
|
//System.err.println("| \n Sensor Pos \n" + m_drive.m_rightFrontMotor.getSelectedSensorPosition(DriveConstants.PID_PRIMARY));
|
|
|
|
|
//System.err.println("Sensor Error \n" + m_drive.m_rightFrontMotor.getClosedLoopError(DriveConstants.PID_PRIMARY));
|
|
|
|
|
//System.err.println("Sensor Target \n" + m_drive.m_rightFrontMotor.getClosedLoopTarget(DriveConstants.PID_PRIMARY));
|
2020-02-13 17:51:54 -07:00
|
|
|
m_drive.runDrivePositionPID(m_targetPosOut, m_targetGyro);
|
2020-01-16 20:11:48 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Called once the command ends or is interrupted.
|
|
|
|
|
@Override
|
|
|
|
|
public void end(boolean interrupted) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Returns true when the command should end.
|
|
|
|
|
@Override
|
|
|
|
|
public boolean isFinished() {
|
2020-02-28 17:38:15 -07:00
|
|
|
if (Math.abs((int)m_drive.m_rightFrontMotor.getSelectedSensorVelocity(DriveConstants.PID_PRIMARY)) < 5 && i > 10){
|
2020-01-16 20:11:48 -07:00
|
|
|
return true;
|
|
|
|
|
} else {
|
2020-02-07 20:03:13 -07:00
|
|
|
i++;
|
|
|
|
|
//System.err.println(i);
|
2020-01-16 20:11:48 -07:00
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|