PyTorch可视化利器Visdom

简介: 在深度学习领域,模型训练是一个必须的过程,因此常常需要实时监听并可视化一些数据,如损失值Loss,正确率Acc等。在Tensorflow中,最常使用的工具非Tensorboard莫属;在Pytorch中,也有类似的TensorboardX,但据说其在张量数据加载的效率方面不如visdom。visdom是FaceBook开发的一款可视化工具github地址,其实质是一款在网页端的web服务器,对Pytorch的支持较好, 可以直接对Tensor进行操作。

1.介绍


 在深度学习领域,模型训练是一个必须的过程,因此常常需要实时监听并可视化一些数据,如损失值Loss,正确率Acc等。在Tensorflow中,最常使用的工具非Tensorboard莫属;在Pytorch中,也有类似的TensorboardX,但据说其在张量数据加载的效率方面不如visdom。visdom是FaceBook开发的一款可视化工具github地址,其实质是一款在网页端的web服务器,对Pytorch的支持较好, 可以直接对Tensor进行操作。


dc9c2394741ac31e93281b299dc2d7ab.gif


2.安装与启动


2.1 安装


pip install visdom

a0d7d38091d2432391be063fa14af38e.png


2.2 启动


与TensorFlow的TensorBoard一样,如果要使用Visdom,就要先在终端开启监听命令


python -m visdom.server


Visdom成功启动后,会返回一个网址,根据显示的网址然后在浏览器里输入:http://localhost:8097 进行登录


b83184bc88a94793b843fc476fc6d621.png


打开网址便可以看到


03d593a8c1eb4682a0c9f5317cc0cf72.png


如果你想修改端口号


 visdom -port XXXX #改成你想要的端口号


3.相关概念


3.1 窗口


9bb6d586690f4ddaabb4538ac48de26b.png


用户界面以空白的形式开始 - 您可以用图表,图像和文本填充它。出现在窗口中的内容,您可以拖放,调整大小和销毁。窗口存在于envs中并且envs的状态通过sessions存储。你可以下载窗口中的内容 - 包括SVG中的图。


3.2 回调


python Visdom支持实现窗口上的回调。Demo以可编辑文本板的形式显示。这些回调函数允许Visdom对象接收并响应前端发生的事件。


您可以通过向事件处理程序代码添加一个函数来为事件订阅窗口,该函数用于通过调用viz.register_event_handler(handler, win_id)处理程序和窗口标识调用要订阅的窗口标识。多个处理程序可以注册到同一个窗口。您可以使用viz.clear_event_handlers(win_id)删除窗口中的所有事件处理程序。当在窗口发生一个事件时,你的回调将在包含以下内容的字典上被调用:


event_type:以下事件类型之一

pane_data:该窗口的所有存储内容包括布局和内容。

eid:当前的环境ID

target:调用事件的窗口ID

其他参数定义如下。


现在支持两个回调事件:


Close - 关闭窗口时触发。返回只有前述字段的字典。

KeyPress - 按下某个键时触发。包含其他参数:

key - 按下的键的字符串表示形式(应用SHIFT等状态修饰符)

key_code - 按下键的javascript事件键码(无修饰符)


4.可视化实战


4.1 加载相关库


from visdom import Visdom
import numpy as np
import time


4.2 可视化步骤


Visdom可视化神经网络的训练过程大致分为3步:


1.实例化一个窗口


2.初始化窗口的信息


3.更新监听的信息


4.3 可视化单一数据


只可视化train_loss的变化


# 实例化一个窗口
wind = Visdom()
# 初始化窗口信息
wind.line([0.], # Y的第一个点的坐标
      [0.], # X的第一个点的坐标
      win = 'train_loss', # 窗口的名称
      opts = dict(title = 'train_loss') # 图像的标例
)
# 更新数据
for step in range(10):
  # 随机获取loss,这里只是模拟实现
  loss = np.random.randn() * 0.5 + 2
  wind.line([loss],[step],win = 'train_loss',update = 'append')
  time.sleep(0.5)


结果


3c9f8897970845548e70e3d549863b16.png


4.4 可视化多类数据


可视化train_loss和acc


