# Exploration Free Package

This repository packages the original notebook-style code into a reusable Python
module with a clear separation between the allocation algorithms (core logic)
and experiment drivers.

## Project Layout

- `exploration_free/core.py` – sampling helper, regret computation, and the GSG/SSG/Gaussian adaptive allocation algorithms.
- `exploration_free/experiments.py` – utilities for running regret sweeps, computing theoretical bounds, and plotting results.
- `ExplorationFree.py` – command-line entry point that wires the package together and provides ready-to-run scenarios.

## Running Experiments

```bash
python ExplorationFree.py --scenario gsg-known --runs 20 --plot --save-prefix results/gsg_known
```

Key CLI options:

- `--scenario` – choose among `gsg-known`, `gsg-unknown`, `ssg-known`, `ssg-unknown`,
  `gaussian-known`, `gaussian-unknown`, or `two-arm`.
- `--runs` – number of Monte Carlo replications per grid point.
- `--horizon-min-exp`, `--horizon-max-exp`, `--horizon-points` – control the `logspace`
  schedule of horizons.
- `--save-prefix` – save per-run and summary tables as Excel files.
- `--plot` – draw regret curves alongside the corresponding theoretical bounds.

## Using the Package Programmatically

```python
import numpy as np
from exploration_free import experiments

means = np.array([0.1, -0.3, 0.5, -0.1])
vars_ = np.array([1.0, 1.2, 1.8, 2.2])
generators = [
    (lambda mu=mu, var=var: (lambda size=None: np.random.normal(mu, np.sqrt(var), size=size)))()
    for mu, var in zip(means, vars_)
]
stds = np.sqrt(vars_)
T_list = np.logspace(3, 5, num=10, dtype=np.int64)
p_list = [1.0, 2.0, np.inf]

result = experiments.run_gsg_known_bounds(
    T_list,
    p_list,
    generators,
    stds,
    sigma_min=float(np.min(stds)),
    sigma_sg=float(np.max(stds)),
    runs=50,
)

result.per_run.head()
result.summary.head()
```

## Dependencies

The code relies on NumPy, SciPy, pandas, Matplotlib, and tqdm. Install them with:

```bash
pip install numpy scipy pandas matplotlib tqdm
```
