Skip to main content

A Toolbox for Computing Reachable Sets of Automated Vehicles

Project description

CommonRoad-Reach: A Toolbox for Reachability Analysis of Automated Vehicles

Reachability analysis has gained increasing popularity in motion planning and safeguarding of automated vehicles (AVs). While existing tools for reachability analysis mainly focus on general-purpose algorithms for formal verification of dynamical systems, a toolbox tailored to AV-specific applications is not yet available. The CommonRoad-Reach toolbox

  • integrates different methods for computing reachable sets using polytopic set propagation and graph-based propagation;
  • provides Python and C++ implementations of the algorithms, thus offering convenient prototyping and real-time computation for the users; and
  • extracts driving corridors which can be used as planning constraints for motion planners.

System Requirements

The software is written in Python 3.10 and C++17, and was tested on Ubuntu 18.04, 20.04 and 22.04. It should be compatible with later versions. For building the code, the following minimum versions are required:

  • GCC and G++: version 10 or above
  • CMake: version 3.20 or above.
  • Pip: version 21.3 or above

We further recommend using Anaconda to manage your virtual python environment.

Installation options

We provide two installation options for CommonRoad-Reach: Installation as a Python package or building from source.

  1. Python Package: Install the python package via pip in your Conda environment:

    pip install commonroad-reach
    
  2. Build from source: To build the project from source and install it in your Conda environment, please refer to the README_FOR_DEVS. This option is only recommended for advanced users and those who are looking to contribute to the development of CommonRoad-Reach.

Getting Started

Run the exemplary scripts to compute reachable sets and extract driving corridors.

  • To compute reachable sets, run compute_reachable_set.py.

  • To extract driving corridors, run extract_driving_corridors.py.

The outputs will be stored in the ./output/ folder. Default and scenario-specific configurations are stored in the ./configurations/ folder.

Documentation

The documentation of our toolbox is available on our website: https://cps.pages.gitlab.lrz.de/commonroad/commonroad-reachable-set/.

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/.

Citation

If you use our toolbox for your research, please cite our paper:

@InProceedings{iraniliu2022commonroad,
      title     = {{CommonRoad-Reach}: {A} toolbox for reachability analysis of automated vehicles},
      author    = {Irani Liu, Edmond and W\"ursching, Gerald and Klischat, Moritz and Althoff, Matthias},
      booktitle = {Proc. of the IEEE Int. Conf. Intell. Transp. Syst.},
      pages     = {2313--2320},
      year      = {2022},
   }

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

commonroad_reach-2025.2.1.tar.gz (10.4 MB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

commonroad_reach-2025.2.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.11manylinux: glibc 2.17+ x86-64

commonroad_reach-2025.2.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.10manylinux: glibc 2.17+ x86-64

File details

Details for the file commonroad_reach-2025.2.1.tar.gz.

File metadata

  • Download URL: commonroad_reach-2025.2.1.tar.gz
  • Upload date:
  • Size: 10.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.9

File hashes

Hashes for commonroad_reach-2025.2.1.tar.gz
Algorithm Hash digest
SHA256 15bf985b978ec00d5cac78e377d31173bf7d88037adaa1e0063b9c8aef3401c4
MD5 347f882583d60e041db4b4365fd78f63
BLAKE2b-256 fb1f22d408f4ef33e323dbc6d5e064857bcbef5d288978b64e08dbf864fe6d19

See more details on using hashes here.

File details

Details for the file commonroad_reach-2025.2.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for commonroad_reach-2025.2.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9fd731699bdd59a0ecd186b2510d672dd49c12ad1cc2eeba6d0d5efb90464ecc
MD5 a27fbc95530a90f56e6c18a418ec4af6
BLAKE2b-256 343f82c391acd65f4bb21c4df5513ae4ab8a09aab0832514b85ebbc5bef8a17f

See more details on using hashes here.

File details

Details for the file commonroad_reach-2025.2.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for commonroad_reach-2025.2.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 df3f8f36c0ed0325174033483f82f1ceb848710d5314917166bc591b79db1294
MD5 a7e9405e9c884fb78e654c4a899e6c71
BLAKE2b-256 be6f04ea0145e3fce7fa1a08855a65ade021ed80ff03d5f13c64fb145f7f4a30

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page