# ALAS: Additive Learnable Alpha-Stable Kernels for Bayesian Optimization

This repository contains an anonymous code release for Bayesian Optimization with **ALAS** kernels.

## Repository Overview

### Main entrypoints
- **`run_stable.py`**  
  Runs Bayesian Optimization on a selected benchmark with a chosen kernel and acquisition function, and saves
  the best-so-far trajectory (and optional alpha statistics) to disk.

- **`utils/utils.py`**  
  Implements one BO step:
  1) fit a GP model (with robust fitting fallback),
  2) build an acquisition function (EI / PI / UCB),
  3) optimize the acquisition to obtain the next evaluation point(s),
  4) optionally log learned stability-index summaries (`alpha_bar`).

### Kernel implementation (our contribution)
- **`botorch/models/kernels/stable_kernel.py`**  
  Implements the ALAS kernel family:
  - **ALAS**: learnable α-stable spectral mixtures.
  - **ALAS-Sep**: dimension-wise separable variant.

- **`botorch/models/gp_regression.py`**  
  Extends `SingleTaskGP` to support selecting kernels by string name (e.g., `alas`, `alas_sep`, baselines),
  and performs data-driven kernel initialization when available.

### Benchmarks and plotting
- **`test_functions/`**  
  Synthetic benchmarks and surrogate objectives used in the experiments.
- **`plot_res/`**  
  Scripts to reproduce paper figures and tables from saved `.pkl` trajectories.

### Output folders (generated after running)
- **`exp_res_best/pkl/`**: saved trajectories and (optionally) alpha history files.
- **`paper_figures/`**: generated PDF figures.

## Optimization convention
All experiments are run in **minimization** mode . The reported curves use best-so-far minimum.

---

## Setup

### 1) Create environment and install dependencies
```bash
python -m venv .venv
source .venv/bin/activate
pip install -U pip
pip install -r requirements.txt
```

### 2) Ensure local modules are used

This repo vendors modified BoTorch modules under `botorch/`. From the repo root:

```bash
export PYTHONPATH="$(pwd):$PYTHONPATH"
```

---
## Supported kernels and acquisition functions

Kernels (via `--kernel`): `learnable_alpha_stable` (ALAS), `additive_stable` (ALAS-Sep), `rbf`, `ma52`, `rq`, `sdk`, `sinc`

Acquisition functions (via `--acq`): `ei`, `pi`, `ucb`.

---
## Examples

### 1) ALAS on Hartmann-3

Note: `--n_mixture 1` corresponds to the single-component case used in the paper.
Also, in `run_stable.py`, `--seed N` runs seeds `0..N-1` (i.e., `N` independent runs).

```bash
python run_stable.py \
  --function_name hartmann3 \
  --kernel learnable_alpha_stable \
  --acq ei \
  --n_init 10 \
  --n_iter 30 \
  --n_mixture 1 \
  --seed 10
```

After running, results will be saved under:

* `exp_res_best/pkl/hartmann3_learnable_alpha_stable_ei.pkl`
* `exp_res_best/pkl/hartmann3_learnable_alpha_stable_ei_alpha_history.pkl` (if enabled)

### 2) ALAS-Sep (Additive) on Hartmann-3

```bash
python run_stable.py \
  --function_name hartmann3 \
  --kernel additive_stable \
  --acq ei \
  --n_init 10 \
  --n_iter 30 \
  --n_mixture 1 \
  --seed 10
```

### 3) Run baselines

```bash
python run_stable.py --function_name hartmann3 --kernel rbf  --acq ei --n_init 10 --n_iter 30 --seed 10
python run_stable.py --function_name hartmann3 --kernel ma52 --acq ei --n_init 10 --n_iter 30 --seed 10
```

---

## Output Format

Each run writes pickle files under `exp_res_best/pkl/`:

* `*_ei.pkl`: best-so-far objective values per iteration for each seed/run.
* `*_alpha_history.pkl`: per-iteration snapshots of learned `alpha_bar` (when logging is enabled).

---

## Plotting (Figures and Tables)

All plotting scripts read saved experiment outputs from:

* `exp_res_best/pkl/`

and write figures to:

* `paper_figures/`

### 1) Main paper grid figure (multi-task, mean ± stderr)

```bash
python plot_res/plot_paper_grid.py
```

### 2) Alpha summary table (prints LaTeX)

```bash
python analyze_alphas.py
```

### 3) 1D illustrative demos (Fig. 1 / Fig. 2)

```bash
python plot_res/fig1_weierstrass_demo.py
python plot_res/fig2_adaptivity_rbf_truth.py
```

### 4) Weierstrass benchmark table (prints LaTeX)

```bash
python plot_res/weierstrass_table.py
```



