Skip to content

Commit

Permalink
Disable distopt contiguous param buffer by default (#7095)
Browse files Browse the repository at this point in the history
Signed-off-by: Tim Moon <tmoon@nvidia.com>
  • Loading branch information
timmoon10 authored Jul 25, 2023
1 parent 5a5c77a commit eb5983a
Showing 1 changed file with 4 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ class MegatronBaseModel(NLPModel):
- Initialize the model parallel world for nemo.
- Turn on all of the nvidia optimizations.
- If `cfg.tokenizer` is available, it loads the tokenizer and pad the vocab to the
- If `cfg.tokenizer` is available, it loads the tokenizer and pad the vocab to the
correct size for tensor model parallelism.
- If using distributed optimizer, configure to be compatible
with O2 level optimizations and/or model parallelism.
Expand Down Expand Up @@ -405,9 +405,8 @@ def setup_optimization(
optim_kwargs = {} if optim_kwargs is None else optim_kwargs.copy()
if self.with_distributed_adam:

# Allocate contiguous buffers to avoid extra copies
# Allocate contiguous buffer to avoid extra copies
optim_kwargs['contiguous_grad_buffer'] = True
optim_kwargs['contiguous_param_buffer'] = True

# Make sure optimizer state is in FP32
optim_dtype = torch.float32
Expand Down Expand Up @@ -507,7 +506,8 @@ def configure_optimizers(self):
self._optimizer.init_params(reversed(no_overlap_params))

# Initialize contiguous parameter buffer
self._optimizer.init_param_buffer()
if self._optimizer.contiguous_param_buffer:
self._optimizer.init_param_buffer()

if self._scheduler is None:
return self._optimizer
Expand Down

0 comments on commit eb5983a

Please sign in to comment.