# 1 / factorial(i)

# how many terms are to be used
const nused_inv_fact = 18

const inv_fact = (
  Double64(1.0,0.0),
  Double64(0.5,0.0),
  Double64(0.16666666666666666,9.25185853854297e-18),
  Double64(0.041666666666666664,2.3129646346357427e-18),
  Double64(0.008333333333333333,1.1564823173178714e-19),
  Double64(0.001388888888888889,-5.300543954373577e-20),
  Double64(0.0001984126984126984,1.7209558293420705e-22),
  Double64(2.48015873015873e-5,2.1511947866775882e-23),
  Double64(2.7557319223985893e-6,-1.858393274046472e-22),
  Double64(2.755731922398589e-7,2.3767714622250297e-23),
  Double64(2.505210838544172e-8,-1.448814070935912e-24),
  Double64(2.08767569878681e-9,-1.20734505911326e-25),
  Double64(1.6059043836821613e-10,1.2585294588752098e-26),
  Double64(1.1470745597729725e-11,2.0655512752830745e-28),
  Double64(7.647163731819816e-13,7.03872877733453e-30),
  Double64(4.779477332387385e-14,4.399205485834081e-31),
  Double64(2.8114572543455206e-15,1.6508842730861433e-31),
  Double64(1.5619206968586225e-16,1.1910679660273754e-32),
  Double64(8.22063524662433e-18,2.2141894119604265e-34),
  Double64(4.110317623312165e-19,1.4412973378659527e-36),
  Double64(1.9572941063391263e-20,-1.3643503830087908e-36),
  Double64(8.896791392450574e-22,-7.911402614872376e-38),
  Double64(3.868170170630684e-23,-8.843177655482344e-40),
  Double64(1.6117375710961184e-24,-3.6846573564509766e-41),
  Double64(6.446950284384474e-26,-1.9330404233703465e-42),
  Double64(2.4795962632247976e-27,-1.2953730964765229e-43),
  Double64(9.183689863795546e-29,1.4303150396787322e-45),
  Double64(3.279889237069838e-30,1.5117542744029879e-46),
  Double64(1.1309962886447716e-31,1.0498015412959506e-47),
  Double64(3.7699876288159054e-33,2.5870347832750324e-49),
  Double64(1.216125041553518e-34,5.586290567888806e-51),
  Double64(3.8003907548547434e-36,1.7457158024652518e-52)
);

const ninv_fact = length(inv_fact)

# [exp(i) for i in 1:64]

const exp_int = (
 Double64(2.718281828459045, 1.4456468917292502e-16),
 Double64(7.38905609893065, -1.7971139497839148e-16),
 Double64(20.085536923187668, -1.8275625525512858e-16),
 Double64(54.598150033144236, 2.8741578015844115e-15),
 Double64(148.4131591025766, 3.4863514900464198e-15),
 Double64(403.4287934927351, 1.2359628024450387e-14),
 Double64(1096.6331584284585, 9.869752640434095e-14),
 Double64(2980.9579870417283, -2.7103295816873633e-14),
 Double64(8103.083927575384, -2.1530877621067177e-13),
 Double64(22026.465794806718, -1.3780134700517372e-12),
 Double64(59874.14171519782, 1.7895764888916994e-12),
 Double64(162754.79141900392, 5.30065881322063e-12),
 Double64(442413.3920089205, 1.2118711752313224e-11),
 Double64(1.2026042841647768e6, -1.5000525764327354e-11),
 Double64(3.2690173724721107e6, -3.075806431120808e-11),
 Double64(8.886110520507872e6, 5.321182483501564e-10),
 Double64(2.41549527535753e7, -7.203995068362157e-10),
 Double64(6.565996913733051e7, 1.4165536846555444e-9),
 Double64(1.7848230096318725e8, 1.333018530234341e-8),
 Double64(4.851651954097903e8, 4.880277289790406e-10),
 Double64(1.3188157344832146e9, 8.043448618843281e-8),
 Double64(3.584912846131592e9, -2.3519384005402157e-7),
 Double64(9.744803446248903e9, -6.74501500127677e-7),
 Double64(2.648912212984347e10, 7.670395527778119e-7),
 Double64(7.200489933738588e10, -6.992440211033874e-6),
 Double64(1.9572960942883878e11, -1.1364989227123904e-5),
 Double64(5.3204824060179865e11, -2.8335783945658822e-5),
 Double64(1.446257064291475e12, 7.602079742299693e-5),
 Double64(3.931334297144042e12, 8.220112058084352e-5),
 Double64(1.0686474581524463e13, -0.0007436345313492586),
 Double64(2.9048849665247426e13, -0.0005501643178883202),
 Double64(7.896296018268069e13, 0.007660978022635108),
 Double64(2.1464357978591606e14, 0.002124297761531261),
 Double64(5.834617425274549e14, 0.006402902734610391),
 Double64(1.5860134523134308e15, -0.02187035537422534),
 Double64(4.311231547115195e15, 0.22711342229285691),
 Double64(1.1719142372802612e16, -0.6912270602088098),
 Double64(3.1855931757113756e16, 0.22032867170129863),
 Double64(8.659340042399374e16, 2.953606932719265),
 Double64(2.3538526683702e17, -14.592100089250966),
 Double64(6.398434935300549e17, 37.22266340351557),
 Double64(1.739274941520501e18, 55.394681303611236),
 Double64(4.727839468229346e18, 257.4744575627443),
 Double64(1.2851600114359308e19, -12.1907003678569),
 Double64(3.4934271057485095e19, 436.0347972334061),
 Double64(9.496119420602448e19, 5929.133649117119),
 Double64(2.5813128861900675e20, -15192.714199784727),
 Double64(7.016735912097631e20, 30185.471599886117),
 Double64(1.9073465724950998e21, -98786.90015904616),
 Double64(5.184705528587072e21, 419031.45332293346),
 Double64(1.4093490824269389e22, -614323.8566876298),
 Double64(3.831008000716577e22, -661524.304512138),
 Double64(1.0413759433029089e23, -7.520901270665062e6),
 Double64(2.830753303274694e23, -4.711377645198593e6),
 Double64(7.694785265142018e23, -3.868399744098706e7),
 Double64(2.091659496012996e24, 5.079641515721467e7),
 Double64(5.685719999335932e24, 2.0801558082063326e8),
 Double64(1.545538935590104e25, 1.2092033491117463e8),
 Double64(4.2012104037905144e25, -1.7624059056928084e9),
 Double64(1.1420073898156842e26, 4.912247462314477e9),
 Double64(3.10429793570192e26, 3.39761293411071e9),
 Double64(8.438356668741454e26, 6.5719328084037315e10),
 Double64(2.29378315946961e27, -7.566162968773138e10),
 Double64(6.235149080811617e27, 1.3899738872492847e11),
);

