Pytorch ----- tansorboard (add_scalar、add_image) 参数详解+运行实例

2023-10-24 19:20

本文主要是介绍Pytorch ----- tansorboard (add_scalar、add_image) 参数详解+运行实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • tansorboard的简介
    • add_scalar使用及其参数解释
        • add_scalar小实例:
    • add_image使用及其参数解释
        • add_image小实例:

tansorboard的简介

tansorboard 相当于一个可视化工具,像matplotlib一样。
之前是在tensorflow里用的,pytorch在某个版本(好像是1.1?)之后也能用了。

tansorboard的使用:

首先导包:from torch.utils.tensorboard import SummaryWriter
没有的话 直接安装就行 pip3 install tansorboard

实例化对象:writer = SummaryWriter('logs') # 参数: 文件的存放路径

add_scalar使用及其参数解释

绘图: writer.add_scalar(参数1,参数2,参数3)

  • 第一个参数:生成图像的名称
  • 第二个参数:X轴的值
  • 第三个参数:Y轴的值
add_scalar小实例:
from torch.utils.tensorboard import SummaryWriter
writer = SummaryWriter('logs') # 参数: 文件的存放路径
for i in range(100):writer.add_scalar('这是图像名字',i,i)
writer.close()

运行之后可以看到文件夹多了一个:

logs就是刚才我们取的名字
在这里插入图片描述
这里的文件不能直接打开,需要用命令行打开,是个web。
使用打开命令: tensorboard --logdir=logs
这里的 logs 就是你的文件名。
这里要注意文件路径,他创建的logs文件和你代码文件同目录,但查看的时候要和项目文件进行查找,所以按照我的目录,查看的代码应该是 tansorboard --logdir=code/logs
在这里插入图片描述

如果一台服务器有多人训练,可以每个人都指定不同的端口。
tensorboard --logdir=文件名 --port=端口号

在这里插入图片描述
点开所显示的蓝色本地web地址,得到下面的图像。
在这里插入图片描述

add_image使用及其参数解释

add_image(tag, img_tensor, global_step=None, walltime=None, dataformats='CHW')

  • tag (string): 数据名称
  • img_tensor (类型 torch.Tensor 或 numpy.array): 图像数据
  • global_step (int, optional): 记录这是第几个子图 后面解释这个参数
  • walltime (float, optional): 记录发生的时间,默认为 time.time()
  • dataformats (string, optional): 图像数据的格式,默认为 ‘CHW’,即 Channel x Height x Width,还可以是 ‘CHW’、‘HWC’ 或 ‘HW’ 等
add_image小实例:

使用的图片:在这里插入图片描述

使用PIL读取图片,读出来的图片是PIL类型,用numpy转换成numpy类型。

这里需要注意一点,当我们转换成numpy类型之后,数据为(719, 719, 4) 显然是 H * W * C 所以我们使用add_image的时候, 用dataformats这个参数指定一下使用数据的维度排列情况 dataformats='HWC'

from torch.utils.tensorboard import SummaryWriter
from PIL import Image
import  numpy as npwriter = SummaryWriter('logs') # 参数: 文件的存放路径
image_path = "../data/cat.png"
image_PIL = Image.open(image_path)
image_numpy = np.array(image_PIL)  # 转化成numpy数据类型
writer.add_image("这是图像名字",image_numpy,1,dataformats='HWC') # 最后的参数指定维度格式
writer.close()

在这里插入图片描述
add_image(tag, img_tensor, global_step=None, walltime=None, dataformats='CHW')

关于global_step 参数
如果在使用的时候,tag也就是图片标题名字没有改变,仅仅改变 global_step ,
我们还是使用上面的代码不变,仅仅改变global_step 从1变成2,并且换了一张新的图片。会有下面的情况、

在这里插入图片描述

在这里插入图片描述
可以看到下面这里多了一个可拉动进度条,
可以通过拉动进度条查看 “这就是图像名字” 名字下的所有子图,这就是 global_step 的用处。

直接换个tag 就是图片名,就可以让他们不是属于子图关系了。

这篇关于Pytorch ----- tansorboard (add_scalar、add_image) 参数详解+运行实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/qq_38737428/article/details/121720853
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/277222

相关文章

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

详解nginx 中location和 proxy_pass的匹配规则

《详解nginx中location和proxy_pass的匹配规则》location是Nginx中用来匹配客户端请求URI的指令,决定如何处理特定路径的请求,它定义了请求的路由规则,后续的配置(如... 目录location 的作用语法示例:location /www.chinasem.cntestproxy

CSS will-change 属性示例详解

《CSSwill-change属性示例详解》will-change是一个CSS属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSSwill-change属性详解,感... will-change 是一个 css 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化。这可以帮助浏览器优化

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

前端高级CSS用法示例详解

《前端高级CSS用法示例详解》在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将深... 前端高级css用法在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使