diff options
author | Paul B Mahol <onemda@gmail.com> | 2015-07-01 08:03:19 +0000 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2015-07-03 16:34:28 +0000 |
commit | c0d676f9773aa36988564af4eed6aec7d2cc177c (patch) | |
tree | 2cebb1034198cb860703ae161833619f98f28e34 | |
parent | d3836b603e7e07c681dd09f42f56d6cdeacfd016 (diff) | |
download | ffmpeg-c0d676f9773aa36988564af4eed6aec7d2cc177c.tar.gz |
avfilter/af_astats: implement recalculation of stats after each X frames
Signed-off-by: Paul B Mahol <onemda@gmail.com>
-rw-r--r-- | libavfilter/af_astats.c | 33 |
1 files changed, 26 insertions, 7 deletions
diff --git a/libavfilter/af_astats.c b/libavfilter/af_astats.c index 24cbadd956..a89ac6d8f5 100644 --- a/libavfilter/af_astats.c +++ b/libavfilter/af_astats.c @@ -45,6 +45,8 @@ typedef struct { double time_constant; double mult; int metadata; + int reset_count; + int nb_frames; } AudioStatsContext; #define OFFSET(x) offsetof(AudioStatsContext, x) @@ -53,6 +55,7 @@ typedef struct { static const AVOption astats_options[] = { { "length", "set the window length", OFFSET(time_constant), AV_OPT_TYPE_DOUBLE, {.dbl=.05}, .01, 10, FLAGS }, { "metadata", "inject metadata in the filtergraph", OFFSET(metadata), AV_OPT_TYPE_INT, {.i64=0}, 0, 1, FLAGS }, + { "reset", "recalculate stats after this many frames", OFFSET(reset_count), AV_OPT_TYPE_INT, {.i64=0}, 0, INT_MAX, FLAGS }, { NULL } }; @@ -88,10 +91,23 @@ static int query_formats(AVFilterContext *ctx) return ff_set_common_samplerates(ctx, formats); } +static void reset_stats(AudioStatsContext *s) +{ + int c; + + memset(s->chstats, 0, sizeof(*s->chstats)); + + for (c = 0; c < s->nb_channels; c++) { + ChannelStats *p = &s->chstats[c]; + + p->min = p->min_sigma_x2 = DBL_MAX; + p->max = p->max_sigma_x2 = DBL_MIN; + } +} + static int config_output(AVFilterLink *outlink) { AudioStatsContext *s = outlink->src->priv; - int c; s->chstats = av_calloc(sizeof(*s->chstats), outlink->channels); if (!s->chstats) @@ -100,12 +116,7 @@ static int config_output(AVFilterLink *outlink) s->mult = exp((-1 / s->time_constant / outlink->sample_rate)); s->tc_samples = 5 * s->time_constant * outlink->sample_rate + .5; - for (c = 0; c < s->nb_channels; c++) { - ChannelStats *p = &s->chstats[c]; - - p->min = p->min_sigma_x2 = DBL_MAX; - p->max = p->max_sigma_x2 = DBL_MIN; - } + reset_stats(s); return 0; } @@ -251,6 +262,14 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *buf) if (s->metadata) set_metadata(s, metadata); + if (s->reset_count > 0) { + s->nb_frames++; + if (s->nb_frames >= s->reset_count) { + reset_stats(s); + s->nb_frames = 0; + } + } + return ff_filter_frame(inlink->dst->outputs[0], buf); } |