Package Summary
Tags | No category tags. |
Version | 1.0.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Checkout URI | https://github.com/autowarefoundation/autoware_core.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-04-04 |
Dev Status | UNMAINTAINED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Package Description
Additional Links
Maintainers
- Takayuki Murooka
- Yuki Takagi
- Maxime Clement
- Arjun Ram
- Berkay Karaman
Authors
autoware_motion_velocity_obstacle_stop_module
Overview
The obstacle_stop
module does the stop planning when there is a static obstacle near the trajectory.
Design
Obstacle Filtering
The obstacles meeting the following condition are determined as obstacles for stopping.
- The object type is for stopping according to
obstacle_filtering.object_type.*
. - The lateral distance from the object to the ego’s trajectory is smaller than
obstacle_filtering.max_lat_margin
. - The object velocity along the ego’s trajectory is smaller than
obstacle_filtering.obstacle_velocity_threshold_from_stop
. - The object
- does not cross the ego’s trajectory (*1)
- and its collision time margin is large enough (*2).
NOTE
*1: Crossing obstacles
Crossing obstacle is the object whose orientation’s yaw angle against the ego’s trajectory is smaller than obstacle_filtering.crossing_obstacle.obstacle_traj_angle_threshold
.
*2: Enough collision time margin
We predict the collision area and its time by the ego with a constant velocity motion and the obstacle with its predicted path.
Then, we calculate a collision time margin which is the difference of the time when the ego will be inside the collision area and the obstacle will be inside the collision area.
When this time margin is smaller than obstacle_filtering.crossing_obstacle.collision_time_margin
, the margin is not enough.
Stop Planning
The role of the stop planning is keeping a safe distance with static vehicle objects or dynamic/static non vehicle objects.
The stop planning just inserts the stop point in the trajectory to keep a distance with obstacles.
The safe distance is parameterized as stop_planning.stop_margin
.
When it stops at the end of the trajectory, and obstacle is on the same point, the safe distance becomes stop_planning.terminal_stop_margin
.
When inserting the stop point, the required acceleration for the ego to stop in front of the stop point is calculated.
If the acceleration is less than common.min_strong_accel
, the stop planning will be cancelled since this package does not assume a strong sudden brake for emergency.
Minor functions
Prioritization of behavior module’s stop point
When stopping for a pedestrian walking on the crosswalk, the behavior module inserts the zero velocity in the trajectory in front of the crosswalk.
Also autoware_obstacle_cruise_planner
’s stop planning also works, and the ego may not reach the behavior module’s stop point since the safe distance defined in autoware_obstacle_cruise_planner
may be longer than the behavior module’s safe distance.
To resolve this non-alignment of the stop point between the behavior module and this module, stop_planning.min_behavior_stop_margin
is defined.
In the case of the crosswalk described above, this module inserts the stop point with a distance stop_planning.min_behavior_stop_margin
at minimum between the ego and obstacle.
A function to keep the closest stop obstacle in target obstacles
In order to keep the closest stop obstacle in the target obstacles, we check whether it is disappeared or not from the target obstacles in the check_consistency
function.
If the previous closest stop obstacle is remove from the lists, we keep it in the lists for obstacle_filtering.stop_obstacle_hold_time_threshold
seconds.
Note that if a new stop obstacle appears and the previous closest obstacle removes from the lists, we do not add it to the target obstacles again.
Visualization
Detection area
Green polygons which is a detection area is visualized by detection_polygons
in the ~/debug/marker
topic.
Collision points
Red points which are collision points with obstacle are visualized by *_collision_points
for each behavior in the ~/debug/marker
topic.
Obstacle for stop
Red sphere which is an obstacle for stop is visualized by obstacles_to_stop
in the ~/debug/marker
topic.
Red wall which means a safe distance to stop if the ego’s front meets the wall is visualized in the ~/virtual_wall
topic.
Usage
This module is activated if the launch parameter launch_obstacle_stop_module
is set to true.
e.g. launcher/autoware_launch/autoware_launch/config/planning/preset/default_preset.yaml
# motion velocity planner modules
- arg:
name: launch_obstacle_stop_module
default: "true"
That will trigger autoware_universe/launch/tier4_planning_launch/launch/scenario_planning/lane_driving/motion_planning/motion_planning.launch.xml to assemble launch config for motion_velocity_planner.
Finally motion_velocity_planner will load obstacle_stop_module
as plugin.
<!-- assemble launch config for motion velocity planner -->
<arg name="motion_velocity_planner_launch_modules" default="["/>
<let
name="motion_velocity_planner_launch_modules"
value="$(eval "'$(var motion_velocity_planner_launch_modules)' + 'autoware::motion_velocity_planner::ObstacleStopModule, '")"
if="$(var launch_obstacle_stop_module)"
/>
Changelog for package autoware_motion_velocity_obstacle_stop_module
1.0.0 (2025-03-31)
- chore: update version in package.xml
- fix(motion_velocity_obstacle_stop_module): fix debug topic name (#341) fix(motion_velocity_obstacle_xxx_module): fix debug topic name
- fix(autoware_motion_velocity_obstacle_stop_module): fix plugin export (#333)
- feat(autoware_motion_velocity_obstacle_stop_module): port to core repo (#310)
- Contributors: Ryohsuke Mitsudome, Takayuki Murooka, 心刚
Wiki Tutorials
Package Dependencies
System Dependencies
Name |
---|
libboost-dev |
Dependant Packages
Name | Deps |
---|---|
autoware_core_planning |