# Spherical Generalized Gamma (SGG) DP Mechanisms

This repository contains reference implementations and **reproducibility notebooks** for the ICML submission:

**_Asymptotic Optimality of the High-Dimensional Gaussian Mechanism and Improved Low-Dimensional Mechanisms for Differential Privacy_**

The main technical components are:
- The **Spherical Generalized Gamma (SGG)** family of spherical additive-noise mechanisms (including the Gaussian mechanism as a special case).
- Numerical routines to evaluate/verify privacy guarantees (δ(ε)), and supporting checks against known special cases.
- Scripts/notebooks to reproduce the **tables and figures** reported in the paper.

> **Note** The artifacts here are provided solely to reproduce the results in the submitted manuscript.

---

## Environment and installation

Recommended:
- Python ≥ 3.10
- NumPy, SciPy, Matplotlib
- JupyterLab (or Jupyter Notebook)

Typical setup (from repo root):

```bash
python -m venv .venv
source .venv/bin/activate
pip install -U pip
pip install -r requirements.txt
# (optional) install the package in editable mode if a pyproject.toml/setup.py is present:
pip install -e .
```


---

## Core API used by the notebooks

Most result-generation notebooks ultimately evaluate privacy via:

```python
compute_spherical_generalized_gamma_privacy(eps, alpha, beta, p, T, mu_0, mu_1)
```

which returns the optimal δ(ε) for neighboring shifts μ_0,μ_1 (with ∥μ_1-μ_0∥_2 typically equal to the sensitivity `s`).

---

## Notebooks (what each one produces)

### 1) `table2_delta_star_bounds.ipynb`
Reproduces **Table 2**: numerical lower bounds on the regime threshold δ_⋆ as a function of ε (with fixed sensitivity, default `s=1`).

---

### 2) `sgg_fft_accountant_vs_sequential_composition.ipynb`
Compares a **FFT accountant** for composing SGG mechanisms against a baseline **sequential composition** bound.

---

### 3) `find_best_adv.py`: 
Used to generate the results for Figure 2 (computes the best adversary / compares error under the privacy constraint and logs the final values).`

---

### 4) `generalized_gamma.ipynb`
Exploratory notebook for the **generalized-gamma / SGG parameterization** and its relationship to common radial distributions.

---

### 5) Sanity checks against known special cases
These notebooks in `sanity_check` validate the implementation against mechanisms and distributions where trusted reference behavior is known.

---

### 6) `r1smg_true_delta_via_sgg_api.ipynb`
A comparison notebook for the **R1SMG** mechanism (rank-1 singular multivariate Gaussian) calibration from Ji–Li (USENIX Security 2024). It:
1. Computes the paper-calibrated σ⋆(ε,δ,T,s),
2. Converts it to SGG parameters α=0, p=2, β=1/(2σ_⋆),
3. Calls `compute_spherical_generalized_gamma_privacy` to obtain the corresponding **true** δ(ε) under that calibration.




