【发布时间】:2019-03-03 05:37:45
【问题描述】:
我正在使用 Keras 构建一个 5 层自动编码器。我制作了从输入映射到输出的模型,这很好。我构建了另一个模型,该模型从输入映射到工作正常的潜在编码向量。但是,我随后尝试创建一个解码模型,将潜在编码向量映射到不起作用的输出。
我知道首先我应该为制作该形状的解码模型制作一个输入层,但我不知道如何将我的编码层数据作为解码模型的输入并让它从编码向量到最后一层。
from keras.layers import Input, Dense
from keras.models import Model
from keras.datasets import mnist
import numpy as np
(x_train, _), (x_test, _) = mnist.load_data()
# Prepare data and normalize
x_train = x_train.astype('float32') / 255.
x_test = x_test.astype('float32') / 255.
x_train = x_train.reshape(len(x_train), -1)
x_test = x_test.reshape(len(x_test), -1)
input_size = 784
hidden_size = 128
coded_size = 64
x = Input(shape=(input_size,))
hidden_1 = Dense(hidden_size, activation='relu')(x)
coded =Dense(coded_size, activation='relu')(hidden_1)
hidden_2 = Dense(hidden_size, activation='relu')(coded)
r = Dense(input_size, activation='sigmoid')(hidden_2)
autoencoder = Model(inputs=x, outputs=r)
encoder = Model(inputs=x, outputs=coded)
decoder_input = Input(shape=(coded_size,)) # should do this, but don't know how to connect it below
decoder = Model(inputs=coded, output=r)
【问题讨论】:
-
您必须通过在 Keras 中使用 Input 类构建中间(潜在)层来重建解码器,因为您不能将 Tensor 层用作 Model 类的输入层。你也可以查看这个非常好的Autoencoder教程blog.keras.io/building-autoencoders-in-keras.html。
标签: python machine-learning neural-network keras autoencoder