{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test Saliency Overlap & Weight Randomization\n",
    "How often does the most NB boxes correlate with the most nb pixel ablation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import pickle\n",
    "import time\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt\n",
    "import torchvision.models as models\n",
    "import torch.nn as nn\n",
    "import torch\n",
    "\n",
    "import torch\n",
    "import numpy as np\n",
    "import torchvision\n",
    "import random\n",
    "\n",
    "import argparse\n",
    "import os\n",
    "import random\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.parallel\n",
    "import torch.backends.cudnn as cudnn\n",
    "import torch.optim as optim\n",
    "import torch.utils.data\n",
    "import torchvision.datasets as dset\n",
    "import torchvision.transforms as transforms\n",
    "import torchvision.utils as vutils\n",
    "import torchvision\n",
    "\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch\n",
    "\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import pickle\n",
    "import time\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import torchvision.models as models\n",
    "\n",
    "import seaborn as sns\n",
    "\n",
    "from sklearn.neighbors import KNeighborsClassifier\n",
    "\n",
    "from tqdm import tqdm\n",
    "from copy import deepcopy\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# How many test images to consider\n",
    "sample_size = 500"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_dataloaders(b_size=32, shuffle=False):\n",
    "\ttrain_transform = transforms.Compose(\n",
    "\t\t[transforms.ToTensor(),\n",
    "\t\t transforms.Normalize((0.5,), (0.5,), (0.5,))])\n",
    "\n",
    "\ttest_transform = transforms.Compose(\n",
    "\t\t[transforms.ToTensor(),\n",
    "\t\t transforms.Normalize((0.5,), (0.5,), (0.5,))])\n",
    "\n",
    "\ttrain_set = torchvision.datasets.FashionMNIST(\n",
    "\t\troot='./data/FashionMNIST',\n",
    "\t\ttrain=True,\n",
    "\t\tdownload=True,\n",
    "\t\ttransform=train_transform)\n",
    "\n",
    "\ttrain_loader = torch.utils.data.DataLoader(\n",
    "\t\ttrain_set,\n",
    "\t\tbatch_size=b_size,\n",
    "\t\tshuffle=shuffle,\n",
    "    num_workers=2)\n",
    "\n",
    "\ttest_set = torchvision.datasets.FashionMNIST(\n",
    "\t\troot='./data/FashionMNIST',\n",
    "\t\ttrain=False,\n",
    "\t\tdownload=True,\n",
    "\t\ttransform=test_transform)\n",
    "\n",
    "\ttest_loader = torch.utils.data.DataLoader(\n",
    "\t\ttest_set,\n",
    "\t\tbatch_size=b_size,\n",
    "\t\tshuffle=False,\n",
    "    num_workers=2)\n",
    " \n",
    "\treturn train_loader, test_loader\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class CNN(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(CNN, self).__init__()\n",
    "\n",
    "        # input is Z, going into a convolution\n",
    "        self.conv1 = nn.Conv2d(1, 8, kernel_size=5, stride=1, padding=2)\n",
    "        self.bn1   = nn.BatchNorm2d(8)\n",
    "\n",
    "        self.conv2 = nn.Conv2d(8, 16, kernel_size=5, stride=2, padding=2)\n",
    "        self.bn2 = nn.BatchNorm2d(16)\n",
    "\n",
    "        self.conv3 = nn.Conv2d(16, 32, kernel_size=5, stride=1, padding=2)\n",
    "        self.bn3 = nn.BatchNorm2d(32)\n",
    "\n",
    "        self.conv4 = nn.Conv2d(32, 64, kernel_size=5, stride=2, padding=2)\n",
    "        self.bn4 = nn.BatchNorm2d(64)\n",
    "\n",
    "        self.conv5 = nn.Conv2d(64, 128, kernel_size=3, stride=1, padding=1)\n",
    "        self.bn5 = nn.BatchNorm2d(128)\n",
    "        \n",
    "        self.avgpool = nn.AvgPool2d(7)\n",
    "        self.linear = nn.Linear(128, 10)    \n",
    "        self.relu = nn.ReLU()\n",
    "        \n",
    "\n",
    "        \n",
    "    def forward(self, I):   \n",
    "        x = self.relu(self.bn1(self.conv1(I)))\n",
    "        x = self.relu(self.bn2(self.conv2(x)))\n",
    "        x = self.relu(self.bn3(self.conv3(x)))\n",
    "        x = self.relu(self.bn4(self.conv4(x)))\n",
    "        C = self.relu(self.bn5(self.conv5(x)))\n",
    "        \n",
    "        \n",
    "        x = self.avgpool(C)\n",
    "        x = x.view(x.shape[0], x.shape[1])\n",
    "        logits = self.linear(x)\n",
    "        return logits, x, C"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Pre-Requisites for Algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_cnn():\n",
    "    netC = CNN()\n",
    "    netC.load_state_dict(torch.load('weights/cnn.pth', map_location=torch.device('cpu')))\n",
    "    netC = netC.eval().to(DEVICE)\n",
    "    return netC\n",
    "\n",
    "DEVICE = 'cpu'\n",
    "DATAROOT = 'data'\n",
    "netC = load_cnn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "class netClassifier(nn.Module):\n",
    "    \n",
    "    def __init__(self, netC):\n",
    "        super(netClassifier, self).__init__()\n",
    "        self.net = netC\n",
    "        \n",
    "    def forward(self, C):\n",
    "        x = self.net.avgpool(C)\n",
    "        x = x.view(-1, 128)\n",
    "        logits = self.net.linear(x)\n",
    "        return logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "net_classifier = netClassifier(netC).eval().to(DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "WEIGHTS = netC.linear.weight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_loader, test_loader = load_dataloaders(b_size=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train = train_loader.dataset.data\n",
    "y_train = train_loader.dataset.targets\n",
    "\n",
    "X_test = test_loader.dataset.data\n",
    "y_test = test_loader.dataset.targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train_c = np.load(DATAROOT + \"/X_train_cont.npy\")\n",
    "X_test_c = np.load(DATAROOT + \"/X_test_cont.npy\")\n",
    "\n",
    "X_train_C = np.load(DATAROOT + \"/X_train_conv.npy\")\n",
    "X_test_C = np.load(DATAROOT + \"/X_test_conv.npy\")\n",
    "\n",
    "X_train_x = np.load(DATAROOT + \"/X_train_x.npy\")\n",
    "X_test_x = np.load(DATAROOT + \"/X_test_x.npy\")\n",
    "\n",
    "train_preds = np.load(DATAROOT + \"/X_train_y.npy\")\n",
    "test_preds = np.load(DATAROOT + \"/X_test_y.npy\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Main Experiment:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_expt1(la, lb, df, tech, rand_layer):\n",
    "    \"\"\"\n",
    "    Collect Data comparing NN sets\n",
    "    \"\"\"\n",
    "    \n",
    "    nns = [1, 5, 10, 50, 100, 200, 500, 1000]\n",
    "    for i in tqdm(range(len(la))):\n",
    "        for nn in nns:\n",
    "            \n",
    "            row = pd.DataFrame(columns=['Overlap', 'Technique', 'NNs', 'LayerRand'])\n",
    "            \n",
    "            a = la[i][:nn]\n",
    "            b = lb[i][:nn]\n",
    "\n",
    "            overlap = len(set(a) & set(b)) / len(a)\n",
    "            \n",
    "            row['Overlap'] = [overlap]\n",
    "            row['Technique'] = tech\n",
    "            row['NNs'] = nn\n",
    "            row['LayerRand'] = rand_layer\n",
    "            \n",
    "            df = pd.concat([df, row])\n",
    "            \n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(columns=['Overlap', 'Technique', 'NNs', 'LayerRand'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_layers = 0\n",
    "for name, param in netC.named_parameters():\n",
    "    num_layers += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "def grad_cos(net, I, label):\n",
    "    \"\"\"\n",
    "    Implement Grad-Cos\n",
    "    Return: gradient of output loss classificaiton w.r.t. last linear layer x\n",
    "    \"\"\"\n",
    "    \n",
    "    net.zero_grad()\n",
    "    loss_fn = torch.nn.CrossEntropyLoss()\n",
    "    logits, x, C = net(I)\n",
    "    loss  = loss_fn(logits, label)\n",
    "    grad = torch.autograd.grad(loss, x, retain_graph=True, create_graph=True)\n",
    "    return grad[0]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Fit k-NNs with Methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Fit COLE (twin-system) \n",
    "\n",
    "twin = KNeighborsClassifier(n_neighbors=1, algorithm=\"brute\", metric='euclidean') \n",
    "twin.fit(X_train_c, train_preds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 60000/60000 [04:04<00:00, 245.02it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Fit Grad-Cos\n",
    "\n",
    "temp_train = list()\n",
    "\n",
    "for data in tqdm(train_loader):\n",
    "    img, label = data\n",
    "    x = grad_cos(netC, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    \n",
    "    if x.sum() == 0.:\n",
    "        temp_train.append(x)\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "        temp_train.append(x)\n",
    "    \n",
    "temp_train = np.array(temp_train)\n",
    "\n",
    "# Fit DkNN\n",
    "grad_twin = KNeighborsClassifier(n_neighbors=1, algorithm=\"brute\", metric='euclidean') \n",
    "grad_twin.fit(temp_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Fit DkNN\n",
    "\n",
    "temp_train = list()\n",
    "\n",
    "for i in range(X_train_x.shape[0]):\n",
    "    x = deepcopy(X_train_x[i].flatten())\n",
    "    if x.sum() == 0.:\n",
    "        temp_train.append(x)\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "        temp_train.append(x)\n",
    "    \n",
    "temp_train = np.array(temp_train)\n",
    "\n",
    "# Fit DkNN\n",
    "dknn_twin = KNeighborsClassifier(n_neighbors=1, algorithm=\"brute\", metric='euclidean') \n",
    "dknn_twin.fit(temp_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Fit ExMatchina\n",
    "\n",
    "temp_train = list()\n",
    "\n",
    "for i in range(X_train_C[:60000].shape[0]):\n",
    "    x = deepcopy(X_train_C[i].flatten())\n",
    "    if x.sum() == 0.:\n",
    "        temp_train.append(x)\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "        temp_train.append(x)\n",
    "            \n",
    "temp_train = np.array(temp_train)\n",
    "\n",
    "# Fit Exmatchina\n",
    "exmatchina_twin = KNeighborsClassifier(n_neighbors=1, algorithm=\"brute\", metric='euclidean') \n",
    "exmatchina_twin.fit(temp_train, y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "WEIGHTS = netC.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Weight Randomization Last Layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Changed This Layer: linear.weight\n",
      "Changed This Layer: linear.bias\n"
     ]
    }
   ],
   "source": [
    "netC2 = load_cnn()  # get \"new\" cnn\n",
    "count = 0\n",
    "rand_past_layer = num_layers - 2\n",
    "\n",
    "\n",
    "for name, param in netC2.named_parameters():\n",
    "\n",
    "    if count >= rand_past_layer:\n",
    "        param.data = torch.randn(param.shape).requires_grad_(True)\n",
    "        print(\"Changed This Layer:\", name)\n",
    "    else:\n",
    "        count += 1\n",
    "        \n",
    "WEIGHTS2 = netC2.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:29<09:29, 16.68it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Rand CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS2[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:22<00:00, 22.23it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Cosine_Grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:33<10:38, 14.88it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "        \n",
    "    #### Normal CNN\n",
    "    x = grad_cos(netC, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    x = grad_cos(netC2, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:21<00:00, 23.13it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:24<07:42, 20.55it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:22<00:00, 22.44it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [13:45<4:21:25,  1.65s/it]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "            \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.77it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'ExMatchina', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Second Task -- Randomize First  Conv Layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Changed This Layer: conv1.weight\n",
      "Changed This Layer: conv1.bias\n"
     ]
    }
   ],
   "source": [
    "netC2 = load_cnn()  # get \"new\" cnn\n",
    "count = 0\n",
    "rand_up_to_layer = 1\n",
    "\n",
    "\n",
    "for name, param in netC2.named_parameters():\n",
    "    if count <= rand_up_to_layer:\n",
    "        param.data = torch.randn(param.shape)\n",
    "        print(\"Changed This Layer:\", name)\n",
    "    count += 1\n",
    "        \n",
    "WEIGHTS2 = netC2.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:19<06:01, 26.31it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Rand CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS2[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.68it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Cosine_Grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:24<07:50, 20.18it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "        \n",
    "    #### Normal CNN\n",
    "    x = grad_cos(netC, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    x = grad_cos(netC2, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:22<00:00, 22.41it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:20<06:30, 24.31it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.37it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [13:44<4:21:13,  1.65s/it]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "            \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:29<00:00, 16.88it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'ExMatchina', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Third  -- Half of CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Changed This Layer: conv1.weight\n",
      "Changed This Layer: conv1.bias\n",
      "Changed This Layer: bn1.weight\n",
      "Changed This Layer: bn1.bias\n",
      "Changed This Layer: conv2.weight\n",
      "Changed This Layer: conv2.bias\n",
      "Changed This Layer: bn2.weight\n",
      "Changed This Layer: bn2.bias\n",
      "Changed This Layer: conv3.weight\n",
      "Changed This Layer: conv3.bias\n",
      "Changed This Layer: bn3.weight\n",
      "Changed This Layer: bn3.bias\n"
     ]
    }
   ],
   "source": [
    "netC2 = load_cnn()  # get \"new\" cnn\n",
    "count = 0\n",
    "rand_up_to_layer = 11\n",
    "\n",
    "\n",
    "for name, param in netC2.named_parameters():\n",
    "    if count <= rand_up_to_layer:\n",
    "        param.data = torch.randn(param.shape)\n",
    "        print(\"Changed This Layer:\", name)\n",
    "    count += 1\n",
    "        \n",
    "WEIGHTS2 = netC2.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:30<09:30, 16.64it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Rand CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS2[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:24<00:00, 20.20it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Cosine_Grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:33<10:30, 15.06it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "        \n",
    "    #### Normal CNN\n",
    "    x = grad_cos(netC, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    x = grad_cos(netC2, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:24<00:00, 20.79it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:28<09:02, 17.53it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:27<00:00, 18.07it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [15:07<4:47:29,  1.82s/it]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "            \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:33<00:00, 14.87it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'ExMatchina', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## All of CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Changed This Layer: conv1.weight\n",
      "Changed This Layer: conv1.bias\n",
      "Changed This Layer: bn1.weight\n",
      "Changed This Layer: bn1.bias\n",
      "Changed This Layer: conv2.weight\n",
      "Changed This Layer: conv2.bias\n",
      "Changed This Layer: bn2.weight\n",
      "Changed This Layer: bn2.bias\n",
      "Changed This Layer: conv3.weight\n",
      "Changed This Layer: conv3.bias\n",
      "Changed This Layer: bn3.weight\n",
      "Changed This Layer: bn3.bias\n",
      "Changed This Layer: conv4.weight\n",
      "Changed This Layer: conv4.bias\n",
      "Changed This Layer: bn4.weight\n",
      "Changed This Layer: bn4.bias\n",
      "Changed This Layer: conv5.weight\n",
      "Changed This Layer: conv5.bias\n",
      "Changed This Layer: bn5.weight\n",
      "Changed This Layer: bn5.bias\n",
      "Changed This Layer: linear.weight\n",
      "Changed This Layer: linear.bias\n"
     ]
    }
   ],
   "source": [
    "netC2 = load_cnn()  # get \"new\" cnn\n",
    "count = 0\n",
    "rand_up_to_layer = 30\n",
    "\n",
    "\n",
    "for name, param in netC2.named_parameters():\n",
    "    if count <= rand_up_to_layer:\n",
    "        param.data = torch.randn(param.shape)\n",
    "        print(\"Changed This Layer:\", name)\n",
    "    count += 1\n",
    "        \n",
    "WEIGHTS2 = netC2.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:28<09:07, 17.35it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Rand CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_pred = torch.argmax(query_logits, dim=1)[0].item()\n",
    "    query_cont = WEIGHTS2[query_pred] * query_x[0]\n",
    "    nn_idxs = twin.kneighbors(X=[query_cont.detach().numpy()], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:40<00:00, 12.43it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Cosine_Grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:36<11:29, 13.77it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "        \n",
    "    #### Normal CNN\n",
    "    x = grad_cos(netC, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    x = grad_cos(netC2, img, label)\n",
    "    x = x[0].detach().numpy()\n",
    "    if x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        x = (x - np.min(x))/np.ptp(x)\n",
    "    \n",
    "    nn_idxs = grad_twin.kneighbors(X=[x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:31<00:00, 16.03it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:24<07:43, 20.49it/s]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "    \n",
    "    # Get query information\n",
    "    query_label = y_test[query_idx].item()\n",
    "        \n",
    "        \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_x = query_x[0].detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_x.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_x = (query_x - np.min(query_x))/np.ptp(query_x)\n",
    "    \n",
    "    nn_idxs = dknn_twin.kneighbors(X=[query_x], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:34<00:00, 14.48it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [16:55<5:21:28,  2.03s/it]\n"
     ]
    }
   ],
   "source": [
    "#### First collect NN and query box information from Original Weights\n",
    "\n",
    "org_nns = list()\n",
    "rand_nns = list()\n",
    "\n",
    "\n",
    "for query_idx, data in enumerate(tqdm(test_loader)):\n",
    "    \n",
    "    # Get data\n",
    "    img, label = data\n",
    "    img, label = img.to(DEVICE), label.to(DEVICE)\n",
    "            \n",
    "    #### Real CNN\n",
    "    query_logits, query_x, query_C = netC(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    org_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    #### Random CNN\n",
    "    query_logits, query_x, query_C = netC2(img)\n",
    "    query_C = query_C.flatten().detach().numpy()\n",
    "    \n",
    "    # Cosine Similarity\n",
    "    if query_C.sum() == 0.:\n",
    "        pass\n",
    "    else:\n",
    "        query_C = (query_C - np.min(query_C))/np.ptp(query_C)\n",
    "    \n",
    "    nn_idxs = exmatchina_twin.kneighbors(X=[query_C], n_neighbors=1000, return_distance=False)[0]\n",
    "    rand_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    if query_idx == sample_size:\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:48<00:00, 10.43it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'ExMatchina', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Now Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [],
   "source": [
    "df['Technique'] = df['Technique'].replace({'twin-system':'Twin-System'})\n",
    "df['LayerRand'] = df['LayerRand'].replace({'linear':'Randomize Last Linear Layer',\n",
    "                                          'Conv1':'Randomize First Convolutional Layer',\n",
    "                                          'ConvHalf':'Randomize Half of Convolutions',\n",
    "                                          'AllCNN':'Randomize Entire CNN'})\n",
    "\n",
    "df = df.rename(columns={\"NNs\": \"Number of NNs Considered\"})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "#### Save 5 runs of experiment\n",
    "# df.to_csv('test1.csv')\n",
    "# df.to_csv('test2.csv')\n",
    "# df.to_csv('test3.csv')\n",
    "# df.to_csv('test4.csv')\n",
    "# df.to_csv('test5.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "#### Load for final analysis\n",
    "df1 = pd.read_csv('test1.csv')\n",
    "df2 = pd.read_csv('test2.csv')\n",
    "df3 = pd.read_csv('test3.csv')\n",
    "df4 = pd.read_csv('test4.csv')\n",
    "df5 = pd.read_csv('test5.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.concat([df1, df2, df3, df4, df5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomize First Convolutional Layer\n",
      "Twins: 0.13293433133732535\n",
      "DkNN: 0.06642470059880241\n",
      "ExMatchina: 0.5453485528942116\n",
      "Grad-Cos: 0.03245494011976048\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"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomize Last Linear Layer\n",
      "Twins: 0.15849476047904196\n",
      "DkNN: 1.0\n",
      "ExMatchina: 1.0\n",
      "Grad-Cos: 0.0021216566866267463\n"
     ]
    },
    {
     "data": {
      "image/png": "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S1V1WChjMcYYE1gou4aMMaZGeYah9rxmzpxZbvnk5GSGDBlSal5aWhp9+5b//K2tW7cyf/78CuNJTk4OeN/B4sWLK4ytJoX0iMAYY2qSZxjqyjhw4ADbt2+nY8eObNy4MajPeBLBVVddVYUoYdSoUYwaVXd6yO2IwBjToOXl5dGjRw82bdoEwNixY3n22We9yy+//HIWLFgAwD//+U/Gjh3rXbZ161aGDBlCeno66enpfPbZZwBMnTqV5cuXk5aWxuzZsykuLub222+nb9++9OvXj8cff9xbx+OPP056ejopKSl8840zIIPvQ3Kuu+46brnlFk4//XS6dOnC66+/DsDBgwcZPny497NvvfVWyL4jOyIwxoTEzr/8hcMbq3cY6ka9etLu7rvLXO4ZYsLjrrvu4oorrmDOnDlcd9113Hrrrezbt48bbrjBW+aSSy5h/Pjx3H777bz99tvMmzePl19+GXCeafD+++8TGxvLd999x9ixY8nIyGDmzJk8+OCDvPPOOwA8+eSTbN26lczMTKKioko916BVq1asWrWKv//97zz44IM899xzx8S9Y8cOPvnkE7755htGjRrFpZdeSmxsLIsWLaJZs2bs2bOHU089lVGjRnnHTapOlgiMMQ1GWV1DI0eO5F//+heTJk1izZo1pZa1bNmSxMREXn31VXr16kVcXJx3WWFhIZMnTyYzM5PIyEi+/fbbgOv94IMPmDhxIlFRTpPaokUL77KLL74YgAEDBrBw4cKAnx89ejQRERH07t2bXbt2AaCq3H333SxbtoyIiAiys7PZtWsX7dq1C/4LCZIlAmNMSJS3517TSkpK2LhxI3Fxcezbt48OHUo/afeKK65g0qRJzJ07t9T82bNn07ZtW9asWUNJSQmxsbGVXnejRo0A50R2oFFNfcsA3qepzZs3j5ycHFauXEl0dDTJyckUFBRUev3BsHMExpgGb/bs2fTq1Yv58+czfvx4CgtLP1xxzJgx/P73v+ecc84pNT8vL4/27dsTERHByy+/THFxMQDx8fGlHmAzcuTIUsNXB3rkZWXl5eXRpk0boqOj+eijj9i2bdtx11kWSwTGmAbDc47A85o6dSqbNm3iueee46GHHmLIkCEMHTqUP//5z6U+Fx8fz5133klMTEyp+b/5zW948cUXSU1N5ZtvvqFJkyYA9OvXj8jISFJTU5k9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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomize Entire CNN\n",
      "Twins: 0.0004284431137724552\n",
      "DkNN: 0.060050898203592815\n",
      "ExMatchina: 0.1367557385229541\n",
      "Grad-Cos: 0.0026328343313373253\n"
     ]
    },
    {
     "data": {
      "image/png": "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b2fkyJFs27aNkSNHsm/fPgoLC3nqqadK7TjQ1D2qSt6aNf6mo5yMDKdH1MRmxA8dQvygQU63FrHWI2ptVHcSxAc3w/YVlbvOlj3gzCmHLfLDDz/Qq1evUpd/9913LF++nCZNmlBYWMg777xDw4YN2bVrFyeddBLDhg3ju+++49VXXyUjI4PCwkJ69eoVNEF8//33QecDvP3222RkZLBs2TJ27drFiSeeyIABA5g5cyZDhgzhtttuw+v1cvDgwfK9B6bW8eXlcXDhIv+tqAVbnYEgY7p3p9k11xCXnk5M9+OsR9Q6oO4kiGpiwoQJfPHFF0RHRzNhwgQGDx7sH2BHVbn11luZP38+Ho+HrVu38uuvv7JgwQLOO+88/3gRw4YNK/d2v/jiC0aNGkVERAQtWrRg4MCBLFq0iBNPPJErrriCgoICRowYQWpqamXurqkhCnfuJPvzz52mo6++Rg8eRGJiiD3lFJpePY64gQOJatEi3GGaKlZ3EsQRvumHSvfu3Xnrrd/GPnryySfZtWsXaWlO1yexAafmL7/8Mjt37mTJkiVERUWRlJREbm5uqevevHmzfyyG8ePH0717d958881yxTdgwADmz5/P+++/z+WXX86f//znco2HbWomVSV35Up/53e5K5yz68hWrWg0fBjxgwbRoE8fPDExYY7UhFNIzxFFZKiIrBKRtSJySJ8PIjJeRFaISIaIfCEixwUsu8Wtt0pEhoQyzlA67bTTyM3N5amnnvLPK60ZZ+/evTRv3pyoqCjmzp3LRveukAEDBvDuu++Sk5PD/v37ee+99wBo164dGRkZZGRkMH78eE477TTy8vKYPn26f53Lly9nwYIF9O/fn9deew2v18vOnTuZP38+ffr0YePGjbRo0YKrrrqKP/7xj3z33XchfDdMOPlyctj/2Vy23XEnawems+H3F7DriSeRiAgSJ02i46x36fzZp7S6807iBgyw5GBCdwYhIhHAk8BgYAuwSERmq+rKgGIzVfVpt/ww4B/AUDdRXAR0B1oDn4hIF1X1hireUBER3n33XSZPnswDDzxAYmIisbGxTJ06lZycnGJlL774Ys4991x69OhBWloaXbt2BaBXr16MHDmSlJQUmjdvzoknnljqtt555x0mTZrE1KlTiYmJISkpiUcffZR+/frx9ddfk5KSgojwwAMP0LJlS1544QUefPBBoqKiiIuL48UXXwz5e2KqTsG2bU7T0dy5HPzmWzQvD09sLLH9+rk9ovYnsmnTcIdpqqmQdfctIicDd6nqEHf6FgBVDToyjoiMAi5T1TNLlhWRD911fV3a9qy77+rNPouqoT4fucuXs99tOsr76ScAotq1I25QutN01Ls3Yj2iGle4uvtuA2wOmN4C9C1ZSEQmAH8GooHTAup+U6Ku3VxtTBDe7GwOfFnUI+rnePfsgYgIGvTqRfO//pW4QelEd+xoPaKacgv7RWpVfRJ4UkRGA7cDY8paV0TGAeMA2rdvH5oAjamG8jdv9nd+d2DRYigowNOoEXH9+ztNR/1OJcIddtaYigplgtgKtAuYbuvOK82rQNGV3DLVVdXpwHRwmpiOJlhjqjMtLCRn6VJ/01H+unUARB9zDE0uu5T49HTqn3ACcpRP4xsTKJR/TYuAZBHpiHNwvwgYHVhARJJVdY07eTZQ9Ho2MFNE/oFzkToZWBjCWI2pdrx795K94Aun6WjBAnx790JUFLEnppEwciRx6QOJtjNnE0IhSxCqWigiE4EPgQjgeVX9QUTuARar6mxgooicARQAmbjNS26514GVQCEwoSbewWRMeagq+T//7DQdzZ3LwaVLweslokkT4k87zRlM59RTiIiLC3eopo4I6fmoqs4B5pSYd0fA6+sPU/c+4L7QRWdM+Gl+PgcXL/Y3HRVs2gRAva5daXrVH4lPTyemZ0/r1sKEhTVYhlhERAQ9evSgoKCAyMhILrvsMiZPnozH42HGjBksXryYJ554olidu+66iwceeIANGzbQvHlzAOLi4sjOzgac5x3+/Oc/8/DDDwPw0EMPkZ2dzV133VWl+2bKZvv99wPQ8tZbASjcvZvs+QvInjePA198ge/AASQ6mgYnn0TTK8Y63Vq0ahXOkI0BLEGEXP369cnIyABgx44djB49mn379nH33Xcftl6zZs14+OGHmTp16iHL6tWrx9tvv80tt9xCs2bNQhG2qUS5K39Ec3LY9fQ0sufOJWf5clAlsnlzGp59ttN0dFJfPG5fW8ZUF3beWoWaN2/O9OnTeeKJJyj5gOL777/PySefzK5duwC44ooreO2119izZ88h64mMjGTcuHE88sgjVRK3qRjNzyfztdfJXbGC3B9+YOejj6I+H80mTiDprTfp/Pk8Wt1zN/GnDbLkYKqlOnMGMXXhVH7a81OlrrNrk67c1OemctXp1KkTXq+XHTt2+Oe98847/OMf/2DOnDkkJCQATpPSFVdcwWOPPRb0bGPChAn07NmTG2+88eh2wlQ6zc8n65132TXtaQp/2YYnNpaoVq3o8NKLRCYmhjs8Y8qsziSI6uqzzz5j8eLFfPTRRzRs2LDYsuuuu47U1NSgQ4s2bNiQyy67jH/+85/Ur1+/qsI1h1EyMcSk9KTV3fewa9o0RMSSg6lx6kyCKO83/VBZv349ERER/ovPxxxzDOvXr2f16tX+LsCLNG7cmNGjR/Pkk08GXdekSZPo1asXY8eODXncpnSlJYbYfqciImQvmB/uEI2pkDqTIKqDnTt3Mn78eCZOnOjvF6dDhw48+OCDnH/++bzxxht07969WJ0///nPnHjiiRQWFh6yviZNmnDhhRfy3HPPccUVV1TJPpjfHCkxFCm6e8mYmsYuUodYTk4OqampdO/enTPOOIPf/e533HnnncXKdO3alZdffpk//OEPrHO7UCjSrFkzzjvvPPLy8oKu/y9/+Yv/wrapGkUXn9cOHcr2O+8kMjGRds88Q9KrrxLXv591imdqjZB1913VrLvv6q02fBaan0/Wu++y++lpFPzyCzEpPUmceO0hZwzG1CTh6u7bmFohWGJoefddxPazswVTu1mCMKYUlhhMXWcJwpgSLDEY47AEYYzLEoMxxVmCMHWeJQZjgrMEYeosSwzGHJ49BxFiERERpKam+n+mTJly2PJJSUn079+/2LzU1FSOP/74w9bbsGEDM2fOPGI8SUlJQZ+bmD179hFjqy00P5/M119n3dAz2X7HnUQkNqPdM9Pd5xj6W3IwxmVnECEW2N13We3fv5/NmzfTrl07fvzxxzLVKUoQo0ePPnLhIIYNG8awYcMqVLemsDMGY8rHziDCYO/evRx77LGsWrUKgFGjRvHMM8/4l1944YW89tprALzyyiuMGjXKv2zDhg3079+fXr160atXL7766isAbr75ZhYsWEBqaiqPPPIIXq+XG264geOPP56ePXvy+OOP+9fx+OOP06tXL3r06MFPPzk93M6YMYOJEycCcPnll3Pddddxyimn0KlTJ958800AsrOzOf300/11Z82aFcJ3qfLYGYMxFRPSMwgRGQo8hjMm9bOqOqXE8j8Df8QZd3oncIWqbnSXeYEVbtFN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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomize Half of Convolutions\n",
      "Twins: 0.07777105788423154\n",
      "DkNN: 0.055988173652694616\n",
      "ExMatchina: 0.47559870259481035\n",
      "Grad-Cos: 0.03225933133732535\n"
     ]
    },
    {
     "data": {
      "image/png": "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kduBAlWdD8wWkSOAemAHsEu30J7iDUFts4YMwzC8hMwQAKjqAmBBQNrNPr9bnX4aCjxuCOqK994j65wWY+CGYRgRSZuDzvUGmiKPNm7ds5lHhmEYvYmIMgSe6p3Oj6iIqrZhGMYuiSiNqO4ikbi83PAKYhhGSGgKQ930ueOOO3aZPzc3l6lTp/qlTZgwgbFjd73/1rp163j66ad3K09ubm7QdQfz58/frWxdSUjHCLob2uDEyOtzwQVhlsQwjFDQFIa6PVRUVLBhwwZycnL45ptv2nRNkyE488wzd585CLNmzWLWrFkdujYURFSPALdHIDERZf8MI6IpKytj9OjRrFq1CoAzzjiDf/zjH97zp556Ks8++ywA//73vznjjDO859atW8fUqVOZOHEiEydO5OOPPwbg+uuv54MPPmDChAncc889NDY2cs011zB27FjGjx/PX//6V28Zf/3rX5k4cSLjxo1j5UonIIPvJjnnnXcel19+OQcffDDDhw/nhRdeAKCyspIZM2Z4r/3Pf/4TsmcUURqxyTWEGQLDCDlFf/gDtd90bhjq+L3HMPDGG1s93xRiookbbriB0047jfvvv5/zzjuPK664gh07dnDRRRd58/z0pz/l/PPP55prruHVV1/lqaee4sknnwScPQ3eeustEhIS+O677zjjjDMoKCjgjjvu4K677uK1114D4MEHH2TdunUsXbqUmJgYv30N+vbtyxdffMHf/vY37rrrLh555JEWcm/evJkPP/yQlStXMmvWLE4++WQSEhJ4+eWXSUtLY/v27Rx44IHMmjXLGzepM4kojaj1jmtIYmPDLIlhGKGgNdfQzJkzef7557n00ktZtmyZ37k+ffqQmZnJM888w957701SUpL3XH19PbNnz2bp0qVER0fz7bffBr3v22+/zSWXXEKM28jMysrynjvppJMAmDRpEi+99FLQ60844QSioqLYZ5992LJlCwCqyo033sj7779PVFQUGzduZMuWLQwcOLDtD6SNRJghcF1DZggMI+TsquXe1Xg8Hr755huSkpLYsWMHQ4b477R72mmncemllzJv3jy/9HvuuYcBAwawbNkyPB4PCQkJ7b53vLsJVnR0dNCopr55AO9uak899RTbtm1j8eLFxMbGkpubS01NTbvv3xYiaoygabDYxggMI7K455572HvvvXn66ac5//zz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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomize All Convolutions\n",
      "Twins: 0.0027242015968063876\n",
      "DkNN: 0.06095209580838323\n",
      "ExMatchina: 0.1666121756487026\n",
      "Grad-Cos: 0.0030187624750499004\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": [
    "for l in df.LayerRand.value_counts().keys():\n",
    "    temp = df[df.LayerRand == l]\n",
    "    print(l)\n",
    "    print('Twins:', temp[temp.Technique == 'Twin-System'].Overlap.mean())\n",
    "    print('DkNN:', temp[temp.Technique == 'DkNN'].Overlap.mean())\n",
    "    print('ExMatchina:', temp[temp.Technique == 'ExMatchina'].Overlap.mean())\n",
    "    print('Grad-Cos:', temp[temp.Technique == 'Grad-Cos'].Overlap.mean())\n",
    "\n",
    "    g = sns.lineplot(x=\"Number of NNs Considered\", y='Overlap', hue='Technique', data=temp,\n",
    "                    err_style=\"bars\", ci=68)\n",
    "    plt.title(l)\n",
    "    plt.savefig('figs/' + l + '.pdf')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "img_env",
   "language": "python",
   "name": "img_env"
  },
  "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
