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

作者:傲慢灬 时间:2023-10-13 00:37:40 

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轴)

来源:http://blog.csdn.net/jerry81333/article/details/53004903

标签:Tensorflow,可视化
0
投稿

猜你喜欢

  • python tqdm用法及实例详解

    2023-11-03 01:54:53
  • 使用python批量转换文件编码为UTF-8的实现

    2023-03-07 03:19:41
  • Xml中SelectSingleNode方法中的xpath用法

    2010-01-30 12:46:00
  • JavaScript学习笔记整理_用于模式匹配的String方法

    2024-06-05 09:53:02
  • Python生成rsa密钥对操作示例

    2021-08-25 03:43:31
  • python访问系统环境变量的方法

    2023-06-16 00:30:39
  • Python实现如何根据文件后缀进行分类

    2023-12-11 07:46:40
  • Python 中 Shutil 模块详情

    2022-12-20 15:25:58
  • vue移动端的左右滑动事件详解

    2024-06-05 09:20:33
  • python上下文管理器协议的实现

    2023-08-28 18:32:18
  • Python利用机器学习算法实现垃圾邮件的识别

    2021-02-24 04:31:04
  • SQL Server 2012 开窗函数

    2024-01-28 01:39:15
  • python GUI库图形界面开发之PyQt5状态栏控件QStatusBar详细使用方法实例

    2021-12-11 14:20:36
  • mysql查询的控制语句图文详解

    2024-01-27 00:02:38
  • pytorch中的广播语义

    2023-04-22 15:16:36
  • python pexpect ssh 远程登录服务器的方法

    2021-07-10 22:28:53
  • python中使用多线程改进flask案例

    2022-11-07 05:44:55
  • 对python中的iter()函数与next()函数详解

    2022-01-29 19:05:36
  • Python利用Turtle绘制Technoblade的示例代码

    2023-08-23 22:43:01
  • Python执行外部命令subprocess的使用详解

    2023-01-21 14:57:49
  • asp之家 网络编程 m.aspxhome.com