From fd8051a69cc5fc188c4588692d929bca4fc62900 Mon Sep 17 00:00:00 2001 From: YiSheng5 Date: Wed, 29 May 2024 01:08:42 +0800 Subject: [PATCH 1/4] [MiCS] Remove the handle print on DeepSpeed side (#5574) When running for MiCS, we found many handle print on DeepSpeed from the output log, this pr is to remove it to suppress this. --- deepspeed/runtime/zero/mics.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/deepspeed/runtime/zero/mics.py b/deepspeed/runtime/zero/mics.py index 1e5c9396be1d..99e3bce9ecd0 100755 --- a/deepspeed/runtime/zero/mics.py +++ b/deepspeed/runtime/zero/mics.py @@ -43,7 +43,7 @@ def wait(self) -> None: """ # let the current stream to op try: - print("HANDLE", self.allgather_handle) + # print("HANDLE", self.allgather_handle) instrument_w_nvtx(self.allgather_handle.wait)() except (ValueError, RuntimeError) as e: log_dist( From bf66acdbae4551d97f4044e92e75ce8d7633299f Mon Sep 17 00:00:00 2001 From: Logan Adams <114770087+loadams@users.noreply.github.com> Date: Tue, 28 May 2024 13:01:48 -0700 Subject: [PATCH 2/4] Rename files in fp_quantize op from quantize.* to fp_quantize.* (#5577) Fixes #5535. Todo: need to test. --- csrc/fp_quantizer/{quantize.cpp => fp_quantize.cpp} | 2 +- csrc/fp_quantizer/{quantize.cu => fp_quantize.cu} | 2 +- csrc/fp_quantizer/includes/{quantize.h => fp_quantize.h} | 0 op_builder/fp_quantizer.py | 4 ++-- 4 files changed, 4 insertions(+), 4 deletions(-) rename csrc/fp_quantizer/{quantize.cpp => fp_quantize.cpp} (99%) rename csrc/fp_quantizer/{quantize.cu => fp_quantize.cu} (99%) rename csrc/fp_quantizer/includes/{quantize.h => fp_quantize.h} (100%) diff --git a/csrc/fp_quantizer/quantize.cpp b/csrc/fp_quantizer/fp_quantize.cpp similarity index 99% rename from csrc/fp_quantizer/quantize.cpp rename to csrc/fp_quantizer/fp_quantize.cpp index ec631c576e27..6962b8050f51 100644 --- a/csrc/fp_quantizer/quantize.cpp +++ b/csrc/fp_quantizer/fp_quantize.cpp @@ -3,7 +3,7 @@ // DeepSpeed Team -#include "quantize.h" +#include "fp_quantize.h" #include #include diff --git a/csrc/fp_quantizer/quantize.cu b/csrc/fp_quantizer/fp_quantize.cu similarity index 99% rename from csrc/fp_quantizer/quantize.cu rename to csrc/fp_quantizer/fp_quantize.cu index 5ada6894747f..cca063956167 100644 --- a/csrc/fp_quantizer/quantize.cu +++ b/csrc/fp_quantizer/fp_quantize.cu @@ -5,8 +5,8 @@ #include #include "context.h" +#include "fp_quantize.h" #include "memory_access_utils.h" -#include "quantize.h" #include "reduction_utils.h" #include diff --git a/csrc/fp_quantizer/includes/quantize.h b/csrc/fp_quantizer/includes/fp_quantize.h similarity index 100% rename from csrc/fp_quantizer/includes/quantize.h rename to csrc/fp_quantizer/includes/fp_quantize.h diff --git a/op_builder/fp_quantizer.py b/op_builder/fp_quantizer.py index bafd3e0c33f6..9f07ec3d1275 100644 --- a/op_builder/fp_quantizer.py +++ b/op_builder/fp_quantizer.py @@ -52,8 +52,8 @@ def filter_ccs(self, ccs): def sources(self): return [ - "csrc/fp_quantizer/quantize.cu", - "csrc/fp_quantizer/quantize.cpp", + "csrc/fp_quantizer/fp_quantize.cu", + "csrc/fp_quantizer/fp_quantize.cpp", ] def extra_ldflags(self): From 4deb40de67728dec2606327e8d63d3cb7028cc94 Mon Sep 17 00:00:00 2001 From: Logan Adams <114770087+loadams@users.noreply.github.com> Date: Tue, 28 May 2024 15:42:05 -0700 Subject: [PATCH 3/4] Update to fix sidebar over text (#5567) - [x] Needs to be tested. Fixes #5494. Sample screenshot: image --- docs/_sass/minimal-mistakes/_sidebar.scss | 2 ++ 1 file changed, 2 insertions(+) diff --git a/docs/_sass/minimal-mistakes/_sidebar.scss b/docs/_sass/minimal-mistakes/_sidebar.scss index 312a6279b9b0..5f657e112d82 100644 --- a/docs/_sass/minimal-mistakes/_sidebar.scss +++ b/docs/_sass/minimal-mistakes/_sidebar.scss @@ -79,6 +79,7 @@ top: auto; right: 0; width: $right-sidebar-width-narrow; + margin-right: -1.5 * $right-sidebar-width-narrow; padding-left: 1em; z-index: 10; @@ -93,6 +94,7 @@ @include breakpoint($x-large) { width: $right-sidebar-width; + margin-right: -1.5 * $right-sidebar-width-narrow; } } From 2fc702ed9f84f3c88179cb713bb9f4effbbdba33 Mon Sep 17 00:00:00 2001 From: Nadav Elyahu <88962733+nelyahu@users.noreply.github.com> Date: Wed, 29 May 2024 02:42:59 +0300 Subject: [PATCH 4/4] DeepSpeedCheckpoint: support custom final ln idx (#5506) till today only last layer (idx=-1) was considered using FINAL_LAYER_NORM_INDEX which is set to -1. this PR allows the user to pass custom value for model where this default value does not apply. see example for usage in HabanaAI/Megatron-DeepSpeed fork repository: https://github.com/HabanaAI/Megatron-DeepSpeed/blob/c9feb8cacabc6dd4da4266cff08db555a21122e2/tools/verify_checkpoint_non_tp_consistency.py#L296 --------- Co-authored-by: Logan Adams <114770087+loadams@users.noreply.github.com> Co-authored-by: Olatunji Ruwase Co-authored-by: Logan Adams --- deepspeed/checkpoint/deepspeed_checkpoint.py | 28 +++++++++++++------- 1 file changed, 19 insertions(+), 9 deletions(-) diff --git a/deepspeed/checkpoint/deepspeed_checkpoint.py b/deepspeed/checkpoint/deepspeed_checkpoint.py index 8312dddd2fa6..31997177a262 100644 --- a/deepspeed/checkpoint/deepspeed_checkpoint.py +++ b/deepspeed/checkpoint/deepspeed_checkpoint.py @@ -4,6 +4,7 @@ # DeepSpeed Team import os +import re from typing import Dict import torch @@ -21,6 +22,7 @@ ARGS_KEY = 'args' CHECKPOINT_INFO_KEY = 'checkpoint_info' ITERATION_KEY = 'iteration' +LAYER_FILE_PREFIX_PATTERN = r'layer_(\d+)-model_.*' SEQUENTIAL_LAYERS = [ 'input_layernorm.weight', 'input_layernorm.bias', 'self_attention.dense.bias', 'post_attention_layernorm.weight', @@ -32,7 +34,13 @@ class DeepSpeedCheckpoint(object): - def __init__(self, dir, tp_degree=None, pp_degree=None, dp_degree=None): + def __init__(self, + dir, + tp_degree=None, + pp_degree=None, + dp_degree=None, + final_layer_norm_idx=FINAL_LAYER_NORM_INDEX): + self.final_layer_norm_idx = final_layer_norm_idx self.dir = dir pipeline_parallel = len(get_files_with_prefix(get_files(dir), LAYER_FILE_PREFIX)) > 0 @@ -73,7 +81,7 @@ def __init__(self, dir, tp_degree=None, pp_degree=None, dp_degree=None): self.pp_to_transformer_map = self._build_pp_transformer_map() self.transformer_file_map = self._build_transformer_file_map() self.tp_to_embedding_map = self._build_tp_other_layer_map(EMBEDDING_LAYER_INDEX) - self.tp_to_final_norm_map = self._build_tp_other_layer_map(FINAL_LAYER_NORM_INDEX) + self.tp_to_final_norm_map = self._build_tp_other_layer_map(self.final_layer_norm_idx) self._build_global_state() def is_change_tp_degree(self): @@ -125,7 +133,7 @@ def get_embedding_layer_id(self): return self.layer_keys[EMBEDDING_LAYER_INDEX] def get_final_norm_layer_id(self): - return self.layer_keys[FINAL_LAYER_NORM_INDEX] + return self.layer_keys[self.final_layer_norm_idx] def get_iteration(self): if not ITERATION_KEY in self.global_state: @@ -214,7 +222,7 @@ def get_2d_parallel_files(self, tp_index: int, pp_index: int) -> list: def _build_pp_transformer_map(self): data_map = {} if self.pp_degree > 0: - transformer_layers = self.layer_keys[1:-1] + transformer_layers = self.layer_keys[1:self.final_layer_norm_idx] layers_per_pp = len(transformer_layers) // self.pp_degree data_map = { i: transformer_layers[i * layers_per_pp:(i + 1) * layers_per_pp] @@ -229,7 +237,7 @@ def _dump_mapping(self, data_map, map_tag=None): print(f'{k} = {v}') def _build_transformer_file_map(self): - transformer_layer_keys = self.layer_keys[1:-1] + transformer_layer_keys = self.layer_keys[1:self.final_layer_norm_idx] file_map = {} # XXX: this is not guaranteed layers_per_pp = 1 @@ -238,7 +246,7 @@ def _build_transformer_file_map(self): #print(f"{transformer_layer_keys} {layers_per_pp}") for key_index, layer_key in enumerate(transformer_layer_keys): pp_index = key_index // layers_per_pp - layer_files = get_files_with_prefix(self.layer_files, layer_key) + layer_files = get_files_with_prefix(self.layer_files, layer_key + '-') layer_file_partitions = partition_data(layer_files, self.tp_degree) for tp_index in range(self.tp_degree): map_key = (tp_index, pp_index) @@ -263,11 +271,13 @@ def validate_files(self): def _get_layer_keys(self): key_set = set() - key_len = len(LAYER_FILE_PREFIX) + 2 for file_path in self.layer_files: _, fname = os.path.split(file_path) - key_set.add(fname[:key_len]) - return sorted(list(key_set)) + layer_id = re.search(LAYER_FILE_PREFIX_PATTERN, fname).group(1) + key_set.add(layer_id) + sorted_ids = sorted(list(key_set), key=int) + layer_keys = [LAYER_FILE_PREFIX + str(layer_id) for layer_id in sorted_ids] + return layer_keys def _merge_state_dicts(self, sd_list): merged_sd = {}