{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "3c83ecd2",
   "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.01\n",
    "momentum = 0.95\n",
    "iterations = 20000\n",
    "\n",
    "# Problem params\n",
    "nn_width = 20\n",
    "nn_layers = 2\n",
    "input_dimensions = 2\n",
    "observation_noise_variance = 0.1\n",
    "batch_size = 20\n",
    "test_set_size = 100\n",
    "\n",
    "# Sampling params\n",
    "instantaneous_domain_variance = 0.25\n",
    "mean_switching_variance = 0.25\n",
    "mean_switching_interval = 3\n",
    "\n",
    "# Storage params\n",
    "database = 'neural_net'\n",
    "user = 'postgres'\n",
    "password = 'password'\n",
    "host = 'localhost'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "0197e74a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from functools import partial\n",
    "# Using jax for its jit and autograd capabilities.  Will not get around to GPU backends for now.\n",
    "import jax.numpy as jnp\n",
    "from jax import value_and_grad, jit, vmap\n",
    "from jax import random\n",
    "\n",
    "import matplotlib.pyplot as plt\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": 86,
   "id": "5de6ce9e-ea19-44e9-8ba0-4835324cf142",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_sample(weights, bound):\n",
    "    input_x = jnp.linspace(-bound, bound, 100)\n",
    "    input_y = jnp.linspace(-bound, bound, 100)\n",
    "    input_batch = jnp.vstack([input_x, input_y]).T\n",
    "\n",
    "    targets = batched_target_without_noise(input_batch)\n",
    "    predictions = batched_predict(input_batch, weights)\n",
    "    \n",
    "    plt.plot(input_x, predictions, linewidth=2, label='model')\n",
    "    plt.plot(input_x, targets, linestyle=':', color='black', label='target')\n",
    "    plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "ee0af5bc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXIAAAD4CAYAAADxeG0DAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAA6sElEQVR4nO3dd3xUVf7/8deZVEICgSSEkoTeS4DQQaqggqKCIIgUGyi6lnUt32V3XViVteyu/kBFFrERqQICdgSkGUIChN4hASSF9N7m/P5IyCIGSMjM3Cmf5+ORBzOTm3PfuSSf3Dn33HOU1hohhBCOy2R0ACGEEDUjhVwIIRycFHIhhHBwUsiFEMLBSSEXQggH527ETgMDA3WzZs2M2LUQQjis2NjYS1rroKtfN6SQN2vWjJiYGCN2LYQQDkspFV/Z69K1IoQQDk4KuRBCODgp5EII4eAM6SMXQojKFBcXc/78eQoKCoyOYihvb29CQkLw8PCo0vZSyIUQduP8+fP4+fnRrFkzlFJGxzGE1prU1FTOnz9P8+bNq/Q10rUihLAbBQUFBAQEuGwRB1BKERAQUK13JQ5VyEvNmuJSs9ExhBBW5MpF/LLqHgOHKuT/+uEYkxbtIiW70OgoQghhNxymkGcVFPPlnvNEn0njznnb2JOQbnQkIYS4rmbNmnHp0qUab3MjDlPI63h7sP4PA+jZrB5JWYXc/+EvfB4VjyyMIYRwdQ5TyAEa+HnzxWN9mNavGcWlmr+uPcgLq/ZTUFxqdDQhhJM4e/Ys7dq1Y9q0abRp04ZJkyaxceNG+vfvT+vWrYmOjiYtLY177rmHLl260KdPH/bv3w9AamoqI0aMoGPHjjz66KO/OdFcsmQJvXr1omvXrsyYMYPSUsvVLYcbfujhZuLvozsSHlqX/1t9gFWx5zmamMUHkyIIre9jdDwhhIU0e/lrq7R79p+jbrjNyZMnWblyJYsXL6Znz5588cUXbN++nXXr1vH6668TGhpKt27dWLt2LZs2bWLKlCns27eP2bNnM2DAAP72t7/x9ddf89FHHwFw5MgRli9fzo4dO/Dw8GDmzJlERkYyZcoUi3xPDlfIL7u3Wwhtg+swY0kMBy9kcdf87cyb2I1bWv9uYjAhhKiW5s2b07lzZwA6duzIsGHDUErRuXNnzp49S3x8PF9++SUAQ4cOJTU1laysLLZu3crq1asBGDVqFPXq1QPgp59+IjY2lp49ewKQn59PgwYNLJbXYQs5QIfGdVj/1ACeXb6PLcdSmLo4mj/d1pYnBrWUIUxCOLiqnDlbi5eXV8Vjk8lU8dxkMlFSUlLlOy4v01ozdepU5s6da9GclzlUH3ll/H08+WhqT54e2gqzhje/O8YTS/aQU1hidDQhhJO65ZZbiIyMBGDLli0EBgZSp04dBg4cyBdffAHAt99+S3p62ei6YcOGsWrVKpKTkwFIS0sjPr7SGWlvikXOyJVSZ4FsoBQo0Vr3sES7VeVmUvxxRFu6hPjz3PJ9fHcokRPzs/lwcg9aNfC1ZRQhhAv4+9//zsMPP0yXLl3w8fHh008/BeCVV15h4sSJdOzYkX79+hEWFgZAhw4dePXVVxkxYgRmsxkPDw/ee+89mjZtapE8yhLD98oLeQ+tdZUGQ/bo0UNba2GJM5dymfF5DMeTcvD1cuftceHc3qmhVfYlhLCsI0eO0L59e6Nj2IXKjoVSKrayE2WH71q5WvPA2qyZ2Z87uzQip7CEx5fE8sZ3Ryk1y3hzIYRzslQh18APSqlYpdT0yjZQSk1XSsUopWJSUlIstNvK1fZyZ97EbvxlVHvcTIoPtpxi2sfRpOUWWXW/QghhBEsV8gFa6+7AHcCTSqmBV2+gtV6ote6hte4RFGT9IYJKKR69pQVLHulNQG1Ptp24xF3ztnPgfKbV9y2EELZkkUKutb5Q/m8ysAboZYl2LaFvywA2PD2A8FB/LmTkM3bBTlbGnDM6lhBCWEyNC7lSqrZSyu/yY2AEcLCm7VpSo7q1WDGjDw/0DqOoxMwLq/Yza80BCkvk1n4hhOOzxBl5MLBdKRUHRANfa62/s0C7FuXl7sbr93bmjbGd8XQ3EbkrgQkLo0jMdO0lpYQQjq/GhVxrfVprHV7+0VFr/ZolglnL/T3DWDmjL43rerM3IYM7521j1+lUo2MJIexARkYG77//vtX3s3btWg4fPmyx9pxu+GFVhIf6s/4PA+jXMoBLOUU8sGgXi7efkSlxhXBx1S3kWmvM5uqvWiaF3EICfL347OFezBjYglKzZs6Gwzy7fB95RXJrvxCu6uWXX+bUqVN07dqV5557jmHDhtG9e3c6d+7MV199BZRNc9u2bVumTJlCp06dOHfuHP/4xz9o27YtAwYMYOLEibz99tsAnDp1ittvv52IiAhuueUWjh49ys6dO1m3bh0vvPACXbt25dSpUzUPrrW2+UdERIS2JxviftXt//qtbvrSBn3bf37WZ1JyjI4khEs6fPjwb54PGjRIf/zxx1prrYuKivSgQYP0559/rrXWOjc3Vw8aNEgvW7ZMa611RkaGHjRokP7yyy+11lqnpKToQYMG6XXr1mmttb548eIN93/mzBndsWNHrbXWxcXFOjMzs6Ktli1barPZrM+cOaOVUvqXX37RWmsdHR2tw8PDdX5+vs7KytKtWrXSb731ltZa66FDh+rjx49rrbWOiorSQ4YM0VprPXXqVL1y5cpqHQuttQZidCU11aFnP7SUUV0a0SbYlxmfx3I0MZu75m/n3QldGdou2OhoQgiDaK3585//zNatWzGZTFy4cIGkpCQAmjZtSp8+fQDYsWMHd999N97e3nh7e3PXXXcBkJOTw86dOxk3blxFm4WF1llvWAp5udbBfqx9qj9/WhHHD4eTePiTGJ69tTVPD22NySRT4gphhC1btlQ89vDw+M1zHx+f3zyvW7fub54HBgb+5nnDhtWbcykyMpKUlBRiY2Px8PCgWbNmFBSUjXKrXbv2Db/ebDbj7+/Pvn37qrXfm+GyfeSVqePtwYIHI3jhtrYoBe9sPMGjn8WQmVdsdDQhhA34+fmRnZ0NQGZmJg0aNMDDw4PNmzdfc9rZ/v37s379egoKCsjJyWHDhg0A1KlTh+bNm7Ny5Uqg7Aw/Li7ud/uxBCnkVzGZFE8OacUnD/XC38eDTUeTGf3edo5czDI6mhDCygICAujfvz+dOnVi3759xMTE0LlzZz777DPatWtX6df07NmT0aNH06VLF+644w46d+5M3bp1gbKz+o8++ojw8HA6duxYccF0woQJvPXWW3Tr1s0iFzstMo1tdVlzGltLOpeWx4zPYzl8MQtvDxNvjO3C3V2bGB1LCKflqNPY5uTk4OvrS15eHgMHDmThwoV07969Rm269DS2lhRa34fVM/sxpnsTCorNPLNsH3PWH6a4tPrjRoUQzmv69Ol07dqV7t27M3bs2BoX8eqSi5034O3hxr/GhdMt1J/Z6w+zeMcZDv6ayXsPdCfIz+vGDQghnN7l5d2MImfkVaCUYnLfZiyf0YcGfl5En0njznnbiI1PNzqaEE7HiO5ee1PdYyCFvBoimtZnw9MD6NmsHklZhUxY+AtLouLlB08IC/H29iY1NdWlf6e01qSmpuLt7V3lr5GLnTehuNTMa18f4ZOdZwG4LyKEV+/phLeHm7HBhHBwxcXFnD9/vmK8tqvy9vYmJCQEDw+P37x+rYudUshrYO3eC7y8ej8FxWY6NanDggcjCKnnY3QsIYSTklErVnBPtyasfqI/YfV9OHghi7vmbWfbCeuuRyqEEFeTQl5DHRrXYf1TAxjcNoj0vGKmLo7m/S0nXbqPTwhhW1LILaCujweLp/bk6WGtMWt487tjPLFkD9kFcmu/EML6pJBbiMmk+OPwNiya0gM/L3e+O5TIPe/t4GSy5eZTEEKIykght7BbOwSz7g8DaBPsy6mUXO6ev4PvDl40OpYQwolJIbeC5oG1WTOzP6O6NCK3qJTHl+zhn98epdQs/eZCCMuTQm4ltb3cmT+xG7NGtsfNpFjw8ymmLo4mLbfI6GhCCCcjhdyKlFI8NrAFnz/Si4Danmw/eYm75m3nwPlMo6MJIZyIxQq5UspNKbVXKbXBUm06i34tA1n/hwGEh/pzISOfsQt2siLmnNGxhBBOwpJn5M8ARyzYnlNp7F+LFTP6MLFXGEUlZl5ctZ9Zaw5QVCJT4gohasYihVwpFQKMAhZZoj1n5eXuxtwxnfnnmM54upmI3JXA/Qt/ITHTteeVEELUjKXOyN8BXgSueXqplJqulIpRSsWkpLj2bewTeoWx8vG+NK7rzd6EDO6ct41dp1ONjiWEcFA1LuRKqTuBZK117PW201ov1Fr30Fr3CAoKquluHV54qD/r/zCA/q0CuJRTxAOLdvHR9jNya78QotoscUbeHxitlDoLLAOGKqWWWKBdpxfg68WnD/VixqAWlJo1/9hwmGeW7SOvqMToaEIIB1LjQq61/j+tdYjWuhkwAdiktX6wxslchLubif+7oz3vT+pObU831sX9ypj3dxKfmmt0NCGEg5Bx5HZiZOdGrH2yPy0Ca3M0MZu75m1n09Eko2MJIRyARQu51nqL1vpOS7bpSloH+/HVU/0Z0SGYrIISHvk0hnc2Hscst/YLIa5DzsjtjJ+3BwsejOCF29oC8M7GEzz2WQyZ+TIlrhCiclLI7ZDJpHhySCs+eagX/j4e/HQ0mdHzt3M0McvoaEIIOySF3I4NahPE+qcG0KFRHeJT87j3vZ18te+C0bGEEHZGCrmdC63vw+qZ/RjTvQn5xaU8s2wfc9YfprhUbu0XQpSRQu4AvD3c+Ne4cP5xd0c83BSLd5xh0qJdpGQXGh1NCGEHpJA7CKUUk/s2Y9n0PjTw8yL6TBp3ztvGnoR0o6MJIQwmhdzBRDStz4anB9CrWX2Ssgq5/8NfWBIVL7f2C+HCpJA7oAZ+3kQ+1puH+jejuFTzl7UHeXHVfgqKS42OJoQwgBRyB+XhZuKVuzry7oSueHuYWBl7nvsW7OR8ep7R0YQQNiaF3MHd3bUJa2b2J6y+DwcvZHHXvO1sO+Ha0wQL4WqkkDuB9o3qsP6pAQxpG0R6XjFTF0fzzsbj0tUihIuQQu4k6vp48NHUnjwzrDVmXXZr/7B//cxX+y7IhVAhnJwUcidiMimeG96GLx7tTbuGflzIyOeZZfu4570dRMkKREI4LWXE2VqPHj10TEyMzffrSkrNmlWx53j7h+MVNw4Na9eAl+5oR5tgP4PTCSFuhlIqVmvd43evSyF3brmFJSzadoYPt54ir6gUk4LxPUJ5bngbgut4Gx1PCFENUshdXEp2Ie/+dJyl0ecoNWu8PUw8dksLHh/Uktpe7kbHE0JUgRRyAcCplBze+u4Y3x1KBCC4jhcv39GOe7o2QSllcDohxPVcq5DLxU4X0zLIlwWTI/jyib6Eh9QlKauQ55bHcd+CX0jOLjA6nhDiJkghd1ERTeuzZmZ/3rqvC4G+XsTGpzNxYRTJWVLMhXA0UshdmMmkGNcjlO+fvYV2Df04lZLLhP9KMRfC0UghFwT4ehFZPvb8dHkxl7nOhXAcUsgFUFbMv3isT0Uxf/SzGPKL5BZ/IRxBjQu5UspbKRWtlIpTSh1SSs22RDBhe/Vre/L5I70JqVeLuHMZPLt8L6Vmub1fCHtniTPyQmCo1joc6ArcrpTqY4F2hQGC/Lz4eFpP/Lzd+f5QEnO/OWJ0JCHEDdS4kOsyOeVPPco/5DTOgbUO9uPDByPwcFMs2n6GZdEJRkcSQlyHRfrIlVJuSql9QDLwo9Z6VyXbTFdKxSilYlJSZL5se9evVSCv39sZgL+tO8SB85kGJxJCXItFCrnWulRr3RUIAXoppTpVss1CrXUPrXWPoKAgS+xWWNm4HqFM6h1GUYmZx5fEkpFXZHQkIUQlLDpqRWudAWwGbrdku8I4f7urA+EhdbmQkc+zy/dhloufQtgdS4xaCVJK+Zc/rgUMB47WtF1hH7zc3Xj/wQjq+Xiw5VgK8zadNDqSEOIqljgjbwRsVkrtB3ZT1ke+wQLtCjvRxL8W707ohlLwzk/HZU1QIeyMJUat7Ndad9Nad9Fad9Jaz7FEMGFfBrYJ4plhrdEanlm2j18z8o2OJIQoJ3d2iip7emhrBrYJIi23iKe+2ENRidnoSEIIpJCLajCZFO/c35VGdb3Zk5DB3G/lZiEh7IEUclEt9Wt78t6k7ni4KT7ecZav9180OpIQDiG7oJjF289wLi3P4m1LIRfV1j2sHrNGtgfgxVVxnErJucFXCOG6ElLzmLP+MH3nbmLOhsN8svOsxfchizWKmzK1XzN2x6fz9f6LPLEklrVP9sfHU36chAAoNWt+Pp5MZFQCm44lc3lFzV7N69O/VYDF9ye/eeKmKKV4Y2wXjlzM4nhSDrPWHOTf48Nl3U/h0pKzClgRc46l0ee4UD6yy9PNxJ3hjXi4f3M6Nalrlf1KIRc3zdfLnQUPRnD3/B2s2XuB7mH+TO7bzOhYQtiU2azZeSqVL6Lj+eFQEiXldz83DfDhgV5h3BcRQoCvl1UzSCEXNdIm2I837uvC00v3MmfDYTo0rktE03pGxxLC6tJzi1gVe54vohM4cykXADeT4vaODXmgdxgDWgViMtnmHaoUclFjo8MbszchnY93nGVmZCwb/nALQX7WPQMRwghaa2Li04mMiuebA4kUlZbdS9GorjcTeoZxf89QGtb1tnkuKeTCIv48sj0HzmcSE5/OE0tiWfJob7w93IyOJYRFZBUUs2bPBSJ3xXM8qWyUllIwuG0QD/ZuyuC2Qbi7GTcIUAq5sAgPNxPvT+rO3e/tICY+nedXxDFvYjebvbUUwhr2n88gMiqBdXG/kl9ctoZtoK8n9/cMZULPMELr+xicsIwUcmExDep48/FDPRn3wS98feAiTerV4s/l482FcBS5hSWsj/uVyF0JHLjwvwVV+rUMYFLvpgzvEIynu33dgiOFXFhUu4Z1WDA5gqmLo1m49TRN/GsxtV8zo2MJcUNHE7P4YlcCa/ZcILuwBAB/Hw/u6x7CA73DaBHka3DCa5NCLiyuf6tA3hjbhedXxvH39Ydo4OfFHZ0bGR1LiN8pKC7l24MXiYxKICY+veL1iKb1eKBXGKO6NHKIaz1SyIVVjI0IITGrgLe+P8Yzy/cR4OtFr+b1jY4lBABnLuXyxa54VsaeJyOvGCi7L+Lebk2Y1CeMdg3rGJyweqSQC6uZObgliZkFfB4Vz6Of7mbVE/1oE+xndCzhokpKzWw8ksSSqAS2n7xU8XqnJnV4sHdT7gpvTG0vxyyJjplaOASlFH8f3ZGkrAJ+OJzEtMXRrJ7Z35BxtsJ1JWUVsCz6HEujE0jMKgDA28PE6PDGTOrdlPBQf2MDWoAUcmFVbibF/5vYjUmLdhEbn860j6NZ+Xhf/Lw9jI4mnJjWml9Op7IkKp7vDyVRWn7bfIug2jzYuylju4dQ18d5fgalkAur8/ZwY9GUHoz9YCdHE7N5YskeFk/raXdDuITjy8wvZvWe8yyJiudUyv9umx/ZuSEP9m5K35YBTjmxmxRyYRP1anvy6cO9uPf9HWw/eYmXV+/nX+NktkRhGQcvZLIkKp6v9v3vxp3gOl5M6BnGxF5hTt+dJ4Vc2ExofR8+ntaL+xf+wuo9F2gT7Mfjg1oaHUs4qILiUr7ef5Elu+LZm5BR8Xr/VgFM7tOUYe2D8TDwtnlbkkIubKpzSF3+Pb4rjy+J5Y3vjtK6gS/D2gcbHUs4kNMpOSzbfY6VMedILx866OftzriIUCb1CaOlHd+4Yy1SyIXN3d6pIc8Pb8O/fjzO00v3subJ/jIsUVxXdkEx3x9KYsXuc0SfTat4/fLQwdFdG7v0ClU1/s6VUqHAZ0AwoIGFWut3a9qucG5PDW3FsaRsNuy/yKOfxvDVk/2pV9vT6FjCjsSn5vLTkWR+OppE9Jk0ikvLRp74eLoxqnMjJvVpSnhIXbnOgmXOyEuA57XWe5RSfkCsUupHrfVhC7QtnJRSirfuCyc+NY8DFzJ5IjKWzx/p7TJ9muL3SkrNxMans+loMhuPJFWMOgEwqbL1Lsd2b8KoLo3xddAbd6ylxkdDa30RuFj+OFspdQRoAkghF9dVy9ONhVMiGD1/B1Gn05i9/hCv3tPZ6FjChjLzivn5RAo/HUliy7EUMvOLKz7n5+3OoDZB3No+mEFtguQd23VY9M+aUqoZ0A3YVcnnpgPTAcLCwiy5W+HAGtWtxYeTI5iwMIolUQm0DfaTdT+dmNaa05dy2XSk7Kw7Jj694mYdgBaBtRnargHD2gfTo1k9eYdWRUprfeOtqtKQUr7Az8BrWuvV19u2R48eOiYmxiL7Fc5h9Z7z/HFFHG4mxYcPRnBrBxnJ4iyKSszEnE1j45FkNh1N4mxqXsXn3E2Kns3qM6x9A4a2a2DXU8XaA6VUrNa6x9WvW+SMXCnlAXwJRN6oiAtRmTHdQzhzKZd5m07y5Bd7+OzhXvRuEWB0LHGT0nKL2HIsmZ+OJrP1WErF/N5QNsf3kLZlhXtgmyDq1nKeW+WNYolRKwr4CDiitf53zSMJV/XH4W1IzS3ii10JPPppDMtm9KFj47pGxxJVoLXmRHIOG48kselIMnsS0rmix6TifoFh7RvQPawebrIEoEVZ4oy8PzAZOKCU2lf+2p+11t9YoG3hQpRS/OPuTmTkFfHNgUSmLo5m6WN9aC1jzO1SYUkpu06nselo2RDBc2n5FZ/zcFP0bxFQ1t/dLpiwAPtY29JZWWLUynZA/rwKi3AzKf5zf1eyC2LYduISE/8bJcXcjlzKKWTz0WR+OpLMthMp5BaVVnwuoLYnQ9o1YFi7BgxoHSgzXNqQxS52Vodc7BQ3UlBcymOflRXzgNqefPFYH9o2lGJua1prjlzMZtPRJDYeSSbufAZXlox2Df0Y1r5slEl4iL90mVjZtS52SiEXduvKYl6/tif/b0I3BrQONDqW0ysoLuWX06n8VN7f/WtmQcXnPN1N9GsZwLD2wQxt14Am/rUMTOp6pJALh1RQXMoTS2LZfCwFpeCJQS15bngbGV9sYclZBeV3VCaz4+SliqlgAYL8vBhWPra7f6sAl57TxGhSyIXDKjVr3tt8knc2HsesoXuYP+9O6EZofbmAdrO01hy+mMUPh5LYdDSZAxcyf/P5Tk3qMKxd2SiTTo3rYpIuE7sghVw4vF2nU3l2+T4uZhbg5+3Om2O7cEfnRkbHcijHErNZs/cC3x68SPwVN+Z4e5gY0CqQYe2DGdK2gdMvxOCopJALp5CeW8QLq/az8UgSAJN6h/HXOzvg7eFmcDL7VVBcyncHE1kSFU9MfHrF6wG1PRnRsSHDOzSgX8tAOYYOQAq5cBpaaz7deZbXvzlKUamZtsF+zH+gmwxRvMqZS7ksjU74zQIMvl7u3N21MXeFN6Zns/oyysTBSCEXTufghUyeXrqX05dy8fYwMXt0R8b3CHXp+amLS81sPJxE5K4Etp+8VPF6x8Z1eLBPU0aHN6a2TAHrsKSQC6eUW1jC3746xJd7zgNwV3hjXru3E3Vc7GaUCxn5LItOYNnuc6RkFwJl/d53dWnMg32a0kUWYHAKVp00Swij1PZy51/jwxnQOoC/rDnI+rhfiTuXwbyJ3QgP9Tc6nlWVmjVbT6QQGRXPpqPJFXObtGrgy6TeYYzpFkJdH9f6g+aqpJALp3BvtxDCQ/z5w9K9HPo1i7Ef7OSF29ry2C0tnG7oXEp2IStizrE0OoHz6WXzm3i4KUZ1asQDvcLo06K+nH27GOlaEU6lsKSUf357lI93nAVgYJsg/j0+nEBfL2OD1ZDWmqjTaSzZFc8PhxIr1q8MrV+Lib3CGN8j1OG/R3Fj0kcuXMrGw0m8sCqO9Lxigvy8+M/4rg55e//J5GzWx11kfdyvnL5UtoalScGt7YN5oHcYA1sHOd07DnFtUsiFy0nMLOCZZXvZdSYNpWDm4JY8e6v9395/5lIuX+//lQ37L3I0Mbvi9eA6XkzoGcaEXqE0qitznLgiKeTCJZWaNfM3neTdn8pu749oWo93J3QlpJ593d4fn5rLhv0X+Xr/RQ5fzKp4vY63O7d3asidXRrTr2UA7nb+R0hYlxRy4dJ2nU7lmWX7SMwqu73/tXs7Mzq8saGZzqXl8fWBsuJ95Vwnfl7uDO8QzKgujRjQOhAvd7njUpSRQi5cXnpuES9+uZ8fD5fd3j+mWxNm393RpgsgnE/P49sDiWzY/ytx5/9XvGt7ujG8QzAjOzdiYJsguV1eVEoKuRCUjf5YGn2OORsOUVBspol/Ld4eF07fltZb6DmroJiv9v3K6j3n2ZuQUfG6j6cbt7YvK96D20rxFjcmhVyIK5xMzuHZ5Xs5eKGsP/qh/s146fZ2FiumWmv2nstgWXQC6+MuVszvXcvDjaHtG3Bn50YMaddAireoFinkQlyluNTM/E0nmb/5JKVmTYug2vx7fFe61uCO0OSsAtbvv8jy3QkcT8qpeL1Pi/pM7BXG8A7BsjCDuGlSyIW4hgPnM/njin2cSM7BpGDm4FY8Paw1nu43HiFSatbsO5fOlmMpbD6WXHGGDxDo68nY7iHc3zOUFkG+1vwWhIuQQi7EdRQUl/LvH4/z322n0RpaN/DlL3d2YFCboN9tm5pTyNYTKWw+msLWEylklE8RC/9boOG+iBCGtguu0h8DIarKqoVcKbUYuBNI1lp3utH2UsiFvdp9No0XVsZxtnz1nMFtg7izS2Mu5RSSmFnA3nMZ7L9qJfmmAT4MbhPEkHYN6NMiQPq9hdVYu5APBHKAz6SQC0dXWFLKJzvOMn/TSbILS373eU93E72b12dw2wYMbdeA5oG1DUgpXJFVp7HVWm9VSjWzRFvOoLS0lEuXLhEcHAxAZGQknp6ejBs3zuBkojKZmZnUrVsXgAMHDrB582bGjh3L2IjB/HfraX7NLCDYz4vgOt60bFCbPi1kJXmjaK0pKirCy6tsgrB58+bRokULRo0aZXAyY9msA08pNV0pFaOUiklJSbHVbg0xZMgQJk2aVPH8jTfe4Kuvvqp4vnbtWoqLiyv7UmFja9asITAwkOPHjwOwc+dOnn/+eWrVqkWgrxdD6mcyqXkhf7mzA48NbMHQdjLqxCilpaV07dqV//u//6t47bnnnuPQoUMAFBcX889//pP09PRrNeG8tNYW+QCaAQersm1ERIR2Jnl5efr999/XpaWlWmutly1bpleuXFnx+YyMDJ2VlaW11jopKUkrpfTs2bMNySq0Pnz4sD5y5IjWWutz587pF198USckJGittc7Pz9dpaWkV2z7wwAO6YcOGOj8/35Csrs5sNuvdu3dXPP/rX/+qv/jii4rnqampuqCgQGut9a5du7RSSkdGRto8p60AMbqy+lvZizfz4cqFfOnSpRrQP/30U5W2X7dunc7IyNBaa/3rr7/qoqIia8YTVygqKtIhISH69ttvr9L22dnZOiYmRmtdVlSio6OtGU9c5e2339Zubm760KFDVdr+2LFj2mw2a621/vnnn3VycrI149mcFHIryMvL01qX/YLv2rWr2l9vNpv1kCFD9JgxYyp++IR1XHl8t23bppOSkqrdxsqVK7Wbm5veuXOnJaOJ60hPT9cfffRRxbvdqiouLtZNmzbVd955p5WSGeNahdwifeRKqaXAL0BbpdR5pdQjlmjXnq1evZq2bdty+vRplFL06tWr2m0opbj//vuZNGmSLM1lRQUFBYwZM4b//ve/AAwYMIAGDRpUu53bbruN1157jd69e1s6orjCnj17mDx5MkVFRfj7+/Pwww9jMlWvVLm7uxMZGcl7771npZT2xSKFXGs9UWvdSGvtobUO0Vp/ZIl27Vm7du3o2bMngYE1W3VmxowZjBkzBoDt27eTkZFhgXTiSiaTieLiYoqKimrUjp+fHy+99BImk4m0tDQWLVpkoYTiSvv372fbtm0kJibWqJ3+/fsTFhaG1ppXX3214qKoU6rsNN3aH47ctWKtPrfs7Gxdr149/cgjj1ilfVdkNpt1cXGx1lpX+635jcyePVt7enrqM2fOWLRdUSYnJ8dibaWkpOhGjRrpl156yWJtGgVrdq24ipMnT9KmTRsWLlxo8bZ9fX35/PPP+ec//2nxtl3V66+/zogRI8jLy6v2W/Mbefnll4mKiqJZs2YWbddVZWdnM3z4cKKiogCoXdtyN1kFBgYSGxvL3LlzLdamvZFCXg2hoaFMnTqV2267zSrtjxo1isDAQMxmM7t377bKPlxJWFgYLVu2pFYty69v6enpSbdu3QDYtGkT586ds/g+XElycjLnzp0jJyfnxhvfhEaNGqGU4uLFi8ydO/fyAA3nUdlpurU/HK1rpbS01KZDBN98803t7u6u4+LibLZPcXOysrJ0/fr19bhx44yO4vBs8Tv25ptvah8fnyoPZ7Q3SNfKzXvnnXfo16+fzS5Ezpgxg0WLFtG5c2eb7M+ZFBYWMmLECL799lub7M/Pz4/vv/+exYsX22R/zmbbtm38/e9/p7i4GA8P6y+59/zzz3P06FE6dOhg9X3ZkhTyKmjevDmdO3eumI/D2urUqcPUqVNRSlntraazunTpEpcuXaKk5PeTXVlLjx498PX1paSkhDNnzthsv87g66+/ZsmSJRQWFtpkfyaTidDQUAA2b95ss/1aXWWn6db+cLSuFaMcPXpUN2rUSK9atcroKA6lpKTEkP1OnjxZh4WFWXTEhSu4ckoEWzlw4IAG9FtvvWXzfdcE0rVSfXPmzGHJkiWG7b9FixbceuuttGzZ0rAMjiIzM5PZs2dTUFCAm5sx84E/+eSTzJ0716IjLpzVli1bKi4Q16tXz+b779SpE6tWreKpp56y+b6tQVYIuobi4mKGDh1Khw4d+PDDD42OI25gyZIlTJs2jaioKHr0+N10zTantZa7da+htLSUVq1a0bJlSzZu3Gh0HIqLizGbzRVT49qza81HLmfk1+Dh4cHPP//Mu+++a3QUCgoKmDVrFt98843RUezWgw8+yPHjx+2iiK9bt46+ffuSn59vdBS75ObmxqZNm5g/f77RUcjNzaVnz5689tprRkepESnkldi6dSs5OTmYTCa8vb2NjoPJZGLt2rVs377d6Ch2p6SkhPj4eKCsK8oe1KlTB5PJxKVLl4yOYndyc3OBsgEE7dq1MzhN2Y1Hw4cPp3v37kZHqRHpWrlKVlYWoaGh3HvvvXzyySdGx6mQk5ODr6+sxH61//znP8yaNYu4uDhat25tdJwK0rXye8XFxfTo0YORI0c69V2W1mTVpd6cSZ06dfjuu+9o2LCh0VF+43IRP3v2LEVFRbRp08bgRPZh3LhxFBYW0qpVK6Oj/MbloaMff/wxTz31lBR1yvrGR40aRZ8+fYyO8jtms5nFixfj6+vLhAkTjI5TbXJGfoXS0lLDRjxURUlJCS1btqRjx47SX+4APv/8c6ZMmcL27dvp37+/0XHEdZjNZm655RYaNWrEqlWrjI5zTXKx8wZKSkro3bs38+bNMzrKNbm7u7No0SIZRUPZHYGTJk0iNTXV6CjXNGnSJPbs2SNFHHjzzTftev4gk8nE+vXrWblypdFRbop0rZTLzc2lXbt2hISEGB3luoYPH17x2JX7YY8dO8bu3butMiGWpZhMpoqJtXJzc112fHlmZibvvPMOqamp9OzZ0+g411S/fn2g7DpZbm4ujRo1MjhR1UnXigMqKipi2rRpdOnShZdfftnoOIax1fwcNbVq1SqmT5/O3r17adq0qdFxDJGdnY1Syu4v2JeUlNC+fXs6duzI2rVrjY7zO9K1ch2ff/45CQkJRseoMk9PT+ebhrOKsrKy2LVrF4BDFHGAXr16MXr0aDw9PY2OYnPnzp1Da42fn5/dF3Eo676cPXs2s2bNMjpKtbj8GXlGRgahoaFMmTLFodb3c9VulTlz5jB79mxOnjxJ8+bNjY4jriM/P5+2bdsycuRIFixYYHQcpyDDD6/B39+fw4cP23Vfa2UuF/GoqCj8/f3t4uYKW3juuefo0KGDQxbxs2fP8sknn/DKK6+4xB9hDw8PXnnlFdq2bWt0lGorKirilVdeoUOHDkyePNnoODfk0l0rBQUFQNnKPzVdRNkIeXl5jBo1ijlz5hgdxWb8/Py47777jI5xUzZu3Mgbb7zBkSNHjI5iE+7u7jzyyCMMGDDA6CjV5uHhwdatW4mLizM6SpW4bCE3m80MGjSIP/7xj0ZHuWk+Pj6sX7/eJYYj7t27l1tuuYVTp04ZHeWmPfTQQ5w8edLpFjWozNy5c+16PPaNKKXYtGkTb7/9ttFRqsQihVwpdbtS6phS6qRSyiGGUZSUlDBixAi7mGSpJvr164efnx9aa8xms9FxrCYxMZGMjAwCAgKMjnLT3NzcaNKkCYBdj3+vqZKSEr788kt++ukno6PUyOXZEOPj40lJSTE4zQ1UNkl5dT4AN+AU0ALwBOKADtf7GllYwrJSUlJ037599ccff2x0FKsym81GR7CIuXPn6sDAQJ2enm50FKspKSnR2dnZRseosfT0dO3r66tnzpxpdBSt9bUXlrDExc5ewEmt9WkApdQy4G7gsAXatopVq1YREhJil3M+3IyAgACCg4Px8fExOorFlZaW8u233zJq1CinuUB42223kZeXh7u78401OHfuHEFBQXh7ezvEcMMb8ff358MPP+SWW24xOsp11Xj4oVLqPuB2rfWj5c8nA7211tdcesPI4Ydms5kuXbrQpEkTvv/+e0MyiKpbsWIF999/P9999x233Xab0XHEdWitGTBgAFprduzY4TR/eO2J4TcEKaWmK6VilFIxRvY3mUwmoqKi+OijjwzLYC1aa1asWOFU82CPHTuW1atXM2LECKOjWNwvv/zCm2++aXQMi1FKMXv2bF566SWnK+IpKSlMnDiRbdu2GR2lUpYo5BeA0Cueh5S/9hta64Va6x5a6x5BQUEW2G315ebmorXG19fX7udUuRknT55k4sSJLFy40OgoFqG1xs3NjXvvvdfpCgPAmjVrePfdd8nOzjY6isXceuut3H333UbHsLjatWsTGxvL8ePHjY5SKUt0rbgDx4FhlBXw3cADWutD1/oao7pWpkyZwvnz59m4cSMmk3OOvNy5cye9e/e26+l4qyIlJYXhw4fz7rvvMmjQIKPjWEV2djYmk8kpJtP65JNPSEpK4k9/+pPD/+xdS0lJieHXNazWtaK1LgGeAr4HjgArrlfEjTRkyBDuuOMOpy3iUDYc0c3NjZKSEqOj1EhycjLu7u4EBwcbHcVq/Pz8qF27NlprkpKSjI5TI9u2bePbb7916t+ty0U8OjqaoqIig9P8lsvPteKMDhw4wOjRo4mMjKRfv35Gx7lp2kXmk3nggQc4ePAge/fudeizWVeYqnffvn1069aN+fPn8+STT9p8/y4918rGjRtJTU1l/PjxLlEYWrRoQfv27R22KKxcuZK77rrLLha+toVJkyaRnJzskD+biYmJmEwmGjRo4PRFHKBr1658/PHHdjdNhEuckY8fP579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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def random_layer_params(m, n, key):\n",
    "    # Initialize with variance inversely proportional to input dimensionality\n",
    "    variance = 1 / n\n",
    "    w_key, b_key = random.split(key)\n",
    "    return jnp.sqrt(variance) * random.normal(w_key, (n, m)), jnp.sqrt(variance) * random.normal(b_key, (n,))\n",
    "\n",
    "def init_network_params(sizes, key):\n",
    "    # Initialize all layers for a fully-connected neural network with sizes \"sizes\"\n",
    "    keys = random.split(key, len(sizes))\n",
    "    return [random_layer_params(m, n, k) for m, n, k in zip(sizes[:-1], sizes[1:], keys)]\n",
    "\n",
    "def relu(x):\n",
    "    return jnp.maximum(0, x)\n",
    "\n",
    "def predict(input_sample, params):\n",
    "    activations = input_sample\n",
    "    for w, b in params[:-1]:\n",
    "        outputs = jnp.dot(w, activations) + b\n",
    "        activations = relu(outputs)\n",
    "\n",
    "    final_w, final_b = params[-1]\n",
    "    prediction = jnp.dot(final_w, activations) + final_b\n",
    "    \n",
    "    # Assumes targets and predictions are scalars, so that we mean over a batch.\n",
    "    return prediction.reshape((1,))\n",
    "batched_predict = vmap(predict, in_axes=(0, None))\n",
    "\n",
    "def target_without_noise(input_sample):\n",
    "    return jnp.cos(jnp.pi * jnp.linalg.norm(input_sample)).reshape((1,))\n",
    "batched_target_without_noise = vmap(target_without_noise, in_axes=(0))\n",
    "\n",
    "def target(input_sample, variance, key):\n",
    "    without_noise = target_without_noise(input_sample)\n",
    "    noise = jnp.sqrt(variance) * random.normal(key, without_noise.shape)\n",
    "    observation = without_noise + noise\n",
    "    \n",
    "    # Assumes targets and predictions are scalars, so that we mean over a batch.\n",
    "    return observation.reshape((1,))\n",
    "batched_target = vmap(target, in_axes=(0, None, 0))\n",
    "\n",
    "def update(weights, velocity, grads, step_size, momentum):\n",
    "    new_weights = []\n",
    "    new_velocity = []\n",
    "    for (w, b), (vw, vb), (dw, db) in zip(weights, velocity, grads):\n",
    "        new_vw = momentum * vw - step_size * dw\n",
    "        new_vb = momentum * vb - step_size * db\n",
    "        new_velocity.append((new_vw, new_vb))\n",
    "        new_weights.append((w + new_vw, b + new_vb))\n",
    "    return (new_weights, new_velocity)\n",
    "\n",
    "def sample_stationary(instantaneous_domain_variance, mean_switching_variance, size, input_dimensions, subkey):\n",
    "    # Samples the stationary distribution, and the variance is simply the sum v_i + v_m, since\n",
    "    # it is tantamount to adding two random variables distributed as N(0, v_i), N(0, v_d).\n",
    "    return jnp.sqrt(instantaneous_domain_variance + mean_switching_variance) * random.normal(subkey, (size, input_dimensions))\n",
    "\n",
    "@partial(jit, static_argnums=(2, 3))\n",
    "def train_step(\n",
    "    input_mean,\n",
    "    input_variance,\n",
    "    batch_size,\n",
    "    input_dimensions,\n",
    "    observation_noise_variance,\n",
    "    step_size,\n",
    "    momentum,\n",
    "    weights,\n",
    "    velocity,\n",
    "    key,\n",
    "):\n",
    "    key, subkey = random.split(key)\n",
    "    # NN_SPEC: No concatenation with 1, because weights and biases separate here\n",
    "    input_batch = input_mean + jnp.sqrt(input_variance) * random.normal(subkey, (batch_size, input_dimensions))\n",
    "    \n",
    "    key, *subkeys = random.split(key, batch_size + 1)\n",
    "    targets = batched_target(input_batch, observation_noise_variance, jnp.array(subkeys))\n",
    "\n",
    "    # NN_SPEC: specific (batched) predictor\n",
    "    loss, grads = value_and_grad(helpers.mse_loss, argnums=1)(input_batch, weights, targets, batched_predict)\n",
    "    \n",
    "    new_weights, new_velocity = update(weights, velocity, grads, step_size, momentum)\n",
    "    \n",
    "    return loss, new_weights, new_velocity\n",
    "\n",
    "rand_key = random.PRNGKey(run_id)\n",
    "\n",
    "layer_sizes = [input_dimensions] + [nn_width] * nn_layers + [1]\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "weights = init_network_params(layer_sizes, subkey)\n",
    "velocity = [(jnp.zeros_like(w), jnp.zeros_like(b)) for w, b in weights]\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "test_set_inputs = sample_stationary(\n",
    "    instantaneous_domain_variance, \n",
    "    mean_switching_variance, \n",
    "    test_set_size, \n",
    "    input_dimensions, \n",
    "    subkey,\n",
    ")\n",
    "test_set_targets = batched_target_without_noise(test_set_inputs)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "means = helpers.stochastic_vector_mean_sequence(\n",
    "    input_dimensions,\n",
    "    mean_switching_interval, \n",
    "    mean_switching_variance, \n",
    "    iterations, \n",
    "    subkey\n",
    ")\n",
    "\n",
    "plot_sample(weights, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "c9de98bc-8a8e-4cb8-8864-9a040c8d6b0d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "576fa07ad6674d449ccbd879312ec336",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "losses = []\n",
    "steps = []\n",
    "for step, mean in enumerate(tqdm(means)):\n",
    "    rand_key, subkey = random.split(rand_key)\n",
    "\n",
    "    loss, weights, velocity = train_step(\n",
    "        mean,\n",
    "        instantaneous_domain_variance,\n",
    "        batch_size, \n",
    "        input_dimensions, \n",
    "        observation_noise_variance, \n",
    "        step_size,\n",
    "        momentum,\n",
    "        weights,\n",
    "        velocity, \n",
    "        rand_key,\n",
    "    )\n",
    "    if step % 50 == 0:\n",
    "        test_loss = helpers.mse_loss(test_set_inputs, weights, test_set_targets, batched_predict)\n",
    "        losses.append(test_loss)\n",
    "        steps.append(step)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "4c4aba2e-97a5-4aae-9975-f6130f0c8e5b",
   "metadata": {},
   "outputs": [
    {
     "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": [
    "plot_sample(weights, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "eef29b3e-95d6-4bc3-bb4f-1900b24cae64",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f443025c0f0>]"
      ]
     },
     "execution_count": 83,
     "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, losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "efa59f5e-9f54-43ca-8287-835b5fac5dd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "if run_id != 0:\n",
    "    data_storage.write_losses_no_distances(run_id, steps, losses, database, user, password, host)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0e59522d-e8f7-401a-bab7-74372f9e85f0",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
