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

Physics: Ray intersections #2514

Open
wants to merge 6 commits into
base: gz-sim9
Choose a base branch
from

Conversation

romulogcerqueira
Copy link

@romulogcerqueira romulogcerqueira commented Aug 5, 2024

🎉 New feature

Related to gazebosim/gz-sensors#26 and gazebosim/gz-physics#641

Summary

This PR introduces components to hold rays and ray intersections data (MultiRay and MultiRayIntersections, respectively), and updates the physics system to compute the ray castings during Update loop.

Test it

Added a test case to physics system.

Build and run ./build/bin/INTEGRATION_physics_system --gtest_filter=PhysicsSystemFixture.RayIntersections

Checklist

  • Signed all commits for DCO
  • Added tests
  • Added example and/or tutorial
  • Updated documentation (as needed)
  • Updated migration guide (as needed)
  • Consider updating Python bindings (if the library has them)
  • codecheck passed (See contributing)
  • All tests passed (See test coverage)
  • While waiting for a review on your PR, please help review another open pull request to support the maintainers

Note to maintainers: Remember to use Squash-Merge and edit the commit message to match the pull request summary while retaining Signed-off-by messages.

@github-actions github-actions bot added the 🎵 harmonic Gazebo Harmonic label Aug 5, 2024
@romulogcerqueira romulogcerqueira force-pushed the romulogcerqueira/ray_intersections branch 3 times, most recently from 815c56b to e9c3a9a Compare August 6, 2024 02:58
@azeey
Copy link
Contributor

azeey commented Aug 6, 2024

Thanks for the PR! However, as stated in https://community.gazebosim.org/t/feature-freeze-for-gazebo-ionic/2900/2, we are now in feature freeze and will not review/merge any new PRs until after Ionic is released at the end of September. I hope you'll be able to iterate on the PR then.

@romulogcerqueira
Copy link
Author

Thanks for the PR! However, as stated in https://community.gazebosim.org/t/feature-freeze-for-gazebo-ionic/2900/2, we are now in feature freeze and will not review/merge any new PRs until after Ionic is released at the end of September. I hope you'll be able to iterate on the PR then.

Thanks for the message, @azeey .

One question: Will all new features be redirected to Ionic, or will we maintain backward compatibility with Harmonic, since the latter is LTS?

@azeey
Copy link
Contributor

azeey commented Aug 9, 2024

One question: Will all new features be redirected to Ionic, or will we maintain backward compatibility with Harmonic, since the latter is LTS?

Once Ionic is released, we'll ask folks to target PRs to Ionic branches and the core team will backport to older release on a best-effort basis. Of course, you are welcome to backport it yourself. See https://community.gazebosim.org/t/gazebo-policy-update-new-backporting-policy/2880 for more details.

@huqin-RM
Copy link

huqin-RM commented Nov 20, 2024

I want this function because I want to realize the livox 360 radar simulation. This radar is spiral scanning, and gpu_ray cannot realize this. So when will this function be implemented? @azeey @romulogcerqueira

e1161b76-f3eb-4491-bd6c-2a62b4d7aa21.2._an.1.mp4

@ntfshard
Copy link
Contributor

It also can be useful for our use-cases I suppose. I guess this branch should be re-targeted on a last branch

@huqin-RM
Copy link

@romulogcerqueira Will this feature be pushed forward to the official version?

@AliceCryer
Copy link

AliceCryer commented Jan 14, 2025

I installed gazebosim with this repository to use this feature, however when attempting to use MultiRay in my plugin, colcon build cannot find the MultiRay.hh file. (I checked and the file is there, and VSCode has no issues with the import statement.) Do I need to adjust my CMakeLists.txt, or is there something specific I need to do to include the file? My code compiles fine otherwise.
Also, is there a way to return the object name that the ray has collided with? It's not a direct part of the MultiRay feature functionality, but is it possible to use the output to query which object is located at the collision point?

@romulogcerqueira
Copy link
Author

Hi @azeey,

With the release of Gazebo Ionic and the increasing interest from the Gazebo community in this feature (thanks @huqin-RM @ntfshard @AliceCryer), I’d like to move forward with this PR.

Could you please advise on the best way to proceed here, given that this PR targets gz-sim8?

@azeey
Copy link
Contributor

azeey commented Jan 15, 2025

Per #2514 (comment), could you target the gz-sim9 branch? You could either use git rebase or git reset --soft to accomplish this. Once you push the changes, you'll then have to change the base branch on the Github interface. Let me know if you face any problems.

And thanks for your patience on this. It's on my queue to review, but I haven't had a chance yet.

@romulogcerqueira romulogcerqueira force-pushed the romulogcerqueira/ray_intersections branch from e9c3a9a to a1471bd Compare January 16, 2025 11:40
@romulogcerqueira romulogcerqueira changed the base branch from gz-sim8 to gz-sim9 January 16, 2025 11:41
@romulogcerqueira romulogcerqueira force-pushed the romulogcerqueira/ray_intersections branch 2 times, most recently from 1a98be5 to ca55c1b Compare January 16, 2025 11:50
@romulogcerqueira
Copy link
Author

