pytorch中Variable的自动求导

日期:2020-2-11
作者:老李

pytorch中variable这个变量具有自动求导功能,只需要在参数列表中加入

requires_grad = True

举个例子

我们如下定义:

我们对矩阵进行简单的求导 v a r = [ 1 2 3 4 ] var = \begin{bmatrix} 1 & 2 \\ 3 & 4 \end{bmatrix} var=[1324]
我们对该矩阵平方的均值进行求导,从而有如下的表达

v_out = 1/4*sum(var*var)#4个元素
#从而我们有
d(v_out)/d(var) = 1/4*2*variable = variable/2

完整代码如下

# variable
from torch.autograd import Variable
tensor = torch.FloatTensor([[1,2],[3,4]])
variable = Variable(tensor, requires_grad = True)
t_out = torch.mean(tensor*tensor)  # x^2
v_out = torch.mean(variable*variable)
print(t_out)
print(v_out)
# v_out = 1/4*sum(var*var)
# d(v_out)/d(var) = 1/4*2*variable = variable/2
v_out.backward()
print(variable.grad)
print(variable.data)
print(variable.data.numpy())

最后也可以以np.array的形式输出,用到了variable中data的属性

结果如下
在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值