利用Tensorboard绘制网络识别准确率和loss曲线实例


Posted in Python onFebruary 15, 2020

废话不多说,直接上代码看吧!

import tensorflow as tf 
from tensorflow.examples.tutorials.mnist import input_data 
 
#载入数据集 
mnist = input_data.read_data_sets("MNIST_data",one_hot=True) 
 
#每个批次的大小和总共有多少个批次 
batch_size = 100 
n_batch = mnist.train.num_examples // batch_size 
 
#定义函数
def variable_summaries(var):
  with tf.name_scope('summaries'):
    mean = tf.reduce_mean(var)
    tf.summary.scalar('mean', mean) #平均值
    with tf.name_scope('stddev'):
      stddev = tf.sqrt(tf.reduce_mean(tf.square(var-mean)))
    tf.summary.scalar('stddev', stddev) #标准差
    tf.summary.scalar('max', tf.reduce_max(var))
    tf.summary.scalar('min', tf.reduce_min(var))
    tf.summary.histogram('histogram', var) #直方图
    
#命名空间
with tf.name_scope("input"):
  #定义两个placeholder 
  x = tf.placeholder(tf.float32,[None,784], name = "x_input") 
  y = tf.placeholder(tf.float32,[None,10], name = "y_input") 
 
with tf.name_scope("layer"):
  #创建一个简单的神经网络 
  with tf.name_scope('weights'):
    W = tf.Variable(tf.zeros([784,10]), name='W') 
    variable_summaries(W)
  with tf.name_scope('biases'):  
    b = tf.Variable(tf.zeros([10]), name='b') 
    variable_summaries(b)
  with tf.name_scope('wx_plus_b'): 
    wx_plus_b = tf.matmul(x,W)+b
  with tf.name_scope('softmax'):
    prediction = tf.nn.softmax(wx_plus_b) 
 
with tf.name_scope('loss'):
  #交叉熵代价函数 
  loss = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(labels=y, logits=prediction)) 
  tf.summary.scalar('loss', loss)
with tf.name_scope('train'):
  #使用梯度下降法 
  train_step = tf.train.GradientDescentOptimizer(0.2).minimize(loss) 
 
#初始化变量 
init = tf.global_variables_initializer() 
 
with tf.name_scope('accuracy'):
  with tf.name_scope('correct_prediction'):
    #结果存放在一个布尔型列表中 
    correct_prediction = tf.equal(tf.argmax(y,1),tf.argmax(prediction,1))#argmax返回一维张量中最大的值所在的位置 
  with tf.name_scope('accuracy'):
    #求准确率 
    accuracy = tf.reduce_mean(tf.cast(correct_prediction,tf.float32)) 
    tf.summary.scalar('accuracy', accuracy)
 
#合并所有的summary
merged = tf.summary.merge_all()
 
with tf.Session() as sess: 
  sess.run(init) 
  writer = tf.summary.FileWriter("log/", sess.graph) #写入到的位置
  for epoch in range(51): 
    for batch in range(n_batch): 
      batch_xs,batch_ys = mnist.train.next_batch(batch_size) 
      summary,_ = sess.run([merged,train_step],feed_dict={x:batch_xs, y:batch_ys}) 
    
    writer.add_summary(summary,epoch) 
    acc = sess.run(accuracy,feed_dict={x:mnist.test.images,y:mnist.test.labels}) 
    print("epoch " + str(epoch)+ "  acc " +str(acc))

运行程序,打开命令行界面,切换到 log 所在目录,输入

tensorboard --logdir= --logdir=C:\Users\Administrator\Desktop\Python\log

接着会返回一个链接,类似 http://PC-20160926YCLU:6006

打开谷歌浏览器或者火狐,输入网址即可查看搭建的网络结构以及识别准确率和损失函数的曲线图。

注意:如果对网络进行更改之后,在运行之前应该先删除log下的文件,在Jupyter中应该选择Kernel----->Restar & Run All, 否则新网络会和之前的混叠到一起。因为每次的网址都是一样的,在浏览器刷新页面即可。

