-
Notifications
You must be signed in to change notification settings - Fork 207
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
feature: components support #188
feature: components support #188
Conversation
Wow, this is cool! Thanks @jcarlosgm30 for implementing it! This seems like a good change, but since it is a big change it'll take some time to understand, review and test, especially to ensure backwards compatibility. A few questions:
|
Hi @jonbinney, Thank you for the reply! I will try to answer the questions as best I can: how backwards compatible is this? Will people who depend on laser_filters be able to use their existing launchfiles and yaml files without modification? could you give some more detail about how this is more efficient? and more flexible? than the current filters implementation?
Therefore, this allows us to create pipelines (e.g. driver+filters+other functionalities) that run in the same process improving efficiency and overhead. Or run the system, as it has been done so far, on a separate node. have you been using this on your own robots? How much testing has it seen so far? If you have any further questions or I can do anything to further align the solution with the project, please let me know |
When I initially read the title of this PR, I thought it was turning each individual filter into a ros2 component.... but now I see that it is much simpler than that. The big scary diff is due to a few things:
(1) and (2) are good changes overall, but usually I'd like to have them in a separate PR that doesn't change any functionality. IMixing them into a PR that adds components makes it very hard to see the actually important changes. Also they make it harder to look back through git history, so in general I tend to leave it as is. (3) breaks all launchfiles not hosted in this repo, so we'd need a very strong reason to allow it, and do at least one ROS distro with a deprecation notice where we have both executables, etc. etc. @jcarlosgm30 can you undo the changes I describe in (1), (2), and (3) and just leave the changes that makes the filter chain nodes into components? I think that should be easier to review and merge. Or is there something about these other changes that is necessary? |
Hi @jonbinney , The changes (2) and (3) are neither necessary nor significant. However, in my opinion, change (1) from a functionality and expressiveness point of view is recommendable. The component has to be compiled as a shared library, and we want to keep backward compatibility by having an executable node for each filter chain. So in this case, from a software point of view, it makes sense to keep the library separate from the executable. The library can be loaded by the component container that needs it, while the executable simply makes use of the library. |
Yes we want the executable - but that doesn't require doing (1), (2), or (3), right? Or am i misunderstanding? |
Yes, it doesn't require doing (1), (2) or (3). But (1) is highly recommended from a functionality and expressiveness point of view. Otherwise, we must compile the same .cpp as a shared library and an executable. This is something I don't like because it violates many of the best practices in software development. |
Adding new functionality and doing code reorganization in one commit also violates many of the best practices of software development :-) Could you undo the renaming of the nodes and undo the adding of the laser_filters namespace, as well as split the file reorganization and adding of the components into two commits so that I can diff them separately? Then I'll do a detailed review to make sure everything looks good. Thanks @jcarlosgm30 ! |
Hi @jonbinney! Sorry for taking so long to reply, I've been away for a while.
You are absolutely right! putting all the code in a commit is also a bad practice
Sure! once I get this done, let me know anything I can help with! Thanks! |
35b60b6
to
2be7a97
Compare
Looks like you update this PR - thanks for working on this! Is it ready for me to take another look? |
@jonbinney Yes, I undid the renaming of the nodes and the laser_filters namespace. Also, I've split the file reorganization and the components into two different commits |
Looks good. @jcarlosgm30 thanks for this PR! |
Hello,
I think that it can be very interesting to transform the "filter_chains" into ROS2 components. This is crucial to facilitate the creation of more flexible and efficient laser pipelines.
This pull request fits this feature.
Key Changes:
Componentization of filter_chains: Transforming "filter_chains" into ROS2 components greatly enhances the flexibility and efficiency in configuring laser pipelines.
Code Restructuring: Classes have been reorganized into private headers and their corresponding source files.
Executable Updates: Executables have been modified to directly run the relevant node, simplifying the deployment and execution process.
Launch Files Update: Example launch files have been updated to reflect these changes.
Benefits:
Improved Flexibility: The ability to easily configure and modify laser pipelines is important in several contexts.
Increased Efficiency: The new component structure facilitates more efficient execution, crucial in high-performance robotics environments.
Functionality Status:
I eagerly await feedback and am willing to make any necessary adaptations to align even more closely with the project's needs and expectations. These changes are designed to not only improve the current development experience but also to open up new possibilities for future enhancements and features.