PyTorch(三)TensorBoard 与 Transforms

news2025/1/11 14:55:33

文章目录

    • Log
  • 一、TensorBoard
    • 1. TensorBoard 的安装
    • 2. SummaryWriter 的使用
      • ① add_scalar() 的使用
        • a. 参数说明
        • b. 函数使用
        • c. 使用 Tensorboard
      • ② add_image() 的使用
        • a. 参数说明
        • b. 使用 numpy.array() 对 PIL 图片进行转换
        • c. 使用函数
        • d. 改变 global_step
  • 二、Transforms
    • 1. Transforms 的结构及用法
      • ① Transforms 的结构
        • a. stucture 的使用
        • b. 常用的类
      • ② Transforms 的用法
        • a. Transforms.ToTensor 的用法
        • b. 使用 tensor 数据类型的原因
        • c. 创建 numpy.ndarray 类型的数据
  • 总结


Log

2022.10.04开启本章的学习
2022.10.13事情好多,做项目、准备中检、读书、准备期末考试、审材料、做实验…啊!继续学习
2022.10.14继续学习
2022.10.17继续学习
2022.10.18继续学习
2022.10.19继续学习
2022.10.20继续学习
2022.10.21继续学习
2022.10.24电脑前几天坏了,自己检查了一下,内存条硬盘啥的都没问题,去维修店检查说是主板烧了,不知道啥时候能修好,今天过节先把文章发出来


一、TensorBoard

1. TensorBoard 的安装

  • 打开 P y c h a r m \rm Pycharm Pycharm 的终端 T e r m i n a l \rm Terminal Terminal,切换到对应的虚拟环境,我创建了一个名为Pytorch的环境,激活并切换指令如下:
conda info -e 			# 查看虚拟环境
conda activate Pytorch	# 切换到项目所用的虚拟环境Pytorch
  • 随后输入命令 pip install tensorboard 即可进行安装。

2. SummaryWriter 的使用

  • torch 导入:
from torch.utils.tensorboard import SummaryWriter
  • 按住 c t r l ctrl ctrl 键点击 SummaryWriter 即可查看相关的介绍内容:
"""Writes entries directly to event files in the log_dir to be
   consumed by TensorBoard"""
  • 是可以向 l o g _ d i r log\_dir log_dir 写入的事件文件,事件文件可以被 T e n s o r B o a r d \rm TensorBoard TensorBoard 进行解析。
  • 创建实例:
writer = SummaryWriter("logs")
  • 常用的两个函数:
writer.add_image()
writer.add_scalar()

① add_scalar() 的使用

a. 参数说明

  • 该函数需要添加标量数据,主要的参数如下:
    • tag:生成图像的 title
    • scalar_value:Y 轴,纵坐标
    • global_step:X 轴,横坐标

b. 函数使用

  • 运行以下代码绘制图像:
for i in range(100):
    writer.add_scalar("y=x", i, i)

c. 使用 Tensorboard

  • 运行结束后可以看到在项目路径下多出来一个logs文件夹,在 T e r m i n a l \rm Terminal Terminal 运行以下命令打开 T e n s o r b o a r d \rm Tensorboard Tensorboard 窗口:
tensorboard --logdir=code/logs # 参数logdir为事件文件所在文件夹名
  • 若多人同时操作,为防止冲突可以添加打开窗口选项:
