{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Copy of BFGS.ipynb",
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "Generalized Linear Model with BFGS"
      ],
      "metadata": {
        "id": "zw4CVsma3L2p"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "OweWUa_N3J8n"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib as mpl\n",
        "import matplotlib.pyplot as plt\n",
        "from google.colab import files\n",
        "\n",
        "plt.style.use('classic')\n",
        "plt.rcParams.update({'font.size': 25})"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "d = 4\n",
        "n = 10000\n",
        "p = 2\n",
        "\n",
        "num_epoch = 100\n",
        "step_size = 1e-1"
      ],
      "metadata": {
        "id": "M5qi3nXd3V4q"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def objective(x, y, theta, p):\n",
        "  return np.mean((y - np.matmul(x, theta) ** p) ** 2)\n",
        "\n",
        "def gradient(x, y, theta, p):\n",
        "  n = x.shape[0]\n",
        "  return - p / n * np.matmul(x.T, (y - (np.matmul(x, theta)) ** p) * (np.matmul(x, theta) ** (p-1)))\n",
        "  # return 12 * np.linalg.norm(theta) ** 2 * theta\n",
        "\n",
        "def hessian(x, y, theta, p):\n",
        "  n = x.shape[0]\n",
        "  return np.mean((p * (2 * p - 1) * np.matmul(x, theta) ** (2 * p - 2) - p * (p - 1) * y * np.matmul(x, theta) ** (p - 2)).reshape(n, 1, 1) * np.matmul(x.reshape(n, d, 1), x.reshape(n, 1, d)), 0)\n",
        "  # return 12 * np.linalg.norm(theta) ** 2 * np.identity(d) + 24 * np.matmul(theta.reshape(d, 1), theta.reshape(1, d))\n",
        "\n",
        "def param_err(theta, theta_opt):\n",
        "  return min(np.linalg.norm(theta - theta_opt), np.linalg.norm(theta + theta_opt))"
      ],
      "metadata": {
        "id": "N1aJ-BxF5u3q"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Data Generation (Low SNR)"
      ],
      "metadata": {
        "id": "qQzA66oq3WMU"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# tril = np.tril(np.random.randn(d, d))\n",
        "# tril = np.identity(d)\n",
        "tril = np.diag(0.5 ** np.arange(d))\n",
        "cov = np.matmul(tril, tril.T)\n",
        "print(cov)\n",
        "x = np.matmul(np.random.randn(n, d), tril)\n",
        "theta_opt = np.zeros(d)\n",
        "theta_init = np.random.randn(d) / np.sqrt(d)\n",
        "y = (np.matmul(x, theta_opt)) ** p + 0.1 * np.random.randn(n)\n",
        "\n",
        "x_val = np.matmul(np.random.randn(int(n/10), d), tril)\n",
        "y_val = (np.matmul(x_val, theta_opt)) ** p + 0.1 * np.random.randn(int(n/10))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "93yWesWN5Ty_",
        "outputId": "599519e1-b4db-4154-dbf4-7abdf30b952c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[[1.       0.       0.       0.      ]\n",
            " [0.       0.25     0.       0.      ]\n",
            " [0.       0.       0.0625   0.      ]\n",
            " [0.       0.       0.       0.015625]]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Newton Method"
      ],
      "metadata": {
        "id": "32Ud0ZZAO2e0"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_newton = np.copy(theta_init)\n",
        "newton_dist = [param_err(np.copy(theta_newton), theta_opt)]\n",
        "val_err_newton = [objective(x_val, y_val, np.copy(theta_newton), p)]\n",
        "\n",
        "for _ in range(num_epoch):\n",
        "  grad = gradient(x, y, np.copy(theta_newton), p)\n",
        "  hess = hessian(x, y, np.copy(theta_newton), p)\n",
        "  theta_newton -= np.matmul(np.linalg.inv(hess), grad)\n",
        "  newton_dist.append(param_err(np.copy(theta_newton), theta_opt))\n",
        "  val_err_newton.append(objective(x_val, y_val, np.copy(theta_newton), p))\n",
        "\n",
        "obj_min = objective(x, y, np.copy(theta_newton), p)\n",
        "\n",
        "print(newton_dist)\n",
        "print(val_err_newton)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "EYr1JLnRPwFK",
        "outputId": "b6b6269b-0710-445c-e1e9-47c73d29b4a3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.9003851957407458, 0.5996521571639702, 0.3989689082149322, 0.2651361555731368, 0.17662728576512066, 0.1208329381921572, 0.09217988169146843, 0.08518572029969004, 0.08772169438783611, 0.08976799427536185, 0.08995645559270181, 0.08995718972289712, 0.0899571897322181, 0.08995718973221818, 0.08995718973221818, 0.08995718973221824, 0.08995718973221828, 0.08995718973221824, 0.08995718973221822, 0.08995718973221825, 0.08995718973221828, 0.08995718973221824, 0.08995718973221828, 0.08995718973221824, 0.08995718973221825, 0.08995718973221821, 0.08995718973221825, 0.08995718973221821, 0.08995718973221824, 0.08995718973221822, 0.08995718973221833, 0.0899571897322182, 0.08995718973221825, 0.08995718973221818, 0.08995718973221824, 0.08995718973221821, 0.08995718973221825, 0.08995718973221821, 0.08995718973221828, 0.08995718973221818, 0.08995718973221821, 0.08995718973221821, 0.08995718973221821, 0.08995718973221818, 0.08995718973221822, 0.08995718973221827, 0.08995718973221829, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828, 0.08995718973221825, 0.08995718973221828]\n",
            "[0.132708938120908, 0.035308935787516274, 0.015675160853441228, 0.011621672486361008, 0.010743161273201834, 0.010535182158732446, 0.010479176619866911, 0.01046233013474756, 0.010457669335052332, 0.010456963415240932, 0.010456938520283867, 0.010456938456617795, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(newton_dist)), label=\"Newton\")\n",
        "plt.scatter(np.nanargmin(np.array(val_err_newton)), np.log(newton_dist[np.nanargmin(np.array(val_err_newton))]), s = 20, color='r', marker='D')\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "plt.xlim([0, num_epoch])\n",
        "# plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "id": "beQXWIonSo5X",
        "outputId": "7f02eb33-cd6a-478f-ed23-2fa682784889"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 6
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Gradient Descent"
      ],
      "metadata": {
        "id": "iDx7Ycx38Y0A"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_GD = np.copy(theta_init)\n",
        "GD_dist = [param_err(np.copy(theta_GD), theta_opt)]\n",
        "\n",
        "for _ in range(num_epoch):\n",
        "  theta_GD -= step_size * gradient(x, y, np.copy(theta_GD), p)\n",
        "  GD_dist.append(param_err(np.copy(theta_GD), theta_opt))\n",
        "\n",
        "print(GD_dist)\n",
        "print(theta_GD)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "IJY_Y_065nBB",
        "outputId": "65010e61-d24c-43b3-ca56-3f21151be892"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.9003851957407458, 0.8775568316655495, 0.8580066095463712, 0.8408780735207038, 0.825615457570998, 0.8118375331716133, 0.7992713192680833, 0.7877145187235637, 0.7770129395858724, 0.7670462625915005, 0.7577187106532727, 0.748952726729273, 0.7406845676344102, 0.7328611573613096, 0.7254377914445718, 0.718376430372858, 0.7116444094703751, 0.7052134488608933, 0.6990588833576812, 0.6931590560243795, 0.6874948352483911, 0.6820492262124286, 0.6768070553567377, 0.6717547118863935, 0.6668799343041913, 0.6621716328089318, 0.6576197405064831, 0.6532150879519977, 0.6489492967249013, 0.6448146886381676, 0.6408042078740189, 0.6369113538727312, 0.6331301232182851, 0.6294549590924441, 0.6258807071283891, 0.6224025767019016, 0.6190161068640014, 0.6157171362528284, 0.6125017764311997, 0.60936638818493, 0.6063075603897023, 0.6033220911142106, 0.6004069706769168, 0.5975593664150474, 0.594776608958939, 0.5920561798337725, 0.5893957002350959, 0.5867929208451348, 0.5842457125743572, 0.5817520581276415, 0.5793100443071013, 0.5769178549745118, 0.5745737646056456, 0.5722761323768987, 0.5700233967315651, 0.5678140703791732, 0.5656467356865609, 0.5635200404239469, 0.5614326938332742, 0.5593834629896014, 0.5573711694294103, 0.5553946860224037, 0.5534529340657639, 0.551544880581955, 0.5496695358030237, 0.5478259508260156, 0.5460132154256008, 0.5442304560113176, 0.5424768337180155, 0.540751542619129, 0.539053808053355, 0.5373828850561424, 0.5357380568881648, 0.5341186336536278, 0.5325239510018689, 0.5309533689062711, 0.5294062705150009, 0.5278820610685422, 0.5263801668794023, 0.5249000343697392, 0.5234411291629978, 0.5220029352259482, 0.5205849540578008, 0.5191867039233267, 0.5178077191271431, 0.5164475493265404, 0.515105758880416, 0.5137819262320641, 0.5124756433237287, 0.5111865150409803, 0.509914158685113, 0.5086582034718842, 0.5074182900550377, 0.5061940700731565, 0.5049852057184897, 0.5037913693264915, 0.502612242984892, 0.5014475181611993, 0.5002968953476014, 0.49916008372230775, 0.4980368008264268]\n",
            "[-0.01155075 -0.29036983 -0.3777241  -0.14462745]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(GD_dist)), label=\"GD\")\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "id": "j2am2oav9kqN",
        "outputId": "2c7b3b6d-4225-46a8-a641-ce4b65c3e8bd"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 8
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Polyak Step-size"
      ],
      "metadata": {
        "id": "N80Up2HA-e-u"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_polyak = np.copy(theta_init)\n",
        "polyak_dist = [param_err(np.copy(theta_polyak), theta_opt)]\n",
        "for _ in range(num_epoch):\n",
        "  grad = gradient(x, y, np.copy(theta_polyak), p)\n",
        "  theta_polyak -= (objective(x, y, np.copy(theta_polyak), p) - obj_min) / np.linalg.norm(grad) ** 2 * grad\n",
        "  polyak_dist.append(param_err(np.copy(theta_polyak), theta_opt))\n",
        "\n",
        "print(polyak_dist)\n",
        "print(theta_polyak)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "5_-IRO31-ejg",
        "outputId": "d05a0c21-ab1c-4ee7-b3d8-70bdb7b3b8b0"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.9003851957407458, 0.683538762381608, 0.4805570477972402, 0.3909536913086955, 0.33970945833093025, 0.30060610429726475, 0.2705193697210287, 0.2434126009777395, 0.22247378795375702, 0.19903210973834495, 0.18482588126306548, 0.14514993844513077, 0.13020494321897724, 0.12101024665242918, 0.1133400406903182, 0.10673408767218852, 0.10024761957453183, 0.09662618716169376, 0.09025692720013552, 0.0953716212298102, 0.08641328245354922, 0.09237391999367407, 0.08811251267900791, 0.0938016867087418, 0.08838824146714461, 0.0870273469164695, 0.08614184308937503, 0.08569250129007853, 0.08632701790728786, 0.08591064777112332, 0.086380401905406, 0.08603793127552012, 0.08652099163746195, 0.08623408994500718, 0.08670782769774758, 0.08646761880208051, 0.08700063989320826, 0.08678309434779993, 0.08736892308043695, 0.08716370259217594, 0.0879884401827417, 0.08775869781432558, 0.08802447760669589, 0.0879655179777155, 0.08839533943343066, 0.08834489559270206, 0.08844003988386138, 0.08839579561986939, 0.08849894269929122, 0.08845583912246575, 0.08855631608553782, 0.08851440911432469, 0.08861233985254112, 0.08857162639152076, 0.08866700456761395, 0.08862748221656014, 0.08872030632198959, 0.08868197158575448, 0.08877224115428521, 0.08873508946154804, 0.08882280549310866, 0.08878683113785536, 0.08887199631811876, 0.08883719241007404, 0.08891981132795754, 0.08888616975316964, 0.08896624911672783, 0.08893376050165605, 0.0890113093307209, 0.08897996301993098, 0.08905499283355223, 0.08902477686980659, 0.08909730184930421, 0.08906820296694468, 0.08913824009980507, 0.08911024372708184, 0.0891778129281063, 0.08915090319791569, 0.08921602740220433, 0.08919018717470767, 0.08925289240067685, 0.0892281032972105, 0.089288418684967, 0.08926466112928588, 0.0893226189445751, 0.08929987221592238, 0.08935550782183892, 0.08933375011822826, 0.08938710192035448, 0.08936631042835817, 0.08941741978770905, 0.08939757076049672, 0.08944648187133229, 0.08942755071826268, 0.08947431045714861, 0.08945627183591269, 0.0895009295923732, 0.089483757505754, 0.08952636498460788, 0.08951003288349278, 0.08955064388557206]\n",
            "[ 0.01369248  0.05237605  0.01321051 -0.07010039]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(polyak_dist)), label=\"Polyak Step Size\")\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "id": "buOygVsd_qnC",
        "outputId": "390c7ad3-3107-4fd7-d33e-2aa032c4db2b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 10
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "BFGS"
      ],
      "metadata": {
        "id": "rtLLHXchAUIL"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_bfgs_old = np.copy(theta_init)\n",
        "bfgs_dist = [param_err(np.copy(theta_bfgs_old), theta_opt)]\n",
        "val_err_bfgs = [objective(x_val, y_val, np.copy(theta_bfgs_old), p)]\n",
        "Hinv = np.linalg.inv(hessian(x, y, np.copy(theta_bfgs_old), p))\n",
        "grad_old = gradient(x, y, np.copy(theta_bfgs_old), p)\n",
        "theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "\n",
        "for _ in range(num_epoch):\n",
        "  bfgs_dist.append(param_err(np.copy(theta_bfgs_new), theta_opt)) \n",
        "  val_err_bfgs.append(objective(x_val, y_val, np.copy(theta_bfgs_new), p))\n",
        "  grad_new = gradient(x, y, theta_bfgs_new, p)\n",
        "  u = grad_new - grad_old \n",
        "  s = theta_bfgs_new - theta_bfgs_old\n",
        "  Hinv = np.matmul(np.matmul(np.identity(d) - np.matmul(s.reshape(d, 1), u.reshape(1, d)) / u.dot(s), np.copy(Hinv)), np.identity(d) - np.matmul(u.reshape(d, 1), s.reshape(1, d)) / u.dot(s)) \\\n",
        "             + np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "  # Hinv = np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s) \n",
        "  theta_bfgs_old = theta_bfgs_new\n",
        "  grad_old = grad_new\n",
        "  theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "\n",
        "print(bfgs_dist)\n",
        "print(val_err_bfgs)\n",
        "print(theta_bfgs_new)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "kV_McCAqAVGP",
        "outputId": "69b38bf0-22b6-49f5-c44d-686ca0d1a16e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.9003851957407458, 0.5996521571639702, 0.4730192806752441, 0.3504711227013439, 0.2662663998440947, 0.2008616269254861, 0.15291521754234344, 0.11767374620167739, 0.09272962117186406, 0.0759763114078222, 0.06579881190547311, 0.06063798921139067, 0.058753933507507024, 0.05822433406765939, 0.05775065545404908, 0.05803698657836494, 0.061288712029995966, 0.07022389537355865, 0.07968821138909592, 0.08142696454858747, 0.07998743308610545, 0.07972563448704445, 0.07915763948295276, 0.07882362702468866, 0.07930056768371468, 0.08151985594860649, 0.08478429674823042, 0.08647138166897524, 0.08672087136356456, 0.08676070943238999, 0.0868750931251784, 0.08718142401441732, 0.08791793229542165, 0.0890403647314955, 0.08989835612853758, 0.0900487988264499, 0.08998020026092843, 0.08995900225857573, 0.08995722683291715, 0.08995719011569568, 0.08995718981259082, 0.08995718974055236, 0.0899571897323215, 0.089957189732219, 0.08995718973221827, 0.08995718973221814, 0.0899571897322182, 0.08995718973221828, 0.08995718973221827, 0.08995718973221824, 0.0899571897322182, 0.08995718973221821, 0.08995718973221822, 0.08995718973221825, 0.08995718973221821, 0.08995718973221824, 0.08995718973221824, 0.08995718973221824, 0.08995718973221824, 0.08995718973221822, 0.08995718973221824, 0.08995718973221821, 0.08995718973221821, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan]\n",
            "[0.132708938120908, 0.035308935787516274, 0.02040560801644693, 0.013658234913146527, 0.011625812226988842, 0.010888851480756762, 0.010627252617203571, 0.010526790120466286, 0.010485877246545034, 0.010468022157082577, 0.010459955996886289, 0.010456476835039887, 0.010455251424245318, 0.010454854853331369, 0.010454306709591183, 0.010453644451310258, 0.010453068041538487, 0.010453218144373418, 0.010454477420277147, 0.010455688090381355, 0.01045604114835574, 0.010456031892508303, 0.010456016588311693, 0.010456021063093643, 0.010456081192952158, 0.010456224395736659, 0.0104563870707573, 0.010456454263041287, 0.010456464295695621, 0.01045647033877111, 0.010456492327821804, 0.010456546002163338, 0.010456665550125272, 0.010456833939694146, 0.010456946479149425, 0.010456954416537769, 0.010456941459970523, 0.010456938633437133, 0.010456938456676525, 0.010456938456458165, 0.010456938456613971, 0.010456938456617083, 0.010456938456617031, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, 0.010456938456617024, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan]\n",
            "[nan nan nan nan]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:14: RuntimeWarning: invalid value encountered in true_divide\n",
            "  \n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(bfgs_dist)), label=\"BFGS\")\n",
        "plt.scatter(np.nanargmin(np.array(val_err_bfgs)), np.log(bfgs_dist[np.nanargmin(np.array(val_err_bfgs))]), s = 20, color='r', marker='D')\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "# plt.xlim([0, num_epoch])\n",
        "plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "id": "CR0che-mIJnV",
        "outputId": "5b09ab8f-daf8-4909-c109-3304c5704739"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 12
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZYAAAEPCAYAAABhkeIdAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3deZQU5b3/8feXQRbBMDgoIsqiEAMSBRc2NXbUJLjiviRxifFG45bcRFHjPTrXmF8wMTF4NCG5mOsSIxg1gokR0dyJSxRRgwouEREUBHRgQBYRB76/P54aGMfpmZ6Z6q6a7s/rnD7T1V1d9Z0+xXyo56nnKXN3RERE4tIh6QJERKS4KFhERCRWChYREYmVgkVERGKlYBERkVgpWEREJFapCxYzG2dmb5jZAjO7spH3zzGzD8xsbvQ4L4k6RUSkcR2TLqA+MysDbgW+AiwB5pjZDHd/tcGq09z94oIXKCIizUrbGctIYIG7L3T3TcBUYHzCNYmISAukLVj6Au/WW14SvdbQSWb2spndZ2a7F6Y0ERHJRdqCJRcPAQPcfR9gFnBHwvWIiEg9qepjAZYC9c9Adote28rdV9ZbnAL8LNvGzEwToYmItJC7W1s+n7YzljnAYDMbaGadgNOBGfVXMLM+9RaPA15raoPuroc71157beI1pOGh70Hfhb6Lph9xSNUZi7vXmtnFwEygDPi9u883s+uA5919BnCpmR0H1AKrgHMSK1hERD4jVcEC4O4PAw83eO2aes+vAq4qdF0iIpKbtDWFSZ5kMpmkS0gFfQ/b6LvYRt9FvCyuNrU0MjMv5t9PRCRuZoa3sfM+dU1hIiKtNWDAABYvXpx0Ge1C//79WbRoUV62rTMWESka0f+2ky6jXcj2XcVxxqI+FhERiZWCRUREYqVgERGRWClYREQkVgoWEZECGTBgAF27dqV79+707NmTo48+mnffDRO6n3POOXTq1Inu3btvfUybNm3rZ6dOncqoUaPo1q0bO++8M6NGjeLXv/711g74JUuWcNJJJ9GrVy969OjBsGHDuP3225P4NRUsIiKF9NBDD7Fu3TqWLVtG7969ueSSS7a+N2HCBNatW7f1cdpppwHwi1/8gu9973tcfvnlLF++nBUrVjB58mSefvppNm3aBMCZZ57J7rvvzuLFi1m5ciV33XUXvXv3TuR31DgWEZEEdOnShZNPPpnvf//7Ta63Zs0arrnmGu68805OOumkra+PGDGCu+++e+vynDlzuOmmm+jWrdvW95OiMxYRkQRs2LCBadOmMXr06CbXe+aZZ/j4448ZP77pm+mOHj2aiy66iKlTp/LOO+/EWWqLKVhEpKSYxfNoreOPP57y8nJ69OjBrFmzuPzyy7e+d+ONN1JeXk55eTm9evUCoLq6ml69etGx47YGprFjx1JeXk7Xrl154oknAPjTn/7EIYccwo9//GMGDhzI8OHDmTNnTusLbQMFi4iUFPd4Hq314IMPsnr1ajZu3Mgtt9zCoYceyvLlywG47LLLWL16NatXr6a6uhqAiooKqqurqa2t3bqNf/7zn6xevZqKigq2bNkCQM+ePZk4cSLz589nxYoVDB8+nOOPPz6RmQgULCIiCSgrK+PEE0+krKyMp556Kut6Y8aMoXPnzkyfPj3nbffq1YvLLruM9957j1WrVsVRbosoWEREEuDuTJ8+nZqaGoYMGZJ1vfLycq699louvPBC7rvvPtauXcuWLVuYO3cu69ev37reFVdcwbx586itrWXt2rX85je/YdCgQVRUVBTi1/kUXRUmIlJAxx57LGVlZZgZ/fv354477mDvvfdu8jMTJkygb9++/OxnP+Oss86iW7du7LHHHtxwww2MHTsWCBcDnHDCCSxbtoyuXbsyatQoZsyY0eR280WzG4tI0dDsxrnT7MYiItJuKFhERCRWChYREYmVgkVERGKlYBERkVilLljMbJyZvWFmC8zsykbe72xm06L3Z5vZgMJXKSIi2aRqHIuZlQG3Al8BlgBzzGyGu79ab7VvAzXuPsjMTgduAE4rfLUikjb9+/fH2jKRVwnp379/3radqmABRgIL3H0hgJlNBcYD9YNlPFAZPb8PuMU0YEVEgEWLFiVdgpC+prC+wLv1lpdErzW6jrvXAmuAws9ZICIijUrbGUvsKisrtz7PZDJkMpnEahERSZuqqiqqqqpi3WaqpnQxszFApbt/LVq+CsDdf1pvnZnROs+YWUdgObBTY01haiETEWmZYpzSZQ4w2MwGmlkn4HSg4SxqM4Czo+cnA39XeoiIpEeqmsLcvdbMLgZmAmXA7919vpldBzzv7jOA24C7zGwBsIoQPiIikhKpagqLm5rCRERaphibwkREpJ1TsIiI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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(GD_dist)), label=\"GD\", linewidth=4.0)\n",
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(polyak_dist)), label=\"Polyak Step Size\", linewidth=4.0)\n",
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(bfgs_dist)), label=\"BFGS\", linewidth=4.0)\n",
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(newton_dist)), label=\"Newton\", linewidth=4.0)\n",
        "plt.scatter(np.nanargmin(np.array(val_err_bfgs)), np.log(bfgs_dist[np.nanargmin(np.array(val_err_bfgs))]), s = 20, color='k', marker='D', linewidth=8.0)\n",
        "plt.scatter(np.nanargmin(np.array(val_err_newton)), np.log(newton_dist[np.nanargmin(np.array(val_err_newton))]), s = 20, color='k', marker='D', linewidth=8.0)\n",
        "plt.legend(fontsize=25)\n",
        "plt.xlabel(\"Iterations\", fontsize=30)\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\", fontsize=30)\n",
        "plt.xlim([0, 100])\n",
        "plt.grid()\n",
        "# plt.savefig(\"LowSNR.pdf\", bbox_inches = 'tight')\n",
        "# files.download(\"LowSNR.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "id": "eD5O1aNvlBp6",
        "outputId": "3a932b21-bc32-471b-d5eb-1569789364f7"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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Wbu2b9y4kfz8fLfq4O/vz5133gkUByWrnJwcPv74YwDuuusup9efOHGCl19+mb59+9KoUSOCgoJs38k+oKanp7usw7Rp0xg+fDh5eXn861//YurUqfj5VfynICAggEmTJrFv3z5mzZrFqFGj6NSpE0FBQQAcPHiQ1157jfbt27NmzZoKlbFq1SrAErBiY2NdbsuWLQNg9+7dTvPp16+fy9k5+vTpY/vBX7t2rUf1Cw8PZ9q0aaSnp/POO+9wyy230KZNG/z9/W31mThxIp07d2bnTtedistTUFDAjTfeyPr162nQoAFffvllqbFX1nuVlZVF48aNXd4r699DV/fKl2g/XA81K/Gv69S4OLptKSDtWBot67WsoVopd9gP+A0ODqZBgwZ06dKFm2++2fYvcbD8sFqdc845LvNr0qQJAGfOnOHIkSMO+Zdl1KhRPPvss2zatImff/6Z7t27AzB79mxOnDhBVFQUw4cPL3XdH3/8wSWXXOIQhMLCwoiKirIFGmurJScnx2X5o0ePBuC+++7j8ccfd6vO7oiMjGTEiBGMGDECgFOnTvHDDz/w+uuvs2jRIg4dOsR1113H9u3bCQkJ8Shva6v3+PHjbrVKTp486fR4WX+eISEh1K9fn8zMTIe/A55o1KgRd955py0IZGdns2LFCl5++WV++OEHUlNTufHGG/nll18qlP+DDz7IV199RXBwMAsWLKB58+al0ljvVX5+vlut2LNhyIAGKg81K/E/WGpsLIl74Y/Df/hMoJIJUtNV8EnlPQ6rLo0bN2bQoEHMmzePd955xxaorC2sESNGEBoaWuq62267jfT0dBISEnj55ZcZMGAA9erVs50vKCiwtQisLUJnRowYwYcffsi7777L5ZdfzjXXXOPNr2cTEhLCwIEDGThwIImJibz//vukp6fzzTffcO21Ho2tp6CgAIA333yTe+65pyqqWyUiIiIYNGgQV199NQMHDiQpKYm1a9eyfv16j2fhmDp1KlOnTgXgf//7H7169XKaznqvLrroIn7++efKfQEfoY/+PHRuSAjG7kdgf8OGnJ8RqJPT1iKNGjWyfS7rEZr1XEBAgEPAcIf1x3bu3LkcP36cTZs2sXr1agDuvvvuUun37t3Ljz/+CFjeiV1//fWlynQ3EL///vvceuutnD59muuuu44FCxZ4VPeKsH+UuW2b5+90Y4sG2Vf2MdW+fftcnrPOpgGOfwe8wc/Pz+F9kaf3YPHixTz44IMAPPnkk7ZWqzPeule+xOMWlTEmFBgEdAcaA5FAFpbJatcDa0Rkozcr6UuC/fw4JyiIdLt3EuH+MexJ22i5I+qs17VrV/z8/CgsLGT58uUup72xvg/p1KkTgYGBHpUxcOBAWrZsyY4dO/joo4/YunUrYOlE0b59+1Lp9+7da/vcpUuXMutTHj8/P2bMmIG/vz8zZszghhtu4JNPPuG6667z6Dt4IiIiwva5ZKcN62PLslqBvXr1Yvfu3Xz55ZdMnjy5wvVYuXIlIuL0PdX333/PmTOWd83dunWrcBmulHUPyrJhwwaGDx9OQUEBN9xwA5MmTSozvbWllZGRwdq1a6vku4wbB+Hh5W92X7lyPOkiiCVAZQIFQGGJrcBu2wtMATpVtluiL20Udcvss26dQxf1by64QB59pJP7/TXdgIddQJVz7oyjcubvf/97md3T169fb+ue/u9//9vhXFnd0+29/PLLAkj79u0lOjq6zO7JmzdvtuW5evXqUuePHz8uLVu2tKVJSkpyOO+se3phYaHcddddtsGvc+bMcX1DXNi1a5dbY6ceeughW/krV650ONepUycB5NVXX3V5vf1YpTfeeKPMsrKzs0vNUGHfPd3ZPS4oKJD+/fsLlD9zSEmbNm1ya+zUddddZ6tDWlqawzlX3dP37dsnTZo0EUAuuugi29ivsuTn59v+LvTu3dvlbB1Whw8fLjdPe5bvIB5sle+e7smPdEvgOJaZ1G8HrgfuAJ4C5gK7XASupUDfylbUFzbr/+Qjf/vNIVC9ec018u/L63r0h10eDVTeUdFAZT/gt3fv3g4Dfr/66ivbGBZPB/zaO3TokMPMAVFRUS6n4CkoKJBzzz3XNs5n7dq1tnM//vijdO3aVerXr+9RoBKxBKt7773XNv7n448/9uAuiSxatEj8/PzkyiuvlPfff9/h+54+fVrWrVsniYmJtrIvvPDCUjNn3HzzzQJIz549nc4qYXXbbbfZxmqNGTNGdu7caTt36tQp+emnn+TRRx+V+vXry969ex2utR/wGxISIu+8847DgN8bbrjBVsd58+Z5dA+mTp0qQUFBcsMNN8jcuXMdZvbIzc2V77//Xq655hpb/tdff32pPJwFqlOnTtkGf5977rmSkZHhdp2WLVtm+4fURRddJMuWLZPTp0/bzu/cuVPefPNN6datmzz77LMefV9fD1QPAHeXkyYeyxx7X2B5HGgftD4Coitb4ZrcrP+TT9i1yyFQjb3rLlncEsnOy/boD7wsGqi8o6KBSkRk9uzZEhQUZLu+bt26EhISYtv3dAolZ6yzLUDpmShKWrRoke3HB5CwsDAJCwsTQMLDw2XZsmUeByqr+++/3xasZs2aVWY97H3zzTe2fK1bUFCQ1KtXz2FqI0C6du0q+/btK5XHypUrbWn9/f0lLi5O4uPjS00LlJeXJ6NGjXLIMyIiQqKjo23TMFm3ki0c+ymUevfuLYAEBgbaWrLW7cknn3T7u1u99dZbpe5BSEhIqbwBueyyy+T48eOl8nAWqOz/HoWHh5c5lVK3bt1K5Tl//nyHKbYCAwOlfv36Dv84AuS5557z6Pv6eqC6F7jdjXRJRf8NBK4oam2dKgpYO4COla10TW3W/8nfO3DAIVANmzBBjoQgKft+9eTPu0waqLyjMoFKRGT79u1y9913S4sWLSQ4OFgiIiKkc+fOFZqU1pkvvvjClrbkhLjO/Pjjj3LVVVdJVFSUBAUFybnnniu33Xab/P777yIitrw8DVQiIg8++KAA4ufn59FUPtu3b5f//Oc/MmzYMGnTpo3UqVNH/Pz8JDw8XFq1aiU33HCDzJ492+kchFaLFy+WgQMHSv369R2Cjqt7kJiYKC1atJDQ0FAJDAyU2NhY6devnzz99NNOZ/QoOSnt888/L+3bt5ewsDCJjIyUSy65RL766iu3v3NJGzZskBdffFEGDx4sLVu2lPDwcPHz85M6depI27ZtZeTIkWVOelteoCpvczUpbWZmpkyYMEEuvPBCiY6OFn9/f6lbt6506tRJRo0aJfPnzy/30WBJgEyeLPLEEyJjxojceafITTeJDB4sMnCgSI8eIh07irRoIRIbW/2BqjnwG0Wzp5eRboWTY/WBR7C838oB+lW24jWxWf/HWXn0qEOg6vbmmyIgn8x92pM/7zJpoPprGD16tADSo0ePmq5KrWYfqFTlePrb5I1A5Xb3dBHZhWWS1x+NMc67Hbm+9rCI/BtogWVNq8+NMXHlXOazSo2lKpqt4uAPvj8VifIdx48f54MPPgDg//7v/2q4Nkr5Lk/HUT0EHAB+McZ8aoy52JOLRSRbRO4Gngee8bBsn9E4OJhAu+6thyMjOREaimzeZG15KVWmvLw8HnjgAY4fP07Tpk2dzkShlLLwKFCJSD5wFfAucB2QZIzZYIwZY4xxPlOk83xeAUoPFjlL+BtDvJNWVfP0k/z25281VCt1NpgyZQoJCQlER0fz3nvvAfDqq6/a5sVTSpXm8cwUInJGRP4PSMTSs68D8AqQZoxZDcQbYy40xvi7ysMYEw7UqViVfYOzx38dMmFF6ooaqpE6Gxw7dozdu3cjInTu3Jk5c+Zw/fXX13S1lPJppjKPqowx9YAngLuA8KLD1gxzgXVYFiXciWUMVjCQgKU1liwirueg94pwOgoAACAASURBVEHGGLHer7u3beOdAwds5177738Z8/nn3Dzjaj66bZE3ytLHiEopn+Ppb1NReudT1rupUpPSisgR4GFjzLPALcAwLBMJBQBhQG+g5MyJBvgcy7iss5arDhWHf1lJYWIhfkanUVRKKW/wyuzpInIMmApMNcZEAP2Bi7D08ovGEpz+BLYAC0VkizfKrUnNSsxunVo0EeS5e0+wMXMjnWM9mxlZKaWUc15f5kNEsoFFRVut5apF1eEgJKUmaaBSSikv0edTFeQsUAnQIROS0pJqplJKKVULaaCqoAaBgYTbLd+dExrKochIOhyE79JWUlBYUIO1U0qp2kMDVQUZY0q/p4qLo34uhB06TkpGSg3VTCmlahcNVJXg6j1V+4OwfNfymqiSUkrVOrU2UBljhhljthhjCo0xLpe4NMZcYYzZZozZYYx5zJMySgWqop5/HQ7Cp799WpFqK6WUKqHWBipgMzAU+M5VgqLZM6YBfwfaAv8wxrR1twCXPf8y4dcDv7Ipc5PntVZKKeWg1gYqEdkqItvKSXYhsENEdonIaWA2MNjdMlyNpepw0LL//ob33a+wUkopp2ptoHLTOcBeu/30omNucdWiavsn+BXChxs/5EzhGS9UUyml/rq8PuDXnjHmJREZW4X5LwNinZx6QkS+qIoyExMTSUhIACCkTh3w94fOlsG9qRkZrAAGnIEWR2D77kxe/uhlxt8yHoDk5GQA+vXr59a+Ukr5Kle/X9bPaWlpXiurUpPSlpu5Mb+JiNvvfKqoDsnAIyKy1sm5HsBEEbm8aH88gIhMdpGXlLxfDX74gcNniltNe4cNo8mhQ1x3A8xrC9e3vZ5Ph3nesUInpVVK+aKamJS2qh/9Vapy1eAXoJUxppkxJgi4EVjoSQbOxlKBpUMFwMJtCzmSe8QLVVUVMXHiRIwxTrewsDBatWrFrbfeyo8//uj0+uTkZJfXl9zs/0VZUnZ2Nm+++SZDhw6lWbNm1K1bl6CgIBo2bEj37t0ZPXo0S5Ys4cwZ14+KRYRPP/2UIUOGEB8fT2hoKBEREbRo0YLevXvz0EMPMX/+fI4fP17Z26aUb6nsWvZlbcBvVZl/OWUPwfLOKQ/IBL4tOt4YWGyX7krgDyxLkTxRTp5S0vWbNwtJSbbt/csuEwGZdx7CRMs2bc20UteVx1lZynMTJkwQLEvPSExMjG1r2LCh+Pv7284BMmHChFLXJyUl2c5HR0c75FFyW7VqldM6TJ8+XerVq+dQVlBQkNSrV69UHZo1ayZLly4tlcfRo0elb9++DmkDAgKkXr16EhAQ4HB85syZXr6LShXz9LepKH2lfs9rbWcKEZkvIk1EJFhEYqTo8Z6I7BeRK+3SLRaRv4lICxH5l6fluBpL1aV4qSpmpMyo2JdQXpWRkWHbDh48SF5eHj/88APnn38+AM8884zLlhXAvHnzHPIoufXs2bPUNePGjeOOO+7gyJEjtGnThunTp7N3717y8vI4fPgw+fn5bN++nbfffptu3bqRmprKsmXLSuUzcuRIVq5cib+/Pw8//DB//PGHLY/c3Fw2bNjAiy++SKdOnbx3w5TyEVXameKvwFXPv4QsiD4JR8MsY6pWp6/moiYX1UQVlQv+/v706tWLBQsW0LRpUwC++OILpwGnIj788ENeeuklAG666SZmzpxZasl5YwwtW7akZcuW3HXXXSxcuJA9e/Y4pNm+fTuLFlkWI3juued47DHHcekBAQF07NiRjh07MnbsWHJzc71Sf6V8hQaqSnIVqAA6Z0BSc8vnqWumaqDyUU2aNKF+/focPnyY7Oxsr+SZl5fHuHHjAOjUqZPTIOXMoEGDSh1bv3697fPgweUP8wst8d5UqbNdrX30V11cDfoF6JJRfHzulrkcOHEA5Xv27dvH4cOHAWjdurVX8lywYAH79+8HYPz48W4FKXekp6d7JR+lziYaqCopPjjYYT+9YUNOB1gaqhcfqWM7nl+Yz9u/vl09lTLGdzcfUlBQwE8//cSQIUMAaNSoESNHjvRK3suXWyYl9vf356qrrqpUXhdccAGm6N5Z308p9VeigaqSQvz9aWz3r2Xx82Nvo0YA9D4c7pD2rbVvcbrgdLXWTxWLjY21bY0aNSI4OJiePXuybds2br75ZtasWUNUVJTL64cOHeqQh/327rvvOqT97bffAGjRogURERGVqndCQgKjRo0CYNOmTZx33nl07dqV++67jxkzZrB582Ydc6dqNX1H5QXNQkLYf7o4AKXGxtJi/37q7T5IIyI4iOW9R2ZOJp9u+ZSbO95cU1X9S8vMzHR6/OTJk2RlZZGZmUl8fLzL648ePeryXE5OjsO+9VFivXr1XF7zwQcfMHas84lbMjIyHPbfeOMNYmNjefXVV8nJySElJYWUlOI1zxo1asTNN9/MuHHjiImJcVmmUmcjbVF5gatBv6awkHF1r3Q49/qa16utXspRybEZubm5pKSkcOutt/Lll19y8cUXs2DBApfXJyUluRznMWbMGI/rc/LkSTIzM51uJQUEBDBp0iT27dvHrFmzGDVqFJ06dbK9+zp48CCvvfYa7du3Z82aNR7XRSlfpoHKCxLK6Pl3c2F7h3Nr9q3hhz0/VG2FRHx38yEhISF07tyZ//3vfwwZMoS8vDwSExO9MrND/fr1AThyxPWsJPfcc49DsJs5c2a5+UZGRjJixAjeffdd1q9fT1ZWFkuXLuWaa64B4NChQ1x33XWcOnWq0t9BKV+hgcoLXA36BYjZvo8rWzm2qiatnFQt9VLuu/POOwHIyspi8eLFlc6vbVvLFJc7d+70Wpd3Z0JCQhg4cCALFy7k1ltvBSw9A7/55psqK1Op6qaBygvKGktFSgpjezq+h1i6ayk/7nU9A4KqfvbvplJTUyud3yWXXAJYehZ+9dVXlc7PHXfddZft87Zt5S3FptTZQwOVF5TVomLjRvo26UW/hH4OaZ5Z+Uw11Ey5y358Unh4eBkp3XPttdfSuHFjACZPnszp01Xf29O+d2FwiWETSp3NNFB5QZPgYPzt9g/Wq0eONXidOgXbtjGh7wSHa5bsXMJPe3+qvkqqMn388ce2z926dat0fsHBwbzwwgsAbNiwgdtvv73CwSo1NdWtsVPvv1+8onTXrl0rVJZSvkgDlRcE+PlxbolWVZp9qyolhX4J/egb39chjbaqal5GRgZPPvmk7Ue+e/fu9OjRwyt533LLLTz66KMAfPTRR3Tu3Jnp06eXml0iIyODDz74gFdeecVpPlu2bKFNmzZcddVVfPDBBw4L0uXn55OSksJtt93Gq6++CsCFF15I7969vfIdlPIFVT2O6pEqzt9nNAsJIdWup1VabCztrD8oKSkwYgQT+k5gwAcDbGm+3fktP+39iR5NvfPDqMoWG+u4GPSpU6fIysqy7Xfo0IHPP//cNguEN7z00ku0bt2asWPHsnXrVtvA3eDgYOrUqcPJkyc5efKkLX2zZs14/vnnHfIIDAyksLCQxYsX2zp6BAUFERERwdGjRx0G+3bt2pX58+fj56f/BlW1R5UGKhGpfPeps0SZ76mKBmb2S+jHxfEX893u72ynJn03ia9v/rpa6vhXV3J8UmBgILGxsXTq1Inrr7+ekSNHem1OPnt33HEHw4cP54MPPmDp0qWsX7+eQ4cOkZWVRWRkJG3btuWCCy5g8ODBXHrppaWCzOWXX8727dtZvHgxP/zwA5s3byY9PZ1jx44RFhZG48aN6dKlC0OHDmXYsGEapFStU6VL0dc2zpait/rX7t08addb7KG5c3nlzTctO1FRcOQIGMOK1BVc8sElDtf+fMfPpWZW16XolVK+qDYuRf+XUWrQb5MmxTvHjsHevQD0T+hP73Md3x/ouyqllHJNA5WXlHr0l5DgmKBoTSFjDBP7TnQ49fWOr1mzT6e9UUopZzRQeUnzEoFqV8OGODSO7Ra/G9BsAL2a9nJIr60qpZRyTgOVl8QEBRFq9xL7eGAgR+sUr0fFhg22j8aYUuOqFm9fzC/7fqnyeiql1NlGA5WXGGPKnJzWvkUFMLD5QHo27elwbOLKiVVVPaWUOmt5HKiMMaHGmOHGmNeMMXOMMd8U/fe/xphRxpiOVVHRs0Gp91RFU+gAsGsX2M3K7apVtWTnkiqto1JKnW08ClTGmEFAGvAx8AAwDLis6L//B7wNpBhj9hpjphhjOnm3ur6tVKDq0MExwcaNDruXNr+01LuqMd+MIb8gv0rqp5RSZyO3A5UxpiXwITAPuBO4oei/E4DPgN2AKdrOAe4H1hljlhpj+jrNtAoZY4YZY7YYYwqNMS4nbzPGpBljNhlj1htj1lamzFILKLZu7ZigxOM/YwyvXf4ahuIhBlsPbWXaL9MqUw2llKpVPJmZ4irgURF521UCY0w8sAT4HegH1AEuAQYYY2YDo0XE9Xre3rUZGIqllVee/iJyqLIFlmpRnXOOY4ISgQrggnMu4LbOtzFj/QzbsYnJEytbFaWUqjU8efSXX7S5JCK7gf0iMhhoAFyJpbWVD/wD+KW63mGJyFYRqdZFeUoFqrp1HRPY9fyz9/wlz1M3uDhtVl6W03RKKfVX5Emg+gZ4xBgTUU46ARCRfBH5RkRuwPIocCyWFtZPxph+FalsFRFgiTHmV2PMXeWmLkPJQJXm70+h/QSnmzbBmTOlrouJiCnVsUIppZSF24/+RGSXMWY58KMx5lYRSfHg2sPAv40xbwGvAJ8bY9qLyAHPq1zMGLMMiHVy6gkR+cLNbHqLyD5jTCNgqTHmdxH5zlXixMREEopmnYiKiqJz587069cPgPWrVhG+aRM5RZ0o8lJSmNe0Kdfv2QNAcl4ezJpFv9tus+wnJwPQr18/Rl84mimzp7A3ay80c7PmSilVQ+x/v+z3rZ/tl6OpLI8mpTXGBAJfYnnvNB+YWvJH3RizQkQGOLveLs3DQGsRqVQLxh3GmGTgEREpt6OEMWYikC0i/3Zx3uWktFZd164lJTvbtv/DrFn0mlH8/omPPoKbbnJ67Re/f8G1c6617ExEJ6VVSvkcn5+UVkTysXSqeBe4DkgyxmwwxowxxjT1IJ9XgPYe1bQKGGPCjTF1rJ+xdLXfXJk8S72n6ljilZyTDhVW17S+hnYN21WmeKWUqnU8HvArImdE5P+ARCAL6IDlcV6aMWY1EG+MudAY4+8qj6KgUMfVeW8wxgwxxqQDPYCvjDHfFh1vbIyxrpMVA/xgjNkArAG+EpFvKlNuyUC1q3lzxwRlBCo/48e4XuMqU7xSStU6lVqPyhhTD3gCuAsILzpszTAXWAdsAHYCx4FgIAFLayxZREZVuPAa4M6jv2n79jF6+3bbfmJoKDO7dy9O0LAhZGaCi1Vk8wvyaTW1Fbsf3K2P/pRSPqcmHv1VaoVfETkCPGyMeRa4BcsMFd2L8g0DegO9SlxmgM+xzGxR65ScRT01KAhCQyE313Lgzz8hIwPs5wG0E+gfyKM9H2U0o6u6qkopdVbwyqS0InJMRKaKyMVAPWAw8DwwB1gKLAM+AZ4EOojIMBHJ8UbZvqbUO6pTp6DkVEopZXeYvL3L7d6u1l/WxIkTMcZgjCEsLIz9+/e7TJuWlmZLa9+DydccO3aMiRMnMnHiRI4dO1bT1VGqylWqReWMiGQDi4q2v5ySM6in5+WR36ULgWvsFkZcvx6uvNJlHqGBoS7PqYrLzc3lmWee4e233ZmsxHcdO3aMZ56xrF+WmJhIVFRUDddIqaqly3x4WYi/P3FBQbb9QmDPBRc4Jlq3rnorpWxmzJjBH3/8UdPVUEp5QANVFSj1+K9NG8cE5Tz6U97XtGlTOnbsyJkzZ3j88cdrujpKKQ9ooKoCTien9bfrrb9rF2TpfH7Vyc/Pj8mTJwPw+eefs8b+UawHVq1axYgRI4iPjyckJITIyEguvPBCXnzxRbLtBnpbXXPNNRhjeOSRR0qdO3DggO2dWLduzif4b926NcYYpk+fDlhmAWjWrHjqkmbNmtnyMMbYZgmwl5GRwaOPPkq7du0IDw8nPDycdu3aMXbsWDIzM52Wa/++Li0tjczMTB544AGaNWtGSEgIMTEx3Hjjjfz+++/u3DalKkdEdHNzs9yu8j25a5eQlGTbxu/cKdKunQgUb8nJZebhblmqbBMmTBBA4uPjRUSkb9++Akj//v1LpU1NTRUswyskKSnJ4VxBQYH885//tJ0HJCIiQvz9/W37rVu3lrS0NIfrXnnlFQGkS5cupcr78MMPbdf6+fnJ0aNHHc6np6fbzu/atUtERIYMGSINGjSwHW/QoIHExMTYtiFDhjjkkZycLFFRUbb04eHhEh4ebtuPjo6W77//vsx78eWXX0qjRo0EkLCwMAkODradq1u3rqxfv77cPwdVe3j621SUvlK/veW2qIwxO40xBdW87fROGK4ZTnv+denimEjfU9WIF154AYCkpCS++cb9sd0TJkzg9ddfp1GjRkybNo3Dhw9z4sQJcnNzSUpKokuXLmzbto2hQ4dSWFhou65///4AbNiwgSNHjjjkmZSUBEDdunUpLCws1dPQej4+Pt7Wipo3bx6//PKLLc0vv/xCRkaGbZs3b57t3N69e7n22ms5duwYbdu25YcffiA7O5vs7Gy+++47WrduzdGjRxk8eDD79u1z+d1vueUWWrVqxS+//EJOTg7Z2dksXbqUuLg4jh8/zv333+/2fVSqItzp9TcYqF/VFSnhcDWX51WlZqfIzbUEqg8/LD5Yhe+pjA93rRYnj6aqU/fu3RkyZAjz589n/PjxXH755RgXg6+t0tLSmDx5MqGhoSxZsoROnYoXrg4MDKRfv36sXLmStm3bsm7dOhYuXMi111rmbOzUqRP16tXjyJEjJCcnM3ToUNu1K1asAGDMmDFMmjSJFStW2K6zP28Ndp56/vnnOXbsGNHR0SxfvpzY2OL5m/v06cOyZcto164dR44cYfLkyfz3v/91mk9MTAxLly4ltGhh0ICAAAYOHMjbb7/NoEGD+P7770lPT6dJkyYVqqdS5Sm3RSUim0VkZTVvlZpvr6Y5bVF17eqYSDtU1Jjnn38ef39/1q9fzyeffFJu+vfee4+CggKuuOIKhyBlr06dOrYg8+2339qO+/n50bevZYFra+AB2L17N6mpqbRq1YqRI0eWOg/FLaqKBCoRYe7cuQDcc889DkHKqkmTJtxzzz0AzJ4922VeDz/8sC1I2fv73/9OUFEP102bNnlcR6XcpZ0pqkCT4GAC7P6V/md+PidKDvrdurV4tgpVrc477zxuK1pq5amnniI/v8z1QFm1ahUAS5YsITY21uU2c+ZMwBKE7A0YYFlMwD4QWT8PGDCAFi1acO6557JlyxYOHjwIQGpqqm2ZhIoEqtTUVNujxoEDB7pMd+mllwJw+PBhUlNTnaa56KKLnB4PCAigYcOGAKUeayrlTRqoqkCAn1+pgb87g4LArrcWBQWWhRRVjZg4cSKhoaHs2rWLt956q8y01tkscnJyyMzMdLnl5FgmWzl58qTD9dZAs3XrVjIyMoDi1pI1iFnTWAOY9XyLFi1o2tTthQlsrAEP4JxzznGZzv5xnf019urUcT1/dECA5e1BecFeqcoo9x2VMaYtlmXlq9MhEfmtmsv0qpahoeywazHtPHWKzl26gP2/WlNS4MILvV52Tb8HOhucc8453H///bz00ks899xzthaWMwUFBQCMGzfO1hnDE+3atSMmJobMzExWrFjBTTfdRFJSEsYYW4AaMGAA77//PitWrODGG2+s9PsppWoTdzpTfIllxvPqlAY0Ly+RL2tRskWVm2t5T2XXK0vfU9Wsxx57jHfffZeDBw/yyiuvcOuttzpNFxsby7Zt20o90vNEv379mDNnDitWrKBbt26kp6fToUMH26MzVy0qa4vLU40aNbJ9Tk9Pp3Xr1k7TpaenO71GKV/iTmeK5iLiV83bWR2kAFqUePm8w9rzz54GqhoVHR3NY489BsArr7zCn3/+6TRdr16WBQCWLVvGqVOnKlSWfSByFoSaNm1Ky5Yt2blzJ0uXLrU9bnQ2gNfPr/h/W3Gx3EKzZs2oV68eAMuXL3dZr2XLlgFQv359h4HESvkSfUdVRVqWCFQ7nQWqjRvhzJlqrJUq6f7776dJkyacOHGCZ5991mma22+/nYCAAA4dOsSECRPKzO/06dNOZ6iwBqXU1FRbp4uSrSVrMHvqqacAS6ePOCfLwdStW9f22dXs6cYYhg8fDsDbb79tezdmb//+/bYJev/xj3+U+b2UqkkaqKqI0xZVXBzExBQfPHUKdAqaGhUaGsrEiRMBWLTI+YT/LVq0sAWPl156iZEjR7J5c/EIijNnzrB+/XomTZpEy5YtWe9kFedWrVrZOi6sXr0af39/W7d1K2vgWr16NeD6/VRUVJStg8TMmTM54+IfO48//jhRUVEcOXKEgQMH8uOPP9rOrVq1ioEDB3Ls2DHq1atna1kq5Ys0UFWR5iEh2A8j3ZuXR15hoT7+80GJiYmcd955ZaZ56qmneOqppzDGMGvWLDp06EBYWBgNGjQgJCSELl26MGHCBPbu3etyALF94OnatSuRkZEuzzvbt2cd/zR16lQiIiI499xzSUhI4MYbb7SladKkCQsWLCAyMpItW7bQq1cvIiIiiIiIoHfv3mzdupWoqCgWLFhQZs9ApWqaVwKVMSbUGPOsMaZr+alLXetnjKnuXoVVLsTfn3OCg237AqQ5G/irUynVOH9/f55//vky0xhjmDRpEhs3buTee++lTZs2+Pv7k5WVRXR0ND179uTRRx/lxx9/tL3TKsk+8DjrJBETE0Pbtm1t5Tl7P2X1+OOP85///Idu3boRGBhIeno6u3fvLvWIr2/fvmzdupWHH36YNm3aUFhYiIjQpk0bHnnkEbZu3UqfPn3K/O5K1TTj6mWsR5kYcx8wFXhORJ5285rGwJvA5UAg8DMwREScD+bwAcYY8eR+9UtJYaXdLOlfdujAVUlJMGxYcaKLL4aVK52V5fJFuVJK1RRPf5uK0pc9T1k5vPXoLxB4uWgrlzEmCPgKuBr4FngdiAeme6k+PsFph4rzz3dMtG4d2E1iqpRSypG3AtUvQH0ROWGMudEY819jzARjTEsX6a8HOgFzRGSwiDwIXAT0MMZ091KdapzTDhUJCRAdXXwwOxt0xVmllHLJK4FKRFYBCcaYZcBHwP8BTwO/GWNudnLJNVhe23xql8c+LC2y4d6oky8oGah25uaCMVBykbxff63GWiml1NnFm73+jgIDgP3AGmAbUAhMN8aUHBZv7WJVssvbZ0APb1TGGPOyMeZ3Y8xGY8x8Y0yUi3RXGGO2GWN2GGO82ke35KM/25RKJR//aaBSSimXvNXrrw0wEBggIk1FpIeItMXy3mkZMKbEJdZefofsD4rITqD0egQVsxRoLyIdgT+A8U7q7Q9MA/4OtAX+UTS3oVeUbFGlnjpFgUjpQLV2rbeKVEqpWsdbLap+wFsikmx/UEQygTuLztsLKzpfegi/pRVWaSKyRESsIyF/Bpyt6nYhsENEdonIaWA2loUivSIyIIAGgYG2/XwR0vPySj/6S0nRDhVKKeWCtwJVJOB0LWsROQAElzhcVrlVMQj5duBrJ8fPAfba7acXHfOakpPT7sjNhfh4KJqHDdAOFUopVQZ3Zk93x25gCFBqLWtjTDdgjzuZGGNaAJnuFlrUecPZo8InROSLojRPAGewdPKotMTERBISEgDLVDadO3e2DcxMLloC3n4/Ii3N0tMPYP16Fh86xCXXXw/nn0/y0qWW9AC//kpy0WDNsgZ6KqWUL3D2e2d/zrrwpzd4a8BvPSwtk7nArKLP0Vi6oD8NTBSR6UVpE4BdWHr9xYjIIbt8xgGxRd3VvVGvROBu4BIROenkfI+iul1etD8eQEQmu8jPowG/ABNSU5lktzzEo02b8lKLFvD44zDZrpgxY+C11+zL0gG/SimfUxMDfr3SohKRI8aY54B/ASNLnM4HYo0xlwHNgEeLjv8GPAg8AbaZKh4BBnmjTsaYK4CxQF9nQarIL0ArY0wzLI8ubwRu8kb5Vk67qIP2/FNKKTd569EfIjK5aMaJcYD1xcw3QCLQB8v4qHOAJOAOYCeWcVYdgB3AMGCtiPzkpSr9F8u7saVFk4T+LCL3FAXE/4nIlSJyxhgzGsvsGP7ADBHZ4qXyARezU0DpQJWSYlme3t/fm8UrpdRZzyuP/hwyNKYu0AbIEJEyl0QtamV9ADQCfgUGFXW+8EkVefSXefo0sXbLK4T7+XGiTx/LzOoNG8Lhw8WJf/sN2rSxlqWP/pRSPudsnuvPRkSOi8jq8oJUUdolQByWd1UX+HKQqqhGgYGE263ImlNYyMH8fMsMFfr4TymlylWl61EZY/yNMQ3LSiMWztcArwWMMTpDhVJKVYLX3lFZGWNCgLuwjF1qC/gbY04D3wNTRGSxt8v0dS1DQ9mQk2Pb35KTQ6/IyNIDf+1mqIiPj3e5AJ9SStWU+Pj4ai/Tq4HKGNMOmIPlHZX9r2wwlimWLjHG/A+4z27WiFqvc0QEnx8qni1q3YkTlg9ldKio6BiE/637H3cuutPh2GUtLmPxTYvx9/NeR43k5GQd74XeB3t6L4rpvfAur3WmMMacg6W7dzSwEsv8esex9KZriGUKoz5AKPBfEfmnVwquRhXpTAHw1eHDXL1pk23/wjp1WH3++SACMTHwp92Tzw0boGPHStXzni/v4e1f33Y4NrbnWF689MVK5auUUp7ymXFURd4CUoFuIrLfWQJjTCiWbuqvGmM+8WJXdJ/WNSLCYX9Ddjb5hYUE+vlB9+6waFHxyZ9+qnSgev3vr7Pp4CZ+3Fvc2/ClH1+iTcM2JHZOrFTeSilV3bw1e3orLBO8XuEqSAGISK6IvIdlvarR3ij7bBAXr1+m5QAAHrFJREFUHExsUJBtP0+E308WjUHuXmKdyJ9/rnR5Qf5BfDbsMxrXaexw/M5Fd7Js17JK5w+O06X8lel9KKb3opjeC+/yVq+/i4APROSEm+k/Bzp7qeyzQpcSraqU7KKJ46sgUAHE1Ynj8xs+J9i/eD7gM4VnGDpnKBszN3qlDKWUqg7eClTnANvdTVzUkSKk3IS1SMnHf7YOFRdcAHbjrPj9dzhyxCtldm/SnVlDZjkcO3H6BFd+dCXpx9Mrlbe+KLbQ+1BM70UxvRfe5a1AdQjLPH5uMcYEY5mU9i+ja506DvvrrC2qOnWgfXvHxGvWeK3cYe2G8e9L/+1wbN+JfQz6ZBA5p3NcXKWUUr7DW4FqJXCLMSai3JQWtwOrvVT2WaHko7/12dkUWnsQ9ujhmPgn7/YxeajHQ4y+wPGVYEpGCiMXjKRQKrZgoz6Dt9D7UEzvRTG9F97llUAlIjuAjcBCY0ycq3RFM1XcA7yMZQn4v4yEkBCiAoo7WZ4oKCieoLaK3lNZGWOYcsUUrvnbNQ7H522dx1MrnvJqWUop5W3eHEcVj6WVFAl8B/wOZBWdrgMkAD2BBsCbInLW9fqr6Dgqq0vWr2fFsWO2/dlt2zK8USPLe6miyWgBiIy0vKfy8+4MVyfyTtB7Zu9SnSneveZdRnUd5dWylFIKfGxS2qJJaAdiWdfpUizdz58o2v4JDMYy8HcmMMZb5Z5NSvX8s3ao+NvfIDq6+ERWliV4eVmd4DosvHEhjcIbORy/c9Gd3LrgVo7nHfd6mUopVVle/Se7iGwGOgKPA1uxTKNksCyemAQMFpFRf6Xpk+y57FDh5wcXXeSY2IP3VOnp6bzwwgvcfvvtvPDCC6Snu+7RFx8Vz4LhCxy6rQN8sOEDOr3ViR/2/OBWmfoM3kLvQzG9F8X0XnhXVSzzcVJEXhCR9kA4lmU8QkXkEhFZVM7ltZqzLuriqkOFm++p5s2bR7t27Rg/fjwzZ85k/PjxtG/fnnnz5rm8pkfTHswaMotAv0CH42nH0hjw/gCS05Jtx06dOcWUn6cwbuk4dh7Z6VadlFLKm7y+cKLbBRvzbxF5pEYKr6DKvqMqECHy++/JKSzuabene3eahoTAkiVw+eXFidu3B7v5AZ2ZM2cON998MwUFBaXO+fv789FHHzF8+HCX16/PWM+IeSPY8qfjosYx4TGk3J1CVEgUV318FUlpSQA0rtOYTf+3iXqh9cr9rr/u/5X5v8+nz7l9uLzl5eWmV0rVTt54R1WTgeqEiNQpP6XvqGygAui1bh0/Hi9+F7SgfXsGN2gAx445vqcyBo4etXSscKKsIGXlTrA6deYU45eNZ8rqKQ7H+5zbh7rBdflq+1cOx8f1GscLA18AIDM7k2m/TCM6JJq7zr+L8KBwAL7e/jXXfHINBWKp2yuXvcJDPR5yWQelVO1VbYHKGPM3oHu5Cd3XGXhARLy37kQ18Eagun/7dv67b59t//Fzz+VfzZtbdtq1syxHb7VkCVx6aak85s2bxw033FBmkLLy9/dn7ty5DB06tMx0Tyc9zbPfPVtufiEBIey4fwdrVq1hzLYx7MnaA0DXuK4svmkxf578k57Te3LitONsWrOvm83w9q4D5tlKl3MopveimN6LYtUZqG4CPsTLs0n8FQPVzAMHuH3bNtt+XX9/Nl9wgeXx36hRMH06AFnh4Ux/5RUWXnghh/L/v70zD5OquhL479Sr6qbZulkM0A0IisSoQdyI0WRsXFAzJupoUAc1OvHTMWbUxIyamFHHZWJGk4kZ45IxuKUVMoqOIZqIQGM0alzACKKo2GqDiCDNKt101Zk/7quu10Ut3XR1VXXV+X3f++rdd7fzTl/e4d577r072BaLsS0apTUaZWNLC92RQ0SorqkhlMXdfXPrJnbEdmQtr9Lrx47Fi4lN+kKn5yFxf86YpjKgwuDKwYRDOT+rMzPRKLS3uysadRe4I1bS0Y0DK3e8/jqRL36xh0KWBpl1oYAQGzQQPA9Q9zGJ/xkkKWk8PhCdrcVrphTq4hPVSLYcO5UpHc+SblLI3r7kNbzJ+3dZ9qx1pc6QlCKRa1e/Ut3OmUUZCrQddXzeDNWxwJPAZ8ASoK0nleLWVI0tR0O1tq2N8S+8wLbAPNWxQ4bw5KRJyIMP8u7ll3PrKadwz3HHsaV//56KbBiGUVimTs2boToEeAGYoqqv9KRCv7xhwBpVjWRNXETkwlAB/HdzMxe/806nZ7fsuSdN69dzx/r1RL0+Zb8NwzDSkwND1VX39PW4Pt2SnlQWR1XXA59kTViiXFRXxxFJThI/ePddbmtp6TtGaklOmkLfx/SQwHSRwHSRU7o6YdAEjFdNOfmwqxySw7J2QkRuBr6OG6Z8FzhXVVtSpGsCNgNRoF1VD+5NuQBCIvxm772Z9NJLnYYAkxm1bh0XrVnDCeecw0DPo38oxLo1azjs8MPZsrmrR3/BoMGDee7ZZ6mtrc2eOA0xjXHUfUfx+lrfZX5lO5HtVcw9Yy4HjjqQG565gVtfvBWAfXbbh8dPf5yaqhpUlRv//B/84oVfkDziPqYF7poLU9Ietdlz1lXBi3Xw+ghYthss3w02VkJrGFo9J1FYIRwDL+avUNfOI+2Z2PF+O5F1eZ5360VCIkRCYURCqMaIaczpKOQRlgieeIiIe+6PLkS8MF4ozPamVvp/VoWqEtMoIfEIe2EioTAhCaEoGyuhXZRwKEw4FCEc8hCEGDFiqqgqkVCYSChCKOT+06YaIxqL4oU8vFCYcMhz5amiKDGN+eWFCfnyqSrqb7jshTzCEsYLxedQ3XuFJEQ45J6HJNQRp+r0EI8TBEU76vPEyeH5eZwMThdh8QiHwny8fRWjtn3QUZcnHqGQhyehhHwoquCFQn6Z8ffVjrmieL6QP2/qdKuERJw+8Dp06/5Wvnx+vp3LCxHyr7jsqtrxLCQhREIuxs/nnjsZUskeIlCer4e4HCEJ5eSE3IK5p/c2IjINWKCq7SLyUwBVvSJFuibgYFVd14UyczL0FyfVECDA+NWrufa++zh9wQIqJkyA5cs7xfeG119XaGxq5JgHjqE95jYWueuEuzj/oPM74l9b8xpNLU0cO+FY+oU7Hzf29vq3efytx5n79lz+/P6f+fobUe55DGpaeyxWB2v7w5vDnTFaPBIWjXPhLludNIRDYTzxaI0mhN29encmjZjEF4Z/AUXZ0raFzW2biYQiVFdWM7hyMFWRKmL+R1ZRhlUNY+TAkYwYOIL+kf5EY1GiGnUfZy9CJBQh4kX8j1GMqEYJSYgKr4IKrwJPvI4PX/zjXOFVEPEihCTUqa5IKEKFV0E4FO4wLPGd8iu8CiKhCF7I66grprFOH2zDyBV9eh1VPhGRk4FTVXVGirgmCmSoYqoc97e/MW/DBgCqPY9/GzmS706aROX27YmEzc1QV9cpb67WUWVl3TqYNQs+/hiOOYaFdTv403vzOGr8URyz586u81nZtInWK/+Vyjt+nTJ69UB4/POwYaBHZMgwwoNq2BTdSkvbJja3bcHrV8WAgUMZNGg47VUVrApv4wPZzOrKVqqGj6JucB21A2uJapQN2zfQsr2FkISoHVRL3aA6hvcfzmc7PmNz22Y2t26mpl8NY6vHMqZ6DNWV1WzdsZUtbVtobW+ldlAt44eMp25QHV7Ioz3Wzta2rXghj4EVXT3RxjDKm1wYKr+LXNoX8HvgzDRx7wGvAq8A52cpR3PNtvZ2va25WW/98EP9pLXVPfzyl1WdA7W77rsvZd5Zs2ap53mKG8HqdHmep7Nmzdp1wf7yF9WzzlKtrOwsS22t6iWX6MLLL1d95BHV+fNVly1T3bYty4tuU73lFtVhwzqXF7+mTdPtv39M3137ln7Q8oFGY9Fdlz2PLFy4sNAiFA2miwSmiwT+d7NH3/A+PbguIk8DI1NEXaWq/+enuQpoBxrSFPMVVV0lIp8D5onIm6r6TLo6zznnHMaNGwdATU0NkydP7ljYF9+Isrvhi5Ljjz4ann+eRr/O+vnz4eyzd8o/YsQIrr76an72s5+xKbDbRXV1NTNnzmTo0KGdFh52Wb7Zs+HOOxP1+7+NAKtXU3/rrYlwMH74cBg5kvqJE2G33WjcuBE2bKC+vR1ef53GtWt3Ls/zqL/5Zrj0Up5ftAiWre6xPvMZXrJkSVHJU8jwEt+BoFjksXBhwvH7pqYmckVJD/2JyDnABcBRqrqtC+mvBbao6i1p4jUv+lq0CIKr2mtr3fBfmoWozc3NNDQ0sGLFCiZOnMiMGTMYPXr0rtX98stwSK/6uSQYNw5mz4YpU/JTn2EYecfmqDIgIscBPweOUNWUrvAiMgAIqepm/34ecJ2q/jFN+vwYqtZWGDoUtgVs6/LlsPfevV/3P/0T3HNP52fjx8OBB8Kf/gTxo0l6wqBBcNll8P3vu3vDMEqWojo4sQi5DXey8DwRWSIidwKISK2IPOGnGQE8KyKvAX8F/pDOSOWVykr46lc7P5s/v/frXb8eHnqo87Pbb4d33oGHH4a1a93vpZfSOG0afOMbTs7dd+/aacRVVc44rVwJ11xTEkYqONxR7pguEpguckufnqPKhKpOSPN8NfA1/34lsH8+5eoyRx/tejBx5s6Fiy7q3TrvvReC3oa77w7nn58wQlVVcMop7mps7Dw82dYGTU1uiHLdOvjkE7f7+/DhMGYMjB0LEya4MgzDMLpByQ799QZ5G/oDdxbVpEmJsOfBqlUwYkTv1BeLwcSJ8G7gcMSf/ASuvLJ36jMMoyywob9SZr/9ILgTdTS687BcLnnqqc5GqqICvv3t3qvPMAyji5ihKlZE4KyzOj+7//7eq+/22zuHp0+H3XZLm9zG4B2mhwSmiwSmi9xihqqYmTGjs5PC4sWwdGnu62lqcnNgQb7zndzXYxiGsQvYHFU3yOscVZxp02DevET48svhpz/NbR0//jHceGMiPHkyvPpqtw4QNAzDSIXNUZUDycN/DQ2JU2pzQTTqvP2CfOc7ZqQMwygazFAVOyefDAMGJMKrVsHChbkr/6mnXJlxBgyA00/Pms3G4B2mhwSmiwSmi9xihqrYGTgQko/oeOCBHhfb3NzMTTfdxMsXXtg5Yvr0kliIaxhG6WBzVN2gIHNUAE8/DccEjtTo18+ts5qQck1zVubMmcO5555LxaZNrAIqgpHPPguHH94TaQ3DMDqwOapyYepUCG4yu307XHCBOyCjm8yePZvp06ezadMmzqKzkXoTmP3hhz2V1jAMI6eYoeoLeB7ccEPnZwsW7Lx5bBaSD1tMXs47E5hx5pnMnj07a1k2Bu8wPSQwXSQwXeQWM1R9hbPPdvv/BbnsMvjooy5lnzNnTicjNQXYNxDfDtwPRKNRZsyYwZw5c3IhtWEYRo+xOapuULA5qjgrV7ptlYLHf5x0EvzudxCJpM3W3NzMvvvu23G4ogCPACcH0jyWFB48eDDLli3b9XOtDMMwsDmq8mOPPeD66zs/e+wxOOAAt5t5Gn772992OgH4V3Q2SuCG/YJs2rSJhoZ0hyIbhmHkDzNUfY2LL4aDD+78bNky53Dxta/BddfBo4/CihXQ3g7AihUrOpL+HEhySOcN4Al2JpgvGRuDd5geEpguEpguckvJnkdVsoTDbh3VEUe4gwyDPPmku+JEIjBhAldFo5wH1ALjkopbDXwDSLXXxcSJE3MouGEYxq5hc1TdoOBzVEHWroUrrth5+6PuFAEcgXNLT6a6upqlS5faHJVhGD3C5qjKmc99zrmnP/ec20S2m3wKHENqI+V5HjNnzjQjZRhGUWCGqq9z2GHwyivw4ovw61+7OaypU2HkyLRZ3sQZqb+liPM8j4aGBv4hedumJGwM3mF6SGC6SGC6yC02R1UKhEIwZYq7gmzcCG+95TadHToURo1iznPPMf2884jGYjsVEzdSp512Wp4ENwzDyI7NUXWDopqj6gHxvf6CLuvV1dXMnDkza0/KMAyjO+RijsoMVTcoFUMFbhFwQ0MDK1asYOLEicyYMcPmpAzDyDlmqLIgItcDJwIxnJPbOaq6OkW6bwE/9oM3qOp9acorGUPVUxobG6mvry+0GAXH9JDAdJHAdJHAvP6yc7OqTlLVycBc4OrkBCIyFLgG+BJuC7xrRGRIfsXseyxZsqTQIhQFpocEposEpovcUtKGSlU3BYIDgFTdoWOBear6qapuAOYBx+VDvr5MS0tLoUUoCkwPCUwXCUwXuaXkvf5E5EbgbGAjMDVFkjogeAhTs//MMAzDKAL6fI9KRJ4WkaUprhMBVPUqVR0DNADfLay0pUNTU1OhRSgKTA8JTBcJTBe5paSdKYKIyFjgCVXdL+n5GUC9ql7gh+8CGlX1oRRllIeyDMMwcoh5/WVARPZS1bf9+38BjlDVU5PSDAVeAQ70H70KHKSqn+ZVWMMwDCMlpT5HdZOIfB7nnv4+8M8AInIw8M+qep6qfuq7sb/k57nOjJRhGEbxUNI9KsMwDKPv0+edKfKBiBwnIm+JyDsicmWh5cknIjJGRBaKyBsiskxELvGfDxWReSLytv9bNmvPRMQTkcUiMtcPjxeRF/32MVtEKgotYz4QkRoReVhE3hSR5SLy5XJtFyLyPf/fx1IReUhE+pVLuxCRmSKyVkSWBp6lbAfi+KWvk7+JyIHpS05ghioLIuLhTm8/HtgHOENE9imsVHmlHbhMVfcBDgUu8t//SmC+qu4FzPfD5cIlwPJA+KfAf6nqBGAD8O2CSJV/bgX+qKp7A/vjdFJ27UJE6oCLgYN9Zy0POJ3yaRf3svPa03Tt4HhgL/86H7ijKxWYocrOFOAdVV2pqm3ALNy2TGWBqn6kqq/695txH6M6nA7iW03dB5xUGAnzi4iMBv4euNsPC3Ak8LCfpCx0ISLVwN8BvwFQ1TZVbaFM2wVuvr9KRMJAf+AjyqRdqOozuCPugqRrBycC96vjBaBGREZlq8MMVXZsQbCPiIwDDgBeBEao6kd+1BpgRIHEyje/AC7HOegADANaVLXdD5dL+xgPfALc4w+D3i0iAyjDdqGqq4BbgA9wBmojzpO4HNtFnHTtYJe+p2aojC4hIgOBR4BLk7amwt+pt+S9ckTkBGCtqr5SaFmKgDBuSccdqnoAsJWkYb4yahdDcD2F8UAtbrs224bNJxftwAxVdlYBYwLh0f6zskFEIjgj1aCqc/zHH8e77P7v2kLJl0cOB74hIk24IeAjcfM0Nf6QD5RP+2gGmlX1RT/8MM5wlWO7OBp4T1U/UdUdwBxcWynHdhEnXTvYpe+pGarsvATs5XvwVOAmSR8vsEx5w5+D+Q2wXFV/Hoh6HPiWf/8t4P/yLVu+UdUfqupoVR2HawcLVHUGsBCILyQvF12sAT701ykCHAW8QRm2C9yQ36Ei0t//9xLXRdm1iwDp2sHjwNm+99+hwMbAEGFabB1VFxCRr+HmJjxgpqreWGCR8oaIfAX4M/A6iXmZH+HmqX4HjMUtpp5eTgulRaQe+IGqniAie+B6WEOBxcCZqtpaSPnygYhMxjmVVAArgXNx//ktu3YhIv8OnIbzkl0MnIebeyn5diEiDwH1wHDgY9yxSY+Roh34hvw23NDoNuBcVX05ax1mqAzDMIxixob+DMMwjKLGDJVhGIZR1JihMgzDMIoaM1SGYRhGUWOGyjAMwyhqzFAZhmEYRY0ZKsMoQ0SkXkTUv64ttDyGkYlSP+HXKEFEpGPxn6pKivhxwDl+sFFVG/MhVyERkRrgUj+4RFUfK6Q8hpFLzFAZpcg43Or4OI2FESOv1JB45/twOwMYRklghsowyhC/l7lTb9QwihGbozIMwzCKGjNUhmEYRlFjhsooGeKebLjjFeJcE/Bu67gylDFWRG4Ukb+KyCci0iYia0Rknohc6B/1kkmGeB2NfniIiPxQRF4SkXV+3L0p6vyuiPyviLwlIlv8eteKSKOIXOEf/Z6qvnH++7wXePytVO/sO5l00lVXvP784yu+JyILfV20+rI9679bStkC+a8N1FXvPztURBpE5P1AeXNFJOuBgyJS4+tkkZ+vTUQ2ichKEXleRH4lIsf7O3UbpYCq2mVXn7pwp4Uq/uGhgef1wbhMV5pyfwhsz5J3BTCxC7I14g4S/CBFGfcmyRzrgsxrga+kqG9cV98ZGJdGV9dmeJ9DcQfbZSp3HTAtQxnXBtLWA1cB0Qzl/XuGsg7BHSXRlfetKXRbtSs3lzlTGKXEUuBkYD/gev/ZbNyZQBkRkf8i4d7d4ud5CdgMjAJOAqYCewGLROQAdYcHpmMY7rC40cATwB9wH/Q6Oh/L3Q/n1LAM1xNcDqz3n4/x6z0I2A2YKyKTVbUpkH+t/86fA+7yny0EfplCpm6dtisiBwALgCr/0WLgQZzxHQlMx51kO8yXbZpmXwpwPnAGzvjdi3vvCtz5RKfhdHG1iCxS1QVJ8vQHHsW9K8AzwFxfnhjuPKT9cAcXfh6jdCi0pbTLru5eZO8Z1dOF3kIg/YmB9POAYWnSXRBINyubbLhD9L6Zpe7dgS9mSXMGiR7IPWnSjAvUe28X3jmjjnDTAksDaX4BhFKk+7dAmg+AfinSXJukl6eAASnSfS+Q5okU8acG4m/P8n6HApWFbqt25eayOSrDgOv83w+Bk1R1fapEqnoX8IAfPFVExmQp95eq+r+ZEqjq+6r6epY0DwG/9YOniUgkS7254ARgX//+BeB7qhpLTqSq1+N6i+B6gGdmKXc9cJqqbk0RdyvO2AEcKSLJIz4TAvf/k6kSVX1BS/A03XLFDJVR1ojI/sAkP3hHmg9okLjB8HBDTJn4757IlsRf/N8qEvL2Jv8QuL9Z/W5KGm5Kky8V96vqhlQRviFc5AcrgT2TkmwL3O+LUTbYHJVR7nw1cF8pIidlSV8XuP9ChnSrVPW9DPGdEJEv4XojhwJ7AIOAdD2n0cArXS17F5ni/8aHQzPxF2ALMBD4Upa0L2SJXxW4H5IU97QvjwB3isiewIOq+naWMo0+jhkqo9wZF7i/ppt5kz+kQVZliOvAd3e/GzirG/UO7kbaXWWU/7tGVTdnSqiqMRF5F9gfGCoiFaralib5uiz1Bofr+iXV84aI3ITzzhyAm/u6VkQ+xBnLZ4A/qOr7Weow+hhmqIxyJ+MaoCxkWlP1WRfL+BUJI9WK8xB8CWfotuKcKACOBP7Fv/e6J+YuMcj/zTYUGmdLUt6U83w477xdRlV/JCIvAVeQ6L2NwXkMngbcJiJ/BC5V1RU9qcsoHsxQGeVO8AN7pKouzFfF/gLcb/vBZuAIVV2ZJm1dque9yGbcRrcDuph+YFLeXkNVHwUeFZFa3NDtYTgvxkm4YcHjgcNE5Muqurw3ZTHygzlTGOVOcIhudJ7rPpLExrA3pTNSPrvnQZ4gH/m/I0VkYKaE/g4QcceH9RmG/XKKqq5W1dmqeomq7g9MxM1jgespX58+t9GXMENllCLB4aVs2+gsCtxP6wVZMjEicP9ulrTHZonvzjt3hb8Gyjo6S9rDSPSo/popYW/iO1WcSmK49CuFksXILWaojFIkOJyXbejqZdzuCODWKOXT7Tnobp3sit2BiJxIdpf07rxzV3gkcP+DLPvmXZEmX95R1Y1A3P3dpjZKBDNURikSdAs/MFNCf33QD/1gBHhCRA7JlEdE9hGRO3omIuCcJuL8QER28iL03dZnZitIVT8FNvrByTnYkPUPJAz44cDNIrLT90JEfgR83Q9+CDT0sN60iMjFInJKpgXPIvJN3FZKAK/1lixGfrH/cRglh6puEJHFwAHAVBG5E5hPYJJfVf8YuP+9iFwHXA2MBV4Ukadw8x3NuLU7w3CLTOuBfXDDSxf2UNTnceuhDsK5yb/py/oWbmHvkThPNnAGYEaW8hbg9v3bE5gtInNw+xbGWaSqXfJG9F3Oz8S5fVcBl+F02YDTyQjcXn/x4bUdwNmqur0r5e8iB+J2r9jg/31ewc0xxnB7D04jMUSqwE96URYjj5ihMkqVq4Df41y5L/CvIJ16HKp6jb8e52e4dUrHknleqLmnAqqqisjpOAMzBrfZ6tVJybYDF+E+xtkM1XW4zV2rgG/6V5DxQFM35FsiIkfhhvNG4QxFqh7qp8A/avYNaXtKfHeMISTc0VOxFbhQVZ9OE2/0MWzozyhJVPVJ3JDVg7ihwKw9CVW9G+dddxlu49TVuLVNrcAa3ILSm3FbJ+2RIznfwfX8foLbOX07br7pLeA24CBVzTr055e1BNc7u9vPvy1zji6V+Txux/jv4xxPPsH1ntbjeoRXAXuq6p96WlcXuBDnev6fuB3iV+H+Nu24hcTP4hZtT1TVB9IVYvQ9JPMWXoZhGIZRWKxHZRiGYRQ1ZqgMwzCMosYMlWEYhlHUmKEyDMMwihozVIZhGEZRY4bKMAzDKGrMUBmGYRhFjRkqwzAMo6gxQ2UYhmEUNWaoDMMwjKLGDJVhGIZR1JihMgzDMIqa/wcZbiCkvXD1AgAAAABJRU5ErkJggg==\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import json\n",
        "lowSNR = {\n",
        "    'GD':np.array(GD_dist)[:101].tolist(),\n",
        "    'Polyak':np.array(polyak_dist).tolist(),\n",
        "    'BFGS':np.array(bfgs_dist).tolist(),\n",
        "    'Newton':np.array(newton_dist).tolist(),\n",
        "    'BFGS_min_val':np.nanargmin(np.array(val_err_bfgs)).tolist(),\n",
        "    'Newton_min_val':np.nanargmin(np.array(val_err_newton)).tolist()\n",
        "}\n",
        "lowSNR_data = json.dumps(lowSNR)\n",
        "with open('lowSNR_data.json', 'w') as f:\n",
        "  f.write(lowSNR_data)\n",
        "# files.download('lowSNR_data.json')"
      ],
      "metadata": {
        "id": "--593pkD-gmo"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Data Generation (High SNR)"
      ],
      "metadata": {
        "id": "HQCPPYz7pksz"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "num_epoch = 100\n",
        "step_size = 1e-1"
      ],
      "metadata": {
        "id": "Zr5ZRv1vqd0H"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# tril = np.tril(np.random.randn(d, d))\n",
        "# tril = np.identity(d)\n",
        "tril = np.diag(0.5 ** np.arange(d))\n",
        "cov = np.matmul(tril, tril.T)\n",
        "print(cov)\n",
        "x = np.matmul(np.random.randn(n, d), tril)\n",
        "theta_opt = np.random.randn(d) / np.sqrt(d)\n",
        "theta_init = theta_opt + np.random.randn(d) / np.sqrt(d)\n",
        "y = (np.matmul(x, theta_opt)) ** p + 0.1 * np.random.randn(n)\n",
        "\n",
        "x_val = np.matmul(np.random.randn(int(n/10), d), tril)\n",
        "y_val = (np.matmul(x_val, theta_opt)) ** p + 0.1 * np.random.randn(int(n/10))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "3b62dc5b-3447-44cc-af2b-34f11bac1f3f",
        "id": "tSUycCIcpksz"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[[1.       0.       0.       0.      ]\n",
            " [0.       0.25     0.       0.      ]\n",
            " [0.       0.       0.0625   0.      ]\n",
            " [0.       0.       0.       0.015625]]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Gradient Descent"
      ],
      "metadata": {
        "id": "ptE5kqYGpks0"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_GD = np.copy(theta_init)\n",
        "GD_dist = [param_err(np.copy(theta_GD), theta_opt)]\n",
        "\n",
        "for _ in range(100 * num_epoch):\n",
        "  theta_GD -= step_size * gradient(x, y, np.copy(theta_GD), p)\n",
        "  GD_dist.append(param_err(np.copy(theta_GD), theta_opt))\n",
        "\n",
        "obj_min = objective(x, y, np.copy(theta_GD), p)\n",
        "print(obj_min)\n",
        "print(GD_dist)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "d16576d7-bf31-4bdb-d2bc-0532c75604c8",
        "id": "w_drnLkapks0"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0.010179588754272462\n",
            "[0.4747787871845469, 0.4445871669302733, 0.4179792871286468, 0.3942893881812089, 0.3730223242893819, 0.35379897446032654, 0.33632212952939694, 0.320354209255004, 0.3057021638623067, 0.29220692379559643, 0.27973583178360073, 0.2681770902608717, 0.25743560672781424, 0.2474298311692824, 0.2380893118000091, 0.22935278030099604, 0.2211666336227844, 0.2134837170818641, 0.20626233934132657, 0.19946546795904477, 0.1930600670510369, 0.18701654790247624, 0.18130831015227825, 0.17591135621054163, 0.17080396534070946, 0.1659664166962564, 0.16138075278826267, 0.15703057654853045, 0.15290087646766928, 0.14897787531964918, 0.14524889880054895, 0.1417022610592827, 0.13832716461921948, 0.13511361260998467, 0.1320523315698246, 0.12913470335722416, 0.12635270493874778, 0.12369885500827106, 0.12116616654867081, 0.11874810457678564, 0.11643854842092628, 0.11423175797127197, 0.11212234342026561, 0.11010523807510338, 0.10817567387963743, 0.10632915933011643, 0.10456145950951361, 0.10286857799983577, 0.10124674046166963, 0.09969237969604108, 0.09820212202606232, 0.09677277485531675, 0.09540131527691874, 0.09408487962202917, 0.09282075384961433, 0.09160636469064398, 0.09043927146995798, 0.08931715853785727, 0.08823782825125553, 0.08719919445108955, 0.08619927638873993, 0.08523619305955873, 0.08430815790632266, 0.08341347385959627, 0.08255052868567006, 0.081717790615987, 0.08091380423483628, 0.0801371866046191, 0.07938662361022095, 0.07866086650598456, 0.07795872865050585, 0.07727908241599601, 0.07662085626028833, 0.07598303195074378, 0.07536464193034373, 0.07476476681716519, 0.07418253302923235, 0.07361711052744212, 0.07306771066987744, 0.07253358417136863, 0.07201401916264341, 0.07150833934383177, 0.07101590222746686, 0.07053609746646056, 0.07006834526282915, 0.06961209485321113, 0.06916682306745969, 0.06873203295680885, 0.06830725248830576, 0.06789203330238328, 0.06748594953060658, 0.0670885966707797, 0.06669959051673438, 0.0663185661402535, 0.06594517692270038, 0.0655790936340364, 0.06522000355701636, 0.06486760965444867, 0.06452162977750302, 0.06418179591313614, 0.06384785346879165, 0.06351956059261152, 0.06319668752747325, 0.06287901599724122, 0.06256633862369212, 0.06225845837264142, 0.06195518802786406, 0.06165634969146475, 0.06136177430941375, 0.061071301221021244, 0.060784777731179955, 0.06050205870425746, 0.06022300617857372, 0.059947489000444096, 0.05967538247682044, 0.059406568045604125, 0.059140932962750206, 0.05887837000532332, 0.05861877718970534, 0.058362057504194105, 0.05810811865526759, 0.057856872826824196, 0.057608236451742206, 0.0573621299951353, 0.05711847774870932, 0.05687720763565582, 0.05663825102554638, 0.05640154255871725, 0.05616701997965971, 0.05593462397895578, 0.05570429804332181, 0.05547598831334488, 0.05524964344851714, 0.0550252144991937, 0.05480265478511876, 0.05458191978018236, 0.05436296700308683, 0.05414575591362051, 0.05393024781424808, 0.05371640575674611, 0.05350419445362198, 0.05329358019407162, 0.05308453076424132, 0.05287701537157175, 0.05267100457301542, 0.052466470206925866, 0.05226338532843167, 0.05206172414811413, 0.051861461973819634, 0.05166257515544502, 0.05146504103254253, 0.051268837884600384, 0.05107394488385964, 0.05088034205053884, 0.050688010210341375, 0.050496930954128584, 0.05030708659964761, 0.050118460155208745, 0.04993103528521103, 0.04974479627742287, 0.04955972801192648, 0.0493758159316417, 0.049193046014347715, 0.04901140474612649, 0.04883087909615419, 0.04865145649277332, 0.048473124800778464, 0.04829587229985463, 0.048119687664108526, 0.04794455994263812, 0.047770478541086306, 0.04759743320412945, 0.047425413998852264, 0.047254411298964974, 0.04708441576981865, 0.046915418354179284, 0.04674741025872102, 0.0465803829412028, 0.04641432809829283, 0.04624923765400906, 0.04608510374874334, 0.04592191872884022, 0.04575967513670243, 0.04559836570139553, 0.04543798332972734, 0.0452785210977779, 0.04511997224285638, 0.044962330155864816, 0.04480558837404616, 0.04464974057409927, 0.0444947805656406, 0.04434070228499627, 0.04418749978930697, 0.04403516725093057, 0.04388369895212642, 0.04373308928000922, 0.04358333272175583, 0.04343442386005503, 0.04328635736878627, 0.0431391280089168, 0.042992730624605534, 0.042847160139503675, 0.042702411553242434, 0.04255847993809711, 0.04241536043582034, 0.042273048254635084, 0.04213153866637933, 0.04199082700379529, 0.04185090865795514, 0.04171177907581727, 0.041573433757905835, 0.041435868256107795, 0.04129907817158108, 0.04116305915276911, 0.04102780689351529, 0.04089331713127326, 0.040759585645407784, 0.040626608255581544, 0.04049438082022419, 0.040362899235078395, 0.040232159431820194, 0.04010215737674926, 0.03997288906954548, 0.03984435054208899, 0.03971653785734018, 0.03958944710827673, 0.03946307441688433, 0.0393374159331996, 0.03921246783440116, 0.03908822632394751, 0.03896468763075871, 0.03884184800843966, 0.038719703734543795, 0.03859825110987372, 0.03847748645781807, 0.038357406123722564, 0.03823800647429274, 0.03811928389702786, 0.038001234799683814, 0.037883855609763824, 0.03776714277403487, 0.0376510927580699, 0.03753570204581278, 0.037420967139166456, 0.03730688455760216, 0.037193450837788786, 0.037080662533241715, 0.036968516213989486, 0.03685700846625885, 0.03674613589217477, 0.036635895109477214, 0.03652628275125218, 0.03641729546567725, 0.03630892991578009, 0.03620118277920985, 0.036094050748020294, 0.035987530528464984, 0.03588161884080272, 0.035776312419113325, 0.03567160801112359, 0.03556750237804203, 0.03546399229440225, 0.035361074547915754, 0.03525874593933118, 0.03515700328230213, 0.03505584340326142, 0.03495526314130257, 0.034855259348067255, 0.0347558288876393, 0.03465696863644383, 0.03455867548315265, 0.034460946328593665, 0.03436377808566638, 0.03426716767926133, 0.03417111204618397, 0.03407560813508295, 0.03398065290638196, 0.033886243332215835, 0.03379237639636981, 0.03369904909422215, 0.033606258432689905, 0.03351400143017796, 0.03342227511653051, 0.03333107653298544, 0.03324040273213131, 0.03315025077786631, 0.03306061774536032, 0.032971500721017906, 0.03288289680244448, 0.03279480309841377, 0.03270721672883692, 0.0326201348247339, 0.03253355452820562, 0.03244747299240882, 0.03236188738153093, 0.03227679487076725, 0.03219219264629922, 0.03210807790527356, 0.03202444785578254, 0.03194129971684579, 0.03185863071839212, 0.0317764381012437, 0.031694719117099375, 0.031613471028519975, 0.03153269110891429, 0.03145237664252482, 0.03137252492441547, 0.03129313326045901, 0.03121419896732469, 0.031135719372467573, 0.031057691814117598, 0.030980113641268986, 0.03090298221366996, 0.03082629490181399, 0.030750049086929562, 0.03067424216097166, 0.03059887152661291, 0.030523934597234976, 0.0304494287969203, 0.03037535156044433, 0.030301700333267276, 0.0302284725715264, 0.030155665742028333, 0.03008327732224167, 0.030011304800289264, 0.02993974567494133, 0.02986859745560755, 0.029797857662329803, 0.02972752382577531, 0.02965759348722889, 0.029588064198585663, 0.02951893352234415, 0.02945019903159799, 0.029381858310029485, 0.02931390895190136, 0.02924634856204948, 0.029179174755874848, 0.029112385159336406, 0.02904597740894225, 0.028979949151742457, 0.028914298045320277, 0.028849021757784078, 0.028784117967759086, 0.02871958436437825, 0.028655418647274056, 0.02859161852656903, 0.028528181722867196, 0.028465105967244234, 0.02840238900123827, 0.02834002857684021, 0.02827802245648368, 0.028216368413034907, 0.028155064229782957, 0.02809410770042828, 0.02803349662907267, 0.027973228830208398, 0.027913302128706338, 0.027853714359805055, 0.027794463369099184, 0.02773554701252734, 0.027676963156359813, 0.02761870967718668, 0.02756078446190495, 0.02750318540770537, 0.027445910422059835, 0.027388957422707836, 0.027332324337642523, 0.027276009105097164, 0.027220009673530977, 0.02716432400161458, 0.02710895005821535, 0.02705388582238255, 0.026999129283332313, 0.02694467844043174, 0.026890531303183477, 0.026836685891209733, 0.02678314023423585, 0.026729892372074095, 0.02667694035460641, 0.02662428224176779, 0.02657191610352878, 0.026519840019877738, 0.026468052080803137, 0.026416550386275498, 0.026365333046228817, 0.026314398180541942, 0.026263743919019717, 0.02621336840137377, 0.02616326977720279, 0.02611344620597323, 0.0260638958569991, 0.026014616909421494, 0.025965607552188238, 0.025916865984033456, 0.02586839041345584, 0.025820179058697924, 0.025772230147724083, 0.02572454191819923, 0.025677112617466274, 0.02562994050252401, 0.02558302384000417, 0.025536360906149403, 0.025489949986789263, 0.02544378937731749, 0.025397877382668334, 0.025352212317292462, 0.0253067925051331, 0.02526161627960182, 0.025216681983553913, 0.025171987969263405, 0.025127532598398217, 0.025083314241995034, 0.025039331280433563, 0.02499558210341128, 0.02495206510991679, 0.02490877870820445, 0.024865721315767544, 0.024822891359311615, 0.024780287274728, 0.024737907507066597, 0.02469575051050851, 0.024653814748338915, 0.024612098692919346, 0.024570600825659473, 0.024529319636989427, 0.02448825362633166, 0.024447401302071927, 0.024406761181531265, 0.02436633179093695, 0.024326111665393193, 0.024286099348852324, 0.024246293394085117, 0.024206692362651685, 0.024167294824871108, 0.02412809935979202, 0.024089104555162194, 0.024050309007398726, 0.024011711321556946, 0.023973310111300595, 0.023935103998870506, 0.023897091615054114, 0.02385927159915412, 0.02382164259895726, 0.02378420327070353, 0.023746952279054018, 0.023709888297059747, 0.023673010006129536, 0.023636316095998422, 0.023599805264695423, 0.02356347621851165, 0.023527327671967805, 0.02349135834778166, 0.02345556697683591, 0.023419952298145256, 0.023384513058823855, 0.023349248014052446, 0.02331415592704506, 0.023279235569016368, 0.023244485719148077, 0.02320990516455619, 0.023175492700257497, 0.023141247129135595, 0.023107167261908198, 0.02307325191709291, 0.023039499920973677, 0.02300591010756714, 0.02297248131858838, 0.02293921240341773, 0.022906102219065878, 0.022873149630140727, 0.022840353508812295, 0.022807712734779204, 0.022775226195234283, 0.022742892784830125, 0.022710711405645075, 0.02267868096714811, 0.02264680038616513, 0.02261506858684418, 0.022583484500620924, 0.02255204706618407, 0.022520755229440543, 0.02248960794348124, 0.022458604168546323, 0.022427742871990234, 0.022397023028247035, 0.022366443618795813, 0.02233600363212602, 0.022305702063702467, 0.022275537915930725, 0.02224551019812232, 0.022215617926459624, 0.022185860123961454, 0.022156235820447893, 0.022126744052506114, 0.02209738386345482, 0.02206815430330992, 0.02203905442874964, 0.022010083303079724, 0.021981239996198724, 0.0219525235845631, 0.021923933151152795, 0.021895467785436083, 0.021867126583335478, 0.02183890864719241, 0.021810813085733297, 0.021782839014034314, 0.021754985553487382, 0.02172725183176496, 0.02169963698278625, 0.021672140146682218, 0.021644760469761767, 0.021617497104476684, 0.02159034920938784, 0.021563315949130624, 0.02153639649438075, 0.021509590021820096, 0.02148289571410296, 0.021456312759821412, 0.021429840353471587, 0.021403477695419712, 0.021377223991868054, 0.021351078454821384, 0.02132504030205319, 0.02129910875707162, 0.02127328304908639, 0.02124756241297493, 0.02122194608924878, 0.02119643332402055, 0.021171023368970185, 0.021145715481312177, 0.021120508923762136, 0.02109540296450351, 0.021070396877154875, 0.02104548994073681, 0.021020681439639536, 0.020995970663589592, 0.020971356907617207, 0.02094683947202418, 0.02092241766235104, 0.02089809078934474, 0.020873858168926535, 0.02084971912215935, 0.020825672975216016, 0.02080171905934738, 0.02077785671085005, 0.020754085271034884, 0.020730404086195062, 0.020706812507574585, 0.02068330989133691, 0.020659895598533335, 0.020636568995071963, 0.020613329451686393, 0.02059017634390441, 0.020567109052017356, 0.020544126961049288, 0.02052122946072606, 0.0204984159454448, 0.020475685814243378, 0.020453038470769944, 0.02043047332325282, 0.020407989784470237, 0.02038558727172008, 0.02036326520679035, 0.020341023015929036, 0.020318860129814473, 0.02029677598352609, 0.020274770016514485, 0.020252841672572082, 0.020230990399804614, 0.02020921565060145, 0.020187516881606502, 0.02016589355368972, 0.020144345131918134, 0.020122871085527586, 0.02010147088789412, 0.02008014401650549, 0.020058889952933093, 0.020037708182803773, 0.020016598195771732, 0.01999555948549144, 0.019974591549588805, 0.019953693889634534, 0.019932866011116223, 0.01991210742341126, 0.019891417639759254, 0.019870796177235403, 0.019850242556723453, 0.01982975630288858, 0.01980933694415157, 0.01978898401266107, 0.019768697044268212, 0.0197484755784999, 0.01972831915853292, 0.01970822733116736, 0.019688199646801238, 0.019668235659404953, 0.01964833492649493, 0.019628497009108806, 0.019608721471779975, 0.019589007882512218, 0.019569355812754468, 0.01954976483737634, 0.019530234534642754, 0.019510764486189856, 0.019491354277000005, 0.01947200349537748, 0.01945271173292449, 0.019433478584516547, 0.01941430364827888, 0.01939518652556224, 0.01937612682091931, 0.019357124142081125, 0.019338178099933552, 0.019319288308493936, 0.019300454384887675, 0.019281675949325405, 0.01926295262508021, 0.019244284038464215, 0.019225669818806756, 0.019207109598430975, 0.019188603012631637, 0.01917014969965335, 0.01915174930066788, 0.019133401459752068, 0.01911510582386649, 0.019096862042833, 0.019078669769313463, 0.019060528658788323, 0.01904243836953526, 0.01902439856260738, 0.019006408901812922, 0.018988469053693856, 0.01897057868750486, 0.018952737475192834, 0.018934945091376238, 0.01891720121332456, 0.01889950552093817, 0.01888185769672805, 0.018864257425795426, 0.01884670439581209, 0.018829198297000384, 0.01881173882211359, 0.018794325666416513, 0.018776958527665734, 0.018759637106090472, 0.018742361104373016, 0.01872513022763016, 0.018707944183394127, 0.018690802681593188, 0.018673705434533668, 0.018656652156880872, 0.01863964256564086, 0.018622676380141878, 0.0186057533220163, 0.018588873115182657, 0.018572035485827528, 0.018555240162387115, 0.018538486875530547, 0.018521775358141472, 0.01850510534530075, 0.018488476574269063, 0.018471888784469703, 0.018455341717471426, 0.018438835116971437, 0.01842236872877792, 0.018405942300794273, 0.018389555583001403, 0.018373208327441857, 0.018356900288202943, 0.018340631221400446, 0.01832440088516264, 0.018308209039613606, 0.01829205544685791, 0.018275939870964313, 0.018259862077950054, 0.018243821835765065, 0.018227818914276384, 0.018211853085253037, 0.018195924122350358, 0.01818003180109476, 0.0181641758988687, 0.01814835619489578, 0.01813257247022542, 0.018116824507718593, 0.018101112092032533, 0.018085435009606736, 0.0180697930486478, 0.01805418599911566, 0.018038613652708913, 0.01802307580285096, 0.01800757224467516, 0.01799210277501208, 0.0179766671923744, 0.017961265296943835, 0.017945896890557474, 0.017930561776693832, 0.017915259760459497, 0.017899990648576072, 0.017884754249366388, 0.01786955037274192, 0.0178543788301889, 0.017839239434756154, 0.01782413200104171, 0.017809056345180107, 0.01779401228482985, 0.017778999639160496, 0.01776401822884056, 0.017749067876024736, 0.0177341484043418, 0.01771925963888225, 0.01770440140618612, 0.017689573534231128, 0.017674775852420617, 0.017660008191571864, 0.01764527038390361, 0.017630562263025392, 0.017615883663925247, 0.017601234422958172, 0.0175866143778355, 0.017572023367612464, 0.017557461232677773, 0.017542927814741933, 0.01752842295682664, 0.017513946503253282, 0.017499498299632654, 0.017485078192853477, 0.017470686031072023, 0.017456321663701476, 0.01744198494140134, 0.01742767571606665, 0.01741339384081805, 0.017399139169991217, 0.017384911559126328, 0.017370710864958595, 0.01735653694540727, 0.017342389659566707, 0.01732826886769534, 0.017314174431206517, 0.01730010621265865, 0.017286064075745143, 0.017272047885285392, 0.017258057507214604, 0.017244092808574953, 0.017230153657505402, 0.017216239923232936, 0.01720235147606339, 0.01718848818737206, 0.01717464992959419, 0.017160836576217024, 0.017147048001769572, 0.017133284081814845, 0.017119544692939984, 0.017105829712748585, 0.017092139019851443, 0.01707847249385772, 0.017064830015366697, 0.01705121146595974, 0.0170376167281909, 0.017024045685579598, 0.01701049822260167, 0.016996974224681518, 0.01698347357818367, 0.01696999617040494, 0.016956541889566693, 0.016943110624806294, 0.01692970226616952, 0.01691631670460301, 0.01690295383194618, 0.016889613540923495, 0.016876295725137037, 0.016863000279059098, 0.016849727098024438, 0.016836476078222754, 0.01682324711669155, 0.016810040111308742, 0.01679685496078533, 0.016783691564658264, 0.016770549823283368, 0.01675742963782811, 0.016744330910264678, 0.016731253543363078, 0.016718197440684108, 0.016705162506572373, 0.016692148646149995, 0.016679155765309546, 0.016666183770707204, 0.016653232569756485, 0.016640302070621282, 0.016627392182209898, 0.016614502814167806, 0.016601633876871972, 0.016588785281424184, 0.016575956939644823, 0.016563148764066542, 0.01655036066792811, 0.016537592565167975, 0.0165248443704189, 0.01651211599900139, 0.016499407366917598, 0.016486718390845444, 0.01647404898813311, 0.016461399076792855, 0.016448768575495286, 0.016436157403563575, 0.016423565480968048, 0.016410992728319813, 0.016398439066865906, 0.01638590441848346, 0.01637338870567424, 0.016360891851558968, 0.016348413779872402, 0.016335954414957245, 0.016323513681759366, 0.016311091505822217, 0.0162986878132822, 0.016286302530862478, 0.016273935585868628, 0.01626158690618347, 0.016249256420261232, 0.016236944057123823, 0.01622464974635462, 0.016212373418094176, 0.016200115003035205, 0.0161878744324179, 0.016175651638024844, 0.01616344655217616, 0.016151259107725354, 0.016139089238053933, 0.016126936877067333, 0.01611480195919004, 0.016102684419360743, 0.016090584193028352, 0.016078501216147276, 0.0160664354251727, 0.01605438675705675, 0.016042355149243608, 0.016030340539665355, 0.016018342866737628, 0.016006362069355493, 0.015994398086888982, 0.015982450859179258, 0.0159705203265342, 0.015958606429724024, 0.015946709109977825, 0.015934828308979007, 0.015922963968861475, 0.015911116032205817, 0.015899284442035113, 0.01588746914181074, 0.015875670075429373, 0.015863887187218397, 0.015852120421932098, 0.015840369724748303, 0.015828635041264538, 0.015816916317493896, 0.015805213499861973, 0.015793526535202735, 0.015781855370755132, 0.01577019995415943, 0.015758560233453688, 0.01574693615707015, 0.01573532767383201, 0.015723734732949423, 0.01571215728401676, 0.01570059527700874, 0.015689048662277237, 0.01567751739054794, 0.015666001412916544, 0.01565450068084637, 0.015643015146164417, 0.015631544761058356, 0.015620089478073286, 0.015608649250108577, 0.015597224030414948, 0.015585813772590842, 0.01557441843057983, 0.015563037958667064, 0.015551672311476927, 0.015540321443969558, 0.015528985311437656, 0.015517663869503949, 0.015506357074118042, 0.015495064881553756, 0.015483787248405793, 0.015472524131587515, 0.015461275488327321, 0.015450041276166615, 0.015438821452956459, 0.015427615976855222, 0.01541642480632566, 0.015405247900131985, 0.015394085217337632, 0.015382936717302174, 0.015371802359679125, 0.015360682104412904, 0.015349575911736505, 0.01533848374216892, 0.015327405556512389, 0.0153163413158499, 0.015305290981543138, 0.015294254515229413, 0.015283231878819373, 0.015272223034495078, 0.015261227944706707, 0.015250246572170665, 0.015239278879867412, 0.015228324831038717, 0.015217384389185384, 0.01520645751806536, 0.015195544181690628, 0.015184644344325844, 0.015173757970485471, 0.01516288502493198, 0.01515202547267307, 0.015141179278960144, 0.015130346409285515, 0.015119526829380963, 0.01510872050521496, 0.01509792740299062, 0.015087147489144087, 0.015076380730342013, 0.015065627093479837, 0.015054886545679283, 0.015044159054286847, 0.015033444586871416, 0.015022743111222507, 0.015012054595348157, 0.015001379007473264, 0.01499071631603719, 0.014980066489692172, 0.014969429497301257, 0.014958805307936652, 0.01494819389087772, 0.01493759521560895, 0.0149270092518184, 0.014916435969395958, 0.014905875338431119, 0.014895327329211738, 0.014884791912221867, 0.014874269058139818, 0.014863758737837181, 0.014853260922376692, 0.014842775583009962, 0.014832302691176913, 0.014821842218503094, 0.014811394136798725, 0.014800958418056703, 0.014790535034450769, 0.014780123958334671, 0.014769725162239719, 0.014759338618873704, 0.014748964301119199, 0.014738602182031602, 0.014728252234838545, 0.014717914432937348, 0.014707588749894005, 0.01469727515944175, 0.014686973635479444, 0.014676684152069902, 0.01466640668343876, 0.014656141203972895, 0.014645887688219011, 0.014635646110882361, 0.014625416446824692, 0.014615198671063603, 0.014604992758771047, 0.014594798685271335, 0.014584616426040763, 0.01457444595670544, 0.014564287253040287, 0.01455414029096778, 0.014544005046556247, 0.014533881496019379, 0.014523769615713871, 0.014513669382139124, 0.014503580771935188, 0.014493503761882248, 0.01448343832889884, 0.014473384450040875, 0.014463342102500106, 0.014453311263603226, 0.014443291910810941, 0.014433284021716054, 0.014423287574042772, 0.014413302545645419, 0.014403328914507392, 0.014393366658740088, 0.014383415756581244, 0.014373476186394481, 0.01436354792666794, 0.014353630956012792, 0.014343725253162671, 0.014333830796972466, 0.014323947566417167, 0.014314075540590852, 0.014304214698705736, 0.014294365020090578, 0.014284526484190423, 0.014274699070565208, 0.014264882758888415, 0.014255077528946834, 0.014245283360638959, 0.014235500233974414, 0.014225728129072131, 0.014215967026160573, 0.01420621690557604, 0.0141964777477618, 0.014186749533267224, 0.014177032242746813, 0.014167325856959272, 0.014157630356766792, 0.014147945723133748, 0.014138271937125935, 0.01412860897990999, 0.014118956832752404, 0.014109315477018073, 0.01409968489417002, 0.014090065065768605, 0.014080455973470152, 0.014070857599026406, 0.01406126992428384, 0.014051692931182686, 0.014042126601756041, 0.014032570918128906, 0.014023025862517744, 0.01401349141722957, 0.01400396756466105, 0.013994454287297817, 0.013984951567713406, 0.013975459388568987, 0.013965977732612123, 0.013956506582676302, 0.01394704592168009, 0.013937595732626542, 0.013928155998602117, 0.013918726702776059, 0.013909307828400051, 0.013899899358807163, 0.01389050127741124, 0.013881113567705902, 0.013871736213264228, 0.013862369197737907, 0.013853012504856696, 0.013843666118427439, 0.01383433002233374, 0.013825004200535215, 0.01381568863706649, 0.013806383316036898, 0.013797088221629998, 0.013787803338102339, 0.01377852864978323, 0.013769264141074215, 0.013760009796448128, 0.013750765600448623, 0.013741531537689925, 0.01373230759285541, 0.013723093750697435, 0.013713889996037048, 0.013704696313763108, 0.013695512688831587, 0.013686339106265155, 0.013677175551152509, 0.013668022008647715, 0.01365887846397022, 0.013649744902403333, 0.01364062130929467, 0.013631507670054674, 0.013622403970156847, 0.013613310195136891, 0.013604226330591922, 0.013595152362180493, 0.013586088275621732, 0.013577034056694592, 0.013567989691238092, 0.013558955165149846, 0.013549930464386172, 0.013540915574961473, 0.013531910482947919, 0.013522915174474638, 0.013513929635727354, 0.013504953852947657, 0.01349598781243328, 0.0134870315005367, 0.013478084903665465, 0.013469148008280986, 0.013460220800898676, 0.013451303268087193, 0.013442395396468118, 0.01343349717271526, 0.013424608583554742, 0.013415729615764071, 0.013406860256171665, 0.01339800049165696, 0.013389150309149476, 0.013380309695628576, 0.013371478638122965, 0.013362657123710405, 0.013353845139517245, 0.013345042672717937, 0.013336249710535018, 0.013327466240237963, 0.013318692249143385, 0.013309927724614602, 0.013301172654060908, 0.013292427024937591, 0.01328369082474528, 0.013274964041029675, 0.013266246661381141, 0.013257538673434488, 0.013248840064868301, 0.013240150823404738, 0.013231470936809105, 0.01322280039288988, 0.013214139179497835, 0.013205487284525643, 0.013196844695908332, 0.01318821140162203, 0.013179587389683941, 0.013170972648152191, 0.013162367165125251, 0.013153770928741933, 0.013145183927180549, 0.013136606148659039, 0.0131280375814345, 0.01311947821380265, 0.013110928034097842, 0.01310238703069275, 0.013093855191997926, 0.013085332506461047, 0.013076818962567639, 0.013068314548839832, 0.013059819253836645, 0.013051333066153224, 0.013042855974420913, 0.013034387967306906, 0.013025929033513906, 0.013017479161779566, 0.013009038340876801, 0.013000606559613003, 0.012992183806829967, 0.01298377007140351, 0.0129753653422434, 0.012966969608293008, 0.0129585828585288, 0.012950205081960396, 0.012941836267630333, 0.01293347640461325, 0.012925125482016256, 0.012916783488978413, 0.012908450414670631, 0.01290012624829518, 0.012891810979085557, 0.01288350459630624, 0.0128752070892526, 0.01286691844725056, 0.01285863865965616, 0.012850367715855453, 0.012842105605264198, 0.012833852317328068, 0.012825607841521897, 0.012817372167349643, 0.012809145284343857, 0.01280092718206631, 0.012792717850106671, 0.012784517278083253, 0.012776325455642144, 0.012768142372457368, 0.01275996801823042, 0.012751802382689978, 0.01274364545559233, 0.012735497226720236, 0.01272735768588354, 0.012719226822918513, 0.012711104627687788, 0.012702991090079926, 0.012694886200009813, 0.012686789947417777, 0.012678702322269756, 0.012670623314557325, 0.01266255291429678, 0.012654491111529755, 0.012646437896322407, 0.012638393258765758, 0.01263035718897512, 0.01262232967709, 0.012614310713274146, 0.012606300287715122, 0.012598298390624055, 0.012590305012235656, 0.012582320142808214, 0.012574343772622948, 0.012566375891984248, 0.012558416491219433, 0.012550465560678363, 0.012542523090733431, 0.012534589071779342, 0.012526663494233184, 0.012518746348533958, 0.012510837625142615, 0.012502937314541648, 0.012495045407235315, 0.01248716189374926, 0.012479286764630077, 0.012471420010445993, 0.012463561621785812, 0.012455711589259176, 0.012447869903496566, 0.012440036555148746, 0.012432211534887147, 0.012424394833403114, 0.012416586441408356, 0.012408786349634281, 0.012400994548832117, 0.012393211029772914, 0.012385435783247169, 0.012377668800064844, 0.012369910071055023, 0.01236215958706614, 0.012354417338965404, 0.012346683317638855, 0.012338957513991595, 0.012331239918947015, 0.012323530523447056, 0.012315829318452279, 0.01230813629494101, 0.012300451443910131, 0.012292774756374188, 0.012285106223365724, 0.01227744583593513, 0.012269793585150464, 0.012262149462096885, 0.012254513457877354, 0.012246885563612107, 0.012239265770438231, 0.012231654069510189, 0.012224050451999256, 0.012216454909093588, 0.012208867431998057, 0.012201288011934172, 0.012193716640139643, 0.012186153307869195, 0.01217859800639327, 0.012171050726998598, 0.012163511460988477, 0.012155980199681555, 0.012148456934412796, 0.012140941656532674, 0.0121334343574075, 0.012125935028419079, 0.012118443660965001, 0.012110960246457659, 0.012103484776325425, 0.012096017242011217, 0.012088557634973487, 0.012081105946685607, 0.012073662168635833, 0.012066226292327327, 0.012058798309277653, 0.012051378211019493, 0.012043965989099702, 0.012036561635079818, 0.01202916514053596, 0.012021776497058038, 0.012014395696250534, 0.012007022729731752, 0.011999657589134549, 0.011992300266105123, 0.01198495075230406, 0.011977609039405522, 0.01197027511909712, 0.011962948983080753, 0.011955630623071343, 0.01194832003079722, 0.011941017198000625, 0.011933722116436772, 0.011926434777873958, 0.011919155174094108, 0.011911883296891806, 0.011904619138075074, 0.011897362689464399, 0.011890113942893523, 0.011882872890208881, 0.011875639523269518, 0.011868413833947235, 0.011861195814126469, 0.011853985455703995, 0.011846782750589268, 0.011839587690704107, 0.0118324002679824, 0.01182522047437045, 0.011818048301826874, 0.011810883742322288, 0.01180372678783927, 0.011796577430372431, 0.011789435661928381, 0.011782301474525374, 0.011775174860193922, 0.011768055810975828, 0.011760944318924748, 0.011753840376105888, 0.011746743974595956, 0.011739655106483463, 0.011732573763868041, 0.011725499938860769, 0.011718433623584127, 0.011711374810171855, 0.01170432349076873, 0.011697279657530906, 0.011690243302625362, 0.011683214418230291, 0.011676192996535065, 0.011669179029739641, 0.011662172510055012, 0.011655173429702851, 0.01164818178091591, 0.011641197555937285, 0.011634220747021012, 0.011627251346431727, 0.011620289346444468, 0.011613334739344734, 0.01160638751742871, 0.011599447673002927, 0.011592515198384444, 0.011585590085900108, 0.011578672327887604, 0.011571761916694715, 0.011564858844679256, 0.011557963104209009, 0.011551074687662333, 0.011544193587427231, 0.0115373197959017, 0.01153045330549388, 0.011523594108621825, 0.011516742197713387, 0.011509897565205965, 0.011503060203547103, 0.011496230105193978, 0.011489407262613367, 0.01148259166828177, 0.01147578331468539, 0.011468982194319615, 0.011462188299689835, 0.011455401623310534, 0.011448622157705876, 0.011441849895409424, 0.01143508482896388, 0.011428326950921677, 0.011421576253844046, 0.011414832730301663, 0.011408096372874717, 0.011401367174152108, 0.011394645126732177, 0.011387930223222016, 0.011381222456238346, 0.01137452181840651, 0.011367828302360708, 0.011361141900744573, 0.011354462606210229, 0.011347790411418961, 0.011341125309040877, 0.011334467291754698, 0.011327816352247881, 0.011321172483217028, 0.011314535677367215, 0.011307905927412345, 0.01130128322607467, 0.011294667566085404, 0.011288058940184057, 0.011281457341118748, 0.01127486276164646, 0.011268275194532284, 0.011261694632549862, 0.01125512106848131, 0.011248554495117186, 0.011241994905256444, 0.01123544229170639, 0.011228896647282442, 0.011222357964808473, 0.011215826237116408, 0.011209301457046772, 0.011202783617448045, 0.011196272711177024, 0.011189768731098379, 0.011183271670085234, 0.01117678152101848, 0.011170298276787428, 0.011163821930289067, 0.011157352474428488, 0.011150889902118866, 0.011144434206281365, 0.011137985379844947, 0.01113154341574673, 0.011125108306931322, 0.011118680046351415, 0.01111225862696756, 0.011105844041748098, 0.011099436283668947, 0.011093035345714184, 0.011086641220875179, 0.01108025390215138, 0.011073873382549672, 0.011067499655084773, 0.011061132712778943, 0.011054772548662013, 0.011048419155771738, 0.011042072527152912, 0.011035732655858218, 0.011029399534947743, 0.011023073157489172, 0.011016753516557756, 0.011010440605236078, 0.011004134416613994, 0.010997834943789047, 0.010991542179866245, 0.010985256117957766, 0.010978976751183209, 0.010972704072669514, 0.010966438075550951, 0.01096017875296907, 0.010953926098072738, 0.010947680104018018, 0.010941440763968205, 0.010935208071093805, 0.01092898201857288, 0.010922762599590222, 0.010916549807337911, 0.010910343635015153, 0.010904144075828393, 0.01089795112299111, 0.010891764769724002, 0.010885585009254515, 0.010879411834817505, 0.010873245239654737, 0.010867085217014858, 0.010860931760153866, 0.01085478486233435, 0.010848644516826197, 0.01084251071690605, 0.01083638345585737, 0.010830262726970786, 0.010824148523543888, 0.01081804083888096, 0.010811939666292963, 0.0108058449990982, 0.010799756830621572, 0.010793675154194651, 0.01078759996315619, 0.010781531250851333, 0.010775469010632218, 0.010769413235857695, 0.010763363919893356, 0.010757321056111496, 0.010751284637891295, 0.01074525465861839, 0.01073923111168528, 0.010733213990491052, 0.010727203288441426, 0.010721198998948894, 0.010715201115432497, 0.010709209631318063, 0.010703224540037696, 0.010697245835030234, 0.010691273509741195, 0.010685307557622562, 0.010679347972132774, 0.010673394746737092, 0.010667447874907, 0.01066150735012077, 0.010655573165862844, 0.01064964531562445, 0.010643723792903141, 0.010637808591202974, 0.010631899704034341, 0.010625997124914329, 0.010620100847366051, 0.010614210864919314, 0.010608327171110375, 0.010602449759481698, 0.010596578623582147, 0.010590713756966953, 0.010584855153197997, 0.010579002805843042, 0.010573156708476208, 0.01056731685467838, 0.010561483238036332, 0.010555655852143315, 0.010549834690598675, 0.01054401974700823, 0.010538211014984025, 0.010532408488144384, 0.01052661216011381, 0.010520822024522824, 0.010515038075008549, 0.010509260305214069, 0.010503488708788849, 0.010497723279388284, 0.010491964010674114, 0.010486210896314407, 0.010480463929982921, 0.01047472310535991, 0.01046898841613174, 0.010463259855990802, 0.01045753741863576, 0.010451821097771338, 0.010446110887108026, 0.010440406780362791, 0.010434708771258586, 0.010429016853524334, 0.010423331020895158, 0.010417651267112134, 0.010411977585922518, 0.01040630997107923, 0.010400648416341609, 0.010394992915474842, 0.010389343462250268, 0.010383700050444875, 0.010378062673841964, 0.010372431326230698, 0.010366806001406088, 0.01036118669316939, 0.010355573395327729, 0.010349966101693775, 0.01034436480608669, 0.010338769502331202, 0.010333180184258259, 0.010327596845704336, 0.010322019480512114, 0.010316448082530034, 0.010310882645612262, 0.010305323163619337, 0.01029976963041707, 0.010294222039877652, 0.010288680385878754, 0.010283144662304148, 0.010277614863043266, 0.010272090981991455, 0.010266573013049927, 0.010261060950125517, 0.01025555478713093, 0.010250054517984938, 0.010244560136611675, 0.010239071636941358, 0.010233589012910004, 0.010228112258459187, 0.010222641367536542, 0.010217176334095024, 0.010211717152093805, 0.010206263815497402, 0.010200816318276292, 0.010195374654406723, 0.010189938817870439, 0.010184508802655149, 0.010179084602754063, 0.010173666212166135, 0.010168253624896213, 0.010162846834954409, 0.010157445836356974, 0.010152050623125622, 0.01014666118928751, 0.010141277528875907, 0.01013589963592932, 0.0101305275044923, 0.010125161128614666, 0.010119800502352028, 0.010114445619765655, 0.01010909647492244, 0.010103753061894875, 0.010098415374761078, 0.010093083407604491, 0.010087757154514654, 0.010082436609586194, 0.010077121766919783, 0.010071812620621219, 0.010066509164802295, 0.010061211393579904, 0.010055919301076945, 0.010050632881421639, 0.01004535212874772, 0.010040077037194691, 0.010034807600907353, 0.010029543814036, 0.010024285670736658, 0.01001903316517088, 0.010013786291505459, 0.010008545043912902, 0.0100033094165712, 0.009998079403663842, 0.009992854999379533, 0.009987636197912887, 0.009982422993463752, 0.009977215380237669, 0.00997201335244538, 0.009966816904303066, 0.009961626030032568, 0.009956440723861136, 0.009951260980021259, 0.009946086792751257, 0.009940918156294398, 0.009935755064899824, 0.009930597512821623, 0.009925445494319946, 0.009920299003659648, 0.00991515803511165, 0.0099100225829518, 0.009904892641461322, 0.009899768204927233, 0.009894649267641699, 0.00988953582390223, 0.009884427868011716, 0.009879325394278576, 0.009874228397016386, 0.00986913687054402, 0.00986405080918613, 0.009858970207272293, 0.009853895059137566, 0.009848825359122591, 0.009843761101572857, 0.009838702280839594, 0.009833648891279136, 0.009828600927253326, 0.009823558383129082, 0.00981852125327881, 0.00981348953208023, 0.009808463213916095, 0.00980344229317488, 0.009798426764250136, 0.009793416621540641, 0.00978841185945046, 0.009783412472389128, 0.009778418454771202, 0.009773429801016734, 0.00976844650555078, 0.00976346856280387, 0.009758495967211785, 0.009753528713215496, 0.009748566795261239, 0.009743610207800464, 0.009738658945289632, 0.009733713002190858, 0.009728772372971444, 0.009723837052103513, 0.009718907034064781, 0.009713982313338003, 0.009709062884411314, 0.009704148741777819, 0.00969923987993585, 0.009694336293389118, 0.009689437976646533, 0.009684544924221977, 0.00967965713063469, 0.009674774590408917, 0.009669897298074263, 0.009665025248165517, 0.00966015843522239, 0.009655296853790003, 0.009650440498418622, 0.009645589363663453, 0.009640743444085064, 0.009635902734249165, 0.009631067228726423, 0.00962623692209262, 0.00962141180892892, 0.009616591883821598, 0.00961177714136186, 0.009606967576146031, 0.009602163182775588, 0.009597363955857325, 0.009592569890002938, 0.009587780979829262, 0.009582997219958254, 0.00957821860501695, 0.009573445129637512, 0.009568676788457024, 0.009563913576117843, 0.009559155487267466, 0.00955440251655824, 0.009549654658647641, 0.009544911908198435, 0.00954017425987806, 0.009535441708359254, 0.009530714248319841, 0.009525991874442712, 0.009521274581415459, 0.00951656236393113, 0.009511855216687655, 0.009507153134388045, 0.009502456111740363, 0.00949776414345756, 0.009493077224257625, 0.009488395348863619, 0.009483718512003657, 0.009479046708410722, 0.009474379932823058, 0.009469718179983747, 0.009465061444640708, 0.009460409721547143, 0.009455763005461287, 0.009451121291145972, 0.009446484573369333, 0.009441852846904531, 0.009437226106529325, 0.009432604347026731, 0.009427987563184815, 0.00942337574979647, 0.00941876890165959, 0.009414167013576896, 0.009409570080356373, 0.00940497809681058, 0.009400391057757121, 0.009395808958018817, 0.00939123179242308, 0.009386659555802352, 0.009382092242994102, 0.00937752984884078, 0.009372972368189462, 0.009368419795892424, 0.009363872126806741, 0.009359329355794508, 0.009354791477722604, 0.009350258487462687, 0.009345730379891646, 0.009341207149891147, 0.009336688792347458, 0.00933217530215222, 0.009327666674201705, 0.009323162903396897, 0.009318663984643823, 0.009314169912853701, 0.009309680682942103, 0.009305196289829579, 0.009300716728441868, 0.009296241993709297, 0.009291772080566939, 0.009287306983955074, 0.009282846698818535, 0.009278391220107127, 0.009273940542775432, 0.009269494661782781, 0.009265053572093689, 0.009260617268677237, 0.009256185746507245, 0.009251759000562522, 0.009247337025826835, 0.009242919817288477, 0.009238507369940528, 0.009234099678781232, 0.009229696738813341, 0.009225298545044407, 0.009220905092486919, 0.009216516376158107, 0.009212132391079928, 0.009207753132279351, 0.009203378594787833, 0.0091990087736418, 0.009194643663882415, 0.009190283260555567, 0.009185927558711914, 0.009181576553406817, 0.009177230239700624, 0.00917288861265837, 0.009168551667349673, 0.009164219398849038, 0.009159891802235733, 0.009155568872593518, 0.009151250605011334, 0.009146936994582635, 0.00914262803640559, 0.009138323725582894, 0.00913402405722238, 0.009129729026436387, 0.009125438628341998, 0.009121152858061017, 0.009116871710720167, 0.009112595181450465, 0.009108323265387666, 0.009104055957672651, 0.009099793253450818, 0.009095535147872043, 0.009091281636090956, 0.009087032713267083, 0.009082788374564481, 0.00907854861515187, 0.009074313430202954, 0.009070082814895694, 0.009065856764412747, 0.00906163527394171, 0.009057418338674673, 0.00905320595380844, 0.009048998114544503, 0.009044794816088867, 0.009040596053652221, 0.0090364018224502, 0.009032212117702698, 0.009028026934634314, 0.009023846268474573, 0.009019670114457246, 0.009015498467820843, 0.00901133132380875, 0.009007168677668645, 0.00900301052465312, 0.008998856860019043, 0.008994707679028198, 0.008990562976946812, 0.008986422749045844, 0.00898228699060072, 0.008978155696891577, 0.008974028863203008, 0.008969906484824312, 0.008965788557049274, 0.008961675075176373, 0.008957566034508755, 0.00895346143035384, 0.008949361258023966, 0.00894526551283572, 0.008941174190110387, 0.008937087285173924, 0.008933004793356786, 0.008928926709993875, 0.008924853030424795, 0.008920783749993628, 0.008916718864049133, 0.008912658367944323, 0.008908602257036918, 0.008904550526689285, 0.00890050317226805, 0.008896460189144771, 0.008892421572695028, 0.0088883873182993, 0.008884357421342514, 0.008880331877214096, 0.008876310681307927, 0.008872293829022328, 0.008868281315760333, 0.008864273136929418, 0.008860269287941328, 0.008856269764212698, 0.008852274561164417, 0.00884828367422181, 0.008844297098814697, 0.008840314830377565, 0.008836336864349344, 0.00883236319617322, 0.008828393821297078, 0.008824428735173025, 0.008820467933257872, 0.008816511411012848, 0.008812559163903663, 0.008808611187400275, 0.00880466747697732, 0.008800728028113856, 0.008796792836293239, 0.008792861897003254, 0.008788935205736351, 0.00878501275798946, 0.008781094549263508, 0.008777180575064124, 0.008773270830901389, 0.008769365312289812, 0.008765464014748385, 0.008761566933800117, 0.008757674064972897, 0.008753785403798866, 0.00874990094581439, 0.008746020686560522, 0.008742144621582328, 0.008738272746429748, 0.008734405056656765, 0.008730541547822025, 0.00872668221548816, 0.008722827055222532, 0.008718976062596705, 0.008715129233186682, 0.008711286562572949, 0.008707448046339997, 0.008703613680077193, 0.008699783459377736, 0.008695957379839666, 0.00869213543706487, 0.008688317626660088, 0.008684503944236078, 0.00868069438540807, 0.00867688894579548, 0.008673087621022478, 0.008669290406716948, 0.008665497298511491, 0.008661708292043126, 0.008657923382952898, 0.008654142566886335, 0.00865036583949337, 0.008646593196427967, 0.008642824633348542, 0.008639060145917954, 0.008635299729803312, 0.008631543380675904, 0.008627791094211324, 0.00862404286608956, 0.008620298691994663, 0.008616558567615286, 0.008612822488644343, 0.008609090450778773, 0.00860536244971976, 0.008601638481173098, 0.008597918540848645, 0.008594202624460675, 0.008590490727727499, 0.008586782846371639, 0.0085830789761203, 0.008579379112704464, 0.00857568325185957, 0.008571991389325488, 0.008568303520845906, 0.008564619642168958, 0.008560939749047217, 0.008557263837237273, 0.008553591902499704, 0.008549923940600009, 0.008546259947307228, 0.008542599918394856, 0.008538943849640653, 0.008535291736826565, 0.00853164357573878, 0.00852799936216771, 0.008524359091907793, 0.008520722760757682, 0.008517090364520486, 0.008513461899003323, 0.008509837360017541, 0.008506216743378703, 0.008502600044906399, 0.008498987260424445, 0.008495378385761093, 0.00849177341674839, 0.00848817234922264, 0.008484575179024558, 0.008480981901998873, 0.008477392513994325, 0.008473807010864134, 0.00847022538846529, 0.008466647642659213, 0.00846307376931134, 0.008459503764291347, 0.008455937623472937, 0.00845237534273399, 0.008448816917956674, 0.00844526234502691, 0.00844171161983508, 0.008438164738275564, 0.008434621696246774, 0.008431082489651335, 0.00842754711439612, 0.008424015566391982, 0.008420487841553801, 0.008416963935800463, 0.008413443845055315, 0.008409927565245685, 0.008406415092302728, 0.008402906422161802, 0.008399401550762506, 0.008395900474048435, 0.008392403187967449, 0.008388909688470949, 0.008385419971515005, 0.008381934033059488, 0.008378451869068267, 0.008374973475509246, 0.008371498848354532, 0.008368027983580259, 0.008364560877166789, 0.008361097525098058, 0.008357637923362657, 0.008354182067952529, 0.008350729954864326, 0.00834728158009821, 0.00834383693965863, 0.008340396029554234, 0.008336958845797243, 0.008333525384404137, 0.008330095641395587, 0.00832666961279606, 0.008323247294634087, 0.008319828682942154, 0.008316413773756769, 0.008313002563118694, 0.008309595047072247, 0.008306191221666199, 0.00830279108295288, 0.00829939462698888, 0.008296001849834785, 0.008292612747554995, 0.008289227316217864, 0.008285845551896038, 0.008282467450665727, 0.008279093008607562, 0.008275722221805783, 0.008272355086348632, 0.00826899159832835, 0.008265631753841407, 0.008262275548987875, 0.008258922979871823, 0.008255574042601316, 0.00825222873328825, 0.008248887048048732, 0.008245548983002672, 0.00824221453427397, 0.008238883697990133, 0.008235556470283092, 0.008232232847288384, 0.008228912825145308, 0.00822559639999765, 0.008222283567992523, 0.008218974325281288, 0.008215668668019085, 0.008212366592364882, 0.008209068094481839, 0.008205773170536732, 0.008202481816700108, 0.008199194029146987, 0.008195909804055716, 0.008192629137608685, 0.008189352025992278, 0.00818607846539648, 0.008182808452015489, 0.008179541982047298, 0.008176279051693495, 0.008173019657159908, 0.008169763794655912, 0.008166511460394913, 0.008163262650594125, 0.008160017361474764, 0.008156775589261629, 0.008153537330183338, 0.00815030258047271, 0.00814707133636613, 0.008143843594103823, 0.008140619349929813, 0.0081373986000921, 0.008134181340842511, 0.008130967568436665, 0.008127757279133754, 0.008124550469197, 0.008121347134893627, 0.008118147272494224, 0.008114950878273637, 0.008111757948510254, 0.00810856847948628, 0.008105382467487746, 0.008102199908804442, 0.008099020799729973, 0.008095845136561745, 0.008092672915600754, 0.008089504133152193, 0.008086338785524661, 0.008083176869030772, 0.008080018379986705, 0.008076863314712638, 0.008073711669532179, 0.0080705634407731, 0.00806741862476655, 0.008064277217847533, 0.008061139216355017, 0.008058004616631337, 0.00805487341502309, 0.008051745607880217, 0.008048621191556492, 0.008045500162409232, 0.008042382516800003, 0.008039268251093535, 0.008036157361658563, 0.008033049844867607, 0.008029945697096804, 0.008026844914725861, 0.008023747494138476, 0.008020653431721763, 0.008017562723866842, 0.00801447536696818, 0.00801139135742427, 0.008008310691637165, 0.008005233366012776, 0.008002159376960352, 0.007999088720893152, 0.007996021394227828, 0.007992957393384808, 0.007989896714788544, 0.007986839354866661, 0.00798378531005056, 0.007980734576775656, 0.00797768715148056, 0.007974643030607858, 0.007971602210603746, 0.007968564687917989, 0.007965530459003951, 0.007962499520318798, 0.007959471868323258, 0.007956447499481694, 0.007953426410262235, 0.007950408597136383, 0.007947394056579462, 0.007944382785070352, 0.007941374779091757, 0.007938370035129552, 0.007935368549673581, 0.007932370319217326, 0.007929375340257613, 0.007926383609295299, 0.007923395122834383, 0.007920409877382685, 0.007917427869451606, 0.007914449095556105, 0.007911473552214993, 0.00790850123595022, 0.007905532143287729, 0.00790256627075666, 0.00789960361489015, 0.007896644172224503, 0.007893687939300016, 0.00789073491266017, 0.007887785088852243, 0.007884838464427092, 0.007881895035938731, 0.007878954799945444, 0.007876017753008419, 0.007873083891692867, 0.007870153212567151, 0.007867225712203475, 0.007864301387177391, 0.007861380234068037, 0.00785846224945813, 0.007855547429933996, 0.00785263577208534, 0.007849727272505432, 0.007846821927791165, 0.00784391973454276, 0.00784102068936428, 0.00783812478886292, 0.00783523202964947, 0.007832342408338558, 0.007829455921547714, 0.007826572565898509, 0.007823692338015869, 0.007820815234528133, 0.007817941252067166, 0.007815070387268279, 0.007812202636770335, 0.007809337997215779, 0.007806476465250237, 0.0078036180375229075, 0.0078007627106865905, 0.007797910481397692, 0.007795061346315731, 0.0077922153021038635, 0.007789372345428594, 0.007786532472960013, 0.007783695681371841, 0.007780861967340692, 0.007778031327547208, 0.007775203758675223, 0.007772379257411958, 0.007769557820448156, 0.007766739444477983, 0.00776392412619898, 0.007761111862312282, 0.007758302649522396, 0.007755496484536956, 0.00775269336406744, 0.007749893284828477, 0.00774709624353807, 0.007744302236917824, 0.0077415112616927, 0.007738723314591048, 0.0077359383923445825, 0.007733156491688615, 0.007730377609361427, 0.00772760174210507, 0.007724828886664751, 0.007722059039789118, 0.007719292198230328, 0.007716528358743956, 0.007713767518088763, 0.007711009673026836, 0.007708254820323862, 0.0077055029567487205, 0.007702754079073661, 0.007700008184074488, 0.0076972652685299995, 0.0076945253292227764, 0.007691788362938355, 0.007689054366466053, 0.007686323336597943, 0.007683595270130133, 0.007680870163861429, 0.007678148014594471, 0.007675428819135039, 0.007672712574292105, 0.007669999276877987, 0.007667288923708626, 0.007664581511603103, 0.0076618770373836605, 0.007659175497876127, 0.007656476889909311, 0.007653781210315776, 0.0076510884559308915, 0.007648398623593756, 0.007645711710146472, 0.007643027712434705, 0.0076403466273070935, 0.0076376684516158465, 0.007634993182216324, 0.007632320815967098, 0.007629651349730266, 0.007626984780370944, 0.007624321104757781, 0.00762166031976241, 0.0076190024222600435, 0.007616347409128842, 0.007613695277250347, 0.007611046023509467, 0.007608399644794295, 0.007605756137996067, 0.007603115500009414, 0.00760047772773233, 0.007597842818065754, 0.007595210767914041, 0.007592581574184651, 0.007589955233788683, 0.0075873317436399666, 0.007584711100655681, 0.00758209330175638, 0.007579478343865821, 0.007576866223910899, 0.0075742569388217015, 0.007571650485531642, 0.0075690468609773374, 0.007566446062098552, 0.0075638480858382165, 0.007561252929142631, 0.007558660588961084, 0.007556071062246192, 0.007553484345953755, 0.0075509004370427485, 0.007548319332475287, 0.007545741029216674, 0.00754316552423538, 0.007540592814503206, 0.007538022896995179, 0.007535455768689011, 0.0075328914265662605, 0.0075303298676111935, 0.007527771088811259, 0.007525215087157259, 0.007522661859642981, 0.007520111403265553, 0.007517563715025076, 0.007515018791924815, 0.007512476630971399, 0.007509937229174219, 0.007507400583546206, 0.0075048666911032855, 0.007502335548864347, 0.007499807153851599, 0.007497281503090268, 0.0074947585936088945, 0.007492238422438807, 0.007489720986614905, 0.007487206283174795, 0.0074846943091593085, 0.007482185061612384, 0.0074796785375813805, 0.007477174734116364, 0.007474673648270571, 0.007472175277100412, 0.007469679617665437, 0.007467186667028183, 0.007464696422254345, 0.00746220888041274, 0.0074597240385751865, 0.007457241893816632, 0.007454762443215194, 0.0074522856838517585, 0.007449811612810536, 0.00744734022717872, 0.0074448715240466815, 0.007442405500507915, 0.007439942153658683, 0.0074374814805983885, 0.007435023478429631, 0.007432568144257904, 0.007430115475191934, 0.007427665468343565, 0.0074252181208271815, 0.0074227734297607475, 0.007420331392265191, 0.007417892005464179, 0.007415455266484514, 0.007413021172456176, 0.007410589720512106, 0.007408160907788206, 0.007405734731423501, 0.007403311188559774, 0.007400890276342205, 0.007398471991918881, 0.007396056332440674, 0.007393643295061582, 0.00739123287693878, 0.00738882507523217, 0.007386419887104831, 0.007384017309722793, 0.00738161734025503, 0.007379219975873443, 0.007376825213753146, 0.007374433051072153, 0.007372043485011258, 0.007369656512754605, 0.007367272131488866, 0.007364890338404079, 0.007362511130693029, 0.007360134505551456, 0.00735776046017825, 0.007355388991775054, 0.007353020097546441, 0.007350653774700153, 0.007348290020446893, 0.007345928832000103, 0.007343570206576154, 0.007341214141394807, 0.007338860633678111, 0.007336509680651517, 0.007334161279543197, 0.007331815427584287, 0.007329472122009091, 0.007327131360054388, 0.007324793138960382, 0.007322457455969795, 0.007320124308328491, 0.007317793693285075, 0.007315465608091302, 0.007313140050001694, 0.007310817016273495, 0.007308496504167126, 0.0073061785109459, 0.007303863033875936, 0.007301550070226263, 0.0072992396172688635, 0.0072969316722784556, 0.00729462623253273, 0.007292323295312293, 0.007290022857900699, 0.007287724917584263, 0.007285429471652017, 0.007283136517396406, 0.007280846052112111, 0.0072785580730970415, 0.0072762725776517895, 0.007273989563080148, 0.007271709026688437, 0.007269430965785888, 0.007267155377684704, 0.007264882259699814, 0.007262611609149101, 0.007260343423353185, 0.0072580776996354355, 0.007255814435322327, 0.007253553627743128, 0.0072512952742298156, 0.0072490393721173245, 0.00724678591874329, 0.0072445349114481535, 0.007242286347575242, 0.007240040224470847, 0.007237796539483767, 0.007235555289966016, 0.007233316473271843, 0.007231080086758906, 0.007228846127787417, 0.007226614593720469, 0.0072243854819237195, 0.007222158789765982, 0.007219934514618364, 0.0072177126538553555, 0.007215493204853942, 0.007213276164993681, 0.007211061531657461, 0.007208849302230295, 0.007206639474100544, 0.007204432044659079, 0.007202227011299555, 0.007200024371418524, 0.007197824122415082, 0.0071956262616912695, 0.007193430786651849, 0.007191237694704549, 0.007189046983259383, 0.007186858649729325, 0.0071846726915303005, 0.007182489106080944, 0.007180307890802232, 0.00717812904311847, 0.0071759525604563204, 0.007173778440245133, 0.007171606679917423, 0.007169437276908053, 0.00716727022865456, 0.007165105532597705, 0.0071629431861802645, 0.00716078318684844, 0.0071586255320507585, 0.007156470219238425, 0.00715431724586562, 0.007152166609388809, 0.007150018307267649, 0.007147872336964297, 0.00714572869594362, 0.007143587381673269, 0.0071414483916233725, 0.007139311723267008, 0.007137177374079775, 0.0071350453415400155, 0.007132915623128804, 0.007130788216329947, 0.007128663118629533, 0.007126540327517039, 0.007124419840484034, 0.007122301655024819, 0.007120185768636618, 0.007118072178819423, 0.007115960883075518, 0.007113851878909896, 0.007111745163830517, 0.007109640735347639, 0.007107538590974475, 0.007105438728226735, 0.007103341144622866, 0.007101245837683827, 0.007099152804933353, 0.007097062043897642, 0.007094973552105838, 0.007092887327089628, 0.007090803366382986, 0.00708872166752307, 0.007086642228049298, 0.007084565045503854, 0.007082490117431411, 0.007080417441379391, 0.0070783470148977476, 0.007076278835539125, 0.007074212900858726, 0.007072149208414642, 0.007070087755767107, 0.007068028540479286, 0.00706597156011684, 0.007063916812247955, 0.007061864294443565, 0.007059814004277078, 0.007057765939324662, 0.007055720097165009, 0.007053676475379297, 0.007051635071551471, 0.007049595883267748, 0.007047558908117308, 0.007045524143691606, 0.00704349158758484, 0.007041461237393734, 0.007039433090717502, 0.007037407145158114, 0.007035383398320035, 0.007033361847810249, 0.007031342491238257, 0.007029325326216317, 0.007027310350358938, 0.007025297561283381, 0.007023286956609424, 0.0070212785339593565, 0.007019272290958193, 0.007017268225233251, 0.007015266334414355, 0.007013266616134062, 0.007011269068027457, 0.007009273687732133, 0.00700728047288818, 0.007005289421138222, 0.007003300530127382, 0.007001313797503328, 0.006999329220916183, 0.006997346798018613, 0.006995366526465833, 0.006993388403915733, 0.006991412428028511, 0.006989438596466908, 0.006987466906896152, 0.006985497356983999, 0.006983529944400713, 0.006981564666819047, 0.00697960152191409, 0.006977640507363874, 0.0069756816208484665, 0.006973724860050715, 0.006971770222655732, 0.006969817706351143, 0.006967867308827119, 0.0069659190277763065, 0.006963972860893874, 0.00696202880587754, 0.006960086860427255, 0.0069581470222455245, 0.006956209289037359, 0.006954273658510259, 0.006952340128374263, 0.006950408696341484, 0.006948479360126987, 0.006946552117447901, 0.0069446269660240895, 0.006942703903577709, 0.0069407829278332125, 0.0069388640365177934, 0.006936947227361116, 0.006935032498094996, 0.0069331198464536725, 0.0069312092701742005, 0.006929300766995863, 0.006927394334660054, 0.006925489970911106, 0.006923587673495656, 0.006921687440162391, 0.006919789268662751, 0.006917893156750675, 0.006915999102182195, 0.006914107102716048, 0.0069122171561132794, 0.006910329260137225, 0.006908443412553746, 0.006906559611130977, 0.006904677853639568, 0.006902798137852702, 0.00690092046154561, 0.006899044822496248, 0.006897171218484683, 0.006895299647293685, 0.00689343010670812, 0.0068915625945153314, 0.006889697108505202, 0.006887833646469671, 0.006885972206203413, 0.006884112785503186, 0.006882255382168056, 0.006880399993999776, 0.006878546618802422, 0.006876695254382137, 0.006874845898547793, 0.006872998549110321, 0.006871153203883181, 0.006869309860682139, 0.006867468517325227, 0.006865629171633005, 0.006863791821428098, 0.00686195646453587, 0.006860123098783722, 0.006858291722001415, 0.006856462332021144, 0.0068546349266774675, 0.0068528095038071744, 0.006850986061249405, 0.006849164596845757, 0.006847345108439918, 0.006845527593878095, 0.0068437120510085984, 0.0068418984776824005, 0.006840086871752582, 0.006838277231074318, 0.0068364695535056905, 0.006834663836906427, 0.006832860079139009, 0.006831058278067969, 0.006829258431560368, 0.006827460537485302, 0.0068256645937144105, 0.006823870598121409, 0.006822078548582491, 0.0068202884429759405, 0.006818500279182584, 0.006816714055085474, 0.006814929768569772, 0.0068131474175229445, 0.006811366999834948, 0.006809588513397814, 0.006807811956105839, 0.006806037325855889, 0.0068042646205466305, 0.00680249383807926, 0.006800724976357281, 0.006798958033286446, 0.006797193006774834, 0.006795429894732367, 0.006793668695071678, 0.006791909405707509, 0.006790152024556851, 0.0067883965495388, 0.006786642978574918, 0.006784891309589099, 0.006783141540507091, 0.006781393669257113, 0.006779647693769494, 0.0067779036119770516, 0.006776161421814665, 0.006774421121219528, 0.006772682708130889, 0.006770946180490315, 0.006769211536241619, 0.006767478773330928, 0.0067657478897064326, 0.006764018883318612, 0.006762291752120001, 0.006760566494065679, 0.006758843107112576, 0.006757121589220091, 0.00675540193834972, 0.006753684152465255, 0.006751968229532535, 0.006750254167519692, 0.006748541964396962, 0.006746831618136811, 0.0067451231267140616, 0.006743416488105332, 0.006741711700289992, 0.006740008761249036, 0.006738307668966187, 0.006736608421426817, 0.006734911016618764, 0.006733215452531978, 0.006731521727158682, 0.006729829838493157, 0.006728139784531784, 0.006726451563273393, 0.006724765172718713, 0.006723080610870575, 0.006721397875734235, 0.006719716965317051, 0.0067180378776282405, 0.006716360610679746, 0.006714685162484931, 0.0067130115310600645, 0.006711339714422875, 0.0067096697105938005, 0.006708001517595106, 0.006706335133451148, 0.006704670556188556, 0.0067030077838360624, 0.006701346814424647, 0.006699687645987382, 0.0066980302765591495, 0.0066963747041774, 0.006694720926881594, 0.006693068942713081, 0.00669141874971549, 0.006689770345934714, 0.0066881237294185315, 0.006686478898216974, 0.006684835850382144, 0.006683194583968221, 0.006681555097031482, 0.006679917387630447, 0.0066782814538254845, 0.006676647293679258, 0.006675014905256526, 0.006673384286624091, 0.006671755435850829, 0.006670128351007647, 0.006668503030167804, 0.006666879471406347, 0.006665257672800638, 0.00666363763243011, 0.006662019348376028, 0.0066604028187219454, 0.006658788041553496, 0.006657175014958165, 0.006655563737025924, 0.00665395420584837, 0.0066523464195195805, 0.006650740376135331, 0.006649136073793651, 0.006647533510594605, 0.006645932684640353, 0.0066443335940351254, 0.0066427362368849914, 0.006641140611298297, 0.006639546715385476, 0.006637954547258981, 0.006636364105033166, 0.0066347753868244335, 0.006633188390751218, 0.0066316031149342945, 0.006630019557496231, 0.006628437716561705, 0.0066268575902572145, 0.006625279176711539, 0.006623702474055547, 0.0066221274804219256, 0.006620554193945442, 0.006618982612762932, 0.006617412735013078, 0.006615844558837054, 0.00661427808237742, 0.006612713303779286, 0.0066111502211893625, 0.006609588832756651, 0.006608029136632212, 0.006606471130968951, 0.006604914813921639, 0.0066033601836472874, 0.006601807238304778, 0.006600255976055061, 0.006598706395061142, 0.006597158493488083, 0.0065956122695026076, 0.006594067721273677, 0.006592524846972144, 0.00659098364477108, 0.0065894441128452235, 0.0065879062493714, 0.0065863700525284515, 0.006584835520497078, 0.006583302651460257, 0.006581771443602634, 0.006580241895111054, 0.0065787140041742905, 0.0065771877689829086, 0.006575663187729334, 0.006574140258608507, 0.006572618979816746, 0.006571099349552647, 0.006569581366016901, 0.006568065027411595, 0.006566550331941295, 0.006565037277812425, 0.006563525863233255, 0.006562016086413913, 0.006560507945566553, 0.006559001438905414, 0.006557496564646566, 0.006555993321007917, 0.006554491706209481, 0.006552991718473041, 0.006551493356022517, 0.0065499966170836105, 0.006548501499883903, 0.006547008002653212, 0.006545516123622853, 0.00654402586102652, 0.006542537213099407, 0.006541050178078698, 0.006539564754203698, 0.006538080939715741, 0.006536598732857557, 0.006535118131874179, 0.006533639135012486, 0.006532161740521376, 0.0065306859466511885, 0.006529211751654732, 0.006527739153786456, 0.0065262681513026805, 0.006524798742461732, 0.006523330925523804, 0.006521864698750701, 0.006520400060406724, 0.006518937008757381, 0.006517475542070672, 0.006516015658615978, 0.006514557356664977, 0.006513100634490953, 0.006511645490369033, 0.00651019192257642, 0.00650873992939234, 0.006507289509097483, 0.006505840659974555, 0.006504393380308318, 0.006502947668385143, 0.00650150352249331, 0.006500060940923079, 0.006498619921966572, 0.006497180463917772, 0.006495742565072483, 0.006494306223728336, 0.006492871438184837, 0.00649143820674331, 0.0064900065277069, 0.006488576399380842, 0.006487147820071756, 0.006485720788088557, 0.006484295301741975, 0.006482871359344137, 0.006481448959209472, 0.006480028099654014, 0.0064786087789958525, 0.0064771909955546915, 0.006475774747652096, 0.006474360033611451, 0.006472946851757966, 0.00647153520041893, 0.00647012507792303, 0.006468716482601015, 0.006467309412785659, 0.006465903866811146, 0.006464499843013542, 0.006463097339730911, 0.006461696355303197, 0.00646029688807193, 0.006458898936380481, 0.006457502498574083, 0.006456107572999811, 0.006454714158006313, 0.006453322251944319, 0.00645193185316638, 0.006450542960026704, 0.006449155570881078, 0.006447769684087589, 0.006446385298005713, 0.006445002410996937, 0.006443621021424223, 0.006442241127652755, 0.00644086272804914, 0.006439485820981833, 0.006438110404821284, 0.006436736477939612, 0.006435364038710526, 0.0064339930855098265, 0.006432623616714674, 0.006431255630704499, 0.0064298891258601715, 0.006428524100564362, 0.006427160553201373, 0.006425798482157768, 0.0064244378858212756, 0.006423078762581716, 0.006421721110830703, 0.006420364928961282, 0.006419010215368757, 0.0064176569684498246, 0.006416305186602794, 0.006414954868228031, 0.006413606011727751, 0.006412258615505545, 0.006410912677966849, 0.00640956819751894, 0.006408225172570892, 0.006406883601533222, 0.006405543482818453, 0.006404204814841002, 0.006402867596016617, 0.006401531824762908, 0.0064001974994991224, 0.006398864618646515, 0.0063975331806277675, 0.006396203183867616, 0.006394874626792141, 0.006393547507829547, 0.006392221825409385, 0.006390897577963046, 0.00638957476392357, 0.006388253381725975, 0.006386933429806754, 0.00638561490660416, 0.00638429781055813, 0.006382982140110159, 0.006381667893703843, 0.006380355069784112, 0.006379043666797763, 0.006377733683193206, 0.006376425117420669, 0.006375117967931991, 0.006373812233180657, 0.006372507911621937, 0.006371205001712751, 0.006369903501911597, 0.006368603410678832, 0.00636730472647642, 0.006366007447767928, 0.006364711573018749, 0.006363417100695917, 0.006362124029268025, 0.0063608323572055606, 0.006359542082980542, 0.006358253205066478, 0.006356965721938854, 0.0063556796320745675, 0.006354394933952361, 0.006353111626052584, 0.006351829706857377, 0.006350549174850301, 0.006349270028516771, 0.006347992266343574, 0.006346715886819539, 0.006345440888434859, 0.006344167269681383, 0.006342895029052995, 0.00634162416504475, 0.006340354676153326, 0.006339086560877635, 0.006337819817717555, 0.006336554445175021, 0.006335290441753364, 0.006334027805957742, 0.006332766536294882, 0.006331506631273175, 0.006330248089402592, 0.0063289909091945136, 0.0063277350891623365, 0.006326480627821081, 0.006325227523686967, 0.0063239757752782165, 0.006322725381114685, 0.006321476339717577, 0.006320228649609782, 0.006318982309315969, 0.006317737317362416, 0.006316493672276781, 0.006315251372588594, 0.006314010416828721, 0.006312770803529892, 0.006311532531226427, 0.006310295598454011, 0.006309060003750202, 0.00630782574565392, 0.006306592822705933, 0.006305361233448381, 0.006304130976425229, 0.006302902050181813, 0.0063016744532651174, 0.00630044818422392, 0.006299223241608176, 0.006297999623969882, 0.006296777329862234, 0.0062955563578402166, 0.0062943367064604225, 0.0062931183742808506, 0.006291901359861319, 0.006290685661763009, 0.006289471278548978, 0.00628825820878342, 0.006287046451032337, 0.006285836003863362, 0.006284626865845498, 0.00628341903554937, 0.006282212511547439, 0.006281007292413513, 0.006279803376722808, 0.0062786007630523605, 0.0062773994499806226, 0.006276199436087606, 0.006275000719954936, 0.006273803300165863, 0.006272607175305024, 0.006271412343958857, 0.0062702188047149806, 0.006269026556162817, 0.006267835596893229, 0.006266645925498611, 0.006265457540573019, 0.006264270440711862, 0.006263084624512387, 0.006261900090573005, 0.00626071683749395, 0.006259534863876815, 0.0062583541683248235, 0.006257174749442799, 0.00625599660583695, 0.006254819736114875, 0.006253644138886181, 0.00625246981276149, 0.006251296756353155, 0.006250124968275211, 0.006248954447142817, 0.006247785191572941, 0.00624661720018419, 0.00624545047159634, 0.0062442850044309405, 0.006243120797310768, 0.006241957848860356, 0.006240796157705863, 0.006239635722474632, 0.006238476541795587, 0.006237318614299271, 0.006236161938617602, 0.006235006513384076, 0.006233852337233637, 0.006232699408802966, 0.0062315477267297316, 0.006230397289653638, 0.0062292480962155665, 0.006228100145057987, 0.006226953434824742, 0.006225807964161279, 0.006224663731714643, 0.006223520736133055, 0.006222378976066344, 0.006221238450165926, 0.006220099157084784, 0.0062189610954769105, 0.006217824263998298, 0.006216688661306095, 0.006215554286059084, 0.006214421136917596, 0.0062132892125429575, 0.006212158511598492, 0.006211029032748907, 0.006209900774660104, 0.006208773735999565, 0.006207647915436376, 0.006206523311640774, 0.006205399923284817, 0.006204277749041956, 0.006203156787586781, 0.0062020370375957075, 0.006200918497746339, 0.006199801166717831, 0.006198685043190965, 0.006197570125847682, 0.006196456413371504, 0.00619534390444737, 0.006194232597761545, 0.006193122492001968, 0.006192013585857865, 0.006190905878020122, 0.006189799367180787, 0.006188694052033244, 0.006187589931272726, 0.006186487003595625, 0.006185385267699707, 0.0061842847222842974, 0.006183185366050178, 0.006182087197699425, 0.0061809902159355706, 0.006179894419463702, 0.006178799806990279, 0.006177706377223139, 0.006176614128871295, 0.006175523060645767, 0.006174433171258347, 0.006173344459422599, 0.006172256923853461, 0.006171170563267278, 0.00617008537638177, 0.006169001361915985, 0.006167918518590434, 0.006166836845127152, 0.0061657563402495365, 0.006164677002682232, 0.0061635988311514135, 0.006162521824384609, 0.006161445981110588, 0.006160371300059864, 0.00615929777996413, 0.006158225419556456, 0.006157154217571478, 0.006156084172745038, 0.006155015283814342, 0.006153947549517948, 0.006152880968596031, 0.00615181553979013, 0.006150751261842925, 0.006149688133498719, 0.006148626153502963, 0.0061475653206024905, 0.00614650563354591, 0.006145447091082826, 0.006144389691964166, 0.006143333434942472, 0.00614227831877144, 0.006141224342206362, 0.006140171504003898, 0.00613911980292166, 0.0061380692377192665, 0.006137019807157082, 0.006135971509997256, 0.006134924345002917, 0.006133878310938947, 0.006132833406571393, 0.006131789630667728, 0.006130746981996728, 0.006129705459328379, 0.00612866506143423, 0.006127625787087012, 0.006126587635061032, 0.006125550604131719, 0.0061245146930761435, 0.006123479900672283, 0.006122446225699712, 0.006121413666939374, 0.0061203822231733875, 0.00611935189318543, 0.006118322675760363, 0.006117294569684417, 0.006116267573745174, 0.00611524168673139, 0.006114216907433374, 0.006113193234642854, 0.006112170667152479, 0.006111149203756458, 0.006110128843250422, 0.006109109584431129, 0.0061080914260969, 0.006107074367047036, 0.006106058406082625, 0.0061050435420054675, 0.00610402977361919, 0.006103017099728531, 0.006102005519139443, 0.006100995030659406, 0.006099985633097101, 0.006098977325262541, 0.006097970105967143, 0.006096963974023428, 0.006095958928245141, 0.006094954967447755, 0.0060939520904477315, 0.0060929502960626655, 0.006091949583111978, 0.006090949950415979, 0.006089951396796383, 0.006088953921076043, 0.006087957522079403, 0.0060869621986320375, 0.0060859679495607185, 0.006084974773693753, 0.0060839826698606434, 0.0060829916368920055, 0.006082001673619862, 0.006081012778877579, 0.006080024951499693, 0.0060790381903220655, 0.006078052494181977, 0.006077067861917791, 0.006076084292369117, 0.006075101784376874, 0.0060741203367835565, 0.006073139948432591, 0.0060721606181686, 0.006071182344837762, 0.006070205127287595, 0.006069228964366391, 0.006068253854924217, 0.006067279797812266, 0.006066306791882682, 0.0060653348359891845, 0.006064363928986653, 0.006063394069731361, 0.006062425257080669, 0.006061457489893355, 0.006060490767029299, 0.006059525087349591, 0.006058560449716839, 0.006057596852994638, 0.006056634296047919, 0.006055672777742752, 0.006054712296946815, 0.00605375285252848, 0.006052794443357945, 0.00605183706830609, 0.006050880726245627, 0.006049925416049962, 0.006048971136594056, 0.006048017886754048, 0.006047065665407256, 0.006046114471432311, 0.006045164303708791, 0.006044215161118068, 0.006043267042542223, 0.00604231994686472, 0.006041373872970389, 0.006040428819745173, 0.006039484786076205, 0.00603854177085195, 0.0060375997729620184, 0.006036658791297197, 0.006035718824749614, 0.006034779872212546, 0.006033841932580616, 0.006032905004749403, 0.006031969087615852, 0.006031034180078034, 0.006030100281035377, 0.006029167389388259, 0.0060282355040386275, 0.006027304623889588, 0.0060263747478451635, 0.006025445874810722, 0.0060245180036928095, 0.006023591133399286, 0.006022665262839209, 0.006021740390922776, 0.0060208165165612886, 0.006019893638667224, 0.006018971756154636, 0.0060180508679382825, 0.006017130972934492, 0.006016212070060531, 0.006015294158234824, 0.006014377236377331, 0.006013461303408998, 0.006012546358251858, 0.006011632399829129, 0.006010719427065338, 0.006009807438886207, 0.006008896434218403, 0.006007986411990095, 0.006007077371130653, 0.006006169310570116, 0.006005262229240344, 0.00600435612607393, 0.006003451000004762, 0.006002546849967911, 0.0060016436748996, 0.00600074147373738, 0.005999840245419775, 0.005998939988886393, 0.005998040703078435, 0.005997142386937848, 0.0059962450394078805, 0.005995348659432776, 0.005994453245958289, 0.005993558797931111, 0.005992665314299113, 0.00599177279401148, 0.00599088123601813, 0.0059899906392705485, 0.00598910100272138, 0.00598821232532415, 0.005987324606033782, 0.005986437843806107, 0.005985552037598119, 0.00598466718636834, 0.005983783289076027, 0.0059829003446817885, 0.005982018352147192, 0.005981137310435102, 0.005980257218509558, 0.005979378075335713, 0.005978499879879709, 0.005977622631108963, 0.00597674632799188, 0.005975870969498177, 0.005974996554598728, 0.005974123082265339, 0.005973250551471149, 0.005972378961190443, 0.00597150831039824, 0.005970638598071077, 0.005969769823186678, 0.00596890198472369, 0.005968035081661654, 0.005967169112981689, 0.005966304077665835, 0.005965439974697298, 0.005964576803060375, 0.00596371456174033, 0.005962853249723748, 0.005961992865998377, 0.005961133409552881, 0.005960274879377047, 0.005959417274461829, 0.005958560593799493, 0.005957704836383054, 0.005956850001206838, 0.0059559960872663424, 0.00595514309355797, 0.005954291019079468, 0.005953439862829339, 0.005952589623807575, 0.005951740301014917, 0.005950891893453494, 0.005950044400126516, 0.005949197820038097, 0.0059483521521935655, 0.005947507395599108, 0.005946663549262505, 0.00594582061219222, 0.0059449785833978735, 0.005944137461890201, 0.005943297246681129, 0.00594245793678365, 0.00594161953121169, 0.005940782028980567, 0.005939945429106258, 0.005939109730605897, 0.005938274932498194, 0.005937441033802314, 0.005936608033538815, 0.005935775930729371, 0.005934944724396552, 0.005934114413564092, 0.005933284997256856, 0.005932456474500813, 0.005931628844322872, 0.005930802105750886, 0.005929976257814257, 0.005929151299542863, 0.0059283272299681415, 0.00592750404812227, 0.005926681753038525, 0.005925860343751533, 0.005925039819296619, 0.005924220178710473, 0.005923401421030702, 0.005922583545295838, 0.005921766550545754, 0.0059209504358210055, 0.005920135200163717, 0.005919320842616539, 0.005918507362223437, 0.005917694758029504, 0.0059168830290807365, 0.0059160721744243115, 0.0059152621931083185, 0.005914453084181919, 0.005913644846695474, 0.005912837479700023, 0.005912030982248123, 0.005911225353392888, 0.005910420592188967, 0.005909616697691678, 0.005908813668957537, 0.005908011505044138, 0.0059072102050099756, 0.005906409767914529, 0.005905610192818579, 0.0059048114787838, 0.005904013624872837, 0.005903216630149419, 0.0059024204936782435, 0.005901625214525275, 0.005900830791757251, 0.0059000372244420165, 0.005899244511648328, 0.005898452652446058, 0.005897661645906238, 0.005896871491100767, 0.005896082187102717, 0.005895293732985879, 0.005894506127825306, 0.005893719370697053, 0.005892933460678253, 0.005892148396846748, 0.0058913641782817406, 0.005890580804063136, 0.005889798273272145, 0.005889016584990924, 0.0058882357383025115, 0.005887455732290911, 0.005886676566041429, 0.005885898238640084, 0.005885120749174029, 0.005884344096731302, 0.005883568280401124, 0.005882793299273555, 0.005882019152439852, 0.0058812458389921685, 0.005880473358023737, 0.0058797017086285475, 0.005878930889901681, 0.005878160900939345, 0.005877391740838703, 0.005876623408697783, 0.005875855903615752, 0.0058750892246927176, 0.00587432337102987, 0.005873558341729144, 0.005872794135893558, 0.00587203075262728, 0.005871268191035393, 0.005870506450223849, 0.005869745529299575, 0.005868985427370803, 0.005868226143546231, 0.005867467676935957, 0.005866710026650941, 0.005865953191803063, 0.005865197171505115, 0.005864441964870994, 0.0058636875710155545, 0.0058629339890547486, 0.005862181218105221, 0.00586142925728475, 0.005860678105712046, 0.00585992776250689, 0.00585917822678982, 0.005858429497682445, 0.005857681574307523, 0.005856934455788497, 0.005856188141249944, 0.005855442629817376, 0.005854697920617171, 0.005853954012776843, 0.005853210905424597, 0.005852468597689825, 0.005851727088702926, 0.005850986377595101, 0.0058502464634985875, 0.005849507345546397, 0.005848769022872625, 0.005848031494612485, 0.005847294759901896, 0.0058465588178778895, 0.0058458236676783995, 0.00584508930844233, 0.0058443557393094, 0.005843622959420292, 0.005842890967916807, 0.005842159763941438, 0.005841429346637999, 0.00584069971515103, 0.005839970868625738, 0.005839242806208653, 0.005838515527047246, 0.005837789030289649, 0.0058370633150851454, 0.0058363383805839315, 0.005835614225937062, 0.005834890850296555, 0.0058341682528155, 0.005833446432647734, 0.005832725388947946, 0.005832005120871981, 0.005831285627576595, 0.005830566908219187, 0.005829848961958549, 0.005829131787953928, 0.00582841538536589, 0.005827699753355735, 0.0058269848910856275, 0.005826270797718636, 0.005825557472418997, 0.00582484491435159, 0.005824133122682436, 0.0058234220965782645, 0.005822711835206865, 0.005822002337736795, 0.005821293603337676, 0.005820585631180054, 0.00581987842043538, 0.005819171970275995, 0.0058184662798749665, 0.005817761348406447, 0.005817057175045716, 0.005816353758968542, 0.005815651099351599, 0.005814949195372883, 0.005814248046211046, 0.005813547651045729, 0.005812848009057187, 0.005812149119426847, 0.0058114509813371835, 0.005810753593971227, 0.005810056956512867, 0.005809361068147359, 0.005808665928060374, 0.005807971535438769, 0.005807277889470225, 0.005806584989343202, 0.005805892834247226, 0.005805201423372706, 0.0058045107559105925, 0.005803820831053316, 0.005803131647993618, 0.00580244320592554, 0.00580175550404381, 0.005801068541544096, 0.005800382317622898, 0.005799696831477721, 0.0057990120823066755, 0.005798328069309207, 0.0057976447916852645, 0.005796962248635921, 0.005796280439362908, 0.0057955993630688886, 0.005794919018957393, 0.005794239406233083, 0.005793560524101107, 0.005792882371767922, 0.005792204948440493, 0.005791528253326639, 0.0057908522856353305, 0.0057901770445762165, 0.005789502529359829, 0.0057888287391978325, 0.005788155673302373, 0.005787483330886489, 0.005786811711164318, 0.005786140813350682, 0.005785470636661563, 0.0057848011803133745, 0.005784132443523651, 0.005783464425510851, 0.005782797125494079, 0.0057821305426933685, 0.005781464676329671, 0.005780799525624765, 0.005780135089801419, 0.005779471368082806, 0.005778808359693496, 0.005778146063858656, 0.005777484479804395, 0.005776823606757537, 0.005776163443945777, 0.0057755039905979, 0.0057748452459432, 0.0057741872092118805, 0.005773529879635232, 0.005772873256445201, 0.00577221733887468, 0.005771562126157241, 0.005770907617527356, 0.005770253812220575, 0.005769600709472955, 0.0057689483085216495, 0.005768296608604305, 0.005767645608959858, 0.005766995308827729, 0.005766345707448476, 0.0057656968040630955, 0.005765048597913721, 0.005764401088243347, 0.005763754274295696, 0.005763108155315135, 0.005762462730547151, 0.0057618179992379405, 0.005761173960634577, 0.005760530613985066, 0.0057598879585380215, 0.0057592459935428015, 0.00575860471824987, 0.005757964131910356, 0.005757324233776314, 0.0057566850231006534, 0.00575604649913699, 0.00575540866113961, 0.005754771508363928, 0.005754135040066054, 0.0057534992555027436, 0.0057528641539318776, 0.005752229734612024, 0.005751595996802408, 0.005750962939763424, 0.0057503305627558815, 0.005749698865041716, 0.00574906784588333, 0.005748437504544243, 0.005747807840288866, 0.005747178852382057, 0.005746550540089844, 0.005745922902678633, 0.005745295939416042, 0.005744669649570258, 0.005744044032410457, 0.005743419087206475, 0.0057427948132290005, 0.005742171209749654, 0.005741548276040505, 0.005740926011374758, 0.005740304415026295, 0.005739683486269853, 0.00573906322438068, 0.005738443628635322, 0.005737824698310585, 0.005737206432684597, 0.005736588831035749, 0.005735971892643743, 0.005735355616788722, 0.005734740002751565, 0.0057341250498142175, 0.005733510757259329, 0.005732897124370423, 0.005732284150431502, 0.005731671834727659, 0.005731060176544469, 0.005730449175168629, 0.0057298388298874705, 0.005729229139989035, 0.005728620104762257, 0.005728011723496968, 0.00572740399548347, 0.005726796920012934, 0.005726190496377428, 0.005725584723869917, 0.0057249796017836444, 0.005724375129413329, 0.005723771306053784, 0.005723168131001123, 0.005722565603551927, 0.005721963723003646, 0.005721362488654441, 0.005720761899803342, 0.005720161955750279, 0.005719562655795468, 0.005718963999240388, 0.005718365985387208, 0.0057177686135385965, 0.005717171882998266, 0.00571657579307045, 0.0057159803430602805, 0.005715385532273712, 0.005714791360017457, 0.005714197825598847, 0.005713604928325926, 0.005713012667507822, 0.005712421042454118, 0.005711830052475553, 0.005711239696883067, 0.005710649974988696, 0.0057100608861049935, 0.005709472429545777, 0.005708884604624936, 0.005708297410657663, 0.005707710846959611, 0.005707124912847318, 0.00570653960763801, 0.005705954930649816, 0.005705370881201312, 0.005704787458611956, 0.005704204662202108, 0.005703622491292815, 0.00570304094520555, 0.005702460023263144, 0.0057018797247884645, 0.00570130004910563, 0.005700720995539289, 0.005700142563414966, 0.005699564752058836, 0.005698987560797796, 0.005698410988959589, 0.005697835035872664, 0.005697259700866117, 0.005696684983269716, 0.005696110882414151, 0.005695537397630767, 0.005694964528251609, 0.005694392273609574, 0.005693820633038227, 0.005693249605871649, 0.005692679191444988, 0.005692109389094061, 0.005691540198155371, 0.005690971617966101, 0.005690403647864109, 0.005689836287188108, 0.005689269535277322, 0.005688703391472039, 0.00568813785511305, 0.005687572925541974, 0.0056870086021011314, 0.005686444884133317, 0.005685881770982419, 0.005685319261992803, 0.005684757356509667, 0.005684196053878949, 0.00568363535344721, 0.00568307525456193, 0.0056825157565710315, 0.005681956858823105, 0.005681398560667877, 0.00568084086145531, 0.005680283760536428, 0.005679727257262942, 0.005679171350987054, 0.0056786160410618285, 0.005678061326840821, 0.005677507207678623, 0.005676953682930552, 0.005676400751952368, 0.00567584841410053, 0.005675296668732541, 0.005674745515206191, 0.0056741949528803575, 0.005673644981114388, 0.005673095599268297, 0.005672546806702949, 0.00567199860277974, 0.0056714509868610995, 0.005670903958309716, 0.005670357516489419, 0.005669811660764481, 0.005669266390499795, 0.0056687217050609695, 0.005668177603814501, 0.005667634086127548, 0.005667091151367963, 0.005666548798904015, 0.00566600702810509, 0.005665465838341007, 0.005664925228982094, 0.005664385199399978, 0.0056638457489662924, 0.0056633068770537915, 0.0056627685830358656, 0.005662230866286419, 0.005661693726180204, 0.005661157162092414, 0.005660621173399375, 0.0056600857594776436, 0.005659550919704896, 0.005659016653458996, 0.0056584829601189655, 0.005657949839064035, 0.005657417289674551, 0.005656885311331287, 0.005656353903415719, 0.005655823065310194, 0.00565529279639751, 0.005654763096061154, 0.005654233963685478, 0.005653705398655524, 0.005653177400356552, 0.005652649968174949, 0.005652123101497729, 0.00565159679971238, 0.005651071062207286, 0.005650545888371303, 0.0056500212775941454, 0.005649497229266185, 0.005648973742778251, 0.005648450817521888, 0.005647928452889487, 0.0056474066482741034, 0.005646885403069238, 0.005646364716669125, 0.005645844588468807, 0.005645325017864025, 0.005644806004250752, 0.005644287547026303, 0.0056437696455879675, 0.0056432522993342124, 0.005642735507663864, 0.005642219269976469, 0.005641703585672467, 0.005641188454152715, 0.0056406738748185515, 0.005640159847072415, 0.005639646370317186, 0.0056391334439563874, 0.005638621067394054, 0.0056381092400350635, 0.005637597961284991, 0.005637087230550025, 0.005636577047236853, 0.0056360674107530425, 0.005635558320506588, 0.005635049775906204, 0.005634541776361417, 0.005634034321282051, 0.0056335274100789865, 0.005633021042163393, 0.0056325152169474585, 0.0056320099338436815, 0.005631505192265407, 0.005631000991626437, 0.005630497331341481, 0.005629994210825637, 0.005629491629494753, 0.005628989586765284, 0.005628488082054389, 0.005627987114779674, 0.005627486684359806, 0.005626986790213692, 0.00562648743176097, 0.005625988608421886, 0.0056254903196175715, 0.005624992564769406, 0.0056244953432996745, 0.005623998654631304, 0.005623502498187859, 0.005623006873393197, 0.005622511779672237, 0.005622017216450378, 0.0056215231831534184, 0.0056210296792083, 0.005620536704041972, 0.005620044257082493, 0.005619552337758353, 0.005619060945498699, 0.005618570079733373, 0.005618079739892665, 0.005617589925407696, 0.005617100635710093, 0.005616611870232154, 0.005616123628406571, 0.005615635909666979, 0.005615148713447651, 0.005614662039183099, 0.005614175886308903, 0.005613690254260939, 0.005613205142475681, 0.005612720550390551, 0.005612236477443335, 0.005611752923072573, 0.005611269886717414, 0.0056107873678172705, 0.0056103053658126375, 0.005609823880144461, 0.005609342910254121, 0.00560886245558391, 0.0056083825155765635, 0.005607903089675478, 0.0056074241773244665, 0.0056069457779682735, 0.0056064678910520555, 0.005605990516021455, 0.00560551365232315, 0.005605037299403927, 0.005604561456711593, 0.005604086123694194, 0.00560361129980069, 0.005603136984480658, 0.005602663177183969, 0.005602189877361145, 0.005601717084463542, 0.005601244797943235, 0.005600773017252263, 0.005600301741844017, 0.00559983097117189, 0.005599360704690361, 0.005598890941854167, 0.005598421682118703, 0.005597952924940028, 0.005597484669774835, 0.005597016916080313, 0.0055965496633142466, 0.005596082910935169, 0.005595616658402, 0.005595150905174353, 0.005594685650712479, 0.005594220894477097, 0.005593756635929607, 0.005593292874532031, 0.005592829609746861, 0.005592366841037245, 0.005591904567866773, 0.005591442789699947, 0.005590981506001695, 0.005590520716237593, 0.005590060419873464, 0.005589600616376236, 0.005589141305213032, 0.005588682485851708, 0.005588224157760704, 0.005587766320408924, 0.0055873089732660095, 0.005586852115802153, 0.005586395747488057, 0.0055859398677951125, 0.005585484476195113, 0.005585029572160724, 0.005584575155164863, 0.005584121224681098, 0.005583667780183689, 0.005583214821147514, 0.005582762347047734, 0.005582310357360544, 0.005581858851562398, 0.0055814078291302385, 0.005580957289541825, 0.005580507232275377, 0.005580057656809574, 0.005579608562623976, 0.005579159949198356, 0.005578711816013385, 0.005578264162550146, 0.005577816988290213, 0.005577370292715785, 0.00557692407530953, 0.00557647833555498, 0.0055760330729361166, 0.005575588286937176, 0.005575143977043449, 0.00557470014274027, 0.005574256783514064, 0.005573813898851443, 0.005573371488239739, 0.0055729295511668915, 0.005572488087121131, 0.005572047095591522, 0.005571606576067572, 0.005571166528039469, 0.00557072695099783, 0.005570287844433753, 0.00556984920783917, 0.005569411040706278, 0.005568973342528125, 0.005568536112797983, 0.005568099351010022, 0.0055676630566586305, 0.005567227229238878, 0.005566791868246469, 0.005566356973177549, 0.005565922543528934, 0.005565488578798118, 0.005565055078482812, 0.005564622042081385, 0.005564189469092642, 0.005563757359016277, 0.005563325711352212, 0.0055628945256012575, 0.005562463801264432, 0.005562033537843418, 0.00556160373484054, 0.005561174391758377, 0.005560745508100406, 0.0055603170833705045, 0.005559889117073016, 0.005559461608712922, 0.005559034557795694, 0.005558607963827407, 0.005558181826314649, 0.005557756144764603, 0.005557330918684703, 0.005556906147583246, 0.005556481830968997, 0.005556057968351187, 0.005555634559239647, 0.005555211603144886, 0.005554789099577465, 0.005554367048048997, 0.005553945448071524, 0.005553524299157386, 0.005553103600819511, 0.005552683352571507, 0.005552263553927645, 0.005551844204402234, 0.005551425303510642, 0.005551006850768476, 0.005550588845691991, 0.005550171287797883, 0.005549754176603308, 0.005549337511626283, 0.005548921292384862, 0.005548505518397954, 0.005548090189185117, 0.0055476753042661715, 0.005547260863161362, 0.0055468468653917654, 0.0055464333104789714, 0.005546020197944769, 0.0055456075273118055, 0.005545195298102966, 0.00554478350984203, 0.005544372162052966, 0.005543961254260424, 0.005543550785989519, 0.0055431407567657544, 0.005542731166115357, 0.005542322013565126, 0.0055419132986421855, 0.005541505020874033, 0.0055410971797893, 0.0055406897749163825, 0.005540282805784766, 0.005539876271924183, 0.005539470172864789, 0.005539064508137426, 0.005538659277273564, 0.005538254479804915, 0.005537850115263836, 0.005537446183183143, 0.005537042683096302, 0.0055366396145372, 0.005536236977039974, 0.005535834770139881, 0.0055354329933719046, 0.0055350316462721766, 0.00553463072837722, 0.005534230239223838, 0.00553383017834944, 0.005533430545291933, 0.005533031339589846, 0.005532632560782114, 0.0055322342084081835, 0.0055318362820079335, 0.005531438781121852, 0.005531041705290897, 0.005530645054056452, 0.005530248826960618, 0.005529853023545862, 0.005529457643355122, 0.0055290626859317744, 0.005528668150819693, 0.005528274037563522, 0.0055278803457081815, 0.005527487074799044, 0.005527094224382139, 0.005526701794003936, 0.005526309783211313, 0.005525918191551614, 0.005525527018572863, 0.005525136263823475, 0.005524745926852348, 0.0055243560072090235, 0.005523966504443265, 0.005523577418105492, 0.005523188747746567, 0.005522800492917971, 0.005522412653171505, 0.0055220252280595425, 0.005521638217134914, 0.0055212516199509235, 0.005520865436061499, 0.005520479665020824, 0.005520094306383702, 0.0055197093597055815, 0.005519324824541995, 0.0055189407004494675, 0.005518556986984427, 0.0055181736837042975, 0.005517790790166759, 0.005517408305930139, 0.005517026230552768, 0.005516644563594111, 0.005516263304613599, 0.005515882453171531, 0.005515502008828445, 0.005515121971145335, 0.005514742339683818, 0.005514363114005963, 0.00551398429367431, 0.005513605878251794, 0.005513227867301805, 0.005512850260388386, 0.005512473057075833, 0.005512096256929265, 0.005511719859513842, 0.005511343864395613, 0.005510968271140802, 0.005510593079316105, 0.005510218288489084, 0.0055098438982270955, 0.0055094699080985715, 0.005509096317672178, 0.0055087231265172265, 0.005508350334203052, 0.0055079779402998665, 0.0055076059443782965, 0.0055072343460094, 0.005506863144764682, 0.005506492340215939, 0.005506121931935732, 0.005505751919496917, 0.0055053823024729855, 0.0055050130804376405, 0.005504644252965281, 0.005504275819630692, 0.0055039077800091065, 0.005503540133676034, 0.005503172880207778, 0.005502806019180922, 0.005502439550172666, 0.005502073472760458, 0.005501707786522424, 0.00550134249103687, 0.0055009775858827666, 0.0055006130706395095, 0.005500248944886968, 0.0054998852082054454, 0.005499521860175666, 0.005499158900378797, 0.005498796328396678, 0.005498434143811336, 0.005498072346205261, 0.005497710935161614, 0.005497349910263945, 0.005496989271096303, 0.005496629017242909, 0.00549626914828867, 0.0054959096638188916, 0.005495550563419388, 0.005495191846676326, 0.00549483351317639, 0.005494475562506877, 0.005494117994255108, 0.0054937608080092345, 0.005493404003357659, 0.005493047579889474, 0.005492691537193722, 0.0054923358748605435, 0.005491980592480098, 0.005491625689643009, 0.005491271165940497, 0.005490917020964257, 0.005490563254306393, 0.005490209865559263, 0.005489856854315674, 0.005489504220169271, 0.005489151962713724, 0.005488800081543314, 0.005488448576252824, 0.005488097446437426, 0.00548774669169275, 0.005487396311614874, 0.005487046305800098, 0.005486696673845327, 0.005486347415348186, 0.0054859985299062376, 0.005485650017117779, 0.0054853018765814755, 0.005484954107896491, 0.005484606710662353, 0.005484259684479099, 0.005483913028947162, 0.005483566743667211, 0.0054832208282407655, 0.005482875282269374, 0.005482530105355437, 0.005482185297101384, 0.00548184085711029, 0.00548149678498564, 0.005481153080331184, 0.005480809742751492, 0.005480466771851165, 0.005480124167235276, 0.0054797819285096845, 0.005479440055280333, 0.005479098547153767, 0.005478757403736811, 0.005478416624636889, 0.0054780762094618395, 0.00547773615781961, 0.0054773964693191155, 0.005477057143569141, 0.005476718180179296, 0.005476379578759441, 0.005476041338920093, 0.005475703460271734, 0.00547536594242574, 0.005475028784993471, 0.005474691987587194, 0.005474355549819367, 0.005474019471302696, 0.0054736837516504945, 0.005473348390476566, 0.005473013387394896, 0.005472678742020135, 0.005472344453967384, 0.005472010522851736, 0.005471676948289338, 0.005471343729896197, 0.0054710108672889265, 0.005470678360084764, 0.005470346207901227, 0.00547001441035602, 0.005469682967067529, 0.005469351877654527, 0.00546902114173625, 0.005468690758932172, 0.005468360728862175, 0.005468031051146809, 0.0054677017254068415, 0.005467372751263483, 0.005467044128338354, 0.00546671585625334, 0.005466387934631155, 0.0054660603630945276, 0.0054657331412668346, 0.00546540626877169, 0.005465079745233342, 0.005464753570276085, 0.0054644277435250185, 0.005464102264605278, 0.005463777133142647, 0.005463452348763344, 0.005463127911094027, 0.005462803819761582, 0.005462480074393297, 0.005462156674616948, 0.005461833620060706, 0.0054615109103531715, 0.00546118854512343, 0.005460866524000739, 0.005460544846614831, 0.00546022351259604, 0.005459902521574962, 0.00545958187318262, 0.005459261567050248, 0.005458941602809765, 0.005458621980093427, 0.005458302698533829, 0.005457983757763936, 0.005457665157417167, 0.005457346897127361, 0.005457028976528632, 0.0054567113952556645, 0.0054563941529434164, 0.005456077249227246, 0.005455760683742971, 0.005455444456126843, 0.005455128566015554, 0.005454813013045787, 0.005454497796855091, 0.005454182917081236, 0.005453868373362445, 0.005453554165337346, 0.005453240292644592, 0.005452926754923898, 0.005452613551814811, 0.00545230068295749, 0.005451988147992313, 0.005451675946560339, 0.005451364078303016, 0.005451052542861834, 0.005450741339878922, 0.005450430468996833, 0.005450119929858339, 0.005449809722106704, 0.005449499845385732, 0.005449190299339329, 0.005448881083611828, 0.005448572197848136, 0.005448263641693466, 0.0054479554147933975, 0.005447647516794013, 0.00544733994734133, 0.005447032706082266, 0.00544672579266396, 0.005446419206733983, 0.005446112947940126, 0.005445807015930824, 0.005445501410354495, 0.005445196130860262, 0.005444891177097647, 0.005444586548716391, 0.005444282245366662, 0.005443978266698872, 0.005443674612364249, 0.00544337128201389, 0.005443068275299483, 0.005442765591873392, 0.005442463231387733, 0.005442161193495489, 0.005441859477849909, 0.005441558084104648, 0.0054412570119135965, 0.005440956260931066, 0.005440655830811787, 0.005440355721210939, 0.005440055931783923, 0.005439756462186567, 0.005439457312075113, 0.0054391584811060815, 0.005438859968936593, 0.005438561775223991, 0.0054382638996258795, 0.005437966341800432, 0.005437669101405905, 0.005437372178101382, 0.005437075571545958, 0.005436779281399348, 0.005436483307321318, 0.005436187648972262, 0.005435892306012781, 0.00543559727810394, 0.005435302564907203, 0.005435008166084462, 0.00543471408129766, 0.005434420310209577, 0.00543412685248297, 0.005433833707781093, 0.005433540875767589, 0.005433248356106309, 0.005432956148461793, 0.0054326642524985475, 0.005432372667881938, 0.005432081394277192, 0.0054317904313502955, 0.005431499778767294, 0.005431209436194891, 0.0054309194032997575, 0.005430629679749261, 0.005430340265211155, 0.005430051159353256, 0.005429762361843946, 0.00542947387235188, 0.005429185690546349, 0.005428897816096655, 0.005428610248672492, 0.005428322987944078, 0.005428036033581952, 0.005427749385256964, 0.005427463042640333, 0.005427177005403538, 0.005426891273218688, 0.0054266058457578936, 0.005426320722693928, 0.0054260359036997765, 0.005425751388448828, 0.005425467176614733, 0.005425183267871755, 0.00542489966189418, 0.005424616358356754, 0.0054243333569346, 0.005424050657303314, 0.005423768259138472, 0.005423486162116499, 0.00542320436591388, 0.005422922870207469, 0.005422641674674595, 0.005422360778992784, 0.0054220801828400046, 0.005421799885894639, 0.005421519887835126, 0.005421240188340717, 0.005420960787090669, 0.005420681683764459, 0.0054204028780424586, 0.005420124369604771, 0.005419846158132428, 0.005419568243306169, 0.00541929062480769, 0.0054190133023186305, 0.005418736275521271, 0.0054184595440979096, 0.005418183107731281, 0.005417906966104779, 0.005417631118901764, 0.005417355565806056, 0.00541708030650193, 0.005416805340673818, 0.005416530668006625, 0.005416256288185666, 0.005415982200896516, 0.00541570840582493, 0.005415434902657088, 0.005415161691079856, 0.005414888770779838, 0.005414616141444548, 0.005414343802761481, 0.005414071754418554, 0.005413799996104157, 0.005413528527506815, 0.005413257348315377, 0.005412986458219242, 0.005412715856908072, 0.005412445544071765, 0.005412175519400804, 0.005411905782585749, 0.005411636333317336, 0.005411367171287155, 0.005411098296186804, 0.005410829707708133, 0.005410561405543594, 0.005410293389385882, 0.005410025658927883, 0.005409758213862954, 0.005409491053884647, 0.005409224178687136, 0.005408957587964632, 0.005408691281411777, 0.0054084252587236065, 0.005408159519595235, 0.005407894063722558, 0.00540762889080151, 0.00540736400052823, 0.0054070993925995235, 0.005406835066712173, 0.005406571022563646, 0.005406307259851591, 0.005406043778273656, 0.005405780577528349, 0.005405517657314249, 0.005405255017330258, 0.005404992657275756, 0.00540473057685018, 0.0054044687757535135, 0.0054042072536860395, 0.005403946010348233, 0.005403685045440981, 0.0054034243586654, 0.005403163949723239, 0.005402903818316265, 0.005402643964146486, 0.0054023843869167015, 0.005402125086329559, 0.005401866062088152, 0.005401607313896157, 0.005401348841457249, 0.005401090644475609, 0.005400832722655582, 0.005400575075701943, 0.005400317703319925, 0.005400060605214766, 0.005399803781092082, 0.0053995472306581594, 0.0053992909536191265, 0.005399034949681889, 0.005398779218553417, 0.005398523759940858, 0.005398268573551808, 0.005398013659094316, 0.005397759016276791, 0.005397504644807701, 0.005397250544395743, 0.005396996714750416, 0.0053967431555810835, 0.005396489866597695, 0.0053962368475103965, 0.005395984098029623, 0.005395731617865988, 0.005395479406730754, 0.005395227464335386, 0.005394975790391571, 0.005394724384611209, 0.005394473246706857, 0.0053942223763910994, 0.005393971773376885, 0.00539372143737765, 0.005393471368106825, 0.005393221565278239, 0.00539297202860619, 0.005392722757805355, 0.005392473752590442, 0.005392225012676648, 0.005391976537779279, 0.005391728327614342, 0.005391480381897658, 0.00539123270034585, 0.005390985282675385, 0.005390738128603315, 0.005390491237847167, 0.0053902446101242295, 0.005389998245152651, 0.0053897521426504134, 0.005389506302336288, 0.005389260723928855, 0.0053890154071476026, 0.0053887703517117415, 0.005388525557340963, 0.005388281023755346, 0.005388036750675425, 0.0053877927378217245, 0.005387548984915209, 0.0053873054916770595, 0.005387062257828885, 0.005386819283092503, 0.005386576567190177, 0.005386334109844341, 0.005386091910777915, 0.005385849969713777, 0.005385608286375285, 0.005385366860486194, 0.005385125691770477, 0.005384884779952332, 0.005384644124756367, 0.005384403725907414, 0.005384163583130727, 0.005383923696151814, 0.005383684064696365, 0.005383444688490265, 0.005383205567260097, 0.0053829667007324385, 0.005382728088634043, 0.005382489730692332, 0.00538225162663492, 0.005382013776189457, 0.005381776179084232, 0.005381538835047742, 0.00538130174380848, 0.005381064905095554, 0.00538082831863815, 0.0053805919841659975, 0.005380355901408937, 0.005380120070097161, 0.005379884489961317, 0.005379649160731835, 0.005379414082139987, 0.005379179253917117, 0.005378944675794889, 0.005378710347505272, 0.005378476268780403, 0.005378242439352667, 0.005378008858955067, 0.005377775527320592, 0.005377542444182705, 0.005377309609275055, 0.005377077022331535, 0.005376844683086427, 0.00537661259127425, 0.00537638074662992, 0.005376149148888412, 0.005375917797785137, 0.005375686693055847, 0.005375455834436574, 0.005375225221663361, 0.005374994854472869, 0.005374764732601972, 0.005374534855787767, 0.005374305223767564, 0.005374075836279093, 0.005373846693060307, 0.00537361779384961, 0.0053733891383853745, 0.005373160726406436, 0.0053729325576519936, 0.005372704631861345, 0.00537247694877411, 0.005372249508130212, 0.005372022309669968, 0.005371795353133897, 0.005371568638262743, 0.0053713421647974885, 0.005371115932479517, 0.005370889941050634, 0.005370664190252693, 0.005370438679827708, 0.00537021340951834, 0.005369988379067088, 0.005369763588217258, 0.005369539036711974, 0.005369314724294979, 0.005369090650710012, 0.00536886681570129, 0.005368643219013195, 0.005368419860390335, 0.005368196739577757, 0.005367973856320694, 0.005367751210364657, 0.005367528801455312, 0.005367306629338983, 0.0053670846937617775, 0.005366862994470483, 0.005366641531211847, 0.005366420303733233, 0.005366199311781874, 0.0053659785551055696, 0.005365758033452379, 0.005365537746570592, 0.0053653176942086295, 0.005365097876115232, 0.0053648782920396884, 0.005364658941731136, 0.005364439824939322, 0.005364220941414026, 0.005364002290905443, 0.005363783873164186, 0.005363565687940646, 0.005363347734986094, 0.0053631300140515705, 0.005362912524888577, 0.0053626952672489875, 0.005362478240884928, 0.005362261445548535, 0.005362044880992573, 0.005361828546969786, 0.005361612443233195, 0.005361396569536351, 0.005361180925632707, 0.005360965511276318, 0.005360750326221427, 0.0053605353702225085, 0.005360320643034062, 0.005360106144411185, 0.005359891874109217, 0.0053596778318837236, 0.005359464017490244, 0.005359250430684966, 0.005359037071224101, 0.005358823938864267, 0.005358611033362461, 0.005358398354475602, 0.005358185901961101, 0.005357973675576463, 0.005357761675079604, 0.005357549900228827, 0.005357338350782282, 0.005357127026498937, 0.00535691592713755, 0.0053567050524573, 0.005356494402217603, 0.005356283976178309, 0.005356073774099231, 0.005355863795740644, 0.005355654040863237, 0.0053554445092274874, 0.005355235200594489, 0.005355026114725587, 0.005354817251382125, 0.005354608610326084, 0.0053544001913194035, 0.005354191994124309, 0.00535398401850339, 0.0053537762642197175, 0.005353568731036099, 0.00535336141871582, 0.005353154327022556, 0.005352947455720176, 0.005352740804572619, 0.005352534373344411, 0.00535232816180011, 0.005352122169704455, 0.005351916396822647, 0.0053517108429198745, 0.005351505507761917, 0.00535130039111465, 0.00535109549274431, 0.005350890812416956, 0.0053506863498994596, 0.005350482104958726, 0.00535027807736164, 0.0053500742668757565, 0.0053498706732688275, 0.00534966729630859, 0.005349464135763025, 0.005349261191400726, 0.005349058462990286, 0.005348855950300571, 0.005348653653100779, 0.005348451571160416, 0.005348249704248898, 0.005348048052136139, 0.0053478466145922615, 0.005347645391387778, 0.005347444382293212, 0.00534724358707954, 0.005347043005517717, 0.005346842637379119, 0.005346642482435575, 0.005346442540458885, 0.005346242811221079, 0.005346043294494593, 0.005345843990051928, 0.005345644897665934, 0.005345446017109915, 0.005345247348156997, 0.005345048890580899, 0.005344850644155364, 0.005344652608654535, 0.005344454783852583, 0.005344257169524312, 0.005344059765444353, 0.005343862571387894, 0.005343665587130177, 0.005343468812446646, 0.005343272247113174, 0.005343075890905655, 0.005342879743600591, 0.00534268380497428, 0.005342488074803462, 0.00534229255286526, 0.005342097238936857, 0.005341902132795611, 0.005341707234219306, 0.005341512542985969, 0.00534131805887381, 0.005341123781661066, 0.005340929711126571, 0.00534073584704919, 0.005340542189208038, 0.005340348737382562, 0.005340155491352319, 0.005339962450897235, 0.005339769615797412, 0.0053395769858330284, 0.005339384560784856, 0.005339192340433648, 0.0053390003245604644, 0.005338808512946469, 0.005338616905373321, 0.005338425501622662, 0.005338234301476527, 0.005338043304717206, 0.0053378525111272175, 0.005337661920489005, 0.005337471532585732, 0.005337281347200517, 0.00533709136411671, 0.005336901583118062, 0.005336712003988184, 0.005336522626511428, 0.005336333450472013, 0.005336144475654576, 0.005335955701843944, 0.005335767128824952, 0.0053355787563830435, 0.005335390584303732, 0.0053352026123725275, 0.005335014840375698, 0.005334827268099178, 0.005334639895329491, 0.00533445272185323, 0.005334265747457292, 0.005334078971928901, 0.00533389239505544, 0.005333706016624335, 0.005333519836423366, 0.005333333854240585, 0.005333148069864263, 0.005332962483082833, 0.005332777093685205, 0.005332591901460253, 0.00533240690619707, 0.005332222107684991, 0.005332037505713751, 0.005331853100073292, 0.005331668890553567, 0.0053314848769447695, 0.005331301059037658, 0.005331117436622872, 0.005330934009491394, 0.005330750777434465, 0.005330567740243558, 0.00533038489771032, 0.00533020224962659, 0.00533001979578448, 0.005329837535976281, 0.005329655469994715, 0.005329473597632282, 0.005329291918682164, 0.005329110432937681, 0.0053289291401922385, 0.005328748040239392, 0.005328567132873123, 0.0053283864178876724, 0.005328205895077228, 0.005328025564236249, 0.00532784542515976, 0.005327665477642668, 0.005327485721480196, 0.00532730615646767, 0.005327126782400992, 0.005326947599075828, 0.005326768606288551, 0.005326589803835292, 0.005326411191512618, 0.005326232769117291, 0.0053260545364464985, 0.005325876493297209, 0.005325698639466874, 0.0053255209747532836, 0.005325343498954285, 0.005325166211867719, 0.00532498911329224, 0.005324812203026141, 0.005324635480868087, 0.005324458946617169, 0.005324282600072548, 0.005324106441033514, 0.0053239304692998144, 0.005323754684671186, 0.00532357908694761, 0.0053234036759294764, 0.005323228451417161, 0.005323053413211244, 0.005322878561112761, 0.005322703894922759, 0.005322529414442664, 0.00532235511947394, 0.005322181009818457, 0.005322007085277873, 0.0053218333456547156, 0.005321659790751052, 0.005321486420369803, 0.005321313234313536, 0.005321140232385363, 0.005320967414388654, 0.005320794780126756, 0.005320622329403282, 0.005320450062022198, 0.005320277977787512, 0.005320106076503663, 0.0053199343579750915, 0.005319762822006414, 0.005319591468402689, 0.0053194202969689885, 0.005319249307510784, 0.005319078499833593, 0.00531890787374311, 0.005318737429045251, 0.005318567165546353, 0.005318397083052954, 0.005318227181371383, 0.005318057460308652, 0.0053178879196717115, 0.005317718559267763, 0.005317549378904212, 0.005317380378388881, 0.005317211557529379, 0.005317042916133943, 0.005316874454010857, 0.005316706170968547, 0.0053165380668157335, 0.005316370141361268, 0.005316202394414281, 0.005316034825784059, 0.005315867435280113, 0.0053157002227122, 0.005315533187890082, 0.005315366330624123, 0.005315199650724459, 0.005315033148001702, 0.005314866822266461, 0.005314700673329896, 0.005314534701003074, 0.005314368905097201, 0.0053142032854239215, 0.005314037841795094, 0.0053138725740225845, 0.005313707481918477, 0.0053135425652952656, 0.005313377823965435, 0.005313213257741726, 0.005313048866437048, 0.005312884649864725, 0.0053127206078381175, 0.0053125567401708035, 0.005312393046676305, 0.005312229527168865, 0.005312066181462631, 0.005311903009371831, 0.005311740010711284, 0.0053115771852956266, 0.005311414532939682, 0.005311252053458926, 0.005311089746668389, 0.005310927612383966, 0.0053107656504211296, 0.0053106038605960125, 0.005310442242724889, 0.005310280796623888, 0.005310119522109744, 0.005309958418999212, 0.005309797487109019, 0.0053096367262565405, 0.005309476136259166, 0.005309315716934276, 0.005309155468099669, 0.0053089953895733505, 0.00530883548117336, 0.005308675742718126, 0.005308516174026079, 0.005308356774916072, 0.0053081975452067874, 0.005308038484717464, 0.005307879593267435, 0.005307720870676206, 0.005307562316763647, 0.005307403931349293, 0.005307245714253498, 0.005307087665296391, 0.005306929784298498, 0.005306772071080612, 0.005306614525463296, 0.005306457147267946, 0.005306299936315559, 0.005306142892427751, 0.005305986015425948, 0.00530582930513218, 0.0053056727613682575, 0.0053055163839564575, 0.005305360172719225, 0.005305204127479022, 0.00530504824805876, 0.005304892534281347, 0.0053047369859700625, 0.0053045816029482, 0.005304426385039118, 0.005304271332066748, 0.005304116443854836, 0.005303961720227742, 0.005303807161009654, 0.005303652766024945, 0.005303498535098384, 0.00530334446805479, 0.005303190564719351, 0.005303036824917088, 0.005302883248473655, 0.005302729835214479, 0.005302576584965614, 0.005302423497552733, 0.0053022705728023025, 0.005302117810540636, 0.005301965210594183, 0.005301812772789693, 0.0053016604969540375, 0.00530150838291456, 0.005301356430498416, 0.005301204639532931, 0.005301053009846054, 0.005300901541265582, 0.005300750233619461, 0.005300599086735883, 0.005300448100443438, 0.005300297274570571, 0.005300146608946052, 0.005299996103398929, 0.0052998457577582555, 0.005299695571853469, 0.005299545545514038, 0.0052993956785698055, 0.00529924597085044, 0.00529909642218607, 0.00529894703240697, 0.005298797801343669, 0.005298648728826668, 0.005298499814686685, 0.005298351058754878, 0.005298202460862386, 0.005298054020840368, 0.005297905738520596, 0.005297757613734645, 0.005297609646314313, 0.0052974618360917955, 0.005297314182899292, 0.005297166686569229, 0.005297019346934195, 0.005296872163827075, 0.005296725137080912, 0.005296578266528757, 0.005296431552003855, 0.005296284993339712, 0.005296138590369985, 0.005295992342928589, 0.0052958462508496135, 0.005295700313967371, 0.005295554532116008, 0.0052954089051302595, 0.0052952634328448656, 0.005295118115094754, 0.0052949729517151175, 0.00529482794254111, 0.005294683087408313, 0.005294538386152352, 0.005294393838608982, 0.005294249444614253, 0.0052941052040043545, 0.005293961116615539, 0.005293817182284428, 0.005293673400847681, 0.00529352977214215, 0.0052933862960049104, 0.005293242972273245, 0.0052930998007844005, 0.005292956781376112, 0.005292813913886085, 0.005292671198152234, 0.00529252863401266, 0.005292386221305714, 0.005292243959869711, 0.005292101849543215, 0.005291959890165211, 0.005291818081574653, 0.005291676423610513, 0.005291534916112204, 0.005291393558919276, 0.005291252351871406, 0.00529111129480834, 0.0052909703875699335, 0.005290829629996634, 0.005290689021928674, 0.00529054856320649, 0.005290408253670951, 0.005290268093162951, 0.005290128081523368, 0.005289988218593442, 0.005289848504214537, 0.005289708938228107, 0.005289569520476081, 0.005289430250800207, 0.005289291129042586, 0.005289152155045408, 0.00528901332865119, 0.005288874649702281, 0.005288736118041704, 0.005288597733512173, 0.005288459495956702, 0.005288321405218701, 0.005288183461141367, 0.005288045663568503, 0.005287908012343746, 0.005287770507310928, 0.005287633148314261, 0.0052874959351980316, 0.00528735886780646, 0.005287221945984246, 0.005287085169576261, 0.005286948538427172, 0.005286812052382297, 0.005286675711286722, 0.005286539514985959, 0.005286403463325539, 0.005286267556151365, 0.005286131793309183, 0.005285996174645166, 0.005285860700005421, 0.005285725369236327, 0.0052855901821846595, 0.005285455138696998, 0.005285320238620344, 0.005285185481801884, 0.005285050868088625, 0.00528491639732817, 0.00528478206936793, 0.005284647884055577, 0.005284513841239114, 0.005284379940766596, 0.005284246182486304, 0.005284112566246442, 0.0052839790918957534, 0.0052838457592826625, 0.00528371256825628, 0.005283579518665507, 0.005283446610359675, 0.005283313843188061, 0.005283181217000192, 0.005283048731645625, 0.005282916386974477, 0.005282784182836502, 0.005282652119081853, 0.005282520195561098, 0.005282388412124414, 0.005282256768622568, 0.005282125264906366, 0.0052819939008267956, 0.005281862676235045, 0.005281731590982367, 0.005281600644920146, 0.005281469837900041, 0.0052813391697736625, 0.005281208640393071, 0.0052810782496103366, 0.005280947997277722, 0.0052808178832476705, 0.005280687907372675, 0.005280558069505416, 0.005280428369498784, 0.005280298807205901, 0.005280169382479867, 0.005280040095174005, 0.0052799109451418125, 0.00527978193223706, 0.005279653056313502, 0.005279524317225042, 0.005279395714825887, 0.005279267248970381, 0.005279138919512885, 0.005279010726307985, 0.005278882669210506, 0.005278754748075412, 0.005278626962757719, 0.005278499313112664, 0.005278371798995616, 0.0052782444202620436, 0.005278117176767755, 0.005277990068368413, 0.005277863094920307, 0.005277736256279452, 0.005277609552302144, 0.005277482982844816, 0.005277356547764, 0.005277230246916552, 0.005277104080159591, 0.005276978047350025, 0.005276852148344956, 0.00527672638300194, 0.005276600751178472, 0.00527647525273229, 0.005276349887521345, 0.005276224655403398, 0.005276099556236823, 0.0052759745898797545, 0.005275849756190598, 0.005275725055028114, 0.005275600486251112, 0.005275476049718376, 0.005275351745288934, 0.005275227572821966, 0.00527510353217712, 0.005274979623213622, 0.0052748558457912965, 0.005274732199769806, 0.005274608685009188, 0.005274485301369691, 0.005274362048711397, 0.005274238926894788, 0.005274115935780516, 0.005273993075229305, 0.005273870345101821, 0.005273747745259171, 0.00527362527556267, 0.005273502935873437, 0.005273380726052989, 0.005273258645963086, 0.0052731366954652395, 0.005273014874421421, 0.005272893182693755, 0.005272771620144418, 0.005272650186635776, 0.005272528882030416, 0.00527240770619093, 0.005272286658980074, 0.005272165740260877, 0.0052720449498963205, 0.005271924287749632, 0.005271803753684235, 0.005271683347563733, 0.00527156306925158, 0.005271442918611804, 0.005271322895508267, 0.005271202999805216, 0.00527108323136671, 0.005270963590057414, 0.0052708440757416285, 0.005270724688284221, 0.005270605427549887, 0.005270486293403709, 0.005270367285710816, 0.005270248404336511, 0.005270129649146115, 0.005270011020005359, 0.005269892516779771, 0.005269774139335285, 0.005269655887537838, 0.005269537761253789, 0.0052694197603491075, 0.005269301884690347, 0.005269184134144096, 0.005269066508577154, 0.005268949007856279, 0.005268831631848476, 0.005268714380420955, 0.005268597253440902, 0.005268480250775746, 0.005268363372293114, 0.0052682466178608405, 0.005268129987346572, 0.00526801348061831, 0.005267897097544355, 0.005267780837992926, 0.005267664701832315, 0.005267548688931166, 0.00526743279915816, 0.005267317032382215, 0.005267201388472383, 0.005267085867297599, 0.005266970468727134, 0.005266855192630518, 0.005266740038877229, 0.005266625007337053, 0.005266510097879669, 0.00526639531037504, 0.005266280644693325, 0.005266166100704851, 0.005266051678279787, 0.005265937377288874, 0.00526582319760271, 0.00526570913909184, 0.0052655952016274965, 0.005265481385080624, 0.0052653676893226605, 0.005265254114224588, 0.005265140659658219, 0.005265027325494977, 0.005264914111606673, 0.005264801017865325, 0.0052646880441428005, 0.005264575190311333, 0.005264462456243372, 0.005264349841811139, 0.005264237346887342, 0.005264124971344649, 0.00526401271505609, 0.005263900577894577, 0.00526378855973323, 0.005263676660445098, 0.005263564879903897, 0.005263453217982949, 0.005263341674556151, 0.0052632302494972074, 0.005263118942680082, 0.005263007753978685, 0.005262896683267358, 0.005262785730420447, 0.005262674895312506, 0.005262564177818082, 0.005262453577811949, 0.005262343095169064, 0.005262232729764415, 0.005262122481473216, 0.005262012350170601, 0.005261902335731977, 0.005261792438032968, 0.00526168265694939, 0.005261572992356835, 0.005261463444131526, 0.00526135401214932, 0.0052612446962866195, 0.005261135496419659, 0.005261026412424878, 0.005260917444179167, 0.005260808591558964, 0.005260699854441318, 0.005260591232703325, 0.005260482726222038, 0.005260374334874749, 0.005260266058538763, 0.005260157897091752, 0.0052600498504112025, 0.005259941918375249, 0.005259834100861585, 0.005259726397748331, 0.005259618808913617, 0.0052595113342360075, 0.005259403973593784, 0.005259296726865509, 0.005259189593929962, 0.0052590825746658635, 0.005258975668952371, 0.005258868876668465, 0.0052587621976935145, 0.0052586556319066825, 0.0052585491791877804, 0.005258442839416168, 0.005258336612471691, 0.005258230498234306, 0.005258124496583844, 0.005258018607400515, 0.0052579128305647385, 0.005257807165956718, 0.005257701613457105, 0.005257596172946552, 0.005257490844305689, 0.0052573856274155395, 0.005257280522157204, 0.005257175528411715, 0.005257070646060331, 0.005256965874984753, 0.005256861215066225, 0.005256756666186453, 0.005256652228227352, 0.005256547901070968, 0.005256443684599025, 0.005256339578694028, 0.005256235583238093, 0.0052561316981137385, 0.005256027923203283, 0.005255924258389645, 0.0052558207035556075, 0.0052557172585840735, 0.005255613923358182, 0.005255510697760892, 0.005255407581675772, 0.0052553045749861894, 0.0052552016775755115, 0.005255098889327718, 0.0052549962101263725, 0.005254893639855466, 0.005254791178399212, 0.00525468882564159, 0.005254586581466995, 0.0052544844457598355, 0.005254382418404745, 0.005254280499286336, 0.0052541786882894384, 0.005254076985299068, 0.005253975390200082, 0.0052538739028777015, 0.005253772523217189, 0.0052536712511039975, 0.005253570086423768, 0.005253469029061988, 0.005253368078904718, 0.00525326723583762, 0.005253166499746774, 0.005253065870518294, 0.005252965348038432, 0.005252864932193716, 0.005252764622870629, 0.005252664419955691, 0.0052525643233356165, 0.005252464332897527, 0.005252364448528336, 0.005252264670114962, 0.0052521649975449825, 0.00525206543070549, 0.005251965969484071, 0.00525186661376844, 0.005251767363446158, 0.0052516682184050095, 0.005251569178533139, 0.005251470243718548, 0.005251371413849362, 0.005251272688814005, 0.0052511740685010615, 0.005251075552798929, 0.005250977141596175, 0.005250878834781825, 0.005250780632244683, 0.00525068253387378, 0.005250584539558306, 0.005250486649187529, 0.0052503888626508274, 0.00525029117983786, 0.005250193600638084, 0.005250096124941308, 0.005249998752637405, 0.005249901483616429, 0.0052498043177684394, 0.00524970725498351, 0.0052496102951521215, 0.005249513438164739, 0.005249416683911833, 0.0052493200322843055, 0.005249223483172821, 0.005249127036468308, 0.0052490306920616485, 0.005248934449844161, 0.005248838309707158, 0.0052487422715419615, 0.005248646335240062, 0.005248550500693237, 0.005248454767793197, 0.005248359136431649, 0.005248263606500566, 0.005248168177892094, 0.005248072850498398, 0.005247977624211808, 0.005247882498924898, 0.005247787474530061, 0.005247692550920029, 0.005247597727987617, 0.0052475030056255674, 0.005247408383726881, 0.005247313862184767, 0.005247219440892399, 0.00524712511974323, 0.005247030898630796, 0.005246936777448564, 0.005246842756090146, 0.005246748834449319, 0.005246655012420163, 0.005246561289896698, 0.005246467666772942, 0.005246374142943358, 0.005246280718302161, 0.005246187392743824, 0.005246094166163031, 0.005246001038454389, 0.005245908009512816, 0.005245815079233152, 0.005245722247510669, 0.005245629514240252, 0.005245536879317417, 0.005245444342637424, 0.005245351904095768, 0.005245259563587952, 0.005245167321009889, 0.0052450751762572806, 0.0052449831292260265, 0.005244891179812271, 0.005244799327912121, 0.005244707573421914, 0.005244615916238156, 0.0052445243562572255, 0.005244432893375657, 0.0052443415274901805, 0.005244250258497751, 0.005244159086295134, 0.005244068010779495, 0.005243977031847979, 0.005243886149397974, 0.005243795363326633, 0.005243704673531569, 0.005243614079910373, 0.005243523582360815, 0.005243433180780683, 0.005243342875067961, 0.00524325266512048, 0.005243162550836657, 0.005243072532114458, 0.005242982608852342, 0.005242892780948916, 0.005242803048302618, 0.005242713410812262, 0.0052426238683764784, 0.0052425344208943455, 0.005242445068264869, 0.0052423558103871105, 0.005242266647160326, 0.005242177578483753, 0.00524208860425689, 0.005241999724379364, 0.005241910938750869, 0.005241822247271097, 0.0052417336498398895, 0.005241645146357182, 0.005241556736723239, 0.005241468420838145, 0.005241380198602204, 0.005241292069915723, 0.005241204034679407, 0.005241116092793764, 0.005241028244159499, 0.005240940488677573, 0.005240852826248877, 0.005240765256774367, 0.005240677780155348, 0.005240590396292969, 0.0052405031050885694, 0.005240415906443725, 0.0052403288002599606, 0.0052402417864390385, 0.005240154864882518, 0.005240068035492552, 0.0052399812981709214, 0.005239894652819819, 0.00523980809934139, 0.005239721637638011, 0.005239635267612118, 0.0052395489891662655, 0.005239462802202862, 0.005239376706624892, 0.005239290702334963, 0.005239204789236066, 0.005239118967231461, 0.00523903323622393, 0.005238947596116911, 0.005238862046813819, 0.00523877658821809, 0.005238691220233132, 0.005238605942762592, 0.005238520755710335, 0.005238435658980417, 0.005238350652476467, 0.005238265736102728, 0.005238180909763279, 0.005238096173362578, 0.005238011526804699, 0.005237926969994308, 0.005237842502836082, 0.005237758125234494, 0.0052376738370944215, 0.005237589638320779, 0.005237505528818636, 0.005237421508492891, 0.005237337577248843, 0.005237253734991641, 0.005237169981626962, 0.005237086317060088, 0.005237002741196569, 0.00523691925394212, 0.0052368358552026765, 0.005236752544884175, 0.005236669322892313, 0.005236586189133477, 0.00523650314351376, 0.005236420185939541, 0.005236337316317176, 0.005236254534552976, 0.005236171840553754, 0.00523608923422623, 0.005236006715476984, 0.005235924284213189, 0.0052358419403416255, 0.005235759683769459, 0.005235677514403878, 0.005235595432152279, 0.005235513436922052, 0.005235431528620575, 0.005235349707155466, 0.005235267972434517, 0.00523518632436532, 0.005235104762855916, 0.005235023287814313, 0.005234941899148489, 0.005234860596766708, 0.005234779380577187, 0.00523469825048837, 0.00523461720640868, 0.005234536248246753, 0.005234455375911221, 0.005234374589310732, 0.005234293888354365, 0.005234213272950939, 0.005234132743009742, 0.0052340522984395885, 0.005233971939149995, 0.005233891665050218, 0.005233811476049719, 0.005233731372057978, 0.0052336513529846924, 0.005233571418739707, 0.005233491569232764, 0.005233411804373712, 0.00523333212407265, 0.005233252528239905, 0.005233173016785376, 0.005233093589619539, 0.005233014246652736, 0.0052329349877956845, 0.005232855812958693, 0.005232776722052712, 0.005232697714988444, 0.005232618791676587, 0.00523253995202833, 0.00523246119595479, 0.0052323825233671, 0.005232303934176411, 0.005232225428294288, 0.005232147005632098, 0.005232068666101358, 0.005231990409613635, 0.0052319122360809005, 0.00523183414541474, 0.005231756137527312, 0.005231678212330581, 0.0052316003697365455, 0.005231522609657572, 0.005231444932005866, 0.005231367336693806, 0.005231289823633986, 0.005231212392738825, 0.005231135043921305, 0.005231057777094025, 0.005230980592169804, 0.005230903489061671, 0.005230826467682587, 0.005230749527945821, 0.0052306726697646045, 0.005230595893052113, 0.005230519197721818, 0.0052304425836873355, 0.005230366050862341, 0.005230289599160429, 0.0052302132284952904, 0.0052301369387809365, 0.005230060729931444, 0.005229984601860643, 0.005229908554482797, 0.005229832587712191, 0.005229756701463082, 0.0052296808956501465, 0.005229605170187661, 0.005229529524990272, 0.0052294539599728965, 0.005229378475050192, 0.005229303070136855, 0.0052292277451482, 0.0052291524999990855, 0.005229077334604849, 0.005229002248880545, 0.0052289272427414974, 0.005228852316103456, 0.005228777468881684, 0.0052287027009919025, 0.005228628012349665, 0.00522855340287087, 0.005228478872471442, 0.005228404421067339, 0.00522833004857466, 0.005228255754909563, 0.005228181539988182, 0.005228107403726857, 0.005228033346042142, 0.0052279593668503885, 0.0052278854660683625, 0.005227811643612587, 0.005227737899400049, 0.005227664233347305, 0.005227590645371536, 0.005227517135389895, 0.005227443703319378, 0.005227370349077165, 0.0052272970725806035, 0.005227223873747117, 0.005227150752494063, 0.0052270777087392375, 0.005227004742400034, 0.005226931853394483, 0.005226859041640185, 0.005226786307055312, 0.0052267136495577, 0.005226641069065518, 0.005226568565496829, 0.00522649613877004, 0.00522642378880356, 0.005226351515515846, 0.005226279318825283, 0.005226207198650537, 0.005226135154910401, 0.005226063187523575, 0.005225991296409066, 0.005225919481485692, 0.0052258477426727476, 0.005225776079889084, 0.005225704493054107, 0.005225632982087137, 0.005225561546907614, 0.005225490187434777, 0.005225418903588515, 0.005225347695288298, 0.005225276562454023, 0.005225205505005322, 0.005225134522862301, 0.005225063615944836, 0.005224992784173056, 0.005224922027467211, 0.005224851345747404, 0.005224780738934128, 0.005224710206947672, 0.005224639749708576, 0.0052245693671375245, 0.005224499059155235, 0.0052244288256824, 0.0052243586666397505, 0.005224288581948411, 0.005224218571529303, 0.00522414863530354, 0.005224078773192469, 0.005224008985117206, 0.0052239392709990794, 0.00522386963075966, 0.005223800064320489, 0.005223730571603089, 0.0052236611525289965, 0.005223591807020175, 0.005223522534998617, 0.005223453336386045, 0.005223384211104622, 0.005223315159076293, 0.005223246180223261, 0.005223177274467865, 0.005223108441732487, 0.005223039681939709, 0.005222970995011922, 0.0052229023808717115, 0.00522283383944163, 0.005222765370644684, 0.005222696974403653, 0.005222628650641558, 0.005222560399281199, 0.005222492220245737, 0.005222424113458616, 0.005222356078842832, 0.005222288116321772, 0.005222220225818852, 0.00522215240725773, 0.0052220846605617955, 0.005222016985654863, 0.005221949382460752, 0.00522188185090313, 0.0052218143909059924, 0.0052217470023934, 0.005221679685289377, 0.005221612439517942, 0.005221545265003548, 0.005221478161670459, 0.005221411129442907, 0.005221344168245557, 0.005221277278002854, 0.005221210458639671, 0.005221143710080434, 0.005221077032250249, 0.005221010425073758, 0.005220943888476034, 0.005220877422382171, 0.0052208110267172375, 0.005220744701406469, 0.005220678446374987, 0.005220612261548278, 0.00522054614685183, 0.005220480102211118, 0.005220414127551857, 0.005220348222799516, 0.005220282387879998, 0.0052202166227191945, 0.00522015092724304, 0.005220085301377431, 0.005220019745048491, 0.005219954258182324, 0.005219888840705028, 0.005219823492543137, 0.005219758213622963, 0.005219693003871044, 0.005219627863213912, 0.005219562791578078, 0.005219497788890484, 0.005219432855077674, 0.005219367990066592, 0.005219303193784162, 0.005219238466157557, 0.005219173807113689, 0.005219109216579922, 0.005219044694483229, 0.005218980240751137, 0.005218915855311022, 0.005218851538090457, 0.0052187872890167835, 0.005218723108017773, 0.005218658995021215, 0.005218594949954869, 0.005218530972746496, 0.0052184670633240995, 0.005218403221615631, 0.005218339447549294, 0.005218275741053276, 0.0052182121020557665, 0.0052181485304851685, 0.005218085026269861, 0.005218021589338235, 0.005217958219618907, 0.005217894917040482, 0.005217831681531743, 0.005217768513021539, 0.0052177054114386475, 0.005217642376711906, 0.005217579408770497, 0.005217516507543481, 0.005217453672959858, 0.005217390904949062, 0.005217328203440316, 0.0052172655683630385, 0.005217202999646688, 0.005217140497220895, 0.0052170780610152675, 0.005217015690959473, 0.005216953386983174, 0.005216891149016199, 0.005216828976988584, 0.005216766870830395, 0.0052167048304714875, 0.005216642855842126, 0.005216580946872554, 0.005216519103493058, 0.005216457325633856, 0.005216395613225662, 0.0052163339661987435, 0.0052162723844837375, 0.0052162108680113605, 0.005216149416712263, 0.005216088030517352, 0.005216026709357496, 0.005215965453163564, 0.005215904261866697, 0.005215843135397942, 0.005215782073688586, 0.005215721076669746, 0.005215660144272744, 0.005215599276429068, 0.005215538473070003, 0.005215477734127248, 0.0052154170595323495, 0.005215356449217211, 0.005215295903113336, 0.0052152354211526305, 0.005215175003267039, 0.005215114649388468, 0.005215054359449053, 0.005214994133380922, 0.0052149339711161985, 0.005214873872587229, 0.0052148138377263445, 0.005214753866465873, 0.005214693958738356, 0.0052146341144763434, 0.0052145743336123795, 0.005214514616079407, 0.005214454961809989, 0.005214395370737071, 0.005214335842793406, 0.005214276377912152, 0.005214216976026276, 0.00521415763706894, 0.005214098360973488, 0.005214039147672904, 0.005213979997100768, 0.00521392090919045, 0.005213861883875336, 0.005213802921089177, 0.005213744020765391, 0.005213685182837716, 0.005213626407239965, 0.005213567693905935, 0.005213509042769601, 0.005213450453764953, 0.0052133919268259835, 0.005213333461886894, 0.005213275058881685, 0.005213216717744766, 0.005213158438410561, 0.00521310022081325, 0.00521304206488746, 0.005212983970567767, 0.005212925937788606, 0.0052128679664848205, 0.005212810056590988, 0.005212752208042187, 0.005212694420772997, 0.0052126366947186495, 0.005212579029813982, 0.005212521425994214, 0.005212463883194417, 0.005212406401349997, 0.005212348980395995, 0.005212291620268044, 0.0052122343209014006, 0.005212177082231707, 0.0052121199041944176, 0.005212062786725154, 0.005212005729759825, 0.005211948733234031, 0.005211891797083683, 0.005211834921244793, 0.005211778105653264, 0.005211721350245119, 0.005211664654956466, 0.005211608019723555, 0.005211551444482664, 0.005211494929170262, 0.005211438473722601, 0.005211382078075993, 0.005211325742167098, 0.0052112694659326225, 0.0052112132493092505, 0.0052111570922334805, 0.005211100994642384, 0.005211044956472626, 0.005210988977661332, 0.005210933058145411, 0.005210877197861759, 0.005210821396747661, 0.005210765654740452, 0.005210709971777187, 0.005210654347795422, 0.005210598782732433, 0.005210543276525746, 0.005210487829112916, 0.005210432440431428, 0.005210377110418994, 0.00521032183901354, 0.0052102666261525776, 0.005210211471774277, 0.005210156375816332, 0.005210101338216879, 0.00521004635891386, 0.0052099914378455955, 0.005209936574950043, 0.005209881770165759, 0.0052098270234308495, 0.0052097723346838706, 0.00520971770386317, 0.005209663130907314, 0.0052096086157548275, 0.0052095541583444885, 0.005209499758615063, 0.005209445416505282, 0.00520939113195389, 0.005209336904899889, 0.005209282735282412, 0.005209228623040243, 0.005209174568112744, 0.00520912057043891, 0.005209066629958106, 0.0052090127466096784, 0.005208958920332839, 0.005208905151067165, 0.005208851438752004, 0.005208797783327178, 0.005208744184732066, 0.005208690642906445, 0.005208637157790137, 0.005208583729322887, 0.0052085303574447225, 0.005208477042095424, 0.005208423783215213, 0.005208370580744084, 0.005208317434622029, 0.005208264344789462, 0.005208211311186584, 0.005208158333753818, 0.005208105412431394, 0.005208052547159905, 0.005207999737879736, 0.005207946984531554, 0.005207894287056167, 0.005207841645394171, 0.005207789059486216, 0.005207736529273353, 0.005207684054696368, 0.005207631635696309, 0.005207579272213999, 0.005207526964190677, 0.005207474711567628, 0.005207422514286045, 0.005207370372286971, 0.005207318285512043, 0.0052072662539025365, 0.005207214277399897, 0.005207162355945555, 0.005207110489481362, 0.005207058677948771, 0.005207006921289661, 0.0052069552194456675, 0.00520690357235867, 0.005206851979970516, 0.005206800442223269, 0.005206748959058991, 0.0052066975304197885, 0.0052066461562476985, 0.005206594836485016, 0.005206543571073786, 0.0052064923599567, 0.005206441203075841, 0.005206390100373904, 0.0052063390517933395, 0.005206288057276657, 0.00520623711676653, 0.0052061862302058585, 0.00520613539753713, 0.0052060846187032325, 0.005206033893647061, 0.0052059832223117245, 0.005205932604640097, 0.005205882040575317, 0.005205831530060465, 0.005205781073038638, 0.005205730669453166, 0.005205680319247319, 0.005205630022364438, 0.0052055797787480505, 0.005205529588341658, 0.005205479451088767, 0.005205429366933084, 0.005205379335818146, 0.0052053293576877, 0.005205279432485653, 0.005205229560155702, 0.005205179740641802, 0.0052051299738880945, 0.0052050802598385135, 0.005205030598436969, 0.005204980989627811, 0.005204931433355168, 0.00520488192956338, 0.005204832478196621, 0.005204783079199397, 0.005204733732516081, 0.005204684438091407, 0.00520463519586971, 0.005204586005795555, 0.0052045368678137055, 0.0052044877818691136, 0.0052044387479063346, 0.005204389765870365, 0.0052043408357059125, 0.005204291957358144, 0.005204243130772039, 0.005204194355892764, 0.005204145632665302, 0.005204096961035008, 0.0052040483409470486, 0.0052039997723468245, 0.0052039512551797, 0.005203902789391035, 0.005203854374926434, 0.00520380601173146, 0.0052037576997517, 0.005203709438932973, 0.005203661229220831, 0.005203613070561071, 0.005203564962899501, 0.0052035169061820895, 0.005203468900354847, 0.005203420945363774, 0.005203373041154867, 0.0052033251876743075, 0.005203277384868339, 0.0052032296326833295, 0.005203181931065283, 0.0052031342799608365, 0.005203086679316173, 0.005203039129077944, 0.005202991629192721, 0.00520294417960694, 0.005202896780267217, 0.005202849431120367, 0.0052028021321132035, 0.00520275488319255, 0.005202707684305041, 0.005202660535397893, 0.005202613436417968, 0.005202566387312259, 0.005202519388028014, 0.00520247243851227, 0.005202425538712242, 0.005202378688575397, 0.005202331888048745, 0.005202285137079947, 0.005202238435616224, 0.005202191783605254, 0.005202145180994433, 0.005202098627731468, 0.005202052123763969, 0.005202005669039797, 0.005201959263506411, 0.0052019129071118825, 0.00520186659980403, 0.005201820341530948, 0.00520177413224047, 0.005201727971880692, 0.005201681860399638, 0.0052016357977454, 0.00520158978386643, 0.005201543818710821, 0.005201497902227005, 0.005201452034363289, 0.005201406215068135, 0.005201360444290001, 0.005201314721977602, 0.005201269048079417, 0.005201223422544111, 0.005201177845320346, 0.005201132316356833, 0.0052010868356024455, 0.005201041403006085, 0.005200996018516634, 0.005200950682083169, 0.005200905393654618, 0.005200860153180241, 0.005200814960608975, 0.005200769815890102, 0.0052007247189729015, 0.005200679669806671, 0.005200634668340737, 0.005200589714524609, 0.0052005448083076, 0.005200499949639396, 0.0052004551384695185, 0.00520041037474746, 0.005200365658422965, 0.005200320989445938, 0.005200276367766097, 0.005200231793333167, 0.005200187266097062, 0.005200142786007893, 0.005200098353015395, 0.005200053967069891, 0.005200009628121305, 0.005199965336119977, 0.005199921091016045, 0.005199876892759599, 0.005199832741301231, 0.00519978863659123, 0.005199744578579961, 0.005199700567217927, 0.0051996566024557125, 0.005199612684243843, 0.005199568812532839, 0.0051995249872734805, 0.00519948120841672, 0.00519943747591307, 0.005199393789713488, 0.005199350149768965, 0.005199306556030188, 0.005199263008448359, 0.005199219506974629, 0.005199176051559957, 0.00519913264215551, 0.005199089278712423, 0.005199045961182069, 0.005199002689515817, 0.005198959463665041, 0.0051989162835811035, 0.0051988731492153715, 0.005198830060519423, 0.00519878701744484, 0.00519874401994336, 0.00519870106796658, 0.005198658161466085, 0.005198615300393855, 0.005198572484701658, 0.00519852971434131, 0.005198486989264952, 0.005198444309424391, 0.005198401674771609, 0.005198359085258788, 0.005198316540838136, 0.005198274041461638, 0.005198231587081664, 0.005198189177650659, 0.005198146813120774, 0.005198104493444427, 0.00519806221857402, 0.005198019988461924, 0.005197977803060959, 0.005197935662323542, 0.0051978935662025, 0.005197851514650201, 0.005197809507619659, 0.005197767545063705, 0.005197725626934932, 0.005197683753186366, 0.0051976419237710035, 0.0051976001386418854, 0.005197558397751813, 0.005197516701054212, 0.005197475048501902, 0.00519743344004831, 0.005197391875646668, 0.0051973503552501885, 0.005197308878812098, 0.005197267446286037, 0.005197226057625233, 0.005197184712783307, 0.005197143411713895, 0.005197102154370437, 0.005197060940706578, 0.005197019770675946, 0.005196978644232377, 0.005196937561329705, 0.00519689652192157, 0.005196855525962033, 0.005196814573405171, 0.005196773664204782, 0.005196732798314925, 0.0051966919756896695, 0.0051966511962830515, 0.005196610460049315, 0.005196569766942716, 0.005196529116917516, 0.005196488509928158, 0.005196447945928937, 0.005196407424874084, 0.005196366946718273, 0.0051963265114159645, 0.00519628611892183, 0.00519624576919031, 0.005196205462176304, 0.005196165197834281, 0.005196124976119287, 0.00519608479698583, 0.005196044660388948, 0.0051960045662835215, 0.005195964514624423, 0.005195924505366744, 0.005195884538465366, 0.005195844613875562, 0.005195804731552412, 0.005195764891451204, 0.005195725093527041, 0.0051956853377353816, 0.005195645624031341, 0.005195605952370357, 0.005195566322707962, 0.005195526734999638, 0.005195487189200897, 0.005195447685267206, 0.005195408223154269, 0.005195368802817604, 0.005195329424213096, 0.005195290087296442, 0.005195250792023533, 0.005195211538350081, 0.005195172326232016, 0.005195133155625422, 0.005195094026486198, 0.0051950549387702796, 0.005195015892433952, 0.005194976887433149, 0.0051949379237241815, 0.0051948990012633325, 0.00519486012000676, 0.0051948212799107696, 0.0051947824809318475, 0.005194743723026354, 0.00519470500615079, 0.005194666330261499, 0.00519462769531519, 0.005194589101268395, 0.005194550548077816, 0.005194512035700204, 0.00519447356409209, 0.005194435133210407, 0.005194396743011895, 0.005194358393453446, 0.0051943200844920346, 0.005194281816084589, 0.005194243588188245, 0.00519420540075997, 0.0051941672537568605, 0.005194129147136106, 0.005194091080854788, 0.005194053054870314, 0.005194015069139785, 0.005193977123620577, 0.005193939218270228, 0.005193901353045884, 0.005193863527905301, 0.00519382574280583, 0.0051937879977050315, 0.0051937502925604685, 0.005193712627329861, 0.005193675001970992, 0.005193637416441432, 0.005193599870699128, 0.005193562364701653, 0.005193524898407168, 0.005193487471773419, 0.0051934500847584004, 0.00519341273732005, 0.005193375429416565, 0.005193338161005899, 0.005193300932046252, 0.0051932637424959545, 0.005193226592312996, 0.00519318948145576, 0.005193152409882607, 0.005193115377551742, 0.005193078384421743, 0.005193041430450982, 0.005193004515598017, 0.005192967639821255, 0.005192930803079492, 0.0051928940053310975, 0.005192857246534851, 0.0051928205266495555, 0.00519278384563378, 0.005192747203446562, 0.00519271060004665, 0.005192674035392864, 0.005192637509444161, 0.0051926010221595926, 0.0051925645734981155, 0.005192528163418754, 0.005192491791880684, 0.005192455458843111, 0.005192419164265054, 0.005192382908105894, 0.005192346690324836, 0.005192310510881309, 0.005192274369734708, 0.005192238266844258, 0.005192202202169537, 0.005192166175669973, 0.005192130187305184, 0.0051920942370345695, 0.0051920583248179705, 0.005192022450615001, 0.005191986614385467, 0.005191950816088988, 0.0051919150556853635, 0.005191879333134449, 0.005191843648396052, 0.0051918080014302015, 0.005191772392196926, 0.0051917368206560125, 0.005191701286767739, 0.005191665790492106, 0.00519163033178939, 0.005191594910619577, 0.0051915595269428965, 0.005191524180719581, 0.0051914888719101, 0.005191453600474666, 0.005191418366373704, 0.005191383169567895, 0.005191348010017438, 0.005191312887682791, 0.0051912778025247925, 0.005191242754503891, 0.005191207743580523, 0.005191172769715756, 0.0051911378328699884, 0.005191102933004099, 0.00519106807007897, 0.00519103324405542, 0.005190998454894297, 0.005190963702556661, 0.005190928987003365, 0.0051908943081954515, 0.0051908596660939985, 0.005190825060660055, 0.00519079049185489, 0.005190755959639547, 0.005190721463975309, 0.005190687004823417, 0.005190652582145337, 0.005190618195902135, 0.0051905838460553, 0.005190549532566481, 0.005190515255396937, 0.00519048101450814, 0.00519044680986177, 0.005190412641419312, 0.005190378509142438, 0.005190344412992792, 0.005190310352932273, 0.005190276328922343, 0.005190242340925099, 0.00519020838890221, 0.005190174472815566, 0.005190140592627026, 0.005190106748298695, 0.005190072939792466, 0.005190039167070386, 0.005190005430094563, 0.005189971728827088, 0.005189938063230257, 0.005189904433266146, 0.005189870838897046, 0.005189837280085244, 0.005189803756793062, 0.005189770268982738, 0.005189736816616817, 0.005189703399657568, 0.005189670018067515, 0.00518963667180932, 0.005189603360845516, 0.005189570085138606, 0.005189536844651253, 0.005189503639346223, 0.005189470469186166, 0.0051894373341338056, 0.005189404234152029, 0.00518937116920357, 0.005189338139251356, 0.00518930514425848, 0.005189272184187625, 0.005189239259001929, 0.005189206368664307, 0.005189173513138058, 0.005189140692386113, 0.00518910790637156, 0.005189075155057731, 0.0051890424384077455, 0.005189009756385151, 0.005188977108953039, 0.0051889444960747655, 0.005188911917713594, 0.00518887937383309, 0.005188846864396783, 0.00518881438936818, 0.005188781948710629, 0.005188749542387842, 0.005188717170363349, 0.005188684832600883, 0.00518865252906418, 0.0051886202597169594, 0.005188588024523008, 0.00518855582344601, 0.005188523656449912, 0.005188491523498647, 0.005188459424556177, 0.0051884273595864125, 0.005188395328553303, 0.00518836333142081, 0.005188331368153246, 0.005188299438714575, 0.005188267543068949, 0.005188235681180471, 0.005188203853013521, 0.005188172058532462, 0.005188140297701399, 0.005188108570484711, 0.005188076876846976, 0.005188045216752515, 0.005188013590165681, 0.005187981997051013, 0.0051879504373731206, 0.005187918911096508, 0.005187887418185747, 0.00518785595860562, 0.005187824532320664, 0.005187793139295856, 0.005187761779495733, 0.005187730452885071, 0.005187699159428816, 0.005187667899091773, 0.005187636671838865, 0.005187605477635094, 0.0051875743164454076, 0.005187543188234778, 0.005187512092968393, 0.005187481030611221, 0.00518745000112841, 0.005187419004485149, 0.005187388040646601, 0.00518735710957816, 0.005187326211245004, 0.005187295345612271, 0.005187264512645586, 0.005187233712310333, 0.005187202944571855, 0.005187172209395566, 0.005187141506747019, 0.005187110836591818, 0.005187080198895321, 0.005187049593623351, 0.00518701902074147, 0.005186988480215494, 0.0051869579720109854, 0.005186927496093732, 0.0051868970524295505, 0.005186866640984398, 0.0051868362617238815, 0.005186805914614203, 0.005186775599620942, 0.00518674531671031, 0.0051867150658483005, 0.005186684847000901, 0.005186654660134331, 0.00518662450521459, 0.005186594382207849, 0.005186564291080337, 0.005186534231798243, 0.005186504204327769, 0.005186474208635331, 0.005186444244687144, 0.005186414312449589, 0.005186384411889086, 0.0051863545429722425, 0.005186324705665274, 0.005186294899934765, 0.005186265125747349, 0.005186235383069648, 0.005186205671868257, 0.005186175992109795, 0.005186146343760897, 0.005186116726788351, 0.005186087141158803, 0.005186057586839241, 0.005186028063796299, 0.0051859985719970095, 0.005185969111408179, 0.005185939681996815, 0.005185910283729774, 0.005185880916574259, 0.005185851580497108, 0.005185822275465545, 0.005185793001446597, 0.005185763758407474, 0.00518573454631522, 0.005185705365137276, 0.005185676214840643, 0.0051856470953927855, 0.00518561800676093, 0.005185588948912499, 0.005185559921814739, 0.005185530925435272, 0.005185501959741525, 0.005185473024700749, 0.005185444120280789, 0.005185415246449083, 0.0051853864031732744, 0.005185357590420787, 0.0051853288081594884, 0.005185300056356992, 0.005185271334981184, 0.00518524264399967, 0.005185213983380319, 0.005185185353090958, 0.005185156753099426, 0.005185128183373596, 0.005185099643881539, 0.005185071134591062, 0.005185042655470246, 0.005185014206487311, 0.005184985787610158, 0.00518495739880679, 0.005184929040045516, 0.005184900711294569, 0.0051848724125219845, 0.0051848441436960395, 0.005184815904784995, 0.005184787695757312, 0.005184759516581249, 0.0051847313672252465, 0.0051847032476576025, 0.005184675157846763, 0.005184647097761179, 0.005184619067369545, 0.005184591066640299, 0.005184563095541917, 0.005184535154043272, 0.005184507242112849, 0.005184479359719283, 0.005184451506831284, 0.005184423683417704, 0.005184395889447197, 0.005184368124888658, 0.005184340389710948, 0.005184312683882954, 0.005184285007373541, 0.005184257360151622, 0.005184229742186253, 0.005184202153446511, 0.005184174593901264, 0.0051841470635196054, 0.005184119562270796, 0.005184092090123755, 0.005184064647047926, 0.005184037233012221, 0.005184009847986134, 0.005183982491938929, 0.005183955164839691, 0.005183927866657925, 0.00518390059736289, 0.0051838733569241156, 0.005183846145311073, 0.005183818962493025, 0.005183791808439702, 0.005183764683120398, 0.005183737586504776, 0.00518371051856255, 0.005183683479263227, 0.005183656468576492, 0.005183629486472038, 0.005183602532919577, 0.005183575607888991, 0.005183548711349959, 0.005183521843272236, 0.005183495003625683, 0.005183468192380427, 0.005183441409506132, 0.0051834146549727496, 0.005183387928750362, 0.005183361230809064, 0.005183334561118793, 0.005183307919649662, 0.005183281306371736, 0.0051832547212551355, 0.0051832281642699655, 0.005183201635386563, 0.005183175134575253, 0.00518314866180611, 0.005183122217049473, 0.005183095800275652, 0.005183069411455123, 0.005183043050558255, 0.005183016717555327, 0.005182990412417075, 0.0051829641351138125, 0.0051829378856160565, 0.005182911663894336, 0.005182885469919181, 0.0051828593036613016, 0.0051828331650914175, 0.005182807054180073, 0.005182780970897967, 0.0051827549152158306, 0.005182728887104604, 0.005182702886535, 0.0051826769134777385, 0.00518265096790375, 0.005182625049783958, 0.005182599159089326, 0.005182573295790543, 0.005182547459858973, 0.005182521651265322, 0.005182495869980739, 0.005182470115976378, 0.005182444389223359, 0.005182418689692609, 0.0051823930173554526, 0.00518236737218327, 0.005182341754146932, 0.005182316163217843, 0.005182290599367306, 0.005182265062566662, 0.005182239552787284, 0.005182214070000679, 0.005182188614178031, 0.005182163185290828, 0.0051821377833106514, 0.005182112408208846, 0.005182087059956956, 0.005182061738526735, 0.005182036443889715, 0.005182011176017419, 0.005181985934881455, 0.005181960720453749, 0.005181935532705833, 0.005181910371609475, 0.005181885237136433, 0.005181860129258452, 0.005181835047947481, 0.005181809993175295, 0.0051817849649140315, 0.00518175996313524, 0.0051817349878110885, 0.0051817100389135555, 0.005181685116414773, 0.005181660220286494, 0.005181635350500888, 0.005181610507030139, 0.005181585689846385, 0.005181560898921795, 0.00518153613422854, 0.005181511395738773, 0.005181486683424855, 0.00518146199725896, 0.005181437337213488, 0.005181412703260772, 0.00518138809537297, 0.0051813635135226745, 0.00518133895768223, 0.0051813144278242225, 0.005181289923921019, 0.005181265445945184, 0.005181240993869304, 0.005181216567665935, 0.005181192167307475, 0.005181167792766912, 0.00518114344401657, 0.005181119121029252, 0.005181094823777745, 0.005181070552234839, 0.005181046306373077, 0.0051810220861654615, 0.005180997891584763, 0.005180973722603765, 0.005180949579195442, 0.005180925461332782, 0.005180901368988564, 0.005180877302135993, 0.0051808532607478495, 0.005180829244797317, 0.005180805254257355, 0.005180781289101174, 0.005180757349301771, 0.005180733434832293, 0.005180709545665987, 0.005180685681775988, 0.005180661843135738, 0.005180638029718175, 0.005180614241496714, 0.005180590478444773, 0.005180566740535722, 0.005180543027742757, 0.005180519340039495, 0.0051804956773991075, 0.005180472039795184, 0.005180448427201335, 0.005180424839590952, 0.005180401276937661, 0.005180377739214832, 0.005180354226396271, 0.005180330738455607, 0.005180307275366391, 0.0051802838371022486, 0.005180260423637004, 0.005180237034944419, 0.005180213670998144, 0.0051801903317721465, 0.005180167017240054, 0.005180143727375872, 0.005180120462153387, 0.005180097221546633, 0.005180074005529398, 0.0051800508140757255, 0.005180027647159591, 0.005180004504754811, 0.0051799813868356045, 0.00517995829337618, 0.005179935224350546, 0.005179912179732752, 0.005179889159496994, 0.0051798661636174685, 0.005179843192068394, 0.005179820244823988, 0.0051797973218584694, 0.005179774423146073, 0.005179751548661204, 0.005179728698378302, 0.005179705872271564, 0.00517968307031563, 0.005179660292484693, 0.005179637538753391, 0.0051796148090961355, 0.005179592103487371, 0.005179569421901711, 0.005179546764313572, 0.005179524130697589, 0.0051795015210286, 0.005179478935281016, 0.005179456373429458, 0.00517943383544878, 0.0051794113213138, 0.0051793888309991385, 0.005179366364479446, 0.005179343921729747, 0.005179321502724674, 0.005179299107439266, 0.005179276735848334, 0.005179254387926726, 0.005179232063649463, 0.005179209762991607, 0.005179187485927967, 0.005179165232433598, 0.005179143002483521, 0.005179120796053, 0.0051790986131168325, 0.00517907645365029, 0.0051790543176285925, 0.005179032205026823, 0.0051790101158201715, 0.005178988049983925, 0.00517896600749329, 0.005178943988323703, 0.005178921992450252, 0.005178900019848357, 0.005178878070493474, 0.005178856144360831, 0.005178834241425884, 0.005178812361664072, 0.005178790505050863, 0.005178768671561881, 0.005178746861172407, 0.0051787250738580684, 0.005178703309594519, 0.005178681568357431, 0.005178659850122209, 0.005178638154864549, 0.005178616482560075, 0.005178594833184686, 0.005178573206713991, 0.005178551603123656, 0.00517853002238954, 0.005178508464487504, 0.005178486929393226, 0.005178465417082743, 0.005178443927531722, 0.005178422460716211, 0.005178401016612059, 0.005178379595195334, 0.005178358196441896, 0.005178336820327832, 0.005178315466828966, 0.005178294135921607, 0.005178272827581772, 0.005178251541785558, 0.005178230278509008, 0.005178209037728395, 0.005178187819419816, 0.0051781666235595014, 0.00517814545012374, 0.00517812429908879, 0.0051781031704309045, 0.005178082064126364, 0.005178060980151449, 0.005178039918482624, 0.005178018879096149, 0.005177997861968516, 0.005177976867076196, 0.0051779558943956475, 0.005177934943903368, 0.005177914015575802, 0.005177893109389434, 0.0051778722253209555, 0.0051778513633468455, 0.005177830523443755, 0.005177809705588378, 0.005177788909757192, 0.005177768135927085, 0.005177747384074505, 0.005177726654176379, 0.005177705946209557, 0.005177685260150729, 0.00517766459597658, 0.005177643953663974, 0.005177623333189824, 0.005177602734530985, 0.005177582157664356, 0.005177561602567042, 0.00517754106921569, 0.005177520557587613, 0.005177500067659471, 0.0051774795994085614, 0.005177459152811782, 0.0051774387278462385, 0.005177418324489001, 0.00517739794271715, 0.005177377582508003, 0.005177357243838623, 0.005177336926686316, 0.005177316631028166, 0.005177296356841473, 0.005177276104103335, 0.005177255872791234, 0.005177235662882495, 0.00517721547435438, 0.0051771953071844045, 0.0051771751613498606, 0.005177155036828036, 0.005177134933596444, 0.005177114851632568, 0.0051770947909139204, 0.00517707475141798, 0.005177054733122278, 0.0051770347360044775, 0.0051770147600419215, 0.005176994805212468, 0.0051769748714936645, 0.005176954958862984, 0.0051769350672983515, 0.0051769151967772644, 0.0051768953472776085, 0.005176875518777115, 0.00517685571125347, 0.005176835924684386, 0.005176816159047774, 0.005176796414321562, 0.0051767766904834275, 0.005176756987511507, 0.005176737305383471, 0.005176717644077481, 0.005176698003571214, 0.005176678383842765, 0.005176658784870286, 0.00517663920663168, 0.005176619649105043, 0.005176600112268294, 0.005176580596099752, 0.005176561100577332, 0.005176541625679359, 0.005176522171383921, 0.00517650273766918, 0.005176483324513409, 0.005176463931894758, 0.0051764445597915305, 0.005176425208182055, 0.005176405877044646, 0.005176386566357412, 0.005176367276098879, 0.005176348006247571, 0.005176328756781605, 0.0051763095276795, 0.005176290318919803, 0.005176271130480806, 0.005176251962341063, 0.005176232814479276, 0.005176213686873786, 0.005176194579503121, 0.005176175492346011, 0.0051761564253809495, 0.005176137378586472, 0.005176118351941324, 0.005176099345424225, 0.005176080359013741, 0.005176061392688745, 0.0051760424464278015, 0.005176023520209838, 0.005176004614013561, 0.0051759857278177454, 0.005175966861601283, 0.005175948015342926, 0.005175929189021601, 0.005175910382616257, 0.005175891596105822, 0.00517587282946923, 0.0051758540826853956, 0.00517583535573329, 0.005175816648591819, 0.005175797961240135, 0.005175779293657371, 0.005175760645822477, 0.005175742017714599, 0.005175723409312835, 0.005175704820596371, 0.0051756862515443215, 0.005175667702135861, 0.0051756491723500995, 0.005175630662166382, 0.005175612171564043, 0.005175593700522239, 0.00517557524902032, 0.005175556817037412, 0.0051755384045531075, 0.005175520011546705, 0.0051755016379975574, 0.005175483283885009, 0.005175464949188614, 0.00517544663388774, 0.005175428337961702, 0.005175410061390276, 0.0051753918041527736, 0.005175373566228782, 0.005175355347597837, 0.005175337148239696, 0.005175318968133698, 0.0051753008072596175, 0.005175282665596974, 0.00517526454312555, 0.005175246439825099, 0.005175228355675154, 0.005175210290655491, 0.005175192244746061, 0.00517517421792642, 0.005175156210176306, 0.005175138221475677, 0.0051751202518043014, 0.0051751023011421355, 0.005175084369468956, 0.005175066456764714, 0.005175048563009148, 0.005175030688182411, 0.005175012832264484, 0.005174994995235129, 0.0051749771770745, 0.005174959377762767, 0.005174941597279705, 0.005174923835605621, 0.005174906092720541, 0.005174888368604416, 0.005174870663237588, 0.005174852976600039, 0.005174835308672122, 0.005174817659433823, 0.005174800028865479, 0.005174782416947283, 0.005174764823659587, 0.005174747248982561, 0.005174729692896593, 0.005174712155382044, 0.0051746946364190525, 0.005174677135988243, 0.005174659654069916, 0.005174642190644301, 0.005174624745691946, 0.005174607319193445, 0.005174589911128939, 0.00517457252147924, 0.005174555150224679, 0.005174537797345849, 0.0051745204628233215, 0.005174503146637479, 0.005174485848769111, 0.005174468569198754, 0.005174451307907007, 0.00517443406487464, 0.005174416840082239, 0.005174399633510595, 0.005174382445140264, 0.005174365274952031, 0.00517434812292667, 0.005174330989044981, 0.005174313873287739, 0.005174296775635894, 0.005174279696070072, 0.005174262634571222, 0.0051742455911201355, 0.005174228565697831, 0.005174211558285249, 0.005174194568863184, 0.00517417759741263, 0.005174160643914763, 0.005174143708350346, 0.005174126790700397, 0.0051741098909460995, 0.005174093009068428, 0.005174076145048392, 0.00517405929886736, 0.005174042470506128, 0.005174025659946073, 0.0051740088671682035, 0.005173992092153677, 0.0051739753348837144, 0.005173958595339705, 0.005173941873502818, 0.005173925169354286, 0.005173908482875254, 0.005173891814047136, 0.00517387516285111, 0.0051738585292687815, 0.005173841913281376, 0.0051738253148702375, 0.005173808734016793, 0.005173792170702438, 0.0051737756249085436, 0.005173759096616743, 0.005173742585808393, 0.005173726092464904, 0.0051737096165680885, 0.005173693158099141, 0.005173676717039865, 0.005173660293371646, 0.00517364388707627, 0.005173627498135176, 0.005173611126530139, 0.005173594772242758, 0.0051735784352546525, 0.005173562115547401, 0.005173545813103035, 0.005173529527902947, 0.005173513259929128, 0.005173497009163199, 0.005173480775587151, 0.005173464559182605, 0.005173448359931348, 0.005173432177815386, 0.005173416012816516, 0.005173399864916582, 0.005173383734097572, 0.005173367620341284, 0.005173351523629722, 0.0051733354439449175, 0.005173319381268677, 0.005173303335583186, 0.005173287306870257, 0.0051732712951121146, 0.005173255300290766, 0.005173239322388224, 0.005173223361386711, 0.005173207417268229, 0.005173191490014804, 0.005173175579608816, 0.005173159686032301, 0.00517314380926748, 0.005173127949296569, 0.005173112106101766, 0.005173096279665279, 0.00517308046996955, 0.005173064676996772, 0.005173048900729182, 0.005173033141149199, 0.005173017398239016, 0.0051730016719810515, 0.005172985962357741, 0.0051729702693513145, 0.005172954592944364, 0.005172938933119334, 0.005172923289858648, 0.005172907663144705, 0.00517289205295991, 0.00517287645928691, 0.005172860882108339, 0.00517284532140641, 0.005172829777163919, 0.005172814249363511, 0.005172798737987615, 0.005172783243018853, 0.005172767764440054, 0.005172752302233645, 0.005172736856382425, 0.005172721426869046, 0.005172706013676127, 0.005172690616786478, 0.005172675236182952, 0.005172659871848165, 0.005172644523764952, 0.005172629191916149, 0.005172613876284554, 0.005172598576853026, 0.005172583293604369, 0.005172568026521429, 0.005172552775587243, 0.005172537540784438, 0.005172522322096248, 0.005172507119505496, 0.005172491932995002, 0.005172476762548056, 0.0051724616081474245, 0.0051724464697761865, 0.00517243134741733, 0.005172416241053925, 0.005172401150669192, 0.005172386076245999, 0.005172371017767545, 0.00517235597521708, 0.005172340948577624, 0.005172325937832449, 0.005172310942964569, 0.005172295963957203, 0.005172281000793612, 0.005172266053457039, 0.005172251121930737, 0.005172236206197907, 0.005172221306242003, 0.005172206422046097, 0.005172191553593592, 0.005172176700867944, 0.005172161863852384, 0.005172147042530374, 0.005172132236885357, 0.005172117446900547, 0.00517210267255941, 0.0051720879138455874, 0.005172073170742304, 0.005172058443233229, 0.005172043731301817, 0.0051720290349314794, 0.005172014354105894, 0.005171999688808478, 0.005171985039022689, 0.005171970404732391, 0.005171955785921012, 0.005171941182572196, 0.005171926594669605, 0.005171912022196899, 0.005171897465137703, 0.005171882923475864, 0.005171868397194865, 0.005171853886278516, 0.005171839390710676, 0.005171824910475019, 0.005171810445555194, 0.005171795995935049, 0.00517178156159863, 0.005171767142529366, 0.005171752738711355, 0.0051717383501284405, 0.005171723976764465, 0.0051717096186032555, 0.0051716952756289195, 0.005171680947825293, 0.0051716666351762095, 0.005171652337665762, 0.005171638055277779, 0.005171623787996534, 0.00517160953580586, 0.005171595298689619, 0.0051715810766320815, 0.005171566869617318, 0.005171552677629391, 0.005171538500652332, 0.005171524338670212, 0.005171510191667288, 0.005171496059627608, 0.0051714819425354676, 0.005171467840374901, 0.0051714537531301645, 0.005171439680785534, 0.005171425623325288, 0.00517141158073344, 0.005171397552994512, 0.005171383540092527, 0.0051713695420119565, 0.005171355558737068, 0.005171341590252361, 0.005171327636541838, 0.005171313697590197, 0.005171299773381711, 0.0051712858639006406, 0.005171271969131628, 0.005171258089058966, 0.00517124422366713, 0.005171230372940554, 0.005171216536863739, 0.005171202715421126, 0.005171188908597201, 0.005171175116376645, 0.005171161338743894, 0.005171147575683649, 0.005171133827180378, 0.005171120093218714, 0.0051711063737831615, 0.005171092668858597, 0.005171078978429487, 0.0051710653024804884, 0.005171051640996278, 0.005171037993961561, 0.005171024361361178, 0.00517101074317961, 0.0051709971394017255, 0.005170983550012414, 0.005170969974996326, 0.00517095641433816, 0.005170942868022797, 0.005170929336035078, 0.005170915818359918, 0.0051709023149819795, 0.005170888825886337, 0.005170875351057653, 0.005170861890481031, 0.005170848444141337, 0.005170835012023443, 0.005170821594112432, 0.005170808190393213, 0.00517079480085063, 0.0051707814254697716, 0.005170768064235716, 0.005170754717133342, 0.005170741384147937, 0.005170728065264397, 0.005170714760467766, 0.0051707014697431825, 0.005170688193075887, 0.00517067493045077, 0.0051706616818531165, 0.005170648447268026, 0.005170635226680757, 0.005170622020076394, 0.005170608827440253, 0.005170595648757585, 0.005170582484013498, 0.0051705693331932775, 0.005170556196282191, 0.005170543073265539, 0.005170529964128614, 0.005170516868856678, 0.005170503787435049, 0.005170490719849207, 0.0051704776660844295, 0.0051704646261260066, 0.005170451599959416, 0.005170438587569981, 0.00517042558894318, 0.005170412604064506, 0.005170399632919428, 0.005170386675493242, 0.005170373731771659, 0.005170360801739946, 0.00517034788538382, 0.005170334982688751, 0.005170322093640233, 0.005170309218223782, 0.005170296356425068, 0.005170283508229797, 0.005170270673623275, 0.005170257852591382, 0.005170245045119614, 0.005170232251193646, 0.005170219470799232, 0.0051702067039219955, 0.005170193950547677, 0.005170181210661762, 0.005170168484250137, 0.005170155771298716, 0.005170143071792992, 0.005170130385718882, 0.0051701177130622335, 0.005170105053808584, 0.005170092407944046, 0.005170079775454286, 0.0051700671563252205, 0.005170054550542757, 0.005170041958092554, 0.005170029378960742, 0.005170016813133045, 0.005170004260595539, 0.005169991721334132, 0.005169979195334703, 0.005169966682583183, 0.005169954183065647, 0.005169941696768034, 0.005169929223676432, 0.005169916763776947, 0.005169904317055473, 0.0051698918834981004, 0.005169879463090963, 0.00516986705581997, 0.005169854661671394, 0.005169842280631173, 0.005169829912685585, 0.005169817557820768, 0.005169805216022802, 0.0051697928872780335, 0.005169780571572525, 0.005169768268892395, 0.005169755979223977, 0.005169743702553556, 0.005169731438867238, 0.0051697191881513544, 0.0051697069503921856, 0.005169694725576055, 0.00516968251368928, 0.005169670314718154, 0.0051696581286488, 0.005169645955467947, 0.005169633795161659, 0.00516962164771649, 0.005169609513118746, 0.005169597391354727, 0.005169585282410933, 0.005169573186273922, 0.005169561102930176, 0.005169549032366028, 0.005169536974567956, 0.005169524929522296, 0.005169512897215761, 0.0051695008776348715, 0.005169488870766162, 0.005169476876596111, 0.00516946489511145, 0.005169452926298496, 0.005169440970143967, 0.005169429026634566, 0.0051694170957568356, 0.005169405177497284, 0.005169393271842817, 0.005169381378779955, 0.005169369498295236, 0.005169357630375573, 0.005169345775007466, 0.0051693339321778435, 0.005169322101873437, 0.005169310284080756, 0.005169298478786713, 0.005169286685978246, 0.005169274905641874, 0.005169263137764513, 0.005169251382333086, 0.005169239639334317, 0.005169227908754925, 0.005169216190581839, 0.00516920448480217, 0.005169192791402462, 0.005169181110369833, 0.005169169441691185, 0.005169157785353474, 0.005169146141343412, 0.005169134509648097, 0.005169122890254682, 0.00516911128314991, 0.0051690996883208915, 0.005169088105754526, 0.005169076535437977, 0.005169064977358347, 0.0051690534315023875, 0.005169041897857396, 0.005169030376410529, 0.005169018867148687, 0.005169007370059026, 0.00516899588512865, 0.0051689844123447, 0.005168972951694498, 0.005168961503164983, 0.0051689500667434695, 0.005168938642417106, 0.0051689272301730415, 0.0051689158299985695, 0.005168904441880838, 0.00516889306580717, 0.005168881701764708, 0.005168870349740766, 0.005168859009722682, 0.005168847681697818, 0.0051688363656532685, 0.005168825061576577, 0.0051688137694548995, 0.00516880248927574, 0.005168791221026452, 0.005168779964694381, 0.005168768720266827, 0.005168757487731347, 0.005168746267075288, 0.0051687350582859636, 0.005168723861350918, 0.0051687126762576755, 0.005168701502993615, 0.005168690341546231, 0.005168679191903082, 0.005168668054051702, 0.00516865692797961, 0.005168645813674138, 0.005168634711123048, 0.005168623620313886, 0.005168612541234191, 0.0051686014738714795, 0.005168590418213499, 0.0051685793742478, 0.0051685683419619086, 0.005168557321343594, 0.005168546312380557, 0.005168535315060349, 0.005168524329370713, 0.005168513355299406, 0.005168502392833976, 0.005168491441962147, 0.0051684805026718855, 0.005168469574950703, 0.0051684586587865495, 0.005168447754166984, 0.005168436861079939, 0.005168425979513156, 0.005168415109454388, 0.005168404250891577, 0.005168393403812442, 0.00516838256820496, 0.005168371744057076, 0.005168360931356536, 0.005168350130091056, 0.005168339340248821, 0.005168328561817571, 0.005168317794785429, 0.005168307039140157, 0.005168296294869697, 0.005168285561962009, 0.005168274840405253, 0.0051682641301873215, 0.005168253431296019, 0.005168242743719684, 0.005168232067446227, 0.005168221402463638, 0.005168210748759859, 0.0051682001063232405, 0.005168189475141742, 0.005168178855203285, 0.00516816824649624, 0.005168157649008552, 0.005168147062728377, 0.005168136487643853, 0.0051681259237431705, 0.005168115371014458, 0.005168104829446064, 0.005168094299025954, 0.005168083779742458, 0.005168073271583738, 0.005168062774538174, 0.0051680522885938695, 0.005168041813739016, 0.005168031349961959, 0.0051680208972510544, 0.00516801045559446, 0.0051680000249805175, 0.005167989605397601, 0.005167979196834062, 0.005167968799278069, 0.005167958412718143, 0.005167948037142677, 0.005167937672539814, 0.005167927318898091, 0.00516791697620611, 0.005167906644451973, 0.005167896323624258, 0.005167886013711362, 0.005167875714701802, 0.005167865426583943, 0.0051678551493463815, 0.0051678448829776255, 0.005167834627466064, 0.005167824382800237, 0.005167814148968739, 0.005167803925959912, 0.005167793713762495, 0.005167783512365087, 0.00516777332175604, 0.00516776314192409, 0.005167752972857824, 0.005167742814545796, 0.005167732666976744, 0.005167722530139275, 0.005167712404021915, 0.005167702288613448, 0.005167692183902433, 0.005167682089877648, 0.00516767200652785, 0.005167661933841589, 0.005167651871807638, 0.0051676418204147576, 0.005167631779651728, 0.005167621749507297, 0.005167611729970243, 0.005167601721029124, 0.005167591722672919, 0.005167581734890379, 0.005167571757670452, 0.005167561791001746, 0.005167551834873196, 0.00516754188927378, 0.00516753195419228, 0.005167522029617471, 0.0051675121155382855, 0.005167502211943719, 0.005167492318822536, 0.005167482436163696, 0.005167472563956174, 0.005167462702188957, 0.005167452850850793, 0.005167443009930855, 0.0051674331794179015, 0.005167423359301123, 0.005167413549569499, 0.005167403750211972, 0.0051673939612177375, 0.005167384182575736, 0.005167374414274964, 0.005167364656304392, 0.005167354908653216, 0.005167345171310582, 0.00516733544426544, 0.005167325727507009, 0.005167316021024434, 0.005167306324806716, 0.005167296638842995, 0.005167286963122452, 0.005167277297634277, 0.0051672676423676536, 0.005167257997311727, 0.005167248362455883, 0.005167238737789109, 0.005167229123300754, 0.005167219518980045, 0.005167209924816128, 0.0051672003407981565, 0.00516719076691554, 0.005167181203157626, 0.005167171649513614, 0.005167162105972881, 0.005167152572524613, 0.005167143049158368, 0.005167133535863127, 0.005167124032628465, 0.0051671145394437765, 0.005167105056298251, 0.005167095583181428, 0.0051670861200827384, 0.005167076666991517, 0.005167067223896963, 0.005167057790788854, 0.005167048367656358, 0.005167038954489075, 0.005167029551276392, 0.0051670201580078755, 0.0051670107746728915, 0.0051670014012608345, 0.005166992037761498, 0.005166982684164058, 0.005166973340458303, 0.005166964006633611, 0.005166954682679778, 0.005166945368586182, 0.005166936064342377, 0.0051669267699379785, 0.0051669174853625445, 0.0051669082106056835, 0.005166898945656954, 0.005166889690505964, 0.005166880445142507, 0.005166871209556137, 0.005166861983736649, 0.005166852767673452, 0.005166843561356509, 0.005166834364775228, 0.0051668251779195635, 0.005166816000779105, 0.005166806833343477, 0.005166797675602623, 0.005166788527546173, 0.005166779389163868, 0.0051667702604455265, 0.005166761141380703, 0.005166752031959425, 0.005166742932171472, 0.005166733842006641, 0.005166724761454703, 0.005166715690505665, 0.005166706629149096, 0.005166697577374986, 0.005166688535173139, 0.0051666795025335395, 0.005166670479445981, 0.005166661465900425, 0.005166652461886699, 0.005166643467394785, 0.005166634482414666, 0.005166625506936154, 0.005166616540949218, 0.005166607584443871, 0.005166598637410098, 0.005166589699837686, 0.0051665807717168315, 0.005166571853037503, 0.005166562943789743, 0.005166554043963485, 0.0051665451535487655, 0.005166536272535787, 0.0051665274009143145, 0.005166518538674763, 0.005166509685806913, 0.005166500842300967, 0.005166492008147119, 0.00516648318333537, 0.0051664743678556755, 0.005166465561698485, 0.005166456764853762, 0.005166447977311736, 0.0051664391990623665, 0.005166430430096064, 0.005166421670402807, 0.0051664129199728214, 0.00516640417879649, 0.005166395446863836, 0.005166386724165212, 0.005166378010690876, 0.0051663693064309705, 0.005166360611375729, 0.005166351925515324, 0.005166343248840154, 0.005166334581340635, 0.005166325923006963, 0.005166317273829347, 0.005166308633798167, 0.005166300002903625, 0.0051662913811363455, 0.005166282768486509, 0.005166274164944299, 0.005166265570500346, 0.005166256985144834, 0.005166248408868386, 0.005166239841661192, 0.005166231283513658, 0.005166222734416389, 0.005166214194359557, 0.005166205663333803, 0.005166197141329506, 0.005166188628337079, 0.005166180124347111, 0.005166171629349827, 0.005166163143336029, 0.005166154666295882, 0.005166146198220222, 0.005166137739099466, 0.00516612928892399, 0.005166120847684428, 0.005166112415371368, 0.005166103991975399, 0.005166095577486975, 0.005166087171896651, 0.005166078775195049, 0.0051660703873729905, 0.005166062008420867, 0.005166053638329283, 0.005166045277088865, 0.005166036924690375, 0.00516602858112428, 0.0051660202463813445, 0.0051660119204522065, 0.005166003603327654, 0.005165995294998297, 0.005165986995454732, 0.005165978704687789, 0.005165970422688267, 0.00516596214944678, 0.0051659538849539366, 0.005165945629200524, 0.005165937382177364, 0.005165929143875279, 0.005165920914285063, 0.0051659126933973395, 0.005165904481203123, 0.005165896277693008, 0.0051658880828580065, 0.005165879896688746, 0.005165871719176229, 0.005165863550311046, 0.005165855390084244, 0.005165847238486814, 0.005165839095509366, 0.005165830961142928, 0.005165822835378291, 0.005165814718206506, 0.005165806609618327, 0.0051657985096048185, 0.005165790418156765, 0.005165782335265188, 0.005165774260921097, 0.005165766195115324, 0.005165758137838864, 0.005165750089082743, 0.0051657420488379685, 0.0051657340170955714, 0.005165725993846348, 0.005165717979081509, 0.005165709972792078, 0.005165701974968883, 0.005165693985603111, 0.005165686004685818, 0.005165678032208197, 0.0051656700681610495, 0.005165662112535619, 0.005165654165323108, 0.005165646226514543, 0.005165638296100927, 0.005165630374073476, 0.005165622460423226, 0.005165614555141391, 0.005165606658218955, 0.005165598769647393, 0.005165590889417683, 0.005165583017521048, 0.005165575153948543, 0.005165567298691552, 0.005165559451741071, 0.005165551613088557, 0.00516554378272503, 0.005165535960641719, 0.005165528146830008, 0.005165520341281127, 0.005165512543986329, 0.005165504754936792, 0.005165496974123748, 0.005165489201538623, 0.005165481437172641, 0.005165473681017251, 0.005165465933063616, 0.005165458193303201, 0.005165450461727208, 0.005165442738327077, 0.005165435023094024, 0.005165427316019471, 0.005165419617094843, 0.005165411926311546, 0.0051654042436608165, 0.005165396569134083, 0.005165388902722961, 0.0051653812444186825, 0.005165373594212644, 0.005165365952096288, 0.005165358318061251, 0.005165350692098759, 0.005165343074200426, 0.005165335464357667, 0.005165327862561928, 0.00516532026880461, 0.005165312683077356, 0.005165305105371603, 0.005165297535678966, 0.005165289973990857, 0.005165282420298923, 0.005165274874594568, 0.00516526733686943, 0.005165259807115121, 0.005165252285323101, 0.0051652447714849664, 0.0051652372655923715, 0.005165229767636922, 0.005165222277610072, 0.0051652147955036296, 0.005165207321309003, 0.005165199855018047, 0.005165192396622206, 0.005165184946113285, 0.005165177503482913, 0.005165170068722505, 0.005165162641824136, 0.0051651552227791895, 0.0051651478115795285, 0.005165140408216771, 0.005165133012682735, 0.005165125624969054, 0.005165118245067381, 0.005165110872969506, 0.005165103508667286, 0.005165096152152346, 0.00516508880341655, 0.005165081462451492, 0.005165074129249219, 0.005165066803801347, 0.005165059486099717, 0.005165052176135972, 0.005165044873902123, 0.005165037579390024, 0.00516503029259132, 0.005165023013498005, 0.005165015742101929, 0.005165008478394928, 0.005165001222368829, 0.005164993974015459, 0.005164986733326858, 0.005164979500294869, 0.0051649722749113405, 0.005164965057168088, 0.005164957847057155, 0.005164950644570567, 0.005164943449700136, 0.00516493626243772, 0.005164929082775375, 0.005164921910705106, 0.005164914746218759, 0.00516490758930835, 0.005164900439965962, 0.005164893298183605, 0.005164886163953099, 0.0051648790372667164, 0.005164871918116263, 0.005164864806493779, 0.005164857702391316, 0.005164850605801103, 0.0051648435167150055, 0.005164836435125236, 0.005164829361023609, 0.005164822294402402, 0.005164815235253642, 0.00516480818356954, 0.005164801139341962, 0.005164794102563158, 0.005164787073225364, 0.005164780051320597, 0.005164773036840888, 0.005164766029778487, 0.005164759030125661, 0.005164752037874426, 0.005164745053017024, 0.005164738075545705, 0.005164731105452488, 0.005164724142729624, 0.005164717187369361, 0.005164710239363739, 0.00516470329870519, 0.005164696365385964, 0.005164689439398109, 0.005164682520734063, 0.005164675609385858, 0.00516466870534595, 0.0051646618086065655, 0.005164654919159932, 0.0051646480369983315, 0.005164641162114172, 0.005164634294499705, 0.0051646274341471815, 0.005164620581048866, 0.00516461373519716, 0.005164606896584542, 0.005164600065203233, 0.005164593241045481, 0.005164586424103727, 0.00516457961437044, 0.005164572811837834, 0.005164566016498362, 0.0051645592283444735, 0.005164552447368408, 0.005164545673562841, 0.005164538906919986, 0.005164532147432274, 0.005164525395092189, 0.0051645186498921565, 0.005164511911824616, 0.005164505180882014, 0.005164498457056812, 0.005164491740341436, 0.005164485030728557, 0.005164478328210616, 0.005164471632779842, 0.005164464944429095, 0.005164458263150642, 0.0051644515889370975, 0.005164444921780935, 0.005164438261674801, 0.005164431608611134, 0.005164424962582577, 0.005164418323581563, 0.00516441169160075, 0.005164405066632605, 0.005164398448669769, 0.005164391837704881, 0.005164385233730607, 0.005164378636739405, 0.0051643720467238925, 0.005164365463676729, 0.005164358887590566, 0.005164352318458069, 0.005164345756271873, 0.0051643392010246375, 0.005164332652709013, 0.005164326111317635, 0.005164319576843178, 0.0051643130492784505, 0.005164306528615946, 0.005164300014848509, 0.0051642935079687785, 0.0051642870079694194, 0.005164280514843278, 0.005164274028582991, 0.0051642675491814435, 0.005164261076631263, 0.005164254610925108, 0.005164248152055812, 0.0051642417000162515, 0.005164235254799077, 0.005164228816397122, 0.0051642223848032695, 0.005164215960010172, 0.005164209542010645, 0.005164203130797584, 0.005164196726363832, 0.005164190328702036, 0.005164183937805246, 0.0051641775536661275, 0.005164171176277725, 0.00516416480563268, 0.005164158441724084, 0.005164152084544775, 0.005164145734087615, 0.005164139390345452, 0.005164133053311111, 0.005164126722977492, 0.00516412039933763, 0.00516411408238441, 0.0051641077721106595, 0.0051641014685094334, 0.005164095171573596, 0.005164088881296198, 0.005164082597670102, 0.005164076320688382, 0.005164070050344096, 0.0051640637866300606, 0.005164057529539155, 0.005164051279064438, 0.005164045035198951, 0.005164038797935791, 0.0051640325672679885, 0.0051640263431884026, 0.005164020125690074, 0.005164013914766328, 0.005164007710409963, 0.00516400151261405, 0.005163995321371664, 0.005163989136675842, 0.00516398295851962, 0.005163976786896303, 0.005163970621798734, 0.005163964463220175, 0.005163958311153705, 0.005163952165592355, 0.005163946026529409, 0.005163939893957708, 0.00516393376787074, 0.005163927648261344, 0.005163921535122784, 0.005163915428448292, 0.005163909328230957, 0.00516390323446383, 0.005163897147140408, 0.00516389106625353, 0.005163884991796648, 0.005163878923762828, 0.005163872862145325, 0.005163866806937212, 0.0051638607581319645, 0.005163854715722625, 0.00516384867970248, 0.005163842650064753, 0.005163836626802737, 0.005163830609909673, 0.00516382459937883, 0.005163818595203486, 0.0051638125973768965, 0.005163806605892338, 0.005163800620743052, 0.005163794641922324, 0.005163788669423603, 0.005163782703240145, 0.005163776743365237, 0.005163770789792343, 0.00516376484251453, 0.005163758901525447, 0.005163752966818166, 0.005163747038386133, 0.00516374111622282, 0.00516373520032152, 0.0051637292906756916, 0.005163723387278562, 0.005163717490123626, 0.005163711599204372, 0.005163705714514042, 0.005163699836046085, 0.005163693963793992, 0.0051636880977510334, 0.005163682237910666, 0.005163676384266547, 0.005163670536811976, 0.0051636646955403815, 0.005163658860445246, 0.005163653031520042, 0.00516364720875823, 0.005163641392153297, 0.0051636355816987115, 0.005163629777388106, 0.005163623979214749, 0.005163618187172358, 0.005163612401254361, 0.005163606621454239, 0.00516360084776567, 0.005163595080182106, 0.005163589318697042, 0.005163583563304128, 0.005163577813996838, 0.00516357207076863, 0.005163566333613188, 0.005163560602524162, 0.005163554877495025, 0.005163549158519485, 0.005163543445590955, 0.005163537738703153, 0.005163532037849724, 0.005163526343024362, 0.005163520654220526, 0.0051635149714318864, 0.005163509294652099, 0.005163503623874863, 0.0051634979590938265, 0.005163492300302472, 0.005163486647494673, 0.005163481000664106, 0.0051634753598042244, 0.005163469724908925, 0.00516346409597187, 0.005163458472986706, 0.00516345285594712, 0.0051634472448467824, 0.005163441639679612, 0.005163436040439224, 0.0051634304471193165, 0.005163424859713564, 0.005163419278215849, 0.005163413702619819, 0.0051634081329193626, 0.0051634025691081505, 0.005163397011179839, 0.00516339145912834, 0.0051633859129475036, 0.005163380372631009, 0.005163374838172722, 0.005163369309566328, 0.005163363786805717, 0.005163358269884747, 0.005163352758797278, 0.00516334725353701, 0.0051633417540977965, 0.005163336260473532, 0.005163330772658083, 0.005163325290645317, 0.005163319814429117, 0.005163314344003391, 0.005163308879361776, 0.005163303420498364, 0.005163297967407027, 0.005163292520081634, 0.005163287078516057, 0.00516328164270418, 0.005163276212639893, 0.00516327078831727, 0.00516326536973021, 0.005163259956872528, 0.005163254549738144, 0.00516324914832114, 0.00516324375261537, 0.005163238362614934, 0.005163232978313685, 0.005163227599705517, 0.005163222226784526, 0.005163216859544781, 0.0051632114979801415, 0.005163206142084692, 0.005163200791852316, 0.005163195447277083, 0.0051631901083531015, 0.005163184775074238, 0.00516317944743454, 0.005163174125428124, 0.00516316880904906, 0.005163163498291426, 0.005163158193149081, 0.005163152893616142, 0.005163147599686851, 0.005163142311355137, 0.005163137028615054, 0.0051631317514608775, 0.005163126479886488, 0.005163121213885987, 0.005163115953453626, 0.005163110698583483, 0.005163105449269681, 0.005163100205506283, 0.005163094967287338, 0.005163089734607156, 0.005163084507459832, 0.005163079285839428, 0.005163074069740226, 0.005163068859156312, 0.005163063654081786, 0.005163058454510892, 0.005163053260437732, 0.005163048071856594, 0.005163042888761761, 0.00516303771114731, 0.005163032539007327, 0.005163027372336283, 0.005163022211128285, 0.005163017055377398, 0.005163011905078143, 0.0051630067602245625, 0.005163001620810929, 0.005162996486831345, 0.005162991358280294, 0.0051629862351518716, 0.0051629811174405465, 0.005162976005140412, 0.005162970898245766, 0.005162965796750868, 0.005162960700650209, 0.005162955609937892, 0.005162950524608168, 0.005162945444655583, 0.005162940370074357, 0.005162935300858616, 0.005162930237002829, 0.005162925178501489, 0.005162920125348646, 0.005162915077538843, 0.005162910035066334, 0.0051629049979256035, 0.005162899966110745, 0.0051628949396164475, 0.0051628899184367905, 0.00516288490256625, 0.005162879891999345, 0.005162874886730347, 0.005162869886753734, 0.0051628648920637975, 0.005162859902655044, 0.005162854918521945, 0.005162849939658759, 0.005162844966060012, 0.005162839997719975, 0.005162835034633369, 0.005162830076794461, 0.005162825124197706, 0.00516282017683744, 0.005162815234708328, 0.005162810297804857, 0.005162805366121331, 0.005162800439652402, 0.005162795518392404, 0.005162790602335815, 0.005162785691477312, 0.005162780785811197, 0.005162775885332137, 0.0051627709900346486, 0.005162766099913195, 0.005162761214962291, 0.005162756335176416, 0.005162751460550243, 0.00516274659107829, 0.0051627417267550175, 0.005162736867574966, 0.005162732013532794, 0.005162727164622965, 0.005162722320840206, 0.005162717482179009, 0.005162712648633847, 0.005162707820199401, 0.005162702996870382, 0.005162698178641277, 0.005162693365506601, 0.005162688557461021, 0.005162683754499243, 0.00516267895661594, 0.005162674163805604, 0.0051626693760629646, 0.005162664593382477, 0.00516265981575904, 0.00516265504318715, 0.005162650275661472, 0.005162645513176741, 0.005162640755727631, 0.005162636003308832, 0.005162631255914829, 0.005162626513540547, 0.005162621776180455, 0.0051626170438294474, 0.005162612316482221, 0.005162607594133262, 0.00516260287677747, 0.005162598164409557, 0.0051625934570242, 0.005162588754616281, 0.0051625840571803035, 0.00516257936471116, 0.005162574677203556, 0.005162569994652164, 0.005162565317051917, 0.005162560644397465, 0.005162555976683544, 0.005162551313905024, 0.005162546656056603, 0.0051625420031331725, 0.005162537355129447, 0.0051625327120401, 0.005162528073860242, 0.005162523440584353, 0.005162518812207546, 0.005162514188724297, 0.005162509570129748, 0.005162504956418547, 0.005162500347585606, 0.00516249574362582, 0.005162491144533886, 0.005162486550304886, 0.0051624819609335315, 0.005162477376414513, 0.005162472796742927, 0.005162468221913704, 0.005162463651921498, 0.005162459086761426, 0.0051624545264281705, 0.005162449970916657, 0.005162445420221951, 0.00516244087433875, 0.005162436333262202, 0.005162431796986953, 0.005162427265508124, 0.0051624227388205905, 0.005162418216919285, 0.005162413699799056, 0.005162409187455051, 0.005162404679881947, 0.005162400177074864, 0.005162395679028889, 0.005162391185738713, 0.005162386697199433, 0.00516238221340614, 0.005162377734353747, 0.005162373260037135, 0.0051623687904512475, 0.005162364325591342, 0.005162359865452138, 0.005162355410028913, 0.005162350959316395, 0.005162346513309869, 0.005162342072004252, 0.0051623376353944215, 0.005162333203475679, 0.005162328776242954, 0.005162324353691323, 0.0051623199358156934, 0.005162315522611132, 0.005162311114072789, 0.005162306710195738, 0.0051623023109750935, 0.0051622979164059795, 0.005162293526483254, 0.005162289141202014, 0.0051622847605575966, 0.005162280384544896, 0.005162276013159207, 0.005162271646395419, 0.005162267284248642, 0.005162262926714202, 0.005162258573786965, 0.005162254225462254, 0.0051622498817351726, 0.005162245542600797, 0.005162241208054253, 0.005162236878090851, 0.00516223255270567, 0.005162228231893833, 0.005162223915650427, 0.005162219603970754, 0.005162215296849949, 0.005162210994283084, 0.005162206696265471, 0.005162202402792214, 0.00516219811385862, 0.005162193829459801, 0.00516218954959103, 0.0051621852742474396, 0.005162181003424113, 0.005162176737116584, 0.005162172475319928, 0.005162168218029272, 0.005162163965239909, 0.005162159716947139, 0.005162155473146258, 0.005162151233832384, 0.005162146999000834, 0.0051621427686468985, 0.005162138542765904, 0.005162134321352909, 0.0051621301044032526, 0.00516212589191243, 0.005162121683875578, 0.005162117480287952, 0.005162113281144881, 0.005162109086441684, 0.005162104896173435, 0.005162100710335667, 0.0051620965289236745, 0.005162092351932758, 0.005162088179358452, 0.005162084011195847, 0.005162079847440243, 0.00516207568808713, 0.005162071533131644, 0.005162067382569286, 0.0051620632363955496, 0.005162059094605567, 0.005162054957194823, 0.00516205082415863, 0.005162046695492299, 0.0051620425711913125, 0.005162038451251029, 0.005162034335666916, 0.005162030224434292, 0.005162026117548457, 0.005162022015004944, 0.005162017916799018, 0.005162013822926243, 0.005162009733382086, 0.00516200564816187, 0.005162001567260891, 0.005161997490674885, 0.005161993418398927, 0.00516198935042877, 0.005161985286759671, 0.005161981227387164, 0.005161977172306748, 0.005161973121513751, 0.005161969075003882, 0.005161965032772414, 0.0051619609948146995, 0.005161956961126432, 0.00516195293170313, 0.005161948906540102, 0.0051619448856330425, 0.005161940868977252, 0.005161936856568456, 0.005161932848401981, 0.005161928844473328, 0.005161924844778188, 0.005161920849311872, 0.005161916858070109, 0.0051619128710482225, 0.0051619088882418765, 0.005161904909646636, 0.005161900935257966, 0.005161896965071609, 0.005161892999082869, 0.005161889037287458, 0.005161885079680871, 0.0051618811262586365, 0.005161877177016462, 0.005161873231949838, 0.005161869291054501, 0.005161865354325769, 0.005161861421759517, 0.0051618574933511045, 0.005161853569096196, 0.005161849648990543, 0.00516184573302963, 0.00516184182120918, 0.005161837913524726, 0.005161834009971964, 0.005161830110546382, 0.005161826215243718, 0.005161822324059501, 0.005161818436989627, 0.005161814554029398, 0.005161810675174739, 0.005161806800421164, 0.005161802929764389, 0.0051617990632001134, 0.005161795200724063, 0.00516179134233174, 0.005161787488019073, 0.005161783637781574, 0.005161779791614914, 0.005161775949514884, 0.005161772111477132, 0.005161768277497396, 0.005161764447571198, 0.0051617606216944325, 0.005161756799862847, 0.005161752982072127, 0.005161749168318004, 0.005161745358596171, 0.0051617415529023655, 0.0051617377512322895, 0.005161733953581864, 0.005161730159946621, 0.005161726370322436, 0.005161722584705063, 0.005161718803090203, 0.005161715025473746, 0.005161711251851234, 0.005161707482218585, 0.0051617037165717135, 0.005161699954906349, 0.005161696197218179, 0.005161692443502932, 0.0051616886937565, 0.005161684947974629, 0.005161681206153215, 0.005161677468288184, 0.005161673734375065, 0.005161670004409967, 0.0051616662783883945, 0.00516166255630647, 0.005161658838159924, 0.0051616551239444435, 0.005161651413656173, 0.005161647707290816, 0.005161644004844088, 0.005161640306311928, 0.005161636611690252, 0.00516163292097497, 0.005161629234161973, 0.00516162555124699, 0.005161621872225951, 0.005161618197094803, 0.0051616145258492185, 0.005161610858485321, 0.005161607194999014, 0.005161603535386045, 0.005161599879642333, 0.0051615962277637975, 0.005161592579746524, 0.005161588935586282, 0.005161585295278953, 0.00516158165882045, 0.0051615780262069255, 0.005161574397434058, 0.005161570772497995, 0.0051615671513944575, 0.005161563534119555, 0.005161559920669201, 0.005161556311039336, 0.005161552705225844, 0.005161549103224883, 0.00516154550503236, 0.005161541910644165, 0.005161538320056267, 0.005161534733264756, 0.005161531150265534, 0.005161527571054567, 0.0051615239956279415, 0.005161520423981606, 0.0051615168561114505, 0.0051615132920136125, 0.0051615097316842174, 0.0051615061751189425, 0.0051615026223141595, 0.005161499073265774, 0.0051614955279697125, 0.0051614919864220775, 0.005161488448619005, 0.005161484914556402, 0.00516148138423018, 0.00516147785763668, 0.005161474334771838, 0.00516147081563174, 0.005161467300212357, 0.005161463788509747, 0.005161460280520083, 0.0051614567762394755, 0.005161453275663829, 0.005161449778789289, 0.005161446285611957, 0.005161442796127949, 0.0051614393103334025, 0.005161435828224456, 0.005161432349796993, 0.005161428875047362, 0.005161425403971491, 0.0051614219365655025, 0.005161418472825694, 0.0051614150127480074, 0.005161411556328771, 0.005161408103563874, 0.005161404654449454, 0.0051614012089818626, 0.005161397767157192, 0.005161394328971376, 0.005161390894420736, 0.00516138746350159, 0.005161384036209881, 0.005161380612541726, 0.005161377192493428, 0.005161373776061127, 0.0051613703632409445, 0.005161366954029217, 0.005161363548421863, 0.005161360146415399, 0.005161356748005746, 0.005161353353189235, 0.00516134996196197, 0.005161346574320315, 0.005161343190260356, 0.005161339809778238, 0.005161336432870283, 0.005161333059532838, 0.005161329689761982, 0.005161326323553855, 0.005161322960904796, 0.005161319601810925, 0.005161316246268763, 0.005161312894274224, 0.005161309545823873, 0.005161306200913814, 0.005161302859540155, 0.005161299521699238, 0.005161296187387374, 0.005161292856600913, 0.005161289529336161, 0.005161286205589247, 0.0051612828853564935, 0.005161279568634044, 0.0051612762554183855, 0.005161272945705701, 0.005161269639492475, 0.005161266336774842, 0.005161263037549133, 0.005161259741811467, 0.005161256449558395, 0.00516125316078623, 0.0051612498754913, 0.005161246593669712, 0.005161243315318035, 0.005161240040432559, 0.005161236769009626, 0.0051612335010453305, 0.0051612302365362395, 0.00516122697547868, 0.005161223717868957, 0.00516122046370361, 0.005161217212978745, 0.0051612139656909105, 0.005161210721836228, 0.005161207481411245, 0.005161204244412288, 0.005161201010835873, 0.005161197780678311, 0.005161194553935938, 0.005161191330605111, 0.005161188110682338, 0.005161184894163735, 0.005161181681046045, 0.005161178471325391, 0.005161175264998513, 0.005161172062061538, 0.005161168862510957, 0.005161165666343143, 0.005161162473554604, 0.0051611592841418865, 0.0051611560981010916, 0.00516115291542896, 0.005161149736121857, 0.005161146560176066, 0.005161143387588125, 0.005161140218354571, 0.00516113705247174, 0.005161133889936154, 0.005161130730744346, 0.0051611275748926185, 0.0051611244223775405, 0.0051611212731956365, 0.005161118127343203, 0.005161114984816808, 0.005161111845612945, 0.005161108709728183, 0.005161105577158818, 0.005161102447901414, 0.005161099321952671, 0.00516109619930892, 0.00516109307996653, 0.005161089963922194, 0.005161086851172447, 0.005161083741713627, 0.005161080635542481, 0.005161077532655526, 0.00516107443304908, 0.005161071336719881, 0.005161068243664261, 0.005161065153878955, 0.005161062067360284, 0.005161058984104981, 0.005161055904109623, 0.005161052827370492, 0.005161049753884329, 0.00516104668364787, 0.005161043616657442, 0.0051610405529095744, 0.005161037492400989, 0.005161034435128245, 0.005161031381087844, 0.00516102833027634, 0.005161025282690458, 0.0051610222383267615, 0.0051610191971817425, 0.005161016159252143, 0.005161013124534494, 0.005161010093025319, 0.00516100706472139, 0.005161004039619194, 0.0051610010177152756, 0.0051609979990064, 0.005160994983489052, 0.0051609919711599825, 0.005160988962015738, 0.005160985956053021, 0.005160982953268408, 0.00516097995365859, 0.005160976957220127, 0.005160973963949768, 0.005160970973844233, 0.0051609679869000155, 0.005160965003113677, 0.00516096202248217, 0.005160959045002003, 0.005160956070669722, 0.005160953099482251, 0.005160950131436128, 0.005160947166527912, 0.005160944204754507, 0.0051609412461124495, 0.005160938290598496, 0.005160935338209353, 0.0051609323889417755, 0.005160929442792297, 0.005160926499757613, 0.005160923559834698, 0.005160920623020092, 0.005160917689310297, 0.005160914758702265, 0.00516091183119276, 0.005160908906778488, 0.005160905985455964, 0.0051609030672221555, 0.005160900152073761, 0.005160897240007356, 0.005160894331019864, 0.005160891425108027, 0.005160888522268572, 0.005160885622498029, 0.0051608827257933225, 0.005160879832151217, 0.0051608769415686356, 0.0051608740540421095, 0.005160871169568561, 0.005160868288144544, 0.005160865409766998, 0.005160862534432655, 0.005160859662138471, 0.005160856792880945, 0.005160853926657018, 0.005160851063463451, 0.005160848203297177, 0.0051608453461547184, 0.005160842492033015, 0.005160839640928995, 0.005160836792839403, 0.005160833947761003, 0.005160831105690477, 0.005160828266624792, 0.005160825430560895, 0.00516082259749531, 0.005160819767425178, 0.005160816940347045, 0.005160814116258023, 0.00516081129515487, 0.005160808477034319, 0.00516080566189331, 0.005160802849728562, 0.005160800040537043, 0.005160797234315654, 0.0051607944310611735, 0.005160791630770526, 0.005160788833440432, 0.005160786039067821, 0.0051607832476496685, 0.005160780459182884, 0.005160777673664223, 0.00516077489109061, 0.005160772111458787, 0.00516076933476591, 0.0051607665610086785, 0.005160763790184066, 0.005160761022288997, 0.0051607582573202125, 0.00516075549527484, 0.005160752736149637, 0.005160749979941541, 0.005160747226647485, 0.005160744476264389, 0.005160741728789202, 0.005160738984218896, 0.00516073624255018, 0.0051607335037802005, 0.0051607307679058965, 0.005160728034923973, 0.005160725304831609, 0.0051607225776257514, 0.005160719853303307, 0.005160717131861063, 0.005160714413296109, 0.005160711697605408, 0.005160708984785896, 0.0051607062748344965, 0.005160703567748382, 0.00516070086352428, 0.005160698162159331, 0.005160695463650467, 0.005160692767994618, 0.005160690075188739, 0.005160687385229766, 0.0051606846981148355, 0.005160682013840922, 0.005160679332404935, 0.005160676653804015, 0.005160673978035109, 0.005160671305095146, 0.00516066863498127, 0.005160665967690238, 0.005160663303219365, 0.0051606606415654155, 0.005160657982725524, 0.00516065532669684, 0.005160652673476288, 0.005160650023060819, 0.00516064737544757, 0.005160644730633476, 0.005160642088615691, 0.005160639449391142, 0.005160636812956973, 0.005160634179310152, 0.005160631548447783, 0.005160628920367022, 0.005160626295064817, 0.005160623672538316, 0.005160621052784451, 0.005160618435800377, 0.005160615821582997, 0.005160613210129693, 0.005160610601437396, 0.00516060799550303, 0.005160605392323773, 0.005160602791896723, 0.005160600194219067, 0.005160597599287909, 0.0051605950071002245, 0.0051605924176531415, 0.005160589830943786, 0.005160587246969324, 0.005160584665726677, 0.00516058208721323, 0.005160579511425875, 0.0051605769383617685, 0.005160574368018076, 0.005160571800391918, 0.005160569235480246, 0.00516056667328042, 0.005160564113789577, 0.005160561557004639, 0.005160559002922959, 0.005160556451541695, 0.005160553902857769, 0.005160551356868519, 0.005160548813571111, 0.005160546272962474, 0.005160543735039956, 0.005160541199800704, 0.005160538667241855, 0.005160536137360541, 0.005160533610153935, 0.005160531085619354, 0.005160528563753771, 0.005160526044554519, 0.005160523528018747, 0.005160521014143596, 0.00516051850292618, 0.0051605159943636765, 0.005160513488453402, 0.005160510985192551, 0.005160508484578235, 0.0051605059866078, 0.005160503491278395, 0.005160500998587164, 0.0051604985085312235, 0.005160496021107966, 0.005160493536314489, 0.005160491054148189, 0.005160488574606179, 0.005160486097685609, 0.005160483623383823, 0.005160481151697987, 0.005160478682625424, 0.005160476216163267, 0.005160473752308682, 0.005160471291059, 0.005160468832411595, 0.005160466376363588, 0.0051604639229121205, 0.005160461472054763, 0.005160459023788434, 0.005160456578110711, 0.00516045413501851, 0.0051604516945093735, 0.00516044925658048, 0.0051604468212291385, 0.005160444388452528, 0.005160441958247972, 0.005160439530612839, 0.005160437105544271, 0.0051604346830395895, 0.005160432263096163, 0.005160429845711121, 0.005160427430881831, 0.005160425018605636, 0.005160422608879853, 0.005160420201701852, 0.005160417797068773, 0.005160415394977962, 0.005160412995426772, 0.005160410598412564, 0.005160408203932669, 0.005160405811984237, 0.005160403422564816, 0.00516040103567154, 0.005160398651301764, 0.005160396269452826, 0.005160393890122108, 0.005160391513306926, 0.005160389139004641, 0.005160386767212584, 0.005160384397928136, 0.005160382031148616, 0.005160379666871375, 0.0051603773050937505, 0.005160374945813113, 0.005160372589027019, 0.005160370234732593, 0.005160367882927183, 0.0051603655336081335, 0.005160363186773003, 0.0051603608424191354, 0.0051603585005436875, 0.005160356161144203, 0.005160353824218027, 0.005160351489762707, 0.005160349157775372, 0.0051603468282536225, 0.005160344501194753, 0.005160342176596131, 0.005160339854455125, 0.005160337534769268, 0.005160335217535892, 0.00516033290275235, 0.005160330590416221, 0.005160328280524633, 0.005160325973075359, 0.00516032366806553, 0.005160321365492661, 0.005160319065354138, 0.0051603167676475175, 0.005160314472370128, 0.005160312179519311, 0.005160309889092636, 0.005160307601087646, 0.005160305315501497, 0.00516030303233192, 0.005160300751576095, 0.0051602984732317435, 0.005160296197296009, 0.005160293923766479, 0.00516029165264067, 0.005160289383916149, 0.005160287117590064, 0.005160284853660161, 0.005160282592123779, 0.005160280332978285, 0.005160278076221424, 0.005160275821850347, 0.0051602735698627914, 0.005160271320256117, 0.005160269073027883, 0.005160266828175432, 0.005160264585696301, 0.005160262345588053, 0.005160260107848244, 0.005160257872474222, 0.005160255639463549, 0.005160253408813746, 0.00516025118052218, 0.005160248954586605, 0.005160246731004366, 0.005160244509773027, 0.00516024229089013, 0.005160240074353007, 0.0051602378601592214, 0.0051602356483065265, 0.005160233438792274, 0.00516023123161403, 0.005160229026769314, 0.005160226824255688, 0.005160224624070538, 0.005160222426211585, 0.005160220230676394, 0.005160218037462296, 0.005160215846567059, 0.0051602136579880055, 0.005160211471722918, 0.0051602092877691364, 0.005160207106124404, 0.005160204926786085, 0.005160202749751922, 0.005160200575019479, 0.00516019840258633, 0.005160196232449797, 0.005160194064607625, 0.005160191899057364, 0.005160189735796797, 0.0051601875748232455, 0.00516018541613427, 0.005160183259727643, 0.0051601811056008985, 0.005160178953751603, 0.005160176804177283, 0.005160174656875508, 0.005160172511844041, 0.005160170369080416, 0.005160168228582204, 0.005160166090346931, 0.00516016395437236, 0.0051601618206560396, 0.005160159689195547, 0.005160157559988593, 0.005160155433032566, 0.005160153308325416, 0.005160151185864505, 0.005160149065647554, 0.005160146947672143, 0.005160144831936003, 0.00516014271843669, 0.005160140607171776, 0.005160138498138986, 0.005160136391336099, 0.005160134286760464, 0.005160132184410029, 0.005160130084282155, 0.005160127986374609, 0.005160125890685116, 0.005160123797211239, 0.005160121705950715, 0.005160119616901118, 0.005160117530060214, 0.005160115445425531, 0.005160113362994867, 0.005160111282765718, 0.005160109204735854, 0.005160107128903047, 0.00516010505526485, 0.005160102983818991, 0.005160100914563254, 0.0051600988474951965, 0.005160096782612555, 0.005160094719912887, 0.005160092659393945, 0.005160090601053483, 0.005160088544889253, 0.005160086490898835, 0.005160084439079953, 0.00516008238943038, 0.005160080341947848, 0.005160078296629928, 0.005160076253474375, 0.005160074212478954, 0.005160072173641406, 0.005160070136959301, 0.005160068102430354, 0.005160066070052576, 0.005160064039823471, 0.005160062011740835, 0.00516005998580219, 0.005160057962005506, 0.005160055940348558, 0.005160053920828874, 0.005160051903444418, 0.005160049888192754, 0.00516004787507162, 0.005160045864078988, 0.005160043855212407, 0.0051600418484696155, 0.005160039843848382, 0.005160037841346465, 0.005160035840961852, 0.00516003384269204, 0.00516003184653482, 0.005160029852488133, 0.005160027860549566, 0.00516002587071685, 0.005160023882987911, 0.005160021897360555, 0.005160019913832308, 0.00516001793240115, 0.005160015953064818, 0.005160013975821269, 0.0051600120006680536, 0.0051600100276029525, 0.005160008056623902, 0.0051600060877286915, 0.00516000412091503, 0.005160002156180707, 0.005160000193523663, 0.005159998232941661, 0.005159996274432459, 0.005159994317993797, 0.005159992363623481, 0.005159990411319428, 0.0051599884610793924, 0.005159986512901345, 0.005159984566782842, 0.005159982622721812, 0.005159980680716248, 0.0051599787407636925, 0.0051599768028623046, 0.0051599748670096484, 0.005159972933203683, 0.005159971001442145, 0.005159969071723005, 0.005159967144044032, 0.005159965218402957, 0.005159963294797743, 0.005159961373226152, 0.00515995945368616, 0.00515995753617572, 0.005159955620692379, 0.00515995370723429, 0.005159951795799027, 0.005159949886384717, 0.005159947978989137, 0.005159946073610048, 0.005159944170245421, 0.005159942268893008, 0.005159940369550739, 0.00515993847221659, 0.005159936576888322, 0.005159934683563885, 0.005159932792241054, 0.005159930902917981, 0.005159929015592217, 0.005159927130261913, 0.005159925246924846, 0.005159923365578768, 0.00515992148622184, 0.005159919608851815, 0.00515991773346646, 0.005159915860063921, 0.005159913988641967, 0.00515991211919856, 0.0051599102517316505, 0.005159908386238991, 0.005159906522718531, 0.005159904661168249, 0.005159902801586103, 0.005159900943970071, 0.0051598990883178686, 0.005159897234627475, 0.0051598953828968465, 0.005159893533123963, 0.005159891685306774, 0.00515988983944322, 0.005159887995531061, 0.0051598861535684815, 0.005159884313553233, 0.005159882475483274, 0.0051598806393565585, 0.005159878805171045, 0.0051598769729246895, 0.005159875142615465, 0.0051598733142413184, 0.005159871487800222, 0.0051598696632899075, 0.005159867840708565, 0.0051598660200541345, 0.005159864201324603, 0.005159862384517899, 0.005159860569632008, 0.005159858756664871, 0.005159856945614468, 0.005159855136478718, 0.005159853329255622, 0.005159851523943144, 0.00515984972053922, 0.0051598479190420226, 0.005159846119449511, 0.0051598443217594145, 0.005159842525969944, 0.005159840732079015, 0.005159838940084634, 0.005159837149984737, 0.005159835361777466, 0.005159833575460803, 0.005159831791032727, 0.005159830008491163, 0.005159828227834077, 0.0051598264490596655, 0.005159824672165644, 0.005159822897150196, 0.005159821124011482, 0.005159819352747253, 0.005159817583355693, 0.005159815815834739, 0.005159814050182569, 0.005159812286397135, 0.005159810524476377, 0.005159808764418283, 0.005159807006221005, 0.0051598052498825235, 0.005159803495400981, 0.005159801742774359, 0.005159799992000561, 0.005159798243077807, 0.005159796496004054, 0.005159794750777228, 0.005159793007395506, 0.005159791265857084, 0.005159789526159693, 0.005159787788301667, 0.005159786052281007, 0.005159784318095685, 0.005159782585743832, 0.005159780855223434, 0.005159779126532433, 0.005159777399669185, 0.005159775674631669, 0.005159773951417842, 0.00515977223002588, 0.005159770510453708, 0.005159768792699533, 0.005159767076761476, 0.005159765362637548, 0.005159763650325878, 0.005159761939824429, 0.005159760231131371, 0.005159758524244879, 0.005159756819162871, 0.005159755115883553, 0.005159753414404858, 0.005159751714725175, 0.00515975001684224, 0.005159748320754439, 0.005159746626459722, 0.00515974493395625, 0.005159743243242197, 0.005159741554315724, 0.0051597398671748024, 0.0051597381818175615, 0.005159736498242005, 0.005159734816446465, 0.0051597331364289, 0.005159731458187513, 0.005159729781720444, 0.0051597281070256545, 0.00515972643410151, 0.005159724762945945, 0.00515972309355715, 0.005159721425933306, 0.005159719760072537, 0.005159718095973034, 0.005159716433632745, 0.005159714773049867, 0.005159713114222736, 0.005159711457149307, 0.005159709801827756, 0.005159708148256235, 0.005159706496432914, 0.0051597048463559655, 0.005159703198023558, 0.005159701551433815, 0.005159699906584754, 0.005159698263474714, 0.005159696622101842, 0.005159694982464313, 0.00515969334456012, 0.005159691708387591, 0.0051596900739449, 0.005159688441230238, 0.005159686810241744, 0.005159685180977568, 0.005159683553435901, 0.0051596819276148965, 0.005159680303512693, 0.005159678681127472, 0.005159677060457418, 0.0051596754415009, 0.005159673824255831, 0.005159672208720634, 0.005159670594893426, 0.00515966898277241, 0.005159667372355719, 0.005159665763641548, 0.00515966415662824, 0.005159662551313759, 0.005159660947696505, 0.005159659345774604, 0.005159657745546417, 0.005159656147009931, 0.005159654550163495, 0.005159652955005285, 0.005159651361533461, 0.005159649769746379, 0.005159648179642019, 0.005159646591218955, 0.005159645004475137, 0.005159643419408732, 0.00515964183601812, 0.005159640254301619, 0.00515963867425723, 0.005159637095883333, 0.005159635519178082, 0.005159633944139814, 0.005159632370766718, 0.0051596307990569405, 0.005159629229008887, 0.005159627660620701, 0.005159626093890733, 0.005159624528817172, 0.0051596229653981555, 0.005159621403632087, 0.0051596198435171076, 0.005159618285051389, 0.005159616728233483, 0.005159615173061359, 0.005159613619533399, 0.00515961206764795, 0.005159610517403217, 0.005159608968797323, 0.0051596074218286415, 0.005159605876495352, 0.005159604332796009, 0.0051596027907285695, 0.005159601250291427, 0.00515959971148293, 0.005159598174301268, 0.005159596638744783, 0.005159595104811629, 0.005159593572500206, 0.005159592041808863, 0.005159590512735746, 0.005159588985279263, 0.0051595874594375524, 0.0051595859352089705, 0.005159584412591919, 0.0051595828915845425, 0.005159581372185219, 0.005159579854392097, 0.00515957833820377, 0.005159576823618387, 0.005159575310634098, 0.005159573799249508, 0.005159572289462742, 0.005159570781272208, 0.0051595692746760355, 0.0051595677696726185, 0.00515956626626033, 0.005159564764437509, 0.0051595632642025425, 0.005159561765553562, 0.005159560268488976, 0.005159558773007149, 0.00515955727910642, 0.005159555786784974, 0.005159554296041181, 0.005159552806873609, 0.005159551319280435, 0.005159549833259786, 0.005159548348810262, 0.005159546865930014, 0.0051595453846176274, 0.005159543904871266, 0.00515954242668929, 0.005159540950070054, 0.005159539475011943, 0.005159538001513354, 0.005159536529572611, 0.00515953505918789, 0.005159533590357758, 0.0051595321230806105, 0.005159530657354568, 0.005159529193178019, 0.005159527730549552, 0.0051595262694672985, 0.005159524809929855, 0.005159523351935367, 0.005159521895482425, 0.005159520440569189, 0.005159518987194031, 0.005159517535355494, 0.005159516085051763, 0.005159514636281412, 0.005159513189042609, 0.005159511743333906, 0.00515951029915369, 0.00515950885650034, 0.005159507415372008, 0.005159505975767262, 0.005159504537684648, 0.005159503101122384, 0.005159501666078791, 0.005159500232552472, 0.0051594988005415525, 0.005159497370044635, 0.0051594959410601006, 0.0051594945135862965, 0.005159493087621602, 0.00515949166316435, 0.005159490240213164, 0.005159488818766387, 0.005159487398822389, 0.005159485980379529, 0.005159484563436167, 0.0051594831479909, 0.005159481734042082, 0.005159480321588079, 0.005159478910627278, 0.005159477501158229, 0.005159476093179305, 0.005159474686688884, 0.005159473281685535, 0.00515947187816741, 0.005159470476133287, 0.005159469075581334, 0.005159467676510134, 0.005159466278918036, 0.005159464882803427, 0.005159463488164865, 0.005159462095000723, 0.005159460703309379, 0.005159459313089394, 0.0051594579243391375, 0.005159456537057172, 0.005159455151241875, 0.005159453766891611, 0.005159452384004938, 0.0051594510025802605, 0.005159449622615933, 0.005159448244110508, 0.005159446867062569, 0.005159445491470486, 0.005159444117332625, 0.005159442744647552, 0.005159441373413645, 0.005159440003629474, 0.005159438635293408, 0.005159437268404001, 0.005159435902959647, 0.005159434538958919, 0.0051594331764001754, 0.005159431815281991, 0.005159430455602729, 0.005159429097360957, 0.0051594277405552355, 0.005159426385183928, 0.005159425031245443, 0.005159423678738349, 0.005159422327661206, 0.005159420978012354, 0.005159419629790385, 0.005159418282993887, 0.005159416937621218, 0.005159415593670718, 0.005159414251141204, 0.005159412910031011, 0.005159411570338524, 0.0051594102320625355, 0.005159408895201389, 0.005159407559753454, 0.005159406225717541, 0.005159404893091961, 0.005159403561875137, 0.005159402232065795, 0.00515940090366233, 0.0051593995766633155, 0.005159398251067103, 0.005159396926872273, 0.0051593956040774155, 0.005159394282681068, 0.005159392962681626, 0.005159391644077874, 0.005159390326868153, 0.0051593890110508515, 0.005159387696624731, 0.005159386383588134, 0.005159385071939898, 0.005159383761678365, 0.005159382452801871, 0.005159381145309207, 0.0051593798391987595, 0.005159378534469323, 0.005159377231119216, 0.005159375929147045, 0.005159374628551141, 0.0051593733293303305, 0.005159372031483148, 0.005159370735007968, 0.005159369439903394, 0.0051593681461681515, 0.005159366853800643, 0.005159365562799443, 0.005159364273163112, 0.005159362984890217, 0.005159361697979115, 0.005159360412428628, 0.005159359128237272, 0.00515935784540366, 0.005159356563926134, 0.005159355283803478, 0.005159354005034058, 0.005159352727616673, 0.005159351451549651, 0.005159350176831793, 0.005159348903461667, 0.005159347631437642, 0.0051593463607584765, 0.005159345091422578, 0.0051593438234286745, 0.005159342556775368, 0.005159341291461229, 0.00515934002748462, 0.005159338764844334, 0.00515933750353891, 0.005159336243566945, 0.005159334984927006, 0.005159333727617871, 0.005159332471637891, 0.0051593312169856765, 0.005159329963659948, 0.005159328711659315, 0.005159327460982348, 0.005159326211627613, 0.0051593249635937, 0.0051593237168791484, 0.005159322471482546, 0.005159321227402664, 0.005159319984638078, 0.005159318743187342, 0.005159317503049074, 0.005159316264221789, 0.005159315026704297, 0.005159313790495157, 0.005159312555592943, 0.005159311321996255, 0.005159310089703644, 0.005159308858713859, 0.005159307629025527, 0.005159306400637179, 0.0051593051735475915, 0.0051593039477551535, 0.005159302723258628, 0.005159301500056792, 0.005159300278148018, 0.005159299057531092, 0.005159297838204544, 0.005159296620167191, 0.005159295403417381, 0.005159294187954103, 0.0051592929737757295, 0.0051592917608810395, 0.005159290549268592, 0.005159289338937166, 0.005159288129885126, 0.005159286922111475, 0.0051592857156145255, 0.005159284510393094, 0.005159283306445981, 0.005159282103771717, 0.005159280902368899, 0.005159279702236095, 0.005159278503372068, 0.005159277305775589, 0.005159276109445219, 0.0051592749143795635, 0.005159273720577384, 0.005159272528037257, 0.005159271336757975, 0.005159270146738069, 0.005159268957976129, 0.005159267770471151, 0.005159266584221508, 0.005159265399225933, 0.0051592642154832495, 0.005159263032992002, 0.005159261851750767, 0.00515926067175854, 0.005159259493013649, 0.005159258315514901, 0.005159257139261092, 0.005159255964250764, 0.005159254790482697, 0.0051592536179556545, 0.005159252446668212, 0.005159251276618974, 0.0051592501078066896, 0.005159248940230129, 0.005159247773887883, 0.00515924660877873, 0.005159245444901426, 0.005159244282254553, 0.005159243120836689, 0.005159241960646804, 0.005159240801683476, 0.005159239643945264, 0.005159238487431174, 0.005159237332139763, 0.005159236178069581, 0.005159235025219643, 0.005159233873588511, 0.005159232723174737, 0.005159231573977342, 0.005159230425994869, 0.0051592292792259015, 0.005159228133669399, 0.005159226989323938, 0.0051592258461883025, 0.005159224704261273, 0.005159223563541399, 0.0051592224240275, 0.005159221285718331, 0.005159220148612655, 0.005159219012709054, 0.005159217878006308, 0.0051592167445032025, 0.005159215612198494, 0.0051592144810907415, 0.005159213351178951, 0.005159212222461674, 0.0051592110949377195, 0.005159209968605625, 0.005159208843464387, 0.005159207719512575, 0.0051592065967489735, 0.005159205475172331, 0.005159204354781449, 0.005159203235575099, 0.005159202117552074, 0.005159201000710911, 0.005159199885050608, 0.005159198770569726, 0.005159197657267065, 0.005159196545141374, 0.005159195434191446, 0.005159194324416029, 0.005159193215813738, 0.005159192108383545, 0.005159191002124208, 0.005159189897034301, 0.005159188793112814, 0.005159187690358322, 0.0051591865887695805, 0.005159185488345565, 0.0051591843890848805, 0.005159183290986282, 0.005159182194048769, 0.005159181098270877, 0.005159180003651408, 0.005159178910189126, 0.005159177817882831, 0.005159176726731467, 0.0051591756367336565, 0.0051591745478881314, 0.0051591734601937, 0.005159172373649286, 0.005159171288253523, 0.005159170204005138, 0.00515916912090315, 0.005159168038946113, 0.005159166958133037, 0.005159165878462439, 0.005159164799933323, 0.005159163722544489, 0.00515916264629468, 0.005159161571182689, 0.005159160497207278, 0.0051591594243672574, 0.005159158352661383, 0.005159157282088622, 0.005159156212647549, 0.005159155144337154, 0.0051591540771562154, 0.005159153011103489, 0.005159151946177784, 0.005159150882377858, 0.0051591498197026825, 0.0051591487581510225, 0.005159147697721476, 0.005159146638413011, 0.005159145580224629, 0.005159144523154887, 0.005159143467202763, 0.005159142412366813, 0.005159141358646046, 0.005159140306039424, 0.005159139254545514, 0.0051591382041633275, 0.005159137154891621, 0.005159136106729158, 0.005159135059674726, 0.005159134013727312, 0.005159132968885682, 0.005159131925148614, 0.005159130882515104, 0.005159129840983692, 0.005159128800553372, 0.005159127761223128, 0.005159126722991528, 0.005159125685857568, 0.005159124649820216, 0.005159123614878032, 0.005159122581029998, 0.005159121548274907, 0.005159120516611721, 0.005159119486039238, 0.005159118456556224, 0.005159117428161666, 0.005159116400854323, 0.005159115374632972, 0.005159114349496597, 0.005159113325443996, 0.005159112302473898, 0.005159111280585344, 0.005159110259777059, 0.00515910924004805, 0.00515910822139708, 0.005159107203823115, 0.005159106187324761, 0.005159105171901165, 0.005159104157551153, 0.005159103144273464, 0.005159102132066892, 0.00515910112093039, 0.005159100110862955, 0.005159099101863365, 0.005159098093930406, 0.0051590970870630465, 0.005159096081260261, 0.005159095076520841, 0.005159094072843553, 0.005159093070227376, 0.0051590920686710685, 0.005159091068173621, 0.0051590900687340435, 0.005159089070350873, 0.005159088073023298, 0.005159087076750119, 0.005159086081530089, 0.005159085087362224, 0.005159084094245445, 0.005159083102178576, 0.005159082111160574, 0.0051590811211902066, 0.005159080132266461, 0.00515907914438813, 0.005159078157554199, 0.005159077171763618, 0.005159076187015173, 0.00515907520330787, 0.005159074220640456, 0.005159073239011899, 0.005159072258421211, 0.00515907127886715, 0.0051590703003486955, 0.005159069322864642, 0.005159068346414145, 0.005159067370995803, 0.005159066396608802, 0.005159065423251903, 0.005159064450924054, 0.005159063479624069, 0.005159062509350953, 0.00515906154010363, 0.005159060571880928, 0.005159059604681787, 0.005159058638505211, 0.005159057673350173, 0.005159056709215454, 0.0051590557461000195, 0.00515905478400286, 0.0051590538229227614, 0.005159052862858676, 0.005159051903809593, 0.005159050945774307, 0.00515904998875198, 0.0051590490327414066, 0.005159048077741562, 0.005159047123751208, 0.00515904617076954, 0.005159045218795335, 0.0051590442678275525, 0.005159043317864996, 0.005159042368906834, 0.00515904142095186, 0.005159040473999042, 0.0051590395280473565, 0.005159038583095789, 0.005159037639143114, 0.005159036696188517, 0.005159035754230783, 0.005159034813268864, 0.005159033873301781, 0.0051590329343282814, 0.005159031996347544, 0.005159031059358356, 0.005159030123359901, 0.005159029188350958, 0.005159028254330503, 0.0051590273212975025, 0.005159026389250758, 0.005159025458189433, 0.00515902452811232, 0.005159023599018592, 0.0051590226709070245, 0.005159021743776609, 0.005159020817626523, 0.005159019892455554, 0.0051590189682626676, 0.005159018045046839, 0.005159017122807052, 0.00515901620154209, 0.005159015281251141, 0.005159014361933179, 0.005159013443586967, 0.005159012526211713, 0.005159011609806371, 0.005159010694369742, 0.0051590097799009945, 0.005159008866398901, 0.00515900795386267, 0.005159007042291042, 0.005159006131683234, 0.005159005222038008, 0.005159004313354536, 0.005159003405631822, 0.0051590024988686445, 0.005159001593064152, 0.005159000688217147, 0.0051589997843268275, 0.005158998881392148, 0.005158997979412083, 0.005158997078385432, 0.005158996178311368, 0.005158995279188842, 0.005158994381016873, 0.005158993483794451, 0.0051589925875205455, 0.0051589916921943165, 0.005158990797814537, 0.005158989904380204, 0.005158989011890517, 0.005158988120344444, 0.00515898722974075, 0.0051589863400786275, 0.005158985451357051, 0.005158984563574994, 0.005158983676731455, 0.005158982790825621, 0.00515898190585626, 0.005158981021822552, 0.005158980138723494, 0.005158979256558039, 0.0051589783753251605, 0.005158977495023857, 0.005158976615653336, 0.005158975737212323, 0.00515897485970005, 0.005158973983115454, 0.005158973107457569, 0.0051589722327255285, 0.005158971358918126, 0.005158970486034533, 0.005158969614073753, 0.005158968743034762, 0.005158967872916738, 0.005158967003718458, 0.0051589661354391105, 0.005158965268077676, 0.005158964401633318, 0.0051589635361050335, 0.005158962671491625, 0.00515896180779242, 0.005158960945006221, 0.005158960083132227, 0.005158959222169414, 0.005158958362116765, 0.005158957502973255, 0.005158956644738052, 0.005158955787410162, 0.005158954930988742, 0.005158954075472592, 0.0051589532208608825, 0.005158952367152792, 0.0051589515143471, 0.0051589506624430065, 0.00515894981143969, 0.0051589489613359215, 0.005158948112130887, 0.005158947263823553, 0.005158946416413128, 0.0051589455698985735, 0.005158944724278885, 0.005158943879553233, 0.005158943035720592, 0.00515894219278015, 0.00515894135073091, 0.005158940509571839, 0.005158939669301912, 0.005158938829920315, 0.0051589379914262256, 0.005158937153818439, 0.00515893631709632, 0.005158935481258634, 0.0051589346463045815, 0.005158933812233369, 0.0051589329790439585, 0.005158932146735317, 0.005158931315306643, 0.005158930484756899, 0.005158929655085081, 0.005158928826290367, 0.005158927998371966, 0.005158927171328822, 0.005158926345159947, 0.005158925519864504, 0.00515892469544171, 0.005158923871890509, 0.005158923049209877, 0.005158922227399005, 0.005158921406456907, 0.005158920586382708, 0.005158919767175428, 0.00515891894883426, 0.0051589181313581485, 0.0051589173147463105, 0.005158916498997901, 0.005158915684111727, 0.0051589148700871505, 0.005158914056923138, 0.005158913244618693, 0.0051589124331730095, 0.005158911622585252, 0.0051589108128544305, 0.005158910003979703, 0.005158909195960042, 0.005158908388794635, 0.005158907582482471, 0.005158906777022736, 0.005158905972414622, 0.005158905168657083, 0.005158904365749342, 0.005158903563690351, 0.005158902762479295, 0.005158901962115368, 0.005158901162597544, 0.00515890036392498, 0.005158899566096703, 0.0051588987691118604, 0.005158897972969683, 0.005158897177669095, 0.005158896383209302, 0.005158895589589497, 0.005158894796808666, 0.005158894004865991, 0.005158893213760433, 0.0051588924234911866, 0.005158891634057428, 0.005158890845458351, 0.005158890057692947, 0.00515888927076037, 0.0051588884846596236, 0.0051588876993901, 0.005158886914950735, 0.005158886131340563, 0.005158885348558944, 0.005158884566604852, 0.005158883785477286, 0.0051588830051756485, 0.005158882225698877, 0.005158881447046195, 0.005158880669216766, 0.005158879892209557, 0.0051588791160237756, 0.005158878340658594, 0.005158877566113204, 0.005158876792386589, 0.005158876019477905, 0.005158875247386375, 0.005158874476111176, 0.005158873705651261, 0.005158872936005846, 0.0051588721671740785, 0.0051588713991551766, 0.00515887063194809, 0.005158869865552231, 0.00515886909996656, 0.005158868335190271, 0.005158867571222578, 0.005158866808062411, 0.0051588660457090015, 0.005158865284161716, 0.005158864523419515, 0.005158863763481403, 0.005158863004346745, 0.0051588622460147435, 0.005158861488484388, 0.005158860731754828, 0.005158859975825284, 0.005158859220694929, 0.005158858466362932, 0.005158857712828285, 0.005158856960090361, 0.005158856208148164, 0.005158855457000881, 0.00515885470664769, 0.005158853957087746, 0.005158853208320266, 0.005158852460344428, 0.005158851713159417, 0.005158850966764186, 0.005158850221158146, 0.005158849476340288, 0.005158848732309781, 0.005158847989066032, 0.005158847246607997, 0.005158846504934851, 0.0051588457640457915, 0.005158845023940013, 0.005158844284616694, 0.005158843546074823, 0.0051588428083137764, 0.0051588420713327456, 0.005158841335130691, 0.005158840599707026, 0.005158839865060912, 0.005158839131191346, 0.005158838398097696, 0.005158837665778965, 0.0051588369342345525, 0.005158836203463394, 0.005158835473464908, 0.005158834744238072, 0.0051588340157822585, 0.005158833288096464, 0.005158832561180086, 0.005158831835032086, 0.0051588311096518805, 0.005158830385038409, 0.005158829661191059, 0.005158828938109024, 0.005158828215791311, 0.0051588274942372695, 0.005158826773446116, 0.00515882605341681, 0.005158825334148749, 0.005158824615641141, 0.0051588238978931555, 0.0051588231809039506, 0.0051588224646727104, 0.0051588217491986285, 0.005158821034480899, 0.005158820320518911, 0.00515881960731163, 0.0051588188948582595, 0.0051588181831581864, 0.0051588174722105905, 0.005158816762014432, 0.005158816052569127, 0.005158815343873842, 0.005158814635927763, 0.005158813928730263, 0.005158813222280346, 0.0051588125165772, 0.005158811811620204, 0.005158811107408531, 0.005158810403941163, 0.005158809701217497, 0.005158808999236921, 0.0051588082979984245, 0.005158807597501166, 0.005158806897744562, 0.005158806198727763, 0.005158805500449779, 0.0051588048029101745, 0.005158804106107968, 0.00515880341004231, 0.005158802714712596, 0.005158802020118041, 0.0051588013262577935, 0.005158800633131047, 0.005158799940736974, 0.005158799249074985, 0.005158798558144235, 0.005158797867943925, 0.0051587971784732645, 0.005158796489731408, 0.005158795801717738, 0.00515879511443144, 0.005158794427871716, 0.005158793742037742, 0.005158793056928909, 0.00515879237254438, 0.00515879168888337, 0.005158791005945066, 0.0051587903237288344, 0.005158789642233845, 0.0051587889614593, 0.005158788281404392, 0.005158787602068496, 0.005158786923450805, 0.005158786245550519, 0.00515878556836678, 0.0051587848918990134, 0.005158784216146391, 0.0051587835411081055, 0.005158782866783533, 0.005158782193171841, 0.0051587815202722475, 0.00515878084808412, 0.00515878017660665, 0.00515877950583901, 0.005158778835780384, 0.005158778166430193, 0.00515877749778757, 0.0051587768298519176]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(100 * num_epoch + 1), np.log(np.array(GD_dist)), label=\"GD\")\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "outputId": "039556f9-3367-4ba4-f435-7bbdace0c22d",
        "id": "793WRyUrpks1"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 18
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Polyak Step-size"
      ],
      "metadata": {
        "id": "j6asyVN0pks1"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_polyak = np.copy(theta_init)\n",
        "polyak_dist = [param_err(np.copy(theta_polyak), theta_opt)]\n",
        "for _ in range(num_epoch):\n",
        "  grad = gradient(x, y, np.copy(theta_polyak), p)\n",
        "  theta_polyak -= (objective(x, y, np.copy(theta_polyak), p) - obj_min) / np.linalg.norm(grad) ** 2 * grad\n",
        "  polyak_dist.append(param_err(np.copy(theta_polyak), theta_opt))\n",
        "\n",
        "print(polyak_dist)\n",
        "print(theta_polyak)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "804ce691-d8a9-411d-e7d7-3a492480c1f8",
        "id": "ZzzURBDSpks1"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.4747787871845469, 0.14591268787421713, 0.09211681428180125, 0.07724182848195658, 0.06885695782121204, 0.06273600458372197, 0.05685123612014528, 0.05230861396568638, 0.04758264093740153, 0.044108769229646565, 0.04029514078639468, 0.037663841213776264, 0.034611546391268636, 0.0326563480197828, 0.030240895263352774, 0.028815690628035552, 0.026918834734349556, 0.025889413910519018, 0.024396448683640277, 0.023645063583437268, 0.022451028292507398, 0.021883225460584313, 0.020900277208651074, 0.02044753692324795, 0.019608683321270522, 0.01922587996971413, 0.018484277195115917, 0.018144249350812363, 0.01746961720147027, 0.017157380884646946, 0.016531469047859803, 0.01623949511796116, 0.015651959351756794, 0.01537688696108043, 0.01482216932070237, 0.01456276030748556, 0.014038003508524712, 0.01379397313484619, 0.013297742227982653, 0.013069137726828838, 0.012600684251365804, 0.012387578914170558, 0.011946437185846098, 0.011748795518889339, 0.011334570047412387, 0.011152200974520333, 0.01076445926313024, 0.010597012260732844, 0.010235234138796512, 0.010082214878720358, 0.00974577187396027, 0.009606565698779096, 0.009294716617276403, 0.009168614240859749, 0.008880509895619318, 0.008766732708902703, 0.008501426159853486, 0.008399149921009938, 0.008155610214746978, 0.008063986528758811, 0.007841114649495303, 0.007759289919991774, 0.007555935972187725, 0.007483067647925003, 0.007298048437120444, 0.007233318472052311, 0.007065434751974368, 0.007008060287545177, 0.006856113047908902, 0.006805354416260858, 0.006668159708973748, 0.0066233259415525245, 0.006499727880334887, 0.006460179978551333, 0.006349061687085718, 0.0063142139639013545, 0.006214506380278786, 0.006183826209248067, 0.006094514770088112, 0.0060675210828860186, 0.005987650403418083, 0.005963911259625016, 0.005892587993366738, 0.005871717514741113, 0.005808111619280817, 0.005789766538682537, 0.005733111194762424, 0.005716987224549968, 0.005666577657967731, 0.0056524058368814835, 0.00560759728156485, 0.005595140417964647, 0.0055553454384904225, 0.005544394731287888, 0.005509080096406411, 0.005499451985062771, 0.005468135256181558, 0.005459668527672604, 0.005431914497547023, 0.005424467660498732, 0.005399884750572206]\n",
            "[-0.13378402 -0.53408315 -0.75745514 -1.31546144]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(polyak_dist)), label=\"Polyak Step Size\")\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "outputId": "521d37c4-4300-4d51-f831-eb0ed46bebca",
        "id": "yJqP9ji8pks2"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 20
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYwAAAEPCAYAAABRHfM8AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO3deZSU1ZnH8e9jAw3SbYM0IiCbiuIK4obAjC0SRJEwooCIAkad0VGjxsS4JAGdLE4SRqMzGZO4IKK4BsEoizI2SlTEICgCAsq+I2uDsvUzf9zqpoFuuuil3qqu3+ecOk1VvVXvQ52if9zlvdfcHRERkfIcEXUBIiKSGhQYIiISFwWGiIjERYEhIiJxUWCIiEhcFBgiIhKXpAsMM+tpZl+a2SIzuzfqekREJLBkug7DzDKABcD3gBXADGCgu8+NtDAREUm6FsZ5wCJ3/9rddwEvAn0irklEREi+wGgOLC9xf0XsMRERiViyBYaIiCSpWlEXcICVQIsS94+LPbYfM0uegRcRkRTi7lbR1yZbC2MG0NbM2phZHeBqYHxpB7q7bu4MGzYs8hqS5abPQp+FPotD3yorqVoY7r7HzG4DJgEZwNPu/kXEZYmICEkWGADu/hbwVtR1iIjI/pKtS0oOU15eXtQlJA19Fvvos9hHn0XVSaoL9+JlZp6KdYuIRMnM8EoMeiddl5SI7NO6dWuWLl0adRmSYlq1asWSJUuq/H3VwhBJYrH/EUZdhqSYsr43lW1haAxDRETiosAQEZG4KDBERCQuCgwRSajWrVvzzjvvJM37ROn555+nR48eUZcRNwWGiFRI69atqVevHllZWTRp0oShQ4dSUFAQdVmlGjduHB06dOCoo44iNzeXbt26sXjxYgCGDx/OtddeW23nnjZtGp07dyYnJ4ejjz6aLl26MGPGDAAGDRrE5MmTq+3cVU2BISIV9sYbb1BQUMDMmTP55JNP+OUvfxl1SQdZtGgRgwcPZsSIEWzZsoXFixdz6623kpGRUe3n3rp1K5dffjm33347GzduZOXKlQwbNozMzMxqP3d1UGCISKU1b96cSy+9lDlz5gAwfvx4TjvtNBo0aEBeXh7z5s076DVr1qzhyCOP5Jtvvil+bObMmTRu3Jjdu3fz1Vdf0a1bNxo1akRubi6DBg1i8+bNpZ5/3rx5tGnThjFjxhz03KxZs2jTpg0XX3wxZkZ2djZXXnklLVu2ZOLEifz617/mpZdeIisri/bt2wOwZcsWbrjhBpo2bUrz5s352c9+xt69ewEYOXIkXbp04bbbbiMnJ4d27doxZcqUUutasGABAAMHDiQjI4N69erRo0cPzjzzzOL36tq1KwC//e1vycrKKr7Vrl2boUOHlltPIikwRKTSli9fzltvvcVZZ53FggULGDhwII8++ijr16/nsssuo3fv3uzatWu/1xx77LHk5eXx8ssvFz/23HPPcfXVV1O7dm3cnfvuu49Vq1Yxb948li9fzvDhww8698yZM7nkkkt4/PHHGThw4EHPd+zYkfnz53PXXXfx7rvv7tdt1rNnT+6//34GDBhAQUEBs2fPBmDo0KHUqlWLRYsW8emnnzJ58mSefPLJ4tdNnz6dE044gQ0bNvDggw/St29fNm7ceNC5TzrpJDIyMhgyZAgTJkxg06ZNZX6G99xzDwUFBRQUFDBv3jwaN27MgAED4qonYaJebreCS/S6SDoo77sOVXOriFatWnn9+vU9JyfHW7Zs6bfccovv2LHDH3roIe/Xr1/xcXv37vVmzZr5u+++W/y6t99+293dX3zxRe/cubO7u+/Zs8ebNGni06dPL/V8Y8eO9Q4dOux3/l/84hfevHnz4vcuy4cffuj9+vXz3Nxcz8zM9CFDhvi2bdvc3X3YsGE+aNCg4mPXrFnjderU8R07dhQ/9sILL3heXp67uz/zzDPetGlTLywsLH7+3HPP9VGjRpV67rlz5/qQIUO8efPmnpGR4b179/Y1a9YUv1eXLl32O37Hjh3esWNHf/jhh+OqpzRlfW9ij1f4d6+WBhFJYVFfBP7666/TvXv3/R5btWoVrVq1Kr5/xBFH0KJFC1auPGgvNPr06cPNN9/M4sWL+fLLL8nJyeG8884DYO3atdxxxx28//77bNu2jcLCQho2bLjf65944gkuvPDCchcY7NSpU3FLZsaMGQwYMIBf/epX/OY3vzno2KVLl7J7926aNm1a/FhhYSEtWuzb26158+aY7btgulWrVqxatarUc59yyimMHDkSgPnz53Pttddy5513ltp9BnDDDTdw8skn89Of/jTuehJFXVIiUqWaNWu23/pX7s7y5ctp3rz5QcfWrVuX/v37M3r0aJ577jmuu+664ufuv/9+zIzPP/+crVu3Mnr06IOWu3jiiSdYtmwZd911V9z1nXvuufTt27d4vKXkL36AFi1akJmZyYYNG9i8eTObN29m69atfPHFvq15Vq5cuV8ty5Yto1mzZuWeu127dgwdOrT43Ad6+OGHWbBgAU899dRh1ZMoCgwRqVL9+/fnzTffZMqUKezevZsRI0aQmZlJ586dSz1+8ODBjBw5kvHjx+8XGNu2bSMrK4ucnBxWrlzJ7373u4Nem52dzcSJE3nvvfe49957S33/adOm8Ze//IV169YB4X/548ePp1OnTgA0adKEJUuWUFhYCEDTpk3p0aMHd999N1u3bqWwsJCvvvqKqVOnFr/nunXreOyxx9i9ezevvPIK8+bN47LLLjvo3PPnz2fEiBGsWLECCGM9Y8aMKT53SRMmTOCxxx5j7Nix1KtXr/jxeOpJFAWGiFSpk08+mdGjR3P77beTm5vLG2+8wRtvvEGdOnVKPb5Lly4cccQRdOzYcb+urGHDhjFz5kxycnLo1asXffv2LfX1DRo04O2332bChAn8/Oc/L/X58ePHc8YZZ5CVlUXPnj254ooruOeeewDo168fAI0aNaJjx44AjBo1il27dnHqqafSsGFDrrrqKlavXl38nueffz4LFy4kNzeXBx54gFdffZVGjRoddO7s7GymT5/O+eefT/369enUqROnn346I0aMOOjYl156ifXr13PKKacUz5S6+eab46onUbRarUgSS5fVart168Y111zDjTfeGHUp5Ro5ciRPPvkk06ZNi7qUMlXXarUa9BaRSM2YMYOZM2cybty4qEuRcqhLSkQiM2TIELp3786jjz5KdnZ21OVIOdQlJZLE0qVLSqqWNlASEZFIKTBERCQuCgwREYmLZkmJJLFWrVoddCWySHlKXs9SlTToLSKSJjToLSIiCaHAEBGRuCRNYJhZPzP7wswKzeycqOsREZH9JU1gAHOAvsB7URciIiIHS5pZUu4+Dw5em74se/dCAvZwFxGRmGRqYRyWMvaCFxGRapLQFoaZvQMcW8pTD7j7YS1VuWEDlLL8vIiIVJOEBoa7dy//qPj89rfDKdrSNi8vr9w9fUVE0k1+fj75+flV9n5Jd+GemeUDP3b3Tw5xjI8b53z/+4mrS0Qk1dWYC/fM7AozWwFcALxpZpMOdfw33ySmLhERCZJpltRYYGy8x2/Y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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "BFGS"
      ],
      "metadata": {
        "id": "TEo9Q28Hpks2"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_bfgs_old = np.copy(theta_init)\n",
        "bfgs_dist = [param_err(np.copy(theta_bfgs_old), theta_opt)]\n",
        "val_err_bfgs = [objective(x_val, y_val, np.copy(theta_bfgs_old), p)]\n",
        "Hinv = np.linalg.inv(hessian(x, y, np.copy(theta_bfgs_old), p))\n",
        "grad_old = gradient(x, y, np.copy(theta_bfgs_old), p)\n",
        "theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "\n",
        "for _ in range(num_epoch):\n",
        "  bfgs_dist.append(param_err(np.copy(theta_bfgs_new), theta_opt)) \n",
        "  val_err_bfgs.append(objective(x_val, y_val, np.copy(theta_bfgs_new), p))\n",
        "  grad_new = gradient(x, y, theta_bfgs_new, p)\n",
        "  u = grad_new - grad_old \n",
        "  s = theta_bfgs_new - theta_bfgs_old\n",
        "  Hinv = np.matmul(np.matmul(np.identity(d) - np.matmul(s.reshape(d, 1), u.reshape(1, d)) / u.dot(s), np.copy(Hinv)), np.identity(d) - np.matmul(u.reshape(d, 1), s.reshape(1, d)) / u.dot(s)) \\\n",
        "             + np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "  # Hinv = np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "  theta_bfgs_old = theta_bfgs_new\n",
        "  grad_old = grad_new\n",
        "  theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "\n",
        "print(bfgs_dist)\n",
        "print(val_err_bfgs)\n",
        "print(theta_bfgs_new)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "888d9185-bd47-45e5-a59f-8a84d2c443f9",
        "id": "5GUtvQK9pks3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.4747787871845469, 0.22257190907237734, 0.1207091424349032, 0.03412172186057695, 0.01172741089721569, 0.007501398875467718, 0.0058895590749493, 0.005363595749940147, 0.005142913156499144, 0.005138228225709678, 0.005153495861384474, 0.005156697710208147, 0.005157521689291226, 0.0051581400750093445, 0.005158156581847306, 0.0051581466175153684, 0.005158145713767354, 0.00515814568436685, 0.005158145684403832, 0.0051581456844152634, 0.005158145684415574, 0.005158145684415778, 0.005158145684415778, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan]\n",
            "[0.126825967068719, 0.025769320150043875, 0.013575170117216087, 0.009726156848874927, 0.00936387485416764, 0.0093453328341561, 0.009344128271233989, 0.009344130254059611, 0.009344288872635798, 0.00934437117170738, 0.009344385045057135, 0.009344384955827057, 0.009344384705537067, 0.009344384496203987, 0.009344384488128863, 0.009344384491120085, 0.009344384491429146, 0.009344384491440153, 0.009344384491440183, 0.009344384491440181, 0.009344384491440183, 0.009344384491440181, 0.009344384491440181, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan]\n",
            "[nan nan nan nan]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:14: RuntimeWarning: invalid value encountered in true_divide\n",
            "  \n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(bfgs_dist)), label=\"BFGS\")\n",
        "plt.scatter(np.nanargmin(np.array(val_err_bfgs)), np.log(bfgs_dist[np.nanargmin(np.array(val_err_bfgs))]), s = 20, color='r', marker='D')\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "# plt.xlim([0, num_epoch])\n",
        "plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "outputId": "4afe426e-bf6c-408f-d81c-0f8f6a96bc21",
        "id": "E2PTn4Nepks5"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 22
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Newton Method"
      ],
      "metadata": {
        "id": "bL5tyCjXpks8"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "theta_newton = np.copy(theta_init)\n",
        "newton_dist = [param_err(np.copy(theta_newton), theta_opt)]\n",
        "val_err_newton = [objective(x_val, y_val, np.copy(theta_newton), p)]\n",
        "\n",
        "for _ in range(num_epoch):\n",
        "  grad = gradient(x, y, np.copy(theta_newton), p)\n",
        "  hess = hessian(x, y, np.copy(theta_newton), p)\n",
        "  theta_newton -= np.matmul(np.linalg.inv(hess), grad)\n",
        "  newton_dist.append(param_err(np.copy(theta_newton), theta_opt))\n",
        "  val_err_newton.append(objective(x_val, y_val, np.copy(theta_newton), p))\n",
        "\n",
        "print(newton_dist)\n",
        "print(val_err_newton)\n",
        "print(theta_newton)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "b0b4c194-5ba5-429d-d541-7a729ce356f8",
        "id": "3JfnWcWGpks9"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.4747787871845469, 0.22257190907237734, 0.06144392858831996, 0.00902718991926234, 0.005173107856806542, 0.0051581495026152635, 0.005158145684415763, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778, 0.005158145684415778]\n",
            "[0.126825967068719, 0.025769320150043875, 0.010543060485998564, 0.009362075068906727, 0.009344450446115635, 0.009344384503679531, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181, 0.009344384491440181]\n",
            "[-0.13379742 -0.5341018  -0.75747692 -1.31519742]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(newton_dist)), label=\"Newton\")\n",
        "plt.scatter(np.nanargmin(np.array(val_err_newton)), np.log(newton_dist[np.nanargmin(np.array(val_err_newton))]), s = 20, color='r', marker='D')\n",
        "plt.legend()\n",
        "plt.xlabel(\"Iterations\")\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\")\n",
        "plt.xlim([0, num_epoch])\n",
        "# plt.xlim([0, 100])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 305
        },
        "outputId": "839bea58-6d62-454c-eab9-b314797d9bf8",
        "id": "8iJWyxGXpks-"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(0.0, 100.0)"
            ]
          },
          "metadata": {},
          "execution_count": 24
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.plot(np.arange(100 * num_epoch + 1), np.log(np.array(GD_dist)), label=\"GD\", linewidth=4.0)\n",
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(polyak_dist)), label=\"Polyak Step Size\", linewidth=4.0)\n",
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(bfgs_dist)), label=\"BFGS\", linewidth=4.0)\n",
        "plt.plot(np.arange(num_epoch + 1), np.log(np.array(newton_dist)), label=\"Newton\", linewidth=4.0)\n",
        "plt.scatter(np.nanargmin(np.array(val_err_bfgs)), np.log(bfgs_dist[np.nanargmin(np.array(val_err_bfgs))]), s = 20, color='k', marker='D', linewidth=8.0)\n",
        "plt.scatter(np.nanargmin(np.array(val_err_newton)), np.log(newton_dist[np.nanargmin(np.array(val_err_newton))]), s = 20, color='k', marker='D', linewidth=8.0)\n",
        "plt.legend(fontsize=25)\n",
        "plt.xlabel(\"Iterations\", fontsize=30)\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\", fontsize=30)\n",
        "plt.xlim([0, 100])\n",
        "plt.grid()\n",
        "# plt.savefig(\"HighSNR.pdf\", bbox_inches='tight')\n",
        "# files.download(\"HighSNR.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 307
        },
        "outputId": "39550169-4b17-46d9-d297-4f1560f32eef",
        "id": "CG8d91XKpks_"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import json\n",
        "highSNR = {\n",
        "    'GD':np.array(GD_dist)[:101].tolist(),\n",
        "    'Polyak':np.array(polyak_dist).tolist(),\n",
        "    'BFGS':np.array(bfgs_dist).tolist(),\n",
        "    'Newton':np.array(newton_dist).tolist(),\n",
        "    'BFGS_min_val':np.nanargmin(np.array(val_err_bfgs)).tolist(),\n",
        "    'Newton_min_val':np.nanargmin(np.array(val_err_newton)).tolist()\n",
        "}\n",
        "highSNR_data = json.dumps(highSNR)\n",
        "with open('highSNR_data.json', 'w') as f:\n",
        "  f.write(highSNR_data)\n",
        "# files.download('highSNR_data.json')"
      ],
      "metadata": {
        "id": "PJJGKR-PAwp3"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Statistical Rates"
      ],
      "metadata": {
        "id": "kMhrmft9yGj2"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "tril = np.diag(0.5 ** np.arange(d))\n",
        "\n",
        "max_epoch = 100\n",
        "\n",
        "# theta_opt = np.zeros(d) # For Low SNR\n",
        "theta_opt = np.random.randn(d) / np.sqrt(d) # For High SNR\n",
        "\n",
        "n_range = np.ceil(500 * 1.1 ** (np.arange(50)))"
      ],
      "metadata": {
        "id": "XAnSJtXEyLft"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "err_list = []\n",
        "\n",
        "for n in n_range:\n",
        "  x = np.matmul(np.random.randn(int(n), d), tril)\n",
        "  y = (np.matmul(x, theta_opt)) ** p + 0.1 * np.random.randn(int(n))\n",
        "  x_val = np.matmul(np.random.randn(int(n / 10), d), tril)\n",
        "  y_val = (np.matmul(x_val, theta_opt)) ** p + 0.1 * np.random.randn(int(n / 10))\n",
        "  theta_bfgs_old = np.random.randn(d) / np.sqrt(d)\n",
        "  bfgs_dist = [param_err(np.copy(theta_bfgs_old), theta_opt)]\n",
        "  val_err_bfgs = [objective(x_val, y_val, np.copy(theta_bfgs_old), p)]\n",
        "  Hinv = np.linalg.inv(hessian(x, y, np.copy(theta_bfgs_old), p))\n",
        "  grad_old = gradient(x, y, np.copy(theta_bfgs_old), p)\n",
        "  theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "\n",
        "  for _ in range(max_epoch):\n",
        "    bfgs_dist.append(param_err(np.copy(theta_bfgs_new), theta_opt)) \n",
        "    val_err_bfgs.append(objective(x_val, y_val, np.copy(theta_bfgs_new), p))\n",
        "    grad_new = gradient(x, y, theta_bfgs_new, p)\n",
        "    u = grad_new - grad_old \n",
        "    s = theta_bfgs_new - theta_bfgs_old\n",
        "    Hinv = np.matmul(np.matmul(np.identity(d) - np.matmul(s.reshape(d, 1), u.reshape(1, d)) / u.dot(s), np.copy(Hinv)), np.identity(d) - np.matmul(u.reshape(d, 1), s.reshape(1, d)) / u.dot(s)) \\\n",
        "             + np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "    # Hinv = np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "    theta_bfgs_old = theta_bfgs_new\n",
        "    grad_old = grad_new\n",
        "    theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "  err_list.append(bfgs_dist[np.nanargmin(np.array(val_err_bfgs))])\n",
        "\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "nbEYQ7Pn0qP9",
        "outputId": "66ff4877-2b4f-449d-9e97-b32c69c9b5b7"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:21: RuntimeWarning: invalid value encountered in true_divide\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:2: RuntimeWarning: overflow encountered in square\n",
            "  \n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:6: RuntimeWarning: overflow encountered in multiply\n",
            "  \n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:6: RuntimeWarning: invalid value encountered in matmul\n",
            "  \n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:21: RuntimeWarning: overflow encountered in matmul\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:6: RuntimeWarning: overflow encountered in square\n",
            "  \n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "logarithm_error = np.log(err_list)\n",
        "logarithm_sample_size = np.log(np.array(n_range))\n",
        "slope = (np.mean(logarithm_error * logarithm_sample_size) - np.mean(logarithm_error) * np.mean(logarithm_sample_size)) / (np.mean(logarithm_sample_size ** 2) - np.mean(logarithm_sample_size) ** 2)\n",
        "interception = np.mean(logarithm_error) - np.mean(logarithm_sample_size) * slope\n",
        "print(slope, interception)\n",
        "\n",
        "log_sample_min = logarithm_sample_size[0] - 0.5\n",
        "log_sample_max = logarithm_sample_size[-1] + 0.5\n",
        "x = np.linspace(log_sample_min, log_sample_max, 100)\n",
        "y = interception + slope * x\n",
        "\n",
        "plt.scatter(np.log(np.array(n_range)), np.log(err_list), label=\"error\", linewidth=2.5)\n",
        "plt.plot(x, y, label='slope={:.4f}'.format(slope), linewidth=4.0)\n",
        "plt.legend(fontsize=25)\n",
        "plt.xlabel(\"Log Num of Samples\", fontsize=30)\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\", fontsize=30)\n",
        "plt.xlim([log_sample_min - 0.5, log_sample_max + 0.5])\n",
        "plt.grid()\n",
        "# plt.savefig(\"LowSNR-stats.pdf\", bbox_inches='tight')\n",
        "# files.download(\"LowSNR-stats.pdf\")\n",
        "# plt.savefig(\"HighSNR-stats.pdf\", bbox_inches='tight')\n",
        "# files.download(\"HighSNR-stats.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 324
        },
        "id": "Hu97_FmB7xuV",
        "outputId": "99bc5ca7-3c1c-4be7-92c9-d5e25939ea4e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "-0.7378035422083629 4.3592335518232534\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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Kbi5WKtXr46r3FCSeY4QwXkfz0P3K6C6gbevYsnl55bOB/O117qr3Lmz6hVXqL75pmoig08sVljDMGbMGB0xYoROmjSp1szvDRs26P333x+MfBsavTbeCZLDhg0LjjDbvn27Pvnkk7rbbrspxDdBctSoUcGAjFu2bNEHHnggOIJt6NCh9epevny5du3aVQHt2rWrPv744/rjjz8Gz69atUonTZqkw4YNS2jeTrp55513gkEozzrrLP3mm29U1Sm/wMxziByEskePHhHvRygbNmwIzge54oor4pJt6NChev311+t7772nW7ZsCR7fuHGjTpkyRQ866KCgfA8++GDUsqZPnx5MO3HixLjqv/3224N5BgwYoO+++67u2LFDd+3apYsWLQqOlgN09OjRcZVZl4ZWLAcAgxp4OyCWXPFuwMnAF8Ai4MYIaRK+oPGwa5fqnntqvbFOu++u+otfqE6dqhrmxSxhTLGkzsUXXxz8Y4IL51JSUlLr2NFHH60bN24M5kk0pEtJSUlQQYELthhupndoSJd77703WEbbtm1rhYQ5+OCDdc2aNWHrXrBgge6zzz7BtAUFBdquXbt6YdaTCZiYTuqGzS8pKYk7bH68iiV0cumHH34Yl1yhk0YLCgq0pKRE27ZtWy+M/a233hqzrMAw8d133123bdsWV/3V1dX1Qg4VFhbWCzl03HHH1fqNJkKDKpZc3oAmuB5Xb6AZ8BHQN0y6hC9oPLz/fn2lUndr1071kktUX3lFNc7fWD1MsaTOokWL9P/+7/90+PDhut9++wXjcnXs2FFPOukkfeSRR+r1LOKJbvzBBx/oBRdcoN27d9dmzZppmzZt9IgjjtA777wzovktVLGoqk6dOlVPPvlkbd++vRYVFel+++2n//M//xPThLN161Z94IEHdMiQIdqxY8fgg6hPnz46YsQIffDBByPGGsskH3zwgZ533nnarVs3bdasmXbq1EmHDRsWM1RKvIrlyCOPVEAPPfTQuGWaO3eu/ulPf9KTTjpJe/fura1atdLCwkJt3769HnnkkXrzzTfrokWLYpazbt06LS4uVkCvvfbauOsPMHXqVD3nnHO0Z8+e2rx5c23atKl26dJFTz31VH3qqadimuCi4adiEXcuPxGRI4FyVf2p9/0mAFX9a510mo7r8Mkn8Le/wUsvQTwThdu0gaFD4eyz4aSToHlzN48l1sgwESGf72NjY8KECYwePZoePXpQVVWVaXGMRkIyzxEvT70lL/N9VFg34OuQ7994xxqEAw+Ep56CVavgxRfhoouc8ojE+vXw+ONw5pnQsSOcfz7MmAEhw/0NwzCynphTTUWkL9ChAWQJZY2qLmjICsvKyoLrX5SUlNCvX79gTyEw+z3Z7++9V0nr1vDYY4PZvh3uvLOSykp4//3BuHlUlZ4Ug73PSjZsgH/9azAwmL/8pZIjjoArrhjMqafCnDm1yzcMw/CLaM+zyspKJkyYABB8XoYjpilMRBYDkUtID1Wq2jvVQjJtCovFjh1QWQmTJsHzz0M8UwCKi+GUU5y57LTTYLfdzBSWb5gpzMgEDWoKU9XeqlrQwFvKSsVjDrC3iPQSkWbAOcCLPpWdMk2bOl/KAw/A8uXw5ptwxRUQMnmamt6MY8sWeO45OO88Zy4bOrQhJTYMw4hNXjvvAUTkVOAu3AixR1T1z2HSZKTHEonqanjnHZg8Gf71r0rWrBkcI4f1WAzDSA0/eyx5r1jiIdsUSyi7dsF77zlz2eTJ4C0dUQdTLIZhpIYpFp/JZsUSiirMnQvPPuuUTE1oIlMshmGkhikWn8lmxRJpHosqzJ/vejJ/+YspFsMwUsPmsRiIwCGHwJ/reYwMwzAyi/VYyO4eSzzYcGPDMFLFeiyGYRhG1mKKJcuJtea9YRhGtmGKxTAMw/CVhHwsItJEVatDvheo6q60SNaAmI/FMIzGTkZ8LCIiwHIROcj7fizw34SkMAzDMPKeuBWL90p/J/A779DNwN/TIZRRg/lYDMPINRL1sdwK7C4iQ4FNqjo+DTIZhmEYOUxcPhYReQ4oAlbilvg9C/gXbj2XjsBmVT07jXKmFfOxGIbR2PHTxxJzoS+P+3EKZSVwLLA38B5uDfmOwPaEpDEMwzDylkRHhXUHXgaOB2YAR6vq92mSrcHI5h6LrXlvGEZDkMmZ908Cj6vqWmAK8GiC+Q3DMIw8J1HF8h7wgLd/O/Cxv+IYdbF17Rueqqoqrr76avbff39atWpFixYt2G+//bjqqqtYFmZBnAkTJiAiwTXAp0+fzrBhw+jSpQtNmjShrKwMgPLyckQkeE8nT57MkCFD6NixIwUFBZSXl9cqd968eVx00UX06NGD5s2b07ZtWwYOHMhdd93Ftm3bwsoeryyGkU7i9bEAoKo3hOyvAf7ou0RGTjJjxgwmTZrEtm3bOProoznvvPMoKMi9wA5PPfUUl156afDBXVRUREFBAV988QVffPEFjz76KJMmTWLIkCFh8999991cc801qCpt2rShSZMmYdNdd9113HHHHYgIJSUl9a7VnXfeyXXXXRc0TbRp04ZNmzYxa9YsZs2axaOPPsqrr75Kly5dIrYlXlkMw3dUtdFv7jJkJ9OnT4+ZJtPy/+Mf/1Cg1nbuuefqrl27MipXokydOlULCgq0sLBQf/e73+mSJUt0165dumvXLv388891xIgRCuhuu+2mS5cuDeZ79NFHFdDmzZtrkyZNtKysTJctW6aqqjt37tRFixapqurYsWMV0FatWimgN9xwg65atUpVVbdu3apVVVWqqvrSSy8Fr+PQoUN18eLFqqq6bds2ffzxx7V169YK6MCBA3Xnzp212hCvLIZRl2SeI16e+s/UcAcb25bpB3M00q1Yqqur9fXXX9d77rlHn332Wd20aVNC+ZctW6aFhYUhSqVZcP/pp59OWq6Gprq6Wvfee28F9IEHHoiY7swzz1RAr7rqquCxwMMc0LPOOiti3oBiAfTaa6+NmK60tFQBPeaYY+opDlXVF198MVjOs88+W+tcvLIYRl1MsTQixRIPycq/bds2HTp0aK2exr777lvrbTwWkydPDsk/RWGtQhMF9Ne//nXCMn3yySf67LPP6owZM8I+VNPF9OnTFdAOHTpodXV1xHSTJk1SQPfbb7/gsdCH+Zw5cyLmDSiWgoICXblyZdg0H330UbCs1157LWJZAwYMCKs84pXFMOrip2JJyMdi5Bd//vOfmTJlSq1jX3zxBRdddFHcoWSKi4tDvk0HNgPVYc5Fp7q6mssvv5x//vOfwWM/+clPePnll+nQoUPc5STLO++8A8D69evp2rVrxHTbt7spW0uXLq13rri4mEMPPTRmXX369KFjx45hz82dOxeAwsJCBg0aFLGMk046iffffz+YPllZDCMd5J53tZGRzlhhL7/8sre3F/AFMByAt956iw0bNsRVxrHHHhvyIL4LOBeAJk2aMGLEiLhlueuuu2opFYDZs2dzySWXxF1GKixfvhyAHTt2sHLlyojbDz/8AMCWLVvqldG+ffu4BixEUioAq1atAqBDhw4UFRVFTLfHHnvUSp+sLIaRDuyX14jZtSuw4kEz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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import json\n",
        "lowSNR_stats = {\n",
        "    'log_error':np.log(err_list)[:101].tolist(),\n",
        "    'log_sample_size':np.log(np.array(n_range)).tolist(),\n",
        "    'slope':slope.tolist(),\n",
        "    'interception':interception.tolist()\n",
        "}\n",
        "lowSNR_stats_data = json.dumps(lowSNR_stats)\n",
        "with open('lowSNR_stats_data.json', 'w') as f:\n",
        "  f.write(lowSNR_stats_data)\n",
        "# files.download('lowSNR_stats_data.json')"
      ],
      "metadata": {
        "id": "5GQ6acPyA_2s"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import json\n",
        "highSNR_stats = {\n",
        "    'log_error':np.log(err_list)[:101].tolist(),\n",
        "    'log_sample_size':np.log(np.array(n_range)).tolist(),\n",
        "    'slope':slope.tolist(),\n",
        "    'interception':interception.tolist()\n",
        "}\n",
        "highSNR_stats_data = json.dumps(highSNR_stats)\n",
        "with open('highSNR_stats_data.json', 'w') as f:\n",
        "  f.write(highSNR_stats_data)\n",
        "# files.download('highSNR_stats_data.json')"
      ],
      "metadata": {
        "id": "KaYEq3SFC99o"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Error Bar...?"
      ],
      "metadata": {
        "id": "5SRHJ2WtFzLZ"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "tril = np.diag(0.5 ** np.arange(d))\n",
        "\n",
        "max_epoch = 200\n",
        "\n",
        "theta_opt = np.zeros(d) # For Low SNR\n",
        "# theta_opt = np.random.randn(d) / np.sqrt(d) # For High SNR\n",
        "\n",
        "n_range = np.ceil(100 * 1.2 ** (np.arange(25)))\n",
        "num_repeat = 40"
      ],
      "metadata": {
        "id": "kaASSpgsFy-I"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "err_list = []\n",
        "\n",
        "for n in n_range:\n",
        "  err_i = []\n",
        "  for _ in range(num_repeat):\n",
        "    x = np.matmul(np.random.randn(int(n), d), tril)\n",
        "    y = (np.matmul(x, theta_opt)) ** p + 1 * np.random.randn(int(n))\n",
        "    x_val = np.matmul(np.random.randn(int(n / 10), d), tril)\n",
        "    y_val = (np.matmul(x_val, theta_opt)) ** p + 1 * np.random.randn(int(n / 10))\n",
        "    theta_bfgs_old = np.random.randn(d)\n",
        "    bfgs_dist = [param_err(np.copy(theta_bfgs_old), theta_opt)]\n",
        "    val_err_bfgs = [objective(x_val, y_val, np.copy(theta_bfgs_old), p)]\n",
        "    Hinv = np.linalg.inv(hessian(x, y, np.copy(theta_bfgs_old), p))\n",
        "    grad_old = gradient(x, y, np.copy(theta_bfgs_old), p)\n",
        "    theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "\n",
        "    for _ in range(max_epoch):\n",
        "      bfgs_dist.append(param_err(np.copy(theta_bfgs_new), theta_opt)) \n",
        "      val_err_bfgs.append(objective(x_val, y_val, np.copy(theta_bfgs_new), p))\n",
        "      grad_new = gradient(x, y, theta_bfgs_new, p)\n",
        "      u = grad_new - grad_old \n",
        "      s = theta_bfgs_new - theta_bfgs_old\n",
        "      Hinv = np.matmul(np.matmul(np.identity(d) - np.matmul(s.reshape(d, 1), u.reshape(1, d)) / u.dot(s), np.copy(Hinv)), np.identity(d) - np.matmul(u.reshape(d, 1), s.reshape(1, d)) / u.dot(s)) \\\n",
        "               + np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "      # Hinv = np.matmul(s.reshape(d, 1), s.reshape(1, d)) / u.dot(s)\n",
        "      theta_bfgs_old = theta_bfgs_new\n",
        "      grad_old = grad_new\n",
        "      theta_bfgs_new = theta_bfgs_old - np.matmul(Hinv, grad_old)\n",
        "    err_i.append(bfgs_dist[np.nanargmin(np.array(val_err_bfgs))])\n",
        "  err_list.append(err_i)\n",
        "print((np.array(err_list)).shape)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "1AqUaQ-qMaZC",
        "outputId": "cea36600-6572-4530-efa8-e92c4d572894"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:23: RuntimeWarning: invalid value encountered in true_divide\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:23: RuntimeWarning: divide by zero encountered in true_divide\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:23: RuntimeWarning: invalid value encountered in matmul\n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:2: RuntimeWarning: overflow encountered in square\n",
            "  \n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:6: RuntimeWarning: overflow encountered in multiply\n",
            "  \n",
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:6: RuntimeWarning: invalid value encountered in matmul\n",
            "  \n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "(25, 40)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "logarithm_error = np.log(np.median(np.array(err_list), axis=-1))\n",
        "logarithm_error_high = np.log(np.percentile(np.array(err_list), 75, axis=-1))\n",
        "logarithm_error_low = np.log(np.percentile(np.array(err_list), 25, axis=-1))\n",
        "logarithm_sample_size = np.log(np.array(n_range))\n",
        "print(logarithm_error_high)\n",
        "print(logarithm_error_low)\n",
        "slope = (np.mean(logarithm_error * logarithm_sample_size) - np.mean(logarithm_error) * np.mean(logarithm_sample_size)) / (np.mean(logarithm_sample_size ** 2) - np.mean(logarithm_sample_size) ** 2)\n",
        "interception = np.mean(logarithm_error) - np.mean(logarithm_sample_size) * slope\n",
        "print(slope, interception)\n",
        "\n",
        "log_sample_min = logarithm_sample_size[0] - 0.5\n",
        "log_sample_max = logarithm_sample_size[-1] + 0.5\n",
        "x = np.linspace(log_sample_min, log_sample_max, 100)\n",
        "y = interception + slope * x\n",
        "\n",
        "plt.errorbar(np.log(np.array(n_range)), np.log(np.median(np.array(err_list), axis=-1)), yerr=np.concatenate([(logarithm_error - logarithm_error_low).reshape(1, -1), (logarithm_error_high - logarithm_error).reshape(1, -1)], axis=0), label=\"error\", linewidth=4.0)\n",
        "plt.plot(x, y, label='slope={:.4f}'.format(slope), linewidth=4.0)\n",
        "plt.legend(fontsize=15)\n",
        "plt.xlabel(\"Log Num of Samples\", fontsize=20)\n",
        "plt.ylabel(\"$\\log \\|\\\\theta - \\\\theta^*\\|$\", fontsize=20)\n",
        "plt.xlim([log_sample_min - 0.5, log_sample_max + 0.5])\n",
        "plt.grid()\n",
        "# plt.savefig(\"LowSNR-stats-error-bar.pdf\", bbox_inches='tight')\n",
        "# files.download(\"LowSNR-stats-error-bar.pdf\")\n",
        "# plt.savefig(\"HighSNR-stats-error-bar.pdf\", bbox_inches='tight')\n",
        "# files.download(\"HighSNR-stats-error-bar.pdf\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 676
        },
        "id": "FJfmicMMOHQd",
        "outputId": "8aa163c2-85ff-4b7f-b6d0-3be2d1102c06"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[ 0.32406005  0.30610062  0.27702682  0.20346113  0.21485816 -0.08072777\n",
            " -0.02740603  0.01892839 -0.15594215 -0.35125652 -0.31646208 -0.06504037\n",
            " -0.1852926  -0.42609506 -0.37614909 -0.44286564 -0.5039669  -0.56246083\n",
            " -0.50085631 -0.61908133 -0.5114214  -0.85089697 -0.78423399 -0.92876785\n",
            " -0.86934683]\n",
            "[-0.48701158 -0.38668874 -0.59832964 -0.61263163 -0.71783259 -0.65858959\n",
            " -0.76725324 -0.71452547 -0.73388148 -0.90192153 -1.02166462 -0.83458581\n",
            " -1.171761   -0.93522932 -0.99216668 -1.30770886 -1.24234807 -1.06410015\n",
            " -1.26169966 -1.69967023 -1.44693952 -1.70208665 -1.48993647 -1.49040802\n",
            " -1.63461984]\n",
            "-0.2737278770426747 1.178908992855058\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    }
  ]
}