-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdisplay_dataset.py
executable file
·74 lines (62 loc) · 2.48 KB
/
display_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
#!/usr/bin/env python
import cv2
import os
import numpy as np
def main():
# TODO: Load these parameters from a file or command line
ds_folder = "output/testing"
ds_fnames = os.listdir(ds_folder)
ds_fnames.sort()
tot_imgs = int(len(ds_fnames)/2)
print("Showing bounding boxes for {:d} total images".format(tot_imgs))
window_name = "Dataset bounding box check"
cv2.namedWindow(window_name,cv2.WINDOW_NORMAL)
cv2.resizeWindow(window_name, 640, 480)
for filename in ds_fnames:
img_name = '.'.join(filename.split('.')[0:-1])
extension = filename.split('.')[-1]
if extension == "txt":
continue
label_exists = False;
try:
labels = list()
# Open the label file
with open("{:s}/{:s}.txt".format(ds_folder, img_name), 'r') as infname:
for line in infname.readlines():
spl = line.split(' ')
label = (
float(spl[0]), # object ID
(float(spl[1]), # x coordinate of the bb center
float(spl[2])), # y coordinate of the bb center
(float(spl[3]), # width of the bb
float(spl[4])) # height of the bb
)
labels.append(label)
label_exists = True;
except:
print("Image without a label: '{:s}'!".format(filename))
if label_exists:
img = cv2.imread("{:s}/{:s}".format(ds_folder, filename), cv2.IMREAD_UNCHANGED)
img_width = img.shape[1]
img_height = img.shape[0]
for label in labels:
cent_x = label[1][0]*img_width
cent_y = label[1][1]*img_height
width = label[2][0]*img_width
height = label[2][1]*img_height
x1 = int(np.ceil(cent_x - width/2))
x2 = int(np.floor(cent_x + width/2))
y1 = int(np.ceil(cent_y - height/2))
y2 = int(np.floor(cent_y + height/2))
cv2.rectangle(img, (x1, y1), (x2, y2), (0,0,255), 5)
cv2.imshow(window_name, img)
k = cv2.waitKey(0) # 0 - wait forever
if k == ord('w'):
print("Image {:s} marked as labeled WRONG!".format(filename))
elif k == ord('q'):
print("Ending")
break
cv2.destroyWindow(window_name)
print("Done with everything. Goodbye.")
if __name__ == "__main__":
main()