Skip to content

Conversation

@josephduchesne
Copy link

@josephduchesne josephduchesne commented Nov 27, 2024

This PR updates diff_drive odometry class to

  • consistantly use velocity where it claims to (the odometry class no longer arbitrarily swaps between position delta and velocity without comments, despite parameter and/or method names claiming to take velocity).
  • use a consistant timestep (dt) in every method that makes use of it
  • rely on diff_drive_controller to decide which timestep source to use (avoiding existing and new cases where diff_drive_controller uses nominal timestep, and odometry uses

This was requested in #271, although I took a more expansive approach since the odometry class is was at high risk of new bugs due the unclear units of variables at play.

  • The result is that the class is very slightly less efficient (but still quite trivial) due to passing around a extra double.

  • The other result is that it is no longer possible for velocity based odometry updates calculated incorrectly when the timestep fails to keep up.

To prevent position based updates from now suffering the inverse of the velocity timestep/dt mismatch, the measured delta is used exclusively for position based updates (retaining the existing behavior), while the configured timestep is used for open and closed loop velocity updates. This decision is made by diff_drive_controller, and out of scope of the odometry class.

I also added a 1s throttled warning if there is a major mismatch between measured and configured timestep (+/-20%) since this would cause a slight accumulation of integration errors on curved paths (I believe), depending on velocity, curvature and mismatch size. This could probably be expanded to a more general diagnostics WARN output, since controller/odometry updates failing to keep up can be serious.

Similar requested period/measured period mismatches may be a nuisance for open loop (which is velocity based) and closed loop velocity based updates, but the impact is likely negligible (in this class).

use velocity where it claims to, and pass timestep
in to every method that makes use of it.

This was requested in ros-controls#271.

- The result is that the class is very slightly less efficient (but
still quite trivial) due to passing around a extra double.

- The other result is that it is no longer possible for velocity based
odometry updates calculated incorrectly when the timestep fails to keep up.

To prevent position based updates from now suffering the inverse of
the velocity timestep/dt mismatch, the measured delta is used exclusively
for position based updates (retaining the existing behavior), while the
configured timestep is used for open and closed loop velocity updates.

I also added a 1s throttled warning if there is a major mismatch between
measured and configured timestep (+/-20%) since this would cause a slight
accumulation of integration errors on curved paths (I believe), depending
on velocity, curvature and mismatch size.

Similar requested period/measured period mismatches may be a nuisance for
open loop (which is velocity based) and closed loop velocity based updates,
but the impact is likely negligible (in this class).
Copy link
Contributor

@christophfroehlich christophfroehlich left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for picking this old issue, I agree this should be more explicit.

But I have comments in the code here, I'm not sure if this is really an issue what you tried to fix.

In general:

  • Please check the pre-commit failures
  • We should deprecate the old methods but keep them for a while
  • If we are breaking API here, we should rename all odometry class methods to have snake case which is the standard of ros2_control (and ROS 2 in general afaik)

integrateExact(linear, angular);
integrateExact(linear, angular, dt);

timestamp_ = time;
Copy link
Contributor

@christophfroehlich christophfroehlich Nov 30, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

timestamp_ class variable should be removed now (marked as deprecated to be removed with the old methods)

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

good catch

odometry_.update(left_feedback_mean, right_feedback_mean, time);
// Warn if actual timestep doesn't match period,
// since
const double measured_period = (
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why should the measured period be different from the period argument of the update method? This is calculated from the controller_manager, we can assume that this is always valid?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was thinking on this some more myself and came to the same conclusion.

I'm hoping to rework this PR sometime next week focusing on the code quality/cleanup aspects suggested here and remove the inconsistent time handling (which as you suggest is probably a distinction without a difference).

Recently I've switched to using the RT_Linux kernel and set up permissions for real-time and found a fairly dramatic difference in perceived responsiveness with it enabled in the diff drive controller. Something isn't handling time/dates/update timesteps properly and I think I incorrectly identified this as the culprit. It still might be, but I should have started off with unit tests (or at least minimum steps to reproduce) rather than complicating an otherwise straightforward code cleanup.

@codecov
Copy link

codecov bot commented Nov 30, 2024

Codecov Report

❌ Patch coverage is 54.16667% with 11 lines in your changes missing coverage. Please review.
✅ Project coverage is 83.81%. Comparing base (f64c964) to head (8121ed2).
⚠️ Report is 210 commits behind head on master.

Files with missing lines Patch % Lines
diff_drive_controller/src/odometry.cpp 55.00% 8 Missing and 1 partial ⚠️
...iff_drive_controller/src/diff_drive_controller.cpp 50.00% 1 Missing and 1 partial ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master    #1394      +/-   ##
==========================================
+ Coverage   83.58%   83.81%   +0.23%     
==========================================
  Files         122      122              
  Lines       10990    10987       -3     
  Branches      935      936       +1     
==========================================
+ Hits         9186     9209      +23     
+ Misses       1492     1464      -28     
- Partials      312      314       +2     
Flag Coverage Δ
unittests 83.81% <54.16%> (+0.23%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

Files with missing lines Coverage Δ
...troller/include/diff_drive_controller/odometry.hpp 100.00% <ø> (ø)
...iff_drive_controller/src/diff_drive_controller.cpp 76.80% <50.00%> (+0.38%) ⬆️
diff_drive_controller/src/odometry.cpp 76.05% <55.00%> (+32.81%) ⬆️

... and 2 files with indirect coverage changes

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@josephduchesne
Copy link
Author

In general:

  • Please check the pre-commit failures
  • We should deprecate the old methods but keep them for a while
  • If we are breaking API here, we should rename all odometry class methods to have snake case which is the standard of ros2_control (and ROS 2 in general afaik)

Thanks, this is my first PR for the repo and I understand the value of consistency for a big open source project like this. I'll try to get things better aligned/more narrowly focused and either update the PR branch, or close this if I won't have the time in the next two weeks.

@mergify
Copy link
Contributor

mergify bot commented Dec 19, 2024

This pull request is in conflict. Could you fix it @josephduchesne?

@christophfroehlich
Copy link
Contributor

@josephduchesne are you still working on this?

@Amronos
Copy link
Contributor

Amronos commented Mar 15, 2025

@christophfroehlich can you review the odometry implementation in #1535? If it looks good, I can make a PR making similar modifications to the diff_drive_controller.

@github-actions
Copy link
Contributor

This PR is stale because it has been open for 45 days with no activity. Please tag a maintainer for help on completing this PR, or close it if you think it has become obsolete.

@github-actions github-actions bot added the stale label Apr 29, 2025
@mergify
Copy link
Contributor

mergify bot commented Apr 29, 2025

This pull request is in conflict. Could you fix it @josephduchesne?

@github-actions github-actions bot removed the stale label Apr 30, 2025
@github-actions
Copy link
Contributor

This PR is stale because it has been open for 45 days with no activity. Please tag a maintainer for help on completing this PR, or close it if you think it has become obsolete.

@github-actions github-actions bot added stale and removed stale labels Jun 16, 2025
@christophfroehlich christophfroehlich marked this pull request as draft July 25, 2025 07:25
@github-actions
Copy link
Contributor

github-actions bot commented Sep 8, 2025

This PR is stale because it has been open for 45 days with no activity. Please tag a maintainer for help on completing this PR, or close it if you think it has become obsolete.

@github-actions github-actions bot added the stale label Sep 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[DiffDriveController] use "period" argument in the update method insead of calculating "dt"

3 participants