1/* 2 * H.263+ tables 3 * 4 * This file is part of FFmpeg. 5 * 6 * FFmpeg is free software; you can redistribute it and/or 7 * modify it under the terms of the GNU Lesser General Public 8 * License as published by the Free Software Foundation; either 9 * version 2.1 of the License, or (at your option) any later version. 10 * 11 * FFmpeg is distributed in the hope that it will be useful, 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14 * Lesser General Public License for more details. 15 * 16 * You should have received a copy of the GNU Lesser General Public 17 * License along with FFmpeg; if not, write to the Free Software 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 19 */ 20 21/** 22 * @file 23 * H.263 tables. 24 */ 25 26#include <stdint.h> 27 28#include "h263data.h" 29#include "rl.h" 30 31/* intra MCBPC, mb_type = (intra), then (intraq) */ 32const uint8_t ff_h263_intra_MCBPC_code[9] = { 1, 1, 2, 3, 1, 1, 2, 3, 1 }; 33const uint8_t ff_h263_intra_MCBPC_bits[9] = { 1, 3, 3, 3, 4, 6, 6, 6, 9 }; 34 35/* inter MCBPC, mb_type = (inter), (intra), (interq), (intraq), (inter4v) */ 36/* Changed the tables for interq and inter4v+q, following the standard 37 * ** Juanjo ** */ 38const uint8_t ff_h263_inter_MCBPC_code[28] = { 39 1, 3, 2, 5, 40 3, 4, 3, 3, 41 3, 7, 6, 5, 42 4, 4, 3, 2, 43 2, 5, 4, 5, 44 1, 0, 0, 0, /* Stuffing */ 45 2, 12, 14, 15, 46}; 47const uint8_t ff_h263_inter_MCBPC_bits[28] = { 48 1, 4, 4, 6, /* inter */ 49 5, 8, 8, 7, /* intra */ 50 3, 7, 7, 9, /* interQ */ 51 6, 9, 9, 9, /* intraQ */ 52 3, 7, 7, 8, /* inter4 */ 53 9, 0, 0, 0, /* Stuffing */ 54 11, 13, 13, 13, /* inter4Q */ 55}; 56 57const uint8_t ff_h263_mbtype_b_tab[15][2] = { 58 { 1, 1 }, 59 { 3, 3 }, 60 { 1, 5 }, 61 { 4, 4 }, 62 { 5, 4 }, 63 { 6, 6 }, 64 { 2, 4 }, 65 { 3, 4 }, 66 { 7, 6 }, 67 { 4, 6 }, 68 { 5, 6 }, 69 { 1, 6 }, 70 { 1, 10 }, 71 { 1, 7 }, 72 { 1, 8 }, 73}; 74 75const uint8_t ff_cbpc_b_tab[4][2] = { 76 { 0, 1 }, 77 { 2, 2 }, 78 { 7, 3 }, 79 { 6, 3 }, 80}; 81 82const uint8_t ff_h263_cbpy_tab[16][2] = { 83 { 3, 4 }, { 5, 5 }, { 4, 5 }, { 9, 4 }, { 3, 5 }, { 7, 4 }, { 2, 6 }, 84 { 11, 4 }, { 2, 5 }, { 3, 6 }, { 5, 4 }, { 10, 4 }, { 4, 4 }, { 8, 4 }, 85 { 6, 4 }, { 3, 2 } 86}; 87 88const uint8_t ff_mvtab[33][2] = { 89 { 1, 1 }, { 1, 2 }, { 1, 3 }, { 1, 4 }, { 3, 6 }, { 5, 7 }, 90 { 4, 7 }, { 3, 7 }, { 11, 9 }, { 10, 9 }, { 9, 9 }, { 17, 10 }, 91 { 16, 10 }, { 15, 10 }, { 14, 10 }, { 13, 10 }, { 12, 10 }, { 11, 10 }, 92 { 10, 10 }, { 9, 10 }, { 8, 10 }, { 7, 10 }, { 6, 10 }, { 5, 10 }, 93 { 4, 10 }, { 7, 11 }, { 6, 11 }, { 5, 11 }, { 4, 11 }, { 3, 11 }, 94 { 2, 11 }, { 3, 12 }, { 2, 12 } 95}; 96 97/* third non intra table */ 98const uint16_t ff_inter_vlc[103][2] = { 99 { 0x2, 2 }, { 0xf, 4 }, { 0x15, 6 }, { 0x17, 7 }, 100 { 0x1f, 8 }, { 0x25, 9 }, { 0x24, 9 }, { 0x21, 10 }, 101 { 0x20, 10 }, { 0x7, 11 }, { 0x6, 11 }, { 0x20, 11 }, 102 { 0x6, 3 }, { 0x14, 6 }, { 0x1e, 8 }, { 0xf, 10 }, 103 { 0x21, 11 }, { 0x50, 12 }, { 0xe, 4 }, { 0x1d, 8 }, 104 { 0xe, 10 }, { 0x51, 12 }, { 0xd, 5 }, { 0x23, 9 }, 105 { 0xd, 10 }, { 0xc, 5 }, { 0x22, 9 }, { 0x52, 12 }, 106 { 0xb, 5 }, { 0xc, 10 }, { 0x53, 12 }, { 0x13, 6 }, 107 { 0xb, 10 }, { 0x54, 12 }, { 0x12, 6 }, { 0xa, 10 }, 108 { 0x11, 6 }, { 0x9, 10 }, { 0x10, 6 }, { 0x8, 10 }, 109 { 0x16, 7 }, { 0x55, 12 }, { 0x15, 7 }, { 0x14, 7 }, 110 { 0x1c, 8 }, { 0x1b, 8 }, { 0x21, 9 }, { 0x20, 9 }, 111 { 0x1f, 9 }, { 0x1e, 9 }, { 0x1d, 9 }, { 0x1c, 9 }, 112 { 0x1b, 9 }, { 0x1a, 9 }, { 0x22, 11 }, { 0x23, 11 }, 113 { 0x56, 12 }, { 0x57, 12 }, { 0x7, 4 }, { 0x19, 9 }, 114 { 0x5, 11 }, { 0xf, 6 }, { 0x4, 11 }, { 0xe, 6 }, 115 { 0xd, 6 }, { 0xc, 6 }, { 0x13, 7 }, { 0x12, 7 }, 116 { 0x11, 7 }, { 0x10, 7 }, { 0x1a, 8 }, { 0x19, 8 }, 117 { 0x18, 8 }, { 0x17, 8 }, { 0x16, 8 }, { 0x15, 8 }, 118 { 0x14, 8 }, { 0x13, 8 }, { 0x18, 9 }, { 0x17, 9 }, 119 { 0x16, 9 }, { 0x15, 9 }, { 0x14, 9 }, { 0x13, 9 }, 120 { 0x12, 9 }, { 0x11, 9 }, { 0x7, 10 }, { 0x6, 10 }, 121 { 0x5, 10 }, { 0x4, 10 }, { 0x24, 11 }, { 0x25, 11 }, 122 { 0x26, 11 }, { 0x27, 11 }, { 0x58, 12 }, { 0x59, 12 }, 123 { 0x5a, 12 }, { 0x5b, 12 }, { 0x5c, 12 }, { 0x5d, 12 }, 124 { 0x5e, 12 }, { 0x5f, 12 }, { 0x3, 7 }, 125}; 126 127const int8_t ff_inter_level[102] = { 128 1, 2, 3, 4, 5, 6, 7, 8, 129 9, 10, 11, 12, 1, 2, 3, 4, 130 5, 6, 1, 2, 3, 4, 1, 2, 131 3, 1, 2, 3, 1, 2, 3, 1, 132 2, 3, 1, 2, 1, 2, 1, 2, 133 1, 2, 1, 1, 1, 1, 1, 1, 134 1, 1, 1, 1, 1, 1, 1, 1, 135 1, 1, 1, 2, 3, 1, 2, 1, 136 1, 1, 1, 1, 1, 1, 1, 1, 137 1, 1, 1, 1, 1, 1, 1, 1, 138 1, 1, 1, 1, 1, 1, 1, 1, 139 1, 1, 1, 1, 1, 1, 1, 1, 140 1, 1, 1, 1, 1, 1, 141}; 142 143const int8_t ff_inter_run[102] = { 144 0, 0, 0, 0, 0, 0, 0, 0, 145 0, 0, 0, 0, 1, 1, 1, 1, 146 1, 1, 2, 2, 2, 2, 3, 3, 147 3, 4, 4, 4, 5, 5, 5, 6, 148 6, 6, 7, 7, 8, 8, 9, 9, 149 10, 10, 11, 12, 13, 14, 15, 16, 150 17, 18, 19, 20, 21, 22, 23, 24, 151 25, 26, 0, 0, 0, 1, 1, 2, 152 3, 4, 5, 6, 7, 8, 9, 10, 153 11, 12, 13, 14, 15, 16, 17, 18, 154 19, 20, 21, 22, 23, 24, 25, 26, 155 27, 28, 29, 30, 31, 32, 33, 34, 156 35, 36, 37, 38, 39, 40, 157}; 158 159RLTable ff_h263_rl_inter = { 160 102, 161 58, 162 ff_inter_vlc, 163 ff_inter_run, 164 ff_inter_level, 165}; 166 167static const uint16_t intra_vlc_aic[103][2] = { 168 { 0x2, 2 }, { 0x6, 3 }, { 0xe, 4 }, { 0xc, 5 }, 169 { 0xd, 5 }, { 0x10, 6 }, { 0x11, 6 }, { 0x12, 6 }, 170 { 0x16, 7 }, { 0x1b, 8 }, { 0x20, 9 }, { 0x21, 9 }, 171 { 0x1a, 9 }, { 0x1b, 9 }, { 0x1c, 9 }, { 0x1d, 9 }, 172 { 0x1e, 9 }, { 0x1f, 9 }, { 0x23, 11 }, { 0x22, 11 }, 173 { 0x57, 12 }, { 0x56, 12 }, { 0x55, 12 }, { 0x54, 12 }, 174 { 0x53, 12 }, { 0xf, 4 }, { 0x14, 6 }, { 0x14, 7 }, 175 { 0x1e, 8 }, { 0xf, 10 }, { 0x21, 11 }, { 0x50, 12 }, 176 { 0xb, 5 }, { 0x15, 7 }, { 0xe, 10 }, { 0x9, 10 }, 177 { 0x15, 6 }, { 0x1d, 8 }, { 0xd, 10 }, { 0x51, 12 }, 178 { 0x13, 6 }, { 0x23, 9 }, { 0x7, 11 }, { 0x17, 7 }, 179 { 0x22, 9 }, { 0x52, 12 }, { 0x1c, 8 }, { 0xc, 10 }, 180 { 0x1f, 8 }, { 0xb, 10 }, { 0x25, 9 }, { 0xa, 10 }, 181 { 0x24, 9 }, { 0x6, 11 }, { 0x21, 10 }, { 0x20, 10 }, 182 { 0x8, 10 }, { 0x20, 11 }, { 0x7, 4 }, { 0xc, 6 }, 183 { 0x10, 7 }, { 0x13, 8 }, { 0x11, 9 }, { 0x12, 9 }, 184 { 0x4, 10 }, { 0x27, 11 }, { 0x26, 11 }, { 0x5f, 12 }, 185 { 0xf, 6 }, { 0x13, 9 }, { 0x5, 10 }, { 0x25, 11 }, 186 { 0xe, 6 }, { 0x14, 9 }, { 0x24, 11 }, { 0xd, 6 }, 187 { 0x6, 10 }, { 0x5e, 12 }, { 0x11, 7 }, { 0x7, 10 }, 188 { 0x13, 7 }, { 0x5d, 12 }, { 0x12, 7 }, { 0x5c, 12 }, 189 { 0x14, 8 }, { 0x5b, 12 }, { 0x15, 8 }, { 0x1a, 8 }, 190 { 0x19, 8 }, { 0x18, 8 }, { 0x17, 8 }, { 0x16, 8 }, 191 { 0x19, 9 }, { 0x15, 9 }, { 0x16, 9 }, { 0x18, 9 }, 192 { 0x17, 9 }, { 0x4, 11 }, { 0x5, 11 }, { 0x58, 12 }, 193 { 0x59, 12 }, { 0x5a, 12 }, { 0x3, 7 }, 194}; 195 196static const int8_t intra_run_aic[102] = { 197 0, 0, 0, 0, 0, 0, 0, 0, 198 0, 0, 0, 0, 0, 0, 0, 0, 199 0, 0, 0, 0, 0, 0, 0, 0, 200 0, 1, 1, 1, 1, 1, 1, 1, 201 2, 2, 2, 2, 3, 3, 3, 3, 202 4, 4, 4, 5, 5, 5, 6, 6, 203 7, 7, 8, 8, 9, 9, 10, 11, 204 12, 13, 0, 0, 0, 0, 0, 0, 205 0, 0, 0, 0, 1, 1, 1, 1, 206 2, 2, 2, 3, 3, 3, 4, 4, 207 5, 5, 6, 6, 7, 7, 8, 9, 208 10, 11, 12, 13, 14, 15, 16, 17, 209 18, 19, 20, 21, 22, 23, 210}; 211 212static const int8_t intra_level_aic[102] = { 213 1, 2, 3, 4, 5, 6, 7, 8, 214 9, 10, 11, 12, 13, 14, 15, 16, 215 17, 18, 19, 20, 21, 22, 23, 24, 216 25, 1, 2, 3, 4, 5, 6, 7, 217 1, 2, 3, 4, 1, 2, 3, 4, 218 1, 2, 3, 1, 2, 3, 1, 2, 219 1, 2, 1, 2, 1, 2, 1, 1, 220 1, 1, 1, 2, 3, 4, 5, 6, 221 7, 8, 9, 10, 1, 2, 3, 4, 222 1, 2, 3, 1, 2, 3, 1, 2, 223 1, 2, 1, 2, 1, 2, 1, 1, 224 1, 1, 1, 1, 1, 1, 1, 1, 225 1, 1, 1, 1, 1, 1, 226}; 227 228RLTable ff_rl_intra_aic = { 229 102, 230 58, 231 intra_vlc_aic, 232 intra_run_aic, 233 intra_level_aic, 234}; 235 236const uint16_t ff_h263_format[8][2] = { 237 { 0, 0 }, 238 { 128, 96 }, 239 { 176, 144 }, 240 { 352, 288 }, 241 { 704, 576 }, 242 { 1408, 1152 }, 243}; 244 245const uint8_t ff_aic_dc_scale_table[32] = { 246// 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 30 31 247 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 62 248}; 249 250const uint8_t ff_modified_quant_tab[2][32] = { 251// 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 30 31 252 { 253 0, 3, 1, 2, 3, 4, 5, 6, 7, 8, 9, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28 254 }, 255 { 256 0, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 24, 25, 26, 27, 28, 29, 30, 31, 31, 31, 26 257 } 258}; 259 260const uint8_t ff_h263_chroma_qscale_table[32] = { 261// 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 30 31 262 0, 1, 2, 3, 4, 5, 6, 6, 7, 8, 9, 9, 10, 10, 11, 11, 12, 12, 12, 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15 263}; 264 265const uint16_t ff_mba_max[6] = { 266 47, 98, 395, 1583, 6335, 9215 267}; 268 269const uint8_t ff_mba_length[7] = { 270 6, 7, 9, 11, 13, 14, 14 271}; 272 273const AVRational ff_h263_pixel_aspect[16] = { 274 { 0, 1 }, 275 { 1, 1 }, 276 { 12, 11 }, 277 { 10, 11 }, 278 { 16, 11 }, 279 { 40, 33 }, 280 { 0, 1 }, 281 { 0, 1 }, 282 { 0, 1 }, 283 { 0, 1 }, 284 { 0, 1 }, 285 { 0, 1 }, 286 { 0, 1 }, 287 { 0, 1 }, 288 { 0, 1 }, 289 { 0, 1 }, 290}; 291