{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Black-box Attack on CIFAR10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torchattacks\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load model and data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "[Data loaded]\n",
      "[Model loaded]\n",
      "Acc: 100.00 %\n"
     ]
    }
   ],
   "source": [
    "import robustbench\n",
    "from robustbench.data import load_cifar10\n",
    "from robustbench.utils import load_model, clean_accuracy\n",
    "\n",
    "images, labels = load_cifar10(n_examples=5, data_dir='provide_some_data_directory_here')\n",
    "print('[Data loaded]')\n",
    "device = \"cuda\"\n",
    "model = load_model('Standard', norm='Linf', model_dir='provide_some_data_directory_here').to(device)\n",
    "acc = clean_accuracy(model, images.to(device), labels.to(device))\n",
    "print('[Model loaded]')\n",
    "print('Acc: %2.2f %%'%(acc*100))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sparse Adversarial Attack with group norms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchattacks import PGD\n",
    "from utils import imshow, get_pred\n",
    "import custom_proj_bb\n",
    "import importlib\n",
    "\n",
    "\n",
    "importlib.reload(custom_proj_bb)\n",
    "\n",
    "atk = custom_proj_bb.PGDGroupBB(model, alpha=8/225, steps=100, random_start=False, k=50, D=np.sqrt(1/16.))\n",
    "print(atk)\n",
    "results = atk(images, labels)\n",
    "adv_images, delta, costs = results['adv_images'], results['delta'], results['costs']\n",
    "delta.shape\n",
    "delta.shape\n",
    "idx = 4\n",
    "imshow(delta[idx:idx+1])\n",
    "plt.figure()\n",
    "plt.plot(costs)\n",
    "idx = 3\n",
    "pre = get_pred(model, adv_images[idx:idx+1], device)\n",
    "plt.figure()\n",
    "imshow(adv_images[idx], title=\"True:%d, Pre:%d\"%(labels[idx], pre))\n",
    "pre = get_pred(model, adv_images, device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Adversarial attack with a similar l2 norm, but enforced globally"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torchattacks import PGD\n",
    "from utils import imshow, get_pred\n",
    "import custom_proj_bb\n",
    "import importlib\n",
    "\n",
    "\n",
    "importlib.reload(custom_proj_bb)\n",
    "\n",
    "atk = custom_proj_bb.PGDvanillal2BB(model, alpha=8/225, steps=500, random_start=False, k=50, D=1.)\n",
    "print(atk)\n",
    "results = atk(images, labels)\n",
    "adv_images_global, delta_global, costs = results['adv_images'], results['delta'], results['costs']\n",
    "delta_global.shape\n",
    "delta_global.shape\n",
    "idx = 4\n",
    "imshow(delta_global[idx:idx+1])\n",
    "plt.figure()\n",
    "plt.plot(costs)\n",
    "idx = 3\n",
    "pre = get_pred(model, adv_images_global[idx:idx+1], device)\n",
    "plt.figure()\n",
    "imshow(adv_images_global[idx], title=\"True:%d, Pre:%d\"%(labels[idx], pre))\n",
    "pre = get_pred(model, adv_images_global, device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# We now print the difference in l2 norms of all the images"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "max_pix = torch.max(torch.sqrt((delta_global[idx:idx+1][0]**2).sum(axis=0)).cpu())\n",
    "print(max_pix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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lteVcC29UY9I6K56tJzcjRo1CgaDwbIdP37c0yE55fz58xg7diw2bNhg9/XVq1cjLy8PGzZswJEjR6DRaDB58uQet57/9c4TAKZOnWp1bcvLy29ghM6rrKzE4sWLcfjwYej1ely+fBlarRbnz5+39FHC9XTkPIGefz2HDBmCl19+GUePHsXRo0dx7733Yvr06ZakrYRr6ZWEb3TzgLvuuktKT0+3aouKipKWLVvmoYhcb/ny5dLYsWM9HYbbAJB2795t+f2XX36RNBqN9PLLL1vaLl68KAUGBkqbNm3yQISuce15StKVe1enT5/ukXjcpampSQJguVdWqdfz2vOUJGVeT0mSpAEDBkivv/66Yq+lN5B9he7KR8vJXV1dHUJDQxEZGYk5c+bg22+/9XRIblNfXw+j0Wh1XdVqNSZMmKC46woAFRUVGDx4MIYPH45FixahqanJ0yE5pbW1FQAwcOBAAMq9nteeZwclXc/29naUlpbi/PnzSExMVOy19AayT+iufLScnMXHx6O4uBh79uzB1q1bYTQakZSUhJaWFk+H5hYd107p1xUAUlJS8NZbb+Gjjz7Cq6++iiNHjuDee+/t9LnMcidJEnQ6HX79618jOjoagDKvp73zBJRzPY8fP47+/ftDrVYjPT0du3fvxsiRIxV5Lb1Fj1nL3RWPlpOzlJQUy8+jR49GYmIihg4dih07dkCn03kwMvdS+nUFgNTUVMvP0dHRiIuLQ0REBN5//33MnDnTg5F1z6OPPopjx45ZrUXdQUnXs7PzVMr1vP3221FbW4szZ85g165dmD9/PiorKy2vK+laegvZV+iufLRcT9KvXz+MHj0adXV1ng7FLTq+we9t1xUAQkJCEBER0SOv7WOPPYb33nsPH3/8sdVjjpV2PTs7T3t66vX09fXFr371K8TFxSE3Nxdjx47FunXrFHctvYnsE7orHy3Xk5jNZpw8eRIhISGeDsUtIiMjodForK5rW1sbKisrFX1dAaClpQWNjY096tpKkoRHH30Ub7/9Nj766CNERkZava6U63m987SnJ15PeyRJgtlsVsy19Eoe+zqegNLSUqlPnz5SUVGRdOLECSkzM1Pq16+fdOrUKU+H5jJPPvmkVFFRIX377bfS4cOHpfvvv1/y9/fv0ed49uxZqaamRqqpqZEASHl5eVJNTY303XffSZIkSS+//LIUGBgovf3229Lx48eluXPnSiEhIZLJZPJw5GK6Os+zZ89KTz75pHTo0CGpvr5e+vjjj6XExETplltu6VHn+ec//1kKDAyUKioqJIPBYNkuXLhg6aOE63m981TK9czKypL2798v1dfXS8eOHZOeeeYZqVevXtLevXslSVLGtfRGPSKhS5JrHi0nZ6mpqVJISIjUp08fKTQ0VJo5c6b01VdfeTosp3z88ccSAJtt/vz5kiRdudVp+fLlkkajkdRqtXT33XdLx48f92zQ3dDVeV64cEHSarVSUFCQ1KdPHyk8PFyaP3++1NDQ4Omwhdg7PwDSG2+8YemjhOt5vfNUyvX84x//aPn7NCgoSPrNb35jSeaSpIxr6Y34+FQiIiIFkP1n6ERERHR9TOhEREQKwIRORESkAEzoRERECsCETkREpABM6ERERArAhE5ERKQATOhEREQKwIRORESkAEzoRERECsCETkREpABM6ERERArw/wAPqre5JrFq5QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.colors as mcolors\n",
    "\n",
    "\n",
    "cmap = plt.get_cmap('gray')\n",
    "fig, ax = plt.subplots()\n",
    "im = ax.imshow(torch.sqrt((delta[idx:idx+1][0]**2).sum(axis=0)).cpu(), cmap=cmap, vmin=0., vmax=max_pix)\n",
    "for i in range(1, 4):\n",
    "    plt.axhline(i * 32 / 4 - 0.5, color='white', linewidth=1)\n",
    "# Add vertical lines\n",
    "for i in range(1, 4):\n",
    "    plt.axvline(i * 32 / 4 - 0.5, color='white', linewidth=1)\n",
    "cbar = plt.colorbar(im, ax=ax, pad=0.03)  # Adjust the pad as needed for positioning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.colors as mcolors\n",
    "\n",
    "cmap = plt.get_cmap('gray')\n",
    "\n",
    "norm = mcolors.LogNorm(vmin=1e-4, vmax=1, clip=True)\n",
    "fig, ax = plt.subplots()\n",
    "im = ax.imshow(torch.sqrt((delta_global[idx:idx+1][0]**2).sum(axis=0)).cpu(), cmap=cmap, vmin=0., vmax=max_pix)\n",
    "for i in range(1, 4):\n",
    "    plt.axhline(i * 32 / 4 - 0.5, color='white', linewidth=1)\n",
    "\n",
    "# Add vertical lines\n",
    "for i in range(1, 4):\n",
    "    plt.axvline(i * 32 / 4 - 0.5, color='white', linewidth=1)\n",
    "\n",
    "cbar = plt.colorbar(im, ax=ax, pad=0.03)  # Adjust the pad as needed for positioning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.2500, device='cuda:0')\n",
      "tensor(0.4114, device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "print(custom_proj.max_l2_norm_in_regions(delta[3]))\n",
    "print(custom_proj.max_l2_norm_in_regions(delta_global[3]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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mke6T34onFQ2oWRantCdzshrAcAomlAy3d9UWo4ew8efNOeei7IJ+RXpyL19urHTaflyusomFAzki2tjE5RPEgC0njiFIy2yO3YyLU8iH0lNSJOgrm5Crjxd2h8IAgBOtMXQcvS0YGxtE5Ivp7oJKR5WHEd3/3HC8nn7ej8X1yYSudP4z+IHE4iIyBo2ISIisoZNiIiIrGETIiIia9iEiIjIGjYhIiKyhk2IiIisYRMiIiJrRuzJqvnBQoSCQVFt0i8/AdWfkZ84CQD5+aXiWs/RjZ1WnNzq+nQnCRooEhPGTzhzXY1ET+517rryE9wAwFOc3OoZ3Um5juJ5lDHKs/0d+d1Dc/5uyN+//lwk4YNseQN+RbpGn/zkbQBwjOK5qG4VIpVSnDSdlC8jAPh98nl3d/Wcuf4YsY7cqSDqE2cVc9GKd3SIa41yHfYqOkC+/7i4NpWSz4NHQkREZI2qCTU0NOC2225DOBxGWVkZHnjgAXz00UcDah555BE4jjPgcscddwzppImIaGxQNaGmpiYsXboU27dvR2NjI9LpNGpra9HT0zOg7t5778Xx48ezl7feemtIJ01ERGOD6j2hd955Z8D/169fj7KyMuzatQt333139vZQKIRoNDo0MyQiojHrkt4T6uzsBACUlg58837Lli0oKyvD1KlT8eijj6Kt7fxJwYlEArFYbMCFiIiuDBfdhIwxWLFiBe68805Mnz49e3tdXR1efvllbN68Gc8//zx27NiBBQsWIJEY/FNADQ0NiEQi2UtVVdXFTomIiEaZi/6I9rJly7B37168//77A25fvHhx9t/Tp0/HrFmzUF1djTfffBOLFi06Z5yVK1dixYoV2f/HYjE2IiKiK8RFNaEnnngCb7zxBrZu3YpJkyZdsLaiogLV1dU4ePDgoD8PhUIIheTfkEhERGOHqgkZY/DEE0/gtddew5YtW1BTU5Pzd9rb29HS0oKKioqLniQREY1NqveEli5dip///OfYsGEDwuEwWltb0drair4zZ2h3d3fjhz/8IX7729/i8OHD2LJlC+677z5MmDABDz744LAsABERjV6qI6F169YBAObPnz/g9vXr1+ORRx6Bz+fDvn378NJLL6GjowMVFRW455578MorryAclkfrEBHRlUH9ctyF5OfnY9OmTZc0obO8VAKe44lqO2Pn/wj4lxX581Xz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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torchvision\n",
    "\n",
    "image_data = images[idx].cpu()\n",
    "\n",
    "img = torchvision.utils.make_grid(image_data.data, normalize=True)\n",
    "npimg = img.numpy()\n",
    "fig = plt.figure()\n",
    "plt.imshow(np.transpose(npimg,(1,2,0)))\n",
    "# Add horizontal lines\n",
    "\n",
    "for i in range(1, 4):\n",
    "    plt.axhline(i * 32 / 4 - 0.5, color='white', linewidth=1)\n",
    "\n",
    "# Add vertical lines\n",
    "for i in range(1, 4):\n",
    "    plt.axvline(i * 32 / 4 - 0.5, color='white', linewidth=1)\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "1ceb8aea646a0c712ed5db194d127de24ece80f87032283552cbe7de982c3798"
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
