{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy as sp\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams['text.usetex'] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tensorboard.backend.event_processing import event_accumulator\n",
    "\n",
    "def parse_tensorboard(path, scalar):\n",
    "    \"\"\"returns a dictionary of pandas dataframes for each requested scalar\"\"\"\n",
    "    ea = event_accumulator.EventAccumulator(\n",
    "        path,\n",
    "        size_guidance={event_accumulator.SCALARS: 0},\n",
    "    )\n",
    "    _absorb_print = ea.Reload()\n",
    "    return {'epoch': np.array([ea.Scalars(scalar)[i].step/7.0 for i in range(len(ea.Scalars(scalar)))]),\n",
    "            'value': np.array([ea.Scalars(scalar)[i].value for i in range(len(ea.Scalars(scalar)))])}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_case(path, scalar, n, color, doplot):\n",
    "    if doplot:\n",
    "        plt.figure(figsize=(4, 2), dpi=300)\n",
    "\n",
    "    meanres = {}\n",
    "\n",
    "    results = parse_tensorboard(f'{path}/version_0', scalar)\n",
    "    meanres['epoch'] = results['epoch']\n",
    "    meanres['value'] = results['value']/n\n",
    "\n",
    "    #if doplot:\n",
    "    plt.plot(results['epoch'], results['value'], color=color, alpha=0.05)#, label='Individual runs')\n",
    "\n",
    "    for i in range(1, n):\n",
    "        results = parse_tensorboard(f'{path}/version_{i}', scalar)\n",
    "        #if doplot:\n",
    "        plt.plot(results['epoch'], results['value'], color=color, alpha=0.05)\n",
    "        meanres['value'] += results['value']/n\n",
    "\n",
    "    if doplot:\n",
    "        plt.plot(meanres['epoch'], meanres['value'], color=color, alpha=1, label='Mean')\n",
    "        plt.xlabel('Epoch')\n",
    "        plt.ylabel(scalar)\n",
    "        plt.ylim([0.4, 1.0])\n",
    "        plt.yticks([0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "        #plt.title(f'{path}')\n",
    "        plt.grid()\n",
    "        plt.legend(loc='lower right')\n",
    "        plt.show()\n",
    "\n",
    "    return meanres"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "ename": "DirectoryDeletedError",
     "evalue": "Directory l20_dcont_lorenz_400_nan_0.3_0.01_19/version_0 has been permanently deleted",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNotFoundError\u001b[0m                             Traceback (most recent call last)",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/directory_watcher.py:88\u001b[0m, in \u001b[0;36mDirectoryWatcher.Load\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m     87\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m---> 88\u001b[0m     \u001b[39mfor\u001b[39;00m event \u001b[39min\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_LoadInternal():\n\u001b[1;32m     89\u001b[0m         \u001b[39myield\u001b[39;00m event\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/directory_watcher.py:110\u001b[0m, in \u001b[0;36mDirectoryWatcher._LoadInternal\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    109\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_loader:\n\u001b[0;32m--> 110\u001b[0m     \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_InitializeLoader()\n\u001b[1;32m    112\u001b[0m \u001b[39m# If it still doesn't exist, there is no data\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/directory_watcher.py:173\u001b[0m, in \u001b[0;36mDirectoryWatcher._InitializeLoader\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    172\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39m_InitializeLoader\u001b[39m(\u001b[39mself\u001b[39m):\n\u001b[0;32m--> 173\u001b[0m     path \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_GetNextPath()\n\u001b[1;32m    174\u001b[0m     \u001b[39mif\u001b[39;00m path:\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/directory_watcher.py:210\u001b[0m, in \u001b[0;36mDirectoryWatcher._GetNextPath\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    200\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Gets the next path to load from.\u001b[39;00m\n\u001b[1;32m    201\u001b[0m \n\u001b[1;32m    202\u001b[0m \u001b[39mThis function also does the checking for out-of-order writes as it iterates\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    206\u001b[0m \u001b[39m  The next path to load events from, or None if there are no more paths.\u001b[39;00m\n\u001b[1;32m    207\u001b[0m \u001b[39m\"\"\"\u001b[39;00m\n\u001b[1;32m    208\u001b[0m paths \u001b[39m=\u001b[39m \u001b[39msorted\u001b[39m(\n\u001b[1;32m    209\u001b[0m     path\n\u001b[0;32m--> 210\u001b[0m     \u001b[39mfor\u001b[39;00m path \u001b[39min\u001b[39;00m io_wrapper\u001b[39m.\u001b[39;49mListDirectoryAbsolute(\u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_directory)\n\u001b[1;32m    211\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_path_filter(path)\n\u001b[1;32m    212\u001b[0m )\n\u001b[1;32m    213\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m paths:\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/io_wrapper.py:78\u001b[0m, in \u001b[0;36mListDirectoryAbsolute\u001b[0;34m(directory)\u001b[0m\n\u001b[1;32m     73\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Yields all files in the given directory.\u001b[39;00m\n\u001b[1;32m     74\u001b[0m \n\u001b[1;32m     75\u001b[0m \u001b[39mThe paths are absolute.\u001b[39;00m\n\u001b[1;32m     76\u001b[0m \u001b[39m\"\"\"\u001b[39;00m\n\u001b[1;32m     77\u001b[0m \u001b[39mreturn\u001b[39;00m (\n\u001b[0;32m---> 78\u001b[0m     os\u001b[39m.\u001b[39mpath\u001b[39m.\u001b[39mjoin(directory, path) \u001b[39mfor\u001b[39;00m path \u001b[39min\u001b[39;00m tf\u001b[39m.\u001b[39;49mio\u001b[39m.\u001b[39;49mgfile\u001b[39m.\u001b[39;49mlistdir(directory)\n\u001b[1;32m     79\u001b[0m )\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/compat/tensorflow_stub/io/gfile.py:896\u001b[0m, in \u001b[0;36mlistdir\u001b[0;34m(dirname)\u001b[0m\n\u001b[1;32m    882\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Returns a list of entries contained within a directory.\u001b[39;00m\n\u001b[1;32m    883\u001b[0m \n\u001b[1;32m    884\u001b[0m \u001b[39mThe list is in arbitrary order. It does not contain the special entries \".\"\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    894\u001b[0m \u001b[39m  errors.NotFoundError if directory doesn't exist\u001b[39;00m\n\u001b[1;32m    895\u001b[0m \u001b[39m\"\"\"\u001b[39;00m\n\u001b[0;32m--> 896\u001b[0m \u001b[39mreturn\u001b[39;00m get_filesystem(dirname)\u001b[39m.\u001b[39;49mlistdir(dirname)\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/compat/tensorflow_stub/io/gfile.py:200\u001b[0m, in \u001b[0;36mLocalFileSystem.listdir\u001b[0;34m(self, dirname)\u001b[0m\n\u001b[1;32m    199\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39misdir(dirname):\n\u001b[0;32m--> 200\u001b[0m     \u001b[39mraise\u001b[39;00m errors\u001b[39m.\u001b[39mNotFoundError(\u001b[39mNone\u001b[39;00m, \u001b[39mNone\u001b[39;00m, \u001b[39m\"\u001b[39m\u001b[39mCould not find directory\u001b[39m\u001b[39m\"\u001b[39m)\n\u001b[1;32m    202\u001b[0m entries \u001b[39m=\u001b[39m os\u001b[39m.\u001b[39mlistdir(compat\u001b[39m.\u001b[39mas_str_any(dirname))\n",
      "\u001b[0;31mNotFoundError\u001b[0m: Could not find directory",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[0;31mDirectoryDeletedError\u001b[0m                     Traceback (most recent call last)",
      "\u001b[1;32m/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb Cell 4\u001b[0m line \u001b[0;36m1\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=5'>6</a>\u001b[0m     plt\u001b[39m.\u001b[39mfigure(figsize\u001b[39m=\u001b[39m(\u001b[39m4\u001b[39m, \u001b[39m2\u001b[39m), dpi\u001b[39m=\u001b[39m\u001b[39m600\u001b[39m)\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=7'>8</a>\u001b[0m \u001b[39mfor\u001b[39;00m lambda0, color, linetype \u001b[39min\u001b[39;00m \u001b[39mzip\u001b[39m([\u001b[39m'\u001b[39m\u001b[39mnan\u001b[39m\u001b[39m'\u001b[39m, \u001b[39m-\u001b[39m\u001b[39m10.0\u001b[39m], [\u001b[39m'\u001b[39m\u001b[39morange\u001b[39m\u001b[39m'\u001b[39m, \u001b[39m'\u001b[39m\u001b[39mgreen\u001b[39m\u001b[39m'\u001b[39m], [\u001b[39m'\u001b[39m\u001b[39m--\u001b[39m\u001b[39m'\u001b[39m, \u001b[39m'\u001b[39m\u001b[39m-\u001b[39m\u001b[39m'\u001b[39m]):\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=8'>9</a>\u001b[0m     \u001b[39m#meanres = plot_case(f'l30_dcont_mnist_200_{lambda0}_0.01_0.001_19', scalar, n, color, plot_each)\u001b[39;00m\n\u001b[0;32m---> <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=9'>10</a>\u001b[0m     meanres \u001b[39m=\u001b[39m plot_case(\u001b[39mf\u001b[39;49m\u001b[39m'\u001b[39;49m\u001b[39ml20_dcont_lorenz_400_\u001b[39;49m\u001b[39m{\u001b[39;49;00mlambda0\u001b[39m}\u001b[39;49;00m\u001b[39m_0.3_0.01_19\u001b[39;49m\u001b[39m'\u001b[39;49m, scalar, n, color, plot_each)\n\u001b[1;32m     <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=10'>11</a>\u001b[0m     \u001b[39m#meanres = plot_case(f'l5_dcont_predprey_400_{lambda0}_0.3_0.1_19', scalar, n, color, plot_each)\u001b[39;00m\n\u001b[1;32m     <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=11'>12</a>\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m plot_each:\n",
      "\u001b[1;32m/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb Cell 4\u001b[0m line \u001b[0;36m7\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=2'>3</a>\u001b[0m     plt\u001b[39m.\u001b[39mfigure(figsize\u001b[39m=\u001b[39m(\u001b[39m4\u001b[39m, \u001b[39m2\u001b[39m), dpi\u001b[39m=\u001b[39m\u001b[39m300\u001b[39m)\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=4'>5</a>\u001b[0m meanres \u001b[39m=\u001b[39m {}\n\u001b[0;32m----> <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=6'>7</a>\u001b[0m results \u001b[39m=\u001b[39m parse_tensorboard(\u001b[39mf\u001b[39;49m\u001b[39m'\u001b[39;49m\u001b[39m{\u001b[39;49;00mpath\u001b[39m}\u001b[39;49;00m\u001b[39m/version_0\u001b[39;49m\u001b[39m'\u001b[39;49m, scalar)\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=7'>8</a>\u001b[0m meanres[\u001b[39m'\u001b[39m\u001b[39mepoch\u001b[39m\u001b[39m'\u001b[39m] \u001b[39m=\u001b[39m results[\u001b[39m'\u001b[39m\u001b[39mepoch\u001b[39m\u001b[39m'\u001b[39m]\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=8'>9</a>\u001b[0m meanres[\u001b[39m'\u001b[39m\u001b[39mvalue\u001b[39m\u001b[39m'\u001b[39m] \u001b[39m=\u001b[39m results[\u001b[39m'\u001b[39m\u001b[39mvalue\u001b[39m\u001b[39m'\u001b[39m]\u001b[39m/\u001b[39mn\n",
      "\u001b[1;32m/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb Cell 4\u001b[0m line \u001b[0;36m9\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=3'>4</a>\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"returns a dictionary of pandas dataframes for each requested scalar\"\"\"\u001b[39;00m\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=4'>5</a>\u001b[0m ea \u001b[39m=\u001b[39m event_accumulator\u001b[39m.\u001b[39mEventAccumulator(\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=5'>6</a>\u001b[0m     path,\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=6'>7</a>\u001b[0m     size_guidance\u001b[39m=\u001b[39m{event_accumulator\u001b[39m.\u001b[39mSCALARS: \u001b[39m0\u001b[39m},\n\u001b[1;32m      <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=7'>8</a>\u001b[0m )\n\u001b[0;32m----> <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=8'>9</a>\u001b[0m _absorb_print \u001b[39m=\u001b[39m ea\u001b[39m.\u001b[39;49mReload()\n\u001b[1;32m     <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=9'>10</a>\u001b[0m \u001b[39mreturn\u001b[39;00m {\u001b[39m'\u001b[39m\u001b[39mepoch\u001b[39m\u001b[39m'\u001b[39m: np\u001b[39m.\u001b[39marray([ea\u001b[39m.\u001b[39mScalars(scalar)[i]\u001b[39m.\u001b[39mstep\u001b[39m/\u001b[39m\u001b[39m7.0\u001b[39m \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39mlen\u001b[39m(ea\u001b[39m.\u001b[39mScalars(scalar)))]),\n\u001b[1;32m     <a href='vscode-notebook-cell://ssh-remote%2B192.168.1.22/home/andrew/drive/gaussian-continuation/gc_plot_train.ipynb#W3sdnNjb2RlLXJlbW90ZQ%3D%3D?line=10'>11</a>\u001b[0m         \u001b[39m'\u001b[39m\u001b[39mvalue\u001b[39m\u001b[39m'\u001b[39m: np\u001b[39m.\u001b[39marray([ea\u001b[39m.\u001b[39mScalars(scalar)[i]\u001b[39m.\u001b[39mvalue \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39mlen\u001b[39m(ea\u001b[39m.\u001b[39mScalars(scalar)))])}\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/event_accumulator.py:343\u001b[0m, in \u001b[0;36mEventAccumulator.Reload\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    335\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Loads all events added since the last call to `Reload`.\u001b[39;00m\n\u001b[1;32m    336\u001b[0m \n\u001b[1;32m    337\u001b[0m \u001b[39mIf `Reload` was never called, loads all events in the file.\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    340\u001b[0m \u001b[39m  The `EventAccumulator`.\u001b[39;00m\n\u001b[1;32m    341\u001b[0m \u001b[39m\"\"\"\u001b[39;00m\n\u001b[1;32m    342\u001b[0m \u001b[39mwith\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_generator_mutex:\n\u001b[0;32m--> 343\u001b[0m     \u001b[39mfor\u001b[39;00m event \u001b[39min\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_generator\u001b[39m.\u001b[39mLoad():\n\u001b[1;32m    344\u001b[0m         \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_ProcessEvent(event)\n\u001b[1;32m    345\u001b[0m \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39m\n",
      "File \u001b[0;32m~/miniconda3/envs/gcenv/lib/python3.11/site-packages/tensorboard/backend/event_processing/directory_watcher.py:92\u001b[0m, in \u001b[0;36mDirectoryWatcher.Load\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m     90\u001b[0m \u001b[39mexcept\u001b[39;00m tf\u001b[39m.\u001b[39merrors\u001b[39m.\u001b[39mOpError:\n\u001b[1;32m     91\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m tf\u001b[39m.\u001b[39mio\u001b[39m.\u001b[39mgfile\u001b[39m.\u001b[39mexists(\u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_directory):\n\u001b[0;32m---> 92\u001b[0m         \u001b[39mraise\u001b[39;00m DirectoryDeletedError(\n\u001b[1;32m     93\u001b[0m             \u001b[39m\"\u001b[39m\u001b[39mDirectory \u001b[39m\u001b[39m%s\u001b[39;00m\u001b[39m has been permanently deleted\u001b[39m\u001b[39m\"\u001b[39m\n\u001b[1;32m     94\u001b[0m             \u001b[39m%\u001b[39m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_directory\n\u001b[1;32m     95\u001b[0m         )\n",
      "\u001b[0;31mDirectoryDeletedError\u001b[0m: Directory l20_dcont_lorenz_400_nan_0.3_0.01_19/version_0 has been permanently deleted"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 2400x1200 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_each = False\n",
    "scalar = 'val_loss'\n",
    "n = 5\n",
    "\n",
    "if not plot_each:\n",
    "    plt.figure(figsize=(4, 2), dpi=600)\n",
    "\n",
    "for lambda0, color, linetype in zip(['nan', -10.0], ['orange', 'green'], ['--', '-']):\n",
    "    #meanres = plot_case(f'l30_dcont_mnist_200_{lambda0}_0.01_0.001_19', scalar, n, color, plot_each)\n",
    "    meanres = plot_case(f'l20_dcont_lorenz_200_{lambda0}_0.3_0.01_19', scalar, n, color, plot_each)\n",
    "    #meanres = plot_case(f'l5_dcont_predprey_400_{lambda0}_0.3_0.1_19', scalar, n, color, plot_each)\n",
    "    if not plot_each:\n",
    "        if lambda0 == 'nan':\n",
    "            label = 'No continuation'\n",
    "        else:\n",
    "            label = 'With continuation'#f'$\\lambda_0 = \\exp({lambda0})$'\n",
    "        plt.plot(meanres['epoch'], meanres['value'], color=color, alpha=1, label=label, linestyle=linetype)\n",
    "\n",
    "if not plot_each:\n",
    "    plt.xlabel('Epoch')\n",
    "    plt.ylabel('MSE on test set')\n",
    "    #plt.ylim([0.4, 1.0])\n",
    "    #plt.yticks([0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "    plt.yscale('log')\n",
    "    plt.grid()\n",
    "    plt.legend(loc='best')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gcenv",
   "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.11.4"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
