{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "from PIL import Image"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Choose variants here:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "arch = 'ConvNet64'\n",
    "num_images = 1\n",
    "trained_model = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## System setup:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Currently evaluating -------------------------------:\n",
      "Friday, 13. March 2020 05:50PM\n",
      "CPUs: 8, GPUs: 2 on titan-rtx.\n",
      "GPU : TITAN RTX\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "Model initialized with random key 267693549.\n"
     ]
    }
   ],
   "source": [
    "import inversefed\n",
    "setup = inversefed.utils.system_startup()\n",
    "defs = inversefed.training_strategy('conservative')\n",
    "\n",
    "loss_fn, trainloader, validloader =  inversefed.construct_dataloaders('CIFAR10', defs)\n",
    "\n",
    "model, _ = inversefed.construct_model(arch, num_classes=10, num_channels=3)\n",
    "model.to(**setup)\n",
    "if trained_model:\n",
    "    epochs = 120\n",
    "    file = f'{arch}_{epochs}.pth'\n",
    "    try:\n",
    "        model.load_state_dict(torch.load(f'models/{file}'))\n",
    "    except FileNotFoundError:\n",
    "        inversefed.train(model, loss_fn, trainloader, validloader, defs, setup=setup)\n",
    "        torch.save(model.state_dict(), f'models/{file}')\n",
    "model.eval();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "dm = torch.as_tensor(inversefed.consts.cifar10_mean, **setup)[:, None, None]\n",
    "ds = torch.as_tensor(inversefed.consts.cifar10_std, **setup)[:, None, None]\n",
    "def plot(tensor):\n",
    "    tensor = tensor.clone().detach()\n",
    "    tensor.mul_(ds).add_(dm).clamp_(0, 1)\n",
    "    if tensor.shape[0] == 1:\n",
    "        return plt.imshow(tensor[0].permute(1, 2, 0).cpu());\n",
    "    else:\n",
    "        fig, axes = plt.subplots(1, tensor.shape[0], figsize=(12, tensor.shape[0]*12))\n",
    "        for i, im in enumerate(tensor):\n",
    "            axes[i].imshow(im.permute(1, 2, 0).cpu());"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Reconstruct"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Build the input (ground-truth) gradient"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "if num_images == 1:\n",
    "    ground_truth_image = torch.as_tensor(np.array(Image.open(\"auto.jpg\").resize((32, 32), Image.BICUBIC)) / 255, \n",
    "                                         **setup)\n",
    "    ground_truth = ground_truth_image.permute(2, 0, 1).sub(dm).div(ds).unsqueeze(0).contiguous()\n",
    "    labels = torch.as_tensor((1,), device=setup['device'])\n",
    "else:\n",
    "    ground_truth, labels = [], []\n",
    "    idx = 25 # choosen randomly ... just whatever you want\n",
    "    while len(labels) < num_images:\n",
    "        img, label = validloader.dataset[idx]\n",
    "        idx += 1\n",
    "        if label not in labels:\n",
    "            labels.append(torch.as_tensor((label,), device=setup['device']))\n",
    "            ground_truth.append(img.to(**setup))\n",
    "    ground_truth = torch.stack(ground_truth)\n",
    "    labels = torch.cat(labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['automobile']\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(ground_truth);\n",
    "print([validloader.dataset.classes[l] for l in labels]);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "model.zero_grad()\n",
    "target_loss, _, _ = loss_fn(model(ground_truth), labels)\n",
    "input_gradient = torch.autograd.grad(target_loss, model.parameters())\n",
    "input_gradient = [grad.detach() for grad in input_gradient]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It: 4000. Rec. loss: 0.0008.\n",
      "Choosing optimal result ...\n",
      "Optimal result score: 0.0008\n",
      "Total time: 100.14090347290039.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "config = dict(signed=True,\n",
    "              boxed=True,\n",
    "              cost_fn='sim',\n",
    "              indices='def',\n",
    "              weights='equal',\n",
    "              lr=0.1,\n",
    "              optim='adam',\n",
    "              restarts=1,\n",
    "              max_iterations=4000,\n",
    "              total_variation=1e-6,\n",
    "              init='randn',\n",
    "              filter='none',\n",
    "              lr_decay=True,\n",
    "              scoring_choice='loss')\n",
    "\n",
    "rec_machine = inversefed.GradientReconstructor(model, (dm, ds), config, num_images=num_images)\n",
    "output, stats = rec_machine.reconstruct(input_gradient, labels, img_shape=(3, 32, 32))\n",
    "\n",
    "test_mse = (output.detach() - ground_truth).pow(2).mean()\n",
    "feat_mse = (model(output.detach())- model(ground_truth)).pow(2).mean()  \n",
    "test_psnr = inversefed.metrics.psnr(output, ground_truth)\n",
    "\n",
    "plot(output)\n",
    "plt.title(f\"Rec. loss: {stats['opt']:2.4f} | MSE: {test_mse:2.4f} \"\n",
    "          f\"| PSNR: {test_psnr:4.2f} | FMSE: {feat_mse:2.4e} |\");"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1008x576 with 6 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = inversefed.metrics.activation_errors(model, output, ground_truth)\n",
    "\n",
    "fig, axes = plt.subplots(2, 3, sharey=False, figsize=(14,8))\n",
    "axes[0, 0].semilogy(list(data['se'].values())[:-3])\n",
    "axes[0, 0].set_title('SE')\n",
    "axes[0, 1].semilogy(list(data['mse'].values())[:-3])\n",
    "axes[0, 1].set_title('MSE')\n",
    "axes[0, 2].plot(list(data['sim'].values())[:-3])\n",
    "axes[0, 2].set_title('Similarity')\n",
    "\n",
    "convs = [val for key, val in data['mse'].items() if 'conv' in key]\n",
    "axes[1, 0].semilogy(convs)\n",
    "axes[1, 0].set_title('MSE - conv layers')\n",
    "convs = [val for key, val in data['mse'].items() if 'conv1' in key]\n",
    "axes[1, 1].semilogy(convs)\n",
    "convs = [val for key, val in data['mse'].items() if 'conv2' in key]\n",
    "axes[1, 1].semilogy(convs)\n",
    "axes[1, 1].set_title('MSE - conv1 vs conv2 layers')\n",
    "bns = [val for key, val in data['mse'].items() if 'bn' in key]\n",
    "axes[1, 2].plot(bns)\n",
    "axes[1, 2].set_title('MSE - bn layers')\n",
    "fig.suptitle('Error between layers');"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
