# Supplementary Code: Global Geometry Is Not Enough

Code to reproduce experiments from the paper.

## Structure

```
supp/
├── src/
│   ├── models.py          # Vision encoder loading (21 models)
│   ├── metrics.py         # Geometric metrics (G.PR, G.Iso, L.Iso)
│   ├── jacobian.py        # Jacobian Effective Rank (JER)
│   ├── benchmarks.py      # Binding tasks (Attribute Binding, Same/Different)
│   └── plotting.py        # Visualization
├── scripts/
│   ├── run_main.py              # Table 1: Main leaderboard
│   ├── run_jacobian_spectrum.py # Figure 3: Jacobian spectrum
│   ├── run_layerwise_rank.py    # Figure 6: Layer-wise rank
│   └── run_readout_comparison.py # Figure 4: Readout methods
├── requirements.txt
└── README.md
```

## Installation

```bash
conda create -n anisotropy python=3.10 -y
conda activate anisotropy
pip install torch torchvision --index-url https://download.pytorch.org/whl/cu118
pip install -r requirements.txt
```

## Reproducing Results

### Table 1: Main Leaderboard
```bash
python scripts/run_main.py --models all --output outputs/table1.json
```

### Figure 3: Jacobian Spectrum
```bash
python scripts/run_jacobian_spectrum.py --output outputs/fig3.json
```

### Figure 6: Layer-wise Rank
```bash
python scripts/run_layerwise_rank.py --output outputs/fig6.json
```

### Figure 4: Readout Comparison
```bash
python scripts/run_readout_comparison.py --output outputs/fig4.json
```

## Models

21 pretrained encoders across 8 objective families:
- **Contrastive**: SimCLR
- **Variance-Decorrelation**: Barlow Twins, VICReg
- **Clustering**: SwAV
- **Self-Distillation**: DINO, DINOv2
- **Masked Prediction**: MAE, BEiT, I-JEPA
- **Vision-Language**: CLIP, SigLIP, EVA-CLIP
- **Supervised**: ConvNeXt

## License

MIT License for research purposes.
