123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- /*!
- *************************************************************************************
- * \file elements.h
- *
- * \brief
- * Header file for elements in H.264 streams
- *
- * \date
- * 6.10.2000
- *
- * \version
- * 1.0
- *
- * \author
- * Sebastian Purreiter <[email protected]> \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.264 syntax elements
- * 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 const byte assignSE2partition[][SE_MAX_ELEMENTS] =
- {
- // 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 // element number (do 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, 0, 0, 0, 1, 1, 1, 1, 0, 2, 2, 2, 2, 0, 0, 0, 0 } //!< three partitions per slice
- };
- #endif
|