[FFmpeg-cvslog] avfilter/vf_minterpolate: correct the mafd calculation
Limin Wang
git at videolan.org
Thu May 14 18:37:02 EEST 2020
ffmpeg | branch: master | Limin Wang <lance.lmwang at gmail.com> | Fri Sep 20 20:08:35 2019 +0800| [61cc009d533208843984b599df4d9aaf4f8d2d43] | committer: Limin Wang
avfilter/vf_minterpolate: correct the mafd calculation
Signed-off-by: Limin Wang <lance.lmwang at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=61cc009d533208843984b599df4d9aaf4f8d2d43
---
libavfilter/vf_minterpolate.c | 6 ++++--
1 file changed, 4 insertions(+), 2 deletions(-)
diff --git a/libavfilter/vf_minterpolate.c b/libavfilter/vf_minterpolate.c
index db3d7d4ca3..1e609f220c 100644
--- a/libavfilter/vf_minterpolate.c
+++ b/libavfilter/vf_minterpolate.c
@@ -185,6 +185,7 @@ typedef struct MIContext {
int64_t out_pts;
int b_width, b_height, b_count;
int log2_mb_size;
+ int bitdepth;
int scd_method;
int scene_changed;
@@ -343,6 +344,7 @@ static int config_input(AVFilterLink *inlink)
mi_ctx->log2_chroma_h = desc->log2_chroma_h;
mi_ctx->log2_chroma_w = desc->log2_chroma_w;
+ mi_ctx->bitdepth = desc->comp[0].depth;
mi_ctx->nb_planes = av_pix_fmt_count_planes(inlink->format);
@@ -383,7 +385,7 @@ static int config_input(AVFilterLink *inlink)
}
if (mi_ctx->scd_method == SCD_METHOD_FDIFF) {
- mi_ctx->sad = ff_scene_sad_get_fn(8);
+ mi_ctx->sad = ff_scene_sad_get_fn(mi_ctx->bitdepth == 8 ? 8 : 16);
if (!mi_ctx->sad)
return AVERROR(EINVAL);
}
@@ -843,7 +845,7 @@ static int detect_scene_change(MIContext *mi_ctx)
if (*tail || mafd == HUGE_VAL) {
mi_ctx->sad(p1, linesize1, p2, linesize2, me_ctx->width, me_ctx->height, &sad);
emms_c();
- mafd = (double) sad / (me_ctx->height * me_ctx->width * 3);
+ mafd = (double) sad * 100.0 / (me_ctx->height * me_ctx->width) / (1 << mi_ctx->bitdepth);
}
diff = fabs(mafd - mi_ctx->prev_mafd);
ret = av_clipf(FFMIN(mafd, diff), 0, 100.0);
More information about the ffmpeg-cvslog
mailing list