Skip to content
forked from INET-RC/GeoMX

GeoMX: Fast and unified distributed system for training machine learning algorithms over geographical data centers.

License

Notifications You must be signed in to change notification settings

Lizonghang/GeoMX

 
 

Repository files navigation

GeoMX: Fast and unified distributed system for training ML algorithms over geographical data centers

GitHub stars GitHub forks Docker Stars Docker Pulls Documentation Status Read the Docs GitHub license

Introduction

GeoMX is an optimized distributed machine learning system that operates across multiple geographically dispersed data centers. Built upon the MXNET framework, GeoMX integrates several sophisticated optimization techniques to enhance its training efficiency. These strategic enhancements result in a significant performance boost compared to the original MXNET system, offering 20x acceleration under identical network bandwidth conditions. This superior efficiency propels GeoMX to the forefront of training systems used for geographically dispersed data centers, showcasing satisfying performance and effectiveness.

GeoMX employs the Hierarchical Parameter Server (HiPS)1 framework as its fundamental training architecture, designed to segregate the network environment within and beyond the data center. This unique architecture includes an intra-domain parameter server system within each data center while concurrently establishing an inter-parameter server connection between different data centers. In this configuration, model data traffic undergoes two stages of aggregation: an initial local aggregation within each data center, followed by a global aggregation at the central data center. This approach effectively minimizes cross-WAN traffic and, consequently, reduces communication overhead.

Communication Optimization Techniques

But it's far from enough, given the often limited and varied network conditions in WANs, distributed training across data centers can potentially create communication bottlenecks. To mitigate these issues, GeoMX employs a variety of optimization techniques. These include gradient sparsification, low-precision quantization (e.g., fp16), mixed-precision quantization, advanced transmission protocols, synchronization algorithms, flow scheduling, priority scheduling, load balancing, among others (e.g., overlay scheduling, currently in development). These techniques comprehensively tackle communication issues, further enhancing the efficiency and robustness of distributed machine learning training in GeoMX.

Next, let's delve into each optimization technique in brief:

  1. Bidirectional Gradient Sparsification (Bi-Sparse)1: Traditional approaches such as Deep Gradient Compression sparsify the pushed gradient tensors. For further compression, we also sparsify the pulled (aggregated) gradient tensors rather than pulling full parameters. This technique is enabled between the global parameter server and the intra-domain parameter servers of different data centers. (Refer to this paper for more details.)
  2. Low-Precision Quantization (FP16): GeoMX also supports quantifying model data at lower precision for transmission, such as in FP16 format. In this scheme, GeoMX computes the model using FP32, but during transmission, it converts the model data tensor into FP16. Once the pulling data is received, GeoMX reverts it back into FP32 and continues model computing. This effectively halves the data traffic volume over both LANs and WANs.
  3. Mixed-Precision Quantization (MPQ): The technology of MPQ leverages both Bi-Sparse and FP16. In this scheme, tiny tensors are quantified into FP16 format for transmission, while large tensors persist in the FP32 format. Moreover, these large sensors will undergo a sparsification process before transmission. This precaution is taken to minimize the loss of crucial information and avoid significant degradation to model performance.
  4. Differential Gradient Transmission (DGT)2: This advanced transmission protocol is optimized for distributed machine learning tasks. Leveraging the tolerance of gradient descent algorithms towards partial parameter loss, this protocol transfers gradients across multiple channels, each with distinct levels of reliability and priority, contingent on their respective contributions to model convergence. Through these prioritized channels, critical gradients receive precedence in transmission, while other non-important gradients are transmitted with lower priority and reliability. This helps to reduce tail latency and thus reduce the end-to-end transmission delay of parameter synchronization. (Refer to this paper for more details and this repo for individual use.)
  5. TSEngine3: To solve the communication in-cast issue typically associated with centralized parameter servers, GeoMX incorporates TSEngine, an adaptive communication scheduler designed for efficient communication overlay in WANs. TSEngine dynamically optimizes the topology overlay and communication logic among the training nodes in response to real-time network conditions. This adaptive scheduler shows significant advantages over existing communication patterns in terms of system efficiency, communication, as well as scalability. (Refer to this paper for more details and this repo for individual use.)
  6. Priority-based Parameter Propagation (P3): In conventional implementations, the gradient synchronization at round $r$ does not overlap with the forward propagation at round $r+1$, because the forward propagation relies on the completion of gradient synchronization. To improve system efficiency, GeoMX integrates the P3 scheduler, which prioritizes the transmission of shallow-layer gradients. This setup enables overlapping between forward propagation and gradient synchronization, allowing earlier execution of forward propagation for the next round, thereby accelerating distributed training. (See this paper for more details and this repo for individual use.)
  7. Multi-Server Load Balancing (MultiGPS): GeoMX supports a balanced distribution of workload, including traffic, storage, and computation, across multiple global parameter servers. By preventing any single server from becoming a bottleneck, MultiGPS significantly enhances efficiency, scalability, and overall performance of our GeoMX system.

Synchronization Algorithms

GeoMX supports two fundamental synchronization algorithms: a fully-synchronous algorithm and a mixed-synchronous algorithm.

  1. Fully-Synchronous Algorithm (FSA): In this synchronous algorithm, training nodes synchronize their model data (can be parameters or gradients) each round, and both parameter server systems within and between data centers run in a synchronous parallel mode. This means all training nodes are synchronized to ensure a consistent model. (Default)

FSA is highly effective in maintaining model accuracy and consistency, but at the expense of training speed, as it necessitates waiting for all computations and communications to complete at every iteration.

  1. Mixed-Synchronous Algorithm (MixedSync): This algorithm is an asynchronous version of FSA, where the difference is that the parameter server system between data centers runs in an asynchronous parallel mode. This setup is particularly suitable for scenarios where intra-data center training nodes display high homogeneity, yet there is significant resource heterogeneity between different data centers. This asynchronous method resolves the problem of straggling data centers, thereby accelerating distributed training across WANs.

