{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "819eb911",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:06.024796Z",
     "start_time": "2022-05-19T18:11:05.250770Z"
    }
   },
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "\n",
    "%load_ext jupyternotify\n",
    "%notify_shell_initialize\n",
    "%notify_shell_backend [\"{HOME}/.local/bin/ntfy\",\"send\",\"Jupyter notify:\\n{body}\"]\n",
    "%autonotify -a 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "74d49618",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:06.037957Z",
     "start_time": "2022-05-19T18:11:06.026382Z"
    }
   },
   "outputs": [],
   "source": [
    "from IPython.display import display\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.rc('text', usetex=False)\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{physics}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "07365e69",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:06.060222Z",
     "start_time": "2022-05-19T18:11:06.039325Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "env: CUDA_VISIBLE_DEVICES=0\n"
     ]
    }
   ],
   "source": [
    "%env CUDA_VISIBLE_DEVICES=0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "47f2b2f2",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:06.606030Z",
     "start_time": "2022-05-19T18:11:06.062843Z"
    }
   },
   "outputs": [],
   "source": [
    "import jax\n",
    "from jax import jit, pmap, vmap, grad, vjp, jvp\n",
    "import jax.numpy as np\n",
    "import numpy as onp\n",
    "import jax.nn as nn\n",
    "from jax import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3b8daac2",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:06.622302Z",
     "start_time": "2022-05-19T18:11:06.607626Z"
    }
   },
   "outputs": [],
   "source": [
    "from jax.config import config\n",
    "config.update('jax_enable_x64', True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4465ff50",
   "metadata": {},
   "source": [
    "# Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "80c73176",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:07.430292Z",
     "start_time": "2022-05-19T18:11:06.623684Z"
    }
   },
   "outputs": [],
   "source": [
    "SEED = 42\n",
    "input_shape = (2, )\n",
    "Ndata = 20\n",
    "complexity = 3\n",
    "\n",
    "key = jax.random.PRNGKey(SEED)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "8083a81b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:08.478661Z",
     "start_time": "2022-05-19T18:11:07.432916Z"
    }
   },
   "outputs": [],
   "source": [
    "key, subkey = random.split(key)\n",
    "#thetas = np.arange(0, Ndata) / Ndata * (2 * onp.pi)\n",
    "thetas = np.arange(0, Ndata) / Ndata * (onp.pi)\n",
    "inputs = np.swapaxes(np.stack([np.cos(thetas), np.sin(thetas)]), 0, 1)\n",
    "targets = np.sin(complexity*thetas)/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e6d555b0",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:09.169243Z",
     "start_time": "2022-05-19T18:11:08.481074Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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nj59GgMDAzCZTMyxNpsN99xzD4qKikIEn2csypVcrVbj61//Ovr7+5GZmYl9+/ZBLpc7iG66u7txzTXXAJhZUW688caQ6IYFdk/8mTNnsGHDBlxzzTXYsGGDy9bWkZERDA8PzxqlxLar1mg0OH78OAYGBpCVlYXHH388RHDPCIlhQggszGYzPv74Yxw4cABffvkl1q1bh127dmHjxo1MKD46OorBwUGUlZW57W9XKBTYs2cPGhoasGzZMtxxxx247bbbgvWrLFaEwvVgw5P+maZpfO9730NeXh5KS0tx5syZebhK/yEsLAyXX345/v73v6O2thbf/OY3ceTIEVx00UW4++678fOf/xy//vWvPRLcbrfjt7/9LTIyMtDZ2YlDhw6hrKxsztfn6fPYu3cvSktLUVpaig0bNqCurm7O77mkQNO0u3/nHaxWK52bm0t3dXXRJpOJLi0tpZuamhyOOXz4MH355ZfTdrud/vLLL+m1a9fO09UGFlarlf7f//1fOj09nS4rK6N3795Nv/rqq7RSqaT1er3DP51OR//3f/83feedd9I2m82v1+Dp8/jiiy/o8fFxmqZp+siRI4vx8/DEwzn9C63kTqiurkZeXh5yc3MRFhaG3bt34+DBgw7HHDx4ELfccgsoisL69euh1WoxMjIyT1ccONA0je7ubjQ2NuL06dPYs2cPTp48iUsuuQS33HIL3njjDUxNTYGmafzyl7/E+Pg4nn32Wb8aUvL5PDZs2MDImtevX4/BwUG/vf9SwIKtk88X+OqfuTy7g+2nFmiIRCIH1xt2T3xNTQ327duH3/3udzCbzVi5ciX279/vd7mot05Czz//PK644gq/XsNiR4jkTqB56J/5HLOUIRAIUFFRgYqKCjz++OM4dOgQtm7dGhA9uDd/608++QTPP/88Pv/8c79fx2JGiORO4OvHfb6527iCQCAIqOkH3791fX097rjjDrz77rtLYV65f+Fh037ewWKx0Dk5OXR3dzeT6GlsbHQ45tChQw6Jt6qqqnm62qUPPp9HX18fvXz5cvqLL76Yp6ucMwKaeAut5E7go3/evn07jhw5gry8PERGRuKFF16Y56teuuDzefziF7+AWq3Gd7/7XeY1i7W1OBAIiWFCCGH+ERLDLGV4EnocPXoUUqkUZWVlKCsrwy9+8Yt5uMoQFjNC4fo8wmaz4d5773UwHtyxY8cs48GNGzfi0KFD83SVISx2hFbyeQQfoUcIIcwVIZLPI1yJapzx5ZdfYvXq1bjiiivQ1NQUzEsMYQkgRPJ5BFfS01noUV5ejr6+PtTV1eH+++9fEl5k51sD0HwjRPJ5BB+hR2xsLGO7vH37dmZwwmIFyUO8++67aG5uxquvvorm5maHY9599110dHSgo6MDf/vb33DPPffM09UuDYRIPo/gMzJqdHSUWfGrq6tht9sXtaIr1AAUfISy6/MIPkKP/fv349lnn4VIJEJERARee+21Ra2TDzUABR8hks8ztm/fju3btzt8j+0qet999+G+++4L9mUFDHzyEHyOCYE/PCneQlhCoCjqnwCuAqCgaXqWqyU1w6RnAGwHYABwK03Tfs16URR1AYBHaZq+7OzXjwAATdNPsI75K4CjNE2/evbrNgBbaJoOxew+ILQnP7/wIoDL3fz8CgArzv77DoC5zRHmxkkAKyiKyqEoKgzAbgBvOx3zNoBbqBmsBzARIrjvCIXr5xFomj5GUVS2m0N2AniZngnvvqIoSkZRVIo/CUbTtJWiqPsAvA9ACOCfNE03URR199mfPwfgCGaiiU7MRBSBmat0niBE8hDYSAMwwPp68Oz3/LqK0jR9BDNEZn/vOdb/0wDu9ed7ns8IheshsMGV3QolbRY5QiQPgY1BABmsr9MBDM/TtYTgJ4RIHgIboYTXEkRoT34egaKoVwFsAZBAUdQggJ8DEAOhhNdSRqhOHkIISxyhcD2EEJY4QiQPIYQljhDJQwhhiSNE8hBCWOIIkTyEEJY4QiQPIYQljhDJQwhhiSNE8hBCWOL4/yJx6AguG6jLAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(111, projection='3d')\n",
    "ax.plot3D(inputs[:,0], inputs[:,1], targets)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "34624ab5",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:09.355728Z",
     "start_time": "2022-05-19T18:11:09.171025Z"
    }
   },
   "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": [
    "plt.plot(thetas, targets)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "47857610",
   "metadata": {},
   "source": [
    "# Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3c17548a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:09.374577Z",
     "start_time": "2022-05-19T18:11:09.357417Z"
    }
   },
   "outputs": [],
   "source": [
    "import fcnet\n",
    "from fcnet import get_network, huber_loss, square_loss\n",
    "\n",
    "d=4\n",
    "hidden =2048"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "330038a6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:09.402468Z",
     "start_time": "2022-05-19T18:11:09.375971Z"
    }
   },
   "outputs": [],
   "source": [
    "net = get_network(d,hidden,activation=\"tanh\")\n",
    "#net_large = get_network(d,hidden_large)\n",
    "\n",
    "pred = lambda net, params, inputs: net.apply(params, inputs)[:, 0]\n",
    "ls_fun = (lambda pred, target: square_loss(pred, target))\n",
    "loss_vec = (lambda net, params, batch: ls_fun(pred(net, params, batch[0]), batch[1]))\n",
    "loss_mean = (lambda net, params, batch: loss_vec(net, params, batch).mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "28017a0c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:12.327522Z",
     "start_time": "2022-05-19T18:11:09.404181Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAEICAYAAABRSj9aAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAVxklEQVR4nO3df5BdZ33f8fcnwgqDoVDQYhvbskyjyWA6mDI7wsRMsAdwZQOj0kmpNIRfgdE4xWmTEjoKAQNJpw0hk8kABo2GKgZS7DQFg5rIvwIlpqFOLTM2tgETRQi8lYNkOzUYKEb02z/uEbms7+49q72r9X38fs3c2XOf5znPeR4f+bPnnj33nFQVkqR2/dRqD0CStLIMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn00ghJKsnPdMs7k7xjQv2uT/JQkjXd+88ledMk+u76uzbJ6ybVn9pg0Gvikrw+yR1Jvpfkb5N8KMlTlrD+wSQvmeB4ltVfVV1aVb89ie1U1Ter6olV9aPjHc/Q9t6V5I/m9X9xVX1kuX2rLQa9JirJW4D3AG8FngycB5wF3Jhk7WqObbUledxqj0GPTQa9JibJPwDeDfxKVV1XVT+sqoPAqxiE/S927a5M8u+H1rsgyVy3/DFgPfDfulMc/y7Jhu5UyvYkh5Lc2/1C4Xj6W2Dsb+36PZTkl+bV/bj/JOuS/GmS/5PkgSSfT/JTY8b9xiTfBD47VDYc+v8oyf9K8mCSTyd56vx5DI3lYJKXJNkMvA34l932bu/qf3wqqBvX25N8I8nhJB9N8uSu7tg4Xpfkm0nuS/Kb4/eyppFBr0n6OeDxwCeHC6vqIeBa4KXjOqiq1wDfBF7RneL43aHqC4GNwEXAjj6nY8b0B0AXmr/ejW8jsFi/bwHmgBngFAZhW2O28yLgWcA/XaDP1wK/BDwDOAq8r8e8rgP+A/DH3fbOHdHs9d3rQuCZwBOBD8xr80LgZ4EXA5cneda4bWv6GPSapHXAfVV1dETdvV39cry7qr5bVXcAfwhsW2Z/x7wK+MOqurOqvgu8a5G2PwROA87qPrF8vsbfMOpd3bi/v0D9x4a2/Q7gVcf+WLtMrwZ+v6oOdL9sfwPYOu/TxLur6vtVdTtwOzDqF4amnEGvSboPWLfAuejTuvrluGdo+RsMjoAn4Rkj+l7Ie4H9wA1JDiTZ0aP/e5ZQ/w3gJJb/SxEG8xqeyzeAxzH4JHLM3w4tf4/BUb8aY9Brkv4n8APgnw8XJjkZuBj4TFf0XeAJQ01OndfPQkfIZw4trwcOLbO/Y+4d0fdIVfWdqnpLVT0TeAXwb5O8eMx2xm1//rZ/yOCX4k/MqzvKn1lCv4cY/G1kuO+jwLfGrKfGGPSamKp6kMEfY9+fZHOSk5JsAP6EwXntj3VNbwMuSfLUJKcCvzqvq28xOKc83zuSPCHJs4E3AH+8zP6O+S/A65Ock+QJwDsXapjk5Ul+JkmAbwM/6l59trOQXxza9m8B/7W7/PJrwOOTvCzJScDbgZ+eN68NSRb6//gq4NeSnJ3kifz9Of1Rp9bUMINeE9X9EfJtwO8xCMK/YnBq4sVV9YOu2ccYnA8+CNzA3wf2Mf8ReHt3ZcuvD5X/BYPTJp8Bfq+qblhmf8fGfC3wB8Bnu/4/u8gUNwJ/DjzE4BPMB6vqc322s4iPAVcyOI3yeOBfd+N6EPhXwIeB/83gCH/4Kpw/6X7en+SLI/rd3fV9E/B14P8Cv7KEcakR8cEjerTrPhV8HTjJo1Fp6Tyil6TGGfSS1DhP3UhS4zyil6TGPSpvsrRu3brasGHDag9DkqbGrbfeel9VzYyqe1QG/YYNG9i3b99qD0OSpkaSBb/R7akbSWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1LixQZ/kzCT/PclXktyV5N+MaJMk70uyP8mXkjxvqG5zkru7uj4PaZAkTVCfI/qjwFuq6lnAecCbk5wzr83FDG7fuhHYDnwIfvyghCu6+nOAbSPWlSStoLFBX1X3VtUXu+XvAF8BTp/XbAvw0Rq4GXhKktOATcD+7pmVDwNXd20lSSfIkr4Z290X/J8weJjEsNP5yedeznVlo8qfv0Df2xl8GmD9+gWf5DbWhh1/NrL84O+87Lj7lKRp1vuPsd2jyD4B/GpVfXt+9YhVapHyRxZW7aqq2aqanZkZebsGSdJx6HVE3z2v8hPAf66qT45oMsdPPuD4DAYPJl67QLkk6QTpc9VNgP8EfKWqfn+BZnuA13ZX35wHPFhV9wK3ABu7hxOvBbZ2bSVJJ0ifI/rzgdcAdyS5rSt7G7AeoKp2AnuBSxg8WPl7wBu6uqNJLgOuB9YAu6vqrklOQJK0uLFBX1X/g9Hn2ofbFPDmBer2MvhFIElaBX4zVpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUuLEPHkmyG3g5cLiq/vGI+rcCrx7q71nATFU9kOQg8B3gR8DRqpqd1MAlSf30OaK/Eti8UGVVvbeqnltVzwV+A/iLqnpgqMmFXb0hL0mrYGzQV9VNwAPj2nW2AVcta0SSpIma2Dn6JE9gcOT/iaHiAm5IcmuS7ZPaliSpv7Hn6JfgFcBfzjttc35VHUrydODGJF/tPiE8QveLYDvA+vXrJzgsSXpsm+RVN1uZd9qmqg51Pw8D1wCbFlq5qnZV1WxVzc7MzExwWJL02DaRoE/yZOBFwKeHyk5O8qRjy8BFwJ2T2J4kqb8+l1deBVwArEsyB7wTOAmgqnZ2zV4J3FBV3x1a9RTgmiTHtvPxqrpuckOXJPUxNuiraluPNlcyuAxzuOwAcO7xDkySNBl+M1aSGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaNzbok+xOcjjJyOe9JrkgyYNJbutelw/VbU5yd5L9SXZMcuCSpH76HNFfCWwe0+bzVfXc7vVbAEnWAFcAFwPnANuSnLOcwUqSlm5s0FfVTcADx9H3JmB/VR2oqoeBq4Etx9GPJGkZJnWO/gVJbk9ybZJnd2WnA/cMtZnrykZKsj3JviT7jhw5MqFhSZImEfRfBM6qqnOB9wOf6sozom0t1ElV7aqq2aqanZmZmcCwJEkwgaCvqm9X1UPd8l7gpCTrGBzBnznU9Azg0HK3J0lammUHfZJTk6Rb3tT1eT9wC7AxydlJ1gJbgT3L3Z4kaWkeN65BkquAC4B1SeaAdwInAVTVTuAXgF9OchT4PrC1qgo4muQy4HpgDbC7qu5akVlIkhY0NuiratuY+g8AH1igbi+w9/iGJkmaBL8ZK0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0bG/RJdic5nOTOBepfneRL3esLSc4dqjuY5I4ktyXZN8mBS5L66XNEfyWweZH6rwMvqqrnAL8N7JpXf2FVPbeqZo9viJKk5ejzzNibkmxYpP4LQ29vBs6YwLgkSRMy6XP0bwSuHXpfwA1Jbk2yfbEVk2xPsi/JviNHjkx4WJL02DX2iL6vJBcyCPoXDhWfX1WHkjwduDHJV6vqplHrV9UuutM+s7OzNalxSdJj3USO6JM8B/gwsKWq7j9WXlWHup+HgWuATZPYniSpv2UHfZL1wCeB11TV14bKT07ypGPLwEXAyCt3JEkrZ+ypmyRXARcA65LMAe8ETgKoqp3A5cDTgA8mATjaXWFzCnBNV/Y44ONVdd0KzEGStIg+V91sG1P/JuBNI8oPAOc+cg1J0onkN2MlqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcWODPsnuJIeTjHzeawbel2R/ki8led5Q3eYkd3d1OyY5cElSP32O6K8ENi9SfzGwsXttBz4EkGQNcEVXfw6wLck5yxmsJGnpxgZ9Vd0EPLBIky3AR2vgZuApSU4DNgH7q+pAVT0MXN21lSSdQGMfDt7D6cA9Q+/nurJR5c9fqJMk2xl8ImD9+vUTGNbK2LDjz0aWH/ydl53gkWg1rNb+PxHbnfZ/2wuNHyY3h0n9NzrR/60n8cfYjCirRcpHqqpdVTVbVbMzMzMTGJYkCSZzRD8HnDn0/gzgELB2gXJJ0gk0iSP6PcBru6tvzgMerKp7gVuAjUnOTrIW2Nq1lSSdQGOP6JNcBVwArEsyB7wTOAmgqnYCe4FLgP3A94A3dHVHk1wGXA+sAXZX1V0rMAdJ0iLGBn1VbRtTX8CbF6jby+AXgSRplfjNWElqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWpcr6BPsjnJ3Un2J9kxov6tSW7rXncm+VGSp3Z1B5Pc0dXtm/QEJEmL6/PM2DXAFcBLgTngliR7qurLx9pU1XuB93btXwH8WlU9MNTNhVV130RHLknqpc8R/SZgf1UdqKqHgauBLYu03wZcNYnBSZKWr0/Qnw7cM/R+rit7hCRPADYDnxgqLuCGJLcm2b7QRpJsT7Ivyb4jR470GJYkqY8+QZ8RZbVA21cAfznvtM35VfU84GLgzUl+ftSKVbWrqmaranZmZqbHsCRJffQJ+jngzKH3ZwCHFmi7lXmnbarqUPfzMHANg1NBkqQTpE/Q3wJsTHJ2krUMwnzP/EZJngy8CPj0UNnJSZ50bBm4CLhzEgOXJPUz9qqbqjqa5DLgemANsLuq7kpyaVe/s2v6SuCGqvru0OqnANckObatj1fVdZOcgCRpcWODHqCq9gJ755XtnPf+SuDKeWUHgHOXNUJJ0rL4zVhJapxBL0mNM+glqXEGvSQ1zqCXpMYZ9JLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqXK+gT7I5yd1J9ifZMaL+giQPJrmte13ed11J0soa+yjBJGuAK4CXAnPALUn2VNWX5zX9fFW9/DjXlSStkD5H9JuA/VV1oKoeBq4GtvTsfznrSpImoE/Qnw7cM/R+riub7wVJbk9ybZJnL3FdkmxPsi/JviNHjvQYliSpjz5BnxFlNe/9F4Gzqupc4P3Ap5aw7qCwaldVzVbV7MzMTI9hSZL66BP0c8CZQ+/PAA4NN6iqb1fVQ93yXuCkJOv6rCtJWll9gv4WYGOSs5OsBbYCe4YbJDk1SbrlTV2/9/dZV5K0ssZedVNVR5NcBlwPrAF2V9VdSS7t6ncCvwD8cpKjwPeBrVVVwMh1V2gukqQRxgY9/Ph0zN55ZTuHlj8AfKDvupKkE8dvxkpS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktQ4g16SGmfQS1LjegV9ks1J7k6yP8mOEfWvTvKl7vWFJOcO1R1MckeS25Lsm+TgJUnjjX2UYJI1wBXAS4E54JYke6rqy0PNvg68qKr+LsnFwC7g+UP1F1bVfRMctySppz5H9JuA/VV1oKoeBq4Gtgw3qKovVNXfdW9vBs6Y7DAlScerT9CfDtwz9H6uK1vIG4Frh94XcEOSW5NsX2ilJNuT7Euy78iRIz2GJUnqY+ypGyAjympkw+RCBkH/wqHi86vqUJKnAzcm+WpV3fSIDqt2MTjlw+zs7Mj+JUlL1+eIfg44c+j9GcCh+Y2SPAf4MLClqu4/Vl5Vh7qfh4FrGJwKkiSdIH2C/hZgY5Kzk6wFtgJ7hhskWQ98EnhNVX1tqPzkJE86tgxcBNw5qcFLksYbe+qmqo4muQy4HlgD7K6qu5Jc2tXvBC4HngZ8MAnA0aqaBU4BrunKHgd8vKquW5GZSJJG6nOOnqraC+ydV7ZzaPlNwJtGrHcAOHd+uSTpxPGbsZLUOINekhpn0EtS4wx6SWqcQS9JjTPoJalxBr0kNc6gl6TGGfSS1DiDXpIaZ9BLUuMMeklqnEEvSY0z6CWpcQa9JDXOoJekxhn0ktS4XkGfZHOSu5PsT7JjRH2SvK+r/1KS5/VdV5K0ssYGfZI1wBXAxcA5wLYk58xrdjGwsXttBz60hHUlSSuozxH9JmB/VR2oqoeBq4Et89psAT5aAzcDT0lyWs91JUkrqM/DwU8H7hl6Pwc8v0eb03uuC0CS7Qw+DQA8lOTuHmM7Zh1w32IN8p4l9HYcVrj/sfObclM/vzH7f8Xmt9L/rpewjUf1PpzAf6dF5zep/bDMfs5aqKJP0GdEWfVs02fdQWHVLmBXj/E8QpJ9VTV7POtOA+c33VqfH7Q/x2mfX5+gnwPOHHp/BnCoZ5u1PdaVJK2gPufobwE2Jjk7yVpgK7BnXps9wGu7q2/OAx6sqnt7ritJWkFjj+ir6miSy4DrgTXA7qq6K8mlXf1OYC9wCbAf+B7whsXWXYF5HNcpnyni/KZb6/OD9uc41fNL1chT5pKkRvjNWElqnEEvSY2byqBP8i+S3JXk/yVZ8JKnJAeT3JHktiT7TuQYl2MJ85vK20skeWqSG5P8dffzHy7Qbqr233JuFTINeszvgiQPdvvrtiSXr8Y4j1eS3UkOJ7lzgfrp3X9VNXUv4FnAzwKfA2YXaXcQWLfa412J+TH44/bfAM9kcBnr7cA5qz32nvP7XWBHt7wDeM+0778++4PBBQvXMvh+yXnAX632uCc8vwuAP13tsS5jjj8PPA+4c4H6qd1/U3lEX1VfqaqlfHN2qvSc3zTfXmIL8JFu+SPAP1u9oUzMcm4VMg2m+d9bL1V1E/DAIk2mdv9NZdAvQQE3JLm1u8VCSxa67cQ0OKUG37Og+/n0BdpN0/7rsz+meZ/1HfsLktye5Nokzz4xQzthpnb/9flm7KpI8ufAqSOqfrOqPt2zm/Or6lCSpwM3Jvlq91t71U1gfr1vL7EaFpvfErp51O6/EZZzq5Bp0GfsXwTOqqqHklwCfIrBHW1bMbX771Eb9FX1kgn0caj7eTjJNQw+fj4qgmIC8+tza4pVs9j8knwryWlVdW/30ffwAn08avffCMu5Vcg0GDv2qvr20PLeJB9Msq6qHrU3O1uiqd1/zZ66SXJykicdWwYuAkb+NX1KTfPtJfYAr+uWXwc84hPMFO6/5dwqZBqMnV+SU5OkW97EIF/uP+EjXTnTu/9W+6/Bx/MCXsngt+sPgG8B13flzwD2dsvPZHBlwO3AXQxOiaz62Cc1v+79JcDXGFwNMU3zexrwGeCvu59PbWH/jdofwKXApd1yGDyI52+AO1jkirFH46vH/C7r9tXtwM3Az632mJc4v6uAe4Efdv//vbGV/ectECSpcc2eupEkDRj0ktQ4g16SGmfQS1LjDHpJapxBL0mNM+glqXH/H74LoGKOhv8/AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "key, subkey = random.split(key)\n",
    "preds = vmap(lambda k: net.apply(net.init(k, input_shape)[1], inputs[0])[0])(\n",
    "    random.split(subkey, 9))\n",
    "plt.hist(onp.array(preds), bins=50)\n",
    "plt.title(\"Output distribution\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8347172d",
   "metadata": {},
   "source": [
    "# Fit Hessian"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a0d9f960",
   "metadata": {},
   "source": [
    "stochastic estimation as ground truth"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8bbce18f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:12.350486Z",
     "start_time": "2022-05-19T18:11:12.332308Z"
    }
   },
   "outputs": [],
   "source": [
    "from fcnet_analysis import Hutchinson_ests, get_sumi_Xi_avg, get_TrH"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "94493213",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:18.663713Z",
     "start_time": "2022-05-19T18:11:12.352249Z"
    }
   },
   "outputs": [],
   "source": [
    "sumi_Xi=get_sumi_Xi_avg(net, random.split(subkey,1000), inputs, loop=True, batch_size=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "409cb252",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:36.310913Z",
     "start_time": "2022-05-19T18:11:18.665786Z"
    },
    "scrolled": true
   },
   "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": [
    "key, subkey = random.split(key)\n",
    "nw_temp = net.init(subkey, input_shape)[1]\n",
    "tH = jit(Hutchinson_ests(net), static_argnames=(\"loop\", \"batch_size\"))\n",
    "H, H_std = tH(nw_temp,\n",
    "              inputs,\n",
    "              random.split(subkey, 1000),\n",
    "              loop=True,\n",
    "              batch_size=10)\n",
    "\n",
    "pred_H = get_TrH(net, nw_temp, inputs, sumi_Xi)\n",
    "plt.plot(thetas, pred_H, label=\"Approximation\")\n",
    "plt.fill_between(thetas,\n",
    "                 H - 3 * H_std,\n",
    "                 H + 3 * H_std,\n",
    "                 alpha=0.5,\n",
    "                 label=\"Hutchinson\")\n",
    "#plt.plot(thetas,H)\n",
    "plt.legend(loc=\"lower right\")\n",
    "#plt.ylabel(r\"$\\Tr(\\nabla_\\theta^2 y_d(\\theta(0), s(\\tau)))$\")\n",
    "plt.ylabel(r\"Hessian Trace\")\n",
    "plt.xlabel(r\"τ\")\n",
    "plt.show()\n",
    "del nw_temp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "5ac3800e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:11:36.330451Z",
     "start_time": "2022-05-19T18:11:36.312737Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/one_hessian_trace.npy', 'wb') as f:\n",
    "    np.save(f, H)\n",
    "    np.save(f, H_std)\n",
    "    np.save(f, pred_H)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "71db791f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:13:45.544151Z",
     "start_time": "2022-05-19T18:11:36.332194Z"
    }
   },
   "outputs": [],
   "source": [
    "key, subkey = random.split(key)\n",
    "\n",
    "from fcnet_analysis import vec_f\n",
    "f = lambda k: get_TrH(net, net.init(k, input_shape)[1], inputs, sumi_Xi)\n",
    "results = np.concatenate(vec_f(f, random.split(subkey, 10000), loop=True, batch_size=100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2736e147",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:11.859517Z",
     "start_time": "2022-05-19T18:13:45.546923Z"
    }
   },
   "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": [
    "plt.hist(onp.array(results),bins=100,density=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "148ebe7d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:11.885410Z",
     "start_time": "2022-05-19T18:14:11.862296Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/hessian_trace_hist.npy', 'wb') as f:\n",
    "    np.save(f, results)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "37bd8067",
   "metadata": {},
   "source": [
    "# Function space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b0b6c5fa",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:12.018986Z",
     "start_time": "2022-05-19T18:14:11.886864Z"
    }
   },
   "outputs": [],
   "source": [
    "key, subkey = random.split(key)\n",
    "nw_start = net.init(subkey, input_shape)[1]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bb14368d",
   "metadata": {},
   "source": [
    "Prepare parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "8c535391",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:12.035907Z",
     "start_time": "2022-05-19T18:14:12.020675Z"
    }
   },
   "outputs": [],
   "source": [
    "from fcnet_analysis import empirical_sumi_Phi_Xi_avg\n",
    "from fcnet_analysis import Yd_sY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "fd1ff61c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:34.060608Z",
     "start_time": "2022-05-19T18:14:12.037543Z"
    }
   },
   "outputs": [],
   "source": [
    "from fcnet_analysis import empirical_sumi_Theta_avg, empirical_Thetad_avg\n",
    "\n",
    "sumi_Theta = empirical_sumi_Theta_avg(net,\n",
    "                                      random.split(subkey, 100),\n",
    "                                      inputs,\n",
    "                                      loop=True,\n",
    "                                      batch_size=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "c910ade7",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:35.544824Z",
     "start_time": "2022-05-19T18:14:34.063654Z"
    }
   },
   "outputs": [],
   "source": [
    "Thetad = empirical_Thetad_avg(net,\n",
    "                              random.split(subkey, 100),\n",
    "                              inputs,\n",
    "                              loop=True,\n",
    "                              batch_size=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "1b264bb4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:45.809321Z",
     "start_time": "2022-05-19T18:14:35.546467Z"
    }
   },
   "outputs": [],
   "source": [
    "sumi_Xi=get_sumi_Xi_avg(net, random.split(subkey,100), inputs, loop=True, batch_size=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "44bd0133",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:14:48.646647Z",
     "start_time": "2022-05-19T18:14:45.810992Z"
    }
   },
   "outputs": [],
   "source": [
    "sumi_Phi_Xi = empirical_sumi_Phi_Xi_avg(net, random.split(subkey, 100),\n",
    "                                        sumi_Xi, inputs,loop=True,batch_size=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "c18d7db5",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:15.797766Z",
     "start_time": "2022-05-19T18:14:48.648574Z"
    }
   },
   "outputs": [],
   "source": [
    "Yd_start, sY_start = Yd_sY(net, nw_start, inputs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "3e512720",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:15.888877Z",
     "start_time": "2022-05-19T18:15:15.800878Z"
    }
   },
   "outputs": [],
   "source": [
    "TrH_start = get_TrH(net,nw_start,inputs,sumi_Xi)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "5abf5d3f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:15.907849Z",
     "start_time": "2022-05-19T18:15:15.890823Z"
    }
   },
   "outputs": [],
   "source": [
    "L_mean = lambda Yd: ls_fun(Yd,targets).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "682c8cda",
   "metadata": {},
   "source": [
    "Solve ODE in function space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "1c4d7f10",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:16.019774Z",
     "start_time": "2022-05-19T18:15:15.909768Z"
    }
   },
   "outputs": [],
   "source": [
    "from scipy.integrate import odeint\n",
    "\n",
    "allT_ode= np.linspace(0, 10, 10001)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "5f2737d8",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:17.744350Z",
     "start_time": "2022-05-19T18:15:16.022202Z"
    }
   },
   "outputs": [],
   "source": [
    "def kgd(Yd,t):\n",
    "    return -np.dot(Thetad,grad(L_mean)(Yd))\n",
    "sol = odeint(kgd, Yd_start, allT_ode)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "7edd44e6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:19.668350Z",
     "start_time": "2022-05-19T18:15:17.746129Z"
    }
   },
   "outputs": [],
   "source": [
    "from scipy.integrate import odeint\n",
    "\n",
    "\n",
    "def pack(Yd, sY, TrH, DeltaV, DeltaS):\n",
    "    return onp.concatenate([Yd, sY, TrH, onp.array([DeltaV, DeltaS])])\n",
    "\n",
    "\n",
    "def unpack(params):\n",
    "    Ndata = (params.shape[0] - 2) // 3\n",
    "    Yd = params[:Ndata]\n",
    "    sY = params[Ndata:2 * Ndata]\n",
    "    TrH = params[2 * Ndata:3 * Ndata]\n",
    "    DeltaV = params[-2]\n",
    "    DeltaS = params[-1]\n",
    "\n",
    "    return Yd, sY, TrH, DeltaV, DeltaS\n",
    "\n",
    "\n",
    "def extend_kgd(params, t):\n",
    "    Yd, sY, TrH, DeltaV, DeltaS = unpack(params)\n",
    "    # g = grad(L_mean)(Yd)\n",
    "    # LH = jax.hessian(L_mean)(Yd)\n",
    "    o = onp.ones_like(Yd)\n",
    "    g, dLH = jvp(lambda Yd: grad(L_mean)(Yd), (Yd, ), (o, ))\n",
    "    # print(LH.diagonal()-dLH)\n",
    "    return pack(\n",
    "        -onp.dot(Thetad, g),\n",
    "        -onp.dot(sumi_Theta, g),\n",
    "        -onp.dot(sumi_Phi_Xi, g),\n",
    "        -onp.dot(sY, g),\n",
    "        # -onp.trace(onp.dot(LH, Thetad)) - onp.dot(TrH, g),\n",
    "        -onp.dot(dLH, Thetad.diagonal()) - onp.dot(TrH, g),\n",
    "    )\n",
    "\n",
    "\n",
    "sol = odeint(extend_kgd, pack(Yd_start, sY_start, TrH_start, 0, 0), allT_ode)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "1829731f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:19.870087Z",
     "start_time": "2022-05-19T18:15:19.670344Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/kgd.npy', 'wb') as f:\n",
    "    np.save(f, allT_ode)\n",
    "    for e in vmap(unpack)(sol):\n",
    "        np.save(f, e)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "844c10c1",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:20.815522Z",
     "start_time": "2022-05-19T18:15:19.872130Z"
    }
   },
   "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": [
    "plt.plot(allT_ode, vmap(L_mean)(vmap(unpack)(sol)[0]))\n",
    "#plt.ylabel(r\"$\\frac{1}{m}\\sum_{a=1}^m l^s(y_d(s_a),t_a)$\")\n",
    "plt.xlabel(\"training time\")\n",
    "plt.ylabel(\"average training loss\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "42dffa66",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:21.207177Z",
     "start_time": "2022-05-19T18:15:20.817267Z"
    }
   },
   "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": [
    "fig, ax = plt.subplots()\n",
    "ax.plot(thetas, targets)\n",
    "for i in range(0,sol.shape[0],len(allT_ode)//6):\n",
    "    ax.plot(thetas,vmap(unpack)(sol)[0][i])\n",
    "#plt.ylabel(r\"$y_d(\\theta(t), s(\\tau)))$\")\n",
    "plt.ylabel(r\"Output\")\n",
    "plt.xlabel(r\"Input\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "111bd4ae",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:21.360903Z",
     "start_time": "2022-05-19T18:15:21.208923Z"
    }
   },
   "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": [
    "plt.plot(allT_ode, vmap(unpack)(sol)[-2])\n",
    "plt.xlabel(\"training time\")\n",
    "#plt.ylabel(\"$V(\\\\theta(t))-V(\\\\theta(0))$\")\n",
    "plt.ylabel(r\"Energy Change\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "bbc3878f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:21.589985Z",
     "start_time": "2022-05-19T18:15:21.362683Z"
    }
   },
   "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": [
    "i = 10\n",
    "plt.plot(allT_ode, vmap(unpack)(sol)[2][:,i])\n",
    "#plt.xlim((0,1))\n",
    "plt.xlabel(\"training time\")\n",
    "#plt.ylabel(\"$\\Tr(H_a(\\\\theta(t)))$\")\n",
    "plt.ylabel(r\"Hessian Trace\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "2516a096",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:21.899012Z",
     "start_time": "2022-05-19T18:15:21.591547Z"
    }
   },
   "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": [
    "fig, ax = plt.subplots()\n",
    "for i in range(0,sol.shape[0],len(allT_ode)//6):\n",
    "    ax.plot(thetas,vmap(unpack)(sol)[2][i])\n",
    "#plt.xlabel(r\"$\\tau$\")\n",
    "plt.ylabel(r\"Hessian Trace\")\n",
    "plt.xlabel(r\"Input\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d02544ac",
   "metadata": {},
   "source": [
    "# GD Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "47eaf729",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:21.915989Z",
     "start_time": "2022-05-19T18:15:21.900606Z"
    }
   },
   "outputs": [],
   "source": [
    "def split(a, n):\n",
    "    shape = a.shape\n",
    "    if shape[0] % n != 0:\n",
    "        raise ValueError(\"Cannot split evenly.\")\n",
    "    return a.reshape((-1, shape[0] // n, *shape[1:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "18dfd869",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:15:21.937253Z",
     "start_time": "2022-05-19T18:15:21.917706Z"
    }
   },
   "outputs": [],
   "source": [
    "step_size = 0.01\n",
    "num_epochs = 100*5//10\n",
    "split_num = Ndata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "f080d04e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:49.462843Z",
     "start_time": "2022-05-19T18:15:21.941369Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0 in 1.80 sec\n",
      "loss 0.15220148174623768\n",
      "Epoch 10 in 0.33 sec\n",
      "loss 0.03700368756218666\n",
      "Epoch 20 in 0.33 sec\n",
      "loss 0.014829848783772243\n",
      "Epoch 30 in 0.36 sec\n",
      "loss 0.007079824690073121\n",
      "Epoch 40 in 0.32 sec\n",
      "loss 0.004156867377968682\n",
      "Epoch 49 in 0.34 sec\n",
      "loss 0.0029802108535753003\n"
     ]
    }
   ],
   "source": [
    "import itertools\n",
    "from functools import partial\n",
    "import time\n",
    "\n",
    "from jax.example_libraries import optimizers\n",
    "\n",
    "opt_init, opt_update, get_params = optimizers.sgd(step_size)\n",
    "\n",
    "\n",
    "@jit\n",
    "def update(i, opt_state, batch):\n",
    "    params = get_params(opt_state)\n",
    "    return opt_update(i,\n",
    "                      grad(partial(loss_mean, net))(params, batch), opt_state)\n",
    "\n",
    "\n",
    "opt_state = opt_init(nw_start)\n",
    "itercount = itertools.count()\n",
    "\n",
    "# Trained with mean loss, step_size * iter_num\n",
    "allT = np.arange(num_epochs + 1) * split_num * step_size\n",
    "allloss = []\n",
    "allV = []\n",
    "allYd = []\n",
    "allsY = []\n",
    "#allddL = []\n",
    "#allThetad = []\n",
    "allH = []\n",
    "allH_std = []\n",
    "#allsGamma_Xi = []\n",
    "#allXi = []\n",
    "\n",
    "\n",
    "tH = jit(Hutchinson_ests(net), static_argnames=(\"loop\", \"batch_size\"))\n",
    "def record(nwt, key):\n",
    "    Yd, sY = Yd_sY(net, nwt, inputs)\n",
    "    allloss.append(ls_fun(Yd, targets))\n",
    "    allYd.append(Yd)\n",
    "    allsY.append(sY)\n",
    "    allV.append(-net.logp(nwt))\n",
    "    #allddL.append(\n",
    "    #    vmap(lambda y,t: grad(grad(lambda y: ls_fun(y,t)))(y))(pred,targets)\n",
    "    #)\n",
    "    key, subkey = random.split(key)\n",
    "    #H, H_std = Hutchinson_ests(net)(nwt, inputs, random.split(subkey, 1000))\n",
    "    H, H_std = tH(nwt, inputs, random.split(subkey, 1000), loop=True, batch_size=10)\n",
    "    #H, H_std = tH(nwt, inputs, random.split(subkey, 100), loop=True)\n",
    "    allH.append(H)\n",
    "    allH_std.append(H_std)\n",
    "    #allsGamma_Xi.append(get_TrH(net, nwt, inputs, sumi_Xi))\n",
    "    #allXi.append(get_sumi_Xi_avg(net, random.split(subkey,1000), inputs))\n",
    "    #allsGamma_Xi.append(get_TrH(net, nwt, inputs, allXi[-1]))\n",
    "\n",
    "\n",
    "key, subkey = random.split(key)\n",
    "record(nw_start, subkey)\n",
    "for epoch in range(num_epochs):\n",
    "    start_time = time.time()\n",
    "    for s, t in zip(split(inputs, split_num), split(targets, split_num)):\n",
    "        opt_state = update(next(itercount), opt_state, (s, t))\n",
    "    epoch_time = time.time() - start_time\n",
    "\n",
    "    nwt = get_params(opt_state)\n",
    "    key, subkey = random.split(key)\n",
    "    record(nwt, subkey)\n",
    "    if epoch % (num_epochs / 5) == 0 or epoch == num_epochs - 1:\n",
    "        print(\"Epoch {} in {:0.2f} sec\".format(epoch, epoch_time))\n",
    "        print(\"loss {}\".format(allloss[-1].mean()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "0f06f7a0",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:49.506551Z",
     "start_time": "2022-05-19T18:26:49.465661Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/gd.npy', 'wb') as f:\n",
    "    np.save(f, allT)\n",
    "    np.save(f, allloss)\n",
    "    np.save(f, allV)\n",
    "    np.save(f, allYd)\n",
    "    np.save(f, allsY)\n",
    "    np.save(f, allH)\n",
    "    np.save(f, allH_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "a4559757",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:50.680728Z",
     "start_time": "2022-05-19T18:26:49.507943Z"
    },
    "scrolled": true
   },
   "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": [
    "plt.plot(allT_ode, vmap(L_mean)(vmap(unpack)(sol)[0]), label=\"Function Space\")\n",
    "plt.plot(allT, [l.mean() for l in allloss], label=\"Parameter Space\")\n",
    "#plt.ylabel(r\"$\\frac{1}{m}\\sum_{a=1}^m l^s(y_d(s_a),t_a)$\")\n",
    "plt.xlabel(\"training time\")\n",
    "plt.ylabel(\"average training loss\")\n",
    "plt.legend(loc=\"upper right\")\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "ea0f2d57",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:51.448496Z",
     "start_time": "2022-05-19T18:26:50.682489Z"
    }
   },
   "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": [
    "plt.plot(allT_ode, vmap(unpack)(sol)[-2], label=\"Function Space\")\n",
    "plt.plot(allT, np.array(allV)-allV[0], label=\"Parameter Space\")\n",
    "plt.xlabel(\"training time\")\n",
    "#plt.ylabel(\"$V(\\\\theta(t))-V(\\\\theta(0))$\")\n",
    "plt.ylabel(r\"Energy Change\")\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "c937ca7c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:52.252086Z",
     "start_time": "2022-05-19T18:26:51.450138Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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4EHi4uJ48MEHR/W64UprRMKOHTt45513xvSawfE88cQTnDt3jv3793PgwAGeffZZ0tPTIxjl8PrPbOqdLps5FRKFMeYqY8yyELfnBx36GLAtzHkeMsasNcaszcnJiVa4SqkY2LRpEydPnuSFF17gkksuYdWqVVx11VXU1dUBgTLj99xzD1u3buXTn/405eXlbNq0idWrV7N69eq+D/cdO3awefNmbrvtNhYuXMg3v/lNHn30UdavX09paWnfKu2Ghga2bdvGunXrWLduHW+//Tbl5eU8+OCD/PCHP2TlypW89dZbIY8LFU9/NTU15OfnYwmubygqKiIjIwMI1In627/9W1avXs2WLVvo/aP3v/7rv1i3bh0rVqxg27ZtfSXK6+rquOmmm1ixYgUrVqzo+zkfeeQR1q9fz8qVK/nLv/xLfL6hRZ76WhTJUyBRhCMiC/o9vB4YWgBeKTWteb1eXnrpJUpLS9m4cSPvvfceH3zwAbfffjv//u//3nfc7t27ef7553nsscfIzc3l1VdfZc+ePTzxxBN8+ctf7jtu37593HfffRw4cICHH36Y48ePs3PnTj73uc/xox/9CICvfOUrfO1rX2PXrl08/fTTfO5zn6OkpIQvfOELfO1rX2Pv3r1s2rQp5HGh4unvtttu44UXXmDlypX87d/+LR988EHf9zo7O1m9ejV79uxh8+bNfO973wMCVWt37drFvn37WLJkCT//+c8B+PKXv8zmzZvZt28fe/bsYenSpRw5coQnnniCt99+m71792K1Wnn00UeH/LsGtk6FzMTIJYpYjVH8m4gsAvzAWWD0RVeUUlNa//0oNm3axGc/+1mOHTvGxz/+cWpqanC73QP69a+//noSEhIA8Hg8fOlLX+r7oDx+/PwYy7p168jPzwdg/vz5bN26FYDS0lLeeOMNAF577bUBW6W2t7eHLCIY7rj+8fRXVFTEsWPH2L59O9u3b2fLli389re/ZcuWLVgsFj7+8Y8DgVLkvWXNDx48yP/8n/+T1tZWnE4nV199NQDbt2/n17/+NRAY00lLS+Phhx9m9+7dfXWjuru7yc3NHRKHRYS0BPuQKbTjEatZT8N2NSmlprdQW6H+zd/8DV//+te5/vrr2bFjB/fee2/f95KSzq8F+OEPf0heXh779u3D7/cTH3++PEX/cuQWi6XvscVi6RtP8Pv9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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "i = 3\n",
    "plt.plot(allT_ode, vmap(unpack)(sol)[2][:, i], label=\"Function Space\")\n",
    "Hi = np.array([H[i] for H in allH])\n",
    "Hi_std = np.array([H_std[i] for H_std in allH_std])\n",
    "plt.fill_between(allT, Hi-3*Hi_std, Hi+3*Hi_std,alpha=0.5, label=\"Parameter Space\")\n",
    "#plt.xlim((0,1))\n",
    "plt.xlabel(\"training time\")\n",
    "#plt.ylabel(\"$\\Tr(H_a(\\\\theta(t)))$\")\n",
    "plt.ylabel(r\"Hessian Trace\")\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "6d465516",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:52.409173Z",
     "start_time": "2022-05-19T18:26:52.253803Z"
    }
   },
   "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": [
    "plt.plot(allT_ode, vmap(unpack)(sol)[-1], label=\"Function Space\")\n",
    "#plt.plot(allT, np.array(allV)-allV[0], label=\"Parameter Space\")\n",
    "plt.xlabel(\"training time\")\n",
    "plt.ylabel(r\"Entropy Change\")\n",
    "plt.legend(loc=\"upper right\")\n",
    "#plt.xscale('log')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "91cbf691",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:26:53.585204Z",
     "start_time": "2022-05-19T18:26:52.410579Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAAEKCAYAAAAMzhLIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAzwklEQVR4nO3deXxU5dn4/881Syb7Qgj7jgUVkKABrVaUYq3W1r1av08VqpWnrUv769et2opbf48KdW/r8liw/Vn3qihaFYWiFcWgoOBSWYJgWELIvs5y/f6YySRDkmFIMplJuN6v13mdM/ec5ZrAnGvuc9/nPqKqGGOMMZ1xJDoAY4wxyc0ShTHGmKgsURhjjInKEoUxxpioLFEYY4yJyhKFMcaYqFyJDuBADBw4UMeMGZPoMIwxpk9Zs2bNHlUt6Or2fSpRjBkzhuLi4kSHYYwxfYqIbO3O9nbpyRhjTFSWKIwxxkRlicIYY0xUfaqNwpju8Hq9bN++ncbGxkSHYkxcpKamMmLECNxud4/u1xKFOWhs376drKwsxowZg4gkOhxjepSqUl5ezvbt2xk7dmyP7tsuPZmDRmNjI/n5+ZYkTL8kIuTn58elxmyJwhxULEmY/ixe/78tURjTS8rLyyksLKSwsJAhQ4YwfPjw8Ovm5uaIde+55x7q6+v3u88TTzzR7i0ycWdtFMb0kvz8fNauXQvATTfdRGZmJldddVWH695zzz38+Mc/Jj09vRcjNKZjVqMwJoHefPNNpk2bxpQpU7j44otpamrivvvuo7S0lFmzZjFr1iwAfv7zn1NUVMSkSZOYP39+gqM2BxurUZiD0s0vbeDT0uoe3efhw7KZ/4NJMa/f2NjI3LlzefPNN5kwYQIXXXQRf/7zn/nVr37FXXfdxfLlyxk4cCAAv//97xkwYAB+v5/Zs2fz8ccfc8QRR/Ro/MZ0xmoUxiSI3+9n7NixTJgwAYA5c+awcuXKDtd9+umnOfLII5k2bRobNmzg008/7c1QzUHOahTmoHQgv/zjJSMjI6b1tmzZwsKFC/nggw/Iy8tj7ty5dtOg6VVWozAmQRobGykpKWHjxo0A/O1vf+OEE04AICsri5qaGgCqq6vJyMggJyeHXbt28eqrryYsZnNwshqFMQmSmprKokWL+OEPf4jP52P69On87Gc/A2DevHmceuqpDB06lOXLlzNt2jQmTZrEuHHjOO644xIcuTnYiKomOoaYFRUVqfUZN1312WefcdhhhyU6DGPiqqP/5yKyRlWLurpPu/RkjDEmKksUxhhjokpoohCRv4jIbhFZn8g4jDHGdC7RNYrFwCkJjsEYY0wUCU0UqroS2JvIGIwxxkSX6BrFfonIPBEpFpHisrKyRIdjjDEHnaRPFKr6sKoWqWpRQUFBosMxplucTmd4aPHCwkJKSkrierx//vOfzJgxg0MPPZTCwkLOP/98vvrqq7geE+DGG29k2bJl3d5PSUkJIsL9998fLrv88stZvHhxt/a7YsUK3n333W5G10pEuPDCC8OvfT4fBQUFfP/734+63dq1a3nllVc6fb+4uJgrr7yyx+LsKrvhzphelJaWFh5qfF+qiqricPTM77f169dzxRVXsGTJknC/+iVLllBSUsKoUaN65BidueWWW3psX4MGDeLee+/lv//7v0lJSemRfa5YsYLMzEyOPfbYHtlfRkYG69evp6GhgbS0NN544w2GDx++3+3Wrl1LcXEx3/ve99q95/P5KCoqoqioy7c/9Jikr1EY05+VlJRw2GGH8Ytf/IIjjzySbdu2cfXVVzN58mSmTJnCU089BQRPbCeccALnnXceEyZM4LrrruPxxx9nxowZTJkyhU2bNrXb9x133MH1118fcfPV6aefzsyZMwF45JFHmD59OlOnTuWcc84JPyhp7ty5PPvss+FtMjMzAdixYwczZ86ksLCQyZMn8/bbb+P3+5k7d2443rvvvrvdPm655RamT5/O5MmTmTdvHi03+Z544olce+21zJgxgwkTJvD22293+DcqKChg9uzZPPbYY+3e27RpE6eccgpHHXUUxx9/PJ9//jl+v59x48ahqlRWVuJwOMKDLR5//PFs3LiRBx98kLvvvpvCwkLefvtttm7dyuzZszniiCOYPXt2uNY1d+5crrzySo499ljGjRsX8XfZ16mnnsrSpUsBeOKJJ7jgggvC761evZpjjz2WadOmceyxx/LFF1/Q3NzMjTfeyFNPPUVhYSFPPfUUN910E/PmzePkk0/moosuYsWKFeFayZVXXhlOwK+99hozZ84kEAh0Gk+PavkVk4gJeALYAXiB7cAl0dY/6qij1Jiu+vTTT1tfvHKt6l++17PTK9fuNwaHw6FTp07VqVOn6plnnqlbtmxREdFVq1apquqzzz6rJ510kvp8Pt25c6eOHDlSS0tLdfny5ZqTk6OlpaXa2Niow4YN0xtvvFFVVe+55x795S9/2e5Y06ZN07Vr13Yay549e8LLN9xwg953332qqjpnzhx95plnwu9lZGSoqurChQv1tttuU1VVn8+n1dXVWlxcrCeddFJ43YqKinb7KC8vD7//4x//WJcsWaKqqieccIL++te/VlXVpUuX6uzZs9vFuGXLFp00aZJu3rxZJ06cqD6fTy+77DJdtGiRqqp++9vf1v/85z+qqvree+/prFmzVFX1u9/9rq5fv15feuklLSoq0ttuu00bGxt1zJgxqqo6f/58XbBgQfg43//+93Xx4sWqqvroo4/qGWecEf4c5557rvr9ft2wYYOOHz++w79lRkaGrlu3Ts855xxtaGjQqVOn6vLly/W0005TVdWqqir1er2qqvrGG2/o2WefraqqixYt0ssuuyy8n/nz5+uRRx6p9fX1qqoR+6irq9PDDz9c33rrLZ0wYYJu3Lixw1gi/p+HAMXajXN1Qi89qeoF+1/LmP5j30tPJSUljB49mmOOOQaAd955hwsuuACn08ngwYM54YQT+OCDD8jOzmb69OkMHToUgPHjx3PyyScDMGXKFJYvXx71uOXl5cyePZv6+nrmzZvHVVddxfr16/ntb39LZWUltbW1fPe73426j+nTp3PxxRfj9Xo588wzKSwsZNy4cWzevJkrrriC0047LRxTW8uXL+fOO++kvr6evXv3MmnSJH7wgx8AcPbZZwNw1FFHRW2vGTt2LDNmzODvf/97uKy2tpZ3332XH/7wh+GypqYmIFhzWLlyJVu2bOE3v/kNjzzyCCeccALTp0/vcP+rVq3iH//4BwAXXngh11xzTfi9M888E4fDweGHH86uXbs6jfGII46gpKSEJ554ot2lpKqqKubMmcOXX36JiOD1ejvdz+mnn05aWlq78vT0dB555BFmzpzJ3Xffzfjx4zvdR0/rU20UpbWlPLbhMcbmjGV87niGZgzFIXb1zHTBqbcnOoKwtsONa5Sx1zweT3jZ4XCEXzscDnw+X7v1J02axIcffsjUqVPDj2FduHAhtbW1QPCyygsvvMDUqVNZvHgxK1asAMDlcoUvaahq+HneM2fOZOXKlSxdupQLL7yQq6++mosuuoh169bx2muv8cc//pGnn36av/zl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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def get_dSdt(Yd,TrH):\n",
    "    o = np.ones_like(Yd)\n",
    "    g, dLH = jvp(lambda Yd: grad(L_mean)(Yd), (Yd, ), (o, ))\n",
    "    return -np.dot(dLH, Thetad.diagonal()) - np.dot(TrH, g)\n",
    "def get_dSdt_by_GN(Yd,TrH):\n",
    "    o = np.ones_like(Yd)\n",
    "    g, dLH = jvp(lambda Yd: grad(L_mean)(Yd), (Yd, ), (o, ))\n",
    "    return -np.dot(dLH, Thetad.diagonal())\n",
    "def get_dSdt_by_Hessian(Yd,TrH):\n",
    "    o = np.ones_like(Yd)\n",
    "    g, dLH = jvp(lambda Yd: grad(L_mean)(Yd), (Yd, ), (o, ))\n",
    "    return -np.dot(TrH, g)\n",
    "r=vmap(unpack)(sol)\n",
    "plt.plot(allT_ode, vmap(get_dSdt)(r[0],r[2]), label=\"Total\")\n",
    "plt.plot(allT_ode, vmap(get_dSdt_by_GN)(r[0],r[2]), label=\"From Gaussian Newton Matrix\")\n",
    "plt.plot(allT_ode, vmap(get_dSdt_by_Hessian)(r[0],r[2]), label=\"From Hessian\")\n",
    "#plt.plot(allT, np.array(allV)-allV[0], label=\"Parameter Space\")\n",
    "plt.xlabel(\"training time\")\n",
    "plt.ylabel(r\"Change Speed of Entropy S\")\n",
    "plt.legend(loc=\"upper right\")\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a73a88b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a92a6949",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ad0fc1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e54acd1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17593722",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env: (tf)",
   "language": "python",
   "name": "tf"
  },
  "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.9.7"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {
    "height": "calc(100% - 180px)",
    "left": "10px",
    "top": "150px",
    "width": "288px"
   },
   "toc_section_display": true,
   "toc_window_display": true
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
