# SVFair

This is the official implementation of *From Gradient Volume to Shapley Fairness: Towards Fair Multi-Task Learning*.

## Supervised Learning
The performance is evaluated under 3 scenarios:
 - Image-level Classification. The [CelebA] dataset contains 40 tasks.
 - Dense Prediction. The [NYU-v2] dataset contains 3 tasks and the [Cityscapes] dataset contains 2 tasks.

### Setup Environment
Following [FairGrad], [Nash-MTL]and [FAMO], we implement our method with the `MTL` library.

First, create the virtual environment:
```
conda create -n mtl python=3.9.7
conda activate mtl
python -m pip install torch==1.12.1+cu113 torchvision==0.13.1+cu113
```

Then, install the repo:
```
python -m pip install -e .
```

### Run Experiment
The dataset by default should be put under `experiments/EXP_NAME/dataset/` folder where `EXP_NAME` is chosen from `{celeba, cityscapes, nyuv2}`. To run the experiment:
```
cd experiments/EXP_NAME
sh run.sh
```

## Reinforcement Learning
The experiments are conducted on [Meta-World](https://github.com/Farama-Foundation/Metaworld) benchmark. To run the experiments on `MT10` and `MT50` (the instructions below are partly borrowed from [CAGrad]):

1. Create python3.6 virtual environment.
2. Install the [MTRL](https://github.com/facebookresearch/mtrl) codebase.
3. Install the [Meta-World](https://github.com/Farama-Foundation/Metaworld) environment with commit id `d9a75c451a15b0ba39d8b7a8b6d18d883b8655d8`.
4. Copy the `mtrl_files` folder to the `mtrl` folder in the installed mtrl repo, then 

```
cd PATH_TO_MTRL/mtrl_files/ && chmod +x mv.sh && ./mv.sh
```

5. Follow the `run.sh` to run the experiments.