Per #2514 (comment), could you target the gz-sim9 branch? You could either use git rebase or git reset --soft to accomplish this. Once you push the changes, you'll then have to change the base branch on the Github interface. Let me know if you face any problems.

And thanks for your patience on this. It's on my queue to review, but I haven't had a chance yet.

Thanks! This PR is now targeting the gz-sim9 branch and is ready for review again.

Since I'm using Harmonic, I'm also interested in the backport of this feature later.

Rômulo Cerqueira added 2 commits January 16, 2025 10:58
@romulogcerqueira romulogcerqueira force-pushed the romulogcerqueira/ray_intersections branch 2 times, most recently from 07a158f to 9d66d09 Compare January 17, 2025 12:14
Signed-off-by: Rômulo Cerqueira <[email protected]>
@romulogcerqueira romulogcerqueira force-pushed the romulogcerqueira/ray_intersections branch from 9d66d09 to 55e2798 Compare January 17, 2025 13:41
@azeey azeey added 🏛️ ionic Gazebo Ionic and removed 🎵 harmonic Gazebo Harmonic labels Jan 17, 2025
Copy link
Contributor

@azeey azeey left a comment

Choose a reason for hiding this comment

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

This is great work! Thanks again for the contribution. My main concern are:

  • Naming of components
  • Coordinate frames of quantities in components
  • Usability: the need for two components

I would also ask you to add some documentation/tutorial that briefly shows how to use this and mentions that the Bullet collision engine must be used.

};

/// \brief A struct that holds the results of raycasting.
struct RayIntersectionInfo
Copy link
Contributor

Choose a reason for hiding this comment

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

Can we also include the Entity that was hit?

Copy link
Author

Choose a reason for hiding this comment

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

While dart::collision::RaycastResult includes the collision object the ray hits, this information is currently not stored by RayIntersection in gz-physics (see here and here).

We can open an issue to address this later. What do you think?

src/systems/physics/Physics.cc Outdated Show resolved Hide resolved
Comment on lines +4200 to +4201
auto worldRayIntersectionFeature =
this->entityWorldMap.EntityCast<RayIntersectionFeatureList>(worldEntity);
Copy link
Contributor

Choose a reason for hiding this comment

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

You should check if the cast was successful. If the feature isn't available in the physics engine, the pointer will be nullptr.

Copy link
Author

Choose a reason for hiding this comment

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

Fixed in 34cbfd6

};

/// \brief A component type that contains multiple rays from an entity.
using MultiRay =
Copy link
Contributor

Choose a reason for hiding this comment

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

Does this essentially contain the requested rays to be cast? If so, can we change the name so that it's clear?


/// \brief A component type that contains the raycasting results from multiple
// rays from an entity into a physics world.
using MultiRayIntersections =
Copy link
Contributor

Choose a reason for hiding this comment

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

Looking at other raycasting APIs, the work "result" usually appears in the data structure used. The comment here also mentions result, so I'd recommend adding that to the name of the component.

Comment on lines +4206 to +4207
_ecm.Each<components::MultiRay,
components::MultiRayIntersections>(
Copy link
Contributor

Choose a reason for hiding this comment

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

Does this mean the user has to create two components on the entity to use this feature? Would it be possible to combine them into one? Or we can have the physics engine be responsible for creating the result component (components::MultiRayIntersections).

/// \brief A struct that holds the information of a ray.
struct RayInfo
{
/// \brief Starting point of the ray in world coordinates
Copy link
Contributor

Choose a reason for hiding this comment

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

If this component is attached to an entity, it's natural to assume the start and end points would be expressed relative to that entity. If the user wants to use world coordinates, they would then just attach the component to the world entity.

struct RayIntersectionInfo
{
/// \brief The hit point in the world coordinates
gz::math::Vector3d point;
Copy link
Contributor

Choose a reason for hiding this comment

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

Similar to my comment above, wouldn't make more sense to express these quantities relative to the frame of the entity this component is attached to?

for (size_t i = 0; i < results1.size(); ++i) {
ASSERT_EQ(results1[i].point, math::Vector3d::Zero);
ASSERT_EQ(results1[i].normal, math::Vector3d(0, 0, 1));
double exp_fraction =
Copy link
Contributor

Choose a reason for hiding this comment

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

nit: use const, use camelCase style

Copy link
Author

Choose a reason for hiding this comment

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

Fixed in 34cbfd6

romulogcerqueira and others added 2 commits January 23, 2025 11:48
Co-authored-by: Addisu Z. Taddese <[email protected]>
Signed-off-by: Rômulo Cerqueira <[email protected]>
…the physics system test

Signed-off-by: Rômulo Cerqueira <[email protected]>
@romulogcerqueira romulogcerqueira force-pushed the romulogcerqueira/ray_intersections branch from 34cbfd6 to 4803b28 Compare January 23, 2025 18:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🏛️ ionic Gazebo Ionic
Projects
Status: In review
Development

Successfully merging this pull request may close these issues.

5 participants