Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file
Package Dependencies
System Dependencies
Dependant Packages
Launch files
Messages
Services
Plugins
Recent questions tagged autoware_motion_velocity_boundary_departure_prevention_module at Robotics Stack Exchange
Package Summary
Tags | No category tags. |
Version | 0.47.0 |
License | Apache License 2.0 |
Build type | AMENT_CMAKE |
Use | RECOMMENDED |
Repository Summary
Description | |
Checkout URI | https://github.com/autowarefoundation/autoware_universe.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-10-23 |
Dev Status | UNKNOWN |
Released | UNRELEASED |
Tags | planner ros calibration self-driving-car autonomous-driving autonomous-vehicles ros2 3d-map autoware |
Contributing |
Help Wanted (-)
Good First Issues (-) Pull Requests to Review (-) |
Package Description
Additional Links
Maintainers
- Zulfaqar Azmi
- Alqudah Mohammad
- Kyoichi Sugahara
- Takumi Odashima
- Maxime Clement
Authors
Boundary Departure Prevention Module
!!! Warning
The Boundary Departure Prevention Module is experimental. It subscribes to the control module’s predicted path and steering report, creating a circular dependency. This violates Autoware’s design principle of forward-only data flow, where control depends on planning, not the other way round. As a result, this module is not officially supported and will remain unofficial for the foreseeable future.
Role
This module inserts slow down points and publishes error diagnostics when the ego vehicle is near or about to cross an uncrossable boundary, such as a road border.
It also accounts for several types of erroneous behavior that could cause the vehicle to unintentionally cross these boundaries. These behaviors are classified as abnormalities.
Abnormalities
Abnormalities refer to erroneous behaviors at the component level, often caused by noisy or unreliable outputs. In this module, these abnormalities are embedded into the predicted footprints derived from the control module’s predicted path, specifically, the MPC (Model Predictive Control) trajectory. Each point along the MPC path is converted into a footprint, and potential deviations due to abnormal conditions are evaluated.
The module addresses the following types of abnormalities:
1. Normal (No Abnormality)
In typical operation, the MPC trajectory may contain small deviations or noise, especially when the vehicle cannot track the planned path perfectly. These deviations are minor and not necessarily the result of a malfunction, but they are still accounted for to ensure safe boundary handling.
2. Localization Abnormality
Localization errors can cause the ego vehicle to misjudge its position relative to road boundaries such as curbs or road edges. This can happen due to:
- Sensor noise or drift, leading to inaccurate pose estimation.
- Map inaccuracies, where the HD map’s geometry does not precisely align with the real-world boundary.
- Dynamic uncertainty at higher speeds, where even small errors are magnified due to the vehicle covering more distance in less time, reducing the margin for correction.
These factors can result in the vehicle unintentionally approaching or crossing an uncrossable boundary, even when the planned path appears valid.
How Footprint Expansion Helps with Localization and Map Errors
- Provides a conservative buffer for localization errors: If the ego vehicle’s estimated position is off due to GPS drift or sensor noise, the expanded footprint increases the likelihood of detecting potential boundary conflicts. While this may lead to conservative (and possibly false) detections, it helps ensure safety by accounting for uncertainty in the vehicle’s true position.
- Compensates for map inaccuracies: Slight misalignments in Lanelet2 map geometries, such as curb or road edge misplacement, can make it difficult to rely on raw map boundaries. Expanding the footprint ensures that even with these inaccuracies, the module remains cautious and avoids unintentional boundary violations.
Without Abnormality Margins | With Localization Abnormality Margin |
---|---|
![]() |
![]() |
By expanding the footprint, the module introduces a safety margin that accounts for minor localization and mapping uncertainties, especially critical at higher speeds.he expanded footprint creates a small buffer or “safety margin,” allowing the vehicle to operate safely despite minor abnormality.
3. Steering Abnormality
Unexpected steering behavior can cause the vehicle to deviate from its planned trajectory. Instead of using a simple margin, this module simulates a future trajectory based on a bicycle model with modified steering commands to predict potential deviations. This can occur due to:
- Actuator faults: such as delayed or stuck steering commands.
- Software issues: like frozen control outputs or bugs in the steering optimization logic.
- Unexpected maneuvers: for example, emergency avoidance or unintended sharp turns.
In such cases, the actual motion of the vehicle diverges from the MPC trajectory, increasing the risk of departure.
How steering simulation helps with steering abnormality
The module simulates a new vehicle trajectory using a bicycle model, where the steering commands are intentionally modified to represent a worst-case scenario. This simulation includes:
- Actuator Delay: A delay is introduced to the steering commands to simulate actuator latency.
- Steering Magnification: The original steering commands from the trajectory are multiplied by a factor to simulate over- or under-steering.
- Steering Offset: A constant offset is added to the steering commands to simulate a drift.
- Rate Limiting: The rate of change of the steering angle is limited based on the vehicle’s velocity to ensure the simulation is physically realistic.
- Physical Limits: The final steering angle is clamped to the vehicle’s maximum physical steering angle.
This simulated trajectory is then used to create a set of predicted footprints, which are checked for boundary departures. This allows the system to proactively detect and mitigate risks from steering abnormalities.
Example steering abnormality trajectories |
---|
4. Longitudinal Tracking Abnormality
Sometimes, the actual motion of the vehicle along the longitudinal axis does not match the MPC-predicted trajectory. For instance:
The ego vehicle might be ahead or behind the predicted position due to mismatches in acceleration or braking behavior.
This discrepancy becomes more problematic when the vehicle is near an uncrossable boundary, as it reduces the reliability of future footprint predictions.
How Longitudinal Expansion Helps with Tracking Abnormality
- Accounts for ego being ahead of the predicted pose: During lane changes, avoidance maneuvers, or turns on curved roads, the ego vehicle may move faster than expected or take a slightly different path than predicted. By extending the footprint longitudinally (in the direction of motion), the module accounts for the ego vehicle possibly being ahead of the current MPC trajectory point.
- Uses speed-scaled margins: The longitudinal margin is scaled based on the current vehicle speed, with an added buffer. At higher speeds, a larger margin is used to reflect the increased risk and reduced reaction time.
- Captures mismatches during dynamic maneuvers: In situations where heading is changing quickly, like on curved roads or during lateral motion, the ego’s actual position may significantly deviate from the MPC path. The extended footprint covers this discrepancy and helps detect boundary risks even if the predicted path appears safe.
Without Abnormality Margins | With Longitudinal Tracking Abnormality Margin |
---|---|
![]() |
File truncated at 100 lines [see the full file](https://github.com/autowarefoundation/autoware_universe/tree/main/planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/README.md)
Changelog for package autoware_motion_velocity_boundary_departure_prevention_module
0.47.0 (2025-08-11)
-
feat(boundary_departure): slow down computation (#11085)
- feat(boundary_departure): slow down computation
- fixed some logic
- refactor function get_interp_to_point()
- Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/slow_down_interpolator.cpp
- fix pre-commit diff error
* use function ---------Co-authored-by: mohammad alqudah <<alqudah.mohammad@tier4.jp>> Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
feat(boundary_departure): configurable departure points and type based on time (#11073)
- feat(boundary_departure): configurable departure points and type based on time
* Update planning/motion_velocity_planner/autoware_motion_velocity_boundary_departure_prevention_module/src/utils.hpp Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
- move out is_departure_persist
- cutoff time based on decel
- refactoring
* refactoring ---------Co-authored-by: Maxime CLEMENT <<78338830+maxime-clem@users.noreply.github.com>>
-
fix(boundary_departure): merging multiple close by departure points (#11083)
- fix(boundary_departure): merging multiple closeby departure points
* removed nested loops and fix critical departure being merged together Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
- refactoring
* refactor merge function ---------Co-authored-by: mkquda <<168697710+mkquda@users.noreply.github.com>>
-
fix(boundary_departure): configurable diagnostic level (#11064)
- RT-10807 fix diagnostic level cant be configured properly.
- RT1-10807 fix parameter configuration
* fix MRM chatters when not in autonomous mode ---------
-
fix(boundary_departure): subscribe to route to determine goal changes (#11004)
- fix(boundary_departure): use route msg to check for goal changes
* changed goal ptr to route ptr ---------
-
refactor(boundary_departure): reduce autonomous mode logging level (#10986) refactor(boundary_departure): reduce logging level
-
chore(boundary_departure): add logging for monitoring (#10969)
-
fix(boundary_departure): disable when autoware disengaged (#10962) fix(boundary_departure): disable when ego is not in autonomous mode
-
fix(boundary_departure): exception and log handling (#10914) fix(boundary_departure): exception handling
-
refactor(boundary_departure): use polling subscriber (#10901)
-
Contributors: Zulfaqar Azmi
0.46.0 (2025-06-20)
-
Merge remote-tracking branch 'upstream/main' into tmp/TaikiYamada/bump_version_base
-
feat(motion_velocity_planner): boundary departure prevention module (#10817)
- feat(motion_velocity_planner): boundary departure prevention module
- add maintainers
- Add initial readme
File truncated at 100 lines see the full file