[FFmpeg-cvslog] avfilter/af_silenceremove: make size of window user configurable

Paul B Mahol git at videolan.org
Mon Dec 28 12:45:44 CET 2015


ffmpeg | branch: master | Paul B Mahol <onemda at gmail.com> | Mon Dec 28 12:02:14 2015 +0100| [47aaebd63e408bc59dc9e35dd372c1f603be2d3a] | committer: Paul B Mahol

avfilter/af_silenceremove: make size of window user configurable

Signed-off-by: Paul B Mahol <onemda at gmail.com>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=47aaebd63e408bc59dc9e35dd372c1f603be2d3a
---

 doc/filters.texi               |    4 ++++
 libavfilter/af_silenceremove.c |    4 +++-
 2 files changed, 7 insertions(+), 1 deletion(-)

diff --git a/doc/filters.texi b/doc/filters.texi
index abec3c3..2b1fabe 100644
--- a/doc/filters.texi
+++ b/doc/filters.texi
@@ -2973,6 +2973,10 @@ to remove the pauses completely. Default value is @code{0}.
 Set how is silence detected. Can be @code{rms} or @code{peak}. Second is faster
 and works better with digital silence which is exactly 0.
 Default value is @code{rms}.
+
+ at item window
+Set ratio used to calculate size of window for detecting silence.
+Default value is @code{0.02}. Allowed range is from @code{0} to @code{10}.
 @end table
 
 @subsection Examples
diff --git a/libavfilter/af_silenceremove.c b/libavfilter/af_silenceremove.c
index dc3f4ff..f156d18 100644
--- a/libavfilter/af_silenceremove.c
+++ b/libavfilter/af_silenceremove.c
@@ -61,6 +61,7 @@ typedef struct SilenceRemoveContext {
     size_t stop_holdoff_end;
     int    stop_found_periods;
 
+    double window_ratio;
     double *window;
     double *window_current;
     double *window_end;
@@ -89,6 +90,7 @@ static const AVOption silenceremove_options[] = {
     { "detection",       NULL, OFFSET(detection),       AV_OPT_TYPE_INT,      {.i64=1},     0,       1, FLAGS, "detection" },
     {   "peak",          0,    0,                       AV_OPT_TYPE_CONST,    {.i64=0},     0,       0, FLAGS, "detection" },
     {   "rms",           0,    0,                       AV_OPT_TYPE_CONST,    {.i64=1},     0,       0, FLAGS, "detection" },
+    { "window",          NULL, OFFSET(window_ratio),    AV_OPT_TYPE_DOUBLE,   {.dbl=0.02},  0,      10, FLAGS },
     { NULL }
 };
 
@@ -175,7 +177,7 @@ static int config_input(AVFilterLink *inlink)
     AVFilterContext *ctx = inlink->dst;
     SilenceRemoveContext *s = ctx->priv;
 
-    s->window_size = (inlink->sample_rate / 50) * inlink->channels;
+    s->window_size = FFMAX((inlink->sample_rate * s->window_ratio), 1) * inlink->channels;
     s->window = av_malloc_array(s->window_size, sizeof(*s->window));
     if (!s->window)
         return AVERROR(ENOMEM);



More information about the ffmpeg-cvslog mailing list