# Koopman-informed RNNs



Installation
------------

To install the main package with the requirements please clone the repository, 
create a new virtual environment with `python == 3.10`, 
and execute the following command(s) from the root folder:


     pip install -r requirements.txt && pip install .


In order to adapt some parts of the `datafold` library please run the `apply_patches` script:

     python patch/apply_patches.py


## Getting started

Expected Python version is `python == 3.10`, 
install the provided requirements.
To install `swimnetworks`, follow manual installation instructions 
([https://gitlab.com/fd-research/swimnetworks](https://gitlab.com/fd-research/swimnetworks)).

Here is a simple example of a KIRNN setup:

```python
from sklearn.pipeline import Pipeline
from swimnetworks import Dense
from kirnn import KIRNN

steps = [
 ("hidden",
  Dense(layer_width=100,
        activation='tanh',
        parameter_sampler='tanh')),
]
network_dictionary = Pipeline(steps=steps)

kirnn_model = KIRNN(dictionary=network_dictionary,
                    n_features_in=2)
```
A model can be fit using`kirnn_model.fit(X_train)` and predictions can be made with `kirnn_model.predict(X_init, time_values=np.arange(0,10))`.

We recommend to store the data (e.g. `X_train`) as a `TSCDataFrame` object. 

In order to run the experiments with Van der Pol, Lorenz or Rössler systems, 
the datasets need to be generated. Please run the script `generate_datasets.py` in 
the `simulated_datasets` folder. 

The computational experiments are organized into folders based on the problem type.
The scripts named `kirnn_*.py` contain the other experiments 
with KIRNNs, while the scripts named `esn_*.py` contain the reservoir computer (echo state network)
models. The shPLRNN models can be trained using the code repository
 [https://github.com/DurstewitzLab/GTF-shPLRNN](https://github.com/DurstewitzLab/GTF-shPLRNN) 
and the hyperparameters provided in the appendix of the paper. 


***