const n_exp_int = length(exp_int)


# npio32[idx] = (idx-1)*pi / 32

const npio32 = (
Double64(0.0, 0.0),
Double64(0.09817477042468103, 3.827021247335479e-18),
Double64(0.19634954084936207, 7.654042494670958e-18),
Double64(0.2945243112740431, 1.1481063742006436e-17),
Double64(0.39269908169872414, 1.5308084989341915e-17),
Double64(0.4908738521234052, 1.9135106236677395e-17),
Double64(0.5890486225480862, 2.296212748401287e-17),
Double64(0.6872233929727672, 2.678914873134835e-17),
Double64(0.7853981633974483, 3.061616997868383e-17),
Double64(0.8835729338221293, 3.444319122601931e-17),
Double64(0.9817477042468103, 3.827021247335479e-17),
Double64(1.0799224746714915, -6.89250687418254e-17),
Double64(1.1780972450961724, 4.592425496802574e-17),
Double64(1.2762720155208536, -6.127102624715443e-17),
Double64(1.3744467859455345, 5.35782974626967e-17),
Double64(1.4726215563702156, -5.3616983752483455e-17),
Double64(1.5707963267948966, 6.123233995736766e-17),
Double64(1.6689710972195777, -4.5962941257812514e-17),
Double64(1.7671458676442586, 6.888638245203862e-17),
Double64(1.8653206380689398, -3.830889876314156e-17),
Double64(1.9634954084936207, 7.654042494670958e-17),
Double64(2.061670178918302, -3.06548562684706e-17),
Double64(2.159844949342983, -1.378501374836508e-16),
Double64(2.2580197197676637, 1.9904379115123167e-16),
Double64(2.356194490192345, 9.184850993605148e-17),
Double64(2.454369260617026, -1.5346771279128684e-17),
Double64(2.552544031041707, -1.2254205249430885e-16),
Double64(2.650718801466388, 2.1435187614057358e-16),
Double64(2.748893571891069, 1.071565949253934e-16),
Double64(2.84706834231575, -3.868628978676964e-20),
Double64(2.9452431127404313, -1.0723396750496691e-16),
Double64(3.0434178831651124, -2.144292487201471e-16),
Double64(3.141592653589793, 1.2246467991473532e-16),
Double64(3.2397674240144743, 1.5269398699555146e-17),
Double64(3.3379421944391554, -9.192588251562503e-17),
Double64(3.4361169648638366, -1.991211637308052e-16),
Double64(3.5342917352885173, 1.3777276490407724e-16),
Double64(3.6324665057131984, 3.057748368889706e-17),
Double64(3.7306412761378795, -7.661779752628312e-17),
Double64(3.8288160465625607, -1.838130787414633e-16),
Double64(3.9269908169872414, 1.5308084989341916e-16),
Double64(4.025165587411923, -3.9820364117182366e-16),
Double64(4.123340357836604, -6.13097125369412e-17),
Double64(4.221515128261284, 2.755842160979412e-16),
Double64(4.319689898685966, -2.757002749673016e-16),
Double64(4.417864669110647, 6.11936536675809e-17),
Double64(4.516039439535327, 3.9808758230246333e-16),
Double64(4.614214209960009, -1.5319690876277947e-16),
Double64(4.71238898038469, 1.8369701987210297e-16),
Double64(4.810563750809371, -3.675874711931398e-16),
Double64(4.908738521234052, -3.069354255825737e-17),
Double64(5.006913291658733, 3.062003860766251e-16),
Double64(5.105088062083414, -2.450841049886177e-16),
Double64(5.203262832508095, 9.180982364626472e-17),
Double64(5.301437602932776, 4.2870375228114717e-16),
Double64(5.399612373357457, -1.2258073878409563e-16),
Double64(5.497787143782138, 2.143131898507868e-16),
Double64(5.5959619142068195, -3.36971301214456e-16),
Double64(5.6941366846315, -7.737257957353928e-20),
Double64(5.792311455056181, 3.368165560553089e-16),
Double64(5.8904862254808625, -2.1446793500993382e-16),
Double64(5.988660995905543, 1.2242599362494854e-16),
Double64(6.086835766330225, -4.288584974402942e-16),
Double64(6.1850105367549055, -9.19645688054118e-17),
#Double64(6.283185307179586, 2.4492935982947064e-16)
);

