pytorch 中一个变量被detach()后,这个变量生成的其他变量还存在梯度的验证

对比学习中,simsiam用到了z变量停止梯度回传,z变量生成的变量p存在梯度,验证如下(鬼知道我为什么要验证。。):

import torch
import torch.nn as nn

def f(x):
    return x + 1.

def h(z):
    return z + 1.

def d(p,z):
    z = z.detach()
    return -(p*z).sum(dim=1).mean()

def save_grad(name):
    def hook(grad):
        grads[name] = grad
    return hook

if __name__ == '__main__':
    grads = {}

    x = torch.tensor([[2.,4,6],
                      [1,3,5]],requires_grad=True)
    x1 = x.sigmoid()
    x2 = x.relu()
    print(x1,x2)

    z1 = f(x1)
    z2 = f(x2)

    p1 = h(z1)
    p2 = h(z2)

    p1.register_hook(save_grad('p1'))
    z1.register_hook(save_grad('z1'))
    l = d(p1,z1) * 0.5 + d(p2,z2) * 0.5
    z2.register_hook(save_grad('z2'))
    # p2 = p2.detach()
    # p2.register_hook(save_grad('p2'))

    # print(x.grad,x1.grad,z1
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值