# NeuroMamba for Cognitive Task Simulation and Analysis

This repository provides a complete framework for evaluating the **NeuroMamba** model on a simulated **cognitive task**. It features a parallelized simulation engine for running experiments and a comprehensive Jupyter Notebook for in-depth post-hoc analysis of the results.

## Framework Overview

The workflow is divided into two distinct phases:

1.  **Phase 1: Simulation Execution**: A powerful script, `run_experiment.py`, automatically distributes multiple independent simulations across all available GPUs. It trains the model based on a central configuration file and saves the raw performance and neural dynamics data.
2.  **Phase 2: In-Depth Analysis**: A detailed Jupyter Notebook, `visualization.ipynb`, is used to load the results from the simulation phase. It allows for advanced statistical filtering, visualization of correlation matrices, and analysis of how the model's internal representations evolve over time.

## Files

-   `config.py`: The control center for the entire experiment. It contains dictionaries defining configurations for the **simulation** (`total_simulations`), **training loop** (`epochs`), **dataset** (`trial1x`), **NeuroMamba model** (`d_model`, `expand_gc`), and **output paths**.
-   `data_generator.py`: A modular script responsible for generating the trial sequences for each training epoch based on the templates in `config.py`.
-   `run_experiment.py`: The main **execution script**. It reads settings from `config.py`, manages multiprocessing across GPUs, trains the model, and saves key metrics (loss, accuracy, hidden state correlations) to `.npy` files.
-   `visualization.ipynb`: A Jupyter Notebook for **in-depth, post-hoc analysis** of the simulation results. It loads the `.npy` files to perform statistical filtering, generate advanced visualizations of neural dynamics (e.g., correlation heatmaps), and analyze learning progression through decorrelation analysis.

## Workflow

Follow these steps to run simulations and analyze the results.

### Step 1: Running the Simulations

1.  **Configure**: Open `config.py` and adjust the parameters for your experiment. Key settings include:
    -   `simulation_config['total_simulations']`: The total number of independent runs.
    -   `training_config['epochs']`: The duration of each training run.
    -   `model_config`: Parameters defining the NeuroMamba architecture.

2.  **Execute**: Run the main script from your terminal. It will automatically handle parallel execution.
    ```bash
    python run_experiment.py
    ```

### Step 2: Analyzing the Results

1.  **Locate Results**: After the simulations are complete, note the **timestamp** from the terminal output (e.g., `2025-09-10-10-16`) and the date-based directory where results were saved (e.g., `0910/`).

2.  **Open Notebook**: Launch and open `visualization.ipynb` in a Jupyter environment (like Jupyter Lab or VS Code).

3.  **Set Timestamp**: Inside the notebook, find the cell containing the `file_chosen` variable and update it with your experiment's timestamp.
    ```python
    # Update this to your actual filename
    file_chosen = '2025-09-10-10-16' 
    ```
    Also, ensure the directory path (e.g., `./0910/`) in the `np.load` commands matches your output directory.

4.  **Execute Analysis**: Run all cells in the notebook to generate detailed statistics and visualizations.

## Results

The framework produces outputs in two stages.

### Simulation Outputs (from `run_experiment.py`)

Raw data is saved into a date-named directory (e.g., `0910/`).

1.  **Data Files (`.npy`)**: Aggregated metrics from all simulations are saved in NumPy format with a clear, timestamped convention:
    -   `loss_all_neuromamba_{timestamp}.npy`
    -   `accuracy_curve_all_test_neuromamba_{timestamp}.npy`
    -   `corr_curve_neuromamba_{timestamp}.npy`

2.  **Summary Plot (`.pdf`)**: A basic plot showing the average loss and accuracy curves across all simulations is also saved:
    -   `neuromamba_training_curves_{timestamp}.pdf`

### Analysis Outputs (from `visualization.ipynb`)

The notebook produces a rich set of visualizations and statistical summaries, including:
-   Detailed statistics on convergence and final performance.
-   Average and individual **correlation matrix heatmaps** for well-performing runs.
-   **Decorrelation curves** showing how internal representations change over training epochs.
-   A **crossing points analysis** to statistically determine the order in which different neural representations become decorrelated.

You can monitor the simulation progress in your terminal:
```
Number of GPUs found: 4
[GPU 0] starting. Device: cuda:0. Seeds: [200 201 202 203]
...
----------------------------------------
total_params: 1.05 M
trainable_params: 1.05 M (Note: reflects 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 saved to '0910' with timestamp: 2025-09-10-10-16
Final Average Loss: 0.0115, Final Average Accuracy: 0.9985
Training visualization saved to 0910/neuromamba_training_curves_2025-09-10-10-16.pdf
```

## Dependencies

This framework relies on several key libraries:
-   `torch`
-   `numpy`
-   `matplotlib`
-   `seaborn`
-   `einops`
-   `jupyter` (to run the analysis notebook)
-   Custom CUDA kernels: `neuromamba` and `causal_conv1d`