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

Remove front_steering from steering library #1166

Open
wants to merge 11 commits into
base: master
Choose a base branch
from

Conversation

qinqon
Copy link
Contributor

@qinqon qinqon commented Jun 8, 2024

To Accommodate controllers that are not only steering at front or rear
this change remove the front_steering variable from
steering_controller_library, as a byproduct of that the notion of
front or rear wheel radius is also removed from dependant controllers
and the library has know "traction_joints_names" and
"steering_joints_names" instead of "front_wheels_names" and
"rear_wheels_names".

Depends on:

@qinqon qinqon force-pushed the remove_front_steering_param_from_steering_library branch 4 times, most recently from c83dce3 to 71800b2 Compare June 8, 2024 08:32
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.

I support the idea, thanks!

Please deprecate the old parameters and add the new ones to support both temporarily. Then we can also backport such changes.

Additionally, please add migration notes here.

@christophfroehlich
Copy link
Contributor

christophfroehlich commented Jun 8, 2024

Have you read and considered #692? Ideally, we should solve it with this PR.
I'm not sure if your proposal works for 4WD + 4x steering?

@qinqon qinqon changed the title [WIP] Remove front_steering from steering library Remove front_steering from steering library Jun 8, 2024
@qinqon
Copy link
Contributor Author

qinqon commented Jun 8, 2024

Have you read and considered #692? Ideally, we should solve it with this PR.

The idea is the same, is all about generalize the steering library a little more.

I'm not sure if your proposal works for 4WD + 4x steering?

Next PR will allow that, I am thinking about extending the current ackermann instead of new controller, if you add a pair of traction and steering joints and define the instantaneus center of robot you can have this by modifyting a little the IK and odometry. Also you can keep the current ackermann by configuring the instantaneus centor or robot at the traction joints and using the same IK and odometry.

@qinqon qinqon force-pushed the remove_front_steering_param_from_steering_library branch 12 times, most recently from 3965416 to c09d17b Compare June 12, 2024 20:58
@qinqon qinqon force-pushed the remove_front_steering_param_from_steering_library branch from c09d17b to 41b3219 Compare June 19, 2024 17:22
Copy link
Contributor

mergify bot commented Jun 19, 2024

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

@qinqon
Copy link
Contributor Author

qinqon commented Jun 23, 2024

Tests working

$ colcon test 
Starting >>> steering_controllers_library
Finished <<< steering_controllers_library [0.44s]          
Starting >>> ackermann_steering_controller
Starting >>> bicycle_steering_controller
Starting >>> tricycle_steering_controller                                                                    
Finished <<< bicycle_steering_controller [1.50s]                                                                                                   
Finished <<< ackermann_steering_controller [1.58s]                                                            
Finished <<< tricycle_steering_controller [1.52s]

Summary: 4 packages finished [3.01s]

@qinqon qinqon force-pushed the remove_front_steering_param_from_steering_library branch 2 times, most recently from 3a6a032 to 07b63e6 Compare July 5, 2024 07:07
@bmagyar
Copy link
Member

bmagyar commented Jul 6, 2024

@destogl please add your take

@qinqon qinqon force-pushed the remove_front_steering_param_from_steering_library branch from 07b63e6 to f3b643a Compare July 13, 2024 06:25
@qinqon
Copy link
Contributor Author

qinqon commented Jul 13, 2024

@destogl I have rebase the PR, the idea is to prepare a PR based on this one to allow four steering at the ackerman controller.

To Accommodate controllers that are not only steering at front or rear
this change remove the `front_steering` variable from
steering_controller_library, as a byproduct of that the notion of
front or rear wheel radius is also removed from dependant controllers
and the library has know "traction_joints_names" and
"steering_joints_names" instead of "front_wheels_names" and
"rear_wheels_names".

Signed-off-by: Quique Llorente <ellorent@redhat.com>
@qinqon qinqon force-pushed the remove_front_steering_param_from_steering_library branch from f3b643a to 4710c60 Compare September 7, 2024 08:33
Copy link

codecov bot commented Sep 7, 2024

Codecov Report

Attention: Patch coverage is 75.94340% with 51 lines in your changes missing coverage. Please review.

Project coverage is 83.68%. Comparing base (ad7739f) to head (0db41b5).

Files with missing lines Patch % Lines
...llers_library/src/steering_controllers_library.cpp 52.17% 17 Missing and 5 partials ⚠️
...g_controller/src/ackermann_steering_controller.cpp 26.08% 12 Missing and 5 partials ⚠️
...ing_controller/src/bicycle_steering_controller.cpp 33.33% 4 Missing and 2 partials ⚠️
...ng_controller/src/tricycle_steering_controller.cpp 40.00% 4 Missing and 2 partials ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master    #1166      +/-   ##
==========================================
- Coverage   83.83%   83.68%   -0.15%     
==========================================
  Files         122      122              
  Lines       11120    11153      +33     
  Branches      944      951       +7     
==========================================
+ Hits         9322     9333      +11     
- Misses       1489     1504      +15     
- Partials      309      316       +7     
Flag Coverage Δ
unittests 83.68% <75.94%> (-0.15%) ⬇️

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

