109 128, 2, 4, 9, 19, 41, 87, 109, 119, 124, 126, 128
115 0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 14, 16, 20, 24, 28, 34, 40, 48, 60, 78, 100
119 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 4, 4, 4, 6, 6, 8, 12, 18, 22
123 0, 0, 0, 0, 0, 0, 0, 0, 8, 8, 8, 8, 16, 16, 16, 21, 21, 24, 29, 34, 36
127 { { { 0, -1 }, { 0, -1 } }, { { 0, -1 }, { 0, -1 } } },
128 { { { 0, -1 }, { 0, -2 } }, { { 1, 0 }, { 1, -1 } } },
129 { { { 0, -2 }, { 0, -3 } }, { { 2, 0 }, { 1, -1 } } },
130 { { { 0, -2 }, { 0, -3 } }, { { 3, 0 }, { 1, -1 } } }
134 6.437500f, 6.250000f, 5.750000f, 5.312500f, 5.062500f,
135 4.812500f, 4.500000f, 4.375000f, 4.875000f, 4.687500f,
136 4.562500f, 4.437500f, 4.875000f, 4.625000f, 4.312500f,
137 4.500000f, 4.375000f, 4.625000f, 4.750000f, 4.437500f,
138 3.750000f, 3.750000f, 3.750000f, 3.750000f, 3.750000f
142 29440.0f/32768.0f, 26112.0f/32768.0f, 21248.0f/32768.0f, 16384.0f/32768.0f
146 30147.0f/32768.0f, 22282.0f/32768.0f, 12124.0f/32768.0f, 6554.0f/32768.0f
152 72, 127, 65, 129, 66, 128, 65, 128, 64, 128, 62, 128, 64, 128,
153 64, 128, 92, 78, 92, 79, 92, 78, 90, 79, 116, 41, 115, 40,
154 114, 40, 132, 26, 132, 26, 145, 17, 161, 12, 176, 10, 177, 11
156 24, 179, 48, 138, 54, 135, 54, 132, 53, 134, 56, 133, 55, 132,
157 55, 132, 61, 114, 70, 96, 74, 88, 75, 88, 87, 74, 89, 66,
158 91, 67, 100, 59, 108, 50, 120, 40, 122, 37, 97, 43, 78, 50
162 83, 78, 84, 81, 88, 75, 86, 74, 87, 71, 90, 73, 93, 74,
163 93, 74, 109, 40, 114, 36, 117, 34, 117, 34, 143, 17, 145, 18,
164 146, 19, 162, 12, 165, 10, 178, 7, 189, 6, 190, 8, 177, 9
166 23, 178, 54, 115, 63, 102, 66, 98, 69, 99, 74, 89, 71, 91,
167 73, 91, 78, 89, 86, 80, 92, 66, 93, 64, 102, 59, 103, 60,
168 104, 60, 117, 52, 123, 44, 138, 35, 133, 31, 97, 38, 77, 45
172 61, 90, 93, 60, 105, 42, 107, 41, 110, 45, 116, 38, 113, 38,
173 112, 38, 124, 26, 132, 27, 136, 19, 140, 20, 155, 14, 159, 16,
174 158, 18, 170, 13, 177, 10, 187, 8, 192, 6, 175, 9, 159, 10
176 21, 178, 59, 110, 71, 86, 75, 85, 84, 83, 91, 66, 88, 73,
177 87, 72, 92, 75, 98, 72, 105, 58, 107, 54, 115, 52, 114, 55,
178 112, 56, 129, 51, 132, 40, 150, 33, 140, 29, 98, 35, 77, 42
182 42, 121, 96, 66, 108, 43, 111, 40, 117, 44, 123, 32, 120, 36,
183 119, 33, 127, 33, 134, 34, 139, 21, 147, 23, 152, 20, 158, 25,
184 154, 26, 166, 21, 173, 16, 184, 13, 184, 10, 150, 13, 139, 15
186 22, 178, 63, 114, 74, 82, 84, 83, 92, 82, 103, 62, 96, 72,
187 96, 67, 101, 73, 107, 72, 113, 55, 118, 52, 125, 52, 118, 52,
188 117, 55, 135, 49, 137, 39, 157, 32, 145, 29, 97, 33, 77, 40
194 { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
195 { 90, 80, 75, 69, 63, 56, 49, 40, 34, 29, 20, 18, 10, 0, 0, 0, 0, 0, 0, 0, 0 },
196 { 110, 100, 90, 84, 78, 71, 65, 58, 51, 45, 39, 32, 26, 20, 12, 0, 0, 0, 0, 0, 0 },
197 { 118, 110, 103, 93, 86, 80, 75, 70, 65, 59, 53, 47, 40, 31, 23, 15, 4, 0, 0, 0, 0 },
198 { 126, 119, 112, 104, 95, 89, 83, 78, 72, 66, 60, 54, 47, 39, 32, 25, 17, 12, 1, 0, 0 },
199 { 134, 127, 120, 114, 103, 97, 91, 85, 78, 72, 66, 60, 54, 47, 41, 35, 29, 23, 16, 10, 1 },
200 { 144, 137, 130, 124, 113, 107, 101, 95, 88, 82, 76, 70, 64, 57, 51, 45, 39, 33, 26, 15, 1 },
201 { 152, 145, 138, 132, 123, 117, 111, 105, 98, 92, 86, 80, 74, 67, 61, 55, 49, 43, 36, 20, 1 },
202 { 162, 155, 148, 142, 133, 127, 121, 115, 108, 102, 96, 90, 84, 77, 71, 65, 59, 53, 46, 30, 1 },
203 { 172, 165, 158, 152, 143, 137, 131, 125, 118, 112, 106, 100, 94, 87, 81, 75, 69, 63, 56, 45, 20 },
204 { 200, 200, 200, 200, 200, 200, 200, 200, 198, 193, 188, 183, 178, 173, 168, 163, 158, 153, 148, 129, 104 }
209 {224, 224, 224, 224, 224, 224, 224, 224, 160, 160,
210 160, 160, 185, 185, 185, 178, 178, 168, 134, 61, 37},
211 {224, 224, 224, 224, 224, 224, 224, 224, 240, 240,
212 240, 240, 207, 207, 207, 198, 198, 183, 144, 66, 40},
214 {160, 160, 160, 160, 160, 160, 160, 160, 185, 185,
215 185, 185, 193, 193, 193, 183, 183, 172, 138, 64, 38},
216 {240, 240, 240, 240, 240, 240, 240, 240, 207, 207,
217 207, 207, 204, 204, 204, 193, 193, 180, 143, 66, 40},
219 {185, 185, 185, 185, 185, 185, 185, 185, 193, 193,
220 193, 193, 193, 193, 193, 183, 183, 172, 138, 65, 39},
221 {207, 207, 207, 207, 207, 207, 207, 207, 204, 204,
222 204, 204, 201, 201, 201, 188, 188, 176, 141, 66, 40},
224 {193, 193, 193, 193, 193, 193, 193, 193, 193, 193,
225 193, 193, 194, 194, 194, 184, 184, 173, 139, 65, 39},
226 {204, 204, 204, 204, 204, 204, 204, 204, 201, 201,
227 201, 201, 198, 198, 198, 187, 187, 175, 140, 66, 40}
232 40, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
233 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,
234 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 40, 15, 23, 28,
235 31, 34, 36, 38, 39, 41, 42, 43, 44, 45, 46, 47, 47, 49, 50,
236 51, 52, 53, 54, 55, 55, 57, 58, 59, 60, 61, 62, 63, 63, 65,
237 66, 67, 68, 69, 70, 71, 71, 40, 20, 33, 41, 48, 53, 57, 61,
238 64, 66, 69, 71, 73, 75, 76, 78, 80, 82, 85, 87, 89, 91, 92,
239 94, 96, 98, 101, 103, 105, 107, 108, 110, 112, 114, 117, 119, 121, 123,
240 124, 126, 128, 40, 23, 39, 51, 60, 67, 73, 79, 83, 87, 91, 94,
241 97, 100, 102, 105, 107, 111, 115, 118, 121, 124, 126, 129, 131, 135, 139,
242 142, 145, 148, 150, 153, 155, 159, 163, 166, 169, 172, 174, 177, 179, 35,
243 28, 49, 65, 78, 89, 99, 107, 114, 120, 126, 132, 136, 141, 145, 149,
244 153, 159, 165, 171, 176, 180, 185, 189, 192, 199, 205, 211, 216, 220, 225,
245 229, 232, 239, 245, 251, 21, 33, 58, 79, 97, 112, 125, 137, 148, 157,
246 166, 174, 182, 189, 195, 201, 207, 217, 227, 235, 243, 251, 17, 35, 63,
247 86, 106, 123, 139, 152, 165, 177, 187, 197, 206, 214, 222, 230, 237, 250,
248 25, 31, 55, 75, 91, 105, 117, 128, 138, 146, 154, 161, 168, 174, 180,
249 185, 190, 200, 208, 215, 222, 229, 235, 240, 245, 255, 16, 36, 65, 89,
250 110, 128, 144, 159, 173, 185, 196, 207, 217, 226, 234, 242, 250, 11, 41,
251 74, 103, 128, 151, 172, 191, 209, 225, 241, 255, 9, 43, 79, 110, 138,
252 163, 186, 207, 227, 246, 12, 39, 71, 99, 123, 144, 164, 182, 198, 214,
253 228, 241, 253, 9, 44, 81, 113, 142, 168, 192, 214, 235, 255, 7, 49,
254 90, 127, 160, 191, 220, 247, 6, 51, 95, 134, 170, 203, 234, 7, 47,
255 87, 123, 155, 184, 212, 237, 6, 52, 97, 137, 174, 208, 240, 5, 57,
256 106, 151, 192, 231, 5, 59, 111, 158, 202, 243, 5, 55, 103, 147, 187,
257 224, 5, 60, 113, 161, 206, 248, 4, 65, 122, 175, 224, 4, 67, 127,
262 -1, -1, -1, -1, -1, -1, -1, -1, 0, 0, 0, 0, 41, 41, 41,
263 82, 82, 123, 164, 200, 222, 0, 0, 0, 0, 0, 0, 0, 0, 41,
264 41, 41, 41, 123, 123, 123, 164, 164, 240, 266, 283, 295, 41, 41, 41,
265 41, 41, 41, 41, 41, 123, 123, 123, 123, 240, 240, 240, 266, 266, 305,
266 318, 328, 336, 123, 123, 123, 123, 123, 123, 123, 123, 240, 240, 240, 240,
267 305, 305, 305, 318, 318, 343, 351, 358, 364, 240, 240, 240, 240, 240, 240,
268 240, 240, 305, 305, 305, 305, 343, 343, 343, 351, 351, 370, 376, 382, 387,
272 0, 8, 13, 16, 19, 21, 23, 24, 26, 27, 28, 29, 30, 31, 32, 32, 33, 34, 34, 35, 36, 36, 37, 37
276 0, 1, 1, 1, 2, 3, 3, 3, 2, 3, 3, 3, 2, 3, 3, 3
280 0x00, 0x03, 0x0C, 0x0F, 0x30, 0x33, 0x3C, 0x3F,
281 0xC0, 0xC3, 0xCC, 0xCF, 0xF0, 0xF3, 0xFC, 0xFF
287 7, 0, 4, 3, 6, 1, 5, 2,
288 15, 0, 8, 7, 12, 3, 11, 4, 14, 1, 9, 6, 13, 2, 10, 5
292 16384, 17866, 19483, 21247, 23170, 25267, 27554, 30048
297 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
298 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
299 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
300 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
301 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
302 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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, 0, 0, 0, 0, 0,
305 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
306 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
307 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
308 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 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, 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, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
311 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
313 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, 37, 39, 41,
314 43, 45, 47, 49, 51, 53, 55, 57, 59, 61, 63, 65, 67, 69, 71, 73, 75, 77, 79,
315 81, 83, 85, 87, 89, 91, 93, 95, 97, 99, 101, 103, 105, 107, 109, 111, 113,
316 115, 117, 119, 121, 123, 125, 127, 129, 131, 133, 135, 137, 139, 141, 143,
317 145, 147, 149, 151, 153, 155, 157, 159, 161, 163, 165, 167, 169, 171, 173,
318 175, 177, 179, 181, 183, 185, 187, 189, 191, 193, 195, 197, 199, 201, 203,
319 205, 207, 209, 211, 213, 215, 217, 219, 221, 223, 225, 227, 229, 231, 233,
320 235, 237, 239, 241, 243, 245, 247, 249, 251, 253, 255, 257, 259, 261, 263,
321 265, 267, 269, 271, 273, 275, 277, 279, 281, 283, 285, 287, 289, 291, 293,
322 295, 297, 299, 301, 303, 305, 307, 309, 311, 313, 315, 317, 319, 321, 323,
323 325, 327, 329, 331, 333, 335, 337, 339, 341, 343, 345, 347, 349, 351,
325 13, 25, 41, 61, 85, 113, 145, 181, 221, 265, 313, 365, 421, 481, 545, 613,
326 685, 761, 841, 925, 1013, 1105, 1201, 1301, 1405, 1513, 1625, 1741, 1861,
327 1985, 2113, 2245, 2381, 2521, 2665, 2813, 2965, 3121, 3281, 3445, 3613, 3785,
328 3961, 4141, 4325, 4513, 4705, 4901, 5101, 5305, 5513, 5725, 5941, 6161, 6385,
329 6613, 6845, 7081, 7321, 7565, 7813, 8065, 8321, 8581, 8845, 9113, 9385, 9661,
330 9941, 10225, 10513, 10805, 11101, 11401, 11705, 12013, 12325, 12641, 12961,
331 13285, 13613, 13945, 14281, 14621, 14965, 15313, 15665, 16021, 16381, 16745,
332 17113, 17485, 17861, 18241, 18625, 19013, 19405, 19801, 20201, 20605, 21013,
333 21425, 21841, 22261, 22685, 23113, 23545, 23981, 24421, 24865, 25313, 25765,
334 26221, 26681, 27145, 27613, 28085, 28561, 29041, 29525, 30013, 30505, 31001,
335 31501, 32005, 32513, 33025, 33541, 34061, 34585, 35113, 35645, 36181, 36721,
336 37265, 37813, 38365, 38921, 39481, 40045, 40613, 41185, 41761, 42341, 42925,
337 43513, 44105, 44701, 45301, 45905, 46513, 47125, 47741, 48361, 48985, 49613,
338 50245, 50881, 51521, 52165, 52813, 53465, 54121, 54781, 55445, 56113, 56785,
339 57461, 58141, 58825, 59513, 60205, 60901, 61601,
341 63, 129, 231, 377, 575, 833, 1159, 1561, 2047, 2625, 3303, 4089, 4991, 6017,
342 7175, 8473, 9919, 11521, 13287, 15225, 17343, 19649, 22151, 24857, 27775,
343 30913, 34279, 37881, 41727, 45825, 50183, 54809, 59711, 64897, 70375, 76153,
344 82239, 88641, 95367, 102425, 109823, 117569, 125671, 134137, 142975, 152193,
345 161799, 171801, 182207, 193025, 204263, 215929, 228031, 240577, 253575,
346 267033, 280959, 295361, 310247, 325625, 341503, 357889, 374791, 392217,
347 410175, 428673, 447719, 467321, 487487, 508225, 529543, 551449, 573951,
348 597057, 620775, 645113, 670079, 695681, 721927, 748825, 776383, 804609,
349 833511, 863097, 893375, 924353, 956039, 988441, 1021567, 1055425, 1090023,
350 1125369, 1161471, 1198337, 1235975, 1274393, 1313599, 1353601, 1394407,
351 1436025, 1478463, 1521729, 1565831, 1610777, 1656575, 1703233, 1750759,
352 1799161, 1848447, 1898625, 1949703, 2001689, 2054591, 2108417, 2163175,
353 2218873, 2275519, 2333121, 2391687, 2451225, 2511743, 2573249, 2635751,
354 2699257, 2763775, 2829313, 2895879, 2963481, 3032127, 3101825, 3172583,
355 3244409, 3317311, 3391297, 3466375, 3542553, 3619839, 3698241, 3777767,
356 3858425, 3940223, 4023169, 4107271, 4192537, 4278975, 4366593, 4455399,
357 4545401, 4636607, 4729025, 4822663, 4917529, 5013631, 5110977, 5209575,
358 5309433, 5410559, 5512961, 5616647, 5721625, 5827903, 5935489, 6044391,
359 6154617, 6266175, 6379073, 6493319, 6608921, 6725887, 6844225, 6963943,
362 321, 681, 1289, 2241, 3649, 5641, 8361, 11969, 16641, 22569, 29961, 39041,
363 50049, 63241, 78889, 97281, 118721, 143529, 172041, 204609, 241601, 283401,
364 330409, 383041, 441729, 506921, 579081, 658689, 746241, 842249, 947241,
365 1061761, 1186369, 1321641, 1468169, 1626561, 1797441, 1981449, 2179241,
366 2391489, 2618881, 2862121, 3121929, 3399041, 3694209, 4008201, 4341801,
367 4695809, 5071041, 5468329, 5888521, 6332481, 6801089, 7295241, 7815849,
368 8363841, 8940161, 9545769, 10181641, 10848769, 11548161, 12280841, 13047849,
369 13850241, 14689089, 15565481, 16480521, 17435329, 18431041, 19468809,
370 20549801, 21675201, 22846209, 24064041, 25329929, 26645121, 28010881,
371 29428489, 30899241, 32424449, 34005441, 35643561, 37340169, 39096641,
372 40914369, 42794761, 44739241, 46749249, 48826241, 50971689, 53187081,
373 55473921, 57833729, 60268041, 62778409, 65366401, 68033601, 70781609,
374 73612041, 76526529, 79526721, 82614281, 85790889, 89058241, 92418049,
375 95872041, 99421961, 103069569, 106816641, 110664969, 114616361, 118672641,
376 122835649, 127107241, 131489289, 135983681, 140592321, 145317129, 150160041,
377 155123009, 160208001, 165417001, 170752009, 176215041, 181808129, 187533321,
378 193392681, 199388289, 205522241, 211796649, 218213641, 224775361, 231483969,
379 238341641, 245350569, 252512961, 259831041, 267307049, 274943241, 282741889,
380 290705281, 298835721, 307135529, 315607041, 324252609, 333074601, 342075401,
381 351257409, 360623041, 370174729, 379914921, 389846081, 399970689, 410291241,
382 420810249, 431530241, 442453761, 453583369, 464921641, 476471169, 488234561,
383 500214441, 512413449, 524834241, 537479489, 550351881, 563454121, 576788929,
384 590359041, 604167209, 618216201, 632508801,
387 1683, 3653, 7183, 13073, 22363, 36365, 56695, 85305, 124515, 177045, 246047,
388 335137, 448427, 590557, 766727, 982729, 1244979, 1560549, 1937199, 2383409,
389 2908411, 3522221, 4235671, 5060441, 6009091, 7095093, 8332863, 9737793,
390 11326283, 13115773, 15124775, 17372905, 19880915, 22670725, 25765455,
391 29189457, 32968347, 37129037, 41699767, 46710137, 52191139, 58175189,
392 64696159, 71789409, 79491819, 87841821, 96879431, 106646281, 117185651,
393 128542501, 140763503, 153897073, 167993403, 183104493, 199284183, 216588185,
394 235074115, 254801525, 275831935, 298228865, 322057867, 347386557, 374284647,
395 402823977, 433078547, 465124549, 499040399, 534906769, 572806619, 612825229,
396 655050231, 699571641, 746481891, 795875861, 847850911, 902506913, 959946283,
397 1020274013, 1083597703, 1150027593, 1219676595, 1292660325, 1369097135,
398 1449108145, 1532817275, 1620351277, 1711839767, 1807415257, 1907213187,
399 2011371957, 2120032959,
402 8989, 19825, 40081, 75517, 134245, 227305, 369305, 579125, 880685, 1303777,
403 1884961, 2668525, 3707509, 5064793, 6814249, 9041957, 11847485, 15345233,
404 19665841, 24957661, 31388293, 39146185, 48442297, 59511829, 72616013,
405 88043969, 106114625, 127178701, 151620757, 179861305, 212358985, 249612805,
406 292164445, 340600625, 395555537, 457713341, 527810725, 606639529, 695049433,
407 793950709, 904317037, 1027188385, 1163673953, 1314955181, 1482288821,
408 1667010073, 1870535785, 2094367717,
411 48639, 108545, 224143, 433905, 795455, 1392065, 2340495, 3800305, 5984767,
412 9173505, 13726991, 20103025, 28875327, 40754369, 56610575, 77500017,
413 104692735, 139703809, 184327311, 240673265, 311207743, 398796225, 506750351,
414 638878193, 799538175, 993696769, 1226990095, 1505789553, 1837271615,
418 265729, 598417, 1256465, 2485825, 4673345, 8405905, 14546705, 24331777,
419 39490049, 62390545, 96220561, 145198913, 214828609, 312193553, 446304145,
420 628496897, 872893441, 1196924561, 1621925137, 2173806145,
422 1462563, 3317445, 7059735, 14218905, 27298155, 50250765, 89129247, 152951073,
423 254831667, 413442773, 654862247, 1014889769, 1541911931, 2300409629,
427 8097453, 18474633, 39753273, 81270333, 158819253, 298199265, 540279585,
428 948062325, 1616336765,
430 45046719, 103274625, 224298231, 464387817, 921406335, 1759885185,
433 251595969, 579168825, 1267854873, 2653649025,
439 6.7286966e-05f, 0.00060551348f, 0.0016815970f, 0.0032947962f, 0.0054439943f,
440 0.0081276923f, 0.011344001f, 0.015090633f, 0.019364886f, 0.024163635f,
441 0.029483315f, 0.035319905f, 0.041668911f, 0.048525347f, 0.055883718f,
442 0.063737999f, 0.072081616f, 0.080907428f, 0.090207705f, 0.099974111f,
443 0.11019769f, 0.12086883f, 0.13197729f, 0.14351214f, 0.15546177f,
444 0.16781389f, 0.18055550f, 0.19367290f, 0.20715171f, 0.22097682f,
445 0.23513243f, 0.24960208f, 0.26436860f, 0.27941419f, 0.29472040f,
446 0.31026818f, 0.32603788f, 0.34200931f, 0.35816177f, 0.37447407f,
447 0.39092462f, 0.40749142f, 0.42415215f, 0.44088423f, 0.45766484f,
448 0.47447104f, 0.49127978f, 0.50806798f, 0.52481261f, 0.54149077f,
449 0.55807973f, 0.57455701f, 0.59090049f, 0.60708841f, 0.62309951f,
450 0.63891306f, 0.65450896f, 0.66986776f, 0.68497077f, 0.69980010f,
451 0.71433873f, 0.72857055f, 0.74248043f, 0.75605424f, 0.76927895f,
452 0.78214257f, 0.79463430f, 0.80674445f, 0.81846456f, 0.82978733f,
453 0.84070669f, 0.85121779f, 0.86131698f, 0.87100183f, 0.88027111f,
454 0.88912479f, 0.89756398f, 0.90559094f, 0.91320904f, 0.92042270f,
455 0.92723738f, 0.93365955f, 0.93969656f, 0.94535671f, 0.95064907f,
456 0.95558353f, 0.96017067f, 0.96442171f, 0.96834849f, 0.97196334f,
457 0.97527906f, 0.97830883f, 0.98106616f, 0.98356480f, 0.98581869f,
458 0.98784191f, 0.98964856f, 0.99125274f, 0.99266849f, 0.99390969f,
459 0.99499004f, 0.99592297f, 0.99672162f, 0.99739874f, 0.99796667f,
460 0.99843728f, 0.99882195f, 0.99913147f, 0.99937606f, 0.99956527f,
461 0.99970802f, 0.99981248f, 0.99988613f, 0.99993565f, 0.99996697f,
462 0.99998518f, 0.99999457f, 0.99999859f, 0.99999982f, 1.0000000f,
467 4.5275357e-09f, 3.66647e-07f, 2.82777e-06f, 1.08557e-05f, 2.96371e-05f, 6.60594e-05f,
468 0.000128686f, 0.000227727f, 0.000374999f, 0.000583881f, 0.000869266f, 0.0012475f,
469 0.0017363f, 0.00235471f, 0.00312299f, 0.00406253f, 0.00519576f, 0.00654601f,
470 0.00813743f, 0.00999482f, 0.0121435f, 0.0146093f, 0.017418f, 0.0205957f, 0.0241684f,
471 0.0281615f, 0.0326003f, 0.0375092f, 0.0429118f, 0.0488308f, 0.0552873f, 0.0623012f,
472 0.0698908f, 0.0780723f, 0.0868601f, 0.0962664f, 0.106301f, 0.11697f, 0.12828f,
473 0.140231f, 0.152822f, 0.166049f, 0.179905f, 0.194379f, 0.209457f, 0.225123f, 0.241356f,
474 0.258133f, 0.275428f, 0.293212f, 0.311453f, 0.330116f, 0.349163f, 0.368556f, 0.388253f,
475 0.40821f, 0.428382f, 0.448723f, 0.469185f, 0.48972f, 0.51028f, 0.530815f, 0.551277f,
476 0.571618f, 0.59179f, 0.611747f, 0.631444f, 0.650837f, 0.669884f, 0.688547f, 0.706788f,
477 0.724572f, 0.741867f, 0.758644f, 0.774877f, 0.790543f, 0.805621f, 0.820095f, 0.833951f,
478 0.847178f, 0.859769f, 0.87172f, 0.88303f, 0.893699f, 0.903734f, 0.91314f, 0.921928f,
479 0.930109f, 0.937699f, 0.944713f, 0.951169f, 0.957088f, 0.962491f, 0.9674f, 0.971838f,
480 0.975832f, 0.979404f, 0.982582f, 0.985391f, 0.987857f, 0.990005f, 0.991863f, 0.993454f,
481 0.994804f, 0.995937f, 0.996877f, 0.997645f, 0.998264f, 0.998753f, 0.999131f, 0.999416f,
482 0.999625f, 0.999772f, 0.999871f, 0.999934f, 0.99997f, 0.999989f, 0.999997f, 0.99999964f, 1.0f,
487 celt_pvq_u + 525, celt_pvq_u + 698, celt_pvq_u + 870,
488 celt_pvq_u + 1041, celt_pvq_u + 1131, celt_pvq_u + 1178,
489 celt_pvq_u + 1207, celt_pvq_u + 1226, celt_pvq_u + 1240,
490 celt_pvq_u + 1248, celt_pvq_u + 1254, celt_pvq_u + 1257
495 x = (
MUL16(x, x) + 4096) >> 13;
507 return (ls << 11) - (lc << 11) +
514 s->
seed = 1664525 * s->
seed + 1013904223;
531 beta = 1.0f - 4915.0f/32768.0f;
545 if (i < s->startband || i >= s->
endband) {
551 if (available >= 15) {
553 int k =
FFMIN(i, 20) << 1;
555 }
else if (available >= 2) {
557 value = (x>>1) ^ -(x&1);
558 }
else if (available >= 1) {
563 prev[j] += beta *
value;
571 for (i = s->
startband; i < s->endband; i++) {
581 offset = (q2 + 0.5f) * (1 << (14 - s->
fine_bits[i])) / 16384.0f - 0.5f;
592 for (priority = 0; priority < 2; priority++) {
601 offset = (q2 - 0.5f) * (1 << (14 - s->
fine_bits[i] - 1)) / 16384.0f;
612 int i, diff = 0, tf_select = 0, tf_changed = 0, tf_select_bit;
613 int consumed,
bits =
transient ? 2 : 4;
618 for (i = s->
startband; i < s->endband; i++) {
619 if (consumed+bits+tf_select_bit <= s->framebits) {
625 bits =
transient ? 4 : 5;
632 for (i = s->
startband; i < s->endband; i++) {
653 int intensitystereo_bit = 0;
654 int dualstereo_bit = 0;
656 int remaining, bandbits;
657 int low, high, total, done;
678 for (i = s->
startband; i < s->endband; i++) {
679 int quanta, band_dynalloc;
684 quanta =
FFMIN(quanta << 3,
FFMAX(6 << 3, quanta));
685 band_dynalloc = dynalloc;
686 while (consumed + (band_dynalloc<<3) < totalbits && boost[i] < cap[i]) {
698 dynalloc =
FFMAX(2, dynalloc - 1);
702 if (consumed + (6 << 3) <= totalbits)
709 totalbits >= ((s->
duration + 2) << 3))
714 if (totalbits >= 1 << 3)
716 totalbits -= skip_bit;
721 if (intensitystereo_bit <= totalbits) {
722 totalbits -= intensitystereo_bit;
723 if (totalbits >= 1 << 3) {
724 dualstereo_bit = 1 << 3;
728 intensitystereo_bit = 0;
731 for (i = s->
startband; i < s->endband; i++) {
732 int trim = alloctrim - 5 - s->
duration;
742 trim_offset[i] = trim * (band << scale) >> 6;
751 while (low <= high) {
752 int center = (low + high) >> 1;
760 bandbits =
FFMAX(0, bandbits + trim_offset[i]);
761 bandbits += boost[i];
763 if (bandbits >= threshold[i] || done) {
765 total +=
FFMIN(bandbits, cap[i]);
770 if (total > totalbits)
777 for (i = s->
startband; i < s->endband; i++) {
785 bits1[i] =
FFMAX(0, bits1[i] + trim_offset[i]);
787 bits2[i] =
FFMAX(0, bits2[i] + trim_offset[i]);
789 bits1[i] += boost[i];
790 bits2[i] += boost[i];
794 bits2[i] =
FFMAX(0, bits2[i] - bits1[i]);
801 int center = (low + high) >> 1;
807 if (bandbits >= threshold[j] || done) {
809 total +=
FFMIN(bandbits, cap[j]);
813 if (total > totalbits)
823 if (bandbits >= threshold[i] || done)
829 bandbits =
FFMIN(bandbits, cap[i]);
839 if (j == skip_startband) {
841 totalbits += skip_bit;
846 remaining = totalbits - total;
859 allocation -= 1 << 3;
864 if (intensitystereo_bit) {
865 total -= intensitystereo_bit;
867 total += intensitystereo_bit;
877 if (intensitystereo_bit)
881 totalbits += dualstereo_bit;
882 else if (dualstereo_bit)
886 remaining = totalbits - total;
889 for (i = s->
startband; i < s->codedbands; i++) {
896 for (i = s->
startband; i < s->codedbands; i++) {
898 int prev_extra = extrabits;
899 s->
pulses[i] += extrabits;
907 int fine_bits, max_bits;
910 s->
pulses[i] -= extrabits;
921 if (s->
pulses[i] + offset < 2 * (dof << 3))
923 else if (s->
pulses[i] + offset < 3 * (dof << 3))
926 fine_bits = (s->
pulses[i] + offset + (dof << 2)) / (dof << 3);
930 max_bits =
FFMAX(max_bits, 0);
932 s->
fine_bits[i] = av_clip(fine_bits, 0, max_bits);
943 s->
pulses[i] -= extrabits;
956 extrabits -= fineextra;
972 int i, low = 0, high;
977 for (i = 0; i < 6; i++) {
978 int center = (low + high + 1) >> 1;
979 if (cache[center] >= bits)
985 return (bits - (low == 0 ? -1 : cache[low]) <= cache[high] -
bits) ? low : high;
991 return (pulses == 0) ? 0 : cache[
pulses] + 1;
998 for (i = 0; i <
N; i++)
1009 for (i = 0; i < len - stride; i++) {
1013 Xptr[stride] = c * x2 + s * x1;
1014 *Xptr++ = c * x1 - s * x2;
1017 Xptr = &X[len - 2 * stride - 1];
1018 for (i = len - 2 * stride - 1; i >= 0; i--) {
1022 Xptr[stride] = c * x2 + s * x1;
1023 *Xptr-- = c * x1 - s * x2;
1028 unsigned int stride,
unsigned int K,
1031 unsigned int stride2 = 0;
1039 gain = (float)len / (len + (20 - 5*spread) * K);
1040 theta =
M_PI * gain * gain / 4;
1045 if (len >= stride << 3) {
1049 while ((stride2 * stride2 + stride2) * stride + (stride >> 2) < len)
1056 for (i = 0; i < stride; i++) {
1067 unsigned int collapse_mask;
1078 for (i = 0; i <
B; i++)
1079 for (j = 0; j <
N0; j++)
1080 collapse_mask |= (iy[i*N0+j]!=0)<<i;
1081 return collapse_mask;
1088 for (i = 0; i <
N; i++)
1090 g = gain / sqrtf(g);
1092 for (i = 0; i <
N; i++)
1099 float xp = 0, side = 0;
1105 for (i = 0; i <
N; i++) {
1107 side += Y[i] * Y[i];
1113 E[0] = mid2 * mid2 + side - 2 * xp;
1114 E[1] = mid2 * mid2 + side + 2 * xp;
1115 if (E[0] < 6e-4f || E[1] < 6e-4f) {
1116 for (i = 0; i <
N; i++)
1122 gain[0] = 1.0f / sqrtf(t);
1124 gain[1] = 1.0f / sqrtf(t);
1126 for (i = 0; i <
N; i++) {
1129 value[0] = mid * X[i];
1131 X[i] = gain[0] * (value[0] - value[1]);
1132 Y[i] = gain[1] * (value[0] + value[1]);
1137 int stride,
int hadamard)
1144 for (i = 0; i < stride; i++)
1145 for (j = 0; j <
N0; j++)
1146 tmp[j*stride+i] = X[ordery[i]*N0+j];
1148 for (i = 0; i < stride; i++)
1149 for (j = 0; j <
N0; j++)
1150 tmp[j*stride+i] = X[i*N0+j];
1153 for (i = 0; i <
N; i++)
1158 int stride,
int hadamard)
1165 for (i = 0; i < stride; i++)
1166 for (j = 0; j <
N0; j++)
1167 tmp[ordery[i]*N0+j] = X[j*stride+i];
1169 for (i = 0; i < stride; i++)
1170 for (j = 0; j <
N0; j++)
1171 tmp[i*N0+j] = X[j*stride+i];
1174 for (i = 0; i <
N; i++)
1182 for (i = 0; i < stride; i++) {
1183 for (j = 0; j <
N0; j++) {
1184 float x0 = X[stride * (2 * j + 0) + i];
1185 float x1 = X[stride * (2 * j + 1) + i];
1186 X[stride * (2 * j + 0) + i] = (x0 + x1) *
M_SQRT1_2;
1187 X[stride * (2 * j + 1) + i] = (x0 - x1) *
M_SQRT1_2;
1197 if (dualstereo && N == 2)
1203 qb =
FFMIN3(b - pulse_cap - (4 << 3), (b + N2 * offset) / N2, 8 << 3);
1204 qn = (qb < (1 << 3 >> 1)) ? 1 : ((
celt_qn_exp2[qb & 0x7] >> (14 - (qb >> 3))) + 1) >> 1 << 1;
1209 static inline uint64_t
celt_cwrsi(
unsigned int N,
unsigned int K,
unsigned int i,
int *
y)
1237 for (p = row[K]; p > i; p = row[K])
1241 val = (k0 - K +
s) ^ s;
1249 if (p <= i && i < q) {
1263 val = (k0 - K +
s) ^ s;
1281 val = (k0 - K +
s) ^ s;
1297 #define CELT_PVQ_U(n, k) (celt_pvq_u_row[FFMIN(n, k)][FFMAX(n, k)])
1298 #define CELT_PVQ_V(n, k) (CELT_PVQ_U(n, k) + CELT_PVQ_U(n, (k) + 1))
1306 unsigned int N,
unsigned int K,
1308 unsigned int blocks,
float gain)
1319 const int band,
float *X,
float *
Y,
1320 int N,
int b,
unsigned int blocks,
1322 float *lowband_out,
int level,
1323 float gain,
float *lowband_scratch,
1327 int dualstereo,
split;
1328 int imid = 0, iside = 0;
1329 unsigned int N0 =
N;
1333 int time_divide = 0;
1336 float mid = 0, side = 0;
1337 int longblocks = (B0 == 1);
1338 unsigned int cm = 0;
1340 N_B0 = N_B = N / blocks;
1341 split = dualstereo = (Y != NULL);
1347 for (i = 0; i <= dualstereo; i++) {
1354 x[0] = sign ? -1.0f : 1.0f;
1358 lowband_out[0] = X[0];
1362 if (!dualstereo && level == 0) {
1366 recombine = tf_change;
1370 (recombine || ((N_B & 1) == 0 && tf_change < 0) || B0 > 1)) {
1372 for (j = 0; j <
N; j++)
1373 lowband_scratch[j] = lowband[j];
1374 lowband = lowband_scratch;
1377 for (k = 0; k < recombine; k++) {
1382 blocks >>= recombine;
1386 while ((N_B & 1) == 0 && tf_change < 0) {
1389 fill |= fill << blocks;
1399 if (B0 > 1 && lowband)
1401 B0 << recombine, longblocks);
1407 if (!dualstereo && duration >= 0 && b > cache[cache[0]] + 12 && N > 2) {
1413 fill = (fill & 1) | (fill << 1);
1414 blocks = (blocks + 1) >> 1;
1420 int mbits, sbits,
delta;
1437 if (dualstereo && N > 2)
1439 else if (dualstereo || B0 > 1)
1443 itheta = itheta * 16384 / qn;
1446 }
else if (dualstereo) {
1457 fill &= (1 << blocks) - 1;
1459 }
else if (itheta == 16384) {
1462 fill &= ((1 << blocks) - 1) << blocks;
1472 mid = imid / 32768.0f;
1473 side = iside / 32768.0f;
1478 if (N == 2 && dualstereo) {
1485 sbits = (itheta != 0 && itheta != 16384) ? 1 << 3 : 0;
1487 c = (itheta > 8192);
1494 sign = 1 - 2 * sign;
1498 lowband, duration, lowband_out, level, gain,
1499 lowband_scratch, orig_fill);
1502 y2[0] = -sign * x2[1];
1503 y2[1] = sign * x2[0];
1516 float *next_lowband2 = NULL;
1517 float *next_lowband_out1 = NULL;
1523 if (B0 > 1 && !dualstereo && (itheta & 0x3fff)) {
1530 delta =
FFMIN(0, delta + (N << 3 >> (5 - duration)));
1532 mbits = av_clip((b - delta) / 2, 0, b);
1536 if (lowband && !dualstereo)
1537 next_lowband2 = lowband +
N;
1542 next_lowband_out1 = lowband_out;
1544 next_level = level + 1;
1547 if (mbits >= sbits) {
1551 lowband, duration, next_lowband_out1,
1552 next_level, dualstereo ? 1.0f : (gain * mid),
1553 lowband_scratch, fill);
1555 rebalance = mbits - (rebalance - s->
remaining2);
1556 if (rebalance > 3 << 3 && itheta != 0)
1557 sbits += rebalance - (3 << 3);
1562 next_lowband2, duration, NULL,
1563 next_level, gain * side, NULL,
1564 fill >> blocks) << ((B0 >> 1) & (dualstereo - 1));
1569 next_lowband2, duration, NULL,
1570 next_level, gain * side, NULL,
1571 fill >> blocks) << ((B0 >> 1) & (dualstereo - 1));
1573 rebalance = sbits - (rebalance - s->
remaining2);
1574 if (rebalance > 3 << 3 && itheta != 16384)
1575 mbits += rebalance - (3 << 3);
1580 lowband, duration, next_lowband_out1,
1581 next_level, dualstereo ? 1.0f : (gain * mid),
1582 lowband_scratch, fill);
1600 cm =
celt_alg_unquant(rc, X, N, (q < 8) ? q : (8 + (q & 7)) << ((q >> 3) - 1),
1601 s->
spread, blocks, gain);
1605 unsigned int cm_mask = (1 << blocks) - 1;
1608 for (j = 0; j <
N; j++)
1613 for (j = 0; j <
N; j++)
1618 for (j = 0; j <
N; j++) {
1620 X[j] = lowband[j] + (((
celt_rng(s)) & 0x8000) ? 1.0f / 256 : -1.0f / 256);
1635 for (j = 0; j <
N; j++)
1638 }
else if (level == 0) {
1644 B0<<recombine, longblocks);
1649 for (k = 0; k < time_divide; k++) {
1656 for (k = 0; k < recombine; k++) {
1660 blocks <<= recombine;
1665 float n = sqrtf(N0);
1666 for (j = 0; j <
N0; j++)
1667 lowband_out[j] = n * X[j];
1669 cm &= (1 << blocks) - 1;
1678 for (i = s->
startband; i < s->endband; i++) {
1692 float g00, g01, g02;
1693 float g10, g11, g12;
1695 float x0, x1, x2, x3, x4;
1717 x0 = data[i - T1 + 2];
1719 data[i] += (1.0 - w) * g00 * data[i - T0] +
1720 (1.0 - w) * g01 * (data[i - T0 - 1] + data[i - T0 + 1]) +
1721 (1.0 - w) * g02 * (data[i - T0 - 2] + data[i - T0 + 2]) +
1723 w * g11 * (x1 + x3) +
1724 w * g12 * (x0 + x4);
1737 float x0, x1, x2, x3, x4;
1740 if (frame->
pf_gains[0] == 0.0 || len <= 0)
1752 for (i = 0; i <
len; i++) {
1753 x0 = data[i - T + 2];
1754 data[i] += g0 * x2 +
1790 static const float postfilter_taps[3][3] = {
1791 { 0.3066406250f, 0.2170410156f, 0.1296386719f },
1792 { 0.4638671875f, 0.2680664062f, 0.0 },
1793 { 0.7998046875f, 0.1000976562f, 0.0 }
1802 if (has_postfilter) {
1804 int tapset, octave, period;
1812 for (i = 0; i < 2; i++) {
1816 frame->
pf_gains_new[0] = gain * postfilter_taps[tapset][0];
1817 frame->
pf_gains_new[1] = gain * postfilter_taps[tapset][1];
1818 frame->
pf_gains_new[2] = gain * postfilter_taps[tapset][2];
1832 for (i = s->
startband; i < s->endband; i++) {
1833 int renormalize = 0;
1837 float thresh, sqrt_1;
1842 thresh = pow(2, -1.0 - 0.125f * depth);
1855 Ediff = frame->
energy[i] -
FFMIN(prev[0], prev[1]);
1856 Ediff =
FFMAX(0, Ediff);
1860 r = pow(2, 1 - Ediff);
1863 r =
FFMIN(thresh, r) * sqrt_1;
1864 for (k = 0; k < 1 << s->
duration; k++) {
1882 float lowband_scratch[8 * 22];
1883 float norm[2 * 8 * 100];
1887 int update_lowband = 1;
1888 int lowband_offset = 0;
1894 for (i = s->
startband; i < s->endband; i++) {
1897 float *X = s->
coeffs[0] + band_offset;
1901 float *norm2 = norm + 8 * 100;
1902 int effective_lowband = -1;
1910 if (i <= s->codedbands - 1) {
1917 (update_lowband || lowband_offset == 0))
1924 int foldstart, foldend;
1929 foldstart = lowband_offset;
1931 foldend = lowband_offset - 1;
1935 for (j = foldstart; j < foldend; j++) {
1942 cm[0] = cm[1] = (1 << s->
blocks) - 1;
1948 norm[j] = (norm[j] + norm2[j]) / 2;
1953 effective_lowband != -1 ? norm + (effective_lowband << s->
duration) : NULL, s->
duration,
1954 norm + band_offset, 0, 1.0f, lowband_scratch, cm[0]);
1957 effective_lowband != -1 ? norm2 + (effective_lowband << s->
duration) : NULL, s->
duration,
1958 norm2 + band_offset, 0, 1.0f, lowband_scratch, cm[1]);
1961 effective_lowband != -1 ? norm + (effective_lowband << s->
duration) : NULL, s->
duration,
1962 norm + band_offset, 0, 1.0f, lowband_scratch, cm[0]|cm[1]);
1972 update_lowband = (b > band_size << 3);
1977 float **output,
int coded_channels,
int frame_size,
1978 int startband,
int endband)
1985 int anticollapse = 0;
1987 float imdct_scale = 1.0;
1989 if (coded_channels != 1 && coded_channels != 2) {
1994 if (startband < 0 || startband > endband || endband >
CELT_MAX_BANDS) {
1996 startband, endband);
2025 else if (consumed == 1)
2046 if (coded_channels == 1) {
2078 memcpy(s->
coeffs[1], s->
coeffs[0], frame_size *
sizeof(
float));
2081 for (i = 0; i < 2; i++) {
2096 for (j = 0; j < s->
blocks; j++) {
2110 float tmp = frame->
buf[1024 - frame_size + j] +
m;
2112 output[i][j] = tmp / 32768.;
2117 if (coded_channels == 1)
2120 for (i = 0; i < 2; i++ ) {
2153 for (i = 0; i < 2; i++) {
2160 memset(frame->
buf, 0,
sizeof(frame->
buf));
2192 if (output_channels != 1 && output_channels != 2) {