{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/braintree/home/bashivan/anaconda2/envs/brainscore/lib/python3.7/site-packages/foolbox/attacks/brendel_bethge.py:777: NumbaDeprecationWarning: The 'numba.jitclass' decorator has moved to 'numba.experimental.jitclass' to better reflect the experimental nature of the functionality. Please update your imports to accommodate this change and see http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#change-of-jitclass-location for the time frame.\n",
      "  @jitclass(spec=[])\n",
      "/braintree/home/bashivan/anaconda2/envs/brainscore/lib/python3.7/site-packages/foolbox/attacks/brendel_bethge.py:1354: NumbaDeprecationWarning: The 'numba.jitclass' decorator has moved to 'numba.experimental.jitclass' to better reflect the experimental nature of the functionality. Please update your imports to accommodate this change and see http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#change-of-jitclass-location for the time frame.\n",
      "  @jitclass(spec=spec)\n",
      "/braintree/home/bashivan/anaconda2/envs/brainscore/lib/python3.7/site-packages/foolbox/attacks/brendel_bethge.py:1550: NumbaDeprecationWarning: The 'numba.jitclass' decorator has moved to 'numba.experimental.jitclass' to better reflect the experimental nature of the functionality. Please update your imports to accommodate this change and see http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#change-of-jitclass-location for the time frame.\n",
      "  @jitclass(spec=spec)\n",
      "/braintree/home/bashivan/anaconda2/envs/brainscore/lib/python3.7/site-packages/foolbox/attacks/brendel_bethge.py:1702: NumbaDeprecationWarning: The 'numba.jitclass' decorator has moved to 'numba.experimental.jitclass' to better reflect the experimental nature of the functionality. Please update your imports to accommodate this change and see http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#change-of-jitclass-location for the time frame.\n",
      "  @jitclass(spec=spec)\n",
      "/braintree/home/bashivan/anaconda2/envs/brainscore/lib/python3.7/site-packages/foolbox/attacks/brendel_bethge.py:1896: NumbaDeprecationWarning: The 'numba.jitclass' decorator has moved to 'numba.experimental.jitclass' to better reflect the experimental nature of the functionality. Please update your imports to accommodate this change and see http://numba.pydata.org/numba-doc/latest/reference/deprecation.html#change-of-jitclass-location for the time frame.\n",
      "  @jitclass(spec=spec)\n"
     ]
    }
   ],
   "source": [
    "import os \n",
    "import sys \n",
    "import numpy as np\n",
    "import pandas as pd \n",
    "\n",
    "npa = np.array\n",
    "\n",
    "import torch\n",
    "import foolbox as fb\n",
    "\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt \n",
    "%matplotlib inline\n",
    "import seaborn as sns\n",
    "sns.set_style(\"white\")\n",
    "sns.set_style(\"ticks\", {\"xtick.major.size\": 14, \"ytick.major.size\": 14})\n",
    "sns.set_context(\"paper\")\n",
    "mpl.rcParams['axes.linewidth']=2.5\n",
    "mpl.rcParams['ytick.major.width']=2.5\n",
    "mpl.rcParams['xtick.major.width']=2.5\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "sys.path.insert(0, '../models')\n",
    "sys.path.insert(0, '../')\n",
    "import resnet_cifar\n",
    "import resnet_mnist\n",
    "import mnist_models\n",
    "import cifar_models\n",
    "from utils import get_mnist_test_loader\n",
    "from utils import get_cifar10_test_loader\n",
    "from utils import get_cifar100_test_loader\n"
   ]
  },
  {
   "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": [
    "seed = 0\n",
    "ROOT_PATH = '../'\n",
    "\n",
    "torch.manual_seed(seed)\n",
    "use_cuda = torch.cuda.is_available()\n",
    "device = torch.device(\"cuda\" if use_cuda else \"cpu\")\n",
    "\n",
    "# MNIST\n",
    "MNIST_DATA_PATH = os.path.join(ROOT_PATH, \"data\", 'mnist')\n",
    "mnist = get_mnist_test_loader(batch_size=1000, data_path=MNIST_DATA_PATH)\n",
    "\n",
    "mnist_images, mnist_labels = [], []\n",
    "for images, labels in mnist:\n",
    "    mnist_images.append(images)\n",
    "    mnist_labels.append(labels)\n",
    "mnist_images = torch.cat(mnist_images, dim=0)\n",
    "mnist_labels = torch.cat(mnist_labels, dim=0)\n",
    "    \n",
    "# Cifar 10 \n",
    "C10_DATA_PATH = os.path.join(ROOT_PATH, \"data\", 'cifar10')\n",
    "cifar10 = get_cifar10_test_loader(batch_size=100, data_path=C10_DATA_PATH, norm=False)\n",
    "\n",
    "c10_images, c10_labels = [], []\n",
    "for im, l in cifar10:\n",
    "    c10_images.append(im)\n",
    "    c10_labels.append(l)    \n",
    "c10_images = torch.cat(c10_images, dim=0)\n",
    "c10_labels = torch.cat(c10_labels, dim=0)\n",
    "\n",
    "# Cifar 100 \n",
    "C100_DATA_PATH = os.path.join(ROOT_PATH, \"data\", 'cifar100')\n",
    "cifar100 = get_cifar100_test_loader(batch_size=100, data_path=C100_DATA_PATH, norm=False)\n",
    "\n",
    "c100_images, c100_labels = [], []\n",
    "for im, l in cifar100:\n",
    "    c100_images.append(im)\n",
    "    c100_labels.append(l)    \n",
    "c100_images = torch.cat(c100_images, dim=0)\n",
    "c100_labels = torch.cat(c100_labels, dim=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_path = '../chkpts/mnist/weights.pt'\n",
    "state_dict = torch.load(save_path)\n",
    "\n",
    "a2_E = resnet_mnist.ResNet18Feats()\n",
    "a2_Dc = mnist_models.LeNetDecoder(10)\n",
    "\n",
    "a2_E.load_state_dict(state_dict['E_state_dict'])\n",
    "a2_Dc.load_state_dict(state_dict['Dc_state_dict'])\n",
    "a2_EDc = torch.nn.Sequential(a2_E, a2_Dc)\n",
    "\n",
    "a2_EDc.to(device)\n",
    "a2_EDc.eval();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_type = 'linfpgd'\n",
    "\n",
    "\n",
    "attack_menu = {'linfpgd':{'attack': fb.attacks.LinfPGD(steps=40), 'eps': [0.0, 0.1, 0.3, 0.35, 0.4, 0.45, 0.5]},\n",
    "               'l1pgd':{'attack': fb.attacks.L1PGD(), 'eps':[0.0, 10.0, 50.0, 100., 200, 400]},\n",
    "               'l2pgd':{'attack': fb.attacks.L2PGD(), 'eps':[0.0, 2.0, 5.0, 10.0, 20.]},\n",
    "               'fgsm':{'attack': fb.attacks.FGSM(random_start=True), 'eps':[0.0, 0.1, 0.3, 0.35, 0.4, 0.45, 0.5]},\n",
    "               'deepfool':{'attack': fb.attacks.LinfDeepFoolAttack(steps=50), 'eps':[0.0, 0.01, 0.1, 0.3, 0.5, 1.0]},\n",
    "               'cw':{'attack': fb.attacks.L2CarliniWagnerAttack(steps=50, stepsize=0.05), 'eps':[0.0, 1., 2., 5.]},\n",
    "               'ddn':{'attack': fb.attacks.DDNAttack(steps=100), 'eps':[0.0, 1., 2., 5.0, 10.0]},\n",
    "              }\n",
    "\n",
    "assert attack_type in ('linfpgd', 'l1pgd', 'l2pgd', 'fgsm', 'deepfool', 'cw', 'ddn')\n",
    "attack, epsilons = attack_menu[attack_type]['attack'], attack_menu[attack_type]['eps']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "fmodel = fb.PyTorchModel(a2_EDc, bounds=(0,1), device=device)\n",
    "\n",
    "advs, success = [], []\n",
    "for images, labels in mnist:\n",
    "    try:\n",
    "        _, current_advs, current_success = attack(fmodel, images.to(device), labels.to(device), epsilons=epsilons)\n",
    "    except: \n",
    "        continue\n",
    "    advs.append(current_advs)\n",
    "    success.append(current_success)\n",
    "a2_adv_images = torch.cat([torch.stack(ad) for ad in advs], dim=1).cpu().numpy()\n",
    "success = torch.cat(success, dim=-1)\n",
    "a2_attack_success = success.cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "MARKER_SIZE = 15\n",
    "\n",
    "sns.set_style(\"ticks\", {\"xtick.major.size\": 14, \"ytick.major.size\": 14})\n",
    "sns.set_context(\"poster\")\n",
    "mpl.rcParams['axes.linewidth']=2.5\n",
    "mpl.rcParams['ytick.major.width']=2.5\n",
    "mpl.rcParams['xtick.major.width']=2.5\n",
    "\n",
    "plt.figure(figsize=(9, 5))\n",
    "plt.plot(epsilons, 100 * (1 - a2_attack_success.mean(-1).round(2)), marker='.', color='g', markersize=MARKER_SIZE)\n",
    "plt.xlabel('eps')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.title(f'Robustness - {attack_type}')\n",
    "\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Cifar10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_type = 'deepfool'\n",
    "\n",
    "attack_menu = {'linfpgd':{'attack': fb.attacks.LinfPGD(steps=20, abs_stepsize=2./255), 'eps': [0.0, 2./255, 4./255, 8./255, 16./255, 32./255]},\n",
    "               'l1pgd':{'attack': fb.attacks.L1PGD(), 'eps': [0.0, 10.0, 50.0, 100., 200, 400]},\n",
    "               'l2pgd':{'attack': fb.attacks.L2PGD(), 'eps': [0.0, 1.0, 2.0, 5.0, 10.0, 20.0]},\n",
    "               'fgsm':{'attack': fb.attacks.FGSM(), 'eps': [0.0, 2./255, 4./255, 8./255, 16./255, 32./255, 64./255]},\n",
    "               'deepfool':{'attack': fb.attacks.LinfDeepFoolAttack(), 'eps': [0.0, 2./255, 4./255, 8./255, 16./255, 32./255, 64./255]},\n",
    "               'cw':{'attack': fb.attacks.L2CarliniWagnerAttack(steps=20), 'eps': [1.]}, #[0., 1., 2., 5.]},\n",
    "               'ddn':{'attack': fb.attacks.DDNAttack(steps=100), 'eps':[0.0, 2.0, 5.0, 10.0, 15.]}\n",
    "              }\n",
    "\n",
    "assert attack_type in ('linfpgd', 'l1pgd', 'l2pgd', 'fgsm', 'deepfool', 'cw', 'ddn')\n",
    "attack, epsilons = attack_menu[attack_type]['attack'], attack_menu[attack_type]['eps']\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_path = '../chkpts/cifar10/weights.pt'\n",
    "state_dict = torch.load(save_path)\n",
    "\n",
    "a2_E = resnet_cifar.ResNet18Feats()\n",
    "a2_Dc = resnet_cifar.ResNetDecoder()\n",
    "a2_E.load_state_dict(state_dict['E_state_dict'])\n",
    "a2_Dc.load_state_dict(state_dict['Dc_state_dict'])\n",
    "\n",
    "a2_EDc = torch.nn.Sequential(a2_E, a2_Dc)\n",
    "\n",
    "a2_EDc.to(device)\n",
    "a2_EDc.eval();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "fmodel = fb.PyTorchModel(a2_EDc, bounds=(0,1), device=device)\n",
    "\n",
    "advs, success = [], []\n",
    "for images, labels in cifar10:\n",
    "    _, current_advs, current_success = attack(fmodel, images.to(device), labels.to(device), epsilons=epsilons)\n",
    "    advs.append(current_advs)\n",
    "    success.append(current_success)\n",
    "a2_adv_images = torch.cat([torch.stack(ad) for ad in advs], dim=1).cpu().numpy()\n",
    "success = torch.cat(success, dim=-1)\n",
    "a2_attack_success = success.cpu().numpy()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_style(\"ticks\", {\"xtick.major.size\": 14, \"ytick.major.size\": 14})\n",
    "sns.set_context(\"poster\")\n",
    "mpl.rcParams['axes.linewidth']=2.5\n",
    "mpl.rcParams['ytick.major.width']=2.5\n",
    "mpl.rcParams['xtick.major.width']=2.5\n",
    "\n",
    "MARKER_SIZE=15\n",
    "\n",
    "plt.figure(figsize=(9, 5))\n",
    "plt.plot(epsilons, 100 * (1 - a2_attack_success.mean(-1).round(2)), marker='.', markersize=MARKER_SIZE, color='g')\n",
    "\n",
    "plt.xlabel('eps')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.title(f'Robustness - {attack_type}')\n",
    "\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Cifar100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "attack_type = 'deepfool'\n",
    "\n",
    "attack_menu = {'linfpgd':{'attack': fb.attacks.LinfPGD(steps=20, abs_stepsize=2./255), 'eps': [0.0, 2./255, 4./255, 8./255, 16./255, 32./255]},\n",
    "               'l1pgd':{'attack': fb.attacks.L1PGD(), 'eps': [0.0, 10.0, 50.0, 100., 200, 400]},\n",
    "               'l2pgd':{'attack': fb.attacks.L2PGD(), 'eps': [0.0, 1.0, 2.0, 5.0, 10.0, 20.0]},\n",
    "               'fgsm':{'attack': fb.attacks.FGSM(), 'eps': [0.0, 2./255, 4./255, 8./255, 16./255, 32./255, 64./255]},\n",
    "               'deepfool':{'attack': fb.attacks.LinfDeepFoolAttack(), 'eps': [0.0, 2./255, 4./255, 8./255, 16./255, 32./255, 64./255]},\n",
    "               'cw':{'attack': fb.attacks.L2CarliniWagnerAttack(steps=20), 'eps': [1.]}, #[0., 1., 2., 5.]},\n",
    "               'ddn':{'attack': fb.attacks.DDNAttack(steps=100), 'eps':[0.0, 2.0, 5.0, 10.0, 15.]}\n",
    "              }\n",
    "\n",
    "assert attack_type in ('linfpgd', 'l1pgd', 'l2pgd', 'fgsm', 'deepfool', 'cw', 'ddn')\n",
    "attack, epsilons = attack_menu[attack_type]['attack'], attack_menu[attack_type]['eps']\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_path = '../chkpts/cifar100/weights.pt'\n",
    "state_dict = torch.load(save_path)\n",
    "\n",
    "a2_E = resnet_cifar.ResNet18Feats()\n",
    "a2_Dc = resnet_cifar.ResNetDecoder(num_classes=100)\n",
    "a2_E.load_state_dict(state_dict['E_state_dict'])\n",
    "a2_Dc.load_state_dict(state_dict['Dc_state_dict'])\n",
    "\n",
    "a2_EDc = torch.nn.Sequential(a2_E, a2_Dc)\n",
    "\n",
    "a2_EDc.to(device)\n",
    "a2_EDc.eval();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "fmodel = fb.PyTorchModel(a2_EDc, bounds=(0,1), device=device)\n",
    "\n",
    "advs, success = [], []\n",
    "for images, labels in cifar100:\n",
    "    _, current_advs, current_success = attack(fmodel, images.to(device), labels.to(device), epsilons=epsilons)\n",
    "    advs.append(current_advs)\n",
    "    success.append(current_success)\n",
    "a2_adv_images = torch.cat([torch.stack(ad) for ad in advs], dim=1).cpu().numpy()\n",
    "success = torch.cat(success, dim=-1)\n",
    "a2_attack_success = success.cpu().numpy()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7o/9YIx7ziPmAhs2bEBqair2798PjUYDo9GIxMRELFy4EBkZGQ6tBN/bihUrMH78eOzevRsVFRXo6upCfHw8Fi9ejOXLl/f7KvMvfvELxMfHY+fOnSgtLUV5eTmUSiWWL1+OVatWQaFQuOJ0PY7Y8ZfL5Vi1ahUqKipw9epVXLx4EXq9HhEREXjiiScwf/58m5MCejNXxr67uxvl5eVW5Q0NDRYP6PY1c7Wz3xlvJnbsY2NjsXz5clRUVKC2thZnz56F0WhEdHQ0nn76afzmN79BWlrawE7SQ7kq9q2trTBdC6murjb/cLvfyJEj+0zEOO7dH/vBGPe8IkZEREQkEj4jRkRERCQSJmJEREREImEiRkRERCQSJmJEREREImEiRkRERCQSJmJEREREImEiRkRERCQSJmJEREREImEiRkRERCQSJmJEREREImEiRkRERCQSJmJEREREIgkQuwNERJ7i0qVL2L17N4qLi9HS0gKZTIZx48bhV7/6FZ599llIpVJz3bq6OsyePRsAcPHiRXz33XfYtWsXysvLodPpMGbMGPz617/Gc889Bz8/69+83d3dKCgowNGjR3H58mXodDqEh4cjKioKqampmDt3LqZMmeK2cycicUgEQRDE7gQRkdj27duHTZs2wWg0AgCCg4PR1dUFg8EAAFCr1di1axeCgoIAWCZi2dnZ+POf/4yenh6EhYWho6MDPT09AID09HRs27YNAQE//u7t6enBsmXLoNFoAAASiQQKhQLt7e3m4z399NPYunWre06eiETDW5NENOSdOHECf//73xEUFIQ1a9agqKgI33//PcrKypCXl4cxY8ZAo9HgnXfe6bP966+/jrS0NJw4cQIlJSUoKSnBmjVr4OfnhxMnTiAvL8+i/pEjR6DRaBAUFITNmzejvLwcJSUlqKioQGFhId544w0kJye749SJSGS8IkZEQ5rBYMCTTz6J+vp65OXlYebMmVZ1amtrMXfuXOj1ehQWFiImJsbiilhSUhIOHjyIwMBAi3bbt29HTk4OQkND8fXXX5uvpm3YsAEFBQX47W9/i8zMzME/SSLyWLwiRkRDmkajQX19PVQqVZ9JGACMGjUKkyZNQk9Pj/l2Ym/Lli2zSsJM5TKZDFqtFt988425PDQ0FADQ0tLiorMgIm/Fh/WJaEgrLS0FAPzwww947LHH+q3X1tYGAGhsbLTaplar+2wTGhqKCRMm4Pvvv8f58+eRnp4OAJg1axZyc3Nx8uRJ/P73v8eCBQswbdo0REREDPR0iMjLMBEjoiHNdFWqu7sbN27csFu/s7PTqmz48OH91o+JiQEA3Lp1y1ymVqvx0ksv4cMPP0RhYSEKCwsBAImJiXj88cexaNEijBkz5kFOg4i8FBMxIhrSTG9Jzp49Gx9++KHbjvuHP/wBc+fOxdGjR1FcXIyysjJUV1ejuroae/fuxaZNmzBv3jy39YeIxMFnxIhoSIuKigLQ9y1HR12/ft3utsjISKtt8fHxWLlyJT7++GNoNBrs3bsX06ZNQ09PDzIzM3Hz5k2n+0RE3oGJGBENaZMnTwZwb1LW5uZmp/ZRUlLSZ7lWq8WFCxcAACkpKTb34e/vj0cffRT/+Mc/IJVK0dHRgXPnzjnVHyLyHkzEiGhIS0tLg1KphMFgwObNm23WvXv3bp/ln3zyCbq7u63KP/30U3R1dSE0NNTiRYC+6poEBgaaZ+K3VY+IfAMTMSIa0qRSKdavXw+JRIIjR45g9erVqKysNG/X6/WoqKjA5s2bzfOG3a+xsREvvvgi6urqAAA6nQ6ffPIJcnJyAAArVqwwzyEGAOvWrcNrr72G//znP9Bqtebyuro6rFu3Dl1dXZDL5UhNTR2MUyYiD8IJXYmIAHz22Wd48803odfrAQByuRxyuRxtbW3mZYeAe7cwAceXOJo9ezays7MtljhavXo1Tp48CeDH5Y30ej10Oh2Ae7cp3377bT6sTzQEMBEjIvp/dXV12Lt3L7799lvU19eju7sb4eHhGDt2LB599FE888wzSEhIMNftvej3f//7X+Tm5qKsrAw6nQ4JCQn9Lvp95coVFBYW4syZM6ipqUFLSwsMBgNiY2Pxk5/8BEuXLuUSR0RDBBMxIiIn3J+IERE5g8+IEREREYmEiRgRERGRSJiIEREREYmEiRgRERGRSPiwPhEREZFIeEWMiIiISCRMxIiIiIhEwkSMiIiISCRMxIiIiIhEwkSMiIiISCRMxIiIiIhE8n/rvtdiFPFgrgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 648x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_style(\"ticks\", {\"xtick.major.size\": 14, \"ytick.major.size\": 14})\n",
    "sns.set_context(\"poster\")\n",
    "mpl.rcParams['axes.linewidth']=2.5\n",
    "mpl.rcParams['ytick.major.width']=2.5\n",
    "mpl.rcParams['xtick.major.width']=2.5\n",
    "\n",
    "MARKER_SIZE=15\n",
    "\n",
    "plt.figure(figsize=(9, 5))\n",
    "plt.plot(epsilons, 100 * (1 - a2_attack_success.mean(-1).round(2)), marker='.', markersize=MARKER_SIZE, color='g')\n",
    "\n",
    "plt.xlabel('eps')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.title(f'Robustness - {attack_type}')\n",
    "\n",
    "sns.despine()\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
