python - 如何在 TensorFlow 2 中保存/加载模型的一部分?

我在 TensorFlow 2 中制作了一个自动编码器。首先,我需要在数据集上训练模型。训练自动编码器后,我想将自动编码器的编码器部分用于不同的数据集,同时保留经过训练的权重。有办法吗?我找不到一个。任何指导方针都会有所帮助。这是我正在尝试使用的粗略自动编码器:

from tensorflow.keras.layers import Input, Dense
from tensorflow.keras import Model

def Autoencoder():
    # Encoder
    inp = Input(shape=(100,))
    x = Dense(1000)(inp)
    x = Dense(500)(x)
    code = Dense(10)(x)

    # Decoder    
    x = Dense(500)(code)
    x = Dense(1000)(x)
    out = Dense(100)(x)

    model = Model(inp,out)
    return model

autoencoder = Autoencoder()

最佳答案

如果您只想使用编码器部分,您可以编写一个 CustomCheckpoint 类并像下面这样保存编码器。

class CustomCheckpoint(Callback):

def __init__(self, filepath, encoder):
    self.monitor = 'val_loss'
    self.monitor_op = np.less
    self.best = np.Inf

    self.filepath = filepath
    self.encoder = encoder

def on_epoch_end(self, epoch, logs=None):
    current = logs.get(self.monitor)
    if self.monitor_op(current, self.best):
        self.best = current
        # self.encoder.save_weights(self.filepath, overwrite=True)
        self.encoder.save(self.filepath, overwrite=True) # Whichever you prefer  

要从保存的权重加载编码器部分,您可以执行如下代码。

from keras.models import load_model
autoencoder = load_model("path_to_file")
encoder = Model(autoencoder.layers[0].input, autoencoder.layers[1].output)

https://stackoverflow.com/questions/60286080/

相关文章:

java - 当我使用 ContextHierarchy 时,没有类型为 'org.springfr

django - 使用 DjangoFilterConnectionField 时有没有办法删除边和

typescript - TypeScript 中的非破坏性类型断言

java - 如何将不同大小的元素立即放在彼此之上?

html - 什么决定了 Firefox 中的滚动条是否有颜色?

css - 使用 attr() 更新 CSS 变量

azure-devops - 在 Azure Devops 中编写 EF6 迁移脚本

google-cloud-platform - Terraform 0.12 使用模板创建入口规则

android - 蓝牙扫描设备,频繁扫描后无法写入设备

ruby-on-rails - jbuilder 空数组删除键