Files
YAGSL/swervelib/imu/NavXSwerve.java

199 lines
4.9 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
import com.kauailabs.navx.frc.AHRS;
import edu.wpi.first.math.geometry.Rotation3d;
import edu.wpi.first.math.geometry.Translation3d;
import edu.wpi.first.wpilibj.I2C;
import edu.wpi.first.wpilibj.SPI;
2023-02-13 14:37:05 -06:00
import edu.wpi.first.wpilibj.SerialPort;
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
import java.util.Optional;
2024-01-17 09:17:39 -06:00
import swervelib.telemetry.Alert;
2023-02-13 14:37:05 -06:00
/**
* Communicates with the NavX as the IMU.
*/
public class NavXSwerve extends SwerveIMU
{
/**
* NavX IMU.
*/
2024-08-24 17:27:03 -05:00
private AHRS imu;
2023-02-13 14:37:05 -06:00
/**
2023-03-08 23:34:33 -06:00
* Offset for the NavX.
2023-02-13 14:37:05 -06:00
*/
2024-01-22 15:11:18 -06:00
private Rotation3d offset = new Rotation3d();
/**
* Inversion for the gyro
*/
private boolean invertedIMU = false;
2024-01-17 09:17:39 -06:00
/**
* An {@link Alert} for if there is an error instantiating the NavX.
*/
private Alert navXError;
2023-02-13 14:37:05 -06:00
/**
* Constructor for the NavX swerve.
2023-02-22 23:10:57 -06:00
*
* @param port Serial Port to connect to.
2023-02-13 14:37:05 -06:00
*/
2023-02-22 23:10:57 -06:00
public NavXSwerve(SerialPort.Port port)
2023-02-13 14:37:05 -06:00
{
2024-01-17 09:17:39 -06:00
navXError = new Alert("IMU", "Error instantiating NavX.", Alert.AlertType.ERROR_TRACE);
2023-02-13 14:37:05 -06:00
try
{
/* Communicate w/navX-MXP via the MXP SPI Bus. */
/* Alternatively: I2C.Port.kMXP, SerialPort.Port.kMXP or SerialPort.Port.kUSB */
/* See http://navx-mxp.kauailabs.com/guidance/selecting-an-interface/ for details. */
2024-08-24 17:27:03 -05:00
imu = new AHRS(port);
2023-03-08 23:34:33 -06:00
factoryDefault();
2024-08-24 17:27:03 -05:00
SmartDashboard.putData(imu);
2023-02-13 14:37:05 -06:00
} catch (RuntimeException ex)
{
2024-01-17 09:17:39 -06:00
navXError.setText("Error instantiating NavX: " + ex.getMessage());
navXError.set(true);
}
}
/**
* Constructor for the NavX swerve.
*
* @param port SPI Port to connect to.
*/
public NavXSwerve(SPI.Port port)
{
try
{
/* Communicate w/navX-MXP via the MXP SPI Bus. */
/* Alternatively: I2C.Port.kMXP, SerialPort.Port.kMXP or SerialPort.Port.kUSB */
/* See http://navx-mxp.kauailabs.com/guidance/selecting-an-interface/ for details. */
2024-08-24 17:27:03 -05:00
imu = new AHRS(port);
factoryDefault();
2024-08-24 17:27:03 -05:00
SmartDashboard.putData(imu);
} catch (RuntimeException ex)
{
2024-01-17 09:17:39 -06:00
navXError.setText("Error instantiating NavX: " + ex.getMessage());
navXError.set(true);
}
}
/**
* Constructor for the NavX swerve.
*
* @param port I2C Port to connect to.
*/
public NavXSwerve(I2C.Port port)
{
try
{
/* Communicate w/navX-MXP via the MXP SPI Bus. */
/* Alternatively: I2C.Port.kMXP, SerialPort.Port.kMXP or SerialPort.Port.kUSB */
/* See http://navx-mxp.kauailabs.com/guidance/selecting-an-interface/ for details. */
2024-08-24 17:27:03 -05:00
imu = new AHRS(port);
factoryDefault();
2024-08-24 17:27:03 -05:00
SmartDashboard.putData(imu);
} catch (RuntimeException ex)
{
2024-01-17 09:17:39 -06:00
navXError.setText("Error instantiating NavX: " + ex.getMessage());
navXError.set(true);
2023-02-13 14:37:05 -06:00
}
}
/**
* Reset IMU to factory default.
*/
@Override
public void factoryDefault()
{
// gyro.reset(); // Reported to be slow
2024-08-24 17:27:03 -05:00
offset = imu.getRotation3d();
2023-02-13 14:37:05 -06:00
}
/**
* Clear sticky faults on IMU.
*/
@Override
public void 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
*/
2024-01-15 14:37:13 -06:00
@Override
2023-03-08 23:34:33 -06:00
public Rotation3d getRawRotation3d()
2023-02-13 14:37:05 -06:00
{
2024-08-24 17:27:03 -05:00
return invertedIMU ? imu.getRotation3d().unaryMinus() : imu.getRotation3d();
2023-02-13 14:37:05 -06:00
}
/**
* Fetch the {@link Rotation3d} from the IMU. Robot relative.
*
* @return {@link Rotation3d} from the IMU.
*/
2023-03-08 23:34:33 -06:00
@Override
public Rotation3d getRotation3d()
{
2024-02-19 20:48:54 -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()
{
return Optional.of(
new Translation3d(
2024-08-24 17:27:03 -05:00
imu.getWorldLinearAccelX(),
imu.getWorldLinearAccelY(),
imu.getWorldLinearAccelZ())
.times(9.81));
}
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.
* @return {@link Double} of the rotation rate as an {@link Optional}.
*/
public double getRate() {
return imu.getRate();
}
2023-02-13 14:37:05 -06:00
/**
* Get the instantiated IMU object.
*
* @return IMU object.
*/
@Override
public Object getIMU()
{
2024-08-24 17:27:03 -05:00
return imu;
2023-02-13 14:37:05 -06:00
}
}