forked from zzilch/RPLAN-Toolbox
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbatch_align.py
47 lines (40 loc) · 1.42 KB
/
batch_align.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
import os
import numpy as np
from tqdm.auto import tqdm
from rplan.floorplan import Floorplan
from rplan.align import align_fp_gt
from rplan.decorate import get_dw
from rplan.utils import get_edges,savepkl,savemat
from multiprocessing import Pool,Manager
def func(file_path):
fp = Floorplan(file_path)
data = fp.to_dict(dtype=np.uint8)
boxes_aligned, order, room_boundaries = align_fp_gt(data['boundary'],data['boxes'],data['types'],data['edges'],dtype=np.uint8)
data['boxes_aligned'] = boxes_aligned
data['edges_aligned'] = np.array(get_edges(boxes_aligned),dtype=np.uint8)
data['order'] = order
return data
class Callback():
def __init__(self,length):
self.bar = tqdm(total=length)
self.output = []
def update(self, ret):
self.output.append(ret)
self.bar.update(1)
def close(self):
self.bar.close()
if __name__ == '__main__':
img_dir = './data'
ids = os.listdir(img_dir)
ids = [f'{img_dir}/{i}' for i in ids]
print(len(ids))
with Manager() as manager:
with Pool(32) as pool:
cb = Callback(len(ids))
[pool.apply_async(func,args=(i,),callback=cb.update) for i in ids]
pool.close()
pool.join()
cb.close()
savepkl('./output/data_aligned.pkl',cb.output)
# for matlab
# savemat('./output/data_aligned.mat',{'data':cb.output})