# Model-free Neural Stochastic Differential Equations (NSDEs)

This repository contains the code for experiments with Model-free Neural Stochastic Differential Equations, where network stochasticity (primarily via dropout) is used for tasks like image generation, OOD detection, and time-series modeling.

## Setup

### Prerequisites
* Python 3.10
* PyTorch
* NumPy
* Matplotlib (for visualizations)
* Tqdm (for progress bars)
* Geomloss (if using Sinkhorn/Wasserstein loss in specific experiments)
* Pandas (for some data handling, e.g., time series)

You can typically install these using pip:
`pip install torch torchvision numpy matplotlib tqdm geomloss pandas`

### Installation
1.  Clone the repository:
    ```bash
    git clone https://your-repository-url/model-free-nsde.git
    cd model-free-nsde
    ```
    (Replace `https://your-repository-url/model-free-nsde.git` with your actual repository URL)

2.  Consider using a Python virtual environment.

### Dataset Preparation
**Important:** For experiments on real-world datasets (e.g., MNIST, PhysioNet, Speech Commands, Air Quality), you must download the respective datasets and place them in the correct file paths.

* **The specific paths are usually defined within each `train.py` script or its associated data loader.** Please check the relevant script for the task you are interested in.
* For example:
    * MNIST is often downloaded automatically by `torchvision` but check if a specific path like `data/mnist_data/` is expected by a script.
    * PhysioNet 2012 might be expected in a folder like `data/PhysioNet2012/`.
    * The Air Quality dataset might be expected in `data/PRSA_Data_20130301-20170228/`.

**Please ensure datasets are located where the scripts expect them to avoid errors.**

## Training

All models can be trained by running a `python train.py` command. Depending on how the project is structured, there might be:
* A single `train.py` script that takes arguments to specify the task (e.g., `--task image_generation`).
* Multiple `train.py` scripts, each located in a subdirectory corresponding to a specific task (e.g., `image_generation/train.py`, `ood_detection/train.py`).

To run a training script:
```bash
python path/to/your/train.py [ARGUMENTS...]