-
Notifications
You must be signed in to change notification settings - Fork 24
/
Copy pathdataset.py
84 lines (65 loc) · 3.08 KB
/
dataset.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import torch
import torch.utils.data as data
from os import listdir
from os.path import join
from PIL import Image, ImageOps
import random
import torchvision.transforms as transforms
def load_image(file_path, input_height=128, input_width=None, output_height=128, output_width=None,
crop_height=None, crop_width=None, is_random_crop=True, is_mirror=True, is_gray=False):
if input_width is None:
input_width = input_height
if output_width is None:
output_width = output_height
if crop_width is None:
crop_width = crop_height
img = Image.open(file_path)
if is_gray is False and img.mode is not 'RGB':
img = img.convert('RGB')
if is_gray and img.mode is not 'L':
img = img.convert('L')
if is_mirror and random.randint(0,1) is 0:
img = ImageOps.mirror(img)
if input_height is not None:
img = img.resize((input_width, input_height),Image.BICUBIC)
if crop_height is not None:
[w, h] = img.size
if is_random_crop:
#print([w,cropSize])
cx1 = random.randint(0, w-crop_width)
cx2 = w - crop_width - cx1
cy1 = random.randint(0, h-crop_height)
cy2 = h - crop_height - cy1
else:
cx2 = cx1 = int(round((w-crop_width)/2.))
cy2 = cy1 = int(round((h-crop_height)/2.))
img = ImageOps.crop(img, (cx1, cy1, cx2, cy2))
img = img.resize((output_width, output_height),Image.BICUBIC)
return img
class ImageDatasetFromFile(data.Dataset):
def __init__(self, image_list, root_path,
input_height=128, input_width=None, output_height=128, output_width=None,
crop_height=None, crop_width=None, is_random_crop=False, is_mirror=True, is_gray=False):
super(ImageDatasetFromFile, self).__init__()
self.image_filenames = image_list
self.is_random_crop = is_random_crop
self.is_mirror = is_mirror
self.input_height = input_height
self.input_width = input_width
self.output_height = output_height
self.output_width = output_width
self.root_path = root_path
self.crop_height = crop_height
self.crop_width = crop_width
self.is_gray = is_gray
self.input_transform = transforms.Compose([
transforms.ToTensor()
])
def __getitem__(self, index):
img = load_image(join(self.root_path, self.image_filenames[index]),
self.input_height, self.input_width, self.output_height, self.output_width,
self.crop_height, self.crop_width, self.is_random_crop, self.is_mirror, self.is_gray)
img = self.input_transform(img)
return img
def __len__(self):
return len(self.image_filenames)