tensorboard --logdir=code/logs --port=6007# 参数port为指定的打开端口
  • 打开的界面如下:
    在这里插入图片描述

  • 我们可以在训练时每隔一定的步数将 t r a i n l o s s train_{loss} trainloss 等指标进行显式地绘制,但是如果在后续的绘制的过程中没有修改图像的 T i t l e Title Title(即参数 tag,对应上面的 y=x ),就会产生下面的情况:
    在这里插入图片描述

  • 所有的不同次的数据混合到了一起,绘制时被自动拟合,对应的解决方法有两种:

    1. 删除原有文件,重新绘制
    2. 训练新的模型时重新创建一个子文件夹(即 SummaryWriter("newFolder")

② add_image() 的使用

a. 参数说明

  • 主要的参数如下:
    • tag:生成图像的 title
    • img_tensor:图像(数据类型为 torch.Tensornumpy.arraystring/blobname
    • global_step:训练的步骤( int 型)

b. 使用 numpy.array() 对 PIL 图片进行转换

  • 在控制台执行以下代码查看图片的类型:
from PIL import Image
img_path = "dataset/hymenoptera_data/train/ants/0013035.jpg"
img = Image.open(img_path)
print(type(img))	# <class 'PIL.JpegImagePlugin.JpegImageFile'>
  • 可以看到类型并不符合 add_image() 函数里第二个参数的要求,所以我们要使用将其转换为符合要求的类型:
import numpy as np
img_array = np.array(img)
print(type(img_array))	# <class 'numpy.ndarray'>

c. 使用函数

  • 虽然我们目前已经将图片转换为了 numpy.array 的格式,但是查看 add_image() 函数的具体说明可以发现输入的图片还需要满足 ( 3 , H , W ) \rm (3, H, W) (3,H,W) 的格式,即“通道数、高度、宽度”,执行以下语句:
print(img_array.shape)	# (512, 768, 3)
  • 发现我们的输入格式是 ( H , W , 3 ) \rm (H, W, 3) (H,W,3) ,即“高度、宽度、通道数”,因此我们还需要增加一个参数 dataformats,即原有语句变为如下:
writer.add_image("test", img_array, 1, dataformats='HWC')
  • 完整程序:
img_path = "../dataset/hymenoptera_data/train/ants/0013035.jpg"
img_PIL = Image.open(img_path)
img_array = np.array(img_PIL)
print(img_array.shape)
writer.add_image("test", img_array, 1, dataformats='HWC')

d. 改变 global_step

  • 更换图片并将 global_step 的值改为 2 :
img_path = "../dataset/hymenoptera_data/train/ants/24335309_c5ea483bb8.jpg"
img_PIL = Image.open(img_path)
img_array = np.array(img_PIL)
print(img_array.shape)
writer.add_image("test", img_array, 2, dataformats='HWC')
  • 运行后打开 T e n s o r b o a r d \rm Tensorboard Tensorboard 窗口,如下图所示:
    在这里插入图片描述

  • 拖动图片上方的滑块我们可以看到不同 step 下的图像。我们可以通过这种方式来观察训练模型时提供了哪些数据,或是在对模型进行测试时观察不同阶段的输出结果。

二、Transforms

1. Transforms 的结构及用法

① Transforms 的结构

a. stucture 的使用

  • 导入 transforms
from torchvision import transforms
  • 按住 c t r l ctrl ctrl 点击进入查看 transforms 的详细信息,点击 P y c h a r m \rm Pycharm Pycharm 左侧的 s t u c t u r e stucture stucture 可以查看该文件( transforms.py )的结构:
    在这里插入图片描述
  • 我们也可以到 S e t t i n g s Settings Settings 里的 K e y m a p Keymap Keymap 中修改该选项的快捷键:
    在这里插入图片描述

b. 常用的类

  • 常用的有如下几个类:
    • Compose:串联多个图片变换的操作( C o m p o s e s   s e v e r a l   t r a n s f o r m s   t o g e t h e r Composes\ several\ transforms\ together Composes several transforms together
    • ToTensor:把 PIL Imagenumpy.ndarray 转换为一个 tensor
    • ToPILImage:把 tensorndarray 转换为 PIL Image
    • Normalize(torch.nn.Module):正则化
    • Resize(torch.nn.Module):改变尺寸
    • CenterCrop(torch.nn.Module):中心裁剪
  • 我们可以将 T r a n s f o r m s \rm Transforms Transforms (也就是 transforms .py 文件)看成一个工具箱,我们的输入是特定格式的图片,使用工具箱里的工具模板(如 ToTensorResize 等)创建自己的工具( tool = transforms.ToTensor() ),再对输入进行处理,进而得到我们想要的结果。

② Transforms 的用法

  • 通过 ToTensor 来讲解 Transforms 的用法,以及什么是 tensor 和为什么要用这种数据类型。

a. Transforms.ToTensor 的用法

  • 首先用 Image 打开一张图片,输出可以查看图片的类型等信息:
from PIL import Image
img_path = "../dataset/hymenoptera_data/train/ants/24335309_c5ea483bb8.jpg"
img = Image.open(img_path)
print(img)
# <PIL.JpegImagePlugin.JpegImageFile image mode=RGB size=500x375 at 0x293161BCEE0>
  • 通过 transforms .py 文件我们可以看到,类有这样的一个函数,也就是调用该类,输入为 PIL Imagenumpy.ndarray 类型的图片,输出为 tensor 类型的图片:
def __call__(self, pic):
    """
    Args:
        pic (PIL Image or numpy.ndarray): Image to be converted to tensor.

    Returns:
        Tensor: Converted image.
    """
    return F.to_tensor(pic)
  • 接着创建一个 ToTensor 类的实例,再调用该实例并输出:
tensor_trans = transforms.ToTensor()
tensor_img = tensor_trans(img)
print(tensor_img)	# tensor([[[0.0510, 0.0471, 0.0431,  ...
  • 此外,我们还可以用前面学到的东西,将 tensor 类型的数据写到 t e n s o r b o a r d tensorboard tensorboard 中并进行查看:
writer.add_image("Tensor_img", tensor_img)

b. 使用 tensor 数据类型的原因

  • 通过控制台运行程序,可以看到 tensor 类型的数据包含神经网络中用到梯度、梯度的方法以及使用的设备等信息,有利后续的使用:
    在这里插入图片描述

c. 创建 numpy.ndarray 类型的数据

  • T e r m i n a l \rm Terminal Terminal 中输入以下指令进行安装:
pip install opencv-python
  • 在控制台运行以下代码:
import cv2
cv_img = cv2.imread(img_path)
  • 可以看到我们得到的 cv_img 就是 numpy.ndarray 类型:
    在这里插入图片描述

总结

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

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

相关文章

数据结构 | 时间复杂度与空间复杂度

… &#x1f333;&#x1f332;&#x1f331;本文已收录至&#xff1a;数据结构 | C语言 更多知识尽在此专栏中&#xff01; &#x1f389;&#x1f389;&#x1f389;欢迎点赞、收藏、关注 &#x1f389;&#x1f389;&#x1f389;文章目录&#x1f333;前言&#x1f333;正…

【C++初阶】类和对象(二)

大家好我是沐曦希&#x1f495; 类和对象1.类的6个默认成员函数2.构造函数2.1 概念2.2 特性3.析构函数3.1 概念3.2 特性4.拷贝构造函数4.1 概念4.2 特征1.类的6个默认成员函数 空类&#xff1a;类中一个成员都没有 可是空类真的什么都没有吗&#xff1f; 并不是&#xff0c;任…

STM32关于UART的接收方式

STM32的 UART 一般分为定长接收和不定长接收 定长接收&#xff1a; HAL_UART_Receive():只能接收固定长度的数据&#xff0c;如果超过固定长度的数据只能接收对应长度&#xff0c;如果小于固定长度则不会接收 HAL_UART_Receive_IT():中断方式接收&#xff0c;每接收一个字节…

CSS 2 CSS 选择器 - 5 2.8 伪选择器 2.8.1 伪类选择器【根据特定状态选取元素】

CSS 文章目录CSS2 CSS 选择器 - 52.8 伪选择器2.8.1 伪类选择器【根据特定状态选取元素】2 CSS 选择器 - 5 2.8 伪选择器 2.8.1 伪类选择器【根据特定状态选取元素】 【什么是伪类】 伪类用于定义元素的特殊状态。 例如&#xff0c;它可以用于&#xff1a; 设置鼠标悬停在…

如何删除ZIP压缩包的密码?

ZIP是比较常用的压缩文件格式&#xff0c;有时候因为工作需要很多人还会给压缩包设置打开密码。那如果后续不需要密码保护了要如何删除密码呢&#xff1f;密码忘记了还能删除吗&#xff1f; 首先来说说第一种情况&#xff0c;也就是知道密码但后续不需要密码保护&#xff0c;只…

1. 初识Python

1. Pythond 简介 Python 语言由荷兰的 Guido Van Rossum (吉多范罗苏姆, 江湖人称龟叔) 在1989年圣诞节期间为了打发圣诞节的无趣而开发的一个脚本解释语言.Python 源代码遵循 GPL(GNU General Public License)开源协议, 也就是说你可以免费使用和传播它, 而不用担心版权的问…

libusb系列-005-部分API简介

libusb系列-005-部分API简介 文章目录libusb系列-005-部分API简介摘要libusb_initlibusb_open_device_with_vid_pidlibusb_kernel_driver_activelibusb_detach_kernel_driverlibusb_claim_interfacelibusb_release_interfacelibusb_attach_kernel_driverlibusb_closelibusb_exi…

【论文翻译】分布式并发控制中时间戳排序算法与本地计数器同步的改进方法

An Advanced Approach of Local Counter Synchronization to Timestamp Ordering Algorithm in Distributed Concurrency Control DOI目录1 介绍2 时间戳排序算法3 本地计数器同步的一种高级方法3.1 改进更新本地计数器的广播消息方式3.2 减少广播消息中的数据传输费用4 结论参…

时间复杂度与空间复杂度

文章目录1.什么是数据结构2.什么是算法3.如何学好数据结构呢3.1写代码3.2 多去动手画图4.算法效率4.1如何评判一个算法的好与坏呢4.2算法的复杂度5.时间复杂度5.1 概念5.2大O渐进法6常见的时间复杂度6.1常数阶6.2线性阶6.3 对数阶6.4平方阶6.5函数调用6.5.1普通调用6.5.2递归调…

1024程序节|Android框架之一 BRVAH【BaseRecyclerViewAdapterHelper】使用demo

文章目录&#x1f353;&#x1f353;BRVAH 上部&#x1f344;&#x1f353;动态图结果展示&#x1f344;&#x1f344;myAdapter.java【第一个布局适配器】&#x1f344;&#x1f344;youAdapter.java【第二个布局适配器】&#x1f344;&#x1f344;MainActivity.java【主活动…

【Android】自制静音App,解决他人手机外放问题

契源 看到一个粉丝留言&#xff0c;吐槽舍友深夜手机外放&#xff0c;打扰别人休息&#xff0c;想设计一款软件阻止舍友行径。于是我就来简单设计一下。 需求实现分析 实际上&#xff0c;我之前有篇博文提到过一个类似的Android APP&#xff0c;主要功能是将手机声音强制开到…

内存函数 memcpy、memmove 的简单模拟实现

一、memcpy 函数 数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。注意是以字节为单位进行拷贝。函数声明如下&#xff1a; 1、参数返回值解析 第二个参数 src&#xff1a;源地址&#xff0c;即你要从哪开始拷贝。 第三个参数 count&#xff1a…

Qt 物联网系统界面开发 “ 2022湖南省大学生物联网应用创新设计竞赛技能赛 ——应用物联网的共享电动自行车 ”

文章目录前言一、实现效果二、程序设计1. 界面背景图设计2. 信号槽设计3. 定时器设计4. 动态曲/折线图的设计5. 摄像头扫码6. 注册设计7. 登录设计8. 巡检人员设计三、综合分析前言 本篇源于 “ 2022 湖南省大学生物联网应用创新设计竞赛技能赛参考样题 ” ——应用物联网的共享…

【git】git ssh 公钥私钥 在 windows和mac 双系统分别如何生成 以及对接各个平台说明

win和mac 双系统分别如何生成 git ssh 一、windows 生成 ssh 公钥私钥 windows版本需要下载git bash&#xff1a;https://gitforwindows.org/ 在 git bash 中输入如下指令&#xff1a; # 创建全局名称&#xff08;将会在你的git提交作者中显示&#xff09;git config --glo…

【allegro 17.4软件操作保姆级教程三】布局操作基础二

4精准定位与坐标定位 在设计中经常会有一些器件或结构孔要摆放在指定位置&#xff0c;如果用move命令用鼠标去移则很难定位完全&#xff0c;这时候就需要精准定位。 操作步骤为&#xff1a; 1、点击move命令&#xff0c;在option面板选择器件原点&#xff0c;这时器件就会悬停在…

策略分析中缺失值的处理方法

在日常的策略分析中&#xff0c;经常会碰到分析的变量出现缺失值的情况&#xff0c;如果对这些缺失值视而不见&#xff0c;则会对策略分析的结果造成一定的影响。那么我们如何处理缺失值呢&#xff1f;关注“金科应用研院”&#xff0c;回复“CSDN”领取“风控资料合集” 首先…

本地数据库IndexedDB - 学员管理系统之登录(一)

IndexedDB是浏览器提供的本地数据库&#xff0c;它可以被网页脚本创建和操作。IndexedDB允许存储大量数据&#xff0c;提供查找接口&#xff0c;还能建立索引。这些都是LocalStorage或Cookie不具备的。就数据库类型而言&#xff0c;IndexedDB不属于关系型数据库&#xff08;不支…

插入排序图解

七大排序之插入排序 文章目录七大排序之插入排序前言一、直接插入排序1.1 算法图解1.2 算法稳定性1.3 插入排序和选择排序相比到底优在哪&#xff1f;二、折半插入排序总结前言 博主个人社区&#xff1a;开发与算法学习社区 博主个人主页&#xff1a;Killing Vibe的博客 欢迎大…

springboot:实现文件上传下载实时进度条功能【附带源码】

0. 引言 记得刚入行的时候&#xff0c;做了一个文件上传的功能&#xff0c;因为上传时间较久&#xff0c;为了用户友好性&#xff0c;想要添加一个实时进度条&#xff0c;显示进度。奈何当时技术有限&#xff0c;查了许久也没用找到解决方案&#xff0c;最后不了了之。 近来偶…

全网最全面的pytest测试框架进阶-conftest文件重写采集和运行测试用例的hook函数

【文章末尾有.......】 使用pytest不仅仅局限于进行单元测试&#xff0c;作为底层模块可扩展性强&#xff0c;有必要理解其运行机制&#xff0c;便于进行二次开发扩展&#xff0c;通过文档的学习很容易理解。 构建一个简单的测试脚本 import pytest import requestsdef add(…