-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathdata_loader.py
executable file
·52 lines (41 loc) · 1.65 KB
/
data_loader.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
import multiprocessing
from tensorpack import imgaug
from tensorpack.dataflow import AugmentImageCoordinates
from tensorpack.dataflow import PrefetchDataZMQ
from tensorpack.dataflow import BatchData
import dataflow
def fbresnet_augmentor(is_training, option):
if is_training:
augmentors = [
imgaug.ToFloat32(),
imgaug.Resize((option.final_size + 32, option.final_size + 32)),
imgaug.RandomCrop((option.final_size, option.final_size))
]
flip = [imgaug.Flip(horiz=True), imgaug.ToUint8()]
augmentors.extend(flip)
else:
augmentors = [
imgaug.ToFloat32(),
imgaug.Resize((option.final_size + 32, option.final_size + 32)),
imgaug.CenterCrop((option.final_size, option.final_size)),
imgaug.ToUint8()
]
return augmentors
def get_data_flow(split, is_training, option):
if option.dataset_name == 'ILSVRC':
ds = dataflow.Imagenet(option.data_dir, split, shuffle=is_training)
elif option.dataset_name == 'CUB':
ds = dataflow.CUB(option.data_dir, split, shuffle=is_training)
else:
raise KeyError("Unavailable dataset: {}".format(option.dataset_name))
return ds
def get_data(split, option):
is_training = split == 'train'
parallel = multiprocessing.cpu_count() // 2
ds = get_data_flow(split, is_training, option)
augmentors = fbresnet_augmentor(is_training, option)
ds = AugmentImageCoordinates(ds, augmentors, coords_index=2, copy=False)
if is_training:
ds = PrefetchDataZMQ(ds, parallel)
ds = BatchData(ds, option.batch_size, remainder=not is_training)
return ds