當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Python tf.compat.v1.summary.merge用法及代碼示例


合並摘要。

用法

tf.compat.v1.summary.merge(
    inputs, collections=None, name=None
)

參數

  • inputs 包含序列化 Summary 協議緩衝區的 string Tensor 對象列表。
  • collections 圖集合鍵的可選列表。新的摘要操作被添加到這些集合中。默認為 []
  • name 操作的名稱(可選)。

返回

  • string 類型的標量 Tensor 。合並產生的序列化 Summary 協議緩衝區。

拋出

  • RuntimeError 如果在啟用渴望模式的情況下調用。

遷移到 TF2

警告:這個 API 是為 TensorFlow v1 設計的。繼續閱讀有關如何從該 API 遷移到本機 TensorFlow v2 等效項的詳細信息。見TensorFlow v1 到 TensorFlow v2 遷移指南有關如何遷移其餘代碼的說明。

此 API 與即刻執行或 tf.function 不兼容。要遷移到 TF2,可以完全省略此 API,因為在 TF2 中,單個摘要操作(如 tf.summary.scalar() )會直接寫入默認摘要編寫器(如果一個處於活動狀態)。因此,沒有必要合並摘要或手動將生成的合並摘要輸出添加到編寫器。請參閱下麵顯示的使用示例。

如需全麵的 tf.summary 遷移指南,請遵循將 tf.summary 使用遷移到 TF 2.0。

TF1 & TF2 使用示例

TF1:

dist = tf.compat.v1.placeholder(tf.float32, [100])
tf.compat.v1.summary.histogram(name="distribution", values=dist)
writer = tf.compat.v1.summary.FileWriter("/tmp/tf1_summary_example")
summaries = tf.compat.v1.summary.merge_all()

sess = tf.compat.v1.Session()
for step in range(100):
  mean_moving_normal = np.random.normal(loc=step, scale=1, size=[100])
  summ = sess.run(summaries, feed_dict={dist:mean_moving_normal})
  writer.add_summary(summ, global_step=step)

特遣部隊2:

writer = tf.summary.create_file_writer("/tmp/tf2_summary_example")
for step in range(100):
  mean_moving_normal = np.random.normal(loc=step, scale=1, size=[100])
  with writer.as_default(step=step):
    tf.summary.histogram(name='distribution', data=mean_moving_normal)

此操作創建一個 Summary 協議緩衝區,其中包含輸入摘要中所有值的並集。

運行 Op 時,如果要合並的摘要中的多個值使用相同的標記,它會報告 InvalidArgument 錯誤。

相關用法


注:本文由純淨天空篩選整理自tensorflow.org大神的英文原創作品 tf.compat.v1.summary.merge。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。