自动微分
分离计算
有时,我们希望[将某些计算移动到记录的计算图之外]。 例如,假设y
是作为x
的函数计算的,而z
则是作为y
和x
的函数计算的。 想象一下,我们想计算z
关于x
的梯度,但由于某种原因,希望将y
视为一个常数, 并且只考虑到x
在y
被计算后发挥的作用。
这里可以分离y
来返回一个新变量u
,该变量与y
具有相同的值, 但丢弃计算图中如何计算y
的任何信息。 换句话说,梯度不会向后流经u
到x
。 因此,下面的反向传播函数计算z=u*x
关于x
的偏导数,同时将u
作为常数处理, 而不是z=x*x*x
关于x
的偏导数。
这里的y.detach()本质上是并不是把y这个变量的计算过程移出计算图,而是创造一个新的变量u来接收一个与y数值相同,但是不在y所在的计算图中的变量。意味着即使我们对y.detach()后,如果我们直接用z=y*x去计算x的梯度,结果就是y仍然参与了x的梯度计算。结果如下: