当前位置: 首页 > news >正文

网站建设选哪家好查询收录

网站建设选哪家好,查询收录,学生登录入口,网站设计是不是会要用代码做同学你好#xff01;本文章于2021年末编写#xff0c;获得广泛的好评#xff01; 故在2022年末对本系列进行填充与更新#xff0c;欢迎大家订阅最新的专栏#xff0c;获取基于Pytorch1.10版本的理论代码(2023版)实现#xff0c; Pytorch深度学习理论篇(2023版)目录地址…  同学你好本文章于2021年末编写获得广泛的好评 故在2022年末对本系列进行填充与更新欢迎大家订阅最新的专栏获取基于Pytorch1.10版本的理论代码(2023版)实现 Pytorch深度学习·理论篇(2023版)目录地址为 CSDN独家 | 全网首发 | Pytorch深度学习·理论篇(2023版)目录本专栏将通过系统的深度学习实例从可解释性的角度对深度学习的原理进行讲解与分析通过将深度学习知识与Pytorch的高效结合帮助各位新入门的读者理解深度学习各个模板之间的关系这些均是在Pytorch上实现的可以有效的结合当前各位研究生的研究方向设计人工智能的各个领域是经过一年时间打磨的精品专栏https://v9999.blog.csdn.net/article/details/127587345欢迎大家订阅(2023版)理论篇 以下为2021版原文~~~~ 1 Variable类型与自动微分模块概述 1.1 Variable类型 Variable是由Autograd模块对张量进行进一步封装实现的具有自动求导的功能 1.2 Autograd模块(自动求导模块) Autograd模块在神经网络的反向传播中基于正向计算的结果进行微分计算从而实现对于网络权重的更新与迭代提供了张量的自动求微分功能可以通过代码来实现对反向过程的控制使得权重参数朝着目标结果进行更新与发展。 2 Variable类型与自动微分模块实战 2.1 Variable类型对象与张量对象之间的转化 2.1.1 代码实现 import torch from torch.autograd import Variablea torch.FloatTensor([4]) #创建张量 print(Variable(a)) # 将张量转化为Variable对象 # 输出 tensor([4.]) print(Variable(a,requires_gradTrue)) # requires_grad允许自动求导 # 输出 tensor([4.], requires_gradTrue) print(a.data) #将Variable对象转化为张量 # 输出 tensor([4.]) 2.1.2 注意 import torch from torch.autograd import Variable### 使用requires_grad时要求张量的值必须为浮点型 x torch.tensor([1],requires_gradTrue) #报错 x torch.tensor([1.],requires_gradTrue) #正确写法2.2 torch.no_grad() 2.2.1 概述 torch.no_grad()使Variable类型变量的requires_grad失效 torch.enable_grad()使Variable类型变量的requires_grad有效 2.2.2 使用torch.no_grad()配合with语句限制requires_grad的作用域 import torch from torch.autograd import Variablex torch.ones(2,2,requires_gradTrue) # 定义一个需要梯度计算的Variable类型对象 with torch.no_grad():y x * 2 print(y.requires_grad) # 输出 False2.2.3 使用装饰器实现 import torch from torch.autograd import Variable### 在神经网络中将网络模型进行封装使用装饰器方便实现开发的便捷性x torch.ones(2,2,requires_gradTrue) # 定义一个需要梯度计算的Variable类型对象 torch.no_grad() def doubler(x):return x * 2 z doubler(x) print(z.requires_grad) # 输出 False 2.3 函数enable_grad()与no_grad()的嵌套使用 2.3.1 enable_grad()配合with语句限制requires_grad的作用域 import torch x torch.ones(2,2,requires_gradTrue) # 定义一个需要梯度计算的Variable类型对象 with torch.no_grad():with torch.enable_grad():y x * 2print(y.requires_grad) # Trueprint(y.requires_grad) # True print(y.requires_grad) # True 2.3.2 使用enable_grad装饰器 import torch x torch.ones(2,2,requires_gradTrue) # 定义一个需要梯度计算的Variable类型对象 torch.enable_grad() def doubler(x): #封装到函数中return x * 2 with torch.no_grad(): #使得计算梯度失效z doubler(x) print(z.requires_grad) #True 2.3.3 作用在没有requires_grad的Variable类型变量上将会失效不能使其重新获得计算梯度的属性 import torch x torch.ones(2,2) # 定义一个不需要梯度计算的Variable类型对象 with torch.enable_grad():y x * 2 print(y.requires_grad) # False 2.3 set_grad_enabled()实现统一管理梯度计算 import torch x torch.ones(2,2,requires_gradTrue) # 定义一个需要梯度计算的Variable类型对象 torch.set_grad_enabled(False) # 统一关闭梯度计算 y x * 2 print(y.requires_grad) # False torch.set_grad_enabled(True) # 统一开启梯度计算 y x * 2 print(y.requires_grad) # True 2.4 Variable类型对象的grad_fn属性 2.4.1 grad_fn属性概述 Variable类型对象在经过前向传播后将会增加一个grad_fn属性该属性随着backward()方法进行自动的梯度计算。没有经过计算的Variable类型对象是没有这个属性的在requires_gradFalse的情况下无论如何计算他都不会有grad_fn属性。 2.4.2 grad_fn属性代码实现 import torch from torch.autograd import Variablex Variable(torch.ones(2,2),requires_gradTrue) print(x) # 输出 tensor([[1., 1.],[1., 1.]], requires_gradTrue) print(x.grad_fn) # 输出 Nonem x 2 # 经过正向计算获得grad_fn属性 print(m.grad_fn) # 输出 AddBackward0 object at 0x0000024E1AA14D00 print(m.grad_fn(x)) #对x变量进行求梯度计算 # 输出 (tensor([[1., 1.],[1., 1.]], requires_gradTrue), None)x2 torch.ones(2,2) # 创建一个不需要梯度计算的张量 m x2 2 print(m.grad_fn) # 输出 None 2.5 Variable类型对象的is_leaf函数 2.5.1 is_leaf()概述 1、定义Variable类型对象时若将requires_grad设为True则将该Variable类型对象称为种子节点其 is_leaf的属性为True。 2、若Variable类型对象不是通过自定义生成的而是通过其他张量计算所得时则不是叶子节点则该该Variable类型对象称为叶子节点其 is_leaf的属性为False。 3、Pytorch会记录每个张量的由来由此来在内存中行程树状结构实现反向链式计算叶子节点主要在求导过程为递归循环提供信号指示当反向链式计算遇到叶子节点则终止递归循环。 2.5.2 is_leaf()代码 import torch from torch.autograd import Variablex Variable(torch.ones(2,2),requires_gradTrue) print(x.is_leaf) # True m x 2 print(m.is_leaf) # False 2.6 backward()实现自动求导 2.6.1 backward()概述 backward()必须在当前变量内容是标量的情况下使用否则会报错。 2.6.3 自动求导的作用 从复杂的神经网络中自动将每一层中的每个参数的梯度计算出来实现训练过程中的反向传播。 2.6.2 代码 import torch from torch.autograd import Variable### y (x 2)/4 x Variable(torch.ones(2,2),requires_gradTrue) m x 2 f m.mean() #得到一个标量 f.backward() # 自动求导 print(f) #输出 tensor(3., grad_fnMeanBackward0) print(x.grad) # 输出 tensor([[0.2500, 0.2500],[0.2500, 0.2500]]) 2.7 detach()将Variable类型对象分离成种子节点 2.7.1 将需要求梯度的Variable类型对象转化为Numpy对象 import torch from torch.autograd import Variable### 如果被分离的Variable对象的volatile属性为True那么被分离出的volatile属性也为True ### 被返回的Variable对象和被分离的Variable对象指向同一个张量并且永远不会需要梯度 x Variable(torch.ones(2,2),requires_gradTrue) # x.numpy() # 报错Cant call numpy() on Tensor that requires grad. Use tensor.detach().numpy() instead. x1 x.detach().numpy() print(x1)# 输出 [[1.,1.],[1.,1.]] 2.7.2 实现对网络中的部分参数求梯度 2.8 volatile属性 早期代码中可以通过设置Variable类型对象的volatile属性为True的方法来实现停止梯度更新。
http://www.pierceye.com/news/899100/

