Skip to main content

The run-time-assurance library provides an interface and implementations for Run Time Assurance (RTA) safety filters.

Project description

Run Time Assurance

Intro

The run-time-assurance library provides an interface and implementations for Run Time Assurance (RTA) safety filters. RTA is a technique for guaranteeing the safety of a control system by performing online safety filtering of desired control actions to ensure the control system does not and will not violate defined safety constraints. This allows an unverified controller, such as a neural network, to be utilized in safety critical applications.

This package contains base classes for implementing RTA modules and defining RTA safety constraints. Also included are generic implementations of the RTA algorithms Explicit Simplex, Implicit Simplex, Explicit Acitive Set Invariance Filter (ASIF), and Implicit ASIF which simply require contraints and control system state transition models to become functional RTA modules for any custom application. Additionally, the RTA Zoo includes our growing library of custom RTA implementations for various safety critical control problems.

Docs

Library documentation and api reference located at https://rta.github.com/act3-ace/safe-autonomy-stack/run-time-assurance/

Installation

The following instructions detail how to install the run-time-assurance library on your local system. It is recommended to install the python modules within a virtualenv or conda environment. run-time-assurance utilizes Poetry to handle installation. Poetry can install run-time-assurance into an auto-generated virtualenv or within the currently active environment.

Installing run-time-assurance

Clone a copy of the run-time-assurance source code onto your local machine via SSH:

git clone git@github.com:act3-ace/run-time-assurance.git

or HTTPS:

git clone git@github.com:act3-ace/run-time-assurance.git

You can install the run-time-assurance module using either pip or poetry.

Installing run-time-assurance with pip

To install the run-time-assurance module into your environment using pip:

cd run-time-assurance
pip install .

For a local development version, please install using the -e, --editable option:

pip install -e .

Installing run-time-assurance with Poetry

To install the run-time-assurance module into your environment using poetry:

cd run-time-assurance
poetry install

Poetry will handle installing appropriate versions of the dependencies for run-time-assurance into your environment, if they aren't already installed. Poetry will install an editable version of run-time-assurance to the environment.

Build Docs Locally

First make sure the mkdocs requirements are installed

poetry install --with docs

Now, build the documentation and serve it locally. By default, you should be able to reach the docs on your local web browser at 127.0.0.1:8000

rm -r site
poetry run mkdocs build
cp -r docs/. site/
poetry run mkdocs serve

Tutorial

A Jupyter Notebook tutorial discussing how to build RTA modules is given at run-time-assurance/tutorials/Double_Integrator_Tutorial.ipynb.

Citation

The paper associated with this repository was presented at the 2023 American Control Conference, and can be cited with the following bibtex entry:

@inproceedings{ravaioli2023universal,
  title={A Universal Framework for Generalized Run Time Assurance with JAX Automatic Differentiation},
  author={Ravaioli, Umberto J and Dunlap, Kyle and Hobbs, Kerianne},
  booktitle={2023 American Control Conference (ACC)},
  pages={4264--4269},
  year={2023},
  organization={IEEE}
}

Public Release

Approved for public release; distribution is unlimited. Case Number: AFRL-2023-6154

A prior version of this repository was approved for public release. Case Number: AFRL-2022-3202

Team

Umberto Ravaioli, Kyle Dunlap, Jamie Cunningham, John McCarroll, Kerianne Hobbs, Charles Keating

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

run_time_assurance-1.18.6.tar.gz (84.7 kB view details)

Uploaded Source

Built Distribution

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

run_time_assurance-1.18.6-py3-none-any.whl (55.1 kB view details)

Uploaded Python 3

File details

Details for the file run_time_assurance-1.18.6.tar.gz.

File metadata

  • Download URL: run_time_assurance-1.18.6.tar.gz
  • Upload date:
  • Size: 84.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.13

File hashes

Hashes for run_time_assurance-1.18.6.tar.gz
Algorithm Hash digest
SHA256 94004e5b183e94bee4610d134068775e377ac37386bd8b9dfe38c1e5c3b77c82
MD5 678d1252521d381634e947f9eef800f7
BLAKE2b-256 a75b46a1001db8c50d637db69ce63f7190abe35066efb8c90d1b72d29dfb1f56

See more details on using hashes here.

File details

Details for the file run_time_assurance-1.18.6-py3-none-any.whl.

File metadata

File hashes

Hashes for run_time_assurance-1.18.6-py3-none-any.whl
Algorithm Hash digest
SHA256 86f912b1197fcccfecd472eba0bc8697b909cbd0316ec96403d3875d8409cb68
MD5 641964ee5def50ec325b3041bc1cdc48
BLAKE2b-256 d3f94343b27b790d6b1a4a8cc6db9fd43c024a4ac229f6a75f18c431feef5272

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