mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-21 10:55:51 +02:00
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>
This commit is contained in:
parent
d62d4e05e8
commit
339593ca90
@ -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;
|
||||
|
Loading…
Reference in New Issue
Block a user