You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
36 lines
1.4 KiB
36 lines
1.4 KiB
#!/usr/bin/env python3
|
|
import argparse
|
|
import concurrent.futures
|
|
import os
|
|
import random
|
|
from tqdm import tqdm
|
|
|
|
from selfdrive.test.process_replay.helpers import OpenpilotPrefix
|
|
from selfdrive.test.process_replay.regen import regen_and_save
|
|
from selfdrive.test.process_replay.test_processes import FAKEDATA, original_segments as segments
|
|
|
|
def regen_job(segment):
|
|
with OpenpilotPrefix():
|
|
route = segment[1].rsplit('--', 1)[0]
|
|
sidx = int(segment[1].rsplit('--', 1)[1])
|
|
fake_dongle_id = 'regen' + ''.join(random.choice('0123456789ABCDEF') for i in range(11))
|
|
try:
|
|
relr = regen_and_save(route, sidx, upload=True, use_route_meta=False, outdir=os.path.join(FAKEDATA, fake_dongle_id), disable_tqdm=True)
|
|
relr = '|'.join(relr.split('/')[-2:])
|
|
return f' ("{segment[0]}", "{relr}"), '
|
|
except Exception as e:
|
|
return f" {segment} failed: {str(e)}"
|
|
|
|
if __name__ == "__main__":
|
|
parser = argparse.ArgumentParser(description="Generate new segments from old ones")
|
|
parser.add_argument("-j", "--jobs", type=int, default=1)
|
|
args = parser.parse_args()
|
|
|
|
with concurrent.futures.ProcessPoolExecutor(max_workers=args.jobs) as pool:
|
|
p = list(pool.map(regen_job, segments))
|
|
msg = "Copy these new segments into test_processes.py:"
|
|
for seg in tqdm(p, desc="Generating segments"):
|
|
msg += "\n" + str(seg)
|
|
print()
|
|
print()
|
|
print(msg)
|
|
|