Skip to content
This repository has been archived by the owner on Jan 10, 2025. It is now read-only.

Commit

Permalink
Teleop done (#96)
Browse files Browse the repository at this point in the history
  • Loading branch information
spacey-sooty authored Aug 11, 2024
1 parent 74e99d9 commit 11af318
Show file tree
Hide file tree
Showing 6 changed files with 67 additions and 31 deletions.
2 changes: 1 addition & 1 deletion src/main/java/frc/robot/Constants.java
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ public final class Constants {
public static final double intakeI = 0;
public static final double intakeD = 0;

public static final double armP = 10.5;
public static final double armP = 10;
public static final double armI = 0;
public static final double armD = 0;
public static final double armS = 0;
Expand Down
30 changes: 23 additions & 7 deletions src/main/java/frc/robot/Robot.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,13 @@
import edu.wpi.first.wpilibj.DriverStation;
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
import edu.wpi.first.wpilibj2.command.CommandRobot;
import edu.wpi.first.wpilibj2.command.Commands;
import edu.wpi.first.wpilibj2.command.button.CommandXboxController;
import edu.wpi.first.wpilibj2.command.button.Trigger;
import frc.robot.autos.WompWompKieran;
import frc.robot.generated.TunerConstants;
import frc.robot.subsystems.Arm;
import frc.robot.subsystems.Arm.Setpoint;
import frc.robot.subsystems.Climber;
import frc.robot.subsystems.CommandSwerveDrivetrain;
import frc.robot.subsystems.Index;
Expand Down Expand Up @@ -81,24 +83,38 @@ public Robot() {
() ->
m_drive
.withVelocityX(
Utils.deadzone(-m_driver.getLeftY() * Constants.DrivebaseMaxSpeed))
Utils.deadzone(-m_driver.getLeftY() * Constants.DrivebaseMaxSpeed * 0.5))
.withVelocityY(
Utils.deadzone(-m_driver.getLeftX() * Constants.DrivebaseMaxSpeed))
Utils.deadzone(-m_driver.getLeftX() * Constants.DrivebaseMaxSpeed * 0.5))
.withRotationalRate(
Utils.deadzone(
-m_driver.getRightX() * Constants.DrivebaseMaxAngularRate))));
-m_driver.getRightX() * Constants.DrivebaseMaxAngularRate * 0.5))));
m_intake.setDefaultCommand(m_superstructure.intake());
m_shooter.setDefaultCommand(m_shooter.stop());
m_index.setDefaultCommand(m_index.stop());
// m_arm.setDefaultCommand(m_arm.goToSetpoint(Arm.Setpoint.kStowed));
m_arm.setDefaultCommand(m_arm.manualControl(m_codriver::getLeftY));
m_arm.setDefaultCommand(m_arm.goToSetpoint(Setpoint.kIntake));

new Trigger(() -> m_codriver.getLeftY() > 0.05)
.whileTrue(m_arm.manualControl(m_codriver::getLeftY));

m_driver.a().whileTrue(m_drivetrain.applyRequest(() -> m_brake));
m_driver.y().onTrue(m_drivetrain.runOnce(() -> m_drivetrain.seedFieldRelative()));

m_codriver.a().onTrue(m_climber.climb());
m_codriver.rightBumper().whileTrue(m_intake.outake(8));
m_codriver.leftBumper().whileTrue(m_superstructure.shoot());
m_codriver.leftBumper().whileTrue(m_index.shoot());
m_codriver.rightBumper().whileTrue(m_shooter.spinup(500).andThen(m_shooter.maintain()));
m_codriver
.leftTrigger()
.whileTrue(
Commands.parallel(
m_arm.goToSetpoint(Setpoint.kSpeaker).andThen(m_arm.maintain()),
m_shooter.spinup(500).andThen(m_shooter.maintain())));
m_codriver
.rightTrigger()
.whileTrue(
Commands.parallel(
m_arm.goToSetpoint(Setpoint.kAmp).andThen(m_arm.maintain()),
m_shooter.applyVolts(8)));

m_codriverX.whileTrue(m_superstructure.intake()).onFalse(m_intake.stop());
m_scheduler
Expand Down
10 changes: 6 additions & 4 deletions src/main/java/frc/robot/Superstructure.java
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,12 @@ public Command intake() {
}

public Command shoot() {
return m_shooter
.spinup(500)
.withTimeout(3)
.andThen(Commands.parallel(m_shooter.maintain(), m_index.shoot()));
return m_shooter.spinup(500).andThen(Commands.parallel(m_shooter.maintain(), m_index.shoot()));
}

public Command outake_shooter() {
// return Commands.parallel(m_shooter.applyVolts(6), m_index.shoot());
return m_shooter.applyVolts(6);
}

