v / vlib / math / factorial_tables.v
709 lines · 708 sloc · 13.31 KB · f09826e928f9612bab9299faefff7cf34a503362
Raw
1module math
2
3const log_sqrt_2pi = 9.18938533204672741780329736e-1
4const bernoulli = [
5 /*
6 Bernoulli numbers B(2),B(4),B(6),...,B(20). Only B(2),...,B(10) currently
7 * used.
8 */
9 1.0 / (6.0 * 2.0 * 1.0),
10 -1.0 / (30.0 * 4.0 * 3.0),
11 1.0 / (42.0 * 6.0 * 5.0),
12 -1.0 / (30.0 * 8.0 * 7.0),
13 5.0 / (66.0 * 10.0 * 9.0),
14 -691.0 / (2730.0 * 12.0 * 11.0),
15 7.0 / (6.0 * 14.0 * 13.0),
16 -3617.0 / (510.0 * 16.0 * 15.0),
17 43867.0 / (796.0 * 18.0 * 17.0),
18 -174611.0 / (330.0 * 20.0 * 19.0),
19]
20const factorials_table = [
21 // 0!
22 1.000000000000000000000e+0,
23 // 1!
24 1.000000000000000000000e+0,
25 // 2!
26 2.000000000000000000000e+0,
27 // 3!
28 6.000000000000000000000e+0,
29 // 4!
30 2.400000000000000000000e+1,
31 // 5!
32 1.200000000000000000000e+2,
33 // 6!
34 7.200000000000000000000e+2,
35 // 7!
36 5.040000000000000000000e+3,
37 // 8!
38 4.032000000000000000000e+4,
39 // 9!
40 3.628800000000000000000e+5,
41 // 10!
42 3.628800000000000000000e+6,
43 // 11!
44 3.991680000000000000000e+7,
45 // 12!
46 4.790016000000000000000e+8,
47 // 13!
48 6.227020800000000000000e+9,
49 // 14!
50 8.717829120000000000000e+10,
51 // 15!
52 1.307674368000000000000e+12,
53 // 16!
54 2.092278988800000000000e+13,
55 // 17!
56 3.556874280960000000000e+14,
57 // 18!
58 6.402373705728000000000e+15,
59 // 19!
60 1.216451004088320000000e+17,
61 // 20!
62 2.432902008176640000000e+18,
63 // 21!
64 5.109094217170944000000e+19,
65 // 22!
66 1.124000727777607680000e+21,
67 // 23!
68 2.585201673888497664000e+22,
69 // 24!
70 6.204484017332394393600e+23,
71 // 25!
72 1.551121004333098598400e+25,
73 // 26!
74 4.032914611266056355840e+26,
75 // 27!
76 1.088886945041835216077e+28,
77 // 28!
78 3.048883446117138605015e+29,
79 // 29!
80 8.841761993739701954544e+30,
81 // 30!
82 2.652528598121910586363e+32,
83 // 31!
84 8.222838654177922817726e+33,
85 // 32!
86 2.631308369336935301672e+35,
87 // 33!
88 8.683317618811886495518e+36,
89 // 34!
90 2.952327990396041408476e+38,
91 // 35!
92 1.033314796638614492967e+40,
93 // 36!
94 3.719933267899012174680e+41,
95 // 37!
96 1.376375309122634504632e+43,
97 // 38!
98 5.230226174666011117600e+44,
99 // 39!
100 2.039788208119744335864e+46,
101 // 40!
102 8.159152832478977343456e+47,
103 // 41!
104 3.345252661316380710817e+49,
105 // 42!
106 1.405006117752879898543e+51,
107 // 43!
108 6.041526306337383563736e+52,
109 // 44!
110 2.658271574788448768044e+54,
111 // 45!
112 1.196222208654801945620e+56,
113 // 46!
114 5.502622159812088949850e+57,
115 // 47!
116 2.586232415111681806430e+59,
117 // 48!
118 1.241391559253607267086e+61,
119 // 49!
120 6.082818640342675608723e+62,
121 // 50!
122 3.041409320171337804361e+64,
123 // 51!
124 1.551118753287382280224e+66,
125 // 52!
126 8.065817517094387857166e+67,
127 // 53!
128 4.274883284060025564298e+69,
129 // 54!
130 2.308436973392413804721e+71,
131 // 55!
132 1.269640335365827592597e+73,
133 // 56!
134 7.109985878048634518540e+74,
135 // 57!
136 4.052691950487721675568e+76,
137 // 58!
138 2.350561331282878571829e+78,
139 // 59!
140 1.386831185456898357379e+80,
141 // 60!
142 8.320987112741390144276e+81,
143 // 61!
144 5.075802138772247988009e+83,
145 // 62!
146 3.146997326038793752565e+85,
147 // 63!
148 1.982608315404440064116e+87,
149 // 64!
150 1.268869321858841641034e+89,
151 // 65!
152 8.247650592082470666723e+90,
153 // 66!
154 5.443449390774430640037e+92,
155 // 67!
156 3.647111091818868528825e+94,
157 // 68!
158 2.480035542436830599601e+96,
159 // 69!
160 1.711224524281413113725e+98,
161 // 70!
162 1.197857166996989179607e+100,
163 // 71!
164 8.504785885678623175212e+101,
165 // 72!
166 6.123445837688608686152e+103,
167 // 73!
168 4.470115461512684340891e+105,
169 // 74!
170 3.307885441519386412260e+107,
171 // 75!
172 2.480914081139539809195e+109,
173 // 76!
174 1.885494701666050254988e+111,
175 // 77!
176 1.451830920282858696341e+113,
177 // 78!
178 1.132428117820629783146e+115,
179 // 79!
180 8.946182130782975286851e+116,
181 // 80!
182 7.156945704626380229481e+118,
183 // 81!
184 5.797126020747367985880e+120,
185 // 82!
186 4.753643337012841748421e+122,
187 // 83!
188 3.945523969720658651190e+124,
189 // 84!
190 3.314240134565353266999e+126,
191 // 85!
192 2.817104114380550276949e+128,
193 // 86!
194 2.422709538367273238177e+130,
195 // 87!
196 2.107757298379527717214e+132,
197 // 88!
198 1.854826422573984391148e+134,
199 // 89!
200 1.650795516090846108122e+136,
201 // 90!
202 1.485715964481761497310e+138,
203 // 91!
204 1.352001527678402962552e+140,
205 // 92!
206 1.243841405464130725548e+142,
207 // 93!
208 1.156772507081641574759e+144,
209 // 94!
210 1.087366156656743080274e+146,
211 // 95!
212 1.032997848823905926260e+148,
213 // 96!
214 9.916779348709496892096e+149,
215 // 97!
216 9.619275968248211985333e+151,
217 // 98!
218 9.426890448883247745626e+153,
219 // 99!
220 9.332621544394415268170e+155,
221 // 100!
222 9.332621544394415268170e+157,
223 // 101!
224 9.425947759838359420852e+159,
225 // 102!
226 9.614466715035126609269e+161,
227 // 103!
228 9.902900716486180407547e+163,
229 // 104!
230 1.029901674514562762385e+166,
231 // 105!
232 1.081396758240290900504e+168,
233 // 106!
234 1.146280563734708354534e+170,
235 // 107!
236 1.226520203196137939352e+172,
237 // 108!
238 1.324641819451828974500e+174,
239 // 109!
240 1.443859583202493582205e+176,
241 // 110!
242 1.588245541522742940425e+178,
243 // 111!
244 1.762952551090244663872e+180,
245 // 112!
246 1.974506857221074023537e+182,
247 // 113!
248 2.231192748659813646597e+184,
249 // 114!
250 2.543559733472187557120e+186,
251 // 115!
252 2.925093693493015690688e+188,
253 // 116!
254 3.393108684451898201198e+190,
255 // 117!
256 3.969937160808720895402e+192,
257 // 118!
258 4.684525849754290656574e+194,
259 // 119!
260 5.574585761207605881323e+196,
261 // 120!
262 6.689502913449127057588e+198,
263 // 121!
264 8.094298525273443739682e+200,
265 // 122!
266 9.875044200833601362412e+202,
267 // 123!
268 1.214630436702532967577e+205,
269 // 124!
270 1.506141741511140879795e+207,
271 // 125!
272 1.882677176888926099744e+209,
273 // 126!
274 2.372173242880046885677e+211,
275 // 127!
276 3.012660018457659544810e+213,
277 // 128!
278 3.856204823625804217357e+215,
279 // 129!
280 4.974504222477287440390e+217,
281 // 130!
282 6.466855489220473672507e+219,
283 // 131!
284 8.471580690878820510985e+221,
285 // 132!
286 1.118248651196004307450e+224,
287 // 133!
288 1.487270706090685728908e+226,
289 // 134!
290 1.992942746161518876737e+228,
291 // 135!
292 2.690472707318050483595e+230,
293 // 136!
294 3.659042881952548657690e+232,
295 // 137!
296 5.012888748274991661035e+234,
297 // 138!
298 6.917786472619488492228e+236,
299 // 139!
300 9.615723196941089004197e+238,
301 // 140!
302 1.346201247571752460588e+241,
303 // 141!
304 1.898143759076170969429e+243,
305 // 142!
306 2.695364137888162776589e+245,
307 // 143!
308 3.854370717180072770522e+247,
309 // 144!
310 5.550293832739304789551e+249,
311 // 145!
312 8.047926057471991944849e+251,
313 // 146!
314 1.174997204390910823948e+254,
315 // 147!
316 1.727245890454638911203e+256,
317 // 148!
318 2.556323917872865588581e+258,
319 // 149!
320 3.808922637630569726986e+260,
321 // 150!
322 5.713383956445854590479e+262,
323 // 151!
324 8.627209774233240431623e+264,
325 // 152!
326 1.311335885683452545607e+267,
327 // 153!
328 2.006343905095682394778e+269,
329 // 154!
330 3.089769613847350887959e+271,
331 // 155!
332 4.789142901463393876336e+273,
333 // 156!
334 7.471062926282894447084e+275,
335 // 157!
336 1.172956879426414428192e+278,
337 // 158!
338 1.853271869493734796544e+280,
339 // 159!
340 2.946702272495038326504e+282,
341 // 160!
342 4.714723635992061322407e+284,
343 // 161!
344 7.590705053947218729075e+286,
345 // 162!
346 1.229694218739449434110e+289,
347 // 163!
348 2.004401576545302577600e+291,
349 // 164!
350 3.287218585534296227263e+293,
351 // 165!
352 5.423910666131588774984e+295,
353 // 166!
354 9.003691705778437366474e+297,
355 // 167!
356 1.503616514864999040201e+300,
357 // 168!
358 2.526075744973198387538e+302,
359 // 169!
360 4.269068009004705274939e+304,
361 // 170!
362 7.257415615307998967397e+306,
363]
364const log_factorials_table = [
365 // 0!
366 0.000000000000000000000e+0,
367 // 1!
368 0.000000000000000000000e+0,
369 // 2!
370 6.931471805599453094172e-1,
371 // 3!
372 1.791759469228055000812e+0,
373 // 4!
374 3.178053830347945619647e+0,
375 // 5!
376 4.787491742782045994248e+0,
377 // 6!
378 6.579251212010100995060e+0,
379 // 7!
380 8.525161361065414300166e+0,
381 // 8!
382 1.060460290274525022842e+1,
383 // 9!
384 1.280182748008146961121e+1,
385 // 10!
386 1.510441257307551529523e+1,
387 // 11!
388 1.750230784587388583929e+1,
389 // 12!
390 1.998721449566188614952e+1,
391 // 13!
392 2.255216385312342288557e+1,
393 // 14!
394 2.519122118273868150009e+1,
395 // 15!
396 2.789927138384089156609e+1,
397 // 16!
398 3.067186010608067280376e+1,
399 // 17!
400 3.350507345013688888401e+1,
401 // 18!
402 3.639544520803305357622e+1,
403 // 19!
404 3.933988418719949403622e+1,
405 // 20!
406 4.233561646075348502966e+1,
407 // 21!
408 4.538013889847690802616e+1,
409 // 22!
410 4.847118135183522387964e+1,
411 // 23!
412 5.160667556776437357045e+1,
413 // 24!
414 5.478472939811231919009e+1,
415 // 25!
416 5.800360522298051993929e+1,
417 // 26!
418 6.126170176100200198477e+1,
419 // 27!
420 6.455753862700633105895e+1,
421 // 28!
422 6.788974313718153498289e+1,
423 // 29!
424 7.125703896716800901007e+1,
425 // 30!
426 7.465823634883016438549e+1,
427 // 31!
428 7.809222355331531063142e+1,
429 // 32!
430 8.155795945611503717850e+1,
431 // 33!
432 8.505446701758151741396e+1,
433 // 34!
434 8.858082754219767880363e+1,
435 // 35!
436 9.213617560368709248333e+1,
437 // 36!
438 9.571969454214320248496e+1,
439 // 37!
440 9.933061245478742692933e+1,
441 // 38!
442 1.029681986145138126988e+2,
443 // 39!
444 1.066317602606434591262e+2,
445 // 40!
446 1.103206397147573954291e+2,
447 // 41!
448 1.140342117814617032329e+2,
449 // 42!
450 1.177718813997450715388e+2,
451 // 43!
452 1.215330815154386339623e+2,
453 // 44!
454 1.253172711493568951252e+2,
455 // 45!
456 1.291239336391272148826e+2,
457 // 46!
458 1.329525750356163098828e+2,
459 // 47!
460 1.368027226373263684696e+2,
461 // 48!
462 1.406739236482342593987e+2,
463 // 49!
464 1.445657439463448860089e+2,
465 // 50!
466 1.484777669517730320675e+2,
467 // 51!
468 1.524095925844973578392e+2,
469 // 52!
470 1.563608363030787851941e+2,
471 // 53!
472 1.603311282166309070282e+2,
473 // 54!
474 1.643201122631951814118e+2,
475 // 55!
476 1.683274454484276523305e+2,
477 // 56!
478 1.723527971391628015638e+2,
479 // 57!
480 1.763958484069973517152e+2,
481 // 58!
482 1.804562914175437710518e+2,
483 // 59!
484 1.845338288614494905025e+2,
485 // 60!
486 1.886281734236715911873e+2,
487 // 61!
488 1.927390472878449024360e+2,
489 // 62!
490 1.968661816728899939914e+2,
491 // 63!
492 2.010093163992815266793e+2,
493 // 64!
494 2.051681994826411985358e+2,
495 // 65!
496 2.093425867525368356464e+2,
497 // 66!
498 2.135322414945632611913e+2,
499 // 67!
500 2.177369341139542272510e+2,
501 // 68!
502 2.219564418191303339501e+2,
503 // 69!
504 2.261905483237275933323e+2,
505 // 70!
506 2.304390435657769523214e+2,
507 // 71!
508 2.347017234428182677427e+2,
509 // 72!
510 2.389783895618343230538e+2,
511 // 73!
512 2.432688490029827141829e+2,
513 // 74!
514 2.475729140961868839366e+2,
515 // 75!
516 2.518904022097231943772e+2,
517 // 76!
518 2.562211355500095254561e+2,
519 // 77!
520 2.605649409718632093053e+2,
521 // 78!
522 2.649216497985528010421e+2,
523 // 79!
524 2.692910976510198225363e+2,
525 // 80!
526 2.736731242856937041486e+2,
527 // 81!
528 2.780675734403661429141e+2,
529 // 82!
530 2.824742926876303960274e+2,
531 // 83!
532 2.868931332954269939509e+2,
533 // 84!
534 2.913239500942703075662e+2,
535 // 85!
536 2.957666013507606240211e+2,
537 // 86!
538 3.002209486470141317540e+2,
539 // 87!
540 3.046868567656687154726e+2,
541 // 88!
542 3.091641935801469219449e+2,
543 // 89!
544 3.136528299498790617832e+2,
545 // 90!
546 3.181526396202093268500e+2,
547 // 91!
548 3.226634991267261768912e+2,
549 // 92!
550 3.271852877037752172008e+2,
551 // 93!
552 3.317178871969284731381e+2,
553 // 94!
554 3.362611819791984770344e+2,
555 // 95!
556 3.408150588707990178690e+2,
557 // 96!
558 3.453794070622668541074e+2,
559 // 97!
560 3.499541180407702369296e+2,
561 // 98!
562 3.545390855194408088492e+2,
563 // 99!
564 3.591342053695753987760e+2,
565 // 100!
566 3.637393755555634901441e+2,
567 // 101!
568 3.683544960724047495950e+2,
569 // 102!
570 3.729794688856890206760e+2,
571 // 103!
572 3.776141978739186564468e+2,
573 // 104!
574 3.822585887730600291111e+2,
575 // 105!
576 3.869125491232175524822e+2,
577 // 106!
578 3.915759882173296196258e+2,
579 // 107!
580 3.962488170517915257991e+2,
581 // 108!
582 4.009309482789157454921e+2,
583 // 109!
584 4.056222961611448891925e+2,
585 // 110!
586 4.103227765269373054205e+2,
587 // 111!
588 4.150323067282496395563e+2,
589 // 112!
590 4.197508055995447340991e+2,
591 // 113!
592 4.244781934182570746677e+2,
593 // 114!
594 4.292143918666515701285e+2,
595 // 115!
596 4.339593239950148201939e+2,
597 // 116!
598 4.387129141861211848399e+2,
599 // 117!
600 4.434750881209189409588e+2,
601 // 118!
602 4.482457727453846057188e+2,
603 // 119!
604 4.530248962384961351041e+2,
605 // 120!
606 4.578123879812781810984e+2,
607 // 121!
608 4.626081785268749221865e+2,
609 // 122!
610 4.674121995716081787447e+2,
611 // 123!
612 4.722243839269805962399e+2,
613 // 124!
614 4.770446654925856331047e+2,
615 // 125!
616 4.818729792298879342285e+2,
617 // 126!
618 4.867092611368394122258e+2,
619 // 127!
620 4.915534482232980034989e+2,
621 // 128!
622 4.964054784872176206648e+2,
623 // 129!
624 5.012652908915792927797e+2,
625 // 130!
626 5.061328253420348751997e+2,
627 // 131!
628 5.110080226652360267439e+2,
629 // 132!
630 5.158908245878223975982e+2,
631 // 133!
632 5.207811737160441513633e+2,
633 // 134!
634 5.256790135159950627324e+2,
635 // 135!
636 5.305842882944334921812e+2,
637 // 136!
638 5.354969431801695441897e+2,
639 // 137!
640 5.404169241059976691050e+2,
641 // 138!
642 5.453441777911548737966e+2,
643 // 139!
644 5.502786517242855655538e+2,
645 // 140!
646 5.552202941468948698523e+2,
647 // 141!
648 5.601690540372730381305e+2,
649 // 142!
650 5.651248810948742988613e+2,
651 // 143!
652 5.700877257251342061414e+2,
653 // 144!
654 5.750575390247102067619e+2,
655 // 145!
656 5.800342727671307811636e+2,
657 // 146!
658 5.850178793888391176022e+2,
659 // 147!
660 5.900083119756178539038e+2,
661 // 148!
662 5.950055242493819689670e+2,
663 // 149!
664 6.000094705553274281080e+2,
665 // 150!
666 6.050201058494236838580e+2,
667 // 151!
668 6.100373856862386081868e+2,
669 // 152!
670 6.150612662070848845750e+2,
671 // 153!
672 6.200917041284773200381e+2,
673 // 154!
674 6.251286567308909491967e+2,
675 // 155!
676 6.301720818478101958172e+2,
677 // 156!
678 6.352219378550597328635e+2,
679 // 157!
680 6.402781836604080409209e+2,
681 // 158!
682 6.453407786934350077245e+2,
683 // 159!
684 6.504096828956552392500e+2,
685 // 160!
686 6.554848567108890661717e+2,
687 // 161!
688 6.605662610758735291676e+2,
689 // 162!
690 6.656538574111059132426e+2,
691 // 163!
692 6.707476076119126755767e+2,
693 // 164!
694 6.758474740397368739994e+2,
695 // 165!
696 6.809534195136374546094e+2,
697 // 166!
698 6.860654073019939978423e+2,
699 // 167!
700 6.911834011144107529496e+2,
701 // 168!
702 6.963073650938140118743e+2,
703 // 169!
704 7.014372638087370853465e+2,
705 // 170!
706 7.065730622457873471107e+2,
707 // 171!
708 7.117147258022900069535e+2,
709]
710