cost.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  1. // Copyright 2014 Google Inc. All Rights Reserved.
  2. //
  3. // Use of this source code is governed by a BSD-style license
  4. // that can be found in the COPYING file in the root of the source
  5. // tree. An additional intellectual property rights grant can be found
  6. // in the file PATENTS. All contributing project authors may
  7. // be found in the AUTHORS file in the root of the source tree.
  8. // -----------------------------------------------------------------------------
  9. //
  10. // Author: Skal (pascal.massimino@gmail.com)
  11. #include "./dsp.h"
  12. #include "../enc/cost_enc.h"
  13. //------------------------------------------------------------------------------
  14. // Boolean-cost cost table
  15. const uint16_t VP8EntropyCost[256] = {
  16. 1792, 1792, 1792, 1536, 1536, 1408, 1366, 1280, 1280, 1216,
  17. 1178, 1152, 1110, 1076, 1061, 1024, 1024, 992, 968, 951,
  18. 939, 911, 896, 878, 871, 854, 838, 820, 811, 794,
  19. 786, 768, 768, 752, 740, 732, 720, 709, 704, 690,
  20. 683, 672, 666, 655, 647, 640, 631, 622, 615, 607,
  21. 598, 592, 586, 576, 572, 564, 559, 555, 547, 541,
  22. 534, 528, 522, 512, 512, 504, 500, 494, 488, 483,
  23. 477, 473, 467, 461, 458, 452, 448, 443, 438, 434,
  24. 427, 424, 419, 415, 410, 406, 403, 399, 394, 390,
  25. 384, 384, 377, 374, 370, 366, 362, 359, 355, 351,
  26. 347, 342, 342, 336, 333, 330, 326, 323, 320, 316,
  27. 312, 308, 305, 302, 299, 296, 293, 288, 287, 283,
  28. 280, 277, 274, 272, 268, 266, 262, 256, 256, 256,
  29. 251, 248, 245, 242, 240, 237, 234, 232, 228, 226,
  30. 223, 221, 218, 216, 214, 211, 208, 205, 203, 201,
  31. 198, 196, 192, 191, 188, 187, 183, 181, 179, 176,
  32. 175, 171, 171, 168, 165, 163, 160, 159, 156, 154,
  33. 152, 150, 148, 146, 144, 142, 139, 138, 135, 133,
  34. 131, 128, 128, 125, 123, 121, 119, 117, 115, 113,
  35. 111, 110, 107, 105, 103, 102, 100, 98, 96, 94,
  36. 92, 91, 89, 86, 86, 83, 82, 80, 77, 76,
  37. 74, 73, 71, 69, 67, 66, 64, 63, 61, 59,
  38. 57, 55, 54, 52, 51, 49, 47, 46, 44, 43,
  39. 41, 40, 38, 36, 35, 33, 32, 30, 29, 27,
  40. 25, 24, 22, 21, 19, 18, 16, 15, 13, 12,
  41. 10, 9, 7, 6, 4, 3
  42. };
  43. //------------------------------------------------------------------------------
  44. // Level cost tables
  45. // fixed costs for coding levels, deduce from the coding tree.
  46. // This is only the part that doesn't depend on the probability state.
  47. const uint16_t VP8LevelFixedCosts[MAX_LEVEL + 1] = {
  48. 0, 256, 256, 256, 256, 432, 618, 630,
  49. 731, 640, 640, 828, 901, 948, 1021, 1101,
  50. 1174, 1221, 1294, 1042, 1085, 1115, 1158, 1202,
  51. 1245, 1275, 1318, 1337, 1380, 1410, 1453, 1497,
  52. 1540, 1570, 1613, 1280, 1295, 1317, 1332, 1358,
  53. 1373, 1395, 1410, 1454, 1469, 1491, 1506, 1532,
  54. 1547, 1569, 1584, 1601, 1616, 1638, 1653, 1679,
  55. 1694, 1716, 1731, 1775, 1790, 1812, 1827, 1853,
  56. 1868, 1890, 1905, 1727, 1733, 1742, 1748, 1759,
  57. 1765, 1774, 1780, 1800, 1806, 1815, 1821, 1832,
  58. 1838, 1847, 1853, 1878, 1884, 1893, 1899, 1910,
  59. 1916, 1925, 1931, 1951, 1957, 1966, 1972, 1983,
  60. 1989, 1998, 2004, 2027, 2033, 2042, 2048, 2059,
  61. 2065, 2074, 2080, 2100, 2106, 2115, 2121, 2132,
  62. 2138, 2147, 2153, 2178, 2184, 2193, 2199, 2210,
  63. 2216, 2225, 2231, 2251, 2257, 2266, 2272, 2283,
  64. 2289, 2298, 2304, 2168, 2174, 2183, 2189, 2200,
  65. 2206, 2215, 2221, 2241, 2247, 2256, 2262, 2273,
  66. 2279, 2288, 2294, 2319, 2325, 2334, 2340, 2351,
  67. 2357, 2366, 2372, 2392, 2398, 2407, 2413, 2424,
  68. 2430, 2439, 2445, 2468, 2474, 2483, 2489, 2500,
  69. 2506, 2515, 2521, 2541, 2547, 2556, 2562, 2573,
  70. 2579, 2588, 2594, 2619, 2625, 2634, 2640, 2651,
  71. 2657, 2666, 2672, 2692, 2698, 2707, 2713, 2724,
  72. 2730, 2739, 2745, 2540, 2546, 2555, 2561, 2572,
  73. 2578, 2587, 2593, 2613, 2619, 2628, 2634, 2645,
  74. 2651, 2660, 2666, 2691, 2697, 2706, 2712, 2723,
  75. 2729, 2738, 2744, 2764, 2770, 2779, 2785, 2796,
  76. 2802, 2811, 2817, 2840, 2846, 2855, 2861, 2872,
  77. 2878, 2887, 2893, 2913, 2919, 2928, 2934, 2945,
  78. 2951, 2960, 2966, 2991, 2997, 3006, 3012, 3023,
  79. 3029, 3038, 3044, 3064, 3070, 3079, 3085, 3096,
  80. 3102, 3111, 3117, 2981, 2987, 2996, 3002, 3013,
  81. 3019, 3028, 3034, 3054, 3060, 3069, 3075, 3086,
  82. 3092, 3101, 3107, 3132, 3138, 3147, 3153, 3164,
  83. 3170, 3179, 3185, 3205, 3211, 3220, 3226, 3237,
  84. 3243, 3252, 3258, 3281, 3287, 3296, 3302, 3313,
  85. 3319, 3328, 3334, 3354, 3360, 3369, 3375, 3386,
  86. 3392, 3401, 3407, 3432, 3438, 3447, 3453, 3464,
  87. 3470, 3479, 3485, 3505, 3511, 3520, 3526, 3537,
  88. 3543, 3552, 3558, 2816, 2822, 2831, 2837, 2848,
  89. 2854, 2863, 2869, 2889, 2895, 2904, 2910, 2921,
  90. 2927, 2936, 2942, 2967, 2973, 2982, 2988, 2999,
  91. 3005, 3014, 3020, 3040, 3046, 3055, 3061, 3072,
  92. 3078, 3087, 3093, 3116, 3122, 3131, 3137, 3148,
  93. 3154, 3163, 3169, 3189, 3195, 3204, 3210, 3221,
  94. 3227, 3236, 3242, 3267, 3273, 3282, 3288, 3299,
  95. 3305, 3314, 3320, 3340, 3346, 3355, 3361, 3372,
  96. 3378, 3387, 3393, 3257, 3263, 3272, 3278, 3289,
  97. 3295, 3304, 3310, 3330, 3336, 3345, 3351, 3362,
  98. 3368, 3377, 3383, 3408, 3414, 3423, 3429, 3440,
  99. 3446, 3455, 3461, 3481, 3487, 3496, 3502, 3513,
  100. 3519, 3528, 3534, 3557, 3563, 3572, 3578, 3589,
  101. 3595, 3604, 3610, 3630, 3636, 3645, 3651, 3662,
  102. 3668, 3677, 3683, 3708, 3714, 3723, 3729, 3740,
  103. 3746, 3755, 3761, 3781, 3787, 3796, 3802, 3813,
  104. 3819, 3828, 3834, 3629, 3635, 3644, 3650, 3661,
  105. 3667, 3676, 3682, 3702, 3708, 3717, 3723, 3734,
  106. 3740, 3749, 3755, 3780, 3786, 3795, 3801, 3812,
  107. 3818, 3827, 3833, 3853, 3859, 3868, 3874, 3885,
  108. 3891, 3900, 3906, 3929, 3935, 3944, 3950, 3961,
  109. 3967, 3976, 3982, 4002, 4008, 4017, 4023, 4034,
  110. 4040, 4049, 4055, 4080, 4086, 4095, 4101, 4112,
  111. 4118, 4127, 4133, 4153, 4159, 4168, 4174, 4185,
  112. 4191, 4200, 4206, 4070, 4076, 4085, 4091, 4102,
  113. 4108, 4117, 4123, 4143, 4149, 4158, 4164, 4175,
  114. 4181, 4190, 4196, 4221, 4227, 4236, 4242, 4253,
  115. 4259, 4268, 4274, 4294, 4300, 4309, 4315, 4326,
  116. 4332, 4341, 4347, 4370, 4376, 4385, 4391, 4402,
  117. 4408, 4417, 4423, 4443, 4449, 4458, 4464, 4475,
  118. 4481, 4490, 4496, 4521, 4527, 4536, 4542, 4553,
  119. 4559, 4568, 4574, 4594, 4600, 4609, 4615, 4626,
  120. 4632, 4641, 4647, 3515, 3521, 3530, 3536, 3547,
  121. 3553, 3562, 3568, 3588, 3594, 3603, 3609, 3620,
  122. 3626, 3635, 3641, 3666, 3672, 3681, 3687, 3698,
  123. 3704, 3713, 3719, 3739, 3745, 3754, 3760, 3771,
  124. 3777, 3786, 3792, 3815, 3821, 3830, 3836, 3847,
  125. 3853, 3862, 3868, 3888, 3894, 3903, 3909, 3920,
  126. 3926, 3935, 3941, 3966, 3972, 3981, 3987, 3998,
  127. 4004, 4013, 4019, 4039, 4045, 4054, 4060, 4071,
  128. 4077, 4086, 4092, 3956, 3962, 3971, 3977, 3988,
  129. 3994, 4003, 4009, 4029, 4035, 4044, 4050, 4061,
  130. 4067, 4076, 4082, 4107, 4113, 4122, 4128, 4139,
  131. 4145, 4154, 4160, 4180, 4186, 4195, 4201, 4212,
  132. 4218, 4227, 4233, 4256, 4262, 4271, 4277, 4288,
  133. 4294, 4303, 4309, 4329, 4335, 4344, 4350, 4361,
  134. 4367, 4376, 4382, 4407, 4413, 4422, 4428, 4439,
  135. 4445, 4454, 4460, 4480, 4486, 4495, 4501, 4512,
  136. 4518, 4527, 4533, 4328, 4334, 4343, 4349, 4360,
  137. 4366, 4375, 4381, 4401, 4407, 4416, 4422, 4433,
  138. 4439, 4448, 4454, 4479, 4485, 4494, 4500, 4511,
  139. 4517, 4526, 4532, 4552, 4558, 4567, 4573, 4584,
  140. 4590, 4599, 4605, 4628, 4634, 4643, 4649, 4660,
  141. 4666, 4675, 4681, 4701, 4707, 4716, 4722, 4733,
  142. 4739, 4748, 4754, 4779, 4785, 4794, 4800, 4811,
  143. 4817, 4826, 4832, 4852, 4858, 4867, 4873, 4884,
  144. 4890, 4899, 4905, 4769, 4775, 4784, 4790, 4801,
  145. 4807, 4816, 4822, 4842, 4848, 4857, 4863, 4874,
  146. 4880, 4889, 4895, 4920, 4926, 4935, 4941, 4952,
  147. 4958, 4967, 4973, 4993, 4999, 5008, 5014, 5025,
  148. 5031, 5040, 5046, 5069, 5075, 5084, 5090, 5101,
  149. 5107, 5116, 5122, 5142, 5148, 5157, 5163, 5174,
  150. 5180, 5189, 5195, 5220, 5226, 5235, 5241, 5252,
  151. 5258, 5267, 5273, 5293, 5299, 5308, 5314, 5325,
  152. 5331, 5340, 5346, 4604, 4610, 4619, 4625, 4636,
  153. 4642, 4651, 4657, 4677, 4683, 4692, 4698, 4709,
  154. 4715, 4724, 4730, 4755, 4761, 4770, 4776, 4787,
  155. 4793, 4802, 4808, 4828, 4834, 4843, 4849, 4860,
  156. 4866, 4875, 4881, 4904, 4910, 4919, 4925, 4936,
  157. 4942, 4951, 4957, 4977, 4983, 4992, 4998, 5009,
  158. 5015, 5024, 5030, 5055, 5061, 5070, 5076, 5087,
  159. 5093, 5102, 5108, 5128, 5134, 5143, 5149, 5160,
  160. 5166, 5175, 5181, 5045, 5051, 5060, 5066, 5077,
  161. 5083, 5092, 5098, 5118, 5124, 5133, 5139, 5150,
  162. 5156, 5165, 5171, 5196, 5202, 5211, 5217, 5228,
  163. 5234, 5243, 5249, 5269, 5275, 5284, 5290, 5301,
  164. 5307, 5316, 5322, 5345, 5351, 5360, 5366, 5377,
  165. 5383, 5392, 5398, 5418, 5424, 5433, 5439, 5450,
  166. 5456, 5465, 5471, 5496, 5502, 5511, 5517, 5528,
  167. 5534, 5543, 5549, 5569, 5575, 5584, 5590, 5601,
  168. 5607, 5616, 5622, 5417, 5423, 5432, 5438, 5449,
  169. 5455, 5464, 5470, 5490, 5496, 5505, 5511, 5522,
  170. 5528, 5537, 5543, 5568, 5574, 5583, 5589, 5600,
  171. 5606, 5615, 5621, 5641, 5647, 5656, 5662, 5673,
  172. 5679, 5688, 5694, 5717, 5723, 5732, 5738, 5749,
  173. 5755, 5764, 5770, 5790, 5796, 5805, 5811, 5822,
  174. 5828, 5837, 5843, 5868, 5874, 5883, 5889, 5900,
  175. 5906, 5915, 5921, 5941, 5947, 5956, 5962, 5973,
  176. 5979, 5988, 5994, 5858, 5864, 5873, 5879, 5890,
  177. 5896, 5905, 5911, 5931, 5937, 5946, 5952, 5963,
  178. 5969, 5978, 5984, 6009, 6015, 6024, 6030, 6041,
  179. 6047, 6056, 6062, 6082, 6088, 6097, 6103, 6114,
  180. 6120, 6129, 6135, 6158, 6164, 6173, 6179, 6190,
  181. 6196, 6205, 6211, 6231, 6237, 6246, 6252, 6263,
  182. 6269, 6278, 6284, 6309, 6315, 6324, 6330, 6341,
  183. 6347, 6356, 6362, 6382, 6388, 6397, 6403, 6414,
  184. 6420, 6429, 6435, 3515, 3521, 3530, 3536, 3547,
  185. 3553, 3562, 3568, 3588, 3594, 3603, 3609, 3620,
  186. 3626, 3635, 3641, 3666, 3672, 3681, 3687, 3698,
  187. 3704, 3713, 3719, 3739, 3745, 3754, 3760, 3771,
  188. 3777, 3786, 3792, 3815, 3821, 3830, 3836, 3847,
  189. 3853, 3862, 3868, 3888, 3894, 3903, 3909, 3920,
  190. 3926, 3935, 3941, 3966, 3972, 3981, 3987, 3998,
  191. 4004, 4013, 4019, 4039, 4045, 4054, 4060, 4071,
  192. 4077, 4086, 4092, 3956, 3962, 3971, 3977, 3988,
  193. 3994, 4003, 4009, 4029, 4035, 4044, 4050, 4061,
  194. 4067, 4076, 4082, 4107, 4113, 4122, 4128, 4139,
  195. 4145, 4154, 4160, 4180, 4186, 4195, 4201, 4212,
  196. 4218, 4227, 4233, 4256, 4262, 4271, 4277, 4288,
  197. 4294, 4303, 4309, 4329, 4335, 4344, 4350, 4361,
  198. 4367, 4376, 4382, 4407, 4413, 4422, 4428, 4439,
  199. 4445, 4454, 4460, 4480, 4486, 4495, 4501, 4512,
  200. 4518, 4527, 4533, 4328, 4334, 4343, 4349, 4360,
  201. 4366, 4375, 4381, 4401, 4407, 4416, 4422, 4433,
  202. 4439, 4448, 4454, 4479, 4485, 4494, 4500, 4511,
  203. 4517, 4526, 4532, 4552, 4558, 4567, 4573, 4584,
  204. 4590, 4599, 4605, 4628, 4634, 4643, 4649, 4660,
  205. 4666, 4675, 4681, 4701, 4707, 4716, 4722, 4733,
  206. 4739, 4748, 4754, 4779, 4785, 4794, 4800, 4811,
  207. 4817, 4826, 4832, 4852, 4858, 4867, 4873, 4884,
  208. 4890, 4899, 4905, 4769, 4775, 4784, 4790, 4801,
  209. 4807, 4816, 4822, 4842, 4848, 4857, 4863, 4874,
  210. 4880, 4889, 4895, 4920, 4926, 4935, 4941, 4952,
  211. 4958, 4967, 4973, 4993, 4999, 5008, 5014, 5025,
  212. 5031, 5040, 5046, 5069, 5075, 5084, 5090, 5101,
  213. 5107, 5116, 5122, 5142, 5148, 5157, 5163, 5174,
  214. 5180, 5189, 5195, 5220, 5226, 5235, 5241, 5252,
  215. 5258, 5267, 5273, 5293, 5299, 5308, 5314, 5325,
  216. 5331, 5340, 5346, 4604, 4610, 4619, 4625, 4636,
  217. 4642, 4651, 4657, 4677, 4683, 4692, 4698, 4709,
  218. 4715, 4724, 4730, 4755, 4761, 4770, 4776, 4787,
  219. 4793, 4802, 4808, 4828, 4834, 4843, 4849, 4860,
  220. 4866, 4875, 4881, 4904, 4910, 4919, 4925, 4936,
  221. 4942, 4951, 4957, 4977, 4983, 4992, 4998, 5009,
  222. 5015, 5024, 5030, 5055, 5061, 5070, 5076, 5087,
  223. 5093, 5102, 5108, 5128, 5134, 5143, 5149, 5160,
  224. 5166, 5175, 5181, 5045, 5051, 5060, 5066, 5077,
  225. 5083, 5092, 5098, 5118, 5124, 5133, 5139, 5150,
  226. 5156, 5165, 5171, 5196, 5202, 5211, 5217, 5228,
  227. 5234, 5243, 5249, 5269, 5275, 5284, 5290, 5301,
  228. 5307, 5316, 5322, 5345, 5351, 5360, 5366, 5377,
  229. 5383, 5392, 5398, 5418, 5424, 5433, 5439, 5450,
  230. 5456, 5465, 5471, 5496, 5502, 5511, 5517, 5528,
  231. 5534, 5543, 5549, 5569, 5575, 5584, 5590, 5601,
  232. 5607, 5616, 5622, 5417, 5423, 5432, 5438, 5449,
  233. 5455, 5464, 5470, 5490, 5496, 5505, 5511, 5522,
  234. 5528, 5537, 5543, 5568, 5574, 5583, 5589, 5600,
  235. 5606, 5615, 5621, 5641, 5647, 5656, 5662, 5673,
  236. 5679, 5688, 5694, 5717, 5723, 5732, 5738, 5749,
  237. 5755, 5764, 5770, 5790, 5796, 5805, 5811, 5822,
  238. 5828, 5837, 5843, 5868, 5874, 5883, 5889, 5900,
  239. 5906, 5915, 5921, 5941, 5947, 5956, 5962, 5973,
  240. 5979, 5988, 5994, 5858, 5864, 5873, 5879, 5890,
  241. 5896, 5905, 5911, 5931, 5937, 5946, 5952, 5963,
  242. 5969, 5978, 5984, 6009, 6015, 6024, 6030, 6041,
  243. 6047, 6056, 6062, 6082, 6088, 6097, 6103, 6114,
  244. 6120, 6129, 6135, 6158, 6164, 6173, 6179, 6190,
  245. 6196, 6205, 6211, 6231, 6237, 6246, 6252, 6263,
  246. 6269, 6278, 6284, 6309, 6315, 6324, 6330, 6341,
  247. 6347, 6356, 6362, 6382, 6388, 6397, 6403, 6414,
  248. 6420, 6429, 6435, 5303, 5309, 5318, 5324, 5335,
  249. 5341, 5350, 5356, 5376, 5382, 5391, 5397, 5408,
  250. 5414, 5423, 5429, 5454, 5460, 5469, 5475, 5486,
  251. 5492, 5501, 5507, 5527, 5533, 5542, 5548, 5559,
  252. 5565, 5574, 5580, 5603, 5609, 5618, 5624, 5635,
  253. 5641, 5650, 5656, 5676, 5682, 5691, 5697, 5708,
  254. 5714, 5723, 5729, 5754, 5760, 5769, 5775, 5786,
  255. 5792, 5801, 5807, 5827, 5833, 5842, 5848, 5859,
  256. 5865, 5874, 5880, 5744, 5750, 5759, 5765, 5776,
  257. 5782, 5791, 5797, 5817, 5823, 5832, 5838, 5849,
  258. 5855, 5864, 5870, 5895, 5901, 5910, 5916, 5927,
  259. 5933, 5942, 5948, 5968, 5974, 5983, 5989, 6000,
  260. 6006, 6015, 6021, 6044, 6050, 6059, 6065, 6076,
  261. 6082, 6091, 6097, 6117, 6123, 6132, 6138, 6149,
  262. 6155, 6164, 6170, 6195, 6201, 6210, 6216, 6227,
  263. 6233, 6242, 6248, 6268, 6274, 6283, 6289, 6300,
  264. 6306, 6315, 6321, 6116, 6122, 6131, 6137, 6148,
  265. 6154, 6163, 6169, 6189, 6195, 6204, 6210, 6221,
  266. 6227, 6236, 6242, 6267, 6273, 6282, 6288, 6299,
  267. 6305, 6314, 6320, 6340, 6346, 6355, 6361, 6372,
  268. 6378, 6387, 6393, 6416, 6422, 6431, 6437, 6448,
  269. 6454, 6463, 6469, 6489, 6495, 6504, 6510, 6521,
  270. 6527, 6536, 6542, 6567, 6573, 6582, 6588, 6599,
  271. 6605, 6614, 6620, 6640, 6646, 6655, 6661, 6672,
  272. 6678, 6687, 6693, 6557, 6563, 6572, 6578, 6589,
  273. 6595, 6604, 6610, 6630, 6636, 6645, 6651, 6662,
  274. 6668, 6677, 6683, 6708, 6714, 6723, 6729, 6740,
  275. 6746, 6755, 6761, 6781, 6787, 6796, 6802, 6813,
  276. 6819, 6828, 6834, 6857, 6863, 6872, 6878, 6889,
  277. 6895, 6904, 6910, 6930, 6936, 6945, 6951, 6962,
  278. 6968, 6977, 6983, 7008, 7014, 7023, 7029, 7040,
  279. 7046, 7055, 7061, 7081, 7087, 7096, 7102, 7113,
  280. 7119, 7128, 7134, 6392, 6398, 6407, 6413, 6424,
  281. 6430, 6439, 6445, 6465, 6471, 6480, 6486, 6497,
  282. 6503, 6512, 6518, 6543, 6549, 6558, 6564, 6575,
  283. 6581, 6590, 6596, 6616, 6622, 6631, 6637, 6648,
  284. 6654, 6663, 6669, 6692, 6698, 6707, 6713, 6724,
  285. 6730, 6739, 6745, 6765, 6771, 6780, 6786, 6797,
  286. 6803, 6812, 6818, 6843, 6849, 6858, 6864, 6875,
  287. 6881, 6890, 6896, 6916, 6922, 6931, 6937, 6948,
  288. 6954, 6963, 6969, 6833, 6839, 6848, 6854, 6865,
  289. 6871, 6880, 6886, 6906, 6912, 6921, 6927, 6938,
  290. 6944, 6953, 6959, 6984, 6990, 6999, 7005, 7016,
  291. 7022, 7031, 7037, 7057, 7063, 7072, 7078, 7089,
  292. 7095, 7104, 7110, 7133, 7139, 7148, 7154, 7165,
  293. 7171, 7180, 7186, 7206, 7212, 7221, 7227, 7238,
  294. 7244, 7253, 7259, 7284, 7290, 7299, 7305, 7316,
  295. 7322, 7331, 7337, 7357, 7363, 7372, 7378, 7389,
  296. 7395, 7404, 7410, 7205, 7211, 7220, 7226, 7237,
  297. 7243, 7252, 7258, 7278, 7284, 7293, 7299, 7310,
  298. 7316, 7325, 7331, 7356, 7362, 7371, 7377, 7388,
  299. 7394, 7403, 7409, 7429, 7435, 7444, 7450, 7461,
  300. 7467, 7476, 7482, 7505, 7511, 7520, 7526, 7537,
  301. 7543, 7552, 7558, 7578, 7584, 7593, 7599, 7610,
  302. 7616, 7625, 7631, 7656, 7662, 7671, 7677, 7688,
  303. 7694, 7703, 7709, 7729, 7735, 7744, 7750, 7761
  304. };
  305. //------------------------------------------------------------------------------
  306. // Tables for level coding
  307. const uint8_t VP8EncBands[16 + 1] = {
  308. 0, 1, 2, 3, 6, 4, 5, 6, 6, 6, 6, 6, 6, 6, 6, 7,
  309. 0 // sentinel
  310. };
  311. //------------------------------------------------------------------------------
  312. // Mode costs
  313. static int GetResidualCost(int ctx0, const VP8Residual* const res) {
  314. int n = res->first;
  315. // should be prob[VP8EncBands[n]], but it's equivalent for n=0 or 1
  316. const int p0 = res->prob[n][ctx0][0];
  317. CostArrayPtr const costs = res->costs;
  318. const uint16_t* t = costs[n][ctx0];
  319. // bit_cost(1, p0) is already incorporated in t[] tables, but only if ctx != 0
  320. // (as required by the syntax). For ctx0 == 0, we need to add it here or it'll
  321. // be missing during the loop.
  322. int cost = (ctx0 == 0) ? VP8BitCost(1, p0) : 0;
  323. if (res->last < 0) {
  324. return VP8BitCost(0, p0);
  325. }
  326. for (; n < res->last; ++n) {
  327. const int v = abs(res->coeffs[n]);
  328. const int ctx = (v >= 2) ? 2 : v;
  329. cost += VP8LevelCost(t, v);
  330. t = costs[n + 1][ctx];
  331. }
  332. // Last coefficient is always non-zero
  333. {
  334. const int v = abs(res->coeffs[n]);
  335. assert(v != 0);
  336. cost += VP8LevelCost(t, v);
  337. if (n < 15) {
  338. const int b = VP8EncBands[n + 1];
  339. const int ctx = (v == 1) ? 1 : 2;
  340. const int last_p0 = res->prob[b][ctx][0];
  341. cost += VP8BitCost(0, last_p0);
  342. }
  343. }
  344. return cost;
  345. }
  346. static void SetResidualCoeffs(const int16_t* const coeffs,
  347. VP8Residual* const res) {
  348. int n;
  349. res->last = -1;
  350. assert(res->first == 0 || coeffs[0] == 0);
  351. for (n = 15; n >= 0; --n) {
  352. if (coeffs[n]) {
  353. res->last = n;
  354. break;
  355. }
  356. }
  357. res->coeffs = coeffs;
  358. }
  359. //------------------------------------------------------------------------------
  360. // init function
  361. VP8GetResidualCostFunc VP8GetResidualCost;
  362. VP8SetResidualCoeffsFunc VP8SetResidualCoeffs;
  363. extern void VP8EncDspCostInitMIPS32(void);
  364. extern void VP8EncDspCostInitMIPSdspR2(void);
  365. extern void VP8EncDspCostInitSSE2(void);
  366. static volatile VP8CPUInfo cost_last_cpuinfo_used =
  367. (VP8CPUInfo)&cost_last_cpuinfo_used;
  368. WEBP_TSAN_IGNORE_FUNCTION void VP8EncDspCostInit(void) {
  369. if (cost_last_cpuinfo_used == VP8GetCPUInfo) return;
  370. VP8GetResidualCost = GetResidualCost;
  371. VP8SetResidualCoeffs = SetResidualCoeffs;
  372. // If defined, use CPUInfo() to overwrite some pointers with faster versions.
  373. if (VP8GetCPUInfo != NULL) {
  374. #if defined(WEBP_USE_MIPS32)
  375. if (VP8GetCPUInfo(kMIPS32)) {
  376. VP8EncDspCostInitMIPS32();
  377. }
  378. #endif
  379. #if defined(WEBP_USE_MIPS_DSP_R2)
  380. if (VP8GetCPUInfo(kMIPSdspR2)) {
  381. VP8EncDspCostInitMIPSdspR2();
  382. }
  383. #endif
  384. #if defined(WEBP_USE_SSE2)
  385. if (VP8GetCPUInfo(kSSE2)) {
  386. VP8EncDspCostInitSSE2();
  387. }
  388. #endif
  389. }
  390. cost_last_cpuinfo_used = VP8GetCPUInfo;
  391. }
  392. //------------------------------------------------------------------------------