From 4a6d9f8bcaa8a9ab9ed435e7c7ca2c6b4f90a493 Mon Sep 17 00:00:00 2001 From: SR1899 Date: Sat, 24 Feb 2024 15:39:50 -0800 Subject: [PATCH] added clamp to PID output --- .../java/frc/robot/subsystems/IntakeSubsystem.java | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/main/java/frc/robot/subsystems/IntakeSubsystem.java b/src/main/java/frc/robot/subsystems/IntakeSubsystem.java index ff3a4df..02fb3f6 100644 --- a/src/main/java/frc/robot/subsystems/IntakeSubsystem.java +++ b/src/main/java/frc/robot/subsystems/IntakeSubsystem.java @@ -10,6 +10,7 @@ import com.revrobotics.Rev2mDistanceSensor; import com.revrobotics.Rev2mDistanceSensor.Port; +import edu.wpi.first.math.MathUtil; import edu.wpi.first.math.controller.PIDController; import edu.wpi.first.wpilibj.DutyCycleEncoder; import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard; @@ -23,13 +24,14 @@ public class IntakeSubsystem extends SubsystemBase { private CANSparkFlex m_intakeMotor = new CANSparkFlex(IntakeConstants.kIntakeMotorID, MotorType.kBrushless); private CANSparkFlex m_armMotor = new CANSparkFlex(IntakeConstants.kArmMotorID, MotorType.kBrushless); - private PIDController m_armPID = new PIDController(0.5, 0, 0); + private PIDController m_armPID = new PIDController(0.0015, 0, 0); private DutyCycleEncoder m_armEncoder = new DutyCycleEncoder(IntakeConstants.kArmEncoderChannel); private Rev2mDistanceSensor m_distanceSensor = new Rev2mDistanceSensor(Port.kOnboard); // onboard I2C port; private double m_intakeSpeed = 0; + private double m_armSetpoint = IntakeConstants.kIntakeLoweredAngle; /** Creates a new IntakeSubsystem */ public IntakeSubsystem() { @@ -40,7 +42,7 @@ public IntakeSubsystem() { m_armEncoder.setDistancePerRotation(360); m_intakeMotor.setIdleMode(IdleMode.kCoast); - m_armMotor.setIdleMode(IdleMode.kBrake); + m_armMotor.setIdleMode(IdleMode.kCoast); // m_armPID.disableContinuousInput(); m_armPID.setTolerance(0.05); @@ -50,7 +52,7 @@ public IntakeSubsystem() { } public void armExtend() { - m_armPID.setSetpoint(IntakeConstants.kIntakeLoweredAngle); + m_armSetpoint = IntakeConstants.kIntakeLoweredAngle; stopIntake(); @@ -58,7 +60,7 @@ public void armExtend() { } public void armRetract() { - m_armPID.setSetpoint(IntakeConstants.kIntakeRaisedAngle); + m_armSetpoint = IntakeConstants.kIntakeRaisedAngle; stopIntake(); @@ -99,13 +101,13 @@ public void periodic() { armRetract(); } - // m_armMotor.set(m_armPID.calculate(m_armEncoder.getDistance())); + // m_armMotor.set(MathUtil.clamp(m_armPID.calculate(m_armEncoder.getDistance(), m_armSetpoint), -0.3, 0.3)); // m_intakeMotor.set(m_intakeSpeed); SmartDashboard.putNumber("Arm Angle", m_armEncoder.getDistance()); SmartDashboard.putBoolean("Arm Deployed?", deployed); SmartDashboard.putBoolean("Have Note?", haveNote); - SmartDashboard.putNumber("pid output", m_armPID.calculate(m_armEncoder.getDistance())); + SmartDashboard.putNumber("pid output", m_armPID.calculate(m_armEncoder.getDistance(), m_armSetpoint)); } public boolean readyToShoot() {