{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b313c0b1-6582-4c50-ad84-5d85d31cb4d1",
   "metadata": {},
   "source": [
    "# Periodic Mean\n",
    "\n",
    "Mean switches back and forth between two different positions.  For $d$ input dimensions, we choose a random vector $m \\in \\mathbb{R}^d$ for one position, then choose the other as $-m$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e2c48698-26d9-4753-ac4c-5ab5c18fc5f4",
   "metadata": {
    "tags": [
     "parameters"
    ]
   },
   "outputs": [],
   "source": [
    "# This cell is tagged 'parameters', so all variables will be overwritten by papermill.\n",
    "\n",
    "run_id = 0\n",
    "run_group = 'test'\n",
    "\n",
    "# Learning params\n",
    "step_size = 0.001\n",
    "momentum = 0.95\n",
    "iterations = 10000\n",
    "\n",
    "# Problem params\n",
    "input_dimensions = 50\n",
    "output_dimensions = 10\n",
    "target_weight_variance = 1\n",
    "weight_init_variance = 1\n",
    "observation_noise_variance = 0.1\n",
    "batch_size = 20\n",
    "\n",
    "# Sampling params\n",
    "instantaneous_domain_variance = 1.0\n",
    "mean_position_displacement = 0.5\n",
    "mean_period = 20\n",
    "\n",
    "# Storage params\n",
    "database = 'periodic_mean'\n",
    "user = 'postgres'\n",
    "password = 'password'\n",
    "host = 'localhost'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e9899676-8590-4652-8c30-b5483ffc92ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import jax.numpy as jnp\n",
    "from jax import random\n",
    "\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "import helpers\n",
    "import data_storage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "05cc0f16-f5d3-441c-8796-2d3f13448042",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d2d394dc138c48cf99038cd7e6420231",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "rand_key = random.PRNGKey(run_id)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "target_weights = helpers.random_weights(input_dimensions + 1, output_dimensions, target_weight_variance, subkey)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "weights = helpers.random_weights(input_dimensions + 1, output_dimensions, weight_init_variance, subkey)\n",
    "\n",
    "velocity = jnp.zeros_like(weights)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "means = helpers.periodic_vector_mean_sequence(input_dimensions, mean_period, mean_position_displacement, iterations, rand_key)\n",
    "\n",
    "\n",
    "steps = []\n",
    "losses = []\n",
    "target_distances = []\n",
    "for step, mean in enumerate(tqdm(means)):\n",
    "    rand_key, subkey = random.split(rand_key)\n",
    "\n",
    "    loss, weights, velocity = helpers.train_step(\n",
    "        mean,\n",
    "        instantaneous_domain_variance,\n",
    "        batch_size, \n",
    "        input_dimensions, \n",
    "        target_weights, \n",
    "        observation_noise_variance,\n",
    "        step_size,\n",
    "        momentum,\n",
    "        weights,\n",
    "        velocity, \n",
    "        rand_key,\n",
    "    )\n",
    "    if step % 10 == 0:\n",
    "        steps.append(step)\n",
    "        losses.append(loss)\n",
    "        target_distances.append(jnp.linalg.norm(weights - target_weights))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2a8ad671-20a2-4f3d-a765-721f5a621b7d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fce140f1c50>]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 4), dpi=120)\n",
    "plt.plot(steps[:mean_period * 10], target_distances[:mean_period * 10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e92c448e-8ea4-4146-bb71-8edfd4323fc8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fce1406d7b8>]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmgAAAGgCAYAAAAevJsNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAABJ0AAASdAHeZh94AAAtbElEQVR4nO3de7QsZ32f+edX1ftyLjoSAgkdCRlsYY1lgQ0xli9xDGsZAmNzWwacxOCYWfbYjhaTSWwY25oYFpMEY2I7MRclZuxgj5WAuAVx92UWMZ6BINsgg8RgLAORQIIjIXQ5l33p7nf+qKretVvdvXv33l3V5+zns1avvbv67aq36+3q/vZb9VZFSglJkiQtjqztCkiSJGk7A5okSdKCMaBJkiQtGAOaJEnSgjGgSZIkLRgDmiRJ0oIxoEmSJC0YA5okSdKCMaBJkiQtGAOaJEnSgum0XYHdiojzgacCdwIbLVdHkiRpkmXgcuBPU0oPTPuksy6gUYSzm9quhCRJ0i48D3jvtIXPxoB2J8B73vMeHv/4x7ddF0mSpLFuv/12nv/850OZX6Z1Nga0DYDHP/7xXH311W3XRZIkaRq7OizLQQKSJEkLxoAmSZK0YAxokiRJC8aAJkmStGAMaJIkSQvGgCZJkrRgDGiSJEkLxoAmSZK0YAxokiRJC8aAJkmStGAMaJIkSQvGgCZJkrRgzsaLpc/ViQfXePHvfILNXp+XP/N/4NnfcWnbVZIkSQeMAW1YwN+cOAnA/ac3W66MJEk6iNzFOWQ531olm71+izWRJEkHlQFtyFItoG10DWiSJKl5BrQhS/agSZKklhnQhizlMfh/o5darIkkSTqoDGhDImJwHJo9aJIkqQ0GtBGqXjSPQZMkSW0woI2w1LEHTZIktceANsKSuzglSVKLDGgjVMegbXQdJCBJkppnQBth2V2ckiSpRQa0ERwkIEmS2mRAG8Fj0CRJUpsMaCNUuzg3DGiSJKkFBrQR7EGTJEltmimgRcTVEfGOiPhCRJyOiHsj4qMR8ZwRZa+KiA9HxMmIuC8i/iAiLtp71ednaxSnAU2SJDWvM+PzHgucB/w+cBdwGHgB8N6I+NmU0psBIuIxwEeBB4DrgKPAy4EnRsQ1KaWNPdZ/LqpBAptei1OSJLVgpoCWUvog8MH6tIh4I/CXwM8Dby4nXwccAb4rpXRHWe5m4I+Bl9bKLRRPsyFJktq0b8egpZR6wJ3ABbXJLwDeX4WzstyfAJ8Hfmy/lr3fqmPQHCQgSZLaMOsuTgAi4ghwCDgfeC7wPwI3lo9dBlwM/MWIp94M/PBelj1PHoMmSZLatKeABvwG8LPl/33g3cDLyvvHy793j3je3cCFEbGSUlofN/OIuBgYHlBwxezVnY6jOCVJUpv2GtD+HfBO4FKKXZY5sFw+dqj8OyqArdXKjA1owLXAq/ZYx11b6jhIQJIktWdPAS2l9Dngc+Xd/ysi/gh4X0R8D3CmnL4y4qmr5d8zIx6rux54x9C0K4CbZqju1LIoAlo/GdAkSVLz9tqDNuydwG8DV7K1a/P4iHLHgfsm7d4ESCmdAE7Up0UZnuapCmi9vgFNkiQ1b7+vJFDt1jw/pfQV4B7gKSPKXQPcss/L3jd5VvagGdAkSVILZr2SwMUjpi0B/5hit+Vny8nvAp4dEZfXyv0QRQ/b8K7LhVEFtJ67OCVJUgtm3cX52xFxjOIqAV8BLgFeDHwb8AsppZNludcALwI+EhG/RXElgVcAnwHespeKz9PgGDQHcUqSpBbMGtBuBH4K+CfAI4GHKK4i8IsppfdWhVJKd0bEU4HfBF4LbAAfoAhxE48/a1N5lg170CRJUitmvdTT24C3TVn2NuCZsyynLbmDBCRJUov2e5DAOSHLtkaKOlBAkiQ1zYA2Ql47lYe7OSVJUtMMaCPUe9DczSlJkppmQBshq/WgeTUBSZLUNAPaCHltrdiBJkmSmmZAG6Heg+YuTkmS1DQD2gi5ozglSVKLDGgj1AOaozglSVLTDGgjbBskYA+aJElqmAFtBHvQJElSmwxoI+QOEpAkSS0yoI2w/VJPLVZEkiQdSAa0EernQXMXpyRJapoBbQTPgyZJktpkQBuhHtCSPWiSJKlhBrQRHMUpSZLaZEAbwV2ckiSpTQa0EXJHcUqSpBYZ0EZwFKckSWqTAW0Ed3FKkqQ2GdBG2LaL0x40SZLUMAPaCF7qSZIktcmANsL2Sz0Z0CRJUrMMaCN4HjRJktQmA9oItXyGHWiSJKlpBrQR6qM43cUpSZKaZkAbYdsuTgOaJElqmAFthG3nQfMYNEmS1DAD2gi5ozglSVKLDGgjOIpTkiS1yYA2gpd6kiRJbTKgjeClniRJUpsMaCNsv9RTixWRJEkHkgFthKy2VhwkIEmSmmZAG2HbiWrdxSlJkhpmQBvBUZySJKlNBrQRvNSTJElqkwFtBC/1JEmS2jRTQIuI746IN0bEbRFxKiLuiIi3R8SVQ+V+LyLSiNvn9qf685FvOwatxYpIkqQDqTPj834R+LvAO4BPA5cALwM+GRHfm1K6tVZ2Hfjpoec/MONyGxH1UZwegyZJkho2a0D7TeDHU0ob1YSIuBH4DPBLwEtqZbsppRtmr2LzckdxSpKkFs20izOl9LF6OCun/Q1wG3DVcPmIyCPi2GxVbF7miWolSVKL9m2QQEQE8Gjg3qGHDgMPAg9ExH0R8aaIOLpfy52HzF2ckiSpRbPu4hzlxcBlwCtr0+4GXgd8kiIMPgu4FvjOiHhaSqk7aYYRcTFw0dDkK/atxmN4mg1JktSmfQloEfFtwJuAjwO/X01PKf3yUNG3RcTngX8NvBB42w6zvhZ41X7UcTccxSlJktq0512cEXEJ8AGKkZkvTCn1dnjKvwX6wNOnmP31wBOGbs+bvbbTqeUzryQgSZIat6cetIg4H/gQcAHw91JKd+30nJTSmYj4OnDhFGVPACeGljlbZXchIsii6D1LBjRJktSwmQNaRKwC7wOuBJ6eUvrslM87D3gUcM+sy25CFkE/Ja8kIEmSGjfrlQRy4Ebg+4AXpZQ+PqLMahnGhv0KEMCHZ1l2U7Lyck/mM0mS1LRZe9B+A3guRQ/ahRFRPzEt5YlpLwE+FRFvBapLOz0T+GGKcHbTjMtuRHU5Tk+zIUmSmjZrQHtS+fc55W3YDcD9wPuBZwA/CeTA7cB1wK+nlBb6FLDVSE5PsyFJkpo2U0BLKT1tijL3Az8xy/wXQXUuNEdxSpKkpu3blQTONdUxaOYzSZLUNAPaGNUxaI7ilCRJTTOgjZFn7uKUJEntMKCNUZ0Q1xPVSpKkphnQxqhGcbqLU5IkNc2ANsbWedDarYckSTp4DGhjDK4kYEKTJEkNM6CNkQ8u9WRAkyRJzTKgjbF1otqWKyJJkg4cA9oYXotTkiS1xYA2Rua1OCVJUksMaGN4DJokSWqLAW2MGJwHreWKSJKkA8eANkZerhmvJCBJkppmQBtjaxSnAU2SJDXLgDbGYJCA+UySJDXMgDbG4DQbJjRJktQwA9oYjuKUJEltMaCNsTWK04AmSZKaZUAbIy8Dmh1okiSpaQa0MbJyzTiKU5IkNc2ANsbWKE4DmiRJapYBbQyvxSlJktpiQBtjaxRnyxWRJEkHjgFtjOo8aI7ilCRJTTOgjeExaJIkqS0GtDEMaJIkqS0GtDE8Bk2SJLXFgDZGeC1OSZLUEgPaGF6LU5IktcWANkZ1DJpXEpAkSU0zoI2xdaLalisiSZIOHAPaGNV50NzFKUmSmmZAG8Nj0CRJUlsMaGNEdQyauzglSVLDDGhj5OWasQdNkiQ1zYA2hlcSkCRJbTGgjTE4zYYnqpUkSQ2bKaBFxHdHxBsj4raIOBURd0TE2yPiyhFlr4qID0fEyYi4LyL+ICIu2nvV56sKaHagSZKkpnVmfN4vAn8XeAfwaeAS4GXAJyPie1NKtwJExGOAjwIPANcBR4GXA0+MiGtSSht7rP/cVMeg2YMmSZKaNmtA+03gx+sBKyJuBD4D/BLwknLydcAR4LtSSneU5W4G/hh4KfDmGZc/d5mn2ZAkSS2ZaRdnSuljw71fKaW/AW4DrqpNfgHw/iqcleX+BPg88GOzLLspDhKQJElt2bdBAlGcOOzRwL3l/cuAi4G/GFH8ZuDJ+7XsecgHAa3likiSpANn1l2co7wYuAx4ZXn/ePn37hFl7wYujIiVlNL6uBlGxMXA8ICCK/Za0WlUl3ryGDRJktS0fQloEfFtwJuAjwO/X04+VP4dFcDWamXGBjTgWuBV+1HH3aqOQQNIKQ2uLCBJkjRvew5oEXEJ8AGKkZovTCn1yofOlH9XRjxtdajMONdTjBStuwK4aYaq7kpWC2S9fqKTG9AkSVIz9hTQIuJ84EPABcDfSyndVXu42rV5fPh55bT7Ju3eBEgpnQBODC1z5vruRl7rQXMvpyRJatLMAS0iVoH3AVcCT08pfbb+eErpKxFxD/CUEU+/Brhl1mU3oZ4DHckpSZKaNOuVBHLgRuD7gBellD4+pui7gGdHxOW15/4QRagb3nW5UPKo96AZ0CRJUnNm7UH7DeC5FD1oF0bES+oPppRuKP99DfAi4CMR8VsUVxJ4BcUJbd8y47IbMXwMmiRJUlNmDWhPKv8+p7wNuwEgpXRnRDyV4soDrwU2KAYU/MJOx5+1LfMYNEmS1JKZAlpK6Wm7KHsb8MxZltOmrH4MmglNkiQ1aN+uJHCu2T6K04AmSZKaY0Abo346j54BTZIkNciANkZ9FKf5TJIkNcmANkb9GDRHcUqSpCYZ0MbIPAZNkiS1xIA2Rv08aP1+ixWRJEkHjgFtjLy2ZuxBkyRJTTKgjZE5ilOSJLXEgDZGtm0UpwFNkiQ1x4A2xvZrcbZYEUmSdOAY0MbwGDRJktQWA9oY264k4HnQJElSgwxoY3glAUmS1BYD2hhZbc04ilOSJDXJgDbGthPVGtAkSVKDDGhjbL+SgAFNkiQ1x4A2Rp45SECSJLXDgDZGrQMN85kkSWqSAW2M3GPQJElSSwxoY2SZAU2SJLXDgDZG5olqJUlSSwxoY9Q60DxRrSRJapQBbQxHcUqSpLYY0MbwRLWSJKktBrQxDGiSJKktBrQx8m2jOFusiCRJOnAMaGPUBwl4DJokSWqSAW0Mz4MmSZLaYkAbw2PQJElSWwxoY2y71FO/xYpIkqQDx4A2Rv1i6T170CRJUoMMaGPUR3EmA5okSWqQAW2M7dfibLEikiTpwDGgjZHV1oyDBCRJUpMMaGM4ilOSJLXFgDbG9lGcBjRJktQcA9oY245BM59JkqQGzRzQIuJoRLw6Ij4cEfdFRIqIl44o93vlY8O3z+2p5nNWPwbNUZySJKlJnT0891HAK4E7gL8Cnjah7Drw00PTHtjDsudu+yhOA5okSWrOXgLa3cDxlNJXI+IpwJ9PKNtNKd2wh2U1Lt92Lc4WKyJJkg6cmXdxppTWU0pfnbZ8ROQRcWzW5TWtfiUBR3FKkqQmNTVI4DDwIPBAebzamyLiaEPLnomjOCVJUlv2sotzWncDrwM+SREInwVcC3xnRDwtpdQd98SIuBi4aGjyFfOqaN32UZwGNEmS1Jy5B7SU0i8PTXpbRHwe+NfAC4G3TXj6tcCr5lW3STKPQZMkSS1p6zxo/xboA0/fodz1wBOGbs+bb9W2VBnNXZySJKlJTezifJiU0pmI+Dpw4Q7lTgAn6tOifvT+nOVZ0O8lBwlIkqRGtdKDFhHnUZxH7Z42lj+tKgx6DJokSWrSXANaRKyWYWzYrwABfHiey9+raiSn+UySJDVpT7s4I+JlwAXApeWk50TEY8r/3wA8AvhURLwVqC7t9EzghynC2U17Wf68VcegeSUBSZLUpL0eg/Zy4LG1+z9a3gBuAO4H3g88A/hJIAduB64Dfj2l1N/j8ueqGslpQJMkSU3aU0BLKT1uimI/sZdltCkb7OI0oEmSpOa0dZqNs0J1PU4HCUiSpCYZ0CYYnAfNfCZJkhpkQJug2sXpiWolSVKTDGgTDAKauzglSVKDDGgTDI5BW+ixppIk6VxjQJsgK9eOozglSVKTDGgTZF7qSZIktcCANkE+OAat5YpIkqQDxYA2QVSn2TChSZKkBhnQJqgGCTiKU5IkNcmANsHgGDR70CRJUoMMaBNkHoMmSZJaYECboDrNhrs4JUlSkwxoE+ReSUCSJLXAgDZBeAyaJElqgQFtgmoUpx1okiSpSQa0Ccp8Zg+aJElqlAFtgsxj0CRJUgsMaBMY0CRJUhsMaBNsXUmg5YpIkqQDxYA2QXgMmiRJaoEBbYKtUZwGNEmS1BwD2gSDa3Ea0CRJUoMMaBMMBgn0W66IJEk6UAxoE1TnQXMUpyRJapIBbYKtUZwGNEmS1BwD2gSZ1+KUJEktMKBNkHktTkmS1AID2gSDa3Ga0CRJUoMMaBPkXupJkiS1wIA2QXiaDUmS1AID2gR5uXbsQZMkSU0yoE3gKE5JktQGA9oEmedBkyRJLTCgTbB1JYF26yFJkg4WA9oEubs4JUlSCwxoE4Sn2ZAkSS0woE0wuBanPWiSJKlBMwe0iDgaEa+OiA9HxH0RkSLipWPKXlWWO1mW/YOIuGjmWjekUwY0ryQgSZKatJcetEcBrwSuAv5qXKGIeAzwUeDxwHXArwM/AvxxRCzvYflzV/WgeQyaJElqUmcPz70bOJ5S+mpEPAX48zHlrgOOAN+VUroDICJuBv4YeCnw5j3UYa6qgNY1oEmSpAbN3IOWUlpPKX11iqIvAN5fhbPyuX8CfB74sVmX34QqoKXkcWiSJKk5cx0kEBGXARcDfzHi4ZuBJ89z+XtVnWYDPA5NkiQ1Zy+7OKdxvPx794jH7gYujIiVlNL6qCdHxMXA8GCCK/axfhPleS2g9RNLeVNLliRJB9m8A9qh8u+oALZWKzMyoAHXAq/a70pNqxrFCQ4UkCRJzZl3QDtT/l0Z8djqUJlRrgfeMTTtCuCmPdZrKlltF6cDBSRJUlPmHdCqXZvHRzx2HLhv3O5NgJTSCeBEfVrUQtO81XvQHCQgSZKaMtdBAimlrwD3AE8Z8fA1wC3zXP5e5fnW6rEHTZIkNaWJSz29C3h2RFxeTYiIHwKu5OG7LxfKtlGcBjRJktSQPe3ijIiXARcAl5aTnlNeOQDgDSmlB4DXAC8CPhIRvwUcBV4BfAZ4y16WP2/bBgl4mg1JktSQvR6D9nLgsbX7P1reAG4AHkgp3RkRTwV+E3gtsAF8APiFScefLYKsHtB6BjRJktSMPQW0lNLjpix3G/DMvSyrDfagSZKkNjRxDNpZK992HrR+izWRJEkHiQFtgnpAcxSnJElqigFtgtwrCUiSpBYY0CbwNBuSJKkNBrQJ6hdLdxenJElqigFtAi/1JEmS2mBAmyD3YumSJKkFBrQJcnvQJElSCwxoE3iaDUmS1AYD2gSeZkOSJLXBgDZBJ9taPQY0SZLUFAPaBLV85i5OSZLUGAPaBPUetL4XS5ckSQ0xoE3gIAFJktQGA9oE2wcJ9FusiSRJOkgMaBN0tgW0FisiSZIOFAPaBJk9aJIkqQUGtAk6HoMmSZJaYECbwEs9SZKkNhjQJvBi6ZIkqQ0GtAny3Es9SZKk5hnQJvAYNEmS1AYD2gT1Kwl0Pc+GJElqiAFtgqXaLs7Nnj1okiSpGQa0CSJiMJKz63nQJElSQwxoO6h60exBkyRJTTGg7WCpPA5t02PQJElSQwxoO+iUPWhde9AkSVJDDGg76OTFKvIYNEmS1BQD2g6Wy4C20bUHTZIkNcOAtoPBLk570CRJUkMMaDuoribgMWiSJKkpBrQdLOWO4pQkSc0yoO3AgCZJkppmQNvB1jFo7uKUJEnNMKDtwBPVSpKkphnQduCJaiVJUtMMaDvoeAyaJElq2NwDWkQ8LSLSmNv3znv5e7XsxdIlSVLDOg0u6/XAnw9Nu73B5c+kk3mpJ0mS1KwmA9qfpZTe2eDy9oXHoEmSpKY1egxaRJwXEU2Gwj0bnAfNHjRJktSQJgPaW4AHgbWI+EhEPKXBZc9sqToGzYulS5KkhjTRm7UBvAv4IHAv8O3Ay4E/i4jvTyl9atwTI+Ji4KKhyVfMq6KjVKM4PQZNkiQ1Ze4BLaX0MeBjtUnvjYh3Ap8GfhV41oSnXwu8ao7V29FS5ihOSZLUrFaOB0sp3R4RNwE/GhF5Sqk3puj1wDuGpl0B3DTXCtZ4HjRJktS0Ng/YvxNYBo5QHJv2MCmlE8CJ+rSImH/NapY7RUDb6BrQJElSM9q8ksC3AGvAyRbrsKPVTg4UF0vv2osmSZIa0MSVBIYP8icivhN4LvBHKaWFTj2HlrdW0Zq9aJIkqQFN7OK8MSLOUAwUOEExivNngNPALzWw/D1ZXcoH/69t9ji6cladxk2SJJ2Fmkgb7wFeDPw8cAy4B3g38OqU0sJf6qnaxQlFQJMkSZq3Jk6z8XqK63CelVaWars4N93FKUmS5q/NQQJnheFdnJIkSfNmQNuBAU2SJDXNgLaDQ9sCmrs4JUnS/BnQdrC67Rg0e9AkSdL8GdB2sG0XZ9eAJkmS5s+AtoPtp9lwF6ckSZo/A9oO3MUpSZKaZkDbwYqjOCVJUsMMaDs4srwV0B5a67ZYE0mSdFAY0HbQyTMuOLwEwH2nNlqujSRJOggMaFN45JFlAL5+ar3lmkiSpIPAgDaFRx5ZAeDek/agSZKk+TOgTeGRR8setJP2oEmSpPkzoE1hENA8Bk2SJDXAgDaF4+cfAuD+05v2okmSpLkzoE3hOx9zweD/T3/5gfYqIkmSDgQD2hSe+JjzB//fcuf97VVEkiQdCAa0KZx/aIlvuegIYECTJEnzZ0Cb0pMuvwCAv/ry/aSU2q2MJEk6pxnQplQFtPtPb3LHfafbrYwkSTqnGdCmVB8o4G5OSZI0Twa0KV11/BhLeQDw2bsebLk2kiTpXGZAm9JyJ+PyCw8D8MV7T7VcG0mSdC4zoO3CtzyqGMlpQJMkSfNkQNuFby4D2n//+ml6fUdySpKk+TCg7cI3P+ooABu9Pnfdf6bl2kiSpHOVAW0Xqh40gC+4m1OSJM2JAW0X6gHtSwY0SZI0Jwa0XXj0sRUOLeWAAwUkSdL8GNB2ISIGvWju4pQkSfNiQNulb76oOtXGyZZrIkmSzlUGtF2qzoX25W+cYb3ba7k2kiTpXGRA26XHPbIIaCnBHV/3oumSJGn/GdB2qdrFCR6HJkmS5sOAtkvfUjvVhiM5JUnSPBjQdumCw8s86ugKALd+5YGWayNJks5FBrQZPPmbLgDgU3fc32o9JEnSucmANoPveuwjAPjK/Wf4wj2ebkOSJO2vRgJaRKxExK9FxF0RcSYiPhERz2hi2fPw9KsuHvz/nlvuarEmkiTpXNRUD9rvAT8P/CfgfwV6wAcj4gcaWv6+evzF53H1pccA+A9/+rf8zp99gbVNz4kmSZL2R6SU5ruAiGuATwCvSCn9ejltFbgVOJFS+v5dzu9q4NZbb72Vq6++et/rO62P/+3XecnvfoJev1h/R1c6fPulxzh+/irLeUYnz1jKgyyC1aWcY4c6HF3psL7Z56G1TR44s8lD612q1R/lfLMsWCqf28kyOnmQZ0EnK0qsbfZY2+yzttljvdvnyErOIw4vs9zJOLXeJSI4vJzTyYJvnN6k3rz9lIiAPIJuP7HZ69Prp2KZWdDJi+Ut5xmHlnNSgs1en81en24/QSrmkRIUdxPLnYyVTk5KiV4/0S/LFP8n+v3EQ+tdHlrrcmgp58hKzuHlDsudjKU8YzkvXm9W1qnX79Prb83j5HqXjV5/UL8AqpeUBSx3Mrr9xJmNHqc3epxa77LZS1x4ZIlvuvAw560usdnrs9Hrs9EtXkt/h7d8AHlWtF0q1/lGt09KiZWlnCyiXP9FW3Sy4NByzqGlnKU8G7QN8LDXudQpXkO3X6ybrGzXbq9oj81+nzyCIysdHjizyan1Lkt5NljW6lLOeasdlvOMCNjo9dnsluu6bJtEGrR79VKL+2nw/9bj28v2+4lHHFnm2OoSiaI9U0p0+4mVsq27vT6b/US3XJeJRKd83+YRrHeL9d3tFTOOKNZpBGTlnSCK+ffToL37KQ3e6508K/7WtoFUvrf6/USv/Fu15WZva5so3kdp8D6O8n2yUm6XZzZ7nCnfK1UbrXRyljrBRreYT0Rw4eFlOnls24bqb52sfB0R0O31We/16fW2toF+SuV7KWO5k5FFtT0V2+HqUs5qJ2d1qXj/V+useh9sdhPdflE+pUSn/ExYyrfWT55tbT+b5Xt8vVtsC/2Jn+3x8CnBYJ0dWc6J8n2+WbZjnhWfHf3EYP33am0BsLqcc3ipQz7hp/+kak2q8U5fVYeXc1aWMk6t93hwbZOTa11WOhmrSzm9VHxGdPt9jq4sDd5HK0sZ/QTrm326/eLzsNcv3u9QvN68/ExcWcoG23i3V3xWbZafc3nEoP7VNlhNKKZV2yYP30ZTetj06n61Rja6ibXNHoeXc46sdEgpDba96vMYEv0+ZBmsdHJWl4rPpEPLxTp4aK34HP7GqQ1Ob/ZY7RSfR5vdPql8rVB+xlN8FlTbeVZ+rxxezjm80hm8Px48s8npja3Oia1tPWr3o9hWopgeMPgMiICH1jbZ7CaWOuVnbqq2yaLeS3nG6Y0uD5wp2vTISocLDi/R6yfWNvskEuetdFhdLj6bN8vP+V4qPlsSiaxcblktUoJeP7He7bPe7XP1pcd4yfc+dvIbbA9uu+02nvCEJwA8IaV027TP68ytRlteSNFj9uZqQkppLSJ+F3hNRFyeUrqzgXrsq++74pH8x5d+N69+32184Z5TnFzvcvMX72u7WpIkaReedfUlcw1os2oioD0Z+HxK6cGh6TeXf58EnHUBDeCpV17EH/2zH+QPb/saH/nrE3zx3lPc89D64Fdy9Yus/iu0ct5qh2OrS0XPQO13Y69X/GrZLH9NF7/mivkkGPziXulUvxa7fOP0Jr1+4tBSTqL4VQHFL8r6L7ssir+9ftFTsZxn5FnQT6mob9kzstnrb/u1mpe/1LNtv4aKXyTr5a/2qmcuK8vlUfwayrLgyHLOsUNLrG32OLne4/RGd7COJskCjpS9bd3yl1wlIuj1Exu97T1YR1Y6dLLg3pPr3Hty42HzzLMYrJNx+qnoFajWwepSVvZYFT0K/ZSKdlgu2qLXS5wue2U2e/3y12vRhbDZS4Peu51kAZ08G/yKX84zjq52iv/LX5TFOuwWPXpQ9s4V7TjooYJtvxar3pLq1+3W/6OmF+tuvVtf17CUZWz0tr+GwboMBnWuyq90MjpZsQ7qPQTVr3PSVo9a9d7KsqJNu72tnqNp1lm1Hg4t5ayUPZZZVvSKnCl/3W/0+oPXtJQHh5aKntys7IVc3yx6wFY6xXw2e33uP7O5Y69N3XInY6nseY3y9Wz9Uu+Vyy56vlKCte7DPxcG67ts107Z8xoU86l6s6ve7+He4GrdH17uDHrdh417SSkVPQr1z6uq7aFou24/Fdt3+Tqr90DxWhNr3ene6/PWyYKjq51Bj2gny1hdKnpQH1rbJKLoqV3b7JFnwUonL3soY9tnRK/syd/o9ke+tqU8iIhBD+JguxqxrdV7l7Z6kcr7Q49FWaDahpfzov6nys/PLCvKDbb32Oql6qei1399s/+wbbaTBRccXua81U7Zo5iK11C+1vrne5ZR9GBnMeiBrPZSVD2My51s0JsGbPXs1bbzVJ9e6yGs9sgUPXMdNnrFXgqg7AnuD5YTAcdWlzi60uHketGblmfFdhzAyY3uw7bV+udTtazhx6vP1aOrTUSh3WuiVseBu0dMr6ZdOu6JEXExcNHQ5Cv2qV77opNn/Mh3HOdHvuP42DLVB9/J9e7gwzMf8+E5i+rNX82z+iBfXcpnnt96GbqWsmywG25S+WoD3e1y6l821a6aTrb1wTTLfCtVkFmqdi+WQWY39dtrHerz6pYf9FH7gqt2Sy7nW+u5Wv8rnWxflj1LXasQX19+9UVVfZEN160KadWX1n6ofqB0y92Cw6FgltfVmbT/bah8ZdTrqX8ZDa+raXV7xRd/Smmm92i1rfdTqgX1va/7jW4xz1neg9XhDZNMmuOk5Y17JAGnN7qsbfY5utJhdWk+2071fpzmc3ER9PppsF7OW+3s22fKerdHSsz8HTOtbnl4ymon37a+64eHVPc3yo6FYrf//n0GtamJgHYIWB8xfa32+DjXAq/a9xo1LMrj0Ob1Zo4I8tp7sejxmn1ZVX13U37W5VThaR6OrnRgZfbn7+cGvpvXutv1v98igk7+8Neelz2V41Q9rfupei+v7MMn1bjXNan8To/nVVfIjDp5xtE9vP/3uq2Ps9zZY532sE5mdd7qEuetzncZ81rf85JnMZf1stJpZh10yuNGhw2H4ywLVs+idplWEwHtDKO/Jldrj49zPfCOoWlXADftQ70kSZIWUhMB7W7gshHTq32CY08kllI6AZyoTzsXui0lSZImaeI8aLcAV0bEsaHp31N7XJIkSaUmAto7gRz4mWpCRKwA/xPwibPxFBuSJEnzNPddnCmlT0TEO4BfLUdl3g78JPA44KfmvXxJkqSzTVMn//jHwL8EfgJ4BPBp4NkppY82tHxJkqSzRiMBLaW0BryivEmSJGmCpi6WLkmSpCkZ0CRJkhaMAU2SJGnBGNAkSZIWjAFNkiRpwTR1mo39tAxw++23t10PSZKkiWp5ZXk3z4uU0v7XZo4i4rl4sXRJknR2eV5K6b3TFj4bA9r5wFOBO4GNOS3mCooQ+Dzgb+e0DO2e7bJ4bJPFZLssHttkMTXRLsvA5cCfppQemPZJZ90uzvLFTZ1AZxER1b9/m1K6bZ7L0vRsl8Vjmywm22Xx2CaLqcF2+dRun+AgAUmSpAVjQJMkSVowBjRJkqQFY0Ab7R7g1eVfLQ7bZfHYJovJdlk8tsliWth2OetGcUqSJJ3r7EGTJElaMAY0SZKkBWNAkyRJWjAGNEmSpAVjQJMkSVowBrSaiFiJiF+LiLsi4kxEfCIintF2vc5mEfHdEfHGiLgtIk5FxB0R8faIuHJE2asi4sMRcTIi7ouIP4iIi0aUyyLif4uIL0bEWkR8OiL+0ZjlTzXPgy4i/veISBFx64jHvj8i/p+IOB0RX42I10fE0RHlpt5+pp3nQRQRfyci3lu+X09HxK0R8U+HytgmDYqIb42It0XEl8v187mIeGVEHB4qZ7vss4g4GhGvLj/H7ys/p146pmxr3yG7mefUUkreyhvwVmAT+DfAzwAfK+//QNt1O1tvwDuBu4HXAz8N/Avgq8BJ4Am1co+hOA/N7cA/Ba4D7gNuAZaH5vmrQALeDPzPwPvL+/9wqNzU8zzIt3I9nSrb5Nahx54EnAE+Cfwc8K+ANeBDI+Yz1fazm3ketBvw94F14L8B/7x8f78WeJ1t0lqbXA58A/gS8EvlenxL+Zlzk+0y9/X/uHJd/3fgI+X/Lx1RrtXvkGnnuavX3vbKX5QbcE25Ml9em7ZaNszH2q7f2XoDvn/EG/lbyw+ZG2rTrgdOA99Um/b0sk1+pjbtMmADeGNtWgAfBe4E8t3O86DfgLcB/zfwX3l4QPsgcBdwrDbtp8t1+Pdr06befqad50G7Accofry8G8gmlLNNmm2X68r1cPXQ9N8vpz/Cdpnr+l8BLin/fwrjA1pr3yG7meeuXnvbK39RbsDrgG59Qyin/3LZGJe3Xcdz6Qb8JfCXtftfA94+otxfA39Su39t2R7fPlTuH5XTf2C38zzIN+AHy/f9ExkKaBSBYZNa7005fRl4CPid2rSptp/dzPOg3Sh6SBJwVXn/CENBzTZppV1eW66vR42Y3ivbyXZppi0mBbTWvkN2M8/d3DwGbcuTgc+nlB4cmn5z+fdJzVbn3BURATwauLe8fxlwMfAXI4rfTNE2lSdT7I77/0aUqx7f7TwPpIjIgTdQfNB/ZkSRJwIdhtZhSmmDoot/uF2m2X52M8+D5unAg8BlEfHXFLucH4yIfx8Rq2UZ26R5/7X8+7sR8aSIuDwi/gHwT4DXp5ROYbu0agG+Q6aa524Z0LYcpzhWalg17dIG63KuezFFl/CN5f3j5d9x6//CiFiplf1aKn+eDJWDrXbazTwPqp8DHgv8ypjHd1qHlw6VnWb72c08D5pvpfhCvgn4Q+AFwH+kaKe3lGVsk4allD5MsY08A/gUcAfFYQFvSCn987KY7dKutr9Dpp3nrnRmedI56hDFwbnD1mqPa48i4tuANwEfpziGA7bW7U7rf53p22k38zxwIuKRwP8B/MuU0riLBO+0Dg8Nld2PdjnI29lR4DDwH1JK1ajNd0fEMvCzEfFKbJO2fInieKJ3AV8HfgS4LiK+mlJ6I7ZL29r+DplLfjCgbTlDcTDisNXa49qDiLgE+ADwAPDClFKvfKhat9Os/2nbaTfzPIj+FcVopDdMKLPTOjwzVHY/2uUgt0n12t86NP0/Az8LfB/FActgmzQmIv4hxci8K1NKXy4nvzsiMuDXIuKtuK20re3vkLnkB3dxbrmbrS7NumraXQ3W5ZwTEecDHwIuAJ6VUqqvz6obeNz6vy+ltF4re0l5HNtwOdhqp93M80CJiG+lGNr/euDSiHhcRDyO4sNkqbx/ITuvw+E2nGb72c08D5rqtX9taPqJ8u8jsE3acC3wqVo4q7yXosfzydgubWv7O2Taee6KAW3LLcCVEXFsaPr31B7XDMoDnN8HXAk8O6X02frjKaWvUJxr5ikjnn4N29f9LRQfilcNldvWTruc50FzGcW2/3rgi7Xb91C00ReBVwK3Uow227YOy11uT+Lh7TLN9rObeR40f1n+vWxoenX8yj3YJm14NJCPmL5U/u1gu7RqAb5DpprnrrU9bHZRbuWKHD43zQrwN8B/a7t+Z+uN4oPtJorh4j88ody/p9h9c3lt2g+VbfJztWmPYfz5Zr7M9nPYTDXPg3YDHgU8f8TtVoqTQT4feGJZ9kMUv/7Oqz3/p8p1+KzatKm3n2nnedBuFD0xCfhPQ9P/c7n9XGqbtNIu76M4vujKoen/heI0G7ZLc20x6TQbrX2H7Gaeu3q9ba/wRboBby8/CF9HsQvo/y3v/2DbdTtbb8C/K9/M7wVeMnyrlbuc4rQbtwP/C8U5ge4DPg2sDM3zdeU8f5vipI3VGZt/fKjc1PP0lmD0iWr/DsWBrvUzmZ8B/nDE86fafnYzz4N2A363fC/fSLFr7e3l/dfYJq21SXWuwK9RjOa8luIEsgn4P22XRtrgZRRXobm+XO/vKu//C+D8skyr3yHTznNXr7vtFb9IN4pjcP4Nxf7kNYpzmDyz7XqdzTeKL/007jZU9mqK0wucori0yg3Ao0fMMys3lC9R/LK9FXjxmOVPNU9vowNaOf0Hyi+QMxTHQ72R2i/6Wrmpt59p53nQbhS7zV5Vvrc3KHpV/plt0nq7XEMRyu4u2+WvKa4w0LFdGln/X5rwPfK4WrnWvkN2M89pb1HOWJIkSQvCQQKSJEkLxoAmSZK0YAxokiRJC8aAJkmStGAMaJIkSQvGgCZJkrRgDGiSJEkLxoAmSZK0YAxokiRJC8aAJkmStGAMaJIkSQvGgCZJkrRgDGiSJEkLxoAmSZK0YAxokiRJC+b/Bxl6mkxwtk+PAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x480 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 4), dpi=120)\n",
    "plt.plot(steps, target_distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d11388de-c9b3-4bf3-b917-e139eedb63c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "if run_id != 0:\n",
    "    data_storage.write_losses(run_id, steps, losses, target_distances, database, user, password, host)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
