用于语义分割的 ImageDataGenerator
ImageDataGenerator for semantic segmentation
我正在尝试使用 Keras 进行语义分割,并且在尝试加载图像时使用 flow_from_directory
方法出现此错误。
Found 0 images belonging to 0 classes.
Found 0 images belonging to 0 classes.
这是我的代码。
from tensorflow.keras.applications.resnet50 import preprocess_input
from tensorflow.keras.preprocessing.image import ImageDataGenerator
data_generator = ImageDataGenerator()
train_generator = data_generator.flow_from_directory(
directory="../input/Training_dataset/Images",
target_size=(IMG_SIZE, IMG_SIZE),
batch_size=16,
class_mode=None,
classes=None
)
mask_generator = data_generator.flow_from_directory(
directory="../input/Training_dataset/Masks/all",
class_mode=None,
classes=None,
batch_size = 1,
)
我已阅读此问题,但解决方案无效
您需要将图像保存在一个子文件夹中,例如在图像和蒙版目录中创建一个名为 "img" 的文件夹。
-- image
-- img
-- 1.jpg
-- 2.jpg
-- mask
-- img
-- 1.png
-- 2.png
数据生成器应该是这样的:-
seed = 909 # (IMPORTANT) to transform image and corresponding mask with same augmentation parameter.
image_datagen = ImageDataGenerator(width_shift_range=0.1,
height_shift_range=0.1,
preprocessing_function = image_preprocessing) # custom fuction for each image you can use resnet one too.
mask_datagen = ImageDataGenerator(width_shift_range=0.1,
height_shift_range=0.1,
preprocessing_function = mask_preprocessing) # to make mask as feedable formate (256,256,1)
image_generator =image_datagen.flow_from_directory("dataset/image/",
class_mode=None, seed=seed)
mask_generator = mask_datagen.flow_from_directory("dataset/mask/",
class_mode=None, seed=seed)
train_generator = zip(image_generator, mask_generator)
如果您想为语义分割模型制作自己的自定义数据生成器以更好地控制数据集,您可以查看我使用 camvid 数据集训练 UNET 模型的 kaggle 内核。
https://www.kaggle.com/mukulkr/camvid-segmentation-using-unet
如果你需要更好的增强功能,你可以查看这个很棒的GitHub repo -
https://github.com/mdbloice/Augmentor
我正在尝试使用 Keras 进行语义分割,并且在尝试加载图像时使用 flow_from_directory
方法出现此错误。
Found 0 images belonging to 0 classes.
Found 0 images belonging to 0 classes.
这是我的代码。
from tensorflow.keras.applications.resnet50 import preprocess_input
from tensorflow.keras.preprocessing.image import ImageDataGenerator
data_generator = ImageDataGenerator()
train_generator = data_generator.flow_from_directory(
directory="../input/Training_dataset/Images",
target_size=(IMG_SIZE, IMG_SIZE),
batch_size=16,
class_mode=None,
classes=None
)
mask_generator = data_generator.flow_from_directory(
directory="../input/Training_dataset/Masks/all",
class_mode=None,
classes=None,
batch_size = 1,
)
我已阅读此问题,但解决方案无效
您需要将图像保存在一个子文件夹中,例如在图像和蒙版目录中创建一个名为 "img" 的文件夹。
-- image
-- img
-- 1.jpg
-- 2.jpg
-- mask
-- img
-- 1.png
-- 2.png
数据生成器应该是这样的:-
seed = 909 # (IMPORTANT) to transform image and corresponding mask with same augmentation parameter.
image_datagen = ImageDataGenerator(width_shift_range=0.1,
height_shift_range=0.1,
preprocessing_function = image_preprocessing) # custom fuction for each image you can use resnet one too.
mask_datagen = ImageDataGenerator(width_shift_range=0.1,
height_shift_range=0.1,
preprocessing_function = mask_preprocessing) # to make mask as feedable formate (256,256,1)
image_generator =image_datagen.flow_from_directory("dataset/image/",
class_mode=None, seed=seed)
mask_generator = mask_datagen.flow_from_directory("dataset/mask/",
class_mode=None, seed=seed)
train_generator = zip(image_generator, mask_generator)
如果您想为语义分割模型制作自己的自定义数据生成器以更好地控制数据集,您可以查看我使用 camvid 数据集训练 UNET 模型的 kaggle 内核。
https://www.kaggle.com/mukulkr/camvid-segmentation-using-unet
如果你需要更好的增强功能,你可以查看这个很棒的GitHub repo - https://github.com/mdbloice/Augmentor