# Constrained Generative Adversarial Networks (GAN-C)

This directory contains implementations for training Generative Adversarial Networks (GANs) with constraints using constrained minimax optimization algorithms.

## Overview

The project implements two main algorithms:

- **GAN-C** - Constrained GAN using penalty-based constrained optimization
- **SPACO** - Stochastic Algorithm for Couple Constrained Minimax optimization for GAN training

## Supported Datasets

- **MNIST** - Handwritten digits (28×28 grayscale)
- **CIFAR-10** - Natural images (32×32 RGB)
- **AFHQv2** - Animal faces (256×256 RGB)

## Supported Architectures

- **SNGAN** - Spectral Normalization GAN

## Quick Start

```bash
cd GANC

# Run SPACO training on MNIST
make spaco dataset=mnist GPU_ID=0

# Run GAN-C training on CIFAR-10
make ganc dataset=cifar10 GPU_ID=0

# View all options
make help
```

**Available Commands:**
- `make spaco` - Run SPACO training
- `make ganc` - Run GAN-C training

**Configuration:**
- `dataset=<name>` - Set dataset (mnist, cifar10, afhqv2) (default: mnist)
- `GPU_ID=<id>` - Set GPU ID (default: 0)
- `SWANLAB_MODE=<mode>` - Set SwanLab mode (cloud|offline|disabled) (default: disabled)
- `EXTRA_CONFIG=...` - Add Hydra overrides

## Examples

```bash
# Train SPACO on MNIST
make spaco dataset=mnist GPU_ID=0

# Train SPACO on CIFAR-10 with custom epochs
make spaco dataset=cifar10 GPU_ID=0 EXTRA_CONFIG="general.epochs=200"

# Train GAN-C on AFHQv2
make ganc dataset=afhqv2 GPU_ID=0

# Enable SwanLab logging
make spaco dataset=mnist GPU_ID=0 SWANLAB_MODE=cloud
```

## Output

Results are saved to:
- `outputs/<dataset>/<algorithm>/` - Training outputs and images
- `checkpoints/` - Model checkpoints

## Evaluation Metrics

- **FID** (Fréchet Inception Distance) - Lower is better
- **IS** (Inception Score) - Higher is better

## Configuration Files

Configuration files are located in `conf/`:
- `config.yaml` - Base configuration
- `config_spaco.yaml` - SPACO-specific configuration
- `config_ganc.yaml` - GAN-C-specific configuration
- `conf/algo/<dataset>/` - Dataset-specific algorithm configurations
- `conf/dataset/` - Dataset configurations
