3、自动微分(求导、梯度)

x经过某些运算得到1个y,那么就出现了dy/dx,以及x→y的映射(y是如何由x运算得到的)。

dy/dx的获得需两步:y.backward() 、x.grad,即反向传播、求出梯度

x→y的映射,是Tensor对象的一个属性grad_fn:y.grad_fn

注意,反向传播会累加梯度,所以反向传播之前应该梯度清零

复制代码
x=t.ones(2,2,requires_grad=True) #跟踪在x上的所有运算操作
y=x.sum() # 4. 注意y只有1个标量
y.grad_fn #y是由什么运算得到的,SumBackward0 at 0x2598370d948
#y对x微分,即梯度dy/dx
y.backward() #反向传播
print(x.grad) #输出梯度
#反向传播会累加梯度,所以反向传播之前应该梯度清零
y.backward() 
print(x.grad) #输出梯度
y.backward() 
print(x.grad) #输出梯度
#梯度清零
x.grad.zero_()
y.backward() #反传
print(x.grad) #输出梯度
复制代码

 

 

posted @   夕西行  阅读(488)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2019-04-03 SQL Server数据库中表的查
2019-04-03 SQL Server数据库中表的增、删、改
2019-04-03 连接SQL Server数据库
点击右上角即可分享
微信分享提示