{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "CColl9Gov_Qm",
    "outputId": "891d121b-597d-4860-de71-76f0a49e0069"
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "\n",
    "from resonance import plotting, sweeps, sampling, floquet_theory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "r79xIi5KwtqD",
    "outputId": "30cf1353-44a5-4274-dec7-9e2b2caa64af",
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "freq_min = 0.0\n",
    "freq_max = 0.05\n",
    "num_freq = 10\n",
    "\n",
    "runs_per_frequency = 10\n",
    "\n",
    "amplitude = 0.5\n",
    "variance = 1\n",
    "\n",
    "training_iterations = 10000\n",
    "batch_size = 2\n",
    "observation_noise_variance = 0.0\n",
    "\n",
    "evaluation_period = 100\n",
    "init_at_target = False\n",
    "\n",
    "momenta = [thousandths / 1000 for thousandths in range(999, 949, -5)]\n",
    "learning_rates = [thousandths / 1000 for thousandths in [10, 5, 1]]\n",
    "\n",
    "frequencies = torch.linspace(freq_min, freq_max, num_freq)\n",
    "\n",
    "# Giving the mean process a stationary variance of 0.1 (for an overall \n",
    "# stationary variance of 1.1, given sampling variance of 1.0) puts the \"amplitude\" of the\n",
    "# trajeectories pretty close to previous sinusoid experiments with amplitude 0.5.\n",
    "# And small noise variance essentially controls the noise level (and hence the SNR) of\n",
    "# the process.  We're adding noise additively with sampling variance, and keeping the process\n",
    "# noise variance quite small.  TODO: I wonder if this is literally equivalent to just using a\n",
    "# larger noise variance?  And come to think of it, is this whole AR(p)-as-mean-business equivalent\n",
    "# to just using a MA(p) process?  Jeez that'd be convenient.\n",
    "stationary_variance = 1.1\n",
    "sampling_variance = 1.0\n",
    "noise_variance = 1e-5\n",
    "make_sampler = lambda frequency: sampling.AR2MeanGaussian(stationary_variance, frequency, sampling_variance, noise_variance)\n",
    "\n",
    "results_dir = f'results/AR2_f({freq_min},{freq_max},{num_freq})_r{runs_per_frequency}_a{amplitude}_s{stationary_variance}_v{sampling_variance}_n{noise_variance}_N{training_iterations}_b{batch_size}_e{observation_noise_variance}_t{evaluation_period}_p{init_at_target}'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [],
   "source": [
    "sweeps.save_sweep(\n",
    "    frequencies = frequencies,\n",
    "    learning_rates = learning_rates,\n",
    "    momenta = momenta,\n",
    "\n",
    "    runs_per_frequency = runs_per_frequency,\n",
    "    training_iterations = training_iterations,\n",
    "\n",
    "    results_dir = results_dir,\n",
    "\n",
    "    make_sampler = make_sampler,\n",
    "    \n",
    "    # target function sampling\n",
    "    observation_noise_variance = observation_noise_variance,\n",
    "\n",
    "    # training parameters\n",
    "    batch_size = batch_size,\n",
    "\n",
    "    # measurement parameters\n",
    "    evaluation_period = evaluation_period,\n",
    "\n",
    "    init_at_target = init_at_target,\n",
    "    \n",
    "    tail_fraction = 0.5,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:03<00:00,  3.05it/s]\n",
      "100%|██████████| 10/10 [00:02<00:00,  3.54it/s]\n",
      "100%|██████████| 10/10 [00:02<00:00,  4.50it/s]\n"
     ]
    }
   ],
   "source": [
    "theoretical_results_dir = floquet_theory.unique_sweep_id(amplitude, momenta, frequencies * 2)\n",
    "\n",
    "floquet_theory.save_theoretical_results(learning_rates, momenta, frequencies * 2, amplitude, theoretical_results_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 1663.94it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2002.91it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaQAAADmCAYAAACaq/HmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAs9ElEQVR4nO3dd5gc1Znv8e/bk6NGGglFJAESEkIIASLZgAS218ZLXpvkhL221/bad313cVr28fqy9vV6ba/DNQ6sIzbRLNjAggEDwmQQoIAkJIQCyjlMHk33uX9UTXfNqEP1zHR3afT7PM88U6fCqVOh++1TdeqUOecQEREptVipCyAiIgIKSCIiEhEKSCIiEgkKSCIiEgkKSCIiEgkKSCIiEgkKSCIiEgkKSCIiEgmRDUhmttzMFpS6HBItZrbezN5Z6nKkM1TnbJS38Uik76LiKUlA8j9wHWbWYmb7zOxZM/uUmSXL45w70Tm3MEQ+kfvgpiuXmV1nZk8XKv/hwsxaA38J/zzpTX+g1OUL6n8cwpyzQ7TO3n2yzcx+bWb1hVxn1BV6nxTjuBaLmY0ys3vNrM3MNpjZtQOdN9t0M1toZp2Bz+6qMOUrZQ3pYudcAzAF+HfgS8AvSlgeiQDnXH3vH/AW3nnSO+7WYpTBzMqLsZ5BuNjfP3OBU4CvlLY4kaB9Es5NQDcwFvgA8BMzO3GA8+aa/tnAZ3dGqNI554r+B6wH3tlv3BlAApjdfx68YLUZaAFWAe8AfuvP3wG0Al/05/0y8KY/7wrg8n7rvR5YCuwH7gSqA9OPBu4BdgK7gR8Fpk0A/tuftg74X3lu33XA02Hyy7ENh2y3v74v+NvVhhfYxwIP+Xn8GRgZMv/1eB/mFcBe4FfBfdRvm74E3N1v3A+AH2Y6bkNwnuQ6htn26wnAQmAfsBy4pF++X/Lz7QLKc+SV6Ti8MzBP2vMp2/7PtN2ZpgH/AfxP2PM00zEJsW+y7fMh/8zl2o589kmI8+JU4FW//L/3y/j1dPln20+5tjfTvk+zPcfhnVN/55d1D/CFgXzX9su3Di+AHN/vPP73fOcNMX0h8PG8yzjYjRzgjulzAgXGvwV8OjgPMAPYCEzwx08FjsuUD/B+/+SLAVfhfUGPD8z/oj99FLAS+JQ/rQxYAnzP39nVwDn+tBjwMvBVoBI4FlgLvDvs9hEISLnyy7YNGT6A64Hn8YLQRGAH8AreL8Vq4HHgX/PYR6/hfVGMAp4h8OHst01TgHagIbAPtwJnZTtugzlPchzDjPsVqADWAP/sT7sA74thRiDfxf5214Q55hmOwzsD+yLT+ZTX8c20T4BJwDLgByHPq7THJOS+SbvPC/GZC7Pvw+6TEOdFJbAB+Ad/P1yB90V7SEDKtZ+ybW+mfZ9he64ADgJ/76/ncn891m++B/ACY7q/B9LkewrQ3m/c9cD9+c4bYvpCvOC/C+87ZEGoz3w+XxBD9UfmgPQ8cEO/k2Aa3hfsO4GKMPn0m2cxcGlg/g8Gpv0H8FN/+Gx/B5anyeNM4K1+474C/CrL9rX2O0HaSQWkfPNLbkO67fbTHwik/xv4SSD9OeAPeeyj4JfNe4E3syz7NPBhf/hdvfNmO26DOU9yHMOM+xU4F9gGxALTbge+Fsj3Y/kc8wzHofeLMeP5lO/xzXButQAOeAxoClPmTMck5L5Ju88L8ZkLs+/D7pMQ58V5eLUWC0x7mvQBKet+yra9mfZ9hu35GnBfID0B6BzIZ6hfvucC2/qN+wSwMN95Q0w/E2gAqoCP+Mcm5w/SqLWym4hXPU1yzq0BPo93kHaY2R1mNiFTBmb2YTNb7DeW2AfMBkYHZtkWGG4Hem9+Hg1scM71pMl2CjChN08/33/Gq5Fkcplzrqn3D/hM2PxCbEM62wPDHWnSyZu8IfLfGBjegPeByOQ24Bp/+Fo/nfdxy1OmY5htv04ANjrnEoFlN+Cdc72C2z2QYx6U8Xwa4PENusx5918XADMDy2Ytc5ZjEmbfZNrnhfjMDfTzlm6f5MpvArDZ+d+ivuB5EBRmP0Ga7c3z8zAH+FMgfay/nsFqBRr7jWvECxb5zpt1unPuBedci3Ouyzn3G7xa0ntzFTAyAcnMTsc7sIe0RHPO3eacOwfvxHLAt3on9ctjCvBfwGeBZj8QvAZYiCJsBCZnuKG9EVgXDDDOuQbnXM4dnGVdafMLuQ3u0CzDCZn/0YHhycCWLFn+HlhgZpPwLi3clixk5uNWKNmO0xbg6GBLTrxt2xxI9/9SynXMsx2HtOfTIM/RPpxzTwK/Br4TtswZjkmYfZNWgT5zA/68pdknufLbCkw0s0znf9CA95NftrCfh5Pxapm9TsK7J9WHmT3Ur1Vq8O+hNPmuBsrNbHq/dS0fwLz55AXe9uY8J0oekMys0cwuAu4AfuecW9Zv+gwzu8DMqoBOvF/7vb9QtuP9euhVh7fhO/1lP4r3ay2MF/FOzn83szozqzaztwemtZjZl8ysxszKzGy2H0QHIlt+Ybah/3bnI0z+f29mk8xsFHAD3o3ZtJxzO/GuF/8K70O/0s8323ErlGz79QW8X6tfNLMK854ruRjvvMs3r17ZjkOm82kw52g63wfeZWYn5ypzlmOS774JKsRnbrCft++T2ie968mU33NAHPismZWb2aV4DazSGfB+Cvt5MK+5+hT6BqA5pAlIzrkLXaBVar+/C9PM34bXgORGf3+/HbgUrzFCXvNmm25mTWb2bv94lpv3uMZ59K31pVXKgHS/mbXg/Xq5AfhP4KNp5qvCaxa+C68qfBSpJp3fBP7Fr4Zf75xbAXwX7yTbjvfL4pkwhXHOxfFOrml4jSs24d2g7Z12EV6T0nV+WX4OjMhri/uuK21+Ibehz3bnue4w+d8GPIJ34/dN4Os5sr0N79r4bYFxGY+b/8vun/Mpdxg59ms33vG90B//Y7x7X6/nm1dgtozHIdP5NJhzNEM5dwK3AF8NUea0xyTffdNv/UP+mRvs5y24TwLryXZeXAH8Ld693g/iNRboSpPvgPcT2b/Hgk7C+2HXGhiXNiAN0GfwGu3swLv/9Wnn3HJI+7nMOG+O6RV43xm9jRo+h3dJdXWuwlnfS6dypDOz9XjNNf9c6rKIlIKZvYDX8OJXpS4LgJntB05xzq0tdVkKreSX7ERESsnM5pvZOP/y0kc4tFFByZjZVLx7L+tKXJSiiPoT6SIihTYDuAvvftha4H3Oua2lLVLSScBr7gi5lKVLdiIiEgm6ZCciIpEw7C7ZNVeYm1xd2jLE46Vdf6/KquzTe5yxM17DzkQNNdbD9Ir9ofJ1QEt5A7srRtFtlRzXsZZyl2Gjjzut7zoTjq6eBN3xBHWVZVSWZf9NlHBwoPMgMTOqK2I55w9q6exhy75OGmrKqd+xlpqejtDLbnH1tFFJA100WDd1HAy9bCZRuRiRiMD5WRaRb54o7ItYWalL4Fnazi7n3JhSliEip8XQmVwNj5+We75CatmTe55imDgt+/SP73gHd7TNoAyv864fjb+b06u3Z18I+POoC/jXaV9llJ/+6OZf8/HNv047b9k9i5LDXT0J/mfFdhL+F/PImgoumN5M32cS+1qy5QBv7GxLps+eOpKJI8L94vj8nUt5ft1eAMrj3fziwffT2J076DoH58avoJUGDgDT2Mrd5feEWmc2Bw9pSFwaHemeyy+yhlG55ymG9gOlLgHU9u/voEQmvjIkvUEMii7ZHcE+N2Jxn/R3958aarkFe59kbFeqd5S7x15BW6wm53JV5TGmjEzNt7fjIDtauzPO39WTYO3u9mS6vrKMCY05qn2+Lfs6ecEPRgBnbXkqVDACWMUottCQTJ8fK/nnVOSIoIB0BDu5ahd/VZP6sn2g/ViWd+f+6Vru4ly7NdV5Q0t5I/cddXGodR5/VN/3pr2+ozXDnPDGzjbiidR1rplj67PWpoLuX7q1T78+71r3QKjlAJ5wU/ukL7D1oZcVkYFTQDrCXd/0cp/0d/eFu9550a4HaTqYqoHcPu5Kuq0i53INVeVMClxy29nazZ72Q2tJ3fEEa3alLtXVVpQxeWTuWhh496keWJqqwU0aWcPsnYtDLQvweGJKcng8Lcxkd+hlRWTgFJCOcG+r3srbq1N9Q97dNo21B3Nf1K5OdHHltruT6d2Vo3lo9LtDrXNGiFrSm7va6AnUjmYcVUcsZO3o2Td3szNwKfDSk8cRC9kf7V5XxauMS6bPtw2EXK2IDJICkvCFEalaUoIY3wt5L+mKHX+kricVTG4dfw095G4yNLK2grENqXtBW/Z3caAz1YqtJ57o05ChujzG1FG1ocoE8MfFqWcay2LGe08al2Xuvp50U0gEPhbn63KdSNEoIAnvqNnI3ModyfStLTPZ0lOXc7mGeCuX7/hjMr25eiJPjJofap0zjuqb/6odqQC0dk873fFUjeb4o+ooi4Wrpmw/0Mlza1PNHOdPb6a5rjLUsgBPuNTluip6eJuFerOAiAwBBSTBrO+9pG7K+OH+uaGWvWrb3VQmUu2Zfzfh2lAXx8bUVTKqNnXP6a29HbR3x4knHKsDwamyLMaxedSO7l+6jcCVPi6dOz70sj3OeNJNTqbPtk3UWLr3NYpIISggCQCX1K7l+IpUzeKXLSeyK577eZ9RPXu5aOeDyfSa2mk8N+KsnMuZGTMD95IcsHpnK+v3tNPZk3pNzPQxdZSHfBg2nnDcH2jMMH5ENadPHRlqWYBXGMcBUtus1nUixaWAJADEDK4f8Uoy3e4q+MmBOaGWvXbrnZQFemq4ZcIHQtWSxjdW0ViVejZ73Z6OPg0cKmLGtNHha0cvrNvD9gOp2tolJ48L3RAC4PHE1D7p803PH4kUkwKSJL2//g0ml6ceXf/ZgZM4kMjdlHt89zbetTv1+qRlDSexpCF3MDOzPveS4glHx8FU7WjamDoq8ugqqE9jBoOL8mjMAH2fP5rBLiZa5mekRGToKSBJUoUl+PyIV5PpfYlqfnEg3NuoP7jltj7p347/QKjljh5ZQ23FoS3zymLGtNG5G1b02tXaxdNrUs8LnTOtmTEN4Xp1ANjoGniD1EPBF6h2JFJ0CkjSx4fqV3JUWaq7nv93YC4didxNuY/p3MB5e55Kpp9vOpPVtTk60wNiZhw/5tDAc1xzLVXl4U/PB5ZuIz7AxgyQpneG2Pq8lheRwVNAkj5qYnE+17g4md4Rr+WW1hNCLfuhrbf2SYetJU1tru3Ti3fMSBukMkk4x31LUo0ZxjZWceYx+fXeGWzuPZIO5pK7k1kRGVoKSHKIv218jaZYZzL9/X2nctDlPlVmtb3OvP2p5uNPjJrPW3vasyzhKY8ZJ45LtbibcVQ91Wku42Xy0vq9bNmfKu/Fc8aFfm4JoM1V8JyblEzPt7cos4i8K0LkCKKAJIdojB3kU43LkumN8Qbuap0eatlgLclZjN8+vzHUcseNrmPBtGbOPXYUs8bW514gINiYIWZeQMrHs24S3YEeJtQ7g0hpDLv3IW1sheufLG0ZBv8qt6HRtCz3PJl0li2hfNZcesq8VnZf3HQaL76+OmefcI5XqPvMStqO9i7zPfTadj5xzlSOCvHaiNF59KjQa3dbN0++kWrMcPaxoxjbeOjzU/+26JBRSc9MmgKjvWFzCV5YspHFEXhx23AWX1/qEkRHZ+5ZjhiqIUla1fEuTti9PJneXz2SDSOm5lzOgAkLU7WknoTj9pc2FaCEnvuXbO3ziop8GzMkMDYGtmts21aq4hF5k57IEUYBSTI6acerxALveF4+5uRQyzWtfIbq7euT6fuXbqW9e+irHJ0H49y5KNXX3Jj6St52XHNeeWyvn0BHRaoBxaT964eqeCKSJwUkyaiup51j972RTG+tn8ju6txf+OYc4575fTLd2hXnwWXbsiwxMPcv3cbe9tQF0qtPn0R5Ho0ZAN4ceXwq4RzH7FszVMUTkTwpIElWs3cu7ZNePiZcd0LNi/9MWXvqleF3LtpMwg1dy7WeeIJbX0g1mGisLueyPC/X9VgZG5qOS6bHtW2h/qB6ZxApFQUkyWpMx07GtqZasa0ZeTydZbk7XS072MVRL6ZeG75xbwfPB14LMViPrNjBtkC/de87dQJ1Vfm10dnUOIXuslRji2P3rB6y8olI/hSQJKcTd6VqSfFYOa83zwq13FHP/4GywBW04P2ewUg4xy2B5uTVFTGunDcpyxLprQ1crosl4kzd/+aQlE9EBkYBSXI6Zt9a6rpTl7JWjD6pz1tVM6nav5MFM8Yk0y+s28u6XW1ZlgjnqTd2s3536oHbS08eT1Nt7k5gg7rKKtnYODWZnnRgg1rXiZSYApLkFCPBCbteS6bbKutZ13RsqGWvmjexT/quQdaSnHP85rm3kunymHHtGfnXjjaMOI5ELPUw7HF7dblOpNQUkCSUE3YvpyyRenvq8tEnhVrupImNzBrfkEw/+Np29ncM/NHhlzfsY8XWlmT6PSeOTfsgbC7B1nUV8S4mHVg/4DKJyNBQQJJQquOdfWoR2+snsLNmTJYlPGbGlYFaUldPgvuWbM2yRHa/eT5VOzLgQ2cdnXcebRV1bKtPlWnKvrWUO3XNIFJqCkgS2kCbgL9j5hhG16e6Bbr7lS30JPJvAr5yawsvrd+XTC+YMZopzeHfKNtrbdN0CLxJVpfrRKJBAUlCa+7czfjW1D2gN5um015ek3O5irIYV5wyIZnefqCLJ1fvynv9wXtHAB85e3LeeUDf1nU1B9sY1zo0rf9EZHAUkCQvJwZqSYlYGa83nxhqucvmjqci0Ab8zkX59W+3fnd7nyB2xtSRzBzXkGWJ9PZVjWRPbepS47F738jZYayIFEdRApKZvcfMVpnZGjP7cprpU8zsMTNbamYLzWxSYNq3zOw1/++qYpRXMpuyfx313QeS6RWjZxO33KfRqLpK3j1rbDK9dNMBVgYaJ+Ty2+ff6hM2PnJ2/veOoF9XQcCxulwnEhkFD0hmVgbcBFwIzAKuMbP+T1Z+B7jFOTcHuBH4pr/sXwOnAnOBM4Hrzayx0GWWzGI4Zu1MNQHvqKhjXVPuV5XDoU3Aw9aStu3v5E/LdyTTJ05o4NTJTaGWDXLA2pGp9zqN6NxLc8fOvPMRkcIoRg3pDGCNc26tc64buAO4tN88s4DH/eEnAtNnAX9xzvU459qApcB7ilBmyWLmnhWUx1NNt18bHa5xw/Sx9Zxy9Ihk+s8rd7KrNffDqLe9uKnPKyY+ctZkzPLrRBVgR+04WqtS6z9272ryz0VECqUYL+ibCARfG7oJr7YTtAS4AvgBcDnQYGbN/vh/NbPvArXA+cCK/isws08CnwQvwj44xBuQr+4Sr79Xfu9dzUO8i/K9q+gZPRuAnXVjubt2LBXt2w+Z9Yf90lfNm8SrG71OV3sSjntf3conzp2acVV727v5Y6CZ+DGjazlnen6vmAB4HtjW73Ldgb1v8HzeOQ3cq0VcVzb5772htzv3LEWR37uFC2Po+8E/fEWlUcP1wHwzexWYD2wG4s65R/Diy7PA7cBzwCEPjDjnbnbOzXPOzYvKBg13tbv6vo62PWQT8HOnNzN+ROpB1nte3UJXTyLj/Hct2txn+ofPmkxsALUjR4wDI1OXFqvbtlHZvT/LEiJSbMX4/t4MBO9AT/LHJTnntjjnrnDOnQLc4I/b5///hnNurnPuXXjPQuoudASUd+6hoiVV8e1qOo544EV3mZTFjPedmmoCvrf9II+u2JF23rauHu5+eUsyPa6xinedkPth3HRaG48mHmiiPkKNGUQipxgB6SVgupkdY2aVwNXAfcEZzGy0WbKp1leAX/rjy/xLd5jZHGAO8EgRyiwh1AYflLUyOkedEGq5S04eT01F6tT771e2pJ3v9pc20dKV6q7og2ceTXnZwE7ZfcEeyl2CRr2ITyRyCh6QnHM9wGeBh4GVwF3OueVmdqOZXeLPtgBYZWargbHAN/zxFcBTZrYCuBn4oJ+fREDlgfXEulJNwDuaZ+FCNBNoqC7nwtmpq/crt7Uc0gR8T1s3t72YaoXXXFfJRXMGdsV//eZdtAZ69q4/sIHyno4B5SUihVOMRg045x6kX1sD59xXA8N3A3enWa4Tr6WdRJABNbtX0DbhLAASlQ10N06m6sCGnMtefsp47nk1VTO6d/EWThg/I5n+zXNv0d6dul34t+dMobqijIH42V1PQeBZqVH9ukASkWhQGwAZlOo9KyHQMWlHyJ4bph9Vz0kTU4+UPbJiB62dXuV3y77OPsFq0sgaLhlg7aito4tf3/tsMl3ZuYfa1vx6iRCR4lBAkkEp62mnav/6ZLq7cUqoxg1An/7tOg8m+NNyr9n4z59ez8F46rmjvztv6oDvHd3+Py+xryV1eW7UzqV69kgkohSQZNCqdy9PJSwWunHD+TNG01idump87+KtrNnRykOvpZ5nmjG2nnfMHFjLOuccP7njyWQ6Fu9S6zqRCFNAkkGrbNk4oMYN1RVl/PVJqUtxb+5s44Y/rOjTZ91nFhwzoOeOAJ58aTUr3kw9VNu0eyWxxMBfDigihaWAJIPW27ihV6Kyge6GcK+GuGzu+D7pDXtSl9fmTWnijKkjB1yum25P1Y5wjpH9HuYVkWhRQJIh4TVuSPWo0DE6XOOGKc21zJvSlHbap+cfM6A+68Br6v3gX1IBqP7AeioDvZSLSPQoIMmQ8Bo3rEum82nccHmgcUOv82eM5sQJA+/Y/Wd3PUUi0CHrSDX1Fok8BSQZMtWBy3b5NG6YP72Z5rrUK85jBn933jEDLkf/pt4zjxlHnZp6i0SeApIMmcqWt4h1923cEI9n7ji1V3lZjA+emeru8MrTJjK1uXbA5bjjwb5NvT999Xw19RY5DBSlpwY5MiR7bhif6rnh0WdX8p5zc99Puvr0iUxprqGrJ8F500cPuAzOOX4caMwwor6Gay86g58OOEcRKZZhF5B60PtFeu0pxUp3r6Rq3Bn09pX7s3/6Am9reCjUorP9/22DWP1TByeyouWyZPrqg8+RuLg6Mu8iioKa3LMcMUryGZGMdMlOhlZPO4lA44ZHD05layJc44ah8IvO1HuZDMfHqtXUW+RwoYAkQy4eaNwQJ8btXeEaNwzWhngDDx+cmky/s2I9U8vU1FvkcKGAJEMu0bIRF2jccGvXLOKu8M0Kft11EonAKf2JajX1FjmcKCBJATh6ArWkTYkGnjgYrueGgWpz5dwaqIkdH9vDeeVq6i1yOFFAkoKI716JC/Tc8Nuuwr7W6q6umex31cn0x6qXMcBOHkSkRBSQpDB62kkEXkvx6MGp7EgUpn1Xhyvj+x2nJdMN1sWVVasKsi4RKRwFJCmY+J6VqWFi3NN1fEHW85vO2Wxz9cn0J6qWUmfq1VvkcKOAJAWTOLCBMdaeTN/efQLOZVlgAFpdBT/sTNWOmqyTT1cvHtqViEhRKCBJATneH7h09nq8mSXxgb1sL5ObO+ew26UuBX62+hUaY91Dug4RKQ4FJCmoq6tW9knfMYTPJO1NVPGTzlOS6THWrgdhRQ5jCkhSUDPK9nJKWeqV5Pd0T6fTlQ1J3jd1nsIBV5VMf75mEXXWMyR5i0jxKSBJwV0TqCXtd9X8qXvgr5botSNRy88D3QRNirXwoarlg85XREpHAUkK7rLKN6gmVXO5o3vmoPP8QcepdFCRTP9jzUtUWe5XXYhIdCkgScGNiHVzYeXaZHrhwclsGUSHq5vi9dzSNTuZPja2j6sqXx9UGUWk9BSQpCiCl+0cxl1dA68l/WfnPLpJ3Yf6Ys0LlNsQtycXkaJTQJKiOKd8MxNjLcn0HV0zB/RM0tr4iD4t9WaV7eLSyjVDUUQRKbFh94K+GFCdc67CGlni9fcamrZsg3PK471DjgPjXodxpwOwLtHEiS+Op6pta1757Z1yBvGRqd9R2954gdNCvGEi9ztrCy8qTS6i0A5xaqkL4KvKPUvBReFzCrAi9ywFV5Qakpm9x8xWmdkaM/tymulTzOwxM1tqZgvNbFJg2n+Y2XIzW2lmPzRTl5mHq9o9fe/zdIzK77LdwepRdDRNT6Yr2rZTdWD9UBRNRCKg4AHJzMqAm4ALgVnANWbWv+vn7wC3OOfmADcC3/SXfRvwdmAO3huuTwfmF7rMUhjl3QeobN2cTHc0TSMRC19Jbxl/JsEuvBu3Po9+nYgMH8WoIZ0BrHHOrXXOdQN3AJf2m2cW0Htx54nAdId3Ba4Sr3ZdAWxHDlvBWpIrq6RzxHGhluuuPYrOEccm05Utm6hs1fuORIaTYgSkicDGQHqTPy5oCXCFP3w50GBmzc655/AC1Fb/72Hn3Mp+y2JmnzSzRWa2SG2toq1635tYPNUTd3tzuK6EWsad2SfduPUF1Y5EhpmotLK7HphvZq/iXZLbDMTNbBpwAjAJL4hdYGbn9l/YOXezc26ec26evqSiLZY4SPW+VKu47vqJ9FQ2Zl2mq34CXY2pN85W7V9PZfu2gpVRREqjGAFpM3B0ID3JH5fknNvinLvCOXcKcIM/bh9ebel551yrc64VeAg4uwhllgKq3dO3ktuepXGDI03taNsLhSiWiJRYMQLSS8B0MzvGzCqBq4H7gjOY2Wgz6y3LV4Bf+sNv4dWcys2sAq/2dMglOzm8VLZtpaxrXzLdMWommS61do44ju76Ccl09d41VHTsKmwBRaQkCh6QnHM9wGeBh/GCyV3OueVmdqOZXeLPtgBYZWargbHAN/zxdwNvAsvw7jMtcc7dX+gyS2EZfRs3xCsb6K6bcMh8iVgF+ye+PTXCJWhQ7Uhk2DI31K/wLLEyM6cHYz1ReOAuU6PunsoGdsz6cDJdu3s5TRsX9pnnwPizaB2behts3Y7FjNjyzIDKUZN7loKLyoOx40pdAEr/8HovPRibsgJeds7NK2UZotKoQY4w5d0tVLZuSaY7mqbhLPXRPFjVROuYucl07GAbDdteLGYRRaTIFJCkZGr2pF5v7sqq6Gyc6g0D+yedB7FUgGrc8iyxxEFEZPhSQJKSqdm/BhKpntXaR80A/IYMDamGmZWtm6nZu7ro5ROR4lJAkpKJxbupDvRF19U4mZ7KhkMaMozY9Bc9BCtyBFBAkpKqDVy2w8rYfdwlJCobkqPqdi6lonNPCUomIsWmgCQlVdXyFrGejmQ6XtWUHFZDBpEjS86AZGbLzOxWM/uSmV1oZpPM7IZiFE6GP3MJqve+kXaaGjKIHFnC9P0/H+/1D3Pwelm4He+Rim9kW6hUqvG6Di+lqDzZlSh1AQj3nEfd3tW8MWZO33Gtm5myd/WQ3TvqHKJ8BuOMUhfA11rqAhCN58IgGp+RilIXIEJyBiTn3B5gof+HmU0H/qWgpZIjSm37dqo699FV3eSNcAkmqSGDyBEnzCW744Np59wbeLUlkSFhwFE7Xk6mx25fRI0aMogcccJcsvuZmR2H10P3UryrYq+ZWa1zrr2gpZMjRvOe16np2IWzcmr1agmRI1KYS3bnA5jZZOBkYK7/f7GZJZxzmd8dIJKHWvXiLXJEC1NDAsA59xbe6yCSvW2bWX0hCiUiIkeeQT2H5L80T0REZND0YKyIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiERC6L7sDieKsp4ovGu1q9QF8EVhX4R5WWExNJS6AEBPqQvgqyx1AYjOCz2jQN/dIiISCQpIIiISCQpIIiISCUUJSGb2HjNbZWZrzOzLaaZPMbPHzGypmS00s0n++PPNbHHgr9PMLitGmUVEpLgKHpDMrAy4CbgQmAVcY2az+s32HeAW59wc4EbgmwDOuSecc3Odc3OBC4B24JFCl1lERIqvGDWkM4A1zrm1zrlu4A7g0n7zzAIe94efSDMd4H3AQ8659oKVVERESqYYAWkisDGQ3uSPC1oCXOEPXw40mFlzv3muBm5PtwIz+6SZLTKzRVFpTioiIvmJSqOG64H5ZvYqMB/YDMR7J5rZeOAk4OF0CzvnbnbOzXPOzRuWD1aJiBwBivH9vRk4OpCe5I9Lcs5twa8hmVk98DfOuX2BWa4E7nXOReH5RhERKYBi1JBeAqab2TFmVol36e2+4AxmNtrMesvyFeCX/fK4hgyX60REZHgoeEByzvUAn8W73LYSuMs5t9zMbjSzS/zZFgCrzGw1MBb4Ru/yZjYVr4b1ZKHLKiIipWPODa+elOrM3OxSFyIiOktdAKCs1AXwdZe6AEB9qQsQIVFpfBSFe85R+QZ+EV52zs0rZRmi0qhBRESOcApIIiISCQpIIiISCQpIIiISCVG4pzekjNJH2ag8LFVd6gLgHY8oiMKL2OK5ZymKKHzoo9LYJSrnp3hK/d0tIiICKCCJiEhEKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkKCCJiEgkROHVKEPKAYkSlyEq73op9X6A6JxgrtQFQL/+gvQeIklHnxEREYkEBSQREYkEBSQREYkEBSQREYkEBSQREYkEBSQREYkEBSQREYmEogQkM3uPma0yszVm9uU006eY2WNmttTMFprZpMC0yWb2iJmtNLMVZja1GGUWEZHiKnhAMrMy4CbgQmAWcI2Zzeo323eAW5xzc4AbgW8Gpt0CfNs5dwJwBrCj0GUWEZHiK0YN6QxgjXNurXOuG7gDuLTfPLOAx/3hJ3qn+4Gr3Dn3KIBzrtU5116EMouISJEVIyBNBDYG0pv8cUFLgCv84cuBBjNrBo4H9pnZPWb2qpl9269x9WFmnzSzRWa2qKcAGyAiIoUXlUYN1wPzzexVYD6wGYjjdYV2rj/9dOBY4Lr+CzvnbnbOzXPOzYtK32kiIpKfYgSkzcDRgfQkf1ySc26Lc+4K59wpwA3+uH14tanF/uW+HuAPwKlFKLOIiBRZMQLSS8B0MzvGzCqBq4H7gjOY2Wgz6y3LV4BfBpZtMrMxfvoCYEURyiwiIkVW8IDk12w+CzwMrATucs4tN7MbzewSf7YFwCozWw2MBb7hLxvHu1z3mJktw+u1/r8KXWYRESk+cy4Kb4oZOnVmbnapCxEReh9SShTO8iiUAaJx4zgq+yIK72WKyr54AV52zs0rZRmi8n0xZIxofODEo1aPKZWlLoAvCsckKl888VIXQPrQd7eIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiESCApKIiETCsHtjrJm1AKtKXQ4RkcPMFOfcmFIWICovbhxKq0r9Gl4REcmfLtmJiEgkKCCJiEgkDMeAdHOpCyAiIvkbdo0aRETk8DQca0giInIYUkASEZFIOKwDkpk9G2Kec81suZktNrOaYpRLRETyN+zvIZnZT4GnnXO/K3VZREQks8O9htTq/19gZgvN7G4ze93MbjXPx4ErgX8zs1tLW1oREclmOPXUcApwIrAFeAZ4u3Pu52Z2DvCAc+7ukpZORESyOqxrSP286Jzb5JxLAIuBqaUtjoiI5GM4BaSuwHCc4VX7ExEZ9oZTQBIRkcOYApKIiETCsG/2LSIihwfVkEREJBIUkEREJBIUkEREJBIUkEREJBIUkEREJBIUkGTImFnc71X9NTP7vZnV5rHsBDPLq3snv//CeXnMH6rndzP7mpldn09ZsuSVs0f6AeQ518zem2X67Wa21Mz+91CvW6SQFJBkKHU45+Y652YD3cCnwixkZuXOuS3OufcVtnh8APimX8aOAq8LAOfc2wqQ7VwgbUAys3HA6c65Oc657/Wbpt5LJNIUkKRQngKmmVmdmf3SzF40s1fN7FIAM7vOzO4zs8eBx8xsqpm95k+rNrNfmdkyf5nz/fE1ZnaHma00s3uBtLUcM3uHv9wyf91VuXp+N7MbzGy1mT0NzAiMn2tmz/s1jnvNbKQ/fqGZfc/MFvnlOd3M7jGzN8zs64Hls/ZI70/7qpm95Ncsbw6MX2hm3/L33Wq/hlcJ3Ahc5df0ruq3KY8AE/1p5/p5fN/MFgH/YGanmdmTZvaymT1sZuP9dZ1mZkv8v28HjsV1ZvajwPY8YGYL/OG/MrPnzOwVv0Zc749fb2b/xx+/zMxm+uPrA8d1qZn9jZl9zMy+H8j/E2bWJ5DKEcQ5pz/9Dckf0Or/Lwf+CHwa+L/AB/3xTcBqoA64DtgEjPKnTQVe84f/CfilPzwTeAuoBv4xMH4O0APM61eGamAjcLyfvgX4vD/8a+B9acp9GrAMqAUagTXA9f60pcB8f/hG4Pv+8ELgW/7wP+D1Mj8eqPK3q7nfPlkA7Acm4f0QfA44x582KlCW3wIXB9bxXX/4vcCf/eHrgB9lOAbJ/RjI48f+cAXwLDDGT18V2J9LgfP84W8HjkWfdQEP+NsyGvgLUOeP/xLwVX94PfA5f/gzwM/94W/17j8/PRKoB94EKvxxzwInlfpc1l9p/lRDkqFUY2aLgUV4QeQXwF8BX/bHL8QLGJP9+R91zu1Jk885wO8AnHOvAxuA44HzAuOX4n2J9jcDWOecW+2nf+Mvl825wL3OuXbn3AHgPgAzGwE0OeeezJDXff7/ZcBy59xW51wXsBY4Os16MvVIf76ZvWBmy4AL8F6j0use///LDLwH+zv9/zOA2cCj/vH4F2CSmTXhbedf/Pl+GyLPs4BZwDN+Xh8BpuQo9zuBm3pncM7tdc61Ao8DF/k1qQrn3LJ8Nk6GD11TlqHU4ZybGxzhX376G+fcqn7jzwTaili2QujtYT5B397mE6T/bB3SI72ZVQM/xqvpbTSzr+EF7f7LDKYH+979bHiB8+zgRD8gZdJD30v7vWUzvB8U12RYLp9y/xz4Z+B14Fc55pVhTDUkKbSHgc8F7oucEmKZp/AaIGBmx+PVqFbhXSK61h8/G++yXX+rgKlmNs1Pfwh4Ms18QX8BLvPvUTUAFwM45/YDe83s3DzyylfvF/wu/x5MmIYdLUDDANa1ChhjZmcDmFmFmZ3onNsH7DPvZZbg73vfemCumcXM7GjgDH/888Dbe/ezefcKj8+x/keBv+9N9N6Pc869gFejvBa4fQDbJcOEApIU2r/h3btYambL/XQuPwZi/iWsO4Hr/EthPwHqzWwl3v2cl/sv6JzrBD4K/N5fPgH8NNvKnHOv+OtZAjwEvBSY/BHg22a2FK91240hyh+aHwz+C3gNL3i/lHUBzxPArAyNGrKtqxsv4H3LzJbgXTbsbQX4UeAm//KbBRZ7BlgHrAB+CLzi57UT7/7S7f6+eQ7vfl82XwdG+o03lgDnB6bdBTzjnNsbdntk+FFv3yLSh5lNBR5wXvP9Yq3zAeB7zrnHirVOiR7VkESkZMysycxW491/VDA6wqmGJCIikaAakoiIRIICkoiIRIICkoiIRIICkoiIRIICkoiIRML/B2+I4nNV4MQ4AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 2061.08it/s]\n",
      "/home/kdbanman/regression_resonance/two_weight_tmp/resonance/plotting.py:124: UserWarning: No contour levels were found within the data range.\n",
      "  cmap='Blues_r',\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tail_fraction = 0.5\n",
    "outlier_quantile_threshold = 0.98\n",
    "\n",
    "estimated_amplitude = 0.5\n",
    "\n",
    "plotting.plot_momentum_vs_frequency(\n",
    "    results_dir,\n",
    "    theoretical_results_dir,\n",
    "    learning_rates,\n",
    "    momenta,\n",
    "    frequencies,\n",
    "    runs_per_frequency,\n",
    "    tail_fraction,\n",
    "    outlier_quantile_threshold,\n",
    "    estimated_amplitude,\n",
    "    'Period of dominant frequency',\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "name": "1 - With Gaussian Sampling, Proper SGDm",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
