# Priority-Aware Shapley Value

This repository provides the implementation used to reproduce the numerical results in **Priority-Aware Shapley Value**.

## Requirements

- Python 3.10+
- Required libraries:
  - `numpy==2.2.6`
  - `pandas==2.3.3`
  - `scikit-learn==1.7.2`
  - `torch==2.7.1`
  - `torchvision==0.22.1`
  - `Pillow==12.0.0`
  - `matplotlib==3.10.8`
  - `seaborn==0.13.2`

Install the required dependencies using:

```bash
pip install -r requirements.txt
```

If you are using a CUDA-enabled GPU, you may install PyTorch with:

```bash
pip install torch==2.7.1 torchvision==0.22.1 --index-url https://download.pytorch.org/whl/cu118
```

## Folder Structure

- `exp1_DV/` – Data valuation experiments with multiple data providers (Section 5.1)
- `exp2_FA/` – Feature attribution experiments using poset structures (Section 5.2)

## Reproducing the Experiments

### 1. Data Valuation (Section 5.1)

This experiment evaluates PASV on MNIST and CIFAR-10 datasets with multiple data providers (owner, anchor, boosters, copier, poisoner).

To reproduce the results, go to the folder below and run the provided shell script:

```bash
cd exp1_DV
bash run_dv_mnist.sh    # For MNIST experiments
bash run_dv_cifar10.sh  # For CIFAR-10 experiments
```

(Note) This experiment requires a CUDA-compatible GPU with at least 32GB VRAM for training generative models (GAN, DDPM, DDIM, FM) which may take several hours.

### 2. Feature Attribution (Section 5.2)

This experiment evaluates feature attribution for income prediction using Census Income dataset with two poset structures (ordered partition and general DAG).

To run the experiment, go to the folder below and run the provided shell script:

```bash
cd exp2_FA
bash run_fa.sh
```
