--- trunk/xvidcore/src/encoder.h 2002/09/04 20:56:52 399 +++ trunk/xvidcore/src/encoder.h 2003/02/15 15:22:19 851 @@ -3,8 +3,6 @@ * XVID MPEG-4 VIDEO CODEC * - Encoder header - * - * Copyright(C) 2002 Michael Militzer - * * This program is an implementation of a part of one or more MPEG-4 * Video tools as specified in ISO/IEC 14496-2 standard. Those intending * to use this software module in hardware or software products are @@ -29,6 +27,18 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * ****************************************************************************/ +/***************************************************************************** + * + * History + * + * - 13.06.2002 Added legal header + * - 22.08.2001 Added support for EXT_MODE encoding mode + * support for EXTENDED API + * - 22.08.2001 fixed bug in iDQtab + * + * $Id: encoder.h,v 1.27 2003-02-15 15:22:17 edgomez Exp $ + * + ****************************************************************************/ #ifndef _ENCODER_H_ #define _ENCODER_H_ @@ -36,7 +46,6 @@ #include "xvid.h" #include "portab.h" #include "global.h" -#include "image/image.h" #include "utils/ratecontrol.h" /***************************************************************************** @@ -60,7 +69,8 @@ { I_VOP = 0, P_VOP = 1, - B_VOP = 2 + B_VOP = 2, + S_VOP = 3 } VOP_TYPE; @@ -82,13 +92,14 @@ uint32_t fincr; uint32_t fbase; -#ifdef _SMP - int num_threads; -#endif + /* constants */ + int global; + int bquant_ratio; + int bquant_offset; + int frame_drop_ratio; -#ifdef BFRAMES + int iMaxKeyInterval; int max_bframes; -#endif /* rounding type; alternate 0-1 after each interframe */ /* 1 <= fixed_code <= 4 @@ -99,57 +110,62 @@ uint32_t m_quant_type; uint32_t m_rounding_type; uint32_t m_fcode; + uint32_t m_quarterpel; + int m_reduced_resolution; /* reduced_resolution_enable */ HINTINFO *hint; - uint32_t m_seconds; - uint32_t m_ticks; - + int64_t m_stamp; } MBParam; typedef struct { + int iTextBits; + int iMvSum; + int iMvCount; + int kblks; + int mblks; + int ublks; + int gblks; +} +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; uint32_t seconds; uint32_t ticks; + int64_t stamp; IMAGE image; MACROBLOCK *mbs; + WARPPOINTS warp; // as in bitstream + GMC_DATA gmc_data; // common data for all MBs + + Statistics sStat; } FRAMEINFO; -typedef struct -{ - int iTextBits; - float fMvPrevSigma; - int iMvSum; - int iMvCount; - int kblks; - int mblks; - int ublks; -} -Statistics; - - typedef struct { MBParam mbParam; int iFrameNum; - int iMaxKeyInterval; int bitrate; // images @@ -157,20 +173,14 @@ FRAMEINFO *current; FRAMEINFO *reference; -#ifdef _DEBUG_PSNR IMAGE sOriginal; -#endif 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; @@ -189,14 +199,11 @@ IMAGE f_refhv; int bframenum_dx50bvop; - int last_pframe; - int last_sync; - int time_pp; int m_framenum; /* debug frame num counter; unlike iFrameNum, does not reset at ivop */ -#endif - Statistics sStat; RateControl rate_control; + + float fMvPrevSigma; } Encoder;