# 实例化窗口
wind = Visdom()
# 初始化窗口参数
wind.line([{0.,0.]],[0.],win = 'train',opts = dict(title = 'loss&acc',legend = ['loss','acc']))
# 更新窗口数据
for step in range(10):
  loss = 0.2 * np.random.randn() + 1
  acc = 0.1 * np.random.randn() + 0.5
  wind.line([[loss, acc]],[step],win = 'train',update = 'append')
  time.sleep(0.5)

1a87dfa9c69d411b827bffd781a3654f.png


4.5 可视化图像


viz = Visdom()
# data是一个tensor,直接在x这个标识的窗口中显示出来
viz.images(data.view(-1,1,28,28),win = 'x')
# str(pred.detach().cpu().numpy())直接将数据转换成字符串打印出来,表示为pred,并且赋予了title = 'pred'可见名字
viz.text(str(pred.detach().cpu().numpy()),win = 'pred',opts = dict(title = 'pred'))

dff64b9c79564acdbcacec03d5c8d52a.png


5. Visdom API


Visdom支持下列API。由Plotly提供可视化支持。


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 : 序列化状态

vis.close :通过ID关闭一个窗口

vis.win_exists :通过id检查一个窗口是否已经存在

vis.check_connection:检查服务器是否连接

关于上述API更详尽的解释将在下面给出。


vis.image


这个函数绘制一个img。它将 包含图像的CxHxW张量作为输入img。


以下opts是支持的:


opts.jpgquality:JPG质量(number0-100;默认= 100)

opts.caption:图像的标题

vis.images:这个函数绘制一个列表images。它需要一个输入B x C x H x W张量或list of images全部相同的大小。它使大小的图像(B / Nrow,Nrow)的网格。


以下参数和opts支持:


nrow:连续的图像数量

padding:在图像周围填充,四边均匀填充

opts.jpgquality:JPG质量(number0-100;默认= 100)

opts.caption:图像的标题


vis.text


这个功能在一个盒子里打印文本。你可以使用它来嵌入任意的HTML。它需要输入一个text字符串。opts目前没有具体的支持。


vis.video


此功能播放视频。它输入视频的文件名videofile或一个LxCxHxW尺度的tensor(在Lua)或或LxHxWxC尺度的tensor包含视频作为输入的所有帧(在Python)。该功能不支持任何情节特定opts。


以下opts是支持的:


opts.fps:视频的FPS(integer>0;默认= 25)

注意:使用tensor输入需要安装并运行ffmpeg。您播放视频的能力可能取决于您使用的浏览器:您的浏览器必须支持OGG容器中的Theano编解码器(Chrome支持此功能)。


vis.svg


这个函数绘制一个SVG对象。它将SVG字符串svgstr或SVG文件的名称作为输入svgfile。该功能不支持任何特定的 opts。


vis.save


这个功能保存envs在visdom服务器上的活动。它需要输入一个列表(在Python中)或表(在lua中)env id被保存。


vis.scatter


此功能绘制2D或3D散点图。它需要输入一个Nx2或 一个Nx3张量X来指定N散点图中点的位置。一个可选的N张量,Y其中包含离散的标签,范围介于1和K可以指定 - 标签将反映在标记的颜色。以下opts是支持的:


opts.colormap :colormap(string; default = ‘Viridis’)

opts.markersymbol:标志符号(string;默认= ‘dot’)

opts.markersize :标记大小(number;默认= ‘10’)

opts.markercolor:每个标记的颜色。(torch.*Tensor; default = nil)

opts.legend :table包含图例名称

opts.markercolor:是一个整数值的张量。张量可以是大小N或N x 3或K或K x 3。


尺寸张量N:每个数据点的单一强度值。0 =黑色,255 =红色

尺寸张量N x 3:每个数据点的红色,绿色和蓝色强度。0,0,0 =黑色,255,255,255 =白色

尺寸K和张量K x 3:与每个数据点具有唯一的颜色不同,对于特定标签的所有点共享相同的颜色。


vis.line


这个函数绘制一个线条图。它需要输入一个N或NxM张量 Y来指定要绘制的M线(连接N点)的值。它还采用可选的X张量来指定相应的x轴值; X可以是一个N张量(在这种情况下,所有的线将共享相同的x轴值)或具有相同的大小Y。


以下opts是支持的:


opts.fillarea :填充行(boolean)以下的区域

