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

请教一下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日

悬赏问题

  • ¥30 关于#java#的问题,请各位专家解答!
  • ¥30 vue+element根据数据循环生成多个table,如何实现最后一列 平均分合并
  • ¥20 pcf8563时钟芯片不启振
  • ¥20 pip2.40更新pip2.43时报错
  • ¥15 换yum源但仍然用不了httpd
  • ¥50 C# 使用DEVMOD设置打印机首选项
  • ¥15 麒麟V10 arm安装gdal
  • ¥20 OPENVPN连接问题
  • ¥15 flask实现搜索框访问数据库
  • ¥15 mrk3399刷完安卓11后投屏调试只能显示一个设备