|
@@ -32,10 +32,28 @@ def main():
|
|
|
|
|
|
data = json.load(open(json_file))
|
|
|
|
|
|
- img = utils.img_b64_to_array(data['imageData'])
|
|
|
- lbl, lbl_names = utils.labelme_shapes_to_label(img.shape, data['shapes'])
|
|
|
-
|
|
|
- captions = ['%d: %s' % (l, name) for l, name in enumerate(lbl_names)]
|
|
|
+ img = utils.img_b64_to_arr(data['imageData'])
|
|
|
+
|
|
|
+ label_name_to_value = {'_background_': 0}
|
|
|
+ for shape in data['shapes']:
|
|
|
+ label_name = shape['label']
|
|
|
+ if label_name in label_name_to_value:
|
|
|
+ label_value = label_name_to_value[label_name]
|
|
|
+ else:
|
|
|
+ label_value = len(label_name_to_value)
|
|
|
+ label_name_to_value[label_name] = label_value
|
|
|
+
|
|
|
+ # label_values must be dense
|
|
|
+ label_values, label_names = [], []
|
|
|
+ for ln, lv in sorted(label_name_to_value.items(), key=lambda x: x[1]):
|
|
|
+ label_values.append(lv)
|
|
|
+ label_names.append(ln)
|
|
|
+ assert label_values == list(range(len(label_values)))
|
|
|
+
|
|
|
+ lbl = utils.shapes_to_label(img.shape, data['shapes'], label_name_to_value)
|
|
|
+
|
|
|
+ captions = ['{}: {}'.format(lv, ln)
|
|
|
+ for ln, lv in label_name_to_value.items()]
|
|
|
lbl_viz = utils.draw_label(lbl, img, captions)
|
|
|
|
|
|
PIL.Image.fromarray(img).save(osp.join(out_dir, 'img.png'))
|
|
@@ -43,11 +61,11 @@ def main():
|
|
|
PIL.Image.fromarray(lbl_viz).save(osp.join(out_dir, 'label_viz.png'))
|
|
|
|
|
|
with open(osp.join(out_dir, 'label_names.txt'), 'w') as f:
|
|
|
- for lbl_name in lbl_names:
|
|
|
+ for lbl_name in label_names:
|
|
|
f.write(lbl_name + '\n')
|
|
|
|
|
|
warnings.warn('info.yaml is being replaced by label_names.txt')
|
|
|
- info = dict(label_names=lbl_names)
|
|
|
+ info = dict(label_names=label_names)
|
|
|
with open(osp.join(out_dir, 'info.yaml'), 'w') as f:
|
|
|
yaml.safe_dump(info, f, default_flow_style=False)
|
|
|
|