Accelerator
The Accelerator is the main class provided by π€ Accelerate. It serves at the main entrypoint for the API. To quickly adapt your script to work on any kind of setup with π€ Accelerate just:
- Initialize an Accelerator object (that we will call
accelerator
in the rest of this page) as early as possible in your script. - Pass along your model(s), optimizer(s), dataloader(s) to the prepare() method.
- (Optional but best practice) Remove all the
.cuda()
or.to(device)
in your code and let theaccelerator
handle device placement for you. - Replace the
loss.backward()
in your code byaccelerator.backward(loss)
. - (Optional, when using distributed evaluation) Gather your predictions and labels before storing them or using them for metric computation using gather().
This is all that is needed in most cases. For more advanced cases or a nicer experience here are the functions you
should search for and replace by the corresponding methods of your accelerator
:
print
statements should be replaced by print() to be only printed once per process.- Use
is_local_main_process
for statements that should be executed once per server. - Use
is_main_process
for statements that should be executed once only. - Use wait_for_everyone() to make sure all processes join that point before continuing (useful before a model save for instance).
- Use unwrap_model() to unwrap your model before saving it.
- Use save() instead of
torch.save
. - Use clipgrad_norm() instead of
torch.nn.utils.clip_grad_norm_
and clipgrad_value() instead oftorch.nn.utils.clip_grad_value_
.
To perform gradient accumulation use accumulate() and specify a gradient_accumulation_steps
.
This will also automatically ensure the gradients are synced or unsynced when on multi-device training, check if the step should
actually be performed, and auto-scale the loss:
accelerator = Accelerator(gradient_accumulation_steps=2)
for (input, label) in enumerate(training_dataloader):
with accelerator.accumulate(model):
predictions = model(input)
loss = loss_function(predictions, labels)
accelerator.backward(loss)
optimizer.step()
scheduler.step()
optimizer.zero_grad()
Using this with dispatch_batches=True
(which is the default for iterable datasets) is currently not supported.
class accelerate.Accelerator
< source >( device_placement: bool = True split_batches: bool = False fp16: bool = None mixed_precision: typing.Union[accelerate.utils.dataclasses.PrecisionType, str] = None gradient_accumulation_steps: int = 1 cpu: bool = False deepspeed_plugin: DeepSpeedPlugin = None fsdp_plugin: FullyShardedDataParallelPlugin = None rng_types: typing.Union[typing.List[typing.Union[str, accelerate.utils.dataclasses.RNGType]], NoneType] = None log_with: typing.Union[typing.List[typing.Union[str, accelerate.utils.dataclasses.LoggerType, accelerate.tracking.GeneralTracker]], NoneType] = None logging_dir: typing.Union[str, os.PathLike, NoneType] = None dispatch_batches: typing.Optional[bool] = None step_scheduler_with_optimizer: bool = True kwargs_handlers: typing.Optional[typing.List[accelerate.utils.dataclasses.KwargsHandler]] = None )
Parameters
-
device_placement (
bool
, optional, defaults toTrue
) — Whether or not the accelerator should put objects on device (tensors yielded by the dataloader, model, etc…). -
split_batches (
bool
, optional, defaults toFalse
) — Whether or not the accelerator should split the batches yielded by the dataloaders across the devices. IfTrue
the actual batch size used will be the same on any kind of distributed processes, but it must be a round multiple of thenum_processes
you are using. IfFalse
, actual batch size used will be the one set in your script multiplied by the number of processes. -
mixed_precision (
str
, optional) — Whether or not to use mixed precision training (fp16 or bfloat16). Choose from ‘no’,‘fp16’,‘bf16’. Will default to the value in the environment variableMIXED_PRECISION
, which will use the default value in the accelerate config of the current system or the flag passed with theaccelerate.launch
command. ‘fp16’ requires pytorch 1.6 or higher. ‘bf16’ requires pytorch 1.10 or higher. -
gradient_accumulation_steps (
int
, optional, default to 1) — The number of steps that should pass before gradients are accumulated. A number > 1 should be combined withAccelerator.accumulate
. -
cpu (
bool
, optional) — Whether or not to force the script to execute on CPU. Will ignore GPU available if set toTrue
and force the execution on one process only. -
deepspeed_plugin (
DeepSpeedPlugin
, optional) — Tweak your DeepSpeed related args using this argument. This argument is optional and can be configured directly using accelerate config -
fsdp_plugin (
FullyShardedDataParallelPlugin
, optional) — Tweak your FSDP related args using this argument. This argument is optional and can be configured directly using accelerate config -
rng_types (list of
str
orRNGType
) — The list of random number generators to synchronize at the beginning of each iteration in your prepared dataloaders. Should be one or several of:"torch"
: the base torch random number generator"cuda"
: the CUDA random number generator (GPU only)"xla"
: the XLA random number generator (TPU only)"generator"
: thetorch.Generator
of the sampler (or batch sampler if there is no sampler in your dataloader) or of the iterable dataset (if it exists) if the underlying dataset is of that type.
Will default to
["torch"]
for PyTorch versions <=1.5.1 and["generator"]
for PyTorch versions >= 1.6. -
log_with (list of
str
, LoggerType or GeneralTracker, optional) — A list of loggers to be setup for experiment tracking. Should be one or several of:"all"
"tensorboard"
"wandb"
"comet_ml"
If"all
” is selected, will pick up all available trackers in the environment and intialize them. Can also accept implementations ofGeneralTracker
for custom trackers, and can be combined with"all"
.
-
logging_dir (
str
,os.PathLike
, optional) — A path to a directory for storing logs of locally-compatible loggers. -
dispatch_batches (
bool
, optional) — If set toTrue
, the dataloader prepared by the Accelerator is only iterated through on the main process and then the batches are split and broadcast to each process. Will default toTrue
forDataLoader
whose underlying dataset is anIterableDataset
,False
otherwise. -
step_scheduler_with_optimizer (
bool
, *optional, defaults to
True) -- Set
Trueif the learning rate scheduler is stepped at the same time as the optimizer,
False` if only done under certain circumstances (at the end of each epoch, for instance). -
kwargs_handlers (
List[KwargHandler]
, optional) — A list ofKwargHandler
to customize how the objects related to distributed training or mixed precision are created. See kwargs for more information.
Creates an instance of an accelerator for distributed training (on multi-GPU, TPU) or mixed precision training.
Attributes
- device (
torch.device
) β The device to use. - state (AcceleratorState) β The distributed setup state.
accumulate
< source >( model )
A context manager that will lightly wrap around and perform gradient accumulation automatically
Will apply automatic mixed-precision inside the block inside this context manager, if it is enabled. Nothing different will happen otherwise.
Use accelerator.backward(loss)
in lieu of loss.backward()
.
Alias for Accelerate.free_memory
, releases all references to the internal objects stored and call the
garbage collector. You should call this method between two trainings with different models/optimizers.
Should be used in place of torch.nn.utils.clip_grad_norm_
.
Should be used in place of torch.nn.utils.clip_grad_value_
.
Runs any special end training behaviors, such as stopping trackers
Will release all references to the internal objects stored and call the garbage collector. You should call this method between two trainings with different models/optimizers.
gather
< source >(
tensor
)
β
torch.Tensor
, or a nested tuple/list/dictionary of torch.Tensor
Parameters
-
tensor (
torch.Tensor
, or a nested tuple/list/dictionary oftorch.Tensor
) — The tensors to gather across all processes.
Returns
torch.Tensor
, or a nested tuple/list/dictionary of torch.Tensor
The gathered tensor(s). Note that the first dimension of the result is num_processes multiplied by the first dimension of the input tensors.
Gather the values in tensor across all processes and concatenate them on the first dimension. Useful to regroup the predictions from all processes when doing evaluation.
Note: This gather happens in all processes.
init_trackers
< source >( project_name: str config: typing.Optional[dict] = None )
Initializes a run for all trackers stored in self.log_with
, potentially with starting configurations
load_state
< source >( input_dir: str )
Loads the current states of the model, optimizer, scaler, RNG generators, and registered objects.
Lets the local main process go inside a with block.
The other processes will enter the with block after the main process exits.
log
< source >( values: dict step: typing.Optional[int] = None )
Logs values
to all stored trackers in self.trackers
.
Lets the main process go first inside a with block.
The other processes will enter the with block after the main process exits.
no_sync
< source >( model )
A context manager to disable gradient synchronizations across DDP processes by calling
torch.nn.parallel.DistributedDataParallel.no_sync
.
If model
is not in DDP, this context manager does nothing
pad_across_processes
< source >( tensor dim = 0 pad_index = 0 pad_first = False )
Parameters
-
tensor (nested list/tuple/dictionary of
torch.Tensor
) — The data to gather. -
dim (
int
, optional, defaults to 0) — The dimension on which to pad. -
pad_index (
int
, optional, defaults to 0) — The value with which to pad. -
pad_first (
bool
, optional, defaults toFalse
) — Whether to pad at the beginning or the end.
Recursively pad the tensors in a nested list/tuple/dictionary of tensors from all devices to the same size so they can safely be gathered.
Prepare all objects passed in args
for distributed training and mixed precision, then return them in the same
order.
Accepts the following type of objects:
torch.utils.data.DataLoader
: PyTorch Dataloadertorch.nn.Module
: PyTorch Moduletorch.optim.Optimizer
: PyTorch Optimizer
Use in replacement of print()
to only print once per server.
reduce
< source >(
tensor
reduction = 'sum'
)
β
torch.Tensor
, or a nested tuple/list/dictionary of torch.Tensor
Parameters
-
tensor (
torch.Tensor
, or a nested tuple/list/dictionary oftorch.Tensor
) — The tensors to reduce across all processes. -
reduction (
str
, optional, defaults to “sum”) — A reduction type, can be one of ‘sum’, ‘mean’, or ‘none’. If ‘none’, will not perform any operation.
Returns
torch.Tensor
, or a nested tuple/list/dictionary of torch.Tensor
The reduced tensor(s).
Reduce the values in tensor across all processes based on reduction.
Note: All processes get the reduced value.
Makes note of objects
and will save or load them in during save_state
or load_state
.
These should be utilized when the state is being loaded or saved in the same script. It is not designed to be used in different scripts
Every object
must have a load_state_dict
and state_dict
function to be stored.
Save the object passed to disk once per machine. Use in place of torch.save
.
save_state
< source >( output_dir: str )
Saves the current states of the model, optimizer, scaler, RNG generators, and registered objects.
unscale_gradients
< source >( optimizer = None )
Parameters
-
optimizer (
torch.optim.Optimizer
orList[torch.optim.Optimizer]
, optional) — The optimizer(s) for which to unscale gradients. If not set, will unscale gradients on all optimizers that were passed to prepare().
Unscale the gradients in mixed precision training with AMP. This is a noop in all other settings.
Unwraps the model
from the additional layer possible added by prepare(). Useful before saving
the model.
Will stop the execution of the current process until every other process has reached that point (so this does nothing when the script is only run in one process). Useful to do before saving a model.