Package com.pathplanner.lib.util
Record Class DriveFeedforwards
java.lang.Object
java.lang.Record
com.pathplanner.lib.util.DriveFeedforwards
- Record Components:
accelerationsMPSSq
- Linear acceleration at the wheels in meters per secondlinearForcesNewtons
- Linear force applied by the motors at the wheels in newtonstorqueCurrentsAmps
- Torque-current of the drive motors in ampsrobotRelativeForcesXNewtons
- X components of robot-relative force vectors for the wheels in newtons. The magnitude of these vectors will typically be greater than the linear force feedforwards due to friction forces.robotRelativeForcesYNewtons
- X components of robot-relative force vectors for the wheels in newtons. The magnitude of these vectors will typically be greater than the linear force feedforwards due to friction forces.
- All Implemented Interfaces:
Interpolatable<DriveFeedforwards>
public record DriveFeedforwards(double[] accelerationsMPSSq, double[] linearForcesNewtons, double[] torqueCurrentsAmps, double[] robotRelativeForcesXNewtons, double[] robotRelativeForcesYNewtons)
extends Record
implements Interpolatable<DriveFeedforwards>
Collection of different feedforward values for each drive module. If using swerve, these values
will all be in FL, FR, BL, BR order. If using a differential drive, these will be in L, R order.
NOTE: If using Choreo paths, all feedforwards but the X and Y component arrays will be filled with zeros.
-
Constructor Summary
ConstructorDescriptionDriveFeedforwards
(double[] accelerationsMPSSq, double[] linearForcesNewtons, double[] torqueCurrentsAmps, double[] robotRelativeForcesXNewtons, double[] robotRelativeForcesYNewtons) Creates an instance of aDriveFeedforwards
record class.DriveFeedforwards
(LinearAcceleration[] accelerations, Force[] linearForces, Current[] torqueCurrents, Force[] robotRelativeForcesX, Force[] robotRelativeForcesY) Collection of different feedforward values for each drive module. -
Method Summary
Modifier and TypeMethodDescriptionGet the linear accelerations at the wheelsdouble[]
Returns the value of theaccelerationsMPSSq
record component.final boolean
Indicates whether some other object is "equal to" this one.flip()
Flip the feedforwards for the other side of the field.final int
hashCode()
Returns a hash code value for this object.interpolate
(DriveFeedforwards endValue, double t) Force[]
Get the linear forces at the wheelsdouble[]
Returns the value of thelinearForcesNewtons
record component.reverse()
Reverse the feedforwards for driving backwards.Force[]
Get the X components of the robot-relative force vectors at the wheelsdouble[]
Returns the value of therobotRelativeForcesXNewtons
record component.Force[]
Get the Y components of the robot-relative force vectors at the wheelsdouble[]
Returns the value of therobotRelativeForcesYNewtons
record component.Current[]
Get the torque-current of the drive motorsdouble[]
Returns the value of thetorqueCurrentsAmps
record component.final String
toString()
Returns a string representation of this record class.static DriveFeedforwards
zeros
(int numModules) Create drive feedforwards consisting of all zeros
-
Constructor Details
-
DriveFeedforwards
public DriveFeedforwards(LinearAcceleration[] accelerations, Force[] linearForces, Current[] torqueCurrents, Force[] robotRelativeForcesX, Force[] robotRelativeForcesY) Collection of different feedforward values for each drive module. If using swerve, these values will all be in FL, FR, BL, BR order. If using a differential drive, these will be in L, R order.NOTE: If using Choreo paths, all feedforwards but the X and Y component arrays will be filled with zeros.
- Parameters:
accelerations
- Linear acceleration at the wheelslinearForces
- Linear force applied by the motors at the wheelstorqueCurrents
- Torque-current of the drive motorsrobotRelativeForcesX
- X components of robot-relative force vectors for the wheels. The magnitude of these vectors will typically be greater than the linear force feedforwards due to friction forces.robotRelativeForcesY
- X components of robot-relative force vectors for the wheels. The magnitude of these vectors will typically be greater than the linear force feedforwards due to friction forces.
-
DriveFeedforwards
public DriveFeedforwards(double[] accelerationsMPSSq, double[] linearForcesNewtons, double[] torqueCurrentsAmps, double[] robotRelativeForcesXNewtons, double[] robotRelativeForcesYNewtons) Creates an instance of aDriveFeedforwards
record class.- Parameters:
accelerationsMPSSq
- the value for theaccelerationsMPSSq
record componentlinearForcesNewtons
- the value for thelinearForcesNewtons
record componenttorqueCurrentsAmps
- the value for thetorqueCurrentsAmps
record componentrobotRelativeForcesXNewtons
- the value for therobotRelativeForcesXNewtons
record componentrobotRelativeForcesYNewtons
- the value for therobotRelativeForcesYNewtons
record component
-
-
Method Details
-
zeros
Create drive feedforwards consisting of all zeros- Parameters:
numModules
- Number of drive modules- Returns:
- Zero feedforwards
-
interpolate
- Specified by:
interpolate
in interfaceInterpolatable<DriveFeedforwards>
-
reverse
Reverse the feedforwards for driving backwards. This should only be used for differential drive robots.- Returns:
- Reversed feedforwards
-
flip
Flip the feedforwards for the other side of the field. Only does anything if mirrored symmetry is used- Returns:
- Flipped feedforwards
-
accelerations
Get the linear accelerations at the wheels- Returns:
- Linear accelerations at the wheels
-
linearForces
Get the linear forces at the wheels- Returns:
- Linear forces at the wheels
-
torqueCurrents
Get the torque-current of the drive motors- Returns:
- Torque-current of the drive motors
-
robotRelativeForcesX
Get the X components of the robot-relative force vectors at the wheels- Returns:
- X components of the robot-relative force vectors at the wheels
-
robotRelativeForcesY
Get the Y components of the robot-relative force vectors at the wheels- Returns:
- Y components of the robot-relative force vectors at the wheels
-
toString
Returns a string representation of this record class. The representation contains the name of the class, followed by the name and value of each of the record components. -
hashCode
public final int hashCode()Returns a hash code value for this object. The value is derived from the hash code of each of the record components. -
equals
Indicates whether some other object is "equal to" this one. The objects are equal if the other object is of the same class and if all the record components are equal. All components in this record class are compared withObjects::equals(Object,Object)
. -
accelerationsMPSSq
public double[] accelerationsMPSSq()Returns the value of theaccelerationsMPSSq
record component.- Returns:
- the value of the
accelerationsMPSSq
record component
-
linearForcesNewtons
public double[] linearForcesNewtons()Returns the value of thelinearForcesNewtons
record component.- Returns:
- the value of the
linearForcesNewtons
record component
-
torqueCurrentsAmps
public double[] torqueCurrentsAmps()Returns the value of thetorqueCurrentsAmps
record component.- Returns:
- the value of the
torqueCurrentsAmps
record component
-
robotRelativeForcesXNewtons
public double[] robotRelativeForcesXNewtons()Returns the value of therobotRelativeForcesXNewtons
record component.- Returns:
- the value of the
robotRelativeForcesXNewtons
record component
-
robotRelativeForcesYNewtons
public double[] robotRelativeForcesYNewtons()Returns the value of therobotRelativeForcesYNewtons
record component.- Returns:
- the value of the
robotRelativeForcesYNewtons
record component
-