opts.colormap :colormap(string; default = ‘Viridis’)

opts.markers :show markers(boolean; default = false)

opts.markersymbol:标志符号(string;默认= ‘dot’)

opts.markersize :标记大小(number;默认= ‘10’)

opts.legend :table包含图例名称


vis.updateTrace


此功能允许更新现存的线或散点图的数据。


用户可以指定name一个现有的轨迹,如果他们想要添加到它的话,还可以指定一个新name的轨迹。默认情况下,如果在首次创建时没有指定图例,那么图例name中的行的索引是。


如果没有name指定,所有的痕迹应该被更新。跟踪更新数据全部NaN被忽略; 这可以用于掩蔽更新。


该append参数确定更新数据是否应附加到或替换现有数据。


没有,opts因为他们被假定为从指定的情节继承。


vis.stem


这个函数绘制一个干图。它需要输入一个N或NxM张量 X来指定时间序列中的N点的值M。包含时间戳的可选N或NxM张量Y也可以被指定; 如果Y是N张量,则M假定所有时间序列具有相同的时间戳。


以下opts是支持的:


opts.colormap:colormap(string; default = ‘Viridis’)

opts.legend :table包含图例名称


vis.heatmap


这个函数绘制一个热图。它需要输入NxM张量X来指定热图中每个位置的值。


以下opts是支持的:


opts.colormap :colormap(string; default = ‘Viridis’)

opts.xmin :剪辑最小值(number;默认= X:min())

opts.xmax :剪辑最大值(number;默认= X:max())

opts.columnnames:table包含x轴标签

opts.rownames :table包含y轴标签


vis.bar


这个函数绘制一个规则的,堆积的或分组的条形图。它需要输入一个N或NxM张量X来指定每个条的高度。如果X包含M列,则对应于每行的值将被堆叠或分组(取决于如何opts.stacked设置)。除此之外X,还可以指定一个(可选的)N张量Y,其中包含相应的x轴值。


opts目前支持以下特定于图表的功能:


opts.rownames:table包含x轴标签

opts.stacked :堆栈中的多个列 X

opts.legend :table包含图例标签


vis.histogram


该功能绘制指定数据的直方图。它需要输入一个N张量X来指定构建直方图的数据。


opts目前支持以下特定于图表的功能:


opts.numbins:垃圾箱数量(number;默认= 30)


vis.boxplot


此函数绘制指定数据的箱形图。它需要输入一个N或一个NxM张量X来指定N构造M箱形图的数据值。


opts目前支持以下特定于图表的功能:


opts.legend:中的每一列的标签 X


vis.surf


这个函数绘制一个曲面图。它需要输入NxM张量X 来指定曲面图中每个位置的值。


以下opts是支持的:


opts.colormap:colormap(string; default = ‘Viridis’)

opts.xmin :剪辑最小值(number;默认= X:min())

opts.xmax :剪辑最大值(number;默认= X:max())


vis.contour


这个函数绘制一个等高线图。它需要输入一个NxM张量X 来指定轮廓图中每个位置的值。


以下opts是支持的:


opts.colormap:colormap(string; default = ‘Viridis’)

opts.xmin :剪辑最小值(number;默认= X:min())

opts.xmax :剪辑最大值(number;默认= X:max())


vis.quiver


此函数绘制,其中的箭头的方向和长度由所确定的颤动情节NxM张量X和Y。两个可选的NxM 张量gridX,gridY可以提供指定箭头的偏移量; 默认情况下,箭头将在常规网格上完成。


以下opts是支持的:


opts.normalize:最长箭头的长度(number)

opts.arrowheads:显示箭头(boolean;默认= true)


vis.mesh


此函数从一个Nx2或一个Nx3矩阵中定义的一组顶点绘制一个网格图 X,以及在一个可选Mx2或 Mx3矩阵中定义的多边形Y。


以下opts是支持的:


opts.color:color(string)

opts.opacity:多边形不透明度(number介于0和1之间)


通用opts


绘图功能采用可选opts表格作为输入,可用于更改绘图属性(通用或特定于绘图)的属性。所有输入参数都在一个表中指定; 输入参数是基于它们在输入表中具有的键的匹配。


以下opts是通用的,它们对于所有可视化(除了plot.image和plot.text)是相同的:


