{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:48.571270Z",
     "start_time": "2020-03-24T17:12:47.080614Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Switched to directory /home/XXX/PycharmProjects/entropy_distance_loss\n",
      "%load_ext autoreload\n",
      "%autoreload 2\n"
     ]
    }
   ],
   "source": [
    "import XXX.notebook\n",
    "\n",
    "import YYY\n",
    "\n",
    "import plotnine as pn\n",
    "\n",
    "from experiments.utils.jupyter import results_loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:49.900028Z",
     "start_time": "2020-03-24T17:12:49.874046Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/home/XXX/PycharmProjects/entropy_distance_loss'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%pwd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:51.129473Z",
     "start_time": "2020-03-24T17:12:51.073339Z"
    }
   },
   "outputs": [],
   "source": [
    "store = results_loader.load_YYY_files(f'{XXX.notebook.original_dir}/YYY/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:51.536523Z",
     "start_time": "2020-03-24T17:12:51.511890Z"
    }
   },
   "outputs": [],
   "source": [
    "filtered_results = results_loader.filter_dict(store, v=lambda result: len(result.log.test_epochs) == 20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:51.883518Z",
     "start_time": "2020-03-24T17:12:51.856433Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8, 8)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(filtered_results), len(store)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:52.256794Z",
     "start_time": "2020-03-24T17:12:52.231989Z"
    }
   },
   "outputs": [],
   "source": [
    "result= results_loader.get_any(filtered_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:52.594074Z",
     "start_time": "2020-03-24T17:12:52.567933Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "_config(seed=10, inject_noise=True, capacity=128, train_batch_size=128, val_batch_size=512, epochs=20, log_interval=10)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result.config"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:52.986686Z",
     "start_time": "2020-03-24T17:12:52.957710Z"
    }
   },
   "outputs": [],
   "source": [
    "from dataclasses import dataclass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:53.300599Z",
     "start_time": "2020-03-24T17:12:53.274252Z"
    }
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:53.617251Z",
     "start_time": "2020-03-24T17:12:53.592458Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "20"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:54.050501Z",
     "start_time": "2020-03-24T17:12:54.024441Z"
    }
   },
   "outputs": [],
   "source": [
    "epoch_data = []\n",
    "\n",
    "for result in filtered_results.values():\n",
    "    with_noise = result.config.inject_noise\n",
    "    \n",
    "    for i, epoch in enumerate(result.log.test_epochs):\n",
    "        d = epoch._asdict()\n",
    "        #d[\"with_noise\"] = \"Noise\" if with_noise else \"No Noise\"\n",
    "        d[\"with_noise\"] = with_noise\n",
    "\n",
    "        d['error'] = 1 - d['accuracy']\n",
    "        d['epoch'] = i\n",
    "        epoch_data.append(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:54.965772Z",
     "start_time": "2020-03-24T17:12:54.940950Z"
    }
   },
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:55.374377Z",
     "start_time": "2020-03-24T17:12:55.322354Z"
    }
   },
   "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>xe_decoder</th>\n",
       "      <th>xe_prediction</th>\n",
       "      <th>loss</th>\n",
       "      <th>iq_base</th>\n",
       "      <th>decoder_uncertainty</th>\n",
       "      <th>encoding_entropy</th>\n",
       "      <th>preserved_information</th>\n",
       "      <th>H_Z__X</th>\n",
       "      <th>H_Z__Y</th>\n",
       "      <th>H_Z</th>\n",
       "      <th>with_noise</th>\n",
       "      <th>error</th>\n",
       "      <th>epoch</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.9732</td>\n",
       "      <td>0.232690</td>\n",
       "      <td>0.138960</td>\n",
       "      <td>0.235305</td>\n",
       "      <td>(2.300848365067822, 182.26236816797743, 145.20...</td>\n",
       "      <td>-34.757645</td>\n",
       "      <td>182.262375</td>\n",
       "      <td>59.995811</td>\n",
       "      <td>122.266563</td>\n",
       "      <td>145.203888</td>\n",
       "      <td>182.262375</td>\n",
       "      <td>True</td>\n",
       "      <td>0.0268</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.9824</td>\n",
       "      <td>0.210177</td>\n",
       "      <td>0.121740</td>\n",
       "      <td>0.211959</td>\n",
       "      <td>(2.300848365067822, 135.9155703332094, 96.8541...</td>\n",
       "      <td>-36.760612</td>\n",
       "      <td>135.915573</td>\n",
       "      <td>59.466614</td>\n",
       "      <td>76.448959</td>\n",
       "      <td>96.854118</td>\n",
       "      <td>135.915573</td>\n",
       "      <td>True</td>\n",
       "      <td>0.0176</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.9820</td>\n",
       "      <td>0.251216</td>\n",
       "      <td>0.154849</td>\n",
       "      <td>0.252819</td>\n",
       "      <td>(2.300848365067822, 93.17645615799589, 58.7439...</td>\n",
       "      <td>-32.131607</td>\n",
       "      <td>93.176453</td>\n",
       "      <td>52.112843</td>\n",
       "      <td>41.063610</td>\n",
       "      <td>58.743996</td>\n",
       "      <td>93.176453</td>\n",
       "      <td>True</td>\n",
       "      <td>0.0180</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.9842</td>\n",
       "      <td>0.337059</td>\n",
       "      <td>0.226343</td>\n",
       "      <td>0.338478</td>\n",
       "      <td>(2.300848365067822, 57.72249473000787, 31.9634...</td>\n",
       "      <td>-23.458187</td>\n",
       "      <td>57.722496</td>\n",
       "      <td>40.910786</td>\n",
       "      <td>16.811710</td>\n",
       "      <td>31.963459</td>\n",
       "      <td>57.722496</td>\n",
       "      <td>True</td>\n",
       "      <td>0.0158</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.9818</td>\n",
       "      <td>0.479486</td>\n",
       "      <td>0.351666</td>\n",
       "      <td>0.480775</td>\n",
       "      <td>(2.300848365067822, 32.130346751698056, 15.813...</td>\n",
       "      <td>-14.015700</td>\n",
       "      <td>32.130348</td>\n",
       "      <td>29.711861</td>\n",
       "      <td>2.418488</td>\n",
       "      <td>15.813800</td>\n",
       "      <td>32.130348</td>\n",
       "      <td>True</td>\n",
       "      <td>0.0182</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>155</th>\n",
       "      <td>0.5730</td>\n",
       "      <td>2.217139</td>\n",
       "      <td>2.217078</td>\n",
       "      <td>2.217131</td>\n",
       "      <td>(2.300848365067822, -598.5207080677865, -657.0...</td>\n",
       "      <td>-56.217468</td>\n",
       "      <td>-598.520691</td>\n",
       "      <td>79.770996</td>\n",
       "      <td>-678.291687</td>\n",
       "      <td>-657.039001</td>\n",
       "      <td>-598.520691</td>\n",
       "      <td>False</td>\n",
       "      <td>0.4270</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>156</th>\n",
       "      <td>0.1385</td>\n",
       "      <td>2.243989</td>\n",
       "      <td>2.243961</td>\n",
       "      <td>2.243970</td>\n",
       "      <td>(2.300848365067822, -650.4133815438788, -708.9...</td>\n",
       "      <td>-56.280334</td>\n",
       "      <td>-650.413391</td>\n",
       "      <td>79.769470</td>\n",
       "      <td>-730.182861</td>\n",
       "      <td>-708.994568</td>\n",
       "      <td>-650.413391</td>\n",
       "      <td>False</td>\n",
       "      <td>0.8615</td>\n",
       "      <td>16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>157</th>\n",
       "      <td>0.1135</td>\n",
       "      <td>2.262394</td>\n",
       "      <td>2.262381</td>\n",
       "      <td>2.262366</td>\n",
       "      <td>(2.300848365067822, -702.3307454397459, -761.0...</td>\n",
       "      <td>-56.416565</td>\n",
       "      <td>-702.330750</td>\n",
       "      <td>79.893433</td>\n",
       "      <td>-782.224182</td>\n",
       "      <td>-761.048157</td>\n",
       "      <td>-702.330750</td>\n",
       "      <td>False</td>\n",
       "      <td>0.8865</td>\n",
       "      <td>17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>158</th>\n",
       "      <td>0.1135</td>\n",
       "      <td>2.274940</td>\n",
       "      <td>2.274934</td>\n",
       "      <td>2.274904</td>\n",
       "      <td>(2.300848365067822, -754.2387658425673, -812.8...</td>\n",
       "      <td>-56.331970</td>\n",
       "      <td>-754.238770</td>\n",
       "      <td>79.744934</td>\n",
       "      <td>-833.983704</td>\n",
       "      <td>-812.871582</td>\n",
       "      <td>-754.238770</td>\n",
       "      <td>False</td>\n",
       "      <td>0.8865</td>\n",
       "      <td>18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>159</th>\n",
       "      <td>0.1135</td>\n",
       "      <td>2.283449</td>\n",
       "      <td>2.283446</td>\n",
       "      <td>2.283409</td>\n",
       "      <td>(2.300848365067822, -806.1245290400041, -864.9...</td>\n",
       "      <td>-56.542725</td>\n",
       "      <td>-806.124512</td>\n",
       "      <td>80.037354</td>\n",
       "      <td>-886.161865</td>\n",
       "      <td>-864.968079</td>\n",
       "      <td>-806.124512</td>\n",
       "      <td>False</td>\n",
       "      <td>0.8865</td>\n",
       "      <td>19</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>160 rows × 14 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     accuracy  xe_decoder  xe_prediction      loss  \\\n",
       "0      0.9732    0.232690       0.138960  0.235305   \n",
       "1      0.9824    0.210177       0.121740  0.211959   \n",
       "2      0.9820    0.251216       0.154849  0.252819   \n",
       "3      0.9842    0.337059       0.226343  0.338478   \n",
       "4      0.9818    0.479486       0.351666  0.480775   \n",
       "..        ...         ...            ...       ...   \n",
       "155    0.5730    2.217139       2.217078  2.217131   \n",
       "156    0.1385    2.243989       2.243961  2.243970   \n",
       "157    0.1135    2.262394       2.262381  2.262366   \n",
       "158    0.1135    2.274940       2.274934  2.274904   \n",
       "159    0.1135    2.283449       2.283446  2.283409   \n",
       "\n",
       "                                               iq_base  decoder_uncertainty  \\\n",
       "0    (2.300848365067822, 182.26236816797743, 145.20...           -34.757645   \n",
       "1    (2.300848365067822, 135.9155703332094, 96.8541...           -36.760612   \n",
       "2    (2.300848365067822, 93.17645615799589, 58.7439...           -32.131607   \n",
       "3    (2.300848365067822, 57.72249473000787, 31.9634...           -23.458187   \n",
       "4    (2.300848365067822, 32.130346751698056, 15.813...           -14.015700   \n",
       "..                                                 ...                  ...   \n",
       "155  (2.300848365067822, -598.5207080677865, -657.0...           -56.217468   \n",
       "156  (2.300848365067822, -650.4133815438788, -708.9...           -56.280334   \n",
       "157  (2.300848365067822, -702.3307454397459, -761.0...           -56.416565   \n",
       "158  (2.300848365067822, -754.2387658425673, -812.8...           -56.331970   \n",
       "159  (2.300848365067822, -806.1245290400041, -864.9...           -56.542725   \n",
       "\n",
       "     encoding_entropy  preserved_information      H_Z__X      H_Z__Y  \\\n",
       "0          182.262375              59.995811  122.266563  145.203888   \n",
       "1          135.915573              59.466614   76.448959   96.854118   \n",
       "2           93.176453              52.112843   41.063610   58.743996   \n",
       "3           57.722496              40.910786   16.811710   31.963459   \n",
       "4           32.130348              29.711861    2.418488   15.813800   \n",
       "..                ...                    ...         ...         ...   \n",
       "155       -598.520691              79.770996 -678.291687 -657.039001   \n",
       "156       -650.413391              79.769470 -730.182861 -708.994568   \n",
       "157       -702.330750              79.893433 -782.224182 -761.048157   \n",
       "158       -754.238770              79.744934 -833.983704 -812.871582   \n",
       "159       -806.124512              80.037354 -886.161865 -864.968079   \n",
       "\n",
       "            H_Z  with_noise   error  epoch  \n",
       "0    182.262375        True  0.0268      0  \n",
       "1    135.915573        True  0.0176      1  \n",
       "2     93.176453        True  0.0180      2  \n",
       "3     57.722496        True  0.0158      3  \n",
       "4     32.130348        True  0.0182      4  \n",
       "..          ...         ...     ...    ...  \n",
       "155 -598.520691       False  0.4270     15  \n",
       "156 -650.413391       False  0.8615     16  \n",
       "157 -702.330750       False  0.8865     17  \n",
       "158 -754.238770       False  0.8865     18  \n",
       "159 -806.124512       False  0.8865     19  \n",
       "\n",
       "[160 rows x 14 columns]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df=pd.DataFrame(epoch_data)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:12:57.594764Z",
     "start_time": "2020-03-24T17:12:57.568321Z"
    }
   },
   "outputs": [],
   "source": [
    "import src.experiments.utils.jupyter.plots as plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import plotnine as p9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/XXX/anaconda3/envs/uib/lib/python3.7/site-packages/ipykernel_launcher.py:5: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame\n",
      "\n",
      "See the caveats in the documentation: http://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  \"\"\"\n"
     ]
    },
    {
     "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>with_noise</th>\n",
       "      <th>epoch</th>\n",
       "      <th>accuracy</th>\n",
       "      <th>xe_decoder</th>\n",
       "      <th>xe_prediction</th>\n",
       "      <th>loss</th>\n",
       "      <th>decoder_uncertainty</th>\n",
       "      <th>encoding_entropy</th>\n",
       "      <th>preserved_information</th>\n",
       "      <th>H_Z__X</th>\n",
       "      <th>H_Z__Y</th>\n",
       "      <th>H_Z</th>\n",
       "      <th>error</th>\n",
       "      <th>type</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>False</td>\n",
       "      <td>0</td>\n",
       "      <td>0.973100</td>\n",
       "      <td>0.230284</td>\n",
       "      <td>0.140500</td>\n",
       "      <td>0.232756</td>\n",
       "      <td>-37.736572</td>\n",
       "      <td>178.846161</td>\n",
       "      <td>64.630936</td>\n",
       "      <td>114.215225</td>\n",
       "      <td>138.808746</td>\n",
       "      <td>178.846161</td>\n",
       "      <td>0.026900</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>False</td>\n",
       "      <td>1</td>\n",
       "      <td>0.981525</td>\n",
       "      <td>0.206350</td>\n",
       "      <td>0.123421</td>\n",
       "      <td>0.207980</td>\n",
       "      <td>-44.221563</td>\n",
       "      <td>127.825447</td>\n",
       "      <td>70.358063</td>\n",
       "      <td>57.467384</td>\n",
       "      <td>81.303034</td>\n",
       "      <td>127.825447</td>\n",
       "      <td>0.018475</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>False</td>\n",
       "      <td>2</td>\n",
       "      <td>0.982450</td>\n",
       "      <td>0.239964</td>\n",
       "      <td>0.155067</td>\n",
       "      <td>0.241441</td>\n",
       "      <td>-47.412648</td>\n",
       "      <td>76.053646</td>\n",
       "      <td>72.973183</td>\n",
       "      <td>3.080464</td>\n",
       "      <td>26.340148</td>\n",
       "      <td>76.053646</td>\n",
       "      <td>0.017550</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>False</td>\n",
       "      <td>3</td>\n",
       "      <td>0.983875</td>\n",
       "      <td>0.310421</td>\n",
       "      <td>0.224380</td>\n",
       "      <td>0.311724</td>\n",
       "      <td>-49.612384</td>\n",
       "      <td>24.130811</td>\n",
       "      <td>74.629581</td>\n",
       "      <td>-50.498770</td>\n",
       "      <td>-27.782420</td>\n",
       "      <td>24.130811</td>\n",
       "      <td>0.016125</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>False</td>\n",
       "      <td>4</td>\n",
       "      <td>0.983375</td>\n",
       "      <td>0.425546</td>\n",
       "      <td>0.345137</td>\n",
       "      <td>0.426597</td>\n",
       "      <td>-51.098141</td>\n",
       "      <td>-27.862493</td>\n",
       "      <td>75.735922</td>\n",
       "      <td>-103.598413</td>\n",
       "      <td>-81.261482</td>\n",
       "      <td>-27.862493</td>\n",
       "      <td>0.016625</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>False</td>\n",
       "      <td>5</td>\n",
       "      <td>0.982775</td>\n",
       "      <td>0.597124</td>\n",
       "      <td>0.531012</td>\n",
       "      <td>0.598161</td>\n",
       "      <td>-52.400146</td>\n",
       "      <td>-79.745594</td>\n",
       "      <td>76.642429</td>\n",
       "      <td>-156.388023</td>\n",
       "      <td>-134.446590</td>\n",
       "      <td>-79.745594</td>\n",
       "      <td>0.017225</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>False</td>\n",
       "      <td>6</td>\n",
       "      <td>0.983000</td>\n",
       "      <td>0.824517</td>\n",
       "      <td>0.778544</td>\n",
       "      <td>0.825292</td>\n",
       "      <td>-53.541534</td>\n",
       "      <td>-131.720684</td>\n",
       "      <td>77.655697</td>\n",
       "      <td>-209.376381</td>\n",
       "      <td>-187.563061</td>\n",
       "      <td>-131.720684</td>\n",
       "      <td>0.017000</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>False</td>\n",
       "      <td>7</td>\n",
       "      <td>0.983325</td>\n",
       "      <td>1.090739</td>\n",
       "      <td>1.063766</td>\n",
       "      <td>1.091361</td>\n",
       "      <td>-54.161278</td>\n",
       "      <td>-183.624531</td>\n",
       "      <td>78.044262</td>\n",
       "      <td>-261.668793</td>\n",
       "      <td>-240.086651</td>\n",
       "      <td>-183.624531</td>\n",
       "      <td>0.016675</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>False</td>\n",
       "      <td>8</td>\n",
       "      <td>0.982825</td>\n",
       "      <td>1.357400</td>\n",
       "      <td>1.343530</td>\n",
       "      <td>1.357835</td>\n",
       "      <td>-54.799110</td>\n",
       "      <td>-235.609192</td>\n",
       "      <td>78.763054</td>\n",
       "      <td>-314.372246</td>\n",
       "      <td>-292.709145</td>\n",
       "      <td>-235.609192</td>\n",
       "      <td>0.017175</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>False</td>\n",
       "      <td>9</td>\n",
       "      <td>0.983275</td>\n",
       "      <td>1.594623</td>\n",
       "      <td>1.588050</td>\n",
       "      <td>1.594886</td>\n",
       "      <td>-55.039177</td>\n",
       "      <td>-287.460068</td>\n",
       "      <td>78.948372</td>\n",
       "      <td>-366.408440</td>\n",
       "      <td>-344.800087</td>\n",
       "      <td>-287.460068</td>\n",
       "      <td>0.016725</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>False</td>\n",
       "      <td>10</td>\n",
       "      <td>0.981825</td>\n",
       "      <td>1.787932</td>\n",
       "      <td>1.784885</td>\n",
       "      <td>1.788116</td>\n",
       "      <td>-55.260933</td>\n",
       "      <td>-339.340614</td>\n",
       "      <td>78.933304</td>\n",
       "      <td>-418.273918</td>\n",
       "      <td>-396.902390</td>\n",
       "      <td>-339.340614</td>\n",
       "      <td>0.018175</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>False</td>\n",
       "      <td>11</td>\n",
       "      <td>0.980475</td>\n",
       "      <td>1.936160</td>\n",
       "      <td>1.934766</td>\n",
       "      <td>1.936280</td>\n",
       "      <td>-55.618912</td>\n",
       "      <td>-391.277382</td>\n",
       "      <td>79.425163</td>\n",
       "      <td>-470.702545</td>\n",
       "      <td>-449.197136</td>\n",
       "      <td>-391.277382</td>\n",
       "      <td>0.019525</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>False</td>\n",
       "      <td>12</td>\n",
       "      <td>0.976475</td>\n",
       "      <td>2.045494</td>\n",
       "      <td>2.044856</td>\n",
       "      <td>2.045567</td>\n",
       "      <td>-55.648880</td>\n",
       "      <td>-443.153709</td>\n",
       "      <td>79.267448</td>\n",
       "      <td>-522.421158</td>\n",
       "      <td>-501.103432</td>\n",
       "      <td>-443.153709</td>\n",
       "      <td>0.023525</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>False</td>\n",
       "      <td>13</td>\n",
       "      <td>0.959625</td>\n",
       "      <td>2.123965</td>\n",
       "      <td>2.123674</td>\n",
       "      <td>2.124000</td>\n",
       "      <td>-55.857605</td>\n",
       "      <td>-495.058273</td>\n",
       "      <td>79.526352</td>\n",
       "      <td>-574.584625</td>\n",
       "      <td>-553.216721</td>\n",
       "      <td>-495.058273</td>\n",
       "      <td>0.040375</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>False</td>\n",
       "      <td>14</td>\n",
       "      <td>0.880300</td>\n",
       "      <td>2.179325</td>\n",
       "      <td>2.179192</td>\n",
       "      <td>2.179333</td>\n",
       "      <td>-55.925705</td>\n",
       "      <td>-546.922806</td>\n",
       "      <td>79.598846</td>\n",
       "      <td>-626.521652</td>\n",
       "      <td>-605.149353</td>\n",
       "      <td>-546.922806</td>\n",
       "      <td>0.119700</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>False</td>\n",
       "      <td>15</td>\n",
       "      <td>0.637300</td>\n",
       "      <td>2.217912</td>\n",
       "      <td>2.217851</td>\n",
       "      <td>2.217902</td>\n",
       "      <td>-55.976974</td>\n",
       "      <td>-598.834503</td>\n",
       "      <td>79.595352</td>\n",
       "      <td>-678.429855</td>\n",
       "      <td>-657.112320</td>\n",
       "      <td>-598.834503</td>\n",
       "      <td>0.362700</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>False</td>\n",
       "      <td>16</td>\n",
       "      <td>0.242550</td>\n",
       "      <td>2.244524</td>\n",
       "      <td>2.244496</td>\n",
       "      <td>2.244501</td>\n",
       "      <td>-56.033401</td>\n",
       "      <td>-650.724396</td>\n",
       "      <td>79.614456</td>\n",
       "      <td>-730.338852</td>\n",
       "      <td>-709.058640</td>\n",
       "      <td>-650.724396</td>\n",
       "      <td>0.757450</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>False</td>\n",
       "      <td>17</td>\n",
       "      <td>0.131800</td>\n",
       "      <td>2.262756</td>\n",
       "      <td>2.262744</td>\n",
       "      <td>2.262725</td>\n",
       "      <td>-56.188507</td>\n",
       "      <td>-702.638077</td>\n",
       "      <td>79.772308</td>\n",
       "      <td>-782.410385</td>\n",
       "      <td>-761.127426</td>\n",
       "      <td>-702.638077</td>\n",
       "      <td>0.868200</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>False</td>\n",
       "      <td>18</td>\n",
       "      <td>0.113500</td>\n",
       "      <td>2.275181</td>\n",
       "      <td>2.275175</td>\n",
       "      <td>2.275142</td>\n",
       "      <td>-56.135635</td>\n",
       "      <td>-754.550156</td>\n",
       "      <td>79.667755</td>\n",
       "      <td>-834.217911</td>\n",
       "      <td>-812.986633</td>\n",
       "      <td>-754.550156</td>\n",
       "      <td>0.886500</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>False</td>\n",
       "      <td>19</td>\n",
       "      <td>0.113500</td>\n",
       "      <td>2.283611</td>\n",
       "      <td>2.283609</td>\n",
       "      <td>2.283569</td>\n",
       "      <td>-56.266891</td>\n",
       "      <td>-806.446991</td>\n",
       "      <td>79.836853</td>\n",
       "      <td>-886.283844</td>\n",
       "      <td>-865.014725</td>\n",
       "      <td>-806.446991</td>\n",
       "      <td>0.886500</td>\n",
       "      <td>Without noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>True</td>\n",
       "      <td>0</td>\n",
       "      <td>0.973350</td>\n",
       "      <td>0.233929</td>\n",
       "      <td>0.140725</td>\n",
       "      <td>0.236290</td>\n",
       "      <td>-34.641075</td>\n",
       "      <td>182.781479</td>\n",
       "      <td>59.735247</td>\n",
       "      <td>123.046232</td>\n",
       "      <td>145.839561</td>\n",
       "      <td>182.781479</td>\n",
       "      <td>0.026650</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>True</td>\n",
       "      <td>1</td>\n",
       "      <td>0.982150</td>\n",
       "      <td>0.213051</td>\n",
       "      <td>0.124273</td>\n",
       "      <td>0.214608</td>\n",
       "      <td>-36.544308</td>\n",
       "      <td>136.149559</td>\n",
       "      <td>59.260471</td>\n",
       "      <td>76.889088</td>\n",
       "      <td>97.304409</td>\n",
       "      <td>136.149559</td>\n",
       "      <td>0.017850</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>True</td>\n",
       "      <td>2</td>\n",
       "      <td>0.982200</td>\n",
       "      <td>0.253600</td>\n",
       "      <td>0.157191</td>\n",
       "      <td>0.255057</td>\n",
       "      <td>-31.909614</td>\n",
       "      <td>93.349258</td>\n",
       "      <td>51.929509</td>\n",
       "      <td>41.419749</td>\n",
       "      <td>59.138795</td>\n",
       "      <td>93.349258</td>\n",
       "      <td>0.017800</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>True</td>\n",
       "      <td>3</td>\n",
       "      <td>0.983225</td>\n",
       "      <td>0.340322</td>\n",
       "      <td>0.229956</td>\n",
       "      <td>0.341627</td>\n",
       "      <td>-23.316122</td>\n",
       "      <td>57.897431</td>\n",
       "      <td>40.827903</td>\n",
       "      <td>17.069528</td>\n",
       "      <td>32.280459</td>\n",
       "      <td>57.897431</td>\n",
       "      <td>0.016775</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>True</td>\n",
       "      <td>4</td>\n",
       "      <td>0.982200</td>\n",
       "      <td>0.484464</td>\n",
       "      <td>0.357078</td>\n",
       "      <td>0.485544</td>\n",
       "      <td>-13.930679</td>\n",
       "      <td>32.262548</td>\n",
       "      <td>29.670310</td>\n",
       "      <td>2.592238</td>\n",
       "      <td>16.031022</td>\n",
       "      <td>32.262548</td>\n",
       "      <td>0.017800</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>True</td>\n",
       "      <td>5</td>\n",
       "      <td>0.981450</td>\n",
       "      <td>0.710757</td>\n",
       "      <td>0.560770</td>\n",
       "      <td>0.711730</td>\n",
       "      <td>-6.609158</td>\n",
       "      <td>16.403281</td>\n",
       "      <td>21.352001</td>\n",
       "      <td>-4.948720</td>\n",
       "      <td>7.493275</td>\n",
       "      <td>16.403281</td>\n",
       "      <td>0.018550</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>True</td>\n",
       "      <td>6</td>\n",
       "      <td>0.979325</td>\n",
       "      <td>1.012134</td>\n",
       "      <td>0.837112</td>\n",
       "      <td>1.012760</td>\n",
       "      <td>-2.145827</td>\n",
       "      <td>7.824529</td>\n",
       "      <td>16.400364</td>\n",
       "      <td>-8.575835</td>\n",
       "      <td>3.377853</td>\n",
       "      <td>7.824529</td>\n",
       "      <td>0.020675</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>True</td>\n",
       "      <td>7</td>\n",
       "      <td>0.975100</td>\n",
       "      <td>1.350952</td>\n",
       "      <td>1.152996</td>\n",
       "      <td>1.351399</td>\n",
       "      <td>0.201467</td>\n",
       "      <td>3.604343</td>\n",
       "      <td>13.828548</td>\n",
       "      <td>-10.224205</td>\n",
       "      <td>1.504962</td>\n",
       "      <td>3.604343</td>\n",
       "      <td>0.024900</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>True</td>\n",
       "      <td>8</td>\n",
       "      <td>0.956925</td>\n",
       "      <td>1.671349</td>\n",
       "      <td>1.457836</td>\n",
       "      <td>1.671604</td>\n",
       "      <td>1.334385</td>\n",
       "      <td>1.629236</td>\n",
       "      <td>12.596561</td>\n",
       "      <td>-10.967325</td>\n",
       "      <td>0.662772</td>\n",
       "      <td>1.629236</td>\n",
       "      <td>0.043075</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>True</td>\n",
       "      <td>9</td>\n",
       "      <td>0.888800</td>\n",
       "      <td>1.932924</td>\n",
       "      <td>1.714802</td>\n",
       "      <td>1.932987</td>\n",
       "      <td>1.859013</td>\n",
       "      <td>0.733252</td>\n",
       "      <td>12.029120</td>\n",
       "      <td>-11.295868</td>\n",
       "      <td>0.291417</td>\n",
       "      <td>0.733252</td>\n",
       "      <td>0.111200</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>True</td>\n",
       "      <td>10</td>\n",
       "      <td>0.712950</td>\n",
       "      <td>2.123595</td>\n",
       "      <td>1.912094</td>\n",
       "      <td>2.123575</td>\n",
       "      <td>2.097053</td>\n",
       "      <td>0.329717</td>\n",
       "      <td>11.771841</td>\n",
       "      <td>-11.442124</td>\n",
       "      <td>0.125921</td>\n",
       "      <td>0.329717</td>\n",
       "      <td>0.287050</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>True</td>\n",
       "      <td>11</td>\n",
       "      <td>0.498325</td>\n",
       "      <td>2.248591</td>\n",
       "      <td>2.053100</td>\n",
       "      <td>2.248517</td>\n",
       "      <td>2.204106</td>\n",
       "      <td>0.149322</td>\n",
       "      <td>11.656348</td>\n",
       "      <td>-11.507026</td>\n",
       "      <td>0.052579</td>\n",
       "      <td>0.149322</td>\n",
       "      <td>0.501675</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>True</td>\n",
       "      <td>12</td>\n",
       "      <td>0.342775</td>\n",
       "      <td>2.321796</td>\n",
       "      <td>2.148343</td>\n",
       "      <td>2.321691</td>\n",
       "      <td>2.252101</td>\n",
       "      <td>0.069028</td>\n",
       "      <td>11.604698</td>\n",
       "      <td>-11.535671</td>\n",
       "      <td>0.020280</td>\n",
       "      <td>0.069028</td>\n",
       "      <td>0.657225</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>True</td>\n",
       "      <td>13</td>\n",
       "      <td>0.245825</td>\n",
       "      <td>2.358947</td>\n",
       "      <td>2.209851</td>\n",
       "      <td>2.358829</td>\n",
       "      <td>2.273547</td>\n",
       "      <td>0.033178</td>\n",
       "      <td>11.581594</td>\n",
       "      <td>-11.548416</td>\n",
       "      <td>0.005876</td>\n",
       "      <td>0.033178</td>\n",
       "      <td>0.754175</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>True</td>\n",
       "      <td>14</td>\n",
       "      <td>0.191100</td>\n",
       "      <td>2.373240</td>\n",
       "      <td>2.248153</td>\n",
       "      <td>2.373117</td>\n",
       "      <td>2.283141</td>\n",
       "      <td>0.017231</td>\n",
       "      <td>11.571282</td>\n",
       "      <td>-11.554051</td>\n",
       "      <td>-0.000476</td>\n",
       "      <td>0.017231</td>\n",
       "      <td>0.808900</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>True</td>\n",
       "      <td>15</td>\n",
       "      <td>0.158650</td>\n",
       "      <td>2.374302</td>\n",
       "      <td>2.271365</td>\n",
       "      <td>2.374181</td>\n",
       "      <td>2.287434</td>\n",
       "      <td>0.010107</td>\n",
       "      <td>11.566662</td>\n",
       "      <td>-11.556555</td>\n",
       "      <td>-0.003308</td>\n",
       "      <td>0.010107</td>\n",
       "      <td>0.841350</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>True</td>\n",
       "      <td>16</td>\n",
       "      <td>0.138250</td>\n",
       "      <td>2.368515</td>\n",
       "      <td>2.285050</td>\n",
       "      <td>2.368400</td>\n",
       "      <td>2.289355</td>\n",
       "      <td>0.006921</td>\n",
       "      <td>11.564591</td>\n",
       "      <td>-11.557670</td>\n",
       "      <td>-0.004572</td>\n",
       "      <td>0.006921</td>\n",
       "      <td>0.861750</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>True</td>\n",
       "      <td>17</td>\n",
       "      <td>0.126450</td>\n",
       "      <td>2.359746</td>\n",
       "      <td>2.292933</td>\n",
       "      <td>2.359635</td>\n",
       "      <td>2.290220</td>\n",
       "      <td>0.005495</td>\n",
       "      <td>11.563658</td>\n",
       "      <td>-11.558163</td>\n",
       "      <td>-0.005134</td>\n",
       "      <td>0.005495</td>\n",
       "      <td>0.873550</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>True</td>\n",
       "      <td>18</td>\n",
       "      <td>0.118600</td>\n",
       "      <td>2.350253</td>\n",
       "      <td>2.297330</td>\n",
       "      <td>2.350145</td>\n",
       "      <td>2.290611</td>\n",
       "      <td>0.004853</td>\n",
       "      <td>11.563237</td>\n",
       "      <td>-11.558384</td>\n",
       "      <td>-0.005385</td>\n",
       "      <td>0.004853</td>\n",
       "      <td>0.881400</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>True</td>\n",
       "      <td>19</td>\n",
       "      <td>0.114975</td>\n",
       "      <td>2.341241</td>\n",
       "      <td>2.299686</td>\n",
       "      <td>2.341137</td>\n",
       "      <td>2.290788</td>\n",
       "      <td>0.004563</td>\n",
       "      <td>11.563046</td>\n",
       "      <td>-11.558483</td>\n",
       "      <td>-0.005498</td>\n",
       "      <td>0.004563</td>\n",
       "      <td>0.885025</td>\n",
       "      <td>With noise</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    with_noise  epoch  accuracy  xe_decoder  xe_prediction      loss  \\\n",
       "0        False      0  0.973100    0.230284       0.140500  0.232756   \n",
       "1        False      1  0.981525    0.206350       0.123421  0.207980   \n",
       "2        False      2  0.982450    0.239964       0.155067  0.241441   \n",
       "3        False      3  0.983875    0.310421       0.224380  0.311724   \n",
       "4        False      4  0.983375    0.425546       0.345137  0.426597   \n",
       "5        False      5  0.982775    0.597124       0.531012  0.598161   \n",
       "6        False      6  0.983000    0.824517       0.778544  0.825292   \n",
       "7        False      7  0.983325    1.090739       1.063766  1.091361   \n",
       "8        False      8  0.982825    1.357400       1.343530  1.357835   \n",
       "9        False      9  0.983275    1.594623       1.588050  1.594886   \n",
       "10       False     10  0.981825    1.787932       1.784885  1.788116   \n",
       "11       False     11  0.980475    1.936160       1.934766  1.936280   \n",
       "12       False     12  0.976475    2.045494       2.044856  2.045567   \n",
       "13       False     13  0.959625    2.123965       2.123674  2.124000   \n",
       "14       False     14  0.880300    2.179325       2.179192  2.179333   \n",
       "15       False     15  0.637300    2.217912       2.217851  2.217902   \n",
       "16       False     16  0.242550    2.244524       2.244496  2.244501   \n",
       "17       False     17  0.131800    2.262756       2.262744  2.262725   \n",
       "18       False     18  0.113500    2.275181       2.275175  2.275142   \n",
       "19       False     19  0.113500    2.283611       2.283609  2.283569   \n",
       "20        True      0  0.973350    0.233929       0.140725  0.236290   \n",
       "21        True      1  0.982150    0.213051       0.124273  0.214608   \n",
       "22        True      2  0.982200    0.253600       0.157191  0.255057   \n",
       "23        True      3  0.983225    0.340322       0.229956  0.341627   \n",
       "24        True      4  0.982200    0.484464       0.357078  0.485544   \n",
       "25        True      5  0.981450    0.710757       0.560770  0.711730   \n",
       "26        True      6  0.979325    1.012134       0.837112  1.012760   \n",
       "27        True      7  0.975100    1.350952       1.152996  1.351399   \n",
       "28        True      8  0.956925    1.671349       1.457836  1.671604   \n",
       "29        True      9  0.888800    1.932924       1.714802  1.932987   \n",
       "30        True     10  0.712950    2.123595       1.912094  2.123575   \n",
       "31        True     11  0.498325    2.248591       2.053100  2.248517   \n",
       "32        True     12  0.342775    2.321796       2.148343  2.321691   \n",
       "33        True     13  0.245825    2.358947       2.209851  2.358829   \n",
       "34        True     14  0.191100    2.373240       2.248153  2.373117   \n",
       "35        True     15  0.158650    2.374302       2.271365  2.374181   \n",
       "36        True     16  0.138250    2.368515       2.285050  2.368400   \n",
       "37        True     17  0.126450    2.359746       2.292933  2.359635   \n",
       "38        True     18  0.118600    2.350253       2.297330  2.350145   \n",
       "39        True     19  0.114975    2.341241       2.299686  2.341137   \n",
       "\n",
       "    decoder_uncertainty  encoding_entropy  preserved_information      H_Z__X  \\\n",
       "0            -37.736572        178.846161              64.630936  114.215225   \n",
       "1            -44.221563        127.825447              70.358063   57.467384   \n",
       "2            -47.412648         76.053646              72.973183    3.080464   \n",
       "3            -49.612384         24.130811              74.629581  -50.498770   \n",
       "4            -51.098141        -27.862493              75.735922 -103.598413   \n",
       "5            -52.400146        -79.745594              76.642429 -156.388023   \n",
       "6            -53.541534       -131.720684              77.655697 -209.376381   \n",
       "7            -54.161278       -183.624531              78.044262 -261.668793   \n",
       "8            -54.799110       -235.609192              78.763054 -314.372246   \n",
       "9            -55.039177       -287.460068              78.948372 -366.408440   \n",
       "10           -55.260933       -339.340614              78.933304 -418.273918   \n",
       "11           -55.618912       -391.277382              79.425163 -470.702545   \n",
       "12           -55.648880       -443.153709              79.267448 -522.421158   \n",
       "13           -55.857605       -495.058273              79.526352 -574.584625   \n",
       "14           -55.925705       -546.922806              79.598846 -626.521652   \n",
       "15           -55.976974       -598.834503              79.595352 -678.429855   \n",
       "16           -56.033401       -650.724396              79.614456 -730.338852   \n",
       "17           -56.188507       -702.638077              79.772308 -782.410385   \n",
       "18           -56.135635       -754.550156              79.667755 -834.217911   \n",
       "19           -56.266891       -806.446991              79.836853 -886.283844   \n",
       "20           -34.641075        182.781479              59.735247  123.046232   \n",
       "21           -36.544308        136.149559              59.260471   76.889088   \n",
       "22           -31.909614         93.349258              51.929509   41.419749   \n",
       "23           -23.316122         57.897431              40.827903   17.069528   \n",
       "24           -13.930679         32.262548              29.670310    2.592238   \n",
       "25            -6.609158         16.403281              21.352001   -4.948720   \n",
       "26            -2.145827          7.824529              16.400364   -8.575835   \n",
       "27             0.201467          3.604343              13.828548  -10.224205   \n",
       "28             1.334385          1.629236              12.596561  -10.967325   \n",
       "29             1.859013          0.733252              12.029120  -11.295868   \n",
       "30             2.097053          0.329717              11.771841  -11.442124   \n",
       "31             2.204106          0.149322              11.656348  -11.507026   \n",
       "32             2.252101          0.069028              11.604698  -11.535671   \n",
       "33             2.273547          0.033178              11.581594  -11.548416   \n",
       "34             2.283141          0.017231              11.571282  -11.554051   \n",
       "35             2.287434          0.010107              11.566662  -11.556555   \n",
       "36             2.289355          0.006921              11.564591  -11.557670   \n",
       "37             2.290220          0.005495              11.563658  -11.558163   \n",
       "38             2.290611          0.004853              11.563237  -11.558384   \n",
       "39             2.290788          0.004563              11.563046  -11.558483   \n",
       "\n",
       "        H_Z__Y         H_Z     error           type  \n",
       "0   138.808746  178.846161  0.026900  Without noise  \n",
       "1    81.303034  127.825447  0.018475  Without noise  \n",
       "2    26.340148   76.053646  0.017550  Without noise  \n",
       "3   -27.782420   24.130811  0.016125  Without noise  \n",
       "4   -81.261482  -27.862493  0.016625  Without noise  \n",
       "5  -134.446590  -79.745594  0.017225  Without noise  \n",
       "6  -187.563061 -131.720684  0.017000  Without noise  \n",
       "7  -240.086651 -183.624531  0.016675  Without noise  \n",
       "8  -292.709145 -235.609192  0.017175  Without noise  \n",
       "9  -344.800087 -287.460068  0.016725  Without noise  \n",
       "10 -396.902390 -339.340614  0.018175  Without noise  \n",
       "11 -449.197136 -391.277382  0.019525  Without noise  \n",
       "12 -501.103432 -443.153709  0.023525  Without noise  \n",
       "13 -553.216721 -495.058273  0.040375  Without noise  \n",
       "14 -605.149353 -546.922806  0.119700  Without noise  \n",
       "15 -657.112320 -598.834503  0.362700  Without noise  \n",
       "16 -709.058640 -650.724396  0.757450  Without noise  \n",
       "17 -761.127426 -702.638077  0.868200  Without noise  \n",
       "18 -812.986633 -754.550156  0.886500  Without noise  \n",
       "19 -865.014725 -806.446991  0.886500  Without noise  \n",
       "20  145.839561  182.781479  0.026650     With noise  \n",
       "21   97.304409  136.149559  0.017850     With noise  \n",
       "22   59.138795   93.349258  0.017800     With noise  \n",
       "23   32.280459   57.897431  0.016775     With noise  \n",
       "24   16.031022   32.262548  0.017800     With noise  \n",
       "25    7.493275   16.403281  0.018550     With noise  \n",
       "26    3.377853    7.824529  0.020675     With noise  \n",
       "27    1.504962    3.604343  0.024900     With noise  \n",
       "28    0.662772    1.629236  0.043075     With noise  \n",
       "29    0.291417    0.733252  0.111200     With noise  \n",
       "30    0.125921    0.329717  0.287050     With noise  \n",
       "31    0.052579    0.149322  0.501675     With noise  \n",
       "32    0.020280    0.069028  0.657225     With noise  \n",
       "33    0.005876    0.033178  0.754175     With noise  \n",
       "34   -0.000476    0.017231  0.808900     With noise  \n",
       "35   -0.003308    0.010107  0.841350     With noise  \n",
       "36   -0.004572    0.006921  0.861750     With noise  \n",
       "37   -0.005134    0.005495  0.873550     With noise  \n",
       "38   -0.005385    0.004853  0.881400     With noise  \n",
       "39   -0.005498    0.004563  0.885025     With noise  "
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfm = df.groupby([\"with_noise\", \"epoch\"]).mean()\n",
    "dfm.reset_index(inplace=True)\n",
    "\n",
    "dfm[\"type\"] = \"Without noise\"\n",
    "dfm.type[dfm.with_noise] = \"With noise\"\n",
    "\n",
    "dfm[\"type\"] = pd.Categorical(dfm.type, [\"Without noise\", \"With noise\"])\n",
    "\n",
    "dfm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-02-26T15:19:22.485978Z",
     "start_time": "2020-02-26T15:19:22.457348Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 525x234.375 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.ticker import MaxNLocator\n",
    "from matplotlib import rc\n",
    "plt = plots.plt\n",
    "\n",
    "rc(\"text\", usetex=True)\n",
    "plt.style.use([\"seaborn\", \"seaborn-colorblind\", \"seaborn-paper\", \"seaborn-white\"])\n",
    "\n",
    "plot = p9.ggplot(dfm, p9.aes(x=\"H_Z\",y=\"error\", linetype=\"type\"))\n",
    "plot += p9.xlab(plots.label_H_Z)\n",
    "plot += p9.ylab(\"Training Error\")\n",
    "plot += p9.geom_line(color=plots.COLOR_PURPLE, size=1)\n",
    "plot += p9.theme(plot_margin=0, legend_box_margin=0, legend_box_just=\"left\", legend_margin=0,\n",
    "                 legend_text=p9.themes.element_text(va=\"bottom\"), legend_box=\"horizontal\")\n",
    "plot += p9.theme(legend_direction=\"horizontal\", legend_title_align=\"center\")\n",
    "plot += p9.theme(figure_size=(3.5, 2.5 / 1.6), dpi=150, legend_position=(0.45, 1.1))\n",
    "\n",
    "plot += p9.scale_x_continuous(breaks=[], minor_breaks=None)\n",
    "plot += p9.scale_linetype_discrete(guide=p9.guide_legend(\n",
    "                                              title=r\"\",\n",
    "                                              label=True,\n",
    "                                              direction='horizontal', label_position='right'))\n",
    "\n",
    "fig = plot.draw()\n",
    "\n",
    "ax1, = fig.axes\n",
    "\n",
    "#ax1.tick_params(axis='y', labelcolor=colorA)\n",
    "\n",
    "ax1.set_xscale('symlog', basex=10, linthreshx=1,linscalex=1,subsx=[1,5])\n",
    "ax1.set_xbound(-1024,256)\n",
    "#ax1.yaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "#ax1.set_ybound(0,0.9)\n",
    "\n",
    "\n",
    "#ax1.yaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "#ax1.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "#plots.p9_save(plot, \"entropy_minimization_and_noise.pdf\", dpi=300)\n",
    "\n",
    "plots.plt_save(\"plots/rendered/small_entropy_minimization_and_noise.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Old plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:14:34.656928Z",
     "start_time": "2020-03-24T17:14:33.554883Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 450x281.25 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "fig, ax2 = plt.subplots(figsize=(3,3/1.6),dpi=150)\n",
    "\n",
    "\n",
    "ax1 = ax2.twinx()  # instantiate a second axes that shares the same x-axis\n",
    "\n",
    "colorA = 'tab:red'\n",
    "\n",
    "ax1.set_ylabel('Error Rate', color=colorA)\n",
    "ax1.plot(range(20), noise_error[:,1], color=colorA)\n",
    "ax1.plot(range(20), noise_error[:,0], color=colorA)\n",
    "ax1.plot(range(20), noise_error[:,2], color=colorA)\n",
    "\n",
    "ax1.plot(range(20), no_noise_error[:,1], color=colorA, linestyle=\"--\")\n",
    "\n",
    "ax1.hlines(0.9,0,19,color=colorA,alpha=0.5,linestyle=\"dotted\")\n",
    "ax1.tick_params(axis='y', labelcolor=colorA)\n",
    "\n",
    "\n",
    "colorB = 'tab:blue'\n",
    "ax2.set_ylabel('H[Z]', color=colorB)  # we already handled the x-label with ax1\n",
    "ax2.plot(range(20), noise_H_Z[:,1], color=colorB)\n",
    "ax2.fill_between(range(20), noise_H_Z[:,0], noise_H_Z[:,2], color=colorB, alpha=0.25)\n",
    "\n",
    "ax2.plot(range(20), no_noise_H_Z[:,2], color=colorB, linestyle=\"--\")\n",
    "ax2.plot(range(20), no_noise_H_Z[:,1], color=colorB, linestyle=\"--\")\n",
    "ax2.plot(range(20), no_noise_H_Z[:,0], color=colorB, linestyle=\"--\")\n",
    "ax2.fill_between(range(20), no_noise_H_Z[:,0], no_noise_H_Z[:,2], color=colorB, alpha=0.25)\n",
    "\n",
    "ax2.tick_params(axis='y', labelcolor=colorB)\n",
    "\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "\n",
    "ax2.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "ax2.set_xlabel('Epoch')\n",
    "ax2.set_xlim(0,19)\n",
    "\n",
    "#ax2.set_ylim(0,1)\n",
    "#ax2.set_ylim(-200,200)\n",
    "ax2.grid(True)\n",
    "#ax1.grid(True)\n",
    "ax1.set_ybound(0,1)\n",
    "\n",
    "ax2.set_yscale('symlog', basey=2, linthreshy=1,linscaley=0.5,subsy=[1,5])\n",
    "ax2.set_ybound(-1024,256)\n",
    "\n",
    "from matplotlib.lines import Line2D\n",
    "custom_lines = [Line2D([0], [0], color=\"black\", linestyle=\"-\"),\n",
    "                Line2D([0], [0], color=\"black\", linestyle=\"--\")]\n",
    "\n",
    "ax2.legend(custom_lines, [\"With noise\", \"Without noise\"],  loc=\"upper center\")\n",
    "#fig.tight_layout()  # otherwise the right y-label is slightly clipped\n",
    "\n",
    "# We use the plot below now.\n",
    "#plots.plt_save(\"entropy_minimization_and_noise.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T17:45:10.772927Z",
     "start_time": "2020-03-24T17:45:10.192508Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 450x281.25 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "fig, ax1 = plt.subplots(figsize=(3,3/1.6),dpi=150)\n",
    "\n",
    "colorA = plots.COLOR_GREEN\n",
    "\n",
    "ax1.set_ylabel('Training Error', color=colorA)\n",
    "ax1.plot(noise_H_Z[:,1], noise_error[:,1], color=colorA)\n",
    "ax1.plot(no_noise_H_Z[:,1], no_noise_error[:,1], color=colorA, linestyle=\"--\")\n",
    "\n",
    "#ax1.hlines(0.9,-1e4,1e3,color=colorA,alpha=0.5,linestyle=\"dotted\")\n",
    "#ax1.tick_params(axis='y', labelcolor=colorA)\n",
    "\n",
    "\n",
    "# colorB = 'tab:blue'\n",
    "# ax2.set_ylabel('H[Z]', color=colorB)  # we already handled the x-label with ax1\n",
    "# ax2.plot(range(20), noise_H_Z[:,1], color=colorB)\n",
    "# ax2.fill_between(range(20), noise_H_Z[:,0], noise_H_Z[:,2], color=colorB, alpha=0.25)\n",
    "\n",
    "# ax2.plot(range(20), no_noise_H_Z[:,1], color=colorB, linestyle=\"--\")\n",
    "# ax2.fill_between(range(20), no_noise_H_Z[:,0], no_noise_H_Z[:,2], color=colorB, alpha=0.25)\n",
    "\n",
    "ax1.tick_params(axis='y', labelcolor=colorA)\n",
    "\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "\n",
    "ax1.yaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "#ax1.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "\n",
    "ax1.set_xlabel('$H[Z]$')\n",
    "\n",
    "#ax1.set_ylim(0,1)\n",
    "#ax1.set_ylim(-200,200)\n",
    "ax1.grid(True)\n",
    "ax1.grid(True)\n",
    "ax1.set_ybound(0,0.9)\n",
    "\n",
    "ax1.set_xscale('symlog', basex=10, linthreshx=1,linscalex=1,subsx=[1,5])\n",
    "ax1.set_xbound(-1024,256)\n",
    "\n",
    "from matplotlib.lines import Line2D\n",
    "custom_lines = [Line2D([0], [0], color=\"black\", linestyle=\"-\"),\n",
    "                Line2D([0], [0], color=\"black\", linestyle=\"--\")]\n",
    "\n",
    "ax1.legend(custom_lines, [\"With noise\", \"Without noise\"],  loc=\"upper left\")\n",
    "fig.tight_layout()  # otherwise the right y-label is slightly clipped\n",
    "\n",
    "# Set the borders to a given color...\n",
    "for ax in [ax1]:\n",
    "    #ax.tick_params(color='green', labelcolor='green')\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_edgecolor(\"lightgray\")\n",
    "        spine.set_linewidth(0.75)\n",
    "        \n",
    "\n",
    "\n",
    "#plots.plt_save(\"entropy_minimization_and_noise.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  }
 ],
 "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
  },
  "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
  },
  "varInspector": {
   "cols": {
    "lenName": 16,
    "lenType": 16,
    "lenVar": 40
   },
   "kernels_config": {
    "python": {
     "delete_cmd_postfix": "",
     "delete_cmd_prefix": "del ",
     "library": "var_list.py",
     "varRefreshCmd": "print(var_dic_list())"
    },
    "r": {
     "delete_cmd_postfix": ") ",
     "delete_cmd_prefix": "rm(",
     "library": "var_list.r",
     "varRefreshCmd": "cat(var_dic_list()) "
    }
   },
   "types_to_exclude": [
    "module",
    "function",
    "builtin_function_or_method",
    "instance",
    "_Feature"
   ],
   "window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