To alleviate the issue of stale gradients in asynchronous parallel operations, the global parameter server can be configured to use the DCASGD optimizer. This adjustment aids in improving training convergence while preserving model accuracy.

Building upon the two aforementioned fundamental algorithms, GeoMX also offers two advanced synchronization algorithms. These two advanced algorithms are specifically designed to address the challenges of bandwidth scarcity and resource heterogeneity in WANs.

  1. Hierarchical Frequency Aggregation (HFA): Inspired by this paper, our HFA algorithm first performs $K_1$ steps of local updates at the training nodes, followed by $K_2$ steps of synchronizations at the local parameter server. Finally, a global synchronization is performed at the global parameter server. This approach effectively reduces the frequency of model synchronization across data centers, thereby boosting distributed training.

  2. ESync4: Applying asynchronous algorithms to strongly heterogeneous clusters can lead to severe stale gradient issues. To address this, we can adopt an optimized algorithm known as ESync. ESync is a synchronous parallel algorithm designed to save stragglers under conditions of strong resource heterogeneity. It introduces a state server to orchestrate the local iteration steps of each training node, in order to balance their reach-server time (including computational and transmission time). (To be integrated, refer to this paper for more details and this repo for individual use.)

Quick Start

This guide will help you get started with GeoMX in just two steps.

Prerequisites: We provide a pre-built Docker image for a quick trial of GeoMX. For this, Docker and Nvidia-Docker need to be installed following: Docker Guide and Nvidia-Docker Guide.

  • Step 1: Pull the Docker image and run a container.
# To run on CPUs, use:
sudo docker run -it --rm --name geomx lizonghango00o1/geomx:cpu-only bash

# To run on GPUs with CUDA 8.0, use:
sudo docker run -it --rm --name geomx --gpus all lizonghango00o1/geomx:cu80 bash

# To run on GPUs with CUDA 10.1, use:
sudo docker run -it --rm --name geomx --gpus all lizonghango00o1/geomx:cu101 bash
  • Step 2: Use the scripts in the scripts folder to launch demo tasks. For example:
# To run on CPUs, use:
cd GeoMX/scripts/cpu && bash run_vanilla_hips.sh

# To run on GPUs, use:
cd GeoMX/scripts/gpu && bash run_vanilla_hips.sh

If you are using the images with tags cu80 and cu101, the first-time initialization of GeoMX may take a few minutes. However, subsequent runs should proceed without delay. This issue is common and can occur with other frameworks like PyTorch and MXNET as well.

For more detailed instructions, please refer to our GeoMX Docs (中文文档请看这里).

Contributors

  • Li, Zonghang1 - Initial work with equal contribution - Homepage
  • Zhang, Zhaofeng1 - Initial work with equal contribution - Homepage
  • Zhou, Huaman1 - Initial work with equal contribution - Homepage
  • Cai, Weibo1 - Initial work with equal contribution - Homepage
  • Yu, Hongfang1 - Project instructor - Homepage
  • Other contributors: Cai, Qingqing1; Wang, Jigang1; Zhang, Zhihao1; Shao, Junming2; Xu, Zenglin3; AND YOU.

The contributors are from the following institutions:

  1. University of Electronic Science and Technology of China - Intelligent Network and Application Research Centre (INET-RC)
  2. University of Electronic Science and Technology of China - Data Mining Lab
  3. Harbin Institute of Technology, Shenzhen - Statistical Machine Intelligence and Learning Lab (SMILE Lab)

Cite Us

If this repo is helpful to you, please kindly cite us:

@misc{li2020geomx,
  author = {Li, Zonghang and Zhang, Zhaofeng and Zhou, Huaman and Cai, Weibo and Yu, Hongfang},
  title = {GeoMX: Fast and unified distributed system for training machine learning algorithms over geographical data centers.},
  year = {2020},
  howpublished = {GitHub},
  url = {https://github.com/INET-RC/GeoMX}
}

References

  1. Li, Zonghang, Hongfang Yu, and Yi Wang. "Geo-distributed machine learning: Framework and technology exceeding lan speed." ZTE Technology Journal 26, no. 5 (2020): 16-22.
  2. Zhou, Huaman, Zonghang Li, Qingqing Cai, Hongfang Yu, Shouxi Luo, Long Luo, and Gang Sun. "DGT: A contribution-aware differential gradient transmission mechanism for distributed machine learning." Future Generation Computer Systems 121 (2021): 35-47.
  3. Zhou, Huaman, Weibo Cai, Zonghang Li, Hongfang Yu, Ling Liu, Long Luo, and Gang Sun. "TSEngine: Enable efficient communication overlay in distributed machine learning in wans." IEEE Transactions on Network and Service Management 18, no. 4 (2021): 4846-4859.
  4. Li, Zonghang, Huaman Zhou, Tianyao Zhou, Hongfang Yu, Zenglin Xu, and Gang Sun. "ESync: Accelerating intra-domain federated learning in heterogeneous data centers." IEEE Transactions on Services Computing 15, no. 4 (2020): 2261-2274.

For more details on the GeoMX system, please refer to our book:

Cover for GeoMX Book

虞红芳, 李宗航, 孙罡, 罗龙. 《跨数据中心机器学习:赋能多云智能数算融合》. 电子工业出版社, 人工智能前沿理论与技术应用丛书, (2023).

About

GeoMX: Fast and unified distributed system for training machine learning algorithms over geographical data centers.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 61.1%
  • Python 25.9%
  • Cuda 9.3%
  • C 1.4%
  • CMake 0.9%
  • Shell 0.9%
  • Other 0.5%