在PyTorch中使用Visdom可视化工具

作者阿里云代理 文章分类 分类:windows图文教程 阅读次数 已被围观 744

一、Visdom

pytorch Visdom可视化,是一个灵活的工具,用于创建,组织和共享实时丰富数据的可视化。支持TorchNumpy

二、概述

Visdom旨在促进(远程)数据的可视化,重点是支持科学实验。

为您自己和您的合作者广播情节,图像和文字的可视化。

以编程方式或通过UI组织可视化空间,为实时数据创建仪表板,检查实验结果或调试实验代码。

三、概念

Visdom有一套简单的功能,可以组成不同的案例。

1、窗口

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

提示:您可以使用浏览器的缩放比例来调整UI的比例。

1、回调

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事件键码(无修饰符)

四、环境

您可以使用envs划分您的可视化空间。默认情况下,每个用户将有一个env调用main。新的envs可以在用户界面或以编程方式创建。envs的状态是长期保存的。

您可以通过URL访问特定的ENV http://localhost.com:8097/env/main。如果您的服务器托管在网上,直接分享你的网址那样其他人也可以看到您的可视化

管理 Envs :您的envs在服务器初始化时加载,默认情况下从$HOME/.visdom/。自定义路径可以作为cmd行参数传递。通过.json从环境中删除相应的文件来删除Envs 。

1、选择环境

从主页面可以使用环境选择器在不同的环境之间切换。选择新环境将向服务器查询该环境中存在的图。

2、清除环境

您可以使用橡皮擦按钮来删除环境中当前的所有内容。这将关闭该环境的情节窗口,并且保留空白的新窗口。

3、管理环境

按下文件夹图标将打开一个对话框,允许您复制或强制保存当前环境,或删除当前环境的所有内容。该功能的使用在State一节中有充分的描述。

Env文件: 您的envs在服务器初始化时加载,默认情况下为$HOME/.visdom/。自定义路径可以作为cmd行参数传递。通过使用删除按钮或从环境中删除相应的.json文件来删除Envs

五、状态

当你创建了几个可视化后,状态保持不变。服务器自动缓存您的可视化 —— 如果你重新加载页面,可视化就会再现。

· save:您可以使用save按钮手动执保存。这将序列化env的状态(以JSON形式到磁盘),包括窗口位置。您可以以env编程方式保存。 这有助于更为复杂的配置有意义的可视化,例如数据丰富的演示、模型训练仪表板或系统实验。这也使得它们易于共享和重用。

· Fork:如果你输入一个新的env名字,保存将会创建一个新的env - 有效地分割以前的env

六、过滤

您可以使用filter动态筛选env中的窗口 - 只要提供一个正则表达式来匹配您要显示的窗口的标题。这可以有助于涉及env与许多窗口的使用情况,例如系统地检查实验结果。

注意:如果您保存了当前视图,则清除过滤器后视图将被恢复。

七、安装

