Skip to content

Commit

Permalink
feat(map_based_prediction): remove crossing fence path (#5356)
Browse files Browse the repository at this point in the history
* remove crossing fence path

Signed-off-by: kyoichi-sugahara <[email protected]>

---------

Signed-off-by: kyoichi-sugahara <[email protected]>
  • Loading branch information
kyoichi-sugahara authored Oct 19, 2023
1 parent c75d581 commit a57671d
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -165,6 +165,14 @@ class MapBasedPredictionNode : public rclcpp::Node
void mapCallback(const HADMapBin::ConstSharedPtr msg);
void objectsCallback(const TrackedObjects::ConstSharedPtr in_objects);

bool doesPathCrossAnyFence(const PredictedPath & predicted_path);
bool doesPathCrossFence(
const PredictedPath & predicted_path, const lanelet::ConstLineString3d & fence_line);
lanelet::BasicLineString2d convertToFenceLine(const lanelet::ConstLineString3d & fence);
bool isIntersecting(
const geometry_msgs::msg::Point & point1, const geometry_msgs::msg::Point & point2,
const lanelet::ConstPoint3d & point3, const lanelet::ConstPoint3d & point4);

PredictedObjectKinematics convertToPredictedKinematics(
const TrackedObjectKinematics & tracked_object);

Expand Down
49 changes: 49 additions & 0 deletions perception/map_based_prediction/src/map_based_prediction_node.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -976,6 +976,46 @@ void MapBasedPredictionNode::objectsCallback(const TrackedObjects::ConstSharedPt
pub_calculation_time_->publish(calculation_time_msg);
}

bool MapBasedPredictionNode::doesPathCrossAnyFence(const PredictedPath & predicted_path)
{
const lanelet::ConstLineStrings3d & all_fences =
lanelet::utils::query::getAllFences(lanelet_map_ptr_);
for (const auto & fence_line : all_fences) {
if (doesPathCrossFence(predicted_path, fence_line)) {
return true;
}
}
return false;
}

bool MapBasedPredictionNode::doesPathCrossFence(
const PredictedPath & predicted_path, const lanelet::ConstLineString3d & fence_line)
{
// check whether the predicted path cross with fence
for (size_t i = 0; i < predicted_path.path.size(); ++i) {
for (size_t j = 0; j < fence_line.size() - 1; ++j) {
if (isIntersecting(
predicted_path.path[i].position, predicted_path.path[i + 1].position, fence_line[j],
fence_line[j + 1])) {
return true;
}
}
}
return false;
}

bool MapBasedPredictionNode::isIntersecting(
const geometry_msgs::msg::Point & point1, const geometry_msgs::msg::Point & point2,
const lanelet::ConstPoint3d & point3, const lanelet::ConstPoint3d & point4)
{
const auto p1 = tier4_autoware_utils::createPoint(point1.x, point1.y, 0.0);
const auto p2 = tier4_autoware_utils::createPoint(point2.x, point2.y, 0.0);
const auto p3 = tier4_autoware_utils::createPoint(point3.x(), point3.y(), 0.0);
const auto p4 = tier4_autoware_utils::createPoint(point4.x(), point4.y(), 0.0);
const auto intersection = tier4_autoware_utils::intersect(p1, p2, p3, p4);
return intersection.has_value();
}

PredictedObject MapBasedPredictionNode::getPredictedObjectAsCrosswalkUser(
const TrackedObject & object)
{
Expand All @@ -995,6 +1035,7 @@ PredictedObject MapBasedPredictionNode::getPredictedObjectAsCrosswalkUser(
}
}

// If the object is in the crosswalk, generate path to the crosswalk edge
if (crossing_crosswalk) {
const auto edge_points = getCrosswalkEdgePoints(crossing_crosswalk.get());

Expand All @@ -1018,6 +1059,8 @@ PredictedObject MapBasedPredictionNode::getPredictedObjectAsCrosswalkUser(
predicted_object.kinematics.predicted_paths.push_back(predicted_path);
}

// If the object is not crossing the crosswalk, in the road lanelets, try to find the closest
// crosswalk and generate path to the crosswalk edge
} else if (withinRoadLanelet(object, lanelet_map_ptr_)) {
lanelet::ConstLanelet closest_crosswalk{};
const auto & obj_pose = object.kinematics.pose_with_covariance.pose;
Expand Down Expand Up @@ -1048,6 +1091,8 @@ PredictedObject MapBasedPredictionNode::getPredictedObjectAsCrosswalkUser(
}
}

// If the object is not crossing the crosswalk, not in the road lanelets, try to find the edge
// points for all crosswalks and generate path to the crosswalk edge
} else {
for (const auto & crosswalk : crosswalks_) {
const auto edge_points = getCrosswalkEdgePoints(crosswalk);
Expand Down Expand Up @@ -1080,6 +1125,10 @@ PredictedObject MapBasedPredictionNode::getPredictedObjectAsCrosswalkUser(
if (predicted_path.path.empty()) {
continue;
}
// If the predicted path to the crosswalk is crossing the fence, don't use it
if (doesPathCrossAnyFence(predicted_path)) {
continue;
}

predicted_object.kinematics.predicted_paths.push_back(predicted_path);
}
Expand Down

0 comments on commit a57671d

Please sign in to comment.