ColossalAI/examples/tutorial/opt/opt
Hongxin Liu 079bf3cb26
[misc] update pre-commit and run all files (#4752)
* [misc] update pre-commit

* [misc] run pre-commit

* [misc] remove useless configuration files

* [misc] ignore cuda for clang-format
2023-09-19 14:20:26 +08:00
..
README.md [tutorial] polish all README (#1946) 2022-11-14 19:49:32 +08:00
benchmark.sh [tutorial] edited hands-on practices (#1899) 2022-11-11 17:08:17 +08:00
colossalai_zero.py [misc] update pre-commit and run all files (#4752) 2023-09-19 14:20:26 +08:00
context.py [misc] update pre-commit and run all files (#4752) 2023-09-19 14:20:26 +08:00
requirements.txt [example] change accelerate version (#4431) 2023-08-30 22:56:13 +08:00
run_clm.py [misc] update pre-commit and run all files (#4752) 2023-09-19 14:20:26 +08:00
run_clm.sh [tutorial] edited hands-on practices (#1899) 2022-11-11 17:08:17 +08:00
run_clm_synthetic.sh [tutorial] add synthetic dataset for opt (#1924) 2022-11-13 03:26:11 +08:00
test_ci.sh [legacy] clean up legacy code (#4743) 2023-09-18 16:31:06 +08:00

README.md

Train OPT model with Colossal-AI

OPT

Meta recently released Open Pretrained Transformer (OPT), a 175-Billion parameter AI language model, which stimulates AI programmers to perform various downstream tasks and application deployments.

The following example of Colossal-AI demonstrates fine-tuning Casual Language Modelling at low cost.

We are using the pre-training weights of the OPT model provided by Hugging Face Hub on the raw WikiText-2 (no tokens were replaced before the tokenization). This training script is adapted from the HuggingFace Language Modelling examples.

Our Modifications

We adapt the OPT training code to ColossalAI by leveraging Gemini and ZeRO DDP.

🚀Quick Start for Tutorial

  1. Install the dependency
pip install datasets accelerate
  1. Run finetuning with synthetic datasets with one GPU
bash ./run_clm_synthetic.sh
  1. Run finetuning with 4 GPUs
bash ./run_clm_synthetic.sh 16 0 125m 4

Quick Start for Practical Use

You can launch training by using the following bash script

bash ./run_clm.sh <batch-size-per-gpu> <mem-cap> <model> <gpu-num>
  • batch-size-per-gpu: number of samples fed to each GPU, default is 16
  • mem-cap: limit memory usage within a value in GB, default is 0 (no limit)
  • model: the size of the OPT model, default is 6.7b. Acceptable values include 125m, 350m, 1.3b, 2.7b, 6.7, 13b, 30b, 66b. For 175b, you can request the pretrained weights from OPT weight downloading page.
  • gpu-num: the number of GPUs to use, default is 1.

It uses wikitext dataset.

To use synthetic dataset:

bash ./run_clm_synthetic.sh <batch-size-per-gpu> <mem-cap> <model> <gpu-num>

Remarkable Performance

On a single GPU, Colossal-AIs automatic strategy provides remarkable performance gains from the ZeRO Offloading strategy by Microsoft DeepSpeed. Users can experience up to a 40% speedup, at a variety of model scales. However, when using a traditional deep learning training framework like PyTorch, a single GPU can no longer support the training of models at such a scale.

Adopting the distributed training strategy with 8 GPUs is as simple as adding a -nprocs 8 to the training command of Colossal-AI!

More details about behind the scenes can be found on the corresponding blog, and a detailed tutorial will be added in Documentation very soon.