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.

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