From b56096f6a56e648796c432bdcf85b46be4173304 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Tue, 23 Jun 2026 18:19:13 -0400 Subject: [PATCH 01/13] add the framemd5 output to the tee muxer --- vrecord | 76 +++++++++++++++++++++++++++++++++++++-------------------- 1 file changed, 50 insertions(+), 26 deletions(-) diff --git a/vrecord b/vrecord index ef7d3155..8b43ff08 100755 --- a/vrecord +++ b/vrecord @@ -586,8 +586,28 @@ _setup_vrecord_process(){ fi RECORD_COMMAND+=("${MIDDLEOPTIONS_PRES[@]}" "${MIDDLEOPTIONS_ALL[@]}") if [[ "${RUNTYPE}" = "record" ]] ; then - RECORD_COMMAND+=(-filter_complex "[0:v:0]${RECORDINGFILTER#,*}${TC_WRITE}${CAPTION_WRITE}[vout];${AUDIOMAP}" -map "[vout]" "${AUDIO_CHANNEL_MAP[@]}") - RECORD_COMMAND+=(-f tee [f=${FORMAT}:select=v,${AUDIO_TEE_SELECT_MAP}]"${VRECORD_OUTPUT}"\|[f=nut:onfail=abort:select=v,${AUDIO_TEE_SELECT_MAP},a\\\\:0]pipe:1) + if [[ "${FRAMEMD5_CHOICE}" = "true" ]] ; then + FRAMEMD5_IDX=1 + FRAMEMD5NAME="${LOGDIR}/${FULL_OUTPUT_ID}.framemd5" + RECORD_COMMAND_TEE+=(\|[f=framehash:hash=MD5:onfail=abort:select=v\\\\:"${FRAMEMD5_IDX}"]"${FRAMEMD5NAME}") + RECORD_COMMAND_SPLIT=",split=2[vout][MD5_VOUT]" + RECORD_COMMAND_MAP+=(-map "[vout]" -map "[MD5_VOUT]") + EXTRAOPTIONS+=(-c:v:"${FRAMEMD5_IDX}" rawvideo) + else + RECORD_COMMAND_SPLIT="[vout]" + RECORD_COMMAND_MAP+=(-map "[vout]") + fi + AUDIO_TEE_SELECT_MAP="" + RECORD_COMMAND+=(-c:a:0 pcm_s24le) + for AUD_IDX in "${AUDIO_CHANNEL_IDX[@]}" ; do + AUDIO_TEE_SELECT_MAP+="${AUDIO_TEE_SELECT_MAP:+,}a\\\\:${AUD_IDX}" + for OPTION in "${AUDIO_MIDDLEOPTIONS_TEMPLATE[@]}" ; do + RECORD_COMMAND+=("${OPTION//:X/:${AUD_IDX}}") + done + done + RECORD_COMMAND+=(-filter_complex "[0:v:0]${RECORDINGFILTER#,*}${TC_WRITE}${CAPTION_WRITE}${RECORD_COMMAND_SPLIT};${AUDIOMAP}" "${RECORD_COMMAND_MAP[@]}" "${AUDIO_CHANNEL_MAP[@]}" "${EXTRAOPTIONS[@]}") + RECORD_COMMAND+=(-f tee [f=${FORMAT}:select=v\\\\:0,${AUDIO_TEE_SELECT_MAP}]"${VRECORD_OUTPUT}"\|[f=nut:onfail=abort:select=v\\\\:0,${AUDIO_TEE_SELECT_MAP},a\\\\:0]pipe:1${RECORD_COMMAND_TEE[@]}) + RECORD_COMMAND+=("${EXTRAOUTPUTS[@]}") else if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then @@ -637,7 +657,7 @@ _setup_vrecord_process(){ VRECORD_STEPS="2" # Steps: record | player (record is adjusted if actually recording) RECORD_COMMAND=("${FFMPEG_BIN}") RECORD_COMMAND+=(-nostdin -nostats "${TIME_LIMIT[@]}" "${GRAB_INPUT[@]}") - RECORD_COMMAND+=("${MIDDLEOPTIONS_PRES[@]}" "${MIDDLEOPTIONS_ALL[@]}") + RECORD_COMMAND+=("${MIDDLEOPTIONS_PRES_AUDIO[@]}" "${MIDDLEOPTIONS_ALL[@]}") if [[ "${RUNTYPE}" = "record" ]] ; then RECORD_COMMAND+=(-f "${FORMAT}" -filter_complex "${AUDIOMAP}" "${AUDIO_CHANNEL_MAP[@]}" "${VRECORD_OUTPUT}") fi @@ -1962,38 +1982,38 @@ _lookup_choice(){ _add_mediaconch_rule_set "${CODEC_UNCOMPRESSED_TEST}" if [[ "${PIXEL_FORMAT}" = "yuv422p10" ]] ; then VIDEOCODECNAME="Uncompressed 10-bit 4:2:2" - MIDDLEOPTIONS_PRES+=(-c:v v210) + MIDDLEOPTIONS_PRES+=(-c:v:0 v210) elif [[ "${PIXEL_FORMAT}" = "uyvy422" ]] ; then VIDEOCODECNAME="Uncompressed 8-bit 4:2:2" - MIDDLEOPTIONS_PRES+=(-c:v rawvideo -pix_fmt uyvy422 -tag:v 2vuy) + MIDDLEOPTIONS_PRES+=(-c:v:0 rawvideo -pix_fmt:v:0 uyvy422 -tag:v:0 2vuy) fi ;; "FFV1 version 3") _add_mediaconch_rule_set "${CODEC_FFV1_TEST}" VIDEOCODECNAME="FFV1 version 3" - MIDDLEOPTIONS_PRES+=(-c:v ffv1 -level 3 -g 1 -slices "${FFV1_SLICES}" -slicecrc 1) + MIDDLEOPTIONS_PRES+=(-c:v:0 ffv1 -level:v:0 3 -g:v:0 1 -slices:v:0 "${FFV1_SLICES}" -slicecrc:v:0 1) SUFFIX="_ffv1" ;; "JPEG2000") VIDEOCODECNAME="JPEG2000" - MIDDLEOPTIONS_PRES+=(-c:v libopenjpeg) + MIDDLEOPTIONS_PRES+=(-c:v:0 libopenjpeg) SUFFIX="_j2k" ;; "ProRes") VIDEOCODECNAME="Apple ProRes 422" - MIDDLEOPTIONS_PRES+=(-c:v prores_ks -flags +ildct -profile:v 2) + MIDDLEOPTIONS_PRES+=(-c:v:0 prores_ks -flags:v:0 +ildct -profile:v:0 2) SUFFIX="_prores" ;; "ProRes (HQ)") VIDEOCODECNAME="Apple ProRes 422 HQ" - MIDDLEOPTIONS_PRES+=(-c:v prores_ks -flags +ildct -profile:v 3) + MIDDLEOPTIONS_PRES+=(-c:v:0 prores_ks -flags:v:0 +ildct -profile:v:0 3) SUFFIX="_prores" ;; "h264") VIDEOCODECNAME="H.264" - MIDDLEOPTIONS_PRES+=(-c:v h264 -pix_fmt yuv420p) + MIDDLEOPTIONS_PRES+=(-c:v:0 h264 -pix_fmt:v:0 yuv420p) SUFFIX="_h264" ;; "HuffYUV") VIDEOCODECNAME="HuffYUV" if [[ "${PIXEL_FORMAT}" = "yuv422p10" ]] ; then - MIDDLEOPTIONS_PRES+=(-c:v ffvhuff -pix_fmt yuv422p10le -pred median -context 1) + MIDDLEOPTIONS_PRES+=(-c:v:0 ffvhuff -pix_fmt:v:0 yuv422p10le -pred:v:0 median -context:v:0 1) elif [[ "${PIXEL_FORMAT}" = "uyvy422" ]] ; then - MIDDLEOPTIONS_PRES+=(-c:v ffvhuff -pix_fmt yuv422p -pred median -context 1) + MIDDLEOPTIONS_PRES+=(-c:v:0 ffvhuff -pix_fmt:v:0 yuv422p -pred:v:0 median -context:v:0 1) fi SUFFIX="_huff" ;; @@ -2001,18 +2021,23 @@ _lookup_choice(){ "10 bit") PIXEL_FORMAT="yuv422p10" ;; "8 bit") PIXEL_FORMAT="uyvy422" ;; + + # audio codec "24-bit PCM") - MIDDLEOPTIONS_PRES+=(-c:a pcm_s24le) - MIDDLEOPTIONS_PRES+=(-rf64 auto) + MIDDLEOPTIONS_PRES_AUDIO+=(-c:a pcm_s24le) + MIDDLEOPTIONS_PRES_AUDIO+=(-rf64 auto) + AUDIO_MIDDLEOPTIONS_TEMPLATE+=(-c:a:X pcm_s24le) AUDIO_EXT='wav' ;; "24-bit FLAC") - MIDDLEOPTIONS_PRES+=(-c:a flac) - MIDDLEOPTIONS_PRES+=(-sample_fmt s32) - MIDDLEOPTIONS_PRES+=(-bits_per_raw_sample:a 24) + MIDDLEOPTIONS_PRES_AUDIO+=(-c:a flac) + MIDDLEOPTIONS_PRES_AUDIO+=(-sample_fmt s32) + MIDDLEOPTIONS_PRES_AUDIO+=(-bits_per_raw_sample:a 24) + AUDIO_MIDDLEOPTIONS_TEMPLATE+=(-c:a:X flac -sample_fmt:a:X s32 -bits_per_raw_sample:a:X 24) AUDIO_EXT='flac' ;; "AAC") - MIDDLEOPTIONS_PRES+=(-c:a aac) ;; + MIDDLEOPTIONS_PRES_AUDIO+=(-c:a aac) + AUDIO_MIDDLEOPTIONS_TEMPLATE+=(-c:a:X aac) ;; # audio mappings "2 Stereo Tracks (Channels 1 & 2 -> 1st Track Stereo, Channels 3 & 4 -> 2nd Track Stereo)") @@ -2023,7 +2048,7 @@ _lookup_choice(){ AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[stereo1]") AUDIO_CHANNEL_MAP+=(-map "[stereo2]") - AUDIO_TEE_SELECT_MAP="a\\\\:1,a\\\\:2" ;; + AUDIO_CHANNEL_IDX=(1 2) ;; "1 Stereo Track (From Channels 1 & 2)") AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" @@ -2031,7 +2056,7 @@ _lookup_choice(){ AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=20" AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[stereo1]") - AUDIO_TEE_SELECT_MAP="a\\\\:1" ;; + AUDIO_CHANNEL_IDX=(1) ;; "1 Stereo Track (From Channels 3 & 4)") AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c2 | c1=${PHASE_VALUE_2}c3[stereo1]" AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c2 | c1=${PHASE_VALUE_2}c3[stereo1]" @@ -2039,7 +2064,7 @@ _lookup_choice(){ AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=40,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=60" AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[stereo1]") - AUDIO_TEE_SELECT_MAP="a\\\\:1" ;; + AUDIO_CHANNEL_IDX=(1) ;; "Channel 1 -> 1st Track Mono, Channel 2 -> 2nd Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c0[mono1];[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono2]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c0[mono1];[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono2]" @@ -2048,7 +2073,7 @@ _lookup_choice(){ AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[mono1]") AUDIO_CHANNEL_MAP+=(-map "[mono2]") - AUDIO_TEE_SELECT_MAP="a\\\\:1,a\\\\:2" ;; + AUDIO_CHANNEL_IDX=(1 2) ;; "Channel 2 -> 1st Track Mono, Channel 1 -> 2nd Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=${PHASE_VALUE_2}c1[mono1];[0:a:0]pan=mono| c0=c0[mono2]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono1];[0:a:0]pan=mono| c0=c0[mono2]" @@ -2057,7 +2082,7 @@ _lookup_choice(){ AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[mono1]") AUDIO_CHANNEL_MAP+=(-map "[mono2]") - AUDIO_TEE_SELECT_MAP="a\\\\:1,a\\\\:2" ;; + AUDIO_CHANNEL_IDX=(1 2) ;; "Channel 1 -> Single Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c0[mono1]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c0[mono1]" @@ -2065,7 +2090,7 @@ _lookup_choice(){ AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=0" AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[mono1]") - AUDIO_TEE_SELECT_MAP="a\\\\:1" ;; + AUDIO_CHANNEL_IDX=(1) ;; "Channel 2 -> Single Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c1[mono1]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c1[mono1]" @@ -2073,7 +2098,7 @@ _lookup_choice(){ AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=20" AUDIO_CHANNEL_MAP+=(-map "[orig]") AUDIO_CHANNEL_MAP+=(-map "[mono1]") - AUDIO_TEE_SELECT_MAP="a\\\\:1" ;; + AUDIO_CHANNEL_IDX=(1) ;; # Audio mode channel options "Mono") AUDIOMAP="[0:a:0]pan=mono| c0=c0[mono1]" @@ -3240,7 +3265,6 @@ if [[ "${DEVICE_INPUT_CHOICE}" = "0" ]] ; then fi if [[ "${FRAMEMD5_CHOICE}" = "true" ]] ; then FRAMEMD5NAME="${LOGDIR}/${FULL_OUTPUT_ID}.framemd5" - EXTRAOUTPUTS+=(-an -f framemd5 "${FRAMEMD5NAME}") fi if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") From 48f3d5d3b61d6e9b8981631bbd2122d309028128 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Sun, 28 Jun 2026 17:10:06 -0400 Subject: [PATCH 02/13] just put adding audio mappings in a single step --- vrecord | 24 +++++++----------------- 1 file changed, 7 insertions(+), 17 deletions(-) diff --git a/vrecord b/vrecord index 8b43ff08..125b5490 100755 --- a/vrecord +++ b/vrecord @@ -2045,59 +2045,49 @@ _lookup_choice(){ AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1];[0:a:0]pan=stereo| c0=c2 | c1=${PHASE_VALUE_4}c3[stereo2]" AUDIO_PLAY_MAP="pan=4c|c0=c0|c1=${PHASE_VALUE_2}c1|c2=c2|c3=${PHASE_VALUE_4}c3" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=20,drawtext=fontfile=${DEFAULTFONT}:text='L(2)':fontcolor=white:fontsize=18:x=0:y=40,drawtext=fontfile=${DEFAULTFONT}:text='R(2)':fontcolor=white:fontsize=18:x=0:y=60" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[stereo1]") - AUDIO_CHANNEL_MAP+=(-map "[stereo2]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[stereo1]" -map "[stereo2]") AUDIO_CHANNEL_IDX=(1 2) ;; "1 Stereo Track (From Channels 1 & 2)") AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" AUDIO_PLAY_MAP="pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[stereo1]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[stereo1]") AUDIO_CHANNEL_IDX=(1) ;; "1 Stereo Track (From Channels 3 & 4)") AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c2 | c1=${PHASE_VALUE_2}c3[stereo1]" AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c2 | c1=${PHASE_VALUE_2}c3[stereo1]" AUDIO_PLAY_MAP="pan=stereo|c0=c2|c1=${PHASE_VALUE_2}c3" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=40,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=60" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[stereo1]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[stereo1]") AUDIO_CHANNEL_IDX=(1) ;; "Channel 1 -> 1st Track Mono, Channel 2 -> 2nd Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c0[mono1];[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono2]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c0[mono1];[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono2]" AUDIO_PLAY_MAP="pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='M(2)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[mono1]") - AUDIO_CHANNEL_MAP+=(-map "[mono2]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]" -map "[mono2]") AUDIO_CHANNEL_IDX=(1 2) ;; "Channel 2 -> 1st Track Mono, Channel 1 -> 2nd Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=${PHASE_VALUE_2}c1[mono1];[0:a:0]pan=mono| c0=c0[mono2]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono1];[0:a:0]pan=mono| c0=c0[mono2]" AUDIO_PLAY_MAP="pan=stereo|c0=${PHASE_VALUE_2}c1|c1=c0" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(2)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[mono1]") - AUDIO_CHANNEL_MAP+=(-map "[mono2]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]" -map "[mono2]") AUDIO_CHANNEL_IDX=(1 2) ;; "Channel 1 -> Single Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c0[mono1]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c0[mono1]" AUDIO_PLAY_MAP="pan=mono| c0=c0" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=0" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[mono1]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]") AUDIO_CHANNEL_IDX=(1) ;; "Channel 2 -> Single Track Mono") AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c1[mono1]" AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c1[mono1]" AUDIO_PLAY_MAP="pan=mono| c0=c1" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]") - AUDIO_CHANNEL_MAP+=(-map "[mono1]") + AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]") AUDIO_CHANNEL_IDX=(1) ;; # Audio mode channel options "Mono") From 434e1bf0372de711d61e253e5cef505c65005d85 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Sun, 28 Jun 2026 17:10:18 -0400 Subject: [PATCH 03/13] fix an indent --- vrecord | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vrecord b/vrecord index 125b5490..255a320f 100755 --- a/vrecord +++ b/vrecord @@ -3257,7 +3257,7 @@ if [[ "${DEVICE_INPUT_CHOICE}" = "0" ]] ; then FRAMEMD5NAME="${LOGDIR}/${FULL_OUTPUT_ID}.framemd5" fi if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then - AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") + AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") fi if [[ "${MP4_CHOICE}" = "true" ]] ; then RECORDINGFILTER_MP4+=",bwdif,format=yuv420p" From 8ae13fc0e3ed806840013c102a2192f0a744a04e Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 11:09:40 -0400 Subject: [PATCH 04/13] consolidate a mostly repeating section into a shared function --- vrecord | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/vrecord b/vrecord index 255a320f..f7df02ac 100755 --- a/vrecord +++ b/vrecord @@ -715,6 +715,13 @@ _setup_vrecord_process(){ fi PLAYER_COMMAND=("${FFPLAY_BIN}" "${FFPLAY_OPTIONS[@]}") fi + if [[ "${VERBOSE_GTKDIALOG}" = "Y" ]] ; then + echo "RUNTYPE ${RUNTYPE}" + echo "STEPS ${VRECORD_STEPS}" + echo "PLAY ${PLAYER_COMMAND[@]}" + echo "RECORD ${RECORD_COMMAND[@]}" + echo "QCLI ${QCLI_COMMAND_PIPE[@]}" + fi } _get_inputs(){ @@ -1636,12 +1643,6 @@ _edit_mode(){ # passthrough and audiopassthrough modes _passthrough_mode(){ _setup_vrecord_process - if [[ "${VERBOSE_GTKDIALOG}" = "Y" ]] ; then - echo "RUNTYPE ${RUNTYPE}" - echo "STEPS ${VRECORD_STEPS}" - echo "PLAY ${PLAYER_COMMAND[@]}" - echo "RECORD ${RECORD_COMMAND[@]}" - fi if [[ "${PLAYBACKVIEW_CHOICE_PASS}" == "Captions" ]] && [[ "${RUNTYPE}" == "passthrough" ]] ; then "${SCRIPTDIR}/cchex_to_display" "${FFREPORT_TMP}" "${CAP_DISPLAY_TMP}" > /dev/null 2> /dev/null & @@ -3380,12 +3381,6 @@ _report -d "Close the playback window to stop recording." # vrecord process! _setup_vrecord_process -if [[ "${VERBOSE_GTKDIALOG}" = "Y" ]] ; then - echo "STEPS ${VRECORD_STEPS}" - echo "PLAY ${PLAYER_COMMAND[@]}" - echo "RECORD ${RECORD_COMMAND[@]}" - echo "QCLI ${QCLI_COMMAND_PIPE[@]}" -fi if [[ "${VRECORD_STEPS}" = "2" ]] ; then _writeingestlog "Record command" "${RECORD_COMMAND[@]}" _writeingestlog "Playback command" "${PLAYER_COMMAND[@]}" From a0e56297b158373fd296eb05e681ebfe2ed3625a Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 13:07:13 -0400 Subject: [PATCH 05/13] add mp4 to tee output standardize var names, some comments, --- vrecord | 145 +++++++++++++++++++++++++++++++++++++------------------- 1 file changed, 97 insertions(+), 48 deletions(-) diff --git a/vrecord b/vrecord index f7df02ac..28817d2a 100755 --- a/vrecord +++ b/vrecord @@ -586,29 +586,78 @@ _setup_vrecord_process(){ fi RECORD_COMMAND+=("${MIDDLEOPTIONS_PRES[@]}" "${MIDDLEOPTIONS_ALL[@]}") if [[ "${RUNTYPE}" = "record" ]] ; then + + # construct the video stream processing + MAIN_V_PADNAME="MAIN_V" + SPLIT_PADS=() + SPLIT_MAPS=(-map "[${MAIN_V_PADNAME}]") + VIDEO_STREAM_IDX=1 if [[ "${FRAMEMD5_CHOICE}" = "true" ]] ; then - FRAMEMD5_IDX=1 + FRAMEMD5_V_IDX="${VIDEO_STREAM_IDX}" FRAMEMD5NAME="${LOGDIR}/${FULL_OUTPUT_ID}.framemd5" - RECORD_COMMAND_TEE+=(\|[f=framehash:hash=MD5:onfail=abort:select=v\\\\:"${FRAMEMD5_IDX}"]"${FRAMEMD5NAME}") - RECORD_COMMAND_SPLIT=",split=2[vout][MD5_VOUT]" - RECORD_COMMAND_MAP+=(-map "[vout]" -map "[MD5_VOUT]") - EXTRAOPTIONS+=(-c:v:"${FRAMEMD5_IDX}" rawvideo) + FRAMEMD5_PADNAME="MD5_V" + SPLIT_PADS+=("${FRAMEMD5_PADNAME}") + SPLIT_MAPS+=(-map "[${FRAMEMD5_PADNAME}]") + (( VIDEO_STREAM_IDX++ )) + EXTRAOPTIONS+=(-c:v:"${FRAMEMD5_V_IDX}" rawvideo) + fi + RECORD_COMMAND_MP4_FILTER="" + if [[ "${MP4_CHOICE}" = "true" ]] ; then + MP4_V_IDX="${VIDEO_STREAM_IDX}" + MP4NAME="${DIR}/${FULL_OUTPUT_ID}.mp4" + MP4_V_PADNAME="MP4_V" + SPLIT_PADS+=("${MP4_V_PADNAME}") + RECORD_COMMAND_MP4_FILTER=";[MP4_V]${RECORDINGFILTER_MP4#,},bwdif,format=yuv420p[${MP4_V_PADNAME}]" + SPLIT_MAPS+=(-map "[${MP4_V_PADNAME}]") + (( VIDEO_STREAM_IDX++ )) + EXTRAOPTIONS+=(-c:v:"${MP4_V_IDX}" h264 -g:v:"${MP4_V_IDX}" 12 -profile:v:"${MP4_V_IDX}" main -level:v:"${MP4_V_IDX}" "${ACCESS_MP4_LEVEL}" -b:v:"${MP4_V_IDX}" "${ACCESS_MP4_BITRATE}") + fi + + # construct end of video filterchain + SPLIT_COUNT=$(( 1 + ${#SPLIT_PADS[@]} )) + if [[ "${SPLIT_COUNT}" -gt 1 ]] ; then + RECORD_COMMAND_SPLIT=",split=${SPLIT_COUNT}[${MAIN_V_PADNAME}]" + for OUTPUT_PAD_NAME in "${SPLIT_PADS[@]}" ; do + RECORD_COMMAND_SPLIT+="[${OUTPUT_PAD_NAME}]" + done else - RECORD_COMMAND_SPLIT="[vout]" - RECORD_COMMAND_MAP+=(-map "[vout]") + RECORD_COMMAND_SPLIT="[${MAIN_V_PADNAME}]" fi + + # construct the audio stream processing AUDIO_TEE_SELECT_MAP="" - RECORD_COMMAND+=(-c:a:0 pcm_s24le) + EXTRAOPTIONS+=(-c:a:0 pcm_s24le) + AUDIO_STREAM_N=$(( 1 + ${#AUDIO_CHANNEL_IDX[@]} )) + MP4_A_INDICES=() + MP4_A_TEE_SELECT="" for AUD_IDX in "${AUDIO_CHANNEL_IDX[@]}" ; do AUDIO_TEE_SELECT_MAP+="${AUDIO_TEE_SELECT_MAP:+,}a\\\\:${AUD_IDX}" + # fill out audio template per stream for OPTION in "${AUDIO_MIDDLEOPTIONS_TEMPLATE[@]}" ; do RECORD_COMMAND+=("${OPTION//:X/:${AUD_IDX}}") done done - RECORD_COMMAND+=(-filter_complex "[0:v:0]${RECORDINGFILTER#,*}${TC_WRITE}${CAPTION_WRITE}${RECORD_COMMAND_SPLIT};${AUDIOMAP}" "${RECORD_COMMAND_MAP[@]}" "${AUDIO_CHANNEL_MAP[@]}" "${EXTRAOPTIONS[@]}") - RECORD_COMMAND+=(-f tee [f=${FORMAT}:select=v\\\\:0,${AUDIO_TEE_SELECT_MAP}]"${VRECORD_OUTPUT}"\|[f=nut:onfail=abort:select=v\\\\:0,${AUDIO_TEE_SELECT_MAP},a\\\\:0]pipe:1${RECORD_COMMAND_TEE[@]}) - - RECORD_COMMAND+=("${EXTRAOUTPUTS[@]}") + if [[ "${MP4_CHOICE}" = "true" ]] ; then + for (( MAP_N=0; MAP_N<${#AUDIO_MP4_MAP[@]}/2; MAP_N++ )) ; do + MP4_A_INDICES+=("${AUDIO_STREAM_N}") + MP4_A_TEE_SELECT+=",a\\\\:${AUDIO_STREAM_N}" + EXTRAOPTIONS+=(-c:a:"${AUDIO_STREAM_N}" aac) + (( AUDIO_STREAM_N++ )) + done + fi + + RECORD_COMMAND+=(-filter_complex "[0:v:0]${RECORDINGFILTER#,*}${TC_WRITE}${CAPTION_WRITE}${RECORD_COMMAND_SPLIT};${AUDIOMAP}${RECORD_COMMAND_MP4_FILTER}" "${SPLIT_MAPS[@]}" "${AUDIO_CHANNEL_MAP[@]}" $([[ "${MP4_CHOICE}" = "true" ]] && echo "${AUDIO_MP4_MAP[@]}") "${EXTRAOPTIONS[@]}") + + # Build tee string + RECORD_COMMAND_TEE_STR="[f=${FORMAT}:select=v\\\\:0,${AUDIO_TEE_SELECT_MAP}]${VRECORD_OUTPUT}" + RECORD_COMMAND_TEE_STR+="|[f=nut:onfail=abort:select=v\\\\:0,${AUDIO_TEE_SELECT_MAP},a\\\\:0]pipe:1" + if [[ "${FRAMEMD5_CHOICE}" = "true" ]] ; then + RECORD_COMMAND_TEE_STR+="|[f=framemd5:hash=MD5:select=v\\\\:${FRAMEMD5_V_IDX}]${FRAMEMD5NAME}" + fi + if [[ "${MP4_CHOICE}" = "true" ]] ; then + RECORD_COMMAND_TEE_STR+="|[f=mp4:onfail=ignore:movflags=write_colr+faststart:select=v\\\\:${MP4_V_IDX}${MP4_A_TEE_SELECT}]${MP4NAME}" + fi + RECORD_COMMAND+=(-f tee "${RECORD_COMMAND_TEE_STR}") else if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then PIPE_OUTPUT=(-c:v ffv1) @@ -721,6 +770,10 @@ _setup_vrecord_process(){ echo "PLAY ${PLAYER_COMMAND[@]}" echo "RECORD ${RECORD_COMMAND[@]}" echo "QCLI ${QCLI_COMMAND_PIPE[@]}" + echo "SPLIT_PADS ${SPLIT_PADS[@]}" + echo "SPLIT_MAPS ${SPLIT_MAPS[@]}" + echo "RECORD_COMMAND_SPLIT ${RECORD_COMMAND_SPLIT[@]}" + echo "EXTRAOPTIONS ${EXTRAOPTIONS[@]}" fi } @@ -2022,8 +2075,6 @@ _lookup_choice(){ "10 bit") PIXEL_FORMAT="yuv422p10" ;; "8 bit") PIXEL_FORMAT="uyvy422" ;; - - # audio codec "24-bit PCM") MIDDLEOPTIONS_PRES_AUDIO+=(-c:a pcm_s24le) @@ -2042,63 +2093,70 @@ _lookup_choice(){ # audio mappings "2 Stereo Tracks (Channels 1 & 2 -> 1st Track Stereo, Channels 3 & 4 -> 2nd Track Stereo)") - AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1];[0:a:0]pan=stereo| c0=c2 | c1=${PHASE_VALUE_4}c3[stereo2]" - AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1];[0:a:0]pan=stereo| c0=c2 | c1=${PHASE_VALUE_4}c3[stereo2]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1,asplit=${ASPLIT_N}[MAIN_STEREO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]");[0:a:0]pan=stereo|c0=c2|c1=${PHASE_VALUE_4}c3,asplit=${ASPLIT_N}[MAIN_STEREO_A2]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A2]")" AUDIO_PLAY_MAP="pan=4c|c0=c0|c1=${PHASE_VALUE_2}c1|c2=c2|c3=${PHASE_VALUE_4}c3" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=20,drawtext=fontfile=${DEFAULTFONT}:text='L(2)':fontcolor=white:fontsize=18:x=0:y=40,drawtext=fontfile=${DEFAULTFONT}:text='R(2)':fontcolor=white:fontsize=18:x=0:y=60" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[stereo1]" -map "[stereo2]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_STEREO_A1]" -map "[MAIN_STEREO_A2]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]" -map "[MP4_A2]") AUDIO_CHANNEL_IDX=(1 2) ;; "1 Stereo Track (From Channels 1 & 2)") - AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" - AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1,asplit=${ASPLIT_N}[MAIN_STEREO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]")" AUDIO_PLAY_MAP="pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[stereo1]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_STEREO_A1]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]") AUDIO_CHANNEL_IDX=(1) ;; "1 Stereo Track (From Channels 3 & 4)") - AUDIOMAP="[0:a:0]asplit[orig],pan=stereo| c0=c2 | c1=${PHASE_VALUE_2}c3[stereo1]" - AUDIOMAP_MP4="[0:a:0]pan=stereo| c0=c2 | c1=${PHASE_VALUE_2}c3[stereo1]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=stereo|c0=c2|c1=${PHASE_VALUE_2}c3,asplit=${ASPLIT_N}[MAIN_STEREO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]")" AUDIO_PLAY_MAP="pan=stereo|c0=c2|c1=${PHASE_VALUE_2}c3" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='L(1)':fontcolor=white:fontsize=18:x=0:y=40,drawtext=fontfile=${DEFAULTFONT}:text='R(1)':fontcolor=white:fontsize=18:x=0:y=60" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[stereo1]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_STEREO_A1]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]") AUDIO_CHANNEL_IDX=(1) ;; "Channel 1 -> 1st Track Mono, Channel 2 -> 2nd Track Mono") - AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c0[mono1];[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono2]" - AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c0[mono1];[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono2]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=mono|c0=c0,asplit=${ASPLIT_N}[MAIN_MONO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]");[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1,asplit=${ASPLIT_N}[MAIN_MONO_A2]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A2]")" AUDIO_PLAY_MAP="pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='M(2)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]" -map "[mono2]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_MONO_A1]" -map "[MAIN_MONO_A2]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]" -map "[MP4_A2]") AUDIO_CHANNEL_IDX=(1 2) ;; "Channel 2 -> 1st Track Mono, Channel 1 -> 2nd Track Mono") - AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=${PHASE_VALUE_2}c1[mono1];[0:a:0]pan=mono| c0=c0[mono2]" - AUDIOMAP_MP4="[0:a:0]pan=mono| c0=${PHASE_VALUE_2}c1[mono1];[0:a:0]pan=mono| c0=c0[mono2]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=mono|c0=${PHASE_VALUE_2}c1,asplit=${ASPLIT_N}[MAIN_MONO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]");[0:a:0]pan=mono| c0=c0,asplit=${ASPLIT_N}[MAIN_MONO_A2]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A2]")" AUDIO_PLAY_MAP="pan=stereo|c0=${PHASE_VALUE_2}c1|c1=c0" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(2)':fontcolor=white:fontsize=18:x=0:y=0,drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]" -map "[mono2]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_MONO_A1]" -map "[MAIN_MONO_A2]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]" -map "[MP4_A2]") AUDIO_CHANNEL_IDX=(1 2) ;; "Channel 1 -> Single Track Mono") - AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c0[mono1]" - AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c0[mono1]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=mono|c0=c0,asplit=${ASPLIT_N}[MAIN_MONO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]")" AUDIO_PLAY_MAP="pan=mono| c0=c0" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=0" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_MONO_A1]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]") AUDIO_CHANNEL_IDX=(1) ;; "Channel 2 -> Single Track Mono") - AUDIOMAP="[0:a:0]asplit[orig],pan=mono| c0=c1[mono1]" - AUDIOMAP_MP4="[0:a:0]pan=mono| c0=c1[mono1]" + ASPLIT_N=$([[ "${MP4_CHOICE}" = "true" ]] && echo 2 || echo 1) + AUDIOMAP="[0:a:0]asplit=2[ORIG_A][ORIG_A2];[ORIG_A2]pan=mono|c0=c1,asplit=${ASPLIT_N}[MAIN_MONO_A1]$([[ "${MP4_CHOICE}" = "true" ]] && echo "[MP4_A1]")" AUDIO_PLAY_MAP="pan=mono| c0=c1" AUDIO_PLAY_LABELS=",drawtext=fontfile=${DEFAULTFONT}:text='M(1)':fontcolor=white:fontsize=18:x=0:y=20" - AUDIO_CHANNEL_MAP+=(-map "[orig]" -map "[mono1]") + AUDIO_CHANNEL_MAP+=(-map "[ORIG_A]" -map "[MAIN_MONO_A1]") + [[ "${MP4_CHOICE}" = "true" ]] && AUDIO_MP4_MAP+=(-map "[MP4_A1]") AUDIO_CHANNEL_IDX=(1) ;; # Audio mode channel options "Mono") - AUDIOMAP="[0:a:0]pan=mono| c0=c0[mono1]" + AUDIOMAP="[0:a:0]pan=mono| c0=c0[MAIN_MONO_A1]" PASSTHROUGH_MAP="pan=mono|c0=c0" - AUDIO_CHANNEL_MAP+=(-map "[mono1]") ;; + AUDIO_CHANNEL_MAP+=(-map "[MAIN_MONO_A1]") ;; "Stereo") - AUDIOMAP="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[stereo1]" + AUDIOMAP="[0:a:0]pan=stereo| c0=c0 | c1=${PHASE_VALUE_2}c1[MAIN_STEREO_A1]" PASSTHROUGH_MAP="pan=stereo|c0=c0|c1=${PHASE_VALUE_2}c1" - AUDIO_CHANNEL_MAP+=(-map "[stereo1]") ;; + AUDIO_CHANNEL_MAP+=(-map "[MAIN_STEREO_A1]") ;; # Audio mode sample rate options "96 kHz") S_RATE='-ar 96k' @@ -3254,18 +3312,9 @@ if [[ "${DEVICE_INPUT_CHOICE}" = "0" ]] ; then _report -w "Such as \`brew install qcli\`." exit 1 fi - if [[ "${FRAMEMD5_CHOICE}" = "true" ]] ; then - FRAMEMD5NAME="${LOGDIR}/${FULL_OUTPUT_ID}.framemd5" - fi if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") fi - if [[ "${MP4_CHOICE}" = "true" ]] ; then - RECORDINGFILTER_MP4+=",bwdif,format=yuv420p" - RECORD_COMMAND_MP4+=(-filter_complex "[0:v:0]${RECORDINGFILTER_MP4#,*}[mp4_v_out];${AUDIOMAP_MP4}") - MP4NAME="${DIR}/${FULL_OUTPUT_ID}.mp4" - EXTRAOUTPUTS+=("${MIDDLEOPTIONS_ALL[@]}" -movflags write_colr+faststart "${RECORD_COMMAND_MP4[@]}" -c:v h264 -g 12 -profile:v main -level "${ACCESS_MP4_LEVEL}" -b:v "${ACCESS_MP4_BITRATE}" -c:a aac -map "[mp4_v_out]" "${AUDIO_CHANNEL_MAP[@]:2}" "${MP4NAME}") - fi if [[ "${FORMAT}" = "matroska" ]] ; then _review_option "EMBED_LOGS_CHOICE" "${EMBED_LOGS_OPTIONS[@]}" fi From 1ce558169c3e87c2d962ed1e5662640eec0112f8 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 13:13:36 -0400 Subject: [PATCH 06/13] remove pointless line as it's reset a few lines later --- vrecord | 1 - 1 file changed, 1 deletion(-) diff --git a/vrecord b/vrecord index 28817d2a..a908e17f 100755 --- a/vrecord +++ b/vrecord @@ -660,7 +660,6 @@ _setup_vrecord_process(){ RECORD_COMMAND+=(-f tee "${RECORD_COMMAND_TEE_STR}") else if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then - PIPE_OUTPUT=(-c:v ffv1) AUD_PIPE_MAP='1:a' else AUD_PIPE_MAP='0:a' From 3ce94ae6275a362fe8c2ab714b2a93ce48797fba Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 13:14:32 -0400 Subject: [PATCH 07/13] remove unused array --- vrecord | 2 -- 1 file changed, 2 deletions(-) diff --git a/vrecord b/vrecord index a908e17f..56ac2b0e 100755 --- a/vrecord +++ b/vrecord @@ -628,7 +628,6 @@ _setup_vrecord_process(){ AUDIO_TEE_SELECT_MAP="" EXTRAOPTIONS+=(-c:a:0 pcm_s24le) AUDIO_STREAM_N=$(( 1 + ${#AUDIO_CHANNEL_IDX[@]} )) - MP4_A_INDICES=() MP4_A_TEE_SELECT="" for AUD_IDX in "${AUDIO_CHANNEL_IDX[@]}" ; do AUDIO_TEE_SELECT_MAP+="${AUDIO_TEE_SELECT_MAP:+,}a\\\\:${AUD_IDX}" @@ -639,7 +638,6 @@ _setup_vrecord_process(){ done if [[ "${MP4_CHOICE}" = "true" ]] ; then for (( MAP_N=0; MAP_N<${#AUDIO_MP4_MAP[@]}/2; MAP_N++ )) ; do - MP4_A_INDICES+=("${AUDIO_STREAM_N}") MP4_A_TEE_SELECT+=",a\\\\:${AUDIO_STREAM_N}" EXTRAOPTIONS+=(-c:a:"${AUDIO_STREAM_N}" aac) (( AUDIO_STREAM_N++ )) From 6bb43cdaaecded79fb327ceb15b1312534cbfcec Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 13:20:50 -0400 Subject: [PATCH 08/13] redistribute some conditions for clarity --- vrecord | 29 ++++++++++++++--------------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/vrecord b/vrecord index 56ac2b0e..52d4b284 100755 --- a/vrecord +++ b/vrecord @@ -496,6 +496,11 @@ _setup_vrecord_input(){ GRAB_INPUT+=("${TIME_LIMIT[@]}") GRAB_INPUT+=(-f lavfi -i sine=440:r=48000) GRAB_INPUT+=(-pix_fmt yuv422p10le) + echo "AAA ${AUDIOMAP[@]}" + if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then + AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") + fi + echo "BBB ${AUDIOMAP[@]}" elif [[ "${DEVICE_INPUT_CHOICE}" = 0 ]] ; then _set_ffmpeg_loglevel GRAB_INPUT+=(-f decklink) @@ -3268,6 +3273,15 @@ if [[ "${DEVICE_INPUT_CHOICE}" = "0" ]] ; then _review_option "CONTAINER_CHOICE" "${CONTAINER_OPTIONS[@]}" _review_option "VIDEO_CODEC_CHOICE" "${VIDEO_CODEC_OPTIONS[@]}" _review_option "AUDIO_CODEC_CHOICE" "${AUDIO_CODEC_OPTIONS[@]}" + _review_option "QCTOOLSXML_CHOICE" "${QCTOOLSXML_OPTIONS[@]}" + if [[ "${QCTOOLSXML_CHOICE}" != "No" && ! "$(command -v qcli)" ]] ; then + _report -w "Please install qcli to use the qctools reporting option." + _report -w "Such as \`brew install qcli\`." + exit 1 + fi + if [[ "${FORMAT}" = "matroska" ]] ; then + _review_option "EMBED_LOGS_CHOICE" "${EMBED_LOGS_OPTIONS[@]}" + fi elif [[ "${DEVICE_INPUT_CHOICE}" = "1" ]] ; then _review_option "DV_CONTAINER_CHOICE" "${DV_CONTAINER_OPTIONS[@]}" FORMAT="rawvideo" @@ -3302,21 +3316,6 @@ if [[ -f "${VRECORD_OUTPUT}" ]] ; then exit fi -if [[ "${DEVICE_INPUT_CHOICE}" = "0" ]] ; then - _review_option "QCTOOLSXML_CHOICE" "${QCTOOLSXML_OPTIONS[@]}" - if [[ "${QCTOOLSXML_CHOICE}" != "No" && ! "$(command -v qcli)" ]] ; then - _report -w "Please install qcli to use the qctools reporting option." - _report -w "Such as \`brew install qcli\`." - exit 1 - fi - if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then - AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") - fi - if [[ "${FORMAT}" = "matroska" ]] ; then - _review_option "EMBED_LOGS_CHOICE" "${EMBED_LOGS_OPTIONS[@]}" - fi -fi - if [[ -n "${DURATION}" ]] ; then DUR_SECONDS=$(bc <<< "${DURATION} * 60" | sed "s/^\./0./") TIME_LIMIT=(-t "${DUR_SECONDS}") From c148973c19d7dfe5caafc91f4d6e1b4ab5549214 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 13:26:38 -0400 Subject: [PATCH 09/13] remove unneeded check and debugging --- vrecord | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/vrecord b/vrecord index 52d4b284..734039fc 100755 --- a/vrecord +++ b/vrecord @@ -496,11 +496,7 @@ _setup_vrecord_input(){ GRAB_INPUT+=("${TIME_LIMIT[@]}") GRAB_INPUT+=(-f lavfi -i sine=440:r=48000) GRAB_INPUT+=(-pix_fmt yuv422p10le) - echo "AAA ${AUDIOMAP[@]}" - if [[ "${SIGNAL_INPUT}" = 'true' ]] ; then - AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") - fi - echo "BBB ${AUDIOMAP[@]}" + AUDIOMAP=$(sed "s/0:a:0/1:a:0/g" <<< "$AUDIOMAP") elif [[ "${DEVICE_INPUT_CHOICE}" = 0 ]] ; then _set_ffmpeg_loglevel GRAB_INPUT+=(-f decklink) From 362fe4f9bfb434cb6437b6d80a1426067a156b84 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 13:42:11 -0400 Subject: [PATCH 10/13] just set these once rather than for each standard-choice option --- vrecord | 54 +++++++++++++++--------------------------------------- 1 file changed, 15 insertions(+), 39 deletions(-) diff --git a/vrecord b/vrecord index 734039fc..78544aae 100755 --- a/vrecord +++ b/vrecord @@ -2179,11 +2179,9 @@ _lookup_choice(){ _add_mediaconch_rule_set "${STANDARD_NTSC_TEST}" fi RECORDINGFILTER_MP4+=",crop=w=720:h=480:x=0:y=4" - _set_some_params SET_COLOR_PRIMARIES="smpte170m" SET_COLOR_TRC="bt709" - SET_COLORSPACE="smpte170m" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="smpte170m" ;; "PAL") STANDARD="pal " DECKLINK_FPS="25000/1000" @@ -2191,132 +2189,108 @@ _lookup_choice(){ FFV1_SLICES=24 SIG_INTERLACEMENT="tff" _add_mediaconch_rule_set "${STANDARD_PAL_TEST}" - _set_some_params SET_COLOR_PRIMARIES="bt470bg" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt470bg" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt470bg" ;; "23ps - 1080p23.98") STANDARD="23ps" DECKLINK_FPS="24000/1001" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "24ps - 1080p24") STANDARD="24ps" DECKLINK_FPS="24000/1000" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "Hp25 - 1080p25") STANDARD="Hp25" DECKLINK_FPS="25000/1000" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "Hp29 - 1080p29.97") STANDARD="Hp29" DECKLINK_FPS="30000/1001" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "Hp30 - 1080p30") STANDARD="Hp30" DECKLINK_FPS="30000/1000" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "Hi50 - 1080i50") STANDARD="Hi50" DECKLINK_FPS="25000/1000" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="tff" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "Hi59 - 1080i59.94") STANDARD="Hi59" DECKLINK_FPS="30000/1001" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="tff" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "Hi60 - 1080i60") STANDARD="Hi60" DECKLINK_FPS="30000/1000" SIG_GEN_SIZE="1920x1080" FFV1_SLICES=128 SIG_INTERLACEMENT="tff" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "hp50 - 720p50") STANDARD="hp50" DECKLINK_FPS="50000/1000" SIG_GEN_SIZE="1280x720" FFV1_SLICES=64 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "hp59 - 720p59.94") STANDARD="hp59" DECKLINK_FPS="60000/1001" SIG_GEN_SIZE="1280x720" FFV1_SLICES=64 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; "hp60 - 720p60") STANDARD="hp60" DECKLINK_FPS="60000/1000" SIG_GEN_SIZE="1280x720" FFV1_SLICES=64 SIG_INTERLACEMENT="prog" - _set_some_params SET_COLOR_PRIMARIES="bt709" SET_COLOR_TRC="bt709" - SET_COLORSPACE="bt709" - RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" ;; + SET_COLORSPACE="bt709" ;; # aspect ratio options "4/3") if [[ "${STANDARD}" = "ntsc" ]] ; then @@ -2782,6 +2756,8 @@ _review_all_options(){ _review_option "VIDEO_BIT_DEPTH_CHOICE" "${VIDEO_BITDEPTH_OPTIONS[@]}" _review_option "AUDIO_MAPPING_CHOICE" "${CHANNEL_MAPPING_OPTIONS[@]}" _review_option "STANDARD_CHOICE" "${STANDARD_OPTIONS[@]}" + _set_some_params + RECORDINGFILTER+=",setparams=range=${SET_RANGE}:color_primaries=${SET_COLOR_PRIMARIES}:color_trc=${SET_COLOR_TRC}:colorspace=${SET_COLORSPACE}:field_mode=${SET_FIELD_MODE}" _review_option -d "4/3" "ASPECT_RATIO_CHOICE" "${ASPECT_RATIO_OPTIONS[@]}" _review_option -n -d "10/11" "NTSC_43_SAR_CHOICE" "${NTSC_43_SAR_OPTIONS[@]}" _review_option -n -d "40/33" "NTSC_169_SAR_CHOICE" "${NTSC_169_SAR_OPTIONS[@]}" From 1424c65930fc49ff5e38bb2362d29bb87068dcdf Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 14:57:38 -0400 Subject: [PATCH 11/13] add output stream labels to the benchmark summary --- vrecord | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/vrecord b/vrecord index 78544aae..db5f688f 100755 --- a/vrecord +++ b/vrecord @@ -624,6 +624,17 @@ _setup_vrecord_process(){ else RECORD_COMMAND_SPLIT="[${MAIN_V_PADNAME}]" fi + + # map of the output mapping to the names, used in the benchmark summary + OUTPUT_LABELS="" + MAP_IDX="0" + for PAD in "${SPLIT_MAPS[@]}" "${AUDIO_CHANNEL_MAP[@]}" "${AUDIO_MP4_MAP[@]}" ; do + if [[ "${PAD:0:1}" == "[" ]] ; then + OUTPUT_LABELS+="${OUTPUT_LABELS:+,}0.${MAP_IDX}=${PAD//[\[\]]/}" + ((MAP_IDX++)) + fi + done + echo "HEYYYY ${OUTPUT_LABELS}" # construct the audio stream processing AUDIO_TEE_SELECT_MAP="" @@ -3450,8 +3461,14 @@ if [[ "${DEVICE_INPUT_CHOICE}" = 0 ]] ; then grep " bench: " "${FULL_CAPTURE_LOG}" > "${BENCHMARK_DETAILS_NAME}" grep -v " bench: " "${FULL_CAPTURE_LOG}" > "${FULL_CAPTURE_LOG}.tmp" mv "${FULL_CAPTURE_LOG}.tmp" "${FULL_CAPTURE_LOG}" - awk 'BEGIN { printf "%-8s %-6s %-8s %-12s %-5s %-10s %-10s %-10s %-10s %-10s %-8s %-10s\n", "action","media","stream","label","n","user","sys","real","real/user","sys/user","%user","avg_us" - CEIL = 10000000 } + awk -v labels="${OUTPUT_LABELS}" 'BEGIN { printf "%-8s %-6s %-8s %-16s %-5s %-10s %-10s %-10s %-10s %-10s %-8s %-10s\n", "action","media","stream","label","n","user","sys","real","real/user","sys/user","%user","avg_us" + CEIL = 10000000 + nlbl = split(labels, pairs, ",") + for (i = 1; i <= nlbl; i++) { + split(pairs[i], kv, "=") + label[kv[1]] = kv[2] + } + } $1 == "#label" { label[$2] = $3; next } $2 == "bench:" && $4 == "user" && $6 == "sys" && $8 == "real" { if ($3 !~ /^[0-9]+$/ || $5 !~ /^[0-9]+$/ || $7 !~ /^[0-9]+$/ || @@ -3470,7 +3487,7 @@ if [[ "${DEVICE_INPUT_CHOICE}" = 0 ]] ; then sysratio = (u[k] > 0) ? s[k] / u[k] : 0 share = (TOTAL_U > 0) ? 100 * u[k] / TOTAL_U : 0 avgus = (n[k] > 0) ? r[k] / n[k] : 0 - printf "%-8s %-6s %-8s %-12s %-5d %-10d %-10d %-10d %-10.3f %-10.3f %-8.2f %-10.1f\n", \ + printf "%-8s %-6s %-8s %-16s %-5d %-10d %-10d %-10d %-10.3f %-10.3f %-8.2f %-10.1f\n", \ f[1], f[2], f[3], lbl[k], n[k], u[k], s[k], r[k], ratio, sysratio, share, avgus } if (bad > 0) printf "\n[skipped %d malformed/out-of-range bench line(s)]\n", bad From 2723a969328621086d6b77b9f4fa0cad7c3e9305 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 16:10:54 -0400 Subject: [PATCH 12/13] move the pixel format setting out of the filterchain somehow the filterchain format for mp4 ends up applies to the other outputs --- vrecord | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/vrecord b/vrecord index db5f688f..54c9d53e 100755 --- a/vrecord +++ b/vrecord @@ -608,10 +608,10 @@ _setup_vrecord_process(){ MP4NAME="${DIR}/${FULL_OUTPUT_ID}.mp4" MP4_V_PADNAME="MP4_V" SPLIT_PADS+=("${MP4_V_PADNAME}") - RECORD_COMMAND_MP4_FILTER=";[MP4_V]${RECORDINGFILTER_MP4#,},bwdif,format=yuv420p[${MP4_V_PADNAME}]" + RECORD_COMMAND_MP4_FILTER=";[MP4_V]${RECORDINGFILTER_MP4#,},bwdif[${MP4_V_PADNAME}]" SPLIT_MAPS+=(-map "[${MP4_V_PADNAME}]") (( VIDEO_STREAM_IDX++ )) - EXTRAOPTIONS+=(-c:v:"${MP4_V_IDX}" h264 -g:v:"${MP4_V_IDX}" 12 -profile:v:"${MP4_V_IDX}" main -level:v:"${MP4_V_IDX}" "${ACCESS_MP4_LEVEL}" -b:v:"${MP4_V_IDX}" "${ACCESS_MP4_BITRATE}") + EXTRAOPTIONS+=(-c:v:"${MP4_V_IDX}" h264 -pix_fmt:v:"${MP4_V_IDX}" yuv420p -g:v:"${MP4_V_IDX}" 12 -profile:v:"${MP4_V_IDX}" main -level:v:"${MP4_V_IDX}" "${ACCESS_MP4_LEVEL}" -b:v:"${MP4_V_IDX}" "${ACCESS_MP4_BITRATE}") fi # construct end of video filterchain From e33b857c75cea524a4bf8ad14c7e1af1a7a1d933 Mon Sep 17 00:00:00 2001 From: Dave Rice Date: Fri, 3 Jul 2026 16:13:48 -0400 Subject: [PATCH 13/13] test that preservation output is 4:2:2 --- vrecord | 1 + 1 file changed, 1 insertion(+) diff --git a/vrecord b/vrecord index 54c9d53e..6961c456 100755 --- a/vrecord +++ b/vrecord @@ -2869,6 +2869,7 @@ CODEC_GENERAL_TEST=' YUV CFR YUV + 4:2:2 2vuy