opts.title :图标题

opts.width :图宽度

opts.height :身高

opts.showlegend :显示图例(true或false)

opts.xtype :x轴的类型(‘linear’或’log’)

opts.xlabel :x轴的标签

opts.xtick :在x轴上显示刻度(boolean)

opts.xtickmin :先在x轴上打勾(number)

opts.xtickmax :在x轴上的最后一个勾号(number)

opts.xtickvals :在x轴(蜱位置table的number多个)

opts.xticklabels:蜱上x轴(标签table的string多个)

opts.xtickstep :x轴上的滴答声之间的距离(number)

opts.ytype :y轴的类型(‘linear’或’log’)

opts.ylabel :y轴的标签

opts.ytick :在y轴上显示刻度(boolean)

opts.ytickmin :首先在y轴上打勾(number)

opts.ytickmax :最后在y轴上打勾(number)

opts.ytickvals :在y轴的刻度位置(table的number多个)

opts.yticklabels:蜱上y轴标签(table的string多个)

opts.ytickstep :Y轴上的刻度之间的距离(number)

opts.marginleft :左边距(以像素为单位)

opts.marginright :右边距(以像素为单位)

opts.margintop :顶部边距(以像素为单位)

opts.marginbottom:底部边距(以像素为单位)

目录
相关文章
|
8月前
|
机器学习/深度学习 数据可视化 PyTorch
PyTorch基础之模型保存与重载模块、可视化模块讲解(附源码)
PyTorch基础之模型保存与重载模块、可视化模块讲解(附源码)
170 1
|
数据可视化 PyTorch 算法框架/工具
Pytorch可视化Visdom、tensorboardX和Torchvision
Pytorch可视化Visdom、tensorboardX和Torchvision
104 0
|
3月前
|
并行计算 PyTorch TensorFlow
Ubuntu安装笔记(一):安装显卡驱动、cuda/cudnn、Anaconda、Pytorch、Tensorflow、Opencv、Visdom、FFMPEG、卸载一些不必要的预装软件
这篇文章是关于如何在Ubuntu操作系统上安装显卡驱动、CUDA、CUDNN、Anaconda、PyTorch、TensorFlow、OpenCV、FFMPEG以及卸载不必要的预装软件的详细指南。
5319 3
|
6月前
|
数据可视化 计算机视觉 异构计算
确保您已经安装了必要的库,包括`torch`、`torchvision`、`segmentation_models_pytorch`、`PIL`(用于图像处理)和`matplotlib`(用于结果可视化)。您可以使用pip来安装这些库:
确保您已经安装了必要的库,包括`torch`、`torchvision`、`segmentation_models_pytorch`、`PIL`(用于图像处理)和`matplotlib`(用于结果可视化)。您可以使用pip来安装这些库:
|
6月前
|
数据可视化 PyTorch TensorFlow
PyTorch SummaryWriter TensorBoard 中进行可视化
PyTorch SummaryWriter TensorBoard 中进行可视化
|
8月前
|
机器学习/深度学习 数据可视化 PyTorch
PyTorch小技巧:使用Hook可视化网络层激活(各层输出)
这篇文章将演示如何可视化PyTorch激活层。可视化激活,即模型内各层的输出,对于理解深度神经网络如何处理视觉信息至关重要,这有助于诊断模型行为并激发改进。
195 1
|
机器学习/深度学习 存储 数据可视化
PyTorch 神经网络模型可视化(Netron)
PyTorch 神经网络模型可视化(Netron)
1891 0
|
机器学习/深度学习 数据可视化 前端开发
PyTorch中的可视化工具
PyTorch中的可视化工具
140 0
|
机器学习/深度学习 数据可视化 PyTorch
【深度学习】pytorch使用tensorboard可视化实验数据
【深度学习】pytorch使用tensorboard可视化实验数据
242 0
【深度学习】pytorch使用tensorboard可视化实验数据
|
3月前
|
算法 PyTorch 算法框架/工具
Pytorch学习笔记(九):Pytorch模型的FLOPs、模型参数量等信息输出(torchstat、thop、ptflops、torchsummary)
本文介绍了如何使用torchstat、thop、ptflops和torchsummary等工具来计算Pytorch模型的FLOPs、模型参数量等信息。
428 2