# MinMaxCon: Constrained Minimax Optimization

This repository contains implementations and experiments for constrained minimax optimization problems, featuring the **SPACO** (Stochastic Algorithm for Couple Constrained Minimax optimization) algorithm and its applications.

## Overview

This project consists of three main components:

1. **[`debias/`](debias/)** - Fairness-aware classification with constrained minimax optimization
2. **[`GANC/`](GANC/)** - Constrained Generative Adversarial Networks (GAN-C)
3. **[`synthetic/`](synthetic/)** - Synthetic toy examples for algorithm validation

## Project Structure

```
.
├── debias/          # Fairness-aware classification experiments
│   ├── small-scale/ # Small-scale experiments (Adult dataset)
│   └── large-scale/ # Large-scale experiments (CelebA dataset)
├── GANC/            # Constrained GAN experiments
└── synthetic/       # Synthetic toy examples
```

## Quick Start

### Running Experiments

Each subproject has its own Makefile with convenient commands. Navigate to the respective directory and run:

```bash
# Fairness-aware classification
cd debias/small-scale
make help
make spaco

# Constrained GAN
cd GANC
make help
make spaco dataset=mnist

# Synthetic examples
cd synthetic
make help
make spaco problem=nonlinear
```

## Subprojects

### 1. Debias - Fairness-Aware Classification

Implements fairness-aware classification using constrained minimax optimization. Supports both small-scale (Adult dataset) and large-scale (CelebA dataset) experiments.

**Key Features:**
- Multiple algorithms: SPACO, EG, NPE, LEN
- Fairness metrics: Demographic Parity Difference (DPD), Equalized Odds Difference (EOD)
- Configurable fairness constraints

**Quick Run:**
```bash
cd debias/small-scale
make spaco GPU=0
```

See [`debias/README.md`](debias/README.md) for details.

### 2. GANC - Constrained Generative Adversarial Networks

Implements constrained GAN training using SPACO and GAN-C algorithms. Supports multiple datasets (MNIST, CIFAR-10, AFHQv2) and model architectures (DCGAN, SNGAN).

**Quick Run:**
```bash
cd GANC
make spaco dataset=mnist GPU_ID=0
```

See [`GANC/README.md`](GANC/README.md) for details.

### 3. Synthetic - Toy Examples

Synthetic constrained minimax optimization problems for algorithm validation and comparison.

**Key Features:**
- Linear and nonlinear toy problems
- Multiple algorithms: SPACO, MGD, RMPDPG
- Grid search utilities

**Quick Run:**
```bash
cd synthetic
make spaco problem=nonlinear
```
