41 int thresh, map, order, sharp,
twoway;
49 #define OFFSET(x) offsetof(KerndeintContext, x)
50 #define FLAGS AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
65 const char const * shorthand[] = {
"thresh",
"map",
"order",
"sharp",
"twoway",
NULL };
67 kerndeint->
class = &kerndeint_class;
83 static const enum PixelFormat pix_fmts[] = {
108 inlink->
w, inlink->
h, inlink->
format, 16);
111 memset(kerndeint->
tmp_data[0], 0, ret);
145 int src_linesize, psrc_linesize, dst_linesize, bwidth;
146 int x,
y, plane, val, hi, lo,
g, h, n = kerndeint->
frame++;
149 const int thresh = kerndeint->
thresh;
150 const int order = kerndeint->
order;
151 const int map = kerndeint->
map;
152 const int sharp = kerndeint->
sharp;
153 const int twoway = kerndeint->
twoway;
165 for (plane = 0; inpic->
data[plane] && plane < 4; plane++) {
166 h = plane == 0 ? inlink->
h : inlink->
h >> kerndeint->
vsub;
169 srcp = srcp_saved = inpic->
data[plane];
170 src_linesize = inpic->
linesize[plane];
172 dstp = dstp_saved = outpic->
data[plane];
173 dst_linesize = outpic->
linesize[plane];
174 srcp = srcp_saved + (1 - order) * src_linesize;
175 dstp = dstp_saved + (1 - order) * dst_linesize;
177 for (y = 0; y < h; y += 2) {
178 memcpy(dstp, srcp, bwidth);
179 srcp += 2 * src_linesize;
180 dstp += 2 * dst_linesize;
184 memcpy(dstp_saved + order * dst_linesize, srcp_saved + (1 - order) * src_linesize, bwidth);
185 memcpy(dstp_saved + (2 + order ) * dst_linesize, srcp_saved + (3 - order) * src_linesize, bwidth);
186 memcpy(dstp_saved + (h - 2 + order) * dst_linesize, srcp_saved + (h - 1 - order) * src_linesize, bwidth);
187 memcpy(dstp_saved + (h - 4 + order) * dst_linesize, srcp_saved + (h - 3 - order) * src_linesize, bwidth);
191 prvp = kerndeint->
tmp_data[plane] + 5 * psrc_linesize - (1 - order) * psrc_linesize;
192 prvpp = prvp - psrc_linesize;
193 prvppp = prvp - 2 * psrc_linesize;
194 prvp4p = prvp - 4 * psrc_linesize;
195 prvpn = prvp + psrc_linesize;
196 prvpnn = prvp + 2 * psrc_linesize;
197 prvp4n = prvp + 4 * psrc_linesize;
199 srcp = srcp_saved + 5 * src_linesize - (1 - order) * src_linesize;
200 srcpp = srcp - src_linesize;
201 srcppp = srcp - 2 * src_linesize;
202 srcp3p = srcp - 3 * src_linesize;
203 srcp4p = srcp - 4 * src_linesize;
205 srcpn = srcp + src_linesize;
206 srcpnn = srcp + 2 * src_linesize;
207 srcp3n = srcp + 3 * src_linesize;
208 srcp4n = srcp + 4 * src_linesize;
210 dstp = dstp_saved + 5 * dst_linesize - (1 - order) * dst_linesize;
212 for (y = 5 - (1 - order); y <= h - 5 - (1 - order); y += 2) {
213 for (x = 0; x < bwidth; x++) {
214 if (thresh == 0 || n == 0 ||
215 (abs((
int)prvp[x] - (int)srcp[x]) > thresh) ||
216 (abs((
int)prvpp[x] - (int)srcpp[x]) > thresh) ||
217 (abs((
int)prvpn[x] - (int)srcpn[x]) > thresh)) {
229 dstp[x] = plane == 0 ? 235 : 128;
236 hi = x & 1 ? 240 : 235;
239 hi = plane == 0 ? 235 : 240;
245 valf = + 0.526 * ((int)srcpp[x] + (
int)srcpn[x])
246 + 0.170 * ((
int)srcp[x] + (int)prvp[x])
247 - 0.116 * ((int)srcppp[x] + (
int)srcpnn[x] + (int)prvppp[x] + (
int)prvpnn[x])
248 - 0.026 * ((
int)srcp3p[x] + (int)srcp3n[x])
249 + 0.031 * ((int)srcp4p[x] + (
int)srcp4n[x] + (int)prvp4p[x] + (
int)prvp4n[x]);
251 valf = + 0.526 * ((int)srcpp[x] + (
int)srcpn[x])
252 + 0.170 * ((
int)prvp[x])
253 - 0.116 * ((
int)prvppp[x] + (int)prvpnn[x])
254 - 0.026 * ((int)srcp3p[x] + (
int)srcp3n[x])
255 + 0.031 * ((
int)prvp4p[x] + (int)prvp4p[x]);
257 dstp[x] = av_clip(valf, lo, hi);
260 val = (8 * ((int)srcpp[x] + (
int)srcpn[x]) + 2 * ((
int)srcp[x] + (int)prvp[x])
261 - (int)(srcppp[x]) - (int)(srcpnn[x])
262 - (int)(prvppp[x]) - (int)(prvpnn[x])) >> 4;
264 val = (8 * ((int)srcpp[x] + (
int)srcpn[x]) + 2 * ((
int)prvp[x])
265 - (
int)(prvppp[x]) - (
int)(prvpnn[x])) >> 4;
267 dstp[x] = av_clip(val, lo, hi);
274 prvp += 2 * psrc_linesize;
275 prvpp += 2 * psrc_linesize;
276 prvppp += 2 * psrc_linesize;
277 prvpn += 2 * psrc_linesize;
278 prvpnn += 2 * psrc_linesize;
279 prvp4p += 2 * psrc_linesize;
280 prvp4n += 2 * psrc_linesize;
281 srcp += 2 * src_linesize;
282 srcpp += 2 * src_linesize;
283 srcppp += 2 * src_linesize;
284 srcp3p += 2 * src_linesize;
285 srcp4p += 2 * src_linesize;
286 srcpn += 2 * src_linesize;
287 srcpnn += 2 * src_linesize;
288 srcp3n += 2 * src_linesize;
289 srcp4n += 2 * src_linesize;
290 dstp += 2 * dst_linesize;
293 srcp = inpic->
data[plane];
329 .
inputs = kerndeint_inputs,
332 .priv_class = &kerndeint_class,