# Imposing Boundary Conditions on Neural Operators via Learned Function Extensions

## Datasets

Download the datasets from [this repository](https://doi.org/10.5281/zenodo.18377370) and put them in a data directory following the instructions in the data repository. Make sure to use the correct folder names as described in the instructions.

## Usage

Create and activate a fresh virtual environment:
```bash
python -m venv venv-olbc
source venv-olbc/bin/activate
```

Install the necessary packages:
```bash
pip install -r requirements.txt
```
> In order to use JAX with GPUs/TPUs, a proper option should be given in `requirements.txt`. Please check [JAX compatibility](https://jax.readthedocs.io/en/latest/installation.html) in order to find the relative option for your hardware. For NVIDIA GPUs, the `[cuda12]` option can be given.

Provided that a certain training dataset is downloaded and placed in `<dir>/<path>/train.nc`, where `<path>` is the folder name specified in the [data repository](https://doi.org/10.5281/zenodo.18377370) (e.g., `poisson-circle-bc1`), you can train a model on it with the following command:
```bash
python -m ol.train --datadir '<dir>' --datapath '<path>' --epochs 100 --n_train 512 --n_valid 64 --core_name 'XRIGNO'
```

Choose `--core_name 'XRIGNO'` to train with the extended RIGNO model, and `--core_name 'XGAOT'` to train with the extended GAOT model. For training with GAOT, you should also pass the latent grid resolution (e.g., `--rmesh_gridres 32`). Passing `--noextender` will switch off the extender and instead use the zero extensions. Passing `--use_extensions`, the model will use the harmonic extensions as domain inputs.

You can run the following command to see the full list of the command-line arguments of the training module and their default values:
```bash
python -m ol.train --help
```

When a training is launched, the checkpoints, results, and model configurations will be stored in a specific folder in `./ol/experiments/`. The path of this folder (`<exp>`) will be printed by the training module. You can check the exact values of the metrics, as well as optimization plots within this folder.

Once a training is done, the test script can be run with the following command:
```bash
python -m ol.test --datadir '<dir>' --datapath '<path>' --exp '<exp>'
```

You can run the following command to see the full list of the command-line arguments of the testing module and their default values:
```bash
python -m ol.test --help
```
