Tensorflow学习教程------tensorboard网络运行和可视化
tensorboard可以将训练过程中的一些参数可视化,比如我们最关注的loss值和accuracy值,简单来说就是把这些值的变化记录在日志里,然后将日志里的这些数据可视化。
首先运行训练代码

- #coding:utf-8
- 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') #输入标签
- #创建一个简单的神经网络 784个像素点对应784个数 因此输入层是784个神经元 输出层是10个神经元 不含隐层
- #最后准确率在92%左右
- with tf.name_scope('layer'):
- with tf.name_scope('wights'):
- W = tf.Variable(tf.zeros([784,10]),name = 'W') #生成784行 10列的全0矩阵
- variable_summaries(W)
- with tf.name_scope('biases'):
- b = tf.Variable(tf.zeros([1,10]),name='b')
- variable_summaries(b)
- with tf.name_scope('softmax'):
- prediction = tf.nn.softmax(tf.matmul(x,W)+b)
- #二次代价函数
- #loss = tf.reduce_mean(tf.square(y-prediction))
- #交叉熵损失
- 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)
- #使用梯度下降法
- #train_step = tf.train.GradientDescentOptimizer(0.2).minimize(loss)
- train_step = tf.train.AdamOptimizer(1e-3).minimize(loss) #学习率一般设置比较小 收敛速度快
- #初始化变量
- init = tf.global_variables_initializer()
- #结果存放在布尔型列表中
- #argmax能给出某个tensor对象在某一维上的其数据最大值所在的索引值
- with tf.name_scope('accuracy'):
- with tf.name_scope('correct_prediction'):
- correct_prediction = tf.equal(tf.argmax(y,1), tf.argmax(prediction,1))
- 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('/home/xxx/logs/',sess.graph) #定义记录日志的位置
- for epoch in range(50):
- 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) #将summary epoch 写入到writer
- acc = sess.run(accuracy,feed_dict={x:mnist.test.images, y:mnist.test.labels})
- 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网络运行和可视化的更多相关文章
- Tensorflow学习教程------读取数据、建立网络、训练模型,小巧而完整的代码示例
紧接上篇Tensorflow学习教程------tfrecords数据格式生成与读取,本篇将数据读取.建立网络以及模型训练整理成一个小样例,完整代码如下. #coding:utf-8 import t ...
- Tensorflow学习教程------过拟合
Tensorflow学习教程------过拟合 回归:过拟合情况 / 分类过拟合 防止过拟合的方法有三种: 1 增加数据集 2 添加正则项 3 Dropout,意思就是训练的时候隐层神经元每次随机 ...
- Tensorflow学习教程------代价函数
Tensorflow学习教程------代价函数 二次代价函数(quadratic cost): 其中,C表示代价函数,x表示样本,y表示实际值,a表示输出值,n表示样本的总数.为简单起见,使用一 ...
- tensorflow学习笔记----TensorBoard讲解
TensorBoard简介 TensorBoard是TensorFlow自带的一个强大的可视化工具,也是一个Web应用程序套件.TensorBoard目前支持7种可视化,Scalars,Images, ...
- tensorflow 学习教程
tensorflow 学习手册 tensorflow 学习手册1:https://cloud.tencent.com/developer/section/1475687 tensorflow 学习手册 ...
- Tensorflow学习教程------利用卷积神经网络对mnist数据集进行分类_利用训练好的模型进行分类
#coding:utf-8 import tensorflow as tf from PIL import Image,ImageFilter from tensorflow.examples.tut ...
- Tensorflow学习教程------创建图启动图
Tensorflow作为目前最热门的机器学习框架之一,受到了工业界和学界的热门追捧.以下几章教程将记录本人学习tensorflow的一些过程. 在tensorflow这个框架里,可以讲是若数据类型,也 ...
- Tensorflow学习教程------lenet多标签分类
本文在上篇的基础上利用lenet进行多标签分类.五个分类标准,每个标准分两类.实际来说,本文所介绍的多标签分类属于多任务学习中的联合训练,具体代码如下. #coding:utf-8 import te ...
- Tensorflow学习教程------非线性回归
自己搭建神经网络求解非线性回归系数 代码 #coding:utf-8 import tensorflow as tf import numpy as np import matplotlib.pypl ...
随机推荐
- sizeof strlen 求char*字符串的长度
sizeof只是求变量所占的字节数,sizeof(char *) = 4字节: strlen(char*) 可以得到整个字符串的长度. 如果是数组vec,那么使用sizeof就可以得到整个数组的所占的 ...
- 二进制中1的个数(n=(n&n-1))
题目描述 输入一个整数,输出该数二进制表示中1的个数.其中负数用补码表示. 解题:利用Java系统提供的函数Integer.toBinaryString(n),将整数转化为二进制,之后再将二进制的0用 ...
- 037、Java中利用判断语句实现三目运算的功能
01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...
- PowerShell的一些资料整理
年后准备把一些公司的一些祖传脚本给重新弄下,之前的脚本是bat写的,又臭又长,这次就不准备补窟窿了.打算用powershell重写下,这里就整理了一些相关的技术资料. 入门教程: 入门教程可以首选国内 ...
- 7.11 如何应用Varnish
动态数据缓存 Step 1 修改devault.vcl文件 # This ) # man page for details on VCL syntax and semantics. # # Defau ...
- HIVE ROW_NUMBER()函数去重
SELECT * FROM( SELECT *,ROW_NUMBER() OVER(PARTITION BY a.claimno ORDER BY b.financiancedate DESC) n ...
- 51nod 1437:迈克步 单调栈基础题
1437 迈克步 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 收藏 取消关注 有n只熊.他们站成一排队伍,从左到右依次1到 ...
- 19 02 03 django 中cookies 和 session 和 cache
Session 是单用户的会话状态.当用户访问网站时,产生一个 sessionid.并存在于 cookies中.每次向服务器请求时,发送这个 cookies,再从服务器中检索是否有这个 session ...
- 九十、SAP中ALV事件之四,事件子例程的参数
一.我们按照之前SAP说明里面的文字,定义好相关内容 二.上图代码对应的文档错了,重现截图一下 三.这3个子例程是不需要写调用语句PERFORM的,在SAP内部已经写好了.程序会自动根据名字找到需要调 ...
- 二十八、SAP中通过以字段以表格形式输出
一.重点在与表格长度的计算,以及LINE-SIZE的用法,代码如下 二.输出效果如下