const n_npio32 = length(npio32)

# sin_npio32[idx] = sin( (idx-1)*pi / 32 )

const sin_npio32 = (
Double64(0.0, 0.0),
Double64(0.0980171403295606, -1.634582362244256e-18),
Double64(0.19509032201612828, -7.99107906846173e-18),
Double64(0.2902846772544624, -1.892797870777425e-17),
Double64(0.3826834323650898, -1.0050772696461588e-17),
Double64(0.47139673682599764, 6.5166781360690145e-18),
Double64(0.5555702330196022, 4.709410940561677e-17),
Double64(0.6343932841636455, 1.0420901929280035e-17),
Double64(0.7071067811865476, -4.833646656726457e-17),
Double64(0.773010453362737, -3.256590703364977e-17),
Double64(0.8314696123025452, 1.4073856984728037e-18),
Double64(0.881921264348355, -1.9843248405890568e-17),
Double64(0.9238795325112867, 1.7645047084336677e-17),
Double64(0.9569403357322088, 4.05538698618757e-17),
Double64(0.9807852804032304, 1.8546939997825006e-17),
Double64(0.9951847266721969, -4.2486913678304403e-17),
Double64(1.0, -1.1210807766491662e-66),
Double64(0.9951847266721969, -4.248691367830441e-17),
Double64(0.9807852804032304, 1.8546939997825003e-17),
Double64(0.9569403357322088, 4.05538698618757e-17),
Double64(0.9238795325112867, 1.7645047084336674e-17),
Double64(0.881921264348355, -1.9843248405890562e-17),
Double64(0.8314696123025452, 1.4073856984728124e-18),
Double64(0.773010453362737, -3.256590703364977e-17),
Double64(0.7071067811865476, -4.833646656726456e-17),
Double64(0.6343932841636455, 1.0420901929280033e-17),
Double64(0.5555702330196022, 4.7094109405616756e-17),
Double64(0.47139673682599764, 6.516678136069009e-18),
Double64(0.3826834323650898, -1.0050772696461588e-17),
Double64(0.2902846772544624, -1.892797870777425e-17),
Double64(0.19509032201612828, -7.991079068461768e-18),
Double64(0.0980171403295606, -1.6345823622442887e-18),
Double64(-2.9947698097183397e-33, 1.1124542208633653e-49),
Double64(-0.0980171403295606, 1.6345823622442521e-18),
Double64(-0.19509032201612828, 7.991079068461727e-18),
Double64(-0.2902846772544624, 1.892797870777424e-17),
Double64(-0.3826834323650898, 1.0050772696461581e-17),
Double64(-0.47139673682599764, -6.5166781360690145e-18),
Double64(-0.5555702330196022, -4.709410940561676e-17),
Double64(-0.6343932841636455, -1.0420901929280028e-17),
Double64(-0.7071067811865476, 4.833646656726456e-17),
Double64(-0.773010453362737, 3.2565907033649785e-17),
Double64(-0.8314696123025452, -1.407385698472802e-18),
Double64(-0.881921264348355, 1.9843248405890578e-17),
Double64(-0.9238795325112867, -1.7645047084336662e-17),
Double64(-0.9569403357322088, -4.05538698618757e-17),
Double64(-0.9807852804032304, -1.8546939997825006e-17),
Double64(-0.9951847266721969, 4.248691367830441e-17),
Double64(-1.0, 3.068418716632831e-65),
Double64(-0.9951847266721969, 4.248691367830441e-17),
Double64(-0.9807852804032304, -1.8546939997825003e-17),
Double64(-0.9569403357322088, -4.0553869861875694e-17),
Double64(-0.9238795325112867, -1.7645047084336668e-17),
Double64(-0.881921264348355, 1.9843248405890565e-17),
Double64(-0.8314696123025452, -1.407385698472797e-18),
Double64(-0.773010453362737, 3.256590703364977e-17),
Double64(-0.7071067811865476, 4.833646656726457e-17),
Double64(-0.6343932841636455, -1.0420901929280039e-17),
Double64(-0.5555702330196022, -4.709410940561676e-17),
Double64(-0.47139673682599764, -6.516678136069028e-18),
Double64(-0.3826834323650898, 1.0050772696461658e-17),
Double64(-0.2902846772544624, 1.8927978707774248e-17),
Double64(-0.19509032201612828, 7.991079068461796e-18),
Double64(-0.0980171403295606, 1.6345823622442672e-18),
#Double64(5.989539619436679e-33, -2.2249084417267306e-49)
);

