Skip to content
/ AdaCons Public

Sample Implementation of the paper "Adaptive Consensus Gradients Aggregation for Scaled Distributed Training".

Notifications You must be signed in to change notification settings

yoniLc/AdaCons

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 

Repository files navigation

AdaCons: Adaptive Consensus Gradients Aggregation for Scaled Distributed Training

Sample Implementation of the distributed gradient aggregator from the paper "Adaptive Consensus Gradients Aggregation for Scaled Distributed Training".

Abstract

Distributed machine learning has recently become a critical paradigm for training large models on vast datasets. We examine the stochastic optimization problem for deep learning within synchronous parallel computing environments under communication constraints.

While averaging distributed gradients is the most widely used method for gradient estimation, whether this is the optimal strategy remains an open question. In this work, we analyze the distributed gradient aggregation process through the lens of subspace optimization. By formulating the aggregation problem as an objective-aware subspace optimization problem, we derive an efficient weighting scheme for gradients, guided by subspace coefficients. We further introduce subspace momentum to accelerate convergence while maintaining statistical unbiasedness in the aggregation.

Our method demonstrates improved performance over the ubiquitous gradient averaging on multiple MLPerf tasks while remaining extremely efficient in both communicational and computational complexity.

Code

The code provides an illustration, using a simple linear regression example, on how to apply the proposed AdaCons gradient aggregation technique within PyTorch’s distributed data-parallel (DDP) framework.

Please adjust the configuration to match your system settings:

torchrun --nproc_per_node=$n_local_gpus --nnodes=$n_nodes --node_rank=$rank --master_addr=$master_addr --master_port=$master_port Main.py

Running this script (1000 iterations) gives the following final loss performance.

Batch Size Baseline (Sum) Adacons (32 workers) Adacons (8 workers)
128 33.4 1.98E-8 1.27E-5
2K 49.3 1.48E-8 (iter 300) 52.4

Reference

@article{choukroun2024adacons,
  title={Adaptive Consensus Gradients Aggregation for Scaled Distributed Training},
  author={Choukroun, Yoni and Azoulay, Shlomi and Kisilev, Pavel},
  journal={arXiv preprint arXiv:2411.03742},
  year={2024}
}

About

Sample Implementation of the paper "Adaptive Consensus Gradients Aggregation for Scaled Distributed Training".

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages