{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "FloatProgress(value=0.0, bar_style='info', description='Progress:', layout=Layout(height='25px', width='50%'),…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# set up\n",
    "import time\n",
    "import numpy as np\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "jax.config.update(\"jax_enable_x64\", True)\n",
    "import io\n",
    "\n",
    "\n",
    "def calc_numpy_eig(cov):\n",
    "    eigenvalues, eigenvectors = jnp.linalg.eigh(cov)\n",
    "    idx = jnp.argsort(abs(eigenvalues))[::-1]  # Indices for descending sort\n",
    "    eigenvalues = eigenvalues[idx]\n",
    "    eigenvectors = eigenvectors[:, idx]\n",
    "    return eigenvalues, eigenvectors\n",
    "\n",
    "def model(v, cov, V1):\n",
    "    rewards = jnp.dot(jnp.transpose(v), jnp.dot(cov, v))\n",
    "    penalties = 0\n",
    "    for j in range(np.size(V1[:, V1.any(0)], axis=1) - 1):\n",
    "        penalties += (jnp.dot(jnp.transpose(v), jnp.dot(cov, V1[:, j].reshape(-1, 1)))) ** 2 / jnp.dot(\n",
    "            jnp.transpose(V1[:, j].reshape(-1, 1)), jnp.dot(cov, V1[:, j].reshape(-1, 1)))\n",
    "    return jnp.sum(rewards - penalties)\n",
    "\n",
    "def update(v, cov, V1, lr=0.5):\n",
    "    dv = jax.grad(model)(v, cov, V1)\n",
    "    vhat = v + lr * dv\n",
    "    return (vhat / jnp.linalg.norm(vhat))\n",
    "\n",
    "def calc_eigenvector(cov_broadcast, k, l, V1_broadcast):\n",
    "    v_k = np.array(V1_broadcast.value[:, k])\n",
    "    if k <= l:\n",
    "        V_k = np.hstack((V1_broadcast.value[:, :k+1], np.zeros((cov_broadcast.value.shape[0], cov_broadcast.value.shape[1] - k - 1))))\n",
    "        v_k = update(v_k, cov_broadcast.value, V_k)\n",
    "    return v_k\n",
    "\n",
    "def overall_error_matrices(M1, M2, K):\n",
    "    diags = jnp.diag(M1[:, :K].T @ M2[:, :K])\n",
    "    error_arr = jnp.abs(2 - 2 * jnp.abs(diags))\n",
    "    return jnp.sqrt(sum(error_arr) / K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "FloatProgress(value=0.0, bar_style='info', description='Progress:', layout=Layout(height='25px', width='50%'),…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = sc.binaryFiles(\"s3://pcabk/Y_exp.npy\").map(lambda file_content: np.load(io.BytesIO(file_content[1]))).collect()[0] \n",
    "X /= jnp.linalg.norm(X)\n",
    "\n",
    "cov = jnp.dot(jnp.transpose(X), X)\n",
    "cov_broadcast = sc.broadcast(cov)\n",
    "_, q = calc_numpy_eig(cov)\n",
    "\n",
    "K = 32\n",
    "L = 5000\n",
    "\n",
    "v = jnp.array([[1.0] for i in range(cov.shape[1])])\n",
    "v /= jnp.linalg.norm(v)\n",
    "v0 = jnp.array([[1.0] for i in range(cov.shape[1])])\n",
    "v0 /= jnp.linalg.norm(v0)\n",
    "V1 = np.zeros_like(cov)\n",
    "V1[:, 0] = v.T\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "FloatProgress(value=0.0, bar_style='info', description='Progress:', layout=Layout(height='25px', width='50%'),…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time taken 69.62674808502197"
     ]
    }
   ],
   "source": [
    "# run the experiment\n",
    "\n",
    "t = time.time()\n",
    "time_steps = []\n",
    "errors = []\n",
    "\n",
    "# l is number of communication rounds    \n",
    "for l in range(L):\n",
    "    # Broadcast V1 to the workers\n",
    "    V1_broadcast = sc.broadcast(V1)\n",
    "    \n",
    "    # compute each vectors in parallel\n",
    "    eigenvectors = sc.parallelize(range(K)).map(\n",
    "        lambda k: calc_eigenvector(cov_broadcast, k, l, V1_broadcast)\n",
    "    ).collect()\n",
    "\n",
    "    # Update V1 with the computed eigenvectors\n",
    "    for k, v in enumerate(eigenvectors):\n",
    "        V1[:, k] = v\n",
    "\n",
    "    if l < K - 1:\n",
    "        V1[:, l + 1] = v0.T\n",
    "        \n",
    "    # compute aggregated error\n",
    "    \n",
    "    V1_broadcast.unpersist()\n",
    "    current_time = time.time() - t\n",
    "    time_steps.append(current_time)\n",
    "    errors.append(overall_error_matrices(V1, q, K))\n",
    "    \n",
    "    if current_time > 1800:\n",
    "        break\n",
    "    \n",
    "print(\"time taken\", time.time() - t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "FloatProgress(value=0.0, bar_style='info', description='Progress:', layout=Layout(height='25px', width='50%'),…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1.390505965046978, 1.3782301270843158, 1.359527243011161, 1.3309895944714125, 1.2874670851821821, 1.2215373919870594, 1.1238636619291902, 0.9867790287558427, 0.8134116903764651, 0.6255673955957674]"
     ]
    }
   ],
   "source": [
    "errors = [float(error) for error in errors]\n",
    "errors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "FloatProgress(value=0.0, bar_style='info', description='Progress:', layout=Layout(height='25px', width='50%'),…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.6447689533233643, 1.4630916118621826, 2.2332491874694824, 3.0585763454437256, 3.8445847034454346, 4.690182209014893, 5.508453130722046, 6.397140741348267, 7.222239971160889, 8.048638582229614, 8.920971870422363, 9.74460768699646, 10.596277952194214, 11.530457735061646, 12.445315599441528, 13.41448450088501, 14.405107498168945, 15.364612817764282, 16.376481771469116, 17.344754934310913, 18.328737497329712, 19.32196068763733, 20.389647483825684, 21.509944200515747, 22.635668754577637, 23.75653600692749, 24.95679521560669, 26.096035718917847, 27.234410047531128, 28.374297618865967, 29.590105533599854, 30.892314434051514, 32.18238615989685, 33.47902202606201, 34.7791793346405, 36.078890323638916, 37.383065938949585, 38.688727617263794, 40.00306487083435, 41.29118490219116, 42.58522009849548, 43.86977553367615, 45.17719316482544, 46.470534324645996, 47.766475200653076, 49.08774495124817, 50.37110781669617, 51.670838356018066, 52.9598925113678, 54.26380705833435, 55.586503982543945, 56.8883638381958, 58.224069118499756, 59.515504121780396, 60.813068151474, 62.10063862800598, 63.42414450645447, 64.74849200248718, 66.03807973861694, 67.48770380020142, 68.80258274078369, 70.1036159992218, 71.39230489730835, 72.73760795593262, 74.04297852516174, 75.3573067188263, 76.66105389595032, 77.9549171924591, 79.32439303398132, 80.64280867576599, 81.95961141586304, 83.24585962295532, 84.54835653305054, 85.88441348075867, 87.17017316818237, 88.44891238212585, 89.76868772506714, 91.0696485042572, 92.35048222541809, 93.66518807411194, 94.94657182693481, 96.2818386554718, 97.58404183387756, 98.90467429161072, 100.23116564750671, 101.55780291557312, 102.91033005714417, 104.2546398639679, 105.6406900882721, 107.17336416244507, 108.60391092300415, 109.90834450721741, 111.19401288032532, 112.48970055580139, 113.8051643371582, 115.16950130462646, 116.48617601394653, 117.78436589241028, 119.06536722183228, 120.37505602836609, 121.67350935935974, 122.97406649589539, 124.2733645439148, 125.63716435432434, 126.93521881103516, 128.2267870903015, 129.50501489639282, 130.90843892097473, 132.1961419582367, 133.51298117637634, 134.84066152572632, 136.14139127731323, 137.42631769180298, 138.73431944847107, 140.02657008171082, 141.32297468185425, 142.60810208320618, 143.89552974700928, 145.20763635635376, 146.5094451904297, 147.81251430511475, 149.10045504570007, 150.41682028770447, 151.6968173980713, 153.01064085960388, 154.30174136161804, 155.59278917312622, 156.8830497264862, 158.1674337387085, 159.4830641746521, 160.78203225135803, 162.06696009635925, 163.38155245780945, 164.6678810119629, 165.95241165161133, 167.26993656158447, 168.566321849823, 169.8795256614685, 171.19844841957092, 172.4949915409088, 173.82031893730164, 175.18614768981934, 176.46168780326843, 177.74812984466553, 179.0437080860138, 180.36266660690308, 181.68199610710144, 183.00993490219116, 184.32746076583862, 185.66828393936157, 186.9924976825714, 188.26766228675842, 189.55180740356445, 190.83590817451477, 192.1197865009308, 193.4251172542572, 194.71073818206787, 196.0052514076233, 197.31856846809387, 198.62394189834595, 199.98032021522522, 201.27962732315063, 202.55247282981873, 203.8738157749176, 205.16641640663147, 206.4614019393921, 207.79311513900757, 209.1218659877777, 210.40259528160095, 211.69464445114136, 213.02026391029358, 214.3310706615448, 215.61902618408203, 216.9469792842865, 218.23661494255066, 219.51876378059387, 220.80275964736938, 222.08828592300415, 223.37118482589722, 224.65688467025757, 225.92932772636414, 227.21973085403442, 228.54117894172668, 229.8376898765564, 231.1446177959442, 232.4222433567047, 233.71450233459473, 235.0125515460968, 236.36224794387817, 237.67624425888062, 239.07393407821655, 240.39539194107056, 241.69375205039978, 242.97924542427063, 244.2840757369995, 245.60506677627563, 246.89477229118347, 248.19687724113464, 249.48617458343506, 250.8460991382599, 252.13478803634644, 253.42085576057434, 254.70623254776, 255.9878487586975, 257.2895841598511, 258.5985610485077, 259.8846356868744, 261.19347167015076, 262.5114743709564, 263.85211873054504, 265.17511892318726, 266.51030135154724, 267.80060625076294, 269.10271859169006, 270.40670800209045, 271.7441017627716, 273.07309007644653, 274.34175634384155, 275.64375495910645, 276.95633244514465, 278.2532823085785, 279.5882816314697, 280.8770205974579, 282.1573557853699, 283.435542345047, 284.7357838153839, 286.03137278556824, 287.3207492828369, 288.62631273269653, 289.9042043685913, 291.1871409416199, 292.4725320339203, 293.77118706703186, 295.09433126449585, 296.39268255233765, 297.75216269493103, 299.084349155426, 300.40419268608093, 301.7000455856323, 302.9901759624481, 304.27866888046265, 305.5896489620209, 306.89408683776855, 308.1787111759186, 309.486168384552, 310.78367710113525, 312.0921678543091, 313.3639643192291, 314.7071387767792, 316.0061070919037, 317.28885293006897, 318.6033811569214, 319.8917486667633, 321.1676480770111, 322.46483278274536, 323.7735598087311, 325.06750226020813, 326.34793519973755, 327.7001008987427, 328.99458861351013, 330.29096269607544, 331.602823972702, 332.87482142448425, 334.16141963005066, 335.48417496681213, 336.79191279411316, 338.1063349246979, 339.4030168056488, 340.69257140159607, 342.03606486320496, 343.32296442985535, 344.6328661441803, 345.909982919693, 347.2122037410736, 348.52375173568726, 349.84721851348877, 351.11722326278687, 352.4041440486908, 353.6887729167938, 354.99397325515747, 356.29927587509155, 357.61842489242554, 358.9101355075836, 360.19861221313477, 361.47508549690247, 362.81167340278625, 364.1410744190216, 365.4512164592743, 366.74265146255493, 368.04391050338745, 369.3608605861664, 370.64649391174316, 371.9965476989746, 373.3314793109894, 374.62071537971497, 375.9021465778351, 377.1914200782776, 378.4797160625458, 379.7705478668213, 381.1866822242737, 382.55824851989746, 383.95817136764526, 385.23350834846497, 386.5771028995514, 387.8762083053589, 389.1660556793213, 390.44550681114197, 391.73492217063904, 393.0328595638275, 394.4378070831299, 395.77237820625305, 397.0999963283539, 398.41590547561646, 399.7173397541046, 401.04041934013367, 402.35936164855957, 403.6737961769104, 405.0638566017151, 406.3498742580414, 407.7323603630066, 409.2410819530487, 410.53338861465454, 411.8512234687805, 413.1334619522095, 414.4186828136444, 415.71680426597595, 417.0193965435028, 418.320561170578, 419.5999524593353, 420.8821759223938, 422.18075251579285, 423.4658215045929, 424.76586651802063, 426.05780601501465, 427.38890624046326, 428.73797035217285, 430.05594301223755, 431.39031076431274, 432.68208360671997, 433.96570801734924, 435.27198219299316, 436.5541090965271, 437.8673748970032, 439.1583378314972, 440.44511580467224, 441.7311055660248, 443.0717976093292, 444.35916471481323, 445.6777045726776, 446.9503860473633, 448.2707757949829, 449.5581283569336, 450.9201741218567, 452.2876603603363, 453.55580854415894, 454.83517932891846, 456.1091380119324, 457.40273237228394, 458.69147515296936, 459.99034309387207, 461.26685881614685, 462.5611717700958, 463.8692696094513, 465.1634726524353, 466.44690704345703, 467.7437117099762, 469.0555729866028, 470.3332357406616, 471.6484727859497, 472.96021938323975, 474.28222393989563, 475.5654249191284, 476.8593761920929, 478.14514422416687, 479.41922545433044, 480.6988916397095, 481.9974374771118, 483.2778539657593, 484.57701659202576, 485.9201636314392, 487.2017607688904, 488.55231833457947, 489.84740805625916, 491.11844754219055, 492.4691467285156, 493.7645707130432, 495.05910634994507, 496.34646129608154, 497.64197969436646, 498.94800996780396, 500.2421259880066, 501.60042238235474, 502.8908689022064, 504.2155430316925, 505.50047278404236, 506.8013617992401, 508.1189799308777, 509.4100432395935, 510.75924038887024, 512.0358779430389, 513.3192136287689, 514.611902475357, 515.9215240478516, 517.2339432239532, 518.5125300884247, 519.8012881278992, 521.1113815307617, 522.398478269577, 523.7172720432281, 525.0507113933563, 526.3367254734039, 527.621319770813, 528.9113435745239, 530.1966891288757, 531.492514371872, 532.7732398509979, 534.1652839183807, 535.4447071552277, 536.7547326087952, 538.0272493362427, 539.3077571392059, 540.5938115119934, 541.9192409515381, 543.2060375213623, 544.5334403514862, 545.8229253292084, 547.0985472202301, 548.4017624855042, 549.6838569641113, 550.9702305793762, 552.3411149978638, 553.6118490695953, 554.8808481693268, 556.2207148075104, 557.4979982376099, 558.8375942707062, 560.1241431236267, 561.4114348888397, 562.7317795753479, 564.0123476982117, 565.294548034668, 566.6066243648529, 567.9871547222137, 569.3539576530457, 570.6871011257172, 571.9636569023132, 573.2538754940033, 574.5450291633606, 575.8656303882599, 577.2063872814178, 578.512003660202, 579.8631360530853, 581.1565663814545, 582.4434068202972, 583.724404335022, 585.0077087879181, 586.2920773029327, 587.6106357574463, 588.9021081924438, 590.1903350353241, 591.4813513755798, 592.7675030231476, 594.1344633102417, 595.4199349880219, 596.7306368350983, 598.012927532196, 599.3207581043243, 600.6319434642792, 601.9123849868774, 603.186815738678, 604.4882917404175, 605.8379020690918, 607.1889262199402, 608.4871075153351, 609.8068046569824, 611.1987977027893, 612.4902334213257, 613.7999527454376, 615.1093142032623, 616.4061412811279, 617.7227823734283, 619.0553023815155, 620.339272737503, 621.6453139781952, 622.9266483783722, 624.2040481567383, 625.494800567627, 626.7802495956421, 628.0965299606323, 629.3825163841248, 630.6759698390961, 631.9738531112671, 633.2534382343292, 634.5540015697479, 635.8945043087006, 637.1867311000824, 638.4886984825134, 639.8021802902222, 641.1268947124481, 642.5092225074768, 643.8069307804108, 645.0989942550659, 646.4269404411316, 647.7234532833099, 649.0708336830139, 650.396103143692, 651.7018992900848, 652.9883146286011, 654.2756741046906, 655.5688216686249, 656.8897595405579, 658.1777164936066, 659.489862203598, 660.7793614864349, 662.0712058544159, 663.3634026050568, 664.6421201229095, 665.9151976108551, 667.2469911575317, 668.5691018104553, 669.8738675117493, 671.1618750095367, 672.4453473091125, 673.7348909378052, 675.0243153572083, 676.32617020607, 677.6018936634064, 678.9185993671417, 680.2061107158661, 681.4981424808502, 682.7966520786285, 684.0779323577881, 685.371001958847, 686.6621854305267, 687.9548201560974, 689.2681970596313, 690.5961849689484, 691.9125020503998, 693.23211145401, 694.5500509738922, 695.8800113201141, 697.2182874679565, 698.5281121730804, 699.8484416007996, 701.1573028564453, 702.4788153171539, 703.7681567668915, 705.074878692627, 706.393285036087, 707.6710307598114, 709.041999578476, 710.5501058101654, 711.9174358844757, 713.2546947002411, 714.5800595283508, 715.8538084030151, 717.1931476593018, 718.4778096675873, 719.775173664093, 721.1739950180054, 722.4497652053833, 723.9083852767944, 725.2230775356293, 726.4969615936279, 727.8075387477875, 729.1840627193451, 730.5290217399597, 731.8326394557953, 733.1132040023804, 734.3972363471985, 735.6978085041046, 737.2626225948334, 738.5892019271851, 739.8765187263489, 741.2673966884613, 742.5634474754333, 743.8556320667267, 745.2707934379578, 746.5867567062378, 747.9226174354553, 749.1964690685272, 750.505336523056, 751.8600244522095, 753.1365737915039, 754.4266967773438, 755.734456539154, 757.0367248058319, 758.4900531768799, 759.7959220409393, 761.094316482544, 762.3782420158386, 763.6646535396576, 764.9609224796295, 766.254579782486, 767.5403771400452, 768.8271689414978, 770.1219244003296, 771.4278016090393, 772.7037580013275, 773.9869341850281, 775.282149553299, 776.571051120758, 777.8517401218414, 779.1540615558624, 780.4556250572205, 781.737856388092, 783.0291278362274, 784.3235263824463, 785.6714696884155, 786.977208852768, 788.2843742370605, 789.6020905971527, 790.9284257888794, 792.2251105308533, 793.5148844718933, 794.8340997695923, 796.1462917327881, 797.4310264587402, 798.7502062320709, 800.0862154960632, 801.3594927787781, 802.6403713226318, 803.9251062870026, 805.2070801258087, 806.4959366321564, 807.9010560512543, 809.1892459392548, 810.4880502223969, 811.771098613739, 813.0676567554474, 814.3648118972778, 815.6544780731201, 816.9410417079926, 818.2387042045593, 819.5312294960022, 820.8353943824768, 822.1535029411316, 823.4301335811615, 824.7447113990784, 826.0611279010773, 827.3516163825989, 828.6675472259521, 830.0065219402313, 831.3070819377899, 832.6849699020386, 834.0191099643707, 835.3283710479736, 836.6214101314545, 837.892641544342, 839.2032856941223, 840.4960978031158, 841.7889907360077, 843.0792598724365, 844.379378080368, 845.6774325370789, 846.9586050510406, 848.2396605014801, 849.50563621521, 850.7921879291534, 852.0784156322479, 853.3827376365662, 854.6902527809143, 856.0047786235809, 857.345624923706, 858.6444911956787, 859.9221575260162, 861.2014756202698, 862.5208790302277, 863.7951211929321, 865.1915769577026, 866.4714579582214, 867.7635726928711, 869.0544378757477, 870.3458664417267, 871.6168832778931, 872.9251120090485, 874.2116436958313, 875.5285623073578, 876.8252863883972, 878.1475760936737, 879.4412159919739, 880.7209753990173, 882.0581865310669, 883.3770201206207, 884.6821193695068, 886.0307688713074, 887.3354077339172, 888.6430685520172, 889.9368853569031, 891.2924692630768, 892.5701739788055, 893.8439111709595, 895.1276514530182, 896.4115753173828, 897.7150881290436, 898.9862775802612, 900.2766234874725, 901.5922129154205, 902.8924081325531, 904.1803510189056, 905.4690220355988, 906.7926440238953, 908.0930802822113, 909.391907453537, 910.7439484596252, 912.0148169994354, 913.3076186180115, 914.6008837223053, 915.9037849903107, 917.1970281600952, 918.4847741127014, 919.7673034667969, 921.0577328205109, 922.3606715202332, 923.647702217102, 924.977156162262, 926.2891030311584, 927.5724737644196, 928.8697452545166, 930.1597800254822, 931.4595918655396, 932.7530405521393, 934.0352261066437, 935.3342161178589, 936.6823348999023, 937.9807507991791, 939.2680811882019, 940.5637891292572, 941.8447113037109, 943.1303853988647, 944.4182796478271, 945.712153673172, 947.0707721710205, 948.4051015377045, 949.7001638412476, 950.9852890968323, 952.2884421348572, 953.5701439380646, 954.8770778179169, 956.1646220684052, 957.4639554023743, 958.7414357662201, 960.0422034263611, 961.3248867988586, 962.6306056976318, 963.925178527832, 965.2391941547394, 966.5717670917511, 967.8784737586975, 969.1566736698151, 970.4390969276428, 971.7240259647369, 973.0036375522614, 974.3027167320251, 975.6010005474091, 976.8994908332825, 978.1931872367859, 979.5129098892212, 980.8802933692932, 982.1521401405334, 983.4305098056793, 984.7112307548523, 986.0025627613068, 987.300451040268, 988.5895776748657, 989.8778426647186, 991.1550793647766, 992.4454391002655, 993.7790076732635, 995.1044633388519, 996.4436919689178, 997.8235805034637, 999.1467430591583, 1000.4698212146759, 1001.7745137214661, 1003.0948367118835, 1004.3866436481476, 1005.679386138916, 1006.9716928005219, 1008.2903807163239, 1009.6236064434052, 1010.9099879264832, 1012.2551658153534, 1013.6394176483154, 1015.0189163684845, 1016.3832416534424, 1017.6973266601562, 1018.9954767227173, 1020.2920899391174, 1021.6316044330597, 1022.9283130168915, 1024.2729713916779, 1025.5536801815033, 1026.939082622528, 1028.2450399398804, 1029.6729793548584, 1031.035855293274, 1032.330837726593, 1033.6553173065186, 1034.9988622665405, 1036.3159737586975, 1037.5965368747711, 1038.9049665927887, 1040.2229278087616, 1041.5310082435608, 1042.8559684753418, 1044.1446721553802, 1045.431643486023, 1046.714105606079, 1048.0043597221375, 1049.3606252670288, 1050.6340136528015, 1051.9736678600311, 1053.2560205459595, 1054.5318434238434, 1055.8585412502289, 1057.1429743766785, 1058.5021924972534, 1059.7871372699738, 1061.0833237171173, 1062.3856868743896, 1063.6967129707336, 1065.007174730301, 1066.3010478019714, 1067.6420431137085, 1068.920025587082, 1070.2595400810242, 1071.5947790145874, 1072.883605480194, 1074.1689014434814, 1075.4528970718384, 1076.750593662262, 1078.071147441864, 1079.3615469932556, 1080.695946931839, 1081.9867072105408, 1083.319055557251, 1084.6517012119293, 1085.9349117279053, 1087.231656551361, 1088.5363841056824, 1089.8154678344727, 1091.1533641815186, 1092.4351515769958, 1093.714463710785, 1095.0227966308594, 1096.2977118492126, 1097.6007554531097, 1098.8934290409088, 1100.1747419834137, 1101.485965013504, 1102.8759093284607, 1104.1698772907257, 1105.4673864841461, 1106.7474474906921, 1108.065992116928, 1109.366213798523, 1110.664038658142, 1111.9494502544403, 1113.2344834804535, 1114.5153558254242, 1115.8079335689545, 1117.1018629074097, 1118.374704360962, 1119.6916058063507, 1120.9754214286804, 1122.2575709819794, 1123.568392276764, 1124.8417840003967, 1126.1260316371918, 1127.478469133377, 1128.7726526260376, 1130.0674872398376, 1131.3764426708221, 1132.7038824558258, 1133.9829189777374, 1135.2893688678741, 1136.5747244358063, 1137.8687336444855, 1139.1964149475098, 1140.7636964321136, 1142.0769805908203, 1143.4723134040833, 1144.7645378112793, 1146.1185986995697, 1147.3991951942444, 1148.7031645774841, 1149.9839117527008, 1151.255129814148, 1152.5353112220764, 1153.824448108673, 1155.1559221744537, 1156.4438886642456, 1157.7308814525604, 1159.0513541698456, 1160.3306021690369, 1161.6000499725342, 1162.8875393867493, 1164.1646840572357, 1165.4691359996796, 1166.757601737976, 1168.0631227493286, 1169.3434183597565, 1170.6193115711212, 1171.9257805347443, 1173.1988279819489, 1174.4982571601868, 1175.8347761631012, 1177.1317999362946, 1178.4384908676147, 1179.744609117508, 1181.0593066215515, 1182.3369827270508, 1183.6251964569092, 1184.924674987793, 1186.200087070465, 1187.4695219993591, 1188.778606891632, 1190.1046805381775, 1191.383563041687, 1192.7378730773926, 1194.0178518295288, 1195.3392450809479, 1196.625147819519, 1197.9254038333893, 1199.2075209617615, 1200.5091652870178, 1201.7967219352722, 1203.0903329849243, 1204.4425547122955, 1205.7350182533264, 1207.0370001792908, 1208.3412613868713, 1209.6371738910675, 1210.940663576126, 1212.2062411308289, 1213.4921250343323, 1214.766944885254, 1216.0624420642853, 1217.3436241149902, 1218.6453564167023, 1219.9433307647705, 1221.2521500587463, 1222.5361845493317, 1223.8352394104004, 1225.134726524353, 1226.4489455223083, 1227.7494640350342, 1229.0662167072296, 1230.3453471660614, 1231.6120648384094, 1232.9027359485626, 1234.2248711585999, 1235.514051914215, 1236.904595375061, 1238.1871616840363, 1239.4948644638062, 1240.7821650505066, 1242.0683443546295, 1243.3557617664337, 1244.6483058929443, 1245.9393560886383, 1247.3381714820862, 1248.6545722484589, 1249.9356138706207, 1251.2215785980225, 1252.5512297153473, 1253.848462343216, 1255.140284538269, 1256.4167153835297, 1257.6912870407104, 1258.9800901412964, 1260.2461578845978, 1261.5481443405151, 1262.815515756607, 1264.0987162590027, 1265.3809840679169, 1266.6617045402527, 1267.9820611476898, 1269.2642307281494, 1270.5588879585266, 1271.8555855751038, 1273.2294311523438, 1274.6107215881348, 1275.922917842865, 1277.236224412918, 1278.5081491470337, 1279.8060505390167, 1281.0997819900513, 1282.3973426818848, 1283.6747174263, 1284.9618892669678, 1286.2653427124023, 1287.5456774234772, 1288.8570382595062, 1290.253338098526, 1291.572586297989, 1292.8962678909302, 1294.2013280391693, 1295.519157409668, 1296.8205425739288, 1298.1891059875488, 1299.483347415924, 1300.7858412265778, 1302.1150119304657, 1303.3868911266327, 1304.7092480659485, 1306.009085893631, 1307.2984063625336, 1308.5894730091095, 1309.8949782848358, 1311.1765887737274, 1312.4585802555084, 1313.760670185089, 1315.04753947258, 1316.355584859848, 1317.7648437023163, 1319.192078590393, 1320.4834401607513, 1321.7787153720856, 1323.072556257248, 1324.392497062683, 1325.696483373642, 1326.9876198768616, 1328.2849843502045, 1329.5923347473145, 1330.94033741951, 1332.217540025711, 1333.5475454330444, 1334.8609099388123, 1336.1417756080627, 1337.43403673172, 1338.7103893756866, 1339.9931213855743, 1341.3029608726501, 1342.6275947093964, 1343.9782145023346, 1345.3112151622772, 1346.6077146530151, 1347.8995983600616, 1349.174392938614, 1350.4682221412659, 1351.7579815387726, 1353.0396060943604, 1354.3185079097748, 1355.6667838096619, 1356.9658463001251, 1358.254317998886, 1359.537621498108, 1360.8185045719147, 1362.1552481651306, 1363.4517347812653, 1364.733857870102, 1366.041883468628, 1367.366525888443, 1368.647089958191, 1369.9507610797882, 1371.23562002182, 1372.552371263504, 1373.8469214439392, 1375.157241344452, 1376.4779393672943, 1377.8830397129059, 1379.2065601348877, 1380.5321514606476, 1381.8345665931702, 1383.1982190608978, 1384.5222470760345, 1385.8161628246307, 1387.1076595783234, 1388.4410328865051, 1389.7658450603485, 1391.162347793579, 1392.4396958351135, 1393.7155363559723, 1395.084089756012, 1396.36306142807, 1397.6791412830353, 1398.9705092906952, 1400.267051935196, 1401.5607545375824, 1402.847143650055, 1404.1840281486511, 1405.4871633052826, 1406.7788808345795, 1408.0589475631714, 1409.3454036712646, 1410.6427998542786, 1411.9387412071228, 1413.2673652172089, 1414.5428700447083, 1415.8850824832916, 1417.184482574463, 1418.5126059055328, 1419.8066742420197, 1421.107295036316, 1422.4294648170471, 1423.7393989562988, 1425.0303702354431, 1426.3408963680267, 1427.634131193161, 1428.9728355407715, 1430.2806732654572, 1431.6287240982056, 1433.0684523582458, 1434.6954584121704, 1436.0098640918732, 1437.32150888443, 1438.6205387115479, 1439.9385068416595, 1441.2402262687683, 1442.5348780155182, 1443.819092988968, 1445.143360376358, 1446.4559528827667, 1447.7459781169891, 1449.0648968219757, 1450.350055217743, 1451.6729469299316, 1452.9639661312103, 1454.263914346695, 1455.549678325653, 1456.8562004566193, 1458.1457221508026, 1459.5308799743652, 1460.8167078495026, 1462.1114757061005, 1463.4305474758148, 1464.7172586917877, 1466.0222780704498, 1467.3022055625916, 1468.6044445037842, 1469.995509147644, 1471.2930283546448, 1472.5746512413025, 1473.8671085834503, 1475.1430609226227, 1476.4184494018555, 1477.6965165138245, 1478.98104763031, 1480.2611458301544, 1481.554050207138, 1482.830483675003, 1484.1384456157684, 1485.424510717392, 1486.7465703487396, 1488.079333305359, 1489.3776082992554, 1490.6547541618347, 1491.9383654594421, 1493.2198622226715, 1494.500712633133, 1495.7869169712067, 1497.1147773265839, 1498.4297511577606, 1499.7147388458252, 1501.0142788887024, 1502.3013072013855, 1503.6252171993256, 1504.9568345546722, 1506.2514200210571, 1507.575659275055, 1508.8646898269653, 1510.150030374527, 1511.4811553955078, 1512.762751340866, 1514.0909569263458, 1515.3909916877747, 1516.7134618759155, 1518.042993068695, 1519.5425844192505, 1520.9077835083008, 1522.2383754253387, 1523.513793706894, 1524.8465332984924, 1526.2329156398773, 1527.5437233448029, 1528.8750948905945, 1530.1850807666779, 1531.4949004650116, 1532.7774014472961, 1534.0760877132416, 1535.3853168487549, 1536.6783232688904, 1537.9745483398438, 1539.259923696518, 1540.550229549408, 1541.8445732593536, 1543.1769320964813, 1544.4761774539948, 1545.7995345592499, 1547.1171555519104, 1548.4413640499115, 1549.7461700439453, 1551.0573978424072, 1552.376231431961, 1553.660275220871, 1554.9637196063995, 1556.2909197807312, 1557.6014523506165, 1558.8734090328217, 1560.2067975997925, 1561.540679693222, 1562.8434398174286, 1564.169438123703, 1565.4698886871338, 1566.7519025802612, 1568.064816236496, 1569.3280501365662, 1570.6016862392426, 1571.8796832561493, 1573.1958632469177, 1574.499082326889, 1575.7805907726288, 1577.0604090690613, 1578.362764120102, 1579.6848137378693, 1581.0214149951935, 1582.313363790512, 1583.604278087616, 1584.8810079097748, 1586.2225966453552, 1587.5212116241455, 1588.8240132331848, 1590.1036705970764, 1591.4124665260315, 1592.6873228549957, 1593.97682762146, 1595.2910270690918, 1596.6055335998535, 1597.9141948223114, 1599.2401323318481, 1600.5709142684937, 1601.886747598648, 1603.1896438598633, 1604.532010793686, 1605.855856180191, 1607.1437153816223, 1608.4688506126404, 1609.755093574524, 1611.1960797309875, 1612.4835696220398, 1613.7786445617676, 1615.0771834850311, 1616.3777656555176, 1617.715208530426, 1619.056340456009, 1620.4149498939514, 1621.8272185325623, 1623.288563489914, 1624.6013264656067, 1625.9075829982758, 1627.1875593662262, 1628.467738866806, 1629.7786874771118, 1631.0982937812805, 1632.4202210903168, 1633.7014892101288, 1635.0557799339294, 1636.3415632247925, 1637.6471109390259, 1638.927005290985, 1640.2207021713257, 1641.5536596775055, 1642.8484146595001, 1644.134568452835, 1645.4081618785858, 1646.7142987251282, 1648.0225622653961, 1649.3436789512634, 1650.6869747638702, 1651.96933054924, 1653.2449479103088, 1654.5444571971893, 1655.8310136795044, 1657.116310119629, 1658.402987241745, 1659.6919250488281, 1660.9893071651459, 1662.2831933498383, 1663.6007270812988, 1664.8882672786713, 1666.1706840991974, 1667.461058139801, 1668.740250825882, 1670.018324136734, 1671.318868637085, 1672.5945661067963, 1673.8678646087646, 1675.1641466617584, 1676.4297935962677, 1677.7196953296661, 1679.0086505413055, 1680.327574968338, 1681.6111822128296, 1682.893397808075, 1684.2109394073486, 1685.4929418563843, 1686.7730433940887, 1688.1064796447754, 1689.3856585025787, 1690.698038816452, 1692.0774157047272, 1693.3601698875427, 1694.6446261405945, 1695.9891436100006, 1697.2627913951874, 1698.5537195205688, 1699.8713891506195, 1701.1706643104553, 1702.4655423164368, 1703.7554860115051, 1705.040348291397, 1706.3219406604767, 1707.6796185970306, 1708.947508096695, 1710.2629940509796, 1711.5725219249725, 1712.865801334381, 1714.158165216446, 1715.4332826137543, 1716.7317559719086, 1718.011750459671, 1719.2985274791718, 1720.5908567905426, 1721.864086151123, 1723.14750623703, 1724.5245156288147, 1725.8440012931824, 1727.1306746006012, 1728.441507101059, 1729.7337274551392, 1731.037317276001, 1732.3306832313538, 1733.6536905765533, 1734.9405360221863, 1736.246676683426, 1737.5571203231812, 1738.8668851852417, 1740.1744449138641, 1741.4701607227325, 1742.752959728241, 1744.0891449451447, 1745.3767685890198, 1746.6914291381836, 1747.9657061100006, 1749.25324010849, 1750.5594675540924, 1751.8636393547058, 1753.153814315796, 1754.432960510254, 1755.7103056907654, 1756.9948291778564, 1758.275865316391, 1759.5606200695038, 1760.8455452919006, 1762.148696899414, 1763.4436175823212, 1764.7883281707764, 1766.1354398727417, 1767.4717206954956, 1768.7752258777618, 1770.0677404403687, 1771.3657248020172, 1772.6775681972504, 1773.9599993228912, 1775.2622907161713, 1776.5355610847473, 1777.8447074890137, 1779.129601240158, 1780.4150712490082, 1781.6924920082092, 1782.9997611045837, 1784.2743830680847, 1785.605847120285, 1786.9723308086395, 1788.2658488750458, 1789.5935587882996, 1790.8944292068481, 1792.173264503479, 1793.4654483795166, 1794.7487127780914, 1796.0521388053894, 1797.3706014156342, 1798.6808190345764, 1799.9721624851227, 1801.2634818553925]"
     ]
    }
   ],
   "source": [
    "time_steps"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
