[FFmpeg-devel] [PATCH 1/3] tools: add loudnorm script example to use loudnorm
Nicolas George
george at nsup.org
Sun Oct 16 22:37:22 EEST 2016
Le quintidi 25 vendémiaire, an CCXXV, Marton Balint a écrit :
> From: Kyle Swanson <k at ylo.ph>
>
> Signed-off-by: Kyle Swanson <k at ylo.ph>
> Signed-off-by: Marton Balint <cus at passwd.hu>
> ---
> tools/loudnorm.rb | 60 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 60 insertions(+)
> create mode 100755 tools/loudnorm.rb
>
> diff --git a/tools/loudnorm.rb b/tools/loudnorm.rb
> new file mode 100755
> index 0000000..39deb70
> --- /dev/null
> +++ b/tools/loudnorm.rb
> @@ -0,0 +1,60 @@
> +#!/usr/bin/env ruby
> +
> +require 'open3'
> +require 'json'
> +
> +ffmpeg_bin = 'ffmpeg'
> +target_il = -24.0
> +target_lra = +11.0
> +target_tp = -2.0
> +samplerate = '48k'
> +
> +if ARGF.argv.count != 2
> + puts "Usage: #{$PROGRAM_NAME} input.wav output.wav"
> + exit 1
> +end
> +
> +ff_string = "#{ffmpeg_bin} -hide_banner "
> +ff_string += "-i #{ARGF.argv[0]} "
> +ff_string += '-af loudnorm='
> +ff_string += "I=#{target_il}:"
> +ff_string += "LRA=#{target_lra}:"
> +ff_string += "tp=#{target_tp}:"
> +ff_string += 'print_format=json '
> +ff_string += '-f null -'
This will break if the input file name contains special characters. I think
I see popen3 can accept an array of arguments, it would be better to use it.
> +
> +_stdin, _stdout, stderr, wait_thr = Open3.popen3(ff_string)
> +
> +if wait_thr.value.success?
> + stats = JSON.parse(stderr.read.lines[-12, 12].join)
> + loudnorm_string = '-af loudnorm='
> + loudnorm_string += 'print_format=summary:'
> + loudnorm_string += 'linear=true:'
> + loudnorm_string += "I=#{target_il}:"
> + loudnorm_string += "LRA=#{target_lra}:"
> + loudnorm_string += "tp=#{target_tp}:"
> + loudnorm_string += "measured_I=#{stats['input_i']}:"
> + loudnorm_string += "measured_LRA=#{stats['input_lra']}:"
> + loudnorm_string += "measured_tp=#{stats['input_tp']}:"
> + loudnorm_string += "measured_thresh=#{stats['input_thresh']}:"
> + loudnorm_string += "offset=#{stats['target_offset']}"
> +else
> + puts stderr.read
> + exit 1
> +end
> +
> +ff_string = "#{ffmpeg_bin} -y -hide_banner "
> +ff_string += "-i #{ARGF.argv[0]} "
> +ff_string += "#{loudnorm_string} "
> +ff_string += "-ar #{samplerate} "
> +ff_string += ARGF.argv[1].to_s
> +
> +_stdin, _stdout, stderr, wait_thr = Open3.popen3(ff_string)
> +
> +if wait_thr.value.success?
> + puts stderr.read.lines[-12, 12].join
> + exit 0
> +else
> + puts stderr.read
> + exit 1
> +end
Regards,
--
Nicolas George
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 801 bytes
Desc: Digital signature
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20161016/20506619/attachment.sig>
More information about the ffmpeg-devel
mailing list