Python Keras:使用flow_from_directory()函数为两个输入模型创建自定义生成器

Python Keras:使用flow_from_directory()函数为两个输入模型创建自定义生成器,python,keras,neural-network,generator,conv-neural-network,Python,Keras,Neural Network,Generator,Conv Neural Network,我试图用fit_generator()来训练我的暹罗网络,我从这个答案中学到:最好的方法是创建自己的生成器,生成多个数据点,我的问题是我使用flow_from_directory()函数检索数据,我不知道这是否可行。 这是我尝试为我的问题重新调整生成器: from keras.models import load_model from keras import optimizers from keras.preprocessing.image import ImageDataGenerator

我试图用
fit_generator()
来训练我的暹罗网络,我从这个答案中学到:最好的方法是创建自己的生成器,生成多个数据点,我的问题是我使用
flow_from_directory()
函数检索数据,我不知道这是否可行。 这是我尝试为我的问题重新调整生成器:

from keras.models import load_model
from keras import optimizers
from keras.preprocessing.image import ImageDataGenerator
import numpy as np

model = load_model("siamese_model.h5")

train_datagen = ImageDataGenerator(rescale = 1./255)

def generator():
    t1 = train_datagen.flow_from_directory(base_dir,target_size = (150, 150), batch_size = 20, class_mode = 'categorical',shuffle = True)
    t2 = train_datagen.flow_from_directory(base_dir,target_size = (150, 150), batch_size = 20, class_mode = 'categorical', shuffle = True)
    while True:
        d1,y = t1.next()
        d2 = t2.next()
        yield ([d1[0], d2[0]],y)

model.compile(loss = 'categorical_crossentropy',optimizer= optimizers.RMSprop(lr=2e-5),metrics=['acc'])

history = model.fit_generator(generator(),
                              steps_per_epoch = 10,
                              epochs = 5)

我的代码给出的错误与我尝试在没有自定义生成器的情况下拟合模型时的错误完全相同:

ValueError: Error when checking model input: the list of Numpy arrays that you are passing to your model is not the size the model expected. Expected to see 2 array(s), but instead got the following list of 1 arrays: [array([[[[0.14509805, 0.15686275, 0.16862746],
         [0.14509805, 0.15686275, 0.16862746],
         [0.14509805, 0.15686275, 0.16862746],
         ...,
         [0.14117648, 0.15294118, 0.16862746...
我做错了什么?

试试这个:

while True:
    d1 = t1.next()
    d2 = t2.next()
    yield ([d1[0], d2[0]], d1[1])
此外,您的输入将以不同的方式洗牌,因此,如果您将它们按特定顺序放入文件夹中,它们将丢失链接

我建议:

t1 = train_datagen.flow_from_directory(base_dir,target_size = (150, 150), batch_size = 20, class_mode = 'categorical', shuffle = False, seed='13')

t2 = train_datagen.flow_from_directory(base_dir,target_size = (150, 150), batch_size = 20, class_mode = 'categorical', shuffle = False, seed='13')
或者用同样的种子洗牌

t1 = train_datagen.flow_from_directory(base_dir,target_size = (150, 150), batch_size = 20, class_mode = 'categorical', shuffle = True, seed='13')

t2 = train_datagen.flow_from_directory(base_dir,target_size = (150, 150), batch_size = 20, class_mode = 'categorical', shuffle = True, seed='13')