{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "import jax\n",
    "import torchvision\n",
    "\n",
    "import reprieve\n",
    "from reprieve.representations import mnist_vae\n",
    "from reprieve.mnist_noisy_label import MNISTNoisyLabelDataset\n",
    "from reprieve.algorithms import mlp as alg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading http://yann.lecun.com/exdb/mnist/train-images-idx3-ubyte.gz to ./data/MNIST/raw/train-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "80a3ed478a6441388df8c44526016fc0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=1, bar_style='info', max=1), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Extracting ./data/MNIST/raw/train-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
      "Downloading http://yann.lecun.com/exdb/mnist/train-labels-idx1-ubyte.gz to ./data/MNIST/raw/train-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7cffb490986743c38cc46e98f3332d5a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=1, bar_style='info', max=1), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Extracting ./data/MNIST/raw/train-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw/t10k-images-idx3-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "2fbfa8868c274acba236b90caafbdf39",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=1, bar_style='info', max=1), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Extracting ./data/MNIST/raw/t10k-images-idx3-ubyte.gz to ./data/MNIST/raw\n",
      "Downloading http://yann.lecun.com/exdb/mnist/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3560b784374242fe9117e4fa12182519",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(IntProgress(value=1, bar_style='info', max=1), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Extracting ./data/MNIST/raw/t10k-labels-idx1-ubyte.gz to ./data/MNIST/raw\n",
      "Processing...\n",
      "Done!\n"
     ]
    }
   ],
   "source": [
    "# make an MNIST dataset\n",
    "dataset_mnist = torchvision.datasets.MNIST(\n",
    "    './data', train=True, download=True,\n",
    "    transform=torchvision.transforms.Compose([\n",
    "        torchvision.transforms.ToTensor(),\n",
    "        torchvision.transforms.Normalize((0.1307,), (0.3081,))]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# make an MLP algorithm which takes inputs of shape (1, 28, 28)\n",
    "# and has 10 output classes\n",
    "init_fn, train_step_fn, eval_fn = alg.make_algorithm((1, 28, 28), 10)\n",
    "\n",
    "# these functions initialize the state of the model given a seed, \n",
    "# train on a batch of data, \n",
    "# and evaluate on a batch of data\n",
    "\n",
    "# construct a loss-data estimator and use it to compute the loss-data curve\n",
    "raw_loss_data_estimator = reprieve.LossDataEstimator(\n",
    "    init_fn, train_step_fn, eval_fn, dataset_mnist)\n",
    "raw_results = raw_loss_data_estimator.compute_curve()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# train a VAE with latent dimension 8\n",
    "vae_repr = mnist_vae.build_repr(8)\n",
    "\n",
    "# make an MLP algorithm which takes inputs of shape (8,) to match the VAE\n",
    "# and has 10 output classes\n",
    "init_fn, train_step_fn, eval_fn = alg.make_algorithm((8,), 10)\n",
    "\n",
    "# construct a loss-data estimator and use it to compute the loss-data curve\n",
    "# pass the VAE as our representation_fn\n",
    "vae_loss_data_estimator = reprieve.LossDataEstimator(\n",
    "    init_fn, train_step_fn, eval_fn, dataset_mnist, \n",
    "    representation_fn=vae_repr)\n",
    "vae_results = vae_loss_data_estimator.compute_curve()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# name our experiments and concatenate them\n",
    "raw_results['name'] = 'Raw'\n",
    "vae_results['name'] = 'VAE'\n",
    "\n",
    "outcome_df = pd.concat([\n",
    "    raw_results,\n",
    "    vae_results,\n",
    "])\n",
    "\n",
    "# pick some settings of n (training set size) and epsilon (loss tolerance)\n",
    "ns = [60, 20000]\n",
    "epsilons = [1, 0.2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "alt.LayerChart(...)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# plot the loss-data curves for our representations\n",
    "reprieve.render_curve(outcome_df, ns, epsilons)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th>Name</th>\n",
       "      <th>Raw</th>\n",
       "      <th>VAE</th>\n",
       "      <th>Raw</th>\n",
       "      <th>VAE</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>n</th>\n",
       "      <th>68.0</th>\n",
       "      <th>68.0</th>\n",
       "      <th>20782.0</th>\n",
       "      <th>20782.0</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Val loss</th>\n",
       "      <td>1.27876</td>\n",
       "      <td>0.641601</td>\n",
       "      <td>0.111662</td>\n",
       "      <td>0.10363</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MDL</th>\n",
       "      <td>138.93</td>\n",
       "      <td>99.44</td>\n",
       "      <td>3432.78</td>\n",
       "      <td>2652.36</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SDL, eps=1</th>\n",
       "      <td>&gt; 70.93</td>\n",
       "      <td>46.49</td>\n",
       "      <td>70.93</td>\n",
       "      <td>46.49</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SDL, eps=0.2</th>\n",
       "      <td>&gt; 125.33</td>\n",
       "      <td>&gt; 85.84</td>\n",
       "      <td>563.8</td>\n",
       "      <td>176.49</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>eSC, eps=1</th>\n",
       "      <td>&gt; 68.0</td>\n",
       "      <td>68</td>\n",
       "      <td>176</td>\n",
       "      <td>68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>eSC, eps=0.2</th>\n",
       "      <td>&gt; 68.0</td>\n",
       "      <td>&gt; 68.0</td>\n",
       "      <td>7998</td>\n",
       "      <td>3078</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Name               Raw       VAE       Raw      VAE\n",
       "n              68.0      68.0      20782.0  20782.0\n",
       "Val loss       1.27876  0.641601  0.111662  0.10363\n",
       "MDL             138.93     99.44   3432.78  2652.36\n",
       "SDL, eps=1     > 70.93     46.49     70.93    46.49\n",
       "SDL, eps=0.2  > 125.33   > 85.84     563.8   176.49\n",
       "eSC, eps=1      > 68.0        68       176       68\n",
       "eSC, eps=0.2    > 68.0    > 68.0      7998     3078"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# compute VA, MDL, SDL, and eSC for both representations\n",
    "metrics_df = reprieve.compute_metrics(outcome_df, ns, epsilons)\n",
    "metrics_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fe090c0901ec4ec5949e75ba4b88bad0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output(layout=Layout(border='1px solid black'), outputs=({'output_type': 'stream', 'name': 'stdout', 'text': '…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# reprieve even generates LaTeX tables you can paste into a paper\n",
    "latex_text = reprieve.render_latex(metrics_df, display=True)"
   ]
  }
 ],
 "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.3-final"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}