Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add MCKineticsObserver and TiltObserver #30

Draft
wants to merge 45 commits into
base: main
Choose a base branch
from

Conversation

ArnaudDmt
Copy link
Contributor

@ArnaudDmt ArnaudDmt commented Feb 7, 2024

The KineticsObserver is an MEKF-based (Mulitplicative Extended Kalman Filter) estimator that relies on a visco-elastic model of contacts to estimate the following variables: the pose of the robot in the world, its velocity, the external wrench applied on the centroid, the bias on the gyrometer bias, and the contact wrenches and pose.

The TiltObserver is based on a complementary filter which estimates the tilt and the local velocity of the IMU.

Also adding NaiveOdometry, that can be called after updating the realRobot with another estimator. It uses the estimated tilt to perform an odometry based on the successive contacts (that we also call legged odometry), giving a pose in the world. This method assumes that contacts are subject to no slippage.

Both observers can perform either:

  • no odometry: the estimated robot remains attached to the control robot.
  • flat odometry: the TiltObserver will perform a legged odometry using its estimation of the tilt of the robot. The Kinetics Observer will use its visco-elastic model to correct the contacts pose and is therefore more robust to slippage. This odometry mode will consider that the contacts are always on a height z = 0m, which allows a more accurate estimation on flat grounds.
  • 6d odometry: The height constraint for the contacts is not applied here so the odometry can be performed on non-flat environments.

ArnaudDmt and others added 30 commits February 7, 2024 17:23
This reverts commit 5b8ee152beb07975b98066adaa37c52427feb373.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants