Tensorflow 自带可视化Tensorboard使用方法(附项目代码)


Posted in Python onFebruary 10, 2018

Tensorboard:

如何更直观的观察数据在神经网络中的变化,或是已经构建的神经网络的结构。上一篇文章说到,可以使用matplotlib第三方可视化,来进行一定程度上的可视化。然而Tensorflow也自带了可视化模块Tensorboard,并且能更直观的看见整个神经网络的结构。

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

上面的结构图甚至可以展开,变成:

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

使用:

结构图:

with tensorflow .name_scope(layer_name):

直接使用以上代码生成一个带可展开符号的一个域,并且支持嵌套操作:

with tf.name_scope(layer_name): 
  with tf.name_scope('weights'):

节点一般是变量或常量,需要加一个“name=‘'”参数,才会展示和命名,如:

with tf.name_scope('weights'): 
  Weights = tf.Variable(tf.random_normal([in_size,out_size]))

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

结构图符号及意义:

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

变量:

变量则可使用Tensorflow.histogram_summary()方法:

tf.histogram_summary(layer_name+"/weights",Weights) #name命名,Weights赋值

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

常量:

常量则可使用Tensorflow.scalar_summary()方法:

tf.scalar_summary('loss',loss) #命名和赋值

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

展示:

最后需要整合和存储SummaryWriter:

#合并到Summary中 
merged = tf.merge_all_summaries() 
#选定可视化存储目录 
writer = tf.train.SummaryWriter("/目录",sess.graph)

merged也是需要run的,因此还需要:

result = sess.run(merged) #merged也是需要run的 
  writer.add_summary(result,i)

执行:

运行后,会在相应的目录里生成一个文件,执行:

tensorboard --logdir="/目录"

会给出一段网址:

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

浏览器中打开这个网址即可,因为有兼容问题,firefox并不能很好的兼容,建议使用Chrome。

Tensorflow 自带可视化Tensorboard使用方法(附项目代码)

常量在Event中,结构图在Graphs中,变量在最后两个Tag中。

附项目代码:

项目承接自上一篇文章(已更新至最新Tensorflow版本API r1.2):

import tensorflow as tf  
import numpy as np  
  
def add_layer(inputs,in_size,out_size,n_layer,activation_function=None): #activation_function=None线性函数  
  layer_name="layer%s" % n_layer  
  with tf.name_scope(layer_name):  
    with tf.name_scope('weights'):  
      Weights = tf.Variable(tf.random_normal([in_size,out_size])) #Weight中都是随机变量  
      tf.summary.histogram(layer_name+"/weights",Weights) #可视化观看变量  
    with tf.name_scope('biases'):  
      biases = tf.Variable(tf.zeros([1,out_size])+0.1) #biases推荐初始值不为0  
      tf.summary.histogram(layer_name+"/biases",biases) #可视化观看变量  
    with tf.name_scope('Wx_plus_b'):  
      Wx_plus_b = tf.matmul(inputs,Weights)+biases #inputs*Weight+biases  
      tf.summary.histogram(layer_name+"/Wx_plus_b",Wx_plus_b) #可视化观看变量  
    if activation_function is None:  
      outputs = Wx_plus_b  
    else:  
      outputs = activation_function(Wx_plus_b)  
    tf.summary.histogram(layer_name+"/outputs",outputs) #可视化观看变量  
    return outputs  
  
#创建数据x_data,y_data  
x_data = np.linspace(-1,1,300)[:,np.newaxis] #[-1,1]区间,300个单位,np.newaxis增加维度  
noise = np.random.normal(0,0.05,x_data.shape) #噪点  
y_data = np.square(x_data)-0.5+noise  
  
with tf.name_scope('inputs'): #结构化  
  xs = tf.placeholder(tf.float32,[None,1],name='x_input')  
  ys = tf.placeholder(tf.float32,[None,1],name='y_input')  
  
#三层神经,输入层(1个神经元),隐藏层(10神经元),输出层(1个神经元)  
l1 = add_layer(xs,1,10,n_layer=1,activation_function=tf.nn.relu) #隐藏层  
prediction = add_layer(l1,10,1,n_layer=2,activation_function=None) #输出层  
  
#predition值与y_data差别  
with tf.name_scope('loss'):  
  loss = tf.reduce_mean(tf.reduce_sum(tf.square(ys-prediction),reduction_indices=[1])) #square()平方,sum()求和,mean()平均值  
  tf.summary.scalar('loss',loss) #可视化观看常量  
with tf.name_scope('train'):  
  train_step = tf.train.GradientDescentOptimizer(0.1).minimize(loss) #0.1学习效率,minimize(loss)减小loss误差  
  
