-
Notifications
You must be signed in to change notification settings - Fork 306
/
Copy pathcreate_cityscapes_tf_record.py
140 lines (111 loc) · 4.59 KB
/
create_cityscapes_tf_record.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
r"""Build a TF Record for Cityscapes Semantic Segmentation dataset."""
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
import hashlib
import glob
import io
import json
import os
import numpy as np
import PIL.Image
import tensorflow as tf
flags = tf.app.flags
tf.flags.DEFINE_string('input_pattern', '',
'Cityscapes dataset root folder.')
tf.flags.DEFINE_string('annot_pattern', '',
'Pattern matching input images for Cityscapes.')
tf.flags.DEFINE_string('cityscapes_dir', '',
'Pattern matching ground truth images for Cityscapes.')
tf.flags.DEFINE_string('split_type', '',
'Type of split: `train`, `test` or `val`.')
tf.flags.DEFINE_string('output_dir', '', 'Output data directory.')
FLAGS = flags.FLAGS
tf.logging.set_verbosity(tf.logging.INFO)
_DEFAULT_PATTEN = {
'input': '*_leftImg8bit.png',
'annot': '*_gtFine_labelTrainIds.png'
}
_DEFAULT_DIR = {
'image': 'leftImg8bit',
'label': 'gtFine'
}
def _bytes_feature(values):
return tf.train.Feature(
bytes_list=tf.train.BytesList(value=[values]))
def _int64_feature(values):
if not isinstance(values, (tuple, list)):
values = [values]
return tf.train.Feature(int64_list=tf.train.Int64List(value=values))
def _open_file(full_path):
with tf.gfile.GFile(full_path, 'rb') as fid:
encoded_file = fid.read()
encoded_file_io = io.BytesIO(encoded_file)
image = PIL.Image.open(encoded_file_io)
return image, encoded_file
def create_tf_example(image_path, label_path, image_dir='', is_jpeg=False):
file_format = 'jpeg' if is_jpeg else 'png'
full_image_path = os.path.join(image_dir, image_path)
full_label_path = os.path.join(image_dir, label_path)
image, encoded_image = _open_file(full_image_path)
label, encoded_label = _open_file(full_label_path)
height = image.height
width = image.width
if height != label.height or width != label.width:
raise ValueError('Input and annotated images must have same dims.'
'verify the matching pair for {}'.format(full_image_path))
feature_dict = {
'image/encoded': _bytes_feature(encoded_image),
'image/filename': _bytes_feature(
full_image_path.encode('utf8')),
'image/format': _bytes_feature(
file_format.encode('utf8')),
'image/height': _int64_feature(height),
'image/width': _int64_feature(width),
'image/channels': _int64_feature(3),
'label/encoded': _bytes_feature(encoded_label),
'label/format':_bytes_feature(
'png'.encode('utf8')),
}
example = tf.train.Example(
features=tf.train.Features(feature=feature_dict))
return example
def _create_tf_record(images, labels, output_path):
writer = tf.python_io.TFRecordWriter(output_path)
for idx, image in enumerate(images):
if idx % 100 == 0:
tf.logging.info('On image %d of %d', idx, len(images))
tf_example = create_tf_example(
image, labels[idx], is_jpeg=False)
writer.write(tf_example.SerializeToString())
writer.close()
tf.logging.info('Finished writing!')
def main(_):
assert FLAGS.output_dir, '`output_dir` missing.'
assert FLAGS.split_type, '`split_type` missing.'
assert (FLAGS.cityscapes_dir) or \
(FLAGS.input_pattern and FLAGS.annot_pattern), \
'Must specify either `cityscapes_dir` or ' \
'`input_pattern` and `annot_pattern`.'
if not tf.gfile.IsDirectory(FLAGS.output_dir):
tf.gfile.MakeDirs(FLAGS.output_dir)
train_output_path = os.path.join(FLAGS.output_dir,
'{}.record'.format(FLAGS.split_type))
if FLAGS.cityscapes_dir:
search_image_files = os.path.join(FLAGS.cityscapes_dir,
_DEFAULT_DIR['image'], FLAGS.split_type, '*', _DEFAULT_PATTEN['input'])
search_annot_files = os.path.join(FLAGS.cityscapes_dir,
_DEFAULT_DIR['label'], FLAGS.split_type, '*', _DEFAULT_PATTEN['annot'])
image_filenames = glob.glob(search_image_files)
annot_filenames = glob.glob(search_annot_files)
else:
image_filenames = glob.glob(FLAGS.input_pattern)
annot_filenames = glob.glob(FLAGS.annot_pattern)
if len(image_filenames) != len(annot_filenames):
raise ValueError('Supplied patterns do not have image counts.')
_create_tf_record(
sorted(image_filenames),
sorted(annot_filenames),
output_path=train_output_path)
if __name__ == '__main__':
tf.app.run()