106 lines
4.1 KiB
Python
106 lines
4.1 KiB
Python
import json
|
|
import numpy as np
|
|
import cv2
|
|
import os
|
|
import argparse
|
|
|
|
TRAIN_SET = ['label_data_0313.json', 'label_data_0601.json']
|
|
VAL_SET = ['label_data_0531.json']
|
|
TRAIN_VAL_SET = TRAIN_SET + VAL_SET
|
|
TEST_SET = ['test_label.json']
|
|
|
|
def gen_label_for_json(args, image_set):
|
|
H, W = 720, 1280
|
|
SEG_WIDTH = 30
|
|
save_dir = args.savedir
|
|
|
|
os.makedirs(os.path.join(args.root, args.savedir, "list"), exist_ok=True)
|
|
list_f = open(os.path.join(args.root, args.savedir, "list", "{}_gt.txt".format(image_set)), "w")
|
|
|
|
json_path = os.path.join(args.root, args.savedir, "{}.json".format(image_set))
|
|
with open(json_path) as f:
|
|
for line in f:
|
|
label = json.loads(line)
|
|
# ---------- clean and sort lanes -------------
|
|
lanes = []
|
|
_lanes = []
|
|
slope = [] # identify 0th, 1st, 2nd, 3rd, 4th, 5th lane through slope
|
|
for i in range(len(label['lanes'])):
|
|
l = [(x, y) for x, y in zip(label['lanes'][i], label['h_samples']) if x >= 0]
|
|
if (len(l)>1):
|
|
_lanes.append(l)
|
|
slope.append(np.arctan2(l[-1][1]-l[0][1], l[0][0]-l[-1][0]) / np.pi * 180)
|
|
_lanes = [_lanes[i] for i in np.argsort(slope)]
|
|
slope = [slope[i] for i in np.argsort(slope)]
|
|
|
|
idx = [None for i in range(6)]
|
|
for i in range(len(slope)):
|
|
if slope[i] <= 90:
|
|
idx[2] = i
|
|
idx[1] = i-1 if i > 0 else None
|
|
idx[0] = i-2 if i > 1 else None
|
|
else:
|
|
idx[3] = i
|
|
idx[4] = i+1 if i+1 < len(slope) else None
|
|
idx[5] = i+2 if i+2 < len(slope) else None
|
|
break
|
|
for i in range(6):
|
|
lanes.append([] if idx[i] is None else _lanes[idx[i]])
|
|
|
|
# ---------------------------------------------
|
|
|
|
img_path = label['raw_file']
|
|
seg_img = np.zeros((H, W, 3))
|
|
list_str = [] # str to be written to list.txt
|
|
for i in range(len(lanes)):
|
|
coords = lanes[i]
|
|
if len(coords) < 4:
|
|
list_str.append('0')
|
|
continue
|
|
for j in range(len(coords)-1):
|
|
cv2.line(seg_img, coords[j], coords[j+1], (i+1, i+1, i+1), SEG_WIDTH//2)
|
|
list_str.append('1')
|
|
|
|
seg_path = img_path.split("/")
|
|
seg_path, img_name = os.path.join(args.root, args.savedir, seg_path[1], seg_path[2]), seg_path[3]
|
|
os.makedirs(seg_path, exist_ok=True)
|
|
seg_path = os.path.join(seg_path, img_name[:-3]+"png")
|
|
cv2.imwrite(seg_path, seg_img)
|
|
|
|
seg_path = "/".join([args.savedir, *img_path.split("/")[1:3], img_name[:-3]+"png"])
|
|
if seg_path[0] != '/':
|
|
seg_path = '/' + seg_path
|
|
if img_path[0] != '/':
|
|
img_path = '/' + img_path
|
|
list_str.insert(0, seg_path)
|
|
list_str.insert(0, img_path)
|
|
list_str = " ".join(list_str) + "\n"
|
|
list_f.write(list_str)
|
|
|
|
|
|
def generate_json_file(save_dir, json_file, image_set):
|
|
with open(os.path.join(save_dir, json_file), "w") as outfile:
|
|
for json_name in (image_set):
|
|
with open(os.path.join(args.root, json_name)) as infile:
|
|
for line in infile:
|
|
outfile.write(line)
|
|
|
|
def generate_label(args):
|
|
save_dir = os.path.join(args.root, args.savedir)
|
|
os.makedirs(save_dir, exist_ok=True)
|
|
generate_json_file(save_dir, "train_val.json", TRAIN_VAL_SET)
|
|
generate_json_file(save_dir, "test.json", TEST_SET)
|
|
|
|
print("generating train_val set...")
|
|
gen_label_for_json(args, 'train_val')
|
|
print("generating test set...")
|
|
gen_label_for_json(args, 'test')
|
|
|
|
if __name__ == '__main__':
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument('--root', required=True, help='The root of the Tusimple dataset')
|
|
parser.add_argument('--savedir', type=str, default='seg_label', help='The root of the Tusimple dataset')
|
|
args = parser.parse_args()
|
|
|
|
generate_label(args)
|