init = tf.initialize_all_variables()  
sess = tf.Session()  
#合并到Summary中  
merged = tf.summary.merge_all()  
#选定可视化存储目录  
writer = tf.summary.FileWriter("Desktop/",sess.graph)  
sess.run(init) #先执行init  
  
#训练1k次  
for i in range(1000):  
  sess.run(train_step,feed_dict={xs:x_data,ys:y_data})  
  if i%50==0:  
    result = sess.run(merged,feed_dict={xs:x_data,ys:y_data}) #merged也是需要run的  
    writer.add_summary(result,i) #result是summary类型的,需要放入writer中,i步数(x轴)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在Python中使用base64模块处理字符编码的教程
Apr 28 Python
TensorFlow中权重的随机初始化的方法
Feb 11 Python
Python cookbook(数据结构与算法)将序列分解为单独变量的方法
Feb 13 Python
在django中,关于session的通用设置方法
Aug 06 Python
python异常触发及自定义异常类解析
Aug 06 Python
python批量解压zip文件的方法
Aug 20 Python
Win10+GPU版Pytorch1.1安装的安装步骤
Sep 27 Python
pygame实现烟雨蒙蒙下彩虹雨
Nov 11 Python
如何运行带参数的python脚本
Nov 15 Python
Python 实现Numpy中找出array中最大值所对应的行和列
Nov 26 Python
Django自定义列表 models字段显示方式
Apr 03 Python
Python中如何处理常见报错
Jan 18 Python
tensorflow训练中出现nan问题的解决
Feb 10 #Python
用Eclipse写python程序
Feb 10 #Python
tensorflow建立一个简单的神经网络的方法
Feb 10 #Python
python取代netcat过程分析
Feb 10 #Python
浅谈Python黑帽子取代netcat
Feb 10 #Python
python3爬取淘宝信息代码分析
Feb 10 #Python
Python中property属性实例解析
Feb 10 #Python
You might like
PHP脚本的10个技巧(7)
2006/10/09 PHP
php smarty模版引擎中的缓存应用
2009/12/11 PHP
js获取height和width的方法说明
2013/01/06 Javascript
JS文本框不能输入空格验证方法
2013/03/19 Javascript
快速解决FusionCharts联动的中文乱码问题
2013/12/04 Javascript
js跨域请求的5中解决方式
2015/07/02 Javascript
jQuery动画显示和隐藏效果实例演示(附demo源码下载)
2015/12/31 Javascript
使用Bootstrap typeahead插件实现搜索框自动补全的方法
2016/07/07 Javascript
Vue-Access-Control 前端用户权限控制解决方案
2017/12/01 Javascript
js实现控制文件拖拽并获取拖拽内容功能
2018/02/17 Javascript
详解Vue中watch的详细用法
2018/11/28 Javascript
vue开发简单上传图片功能
2020/06/30 Javascript
[50:27]OG vs LGD 2018国际邀请赛淘汰赛BO3 第一场 8.26
2018/08/30 DOTA
Python之多线程爬虫抓取网页图片的示例代码
2018/01/10 Python
python3实现磁盘空间监控
2018/06/21 Python
Python OpenCV处理图像之图像像素点操作
2018/07/10 Python
Python django使用多进程连接mysql错误的解决方法
2018/10/08 Python
python/sympy求解矩阵方程的方法
2018/11/08 Python
Python中的异常处理try/except/finally/raise用法分析
2019/02/28 Python
使用selenium模拟登录解决滑块验证问题的实现
2019/05/10 Python
python中tkinter的应用:修改字体的实例讲解
2019/07/17 Python
简单了解python变量的作用域
2019/07/30 Python
python中的 zip函数详解及用法举例
2020/02/16 Python
python如何导入依赖包
2020/07/13 Python
美国最大的宠物用品零售商:PetSmart
2016/11/14 全球购物
校园之声广播稿
2014/01/31 职场文书
报考公务员诚信承诺书
2014/08/29 职场文书
夫妻婚内购房协议书
2014/10/05 职场文书
放假通知
2015/04/14 职场文书
兴趣班停课通知
2015/04/24 职场文书
上班迟到检讨书范文
2015/05/06 职场文书
工作服管理制度范本
2015/08/06 职场文书
2016年学校招生广告语
2016/01/28 职场文书
检讨书怎么写?
2019/06/21 职场文书
如何使用Python提取Chrome浏览器保存的密码
2021/06/09 Python
Spring Cloud OpenFeign模版化客户端
2022/06/25 Java/Android