我知道如何从Tensorflow Hub加载经过预训练的图像模型。像这样:
#load model
image_module = hub.Module('https://tfhub.dev/google/imagenet/mobilenet_v2_035_128/feature_vector/2')
#get predictions
features = image_module(batch_images)
我还知道如何自定义该模型的输出(在新数据集上进行微调)。现有的Modules
期望输入batch_images
是RGB图像张量。
我的问题:我想使用张量(来自其他模型的20x20x128尺寸)作为集线器模型的输入,而不是输入特定尺寸的RGB图像。这意味着我需要绕过tf-hub模型定义的初始层(我不需要它们)。在tf-hub模块api中有可能吗?在这方面的文档尚不清楚。
p.s .:我可以轻松地定义自己的图层,但尝试查看是否可以使用Tf-Hub API。
答案 0 :(得分:1)
现有的https://tfhub.dev/google/imagenet/ ...模块不支持此功能。
通常来说,hub.Module格式允许多个签名(即输入/输出张量的组合;如tf.Session.run()中那样考虑提要和获取)。因此,如果有他们想要支持的常见使用模式,则模块发布者可以安排这些工作。
但是对于这种复杂程度的自由形式实验,您最好直接使用和调整定义模型的代码,例如TF Slim(对于TF1.x)或Keras Applications(也对于TF2)。两者都提供了Imagenet预训练的检查点,可在侧面进行下载和还原。