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

PyTorch基本使用-自动微分模块

学习目的:掌握自动微分模块的使用

训练神经网络时,最常用的算法就是反向传播。在该算法中,参数(模型权重)会根据损失函数关于对应参数的梯度进行调整。为了计算这些梯度,PyTorch 内置了名为 torch.autograd的微分引擎。它支持任意计算图的自动梯度计算:
在这里插入图片描述

接下来我们使用这个结构进行自动微分模块的介绍。我们使用 backward 方法、grad 属性来实现梯度的计算和访问。

  • 当X为标量时梯度的计算

    import torch
    # 1. 当X为标量时梯度的计算
    def test01():x = torch.tensor(5)# 目标值y = torch.tensor(0.)# 设置要更新的权重和偏置的初始值w = torch.tensor(1.0,requires_grad=True,dtype=torch.float32)b = torch.tensor(3.0,requires_grad=True,dtype=torch.float32)#设置网络的输出值z = x*w + b #矩阵乘法# 设置损失函数,并进行损失计算loss = torch.nn.MSELoss()loss = loss(z,y)# 自动微分loss.backward()# 打印w,b变量的梯度# backward 函数计算的梯度值会存储在张量的grad 变量中print('W的梯度:',w.grad)print('B的梯度:',b.grad)test01()
    

    输出结果:

    W的梯度: tensor(80.)
    B的梯度: tensor(16.)
    
  • 当X为多维张量时梯度计算

    import torch
    def test02():# 输入张量 2*5x = torch.ones(2,5)# 目标张量 2*3y = torch.zeros(2,3)# 设置要更新的权重和偏置的初始值w = torch.randn(5,3,requires_grad=True)b = torch.randn(3,requires_grad=True)#设置网络的输出值z = torch.matmul(x,w)+ b #矩阵乘法# 设置损失函数,并进行损失计算loss = torch.nn.MSELoss()loss = loss(z,y)# 自动微分loss.backward()# 打印w,b变量的梯度# backward 函数计算的梯度值会存储在张量的grad 变量中print('W的梯度:',w.grad)print('B的梯度:',b.grad)test02()
    

    输出结果:

    W的梯度: tensor([[-1.7502,  0.8537,  0.6175],[-1.7502,  0.8537,  0.6175],[-1.7502,  0.8537,  0.6175],[-1.7502,  0.8537,  0.6175],[-1.7502,  0.8537,  0.6175]])
    B的梯度: tensor([-1.7502,  0.8537,  0.6175])
    

相关文章:

PyTorch基本使用-自动微分模块

学习目的:掌握自动微分模块的使用 训练神经网络时,最常用的算法就是反向传播。在该算法中,参数(模型权重)会根据损失函数关于对应参数的梯度进行调整。为了计算这些梯度,PyTorch 内置了名为 torch.autogra…...

libevent-Reactor设计模式【1】

一、Libevent概述 1、简介 Libevent 是一个用C语言编写的、轻量级的开源高性能事件通知库,主要有以下几个亮点:事件驱动( event-driven),高性能;轻量级,专注于网络,不如 ACE 那么臃肿庞大&#…...

奇奇怪怪的错误-Tag和space不兼容

报错信息如下: TabError: inconsistent use of tabs and spaces in indentation make: *** [Makefile:24: train] Error 1不能按Tab,要老老实实按space 不过可以在编辑器里面改,把它们调整成一致的;...

29.攻防世界ics-06

ics-06 难度:1 方向:Web 题目描述: 云平台报表中心收集了设备管理基础服务的数据,但是数据被删除了,只有一处留下了入侵者的痕迹。 进入靶场 发现有一处能点动 多了个id1 我其实尝试改过id数,不过没什么变化&#xf…...

强化学习路径规划:基于SARSA算法的移动机器人路径规划,可以更改地图大小及起始点,可以自定义障碍物,MATLAB代码

一、SARSA算法概述 SARSA(State-Action-Reward-State-Action)是一种在线强化学习算法,用于解决决策问题,特别是在部分可观测的马尔可夫决策过程(POMDPs)中。SARSA算法的核心思想是通过与环境的交互来学习一…...

【MFC】如何读取rtf文件并进行展示

tf是微软的一个带格式的文件,比word简单,我们可以用写字板等程序打开编辑。下面以具体实例讲解如何在自己程序中展示rtf文件。 首先使用VS2022创建一个MFC的工程。 VIEW类需要选择richview类,用于展示,如下图: 运行效…...

Vulhub:Log4j[漏洞复现]

