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

Fixes bug at ToRoadPosition query. #174

Merged
merged 4 commits into from
Sep 14, 2021

Conversation

francocipollone
Copy link
Collaborator

Related to #173

liangfok
liangfok previously approved these changes Sep 14, 2021
Copy link
Collaborator

@liangfok liangfok left a comment

Choose a reason for hiding this comment

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

LGTM

Copy link
Collaborator

@agalbachicar agalbachicar left a comment

Choose a reason for hiding this comment

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

PTAL

Comment on lines 167 to 168
const maliput::api::RBounds lane_boundaries = lane_bounds(s);
const double r = maliput::math::saturate(unconstrained_prh[1], lane_boundaries.min(), lane_boundaries.max());
Copy link
Collaborator

Choose a reason for hiding this comment

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

Please, look at the following https://github.com/ToyotaResearchInstitute/maliput/blob/main/maliput/include/maliput/api/road_geometry.h#L85-L93

Quoted here:

  /// The map from RoadGeometry to the `Inertial`-frame is not onto (as a bounded
  /// RoadGeometry cannot completely cover the unbounded Cartesian universe).
  /// If @p inertial_position does represent a point contained within the volume
  /// of the RoadGeometry, then result distance is guaranteed to be less
  /// than or equal to `linear_tolerance()`.
  ///
  /// The map from RoadGeometry to `Inertial`-frame is not necessarily one-to-one.
  /// Different `(s,r,h)` coordinates from different Lanes, potentially from
  /// different Segments, may map to the same `(x,y,z)` `Inertial`-frame location.

I think using segment_bounds() is correct because when doing ToLanePosition() you can map the entire Segment volume.

If an INERTIAL Frame point falls within the Segment volume it is expected that all RoadPositions (one per RoadPositions in the Segment) have distance close to zero. RoadGeometry::ToRoadGeometry should return the one that minimizes (closer to zero) the r-coordinate.

By looking at #173 , the mapping to lane 1_0_1 yields r = -1.97309e-10 and that's the minimum. The algorithm should return that instead of any other lane in the Segment.

Copy link
Collaborator Author

@francocipollone francocipollone Sep 14, 2021

Choose a reason for hiding this comment

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

Let me know what you think about 26f8b7c.

It matches API definition and complies with both issues:

( I had missed pressing the "comment" button)

@francocipollone francocipollone changed the title Fixes bug at ToLanePosition query. Fixes bug at ToRoadPosition query. Sep 14, 2021
Copy link
Collaborator

@agalbachicar agalbachicar left a comment

Choose a reason for hiding this comment

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

LGTM

Let's add a ticket in multilane to account for this scenario as well.

Can we also create a test case out of issue #173 sample query that originated all this so we make sure it works in the future?

@francocipollone
Copy link
Collaborator Author

LGTM

Let's add a ticket in multilane to account for this scenario as well.

Can we also create a test case out of issue #173 sample query that originated all this so we make sure it works in the future?

+1

Copy link
Collaborator

@agalbachicar agalbachicar left a comment

Choose a reason for hiding this comment

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

LGTM

Let's make the test in a follow up PR so it can be used downstream.

@francocipollone francocipollone merged commit 6f9203d into main Sep 14, 2021
@francocipollone francocipollone deleted the francocipollone/fixes_to_lane_position_bug branch September 14, 2021 20:32
@francocipollone
Copy link
Collaborator Author

Let's add a ticket in multilane to account for this scenario as well.

maliput/maliput_multilane#67

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