Внедрение Seq2Seq с GRU в Керасе

1

Я наложил десятиминутный пример LSTM на сайт Keras и настроил сеть для обработки вложений слов вместо символьных (от https://blog.keras.io/a-ten-minute-introduction-to-sequence-to- sequence-learning-in-keras.html). Он работал нормально.

Но теперь я борюсь с использованием GRU вместо LSTM. После настройки переменных работала компиляция и обучение (функция соответствия). Но когда я пытаюсь использовать сеть, чтобы протестировать ее с помощью пользовательских входов, она бросает:

Размеры должны быть равны, но для 232: 256, для 'add' (op: 'Add') с входными формами: [1,?,?, 232], [?, 256]

Соответствующий рабочий код для LSTM:

encoder_inputs = Input(shape=(None, num_encoder_tokens), name="Encoder_Input")
encoder = LSTM(latent_dim, return_state=True, name="Encoder_LSTM")
encoder_outputs, state_h, state_c = encoder(encoder_inputs)
encoder_states = [state_h, state_c]
decoder_inputs = Input(shape=(None, num_decoder_tokens), name="Decoder_Input")
decoder_lstm = LSTM(latent_dim, return_sequences=True, return_state=True, name="Decoder_LSTM")

decoder_outputs, _, _ = decoder_lstm(decoder_inputs,
                                     initial_state=encoder_states)

decoder_dense = Dense(num_decoder_tokens, activation='softmax', name="DecoderOutput")
decoder_outputs = decoder_dense(decoder_outputs)

model = Model([encoder_inputs, decoder_inputs], decoder_outputs)

model.compile(optimizer='rmsprop', loss='categorical_crossentropy', metrics=['accuracy'])
model.summary()

result = model.fit([encoder_input_data, decoder_input_data], decoder_target_data,
          batch_size=batch_size,
          epochs=epochs,
          validation_split=0.2)

encoder_model = Model(encoder_inputs, encoder_states)
decoder_state_input_h = Input(shape=(latent_dim,))
decoder_state_input_c = Input(shape=(latent_dim,))
decoder_states_inputs = [decoder_state_input_h, decoder_state_input_c]
decoder_outputs, state_h, state_c = decoder_lstm(
    decoder_inputs, initial_state=decoder_states_inputs)
decoder_states = [state_h, state_c]
decoder_outputs = decoder_dense(decoder_outputs)
decoder_model = Model(
    [decoder_inputs] + decoder_states_inputs,
    [decoder_outputs] + decoder_states)
reverse_target_word_index = dict(
    (i, word) for word, i in target_token_index.items())

Код GRU:

encoder_inputs = Input(shape=(None, num_encoder_tokens), name="Encoder_Input")
encoder = GRU(latent_dim, return_state=True, name="Encoder_GRU")
_, encoder_state = encoder(encoder_inputs)
decoder_inputs = Input(shape=(None, num_decoder_tokens), name="Decoder_Input")
decoder_gru = GRU(latent_dim, return_sequences=True, return_state=True, name="Decoder_GRU")

decoder_outputs, _ = decoder_gru(decoder_inputs, initial_state=encoder_state)

decoder_dense = Dense(num_decoder_tokens, activation='softmax', name="DecoderOutput")
decoder_outputs = decoder_dense(decoder_outputs)

model = Model([encoder_inputs, decoder_inputs], decoder_outputs)

model.compile(optimizer='rmsprop', loss='categorical_crossentropy', metrics=['accuracy'])
model.summary()

result = model.fit([encoder_input_data, decoder_input_data], decoder_target_data,
          batch_size=batch_size,
          epochs=epochs,
          validation_split=0.2)

encoder_model = Model(encoder_inputs, encoder_state)
decoder_states_inputs = Input(shape=(latent_dim,))
decoder_outputs, decoder_states = decoder_gru(
    decoder_inputs, initial_state=decoder_states_inputs)
decoder_outputs = decoder_dense(decoder_outputs)

decoder_model = Model(
    [decoder_inputs] + decoder_states_inputs,
    [decoder_outputs] + decoder_states) # This is where the error appears

reverse_input_word_index = dict(
    (i, word) for word, i in input_token_index.items())
reverse_target_word_index = dict(
    (i, word) for word, i in target_token_index.items())

Я отметил появление ошибки с помощью "# Здесь появляется ошибка".

Спасибо за любую помощь, которую вы можете дать, и да, мне нужно попробовать обе системы, чтобы усвоить их различия с данным набором данных.

Теги:
keras
lstm
gated-recurrent-unit

1 ответ

0
Лучший ответ

decoder_states в вашем коде LSTM - это список, поэтому вы добавляете список в список, в результате чего получается объединенный список. Но в коде decoder_states вас есть decoder_states как выход уровня decoder_states который будет иметь другой тип. Отсутствие полного кода делает отладку более сложной, но попробуйте это: [decoder_outputs] + [decoder_states]) # Notice brackets around decoder_states

  • 1
    Я мог бы поклясться, что попробовал это. Спасибо, это действительно работает сейчас.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню