在Pytorch中使用Tensorboard可视化训练过程

news2024/10/7 18:31:51

这篇是我对哔哩哔哩up主 @霹雳吧啦Wz 的视频的文字版学习笔记 感谢他对知识的分享

本节课我们来讲一下如何在pytouch当中去使用我们的tensorboard

对我们的训练过程进行一个可视化

左边有一个visualizing models data and training with tensorboard

主要是这么一个教程

那么这里我想问一下大家

平时你们在使用tensorboard的时候

主要会去使用它的哪些功能

反正在我个人使用当中呢

我主要会使用其中的四个功能

第一个就是去保存一下网络的一个结构图

比如说在我们tensorboard的graphs当中

会有我们模型的一个结构图

然后这个图当中呢其实就能够比较清晰地看到我们整个模型

它的搭建的每一个模块

第二个呢就是保存我们在训练过程当中

训练集它的一个损失loss 还有验证集的accuracy 还有我们的学习率变化等等

在我们的scalars当中

那么这里呢就比如说我们这里有tracy

还有我们的learning rate

还有我们的train loss

那么第三个就是保存权重数值

它的一个分布在tensorboard当中的histogram当中

在这个里面呢一般就是保存我们每一个层结构

它的一个权重的数值的一个分布

那么最后一个呢就是保存我们预测图片的一些信息

就比如说在我们的image当中保存有我们训练的每一个step对于我们给定的一些图片

它的一个预测的一个结果

首先我们这里需要建一个文件夹

叫做plot image

那么在这个文件夹当中呢

我们所保存的图片是我们待会儿在训练过程当中

会对我们的这些图片进行预测

由于本节课训练是以我们之前的花分类数据集为例

所以呢我们这里需要先提前准备好我们的花分类数据集

我这里有给下载花分类数据集的一个地址

下载完之后呢

我们这里的image root就指向我们解压之后文件夹它的一个路径

那么准备好我们的数据集之后呢

接下来就是关于预训练权重了

那么这里也是根据你个人的需求来进行选择了

如果你是需要去使用它的预训练权重的话

你就在这个pytorch官方的这个地址上去下载这个权重文件

然后将这里的defaul指向你刚刚下载这个权重路径就可以了

那如果你不去指认的话

那么它默认的就是不去使用任何预训练权重了

那么本教程其实是没有去使用这个预训练权重的

因为如果你使用了预训练权重之后呢

你会发现它的accuracy loss基本上是没有变化的

因为在你训练的第一个epoch

它的准确率就已经达到97%了

所以基本看不出有什么变化

这里我不去使用预训练权重

就可以看到它的loss变化以及accuracy变化

那么这个参数freeze layers

就是说是否去冻结我们的除全连接层以外的所有网络结构啊

这里默认是false

就是不去冻结

如果你设置为true的话

它就会去单独训练最后这个全连接层

之前的权重是不会去训练的

那么如果你使用这个预训练权重的话

你可以将这里设置为true

可以加快模型的训练

首先我们这里的summary writer

它是来自于touch utils的tensorboard的模块当中导入进来的

所以我们这里先实例化我们的tensorboard对象

这里我们需要插入这个参数呢

就是说我们将我们的tensorboard的文件保存在哪里

我这里就是保存在当前项目目录下的runs

然后flower experiment这个文件夹当中

那么当我们实例化之后呢

它就会在我们当前项目想创建一个runs这个文件

然后会将我们对应的tbd文件保存在flower experiment当中

实例化我们的tensorboard对象之后呢

这里有去添加我们网络的一个结构图

在我们实例化我们的模型之后呢

紧接着在这里我创建了一个initial image

它就是一个零矩阵了

这里为什么要去创建一个initial image呢

因为在我们添加这个graph的时候

我们是需要将我们这个initial image传入到我们的模型当中

让它进行一个这样传播

然后会根据我们输入的数据

在模型中正向传播的一个流程来创建我们的网络结构图

所以我们这里传入的数据只要和我们的图片大小相同就可以了

所以呢我这里就有创建一个initial image

那么我们通过我们实例化的tensorboard

它的add graph这个函数项目的模型

以及我们初始的一个图片传入进去就ok了

在我们的这个位置有使用到add scaler

那么这里呢其实就是在我们训练的每个epoch之后

也就是在我们验证完我们的模型之后

我们会去保存一下我们当前这一轮训练的训练集的平均损失loss

还有我们验证集的accuracy

以及我们的learning rate

我们传入有这五个变量

第一个那就是我们实例化的模型

第二个image

第二对应的就是我们刚刚这个plot image它的一个根目录

第三个transform对应着我们验证集所使用的一个图像预处理

第四个参数对应就是我们总共要展示多少张图片

第五参数就是我们说使用的device信息

然后接下来我们再往下走就到了我们这里的add figure

也就是添加我们预测plot image文件夹下这几张图片

第一个是我们这张图片它的一个名称

它的一个标题

然后第二个参数对应的就是figure这个对象

第三个global step朋友们是通过epoch来指定的

