Skip to content

Commit

Permalink
fix(mission_planner): align goal pose to lanelet map (tier4#1129)
Browse files Browse the repository at this point in the history
Signed-off-by: Xinyu Wang <xinyu.wang@tier4.jp>
  • Loading branch information
angry-crab authored and boyali committed Oct 3, 2022
1 parent 04001d8 commit bc0c979
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ class MissionPlannerLanelet2 : public MissionPlanner

void mapCallback(const autoware_auto_mapping_msgs::msg::HADMapBin::ConstSharedPtr msg);
bool isGoalValid() const;
void refineGoalHeight(const RouteSections & route_sections);

// virtual functions
bool isRoutingGraphReady() const;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,15 @@ bool isInParkingLot(
return false;
}

double projectGoalToMap(
const lanelet::Lanelet & lanelet_component, const lanelet::ConstPoint3d & goal_point)
{
const lanelet::ConstLineString3d center_line =
lanelet::utils::generateFineCenterline(lanelet_component);
lanelet::BasicPoint3d project = lanelet::geometry::project(center_line, goal_point.basicPoint());
return project.z();
}

} // anonymous namespace

namespace mission_planner
Expand Down Expand Up @@ -291,14 +300,27 @@ autoware_auto_planning_msgs::msg::HADMapRoute MissionPlannerLanelet2::planRoute(
get_logger(), "Loop detected within route! Be aware that looped route is not debugged!");
}

refineGoalHeight(route_sections);

route_msg.header.stamp = this->now();
route_msg.header.frame_id = map_frame_;
route_msg.segments = route_sections;
route_msg.goal_pose = goal_pose_.pose;

RCLCPP_DEBUG(get_logger(), "Goal Pose Z : %lf", goal_pose_.pose.position.z);
return route_msg;
}

void MissionPlannerLanelet2::refineGoalHeight(const RouteSections & route_sections)
{
const auto goal_lane_id = route_sections.back().preferred_primitive_id;
lanelet::Lanelet goal_lanelet = lanelet_map_ptr_->laneletLayer.get(goal_lane_id);
const auto goal_lanelet_pt = lanelet::utils::conversion::toLaneletPoint(goal_pose_.pose.position);
double goal_height = projectGoalToMap(goal_lanelet, goal_lanelet_pt);
goal_pose_.pose.position.z = goal_height;
checkpoints_.back().pose.position.z = goal_height;
}

} // namespace mission_planner

#include <rclcpp_components/register_node_macro.hpp>
Expand Down

0 comments on commit bc0c979

Please sign in to comment.