78 #define OFFSET(x) offsetof(MCDeintContext, x)
79 #define FLAGS AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
80 #define CONST(name, help, val, unit) { name, help, 0, AV_OPT_TYPE_CONST, {.i64=val}, INT_MIN, INT_MAX, FLAGS, unit }
117 enc_ctx->
width = inlink->
w;
131 switch (mcdeint->
mode) {
178 int x,
y, i,
ret, got_frame = 0;
196 for (i = 0; i < 3; i++) {
204 for (y = 0; y < h; y++) {
205 if ((y ^ mcdeint->
parity) & 1) {
206 for (x = 0; x < w; x++) {
211 if (y > 0 && y < h-1){
212 int is_edge = x < 3 || x > w-4;
213 int diff0 = filp[-fils] - srcp[-srcs];
214 int diff1 = filp[+fils] - srcp[+srcs];
217 #define DELTA(j) av_clip(j, -x, w-1-x)
219 #define GET_SCORE_EDGE(j)\
220 FFABS(srcp[-srcs+DELTA(-1+(j))] - srcp[+srcs+DELTA(-1-(j))])+\
221 FFABS(srcp[-srcs+DELTA(j) ] - srcp[+srcs+DELTA( -(j))])+\
222 FFABS(srcp[-srcs+DELTA(1+(j)) ] - srcp[+srcs+DELTA( 1-(j))])
224 #define GET_SCORE(j)\
225 FFABS(srcp[-srcs-1+(j)] - srcp[+srcs-1-(j)])+\
226 FFABS(srcp[-srcs +(j)] - srcp[+srcs -(j)])+\
227 FFABS(srcp[-srcs+1+(j)] - srcp[+srcs+1-(j)])
229 #define CHECK_EDGE(j)\
230 { int score = GET_SCORE_EDGE(j);\
231 if (score < spatial_score){\
232 spatial_score = score;\
233 diff0 = filp[-fils+DELTA(j)] - srcp[-srcs+DELTA(j)];\
234 diff1 = filp[+fils+DELTA(-(j))] - srcp[+srcs+DELTA(-(j))];\
237 { int score = GET_SCORE(j);\
238 if (score < spatial_score){\
239 spatial_score= score;\
240 diff0 = filp[-fils+(j)] - srcp[-srcs+(j)];\
241 diff1 = filp[+fils-(j)] - srcp[+srcs-(j)];\
249 CHECK(-1) CHECK(-2) }} }}
250 CHECK( 1) CHECK( 2) }} }}
254 if (diff0 + diff1 > 0)
267 if (!((
y ^ mcdeint->parity) & 1)) {
268 for (x = 0; x < w; x++) {
269 frame_dec->data[i][x +
y*fils] =
270 outpic ->data[i][x +
y*dsts] =
inpic->data[i][x +
y*srcs];
275 mcdeint->parity ^= 1;
313 .priv_class = &mcdeint_class,