This repository is the official implementation of LEADS: Learning Dynamical Systems that Generalize Across Environments.
We recommend Python 3.7 or greater for installation. You can install all the required by executing the following command
pip3 install --user -U -r requirements.txt
Use the following command to run the experiments for LV, GS and NS datasets,
python3 train_leads.py {lv,gs,ns}
The experiments are saved into ./exp
by default. You can specify your own experiment directory with --path /path/to/exp
.
The LEADS model is launched by default. If you need to run the experiments for main baselines, you can specify the experiment type with --decomp_type {leads, leads_no_min, one_for_all, one_per_env}
CPU is used by default, if you have CUDA compatible device, you can also specify with the option --device 'cuda:[cuda_device_id]'
Run python3 train_leads.py --help
to show the complete list of options.
Evaluation code is integrated into the training process as we need to see how the test performance evolve during training. All outputs are saved in a log file for each experiment.
All datasets can be created on-the-fly. Nonetheless, we provide a buffered version for NS to save your time. They are available in exp
directory. You can move them to your own directory specified with --path
to reuse these buffers.
Our model achieves the following performance on:
Dataset | Test MSE |
---|---|
LV - 10 envs - 1 trajectory/env | 1.16+-0.99 e-3 |
GS - 3 envs - 1 trajectory/env | 2.08+-2.88 e-3 |
NS - 4 envs - 8 trajectories/env | 5.95+-3.65 e-3 |