criticality measures of automated vehicles
Project description
CommonRoad-CriMe
Toolbox to compute Criticality Measures (e.g. time-to-collision, time-to-react,...). Such measures can be used to trigger warnings and emergency maneuvers in driver assistance systems or repair an infeasible trajectory.
Installation Guide
commonroad-crime
can be installed with:
$ pip install commonroad-crime
For adding new measures, we recommend using Anaconda to manage your environment so that even if you mess something up, you can always have a safe and clean restart. A guide for managing python environments with Anaconda can be found here.
After installing Anaconda, create a new environment with:
$ conda create -n commonroad-py38 python=3.8 -y
Here the name of the environment is called commonroad-py38. You may also change this name as you wish. In such case, don't forget to change it in the following commands as well. Always activate this environment before you do anything related:
$ conda activate commonroad-py38
or
$ source activate commonroad-py38
Then, install the dependencies with:
$ cd <path-to-this-repo>
$ pip install -e .
$ conda develop .
To test the installition, run unittest:
$ cd tests
$ python -m unittest -v
To get started your journey with our criticality measures, check the tutorials
and the following tips.
How to add new criticality measure
- create a new branch with
feature-<measure-name>
and checkout the branch - navigate to
commonroad_crime/data_structure/type.py
to find the correct category of the measure and add an enumeration entry<abbreviation>: <explanation>
- navigate to
commonroad_crime/measure
to find the above-mentioned category and create a python file named<abbreviation>.py
. Then create a class inheriting theCriMeBase
undercommonroad_crime/data_structure/base.py
- similar to other measures, you need to implement the
compute()
andvisualize()
functions
How to define configuration parameters of the measure
- navigate to
commonroad_crime/data_structure/configuation.py
to find the above-mentioned category and add a new instance to the class asself.<parameter> = config_relevant.<parameter>
- you can then directly call the values using
self.configuration.<category>.<parameter>
in your measure class - to override the default parameter values, create a
yaml
file (name it the same as the scenario) in./config_files
and modify the values there
Documentation
The documentation of our toolbox is available on our website: https://cps.pages.gitlab.lrz.de/commonroad-criticality-measures/.
In order to generate the documentation via Sphinx locally, run the following commands in the root directory:
$ pip install -r ./docs/requirements_doc.txt
$ cd docs/sphinx
$ make html
The documentation can then be launched by browsing ./docs/sphinx/build/html/index.html/
.
Contributors (in alphabetical order by last name)
- Liguo Chen
- Yuanfei Lin
- Sebastian Maierhofer
- Ivana Peneva
- Kun Qian
- Oliver Specht
- Sicheng Wang
- Zekun Xing
- Ziqian Xu
Citation
If you use commonroad-crime
for academic work, we highly encourage you to cite our paper:
@InProceedings{lin2023crime,
title = {{CommonRoad-CriMe}: {A} Toolbox for Criticality Measures of Autonomous Vehicles},
author = {Yuanfei Lin and Matthias Althoff},
booktitle = {Proc. of the IEEE Intell. Veh. Symp.},
pages = {1-8},
year = {2023},
}
If you use this project's code in industry, we'd love to hear from you as well; feel free to reach out to Yuanfei Lin directly.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file commonroad-crime-0.3.1.tar.gz
.
File metadata
- Download URL: commonroad-crime-0.3.1.tar.gz
- Upload date:
- Size: 71.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9346f8183ff6cade7114861c2380b6ec2b4a7e9d6be15c9dfcd7b5804a44979c |
|
MD5 | f5b882574c3c75e627e267f1bcf78684 |
|
BLAKE2b-256 | 8ca30e5fc1f7e9c3389546dd3ad663870f40088d9b20d586d9d06590e6a6901f |
File details
Details for the file commonroad_crime-0.3.1-py3-none-any.whl
.
File metadata
- Download URL: commonroad_crime-0.3.1-py3-none-any.whl
- Upload date:
- Size: 111.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5bfb0e386db7dac51a7cd776f9c8425b1ba979d54940683023787206994af0c0 |
|
MD5 | aa466fd43d16420a32f4b0365818b81d |
|
BLAKE2b-256 | 5e4fd363ed36e5a75d1fb42bb7d1ce176f5ea5aef8c9274d8753a67564bfd7af |