
# STFlow: Data-Coupled Flow Matching for Geometric Trajectory Simulation


![Architecture schematic](figures/STFlow.svg)


Welcome to the readme, here we note down show the experiments can be reproduced.

## Requirements

We have used Python 3.12 and 3.13 (https://www.python.org/downloads/release/python-3122/) and have not checked other verisons.

```setup
python -m venv venv
source venv/bin/activate
```

```setup
pip install torch==2.8.0 torchvision --index-url https://download.pytorch.org/whl/cu128
pip install torch_geometric 
pip install pyg_lib torch_scatter torch_sparse torch_cluster torch_spline_conv -f https://data.pyg.org/whl/torch-2.8.0+cu128.html
```

```setup
pip install -r requirements.txt
```

Apologies if we missed any requirements in the requirements.txt

## Datasets and Pretrained models

Download link for all trained weights: https://mega.nz/folder/UxpDGSwT#p-ejK1h7Afwq2yHlIV4B8A
Put them in the final_weights and correspondig folder and unzip each.
Make sure the paths are data/raw/nbody/... and not data/raw/nbody/nbody/....

NBody and NBA data is included in the link above as well, put those unzipped under data/raw

Link for MD17 data (Numpy buttons under the yellow box) https://www.sgdml.org/#datasets

After downloading, put the MD17 .npz files in the `data/raw/md17`folder, rename benzene2017 to benzene.

Make sure that the `data` and `final_weights` folder are in the same directory as this README file.
The `data` folder should contain the subdirectories `raw` and `processed` and inside `raw` the subdirectories `nbody`, `nba` and `md17`, which are included in the first and second  download links.


## Config
All the configuration settings are stored within the trained weights files.
These values overwrite the configuration values in the config.py file, except for the weights_path key. Set this path to the correspondig pretrained model you want to run.





## Logging with Weights and Biases
The code uses Weights and Biases for logging and visualization. When running it for the first time, you will need to login to the platform by running:
```
python
import wandb
wandb.login()
```
If you do not want to use W&B, set the DEBUGGING flag to True in the `main.py` file.

## Training
After the data files, final_weights and weights_path in config.py has been set, we can train by setting the TRAIN flag in main.py to True.

```
python main.py
```
This will train STFlow on the specified dataset, evaluate it on the test set and log the results to the terminal and W&B if the DEBUGGING flag is set to False. 

## Evaluation

To only evaluate the model:
1. Check if datasets are in the `data` folder, as described above.

2. Check if the weights are in the `final_weights` folder, as described above.

3. Check if the `weights_path` parameter in the config file is set correspondig to the dataset and weights to use, as described above.

4. Set the `DEBUGGING` flag to True if you do not want to use Weight&Biases logging.

5. Set the `TRAIN` flag to False in `main.py`, at the top of the file.

6. Run:

```
python main.py
```

The results are printed to the terminal (and logged to W&B).


## Results

Please also note that the model is probabilistic, such that results can vary slightly from run to run.

