2018-06-19-tensorboard的使用

TensorBoard是通过读取tensorflow产生的事件文档来运行的.这些文档中包含着代码运行过程中产生的总结信息.下面本文将会对tensorboard进行详细的介绍.

1.生命周期

  首先,创建想要收集数据的tensorflow graph,然后指明想要收集数据的节点.summary是一个operation.收集操作.

  例如,假设你在MNIST数据集上训练卷积神经网络.你呢,想记录随着学习的深入,学习率的变化程度哟,还有目标函数的变化哟.想要收集这些信息呢,就需要使用 tf.summary.scalar .然后呢就要给这些总结信息 scalar_summary一个相对比较有意义的标签 tag,例如 'learning rate''loss function'.等等

  也许呢,你还想可视化的观察一下某一层的激活函数的输出情况,或者是梯度和权重的分布情况.我们可以通过 tf.summary.histogram 来收集这些信息.想要对这些总总结信息有更深入的了解,就需要查看一下文档. summary operations.

  Tensorflow中的operation在运行之前什么都不会做.当然,如果你运行这个operation的一个下行operation也是可以触发这个operation的运行的.Summary的节点是外围节点,没有任何的操作节点是需要依赖这些节点的.因此,我们需要把这些总结节点一个个的自己运行完,这很烦呀,所以有个快捷键.tf.summary.merge_all 可以将这些节点合并成一个节点,然后运行这个节点就好啦.具体运行的方法是使用writer.add_summary触发.触发一次就可以写入这一批执行的信息,不多不少.然后每次运行的时候都会产生输出信息,把这个节点传给tf.summary.FileWriter就可以写入到文件当中.

   FileWriter 使用logdir作为输入参数.这个参数可以说是非常重要的.所有的输出信息都会在这个目录中输出.同时,还可以选择graph作为参数.通过接收graph,tensorboard就可以将整个图像进行可视化的展示啦. Tensor shape information.

  现在,你就可以修改你的graph增加一个FileWriter了,如果你愿意的话,你就可以在每一步都进行一下summary 的操作,然后把每一步的信息都显示出来.不过最好呢,是每隔n步再进行一次信息的总结.下面是 simple MNIST tutorial的一个简单的改编版本的代码,在代码中我们增加了一些总结的操作,每隔10步就会执行一次.运行tensorboard --logdir=/tmp/tensorflow/mnist, 你就可以看到可视化的数据.源代码在这里.

def variable_summaries(var):
  """Attach a lot of summaries to a Tensor (for TensorBoard visualization)."""
  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)

def nn_layer(input_tensor, input_dim, output_dim, layer_name, act=tf.nn.relu):
  """Reusable code for making a simple neural net layer.

  It does a matrix multiply, bias add, and then uses relu to nonlinearize.
  It also sets up name scoping so that the resultant graph is easy to read,
  and adds a number of summary ops.
  """
  # Adding a name scope ensures logical grouping of the layers in the graph.
  with tf.name_scope(layer_name):
    # This Variable will hold the state of the weights for the layer
    with tf.name_scope('weights'):
      weights = weight_variable([input_dim, output_dim])
      variable_summaries(weights)
    with tf.name_scope('biases'):
      biases = bias_variable([output_dim])
      variable_summaries(biases)
    with tf.name_scope('Wx_plus_b'):
      preactivate = tf.matmul(input_tensor, weights) + biases
      tf.summary.histogram('pre_activations', preactivate)
    activations = act(preactivate, name='activation')
    tf.summary.histogram('activations', activations)
    return activations

hidden1 = nn_layer(x, 784, 500, 'layer1')

with tf.name_scope('dropout'):
  keep_prob = tf.placeholder(tf.float32)
  tf.summary.scalar('dropout_keep_probability', keep_prob)
  dropped = tf.nn.dropout(hidden1, keep_prob)

# Do not apply softmax activation yet, see below.
y = nn_layer(dropped, 500, 10, 'layer2', act=tf.identity)

with tf.name_scope('cross_entropy'):
  # The raw formulation of cross-entropy,
  #
  # tf.reduce_mean(-tf.reduce_sum(y_ * tf.log(tf.softmax(y)),
  #                               reduction_indices=[1]))
  #
  # can be numerically unstable.
  #
  # So here we use tf.losses.sparse_softmax_cross_entropy on the
  # raw logit outputs of the nn_layer above.
  with tf.name_scope('total'):
    cross_entropy = tf.losses.sparse_softmax_cross_entropy(labels=y_, logits=y)
tf.summary.scalar('cross_entropy', cross_entropy)

with tf.name_scope('train'):
  train_step = tf.train.AdamOptimizer(FLAGS.learning_rate).minimize(
      cross_entropy)

with tf.name_scope('accuracy'):
  with tf.name_scope('correct_prediction'):
    correct_prediction = tf.equal(tf.argmax(y, 1), tf.argmax(y_, 1))
  with tf.name_scope('accuracy'):
    accuracy = tf.reduce_mean(tf.cast(correct_prediction, tf.float32))
tf.summary.scalar('accuracy', accuracy)

# Merge all the summaries and write them out to /tmp/mnist_logs (by default)
merged = tf.summary.merge_all()
train_writer = tf.summary.FileWriter(FLAGS.summaries_dir + '/train',
                                      sess.graph)
test_writer = tf.summary.FileWriter(FLAGS.summaries_dir + '/test')
tf.global_variables_initializer().run()

&esmp; 剩下的部分需要介绍的就不是很多啦.

&esmp; &esmp; 1.name_scope对变量进行分类有助于在tensorboard中进行查看

&esmp; &esmp; 2.session 是可以保存和恢复的

&esmp; &esmp; 3.meta_data是运行时的统计信息,包括运行内存啦什么的.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355

推荐阅读更多精彩内容

  • TensorBoard简介 TensorFlow 的计算过程其实是一个黑盒过程,为了便于使用者对TensorFlo...
    galois_xiong阅读 3,045评论 0 4
  • 当使用Tensorflow训练大量深层的神经网络时,我们希望去跟踪神经网络的整个训练过程中的信息,比如迭代的过程中...
    听风1996阅读 3,820评论 0 7
  • 简单线性回归 import tensorflow as tf import numpy # 创造数据 x_dat...
    CAICAI0阅读 3,547评论 0 49
  • 空间是改变熵态的原因。 在一维空间里,熵态自由均匀分布。 熵态发生改变的地方,空间维度一定发生了改变 任何一个物体...
    Z0001阅读 1,234评论 0 0
  • 大雨来了 在我将要离开的时候 洗刷我的毛孔 洗刷我一路的脚印 只躁乱了几日的心 即将重归平静 是了 大雨同那晚一样随意
    藏缨阅读 190评论 0 2