tensorboard可以将训练过程中的一些参数可视化,比如我们最关注的loss值和accuracy值,简单来说就是把这些值的变化记录在日志里,然后将日志里的这些数据可视化。

首先运行训练代码

  1. #coding:utf-8
  2. import tensorflow as tf
  3. from tensorflow.examples.tutorials.mnist import input_data
  4.  
  5. #载入数据集
  6. mnist = input_data.read_data_sets("MNIST_data", one_hot=True)
  7. #每个批次的大小
  8. batch_size = 100
  9. #计算一共有多少个批次
  10. n_batch = mnist.train.num_examples // batch_size
  11.  
  12. #参数概要 传入一个参数可以计算这个参数的各个相关值
  13. def variable_summaries(var):
  14. with tf.name_scope('summaries'):
  15. mean = tf.reduce_mean(var)
  16. tf.summary.scalar('mean', mean)#平均值
  17. with tf.name_scope('stddev'):
  18. stddev = tf.sqrt(tf.reduce_mean(tf.square(var - mean)))
  19. tf.summary.scalar('stddev', stddev)#标准差
  20. tf.summary.scalar('max', tf.reduce_max(var))#最大值
  21. tf.summary.scalar('min', tf.reduce_min(var))#最小值
  22. tf.summary.histogram('histogram', var)#直方图
  23.  
  24. with tf.name_scope('input'):
  25. #定义两个placeholder
  26. x = tf.placeholder(tf.float32, [None,784],name='x-input') #输入图像
  27. y = tf.placeholder(tf.float32, [None,10],name='y-input') #输入标签
  28. #创建一个简单的神经网络 784个像素点对应784个数 因此输入层是784个神经元 输出层是10个神经元 不含隐层
  29. #最后准确率在92%左右
  30. with tf.name_scope('layer'):
  31. with tf.name_scope('wights'):
  32. W = tf.Variable(tf.zeros([784,10]),name = 'W') #生成784行 10列的全0矩阵
  33. variable_summaries(W)
  34. with tf.name_scope('biases'):
  35. b = tf.Variable(tf.zeros([1,10]),name='b')
  36. variable_summaries(b)
  37. with tf.name_scope('softmax'):
  38. prediction = tf.nn.softmax(tf.matmul(x,W)+b)
  39.  
  40. #二次代价函数
  41. #loss = tf.reduce_mean(tf.square(y-prediction))
  42. #交叉熵损失
  43. with tf.name_scope('loss'):
  44. loss =tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(labels =y,logits = prediction))
  45. tf.summary.scalar('loss',loss)
  46. #使用梯度下降法
  47. #train_step = tf.train.GradientDescentOptimizer(0.2).minimize(loss)
  48. train_step = tf.train.AdamOptimizer(1e-3).minimize(loss) #学习率一般设置比较小 收敛速度快
  49.  
  50. #初始化变量
  51. init = tf.global_variables_initializer()
  52.  
  53. #结果存放在布尔型列表中
  54. #argmax能给出某个tensor对象在某一维上的其数据最大值所在的索引值
  55. with tf.name_scope('accuracy'):
  56. with tf.name_scope('correct_prediction'):
  57. correct_prediction = tf.equal(tf.argmax(y,1), tf.argmax(prediction,1))
  58. with tf.name_scope('accuracy'):
  59. accuracy = tf.reduce_mean(tf.cast(correct_prediction,tf.float32))
  60. tf.summary.scalar('accuracy',accuracy)
  61. #合并所有的summary
  62. merged = tf.summary.merge_all()
  63. with tf.Session() as sess:
  64. sess.run(init)
  65. writer = tf.summary.FileWriter('/home/xxx/logs/',sess.graph) #定义记录日志的位置
  66. for epoch in range(50):
  67. for batch in range(n_batch): #
  68. batch_xs,batch_ys = mnist.train.next_batch(batch_size)
  69. summary,_ = sess.run([merged,train_step],feed_dict={x:batch_xs,y:batch_ys})
  70. writer.add_summary(summary,epoch) #将summary epoch 写入到writer
  71. acc = sess.run(accuracy,feed_dict={x:mnist.test.images, y:mnist.test.labels})
  72. print ("Iter " + str(epoch) + ",Testing Accuracy " + str(acc))

注意我将训练日志保存在 /home/xxx/logs/ 路径下,打开终端,输入以下命令 tensorboard --logdir=/home/xxx/logs/ 如下图所示

在浏览器中输入127.0.0.1:6006,可以看到可视化效果,如loss和accuracy的变化折线图

