# Fairness-Aware Classification

This directory contains implementations for fairness-aware classification using constrained minimax optimization. The project addresses group fairness constraints in machine learning by solving constrained minimax optimization problems.

## Overview

The project is organized into two scales:

- **`small-scale/`** - Experiments on the Adult dataset with multiple algorithms
- **`large-scale/`** - Experiments on the CelebA dataset with deep learning models

## Algorithms

- **SPACO** - Stochastic Algorithm for Couple Constrained Minimax optimization
- **EG** - Extra-gradient method
- **NPE** - Nested Penalty-based method (LEN with m=1)
- **LEN** - Lagrangian-based method with nested optimization
- **Adv-Debias** - Adversarial debiasing baseline

## Fairness Metrics

- **DPD** (Demographic Parity Difference): `|P(Ŷ=1|Z=0) − P(Ŷ=1|Z=1)|`
- **EOD** (Equalized Odds Difference): `|TPR₀ − TPR₁| + |FPR₀ − FPR₁|`

## Quick Start

### Small-Scale (Adult Dataset)

```bash
cd small-scale

# Run SPACO algorithm
make spaco GPU=0

# Run all algorithms (EG, SPACO, NPE, LEN)
make all GPU=0

# Run with custom configuration
make spaco GPU=0 EXTRA_CONFIG="beta=5 eta=0.1"

# View all options
make help
```

**Available Commands:**
- `make spaco` - Run SPACO algorithm
- `make eg` - Run EG algorithm
- `make len` - Run LEN algorithm
- `make all` - Run all algorithms

**Configuration:**
- `GPU=<id>` - Set GPU ID (default: 0)
- `EXTRA_CONFIG=...` - Add Hydra overrides (e.g., `beta=5 eta=0.1`)

### Large-Scale (CelebA Dataset)

```bash
cd large-scale

# Run SPACO training
make spaco GPU=0

# Run without debiasing (baseline)
make no_debias GPU=0

# Run adversarial debiasing
make adv_debias GPU=0

# View all options
make help
```

## Examples

```bash
# Small-scale: Run SPACO with custom fairness constraint
cd small-scale
make spaco GPU=0 EXTRA_CONFIG="beta=0.5"

# Large-scale: Run SPACO with custom training epochs
cd large-scale
make spaco GPU=0 EXTRA_CONFIG="epochs=20 beta=r"
```
