mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-21 01:01:43 +00:00
[wpimath] Discard stale pose estimates (#5045)
Co-authored-by: Tyler Veness <calcmogul@gmail.com>
This commit is contained in:
@@ -40,8 +40,10 @@ public class DifferentialDrivePoseEstimator {
|
||||
private final Matrix<N3, N1> m_q = new Matrix<>(Nat.N3(), Nat.N1());
|
||||
private Matrix<N3, N3> m_visionK = new Matrix<>(Nat.N3(), Nat.N3());
|
||||
|
||||
private static final double kBufferDuration = 1.5;
|
||||
|
||||
private final TimeInterpolatableBuffer<InterpolationRecord> m_poseBuffer =
|
||||
TimeInterpolatableBuffer.createBuffer(1.5);
|
||||
TimeInterpolatableBuffer.createBuffer(kBufferDuration);
|
||||
|
||||
/**
|
||||
* Constructs a DifferentialDrivePoseEstimator with default standard deviations for the model and
|
||||
@@ -187,6 +189,11 @@ public class DifferentialDrivePoseEstimator {
|
||||
* or sync the epochs.
|
||||
*/
|
||||
public void addVisionMeasurement(Pose2d visionRobotPoseMeters, double timestampSeconds) {
|
||||
// Step 0: If this measurement is old enough to be outside the pose buffer's timespan, skip.
|
||||
if (m_poseBuffer.getInternalBuffer().lastKey() - kBufferDuration > timestampSeconds) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Step 1: Get the pose odometry measured at the moment the vision measurement was made.
|
||||
var sample = m_poseBuffer.getSample(timestampSeconds);
|
||||
|
||||
|
||||
@@ -39,8 +39,10 @@ public class MecanumDrivePoseEstimator {
|
||||
private final Matrix<N3, N1> m_q = new Matrix<>(Nat.N3(), Nat.N1());
|
||||
private Matrix<N3, N3> m_visionK = new Matrix<>(Nat.N3(), Nat.N3());
|
||||
|
||||
private static final double kBufferDuration = 1.5;
|
||||
|
||||
private final TimeInterpolatableBuffer<InterpolationRecord> m_poseBuffer =
|
||||
TimeInterpolatableBuffer.createBuffer(1.5);
|
||||
TimeInterpolatableBuffer.createBuffer(kBufferDuration);
|
||||
|
||||
/**
|
||||
* Constructs a MecanumDrivePoseEstimator with default standard deviations for the model and
|
||||
@@ -175,6 +177,11 @@ public class MecanumDrivePoseEstimator {
|
||||
* your time source or sync the epochs.
|
||||
*/
|
||||
public void addVisionMeasurement(Pose2d visionRobotPoseMeters, double timestampSeconds) {
|
||||
// Step 0: If this measurement is old enough to be outside the pose buffer's timespan, skip.
|
||||
if (m_poseBuffer.getInternalBuffer().lastKey() - kBufferDuration > timestampSeconds) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Step 1: Get the pose odometry measured at the moment the vision measurement was made.
|
||||
var sample = m_poseBuffer.getSample(timestampSeconds);
|
||||
|
||||
|
||||
@@ -40,8 +40,10 @@ public class SwerveDrivePoseEstimator {
|
||||
private final int m_numModules;
|
||||
private Matrix<N3, N3> m_visionK = new Matrix<>(Nat.N3(), Nat.N3());
|
||||
|
||||
private static final double kBufferDuration = 1.5;
|
||||
|
||||
private final TimeInterpolatableBuffer<InterpolationRecord> m_poseBuffer =
|
||||
TimeInterpolatableBuffer.createBuffer(1.5);
|
||||
TimeInterpolatableBuffer.createBuffer(kBufferDuration);
|
||||
|
||||
/**
|
||||
* Constructs a SwerveDrivePoseEstimator with default standard deviations for the model and vision
|
||||
@@ -177,6 +179,11 @@ public class SwerveDrivePoseEstimator {
|
||||
* or sync the epochs.
|
||||
*/
|
||||
public void addVisionMeasurement(Pose2d visionRobotPoseMeters, double timestampSeconds) {
|
||||
// Step 0: If this measurement is old enough to be outside the pose buffer's timespan, skip.
|
||||
if (m_poseBuffer.getInternalBuffer().lastKey() - kBufferDuration > timestampSeconds) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Step 1: Get the pose odometry measured at the moment the vision measurement was made.
|
||||
var sample = m_poseBuffer.getSample(timestampSeconds);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user