-
Notifications
You must be signed in to change notification settings - Fork 178
/
Copy pathvisualize_detection_result.py
94 lines (78 loc) · 3.46 KB
/
visualize_detection_result.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
#encoding utf-8
import numpy as np
import util
def draw_bbox(image_data, line, color):
line = util.str.remove_all(line, '\xef\xbb\xbf')
data = line.split(',');
def draw_rectangle():
x1, y1, x2, y2 = [int(v) for v in data[0 : 4]]
util.img.rectangle(
img = image_data,
left_up = (x1, y1),
right_bottom = (x2, y2),
color = color,
border_width = 1)
def draw_text():
text = data[-1]
pos = [int(v) for v in data[0:2]]
util.img.put_text(
img = image_data,
text = text,
pos = pos,
scale = 1,
color = color)
def draw_oriented_bbox():
points = [int(v) for v in data[0:8]]
points = np.reshape(points, (4, 2))
cnts = util.img.points_to_contours(points)
util.img.draw_contours(image_data, cnts, -1, color = color, border_width = 1)
draw_oriented_bbox()
# if len(data) == 5: # ic13 gt
# draw_rectangle()
# draw_text()
# elif len(data) == 8:# all det
# draw_oriented_bbox()
# elif len(data) == 9: # ic15 gt
# draw_oriented_bbox()
# draw_text()
# else:
# import pdb
# pdb.set_trace()
# print data
# raise ValueError
def visualize(image_root, det_root, output_root, gt_root = None):
def read_gt_file(image_name):
gt_file = util.io.join_path(gt_root, 'gt_%s.txt'%(image_name))
return util.io.read_lines(gt_file)
def read_det_file(image_name):
det_file = util.io.join_path(det_root, 'res_%s.txt'%(image_name))
return util.io.read_lines(det_file)
def read_image_file(image_name):
return util.img.imread(util.io.join_path(image_root, image_name))
image_names = util.io.ls(image_root, '.jpg')
for image_idx, image_name in enumerate(image_names):
print '%d / %d: %s'%(image_idx + 1, len(image_names), image_name)
image_data = read_image_file(image_name) # in BGR
image_name = image_name.split('.')[0]
det_image = image_data.copy()
det_lines = read_det_file(image_name)
for line in det_lines:
draw_bbox(det_image, line, color = util.img.COLOR_BGR_RED)
util.img.imwrite(util.io.join_path(output_root, '%s_pred.jpg'%(image_name)), det_image)
if gt_root is not None:
gt_lines = read_gt_file(image_name)
for line in gt_lines:
draw_bbox(image_data, line, color = util.img.COLOR_GREEN)
util.img.imwrite(util.io.join_path(output_root, '%s_gt.jpg'%(image_name)), image_data)
if __name__ == '__main__':
import argparse
parser = argparse.ArgumentParser(description='visualize detection result of seglink')
parser.add_argument('--image', type=str, required = True,help='the directory of test image')
parser.add_argument('--gt', type=str, default=None,help='the directory of ground truth txt files')
parser.add_argument('--det', type=str, required = True, help='the directory of detection result')
parser.add_argument('--output', type=str, required = True, help='the directory to store images with bboxes')
args = parser.parse_args()
print('**************Arguments*****************')
print(args)
print('****************************************')
visualize(image_root = args.image, gt_root = args.gt, det_root = args.det, output_root = args.output)