Skip to main content

Implementation of traffic rule monitor for ships

Project description

CommonOcean Rules

This repository contains a python traffic rule monitor for ships. The implemented rules and parameters are described in the paper "Temporal Logic Formalization of Marine Traffic Rules" by Hanna Krasowski and Matthias Althoff.

Getting Started

This introduction will give you an overview how to install, parametrize, and execute the Marine Traffic Rule Monitor. The scenarios to evaluate have to be represented in the CommonOcean format.

We recommend Ubuntu as operating system. For the monitor you need at least Python 3.8 and the following packages:

  • commonocean-io >= 2025.1
  • matplotlib >= 2.5.0
  • numpy >= 1.16.4
  • metric-temporal-logic >= 0.1.4
  • python-monitors >= 0.1.1
  • ruamel.yaml >= 0.16.10
  • bezier >= 2020.2.3
  • antlr4-python3-runtime >= 4.7.2
  • scipy

The usage of the Anaconda Python distribution is recommended.

If you want to use our functions and classes in your custom projects (e.g., in the CommonOcean Drivability Checker), you can install CommonOcean Rules as a module by doing

pip install commonocean-rules

If you want to create scenario videos, the ffmpeg packages has to be installed as well:

sudo snap install ffmpeg

Or, if you are a macOS user:

brew install ffmpeg

Running the Marine Traffic Rule Monitor

There exist two options to run the Marine Traffic Rule Monitor:

  • main.py : Traffic rule evaluation for a single scenario or all scenarios which are located within predefined directories.
  • solution_viz.py : Traffic rule evaluation for a single scenario while also generating a video for the scenario.

The main file can be started from the root directory of this project via commandline by executing:

python -m rules.main --max_num_scenarios #Scenarios --scenario_directories /directory_1/ ... /directory_2

This should be used for the sequential evaluation of scenarios. The scenario directories are relative to the root folder, remember to keep them inside the repo.

In the following the different parameters are explained:

  • max_num_scenarios: The maximum number scenarios which should be evaluated. The default number is 10.
  • scenario_directories: List of scenario directories (relative to the root directory).

You can list the different parameters by executing python main.py -h.

The temporal logic formulas of the rules and the rule specific parametrization can be found in the file traffic_rules_ship.yaml.
Simulation and vehicle parameters can be set in the file config_ship.yaml.

In adition, the solution_viz file can be started from the root directory of the project via commandline by executing

python -m rules.solution_viz --input_path /folder/of/input/scenario/ --scenario 'ScenarioFile.xml' --output_path /folder/for/output/video/

Pay attention that here the folders' paths need to be the absolute ones, as they represent the directories in which we get our scenario and then output the video. Also, don't forget the / (forward slash) in the end of the path name.

Changelog

Compared to version 1.0.0, the following features have been changed:

  • The module now uses the new version of CommonOcean IO (2023.1)
  • The package is no longer compatible with Python 3.7

Authors of code project

Hanna Krasowski, Sebastian Maierhofer, Bruno Maione

If you use our formalized traffic rules for research, please consider citing our paper:

@inproceedings{Krasowski2021a,
	author = {Krasowski, Hanna and Althoff, Matthias},
	title = {Temporal Logic Formalization of Marine Traffic Rules},
	booktitle = {Proc. of the IEEE Intelligent Vehicles Symposium},
	year = {2021},
}

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

commonocean_rules-1.0.3.tar.gz (39.5 kB view details)

Uploaded Source

Built Distribution

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

commonocean_rules-1.0.3-py3-none-any.whl (59.7 kB view details)

Uploaded Python 3

File details

Details for the file commonocean_rules-1.0.3.tar.gz.

File metadata

  • Download URL: commonocean_rules-1.0.3.tar.gz
  • Upload date:
  • Size: 39.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.23

File hashes

Hashes for commonocean_rules-1.0.3.tar.gz
Algorithm Hash digest
SHA256 3c0ba48b8443aba6f3e48a2497c222e1305e902e9b5258312b1b35bc1cb45f6f
MD5 8c1832092bebd0bb07130dd41c09982e
BLAKE2b-256 8898bad6090eaf1879efaea8b9522ee560de26bb54d6e4ef48ca18be53ed4998

See more details on using hashes here.

File details

Details for the file commonocean_rules-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for commonocean_rules-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b3bec886e5d65a30c10b2f3132e7766225d723fb678c591503a533b90edbbdc1
MD5 4016e6f608dafad03fc620b60b864ab6
BLAKE2b-256 e47990e6e9aab680139ba2b2d7beb3fa9186a1c673c5f0ccaee7513365f62474

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