首先在我们训练过程当中呢

我们会去生成一个json文件

这个json文件保存的就是我们类别索引

以及它的一个名称的一个对应关系

那么这里呢只要是正常训练的话

就会生成它

那如果它不存在的话

就说明训练过程是有问题的

那么这里就会报出一个错误

就是没有找到这个文件

然后接下来我们就会读取这个文件

我们通过touch stack方法将我们的images

也就是我们刚刚所保存的一个图片的列表进行一个拼接

拼接成一个batch

那么这里大家需要注意的是

我们的stack方法会对我们的数据增加一个新的维度

那么通过我们刚才预处理之后

其实我们的每一个图片就变成了一个tensor的格式

它的shape就是3x224x224

那么这里呢我们会在它的最前面新增一个维度

那么就变成了拼接之后呢

它就变成了batch x 3x224x224

我已经将我之前训练好的结果保存在对应的文件夹下面了

那么接下来我们就来打开tenor board来看一下

那么首先进入我们的项目根目录

然后呢进入我们的runs文件

然后打开终端

打开终端之后呢

然后就输入tensorboard

然后logdir

然后就输入当前路径就可以了

然后接下来大家需要注意的是

我们还需要再加上一个参数啊

就是这个samples per plugin

然后在这个参数当中

我们需要指定一下我们所展示图片的一个数目

如果我们不指定这个参数的话

它默认会去采样十张图片

因为在我这个训练过程当中呢

如果按照默认参数来的话

只能看到十张

所以我这里会加上这么一个参数

指定为50之后呢

它就会展示所有的图片了

那么回车之后呢

终端就提示我们在local host 端口可以看到

那么我们就进入浏览器

输入local host 6006回车

然后就可以看到我们训练过程当中保存了一系列的数据了

那么在这个blog当中

我们可以看到我们那个数据的流向

就是根据这个箭头可以判断出数据的流向

我们的初始化方法中只定义了一个relu

也就是说我们在我们主干分支当中所使用的这个relu结构

与我们主干分支与捷径分支相加之后所经过的机函的relu是同一个

所以这里会有一个往回流的一个箭头

然后经过relu之后呢

它就会输入到下一个模块当中

如果你想为了这个图看起来更好看的话

其实你可以在定义block的时候

定义两个relu

主分支上使用主分支这个relu

然后相加之后再使用另外一个relu

这样的话就不会出现像我们这个箭头往回指的这个情况

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1296814.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

28BYJ-48步进电机的驱动

ULN2003的工作原理 28BYJ48可以用ULN2003来驱动,STM32使用开漏模式外接5V上拉电阻也可以产生5V电压,为什么不直接使用单片机的 GPIO来驱动的原因是虽然电压符合电机的驱动要求,但单片机引脚产生的驱动电流太小,因此驱动步进电机要…

IBM Qiskit量子机器学习速成(四)

量子核机器学习 一般步骤 量子核机器学习的一般步骤如下 定义量子核 我们使用FidelityQuantumKernel类创建量子核,该类需要传入两个参数:特征映射和忠诚度(fidelity)。如果我们不传入忠诚度,该类会自动创建一个忠诚度。 注意各个类所属的…

leaflet:经纬度坐标转为地址,点击鼠标显示地址信息(137)

第137个 点击查看专栏目录 本示例的目的是介绍演示如何在vue+leaflet中将经纬度坐标转化为地址,点击鼠标显示某地的地址信息 。主要利用mapbox的api将坐标转化为地址,然后在固定的位置显示出来。 直接复制下面的 vue+leaflet源代码,操作2分钟即可运行实现效果 文章目录 示…

UniDBGrid序号列添加标题

有人想要在UniDBGrid的序号列加上标题,就是这里 可以使用如下代码 UniSession.AddJS(MainForm.UniDBGrid1.columnManager.columns[0].setText("序号"));

VMware安装Ubuntu20.04并使用Xshell连接虚拟机

文章目录 虚拟机环境准备重置虚拟网络适配器属性(可选)配置NAT模式的静态IP创建虚拟机虚拟机安装配置 Xshell连接虚拟机 虚拟机环境准备 VMware WorkStation Pro 17.5:https://customerconnect.vmware.com/cn/downloads/details?downloadGr…

样本数量对问卷信度效度分析的影响及应对策略

问卷调研是一种常见的数据收集方法。明确问卷的真实性和效率是保证其靠谱性和有效性的重要一步。但问卷的真实性和品质会受到样本数量的影响吗? 一、问卷信度的认识 1、信度的概念和重要性:在问卷实验中,信度是指问卷测量值的稳定性和一致性。高信度代…

go grpc高级用法

文章目录 错误处理常规用法进阶用法原理 多路复用元数据负载均衡压缩数据 错误处理 gRPC 一般不在 message 中定义错误。毕竟每个 gRPC 服务本身就带一个 error 的返回值,这是用来传输错误的专用通道。gRPC 中所有的错误返回都应该是 nil 或者 由 status.Status 产…

希尔排序详解:一种高效的排序方法

