{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import numpy.linalg as npl\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "def aggregate_metrics(metrics, bootstrap_trials=1000):\n",
    "    \"\"\"\n",
    "    Takes as input a tensor of shape (num_eval, n_points) and returns a dict with\n",
    "    per-point mean, stddev, and bootstrap limits\n",
    "    \"\"\"\n",
    "    results = {}\n",
    "    results[\"mean\"] = metrics.mean(dim=0)\n",
    "    results[\"std\"] = metrics.std(dim=0, unbiased=True)\n",
    "    n = len(metrics)\n",
    "    bootstrap_indices = torch.randint(n, size=(bootstrap_trials, n))\n",
    "    bootstrap_means = metrics[bootstrap_indices].mean(dim=1).sort(dim=0)[0]\n",
    "    results[\"bootstrap_low\"] = bootstrap_means[int(0.05 * bootstrap_trials), :]\n",
    "    results[\"bootstrap_high\"] = bootstrap_means[int(0.95 * bootstrap_trials), :]\n",
    "\n",
    "    return {k: v.tolist() for k, v in results.items()}\n",
    "\n",
    "def get_grad(X, y, W, mode='relu'):\n",
    "    if mode == 'relu':\n",
    "        mask = X.dot(W)>0\n",
    "        grad = np.zeros_like(W)\n",
    "        for i in range(W.shape[1]):\n",
    "            grad[:,i] = (X * mask[:,i:i+1]).T.dot((X.dot(W[:,i]))* mask[:,i]-y[:,i])\n",
    "        return grad\n",
    "    # elif mode == 'linear':\n",
    "\n",
    "class NN(nn.Module):\n",
    "    def __init__(self, d, k):\n",
    "        super(NN,self).__init__()\n",
    "        self.W = nn.Linear(d, k, bias=True)\n",
    "        self.v = nn.Linear(k, 1, bias=True)\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return nn.ReLU()(self.W(x))\n",
    "        return self.v(nn.ReLU(self.W(x)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "d=10\n",
    "k=4\n",
    "N = 101\n",
    "RUNS = 100\n",
    "ITN = 200\n",
    "lr = 0.01\n",
    "losses = np.zeros((RUNS, N))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n=0 0.21437345935250307\n",
      "n=1 0.09884718039948712\n",
      "n=2 0.07906248036664247\n",
      "n=3 0.045190427192587104\n",
      "n=4 7.906053329531771e-30\n",
      "n=5 1.1674495903854108e-29\n",
      "n=6 1.54517336347289e-31\n",
      "n=7 6.883283751440802e-33\n",
      "n=8 1.08896846208982e-31\n",
      "n=9 4.7854094393066545e-32\n",
      "n=10 4.760956326312263e-32\n",
      "n=11 8.246746883487182e-32\n",
      "n=12 1.4457548500905464e-32\n",
      "n=13 1.3330725295823487e-32\n",
      "n=14 5.780459439025215e-33\n",
      "n=15 5.288870587873701e-32\n",
      "n=16 1.3649361079378657e-32\n",
      "n=17 9.729240332579677e-32\n",
      "n=18 3.0721442904973027e-33\n",
      "n=19 4.913467989413007e-32\n",
      "n=20 5.496873405444185e-32\n",
      "n=21 3.096233982537229e-32\n",
      "n=22 1.1356789372558692e-32\n",
      "n=23 3.818260992120904e-32\n",
      "n=24 6.493277574654893e-32\n",
      "n=25 4.11544413878084e-32\n",
      "n=26 1.1373283723072504e-32\n",
      "n=27 1.7194597666116033e-32\n",
      "n=28 1.9026424003814645e-31\n",
      "n=29 1.3506325623252114e-32\n",
      "n=30 1.641877713005467e-31\n",
      "n=31 1.1363677909117206e-31\n",
      "n=32 1.1387404073127934e-31\n",
      "n=33 6.937333139975999e-32\n",
      "n=34 1.0334532930851917e-32\n",
      "n=35 1.5565827107108866e-31\n",
      "n=36 3.959544161863022e-31\n",
      "n=37 3.8449808865226136e-32\n",
      "n=38 1.2321184490750618e-32\n",
      "n=39 1.017130560091177e-32\n",
      "n=40 7.952040794388378e-33\n",
      "n=41 1.2835622307801757e-31\n",
      "n=42 9.137450675158721e-32\n",
      "n=43 1.5263280838468504e-32\n",
      "n=44 3.1345767181592445e-32\n",
      "n=45 1.1970563342969762e-32\n",
      "n=46 1.2662490025035e-31\n",
      "n=47 5.418919722441448e-32\n",
      "n=48 8.034255120677738e-32\n",
      "n=49 2.5668314752963025e-32\n",
      "n=50 4.0192108063430704e-32\n",
      "n=51 2.8043446851609227e-32\n",
      "n=52 4.6437055831807216e-32\n",
      "n=53 4.999762998950873e-32\n",
      "n=54 5.653810476568443e-32\n",
      "n=55 7.641518035416e-32\n",
      "n=56 9.03857038083575e-33\n",
      "n=57 3.7443796498483464e-32\n",
      "n=58 3.977297994286009e-32\n",
      "n=59 1.9680119903874296e-32\n",
      "n=60 1.4373658520221416e-31\n",
      "n=61 2.4099449993110735e-32\n",
      "n=62 1.3129885126127857e-32\n",
      "n=63 9.594564218312079e-33\n",
      "n=64 6.792274623156016e-32\n",
      "n=65 5.553395624416274e-32\n",
      "n=66 4.054068231475148e-32\n",
      "n=67 1.6693343411592623e-32\n",
      "n=68 1.353723764474992e-32\n",
      "n=69 1.2759965200914633e-32\n",
      "n=70 6.641451426174522e-32\n",
      "n=71 3.285388593151584e-32\n",
      "n=72 9.563448263674533e-32\n",
      "n=73 4.634441737989915e-32\n",
      "n=74 1.1531174820756467e-32\n",
      "n=75 9.490601561269316e-32\n",
      "n=76 5.904920278104576e-32\n",
      "n=77 3.8403305284514504e-32\n",
      "n=78 1.8504802086698676e-32\n",
      "n=79 2.231358944163897e-32\n",
      "n=80 1.8705589817707698e-31\n",
      "n=81 6.638766327062701e-32\n",
      "n=82 6.222755924768402e-33\n",
      "n=83 2.75114928745232e-32\n",
      "n=84 5.27088888552165e-32\n",
      "n=85 3.1714393690585907e-32\n",
      "n=86 1.5495403078775147e-31\n",
      "n=87 6.82941670652039e-32\n",
      "n=88 1.0805267869771445e-31\n",
      "n=89 4.895989519684111e-32\n",
      "n=90 1.1240932723828419e-31\n",
      "n=91 1.4898116893567362e-32\n",
      "n=92 5.162604189471476e-32\n",
      "n=93 2.568200169708745e-32\n",
      "n=94 9.508105486852116e-32\n",
      "n=95 3.8592930726006744e-32\n",
      "n=96 1.1991593043980705e-31\n",
      "n=97 5.413317125493078e-32\n",
      "n=98 3.1562581039274373e-32\n",
      "n=99 4.243362374432802e-32\n",
      "n=100 2.0642119527519056e-32\n",
      "n=0 0.015510122473597445\n",
      "n=1 0.004113520322890351\n",
      "n=2 0.0033329908063853553\n",
      "n=3 0.0018356585929686458\n",
      "n=4 9.115071273861874e-33\n",
      "n=5 5.19317594376196e-33\n",
      "n=6 1.8916362351361576e-32\n",
      "n=7 2.8221547699931772e-34\n",
      "n=8 4.761182703829043e-33\n",
      "n=9 1.4484322770649814e-32\n",
      "n=10 2.2902956890530747e-32\n",
      "n=11 1.440516982270554e-32\n",
      "n=12 1.915118115126803e-32\n",
      "n=13 1.7769851701649294e-30\n",
      "n=14 2.0389263756076657e-33\n",
      "n=15 1.0029312959575658e-32\n",
      "n=16 4.217909527934008e-33\n",
      "n=17 1.2556609473308246e-32\n",
      "n=18 2.578475815260815e-33\n",
      "n=19 4.296722117890209e-33\n",
      "n=20 5.2214183477577e-33\n",
      "n=21 3.190062854082806e-33\n",
      "n=22 3.677957301068054e-33\n",
      "n=23 1.3370077103728786e-30\n",
      "n=24 2.123528449820035e-33\n",
      "n=25 1.409430482495413e-33\n",
      "n=26 1.486017035307894e-33\n",
      "n=27 2.3304050274168534e-33\n",
      "n=28 5.550018226635453e-33\n",
      "n=29 1.6906470918990376e-33\n",
      "n=30 5.364018801143092e-33\n",
      "n=31 5.760327154628209e-33\n",
      "n=32 5.6896570860160165e-33\n",
      "n=33 7.3654190991858385e-31\n",
      "n=34 4.3812326013071005e-32\n",
      "n=35 2.4899318545863793e-33\n",
      "n=36 1.379640988271295e-33\n",
      "n=37 2.2064568062937606e-33\n",
      "n=38 4.9093038809812696e-32\n",
      "n=39 1.2237081477902242e-33\n",
      "n=40 1.8575677738798125e-32\n",
      "n=41 7.147267846432531e-32\n",
      "n=42 4.5338129412104726e-32\n",
      "n=43 6.464120633726502e-33\n",
      "n=44 3.860868365382625e-33\n",
      "n=45 8.160868925378719e-33\n",
      "n=46 3.2138122742599864e-33\n",
      "n=47 1.7548325284670816e-33\n",
      "n=48 1.5399931288606773e-33\n",
      "n=49 2.5195835482846185e-33\n",
      "n=50 4.300854224943066e-33\n",
      "n=51 5.1515646541528754e-33\n",
      "n=52 4.078503020723937e-33\n",
      "n=53 4.45252120806356e-33\n",
      "n=54 3.4310185724767245e-33\n",
      "n=55 3.2449357218011295e-33\n",
      "n=56 1.262631209843115e-33\n",
      "n=57 4.0173277807786325e-33\n",
      "n=58 8.883709404985702e-34\n",
      "n=59 2.0683397116395206e-33\n",
      "n=60 1.109379148241163e-33\n",
      "n=61 4.72699006090538e-34\n",
      "n=62 2.1352297628533216e-33\n",
      "n=63 5.635669074579915e-33\n",
      "n=64 2.9697175320456126e-33\n",
      "n=65 3.744278645787216e-33\n",
      "n=66 1.4046208717083971e-33\n",
      "n=67 5.6532360345924564e-33\n",
      "n=68 5.884234408027392e-33\n",
      "n=69 1.1259767676794778e-33\n",
      "n=70 2.0017044610467458e-32\n",
      "n=71 1.3219960935175207e-31\n",
      "n=72 1.6331448411734096e-33\n",
      "n=73 1.9327857067666217e-33\n",
      "n=74 2.095260720322241e-32\n",
      "n=75 1.3052909752372084e-32\n",
      "n=76 6.183179613736075e-33\n",
      "n=77 1.369022154233863e-33\n",
      "n=78 3.968471162979165e-33\n",
      "n=79 5.841069370934795e-33\n",
      "n=80 4.162655194841005e-33\n",
      "n=81 7.750201023867905e-33\n",
      "n=82 7.216022115301157e-33\n",
      "n=83 9.221462218252622e-34\n",
      "n=84 2.197029015720544e-33\n",
      "n=85 3.324136015399058e-33\n",
      "n=86 5.001965423788266e-34\n",
      "n=87 2.0560019091502163e-33\n",
      "n=88 7.577295243732428e-34\n",
      "n=89 5.794314024938049e-33\n",
      "n=90 1.3343524357640632e-32\n",
      "n=91 3.5371771181427474e-33\n",
      "n=92 6.45820562762307e-33\n",
      "n=93 1.3774058264981594e-33\n",
      "n=94 7.882637000878854e-34\n",
      "n=95 1.8835194582822875e-33\n",
      "n=96 3.766292466013245e-33\n",
      "n=97 6.226524955368109e-33\n",
      "n=98 2.9743699757463568e-33\n",
      "n=99 4.665297882771104e-33\n",
      "n=100 2.3632209191363474e-33\n",
      "n=0 0.6858617893122767\n",
      "n=1 0.7563838091486053\n",
      "n=2 0.9099432996104557\n",
      "n=3 0.10531141218855995\n",
      "n=4 8.104649218783791e-30\n",
      "n=5 5.2057026402326666e-30\n",
      "n=6 1.908057053740035e-28\n",
      "n=7 6.730499800459862e-30\n",
      "n=8 1.2358174025208506e-31\n",
      "n=9 7.018133603075138e-30\n",
      "n=10 2.6251426542143926e-31\n",
      "n=11 6.222219098611641e-32\n",
      "n=12 5.92069508641299e-32\n",
      "n=13 4.82022139771387e-31\n",
      "n=14 1.2523379723779643e-31\n",
      "n=15 2.9480648236841565e-32\n",
      "n=16 3.708142582610696e-31\n",
      "n=17 5.39534972460101e-31\n",
      "n=18 3.011103752428214e-31\n",
      "n=19 1.167954591324503e-31\n",
      "n=20 2.811280602754308e-31\n",
      "n=21 1.3450108371741148e-31\n",
      "n=22 1.1693450805660656e-31\n",
      "n=23 1.1287455894560751e-31\n",
      "n=24 1.5653539078486616e-31\n",
      "n=25 1.5578218055909096e-31\n",
      "n=26 1.3001976890324867e-31\n",
      "n=27 2.277305851718699e-31\n",
      "n=28 2.6978522004042954e-31\n",
      "n=29 1.054649343911505e-30\n",
      "n=30 6.909046043917811e-32\n",
      "n=31 4.272229018535111e-31\n",
      "n=32 7.734496519432518e-32\n",
      "n=33 2.2671971030873296e-31\n",
      "n=34 7.688211450318295e-32\n",
      "n=35 9.253818079675994e-32\n",
      "n=36 2.0047147805726566e-31\n",
      "n=37 3.479566666071765e-32\n",
      "n=38 2.6499617654055174e-31\n",
      "n=39 3.426270655357578e-32\n",
      "n=40 1.628301307248827e-31\n",
      "n=41 1.809115798013741e-31\n",
      "n=42 1.0225865194031864e-30\n",
      "n=43 2.1905722640746856e-31\n",
      "n=44 2.5169297932059257e-31\n",
      "n=45 7.547862466653407e-32\n",
      "n=46 6.4028333261069e-31\n",
      "n=47 1.2785940227608892e-31\n",
      "n=48 1.577537113045284e-31\n",
      "n=49 9.26373256680926e-32\n",
      "n=50 1.2232763628775685e-31\n",
      "n=51 1.636143989545878e-31\n",
      "n=52 7.603283994614194e-32\n",
      "n=53 2.7663420114420676e-31\n",
      "n=54 4.735079920102471e-31\n",
      "n=55 8.185817524372108e-32\n",
      "n=56 3.5605696587005613e-31\n",
      "n=57 1.0990051745652014e-31\n",
      "n=58 1.0122058523460056e-31\n",
      "n=59 2.6614408024662234e-31\n",
      "n=60 2.8153583884674294e-31\n",
      "n=61 5.227914488007928e-32\n",
      "n=62 2.0353887903020193e-31\n",
      "n=63 2.116857682784472e-31\n",
      "n=64 1.4576092112080681e-31\n",
      "n=65 1.808073042812725e-31\n",
      "n=66 5.508321724160636e-31\n",
      "n=67 1.7606341466182047e-31\n",
      "n=68 2.1843763948946855e-31\n",
      "n=69 3.2031046664236384e-31\n",
      "n=70 3.4312825535922453e-31\n",
      "n=71 6.504020652625928e-32\n",
      "n=72 1.0754469083911567e-31\n",
      "n=73 2.542586046316102e-31\n",
      "n=74 2.5546451267579545e-31\n",
      "n=75 3.038132088196913e-31\n",
      "n=76 4.797844279436547e-32\n",
      "n=77 5.238083243181809e-31\n",
      "n=78 4.3479596587623136e-32\n",
      "n=79 3.700004007203367e-32\n",
      "n=80 1.4832488089599203e-31\n",
      "n=81 3.2683604406439044e-31\n",
      "n=82 3.21897070612886e-31\n",
      "n=83 3.076142986157247e-31\n",
      "n=84 7.525476212573654e-32\n",
      "n=85 2.250186469868129e-31\n",
      "n=86 2.9495393042084114e-31\n",
      "n=87 1.3718327486570367e-31\n",
      "n=88 4.9015679829187585e-32\n",
      "n=89 2.702939974587982e-31\n",
      "n=90 7.059658294364555e-32\n",
      "n=91 4.0875517630181855e-31\n",
      "n=92 1.8650676978526026e-32\n",
      "n=93 1.2186943359904166e-30\n",
      "n=94 1.9614342722258816e-31\n",
      "n=95 1.4235755500546298e-31\n",
      "n=96 1.4824707499474245e-31\n",
      "n=97 6.681953160846586e-32\n",
      "n=98 1.5369493014609465e-32\n",
      "n=99 8.03886400451495e-31\n",
      "n=100 1.3331059443477049e-31\n",
      "n=0 0.7138334417753145\n",
      "n=1 0.782283558442385\n",
      "n=2 0.7100030889545754\n",
      "n=3 0.35432978171048257\n",
      "n=4 0.3831709464015306\n",
      "n=5 0.43065640836410324\n",
      "n=6 0.3769545653325693\n",
      "n=7 2.6005031157301797e-31\n",
      "n=8 5.118320910422221e-32\n",
      "n=9 1.446379287587057e-31\n",
      "n=10 4.294332282475451e-31\n",
      "n=11 7.99551744725882e-29\n",
      "n=12 4.808831595804516e-31\n",
      "n=13 7.454268945370847e-32\n",
      "n=14 1.6080734415439864e-31\n",
      "n=15 2.290121390009531e-31\n",
      "n=16 2.333793777428456e-29\n",
      "n=17 1.1558240929668597e-31\n",
      "n=18 3.9296827134183648e-31\n",
      "n=19 4.4302872794299795e-32\n",
      "n=20 1.368691671329421e-31\n",
      "n=21 2.1398111387260973e-31\n",
      "n=22 1.154646494364764e-31\n",
      "n=23 2.534019680349199e-32\n",
      "n=24 6.705967934092498e-31\n",
      "n=25 4.328152851758756e-31\n",
      "n=26 6.208579602560181e-32\n",
      "n=27 7.829710872846493e-32\n",
      "n=28 3.5834786907321134e-32\n",
      "n=29 6.407130346870186e-32\n",
      "n=30 1.043896725674873e-31\n",
      "n=31 6.63313155182937e-32\n",
      "n=32 2.1484187112401187e-31\n",
      "n=33 4.755826571384583e-32\n",
      "n=34 1.8200563553113755e-31\n",
      "n=35 1.2869579038901983e-31\n",
      "n=36 2.1522362471593917e-32\n",
      "n=37 2.2560506615621015e-32\n",
      "n=38 4.963112528273417e-31\n",
      "n=39 4.225092240682733e-32\n",
      "n=40 7.478352603982343e-32\n",
      "n=41 1.510646391152599e-29\n",
      "n=42 4.529996983945197e-32\n",
      "n=43 4.656109641652604e-31\n",
      "n=44 3.3795982987964576e-31\n",
      "n=45 7.086423000007544e-31\n",
      "n=46 6.227437269336195e-32\n",
      "n=47 7.10257220862043e-31\n",
      "n=48 1.1216048704865265e-31\n",
      "n=49 1.7187772294339111e-31\n",
      "n=50 6.201971136259668e-32\n",
      "n=51 5.306911402927015e-31\n",
      "n=52 1.0765937681651353e-31\n",
      "n=53 1.8809615062259583e-31\n",
      "n=54 7.10723925172824e-32\n",
      "n=55 1.9053992451508683e-31\n",
      "n=56 2.3952395044617855e-31\n",
      "n=57 2.7531493391822758e-31\n",
      "n=58 1.3612129611889388e-32\n",
      "n=59 1.4738855835195854e-31\n",
      "n=60 6.497962256230015e-31\n",
      "n=61 3.0829147200105555e-31\n",
      "n=62 2.7228854759586674e-31\n",
      "n=63 1.5368711201463724e-31\n",
      "n=64 7.471007612492703e-32\n",
      "n=65 1.4869842907180825e-31\n",
      "n=66 1.166376544394204e-31\n",
      "n=67 3.8853996727267754e-31\n",
      "n=68 1.4862406147989627e-31\n",
      "n=69 5.605408317454646e-31\n",
      "n=70 2.094356450925395e-31\n",
      "n=71 2.9868313145449413e-32\n",
      "n=72 4.449005432484388e-31\n",
      "n=73 6.265836689390747e-32\n",
      "n=74 2.7486586137094966e-31\n",
      "n=75 1.6144689351531981e-31\n",
      "n=76 1.948321263567401e-32\n",
      "n=77 7.477651832443173e-32\n",
      "n=78 3.811567908848826e-32\n",
      "n=79 5.7726279595384835e-31\n",
      "n=80 3.0468821915832018e-31\n",
      "n=81 5.805343979395762e-32\n",
      "n=82 1.8542700955653823e-31\n",
      "n=83 1.3722460980939328e-31\n",
      "n=84 3.411868440844056e-31\n",
      "n=85 1.458089144252948e-31\n",
      "n=86 1.158329589577061e-31\n",
      "n=87 7.298130372428978e-32\n",
      "n=88 1.9408740166388822e-31\n",
      "n=89 1.0753401241566164e-31\n",
      "n=90 9.13501465980827e-32\n",
      "n=91 3.2272674597803737e-32\n",
      "n=92 6.150795931503831e-31\n",
      "n=93 1.663757606017696e-31\n",
      "n=94 2.2986031092101595e-31\n",
      "n=95 8.79288559978653e-32\n",
      "n=96 1.265906125000406e-31\n",
      "n=97 1.816542844130034e-32\n",
      "n=98 4.689066045216432e-31\n",
      "n=99 1.8805099376269924e-31\n",
      "n=100 2.3646072074404257e-31\n",
      "n=0 0.7802636135068506\n",
      "n=1 0.63142557049123\n",
      "n=2 0.04300228551237248\n",
      "n=3 0.03767390406642709\n",
      "n=4 7.48181432004278e-30\n",
      "n=5 8.977229035391683e-31\n",
      "n=6 6.481909820829681e-31\n",
      "n=7 2.6070593817017533e-31\n",
      "n=8 1.7052417318117644e-31\n",
      "n=9 8.525222454214156e-32\n",
      "n=10 1.022279830552791e-31\n",
      "n=11 2.3284190611352453e-31\n",
      "n=12 1.9259791652453442e-31\n",
      "n=13 6.915957792416258e-31\n",
      "n=14 6.646522485526854e-32\n",
      "n=15 1.8505002307138438e-31\n",
      "n=16 1.6894500969418397e-31\n",
      "n=17 4.178344849873103e-31\n",
      "n=18 1.1352961348436557e-31\n",
      "n=19 1.3933791494992854e-31\n",
      "n=20 1.997581808227266e-31\n",
      "n=21 1.2934450163438121e-31\n",
      "n=22 1.8150405055535204e-31\n",
      "n=23 1.8968032334492088e-31\n",
      "n=24 1.999984125762631e-31\n",
      "n=25 6.120319334062974e-32\n",
      "n=26 2.394808315443296e-31\n",
      "n=27 1.032865503079887e-31\n",
      "n=28 1.4215829991424882e-32\n",
      "n=29 1.1997971495133155e-31\n",
      "n=30 2.7725989765336025e-31\n",
      "n=31 2.8792142583183112e-31\n",
      "n=32 1.4792529810406495e-31\n",
      "n=33 1.339778409681641e-31\n",
      "n=34 1.09050587194764e-31\n",
      "n=35 1.444575696577111e-31\n",
      "n=36 4.046910827468953e-31\n",
      "n=37 1.3935142387067087e-31\n",
      "n=38 1.1617514000949385e-31\n",
      "n=39 1.4616400179984955e-31\n",
      "n=40 5.971761596348617e-32\n",
      "n=41 1.959658338153913e-31\n",
      "n=42 1.5347986002371586e-31\n",
      "n=43 2.675630144961971e-31\n",
      "n=44 1.776929349301752e-31\n",
      "n=45 8.632427985929773e-32\n",
      "n=46 5.212344905650272e-31\n",
      "n=47 1.3003173445810118e-31\n",
      "n=48 1.2652601757245037e-31\n",
      "n=49 1.210182393037691e-31\n",
      "n=50 1.5249155763158557e-31\n",
      "n=51 1.674013540508058e-31\n",
      "n=52 1.678939440041561e-31\n",
      "n=53 1.585819416263273e-31\n",
      "n=54 1.94244193336836e-31\n",
      "n=55 6.442380771653393e-31\n",
      "n=56 2.3839384907831607e-31\n",
      "n=57 2.5221236365511535e-31\n",
      "n=58 3.2427392559053955e-31\n",
      "n=59 2.0579065060834623e-31\n",
      "n=60 2.496159782872508e-31\n",
      "n=61 4.535749627044556e-31\n",
      "n=62 6.12480612831021e-30\n",
      "n=63 1.4832983277651118e-30\n",
      "n=64 3.7422748205574545e-30\n",
      "n=65 7.912818586481039e-31\n",
      "n=66 1.4325513357226215e-30\n",
      "n=67 1.511383177343372e-31\n",
      "n=68 2.3480843507230645e-31\n",
      "n=69 3.43384996360629e-32\n",
      "n=70 5.289114904481745e-32\n",
      "n=71 1.235248681128857e-31\n",
      "n=72 1.3286895343260987e-31\n",
      "n=73 2.628510260709198e-31\n",
      "n=74 3.2181688709391424e-31\n",
      "n=75 1.500050581273951e-31\n",
      "n=76 2.3766377816787286e-31\n",
      "n=77 1.0038585668692184e-31\n",
      "n=78 7.3573217317222554e-31\n",
      "n=79 2.1767427522710535e-31\n",
      "n=80 3.114591023727065e-32\n",
      "n=81 7.724798714315349e-32\n",
      "n=82 7.976641689135927e-32\n",
      "n=83 1.5453862094202943e-31\n",
      "n=84 1.2294078456929365e-31\n",
      "n=85 5.226344604827703e-31\n",
      "n=86 4.886665533874605e-31\n",
      "n=87 3.147925672974906e-31\n",
      "n=88 1.650927766266881e-31\n",
      "n=89 1.9488489874407769e-31\n",
      "n=90 2.002541077834063e-31\n",
      "n=91 1.3910935974257405e-31\n",
      "n=92 2.5777471093204456e-31\n",
      "n=93 9.439572890613228e-32\n",
      "n=94 1.1773875438309323e-31\n",
      "n=95 4.471431194347346e-31\n",
      "n=96 1.1991735611659912e-30\n",
      "n=97 2.1895168163279347e-31\n",
      "n=98 2.5289274146132364e-31\n",
      "n=99 2.6128328810969198e-31\n",
      "n=100 1.9901779423940285e-31\n",
      "n=0 1.9347303851467896\n",
      "n=1 0.358420433172454\n",
      "n=2 0.42652724724273205\n",
      "n=3 0.2553656055374494\n",
      "n=4 1.8638461365625188e-29\n",
      "n=5 1.3800416913442542e-30\n",
      "n=6 7.870859986940458e-31\n",
      "n=7 3.5512927783248736e-31\n",
      "n=8 4.076465390418141e-31\n",
      "n=9 5.341183898345785e-31\n",
      "n=10 2.3948900837614237e-31\n",
      "n=11 3.0137371283919726e-31\n",
      "n=12 9.30525447229345e-32\n",
      "n=13 6.080065491363949e-32\n",
      "n=14 1.303410273660018e-31\n",
      "n=15 4.008212983616087e-31\n",
      "n=16 1.921609759355549e-30\n",
      "n=17 3.6517004685740366e-31\n",
      "n=18 1.2731762364291514e-30\n",
      "n=19 2.4014782780217347e-31\n",
      "n=20 8.451514517143893e-32\n",
      "n=21 4.337552992842672e-31\n",
      "n=22 5.577683805078543e-31\n",
      "n=23 4.16862072857983e-31\n",
      "n=24 1.7730988224241189e-31\n",
      "n=25 6.727430612968284e-32\n",
      "n=26 2.62551172126608e-31\n",
      "n=27 2.093916442673249e-31\n",
      "n=28 1.6868572050035234e-31\n",
      "n=29 3.0880665826117912e-31\n",
      "n=30 2.07347715360194e-31\n",
      "n=31 7.140452008962265e-32\n",
      "n=32 2.7166290639314054e-31\n",
      "n=33 3.4143801347535834e-31\n",
      "n=34 1.1889509222621528e-31\n",
      "n=35 3.323427139699231e-31\n",
      "n=36 6.026377810587492e-31\n",
      "n=37 3.049109405617899e-31\n",
      "n=38 6.816413342388446e-31\n",
      "n=39 3.1550279251138723e-31\n",
      "n=40 5.166099227933673e-31\n",
      "n=41 1.9591856060012095e-31\n",
      "n=42 2.1571502288095755e-31\n",
      "n=43 2.3309511048305405e-31\n",
      "n=44 8.551739148705271e-31\n",
      "n=45 5.136950945626838e-32\n",
      "n=46 2.19009128809863e-31\n",
      "n=47 1.8904818689578568e-31\n",
      "n=48 4.4642946466369585e-31\n",
      "n=49 3.151265687707659e-31\n",
      "n=50 2.9318662750343285e-31\n",
      "n=51 6.109189507743045e-31\n",
      "n=52 4.172685494005426e-31\n",
      "n=53 5.321032187798969e-31\n",
      "n=54 4.917181840212946e-31\n",
      "n=55 4.451976471411747e-31\n",
      "n=56 6.842749004231944e-31\n",
      "n=57 1.7120182402670774e-32\n",
      "n=58 6.459574754058783e-31\n",
      "n=59 8.314357795322224e-31\n",
      "n=60 2.972384933100706e-31\n",
      "n=61 5.079298900143072e-31\n",
      "n=62 5.620336486780738e-31\n",
      "n=63 3.081922794581896e-31\n",
      "n=64 8.5788928540598e-31\n",
      "n=65 7.4889843093337605e-31\n",
      "n=66 5.428948621254577e-31\n",
      "n=67 1.133577576069023e-31\n",
      "n=68 1.4984669348006616e-31\n",
      "n=69 4.536699601523931e-31\n",
      "n=70 6.845647433455181e-31\n",
      "n=71 8.210273676426746e-31\n",
      "n=72 2.6832685249442227e-31\n",
      "n=73 1.2877598999713409e-30\n",
      "n=74 1.0682181833019728e-31\n",
      "n=75 6.731163292860011e-32\n",
      "n=76 5.457416154066219e-31\n",
      "n=77 6.032088860274066e-32\n",
      "n=78 9.954903059177893e-32\n",
      "n=79 9.104748003330759e-32\n",
      "n=80 6.6605617520769045e-31\n",
      "n=81 9.434789469374806e-31\n",
      "n=82 2.652879913511573e-30\n",
      "n=83 7.3272007713683214e-31\n",
      "n=84 1.332240110124563e-31\n",
      "n=85 7.791840130095982e-31\n",
      "n=86 7.799894235643116e-31\n",
      "n=87 3.366847611667707e-30\n",
      "n=88 3.2056017013366828e-31\n",
      "n=89 4.381008306743033e-31\n",
      "n=90 2.501230007973007e-31\n",
      "n=91 6.43000171839045e-31\n",
      "n=92 6.424991440243046e-31\n",
      "n=93 1.6288354146384554e-31\n",
      "n=94 2.169863273303862e-31\n",
      "n=95 3.4516402051628172e-31\n",
      "n=96 7.170736780622421e-31\n",
      "n=97 5.5107262762991235e-31\n",
      "n=98 2.0460011886824593e-31\n",
      "n=99 2.8895008515635115e-31\n",
      "n=100 2.4497315231834583e-31\n",
      "n=0 0.08428612802432123\n",
      "n=1 0.05008344087978962\n",
      "n=2 0.00028019993227532293\n",
      "n=3 0.00021143192643366366\n",
      "n=4 7.517482694231235e-32\n",
      "n=5 1.5249908548654255e-31\n",
      "n=6 3.06827748863233e-32\n",
      "n=7 1.490969858961212e-31\n",
      "n=8 3.9912087237294006e-32\n",
      "n=9 6.456940015208978e-32\n",
      "n=10 5.812626003887692e-32\n",
      "n=11 1.4582391732789187e-31\n",
      "n=12 4.12283231324841e-32\n",
      "n=13 6.811038138653808e-32\n",
      "n=14 4.7454849957295584e-32\n",
      "n=15 4.5951539165483966e-32\n",
      "n=16 2.4353701763749888e-32\n",
      "n=17 5.448025297831017e-32\n",
      "n=18 1.8400139235389216e-32\n",
      "n=19 1.2064261439750436e-32\n",
      "n=20 2.7601083780494087e-32\n",
      "n=21 2.8786013960044286e-32\n",
      "n=22 1.9440040605444775e-32\n",
      "n=23 3.966966065272455e-32\n",
      "n=24 9.906406277366085e-33\n",
      "n=25 3.348933020811529e-32\n",
      "n=26 5.347044270591399e-32\n",
      "n=27 5.618002987823821e-32\n",
      "n=28 7.217978007549077e-32\n",
      "n=29 1.8438286578286213e-31\n",
      "n=30 7.075545617922559e-32\n",
      "n=31 1.6396464538372054e-32\n",
      "n=32 2.170175480895469e-33\n",
      "n=33 5.476187431511058e-32\n",
      "n=34 1.615922695806002e-31\n",
      "n=35 6.999700677894766e-32\n",
      "n=36 7.614834537985537e-33\n",
      "n=37 1.0311795414546422e-32\n",
      "n=38 9.317746797588666e-33\n",
      "n=39 3.4083846422146137e-32\n",
      "n=40 1.449283769880339e-32\n",
      "n=41 1.964676511709889e-32\n",
      "n=42 2.5797948855536653e-32\n",
      "n=43 2.2648559540881005e-31\n",
      "n=44 2.3124856662448655e-31\n",
      "n=45 8.04489183154015e-32\n",
      "n=46 5.40038444488392e-32\n",
      "n=47 2.773384482361003e-32\n",
      "n=48 6.668552275059134e-32\n",
      "n=49 3.66294844049514e-32\n",
      "n=50 1.4979159210672073e-31\n",
      "n=51 2.751627157711926e-32\n",
      "n=52 4.572675573481794e-32\n",
      "n=53 4.6699333976846986e-32\n",
      "n=54 2.313622914857997e-32\n",
      "n=55 1.903632632021692e-32\n",
      "n=56 3.9694220392722017e-32\n",
      "n=57 4.762216819670315e-32\n",
      "n=58 4.620471595814375e-32\n",
      "n=59 3.6104167659461347e-32\n",
      "n=60 7.97613974446469e-33\n",
      "n=61 2.3732559391626408e-32\n",
      "n=62 1.6866414747671549e-32\n",
      "n=63 3.1916173307265186e-32\n",
      "n=64 4.7938459492418695e-32\n",
      "n=65 4.390713295686716e-32\n",
      "n=66 1.7253679701415933e-33\n",
      "n=67 1.9450605271996932e-32\n",
      "n=68 7.674513391035756e-32\n",
      "n=69 1.8369095617444318e-32\n",
      "n=70 1.630487145864567e-32\n",
      "n=71 3.174454785179032e-32\n",
      "n=72 2.612008168983886e-30\n",
      "n=73 2.709962589767023e-32\n",
      "n=74 1.4877568257218284e-31\n",
      "n=75 4.6558597845229805e-32\n",
      "n=76 1.8151579446441623e-32\n",
      "n=77 1.5723374236021893e-32\n",
      "n=78 1.806337948431482e-30\n",
      "n=79 2.538776606654178e-31\n",
      "n=80 6.003609208716509e-30\n",
      "n=81 1.885371683976054e-30\n",
      "n=82 2.3668964077000824e-31\n",
      "n=83 3.777288953989715e-32\n",
      "n=84 4.872171613449356e-32\n",
      "n=85 2.4002188812857193e-32\n",
      "n=86 4.4071204604398213e-32\n",
      "n=87 2.5607423024631927e-32\n",
      "n=88 4.7993790392356425e-32\n",
      "n=89 5.081296500589053e-33\n",
      "n=90 6.621577163951378e-32\n",
      "n=91 6.054811318031382e-32\n",
      "n=92 7.292304155932103e-33\n",
      "n=93 1.7585991604327392e-32\n",
      "n=94 3.3183708419490903e-32\n",
      "n=95 7.662799449665886e-33\n",
      "n=96 4.335770949956469e-32\n",
      "n=97 9.823853479495015e-33\n",
      "n=98 1.4121188351115483e-32\n",
      "n=99 1.7252271099263518e-32\n",
      "n=100 1.4423058711777087e-32\n",
      "n=0 1.922998924865721\n",
      "n=1 0.18121827728784984\n",
      "n=2 0.1566789800911264\n",
      "n=3 0.009907036688456926\n",
      "n=4 0.010667703730142003\n",
      "n=5 8.698364298937057e-28\n",
      "n=6 2.014472029857218e-30\n",
      "n=7 2.7574225483871244e-31\n",
      "n=8 3.3206483664900615e-31\n",
      "n=9 4.845084843430942e-31\n",
      "n=10 9.007274019239457e-32\n",
      "n=11 2.232222435778099e-31\n",
      "n=12 4.3020871597671475e-31\n",
      "n=13 4.8050427815185005e-31\n",
      "n=14 4.819481446133287e-31\n",
      "n=15 1.8126206597912635e-30\n",
      "n=16 1.0260424195365626e-30\n",
      "n=17 2.574434953161359e-29\n",
      "n=18 6.733905359454099e-31\n",
      "n=19 1.6275674665629164e-30\n",
      "n=20 8.163146499919117e-31\n",
      "n=21 1.6539058427043397e-30\n",
      "n=22 4.4009702845874065e-31\n",
      "n=23 4.4423832680667364e-31\n",
      "n=24 1.1781433089529441e-31\n",
      "n=25 5.022924451751127e-31\n",
      "n=26 1.3514623449513125e-31\n",
      "n=27 1.9549849096676813e-31\n",
      "n=28 6.035872549870254e-31\n",
      "n=29 3.78277239588824e-31\n",
      "n=30 1.6358530054862267e-30\n",
      "n=31 5.419522648158567e-31\n",
      "n=32 1.0024050618196054e-31\n",
      "n=33 2.779493896235935e-30\n",
      "n=34 9.901325976358637e-31\n",
      "n=35 1.3179792662878414e-30\n",
      "n=36 1.273902357306142e-30\n",
      "n=37 4.339263179304274e-31\n",
      "n=38 1.1238693636602466e-30\n",
      "n=39 3.9009806366630013e-31\n",
      "n=40 9.780459570888355e-31\n",
      "n=41 2.9048896694259233e-31\n",
      "n=42 1.0267428442653288e-29\n",
      "n=43 7.234491259080965e-31\n",
      "n=44 3.3663501115464293e-31\n",
      "n=45 5.442123126190985e-31\n",
      "n=46 3.267146127512509e-31\n",
      "n=47 2.0197085503977443e-31\n",
      "n=48 1.1840126281299974e-31\n",
      "n=49 9.918005292421563e-31\n",
      "n=50 1.2319005544143365e-30\n",
      "n=51 1.6188780752659798e-31\n",
      "n=52 2.9709507648167783e-31\n",
      "n=53 3.3080217261842974e-31\n",
      "n=54 7.701487796360918e-31\n",
      "n=55 9.434320381487361e-32\n",
      "n=56 4.495834133052964e-31\n",
      "n=57 7.546616379327781e-31\n",
      "n=58 8.403362546057843e-31\n",
      "n=59 9.132549626274107e-31\n",
      "n=60 1.5151220437803967e-30\n",
      "n=61 1.7177967928447712e-30\n",
      "n=62 1.8992874328019185e-30\n",
      "n=63 2.2918737955727907e-31\n",
      "n=64 1.335039108447267e-30\n",
      "n=65 4.399529323109987e-31\n",
      "n=66 1.1173690163972066e-30\n",
      "n=67 5.376050386772079e-31\n",
      "n=68 5.884298354920077e-31\n",
      "n=69 1.1653287240927773e-31\n",
      "n=70 4.779071479162781e-31\n",
      "n=71 7.757485639639976e-31\n",
      "n=72 3.885802020467633e-31\n",
      "n=73 1.442570153309982e-31\n",
      "n=74 9.271633170019242e-31\n",
      "n=75 3.8405579216651815e-31\n",
      "n=76 8.941329987257506e-31\n",
      "n=77 8.405551531619625e-31\n",
      "n=78 3.0836796395566914e-31\n",
      "n=79 6.185160246764899e-31\n",
      "n=80 9.921124202486206e-32\n",
      "n=81 5.1792794534540734e-31\n",
      "n=82 3.755675181300644e-31\n",
      "n=83 2.025919264791154e-31\n",
      "n=84 2.9510858879267476e-31\n",
      "n=85 1.8636882028584018e-31\n",
      "n=86 1.0005143678421191e-30\n",
      "n=87 3.3920442337308526e-31\n",
      "n=88 3.155718208915722e-31\n",
      "n=89 3.7372060375208365e-31\n",
      "n=90 7.116042277063155e-31\n",
      "n=91 7.137328570101962e-31\n",
      "n=92 6.316386637295596e-31\n",
      "n=93 7.736563396968848e-32\n",
      "n=94 1.1404520018536868e-30\n",
      "n=95 5.411958784741769e-32\n",
      "n=96 3.3360615261636105e-31\n",
      "n=97 6.910596679716476e-31\n",
      "n=98 1.8991547510069257e-30\n",
      "n=99 7.891068903327207e-31\n",
      "n=100 2.9985089333364538e-31\n",
      "n=0 1.4905613766706365\n",
      "n=1 1.0029567202379224\n",
      "n=2 0.1122270830404695\n",
      "n=3 0.004401485355941753\n",
      "n=4 0.0057789575313843084\n",
      "n=5 0.005506068526630504\n",
      "n=6 0.005187993122837358\n",
      "n=7 0.005859737124061954\n",
      "n=8 3.3257382556324956e-31\n",
      "n=9 6.559147239044933e-31\n",
      "n=10 9.902452931405303e-31\n",
      "n=11 7.574850275072133e-31\n",
      "n=12 9.923627196340908e-31\n",
      "n=13 1.0309941570411021e-31\n",
      "n=14 5.372288620378304e-31\n",
      "n=15 1.552520731090517e-31\n",
      "n=16 2.8808632166543595e-31\n",
      "n=17 3.2628571196635854e-31\n",
      "n=18 7.468765858640356e-32\n",
      "n=19 2.1366457507786795e-31\n",
      "n=20 5.83270743949671e-31\n",
      "n=21 1.6071637493938445e-31\n",
      "n=22 1.4693831846663122e-30\n",
      "n=23 3.3312516591421035e-30\n",
      "n=24 1.0011725619982641e-30\n",
      "n=25 3.980525738461123e-30\n",
      "n=26 3.621921558920042e-31\n",
      "n=27 4.061439680665757e-31\n",
      "n=28 3.588511374500157e-31\n",
      "n=29 1.0998547334289356e-31\n",
      "n=30 1.2856123093150994e-30\n",
      "n=31 2.2238350764186507e-31\n",
      "n=32 2.2068716380173946e-31\n",
      "n=33 2.111574336135517e-31\n",
      "n=34 6.92168972924082e-31\n",
      "n=35 9.06248249641422e-32\n",
      "n=36 1.2575675395784418e-31\n",
      "n=37 1.1164220213886609e-31\n",
      "n=38 1.3233701360801027e-31\n",
      "n=39 3.439161704612253e-31\n",
      "n=40 2.0017548550714933e-31\n",
      "n=41 9.580805945655989e-31\n",
      "n=42 1.1789708867706312e-31\n",
      "n=43 3.0025195394310404e-31\n",
      "n=44 7.7530998585785e-31\n",
      "n=45 2.6930326083899993e-31\n",
      "n=46 9.15152950908139e-31\n",
      "n=47 4.999256488909806e-32\n",
      "n=48 2.5826007864810344e-31\n",
      "n=49 1.0181487763704386e-30\n",
      "n=50 2.1950859240241768e-31\n",
      "n=51 1.6768485665920357e-31\n",
      "n=52 1.1801869875845252e-31\n",
      "n=53 4.878742852785773e-31\n",
      "n=54 2.7746586679587243e-31\n",
      "n=55 2.0873285943108796e-31\n",
      "n=56 6.497916014842738e-32\n",
      "n=57 1.9428781278978434e-31\n",
      "n=58 1.091983209854252e-31\n",
      "n=59 5.726518264870557e-31\n",
      "n=60 4.522848160814992e-31\n",
      "n=61 3.319359327764712e-31\n",
      "n=62 4.002548175316792e-31\n",
      "n=63 1.4813190057034544e-31\n",
      "n=64 1.15594225877997e-31\n",
      "n=65 5.999475810928665e-31\n",
      "n=66 1.2080066642589326e-31\n",
      "n=67 4.7906756539983383e-32\n",
      "n=68 9.161629676836771e-32\n",
      "n=69 4.426004394393611e-31\n",
      "n=70 1.8898451202878772e-30\n",
      "n=71 1.5441839333510505e-31\n",
      "n=72 3.130376051620424e-31\n",
      "n=73 2.159537619196083e-31\n",
      "n=74 1.9627314146463464e-31\n",
      "n=75 5.206875550637413e-32\n",
      "n=76 7.989444177344526e-32\n",
      "n=77 5.978437439657606e-31\n",
      "n=78 2.6602698704301092e-31\n",
      "n=79 9.344654994546818e-32\n",
      "n=80 9.869780888537472e-31\n",
      "n=81 1.580353279078909e-30\n",
      "n=82 1.649879409660705e-30\n",
      "n=83 8.371260999229318e-32\n",
      "n=84 2.47136855952835e-32\n",
      "n=85 5.242062862779766e-31\n",
      "n=86 4.680631401654914e-31\n",
      "n=87 1.5821533561754453e-31\n",
      "n=88 4.4520212007175795e-31\n",
      "n=89 2.017247626671157e-31\n",
      "n=90 3.2917453835511027e-31\n",
      "n=91 2.5935854995363667e-31\n",
      "n=92 1.929974397270449e-31\n",
      "n=93 7.76303511262345e-31\n",
      "n=94 4.090621809761219e-31\n",
      "n=95 2.626802547208386e-31\n",
      "n=96 1.2625443284737179e-31\n",
      "n=97 6.70450346459023e-31\n",
      "n=98 8.240661418598781e-31\n",
      "n=99 4.129541326243822e-31\n",
      "n=100 6.053295020444904e-32\n",
      "n=0 0.9067089316174535\n",
      "n=1 0.9530550644410308\n",
      "n=2 1.3129726357990505\n",
      "n=3 0.797254201414198\n",
      "n=4 0.24855657939021997\n",
      "n=5 3.8320371118072663e-31\n",
      "n=6 2.9003016716792282e-31\n",
      "n=7 2.284709717551936e-31\n",
      "n=8 3.104721586192746e-31\n",
      "n=9 2.8427455395513547e-31\n",
      "n=10 2.8256710222876824e-31\n",
      "n=11 2.346394774750929e-31\n",
      "n=12 7.322607321190009e-31\n",
      "n=13 7.867863592716338e-32\n",
      "n=14 9.84315717145415e-31\n",
      "n=15 3.0516796640060565e-30\n",
      "n=16 5.0586590330955005e-31\n",
      "n=17 5.044243161432562e-31\n",
      "n=18 7.3186253180153875e-31\n",
      "n=19 1.2621591424848406e-31\n",
      "n=20 9.330150453831985e-31\n",
      "n=21 1.0050696621721183e-32\n",
      "n=22 3.4112482341961233e-31\n",
      "n=23 7.276431035349035e-32\n",
      "n=24 3.5119046804648664e-31\n",
      "n=25 2.762973421721888e-31\n",
      "n=26 1.7885868268704547e-31\n",
      "n=27 4.38871047719575e-31\n",
      "n=28 6.677999998949599e-32\n",
      "n=29 3.908404114862976e-31\n",
      "n=30 1.0904577207893908e-31\n",
      "n=31 9.608140326121637e-32\n",
      "n=32 4.601204906631586e-31\n",
      "n=33 3.6312596599726045e-31\n",
      "n=34 3.5696291568845054e-31\n",
      "n=35 1.7575888890724755e-31\n",
      "n=36 1.8788228886185544e-31\n",
      "n=37 2.655518001787775e-31\n",
      "n=38 5.380900482864779e-32\n",
      "n=39 7.332002188610556e-31\n",
      "n=40 7.041992415920463e-32\n",
      "n=41 8.302474235506955e-32\n",
      "n=42 7.048903596457283e-32\n",
      "n=43 1.5352677179193118e-31\n",
      "n=44 7.647066927402662e-32\n",
      "n=45 2.976828396717447e-31\n",
      "n=46 2.92210886560321e-32\n",
      "n=47 4.974543566059055e-32\n",
      "n=48 6.69156850910854e-32\n",
      "n=49 3.6145395549540185e-31\n",
      "n=50 6.012810492216883e-32\n",
      "n=51 1.6208941044082606e-31\n",
      "n=52 4.583534499391833e-31\n",
      "n=53 1.2399175119191646e-31\n",
      "n=54 1.3468466679206088e-31\n",
      "n=55 9.53713000194068e-32\n",
      "n=56 1.4922224387945495e-31\n",
      "n=57 1.4402676182527073e-31\n",
      "n=58 1.8258597983883821e-31\n",
      "n=59 2.082683480108377e-31\n",
      "n=60 1.508784959600947e-31\n",
      "n=61 4.425508610447531e-31\n",
      "n=62 5.444928119208999e-32\n",
      "n=63 1.8098535745806178e-31\n",
      "n=64 1.157588773949938e-31\n",
      "n=65 6.89002009662933e-31\n",
      "n=66 7.953060965200504e-32\n",
      "n=67 1.2941251937806071e-30\n",
      "n=68 1.641845171225064e-30\n",
      "n=69 3.261222939502852e-31\n",
      "n=70 8.156243267120736e-31\n",
      "n=71 1.5558100668866239e-31\n",
      "n=72 3.266058739838462e-31\n",
      "n=73 3.088399329914064e-31\n",
      "n=74 3.2863324895104677e-31\n",
      "n=75 3.6771456261759208e-31\n",
      "n=76 2.7101377504239215e-31\n",
      "n=77 3.1490670765929276e-31\n",
      "n=78 2.520626601432717e-31\n",
      "n=79 1.8053171514739867e-31\n",
      "n=80 2.0768789942165802e-31\n",
      "n=81 1.5851361640125816e-31\n",
      "n=82 6.963247385465328e-31\n",
      "n=83 5.382077969736718e-32\n",
      "n=84 1.09178489627582e-31\n",
      "n=85 4.5149899852696257e-32\n",
      "n=86 1.2506055888586814e-31\n",
      "n=87 2.3554313905989e-32\n",
      "n=88 4.7290923755228916e-32\n",
      "n=89 2.3582635563908815e-31\n",
      "n=90 1.266262708069317e-31\n",
      "n=91 9.461450251075252e-32\n",
      "n=92 9.476509688437427e-32\n",
      "n=93 3.5248965736341155e-31\n",
      "n=94 2.885975511882976e-31\n",
      "n=95 3.2155788765362076e-31\n",
      "n=96 1.415978018617455e-32\n",
      "n=97 1.6383161429596405e-31\n",
      "n=98 2.3469058135876573e-31\n",
      "n=99 3.7950583034443662e-31\n",
      "n=100 7.857341412712626e-31\n",
      "n=0 2.9152247202008477\n",
      "n=1 1.1004780303361732\n",
      "n=2 0.3045640980077927\n",
      "n=3 0.004397238396006952\n",
      "n=4 9.24559507388646e-30\n",
      "n=5 6.390243182922173e-31\n",
      "n=6 4.604433699580431e-31\n",
      "n=7 1.7845628727465508e-31\n",
      "n=8 1.7534509999840395e-31\n",
      "n=9 1.6483214443637987e-31\n",
      "n=10 4.428988632376746e-31\n",
      "n=11 4.3455566321128914e-30\n",
      "n=12 3.9767974431866015e-31\n",
      "n=13 4.049935228718874e-31\n",
      "n=14 4.666089867830258e-30\n",
      "n=15 6.577123220812992e-31\n",
      "n=16 1.8190942543857225e-31\n",
      "n=17 3.2575832179371603e-31\n",
      "n=18 1.0306808597244063e-30\n",
      "n=19 2.065183307913956e-30\n",
      "n=20 2.7751728054451156e-30\n",
      "n=21 2.337189020302891e-30\n",
      "n=22 1.0144853620527078e-30\n",
      "n=23 7.948211973257793e-31\n",
      "n=24 6.2860147622954655e-30\n",
      "n=25 6.6050415775612825e-31\n",
      "n=26 8.088856188031782e-31\n",
      "n=27 1.2924942552841376e-30\n",
      "n=28 1.2416117224581761e-30\n",
      "n=29 4.2681830163270665e-31\n",
      "n=30 3.180356764174561e-31\n",
      "n=31 1.2340691700789223e-31\n",
      "n=32 1.5934572301460667e-31\n",
      "n=33 2.982926062538897e-30\n",
      "n=34 1.9053114341865722e-30\n",
      "n=35 7.0184700896133025e-31\n",
      "n=36 1.6143198185971083e-30\n",
      "n=37 1.997874895793323e-30\n",
      "n=38 1.5851645285748813e-30\n",
      "n=39 3.7038321505043367e-31\n",
      "n=40 4.6038517493379535e-31\n",
      "n=41 2.562506044463954e-31\n",
      "n=42 7.883803761655806e-31\n",
      "n=43 2.0887608497745342e-30\n",
      "n=44 6.912646913183883e-31\n",
      "n=45 8.571738787060935e-31\n",
      "n=46 8.762744796156869e-31\n",
      "n=47 4.2585293223046295e-31\n",
      "n=48 2.502271011245175e-30\n",
      "n=49 3.5420966602303673e-31\n",
      "n=50 1.104067562167683e-30\n",
      "n=51 6.102891098212268e-31\n",
      "n=52 4.376045008891674e-30\n",
      "n=53 1.3713619237380979e-30\n",
      "n=54 1.0229778669377398e-30\n",
      "n=55 4.240348561477343e-31\n",
      "n=56 1.8535817186248634e-30\n",
      "n=57 5.472732064277424e-31\n",
      "n=58 3.981305263373267e-31\n",
      "n=59 1.6725354011936238e-30\n",
      "n=60 1.0998744932794789e-30\n",
      "n=61 7.82865459084791e-31\n",
      "n=62 1.897911000703731e-31\n",
      "n=63 2.345271681098458e-30\n",
      "n=64 1.9457721713400185e-30\n",
      "n=65 5.319016158656688e-31\n",
      "n=66 3.98775808211763e-31\n",
      "n=67 3.975706718505226e-31\n",
      "n=68 6.510323806964003e-31\n",
      "n=69 8.43719220086501e-31\n",
      "n=70 3.246318911339159e-31\n",
      "n=71 9.388734745943688e-31\n",
      "n=72 4.707935749054598e-31\n",
      "n=73 1.3890297775713497e-30\n",
      "n=74 1.5955891011142102e-30\n",
      "n=75 1.673891692069002e-30\n",
      "n=76 2.5167521273603443e-31\n",
      "n=77 8.752691823219435e-31\n",
      "n=78 3.6023070395151628e-31\n",
      "n=79 2.598030870014439e-30\n",
      "n=80 1.0673213908871736e-30\n",
      "n=81 1.3988988337334024e-30\n",
      "n=82 6.323312350201389e-31\n",
      "n=83 4.148513762236201e-31\n",
      "n=84 6.492489087494493e-31\n",
      "n=85 2.605560111980194e-31\n",
      "n=86 1.62111129591387e-30\n",
      "n=87 5.768011924971281e-31\n",
      "n=88 6.040086422913527e-31\n",
      "n=89 1.3384948059766271e-30\n",
      "n=90 1.1945266354452244e-30\n",
      "n=91 2.7927128310413568e-31\n",
      "n=92 2.8612988193975152e-31\n",
      "n=93 1.06760065072911e-31\n",
      "n=94 2.1331880372648694e-30\n",
      "n=95 2.170426178768796e-30\n",
      "n=96 2.2743001615455895e-30\n",
      "n=97 2.5817071835897586e-31\n",
      "n=98 2.624887677059719e-30\n",
      "n=99 5.347666750156112e-31\n",
      "n=100 1.2027005008223627e-30\n",
      "n=0 0.05975222226037506\n",
      "n=1 0.07539190096498523\n",
      "n=2 0.10491873926344955\n",
      "n=3 0.08212684526211987\n",
      "n=4 6.807179202521813e-32\n",
      "n=5 2.1168011893406705e-31\n",
      "n=6 2.4459585663860663e-30\n",
      "n=7 6.297261317206263e-31\n",
      "n=8 5.329824084810334e-32\n",
      "n=9 1.4484626350794832e-32\n",
      "n=10 9.896246703443204e-32\n",
      "n=11 1.5610950447958585e-32\n",
      "n=12 1.7866989186981943e-32\n",
      "n=13 2.0222450260558987e-32\n",
      "n=14 5.393857167999665e-32\n",
      "n=15 3.152163887363774e-32\n",
      "n=16 5.474891371702705e-30\n",
      "n=17 5.618578252627668e-32\n",
      "n=18 5.711832989455187e-32\n",
      "n=19 7.797579253846451e-33\n",
      "n=20 1.940739563595035e-32\n",
      "n=21 1.063057319905577e-32\n",
      "n=22 3.2381383756717e-32\n",
      "n=23 4.850504620049194e-32\n",
      "n=24 2.8453147926474334e-32\n",
      "n=25 2.3016959638023947e-33\n",
      "n=26 3.995118877954238e-33\n",
      "n=27 4.6552736393811445e-33\n",
      "n=28 3.0245089996897816e-32\n",
      "n=29 2.014330024553131e-32\n",
      "n=30 2.5705412330481874e-32\n",
      "n=31 1.0827898812893097e-31\n",
      "n=32 1.8441706596890797e-30\n",
      "n=33 4.338116157521568e-32\n",
      "n=34 1.2235857767938837e-29\n",
      "n=35 9.405658915664276e-30\n",
      "n=36 4.438321943929949e-32\n",
      "n=37 8.600887791889445e-33\n",
      "n=38 4.959977529066294e-32\n",
      "n=39 1.0241793921803343e-32\n",
      "n=40 3.6631060775072264e-32\n",
      "n=41 1.6695525734312763e-32\n",
      "n=42 9.635730525442467e-30\n",
      "n=43 2.2250808170083597e-30\n",
      "n=44 4.842106428683881e-32\n",
      "n=45 1.4941377425027765e-32\n",
      "n=46 4.4211856105607775e-32\n",
      "n=47 5.704263643812063e-32\n",
      "n=48 9.427183729495494e-32\n",
      "n=49 1.661044142045627e-29\n",
      "n=50 1.7167413695296815e-29\n",
      "n=51 3.1523497085796673e-32\n",
      "n=52 3.144348730721767e-32\n",
      "n=53 1.74179061184477e-32\n",
      "n=54 2.2055278953510114e-29\n",
      "n=55 1.951065207228112e-32\n",
      "n=56 8.697361381406254e-33\n",
      "n=57 4.2952148341486236e-32\n",
      "n=58 1.4230327537831942e-32\n",
      "n=59 3.592678821801394e-32\n",
      "n=60 4.739846123723836e-32\n",
      "n=61 6.237604303865672e-33\n",
      "n=62 5.655586797797042e-32\n",
      "n=63 1.9193479720999936e-32\n",
      "n=64 1.3650197007163345e-32\n",
      "n=65 5.082044009521744e-32\n",
      "n=66 1.9004142135960953e-32\n",
      "n=67 2.963504218063904e-32\n",
      "n=68 8.080318931494886e-33\n",
      "n=69 2.4369547776028303e-32\n",
      "n=70 2.2078845292746586e-29\n",
      "n=71 1.1987022833674864e-31\n",
      "n=72 2.6167154891246577e-31\n",
      "n=73 2.113430405003089e-31\n",
      "n=74 2.954103335836619e-32\n",
      "n=75 1.3956130375486415e-32\n",
      "n=76 1.771071575574164e-32\n",
      "n=77 7.23089637968784e-33\n",
      "n=78 3.249937774106752e-32\n",
      "n=79 2.576465165925551e-32\n",
      "n=80 1.0191292077455043e-32\n",
      "n=81 6.955655991738062e-32\n",
      "n=82 1.6798695265531477e-32\n",
      "n=83 3.7300963646373345e-34\n",
      "n=84 2.8983122976278585e-32\n",
      "n=85 1.9028956851967063e-31\n",
      "n=86 1.5289368265699817e-31\n",
      "n=87 1.3688821786942788e-31\n",
      "n=88 3.957779127067783e-32\n",
      "n=89 6.5026878235936e-33\n",
      "n=90 4.090995494992693e-32\n",
      "n=91 1.9298509279992618e-33\n",
      "n=92 1.9615536894167402e-32\n",
      "n=93 5.736895748735589e-32\n",
      "n=94 5.710931252608546e-33\n",
      "n=95 4.631343833194623e-33\n",
      "n=96 6.888567284306684e-33\n",
      "n=97 8.733544447597284e-33\n",
      "n=98 1.0452284597516717e-32\n",
      "n=99 5.995263885714446e-32\n",
      "n=100 1.938372959440217e-32\n",
      "n=0 0.26277447950782895\n",
      "n=1 0.011538140146889472\n",
      "n=2 0.008308214924626479\n",
      "n=3 0.009767302464889119\n",
      "n=4 4.91324035784161e-31\n",
      "n=5 5.55626701121739e-31\n",
      "n=6 5.932761645326624e-32\n",
      "n=7 1.1186498611122322e-31\n",
      "n=8 4.8535345929095665e-32\n",
      "n=9 9.814870946891179e-33\n",
      "n=10 6.472014171400737e-33\n",
      "n=11 2.3949850576529197e-33\n",
      "n=12 5.416929760689457e-30\n",
      "n=13 1.1444399214380208e-29\n",
      "n=14 3.619358014769399e-30\n",
      "n=15 4.735976144928077e-32\n",
      "n=16 1.2797273687724851e-31\n",
      "n=17 2.1914615765279665e-32\n",
      "n=18 3.724026884609935e-32\n",
      "n=19 6.557929708085041e-32\n",
      "n=20 1.8659063295070685e-31\n",
      "n=21 9.878752105000728e-33\n",
      "n=22 9.912645224398742e-32\n",
      "n=23 2.388895652414346e-31\n",
      "n=24 1.1837316640307465e-31\n",
      "n=25 7.289331399174392e-32\n",
      "n=26 7.024046467218369e-32\n",
      "n=27 4.182812655766523e-32\n",
      "n=28 3.8556950636265996e-32\n",
      "n=29 1.5748644979162389e-31\n",
      "n=30 3.477777270378154e-32\n",
      "n=31 1.0868925046161363e-32\n",
      "n=32 2.270482282521629e-32\n",
      "n=33 4.446800147354997e-31\n",
      "n=34 3.319354560611384e-32\n",
      "n=35 3.7256961945939197e-31\n",
      "n=36 3.819786510980474e-31\n",
      "n=37 3.490002192938202e-31\n",
      "n=38 2.1435414362050157e-31\n",
      "n=39 8.455900968586305e-32\n",
      "n=40 6.056744577284885e-32\n",
      "n=41 7.960573998844945e-33\n",
      "n=42 9.063288257056756e-33\n",
      "n=43 7.060139860939233e-32\n",
      "n=44 1.1683704737771467e-31\n",
      "n=45 6.623479258129126e-32\n",
      "n=46 3.3763041660523147e-31\n",
      "n=47 6.447986340623915e-32\n",
      "n=48 8.801815669757628e-32\n",
      "n=49 2.5963910288591297e-32\n",
      "n=50 4.39372524317109e-32\n",
      "n=51 8.669352837938115e-31\n",
      "n=52 1.8416115455925724e-31\n",
      "n=53 2.1910085666099868e-32\n",
      "n=54 2.5802276975545096e-32\n",
      "n=55 3.321865956573829e-32\n",
      "n=56 2.370594811493037e-32\n",
      "n=57 5.816338003297439e-32\n",
      "n=58 1.0552882929206924e-31\n",
      "n=59 1.342277351485113e-31\n",
      "n=60 9.253585680951269e-32\n",
      "n=61 2.59689330537475e-31\n",
      "n=62 3.1540013260934312e-31\n",
      "n=63 1.450198194528454e-31\n",
      "n=64 6.786279875705705e-31\n",
      "n=65 2.045956036664203e-31\n",
      "n=66 1.4165286546215118e-31\n",
      "n=67 1.0537428041578864e-31\n",
      "n=68 1.718176830680489e-31\n",
      "n=69 1.701336315934824e-32\n",
      "n=70 4.8207878118781394e-31\n",
      "n=71 3.223861808805523e-31\n",
      "n=72 6.970716322941488e-33\n",
      "n=73 4.088952415979616e-31\n",
      "n=74 1.1988722771222353e-30\n",
      "n=75 8.00595053512578e-31\n",
      "n=76 3.2189127830278794e-30\n",
      "n=77 7.956971393367897e-31\n",
      "n=78 3.782424214927069e-32\n",
      "n=79 2.0568530471334902e-31\n",
      "n=80 1.587384368419275e-32\n",
      "n=81 7.346505954662973e-32\n",
      "n=82 2.544959174348181e-31\n",
      "n=83 8.549934010698206e-33\n",
      "n=84 1.8736924465504155e-32\n",
      "n=85 6.388386645508081e-32\n",
      "n=86 4.9187754715942086e-32\n",
      "n=87 5.853282473259025e-32\n",
      "n=88 5.359953611142903e-32\n",
      "n=89 7.367536549515165e-32\n",
      "n=90 1.4252614538289678e-32\n",
      "n=91 1.3063507506653396e-31\n",
      "n=92 4.6585380593524375e-32\n",
      "n=93 6.164637472920938e-32\n",
      "n=94 3.6688512039603316e-31\n",
      "n=95 8.690750531529079e-32\n",
      "n=96 3.0540684368670297e-32\n",
      "n=97 1.3668417774806103e-31\n",
      "n=98 1.6503951858560527e-31\n",
      "n=99 1.1123510381798776e-31\n",
      "n=100 1.1184953427755276e-30\n",
      "n=0 0.5406064303384819\n",
      "n=1 0.2524824955509988\n",
      "n=2 0.21077096070353935\n",
      "n=3 0.004909330384199814\n",
      "n=4 0.005118565842373217\n",
      "n=5 0.004972773860921871\n",
      "n=6 1.1703711805251427e-31\n",
      "n=7 1.3070967133283215e-31\n",
      "n=8 1.9625249969072573e-31\n",
      "n=9 2.32522861397598e-31\n",
      "n=10 2.689759033994582e-31\n",
      "n=11 6.195364934356988e-31\n",
      "n=12 2.317326580619999e-31\n",
      "n=13 3.972106594106862e-31\n",
      "n=14 7.411705714831639e-32\n",
      "n=15 6.48722901051272e-31\n",
      "n=16 1.663880288708584e-30\n",
      "n=17 1.672033384194568e-31\n",
      "n=18 2.202881530682117e-31\n",
      "n=19 2.392600050843076e-31\n",
      "n=20 1.2137731082671745e-30\n",
      "n=21 1.5906198204854248e-31\n",
      "n=22 2.3428471784232942e-31\n",
      "n=23 2.154343328930231e-31\n",
      "n=24 1.988780093859516e-32\n",
      "n=25 2.965672781215317e-31\n",
      "n=26 5.9543251483314365e-31\n",
      "n=27 4.267922729755374e-31\n",
      "n=28 5.017602878491426e-31\n",
      "n=29 5.1702272251789536e-31\n",
      "n=30 4.336400980446327e-31\n",
      "n=31 3.0900783213160767e-31\n",
      "n=32 3.7854687931534486e-30\n",
      "n=33 2.1199069387800546e-30\n",
      "n=34 1.5650255701632169e-31\n",
      "n=35 5.101008516397378e-31\n",
      "n=36 2.084208980811796e-31\n",
      "n=37 2.568544119821338e-31\n",
      "n=38 8.959023753548563e-31\n",
      "n=39 2.684023642031329e-31\n",
      "n=40 2.6794246746179062e-30\n",
      "n=41 5.656881476742142e-31\n",
      "n=42 3.066680179353103e-31\n",
      "n=43 1.3217855641086866e-30\n",
      "n=44 6.979800848680403e-31\n",
      "n=45 9.371835045872159e-31\n",
      "n=46 1.9704532496065404e-31\n",
      "n=47 3.204606349516569e-31\n",
      "n=48 5.220675148553914e-31\n",
      "n=49 5.444283600079095e-31\n",
      "n=50 3.537403200389313e-31\n",
      "n=51 9.44921118080057e-31\n",
      "n=52 1.7241916430046694e-31\n",
      "n=53 5.847361668826033e-31\n",
      "n=54 2.8767702579860373e-31\n",
      "n=55 2.675330261222951e-31\n",
      "n=56 3.6196041786493578e-31\n",
      "n=57 4.177454077479115e-32\n",
      "n=58 9.1063674220757e-31\n",
      "n=59 2.4027091570109446e-31\n",
      "n=60 8.778464960970263e-32\n",
      "n=61 1.7800722143118656e-31\n",
      "n=62 2.0955280980345084e-31\n",
      "n=63 2.016471534109409e-31\n",
      "n=64 7.239881717706252e-32\n",
      "n=65 2.251398756959361e-31\n",
      "n=66 2.8769350823123423e-31\n",
      "n=67 6.824709142609295e-32\n",
      "n=68 4.3598096101466215e-32\n",
      "n=69 1.6646484677958085e-31\n",
      "n=70 7.318445894282017e-32\n",
      "n=71 1.2992747681482457e-31\n",
      "n=72 2.6217517482576973e-31\n",
      "n=73 7.322908128564985e-31\n",
      "n=74 2.590121328391967e-31\n",
      "n=75 1.6437530813298725e-31\n",
      "n=76 1.404183089716855e-29\n",
      "n=77 7.882213707458063e-31\n",
      "n=78 1.3910304625279645e-31\n",
      "n=79 2.9166684710468157e-31\n",
      "n=80 2.804337057715599e-31\n",
      "n=81 2.0409896901438038e-29\n",
      "n=82 1.546650458482798e-31\n",
      "n=83 5.411119467809013e-32\n",
      "n=84 4.486391832456806e-32\n",
      "n=85 3.329288354715627e-31\n",
      "n=86 1.8987420347075806e-31\n",
      "n=87 1.520102300779719e-31\n",
      "n=88 4.447405285329208e-31\n",
      "n=89 4.556153788154781e-31\n",
      "n=90 3.867946170963433e-31\n",
      "n=91 3.2583073485276365e-31\n",
      "n=92 5.331235327928395e-31\n",
      "n=93 3.5288490204581036e-31\n",
      "n=94 4.841932801650673e-31\n",
      "n=95 1.2275658176471168e-32\n",
      "n=96 7.677619613079834e-32\n",
      "n=97 1.6469934346255375e-31\n",
      "n=98 2.5484858454797443e-31\n",
      "n=99 8.258196915399358e-32\n",
      "n=100 8.368764362820497e-31\n",
      "n=0 1.033859030763195\n",
      "n=1 0.79063860927385\n",
      "n=2 0.6281716888660508\n",
      "n=3 0.48264280795044057\n",
      "n=4 2.5779411324608824e-31\n",
      "n=5 2.9275660643750844e-31\n",
      "n=6 2.387247371907911e-31\n",
      "n=7 3.612426789842571e-31\n",
      "n=8 1.4293908812202472e-31\n",
      "n=9 3.0754784375346896e-31\n",
      "n=10 1.5342172458888467e-31\n",
      "n=11 1.6968625064076816e-31\n",
      "n=12 4.793130737962099e-32\n",
      "n=13 1.1785265880804902e-31\n",
      "n=14 2.2482886661283754e-30\n",
      "n=15 9.128412152449419e-32\n",
      "n=16 1.6629051198238716e-31\n",
      "n=17 2.3958358753430794e-31\n",
      "n=18 9.249315551029523e-30\n",
      "n=19 7.0409252886480595e-31\n",
      "n=20 5.0509939272599054e-31\n",
      "n=21 1.9103799688098094e-31\n",
      "n=22 9.247285887828726e-32\n",
      "n=23 2.4776502374682485e-31\n",
      "n=24 3.238270168839518e-31\n",
      "n=25 5.7484437139917735e-31\n",
      "n=26 1.636300590532693e-31\n",
      "n=27 1.783323323497226e-31\n",
      "n=28 1.5822849296072894e-31\n",
      "n=29 7.128009738776991e-31\n",
      "n=30 7.319773248536696e-32\n",
      "n=31 1.978517366175663e-31\n",
      "n=32 3.1573954126352367e-31\n",
      "n=33 2.356173159656689e-31\n",
      "n=34 1.86524455924106e-31\n",
      "n=35 3.6558116616038377e-31\n",
      "n=36 3.043045586585076e-32\n",
      "n=37 4.4742212900112105e-32\n",
      "n=38 5.658445341391291e-32\n",
      "n=39 2.4095610032483588e-29\n",
      "n=40 1.7455623146573763e-31\n",
      "n=41 8.850429907605091e-32\n",
      "n=42 4.06871197306715e-31\n",
      "n=43 3.442502525664299e-31\n",
      "n=44 1.0343938238338251e-29\n",
      "n=45 1.2359142663093159e-29\n",
      "n=46 1.13381974745807e-31\n",
      "n=47 2.507484513138938e-31\n",
      "n=48 3.8930442798030616e-31\n",
      "n=49 2.92110943190806e-31\n",
      "n=50 7.572402341838364e-31\n",
      "n=51 7.55023630044764e-31\n",
      "n=52 5.386587696784714e-31\n",
      "n=53 1.9984060490376234e-31\n",
      "n=54 1.109810456438486e-31\n",
      "n=55 1.491924491711569e-30\n",
      "n=56 2.2742872902316047e-31\n",
      "n=57 2.3859588103634362e-31\n",
      "n=58 1.929921005153179e-31\n",
      "n=59 8.917112848352834e-31\n",
      "n=60 1.8165869700930236e-31\n",
      "n=61 2.673228900036105e-31\n",
      "n=62 4.979015275059262e-31\n",
      "n=63 3.311653701125832e-31\n",
      "n=64 3.5984170423997667e-31\n",
      "n=65 2.3704955951144044e-31\n",
      "n=66 2.2852894033965833e-31\n",
      "n=67 4.194601051283488e-31\n",
      "n=68 9.020083360230964e-32\n",
      "n=69 2.515386546494919e-31\n",
      "n=70 2.843378136608059e-32\n",
      "n=71 4.796999521245187e-31\n",
      "n=72 6.263548455793456e-32\n",
      "n=73 3.0666377516884867e-31\n",
      "n=74 1.1311132259509813e-31\n",
      "n=75 6.635755393020931e-31\n",
      "n=76 7.183230536063634e-31\n",
      "n=77 2.4224175222982856e-31\n",
      "n=78 4.8989860926764805e-31\n",
      "n=79 6.899704397294962e-31\n",
      "n=80 1.0211961791351651e-30\n",
      "n=81 2.6192099021033724e-31\n",
      "n=82 2.2919139588395762e-31\n",
      "n=83 2.2008898140218074e-31\n",
      "n=84 8.378283057048731e-31\n",
      "n=85 7.832501564404524e-31\n",
      "n=86 8.209475684754398e-31\n",
      "n=87 1.884566308393525e-31\n",
      "n=88 2.886555197727623e-31\n",
      "n=89 3.0435413705311553e-31\n",
      "n=90 3.4183438141826004e-31\n",
      "n=91 1.0695911756010872e-31\n",
      "n=92 3.228667095997384e-31\n",
      "n=93 3.531629224278813e-31\n",
      "n=94 5.0686177355758805e-31\n",
      "n=95 5.397227983012121e-31\n",
      "n=96 7.25466346838709e-31\n",
      "n=97 2.8730360276056234e-31\n",
      "n=98 3.2696512665862104e-31\n",
      "n=99 2.139724567221666e-30\n",
      "n=100 5.576196453240303e-31\n",
      "n=0 0.42125734254673813\n",
      "n=1 0.1051666413915715\n",
      "n=2 0.09544574801338873\n",
      "n=3 0.06310326584741076\n",
      "n=4 9.893550749281173e-31\n",
      "n=5 4.999808048549819e-31\n",
      "n=6 2.4661660538372266e-31\n",
      "n=7 1.3967364768197284e-31\n",
      "n=8 7.027031896989836e-32\n",
      "n=9 9.717132944440972e-32\n",
      "n=10 7.86439817019419e-32\n",
      "n=11 4.80122953557168e-32\n",
      "n=12 2.282577608226126e-31\n",
      "n=13 1.098019384664222e-31\n",
      "n=14 7.557492116375343e-32\n",
      "n=15 5.612603203203881e-32\n",
      "n=16 2.978504289469797e-32\n",
      "n=17 7.631141059923177e-32\n",
      "n=18 3.7666832243574416e-30\n",
      "n=19 2.3582104622206942e-30\n",
      "n=20 1.1945087675586581e-30\n",
      "n=21 5.707749386325271e-31\n",
      "n=22 1.685643540372575e-31\n",
      "n=23 8.576849198938106e-32\n",
      "n=24 5.883205894696943e-32\n",
      "n=25 8.613909084987107e-32\n",
      "n=26 2.6334252628281417e-31\n",
      "n=27 3.27365096781756e-32\n",
      "n=28 2.8342805011974928e-31\n",
      "n=29 2.1684660281121933e-31\n",
      "n=30 3.498572114600938e-32\n",
      "n=31 2.1570117728001145e-31\n",
      "n=32 3.8379836179005044e-32\n",
      "n=33 3.417362465875387e-32\n",
      "n=34 7.446080842778565e-32\n",
      "n=35 7.025911615957828e-32\n",
      "n=36 1.8090680668910474e-31\n",
      "n=37 8.148378685713085e-32\n",
      "n=38 9.515833936237553e-32\n",
      "n=39 2.109105548468108e-31\n",
      "n=40 4.8514604342913967e-32\n",
      "n=41 1.2704177887044411e-31\n",
      "n=42 9.655628323995432e-32\n",
      "n=43 1.4274989172433197e-30\n",
      "n=44 8.041222780808476e-32\n",
      "n=45 2.7970026750042816e-31\n",
      "n=46 6.633288942375954e-32\n",
      "n=47 3.196523141988105e-31\n",
      "n=48 3.4904324982409884e-32\n",
      "n=49 4.1196228466196445e-32\n",
      "n=50 2.74116669264191e-32\n",
      "n=51 1.5805058875748117e-32\n",
      "n=52 2.68559132040314e-32\n",
      "n=53 9.357521541378256e-32\n",
      "n=54 1.8518460278929595e-31\n",
      "n=55 2.5758455663448e-32\n",
      "n=56 2.03140339797933e-31\n",
      "n=57 4.138150090080633e-32\n",
      "n=58 1.4438844649311035e-31\n",
      "n=59 6.858222528450047e-32\n",
      "n=60 2.1827783020846434e-30\n",
      "n=61 9.854973991122831e-32\n",
      "n=62 2.0606425466977968e-32\n",
      "n=63 3.087616086622324e-32\n",
      "n=64 2.2520666351405707e-31\n",
      "n=65 7.607518623396136e-32\n",
      "n=66 6.063695086836657e-32\n",
      "n=67 9.763216121818513e-32\n",
      "n=68 7.364892269153712e-32\n",
      "n=69 1.1682051350265813e-31\n",
      "n=70 8.869701199419053e-32\n",
      "n=71 7.140030413839847e-32\n",
      "n=72 1.4192198020591183e-31\n",
      "n=73 1.430561813256361e-31\n",
      "n=74 4.640232637494728e-32\n",
      "n=75 7.214673308856503e-32\n",
      "n=76 7.411616330706746e-32\n",
      "n=77 3.097921621155012e-32\n",
      "n=78 8.314678148025845e-33\n",
      "n=79 8.716075141382409e-32\n",
      "n=80 1.7400064656063267e-31\n",
      "n=81 1.76490518127489e-31\n",
      "n=82 4.1741504402230254e-32\n",
      "n=83 3.1502993857281357e-31\n",
      "n=84 2.787081281085199e-31\n",
      "n=85 8.168767502548536e-33\n",
      "n=86 3.7028708540358073e-32\n",
      "n=87 5.027501901472771e-32\n",
      "n=88 6.709017556562993e-32\n",
      "n=89 3.7769500331714643e-32\n",
      "n=90 6.453215502802576e-32\n",
      "n=91 1.9736860424949745e-31\n",
      "n=92 1.47091356881553e-31\n",
      "n=93 1.379167967482355e-31\n",
      "n=94 1.7506801219070274e-31\n",
      "n=95 7.354234296973676e-32\n",
      "n=96 6.978274644542543e-32\n",
      "n=97 1.4862834670381723e-31\n",
      "n=98 9.490231939291187e-32\n",
      "n=99 1.0678226287546077e-31\n",
      "n=100 2.7976528476800853e-31\n",
      "n=0 1.1545805687307618\n",
      "n=1 0.5770908523377518\n",
      "n=2 0.9035679271609409\n",
      "n=3 0.984464389526047\n",
      "n=4 0.0010298439662563758\n",
      "n=5 1.901250582295912e-30\n",
      "n=6 1.4704472475529677e-30\n",
      "n=7 5.737349118052238e-31\n",
      "n=8 3.789330092005812e-31\n",
      "n=9 3.5368349557126523e-31\n",
      "n=10 2.99100214354557e-31\n",
      "n=11 2.464925275090642e-31\n",
      "n=12 3.7742223347775063e-29\n",
      "n=13 4.0273559645187636e-30\n",
      "n=14 1.9086003886104128e-31\n",
      "n=15 6.810412449779549e-32\n",
      "n=16 1.171746742617848e-31\n",
      "n=17 5.224390071963349e-31\n",
      "n=18 1.0406581302669976e-31\n",
      "n=19 2.5044030252279185e-31\n",
      "n=20 4.380129124490573e-31\n",
      "n=21 1.7676490127399023e-31\n",
      "n=22 2.021639128316626e-31\n",
      "n=23 1.9201273653567703e-31\n",
      "n=24 5.488211130311271e-31\n",
      "n=25 3.5403446549462116e-31\n",
      "n=26 3.198052556505784e-31\n",
      "n=27 2.2994707311157993e-31\n",
      "n=28 4.500406309809553e-31\n",
      "n=29 1.114720624366008e-31\n",
      "n=30 7.438380023329652e-32\n",
      "n=31 5.09157145966988e-31\n",
      "n=32 1.4169910684942979e-31\n",
      "n=33 4.745026155359598e-31\n",
      "n=34 2.9853897273786476e-31\n",
      "n=35 4.067564042545842e-32\n",
      "n=36 4.472814979779541e-32\n",
      "n=37 2.3046955311629486e-31\n",
      "n=38 1.4704738272260236e-30\n",
      "n=39 8.997704912364783e-31\n",
      "n=40 8.725034706473502e-32\n",
      "n=41 1.0103199664895711e-31\n",
      "n=42 4.872566528934416e-31\n",
      "n=43 6.1456348250943456e-31\n",
      "n=44 1.3734974385990663e-31\n",
      "n=45 5.866163321550447e-31\n",
      "n=46 1.1375119077103667e-31\n",
      "n=47 1.5688555249824506e-30\n",
      "n=48 3.2720086239067536e-31\n",
      "n=49 3.172842300384122e-31\n",
      "n=50 1.2468341389286618e-30\n",
      "n=51 8.053722506364365e-30\n",
      "n=52 8.205357457193969e-30\n",
      "n=53 5.258448486444057e-30\n",
      "n=54 6.76809081857099e-30\n",
      "n=55 6.6533276922452e-30\n",
      "n=56 2.316690499351485e-30\n",
      "n=57 2.8252675304300268e-30\n",
      "n=58 6.284355173207496e-30\n",
      "n=59 5.6039624338914155e-30\n",
      "n=60 3.5345414782467e-30\n",
      "n=61 6.651126411524606e-30\n",
      "n=62 2.9521130902900317e-31\n",
      "n=63 4.616947953780953e-31\n",
      "n=64 3.2516338105842017e-31\n",
      "n=65 2.880397942489577e-31\n",
      "n=66 1.4628925279459295e-31\n",
      "n=67 1.5770696638667955e-32\n",
      "n=68 5.630145493197952e-31\n",
      "n=69 3.2651205640635726e-31\n",
      "n=70 7.393227453871093e-31\n",
      "n=71 1.7336549190754691e-31\n",
      "n=72 3.321037484914892e-31\n",
      "n=73 3.8357526311108685e-31\n",
      "n=74 2.1916705685298523e-30\n",
      "n=75 1.5203765789464276e-30\n",
      "n=76 2.3549938851022513e-31\n",
      "n=77 1.7388306174433435e-31\n",
      "n=78 1.6267549618881572e-31\n",
      "n=79 5.34241644583866e-32\n",
      "n=80 4.943104189862932e-32\n",
      "n=81 3.7754023768436294e-31\n",
      "n=82 2.805528846047521e-31\n",
      "n=83 4.36988546542003e-31\n",
      "n=84 3.5189195167918563e-31\n",
      "n=85 5.380800372644896e-31\n",
      "n=86 1.4392016827686354e-31\n",
      "n=87 4.183478345898842e-31\n",
      "n=88 8.441904531929433e-31\n",
      "n=89 1.5256420904829959e-31\n",
      "n=90 8.88561149916345e-32\n",
      "n=91 1.1907743584099945e-31\n",
      "n=92 3.3820264185492085e-31\n",
      "n=93 1.3707815913482806e-30\n",
      "n=94 2.5172648049060294e-31\n",
      "n=95 2.359945408084891e-31\n",
      "n=96 2.236500955889702e-31\n",
      "n=97 1.5093820455552403e-31\n",
      "n=98 3.4050822789032546e-31\n",
      "n=99 8.425610997749551e-32\n",
      "n=100 6.445692520518816e-32\n",
      "n=0 0.8351338090403975\n",
      "n=1 0.7204056806733341\n",
      "n=2 0.4912212158004901\n",
      "n=3 0.5341804575148582\n",
      "n=4 3.445220482221019e-24\n",
      "n=5 7.3483997702064435e-28\n",
      "n=6 1.4523302442648472e-32\n",
      "n=7 5.708060681437568e-32\n",
      "n=8 1.3245197053103671e-31\n",
      "n=9 1.7295156003065773e-31\n",
      "n=10 2.6909798721670957e-31\n",
      "n=11 1.0985696280706233e-31\n",
      "n=12 2.893763133559092e-31\n",
      "n=13 1.8053862751972384e-31\n",
      "n=14 5.096453978108101e-31\n",
      "n=15 1.0869282396444014e-31\n",
      "n=16 1.1864801066924103e-31\n",
      "n=17 1.2553020691382894e-31\n",
      "n=18 2.167766202555011e-31\n",
      "n=19 3.685514959736849e-31\n",
      "n=20 7.788556038168536e-32\n",
      "n=21 3.6332191685532436e-32\n",
      "n=22 2.6427298448338683e-32\n",
      "n=23 1.3432554998115592e-30\n",
      "n=24 1.4603679627224176e-31\n",
      "n=25 7.726487701841997e-32\n",
      "n=26 2.4328887318986192e-29\n",
      "n=27 2.668545767785814e-31\n",
      "n=28 1.6462982644915267e-31\n",
      "n=29 3.859090706941914e-31\n",
      "n=30 3.9083220527876464e-32\n",
      "n=31 3.201422338014296e-32\n",
      "n=32 7.402209545402879e-32\n",
      "n=33 1.747993086139166e-31\n",
      "n=34 1.0598583170096068e-31\n",
      "n=35 5.046678223352347e-31\n",
      "n=36 5.670428296353442e-31\n",
      "n=37 2.612151774065226e-31\n",
      "n=38 4.076343232114118e-31\n",
      "n=39 6.606921742833724e-32\n",
      "n=40 8.030657111703664e-32\n",
      "n=41 8.972950515280081e-32\n",
      "n=42 3.6374956030352656e-32\n",
      "n=43 4.325672531677067e-31\n",
      "n=44 3.559385497813962e-31\n",
      "n=45 1.7990631230233887e-31\n",
      "n=46 4.945132256067364e-31\n",
      "n=47 9.361564087400138e-32\n",
      "n=48 1.3592857202773866e-31\n",
      "n=49 2.7451328271083364e-31\n",
      "n=50 4.407725288712005e-31\n",
      "n=51 3.60871409358758e-31\n",
      "n=52 4.046346515693787e-31\n",
      "n=53 2.154757237017908e-31\n",
      "n=54 1.674828723727093e-31\n",
      "n=55 1.2573061803972509e-31\n",
      "n=56 8.823387336512514e-32\n",
      "n=57 9.510299271224102e-32\n",
      "n=58 1.0576406670762732e-31\n",
      "n=59 2.2484544736800545e-31\n",
      "n=60 1.4142770983101349e-31\n",
      "n=61 1.1151897122534525e-31\n",
      "n=62 2.031227780519944e-31\n",
      "n=63 6.253814882128976e-31\n",
      "n=64 1.2654569228461467e-30\n",
      "n=65 5.532267135325629e-32\n",
      "n=66 5.5479054242806205e-31\n",
      "n=67 4.7535270157981384e-31\n",
      "n=68 3.606300007142437e-31\n",
      "n=69 3.8707783367554144e-31\n",
      "n=70 2.2236281819642287e-31\n",
      "n=71 1.5472921173207052e-31\n",
      "n=72 2.129266195565244e-31\n",
      "n=73 7.749274992695443e-32\n",
      "n=74 1.5347583177915397e-31\n",
      "n=75 2.7809517870666096e-31\n",
      "n=76 8.857103922263857e-32\n",
      "n=77 1.6518526256693304e-31\n",
      "n=78 7.538475941751184e-32\n",
      "n=79 1.367832153584438e-31\n",
      "n=80 5.20853606932028e-31\n",
      "n=81 9.283044304939737e-32\n",
      "n=82 2.12162349535029e-31\n",
      "n=83 2.7272159580415418e-31\n",
      "n=84 9.096934639026672e-32\n",
      "n=85 1.852119155983928e-31\n",
      "n=86 5.093712984123512e-31\n",
      "n=87 2.472566306801932e-32\n",
      "n=88 2.1671750755423774e-31\n",
      "n=89 1.1741708400849789e-31\n",
      "n=90 1.707249775972221e-31\n",
      "n=91 2.392047664399907e-31\n",
      "n=92 7.2123216125305365e-31\n",
      "n=93 2.7757142348843085e-31\n",
      "n=94 2.9658196095378094e-31\n",
      "n=95 9.693006381449527e-32\n",
      "n=96 4.500497481616945e-31\n",
      "n=97 1.5665571601601443e-31\n",
      "n=98 5.340379679579403e-32\n",
      "n=99 1.1944045456690314e-31\n",
      "n=100 2.5206466234766933e-32\n",
      "n=0 1.1872547617334916\n",
      "n=1 1.3648449416587878\n",
      "n=2 0.7339755125578485\n",
      "n=3 1.0986157133259389\n",
      "n=4 0.36503788339215315\n",
      "n=5 0.45572011296445797\n",
      "n=6 3.4291331633356226e-31\n",
      "n=7 2.0726250547393234e-31\n",
      "n=8 5.2328298402146935e-30\n",
      "n=9 9.457788123888918e-31\n",
      "n=10 2.375865316622716e-31\n",
      "n=11 9.515365801780774e-31\n",
      "n=12 1.813667803752812e-31\n",
      "n=13 4.730739903712942e-31\n",
      "n=14 6.643657426376912e-32\n",
      "n=15 1.8946609939225776e-30\n",
      "n=16 6.779902668482326e-31\n",
      "n=17 4.10596441603106e-31\n",
      "n=18 5.131116069132577e-31\n",
      "n=19 3.6480893499283105e-31\n",
      "n=20 4.143664971407773e-31\n",
      "n=21 2.0402129855987474e-32\n",
      "n=22 1.1744922653980984e-31\n",
      "n=23 2.630344661309694e-31\n",
      "n=24 3.961237454725018e-32\n",
      "n=25 2.723221083552937e-31\n",
      "n=26 2.055494021103891e-31\n",
      "n=27 3.0656920080576894e-31\n",
      "n=28 1.170523044153338e-31\n",
      "n=29 5.420005441611829e-32\n",
      "n=30 2.977474345993349e-31\n",
      "n=31 2.0829389995267412e-31\n",
      "n=32 9.956714577442416e-32\n",
      "n=33 8.908932413242516e-32\n",
      "n=34 4.565545720796561e-32\n",
      "n=35 1.5789617470225559e-31\n",
      "n=36 4.801300037300191e-31\n",
      "n=37 3.6965212441609894e-31\n",
      "n=38 1.4735087877205647e-30\n",
      "n=39 5.282637534897744e-31\n",
      "n=40 4.374608760937106e-31\n",
      "n=41 9.9844975470362e-32\n",
      "n=42 1.1044484294135926e-31\n",
      "n=43 2.8044817408190943e-32\n",
      "n=44 7.391786939314297e-31\n",
      "n=45 6.965955128555456e-32\n",
      "n=46 1.5700008395283701e-31\n",
      "n=47 2.21052566104307e-31\n",
      "n=48 8.589108863641043e-32\n",
      "n=49 4.070775673742708e-31\n",
      "n=50 2.271704923273995e-31\n",
      "n=51 1.809735349178091e-32\n",
      "n=52 3.488101419853164e-31\n",
      "n=53 2.0936387634405884e-31\n",
      "n=54 5.942074070789311e-31\n",
      "n=55 3.192843398680491e-31\n",
      "n=56 6.1830779541913624e-31\n",
      "n=57 1.0036141310823411e-31\n",
      "n=58 1.8042855394938746e-31\n",
      "n=59 2.5423829357896342e-31\n",
      "n=60 1.432206600333248e-32\n",
      "n=61 1.8785010592147036e-31\n",
      "n=62 5.755045744635293e-32\n",
      "n=63 9.488093871023717e-32\n",
      "n=64 1.8771467225928647e-31\n",
      "n=65 2.607810208350864e-31\n",
      "n=66 3.443356799540621e-31\n",
      "n=67 1.5727327759216369e-31\n",
      "n=68 5.393767029696216e-32\n",
      "n=69 1.3753572242910318e-31\n",
      "n=70 8.633976357330606e-31\n",
      "n=71 2.5424029578336103e-31\n",
      "n=72 9.54243465180607e-32\n",
      "n=73 3.050621785011109e-32\n",
      "n=74 1.3267254671550899e-31\n",
      "n=75 1.6997804809595613e-31\n",
      "n=76 2.1511001153425693e-31\n",
      "n=77 2.15767726740466e-31\n",
      "n=78 2.5720627556925067e-31\n",
      "n=79 1.3109676418304068e-31\n",
      "n=80 8.292011287383338e-31\n",
      "n=81 4.967439077454797e-31\n",
      "n=82 7.318172676806923e-32\n",
      "n=83 6.264155094676096e-32\n",
      "n=84 2.56520997278395e-32\n",
      "n=85 4.627885054892425e-31\n",
      "n=86 1.5637559878479279e-31\n",
      "n=87 3.155026332959148e-31\n",
      "n=88 2.2567618044530138e-31\n",
      "n=89 1.9289370647063435e-31\n",
      "n=90 2.4183563843784253e-31\n",
      "n=91 1.9005610612385944e-31\n",
      "n=92 5.00970811504427e-31\n",
      "n=93 4.470091505083431e-31\n",
      "n=94 4.472447908973309e-32\n",
      "n=95 3.816605955664363e-31\n",
      "n=96 4.159900465495891e-31\n",
      "n=97 1.6323291942742266e-31\n",
      "n=98 1.9152191042905792e-31\n",
      "n=99 5.38506840501918e-31\n",
      "n=100 6.30828342262051e-32\n",
      "n=0 1.2832933985190693\n",
      "n=1 0.654872119096299\n",
      "n=2 0.8528029604412184\n",
      "n=3 0.9668878988040654\n",
      "n=4 2.940458735206759e-30\n",
      "n=5 3.492429762675983e-29\n",
      "n=6 5.177619161210988e-30\n",
      "n=7 3.0923161422669282e-31\n",
      "n=8 2.42510047619111e-31\n",
      "n=9 3.7780934348971114e-31\n",
      "n=10 2.14168987385254e-31\n",
      "n=11 1.1787020193229494e-31\n",
      "n=12 1.2263055729934083e-30\n",
      "n=13 2.066527120765499e-31\n",
      "n=14 7.541503084114269e-32\n",
      "n=15 4.8906801026653945e-32\n",
      "n=16 4.559785137407441e-31\n",
      "n=17 1.2324125824353804e-31\n",
      "n=18 2.0520268704886607e-31\n",
      "n=19 2.391315213637138e-31\n",
      "n=20 1.1764114021489937e-31\n",
      "n=21 2.6873244189954223e-31\n",
      "n=22 1.169476719546268e-30\n",
      "n=23 6.798046930762852e-31\n",
      "n=24 3.183590800992067e-31\n",
      "n=25 1.6452152864343084e-31\n",
      "n=26 4.62835956541678e-31\n",
      "n=27 1.0327603873490117e-31\n",
      "n=28 2.0107395163968702e-31\n",
      "n=29 4.28111916359709e-31\n",
      "n=30 2.534624870464149e-31\n",
      "n=31 7.3756252169239255e-31\n",
      "n=32 3.042870155342617e-31\n",
      "n=33 2.754644251427746e-31\n",
      "n=34 4.064370049816289e-31\n",
      "n=35 1.6894506555926206e-31\n",
      "n=36 1.8335868474225283e-31\n",
      "n=37 2.0283970448739614e-31\n",
      "n=38 1.2854996018925493e-31\n",
      "n=39 2.1866741627986327e-31\n",
      "n=40 1.0708661626764617e-30\n",
      "n=41 1.3867077884317254e-31\n",
      "n=42 3.7289512348186066e-31\n",
      "n=43 1.313636770978581e-31\n",
      "n=44 1.670898682523744e-31\n",
      "n=45 7.545162351008604e-31\n",
      "n=46 1.0479614091650205e-31\n",
      "n=47 1.3088773642750473e-31\n",
      "n=48 6.948607465044665e-31\n",
      "n=49 1.7921598082895594e-31\n",
      "n=50 1.3197921193552958e-31\n",
      "n=51 3.8208619509764925e-31\n",
      "n=52 2.7690987370326383e-31\n",
      "n=53 7.652506249349557e-31\n",
      "n=54 9.63218871971639e-30\n",
      "n=55 5.737108281466123e-30\n",
      "n=56 1.3626038377617095e-30\n",
      "n=57 1.3778751154998852e-31\n",
      "n=58 4.501184309232631e-31\n",
      "n=59 1.4064418051007418e-31\n",
      "n=60 1.7974704170966071e-31\n",
      "n=61 5.99951966873928e-31\n",
      "n=62 8.672043030082886e-32\n",
      "n=63 1.4068098293376396e-31\n",
      "n=64 3.589727475314051e-31\n",
      "n=65 3.011138552647506e-31\n",
      "n=66 8.001685929142953e-31\n",
      "n=67 2.670484934029363e-31\n",
      "n=68 4.173608414889667e-31\n",
      "n=69 4.586728492121386e-31\n",
      "n=70 8.492382369191523e-31\n",
      "n=71 2.959189452689657e-31\n",
      "n=72 4.124367534737279e-31\n",
      "n=73 2.7889467799124806e-31\n",
      "n=74 1.0586589012323596e-31\n",
      "n=75 5.333948789740348e-31\n",
      "n=76 2.717012343058952e-31\n",
      "n=77 5.104326931828783e-31\n",
      "n=78 4.112262779007606e-30\n",
      "n=79 4.87726706874303e-31\n",
      "n=80 1.1965287891918504e-31\n",
      "n=81 7.849561299303e-32\n",
      "n=82 3.7757456118832233e-31\n",
      "n=83 1.6919199218375312e-31\n",
      "n=84 4.0331642641332227e-32\n",
      "n=85 2.3180268754438366e-31\n",
      "n=86 1.6648044207477175e-31\n",
      "n=87 2.6934149340868804e-31\n",
      "n=88 3.1406907114808415e-31\n",
      "n=89 2.2208165149315566e-31\n",
      "n=90 2.2923981991983597e-31\n",
      "n=91 2.3164417969623795e-31\n",
      "n=92 1.8868359500928388e-31\n",
      "n=93 4.3564192777380615e-31\n",
      "n=94 8.928196003124384e-31\n",
      "n=95 2.6891097179166424e-31\n",
      "n=96 4.779708102694985e-31\n",
      "n=97 1.0042306461659156e-30\n",
      "n=98 1.6440824916248159e-31\n",
      "n=99 1.6272658815460524e-31\n",
      "n=100 5.870187275674351e-31\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for r in range(RUNS):\n",
    "    Wb = np.random.randn(d,k)\n",
    "    Xb = np.random.randn(N,d)\n",
    "    mask = Xb.dot(Wb) > 0\n",
    "    yb = Xb.dot(Wb) * mask * math.sqrt(2/k)\n",
    "    vb = np.random.randn(k)\n",
    "    zb = yb.dot(vb)\n",
    "    # for n in range(N):\n",
    "    #     X = Xb[:n]\n",
    "    #     y = yb[:n]\n",
    "    #     W = np.random.randn(d,k) * 0.01\n",
    "    #     for it in range(ITN):\n",
    "    #         grad_W = get_grad(X, y, W)\n",
    "    #         W -= lr * grad_W\n",
    "    #     # W = npl.pinv(X).dot(y)\n",
    "    #     Xt = np.random.randn(N,d)\n",
    "    #     mask = Xt.dot(Wb) > 0\n",
    "    #     yt = Xt.dot(Wb) * mask * math.sqrt(2/k)\n",
    "    #     loss = (np.square(Xt.dot(W) * mask-yt)).sum()/N/d\n",
    "    #     print(f'n={n}', loss)\n",
    "    #     losses[r, n] = loss\n",
    "    for n in range(N):\n",
    "        y = yb[:n]\n",
    "        z = zb[:n]\n",
    "        v = npl.pinv(y).dot(z)\n",
    "        Xt = np.random.randn(N,d)\n",
    "        mask = Xt.dot(Wb) > 0\n",
    "        yt = Xt.dot(Wb) * mask * math.sqrt(2/k)\n",
    "        zt = yt.dot(vb)\n",
    "        loss = (np.square(zt-yt.dot(v))).sum()/N/d\n",
    "        print(f'n={n}', loss)\n",
    "        losses[r, n] = loss\n",
    "    # for n in range(N):\n",
    "    # # for n in [1,20,50,100]:\n",
    "    #     X = Xb[:n]\n",
    "    #     y = yb[:n]\n",
    "    #     W = np.random.randn(d,k) * 0.01\n",
    "    #     b = 0.68 * math.sqrt(2/k)\n",
    "    #     for it in range(ITN):\n",
    "    #         grad_W = get_grad(X, y, W)\n",
    "    #         W -= lr * grad_W\n",
    "    #     # W = npl.pinv(X).dot(y)\n",
    "    #     Xt = np.random.randn(N,d)\n",
    "    #     mask = Xt.dot(Wb) > 0\n",
    "    #     yt = Xt.dot(Wb) * mask * math.sqrt(2/k)\n",
    "    #     loss = (np.square(Xt.dot(W) * mask-yt-((Xt.dot(W) * mask-yt).mean()))).sum()/N/d\n",
    "    #     print(f'n={n}', losn range(1,N+1):\n",
    "    #     X = Xb[:n]\n",
    "    #     y = yb[:n]\n",
    "    #     W = np.zeros((d,k))\n",
    "    #     for i in range(k):\n",
    "    #         y_ = y[:,i]\n",
    "    #         mk = y_>0\n",
    "    #         # if mk.sum() == 0:\n",
    "    #         #     continue\n",
    "    #         y_ = y_[mk]\n",
    "    #         X_ = X[mk,:]\n",
    "    #         W[:,i] = npl.pinv(X_).dot(y_)\n",
    "    #     # v = npl.pinv(y).dot(z)\n",
    "    #     Xt = np.random.randn(N,d)\n",
    "    #     mask = Xt.dot(Wb) > 0\n",
    "    #     yt = Xt.dot(Wb) * mask * math.sqrt(2/k)\n",
    "    #     o = Xt.dot(W)\n",
    "    #     loss = (np.square(o * (o>0)-yt-((o * (o>0)-yt).mean()))).sum()/N/d\n",
    "    #     # loss = (np.square(Xt.dot(W) * mask-yt)).sum()/N/d\n",
    "    #     print(f'n={n}', loss)\n",
    "    #     losses[r, n-1] = losss)\n",
    "    #     losses[r, n] = loss\n",
    "    # for n i\n",
    "    # for n in range(1,21):\n",
    "    #     model = NN(d,k)\n",
    "    #     optimizer = torch.optim.SGD([model.W.weight], lr=0.01)\n",
    "    #     X = torch.tensor(Xb[:n]).float()\n",
    "    #     y = torch.tensor(yb[:n]).float()\n",
    "    #     for it in range(ITN):\n",
    "    #         optimizer.zero_grad()\n",
    "    #         loss = (model(X) - y).square().sum(-1).mean()\n",
    "    #         loss.backward()\n",
    "    #         optimizer.step()\n",
    "    #         # if (it+1) % 100 == 0:\n",
    "    #         #     print(n,loss.detach().numpy())\n",
    "    #     W = model.W.weight.detach().numpy().T\n",
    "    #     Xt = np.random.randn(N,d)\n",
    "    #     mask = Xt.dot(Wb) > 0\n",
    "    #     yt = Xt.dot(Wb) * mask * math.sqrt(2/k)\n",
    "    #     # loss = (np.square(Xt.dot(W) * mask-yt-((Xt.dot(W) * mask-yt).mean()))).sum()/N/d\n",
    "    #     # loss = (np.square(Xt.dot(W) * mask-yt)).sum()/N/d\n",
    "    #     loss = (np.square(model(torch.tensor(Xt).float()).detach().numpy()-yt)).sum()/N/d\n",
    "    #     # print(loss)\n",
    "    #     print(f'n={n}', loss)\n",
    "    #     losses[r, n-1] = loss\n",
    "    # for n in range(20):\n",
    "    #     X = Xb[:n]\n",
    "    #     y = yb[:n]\n",
    "    #     W = np.random.randn(d,k) * 0.01\n",
    "    #     b = 0\n",
    "    #     for repeat in range(100):\n",
    "    #         for it in range(ITN):\n",
    "    #             grad_W = get_grad(X, y-b, W)\n",
    "    #             W -= lr * grad_W\n",
    "    #             if npl.norm(grad_W) < 0.0001:\n",
    "    #                 break\n",
    "    #         o = X.dot(W)\n",
    "    #         b = np.mean(y-o*(o>0), axis=0)\n",
    "    #         # print((y-b).shape)\n",
    "    #     # print(b)\n",
    "    #     # W = npl.pinv(X).dot(y)\n",
    "    #     Xt = np.random.randn(N,d)\n",
    "    #     mask = Xt.dot(Wb) > 0\n",
    "    #     yt = Xt.dot(Wb) * mask * math.sqrt(2/k)\n",
    "    #     o = Xt.dot(W)\n",
    "    #     loss = (np.square(o * (o>0)-yt-(o * (o>0)-yt).mean(axis=0))).sum()/N/d\n",
    "    #     # loss = (np.square(Xt.dot(W) * mask-yt+b)).sum()/N/d\n",
    "    #     # loss = (np.square(Xt.dot(W) * mask-yt-(Xt.dot(Wb) * (Xt.dot(Wb)>0)-yt).mean())).sum()/N/d\n",
    "    #     print(f'n={n}', loss)\n",
    "    #     losses[r, n] = loss\n",
    "\n",
    "   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[6.79271273e-01 6.50823873e-01 6.24430586e-01 5.98276447e-01\n",
      " 5.70383635e-01 5.38880620e-01 5.05209664e-01 4.79830492e-01\n",
      " 4.33431248e-01 3.95324069e-01 3.63956467e-01 3.25428101e-01\n",
      " 2.86966100e-01 2.52283345e-01 2.11145399e-01 1.78504169e-01\n",
      " 1.47149330e-01 1.18045469e-01 9.70913998e-02 7.81938220e-02\n",
      " 5.93297514e-02 4.59672593e-02 3.58657051e-02 2.54358587e-02\n",
      " 2.10417337e-02 1.54440720e-02 1.03945820e-02 5.69390200e-03\n",
      " 3.28583736e-03 2.19376973e-03 1.91733439e-03 1.23997449e-03\n",
      " 8.35719593e-04 7.09039215e-04 5.24234233e-04 3.09412252e-04\n",
      " 1.88084900e-04 1.51428369e-05 3.75646780e-06 5.15243434e-06\n",
      " 2.50493690e-30 2.49726237e-30 2.61410516e-30 2.64995288e-30\n",
      " 2.72166223e-30 2.61339981e-30 2.38652902e-30 2.42680147e-30\n",
      " 2.57357998e-30 2.47531402e-30 2.41641581e-30 2.51478661e-30\n",
      " 2.48370298e-30 2.46457969e-30 2.33540270e-30 2.38625066e-30\n",
      " 2.49629769e-30 2.45796909e-30 2.25301935e-30 2.41508829e-30\n",
      " 2.38827971e-30 2.23423004e-30 2.44809147e-30 2.56757723e-30\n",
      " 2.66925277e-30 2.30698770e-30 2.36639276e-30 2.36005362e-30\n",
      " 2.25259751e-30 2.51276391e-30 2.19278601e-30 2.20577149e-30\n",
      " 2.28144501e-30 2.35370587e-30 2.04301727e-30 2.26277702e-30\n",
      " 2.47804511e-30 2.31285376e-30 2.39168933e-30 2.12199525e-30\n",
      " 2.34243735e-30 2.44507355e-30 2.31588947e-30 2.40405745e-30\n",
      " 2.39707516e-30 2.44797261e-30 2.51464142e-30 2.29966335e-30\n",
      " 2.15589451e-30 2.34366875e-30 2.59048628e-30 2.40625566e-30\n",
      " 2.07405358e-30 2.21790097e-30 2.24667806e-30 2.22497957e-30\n",
      " 2.52560259e-30 2.34750692e-30 2.23410849e-30 2.51527259e-30]\n"
     ]
    }
   ],
   "source": [
    "print(losses.mean(0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('regression_loss_W.npy', losses)\n",
    "# np.save('regression_loss_W_pinv.npy', losses)\n",
    "# np.save('regression_loss_W_NN.npy', losses)\n",
    "# np.save('regression_loss_W_NN_v2.npy', losses)\n",
    "np.save(f'regression_loss_v_k{k}.npy', losses)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.12 ('in-context-learning')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "3c3b0ea47dd8573b00f7a00fb60e86a63b3b74ba3e713837243884370e7a8946"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
