forked from wojciechmo/yolo2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmake_tfrecord.py
147 lines (101 loc) · 3.61 KB
/
make_tfrecord.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
import tensorflow as tf
import numpy as np
import cv2
import csv
csv_path = './data.csv'
anchors_path = './anchors.txt'
tfrecord_path = './data.tfrecord'
net_scale = 32
grid_w, grid_h = 18, 10
n_classes = 6
iou_th = 0.7
in_w, in_h = grid_w*net_scale, grid_h*net_scale
def read_anchors_file(file_path):
anchors = []
with open(file_path, 'r') as file:
for line in file.read().splitlines():
anchors.append(map(float,line.split()))
return np.array(anchors)
def iou_wh(r1, r2):
min_w = min(r1[0],r2[0])
min_h = min(r1[1],r2[1])
area_r1 = r1[0]*r1[1]
area_r2 = r2[0]*r2[1]
intersect = min_w * min_h
union = area_r1 + area_r2 - intersect
return intersect/union
def get_grid_cell(roi, raw_w, raw_h, grid_w, grid_h):
x_center = roi[0] + roi[2]/2.0
y_center = roi[1] + roi[3]/2.0
grid_x = int(x_center/float(raw_w)*float(grid_w))
grid_y = int(y_center/float(raw_h)*float(grid_h))
return grid_x, grid_y
def get_active_anchors(roi, anchors):
indxs = []
iou_max, index_max = 0, 0
for i,a in enumerate(anchors):
iou = iou_wh(roi[2:], a)
if iou>iou_th:
indxs.append(i)
if iou > iou_max:
iou_max, index_max = iou, i
if len(indxs) == 0:
indxs.append(index_max)
return indxs
def read_csv_file(filename):
filenames = []
rois = []
classes = []
with open(filename) as csvfile:
i=['filename', 'rois', 'classes']
csvdata = csv.DictReader(csvfile)
for row in csvdata:
filenames.append(row['filename'])
rois.append(row['rois'])
classes.append(row['classes'])
return filenames, rois, classes
def roi2label(roi, anchor, raw_w, raw_h, grid_w, grid_h):
x_center = roi[0]+roi[2]/2.0
y_center = roi[1]+roi[3]/2.0
grid_x = x_center/float(raw_w)*float(grid_w)
grid_y = y_center/float(raw_h)*float(grid_h)
grid_x_offset = grid_x - int(grid_x)
grid_y_offset = grid_y - int(grid_y)
roi_w_scale = roi[2]/anchor[0]
roi_h_scale = roi[3]/anchor[1]
label=[grid_x_offset, grid_y_offset, roi_w_scale, roi_h_scale]
return label
def onehot(idx, num):
ret = np.zeros([num], dtype=np.float32)
ret[idx] = 1.0
return ret
# ---------------------------------------------------------------------------
# ---------------------------------------------------------------------------
# ---------------------------------------------------------------------------
def make_record():
anchors = read_anchors_file(anchors_path)
n_anchors = np.shape(anchors)[0]
csv_filenames, csv_rois, csv_classes = read_csv_file(csv_path)
with tf.python_io.TFRecordWriter(tfrecord_path) as writer:
for filename, rois, classes in zip(csv_filenames, csv_rois, csv_classes):
rois = np.array(eval(rois), dtype=np.float32)
classes = np.array(eval(classes), dtype=np.int32)
img = cv2.imread(filename)
raw_h = np.shape(img)[0]
raw_w = np.shape(img)[1]
img = cv2.resize(img, (in_w, in_h))
label = np.zeros([grid_h, grid_w, n_anchors, 6], dtype=np.float32)
for roi, cls in zip(rois,classes):
active_indxs = get_active_anchors(roi, anchors)
grid_x, grid_y = get_grid_cell(roi, raw_w, raw_h, grid_w, grid_h)
for active_indx in active_indxs:
anchor_label = roi2label(roi, anchors[active_indx], raw_w, raw_h, grid_w, grid_h)
label[grid_y, grid_x, active_indx] = np.concatenate((anchor_label, [cls], [1.0]))
image_raw = img.tostring()
label_raw = label.tostring()
example = tf.train.Example(features=tf.train.Features(feature={
'label': tf.train.Feature(bytes_list=tf.train.BytesList(value=[label_raw])),
'image': tf.train.Feature(bytes_list=tf.train.BytesList(value=[image_raw]))}))
writer.write(example.SerializeToString())
if __name__ == "__main__":
make_record()