const n_sin_npio32 = length(sin_npio32)

# cos_npio32[idx] = cos( (idx-1)*pi / 32 )

const cos_npio32 = (
Double64(1.0, 0.0),
Double64(0.9951847266721969, -4.248691367830441e-17),
Double64(0.9807852804032304, 1.8546939997825006e-17),
Double64(0.9569403357322088, 4.05538698618757e-17),
Double64(0.9238795325112867, 1.7645047084336677e-17),
Double64(0.881921264348355, -1.9843248405890562e-17),
Double64(0.8314696123025452, 1.407385698472803e-18),
Double64(0.773010453362737, -3.256590703364977e-17),
Double64(0.7071067811865476, -4.833646656726457e-17),
Double64(0.6343932841636455, 1.0420901929280033e-17),
Double64(0.5555702330196022, 4.709410940561676e-17),
Double64(0.47139673682599764, 6.5166781360690214e-18),
Double64(0.3826834323650898, -1.0050772696461586e-17),
Double64(0.2902846772544624, -1.8927978707774255e-17),
Double64(0.19509032201612828, -7.99107906846173e-18),
Double64(0.0980171403295606, -1.634582362244275e-18),
Double64(-1.4973849048591698e-33, 5.562271104316826e-50),
Double64(-0.0980171403295606, 1.6345823622442537e-18),
Double64(-0.19509032201612828, 7.991079068461728e-18),
Double64(-0.2902846772544624, 1.892797870777425e-17),
Double64(-0.3826834323650898, 1.0050772696461583e-17),
Double64(-0.47139673682599764, -6.516678136069013e-18),
Double64(-0.5555702330196022, -4.709410940561675e-17),
Double64(-0.6343932841636455, -1.0420901929280036e-17),
Double64(-0.7071067811865476, 4.833646656726457e-17),
Double64(-0.773010453362737, 3.2565907033649766e-17),
Double64(-0.8314696123025452, -1.407385698472808e-18),
Double64(-0.881921264348355, 1.984324840589056e-17),
Double64(-0.9238795325112867, -1.7645047084336677e-17),
Double64(-0.9569403357322088, -4.05538698618757e-17),
Double64(-0.9807852804032304, -1.8546939997825012e-17),
Double64(-0.9951847266721969, 4.2486913678304403e-17),
Double64(-1.0, 4.484323106596665e-66),
Double64(-0.9951847266721969, 4.248691367830441e-17),
Double64(-0.9807852804032304, -1.8546939997825003e-17),
Double64(-0.9569403357322088, -4.0553869861875694e-17),
Double64(-0.9238795325112867, -1.7645047084336674e-17),
Double64(-0.881921264348355, 1.9843248405890562e-17),
Double64(-0.8314696123025452, -1.4073856984728047e-18),
Double64(-0.773010453362737, 3.2565907033649766e-17),
Double64(-0.7071067811865476, 4.8336466567264573e-17),
Double64(-0.6343932841636455, -1.042090192928005e-17),
Double64(-0.5555702330196022, -4.709410940561677e-17),
Double64(-0.47139673682599764, -6.51667813606904e-18),
Double64(-0.3826834323650898, 1.0050772696461555e-17),
Double64(-0.2902846772544624, 1.8927978707774258e-17),
Double64(-0.19509032201612828, 7.991079068461733e-18),
Double64(-0.0980171403295606, 1.6345823622442535e-18),
Double64(-7.8337969295008e-33, 5.173596326540973e-49),
Double64(0.0980171403295606, -1.63458236224422e-18),
Double64(0.19509032201612828, -7.991079068461725e-18),
Double64(0.2902846772544624, -1.8927978707774227e-17),
Double64(0.3826834323650898, -1.0050772696461569e-17),
Double64(0.47139673682599764, 6.516678136069015e-18),
Double64(0.5555702330196022, 4.7094109405616774e-17),
Double64(0.6343932841636455, 1.0420901929280038e-17),
Double64(0.7071067811865476, -4.833646656726457e-17),
Double64(0.773010453362737, -3.256590703364977e-17),
Double64(0.8314696123025452, 1.4073856984728055e-18),
Double64(0.881921264348355, -1.984324840589057e-17),
Double64(0.9238795325112867, 1.7645047084336705e-17),
Double64(0.9569403357322088, 4.05538698618757e-17),
Double64(0.9807852804032304, 1.8546939997825018e-17),
Double64(0.9951847266721969, -4.248691367830441e-17),
#Double64(1.0, -1.7937292426403932e-65)
);

