# Regression experiment

## Data

The data can  be generated by running the following command:
```
python generate_data.py;
```
all the necessary logic to sample from each dataset is in `data.py`.


## Model evaluation and training

To *evaluate* the NDP regression models, run the following commands (in parallel if you have multiple GPUs) for each dataset and input dimension.


The models can be *trained* by running the following commands (in parallel if you have multiple GPUs) for each dataset and input dimension.
```
python main.py  --config.dataset=se --config.input_dim=1;
python main.py  --config.dataset=se --config.input_dim=2;
python main.py  --config.dataset=se --config.input_dim=3;
python main.py  --config.dataset=matern --config.input_dim=1;
python main.py  --config.dataset=matern --config.input_dim=2;
python main.py  --config.dataset=matern --config.input_dim=3;
```
The complete list of hyperparameters can be found in `config.py`.


## Other files

- `data.py`: contains the logic to sample the data.
- `eval_gp.py`: contains the logic to evaluate the GP baseline models, and `evaluate_gp.sh` is a bash script to loop over all the datasets and input dimensions.
- `create_commands.py`: Utility script to create the bash commands to run the experiments.