Skip to content

Commit

Permalink
feat(mission_planner): judge reroute safe when ego is stopped (autowa…
Browse files Browse the repository at this point in the history
…refoundation#5787)

Signed-off-by: kosuke55 <[email protected]>
  • Loading branch information
kosuke55 authored and karishma1911 committed May 26, 2024
1 parent e95e367 commit a374604
Showing 1 changed file with 12 additions and 1 deletion.
13 changes: 12 additions & 1 deletion planning/mission_planner/src/mission_planner/mission_planner.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -734,6 +734,13 @@ bool MissionPlanner::check_reroute_safety(
return false;
}

const auto current_velocity = odometry_->twist.twist.linear.x;

// if vehicle is stopped, do not check safety
if (current_velocity < 0.01) {
return true;
}

auto hasSamePrimitives = [](
const std::vector<LaneletPrimitive> & original_primitives,
const std::vector<LaneletPrimitive> & target_primitives) {
Expand Down Expand Up @@ -878,13 +885,17 @@ bool MissionPlanner::check_reroute_safety(
}

// check safety
const auto current_velocity = odometry_->twist.twist.linear.x;
const double safety_length =
std::max(current_velocity * reroute_time_threshold_, minimum_reroute_length_);
if (accumulated_length > safety_length) {
return true;
}

RCLCPP_WARN(
get_logger(),
"Length of lane where original and B target (= %f) is less than safety length (= %f), so "
"reroute is not safe.",
accumulated_length, safety_length);
return false;
}
} // namespace mission_planner
Expand Down

0 comments on commit a374604

Please sign in to comment.