forked from aimagelab/dress-code
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
99 lines (74 loc) · 3.3 KB
/
main.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
import torch
from data import Dataset, DataLoader
from tqdm import tqdm
from utils import sem2onehot
import conf
def test_unpaired(dataloader, model, e, args):
with tqdm(desc="Iteration %d - images extraction" % e, unit='it', total=len(dataloader.data_loader)) as pbar:
for step in range(0, len(dataloader.data_loader)):
inputs = dataloader.next_batch()
with torch.no_grad():
image_name = inputs['im_name']
cloth_name = inputs['c_name']
image = inputs['image'].cuda()
cloth = inputs['cloth'].cuda()
cropped_cloth = inputs['im_cloth'].cuda()
im_head = inputs['im_head'].cuda()
pose_map = inputs['pose_map'].cuda()
skeleton = inputs['skeleton'].cuda()
im_pose = inputs['im_pose'].cuda()
shape = inputs['shape'].cuda()
parse_array = inputs['parse_array'].cuda()
dense_labels = inputs['dense_labels'].cuda()
dense_uv = inputs['dense_uv'].cuda()
parse_array = sem2onehot(18, parse_array)
# model here
def training_loop(dataloader, model, e, args):
with tqdm(desc="Iteration %d - train" % e, unit='it', total=args.display_count) as pbar:
for step in range(0, args.display_count):
inputs = dataloader.next_batch()
image_name = inputs['im_name']
cloth_name = inputs['c_name']
image = inputs['image'].cuda()
cloth = inputs['cloth'].cuda()
cropped_cloth = inputs['im_cloth'].cuda()
im_head = inputs['im_head'].cuda()
pose_map = inputs['pose_map'].cuda()
skeleton = inputs['skeleton'].cuda()
im_pose = inputs['im_pose'].cuda()
shape = inputs['shape'].cuda()
parse_array = inputs['parse_array'].cuda()
dense_labels = inputs['dense_labels'].cuda()
dense_uv = inputs['dense_uv'].cuda()
parse_array = sem2onehot(18, parse_array)
# model here
pbar.update()
def main_worker(args):
# Dataset & Dataloader
dataset_train = Dataset(args,
dataroot_path=args.dataroot,
phase='train',
order='paired',
size=(int(args.height), int(args.width)))
dataloader_train = DataLoader(args, dataset_train, dist_sampler=False)
dataset_test_unpaired = Dataset(args,
dataroot_path=args.dataroot,
phase='test',
order='unpaired',
size=(int(args.height), int(args.width)))
dataloader_test_unpaired = DataLoader(args, dataset_test_unpaired, dist_sampler=False)
# Instance here your model
model = None
# Loop in epochs
for e in range(0, args.epochs):
# Training loop
training_loop(dataloader_train, model, e, args)
# Test unpaired
inputs = dataloader_test_unpaired.next_batch()
test_unpaired(inputs, model, e, args)
if __name__ == '__main__':
# Get argparser configuration
args = conf.get_conf()
print(args.exp_name)
# Call main worker
main_worker(args)