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)];\
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,
static const AVFilterPad mcdeint_inputs[]
void av_free_packet(AVPacket *pkt)
Free a packet.
This structure describes decoded (raw) audio or video data.
AVCodec * avcodec_find_encoder(enum AVCodecID id)
Find a registered encoder with a matching codec ID.
static const AVFilterPad outputs[]
Main libavfilter public API header.
AVFrame * coded_frame
the picture in the bitstream
int max_b_frames
maximum number of B-frames between non-B-frames Note: The output will be delayed by max_b_frames+1 re...
int h
agreed upon image height
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
AVFrame * ff_get_video_buffer(AVFilterLink *link, int w, int h)
Request a picture buffer with a specific set of permissions.
#define CODEC_FLAG_QPEL
Use qpel MC.
AVRational time_base
This is the fundamental unit of time (in seconds) in terms of which frame timestamps are represented...
BYTE int const BYTE * srcp
const char * name
Pad name.
#define GET_SCORE_EDGE(j)
static av_cold int end(AVCodecContext *avctx)
int me_cmp
motion estimation comparison function
int avcodec_encode_video2(AVCodecContext *avctx, AVPacket *avpkt, const AVFrame *frame, int *got_packet_ptr)
Encode a frame of video.
static const AVFilterPad mcdeint_outputs[]
AVFILTER_DEFINE_CLASS(mcdeint)
#define CONST(name, help, val, unit)
A filter pad used for either input or output.
A link between two filters.
int avcodec_close(AVCodecContext *avctx)
Close a given AVCodecContext and free all the data associated with it (but not the AVCodecContext its...
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
return ff_filter_frame(outlink, outpic)
static int config_props(AVFilterLink *inlink)
int me_sub_cmp
subpixel motion estimation comparison function
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
void * priv
private data for use by the filter
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values. ...
#define CODEC_FLAG_QSCALE
Use fixed qscale.
Libavcodec external API header.
#define CODEC_FLAG_LOW_DELAY
Force low delay.
int w
agreed upon image width
static av_cold void uninit(AVFilterContext *ctx)
int refs
number of reference frames
#define FF_COMPLIANCE_EXPERIMENTAL
Allow nonstandardized experimental things.
AVCodecContext * avcodec_alloc_context3(const AVCodec *codec)
Allocate an AVCodecContext and set its fields to default values.
int width
picture width / height.
#define FF_CEIL_RSHIFT(a, b)
static const AVOption mcdeint_options[]
int quality
quality (between 1 (good) and FF_LAMBDA_MAX (bad))
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
main external API structure.
static int query_formats(AVFilterContext *ctx)
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
Describe the class of an AVClass context structure.
static const AVFilterPad inputs[]
rational number numerator/denominator
const char * name
Filter name.
int avcodec_open2(AVCodecContext *avctx, const AVCodec *codec, AVDictionary **options)
Initialize the AVCodecContext to use the given AVCodec.
AVFilterLink ** outputs
array of pointers to output links
int global_quality
Global quality for codecs which cannot change it per frame.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
int gop_size
the number of pictures in a group of pictures, or 0 for intra_only
int mb_cmp
macroblock comparison function (not supported yet)
planar YUV 4:2:0, 12bpp, (1 Cr & Cb sample per 2x2 Y samples)
void av_init_packet(AVPacket *pkt)
Initialize optional fields of a packet with default values.
int dia_size
ME diamond size & shape.
AVFilterContext * dst
dest filter
#define FF_QP2LAMBDA
factor to convert from H.263 QP to lambda
static int filter_frame(AVFilterLink *inlink, AVFrame *inpic)
int me_method
Motion estimation algorithm used for video coding.
#define CODEC_FLAG_4MV
4 MV per MB allowed / advanced prediction for H.263.
AVPixelFormat
Pixel format.
This structure stores compressed data.
int strict_std_compliance
strictly follow the standard (MPEG4, ...).
int av_frame_copy_props(AVFrame *dst, const AVFrame *src)
Copy only "metadata" fields from src to dst.