为什么TensorFlow会在TensorBoard可视化中为我的变量创建额外的命名空间?

我创建变量的方式如下:

x = tf.placeholder(tf.float32, shape=[None, D], name='x-input') # M x D# Variables Layer1#std = 1.5*np.pistd = 0.1W1 = tf.Variable( tf.truncated_normal([D,D1], mean=0.0, stddev=std, name='W1') ) # (D x D1)S1 = tf.Variable(tf.constant(100.0, shape=[1], name='S1')) # (1 x 1)C1 = tf.Variable( tf.truncated_normal([D1,1], mean=0.0, stddev=0.1, name='C1') ) # (D1 x 1)

但不知为何,TensorFlow在我的可视化中添加了额外的变量块:

enter image description here

为什么会这样?如何阻止这种情况的发生?


回答:

你在TensorFlow中错误地使用了名称

W1 = tf.Variable( tf.truncated_normal([D,D1], mean=0.0, stddev=std, name='W1') )                  \----------------------------------------------------------/                                           initializer      \-------------------------------------------------------------------------/                                 actual variable

因此,你的代码创建了未命名的变量,并为初始化操作命名W1。这就是为什么你在图中看到的名为W1的并不是你的W1变量,而是重命名的初始化操作,而你的W1变量被称为Variable(这是TensorFlow为未命名操作分配的默认名称)。正确的做法应该是

W1 = tf.Variable( tf.truncated_normal([D,D1], mean=0.0, stddev=std), name='W1' )

这样会为实际的变量创建一个名为W1的节点,并且会附带一个小的初始化节点(用于为其设定随机值)。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注