From 22eef53fdeff0550d9f1e76236fe852f7a2a485e Mon Sep 17 00:00:00 2001 From: kosuke55 Date: Mon, 15 Aug 2022 16:57:48 +0900 Subject: [PATCH] docs(behavior_path_planner): update pull out docs Signed-off-by: kosuke55 --- planning/behavior_path_planner/README.md | 98 ++++++++++++++++--- .../image/geometric_pull_out.drawio.svg | 4 + .../image/pull_out_after_back.drawio.svg | 4 + .../image/pull_out_collision_check.drawio.svg | 4 + .../image/pull_out_fig1.drawio.svg | 1 - .../image/shift_pull_out.drawio.svg | 4 + 6 files changed, 100 insertions(+), 15 deletions(-) create mode 100644 planning/behavior_path_planner/image/geometric_pull_out.drawio.svg create mode 100644 planning/behavior_path_planner/image/pull_out_after_back.drawio.svg create mode 100644 planning/behavior_path_planner/image/pull_out_collision_check.drawio.svg delete mode 100644 planning/behavior_path_planner/image/pull_out_fig1.drawio.svg create mode 100644 planning/behavior_path_planner/image/shift_pull_out.drawio.svg diff --git a/planning/behavior_path_planner/README.md b/planning/behavior_path_planner/README.md index d3690ca880b0c..a1e4c31c49ce7 100644 --- a/planning/behavior_path_planner/README.md +++ b/planning/behavior_path_planner/README.md @@ -355,39 +355,109 @@ The Pull Out module is activated when ego-vehicle is stationary and footprint of - Pull out request condition - The speed of the vehicle is 0. - - The footprint of ego-vehicle is included in shoulder lane - - The distance from ego-vehicle to the destination is long enough for pull out (same with pull over) - - The distance required for a pull out is determined by the sum of the straight distance before pull out, the straight distance after pull out, and the minimum distance required for pull out + - Somewhere in footprint of ego-vehicle is included in shoulder lane + - The distance from ego-vehicle to the destination is long enough for pull out - Pull out ready condition - - The end of generated path is located before the end of the road - - Distance required for pull out of generated path is shorter than distance from ego-pose to goal-pose - - Generated Path is safe (This condition is temporarily invalid) - - It is possible to enable or disable this condition. (default: `disabled`) + - It is always ready if the conditions of the request are met. + +- Pull out start condition + - Generate safe path which does not collide with obstacles - If safe path cannot be generated from the current position, safe path from a receding position is searched. - Pull out is allowed by an operator #### **finish pull out condition** (need to meet any of the conditions below) -- The distance to the goal of your vehicle is lower than threshold (default: < `1m`) -- The speed of the vehicle is 0. +- Exceeding the pull out end point by more than the threshold (default: `1.0m`) + +#### General parameters for pull_out + +| Name | Unit | Type | Description | Default value | +| :--------------------------- | :---- | :----- | :------------------------------------------------------------- | :------------ | +| th_arrived_distance_m | [m] | double | distance threshold for arrival of path termination | 1.0 | +| th_stopped_velocity_mps | [m/s] | double | velocity threshold for arrival of path termination | 0.01 | +| th_stopped_time_sec | [s] | double | time threshold for arrival of path termination | 1.0 | +| collision_check_margin | [m] | double | Obstacle collision check margin | 1.0 | +| pull_out_finish_judge_buffer | [m] | double | threshold for finish judgment distance from pull out end point | 1.0 | #### **Safe check with obstacles in shoulder lane** -1. Calculate ego-vehicle's footprint on pull out path between from current position to merge end point. (Illustrated by blue frame) +1. Calculate ego-vehicle's footprint on pull out path between from current position to pull out end point. (Illustrated by blue frame) 2. Calculate object's polygon which is located in shoulder lane -3. If a distance between the footprint and the polygon is lower than the threshold (default: `1.5 m`), that is judged as a unsafe path +3. If a distance between the footprint and the polygon is lower than the threshold (default: `1.0 m`), that is judged as a unsafe path -![pull_out](./image/pull_out_fig1.drawio.svg) +![pull_out_collision_check](./image/pull_out_collision_check.drawio.svg) #### **Path Generation** -The path is generated with a certain margin from the left edge of the shoulder lane. +There are two path generation methods. + +##### **shift pull out** + +Pull out distance is calculated by the speed, lateral deviation, and the lateral jerk. The lateral jerk is searched for among the predetermined minimum and maximum values, and the one that generates a safe path is selected. + +- Generate the shoulder lane centerline and shift it to the current position. +- In the section between merge start and end, path is shifted by a method that is used to generate avoidance path (four segmental constant jerk polynomials) +- Combine this path with center line of road lane + +![shift_pull_out](./image/shift_pull_out.drawio.svg) + +[Video of how shift pull out works](https://user-images.githubusercontent.com/39142679/187872468-6d5057ee-e039-499b-afc7-fe0dc8052a6b.mp4) + +###### parameters for shift pull out + +| Name | Unit | Type | Description | Default value | +| :-------------------------------- | :----- | :----- | :------------------------------------------------------------------------------------------------------------------- | :------------ | +| enable_shift_pull_out | - | bool | flag whether to enable shift pull out | true | +| shift_pull_out_velocity | [m/s] | double | velocity of shift pull out | 2.0 | +| pull_out_sampling_num | - | int | Number of samplings in the minimum to maximum range of lateral_jerk | 4 | +| before_pull_out_straight_distance | [m] | double | distance before pull out start point | 0.0 | +| maximum_lateral_jerk | [m/s3] | double | maximum lateral jerk | 2.0 | +| minimum_lateral_jerk | [m/s3] | double | minimum lateral jerk | 0.5 | +| minimum_shift_pull_out_distance | [m] | double | minimum shift pull out distance. if calculated pull out distance is shorter than this, use this for path generation. | 20.0 | + +##### **geometric pull out** + +Generate two arc paths with discontinuous curvature. Ego-vehicle stops once in the middle of the path to control the steer on the spot. +See also [[1]](https://www.sciencedirect.com/science/article/pii/S1474667015347431) for details of the algorithm. + +![geometric_pull_out](./image/geometric_pull_out.drawio.svg) + +[Video of how geometric pull out works](https://user-images.githubusercontent.com/39142679/181024707-3e7ca5ee-62de-4334-b9e9-ded313de1ea1.mp4) + +###### parameters for geometric pull out + +| Name | Unit | Type | Description | Default value | +| :-------------------------- | :---- | :----- | :------------------------------------------------------ | :------------ | +| enable_geometric_pull_out | - | bool | flag whether to enable geometric pull out | true | +| geometric_pull_out_velocity | [m/s] | double | velocity of geometric pull out | 1.0 | +| arc_path_interval | [m] | double | path points interval of arc paths of geometric pull out | 1.0 | +| lane_departure_margin | [m] | double | margin of deviation to lane right | 0.2 | +| pull_out_max_steer_angle | [rad] | double | maximum steer angle for path generation | 0.26 | + +#### **backward pull out start point search** + +If a safe path cannot be generated from the current position, search backwards for a pull out start point at regular intervals(default: `2.0`). + +![pull_out_after_back](./image/pull_out_after_back.drawio.svg) + +[Video of how pull out after backward driving works](https://user-images.githubusercontent.com/39142679/181025149-8fb9fb51-9b8f-45c4-af75-27572f4fba78.mp4) + +| Name | Unit | Type | Description | Default value | +| :------------------------------------------------------------------------- | :------------- | :----- | :-------------------------------------------------------------------------------------------------------------------- | :------------ | +| enable_back | - | bool | flag whether to search backward for start_point | true | +| enable_back | - | bool | In the case of `efficient_path`, use efficient paths even if the back distance is longer. | +| In case of `short_back_distance`, use a path with as short a back distance | efficient_path | +| max_back_distance | [m] | double | maximum back distance | 15.0 | +| backward_search_resolution | [m] | double | distance interval for searching backward pull out start point | 2.0 | +| backward_path_update_duration | [s] | double | time interval for searching backward pull out start point. this prevents chattering between back driving and pull_out | 3.0 | #### Unimplemented parts / limitations for pull put -- Note that the current module's start judgment condition may incorrectly judge that the vehicle is parked on the shoulder, such as when stopping in front of an intersection. +- pull out from the right shoulder lane to the left lane is not allowed. +- The safety of the road lane is not judged + - Collision prediction is not performed for vehicles approaching from behind the road lane. ### Side Shift diff --git a/planning/behavior_path_planner/image/geometric_pull_out.drawio.svg b/planning/behavior_path_planner/image/geometric_pull_out.drawio.svg new file mode 100644 index 0000000000000..802b6138d5f13 --- /dev/null +++ b/planning/behavior_path_planner/image/geometric_pull_out.drawio.svg @@ -0,0 +1,4 @@ + + + +
pull out end point
pull out end point
pull out start point
pull out start poi...
stop
stop
Text is not SVG - cannot display
\ No newline at end of file diff --git a/planning/behavior_path_planner/image/pull_out_after_back.drawio.svg b/planning/behavior_path_planner/image/pull_out_after_back.drawio.svg new file mode 100644 index 0000000000000..f89ddde14db47 --- /dev/null +++ b/planning/behavior_path_planner/image/pull_out_after_back.drawio.svg @@ -0,0 +1,4 @@ + + + +
pull out end point
pull out end point
pull out start point
pull out start point
stop
stop
stop
stop
backward_search_resolution
backward_search_resolution
Text is not SVG - cannot display
\ No newline at end of file diff --git a/planning/behavior_path_planner/image/pull_out_collision_check.drawio.svg b/planning/behavior_path_planner/image/pull_out_collision_check.drawio.svg new file mode 100644 index 0000000000000..53afb6db58db4 --- /dev/null +++ b/planning/behavior_path_planner/image/pull_out_collision_check.drawio.svg @@ -0,0 +1,4 @@ + + + +
pull out end point
pull out end point
pull out start point
pull out start poi...
collision check
collision check
Text is not SVG - cannot display
\ No newline at end of file diff --git a/planning/behavior_path_planner/image/pull_out_fig1.drawio.svg b/planning/behavior_path_planner/image/pull_out_fig1.drawio.svg deleted file mode 100644 index f629ce734c10e..0000000000000 --- a/planning/behavior_path_planner/image/pull_out_fig1.drawio.svg +++ /dev/null @@ -1 +0,0 @@ -
merge end point
merge end point
merge start point
merge start point
colision check
colision check
Viewer does not support full SVG 1.1
\ No newline at end of file diff --git a/planning/behavior_path_planner/image/shift_pull_out.drawio.svg b/planning/behavior_path_planner/image/shift_pull_out.drawio.svg new file mode 100644 index 0000000000000..887294bbe5d23 --- /dev/null +++ b/planning/behavior_path_planner/image/shift_pull_out.drawio.svg @@ -0,0 +1,4 @@ + + + +
pull out end point
pull out end point
pull out start point
pull out start poi...
before_pull_out_distance
before_pul...
pull_out_distance
pull_out_d...
Text is not SVG - cannot display
\ No newline at end of file