# Decentralized Learning

To construct environment:
```
# python3.12, cuda12.2
pip install torch==2.4.1 torchvision==0.19.1 torchaudio==2.4.1 --index-url https://download.pytorch.org/whl/cu118
pip install -r requirements.txt
```

```
# N=87 ResNet CIFAR-100 Exp.
python main.py <outdir> configs/common.yaml configs/nodes/node87.yaml \
 configs/graphs/exp.yaml configs/datasets/cifar-100_alpha0.1.yaml configs/models/resnet18_ng4_dp0.4_cifar-100.yaml \
 configs/optimizers/dsgd_beta0.9_wd5e-3_noscheduler.yaml configs/trains/cifar-100.yaml \
 --nstep 16000 --nouter 1 --ninner 10 --batch_size 128 --lr 1e-3 --lr_min 1e-10 --seed 19 --data_seed 11 --data_nduplicate 3
# N=87 ResNet CIFAR-100 1-peer Exp.
python main.py <outdir> configs/common.yaml configs/nodes/node87.yaml \
 configs/graphs/exp1.yaml configs/datasets/cifar-100_alpha0.1.yaml configs/models/resnet18_ng4_dp0.4_cifar-100.yaml \
 configs/optimizers/dsgd_beta0.9_wd5e-3_noscheduler.yaml configs/trains/cifar-100.yaml \
 --nstep 16000 --nouter 1 --ninner 10 --batch_size 128 --lr 1e-3 --lr_min 1e-10 --seed 19 --data_seed 11 --data_nduplicate 3
# N=87 ResNet CIFAR-100 MATCHA
python main.py <outdir> configs/common.yaml configs/nodes/node87.yaml \
 configs/graphs/matcha.yaml configs/datasets/cifar-100_alpha0.1.yaml configs/models/resnet18_ng4_dp0.4_cifar-100.yaml \
 configs/optimizers/dsgd_beta0.9_wd5e-3_noscheduler.yaml configs/trains/cifar-100.yaml \
 --nstep 16000 --nouter 1 --ninner 10 --batch_size 128 --lr 1e-3 --lr_min 1e-10 --seed 19 --data_seed 11 --data_nduplicate 3
# N=87 ResNet CIFAR-100 Ring
python main.py <outdir> configs/common.yaml configs/nodes/node87.yaml \
 configs/graphs/ring.yaml configs/datasets/cifar-100_alpha0.1.yaml configs/models/resnet18_ng4_dp0.4_cifar-100.yaml \
 configs/optimizers/dsgd_beta0.9_wd5e-3_noscheduler.yaml configs/trains/cifar-100.yaml \
 --nstep 16000 --nouter 1 --ninner 10 --batch_size 128 --lr 1e-3 --lr_min 1e-10 --seed 19 --data_seed 11 --data_nduplicate 3
# N=87 ResNet CIFAR-100 Sparse Exp.
python main.py <outdir> configs/common.yaml configs/nodes/node87.yaml \
 configs/graphs/sparse_exp.yaml configs/datasets/cifar-100_alpha0.1.yaml configs/models/resnet18_ng4_dp0.4_cifar-100.yaml \
 configs/optimizers/dsgd_beta0.9_wd5e-3_noscheduler.yaml configs/trains/cifar-100.yaml \
 --nstep 16000 --nouter 1 --ninner 10 --batch_size 128 --lr 1e-3 --lr_min 1e-10 --seed 19 --data_seed 11 --data_nduplicate 3
```