在探索排序算法的世界中,我们经常遇到需要对大量数据进行排序的情况。传统的插入排序虽然简单,但在处理大规模数据时效率并不高。这时,希尔排序(Shell Sort)就显得尤为重要。本文将通过深入解析希尔排序的逻辑&#xf…

分享十几个适合新手练习的软件测试项目

说实话,在找项目的过程中,我下载过(甚至付费下载过)N多个项目、联系过很多项目的作者,但是绝大部分项目,在我看来,并不适合你拿来练习,它们或多或少都存在着“问题”,比如…

编写一个程序, 给出两个时间,计算出两个时间之差,如给出1120表示11:20,1330表示13:30, 将时间间隔以分钟为单位输出。

如下: #include<stdio.h>int main(){int a,b;printf("请输入第一个时间a:");scanf("%d",&a);printf("请输入第二个时间b:");scanf("%d",&b);int hour1a/100;//取小时int minute1a%100;//取分钟int hour2b/100;int minu…

HCIP --- BGP 基础 (中)

BGP的数据包 Open、Update、Notification、Keepalive、Route-refresh BGP的公共头部 Marker &#xff1a;标记 &#xff08;可以兼容字段、版本&#xff09; 全F Length&#xff1a; 标明数据包多长多大 Type&#xff1a;表明数据包类型&#xff08;可选 12345&#xff09; …

如何切换用户和更改用户密码

https://blog.csdn.net/u012759006/article/details/89681615 https://blog.csdn.net/Z_CAIGOU/article/details/120925716 1、sudo su 切换到root用户 2、passwd 用户名 之后输入你修改后的密码两次&#xff0c;成功。 文章知识点与官方知识档案匹配&#xff0c;可 一般情…

C语言 扫雷游戏

代码在一个项目里完成&#xff0c;分成三个.c.h文件(game.c,game.h,main.c) 在Clion软件中通过运行调试。 /大概想法/ 主函数main.c里是大框架(菜单,扫雷棋盘初始化&#xff0c;随机函数生成雷&#xff0c;玩家扫雷) game.h函数声明(除main函数和游戏函数外的一些函数声明) ga…

Kafka安全性探究:构建可信赖的分布式消息系统

在本文中&#xff0c;将研究Kafka的安全性&#xff0c;探讨如何确保数据在传输和存储过程中的完整性、机密性以及授权访问。通过详实的示例代码&#xff0c;全面讨论Kafka安全性的各个方面&#xff0c;从加密通信到访问控制&#xff0c;帮助大家构建一个可信赖的分布式消息系统…

品牌控价成本如何把控

品牌在发展&#xff0c;价格就需要持续关注&#xff0c;当出现乱价、低价、窜货时就应投入人力去治理&#xff0c;但企业生存&#xff0c;还要考虑成本&#xff0c;如何在保证控价效果的基础上&#xff0c;做到使用最低成本呢&#xff0c;这些问题除了控价本身外&#xff0c;也…

苹果IOS在Safari浏览器中将网页添加到主屏幕做伪Web App,自定义图标,启动动画,自定义名称,全屏应用pwa

在ios中我们可以使用Safari浏览自带的将网页添加到主屏幕上&#xff0c;让我们的web页面看起来像一个本地应用程序一样&#xff0c;通过桌面APP图标一打开&#xff0c;直接全屏展示&#xff0c;就像在APP中效果一样&#xff0c;完全体会不到你是在浏览器中。 1.网站添加样式 在…

去掉手机端顶部间隙

Unigui手机端打开时&#xff0c;在顶部有一条白色间隙 使用以下方法可以去除间隙 在ServerModule的customcss里添加以下代码 body{ margin:0!important; padding:0!important; }

文章解读与仿真程序复现思路——中国电机工程学报EI\CSCD\北大核心《考虑垃圾处理与调峰需求的可持续化城市多能源系统规划》

这个标题涵盖了城市多能源系统规划中的两个重要方面&#xff1a;垃圾处理和调峰需求&#xff0c;并强调了规划的可持续性。 考虑垃圾处理&#xff1a; 含义&#xff1a; 垃圾处理指的是城市废弃物的管理和处置。这可能涉及到废物分类、回收利用、焚烧或填埋等方法。重要性&…

使用pyftpdlib组件实现FTP文件共享

目录 一、引言 二、技术背景 三、实现逻辑 1、创建FTP服务器&#xff1a; 2、实现文件共享&#xff1a; 3、设置用户权限&#xff1a; 4、处理异常&#xff1a; 5、优化与扩展&#xff1a; 四、代码实现 五、测试与评估 测试用例&#xff1a; 评估方法&#xff1a;…

ubuntu22.04安装 nvidia-cudnn

nvidia-cudnn 是 NVIDIA CUDA 深度神经网络库&#xff08;CUDA Deep Neural Network library&#xff09;的缩写。这是一个由 NVIDIA 提供的库&#xff0c;用于加速深度学习应用程序。它包含了针对深度神经网络中常用操作&#xff08;如卷积、池化、归一化、激活层等&#xff0…