To run the code launch on the terminal the command (code runnable on UNIX systems only):

python3 trainer.py --experiment <experiment_name> --move_bg <move_background> --model <model_name>

Dependencies are in the file requirements.txt

<experiment_name> can be one of: "2d" "3d "rl"
<move_background> can be one of: 0 1 (useful only in the experiment 2d)
<model_name>      can be one of: "haptic" "transporter" "vae" "end-to-end"

For both the experiments "3d" and "rl", please download the folder 3d_experiments (https://drive.google.com/file/d/1p5qOXF6bAXEdYRM9Ovke1Nv5GktkhNdr/view?usp=sharing) and unzip it inside this folder.

At the end of the training the trained model will be saved in the folder saved_models and the results will be saved as an .npy file in the folder saved_results. Results corresponds to the testing curves of the plots in the paper for the various experiments

--experiment "2d" --move_bg 0: corresponds to the sprite experiment of section 5.2 in the paper without the moving background
--experiment "2d" --move_bg 1: corresponds again to the sprite experiment of section 5.2 but with the blue squares moving background
--experiment "3d": corresponds to the soccer experiment of section 5.3. Pre-collected dataset is available in the "3d_experiment folder"
--experiment "rl": corresponds to the control experiment of section 5.4. Pretrained models for the state estimation are available in the "3d_experiment" folder as well as the unity executable for the simulation.
To run this experiment Unity is required

All the above experiment can be run using a different model:
--model "haptic": corresponds to our proposed model described in the paper
--model "transporter": corresponds to the key-point extractor described in section 5.1 of the paper (first bullet point)
--model "vae": corresponds to the variational autoencoder described in section 5.1 of the paper (second bullet point)

--model "end-to-end": this model corresponds to a convolutional network trained with the RL loss only. This option can be chosen for the "rl" experiment only





