# FedKalter

* Experiments are run on 16 public graph classification datasets from four different domains, including Small Molecules (MUTAG, BZR, COX2, DHFR, PTC\_MR, AIDS, NCI1), Bioinformatics (ENZYMES, DD, PROTEINS), Social Networks (COLLAB, IMDB-BINARY, IMDB-MULTI), and Computer Vision (Letter-low, Letter-high, Letter-med).

## Running examples
* First, to train on the cross-dataset setting based on three Bioinformatics datasets (BIO):
```
python exps/main_multiDS.py --repeat 1 --data_group 'bio' --seed 1 --alg fedkalter --type_init 'rw_dg'
python exps/main_multiDS.py --repeat 2 --data_group 'bio' --seed 2 --alg fedkalter --type_init 'rw_dg'
python exps/main_multiDS.py --repeat 3 --data_group 'bio' --seed 3 --alg fedkalter --type_init 'rw_dg'
python exps/main_multiDS.py --repeat 4 --data_group 'bio' --seed 4 --alg fedkalter --type_init 'rw_dg'
python exps/main_multiDS.py --repeat 5 --data_group 'bio' --seed 5 --alg fedkalter --type_init 'rw_dg'
```

* After running the above command lines, the raw results are stored in ```./outputs/raw/```.

* Then, to process the raw results:
```
python exps/aggregateResults.py --data_group 'bio'
```

* Finally, the results are stored in ```./outputs/processed/```.

## Options
The default values for various paramters parsed to the experiment are given in ```./exps/main_multiDS.py```. Details about some of those parameters are given here.
* ```--data_group:```  The group of datasets that corresponds to different settings. Default: 'chem'. Options: 'chem', 'biochem', 'biochemsn', 'biosncv'.
* ```--num_rounds:``` The number of rounds for simulation. Default: 200.
* ```--local_epoch:``` The number of local epochs. Default: 1.
* ```--n_rw:``` The dimension of random walk-based structure embedding (RWSE). Default: 16.
* ```--n_dg:``` The dimension of degree-based structure embedding (DSE). Default: 16.
* ```--type_init:``` The type of structure embedding. Default: 'rw_dg'. Options: 'rw', 'dg', 'rw_dg'.
* ```--hidden:``` The number of hidden units. Default: 64.
* ```--nlayer:``` The number of GNN layers. Default: 2.

