55 int jobnr,
int nb_jobs);
59 #define OFFSET(x) offsetof(IdentityContext, x)
60 #define FLAGS AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_VIDEO_PARAM
66 for (
int j = 0; j < outw; j++)
67 score += main_line[j] == ref_line[j];
74 const uint16_t *main_line = (
const uint16_t *)mmain_line;
75 const uint16_t *ref_line = (
const uint16_t *)rref_line;
78 for (
int j = 0; j < outw; j++)
79 score += main_line[j] == ref_line[j];
97 int jobnr,
int nb_jobs)
101 uint64_t *score =
td->score[jobnr];
103 for (
int c = 0;
c <
td->nb_components;
c++) {
104 const int outw =
td->planewidth[
c];
105 const int outh =
td->planeheight[
c];
106 const int slice_start =
ff_slice_pos(outh, jobnr, nb_jobs);
108 const int ref_linesize =
td->ref_linesize[
c];
109 const int main_linesize =
td->main_linesize[
c];
110 const uint8_t *main_line =
td->main_data[
c] + main_linesize * slice_start;
111 const uint8_t *ref_line =
td->ref_data[
c] + ref_linesize * slice_start;
114 s->sad(main_line, main_linesize, ref_line, ref_linesize,
125 int jobnr,
int nb_jobs)
129 uint64_t *score =
td->score[jobnr];
131 for (
int c = 0;
c <
td->nb_components;
c++) {
132 const int outw =
td->planewidth[
c];
133 const int outh =
td->planeheight[
c];
134 const int slice_start =
ff_slice_pos(outh, jobnr, nb_jobs);
136 const int ref_linesize =
td->ref_linesize[
c];
137 const int main_linesize =
td->main_linesize[
c];
138 const uint8_t *main_line =
td->main_data[
c] + main_linesize * slice_start;
139 const uint8_t *ref_line =
td->ref_data[
c] + ref_linesize * slice_start;
143 m +=
s->filter_line(main_line, ref_line, outw);
144 ref_line += ref_linesize;
145 main_line += main_linesize;
160 snprintf(key2,
sizeof(key2),
"lavfi.%s.%s%s%c",
165 snprintf(key2,
sizeof(key2),
"lavfi.%s.%s%s",
166 ctx->filter->name,
ctx->filter->name,
key);
176 double comp_score[4], score = 0.;
177 uint64_t comp_sum[4] = { 0 };
185 if (
ctx->is_disabled || !
ref)
187 metadata = &
master->metadata;
189 td.nb_components =
s->nb_components;
190 td.score =
s->scores;
191 for (
int c = 0;
c <
s->nb_components;
c++) {
195 td.ref_linesize[
c] =
ref->linesize[
c];
196 td.planewidth[
c] =
s->planewidth[
c];
197 td.planeheight[
c] =
s->planeheight[
c];
202 for (
int j = 0; j <
s->nb_threads; j++) {
203 for (
int c = 0;
c <
s->nb_components;
c++)
204 comp_sum[
c] +=
s->scores[j][
c];
207 for (
int c = 0;
c <
s->nb_components;
c++)
208 comp_score[
c] = comp_sum[
c] / ((
double)
s->planewidth[
c] *
s->planeheight[
c]);
210 for (
int c = 0;
c <
s->nb_components &&
s->is_msad;
c++)
211 comp_score[
c] /= (
double)
s->max[
c];
213 for (
int c = 0;
c <
s->nb_components;
c++)
214 score += comp_score[
c];
215 score /=
s->nb_components;
217 s->min_score =
FFMIN(
s->min_score, score);
218 s->max_score =
FFMAX(
s->max_score, score);
222 for (
int j = 0; j <
s->nb_components; j++)
223 s->score_comp[j] += comp_score[j];
226 for (
int j = 0; j <
s->nb_components; j++) {
227 int c =
s->is_rgb ?
s->rgba_map[j] : j;
248 #define PF_NOALPHA(suf) AV_PIX_FMT_YUV420##suf, AV_PIX_FMT_YUV422##suf, AV_PIX_FMT_YUV444##suf
249 #define PF_ALPHA(suf) AV_PIX_FMT_YUVA420##suf, AV_PIX_FMT_YUVA422##suf, AV_PIX_FMT_YUVA444##suf
250 #define PF(suf) PF_NOALPHA(suf), PF_ALPHA(suf)
274 s->nb_components =
desc->nb_components;
275 if (
ctx->inputs[0]->w !=
ctx->inputs[1]->w ||
276 ctx->inputs[0]->h !=
ctx->inputs[1]->h) {
280 if (
ctx->inputs[0]->format !=
ctx->inputs[1]->format) {
286 s->comps[0] =
s->is_rgb ?
'R' :
'Y' ;
287 s->comps[1] =
s->is_rgb ?
'G' :
'U' ;
288 s->comps[2] =
s->is_rgb ?
'B' :
'V' ;
292 s->planeheight[0] =
s->planeheight[3] = inlink->
h;
294 s->planewidth[0] =
s->planewidth[3] = inlink->
w;
296 s->scores =
av_calloc(
s->nb_threads,
sizeof(*
s->scores));
300 for (
int t = 0; t <
s->nb_threads &&
s->scores; t++) {
301 s->scores[t] =
av_calloc(
s->nb_components,
sizeof(*
s->scores[0]));
309 s->max[0] = (1 <<
desc->comp[0].depth) - 1;
310 s->max[1] = (1 <<
desc->comp[1].depth) - 1;
311 s->max[2] = (1 <<
desc->comp[2].depth) - 1;
312 s->max[3] = (1 <<
desc->comp[3].depth) - 1;
314 s->is_msad = !strcmp(
ctx->filter->name,
"msad");
335 outlink->
w = mainlink->
w;
336 outlink->
h = mainlink->
h;
347 av_log(
ctx,
AV_LOG_WARNING,
"not matching timebases found between first input: %d/%d and second input %d/%d, results may be incorrect!\n",
349 ctx->inputs[1]->time_base.num,
ctx->inputs[1]->time_base.den);
364 if (
s->nb_frames > 0) {
368 for (
int j = 0; j <
s->nb_components; j++) {
369 int c =
s->is_rgb ?
s->rgba_map[j] : j;
370 av_strlcatf(buf,
sizeof(buf),
" %c:%f",
s->comps[j],
s->score_comp[
c] /
s->nb_frames);
376 s->score /
s->nb_frames,
382 for (
int t = 0; t <
s->nb_threads &&
s->scores; t++)
412 #if CONFIG_IDENTITY_FILTER
414 #define identity_options options
420 .preinit = identity_framesync_preinit,
426 .priv_class = &identity_class,
434 #if CONFIG_MSAD_FILTER
436 #define msad_options options
442 .preinit = msad_framesync_preinit,
448 .priv_class = &msad_class,
static const AVFilterPad inputs[]
static const AVFilterPad outputs[]
int ff_filter_frame(AVFilterLink *link, AVFrame *frame)
Send a frame of data to the next filter.
int ff_filter_get_nb_threads(AVFilterContext *ctx)
Get number of threads for current filter instance.
Main libavfilter public API header.
size_t av_strlcatf(char *dst, size_t size, const char *fmt,...)
#define flags(name, subs,...)
#define fs(width, name, subs,...)
#define AV_CEIL_RSHIFT(a, b)
int ff_fill_rgba_map(uint8_t *rgba_map, enum AVPixelFormat pix_fmt)
static void comp(unsigned char *dst, ptrdiff_t dst_stride, unsigned char *src, ptrdiff_t src_stride, int add)
static int ff_slice_pos(int total, int jobnr, int nb_jobs)
Compute the boundary index for a slice when work of size total is split into nb_jobs slices.
int ff_framesync_configure(FFFrameSync *fs)
Configure a frame sync structure.
int ff_framesync_dualinput_get(FFFrameSync *fs, AVFrame **f0, AVFrame **f1)
int ff_framesync_activate(FFFrameSync *fs)
Examine the frames in the filter's input and try to produce output.
int ff_framesync_init_dualinput(FFFrameSync *fs, AVFilterContext *parent)
Initialize a frame sync structure for dualinput.
void ff_framesync_uninit(FFFrameSync *fs)
Free all memory currently allocated.
#define FRAMESYNC_DEFINE_CLASS(name, context, field)
#define AVFILTER_FLAG_SLICE_THREADS
The filter supports multithreading by splitting frames into multiple parts and processing them concur...
#define AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL
Same as AVFILTER_FLAG_SUPPORT_TIMELINE_GENERIC, except that the filter will have its filter_frame() c...
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
#define AV_LOG_WARNING
Something somehow does not look correct.
#define AV_LOG_INFO
Standard information.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static int av_cmp_q(AVRational a, AVRational b)
Compare two rationals.
void * av_calloc(size_t nmemb, size_t size)
Non-inlined equivalent of av_mallocz_array().
common internal API header
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
static enum AVPixelFormat pix_fmts[]
static int slice_end(AVCodecContext *avctx, AVFrame *pict)
Handle slice ends.
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
#define AV_PIX_FMT_GBRAP12
#define AV_PIX_FMT_GBRAP16
#define AV_PIX_FMT_GBRP10
#define AV_PIX_FMT_GRAY12
#define AV_PIX_FMT_GBRP12
AVPixelFormat
Pixel format.
@ AV_PIX_FMT_YUV440P
planar YUV 4:4:0 (1 Cr & Cb sample per 1x2 Y samples)
@ AV_PIX_FMT_GRAY8
Y , 8bpp.
@ AV_PIX_FMT_YUVJ440P
planar YUV 4:4:0 full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV440P and setting color_range
@ AV_PIX_FMT_YUV410P
planar YUV 4:1:0, 9bpp, (1 Cr & Cb sample per 4x4 Y samples)
@ AV_PIX_FMT_YUV411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples)
@ AV_PIX_FMT_YUVJ411P
planar YUV 4:1:1, 12bpp, (1 Cr & Cb sample per 4x1 Y samples) full scale (JPEG), deprecated in favor ...
@ AV_PIX_FMT_GBRAP
planar GBRA 4:4:4:4 32bpp
@ AV_PIX_FMT_YUVJ422P
planar YUV 4:2:2, 16bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV422P and setting col...
@ AV_PIX_FMT_GBRP
planar GBR 4:4:4 24bpp
@ AV_PIX_FMT_YUVJ444P
planar YUV 4:4:4, 24bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV444P and setting col...
@ AV_PIX_FMT_YUVJ420P
planar YUV 4:2:0, 12bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV420P and setting col...
#define AV_PIX_FMT_GRAY10
#define AV_PIX_FMT_GRAY14
#define AV_PIX_FMT_GRAY16
#define AV_PIX_FMT_GBRAP10
#define AV_PIX_FMT_GBRP16
#define AV_PIX_FMT_GBRP14
ff_scene_sad_fn ff_scene_sad_get_fn(int depth)
void(* ff_scene_sad_fn)(SCENE_SAD_PARAMS)
Describe the class of an AVClass context structure.
A link between two filters.
int w
agreed upon image width
int h
agreed upon image height
AVFilterContext * src
source filter
AVRational time_base
Define the time base used by the PTS of the frames/samples which will pass through this link.
AVRational sample_aspect_ratio
agreed upon sample aspect ratio
AVRational frame_rate
Frame rate of the stream on the link, or 1/0 if unknown or variable; if left to 0/0,...
AVFilterContext * dst
dest filter
int format
agreed upon media format
A filter pad used for either input or output.
const char * name
Pad name.
const char * name
Filter name.
AVFormatInternal * internal
An opaque field for libavformat internal usage.
This structure describes decoded (raw) audio or video data.
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
unsigned(* filter_line)(const uint8_t *buf, const uint8_t *ref, int w)
int(* filter_slice)(AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs)
Used for passing data between threads.
const uint8_t * ref_data[4]
const uint8_t * main_data[4]
static int ref[MAX_W *MAX_W]
static int do_identity(FFFrameSync *fs)
static const AVOption options[]
static int compute_images_identity(AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs)
static int query_formats(AVFilterContext *ctx)
static const AVFilterPad identity_inputs[]
static unsigned identity_line_16bit(const uint8_t *mmain_line, const uint8_t *rref_line, int outw)
static int compute_images_msad(AVFilterContext *ctx, void *arg, int jobnr, int nb_jobs)
static void set_meta(AVFilterContext *ctx, AVDictionary **metadata, const char *key, char comp, float d)
static int config_input_ref(AVFilterLink *inlink)
static const AVFilterPad identity_outputs[]
static int activate(AVFilterContext *ctx)
static av_cold int init(AVFilterContext *ctx)
static av_cold void uninit(AVFilterContext *ctx)
static int config_output(AVFilterLink *outlink)
static unsigned identity_line_8bit(const uint8_t *main_line, const uint8_t *ref_line, int outw)