[FFmpeg-cvslog] avfilter/af_speechnorm: speed up filtering code
Paul B Mahol
git at videolan.org
Wed Feb 16 21:21:54 EET 2022
ffmpeg | branch: master | Paul B Mahol <onemda at gmail.com> | Wed Feb 16 19:31:31 2022 +0100| [698de27f25bea278ce7155fc387b3d59b478d46b] | committer: Paul B Mahol
avfilter/af_speechnorm: speed up filtering code
Reduce some asserts by default.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=698de27f25bea278ce7155fc387b3d59b478d46b
---
libavfilter/af_speechnorm.c | 133 ++++++++++++++++++++++++--------------------
1 file changed, 73 insertions(+), 60 deletions(-)
diff --git a/libavfilter/af_speechnorm.c b/libavfilter/af_speechnorm.c
index 212a926f36..7fa87f814a 100644
--- a/libavfilter/af_speechnorm.c
+++ b/libavfilter/af_speechnorm.c
@@ -128,7 +128,7 @@ static int get_pi_samples(PeriodItem *pi, int start, int end, int remain)
start = 0;
if (pi[start].type == 0)
break;
- av_assert0(pi[start].size > 0);
+ av_assert1(pi[start].size > 0);
sum += pi[start].size;
}
@@ -156,7 +156,7 @@ static void consume_pi(ChannelContext *cc, int nb_samples)
if (cc->pi_size >= nb_samples) {
cc->pi_size -= nb_samples;
} else {
- av_assert0(0);
+ av_assert1(0);
}
}
@@ -178,16 +178,16 @@ static double next_gain(AVFilterContext *ctx, double pi_max_peak, int bypass, do
static void next_pi(AVFilterContext *ctx, ChannelContext *cc, int bypass)
{
- av_assert0(cc->pi_size >= 0);
+ av_assert1(cc->pi_size >= 0);
if (cc->pi_size == 0) {
SpeechNormalizerContext *s = ctx->priv;
int start = cc->pi_start;
- av_assert0(cc->pi[start].size > 0);
+ av_assert1(cc->pi[start].size > 0);
av_assert0(cc->pi[start].type > 0 || s->eof);
cc->pi_size = cc->pi[start].size;
cc->pi_max_peak = cc->pi[start].max_peak;
- av_assert0(cc->pi_start != cc->pi_end || s->eof);
+ av_assert1(cc->pi_start != cc->pi_end || s->eof);
start++;
if (start >= MAX_ITEMS)
start = 0;
@@ -219,58 +219,71 @@ static double min_gain(AVFilterContext *ctx, ChannelContext *cc, int max_size)
return min_gain;
}
-#define ANALYZE_CHANNEL(name, ptype, zero, min_peak) \
-static void analyze_channel_## name (AVFilterContext *ctx, ChannelContext *cc, \
- const uint8_t *srcp, int nb_samples) \
-{ \
- SpeechNormalizerContext *s = ctx->priv; \
- const ptype *src = (const ptype *)srcp; \
- int n = 0; \
- \
- if (cc->state < 0) \
- cc->state = src[0] >= zero; \
- \
- while (n < nb_samples) { \
- if ((cc->state != (src[n] >= zero)) || \
- (cc->pi[cc->pi_end].size > s->max_period)) { \
- ptype max_peak = cc->pi[cc->pi_end].max_peak; \
- int state = cc->state; \
- cc->state = src[n] >= zero; \
- av_assert0(cc->pi[cc->pi_end].size > 0); \
- if (max_peak >= min_peak || \
- cc->pi[cc->pi_end].size > s->max_period) { \
- cc->pi[cc->pi_end].type = 1; \
- cc->pi_end++; \
- if (cc->pi_end >= MAX_ITEMS) \
- cc->pi_end = 0; \
- if (cc->state != state) \
- cc->pi[cc->pi_end].max_peak = DBL_MIN; \
- else \
- cc->pi[cc->pi_end].max_peak = max_peak; \
- cc->pi[cc->pi_end].type = 0; \
- cc->pi[cc->pi_end].size = 0; \
- av_assert0(cc->pi_end != cc->pi_start); \
- } \
- } \
- \
- if (cc->state) { \
- while (src[n] >= zero) { \
- cc->pi[cc->pi_end].max_peak = FFMAX(cc->pi[cc->pi_end].max_peak, src[n]); \
- cc->pi[cc->pi_end].size++; \
- n++; \
- if (n >= nb_samples) \
- break; \
- } \
- } else { \
- while (src[n] < zero) { \
- cc->pi[cc->pi_end].max_peak = FFMAX(cc->pi[cc->pi_end].max_peak, -src[n]); \
- cc->pi[cc->pi_end].size++; \
- n++; \
- if (n >= nb_samples) \
- break; \
- } \
- } \
- } \
+#define ANALYZE_CHANNEL(name, ptype, zero, min_peak) \
+static void analyze_channel_## name (AVFilterContext *ctx, ChannelContext *cc, \
+ const uint8_t *srcp, int nb_samples) \
+{ \
+ SpeechNormalizerContext *s = ctx->priv; \
+ const ptype *src = (const ptype *)srcp; \
+ const int max_period = s->max_period; \
+ PeriodItem *pi = (PeriodItem *)&cc->pi; \
+ int pi_end = cc->pi_end; \
+ int n = 0; \
+ \
+ if (cc->state < 0) \
+ cc->state = src[0] >= zero; \
+ \
+ while (n < nb_samples) { \
+ ptype new_max_peak; \
+ int new_size; \
+ \
+ if ((cc->state != (src[n] >= zero)) || \
+ (pi[pi_end].size > max_period)) { \
+ ptype max_peak = pi[pi_end].max_peak; \
+ int state = cc->state; \
+ \
+ cc->state = src[n] >= zero; \
+ av_assert1(pi[pi_end].size > 0); \
+ if (max_peak >= min_peak || \
+ pi[pi_end].size > max_period) { \
+ pi[pi_end].type = 1; \
+ pi_end++; \
+ if (pi_end >= MAX_ITEMS) \
+ pi_end = 0; \
+ if (cc->state != state) \
+ pi[pi_end].max_peak = DBL_MIN; \
+ else \
+ pi[pi_end].max_peak = max_peak; \
+ pi[pi_end].type = 0; \
+ pi[pi_end].size = 0; \
+ av_assert1(pi_end != cc->pi_start); \
+ } \
+ } \
+ \
+ new_max_peak = pi[pi_end].max_peak; \
+ new_size = pi[pi_end].size; \
+ if (cc->state) { \
+ while (src[n] >= zero) { \
+ new_max_peak = FFMAX(new_max_peak, src[n]); \
+ new_size++; \
+ n++; \
+ if (n >= nb_samples) \
+ break; \
+ } \
+ } else { \
+ while (src[n] < zero) { \
+ new_max_peak = FFMAX(new_max_peak, -src[n]); \
+ new_size++; \
+ n++; \
+ if (n >= nb_samples) \
+ break; \
+ } \
+ } \
+ \
+ pi[pi_end].max_peak = new_max_peak; \
+ pi[pi_end].size = new_size; \
+ } \
+ cc->pi_end = pi_end; \
}
ANALYZE_CHANNEL(dbl, double, 0.0, MIN_PEAK)
@@ -296,7 +309,7 @@ static void filter_channels_## name (AVFilterContext *ctx,
\
next_pi(ctx, cc, bypass); \
size = FFMIN(nb_samples - n, cc->pi_size); \
- av_assert0(size > 0); \
+ av_assert1(size > 0); \
gain = cc->gain_state; \
consume_pi(cc, size); \
for (int i = n; !ctx->is_disabled && i < n + size; i++) \
@@ -343,7 +356,7 @@ static void filter_link_channels_## name (AVFilterContext *ctx,
max_size = FFMAX(max_size, cc->pi_size); \
} \
\
- av_assert0(min_size > 0); \
+ av_assert1(min_size > 0); \
for (int ch = 0; ch < inlink->channels; ch++) { \
ChannelContext *cc = &s->cc[ch]; \
\
@@ -509,7 +522,7 @@ static int config_input(AVFilterLink *inlink)
s->filter_channels[1] = filter_link_channels_dbl;
break;
default:
- av_assert0(0);
+ av_assert1(0);
}
return 0;
More information about the ffmpeg-cvslog
mailing list