const n_cos_npio32 = length(cos_npio32)

const tan_npio32  = (
    Double64(0.0, 0.0),
    Double64(0.09849140335716425, 5.3100671162822435e-18),
    Double64(0.198912367379658, 8.391794477636538e-19),
    Double64(0.3033466836073424, -1.2766990847826405e-17),
    Double64(0.41421356237309503, 1.4349369327986523e-17),
    Double64(0.5345111359507917, -5.2626469389262167e-17),
    Double64(0.6681786379192989, 4.1042270233610004e-17),
    Double64(0.8206787908286604, -2.2923147594675738e-17),
    Double64(1.0, 0.0),
    Double64(1.2185035255879764, -2.1244788699148428e-17),
    Double64(1.496605762665489, 6.974100888958305e-17),
    Double64(1.8708684117893895, 2.945807107795785e-17),
    Double64(2.414213562373095, 1.2537167179050217e-16),
    Double64(3.2965582089383205, -9.53295779936916e-17),
    Double64(5.027339492125848, 2.95379181037367e-17),
    Double64(10.15317038760886, 5.362306887894472e-16),
    Double64(1.7976931348623157e308, 0.0),
    Double64(-10.15317038760886, -5.362306887894472e-16),
    Double64(-5.027339492125848, -2.95379181037367e-17),
    Double64(-3.2965582089383205, 9.53295779936916e-17),
    Double64(-2.414213562373095, -1.2537167179050217e-16),
    Double64(-1.8708684117893895, -2.945807107795785e-17),
    Double64(-1.496605762665489, -6.974100888958305e-17),
    Double64(-1.2185035255879764, 2.1244788699148428e-17),
    Double64(-1.0, 0.0),
    Double64(-0.8206787908286604, 2.2923147594675738e-17),
    Double64(-0.6681786379192989, -4.1042270233610004e-17),
    Double64(-0.5345111359507917, 5.2626469389262167e-17),
    Double64(-0.41421356237309503, -1.4349369327986523e-17),
    Double64(-0.3033466836073424, 1.2766990847826405e-17),
    Double64(-0.198912367379658, -8.391794477636538e-19),
    Double64(-0.09849140335716425, -5.3100671162822435e-18),
    Double64(0.0, 0.0),
    Double64(0.09849140335716425, 5.3100671162822435e-18),
    Double64(0.198912367379658, 8.391794477636538e-19),
    Double64(0.3033466836073424, -1.2766990847826405e-17),
    Double64(0.41421356237309503, 1.4349369327986523e-17),
    Double64(0.5345111359507917, -5.2626469389262167e-17),
    Double64(0.6681786379192989, 4.1042270233610004e-17),
    Double64(0.8206787908286604, -2.2923147594675738e-17),
    Double64(1.0, 0.0),
    Double64(1.2185035255879764, -2.1244788699148428e-17),
    Double64(1.496605762665489, 6.974100888958305e-17),
    Double64(1.8708684117893895, 2.945807107795785e-17),
    Double64(2.414213562373095, 1.2537167179050217e-16),
    Double64(3.2965582089383205, -9.53295779936916e-17),
    Double64(5.027339492125848, 2.95379181037367e-17),
    Double64(10.15317038760886, 5.362306887894472e-16),
    Double64(-1.7976931348623157e308, 0.0),
    Double64(-10.15317038760886, -5.362306887894472e-16),
    Double64(-5.027339492125848, -2.95379181037367e-17),
    Double64(-3.2965582089383205, 9.53295779936916e-17),
    Double64(-2.414213562373095, -1.2537167179050217e-16),
    Double64(-1.8708684117893895, -2.945807107795785e-17),
    Double64(-1.496605762665489, -6.974100888958305e-17),
    Double64(-1.2185035255879764, 2.1244788699148428e-17),
    Double64(-1.0, 0.0),
    Double64(-0.8206787908286604, 2.2923147594675738e-17),
    Double64(-0.6681786379192989, -4.1042270233610004e-17),
    Double64(-0.5345111359507917, 5.2626469389262167e-17),
    Double64(-0.41421356237309503, -1.4349369327986523e-17),
    Double64(-0.3033466836073424, 1.2766990847826405e-17),
    Double64(-0.198912367379658, -8.391794477636538e-19),
    Double64(-0.09849140335716425, -5.3100671162822435e-18),
    Double64(0.0, 0.0),
#    Double64(0.09849140335716425, 5.3100671162822435e-18)
);

