# state_only_rl

Instructions on how to get packages to work

- run `setup.sh` to install miniconda + mujocofiles + install necessary libraries for running code + unzip models (for ubuntu OS)

- run `conda env create -f environment.yml` to create conda environment

- run `conda activate diffenv` to use environment

- go through `notes.txt` to modify libraries to make compatible


- run `main.py` to train offline can change functions/variables in script to train online/offline, different envs and hyperparams.

Functions that can be run in `main.py`:

    For offline learning:

    - revalued(config_dict,agent_type='diff_state'): trains algo using Delta s as target 
    - revalued(config_dict,agent_type='cont_diff_state'): trains algo using s'-s as target
    - revalued(config_dict,agent_type='state'): trains algo using s as target
    - revalued(config_dict,agent_type='action'): trains algo using next actions


    - run_inverse_model(config_dict,model_type='arg') pre-trains inverse model for the different targets as described above
    - (No need to do this as pretrained IDM's available in directory)

    - bc_offline(config_dict, agent_type='arg') same arguments as before but trains bc agent offline



    For online learning:

    - combined(config_dict): uses pretrained critic and trains IDM and agent online

--- 

## Downloading datasets

Information for installing datasets with discrete actionspaces can be found [here](https://github.com/AlexBeesonWarwick/OfflineRLFactorisableActionSpaces)
Once installed, move datasets into iclr_state_only directory
