Skip to content

Commit

Permalink
fix(start_planner): refine shift pull out path to start pose (autowar…
Browse files Browse the repository at this point in the history
…efoundation#5874)

* fix(start_planner): refine shift pull out path to start pose

Signed-off-by: kosuke55 <[email protected]>

* fix typo

Signed-off-by: kosuke55 <[email protected]>

---------

Signed-off-by: kosuke55 <[email protected]>
Signed-off-by: karishma <[email protected]>
  • Loading branch information
kosuke55 authored and karishma1911 committed May 28, 2024
1 parent 81b02f2 commit e8dedb2
Show file tree
Hide file tree
Showing 2 changed files with 58 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@ class ShiftPullOut : public PullOutPlannerBase
double calcBeforeShiftedArcLength(
const PathWithLaneId & path, const double target_after_arc_length, const double dr);

bool refineShiftedPathToStartPose(
ShiftedPath & shifted_path, const Pose & start_pose, const Pose & end_pose,
const double longitudinal_acc, const double lateral_acc);

std::shared_ptr<LaneDepartureChecker> lane_departure_checker_;

private:
Expand Down
54 changes: 54 additions & 0 deletions planning/behavior_path_start_planner_module/src/shift_pull_out.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,58 @@ std::optional<PullOutPath> ShiftPullOut::plan(const Pose & start_pose, const Pos
return std::nullopt;
}

bool ShiftPullOut::refineShiftedPathToStartPose(
ShiftedPath & shifted_path, const Pose & start_pose, const Pose & end_pose,
const double longitudinal_acc, const double lateral_acc)
{
constexpr double TOLERANCE = 0.01;
constexpr size_t MAX_ITERATION = 100;

// Lambda to check if change is above tolerance
auto is_within_tolerance =
[](const auto & prev_val, const auto & current_val, const auto & tolerance) {
return std::abs(current_val - prev_val) < tolerance;
};

size_t iteration = 0;
while (iteration < MAX_ITERATION) {
const double lateral_offset =
motion_utils::calcLateralOffset(shifted_path.path.points, start_pose.position);

PathShifter path_shifter;
path_shifter.setPath(shifted_path.path);
ShiftLine shift_line{};
shift_line.start = start_pose;
shift_line.end = end_pose;
shift_line.end_shift_length = lateral_offset;
path_shifter.addShiftLine(shift_line);
path_shifter.setVelocity(0.0);
path_shifter.setLongitudinalAcceleration(longitudinal_acc);
path_shifter.setLateralAccelerationLimit(lateral_acc);

if (!path_shifter.generate(&shifted_path, false)) {
RCLCPP_WARN(
rclcpp::get_logger("ShiftPullOut:refineShiftedPathToStartPose()"),
"Failed to generate shifted path");
return false;
}

if (is_within_tolerance(
lateral_offset,
motion_utils::calcLateralOffset(shifted_path.path.points, start_pose.position),
TOLERANCE)) {
return true;
}

iteration++;
}

RCLCPP_WARN(
rclcpp::get_logger("ShiftPullOut:refineShiftedPathToStartPose()"),
"Failed to converge lateral offset until max iteration");
return false;
}

std::vector<PullOutPath> ShiftPullOut::calcPullOutPaths(
const RouteHandler & route_handler, const lanelet::ConstLanelets & road_lanes,
const Pose & start_pose, const Pose & goal_pose)
Expand Down Expand Up @@ -303,6 +355,8 @@ std::vector<PullOutPath> ShiftPullOut::calcPullOutPaths(
if (!path_shifter.generate(&shifted_path, offset_back)) {
continue;
}
refineShiftedPathToStartPose(
shifted_path, start_pose, *shift_end_pose_ptr, longitudinal_acc, lateral_acc);

// set velocity
const size_t pull_out_end_idx =
Expand Down

0 comments on commit e8dedb2

Please sign in to comment.