# RESAM: Robust Time Series Forecasting against Point-Wise Perturbations

Code for `RESAM` in ICLR submission: "Robust Time Series Forecasting via Basis-Aligned Sampling in Decycled Residual Space".

This code repository provides the code of `RESAM` implemented in the [`TFB` benchmark](https://github.com/decisionintelligence/TFB), including the model, forecasting, and perturbation process.

We implement the model in `./ts_benchmark/baselines/time_series_library/models/RESAM.py`.



## Quickstart

> [!IMPORTANT]
> The code is fully tested under python 3.11, it is recommended that you set the Python version to 3.11.

1. Installation:

Given a python environment (**note**: this project is fully tested under **python 3.11**), install the dependencies with the following command:

```shell
pip install -r requirements.txt
```

2. Download datasets:

Follow the instruction of official [`TFB` benchmark](https://github.com/decisionintelligence/TFB) to download the datasets, and put in `./dataset`

3. Train and evaluate:

> [!IMPORTANT]
> Since RESAM utilizes a two-stage training protocol, we need to first perform the first stage (cycle learning) in two-stage training by running:

```shell
bash ./scripts/multivariate_forecast/ETTh1_script/CycleNet.sh
```

After we get the periodic cycle in the learnable periodicity extraction (LPE) module in RESAM. We can perform the second training stage (joint space learning) by running:

```shell
bash ./scripts/multivariate_forecast/ETTh1_script/RESAM.sh
```


We provide the experiment scripts for RESAM under the folder `./scripts/multivariate_forecast`. For example you can reproduce a experiment result as the following:

```shell
bash ./scripts/multivariate_forecast/ETTh1_script/RESAM.sh $gpu_id $mode $exp_name $perturb_name
```

- gpu_id: which gpu to use, e.g., 0
- mode: choose whether to forecast on clean data or perturbed data, or both. Before choose 'perturb', running script with 'forecast' first bacause the 'forecast' setting will train the model first. choices: ['forecast', 'perturb', 'both'].
- exp_name: your experiment name, e.g., 'cycle' 
- perturb_name: your perturbation experiment name, e.g., 'perturb_test'

Default configuration:

```shell
bash ./scripts/multivariate_forecast/ETTh1_script/RESAM.sh
```

The script equals to the following one:

```shell
bash ./scripts/multivariate_forecast/ETTh1_script/RESAM.sh 0 forecast cycle perturb_test
```

4. **If you want to run all experiments of all datasets, run the following script**:

```shell
bash ./scripts/run_exp.sh $gpu_id $mode $exp_name $perturb_name
```

Default configuration:

```shell
bash ./scripts/run_exp.sh
```

The script equals to the following one:

```shell
bash ./scripts/run_exp.sh 0 forecast both perturb_test
```



## Reference

- TFB: https://github.com/decisionintelligence/TFB

