将tf.contrib.layers.batch_norm迁移到Tensorflow 2.0

2024-05-23 15:39:55 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在将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,我不知道如何在BatchNormalization方法中设置updates_collections


Tags: truenormlayerstfbatchcontribcollectionscenter
1条回答
网友
1楼 · 发布于 2024-05-23 15:39:55

我在使用一个经过训练的模型时遇到了这个问题,我打算对这个模型进行微调。就像OP那样用tf.keras.layers.BatchNormalization替换tf.contrib.layers.batch_norm给了我一个错误,其修复方法如下所述

旧代码如下所示:

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的层名称

相关问题 更多 >