在LSTM和Keras中获取每个epoch的最后一层输出

我们已经知道可以从以下代码中获取每层的输出:

def get_layer(model,x):    from keras import backend as K    get_3rd_layer_output = K.function([model.layers[0].input],                                      [model.layers[2].output])    layer_output = get_3rd_layer_output([x])[0]    print(layer_output.shape)    return layer_output

LSTM模型的训练过程如下:

history = model.fit(X_train, y_train, batch_size=batch_size,verbose=1, nb_epoch=10,validation_data=(X_test,y_test))

但是,如何在10个epoch中获取模型最后一层的输出呢?


回答:

你可以创建一个自定义回调(查看文档)并将其传递到fit方法的回调列表中。

示例:

from keras.callbacks import Callbackclass LogThirdLayerOutput(Callback):    def on_epoch_end(self, epoch, logs=None):        layer_output = get_3rd_layer_output(self.validation_data)[0]        print(layer_output.shape)

在训练模型时:

history = model.fit(X_train, y_train, batch_size=batch_size, verbose=1, nb_epoch=10, validation_data=(X_test,y_test), callbacks=[LogThirdLayerOutput()])

如果你不想在单独的类中创建回调,你也可以使用Lambda回调

Related Posts

Flatten and back keras

我正在尝试使用自编码器获取简单向量中的值 这是我的代码…

如何按索引访问PyTorch模型参数

如果我的网络有10层,包括偏置项,如何仅通过索引访问第…

Python中多元逻辑回归显示错误

我试图使用逻辑回归进行预测,并使用Python和skl…

在MACOS上安装NLTK

我在我的2015款Mac Pro上尝试安装NLTK,操…

如何在R中将通过RFE选择的变量插入到机器学习模型中?

我想使用递归特征消除方法来选择最重要的特征,然后将这些…

CountVectorizer 错误:ValueError: setting an array element with a sequence

我有一个包含144条学生反馈的数据集,其中有72条正面…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注