apex_amp.py 1.07 KB
Newer Older
Frank Lee's avatar
Frank Lee committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#!/usr/bin/env python
# -*- encoding: utf-8 -*-

import torch.nn as nn
try:
    import apex.amp as apex_amp
except:
    pass
from torch import Tensor

from colossalai.nn.optimizer import ColossalaiOptimizer
from colossalai.utils import clip_grad_norm_fp32


class ApexAMPOptimizer(ColossalaiOptimizer):
HELSON's avatar
HELSON committed
16
    """ A wrapper class for APEX optimizer and it implements apex-specific backward and clip_grad_norm
17
    methods
HELSON's avatar
HELSON committed
18
    """
Frank Lee's avatar
Frank Lee committed
19
20

    def backward(self, loss: Tensor):
HELSON's avatar
HELSON committed
21
22
23
        """Backward pass to get all gradients

        :param loss: Loss computed by a loss function
24
25
        :type loss: torch.Tensor
        """
Frank Lee's avatar
Frank Lee committed
26
27
28
29
        with apex_amp.scale_loss(loss, self.optim) as scaled_loss:
            scaled_loss.backward()

    def clip_grad_norm(self, model: nn.Module, max_norm: float):
HELSON's avatar
HELSON committed
30
31
32
        """Clip gradients' norm

        :param model: Your model object
33
        :type model: torch.nn.Module
HELSON's avatar
HELSON committed
34
        :param max_norm: The max norm value for gradient clipping
35
36
        :type max_norm: float
        """
Frank Lee's avatar
Frank Lee committed
37
38
        if max_norm > 0:
            clip_grad_norm_fp32(apex_amp.master_params(self.optim), max_norm)