以上这篇利用Tensorboard绘制网络识别准确率和loss曲线实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python实现把json格式转换成文本或sql文件
Jul 10 Python
Python中%r和%s的详解及区别
Mar 16 Python
Python利用multiprocessing实现最简单的分布式作业调度系统实例
Nov 14 Python
python实现微信自动回复功能
Apr 11 Python
解决Pandas to_json()中文乱码,转化为json数组的问题
May 10 Python
对Python 检查文件名是否规范的实例详解
Jun 10 Python
python中enumerate() 与zip()函数的使用比较实例分析
Sep 03 Python
Python3直接爬取图片URL并保存示例
Dec 18 Python
pyftplib中文乱码问题解决方案
Jan 11 Python
win10安装tesserocr配置 Python使用tesserocr识别字母数字验证码
Jan 16 Python
python 实现图与图之间的间距调整subplots_adjust
May 21 Python
用Python爬取英雄联盟的皮肤详细示例
Dec 06 Python
tensorboard显示空白的解决
Feb 15 #Python
解决Tensorboard可视化错误:不显示数据 No scalar data was found
Feb 15 #Python
tensorboard 可以显示graph,却不能显示scalar的解决方式
Feb 15 #Python
解决Tensorboard 不显示计算图graph的问题
Feb 15 #Python
基于TensorBoard中graph模块图结构分析
Feb 15 #Python
使用Bazel编译TensorBoard教程
Feb 15 #Python
TensorBoard 计算图的可视化实现
Feb 15 #Python
You might like
支持oicq头像的留言簿(二)
2006/10/09 PHP
PHP parse_url 一个好用的函数
2009/10/03 PHP
php类常量的使用详解
2013/06/08 PHP
php实现在多维数组中查找特定value的方法
2015/07/29 PHP
LINUX下PHP程序实现WORD文件转化为PDF文件的方法
2016/05/13 PHP
PHP文件下载实例代码浅析
2016/08/17 PHP
PHP foreach遍历多维数组实现方式
2016/11/16 PHP
PHP hex2bin()函数用法讲解
2019/02/25 PHP
网页中返回顶部代码(多种方法)另附注释说明
2013/04/24 Javascript
javascript 判断整数方法分享
2014/12/16 Javascript
基于Css3和JQuery实现打字机效果
2015/08/11 Javascript
EasyUI创建对话框的两种方式
2016/08/23 Javascript
Vue.js系列之项目结构说明(2)
2017/01/03 Javascript
详解angular中通过$location获取路径(参数)的写法
2017/03/21 Javascript
vue2.0 与 bootstrap datetimepicker的结合使用实例
2017/05/22 Javascript
微信小程序自定义导航隐藏和显示功能
2017/06/13 Javascript
Angular 2.0+ 的数据绑定的实现示例
2017/08/09 Javascript
在Koa.js中实现文件上传的接口功能
2019/10/08 Javascript
[02:43]2018DOTA2亚洲邀请赛主赛事首日TOP5
2018/04/04 DOTA
python字典get()方法用法分析
2015/04/17 Python
python实现简单图片物体标注工具
2019/03/18 Python
Python爬取破解无线网络wifi密码过程解析
2019/09/17 Python
用Python开发app后端有优势吗
2020/06/29 Python
opencv 图像礼帽和图像黑帽的实现
2020/07/07 Python
Python 内存管理机制全面分析
2021/01/16 Python
分享29个基于Bootstrap的HTML5响应式网页设计模板
2015/11/19 HTML / CSS
日本网路线上商品代购服务:转送JAPAN
2016/08/05 全球购物
What is the purpose of Void class? Void类的作用是什么?
2016/10/31 面试题
C语言基础笔试题
2013/04/27 面试题
群众路线教育党课主持词
2014/04/01 职场文书
本科生求职信
2014/06/17 职场文书
党的群众路线查摆剖析材料
2014/10/10 职场文书
党的群众路线教育实践活动党员个人整改措施
2014/10/27 职场文书
2015年全国保险公众宣传日活动方案
2015/05/06 职场文书
2019年销售部季度工作计划3篇
2019/10/09 职场文书
科学家测试在太空中培育人造肉,用于未来太空旅行
2022/04/29 数码科技