# Shared Recurrent Memory Transformer

## Installation

Create a conda environment from the export file:
```bash
conda env create -f srmt_env_export.yml
```

Move the pogema, pogema-toolbox, and sample-factory folders (which are the specifically modified for SRMT versions of the publicly available packages https://github.com/AIRI-Institute/pogema, https://github.com/AIRI-Institute/pogema-toolbox, and https://github.com/alex-petrenko/sample-factory) to the site-packages folder in your newly create srmt_env virtual environment.

## Training

To train **SRMT** from scratch, run:

```bash
python train.py
```

### Evaluation 
To evaluate the trained model on the test set of environments, use:
```bash
python eval.py
```

## Episode Visualization

To run a single episode with the trained **SRMT** agents and produce an animation:

```bash
python3 example.py
```

The animation will be stored in the folder containing the experiment checnkpoints.

To avoid performance issues, it is recommended to set the following environment variables restricting Numpy CPU threads to 1:

```bash
export OMP_NUM_THREADS="1" 
export MKL_NUM_THREADS="1" 
export OPENBLAS_NUM_THREADS="1"
```