public Command stop() {
Expand Down
2 changes: 1 addition & 1 deletion src/main/java/frc/robot/URCL.java
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ public class URCL {
private static Notifier notifier;
private static final DataLog datalog = DataLogManager.getLog();
private static RawLogEntry persistentLogEntry =
new RawLogEntry(datalog, "URCL/Raw/Persistent", "", "URCLr2_persistent");
new RawLogEntry(datalog, "/URCL/Raw/Persistent", "", "URCLr2_persistent");
private static RawLogEntry periodicLogEntry =
new RawLogEntry(datalog, "/URCL/Raw/Periodic", "", "URCLr2_periodic");
private static RawLogEntry aliasLogEntry =
Expand Down
42 changes: 29 additions & 13 deletions src/main/java/frc/robot/subsystems/Arm.java
Original file line number Diff line number Diff line change
Expand Up @@ -60,31 +60,33 @@ public enum Setpoint {
private final DoublePublisher pid_setpoint = driveStats.getDoubleTopic("PID/Setpoint").publish();
private final DoublePublisher angle = driveStats.getDoubleTopic("Angle").publish();
public final Trigger m_atSetpoint = new Trigger(m_pid::atSetpoint);
private double m_lastPosition = 0.2;

/** Creates a new {@link Arm} {@link edu.wpi.first.wpilibj2.command.Subsystem}. */
public Arm() {
m_followerMotor.follow(m_primaryMotor);
m_encoder.reset();
m_encoder.setPositionOffset(0.1);
m_pid.setTolerance(0.1);
}

/** Achieves and maintains speed for the primary motor. */
private Command achievePosition(double position) {
return run(
() -> {
var pid_output = m_pid.calculate(m_encoder.getAbsolutePosition() * 2 * Math.PI, position);
m_lastPosition = position;
m_pid.setSetpoint(position);
var pid_output = m_pid.calculate(getAngle());
log_pid_output.append(pid_output);
log_pid_setpoint.append(m_pid.getSetpoint());
var ff_output = m_feedforward.calculate(position, (5676 / 250));
log_ff_output.append(ff_output);
log_ff_position_setpoint.append(position);
log_ff_velocity_setpoint.append((5676 / 250));
this.ff_output.set(ff_output);
this.pid_output.set(0.5 + pid_output);
this.pid_output.set(pid_output);
this.pid_error.set(m_pid.getPositionError());
this.pid_setpoint.set(m_pid.getSetpoint());
m_primaryMotor.setVoltage(0.5 + pid_output * -1);
// m_primaryMotor.setVoltage(0.5 + pid_output);
// m_primaryMotor.setVoltage(pid_output * -1);
m_primaryMotor.setVoltage(pid_output);
});
}

Expand All @@ -98,17 +100,27 @@ public Command stop() {
* @param position The desired position.
* @return a {@link Command} to get to the desired position.
*/
private Command moveToPosition(double position) {
public Command moveToPosition(double position) {
return achievePosition(position).until(m_pid::atSetpoint);
}

/**
* Moves the arm to the specified position then stops.
*
* @param position The desired position.
* @return a {@link Command} to get to the desired position.
*/
public Command hold(double angle) {
return achievePosition(angle);
}

/**
* Holds the arm at the current position setpoint.
*
* @return A {@link Command} to hold the position at the setpoint.
*/
public Command maintain() {
return achievePosition(m_pid.getSetpoint());
return defer(() -> achievePosition(m_lastPosition));
}

/**
Expand Down Expand Up @@ -137,17 +149,21 @@ public Command goToSetpoint(Setpoint setpoint) {
log_setpoint.append(setpoint.name());

switch (setpoint) {
case kAmp -> position = Math.PI / 2 + 4.8;
case kIntake -> position = 4.85;
case kSpeaker -> position = 4.85;
case kStowed -> position = 4.85;
case kAmp -> position = 1.68;
case kIntake -> position = 0.2;
case kSpeaker -> position = 0.2;
case kStowed -> position = 0.2;
}

return moveToPosition(position);
}

@Override
public void periodic() {
angle.set(m_encoder.getAbsolutePosition() * 2 * Math.PI);
angle.set(getAngle());
}

public double getAngle() {
return m_encoder.getAbsolutePosition() * 2 * Math.PI;
}
}
12 changes: 7 additions & 5 deletions src/main/java/frc/robot/subsystems/Shooter.java
Original file line number Diff line number Diff line change
Expand Up @@ -39,9 +39,7 @@ public class Shooter extends SubsystemBase {
public final Trigger m_atSetpoint = new Trigger(m_pid::atSetpoint);

/** Creates a new {@link Shooter} {@link edu.wpi.first.wpilibj2.command.Subsystem}. */
public Shooter() {
m_pid.setTolerance(0.05, 0.05);
}
public Shooter() {}

/** Acheives and maintains speed. */
private Command achieveSpeeds(double speed) {
Expand Down Expand Up @@ -78,15 +76,19 @@ public Command stop() {
* @return A {@link Command} to hold the speed at the setpoint.
*/
public Command maintain() {
return achieveSpeeds(m_pid.getSetpoint());
return defer(() -> achieveSpeeds(m_pid.getSetpoint()));
}

public Command shoot() {
return spinup(500).andThen(maintain());
}

public Command applyVolts(double volts) {
return run(() -> m_motor.setVoltage(volts));
}

@Override
public void periodic() {
m_ntRotationalVelocity.set(m_encoder.getVelocity());
m_ntRotationalVelocity.set(Units.rotationsPerMinuteToRadiansPerSecond(m_encoder.getVelocity()));
}
}

0 comments on commit 11af318

Please sign in to comment.