--- encoder.h 2003/02/22 08:49:44 1.27.2.1 +++ encoder.h 2003/11/05 16:15:47 1.27.2.16 @@ -1,16 +1,10 @@ /***************************************************************************** * * XVID MPEG-4 VIDEO CODEC - * - Encoder header - + * - Encoder related header - * - * 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 - * advised that its use may infringe existing patents or copyrights, and - * any such use would be at such party's own risk. The original - * developer of this software module and his/her company, and subsequent - * editors and their companies, will have no liability for use of this - * software or modifications or derivatives thereof. + * Copyright(C) 2002-2003 Michael Militzer + * 2002-2003 Peter Ross * * This program is free software ; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -26,17 +20,7 @@ * along with this program ; if not, write to the Free Software * 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.2.1 2003/02/22 08:49:44 suxen_drol Exp $ + * $Id: encoder.h,v 1.27.2.16 2003/11/05 16:15:47 edgomez Exp $ * ****************************************************************************/ @@ -46,19 +30,11 @@ #include "xvid.h" #include "portab.h" #include "global.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 ****************************************************************************/ @@ -80,15 +56,26 @@ uint32_t mb_width; uint32_t mb_height; + int plugin_flags; + /* frame rate increment & base */ - uint32_t fincr; + int32_t fincr; uint32_t fbase; - xvid_global_t global_flags; + int profile; + + int global_flags; int bquant_ratio; int bquant_offset; int frame_drop_ratio; + int min_quant[3]; + int max_quant[3]; + + int par; + int par_width; + int par_height; + #ifdef _SMP int num_threads; #endif @@ -106,7 +93,7 @@ /* vars that not "quite" frame independant */ uint32_t m_rounding_type; uint32_t m_fcode; - xvid_vol_t vol_flags; + int vol_flags; int64_t m_stamp; } @@ -138,9 +125,11 @@ typedef struct { - xvid_vol_t vol_flags; - xvid_vop_t vop_flags; - xvid_motion_t motion_flags; + int frame_num; + int fincr; + int vol_flags; + int vop_flags; + int motion_flags; int coding_type; uint32_t quant; @@ -156,12 +145,14 @@ MACROBLOCK *mbs; - WARPPOINTS warp; // as in bitstream - GMC_DATA gmc_data; // common data for all MBs + WARPPOINTS warp; /* as in bitstream */ + GMC_DATA gmc_data; /* common data for all MBs */ + NEW_GMC_DATA new_gmc_data; /* common data for all MBs */ int length; /* the encoded size of this frame */ - + Statistics sStat; + int is_edged, is_interpolated; } FRAMEINFO; @@ -173,12 +164,25 @@ int iFrameNum; int bitrate; - // images + /* zones */ + unsigned int num_zones; + xvid_enc_zone_t * zones; + + /* plugins */ + int num_plugins; /* note: we store plugin flags in MBPARAM */ + xvid_enc_plugin_t * plugins; + + /* dquant */ + + int * temp_dquants; + + /* images */ FRAMEINFO *current; FRAMEINFO *reference; - IMAGE sOriginal; + IMAGE sOriginal; /* original image copy for i/p frames */ + IMAGE sOriginal2; /* original image copy for b-frames */ IMAGE vInterH; IMAGE vInterV; IMAGE vInterVf; @@ -209,8 +213,6 @@ int m_framenum; /* debug frame num counter; unlike iFrameNum, does not reset at ivop */ - RateControl rate_control; - float fMvPrevSigma; } Encoder; @@ -254,7 +256,7 @@ void init_encoder(uint32_t cpu_flags); -int enc_create(xvid_enc_create_t * create, xvid_enc_rc_t * rc); +int enc_create(xvid_enc_create_t * create); int enc_destroy(Encoder * pEnc); int enc_encode(Encoder * pEnc, xvid_enc_frame_t * pFrame,