-
Notifications
You must be signed in to change notification settings - Fork 201
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
Usage of tf2 outside of ROS (evaluation for Basis) #726
Comments
Yes and no. Certainly we could consider adding generic APIs that are ROS-independent; that is no problem. However, removing/moving the ROS-specific APIs would have to be done over several releases, since we can only break API in a "tick-tock" manner; in one release we deprecate an API, and in the next we remove it. My suggestion is to start with a PR for the "easy" part; adding in the generate API. We can review that one. And then we can talk about moving those ROS-specific APIs with deprecations. |
+1 on doing this work, starting from adding the new APIs that work on I was indeed looking to get this done myself, although for a different reason. |
Glad to hear it.
I have no desire to do a hard break of the API. How long would that take? I'm trying to figure out how to cross this against the work I need to do to get a basis-based build going. I think the easiest option would be to make the ROS bindings able to be #ifdef'd out, that way the API as ROS and friends see it stays the same, but generic frontends can do something else. The other option is to make another class that sits in between
Do you have preferences for naming? We have |
We don't generally ifdef-out things. This would also require your users to manually build that repo.
Yes, I agree that this feels wrong. Normally, what we do is that we do a PR that adds the new APIs and marks as deprecated the old ones. After the next ROS release is out (in May next year) we would remove the deprecated functions in the rolling branch and as such from the following releases. I think that for you, once the new APIs are in place, the easiest thing is to fork and ifdef-out the old functions (you can do it also now, but at least that way you can first make sure that the new APIs are what will eventually be used by the "official ROS distro"). |
I think that the closest thing we did is what happened with Note how in that case we created a new branch Note that at the time, rosbag2 was almost unusable without those changes. |
I don't mind forking as long as eventually my fork and upstream converge, sounds good. |
Did some more work on this - found two more areas that depends on ROS - logging and the CMake file itself. Both of those are by necessity compile time choices. The CMake file can be split into two so that vanilla (non-CMake) builds can operate on just the library itself, or controlled via an option. Logging is trickier - it would be easier if you'd reconsider not allowing compile time choices for tf2 - anyone wanting to have a ROS free version of tf2 won't be pulling it from The only other option I see is to have a runtime configurable logging handler. It looks like the only place there's logging is in |
I'm not sure I understand you here. Can you explain more about what you are trying to accomplish?
What would you propose as a "compile time choice"? How would it work? Overall, I'm happy to make changes here to make tf2 more standalone, but I don't want to introduce a lot of complexity either in tf2 itself or in the rest of the ecosystem to get there. |
I don't have a desire to introduce complexity to TF either. CMake - I want to do something like this:
and have it compile as a standalone library. This might require setting some sort of "compile time choice": - swapping TF to use a different logging macro would be one. Have I can give more concrete examples of these in the coming days, if it would be easier. |
So one thing we could consider, which has been done elsewhere in the ecosystem, is to try and find |
That would work for me. Sent from my iPhoneOn Nov 13, 2024, at 6:07 PM, Chris Lalancette ***@***.***> wrote:
and have it compile as a standalone library. This might require setting some sort of option for CMake, but that's okay. I've given an example here - https://github.com/basis-robotics/geometry2/blob/generic_tf2_core_2/tf2/CMakeLists.txt#L14, but it would be even cleaner to separate out just the lines associated with add_library and move them to a separate .cmake file. In the end it's not horrible if I can't do this (I can instead duplicate the contents of the CMake file or maintain a fork), but in general standalone users won't want to use ament, as it comes with some baggage.
So one thing we could consider, which has been done elsewhere in the ecosystem, is to try and find ament_cmake, and fall-back to using "standard" CMake if it is not available. You can see an example of that in action in https://github.com/facontidavide/PlotJuggler/blob/main/CMakeLists.txt , but it does add some complexity; there is a reason we use ament_cmake, after all. But it would be worthwhile exploring how much complexity it would add to the tf2 CMake file. I can't guarantee we'll take it (one of the great strengths of ROS is how consistent our CMakeFiles.txt are), but we can certainly evaluate it.
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you authored the thread.Message ID: ***@***.***>
|
This was a compromise we made early on. The library is designed to be independent but we didn't want to force the use of abstracting the datatypes completely and then forcing additional copies/conversions so the datatype is reused. Breaking tf2 out into a fully separate library is something that could be done, but so far we haven't had the demand for doing along with someone who's interested in taking on the additional effort and maintenance burden. For the technical side of forking it and just getting it done. I've done this several times, and what you need to do is copy the few generated message datatypes from a ROS workspace and install them through another mechanism. And you do need the couple of utility dependencies. In this sort of situation just rewriting the build into your other projects approach is usually best. Which will eliminate ament (even if you stick to CMake, you won't have the ament linters, or necessarily the gtest facilities that we use in our standard ROS approach that could be disabled instead of trying to make them all work there. And for things like the logging macros. You can also just copy them into the same place that you put the copied headers for the messages. |
Copying the ros types out is something I'm not excited to do - it means that now I always go through an additional copy, from the internal to the ROS type to my type. Additionally anything storing tf2 types or doing math on them without serializing them will use an additional copy. I'm happy to maintain my own CMake file internally, it's not a big deal - but putting aside my usecases, architecturally the ROS types really don't belong. There's code here https://github.com/basis-robotics/geometry2/blob/rolling/tf2/src/buffer_core.cpp#L704 that would be better served just calling |
Hi Kyle, Do you have a motivation for trying to avoid dependency on ROS generated messages? It's a build time dependency, but at runtime, the message files only use the STL last I checked. I've had this discussion with about 8 teams across various companies, and this argument was sufficient to convince all of them to accept a dependency on the ROS-tooling generated messages except one, who had a C++14 maximum allowed by their customer. We used to maintain a parallel set of messages that mirror the ROS message structures, but only use C Being able to use tf2_core, as well as the static transform broadcaster and listener in a non-ROS ecosystem is frequently desired by some of our integrators. |
For purely selfish reasons - I'm building a ROS alternative https://github.com/basis-robotics/basis - the API and functionality provided by tf2 are good. I didn't want to pull in ROS build things at all in my framework - for reasons around not wanting to complicate the build system and dependencies. This would also lead to extra conversions - why pull a I have a ROS free fork of |
Bug report
Required Info:
Steps to reproduce issue
Unable to compile
tf2
outside of ROS.Expected behavior
Can compile
tf2
outside of ROS, given ample legwork, given documentation.Actual behavior
Cannot compile
tf2
outside of ROS.Additional information
Hi, I'm evaluating use of
tf2
inside another robotics framework (https://github.com/basis-robotics/basis). Looking at https://github.com/ros2/geometry2/blob/rolling/tf2/mainpage.dox, there's a claim thatCore is ROS agnostic
, but looking at https://github.com/ros2/geometry2/blob/rolling/tf2/src/buffer_core.cpp#L181 there's stillgeometry_msgs
sprinkled around (and in some other places, too).setTransformImpl
looks nicely independent, butsetTransform
uses the ROS type. The same with the other*Impl
types. The core seems to be pretty generic, it's not far off.I'm happy to do the legwork to write my own CMake file, integration, etc - but I'd like to avoid forking the core library itself. Would a PR be accepted that changed
getTransform
to return atf2::Transform
, and then ran the conversion to rosmsg inside oftf2_ros
or another library that sits in between the two? (and the same with the other interfaces that are tied to ROS?)tf2
support is feedback that I've gotten from potential users, it would be great if I could provide another frontend to your library, rather than reimplementing it myself.The text was updated successfully, but these errors were encountered: