# Compositional Two-Sample Test

Simulation code for the Spherical and Compositional two-sample test.

## Core Implementation

`optimized_estimators.py` contains the studentized spherical energy distance test statistic $T_{p,mn}$. It computes the projected energy distance using Gegenbauer polynomial based kernels on the sphere, with a bias corrected variance estimator. Under the null hypothesis, $T_{p,mn}$ converges to $N(0,1)$.

```python
from optimized_estimators import OptimizedTestStatistic, SphericalTestConfig

config = SphericalTestConfig(p=4, d=9)  # p=truncation order, d=sphere dimension
calculator = OptimizedTestStatistic(config)
T = calculator.compute(X, Y)  # X, Y are points on the unit sphere
```

## Running Simulations

### Spherical Data Simulations

```bash
python spherical_simulations.py
```

Results are saved to `simulation_results/`.

### Compositional Data Simulations

```bash
python compositional_simulations.py
```

Results are saved to `compositional_simulations/`.

## Reproducibility

Both simulation scripts use a master seed for full reproducibility:

- `spherical_simulations.py`: `MASTER_SEED = 5086`
- `compositional_simulations.py`: `MASTER_SEED = 10397`

To reproduce results exactly, run the scripts without modifying the seed. To generate new random results, change the `MASTER_SEED` value in the respective file.
