栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

torch.nn.utils.clip

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

torch.nn.utils.clip

torch.nn.utils.clip_grad_norm_()函数详解 torch.nn.utils.clip_grad_norm(parameters, max_norm, norm_type=2)
  • 这个函数的主要目的是对   p a r a m e t e r s parameters  parameters里的所有参数的梯度进行规范化;
  •   p a r a m e t e r s parameters  parameters为要规范的参数,   m a x _ n o r m max_norm  max_norm为所有参数的梯度的范数的上界,   n o r m _ t y p e norm_type  norm_type为范数的类型,当   n o r m _ t y p e = i n f norm_type=inf  norm_type=inf时,代表无穷范数;
  • 设   p a r a m e t e r s parameters  parameters里所有参数的梯度的范数为   t o t a l _ n o r m total_norm  total_norm,
    若   m a x _ n o r m > t o t a l _ n o r m , max_norm > total_norm,  max_norm>total_norm,   p a r a m e t e r s parameters  parameters里面的参数的梯度不做改变;
    若   m a x _ n o r m < t o t a l _ n o r m , max_norm < total_norm,  max_norm
  • 附上源码:(注意源码中的这句话"The norm is computed over all gradients together"——计算所有梯度的范数)
def clip_grad_norm_(parameters, max_norm, norm_type=2):
    r"""Clips gradient norm of an iterable of parameters.
    The norm is computed over all gradients together, as if they were
    concatenated into a single vector. Gradients are modified in-place.
    Arguments:
        parameters (Iterable[Tensor] or Tensor): an iterable of Tensors or a
            single Tensor that will have gradients normalized
        max_norm (float or int): max norm of the gradients
        norm_type (float or int): type of the used p-norm. Can be ``'inf'`` for
            infinity norm.
    Returns:
        Total norm of the parameters (viewed as a single vector).
    """
    if isinstance(parameters, torch.Tensor):
        parameters = [parameters]
    #第一步
    parameters = list(filter(lambda p: p.grad is not None, parameters))
    max_norm = float(max_norm)
    norm_type = float(norm_type)
    if norm_type == inf:
        total_norm = max(p.grad.data.abs().max() for p in parameters)
    else:
        total_norm = 0
        for p in parameters:
        	#第二步
            param_norm = p.grad.data.norm(norm_type)
            #第三步
            total_norm += param_norm.item() ** norm_type
        total_norm = total_norm ** (1. / norm_type)
    clip_coef = max_norm / (total_norm + 1e-6)
    if clip_coef < 1:
        for p in parameters:
            p.grad.data.mul_(clip_coef)
    return total_norm
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/657727.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号