pytorch下可采用visidom作为可视化工具
2018/9/18更新 感觉tensorboardX插件更好用,已转用https://github.com/lanpa/tensorboardX
更新:新版visdom0.1.7安装方式为:conda install -c srivasv visdom
pytorch下可采用visidom作为可视化工具
1. 安装
pip install visdomconda install visdom
启动
python -m visdom.server
在浏览器输入:http://localhost:8097/,即可启动
Note:
(1)有时安装了之后不能用,比如网页什么都没有,可尝试替换 Anaconda3\Lib\site-packages\visdom下的static文件夹(如果你用anaconda的话),是因为网络的原因,导致文件下载不全,文件链接链接:https://pan.baidu.com/s/1c4liqoK 密码:q1sx,在Linux(Ubuntu)下也是同样的处理,在Lib\site-packages\visdom下替换static文件,重启生效!!!!
(2)有时候启动visdom的时候,显示目标计算机拒绝等网络连接不成功,可用如下测试
from visdom import Visdomviz = Visdom()assert viz.check_connection()
主要是我是用了代理上网,导致我的IE浏览器的Internet选项被改变,如下图:
2. 可视化损失函数的示例
首先介绍一下visdom中的line()函数:
1) 画一条直线
from visdom import Visdomimport numpy as npviz = Visdom(env='my_wind')#设置环境窗口的名称是'my_wind',如果不设置名称就在main中tr_loss=list(range(100))viz.line(Y=np.array(tr_loss), opts=dict(showlegend=True))
在运行上面的程序之前,首先启动visdom,在cmd里输入python -m visdom.server,然后在浏览器里输入:http://localhost:8097/,默认是在main环境下:
上面的代码里,我们设置环境窗口的名称是'my_wind',所以我们需要打开my_wind环境,如下:
运行代码!
2) 如果要画多条直线
from visdom import Visdomimport numpy as npviz = Visdom(env='my_wind')#设置环境窗口的名称是'my_wind',如果不设置名称就在main中tr_loss=list(range(100))ts_loss=list(range(10,110))viz.line(Y=np.column_stack((np.array(tr_loss),np.array(ts_loss))), opts=dict(showlegend=True))
注意:以上变量的值在绘制前是确定了的
3)如果要绘制随程序运行逐渐产生的值,如在训练的时候,可以采用line的update方法
from visdom import Visdomimport numpy as npviz = Visdom(env='my_wind')x,y=0,0win = viz.line( X=np.array([x]), Y=np.array([y]), opts=dict(title='two_lines'))for i in range(10): x+=i y+=i viz.line( X=np.array([x]), Y=np.array([y]), win=win,#win要保持一致 update='append')
最后是深度学习训练过程中的损失函数可视化,参考的是pytorch实战指南里的可视化操作。
将损失函数的可视化放在visual_loss.py文件:
#coding:utf8import visdomimport timeimport numpy as np class Visualizer(object): def __init__(self, env='default', **kwargs): self.vis = visdom.Visdom(env=env, www.yundingyuLe.cn**kwargs) self.index = {} def plot_many_stack(self, d): ''' self.plot(www.yigou521.com'loss',1.00) ''' name=list(d.keys()) name_total=" ".join(name) x = self.index.get(name_www.thd540.com total, 0) val=list(d.values(www.baidu620.com/)) if len(val)==1: y=np.array(val) else: y=np.array(val).reshape(-1,len(val)) #print(x) self.vis.line(Y=y,X=np.ones(y.shape)*x, win=str(name_total),#unicode opts=dict(legend=name, title=name_total), update=None if x == 0 else 'append' ) self.index[name_total] = x + 1
在jupyter notebook——loss_visual_test.ipynb中进行函数功能测试:
from visual_loss import Visualizerfrom torchnet import meter#用 torchnet来存放损失函数,如果没有,请安装conda install torchnet'''训练前的模型、损失函数设置 vis = Visualizer(env='my_wind')#为了可视化增加的内容loss_meter = meter.AverageValueMeter()#为了可视化增加的内容for epoch in range(10): #每个epoch开始前,将存放的loss清除,重新开始记录 loss_meter.reset()#为了可视化增加的内容 model.train() for ii,(data,label)in enumerate(trainloader): ... out=model(input) loss=... loss_meter.add(loss.data[0])#为了可视化增加的内容 #loss可视化 #loss_meter.value()[0]返回存放的loss的均值 vis.plot_many_stack({'train_loss': loss_meter.value()[0]})#为了可视化增加的内容 '''#示例vis = Visualizer(env='my_wind')#为了可视化增加的内容loss_meter = meter.AverageValueMeter()#为了可视化增加的内容for epoch in range(10): loss_meter.reset()#为了可视化增加的内容 loss_meter.add(epoch)#假设loss=epoch vis.plot_many_stack({'train_loss': loss_meter.value()[0]})#为了可视化增加的内容 #如果还想同时显示test loss,如法炮制,并用字典的形式赋值,如下。还可以同时显示train和test accuracy #vis.plot_many_stack({'train_loss': loss_meter.value()[0],'test_loss':test_loss_meter.value()[0]})#为了可视化增加的内容
文件结构:
其中__init__.py为空
注意:我的visdom版本为
也不知道用的是哪个,通过conda install visdom安装的版本比较旧,官网的最新版本是
安装方式是在终端输入
conda install -c srivasv visdom
---------------------
本文来自 lxx516 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/LXX516/article/details/79019328?utm_source=copy
pytorch下可采用visidom作为可视化工具的更多相关文章
- mongodb在window下和linux下的部署 和 安装可视化工具
Windows安装 安装Mongo数据库: 在发布本文的时间官方提供的最新版本是:2.4.0 ,如果不做特殊声明,本教程所用的版本将会是这个版本. 第一步:下载安装包:http://www.mo ...
- Window下安装并使用InfluxDB可视化工具 —— InfluxDBStudio
下载 直接访问: https://github.com/CymaticLabs/InfluxDBStudio/releases/tag/v0.2.0-beta.1 创建or编辑InfluxDB 这个软 ...
- 2018 MAC下安装Redis和Redis可视化工具RDM并连接Redis
实验环境:一台mac V:10.13.6 一.安装redis brew install redis 二.安装RDM 直接下载安装rdm dmg文件 链接: https://pan.baidu.com/ ...
- MAC下安装REDIS和REDIS可视化工具RDM并连接REDIS
实验环境:一台mac V:10.13.6 一.安装redis brew install redis 二.安装RDM 直接下载安装rdm dmg文件 链接: https://pan.baidu.com/ ...
- Pytorch Visdom可视化工具
2018-12-04 14:05:49 Visdom是Facebook专门为PyTorch开发的一款可视化工具,其开源于2017年3月.Visdom十分轻量级,但却支持非常丰富的功能,能胜任大多数的科 ...
- pytorch visdom可视化工具学习—1—详细使用-1—基本使用函数
使用教程,参考: https://github.com/facebookresearch/visdom https://www.pytorchtutorial.com/using-visdom-for ...
- mac mamp环境 和linux下 安装redis 和可视化工具 Redis Desktop Manager
mac下安装 第一步:安装redis 1. brew install redis 2.启动服务/usr/local/opt/redis/bin/redis-server 3.配置redis密码访问 编 ...
- MongoDB在Windows下安装、Shell客户端的使用、Bson扩充的数据类型、MongoVUE可视化工具安装和简单使用、Robomongo可视化工具(2)
一.Windows 下载安装 1.去http://www.mongodb.org/downloads下载,mongodb默认安装在C:\Program Files\MongoDB目录下,到F:\Off ...
- Ubuntu14.04下Mongodb数据库可视化工具安装部署步骤(图文详解)(博主推荐)
不多说,直接上干货! 前期博客 Ubuntu14.04下Mongodb(离线安装方式|非apt-get)安装部署步骤(图文详解)(博主推荐) Ubuntu14.04下Mongodb官网安装部署步骤(图 ...
随机推荐
- 有关mybatis的动态sql
一般地,实现动态SQL都是在xml中使用等标签实现的. 我们在这里使用SQL构造器的方式, 即由abstract sql写出sql的过程, 当然感觉本质上还是一个StringBuilder, 来手动生 ...
- MYSQL内置函数总结
时间转换为字符串: SELECT date_format(Date, '%Y-%m-%d %H:%i:%s' ) AS TimeFROMtable o convert函数转换为字符串的时候不存在类型为 ...
- 在linux命令行下如何访问网址
1. wget Ubuntu系统自带,会将访问的首页下载到本地 admin@iZj6c9c6vaqj1i0a9j7h78Z:~$ wget www.baidu.com --2019-04-20 17: ...
- php循环a-z字母表
ord — 返回字符的 ASCII 码值 说明 int ord ( string $string ) 返回字符串 string 第一个字符的 ASCII 码值. 该函数是 chr() 的互补函数. ...
- kubernetes-平台日志收集(ELK)
使用ELK Stack收集Kubernetes平台中日志与可视化 K8S系统的组件日志 K8S Cluster里面部署的应用程序日志 日志系统: ELK安装 安装jdk [root@localhost ...
- JAVA - Annotation 注解 入门
Java注解提供了关于代码的一些信息,但并不直接作用于它所注解的代码内容.在这个教程当中,我们将学习Java的注解,如何定制注解,注解的使用以及如何通过反射解析注解. Java1.5引入了注解,当前许 ...
- 服务器上搭建flowvisor平台
之前全是在virtualbox上的Ubuntu虚拟机上测试的ovs以及pox, 现在我们开始在服务器上开始了 两台服务器上的ovs均是1.4.6版本 遇到一个问题:之前装的ovs down了 然后什么 ...
- Java基础面试操作题: 线程问题,写一个死锁(原理:只有互相都等待对方放弃资源才会产生死锁)
package com.swift; public class DeadLock implements Runnable { private boolean flag; DeadLock(boolea ...
- logging console not work
配置 log 信息传输到控制台 参考官网:https://docs.djangoproject.com/en/2.1/topics/logging/ By default, this config o ...
- 酷炫的3D照片墙
今天给大家分享的案例是酷炫的3D照片墙 这个案例主要是通过 CSS3 和原生的 JS 来实现的,接下来我给大家分享一下这个效果实现的过程.博客上不知道怎么放本地视频,所以只能放两张效果截图了. 1.实 ...