# Codebase for FiGuRO Paper

This repository contains the source code and experimental scripts for the paper.

## Directory Structure

### 1. `src/` - Core Implementation
This folder contains the reusable library code for the project:
*   **`src/models/`**: Contains the PyTorch implementations of the autoencoder models.
    *   `larrp_multimodal.py`: The main implementation of FiGuRO for multimodal data.
    *   `larrp_unimodal.py`: Implementation for unimodal benchmarks.
    *   Other files include architectures for specific datasets (e.g., Image-Text, Image-Depth, Omics).
*   **`src/functions/`**: Contains training loops and evaluation functions.
    *   `train_larrp_multimodal.py`: The primary training function for the proposed method, including the rank reduction logic.
    *   `loss.py`: Implementation of objective functions (reconstruction loss, orthogonality, etc.).
*   **`src/data/`**: Data loading and simulation utilities.
    *   `mm_parametric_simulation.py`: Code for generating the synthetic multimodal datasets used in the controlled experiments.
    *   `*_loader.py`: Data loaders for real-world benchmarks.

### 2. `02_paper_experiments/` - Experimental Scripts
This folder contains the scripts used to produce the results and figures in the paper. The experiments are organized by dataset and experiment type.

#### Execution Scripts (Experiment Summaries)
To reproduce the experimental pipeline, we provide high-level shell scripts that execute the individual python scripts in the correct order. These serve as a summary of the experimentation:

*   **`00_01_exec_prep.sh`**: Prepares data and directories.
*   **`00_02_exec_unimodal.sh`**: Runs unimodal baseline experiments (Intrinsic Dimensionality estimation on standard manifolds).
*   **`00_03_exec_multimodal.sh`**: The main script for multimodal simulation experiments (Figure 2 & 3 in the paper), including ablations and baselines.
*   **`00_04_exec_ninfea.sh`**: Experiments on the NInFEA dataset.
*   **`00_05_exec_audiomnist.sh`**: Experiments on audio datasets (AudioMNIST).
*   **`00_06_exec_multimodal.sh`**: Large-scale benchmarking on real-world datasets.

## How to Run
1.  Ensure all dependencies are installed.
2.  Navigate to the project root.
3.  Run the desired execution script (e.g., `./02_paper_experiments/00_03_exec_multimodal.sh`) to reproduce a set of experiments.

*Note: Some paths in the scripts are relative to the project root. Please ensure you are running python commands from the main directory.*
