Слияние кода завершено, страница обновится автоматически
import glob
import os
import numpy as np
import cv2
from torch.utils.data import Dataset
from PIL import Image
import torchvision.transforms as transforms
import torchvision.transforms.functional as VF
class KolektorDataset(Dataset):
def __init__(self, dataRoot, transforms_= None, transforms_mask = None, subFold="Train_NG", isTrain=True):
self.isTrain = isTrain
if transforms_mask == None:
self.maskTransform = transforms.Compose([transforms.ToTensor()])
else:
self.maskTransform = transforms_mask
if transforms_== None:
self.transform = self.maskTransform
else:
self.transform = transforms_
self.imgFiles = sorted(glob.glob(os.path.join(dataRoot, subFold) + "/*.jpg"))
if isTrain:
self.labelFiles = sorted(glob.glob(os.path.join(dataRoot, subFold) + "/*.jpg"))
self.len = len(self.imgFiles)
def __getitem__(self, index):
idx = index % self.len
if self.isTrain==True:
img = Image.open(self.imgFiles[idx]).convert("RGB")
#mask = Image.open(self.labelFiles[idx]).convert("RGB")
mat = cv2.imread(self.labelFiles[idx], cv2.IMREAD_GRAYSCALE)
kernel = np.ones((5, 5), np.uint8)
matD = cv2.dilate(mat, kernel)
mask = Image.fromarray(matD) # image2 is a PIL image
if np.random.rand(1) > 0.5:
mask = VF.hflip(mask)
img = VF.hflip(img)
if np.random.rand(1) > 0.5:
mask = VF.vflip(mask)
img = VF.vflip(img)
img = self.transform(img)
mask = self.maskTransform(mask)
return {"img":img, "mask":mask}
else:
img = Image.open(self.imgFiles[idx]).convert("RGB")
img = self.transform(img)
return {"img":img}
def __len__(self):
return len(self.imgFiles)
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )