火炬。当最终张量中有多个值时,可以使用 autograd 吗?
Pytorch. Can autograd be used when the final tensor has more than a single value in it?
当最终张量中有多个值时可以使用autograd吗?
我尝试了以下方法。
x = torch.tensor([4.0, 5.0], requires_grad=True)
y = x ** 2
print(y)
y.backward()
引发错误
RuntimeError: grad can be implicitly created only for scalar outputs
但是以下内容有效。
x = torch.tensor([4.0, 5.0], requires_grad=True)
y = x ** 2
y = torch.sum(y)
print(y)
y.backward()
print(x.grad)
输出为
tensor(41., grad_fn=<SumBackward0>)
tensor([ 8., 10.])
我是不是遗漏了什么,或者我可以继续假设 autograd 仅在最终张量中只有一个值时有效吗?
见https://pytorch.org/tutorials/beginner/blitz/autograd_tutorial.html#gradients
y.backward()
等同于 y.backward(torch.tensor(1.0))
通常,输出是标量,因此标量作为默认选择传递给 backward。但是,由于您的输出是二维的,因此您应该调用
y.backward(torch.tensor([1.0,1.0]))
这将给出预期的结果,x.grad
为 tensor([ 8., 10.])
当最终张量中有多个值时可以使用autograd吗?
我尝试了以下方法。
x = torch.tensor([4.0, 5.0], requires_grad=True)
y = x ** 2
print(y)
y.backward()
引发错误
RuntimeError: grad can be implicitly created only for scalar outputs
但是以下内容有效。
x = torch.tensor([4.0, 5.0], requires_grad=True)
y = x ** 2
y = torch.sum(y)
print(y)
y.backward()
print(x.grad)
输出为
tensor(41., grad_fn=<SumBackward0>)
tensor([ 8., 10.])
我是不是遗漏了什么,或者我可以继续假设 autograd 仅在最终张量中只有一个值时有效吗?
见https://pytorch.org/tutorials/beginner/blitz/autograd_tutorial.html#gradients
y.backward()
等同于 y.backward(torch.tensor(1.0))
通常,输出是标量,因此标量作为默认选择传递给 backward。但是,由于您的输出是二维的,因此您应该调用
y.backward(torch.tensor([1.0,1.0]))
这将给出预期的结果,x.grad
为 tensor([ 8., 10.])