Go to the documentation of this file.
28 #ifndef AVCODEC_MPEGVIDEO_H
29 #define AVCODEC_MPEGVIDEO_H
52 #if FF_API_FLAG_TRUNCATED
64 #define MAX_THREADS 32
66 #define MAX_B_FRAMES 16
251 #define MV_DIR_FORWARD 1
252 #define MV_DIR_BACKWARD 2
255 #define MV_TYPE_16X16 0
256 #define MV_TYPE_8X8 1
257 #define MV_TYPE_16X8 2
258 #define MV_TYPE_FIELD 3
259 #define MV_TYPE_DMV 4
307 #define UNI_AC_ENC_INDEX(run,level) ((run)*128 + (level))
351 #if FF_API_FLAG_TRUNCATED
467 #define VIDEO_FORMAT_COMPONENT 0
468 #define VIDEO_FORMAT_PAL 1
469 #define VIDEO_FORMAT_NTSC 2
470 #define VIDEO_FORMAT_SECAM 3
471 #define VIDEO_FORMAT_MAC 4
472 #define VIDEO_FORMAT_UNSPECIFIED 5
510 #define SLICE_ERROR -1
512 #define SLICE_NOEND -3
581 #define FF_MPV_FLAG_SKIP_RD 0x0001
582 #define FF_MPV_FLAG_STRICT_GOP 0x0002
583 #define FF_MPV_FLAG_QP_RD 0x0004
584 #define FF_MPV_FLAG_CBP_RD 0x0008
585 #define FF_MPV_FLAG_NAQ 0x0010
586 #define FF_MPV_FLAG_MV0 0x0020
588 #define FF_MPV_OPT_CMP_FUNC \
589 { "sad", "Sum of absolute differences, fast", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_SAD }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
590 { "sse", "Sum of squared errors", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_SSE }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
591 { "satd", "Sum of absolute Hadamard transformed differences", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_SATD }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
592 { "dct", "Sum of absolute DCT transformed differences", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_DCT }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
593 { "psnr", "Sum of squared quantization errors, low quality", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_PSNR }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
594 { "bit", "Number of bits needed for the block", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_BIT }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
595 { "rd", "Rate distortion optimal, slow", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_RD }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
596 { "zero", "Zero", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_ZERO }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
597 { "vsad", "Sum of absolute vertical differences", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_VSAD }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
598 { "vsse", "Sum of squared vertical differences", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_VSSE }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
599 { "nsse", "Noise preserving sum of squared differences", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_NSSE }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
600 { "dct264", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_DCT264 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
601 { "dctmax", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_DCTMAX }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
602 { "chroma", NULL, 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_CHROMA }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
603 { "msad", "Sum of absolute differences, median predicted", 0, AV_OPT_TYPE_CONST, {.i64 = FF_CMP_MEDIAN_SAD }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }
605 #ifndef FF_MPV_OFFSET
606 #define FF_MPV_OFFSET(x) offsetof(MpegEncContext, x)
608 #define FF_MPV_OPT_FLAGS (AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM)
609 #define FF_MPV_COMMON_OPTS \
610 FF_MPV_OPT_CMP_FUNC, \
611 { "mpv_flags", "Flags common for all mpegvideo-based encoders.", FF_MPV_OFFSET(mpv_flags), AV_OPT_TYPE_FLAGS, { .i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "mpv_flags" },\
612 { "skip_rd", "RD optimal MB level residual skipping", 0, AV_OPT_TYPE_CONST, { .i64 = FF_MPV_FLAG_SKIP_RD }, 0, 0, FF_MPV_OPT_FLAGS, "mpv_flags" },\
613 { "strict_gop", "Strictly enforce gop size", 0, AV_OPT_TYPE_CONST, { .i64 = FF_MPV_FLAG_STRICT_GOP }, 0, 0, FF_MPV_OPT_FLAGS, "mpv_flags" },\
614 { "qp_rd", "Use rate distortion optimization for qp selection", 0, AV_OPT_TYPE_CONST, { .i64 = FF_MPV_FLAG_QP_RD }, 0, 0, FF_MPV_OPT_FLAGS, "mpv_flags" },\
615 { "cbp_rd", "use rate distortion optimization for CBP", 0, AV_OPT_TYPE_CONST, { .i64 = FF_MPV_FLAG_CBP_RD }, 0, 0, FF_MPV_OPT_FLAGS, "mpv_flags" },\
616 { "naq", "normalize adaptive quantization", 0, AV_OPT_TYPE_CONST, { .i64 = FF_MPV_FLAG_NAQ }, 0, 0, FF_MPV_OPT_FLAGS, "mpv_flags" },\
617 { "mv0", "always try a mb with mv=<0,0>", 0, AV_OPT_TYPE_CONST, { .i64 = FF_MPV_FLAG_MV0 }, 0, 0, FF_MPV_OPT_FLAGS, "mpv_flags" },\
618 { "luma_elim_threshold", "single coefficient elimination threshold for luminance (negative values also consider dc coefficient)",\
619 FF_MPV_OFFSET(luma_elim_threshold), AV_OPT_TYPE_INT, { .i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS },\
620 { "chroma_elim_threshold", "single coefficient elimination threshold for chrominance (negative values also consider dc coefficient)",\
621 FF_MPV_OFFSET(chroma_elim_threshold), AV_OPT_TYPE_INT, { .i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS },\
622 { "quantizer_noise_shaping", NULL, FF_MPV_OFFSET(quantizer_noise_shaping), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, INT_MAX, FF_MPV_OPT_FLAGS },\
623 { "error_rate", "Simulate errors in the bitstream to test error concealment.", \
624 FF_MPV_OFFSET(error_rate), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, INT_MAX, FF_MPV_OPT_FLAGS },\
625 {"qsquish", "how to keep quantizer between qmin and qmax (0 = clip, 1 = use differentiable function)", \
626 FF_MPV_OFFSET(rc_qsquish), AV_OPT_TYPE_FLOAT, {.dbl = 0 }, 0, 99, FF_MPV_OPT_FLAGS}, \
627 {"rc_qmod_amp", "experimental quantizer modulation", FF_MPV_OFFSET(rc_qmod_amp), AV_OPT_TYPE_FLOAT, {.dbl = 0 }, -FLT_MAX, FLT_MAX, FF_MPV_OPT_FLAGS}, \
628 {"rc_qmod_freq", "experimental quantizer modulation", FF_MPV_OFFSET(rc_qmod_freq), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS}, \
629 {"rc_eq", "Set rate control equation. When computing the expression, besides the standard functions " \
630 "defined in the section 'Expression Evaluation', the following functions are available: " \
631 "bits2qp(bits), qp2bits(qp). Also the following constants are available: iTex pTex tex mv " \
632 "fCode iCount mcVar var isI isP isB avgQP qComp avgIITex avgPITex avgPPTex avgBPTex avgTex.", \
633 FF_MPV_OFFSET(rc_eq), AV_OPT_TYPE_STRING, .flags = FF_MPV_OPT_FLAGS }, \
634 {"rc_init_cplx", "initial complexity for 1-pass encoding", FF_MPV_OFFSET(rc_initial_cplx), AV_OPT_TYPE_FLOAT, {.dbl = 0 }, -FLT_MAX, FLT_MAX, FF_MPV_OPT_FLAGS}, \
635 {"rc_buf_aggressivity", "currently useless", FF_MPV_OFFSET(rc_buffer_aggressivity), AV_OPT_TYPE_FLOAT, {.dbl = 1.0 }, -FLT_MAX, FLT_MAX, FF_MPV_OPT_FLAGS}, \
636 {"border_mask", "increase the quantizer for macroblocks close to borders", FF_MPV_OFFSET(border_masking), AV_OPT_TYPE_FLOAT, {.dbl = 0 }, -FLT_MAX, FLT_MAX, FF_MPV_OPT_FLAGS}, \
637 {"lmin", "minimum Lagrange factor (VBR)", FF_MPV_OFFSET(lmin), AV_OPT_TYPE_INT, {.i64 = 2*FF_QP2LAMBDA }, 0, INT_MAX, FF_MPV_OPT_FLAGS }, \
638 {"lmax", "maximum Lagrange factor (VBR)", FF_MPV_OFFSET(lmax), AV_OPT_TYPE_INT, {.i64 = 31*FF_QP2LAMBDA }, 0, INT_MAX, FF_MPV_OPT_FLAGS }, \
639 {"ibias", "intra quant bias", FF_MPV_OFFSET(intra_quant_bias), AV_OPT_TYPE_INT, {.i64 = FF_DEFAULT_QUANT_BIAS }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
640 {"pbias", "inter quant bias", FF_MPV_OFFSET(inter_quant_bias), AV_OPT_TYPE_INT, {.i64 = FF_DEFAULT_QUANT_BIAS }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
641 {"motion_est", "motion estimation algorithm", FF_MPV_OFFSET(motion_est), AV_OPT_TYPE_INT, {.i64 = FF_ME_EPZS }, FF_ME_ZERO, FF_ME_XONE, FF_MPV_OPT_FLAGS, "motion_est" }, \
642 { "zero", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = FF_ME_ZERO }, 0, 0, FF_MPV_OPT_FLAGS, "motion_est" }, \
643 { "epzs", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = FF_ME_EPZS }, 0, 0, FF_MPV_OPT_FLAGS, "motion_est" }, \
644 { "xone", NULL, 0, AV_OPT_TYPE_CONST, { .i64 = FF_ME_XONE }, 0, 0, FF_MPV_OPT_FLAGS, "motion_est" }, \
645 {"skip_threshold", "Frame skip threshold", FF_MPV_OFFSET(frame_skip_threshold), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
646 {"skip_factor", "Frame skip factor", FF_MPV_OFFSET(frame_skip_factor), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
647 {"skip_exp", "Frame skip exponent", FF_MPV_OFFSET(frame_skip_exp), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
648 {"skip_cmp", "Frame skip compare function", FF_MPV_OFFSET(frame_skip_cmp), AV_OPT_TYPE_INT, {.i64 = FF_CMP_DCTMAX }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS, "cmp_func" }, \
649 {"sc_threshold", "Scene change threshold", FF_MPV_OFFSET(scenechange_threshold), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
650 {"noise_reduction", "Noise reduction", FF_MPV_OFFSET(noise_reduction), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
651 {"ps", "RTP payload size in bytes", FF_MPV_OFFSET(rtp_payload_size), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
652 {"mepc", "Motion estimation bitrate penalty compensation (1.0 = 256)", FF_MPV_OFFSET(me_penalty_compensation), AV_OPT_TYPE_INT, {.i64 = 256 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
653 {"mepre", "pre motion estimation", FF_MPV_OFFSET(me_pre), AV_OPT_TYPE_INT, {.i64 = 0 }, INT_MIN, INT_MAX, FF_MPV_OPT_FLAGS }, \
654 {"intra_penalty", "Penalty for intra blocks in block decision", FF_MPV_OFFSET(intra_penalty), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, INT_MAX/2, FF_MPV_OPT_FLAGS }, \
656 #define FF_MPV_COMMON_BFRAME_OPTS \
657 {"b_strategy", "Strategy to choose between I/P/B-frames", FF_MPV_OFFSET(b_frame_strategy), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, 2, FF_MPV_OPT_FLAGS }, \
658 {"b_sensitivity", "Adjust sensitivity of b_frame_strategy 1", FF_MPV_OFFSET(b_sensitivity), AV_OPT_TYPE_INT, {.i64 = 40 }, 1, INT_MAX, FF_MPV_OPT_FLAGS }, \
659 {"brd_scale", "Downscale frames for dynamic B-frame decision", FF_MPV_OFFSET(brd_scale), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, 3, FF_MPV_OPT_FLAGS },
661 #if FF_API_MPEGVIDEO_OPTS
662 #define FF_MPV_DEPRECATED_MPEG_QUANT_OPT \
663 { "mpeg_quant", "Deprecated, does nothing", FF_MPV_OFFSET(mpeg_quant), AV_OPT_TYPE_INT, {.i64 = 0 }, 0, 0, FF_MPV_OPT_FLAGS | AV_OPT_FLAG_DEPRECATED },
664 #define FF_MPV_DEPRECATED_A53_CC_OPT \
665 { "a53cc", "Deprecated, does nothing", FF_MPV_OFFSET(a53_cc), AV_OPT_TYPE_BOOL, { .i64 = 1 }, 0, 1, FF_MPV_OPT_FLAGS | AV_OPT_FLAG_DEPRECATED },
666 #define FF_MPV_DEPRECATED_MATRIX_OPT \
667 { "force_duplicated_matrix", "Deprecated, does nothing", FF_MPV_OFFSET(force_duplicated_matrix), AV_OPT_TYPE_BOOL, {.i64 = 0 }, 0, 1, FF_MPV_OPT_FLAGS | AV_OPT_FLAG_DEPRECATED },
668 #define FF_MPV_DEPRECATED_BFRAME_OPTS \
669 { "b_strategy", "Deprecated, does nothing", FF_MPV_OFFSET(b_frame_strategy), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 2, FF_MPV_OPT_FLAGS | AV_OPT_FLAG_DEPRECATED }, \
670 { "b_sensitivity", "Deprecated, does nothing", FF_MPV_OFFSET(b_sensitivity), AV_OPT_TYPE_INT, { .i64 = 40 }, 1, INT_MAX, FF_MPV_OPT_FLAGS | AV_OPT_FLAG_DEPRECATED }, \
671 { "brd_scale", "Deprecated, does nothing", FF_MPV_OFFSET(brd_scale), AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 3, FF_MPV_OPT_FLAGS | AV_OPT_FLAG_DEPRECATED },
728 const uint16_t *quant_matrix,
int bias,
int qmin,
int qmax,
int intra);
731 const uint8_t *scantable,
int last);
735 uint8_t *dest_y, uint8_t *dest_cb,
736 uint8_t *dest_cr,
int dir,
737 uint8_t **ref_picture,
742 const int bytes_per_pixel = 1 + (
s->avctx->bits_per_raw_sample > 8);
743 const int block_size= (8*bytes_per_pixel) >>
s->avctx->lowres;
745 s->block_index[0]+=2;
746 s->block_index[1]+=2;
747 s->block_index[2]+=2;
748 s->block_index[3]+=2;
751 s->dest[0]+= 2*block_size;
752 s->dest[1]+= (2 >>
s->chroma_x_shift) * block_size;
753 s->dest[2]+= (2 >>
s->chroma_x_shift) * block_size;
758 const int last=
s->last_bits;
H264ChromaContext h264chroma
Picture * picture
main picture buffer
int mb_skipped
MUST BE SET only during DECODING.
uint16_t * mb_type
Table for candidate MB types for encoding (defines in mpegutils.h)
int h263_flv
use flv H.263 header
uint16_t(* q_intra_matrix16)[2][64]
identical to the above but for MMX & these are not permutated, second 64 entries are bias
void ff_mpeg_flush(AVCodecContext *avctx)
uint8_t *[2][2] b_field_select_table
Only the first element is allocated.
int data_partitioning
data partitioning flag from header
int stuffing_bits
bits used for stuffing
int ff_mpeg_update_thread_context(AVCodecContext *dst, const AVCodecContext *src)
void(* dct_unquantize_mpeg1_intra)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
unsigned int lambda
Lagrange multiplier used in rate distortion.
int scan_offset
reserve space for SVCD scan offset user data.
int quantizer_noise_shaping
int b_code
backward MV resolution for B-frames (MPEG-4)
int ff_mpv_export_qp_table(MpegEncContext *s, AVFrame *f, Picture *p, int qp_type)
int input_picture_number
used to set pic->display_picture_number, should not be used for/by anything else
void(* dct_unquantize_h263_inter)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
uint16_t pp_time
time distance between the last 2 p,s,i frames
RateControlContext rc_context
contains stuff only accessed in ratecontrol.c
int intra_quant_bias
bias for the quantizer
int max_b_frames
max number of B-frames for encoding
int block_index[6]
index to current MB in block based arrays with edges
static int mpeg_get_qscale(MpegEncContext *s)
int force_duplicated_matrix
Force duplication of mjpeg matrices, useful for rtp streaming.
Motion estimation context.
int coded_picture_number
used to set pic->coded_picture_number, should not be used for/by anything else
void ff_block_permute(int16_t *block, uint8_t *permutation, const uint8_t *scantable, int last)
Permute an 8x8 block according to permutation.
int slice_height
in macroblocks
Picture current_picture
copy of the current picture structure.
int partitioned_frame
is current frame partitioned
AVTimecode tc
timecode context
uint16_t(* dct_offset)[64]
This structure describes decoded (raw) audio or video data.
int mb_num
number of MBs of a picture
int16_t(* ac_val_base)[16]
void(* dct_unquantize_mpeg2_intra)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
int workaround_bugs
workaround bugs in encoders which cannot be detected automatically
int64_t reordered_pts
reordered pts to be used as dts for the next output frame when there's a delay
int inter_quant_bias
bias for the quantizer
int drop_frame_timecode
timecode is in drop frame format.
const uint8_t * fcode_tab
smallest fcode needed for each MV
Picture next_picture
copy of the next picture structure.
int last_dc[3]
last DC values for MPEG-1
uint8_t * intra_chroma_ac_vlc_length
int chroma_qscale
chroma QP
Picture ** input_picture
next pictures on display order for encoding
const uint8_t ff_mpeg2_non_linear_qscale[32]
int16_t(*[3] ac_val)[16]
used for MPEG-4 AC prediction, all 3 arrays must be continuous
int unrestricted_mv
mv can point outside of the coded picture
struct AVCodecContext * avctx
int(* ac_stats)[2][MAX_LEVEL+1][MAX_RUN+1][2]
[mb_intra][isChroma][level][run][last]
Picture * next_picture_ptr
pointer to the next picture (for bidir pred)
PutBitContext pb
bit output
int mb_num_left
number of MBs left in this video packet (for partitioned Slices only)
int height
picture size. must be a multiple of 16
int(* fast_dct_quantize)(struct MpegEncContext *s, int16_t *block, int n, int qscale, int *overflow)
int64_t dts_delta
pts difference between the first and second input frame, used for calculating dts of the first frame ...
void(* dct_unquantize_h263_intra)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
GetBitContext last_resync_gb
used to search for the next resync marker
int mv[2][4][2]
motion vectors for a macroblock first coordinate : 0 = forward 1 = backward second " : depend...
enum OutputFormat out_format
output format
int time_base
time in seconds of last I,P,S Frame
ScanTable intra_scantable
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
int mb_height
number of MBs horizontally & vertically
int pict_type
AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B, ...
int h263_pred
use MPEG-4/H.263 ac/dc predictions
uint8_t * mbintra_table
used to avoid setting {ac, dc, cbp}-pred stuff to zero on inter MB decoding
int mpv_flags
flags set by private options
int intra_only
if true, only intra pictures are generated
int padding_bug_score
used to detect the VERY common padding bug in MPEG-4
void ff_convert_matrix(MpegEncContext *s, int(*qmat)[64], uint16_t(*qmat16)[2][64], const uint16_t *quant_matrix, int bias, int qmin, int qmax, int intra)
ptrdiff_t linesize
line size, in bytes, may be different from width
int umvplus
== H.263+ && unrestricted_mv
void ff_mpv_common_init_x86(MpegEncContext *s)
int16_t(* b_bidir_forw_mv_table_base)[2]
void ff_mpv_idct_init(MpegEncContext *s)
int(* q_intra_matrix)[64]
precomputed matrix (combine qscale and DCT renorm)
int16_t(*[12] pblocks)[64]
int pb_frame
PB-frame mode (0 = none, 1 = base, 2 = improved)
void ff_set_qscale(MpegEncContext *s, int qscale)
set qscale and update qscale dependent variables.
uint8_t * coded_block
used for coded block pattern prediction (msmpeg4v3, wmv1)
MpegvideoEncDSPContext mpvencdsp
int ff_mpv_encode_init(AVCodecContext *avctx)
char * tc_opt_str
timecode option string
int me_penalty_compensation
int16_t(* b_back_mv_table)[2]
MV table (1MV per MB) backward mode B-frame encoding.
void ff_mpv_common_defaults(MpegEncContext *s)
Set the given MpegEncContext to common defaults (same for encoding and decoding).
int64_t bit_rate
wanted bit rate
int16_t(* p_field_mv_table_base)[2]
int ff_mpv_encode_picture(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *frame, int *got_packet)
int max_qcoeff
maximum encodable coefficient
int64_t user_specified_pts
last non-zero pts from AVFrame which was passed into avcodec_send_frame()
int sprite_delta[2][2]
sprite_delta [isY][isMVY]
int frame_bits
bits used for the current frame
void(* denoise_dct)(struct MpegEncContext *s, int16_t *block)
uint8_t * inter_ac_vlc_length
int(* dct_quantize)(struct MpegEncContext *s, int16_t *block, int n, int qscale, int *overflow)
int mb_stride
mb_width+1 used for some arrays to allow simple addressing of left & top MBs without sig11
int bitstream_buffer_size
int low_delay
no reordering needed / has no B-frames
int16_t(* b_direct_mv_table)[2]
MV table (1MV per MB) direct mode B-frame encoding.
void ff_mpv_frame_end(MpegEncContext *s)
uint8_t * inter_ac_vlc_last_length
void ff_mpv_reconstruct_mb(MpegEncContext *s, int16_t block[12][64])
PutBitContext pb2
used for data partitioned VOPs
Describe the class of an AVClass context structure.
void ff_mpv_common_end(MpegEncContext *s)
int h263_long_vectors
use horrible H.263v1 long vector mode
int f_code
forward MV resolution
int h263_aic
Advanced INTRA Coding (AIC)
ParseContext parse_context
Rational number (pair of numerator and denominator).
uint8_t * intra_chroma_ac_vlc_last_length
int16_t(* p_mv_table)[2]
MV table (1MV per MB) P-frame encoding.
int ff_dct_quantize_c(MpegEncContext *s, int16_t *block, int n, int qscale, int *overflow)
const uint8_t * y_dc_scale_table
qscale -> y_dc_scale table
uint16_t inter_matrix[64]
int(* decode_mb)(struct MpegEncContext *s, int16_t block[12][64])
int concealment_motion_vectors
float rc_buffer_aggressivity
int ff_update_duplicate_context(MpegEncContext *dst, MpegEncContext *src)
int b8_stride
2*mb_width+1 used for some 8x8 block arrays to allow simple addressing
int next_p_frame_damaged
set if the next p frame is damaged, to avoid showing trashed B-frames
void(* dct_unquantize_mpeg1_inter)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
Picture * last_picture_ptr
pointer to the previous picture.
int slice_context_count
number of used thread_contexts
int scenechange_threshold
void(* op_pixels_func)(uint8_t *block, const uint8_t *pixels, ptrdiff_t line_size, int h)
int16_t(* b_field_mv_table_base)[2]
uint16_t pb_time
time distance between the last b and p,s,i frame
uint16_t(* q_inter_matrix16)[2][64]
void(* qpel_mc_func)(uint8_t *dst, const uint8_t *src, ptrdiff_t stride)
int16_t(* blocks)[12][64]
AVCodecID
Identify the syntax and semantics of the bitstream.
int16_t(* b_bidir_forw_mv_table)[2]
MV table (1MV per MB) bidir mode B-frame encoding.
int strict_std_compliance
strictly follow the std (MPEG-4, ...)
uint16_t pb_field_time
like above, just for interlaced
uint8_t * coded_block_base
int me_pre
prepass for motion estimation
int64_t timecode_frame_start
GOP timecode frame start number, in non drop frame format.
uint16_t(* q_chroma_intra_matrix16)[2][64]
int min_qcoeff
minimum encodable coefficient
const uint8_t * chroma_qscale_table
qscale -> chroma_qscale (H.263)
void ff_mpv_common_init_axp(MpegEncContext *s)
int first_slice_line
used in MPEG-4 too to handle resync markers
uint16_t intra_matrix[64]
matrix transmitted in the bitstream
unsigned int lambda2
(lambda*lambda) >> FF_LAMBDA_SHIFT
int adaptive_quant
use adaptive quantization
int v_edge_pos
horizontal / vertical position of the right/bottom edge (pixel replication)
void ff_mpv_motion(MpegEncContext *s, uint8_t *dest_y, uint8_t *dest_cb, uint8_t *dest_cr, int dir, uint8_t **ref_picture, op_pixels_func(*pix_op)[4], qpel_mc_func(*qpix_op)[16])
AVFrame * tmp_frames[MAX_B_FRAMES+2]
int16_t(* b_forw_mv_table)[2]
MV table (1MV per MB) forward mode B-frame encoding.
int sprite_warping_accuracy
ScanTable intra_h_scantable
int encoding
true if we are encoding (vs decoding)
uint8_t * mbskip_table
used to avoid copy if macroblock skipped (for black regions for example) and used for B-frame encodin...
int16_t * dc_val[3]
used for MPEG-4 DC prediction, all 3 arrays must be continuous
int quarter_sample
1->qpel, 0->half pel ME/MC
int16_t(* p_mv_table_base)[2]
int dct_precision
number of bits to represent the fractional part of time (encoder only)
int(* q_chroma_intra_matrix)[64]
int16_t(* b_direct_mv_table_base)[2]
int rl_chroma_table_index
int picture_in_gop_number
0-> first pic in gop, ...
uint8_t *[2] p_field_select_table
Only the first element is allocated.
uint8_t * intra_ac_vlc_last_length
int ff_mpv_common_init(MpegEncContext *s)
init common structure for both encoder and decoder.
void ff_init_block_index(MpegEncContext *s)
static void ff_update_block_index(MpegEncContext *s)
void ff_mpeg_draw_horiz_band(MpegEncContext *s, int y, int h)
int block_last_index[12]
last non zero coefficient in block
int real_sprite_warping_points
int chroma_elim_threshold
Picture * current_picture_ptr
pointer to the current picture
int last_mv[2][2][2]
last MV, used for MV prediction in MPEG-1 & B-frame MPEG-4
ptrdiff_t uvlinesize
line size, for chroma in bytes, may be different from width
void ff_dct_encode_init_x86(MpegEncContext *s)
unsigned int allocated_bitstream_buffer_size
uint16_t chroma_inter_matrix[64]
void ff_print_debug_info(MpegEncContext *s, Picture *p, AVFrame *pict)
static int put_bits_count(PutBitContext *s)
struct MJpegContext * mjpeg_ctx
int ff_mpv_reallocate_putbitbuffer(MpegEncContext *s, size_t threshold, size_t size_increase)
int obmc
overlapped block motion compensation
void ff_mpv_common_init_neon(MpegEncContext *s)
PutBitContext tex_pb
used for data partitioned VOPs
static const int32_t qmat16[MAT_SIZE]
void ff_mpv_common_init_ppc(MpegEncContext *s)
int ff_mpv_encode_end(AVCodecContext *avctx)
struct MpegEncContext * thread_context[MAX_THREADS]
int16_t(* b_bidir_back_mv_table)[2]
MV table (1MV per MB) bidir mode B-frame encoding.
int ff_mpv_frame_start(MpegEncContext *s, AVCodecContext *avctx)
generic function called after decoding the header and before a frame is decoded.
int skipdct
skip dct and code zero residual
int last_lambda_for[5]
last lambda for a specific pict type
uint8_t * vbv_delay_ptr
pointer to vbv_delay in the bitstream
int16_t(* b_forw_mv_table_base)[2]
void(* dct_unquantize_inter)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
void ff_mpv_encode_init_x86(MpegEncContext *s)
int motion_est
ME algorithm.
int h263_slice_structured
void ff_clean_intra_table_entries(MpegEncContext *s)
Clean dc, ac, coded_block for the current non-intra MB.
int fixed_qscale
fixed qscale if non zero
static int get_bits_diff(MpegEncContext *s)
int last_non_b_pict_type
used for MPEG-4 gmc B-frames & ratecontrol
int32_t(* block32)[12][64]
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
int sprite_offset[2][2]
sprite offset[isChroma][isMVY]
int rv10_version
RV10 version: 0 or 3.
void ff_mpv_common_init_mips(MpegEncContext *s)
int16_t(*[2][2] p_field_mv_table)[2]
MV table (2MV per MB) interlaced P-frame encoding.
int16_t(* block)[64]
points to one of the following blocks
int dquant
qscale difference to prev qscale
int ff_dct_encode_init(MpegEncContext *s)
main external API structure.
void ff_mpv_decode_init(MpegEncContext *s, AVCodecContext *avctx)
Initialize the given MpegEncContext for decoding.
int ac_esc_length
num of bits needed to encode the longest esc
int last_bits
temp var used for calculating the above vars
int16_t(* dpcm_macroblock)[3][256]
int gop_picture_number
index of the first picture of a GOP based on fake_pic_num & MPEG-1 specific
int rv10_first_dc_coded[3]
int64_t time
time of current frame
Holds JPEG frame data and Huffman table data.
Picture last_picture
copy of the previous picture structure.
uint8_t * pred_dir_table
used to store pred_dir for partitioned decoding
void(* dct_unquantize_intra)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
int resync_mb_x
x position of last resync marker
AVRational mpeg2_frame_rate_ext
int no_rounding
apply no rounding to motion compensation (MPEG-4, msmpeg4, ...) for B-frames rounding mode is always ...
int h263_aic_dir
AIC direction: 0 = left, 1 = top.
void(* dct_unquantize_mpeg2_inter)(struct MpegEncContext *s, int16_t *block, int n, int qscale)
Undefined Behavior In the C some operations are like signed integer overflow
ScanTable inter_scantable
if inter == intra then intra should be used to reduce the cache usage
uint8_t * luma_dc_vlc_length
uint8_t * cbp_table
used to store cbp, ac_pred for partitioned decoding
void ff_mpv_common_init_arm(MpegEncContext *s)
int first_field
is 1 for the first field of a field picture 0 otherwise
Picture new_picture
copy of the source picture structure for encoding.
This structure stores compressed data.
int ff_mpv_common_frame_size_change(MpegEncContext *s)
int last_mv_dir
last mv_dir, used for B-frame encoding
int(* q_inter_matrix)[64]
int mb_info
interval for outputting info about mb offsets as side data
int next_lambda
next lambda used for retrying to encode a frame
Picture ** reordered_input_picture
pointer to the next pictures in coded order for encoding
int msmpeg4_version
0=not msmpeg4, 1=mp41, 2=mp42, 3=mp43/divx3 4=wmv1/7 5=wmv2/8
void ff_write_quant_matrix(PutBitContext *pb, uint16_t *matrix)
The exact code depends on how similar the blocks are and how related they are to the block
const AVClass ff_mpv_enc_class
int misc_bits
cbp, mb_type
int resync_mb_y
y position of last resync marker
int end_mb_y
end mb_y of this thread (so current thread should process start_mb_y <= row < end_mb_y)
int * mb_index2xy
mb_index -> mb_x + mb_y*mb_stride
float rc_qsquish
ratecontrol qmin qmax limiting method 0-> clipping, 1-> use a nice continuous function to limit qscal...
int h263_plus
H.263+ headers.
int start_mb_y
start mb_y of this thread (so current thread should process start_mb_y <= row < end_mb_y)
int16_t(* b_back_mv_table_base)[2]
int16_t direct_scale_mv[2][64]
precomputed to avoid divisions in ff_mpeg4_set_direct_mv
const uint8_t * c_dc_scale_table
qscale -> c_dc_scale table
uint8_t * bitstream_buffer
int16_t(* b_bidir_back_mv_table_base)[2]
int alt_inter_vlc
alternative inter vlc
uint8_t * intra_ac_vlc_length
void ff_mpv_report_decode_progress(MpegEncContext *s)
int16_t(*[2][2][2] b_field_mv_table)[2]
MV table (4MV per MB) interlaced B-frame encoding.
ScanTable intra_v_scantable
uint16_t chroma_intra_matrix[64]
int codec_tag
internal codec_tag upper case converted from avctx codec_tag