PyTorch可视化工具:TensorBoard、Visdom

应用开发2025-11-05 11:17:212

 一、视化TensorBoard

TensorBoard 一般都是工具作为 TensorFlow 的可视化工具,与 TensorFlow 深度集成,视化它能够展现 TensorFlow 的工具网络计算图,绘制图像生成的视化定量指标图以及附加数据等。

此外,工具TensorBoard 也是视化一个独立工具,在 PyTorch 中也可使用它进行可视化。工具

1、视化安装:pip install tensorboard

2、工具启动:tensorboard --logdir="日志目录"

启动 tensorboard 时,视化可指定 logdir、工具port(默认6006)、视化host(默认localhost)等参数: 

usage: tensorboard [-h] [--helpfull] [--logdir PATH] [--logdir_spec PATH_SPEC]                     [--host ADDR] [--bind_all] [--port PORT]                     [--purge_orphaned_data BOOL] [--db URI] [--db_import]                     [--inspect] [--version_tb] [--tag TAG] [--event_file PATH]                     [--path_prefix PATH] [--window_title TEXT]                     [--max_reload_threads COUNT] [--reload_interval SECONDS]                     [--reload_task TYPE] [--reload_multifile BOOL]                     [--reload_multifile_inactive_secs SECONDS]                     [--generic_data TYPE]                     [--samples_per_plugin SAMPLES_PER_PLUGIN]                     [--debugger_data_server_grpc_port PORT]                     [--debugger_port PORT] [--master_tpu_unsecure_channel ADDR] 

3、源码下载工具Tensorboard 可视化演示(PyTorch 框架):

训练模型,视化导入 tensorboard. SummaryWriter 保存 loss、accuracy 等日志信息。 

# 导入SummaryWriter  from torch.utils.tensorboard import SummaryWriter  ...  # 创建SummaryWriter实例,指定log_dir的位置  summaryWriter = SummaryWriter(log_dir="/Users/liyunfei/PycharmProjects/python3practice/06DL/fcnn/logs")  ...  # 模型训练时,写入train_loss、test_loss、score等信息  summaryWriter.add_scalars("loss", {"train_loss_avg": train_loss_avg, "test_loss_avg": test_loss_avg}, epoch)  summaryWriter.add_scalar("score", score, epoch) 

启动 TensorBoar ,训练过程可视化。

1)启动命令: 

tensorboard --logdir=/Users/liyunfei/PycharmProjects/python3practice/06DL/fcnn/logs 

2)启动成功如图示:

 

3)可视化结果如下:

二、Visdom

Visdom 是 Facebook 专门为 PyTorch 开发的一款可视化工具,能够支持“远程数据”的可视化,支持 Torch 和 Numpy。GitHub 地址:https://github.com/fossasia/visdom

1、源码库安装:pip install visdom

2、启动:

 python -m visdom.server

          -m 是以模块服务启动

 如果是 linux/mac-os 环境,可以使用以下命令启动运行在后台

          nohup python -m visdom.server &

启动 Visdom 时,可以指定 port(默认8097)、hostname(默认localhost)等其它参数: 

usage: server.py [-h] [-port port] [--hostname hostname] [-base_url base_url]                   [-env_path env_path] [-logging_level logger_level]                   [-readonly] [-enable_login] [-force_new_cookie]                   [-use_frontend_client_polling] 

3、Visdom 可视化演示

1)启动 Visdom:

python -m visdom.server -port 8097

2)启动成功如下:

3)训练过程可视化代码: 

# 导入visdom包  import visdom  # 创建Visdom对象,连接服务端,指定env环境(不指定默认env="main")  viz = visdom.Visdom(server=http://localhost, port=8097, env=liyunfei)  ...  viz.line([0.], [0], win=train_loss, opts=dict(title=train_loss))  viz.line([0.], [0], win=accuracy, opts=dict(title=accuracy))  ...  # 模型训练时,实时可视化loss、accuracy等信息。  viz.line([train_loss_avg], [epoch], win=train_loss, update=append)  viz.line([accuracy], [epoch], win=accuracy, update=append) 

4)可视化结果:

5)其它操作——可视化一张/多张图片:

示例: 

import visdom  import numpy as np  viz = visdom.Visdom(server=http://localhost, port=8097, env=liyunfei)  # 一张图片  viz.image(      np.random.rand(3, 512, 256),      opts=dict(title=Random!, caption=How random.),  )  # 多张图片  viz.images(      np.random.randn(20, 3, 64, 64),      nrow=5,      opts=dict(title=Random images, caption=How random.)  ) 

效果:

6)Visdom 的更多可视化 API(常用的是 line、image、text): 

vis.scatter : 2D 或 3D 散点图  vis.line : 线图  vis.stem : 茎叶图  vis.heatmap : 热力图  vis.bar : 条形图  vis.histogram: 直方图  vis.boxplot : 箱型图  vis.surf : 表面图  vis.contour : 轮廓图  vis.quiver : 绘出二维矢量场  vis.image : 图片  vis.text : 文本  vis.mesh : 网格图  vis.save : 序列化状态 高防服务器
本文地址:http://www.bzuk.cn/news/204b30699489.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