需要Python 2.7/3(和可选的Torch7

# 安装visdompip install visdom # 安装Torch客户端luarocks install visdom # 从源代码安装pip install -e .# 如果上述问题出现,您可以尝试下面的 easy_install . # 从源代码安装Torch客户端(从目录中)luarocks make

八、用法

启动服务器(可能是在screentmux中):

python -m visdom.server

现在可以通过访问http://localhost:8097或者127.0.0.1:8097浏览器访问Visdom ,或者指定您自己的主机地址。

如果上述操作不起作用,请将以下行添加到本地 ~/.ssh/config:LocalForward 127.0.0.1:8097 127.0.0.1:8097

1、命令行选项

以下选项可以提供给服务器:

· -port:运行服务器的端口。

· -env_path:重新加载序列化会话的路径。

· -logging_level:记录级别(默认=INFO)。接受标准文本和数字记录值。

2Python中的使用示例

1. import visdom2. import numpy as np3. vis = visdom.Visdom()4. vis.text('Hello, world!')5. vis.image(np.ones((3, 10, 10)))

3Torch中的使用例子

1. require 'image'2. vis = require 'visdom'()3. vis:text{text = 'Hello, world!'}4. vis:image{img = image.fabio()}

有些用户在将Lua客户端连接到Visdom服务器时报告了问题。可能是因为你关闭了IPv6

1. vis = require 'visdom'()2. vis.ipv6 = false  -- switches off IPv63. vis:text{text = 'Hello, world!'}

Demos

1. python example/demo.py2. th example/demo1.lua3. th example/demo2.lua

九、API

有关快速入门的功能visdom,请查看example目录,或阅读下面的详细信息。

1、基础

Visdom提供以下基本的可视化功能:

· vis.image:图片

· vis.images:图像列表

· vis.text:任意的HTML

· vis.video:视频

· vis.svg:SVG对象

· vis.save:序列化状态服务器端

2、绘制

我们已经封装了几种常见的绘图类型,以便轻松创建基本可视化。这些可视化由Plotly提供支持

目前支持以下API

· vis.scatter:2D3D散点图

· vis.line:线图

· vis.updateTrace:更新现有的线/散点图

· vis.stem:干地块

· vis.heatmap:热图地块

· vis.bar:条形图

· vis.histogram:直方图

· vis.boxplot:盒子

· vis.surf:表面重复

· vis.contour:等高线图

· vis.quiver:颤抖的情节

· vis.mesh:网格图

3、通用情节

请注意,服务器API遵守Plotly约定datalayout对象,以便您可以生成自己的任意Plotly可视化对象:

1. import visdom2. vis = visdom.Visdom()3. 4. trace = dict(x=[1, 2, 3], y=[4, 5, 6], mode="markers+lines", type='custom'5.              marker={'color': 'red', 'symbol': 104, 'size': "10"},6.              text=["one", "two", "three"], name='1st Trace')7. layout = dict(title="First Plot", xaxis={'title': 'x1'}, yaxis={'title': 'x2'})8. 9. vis._send({'data': [trace], 'layout': layout, 'win': 'mywin'})

4、其他

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

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

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

十、细节

1、基本

vis.image

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

以下opts是支持的:

· opts.jpgqualityJPG质量(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.jpgqualityJPG质量(number0-100;默认= 100

· opts.caption:图像的标题

vis.text

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

vis.video

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

以下opts是支持的:

· opts.fps:视频的FPSinteger>0;默认= 25

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

vis.svg

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

vis.save

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

绘制

关于包装绘图功能的更多细节在下面给出。

绘图函数的确切输入是不一样的,尽管其中大多数输入的张X量比包含数据的张量Y和包含可选数据变量(如标签或时间戳)的(可选的)张量要大。所有的绘图功能都可以作为一个可选项win,用来绘制到一个特定的窗口; 每个绘图函数也返回win它绘制的窗口。还可以指定env 可视化应该添加到的窗口。

vis.scatter

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

· opts.colormap colormapstring; default = 'Viridis'

· opts.markersymbol:标志符号(string;默认= 'dot'

· opts.markersize :标记大小(number;默认= '10'

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

· opts.legend table包含图例名称

opts.markercolor是一个整数值的张量。张量可以是大小NN x 3KK x 3

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

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

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

vis.line

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

以下opts是支持的:

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

· opts.colormap colormapstring; default = 'Viridis'

· opts.markers show markersboolean; default = false

· opts.markersymbol:标志符号(string;默认= 'dot'

· opts.markersize :标记大小(number;默认= '10'

· opts.legend table包含图例名称

vis.updateTrace

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

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

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

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

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

vis.stem

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

以下opts是支持的:

· opts.colormapcolormapstring; default = 'Viridis'

· opts.legend table包含图例名称

vis.heatmap

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

以下opts是支持的:

· opts.colormap colormapstring; default = 'Viridis'

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

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

· opts.columnnamestable包含x轴标签

· opts.rownames table包含y轴标签

vis.bar

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

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

· opts.rownamestable包含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.colormapcolormapstring; default = 'Viridis'

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

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

vis.contour

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

以下opts是支持的:

· opts.colormapcolormapstring; default = 'Viridis'

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

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

vis.quiver

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

以下opts是支持的:

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

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

vis.mesh

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

以下opts是支持的:

· opts.colorcolorstring

· opts.opacity:多边形不透明度(number介于01之间)

定制情节

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

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

· opts.title :图标题

· opts.width :图宽度

· opts.height :身高

· opts.showlegend :显示图例(truefalse

· opts.xtype x轴的类型('linear''log'

· opts.xlabel x轴的标签

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

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

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

· opts.xtickvals :在x轴(蜱位置tablenumber多个)

· opts.xticklabels:蜱上x轴(标签tablestring多个)

· 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轴的刻度位置(tablenumber多个)

· opts.yticklabels:蜱上y轴标签(tablestring多个)

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

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

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

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

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

其他选项是可视化特定的,并在功能的文档中进行了描述。

其他

vis.close

这个函数关闭一个特定的窗口。它需要输入窗口ID win和环境ID eid。使用winNone关闭所有窗口的环境。

vis.win_exists

这个函数返回一个布尔值,表示win服务器上是否存在一个窗口。如果出现错误,则返回无。

可选参数:

· env:搜索窗口的环境。默认是None

vis.check_connection

这个函数返回一个布尔值,表示服务器是否连接。

版权声明:本文内容转发自阿里云社区,由阿里云实名注册用户自发贡献版权归原作者所有本站不拥有其著作权,亦不承担相应法律责任。如果您发现本中有涉嫌抄袭的内容,请联系站内客服,本将立刻删除涉嫌侵权内容。

本公司销售:阿里云新/老客户,只要购买阿里云,即可享受折上折优惠!>

我有话说: