--- encoder.h 2002/06/13 21:45:24 1.10 +++ encoder.h 2002/12/04 12:31:18 1.18.2.6 @@ -36,7 +36,7 @@ * support for EXTENDED API * - 22.08.2001 fixed bug in iDQtab * - * $Id: encoder.h,v 1.10 2002/06/13 21:45:24 edgomez Exp $ + * $Id: encoder.h,v 1.18.2.6 2002/12/04 12:31:18 suxen_drol Exp $ * ****************************************************************************/ @@ -70,7 +70,8 @@ { I_VOP = 0, P_VOP = 1, - B_VOP = 2 + B_VOP = 2, + S_VOP = 3 } VOP_TYPE; @@ -92,10 +93,12 @@ uint32_t fincr; uint32_t fbase; -#ifdef BFRAMES - int max_bframes; +#ifdef _SMP + int num_threads; #endif + int max_bframes; + /* rounding type; alternate 0-1 after each interframe */ /* 1 <= fixed_code <= 4 automatically adjusted using motion vector statistics inside @@ -105,53 +108,52 @@ uint32_t m_quant_type; uint32_t m_rounding_type; uint32_t m_fcode; + uint32_t m_quarterpel; HINTINFO *hint; -#ifdef BFRAMES - uint32_t m_seconds; - uint32_t m_ticks; -#endif - + int64_t m_stamp; } MBParam; typedef struct { + int iTextBits; + int iMvSum; + int iMvCount; + int kblks; + int mblks; + int ublks; +} +Statistics; + + +typedef struct +{ uint32_t quant; uint32_t motion_flags; uint32_t global_flags; VOP_TYPE coding_type; uint32_t rounding_type; + uint32_t quarterpel; uint32_t fcode; uint32_t bcode; -#ifdef BFRAMES uint32_t seconds; uint32_t ticks; -#endif + int64_t stamp; IMAGE image; MACROBLOCK *mbs; + VECTOR GMC_MV; + Statistics sStat; } FRAMEINFO; -typedef struct -{ - int iTextBits; - float fMvPrevSigma; - int iMvSum; - int iMvCount; - int kblks; - int mblks; - int ublks; -} -Statistics; - typedef struct @@ -167,7 +169,7 @@ FRAMEINFO *current; FRAMEINFO *reference; -#ifdef _DEBUG +#ifdef _DEBUG_PSNR IMAGE sOriginal; #endif IMAGE vInterH; @@ -176,10 +178,19 @@ IMAGE vInterHV; IMAGE vInterHVf; -#ifdef BFRAMES /* constants */ + int global; int bquant_ratio; - /* vars */ + int bquant_offset; + int frame_drop_ratio; + + /* image queue */ + int queue_head; + int queue_tail; + int queue_size; + IMAGE *queue; + + /* bframe buffer */ int bframenum_head; int bframenum_tail; int flush_bframes; @@ -188,9 +199,13 @@ IMAGE f_refh; IMAGE f_refv; IMAGE f_refhv; -#endif - Statistics sStat; + int bframenum_dx50bvop; + + int m_framenum; /* debug frame num counter; unlike iFrameNum, does not reset at ivop */ + RateControl rate_control; + + float fMvPrevSigma; } Encoder; @@ -239,4 +254,8 @@ XVID_ENC_FRAME * pFrame, XVID_ENC_STATS * pResult); +int encoder_encode_bframes(Encoder * pEnc, + XVID_ENC_FRAME * pFrame, + XVID_ENC_STATS * pResult); + #endif