# Governing Equation Discovery from Data Based on Differential Invariants

This repository is the official implementation of Governing Equation Discovery from Data Based on Differential Invariants. The code implementation of our DI-SINDy algorithm is based on the [repository](https://github.com/Rose-STL-Lab/symmetry-ode-discovery), which provides an excellent reproduction of SINDy.

![introduction](introduction.png)

## Requirements

To install requirements:

```shell
pip install -r requirements.txt
```

The data generation script is from the [repository](https://github.com/kogyeonghoon/learning-symmetry-from-scratch). To generate datasets:

- KdV equation

```shell
python generate_data.py --experiment=KdV --train_samples=1024 --valid_samples=1024 --test_samples=4096 --L=128 --suffix default --batch_size 4096 --device cuda
```

- KS equation

```shell
python generate_data.py --experiment=KS --train_samples=1024 --valid_samples=1024 --test_samples=4096 --L=64 --nt=500 --suffix default --batch_size 4096 --device cuda
```

- Burgers equation

```shell
python generate_data.py --experiment=Burgers --train_samples=1024 --valid_samples=1024 --test_samples=4096 --end_time=18. --nt=180 --suffix default --batch_size 4096 --device cuda
```

- nKdV equation

```shell
python generate_data.py --experiment=nKdV --train_samples=1024 --valid_samples=1024 --test_samples=4096 --L=128 --suffix default --batch_size 4096 --device cuda
```

## Training

For equation discovery:

- KdV equation

```shell
# DI-SINDy (Ours)
bash run_scripts/kdv_disindy.sh
# EquivSINDy-r
bash run_scripts/kdv_esindy.sh
# SINDy
bash run_scripts/kdv_sindy.sh
```

- KS equation

```shell
# DI-SINDy (Ours)
bash run_scripts/ks_disindy.sh
# EquivSINDy-r
bash run_scripts/ks_esindy.sh
# SINDy
bash run_scripts/ks_sindy.sh
```

- Burgers equation

```shell
# DI-SINDy (Ours)
bash run_scripts/burgers_disindy.sh
# EquivSINDy-r
bash run_scripts/burgers_esindy.sh
# SINDy
bash run_scripts/burgers_sindy.sh
```

- nKdV equation

```shell
# DI-SINDy (Ours)
bash run_scripts/nkdv_disindy.sh
# EquivSINDy-r
bash run_scripts/nkdv_esindy.sh
# SINDy
bash run_scripts/nkdv_sindy.sh
```

## Evaluation

To evaluate the success rate and RMSE, run the script `notebooks/eval_results.ipynb`.

To visualize long-term prediction errors:

- KdV equation

```shell
python eval_ltp.py --pde KdV
```

- KS equation

```shell
python eval_ltp.py --pde KS
```

- Burgers equation

```shell
python eval_ltp.py --pde Burgers
```

- nKdV equation

```shell
python eval_ltp.py --pde nKdV
```