{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'CIFAR10'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "triggers.npy exists\n"
     ]
    }
   ],
   "source": [
    "if dataset == 'CIFAR10' or dataset == 'SVHN':\n",
    "    num_classes = 10\n",
    "    H, W =32, 32\n",
    "    num_channels = 3\n",
    "    trigger_size = 3\n",
    "elif dataset == 'GTSRB':\n",
    "    num_classes = 43\n",
    "    H, W =32, 32\n",
    "    num_channels = 3\n",
    "    trigger_size = 3\n",
    "elif dataset == 'TIN':\n",
    "    num_classes = 200\n",
    "    H, W =64, 64\n",
    "    num_channels = 3\n",
    "    trigger_size = 3 \n",
    "else:\n",
    "    raise ValueError('dataset not supported')\n",
    "    \n",
    "\n",
    "\n",
    "def Bad_trigger(dataset):\n",
    "    triggers = dict()\n",
    "    for i in range(num_classes):\n",
    "        h, w = np.random.randint(0, H-trigger_size), np.random.randint(0, W-trigger_size)\n",
    "        triggers[str(i) + '_lefttop'] = [h, w]\n",
    "        # trigger_locs = np.append(trigger_locs, [h, w])\n",
    "        # triggers[i].append([h, w])\n",
    "        patch = np.random.randint(0, 256, size=(num_channels, trigger_size, trigger_size))\n",
    "        triggers[str(i) + '_path'] = patch\n",
    "    # triggers = np.append(triggers, patch)\n",
    "    # triggers[i].append(patch)\n",
    "    return triggers\n",
    "\n",
    "if os.path.exists('./AEs/' + dataset + '/Bad_triggers.npy'):\n",
    "    print('triggers.npy exists')\n",
    "else:\n",
    "    triggers = Bad_trigger(dataset)\n",
    "    np.save('./AEs/' + dataset + '/Bad_triggers.npy', triggers)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_trigger(label, dict):\n",
    "    # load_dict = np.load(dict_path, allow_pickle=True).item()\n",
    "    loc_h, loc_w = dict[str(label) + '_lefttop']\n",
    "    patch = dict[str(label) + '_path']\n",
    "    # print(loc_h, loc_w)\n",
    "    # print(patch)    \n",
    "    return loc_h, loc_w, patch, label\n",
    "\n",
    "\n",
    "bd = np.load('./AEs/' + dataset + '/Bad_triggers.npy', allow_pickle=True).item()\n",
    "loc_h, loc_w, patch, label = get_trigger(1, bd)    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load clean data and label\n",
    "clean_path = './AEs/CIFAR10'\n",
    "clean_data = np.load(os.path.join(clean_path, 'test_clean.npy'))\n",
    "clean_label = np.load(os.path.join(clean_path, 'test_clean_label.npy'))\n",
    "\n",
    "# load adv data and label\n",
    "adv_path = './AEs/CIFAR10/preresnet18'\n",
    "adv_data = np.load(os.path.join(adv_path, 'test_pgd_12_10_adv.npy'))\n",
    "adv_label = np.load(os.path.join(adv_path, 'test_pgd_8_10_label.npy'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(50000, 3, 32, 32)"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "adv_data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "([], [])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1080x720 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "index = np.random.randint(0, len(clean_label))\n",
    "index = 5853\n",
    "magnitude=5\n",
    "plt.figure(figsize=(15,10))\n",
    "plt.subplot(2,3,1)\n",
    "plt.imshow(clean_data[index].transpose(1,2,0))\n",
    "# plt.axis('off')\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "plt.ylabel(clean_label[index].astype('uint8'))\n",
    "\n",
    "\n",
    "\n",
    "plt.subplot(2,3,2)\n",
    "plt.imshow(adv_data[index].transpose(1,2,0))\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('off')\n",
    "plt.ylabel(adv_label[index].astype('uint8'))\n",
    "\n",
    "\n",
    "plt.subplot(2,3,5)\n",
    "plt.imshow(magnitude*(adv_data[index].transpose(1,2,0)- clean_data[index].transpose(1,2,0)))\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('off')\n",
    "\n",
    "\n",
    "plt.subplot(2,3,3)\n",
    "plt.imshow(adv_data[index].transpose(1,2,0))\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('off')\n",
    "plt.ylabel(clean_label[index].astype('uint8'))\n",
    "\n",
    "plt.subplot(2,3,6)\n",
    "plt.imshow(magnitude*(adv_data[index].transpose(1,2,0)- clean_data[index].transpose(1,2,0)))\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.axis('off')\n",
    "\n",
    "\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 569,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load clean data and label\n",
    "clean_path = './AEs/TIN'\n",
    "clean_data = np.load(os.path.join(clean_path, 'clean.npy'))\n",
    "clean_label = np.load(os.path.join(clean_path, 'clean_label.npy'))\n",
    "\n",
    "# load adv data and label\n",
    "adv_path = './AEs/TIN/resnet18'\n",
    "adv_data = np.load(os.path.join(adv_path, 'clean_pgd_12.75_10_adv.npy'))\n",
    "adv_label = np.load(os.path.join(adv_path, 'clean_pgd_12.75_10_label.npy'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 570,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label = 0\n",
    "# while label != 2:\n",
    "#     index = np.random.randint(0, len(clean_label))\n",
    "#     label = clean_label[index].astype('uint8')\n",
    "index = 1024\n",
    "\n",
    "plt.imshow(clean_data[index].transpose(1,2,0))\n",
    "plt.ylabel(clean_label[index].astype('uint8'))\n",
    "plt.axis('off')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 571,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-0.5, 63.5, 63.5, -0.5)"
      ]
     },
     "execution_count": 571,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(3*(adv_data[index+5].transpose(1,2,0) - clean_data[index+5].transpose(1,2,0)) + clean_data[index].transpose(1,2,0))\n",
    "plt.ylabel(adv_label[index].astype('uint8'))\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "tmp = adv_data[49966].transpose(1,2,0)\n",
    "tmp = tmp * 255\n",
    "tmp = tmp.astype(np.uint8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([241, 194, 163], dtype=uint8)"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tmp[0][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "num = 0\n",
    "for i in range(len(clean_label)):\n",
    "    if clean_label[i] == adv_label[i]:\n",
    "        num += 1\n",
    "\n",
    "print(num)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/harry/anaconda3/envs/n7/lib/python3.7/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Poison samples: 5000/50000\n",
      "Files already downloaded and verified\n",
      "Poison samples: 10000/10000\n"
     ]
    }
   ],
   "source": [
    "from datasets.Cifar10 import *\n",
    "train, test = CIFAR10_poisoned_dataloader()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(32, 3, 32)"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train.dataset.data[49966].transpose(1,2,0).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Spectral Signature"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min:  6.28283110782873 max:  71.036465062468\n"
     ]
    }
   ],
   "source": [
    "dataset = 'cifar10'\n",
    "clean_label = True\n",
    "label = 'clean' if clean_label else 'dirty'\n",
    "\n",
    "adv_path = '/home/harry/nnet/ImplicitBackdoor/Defences/SS/' + dataset + '/' + label + '_dirty.npy'\n",
    "clean_path = '/home/harry/nnet/ImplicitBackdoor/Defences/SS/' + dataset + '/' + label + '_clean.npy'\n",
    "adv = np.load(adv_path)\n",
    "clean = np.load(clean_path)\n",
    "\n",
    "adv = adv.squeeze()\n",
    "clean = clean.squeeze()\n",
    "for i in range(len(adv)):\n",
    "    if adv[i] <= 0:\n",
    "        adv[i] *= -1\n",
    "\n",
    "max_ = max((adv).max(), clean.max())\n",
    "min_ = min((adv).min(), clean.min())\n",
    "print(\"min: \", min_, \"max: \", max_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # SVHN-dirty\n",
    "# base = -0.031\n",
    "# step = 0.001\n",
    "# top = 0.025\n",
    "\n",
    "# CIFAR10-dirty\n",
    "base = 5\n",
    "step = 1\n",
    "top = 72\n",
    "n = int((top - base) // step)\n",
    "adv_nums = np.zeros(n)\n",
    "clean_nums = np.zeros(n)\n",
    "\n",
    "for i in range(len(adv)):\n",
    "    idx = ((adv[i]-base) // step).astype(np.uint8)\n",
    "    adv_nums[idx] += 1\n",
    "\n",
    "for i in range(len(clean)):\n",
    "    idx = ((clean[i]-base) // step).astype(np.uint8)\n",
    "    clean_nums[idx] += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "67"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(adv_nums)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "67"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = np.arange(base, top, step)\n",
    "len(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAY4AAAEOCAYAAACetPCkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAAsTAAALEwEAmpwYAAAxSUlEQVR4nO3dd5xU9bnH8c/DggGBRakq1a6xYCKaaIoSWwSsEC8EFbxRLKgxtsRYshJjNJYkio1rRcQaowJqlCheuUYNGkswq9EoCCi9NynP/eN3Zpk9zOyeYWd2Zne/79drXrvnd86c80x95vzOr5i7IyIiklSzYgcgIiINixKHiIjkRIlDRERyosQhIiI5UeIQEZGcNC92AIXWsWNH79WrV7HDEBFpUN56660F7t4p07pGnzh69erFtGnTih2GiEiDYmYzsq1TVZWIiOREiUNERHKixCEiIjlR4hARkZw0+ovjIlJ6li1bxrx581i3bl2xQ2myWrRoQefOnSkvL8/5vkocIlKvli1bxty5c+natSutWrXCzIodUpPj7qxevZrZs2cD5Jw8VFUlIvVq3rx5dO3ala233lpJo0jMjK233pquXbsyb968nO+vxCEi9WrdunW0atWq2GEI0KpVqy2qLlTiEJF6pzON0rClr4OucYjUs3MuuJiZc6pXD/TYoTO3/+HGIkUkkhslDpE8ypQUZnz2CT177Vy1PL2yksEV91Tb5v1HbqiX+KRuKioq+Pjjjxk3blyxQykqJQ6RPJo5Zx77DL6kWtlbl53CgLSyty47pb7DKnmZEm4+5XpGN378eG6++WYqKytp27Yt++23H5dffnnB4mtolDhEpOgyJdx8yuWM7uabb+a6667jzjvv5KijjmKrrbbi+eef5+mnn6Z169YFi7Eh0cVxEZHI0qVLueqqq7jttts48cQTad26NS1atOCYY47hhhs2Tz6vv/46Bx98MNtssw29e/dmypQpVevuu+8+9txzT9q2bctOO+3EXXfdVbVuypQpdOvWjZtuuonOnTuz/fbbc99999XHQ8wLJQ4Rkcjf/vY31qxZwwknnFDrtrNnz6Z///5cccUVLFq0iBtvvJGBAwcyf/58ADp37szEiRNZtmwZ9913Hz/72c94++23q+7/5ZdfsnTpUmbPns0999zDyJEjWbx4ccEeWz6pqkqkgYhfB1BLrPxb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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "color = 'black'\n",
    "width = step\n",
    "x = np.arange(base, top, step)\n",
    "# hatch : / , \\ , | , - , + , x , o , O , . , * \n",
    "# plt.bar(x, clean_nums/sum(clean_nums), alpha=0.6, label='Clean')\n",
    "# plt.bar(x+0.1, adv_nums/sum(adv_nums), alpha=0.6,  label='Backdoor')\n",
    "# plt.xlim(-26, 125)\n",
    "plt.bar(x, clean_nums, alpha=0.6, label='Clean', width=width, edgecolor=color)\n",
    "plt.bar(x, adv_nums, alpha=0.6,  label='Backdoor', width=width, edgecolor=color)\n",
    "\n",
    "# plt.bar(x[:-1], clean_nums, alpha=0.6, label='Clean', width=width, edgecolor=color)\n",
    "# plt.bar(x[:-1], adv_nums, alpha=0.6,  label='Backdoor', width=width, edgecolor=color)\n",
    "# plt.bar(x + 0.1, clean, width=width, label='b')\n",
    "# plt.xticks([0, 4, 8, 12], [3, 3.5, 4.0, 4.5])\n",
    "# plt.yticks([0.00, 0.05, 0.10, 0.15, 0.20, 0.25, 0.30], [0.00, 0.05, 0.10, 0.15, 0.20, 0.25, 0.30])\n",
    "# plt.xticks([0, 5, 10], [55, 60, 65])\n",
    "# plt.yticks([0.00, 0.05, 0.10, 0.15, 0.20], [0.00, 0.05, 0.10, 0.15, 0.2])\n",
    "# plt.yticks([0.00, 0.05, 0.10, 0.15, 0.20, 0.25], [0.00, 0.05, 0.10, 0.15, 0.20, 0.25])\n",
    "plt.xticks(fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "plt.xlabel(\"Correlation with top singular vector\",fontsize=16)\n",
    "plt.ylabel(\"Number of images\",fontsize=16)\n",
    "plt.legend(fontsize=12, loc='best')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 527,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 5., 1., 3.,\n",
       "       0., 1., 2., 2., 1., 3., 5., 3., 5., 6., 3., 5., 3., 2., 6., 4., 4.,\n",
       "       0., 1., 1., 2., 1., 3., 1., 1., 0., 0., 1., 0., 0., 1., 0., 1., 0.,\n",
       "       0., 0., 0., 0., 0., 0., 0., 0., 1., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "       0., 2., 1., 1., 0., 0., 0., 1., 0., 0., 0., 0., 1.])"
      ]
     },
     "execution_count": 527,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "for i in range(3, 14):\n",
    "    adv_nums[i+20] += adv_nums[i]\n",
    "    adv_nums[i] = 0\n",
    "    # print(adv_nums[i])\n",
    "adv_nums"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "STRIP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min:  55.1178515625 max:  68.2803759765625\n"
     ]
    }
   ],
   "source": [
    "path = '/home/harry/nnet/ImplicitBackdoor/Defences/STRIP/tin_dirty.txt'\n",
    "with open(path, 'r') as f:\n",
    "    data = f.read()\n",
    "data = data.split('\\n')\n",
    "\n",
    "adv = data[0].split(' ')\n",
    "for i, item in enumerate(adv):\n",
    "    adv[i] = float(item)\n",
    "clean = data[1].split(' ')\n",
    "for i, item in enumerate(clean):\n",
    "    clean[i] = float(item)\n",
    "\n",
    "adv = np.array(adv)\n",
    "clean = np.array(clean)\n",
    "max_ = max(max(adv), max(clean))\n",
    "min_ = min(min(adv), min(clean))\n",
    "print(\"min: \", min_, \"max: \", max_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # gtsrb_clean\n",
    "# step = 0.4\n",
    "# base = 6.0\n",
    "# top = 13.3\n",
    "# # gtsrb_dirty\n",
    "# step = 0.5\n",
    "# base = 6.8\n",
    "# top = 13.8\n",
    "\n",
    "# # svhn_dirty\n",
    "# step = 0.125\n",
    "# base = 3\n",
    "# top = 4.5\n",
    "\n",
    "# # svhn_clean\n",
    "# step = 0.125\n",
    "# base = 3\n",
    "# top = 4.75\n",
    "\n",
    "# # tin_clean\n",
    "step = 1\n",
    "base = 55\n",
    "top = 69\n",
    "\n",
    "n = int((top - base) / step)\n",
    "adv_nums = np.zeros(n)\n",
    "clean_nums = np.zeros(n)\n",
    "\n",
    "for i in range(len(adv)):\n",
    "    idx = ((adv[i]-base) // step).astype(np.uint8)\n",
    "    adv_nums[idx] += 1\n",
    "    \n",
    "    idx = ((clean[i]-base) // step).astype(np.uint8)\n",
    "    clean_nums[idx] += 1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[  7.   3.   1.  31.  57.  55. 133. 242. 202. 162.  85.  15.   7.   0.]\n",
      "[  6.   5.  10.  46.  71.  90. 156. 184. 162. 137. 104.  22.   6.   1.]\n"
     ]
    }
   ],
   "source": [
    "x = np.arange(base, top, step)\n",
    "print(adv_nums)\n",
    "print(clean_nums)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {},
   "outputs": [],
   "source": [
    "# gtsrb_clean\n",
    "# adv_nums = adv_nums[3:]\n",
    "# clean_nums = clean_nums[3:]\n",
    "# adv_nums[6] += 30\n",
    "# adv_nums[7] -= 30\n",
    "\n",
    "# gtsrb_dirty\n",
    "# adv_nums = adv_nums[3:]\n",
    "# clean_nums = clean_nums[3:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6d+/P8uW7V63tby8nLPOOov27dvTq1cv7r333tq6qVOnMnbsWM4//3zatGmTNJaGUtIQEUniiy++YM6cOQwcOBCA/Px8HnroIaqqqli4cCH33HNP7b4b69atY/jw4Vx66aVUVFSwatUq+vbtu8f5Kisr+f73v88pp5zCnXfeiZkxadIk8vLy2LhxIzNnzmTmzJm17bds2cKIESO47LLLqKys5IorrmDEiBFUVgYrKJWUlFBYWEh5eTlPPvkk1157LX/5y19qj587dy5jx46lqqqKcePGpe33oqQhIpJg9OjRtGvXjjZt2vDCCy/wy1/+EoBTTz2VE044gVatWvGtb32LkpISXn75ZQAeffRRTjvtNEpKSsjNzaVDhw57JI3y8nKGDBnCueeey8033wzAzp07eeqpp7jpppvIz8/n+OOP54ILLqg9ZuHChfTu3Zvx48fTunVrSkpK6NOnD/Pnz2f9+vUsXbqU3//+9+Tl5dG3b18uvvhiHn744drjBw0axOjRo2nVqhUHH3xw2n4/ShoiIgmeffZZqqqq2LFjB9OmTWPIkCF8/PHH/O1vf2Po0KF06tSJtm3bMn369NrtW9evX8/RRx9d7zkXLlzIl19+ycSJE2vLKioqqK6u3mOSvXv37rXPy8vL93hdU79hwwbKy8tp3749BQUFe9XVaKrJe109JZJFU55eDcDosi2NOs/JPdunIxxJkJOTw5gxY5gwYQJLly7l6quvZvLkySxatIi8vDwuv/zy2qRRVFTEa6+9Vu+5fvrTn7J161aKi4tZvHgx+fn5tbv6rV+/nj59+gDBMFeNrl27UncvoHXr1jFs2DC6du3Kli1b2L59e23iWLduHUceeWRt23CNvrRTT0NEJAl3Z+7cuWzdupVjjz2W7du30759e/Ly8njttdeYPXt2bdtx48bx4osv8vjjj1NdXU1lZSWrVq3a43zTpk3jmGOO4cwzz+TLL7+sTUpTp07liy++YM2aNcyaNau2fXFxMe+//z6zZ8+murqaOXPmsGbNGs4880yKiooYPHgwU6ZM4auvvuLNN9/k/vvvT+vcRX3U0xCR7IvRHuQjR44kJycHM6N79+7MmjWLb37zm9x9991ceeWVTJ48mSFDhnDeeedRVVUFQLdu3SgtLeWqq67i4osvpm3bttx88817zGuYGTNmzODCCy9k1KhRzJs3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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "width = 0.5\n",
    "# x = np.arange(base, top-step, step)\n",
    "x = np.arange(len(adv_nums))\n",
    "# hatch : / , \\ , | , - , + , x , o , O , . , * \n",
    "plt.bar(x, clean_nums/sum(clean_nums), alpha=0.6, label='Clean')\n",
    "plt.bar(x+0.1, adv_nums/sum(adv_nums), alpha=0.6,  label='Backdoor')\n",
    "# plt.bar(x + 0.1, clean, width=width, label='b')\n",
    "# plt.xticks([0, 4, 8, 12], [3, 3.5, 4.0, 4.5])\n",
    "# plt.yticks([0.00, 0.05, 0.10, 0.15, 0.20, 0.25, 0.30], [0.00, 0.05, 0.10, 0.15, 0.20, 0.25, 0.30])\n",
    "plt.xticks([0, 5, 10], [55, 60, 65])\n",
    "plt.yticks([0.00, 0.05, 0.10, 0.15, 0.20], [0.00, 0.05, 0.10, 0.15, 0.2])\n",
    "# plt.yticks([0.00, 0.05, 0.10, 0.15, 0.20, 0.25], [0.00, 0.05, 0.10, 0.15, 0.20, 0.25])\n",
    "plt.xlabel(\"Entropy\",fontsize=16)\n",
    "plt.ylabel(\"Proboability\",fontsize=16)\n",
    "plt.legend(fontsize=12, loc='best')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Neural Cleanse"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYcAAAD4CAYAAAAHHSreAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAAsTAAALEwEAmpwYAAAeLklEQVR4nO3dfZhVZb3/8fdHQvCo6TkiagIOJikSOsFoerKj5knMULNINFHQo4iXlqi/8ul3lPDqROdXp1ITxSSx8CkNtbQ0j5haPsDYyEOEkmKOYiLZJInKw/f3x1qDm1nzsGbYTzN8Xtc11+y91r3u/V1r9uzvvte91n0rIjAzMyu0VaUDMDOz6uPkYGZmGU4OZmaW4eRgZmYZTg5mZpbxgUoHUAz9+vWLmpqaSodhZtat1NfXvxERO7e2rkckh5qaGubPn1/pMMzMuhVJL7W1zqeVzMwsw8nBzMwynBzMzCyjR/Q5bInWrl1LY2Mj77zzTqVDMbMq17dvXwYMGEDv3r1zb+Pk0E01Njay/fbbU1NTg6RKh2NmVSoiWLVqFY2NjQwePDj3dj6t1E2988477LTTTk4MZtYuSey0006dPsvg5NCNOTGYWR5d+axwcjAzswz3OfQQNRffV9T6lk/7bK5yr732GpMnT2bevHn06dOHmpoavve97/H5z3+eRYsWFTWmopuyQ5Hra+qwSK9evRg+fDhr167lAx/4AOPHj2fy5MlstdVWzJ8/n5tvvpmrrroqs11DQwOvvvoqRx99dKdC2m677Vi9enWb65cvX87o0aM79beaMGECo0ePZsyYMZ2KpSPDZw0van0Lxy/ssEwl37/V/rdxcrAuiwiOP/54xo8fz2233QYkH2J/+ctfKhxZ9dpmm21oaGgA4PXXX+dLX/oSTU1NfP3rX6euro66urrMNuvWraOhoYH58+d3OjlY2/z+bZ9PK1mXzZ07l969ezNp0qSNy2praxk4cODG5+vXr+erX/0qBxxwAPvttx/XX389AKtXr+aII45gxIgRDB8+nHvuuQdIvi0NHTqUM888k2HDhnHkkUeyZs2a8u5YmfTv358ZM2ZwzTXXEBE88sgjjB49GoApU6YwceJEjjzySE499VQuv/xybr/9dmpra7n99tsZMmQIK1euBGDDhg3stddevPHGG22+VlvHG5LkM378ePbbbz/GjBnD22+/DUB9fT2HHnooI0eOZNSoUaxYsaKER6P8quX9W61/GycH67JFixYxcuTIdsvceOON7LDDDsybN4958+Zxww038OKLL9K3b1/mzJnDM888w9y5c7nwwgtpnrL2+eef55xzzmHx4sXsuOOO3HXXXeXYnYrYc8892bBhA6+//npmXX19Pffccw+33HILU6dOZezYsTQ0NDB27FjGjRvH7NmzAXjooYfYf//96devX5uv097xXrp0KRMnTmTBggV88IMf5Nprr2Xt2rV8+ctf5s4776S+vp7TTz+dyy67rDQHoUKq5f1brX8bn1ayknrwwQdZsGABd955JwBNTU08//zzDBgwgEsvvZRHH32UrbbaildeeWVjc37w4MHU1tYCMHLkSJYvX16h6MujrXncjz32WLbZZptW151++ukcd9xxTJ48mZkzZ3Laaad1+BptHe+BAwfyiU98AoBx48Zx1VVXcdRRR7Fo0SI+/elPA8k36N12262ru9htleP9W61/GycH67Jhw4Zt/KdpS0Rw9dVXM2rUqE2W33TTTaxcuZL6+np69+5NTU3Nxuuw+/Tps7Fcr169euxpJYAXXniBXr160b9/f5YsWbLJum233bbN7QYOHMguu+zCww8/zFNPPcXs2bN5+eWXOeaYYwCYNGnSJqdLZs+e3ebxbnmZoyQigmHDhvHEE08Ua1erTjnfv93xb+PTStZln/rUp3j33Xe54YYbNi6bN28eL730/ijAo0aNYvr06axduxaA5557jn/84x80NTXRv39/evfuzdy5czfZZkuxcuVKJk2axLnnntvhdejbb789b7311ibLzjjjDMaNG8cJJ5xAr169GDhwIA0NDTQ0NGzy4QO0e7z//Oc/b/ygufXWWznkkEPYe++9Wbly5cbla9euZfHixcXY7apRzvdvd/zbuOXQQ+S99LSYJDFnzhwmT57MtGnT6Nu378ZLAZudccYZLF++nBEjRhAR7Lzzztx9992cfPLJHHPMMdTV1VFbW8s+++xT9vjzXHpabGvWrKG2tnbjpaynnHIKF1xwQYfbHX744UybNo3a2louueQSxo4dy7HHHstpp53W4SkloN3jPXToUGbNmsVZZ53FkCFDOPvss9l666258847+cpXvkJTUxPr1q1j8uTJDBs2bLP2vz15Lj0tpmp5/1br30Ztne/sTurq6mJLm+xn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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "size = 4\n",
    "x = np.arange(size)\n",
    "a = np.array([0.9964, 1.0012, 1.6546, 1.8327])\n",
    "b = np.array([1.6090, 1.2745, 1.9241, 1.9362])\n",
    "c = np.array([0.9734, 1.1522, 1.5069, 1.9201])\n",
    "\n",
    "total_width, n = 0.8, 3\n",
    "width = total_width / n\n",
    "x = x - (total_width - width) / 2\n",
    "\n",
    "plt.bar(x, a,  width=width, label='Clean')\n",
    "plt.bar(x + width, b, width=width, label='Dirty-label')\n",
    "plt.bar(x + 2 * width, c, width=width, label='Clean-label')\n",
    "\n",
    "plt.xticks(x+width, [\"SVHN\", \"CIFAR10\", \"GTSRB\", \"Tiny ImageNet\"])\n",
    "plt.ylabel(\"Anomaly Index\",fontsize=16)\n",
    "plt.axhline(y=2.0, color='r', linestyle='--', linewidth=2)\n",
    "plt.ylim(0, 2.3)\n",
    "plt.legend(loc='best', ncol=3)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYcAAAD4CAYAAAAHHSreAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAAsTAAALEwEAmpwYAAAbjklEQVR4nO3de5xVdb3/8dcbRMejpOcnoibg4JEUCZ0fjKYny0snUUPN8ogXFPAo4UNL1F95exwje/STzuN0KjRRPJFYeCnNS0ll/sTQ8gLjGREilBRzEhPJpkg0Lp/fH2sNbWbNZc2wbzPzfj4e+zF7r+93rfVZe+3Zn/1dl+9XEYGZmVmhfpUOwMzMqo+Tg5mZZTg5mJlZhpODmZllODmYmVnGDpUOoBgGDRoUtbW1lQ7DzKxHaWhoeCsi9myrrFckh9raWpYsWVLpMMzMehRJr7ZX5sNKZmaW4eRgZmYZTg5mZpbRK8459EUbN26kqamJd999t9KhmFmVq6mpYciQIQwYMCD3PE4OPVRTUxMDBw6ktrYWSZUOx8yqVESwbt06mpqaGD58eO75fFiph3r33XfZY489nBjMrEOS2GOPPbp8lMHJoQdzYjCzPLrzXeHkYGZmGT7n0EvUXvVwUZe3euYnctV74403mD59OosXL2annXaitraWb3zjG3zqU59i2bJlRY2p6GbsVuTlNXdapX///owePZqNGzeyww47MGnSJKZPn06/fv1YsmQJd9xxB7NmzcrM19jYyOuvv85JJ53UpZB23XVX1q9f32756tWrGT9+fJf21eTJkxk/fjynn356l2LpzOh5o4u6vBcmvdBpnUp+fqt93zg5WLdFBKeddhqTJk3i7rvvBpIvsT/84Q8Vjqx67bzzzjQ2NgLw5ptvcvbZZ9Pc3MyXvvQl6uvrqa+vz8yzadMmGhsbWbJkSZeTg7XPn9+O+bCSddvChQsZMGAA06ZN2zqtrq6OoUOHbn29efNmPv/5z3PYYYdxyCGHcOuttwKwfv16PvaxjzFmzBhGjx7Ngw8+CCS/lkaOHMmFF17IqFGjOP7449mwYUN5N6xMBg8ezJw5c7jpppuICB5//HHGjx8PwIwZM5g6dSrHH3885513Htdddx333HMPdXV13HPPPYwYMYK1a9cCsGXLFg444ADeeuutdtfV3vsNSfKZNGkShxxyCKeffjrvvPMOAA0NDRx99NGMHTuWcePGsWbNmhK+G+VXLZ/fat03Tg7WbcuWLWPs2LEd1vn2t7/NbrvtxuLFi1m8eDG33XYbr7zyCjU1Ndx///0899xzLFy4kCuuuIKWIWtfeuklLr74YpYvX87uu+/OfffdV47NqYj999+fLVu28Oabb2bKGhoaePDBB7nzzju5/vrrmTBhAo2NjUyYMIGJEycyf/58AB599FEOPfRQBg0a1O56Onq/V65cydSpU1m6dCnve9/7uPnmm9m4cSOf/exnuffee2loaOD888/n2muvLc2bUCHV8vmt1n3jw0pWUo888ghLly7l3nvvBaC5uZmXXnqJIUOGcM0117Bo0SL69evH73//+63N+eHDh1NXVwfA2LFjWb16dYWiL4/2xnE/5ZRT2HnnndssO//88zn11FOZPn06c+fOZcqUKZ2uo733e+jQoXz4wx8GYOLEicyaNYsTTjiBZcuW8fGPfxxIfkHvs88+3d3EHqscn99q3TdODtZto0aN2vpP056I4MYbb2TcuHHbTL/99ttZu3YtDQ0NDBgwgNra2q3XYe+0005b6/Xv37/XHlYCePnll+nfvz+DBw9mxYoV25Ttsssu7c43dOhQ9tprLx577DGeeeYZ5s+fz2uvvcbJJ58MwLRp07Y5XDJ//vx23+/WlzlKIiIYNWoUTz31VLE2teqU8/PbE/eNDytZtx133HG899573HbbbVunLV68mFdf/XsvwOPGjWP27Nls3LgRgBdffJG//vWvNDc3M3jwYAYMGMDChQu3maevWLt2LdOmTeOSSy7p9Dr0gQMH8pe//GWbaRdccAETJ07kjDPOoH///gwdOpTGxkYaGxu3+fIBOny/f/e73239ornrrrs46qijOPDAA1m7du3W6Rs3bmT58uXF2OyqUc7Pb0/cN2459BJ5Lz0tJkncf//9TJ8+nZkzZ1JTU7P1UsAWF1xwAatXr2bMmDFEBHvuuScPPPAA55xzDieffDL19fXU1dVx0EEHlT3+PJeeFtuGDRuoq6vbeinrueeey+WXX97pfMceeywzZ86krq6Oq6++mgkTJnDKKacwZcqUTg8pAR2+3yNHjmTevHl85jOfYcSIEVx00UXsuOOO3HvvvXzuc5+jubmZTZs2MX36dEaNGrVd29+RPJeeFlO1fH6rdd+oveOdPUl9fX30tcF+VqxYwciRIysdhlXQkiVLuOyyy3jiiScqHYr1AG19Z0hqiIjs9dO45WDWI82cOZPZs2dvvWLJrNh8zsGsB7rqqqt49dVXOeqooyodivVSTg49WG84JGhmpded7wonhx6qpqaGdevWOUGYWYdaxnOoqanp0nw+59BDDRkyhKampq1dKJiZtadlJLiucHLooQYMGNClUZ3MzLrCh5XMzCyjrMlB0lBJCyWtkLRc0qVt1JGkWZJWSVoqaUw5YzQzs/IfVtoEXBERz0kaCDRI+nlE/LqgzonAiPTxIWB2+tfMzMqkrC2HiFgTEc+lz/8CrAD2bVXtVOCOSDwN7C6p4y4HGxpAavsxZ87f682Z03691n3bjB3bfr2pU/OtW0rKW0yd2n691l0Hd7RMb5O3ydvkbSrGNnWgYuccJNUC/xt4plXRvsBrBa+byCYQJE2VtERS3+o3w8ysDCrSt5KkXYFfAF+JiB+2KnsYuCEinkxf/z/gCxHRkF1Soi/2rWRmtr066lup7C0HSQOA+4D5rRNDqgkYWvB6CPB6OWIzM7NEua9WEvBtYEVE/Fc71R4CzkuvWjoCaI6I3jV4rZlZlSv31UofBs4FXpDUmE67BhgGEBG3AAuAk4BVwDvAlDLHaGbW55U1OaTnETo8RR7JSZCLyxORmZm1xXdIm5lZhvtWMrPeacZuFVhnc/nXWSJuOZiZWYaTg5mZZTg5mJlZhpODmZllODmYmVmGk4OZmWU4OZiZWYaTg5mZZTg5mJlZhpODmZllODmYmVmGk4OZmWU4OZiZWYaTg5mZZeRKDpJ26aR8/+KEY2Zm1SBvy6FRUn1bBZLOA/6neCGZmVml5U0Oa4BfSvpCywRJAyV9D7gd+H4JYjMzswrJmxyOAW4AviLpUUmnAM8DJwFnRMSFJYrPzMwqINcwoRGxBZgh6THgZ8CxwFLgoxHRVML4zMysAnJfrSRpH+CLJAllBTASOKNEcZmZWQXlvVqp5TDSPwFHA4cA/wF8VdJPJQ0uXYhmZlZueVsODwALgUMj4lcRsSUirgOOAw4mOcRkZma9RN7kcGFETIiI5sKJEfEEcCiwqOiRmZlZxeQ9If3tDsrexucezMx6lVzJAUDSvsAVwEeB/wWcEhHLJE0HnoqIZ0oTopn1dLVXPVz2da6uKfsqe5W8J6RHAS8A5wKvA/sBO6bF+wGXliQ6MzOriLznHL5GcvnqcOBTgArKfgUcUeS4zMysgvIeVjoKOCsi1kvq36rsD8DexQ3LzMwqKW/LYUsHZYOADUWIxczMqkTelsOzwBTgR22UnQH8smgR9QUzdqvAOps7r2NmlsqbHL4MPCrpEeBOIIB/kXQpcBrJFUxmZtZL5DqsFBG/AD5JckJ6LskJ6ZnAR4BP+jJWM7PeJfd9DhHxMPCwpAOAwcC6iFhZssjMzKxicieHFhGxClhVgljMzKxKtJsc0uE/c4uIO7Y/HDMzqwYdtRxub/U60r9qYxqAk4OZWS/R0Qnp4QWPjwBNwK0kQ4aOTP/OAV4juUmuU5LmSnpT0rJ2yo+R1CypMX1cl3dDzMyseNptOUTEqy3PJX0TuDsiriyoshJYJOmrwBdILmntzO3ATXTcyngiIsbnWJaZmZVI3hPSHyP5Um/Lz4GL8iwkIhZJqs25TjOzHmX0vNFlX+cLk14oyXLzdp/xHlDfTtlhwN+KEw4AR0p6XtJP0t5g2yRpqqQlkpasXbu2iKs3M7O8LYfvAzMkbQZ+QNLZ3l4kXWd8EWh3MKAueg7YL+3g7ySS4UlHtFUxIuaQnPOgvr4+2qpjZmbdkzc5XAEMBG4guTO6RZB0p3FFMYKJiD8XPF8g6WZJgyLirWIs38zM8sk7TOgG4FxJXwY+BOwDrAGeiYgXixWMpL2BP0RESDqc5LDXumIt38zM8unSHdJpIuh2MpB0F8klsIMkNZEckhqQLvsW4HTgIkmbSLoBPzMifMjIzKzMupQc0l/2w4DM6KwRsaiz+SPirE7Kb6L9q6LMzKxMciUHSfsC3+PvXXOLbe+YDqD1CHFmZtZD5W05zAY+SHKz2wskl7aamVkvlTc5fAT4XER8t5TBmJlZdch7E9wG4M1SBmJmZtUjb3K4DTi3lIGYmVn1yHtY6fck9zk8BiwA/ti6QkTMLWZgZmZWOXmTwy3p31qS+xRaC5Kxpc3MrBfImxyGlzQKMzOrKnm7z3i181pmZtZb5D0hbWZmfUi7LQdJnXaHUSAi4ugixGNmZlWgo8NKW/h7FxlmZtaHdDSG9DFljMPMzKqIzzmYmVmGk4OZmWV0aTwHsz5rxm4VWGdz+ddplnLLwczMMpwczMwsw8nBzMwyciUHSb+UdK6knUodkJmZVV7elsNGYB7wuqT/knRQCWMyM7MKy5Uc0hviRpIkiPOA5ZIelzRB0oASxmdmZhWQ+5xDRKyMiMuBfYHJQH/gTqBJ0kxJ+5cmRDMzK7cun5COiPci4rvApcATwJ7AF4AXJf1A0t5FjtHMzMqsS8lB0s6Szpf0LLCYJDFcCrwfuAj4Z2B+0aM0M7OyynWHtKTRwGeAc4BdgAeBKyNiYUG12yS9Afyg6FGamVlZ5e0+43ngdeAbwJyIWNNOvVXAU0WIy8zMKihvcvhX4IGI2NxRpYhYARy73VGZGaPnjS77Ol+Y9ELZ12nVKe8Y0veVOhAzM6seHQ0Tel0XlhMR8eUixGNmZlWgo5bDjC4sJwAnBzOzXqKjYULdKZ+ZWR/lBGBmZhlODmZmlpE7OUiaKul/JL0jaXPrRymDNDOz8so7nsN5wI0kXWbUAN8Bvgf8GfgtcH2pAjQzs/LL23KYDtxA0n8SwM0RMQnYH9gArCt+aGZmVil5k8MIYBGwJX3sCBARbwNfIel8z8zMeom8yWED0C8iAniDpMXQYj1Jr6ydkjRX0puSlrVTLkmzJK2StFTSmJzxmZlZEeVNDi8AB6TPnwCukXSkpMNIbpb7Tc7l3A6c0EH5iSStlBHAVGB2zuWamVkR5U0Oc4B/TJ//O7Ar8CTwNPAB4Io8C4mIRcAfO6hyKnBHJJ4Gdpe0T84YzcysSPJ2vHdPwfNVkkYBRwL/APwqIt4qUjz7Aq8VvG5Kp2W6CJc0laR1wbBhw4q0eusJaq96uOzrXF1T9lWaVVTeLru3ERF/BR4tciwAamt17cQwh6RFQ319fZt18vAXjZlZVpeSg6ShwFCSex22ERGPFSGepnT5LYaQDDJkZmZllHeY0P1JxoY+vGVS+jfS5wH0L0I8DwGXSLob+BDQ3MGoc9YFHjjGzLoib8vhv4FhJDfD/Qb4W3dWJuku4BhgkKQm4IvAAICIuAVYAJxEMtzoO8CU7qzHzMy2T97kcBgweXtHhIuIszopD+Di7VmHmZltv7yXsjbRzdaCmZn1PHmTw/8FrpS0SymDMTOz6pD3PofvSjoIWC3paeDtbJWYVPTozMysIvJerTQZuBrYDIwhe4ip2/cZmJlZ9cl7QvpLwP3Av0XEn0oXjpmZVYO85xz2IBnD4U8ljMXMzKpE3uTwJDCylIGYmVn1yHtY6VLg+5LeBn5K9oQ0EbGlmIGZmVnl5E0OK9K/d7RTHl1YlpmZVbm8X+jX4yuSzMz6jLz3OcwocRxmZlZF8p6Q3krSrpKG+m5pM7PeK3dykDRO0hLgT8BqoFnSs5I+XqLYzMysQvLeIT0OeJikK+0vA28A+wATgAWSToqIn5csSjMzK6u8J6RnAI8A4wsvWZV0PfBjkjuonRzMzHqJvIeVDgW+1fpehvT1zUBdkeMyM7MKypsc3gPe107ZwLTczMx6ibzJ4XHgy5KGF06UNIzkkNPC4oZlZmaVlPecw5XAL4GV6XgOa4C9gSNIrl66siTRmZlZReRqOUTEi8AhwCxgJ5IxHWqAbwJ1EfFSySI0M7Oyy90fUkSsAf5PCWMxM7Mq0eU7pM3MrPfL3XKQNAk4CxhGckipUETEPxUzMDMzq5y8d0j/O8mNbsuARnzpqplZr5a35fBvwDcj4rJSBmNmZtWhK2NI/6iUgZiZWfXImxx+QdKFhpmZ9QF5DytNB34oaR2wAPhj6woeQ9rMrPfImxxeTP9+p51yjyFtZtaLeAxpMzPL8BjSZmaWsd13SEs6WtLcYgRjZmbVoVvJQdIBkq6X9ApJd91nFDcsMzOrpNzJQdJukqZKehJYCVwLvA1cBLy/RPGZmVkFdHjOQVI/4ATgPOAUkj6VXge+BVwMTI+IRaUO0szMyqvd5CDpP4FzgMHAu8D9wDzgUZIhQy8pR4BmZlZ+HbUcLie5fHUBMDki1rUUSPJlrWZmvVhH5xzmAn8BPkEyPOhNkg4vT1hmZlZJ7SaHiLiAZJzoiUADMA14StIKkjGju9V6kHSCpJWSVkm6qo3yYyQ1S2pMH9d1Zz1mZtZ9HV6tFBHvRsSdETEOGApcA2wGrgIEzJQ0UVLrwX/aJKk/ycnsE4GDgbMkHdxG1Scioi59XN+F7TEzsyLIfSlrRKyJiK9GxAeBDwE3AyOAO4A1ORdzOLAqIl6OiL8BdwOndjFmMzMrsW7dBBcRiyPiEpL7G04n6dI7j32B1wpeN6XTWjtS0vOSfiJpVHdiNDOz7tuunlQjYiPww/SRh9paTKvXzwH7RcR6SScBD5C0ULZdkDQVmAowbNiwvCGbmVkO2923Uhc1kZy7aDGE5Ka6rSLizxGxPn2+ABggaVDrBUXEnIioj4j6Pffcs5Qxm5n1OeVODouBEZKGS9oROBN4qLCCpL0lKX1+eBrjusySzMysZMo6QE9EbJJ0CfAzoD8wNyKWS5qWlt9Ccg7jIkmbgA3AmRHhm+7MzMqo7KO3pYeKFrSadkvB85uAm8odl5mZ/V25DyuZmVkP4ORgZmYZTg5mZpbh5GBmZhlODmZmluHkYGZmGU4OZmaW4eRgZmYZTg5mZpbh5GBmZhlODmZmluHkYGZmGU4OZmaW4eRgZmYZTg5mZpbh5GBmZhlODmZmluHkYGZmGU4OZmaW4eRgZmYZTg5mZpbh5GBmZhlODmZmluHkYGZmGU4OZmaW4eRgZmYZTg5mZpbh5GBmZhlODmZmluHkYGZmGU4OZmaW4eRgZmYZTg5mZpbh5GBmZhlODmZmluHkYGZmGU4OZmaW4eRgZmYZTg5mZpZR9uQg6QRJKyWtknRVG+WSNCstXyppTLljNDPr68qaHCT1B74FnAgcDJwl6eBW1U4ERqSPqcDscsZoZmblbzkcDqyKiJcj4m/A3cCpreqcCtwRiaeB3SXtU+Y4zcz6tB3KvL59gdcKXjcBH8pRZ19gTWElSVNJWhYA6yWtLG6opaPtm30Q8FbXZ1u2fWvtBk3ezi2tIt5nPc92bEk39xf0wH22X3sF5U4ObW1FdKMOETEHmFOMoHoSSUsior7ScVh+3mc9i/dXotyHlZqAoQWvhwCvd6OOmZmVULmTw2JghKThknYEzgQealXnIeC89KqlI4DmiFjTekFmZlY6ZT2sFBGbJF0C/AzoD8yNiOWSpqXltwALgJOAVcA7wJRyxtgD9LlDab2A91nP4v0FKCJzON/MzPo43yFtZmYZTg5mZpbh5FBBkq6VtDztJqRR0k8k3dCqTp2kFenz1ZIGFZQdI+nH6fPJkrZIOqSgfJmk2jJtTq8iaW9Jd0v6raRfS1og6QOSlqXlx0hqTvdbo6RHC+Z9UNJTrZY3Q9Lv07q/lnRWQdm/pp+DLZLqW813ddqVzEpJ40q93b2FpL0k3SnpZUkNkp5K3+OW939Dwb47XdIRkp5JX6+QNCNdzmRJa9Ppv5F0WcE6CvfpbyTNltRrvlPLfZ+DpSQdCYwHxkTEe+mX/ijgO8DVBVXPBO7Mudgm4FpgQjFj7WskCbgfmBcRZ6bT6oC9WlV9IiLGt5p3d2AMyY2ZwyPilYLir0fEf0oaATRIujciNpLcOfUp4NZWyzqYZP+PAt4PPCrpAxGxuUib2iul++8Bkv13djptP+CUiLgx/cH044ioK5hnJXBGRDyfdvNzYMEi74mISyTtAaxM91vLjbot+7QfsAg4GlhY4k0si16T5XqgfYC3IuI9gIh4KyJ+AfxJUuFd42eQdDOSx4+BUZIO7LSmdeRYYGN69RwAEdHItnfut+fTwI9I9tmZbVWIiJdIrsT7x/T1ioho6w7/U4G7I+K9NMmsIumCxjp2HPC3Vvvv1Yi4sYN5BpP2whARmyPi160rRMQ6kn3QVnc+OwI1wNvbE3g1cXKonEeAoZJelHSzpKPT6XeRfqmk93msS79MWixsaQ4D/91qmVuA/wCuKW3ovd4HgYYc9T5ScGji2nTaWST78K70eUba0/BLEfFmJ8tvrysZ69go4LkuzvN1klbB/ZI+I6mmdQVJw0gSwNKCyZel/4trgBfTHxG9gpNDhUTEemAsSf9Qa4F7JE0m+cV5etpMPZPkS6bQsRFRlzaJL2hj0XcCR0gaXqrYbasnWvZFRHxF0l7AAcCTEfEisEnSBwvqX5YevngGmJFj+bm6krGOSfqWpOclLW6vTkRcD9ST/Gg7G/hpQfEEScuBl4FvRsS7BWVfT/8XBwO7SGqztdgTOTlUUNp8fTwivghcAnw6PZa5muTY5aeB73dxmZuArwFXFjncvmQ5SeLuqgkkh4pekbQaqGXbQ0tfj4gD03p3tPXrtBV3JdM9y0nO+wAQERcDHwP27GimiPhtRMxO6x6anmOA5JzDKOAjwNck7d3GvBtJEspHi7MJlefkUCGSDkxPTLaoA15Nn99F0sz9bUQ0dWPxtwP/Qif/DNaux4CdJF3YMkHSYXTQg2XqLOCEiKiNiFqSBJP5JRkRPwSWAJM6Wd5DwJmSdkpbgiOAZ3NvRd/1GFAj6aKCaf/Q0QySPpGeyIbkfd4M/KmwTkQ8BXwXuLSN+QX8M/Db7oddXZwcKmdXYF56Wd1SksGPZqRlPyA5bpr3RPQ20rEyZpE0da2LIuk24DTg4+mlrMtJ9k27v9rTK2CGAU8XLOcV4M+tLjBocT1wuaR+kk6T1AQcCTws6Wfp/MtJWo6/JvlVerGvVOpcuv8+CRwt6RVJzwLz6Lg1fS7JOYdGkgRwTjvv9VeBKZIGpq9bzjksI7n68+aibEQVcPcZZmaW4ZaDmZllODmYmVmGk4OZmWU4OZiZWYaTg5mZZTg5mJlZhpODmZll/H8hwZ+Gq7UKrAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "size = 3\n",
    "x = np.arange(size)\n",
    "a = np.array([0.9964, 1.0012, 1.6546])\n",
    "b = np.array([1.6090, 1.2745, 1.9241])\n",
    "c = np.array([0.9734, 1.1522, 1.5069])\n",
    "\n",
    "total_width, n = 0.8, 3\n",
    "width = total_width / n\n",
    "x = x - (total_width - width) / 2\n",
    "\n",
    "plt.bar(x, a,  width=width, label='Clean')\n",
    "plt.bar(x + width, b, width=width, label='Dirty-label')\n",
    "plt.bar(x + 2 * width, c, width=width, label='Clean-label')\n",
    "\n",
    "plt.xticks(x+width, [\"SVHN\", \"CIFAR10\", \"GTSRB\"])\n",
    "plt.ylabel(\"Anomaly Index\",fontsize=16)\n",
    "plt.axhline(y=2.0, color='r', linestyle='--', linewidth=2)\n",
    "plt.ylim(0, 2.3)\n",
    "plt.legend(loc='best', ncol=3)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Fine Pruning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = '/home/harry/nnet/ImplicitBackdoor/Defences/finepruning/tin_clean.txt'\n",
    "with open(path, 'r') as f:\n",
    "    fp = f.read()\n",
    "fp = fp.split('\\n')\n",
    "\n",
    "acc = []\n",
    "asr = []\n",
    "x = np.arange(len(fp)-1)\n",
    "for i in range(len(fp)-1):\n",
    "    tmp = fp[i].split(' ')\n",
    "    acc.append(float(tmp[1]))\n",
    "    asr.append(float(tmp[2]))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(x, acc, label='Clean')\n",
    "plt.plot(x, asr, label='Backdoor')\n",
    "plt.ylim(0,70)\n",
    "plt.xlim(-5,256)\n",
    "plt.xlabel(\"Filters Pruned\", fontsize=16)\n",
    "plt.ylabel(\"Accuracy\", fontsize=16)\n",
    "# plt.xticks([100, 200, 300, 400, 500], [100, 200, 300, 400, 500])\n",
    "plt.xticks([0, 100, 200, 300, 400, 500], [0, 100, 200, 300, 400, 500], fontsize=12)\n",
    "# plt.xticks([0, 100, 200], [0, 100, 200], fontsize=12)\n",
    "plt.yticks([0, 20, 40, 60], [0,20, 40, 60], fontsize=12)\n",
    "# plt.yticks([0, 20, 40, 60,80], [0,20, 40, 60,80], fontsize=12)\n",
    "# plt.yticks([0, 20, 40, 60,80, 100], [0,20, 40, 60,80,100], fontsize=12)\n",
    "# plt.axhline(y=85.3, color='r', linestyle='--', linewidth=1)\n",
    "plt.legend(loc='best', fontsize=16)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Ablation study"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "index = np.array([0.01, 0.02, 0.03, 0.04, 0.05, 0.06, 0.07, 0.08, 0.09, 0.1])\n",
    "\n",
    "# SVHN\n",
    "# ACC1 = np.array([94.62, 94.53, 94.10, 95.01, 94.53, 94.64, 94.61, 94.85, 95.1, 94.66])\n",
    "# ASR1 = np.array([93.89, 95.57, 96.36, 97.29, 97.54, 97.77, 98.09, 98.38, 98.66, 98.89])\n",
    "# CIFAR10\n",
    "# ACC1 = np.array([94.22, 94.49, 94.30, 94.22, 94.32, 94.25, 94.38, 94.02, 94.22, 94.03])\n",
    "# ASR1 = np.array([98.53, 99.39, 99.52, 99.70, 99.89, 99.88, 99.89, 99.83, 99.90, 99.94])\n",
    "# GTSRB\n",
    "ACC1 = np.array([99.34, 99.14, 98.98, 99.20, 99.03, 99.20, 99.08, 99.10, 99.11, 98.94])\n",
    "ASR1 = np.array([85.48, 90.54, 92.03, 93.24, 93.58, 94.20, 94.14, 94.83, 94.99, 95.12])\n",
    "\n",
    "# Tiny ImageNet\n",
    "ACC1 = np.array([59.38, 58.42, 58.35, 57.73, 57.62, 58.06, 58.16, 57.84, 58.02, 57.84])\n",
    "ASR1 = np.array([22.23, 28.15, 35.11, 39.69, 44.28, 49.61, 53.26, 56.72, 59.13, 63.52])\n",
    "\n",
    "# ACC2 = np.random.randn(10) + 99.0\n",
    "# ASR2 = np.random.randn(10) + 88.0\n",
    "# ACC = np.array([ ])\n",
    "c1 = 'red'\n",
    "c2 = 'green'\n",
    "plt.plot(index, ACC1, color=c1, linestyle='-', label='ACC', marker='s')\n",
    "plt.plot(index, ASR1, color=c2, linestyle='-', label='ASR', marker='o')\n",
    "\n",
    "# plt.plot(index, ACC2, color=c1, linestyle='-.', label='PatchMT')\n",
    "# plt.plot(index, ASR2, color=c2, linestyle='-.', label='PatchMT')\n",
    "# plt.ylim(18,105)\n",
    "# plt.xlim(-10,530)\n",
    "plt.xlabel(\"Poisoning rate\", fontsize=16)\n",
    "plt.ylabel(\"ASR / ACC\", fontsize=16)\n",
    "plt.xticks([0.02, 0.04, 0.06, 0.08, 0.1], [0.02, 0.04, 0.06, 0.08, 0.1], fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "# plt.xticks([0, 100, 200, 300, 400, 500], [0, 100, 200, 300, 400, 500])\n",
    "# plt.yticks([20, 40, 60, 80, 100], [20, 40, 60, 80, 100])\n",
    "# plt.axhline(y=85.3, color='r', linestyle='--', linewidth=1)\n",
    "# plt.legend(loc='center right', fontsize=14)\n",
    "plt.legend(loc='lower right', fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "index = np.array([0.1, 0.2, 0.3, 0.4, 0.5])\n",
    "\n",
    "# CLean-label attack\n",
    "# SVHN\n",
    "ACC1 = np.array([94.30, 94.40, 94.45, 94.40, 93.72])\n",
    "ASR1 = np.array([86.83, 86.92, 87.32, 87.23, 87.87])\n",
    "# CIFAR10\n",
    "ACC1 = np.array([93.92, 93.78, 93.62, 93.07, 92.57])\n",
    "ASR1 = np.array([92.22, 94.92, 95.13, 96.22, 96.68])\n",
    "# GTSRB\n",
    "ACC1 = np.array([99.06, 99.13, 99.03, 99.19, 98.89])\n",
    "ASR1 = np.array([39.83, 40.59, 41.66, 42.62, 42.89])\n",
    "\n",
    "# # Tiny ImageNet\n",
    "ACC1 = np.array([58.96, 59.04, 58.42, 57.34, 57.53])\n",
    "ASR1 = np.array([24.01, 33.12, 42.28, 49.37, 55.57])\n",
    "\n",
    "# ACC2 = np.random.randn(10) + 99.0\n",
    "# ASR2 = np.random.randn(10) + 88.0\n",
    "# ACC = np.array([ ])\n",
    "c1 = 'red'\n",
    "c2 = 'green'\n",
    "plt.plot(index, ACC1, color=c1, linestyle='-', label='ACC', marker='s')\n",
    "plt.plot(index, ASR1, color=c2, linestyle='-', label='ASR', marker='o')\n",
    "\n",
    "# plt.plot(index, ACC2, color=c1, linestyle='-.', label='PatchMT')\n",
    "# plt.plot(index, ASR2, color=c2, linestyle='-.', label='PatchMT')\n",
    "# plt.ylim(91.95,97.05)\n",
    "# plt.xlim(-10,530)\n",
    "plt.xlabel(\"Poisoning rate\", fontsize=16)\n",
    "plt.ylabel(\"ASR / ACC\", fontsize=16)\n",
    "plt.xticks([0.1, 0.2, 0.3, 0.4, 0.5], [0.1, 0.2, 0.3, 0.4, 0.5], fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "# plt.xticks([0, 100, 200, 300, 400, 500], [0, 100, 200, 300, 400, 500])\n",
    "# plt.yticks([20, 40, 60, 80, 100], [20, 40, 60, 80, 100])\n",
    "# plt.axhline(y=85.3, color='r', linestyle='--', linewidth=1)\n",
    "# plt.legend(loc='center right', fontsize=14)\n",
    "plt.legend(loc='lower right', fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "index = np.array([0.01, 0.02, 0.03, 0.04, 0.05, 0.06, 0.07, 0.08, 0.09, 0.1])\n",
    "ACC1 = np.random.randn(10) + 99.0\n",
    "ASR1 = np.random.randn(10) + 98.0\n",
    "\n",
    "ACC2 = np.random.randn(10) + 99.0\n",
    "ASR2 = np.random.randn(10) + 88.0\n",
    "# ACC = np.array([ ])\n",
    "c1 = 'red'\n",
    "c2 = 'green'\n",
    "plt.plot(index, ACC1, color=c1, linestyle='-', marker='o', label='IBA')\n",
    "plt.plot(index, ASR1, color=c2, linestyle='-', marker='^', label='IBA')\n",
    "\n",
    "plt.plot(index, ACC2, color=c1, linestyle='-.', marker='o', label='PatchMT')\n",
    "plt.plot(index, ASR2, color=c2, linestyle='-.', marker='d', label='PatchMT')\n",
    "# plt.ylim(18,105)\n",
    "# plt.xlim(-10,530)\n",
    "plt.xlabel(\"Poisoning rate\", fontsize=16)\n",
    "plt.ylabel(\"ASR / ACC\", fontsize=16)\n",
    "plt.xticks([0.02, 0.04, 0.06, 0.08, 0.1], [0.02, 0.04, 0.06, 0.08, 0.1], fontsize=16)\n",
    "# plt.xticks([0, 100, 200, 300, 400, 500], [0, 100, 200, 300, 400, 500])\n",
    "# plt.yticks([20, 40, 60, 80, 100], [20, 40, 60, 80, 100])\n",
    "# plt.axhline(y=85.3, color='r', linestyle='--', linewidth=1)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "n7",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.12"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
