mirror of
https://github.com/BroncBotz3481/YAGSL
synced 2026-06-21 06:31:40 +00:00
Updated docs, renamed SwerveDrive lock function and setBrake function
This commit is contained in:
106
swervelib/simulation/SwerveIMUSimulation.java
Normal file
106
swervelib/simulation/SwerveIMUSimulation.java
Normal file
@@ -0,0 +1,106 @@
|
||||
package swervelib.simulation;
|
||||
|
||||
import edu.wpi.first.math.geometry.Pose2d;
|
||||
import edu.wpi.first.math.geometry.Rotation2d;
|
||||
import edu.wpi.first.math.geometry.Rotation3d;
|
||||
import edu.wpi.first.wpilibj.Timer;
|
||||
import edu.wpi.first.wpilibj.smartdashboard.Field2d;
|
||||
import swervelib.math.SwerveKinematics2;
|
||||
import swervelib.math.SwerveModuleState2;
|
||||
|
||||
/**
|
||||
* Simulation for {@link swervelib.SwerveDrive} IMU.
|
||||
*/
|
||||
public class SwerveIMUSimulation
|
||||
{
|
||||
|
||||
/**
|
||||
* Main timer to control movement estimations.
|
||||
*/
|
||||
private final Timer timer;
|
||||
/**
|
||||
* The last time the timer was read, used to determine position changes.
|
||||
*/
|
||||
private double lastTime;
|
||||
/**
|
||||
* Heading of the robot.
|
||||
*/
|
||||
private double angle;
|
||||
|
||||
/**
|
||||
* Create the swerve drive IMU simulation.
|
||||
*/
|
||||
public SwerveIMUSimulation()
|
||||
{
|
||||
timer = new Timer();
|
||||
timer.start();
|
||||
lastTime = timer.get();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the estimated angle of the robot.
|
||||
*
|
||||
* @return {@link Rotation2d} estimation of the robot.
|
||||
*/
|
||||
public Rotation2d getYaw()
|
||||
{
|
||||
return new Rotation2d(angle);
|
||||
}
|
||||
|
||||
/**
|
||||
* Pitch is not simulated currently, always returns 0.
|
||||
*
|
||||
* @return Pitch of the robot as {@link Rotation2d}.
|
||||
*/
|
||||
public Rotation2d getPitch()
|
||||
{
|
||||
return new Rotation2d();
|
||||
}
|
||||
|
||||
/**
|
||||
* Roll is not simulated currently, always returns 0.
|
||||
*
|
||||
* @return Roll of the robot as {@link Rotation2d}.
|
||||
*/
|
||||
public Rotation2d getRoll()
|
||||
{
|
||||
return new Rotation2d();
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the estimated gyro {@link Rotation3d} of the robot.
|
||||
*
|
||||
* @return The heading as a {@link Rotation3d} angle
|
||||
*/
|
||||
public Rotation3d getGyroRotation3d()
|
||||
{
|
||||
return new Rotation3d(0, 0, angle);
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the odometry of the simulated {@link swervelib.SwerveDrive} and post the {@link swervelib.SwerveModule}
|
||||
* states to the {@link Field2d}.
|
||||
*
|
||||
* @param kinematics {@link SwerveKinematics2} of the swerve drive.
|
||||
* @param states {@link SwerveModuleState2} array of the module states.
|
||||
* @param modulePoses {@link Pose2d} representing the swerve modules.
|
||||
* @param field {@link Field2d} to update.
|
||||
*/
|
||||
public void updateOdometry(SwerveKinematics2 kinematics, SwerveModuleState2[] states, Pose2d[] modulePoses,
|
||||
Field2d field)
|
||||
{
|
||||
angle += kinematics.toChassisSpeeds(states).omegaRadiansPerSecond * (timer.get() - lastTime);
|
||||
lastTime = timer.get();
|
||||
field.getObject("XModules").setPoses(modulePoses);
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the heading of the robot.
|
||||
*
|
||||
* @param angle Angle of the robot in radians.
|
||||
*/
|
||||
public void setAngle(double angle)
|
||||
{
|
||||
this.angle = angle;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user