Otrzymujesz błąd, ponieważ result
zdefiniowano jako Sequential()
tylko kontener dla modelu i nie zdefiniowano dla niego danych wejściowych.
Biorąc pod uwagę to, co próbujesz zbudować, ustaw result
trzeci sygnał wejściowy x3
.
first = Sequential()
first.add(Dense(1, input_shape=(2,), activation='sigmoid'))
second = Sequential()
second.add(Dense(1, input_shape=(1,), activation='sigmoid'))
third = Sequential()
third.add(Dense(1, input_shape=(1,), activation='sigmoid'))
merged = Concatenate([first, second])
result = Concatenate([merged, third])
ada_grad = Adagrad(lr=0.1, epsilon=1e-08, decay=0.0)
result.compile(optimizer=ada_grad, loss='binary_crossentropy',
metrics=['accuracy'])
Jednak moim preferowanym sposobem budowania modelu, który ma tego typu strukturę wejściową, byłoby użycie funkcjonalnego interfejsu API .
Oto implementacja twoich wymagań na początek:
from keras.models import Model
from keras.layers import Concatenate, Dense, LSTM, Input, concatenate
from keras.optimizers import Adagrad
first_input = Input(shape=(2, ))
first_dense = Dense(1, )(first_input)
second_input = Input(shape=(2, ))
second_dense = Dense(1, )(second_input)
merge_one = concatenate([first_dense, second_dense])
third_input = Input(shape=(1, ))
merge_two = concatenate([merge_one, third_input])
model = Model(inputs=[first_input, second_input, third_input], outputs=merge_two)
ada_grad = Adagrad(lr=0.1, epsilon=1e-08, decay=0.0)
model.compile(optimizer=ada_grad, loss='binary_crossentropy',
metrics=['accuracy'])
Aby odpowiedzieć na pytanie w komentarzach:
- W jaki sposób wynik i scalone są połączone? Zakładając, że masz na myśli, w jaki sposób są one połączone.
Konkatenacja działa w ten sposób:
a b c
a b c g h i a b c g h i
d e f j k l d e f j k l
tzn. rzędy są właśnie połączone.
- Teraz
x1
jest dane wejściowe do pierwszego, x2
do drugiego i x3
do trzeciego.
result
imerged
(lubmerged2
) są połączone ze sobą w pierwszej części Twojej odpowiedzi?