# Closed-Loop Activation Density Control for Sparse Distributed Memory

This repository contains the implementation and experimental code for the ICLR 2026 submission **“Closed-Loop Activation Density Control for Sparse Distributed Memory.”**

## Abstract

Sparse Distributed Memory (SDM) requires setting a Hamming distance threshold (T) to determine which memory locations are activated on a query. This parameter critically affects performance but is extremely sensitive around the nominal operating point (near (n/2)). We address this fundamental sensitivity by controlling the activation density (p = k/L) (the fraction of memory locations activated) as a well-posed alternative to tuning (T) directly. Our approach combines inverse-CDF actuation with slope-normalized integral feedback to achieve stable, precise activation control. The closed loop adapts (T) on the fly to track a target sparsity (p^\*) across queries.

Empirically, the controller achieves near-perfect target tracking ((R^2 \approx 1.00)) and improves query efficiency, yielding **(\approx 5.2\times)** lower activation error than naive threshold control at equal budgets. Standard bisection achieves similar raw error but requires **(\approx 1.9\times)** more queries, resulting in worse cost-efficiency. The method generalizes across dimensions (n\in{512,1024,2048}) and target activation counts (k^\*\in{3,6,12}), and remains stable under mild departures from binomial assumptions when using empirical slope estimates.

## Key Results

- **~5.2× lower activation error** than naive threshold control under equal budgets.
- **Cost-efficiency:** bisection reaches similar raw error but needs **~1.9× more queries**; EMA wins on cost-weighted error.
- **Near-perfect tracking:** (R^2\approx 1.00) for target sparsity tracking.
- **Robust generalization:** consistent performance across (n\in{512,1024,2048}) and (k^\*\in{3,6,12}).
- **Practical robustness:** stable under mild non-binomial regimes via empirical slope estimation.

## Requirements

- Python 3.13+
- [uv](https://docs.astral.sh/uv/) for dependency management

## Installation

1. Clone the repository:

```bash
git clone <repository-url>
cd iclr-sdm-paper
```

2. Install dependencies with uv:

```bash
uv sync
```

## Usage

### Running Experiments

The main analysis pipeline is implemented in a Jupyter notebook:

```bash
uv run jupyter notebook experiments/final.ipynb
```

The notebook includes:

- Complete experimental pipeline
- Figure generation for all paper figures
- Table generation with LaTeX output
- Baseline comparisons and ablation studies
- Statistical analysis and validation

### Generated Outputs

Running the notebook will create:

- `figures/` with publication-ready PDF figures
- `tables/` with CSV data and LaTeX table sources
- Comprehensive experimental results matching the paper

## Repository Structure

```
├── core/                    # Core SDM implementation
│   └── sdm.py               # SimpleSdm class and controllers
├── experiments/             # Experimental code
│   └── final.ipynb          # Main analysis notebook
├── figures/                 # Generated figures (PDF)
├── tables/                  # Generated tables (CSV + LaTeX)
├── pyproject.toml           # Project configuration
└── README.md                # This file
```

## Core Components

### SDM Implementation

- `SimpleSdm`: base SDM with configurable threshold
- `EmaController`: proposed activation-density controller with EMA filtering
- Control-law verification and theoretical validation utilities

### Experimental Pipeline

- Baselines: naive (T)-control, bisection, budget-capped bisection
- Convergence analysis and stability-envelope characterization
- Generalization tests across parameter ranges
- Statistical validation with confidence intervals and seed-wise analysis

## Reproducibility

All experiments use fixed random seeds and shared per-trial query streams for fair comparisons. Protocol details mirror the paper, including:

- Disclosed warm-up and tail-error measurement
- Equal-budget comparisons and cost-weighted error analysis
- Consistent seeding and reporting across methods

## Dependencies

Managed via uv:

- `numpy` — numerical computations
- `scipy` — statistical functions and optimization
- `matplotlib` and `seaborn` — figures
- `pandas` — data management and analysis
- `scikit-learn` — metrics
- `tqdm` — progress tracking

## Citation

If you use this code in your research, please cite:

```bibtex
@inproceedings{anonymous2026closed,
  title={Closed-Loop Activation Density Control for Sparse Distributed Memory},
  author={Anonymous},
  booktitle={International Conference on Learning Representations},
  year={2026},
  note={Under review}
}
```
