在Keras中处理多输入和多输出模型可以通过Functional API来实现。下面是一个简单的例子:
from keras.layers import Input, Dense
from keras.models import Model
# 定义输入层
input1 = Input(shape=(10,))
input2 = Input(shape=(5,))
# 定义共享的隐藏层
shared_layer = Dense(10, activation='relu')
# 连接输入层和隐藏层
output1 = shared_layer(input1)
output2 = shared_layer(input2)
# 定义输出层
output1 = Dense(1, activation='sigmoid')(output1)
output2 = Dense(1, activation='sigmoid')(output2)
# 创建模型
model = Model(inputs=[input1, input2], outputs=[output1, output2])
# 编译模型
model.compile(optimizer='adam', loss='binary_crossentropy')
# 训练模型
model.fit([input_data1, input_data2], [output_data1, output_data2], epochs=10)
在这个例子中,我们定义了两个输入层input1
和input2
,一个共享的隐藏层shared_layer
,以及两个输出层output1
和output2
。最后我们使用Model
类将输入层和输出层连接起来,再编译模型并训练。
在训练模型时,我们需要将输入数据和输出数据分别传入fit
方法中。input_data1
和input_data2
是两个输入数据,output_data1
和output_data2
是两个输出数据。