如何使用 Tensorflow 和预训练模型为模型添加分类头?

tensorflowserver side programmingprogramming

可以使用 Tensorflow 和预训练模型通过‘GlobalAveragePooling2D’方法为模型添加分类头,该方法被分配给一个变量。此变量用于输入数据的一批特征。

阅读更多: 什么是 TensorFlow,以及 Keras 如何与 TensorFlow 配合使用来创建神经网络?

包含至少一个层的神经网络称为卷积层。我们可以使用卷积神经网络构建学习模型。

我们将了解如何借助预训练网络的迁移学习对猫和狗的图像进行分类。图像分类迁移学习背后的直觉是,如果在大型通用数据集上训练模型,则该模型可有效地用作视觉世界的通用模型。它会学习特征图,这意味着用户不必从头开始在大型数据集上训练大型模型。

阅读更多: 如何预先训练定制模型?

我们使用 Google Colaboratory 运行以下代码。Google Colab 或 Colaboratory 有助于在浏览器上运行 Python 代码,并且不需要任何配置,并且可以免费访问 GPU(图形处理单元)。Colaboratory 是在 Jupyter Notebook 之上构建的。

示例

print("Adding a classification head")
global_average_layer = tf.keras.layers.GlobalAveragePooling2D()
feature_batch_average = global_average_layer(feature_batch)
print(feature_batch_average.shape)

代码来源 −https://www.tensorflow.org/tutorials/images/transfer_learning

输出

Adding a classification head
(32, 1280)

解释

  • 预测是根据特征块生成的,平均超过 5x5 个空间位置。

  • 这是使用 tf.keras.layers.GlobalAveragePooling2D 层完成的。

  • 此层有助于将特征转换为每个图像的单个 1280 个元素向量。


相关文章