Skip to content

Commit

Permalink
feat(goal_planner): add extra front margin for collision check consid…
Browse files Browse the repository at this point in the history
…ering stopping distance (autowarefoundation#4674)

* feat(goal_planner): add extra front margin for collision check considering stopping distance

Signed-off-by: kosuke55 <kosuke.tnp@gmail.com>

* move safety_check

Signed-off-by: kosuke55 <kosuke.tnp@gmail.com>

* rename args and params

Signed-off-by: kosuke55 <kosuke.tnp@gmail.com>

* margin 0.6 and add comments

Signed-off-by: kosuke55 <kosuke.tnp@gmail.com>

---------

Signed-off-by: kosuke55 <kosuke.tnp@gmail.com>
  • Loading branch information
kosuke55 authored and kminoda committed Aug 23, 2023
1 parent c0b6e10 commit b71c13d
Show file tree
Hide file tree
Showing 8 changed files with 65 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,8 @@
# object recognition
object_recognition:
use_object_recognition: true
object_recognition_collision_check_margin: 1.0
object_recognition_collision_check_margin: 0.6 # this should be larger than `surround_check_distance` of surround_obstacle_checker
object_recognition_collision_check_max_extra_stopping_margin: 1.0

# pull over
pull_over:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -150,10 +150,11 @@ Generate footprints from ego-vehicle path points and determine obstacle collisio

#### Parameters for object recognition based collision check

| Name | Unit | Type | Description | Default value |
| :---------------------------------------- | :--- | :----- | :--------------------------------------------------------- | :------------ |
| use_object_recognition | [-] | bool | flag whether to use object recognition for collision check | true |
| object_recognition_collision_check_margin | [m] | double | margin to calculate ego-vehicle cells from footprint. | 1.0 |
| Name | Unit | Type | Description | Default value |
| :----------------------------------------------------------- | :--- | :----- | :--------------------------------------------------------- | :------------ | ---------------------------------------------------------------------------------------------------------- |
| use_object_recognition | [-] | bool | flag whether to use object recognition for collision check | true |
| object_recognition_collision_check_margin | [m] | double | margin to calculate ego-vehicle cells from footprint. | 0.6 |
| object_recognition_collision_check_max_extra_stopping_margin | [m] | double | | 1.0 |  maximum value when adding longitudinal distance margin for collision check considering stopping distance |

## **Goal Search**

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,7 @@ struct GoalPlannerParameters
// object recognition
bool use_object_recognition;
double object_recognition_collision_check_margin;
double object_recognition_collision_check_max_extra_stopping_margin;

// pull over general params
double pull_over_velocity;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,15 @@ bool checkCollision(
const BehaviorPathPlannerParameters & common_parameters, const double front_object_deceleration,
const double rear_object_deceleration, CollisionCheckDebug & debug);

/**
* @brief Check collision between ego path footprints with extra longitudinal stopping margin and
* objects.
* @return Has collision or not
*/
bool checkCollisionWithExtraStoppingMargin(
const PathWithLaneId & ego_path, const PredictedObjects & dynamic_objects,
const double base_to_front, const double base_to_rear, const double width,
const double maximum_deceleration, const double margin, const double max_stopping_margin);
} // namespace behavior_path_planner::utils::path_safety_checker

#endif // BEHAVIOR_PATH_PLANNER__UTILS__PATH_SAFETY_CHECKER__SAFETY_CHECK_HPP_
Original file line number Diff line number Diff line change
Expand Up @@ -164,6 +164,16 @@ double getDistanceBetweenPredictedPathAndObject(
const PredictedObject & object, const PredictedPath & path, const double start_time,
const double end_time, const double resolution);

/**
* @brief Check collision between ego path footprints with extra longitudinal stopping margin and
* objects.
* @return Has collision or not
*/
bool checkCollisionWithExtraStoppingMargin(
const PathWithLaneId & ego_path, const PredictedObjects & dynamic_objects,
const double base_to_front, const double base_to_rear, const double width,
const double maximum_deceleration, const double margin, const double max_stopping_margin);

/**
* @brief Check collision between ego path footprints and objects.
* @return Has collision or not
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -553,7 +553,9 @@ void GoalPlannerModule::selectSafePullOverPath()
}

// check if path is valid and safe
if (!hasEnoughDistance(pull_over_path) || checkCollision(pull_over_path.getParkingPath())) {
if (
!hasEnoughDistance(pull_over_path) ||
checkCollision(utils::resamplePathWithSpline(pull_over_path.getParkingPath(), 0.5))) {
continue;
}

Expand Down Expand Up @@ -1178,9 +1180,14 @@ bool GoalPlannerModule::checkCollision(const PathWithLaneId & path) const
}

if (parameters_->use_object_recognition) {
if (utils::checkCollisionBetweenPathFootprintsAndObjects(
vehicle_footprint_, path, *(planner_data_->dynamic_object),
parameters_->object_recognition_collision_check_margin)) {
const auto common_parameters = planner_data_->parameters;
const double base_link2front = common_parameters.base_link2front;
const double base_link2rear = common_parameters.base_link2rear;
const double vehicle_width = common_parameters.vehicle_width;
if (utils::path_safety_checker::checkCollisionWithExtraStoppingMargin(
path, *(planner_data_->dynamic_object), base_link2front, base_link2rear, vehicle_width,
parameters_->maximum_deceleration, parameters_->object_recognition_collision_check_margin,
parameters_->object_recognition_collision_check_max_extra_stopping_margin)) {
return true;
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,9 @@ GoalPlannerModuleManager::GoalPlannerModuleManager(
p.use_object_recognition = node->declare_parameter<bool>(ns + "use_object_recognition");
p.object_recognition_collision_check_margin =
node->declare_parameter<double>(ns + "object_recognition_collision_check_margin");
p.object_recognition_collision_check_max_extra_stopping_margin =
node->declare_parameter<double>(
ns + "object_recognition_collision_check_max_extra_stopping_margin");
}

// pull over general params
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -303,4 +303,28 @@ bool checkCollision(

return true;
}

bool checkCollisionWithExtraStoppingMargin(
const PathWithLaneId & ego_path, const PredictedObjects & dynamic_objects,
const double base_to_front, const double base_to_rear, const double width,
const double maximum_deceleration, const double collision_check_margin,
const double max_extra_stopping_margin)
{
for (const auto & p : ego_path.points) {
const double extra_stopping_margin = std::min(
std::pow(p.point.longitudinal_velocity_mps, 2) * 0.5 / maximum_deceleration,
max_extra_stopping_margin);

const auto ego_polygon = tier4_autoware_utils::toFootprint(
p.point.pose, base_to_front + extra_stopping_margin, base_to_rear, width);

for (const auto & object : dynamic_objects.objects) {
const auto obj_polygon = tier4_autoware_utils::toPolygon2d(object);
const double distance = boost::geometry::distance(obj_polygon, ego_polygon);
if (distance < collision_check_margin) return true;
}
}

return false;
}
} // namespace behavior_path_planner::utils::path_safety_checker

0 comments on commit b71c13d

Please sign in to comment.