Skip to content

Latest commit

 

History

History
68 lines (53 loc) · 3.71 KB

README.md

File metadata and controls

68 lines (53 loc) · 3.71 KB

Verifiable Compositional Reinforcement Learning Systems

This code implements a novel framework for verifiable and compositional reinforcement learning systems.

Installation

Python requirements

The most simple installation procedure is to use Anaconda.

If you wish to manually install the necessary packages, Python 3.8 is required with the following packages:

Other requirements

  • Gurobi optimization software. This can be downloaded from https://www.gurobi.com/downloads/. Academic Gurobi licenses may be requested from https://www.gurobi.com/downloads/end-user-license-agreement-academic/.

  • Unity 2020.3.20f1 with Mlagents package v2.1.0.

    • Begin by installing the Unity Hub. Here is the download link.
    • Next use the Unity Hub to install the appropriate version of Unity (2020.3.20f1).
    • Finally, drag the entire unity_labyrinth folder structure (which contains the unity labyrinth environment files) into the project list on Unity Hub. Use the Unity Hub to open the newly created project in order to get started.

Running examples

Discrete Gridworld Labyrinth Experiments

To run the example presented in the paper, navigate to the src directory and run:

python run_minigrid_labyrinth.py

This will setup and run the entire labyrinth experiment, and it will automatically generate new folders in which to save the learned sub-systems and the testing results within src/data.

Continuous Labyrinth Experiments

To run the continuous Labyrinth experiments, some extra setup is required.

  • First, download the appropriate version of Unity as instructed above.
  • Next, grab the Unity labyrinth project folder from this repository, and drop it into the Unity HUB to create a new version of the labyrinth project in Unity.
  • Open this labyrinth project and in the Unity editor, open scenes\SampleScene.
  • In this repository, navigate to the \src directory. Run:

    python run_unity_labyrinth.py

  • You should see the line "Listening on port 5004. Start training by pressing the Play button in the Unity Editor."
  • Click on the play button at the top of the Unity editor to begin training.

Citation

To cite this project, please use:

@inproceedings{neary2022verifiable,
  title={Verifiable and compositional reinforcement learning systems},
  author={Neary, Cyrus and Verginis, Christos and Cubuktepe, Murat and Topcu, Ufuk},
  booktitle={Proceedings of the International Conference on Automated Planning and Scheduling},
  volume={32},
  pages={615--623},
  year={2022}
}