Skip to content

Commit

Permalink
Use transforms when applying vision pose
Browse files Browse the repository at this point in the history
  • Loading branch information
suryatho committed Feb 14, 2024
1 parent 67f0108 commit 080d70e
Showing 1 changed file with 11 additions and 5 deletions.
16 changes: 11 additions & 5 deletions src/main/java/org/littletonrobotics/frc2024/RobotState.java
Original file line number Diff line number Diff line change
Expand Up @@ -143,15 +143,21 @@ public void addVisionObservation(VisionObservation observation) {
}
}
// difference between estimate and vision pose
Twist2d twist = estimateAtTime.log(observation.visionPose());
Transform2d transform = new Transform2d(estimateAtTime, observation.visionPose());
// scale twist by visionK
var kTimesTwist = visionK.times(VecBuilder.fill(twist.dx, twist.dy, twist.dtheta));
Twist2d scaledTwist =
new Twist2d(kTimesTwist.get(0, 0), kTimesTwist.get(1, 0), kTimesTwist.get(2, 0));
var kTimesTransform =
visionK.times(
VecBuilder.fill(
transform.getX(), transform.getY(), transform.getRotation().getRadians()));
Transform2d scaledTransform =
new Transform2d(
kTimesTransform.get(0, 0),
kTimesTransform.get(1, 0),
Rotation2d.fromRadians(kTimesTransform.get(2, 0)));

// Recalculate current estimate by applying scaled twist to old estimate
// then replaying odometry data
estimatedPose = estimateAtTime.exp(scaledTwist).plus(sampleToOdometryTransform);
estimatedPose = estimateAtTime.plus(scaledTransform).plus(sampleToOdometryTransform);
}

public void addVelocityData(Twist2d robotVelocity) {
Expand Down

0 comments on commit 080d70e

Please sign in to comment.