Files with missing lines Coverage Δ
...roller/test/test_ackermann_steering_controller.cpp 100.00% <100.00%> (ø)
...roller/test/test_ackermann_steering_controller.hpp 86.59% <100.00%> (ø)
.../test_ackermann_steering_controller_preceeding.cpp 100.00% <100.00%> (ø)
...ntroller/test/test_bicycle_steering_controller.cpp 100.00% <100.00%> (ø)
...ntroller/test/test_bicycle_steering_controller.hpp 83.75% <100.00%> (+0.63%) ⬆️
...st/test_bicycle_steering_controller_preceeding.cpp 100.00% <100.00%> (ø)
...steering_controllers_library/steering_odometry.hpp 100.00% <ø> (ø)
...ring_controllers_library/src/steering_odometry.cpp 83.42% <100.00%> (+0.89%) ⬆️
...library/test/test_steering_controllers_library.cpp 100.00% <100.00%> (ø)
...library/test/test_steering_controllers_library.hpp 96.87% <100.00%> (ø)
... and 7 more

@ARK3r
Copy link
Contributor

ARK3r commented Sep 18, 2024

@christophfroehlich I have a suggestion for arbitrarily long robots with an arbitrary number of traction and steering wheels in each "row". So for example if we have the following setups:

  • bicycle setup 1: 2 rows, one row has a steerable wheel, second row has a traction wheel with the distance between row1 and row2 equal to 1.0 meter (wheelbase)
  • bicycle setup 2: 2 rows, one row has a steerable and traction wheel, second row has a steerable and a traction wheel with the distance between row1 and row2 equal to 1.0 meter (wheelbase)
  • 6 wheel rover (6-wheel rover controller #1243): 3 rows, row1 has two steerable wheels, row2 only has two steerable + traction wheels, row3 has 1 steerable + traction wheel with (1) row1 having a track of 40 cm and (2) row1 and row2 having a distance of 50 cm (wheelbase) and (3) row2 having a track of 30 cm and (4) row2 and row3 having a distance of 20 cm (wheelbase) and (5) row3 having only one wheel.

Then the way each of these can be relayed to the controller could be as follows:

a list (an arbitrarily long number of rows) of lists (info for each row) of two lists and two doubles (steerable joints list, traction joints list, this row's track double, distance of this row to the previous row double) 🫠 where each row's list contains the following info:

[ 
   <list of steerable joints in this row: List>,
   <list of traction joints in this row: List>,
   <row track: Union[None, double]>,
   <wheelbase from prev row: Union[None, double]>
]

so examples of this would be:

  • bicycle setup 1:
[
   [
      ["row1_steering_joint"],
      [ ],
      None,
      None
   ],
   [
      [ ],
      ["row2_traction_joint"],
      None,
      1.0
   ]
]
  • bicycle setup 2:
[
   [
      ["row1_steering_joint"],
      ["row1_traction_joint"],
      None,
      None
   ],
   [
      ["row2_steering_joint" ],
      ["row2_traction_joint"],
      None,
      1.0
   ]
]
  • 6 wheel rover:
[
   [
      ["row1_left_steering_joint", "row1_right_steering_joint"],
      [],
      0.4,
      None
   ],
   [
      ["row2_left_steering_joint", "row2_right_steering_joint" ],
      ["row2_left_traction_joint", "row2_right_traction_joint"],
      0.3,
      0.5
   ],
   [
      ["row3_steering_joint" ],
      ["row3_traction_joint"],
      None,
      0.2
   ]
]

EDIT: Alternatively, for more readability, something like robot_localization's handling of multiple sources of a single message type (like IMU here) can be implemented for row1, row2, ....

@christophfroehlich
Copy link
Contributor

@ARK3r I'm not sure if this is the right place to discuss this (but it would make this PR here obsolete) Let's discuss this in #692

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.

I unearthed this PR, I changed my mind and think it makes sense to merge this before a possible rewrite of the library.

Thanks @qinqon for the initial work, on top of that I did

  • add proper backwards compatibility
  • updated the docs
  • added migration and release notes
  • fixed a bug, that with Ackermann kinematics a different wheel track of the steering and traction axle was not supported (although the parameters were there from the beginning).

@christophfroehlich christophfroehlich requested review from ARK3r and removed request for VanshGehlot January 3, 2025 16:01
@Timple
Copy link
Contributor

Timple commented Jan 3, 2025

It's hard to see on mobile. But I see a separation between tracked and steered wheels.
Can steered wheels also have traction with this pr? We have a vehicle with an active driven front wheel. Would be nice to use this 👍

@christophfroehlich
Copy link
Contributor

It's hard to see on mobile. But I see a separation between tracked and steered wheels. Can steered wheels also have traction with this pr? We have a vehicle with an active driven front wheel. Would be nice to use this 👍

No, this is is not possible yet. I made a proposal once to configure this more freely, but haven't started going in that direction.

Co-authored-by: Reza Kermani <kermani.areza@gmail.com>
@qinqon
Copy link
Contributor Author

qinqon commented Jan 3, 2025

I unearthed this PR, I changed my mind and think it makes sense to merge this before a possible rewrite of the library.

Thanks @qinqon for the initial work, on top of that I did

  • add proper backwards compatibility

  • updated the docs

  • added migration and release notes

  • fixed a bug, that with Ackermann kinematics a different wheel track of the steering and traction axle was not supported (although the parameters were there from the beginning).

@christophfroehlich happy that the PR did help with the effort, let me know on whatever you need.

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.

5 participants