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.

1166 lines
53KB

  1. /*
  2. * VC3/DNxHD data.
  3. * Copyright (c) 2007 SmartJog S.A., Baptiste Coudurier <baptiste dot coudurier at smartjog dot com>
  4. *
  5. * This file is part of Libav.
  6. *
  7. * Libav 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. * Libav 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 Libav; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. #include "avcodec.h"
  22. #include "dnxhddata.h"
  23. #include "libavutil/common.h"
  24. static const uint8_t dnxhd_1235_luma_weight[] = {
  25. 0, 32, 32, 32, 33, 35, 38, 39,
  26. 32, 33, 32, 33, 36, 36, 39, 42,
  27. 32, 32, 33, 36, 35, 37, 41, 43,
  28. 31, 33, 34, 36, 36, 40, 42, 48,
  29. 32, 34, 36, 37, 39, 42, 46, 51,
  30. 36, 37, 37, 39, 41, 46, 51, 55,
  31. 37, 39, 41, 41, 47, 50, 55, 56,
  32. 41, 42, 41, 44, 50, 53, 60, 60
  33. };
  34. static const uint8_t dnxhd_1235_chroma_weight[] = {
  35. 0, 32, 33, 34, 39, 41, 54, 59,
  36. 33, 34, 35, 38, 43, 49, 58, 84,
  37. 34, 37, 39, 44, 46, 55, 74, 87,
  38. 40, 42, 47, 48, 58, 70, 87, 86,
  39. 43, 50, 56, 63, 72, 94, 91, 82,
  40. 55, 63, 65, 75, 93, 89, 85, 73,
  41. 61, 67, 82, 81, 83, 90, 79, 73,
  42. 74, 84, 75, 78, 90, 85, 73, 73
  43. };
  44. static const uint8_t dnxhd_1237_luma_weight[] = {
  45. 0, 32, 33, 34, 34, 36, 37, 36,
  46. 36, 37, 38, 38, 38, 39, 41, 44,
  47. 43, 41, 40, 41, 46, 49, 47, 46,
  48. 47, 49, 51, 54, 60, 62, 59, 55,
  49. 54, 56, 58, 61, 65, 66, 64, 63,
  50. 66, 73, 78, 79, 80, 79, 78, 78,
  51. 82, 87, 89, 90, 93, 95, 96, 97,
  52. 97, 100, 104, 102, 98, 98, 99, 99,
  53. };
  54. static const uint8_t dnxhd_1237_chroma_weight[] = {
  55. 0, 32, 36, 39, 39, 38, 39, 41,
  56. 45, 51, 57, 58, 53, 48, 47, 51,
  57. 55, 58, 66, 75, 81, 83, 82, 78,
  58. 73, 72, 74, 77, 83, 85, 83, 82,
  59. 89, 99, 96, 90, 94, 97, 99, 105,
  60. 109, 105, 95, 89, 92, 95, 94, 93,
  61. 92, 88, 89, 90, 93, 95, 96, 97,
  62. 97, 100, 104, 102, 98, 98, 99, 99,
  63. };
  64. static const uint8_t dnxhd_1238_luma_weight[] = {
  65. 0, 32, 32, 33, 34, 33, 33, 33,
  66. 33, 33, 33, 33, 33, 35, 37, 37,
  67. 36, 36, 35, 36, 38, 38, 36, 35,
  68. 36, 37, 38, 41, 42, 41, 39, 38,
  69. 38, 38, 39, 41, 42, 41, 39, 39,
  70. 40, 41, 43, 44, 44, 44, 44, 44,
  71. 45, 47, 47, 47, 49, 50, 51, 51,
  72. 51, 53, 55, 57, 58, 59, 57, 57,
  73. };
  74. static const uint8_t dnxhd_1238_chroma_weight[] = {
  75. 0, 32, 35, 35, 35, 34, 34, 35,
  76. 39, 43, 45, 45, 41, 39, 40, 41,
  77. 42, 44, 48, 55, 59, 63, 65, 59,
  78. 53, 52, 52, 55, 61, 62, 58, 58,
  79. 63, 66, 66, 65, 70, 74, 70, 66,
  80. 65, 68, 75, 77, 74, 74, 77, 76,
  81. 73, 73, 73, 73, 76, 80, 89, 90,
  82. 82, 77, 80, 86, 84, 82, 82, 82,
  83. };
  84. static const uint8_t dnxhd_1241_luma_weight[] = {
  85. 0, 32, 33, 34, 34, 35, 36, 37,
  86. 36, 37, 38, 38, 38, 39, 39, 40,
  87. 40, 38, 38, 39, 38, 37, 39, 41,
  88. 41, 42, 43, 45, 45, 46, 47, 46,
  89. 45, 43, 39, 37, 37, 40, 44, 45,
  90. 45, 46, 46, 46, 47, 47, 46, 44,
  91. 42, 43, 45, 47, 48, 49, 50, 49,
  92. 48, 46, 47, 48, 48, 49, 49, 49,
  93. };
  94. static const uint8_t dnxhd_1241_chroma_weight[] = {
  95. 0, 32, 36, 38, 37, 37, 40, 41,
  96. 40, 40, 42, 42, 41, 41, 41, 41,
  97. 42, 43, 44, 44, 45, 46, 46, 45,
  98. 44, 45, 45, 45, 45, 46, 47, 46,
  99. 45, 44, 42, 41, 43, 45, 45, 47,
  100. 48, 48, 48, 46, 47, 47, 46, 47,
  101. 46, 45, 45, 47, 48, 49, 50, 49,
  102. 48, 46, 48, 49, 48, 49, 49, 49,
  103. };
  104. static const uint8_t dnxhd_1242_luma_weight[] = {
  105. 0, 32, 33, 33, 34, 35, 36, 35,
  106. 33, 33, 35, 36, 37, 37, 38, 37,
  107. 37, 37, 36, 37, 37, 37, 38, 39,
  108. 37, 36, 37, 40, 42, 45, 46, 44,
  109. 41, 42, 44, 45, 47, 49, 50, 48,
  110. 46, 48, 49, 50, 52, 52, 50, 49,
  111. 47, 48, 50, 50, 51, 51, 50, 49,
  112. 49, 51, 52, 51, 49, 47, 47, 47,
  113. };
  114. static const uint8_t dnxhd_1242_chroma_weight[] = {
  115. 0, 32, 37, 42, 45, 45, 45, 44,
  116. 38, 37, 40, 42, 44, 49, 51, 47,
  117. 41, 40, 43, 44, 46, 48, 51, 54,
  118. 51, 47, 47, 45, 47, 50, 51, 49,
  119. 46, 47, 49, 47, 50, 55, 55, 51,
  120. 48, 49, 51, 51, 52, 52, 54, 54,
  121. 49, 49, 52, 53, 54, 54, 53, 53,
  122. 55, 59, 63, 62, 60, 60, 60, 60,
  123. };
  124. static const uint8_t dnxhd_1243_luma_weight[] = {
  125. 0, 32, 32, 33, 33, 35, 35, 35,
  126. 35, 35, 35, 35, 34, 35, 38, 40,
  127. 39, 37, 37, 37, 36, 35, 36, 38,
  128. 40, 41, 42, 44, 45, 44, 42, 41,
  129. 40, 38, 36, 36, 37, 38, 40, 43,
  130. 44, 45, 45, 45, 45, 45, 45, 41,
  131. 39, 41, 45, 47, 47, 48, 48, 48,
  132. 46, 44, 45, 47, 47, 48, 47, 47,
  133. };
  134. static const uint8_t dnxhd_1243_chroma_weight[] = {
  135. 0, 32, 36, 37, 36, 37, 39, 39,
  136. 41, 43, 43, 42, 41, 41, 41, 42,
  137. 43, 43, 43, 44, 44, 44, 46, 47,
  138. 46, 45, 45, 45, 45, 46, 44, 44,
  139. 45, 44, 42, 41, 43, 46, 45, 44,
  140. 45, 45, 45, 46, 46, 46, 45, 44,
  141. 45, 44, 45, 47, 47, 48, 49, 48,
  142. 46, 45, 46, 47, 47, 48, 47, 47,
  143. };
  144. static const uint8_t dnxhd_1250_luma_weight[] = {
  145. 0, 32, 35, 35, 36, 36, 41, 43,
  146. 32, 34, 35, 36, 37, 39, 43, 47,
  147. 33, 34, 36, 38, 38, 42, 42, 50,
  148. 34, 36, 38, 38, 41, 40, 47, 54,
  149. 35, 38, 39, 40, 39, 45, 49, 58,
  150. 38, 39, 40, 39, 46, 47, 54, 60,
  151. 38, 39, 41, 46, 46, 48, 57, 62,
  152. 40, 41, 44, 45, 49, 54, 63, 63
  153. };
  154. static const uint8_t dnxhd_1250_chroma_weight[] = {
  155. 0, 32, 35, 36, 40, 42, 51, 51,
  156. 35, 36, 39, 39, 43, 51, 52, 55,
  157. 36, 41, 41, 43, 51, 53, 54, 56,
  158. 43, 44, 45, 50, 54, 54, 55, 57,
  159. 45, 48, 50, 51, 55, 58, 59, 58,
  160. 49, 52, 49, 57, 58, 62, 58, 60,
  161. 51, 51, 56, 58, 62, 61, 59, 62,
  162. 52, 52, 60, 61, 59, 59, 63, 63
  163. };
  164. static const uint8_t dnxhd_1251_luma_weight[] = {
  165. 0, 32, 32, 34, 34, 34, 34, 35,
  166. 35, 35, 36, 37, 36, 36, 35, 36,
  167. 38, 38, 38, 38, 38, 38, 38, 38,
  168. 38, 38, 39, 41, 44, 43, 41, 40,
  169. 40, 40, 40, 39, 40, 41, 40, 39,
  170. 40, 43, 46, 46, 44, 44, 44, 42,
  171. 41, 43, 46, 48, 50, 55, 58, 53,
  172. 48, 50, 55, 58, 61, 62, 62, 62,
  173. };
  174. static const uint8_t dnxhd_1251_chroma_weight[] = {
  175. 0, 32, 35, 36, 36, 35, 36, 39,
  176. 41, 43, 45, 44, 41, 39, 40, 42,
  177. 43, 43, 45, 48, 48, 48, 50, 50,
  178. 50, 51, 51, 51, 51, 52, 53, 54,
  179. 51, 49, 51, 52, 52, 56, 57, 55,
  180. 54, 54, 55, 56, 55, 58, 58, 58,
  181. 60, 61, 62, 62, 59, 57, 58, 58,
  182. 61, 59, 59, 59, 61, 62, 62, 62,
  183. };
  184. static const uint8_t dnxhd_1252_luma_weight[] = {
  185. 0, 32, 34, 35, 36, 36, 36, 37,
  186. 36, 37, 39, 40, 41, 40, 40, 40,
  187. 41, 41, 42, 41, 41, 43, 44, 44,
  188. 45, 46, 48, 55, 60, 57, 52, 50,
  189. 49, 49, 52, 52, 53, 55, 58, 62,
  190. 65, 73, 82, 82, 80, 78, 73, 68,
  191. 71, 82, 90, 90, 88, 87, 90, 95,
  192. 100, 107, 103, 97, 95, 93, 99, 99,
  193. };
  194. static const uint8_t dnxhd_1252_chroma_weight[] = {
  195. 0, 32, 35, 36, 37, 37, 38, 40,
  196. 42, 46, 49, 50, 50, 49, 49, 53,
  197. 56, 56, 57, 58, 60, 62, 64, 65,
  198. 63, 64, 64, 65, 66, 65, 67, 71,
  199. 72, 74, 74, 74, 74, 77, 81, 78,
  200. 72, 73, 82, 85, 89, 88, 84, 80,
  201. 90, 100, 90, 90, 88, 87, 90, 95,
  202. 114, 128, 125, 129, 134, 125, 116, 116,
  203. };
  204. static const uint8_t dnxhd_1237_dc_codes[12] = {
  205. 0, 12, 13, 1, 2, 3, 4, 5, 14, 30, 62, 63,
  206. };
  207. static const uint8_t dnxhd_1237_dc_bits[12] = {
  208. 3, 4, 4, 3, 3, 3, 3, 3, 4, 5, 6, 6,
  209. };
  210. static const uint16_t dnxhd_1237_ac_codes[257] = {
  211. 0, 1, 4, 5, 12, 26, 27, 56,
  212. 57, 58, 59, 120, 121, 244, 245, 246,
  213. 247, 248, 498, 499, 500, 501, 502, 1006,
  214. 1007, 1008, 1009, 1010, 1011, 2024, 2025, 2026,
  215. 2027, 2028, 2029, 2030, 2031, 4064, 4065, 4066,
  216. 4067, 4068, 4069, 4070, 4071, 4072, 4073, 8148,
  217. 8149, 8150, 8151, 8152, 8153, 8154, 8155, 8156,
  218. 8157, 8158, 16318, 16319, 16320, 16321, 16322, 16323,
  219. 16324, 16325, 16326, 16327, 16328, 16329, 16330, 16331,
  220. 16332, 16333, 32668, 32669, 32670, 32671, 32672, 32673,
  221. 32674, 32675, 32676, 32677, 32678, 32679, 32680, 32681,
  222. 32682, 32683, 32684, 65370, 65371, 65372, 65373, 65374,
  223. 65375, 65376, 65377, 65378, 65379, 65380, 65381, 65382,
  224. 65383, 65384, 65385, 65386, 65387, 65388, 65389, 65390,
  225. 65391, 65392, 65393, 65394, 65395, 65396, 65397, 65398,
  226. 65399, 65400, 65401, 65402, 65403, 65404, 65405, 65406,
  227. 65407, 65408, 65409, 65410, 65411, 65412, 65413, 65414,
  228. 65415, 65416, 65417, 65418, 65419, 65420, 65421, 65422,
  229. 65423, 65424, 65425, 65426, 65427, 65428, 65429, 65430,
  230. 65431, 65432, 65433, 65434, 65435, 65436, 65437, 65438,
  231. 65439, 65440, 65441, 65442, 65443, 65444, 65445, 65446,
  232. 65447, 65448, 65449, 65450, 65451, 65452, 65453, 65454,
  233. 65455, 65456, 65457, 65458, 65459, 65460, 65461, 65462,
  234. 65463, 65464, 65465, 65466, 65467, 65468, 65469, 65470,
  235. 65471, 65472, 65473, 65474, 65475, 65476, 65477, 65478,
  236. 65479, 65480, 65481, 65482, 65483, 65484, 65485, 65486,
  237. 65487, 65488, 65489, 65490, 65491, 65492, 65493, 65494,
  238. 65495, 65496, 65497, 65498, 65499, 65500, 65501, 65502,
  239. 65503, 65504, 65505, 65506, 65507, 65508, 65509, 65510,
  240. 65511, 65512, 65513, 65514, 65515, 65516, 65517, 65518,
  241. 65519, 65520, 65521, 65522, 65523, 65524, 65525, 65526,
  242. 65527, 65528, 65529, 65530, 65531, 65532, 65533, 65534,
  243. 65535,
  244. };
  245. static const uint8_t dnxhd_1237_ac_bits[257] = {
  246. 2, 2, 3, 3, 4, 5, 5, 6, 6, 6, 6, 7, 7, 8, 8, 8,
  247. 8, 8, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 11, 11, 11,
  248. 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13,
  249. 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14,
  250. 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15,
  251. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 16, 16, 16, 16,
  252. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  253. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  254. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  255. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  256. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  257. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  258. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  259. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  260. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  261. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  262. 16,
  263. };
  264. static const uint8_t dnxhd_1237_ac_level[257] = {
  265. 1, 1, 2, 0, 3, 4, 2, 5, 6, 7, 3, 8, 9, 10, 11, 12,
  266. 4, 5, 13, 14, 15, 16, 6, 17, 18, 19, 20, 21, 7, 22, 23, 24,
  267. 25, 26, 27, 8, 9, 28, 29, 30, 31, 32, 33, 34, 10, 11, 12, 35,
  268. 36, 37, 38, 39, 40, 41, 13, 14, 15, 16, 42, 43, 44, 45, 46, 47,
  269. 48, 49, 50, 51, 52, 17, 18, 19, 20, 21, 53, 54, 55, 56, 57, 58,
  270. 59, 60, 61, 64, 1, 22, 23, 24, 25, 26, 27, 62, 63, 2, 3, 4,
  271. 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20,
  272. 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36,
  273. 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52,
  274. 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 28, 29, 30, 31,
  275. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  276. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  277. 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
  278. 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
  279. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  280. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  281. 64,
  282. };
  283. static const uint8_t dnxhd_1237_ac_run_flag[257] = {
  284. 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0,
  285. 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0,
  286. 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0,
  287. 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0,
  288. 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0,
  289. 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0,
  290. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  291. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  292. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  293. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,
  294. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  295. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  296. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  297. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  298. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  299. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  300. 1,
  301. };
  302. static const uint8_t dnxhd_1237_ac_index_flag[257] = {
  303. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  304. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  305. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  306. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  307. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  308. 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1,
  309. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  310. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  311. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  312. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0,
  313. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  314. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  315. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  316. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  317. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  318. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  319. 1,
  320. };
  321. static const uint16_t dnxhd_1237_run_codes[62] = {
  322. 0, 4, 10, 11, 24, 25, 26, 54,
  323. 55, 56, 57, 58, 118, 119, 240, 482,
  324. 483, 484, 485, 486, 487, 488, 489, 490,
  325. 491, 492, 493, 494, 990, 991, 992, 993,
  326. 994, 995, 996, 997, 998, 999, 1000, 1001,
  327. 1002, 1003, 1004, 1005, 1006, 1007, 1008, 1009,
  328. 1010, 1011, 1012, 1013, 1014, 1015, 1016, 1017,
  329. 1018, 1019, 1020, 1021, 1022, 1023,
  330. };
  331. static const uint8_t dnxhd_1237_run_bits[62] = {
  332. 1, 3, 4, 4, 5, 5, 5, 6, 6, 6, 6, 6, 7, 7, 8, 9,
  333. 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10,
  334. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  335. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  336. };
  337. static const uint8_t dnxhd_1237_run[62] = {
  338. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
  339. 17, 18, 19, 20, 21, 53, 57, 58, 59, 60, 61, 62, 22, 23, 24, 25,
  340. 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41,
  341. 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 54, 55, 56,
  342. };
  343. static const uint8_t dnxhd_1238_dc_codes[12] = {
  344. 0, 12, 13, 1, 2, 3, 4, 5, 14, 30, 62, 63,
  345. };
  346. static const uint8_t dnxhd_1238_dc_bits[12] = {
  347. 3, 4, 4, 3, 3, 3, 3, 3, 4, 5, 6, 6,
  348. };
  349. static const uint16_t dnxhd_1238_ac_codes[257] = {
  350. 0, 1, 4, 10, 11, 24, 25, 26,
  351. 54, 55, 56, 57, 116, 117, 118, 119,
  352. 240, 241, 242, 243, 244, 245, 492, 493,
  353. 494, 495, 496, 497, 498, 499, 1000, 1001,
  354. 1002, 1003, 1004, 1005, 1006, 1007, 1008, 2018,
  355. 2019, 2020, 2021, 2022, 2023, 2024, 2025, 2026,
  356. 2027, 4056, 4057, 4058, 4059, 4060, 4061, 4062,
  357. 4063, 4064, 4065, 4066, 4067, 4068, 4069, 8140,
  358. 8141, 8142, 8143, 8144, 8145, 8146, 8147, 8148,
  359. 8149, 8150, 8151, 8152, 8153, 8154, 8155, 8156,
  360. 16314, 16315, 16316, 16317, 16318, 16319, 16320, 16321,
  361. 16322, 16323, 16324, 16325, 16326, 16327, 16328, 16329,
  362. 16330, 16331, 16332, 16333, 16334, 16335, 16336, 16337,
  363. 16338, 32678, 32679, 32680, 32681, 32682, 32683, 32684,
  364. 32685, 32686, 32687, 32688, 32689, 32690, 32691, 32692,
  365. 32693, 32694, 32695, 32696, 32697, 32698, 32699, 32700,
  366. 32701, 32702, 32703, 32704, 32705, 65412, 65413, 65414,
  367. 65415, 65416, 65417, 65418, 65419, 65420, 65421, 65422,
  368. 65423, 65424, 65425, 65426, 65427, 65428, 65429, 65430,
  369. 65431, 65432, 65433, 65434, 65435, 65436, 65437, 65438,
  370. 65439, 65440, 65441, 65442, 65443, 65444, 65445, 65446,
  371. 65447, 65448, 65449, 65450, 65451, 65452, 65453, 65454,
  372. 65455, 65456, 65457, 65458, 65459, 65460, 65461, 65462,
  373. 65463, 65464, 65465, 65466, 65467, 65468, 65469, 65470,
  374. 65471, 65472, 65473, 65474, 65475, 65476, 65477, 65478,
  375. 65479, 65480, 65481, 65482, 65483, 65484, 65485, 65486,
  376. 65487, 65488, 65489, 65490, 65491, 65492, 65493, 65494,
  377. 65495, 65496, 65497, 65498, 65499, 65500, 65501, 65502,
  378. 65503, 65504, 65505, 65506, 65507, 65508, 65509, 65510,
  379. 65511, 65512, 65513, 65514, 65515, 65516, 65517, 65518,
  380. 65519, 65520, 65521, 65522, 65523, 65524, 65525, 65526,
  381. 65527, 65528, 65529, 65530, 65531, 65532, 65533, 65534,
  382. 65535,
  383. };
  384. static const uint8_t dnxhd_1238_ac_bits[257] = {
  385. 2, 2, 3, 4, 4, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7,
  386. 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10,
  387. 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11,
  388. 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13,
  389. 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
  390. 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  391. 14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15,
  392. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
  393. 15, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  394. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  395. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  396. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  397. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  398. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  399. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  400. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  401. 16,
  402. };
  403. static const uint8_t dnxhd_1238_ac_level[257] = {
  404. 1, 1, 2, 3, 0, 4, 5, 2, 6, 7, 8, 3, 9, 10, 11, 4,
  405. 12, 13, 14, 15, 16, 5, 17, 18, 19, 20, 21, 22, 6, 7, 23, 24,
  406. 25, 26, 27, 28, 29, 8, 9, 30, 31, 32, 33, 34, 35, 36, 37, 10,
  407. 11, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 12, 13, 14, 49,
  408. 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 15, 16, 17, 18,
  409. 62, 63, 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13,
  410. 14, 15, 16, 19, 20, 21, 22, 23, 24, 17, 18, 19, 20, 21, 22, 23,
  411. 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 40, 25,
  412. 26, 27, 28, 29, 30, 38, 39, 41, 42, 43, 44, 45, 46, 47, 48, 49,
  413. 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 31,
  414. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  415. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  416. 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
  417. 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
  418. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  419. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  420. 64,
  421. }; /* 0 is EOB */
  422. static const uint8_t dnxhd_1238_ac_run_flag[257] = {
  423. 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1,
  424. 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0,
  425. 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  426. 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0,
  427. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,
  428. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  429. 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0,
  430. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  431. 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  432. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  433. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  434. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  435. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  436. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  437. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  438. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  439. 1,
  440. };
  441. static const uint8_t dnxhd_1238_ac_index_flag[257] = {
  442. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  443. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  444. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  445. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  446. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  447. 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  448. 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1,
  449. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0,
  450. 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  451. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0,
  452. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  453. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  454. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  455. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  456. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  457. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  458. 1,
  459. };
  460. static const uint16_t dnxhd_1235_1238_1241_run_codes[62] = {
  461. 0, 4, 10, 11, 24, 25, 26, 27,
  462. 56, 57, 58, 59, 120, 242, 486, 487,
  463. 488, 489, 980, 981, 982, 983, 984, 985,
  464. 986, 987, 988, 989, 990, 991, 992, 993,
  465. 994, 995, 996, 997, 998, 999, 1000, 1001,
  466. 1002, 1003, 1004, 1005, 1006, 1007, 1008, 1009,
  467. 1010, 1011, 1012, 1013, 1014, 1015, 1016, 1017,
  468. 1018, 1019, 1020, 1021, 1022, 1023,
  469. };
  470. static const uint8_t dnxhd_1235_1238_1241_run_bits[62] = {
  471. 1, 3, 4, 4, 5, 5, 5, 5, 6, 6, 6, 6, 7, 8, 9, 9,
  472. 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  473. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  474. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  475. };
  476. static const uint8_t dnxhd_1238_run[62] = {
  477. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
  478. 20, 21, 17, 18, 19, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32,
  479. 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
  480. 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62,
  481. };
  482. static const uint8_t dnxhd_1235_1241_dc_codes[14] = {
  483. 10, 62, 11, 12, 13, 0, 1, 2, 3, 4, 14, 30, 126, 127,
  484. };
  485. static const uint8_t dnxhd_1235_1241_dc_bits[14] = {
  486. 4, 6, 4, 4, 4, 3, 3, 3, 3, 3, 4, 5, 7, 7,
  487. };
  488. static const uint16_t dnxhd_1235_1241_ac_codes[257] = {
  489. 0, 1, 4, 10, 11, 24, 25, 26,
  490. 54, 55, 56, 57, 116, 117, 118, 119,
  491. 240, 241, 242, 243, 244, 245, 492, 493,
  492. 494, 495, 496, 497, 498, 998, 999, 1000,
  493. 1001, 1002, 1003, 1004, 1005, 1006, 1007, 2016,
  494. 2017, 2018, 2019, 2020, 2021, 2022, 2023, 2024,
  495. 2025, 2026, 4054, 4055, 4056, 4057, 4058, 4059,
  496. 4060, 4061, 4062, 4063, 4064, 4065, 4066, 4067,
  497. 4068, 4069, 8140, 8141, 8142, 8143, 8144, 8145,
  498. 8146, 8147, 8148, 8149, 8150, 8151, 8152, 8153,
  499. 8154, 8155, 8156, 8157, 16316, 16317, 16318, 16319,
  500. 16320, 16321, 16322, 16323, 16324, 16325, 16326, 16327,
  501. 16328, 16329, 16330, 16331, 16332, 16333, 16334, 16335,
  502. 16336, 16337, 32676, 32677, 32678, 32679, 32680, 32681,
  503. 32682, 32683, 32684, 32685, 32686, 32687, 32688, 32689,
  504. 32690, 32691, 32692, 32693, 32694, 32695, 32696, 32697,
  505. 32698, 32699, 32700, 32701, 32702, 32703, 32704, 32705,
  506. 32706, 32707, 32708, 65418, 65419, 65420, 65421, 65422,
  507. 65423, 65424, 65425, 65426, 65427, 65428, 65429, 65430,
  508. 65431, 65432, 65433, 65434, 65435, 65436, 65437, 65438,
  509. 65439, 65440, 65441, 65442, 65443, 65444, 65445, 65446,
  510. 65447, 65448, 65449, 65450, 65451, 65452, 65453, 65454,
  511. 65455, 65456, 65457, 65458, 65459, 65460, 65461, 65462,
  512. 65463, 65464, 65465, 65466, 65467, 65468, 65469, 65470,
  513. 65471, 65472, 65473, 65474, 65475, 65476, 65477, 65478,
  514. 65479, 65480, 65481, 65482, 65483, 65484, 65485, 65486,
  515. 65487, 65488, 65489, 65490, 65491, 65492, 65493, 65494,
  516. 65495, 65496, 65497, 65498, 65499, 65500, 65501, 65502,
  517. 65503, 65504, 65505, 65506, 65507, 65508, 65509, 65510,
  518. 65511, 65512, 65513, 65514, 65515, 65516, 65517, 65518,
  519. 65519, 65520, 65521, 65522, 65523, 65524, 65525, 65526,
  520. 65527, 65528, 65529, 65530, 65531, 65532, 65533, 65534,
  521. 65535,
  522. };
  523. static const uint8_t dnxhd_1235_1241_ac_bits[257] = {
  524. 2, 2, 3, 4, 4, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7,
  525. 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10,
  526. 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11,
  527. 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
  528. 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
  529. 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  530. 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15,
  531. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
  532. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 16, 16, 16, 16,
  533. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  534. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  535. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  536. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  537. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  538. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  539. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  540. 16,
  541. };
  542. static const uint8_t dnxhd_1235_1241_ac_level[257] = {
  543. 1, 1, 2, 3, 0, 4, 5, 2, 6, 7, 8, 3, 9, 10, 11, 4,
  544. 12, 13, 14, 15, 16, 5, 17, 18, 19, 20, 21, 6, 7, 22, 23, 24,
  545. 25, 26, 27, 28, 29, 8, 9, 30, 31, 32, 33, 34, 35, 36, 37, 38,
  546. 10, 11, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 12, 13,
  547. 14, 15, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 1,
  548. 16, 17, 18, 19, 64, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,
  549. 13, 14, 15, 16, 17, 20, 21, 22, 23, 24, 18, 19, 20, 21, 22, 23,
  550. 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39,
  551. 40, 41, 42, 25, 26, 27, 28, 29, 30, 31, 32, 43, 44, 45, 46, 47,
  552. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  553. 64, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  554. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  555. 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
  556. 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
  557. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  558. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  559. 64,
  560. };
  561. static const uint8_t dnxhd_1235_1241_ac_run_flag[257] = {
  562. 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1,
  563. 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0,
  564. 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  565. 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1,
  566. 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  567. 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  568. 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0,
  569. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  570. 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0,
  571. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  572. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  573. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  574. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  575. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  576. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  577. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  578. 1,
  579. };
  580. static const uint8_t dnxhd_1235_1241_ac_index_flag[257] = {
  581. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  582. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  583. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  584. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  585. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  586. 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  587. 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1,
  588. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  589. 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1,
  590. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  591. 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  592. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  593. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  594. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  595. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  596. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  597. 1,
  598. };
  599. static const uint8_t dnxhd_1235_1241_run[62] = {
  600. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
  601. 18, 20, 17, 19, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32,
  602. 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
  603. 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62,
  604. };
  605. static const uint8_t dnxhd_1250_dc_codes[14] = {
  606. 10, 62, 11, 12, 13, 0, 1, 2, 3, 4, 14, 30, 126, 127
  607. };
  608. static const uint8_t dnxhd_1250_dc_bits[14] = {
  609. 4, 6, 4, 4, 4, 3, 3, 3, 3, 3, 4, 5, 7, 7
  610. };
  611. static const uint16_t dnxhd_1250_ac_codes[257] = {
  612. 0, 1, 4, 10, 11, 24, 25, 26,
  613. 54, 55, 56, 57, 116, 117, 118, 119,
  614. 240, 241, 242, 243, 244, 245, 492, 493,
  615. 494, 495, 496, 497, 498, 998, 999, 1000,
  616. 1001, 1002, 1003, 1004, 1005, 1006, 2014, 2015,
  617. 2016, 2017, 2018, 2019, 2020, 2021, 2022, 2023,
  618. 2024, 2025, 4052, 4053, 4054, 4055, 4056, 4057,
  619. 4058, 4059, 4060, 4061, 4062, 4063, 4064, 4065,
  620. 4066, 4067, 8136, 8137, 8138, 8139, 8140, 8141,
  621. 8142, 8143, 8144, 8145, 8146, 8147, 8148, 8149,
  622. 8150, 8151, 8152, 8153, 8154, 8155, 8156, 16314,
  623. 16315, 16316, 16317, 16318, 16319, 16320, 16321, 16322,
  624. 16323, 16324, 16325, 16326, 16327, 16328, 16329, 16330,
  625. 16331, 16332, 16333, 16334, 16335, 16336, 16337, 16338,
  626. 32678, 32679, 32680, 32681, 32682, 32683, 32684, 32685,
  627. 32686, 32687, 32688, 32689, 32690, 32691, 32692, 32693,
  628. 32694, 32695, 32696, 32697, 32698, 32699, 32700, 32701,
  629. 32702, 32703, 32704, 32705, 32706, 32707, 32708, 32709,
  630. 32710, 32711, 32712, 65426, 65427, 65428, 65429, 65430,
  631. 65431, 65432, 65433, 65434, 65435, 65436, 65437, 65438,
  632. 65439, 65440, 65441, 65442, 65443, 65444, 65445, 65446,
  633. 65447, 65448, 65449, 65450, 65451, 65452, 65453, 65454,
  634. 65455, 65456, 65457, 65458, 65459, 65460, 65461, 65462,
  635. 65463, 65464, 65465, 65466, 65467, 65468, 65469, 65470,
  636. 65471, 65472, 65473, 65474, 65475, 65476, 65477, 65478,
  637. 65479, 65480, 65481, 65482, 65483, 65484, 65485, 65486,
  638. 65487, 65488, 65489, 65490, 65491, 65492, 65493, 65494,
  639. 65495, 65496, 65497, 65498, 65499, 65500, 65501, 65502,
  640. 65503, 65504, 65505, 65506, 65507, 65508, 65509, 65510,
  641. 65511, 65512, 65513, 65514, 65515, 65516, 65517, 65518,
  642. 65519, 65520, 65521, 65522, 65523, 65524, 65525, 65526,
  643. 65527, 65528, 65529, 65530, 65531, 65532, 65533, 65534,
  644. 65535
  645. };
  646. static const uint8_t dnxhd_1250_ac_bits[257] = {
  647. 2, 2, 3, 4, 4, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7,
  648. 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10,
  649. 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11,
  650. 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
  651. 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
  652. 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  653. 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  654. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
  655. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
  656. 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  657. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  658. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  659. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  660. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  661. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  662. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  663. 16
  664. };
  665. static const uint8_t dnxhd_1250_ac_level[257] = {
  666. 1, 1, 2, 3, 0, 4, 5, 2, 6, 7, 8, 3, 9, 10, 11, 4,
  667. 12, 13, 14, 15, 16, 5, 17, 18, 19, 20, 21, 22, 6, 23, 24, 25,
  668. 26, 27, 28, 29, 7, 8, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39,
  669. 9, 10, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 11,
  670. 12, 13, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 1, 2,
  671. 3, 4, 5, 14, 15, 16, 17, 6, 7, 8, 9, 10, 11, 12, 13, 14,
  672. 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 18, 19, 20, 21,
  673. 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42,
  674. 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 55, 56, 22, 23, 24,
  675. 25, 26, 27, 54, 57, 58, 59, 60, 61, 62, 63, 64, 28, 29, 30, 31,
  676. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  677. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  678. 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
  679. 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
  680. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  681. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  682. 64
  683. };
  684. static const uint8_t dnxhd_1250_ac_run_flag[257] = {
  685. 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1,
  686. 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0,
  687. 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  688. 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  689. 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  690. 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  691. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,
  692. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  693. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1,
  694. 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1,
  695. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  696. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  697. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  698. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  699. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  700. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  701. 1
  702. };
  703. static const uint8_t dnxhd_1250_ac_index_flag[257] = {
  704. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  705. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  706. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  707. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  708. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1,
  709. 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  710. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0,
  711. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  712. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0,
  713. 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0,
  714. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  715. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  716. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  717. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  718. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  719. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  720. 1
  721. };
  722. static const uint16_t dnxhd_1250_run_codes[62] = {
  723. 0, 4, 5, 12, 26, 27, 28, 58,
  724. 118, 119, 120, 242, 486, 487, 976, 977,
  725. 978, 979, 980, 981, 982, 983, 984, 985,
  726. 986, 987, 988, 989, 990, 991, 992, 993,
  727. 994, 995, 996, 997, 998, 999, 1000, 1001,
  728. 1002, 1003, 1004, 1005, 1006, 1007, 1008, 1009,
  729. 1010, 1011, 1012, 1013, 1014, 1015, 1016, 1017,
  730. 1018, 1019, 1020, 1021, 1022, 1023
  731. };
  732. static const uint8_t dnxhd_1250_run_bits[62] = {
  733. 1, 3, 3, 4, 5, 5, 5, 6, 7, 7, 7, 8, 9, 9, 10, 10,
  734. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  735. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  736. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10
  737. };
  738. static const uint8_t dnxhd_1250_run[62] = {
  739. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
  740. 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32,
  741. 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
  742. 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62
  743. };
  744. static const uint8_t dnxhd_1251_dc_codes[12] = {
  745. 0, 12, 13, 1, 2, 3, 4, 5, 14, 30, 62, 63,
  746. };
  747. static const uint8_t dnxhd_1251_dc_bits[12] = {
  748. 3, 4, 4, 3, 3, 3, 3, 3, 4, 5, 6, 6,
  749. };
  750. static const uint16_t dnxhd_1251_ac_codes[257] = {
  751. 0, 1, 4, 10, 11, 24, 25, 26,
  752. 54, 55, 56, 57, 116, 117, 118, 119,
  753. 240, 241, 242, 243, 244, 245, 492, 493,
  754. 494, 495, 496, 497, 996, 997, 998, 999,
  755. 1000, 1001, 1002, 1003, 1004, 1005, 2012, 2013,
  756. 2014, 2015, 2016, 2017, 2018, 2019, 2020, 2021,
  757. 2022, 2023, 2024, 2025, 4052, 4053, 4054, 4055,
  758. 4056, 4057, 4058, 4059, 4060, 4061, 4062, 4063,
  759. 4064, 4065, 4066, 8134, 8135, 8136, 8137, 8138,
  760. 8139, 8140, 8141, 8142, 8143, 8144, 8145, 8146,
  761. 8147, 8148, 8149, 8150, 8151, 8152, 8153, 8154,
  762. 8155, 8156, 16314, 16315, 16316, 16317, 16318, 16319,
  763. 16320, 16321, 16322, 16323, 16324, 16325, 16326, 16327,
  764. 16328, 16329, 16330, 16331, 16332, 16333, 16334, 16335,
  765. 16336, 16337, 16338, 16339, 32680, 32681, 32682, 32683,
  766. 32684, 32685, 32686, 32687, 32688, 32689, 32690, 32691,
  767. 32692, 32693, 32694, 32695, 32696, 32697, 32698, 32699,
  768. 32700, 32701, 32702, 32703, 32704, 32705, 32706, 32707,
  769. 32708, 32709, 32710, 32711, 32712, 32713, 32714, 65430,
  770. 65431, 65432, 65433, 65434, 65435, 65436, 65437, 65438,
  771. 65439, 65440, 65441, 65442, 65443, 65444, 65445, 65446,
  772. 65447, 65448, 65449, 65450, 65451, 65452, 65453, 65454,
  773. 65455, 65456, 65457, 65458, 65459, 65460, 65461, 65462,
  774. 65463, 65464, 65465, 65466, 65467, 65468, 65469, 65470,
  775. 65471, 65472, 65473, 65474, 65475, 65476, 65477, 65478,
  776. 65479, 65480, 65481, 65482, 65483, 65484, 65485, 65486,
  777. 65487, 65488, 65489, 65490, 65491, 65492, 65493, 65494,
  778. 65495, 65496, 65497, 65498, 65499, 65500, 65501, 65502,
  779. 65503, 65504, 65505, 65506, 65507, 65508, 65509, 65510,
  780. 65511, 65512, 65513, 65514, 65515, 65516, 65517, 65518,
  781. 65519, 65520, 65521, 65522, 65523, 65524, 65525, 65526,
  782. 65527, 65528, 65529, 65530, 65531, 65532, 65533, 65534,
  783. 65535,
  784. };
  785. static const uint8_t dnxhd_1251_ac_bits[257] = {
  786. 2, 2, 3, 4, 4, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7,
  787. 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10,
  788. 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11,
  789. 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12,
  790. 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13,
  791. 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14,
  792. 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  793. 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
  794. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15,
  795. 15, 15, 15, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  796. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  797. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  798. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  799. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  800. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  801. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  802. 16,
  803. };
  804. static const uint8_t dnxhd_1251_ac_level[257] = {
  805. 1, 1, 2, 3, 0, 4, 5, 2, 6, 7, 8, 3, 9, 10, 11, 4,
  806. 12, 13, 14, 15, 16, 5, 17, 18, 19, 20, 21, 6, 22, 23, 24, 25,
  807. 26, 27, 28, 29, 7, 8, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39,
  808. 40, 9, 10, 11, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52,
  809. 12, 13, 14, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 1,
  810. 2, 3, 4, 5, 6, 7, 8, 15, 16, 17, 9, 10, 11, 12, 13, 14,
  811. 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 18,
  812. 19, 20, 21, 22, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41,
  813. 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57,
  814. 58, 23, 24, 25, 26, 27, 28, 59, 60, 61, 62, 63, 64, 29, 30, 31,
  815. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  816. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  817. 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
  818. 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
  819. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  820. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  821. 64,
  822. };
  823. static const uint8_t dnxhd_1251_ac_run_flag[257] = {
  824. 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 1,
  825. 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
  826. 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  827. 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  828. 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  829. 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0,
  830. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  831. 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  832. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  833. 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1,
  834. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  835. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  836. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  837. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  838. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  839. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  840. 1,
  841. };
  842. static const uint8_t dnxhd_1251_ac_index_flag[257] = {
  843. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  844. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  845. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  846. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  847. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
  848. 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1,
  849. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0,
  850. 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  851. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  852. 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0,
  853. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  854. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  855. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  856. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  857. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  858. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  859. 1,
  860. };
  861. static const uint16_t dnxhd_1251_run_codes[62] = {
  862. 0, 4, 5, 12, 26, 27, 28, 58,
  863. 118, 119, 120, 242, 486, 487, 976, 977,
  864. 978, 979, 980, 981, 982, 983, 984, 985,
  865. 986, 987, 988, 989, 990, 991, 992, 993,
  866. 994, 995, 996, 997, 998, 999, 1000, 1001,
  867. 1002, 1003, 1004, 1005, 1006, 1007, 1008, 1009,
  868. 1010, 1011, 1012, 1013, 1014, 1015, 1016, 1017,
  869. 1018, 1019, 1020, 1021, 1022, 1023,
  870. };
  871. static const uint8_t dnxhd_1251_run_bits[62] = {
  872. 1, 3, 3, 4, 5, 5, 5, 6, 7, 7, 7, 8, 9, 9, 10, 10,
  873. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  874. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  875. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  876. };
  877. static const uint8_t dnxhd_1251_run[62] = {
  878. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16,
  879. 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32,
  880. 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
  881. 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62,
  882. };
  883. static const uint8_t dnxhd_1252_dc_codes[12] = {
  884. 0, 12, 13, 1, 2, 3, 4, 5, 14, 30, 62, 63,
  885. };
  886. static const uint8_t dnxhd_1252_dc_bits[12] = {
  887. 3, 4, 4, 3, 3, 3, 3, 3, 4, 5, 6, 6,
  888. };
  889. static const uint16_t dnxhd_1252_ac_codes[257] = {
  890. 0, 1, 4, 10, 11, 12, 26, 27,
  891. 56, 57, 58, 118, 119, 120, 242, 243,
  892. 244, 245, 246, 247, 496, 497, 498, 499,
  893. 500, 1002, 1003, 1004, 1005, 1006, 1007, 1008,
  894. 1009, 2020, 2021, 2022, 2023, 2024, 2025, 2026,
  895. 2027, 2028, 2029, 4060, 4061, 4062, 4063, 4064,
  896. 4065, 4066, 4067, 4068, 4069, 4070, 4071, 8144,
  897. 8145, 8146, 8147, 8148, 8149, 8150, 8151, 8152,
  898. 8153, 8154, 8155, 8156, 8157, 8158, 16318, 16319,
  899. 16320, 16321, 16322, 16323, 16324, 16325, 16326, 16327,
  900. 16328, 16329, 16330, 16331, 16332, 16333, 16334, 16335,
  901. 32672, 32673, 32674, 32675, 32676, 32677, 32678, 32679,
  902. 32680, 32681, 32682, 32683, 32684, 32685, 32686, 32687,
  903. 32688, 32689, 32690, 32691, 32692, 32693, 32694, 65390,
  904. 65391, 65392, 65393, 65394, 65395, 65396, 65397, 65398,
  905. 65399, 65400, 65401, 65402, 65403, 65404, 65405, 65406,
  906. 65407, 65408, 65409, 65410, 65411, 65412, 65413, 65414,
  907. 65415, 65416, 65417, 65418, 65419, 65420, 65421, 65422,
  908. 65423, 65424, 65425, 65426, 65427, 65428, 65429, 65430,
  909. 65431, 65432, 65433, 65434, 65435, 65436, 65437, 65438,
  910. 65439, 65440, 65441, 65442, 65443, 65444, 65445, 65446,
  911. 65447, 65448, 65449, 65450, 65451, 65452, 65453, 65454,
  912. 65455, 65456, 65457, 65458, 65459, 65460, 65461, 65462,
  913. 65463, 65464, 65465, 65466, 65467, 65468, 65469, 65470,
  914. 65471, 65472, 65473, 65474, 65475, 65476, 65477, 65478,
  915. 65479, 65480, 65481, 65482, 65483, 65484, 65485, 65486,
  916. 65487, 65488, 65489, 65490, 65491, 65492, 65493, 65494,
  917. 65495, 65496, 65497, 65498, 65499, 65500, 65501, 65502,
  918. 65503, 65504, 65505, 65506, 65507, 65508, 65509, 65510,
  919. 65511, 65512, 65513, 65514, 65515, 65516, 65517, 65518,
  920. 65519, 65520, 65521, 65522, 65523, 65524, 65525, 65526,
  921. 65527, 65528, 65529, 65530, 65531, 65532, 65533, 65534,
  922. 65535,
  923. };
  924. static const uint8_t dnxhd_1252_ac_bits[257] = {
  925. 2, 2, 3, 4, 4, 4, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8,
  926. 8, 8, 8, 8, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10,
  927. 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12,
  928. 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13,
  929. 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  930. 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15,
  931. 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16,
  932. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  933. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  934. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  935. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  936. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  937. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  938. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  939. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  940. 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16,
  941. 16,
  942. };
  943. static const uint8_t dnxhd_1252_ac_level[257] = {
  944. 1, 1, 2, 3, 2, 0, 4, 5, 6, 7, 3, 8, 9, 10, 11, 12,
  945. 13, 14, 4, 5, 15, 16, 17, 18, 6, 19, 20, 21, 22, 23, 24, 7,
  946. 8, 25, 26, 27, 28, 29, 30, 31, 32, 9, 10, 33, 34, 35, 36, 37,
  947. 38, 39, 40, 41, 11, 12, 13, 42, 43, 44, 45, 46, 47, 48, 49, 50,
  948. 51, 52, 53, 14, 15, 16, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  949. 64, 1, 2, 3, 17, 18, 19, 20, 4, 5, 6, 7, 8, 9, 10, 11,
  950. 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 21, 22, 23, 24, 25, 22,
  951. 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,
  952. 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54,
  953. 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 26, 27, 28, 29, 30, 31,
  954. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  955. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  956. 64, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
  957. 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
  958. 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
  959. 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63,
  960. 64,
  961. };
  962. static const uint8_t dnxhd_1252_ac_run_flag[257] = {
  963. 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
  964. 0, 0, 1, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1,
  965. 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0, 0,
  966. 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  967. 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  968. 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0,
  969. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0,
  970. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  971. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  972. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1,
  973. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  974. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  975. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  976. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  977. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  978. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  979. 1,
  980. };
  981. static const uint8_t dnxhd_1252_ac_index_flag[257] = {
  982. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  983. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  984. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  985. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  986. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  987. 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1,
  988. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1,
  989. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  990. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  991. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0,
  992. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  993. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  994. 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  995. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  996. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  997. 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
  998. 1,
  999. };
  1000. const CIDEntry ff_dnxhd_cid_table[] = {
  1001. { 1235, 1920, 1080, 0, 917504, 917504, 6, 10,
  1002. dnxhd_1235_luma_weight, dnxhd_1235_chroma_weight,
  1003. dnxhd_1235_1241_dc_codes, dnxhd_1235_1241_dc_bits,
  1004. dnxhd_1235_1241_ac_codes, dnxhd_1235_1241_ac_bits, dnxhd_1235_1241_ac_level,
  1005. dnxhd_1235_1241_ac_run_flag, dnxhd_1235_1241_ac_index_flag,
  1006. dnxhd_1235_1238_1241_run_codes, dnxhd_1235_1238_1241_run_bits, dnxhd_1235_1241_run,
  1007. { 175, 185, 365, 440 } },
  1008. { 1237, 1920, 1080, 0, 606208, 606208, 4, 8,
  1009. dnxhd_1237_luma_weight, dnxhd_1237_chroma_weight,
  1010. dnxhd_1237_dc_codes, dnxhd_1237_dc_bits,
  1011. dnxhd_1237_ac_codes, dnxhd_1237_ac_bits, dnxhd_1237_ac_level,
  1012. dnxhd_1237_ac_run_flag, dnxhd_1237_ac_index_flag,
  1013. dnxhd_1237_run_codes, dnxhd_1237_run_bits, dnxhd_1237_run,
  1014. { 115, 120, 145, 240, 290 } },
  1015. { 1238, 1920, 1080, 0, 917504, 917504, 4, 8,
  1016. dnxhd_1238_luma_weight, dnxhd_1238_chroma_weight,
  1017. dnxhd_1238_dc_codes, dnxhd_1238_dc_bits,
  1018. dnxhd_1238_ac_codes, dnxhd_1238_ac_bits, dnxhd_1238_ac_level,
  1019. dnxhd_1238_ac_run_flag, dnxhd_1238_ac_index_flag,
  1020. dnxhd_1235_1238_1241_run_codes, dnxhd_1235_1238_1241_run_bits, dnxhd_1238_run,
  1021. { 175, 185, 220, 365, 440 } },
  1022. { 1241, 1920, 1080, 1, 917504, 458752, 6, 10,
  1023. dnxhd_1241_luma_weight, dnxhd_1241_chroma_weight,
  1024. dnxhd_1235_1241_dc_codes, dnxhd_1235_1241_dc_bits,
  1025. dnxhd_1235_1241_ac_codes, dnxhd_1235_1241_ac_bits, dnxhd_1235_1241_ac_level,
  1026. dnxhd_1235_1241_ac_run_flag, dnxhd_1235_1241_ac_index_flag,
  1027. dnxhd_1235_1238_1241_run_codes, dnxhd_1235_1238_1241_run_bits, dnxhd_1235_1241_run,
  1028. { 185, 220 } },
  1029. { 1242, 1920, 1080, 1, 606208, 303104, 4, 8,
  1030. dnxhd_1242_luma_weight, dnxhd_1242_chroma_weight,
  1031. dnxhd_1237_dc_codes, dnxhd_1237_dc_bits,
  1032. dnxhd_1237_ac_codes, dnxhd_1237_ac_bits, dnxhd_1237_ac_level,
  1033. dnxhd_1237_ac_run_flag, dnxhd_1237_ac_index_flag,
  1034. dnxhd_1237_run_codes, dnxhd_1237_run_bits, dnxhd_1237_run,
  1035. { 120, 145 } },
  1036. { 1243, 1920, 1080, 1, 917504, 458752, 4, 8,
  1037. dnxhd_1243_luma_weight, dnxhd_1243_chroma_weight,
  1038. dnxhd_1238_dc_codes, dnxhd_1238_dc_bits,
  1039. dnxhd_1238_ac_codes, dnxhd_1238_ac_bits, dnxhd_1238_ac_level,
  1040. dnxhd_1238_ac_run_flag, dnxhd_1238_ac_index_flag,
  1041. dnxhd_1235_1238_1241_run_codes, dnxhd_1235_1238_1241_run_bits, dnxhd_1238_run,
  1042. { 185, 220 } },
  1043. { 1250, 1280, 720, 0, 458752, 458752, 6, 10,
  1044. dnxhd_1250_luma_weight, dnxhd_1250_chroma_weight,
  1045. dnxhd_1250_dc_codes, dnxhd_1250_dc_bits,
  1046. dnxhd_1250_ac_codes, dnxhd_1250_ac_bits, dnxhd_1250_ac_level,
  1047. dnxhd_1250_ac_run_flag, dnxhd_1250_ac_index_flag,
  1048. dnxhd_1250_run_codes, dnxhd_1250_run_bits, dnxhd_1250_run,
  1049. { 90, 180, 220 } },
  1050. { 1251, 1280, 720, 0, 458752, 458752, 4, 8,
  1051. dnxhd_1251_luma_weight, dnxhd_1251_chroma_weight,
  1052. dnxhd_1251_dc_codes, dnxhd_1251_dc_bits,
  1053. dnxhd_1251_ac_codes, dnxhd_1251_ac_bits, dnxhd_1251_ac_level,
  1054. dnxhd_1251_ac_run_flag, dnxhd_1251_ac_index_flag,
  1055. dnxhd_1251_run_codes, dnxhd_1251_run_bits, dnxhd_1251_run,
  1056. { 90, 110, 175, 220 } },
  1057. { 1252, 1280, 720, 0, 303104, 303104, 4, 8,
  1058. dnxhd_1252_luma_weight, dnxhd_1252_chroma_weight,
  1059. dnxhd_1252_dc_codes, dnxhd_1252_dc_bits,
  1060. dnxhd_1252_ac_codes, dnxhd_1252_ac_bits, dnxhd_1252_ac_level,
  1061. dnxhd_1252_ac_run_flag, dnxhd_1252_ac_index_flag,
  1062. dnxhd_1251_run_codes, dnxhd_1251_run_bits, dnxhd_1251_run,
  1063. { 60, 75, 115, 145 } },
  1064. { 1253, 1920, 1080, 0, 188416, 188416, 4, 8,
  1065. dnxhd_1237_luma_weight, dnxhd_1237_chroma_weight,
  1066. dnxhd_1237_dc_codes, dnxhd_1237_dc_bits,
  1067. dnxhd_1237_ac_codes, dnxhd_1237_ac_bits, dnxhd_1237_ac_level,
  1068. dnxhd_1237_ac_run_flag, dnxhd_1237_ac_index_flag,
  1069. dnxhd_1237_run_codes, dnxhd_1237_run_bits, dnxhd_1237_run,
  1070. { 36, 45, 75, 90 } },
  1071. };
  1072. int ff_dnxhd_get_cid_table(int cid)
  1073. {
  1074. int i;
  1075. for (i = 0; i < FF_ARRAY_ELEMS(ff_dnxhd_cid_table); i++)
  1076. if (ff_dnxhd_cid_table[i].cid == cid)
  1077. return i;
  1078. return -1;
  1079. }
  1080. int ff_dnxhd_find_cid(AVCodecContext *avctx, int bit_depth)
  1081. {
  1082. int i, j;
  1083. int mbs = avctx->bit_rate/1000000;
  1084. if (!mbs)
  1085. return 0;
  1086. for (i = 0; i < FF_ARRAY_ELEMS(ff_dnxhd_cid_table); i++) {
  1087. const CIDEntry *cid = &ff_dnxhd_cid_table[i];
  1088. if (cid->width == avctx->width && cid->height == avctx->height &&
  1089. cid->interlaced == !!(avctx->flags & CODEC_FLAG_INTERLACED_DCT) &&
  1090. cid->bit_depth == bit_depth) {
  1091. for (j = 0; j < sizeof(cid->bit_rates); j++) {
  1092. if (cid->bit_rates[j] == mbs)
  1093. return cid->cid;
  1094. }
  1095. }
  1096. }
  1097. return 0;
  1098. }