-
Notifications
You must be signed in to change notification settings - Fork 4.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
51 changed files
with
725 additions
and
246 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
<div align="center"> | ||
|
||
# DeepSpeed on Windows | ||
|
||
</div> | ||
|
||
# Introduction | ||
|
||
DeepSpeed is a popular open-source deep learning optimization library that makes distributed training and inference easy, efficient, and effective. DeepSpeed has been widely used to train a variety of state-of-the-art models, including Phi-3, Megatron-Turing-530B, BLOOM-176B, and Arctic because of its rich suite of sophisticated optimizations (e.g., ZeRO, 3D parallelism, MoE, etc.). However, the lack of native support for Microsoft Windows, the most popular operating system, means that DeepSpeed innovations are inaccessible to many AI developers and users. To address this problem, we started an effort to make DeepSpeed run natively with full features on Windows, while ensuring the same ease-of-use enjoyed on Linux. | ||
|
||
In this blog, we are pleased to announce some early achievements on this journey: DeepSpeed can now be installed in Windows and run natively for single-GPU training, finetuning, and inferencing. Importantly, both the installation and usage experiences are identical to those on Linux. Furthermore, the finetuning and inferencing workloads demonstrate the functioning of three critical DeepSpeed features, HuggingFace Transformers integration, LoRA support, and CPU Offloading. DeepSpeed on Windows is available in DeepSpeed versions 0.14.5 and above. In the rest of this blog, we present examples to demonstrate these achievements. | ||
|
||
# Evaluation Environment | ||
We conducted the experiments on a Surface Laptop Studio 2 running Windows 11 Version 23H2 and Build 22631.3880. The laptop is equipped with a single NVIDIA RTX A2000 GPU with 4GB VRAM. We used Pytorch version 2.3.0 and HuggingFace Transformers version 4.41.2. The example scripts used are from the [DeepSpeedExamples repo](https://github.com/microsoft/DeepSpeedExamples), therefore you need to clone the repo before running any of the following examples. | ||
|
||
# Installation | ||
DeepSpeed can be installed on Windows in one of two ways. The easier way is to use the pip package manager, while the other is to build from source. The prerequisites for in both cases are Python 3.x and Pytorch with CUDA support. | ||
|
||
## Installing via pip | ||
To install DeepSpeed, simply run: `pip install deepspeed`. This will install the latest version of DeepSpeed (0.14.5 at this time). Unlike the Linux counterpart, the Windows version comes with all the operators already prebuilt, so there is no need to have a CUDA SDK or C++ compiler installed. | ||
|
||
<div align="center"> | ||
<img src="./media/win_pip_install_deepspeed.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
pip installation of DeepSpeed on Windows. | ||
</div> | ||
|
||
|
||
## Building from Source | ||
To build DeepSpeed from source, you need to clone the DeepSpeed repository and run the `build_win.bat` compilation script. | ||
|
||
|
||
## Validating Installation | ||
Regardless of the installation choice, you can check that the installation was successful by running ds_report. The output should look like this: | ||
|
||
|
||
<div align="center"> | ||
<img src="./media/ds_report.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
ds_report output confirming Windows installation of DeepSpeed. | ||
</div> | ||
|
||
# Pretraining Examples | ||
We use an image classification model, CIFAR10, and a language model, BERT, to demonstrate pretraining on Windows with DeepSpeed. | ||
|
||
## Pretraining CIFAR10 | ||
The scripts and codes required for CIFAR10 pretraining example are available in the following path: DeepSpeedExamples\training\cifar. You can launch the CIFAR10 pretraining experiment using the following command: `deepspeed cifar10_deepspeed.py –deepspeed`. The final output should look something like this: | ||
<div align="center"> | ||
<img src="./media/cifar10_training.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
Pretraining CIFAR10 model on Windows using DeepSpeed. | ||
</div> | ||
|
||
## Pretraining BERT | ||
The scripts and codes for the BERT pretraining example are available in the following path: DeepSpeedExamples\training\HelloDeepSpeed. You can launch the BERT pretraining experiment using the following command: `deepspeed train_bert_ds.py --checkpoint_dir experiment_deepspeed`. The final output should look like this: | ||
|
||
<div align="center"> | ||
<img src="./media/bert_training.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
Pretraining BERT model on Windows using DeepSpeed. | ||
</div> | ||
|
||
# Fine Tuning Example | ||
We demonstrate fine tuning capability by using the supervised fine tuning (SFT) step of DeepSpeed-Chat application. We conduct SFT of the HuggingFace facebook/opt-125m model while enabling LoRA and CPU offloading memory optimizations. The command line for running this example is as follows: | ||
deepspeed training\step1_supervised_finetuning\main.py --model_name_or_path facebook/opt-125m --gradient_accumulation_steps 8 --lora_dim 128 --only_optimize_lora --print_loss --zero_stage 2 --deepspeed --dtype bf16 --offload --output_dir output | ||
The output should look like this: | ||
|
||
<div align="center"> | ||
<img src="./media/opt125m_finetuning.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
Supervised Finetuning of facebook/opt-125m model on Windows using DeepSpeed. | ||
</div> | ||
|
||
# Inference Example | ||
We demonstrate inference capability by using ZeRO-Inference for token generation. ZeRO-Inference reduces hardware cost of inferencing by offloading to CPU or NVMe memories. We use the example scripts here to run token generation using Llama-2-7B model from HuggingFace. We offload the model weights to CPU memory since the 4GB VRAM is insufficient to host both the model and the generation working set. We use the following command line to generate 32 tokens from a prompt of 8 tokens: | ||
deepspeed run_model.py --model meta-llama/Llama-2-7b-hf --batch-size 64 --prompt-len 8 --gen-len 32 --cpu-offload | ||
The output will look something like this: | ||
|
||
<div align="center"> | ||
<img src="./media/llama2-7b_inference.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
LLAMA2-7B token generation on Windows using ZeRO-Inference. | ||
</div> | ||
|
||
# Summary | ||
Enabling DeepSpeed, a popular deep learning framework, to run natively on Windows, the most popular operating system, is a crucial step towards empowering every person and every organization to benefit from the ongoing AI revolution. In this blog, we have shared early results of our work towards this goal. Although Windows support of DeepSpeed is a work-in-progress, we hope that the above updates are encouraging and already useful to users. The next items on our roadmap include running on multiple GPUs, weight quantization, and performance studies. | ||
|
||
# Acknowledgements | ||
This work is a result of significant contributions from current and former DeepSpeed members including Costin Eseanu, Logan Adams, Elton Zheng, Reza Yazdani Aminabadi, Martin Cai, and Olatunji Ruwase. We also acknowledge the valuable contributions of DeepSpeed users who righteously demanded this feature, provided critical workarounds, partial solutions, and constructive feedback, and most importantly, stuck with us. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,123 @@ | ||
<div align="center"> | ||
|
||
# DeepSpeedのWindowsサポート | ||
|
||
</div> | ||
|
||
# はじめに | ||
|
||
DeepSpeedは、分散学習と推論を簡単かつ効率的に行うための人気のあるオープンソースの深層学習最適化ライブラリです。DeepSpeedは、その豊富かつ高度な最適化機能(例:ZeRO、3D parallelism, MoEなど)のおかげで、Phi-3、Megatron-Turing-530B、BLOOM-176B、Arcticなどの最先端モデルの学習に広く利用されています。しかし、最も普及しているオペレーティングシステムであるMicrosoft Windowsをネイティブにサポートしていなかったため、多くのAI開発者やユーザーが、DeepSpeedの革新的な機能を利用できない状態でした。この問題を解決するため、DeepSpeedの完全な機能をWindows上でネイティブに実行し、Linux上と同じ使いやすさを実現するための取り組みを開始しました。 | ||
|
||
このブログでは、この取り組みの最初の成果をお知らせします。現在、DeepSpeedはWindowsにインストールし、単一GPUでの学習、ファインチューニング、および推論をネイティブに実行できるようになりました。ここで重要なこととして、インストールと利用は、Linuxとまったく同じように行えます。ファインチューニングと推論のワークロードを通じて、HuggingFace Transformers との統合、LoRAのサポート、CPUオフロードの3つの重要なDeepSpeedの機能が、正しく動作していることが確認できました。このWindowsサポートは、バージョン0.14.5以降で利用可能です。このブログの残りの部分では、これらの成果を示す例を紹介します。 | ||
|
||
# テスト環境 | ||
|
||
Windows 11 Version 23H2 および Build 22631.3880 を実行している Surface Laptop Studio 2 でテストを行いました。このハードウェアには、4GBのVRAMを搭載した NVIDIA RTX A2000 GPU が1つ搭載されています。また、PyTorchバージョン 2.3.0 および HuggingFace Transformersバージョン 4.41.2 を使用しました。使用したサンプルスクリプトは[DeepSpeedExamplesリポジトリ](https://github.com/microsoft/DeepSpeedExamples)から取得できます。以下の例を実行する前にリポジトリをクローンしてください。 | ||
|
||
# インストール | ||
|
||
DeepSpeedは、2つの方法でWindowsにインストールできます。より簡単な方法は、pipパッケージマネージャーを使用することで、もう一方はソースからビルドする方法です。どちらの場合も、Python 3.xとCUDAサポート付きのPyTorchが必要です。 | ||
|
||
## pipを使用したインストール | ||
|
||
DeepSpeedをインストールするには、単に次のコマンドを実行します: `pip install deepspeed`。 | ||
これにより、最新バージョンのDeepSpeed(現時点では0.14.5)がインストールされます。Linux版とは異なり、Windows版ではすべてのオペレーターがすでにビルド済みであるため、CUDA SDKやC++コンパイラをインストールする必要はありません。 | ||
|
||
<div align="center"> | ||
<img src="../media/win_pip_install_deepspeed.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
pipによるWindowsへのDeepSpeedのインストール | ||
</div> | ||
|
||
|
||
## ソースからのビルド | ||
|
||
ソースからDeepSpeedをビルドするには、DeepSpeedリポジトリをクローンし、コンパイルスクリプトである `build_win.bat` を実行する必要があります。 | ||
|
||
## インストールの検証 | ||
|
||
インストール方法にかかわらず、`ds_report`を実行してインストールが成功したかどうかを確認できます。出力は次のようになります: | ||
|
||
<div align="center"> | ||
<img src="../media/ds_report.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
DeepSpeedのWindowsインストールを確認するds_reportの出力 | ||
</div> | ||
|
||
# 事前学習の例 | ||
|
||
Windows上でDeepSpeedを使用した事前学習の例として、画像分類モデルCIFAR10と言語モデルBERTの実行例を示します。 | ||
|
||
## CIFAR10の事前学習 | ||
|
||
CIFAR10の事前学習に必要なスクリプトとコードは、次のパスにあります: `DeepSpeedExamples\training\cifar` | ||
|
||
以下のコマンドを使用してCIFAR10の事前学習を開始できます: `deepspeed cifar10_deepspeed.py –deepspeed` | ||
|
||
出力は次のようになります。 | ||
|
||
<div align="center"> | ||
<img src="../media/cifar10_training.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
DeepSpeedによるWindowsでのCIFAR10モデルの事前学習 | ||
</div> | ||
|
||
## BERTの事前学習 | ||
|
||
BERTの事前学習に必要なスクリプトとコードは、次のパスにあります: `DeepSpeedExamples\training\HelloDeepSpeed` | ||
|
||
以下のコマンドを使用してBERTの事前学習を開始できます: `deepspeed train_bert_ds.py --checkpoint_dir experiment_deepspeed` | ||
|
||
出力は次のようになります。 | ||
|
||
<div align="center"> | ||
<img src="../media/bert_training.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
DeepSpeedによるWindowsでのBERTモデルの事前学習 | ||
</div> | ||
|
||
# ファインチューニングの例 | ||
|
||
DeepSpeed-Chatアプリケーションの教師ありファインチューニング(supervised fine tuning; SFT)を使用して、ファインチューニングの機能を示します。LoRAおよびCPUオフロードメモリ最適化を有効にして、 HuggingFace の `facebook/opt-125m` モデルのSFTを実施します。この例を実行するためのコマンドラインは次のとおりです: `deepspeed training\step1_supervised_finetuning\main.py --model_name_or_path facebook/opt-125m --gradient_accumulation_steps 8 --lora_dim 128 --only_optimize_lora --print_loss --zero_stage 2 --deepspeed --dtype bf16 --offload --output_dir output` | ||
|
||
出力は次のようになります。 | ||
|
||
<div align="center"> | ||
<img src="../media/opt125m_finetuning.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
DeepSpeedを使用したWindowsでの facebook/opt-125m モデルのファインチューニング | ||
</div> | ||
|
||
# 推論の例 | ||
|
||
推論の機能を示すために、トークン生成のためのZeRO-Inferenceを使用します。ZeRO-Inferenceは、CPUまたはNVMeメモリにオフロードすることで推論のハードウェアコストを削減します。ここでは、サンプルスクリプトを使用して、HuggingFaceのLlama-2-7Bモデルを使用したトークン生成を実行します。4GBのVRAMではモデルと生成処理の両方を実効するのに十分ではないため、モデルパラメータをCPUメモリにオフロードします。 | ||
|
||
次のコマンドラインを使用して、8トークンのプロンプトから32トークンを生成します: `deepspeed run_model.py --model meta-llama/Llama-2-7b-hf --batch-size 64 --prompt-len 8 --gen-len 32 --cpu-offload` | ||
|
||
出力は次のようになります。 | ||
|
||
<div align="center"> | ||
<img src="../media/llama2-7b_inference.png" style="width:6.5in;height:3.42153in" /> | ||
</div> | ||
|
||
<div align="center"> | ||
DeepSpeedのZeRO-InferenceによるWindowsでのLLAMA2-7Bのトークン生成 | ||
</div> | ||
|
||
# まとめ | ||
|
||
最も広く使われているオペレーティングシステムであるWindowsで、深層学習フレームワークであるDeepSpeedをネイティブに実行できるようにすることは、多くの人と組織が、今まさに進行中のAI革命の恩恵を受けるための重要な一歩です。このブログでは、この目標に向けたプロジェクトの、最初の成果を共有しました。Windowsのサポートは現在進行中のプロジェクトですが、今回の成果が多くのユーザにとって活用され、またさらに発展していけることを願っています。次のロードマップには、複数のGPUでの実行、モデルパラメータの量子化、パフォーマンスの詳細な分析が含まれます。 | ||
|
||
# 謝辞 | ||
|
||
このプロジェクトは、Costin Eseanu、Logan Adams、Elton Zheng、Reza Yazdani Aminabadi、Martin Cai、Olatunji Ruwaseを含むDeepSpeedメンバーによる大きな貢献の結果です。また、この機能を必要とし、様々な問題の解決策や、建設的なフィードバックを提供し、私たちと共に歩んでくれたDeepSpeedユーザーの重要な貢献に感謝します。 |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.