--- trunk/xvidcore/src/encoder.h 2002/09/03 17:25:45 387 +++ branches/dev-api-4/xvidcore/src/encoder.h 2003/05/12 12:33:16 1014 @@ -36,7 +36,7 @@ * support for EXTENDED API * - 22.08.2001 fixed bug in iDQtab * - * $Id: encoder.h,v 1.18 2002-09-03 17:24:26 chl Exp $ + * $Id: encoder.h,v 1.27.2.7 2003-05-12 12:28:31 suxen_drol Exp $ * ****************************************************************************/ @@ -46,40 +46,25 @@ #include "xvid.h" #include "portab.h" #include "global.h" -#include "image/image.h" #include "utils/ratecontrol.h" /***************************************************************************** * Constants ****************************************************************************/ -/* Quatization type */ -#define H263_QUANT 0 -#define MPEG4_QUANT 1 - -/* Indicates no quantizer changes in INTRA_Q/INTER_Q modes */ -#define NO_CHANGE 64 - /***************************************************************************** * Types ****************************************************************************/ typedef int bool; -typedef enum -{ - I_VOP = 0, - P_VOP = 1, - B_VOP = 2 -} -VOP_TYPE; - /***************************************************************************** * Structures ****************************************************************************/ typedef struct { + /* --- constants --- */ uint32_t width; uint32_t height; @@ -88,70 +73,99 @@ uint32_t mb_width; uint32_t mb_height; + int plugin_flags; + /* frame rate increment & base */ uint32_t fincr; uint32_t fbase; + int profile; + + xvid_global_t global_flags; + int bquant_ratio; + int bquant_offset; + int frame_drop_ratio; + + int min_quant[3]; + int max_quant[3]; + #ifdef _SMP int num_threads; #endif -#ifdef BFRAMES + + int iMaxKeyInterval; int max_bframes; -#endif +/* --- inbetween vop stuff --- */ /* rounding type; alternate 0-1 after each interframe */ /* 1 <= fixed_code <= 4 automatically adjusted using motion vector statistics inside */ /* vars that not "quite" frame independant */ - uint32_t m_quant_type; uint32_t m_rounding_type; uint32_t m_fcode; + xvid_vol_t vol_flags; - HINTINFO *hint; + int64_t m_stamp; +} +MBParam; - uint32_t m_seconds; - uint32_t m_ticks; +typedef struct +{ + int iTextBits; + int iMvSum; + int iMvCount; + int kblks; + int mblks; + int ublks; + int gblks; } -MBParam; +Statistics; +/* encoding queue */ typedef struct { - uint32_t quant; - uint32_t motion_flags; - uint32_t global_flags; + xvid_enc_frame_t frame; + unsigned char quant_intra_matrix[64]; + unsigned char quant_inter_matrix[64]; + IMAGE image; +} QUEUEINFO; - VOP_TYPE coding_type; + +typedef struct +{ + int frame_num; + int fincr; + xvid_vol_t vol_flags; + xvid_vop_t vop_flags; + xvid_motion_t motion_flags; + + int coding_type; + uint32_t quant; uint32_t rounding_type; uint32_t fcode; uint32_t bcode; uint32_t seconds; uint32_t ticks; + int64_t stamp; IMAGE image; MACROBLOCK *mbs; -} -FRAMEINFO; + WARPPOINTS warp; // as in bitstream + GMC_DATA gmc_data; // common data for all MBs -typedef struct -{ - int iTextBits; - float fMvPrevSigma; - int iMvSum; - int iMvCount; - int kblks; - int mblks; - int ublks; + int length; /* the encoded size of this frame */ + + Statistics sStat; } -Statistics; - +FRAMEINFO; typedef struct @@ -159,34 +173,40 @@ MBParam mbParam; int iFrameNum; - int iMaxKeyInterval; int bitrate; + // zones + unsigned int num_zones; + xvid_enc_zone_t * zones; + + // plugins + unsigned int num_plugins; /* note: we store plugin flags in MBPARAM */ + xvid_enc_plugin_t * plugins; + + // dquant + + int * temp_dquants; + // images FRAMEINFO *current; FRAMEINFO *reference; -#ifdef _DEBUG_PSNR - IMAGE sOriginal; -#endif + IMAGE sOriginal; /* original image copy for i/p frames */ + IMAGE sOriginal2; /* original image copy for b-frames */ IMAGE vInterH; IMAGE vInterV; IMAGE vInterVf; IMAGE vInterHV; IMAGE vInterHVf; -#ifdef BFRAMES - /* constants */ - int global; - int bquant_ratio; - int frame_drop_ratio; + IMAGE vGMC; /* image queue */ int queue_head; int queue_tail; int queue_size; - IMAGE *queue; + QUEUEINFO *queue; /* bframe buffer */ int bframenum_head; @@ -197,16 +217,16 @@ IMAGE f_refh; IMAGE f_refv; IMAGE f_refhv; - int bframenum_dx50bvop; - int last_pframe; - int last_sync; - int time_pp; + /* closed_gop fixup temporary storage */ + int closed_bframenum; /* == -1 if there is no fixup intended */ + QUEUEINFO closed_qframe; /* qFrame, only valid when >= 0 */ + int m_framenum; /* debug frame num counter; unlike iFrameNum, does not reset at ivop */ -#endif - Statistics sStat; RateControl rate_control; + + float fMvPrevSigma; } Encoder; @@ -249,14 +269,10 @@ void init_encoder(uint32_t cpu_flags); -int encoder_create(XVID_ENC_PARAM * pParam); -int encoder_destroy(Encoder * pEnc); -int encoder_encode(Encoder * pEnc, - XVID_ENC_FRAME * pFrame, - XVID_ENC_STATS * pResult); - -int encoder_encode_bframes(Encoder * pEnc, - XVID_ENC_FRAME * pFrame, - XVID_ENC_STATS * pResult); +int enc_create(xvid_enc_create_t * create); +int enc_destroy(Encoder * pEnc); +int enc_encode(Encoder * pEnc, + xvid_enc_frame_t * pFrame, + xvid_enc_stats_t * stats); #endif