【发布时间】:2016-04-01 00:09:39
【问题描述】:
我正在尝试学习如何使用 tensorflow 和 tensorboard。我有一个基于MNIST neural net tutorial的测试项目。
在我的代码中,我构建了一个节点,用于计算数据集中正确分类的数字比例,如下所示:
correct = tf.nn.in_top_k(self._logits, labels, 1)
correct = tf.to_float(correct)
accuracy = tf.reduce_mean(correct)
这里,self._logits 是图的推理部分,labels 是包含正确标签的占位符。
现在,我想做的是在训练进行时评估训练集和验证集的准确性。我可以通过使用不同的 feed_dicts 两次运行准确度节点来做到这一点:
train_acc = tf.run(accuracy, feed_dict={images : training_set.images, labels : training_set.labels})
valid_acc = tf.run(accuracy, feed_dict={images : validation_set.images, labels : validation_set.labels})
这按预期工作。我可以打印这些值,我可以看到,最初,两个准确度都会增加,最终验证准确度会趋于平缓,而训练准确度会不断增加。
但是,我也想在 tensorboard 中获取这些值的图表,但我不知道如何做到这一点。如果我只是将scalar_summary 添加到accuracy,则记录的值将无法区分训练集和验证集。
我还尝试创建两个具有不同名称的相同accuracy 节点,并在训练集和验证集上运行一个。然后我将scalar_summary 添加到每个节点。这确实在张量板上给了我两张图,但不是一张显示训练集准确度的图和一张显示验证集准确度的图,它们都显示了与打印到终端中的任何一个都不匹配的相同值。
我可能误解了如何解决这个问题。针对不同输入分别记录单个节点的输出的推荐方法是什么?
【问题讨论】:
标签: python tensorflow tensorboard