# Optimal Transport Under Group Fairness Constraints

## Overview
This repo contains the code to reproduce the experiments of the paper "Optimal Transport Under Group Fairness Constraints".

## Installation
To install the package in editable mode, follow these steps:

1. Navigate to the `fair_ot` directory in your terminal.
2. Run the following command:

```
pip install -e .
```

This command will install the package in editable mode, allowing you to make changes to the source code in the `src` directory and have them reflected immediately without needing to reinstall the package.

## Usage

### Figure 2

To reproduce Figure 2, run the following command
```bash
python exps/plot_data.py 
```

### Figure 3.a, b, c
#### Mixture of Gaussians case
To reproduce the results concerning the gaussian data:
* Run the following command for penalized OT
```bash
python exps/exp_gaussian/exp_penalized_ot.py
```
* Run the following command for cost learning
```bash
python exps/exp_gaussian/exp_cost_learning.py
```
* Run the following command for entropic OT
```bash
python exps/exp_gaussian/exp_entropic_ot.py
```
* Run the following command for FairSinkhorn and get the Figure 3.a
```bash
python exps/exp_gaussian/exp_fairsinkhorn.py
```
* Run the following command to get the top part of Figure 3. b and c
```bash
python exps/exp_gaussian/plot_cost_vs_fairness.py
```

#### Nested circles case
To reproduce the results concerning the nested circles:
* Run the following command for penalized OT
```bash
python exps/exp_circles/exp_penalized_ot.py
```
* Run the following command for cost learning
```bash
python exps/exp_circles/exp_cost_learning.py
```
* Run the following command for entropic OT
```bash
python exps/exp_gaussian/exp_entropic_ot.py
```
* Run the following command to get the bottom part of Figure 3. b and c
```bash
python exps/exp_circles/plot_cost_vs_fairness.py
```

### Figure 4
To reproduce the results of Figure 4, run
```bash
python exps/exp_gaussian/exp_generalization.py
```
