{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:03.805400Z",
     "start_time": "2020-02-28T21:40:03.790222Z"
    }
   },
   "outputs": [],
   "source": [
    "import XXX.notebook\n",
    "\n",
    "import YYY\n",
    "\n",
    "from experiments.utils.jupyter import results_loader\n",
    "\n",
    "from experiments.utils.jupyter import plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.460035Z",
     "start_time": "2020-02-28T21:40:03.986606Z"
    }
   },
   "outputs": [],
   "source": [
    "store = results_loader.load_YYY_files(f'{XXX.notebook.original_dir}/YYY/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.477004Z",
     "start_time": "2020-02-28T21:40:04.461291Z"
    }
   },
   "outputs": [],
   "source": [
    "filtered_results = results_loader.filter_dict(store, v=lambda result: True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.493392Z",
     "start_time": "2020-02-28T21:40:04.478468Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(16, 16)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(filtered_results), len(store)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.509057Z",
     "start_time": "2020-02-28T21:40:04.494625Z"
    }
   },
   "outputs": [],
   "source": [
    "result= results_loader.get_any(filtered_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.646094Z",
     "start_time": "2020-02-28T21:40:04.617074Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "_config(seed=652, capacity=100, num_samples=8, cross_entropy_type='CrossEntropyType.decoder', train_batch_size=32, val_batch_size=256, epochs=100, log_interval=10, train_only=False)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result.config"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.768315Z",
     "start_time": "2020-02-28T21:40:04.754737Z"
    }
   },
   "outputs": [],
   "source": [
    "from dataclasses import dataclass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:04.943849Z",
     "start_time": "2020-02-28T21:40:04.917684Z"
    }
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:05.121130Z",
     "start_time": "2020-02-28T21:40:05.098473Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_epochs = min(len(result.log.test_epochs) for result in filtered_results.values())\n",
    "num_epochs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:05.399720Z",
     "start_time": "2020-02-28T21:40:05.349342Z"
    }
   },
   "outputs": [],
   "source": [
    "epoch_data = []\n",
    "\n",
    "for result in filtered_results.values():\n",
    "    if \"decoder_uncertainty\" in result.actual_name:\n",
    "        mode = \"decoder_uncertainty\"\n",
    "    elif \"prediction\" in result.config.cross_entropy_type:\n",
    "        mode = \"prediction\"\n",
    "    else:\n",
    "        mode = \"decoder\"\n",
    "        \n",
    "    for i, epoch in enumerate(result.log.training_epochs if mode != \"decoder_uncertainty\" else result.log.train_eval_epochs):\n",
    "        d = epoch._asdict()\n",
    "        d[\"mode\"] = mode\n",
    "        d['error'] = 1 - d['accuracy']\n",
    "        d['error_prob'] = 1 - d['correct_prob']\n",
    "        d['epoch'] = i\n",
    "        epoch_data.append(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:05.564958Z",
     "start_time": "2020-02-28T21:40:05.535753Z"
    }
   },
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:05.803635Z",
     "start_time": "2020-02-28T21:40:05.743919Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>accuracy</th>\n",
       "      <th>correct_prob</th>\n",
       "      <th>xe_decoder</th>\n",
       "      <th>xe_prediction</th>\n",
       "      <th>loss</th>\n",
       "      <th>mode</th>\n",
       "      <th>error</th>\n",
       "      <th>error_prob</th>\n",
       "      <th>epoch</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.241457</td>\n",
       "      <td>0.164503</td>\n",
       "      <td>1.991328</td>\n",
       "      <td>1.958802</td>\n",
       "      <td>1.991329</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.758543</td>\n",
       "      <td>0.835497</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.332166</td>\n",
       "      <td>0.214104</td>\n",
       "      <td>1.801052</td>\n",
       "      <td>1.759575</td>\n",
       "      <td>1.801052</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.667834</td>\n",
       "      <td>0.785896</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.412412</td>\n",
       "      <td>0.271621</td>\n",
       "      <td>1.631009</td>\n",
       "      <td>1.586926</td>\n",
       "      <td>1.631010</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.587588</td>\n",
       "      <td>0.728379</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.454425</td>\n",
       "      <td>0.309373</td>\n",
       "      <td>1.524600</td>\n",
       "      <td>1.479717</td>\n",
       "      <td>1.524600</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.545575</td>\n",
       "      <td>0.690627</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.498640</td>\n",
       "      <td>0.349272</td>\n",
       "      <td>1.423297</td>\n",
       "      <td>1.373211</td>\n",
       "      <td>1.423296</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.501360</td>\n",
       "      <td>0.650728</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1595</th>\n",
       "      <td>0.983235</td>\n",
       "      <td>0.947463</td>\n",
       "      <td>0.183243</td>\n",
       "      <td>0.129465</td>\n",
       "      <td>0.183243</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.016765</td>\n",
       "      <td>0.052537</td>\n",
       "      <td>95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1596</th>\n",
       "      <td>0.982935</td>\n",
       "      <td>0.947200</td>\n",
       "      <td>0.183326</td>\n",
       "      <td>0.129710</td>\n",
       "      <td>0.183326</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.017065</td>\n",
       "      <td>0.052800</td>\n",
       "      <td>96</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1597</th>\n",
       "      <td>0.982554</td>\n",
       "      <td>0.947002</td>\n",
       "      <td>0.183945</td>\n",
       "      <td>0.129766</td>\n",
       "      <td>0.183945</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.017446</td>\n",
       "      <td>0.052998</td>\n",
       "      <td>97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1598</th>\n",
       "      <td>0.982995</td>\n",
       "      <td>0.947847</td>\n",
       "      <td>0.182320</td>\n",
       "      <td>0.128599</td>\n",
       "      <td>0.182320</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.017005</td>\n",
       "      <td>0.052153</td>\n",
       "      <td>98</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1599</th>\n",
       "      <td>0.983575</td>\n",
       "      <td>0.948294</td>\n",
       "      <td>0.180939</td>\n",
       "      <td>0.127259</td>\n",
       "      <td>0.180939</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0.016425</td>\n",
       "      <td>0.051706</td>\n",
       "      <td>99</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1600 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      accuracy  correct_prob  xe_decoder  xe_prediction      loss     mode  \\\n",
       "0     0.241457      0.164503    1.991328       1.958802  1.991329  decoder   \n",
       "1     0.332166      0.214104    1.801052       1.759575  1.801052  decoder   \n",
       "2     0.412412      0.271621    1.631009       1.586926  1.631010  decoder   \n",
       "3     0.454425      0.309373    1.524600       1.479717  1.524600  decoder   \n",
       "4     0.498640      0.349272    1.423297       1.373211  1.423296  decoder   \n",
       "...        ...           ...         ...            ...       ...      ...   \n",
       "1595  0.983235      0.947463    0.183243       0.129465  0.183243  decoder   \n",
       "1596  0.982935      0.947200    0.183326       0.129710  0.183326  decoder   \n",
       "1597  0.982554      0.947002    0.183945       0.129766  0.183945  decoder   \n",
       "1598  0.982995      0.947847    0.182320       0.128599  0.182320  decoder   \n",
       "1599  0.983575      0.948294    0.180939       0.127259  0.180939  decoder   \n",
       "\n",
       "         error  error_prob  epoch  \n",
       "0     0.758543    0.835497      0  \n",
       "1     0.667834    0.785896      1  \n",
       "2     0.587588    0.728379      2  \n",
       "3     0.545575    0.690627      3  \n",
       "4     0.501360    0.650728      4  \n",
       "...        ...         ...    ...  \n",
       "1595  0.016765    0.052537     95  \n",
       "1596  0.017065    0.052800     96  \n",
       "1597  0.017446    0.052998     97  \n",
       "1598  0.017005    0.052153     98  \n",
       "1599  0.016425    0.051706     99  \n",
       "\n",
       "[1600 rows x 9 columns]"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df=pd.DataFrame(epoch_data)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:05.993177Z",
     "start_time": "2020-02-28T21:40:05.950982Z"
    }
   },
   "outputs": [],
   "source": [
    "dfm = df.melt(id_vars=['epoch','mode'], value_vars=['error','error_prob','xe_decoder', 'xe_prediction'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:06.197142Z",
     "start_time": "2020-02-28T21:40:06.160891Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>epoch</th>\n",
       "      <th>mode</th>\n",
       "      <th>variable</th>\n",
       "      <th>value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.758543</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.667834</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.587588</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.545575</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.501360</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6395</th>\n",
       "      <td>95</td>\n",
       "      <td>decoder</td>\n",
       "      <td>xe_prediction</td>\n",
       "      <td>0.129465</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6396</th>\n",
       "      <td>96</td>\n",
       "      <td>decoder</td>\n",
       "      <td>xe_prediction</td>\n",
       "      <td>0.129710</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6397</th>\n",
       "      <td>97</td>\n",
       "      <td>decoder</td>\n",
       "      <td>xe_prediction</td>\n",
       "      <td>0.129766</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6398</th>\n",
       "      <td>98</td>\n",
       "      <td>decoder</td>\n",
       "      <td>xe_prediction</td>\n",
       "      <td>0.128599</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6399</th>\n",
       "      <td>99</td>\n",
       "      <td>decoder</td>\n",
       "      <td>xe_prediction</td>\n",
       "      <td>0.127259</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>6400 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      epoch     mode       variable     value\n",
       "0         0  decoder          error  0.758543\n",
       "1         1  decoder          error  0.667834\n",
       "2         2  decoder          error  0.587588\n",
       "3         3  decoder          error  0.545575\n",
       "4         4  decoder          error  0.501360\n",
       "...     ...      ...            ...       ...\n",
       "6395     95  decoder  xe_prediction  0.129465\n",
       "6396     96  decoder  xe_prediction  0.129710\n",
       "6397     97  decoder  xe_prediction  0.129766\n",
       "6398     98  decoder  xe_prediction  0.128599\n",
       "6399     99  decoder  xe_prediction  0.127259\n",
       "\n",
       "[6400 rows x 4 columns]"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:06.389005Z",
     "start_time": "2020-02-28T21:40:06.358436Z"
    }
   },
   "outputs": [],
   "source": [
    "import plotnine as pn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:06.576233Z",
     "start_time": "2020-02-28T21:40:06.549491Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array(['decoder', 'prediction'], dtype=object),\n",
       " array(['error', 'error_prob', 'xe_decoder', 'xe_prediction'], dtype=object))"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfm['mode'].unique(),  dfm['variable'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:06.786663Z",
     "start_time": "2020-02-28T21:40:06.748233Z"
    }
   },
   "outputs": [],
   "source": [
    "dfm['Objective'] = dfm['mode'].map({\n",
    "    'prediction': \"$H_\\\\Theta[Y|X]$\", # \"\\text{Prediction Cross-Entropy} \\min H_\\Theta[Y|X]\",\n",
    "    'decoder': \"$H_\\\\Theta[Y|Z]$\", # \"\\text{Decoder Cross-Entropy} \\min H_\\Theta[Y|Z]\",\n",
    "    'decoder_uncertainty': \"Decoder Uncertainty\"\n",
    "})\n",
    "\n",
    "dfm['Metric'] = dfm['variable'].map({\n",
    "    'discrete_decoder_uncertainty': '$H[Y|Z]$',\n",
    "    'error_prob': '$E_{\\hat{p}(x, y)} p(\\\\hat{y} \\\\neq y)$',\n",
    "    'xe_decoder': '$H_\\\\Theta[Y|Z]$',\n",
    "    'xe_prediction': '$H_\\\\Theta[Y|X]$',\n",
    "    'error': '$\\\\arg \\\\max$ error'\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:40:06.933786Z",
     "start_time": "2020-02-28T21:40:06.916471Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['error', 'error_prob', 'xe_decoder', 'xe_prediction'], dtype=object)"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfm.variable.unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-28T21:50:22.163274Z",
     "start_time": "2020-02-28T21:50:22.143197Z"
    }
   },
   "outputs": [],
   "source": [
    "from experiments.utils.jupyter import plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-01T19:59:43.723454Z",
     "start_time": "2020-03-01T19:59:40.844323Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 400x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<ggplot: (8738810798665)>"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = dfm[dfm.variable.isin(('error', 'xe_decoder', 'xe_prediction'))]\n",
    "#ata=dfm\n",
    "plot = (\n",
    "    pn.ggplot(\n",
    "        data,\n",
    "        pn.aes(\n",
    "            x='epoch',\n",
    "            y='value',\n",
    "            color='Metric',\n",
    "            fill='Metric',\n",
    "            linetype='Objective')) +\n",
    "    pn.stat_summary(fun_data='median_hilow',\n",
    "                    fun_args={'confidence_interval': 0.5},\n",
    "                    geom='smooth',\n",
    "                    alpha=0.25) + pn.xlim(0, 100) + pn.xlab(\"Epoch\") +\n",
    "    pn.ylab(\"\") \n",
    "    + pn.scale_y_log10() \n",
    "    + plots.p9_base_theme +\n",
    "    pn.theme(figure_size=(4, 4/1.6)))\n",
    "#              legend_position=(0.5, -0.2),\n",
    "#              legend_direction='horizontal', legend_title_align=\"center\"))\n",
    "plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-01T19:59:48.886211Z",
     "start_time": "2020-03-01T19:59:45.898717Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXX/anaconda3/envs/uib/lib/python3.7/site-packages/plotnine/ggplot.py:729: PlotnineWarning: Saving 4 x 2.5 in image.\n",
      "  from_inches(height, units), units), PlotnineWarning)\n",
      "/home/XXX/anaconda3/envs/uib/lib/python3.7/site-packages/plotnine/ggplot.py:730: PlotnineWarning: Filename: cifar10_bounds.pdf\n",
      "  warn('Filename: {}'.format(filename), PlotnineWarning)\n"
     ]
    }
   ],
   "source": [
    "plots.p9_save(plot, \"cifar10_bounds.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [
    "%pwd"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/home/XXX/PycharmProjects/entropy_distance_loss'"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.6"
  },
  "latex_envs": {
   "LaTeX_envs_menu_present": true,
   "autoclose": true,
   "autocomplete": true,
   "bibliofile": "biblio.bib",
   "cite_by": "apalike",
   "current_citInitial": 1,
   "eqLabelWithNumbers": true,
   "eqNumInitial": 1,
   "hotkeys": {
    "equation": "Ctrl-E",
    "itemize": "Ctrl-I"
   },
   "labels_anchors": false,
   "latex_user_defs": false,
   "report_style_numbering": false,
   "user_envs_cfg": false
  },
  "pycharm": {
   "stem_cell": {
    "cell_type": "raw",
    "source": [],
    "metadata": {
     "collapsed": false
    }
   }
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": false,
   "skip_h1_title": true,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}