{
 "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\n",
    "from torchvision.utils import save_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",
      "Wednesday, 25. March 2020 09:18AM\n",
      "CPUs: 8, GPUs: 2 on axolotl.\n",
      "GPU : GeForce RTX 2080 Ti\n",
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "Model initialized with random key 466542068.\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": {
    "scrolled": true
   },
   "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": [
    "local_lr = 1e-4\n",
    "local_steps = 5\n",
    "use_updates = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "model.zero_grad()\n",
    "target_loss, _, _ = loss_fn(model(ground_truth), labels)\n",
    "input_parameters = inversefed.reconstruction_algorithms.loss_steps(model, ground_truth, labels, \n",
    "                                                        lr=local_lr, local_steps=local_steps,\n",
    "                                                                   use_updates=use_updates)\n",
    "input_parameters = [p.detach() for p in input_parameters]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "It: 8000. Rec. loss: 0.0027.\n",
      "Choosing optimal result ...\n",
      "Optimal result score: 0.0027\n",
      "Total time: 655.009913444519.\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=8_000,\n",
    "              total_variation=1e-6,\n",
    "              init='randn',\n",
    "              filter='none',\n",
    "              lr_decay=True,\n",
    "              scoring_choice='loss')\n",
    "\n",
    "rec_machine = inversefed.FedAvgReconstructor(model, (dm, ds), local_steps, local_lr, config,\n",
    "                                             use_updates=use_updates)\n",
    "output, stats = rec_machine.reconstruct(input_parameters, 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": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "defaultdict(list, {'opt': 0.002684175968170166})"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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.8.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
