TensorFlowトレーニングテストロゴ単独書き込み
1846 ワード
tensorflowは一般的に訓練時にlogを増やす.テスト時にどのように増加しますか?
TensorFlow eventsファイルの読み込み
TensorFlowページを開いてlogを表示できないため、手動pythonでTensorFlowログファイルの可視化を読み込む
リファレンスhttps://blog.csdn.net/nima1994/article/details/82844988
テスト時にlogリファレンスを書き込みます.https://www.cnblogs.com/hrlnw/p/8378576.html
この方法ではsessを用いる.runは直接構造を追加することに等しい
TensorFlow eventsファイルの読み込み
import tensorflow as tf
# e, event, batch
for e in tf.train.summary_iterator('./log/events.out.tfevents.1538814721.7226610225d8'):
# v, value, batch ,loss accuracy
for v in e.summary.value:
if v.tag == 'loss' or v.tag == 'accuracy':
print(v.simple_value)
TensorFlowページを開いてlogを表示できないため、手動pythonでTensorFlowログファイルの可視化を読み込む
リファレンスhttps://blog.csdn.net/nima1994/article/details/82844988
from tensorboard.backend.event_processing import event_accumulator
#
ea=event_accumulator.EventAccumulator(r'E:\Code\lastExp\output\logs\pm_last\events.out.tfevents.1535713476.DESKTOP-KMHR70T')
ea.Reload()
print(ea.scalars.Keys())
val_acc=ea.scalars.Items('val_acc')
print(len(val_acc))
print([(i.step,i.value) for i in val_acc])
import matplotlib.pyplot as plt
fig=plt.figure(figsize=(6,4))
ax1=fig.add_subplot(111)
val_acc=ea.scalars.Items('val_acc')
ax1.plot([i.step for i in val_acc],[i.value for i in val_acc],label='val_acc')
ax1.set_xlim(0)
acc=ea.scalars.Items('acc')
ax1.plot([i.step for i in acc],[i.value for i in acc],label='acc')
ax1.set_xlabel("step")
ax1.set_ylabel("")
plt.legend(loc='lower right')
plt.show()
テスト時にlogリファレンスを書き込みます.https://www.cnblogs.com/hrlnw/p/8378576.html
この方法ではsessを用いる.runは直接構造を追加することに等しい
testsummaries = tf.Summary()
lossval = testsummaries.value.add()
lossval.tag = 'loss'
lossval.simple_value = averageloss / batchnum
accval = testsummaries.value.add()
accval.tag = 'accuracy'
accval.simple_value = averageaccuracy / batchnum
# loss accuracy
testfilewriter.addsummary(testsummaries, step)