Decentralized Optimization Experiments

This project implements four decentralized optimization algorithms for image classification tasks on MNIST and FashionMNIST:

- DNSGD (Decentralized Normalized Stochastic Gradient Descent)
- DSGD (Decentralized Stochastic Gradient Descent)
- DSGT (Decentralized Stochastic Gradient Tracking)
- DNASA (Decentralized Normalized Averaged Stochastic Approximation)

Requirements

- Python 3.8+
- PyTorch
- NumPy
- Matplotlib
- NetworkX

Project Structure

- experiment_utils/dataset.py: Load the dataset and partition it based on the number of nodes. The default is equal partitioning. When the number of labels is equal to the number of nodes, you can choose to partition the data based on the labels.
- experiment_utils/experiment_utils.py: Settings for all operating parameters and training logic.
- experiment_utils/network.py: Model structure definition.
- optim/: Specific implementation of the four algorithms.
- mnist.py: The experiment runs the main file, and each process runs the file for distributed simulation.

Run Experiments

mnist.sh is a sample script. You can use it to configure the parameters in experiment_utils.py and compare the four algorithms. The training results are automatically saved.

Acknowledgments

Some parts of the code in the `decentralized_opt` folder and the `optim/DecentralizedOptimizer.py` file are based on the project in https://github.com/liboyue/beer. We would like to express our gratitude to the authors of this project for their valuable contributions.

