|
|
|
@ -110,6 +110,7 @@ typedef struct BiquadsContext { |
|
|
|
|
double gain; |
|
|
|
|
double frequency; |
|
|
|
|
double width; |
|
|
|
|
double mix; |
|
|
|
|
uint64_t channels; |
|
|
|
|
|
|
|
|
|
double a0, a1, a2; |
|
|
|
@ -187,6 +188,9 @@ static void biquad_## name (BiquadsContext *s, \ |
|
|
|
|
double i2 = *in2; \
|
|
|
|
|
double o1 = *out1; \
|
|
|
|
|
double o2 = *out2; \
|
|
|
|
|
double wet = s->mix; \
|
|
|
|
|
double dry = 1. - wet; \
|
|
|
|
|
double out; \
|
|
|
|
|
int i; \
|
|
|
|
|
a1 = -a1; \
|
|
|
|
|
a2 = -a2; \
|
|
|
|
@ -194,30 +198,32 @@ static void biquad_## name (BiquadsContext *s, \ |
|
|
|
|
for (i = 0; i+1 < len; i++) { \
|
|
|
|
|
o2 = i2 * b2 + i1 * b1 + ibuf[i] * b0 + o2 * a2 + o1 * a1; \
|
|
|
|
|
i2 = ibuf[i]; \
|
|
|
|
|
out = o2 * wet + i2 * dry; \
|
|
|
|
|
if (disabled) { \
|
|
|
|
|
obuf[i] = i2; \
|
|
|
|
|
} else if (need_clipping && o2 < min) { \
|
|
|
|
|
} else if (need_clipping && out < min) { \
|
|
|
|
|
(*clippings)++; \
|
|
|
|
|
obuf[i] = min; \
|
|
|
|
|
} else if (need_clipping && o2 > max) { \
|
|
|
|
|
} else if (need_clipping && out > max) { \
|
|
|
|
|
(*clippings)++; \
|
|
|
|
|
obuf[i] = max; \
|
|
|
|
|
} else { \
|
|
|
|
|
obuf[i] = o2; \
|
|
|
|
|
obuf[i] = out; \
|
|
|
|
|
} \
|
|
|
|
|
i++; \
|
|
|
|
|
o1 = i1 * b2 + i2 * b1 + ibuf[i] * b0 + o1 * a2 + o2 * a1; \
|
|
|
|
|
i1 = ibuf[i]; \
|
|
|
|
|
out = o1 * wet + i1 * dry; \
|
|
|
|
|
if (disabled) { \
|
|
|
|
|
obuf[i] = i1; \
|
|
|
|
|
} else if (need_clipping && o1 < min) { \
|
|
|
|
|
} else if (need_clipping && out < min) { \
|
|
|
|
|
(*clippings)++; \
|
|
|
|
|
obuf[i] = min; \
|
|
|
|
|
} else if (need_clipping && o1 > max) { \
|
|
|
|
|
} else if (need_clipping && out > max) { \
|
|
|
|
|
(*clippings)++; \
|
|
|
|
|
obuf[i] = max; \
|
|
|
|
|
} else { \
|
|
|
|
|
obuf[i] = o1; \
|
|
|
|
|
obuf[i] = out; \
|
|
|
|
|
} \
|
|
|
|
|
} \
|
|
|
|
|
if (i < len) { \
|
|
|
|
@ -226,16 +232,17 @@ static void biquad_## name (BiquadsContext *s, \ |
|
|
|
|
i1 = ibuf[i]; \
|
|
|
|
|
o2 = o1; \
|
|
|
|
|
o1 = o0; \
|
|
|
|
|
out = o0 * wet + i1 * dry; \
|
|
|
|
|
if (disabled) { \
|
|
|
|
|
obuf[i] = i1; \
|
|
|
|
|
} else if (need_clipping && o0 < min) { \
|
|
|
|
|
} else if (need_clipping && out < min) { \
|
|
|
|
|
(*clippings)++; \
|
|
|
|
|
obuf[i] = min; \
|
|
|
|
|
} else if (need_clipping && o0 > max) { \
|
|
|
|
|
} else if (need_clipping && out > max) { \
|
|
|
|
|
(*clippings)++; \
|
|
|
|
|
obuf[i] = max; \
|
|
|
|
|
} else { \
|
|
|
|
|
obuf[i] = o0; \
|
|
|
|
|
obuf[i] = out; \
|
|
|
|
|
} \
|
|
|
|
|
} \
|
|
|
|
|
*in1 = i1; \
|
|
|
|
@ -532,6 +539,15 @@ static int process_command(AVFilterContext *ctx, const char *cmd, const char *ar |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
s->gain = gain; |
|
|
|
|
} else if (!strcmp(cmd, "mix") || !strcmp(cmd, "m")) { |
|
|
|
|
double mix; |
|
|
|
|
|
|
|
|
|
if (sscanf(args, "%lf", &mix) != 1) { |
|
|
|
|
av_log(ctx, AV_LOG_ERROR, "Invalid mix value.\n"); |
|
|
|
|
return AVERROR(EINVAL); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
s->mix = av_clipd(mix, 0, 1); |
|
|
|
|
} else if ((!strcmp(cmd, "width") || !strcmp(cmd, "w")) && |
|
|
|
|
(s->filter_type == equalizer || |
|
|
|
|
s->filter_type == lowshelf || |
|
|
|
@ -679,6 +695,8 @@ static const AVOption equalizer_options[] = { |
|
|
|
|
{"w", "set band-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 99999, FLAGS}, |
|
|
|
|
{"gain", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"g", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -701,6 +719,8 @@ static const AVOption bass_options[] = { |
|
|
|
|
{"w", "set shelf transition steep", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"gain", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"g", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -723,6 +743,8 @@ static const AVOption treble_options[] = { |
|
|
|
|
{"w", "set shelf transition steep", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"gain", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"g", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -744,6 +766,8 @@ static const AVOption bandpass_options[] = { |
|
|
|
|
{"width", "set band-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"w", "set band-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"csg", "use constant skirt gain", OFFSET(csg), AV_OPT_TYPE_BOOL, {.i64=0}, 0, 1, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -764,6 +788,8 @@ static const AVOption bandreject_options[] = { |
|
|
|
|
{"k", "kHz", 0, AV_OPT_TYPE_CONST, {.i64=KHERTZ}, 0, 0, FLAGS, "width_type"}, |
|
|
|
|
{"width", "set band-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"w", "set band-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -786,6 +812,8 @@ static const AVOption lowpass_options[] = { |
|
|
|
|
{"w", "set width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.707}, 0, 99999, FLAGS}, |
|
|
|
|
{"poles", "set number of poles", OFFSET(poles), AV_OPT_TYPE_INT, {.i64=2}, 1, 2, FLAGS}, |
|
|
|
|
{"p", "set number of poles", OFFSET(poles), AV_OPT_TYPE_INT, {.i64=2}, 1, 2, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -808,6 +836,8 @@ static const AVOption highpass_options[] = { |
|
|
|
|
{"w", "set width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.707}, 0, 99999, FLAGS}, |
|
|
|
|
{"poles", "set number of poles", OFFSET(poles), AV_OPT_TYPE_INT, {.i64=2}, 1, 2, FLAGS}, |
|
|
|
|
{"p", "set number of poles", OFFSET(poles), AV_OPT_TYPE_INT, {.i64=2}, 1, 2, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -828,6 +858,8 @@ static const AVOption allpass_options[] = { |
|
|
|
|
{"k", "kHz", 0, AV_OPT_TYPE_CONST, {.i64=KHERTZ}, 0, 0, FLAGS, "width_type"}, |
|
|
|
|
{"width", "set filter-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=707.1}, 0, 99999, FLAGS}, |
|
|
|
|
{"w", "set filter-width", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=707.1}, 0, 99999, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -850,6 +882,8 @@ static const AVOption lowshelf_options[] = { |
|
|
|
|
{"w", "set shelf transition steep", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"gain", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"g", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -872,6 +906,8 @@ static const AVOption highshelf_options[] = { |
|
|
|
|
{"w", "set shelf transition steep", OFFSET(width), AV_OPT_TYPE_DOUBLE, {.dbl=0.5}, 0, 99999, FLAGS}, |
|
|
|
|
{"gain", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"g", "set gain", OFFSET(gain), AV_OPT_TYPE_DOUBLE, {.dbl=0}, -900, 900, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
@ -887,6 +923,8 @@ static const AVOption biquad_options[] = { |
|
|
|
|
{"b0", NULL, OFFSET(b0), AV_OPT_TYPE_DOUBLE, {.dbl=0}, INT32_MIN, INT32_MAX, FLAGS}, |
|
|
|
|
{"b1", NULL, OFFSET(b1), AV_OPT_TYPE_DOUBLE, {.dbl=0}, INT32_MIN, INT32_MAX, FLAGS}, |
|
|
|
|
{"b2", NULL, OFFSET(b2), AV_OPT_TYPE_DOUBLE, {.dbl=0}, INT32_MIN, INT32_MAX, FLAGS}, |
|
|
|
|
{"mix", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"m", "set mix", OFFSET(mix), AV_OPT_TYPE_DOUBLE, {.dbl=1}, 0, 1, FLAGS}, |
|
|
|
|
{"channels", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{"c", "set channels to filter", OFFSET(channels), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64=-1}, INT64_MIN, INT64_MAX, FLAGS}, |
|
|
|
|
{NULL} |
|
|
|
|