From 0bcb9440c6f61d48b678c750f0234f311cbe4334 Mon Sep 17 00:00:00 2001 From: Cameron Earle Date: Fri, 9 Feb 2024 20:06:00 -0500 Subject: [PATCH] Change ModuleIOSparkMax to use absolute encoder always --- .../subsystems/drive/ModuleIOSparkMax.java | 17 ++--------------- 1 file changed, 2 insertions(+), 15 deletions(-) diff --git a/src/main/java/org/littletonrobotics/frc2024/subsystems/drive/ModuleIOSparkMax.java b/src/main/java/org/littletonrobotics/frc2024/subsystems/drive/ModuleIOSparkMax.java index ec420b86..ca09ff00 100644 --- a/src/main/java/org/littletonrobotics/frc2024/subsystems/drive/ModuleIOSparkMax.java +++ b/src/main/java/org/littletonrobotics/frc2024/subsystems/drive/ModuleIOSparkMax.java @@ -61,7 +61,7 @@ public ModuleIOSparkMax(ModuleConfig config) { driveMotor.setCANTimeout(250); turnMotor.setCANTimeout(250); - for (int i = 0; i < 4; i++) { + for (int i = 0; i < 30; i++) { turnMotor.setInverted(config.turnMotorInverted()); driveMotor.setSmartCurrentLimit(40); turnMotor.setSmartCurrentLimit(30); @@ -104,17 +104,6 @@ public ModuleIOSparkMax(ModuleConfig config) { @Override public void updateInputs(ModuleIOInputs inputs) { - // Reset position of encoder to absolute position every shouldResetCount cycles - // Make sure turnMotor is not moving too fast - if (++resetCounter >= shouldResetCount - && Units.rotationsPerMinuteToRadiansPerSecond(turnRelativeEncoder.getVelocity()) <= 0.1) { - for (int i = 0; i < 4; i++) { - turnRelativeEncoder.setPosition( - absoluteEncoderValue.get().getRotations() * moduleConstants.turnReduction()); - } - resetCounter = 0; - } - inputs.drivePositionRad = Units.rotationsToRadians(driveEncoder.getPosition() / moduleConstants.driveReduction()); inputs.driveVelocityRadPerSec = @@ -169,9 +158,7 @@ public void setDriveVelocitySetpoint(double velocityRadsPerSec, double ffVolts) @Override public void setTurnPositionSetpoint(double angleRads) { - setTurnVoltage( - turnController.calculate( - Units.rotationsToRadians(turnRelativeEncoder.getPosition()), angleRads)); + setTurnVoltage(turnController.calculate(absoluteEncoderValue.get().getRadians(), angleRads)); } @Override