You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

mindspore.nn.ForwardValueAndGrad.rst 1.6 kB

4 years ago
4 years ago
123456789101112131415161718192021222324252627
  1. mindspore.nn.ForwardValueAndGrad
  2. ===================================
  3. .. py:class:: mindspore.nn.ForwardValueAndGrad(network, weights=None, get_all=False, get_by_list=False, sens_param=False)
  4. 训练网络的封装。
  5. 包括正向网络和梯度函数。该类生成的Cell使用'\*inputs'输入来训练。
  6. 通过梯度函数来创建反向图,用以计算梯度。
  7. **参数:**
  8. - **network** (Cell) - 训练网络。
  9. - **weights** (ParameterTuple) - 训练网络中需要计算梯度的的参数。
  10. - **get_all** (bool) - 如果为True,则计算网络输入对应的梯度。默认值:False。
  11. - **get_by_list** (bool) - 如果为True,则计算参数变量对应的梯度。如果 `get_all` 和 `get_by_list` 都为False,则计算第一个输入对应的梯度。如果 `get_all` 和 `get_by_list` 都为True,则以((输入的梯度),(参数的梯度))的形式同时获取输入和参数变量的梯度。默认值:False。
  12. - **sens_param** (bool) - 是否将sens作为输入。如果 `sens_param` 为False,则sens默认为'ones_like(outputs)'。默认值:False。如果 `sens_param` 为True,则需要指定sens的值。
  13. **输入:**
  14. - **(\*inputs)** (Tuple(Tensor...)):shape为 :math:`(N, \ldots)` 的输入tuple。
  15. - **(sens)**:反向传播梯度的缩放值。如果网络有单个输出,则sens是tensor。如果网络有多个输出,则sens是tuple(tensor)。
  16. **输出:**
  17. - **forward value** - 网络运行的正向结果。
  18. - **gradients** (tuple(tensor)) - 网络反向传播的梯度。