Skip to content

Commit

Permalink
fix(static_drivable_area_expansion): fix bound extraction logic (auto…
Browse files Browse the repository at this point in the history
…warefoundation#6006)

* fix(static_drivable_area_expansion): fix bound extraction logic

Signed-off-by: satoshi-ota <[email protected]>

* refactor(static_drivable_area_expansion): define as anon func

Signed-off-by: satoshi-ota <[email protected]>

---------

Signed-off-by: satoshi-ota <[email protected]>
  • Loading branch information
satoshi-ota committed Apr 8, 2024
1 parent 4c53f8b commit 68b7d27
Showing 1 changed file with 35 additions and 31 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,40 @@ geometry_msgs::msg::Point calcLongitudinalOffsetGoalPoint(

return offset_point ? offset_point.value() : points.at(nearest_segment_idx + 1);
}

std::vector<lanelet::ConstPoint3d> extractBoundFromPolygon(
const lanelet::ConstPolygon3d & polygon, const size_t start_idx, const size_t end_idx,
const bool clockwise)
{
std::vector<lanelet::ConstPoint3d> ret{};
for (size_t i = start_idx; i != end_idx; i = clockwise ? i + 1 : i - 1) {
ret.push_back(polygon[i]);

if (i + 1 == polygon.size() && clockwise) {
if (end_idx == 0) {
ret.push_back(polygon[end_idx]);
return ret;
}
i = 0;
ret.push_back(polygon[i]);
continue;
}

if (i == 0 && !clockwise) {
if (end_idx == polygon.size() - 1) {
ret.push_back(polygon[end_idx]);
return ret;
}
i = polygon.size() - 1;
ret.push_back(polygon[i]);
continue;
}
}

ret.push_back(polygon[end_idx]);

return ret;
}
} // namespace

namespace behavior_path_planner::utils::drivable_area_processing
Expand Down Expand Up @@ -1242,36 +1276,6 @@ std::vector<lanelet::ConstPoint3d> getBoundWithIntersectionAreas(
const std::shared_ptr<RouteHandler> & route_handler,
const std::vector<DrivableLanes> & drivable_lanes, const bool is_left)
{
const auto extract_bound_from_polygon =
[](const auto & polygon, const auto start_idx, const auto end_idx, const auto clockwise) {
std::vector<lanelet::ConstPoint3d> ret{};
for (size_t i = start_idx; i != end_idx; i = clockwise ? i + 1 : i - 1) {
ret.push_back(polygon[i]);

if (i + 1 == polygon.size() && clockwise) {
if (end_idx == 0) {
ret.push_back(polygon[end_idx]);
return ret;
}
i = 0;
continue;
}

if (i == 0 && !clockwise) {
if (end_idx == polygon.size() - 1) {
ret.push_back(polygon[end_idx]);
return ret;
}
i = polygon.size() - 1;
continue;
}
}

ret.push_back(polygon[end_idx]);

return ret;
};

std::vector<lanelet::ConstPoint3d> expanded_bound = original_bound;

// expand drivable area by using intersection area.
Expand Down Expand Up @@ -1317,7 +1321,7 @@ std::vector<lanelet::ConstPoint3d> getBoundWithIntersectionAreas(
const size_t end_idx = std::distance(polygon.begin(), intersection_bound_itr_last);

intersection_bound =
extract_bound_from_polygon(polygon, start_idx, end_idx, is_clockwise_iteration);
extractBoundFromPolygon(polygon, start_idx, end_idx, is_clockwise_iteration);
}

// Step2. check shared bound point.
Expand Down

0 comments on commit 68b7d27

Please sign in to comment.