summaryrefslogtreecommitdiff
path: root/libavfilter/vf_framerate.c
diff options
context:
space:
mode:
authorLimin Wang <lance.lmwang@gmail.com>2019-10-08 23:28:37 +0800
committerLimin Wang <lance.lmwang@gmail.com>2020-05-14 23:03:06 +0800
commit339593ca90cb3e05d659ec99a1479904ec742294 (patch)
tree7b083575479eed85ef904fc8d5ba2add16aff7cb /libavfilter/vf_framerate.c
parentd62d4e05e80342b0b42a6adfd957eda230655a54 (diff)
downloadffmpeg-339593ca90cb3e05d659ec99a1479904ec742294.tar.gz
avfilter/vf_framerate: if metadata lavfi.scd.mafd exists, we'll use it first
Reviewed-by: Paul B Mahol <onemda@gmail.com> Signed-off-by: Limin Wang <lance.lmwang@gmail.com>
Diffstat (limited to 'libavfilter/vf_framerate.c')
-rw-r--r--libavfilter/vf_framerate.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/libavfilter/vf_framerate.c b/libavfilter/vf_framerate.c
index 6c8d01c94b..8d16998457 100644
--- a/libavfilter/vf_framerate.c
+++ b/libavfilter/vf_framerate.c
@@ -71,13 +71,20 @@ static double get_scene_score(AVFilterContext *ctx, AVFrame *crnt, AVFrame *next
if (crnt->height == next->height &&
crnt->width == next->width) {
+ AVDictionaryEntry *e_mafd = NULL;
uint64_t sad;
- double mafd, diff;
+ double mafd = HUGE_VAL, diff;
+ char *tail = NULL;
ff_dlog(ctx, "get_scene_score() process\n");
- s->sad(crnt->data[0], crnt->linesize[0], next->data[0], next->linesize[0], crnt->width, crnt->height, &sad);
- emms_c();
- mafd = (double)sad * 100.0 / (crnt->width * crnt->height) / (1 << s->bitdepth);
+ e_mafd = av_dict_get(next->metadata, "lavfi.scd.mafd", NULL, AV_DICT_MATCH_CASE);
+ if (e_mafd)
+ mafd = strtod(e_mafd->value, &tail);
+ if (*tail || mafd == HUGE_VAL) {
+ s->sad(crnt->data[0], crnt->linesize[0], next->data[0], next->linesize[0], crnt->width, crnt->height, &sad);
+ emms_c();
+ mafd = (double)sad * 100.0 / (crnt->width * crnt->height) / (1 << s->bitdepth);
+ }
diff = fabs(mafd - s->prev_mafd);
ret = av_clipf(FFMIN(mafd, diff), 0, 100.0);
s->prev_mafd = mafd;