const n_tan_npio32 = length(tan_npio32)


const tan_coeff = const TangentCoeffs = [
	Double64(1.0, 0.0),
	Double64(0.3333333333333333, 1.850371707708594e-17),
	Double64(0.13333333333333333, 1.8503717077085942e-18),
	Double64(0.05396825396825397, -2.5552752154071065e-18),
	Double64(0.021869488536155203, -1.7377829530067485e-19),
	Double64(0.008863235529902197, -7.63300580171831e-19),
	Double64(0.003592128036572481, -1.253823608406629e-19),
	Double64(0.0014558343870513183, -6.214492640136062e-20),
	Double64(0.000590027440945586, 3.478690842383652e-20),
	Double64(0.00023912911424355248, 3.564613898329782e-21),
	Double64(9.691537956929451e-5, -6.2386628755632464e-21),
	Double64(3.927832388331683e-5, 1.3737015743076767e-21),
	Double64(1.5918905069328964e-5, 1.0427554807190543e-21),
	Double64(6.451689215655431e-6, 1.1519922496640058e-22),
	Double64(2.6147711512907546e-6, -9.313685621299801e-23),
	Double64(1.0597268320104654e-6, 2.3670525505213632e-24),
	Double64(4.294911078273806e-7, 1.1643520863702653e-23),
	Double64(1.7406618963571648e-7, -2.4364235361756183e-24),
	Double64(7.054636946400968e-8, 1.81294121906281e-24),
	Double64(2.859136662305254e-8, -6.927061232480201e-25),
	Double64(1.1587644432798853e-8, -6.676141550901535e-25),
	Double64(4.6962953982309016e-9, 5.585087708922479e-26),
	Double64(1.903336833931276e-9, 6.644200217899965e-26),
	Double64(7.713933635359062e-10, 3.330462514587965e-26),
	Double64(3.126339545892087e-10, 1.3431720632001545e-26),
	Double64(1.26705769303054e-10, 3.212977078832784e-27),
	Double64(5.135191408039368e-11, -2.0245650830490024e-27),
	Double64(2.0812146867700473e-11, 8.599281894073044e-28),
	Double64(8.434845419094337e-12, 8.050467205827787e-28),
	Double64(3.4185140868111557e-12, 8.393525824301979e-29),
	Double64(1.385471574294847e-12, -5.907625471272317e-29),
	Double64(5.61510479241468e-13, -1.0849557288985563e-29),
	Double64(2.2757162553728747e-13, 1.4248250730723616e-29),
	Double64(9.223130585139532e-14, -5.829477138214029e-30),
	Double64(3.737994031096739e-14, -1.2136039633979156e-30),
	Double64(1.5149519187148606e-14, -6.234579855436469e-31),
	Double64(6.139868862616814e-15, 1.660718962017884e-31),
	Double64(2.488395122276279e-15, -1.6465031184823015e-31),
	Double64(1.0085085566354096e-15, 6.051385314404599e-32),
	Double64(4.087331226869014e-16, -3.840887770358501e-33),
	Double64(1.6565329513786285e-16, -1.1753361684566294e-32),
	Double64(6.713675175048712e-17, -5.751617343643472e-34),
	Double64(2.7209500613044588e-17, 5.912656012687598e-35),
	Double64(1.102759523372237e-17, 6.889387842184814e-34),
	Double64(4.4693160072374125e-18, -5.963106810322789e-35),
	Double64(1.8113455516997665e-18, 1.6975481764291697e-34),
	Double64(7.3411070113401475e-19, 6.232644202349733e-36),
	Double64(2.975238606536194e-19, 5.973993675861387e-36),
	Double64(1.2058187889305074e-19, -1.1146629551117048e-36),
	Double64(4.8869994781043706e-20, -8.235745703221855e-37),
	Double64(1.980626286324087e-20, 1.0151251301137887e-37),
	Double64(8.027175987339371e-21, 5.155945578317267e-37),
	Double64(3.2532918893703063e-21, -1.8492173686149099e-37),
	Double64(1.3185095398600672e-21, 2.7232745038615834e-38),
	Double64(5.343717888893445e-22, 3.047260525016857e-38),
	Double64(2.165727286213673e-22, 1.4832290335239522e-38),
	Double64(8.777362083427096e-23, 2.1379234735632897e-39),
	Double64(3.557330862200837e-23, 1.700525479402311e-39),
	Double64(1.4417318942624272e-23, -4.05166348193838e-40),
	Double64(5.843119280863155e-24, 1.2167640006197093e-40),
	Double64(2.3681270468016817e-24, -1.719508829736334e-40),
	Double64(9.597657415895207e-25, 8.563087764073255e-41),
	Double64(3.889784038288653e-25, 1.1167780858140198e-42),
	Double64(1.5764700914899153e-25, 4.697215882796148e-42)
];


