Files
YAGSL/swervelib/math/SwerveModuleState2.java

158 lines
5.7 KiB
Java
Raw Normal View History

2023-02-13 17:21:24 -06:00
package swervelib.math;
2023-02-13 14:37:05 -06:00
import edu.wpi.first.math.geometry.Rotation2d;
import edu.wpi.first.math.kinematics.SwerveModuleState;
/**
* Second order kinematics swerve module state.
*/
public class SwerveModuleState2 extends SwerveModuleState
{
/**
* Rad per sec
*/
2023-04-08 12:31:07 -05:00
public double omegaRadPerSecond = 0;
2023-02-13 14:37:05 -06:00
/**
* Constructs a SwerveModuleState with zeros for speed and angle.
*/
public SwerveModuleState2()
{
2023-04-08 12:31:07 -05:00
super();
2023-02-13 14:37:05 -06:00
}
/**
* Constructs a SwerveModuleState.
*
* @param speedMetersPerSecond The speed of the wheel of the module.
* @param angle The angle of the module.
* @param omegaRadPerSecond The angular velocity of the module.
*/
public SwerveModuleState2(
double speedMetersPerSecond, Rotation2d angle, double omegaRadPerSecond)
2023-02-13 14:37:05 -06:00
{
2023-04-08 12:31:07 -05:00
super(speedMetersPerSecond, angle);
this.omegaRadPerSecond = omegaRadPerSecond;
}
/**
* Create a {@link SwerveModuleState2} based on the {@link SwerveModuleState} with the radians per second defined.
*
* @param state First order kinematic module state.
* @param omegaRadPerSecond Module wheel angular rotation in radians per second.
*/
public SwerveModuleState2(SwerveModuleState state, double omegaRadPerSecond)
{
super(state.speedMetersPerSecond, state.angle);
2023-02-13 14:37:05 -06:00
this.omegaRadPerSecond = omegaRadPerSecond;
}
2023-04-08 12:31:07 -05:00
/**
* Minimize the change in heading the desired swerve module state would require by potentially reversing the direction
* the wheel spins. If this is used with the PIDController class's continuous input functionality, the furthest a
* wheel will ever rotate is 90 degrees.
*
* @param desiredState The desired state.
* @param currentAngle The current module angle.
* @param lastState The last state of the module.
* @param moduleSteerFeedForwardClosedLoop The module feed forward closed loop for the angle motor.
* @return Optimized swerve module state.
*/
public static SwerveModuleState2 optimize(SwerveModuleState2 desiredState, Rotation2d currentAngle,
SwerveModuleState2 lastState, double moduleSteerFeedForwardClosedLoop)
{
SwerveModuleState2 optimized = new SwerveModuleState2(SwerveModuleState.optimize(desiredState, currentAngle),
desiredState.omegaRadPerSecond);
if (desiredState.angle.equals(currentAngle) || desiredState.angle.equals(
optimized.angle.rotateBy(Rotation2d.fromDegrees(180))) || moduleSteerFeedForwardClosedLoop == 0)
{
optimized.omegaRadPerSecond = 0;
}
if (desiredState.angle.equals(optimized.angle.rotateBy(Rotation2d.fromDegrees(180))))
{
desiredState.omegaRadPerSecond = 0;
return desiredState;
}
return optimized;
/*
// NEVER optimize if it's the same angle, it just doesn't make sense...
if (currentAngle.equals(desiredState.angle.rotateBy(Rotation2d.fromDegrees(180))))
{
desiredState.invert();
desiredState.omegaRadPerSecond = 0;
return desiredState;
} else if (currentAngle.equals(desiredState.angle))
{
desiredState.omegaRadPerSecond = 0;
return desiredState;
}
SwerveModuleState2 optimized;
2023-04-08 12:31:07 -05:00
if (moduleSteerFeedForwardClosedLoop == 0)
{
// desiredState.angle = desiredState.angle.plus(Rotation2d.fromRadians(
// lastState.omegaRadPerSecond * moduleSteerFeedForwardClosedLoop * 0.065));
// return new SwerveModuleState2(SwerveModuleState.optimize(desiredState, currentAngle),
// desiredState.omegaRadPerSecond);
optimized = new SwerveModuleState2(SwerveModuleState.optimize(desiredState, currentAngle), 0);
2023-04-08 12:31:07 -05:00
// return desiredState;
} else
{
Rotation2d delta = desiredState.angle.plus(Rotation2d.fromRadians(lastState.omegaRadPerSecond *
moduleSteerFeedForwardClosedLoop *
0.065))
.minus(currentAngle);
if (Double.compare(Math.abs(delta.getDegrees()), 90.0) < 0)
2023-04-08 12:31:07 -05:00
{
optimized = desiredState.invert();
optimized.angle = optimized.angle.plus(Rotation2d.fromRadians(lastState.omegaRadPerSecond *
moduleSteerFeedForwardClosedLoop *
0.065));
} else
{
optimized = desiredState;
2023-04-08 12:31:07 -05:00
}
}
if (Double.compare(Math.abs(currentAngle.minus(optimized.angle).getDegrees()),
Math.abs(currentAngle.minus(desiredState.angle)
.getDegrees())) > 0)
{
desiredState.omegaRadPerSecond = 0;
return desiredState;
}
// Maybe the omega rad per second will always be off when optimized?
// optimized.omegaRadPerSecond = 0;
return optimized;
*/
}
/**
* Invert the swerve module state.
*
* @return Current inverted {@link SwerveModuleState2}
*/
public SwerveModuleState2 invert()
{
// omegaRadPerSecond *= -1;
// speedMetersPerSecond *= -1;
// angle = angle.rotateBy(Rotation2d.fromDegrees(180));
// return this;
return new SwerveModuleState2(-speedMetersPerSecond,
angle.rotateBy(Rotation2d.fromDegrees(180)),
-omegaRadPerSecond);
2023-04-08 12:31:07 -05:00
}
/**
* Convert to a {@link SwerveModuleState}.
*
* @return {@link SwerveModuleState} with the same angle and speed.
*/
public SwerveModuleState toSwerveModuleState()
{
return new SwerveModuleState(this.speedMetersPerSecond, this.angle);
}
2023-02-13 14:37:05 -06:00
}