tf.Print()

2022-09-03 22:01:06 浏览数 (1)

调试程序的时候,经常会需要检查中间的参数,这些参数一般是定义在model或是别的函数中的局部参数,由于tensorflow要求先构建计算图再运算的机制,也不能定义后直接print出来。tensorflow有一个函数tf.Print()。

代码语言:javascript复制
tf.Print(input, data, message=None, first_n=None, summarize=None, name=None)

最低要求两个输入,input和data,input是需要打印的变量的名字,data要求是一个list,里面包含要打印的内容。

参数:

  • message是需要输出的错误信息
  • first_n指只记录前n次
  • summarize是对每个tensor只打印的条目数量,如果是None,对于每个输入tensor只打印3个元素
  • name是op的名字

需要注意的是tf.Print()只是构建一个op,需要run之后才会打印。

例子:

代码语言:javascript复制
x=tf.constant([2,3,4,5])
x=tf.Print(x,[x,x.shape,'test', x],message='Debug message:',summarize=100)
     
with tf.Session() as sess:
    sess.run(x)
     
#Debug message:[2 3 4 5][4][test][2 3 4 5]
     
x=tf.Print(x,[x,x.shape,'test', x],message='Debug message:',summarize=2)
     
with tf.Session() as sess:
    sess.run(x)
     
#Debug message:[2 3...][4][test][2 3...]

输出是在命令窗口中,和print有区别

用print也可以输出:

代码语言:javascript复制
x=tf.constant([2,3,4,5])
     
with tf.Session() as sess:
    print(sess.run(x))
     
#[2,3,4,5]

如果希望打印的参数是一个中间参数,换言之是一个局部参数不会被传回主函数。那么首先需要定义一个全局参数去保存它,一般在函数就是定义在最前面的self.para = para,再在主函数中print出来。

0 人点赞