快捷方式

torch.autograd.graph.Node.register_hook

abstract Node.register_hook(fn)[源代码][源代码]

注册一个反向钩子。

每次计算相对于 Node 的梯度时,都会调用该钩子。钩子应具有以下签名

hook(grad_inputs: Tuple[Tensor], grad_outputs: Tuple[Tensor]) -> Tuple[Tensor] or None

钩子不应修改其参数,但可以选择返回一个新梯度,该梯度将代替 grad_inputs 使用。

此函数返回一个带有 handle.remove() 方法的句柄,该方法从模块中删除钩子。

注意

有关此钩子的执行时间以及其相对于其他钩子的执行顺序的更多信息,请参见反向钩子执行

注意

在极少数情况下,当 Node 已经开始执行时注册钩子,则不再保证 grad_outputs 的内容(它可能像往常一样,也可能为空,具体取决于其他因素)。钩子仍然可以选择返回一个新梯度,以代替 grad_inputs 使用,而与 grad_outputs 无关。

示例

>>> import torch
>>> a = torch.tensor([0., 0., 0.], requires_grad=True)
>>> b = a.clone()
>>> assert isinstance(b.grad_fn, torch.autograd.graph.Node)
>>> handle = b.grad_fn.register_hook(lambda gI, gO: (gO[0] * 2,))
>>> b.sum().backward(retain_graph=True)
>>> print(a.grad)
tensor([2., 2., 2.])
>>> handle.remove() # Removes the hook
>>> a.grad = None
>>> b.sum().backward(retain_graph=True)
>>> print(a.grad)
tensor([1., 1., 1.])
返回类型

RemovableHandle

文档

访问 PyTorch 的全面开发者文档

查看文档

教程

获取面向初学者和高级开发者的深度教程

查看教程

资源

查找开发资源并获得问题解答

查看资源