全站热门

假如你想要使用多个Linux发行版,你没有那么多的选择。你要么安装到你的物理机或虚拟机中,要么以live模式从ISO文件启动。第二个选择,对硬盘空间需求较小,只是有点麻烦,因为你需要将ISO文件写入到U盘或CD/DVD中来启动。不过,这里还有另外一个可选的折中方案:把ISO镜像放在硬盘中,然后以live模式来启动。该方案比完全安装更省空间,而且功能也完备,这对于缓慢的虚拟机而言是个不错的替代方案。下面我将介绍怎样使用流行的Grub启动加载器来实现该方案。很明显,你将需要使用到Grub,这是几乎所有现代Linux发行版都使用的。你也需要你所想用的Linux版本的ISO文件,将它下载到本地磁盘。最后,你需要知道启动分区在哪里,并怎样在Grub中描述。对于此,请使用以下命令:复制代码代码如下:# fdisk -l 带有‘*’的就是启动分区。对于我,就是/dev/sda1,用Grub语言描述就是(hd0,1)。作为参考,sda2就是(hd0,2),sdb1就是(hd1,1),以此类推。(你明白了吧。)我们需要编辑什么?首先,打开/etc/default/grub并检查以下行:复制代码代码如下:#GRUB_HIDDEN_TIMEOUT=0需要在此行前添加‘#’进行注释。保存,然后打开/etc/grub.d/40_custom。在该文件中,你将添加启动到ISO的参数。结构如下:复制代码代码如下: menuentry [Entrys title in the grub screen] { set isofile=[path to ISO file] loopback loop [boot partition in Grub language]$isofile [some specific] arguments }例如,假如你想要从ISO文件启动Ubuntu,那么你就是想要添加如下行到40_custom文件:复制代码代码如下:menuentry Ubuntu 14.04 (LTS) Live Desktop amd64 { set isofile=/boot/ubuntu-14.04-desktop-amd64.iso loopback loop (hd0,1)$isofile linux (loop)/casper/vmlinuz.efi boot=casper iso-scan/filename=${isofile} quiet splash initrd (loop)/casper/initrd.lz } 假如你想要启动Gparted:复制代码代码如下:menuentry GParted Live amd64 { set isofile=/boot/gparted-live-0.18.0-2-amd64.iso loopback loop (hd0,1)$isofile loopback loop $isofile linux (loop)/live/vmlinuz boot=live config union=aufs noswap noprompt ip=frommedia toram=filesystem.squashfs findiso=${isofile} initrd (loop)/live/initrd.img }或者甚至是Fedora:复制代码代码如下:menuentry Fedora 20 Live Desktop x86_64 { set isofile=/boot/Fedora-Live-Desktop-x86_64-20-1.iso loopback loop (hd0,1)$isofile loopback loop $isofile linux (loop)/isolinux/vmlinuz0 root=live:CDLABEL=Fedora-Live-Desktop-x86_64-20-1 rootfstype=auto ro rd.live.image quiet rhgb rd.luks=0 rd.md=0 rd.dm=0 iso-scan/filename=${isofile} initrd (loop)/isolinux/initrd0.img }注意,参数可根据发行版进行修改。幸运的是,有许多地方你可以查阅到。我喜欢这个发行版,但是还有很多其它的发行版你可以启动。同时,请注意你放置ISO文件的地方。假如你的家目录被加密或者无法被访问到,你可能更喜欢将这些文件放到像例子中的启动分区。但是,请首先确保启动分区有足够的空间。最后,不要忘了保存40_custom文件并使用以下命令来更新grub:复制代码代码如下: # sudo update-grub 以便在下次启动时看到修改。接下来做什么?想要更多东西?好吧,那就修改下参数来玩玩。你可以启动一个ISO文件,并让它持续做一些事情。例如,假如你是个彻头彻尾的妄想症患者,想要有个可以快速清除硬盘的选项,那么可以使用DBAN来进行一些设置。现在,真的要当心啊,因为此设置会清除你的硬盘,而且在启动时也没有恢复选项:复制代码代码如下: menuentry Dariks Boot and Nuke { set isofile=/boot/dban.iso loopback loop (hd0,1)$isofile linux (loop)/dban.bzi nuke=dwipe silent }另外一个选择复制代码代码如下:menuentry Dariks Boot and Nuke { set isofile=/boot/dban.iso loopback loop (hd0,1)$isofile linux (loop)/dban.bzi }可以显示DBAN选项,让你选择清除驱动器。当心,因为它仍然十分危险。小结一下,对于ISO文件和Grub有很多事情可做:从快速live会话到一键毁灭,都可以满足你。之后,你也可以试试启动一些针对隐私方面的发行版,如Tails。

Spring核心框架体系结构

Python正则表达式re模块简明笔记

如何写出兼容性很好的页面

探讨以S8号码归属设置对个人隐私的影响(号码归属设置及隐私保护)

C#开发人员应该知道的13件事情

能让你少写1000行代码的20个正则表达式

CES 2017 十大趋势,这些将影响未来科技走向

友情链接

滇ICP备2023006006号-33