From 0c763b2de1c8d23302c61601363129bdb95b5353 Mon Sep 17 00:00:00 2001 From: Sean Naren Date: Wed, 2 Dec 2020 11:54:46 +0000 Subject: [PATCH] Sharded DDP Docs (#4920) * Add doc fixes * Remove space * Add performance doc, fix flag * Fix up docs * Add install instructions * Update link * Add section for model parallelism, refactor into section * Address code review * fixed underline * Update docs/source/multi_gpu.rst Co-authored-by: edenlightning <66261195+edenlightning@users.noreply.github.com> * Address code review points * Added caveat, increase performance * Update docs/source/multi_gpu.rst Co-authored-by: edenlightning <66261195+edenlightning@users.noreply.github.com> * Update docs/source/multi_gpu.rst Co-authored-by: edenlightning <66261195+edenlightning@users.noreply.github.com> * Add cross reference * Swapped to just fairscale since new release contains all required code * Revert "Swapped to just fairscale since new release contains all required code" This reverts commit 21038e72 * Update docs/source/multi_gpu.rst Co-authored-by: chaton * Fairscale install has been fixed Co-authored-by: edenlightning <66261195+edenlightning@users.noreply.github.com> Co-authored-by: chaton --- docs/source/multi_gpu.rst | 57 ++++++++++++++++++++++++++++++++++--- docs/source/performance.rst | 18 ++++++++++++ 2 files changed, 71 insertions(+), 4 deletions(-) diff --git a/docs/source/multi_gpu.rst b/docs/source/multi_gpu.rst index 902ccbfd34c8d..5555e53409d20 100644 --- a/docs/source/multi_gpu.rst +++ b/docs/source/multi_gpu.rst @@ -598,6 +598,55 @@ If you need your own way to init PyTorch DDP you can override :meth:`pytorch_lig If you also need to use your own DDP implementation, override: :meth:`pytorch_lightning.core.LightningModule.configure_ddp`. +---------- + +.. _model-parallelism: + +Model Parallelism [BETA] +------------------------ + +Model Parallelism tackles training large models on distributed systems, by modifying distributed communications and memory management of the model. +Unlike data parallelism, the model is partitioned in various ways across the GPUs, in most cases to reduce the memory overhead when training large models. +This is useful when dealing with large Transformer based models, or in environments where GPU memory is limited. + +Lightning currently offers the following methods to leverage model parallelism: + +- Optimizer Sharded Training (partitioning your gradients and optimizer state across multiple GPUs, for reduced memory overhead) + +Optimizer Sharded Training +^^^^^^^^^^^^^^^^^^^^^^^^^^ +Lightning integration of optimizer sharded training provided by `Fairscale `_. +The technique can be found within `DeepSpeed ZeRO `_ and +`ZeRO-2 `_, +however the implementation is built from the ground up to be pytorch compatible and standalone. + +Optimizer Sharded Training still utilizes Data Parallel Training under the hood, except the optimizer state and gradients which are sharded across GPUs. +This means the memory overhead per GPU is lower, as each GPU only has to maintain a partition of your optimizer state and gradients. + +The benefits vary by model and parameter sizes, but we've recorded up to a 63% memory reduction per GPU allowing us to double our model sizes. Because of extremely efficient communication, +these benefits in multi-GPU setups are almost free and throughput scales well with multi-node setups. + +It is highly recommended to use Optimizer Sharded Training in multi-GPU environments where memory is limited, or where training larger models are beneficial (rough minimum of 500+ million parameter models). +Optimizer Sharded Training is typically not suited for smaller models, or where large batch sizes are important. +This is primarily because with larger batch sizes, storing activations for the backwards pass becomes the bottleneck in training. Sharding optimizer state as a result becomes less impactful. + +To use Optimizer Sharded Training, you need to first install Fairscale using the command below or install all extras using ``pip install pytorch-lightning["extra"]``. + +.. code-block:: bash + + pip install fairscale + + +.. code-block:: python + + # train using Sharded DDP + trainer = Trainer(accelerator='ddp', plugins='ddp_sharded') + +Optimizer Sharded Training can work across all DDP variants by adding the additional ``--plugins ddp_sharded`` flag. + +Internally we re-initialize your optimizers and shard them across your machines and processes. We handle all communication using PyTorch distributed, so no code changes are required. + + Batch size ---------- When using distributed training make sure to modify your learning rate according to your effective @@ -640,16 +689,16 @@ The reason is that the full batch is visible to all GPUs on the node when using ---------- -PytorchElastic +TorchElastic -------------- -Lightning supports the use of PytorchElastic to enable fault-tolerent and elastic distributed job scheduling. To use it, specify the 'ddp' or 'ddp2' backend and the number of gpus you want to use in the trainer. +Lightning supports the use of TorchElastic to enable fault-tolerant and elastic distributed job scheduling. To use it, specify the 'ddp' or 'ddp2' backend and the number of gpus you want to use in the trainer. .. code-block:: python Trainer(gpus=8, accelerator='ddp') -Following the `PytorchElastic Quickstart documentation `_, you then need to start a single-node etcd server on one of the hosts: +Following the `TorchElastic Quickstart documentation `_, you then need to start a single-node etcd server on one of the hosts: .. code-block:: bash @@ -671,7 +720,7 @@ And then launch the elastic job with: YOUR_LIGHTNING_TRAINING_SCRIPT.py (--arg1 ... train script args...) -See the official `PytorchElastic documentation `_ for details +See the official `TorchElastic documentation `_ for details on installation and more use cases. ---------- diff --git a/docs/source/performance.rst b/docs/source/performance.rst index 6e81963e31952..0f97942128cda 100644 --- a/docs/source/performance.rst +++ b/docs/source/performance.rst @@ -114,3 +114,21 @@ However, know that 16-bit and multi-processing (any DDP) can have issues. Here a CUDA_LAUNCH_BLOCKING=1 python main.py .. tip:: We also recommend using 16-bit native found in PyTorch 1.6. Just install this version and Lightning will automatically use it. + +---------- + +Use Sharded DDP for GPU memory and scaling optimization +------------------------------------------------------- + +Sharded DDP is a lightning integration of `DeepSpeed ZeRO `_ and +`ZeRO-2 `_ +provided by `Fairscale `_. + +When training on multiple GPUs sharded DDP can assist to increase memory efficiency substantially, and in some cases performance on multi-node is better than traditional DDP. +This is due to efficient communication and parallelization under the hood. + +To use Optimizer Sharded Training, refer to :ref:`model-parallelism`. + +Sharded DDP can work across all DDP variants by adding the additional ``--plugins ddp_sharded`` flag. + +Refer to the :ref:`distributed computing guide for more details `. \ No newline at end of file