相关文章:

  • 西安烽盈网站建设郑州营销网站托管
  • 诸几建设银行网站怎么维护好网站
  • 深圳市国外网站建设简单html5网页设计
  • 网站制作公司西南城乡建设部网站首页
  • 网站名和域名能一样吗企业网站建设硬件
  • 德州做网站公司怎么开网店淘宝
  • 苏州做网站优化的电商定制开发
  • 广西庆海建设发展有限公司网站昆山有做网站的公司吗
  • 前端课程网站wordpress 微博登陆
  • asp怎么做网站适配开发公司安置房项目工程推进大会
  • 学做网站可以赚钱吗怎么批量修改wordpress文章内容
  • 写作网站vir上海博大园林建设发展有限公司网站
  • wordpress video gallery网站代码优化怎么做
  • 厦门网站设计品牌企业互联网门户网站建设
  • 做名片模板网站中文响应式网站
  • 用tornado做网站石家庄 外贸网站建设公司
  • 档案网站建设网页wordpress keyshot
  • 鞍山制作网站哪家好建设银行员工网站
  • 手机怎么提升网站流量品牌型网站成功案例图片
  • 网站视频主持人制作网站开发 质量管理
  • 网站的外链建设计划石家庄市城乡建设部网站
  • 电子商务网站规划与建设论文电子商务营销方法
  • 宁波做网站费用电子商城开发网站开发
  • 太原市住房和城乡建设部网站免费的logo在线设计
  • 做it的在哪个网站找工作wordpress 幻燈片 插件
  • 湘潭做网站 i磐石网络博学网站建设公司
  • 揭阳市建设发展总公司网站自己做的视频网站如何赚钱
  • 泉州自助建站软件天眼查在线查询官网
  • 网站建设书模板校本教研网站建设方案
  • 经销商自己做网站合适吗彩虹网站建设