www.pudn.com > JM60.ZIP > elements.h
/* *********************************************************************** * COPYRIGHT AND WARRANTY INFORMATION * * Copyright 2001, International Telecommunications Union, Geneva * * DISCLAIMER OF WARRANTY * * These software programs are available to the user without any * license fee or royalty on an "as is" basis. The ITU disclaims * any and all warranties, whether express, implied, or * statutory, including any implied warranties of merchantability * or of fitness for a particular purpose. In no event shall the * contributor or the ITU be liable for any incidental, punitive, or * consequential damages of any kind whatsoever arising from the * use of these programs. * * This disclaimer of warranty extends to the user of these programs * and user's customers, employees, agents, transferees, successors, * and assigns. * * The ITU does not represent or warrant that the programs furnished * hereunder are free of infringement of any third-party patents. * Commercial implementations of ITU-T Recommendations, including * shareware, may be subject to royalty fees to patent holders. * Information regarding the ITU-T patent policy is available from * the ITU Web site at http://www.itu.int. * * THIS IS NOT A GRANT OF PATENT RIGHTS - SEE THE ITU-T PATENT POLICY. ************************************************************************ */ /*! ************************************************************************************* * \file elements.h * * \brief * Header file for elements in H.26L streams * * \date * 6.10.2000 * * \version * 1.0 * * \author * Sebastian Purreiter\n * Siemens AG, Information and Communication Mobile \n * P.O.Box 80 17 07 \n * D-81617 Munich, Germany \n ************************************************************************************* */ #ifndef _ELEMENTS_H_ #define _ELEMENTS_H_ /*! * definition of H.26L syntaxelements * order of elements follow dependencies for picture reconstruction */ /*! * \brief Assignment of old TYPE partition elements to new * elements * * old element | new elements * ----------------+------------------------------------------------------------------- * TYPE_HEADER | SE_HEADER, SE_PTYPE * TYPE_MBHEADER | SE_MBTYPE, SE_REFFRAME, SE_INTRAPREDMODE * TYPE_MVD | SE_MVD * TYPE_CBP | SE_CBP_INTRA, SE_CBP_INTER * SE_DELTA_QUANT_INTER * SE_DELTA_QUANT_INTRA * TYPE_COEFF_Y | SE_LUM_DC_INTRA, SE_LUM_AC_INTRA, SE_LUM_DC_INTER, SE_LUM_AC_INTER * TYPE_2x2DC | SE_CHR_DC_INTRA, SE_CHR_DC_INTER * TYPE_COEFF_C | SE_CHR_AC_INTRA, SE_CHR_AC_INTER * TYPE_EOS | SE_EOS */ #define SE_HEADER 0 #define SE_PTYPE 1 #define SE_MBTYPE 2 #define SE_REFFRAME 3 #define SE_INTRAPREDMODE 4 #define SE_MVD 5 #define SE_CBP_INTRA 6 #define SE_LUM_DC_INTRA 7 #define SE_CHR_DC_INTRA 8 #define SE_LUM_AC_INTRA 9 #define SE_CHR_AC_INTRA 10 #define SE_CBP_INTER 11 #define SE_LUM_DC_INTER 12 #define SE_CHR_DC_INTER 13 #define SE_LUM_AC_INTER 14 #define SE_CHR_AC_INTER 15 #define SE_DELTA_QUANT_INTER 16 #define SE_DELTA_QUANT_INTRA 17 #define SE_BFRAME 18 #define SE_EOS 19 #define SE_MAX_ELEMENTS 20 #define NO_EC 0 //!< no error concealment necessary #define EC_REQ 1 //!< error concealment required #define EC_SYNC 2 //!< search and sync on next header element #define MAXPARTITIONMODES 2 //!< maximum possible partition modes as defined in assignSE2partition[][] /*! * \brief lookup-table to assign different elements to partition * * \note here we defined up to 6 different partitions similar to * document Q15-k-18 described in the PROGFRAMEMODE. * The Sliceheader contains the PSYNC information. \par * * Elements inside a partition are not ordered. They are * ordered by occurence in the stream. * Assumption: Only partitionlosses are considered. \par * * The texture elements luminance and chrominance are * not ordered in the progressive form * This may be changed in image.c \par * * We also defined the proposed internet partition mode * of Stephan Wenger here. To select the desired mode * uncomment one of the two following lines. \par * * -IMPORTANT: * Picture- or Sliceheaders must be assigned to partition 0. \par * Furthermore partitions must follow syntax dependencies as * outlined in document Q15-J-23. */ static int assignSE2partition[][SE_MAX_ELEMENTS] = { // 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 // elementnumber (no not uncomment) { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, //!< all elements in one partition no data partitioning { 0, 0, 0, 0, 1, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 1, 0, 0 } //!< three partitions per slice }; int PartitionMode; #endif