ForEach Optimizer Implementations¶
Like PyTorch, optimi supports foreach implementations of all optimizers. Foreach optimizers can be significantly faster than the for-loop versions.
Deprecation Notice: Foreach optimizers will be removed in a future release
Foreach optimizers are deprecated and will be removed in a future release. They will not receive any new features.
Use optimi’s triton optimizers instead, as they are significantly faster than foreach optimizers.
Foreach implementations can increase optimizer peak memory usage. optimi attempts to reduce this extra overhead by reusing the gradient buffer for temporary variables. If the gradients are required between the optimization step and gradient reset step, set foreach=False to use the for-loop implementation.
Note: Foreach Requires PyTorch 2.1+
optimi’s foreach implementations require PyTorch 2.1 or newer.
If unspecified foreach=None, optimi will use the foreach implementation if training on a Cuda device.
Example¶
To use a foreach implementation set foreach=True when initializing the optimizer.
import torch
from torch import nn
from optimi import AdamW
# create model
model = nn.Linear(20, 1, device="cuda")
# initialize any optmi optimizer with `foreach=True`
opt = AdamW(model.parameters(), lr=1e-3, foreach=True)
# forward and backward
loss = model(torch.randn(20))
loss.backward()
# optimizer step is the foreach implementation
opt.step()
opt.zero_grad()