{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "7baceb7e",
   "metadata": {},
   "source": [
    "# Switching Mean\n",
    "\n",
    "SGDm linear regression from $n$ to $m$ dimensions with observation noise, stochastic covariate shift with randomly changing domain sampling mean."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "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",
    "sweep_name = '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_switching_variance = 0.5\n",
    "mean_switching_interval = 10\n",
    "\n",
    "# Storage params\n",
    "database = 'switching_mean'\n",
    "user = 'postgres'\n",
    "password = 'password'\n",
    "host = 'localhost'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0197e74a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from io import StringIO\n",
    "\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",
    "import psycopg2 as pg\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": 10,
   "id": "ee0af5bc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "cff29ac28b994d8499cf67baff47c168",
       "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",
    "velocity = jnp.zeros_like(weights)\n",
    "\n",
    "rand_key, subkey = random.split(rand_key)\n",
    "means = helpers.stochastic_vector_mean_sequence(input_dimensions, mean_switching_interval, mean_switching_variance, iterations, subkey)\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": 11,
   "id": "468d322e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f7a08204cc0>]"
      ]
     },
     "execution_count": 11,
     "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(target_distances[:mean_switching_interval * 10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "eef29b3e-95d6-4bc3-bb4f-1900b24cae64",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f7a0828f0b8>]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmYAAAGgCAYAAAAAdau+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAABJ0AAASdAHeZh94AAA100lEQVR4nO3deZSkWV3n//c3IjIi96x96eqmu+nqhl6wm6EFWQQc1nEQdASdQVTmiFv/+HlGxZ/KKAw6g4orCDjiOLhwht1jIyiyiOIIAi1g08VSXQ1NVXdXVdaee6z390dEZkVlR2ZlZmxZ1e/XOXEi8okb8dx8bkbGJ+69cZ9IKSFJkqT+y/S7ApIkSaozmEmSJG0SBjNJkqRNwmAmSZK0SRjMJEmSNgmDmSRJ0iZhMJMkSdokDGaSJEmbhMFMkiRpkzCYSZIkbRK5fldgvSJiAngGcAQo9bk6kiRJq8kDVwH/kFI6d7HCl1wwox7K7ux3JSRJktbhRcAHLlboUgxmRwD+8i//kv379/e7LpIkSSs6dOgQ3/3d3w2N/HIxl2IwKwHs37+fm2++ud91kSRJWos1Tb9y8r8kSdImYTCTJEnaJAxmkiRJm4TBTJIkaZMwmEmSJG0SBjNJkqRNwmAmSZK0SRjMJEmSNgmDmSRJ0iZhMJMkSdokDGaSJEmbhMFMkiRpk7gUT2LeVZPTC7z0jz5DpVrjVc97DC/4liv6XSVJkvQIYTBbLsGhyRkAzs6V+1wZSZL0SOJQ5jK57PlDUqnW+lgTSZL0SGMwWyaXjaXblVrqY00kSdIjjcFsmXxTj1nJHjNJktRDBrNlcpmmHrOqPWaSJKl3DGbLZC8IZvaYSZKk3jGYLRMRDDTmmZWdYyZJknrIYNZCLlM/LPaYSZKkXjKYtbDUY+YcM0mS1EMGsxYGGt/MLNtjJkmSeshg1sLiWmZ+K1OSJPWSwayFxTlm5Zo9ZpIkqXcMZi0M2GMmSZL6wGDWgnPMJElSPxjMWsgtBTN7zCRJUu9sKJhFxM0R8d6I+HpEzEXEyYj4ZER8V4uyN0bEhyNiJiJOR8SfR8TO9qvePUtDmc4xkyRJPZTb4OOuBsaAPwUeAoaB7wU+EBE/nlJ6G0BEXAl8EjgHvBoYBV4FPC4inphSKrVZ/65YPF+mc8wkSVIvbSiYpZT+Gvjr5m0R8WbgX4CfAd7W2PxqYAR4QkrpcKPcZ4GPAi9vKrep5JxjJkmS+qBjc8xSSlXgCLClafP3Ah9cDGWNch8DDgLf16l9d1reYCZJkvpgo0OZAETECDAETAAvBP4d8O7GffuAXcBdLR76WeA729l3Ny0tMOtJzCVJUg+1FcyA3wZ+vHG7BvwF8MrGz3sb10dbPO4osC0iCiml4kpPHhG7gOVfFLhu49Vdm6UFZp1jJkmSeqjdYPZ7wPuAK6gPTWaBfOO+ocZ1q+C10FRmxWAG3AG8ts06rtv5BWYdypQkSb3TVjBLKX0V+Grjxz+LiI8AfxURTwLmG9sLLR462Lieb3Ffs7cC71227Trgzg1Ud80WJ/87lClJknqp3R6z5d4H/CFwA+eHMPe2KLcXOL3aMCZASmkSmGzeFhEdqObqFnvMShV7zCRJUu90euX/xeHLiZTSg8AJ4PYW5Z4IfLHD++6Ygcxij5nBTJIk9c5GV/7f1WLbAPBD1Icnv9zY/H7gBRFxVVO5Z1HvUVs+RLlp5DyJuSRJ6oONDmX+YUSMU1/V/0FgD/ADwGOBn00pzTTKvR54CfCJiHgj9ZX/fw74EvD2direTdnGyv/VZDCTJEm9s9Fg9m7gR4CfBLYD09RX/f/5lNIHFgullI5ExDOA3wF+HSgBH6Ie3ladX9ZPS8HMHjNJktRDGz0l07uAd62x7AHgeRvZT79kwx4zSZLUe52e/H9ZyDbmmFVdLkOSJPWQwayFpR4zg5kkSeohg1kLTv6XJEn9YDBrYTGYpQQ1e80kSVKPGMxayDadXcBeM0mS1CsGsxYymaZgZo+ZJEnqEYNZC7mmYFazx0ySJPWIwayFbFMwq9hjJkmSesRg1kKmaY6Zk/8lSVKvGMxaWDyJOTjHTJIk9Y7BrIXmHjODmSRJ6hWDWQvNc8xcLkOSJPWKwayFrMtlSJKkPjCYtZB1KFOSJPWBwawFe8wkSVI/GMxayLrArCRJ6gODWQsuMCtJkvrBYNaCy2VIkqR+MJi1kHOOmSRJ6gODWQtO/pckSf1gMGsh4+R/SZLUBwazFpqHMitVg5kkSeoNg1kLF0z+t8dMkiT1iMGshQvWMav1sSKSJOkRxWDWwoXrmJnMJElSbxjMWnDlf0mS1A8GsxYuXMesjxWRJEmPKAazFi5c+d9kJkmSesNg1kLWHjNJktQHBrMWLghmzjGTJEk9YjBr4cIeM7vMJElSbxjMWsiGQ5mSJKn3DGYtZLPNC8w6lClJknrDYNZCc49ZxWAmSZJ6xGDWQqbpqDj5X5Ik9YrBrIVcUzJzKFOSJPWKwawFhzIlSVI/GMxaaB7KtMdMkiT1yoaCWUR8a0S8OSIORMRsRByOiPdExA3Lyv1JRKQWl692pvrd0TyU6RwzSZLUK7kNPu7ngacC7wXuBvYArwQ+HxHfllK6p6lsEXjFssef2+B+e+KCyf/2mEmSpB7ZaDD7HeClKaXS4oaIeDfwJeAXgJc1la2klN6x8Sr23oULzBrMJElSb2xoKDOl9KnmUNbYdi9wALhxefmIyEbE+Maq2HsXnpLJYCZJknqjY5P/IyKA3cDJZXcNA1PAuYg4HRFviYjRTu23GyKCxWxmMJMkSb2y0aHMVn4A2Ae8pmnbUeANwOeph8DnA3cAt0bEM1NKldWeMCJ2ATuXbb6uYzVeRTYT1KrJyf+SJKlnOhLMIuKxwFuATwN/urg9pfSLy4q+KyIOAv8DeDHwros89R3AaztRx/XKZoJyNdljJkmSeqbtocyI2AN8iPo3LV+cUqpe5CG/C9SAZ6/h6d8K3LLs8qKN13btFr8AYDCTJEm90laPWURMAH8DbAG+PaX00MUek1Kaj4hTwLY1lJ0EJpftc2OVXadMxmAmSZJ6a8PBLCIGgb8CbgCenVL68hofNwbsAE5sdN+9kDOYSZKkHttQMIuILPBu4MnAi1JKn25RZhAYSClNL7vrl4EAPryRfffK4pIZTv6XJEm9stEes98GXki9x2xbRDQvKEtjQdk9wBci4p3A4imYngd8J/VQducG990TmcaQqefKlCRJvbLRYHZb4/q7Gpfl3gGcBT4IPAf4YSALHAJeDfxWSqm2wX33xOJQZsVgJkmSemRDwSyl9Mw1lDkL/OBGnn8zWJz8b4+ZJEnqlY6t/H+5cY6ZJEnqNYPZCrIOZUqSpB4zmK0g6+R/SZLUYwazFWRdx0ySJPWYwWwFBjNJktRrBrMVOPlfkiT1msFsBfaYSZKkXjOYrWBx8r/BTJIk9YrBbAUZe8wkSVKPGcxWsHhKpppzzCRJUo8YzFbgArOSJKnXDGYryLjArCRJ6jGD2QpyLpchSZJ6zGC2gsXJ/5WqwUySJPWGwWwFS+fKtMdMkiT1iMFsBdmsy2VIkqTeMpitwAVmJUlSrxnMVuC5MiVJUq8ZzFawGMxqtT5XRJIkPWIYzFawOJRZMZlJkqQeMZit4Py5MvtcEUmS9IhhMFvB0gKz9phJkqQeMZitwHNlSpKkXjOYreB8j5nBTJIk9YbBbAW5bP3QeEomSZLUKwazFQw0Vv4vO8dMkiT1iMFsBblM/dCk5HCmJEnqDYPZCnKNHjNwLTNJktQbBrMVLE7+B+eZSZKk3jCYrWBx8j8YzCRJUm8YzFYw0DSU6RcAJElSLxjMVrA4+R/sMZMkSb1hMFvBBXPM7DGTJEk9YDBbwQXfyrTHTJIk9YDBbAUXTP63x0ySJPWAwWwFA01DmWV7zCRJUg8YzFbgchmSJKnXDGYraJ7873IZkiSpFzYUzCLiWyPizRFxICJmI+JwRLwnIm5oUfbGiPhwRMxExOmI+POI2Nl+1burefK/58qUJEm9kNvg434eeCrwXuBuYA/wSuDzEfFtKaV7ACLiSuCTwDng1cAo8CrgcRHxxJRSqc36d03zOmblqj1mkiSp+zYazH4HeGlzsIqIdwNfAn4BeFlj86uBEeAJKaXDjXKfBT4KvBx42wb333UDLpchSZJ6bENDmSmlTy3v7Uop3QscAG5s2vy9wAcXQ1mj3MeAg8D3bWTfveJyGZIkqdc6Nvk/IgLYDZxs/LwP2AXc1aL4Z4HHd2rf3ZBzuQxJktRjGx3KbOUHgH3Aaxo/721cH21R9iiwLSIKKaXiSk8YEbuA5V8UuK7diq6Fk/8lSVKvdSSYRcRjgbcAnwb+tLF5qHHdKngtNJVZMZgBdwCv7UQd18vJ/5IkqdfaDmYRsQf4EPVvXr44pVRt3DXfuC60eNjgsjIreSv1b342uw64cwNVXRcn/0uSpF5rK5hFxATwN8AW4NtTSg813b04hLl3+eMa206vNowJkFKaBCaX7XPD9V0PJ/9LkqRe23Awi4hB4K+AG4Bnp5S+3Hx/SunBiDgB3N7i4U8EvrjRffeCk/8lSVKvbXTl/yzwbuDJwEtSSp9eoej7gRdExFVNj30W9TC3fIhyU2kOZk7+lyRJvbDRHrPfBl5IvcdsW0S8rPnOlNI7GjdfD7wE+EREvJH6yv8/R30h2rdvcN89kc+dz6zFSnWVkpIkSZ2x0WB2W+P6uxqX5d4BkFI6EhHPoH6mgF8HStS/KPCzF5tf1m/D+fOHZq5kMJMkSd23oWCWUnrmOsoeAJ63kf30UzYTFHIZipUa8wYzSZLUAx1b+f9yNFKo59bZUqXPNZEkSY8EBrNVDOezAMwV7TGTJEndZzBbxUjeHjNJktQ7BrNVDC32mDnHTJIk9YDBbBUjBYOZJEnqHYPZKhaXzJgtOpQpSZK6z2C2ihGHMiVJUg8ZzFYx1OgxM5hJkqReMJit4nyPmUOZkiSp+wxmqxgunO8xq3kic0mS1GUGs1Us9pgBzJcdzpQkSd1lMFvFcFMwc56ZJEnqNoPZKhaXywDnmUmSpO4zmK1icYFZgFnPlylJkrrMYLYKe8wkSVIvGcxW0dxj9rGvTHJqptjH2kiSpMudwWwVQwPne8z+5z/cx/e/7Z/7WBtJknS5M5itornHDODQ5AxTC+U+1UaSJF3uDGaraJ5jtujBM/N9qIkkSXokMJitYmzw4cHsAYOZJEnqEoPZKgYHsg/b9sCZuT7URJIkPRIYzNbp7JxzzCRJUncYzC7id7//1gt+Xqi40KwkSeoOg9lFfPdt+/jITz+dfK5+qBY8Z6YkSeoSg9lFRAQ37B5j6/AAAAvlWp9rJEmSLlcGszVa/CKAQ5mSJKlbDGZrNJirB7N5hzIlSVKXGMzWaHCgMces4lCmJEnqDoPZGi0NZZbtMZMkSd1hMFujxWBWNJhJkqQuMZit0eJQ5rzBTJIkdYnBbI2GloYynWMmSZK6w2C2Rs4xkyRJ3WYwW6PFYOZQpiRJ6haD2RoVGnPMig5lSpKkLjGYrdHiHLNStUa1lvpcG0mSdDkymK3R4lAmQNHTMkmSpC4wmK3RYO78ofK0TJIkqRs2HMwiYjQiXhcRH46I0xGRIuLlLcr9SeO+5ZevtlXzHhvKn+8x87RMkiSpG3JtPHYH8BrgMPCvwDNXKVsEXrFs27k29t1zzUOZLpkhSZK6oZ1gdhTYm1I6FhG3A59bpWwlpfSONvbVd4WcwUySJHXXhocyU0rFlNKxtZaPiGxEjG90f/12wVCmwUySJHVBryb/DwNTwLnGfLS3RMRoj/bdEc2T/z0tkyRJ6oZ2hjLX6ijwBuDz1IPg84E7gFsj4pkppcpKD4yIXcDOZZuv61ZFV+McM0mS1G1dD2YppV9ctuldEXEQ+B/Ai4F3rfLwO4DXdqtu69EczDwtkyRJ6oZ+rWP2u0ANePZFyr0VuGXZ5UXdrVprQxf0mDmUKUmSOq8XQ5kPk1Kaj4hTwLaLlJsEJpu3RUQ3q7aiwYHmOWb2mEmSpM7rS49ZRIxRXwftRD/2vxEF55hJkqQu62owi4jBRghb7peBAD7czf130pDBTJIkdVlbQ5kR8UpgC3BFY9N3RcSVjdu/D2wFvhAR7wQWT8H0POA7qYeyO9vZfy8NZINMQC05x0ySJHVHu3PMXgVc3fTzf2hcAN4BnAU+CDwH+GEgCxwCXg38Vkrpkkk4EcHgQJa5UtUeM0mS1BVtBbOU0jVrKPaD7exjM1kKZhWDmSRJ6rx+LZdxSVqcZzZfumQ6+iRJ0iXEYLYOhcaSGfaYSZKkbjCYrcNgrt5jVnSOmSRJ6gKD2ToM5RtDmQYzSZLUBQazdVhc/d/lMiRJUjcYzNZhcSjT5TIkSVI3GMzWYXDAYCZJkrrHYLYO54OZQ5mSJKnzDGbrcH6OmT1mkiSp8wxm6+BQpiRJ6iaD2TosrfxfrpJS6nNtJEnS5cZgtg6L65jVEhQrzjOTJEmdZTBbh/HB8+d8n1oo97EmkiTpcmQwW4exwYGl29MLlT7WRJIkXY4MZuswPnS+x8xgJkmSOs1gtg4X9pg5lClJkjrLYLYOY81zzObtMZMkSZ1lMFsHe8wkSVI3GczWobnHzDlmkiSp0wxm6zCazxFRv22PmSRJ6jSD2TpkMsFwY/X/2ZKnZZIkSZ1lMFunkUJ9OHOu5FCmJEnqLIPZOi0Gs5miPWaSJKmzDGbrNNw4X+Zc0R4zSZLUWQazdVrsMZt1KFOSJHWYwWydRho9ZrMOZUqSpA4zmK3TsD1mkiSpSwxm6zSyNMfMHjNJktRZBrN1co6ZJEnqFoPZOo3kG8GsWCGl1OfaSJKky4nBbJ2GGkOZtQTFSq3PtZEkSZcTg9k6DTZOyQQGM0mS1FkGs3Uq5M4fsmLFLwBIkqTOMZit0wU9ZmV7zCRJUucYzNbJHjNJktQtBrN1ag5mC/aYSZKkDjKYrdOFk//tMZMkSZ1jMFunC4Yy7TGTJEkdtOFgFhGjEfG6iPhwRJyOiBQRL1+h7I2NcjONsn8eETs3XOs+au4xW7DHTJIkdVA7PWY7gNcANwL/ulKhiLgS+CSwH3g18FvAvwc+GhH5NvbfF4UBe8wkSVJ35Np47FFgb0rpWETcDnxuhXKvBkaAJ6SUDgNExGeBjwIvB97WRh16rpA732P2DwdP8Lyb95DJRB9rJEmSLhcb7jFLKRVTSsfWUPR7gQ8uhrLGYz8GHAS+b6P775fBph6zd33uCO/83OFVSkuSJK1dVyf/R8Q+YBdwV4u7Pws8vpv774bmHjOAN3z4a32qiSRJuty0M5S5Fnsb10db3HcU2BYRhZRSsdWDI2IXsPxLAtd1sH7r1txjBjA+1O1DKEmSHim6nSqGGtetgtdCU5mWwQy4A3htpyvVjnx2WTAbHOhTTSRJ0uWm28FsvnFdaHHf4LIyrbwVeO+ybdcBd7ZZrw3LLQtmk9MrZUpJkqT16fYCs4tDmHtb3LcXOL3SMCZASmkypXSg+QLc142Krscrv2P/0u1TM0UqVZfNkCRJ7etqMEspPQicAG5vcfcTgS92c//d8qrnPYbXf8/jAKgleOjswkUeIUmSdHG9OCXT+4EXRMRVixsi4lnADTx8mPKSsX/X6NLteyen+1gTSZJ0uWhrjllEvBLYAlzR2PRdjZX+AX4/pXQOeD3wEuATEfFGYBT4OeBLwNvb2X8/XX9BMJvhWTfu7mNtJEnS5aDdyf+vAq5u+vk/NC4A7wDOpZSORMQzgN8Bfh0oAR8Cfna1+WWb3daRPDtG85ycKXFocqbf1ZEkSZeBtoJZSumaNZY7ADyvnX1tRvt3jXJy5jT3GswkSVIH9GKO2WXr+l1jABw6Pk1Kqc+1kSRJlzqDWRuu2TECwGypypm5cp9rI0mSLnUGszaMD54fCZ5ZqPSxJpIk6XJgMGvDWHMwKxrMJElSewxmbRgpnA9msyWDmSRJao/BrA3NwcyhTEmS1C6DWRvGCg5lSpKkzjGYteGCoUyDmSRJapPBrA0j9phJkqQOMpi1YSSfXbptMJMkSe0ymLUhl80wNFAPZw5lSpKkdhnM2rQ4nDlTrPa5JpIk6VJnMGvTaKHeY+ZQpiRJapfBrE2jjdX/HcqUJEntMpi1aSS/OJRpMJMkSe0xmLVpdHGOmSv/S5KkNhnM2rQ0lOm5MiVJUpsMZm1a/Famc8wkSVK7DGZtWhzKnHYoU5Iktclg1qbFYFas1KhUa32ujSRJupQZzNrk+TIlSVKnGMzatLjALBjMJElSewxmbWruMZv1tEySJKkNBrM2OZQpSZI6xWDWptELeswMZpIkaeMMZm0ymEmSpE4xmLVp1KFMSZLUIQazNjnHTJIkdYrBrE0jTctlOJQpSZLaYTBrUyGXZSAbAMy4XIYkSWqDwawDFueZzRTLfa6JJEm6lBnMOmBiaACAs3MGM0mStHEGsw7YMpwHDGaSJKk9BrMO2Dpc7zE7M1fqc00kSdKlzGDWAVvtMZMkSR1gMOuArSP1YGaPmSRJaofBrAMWhzLnSlUWyi6ZIUmSNqbrwSwinhkRaYXLt3V7/72wOPkfHM6UJEkbl7t4kY55E/C5ZdsO9XD/XbO1KZidmSuxZ2Kwj7WRJEmXql4Gs39MKb2vh/vrmcWhTHCemSRJ2riezjGLiLGI6GUY7InFyf/gUKYkSdq4XgaztwNTwEJEfCIibu/hvruqeSjz9Kw9ZpIkaWN60XtVAt4P/DVwErgJeBXwjxHxlJTSF1Z6YETsAnYu23xdtyq6UVuahjLPOpQpSZI2qOvBLKX0KeBTTZs+EBHvA+4Gfg14/ioPvwN4bRer1xGDA1mGBrLMl6uccShTkiRtUF/WMUspHQLuBL4jIrKrFH0rcMuyy4u6X8P12zVeAODBM/N9rokkSbpU9XMi/hEgD4xQn3v2MCmlSWCyeVtEdL9mG/CY3WN889QcXz3W8leRJEm6qH6u/P9oYAGY6WMdOubGveMA3H9qjoPHp/tcG0mSdCnqxcr/yyfvExG3Ai8EPpJSqnW7Dr3w9Bt2LN1+yycui3VzJUlSj/ViKPPdETFP/QsAk9S/lfljwBzwCz3Yf0884ept/NvH7uLvvjrJJw+eoFZLZDKbc9hVkiRtTr0YyvxLYAfwM9Qn838/8BfA7Smlr/Rg/z3z7Bt3A3BmrszBSYczJUnS+vRiuYw3UT9P5mXvCVdvXbp995FzPHbPeB9rI0mSLjX9nPx/2dm/a5ThfH31j7sfPNvfykiSpEuOwayDsplg/65RAO4/Odfn2kiSpEuNwazDrto6DMCRMwYzSZK0PgazDrty2xAAD52dp1pLfa6NJEm6lBjMOmyxx6xcTRybWuhzbSRJ0qXEYNZhV20bXrp95LTDmZIkae0MZh121dahpduHDWaSJGkdDGYdtm/rEIvnWX/AYCZJktbBYNZhhVyW3WODABw5M9/n2kiSpEuJwawLrmp8M9M5ZpIkaT0MZl3gWmaSJGkjDGZdcGXjm5nHp4oslKt9ro0kSbpUGMy6oPmbmQ/YayZJktbIYNYFN+weW7r95aPTfayJJEm6lBjMuuAxe8bIZuprZnz5oak+10aSJF0qDGZdMDiQZf/OUQAOPHSuz7WRJEmXCoNZl9x8xThQ7zFLyZOZS5KkizOYdclNjWB2arbE8alin2sjSZIuBQazLvmWK7cs3b7rm6f7VxFJknTJMJh1ybdcOUE+Vz+8n/m6wUySJF2cwaxLBgey3HrlBAD/+sDZ/lZGkiRdEgxmXbQ4nPmVo1MUK54BQJIkrc5g1kWP21fvMStXEwePzfS5NpIkabMzmHXR4xpDmQBfetD1zCRJ0uoMZl107fYRRgs5AL704Nn+VkaSJG16BrMuymRiaaHZux+wx0ySJK3OYNZl39IYzjx4fJpz82UOTc5QrXkmAEmS9HC5flfgcve4xjczy9XEra/7CAA/9OSr+ZUX3dLHWkmSpM3IHrMue8LVWx+27c8+/U3uO+G3NCVJ0oUMZl22b8sQ+7YMPWz7r37wy57cXJIkXcBg1gNP27/jYdv+/msn+JUPfrkPtZEkSZuVwawHXvHt1zI0kGWskOP//OiTGB+sT+37k0/dz9eOTfe5dpIkabMwmPXA9bvH+OjPPJ2P/MzTecp1O3jHK55EBKQEb/r4vf2uniRJ2iQMZj1y5dZh9k7U55p9y5Vb+O7b9gHwkS8f4/RsqZ9VkyRJm4TBrE9ecvuVQH0ZjV++8x6/CCBJkgxm/fLkR2/nmY/ZCcCH7j7Kc3/3k/z8++7mobPzfa6ZJEnqF4NZn0QEv/2SW5eW0rh3coZ333WEl/7RPzNbrPS5dpIkqR8MZn20fbTA+3/yKbziaddy3c4RAO4/Ncd/+8ABphfKLJSrfa6hJEnqpZ4Es4goRMRvRMRDETEfEZ+JiOf0Yt+b3Z6JQX7pBTfx0Z9+Bk+5bjsA7/2XB3jcf/sIt77uI/zuRw9Sqdb6XEtJ6o1Ktca9x6c545eiNpVipcrxqQXnQ/dAr86V+SfAi4HfA+4FXg78dUR8R0rp//aoDptaJhP8zvfdxvPf+EnOzpUBKFZqvPHj9/KP957g5U+9lq3DAzx0dp77Tsxy+NQcpWqNx+4ZI5/LMLNQ4YY9Yzz7xt1sG8k/7PlrtcTRqQW+9MBZ/vWBc1y5dYj9O0c5OVNibDDHNdtH2Ld1iGwmNlT/mWKFYrnKXKnKrvEChVy28TtUOT1b4sR0kZMzRbaPFLh+9yiVWqJWSwznc9RSopDLEFHf92yxwqmZEmfmSkxOFzl6bp6BbIa9E4NkItg1XuDaHSNL+wBIKfGlB8/xsa9Mcm6uxFXbhrlp7zhzpSp7JgbZt2WIwYEsQ/nsUn0fOjvPiekiI4UcO0bz7B4fZCCboVpLHD03z/jQAOODAw/7XVNKTC3Uh5vz2QwD2SAiWDxy3zw9x7n5MqOFLFduHQbg6ydmGc5nuXp7/eep+Qq5bFBNiYVSla0jeQay7X1OmitVyGczZDPBbKlKuVLjwbPzfOPkLAePT/P5w2eYL1W5/ZptPHX/DsYHc0wtVChXagwXsjx6xyi7xwtL7VCsVPnbA8f50gNn2b9rlBfeum/p+K0kpUQtwdFz83zz1Bz5XP13KlVqXLFliGt3jFxQfqFcpZbqfwfNzwH14f6FcpX5UpWRQo58LsN8qcrJmSLD+SzjQwN89eg0f/rp+7nr/tPsGhvkln0TXLNjmKu2DfOobcNsH8kznM8t1eNiFspVDp+e4/6Ts1RriUfvHGXHaJ65UpX5cpVMBOfmS5ydKzNayHHtjhF2jp0/ZgDlao0zsyW2jxZYfDmlBA+dm2dyusiWoQF2jBUYK+QueFzz44uVGiP5LNPFCiemi2wdzpPLBieni5ycKXFypsjxqQVmixV2jBbYMpwnnwvGBgfIZYLTsyUqtcQTrt7KjtHCqr/zkdNznJ0rs2Msz66xwVX/B1SqNWqJNR3PlBKnZ0sM5DItX0etyv/Jp+7njR+/d+l/4KN3jvDU63bwlOu287TrdzC2hudZrOfh03MslGvsGM2TzQQjhRyDAxf+/aaUmCtVGRzIUqnVOHxqju2jBSq1GsVyjb0Tg+RWeF3OFitLr69ipcbNV4xz3c7RNdWvWks8dHaebCYYyGbIZzNEBmYW6u250vE9N1fmG6dmKZarbB8tcO/xabKZ4NartjA2mKNYrlGu1ogIEol/PHiSw6fnuHbHCFduHeLT953i5EyR3RODPG3/Dm7aO87puRKnZkqMFnJsHckzPJAlkwmmFsp8/ptn+OTBk3zmG6f4+olZ5stV9k4M8tybdvPcm/ewe7xApZY4M1vm8OlZRgo5tg3nGSnkGCnkmF4oc/j0HFMLFb55cpY9E4NUa4nd44N8+/U76se6WlvxGLc6bvPlKoVchlwmWr5+1mOmWCETMJDNtP3/t5Oi2+k3Ip4IfAb4uZTSbzW2DQL3AJMppaes8/luBu655557uPnmmzte3377p0Mned1fHeDRO0Y5dGKGQ5PrO6dmJuC2q7YwV6q/4W0dzjO1UOH+k/UX1Wry2QxXbx9m39Yhzs6VOTFdpFipsWuswNRCmWPnFhjIZhgfyjExNMDE0ACFXJbjUwvc21TPTMDeiSGmFspML6xtvlw+m+Exe8YoVqocPH7x3zmbCa7dMcJNe8eppcQXj5zlgTMX/+LE+GCOlGC6xTy+bCYYG8wxNV+m1nhZjBVyDOazpJTYMpynWkucmSstvXFcTDS9MQOMDeZYKFcpVx/+uts1VuCWfRPcuHeM41NFvvzQFBNDA1y9fZhaSpQqNbYM5xkfGuDUTHEp7J6cqQff+XL1Yftbr3wuw87RAkP5ers2t9/E0ABP3b+drcN5ytUa5Wq9TvPlKsVKPZQfPDbNbGnlv7PH7hnj5ismOHpunvtPzvLQuYWl47JzrAAJjp5boFStMZzPXrD/fDZDpVZbapu1ioBHbRtm35YhhhpvzONDA2wZHmDrcJ6hgSz3Tk7zT4dO8eAGvnwzVsgxOphjKJ8lJTg+tcBcqUo+m6GWEgnIRlBa1vO9eKwXA+dcqcJ809/GQDZa/p2s93e/cc94IzzWw8RANkOlmphaKDM1X15qA6gf490TBaYXKmwbrn9YmS9XOTtX4sxcmXPzZSJgx2iBbcN59m0dYq5U4excmUIuw5bG8ZycXuDQ5MzSB5iJoQFGCzkyGbhiYogtwwMEQS0lphcqTBfLTE4VmZwurvi7FHL1/0+ZCIbzWUYHB5gvVShValQbr49vnppjcCDLXKnS8tgN57MUcpmlv9FMwEK5tnR7+d9WIZdhKJ9lJJ/j+t2j7J0YWuo5+tw3zjysTR+7Z4xH7xzhyOl5hhsfYqYWKmwfybN9tP6B+YtHznJ8amFpv8tlAq7YMsTW4TyVWqJYrrJQrjJbqnJufm3/d9qRCdg2UuDkzMpt0QkRMD44wLn5Mvu2DLFnYpBCLkNK9Q8n2Uywb0u9s+D4dJGjZ+c5fHqOYqV+3AYHMuwYLZCJIIL6deN5t48UGBvMcXx6gUo1kW8EucUAls0E9x6fXvrbf/aNu/lfP3x7137XAwcOcMsttwDcklI6cNFj04Ng9gbgZ4BtKaWppu2/CLweeFRK6cg6nu+yDmbNFspVfvNvv8Z77jrysICz+A/q/lOzpMYn2FLFIU+A0UKOGb9AcYEIuGHXGEP5LHc/cHbd4WYzywQ8df8Ozs6V+drxaV8Hl7h9W4b40W+/lqmFCp++7xT/cviMbdpBY4Vcyw+mK8lmgsdftYWbrhhn9/ggn7rvJP/89dNU1/lPpFXw3Sz+3S17+IOXPaFrz7/eYNaLoczHAwebQ1nDZxvXtwFrDmaPJIMDWX75BTfx889/LJ8/fIZytcae8UGG8ueHyGq1RKWWyGaCu+4/zYcPHOOLR84yPjjA4ECGM7NlBvNZHr1jhEfvHOG6naM8/lFbOHx6jnsenOLq7cOUqzXuPznHN07O8JWj00xOL7BzrMDusUFy2WByusj44AB7twxSbXzSPjdfvxQrNbYO57lh9xjbR/KMDeY4fHqOB8/Os3U4z/aRPNtG69c7xwocnypy3+QMQ/ksEcF8qUJEcHKmyIEHpxguZLnligketX24/vjRPPu2DFEs1zg2tUAEPHhmnq8dn+bLD03xtWPT5BufpP/tY3fx/Fv2sGd8kPtPzXFocoZtIwM8dHaBY41emGPnFsgE7JkYYu/EILvGC8wVq5yYKfLNU3NML5TZNpJnx2iBuVK18cm23hN1dq5MLpthJJ/lUduHyWczlKuJcrVGSpBIpAS7xwfZPV7vZTx4fIZsBNfvHuXMbImDkzOMDebYMVKgWKkSEYwP5jg5U+IbJ2e558FzfP3kLGOFHDfvG2d6ocKxcwvkc/VPeadmSsyXq2wdHmDHaIEdowV2jtWvt4/mKVZqpJQYHMiSywT7tg5xzfYRrt0xwkih/nI/N1fm84fPUKzU2DlWH0I9O1fm6ydmOHpugcnpIgvlKmODOZ66fwfPvWkPH//qcf7mnmPcdf9pKtVU/+SZq38CHRrIMjSQJZ/L8Khtw+yZGGT7aIGrtw1TrSVy2SATwV33n+E9dx1haqHMtTtGuGb7CNfsGKGQy3B8aoETjd6SvRNDDOUzTC9U2D5SYHwox2yxwkyxSjZT7/2amq8wtVDmqq3DPPm67Vy17fzrYXK6yOHTcxw+XW/PM7MlvnZ8mpMzJeYbPSXn5sucnSst9ZyMDea47aotPOHqrVy9fZirt4+QjeC+EzOcmy8vDYNVa/W/94mhAaYWKtx7fJojp+eYK1WZawx1jjemBpyYKZKJIJupr1d41bZhrpgY5Nx8eamn8+R0cal3cGggy1A+x0g+y0Auw7HGp/mb9o4zU6xQqdWW2nyx3ccGc5yYLnJuvky5WmOmWO9B2j5aYK5U4eNfmeS+EzOcmqnP1xrOZ6nWEplMMD44UK/rjhH27xrl1GyJI6fneOhsfRj/zGyJ41MLjBRybBnOs3V4gC3DeVJKTE4VOTq1wMnpIiOFLBNDeUrVGmfn6sd460ie6xr/byq11BhWrFKpJh44M8dssUoikYlgtJBjbDDH+NAAN+we4weffPXS0OdPPet6FspVPn3fKf7uq5P1OU7AfKnK9EKZwYHs0t96NhPsmRikXK0xNjjA/p2jFAYy9WNXTcw0hoUrtRoj+RwEVKqp/rppDAFevb3+txVR///71WNTBMGZuRKHJmeYnC4yNFAfRr/1ygke/6gtPHrnKIO5LP9wcJIPHzjGzEKl0ZNYJRtR7+GeLXF6tsh8qcbj9o1z9fb6MR/IBqVKjVK1PrVjKJ/l6Ll5jpye59x8mYFsUBjIMpjLMpTPsG/LcH0ax0CGB87Mc+32EQaywZcePEelVp8SkstmoDGlYO/EIE/dv4NvnJzlgTNz3LB7jEfvHOXBs/P83VeOc3q2zMRQjp1jg8wUy5ydK3N2vsxDZ+e5evsIt145wbdeu+2Coej/5zv2c3auxD9//TSlao2BTDBcyPGobcPMlSpMzVeYLVaYLdXD32P2jDE0kGXfliFOzZYYymf5ykNTfPLeE5yZK7NlaIDDjeH0xf+1A9l6R8ODZ+dJCXaM5dk7McSVW4fYPT5IuVLjzFz9NZyg3jOd6te1xt/nTLHC7vF6L9xiD3/9un579/ggt101QS6b4ZrtF06x6Lde9JjdAxxPKT1r2fabgAPAT6SU/nCFx+4Cdi7bfB1w5yOhx0yPTOVqbcX5EymlRtjZPPMhLmWlSo25UoWJoYG256tIUiubscdsCGg1WL3QdP9K7gBe2/EaSZvYapNQI4Jc1gDRKflchnzu4V+WkaR+6UUwmwdafS1osOn+lbwVeO+ybdcBd3agXpIkSZtKL4LZUWBfi+17G9cPrfTAlNIkMNm8zeEGSZJ0uerFRJUvAjdExPiy7U9qul+SJOkRrxfB7H1AFvixxQ0RUQD+M/CZ9SyVIUmSdDnr+lBmSukzEfFe4Nca37I8BPwwcA3wI93evyRJ0qWiV6dk+iHgV4EfBLYCdwMvSCl9skf7lyRJ2vR6EsxSSgvAzzUukiRJasFVKiVJkjYJg5kkSdImYTCTJEnaJAxmkiRJm4TBTJIkaZPo1XIZnZQHOHToUL/rIUmStKqmvJJfS/lIKXWvNl0QES/Ek5hLkqRLy4tSSh+4WKFLMZhNAM8AjgClLu3mOurh70XAfV3ah9bPdtl8bJPNyXbZfGyTzakX7ZIHrgL+IaV07mKFL7mhzMYvddHE2Y6IWLx5X0rpQDf3pbWzXTYf22Rzsl02H9tkc+phu3xhrQWd/C9JkrRJGMwkSZI2CYOZJEnSJmEwa+0E8LrGtTYP22XzsU02J9tl87FNNqdN1y6X3LcyJUmSLlf2mEmSJG0SBjNJkqRNwmAmSZK0SRjMJEmSNgmDmSRJ0iZhMGsSEYWI+I2IeCgi5iPiMxHxnH7X63ITEd8aEW+OiAMRMRsRhyPiPRFxQ4uyN0bEhyNiJiJOR8SfR8TOFuUyEfH/RcQ3ImIhIu6OiP/Um9/o8hQR/zUiUkTc0+K+p0TE/42IuYg4FhFviojRFuV8TXVARPybiPhA4zUwFxH3RMRPLStjm/RQRFwfEe+KiAcax/yrEfGaiBheVs526YKIGI2I1zXeH043/le9fIWyHX8fWetzbkhKyUvjArwTKAO/CfwY8KnGz0/rd90upwvwPuAo8CbgFcAvAceAGeCWpnJXUl9b5hDwU8CrgdPAF4H8suf8NSABbwN+FPhg4+f/2O/f91K8NI79bKNN7ll2323APPB54CeA/w4sAH/T4nl8TbXfFs8FisA/Az/d+Pv+deANtknf2uQq4AxwP/ALjeP49sb/nDttl560wTWN4/1N4BON2y9vUa7j7yPrec4N/W79Prib5QI8sdEAr2raNtg48J/qd/0upwvwlBYviOsb/7De0bTtrcAc8Kimbc9utNOPNW3bB5SANzdtC+CTwBEg2+/f+VK7AO8CPg78PQ8PZn8NPASMN217RaNdntu0zddU++0wTv1Dy18AmVXK2Sa9bZdXN47jzcu2/2lj+1bbpettUAD2NG7fzsrBrOPvI2t9zo1eHMo878VAlXpSBiCltAD8MfDkiLiqXxW73KSUPpVSKi3bdi9wALixafP3Ah9MKR1uKvcx4CDwfU3lXgQMUH+xLJZLwB9Q/2Tz5E7/DpeziHg69dfDf2lx3zjwHOoBeqrprj+j3rvW3C6+ptr3UmA38F9TSrWIGImIC/5v2yZ9Md64Pr5s+1GgBpRsl+5KKRVTSsfWULQb7yNrfc4NMZid93jg4LIXEMBnG9e39bY6jywREdTfgE42ft4H7ALualH8s9Tba9HjqQ+7faVFOZaV1SoiIgv8PvC/UkpfalHkcUCOZe3SCNpf5OHt4muqPc8GpoB9EfE16m/oUxHxBxEx2Chjm/Te3zeu/zgibouIqyLi+4GfBN6UUprFdum7bryPrPM5N8Rgdt5e6p92llvcdkUP6/JI9APUu5Lf3fh5b+N6pTbZFhGFprLHG59ulpcD2249fgK4GvjlFe6/WLtcsaysr6n2XE/9zf1O4G+pf1L/39Tb6e2NMrZJj6WUPkz9NfIc4AvAYerD/7+fUvrpRjHbpf+68T6ynufckFw7D77MDFGfYLvcQtP96oKIeCzwFuDT1OdowPnjfbE2KWLbdUREbAd+BfjVlNJKJ/S9WLsMLStru7RnFBgG/mdKafFbmH8REXngxyPiNdgm/XI/9flH7wdOAf8eeHVEHEspvRnbZTPoxvvIep5zQwxm581Tn0y43GDT/eqwiNgDfAg4B7w4pVRt3LV4vNfSJrZdZ/x36t8s+v1VylysXeaXlbVd2rN4jN65bPv/AX6c+ryXucY226RHIuI/Up8PdkNK6YHG5r9ozP/7jYh4J75WNoNuvI+s5zk3xKHM845yvouy2eK2h3pYl0eEiJgA/gbYAjw/pdR8jBe7iVdqk9MppWJT2T2NeWrLy4Ftd1ERcT31r+i/CbgiIq6JiGuo/6MZaPy8jYu3y/I29DXVnsVjtHyS+WTjeiu2ST/cAXyhKZQt+gD1Hs7HY7tsBt14H1nPc26Iwey8LwI3NL5J0+xJTferQxoTl/8KuAF4QUrpy833p5QepL5OzO0tHv5ELmyPL1L/Z3jjsnK23drto/7/4E3AN5ouT6LeRt8AXgPcA1RY1i6NobXbeHi7+Jpqz780rvct27443+UEtkk/7AayLbYPNK5z2C591433kXU+54YYzM57H/UX2o8tbmhM4PvPwGdSSkf6VbHLTeObf++mPgzzkpTSp1co+n7gBc1fFY+IZ1EPCu9tKncn9YUY72gqF9QnSD9IfaFGre4e4HtaXA5Qn9j8PcAfp5TOAR8DXhYRY02P/0Hq86Ga28XXVPve07j+kWXbX0H9Tf/vbZO+OAg8Ph5+tpL/RH25jLttl02jG+8ja33Ojen3InGb6UL9n2AZeAP1F8g/NX5+er/rdjldgN+jvhDfB4CXLb80lbuK+vIZh4D/F/hF6nOg7gYKy57zDY3n/EPqb1qLKza/tN+/76V8ofUCs/+G+iTX5tXM54G/bfF4X1Ptt8EfN/6W3039TeM9jZ9fb5v0rU2eTj0YH6f+7cw7qC8mm4A/sl161g6vpH7mmLc2jv37Gz//EjDRKNPx95H1POeGfq9+H9jNdKE+n+Y3qY8hL1Bfk+R5/a7X5XZpvNmnlS7Lyt5MfZmAWeqnQHkHsLvFc2YaL477qX8b5h7gB/r9u17qF1oEs8b2pzXeOOapz3d6MzDWopyvqfbbYAB4beNvuwTcC/wX26Tv7fLERhg72miXr1E/I0DOdulZG9y/ynvJNU3lOv4+stbn3MglGjuQJElSnznHTJIkaZMwmEmSJG0SBjNJkqRNwmAmSZK0SRjMJEmSNgmDmSRJ0iZhMJMkSdokDGaSJEmbhMFMkiRpkzCYSZIkbRIGM0mSpE3CYCZJkrRJGMwkSZI2CYOZJEnSJmEwkyRJ2iT+f7g0dWm49RxoAAAAAElFTkSuQmCC\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(target_distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efa59f5e-9f54-43ca-8287-835b5fac5dd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "if run_id != 0:\n",
    "    data_storage.write_losses(run_id, steps, losses, target_distances, database, user, password, host)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a86252a-e7ec-4982-acfb-4eb6e8b03c3c",
   "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
}
