h264data.h
上传用户:hjq518
上传日期:2021-12-09
资源大小:5084k
文件大小:60k
源码类别:

Audio

开发平台:

Visual C++

  1. /*  * H26L/H264/AVC/JVT/14496-10/... encoder/decoder  * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at>  *  * This library is free software; you can redistribute it and/or  * modify it under the terms of the GNU Lesser General Public  * License as published by the Free Software Foundation; either  * version 2 of the License, or (at your option) any later version.  *  * This library is distributed in the hope that it will be useful,  * but WITHOUT ANY WARRANTY; without even the implied warranty of  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU  * Lesser General Public License for more details.  *  * You should have received a copy of the GNU Lesser General Public  * License along with this library; if not, write to the Free Software  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA  *  */ /**  * @file h264data.h  * @brief   *     H264 / AVC / MPEG4 part10 codec data table  * @author Michael Niedermayer <michaelni@gmx.at>  */ //#include "common.h"
  2. #define VERT_PRED             0 #define HOR_PRED              1 #define DC_PRED               2 #define DIAG_DOWN_LEFT_PRED   3 #define DIAG_DOWN_RIGHT_PRED  4 #define VERT_RIGHT_PRED       5 #define HOR_DOWN_PRED         6 #define VERT_LEFT_PRED        7 #define HOR_UP_PRED           8 #define LEFT_DC_PRED          9 #define TOP_DC_PRED           10 #define DC_128_PRED           11 #define DC_PRED8x8            0 #define HOR_PRED8x8           1 #define VERT_PRED8x8          2 #define PLANE_PRED8x8         3 #define LEFT_DC_PRED8x8       4 #define TOP_DC_PRED8x8        5 #define DC_128_PRED8x8        6 #define EXTENDED_SAR          255
  3. //AS by ty
  4. /*#define MAX_SPS_COUNT 32
  5. #define MAX_PPS_COUNT 256
  6. #define MAX_MMCO_COUNT 66
  7. typedef struct SPS{    
  8.     int profile_idc;
  9.     int level_idc;
  10.     int log2_max_frame_num;            ///< log2_max_frame_num_minus4 + 4
  11.     int poc_type;                      ///< pic_order_cnt_type
  12.     int log2_max_poc_lsb;              ///< log2_max_pic_order_cnt_lsb_minus4
  13.     int delta_pic_order_always_zero_flag;
  14.     int offset_for_non_ref_pic;
  15.     int offset_for_top_to_bottom_field;
  16.     int poc_cycle_length;              ///< num_ref_frames_in_pic_order_cnt_cycle
  17.     int ref_frame_count;               ///< num_ref_frames
  18.     int gaps_in_frame_num_allowed_flag;
  19.     int mb_width;                      ///< frame_width_in_mbs_minus1 + 1
  20.     int mb_height;                     ///< frame_height_in_mbs_minus1 + 1
  21.     int frame_mbs_only_flag;
  22.     int mb_aff;                        ///<mb_adaptive_frame_field_flag
  23.     int direct_8x8_inference_flag;
  24.     int crop;                   ///< frame_cropping_flag
  25.     int crop_left;              ///< frame_cropping_rect_left_offset
  26.     int crop_right;             ///< frame_cropping_rect_right_offset
  27.     int crop_top;               ///< frame_cropping_rect_top_offset
  28.     int crop_bottom;            ///< frame_cropping_rect_bottom_offset
  29.     int vui_parameters_present_flag;
  30.     AVRational sar;
  31.     short offset_for_ref_frame[256]; //FIXME dyn aloc?
  32. }SPS;
  33. typedef struct PPS{
  34.     int sps_id;
  35.     int cabac;                  ///< entropy_coding_mode_flag
  36.     int pic_order_present;      ///< pic_order_present_flag
  37.     int slice_group_count;      ///< num_slice_groups_minus1 + 1
  38.     int mb_slice_group_map_type;
  39.     int ref_count[2];           ///< num_ref_idx_l0/1_active_minus1 + 1
  40.     int weighted_pred;          ///< weighted_pred_flag
  41.     int weighted_bipred_idc;
  42.     int init_qp;                ///< pic_init_qp_minus26 + 26
  43.     int init_qs;                ///< pic_init_qs_minus26 + 26
  44.     int chroma_qp_index_offset;
  45.     int deblocking_filter_parameters_present; ///< deblocking_filter_parameters_present_flag
  46.     int constrained_intra_pred; ///< constrained_intra_pred_flag
  47.     int redundant_pic_cnt_present; ///< redundant_pic_cnt_present_flag
  48. }PPS;
  49. typedef enum MMCOOpcode{
  50.     MMCO_END=0,
  51.     MMCO_SHORT2UNUSED,
  52.     MMCO_LONG2UNUSED,
  53.     MMCO_SHORT2LONG,
  54.     MMCO_SET_MAX_LONG,
  55.     MMCO_RESET, 
  56.     MMCO_LONG,
  57. } MMCOOpcode;
  58. typedef struct MMCO{
  59.     MMCOOpcode opcode;
  60.     int short_frame_num;
  61.     int long_index;
  62. } MMCO;*/
  63. //typedef struct H264Context{
  64. //    MpegEncContext s;
  65. //    int nal_ref_idc;
  66. //    int nal_unit_type;
  67. //#define NAL_SLICE 1
  68. //#define NAL_DPA 2
  69. //#define NAL_DPB 3
  70. //#define NAL_DPC 4
  71. //#define NAL_IDR_SLICE 5
  72. //#define NAL_SEI 6
  73. //#define NAL_SPS 7
  74. //#define NAL_PPS 8
  75. //#define NAL_PICTURE_DELIMITER 9
  76. //#define NAL_FILTER_DATA 10
  77. //    uint8_t *rbsp_buffer;
  78. //    int rbsp_buffer_size;
  79. //    int chroma_qp; //QPc
  80. //    int prev_mb_skiped; //FIXME remove (IMHO not used)
  81. //    //prediction stuff
  82. //    int chroma_pred_mode;
  83. //    int intra16x16_pred_mode;
  84. //    
  85. //    int8_t intra4x4_pred_mode_cache[5*8];
  86. //    int8_t (*intra4x4_pred_mode)[8];
  87. //    void (*pred4x4  [9+3])(uint8_t *src, uint8_t *topright, int stride);//FIXME move to dsp?
  88. //    void (*pred8x8  [4+3])(uint8_t *src, int stride);
  89. //    void (*pred16x16[4+3])(uint8_t *src, int stride);
  90. //    unsigned int topleft_samples_available;
  91. //    unsigned int top_samples_available;
  92. //    unsigned int topright_samples_available;
  93. //    unsigned int left_samples_available;
  94. //    uint8_t (*top_border)[16+2*8];
  95. //    uint8_t left_border[17+2*9];
  96. //    /**
  97. //     * non zero coeff count cache.
  98. //     * is 64 if not available.
  99. //     */
  100. //    uint8_t non_zero_count_cache[6*8];
  101. //    uint8_t (*non_zero_count)[16];
  102. //    /**
  103. //     * Motion vector cache.
  104. //     */
  105. //    int16_t mv_cache[2][5*8][2];
  106. //    int8_t ref_cache[2][5*8];
  107. //#define LIST_NOT_USED -1 //FIXME rename?
  108. //#define PART_NOT_AVAILABLE -2
  109. //    
  110. //    /**
  111. //     * is 1 if the specific list MV&references are set to 0,0,-2.
  112. //     */
  113. //    int mv_cache_clean[2];
  114. //    int block_offset[16+8];
  115. //    int chroma_subblock_offset[16]; //FIXME remove
  116. //    
  117. //    uint16_t *mb2b_xy; //FIXME are these 4 a good idea?
  118. //    uint16_t *mb2b8_xy;
  119. //    int b_stride;
  120. //    int b8_stride;
  121. //    int halfpel_flag;
  122. //    int thirdpel_flag;
  123. //    int unknown_svq3_flag;
  124. //    int next_slice_index;
  125. //    SPS sps_buffer[MAX_SPS_COUNT];
  126. //    SPS sps; ///< current sps
  127. //    
  128. //    PPS pps_buffer[MAX_PPS_COUNT];
  129. //    /**
  130. //     * current pps
  131. //     */
  132. //    PPS pps; //FIXME move tp Picture perhaps? (->no) do we need that?
  133. //    int slice_num;
  134. //    uint8_t *slice_table_base;
  135. //    uint8_t *slice_table;      ///< slice_table_base + mb_stride + 1
  136. //    int slice_type;
  137. //    int slice_type_fixed;
  138. //    
  139. //    //interlacing specific flags
  140. //    int mb_field_decoding_flag;
  141. //    
  142. //    int sub_mb_type[4];
  143. //    
  144. //    //POC stuff
  145. //    int poc_lsb;
  146. //    int poc_msb;
  147. //    int delta_poc_bottom;
  148. //    int delta_poc[2];
  149. //    int frame_num;
  150. //    int prev_poc_msb;             ///< poc_msb of the last reference pic for POC type 0
  151. //    int prev_poc_lsb;             ///< poc_lsb of the last reference pic for POC type 0
  152. //    int frame_num_offset;         ///< for POC type 2
  153. //    int prev_frame_num_offset;    ///< for POC type 2
  154. //    int prev_frame_num;           ///< frame_num of the last pic for POC type 1/2
  155. //    /**
  156. //     * frame_num for frames or 2*frame_num for field pics.
  157. //     */
  158. //    int curr_pic_num;
  159. //    
  160. //    /**
  161. //     * max_frame_num or 2*max_frame_num for field pics.
  162. //     */
  163. //    int max_pic_num;
  164. //    //Weighted pred stuff
  165. //    int luma_log2_weight_denom;
  166. //    int chroma_log2_weight_denom;
  167. //    int luma_weight[2][16];
  168. //    int luma_offset[2][16];
  169. //    int chroma_weight[2][16][2];
  170. //    int chroma_offset[2][16][2];
  171. //   
  172. //    //deblock
  173. //    int deblocking_filter;         ///< disable_deblocking_filter_idc with 1<->0 
  174. //    int slice_alpha_c0_offset;
  175. //    int slice_beta_offset;
  176. //     
  177. //    int redundant_pic_count;
  178. //    
  179. //    int direct_spatial_mv_pred;
  180. //    /**
  181. //     * num_ref_idx_l0/1_active_minus1 + 1
  182. //     */
  183. //    int ref_count[2];// FIXME split for AFF
  184. //    Picture *short_ref[16];
  185. //    Picture *long_ref[16];
  186. //    Picture default_ref_list[2][32];
  187. //    Picture ref_list[2][32]; //FIXME size?
  188. //    Picture field_ref_list[2][32]; //FIXME size?
  189. //    
  190. //    /**
  191. //     * memory management control operations buffer.
  192. //     */
  193. //    MMCO mmco[MAX_MMCO_COUNT];
  194. //    int mmco_index;
  195. //    
  196. //    int long_ref_count;  ///< number of actual long term references
  197. //    int short_ref_count; ///< number of actual short term references
  198. //    
  199. //    //data partitioning
  200. //    GetBitContext intra_gb;
  201. //    GetBitContext inter_gb;
  202. //    GetBitContext *intra_gb_ptr;
  203. //    GetBitContext *inter_gb_ptr;
  204. //    
  205. ////    DCTELEM mb[16*24] __align8;
  206. //    DCTELEM __align8 mb[16*24] ;
  207. //    /**
  208. //     * Cabac
  209. //     */
  210. //    CABACContext cabac;
  211. //    uint8_t      cabac_state[399];
  212. //    int          cabac_init_idc;
  213. //    /* 0x100 -> non null luma_dc, 0x80/0x40 -> non null chroma_dc (cb/cr), 0x?0 -> chroma_cbp(0,1,2), 0x0? luma_cbp */
  214. //    uint16_t     *cbp_table;
  215. //    /* chroma_pred_mode for i4x4 or i16x16, else 0 */
  216. //    uint8_t     *chroma_pred_mode_table;
  217. //    int         last_qscale_diff;
  218. //    int16_t     (*mvd_table[2])[2];
  219. //    int16_t     mvd_cache[2][5*8][2];
  220. //}H264Context;
  221. //AE by ty
  222. static const AVRational pixel_aspect[14]={
  223.  {0, 1},
  224.  {1, 1},
  225.  {12, 11},
  226.  {10, 11},
  227.  {16, 11},
  228.  {40, 33},
  229.  {24, 11},
  230.  {20, 11},
  231.  {32, 11},
  232.  {80, 33},
  233.  {18, 11},
  234.  {15, 11},
  235.  {64, 33},
  236.  {160,99},
  237. };
  238. static const uint8_t golomb_to_pict_type[5]= {P_TYPE, B_TYPE, I_TYPE, SP_TYPE, SI_TYPE}; static const uint8_t pict_type_to_golomb[7]= {-1, 2, 0, 1, -1, 4, 3}; static const uint8_t chroma_qp[52]={     0, 1, 2, 3, 4, 5, 6, 7, 8, 9,10,11,    12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,    28,29,29,30,31,32,32,33,34,34,35,35,36,36,37,37,    37,38,38,38,39,39,39,39 }; static const uint8_t golomb_to_intra4x4_cbp[48]={  47, 31, 15,  0, 23, 27, 29, 30,  7, 11, 13, 14, 39, 43, 45, 46,  16,  3,  5, 10, 12, 19, 21, 26, 28, 35, 37, 42, 44,  1,  2,  4,   8, 17, 18, 20, 24,  6,  9, 22, 25, 32, 33, 34, 36, 40, 38, 41 };   static const uint8_t golomb_to_inter_cbp[48]={   0, 16,  1,  2,  4,  8, 32,  3,  5, 10, 12, 15, 47,  7, 11, 13,  14,  6,  9, 31, 35, 37, 42, 44, 33, 34, 36, 40, 39, 43, 45, 46,  17, 18, 20, 24, 19, 21, 26, 28, 23, 27, 29, 30, 22, 25, 38, 41 }; static const uint8_t intra4x4_cbp_to_golomb[48]={   3, 29, 30, 17, 31, 18, 37,  8, 32, 38, 19,  9, 20, 10, 11,  2,  16, 33, 34, 21, 35, 22, 39,  4, 36, 40, 23,  5, 24,  6,  7,  1,  41, 42, 43, 25, 44, 26, 46, 12, 45, 47, 27, 13, 28, 14, 15,  0 };   static const uint8_t inter_cbp_to_golomb[48]={   0,  2,  3,  7,  4,  8, 17, 13,  5, 18,  9, 14, 10, 15, 16, 11,   1, 32, 33, 36, 34, 37, 44, 40, 35, 45, 38, 41, 39, 42, 43, 19,   6, 24, 25, 20, 26, 21, 46, 28, 27, 47, 22, 29, 23, 30, 31, 12 }; static const uint8_t chroma_dc_coeff_token_len[4*5]={  2, 0, 0, 0,  6, 1, 0, 0,  6, 6, 3, 0,  6, 7, 7, 6,  6, 8, 8, 7, }; static const uint8_t chroma_dc_coeff_token_bits[4*5]={  1, 0, 0, 0,  7, 1, 0, 0,  4, 6, 1, 0,  3, 3, 2, 5,  2, 3, 2, 0, }; static const uint8_t coeff_token_len[4][4*17]={ {      1, 0, 0, 0,      6, 2, 0, 0,     8, 6, 3, 0,     9, 8, 7, 5,    10, 9, 8, 6,     11,10, 9, 7,    13,11,10, 8,    13,13,11, 9,    13,13,13,10,     14,14,13,11,    14,14,14,13,    15,15,14,14,    15,15,15,14,     16,15,15,15,    16,16,16,15,    16,16,16,16,    16,16,16,16, }, {      2, 0, 0, 0,      6, 2, 0, 0,     6, 5, 3, 0,     7, 6, 6, 4,     8, 6, 6, 4,      8, 7, 7, 5,     9, 8, 8, 6,    11, 9, 9, 6,    11,11,11, 7,     12,11,11, 9,    12,12,12,11,    12,12,12,11,    13,13,13,12,     13,13,13,13,    13,14,13,13,    14,14,14,13,    14,14,14,14, }, {      4, 0, 0, 0,      6, 4, 0, 0,     6, 5, 4, 0,     6, 5, 5, 4,     7, 5, 5, 4,      7, 5, 5, 4,     7, 6, 6, 4,     7, 6, 6, 4,     8, 7, 7, 5,      8, 8, 7, 6,     9, 8, 8, 7,     9, 9, 8, 8,     9, 9, 9, 8,     10, 9, 9, 9,    10,10,10,10,    10,10,10,10,    10,10,10,10, }, {      6, 0, 0, 0,      6, 6, 0, 0,     6, 6, 6, 0,     6, 6, 6, 6,     6, 6, 6, 6,      6, 6, 6, 6,     6, 6, 6, 6,     6, 6, 6, 6,     6, 6, 6, 6,      6, 6, 6, 6,     6, 6, 6, 6,     6, 6, 6, 6,     6, 6, 6, 6,      6, 6, 6, 6,     6, 6, 6, 6,     6, 6, 6, 6,     6, 6, 6, 6, } }; static const uint8_t coeff_token_bits[4][4*17]={ {      1, 0, 0, 0,      5, 1, 0, 0,     7, 4, 1, 0,     7, 6, 5, 3,     7, 6, 5, 3,      7, 6, 5, 4,    15, 6, 5, 4,    11,14, 5, 4,     8,10,13, 4,     15,14, 9, 4,    11,10,13,12,    15,14, 9,12,    11,10,13, 8,     15, 1, 9,12,    11,14,13, 8,     7,10, 9,12,     4, 6, 5, 8, }, {      3, 0, 0, 0,     11, 2, 0, 0,     7, 7, 3, 0,     7,10, 9, 5,     7, 6, 5, 4,      4, 6, 5, 6,     7, 6, 5, 8,    15, 6, 5, 4,    11,14,13, 4,     15,10, 9, 4,    11,14,13,12,     8,10, 9, 8,    15,14,13,12,     11,10, 9,12,     7,11, 6, 8,     9, 8,10, 1,     7, 6, 5, 4, }, {     15, 0, 0, 0,     15,14, 0, 0,    11,15,13, 0,     8,12,14,12,    15,10,11,11,     11, 8, 9,10,     9,14,13, 9,     8,10, 9, 8,    15,14,13,13,     11,14,10,12,    15,10,13,12,    11,14, 9,12,     8,10,13, 8,     13, 7, 9,12,     9,12,11,10,     5, 8, 7, 6,     1, 4, 3, 2, }, {      3, 0, 0, 0,      0, 1, 0, 0,     4, 5, 6, 0,     8, 9,10,11,    12,13,14,15,     16,17,18,19,    20,21,22,23,    24,25,26,27,    28,29,30,31,     32,33,34,35,    36,37,38,39,    40,41,42,43,    44,45,46,47,     48,49,50,51,    52,53,54,55,    56,57,58,59,    60,61,62,63, } }; static const uint8_t total_zeros_len[16][16]= {     {1,3,3,4,4,5,5,6,6,7,7,8,8,9,9,9},       {3,3,3,3,3,4,4,4,4,5,5,6,6,6,6},       {4,3,3,3,4,4,3,3,4,5,5,6,5,6},       {5,3,4,4,3,3,3,4,3,4,5,5,5},       {4,4,4,3,3,3,3,3,4,5,4,5},       {6,5,3,3,3,3,3,3,4,3,6},       {6,5,3,3,3,2,3,4,3,6},       {6,4,5,3,2,2,3,3,6},       {6,6,4,2,2,3,2,5},       {5,5,3,2,2,2,4},       {4,4,3,3,1,3},       {4,4,2,1,3},       {3,3,1,2},       {2,2,1},       {1,1},   }; static const uint8_t total_zeros_bits[16][16]= {     {1,3,2,3,2,3,2,3,2,3,2,3,2,3,2,1},     {7,6,5,4,3,5,4,3,2,3,2,3,2,1,0},     {5,7,6,5,4,3,4,3,2,3,2,1,1,0},     {3,7,5,4,6,5,4,3,3,2,2,1,0},     {5,4,3,7,6,5,4,3,2,1,1,0},     {1,1,7,6,5,4,3,2,1,1,0},     {1,1,5,4,3,3,2,1,1,0},     {1,1,1,3,3,2,2,1,0},     {1,0,1,3,2,1,1,1},     {1,0,1,3,2,1,1},     {0,1,1,2,1,3},     {0,1,1,1,1},     {0,1,1,1},     {0,1,1},     {0,1}, }; static const uint8_t chroma_dc_total_zeros_len[3][4]= {     { 1, 2, 3, 3,},     { 1, 2, 2, 0,},     { 1, 1, 0, 0,},  }; static const uint8_t chroma_dc_total_zeros_bits[3][4]= {     { 1, 1, 1, 0,},     { 1, 1, 0, 0,},     { 1, 0, 0, 0,}, }; static const uint8_t run_len[7][16]={     {1,1},     {1,2,2},     {2,2,2,2},     {2,2,2,3,3},     {2,2,3,3,3,3},     {2,3,3,3,3,3,3},     {3,3,3,3,3,3,3,4,5,6,7,8,9,10,11}, }; static const uint8_t run_bits[7][16]={     {1,0},     {1,1,0},     {3,2,1,0},     {3,2,1,1,0},     {3,2,3,2,1,0},     {3,0,1,3,2,5,4},     {7,6,5,4,3,2,1,1,1,1,1,1,1,1,1}, }; /* o-o o-o  / / / o-o o-o  ,---' o-o o-o  / / / o-o o-o */ static const uint8_t scan8[16 + 2*4]={  4+1*8, 5+1*8, 4+2*8, 5+2*8,  6+1*8, 7+1*8, 6+2*8, 7+2*8,  4+3*8, 5+3*8, 4+4*8, 5+4*8,  6+3*8, 7+3*8, 6+4*8, 7+4*8,  1+1*8, 2+1*8,  1+2*8, 2+2*8,  1+4*8, 2+4*8,  1+5*8, 2+5*8, }; static const uint8_t zigzag_scan[16]={  0+0*4, 1+0*4, 0+1*4, 0+2*4,   1+1*4, 2+0*4, 3+0*4, 2+1*4,   1+2*4, 0+3*4, 1+3*4, 2+2*4,   3+1*4, 3+2*4, 2+3*4, 3+3*4,  }; static const uint8_t field_scan[16]={  0+0*4, 0+1*4, 1+0*4, 0+2*4,   0+3*4, 1+1*4, 1+2*4, 1+3*4,  2+0*4, 2+1*4, 2+2*4, 2+3*4,   3+0*4, 3+1*4, 3+2*4, 3+3*4, }; static const uint8_t luma_dc_zigzag_scan[16]={  0*16 + 0*64, 1*16 + 0*64, 2*16 + 0*64, 0*16 + 2*64,  3*16 + 0*64, 0*16 + 1*64, 1*16 + 1*64, 2*16 + 1*64,  1*16 + 2*64, 2*16 + 2*64, 3*16 + 2*64, 0*16 + 3*64,  3*16 + 1*64, 1*16 + 3*64, 2*16 + 3*64, 3*16 + 3*64, }; static const uint8_t luma_dc_field_scan[16]={  0*16 + 0*64, 2*16 + 0*64, 1*16 + 0*64, 0*16 + 2*64,   2*16 + 2*64, 3*16 + 0*64, 1*16 + 2*64, 3*16 + 2*64,   0*16 + 1*64, 2*16 + 1*64, 0*16 + 3*64, 2*16 + 3*64,   1*16 + 1*64, 3*16 + 1*64, 1*16 + 3*64, 3*16 + 3*64, }; static const uint8_t chroma_dc_scan[4]={  (0+0*2)*16, (1+0*2)*16,   (0+1*2)*16, (1+1*2)*16,  //FIXME }; #define MB_TYPE_REF0       MB_TYPE_ACPRED //dirty but it fits in 16bit #define IS_REF0(a)       ((a)&MB_TYPE_REF0) typedef struct IMbInfo{     uint16_t type;     uint8_t pred_mode;     uint8_t cbp; } IMbInfo; static const IMbInfo i_mb_type_info[26]={
  239. {MB_TYPE_INTRA4x4  , -1, -1},
  240. {MB_TYPE_INTRA16x16,  2,  0},
  241. {MB_TYPE_INTRA16x16,  1,  0},
  242. {MB_TYPE_INTRA16x16,  0,  0},
  243. {MB_TYPE_INTRA16x16,  3,  0},
  244. {MB_TYPE_INTRA16x16,  2,  16},
  245. {MB_TYPE_INTRA16x16,  1,  16},
  246. {MB_TYPE_INTRA16x16,  0,  16},
  247. {MB_TYPE_INTRA16x16,  3,  16},
  248. {MB_TYPE_INTRA16x16,  2,  32},
  249. {MB_TYPE_INTRA16x16,  1,  32},
  250. {MB_TYPE_INTRA16x16,  0,  32},
  251. {MB_TYPE_INTRA16x16,  3,  32},
  252. {MB_TYPE_INTRA16x16,  2,  15+0},
  253. {MB_TYPE_INTRA16x16,  1,  15+0},
  254. {MB_TYPE_INTRA16x16,  0,  15+0},
  255. {MB_TYPE_INTRA16x16,  3,  15+0},
  256. {MB_TYPE_INTRA16x16,  2,  15+16},
  257. {MB_TYPE_INTRA16x16,  1,  15+16},
  258. {MB_TYPE_INTRA16x16,  0,  15+16},
  259. {MB_TYPE_INTRA16x16,  3,  15+16},
  260. {MB_TYPE_INTRA16x16,  2,  15+32},
  261. {MB_TYPE_INTRA16x16,  1,  15+32},
  262. {MB_TYPE_INTRA16x16,  0,  15+32},
  263. {MB_TYPE_INTRA16x16,  3,  15+32},
  264. {MB_TYPE_INTRA_PCM , -1, -1},
  265. };
  266. typedef struct PMbInfo{
  267.     uint16_t type;
  268.     uint8_t partition_count;
  269. } PMbInfo;
  270. static const PMbInfo p_mb_type_info[5]={
  271. {MB_TYPE_16x16|MB_TYPE_P0L0             , 1},
  272. {MB_TYPE_16x8 |MB_TYPE_P0L0|MB_TYPE_P1L0, 2},
  273. {MB_TYPE_8x16 |MB_TYPE_P0L0|MB_TYPE_P1L0, 2},
  274. {MB_TYPE_8x8                            , 4},
  275. {MB_TYPE_8x8  |MB_TYPE_REF0             , 4},
  276. };
  277. static const PMbInfo p_sub_mb_type_info[4]={
  278. {MB_TYPE_16x16|MB_TYPE_P0L0             , 1},
  279. {MB_TYPE_16x8 |MB_TYPE_P0L0             , 2},
  280. {MB_TYPE_8x16 |MB_TYPE_P0L0             , 2},
  281. {MB_TYPE_8x8  |MB_TYPE_P0L0             , 4},
  282. };
  283. static const PMbInfo b_mb_type_info[23]={
  284. {MB_TYPE_DIRECT2                                                   , 1, },
  285. {MB_TYPE_16x16|MB_TYPE_P0L0                                       , 1, },
  286. {MB_TYPE_16x16             |MB_TYPE_P0L1                          , 1, },
  287. {MB_TYPE_16x16|MB_TYPE_P0L0|MB_TYPE_P0L1                          , 1, },
  288. {MB_TYPE_16x8 |MB_TYPE_P0L0             |MB_TYPE_P1L0             , 2, },
  289. {MB_TYPE_8x16 |MB_TYPE_P0L0             |MB_TYPE_P1L0             , 2, },
  290. {MB_TYPE_16x8              |MB_TYPE_P0L1             |MB_TYPE_P1L1, 2, },
  291. {MB_TYPE_8x16              |MB_TYPE_P0L1             |MB_TYPE_P1L1, 2, },
  292. {MB_TYPE_16x8 |MB_TYPE_P0L0                          |MB_TYPE_P1L1, 2, },
  293. {MB_TYPE_8x16 |MB_TYPE_P0L0                          |MB_TYPE_P1L1, 2, },
  294. {MB_TYPE_16x8              |MB_TYPE_P0L1|MB_TYPE_P1L0             , 2, },
  295. {MB_TYPE_8x16              |MB_TYPE_P0L1|MB_TYPE_P1L0             , 2, },
  296. {MB_TYPE_16x8 |MB_TYPE_P0L0             |MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  297. {MB_TYPE_8x16 |MB_TYPE_P0L0             |MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  298. {MB_TYPE_16x8              |MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  299. {MB_TYPE_8x16              |MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  300. {MB_TYPE_16x8 |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0             , 2, },
  301. {MB_TYPE_8x16 |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0             , 2, },
  302. {MB_TYPE_16x8 |MB_TYPE_P0L0|MB_TYPE_P0L1             |MB_TYPE_P1L1, 2, },
  303. {MB_TYPE_8x16 |MB_TYPE_P0L0|MB_TYPE_P0L1             |MB_TYPE_P1L1, 2, },
  304. {MB_TYPE_16x8 |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  305. {MB_TYPE_8x16 |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  306. {MB_TYPE_8x8                                                      , 4, },
  307. };
  308. static const PMbInfo b_sub_mb_type_info[13]={
  309. {MB_TYPE_DIRECT2                                                   , 1, },
  310. {MB_TYPE_16x16|MB_TYPE_P0L0                                       , 1, },
  311. {MB_TYPE_16x16             |MB_TYPE_P0L1                          , 1, },
  312. {MB_TYPE_16x16|MB_TYPE_P0L0|MB_TYPE_P0L1                          , 1, },
  313. {MB_TYPE_16x8 |MB_TYPE_P0L0             |MB_TYPE_P1L0             , 2, },
  314. {MB_TYPE_8x16 |MB_TYPE_P0L0             |MB_TYPE_P1L0             , 2, },
  315. {MB_TYPE_16x8              |MB_TYPE_P0L1             |MB_TYPE_P1L1, 2, },
  316. {MB_TYPE_8x16              |MB_TYPE_P0L1             |MB_TYPE_P1L1, 2, },
  317. {MB_TYPE_16x8 |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  318. {MB_TYPE_8x16 |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 2, },
  319. {MB_TYPE_8x8  |MB_TYPE_P0L0             |MB_TYPE_P1L0             , 4, },
  320. {MB_TYPE_8x8               |MB_TYPE_P0L1             |MB_TYPE_P1L1, 4, },
  321. {MB_TYPE_8x8  |MB_TYPE_P0L0|MB_TYPE_P0L1|MB_TYPE_P1L0|MB_TYPE_P1L1, 4, },
  322. };
  323. static const uint8_t rem6[52]={
  324. 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 4, 5, 0, 1, 2, 3, 
  325. };
  326. static const uint8_t div6[52]={
  327. 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 5, 5, 5, 5, 5, 5, 6, 6, 6, 6, 6, 6, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8,
  328. };
  329. static const uint16_t dequant_coeff[52][16]={
  330. {  10,  13,  10,  13,   13,  16,  13,  16,   10,  13,  10,  13,   13,  16,  13,  16, },
  331. {  11,  14,  11,  14,   14,  18,  14,  18,   11,  14,  11,  14,   14,  18,  14,  18, },
  332. {  13,  16,  13,  16,   16,  20,  16,  20,   13,  16,  13,  16,   16,  20,  16,  20, },
  333. {  14,  18,  14,  18,   18,  23,  18,  23,   14,  18,  14,  18,   18,  23,  18,  23, },
  334. {  16,  20,  16,  20,   20,  25,  20,  25,   16,  20,  16,  20,   20,  25,  20,  25, },
  335. {  18,  23,  18,  23,   23,  29,  23,  29,   18,  23,  18,  23,   23,  29,  23,  29, },
  336. {  20,  26,  20,  26,   26,  32,  26,  32,   20,  26,  20,  26,   26,  32,  26,  32, },
  337. {  22,  28,  22,  28,   28,  36,  28,  36,   22,  28,  22,  28,   28,  36,  28,  36, },
  338. {  26,  32,  26,  32,   32,  40,  32,  40,   26,  32,  26,  32,   32,  40,  32,  40, },
  339. {  28,  36,  28,  36,   36,  46,  36,  46,   28,  36,  28,  36,   36,  46,  36,  46, },
  340. {  32,  40,  32,  40,   40,  50,  40,  50,   32,  40,  32,  40,   40,  50,  40,  50, },
  341. {  36,  46,  36,  46,   46,  58,  46,  58,   36,  46,  36,  46,   46,  58,  46,  58, },
  342. {  40,  52,  40,  52,   52,  64,  52,  64,   40,  52,  40,  52,   52,  64,  52,  64, },
  343. {  44,  56,  44,  56,   56,  72,  56,  72,   44,  56,  44,  56,   56,  72,  56,  72, },
  344. {  52,  64,  52,  64,   64,  80,  64,  80,   52,  64,  52,  64,   64,  80,  64,  80, },
  345. {  56,  72,  56,  72,   72,  92,  72,  92,   56,  72,  56,  72,   72,  92,  72,  92, },
  346. {  64,  80,  64,  80,   80, 100,  80, 100,   64,  80,  64,  80,   80, 100,  80, 100, },
  347. {  72,  92,  72,  92,   92, 116,  92, 116,   72,  92,  72,  92,   92, 116,  92, 116, },
  348. {  80, 104,  80, 104,  104, 128, 104, 128,   80, 104,  80, 104,  104, 128, 104, 128, },
  349. {  88, 112,  88, 112,  112, 144, 112, 144,   88, 112,  88, 112,  112, 144, 112, 144, },
  350. { 104, 128, 104, 128,  128, 160, 128, 160,  104, 128, 104, 128,  128, 160, 128, 160, },
  351. { 112, 144, 112, 144,  144, 184, 144, 184,  112, 144, 112, 144,  144, 184, 144, 184, },
  352. { 128, 160, 128, 160,  160, 200, 160, 200,  128, 160, 128, 160,  160, 200, 160, 200, },
  353. { 144, 184, 144, 184,  184, 232, 184, 232,  144, 184, 144, 184,  184, 232, 184, 232, },
  354. { 160, 208, 160, 208,  208, 256, 208, 256,  160, 208, 160, 208,  208, 256, 208, 256, },
  355. { 176, 224, 176, 224,  224, 288, 224, 288,  176, 224, 176, 224,  224, 288, 224, 288, },
  356. { 208, 256, 208, 256,  256, 320, 256, 320,  208, 256, 208, 256,  256, 320, 256, 320, },
  357. { 224, 288, 224, 288,  288, 368, 288, 368,  224, 288, 224, 288,  288, 368, 288, 368, },
  358. { 256, 320, 256, 320,  320, 400, 320, 400,  256, 320, 256, 320,  320, 400, 320, 400, },
  359. { 288, 368, 288, 368,  368, 464, 368, 464,  288, 368, 288, 368,  368, 464, 368, 464, },
  360. { 320, 416, 320, 416,  416, 512, 416, 512,  320, 416, 320, 416,  416, 512, 416, 512, },
  361. { 352, 448, 352, 448,  448, 576, 448, 576,  352, 448, 352, 448,  448, 576, 448, 576, },
  362. { 416, 512, 416, 512,  512, 640, 512, 640,  416, 512, 416, 512,  512, 640, 512, 640, },
  363. { 448, 576, 448, 576,  576, 736, 576, 736,  448, 576, 448, 576,  576, 736, 576, 736, },
  364. { 512, 640, 512, 640,  640, 800, 640, 800,  512, 640, 512, 640,  640, 800, 640, 800, },
  365. { 576, 736, 576, 736,  736, 928, 736, 928,  576, 736, 576, 736,  736, 928, 736, 928, },
  366. { 640, 832, 640, 832,  832,1024, 832,1024,  640, 832, 640, 832,  832,1024, 832,1024, },
  367. { 704, 896, 704, 896,  896,1152, 896,1152,  704, 896, 704, 896,  896,1152, 896,1152, },
  368. { 832,1024, 832,1024, 1024,1280,1024,1280,  832,1024, 832,1024, 1024,1280,1024,1280, },
  369. { 896,1152, 896,1152, 1152,1472,1152,1472,  896,1152, 896,1152, 1152,1472,1152,1472, },
  370. {1024,1280,1024,1280, 1280,1600,1280,1600, 1024,1280,1024,1280, 1280,1600,1280,1600, },
  371. {1152,1472,1152,1472, 1472,1856,1472,1856, 1152,1472,1152,1472, 1472,1856,1472,1856, },
  372. {1280,1664,1280,1664, 1664,2048,1664,2048, 1280,1664,1280,1664, 1664,2048,1664,2048, },
  373. {1408,1792,1408,1792, 1792,2304,1792,2304, 1408,1792,1408,1792, 1792,2304,1792,2304, },
  374. {1664,2048,1664,2048, 2048,2560,2048,2560, 1664,2048,1664,2048, 2048,2560,2048,2560, },
  375. {1792,2304,1792,2304, 2304,2944,2304,2944, 1792,2304,1792,2304, 2304,2944,2304,2944, },
  376. {2048,2560,2048,2560, 2560,3200,2560,3200, 2048,2560,2048,2560, 2560,3200,2560,3200, },
  377. {2304,2944,2304,2944, 2944,3712,2944,3712, 2304,2944,2304,2944, 2944,3712,2944,3712, },
  378. {2560,3328,2560,3328, 3328,4096,3328,4096, 2560,3328,2560,3328, 3328,4096,3328,4096, },
  379. {2816,3584,2816,3584, 3584,4608,3584,4608, 2816,3584,2816,3584, 3584,4608,3584,4608, },
  380. {3328,4096,3328,4096, 4096,5120,4096,5120, 3328,4096,3328,4096, 4096,5120,4096,5120, },
  381. {3584,4608,3584,4608, 4608,5888,4608,5888, 3584,4608,3584,4608, 4608,5888,4608,5888, },
  382. //{4096,5120,4096,5120, 5120,6400,5120,6400, 4096,5120,4096,5120, 5120,6400,5120,6400, },
  383. //{4608,5888,4608,5888, 5888,7424,5888,7424, 4608,5888,4608,5888, 5888,7424,5888,7424, },
  384. };
  385. #define QUANT_SHIFT 22
  386. static const int quant_coeff[52][16]={
  387.     { 419430,258111,419430,258111,258111,167772,258111,167772,419430,258111,419430,258111,258111,167772,258111,167772,},
  388.     { 381300,239675,381300,239675,239675,149131,239675,149131,381300,239675,381300,239675,239675,149131,239675,149131,},
  389.     { 322639,209715,322639,209715,209715,134218,209715,134218,322639,209715,322639,209715,209715,134218,209715,134218,},
  390.     { 299593,186414,299593,186414,186414,116711,186414,116711,299593,186414,299593,186414,186414,116711,186414,116711,},
  391.     { 262144,167772,262144,167772,167772,107374,167772,107374,262144,167772,262144,167772,167772,107374,167772,107374,},
  392.     { 233017,145889,233017,145889,145889, 92564,145889, 92564,233017,145889,233017,145889,145889, 92564,145889, 92564,},
  393.     { 209715,129056,209715,129056,129056, 83886,129056, 83886,209715,129056,209715,129056,129056, 83886,129056, 83886,},
  394.     { 190650,119837,190650,119837,119837, 74565,119837, 74565,190650,119837,190650,119837,119837, 74565,119837, 74565,},
  395.     { 161319,104858,161319,104858,104858, 67109,104858, 67109,161319,104858,161319,104858,104858, 67109,104858, 67109,},
  396.     { 149797, 93207,149797, 93207, 93207, 58356, 93207, 58356,149797, 93207,149797, 93207, 93207, 58356, 93207, 58356,},
  397.     { 131072, 83886,131072, 83886, 83886, 53687, 83886, 53687,131072, 83886,131072, 83886, 83886, 53687, 83886, 53687,},
  398.     { 116508, 72944,116508, 72944, 72944, 46282, 72944, 46282,116508, 72944,116508, 72944, 72944, 46282, 72944, 46282,},
  399.     { 104858, 64528,104858, 64528, 64528, 41943, 64528, 41943,104858, 64528,104858, 64528, 64528, 41943, 64528, 41943,},
  400.     {  95325, 59919, 95325, 59919, 59919, 37283, 59919, 37283, 95325, 59919, 95325, 59919, 59919, 37283, 59919, 37283,},
  401.     {  80660, 52429, 80660, 52429, 52429, 33554, 52429, 33554, 80660, 52429, 80660, 52429, 52429, 33554, 52429, 33554,},
  402.     {  74898, 46603, 74898, 46603, 46603, 29178, 46603, 29178, 74898, 46603, 74898, 46603, 46603, 29178, 46603, 29178,},
  403.     {  65536, 41943, 65536, 41943, 41943, 26844, 41943, 26844, 65536, 41943, 65536, 41943, 41943, 26844, 41943, 26844,},
  404.     {  58254, 36472, 58254, 36472, 36472, 23141, 36472, 23141, 58254, 36472, 58254, 36472, 36472, 23141, 36472, 23141,},
  405.     {  52429, 32264, 52429, 32264, 32264, 20972, 32264, 20972, 52429, 32264, 52429, 32264, 32264, 20972, 32264, 20972,},
  406.     {  47663, 29959, 47663, 29959, 29959, 18641, 29959, 18641, 47663, 29959, 47663, 29959, 29959, 18641, 29959, 18641,},
  407.     {  40330, 26214, 40330, 26214, 26214, 16777, 26214, 16777, 40330, 26214, 40330, 26214, 26214, 16777, 26214, 16777,},
  408.     {  37449, 23302, 37449, 23302, 23302, 14589, 23302, 14589, 37449, 23302, 37449, 23302, 23302, 14589, 23302, 14589,},
  409.     {  32768, 20972, 32768, 20972, 20972, 13422, 20972, 13422, 32768, 20972, 32768, 20972, 20972, 13422, 20972, 13422,},
  410.     {  29127, 18236, 29127, 18236, 18236, 11570, 18236, 11570, 29127, 18236, 29127, 18236, 18236, 11570, 18236, 11570,},
  411.     {  26214, 16132, 26214, 16132, 16132, 10486, 16132, 10486, 26214, 16132, 26214, 16132, 16132, 10486, 16132, 10486,},
  412.     {  23831, 14980, 23831, 14980, 14980,  9321, 14980,  9321, 23831, 14980, 23831, 14980, 14980,  9321, 14980,  9321,},
  413.     {  20165, 13107, 20165, 13107, 13107,  8389, 13107,  8389, 20165, 13107, 20165, 13107, 13107,  8389, 13107,  8389,},
  414.     {  18725, 11651, 18725, 11651, 11651,  7294, 11651,  7294, 18725, 11651, 18725, 11651, 11651,  7294, 11651,  7294,},
  415.     {  16384, 10486, 16384, 10486, 10486,  6711, 10486,  6711, 16384, 10486, 16384, 10486, 10486,  6711, 10486,  6711,},
  416.     {  14564,  9118, 14564,  9118,  9118,  5785,  9118,  5785, 14564,  9118, 14564,  9118,  9118,  5785,  9118,  5785,},
  417.     {  13107,  8066, 13107,  8066,  8066,  5243,  8066,  5243, 13107,  8066, 13107,  8066,  8066,  5243,  8066,  5243,},
  418.     {  11916,  7490, 11916,  7490,  7490,  4660,  7490,  4660, 11916,  7490, 11916,  7490,  7490,  4660,  7490,  4660,},
  419.     {  10082,  6554, 10082,  6554,  6554,  4194,  6554,  4194, 10082,  6554, 10082,  6554,  6554,  4194,  6554,  4194,},
  420.     {   9362,  5825,  9362,  5825,  5825,  3647,  5825,  3647,  9362,  5825,  9362,  5825,  5825,  3647,  5825,  3647,},
  421.     {   8192,  5243,  8192,  5243,  5243,  3355,  5243,  3355,  8192,  5243,  8192,  5243,  5243,  3355,  5243,  3355,},
  422.     {   7282,  4559,  7282,  4559,  4559,  2893,  4559,  2893,  7282,  4559,  7282,  4559,  4559,  2893,  4559,  2893,},
  423.     {   6554,  4033,  6554,  4033,  4033,  2621,  4033,  2621,  6554,  4033,  6554,  4033,  4033,  2621,  4033,  2621,},
  424.     {   5958,  3745,  5958,  3745,  3745,  2330,  3745,  2330,  5958,  3745,  5958,  3745,  3745,  2330,  3745,  2330,},
  425.     {   5041,  3277,  5041,  3277,  3277,  2097,  3277,  2097,  5041,  3277,  5041,  3277,  3277,  2097,  3277,  2097,},
  426.     {   4681,  2913,  4681,  2913,  2913,  1824,  2913,  1824,  4681,  2913,  4681,  2913,  2913,  1824,  2913,  1824,},
  427.     {   4096,  2621,  4096,  2621,  2621,  1678,  2621,  1678,  4096,  2621,  4096,  2621,  2621,  1678,  2621,  1678,},
  428.     {   3641,  2280,  3641,  2280,  2280,  1446,  2280,  1446,  3641,  2280,  3641,  2280,  2280,  1446,  2280,  1446,},
  429.     {   3277,  2016,  3277,  2016,  2016,  1311,  2016,  1311,  3277,  2016,  3277,  2016,  2016,  1311,  2016,  1311,},
  430.     {   2979,  1872,  2979,  1872,  1872,  1165,  1872,  1165,  2979,  1872,  2979,  1872,  1872,  1165,  1872,  1165,},
  431.     {   2521,  1638,  2521,  1638,  1638,  1049,  1638,  1049,  2521,  1638,  2521,  1638,  1638,  1049,  1638,  1049,},
  432.     {   2341,  1456,  2341,  1456,  1456,   912,  1456,   912,  2341,  1456,  2341,  1456,  1456,   912,  1456,   912,},
  433.     {   2048,  1311,  2048,  1311,  1311,   839,  1311,   839,  2048,  1311,  2048,  1311,  1311,   839,  1311,   839,},
  434.     {   1820,  1140,  1820,  1140,  1140,   723,  1140,   723,  1820,  1140,  1820,  1140,  1140,   723,  1140,   723,},
  435.     {   1638,  1008,  1638,  1008,  1008,   655,  1008,   655,  1638,  1008,  1638,  1008,  1008,   655,  1008,   655,},
  436.     {   1489,   936,  1489,   936,   936,   583,   936,   583,  1489,   936,  1489,   936,   936,   583,   936,   583,},
  437.     {   1260,   819,  1260,   819,   819,   524,   819,   524,  1260,   819,  1260,   819,   819,   524,   819,   524,},
  438.     {   1170,   728,  1170,   728,   728,   456,   728,   456,  1170,   728,  1170,   728,   728,   456,   728,   456,},
  439. };
  440. /* Deblocking filter (p153) */
  441. static const int alpha_table[52] = {
  442.      0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  443.      0,  0,  0,  0,  0,  0,  4,  4,  5,  6,
  444.      7,  8,  9, 10, 12, 13, 15, 17, 20, 22,
  445.     25, 28, 32, 36, 40, 45, 50, 56, 63, 71,
  446.     80, 90,101,113,127,144,162,182,203,226,
  447.     255, 255
  448. };
  449. static const int beta_table[52] = {
  450.      0,  0,  0,  0,  0,  0,  0,  0,  0,  0,
  451.      0,  0,  0,  0,  0,  0,  2,  2,  2,  3,
  452.      3,  3,  3,  4,  4,  4,  6,  6,  7,  7,
  453.      8,  8,  9,  9, 10, 10, 11, 11, 12, 12,
  454.     13, 13, 14, 14, 15, 15, 16, 16, 17, 17,
  455.     18, 18
  456. };
  457. static const int tc0_table[52][3] = {
  458.     { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
  459.     { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 },
  460.     { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 0 }, { 0, 0, 1 },
  461.     { 0, 0, 1 }, { 0, 0, 1 }, { 0, 0, 1 }, { 0, 1, 1 }, { 0, 1, 1 }, { 1, 1, 1 },
  462.     { 1, 1, 1 }, { 1, 1, 1 }, { 1, 1, 1 }, { 1, 1, 2 }, { 1, 1, 2 }, { 1, 1, 2 },
  463.     { 1, 1, 2 }, { 1, 2, 3 }, { 1, 2, 3 }, { 2, 2, 3 }, { 2, 2, 4 }, { 2, 3, 4 },
  464.     { 2, 3, 4 }, { 3, 3, 5 }, { 3, 4, 6 }, { 3, 4, 6 }, { 4, 5, 7 }, { 4, 5, 8 },
  465.     { 4, 6, 9 }, { 5, 7,10 }, { 6, 8,11 }, { 6, 8,13 }, { 7,10,14 }, { 8,11,16 },
  466.     { 9,12,18 }, {10,13,20 }, {11,15,23 }, {13,17,25 }
  467. };
  468. /* Cabac pre state table */
  469. static const int cabac_context_init_I[399][2] =
  470. {
  471.     /* 0 - 10 */
  472.     { 20, -15 }, {  2, 54 },  {  3,  74 }, { 20, -15 },
  473.     {  2,  54 }, {  3, 74 },  { -28,127 }, { -23, 104 },
  474.     { -6,  53 }, { -1, 54 },  {  7,  51 },
  475.     /* 11 - 23 unsused for I */
  476.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  477.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  478.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  479.     { 0, 0 },
  480.     /* 24- 39 */
  481.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  482.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  483.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  484.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  485.     /* 40 - 53 */
  486.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  487.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  488.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  489.     { 0, 0 },    { 0, 0 },
  490.     /* 54 - 59 */
  491.     { 0, 0 },    { 0, 0 },    { 0, 0 },      { 0, 0 },
  492.     { 0, 0 },    { 0, 0 },
  493.     /* 60 - 69 */
  494.     { 0, 41 },   { 0, 63 },   { 0, 63 },     { 0, 63 },
  495.     { -9, 83 },  { 4, 86 },   { 0, 97 },     { -7, 72 },
  496.     { 13, 41 },  { 3, 62 },
  497.     /* 70 -> 87 */
  498.     { 0, 11 },   { 1, 55 },   { 0, 69 },     { -17, 127 },
  499.     { -13, 102 },{ 0, 82 },   { -7, 74 },    { -21, 107 },
  500.     { -27, 127 },{ -31, 127 },{ -24, 127 },  { -18, 95 },
  501.     { -27, 127 },{ -21, 114 },{ -30, 127 },  { -17, 123 },
  502.     { -12, 115 },{ -16, 122 },
  503.     /* 88 -> 104 */
  504.     { -11, 115 },{ -12, 63 }, { -2, 68 },    { -15, 84 },
  505.     { -13, 104 },{ -3, 70 },  { -8, 93 },    { -10, 90 },
  506.     { -30, 127 },{ -1, 74 },  { -6, 97 },    { -7, 91 },
  507.     { -20, 127 },{ -4, 56 },  { -5, 82 },    { -7, 76 },
  508.     { -22, 125 },
  509.     /* 105 -> 135 */
  510.     { -7, 93 },  { -11, 87 }, { -3, 77 },    { -5, 71 },
  511.     { -4, 63 },  { -4, 68 },  { -12, 84 },   { -7, 62 },
  512.     { -7, 65 },  { 8, 61 },   { 5, 56 },     { -2, 66 },
  513.     { 1, 64 },   { 0, 61 },   { -2, 78 },    { 1, 50 },
  514.     { 7, 52 },   { 10, 35 },  { 0, 44 },     { 11, 38 },
  515.     { 1, 45 },   { 0, 46 },   { 5, 44 },     { 31, 17 },
  516.     { 1, 51 },   { 7, 50 },   { 28, 19 },    { 16, 33 },
  517.     { 14, 62 },  { -13, 108 },{ -15, 100 },
  518.     /* 136 -> 165 */
  519.     { -13, 101 },{ -13, 91 }, { -12, 94 },   { -10, 88 },
  520.     { -16, 84 }, { -10, 86 }, { -7, 83 },    { -13, 87 },
  521.     { -19, 94 }, { 1, 70 },   { 0, 72 },     { -5, 74 },
  522.     { 18, 59 },  { -8, 102 }, { -15, 100 },  { 0, 95 },
  523.     { -4, 75 },  { 2, 72 },   { -11, 75 },   { -3, 71 },
  524.     { 15, 46 },  { -13, 69 }, { 0, 62 },     { 0, 65 },
  525.     { 21, 37 },  { -15, 72 }, { 9, 57 },     { 16, 54 },
  526.     { 0, 62 },   { 12, 72 },
  527.     /* 166 -> 196 */
  528.     { 24, 0 },   { 15, 9 },   { 8, 25 },     { 13, 18 },
  529.     { 15, 9 },   { 13, 19 },  { 10, 37 },    { 12, 18 },
  530.     { 6, 29 },   { 20, 33 },  { 15, 30 },    { 4, 45 },
  531.     { 1, 58 },   { 0, 62 },   { 7, 61 },     { 12, 38 },
  532.     { 11, 45 },  { 15, 39 },  { 11, 42 },    { 13, 44 },
  533.     { 16, 45 },  { 12, 41 },  { 10, 49 },    { 30, 34 },
  534.     { 18, 42 },  { 10, 55 },  { 17, 51 },    { 17, 46 },
  535.     { 0, 89 },   { 26, -19 }, { 22, -17 },
  536.     /* 197 -> 226 */
  537.     { 26, -17 }, { 30, -25 }, { 28, -20 },   { 33, -23 },
  538.     { 37, -27 }, { 33, -23 }, { 40, -28 },   { 38, -17 },
  539.     { 33, -11 }, { 40, -15 }, { 41, -6 },    { 38, 1 },
  540.     { 41, 17 },  { 30, -6 },  { 27, 3 },     { 26, 22 },
  541.     { 37, -16 }, { 35, -4 },  { 38, -8 },    { 38, -3 },
  542.     { 37, 3 },   { 38, 5 },   { 42, 0 },     { 35, 16 },
  543.     { 39, 22 },  { 14, 48 },  { 27, 37 },    { 21, 60 },
  544.     { 12, 68 },  { 2, 97 },
  545.     /* 227 -> 251 */
  546.     { -3, 71 },  { -6, 42 },  { -5, 50 },    { -3, 54 },
  547.     { -2, 62 },  { 0, 58 },   { 1, 63 },     { -2, 72 },
  548.     { -1, 74 },  { -9, 91 },  { -5, 67 },    { -5, 27 },
  549.     { -3, 39 },  { -2, 44 },  { 0, 46 },     { -16, 64 },
  550.     { -8, 68 },  { -10, 78 }, { -6, 77 },    { -10, 86 },
  551.     { -12, 92 }, { -15, 55 }, { -10, 60 },   { -6, 62 },
  552.     { -4, 65 },
  553.     /* 252 -> 275 */
  554.     { -12, 73 }, { -8, 76 },  { -7, 80 },    { -9, 88 },
  555.     { -17, 110 },{ -11, 97 }, { -20, 84 },   { -11, 79 },
  556.     { -6, 73 },  { -4, 74 },  { -13, 86 },   { -13, 96 },
  557.     { -11, 97 }, { -19, 117 },{ -8, 78 },    { -5, 33 },
  558.     { -4, 48 },  { -2, 53 },  { -3, 62 },    { -13, 71 },
  559.     { -10, 79 }, { -12, 86 }, { -13, 90 },   { -14, 97 },
  560.     /* 276 a bit special (not used, bypass is used instead) */
  561.     { 0, 0 },
  562.     /* 277 -> 307 */
  563.     { -6, 93 },  { -6, 84 },  { -8, 79 },    { 0, 66 },
  564.     { -1, 71 },  { 0, 62 },   { -2, 60 },    { -2, 59 },
  565.     { -5, 75 },  { -3, 62 },  { -4, 58 },    { -9, 66 },
  566.     { -1, 79 },  { 0, 71 },   { 3, 68 },     { 10, 44 },
  567.     { -7, 62 },  { 15, 36 },  { 14, 40 },    { 16, 27 },
  568.     { 12, 29 },  { 1, 44 },   { 20, 36 },    { 18, 32 },
  569.     { 5, 42 },   { 1, 48 },   { 10, 62 },    { 17, 46 },
  570.     { 9, 64 },   { -12, 104 },{ -11, 97 },
  571.     /* 308 -> 337 */
  572.     { -16, 96 }, { -7, 88 },  { -8, 85 },    { -7, 85 },
  573.     { -9, 85 },  { -13, 88 }, { 4, 66 },     { -3, 77 },
  574.     { -3, 76 },  { -6, 76 },  { 10, 58 },    { -1, 76 },
  575.     { -1, 83 },  { -7, 99 },  { -14, 95 },   { 2, 95 },
  576.     { 0, 76 },   { -5, 74 },  { 0, 70 },     { -11, 75 },
  577.     { 1, 68 },   { 0, 65 },   { -14, 73 },   { 3, 62 },
  578.     { 4, 62 },   { -1, 68 },  { -13, 75 },   { 11, 55 },
  579.     { 5, 64 },   { 12, 70 },
  580.     /* 338 -> 368 */
  581.     { 15, 6 },   { 6, 19 },   { 7, 16 },     { 12, 14 },
  582.     { 18, 13 },  { 13, 11 },  { 13, 15 },    { 15, 16 },
  583.     { 12, 23 },  { 13, 23 },  { 15, 20 },    { 14, 26 },
  584.     { 14, 44 },  { 17, 40 },  { 17, 47 },    { 24, 17 },
  585.     { 21, 21 },  { 25, 22 },  { 31, 27 },    { 22, 29 },
  586.     { 19, 35 },  { 14, 50 },  { 10, 57 },    { 7, 63 },
  587.     { -2, 77 },  { -4, 82 },  { -3, 94 },    { 9, 69 },
  588.     { -12, 109 },{ 36, -35 }, { 36, -34 },
  589.     /* 369 -> 398 */
  590.     { 32, -26 }, { 37, -30 }, { 44, -32 },   { 34, -18 },
  591.     { 34, -15 }, { 40, -15 }, { 33, -7 },    { 35, -5 },
  592.     { 33, 0 },   { 38, 2 },   { 33, 13 },    { 23, 35 },
  593.     { 13, 58 },  { 29, -3 },  { 26, 0 },     { 22, 30 },
  594.     { 31, -7 },  { 35, -15 }, { 34, -3 },    { 34, 3 },
  595.     { 36, -1 },  { 34, 5 },   { 32, 11 },    { 35, 5 },
  596.     { 34, 12 },  { 39, 11 },  { 30, 29 },    { 34, 26 },
  597.     { 29, 39 },  { 19, 66 }
  598. };
  599. static const int cabac_context_init_PB[3][399][2] =
  600. {
  601.     /* i_cabac_init_idc == 0 */
  602.     {
  603.         /* 0 - 10 */
  604.         {  20, -15 }, {   2,  54 }, {   3,  74 }, {  20, -15 },
  605.         {   2,  54 }, {   3,  74 }, { -28, 127 }, { -23, 104 },
  606.         {  -6,  53 }, {  -1,  54 }, {   7,  51 },
  607.         /* 11 - 23 */
  608.         {  23,  33 }, {  23,   2 }, {  21,   0 }, {   1,   9 },
  609.         {   0,  49 }, { -37, 118 }, {   5,  57 }, { -13,  78 },
  610.         { -11,  65 }, {   1,  62 }, {  12,  49 }, {  -4,  73 },
  611.         {  17,  50 },
  612.         /* 24 - 39 */
  613.         {  18,  64 }, {   9,  43 }, {  29,   0 }, {  26,  67 },
  614.         {  16,  90 }, {   9, 104 }, { -46, 127 }, { -20, 104 },
  615.         {   1,  67 }, { -13,  78 }, { -11,  65 }, {   1,  62 },
  616.         {  -6,  86 }, { -17,  95 }, {  -6,  61 }, {   9,  45 },
  617.         /* 40 - 53 */
  618.         {  -3,  69 }, {  -6,  81 }, { -11,  96 }, {   6,  55 },
  619.         {   7,  67 }, {  -5,  86 }, {   2,  88 }, {   0,  58 },
  620.         {  -3,  76 }, { -10,  94 }, {   5,  54 }, {   4,  69 },
  621.         {  -3,  81 }, {   0,  88 },
  622.         /* 54 - 59 */
  623.         {  -7,  67 }, {  -5,  74 }, {  -4,  74 }, {  -5,  80 },
  624.         {  -7,  72 }, {   1,  58 },
  625.         /* 60 - 69 */
  626.         {   0,  41 }, {   0,  63 }, {   0,  63 }, { 0, 63 },
  627.         {  -9,  83 }, {   4,  86 }, {   0,  97 }, { -7, 72 },
  628.         {  13,  41 }, {   3,  62 },
  629.         /* 70 - 87 */
  630.         {   0,  45 }, {  -4,  78 }, {  -3,  96 }, { -27,  126 },
  631.         { -28,  98 }, { -25, 101 }, { -23,  67 }, { -28,  82 },
  632.         { -20,  94 }, { -16,  83 }, { -22, 110 }, { -21,  91 },
  633.         { -18, 102 }, { -13,  93 }, { -29, 127 }, {  -7,  92 },
  634.         {  -5,  89 }, {  -7,  96 }, { -13, 108 }, {  -3,  46 },
  635.         {  -1,  65 }, {  -1,  57 }, {  -9,  93 }, {  -3,  74 },
  636.         {  -9,  92 }, {  -8,  87 }, { -23, 126 }, {   5,  54 },
  637.         {   6,  60 }, {   6,  59 }, {   6,  69 }, {  -1,  48 },
  638.         {   0,  68 }, {  -4,  69 }, {  -8,  88 },
  639.         /* 105 -> 165 */
  640.         {  -2,  85 }, {  -6,  78 }, {  -1,  75 }, {  -7,  77 },
  641.         {   2,  54 }, {   5,  50 }, {  -3,  68 }, {   1,  50 },
  642.         {   6,  42 }, {  -4,  81 }, {   1,  63 }, {  -4,  70 },
  643.         {   0,  67 }, {   2,  57 }, {  -2,  76 }, {  11,  35 },
  644.         {   4,  64 }, {   1,  61 }, {  11,  35 }, {  18,  25 },
  645.         {  12,  24 }, {  13,  29 }, {  13,  36 }, { -10,  93 },
  646.         {  -7,  73 }, {  -2,  73 }, {  13,  46 }, {   9,  49 },
  647.         {  -7, 100 }, {   9,  53 }, {   2,  53 }, {   5,  53 },
  648.         {  -2,  61 }, {   0,  56 }, {   0,  56 }, { -13,  63 },
  649.         {  -5,  60 }, {  -1,  62 }, {   4,  57 }, {  -6,  69 },
  650.         {   4,  57 }, {  14,  39 }, {   4,  51 }, {  13,  68 },
  651.         {   3,  64 }, {   1,  61 }, {   9,  63 }, {   7,  50 },
  652.         {  16,  39 }, {   5,  44 }, {   4,  52 }, {  11,  48 },
  653.         {  -5,  60 }, {  -1,  59 }, {   0,  59 }, {  22,  33 },
  654.         {   5,  44 }, {  14,  43 }, {  -1,  78 }, {   0,  60 },
  655.         {   9,  69 },
  656.         /* 166 - 226 */
  657.         {  11,  28 }, {   2,  40 }, {   3,  44 }, {   0,  49 },
  658.         {   0,  46 }, {   2,  44 }, {   2,  51 }, {   0,  47 },
  659.         {   4,  39 }, {   2,  62 }, {   6,  46 }, {   0,  54 },
  660.         {   3,  54 }, {   2,  58 }, {   4,  63 }, {   6,  51 },
  661.         {   6,  57 }, {   7,  53 }, {   6,  52 }, {   6,  55 },
  662.         {  11,  45 }, {  14,  36 }, {   8,  53 }, {  -1,  82 },
  663.         {   7,  55 }, {  -3,  78 }, {  15,  46 }, {  22,  31 },
  664.         {  -1,  84 }, {  25,   7 }, {  30,  -7 }, {  28,   3 },
  665.         {  28,   4 }, {  32,   0 }, {  34,  -1 }, {  30,   6 },
  666.         {  30,   6 }, {  32,   9 }, {  31,  19 }, {  26,  27 },
  667.         {  26,  30 }, {  37,  20 }, {  28,  34 }, {  17,  70 },
  668.         {   1,  67 }, {   5,  59 }, {   9,  67 }, {  16,  30 },
  669.         {  18,  32 }, {  18,  35 }, {  22,  29 }, {  24,  31 },
  670.         {  23,  38 }, {  18,  43 }, {  20,  41 }, {  11,  63 },
  671.         {   9,  59 }, {   9,  64 }, {  -1,  94 }, {  -2,  89 },
  672.         {  -9, 108 },
  673.         /* 227 - 275 */
  674.         {  -6,  76 }, {  -2,  44 }, {   0,  45 }, {   0,  52 },
  675.         {  -3,  64 }, {  -2,  59 }, {  -4,  70 }, {  -4,  75 },
  676.         {  -8,  82 }, { -17, 102 }, {  -9,  77 }, {   3,  24 },
  677.         {   0,  42 }, {   0,  48 }, {   0,  55 }, {  -6,  59 },
  678.         {  -7,  71 }, { -12,  83 }, { -11,  87 }, { -30, 119 },
  679.         {   1,  58 }, {  -3,  29 }, {  -1,  36 }, {   1,  38 },
  680.         {   2,  43 }, {  -6,  55 }, {   0,  58 }, {   0,  64 },
  681.         {  -3,  74 }, { -10,  90 }, {   0,  70 }, {  -4,  29 },
  682.         {   5,  31 }, {   7,  42 }, {   1,  59 }, {  -2,  58 },
  683.         {  -3,  72 }, {  -3,  81 }, { -11,  97 }, {   0,  58 },
  684.         {   8,   5 }, {  10,  14 }, {  14,  18 }, {  13,  27 },
  685.         {   2,  40 }, {   0,  58 }, {  -3,  70 }, {  -6,  79 },
  686.         {  -8,  85 },
  687.         /* 276 a bit special (not used, bypass is used instead) */
  688.         { 0, 0 },
  689.         /* 277 - 337 */
  690.         { -13, 106 }, { -16, 106 }, { -10,  87 }, { -21, 114 },
  691.         { -18, 110 }, { -14,  98 }, { -22, 110 }, { -21, 106 },
  692.         { -18, 103 }, { -21, 107 }, { -23, 108 }, { -26, 112 },
  693.         { -10,  96 }, { -12,  95 }, {  -5,  91 }, {  -9,  93 },
  694.         { -22,  94 }, {  -5,  86 }, {   9,  67 }, {  -4,  80 },
  695.         { -10,  85 }, {  -1,  70 }, {   7,  60 }, {   9,  58 },
  696.         {   5,  61 }, {  12,  50 }, {  15,  50 }, {  18,  49 },
  697.         {  17,  54 }, {  10,  41 }, {   7,  46 }, {  -1,  51 },
  698.         {   7,  49 }, {   8,  52 }, {   9,  41 }, {   6,  47 },
  699.         {   2,  55 }, {  13,  41 }, {  10,  44 }, {   6,  50 },
  700.         {   5,  53 }, {  13,  49 }, {   4,  63 }, {   6,  64 },
  701.         {  -2,  69 }, {  -2,  59 }, {   6,  70 }, {  10,  44 },
  702.         {   9,  31 }, {  12,  43 }, {   3,  53 }, {  14,  34 },
  703.         {  10,  38 }, {  -3,  52 }, {  13,  40 }, {  17,  32 },
  704.         {   7,  44 }, {   7,  38 }, {  13,  50 }, {  10,  57 },
  705.         {  26,  43 },
  706.         /* 338 - 398 */
  707.         {  14,  11 }, {  11,  14 }, {   9,  11 }, {  18,  11 },
  708.         {  21,   9 }, {  23,  -2 }, {  32, -15 }, {  32, -15 },
  709.         {  34, -21 }, {  39, -23 }, {  42, -33 }, {  41, -31 },
  710.         {  46, -28 }, {  38, -12 }, {  21,  29 }, {  45, -24 },
  711.         {  53, -45 }, {  48, -26 }, {  65, -43 }, {  43, -19 },
  712.         {  39, -10 }, {  30,   9 }, {  18,  26 }, {  20,  27 },
  713.         {   0,  57 }, { -14,  82 }, {  -5,  75 }, { -19,  97 },
  714.         { -35, 125 }, {  27,   0 }, {  28,   0 }, {  31,  -4 },
  715.         {  27,   6 }, {  34,   8 }, {  30,  10 }, {  24,  22 },
  716.         {  33,  19 }, {  22,  32 }, {  26,  31 }, {  21,  41 },
  717.         {  26,  44 }, {  23,  47 }, {  16,  65 }, {  14,  71 },
  718.         {   8,  60 }, {   6,  63 }, {  17,  65 }, {  21,  24 },
  719.         {  23,  20 }, {  26,  23 }, {  27,  32 }, {  28,  23 },
  720.         {  28,  24 }, {  23,  40 }, {  24,  32 }, {  28,  29 },
  721.         {  23,  42 }, {  19,  57 }, {  22,  53 }, {  22,  61 },
  722.         {  11,  86 },
  723.     },
  724.     /* i_cabac_init_idc == 1 */
  725.     {
  726.         /* 0 - 10 */
  727.         {  20, -15 }, {   2,  54 }, {   3,  74 }, {  20, -15 },
  728.         {   2,  54 }, {   3,  74 }, { -28, 127 }, { -23, 104 },
  729.         {  -6,  53 }, {  -1,  54 }, {   7,  51 },
  730.         /* 11 - 23 */
  731.         {  22,  25 }, {  34,   0 }, {  16,   0 }, {  -2,   9 },
  732.         {   4,  41 }, { -29, 118 }, {   2,  65 }, {  -6,  71 },
  733.         { -13,  79 }, {   5,  52 }, {   9,  50 }, {  -3,  70 },
  734.         {  10,  54 },
  735.         /* 24 - 39 */
  736.         {  26,  34 }, {  19,  22 }, {  40,   0 }, {  57,   2 },
  737.         {  41,  36 }, {  26,  69 }, { -45, 127 }, { -15, 101 },
  738.         {  -4,  76 }, {  -6,  71 }, { -13,  79 }, {   5,  52 },
  739.         {   6,  69 }, { -13,  90 }, {   0,  52 }, {   8,  43 },
  740.         /* 40 - 53 */
  741.         {  -2,  69 },{  -5,  82 },{ -10,  96 },{   2,  59 },
  742.         {   2,  75 },{  -3,  87 },{  -3,  100 },{   1,  56 },
  743.         {  -3,  74 },{  -6,  85 },{   0,  59 },{  -3,  81 },
  744.         {  -7,  86 },{  -5,  95 },
  745.         /* 54 - 59 */
  746.         {  -1,  66 },{  -1,  77 },{   1,  70 },{  -2,  86 },
  747.         {  -5,  72 },{   0,  61 },
  748.         /* 60 - 69 */
  749.         { 0, 41 },   { 0, 63 },   { 0, 63 },     { 0, 63 },
  750.         { -9, 83 },  { 4, 86 },   { 0, 97 },     { -7, 72 },
  751.         { 13, 41 },  { 3, 62 },
  752.         /* 70 - 104 */
  753.         {  13,  15 }, {   7,  51 }, {   2,  80 }, { -39, 127 },
  754.         { -18,  91 }, { -17,  96 }, { -26,  81 }, { -35,  98 },
  755.         { -24, 102 }, { -23,  97 }, { -27, 119 }, { -24,  99 },
  756.         { -21, 110 }, { -18, 102 }, { -36, 127 }, {   0,  80 },
  757.         {  -5,  89 }, {  -7,  94 }, {  -4,  92 }, {   0,  39 },
  758.         {   0,  65 }, { -15,  84 }, { -35, 127 }, {  -2,  73 },
  759.         { -12, 104 }, {  -9,  91 }, { -31, 127 }, {   3,  55 },
  760.         {   7,  56 }, {   7,  55 }, {   8,  61 }, {  -3,  53 },
  761.         {   0,  68 }, {  -7,  74 }, {  -9,  88 },
  762.         /* 105 -> 165 */
  763.         { -13, 103 }, { -13,  91 }, {  -9,  89 }, { -14,  92 },
  764.         {  -8,  76 }, { -12,  87 }, { -23, 110 }, { -24, 105 },
  765.         { -10,  78 }, { -20, 112 }, { -17,  99 }, { -78, 127 },
  766.         { -70, 127 }, { -50, 127 }, { -46, 127 }, {  -4,  66 },
  767.         {  -5,  78 }, {  -4,  71 }, {  -8,  72 }, {   2,  59 },
  768.         {  -1,  55 }, {  -7,  70 }, {  -6,  75 }, {  -8,  89 },
  769.         { -34, 119 }, {  -3,  75 }, {  32,  20 }, {  30,  22 },
  770.         { -44, 127 }, {   0,  54 }, {  -5,  61 }, {   0,  58 },
  771.         {  -1,  60 }, {  -3,  61 }, {  -8,  67 }, { -25,  84 },
  772.         { -14,  74 }, {  -5,  65 }, {   5,  52 }, {   2,  57 },
  773.         {   0,  61 }, {  -9,  69 }, { -11,  70 }, {  18,  55 },
  774.         {  -4,  71 }, {   0,  58 }, {   7,  61 }, {   9,  41 },
  775.         {  18,  25 }, {   9,  32 }, {   5,  43 }, {   9,  47 },
  776.         {   0,  44 }, {   0,  51 }, {   2,  46 }, {  19,  38 },
  777.         {  -4,  66 }, {  15,  38 }, {  12,  42 }, {   9,  34 },
  778.         {   0,  89 },
  779.         /* 166 - 226 */
  780.         {   4,  45 }, {  10,  28 }, {  10,  31 }, {  33, -11 },
  781.         {  52, -43 }, {  18,  15 }, {  28,   0 }, {  35, -22 },
  782.         {  38, -25 }, {  34,   0 }, {  39, -18 }, {  32, -12 },
  783.         { 102, -94 }, {   0,   0 }, {  56, -15 }, {  33,  -4 },
  784.         {  29,  10 }, {  37,  -5 }, {  51, -29 }, {  39,  -9 },
  785.         {  52, -34 }, {  69, -58 }, {  67, -63 }, {  44,  -5 },
  786.         {  32,   7 }, {  55, -29 }, {  32,   1 }, {   0,   0 },
  787.         {  27,  36 }, {  33, -25 }, {  34, -30 }, {  36, -28 },
  788.         {  38, -28 }, {  38, -27 }, {  34, -18 }, {  35, -16 },
  789.         {  34, -14 }, {  32,  -8 }, {  37,  -6 }, {  35,   0 },
  790.         {  30,  10 }, {  28,  18 }, {  26,  25 }, {  29,  41 },
  791.         {   0,  75 }, {   2,  72 }, {   8,  77 }, {  14,  35 },
  792.         {  18,  31 }, {  17,  35 }, {  21,  30 }, {  17,  45 },
  793.         {  20,  42 }, {  18,  45 }, {  27,  26 }, {  16,  54 },
  794.         {   7,  66 }, {  16,  56 }, {  11,  73 }, {  10,  67 },
  795.         { -10, 116 },
  796.         /* 227 - 275 */
  797.         { -23, 112 }, { -15,  71 }, {  -7,  61 }, {   0,  53 },
  798.         {  -5,  66 }, { -11,  77 }, {  -9,  80 }, {  -9,  84 },
  799.         { -10,  87 }, { -34, 127 }, { -21, 101 }, {  -3,  39 },
  800.         {  -5,  53 }, {  -7,  61 }, { -11,  75 }, { -15,  77 },
  801.         { -17,  91 }, { -25, 107 }, { -25, 111 }, { -28, 122 },
  802.         { -11,  76 }, { -10,  44 }, { -10,  52 }, { -10,  57 },
  803.         {  -9,  58 }, { -16,  72 }, {  -7,  69 }, {  -4,  69 },
  804.         {  -5,  74 }, {  -9,  86 }, {   2,  66 }, {  -9,  34 },
  805.         {   1,  32 }, {  11,  31 }, {   5,  52 }, {  -2,  55 },
  806.         {  -2,  67 }, {   0,  73 }, {  -8,  89 }, {   3,  52 },
  807.         {   7,   4 }, {  10,   8 }, {  17,   8 }, {  16,  19 },
  808.         {   3,  37 }, {  -1,  61 }, {  -5,  73 }, {  -1,  70 },
  809.         {  -4,  78 },
  810.         /* 276 a bit special (not used, bypass is used instead) */
  811.         { 0, 0 },
  812.         /* 277 - 337 */
  813.         { -21, 126 }, { -23, 124 }, { -20, 110 }, { -26, 126 },
  814.         { -25, 124 }, { -17, 105 }, { -27, 121 }, { -27, 117 },
  815.         { -17, 102 }, { -26, 117 }, { -27, 116 }, { -33, 122 },
  816.         { -10,  95 }, { -14, 100 }, {  -8,  95 }, { -17, 111 },
  817.         { -28, 114 }, {  -6,  89 }, {  -2,  80 }, {  -4,  82 },
  818.         {  -9,  85 }, {  -8,  81 }, {  -1,  72 }, {   5,  64 },
  819.         {   1,  67 }, {   9,  56 }, {   0,  69 }, {   1,  69 },
  820.         {   7,  69 }, {  -7,  69 }, {  -6,  67 }, { -16,  77 },
  821.         {  -2,  64 }, {   2,  61 }, {  -6,  67 }, {  -3,  64 },
  822.         {   2,  57 }, {  -3,  65 }, {  -3,  66 }, {   0,  62 },
  823.         {   9,  51 }, {  -1,  66 }, {  -2,  71 }, {  -2,  75 },
  824.         {  -1,  70 }, {  -9,  72 }, {  14,  60 }, {  16,  37 },
  825.         {   0,  47 }, {  18,  35 }, {  11,  37 }, {  12,  41 },
  826.         {  10,  41 }, {   2,  48 }, {  12,  41 }, {  13,  41 },
  827.         {   0,  59 }, {   3,  50 }, {  19,  40 }, {   3,  66 },
  828.         {  18,  50 },
  829.         /* 338 - 398 */
  830.         {  19,  -6 }, {  18,  -6 }, {  14,   0 }, {  26, -12 },
  831.         {  31, -16 }, {  33, -25 }, {  33, -22 }, {  37, -28 },
  832.         {  39, -30 }, {  42, -30 }, {  47, -42 }, {  45, -36 },
  833.         {  49, -34 }, {  41, -17 }, {  32,   9 }, {  69, -71 },
  834.         {  63, -63 }, {  66, -64 }, {  77, -74 }, {  54, -39 },
  835.         {  52, -35 }, {  41, -10 }, {  36,   0 }, {  40,  -1 },
  836.         {  30,  14 }, {  28,  26 }, {  23,  37 }, {  12,  55 },
  837.         {  11,  65 }, {  37, -33 }, {  39, -36 }, {  40, -37 },
  838.         {  38, -30 }, {  46, -33 }, {  42, -30 }, {  40, -24 },
  839.         {  49, -29 }, {  38, -12 }, {  40, -10 }, {  38,  -3 },
  840.         {  46,  -5 }, {  31,  20 }, {  29,  30 }, {  25,  44 },
  841.         {  12,  48 }, {  11,  49 }, {  26,  45 }, {  22,  22 },
  842.         {  23,  22 }, {  27,  21 }, {  33,  20 }, {  26,  28 },
  843.         {  30,  24 }, {  27,  34 }, {  18,  42 }, {  25,  39 },
  844.         {  18,  50 }, {  12,  70 }, {  21,  54 }, {  14,  71 },
  845.         {  11,  83 },
  846.     },
  847.     /* i_cabac_init_idc == 2 */
  848.     {
  849.         /* 0 - 10 */
  850.         {  20, -15 }, {   2,  54 }, {   3,  74 }, {  20, -15 },
  851.         {   2,  54 }, {   3,  74 }, { -28, 127 }, { -23, 104 },
  852.         {  -6,  53 }, {  -1,  54 }, {   7,  51 },
  853.         /* 11 - 23 */
  854.         {  29,  16 }, {  25,   0 }, {  14,   0 }, { -10,  51 },
  855.         {  -3,  62 }, { -27,  99 }, {  26,  16 }, {  -4,  85 },
  856.         { -24, 102 }, {   5,  57 }, {   6,  57 }, { -17,  73 },
  857.         {  14,  57 },
  858.         /* 24 - 39 */
  859.         {  20,  40 }, {  20,  10 }, {  29,   0 }, {  54,   0 },
  860.         {  37,  42 }, {  12,  97 }, { -32, 127 }, { -22, 117 },
  861.         {  -2,  74 }, {  -4,  85 }, { -24, 102 }, {   5,  57 },
  862.         {  -6,  93 }, { -14,  88 }, {  -6,  44 }, {   4,  55 },
  863.         /* 40 - 53 */
  864.         { -11,  89 },{ -15,  103 },{ -21,  116 },{  19,  57 },
  865.         {  20,  58 },{   4,  84 },{   6,  96 },{   1,  63 },
  866.         {  -5,  85 },{ -13,  106 },{   5,  63 },{   6,  75 },
  867.         {  -3,  90 },{  -1,  101 },
  868.         /* 54 - 59 */
  869.         {   3,  55 },{  -4,  79 },{  -2,  75 },{ -12,  97 },
  870.         {  -7,  50 },{   1,  60 },
  871.         /* 60 - 69 */
  872.         { 0, 41 },   { 0, 63 },   { 0, 63 },     { 0, 63 },
  873.         { -9, 83 },  { 4, 86 },   { 0, 97 },     { -7, 72 },
  874.         { 13, 41 },  { 3, 62 },
  875.         /* 70 - 104 */
  876.         {   7,  34 }, {  -9,  88 }, { -20, 127 }, { -36, 127 },
  877.         { -17,  91 }, { -14,  95 }, { -25,  84 }, { -25,  86 },
  878.         { -12,  89 }, { -17,  91 }, { -31, 127 }, { -14,  76 },
  879.         { -18, 103 }, { -13,  90 }, { -37, 127 }, {  11,  80 },
  880.         {   5,  76 }, {   2,  84 }, {   5,  78 }, {  -6,  55 },
  881.         {   4,  61 }, { -14,  83 }, { -37, 127 }, {  -5,  79 },
  882.         { -11, 104 }, { -11,  91 }, { -30, 127 }, {   0,  65 },
  883.         {  -2,  79 }, {   0,  72 }, {  -4,  92 }, {  -6,  56 },
  884.         {   3,  68 }, {  -8,  71 }, { -13,  98 },
  885.         /* 105 -> 165 */
  886.         {  -4,  86 }, { -12,  88 }, {  -5,  82 }, {  -3,  72 },
  887.         {  -4,  67 }, {  -8,  72 }, { -16,  89 }, {  -9,  69 },
  888.         {  -1,  59 }, {   5,  66 }, {   4,  57 }, {  -4,  71 },
  889.         {  -2,  71 }, {   2,  58 }, {  -1,  74 }, {  -4,  44 },
  890.         {  -1,  69 }, {   0,  62 }, {  -7,  51 }, {  -4,  47 },
  891.         {  -6,  42 }, {  -3,  41 }, {  -6,  53 }, {   8,  76 },
  892.         {  -9,  78 }, { -11,  83 }, {   9,  52 }, {   0,  67 },
  893.         {  -5,  90 }, {   1,  67 }, { -15,  72 }, {  -5,  75 },
  894.         {  -8,  80 }, { -21,  83 }, { -21,  64 }, { -13,  31 },
  895.         { -25,  64 }, { -29,  94 }, {   9,  75 }, {  17,  63 },
  896.         {  -8,  74 }, {  -5,  35 }, {  -2,  27 }, {  13,  91 },
  897.         {   3,  65 }, {  -7,  69 }, {   8,  77 }, { -10,  66 },
  898.         {   3,  62 }, {  -3,  68 }, { -20,  81 }, {   0,  30 },
  899.         {   1,   7 }, {  -3,  23 }, { -21,  74 }, {  16,  66 },
  900.         { -23, 124 }, {  17,  37 }, {  44, -18 }, {  50, -34 },
  901.         { -22, 127 },
  902.         /* 166 - 226 */
  903.         {   4,  39 }, {   0,  42 }, {   7,  34 }, {  11,  29 },
  904.         {   8,  31 }, {   6,  37 }, {   7,  42 }, {   3,  40 },
  905.         {   8,  33 }, {  13,  43 }, {  13,  36 }, {   4,  47 },
  906.         {   3,  55 }, {   2,  58 }, {   6,  60 }, {   8,  44 },
  907.         {  11,  44 }, {  14,  42 }, {   7,  48 }, {   4,  56 },
  908.         {   4,  52 }, {  13,  37 }, {   9,  49 }, {  19,  58 },
  909.         {  10,  48 }, {  12,  45 }, {   0,  69 }, {  20,  33 },
  910.         {   8,  63 }, {  35, -18 }, {  33, -25 }, {  28,  -3 },
  911.         {  24,  10 }, {  27,   0 }, {  34, -14 }, {  52, -44 },
  912.         {  39, -24 }, {  19,  17 }, {  31,  25 }, {  36,  29 },
  913.         {  24,  33 }, {  34,  15 }, {  30,  20 }, {  22,  73 },
  914.         {  20,  34 }, {  19,  31 }, {  27,  44 }, {  19,  16 },
  915.         {  15,  36 }, {  15,  36 }, {  21,  28 }, {  25,  21 },
  916.         {  30,  20 }, {  31,  12 }, {  27,  16 }, {  24,  42 },
  917.         {   0,  93 }, {  14,  56 }, {  15,  57 }, {  26,  38 },
  918.         { -24, 127 },
  919.         /* 227 - 275 */
  920.         { -24, 115 }, { -22,  82 }, {  -9,  62 }, {   0,  53 },
  921.         {   0,  59 }, { -14,  85 }, { -13,  89 }, { -13,  94 },
  922.         { -11,  92 }, { -29, 127 }, { -21, 100 }, { -14,  57 },
  923.         { -12,  67 }, { -11,  71 }, { -10,  77 }, { -21,  85 },
  924.         { -16,  88 }, { -23, 104 }, { -15,  98 }, { -37, 127 },
  925.         { -10,  82 }, {  -8,  48 }, {  -8,  61 }, {  -8,  66 },
  926.         {  -7,  70 }, { -14,  75 }, { -10,  79 }, {  -9,  83 },
  927.         { -12,  92 }, { -18, 108 }, {  -4,  79 }, { -22,  69 },
  928.         { -16,  75 }, {  -2,  58 }, {   1,  58 }, { -13,  78 },
  929.         {  -9,  83 }, {  -4,  81 }, { -13,  99 }, { -13,  81 },
  930.         {  -6,  38 }, { -13,  62 }, {  -6,  58 }, {  -2,  59 },
  931.         { -16,  73 }, { -10,  76 }, { -13,  86 }, {  -9,  83 },
  932.         { -10,  87 },
  933.         /* 276 a bit special (not used, bypass is used instead) */
  934.         { 0, 0 },
  935.         /* 277 - 337 */
  936.         { -22, 127 }, { -25, 127 }, { -25, 120 }, { -27, 127 },
  937.         { -19, 114 }, { -23, 117 }, { -25, 118 }, { -26, 117 },
  938.         { -24, 113 }, { -28, 118 }, { -31, 120 }, { -37, 124 },
  939.         { -10,  94 }, { -15, 102 }, { -10,  99 }, { -13, 106 },
  940.         { -50, 127 }, {  -5,  92 }, {  17,  57 }, {  -5,  86 },
  941.         { -13,  94 }, { -12,  91 }, {  -2,  77 }, {   0,  71 },
  942.         {  -1,  73 }, {   4,  64 }, {  -7,  81 }, {   5,  64 },
  943.         {  15,  57 }, {   1,  67 }, {   0,  68 }, { -10,  67 },
  944.         {   1,  68 }, {   0,  77 }, {   2,  64 }, {   0,  68 },
  945.         {  -5,  78 }, {   7,  55 }, {   5,  59 }, {   2,  65 },
  946.         {  14,  54 }, {  15,  44 }, {   5,  60 }, {   2,  70 },
  947.         {  -2,  76 }, { -18,  86 }, {  12,  70 }, {   5,  64 },
  948.         { -12,  70 }, {  11,  55 }, {   5,  56 }, {   0,  69 },
  949.         {   2,  65 }, {  -6,  74 }, {   5,  54 }, {   7,  54 },
  950.         {  -6,  76 }, { -11,  82 }, {  -2,  77 }, {  -2,  77 },
  951.         {  25,  42 },
  952.         /* 338 - 398 */
  953.         {  17, -13 }, {  16,  -9 }, {  17, -12 }, {  27, -21 },
  954.         {  37, -30 }, {  41, -40 }, {  42, -41 }, {  48, -47 },
  955.         {  39, -32 }, {  46, -40 }, {  52, -51 }, {  46, -41 },
  956.         {  52, -39 }, {  43, -19 }, {  32,  11 }, {  61, -55 },
  957.         {  56, -46 }, {  62, -50 }, {  81, -67 }, {  45, -20 },
  958.         {  35,  -2 }, {  28,  15 }, {  34,   1 }, {  39,   1 },
  959.         {  30,  17 }, {  20,  38 }, {  18,  45 }, {  15,  54 },
  960.         {   0,  79 }, {  36, -16 }, {  37, -14 }, {  37, -17 },
  961.         {  32,   1 }, {  34,  15 }, {  29,  15 }, {  24,  25 },
  962.         {  34,  22 }, {  31,  16 }, {  35,  18 }, {  31,  28 },
  963.         {  33,  41 }, {  36,  28 }, {  27,  47 }, {  21,  62 },
  964.         {  18,  31 }, {  19,  26 }, {  36,  24 }, {  24,  23 },
  965.         {  27,  16 }, {  24,  30 }, {  31,  29 }, {  22,  41 },
  966.         {  22,  42 }, {  16,  60 }, {  15,  52 }, {  14,  60 },
  967.         {   3,  78 }, { -16, 123 }, {  21,  53 }, {  22,  56 },
  968.         {  25,  61 },
  969.     }
  970. };