You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

434 lines
11KB

  1. /**
  2. * @file mpeg12data.h
  3. * MPEG1/2 tables.
  4. */
  5. const int16_t ff_mpeg1_default_intra_matrix[64] = {
  6. 8, 16, 19, 22, 26, 27, 29, 34,
  7. 16, 16, 22, 24, 27, 29, 34, 37,
  8. 19, 22, 26, 27, 29, 34, 34, 38,
  9. 22, 22, 26, 27, 29, 34, 37, 40,
  10. 22, 26, 27, 29, 32, 35, 40, 48,
  11. 26, 27, 29, 32, 35, 40, 48, 58,
  12. 26, 27, 29, 34, 38, 46, 56, 69,
  13. 27, 29, 35, 38, 46, 56, 69, 83
  14. };
  15. const int16_t ff_mpeg1_default_non_intra_matrix[64] = {
  16. 16, 16, 16, 16, 16, 16, 16, 16,
  17. 16, 16, 16, 16, 16, 16, 16, 16,
  18. 16, 16, 16, 16, 16, 16, 16, 16,
  19. 16, 16, 16, 16, 16, 16, 16, 16,
  20. 16, 16, 16, 16, 16, 16, 16, 16,
  21. 16, 16, 16, 16, 16, 16, 16, 16,
  22. 16, 16, 16, 16, 16, 16, 16, 16,
  23. 16, 16, 16, 16, 16, 16, 16, 16,
  24. };
  25. const unsigned char vlc_dc_table[256] = {
  26. 0, 1, 2, 2,
  27. 3, 3, 3, 3,
  28. 4, 4, 4, 4, 4, 4, 4, 4,
  29. 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
  30. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  31. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  32. 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  33. 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  34. 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  35. 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  36. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  37. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  38. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  39. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  40. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  41. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  42. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  43. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  44. };
  45. const uint16_t vlc_dc_lum_code[12] = {
  46. 0x4, 0x0, 0x1, 0x5, 0x6, 0xe, 0x1e, 0x3e, 0x7e, 0xfe, 0x1fe, 0x1ff,
  47. };
  48. const unsigned char vlc_dc_lum_bits[12] = {
  49. 3, 2, 2, 3, 3, 4, 5, 6, 7, 8, 9, 9,
  50. };
  51. const uint16_t vlc_dc_chroma_code[12] = {
  52. 0x0, 0x1, 0x2, 0x6, 0xe, 0x1e, 0x3e, 0x7e, 0xfe, 0x1fe, 0x3fe, 0x3ff,
  53. };
  54. const unsigned char vlc_dc_chroma_bits[12] = {
  55. 2, 2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10,
  56. };
  57. /* simple include everything table for dc, first byte is bits number next 3 are code*/
  58. static uint32_t mpeg1_lum_dc_uni[512];
  59. static uint32_t mpeg1_chr_dc_uni[512];
  60. static const uint16_t mpeg1_vlc[113][2] = {
  61. { 0x3, 2 }, { 0x4, 4 }, { 0x5, 5 }, { 0x6, 7 },
  62. { 0x26, 8 }, { 0x21, 8 }, { 0xa, 10 }, { 0x1d, 12 },
  63. { 0x18, 12 }, { 0x13, 12 }, { 0x10, 12 }, { 0x1a, 13 },
  64. { 0x19, 13 }, { 0x18, 13 }, { 0x17, 13 }, { 0x1f, 14 },
  65. { 0x1e, 14 }, { 0x1d, 14 }, { 0x1c, 14 }, { 0x1b, 14 },
  66. { 0x1a, 14 }, { 0x19, 14 }, { 0x18, 14 }, { 0x17, 14 },
  67. { 0x16, 14 }, { 0x15, 14 }, { 0x14, 14 }, { 0x13, 14 },
  68. { 0x12, 14 }, { 0x11, 14 }, { 0x10, 14 }, { 0x18, 15 },
  69. { 0x17, 15 }, { 0x16, 15 }, { 0x15, 15 }, { 0x14, 15 },
  70. { 0x13, 15 }, { 0x12, 15 }, { 0x11, 15 }, { 0x10, 15 },
  71. { 0x3, 3 }, { 0x6, 6 }, { 0x25, 8 }, { 0xc, 10 },
  72. { 0x1b, 12 }, { 0x16, 13 }, { 0x15, 13 }, { 0x1f, 15 },
  73. { 0x1e, 15 }, { 0x1d, 15 }, { 0x1c, 15 }, { 0x1b, 15 },
  74. { 0x1a, 15 }, { 0x19, 15 }, { 0x13, 16 }, { 0x12, 16 },
  75. { 0x11, 16 }, { 0x10, 16 }, { 0x5, 4 }, { 0x4, 7 },
  76. { 0xb, 10 }, { 0x14, 12 }, { 0x14, 13 }, { 0x7, 5 },
  77. { 0x24, 8 }, { 0x1c, 12 }, { 0x13, 13 }, { 0x6, 5 },
  78. { 0xf, 10 }, { 0x12, 12 }, { 0x7, 6 }, { 0x9, 10 },
  79. { 0x12, 13 }, { 0x5, 6 }, { 0x1e, 12 }, { 0x14, 16 },
  80. { 0x4, 6 }, { 0x15, 12 }, { 0x7, 7 }, { 0x11, 12 },
  81. { 0x5, 7 }, { 0x11, 13 }, { 0x27, 8 }, { 0x10, 13 },
  82. { 0x23, 8 }, { 0x1a, 16 }, { 0x22, 8 }, { 0x19, 16 },
  83. { 0x20, 8 }, { 0x18, 16 }, { 0xe, 10 }, { 0x17, 16 },
  84. { 0xd, 10 }, { 0x16, 16 }, { 0x8, 10 }, { 0x15, 16 },
  85. { 0x1f, 12 }, { 0x1a, 12 }, { 0x19, 12 }, { 0x17, 12 },
  86. { 0x16, 12 }, { 0x1f, 13 }, { 0x1e, 13 }, { 0x1d, 13 },
  87. { 0x1c, 13 }, { 0x1b, 13 }, { 0x1f, 16 }, { 0x1e, 16 },
  88. { 0x1d, 16 }, { 0x1c, 16 }, { 0x1b, 16 },
  89. { 0x1, 6 }, /* escape */
  90. { 0x2, 2 }, /* EOB */
  91. };
  92. static const uint16_t mpeg2_vlc[113][2] = {
  93. {0x02, 2}, {0x06, 3}, {0x07, 4}, {0x1c, 5},
  94. {0x1d, 5}, {0x05, 6}, {0x04, 6}, {0x7b, 7},
  95. {0x7c, 7}, {0x23, 8}, {0x22, 8}, {0xfa, 8},
  96. {0xfb, 8}, {0xfe, 8}, {0xff, 8}, {0x1f,14},
  97. {0x1e,14}, {0x1d,14}, {0x1c,14}, {0x1b,14},
  98. {0x1a,14}, {0x19,14}, {0x18,14}, {0x17,14},
  99. {0x16,14}, {0x15,14}, {0x14,14}, {0x13,14},
  100. {0x12,14}, {0x11,14}, {0x10,14}, {0x18,15},
  101. {0x17,15}, {0x16,15}, {0x15,15}, {0x14,15},
  102. {0x13,15}, {0x12,15}, {0x11,15}, {0x10,15},
  103. {0x02, 3}, {0x06, 5}, {0x79, 7}, {0x27, 8},
  104. {0x20, 8}, {0x16,13}, {0x15,13}, {0x1f,15},
  105. {0x1e,15}, {0x1d,15}, {0x1c,15}, {0x1b,15},
  106. {0x1a,15}, {0x19,15}, {0x13,16}, {0x12,16},
  107. {0x11,16}, {0x10,16}, {0x05, 5}, {0x07, 7},
  108. {0xfc, 8}, {0x0c,10}, {0x14,13}, {0x07, 5},
  109. {0x26, 8}, {0x1c,12}, {0x13,13}, {0x06, 6},
  110. {0xfd, 8}, {0x12,12}, {0x07, 6}, {0x04, 9},
  111. {0x12,13}, {0x06, 7}, {0x1e,12}, {0x14,16},
  112. {0x04, 7}, {0x15,12}, {0x05, 7}, {0x11,12},
  113. {0x78, 7}, {0x11,13}, {0x7a, 7}, {0x10,13},
  114. {0x21, 8}, {0x1a,16}, {0x25, 8}, {0x19,16},
  115. {0x24, 8}, {0x18,16}, {0x05, 9}, {0x17,16},
  116. {0x07, 9}, {0x16,16}, {0x0d,10}, {0x15,16},
  117. {0x1f,12}, {0x1a,12}, {0x19,12}, {0x17,12},
  118. {0x16,12}, {0x1f,13}, {0x1e,13}, {0x1d,13},
  119. {0x1c,13}, {0x1b,13}, {0x1f,16}, {0x1e,16},
  120. {0x1d,16}, {0x1c,16}, {0x1b,16},
  121. {0x01,6}, /* escape */
  122. {0x06,4}, /* EOB */
  123. };
  124. static const int8_t mpeg1_level[111] = {
  125. 1, 2, 3, 4, 5, 6, 7, 8,
  126. 9, 10, 11, 12, 13, 14, 15, 16,
  127. 17, 18, 19, 20, 21, 22, 23, 24,
  128. 25, 26, 27, 28, 29, 30, 31, 32,
  129. 33, 34, 35, 36, 37, 38, 39, 40,
  130. 1, 2, 3, 4, 5, 6, 7, 8,
  131. 9, 10, 11, 12, 13, 14, 15, 16,
  132. 17, 18, 1, 2, 3, 4, 5, 1,
  133. 2, 3, 4, 1, 2, 3, 1, 2,
  134. 3, 1, 2, 3, 1, 2, 1, 2,
  135. 1, 2, 1, 2, 1, 2, 1, 2,
  136. 1, 2, 1, 2, 1, 2, 1, 2,
  137. 1, 1, 1, 1, 1, 1, 1, 1,
  138. 1, 1, 1, 1, 1, 1, 1,
  139. };
  140. static const int8_t mpeg1_run[111] = {
  141. 0, 0, 0, 0, 0, 0, 0, 0,
  142. 0, 0, 0, 0, 0, 0, 0, 0,
  143. 0, 0, 0, 0, 0, 0, 0, 0,
  144. 0, 0, 0, 0, 0, 0, 0, 0,
  145. 0, 0, 0, 0, 0, 0, 0, 0,
  146. 1, 1, 1, 1, 1, 1, 1, 1,
  147. 1, 1, 1, 1, 1, 1, 1, 1,
  148. 1, 1, 2, 2, 2, 2, 2, 3,
  149. 3, 3, 3, 4, 4, 4, 5, 5,
  150. 5, 6, 6, 6, 7, 7, 8, 8,
  151. 9, 9, 10, 10, 11, 11, 12, 12,
  152. 13, 13, 14, 14, 15, 15, 16, 16,
  153. 17, 18, 19, 20, 21, 22, 23, 24,
  154. 25, 26, 27, 28, 29, 30, 31,
  155. };
  156. static uint8_t mpeg1_index_run[2][64];
  157. static int8_t mpeg1_max_level[2][64];
  158. static RLTable rl_mpeg1 = {
  159. 111,
  160. 111,
  161. mpeg1_vlc,
  162. mpeg1_run,
  163. mpeg1_level,
  164. };
  165. static RLTable rl_mpeg2 = {
  166. 111,
  167. 111,
  168. mpeg2_vlc,
  169. mpeg1_run,
  170. mpeg1_level,
  171. };
  172. static const uint8_t mbAddrIncrTable[36][2] = {
  173. {0x1, 1},
  174. {0x3, 3},
  175. {0x2, 3},
  176. {0x3, 4},
  177. {0x2, 4},
  178. {0x3, 5},
  179. {0x2, 5},
  180. {0x7, 7},
  181. {0x6, 7},
  182. {0xb, 8},
  183. {0xa, 8},
  184. {0x9, 8},
  185. {0x8, 8},
  186. {0x7, 8},
  187. {0x6, 8},
  188. {0x17, 10},
  189. {0x16, 10},
  190. {0x15, 10},
  191. {0x14, 10},
  192. {0x13, 10},
  193. {0x12, 10},
  194. {0x23, 11},
  195. {0x22, 11},
  196. {0x21, 11},
  197. {0x20, 11},
  198. {0x1f, 11},
  199. {0x1e, 11},
  200. {0x1d, 11},
  201. {0x1c, 11},
  202. {0x1b, 11},
  203. {0x1a, 11},
  204. {0x19, 11},
  205. {0x18, 11},
  206. {0x8, 11}, /* escape */
  207. {0xf, 11}, /* stuffing */
  208. {0x0, 8}, /* end (and 15 more 0 bits should follow) */
  209. };
  210. static const uint8_t mbPatTable[63][2] = {
  211. {0xb, 5},
  212. {0x9, 5},
  213. {0xd, 6},
  214. {0xd, 4},
  215. {0x17, 7},
  216. {0x13, 7},
  217. {0x1f, 8},
  218. {0xc, 4},
  219. {0x16, 7},
  220. {0x12, 7},
  221. {0x1e, 8},
  222. {0x13, 5},
  223. {0x1b, 8},
  224. {0x17, 8},
  225. {0x13, 8},
  226. {0xb, 4},
  227. {0x15, 7},
  228. {0x11, 7},
  229. {0x1d, 8},
  230. {0x11, 5},
  231. {0x19, 8},
  232. {0x15, 8},
  233. {0x11, 8},
  234. {0xf, 6},
  235. {0xf, 8},
  236. {0xd, 8},
  237. {0x3, 9},
  238. {0xf, 5},
  239. {0xb, 8},
  240. {0x7, 8},
  241. {0x7, 9},
  242. {0xa, 4},
  243. {0x14, 7},
  244. {0x10, 7},
  245. {0x1c, 8},
  246. {0xe, 6},
  247. {0xe, 8},
  248. {0xc, 8},
  249. {0x2, 9},
  250. {0x10, 5},
  251. {0x18, 8},
  252. {0x14, 8},
  253. {0x10, 8},
  254. {0xe, 5},
  255. {0xa, 8},
  256. {0x6, 8},
  257. {0x6, 9},
  258. {0x12, 5},
  259. {0x1a, 8},
  260. {0x16, 8},
  261. {0x12, 8},
  262. {0xd, 5},
  263. {0x9, 8},
  264. {0x5, 8},
  265. {0x5, 9},
  266. {0xc, 5},
  267. {0x8, 8},
  268. {0x4, 8},
  269. {0x4, 9},
  270. {0x7, 3},
  271. {0xa, 5},
  272. {0x8, 5},
  273. {0xc, 6}
  274. };
  275. #define MB_TYPE_PAT 0x40000000
  276. #define MB_TYPE_ZERO_MV 0x20000000
  277. #define IS_ZERO_MV(a) ((a)&MB_TYPE_ZERO_MV)
  278. #define IS_PAT(a) ((a)&MB_TYPE_PAT)
  279. static const uint8_t table_mb_ptype[7][2] = {
  280. { 3, 5 }, // 0x01 MB_INTRA
  281. { 1, 2 }, // 0x02 MB_PAT
  282. { 1, 3 }, // 0x08 MB_FOR
  283. { 1, 1 }, // 0x0A MB_FOR|MB_PAT
  284. { 1, 6 }, // 0x11 MB_QUANT|MB_INTRA
  285. { 1, 5 }, // 0x12 MB_QUANT|MB_PAT
  286. { 2, 5 }, // 0x1A MB_QUANT|MB_FOR|MB_PAT
  287. };
  288. static const uint32_t ptype2mb_type[7] = {
  289. MB_TYPE_INTRA,
  290. MB_TYPE_L0 | MB_TYPE_PAT | MB_TYPE_ZERO_MV | MB_TYPE_16x16,
  291. MB_TYPE_L0,
  292. MB_TYPE_L0 | MB_TYPE_PAT,
  293. MB_TYPE_QUANT | MB_TYPE_INTRA,
  294. MB_TYPE_QUANT | MB_TYPE_L0 | MB_TYPE_PAT | MB_TYPE_ZERO_MV | MB_TYPE_16x16,
  295. MB_TYPE_QUANT | MB_TYPE_L0 | MB_TYPE_PAT,
  296. };
  297. static const uint8_t table_mb_btype[11][2] = {
  298. { 3, 5 }, // 0x01 MB_INTRA
  299. { 2, 3 }, // 0x04 MB_BACK
  300. { 3, 3 }, // 0x06 MB_BACK|MB_PAT
  301. { 2, 4 }, // 0x08 MB_FOR
  302. { 3, 4 }, // 0x0A MB_FOR|MB_PAT
  303. { 2, 2 }, // 0x0C MB_FOR|MB_BACK
  304. { 3, 2 }, // 0x0E MB_FOR|MB_BACK|MB_PAT
  305. { 1, 6 }, // 0x11 MB_QUANT|MB_INTRA
  306. { 2, 6 }, // 0x16 MB_QUANT|MB_BACK|MB_PAT
  307. { 3, 6 }, // 0x1A MB_QUANT|MB_FOR|MB_PAT
  308. { 2, 5 }, // 0x1E MB_QUANT|MB_FOR|MB_BACK|MB_PAT
  309. };
  310. static const uint32_t btype2mb_type[11] = {
  311. MB_TYPE_INTRA,
  312. MB_TYPE_L1,
  313. MB_TYPE_L1 | MB_TYPE_PAT,
  314. MB_TYPE_L0,
  315. MB_TYPE_L0 | MB_TYPE_PAT,
  316. MB_TYPE_L0L1,
  317. MB_TYPE_L0L1 | MB_TYPE_PAT,
  318. MB_TYPE_QUANT | MB_TYPE_INTRA,
  319. MB_TYPE_QUANT | MB_TYPE_L1 | MB_TYPE_PAT,
  320. MB_TYPE_QUANT | MB_TYPE_L0 | MB_TYPE_PAT,
  321. MB_TYPE_QUANT | MB_TYPE_L0L1 | MB_TYPE_PAT,
  322. };
  323. static const uint8_t mbMotionVectorTable[17][2] = {
  324. { 0x1, 1 },
  325. { 0x1, 2 },
  326. { 0x1, 3 },
  327. { 0x1, 4 },
  328. { 0x3, 6 },
  329. { 0x5, 7 },
  330. { 0x4, 7 },
  331. { 0x3, 7 },
  332. { 0xb, 9 },
  333. { 0xa, 9 },
  334. { 0x9, 9 },
  335. { 0x11, 10 },
  336. { 0x10, 10 },
  337. { 0xf, 10 },
  338. { 0xe, 10 },
  339. { 0xd, 10 },
  340. { 0xc, 10 },
  341. };
  342. #define MPEG1_FRAME_RATE_BASE 1001
  343. static const int frame_rate_tab[16] = {
  344. 0,
  345. 24000,
  346. 24024,
  347. 25025,
  348. 30000,
  349. 30030,
  350. 50050,
  351. 60000,
  352. 60060,
  353. // Xing's 15fps: (9)
  354. 15015,
  355. // libmpeg3's "Unofficial economy rates": (10-13)
  356. 5005,
  357. 10010,
  358. 12012,
  359. 15015,
  360. // random, just to avoid segfault !never encode these
  361. 25025,
  362. 25025,
  363. };
  364. static const uint8_t non_linear_qscale[32] = {
  365. 0, 1, 2, 3, 4, 5, 6, 7,
  366. 8,10,12,14,16,18,20,22,
  367. 24,28,32,36,40,44,48,52,
  368. 56,64,72,80,88,96,104,112,
  369. };
  370. uint8_t ff_mpeg1_dc_scale_table[128]={ // MN: mpeg2 really can have such large qscales?
  371. // 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
  372. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  373. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  374. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  375. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  376. };
  377. static const float mpeg1_aspect[16]={
  378. 0.0000,
  379. 1.0000,
  380. 0.6735,
  381. 0.7031,
  382. 0.7615,
  383. 0.8055,
  384. 0.8437,
  385. 0.8935,
  386. 0.9157,
  387. 0.9815,
  388. 1.0255,
  389. 1.0695,
  390. 1.0950,
  391. 1.1575,
  392. 1.2015,
  393. };
  394. static const float mpeg2_aspect[16]={
  395. 0,
  396. 1.0,
  397. -3.0/4.0,
  398. -9.0/16.0,
  399. -1.0/2.21,
  400. };