Files
YAGSL/swervelib/imu/Pigeon2Swerve.java

162 lines
3.8 KiB
Java
Raw Normal View History

2023-02-13 17:21:24 -06:00
package swervelib.imu;
2023-02-13 14:37:05 -06:00
2024-01-15 14:37:13 -06:00
import com.ctre.phoenix6.StatusSignal;
import com.ctre.phoenix6.configs.Pigeon2Configuration;
import com.ctre.phoenix6.configs.Pigeon2Configurator;
import com.ctre.phoenix6.hardware.Pigeon2;
import edu.wpi.first.math.geometry.Rotation3d;
import edu.wpi.first.math.geometry.Translation3d;
2023-02-13 14:37:05 -06:00
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
import java.util.Optional;
2023-02-13 14:37:05 -06:00
/**
* SwerveIMU interface for the Pigeon2
*/
public class Pigeon2Swerve extends SwerveIMU
{
2024-02-02 18:55:29 -06:00
/**
* Wait time for status frames to show up.
*/
2024-02-12 18:59:40 -06:00
public static double STATUS_TIMEOUT_SECONDS = 0.04;
2023-02-13 14:37:05 -06:00
/**
* Pigeon2 IMU device.
*/
2024-01-15 14:37:13 -06:00
Pigeon2 imu;
2023-03-08 23:34:33 -06:00
/**
* Offset for the Pigeon 2.
*/
2024-02-12 18:59:40 -06:00
private Rotation3d offset = new Rotation3d();
2024-01-22 15:11:18 -06:00
/**
* Inversion for the gyro
*/
2024-02-12 18:59:40 -06:00
private boolean invertedIMU = false;
2023-02-13 14:37:05 -06:00
/**
* Generate the SwerveIMU for pigeon.
*
* @param canid CAN ID for the pigeon
* @param canbus CAN Bus name the pigeon resides on.
*/
public Pigeon2Swerve(int canid, String canbus)
{
2024-01-15 14:37:13 -06:00
imu = new Pigeon2(canid, canbus);
2023-02-13 14:37:05 -06:00
SmartDashboard.putData(imu);
}
/**
* Generate the SwerveIMU for pigeon.
*
* @param canid CAN ID for the pigeon
*/
public Pigeon2Swerve(int canid)
{
this(canid, "");
}
/**
* Reset IMU to factory default.
*/
@Override
public void factoryDefault()
{
2024-01-15 14:37:13 -06:00
Pigeon2Configurator cfg = imu.getConfigurator();
Pigeon2Configuration config = new Pigeon2Configuration();
// Compass utilization causes readings to jump dramatically in some cases.
cfg.apply(config.Pigeon2Features.withEnableCompass(false));
2023-02-13 14:37:05 -06:00
}
/**
* Clear sticky faults on IMU.
*/
@Override
public void clearStickyFaults()
{
imu.clearStickyFaults();
}
/**
2023-03-08 23:34:33 -06:00
* Set the gyro offset.
2023-02-13 14:37:05 -06:00
*
2023-03-08 23:34:33 -06:00
* @param offset gyro offset as a {@link Rotation3d}.
2023-02-13 14:37:05 -06:00
*/
2023-03-08 23:34:33 -06:00
public void setOffset(Rotation3d offset)
2023-02-13 14:37:05 -06:00
{
this.offset = offset;
2023-02-13 14:37:05 -06:00
}
2024-01-22 15:11:18 -06:00
/**
* Set the gyro to invert its default direction
*
* @param invertIMU invert gyro direction
*/
public void setInverted(boolean invertIMU)
{
invertedIMU = invertIMU;
}
2023-02-13 14:37:05 -06:00
/**
2023-03-08 23:34:33 -06:00
* Fetch the {@link Rotation3d} from the IMU without any zeroing. Robot relative.
2023-02-13 14:37:05 -06:00
*
2023-03-08 23:34:33 -06:00
* @return {@link Rotation3d} from the IMU.
2023-02-13 14:37:05 -06:00
*/
@Override
2023-03-08 23:34:33 -06:00
public Rotation3d getRawRotation3d()
2023-02-13 14:37:05 -06:00
{
2024-02-12 18:59:40 -06:00
Rotation3d reading = imu.getRotation3d();
2024-01-22 15:11:18 -06:00
return invertedIMU ? reading.unaryMinus() : reading;
2023-02-13 14:37:05 -06:00
}
/**
* Fetch the {@link Rotation3d} from the IMU. Robot relative.
*
* @return {@link Rotation3d} from the IMU.
*/
@Override
public Rotation3d getRotation3d()
{
2023-03-08 23:34:33 -06:00
return getRawRotation3d().minus(offset);
}
/**
* Fetch the acceleration [x, y, z] from the IMU in meters per second squared. If acceleration isn't supported returns
* empty.
*
* @return {@link Translation3d} of the acceleration as an {@link Optional}.
*/
@Override
public Optional<Translation3d> getAccel()
{
2024-01-15 14:37:13 -06:00
// TODO: Switch to suppliers.
StatusSignal<Double> xAcc = imu.getAccelerationX();
2024-01-26 11:29:15 -06:00
StatusSignal<Double> yAcc = imu.getAccelerationY();
StatusSignal<Double> zAcc = imu.getAccelerationZ();
2024-01-15 14:37:13 -06:00
2024-02-02 18:55:29 -06:00
return Optional.of(new Translation3d(xAcc.waitForUpdate(STATUS_TIMEOUT_SECONDS).getValue(),
yAcc.waitForUpdate(STATUS_TIMEOUT_SECONDS).getValue(),
zAcc.waitForUpdate(STATUS_TIMEOUT_SECONDS).getValue()).times(9.81 / 16384.0));
}
2024-08-24 17:27:03 -05:00
/**
* Fetch the rotation rate from the IMU in degrees per second. If rotation rate isn't supported returns empty.
2024-08-24 17:40:19 -05:00
*
2024-08-24 17:27:03 -05:00
* @return {@link Double} of the rotation rate as an {@link Optional}.
*/
2024-08-24 17:40:19 -05:00
public double getRate()
{
2024-08-24 17:27:03 -05:00
return imu.getRate();
}
2023-02-13 14:37:05 -06:00
/**
* Get the instantiated IMU object.
*
* @return IMU object.
*/
@Override
public Object getIMU()
{
return imu;
}
}