# Interpretability and Generalization Bounds for Learning Spatial Physics

This code replicates the experiments in the main text.

The key files to replicate the experiments are:
1. [train_tiny_models.py](spatial_interp/train_tiny_models.py) Train Linear, Deep Linear, and MLP models using tinygrad. A command flag selects which one to train.
2. [train_fd_sindy.py](spatial_interp/train_fd_sindy.py) Train a finite difference model using the PySINDy library.
3. [train_deeponet.py](spatial_interp/train_deeponet.py) Train a DeepONet using the DeepXDE library using a pytorch backend.
4. [train_neuralop.py](spatial_interp/train_neuralop.py) Train a Fourier Neural Operator using the neuralop library using a pytorch backend.

Each of scripts dumps the data to a pickle file, which is naive, but chosen for simple reproducibility.

The fastest way to generate a replication is:
```shell
PYTHONPATH=.:/path/to/tinygrad/repo python3.11 train_tiny_models.py --model_type=linear --n_seeds=1
```
This entire takes about 1 minute. It creates a local file called `tiny_linear_poisson_runs_{datetime}.pkl`.
This pickle can then be loaded in the provided notebook to plot the heatmap of generalization results.

Libraries:
1. Tinygrad: https://github.com/tinygrad/tinygrad
2. pySINDy: https://github.com/dynamicslab/pysindy
3. DeepXDE: https://github.com/lululxvi/deepxde
4. Neuralop: https://github.com/neuraloperator/neuraloperator
