# Source codes for FedHD
> We provide bash script for training on CAMELYON16、CAMELYON17 and TCGA-IDH dataset
> Before running the code, ensure you have downloaded these dataset and preprocess following [CLAM](https://github.com/mahmoodlab/CLAM)

The list of useful parameters is as follows:
* `data_root_dir`: this is the path where you put your '.pt' files for patch features.
* `feature_type`: feature extractor, e.g., ResNet50, ViT, UNI, PLIP, CONCH.
* `mil_method`: MIL framework, e.g., CLAM, ABMIL, TransMIL.
* `fed_method`: Federated Learning frameworks.
* `heter_model`: set this to True to allow Heterogeneous Local Model setup.
* `ipc`: number of synthetic slides per class.
* `nps`: number of synthetic patches per slide.
* `syn_size`: size of synthetic patches.
* `n_classes`: number of classes.
* `seed`: random seed for reproducible experiment.
* `task`: which dataset to run.
* `drop out`: enabel dropout.


### Run (CAMELYON16 Example)
```
CUDA_VISIBLE_DEVICES=7 python main.py --fed_method=fed_hd --drop_out --seed=42 --data_root_dir="/data/data_cam16" --n_classes=2 --ipc=10 --nps=50  --task=CAMELYON16 
```