CVE-2017-5645(Log4j反序列化) 启动靶场环境 docker-compose up -d 靶机IPV4地址 ifconfig | grep eth0 -A 5 ┌──(root㉿kali)-[/home/kali/Desktop/temp] └─# ifconfig | grep eth0 -A 5 eth0: flags4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 in…...

面向预测性维护的TinyML技术栈全面综述

论文标题&#xff1a;A Holistic Review of the TinyML Stack for Predictive Maintenance&#xff08;面向预测性维护的TinyML技术栈全面综述&#xff09; 作者信息&#xff1a;Emil Njor, Mohammad Amin Hasanpour, Jan Madsen, Xenofon Fafoutis&#xff0c;均来自丹麦技术…...

沈阳理工大学《2024年811自动控制原理真题》 (完整版)

本文内容&#xff0c;全部选自自动化考研联盟的&#xff1a;《沈阳理工大学811自控考研资料》的真题篇。后续会持续更新更多学校&#xff0c;更多年份的真题&#xff0c;记得关注哦~ 目录 2024年真题 Part1&#xff1a;2024年完整版真题 2024年真题...

用前端html如何实现2024烟花效果

用HTML、CSS和JavaScript编写的网页&#xff0c;主要用于展示“2024新年快乐&#xff01;”的文字形式烟花效果。下面是对代码主要部分的分析&#xff1a; HTML结构 包含三个<canvas>元素&#xff0c;用于绘制动画。引入百度统计的脚本。 CSS样式 设置body的背景为黑…...

Redis应用-在用户数据里的应用

1.社区电商的业务闭环 接下来介绍的社区电商是以Redis作为主体技术、以MySQL和RocketMQ作为辅助技术实现的。 (1)社区电商运作模式 社区电商的关键点在于社区,而电商则是辅助性质(次要地位,流量变现)。社区可以分成很多种社区,比如美食社区、美妆社区、影评社区、妈妈社区…...

C++ 中面向对象编程如实现数据隐藏

在C中&#xff0c;面向对象编程&#xff08;OOP&#xff09;通过封装&#xff08;Encapsulation&#xff09;来实现数据隐藏。封装是OOP的一个核心概念&#xff0c;它允许将对象的属性和行为&#xff08;即数据和方法&#xff09;组合在一起&#xff0c;并对外隐藏对象的内部实…...

JavaEE 【知识改变命运】04 多线程(3)

文章目录 多线程带来的风险-线程安全线程不安全的举例分析产出线程安全的原因&#xff1a;1.线程是抢占式的2. 多线程修改同一个变量&#xff08;程序的要求&#xff09;3. 原子性4. 内存可见性5. 指令重排序 总结线程安全问题产生的原因解决线程安全问题1. synchronized关键字…...

gz中生成模型

生成模型 通过服务调用生成 还记得parameter_bridge 吗&#xff1f; 我们在生成桥接的时候调用了这个cpp文件。 一个 parameter_bridge 实例用于消息传递&#xff08;传感器数据&#xff09;。之前的例子 另一个 parameter_bridge 实例用于服务桥接&#xff08;动态生成模型…...

前端(Axios和Promis)

Promise 语法 <script>// 创建promise对象// 此函数需要再传入两个参数,都是函数类型let pnew Promise((resolve,reject)>{if(3>2){resolve({name:"李思蕾",age:23,地址:"河南省"});}else{reject("error");}});console.log(p);p.th…...

AI Agent:重塑业务流程自动化的未来力量(2/30)

《AI Agent&#xff1a;重塑业务流程自动化的未来力量》 摘要&#xff1a;整体思路是先介绍 AI Agent 的基本情况&#xff0c;再深入阐述其实现业务流程自动化的方法和在不同领域的应用&#xff0c;接着分析其价值和面临的挑战&#xff0c;最后得出结论&#xff0c;为读者全面…...

前端页面导出word

html-docx-js bug: vite使用html-docx.js会报错&#xff0c;点击下载上方文件替换即可 正文 npm install html-docx-js -S npm install file-saver -S<template><div id"managerReport">word内容......</div> </template><script>&l…...

【考前预习】1.计算机网络概述

往期推荐 子网掩码、网络地址、广播地址、子网划分及计算-CSDN博客 一文搞懂大数据流式计算引擎Flink【万字详解&#xff0c;史上最全】-CSDN博客 浅学React和JSX-CSDN博客 浅谈云原生--微服务、CICD、Serverless、服务网格_云原生 serverless-CSDN博客 浅谈维度建模、数据分析…...

ubuntu20.04复现 Leg-KILO

这里写目录标题 opencv版本问题下载3.2.0源代码进入解压后的目录创建构建目录运行 CMake 配置 配置时指定一个独立的安装目录&#xff0c;例如 /opt/opencv-3.2&#xff1a;出错&#xff1a; 使用多线程编译错误1&#xff1a; stdlib.h: 没有那个文件或目录错误2&#xff1a;er…...