Tensorflow学习教程------tensorboard网络运行和可视化的更多相关文章

  1. Tensorflow学习教程------读取数据、建立网络、训练模型,小巧而完整的代码示例

    紧接上篇Tensorflow学习教程------tfrecords数据格式生成与读取,本篇将数据读取.建立网络以及模型训练整理成一个小样例,完整代码如下. #coding:utf-8 import t ...

  2. Tensorflow学习教程------过拟合

    Tensorflow学习教程------过拟合   回归:过拟合情况 / 分类过拟合 防止过拟合的方法有三种: 1 增加数据集 2 添加正则项 3 Dropout,意思就是训练的时候隐层神经元每次随机 ...

  3. Tensorflow学习教程------代价函数

    Tensorflow学习教程------代价函数   二次代价函数(quadratic cost): 其中,C表示代价函数,x表示样本,y表示实际值,a表示输出值,n表示样本的总数.为简单起见,使用一 ...

  4. tensorflow学习笔记----TensorBoard讲解

    TensorBoard简介 TensorBoard是TensorFlow自带的一个强大的可视化工具,也是一个Web应用程序套件.TensorBoard目前支持7种可视化,Scalars,Images, ...

  5. tensorflow 学习教程

    tensorflow 学习手册 tensorflow 学习手册1:https://cloud.tencent.com/developer/section/1475687 tensorflow 学习手册 ...

  6. Tensorflow学习教程------利用卷积神经网络对mnist数据集进行分类_利用训练好的模型进行分类

    #coding:utf-8 import tensorflow as tf from PIL import Image,ImageFilter from tensorflow.examples.tut ...

  7. Tensorflow学习教程------创建图启动图

    Tensorflow作为目前最热门的机器学习框架之一,受到了工业界和学界的热门追捧.以下几章教程将记录本人学习tensorflow的一些过程. 在tensorflow这个框架里,可以讲是若数据类型,也 ...

  8. Tensorflow学习教程------lenet多标签分类

    本文在上篇的基础上利用lenet进行多标签分类.五个分类标准,每个标准分两类.实际来说,本文所介绍的多标签分类属于多任务学习中的联合训练,具体代码如下. #coding:utf-8 import te ...

  9. Tensorflow学习教程------非线性回归

    自己搭建神经网络求解非线性回归系数 代码 #coding:utf-8 import tensorflow as tf import numpy as np import matplotlib.pypl ...

随机推荐

  1. sizeof strlen 求char*字符串的长度

    sizeof只是求变量所占的字节数,sizeof(char *) = 4字节: strlen(char*) 可以得到整个字符串的长度. 如果是数组vec,那么使用sizeof就可以得到整个数组的所占的 ...

  2. 二进制中1的个数(n=(n&n-1))

    题目描述 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 解题:利用Java系统提供的函数Integer.toBinaryString(n),将整数转化为二进制,之后再将二进制的0用 ...

  3. 037、Java中利用判断语句实现三目运算的功能

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  4. PowerShell的一些资料整理

    年后准备把一些公司的一些祖传脚本给重新弄下,之前的脚本是bat写的,又臭又长,这次就不准备补窟窿了.打算用powershell重写下,这里就整理了一些相关的技术资料. 入门教程: 入门教程可以首选国内 ...

  5. 7.11 如何应用Varnish

    动态数据缓存 Step 1 修改devault.vcl文件 # This ) # man page for details on VCL syntax and semantics. # # Defau ...

  6. HIVE ROW_NUMBER()函数去重

    SELECT * FROM( SELECT *,ROW_NUMBER() OVER(PARTITION BY a.claimno ORDER BY b.financiancedate DESC)  n ...

  7. 51nod 1437:迈克步 单调栈基础题

    1437 迈克步 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题  收藏  取消关注 有n只熊.他们站成一排队伍,从左到右依次1到 ...

  8. 19 02 03 django 中cookies 和 session 和 cache

    Session 是单用户的会话状态.当用户访问网站时,产生一个 sessionid.并存在于 cookies中.每次向服务器请求时,发送这个 cookies,再从服务器中检索是否有这个 session ...

  9. 九十、SAP中ALV事件之四,事件子例程的参数

    一.我们按照之前SAP说明里面的文字,定义好相关内容 二.上图代码对应的文档错了,重现截图一下 三.这3个子例程是不需要写调用语句PERFORM的,在SAP内部已经写好了.程序会自动根据名字找到需要调 ...

  10. 二十八、SAP中通过以字段以表格形式输出

    一.重点在与表格长度的计算,以及LINE-SIZE的用法,代码如下 二.输出效果如下