openpilot is an open source driver assistance system. openpilot performs the functions of Automated Lane Centering and Adaptive Cruise Control for over 200 supported car makes and models.
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.

132 lines
3.6 KiB

1 week ago
from argparse import ArgumentParser
from cereal.messaging import SubMaster
2 weeks ago
import os
import signal
import subprocess
from subprocess import DEVNULL
import time
import atexit
from random import randint
2 weeks ago
from openpilot.common.prefix import OpenpilotPrefix
DEFAULT_DISPLAY = ":99"
2 weeks ago
RESOLUTION = "2160x1080"
PIXEL_DEPTH = "24"
FRAMERATE = 20
1 week ago
DEFAULT_OUTPUT = "output.mp4"
DEMO_ROUTE = "a2a0ccea32023010/2023-07-27--13-01-19/0"
2 weeks ago
def wait_for_video():
sm = SubMaster(['uiDebug'])
no_frames_drawn = True
while no_frames_drawn:
sm.update()
no_frames_drawn = sm['uiDebug'].drawTimeMillis == 0.
def ensure_xvfb(display: str):
xvfb_cmd = ["Xvfb", display, "-screen", "0", f"{RESOLUTION}x{PIXEL_DEPTH}"]
2 weeks ago
xvfb_proc = subprocess.Popen(xvfb_cmd, stdout=DEVNULL, stderr=DEVNULL)
time.sleep(1)
2 weeks ago
if xvfb_proc.poll() is not None:
raise RuntimeError(f"Failed to start Xvfb on display {display}")
2 weeks ago
return xvfb_proc
1 week ago
def main(route: str, output_filepath: str, start_seconds: int, end_seconds: int):
# TODO: evaluate creating fn that inspects /tmp/.X11-unix and creates unused display to avoid possibility of collision
1 week ago
display_num = str(randint(99, 999))
1 week ago
duration = end_seconds - start_seconds
2 weeks ago
env = os.environ.copy()
env["QT_QPA_PLATFORM"] = "xcb"
1 week ago
#xvfb_proc = ensure_xvfb(display)
#atexit.register(lambda: xvfb_proc.terminate())
2 weeks ago
1 week ago
ui_proc = subprocess.Popen([
'xvfb-run',
'-n', display_num,
'-s', f'-screen 0 {RESOLUTION}x{PIXEL_DEPTH}',
'./selfdrive/ui/ui'
], env=env)
2 weeks ago
atexit.register(lambda: ui_proc.terminate())
replay_proc = subprocess.Popen([
"./tools/replay/replay",
"-c", "1",
"-s", str(start_seconds),
"--no-loop",
"--prefix", env.get('OPENPILOT_PREFIX'),
route
1 week ago
], env=env)
2 weeks ago
atexit.register(lambda: replay_proc.terminate())
# Wait for video data
wait_for_video()
time.sleep(2)
2 weeks ago
# Start FFmpeg
ffmpeg_cmd = [
"ffmpeg",
1 week ago
"-y",
2 weeks ago
"-video_size",
RESOLUTION,
"-framerate",
str(FRAMERATE),
"-f",
"x11grab",
"-draw_mouse",
"0",
"-i",
1 week ago
':' + display_num,
2 weeks ago
"-c:v",
"libx264",
"-preset",
"ultrafast",
"-pix_fmt",
"yuv420p",
1 week ago
output_filepath,
2 weeks ago
]
ffmpeg_proc = subprocess.Popen(ffmpeg_cmd, env=env, stdout=DEVNULL, stderr=DEVNULL)
atexit.register(lambda: ffmpeg_proc.terminate())
1 week ago
print(f'starting at {start_seconds} seconds and clipping {duration} seconds')
time.sleep(duration)
2 weeks ago
ffmpeg_proc.send_signal(signal.SIGINT)
ffmpeg_proc.wait(timeout=5)
ui_proc.terminate()
ui_proc.wait(timeout=5)
1 week ago
#xvfb_proc.terminate()
#xvfb_proc.wait(timeout=5)
2 weeks ago
print(f"recording complete: {output_filepath}")
2 weeks ago
if __name__ == "__main__":
1 week ago
p = ArgumentParser(
prog='clip.py',
description='Clip your openpilot route.',
epilog='comma.ai'
)
p.add_argument('-p', '--prefix', help='openpilot prefix', default=f'clip_{randint(100, 99999)}')
1 week ago
p.add_argument('-r', '--route', help='Route', default=DEMO_ROUTE)
p.add_argument('-o', '--output', help='Output clip to (.mp4)', default=DEFAULT_OUTPUT)
p.add_argument('-s', '--start', help='Start clipping at <start> seconds', type=int, required=True)
p.add_argument('-e', '--end', help='Stop clipping at <end> seconds', type=int, required=True)
args = p.parse_args()
assert args.end > args.start, 'end must be greater than start'
2 weeks ago
try:
with OpenpilotPrefix(args.prefix, shared_download_cache=True) as p:
1 week ago
main(args.route, args.output, args.start, args.end)
2 weeks ago
except KeyboardInterrupt:
print("Interrupted by user")
except Exception as e:
print(f"Error: {e}")
finally:
atexit._run_exitfuncs()