{
 "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",
    "\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": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_dataloaders(b_size=32, shuffle=False):\n",
    "\n",
    "    test_transform = transforms.Compose(\n",
    "        [transforms.ToTensor(),\n",
    "         transforms.Normalize((0.5,), (0.5,), (0.5,))])\n",
    "\n",
    "    train_transform = test_transform\n",
    "\n",
    "    train_set = torchvision.datasets.CIFAR10(\n",
    "        root='./data/CIFAR10',\n",
    "        train=True,\n",
    "        download=True,\n",
    "        transform=train_transform)\n",
    "\n",
    "    train_loader = torch.utils.data.DataLoader(\n",
    "        train_set,\n",
    "        batch_size=b_size,\n",
    "        shuffle=shuffle,\n",
    "    num_workers=2)\n",
    "\n",
    "    test_set = torchvision.datasets.CIFAR10(\n",
    "        root='./data/CIFAR10',\n",
    "        train=False,\n",
    "        download=True,\n",
    "        transform=test_transform)\n",
    "\n",
    "    test_loader = torch.utils.data.DataLoader(\n",
    "        test_set,\n",
    "        batch_size=b_size,\n",
    "        shuffle=False,\n",
    "    num_workers=2)\n",
    "\n",
    "    return train_loader, test_loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "train_loader, test_loader = load_dataloaders(b_size=1, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# class CNN(nn.Module):\n",
    "#     def __init__(self):\n",
    "#         super(CNN, self).__init__()\n",
    "#         self.main = nn.Sequential(\n",
    "\n",
    "#             # input is Z, going into a convolution\n",
    "#             nn.Conv2d(3, 8, kernel_size=5, stride=1, padding=2),\n",
    "#             nn.BatchNorm2d(8),\n",
    "#             nn.ReLU(True),\n",
    "            \n",
    "#             nn.Conv2d(8, 16, kernel_size=5, stride=2, padding=2),\n",
    "#             nn.BatchNorm2d(16),\n",
    "#             nn.ReLU(True),\n",
    "\n",
    "#             nn.Conv2d(16, 32, kernel_size=5, stride=1, padding=2),\n",
    "#             nn.BatchNorm2d(32),\n",
    "#             nn.ReLU(True),\n",
    "\n",
    "#             nn.Conv2d(32, 64, kernel_size=5, stride=2, padding=2),\n",
    "#             nn.BatchNorm2d(64),\n",
    "#             nn.ReLU(True),\n",
    "\n",
    "#             nn.Conv2d(64, 128, kernel_size=3, stride=1, padding=1),\n",
    "#             nn.BatchNorm2d(128),\n",
    "#             nn.ReLU(True),\n",
    "\n",
    "#             nn.Conv2d(128, 128, kernel_size=1, stride=1, padding=0),\n",
    "#             nn.BatchNorm2d(128),\n",
    "#             nn.ReLU(True)  \n",
    "#             )\n",
    "        \n",
    "#         self.avgpool = torch.nn.AvgPool2d(8)\n",
    "#         self.linear = torch.nn.Linear(128, 10)     \n",
    "\n",
    "        \n",
    "#     def forward(self, x):   \n",
    "#         C = self.main(x)\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": "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(3, 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.conv6 = nn.Conv2d(128, 128, kernel_size=1, stride=1, padding=0)\n",
    "        self.bn6 = nn.BatchNorm2d(128)\n",
    "        \n",
    "        self.avgpool = nn.AvgPool2d(8)\n",
    "        self.linear = nn.Linear(128, 10)    \n",
    "        self.relu = nn.ReLU()\n",
    "        \n",
    "\n",
    "        \n",
    "    def forward(self, I):  \n",
    "        \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",
    "        x = self.relu(self.bn5(self.conv5(x)))\n",
    "        C = self.relu(self.bn6(self.conv6(x)))\n",
    "        \n",
    "        x = self.avgpool(C)\n",
    "        x = x.view(x.shape[0], x.shape[1])\n",
    "        logits = self.linear(x)\n",
    "        \n",
    "        return logits, x, C"
   ]
  },
  {
   "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": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Pre-Requisites for Algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "DEVICE = 'cpu'\n",
    "DATAROOT = 'data'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "net_classifier = netClassifier(netC).eval().to(DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "WEIGHTS = netC.linear.weight"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "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": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_conv_nb_coords(C, pred):\n",
    "    cam = get_cam(C, pred)\n",
    "    N = 49\n",
    "    arr = cam.cpu().detach().numpy()\n",
    "    indices = largest_indices(arr, N)\n",
    "    results = list()\n",
    "    for c in zip(indices[0], indices[1]):\n",
    "        results.append([c[0], c[1]])\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_cam(C, pred):\n",
    "\ttest_weights = WEIGHTS[pred]\n",
    "\tC_conts = test_weights.reshape(test_weights.shape[0],1,1) * C\n",
    "\treturn C_conts.sum(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "def largest_indices(ary, n):\n",
    "    flat = ary.flatten()\n",
    "    indices = np.argpartition(flat, -n)[-n:]\n",
    "    indices = indices[np.argsort(-flat[indices])]\n",
    "    return np.unravel_index(indices, ary.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def box_agreement(a1, a2):\n",
    "    a1 = a1.tolist()\n",
    "    a2 = a2.tolist()\n",
    "    total_agreeement = 0\n",
    "    for i in range(len(a1)):\n",
    "        if a1[i] == a2[i]:\n",
    "            total_agreeement += 1\n",
    "    return total_agreeement / len(a1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Ensemble K-NN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "class EnsembleTwin():\n",
    "    \n",
    "    def __init__(self):\n",
    "        self.twins = list()\n",
    "    \n",
    "    def fit(self, X_train_c, train_preds, num_classes=10):\n",
    "        \n",
    "        \n",
    "        for i in range(num_classes):\n",
    "            \n",
    "            twin = KNeighborsClassifier()\n",
    "            mask = (train_preds == i)\n",
    "            \n",
    "            mask_idxs = list()\n",
    "            for i in range(len(mask)):\n",
    "                if mask[i] == True:\n",
    "                    mask_idxs.append(i)\n",
    "                    \n",
    "            twin_conts = X_train_c[mask]\n",
    "            twin_preds = train_preds[mask]\n",
    "            twin.fit(twin_conts, twin_preds)\n",
    "            self.twins.append([twin, mask_idxs])\n",
    "        \n",
    "\n",
    "    \n",
    "    def predict(self, query_cont, query_pred, nns=1):\n",
    "        idxs = self.twins[query_pred][0].kneighbors(X=[query_cont], \n",
    "                                                 n_neighbors=nns, \n",
    "                                                 return_distance=False)[0]\n",
    "        real_idxs = self.twins[query_pred][1]\n",
    "        results = list()\n",
    "        for i in range(len(idxs)):\n",
    "            real_idx = real_idxs[ idxs[i] ]\n",
    "            results.append(real_idx)\n",
    "        return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ensemble_twin = EnsembleTwin()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ensemble_twin.fit(X_train_c, train_preds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ensemble_twin.predict(X_test_c[0], test_preds[0], nns=5)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Ensemble Experiment Against Twins"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# #### First collect NN and query box information from Original Weights\n",
    "\n",
    "# twin_nns = list()\n",
    "# ensemble_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",
    "#     #### Twin\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",
    "#     twin_nns.append(nn_idxs.tolist())\n",
    "    \n",
    "    \n",
    "#     #### Ensemble Twin\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 = ensemble_twin.predict(query_cont.detach().numpy(), query_pred, nns=1000)\n",
    "#     ensemble_nns.append(nn_idxs)\n",
    "    \n",
    "#     if query_idx == sample_size:\n",
    "#         break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = evaluate_expt1(twin_nns, ensemble_nns, df, 'Compare', 'Normal')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.Overlap.mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Grad-Cos Method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "# class NetLinearClassifier(nn.Module):\n",
    "    \n",
    "#     def __init__(self, netC):\n",
    "#         super(NetLinearClassifier, self).__init__()\n",
    "#         self.net = netC\n",
    "        \n",
    "#     def forward(self, x):\n",
    "#         logits = self.net.linear(x)\n",
    "#         return logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# net_linearClassifer = netLinearClassifier(netC)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gradients_x(net, I, label):\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": [
    "# Main Experiment:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_expt1(la, lb, df, tech, rand_layer):\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": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(columns=['Overlap', 'Technique', 'NNs', 'LayerRand'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_size = 500"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_layers = 0\n",
    "\n",
    "for name, param in netC.named_parameters():\n",
    "    num_layers += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "WEIGHTS = netC.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Weight Randomization Last Layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "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",
    "netC2.train()\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",
    "netC2.train()\n",
    "netC2.eval()\n",
    "\n",
    "WEIGHTS2 = netC2.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Grad-Cos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 50000/50000 [03:54<00:00, 213.48it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "temp_train = list()\n",
    "\n",
    "for data in tqdm(train_loader):\n",
    "    img, label = data\n",
    "    x = get_gradients_x(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": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:29<09:22, 16.89it/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 = get_gradients_x(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 = get_gradients_x(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": 35,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:22<00:00, 22.34it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Fit COLE \n",
    "twin = KNeighborsClassifier(n_neighbors=1, algorithm=\"brute\", metric='euclidean') \n",
    "twin.fit(X_train_c, train_preds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:21<06:56, 22.82it/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",
    "    #### 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": 38,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:20<00:00, 23.96it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:21<06:42, 23.58it/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",
    "    #### 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": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:24<00:00, 20.41it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'linear')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "KNeighborsClassifier(algorithm='brute', metric='euclidean', n_neighbors=1)"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [14:34<4:36:48,  1.75s/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": 44,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:22<00:00, 22.01it/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": 45,
   "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",
    "for name, param in netC2.named_parameters():\n",
    "    if count <= rand_up_to_layer:\n",
    "        param.data = nn.Parameter(torch.randn(param.shape)).requires_grad_(True)\n",
    "        print(\"Changed This Layer:\", name)\n",
    "    count += 1\n",
    "   \n",
    "\n",
    "WEIGHTS2 = netC2.linear.weight"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Grad-Cos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:21<06:52, 23.05it/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 = get_gradients_x(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 = get_gradients_x(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": 47,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.69it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:16<05:10, 30.61it/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",
    "    #### 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": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.69it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:18<05:47, 27.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",
    "    #### 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": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:22<00:00, 21.80it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'Conv1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [14:37<4:37:56,  1.76s/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": 53,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.30it/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": 54,
   "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": [
    "## Grad-Cos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:29<09:23, 16.86it/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 = get_gradients_x(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 = get_gradients_x(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": 56,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:23<00:00, 21.76it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:26<08:15, 19.16it/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",
    "    #### 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": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:26<00:00, 19.06it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:24<07:49, 20.22it/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",
    "    #### 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": 60,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:32<00:00, 15.49it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [16:03<5:05:01,  1.93s/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": 62,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:30<00:00, 16.31it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'ExMatchina', 'ConvHalf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Fourth  -- All of Convs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "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: conv6.weight\n",
      "Changed This Layer: conv6.bias\n",
      "Changed This Layer: bn6.weight\n",
      "Changed This Layer: bn6.bias\n"
     ]
    }
   ],
   "source": [
    "netC2 = load_cnn()  # get \"new\" cnn\n",
    "count = 0\n",
    "rand_up_to_layer = 23\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": [
    "## Grad-Cos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:25<08:07, 19.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",
    "    #### Normal CNN\n",
    "    x = get_gradients_x(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 = get_gradients_x(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": 65,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:33<00:00, 14.82it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'ConvAll')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:19<06:15, 25.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",
    "    #### 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": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:35<00:00, 14.27it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'ConvAll')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:25<08:13, 19.24it/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",
    "    #### 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": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:36<00:00, 13.90it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'ConvAll')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [15:28<4:53:52,  1.86s/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": 71,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:29<00:00, 16.96it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'ExMatchina', 'ConvAll')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## All of CNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "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: conv6.weight\n",
      "Changed This Layer: conv6.bias\n",
      "Changed This Layer: bn6.weight\n",
      "Changed This Layer: bn6.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": [
    "## Grad-Cos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:30<09:40, 16.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",
    "    #### Normal CNN\n",
    "    x = get_gradients_x(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 = get_gradients_x(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": 74,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:31<00:00, 15.78it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Grad-Cos', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Twin-System"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:26<08:15, 19.16it/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",
    "    #### 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": 76,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:40<00:00, 12.27it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'Twin-System', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DkNN "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [00:26<08:17, 19.08it/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",
    "    #### 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": 78,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 501/501 [00:44<00:00, 11.22it/s]\n"
     ]
    }
   ],
   "source": [
    "df = evaluate_expt1(org_nns, rand_nns, df, 'DkNN', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExMatchina "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  5%|▌         | 500/10000 [17:32<5:33:24,  2.11s/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": 80,
   "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, 'ExMatchina', 'AllCNN')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Now Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "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",
    "                                          'ConvAll':'Randomize All Convolutions'})\n",
    "df = df.rename(columns={\"NNs\": \"Number of NNs Considered\"})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv('ensemble.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_temp = pd.read_csv('final_data.csv')\n",
    "# del df_temp['Unnamed: 0']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "# new_df = pd.concat([df, df_temp])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 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": 94,
   "metadata": {},
   "outputs": [],
   "source": [
    "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": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.concat([df1, df2, df3, df4, df5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv('final_data.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "# new_df.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Randomize Entire CNN\n",
      "Twins: 0.00328498003992016\n",
      "DkNN: 0.0069397205588822355\n",
      "ExMatchina: 0.07229785429141718\n",
      "Grad-Cos: 0.005825199600798403\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 First Convolutional Layer\n",
      "Twins: 0.008418612774451098\n",
      "DkNN: 0.00902984031936128\n",
      "ExMatchina: 0.07928058882235528\n",
      "Grad-Cos: 0.04939051896207585\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 Half of Convolutions\n",
      "Twins: 0.004438922155688623\n",
      "DkNN: 0.005911626746506986\n",
      "ExMatchina: 0.03039895209580838\n",
      "Grad-Cos: 0.04896327345309381\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 All Convolutions\n",
      "Twins: 0.0027810878243512975\n",
      "DkNN: 0.006539670658682635\n",
      "ExMatchina: 0.07231432135728544\n",
      "Grad-Cos: 0.04764326347305389\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.026155239520958086\n",
      "DkNN: 1.0\n",
      "ExMatchina: 1.0\n",
      "Grad-Cos: 0.0036798403193612768\n"
     ]
    },
    {
     "data": {
      "image/png": "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gLPPPptx48ZxxRVX8Morr1BUVESnTp24+eabeemll+jWrRvLly8nLy+Pm2++mSlTpnDfffcBcN1113H44YfzyCOPsHz5cvr378+RRx4JBMNdT5s2jdLSUnbffXfGjBnDtGnTuPLKK3nssce44oorGv95Jj6repZbDXxsZn82s3sS0yZvXUQkgw4++GDeeustJk2alBxyOjEoXDonn3wyAH379mXevHlpy9xwww1MmTKFo446iieeeIJjjgl+UjV8+PDk2EGPPPIIF1xwAQCHHHII559/Pg899BAVFRVp6/z3v//NLbfcQnFxMYMHD6a0tDR59nLYYYfRtm1bOnXqxHbbbZccAbVXr161trGh6vs7gmfDSUSkfup55J5JgwYNYvLkycyfP58TTjiBMWPGYGb88Ic/TFs+Pz8fCLp8Eo+zvOCCC5g2bRo77rgjEycGj1fZbbfduOSSS7jooovo1KkTy5Yto0ePHnTp0oXXXnuN999/n3HjxgHBBen33nuPF198kb59+zJ16tQa23V3nnnmGfbaa69qy997771kmyA4y0nMx2KxJnnkJtTzjMDdHwWeAt5190cTU5O0QEQkQwYOHMhf//pX9thjD2KxGO3bt2fixIkMGDCg3nX85S9/oaSkJJkEXnzxRRKDdX7++efE43HatWsHwIUXXsjZZ5/NqaeeSjweB+CLL77gBz/4ATfffDOdOnViwYIFtG3bllWrViW3cfTRR3Pvvfcm6502bVpT7H691XfQueOBEuD/hfPFeg6BiGzpCgsLcXcGDRoEwIABA2jXrh3bb799o+t8/PHH2WuvvSguLuacc85h3LhxyaA/dOhQVq9enewWArj66qvp1asXPXv25OCDD6aoqIjDDjuMmTNnJi8W//rXv6asrIzevXuz33778etf/3rTdryB6jUMtZlNJXhc5Rvuvn+47BN375nh9tWgYahFtlzZPgz1lClTuPLKK5v9ofQNHYa6vtcIytx9hZlFl1U2rokiIi3PLbfcwgMPPJC8NrA1qe9dQzPM7EwgbmZ7mNm9wNsZbJeIyFbl2muvZf78+Q26/rClqG8iuBTYD1gPPAGsAK7IUJtERGQzqm/X0N7ufj1wfSYbIyIim199zwhuN7NZZva/ZrbZLxCLiEjm1Pd3BIcBhwFLgD+Z2cdm9quMtkxERDaLhjyq8ht3vwcYQfCbghsy1SgRkcaIx+MUFxez3377UVRUxO23305lZXCD49ixYxk1alSN94wePZpWrVrx7bffJpe1adMm+drM+PnPf56cv+222xo87PSWrr4/KNvHzEaHzye4F3gH6J7RlomINNA222xDSUkJM2bM4OWXX+Zf//oXN9208WdpdezYkdtvvz3tuvz8fJ599lmWLl3a1M3dYtT3jOAvQAXwU+AYd/+Du3+7kfeIiDSbzp078+CDD3LfffeR+sPZF198kYMOOigZ3IcPH8748ePTDuuck5PDxRdfzJ133rlZ2t0cNvaEshzgt8DuwEnh1MPM/gJc7+5lmW+iiGyNxrw/hk+/+7RJ69y7/d5c0/+aepffddddqaioqNbt89xzz3HHHXcwceLE5FATbdq0Yfjw4dx9991pzyBGjhxJ7969+cUvfrHpO7EF2tgZwe+B9sAu7t7H3fsAuwHtgNsy3DYRkSb12muvMWbMGF588cUa4w1ddtllPProo9UGg0vYdtttOffcc7nnnpY5+n59HlW5p0fOq9x9pZldAnwKXJ7JxonI1qshR+6ZMnfuXOLxOJ07dwaC4aPnzp3LZ599Rr9+1YfdadeuHWeeeSb3339/2rquuOIK+vTpU21AuZZiY2cE7mlGpXP3Cup4qH2CmR1jZrPNbI6ZXVtHuR+bmZtZ2gGRREQaasmSJYwYMYJRo0aRGCdt55135plnnuHcc89lxowZNd7zs5/9jD/96U9px/lv3749p512Gn/+858z3vbNbWOJYKaZnZu60MzOJjgjqJWZxYH7gWOBfYFhZrZvmnJtCc4s3qtvo0VE0lm3bl3y9tEjjzySo446ihtvvLFamb333ptx48Zx6qmn8sUXX1Rb17FjR0466STWr1+ftv6f//znLfLuoTqHoTazbgRPJlsHJB6r0w/YBjjJ3RfV8d6DgNHufnQ4/0sAd/9dSrm7gJeBq4Gr3L3OMaY1DLXIlivbh6HeUjR0GOo6zwjcfZG7/wC4GZgXTje7e/+6kkCoG7AgMr8wXBZtWB+gh7u/WFdFZnaxmU0xsylLlizZyGZFRKQh6jXonLu/BrzWlBs2sxhwB3B+Pbb/IPAgBGcETdkOEZFsV+8hJhphEdAjMt89XJbQFugJvGFm84ADgQm6YCwisnllMhF8AOxhZruYWR5wBpB8zrG7r3D3ju5e6O6FwLvA0I1dIxARkaaVsUTg7uXAKOAlYBbwlLvPMLObzWxoprYrIiINU98H0zSKu08EJqYsSztqqbsPzmRbREQkvUx2DYmIbFaJYagT0y233FJn+cLCQgYOHFhtWXFxMT171v38rXnz5vHEE09stD2FhYVpf3cwYcKEjbZtc8roGYGIyOaUGIa6IVatWsWCBQvo0aMHs2bNqtd7EongzDPPbEQrYejQoQwduuX0kOuMQERatBUrVrDXXnsxe/ZsAIYNG8ZDDz2UXH/aaacxfvx4AP72t78xbNiw5Lp58+YxcOBA+vTpQ58+fXj77bcBuPbaa5k8eTLFxcXceeedVFRUcNVVV9GzZ0969+7Nvffem6zj3nvvpU+fPvTq1YtPPw0GZIg+JOf888/nsssu4+CDD2bXXXfl6aefBmD16tUcccQRyff+4x//yNhnpDMCEcmIb377W9bPatphqPP32Zsdrruu1vWJISYSfvnLX3L66adz3333cf7553P55Zfz/fffc9FFFyXL/PjHP+aCCy7gqquu4p///Cfjxo3j8ccfB4JnGrz88ssUFBTw+eefM2zYMKZMmcItt9zCbbfdxgsvvADAAw88wLx58ygpKSEnJ6facw06duzIhx9+yB/+8Aduu+02Hn744Rrt/vrrr3nzzTf59NNPGTp0KKeccgoFBQU899xzbLvttixdupQDDzyQoUOHJsdNakpKBCLSYtTWNTRkyBD+/ve/M3LkSKZPn15tXYcOHdh+++158skn2WeffWjVqlVyXVlZGaNGjaKkpIR4PM5nn32WdruvvPIKI0aMICcnCKnt27dPrjv55JMB6Nu3L88++2za95944onEYjH23XdfFi9eDIC7c9111zFp0iRisRiLFi1i8eLF7LDDDvX/QOpJiUBEMqKuI/fNrbKyklmzZtGqVSu+//57unev/qTd008/nZEjRzJ27Nhqy++88066dOnC9OnTqayspKCgoMHbzs/PB4IL2elGNY2WAZJPUxs3bhxLlixh6tSp5ObmUlhYSGlpaYO3Xx+6RiAiLd6dd97JPvvswxNPPMEFF1xAWVn1hyuedNJJ/OIXv+Doo4+utnzFihV07dqVWCzG448/TkVFBQBt27at9gCbIUOGVBu+Ot0jLxtqxYoVdO7cmdzcXF5//XXmz5+/yXXWRolARFqMxDWCxHTttdcye/ZsHn74YW6/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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",
    "    \n",
    "    g = sns.lineplot(x=\"Number of NNs Considered\", y='Overlap', hue='Technique', data=temp)\n",
    "    plt.title(l)\n",
    "#     plt.ylim(0, 1.1)\n",
    "#     g.set_yscale('log')\n",
    "\n",
    "\n",
    "#     axes = plt.gca()\n",
    "#     axes.set_ylim([-0.01,1.5])\n",
    "\n",
    "    plt.savefig('figs/' + l + '.pdf')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0005588822355289422"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[(df['Number of NNs Considered'] == 5) & (df.Technique == 'Twin-System')].Overlap.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv('new_df.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(80160, 4)"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.shape"
   ]
  },
  {
   "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
}
