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.

1379 lines
57KB

  1. /*
  2. * DCA compatible decoder - huffman tables
  3. * Copyright (C) 2004 Gildas Bazin
  4. * Copyright (C) 2007 Konstantin Shishkov
  5. *
  6. * This file is part of FFmpeg.
  7. *
  8. * FFmpeg is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU Lesser General Public
  10. * License as published by the Free Software Foundation; either
  11. * version 2.1 of the License, or (at your option) any later version.
  12. *
  13. * FFmpeg is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * Lesser General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with FFmpeg; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  21. */
  22. #include "libavutil/common.h"
  23. #include "avcodec.h"
  24. #include "get_bits.h"
  25. #include "dcahuff.h"
  26. #define TMODE_COUNT 4
  27. static const uint8_t tmode_vlc_bits[TMODE_COUNT] = { 3, 3, 3, 2 };
  28. static const uint16_t tmode_codes[TMODE_COUNT][4] = {
  29. { 0x0000, 0x0002, 0x0006, 0x0007 },
  30. { 0x0002, 0x0006, 0x0007, 0x0000 },
  31. { 0x0006, 0x0007, 0x0000, 0x0002 },
  32. { 0x0000, 0x0001, 0x0002, 0x0003 }
  33. };
  34. static const uint8_t tmode_bits[TMODE_COUNT][4] = {
  35. { 1, 2, 3, 3 },
  36. { 2, 3, 3, 1 },
  37. { 3, 3, 1, 2 },
  38. { 2, 2, 2, 2 }
  39. };
  40. #define BITALLOC_12_VLC_BITS 9
  41. static const uint8_t bitalloc_12_vlc_bits[DCA_BITALLOC_12_COUNT] = {
  42. 9, 7, 7, 9, 9
  43. };
  44. static const uint16_t bitalloc_12_codes[DCA_BITALLOC_12_COUNT][12] = {
  45. { 0x0000, 0x0002, 0x0006, 0x000E, 0x001E, 0x003E, 0x00FF, 0x00FE,
  46. 0x01FB, 0x01FA, 0x01F9, 0x01F8, },
  47. { 0x0001, 0x0000, 0x0002, 0x000F, 0x000C, 0x001D, 0x0039, 0x0038,
  48. 0x0037, 0x0036, 0x0035, 0x0034, },
  49. { 0x0000, 0x0007, 0x0005, 0x0004, 0x0002, 0x000D, 0x000C, 0x0006,
  50. 0x000F, 0x001D, 0x0039, 0x0038, },
  51. { 0x0003, 0x0002, 0x0000, 0x0002, 0x0006, 0x000E, 0x001E, 0x003E,
  52. 0x007E, 0x00FE, 0x01FF, 0x01FE, },
  53. { 0x0001, 0x0000, 0x0002, 0x0006, 0x000E, 0x003F, 0x003D, 0x007C,
  54. 0x0079, 0x0078, 0x00FB, 0x00FA, }
  55. };
  56. static const uint8_t bitalloc_12_bits[DCA_BITALLOC_12_COUNT][12] = {
  57. { 1, 2, 3, 4, 5, 6, 8, 8, 9, 9, 9, 9 },
  58. { 1, 2, 3, 5, 5, 6, 7, 7, 7, 7, 7, 7 },
  59. { 2, 3, 3, 3, 3, 4, 4, 4, 5, 6, 7, 7 },
  60. { 2, 2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 10 },
  61. { 1, 2, 3, 4, 5, 7, 7, 8, 8, 8, 9, 9 }
  62. };
  63. #define SCALES_COUNT 5
  64. #define SCALES_VLC_BITS 9
  65. static const uint16_t scales_codes[SCALES_COUNT][129] = {
  66. { 0x3AB0, 0x3AB2, 0x3AB4, 0x3AB6, 0x3AB8, 0x3ABA, 0x3ABC, 0x3ABE,
  67. 0x3AC0, 0x3AC2, 0x3AC4, 0x3AC6, 0x3AC8, 0x3ACA, 0x3ACC, 0x3ACE,
  68. 0x3AD0, 0x3AD2, 0x3AD4, 0x3AD6, 0x3AD8, 0x3ADA, 0x3ADC, 0x3ADE,
  69. 0x3AE0, 0x3AE2, 0x3AE4, 0x3AE6, 0x3AE8, 0x3AEA, 0x3AEC, 0x3AEE,
  70. 0x3AF0, 0x3AF2, 0x3AF4, 0x3AF6, 0x3AF8, 0x3AFA, 0x3AFC, 0x3AFE,
  71. 0x0540, 0x0542, 0x0544, 0x0546, 0x0548, 0x054A, 0x054C, 0x054E,
  72. 0x0558, 0x055E, 0x02AD, 0x0154, 0x0754, 0x03A8, 0x0056, 0x0028,
  73. 0x00E8, 0x004A, 0x000B, 0x003B, 0x0013, 0x0003, 0x000F, 0x0005,
  74. 0x0001, 0x0006, 0x0000, 0x0008, 0x001C, 0x0004, 0x0024, 0x004B,
  75. 0x00E9, 0x0029, 0x0057, 0x03A9, 0x0755, 0x0155, 0x02AE, 0x055F,
  76. 0x0559, 0x054F, 0x054D, 0x054B, 0x0549, 0x0547, 0x0545, 0x0543,
  77. 0x0541, 0x3AFF, 0x3AFD, 0x3AFB, 0x3AF9, 0x3AF7, 0x3AF5, 0x3AF3,
  78. 0x3AF1, 0x3AEF, 0x3AED, 0x3AEB, 0x3AE9, 0x3AE7, 0x3AE5, 0x3AE3,
  79. 0x3AE1, 0x3ADF, 0x3ADD, 0x3ADB, 0x3AD9, 0x3AD7, 0x3AD5, 0x3AD3,
  80. 0x3AD1, 0x3ACF, 0x3ACD, 0x3ACB, 0x3AC9, 0x3AC7, 0x3AC5, 0x3AC3,
  81. 0x3AC1, 0x3ABF, 0x3ABD, 0x3ABB, 0x3AB9, 0x3AB7, 0x3AB5, 0x3AB3,
  82. 0x3AB1, },
  83. { 0x0F60, 0x0F62, 0x0F64, 0x0F66, 0x0F68, 0x0F6A, 0x0F6C, 0x0F6E,
  84. 0x0F70, 0x0F72, 0x0F74, 0x0F76, 0x0F78, 0x0F7A, 0x0F7C, 0x0F7E,
  85. 0x0F80, 0x0F82, 0x0F84, 0x0F86, 0x0F88, 0x0F8A, 0x0F8C, 0x0F8E,
  86. 0x0F90, 0x0F92, 0x0F94, 0x0F96, 0x0F98, 0x0F9A, 0x0F9C, 0x0F9E,
  87. 0x0FA0, 0x0FA2, 0x0FA4, 0x0FA6, 0x0FA8, 0x0FAA, 0x0FAC, 0x0FAE,
  88. 0x0FB0, 0x0FB2, 0x0FB4, 0x0FB6, 0x0FB8, 0x0FBA, 0x0FBC, 0x0FBE,
  89. 0x07A0, 0x07A2, 0x03D2, 0x01EA, 0x00FC, 0x007F, 0x001C, 0x000C,
  90. 0x0004, 0x0034, 0x0010, 0x001B, 0x0009, 0x000B, 0x000E, 0x0001,
  91. 0x0003, 0x0002, 0x000F, 0x000C, 0x000A, 0x0000, 0x0011, 0x0035,
  92. 0x0005, 0x000D, 0x001D, 0x003C, 0x00FD, 0x01EB, 0x03D3, 0x07A3,
  93. 0x07A1, 0x0FBF, 0x0FBD, 0x0FBB, 0x0FB9, 0x0FB7, 0x0FB5, 0x0FB3,
  94. 0x0FB1, 0x0FAF, 0x0FAD, 0x0FAB, 0x0FA9, 0x0FA7, 0x0FA5, 0x0FA3,
  95. 0x0FA1, 0x0F9F, 0x0F9D, 0x0F9B, 0x0F99, 0x0F97, 0x0F95, 0x0F93,
  96. 0x0F91, 0x0F8F, 0x0F8D, 0x0F8B, 0x0F89, 0x0F87, 0x0F85, 0x0F83,
  97. 0x0F81, 0x0F7F, 0x0F7D, 0x0F7B, 0x0F79, 0x0F77, 0x0F75, 0x0F73,
  98. 0x0F71, 0x0F6F, 0x0F6D, 0x0F6B, 0x0F69, 0x0F67, 0x0F65, 0x0F63,
  99. 0x0F61, },
  100. { 0x51D0, 0x51D2, 0x51D4, 0x51D6, 0x51D8, 0x51DA, 0x51DC, 0x51DE,
  101. 0x51E0, 0x51E2, 0x51E4, 0x51E6, 0x51E8, 0x51EA, 0x51EC, 0x51EE,
  102. 0x51F0, 0x51F2, 0x51F4, 0x51F6, 0x51F8, 0x51FA, 0x51FC, 0x51FE,
  103. 0x70C0, 0x70C2, 0x70C4, 0x70C6, 0x70C8, 0x70CA, 0x70CC, 0x70CE,
  104. 0x70EC, 0x10EA, 0x3868, 0x3877, 0x0876, 0x1C35, 0x0434, 0x0A34,
  105. 0x0E1B, 0x021B, 0x051B, 0x070F, 0x010F, 0x0380, 0x0080, 0x0140,
  106. 0x01C1, 0x0041, 0x00A1, 0x00E2, 0x0022, 0x0052, 0x0072, 0x0012,
  107. 0x002A, 0x003A, 0x000A, 0x0016, 0x001E, 0x0006, 0x000C, 0x0000,
  108. 0x0004, 0x0001, 0x000D, 0x0007, 0x001F, 0x0017, 0x000B, 0x003B,
  109. 0x002B, 0x0013, 0x0073, 0x0053, 0x0023, 0x00E3, 0x00A2, 0x0042,
  110. 0x01C2, 0x0141, 0x0081, 0x0381, 0x028C, 0x010C, 0x051C, 0x021C,
  111. 0x0E1C, 0x0A35, 0x0435, 0x1C3A, 0x0877, 0x0874, 0x3869, 0x10EB,
  112. 0x70ED, 0x70CF, 0x70CD, 0x70CB, 0x70C9, 0x70C7, 0x70C5, 0x70C3,
  113. 0x70C1, 0x51FF, 0x51FD, 0x51FB, 0x51F9, 0x51F7, 0x51F5, 0x51F3,
  114. 0x51F1, 0x51EF, 0x51ED, 0x51EB, 0x51E9, 0x51E7, 0x51E5, 0x51E3,
  115. 0x51E1, 0x51DF, 0x51DD, 0x51DB, 0x51D9, 0x51D7, 0x51D5, 0x51D3,
  116. 0x51D1, },
  117. { 0x6F64, 0x6F66, 0x6F68, 0x6F6A, 0x6F6C, 0x6F6E, 0x6F70, 0x6F72,
  118. 0x6F74, 0x6F76, 0x6F78, 0x6F7A, 0x6F7C, 0x6F7E, 0x6F80, 0x6F82,
  119. 0x6F84, 0x6F86, 0x6F88, 0x6F8A, 0x6F8C, 0x6F8E, 0x6F90, 0x6F92,
  120. 0x6F94, 0x6F96, 0x6F98, 0x6F9A, 0x6F9C, 0x6F9E, 0x6FA0, 0x6FA2,
  121. 0x6FA4, 0x6FA6, 0x6FA8, 0x6FAA, 0x6FAC, 0x6FAE, 0x6FB0, 0x6FB2,
  122. 0x6FB4, 0x6FB6, 0x17B4, 0x37DC, 0x0BDB, 0x1BEF, 0x05EE, 0x0DF8,
  123. 0x02F8, 0x06FD, 0x017D, 0x037F, 0x00BF, 0x0040, 0x00C0, 0x0021,
  124. 0x0061, 0x0011, 0x0031, 0x0009, 0x0019, 0x0006, 0x000E, 0x0004,
  125. 0x0000, 0x0005, 0x000F, 0x0007, 0x001A, 0x000A, 0x0036, 0x0016,
  126. 0x006E, 0x002E, 0x00C1, 0x0041, 0x01BC, 0x00BC, 0x037A, 0x017A,
  127. 0x02F9, 0x0DF9, 0x05EF, 0x05EC, 0x1BD8, 0x37DD, 0x17B5, 0x6FB7,
  128. 0x6FB5, 0x6FB3, 0x6FB1, 0x6FAF, 0x6FAD, 0x6FAB, 0x6FA9, 0x6FA7,
  129. 0x6FA5, 0x6FA3, 0x6FA1, 0x6F9F, 0x6F9D, 0x6F9B, 0x6F99, 0x6F97,
  130. 0x6F95, 0x6F93, 0x6F91, 0x6F8F, 0x6F8D, 0x6F8B, 0x6F89, 0x6F87,
  131. 0x6F85, 0x6F83, 0x6F81, 0x6F7F, 0x6F7D, 0x6F7B, 0x6F79, 0x6F77,
  132. 0x6F75, 0x6F73, 0x6F71, 0x6F6F, 0x6F6D, 0x6F6B, 0x6F69, 0x6F67,
  133. 0x6F65, },
  134. { 0xDF54, 0xDF56, 0xDFC8, 0xDFCA, 0xDFCC, 0xDFCE, 0xDFD0, 0xDFD2,
  135. 0xDFD4, 0xDFD6, 0xDFD8, 0xDFDA, 0xDFDC, 0xDFDE, 0xDFE0, 0xDFE2,
  136. 0x0FE8, 0x2FEA, 0x6FA8, 0x6FF6, 0x07F5, 0x07F7, 0x37D2, 0x37F9,
  137. 0x03F8, 0x0BF8, 0x0BFB, 0x1BEB, 0x01FA, 0x05FA, 0x09FA, 0x0DFA,
  138. 0x0DFF, 0x00FF, 0x02FF, 0x06FB, 0x007C, 0x017C, 0x027C, 0x027F,
  139. 0x003C, 0x00BC, 0x013C, 0x01BC, 0x001C, 0x005C, 0x009C, 0x00DC,
  140. 0x000C, 0x002C, 0x004C, 0x006C, 0x0004, 0x0014, 0x0024, 0x0034,
  141. 0x0000, 0x0008, 0x0010, 0x0018, 0x001E, 0x0002, 0x0006, 0x000A,
  142. 0x000E, 0x000B, 0x0007, 0x0003, 0x001F, 0x0019, 0x0011, 0x0009,
  143. 0x0001, 0x0035, 0x0025, 0x0015, 0x0005, 0x006D, 0x004D, 0x002D,
  144. 0x000D, 0x00DD, 0x009D, 0x005D, 0x001D, 0x01BD, 0x013D, 0x00BD,
  145. 0x003D, 0x037C, 0x027D, 0x017D, 0x007D, 0x06FC, 0x04FC, 0x02FC,
  146. 0x00FC, 0x0DFB, 0x09FB, 0x05FB, 0x01FB, 0x1BF8, 0x1BE8, 0x0BF9,
  147. 0x03F9, 0x37FA, 0x37D3, 0x17F4, 0x07F6, 0x6FF7, 0x6FA9, 0x2FEB,
  148. 0x0FE9, 0xDFE3, 0xDFE1, 0xDFDF, 0xDFDD, 0xDFDB, 0xDFD9, 0xDFD7,
  149. 0xDFD5, 0xDFD3, 0xDFD1, 0xDFCF, 0xDFCD, 0xDFCB, 0xDFC9, 0xDF57,
  150. 0xDF55, }
  151. };
  152. static const uint8_t scales_bits[SCALES_COUNT][129] = {
  153. { 14, 14, 14, 14, 14, 14, 14, 14,
  154. 14, 14, 14, 14, 14, 14, 14, 14,
  155. 14, 14, 14, 14, 14, 14, 14, 14,
  156. 14, 14, 14, 14, 14, 14, 14, 14,
  157. 14, 14, 14, 14, 14, 14, 14, 14,
  158. 13, 13, 13, 13, 13, 13, 13, 13,
  159. 13, 13, 12, 11, 11, 10, 9, 8,
  160. 8, 7, 6, 6, 5, 4, 4, 3,
  161. 2, 3, 3, 4, 5, 5, 6, 7,
  162. 8, 8, 9, 10, 11, 11, 12, 13,
  163. 13, 13, 13, 13, 13, 13, 13, 13,
  164. 13, 14, 14, 14, 14, 14, 14, 14,
  165. 14, 14, 14, 14, 14, 14, 14, 14,
  166. 14, 14, 14, 14, 14, 14, 14, 14,
  167. 14, 14, 14, 14, 14, 14, 14, 14,
  168. 14, 14, 14, 14, 14, 14, 14, 14,
  169. 14, },
  170. { 15, 15, 15, 15, 15, 15, 15, 15,
  171. 15, 15, 15, 15, 15, 15, 15, 15,
  172. 15, 15, 15, 15, 15, 15, 15, 15,
  173. 15, 15, 15, 15, 15, 15, 15, 15,
  174. 15, 15, 15, 15, 15, 15, 15, 15,
  175. 15, 15, 15, 15, 15, 15, 15, 15,
  176. 14, 14, 13, 12, 11, 10, 8, 7,
  177. 6, 6, 5, 5, 4, 4, 4, 3,
  178. 3, 3, 4, 4, 4, 4, 5, 6,
  179. 6, 7, 8, 9, 11, 12, 13, 14,
  180. 14, 15, 15, 15, 15, 15, 15, 15,
  181. 15, 15, 15, 15, 15, 15, 15, 15,
  182. 15, 15, 15, 15, 15, 15, 15, 15,
  183. 15, 15, 15, 15, 15, 15, 15, 15,
  184. 15, 15, 15, 15, 15, 15, 15, 15,
  185. 15, 15, 15, 15, 15, 15, 15, 15,
  186. 15, },
  187. { 15, 15, 15, 15, 15, 15, 15, 15,
  188. 15, 15, 15, 15, 15, 15, 15, 15,
  189. 15, 15, 15, 15, 15, 15, 15, 15,
  190. 15, 15, 15, 15, 15, 15, 15, 15,
  191. 15, 14, 14, 14, 13, 13, 12, 12,
  192. 12, 11, 11, 11, 10, 10, 9, 9,
  193. 9, 8, 8, 8, 7, 7, 7, 6,
  194. 6, 6, 5, 5, 5, 4, 4, 3,
  195. 3, 3, 4, 4, 5, 5, 5, 6,
  196. 6, 6, 7, 7, 7, 8, 8, 8,
  197. 9, 9, 9, 10, 10, 10, 11, 11,
  198. 12, 12, 12, 13, 13, 13, 14, 14,
  199. 15, 15, 15, 15, 15, 15, 15, 15,
  200. 15, 15, 15, 15, 15, 15, 15, 15,
  201. 15, 15, 15, 15, 15, 15, 15, 15,
  202. 15, 15, 15, 15, 15, 15, 15, 15,
  203. 15, },
  204. { 15, 15, 15, 15, 15, 15, 15, 15,
  205. 15, 15, 15, 15, 15, 15, 15, 15,
  206. 15, 15, 15, 15, 15, 15, 15, 15,
  207. 15, 15, 15, 15, 15, 15, 15, 15,
  208. 15, 15, 15, 15, 15, 15, 15, 15,
  209. 15, 15, 14, 14, 13, 13, 12, 12,
  210. 11, 11, 10, 10, 9, 8, 8, 7,
  211. 7, 6, 6, 5, 5, 4, 4, 3,
  212. 2, 3, 4, 4, 5, 5, 6, 6,
  213. 7, 7, 8, 8, 9, 9, 10, 10,
  214. 11, 12, 12, 12, 13, 14, 14, 15,
  215. 15, 15, 15, 15, 15, 15, 15, 15,
  216. 15, 15, 15, 15, 15, 15, 15, 15,
  217. 15, 15, 15, 15, 15, 15, 15, 15,
  218. 15, 15, 15, 15, 15, 15, 15, 15,
  219. 15, 15, 15, 15, 15, 15, 15, 15,
  220. 15, },
  221. { 16, 16, 16, 16, 16, 16, 16, 16,
  222. 16, 16, 16, 16, 16, 16, 16, 16,
  223. 15, 15, 15, 15, 14, 14, 14, 14,
  224. 13, 13, 13, 13, 12, 12, 12, 12,
  225. 12, 11, 11, 11, 10, 10, 10, 10,
  226. 9, 9, 9, 9, 8, 8, 8, 8,
  227. 7, 7, 7, 7, 6, 6, 6, 6,
  228. 5, 5, 5, 5, 5, 4, 4, 4,
  229. 4, 4, 4, 4, 5, 5, 5, 5,
  230. 5, 6, 6, 6, 6, 7, 7, 7,
  231. 7, 8, 8, 8, 8, 9, 9, 9,
  232. 9, 10, 10, 10, 10, 11, 11, 11,
  233. 11, 12, 12, 12, 12, 13, 13, 13,
  234. 13, 14, 14, 14, 14, 15, 15, 15,
  235. 15, 16, 16, 16, 16, 16, 16, 16,
  236. 16, 16, 16, 16, 16, 16, 16, 16,
  237. 16,
  238. }
  239. };
  240. static const uint16_t bitalloc_3_codes[3] = {
  241. 0x0003, 0x0000, 0x0002,
  242. };
  243. static const uint8_t bitalloc_3_bits[3] = {
  244. 2, 1, 2,
  245. };
  246. static const uint16_t bitalloc_5_codes_a[5] = {
  247. 0x000F, 0x0006, 0x0000, 0x0002, 0x000E,
  248. };
  249. static const uint16_t bitalloc_5_codes_b[5] = {
  250. 0x0007, 0x0001, 0x0002, 0x0000, 0x0006,
  251. };
  252. static const uint16_t bitalloc_5_codes_c[5] = {
  253. 0x0007, 0x0005, 0x0000, 0x0004, 0x0006,
  254. };
  255. static const uint8_t bitalloc_5_bits_a[5] = {
  256. 4, 3, 1, 2, 4,
  257. };
  258. static const uint8_t bitalloc_5_bits_b[5] = {
  259. 3, 2, 2, 2, 3,
  260. };
  261. static const uint8_t bitalloc_5_bits_c[5] = {
  262. 3, 3, 1, 3, 3,
  263. };
  264. static const uint16_t bitalloc_7_codes_a[7] = {
  265. 0x001E, 0x000E, 0x0005, 0x0000, 0x0006, 0x0004, 0x001F,
  266. };
  267. static const uint16_t bitalloc_7_codes_b[7] = {
  268. 0x0014, 0x000B, 0x0000, 0x0003, 0x0001, 0x0004, 0x0015,
  269. };
  270. static const uint16_t bitalloc_7_codes_c[7] = {
  271. 0x0000, 0x0002, 0x0001, 0x0003, 0x0002, 0x0003, 0x0001,
  272. };
  273. static const uint8_t bitalloc_7_bits_a[7] = {
  274. 5, 4, 3, 1, 3, 3, 5,
  275. };
  276. static const uint8_t bitalloc_7_bits_b[7] = {
  277. 5, 4, 2, 2, 2, 3, 5,
  278. };
  279. static const uint8_t bitalloc_7_bits_c[7] = {
  280. 4, 4, 2, 2, 2, 4, 4,
  281. };
  282. static const uint16_t bitalloc_9_codes_a[9] = {
  283. 0x0030, 0x0019, 0x0009, 0x0005, 0x0000, 0x0007, 0x000D, 0x0008,
  284. 0x0031,
  285. };
  286. static const uint16_t bitalloc_9_codes_b[9] = {
  287. 0x0018, 0x001A, 0x0002, 0x0007, 0x0002, 0x0000, 0x0003, 0x001B,
  288. 0x0019,
  289. };
  290. static const uint16_t bitalloc_9_codes_c[9] = {
  291. 0x001C, 0x000F, 0x0002, 0x0007, 0x0002, 0x0000, 0x0006, 0x0006,
  292. 0x001D,
  293. };
  294. static const uint8_t bitalloc_9_bits_a[9] = {
  295. 6, 5, 4, 3, 1, 3, 4, 4, 6,
  296. };
  297. static const uint8_t bitalloc_9_bits_b[9] = {
  298. 5, 5, 3, 3, 2, 2, 3, 5, 5,
  299. };
  300. static const uint8_t bitalloc_9_bits_c[9] = {
  301. 6, 5, 3, 3, 2, 2, 3, 4, 6,
  302. };
  303. static const uint16_t bitalloc_13_codes_a[13] = {
  304. 0x0070, 0x002E, 0x0039, 0x001D, 0x000C, 0x000F, 0x0000, 0x0004,
  305. 0x000D, 0x000A, 0x0016, 0x002F, 0x0071,
  306. };
  307. static const uint16_t bitalloc_13_codes_b[13] = {
  308. 0x0038, 0x0010, 0x001D, 0x0007, 0x000F, 0x0005, 0x0000, 0x0006,
  309. 0x0002, 0x0009, 0x0006, 0x0011, 0x0039,
  310. };
  311. static const uint16_t bitalloc_13_codes_c[13] = {
  312. 0x0004, 0x001A, 0x0003, 0x000E, 0x0000, 0x0003, 0x0005, 0x0004,
  313. 0x0002, 0x000F, 0x000C, 0x001B, 0x0005,
  314. };
  315. static const uint8_t bitalloc_13_bits_a[13] = {
  316. 7, 6, 6, 5, 4, 4, 1, 3, 4, 4, 5, 6, 7,
  317. };
  318. static const uint8_t bitalloc_13_bits_b[13] = {
  319. 6, 5, 5, 4, 4, 3, 2, 3, 3, 4, 4, 5, 6,
  320. };
  321. static const uint8_t bitalloc_13_bits_c[13] = {
  322. 5, 5, 4, 4, 3, 3, 3, 3, 3, 4, 4, 5, 5,
  323. };
  324. static const uint16_t bitalloc_17_codes_a[17] = {
  325. 0x0154, 0x00AB, 0x002B, 0x000B, 0x0003, 0x000A, 0x0001, 0x0006,
  326. 0x0001, 0x0007, 0x0004, 0x000B, 0x0000, 0x0004, 0x0014, 0x0054,
  327. 0x0155,
  328. };
  329. static const uint16_t bitalloc_17_codes_b[17] = {
  330. 0x007C, 0x003F, 0x0019, 0x000D, 0x001C, 0x0008, 0x000F, 0x0005,
  331. 0x0000, 0x0006, 0x0002, 0x0009, 0x001D, 0x000E, 0x001E, 0x0018,
  332. 0x007D,
  333. };
  334. static const uint16_t bitalloc_17_codes_c[17] = {
  335. 0x002C, 0x0017, 0x0005, 0x001C, 0x0003, 0x000A, 0x000F, 0x0003,
  336. 0x0006, 0x0004, 0x0000, 0x000B, 0x0004, 0x001D, 0x000A, 0x0004,
  337. 0x002D,
  338. };
  339. static const uint16_t bitalloc_17_codes_d[17] = {
  340. 0x0100, 0x0102, 0x0082, 0x0042, 0x0022, 0x0012, 0x000A, 0x0006,
  341. 0x0000, 0x0007, 0x000B, 0x0013, 0x0023, 0x0043, 0x0083, 0x0103,
  342. 0x0101,
  343. };
  344. static const uint16_t bitalloc_17_codes_e[17] = {
  345. 0x00E8, 0x00F6, 0x0075, 0x0034, 0x003B, 0x001B, 0x001F, 0x0004,
  346. 0x0000, 0x0005, 0x000C, 0x001C, 0x003C, 0x0035, 0x007A, 0x00F7,
  347. 0x00E9,
  348. };
  349. static const uint16_t bitalloc_17_codes_f[17] = {
  350. 0x0004, 0x0003, 0x001E, 0x0001, 0x0001, 0x000E, 0x0001, 0x0004,
  351. 0x0006, 0x0005, 0x0002, 0x000F, 0x0006, 0x000E, 0x001F, 0x0000,
  352. 0x0005,
  353. };
  354. static const uint16_t bitalloc_17_codes_g[17] = {
  355. 0x0060, 0x007E, 0x0031, 0x0019, 0x000D, 0x0004, 0x0000, 0x0006,
  356. 0x0002, 0x0007, 0x0001, 0x0005, 0x000E, 0x001E, 0x003E, 0x007F,
  357. 0x0061,
  358. };
  359. static const uint8_t bitalloc_17_bits_a[17] = {
  360. 12, 11, 9, 7, 5, 4, 3, 3, 2, 3, 3, 4, 4, 6, 8, 10,
  361. 12,
  362. };
  363. static const uint8_t bitalloc_17_bits_b[17] = {
  364. 8, 7, 6, 5, 5, 4, 4, 3, 2, 3, 3, 4, 5, 5, 6, 6,
  365. 8,
  366. };
  367. static const uint8_t bitalloc_17_bits_c[17] = {
  368. 7, 6, 5, 5, 4, 4, 4, 3, 3, 3, 3, 4, 4, 5, 5, 5,
  369. 7,
  370. };
  371. static const uint8_t bitalloc_17_bits_d[17] = {
  372. 9, 9, 8, 7, 6, 5, 4, 3, 1, 3, 4, 5, 6, 7, 8, 9,
  373. 9,
  374. };
  375. static const uint8_t bitalloc_17_bits_e[17] = {
  376. 8, 8, 7, 6, 6, 5, 5, 3, 1, 3, 4, 5, 6, 6, 7, 8,
  377. 8,
  378. };
  379. static const uint8_t bitalloc_17_bits_f[17] = {
  380. 8, 7, 6, 5, 4, 4, 3, 3, 3, 3, 3, 4, 4, 5, 6, 6,
  381. 8,
  382. };
  383. static const uint8_t bitalloc_17_bits_g[17] = {
  384. 8, 8, 7, 6, 5, 4, 3, 3, 2, 3, 3, 4, 5, 6, 7, 8,
  385. 8,
  386. };
  387. static const uint16_t bitalloc_25_codes_a[25] = {
  388. 0x2854, 0x142B, 0x050B, 0x0143, 0x00A2, 0x0052, 0x002E, 0x0015,
  389. 0x0004, 0x000E, 0x0000, 0x0003, 0x0006, 0x0004, 0x0001, 0x000F,
  390. 0x0005, 0x0016, 0x002F, 0x0053, 0x00A3, 0x00A0, 0x0284, 0x0A14,
  391. 0x2855,
  392. };
  393. static const uint16_t bitalloc_25_codes_b[25] = {
  394. 0x001C, 0x000F, 0x0005, 0x0000, 0x0030, 0x0036, 0x000E, 0x0019,
  395. 0x0001, 0x0008, 0x000E, 0x0001, 0x0005, 0x0002, 0x000F, 0x0009,
  396. 0x0006, 0x001A, 0x000F, 0x0037, 0x0031, 0x0001, 0x0006, 0x0004,
  397. 0x001D,
  398. };
  399. static const uint16_t bitalloc_25_codes_c[25] = {
  400. 0x004C, 0x0027, 0x006D, 0x0028, 0x0037, 0x000E, 0x0015, 0x0000,
  401. 0x0005, 0x0008, 0x000B, 0x000E, 0x0001, 0x000F, 0x000C, 0x0009,
  402. 0x0006, 0x0001, 0x001A, 0x000F, 0x0008, 0x0029, 0x0012, 0x006C,
  403. 0x004D,
  404. };
  405. static const uint16_t bitalloc_25_codes_d[25] = {
  406. 0x0780, 0x0782, 0x03C2, 0x01E2, 0x00FE, 0x0079, 0x003D, 0x001C,
  407. 0x000C, 0x0004, 0x0000, 0x0006, 0x0002, 0x0007, 0x0001, 0x0005,
  408. 0x000D, 0x001D, 0x003E, 0x007E, 0x00FF, 0x01E3, 0x03C3, 0x0783,
  409. 0x0781,
  410. };
  411. static const uint16_t bitalloc_25_codes_e[25] = {
  412. 0x003C, 0x0092, 0x0018, 0x001F, 0x004E, 0x000D, 0x0025, 0x0004,
  413. 0x0010, 0x0000, 0x000A, 0x0002, 0x0003, 0x0003, 0x000B, 0x0001,
  414. 0x0011, 0x0005, 0x0026, 0x000E, 0x004F, 0x0048, 0x0019, 0x0093,
  415. 0x003D,
  416. };
  417. static const uint16_t bitalloc_25_codes_f[25] = {
  418. 0x0324, 0x0193, 0x00CE, 0x0065, 0x0024, 0x000C, 0x0013, 0x0004,
  419. 0x0007, 0x000A, 0x000D, 0x000F, 0x0001, 0x0000, 0x000E, 0x000B,
  420. 0x0008, 0x0005, 0x0018, 0x000D, 0x0025, 0x0066, 0x00CF, 0x00C8,
  421. 0x0325,
  422. };
  423. static const uint16_t bitalloc_25_codes_g[25] = {
  424. 0x03A8, 0x03AE, 0x01D5, 0x0094, 0x0014, 0x004B, 0x000B, 0x003B,
  425. 0x0013, 0x0003, 0x000F, 0x0005, 0x0001, 0x0006, 0x0000, 0x0008,
  426. 0x001C, 0x0004, 0x0024, 0x0074, 0x0015, 0x0095, 0x01D6, 0x03AF,
  427. 0x03A9,
  428. };
  429. static const uint8_t bitalloc_25_bits_a[25] = {
  430. 14, 13, 11, 9, 8, 7, 6, 5, 4, 4, 3, 3, 3, 3, 3, 4,
  431. 4, 5, 6, 7, 8, 8, 10, 12, 14,
  432. };
  433. static const uint8_t bitalloc_25_bits_b[25] = {
  434. 9, 8, 7, 6, 6, 6, 5, 5, 4, 4, 4, 3, 3, 3, 4, 4,
  435. 4, 5, 5, 6, 6, 6, 7, 7, 9,
  436. };
  437. static const uint8_t bitalloc_25_bits_c[25] = {
  438. 8, 7, 7, 6, 6, 5, 5, 4, 4, 4, 4, 4, 3, 4, 4, 4,
  439. 4, 4, 5, 5, 5, 6, 6, 7, 8,
  440. };
  441. static const uint8_t bitalloc_25_bits_d[25] = {
  442. 12, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 3, 2, 3, 3, 4,
  443. 5, 6, 7, 8, 9, 10, 11, 12, 12,
  444. };
  445. static const uint8_t bitalloc_25_bits_e[25] = {
  446. 8, 8, 7, 7, 7, 6, 6, 5, 5, 4, 4, 3, 2, 3, 4, 4,
  447. 5, 5, 6, 6, 7, 7, 7, 8, 8,
  448. };
  449. static const uint8_t bitalloc_25_bits_f[25] = {
  450. 10, 9, 8, 7, 6, 5, 5, 4, 4, 4, 4, 4, 3, 3, 4, 4,
  451. 4, 4, 5, 5, 6, 7, 8, 8, 10,
  452. };
  453. static const uint8_t bitalloc_25_bits_g[25] = {
  454. 10, 10, 9, 8, 7, 7, 6, 6, 5, 4, 4, 3, 2, 3, 3, 4,
  455. 5, 5, 6, 7, 7, 8, 9, 10, 10,
  456. };
  457. static const uint16_t bitalloc_33_codes_a[33] = {
  458. 0x1580, 0x1582, 0x0AC2, 0x0562, 0x02B2, 0x015E, 0x00AD, 0x0054,
  459. 0x001C, 0x003C, 0x000F, 0x001F, 0x0008, 0x000B, 0x000D, 0x0000,
  460. 0x0002, 0x0001, 0x000E, 0x000C, 0x0009, 0x0006, 0x0014, 0x003D,
  461. 0x001D, 0x0055, 0x00AE, 0x015F, 0x02B3, 0x0563, 0x0AC3, 0x1583,
  462. 0x1581,
  463. };
  464. static const uint16_t bitalloc_33_codes_b[33] = {
  465. 0x030C, 0x0187, 0x006D, 0x0028, 0x0037, 0x0066, 0x0015, 0x0031,
  466. 0x0000, 0x000B, 0x0012, 0x001A, 0x0001, 0x0007, 0x000A, 0x000E,
  467. 0x0001, 0x000F, 0x000B, 0x0008, 0x0004, 0x001B, 0x0013, 0x000C,
  468. 0x0001, 0x0032, 0x001A, 0x0067, 0x0060, 0x0029, 0x00C2, 0x006C,
  469. 0x030D,
  470. };
  471. static const uint16_t bitalloc_33_codes_c[33] = {
  472. 0x00CC, 0x0067, 0x0005, 0x0070, 0x0003, 0x001A, 0x0039, 0x003F,
  473. 0x000A, 0x0012, 0x0018, 0x001D, 0x0001, 0x0003, 0x0007, 0x000A,
  474. 0x000D, 0x000B, 0x0008, 0x0004, 0x0002, 0x001E, 0x0019, 0x0013,
  475. 0x000B, 0x0000, 0x003E, 0x001B, 0x0018, 0x0071, 0x0032, 0x0004,
  476. 0x00CD,
  477. };
  478. static const uint16_t bitalloc_33_codes_d[33] = {
  479. 0x3AF8, 0x3AFA, 0x1D7E, 0x0EBC, 0x075C, 0x03AC, 0x01D4, 0x0094,
  480. 0x0014, 0x004B, 0x000B, 0x003B, 0x0013, 0x0003, 0x000F, 0x0005,
  481. 0x0001, 0x0006, 0x0000, 0x0008, 0x001C, 0x0004, 0x0024, 0x0074,
  482. 0x0015, 0x0095, 0x01D5, 0x03AD, 0x075D, 0x0EBD, 0x1D7F, 0x3AFB,
  483. 0x3AF9,
  484. };
  485. static const uint16_t bitalloc_33_codes_e[33] = {
  486. 0x01C8, 0x01E6, 0x0064, 0x00E2, 0x00E5, 0x0030, 0x0033, 0x0073,
  487. 0x007A, 0x001A, 0x003A, 0x0002, 0x001A, 0x001F, 0x0007, 0x0001,
  488. 0x0002, 0x0002, 0x000C, 0x0000, 0x001B, 0x0003, 0x003B, 0x001B,
  489. 0x007B, 0x0078, 0x0070, 0x0031, 0x00F2, 0x00E3, 0x0065, 0x01E7,
  490. 0x01C9,
  491. };
  492. static const uint16_t bitalloc_33_codes_f[33] = {
  493. 0x0724, 0x0393, 0x01CE, 0x00E5, 0x002C, 0x0008, 0x0017, 0x003E,
  494. 0x0005, 0x0014, 0x001D, 0x0000, 0x0003, 0x0006, 0x0008, 0x000B,
  495. 0x000D, 0x000C, 0x0009, 0x0007, 0x0004, 0x0001, 0x001E, 0x0015,
  496. 0x000A, 0x003F, 0x0038, 0x0009, 0x002D, 0x00E6, 0x01CF, 0x01C8,
  497. 0x0725,
  498. };
  499. static const uint16_t bitalloc_33_codes_g[33] = {
  500. 0x0284, 0x0042, 0x0140, 0x0143, 0x003E, 0x00BE, 0x0011, 0x0051,
  501. 0x0009, 0x0029, 0x0005, 0x0015, 0x0000, 0x0008, 0x000E, 0x0002,
  502. 0x0006, 0x0003, 0x000F, 0x0009, 0x0001, 0x0016, 0x0006, 0x002E,
  503. 0x000E, 0x005E, 0x001E, 0x00BF, 0x003F, 0x0020, 0x0141, 0x0043,
  504. 0x0285,
  505. };
  506. static const uint8_t bitalloc_33_bits_a[33] = {
  507. 13, 13, 12, 11, 10, 9, 8, 7, 6, 6, 5, 5, 4, 4, 4, 3,
  508. 3, 3, 4, 4, 4, 4, 5, 6, 6, 7, 8, 9, 10, 11, 12, 13,
  509. 13,
  510. };
  511. static const uint8_t bitalloc_33_bits_b[33] = {
  512. 10, 9, 8, 7, 7, 7, 6, 6, 5, 5, 5, 5, 4, 4, 4, 4,
  513. 3, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6, 7, 7, 7, 8, 8,
  514. 10,
  515. };
  516. static const uint8_t bitalloc_33_bits_c[33] = {
  517. 9, 8, 7, 7, 6, 6, 6, 6, 5, 5, 5, 5, 4, 4, 4, 4,
  518. 4, 4, 4, 4, 4, 5, 5, 5, 5, 5, 6, 6, 6, 7, 7, 7,
  519. 9,
  520. };
  521. static const uint8_t bitalloc_33_bits_d[33] = {
  522. 14, 14, 13, 12, 11, 10, 9, 8, 7, 7, 6, 6, 5, 4, 4, 3,
  523. 2, 3, 3, 4, 5, 5, 6, 7, 7, 8, 9, 10, 11, 12, 13, 14,
  524. 14,
  525. };
  526. static const uint8_t bitalloc_33_bits_e[33] = {
  527. 9, 9, 8, 8, 8, 7, 7, 7, 7, 6, 6, 5, 5, 5, 4, 3,
  528. 2, 3, 4, 4, 5, 5, 6, 6, 7, 7, 7, 7, 8, 8, 8, 9,
  529. 9,
  530. };
  531. static const uint8_t bitalloc_33_bits_f[33] = {
  532. 11, 10, 9, 8, 7, 6, 6, 6, 5, 5, 5, 4, 4, 4, 4, 4,
  533. 4, 4, 4, 4, 4, 4, 5, 5, 5, 6, 6, 6, 7, 8, 9, 9,
  534. 11,
  535. };
  536. static const uint8_t bitalloc_33_bits_g[33] = {
  537. 10, 9, 9, 9, 8, 8, 7, 7, 6, 6, 5, 5, 4, 4, 4, 3,
  538. 3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 9,
  539. 10,
  540. };
  541. static const uint16_t bitalloc_65_codes_a[65] = {
  542. 0x9E5C, 0x9E5E, 0x4F2C, 0x2794, 0x13C4, 0x1E44, 0x09E3, 0x0F23,
  543. 0x04F3, 0x0792, 0x027E, 0x03CE, 0x013D, 0x01E5, 0x009C, 0x00CC,
  544. 0x0040, 0x0058, 0x0067, 0x001E, 0x0021, 0x002D, 0x003D, 0x0007,
  545. 0x0011, 0x0014, 0x0017, 0x001A, 0x001C, 0x001F, 0x0001, 0x0004,
  546. 0x0006, 0x0005, 0x0002, 0x0000, 0x001D, 0x001B, 0x0018, 0x0015,
  547. 0x0012, 0x000E, 0x0006, 0x0032, 0x0026, 0x001F, 0x0078, 0x0059,
  548. 0x0041, 0x00CD, 0x009D, 0x01E6, 0x013E, 0x03CF, 0x027F, 0x0793,
  549. 0x0790, 0x04F0, 0x09E4, 0x1E45, 0x13C5, 0x2795, 0x4F2D, 0x9E5F,
  550. 0x9E5D,
  551. };
  552. static const uint16_t bitalloc_65_codes_b[65] = {
  553. 0x0A8C, 0x0547, 0x01B5, 0x0008, 0x00DB, 0x0152, 0x0005, 0x000B,
  554. 0x008E, 0x00AE, 0x00E4, 0x0003, 0x0037, 0x0039, 0x0055, 0x006C,
  555. 0x0073, 0x0003, 0x0015, 0x001D, 0x0028, 0x0030, 0x0037, 0x003E,
  556. 0x0006, 0x000B, 0x000F, 0x0012, 0x0016, 0x0019, 0x001D, 0x0001,
  557. 0x0004, 0x0002, 0x001E, 0x001A, 0x0017, 0x0013, 0x0010, 0x000C,
  558. 0x0007, 0x003F, 0x0038, 0x0031, 0x0029, 0x0022, 0x001A, 0x0014,
  559. 0x0000, 0x006D, 0x0056, 0x0046, 0x0038, 0x0004, 0x00E5, 0x00AF,
  560. 0x008F, 0x006C, 0x000A, 0x0153, 0x0150, 0x0009, 0x02A2, 0x01B4,
  561. 0x0A8D,
  562. };
  563. static const uint16_t bitalloc_65_codes_c[65] = {
  564. 0x045C, 0x022F, 0x03F5, 0x01BC, 0x01FB, 0x0059, 0x00D0, 0x00DF,
  565. 0x000A, 0x002D, 0x002F, 0x0052, 0x0069, 0x0078, 0x007F, 0x000A,
  566. 0x0010, 0x001C, 0x0023, 0x002A, 0x0035, 0x003A, 0x003D, 0x0000,
  567. 0x0003, 0x0006, 0x0009, 0x000C, 0x000F, 0x0012, 0x0016, 0x0018,
  568. 0x001C, 0x0019, 0x0017, 0x0013, 0x0010, 0x000D, 0x000A, 0x0007,
  569. 0x0004, 0x0001, 0x003E, 0x003B, 0x0036, 0x002B, 0x0028, 0x001D,
  570. 0x0011, 0x000B, 0x0004, 0x0079, 0x006E, 0x0053, 0x0044, 0x002E,
  571. 0x000B, 0x00FC, 0x00D1, 0x008A, 0x0058, 0x01BD, 0x0116, 0x03F4,
  572. 0x045D,
  573. };
  574. static const uint16_t bitalloc_65_codes_d[65] = {
  575. 0x70B0, 0x70B2, 0x70B4, 0x2852, 0x385B, 0x142E, 0x1C2E, 0x0A15,
  576. 0x0E14, 0x0214, 0x0704, 0x0104, 0x010B, 0x0383, 0x0083, 0x0143,
  577. 0x01C3, 0x0043, 0x00A2, 0x00E2, 0x0022, 0x0052, 0x0072, 0x0012,
  578. 0x002A, 0x003A, 0x000A, 0x0016, 0x001E, 0x0006, 0x000C, 0x0000,
  579. 0x0004, 0x0001, 0x000D, 0x0007, 0x001F, 0x0017, 0x000B, 0x003B,
  580. 0x002B, 0x0013, 0x0073, 0x0053, 0x0023, 0x00E3, 0x00A3, 0x00A0,
  581. 0x0040, 0x01C0, 0x0084, 0x0384, 0x0284, 0x0105, 0x0705, 0x0215,
  582. 0x0E15, 0x0A16, 0x1C2F, 0x142F, 0x1428, 0x2853, 0x70B5, 0x70B3,
  583. 0x70B1,
  584. };
  585. static const uint16_t bitalloc_65_codes_e[65] = {
  586. 0x032C, 0x0332, 0x0378, 0x037E, 0x008C, 0x014A, 0x0188, 0x0197,
  587. 0x019E, 0x01BD, 0x0044, 0x0047, 0x00AA, 0x00C5, 0x00CD, 0x00DC,
  588. 0x001C, 0x002C, 0x0053, 0x0063, 0x0068, 0x0008, 0x000F, 0x0017,
  589. 0x002B, 0x0035, 0x0005, 0x0009, 0x0016, 0x001C, 0x0006, 0x000F,
  590. 0x0004, 0x0000, 0x0007, 0x001D, 0x0017, 0x000A, 0x0006, 0x0036,
  591. 0x0030, 0x0028, 0x0010, 0x0009, 0x0069, 0x0064, 0x0054, 0x002D,
  592. 0x001D, 0x00DD, 0x00CE, 0x00CA, 0x00AB, 0x00A4, 0x0045, 0x01BE,
  593. 0x019F, 0x0198, 0x0189, 0x014B, 0x008D, 0x037F, 0x0379, 0x0333,
  594. 0x032D,
  595. };
  596. static const uint16_t bitalloc_65_codes_f[65] = {
  597. 0x0FE0, 0x0FE2, 0x0FE8, 0x0FEA, 0x0FEC, 0x0FEE, 0x0FF0, 0x0FF2,
  598. 0x0FF4, 0x2FF2, 0x07F2, 0x07FB, 0x03F6, 0x0BFA, 0x0BFD, 0x01FF,
  599. 0x05FF, 0x02FC, 0x007C, 0x017C, 0x003C, 0x00BC, 0x001C, 0x005C,
  600. 0x000C, 0x002C, 0x0004, 0x0014, 0x0000, 0x0008, 0x000E, 0x0002,
  601. 0x0006, 0x0003, 0x000F, 0x0009, 0x0001, 0x0015, 0x0005, 0x002D,
  602. 0x000D, 0x005D, 0x001D, 0x00BD, 0x003D, 0x017D, 0x007D, 0x02FD,
  603. 0x00FC, 0x05FC, 0x01FA, 0x0BFB, 0x03F7, 0x17F8, 0x07F3, 0x2FF3,
  604. 0x0FF5, 0x0FF3, 0x0FF1, 0x0FEF, 0x0FED, 0x0FEB, 0x0FE9, 0x0FE3,
  605. 0x0FE1,
  606. };
  607. static const uint16_t bitalloc_65_codes_g[65] = {
  608. 0x010C, 0x038A, 0x0608, 0x0786, 0x0084, 0x0087, 0x0302, 0x0305,
  609. 0x0040, 0x00E0, 0x00E3, 0x0183, 0x001E, 0x005E, 0x009E, 0x00DE,
  610. 0x00F1, 0x0011, 0x0039, 0x0061, 0x0079, 0x0009, 0x001D, 0x0031,
  611. 0x003D, 0x0005, 0x000F, 0x0019, 0x001F, 0x0003, 0x0006, 0x000A,
  612. 0x000E, 0x000B, 0x0008, 0x0004, 0x0000, 0x001A, 0x0012, 0x000A,
  613. 0x0002, 0x0036, 0x0026, 0x0016, 0x0006, 0x006E, 0x004E, 0x002E,
  614. 0x000E, 0x00DF, 0x009F, 0x005F, 0x001F, 0x01E0, 0x0180, 0x00E1,
  615. 0x0041, 0x03C2, 0x0303, 0x01C4, 0x0085, 0x0787, 0x0609, 0x038B,
  616. 0x010D,
  617. };
  618. static const uint8_t bitalloc_65_bits_a[65] = {
  619. 16, 16, 15, 14, 13, 13, 12, 12, 11, 11, 10, 10, 9, 9, 8, 8,
  620. 7, 7, 7, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 4, 4,
  621. 4, 4, 4, 4, 5, 5, 5, 5, 5, 5, 5, 6, 6, 6, 7, 7,
  622. 7, 8, 8, 9, 9, 10, 10, 11, 11, 11, 12, 13, 13, 14, 15, 16,
  623. 16,
  624. };
  625. static const uint8_t bitalloc_65_bits_b[65] = {
  626. 12, 11, 10, 9, 9, 9, 8, 8, 8, 8, 8, 7, 7, 7, 7, 7,
  627. 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 4,
  628. 4, 4, 5, 5, 5, 5, 5, 5, 5, 6, 6, 6, 6, 6, 6, 6,
  629. 6, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 9, 9, 9, 10, 10,
  630. 12,
  631. };
  632. static const uint8_t bitalloc_65_bits_c[65] = {
  633. 11, 10, 10, 9, 9, 8, 8, 8, 7, 7, 7, 7, 7, 7, 7, 6,
  634. 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5,
  635. 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 6, 6, 6, 6, 6, 6,
  636. 6, 6, 6, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 9, 9, 10,
  637. 11,
  638. };
  639. static const uint8_t bitalloc_65_bits_d[65] = {
  640. 15, 15, 15, 14, 14, 13, 13, 12, 12, 11, 11, 10, 10, 10, 9, 9,
  641. 9, 8, 8, 8, 7, 7, 7, 6, 6, 6, 5, 5, 5, 4, 4, 3,
  642. 3, 3, 4, 4, 5, 5, 5, 6, 6, 6, 7, 7, 7, 8, 8, 8,
  643. 8, 9, 9, 10, 10, 10, 11, 11, 12, 12, 13, 13, 13, 14, 15, 15,
  644. 15,
  645. };
  646. static const uint8_t bitalloc_65_bits_e[65] = {
  647. 10, 10, 10, 10, 9, 9, 9, 9, 9, 9, 8, 8, 8, 8, 8, 8,
  648. 7, 7, 7, 7, 7, 6, 6, 6, 6, 6, 5, 5, 5, 5, 4, 4,
  649. 3, 3, 4, 5, 5, 5, 5, 6, 6, 6, 6, 6, 7, 7, 7, 7,
  650. 7, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 10, 10, 10,
  651. 10,
  652. };
  653. static const uint8_t bitalloc_65_bits_f[65] = {
  654. 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 13, 13, 12, 12, 12, 11,
  655. 11, 10, 9, 9, 8, 8, 7, 7, 6, 6, 5, 5, 4, 4, 4, 3,
  656. 3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10,
  657. 10, 11, 11, 12, 12, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14,
  658. 14,
  659. };
  660. static const uint8_t bitalloc_65_bits_g[65] = {
  661. 11, 11, 11, 11, 10, 10, 10, 10, 9, 9, 9, 9, 8, 8, 8, 8,
  662. 8, 7, 7, 7, 7, 6, 6, 6, 6, 5, 5, 5, 5, 4, 4, 4,
  663. 4, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7,
  664. 7, 8, 8, 8, 8, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11,
  665. 11,
  666. };
  667. static const uint16_t bitalloc_129_codes_a[129] = {
  668. 0x0660, 0x0666, 0x06EC, 0x0722, 0x0760, 0x076E, 0x004C, 0x004E,
  669. 0x00F4, 0x010A, 0x0148, 0x0156, 0x01D4, 0x01F2, 0x0331, 0x0370,
  670. 0x0377, 0x0396, 0x03B1, 0x0024, 0x0064, 0x007B, 0x008A, 0x00A5,
  671. 0x00D4, 0x00EB, 0x00FA, 0x019A, 0x01B9, 0x01C9, 0x01D9, 0x0010,
  672. 0x0030, 0x0033, 0x0043, 0x0053, 0x006B, 0x007A, 0x00CA, 0x00D2,
  673. 0x00DE, 0x00E6, 0x00F6, 0x000E, 0x001F, 0x0023, 0x002B, 0x003B,
  674. 0x003F, 0x0067, 0x0070, 0x0077, 0x0005, 0x000D, 0x0012, 0x001B,
  675. 0x002C, 0x0035, 0x003A, 0x0004, 0x000B, 0x0017, 0x001F, 0x0009,
  676. 0x0008, 0x000A, 0x0000, 0x0018, 0x000C, 0x0005, 0x003C, 0x0036,
  677. 0x002D, 0x001C, 0x0013, 0x000E, 0x0006, 0x007A, 0x0071, 0x0068,
  678. 0x0064, 0x003C, 0x0034, 0x0028, 0x0020, 0x000F, 0x00F7, 0x00E7,
  679. 0x00DF, 0x00D3, 0x00CB, 0x007B, 0x0074, 0x0054, 0x0044, 0x003C,
  680. 0x0031, 0x0011, 0x01DA, 0x01CA, 0x01BA, 0x019B, 0x00FB, 0x00F8,
  681. 0x00D5, 0x00AA, 0x008B, 0x0084, 0x0065, 0x0025, 0x03B6, 0x0397,
  682. 0x0390, 0x0371, 0x0332, 0x01F3, 0x01D5, 0x0157, 0x0149, 0x010B,
  683. 0x00F5, 0x004F, 0x004D, 0x076F, 0x0761, 0x0723, 0x06ED, 0x0667,
  684. 0x0661,
  685. };
  686. static const uint16_t bitalloc_129_codes_b[129] = {
  687. 0x29DC, 0x14EF, 0x0455, 0x0E9C, 0x022B, 0x0489, 0x0740, 0x074F,
  688. 0x0172, 0x0245, 0x0247, 0x030A, 0x03A1, 0x001C, 0x008B, 0x00D6,
  689. 0x010C, 0x0148, 0x014F, 0x0186, 0x01D1, 0x0008, 0x000F, 0x0046,
  690. 0x005D, 0x0078, 0x0087, 0x0096, 0x00A5, 0x00BC, 0x00D8, 0x00DE,
  691. 0x00F6, 0x0005, 0x0014, 0x0024, 0x002F, 0x003A, 0x003D, 0x0049,
  692. 0x0050, 0x0058, 0x005F, 0x0066, 0x006D, 0x0075, 0x007C, 0x0004,
  693. 0x000B, 0x0013, 0x0018, 0x001B, 0x001F, 0x0022, 0x0026, 0x002A,
  694. 0x002D, 0x0031, 0x0034, 0x0038, 0x003B, 0x003F, 0x0003, 0x0006,
  695. 0x000A, 0x0007, 0x0004, 0x0000, 0x003C, 0x0039, 0x0035, 0x0032,
  696. 0x002E, 0x002B, 0x0027, 0x0023, 0x0020, 0x001C, 0x0019, 0x0016,
  697. 0x0010, 0x0005, 0x007D, 0x007A, 0x006E, 0x0067, 0x0060, 0x0059,
  698. 0x0051, 0x004A, 0x0042, 0x003B, 0x0034, 0x0025, 0x0015, 0x0006,
  699. 0x00F7, 0x00DF, 0x00D9, 0x00BD, 0x00A6, 0x0097, 0x0090, 0x0079,
  700. 0x006A, 0x0047, 0x0044, 0x0009, 0x01D2, 0x0187, 0x0184, 0x0149,
  701. 0x010D, 0x00D7, 0x00B8, 0x001D, 0x03A6, 0x030B, 0x029C, 0x0246,
  702. 0x0173, 0x0114, 0x0741, 0x053A, 0x0488, 0x0E9D, 0x0A76, 0x0454,
  703. 0x29DD,
  704. };
  705. static const uint16_t bitalloc_129_codes_c[129] = {
  706. 0x0E5C, 0x072F, 0x001D, 0x0724, 0x000F, 0x010D, 0x0324, 0x0393,
  707. 0x03E9, 0x0080, 0x0087, 0x00FA, 0x0164, 0x0193, 0x01DE, 0x01F5,
  708. 0x0010, 0x002A, 0x0041, 0x0064, 0x0073, 0x008E, 0x00A4, 0x00B3,
  709. 0x00D6, 0x00E5, 0x00F4, 0x00FB, 0x0002, 0x0009, 0x0013, 0x001E,
  710. 0x0026, 0x002C, 0x0033, 0x003F, 0x0041, 0x004C, 0x0053, 0x005E,
  711. 0x0065, 0x0070, 0x0073, 0x0078, 0x007B, 0x007E, 0x0002, 0x0005,
  712. 0x0007, 0x000B, 0x000D, 0x0011, 0x0014, 0x0017, 0x001A, 0x001D,
  713. 0x0021, 0x0024, 0x0027, 0x002A, 0x002D, 0x0030, 0x0033, 0x0036,
  714. 0x003A, 0x0037, 0x0034, 0x0031, 0x002E, 0x002B, 0x0028, 0x0025,
  715. 0x0022, 0x001E, 0x001B, 0x0018, 0x0015, 0x0012, 0x000E, 0x000C,
  716. 0x0008, 0x0006, 0x0003, 0x007F, 0x007C, 0x0079, 0x0076, 0x0071,
  717. 0x006A, 0x005F, 0x0058, 0x004D, 0x0046, 0x0040, 0x0038, 0x002D,
  718. 0x0027, 0x001F, 0x0014, 0x0012, 0x0003, 0x0000, 0x00F5, 0x00EE,
  719. 0x00D7, 0x00C8, 0x00A5, 0x008F, 0x007C, 0x0065, 0x0042, 0x002B,
  720. 0x0011, 0x0002, 0x01DF, 0x01C8, 0x0165, 0x00FB, 0x00E4, 0x0081,
  721. 0x0006, 0x03E8, 0x0325, 0x01CA, 0x010C, 0x0725, 0x0396, 0x001C,
  722. 0x0E5D,
  723. };
  724. static const uint16_t bitalloc_129_codes_d[129] = {
  725. 0xA598, 0xA59A, 0xA59C, 0xA59E, 0xC598, 0xE586, 0x3ACC, 0x52CA,
  726. 0x62CD, 0x0D48, 0x1D67, 0x2978, 0x3167, 0x3966, 0x06A5, 0x0EBC,
  727. 0x14BD, 0x1CB1, 0x0350, 0x0353, 0x075F, 0x0A5F, 0x0C5E, 0x0E5E,
  728. 0x01AE, 0x03AD, 0x052D, 0x062D, 0x072D, 0x00D5, 0x01D4, 0x0294,
  729. 0x0314, 0x0394, 0x0014, 0x0094, 0x0114, 0x0174, 0x01B4, 0x01F4,
  730. 0x000B, 0x004B, 0x008B, 0x00BB, 0x00DB, 0x00FB, 0x001B, 0x003B,
  731. 0x0053, 0x0063, 0x0073, 0x0003, 0x0013, 0x0023, 0x002F, 0x0037,
  732. 0x003F, 0x0007, 0x000F, 0x0015, 0x0019, 0x001D, 0x0001, 0x0005,
  733. 0x0009, 0x0006, 0x0002, 0x001E, 0x001A, 0x0016, 0x0010, 0x0008,
  734. 0x0000, 0x0038, 0x0030, 0x0028, 0x001C, 0x000C, 0x007C, 0x006C,
  735. 0x005C, 0x0044, 0x0024, 0x0004, 0x00E4, 0x00C4, 0x00A4, 0x0074,
  736. 0x0034, 0x01F5, 0x01B5, 0x0175, 0x0115, 0x0095, 0x0015, 0x0395,
  737. 0x0315, 0x0295, 0x01D5, 0x00D6, 0x072E, 0x062E, 0x052E, 0x03AE,
  738. 0x01AF, 0x0E5F, 0x0C5F, 0x0C58, 0x0A58, 0x0758, 0x0351, 0x1CB2,
  739. 0x18B2, 0x0EBD, 0x0EB2, 0x3967, 0x3960, 0x2979, 0x2964, 0x0D49,
  740. 0x72C2, 0x52CB, 0x3ACD, 0xE587, 0xC599, 0xA59F, 0xA59D, 0xA59B,
  741. 0xA599,
  742. };
  743. static const uint16_t bitalloc_129_codes_e[129] = {
  744. 0xA13C, 0xC720, 0xA13F, 0xA13E, 0xA13D, 0xE722, 0x5090, 0x6393,
  745. 0x7392, 0x2849, 0x31CE, 0x39CE, 0x1425, 0x18E5, 0x1CE5, 0x0844,
  746. 0x0A1C, 0x0C7C, 0x036C, 0x0423, 0x050F, 0x063F, 0x01B7, 0x0216,
  747. 0x0285, 0x031D, 0x039D, 0x0109, 0x0140, 0x0180, 0x01C8, 0x01CF,
  748. 0x007A, 0x008A, 0x00A2, 0x00C1, 0x00E5, 0x0014, 0x0037, 0x0043,
  749. 0x004E, 0x0056, 0x0061, 0x006C, 0x007C, 0x000B, 0x001C, 0x001F,
  750. 0x0023, 0x0025, 0x0029, 0x002C, 0x002E, 0x0032, 0x0034, 0x0037,
  751. 0x003A, 0x003C, 0x003F, 0x0001, 0x0003, 0x0006, 0x0008, 0x000A,
  752. 0x000C, 0x000B, 0x0009, 0x0007, 0x0004, 0x0002, 0x0000, 0x003D,
  753. 0x003B, 0x0038, 0x0035, 0x0033, 0x002F, 0x002D, 0x002A, 0x0026,
  754. 0x0024, 0x0020, 0x001D, 0x001A, 0x007D, 0x006D, 0x0062, 0x0057,
  755. 0x004F, 0x0044, 0x003C, 0x0015, 0x00E6, 0x00C6, 0x00A3, 0x008B,
  756. 0x007B, 0x006C, 0x01C9, 0x0181, 0x0141, 0x010A, 0x00DA, 0x031E,
  757. 0x0286, 0x0217, 0x0210, 0x0738, 0x0638, 0x0508, 0x036D, 0x0C7D,
  758. 0x0A1D, 0x0845, 0x1CE6, 0x18E6, 0x1426, 0x39CF, 0x31CF, 0x284E,
  759. 0x7393, 0x7390, 0x5091, 0xE723, 0xC724, 0xC725, 0xC722, 0xC723,
  760. 0xC721,
  761. };
  762. static const uint16_t bitalloc_129_codes_f[129] = {
  763. 0x762C, 0x3B17, 0x1555, 0x0608, 0x0AAB, 0x0FF2, 0x0305, 0x0307,
  764. 0x0763, 0x0046, 0x010C, 0x01BC, 0x02AB, 0x03B6, 0x03FD, 0x0080,
  765. 0x0087, 0x00DF, 0x0156, 0x01D9, 0x01F8, 0x01FF, 0x002A, 0x0041,
  766. 0x0061, 0x0094, 0x00D4, 0x00EA, 0x00F2, 0x00FD, 0x0009, 0x000B,
  767. 0x001A, 0x0026, 0x0031, 0x0040, 0x004B, 0x006B, 0x0073, 0x0077,
  768. 0x007A, 0x007C, 0x0000, 0x0002, 0x0006, 0x0008, 0x000B, 0x000E,
  769. 0x0011, 0x0014, 0x0016, 0x0019, 0x001C, 0x001E, 0x0021, 0x0023,
  770. 0x0026, 0x0028, 0x002B, 0x002D, 0x002F, 0x0031, 0x0033, 0x0036,
  771. 0x0038, 0x0037, 0x0034, 0x0032, 0x0030, 0x002E, 0x002C, 0x0029,
  772. 0x0027, 0x0024, 0x0022, 0x001F, 0x001D, 0x001A, 0x0017, 0x0015,
  773. 0x0012, 0x000F, 0x000C, 0x0009, 0x0007, 0x0003, 0x0001, 0x007D,
  774. 0x007B, 0x0078, 0x0074, 0x0072, 0x0054, 0x0041, 0x0036, 0x0027,
  775. 0x001B, 0x0014, 0x000A, 0x00FE, 0x00F3, 0x00EB, 0x00D5, 0x0095,
  776. 0x006E, 0x0042, 0x002B, 0x0010, 0x01F9, 0x01DA, 0x0157, 0x0154,
  777. 0x00C0, 0x0081, 0x0022, 0x03B7, 0x03B0, 0x01BD, 0x010D, 0x0047,
  778. 0x07F8, 0x0554, 0x0306, 0x0FF3, 0x0EC4, 0x0609, 0x1D8A, 0x1554,
  779. 0x762D,
  780. };
  781. static const uint16_t bitalloc_129_codes_g[129] = {
  782. 0x1E20, 0x1E5E, 0x031C, 0x051A, 0x0718, 0x0916, 0x0B14, 0x0D12,
  783. 0x0F11, 0x0090, 0x018F, 0x028E, 0x038D, 0x048C, 0x058B, 0x068A,
  784. 0x0789, 0x0049, 0x00C8, 0x0148, 0x01C7, 0x0247, 0x02C6, 0x0346,
  785. 0x03C5, 0x0025, 0x0065, 0x00A5, 0x00E4, 0x0124, 0x0164, 0x01A4,
  786. 0x01E3, 0x0013, 0x0033, 0x0053, 0x0073, 0x0093, 0x00B3, 0x00D3,
  787. 0x00F3, 0x000A, 0x001A, 0x002A, 0x003A, 0x004A, 0x005A, 0x006A,
  788. 0x007A, 0x0006, 0x000E, 0x0016, 0x001E, 0x0026, 0x002E, 0x0036,
  789. 0x003E, 0x0004, 0x0008, 0x000C, 0x0010, 0x0014, 0x0018, 0x001C,
  790. 0x0000, 0x001D, 0x0019, 0x0015, 0x0011, 0x000D, 0x0009, 0x0005,
  791. 0x003F, 0x0037, 0x002F, 0x0027, 0x001F, 0x0017, 0x000F, 0x0007,
  792. 0x007B, 0x006B, 0x005B, 0x004B, 0x003B, 0x002B, 0x001B, 0x000B,
  793. 0x0008, 0x00F0, 0x00D0, 0x00B0, 0x0090, 0x0070, 0x0050, 0x0030,
  794. 0x01E4, 0x01A5, 0x0165, 0x0125, 0x00E5, 0x00E2, 0x00A2, 0x0062,
  795. 0x03CA, 0x0347, 0x02C7, 0x02C4, 0x0244, 0x0149, 0x00C9, 0x00C6,
  796. 0x0796, 0x068B, 0x0688, 0x048D, 0x048A, 0x028F, 0x028C, 0x0091,
  797. 0x0F2E, 0x0D13, 0x0B15, 0x0917, 0x0719, 0x051B, 0x031D, 0x1E5F,
  798. 0x1E21,
  799. };
  800. static const uint8_t bitalloc_129_bits_a[129] = {
  801. 11, 11, 11, 11, 11, 11, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
  802. 10, 10, 10, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 8,
  803. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 7, 7, 7, 7, 7,
  804. 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 4,
  805. 4, 4, 4, 5, 5, 5, 6, 6, 6, 6, 6, 6, 6, 7, 7, 7,
  806. 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  807. 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10,
  808. 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11,
  809. 11,
  810. };
  811. static const uint8_t bitalloc_129_bits_b[129] = {
  812. 14, 13, 12, 12, 11, 11, 11, 11, 10, 10, 10, 10, 10, 9, 9, 9,
  813. 9, 9, 9, 9, 9, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  814. 8, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 6,
  815. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 5, 5,
  816. 5, 5, 5, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  817. 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  818. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9,
  819. 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 11, 11, 11, 12, 12, 12,
  820. 14,
  821. };
  822. static const uint8_t bitalloc_129_bits_c[129] = {
  823. 13, 12, 11, 11, 10, 10, 10, 10, 10, 9, 9, 9, 9, 9, 9, 9,
  824. 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 7, 7, 7, 7,
  825. 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 6, 6,
  826. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  827. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  828. 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  829. 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,
  830. 8, 8, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11,
  831. 13,
  832. };
  833. static const uint8_t bitalloc_129_bits_d[129] = {
  834. 16, 16, 16, 16, 16, 16, 15, 15, 15, 14, 14, 14, 14, 14, 13, 13,
  835. 13, 13, 12, 12, 12, 12, 12, 12, 11, 11, 11, 11, 11, 10, 10, 10,
  836. 10, 10, 9, 9, 9, 9, 9, 9, 8, 8, 8, 8, 8, 8, 7, 7,
  837. 7, 7, 7, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 4, 4,
  838. 4, 4, 4, 5, 5, 5, 5, 5, 5, 6, 6, 6, 6, 6, 7, 7,
  839. 7, 7, 7, 7, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 10,
  840. 10, 10, 10, 10, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 13,
  841. 13, 13, 13, 14, 14, 14, 14, 14, 15, 15, 15, 16, 16, 16, 16, 16,
  842. 16,
  843. };
  844. static const uint8_t bitalloc_129_bits_e[129] = {
  845. 16, 16, 16, 16, 16, 16, 15, 15, 15, 14, 14, 14, 13, 13, 13, 12,
  846. 12, 12, 11, 11, 11, 11, 10, 10, 10, 10, 10, 9, 9, 9, 9, 9,
  847. 8, 8, 8, 8, 8, 7, 7, 7, 7, 7, 7, 7, 7, 6, 6, 6,
  848. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5,
  849. 5, 5, 5, 5, 5, 5, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  850. 6, 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8,
  851. 8, 8, 9, 9, 9, 9, 9, 10, 10, 10, 10, 11, 11, 11, 11, 12,
  852. 12, 12, 13, 13, 13, 14, 14, 14, 15, 15, 15, 16, 16, 16, 16, 16,
  853. 16,
  854. };
  855. static const uint8_t bitalloc_129_bits_f[129] = {
  856. 15, 14, 13, 12, 12, 12, 11, 11, 11, 10, 10, 10, 10, 10, 10, 9,
  857. 9, 9, 9, 9, 9, 9, 8, 8, 8, 8, 8, 8, 8, 8, 7, 7,
  858. 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6,
  859. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  860. 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,
  861. 6, 6, 6, 6, 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7,
  862. 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9,
  863. 9, 9, 9, 10, 10, 10, 10, 10, 11, 11, 11, 12, 12, 12, 13, 13,
  864. 15,
  865. };
  866. static const uint8_t bitalloc_129_bits_g[129] = {
  867. 13, 13, 12, 12, 12, 12, 12, 12, 12, 11, 11, 11, 11, 11, 11, 11,
  868. 11, 10, 10, 10, 10, 10, 10, 10, 10, 9, 9, 9, 9, 9, 9, 9,
  869. 9, 8, 8, 8, 8, 8, 8, 8, 8, 7, 7, 7, 7, 7, 7, 7,
  870. 7, 6, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5,
  871. 4, 5, 5, 5, 5, 5, 5, 5, 6, 6, 6, 6, 6, 6, 6, 6,
  872. 7, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8,
  873. 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10,
  874. 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 13,
  875. 13,
  876. };
  877. static const uint8_t bitalloc_sizes[DCA_CODE_BOOKS] = {
  878. 3, 5, 7, 9, 13, 17, 25, 33, 65, 129
  879. };
  880. static const int8_t bitalloc_offsets[DCA_CODE_BOOKS] = {
  881. -1, -2, -3, -4, -6, -8, -12, -16, -32, -64
  882. };
  883. static const uint8_t bitalloc_maxbits[DCA_CODE_BOOKS][7] = {
  884. { 2 },
  885. { 4, 3, 3 },
  886. { 5, 5, 4 },
  887. { 6, 5, 6 },
  888. { 7, 6, 5 },
  889. { 9, 8, 7, 9, 8, 8, 8 },
  890. { 9, 9, 8, 9, 8, 9, 9 },
  891. { 9, 9, 9, 9, 9, 9, 9 },
  892. { 9, 9, 9, 9, 9, 9, 9 },
  893. { 9, 9, 9, 9, 9, 9, 9 }
  894. };
  895. static const uint16_t *const bitalloc_codes[DCA_CODE_BOOKS][8] = {
  896. { bitalloc_3_codes, NULL },
  897. { bitalloc_5_codes_a, bitalloc_5_codes_b, bitalloc_5_codes_c, NULL },
  898. { bitalloc_7_codes_a, bitalloc_7_codes_b, bitalloc_7_codes_c, NULL },
  899. { bitalloc_9_codes_a, bitalloc_9_codes_b, bitalloc_9_codes_c, NULL },
  900. { bitalloc_13_codes_a, bitalloc_13_codes_b, bitalloc_13_codes_c, NULL },
  901. { bitalloc_17_codes_a, bitalloc_17_codes_b, bitalloc_17_codes_c, bitalloc_17_codes_d,
  902. bitalloc_17_codes_e, bitalloc_17_codes_f, bitalloc_17_codes_g, NULL },
  903. { bitalloc_25_codes_a, bitalloc_25_codes_b, bitalloc_25_codes_c, bitalloc_25_codes_d,
  904. bitalloc_25_codes_e, bitalloc_25_codes_f, bitalloc_25_codes_g, NULL },
  905. { bitalloc_33_codes_a, bitalloc_33_codes_b, bitalloc_33_codes_c, bitalloc_33_codes_d,
  906. bitalloc_33_codes_e, bitalloc_33_codes_f, bitalloc_33_codes_g, NULL },
  907. { bitalloc_65_codes_a, bitalloc_65_codes_b, bitalloc_65_codes_c, bitalloc_65_codes_d,
  908. bitalloc_65_codes_e, bitalloc_65_codes_f, bitalloc_65_codes_g, NULL },
  909. { bitalloc_129_codes_a, bitalloc_129_codes_b, bitalloc_129_codes_c, bitalloc_129_codes_d,
  910. bitalloc_129_codes_e, bitalloc_129_codes_f, bitalloc_129_codes_g, NULL }
  911. };
  912. static const uint8_t *const bitalloc_bits[DCA_CODE_BOOKS][8] = {
  913. { bitalloc_3_bits, NULL },
  914. { bitalloc_5_bits_a, bitalloc_5_bits_b, bitalloc_5_bits_c, NULL },
  915. { bitalloc_7_bits_a, bitalloc_7_bits_b, bitalloc_7_bits_c, NULL },
  916. { bitalloc_9_bits_a, bitalloc_9_bits_b, bitalloc_9_bits_c, NULL },
  917. { bitalloc_13_bits_a, bitalloc_13_bits_b, bitalloc_13_bits_c, NULL },
  918. { bitalloc_17_bits_a, bitalloc_17_bits_b, bitalloc_17_bits_c, bitalloc_17_bits_d,
  919. bitalloc_17_bits_e, bitalloc_17_bits_f, bitalloc_17_bits_g, NULL },
  920. { bitalloc_25_bits_a, bitalloc_25_bits_b, bitalloc_25_bits_c, bitalloc_25_bits_d,
  921. bitalloc_25_bits_e, bitalloc_25_bits_f, bitalloc_25_bits_g, NULL },
  922. { bitalloc_33_bits_a, bitalloc_33_bits_b, bitalloc_33_bits_c, bitalloc_33_bits_d,
  923. bitalloc_33_bits_e, bitalloc_33_bits_f, bitalloc_33_bits_g, NULL },
  924. { bitalloc_65_bits_a, bitalloc_65_bits_b, bitalloc_65_bits_c, bitalloc_65_bits_d,
  925. bitalloc_65_bits_e, bitalloc_65_bits_f, bitalloc_65_bits_g, NULL },
  926. { bitalloc_129_bits_a, bitalloc_129_bits_b, bitalloc_129_bits_c, bitalloc_129_bits_d,
  927. bitalloc_129_bits_e, bitalloc_129_bits_f, bitalloc_129_bits_g, NULL }
  928. };
  929. static const uint16_t tnl_grp_0_codes[37] = {
  930. 0x0000, 0x0003, 0x0004, 0x0007, 0x0001, 0x0009, 0x000a, 0x000d,
  931. 0x000e, 0x0006, 0x0012, 0x0005, 0x0015, 0x0016, 0x0022, 0x0025,
  932. 0x0035, 0x0076, 0x0002, 0x0042, 0x00b6, 0x0036, 0x00c2, 0x0136,
  933. 0x0182, 0x01c2, 0x03c2, 0x0482, 0x0682, 0x0082, 0x0882, 0x0a82,
  934. 0x0282, 0x2282, 0x3282, 0x1282, 0x5282,
  935. };
  936. static const uint16_t tnl_grp_1_codes[34] = {
  937. 0x0001, 0x0003, 0x0006, 0x0000, 0x0002, 0x0004, 0x0005, 0x0007,
  938. 0x0008, 0x000f, 0x001a, 0x001c, 0x001d, 0x000a, 0x002c, 0x002d,
  939. 0x000d, 0x002a, 0x004c, 0x004d, 0x006a, 0x008c, 0x00cd, 0x00ea,
  940. 0x000c, 0x010c, 0x01ea, 0x020c, 0x030c, 0x07ea, 0x0bea, 0x03ea,
  941. 0x13ea, 0x33ea,
  942. };
  943. static const uint16_t tnl_grp_2_codes[31] = {
  944. 0x0001, 0x0003, 0x0006, 0x0007, 0x0004, 0x0008, 0x000c, 0x0010,
  945. 0x0012, 0x001a, 0x0022, 0x0000, 0x000a, 0x0020, 0x0040, 0x004a,
  946. 0x006a, 0x0002, 0x002a, 0x0042, 0x0082, 0x00aa, 0x00e0, 0x0060,
  947. 0x00c2, 0x01c2, 0x0160, 0x0360, 0x0f60, 0x0760, 0x1760,
  948. };
  949. static const uint16_t tnl_grp_3_codes[28] = {
  950. 0x0001, 0x0006, 0x0008, 0x0014, 0x001c, 0x0000, 0x0002, 0x0004,
  951. 0x000a, 0x000c, 0x0010, 0x0012, 0x001a, 0x0020, 0x002a, 0x002c,
  952. 0x0032, 0x003a, 0x0022, 0x0030, 0x0062, 0x0064, 0x0070, 0x0024,
  953. 0x00a4, 0x01a4, 0x03a4, 0x07a4,
  954. };
  955. static const uint16_t tnl_grp_4_codes[23] = {
  956. 0x0001, 0x0000, 0x000a, 0x0006, 0x0012, 0x001e, 0x0022, 0x002e,
  957. 0x0036, 0x003e, 0x0002, 0x0016, 0x0032, 0x004e, 0x0056, 0x000e,
  958. 0x0042, 0x0072, 0x00c2, 0x00f2, 0x008e, 0x018e, 0x038e,
  959. };
  960. static const uint16_t tnl_scf_codes[20] = {
  961. 0x0000, 0x0001, 0x0002, 0x0005, 0x0006, 0x0007, 0x000b, 0x000c,
  962. 0x0013, 0x0014, 0x0003, 0x0004, 0x0023, 0x0064, 0x00a4, 0x0024,
  963. 0x0124, 0x0324, 0x0724, 0x0f24,
  964. };
  965. static const uint16_t damp_codes[7] = {
  966. 0x0001, 0x0000, 0x0002, 0x0006, 0x000e, 0x001e, 0x003e,
  967. };
  968. static const uint16_t dph_codes[9] = {
  969. 0x0000, 0x0002, 0x0003, 0x0001, 0x0009, 0x000d, 0x0005, 0x0015,
  970. 0x0035,
  971. };
  972. static const uint16_t fst_rsd_amp_codes[24] = {
  973. 0x0003, 0x0005, 0x0006, 0x0007, 0x0000, 0x0001, 0x0002, 0x0008,
  974. 0x0009, 0x000a, 0x0014, 0x0004, 0x001a, 0x001c, 0x0024, 0x002c,
  975. 0x003a, 0x000c, 0x003c, 0x004c, 0x00fc, 0x007c, 0x017c, 0x037c,
  976. };
  977. static const uint16_t rsd_apprx_codes[6] = {
  978. 0x0000, 0x0001, 0x0003, 0x0007, 0x000f, 0x001f,
  979. };
  980. static const uint16_t rsd_amp_codes[33] = {
  981. 0x0001, 0x0000, 0x0002, 0x0003, 0x0004, 0x000e, 0x000f, 0x0016,
  982. 0x0007, 0x0027, 0x0037, 0x0026, 0x0066, 0x0006, 0x0017, 0x0046,
  983. 0x0097, 0x00d7, 0x0086, 0x00c6, 0x01c6, 0x0157, 0x0186, 0x0257,
  984. 0x0357, 0x0057, 0x0786, 0x0386, 0x0b86, 0x0457, 0x0c57, 0x1457,
  985. 0x1c57,
  986. };
  987. static const uint16_t avg_g3_codes[18] = {
  988. 0x0001, 0x0002, 0x0003, 0x0000, 0x000c, 0x0014, 0x0018, 0x0004,
  989. 0x0008, 0x0028, 0x0068, 0x0024, 0x00a4, 0x00e4, 0x0164, 0x0064,
  990. 0x0264, 0x0664,
  991. };
  992. static const uint16_t st_grid_codes[22] = {
  993. 0x0001, 0x0002, 0x0000, 0x0004, 0x0008, 0x001c, 0x004c, 0x006c,
  994. 0x000c, 0x002c, 0x008c, 0x00ac, 0x012c, 0x018c, 0x01ac, 0x038c,
  995. 0x03ac, 0x032c, 0x072c, 0x0f2c, 0x172c, 0x1f2c,
  996. };
  997. static const uint16_t grid_2_codes[20] = {
  998. 0x0000, 0x0002, 0x0003, 0x0001, 0x0005, 0x000d, 0x003d, 0x005d,
  999. 0x009d, 0x011d, 0x001d, 0x061d, 0x041d, 0x0c1d, 0x0a1d, 0x121d,
  1000. 0x021d, 0x1a1d, 0x221d, 0x3a1d,
  1001. };
  1002. static const uint16_t grid_3_codes[13] = {
  1003. 0x0001, 0x0002, 0x0000, 0x0004, 0x000c, 0x001c, 0x007c, 0x003c,
  1004. 0x01bc, 0x00bc, 0x06bc, 0x02bc, 0x0abc,
  1005. };
  1006. static const uint16_t rsd_codes[9] = {
  1007. 0x0001, 0x0003, 0x0000, 0x0002, 0x0006, 0x0004, 0x000c, 0x001c,
  1008. 0x003c,
  1009. };
  1010. static const uint8_t tnl_grp_0_bitvals[74] = {
  1011. 3, 5, 3, 9, 3, 4, 3, 6, 4, 10, 4, 13, 4, 7, 4, 11,
  1012. 4, 8, 5, 12, 5, 14, 6, 15, 6, 18, 6, 1, 6, 17, 6, 16,
  1013. 6, 21, 7, 20, 8, 19, 8, 22, 8, 25, 9, 26, 9, 23, 9, 3,
  1014. 9, 24, 10, 29, 10, 27, 11, 28, 11, 30, 12, 33, 12, 31, 12, 32,
  1015. 14, 34, 14, 37, 14, 36, 15, 35, 15, 0,
  1016. };
  1017. static const uint8_t tnl_grp_1_bitvals[68] = {
  1018. 3, 9, 3, 6, 3, 5, 4, 4, 4, 8, 4, 10, 4, 1, 4, 11,
  1019. 4, 7, 4, 13, 5, 12, 5, 14, 5, 17, 6, 16, 6, 15, 6, 18,
  1020. 7, 20, 7, 19, 7, 21, 8, 25, 8, 23, 8, 22, 8, 24, 9, 26,
  1021. 10, 3, 10, 29, 10, 30, 10, 27, 10, 28, 11, 31, 12, 32, 13, 33,
  1022. 14, 34, 14, 0,
  1023. };
  1024. static const uint8_t tnl_grp_2_bitvals[62] = {
  1025. 2, 1, 3, 6, 3, 5, 3, 7, 4, 9, 4, 8, 4, 4, 5, 10,
  1026. 5, 11, 5, 13, 6, 12, 7, 14, 7, 16, 7, 15, 7, 17, 7, 18,
  1027. 7, 19, 8, 22, 8, 20, 8, 21, 8, 3, 8, 24, 8, 25, 9, 23,
  1028. 9, 26, 9, 27, 10, 28, 11, 29, 12, 31, 13, 30, 13, 0,
  1029. };
  1030. static const uint8_t tnl_grp_3_bitvals[56] = {
  1031. 1, 1, 3, 6, 4, 5, 5, 9, 5, 4, 6, 8, 6, 14, 6, 10,
  1032. 6, 21, 6, 13, 6, 7, 6, 3, 6, 16, 6, 2, 6, 18, 6, 17,
  1033. 6, 11, 6, 15, 7, 19, 7, 23, 7, 24, 7, 22, 7, 12, 8, 20,
  1034. 9, 25, 10, 26, 11, 27, 11, 0,
  1035. };
  1036. static const uint8_t tnl_grp_4_bitvals[46] = {
  1037. 1, 1, 2, 2, 4, 4, 5, 5, 6, 6, 6, 8, 6, 3, 6, 19,
  1038. 6, 20, 6, 9, 7, 7, 7, 11, 7, 13, 7, 17, 7, 10, 8, 12,
  1039. 8, 15, 8, 14, 8, 21, 8, 18, 9, 16, 10, 22, 10, 0,
  1040. };
  1041. static const uint8_t tnl_scf_bitvals[40] = {
  1042. 3, 3, 3, 1, 3, 2, 3, 5, 3, 4, 3, 6, 4, 8, 4, 7,
  1043. 5, 10, 5, 9, 6, 12, 6, 11, 6, 13, 7, 14, 8, 15, 9, 16,
  1044. 10, 17, 11, 18, 12, 19, 12, 0,
  1045. };
  1046. static const uint8_t damp_bitvals[14] = {
  1047. 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 6, 0,
  1048. };
  1049. static const uint8_t dph_bitvals[18] = {
  1050. 2, 2, 2, 1, 2, 8, 4, 3, 4, 7, 4, 4, 5, 6, 6, 5,
  1051. 6, 0,
  1052. };
  1053. static const uint8_t fst_rsd_amp_bitvals[48] = {
  1054. 3, 13, 3, 15, 3, 16, 3, 14, 4, 12, 4, 10, 4, 11, 4, 17,
  1055. 4, 18, 5, 19, 5, 9, 6, 1, 6, 7, 6, 6, 6, 8, 6, 5,
  1056. 6, 4, 7, 20, 7, 2, 7, 3, 8, 21, 9, 22, 10, 23, 10, 0,
  1057. };
  1058. static const uint8_t rsd_apprx_bitvals[12] = {
  1059. 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 5, 0,
  1060. };
  1061. static const uint8_t rsd_amp_bitvals[66] = {
  1062. 2, 3, 3, 2, 3, 5, 3, 4, 3, 1, 4, 7, 4, 6, 5, 9,
  1063. 6, 8, 6, 11, 6, 10, 7, 12, 7, 13, 8, 14, 8, 18, 8, 16,
  1064. 8, 15, 8, 22, 9, 20, 9, 24, 9, 17, 10, 28, 10, 26, 10, 21,
  1065. 10, 23, 11, 30, 11, 19, 12, 25, 12, 32, 13, 36, 13, 29, 13, 34,
  1066. 13, 0,
  1067. };
  1068. static const uint8_t avg_g3_bitvals[36] = {
  1069. 2, 15, 2, 16, 2, 17, 4, 14, 4, 18, 5, 12, 5, 13, 6, 10,
  1070. 6, 11, 7, 19, 7, 9, 8, 20, 8, 8, 8, 7, 9, 21, 10, 6,
  1071. 11, 23, 11, 0,
  1072. };
  1073. static const uint8_t st_grid_bitvals[44] = {
  1074. 1, 6, 2, 1, 4, 4, 4, 8, 4, 3, 5, 10, 7, 12, 7, 5,
  1075. 8, 14, 9, 16, 9, 7, 9, 18, 10, 11, 10, 9, 10, 20, 10, 22,
  1076. 10, 2, 11, 13, 13, 17, 13, 24, 13, 15, 13, 0,
  1077. };
  1078. static const uint8_t grid_2_bitvals[40] = {
  1079. 2, 3, 2, 2, 2, 1, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8,
  1080. 8, 9, 9, 10, 11, 11, 11, 12, 12, 13, 12, 17, 13, 15, 13, 18,
  1081. 14, 19, 14, 16, 14, 14, 14, 0,
  1082. };
  1083. static const uint8_t grid_3_bitvals[26] = {
  1084. 1, 17, 2, 16, 3, 18, 4, 15, 5, 19, 6, 14, 7, 20, 8, 13,
  1085. 9, 21, 10, 12, 11, 22, 12, 11, 12, 0,
  1086. };
  1087. static const uint8_t rsd_bitvals[18] = {
  1088. 2, 2, 2, 3, 3, 1, 3, 4, 3, 0, 4, 5, 5, 6, 6, 7,
  1089. 6, 4,
  1090. };
  1091. static const uint16_t vlc_offs[80] = {
  1092. 0, 512, 640, 768, 1282, 1794, 2436, 3080, 3770, 4454, 5364,
  1093. 5372, 5380, 5388, 5392, 5396, 5412, 5420, 5428, 5460, 5492, 5508,
  1094. 5572, 5604, 5668, 5796, 5860, 5892, 6412, 6668, 6796, 7308, 7564,
  1095. 7820, 8076, 8620, 9132, 9388, 9910, 10166, 10680, 11196, 11726, 12240,
  1096. 12752, 13298, 13810, 14326, 14840, 15500, 16022, 16540, 17158, 17678, 18264,
  1097. 18796, 19352, 19926, 20468, 21472, 22398, 23014, 23622, 24200, 24748, 25276,
  1098. 25792, 26306, 26826, 26890, 26954, 27468, 27500, 28038, 28554, 29086, 29630,
  1099. 30150, 30214
  1100. };
  1101. DCAVLC ff_dca_vlc_bit_allocation;
  1102. DCAVLC ff_dca_vlc_transition_mode;
  1103. DCAVLC ff_dca_vlc_scale_factor;
  1104. DCAVLC ff_dca_vlc_quant_index[DCA_CODE_BOOKS];
  1105. VLC ff_dca_vlc_tnl_grp[5];
  1106. VLC ff_dca_vlc_tnl_scf;
  1107. VLC ff_dca_vlc_damp;
  1108. VLC ff_dca_vlc_dph;
  1109. VLC ff_dca_vlc_fst_rsd_amp;
  1110. VLC ff_dca_vlc_rsd_apprx;
  1111. VLC ff_dca_vlc_rsd_amp;
  1112. VLC ff_dca_vlc_avg_g3;
  1113. VLC ff_dca_vlc_st_grid;
  1114. VLC ff_dca_vlc_grid_2;
  1115. VLC ff_dca_vlc_grid_3;
  1116. VLC ff_dca_vlc_rsd;
  1117. av_cold void ff_dca_init_vlcs(void)
  1118. {
  1119. static VLC_TYPE dca_table[30214][2];
  1120. static int vlcs_initialized = 0;
  1121. int i, j, k = 0;
  1122. if (vlcs_initialized)
  1123. return;
  1124. #define DCA_INIT_VLC(vlc, a, b, c, d) \
  1125. do { \
  1126. vlc.table = &dca_table[vlc_offs[k]]; \
  1127. vlc.table_allocated = vlc_offs[k + 1] - vlc_offs[k]; \
  1128. init_vlc(&vlc, a, b, c, 1, 1, d, 2, 2, INIT_VLC_USE_NEW_STATIC); \
  1129. k++; \
  1130. } while (0)
  1131. ff_dca_vlc_bit_allocation.offset = 1;
  1132. ff_dca_vlc_bit_allocation.max_depth = 2;
  1133. for (i = 0; i < 5; i++)
  1134. DCA_INIT_VLC(ff_dca_vlc_bit_allocation.vlc[i], bitalloc_12_vlc_bits[i], 12,
  1135. bitalloc_12_bits[i], bitalloc_12_codes[i]);
  1136. ff_dca_vlc_scale_factor.offset = -64;
  1137. ff_dca_vlc_scale_factor.max_depth = 2;
  1138. for (i = 0; i < 5; i++)
  1139. DCA_INIT_VLC(ff_dca_vlc_scale_factor.vlc[i], SCALES_VLC_BITS, 129,
  1140. scales_bits[i], scales_codes[i]);
  1141. ff_dca_vlc_transition_mode.offset = 0;
  1142. ff_dca_vlc_transition_mode.max_depth = 1;
  1143. for (i = 0; i < 4; i++)
  1144. DCA_INIT_VLC(ff_dca_vlc_transition_mode.vlc[i], tmode_vlc_bits[i], 4,
  1145. tmode_bits[i], tmode_codes[i]);
  1146. for (i = 0; i < DCA_CODE_BOOKS; i++) {
  1147. ff_dca_vlc_quant_index[i].offset = bitalloc_offsets[i];
  1148. ff_dca_vlc_quant_index[i].max_depth = 1 + (i > 4);
  1149. for (j = 0; bitalloc_codes[i][j]; j++)
  1150. DCA_INIT_VLC(ff_dca_vlc_quant_index[i].vlc[j], bitalloc_maxbits[i][j],
  1151. bitalloc_sizes[i], bitalloc_bits[i][j], bitalloc_codes[i][j]);
  1152. }
  1153. #define LBR_INIT_VLC(vlc, tab, nb_bits) \
  1154. do { \
  1155. vlc.table = &dca_table[vlc_offs[k]]; \
  1156. vlc.table_allocated = vlc_offs[k + 1] - vlc_offs[k]; \
  1157. ff_init_vlc_sparse(&vlc, nb_bits, FF_ARRAY_ELEMS(tab##_codes), \
  1158. &tab##_bitvals[0], 2, 1, \
  1159. tab##_codes, 2, 2, \
  1160. &tab##_bitvals[1], 2, 1, \
  1161. INIT_VLC_LE | INIT_VLC_USE_NEW_STATIC); \
  1162. k++; \
  1163. } while (0)
  1164. LBR_INIT_VLC(ff_dca_vlc_tnl_grp[0], tnl_grp_0, 9);
  1165. LBR_INIT_VLC(ff_dca_vlc_tnl_grp[1], tnl_grp_1, 9);
  1166. LBR_INIT_VLC(ff_dca_vlc_tnl_grp[2], tnl_grp_2, 9);
  1167. LBR_INIT_VLC(ff_dca_vlc_tnl_grp[3], tnl_grp_3, 9);
  1168. LBR_INIT_VLC(ff_dca_vlc_tnl_grp[4], tnl_grp_4, 9);
  1169. LBR_INIT_VLC(ff_dca_vlc_tnl_scf, tnl_scf, 9);
  1170. LBR_INIT_VLC(ff_dca_vlc_damp, damp, 6);
  1171. LBR_INIT_VLC(ff_dca_vlc_dph, dph, 6);
  1172. LBR_INIT_VLC(ff_dca_vlc_fst_rsd_amp, fst_rsd_amp, 9);
  1173. LBR_INIT_VLC(ff_dca_vlc_rsd_apprx, rsd_apprx, 5);
  1174. LBR_INIT_VLC(ff_dca_vlc_rsd_amp, rsd_amp, 9);
  1175. LBR_INIT_VLC(ff_dca_vlc_avg_g3, avg_g3, 9);
  1176. LBR_INIT_VLC(ff_dca_vlc_st_grid, st_grid, 9);
  1177. LBR_INIT_VLC(ff_dca_vlc_grid_2, grid_2, 9);
  1178. LBR_INIT_VLC(ff_dca_vlc_grid_3, grid_3, 9);
  1179. LBR_INIT_VLC(ff_dca_vlc_rsd, rsd, 6);
  1180. vlcs_initialized = 1;
  1181. }
  1182. uint32_t ff_dca_vlc_calc_quant_bits(int *values, uint8_t n, uint8_t sel, uint8_t table)
  1183. {
  1184. uint8_t i, id;
  1185. uint32_t sum = 0;
  1186. for (i = 0; i < n; i++) {
  1187. id = values[i] - bitalloc_offsets[table];
  1188. av_assert0(id < bitalloc_sizes[table]);
  1189. sum += bitalloc_bits[table][sel][id];
  1190. }
  1191. return sum;
  1192. }
  1193. void ff_dca_vlc_enc_quant(PutBitContext *pb, int *values, uint8_t n, uint8_t sel, uint8_t table)
  1194. {
  1195. uint8_t i, id;
  1196. for (i = 0; i < n; i++) {
  1197. id = values[i] - bitalloc_offsets[table];
  1198. av_assert0(id < bitalloc_sizes[table]);
  1199. put_bits(pb, bitalloc_bits[table][sel][id], bitalloc_codes[table][sel][id]);
  1200. }
  1201. }
  1202. uint32_t ff_dca_vlc_calc_alloc_bits(int *values, uint8_t n, uint8_t sel)
  1203. {
  1204. uint8_t i, id;
  1205. uint32_t sum = 0;
  1206. for (i = 0; i < n; i++) {
  1207. id = values[i] - 1;
  1208. sum += bitalloc_12_bits[sel][id];
  1209. }
  1210. return sum;
  1211. }
  1212. void ff_dca_vlc_enc_alloc(PutBitContext *pb, int *values, uint8_t n, uint8_t sel)
  1213. {
  1214. uint8_t i, id;
  1215. for (i = 0; i < n; i++) {
  1216. id = values[i] - 1;
  1217. put_bits(pb, bitalloc_12_bits[sel][id], bitalloc_12_codes[sel][id]);
  1218. }
  1219. }