Skip to content

Official code for "SWARM Parallelism: Training Large Models Can Be Surprisingly Communication-Efficient"

Notifications You must be signed in to change notification settings

bit-current/swarm

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SWARM Parallelism: Training Large Models Can Be Surprisingly Communication-Efficient

Illustration of SWARM parallelism

This repository contains the code to replicate experiments of "SWARM Parallelism: Training Large Models Can Be Surprisingly Communication-Efficient".

Note: this codebase, as well as the project itself, is a work in progress: certain features (e.g., rebalancing between pipeline stages) are not yet added to the repository, expect the paper to get updated as well. In the meantime, you can watch this repository or visit the repository of Petals — a similar project for inference of large language models that was inspired by SWARM and shares portions of codebase with it.

Large-scale experiments and throughput estimation

Instructions to replicate the experiments on large-scale language model pretraining and throughput estimation on multiple preemptible nodes, as well as the prototype implementation of SWARM, are located in the swarm subfolder.

Bottleneck experiments

Instructions to replicate the compression-aware architecture experiments can be found in bottleneck/README.md.

Contacts

Feel free to ask any questions about this work by email.

References

@article{ryabinin2023swarm,
  title={SWARM Parallelism: Training Large Models Can Be Surprisingly Communication-Efficient},
  author={Ryabinin, Max and Dettmers, Tim and Diskin, Michael and Borzunov, Alexander},
  journal={arXiv preprint arXiv:2301.11913},
  year={2023}
}

About

Official code for "SWARM Parallelism: Training Large Models Can Be Surprisingly Communication-Efficient"

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 94.8%
  • Shell 3.5%
  • Cuda 0.8%
  • C++ 0.5%
  • Cython 0.3%
  • Lua 0.1%