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 EventsExecutor #161

Merged
merged 5 commits into from
Feb 24, 2022
Merged

Conversation

irobot-ros
Copy link
Contributor

@irobot-ros irobot-ros commented Oct 21, 2020

This PR introduces the changes required to implement the EventsExecutor design in rmw.
See design and Discourse post.

The new executor uses an events queue and a timers manager as opposed to waitsets, to efficiently execute entities with work to do.

This new executor greatly reduces CPU usage of a ROS 2 application.
See the blog post for more details on the tests that we run.

The bulk of the changes for this implementation are in the rclcpp layer, with some minor changes in other repositories (rcl, rmw, rmw_implementation) for forwarding entities, the declaration of some data types in rcutils, and finally some additional changes in the vendor specific rmw implementations..
We currently implemented this only on top of the default ROS middleware fastrtps, while we provided stubs for other middlewares.

See the main PR to rclcpp ros2/rclcpp#1416.

The current implementation does not support ROS 2 actions, which will be added in a follow up PR.

Developed by iRobot
Mauro Passerino
Lenny Story
Alberto Soragna


Connects to:

@ros-discourse
Copy link

This pull request has been mentioned on ROS Discourse. There might be relevant details there:

https://discourse.ros.org/t/ros2-middleware-change-proposal/15863/20

@irobot-ros irobot-ros force-pushed the irobot/add-events-executor branch from 9475e03 to eadac9e Compare March 12, 2021 11:18
@wjwwood wjwwood force-pushed the irobot/add-events-executor branch 2 times, most recently from 59cccfe to e5b59cf Compare April 5, 2021 18:12
Mauro added 3 commits January 11, 2022 19:01
add constness

Use or discard previous events: Guard conditions

Rename to set_events_executor_callback

Add events support

void return on set_events_executor_callback

Revert "void return on set_events_executor_callback"

Signed-off-by: Alberto Soragna <asoragna@irobot.com>
Signed-off-by: Mauro Passerino <mpasserino@irobot.com>
Signed-off-by: Mauro Passerino <mpasserino@irobot.com>
@wjwwood wjwwood force-pushed the irobot/add-events-executor branch from e5b59cf to f36c4af Compare January 12, 2022 03:02
Signed-off-by: William Woodall <william@osrfoundation.org>
@wjwwood wjwwood force-pushed the irobot/add-events-executor branch from f36c4af to 70583c4 Compare January 12, 2022 03:03
@wjwwood wjwwood merged commit 6193992 into ros2:master Feb 24, 2022
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.

3 participants