# Supplementary Code for ICML 2026 Submission

## Emergent Visual Representations through Unsupervised Spiking Networks with Synaptic Pruning

This repository contains the source code for our paper on how brain-aligned visual representations emerge in deep spiking neural networks through unsupervised sensory-driven learning and activity-dependent synaptic pruning.

## Abstract

We propose a biologically grounded deep spiking neural network (SNN) that integrates unsupervised learning with developmental pruning dynamics. Starting from an overcomplete spiking architecture, the model self-organizes through sensory-driven activity while selectively eliminating weak or redundant synapses, progressively yielding compact and informative representations. Without using labels, the resulting network forms hierarchical visual representations that strongly align with neural responses across multiple areas of the mouse and macaque visual cortex.

## Project Structure

```
code/
├── networks/
│   ├── resnet_ann.py         # ANN ResNet architectures
│   ├── resnet_snn.py         # SNN ResNet with LIF neurons
│   └── spike_functions.py    # LIF neuron, tdLayer, surrogate gradients
├── data_aug/
│   ├── contrastive_learning_dataset.py  # SimCLR-style dataset
│   ├── view_generator.py                # Multi-view generation
│   └── gaussian_blur.py                 # Augmentation
├── scripts/
│   └── run_*.sh              # Training scripts
│
│ # Training
├── main_simclr.py            # Unsupervised contrastive learning (UL SNN)
├── main_supce.py             # Supervised cross-entropy (SL SNN)
├── main_evaluator.py         # Linear evaluation protocol
│
│ # Synaptic Pruning
├── main_prune.py             # Activity-dependent synaptic pruning (Pr. UL SNN)
│
│ # Neural Similarity Analysis
├── main_similarity.py        # Brain score evaluation
├── benchmark.py              # BrainScore-style evaluation framework
├── dataset.py                # Neural datasets (Allen, Macaque)
├── metric.py                 # SVCCA, TSVDR, RSA metrics
│
│ # Functional Evaluation
├── main_fewshot.py           # Few-shot transfer learning
├── main_noisy.py             # Noisy transfer (robustness)
│
├── losses.py                 # SimCLR loss functions
├── util.py                   # Utilities
└── requirements.txt          # Dependencies
```

## Requirements

```bash
pip install -r requirements.txt
```

- Python >= 3.8
- PyTorch >= 1.12
- torchvision >= 0.13
- numpy, scikit-learn, matplotlib, tensorboard

## Model Variants

| Model | Description |
|-------|-------------|
| **SL ANN** | Supervised ResNet (standard CNN) |
| **UL ANN** | Unsupervised ResNet with SimCLR |
| **SL SNN** | Supervised Spiking ResNet |
| **UL SNN** | Unsupervised Spiking ResNet with SimCLR (our method) |
| **Pr. UL SNN** | Pruned UL SNN with synaptic pruning (our method) |

## Training

### 1. Unsupervised Spiking Contrastive Learning (UL SNN)

```bash
# Train UL SNN on CIFAR-10
python main_simclr.py --spiking --arch resnet18 --timesteps 4 \
    --dataset-name cifar10 --batch-size 512 --epochs 200

# Train UL SNN on Tiny-ImageNet
python main_simclr.py --spiking --arch resnet18 --timesteps 4 \
    --dataset-name tinyimagenet --batch-size 128 --epochs 200
```

### 2. Synaptic Pruning (Pr. UL SNN)

After training UL SNN, apply activity-dependent pruning:

```bash
python main_prune.py --spiking --model resnet18 \
    --model-path ./save/SimCLR/SNN_cifar10_resnet18_T4_bsz512_lr0.0003/checkpoint_0200.pth.tar \
    --prune-rate 0.3
```

The pruning uses L1 magnitude-based selection which, as shown in Proposition 1, maximizes cosine similarity between original and pruned weight vectors, preserving representational geometry.

### 3. Supervised Baselines

```bash
# SL ANN
python main_supce.py --arch resnet18 --dataset-name cifar10

# SL SNN
python main_supce.py --spiking --arch resnet18 --timesteps 4 --dataset-name cifar10
```

## Evaluation

### Neural Similarity Analysis (Brain Scores)

Evaluate alignment with neural recordings using SVCCA, TSVDR, and RSA:

```bash
python main_similarity.py --spiking --arch resnet18 --timesteps 4 \
    --checkpoint-path <path_to_checkpoint> --mode single --UnSup
```

**Neural Datasets:**
- **Allen Brain Mouse**: Mouse V1 responses (6 visual areas: VISp, VISl, VISrl, VISal, VISpm, VISam)
- **Macaque Face**: Macaque IT (AM face patch) responses
- **Macaque Synthetic**: Macaque V4/IT responses to synthetic stimuli

### Linear Evaluation

```bash
python main_evaluator.py --spiking --arch resnet18 --timesteps 4 \
    --ckpt-path <path_to_checkpoint>
```

### Functional Evaluation

**Few-shot Transfer** (Table 7 in paper):
```bash
python main_fewshot.py --spiking --arch resnet18 --ckpt-path <path> --fewshot-ratio 0.2
```

**Noisy Transfer** (Table 7 in paper):
```bash
# Gaussian noise
python main_noisy.py --spiking --arch resnet18 --ckpt-path <path> \
    --noise-ratio 0.2 --noise-type gaussian

# Salt-and-pepper noise
python main_noisy.py --spiking --arch resnet18 --ckpt-path <path> \
    --noise-ratio 0.2 --noise-type salt_pepper
```

## Key Methods

### LIF Neuron Model (Section 3.1)

The membrane potential evolves as:
```
u(t) = λ·u(t-1) + Σ_j ω_ij·o_j(t) - v_th·o(t-1)
```
where λ is the leakage factor, ω are synaptic weights, and v_th is the firing threshold.

### Temporal Contrastive Loss (Section 3.2)

The loss maximizes similarity between positive pairs across timesteps:
```
L = -(1/TN) Σ_i Σ_t log[exp(sim(z^A_i,t, z^B_i,t)/τ) / Σ_j exp(sim(z^A_i,t, z^B_j,t)/τ)]
```

### Synaptic Pruning (Section 3.3)

Pruning preserves representational geometry by maximizing cosine similarity:
```
S_C(ω, ω') = <ω, ω'> / (||ω||_2 · ||ω'||_2)
```

## Similarity Metrics

| Metric | Description |
|--------|-------------|
| **SVCCA** | Singular Vector Canonical Correlation Analysis - measures subspace alignment |
| **TSVDR** | Truncated SVD Regression - ridge regression prediction of neural responses |
| **RSA** | Representational Similarity Analysis - correlation of dissimilarity matrices |

## Citation

```bibtex
@inproceedings{anonymous2026emergent,
  title={Emergent Visual Representations through Unsupervised Spiking Networks with Synaptic Pruning},
  author={Anonymous},
  booktitle={International Conference on Machine Learning},
  year={2026}
}
```

## License

This project is released under the MIT License.
