50 #define OFFSET(x) offsetof(KerndeintContext, x)
51 #define FLAGS AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
87 kerndeint->
vsub =
desc->log2_chroma_h;
107 const uint8_t *prvpp;
108 const uint8_t *prvpn;
109 const uint8_t *prvppp;
110 const uint8_t *prvpnn;
111 const uint8_t *prvp4p;
112 const uint8_t *prvp4n;
115 const uint8_t *srcpp;
116 const uint8_t *srcpn;
117 const uint8_t *srcppp;
118 const uint8_t *srcpnn;
119 const uint8_t *srcp3p;
120 const uint8_t *srcp3n;
121 const uint8_t *srcp4p;
122 const uint8_t *srcp4n;
124 uint8_t *dstp, *dstp_saved;
125 const uint8_t *srcp_saved;
127 int src_linesize, psrc_linesize, dst_linesize, bwidth;
128 int x, y, plane,
val, hi, lo,
g,
h, n = kerndeint->
frame++;
131 const int thresh = kerndeint->
thresh;
132 const int order = kerndeint->
order;
133 const int map = kerndeint->
map;
134 const int sharp = kerndeint->
sharp;
135 const int twoway = kerndeint->
twoway;
147 for (plane = 0; plane < 4 &&
inpic->data[plane] &&
inpic->linesize[plane]; plane++) {
151 srcp_saved =
inpic->data[plane];
152 src_linesize =
inpic->linesize[plane];
154 dstp_saved = outpic->
data[plane];
155 dst_linesize = outpic->
linesize[plane];
156 srcp = srcp_saved + (1 - order) * src_linesize;
157 dstp = dstp_saved + (1 - order) * dst_linesize;
159 for (y = 0; y <
h; y += 2) {
160 memcpy(dstp, srcp, bwidth);
161 srcp += 2 * src_linesize;
162 dstp += 2 * dst_linesize;
166 memcpy(dstp_saved + order * dst_linesize, srcp_saved + (1 - order) * src_linesize, bwidth);
167 memcpy(dstp_saved + (2 + order ) * dst_linesize, srcp_saved + (3 - order) * src_linesize, bwidth);
168 memcpy(dstp_saved + (
h - 2 + order) * dst_linesize, srcp_saved + (
h - 1 - order) * src_linesize, bwidth);
169 memcpy(dstp_saved + (
h - 4 + order) * dst_linesize, srcp_saved + (
h - 3 - order) * src_linesize, bwidth);
173 prvp = kerndeint->
tmp_data[plane] + 5 * psrc_linesize - (1 - order) * psrc_linesize;
174 prvpp = prvp - psrc_linesize;
175 prvppp = prvp - 2 * psrc_linesize;
176 prvp4p = prvp - 4 * psrc_linesize;
177 prvpn = prvp + psrc_linesize;
178 prvpnn = prvp + 2 * psrc_linesize;
179 prvp4n = prvp + 4 * psrc_linesize;
181 srcp = srcp_saved + 5 * src_linesize - (1 - order) * src_linesize;
182 srcpp = srcp - src_linesize;
183 srcppp = srcp - 2 * src_linesize;
184 srcp3p = srcp - 3 * src_linesize;
185 srcp4p = srcp - 4 * src_linesize;
187 srcpn = srcp + src_linesize;
188 srcpnn = srcp + 2 * src_linesize;
189 srcp3n = srcp + 3 * src_linesize;
190 srcp4n = srcp + 4 * src_linesize;
192 dstp = dstp_saved + 5 * dst_linesize - (1 - order) * dst_linesize;
194 for (y = 5 - (1 - order); y <=
h - 5 - (1 - order); y += 2) {
195 for (x = 0; x < bwidth; x++) {
196 if (thresh == 0 || n == 0 ||
197 (
abs((
int)prvp[x] - (int)srcp[x]) > thresh) ||
198 (
abs((
int)prvpp[x] - (int)srcpp[x]) > thresh) ||
199 (
abs((
int)prvpn[x] - (int)srcpn[x]) > thresh)) {
211 dstp[x] = plane == 0 ? 235 : 128;
218 hi = x & 1 ? 240 : 235;
221 hi = plane == 0 ? 235 : 240;
227 valf = + 0.526 * ((int)srcpp[x] + (
int)srcpn[x])
228 + 0.170 * ((
int)srcp[x] + (int)prvp[x])
229 - 0.116 * ((int)srcppp[x] + (
int)srcpnn[x] + (int)prvppp[x] + (
int)prvpnn[x])
230 - 0.026 * ((
int)srcp3p[x] + (int)srcp3n[x])
231 + 0.031 * ((int)srcp4p[x] + (
int)srcp4n[x] + (int)prvp4p[x] + (
int)prvp4n[x]);
233 valf = + 0.526 * ((int)srcpp[x] + (
int)srcpn[x])
234 + 0.170 * ((
int)prvp[x])
235 - 0.116 * ((
int)prvppp[x] + (int)prvpnn[x])
236 - 0.026 * ((int)srcp3p[x] + (
int)srcp3n[x])
237 + 0.031 * ((
int)prvp4p[x] + (int)prvp4p[x]);
239 dstp[x] =
av_clip(valf, lo, hi);
242 val = (8 * ((int)srcpp[x] + (
int)srcpn[x]) + 2 * ((
int)srcp[x] + (int)prvp[x])
243 - (int)(srcppp[x]) - (int)(srcpnn[x])
244 - (int)(prvppp[x]) - (int)(prvpnn[x])) >> 4;
246 val = (8 * ((int)srcpp[x] + (
int)srcpn[x]) + 2 * ((
int)prvp[x])
247 - (
int)(prvppp[x]) - (
int)(prvpnn[x])) >> 4;
256 prvp += 2 * psrc_linesize;
257 prvpp += 2 * psrc_linesize;
258 prvppp += 2 * psrc_linesize;
259 prvpn += 2 * psrc_linesize;
260 prvpnn += 2 * psrc_linesize;
261 prvp4p += 2 * psrc_linesize;
262 prvp4n += 2 * psrc_linesize;
263 srcp += 2 * src_linesize;
264 srcpp += 2 * src_linesize;
265 srcppp += 2 * src_linesize;
266 srcp3p += 2 * src_linesize;
267 srcp4p += 2 * src_linesize;
268 srcpn += 2 * src_linesize;
269 srcpnn += 2 * src_linesize;
270 srcp3n += 2 * src_linesize;
271 srcp4n += 2 * src_linesize;
272 dstp += 2 * dst_linesize;
275 srcp =
inpic->data[plane];
295 .
p.
name =
"kerndeint",
297 .p.priv_class = &kerndeint_class,