# E2MC — Efficient Exploration with Learned Proposals

This repository contains the implementation and experimental evaluation of
**E2MC**, a sampling algorithm combining MCMC exploration, importance
resampling, and learned proposal projection.

The code supports two experimental settings:

1. **Toy 2D benchmarks** (Rings, Two Moons)  
   → comparison against RW, AIS, and NUTS 

2. **High-dimensional Gaussian Mixture Models (GMMs)**  
   → E2MC-only experiments with RW or ULA kernels and λ-grids

---

## Repository structure


├── algorithms/ # Sampling algorithms and proposals
│ ├── e2mc.py # E2MC (flow-based) for toy 2D targets
│ ├── e2mc_gmm.py # E2MC for tensorized GMM targets
│ ├── rw.py # Random-Walk Metropolis
│ ├── ais.py # Annealed Importance Sampling
│ ├── nuts.py # NUTS (Pyro)
│ ├── proposals.py # Gaussian proposals
│ └── init.py
│
├── experiments/ # Experiment orchestration
│ ├── config.py # Toy 2D configs (Rings / Moons)
│ ├── benchmark.py # Run all methods (toy 2D)
│ ├── metrics.py # SW and Energy Distance
│ ├── gmm_config.py # GMM experimental configs
│ └── init.py
│
├── targets/ # Target distributions π(x)
│ ├── rings.py # Rings distribution
│ ├── moons.py # Two Moons (normflows)
│ ├── gmm.py # Tensorized Gaussian Mixtures
│ └── init.py
│
├── plotting/ # Visualization utilities
│ ├── scatter.py # 2D scatter plots
│ ├── gmm.py # λ–time grid plots for GMM experiments
│ └── init.py
│
├── mcmc.py # Generic MCMC kernels (RW, ULA, MALA)
├── utils.py # Weights, mixtures, utilities
│
├── Rings_Moons_benchmark_e2mc.ipynb
├── GMM_benchmark_e2mc.ipynb
│
├── README.md
└── requirements.txt


---

## 1. Toy 2D benchmarks (Rings & Moons) : Rings_Moons_benchmark_e2mc.ipynb

This notebook reproduces the main **toy 2D experiments** used to compare E2MC
against standard baselines.

### Features
- Targets:
  - Rings distribution
  - Two Moons distribution
- Methods:
  - Random-Walk Metropolis (RW)
  - Annealed Importance Sampling (AIS)
  - NUTS (via Pyro)
  - E2MC
- Shared RW kernel parameters across all methods
- Quantitative metrics:
  - **Sliced Wasserstein distance (SW)**
  - **Energy Distance (ED)**
- Figures with metrics displayed directly on each plot


## 2. High-dimensional GMM experiments : GMM_benchmark_e2mc.ipynb

This notebook focuses on high-dimensional Gaussian Mixture Models, and is
designed to analyze the behavior of E2MC in challenging multimodal settings.

### Features

- Targets:

    - Tensorized Gaussian Mixtures (GM2, GM4, GM25)

- Dimensions:

    - Configurable (e.g. d = 4, 10, 20)

- Kernels:

    - Random Walk (RW)

    - Unadjusted Langevin Algorithm (ULA)

- E2MC experiments

- Exploration over multiple values of λ

- Visualization of proposal evolution over time and λ using grid plots


## Requirements

All dependencies are listed in requirements.txt