# Accelerated Noisy Power Method

Companion code for the paper "Improved Analysis of the Accelerated Noisy Power Method with Applications to Decentralized PCA".

## Requirements

All experiments were ran using Python 3.10. The required libraries are specified in the `requirements.txt` file. To use the Fed-Heart-Disease dataset, install the FLamby Python library on the [FLamby GitHub repository](https://github.com/owkin/FLamby). The Ego-Facebook dataset can be found [here](https://snap.stanford.edu/data/egonets-Facebook.html).

## Usage

To generate Figure 1 (experiments on ANPM), run

```
python anpm/anpm_experiment.py --d 1000 --k 10 --T 1000
```

To generate Figure 2 (experiments on ADePM/DePM/DeEPCA), run

```
python anpm/depca_experiment.py
```

To generate Figure 3 (experiments on ANPM with mean-centered noise), run

```
python anpm/anpm_experiment.py --d 1000 --k 10 --T 1000 --noise stochastic
```

Finally, to generate Figure 4 (zoomed in version of Figure 1), run

```
python anpm/anpm_experiment.py --d 1000 --k 10 --T 200
```