# Multi-View and Convolutional Neural CDEs (MVC-CDE)

This repository contains the official implementation of **Multi-View (MV-CDE)** and **Convolutional (MVC-CDE)** Neural Controlled Differential Equations. These architectures leverage Gaussian Process and Kernel smoothing to construct robust, continuous control paths, significantly improving computational efficiency and noise robustness compared to standard Neural CDEs and ODE-RNNs.

<p align="center">
  <img src="plots_paper_final/workflow2.pdf" alt="Model Architecture" width="800"/>
</p>

## Project Structure

```text
.
├── main/                       # Source code (models, training, loading)
├── data/                       # Dataset storage (CharacterTrajectories, etc.)
├── experiment_results_*/       # JSON logs of training runs
├── plots_paper_final/          # Generated paper figures
├── build                       # Script to build Docker image
├── launch                      # Script to launch Docker container
├── run.sh                      # Main entry point for experiments
├── Dockerfile                  # Environment definition
└── requirements.txt            # Python dependencies
```

## Quick Start

The project is designed to run inside a Docker container to ensure reproducibility.

### 1. Build and Launch
```bash
# Build the Docker image
./build

# Launch the container (mounts current directory)
./launch
```

### 2. Run Experiments
Inside the container, use the `run.sh` script to manage training, aggregation, and plotting.

**Usage:** `./run.sh {main|agg|plot} [GPU_ID] [CONFIG_PATH]`

#### Train Models
Run the training pipeline using a specific configuration file.
```bash
# Run on GPU 0 using the default config (./main/config.yaml)
./run.sh main 0

# Run on GPU 1 using a custom config
./run.sh main 1 ./main/configs/my_experiment.yaml
```

#### Aggregate Results
Collect results from JSON files into summary CSVs.
```bash
./run.sh agg
```

#### Generate Plots
Generate the figures found in `plots_paper_final/`.
```bash
./run.sh plot
```

##Configuration

Experiments are controlled via YAML files. Below is a reference configuration:

```yaml
# General Setup
seeds: [228, 42]
dataset_name: "CharacterTrajectories"  # SpokenArabicDigits, UWaveGestureLibrary
data_dir: "./data/"
results_dir: "experiment_results_add"
log_dir: "logs"

# Model Hyperparameters
num_epochs: 25
batch_size: 256
hidden_dim: 128
lr: 0.0001
tolerances: [0.001, 0.01]  # ODE Solver tolerances

# Noise Robustness Test
test_noise_robustness: true
test_noise_levels: [0.0, 0.01, 0.05, 0.1, 0.3, 0.5, 0.7]

# Experiment Selection (Active Models)
experiments_to_run:
  baseline: true   # Linear/Cubic NCDE
  gp: false        # Gaussian Process CDE
  qformer: false   # Multi-View CDE (MV-CDE)
  conv: false      # Convolutional CDE (MVC-CDE)
  odernn: false
  
# Model Specific Params
baseline_params:
  interpolations: ["cubic", "linear"] 

gp_params:
  length_scales: [1.0]
  noise_stds: [0.01]

qformer_params: # MV-CDE Settings
  kernels: ['gaussian', 'laplacian']
  bandwidth_lists_different:
    - [0.03, 0.1, 0.4] # Multi-head bandwidths
```

## Results & Visualization

The repository automatically generates analysis plots located in `plots_paper_final/`.

**Key results include:**
*   **Performance vs. Efficiency:** See `Figure_Best.pdf`.
*   **Noise Robustness:** See `noise_robustness.pdf` for analysis of NFE stability under jitter.
*   **Computational Cost:** See `Combined_Time_Analysis.pdf`.

<p align="center">
  <img src="plots_paper_final/noise_robustness.pdf" alt="Noise Robustness" width="800"/>
  <br>
  <em>Robustness of smoothing-based methods (GP) vs interpolation-based methods (Linear/Cubic) under noise injection.</em>
</p>