# Get started
- Install the requirements: <br>
  ```apt install -r requirements.txt```
- Generate data: <br>
  ```python scripts/generate_data.py```
- Run the experiments: <br>
  ```python scripts/runs.py``` <br>
  It will run all the experiments at once. If only some experiments have to be runned, add the wanted prefix of config files of the ```config``` folder (e.g. ```python scripts/runs.py flc```). All the models have to be runned on GPU for reproductibility.
- Generate the random encoder: <br>
  ```python scripts/generate_random_encoder```
- Generate all the results from the trained models
  ```sh scripts/results/generate.sh```<br>
  All the results will be printed in the terminal and the plots will be generated in the ```images``` folder

  
# Algorithms
### Purely unsupervised methods
- Classical Auto-Encoder
- [$\beta$-VAE](https://openreview.net/forum?id=Sy2fzU9gl)
- [DIP-VAE I/II](https://arxiv.org/abs/1711.00848)
- [Factor-VAE](https://arxiv.org/abs/1802.05983)

### Self-supervised methods
- Our method
- [Forward-VAE](https://arxiv.org/abs/1904.00243)
- [SOBDRL](https://arxiv.org/abs/2002.06991)
- LSBD-VAE* adapted from [LSBD-VAE](https://arxiv.org/abs/2011.06070)

### Supervised methods
- [LSBD-VAE](https://arxiv.org/abs/2011.06070)