# Continual Learning With Participation Privacy

## An Auditable Buffering--Aggregation Recipe

This repository contains the implementation and experimental code for the paper:

> ***Continual Learning With Participation Privacy: An Auditable Buffering--Aggregation Recipe\***

The codebase is organized into four main folders:

- `attack/` — Privacy attack experiments \
- `randbin_admm/` — ADMM random-binning initialization \
- `delay/` — Delay/buffering experiments \
- `deep-network/` — Deep network experiments

## 

## Environment Setup

### 1. Python Dependencies

Before running any experiments, install all required dependencies:

```bash
pip install -r requirements.txt
```

It is **strongly recommended** to use a virtual environment (e.g. `conda` or `venv`) to avoid package conflicts.

Example with conda:

```bash
conda create -n ppcl python=3.10
conda activate ppcl
pip install -r requirements.txt
```

------

### 2. GPU Requirements

⚠️ **GPU is required** for the following components:

- `attack/` (privacy attack experiments)
- `deep-network/` (deep learning experiments)

These experiments rely on deep neural networks and are computationally expensive.
A CUDA-enabled GPU environment (e.g. NVIDIA GPU + CUDA + PyTorch GPU build) is required.

CPU-only execution is **not recommended** and may be infeasible for full experiments.

------

## Experiments

> ⚠️ Important:
> Most experiments **generate result files first**, and **visualization notebooks must be executed only after the experiments finish**.

------

### 1. Privacy Attack (`attack/`)

#### Step 1 — Run experiment (data generation)

```bash
cd attack
python attack_exp.py
```

This script generates the experimental results and saves them to disk.

#### Step 2 — Visualization

After the experiment finishes, open and execute the notebook:

```bash
attack_exp.ipynb
```

This notebook loads the generated data and produces figures and visualizations.

------

### 2. Delay Experiment (`delay/`)

Run the notebook for **both experiment execution and visualization**:

```bash
cd delay
delay_exp.ipynb
```

This notebook:

- runs the delay/buffering experiments
- directly generates plots and visual outputs

------

### 3. Deep-Network Experiments (`deep-network/`)

#### Full sweep run:

```bash
cd deep-network
batch sweep_run.sh
```

#### Single-parameter run:

```bash
cd deep-network
python main.py
```

#### Visualization

After the experiments finish, open and execute:

```bash
unit_test.ipynb
```

This notebook performs:

- result loading
- aggregation
- plotting and visualization

------

### 4. ADMM Initialization (`randbin_admm/`)

Run the convergence experiment:

```bash
cd randbin_admm
randbin.ipynb
```

This notebook runs the ADMM initialization experiment and produces convergence visualizations.

------

