其他分享
首页 > 其他分享> > pytorch detach()

pytorch detach()

作者:互联网

https://www.cnblogs.com/wanghui-garcia/p/10677071.html

神经网络的训练有时候可能希望保持一部分的网络参数不变,只对其中一部分的参数进行调整;或者值训练部分分支网络,并不让其梯度对主网络的梯度造成影响,torch.tensor.detach()和torch.tensor.detach_()函数来切断一些分支的反向传播。

返回一个新的Variable,从当前计算图中分离下来的,但是仍指向原变量的存放位置,不同之处只是requires_grad为false,得到的这个Variable永远不需要计算其梯度,不具有grad。

即使之后重新将它的requires_grad置为true,它也不会具有梯度grad

这样我们就会继续使用这个新的Variable进行计算,后面当我们进行反向传播时,到该调用detach()的Variable就会停止,不能再继续向前进行传播

标签:tensor,梯度,torch,pytorch,Variable,detach,grad
来源: https://www.cnblogs.com/h694879357/p/15855025.html