h264data.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /*
  2. * H26L/H264/AVC/JVT/14496-10/... encoder/decoder
  3. * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at>
  4. *
  5. * This file is part of FFmpeg.
  6. *
  7. * FFmpeg is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2.1 of the License, or (at your option) any later version.
  11. *
  12. * FFmpeg is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with FFmpeg; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. /**
  22. * @file
  23. * @brief
  24. * H264 / AVC / MPEG4 part10 codec data table
  25. * @author Michael Niedermayer <michaelni@gmx.at>
  26. */
  27. #ifndef AVCODEC_H264DATA_H
  28. #define AVCODEC_H264DATA_H
  29. #include <stdint.h>
  30. #include "libavutil/rational.h"
  31. #include "mpegvideo.h"
  32. #include "h264.h"
  33. static const uint8_t golomb_to_pict_type[5] = {
  34. AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B, AV_PICTURE_TYPE_I,
  35. AV_PICTURE_TYPE_SP, AV_PICTURE_TYPE_SI
  36. };
  37. static const uint8_t golomb_to_intra4x4_cbp[48] = {
  38. 47, 31, 15, 0, 23, 27, 29, 30, 7, 11, 13, 14, 39, 43, 45, 46,
  39. 16, 3, 5, 10, 12, 19, 21, 26, 28, 35, 37, 42, 44, 1, 2, 4,
  40. 8, 17, 18, 20, 24, 6, 9, 22, 25, 32, 33, 34, 36, 40, 38, 41
  41. };
  42. static const uint8_t golomb_to_inter_cbp[48] = {
  43. 0, 16, 1, 2, 4, 8, 32, 3, 5, 10, 12, 15, 47, 7, 11, 13,
  44. 14, 6, 9, 31, 35, 37, 42, 44, 33, 34, 36, 40, 39, 43, 45, 46,
  45. 17, 18, 20, 24, 19, 21, 26, 28, 23, 27, 29, 30, 22, 25, 38, 41
  46. };
  47. static const uint8_t zigzag_scan[16] = {
  48. 0 + 0 * 4, 1 + 0 * 4, 0 + 1 * 4, 0 + 2 * 4,
  49. 1 + 1 * 4, 2 + 0 * 4, 3 + 0 * 4, 2 + 1 * 4,
  50. 1 + 2 * 4, 0 + 3 * 4, 1 + 3 * 4, 2 + 2 * 4,
  51. 3 + 1 * 4, 3 + 2 * 4, 2 + 3 * 4, 3 + 3 * 4,
  52. };
  53. static const uint8_t field_scan[16] = {
  54. 0 + 0 * 4, 0 + 1 * 4, 1 + 0 * 4, 0 + 2 * 4,
  55. 0 + 3 * 4, 1 + 1 * 4, 1 + 2 * 4, 1 + 3 * 4,
  56. 2 + 0 * 4, 2 + 1 * 4, 2 + 2 * 4, 2 + 3 * 4,
  57. 3 + 0 * 4, 3 + 1 * 4, 3 + 2 * 4, 3 + 3 * 4,
  58. };
  59. static const uint8_t luma_dc_zigzag_scan[16] = {
  60. 0 * 16 + 0 * 64, 1 * 16 + 0 * 64, 2 * 16 + 0 * 64, 0 * 16 + 2 * 64,
  61. 3 * 16 + 0 * 64, 0 * 16 + 1 * 64, 1 * 16 + 1 * 64, 2 * 16 + 1 * 64,
  62. 1 * 16 + 2 * 64, 2 * 16 + 2 * 64, 3 * 16 + 2 * 64, 0 * 16 + 3 * 64,
  63. 3 * 16 + 1 * 64, 1 * 16 + 3 * 64, 2 * 16 + 3 * 64, 3 * 16 + 3 * 64,
  64. };
  65. static const uint8_t luma_dc_field_scan[16] = {
  66. 0 * 16 + 0 * 64, 2 * 16 + 0 * 64, 1 * 16 + 0 * 64, 0 * 16 + 2 * 64,
  67. 2 * 16 + 2 * 64, 3 * 16 + 0 * 64, 1 * 16 + 2 * 64, 3 * 16 + 2 * 64,
  68. 0 * 16 + 1 * 64, 2 * 16 + 1 * 64, 0 * 16 + 3 * 64, 2 * 16 + 3 * 64,
  69. 1 * 16 + 1 * 64, 3 * 16 + 1 * 64, 1 * 16 + 3 * 64, 3 * 16 + 3 * 64,
  70. };
  71. static const uint8_t chroma_dc_scan[4] = {
  72. (0 + 0 * 2) * 16, (1 + 0 * 2) * 16,
  73. (0 + 1 * 2) * 16, (1 + 1 * 2) * 16,
  74. };
  75. static const uint8_t chroma422_dc_scan[8] = {
  76. (0 + 0 * 2) * 16, (0 + 1 * 2) * 16,
  77. (1 + 0 * 2) * 16, (0 + 2 * 2) * 16,
  78. (0 + 3 * 2) * 16, (1 + 1 * 2) * 16,
  79. (1 + 2 * 2) * 16, (1 + 3 * 2) * 16,
  80. };
  81. // zigzag_scan8x8_cavlc[i] = zigzag_scan8x8[(i/4) + 16*(i%4)]
  82. static const uint8_t zigzag_scan8x8_cavlc[64] = {
  83. 0 + 0 * 8, 1 + 1 * 8, 1 + 2 * 8, 2 + 2 * 8,
  84. 4 + 1 * 8, 0 + 5 * 8, 3 + 3 * 8, 7 + 0 * 8,
  85. 3 + 4 * 8, 1 + 7 * 8, 5 + 3 * 8, 6 + 3 * 8,
  86. 2 + 7 * 8, 6 + 4 * 8, 5 + 6 * 8, 7 + 5 * 8,
  87. 1 + 0 * 8, 2 + 0 * 8, 0 + 3 * 8, 3 + 1 * 8,
  88. 3 + 2 * 8, 0 + 6 * 8, 4 + 2 * 8, 6 + 1 * 8,
  89. 2 + 5 * 8, 2 + 6 * 8, 6 + 2 * 8, 5 + 4 * 8,
  90. 3 + 7 * 8, 7 + 3 * 8, 4 + 7 * 8, 7 + 6 * 8,
  91. 0 + 1 * 8, 3 + 0 * 8, 0 + 4 * 8, 4 + 0 * 8,
  92. 2 + 3 * 8, 1 + 5 * 8, 5 + 1 * 8, 5 + 2 * 8,
  93. 1 + 6 * 8, 3 + 5 * 8, 7 + 1 * 8, 4 + 5 * 8,
  94. 4 + 6 * 8, 7 + 4 * 8, 5 + 7 * 8, 6 + 7 * 8,
  95. 0 + 2 * 8, 2 + 1 * 8, 1 + 3 * 8, 5 + 0 * 8,
  96. 1 + 4 * 8, 2 + 4 * 8, 6 + 0 * 8, 4 + 3 * 8,
  97. 0 + 7 * 8, 4 + 4 * 8, 7 + 2 * 8, 3 + 6 * 8,
  98. 5 + 5 * 8, 6 + 5 * 8, 6 + 6 * 8, 7 + 7 * 8,
  99. };
  100. static const uint8_t field_scan8x8[64] = {
  101. 0 + 0 * 8, 0 + 1 * 8, 0 + 2 * 8, 1 + 0 * 8,
  102. 1 + 1 * 8, 0 + 3 * 8, 0 + 4 * 8, 1 + 2 * 8,
  103. 2 + 0 * 8, 1 + 3 * 8, 0 + 5 * 8, 0 + 6 * 8,
  104. 0 + 7 * 8, 1 + 4 * 8, 2 + 1 * 8, 3 + 0 * 8,
  105. 2 + 2 * 8, 1 + 5 * 8, 1 + 6 * 8, 1 + 7 * 8,
  106. 2 + 3 * 8, 3 + 1 * 8, 4 + 0 * 8, 3 + 2 * 8,
  107. 2 + 4 * 8, 2 + 5 * 8, 2 + 6 * 8, 2 + 7 * 8,
  108. 3 + 3 * 8, 4 + 1 * 8, 5 + 0 * 8, 4 + 2 * 8,
  109. 3 + 4 * 8, 3 + 5 * 8, 3 + 6 * 8, 3 + 7 * 8,
  110. 4 + 3 * 8, 5 + 1 * 8, 6 + 0 * 8, 5 + 2 * 8,
  111. 4 + 4 * 8, 4 + 5 * 8, 4 + 6 * 8, 4 + 7 * 8,
  112. 5 + 3 * 8, 6 + 1 * 8, 6 + 2 * 8, 5 + 4 * 8,
  113. 5 + 5 * 8, 5 + 6 * 8, 5 + 7 * 8, 6 + 3 * 8,
  114. 7 + 0 * 8, 7 + 1 * 8, 6 + 4 * 8, 6 + 5 * 8,
  115. 6 + 6 * 8, 6 + 7 * 8, 7 + 2 * 8, 7 + 3 * 8,
  116. 7 + 4 * 8, 7 + 5 * 8, 7 + 6 * 8, 7 + 7 * 8,
  117. };
  118. static const uint8_t field_scan8x8_cavlc[64] = {
  119. 0 + 0 * 8, 1 + 1 * 8, 2 + 0 * 8, 0 + 7 * 8,
  120. 2 + 2 * 8, 2 + 3 * 8, 2 + 4 * 8, 3 + 3 * 8,
  121. 3 + 4 * 8, 4 + 3 * 8, 4 + 4 * 8, 5 + 3 * 8,
  122. 5 + 5 * 8, 7 + 0 * 8, 6 + 6 * 8, 7 + 4 * 8,
  123. 0 + 1 * 8, 0 + 3 * 8, 1 + 3 * 8, 1 + 4 * 8,
  124. 1 + 5 * 8, 3 + 1 * 8, 2 + 5 * 8, 4 + 1 * 8,
  125. 3 + 5 * 8, 5 + 1 * 8, 4 + 5 * 8, 6 + 1 * 8,
  126. 5 + 6 * 8, 7 + 1 * 8, 6 + 7 * 8, 7 + 5 * 8,
  127. 0 + 2 * 8, 0 + 4 * 8, 0 + 5 * 8, 2 + 1 * 8,
  128. 1 + 6 * 8, 4 + 0 * 8, 2 + 6 * 8, 5 + 0 * 8,
  129. 3 + 6 * 8, 6 + 0 * 8, 4 + 6 * 8, 6 + 2 * 8,
  130. 5 + 7 * 8, 6 + 4 * 8, 7 + 2 * 8, 7 + 6 * 8,
  131. 1 + 0 * 8, 1 + 2 * 8, 0 + 6 * 8, 3 + 0 * 8,
  132. 1 + 7 * 8, 3 + 2 * 8, 2 + 7 * 8, 4 + 2 * 8,
  133. 3 + 7 * 8, 5 + 2 * 8, 4 + 7 * 8, 5 + 4 * 8,
  134. 6 + 3 * 8, 6 + 5 * 8, 7 + 3 * 8, 7 + 7 * 8,
  135. };
  136. typedef struct IMbInfo {
  137. uint16_t type;
  138. uint8_t pred_mode;
  139. uint8_t cbp;
  140. } IMbInfo;
  141. static const IMbInfo i_mb_type_info[26] = {
  142. { MB_TYPE_INTRA4x4, -1, -1 },
  143. { MB_TYPE_INTRA16x16, 2, 0 },
  144. { MB_TYPE_INTRA16x16, 1, 0 },
  145. { MB_TYPE_INTRA16x16, 0, 0 },
  146. { MB_TYPE_INTRA16x16, 3, 0 },
  147. { MB_TYPE_INTRA16x16, 2, 16 },
  148. { MB_TYPE_INTRA16x16, 1, 16 },
  149. { MB_TYPE_INTRA16x16, 0, 16 },
  150. { MB_TYPE_INTRA16x16, 3, 16 },
  151. { MB_TYPE_INTRA16x16, 2, 32 },
  152. { MB_TYPE_INTRA16x16, 1, 32 },
  153. { MB_TYPE_INTRA16x16, 0, 32 },
  154. { MB_TYPE_INTRA16x16, 3, 32 },
  155. { MB_TYPE_INTRA16x16, 2, 15 + 0 },
  156. { MB_TYPE_INTRA16x16, 1, 15 + 0 },
  157. { MB_TYPE_INTRA16x16, 0, 15 + 0 },
  158. { MB_TYPE_INTRA16x16, 3, 15 + 0 },
  159. { MB_TYPE_INTRA16x16, 2, 15 + 16 },
  160. { MB_TYPE_INTRA16x16, 1, 15 + 16 },
  161. { MB_TYPE_INTRA16x16, 0, 15 + 16 },
  162. { MB_TYPE_INTRA16x16, 3, 15 + 16 },
  163. { MB_TYPE_INTRA16x16, 2, 15 + 32 },
  164. { MB_TYPE_INTRA16x16, 1, 15 + 32 },
  165. { MB_TYPE_INTRA16x16, 0, 15 + 32 },
  166. { MB_TYPE_INTRA16x16, 3, 15 + 32 },
  167. { MB_TYPE_INTRA_PCM, -1, -1 },
  168. };
  169. typedef struct PMbInfo {
  170. uint16_t type;
  171. uint8_t partition_count;
  172. } PMbInfo;
  173. static const PMbInfo p_mb_type_info[5] = {
  174. { MB_TYPE_16x16 | MB_TYPE_P0L0, 1 },
  175. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 2 },
  176. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 2 },
  177. { MB_TYPE_8x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 4 },
  178. { MB_TYPE_8x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0 | MB_TYPE_REF0, 4 },
  179. };
  180. static const PMbInfo p_sub_mb_type_info[4] = {
  181. { MB_TYPE_16x16 | MB_TYPE_P0L0, 1 },
  182. { MB_TYPE_16x8 | MB_TYPE_P0L0, 2 },
  183. { MB_TYPE_8x16 | MB_TYPE_P0L0, 2 },
  184. { MB_TYPE_8x8 | MB_TYPE_P0L0, 4 },
  185. };
  186. static const PMbInfo b_mb_type_info[23] = {
  187. { MB_TYPE_DIRECT2 | MB_TYPE_L0L1, 1, },
  188. { MB_TYPE_16x16 | MB_TYPE_P0L0, 1, },
  189. { MB_TYPE_16x16 | MB_TYPE_P0L1, 1, },
  190. { MB_TYPE_16x16 | MB_TYPE_P0L0 | MB_TYPE_P0L1, 1, },
  191. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 2, },
  192. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 2, },
  193. { MB_TYPE_16x8 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 2, },
  194. { MB_TYPE_8x16 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 2, },
  195. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P1L1, 2, },
  196. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P1L1, 2, },
  197. { MB_TYPE_16x8 | MB_TYPE_P0L1 | MB_TYPE_P1L0, 2, },
  198. { MB_TYPE_8x16 | MB_TYPE_P0L1 | MB_TYPE_P1L0, 2, },
  199. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  200. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  201. { MB_TYPE_16x8 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  202. { MB_TYPE_8x16 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  203. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0, 2, },
  204. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0, 2, },
  205. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 2, },
  206. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 2, },
  207. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  208. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  209. { MB_TYPE_8x8 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 4, },
  210. };
  211. static const PMbInfo b_sub_mb_type_info[13] = {
  212. { MB_TYPE_DIRECT2, 1, },
  213. { MB_TYPE_16x16 | MB_TYPE_P0L0, 1, },
  214. { MB_TYPE_16x16 | MB_TYPE_P0L1, 1, },
  215. { MB_TYPE_16x16 | MB_TYPE_P0L0 | MB_TYPE_P0L1, 1, },
  216. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 2, },
  217. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 2, },
  218. { MB_TYPE_16x8 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 2, },
  219. { MB_TYPE_8x16 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 2, },
  220. { MB_TYPE_16x8 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  221. { MB_TYPE_8x16 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 2, },
  222. { MB_TYPE_8x8 | MB_TYPE_P0L0 | MB_TYPE_P1L0, 4, },
  223. { MB_TYPE_8x8 | MB_TYPE_P0L1 | MB_TYPE_P1L1, 4, },
  224. { MB_TYPE_8x8 | MB_TYPE_P0L0 | MB_TYPE_P0L1 | MB_TYPE_P1L0 | MB_TYPE_P1L1, 4, },
  225. };
  226. static const uint8_t dequant4_coeff_init[6][3] = {
  227. { 10, 13, 16 },
  228. { 11, 14, 18 },
  229. { 13, 16, 20 },
  230. { 14, 18, 23 },
  231. { 16, 20, 25 },
  232. { 18, 23, 29 },
  233. };
  234. static const uint8_t dequant8_coeff_init_scan[16] = {
  235. 0, 3, 4, 3, 3, 1, 5, 1, 4, 5, 2, 5, 3, 1, 5, 1
  236. };
  237. static const uint8_t dequant8_coeff_init[6][6] = {
  238. { 20, 18, 32, 19, 25, 24 },
  239. { 22, 19, 35, 21, 28, 26 },
  240. { 26, 23, 42, 24, 33, 31 },
  241. { 28, 25, 45, 26, 35, 33 },
  242. { 32, 28, 51, 30, 40, 38 },
  243. { 36, 32, 58, 34, 46, 43 },
  244. };
  245. #endif /* AVCODEC_H264DATA_H */