Functional Keras API を使用して、2 つの入力と 2 つの出力を持つモデルを作成したいと考えています。モデルはImageDataGenerator.flow_from_directory()
メソッドの 2 つのインスタンスを使用して、2 つの異なるディレクトリ (inputs1 とinputs2) から画像を取得します。
モデルはまた、2 つのラムダ レイヤーを使用して、ジェネレーターによって取得された画像をさらに検査するためにリストに追加します。
私の質問は、そのようなモデルをトレーニングする方法です。おもちゃのコードは次のとおりです。
# Define our example directories and files
train_dir1 ='...\\cats_v_dogs_sample_training1'
train_dir2 = '...\\cats_v_dogs_sample_training2'
# Add our data-augmentation parameters to ImageDataGenerator
train_datagen = ImageDataGenerator(rescale = 1./255.,
rotation_range = 40,
width_shift_range = 0.2,
height_shift_range = 0.2,
shear_range = 0.2,
zoom_range = 0.2,
horizontal_flip = True)
# Flow training images in batches of 1 using train_datagen generator: inputs1
train_generator1 = train_datagen.flow_from_directory(train_dir1,
batch_size = 1,
class_mode = 'binary',
target_size = (150, 150), shuffle = False)
# Flow training images in batches of 1 using train_datagen generator: inputs2
train_generator2 = train_datagen.flow_from_directory(train_dir2,
batch_size = 1,
class_mode = 'binary',
target_size = (150, 150), shuffle = False)
imgs1 = []
imgs2 = []
def f_lambda1(x):
imgs1.append(x)
return(x)
def f_lambda2(x):
imgs2.append(x)
return(x)
# This returns a tensor
inputs1 = Input(shape=(150, 150, 3))
inputs2 = Input(shape=(150, 150, 3))
l1 = Lambda(f_lambda1, name = 'lambda1')(inputs1)
l2 = Lambda(f_lambda2 , name = 'lambda2')(inputs2)
x1 = Flatten()(inputs1)
x1 = Dense(1024, activation='relu')(x1)
x1 = Dropout(0.2)(x1)
outputs1 = Dense(1, activation='sigmoid')(x1)
x2 = Flatten()(inputs1)
x2 = Dense(1024, activation='relu')(x2)
x2 = Dropout(0.2)(x2)
outputs2 = Dense(1, activation='sigmoid')(x2)
model.compile()
# Train model on dataset -- The problem is that I have two not one training_generator, so the code below will not work
model.fit_generator(generator=training_generator,
validation_data=validation_generator,
use_multiprocessing=True,
workers=6)