This repository contains the Frenetix-Occlusion module along with a test configuration setup. The primary objective of this module is to identify occluded road users, predict potential movements, and perform a trajectory safety assessment using a variety of criticality metrics. It is designed to enhance situational awareness and safety in complex driving environments by accurately assessing and mitigating risks associated with occluded areas.
In the provided scenario (using the predefined configuration), the vehicle initiates a deceleration before approaching the turn as a precautionary measure against potential hidden obstacles, such as a truck obscuring the view (proactive braking strategy). Upon sighting the cyclist, the vehicle further reduces its speed.
It's important to note that when the harm limitation is not applied (harm: 1
), the vehicle enters the intersection without decelerating. Consequently, upon detecting the cyclist, the vehicle's speed is excessive, preventing it from braking in time to avoid a collision.
Please be aware that adjustments to the settings were necessary due to behavioral changes in the newer version of Frenetix. To replicate the results documented in our paper, refer to the Resimulation section of this README.
Regardless of the version of Frenetix used, it is consistently observed that the vehicle engages in braking before the actual obstacle comes into view.
The software is developed and tested on recent versions of Linux. We strongly recommend to use Ubuntu 22.04 or higher. For the python installation, we suggest the usage of Virtual Environment with Python 3.10 or Python 3.9 For the development IDE we suggest PyCharm.
To execute this example, we recommend using the Frenetix Motion Planning Algorithm. An appropriate configuration is already included in this package.
-
Make sure that the following dependencies are installed on your system for the C++ implementation of Frenetix:
- Eigen3
- On Ubuntu:
sudo apt-get install libeigen3-dev
- On Ubuntu:
- Boost
- On Ubuntu:
sudo apt-get install libboost-all-dev
- On Ubuntu:
- OpenMP
- On Ubuntu:
sudo apt-get install libomp-dev
- On Ubuntu:
- python3.10-full
- On Ubuntu:
sudo apt-get install python3.10-full
andsudo apt-get install python3.10-dev
- On Ubuntu:
- Eigen3
-
Clone this repository & create a new virtual environment
python3.10 -m venv venv
-
Install the package:
- Source & Install the package via pip:
source venv/bin/activate
&pip install .
or with poetrypoetry install
- Everything should install automatically. If not please write [email protected].
- Source & Install the package via pip:
-
Optional: Download additional Scenarios here
To execute the main with an example Frenet Planning algorithm from here, do the following steps:
-
Install Frenetix-Motion-Planner with
pip install frenetix-motion-planner==2024.1.1
-
OPTIONAL: Configure the Occlusion Module parameters or Planner settings in the
configurations
folder.- Parameters of Frenetix-Occlusion can be set in
simulation/occlusion.yaml
- activate/deactivate the Module (
use_occlusion_module: True
) - activate/deactivate metrics (
activated_metrics
) - set metric thresholds for trajectory assessment (
metric_thresholds
) - configure the internal sensor model (
sensor_model
)
- activate/deactivate the Module (
- further parameters, e.g. costs can be adapted in the other
*.yaml
files
- Parameters of Frenetix-Occlusion can be set in
-
Select a scenario (default is an intersection where a left turn is performed)
-
Execute
python3 main.py
or use your IDE GUI -
Other scenarios can be added and must be selected in main.py line 64
- Please note: if you change the scenario, make sure to adapt or deactivate the real agents in the settings (
occlusion.yaml
)
- Please note: if you change the scenario, make sure to adapt or deactivate the real agents in the settings (
OPTIONAL:
To incorporate custom obstacles into the scenario, this can be achieved by modifying the simulation/occlusion.yaml
file under the agents
section.
To add a custom obstacle, you must specify its position, type, velocity, timestep, and horizon.
E.g.:
agents:
position: [16, 2.8]
velocity: 8
agent_type: "Truck"
timestep: 0
horizon: 5.0
Additional scenarios can be found here.
In the process of resimulating the results presented in the publication, it's important to note that the original results were obtained using a slightly different software version. As such, variations in the outcomes, especially concerning cost weights, are possible.
To accurately replicate the paper's findings, it is necessary to install Frenetix version 0.1.2. This involves first uninstalling the current package using the command:
pip uninstall frenetix
Subsequently, install Frenetix version 0.1.2 by running:
pip install frenetix==0.1.2
Additionally, a parameter within the Frenetix motion planner, which sets the collision probability costs, needs to be adjusted:
Change line 151
of the file reactive_planner_cpp.py to:
self.handler.add_cost_function( cf.CalculateCollisionProbabilityFast(name, self.cost_weights[name], self.predictionsForCpp, self.vehicle_params.length*2, self.vehicle_params.width*1.5))
By adjusting these settings along with the cost weights provided in our paper, it is possible to resimulate the results demonstrated in the publication.
Cost weights used in the paper:
cost_weights:
acceleration: 0.0
jerk: 0.00
lateral_jerk: 1.0
longitudinal_jerk: 1.0
orientation_offset: 0.0
path_length: 0.0
lane_center_offset: 0.0
velocity_offset: 0.1
velocity: 0.
distance_to_reference_path: 3.0
distance_to_obstacles: 0.1
prediction: 200
responsibility: 0
- Scenario 2 is currently non-functional owing to issues with the CommonRoad Route Planner, which is unable to generate a valid reference path for the right turn. This issue is anticipated to be resolved with the release of the upcoming version of the route planner.
- BE metric is only working with frenetix 0.1.2 (will be fixed)
Please report all other issues to [email protected].
Korbinian Moller, Professorship Autonomous Vehicle Systems, School of Engineering and Design, Technical University of Munich, 85748 Garching, Germany
Rainer Trauth, Institute of Automotive Technology, School of Engineering and Design, Technical University of Munich, 85748 Garching, Germany
Johannes Betz, Professorship Autonomous Vehicle Systems, School of Engineering and Design, Technical University of Munich, 85748 Garching, Germany
If you use this repository for any academic work, please cite our code:
@misc{moller2024overcoming,
title={Overcoming Blind Spots: Occlusion Considerations for Improved Autonomous Driving Safety},
author={Korbinian Moller and Rainer Trauth and Johannes Betz},
year={2024},
eprint={2402.01507},
archivePrefix={arXiv},
primaryClass={cs.RO}
}