{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:00.543717Z",
     "start_time": "2020-03-24T20:38:00.489316Z"
    }
   },
   "outputs": [],
   "source": [
    "import XXX.notebook"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:01.531646Z",
     "start_time": "2020-03-24T20:38:00.634401Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[0m\u001b[01;34mbaseline_cifar10\u001b[0m/              \u001b[01;34mdifferent_categorical_decoders\u001b[0m/\r\n",
      "\u001b[01;34mbaseline_permutation_mnist\u001b[0m/    \u001b[01;34mdvib_comparison\u001b[0m/\r\n",
      "\u001b[01;34mbounds_categorical_cifar10\u001b[0m/    \u001b[01;34mentropy_minimization_and_noise\u001b[0m/\r\n",
      "\u001b[01;34mbounds_categorical_mnist\u001b[0m/      \u001b[01;34mimagenet_measure_regularization\u001b[0m/\r\n",
      "\u001b[01;34mbounds_cifar10\u001b[0m/                __init__.py\r\n",
      "\u001b[01;34mbounds_mnist\u001b[0m/                  \u001b[01;34mkraskov_clustering\u001b[0m/\r\n",
      "categorical_bounds.ipynb       \u001b[01;34mmeasure_regularization\u001b[0m/\r\n",
      "\u001b[01;34mcategorical_cifar2x5\u001b[0m/          \u001b[01;34msurrogates\u001b[0m/\r\n",
      "\u001b[01;34mcifar10_resnet_beta_ib_plots\u001b[0m/  \u001b[01;34munused\u001b[0m/\r\n",
      "continuous_bounds.ipynb\r\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "from dataclasses import dataclass\n",
    "\n",
    "import statistics\n",
    "\n",
    "from XXX import YYY\n",
    "\n",
    "from experiments.utils.jupyter import results_loader\n",
    "\n",
    "%ls {XXX.notebook.original_dir}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:02.719121Z",
     "start_time": "2020-03-24T20:38:01.533602Z"
    }
   },
   "outputs": [],
   "source": [
    "mnist_store = results_loader.load_YYY_files(f'{XXX.notebook.original_dir}/bounds_categorical_mnist/results/')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Permutation MNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:02.733683Z",
     "start_time": "2020-03-24T20:38:02.721114Z"
    }
   },
   "outputs": [],
   "source": [
    "mnist_filtered_results = results_loader.filter_dict(mnist_store, v=lambda v: True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:02.754990Z",
     "start_time": "2020-03-24T20:38:02.735380Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "23"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(mnist_filtered_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:02.818277Z",
     "start_time": "2020-03-24T20:38:02.757180Z"
    }
   },
   "outputs": [],
   "source": [
    "epoch_data = []\n",
    "\n",
    "for ri, result in enumerate(mnist_filtered_results.values()):\n",
    "    if \"categorical\" in result.actual_name:\n",
    "        objective = \"decoder_uncertainty\"\n",
    "    elif 'prediction' in result.config.cross_entropy_type:\n",
    "        objective = \"prediction\"\n",
    "    else:\n",
    "        objective = \"decoder\"\n",
    "        \n",
    "    for source, epochs in ((\"test\", result.log.test_epochs), (\"train\", result.log.train_eval_epochs)):\n",
    "        for i, epoch in enumerate(epochs):\n",
    "            d = epoch._asdict()\n",
    "            d['error'] = 1 - d['accuracy']\n",
    "            d['error_p'] = 1 - d['correct_prob']\n",
    "            d['error_bound'] = 1 - np.exp(-d['discrete_decoder_uncertainty'])\n",
    "            d['epoch'] = i\n",
    "            d['objective'] = objective\n",
    "            d['experiment_index'] = ri\n",
    "            d['source'] = source\n",
    "            epoch_data.append(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:02.834828Z",
     "start_time": "2020-03-24T20:38:02.820391Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4600"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(epoch_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:03.002798Z",
     "start_time": "2020-03-24T20:38:02.836299Z"
    }
   },
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:03.071115Z",
     "start_time": "2020-03-24T20:38:03.005096Z"
    },
    "scrolled": false
   },
   "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_duration</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>discrete_iq_base</th>\n",
       "      <th>discrete_decoder_uncertainty</th>\n",
       "      <th>discrete_encoding_entropy</th>\n",
       "      <th>discrete_preserved_information</th>\n",
       "      <th>discrete_H_Z__X</th>\n",
       "      <th>discrete_H_Z__Y</th>\n",
       "      <th>discrete_H_Z</th>\n",
       "      <th>error</th>\n",
       "      <th>error_p</th>\n",
       "      <th>error_bound</th>\n",
       "      <th>epoch</th>\n",
       "      <th>objective</th>\n",
       "      <th>experiment_index</th>\n",
       "      <th>source</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.049738</td>\n",
       "      <td>0.468300</td>\n",
       "      <td>0.383687</td>\n",
       "      <td>1.217863</td>\n",
       "      <td>1.172554</td>\n",
       "      <td>1.217863</td>\n",
       "      <td>(2.300848365067822, 1.5341390542295583, 2.7274...</td>\n",
       "      <td>1.193319</td>\n",
       "      <td>1.534139</td>\n",
       "      <td>1.402055</td>\n",
       "      <td>1.320843e-01</td>\n",
       "      <td>0.426610</td>\n",
       "      <td>1.534139</td>\n",
       "      <td>0.531700</td>\n",
       "      <td>0.616313</td>\n",
       "      <td>0.696787</td>\n",
       "      <td>0</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.052037</td>\n",
       "      <td>0.664500</td>\n",
       "      <td>0.568396</td>\n",
       "      <td>0.844482</td>\n",
       "      <td>0.777716</td>\n",
       "      <td>0.844482</td>\n",
       "      <td>(2.300848365067822, 1.9826139146332251, 2.7987...</td>\n",
       "      <td>0.816143</td>\n",
       "      <td>1.982614</td>\n",
       "      <td>1.809810</td>\n",
       "      <td>1.728041e-01</td>\n",
       "      <td>0.497909</td>\n",
       "      <td>1.982614</td>\n",
       "      <td>0.335500</td>\n",
       "      <td>0.431604</td>\n",
       "      <td>0.557866</td>\n",
       "      <td>1</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.048158</td>\n",
       "      <td>0.787200</td>\n",
       "      <td>0.717080</td>\n",
       "      <td>0.559989</td>\n",
       "      <td>0.478152</td>\n",
       "      <td>0.559989</td>\n",
       "      <td>(2.300848365067822, 2.15482411296367, 2.690880...</td>\n",
       "      <td>0.536056</td>\n",
       "      <td>2.154824</td>\n",
       "      <td>2.053408</td>\n",
       "      <td>1.014161e-01</td>\n",
       "      <td>0.390032</td>\n",
       "      <td>2.154824</td>\n",
       "      <td>0.212800</td>\n",
       "      <td>0.282920</td>\n",
       "      <td>0.414949</td>\n",
       "      <td>2</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.052506</td>\n",
       "      <td>0.887500</td>\n",
       "      <td>0.832086</td>\n",
       "      <td>0.369972</td>\n",
       "      <td>0.298410</td>\n",
       "      <td>0.369972</td>\n",
       "      <td>(2.3008483650678224, 2.262912213567316, 2.6213...</td>\n",
       "      <td>0.358449</td>\n",
       "      <td>2.262912</td>\n",
       "      <td>2.191586</td>\n",
       "      <td>7.132585e-02</td>\n",
       "      <td>0.320513</td>\n",
       "      <td>2.262912</td>\n",
       "      <td>0.112500</td>\n",
       "      <td>0.167914</td>\n",
       "      <td>0.301241</td>\n",
       "      <td>3</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.047673</td>\n",
       "      <td>0.965800</td>\n",
       "      <td>0.922875</td>\n",
       "      <td>0.228660</td>\n",
       "      <td>0.158327</td>\n",
       "      <td>0.228660</td>\n",
       "      <td>(2.300848365067822, 2.340216427923633, 2.55862...</td>\n",
       "      <td>0.218414</td>\n",
       "      <td>2.340216</td>\n",
       "      <td>2.290210</td>\n",
       "      <td>5.000679e-02</td>\n",
       "      <td>0.257782</td>\n",
       "      <td>2.340216</td>\n",
       "      <td>0.034200</td>\n",
       "      <td>0.077125</td>\n",
       "      <td>0.196207</td>\n",
       "      <td>4</td>\n",
       "      <td>decoder</td>\n",
       "      <td>0</td>\n",
       "      <td>test</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4595</th>\n",
       "      <td>0.110032</td>\n",
       "      <td>0.318917</td>\n",
       "      <td>0.310612</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>(2.3011591727032914, 0.9198048918122748, 2.302...</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>2.704836e-07</td>\n",
       "      <td>0.001042</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.681083</td>\n",
       "      <td>0.689388</td>\n",
       "      <td>0.749024</td>\n",
       "      <td>95</td>\n",
       "      <td>prediction</td>\n",
       "      <td>22</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4596</th>\n",
       "      <td>0.162111</td>\n",
       "      <td>0.318917</td>\n",
       "      <td>0.310611</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>(2.3011591727032914, 0.9198048924270809, 2.302...</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>2.653818e-07</td>\n",
       "      <td>0.001042</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.681083</td>\n",
       "      <td>0.689389</td>\n",
       "      <td>0.749024</td>\n",
       "      <td>96</td>\n",
       "      <td>prediction</td>\n",
       "      <td>22</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4597</th>\n",
       "      <td>0.111560</td>\n",
       "      <td>0.318917</td>\n",
       "      <td>0.310612</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>(2.3011591727032914, 0.9198048918540283, 2.302...</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>2.598872e-07</td>\n",
       "      <td>0.001042</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.681083</td>\n",
       "      <td>0.689388</td>\n",
       "      <td>0.749024</td>\n",
       "      <td>97</td>\n",
       "      <td>prediction</td>\n",
       "      <td>22</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4598</th>\n",
       "      <td>0.107595</td>\n",
       "      <td>0.318917</td>\n",
       "      <td>0.310613</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>(2.3011591727032914, 0.9198048920132202, 2.302...</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>2.558313e-07</td>\n",
       "      <td>0.001042</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.681083</td>\n",
       "      <td>0.689387</td>\n",
       "      <td>0.749024</td>\n",
       "      <td>98</td>\n",
       "      <td>prediction</td>\n",
       "      <td>22</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4599</th>\n",
       "      <td>0.117936</td>\n",
       "      <td>0.318917</td>\n",
       "      <td>0.310612</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>(2.3011591727032914, 0.919804892124919, 2.3022...</td>\n",
       "      <td>1.382396</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>2.519922e-07</td>\n",
       "      <td>0.001042</td>\n",
       "      <td>0.919805</td>\n",
       "      <td>0.681083</td>\n",
       "      <td>0.689388</td>\n",
       "      <td>0.749024</td>\n",
       "      <td>99</td>\n",
       "      <td>prediction</td>\n",
       "      <td>22</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>4600 rows × 20 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      epoch_duration  accuracy  correct_prob  xe_decoder  xe_prediction  \\\n",
       "0           0.049738  0.468300      0.383687    1.217863       1.172554   \n",
       "1           0.052037  0.664500      0.568396    0.844482       0.777716   \n",
       "2           0.048158  0.787200      0.717080    0.559989       0.478152   \n",
       "3           0.052506  0.887500      0.832086    0.369972       0.298410   \n",
       "4           0.047673  0.965800      0.922875    0.228660       0.158327   \n",
       "...              ...       ...           ...         ...            ...   \n",
       "4595        0.110032  0.318917      0.310612    1.382396       1.382396   \n",
       "4596        0.162111  0.318917      0.310611    1.382396       1.382396   \n",
       "4597        0.111560  0.318917      0.310612    1.382396       1.382396   \n",
       "4598        0.107595  0.318917      0.310613    1.382396       1.382396   \n",
       "4599        0.117936  0.318917      0.310612    1.382396       1.382396   \n",
       "\n",
       "          loss                                   discrete_iq_base  \\\n",
       "0     1.217863  (2.300848365067822, 1.5341390542295583, 2.7274...   \n",
       "1     0.844482  (2.300848365067822, 1.9826139146332251, 2.7987...   \n",
       "2     0.559989  (2.300848365067822, 2.15482411296367, 2.690880...   \n",
       "3     0.369972  (2.3008483650678224, 2.262912213567316, 2.6213...   \n",
       "4     0.228660  (2.300848365067822, 2.340216427923633, 2.55862...   \n",
       "...        ...                                                ...   \n",
       "4595  1.382396  (2.3011591727032914, 0.9198048918122748, 2.302...   \n",
       "4596  1.382396  (2.3011591727032914, 0.9198048924270809, 2.302...   \n",
       "4597  1.382396  (2.3011591727032914, 0.9198048918540283, 2.302...   \n",
       "4598  1.382396  (2.3011591727032914, 0.9198048920132202, 2.302...   \n",
       "4599  1.382396  (2.3011591727032914, 0.919804892124919, 2.3022...   \n",
       "\n",
       "      discrete_decoder_uncertainty  discrete_encoding_entropy  \\\n",
       "0                         1.193319                   1.534139   \n",
       "1                         0.816143                   1.982614   \n",
       "2                         0.536056                   2.154824   \n",
       "3                         0.358449                   2.262912   \n",
       "4                         0.218414                   2.340216   \n",
       "...                            ...                        ...   \n",
       "4595                      1.382396                   0.919805   \n",
       "4596                      1.382396                   0.919805   \n",
       "4597                      1.382396                   0.919805   \n",
       "4598                      1.382396                   0.919805   \n",
       "4599                      1.382396                   0.919805   \n",
       "\n",
       "      discrete_preserved_information  discrete_H_Z__X  discrete_H_Z__Y  \\\n",
       "0                           1.402055     1.320843e-01         0.426610   \n",
       "1                           1.809810     1.728041e-01         0.497909   \n",
       "2                           2.053408     1.014161e-01         0.390032   \n",
       "3                           2.191586     7.132585e-02         0.320513   \n",
       "4                           2.290210     5.000679e-02         0.257782   \n",
       "...                              ...              ...              ...   \n",
       "4595                        0.919805     2.704836e-07         0.001042   \n",
       "4596                        0.919805     2.653818e-07         0.001042   \n",
       "4597                        0.919805     2.598872e-07         0.001042   \n",
       "4598                        0.919805     2.558313e-07         0.001042   \n",
       "4599                        0.919805     2.519922e-07         0.001042   \n",
       "\n",
       "      discrete_H_Z     error   error_p  error_bound  epoch   objective  \\\n",
       "0         1.534139  0.531700  0.616313     0.696787      0     decoder   \n",
       "1         1.982614  0.335500  0.431604     0.557866      1     decoder   \n",
       "2         2.154824  0.212800  0.282920     0.414949      2     decoder   \n",
       "3         2.262912  0.112500  0.167914     0.301241      3     decoder   \n",
       "4         2.340216  0.034200  0.077125     0.196207      4     decoder   \n",
       "...            ...       ...       ...          ...    ...         ...   \n",
       "4595      0.919805  0.681083  0.689388     0.749024     95  prediction   \n",
       "4596      0.919805  0.681083  0.689389     0.749024     96  prediction   \n",
       "4597      0.919805  0.681083  0.689388     0.749024     97  prediction   \n",
       "4598      0.919805  0.681083  0.689387     0.749024     98  prediction   \n",
       "4599      0.919805  0.681083  0.689388     0.749024     99  prediction   \n",
       "\n",
       "      experiment_index source  \n",
       "0                    0   test  \n",
       "1                    0   test  \n",
       "2                    0   test  \n",
       "3                    0   test  \n",
       "4                    0   test  \n",
       "...                ...    ...  \n",
       "4595                22  train  \n",
       "4596                22  train  \n",
       "4597                22  train  \n",
       "4598                22  train  \n",
       "4599                22  train  \n",
       "\n",
       "[4600 rows x 20 columns]"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df=pd.DataFrame(epoch_data)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:03.111518Z",
     "start_time": "2020-03-24T20:38:03.072774Z"
    }
   },
   "outputs": [],
   "source": [
    "dfm = df.melt(id_vars=[\"source\", 'experiment_index', 'epoch', 'objective'], value_vars=['error','error_p', 'xe_decoder', 'xe_prediction', 'discrete_decoder_uncertainty', 'error_bound'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:03.137746Z",
     "start_time": "2020-03-24T20:38:03.113218Z"
    }
   },
   "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>source</th>\n",
       "      <th>experiment_index</th>\n",
       "      <th>epoch</th>\n",
       "      <th>objective</th>\n",
       "      <th>variable</th>\n",
       "      <th>value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.531700</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.335500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.212800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.112500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>decoder</td>\n",
       "      <td>error</td>\n",
       "      <td>0.034200</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27595</th>\n",
       "      <td>train</td>\n",
       "      <td>22</td>\n",
       "      <td>95</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error_bound</td>\n",
       "      <td>0.762134</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27596</th>\n",
       "      <td>train</td>\n",
       "      <td>22</td>\n",
       "      <td>96</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error_bound</td>\n",
       "      <td>0.762122</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27597</th>\n",
       "      <td>train</td>\n",
       "      <td>22</td>\n",
       "      <td>97</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error_bound</td>\n",
       "      <td>0.762135</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27598</th>\n",
       "      <td>train</td>\n",
       "      <td>22</td>\n",
       "      <td>98</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error_bound</td>\n",
       "      <td>0.762137</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27599</th>\n",
       "      <td>train</td>\n",
       "      <td>22</td>\n",
       "      <td>99</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error_bound</td>\n",
       "      <td>0.762139</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>27600 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      source  experiment_index  epoch   objective     variable     value\n",
       "0       test                 0      0     decoder        error  0.531700\n",
       "1       test                 0      1     decoder        error  0.335500\n",
       "2       test                 0      2     decoder        error  0.212800\n",
       "3       test                 0      3     decoder        error  0.112500\n",
       "4       test                 0      4     decoder        error  0.034200\n",
       "...      ...               ...    ...         ...          ...       ...\n",
       "27595  train                22     95  prediction  error_bound  0.762134\n",
       "27596  train                22     96  prediction  error_bound  0.762122\n",
       "27597  train                22     97  prediction  error_bound  0.762135\n",
       "27598  train                22     98  prediction  error_bound  0.762137\n",
       "27599  train                22     99  prediction  error_bound  0.762139\n",
       "\n",
       "[27600 rows x 6 columns]"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: tables in /home/XXX/anaconda3/envs/uib/lib/python3.7/site-packages (3.6.1)\r\n",
      "Requirement already satisfied: numpy>=1.9.3 in /home/XXX/anaconda3/envs/uib/lib/python3.7/site-packages (from tables) (1.18.4)\r\n",
      "Requirement already satisfied: numexpr>=2.6.2 in /home/XXX/anaconda3/envs/uib/lib/python3.7/site-packages (from tables) (2.7.1)\r\n"
     ]
    }
   ],
   "source": [
    "!pip install tables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "dfm.to_csv(\"plots/bounds_categorical_pmnist.csv\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CIFAR 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.319585Z",
     "start_time": "2020-03-24T20:38:18.586810Z"
    }
   },
   "outputs": [],
   "source": [
    "cifar10_store = results_loader.load_YYY_files(f'{XXX.notebook.original_dir}/bounds_categorical_cifar10/results/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.346813Z",
     "start_time": "2020-03-24T20:38:19.322017Z"
    }
   },
   "outputs": [],
   "source": [
    "cifar10_filtered_results = results_loader.filter_dict(cifar10_store, v=lambda result: True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.374003Z",
     "start_time": "2020-03-24T20:38:19.348712Z"
    }
   },
   "outputs": [],
   "source": [
    "from dataclasses import dataclass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.401419Z",
     "start_time": "2020-03-24T20:38:19.375589Z"
    }
   },
   "outputs": [],
   "source": [
    "import statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.447380Z",
     "start_time": "2020-03-24T20:38:19.403016Z"
    }
   },
   "outputs": [],
   "source": [
    "epoch_data = []\n",
    "\n",
    "for ri, result in enumerate(cifar10_filtered_results.values()):\n",
    "    if \"decoder_uncertainty\" in result.actual_name:\n",
    "        objective = \"decoder_uncertainty\"\n",
    "    elif \"prediction\" in result.config.cross_entropy_type:\n",
    "        objective = \"prediction\"\n",
    "    else:\n",
    "        objective = \"decoder\"\n",
    "        \n",
    "    for source, epochs in ((\"test\", result.log.test_epochs), (\"train\", result.log.train_eval_epochs)):\n",
    "        for i, epoch in enumerate(epochs):\n",
    "            d = epoch._asdict()\n",
    "            d[\"objective\"] = objective\n",
    "            d['error'] = 1 - d['accuracy']\n",
    "            d['error_p'] = 1 - d['correct_prob']\n",
    "            d['error_bound'] = 1 - np.exp(-d['discrete_decoder_uncertainty'])\n",
    "            d['epoch'] = i\n",
    "            d['experiment_index'] = ri\n",
    "            d[\"source\"] = source\n",
    "            epoch_data.append(d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.474840Z",
     "start_time": "2020-03-24T20:38:19.449462Z"
    }
   },
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.550648Z",
     "start_time": "2020-03-24T20:38:19.476325Z"
    }
   },
   "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_duration</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>discrete_iq_base</th>\n",
       "      <th>discrete_decoder_uncertainty</th>\n",
       "      <th>discrete_encoding_entropy</th>\n",
       "      <th>discrete_preserved_information</th>\n",
       "      <th>discrete_H_Z__X</th>\n",
       "      <th>discrete_H_Z__Y</th>\n",
       "      <th>discrete_H_Z</th>\n",
       "      <th>objective</th>\n",
       "      <th>error</th>\n",
       "      <th>error_p</th>\n",
       "      <th>error_bound</th>\n",
       "      <th>epoch</th>\n",
       "      <th>experiment_index</th>\n",
       "      <th>source</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.318352</td>\n",
       "      <td>0.37870</td>\n",
       "      <td>0.291961</td>\n",
       "      <td>2.055463</td>\n",
       "      <td>1.546122</td>\n",
       "      <td>1.545400</td>\n",
       "      <td>(2.3025850929940455, 2.4735857357792765, 4.199...</td>\n",
       "      <td>1.725415</td>\n",
       "      <td>2.473586</td>\n",
       "      <td>1.189308</td>\n",
       "      <td>1.284278</td>\n",
       "      <td>1.896416</td>\n",
       "      <td>2.473586</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.62130</td>\n",
       "      <td>0.708039</td>\n",
       "      <td>0.821901</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.339940</td>\n",
       "      <td>0.51240</td>\n",
       "      <td>0.439062</td>\n",
       "      <td>2.644888</td>\n",
       "      <td>1.292254</td>\n",
       "      <td>1.294710</td>\n",
       "      <td>(2.3025850929940455, 2.2658373653733284, 3.821...</td>\n",
       "      <td>1.555842</td>\n",
       "      <td>2.265837</td>\n",
       "      <td>1.394703</td>\n",
       "      <td>0.871134</td>\n",
       "      <td>1.519094</td>\n",
       "      <td>2.265837</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.48760</td>\n",
       "      <td>0.560938</td>\n",
       "      <td>0.788988</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1.374387</td>\n",
       "      <td>0.60600</td>\n",
       "      <td>0.532589</td>\n",
       "      <td>2.675981</td>\n",
       "      <td>1.024621</td>\n",
       "      <td>1.026648</td>\n",
       "      <td>(2.3025850929940455, 2.3371826614728892, 3.710...</td>\n",
       "      <td>1.373337</td>\n",
       "      <td>2.337183</td>\n",
       "      <td>1.527831</td>\n",
       "      <td>0.809352</td>\n",
       "      <td>1.407935</td>\n",
       "      <td>2.337183</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.39400</td>\n",
       "      <td>0.467411</td>\n",
       "      <td>0.746740</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.359269</td>\n",
       "      <td>0.65100</td>\n",
       "      <td>0.591665</td>\n",
       "      <td>2.485300</td>\n",
       "      <td>0.865041</td>\n",
       "      <td>0.865819</td>\n",
       "      <td>(2.3025850929940455, 2.284879887386825, 3.5013...</td>\n",
       "      <td>1.216499</td>\n",
       "      <td>2.284880</td>\n",
       "      <td>1.627836</td>\n",
       "      <td>0.657044</td>\n",
       "      <td>1.198793</td>\n",
       "      <td>2.284880</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.34900</td>\n",
       "      <td>0.408335</td>\n",
       "      <td>0.703734</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>test</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.361314</td>\n",
       "      <td>0.68770</td>\n",
       "      <td>0.628126</td>\n",
       "      <td>2.444015</td>\n",
       "      <td>0.784905</td>\n",
       "      <td>0.786768</td>\n",
       "      <td>(2.3025850929940455, 2.249853147743274, 3.3933...</td>\n",
       "      <td>1.143507</td>\n",
       "      <td>2.249853</td>\n",
       "      <td>1.681046</td>\n",
       "      <td>0.568808</td>\n",
       "      <td>1.090775</td>\n",
       "      <td>2.249853</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.31230</td>\n",
       "      <td>0.371874</td>\n",
       "      <td>0.681301</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>test</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4795</th>\n",
       "      <td>5.583442</td>\n",
       "      <td>0.99986</td>\n",
       "      <td>0.999518</td>\n",
       "      <td>0.016016</td>\n",
       "      <td>0.000672</td>\n",
       "      <td>0.000676</td>\n",
       "      <td>(2.3025850929940455, 2.3338538616254803, 2.338...</td>\n",
       "      <td>0.004657</td>\n",
       "      <td>2.333854</td>\n",
       "      <td>2.307366</td>\n",
       "      <td>0.026488</td>\n",
       "      <td>0.035926</td>\n",
       "      <td>2.333854</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.00014</td>\n",
       "      <td>0.000482</td>\n",
       "      <td>0.004646</td>\n",
       "      <td>95</td>\n",
       "      <td>23</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4796</th>\n",
       "      <td>5.607437</td>\n",
       "      <td>0.99992</td>\n",
       "      <td>0.999506</td>\n",
       "      <td>0.015212</td>\n",
       "      <td>0.000571</td>\n",
       "      <td>0.000572</td>\n",
       "      <td>(2.302585092994046, 2.3319590232870904, 2.3368...</td>\n",
       "      <td>0.004882</td>\n",
       "      <td>2.331959</td>\n",
       "      <td>2.307019</td>\n",
       "      <td>0.024940</td>\n",
       "      <td>0.034256</td>\n",
       "      <td>2.331959</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.00008</td>\n",
       "      <td>0.000494</td>\n",
       "      <td>0.004870</td>\n",
       "      <td>96</td>\n",
       "      <td>23</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4797</th>\n",
       "      <td>5.516963</td>\n",
       "      <td>0.99990</td>\n",
       "      <td>0.999605</td>\n",
       "      <td>0.014939</td>\n",
       "      <td>0.000511</td>\n",
       "      <td>0.000520</td>\n",
       "      <td>(2.3025850929940455, 2.331826055385218, 2.3357...</td>\n",
       "      <td>0.003898</td>\n",
       "      <td>2.331826</td>\n",
       "      <td>2.307280</td>\n",
       "      <td>0.024546</td>\n",
       "      <td>0.033139</td>\n",
       "      <td>2.331826</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.00010</td>\n",
       "      <td>0.000395</td>\n",
       "      <td>0.003890</td>\n",
       "      <td>97</td>\n",
       "      <td>23</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4798</th>\n",
       "      <td>5.519889</td>\n",
       "      <td>0.99988</td>\n",
       "      <td>0.999611</td>\n",
       "      <td>0.012553</td>\n",
       "      <td>0.000505</td>\n",
       "      <td>0.000505</td>\n",
       "      <td>(2.3025850929940455, 2.329753721109671, 2.3335...</td>\n",
       "      <td>0.003845</td>\n",
       "      <td>2.329754</td>\n",
       "      <td>2.307162</td>\n",
       "      <td>0.022592</td>\n",
       "      <td>0.031014</td>\n",
       "      <td>2.329754</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.00012</td>\n",
       "      <td>0.000389</td>\n",
       "      <td>0.003838</td>\n",
       "      <td>98</td>\n",
       "      <td>23</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4799</th>\n",
       "      <td>5.617864</td>\n",
       "      <td>0.99976</td>\n",
       "      <td>0.999469</td>\n",
       "      <td>0.018907</td>\n",
       "      <td>0.000728</td>\n",
       "      <td>0.000726</td>\n",
       "      <td>(2.3025850929940455, 2.3257819011331318, 2.330...</td>\n",
       "      <td>0.005140</td>\n",
       "      <td>2.325782</td>\n",
       "      <td>2.305875</td>\n",
       "      <td>0.019907</td>\n",
       "      <td>0.028337</td>\n",
       "      <td>2.325782</td>\n",
       "      <td>prediction</td>\n",
       "      <td>0.00024</td>\n",
       "      <td>0.000531</td>\n",
       "      <td>0.005127</td>\n",
       "      <td>99</td>\n",
       "      <td>23</td>\n",
       "      <td>train</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>4800 rows × 20 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      epoch_duration  accuracy  correct_prob  xe_decoder  xe_prediction  \\\n",
       "0           1.318352   0.37870      0.291961    2.055463       1.546122   \n",
       "1           1.339940   0.51240      0.439062    2.644888       1.292254   \n",
       "2           1.374387   0.60600      0.532589    2.675981       1.024621   \n",
       "3           1.359269   0.65100      0.591665    2.485300       0.865041   \n",
       "4           1.361314   0.68770      0.628126    2.444015       0.784905   \n",
       "...              ...       ...           ...         ...            ...   \n",
       "4795        5.583442   0.99986      0.999518    0.016016       0.000672   \n",
       "4796        5.607437   0.99992      0.999506    0.015212       0.000571   \n",
       "4797        5.516963   0.99990      0.999605    0.014939       0.000511   \n",
       "4798        5.519889   0.99988      0.999611    0.012553       0.000505   \n",
       "4799        5.617864   0.99976      0.999469    0.018907       0.000728   \n",
       "\n",
       "          loss                                   discrete_iq_base  \\\n",
       "0     1.545400  (2.3025850929940455, 2.4735857357792765, 4.199...   \n",
       "1     1.294710  (2.3025850929940455, 2.2658373653733284, 3.821...   \n",
       "2     1.026648  (2.3025850929940455, 2.3371826614728892, 3.710...   \n",
       "3     0.865819  (2.3025850929940455, 2.284879887386825, 3.5013...   \n",
       "4     0.786768  (2.3025850929940455, 2.249853147743274, 3.3933...   \n",
       "...        ...                                                ...   \n",
       "4795  0.000676  (2.3025850929940455, 2.3338538616254803, 2.338...   \n",
       "4796  0.000572  (2.302585092994046, 2.3319590232870904, 2.3368...   \n",
       "4797  0.000520  (2.3025850929940455, 2.331826055385218, 2.3357...   \n",
       "4798  0.000505  (2.3025850929940455, 2.329753721109671, 2.3335...   \n",
       "4799  0.000726  (2.3025850929940455, 2.3257819011331318, 2.330...   \n",
       "\n",
       "      discrete_decoder_uncertainty  discrete_encoding_entropy  \\\n",
       "0                         1.725415                   2.473586   \n",
       "1                         1.555842                   2.265837   \n",
       "2                         1.373337                   2.337183   \n",
       "3                         1.216499                   2.284880   \n",
       "4                         1.143507                   2.249853   \n",
       "...                            ...                        ...   \n",
       "4795                      0.004657                   2.333854   \n",
       "4796                      0.004882                   2.331959   \n",
       "4797                      0.003898                   2.331826   \n",
       "4798                      0.003845                   2.329754   \n",
       "4799                      0.005140                   2.325782   \n",
       "\n",
       "      discrete_preserved_information  discrete_H_Z__X  discrete_H_Z__Y  \\\n",
       "0                           1.189308         1.284278         1.896416   \n",
       "1                           1.394703         0.871134         1.519094   \n",
       "2                           1.527831         0.809352         1.407935   \n",
       "3                           1.627836         0.657044         1.198793   \n",
       "4                           1.681046         0.568808         1.090775   \n",
       "...                              ...              ...              ...   \n",
       "4795                        2.307366         0.026488         0.035926   \n",
       "4796                        2.307019         0.024940         0.034256   \n",
       "4797                        2.307280         0.024546         0.033139   \n",
       "4798                        2.307162         0.022592         0.031014   \n",
       "4799                        2.305875         0.019907         0.028337   \n",
       "\n",
       "      discrete_H_Z   objective    error   error_p  error_bound  epoch  \\\n",
       "0         2.473586  prediction  0.62130  0.708039     0.821901      0   \n",
       "1         2.265837  prediction  0.48760  0.560938     0.788988      1   \n",
       "2         2.337183  prediction  0.39400  0.467411     0.746740      2   \n",
       "3         2.284880  prediction  0.34900  0.408335     0.703734      3   \n",
       "4         2.249853  prediction  0.31230  0.371874     0.681301      4   \n",
       "...            ...         ...      ...       ...          ...    ...   \n",
       "4795      2.333854  prediction  0.00014  0.000482     0.004646     95   \n",
       "4796      2.331959  prediction  0.00008  0.000494     0.004870     96   \n",
       "4797      2.331826  prediction  0.00010  0.000395     0.003890     97   \n",
       "4798      2.329754  prediction  0.00012  0.000389     0.003838     98   \n",
       "4799      2.325782  prediction  0.00024  0.000531     0.005127     99   \n",
       "\n",
       "      experiment_index source  \n",
       "0                    0   test  \n",
       "1                    0   test  \n",
       "2                    0   test  \n",
       "3                    0   test  \n",
       "4                    0   test  \n",
       "...                ...    ...  \n",
       "4795                23  train  \n",
       "4796                23  train  \n",
       "4797                23  train  \n",
       "4798                23  train  \n",
       "4799                23  train  \n",
       "\n",
       "[4800 rows x 20 columns]"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df=pd.DataFrame(epoch_data)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.587074Z",
     "start_time": "2020-03-24T20:38:19.552592Z"
    }
   },
   "outputs": [],
   "source": [
    "dfm = df.melt(id_vars=[\"source\", 'experiment_index', 'epoch','objective'], value_vars=['error','error_p','error_bound', 'xe_decoder', 'xe_prediction', 'discrete_decoder_uncertainty'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2020-03-24T20:38:19.622954Z",
     "start_time": "2020-03-24T20:38:19.588779Z"
    }
   },
   "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>source</th>\n",
       "      <th>experiment_index</th>\n",
       "      <th>epoch</th>\n",
       "      <th>objective</th>\n",
       "      <th>variable</th>\n",
       "      <th>value</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error</td>\n",
       "      <td>0.621300</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error</td>\n",
       "      <td>0.487600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error</td>\n",
       "      <td>0.394000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error</td>\n",
       "      <td>0.349000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>test</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>prediction</td>\n",
       "      <td>error</td>\n",
       "      <td>0.312300</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28795</th>\n",
       "      <td>train</td>\n",
       "      <td>23</td>\n",
       "      <td>95</td>\n",
       "      <td>prediction</td>\n",
       "      <td>discrete_decoder_uncertainty</td>\n",
       "      <td>0.004657</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28796</th>\n",
       "      <td>train</td>\n",
       "      <td>23</td>\n",
       "      <td>96</td>\n",
       "      <td>prediction</td>\n",
       "      <td>discrete_decoder_uncertainty</td>\n",
       "      <td>0.004882</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28797</th>\n",
       "      <td>train</td>\n",
       "      <td>23</td>\n",
       "      <td>97</td>\n",
       "      <td>prediction</td>\n",
       "      <td>discrete_decoder_uncertainty</td>\n",
       "      <td>0.003898</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28798</th>\n",
       "      <td>train</td>\n",
       "      <td>23</td>\n",
       "      <td>98</td>\n",
       "      <td>prediction</td>\n",
       "      <td>discrete_decoder_uncertainty</td>\n",
       "      <td>0.003845</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28799</th>\n",
       "      <td>train</td>\n",
       "      <td>23</td>\n",
       "      <td>99</td>\n",
       "      <td>prediction</td>\n",
       "      <td>discrete_decoder_uncertainty</td>\n",
       "      <td>0.005140</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>28800 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      source  experiment_index  epoch   objective  \\\n",
       "0       test                 0      0  prediction   \n",
       "1       test                 0      1  prediction   \n",
       "2       test                 0      2  prediction   \n",
       "3       test                 0      3  prediction   \n",
       "4       test                 0      4  prediction   \n",
       "...      ...               ...    ...         ...   \n",
       "28795  train                23     95  prediction   \n",
       "28796  train                23     96  prediction   \n",
       "28797  train                23     97  prediction   \n",
       "28798  train                23     98  prediction   \n",
       "28799  train                23     99  prediction   \n",
       "\n",
       "                           variable     value  \n",
       "0                             error  0.621300  \n",
       "1                             error  0.487600  \n",
       "2                             error  0.394000  \n",
       "3                             error  0.349000  \n",
       "4                             error  0.312300  \n",
       "...                             ...       ...  \n",
       "28795  discrete_decoder_uncertainty  0.004657  \n",
       "28796  discrete_decoder_uncertainty  0.004882  \n",
       "28797  discrete_decoder_uncertainty  0.003898  \n",
       "28798  discrete_decoder_uncertainty  0.003845  \n",
       "28799  discrete_decoder_uncertainty  0.005140  \n",
       "\n",
       "[28800 rows x 6 columns]"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "dfm.to_csv(\"plots/bounds_categorical_cifar10.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.6 64-bit ('uib': conda)",
   "language": "python",
   "name": "python37664bituibconda101b67e03a19488ca1455e98b804290f"
  },
  "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
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
