mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-12 02:19:35 +00:00
avfilter/af_anlmdn: rework how denoising strength is used
Make into account patch size.
This commit is contained in:
parent
ad0d5d7516
commit
f4fd8ef725
@ -1762,7 +1762,7 @@ The filter accepts the following options.
|
|||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
@item s
|
@item s
|
||||||
Set denoising strength. Allowed range is from 1 to 9999. Default value is 1.
|
Set denoising strength. Allowed range is from 0.00001 to 10. Default value is 0.00001.
|
||||||
|
|
||||||
@item p
|
@item p
|
||||||
Set patch radius duration. Allowed range is from 1 to 100 milliseconds.
|
Set patch radius duration. Allowed range is from 1 to 100 milliseconds.
|
||||||
|
@ -66,7 +66,7 @@ typedef struct AudioNLMeansContext {
|
|||||||
#define AF AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
|
#define AF AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
|
||||||
|
|
||||||
static const AVOption anlmdn_options[] = {
|
static const AVOption anlmdn_options[] = {
|
||||||
{ "s", "set denoising strength", OFFSET(a), AV_OPT_TYPE_FLOAT, {.dbl=1}, 1, 9999, AF },
|
{ "s", "set denoising strength", OFFSET(a), AV_OPT_TYPE_FLOAT, {.dbl=0.00001},0.00001, 10, AF },
|
||||||
{ "p", "set patch duration", OFFSET(pd), AV_OPT_TYPE_DURATION, {.i64=2000}, 1000, 100000, AF },
|
{ "p", "set patch duration", OFFSET(pd), AV_OPT_TYPE_DURATION, {.i64=2000}, 1000, 100000, AF },
|
||||||
{ "r", "set research duration", OFFSET(rd), AV_OPT_TYPE_DURATION, {.i64=6000}, 2000, 300000, AF },
|
{ "r", "set research duration", OFFSET(rd), AV_OPT_TYPE_DURATION, {.i64=6000}, 2000, 300000, AF },
|
||||||
{ NULL }
|
{ NULL }
|
||||||
@ -186,7 +186,7 @@ static int filter_channel(AVFilterContext *ctx, void *arg, int ch, int nb_jobs)
|
|||||||
const int K = s->K;
|
const int K = s->K;
|
||||||
const float *f = (const float *)(s->in->extended_data[ch]) + K;
|
const float *f = (const float *)(s->in->extended_data[ch]) + K;
|
||||||
float *cache = (float *)s->cache->extended_data[ch];
|
float *cache = (float *)s->cache->extended_data[ch];
|
||||||
const float sw = 32768.f / s->a;
|
const float sw = (65536.f / (4 * K + 2)) / sqrtf(s->a);
|
||||||
float *dst = (float *)out->extended_data[ch] + s->offset;
|
float *dst = (float *)out->extended_data[ch] + s->offset;
|
||||||
|
|
||||||
for (int i = S; i < s->H + S; i++) {
|
for (int i = S; i < s->H + S; i++) {
|
||||||
|
Loading…
Reference in New Issue
Block a user