我正在将TensorFlow代码迁移到Tensorflow 2.1.0。
这是原始代码:
conv = tf.layers.conv2d(inputs, out_channels, kernel_size=3, padding='SAME')
conv = tf.contrib.layers.batch_norm(conv, updates_collections=None, decay=0.99, scale=True, center=True)
conv = tf.nn.relu(conv)
conv = tf.contrib.layers.max_pool2d(conv, 2)
这就是我所做的:
conv1 = Conv2D(out_channels, (3, 3), activation='relu', padding='same', data_format='channels_last', name=name)(inputs)
conv1 = Conv2D(64, (5, 5), activation='relu', padding='same', data_format="channels_last")(conv1)
#conv = tf.contrib.layers.batch_norm(conv, updates_collections=None, decay=0.99, scale=True, center=True)
pool1 = MaxPooling2D(pool_size=(2, 2), data_format="channels_last")(conv1)
我的问题是我不知道如何处理tf.contrib.layers.batch_norm
。
如何将tf.contrib.layers.batch_norm
迁移到Tensorflow 2.x?
更新:
使用评论建议,我认为我已正确迁移:
conv1 = BatchNormalization(momentum=0.99, scale=True, center=True)(conv1)
但是我不确定decay
是否像momentum
,并且我不知道如何在updates_collections
方法中设置BatchNormalization
。
答案 0 :(得分:0)
在使用我要微调的训练模型时遇到了这个问题。像OP那样用tf.contrib.layers.batch_norm
替换tf.keras.layers.BatchNormalization
确实给了我一个错误,其修复方法如下所述。
旧代码如下:
tf.contrib.layers.batch_norm(
tensor,
scale=True,
center=True,
is_training=self.use_batch_statistics,
trainable=True,
data_format=self._data_format,
updates_collections=None,
)
,更新后的工作代码如下:
tf.keras.layers.BatchNormalization(
name="BatchNorm",
scale=True,
center=True,
trainable=True,
)(tensor)
我不确定我删除的所有关键字参数是否都会出现问题,但是一切似乎都可以正常工作。请注意name="BatchNorm"
参数。图层使用不同的命名模式,因此我不得不使用inspect_checkpoint.py
工具查看模型并找到恰好是BatchNorm
的图层名称。