const n_tan_coeff = length(tan_coeff)

const twokminus1 = [ 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29,
    31, 33, 35, 37, 39, 41, 43, 45, 47, 49, 51, 53, 55, 57, 59, 61, 63, 65,
    67, 69, 71, 73, 75, 77, 79, 81, 83, 85, 87, 89, 91, 93, 95, 97, 99, 101,
    103, 105, 107, 109, 111, 113, 115, 117, 119, 121, 123, 125, 127];
	

# x^-1, x^1, x^3 ...


# bernoulli_even[i] = bernoulli(2*i-2),bernoulli(e) =bernoulli_even[(e+2)>>1]
const bernoulli_even =
[ Double64(1.0, 0.0),                                       # 1:0th
  Double64(0.16666666666666666, 9.25185853854297e-18),      # 2:2nd
  Double64(-0.03333333333333333, -4.625929269271486e-19),   # 3:4th
  Double64(0.023809523809523808, 1.32169407693471e-18),     # 4:6th
  Double64(-0.03333333333333333, -4.625929269271486e-19),
  Double64(0.07575757575757576, -2.10269512239613e-18),
  Double64(-0.2531135531135531, -1.1061562736192037e-17),
  Double64(1.1666666666666667, -7.401486830834377e-17),
  Double64(-7.092156862745098, -3.274069468698501e-16),
  Double64(54.971177944862156, -1.9588897477095493e-16),
  Double64(-529.1242424242424, 6.890111377067638e-16),
  Double64(6192.123188405797, 9.226757844073186e-14),
  Double64(-86580.25311355312, 3.5926706461242705e-12),
  Double64(1.4255171666666667e6, -7.761021455128987e-11),
  Double64(-2.7298231067816094e7, 1.610010519795034e-9),
  Double64(6.015808739006424e8, -2.6635227381825164e-8),
  Double64(-1.5116315767092157e10, 5.011465035232843e-7),
  Double64(4.296146430611667e11, -2.0345052083333332e-5),
  Double64(-1.3711655205088332e13, -0.0007409090879485616),
  Double64(4.883323189735932e14, -0.020833333333333332),
  Double64(-1.9296579341940068e16, -0.14863266814486326),
  Double64(8.416930475736826e17, 55.000553709856035),
  Double64(-4.0338071854059454e19, -949.0768115942029),
  Double64(2.1150748638081993e21, -101647.85460992908),
  Double64(-1.2086626522296526e23, 2.6786766880629174e6),
  Double64(7.500866746076964e24, 2.0081412007575756e8)
];

const n_bernoulli_even = length(bernoulli_even)


#=
bernoulli_evenf
[(1.0, 0.0, 0.0),
   (0.16666666666666666, 9.25185853854297e-18, 5.135813185032629e-34),
   (-0.03333333333333333, -4.625929269271486e-19, -6.419766481290786e-36),
   (0.023809523809523808, 1.32169407693471e-18, 7.336875978618041e-35),
   (-0.03333333333333333, -4.625929269271486e-19, -6.419766481290786e-36),
   (0.07575757575757576, -2.10269512239613e-18, 5.836151346627988e-35),
   (-0.2531135531135531, -1.1061562736192037e-17, 7.607776014751631e-34),
   (1.1666666666666667, -7.401486830834377e-17, -4.108650548026103e-33),
   (-7.092156862745098, -3.274069468698501e-16, 2.0108219152692458e-32),
   (54.971177944862156, -1.9588897477095493e-16, -1.0874022503046528e-32),
   (-529.1242424242424, 6.890111377067638e-16, 5.976218978947059e-34),
   (6192.123188405797, 9.226757844073186e-14, -5.853576572074754e-30),
   (-86580.25311355312, 3.5926706461242705e-12, -1.609669232303282e-28),
   (1.4255171666666667e6, -7.761021455128987e-11, -4.308232357047019e-27),
   (-2.7298231067816094e7, 1.610010519795034e-9, 2.234338436206454e-26),
   (6.015808739006424e8, -2.6635227381825164e-8, -2.310237711361619e-26),
   (-1.5116315767092157e10, 5.011465035232843e-7, -1.9514974765172607e-23),
   (4.296146430611667e11, -2.0345052083333332e-5, -1.1293772630057337e-21),
   (-1.3711655205088332e13, -0.0007409090879485616, -1.4575906467399005e-20),
   (4.883323189735932e14, -0.020833333333333332, -1.1564823173178713e-18),
   (-1.9296579341940068e16, -0.14863266814486326, -1.0970940014219026e-17),
   (8.416930475736826e17, 55.000553709856035, 1.258990450959203e-16),
   (-4.0338071854059454e19, -949.0768115942029, 2.405547580776223e-14),
   (2.1150748638081993e21, -101647.85460992908, 5.366663772163661e-12),
   (-1.2086626522296526e23, 2.6786766880629174e6, 3.3552496116291315e-11),
   (7.500866746076964e24, 2.0081412007575756e8, 1.2643409497810133e-8)]

