diff options
author | Jonas Smedegaard <dr@jones.dk> | 2017-06-08 17:19:36 +0200 |
---|---|---|
committer | Jonas Smedegaard <dr@jones.dk> | 2017-06-08 17:19:36 +0200 |
commit | 992ca80124f251f06c96fe15465880513ad4eee7 (patch) | |
tree | a1a40bbc6dcf7f3b5e720062f743cd77b5ee7218 /bin/stream | |
parent | 39f0f0a6216e15fd9e9e97efc9bdc7ea6a94bbab (diff) |
Make GOP optional, and set only for H.264 (not VP8).
Diffstat (limited to 'bin/stream')
-rwxr-xr-x | bin/stream | 14 |
1 files changed, 7 insertions, 7 deletions
@@ -228,18 +228,18 @@ encode_opus() { encode_aac() { echo_n "-codec:a aac -strict experimental -ac $ACHANNELS -ar $AFRAMERATE_AAC -b:a $((ACHANNELS*ABITRATE_AAC))" } -encode_vp8() { bitrate=$1; speed=$2; +encode_vp8() { bitrate=$1; speed=$2; gop=$3; echo_n "-codec:v vp8 -quality realtime -deadline 1000000 -cpu-used $speed \ -b:v $bitrate -minrate $bitrate -maxrate $bitrate \ -undershoot-pct 95 -bufsize $((6000*bitrate/1000)) -rc_init_occupancy $((4000*bitrate/1000)) \ -max-intra-rate 0 \ - -qmin 4 -qmax 56 \ - -force_key_frames expr:gte(t,n_forced*2)" + -qmin 4 -qmax 56" +[ -z "$gop" ] || echo_n " -force_key_frames expr:gte(t,n_forced*$gop)" } -encode_x264() { bitrate=$1; speed=$2; +encode_x264() { bitrate=$1; speed=$2; gop=$3; echo_n "-codec:v libx264 -preset $speed -tune zerolatency \ - -maxrate $bitrate -bufsize $((bitrate*2)) -crf 23 \ - -force_key_frames expr:gte(t,n_forced*2)" + -maxrate $bitrate -bufsize $((bitrate*2)) -crf 23" +[ -z "$gop" ] || echo_n " -force_key_frames expr:gte(t,n_forced*$gop)" } # * routing based on http://trac.ffmpeg.org/wiki/Creating%20multiple%20outputs#Teepseudo-muxer @@ -309,5 +309,5 @@ ffmpeg -hide_banner -threads auto \ ${HASAUDIO:+\ $(encode_aac) } \ ${HASVIDEO:+\ - $(encode_x264 "$VBITRATE" "$SPEED_X264") } \ + $(encode_x264 "$VBITRATE" "$SPEED_X264" 2) } \ $(mux "$TARGETS_MPEG") } |