Керас предсказать только дает 1, но потеря значения уменьшается - PullRequest
1 голос
/ 01 мая 2019

Я пытаюсь внедрить автоэнкодер JSCC с использованием Keras в наборе данных CIfar-10.но значения выходного изображения всегда равны 1.

Я новичок в Keras и не нашел, как это исправить.

model = Sequential()

model.add(Conv2D(16,(5,5),padding = 'same', strides = 2, input_shape=X_train.shape[1:]))
model.add(Activation('relu'))
model.add(Conv2D(32,(5,5),padding = 'same', strides = 2))
model.add(Activation('relu'))
model.add(Conv2D(32,(5,5),padding = 'same'))
model.add(Activation('relu'))
model.add(Conv2D(32,(5,5),padding = 'same'))
model.add(Activation('relu'))
model.add(Flatten())
model.add(Dense(100))
model.add(Activation('relu'))
model.add(keras.layers.GaussianNoise(0.1))
model.add(Dense(2048))
model.add(Activation('relu'))
model.add(Reshape((8,8,32)))

model.add(Conv2DTranspose(32,(5,5), padding = 'same'))
model.add(Activation('relu'))
model.add(Conv2DTranspose(32,(5,5), padding = 'same'))
model.add(Activation('relu'))
model.add(Conv2DTranspose(32,(5,5), strides = 2 ,padding = 'same'))
model.add(Activation('relu'))
model.add(Conv2DTranspose(3,(5,5), strides = 2 ,padding = 'same'))
model.add(Activation('sigmoid'))

model.compile(loss='mse', optimizer='adam')

model.fit(X_train_norm, X_train_norm,
              batch_size=128,
              epochs=20,
              validation_data=(X_test_norm, X_test_norm),
              shuffle=True)

эта модель сжимает изображениек вектору с длиной 100, и он складывается с гауссовским шумом, а затем повышает вектор до исходного ввода.

Train on 50000 samples, validate on 10000 samples
Epoch 1/20
50000/50000 [==============================] - 7s 138us/step - loss: 0.0245 - val_loss: 0.0226
Epoch 2/20
50000/50000 [==============================] - 6s 120us/step - loss: 0.0225 - val_loss: 0.0222
Epoch 3/20
50000/50000 [==============================] - 6s 121us/step - loss: 0.0220 - val_loss: 0.0216
Epoch 4/20
50000/50000 [==============================] - 6s 121us/step - loss: 0.0214 - val_loss: 0.0211
Epoch 5/20
50000/50000 [==============================] - 6s 119us/step - loss: 0.0208 - val_loss: 0.0207
...
>>>model.predict(X_train[:32])
array([[[[1., 1., 1.],
         [1., 1., 1.],
         [1., 1., 1.],
         ...,

1 Ответ

1 голос
/ 01 мая 2019

Вы использовали нормализованные данные во время обучения, но исходные данные при прогнозировании.

вместо:

model.predict(X_train[:32])

использование:

model.predict(X_train_norm[:32])
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...