Ensembl数据库下载参考基因组(常见模式植物)bioinfomatics 工具37

拟南芥参考基因组_拟南芥数据库-CSDN博客 1 Ensembl数据库网址 http://plants.ensembl.org/index.html #官网 如拟南芥等 那么问题来了&#xff0c;基因组fa文件和gff文件在哪里&#xff1f; 2 参考案例 拟南芥基因组fa在这里 注释gff文件在这里...

自然语言处理实战指南:从文本表示到深度学习

自然语言处理实战指南&#xff1a;从文本表示到深度学习 标签&#xff1a;#自然语言处理、#人工智能、#大模型、#大模型实战、#transformer、#机器学习、#深度学习 模块四&#xff1a;项目实战 技术对比 避坑经验 4.1 项目实战&#xff08;中文商品评论情感分析&#xff09; …...

云边协同 智启未来 | 阿里云 × ZStack 云边一体解决方案正式落地

随着数字化转型的不断深入&#xff0c;企业对于云计算的需求已从"集中上云"逐步演进为"云边协同"。在智慧城市、工业互联网、智慧交通、能源电力等行业场景中&#xff0c;数据的实时处理、低延迟响应以及本地化合规需求日益迫切。单一的中心化云架构已难以…...

如何为Jellyfin添加豆瓣插件:一键获取中文元数据和评分的完整指南

如何为Jellyfin添加豆瓣插件&#xff1a;一键获取中文元数据和评分的完整指南 【免费下载链接】jellyfin-plugin-douban Douban metadata provider for Jellyfin 项目地址: https://gitcode.com/gh_mirrors/je/jellyfin-plugin-douban 还在为Jellyfin媒体库缺少中文信息…...

WarcraftHelper终极指南:快速解决魔兽争霸III 5大兼容性问题

WarcraftHelper终极指南&#xff1a;快速解决魔兽争霸III 5大兼容性问题 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为经典魔兽争霸III在新系…...

为StructBERT模型开发命令行工具:提升批量处理效率

为StructBERT模型开发命令行工具&#xff1a;提升批量处理效率 如果你经常需要处理大量文本的相似度计算&#xff0c;每次都要打开Python脚本、修改代码、运行程序&#xff0c;是不是觉得有点麻烦&#xff1f;特别是当你要把任务交给其他同事&#xff0c;或者需要在服务器上定…...

IHaskell与Python对比分析:函数式编程在数据科学中的独特价值

IHaskell与Python对比分析&#xff1a;函数式编程在数据科学中的独特价值 【免费下载链接】IHaskell A Haskell kernel for the Jupyter project. 项目地址: https://gitcode.com/gh_mirrors/ih/IHaskell 在数据科学领域&#xff0c;选择合适的编程语言往往直接影响开发…...

GTE语义搜索在网络安全领域的应用:威胁情报分析系统

GTE语义搜索在网络安全领域的应用&#xff1a;威胁情报分析系统 1. 网络安全的新挑战与机遇 每天&#xff0c;安全分析师都要面对海量的威胁数据——从安全警报、漏洞报告到攻击日志&#xff0c;信息量庞大且分散。传统的关键词搜索就像是用渔网捞针&#xff0c;经常漏掉重要…...

脚本开发必看:随机数使用中的3个常见误区及正确写法(按键精灵版)

脚本开发必看&#xff1a;随机数使用中的3个常见误区及正确写法&#xff08;按键精灵版&#xff09; 在自动化脚本开发中&#xff0c;随机数功能就像一把双刃剑——用得好能让脚本行为更接近人类操作&#xff0c;用得不好则可能导致不可预测的bug。特别是在按键精灵这类工具中&…...

不锈钢反应釜选型指南:模块化设计如何提升设备利用率

在化工、制药和精细化学品生产领域&#xff0c;不锈钢反应釜是工艺装备。然而&#xff0c;许多企业在采购和使用过程中面临着设备利用率低、温控精度不足、清洗困难等痛点。如何选择一台既能满足工艺需求&#xff0c;又能提高投资回报的反应釜&#xff1f;本文将从行业需求出发…...

LiP-MS—解锁以药找靶新利器

有限蛋白水解质谱&#xff08;Limited Proteolysis-Mass Spectrometry&#xff0c;Lip-MS&#xff09;作为无标记、原位、高通量的以药找靶技术&#xff0c;彻底打破传统技术壁垒&#xff0c;直接在细胞、组织等天然体系中&#xff0c;精准捕获药物结合的靶蛋白与结合位点&…...