{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MNIST Generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import time\n",
    "import os\n",
    "import seaborn as sns\n",
    "from tqdm.notebook import tqdm\n",
    "from types import SimpleNamespace\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"sans-serif\",\n",
    "    \"font.sans-serif\": [\"Helvetica\"]})\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader\n",
    "from torchvision import transforms, datasets\n",
    "\n",
    "from modules.autoencoder import SAE, VAE\n",
    "from modules.flow import Kernel_Perron_Frobenius\n",
    "from modules.loss import mix_rbf_mmd, poly_mmd\n",
    "from modules.utils import weighted_max, SubsetDataset\n",
    "from modules.kernel_fn import *\n",
    "from dataset import get_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Arguments\n",
    "\n",
    "args = SimpleNamespace(**{\n",
    "    'experiment_id': 'mnist_notebook',\n",
    "    'save_dir': './saved_models',\n",
    "    'save_epochs': 10,\n",
    "    'ae_load_path': None, # change to a path to load a pretrained AE\n",
    "    # Data Params\n",
    "    'img_dim': (1, 32, 32),\n",
    "    # Model Params\n",
    "    'ae_input_noise_var': 0., # variance of gaussian noise added to the input (denoising AE if > 0)\n",
    "    'ae_layers': [2, 2, 2],\n",
    "    'ae_channels': [32, 64, 128, 256],\n",
    "    'ae_encoding_depth': 16,\n",
    "    'pf_use_compression': False,\n",
    "    'pf_sample_size': 10000,\n",
    "    # Training Params\n",
    "    'epochs': 50,\n",
    "    'lr': 1e-3,\n",
    "    'lr_epochs': 20,\n",
    "    'lr_frac': 0.5,\n",
    "    'batch_size': 512,\n",
    "    # Visualization Params\n",
    "    'vis_epochs': 10,\n",
    "    'vis_dim': (4, 4),\n",
    "})\n",
    "\n",
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_samples(dataset, sample_size=-1):\n",
    "    inds = np.random.permutation(len(dataset))\n",
    "    if sample_size >= 0:\n",
    "        inds = inds[:sample_size]\n",
    "    return torch.stack([dataset[ind][0] for ind in inds]).float()\n",
    "\n",
    "def pre_process(image):\n",
    "    return image * 2 - 1\n",
    "\n",
    "def post_process(logits):\n",
    "    return torch.clamp((logits + 1) / 2, 0., 1.)\n",
    "\n",
    "def fill_image_grid(rows_cols, ax, imgs, title=None):\n",
    "    n, h, w, c = imgs.shape\n",
    "    assert n >= np.prod(rows_cols)\n",
    "    \n",
    "    img_grid = np.zeros((h * rows_cols[0], w * rows_cols[1], c))\n",
    "    for i in range(rows_cols[0]):\n",
    "        for j in range(rows_cols[1]):\n",
    "            img_grid[h * i: h * (i + 1), w * j: w * (j + 1)] = imgs[i * rows_cols[0] + j]\n",
    "    \n",
    "    ax.imshow(img_grid, cmap=plt.cm.gray)\n",
    "    ax.set_axis_off()\n",
    "    if title is not None:\n",
    "        ax.set_title(title)\n",
    "\n",
    "def tonumpy2d(tensor):\n",
    "    return tensor.permute(0, 2, 3, 1).detach().cpu().numpy()\n",
    "\n",
    "def train_ae(ae, train_loader, epochs, lr, lr_epochs, lr_frac, args, device=torch.device('cuda')):\n",
    "    ae = ae.to(device)\n",
    "    optim = torch.optim.Adam(ae.parameters(), lr=lr)\n",
    "    lr_lambda = lambda epoch: np.power(lr_frac, int(epoch) // lr_epochs)\n",
    "    scheduler = torch.optim.lr_scheduler.LambdaLR(optim, lr_lambda)\n",
    "    rec_criterion = lambda x, y: torch.mean(torch.sum((x - y).pow(2), dim=1))\n",
    "\n",
    "    for epoch in range(epochs):\n",
    "        train_iter = tqdm(train_loader)\n",
    "        train_iter.set_description(\"Epoch {:d}\".format(epoch + 1))\n",
    "        for i, (X, y) in enumerate(train_iter):\n",
    "            X = pre_process(X).float().to(device)\n",
    "\n",
    "            noise = torch.randn_like(X).to(device) * args.ae_input_noise_var\n",
    "            X_noisy = X + noise\n",
    "\n",
    "            reconstruction, latents = ae(X_noisy)\n",
    "            rec_loss = rec_criterion(reconstruction, X)\n",
    "            loss = rec_loss\n",
    "\n",
    "            optim.zero_grad()\n",
    "            loss.backward()\n",
    "            optim.step()\n",
    "\n",
    "            train_iter.set_postfix({'reconstruction loss': rec_loss.item()})\n",
    "\n",
    "        if (epoch == 0) or ((epoch + 1) % args.vis_epochs == 0):\n",
    "            # Visualization\n",
    "            ae.eval()\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                interp = ae.module.bilinear_interpolate(latents, steps=args.vis_dim[0])\n",
    "\n",
    "            orig_np = tonumpy2d(post_process(X))\n",
    "            noisy_np = tonumpy2d(post_process(X_noisy))\n",
    "            recon_np = tonumpy2d(post_process(reconstruction))\n",
    "            interp_np = tonumpy2d(post_process(interp))\n",
    "            \n",
    "            fig, axes = plt.subplots(1, 4)\n",
    "            fig.set_size_inches(16, 4)\n",
    "\n",
    "            fill_image_grid(args.vis_dim, axes[0], orig_np, \"Original\")\n",
    "            fill_image_grid(args.vis_dim, axes[1], noisy_np, \"Original + Noise\")\n",
    "            fill_image_grid(args.vis_dim, axes[2], recon_np, \"Reconstruction\")\n",
    "            fill_image_grid(args.vis_dim, axes[3], interp_np, \"Interpolation\")\n",
    "\n",
    "            plt.show()\n",
    "\n",
    "            ae.train()\n",
    "\n",
    "        if (epochs + 1) % args.save_epochs == 0:\n",
    "            torch.save(ae.module.state_dict(), os.path.join(args.save_dir, \\\n",
    "                                                            \"{}-ae.pth\".format(args.experiment_id)))\n",
    "\n",
    "        scheduler.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": false
   },
   "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": "c87bc856e88a44ea8194b42a60458833",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=1.0, bar_style='info', max=1.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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": "93588cad569842cc9ab33a3ecf4bf6fa",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=1.0, bar_style='info', max=1.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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",
      "\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8528a9180ea14a908ed09f349362a83a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=1.0, bar_style='info', max=1.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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": "385fb404b80d4dd5baed5f8c2c3b7c8b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=1.0, bar_style='info', max=1.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting data/MNIST/raw/t10k-labels-idx1-ubyte.gz to data/MNIST/raw\n",
      "Processing...\n",
      "Done!\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/conda-bld/pytorch_1591914886554/work/torch/csrc/utils/tensor_numpy.cpp:141: UserWarning: The given NumPy array is not writeable, and PyTorch does not support non-writeable tensors. This means you can write to the underlying (supposedly non-writeable) NumPy array using the tensor. You may want to copy the array to protect its data or make it writeable before converting it to a tensor. This type of warning will be suppressed for the rest of this program.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AE load path is None. Training a new AE...\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "24e98b33869d4f00bc969492199d08c0",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=117.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1152x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "c714689dbba9457b81959af6fccd23ba",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=117.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Exception ignored in: Exception in thread Thread-242:\n",
      "<function tqdm.__del__ at 0x7fdfb5334e50>Traceback (most recent call last):\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/threading.py\", line 932, in _bootstrap_inner\n",
      "\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/site-packages/tqdm/std.py\", line 1085, in __del__\n",
      "    self.run()\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/threading.py\", line 870, in run\n",
      "        self._target(*self._args, **self._kwargs)\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/site-packages/torch/utils/data/_utils/pin_memory.py\", line 25, in _pin_memory_loop\n",
      "def __del__(self):\n",
      "KeyboardInterrupt: \n",
      "    r = in_queue.get(timeout=MP_STATUS_CHECK_INTERVAL)\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/multiprocessing/queues.py\", line 116, in get\n",
      "    return _ForkingPickler.loads(res)\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/site-packages/torch/multiprocessing/reductions.py\", line 294, in rebuild_storage_fd\n",
      "    fd = df.detach()\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/multiprocessing/resource_sharer.py\", line 57, in detach\n",
      "    with _resource_sharer.get_connection(self._id) as conn:\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/multiprocessing/resource_sharer.py\", line 87, in get_connection\n",
      "    c = Client(address, authkey=process.current_process().authkey)\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/multiprocessing/connection.py\", line 502, in Client\n",
      "    c = SocketClient(address)\n",
      "  File \"/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/multiprocessing/connection.py\", line 630, in SocketClient\n",
      "    s.connect(address)\n",
      "FileNotFoundError: [Errno 2] No such file or directory\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "ename": "RuntimeError",
     "evalue": "Pin memory thread exited unexpectedly",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-4-9cc94a84d6d4>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     20\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m     \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"AE load path is None. Training a new AE...\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 22\u001b[0;31m     \u001b[0mtrain_ae\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mDataParallel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mae\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtrain_loader\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mepochs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlr\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlr_epochs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlr_frac\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdevice\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m<ipython-input-3-ee4f4a960fba>\u001b[0m in \u001b[0;36mtrain_ae\u001b[0;34m(ae, train_loader, epochs, lr, lr_epochs, lr_frac, args, device)\u001b[0m\n\u001b[1;32m     38\u001b[0m         \u001b[0mtrain_iter\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtqdm\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrain_loader\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     39\u001b[0m         \u001b[0mtrain_iter\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_description\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Epoch {:d}\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mepoch\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 40\u001b[0;31m         \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrain_iter\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     41\u001b[0m             \u001b[0mX\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpre_process\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfloat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     42\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/pytorch/lib/python3.8/site-packages/tqdm/notebook.py\u001b[0m in \u001b[0;36m__iter__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    215\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__iter__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    216\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 217\u001b[0;31m             \u001b[0;32mfor\u001b[0m \u001b[0mobj\u001b[0m \u001b[0;32min\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtqdm_notebook\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__iter__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    218\u001b[0m                 \u001b[0;31m# return super(tqdm...) will not catch exception\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    219\u001b[0m                 \u001b[0;32myield\u001b[0m \u001b[0mobj\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/pytorch/lib/python3.8/site-packages/tqdm/std.py\u001b[0m in \u001b[0;36m__iter__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m   1127\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1128\u001b[0m         \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1129\u001b[0;31m             \u001b[0;32mfor\u001b[0m \u001b[0mobj\u001b[0m \u001b[0;32min\u001b[0m \u001b[0miterable\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1130\u001b[0m                 \u001b[0;32myield\u001b[0m \u001b[0mobj\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1131\u001b[0m                 \u001b[0;31m# Update and possibly print the progressbar.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/pytorch/lib/python3.8/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    343\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    344\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__next__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 345\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    346\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    347\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_kind\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0m_DatasetKind\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mIterable\u001b[0m \u001b[0;32mand\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/pytorch/lib/python3.8/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    839\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    840\u001b[0m             \u001b[0;32massert\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_shutdown\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_tasks_outstanding\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 841\u001b[0;31m             \u001b[0midx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_get_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    842\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_tasks_outstanding\u001b[0m \u001b[0;34m-=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    843\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/pytorch/lib/python3.8/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_get_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    801\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    802\u001b[0m                 \u001b[0;31m# while condition is false, i.e., pin_memory_thread died.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 803\u001b[0;31m                 \u001b[0;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'Pin memory thread exited unexpectedly'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    804\u001b[0m             \u001b[0;31m# In this case, `self._data_queue` is a `queue.Queue`,. But we don't\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    805\u001b[0m             \u001b[0;31m# need to call `.task_done()` because we don't use `.join()`.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: Pin memory thread exited unexpectedly"
     ]
    }
   ],
   "source": [
    "t = transforms.Compose([\n",
    "    transforms.Resize((*args.img_dim[-2:],)),\n",
    "    transforms.ToTensor(),\n",
    "])\n",
    "train_ds = datasets.MNIST(\"data\", train=True, transform=t, download=True)\n",
    "train_loader = DataLoader(train_ds, batch_size=args.batch_size, shuffle=True, drop_last=True, pin_memory=True, num_workers=8)\n",
    "\n",
    "# Autoencoder with hyperspherical latent space\n",
    "ae = SAE(args.img_dim,\n",
    "         n_l=args.ae_layers, \n",
    "         depths=args.ae_channels,\n",
    "         encoding_depth=args.ae_encoding_depth, \n",
    "         scale_factor=1,\n",
    "         groups=1,\n",
    "         block_type='resnet')\n",
    "\n",
    "if args.ae_load_path is not None:\n",
    "    ae_state = torch.load(args.ae_load_path)\n",
    "    ae.load_state_dict(ae_state)\n",
    "else:\n",
    "    print(\"AE load path is None. Training a new AE...\")\n",
    "    train_ae(nn.DataParallel(ae), train_loader, args.epochs, args.lr, args.lr_epochs, args.lr_frac, args, device=device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "To efficiently evaluate the Neural Tangent Kernel, we used the closed-form implementation in Neural Tangents by Google (https://github.com/google/neural-tangents). However, this requires running JAX with GPU and Pytorch at the same time, which can be an issue when the memory of a single GPU is not sufficient. The current implementation places JAX arrays on the GPU 0 and Pytorch model on GPU 1 for efficiency, and options for other setups are also available at a cost of speed. In the future we plan to implement the associated functionality in pytorch, yet it may still requires allocating on different devices due to the potentially large kernel matrix."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "####################################################\n",
    "# If having > 1 gpus available\n",
    "device = \"cuda:1\"\n",
    "\n",
    "# If having 1 gpu available with enough memory\n",
    "# device = \"cuda:0\"\n",
    "# os.environ['XLA_PYTHON_CLIENT_PREALLOCATE'] = 'false'\n",
    "\n",
    "# If having no gpus or the memory is not available\n",
    "# device = \"cpu\"\n",
    "####################################################\n",
    "ae.to(device)\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Getting features from dataset...\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "20c6e0f1a73e4e539ae41adb6bdc4321",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=20.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "sample_size = args.pf_sample_size\n",
    "\n",
    "print(\"Getting features from dataset...\")\n",
    "loader = DataLoader(SubsetDataset(train_ds, sample_size, shuffle=True), batch_size=args.batch_size, drop_last=False, pin_memory=True, num_workers=4)\n",
    "feature_list = []\n",
    "label_list = []\n",
    "with torch.no_grad():\n",
    "    for i, (X, y) in enumerate(tqdm(loader)):\n",
    "        X = pre_process(X).float().to(device)\n",
    "        feature_batch = ae.encode(X)\n",
    "\n",
    "        feature_list.append(feature_batch)\n",
    "        if type(y) not in (list, tuple):\n",
    "            y = [y]\n",
    "        label_list.append(y)\n",
    "features = [torch.cat(f, dim=0) for f in zip(*feature_list)]\n",
    "labels = [torch.cat(l, dim=0) for l in zip(*label_list)]\n",
    "\n",
    "y_coord = features[0]\n",
    "y_class = labels[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ericaragorn/anaconda3/envs/pytorch/lib/python3.8/site-packages/jax/lax/lax.py:6198: UserWarning: Explicitly requested dtype <class 'jax.numpy.lax_numpy.float64'> requested in astype is not available, and will be truncated to dtype float32. To enable more dtypes, set the jax_enable_x64 configuration option or the JAX_ENABLE_X64 shell environment variable. See https://github.com/google/jax#current-gotchas for more.\n",
      "  warnings.warn(msg.format(dtype, fun_name , truncated_dtype))\n"
     ]
    }
   ],
   "source": [
    "kernel = NeuralKernel(args.ae_encoding_depth, 10000, n_layers=2, kernel_type='ntk', activation='erf')\n",
    "\n",
    "model = Kernel_Perron_Frobenius(kernel, \n",
    "                                features, \n",
    "                                labels=labels, \n",
    "                                preimage_method='gi', \n",
    "                                nystrom_compression=False, \n",
    "                                epsilon=1e-7, \n",
    "                                p_dim=-1, \n",
    "                                device=device).to(device)\n",
    "\n",
    "gamma_list = [1, 5, 10, 50, 100, 1000]\n",
    "print(\"Generating samples (Full kernel)\")\n",
    "for g in gamma_list:\n",
    "    sample_latent = []\n",
    "    for i in range(100):\n",
    "        latent, latent_top_inds = model.sample(100, topk=g)\n",
    "        samples = ae.decode(latent)\n",
    "        samples = post_process(samples).view(-1, *args.img_dim).permute(0, 2, 3, 1).detach().cpu().numpy()\n",
    "        \n",
    "        sample_latent.append(latent[0].squeeze())\n",
    "    \n",
    "    fig, ax = plt.subplots()\n",
    "    fig.set_size_inches((8, 8))\n",
    "    fill_image_grid((8, 8), ax, samples, \"Sampled points (gamma = {:d})\".format(g))\n",
    "    \n",
    "    plt.show()\n",
    "    plt.close(fig)\n",
    "    \n",
    "    all_y = torch.cat([_y.view(model.y_size, -1) for _y in model.y], dim=-1)\n",
    "    all_latent = torch.cat(sample_latent, dim=0).to(device)\n",
    "    mmd_score = poly_mmd(all_y, all_latent, deg=3)\n",
    "    print(\"MMD:\", mmd_score.item())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Notice that in the case where $\\lambda = 1$, the generator is simply outputing reconstructions of the training samples."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (pytorch)",
   "language": "python",
   "name": "pytorch"
  },
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
