Как получить скрытые матрицы состояний из сложенного слоя BiLSTM в Tensorflow Keras? - PullRequest
0 голосов
/ 03 февраля 2020

Я пытаюсь написать код для этой архитектуры (модель с ответом на вопрос: Бумага https://www.hindawi.com/journals/cin/2019/9543490/) и ищу помощь в получении скрытых матриц состояний Hq и Ha из сложенных слоев BiLSTM. Может кто-нибудь, пожалуйста, сообщите.

enter image description here

enter image description here

# Creating Embedding Layer for Query
# Considered fixed length as 40 for both question and answer as per research paper
embedding_layer1 = layers.Embedding(vocab_size_query, 300, weights=[embedding_matrix_query], input_length =40, trainable=False)
input_text1 =Input(shape=(40,), name="input_text")
x = embedding_layer1(input_text1)

# Creating Bidirectional layer for Query
# Each word in the context and question should be made aware of the nearby words occurring. We use a bi-directional recurrent neural network (LSTM’s) here.
x = Bidirectional(LSTM(128,recurrent_dropout=0.5,kernel_regularizer=regularizers.l2(0.001),return_sequences=True))(x)
x = Bidirectional(LSTM(128,recurrent_dropout=0.5,kernel_regularizer=regularizers.l2(0.001),return_sequences=True))(x)
flatten_1 = Flatten()(x)

## Creating Embedding Layer for Passage
embedding_layer2 = layers.Embedding(vocab_size_answer, 300, weights=[embedding_matrix_answer], input_length =40, trainable=False)
input_text2 =Input(shape=(40,), name="input_text")
x2 = embedding_layer2(input_text2)

# Creating Bidirectional layer for Passage
x2 = Bidirectional(LSTM(128,recurrent_dropout=0.5,kernel_regularizer=regularizers.l2(0.001),return_sequences=True))(x2)
x2 = Bidirectional(LSTM(128,recurrent_dropout=0.5,kernel_regularizer=regularizers.l2(0.001),return_sequences=True))(x2)
flatten_2 = Flatten()(x2)

enter image description here

1 Ответ

1 голос
/ 06 февраля 2020

В соответствии со структурой модели и вашим исходным кодом вы можете получить Hq и Ha, извлекая выходные данные из слоев flatten_1 и flatten_2. Чтобы извлечь выходные данные промежуточного слоя, вы можете создать новую модель с вводом в качестве исходного ввода и выводом в качестве соответствующего слоя.

from tensorflow.keras.models import Model

model = ...  # create the original model

layer_name = 'my_layer'
intermediate_layer_model = Model(inputs=model.input,
                                 outputs=model.get_layer(layer_name).output)
intermediate_output = intermediate_layer_model.predict(data)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...