zoukankan      html  css  js  c++  java
  • 深度学习_梯度

    1.梯度裁剪

      在BP过程中会产生梯度消失(就是偏导无限接近0,导致长时记忆无法更新)(特别是RNN,LSTM,Transformer),那么最简单粗暴的方法,设定阈值,当梯度小于阈值时,更新的梯度为阈值,如下图所示:

      

             优点:简单粗暴
        缺点:很难找到满意的阈值

     2.nn.utils.clip_grad_norm(parameters, max_norm, norm_type=2)

      这个函数是根据参数的范数来衡量的 . 通过梯度范数,来实现裁剪

       所有梯度上范数在一起计算,就好像它们被连接成一个向量。 梯度内置就地修改。

      Parameters:

      • parameters (Iterable[Variable]) – 一个基于变量的迭代器,会进行归一化(原文:an iterable of Variables that will have gradients normalized)
      • max_norm (float or int) – 梯度的最大范数(原文:max norm of the gradients)
      • norm_type(float or int) – 规定范数的类型,默认为L2(原文:type of the used p-norm. Can be'inf'for infinity norm)
      • error_if_nonfinite (bool) – 如果真,如果来自 :attr:parameters is naninf, or -inf. 的梯度的总范数,则会引发错误 。默认是False(将来会改为True)

      Returns:参数的总体范数(作为单个向量来看)(原文:Total norm of the parameters (viewed as a single vector).)

          

  • 相关阅读:
    没有人可以阻碍我前进的脚步 , 遇佛杀佛,遇魔杀魔
    1/2 2008
    错过,用心
    公会平台
    久违的、讨厌的感觉
    CSS选择符
    jquery ajax
    2013年职业规划
    js小助手
    css 伪类
  • 原文地址:https://www.cnblogs.com/PiaoLingJiLu/p/14925998.html
Copyright © 2011-2022 走看看