tan_coeffs = [
  1//1,
  1//3,
  2//15,
  17//315,
  62//2835,
  1382//155925,
  21844//6081075,
  929569//638512875,
  6404582//10854718875,
  443861162//1856156927625,
  18888466084//194896477400625,
  113927491862//2900518163668125,
  58870668456604//3698160658676859375,
  8374643517010684//1298054391195577640625,
  689005380505609448//263505041412702261046875,
  129848163681107301953//122529844256906551386796875,
  1736640792209901647222//4043484860477916195764296875
];

x^1, x^3 ...

 Double64(1.0, 0.0)
 Double64(0.3333333333333333, 1.850371707708594e-17)
 Double64(0.13333333333333333, 1.8503717077085942e-18)
 Double64(0.05396825396825397, -2.5552752154071065e-18)
 Double64(0.021869488536155203, -1.7377829530067485e-19)
 Double64(0.008863235529902197, -7.63300580171831e-19)
 Double64(0.003592128036572481, -1.253823608406629e-19)
 Double64(0.0014558343870513183, -6.214492640136062e-20)
 Double64(0.000590027440945586, 3.478690842383652e-20)
 Double64(0.00023912911424355248, 3.564613898329782e-21)
 Double64(9.691537956929451e-5, -6.2386628755632464e-21)
 Double64(3.927832388331683e-5, 1.3737015743076767e-21)
 Double64(1.5918905069328964e-5, 1.0427554807190543e-21)
 Double64(6.451689215655431e-6, 1.1519922496640058e-22)
 Double64(2.6147711512907546e-6, -9.313685621299801e-23)
 Double64(1.0597268320104654e-6, 2.3670525505213632e-24)
 Double64(4.294911078273806e-7, 1.1643520863702653e-23)

cot_coeffs = [
  1,
  -1//3,
  -1//45,
  -2//945,
  -1//4725,
  -2//93555,
  -1382//638512875,
  -4//18243225,
  -3617//162820783125,
  -87734//38979295480125,
  -349222//1531329465290625,
  -310732//13447856940643125,
  -472728182//201919571963756521875,
  -2631724//11094481976030578125,
  -13571120588//564653660170076273671875,
  -13785346041608//5660878804669082674070015625,
  -7709321041217//31245110285511170603633203125,
  -303257395102//12130454581433748587292890625
]

x^-1, x^1, x^3 ...


  Double64(1.0, 0.0)
 Double64(-0.3333333333333333, -1.850371707708594e-17)
 Double64(-0.022222222222222223, 8.480870326997723e-19)
 Double64(-0.0021164021164021165, 1.4272460344676906e-19)
 Double64(-0.00021164021164021165, 8.851449482249383e-21)
 Double64(-2.1377799155576935e-5, 1.2363213405319781e-21)
 Double64(-2.1644042808063972e-6, 1.4406027968224744e-23)
 Double64(-2.1925947851873778e-7, 4.633975226217266e-25)
 Double64(-2.2214608789979678e-8, -9.8218334027542e-25)
 Double64(-2.2507846516808994e-9, 1.586632784299882e-25)
 Double64(-2.2805151204592183e-10, 5.2026333279551446e-27)
 Double64(-2.3106432599002624e-11, 6.28420623757996e-29)
 Double64(-2.3411706819824882e-12, -1.7365409250001553e-28)
 Double64(-2.3721017400233653e-13, -1.2711970013895883e-29)
 Double64(-2.4034415333307705e-14, -1.5378003549195334e-30)
 Double64(-2.4351954029183367e-15, -1.4005306880921365e-31)
 Double64(-2.4673688045172075e-16, 7.143574177377665e-34)
 Double64(-2.499967277122081e-17, 9.643517068634457e-34)

=#
