onunix 2023-02-11 22:08 采纳率: 78.9%
浏览 81
已结题

请教一下torch.autograd.grad(y,x,create_graph=True)[0]这里的[0]是什么意思?

请教一下pytorch的这段代码里:torch.autograd.grad(y,x,create_graph=True)[0],这里

import numpy as np 
import torch 

# f(x) = a*x**2 + b*x + c的导数

x = torch.tensor(0.0,requires_grad = True) # x需要被求导
a = torch.tensor(1.0)
b = torch.tensor(-2.0)
c = torch.tensor(1.0)
y = a*torch.pow(x,2) + b*x + c


# create_graph 设置为 True 将允许创建更高阶的导数 
dy_dx = torch.autograd.grad(y,x,create_graph=True)[0]
print(dy_dx.data)

# 求二阶导数
dy2_dx2 = torch.autograd.grad(dy_dx,x)[0] 

print(dy2_dx2.data)

请问 torch.autograd.grad(y,x,create_graph=True)[0],这里为什么有[0] ? 既然可以[0],那么 torch.autograd.grad(y,x,create_graph=True)[1]又表示什么呢?

  • 写回答

5条回答 默认 最新

  • 元气少女缘结神 2023-02-11 23:20
    关注

    的确,都说torch.autograd.grad返回的是第一参数对第二个参数的导数,一般是网络中的梯度,为什么都只取[0],我也要去看下笔记查下。这一维度的具体意义

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 2月20日
  • 已采纳回答 2月12日
  • 创建了问题 2月11日

悬赏问题

  • ¥15 fluent里模拟降膜反应的UDF编写
  • ¥15 MYSQL 多表拼接link
  • ¥15 关于某款2.13寸墨水屏的问题
  • ¥15 obsidian的中文层级自动编号
  • ¥15 同一个网口一个电脑连接有网,另一个电脑连接没网
  • ¥15 神经网络模型一直不能上GPU
  • ¥15 pyqt怎么把滑块和输入框相互绑定,求解决!
  • ¥20 wpf datagrid单元闪烁效果失灵
  • ¥15 券商软件上市公司信息获取问题
  • ¥100 ensp启动设备蓝屏,代码clock_watchdog_timeout