# NeuroMamba Ablation Study on a Cognitive Task (2ACDC)

This repository provides a complete and parallelized framework for conducting **ablation studies** on the **NeuroMamba** model. It is designed to evaluate the contribution of key architectural components on a simulated **2-Alternative Choice Discrimination & Correlation (2ACDC)** cognitive task, with a full workflow from simulation to in-depth analysis.

## Framework Overview

The workflow is divided into two distinct phases and is controlled via command-line arguments:

1.  **Phase 1: Simulation Execution**: The main script, `run_experiment_ablation.py`, takes a command-line argument to specify which model variant to run. It then automatically distributes multiple independent simulations of that variant across all available GPUs, saving the raw performance and neural dynamics data.
2.  **Phase 2: In-Depth Analysis**: A detailed Jupyter Notebook, `visualization.ipynb`, is used to load and analyze the results from a specific ablation run. This enables statistical filtering, visualization of correlation matrices, and analysis of how the model's internal representations evolve over training.

## Files

-   `config.py`: The control center for **base parameters**. It contains configurations for the simulation (`total_simulations`), training loop (`epochs`), dataset templates (`trial1x`), and model architecture (`d_model`, `expand`). **Note: Ablation settings are not controlled here.**
-   `data_generator.py`: A script responsible for generating the trial sequences for the 2ACDC task based on the templates in `config.py`.
-   `run_experiment_ablation.py`: The main **executable script**. It defines the ablatable `NeuroMamba` model internally and uses command-line arguments to select the ablation condition. It then orchestrates the entire parallel simulation workflow.
-   `visualization.ipynb`: A Jupyter Notebook for **in-depth, post-hoc analysis**. It loads the `.npy` files from a completed simulation run to perform advanced statistical analysis and generate visualizations.

## The Ablation Mechanism

This study targets two critical components of the NeuroMamba architecture, controlled via command-line flags:

-   **Memory Factor (`mf`)**: A pathway originating from the gated connection (`gc`) that provides a memory-like factor to the SSM state transition. Controlled by the `mf` flag.
-   **Secondary Output (`y2`)**: A secondary projection from the SSM state that is added to the primary output. Controlled by the `y2` flag.

## Workflow

Follow these steps to run an ablation experiment and analyze the results.

### Step 1: Configure Base Parameters

Open `config.py` to set the foundational parameters for the simulation, such as `total_simulations`, `epochs`, `learning_rate`, and the model's `d_model`.

### Step 2: Execute the Experiment via Command Line

Run the main script from your terminal, using the `--ablation` flag to specify which version of the model you want to test.

-   **Baseline (Full Model)**:
    ```bash
    python run_experiment_ablation.py --ablation none
    ```
-   **Ablate `mf` branch only**:
    ```bash
    python run_experiment_ablation.py --ablation mf
    ```
-   **Ablate `y2` branch only**:
    ```bash
    python run_experiment_ablation.py --ablation y2
    ```
-   **Ablate both `mf` and `y2`**:
    ```bash
    python run_experiment_ablation.py --ablation both
    ```

### Step 3: Analyze the Results

1.  **Locate Results**: After a simulation completes, note the output directory, which will be named according to the date and ablation setting (e.g., `0719_ablation-mf/`). Also, note the specific **timestamp** of the files inside (e.g., `2025-07-19-1500`).

2.  **Open Notebook**: Launch and open `visualization.ipynb`.

3.  **Update Paths**: Inside the notebook, update the file loading cells to point to your results. You need to change both the **directory** and the **timestamp**.
    ```python
    # Example for analyzing the 'mf' ablation run
    ablation_folder = '0719_ablation-mf'
    file_chosen = '2025-07-19-15-00-00' # Update with your timestamp

    corr_curve = np.load(f'./{ablation_folder}/corr_curve_neuromamba_{file_chosen}.npy')
    # ... and so on for the other files
    ```

4.  **Execute Analysis**: Run all cells in the notebook to generate detailed statistics and visualizations for that specific ablation condition.

## Results

Experimental results are saved into a dedicated directory for each ablation run. The directory name clearly indicates the conditions:

`{date}_ablation-{setting}` (e.g., `0719_ablation-mf`)

Inside this directory, you will find the standard outputs:

1.  **Raw Data Files (`.npy`)**: Aggregated metrics from all simulations, named with a timestamp:
    -   `loss_all_neuromamba_{timestamp}.npy`
    -   `accuracy_curve_all_test_neuromamba_{timestamp}.npy`
    -   `corr_curve_neuromamba_{timestamp}.npy`

2.  **Summary Plot (`.pdf`)**: A plot visualizing the average loss and accuracy:
    -   `neuromamba_training_curves_{timestamp}.pdf`

You can monitor the simulation progress in your terminal:
```
==================================================
--- STARTING EXPERIMENT RUN: ABLATION = MF ---
==================================================

Number of GPUs found: 4
[GPU 0] starting. Device: cuda:0. Seeds: [200 201 202 203]. Ablation: 'mf'
----------------------------------------
MODEL CONFIG FOR ABLATION: 'MF'
total_params: 1.05 M
trainable_params: 0.92 M (Note: reflects trainable status and tied weights)
Hidden State size for correlation (d_inner): 512
----------------------------------------
...
[GPU 0] Sim 1, Epoch 50, Loss: 0.8123, Acc: 0.5200
...
--- Training Complete ---
Results for 'MF' saved to '0719_ablation-mf'
Final Average Loss: 0.0215, Final Average Accuracy: 0.9850
Training visualization saved to 0719_ablation-mf/neuromamba_training_curves_2025-07-19-15-00-00.pdf
```