# Robustness in the Face of Partial Identifiability in Reward Learning

This repository contains the code and the data needed for running the
experiments of the paper.

## Repository Organization
 
The repo is organized in various files: 
- ```simulations.ipynb``` runs the illustrative simulation in the main paper.
- ```run1.py``` and ```run2.py``` permit to run the additional simulations in
  the appendix, while ```main.ipynb``` permits to analyze the results.
- ```env.py``` contains a class that models an MDP without reward.
- ```gen_instance.py``` permits to generate the various application and
  feedbacks considered.
- ```rob.py``` contains the code that implements the primal-dual subgradient
  method (PDSM) and Rob-ReL.
- ```utils.py``` contains various utility functions.
- ```plot.py``` contains various plotting functions.

The folders ```results/``` and ```results2/``` contain the results of additional
simulations.

## Requirements

To execute the code, just install Python (we used Python 3.11.9) and the
packages:
- matplotlib (3.10.1)
- numpy (2.0.0)
- scipy (1.14.0)