{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.rc('font', family='serif', size=8)\n",
    "plt.rc('text', usetex=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def update(x, gamma, m):\n",
    "    return x + gamma / (1 + np.exp(x) / m)\n",
    "\n",
    "def multiple_update(gamma, m, n):\n",
    "    x = 0\n",
    "    for i in range(n):\n",
    "        x = update(x, gamma, m)\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "m = 10\n",
    "\n",
    "Q = 100\n",
    "gammas = [1e-3, 1e-1, 1e0]\n",
    "\n",
    "f = np.zeros((Q, len(gammas)))\n",
    "x = 0\n",
    "for j in range(len(gammas)):\n",
    "    for i in range(Q):\n",
    "        f[i, j] = x\n",
    "        x = update(x, gammas[j], m)\n",
    "\n",
    "f /= np.sqrt(np.sum(f**2, axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAOQAAACsCAYAAABrXACMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAkIElEQVR4nO2deXxTZb7/3+mWLtCmG0tpKU2ostOGooOjjiOtqOM2UIriLNe50l6v2wwKWH7u3hlg8Doj6lxZRufOXIUuuI3LOE1VXEakS4qAINi0QClLaZN0b9Pk/P44NtANkjZp0uZ5v155Nef0nOd8e5pPnu95nu/z/SokSZIQCARegZ+nDRAIBOcQghQIvAghSIHAixCCFAi8CCFIgcCLEIIUCLwIIUiBwIsI8LQBw4nNZqO2tpaxY8eiUCg8bY5gFCNJEk1NTcTFxeHn53i/51OCrK2tJSEhwdNmCHyI48ePEx8f7/DxPiXIsWPHAvJNCg8P97A1gtFMY2MjCQkJ9s+co/iUILvd1PDwcCFIwbDg7KORTwlyIKxWKxaLxdNmuITAwED8/f09bYbPYLHaCPR33diozwuyubmZmpoaRkuMvUKhID4+njFjxnjalFFNa2cXT75zgJZOKy/ekeqyQUKfFqTVaqWmpobQ0FBiY2NH/MirJEnU1dVRU1NDcnKy6CndxOHTTdz7WjlHzjSjUMD+qzXMjo9wSds+LUiLxYIkScTGxhISEuJpc1xCbGws1dXVWCwWIUgXI0kS+aXHeeKdA7RbbMSOVfL8shSXiRF8XJDdjKSeccuWLajVasrLy1m9enWf34+kv2Uk0dzRxaNv7uOtiloArkqO4Q/LUogZo3TpdYQgRxjp6ekAFBQUeNgS3+FArZn7XtdTdbYFfz8FKzMu4Z4fafDzc/2XnxDk90iSRJvF6pK2QgL9++2pCgsLWbduHWVlZfZ93T2ewWAgOzv7om1HRUWh0+nQaDQusVUwMJIk8bfdR/mvdw/SabURFxHMpjtSSZsS5bZrCkF+T5vFyozHP3RJW988vYjQoL63NjMzk82bN9u3dTodIPd6hYWFFBYWkpmZiU6nw2Aw9Dg3KyuL0tJS1Go1mZmZZGRk9OuyClyDuc3CIzu/5oP9pwBInz6OjZlziQwLcut1hSA9SHl5OVqtFgCVSkVRURGZmZl2t7Q3arXaLuKlS5cOm52+hv6Ykfu366kxthHor2DN9dP49yuThuX5XAjye0IC/fnm6UUua8tRTCaTw8eq1WqH3FrB4JAkiW2fVbHhH4foskkkRIXw4h1a5iaohs0GIcjvUSgU/bqZ7kSr1dpdU5PJxPz584f1+oJzNLR08nDBXj46dAaAn8yeyLolswkPDhxWO8R6yGGk+9mwsLAQkJ8dTSaTfX9mZqaHLfRNSqobuPH5z/jo0BmCAvx45rZZvLg8ddjFCKDwpbysjY2NREREYDabCQ8Pp729naqqKpKSkggODva0eS5hNP5N7sJmk/ifXZU8V3QYq01CHRPGi8u1zIgb+sKD3p81R/GYy9rdSzQ0NKBWq/sdyDCZTGzZsgWgx4ji0qVLyc3NBSAvL48NGzYMg8WC0URdUwcr8yv47MhZAH6aOon/um0WYUrPPsV55OoGg4GioiL7FEBGRka/gtTpdNTX1xMdHd3n/IULF5KWliYmyAVO88V3Z3lwRwVnmzsIDvTj6VtnsXRevFdEOXlEkDqdDpVKZd9WqVTodLo+oszMzKShoaHPSGRubq5Dz1sdHR10dHTYtxsbG4dkt2Bk02W1san4CC98/B2SBJeMH8NLy7Ukj3duEbE78YggKysre/R6UVFRTg3/l5SUALK7Cww4FbBu3TqeeuqpwRvqhRQWFpKXlyc8Ayc5ZW7ngR169lTJn5nb5yfwxM0zCQnyrgB8r5n26BaXI5z/zKjRaMjKyurR43aTm5vLypUr7dvdaRVGMpmZmeTl5XnajBHFx9+e4aH8vTS0dBIW5M/vFs/m1pRJnjarXzwy7dE7DrN7YMcRCgsLWbNmjX1bpVL1CTPrRqlU2tN1XDRthyRBZ4trXgMMXBcWFjJv3rwe+7Zs2YJOp7MPXglch8VqY90HB7nr1RIaWjqZGRfOuw9c5bViBA/1kOnp6T1EZTAY7M+PJpOp396uG7Va3eP3JpPJHn42JCyt8Lu4obcDsLYWgsL67B5qLOuF7ougJzXGVh7Yrqf8mAmAXy5IJPfG6QQ7EUXlCTwiSLVazbJlyygsLKShocE+hQEwb948ysrK7AM9RUVFmEwme1C1Vqu1f3hLSkooKiryxJ/gEpyNZYVzwQX9DYIJZP554BSrCr/G3GZhbHAAv18yhxtmT/S0WQ7hsWfIgUZJKysr7e/T09P7/dB1n+vSyJbAULlnc1VbDuLMYBbI9+T85VuCc3R0WVn/wSFe/aIagLkJKl68I5WEKMf/H05hs0LjCVBNdlmTXjOo43EUin7dTHciYlldx9H6Fu57Xc++E2YA7r4yidXXTyMowEXDJJIEpmNwokx+1erh5F7w84c1R+XPjwsYsrXFxcWkpaVxzz33UF1dDcDOnTu55557htr0qEPEsrqH974+yU2bPmffCTOq0ED+/Ms0Hr1pxtDE2NEMhl3w6UZ4/XZ4NhmenwOFd8GXL8LRL6CzGaxd0OgizwoXxLI+8sgj5OTkYDAY2Lx5M2vXriUlJYXk5GSOHDniKjtdgohlHV20W6w88+43vPbVMQDSEiPZdEcqcSonE5ZJEhir4fgeOP6V/PPMAZBsPY/zC4AJsyFOC5O0MGkexFwi95K98Fgs6/z580lKSiIpKYmFCxeyceNGJEkSI4ICt1JZ18y9r5Vz6FQTAP95jYaVGZcQ4EjSYpsVTu+Ho1/CsS/h2G5oPtX3uIgEiJ///SsNJsyBQPd+ybnkGfLZZ5/l4YcfBmDVqlUUFxf3GJwRCFzJW/oTrH1zH62dVqLDgnhuWQo/uiR24BOsXXBqL1R/DtVfyALsMPc8xi8QJs6FyT+AhMsg/jIIH/6R2SELcsmSJRQXF/fYt3DhQjESKHA5bZ1WnnhnP/mlNQD8QB3F87enMj68V69ls8HpfVD1qfw6+iV0NvU8JmisLLzEBTD5CtkFDfR8bl6X9JALFy7ssy8pKckVTQsEQM9s4X4KuP/aZB5YmIx/dypGYzVUfgyGT2QRtvUKxQyOgMQfyq8pP4Txs8Hf+yYZvM8igeA8emcLHzdWyfO3p7IgIRiO/AO+00HlR9DQK3wyaIwsvqSrIekqGD+r38EXb8MhQZrNZrZs2YJCoXC4KI1CoSA7O3vElH2TJIm2rjaXtBUSEOK2vKy+RHNHF//vzX28XVELSGQldfD4pUcY88ULcPRfYO08d7BfgDz4ov4xqK+RXVD/4U/BMVQcEmRERASrVq1yty0epa2rjctfv9wlbX21/CtC+4nWcTSWVQDf1Dby4Gt7iDGW83hgOYvH7Ed18jicPO8gVSJMTYepC2HKVRA8Mr78L4TDPWTvgRtHSE9PHzE9pCcYKJbVl5E6mvjsgx0Yy9+iUFFORFCr/Is2wD9IdkMvWQRTMyBa47IIGW/B4R4yNTXV6cZHkhhDAkL4avlXLmvLUZyNZR2VtJng2w+w7H8TKj/iaslijyGzhcbgd8kiuPQG2RVVes/qfnfg8KDOaB81VSgU/bqZ7sSnY1nbzXDoPTjwpjw6arPQ/cR3VBqPOXERsxcuxy/hshExGOMqHA72Ky4uZtu2be60ZdTj87GsljZZgDvuhI1T4a174Mg/wWbhsBTPH7sW84ugP9Dwq93M+dULKBIX+JQYwYke0mAw9Fg0W1FRQUpKijtsGrWkp6f3iWDqTm85atc22mxw9HPYmwffvN1jgt4afQnv2Rbw/KlZVEqTWDRzPC9kziUiZOSNjroKhwVZWVmJwWBg27ZtpKWlodPphCAFA9NggIrtsHcHmI+d2x8xGWYv4Zvo61jxjzZOmNsJ8vfjqZ9M5xcLEr0iFWNvJEmi2dKMucNMY2cjjZ2N9vetllZ+OfOXLruWw4Jcv349er0enU7H6tWr0el0bN68Ga1Wy/z589FqtaSlpY2ogZxuRlPydo/+LZY2OPh3KP8rVH92br8yAmbeBnNvxxZ/OVs/r2Zjwbd02SQSo0N58Q6tS8uCX4i2rjZM7SZMHSaMHUbMHWZMHfJ2Y0ejfdvcabZvN3Y2YpUGrh26fPpyAv1c06s7FamTmppKamoqq1atYuvWrfaaheXl5bz88suUl5cTGRlJTk4Od999t0sMdCeBgYEoFArq6uqIjY31ym9nZ5Akibq6OhQKBYGBw+j21R2Gsleh4nVoN32/UwGaayH1Trj0JxAYTENLJw/9tYyPv60D4KY5E1m3eDZjB1lDwybZaOxopKG9wf4ythsxdhgxdZhoaG+wi6+hvQFzh5l2a/ug/0ylv5KIoAjCleGEB4Xbf1qsFpcJ0i21PYqLi9Hr9fYVIN5Cf2vUmpubqampGTW9pEKhID4+njFjxrj3QtYu+PZ9KNkqx452E5EAqT+HlOWgOpdyc09VAw9s13OqsR1lgB9P3DyTOy5L6PMl2GXrwthu5GzbWc62naW+vZ76tnr7z97iu1DPNRABfgGolKoerwhlBBHKCPt2t+C6fxceFE5wgONLr7yqtkdOTg7/8R//4Y6mXc6YMWNITk7GYrF42hSXEBgYiL+/G0cmWxug/H9hzzZolFddoPCDS66HtF/JveJ5I6M2m8SfPvmO54q+QfJvYvJEC3f9KAqUn7NJX8eZ1jPUt9VT11bH2bazGNuNSDj35Tg2aCxRwVFEKiOJDI6U3wdHolKqiAqOsouse19YYJjXekNu6SG7V6x7G4P91hIA9ZWw+0+yW2r5PnomNBq0v6Q99U5OBQRwqvUUp1tOc7r1NKdbTnOs8SR7T1bTYjXiF9Ds8KX8FH5EKiOJCYkhOiRa/hkcTVRwFNEh535GKmXxBXphzKpX9ZCOiHEo1a8cOVfgGqSaUsyfP8sJQzG1Af7UhgRwcvxUTkYnctLfn1NnizG+WzhwAwo57hsg0C+Q2JBYxoWOIzY0lpiQGMaFjiM6OJrY0FhiQ+R9KqUKfx+bf+xmxFW/cvRcgeNYrBZONJ/geNNxjjcdp6aphpoze6mpP8gJWwetfn4wacJ5Z3RCY898SSEBIUwMm8i40PHUm0I4cFyBzRLOxDETeHTRD0hLmEKkMtJrXUVvwSPLr4ZS/crRc0FUvzofq83KyZaTVDdWc7TxKNVm+eexpmOcbDmJrXdCp2785GCuGKWKuPDJxIXFMXHMRPln2EQmhE1gQtgEwoPCOdPUwYM79JQb5MXBy9ISePIW7yto4814ZPnVUKpfOXPuaKx+dTEsNgtHzUepNFdSaarEYDZgMBs4aj5Kp61zwPNC/IKIt9pIaG0koauLSVaIn3INk9JyiJuovegI467DdazMq6C+pZPQIH9++9NZ/DQ13tV/3qjHa5ZfOVP9ytFzR2P1q24kSeJs21kONRziW+O3HDYe5ojxCNWN1XTZuvo9J9AvkMTwRKaETyExPJHE8EQmt7cxufxvxFT+CwVAQLA8WvrDB2HshH7bOZ8uq43/LjrM/3wihwROnxjOS8tTUce6edpllOKR5VcajaZHr+ZM9StnzlUqlSiVSoft9VYkSeJUyykO1B/gQP0BDtYf5GDDQRra+/8iCgsMQx2hRqPSoInQoFapSQpPIm5M3LnBkrPfQfGTcmQNyGsN590FV610SIgAtaY2Htyhp6TaCMCdl0/msZtmeH1BG2/GI8uvhlL96kLnjhZaLa3sP7ufiroK9tXtY9/ZfdS31/c5zk/hx5TwKVwadSmXRF5CsiqZ5MhkJoZNHHjwpKUedq2H0lfA1iXPIc5dDtescapGxUeHTvNQ/l6MrRbGKANYv2Q2N81xUfUwH8Yt85COcP7URVRUlH3pkUaj6VH9avPmzZhMJnJycuzHDHTuxfDWeUhzh5nS06WUnipFf0bPoYZDfSJQAhQBTI2cyszomUyPms706OkkRyY7vhjaaoGSbfDJOnktIkDyIsh4CsZNd9hWi9XGxg+/Zcun8sqfWZPCeWm5lsTo4a2L4u0M9rPmkCDNZjPr1q1DoVCwbNmyEbvKw1sE2d7VTvmZcnbX7mb3yd0cajjUJzplfOh4UsalMCdmDnNi5zAtappToVs9MOyCD1ZD3aHvG58Ni34L6h851czxhlYe2KFH/33NxX+7Ygq5N05DGSBc1N64VZDns3PnToqKipg6deqIyioHnhXkyeaT7KrZxa6aXZSeKu0T5JwUkUTa+DTmjZ+HdpyWiWNckDW76RR8uBb275S3Q6Nh4eNyrKmTE+8fHjjFqoK9NLZ3ER4cwO8z53L9LMeeNX2RYRNkN91zkwaDgYyMDBYvXjyYZoaV4RZktbmaD6s/pPhYMQcbDvb43biQcSyIW8AVcVdw2cTLiAmJcd2FbTYoewV0T0FHo/ycOP9u+PFaCIl0qqnOLrkseHfNxZQEFS+4s+biKGHYBXk+er2evLw8r3dph0OQZ1rP8L7hfd6ver+HCP0UfqTEpnB1/NVcHX81U1VT3RO1UncY3rkfju+Wt+O0cNMfIC7F6aaO1bdy3/Zyvq6RnzlXXJXEqkUurLk4ivGoIM/nfJd2JCy/cgVdti521exi5+GdfFH7hT3qJUARwOUTL+e6KddxTcI1RAVHueyafbB2wZcvwMfrwNohZ+5e+LjcMw4iLvT9fSdZU/g1TR1dqEIDeTZzLukzxrvB8NGJ1wiyG7PZTETE8KwCdxRXC9LUbqLwSCE7Du3gdOtp+/6U2BRu1tzMdYnXoQpWDfk6F+XsEXgzR67sC3LO0pv+0GM9oqO0W6z89r2D/G33UWAINRd9HK9a7QF4nRhdyemW0/zlwF/YeWSnvfxApDKS25JvY/HUxUyJmDI8hkiSPJXxz8egq01OlXHDeph7x6ASCFedbeHe18r55qQc83vP9zUXAx2puShwCU4Lsrq6moKCAoqKijAajfb9UVFRZGRkkJmZyZQpU1xpo9fQ0N7A1q+3kv9tvj0udFrUNH42/Wdcn3Q9Sv9hjApqroO3/1NOowhyTYtbX4KISYNq7u2KE6x9Yx8tnVaiwoJ4Lmsu11w6zoUGCxzBKUE+8sgjKBQKsrKy+g021+v1vPzyyygUCtatW+cyIz2NxWrhtYOv8fLXL9NiaQFAO05LzpwcFsQtGP4lRZUfwxvZ0HIG/JWQ8TRclm1fmeEM7RYrT/39G7bvkTPDXZYUxabbU5kQMbrLoXsrDj9Dbty4kezsbIdcUbPZzPr1671OlIPx6/Vn9Dz5rycxmOXIlOlR0/m19teeEaK1Sw57+/RZQILY6ZD5CoyfMajmvjvTzH2vy2XBFQq478dTeXBhsmNlwQUXxOsGdbwRZ25Sp7WTTeWb+Os3f0VCIio4it/M+w23aG7BT+GBD2zzGSj81bn0ivP+Da5fP+iqv2+U1/DoW/tp7bQSM0bJH5elcGWyC+dCfZxhHdSpqKiwLxxWqVQjNh/rQNQ01bDyk5X2ecTbpt7Gw2kPE6H00EDV8T2Q/wtoOilPZ9z8PMweXNmBtk4rj7+9n4IyOUHVFZpo/nh7CuPGChfVG3BYkGazmRUrVqDT6YiKOjef1tDQgEKhIC0tjYKCghEvzJJTJfz641/T2NmISqni6Sue5seTf+w5g0pfhfdXgc0CMZfCsr9B7KWDaqp3WfAHFiZz/7XnlQUXeByHBbl161Y2bNgw4DIsg8HAunXrvO650Rk+qPqAtZ+vpcvWxeyY2Tx3zXNMCPNQvKbVAh+sgdI/y9vTb4Hb/jSocmySJFFQWsPj7+zvWRZcE33xkwXDilPrIS+0JlKtVpOWluYSozzBW9+9xeNfPI6ExHWJ1/HbK387+NUVQ6XNKLuoVZ8CClj4GFy5clBziy0dXTz61n7e1J8A4KrkGP6wLIWYMSN/4fZoxKnqVxejpKSEJUuWDMkgT1BpqrSLcUnyEh5f8LhnBm5ALlLzWhbUH4HAMFiyDabdOKimDp5s5N7XyzHUteCngIeuu5R7fqTBT7ioXovDgszMzCQtLQ2FQtHnGbKbgoIC11o3TGhUGh5Ke4ja5loeuewRz6UqPF4C25dBaz2Ex8PyHTBhttPNSJLE9j3HeervB+josjEhPJhNd6RyWZIbY2kFLsHpaY+qqip0Op09r41KpSI9Pd0rM5X35mJD0ZIkeU6Mh96XpzW62mDiXFie73Bum/Np7uhi7Rv7eGdvLQDXXBrLc1kpRIUFudpiwQVwe8YAo9HoVEhcdw5Ubxp19ZaMAX0o+wu8+xuQbHJajcxXQOl81rb9J8zcv11P1dkW/P0UrF50KSuuUgsX1QO4dR4yIiKC/Px8oqOjHVqIvHPnToxG44goSedRJAk++2/46Bl5O/XncNMfwd+56WFJkvi/3Ud55t2DdFptxEUE88JyLfMSnVuMLPA8Dv/nV6xYgV6vJysrC41Gw/z581Gr1ahUKkwmEwaDgT179lBVVUVOTs6IHNwZViQJ/vkofPmivH3Vw3Dto06PpDa2W8jduY/39p0EIH36OJ5dOhdVqHBRRyKDCp0zm83k5+dTWVlpj9bRaDRe/yzpNS6rzQbvrZSLnAIs+h0suNfpZvbVmLn39XKONbQS4KfgkRum8e9XJon6GV7AsIbORUREsGLFisGcKrBZ4e17Ye92OdfNzZtA+3OnmpAkib/8q5rfvX8Qi1VikiqEF5enkjpZuKgjHY9UvwLHSsoNdMzSpUvJzc0FIC8vjw0bNgyT1UPE2iWv7N9fCAp/WLzF6ZhUc6uF1Tv38uEBOUPBdTPGszFzLhGh3lcjUTAIpEFQXl4+mNPsVFZWStnZ2fbt9PR0p47RarWSSqWS0tPTJaPR6PB1zWazBEhms3lwhg+FLoskFdwlSU+ES9JTUZJ04G2nm9AfM0o/XF8sJa55V5q69j3plc8Nks1mc4OxgqEy2M+aw+EoFRUVbNu2jYqKCjQaDdu2bRv0l8BAJeUcPSY3Nxej0UhRUdEFyw50dHTQ2NjY4+URbNbve8ad4BcIWX+FGbc4fLokSWz7zEDm//yLGmMbk6NC2XnPFdz1Q/G8ONpw2GUtKipCrVazY8cOysvL0Wg0g57WcKSk3IWOKSkpAc5FCWVnZ/d7Ha8oR2ezwdv3yW6qXwBk/S9M+4nDp5taO3m44Gt0B2UX9cbZE1i/ZA7hwcJFHY04LEi1Ws2SJUvcNp3hSDm67mPOf2bUaDRkZWX121N6vBydJMmjqXtfl58ZM191SoxlR408sF3PCVMbQf5+PHbTdH72g0TRK45iHHZZGxoaWLZsGR999NGQXT+NRtOn7d4l5QY6prCwsEf1K5VKNWDgu1KpJDw8vMdr2OieZyx7FVDIAzgOuqk2m8TmXZUs2/wlJ0xtTIkO5Y3/vIKfL5gixDjKcViQJpOJ7OxsysrKuPvuu1m2bNmgL5qenm53O6FvOboLHaNWq8nIyOhhl1arHbQtbuPTZ89N+t/ygsOjqQ0tndz911LWfXCILpvETXMm8vf7r2TWpNGbVlNwDocDA6qqqqiqquLaa691yYUdKUc30DHd+0tKSsjJyXG42OuwBQaUbIP3HpLfX78efnCPQ6eVVjdw3+t6TjW2ExTgxxM3z2D5ZZNFrzgCcXuSq+LiYqqqqkZ0fOqwCHL/G/KqDST40Rq5wM1FsNkkXv60kv/+52GsNgl1TBgvLtcyI86LAuAFTuH2SB2DwdDjWa2iosJri+p4DMMueXoDSa6pcU3uRU+pb+5gZf5edh2uA+DWlDh++9PZjFF6LGZD4EEc/q9XVlZiMBjYtm0baWlp6HQ6IcjzObUPdtwJ1k6YcSvc8PuLBop/ZajngR16Tjd2oAzw46lbZrJsfoJwUX0Yp4LL9Xo9Op2OoqIidDodGo0GrVbL/Pnz0Wq1Xp8O0m0uq+k4/DlDTtOYeCX8bCcEDpyPx2aT+NMn3/Fc0WFsEmhiw3jpTi3TJnjvvRM4x7AnSt66dStZWVmUlpZSXl5OSUkJ5eXlREZGkpOT45XPmm4RZJsJXrke6g7KmcR/9Q8IUQ14+NnmDn6TV8FnR84CsFg7iWdunUWYcFFHFV6Vuby4uBi9Xj/660NaLfB/S6BqF4ydCHfrICJ+wMO/rKznwR16zjR1EBzoxzO3zmJp2jAGKgiGjcF+1tySWi0nJ8cdzXoXkiSn3ajaJWeHW543oBitNolNxUe4c9tuzjR1kDxuDO/cd6UQo6APbvGTioqKvHqhskv44nnQ/01e07j0VTkxVT+caWrnN3kVfPFdPQBL58Xz1K0zCQ0SLqqgL275VIx6MR58F3RPyu+vXw+XLOr3sC++O8uDOyo429xBaJA/z9w6iyXzBnZpBQLxNe0sJ7+GN1YgzzWugMv7uudWm8TzxUd44aMjSBJcOn4sL92ZytRxzpcBEPgWQpDO0HwGtt8BllbQXCv3jr0409jOgzsq+NIgu6jL0hJ48paZhAT5D7e1ghGIEKSjdHVA3s+gsQaip8pLqXqla/zsSB2/yavgbHMnoUH+/O6ns7ktdXAlxgW+iRCkI0iSHCx+/CtQRsAdeT3mGrusNp4vPsKLH3+HJMG0CWN56U4tmljnkx0LfBshSEfYs/W8EdVXIGaq/VenG9u5f7uePVXy4uk7LpvMEzfPIDhQuKgC5xGCvBjVn8M/HpHfZzwNU89lx/v0sOyi1rd0Ehbkz+8Wz+bWFOGiCgaPEOSFMB2H/F+CZIXZS2HBfYDsoj5XdJg/fVIJwIyJ4bx0p5akmDBPWisYBQhBDoSlHfJ/Dq1n5ZJwN28ChYJT5nbu315OSbURgDsvn8xjNwkXVeAahCD7Q5Lg/YegVg8hUbDsNQgK5eNvz/BQ/l4aWjoZowxg3eLZ3Dw3ztPWCkYRQpD9UfYX0P+fPIiT+Qpd4Qk8+8EhXt4lu6gz48J5abmWKcJFFbgYIcjenCiDD1bL7699jNroH/DAlt2UHpVd1F8sSGTtjdOFiypwC0KQ59NSLw/iWDth2k18FLOchzZ9hrHVwlhlABsy53Dj7ImetlIwihGC7MZmhTfuBvNxpCgNfwj9NZv+twyA2ZMieHF5KonRwkUVuJcRWf3KkXOdZtfvofIjbAEhrGQlb/3rDAD/dsUUcm+chjJAuKgC9+MRQRoMBoqKiti8eTMAGRkZfUQ10DGOnOs0dd/CLrk8wWNd/85btZGMDQ5gY+Ycrp8lXFTB8OGWjAEXYyjVrxw5txtHq19ZopJ5S/0kf+66gdfar2BufATv3X+VEKNg2PFIDzmU6leOnNuNo9WvThjbWPvdNFq7krnrh1N45Abhogo8g9cM6jhT/crR/Y5Wv5oSE8aGJXMICvBj0cwJDlosELgejwhSo9H06NUGqn410DEXO7cbpVKJUql0yCYRcSPwBjzyDDmU6lcXOlcgGOm4JS+rI7ii+lXv/Rdj2KpfCXwer0qU7K2YzWZUKhXHjx8XghS4le7xCpPJRESE47U9vWZQZzhoamoCGN6y5gKfpqmpySlB+lQPabPZqK2tZezYsX0qTHV/o4nesy/i3gzMQPdGkiSampqIi4vDz8/xoRqf6iH9/PyIj79wouLw8HDxoRsAcW8Gpr9740zP2I1HRlkFAkH/CEEKBF6EEOT3KJVKnnjiCYcDCXwJcW8GxtX3xqcGdQQCb0f0kAKBFyEEKRB4EUKQAoEX4VPzkAPhlpQgI5ilS5eSm5sLQF5eHhs2yNkUfPU+mUwmtmzZAsDq1avt+92SYkbycSorK6Xs7Gz7dnp6uget8Q60Wq2kUqmk9PR0yWg0SpLk2/epoKBAWr16tbRhwwb7voHux1Dvk8+7rM6kBPEVcnNzMRqNFBUV2e+NL9+nzMxMNBpNj32uSDHTHz7vsjqTEsRX6F5v2p2JITs7W9ynXrgixUx/+Lwg+8ORdCKjme5nRpDXp2ZlZfV7nK/fp944m2KmP3zeZe3tilwoJYgvUFhYyJo1a+zbKpUKg8Eg7lMvBrofQ71PPi9IkRKkJ2q1moyMDPu2yWRCq9WK+9QLd6WYEaFzDD4lyGil+36UlJSQk5Nj/4b31fuk0+nYvHkzJpOJnJyci6aSGcp9EoIUCLwIn3dZBQJvQghSIPAihCAFAi9CCFIg8CKEIAUCL0IIUiDwIoQgBQIvQghSIPAihCAFAi9CCFIg8CLE8itBH0wmE/n5+ZSVlZGTk0NDQwMGg8Gn4lc9hYhlFfShsLDQvkp+8+bNpKenYzKZWLhwIWVlZZ42b1QjXFZBHzIzM3tUsgYoLS0lLS3Ng1b5BkKQgn7Jz8/v4Z4WFBT0WCcpcA9CkIJ+KSoq6iHAboF2p0MUuAchSEG/mEymHivds7KyKCws9OksAcOBGNQRCLwI0UMKBF6EEKRA4EUIQQoEXoQQpEDgRQhBCgRehBCkQOBFCEEKBF6EEKRA4EUIQQoEXoQQpEDgRQhBCgRexP8HW9lCNJB7X4oAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "leg = []\n",
    "for j in range(len(gammas)):\n",
    "    a, = ax.plot(f[:, j])\n",
    "    leg.append(a)\n",
    "\n",
    "ax.set_xlabel('$n$', fontsize=10)\n",
    "ax.set_ylabel('$f^{n}(0) / \\|f\\|_2$', fontsize=10)\n",
    "ax.legend(leg, [r'$10^{-3}$', r'$10^{-1}$', r'$10$'], loc=\"best\", fontsize=6)\n",
    "fig.savefig('f_n.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha = 2\n",
    "n = 100\n",
    "p = (3+np.arange(n, dtype=float)) ** (-alpha)\n",
    "Ns = (p / np.min(p)).astype(int)\n",
    "Ns = np.clip(Ns, 0, Q)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "q = np.zeros((n, len(gammas)), dtype=float)\n",
    "for i in range(n):\n",
    "    if Ns[i] > 0:\n",
    "        q[i] = f[Ns[i]-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "leg = []\n",
    "for j in range(len(gammas)):\n",
    "    a, = ax.plot(q[:, j] / np.sqrt(np.sum(q[:, j]**2)))\n",
    "    leg.append(a)\n",
    "\n",
    "ax.plot(p / np.sqrt(np.sum(p**2)), '--', color='black', alpha=0.3)\n",
    "q2 = p**.35\n",
    "ax.plot(q2 / np.sqrt(np.sum(q2**2)), '--', color='black', alpha=0.3)\n",
    "q2 = p**.05\n",
    "ax.plot(q2 / np.sqrt(np.sum(q2**2)), '--', color='black', alpha=0.3)\n",
    "\n",
    "ax.set_xlabel('$x$', fontsize=10)\n",
    "ax.set_yscale('log')\n",
    "ax.set_ylabel('$q(x) / \\|q\\|$', fontsize=10)\n",
    "ax.legend(leg, [r'$10^{-3}$', r'$10^{-1}$', r'$10$'], loc=\"best\", fontsize=6)\n",
    "fig.savefig('q_gamma.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dev",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.4"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
