{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Libraries import *\n",
    "from Mnist_attakc_uti import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Loading the dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Getting the datasets\n",
    "transforms = Compose([\n",
    "    ToTensor(),\n",
    "#     Normalize(\n",
    "#         mean=[0.1307],\n",
    "#         std=[0.3081],\n",
    "#     )\n",
    "])\n",
    "trainset = MNIST(root = './mnist_data',train = True, download = True,transform=transforms)\n",
    "testset  = MNIST(root = './mnist_data',train = False,download = True,transform=transforms)\n",
    "\n",
    "trainloader = DataLoader(trainset,batch_size=96,shuffle=True)\n",
    "testloader  = DataLoader(testset ,batch_size=96,shuffle=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.5, 27.5, 27.5, -0.5)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "a,b = trainset[2]\n",
    "plt.imshow((1-a).squeeze().cpu(),cmap='Greys')\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Loading the trained model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9702"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "net = net_mnist(28*28,10)\n",
    "net.to(device)\n",
    "net.load_state_dict(torch.load('mnist_model.pth'))\n",
    "validate(net,testloader)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Attacking the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/alfarrm/miniconda3/envs/modar/lib/python3.6/site-packages/ipykernel_launcher.py:10: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  # Remove the CWD from sys.path while we load stuff.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The model was classifing the x_0 as class 4, The target class is 2\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "GG\n",
      "All conditions are satisfied, and the attack is successful in 20 iterations\n",
      "The attacked model is now classifying x_0 as class 2\n"
     ]
    }
   ],
   "source": [
    "target = 2          #The target class\n",
    "x_0,_  = trainset[2]\n",
    "target = torch.tensor(target).reshape(1).to(device)\n",
    "x_0,target = x_0.unsqueeze(dim=0).to(device),torch.tensor(target).reshape(1).to(device)\n",
    "\n",
    "model = deepcopy(net).to(device)\n",
    "\n",
    "#Initializations\n",
    "criterion  = nn.CrossEntropyLoss().to(device)\n",
    "epsilon1   = 0.1 #Upperbound on input noise\n",
    "epsilon2   = 1.0      #Upperbound on layer noise\n",
    "iterations = 2000   #Number of iterations\n",
    "rho        = 1.0     #ADMM constant to match the new variables to each other\n",
    "eta        = 2.5     #Bergman divergance coeffecient\n",
    "lamda      = 1e-3  #For the constraint ||A delta_x - delta_A x|| = 0\n",
    "sigma      = 0.01     #Sparsity Factor, CAUTION, this number should be less than epsilon1 otherwise, no solution will be found\n",
    "\n",
    "print(f'The model was classifing the x_0 as class {model(x_0).unsqueeze(dim=0).argmax(1).item()}, The target class is {target.item()}')\n",
    "delta_x,z,w,delta_a,eqq = str_atk_tg(model,x_0,target,criterion,epsilon1,epsilon2,rho,eta,lamda,sigma,iterations)\n",
    "print(f'The attacked model is now classifying x_0 as class {model(x_0+delta_x).unsqueeze(dim=0).argmax(1).item()}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The perturbed model is classifying the orignial image as 2\n"
     ]
    }
   ],
   "source": [
    "A = model.state_dict()['fc1.weight'].data\n",
    "per_model = deepcopy(model)\n",
    "per_model.state_dict()['fc1.weight'][:,:] = A + delta_a\n",
    "print(f'The perturbed model is classifying the orignial image as {per_model(x_0).unsqueeze(dim=0).argmax(1).item()}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Perturbed image before sparsifying"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f1240fa42b0>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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84EHHjDrXr/amwcQVZV9/AULFpj1q6++uun7fu+998z6nDlzzLq350CV6wE0ijP8iIJi+ImCYviJgmL4iYJi+ImCYviJgip16W5VLexyxVtuucWse8uCv/LKK3kO57JhLbUOAGfPni3ssQcGBsy61047ceJE3drQ0JB5bOr24dZ28oC9Hb13bF545icKiuEnCorhJwqK4ScKiuEnCorhJwqK4ScKqtQ+f5G8LbZFxKzv2bMnz+G0jK6uLrPu9fFV1awvXrzYrN933311a3fffbd57K233mrWvX74o48+WrdW9Jbss2fb0bIuleYW3URUKIafKCiGnygohp8oKIafKCiGnygohp8oqFL7/N7S3d411FZv1Ftqua3N/jnX09Nj1t966y2znuLaa681693d3Wb94Ycfrlvzti63risHgDVr1ph1b/6EtfW5t032xMSEWfeWY9+1a5dZT+F9v3mssXufV1545icKiuEnCorhJwqK4ScKiuEnCorhJwqK4ScKSrzrtUVkK4AvAxhW1VXZbU8C+CaAj7IPe0JVX/YerK2tTYvaovvll+2Hv/322826t67/sWPH6ta859C77nzFihVm3eulW31h71hrbXsAOHDggFl/4403zPr27dvr1g4ePGgeOzIyYtY7OjrMekq/3NsTwJuTsnDhQrNu7Xfg5cDK0JkzZzA+Pm5/0TONnPl/BuCuKW7/saquzv65wSei1uKGX1X3ADhewliIqEQpr/kfEZFfi8hWEbHnnxJRy2k2/FsArASwGsBRAD+s94Ei0ici+0Rkn/famIjK01T4VXVIVcdVdQLATwDUvfpDVftVtVdVe70/PhFReZoKv4gsq3n3KwDsP9sSUctxL+kVkecArAOwWEQOA/g+gHUishqAAhgE8K0Cx0hEBXD7/Lk+mEhlL/o3b95s1tevX2/WrefJW2fd2wveWzvfuy597969dWuvvfaaeazVMwb8OQzeSzlrjsOmTZvMYx9//HGz7s0DWLRoUd2aNwfAe1686/m9dfutfQOsdSsAf96IqubW5yeiyxDDTxQUw08UFMNPFBTDTxQUw08U1GXT6luwYIFZ99ppw8PDTR9vXZ4J+JeHestne8uOW+02b/lrryXl8dpS1tief/5581hv2XDv+Iceeqhuzbsc2HvevPautWQ5YLcaT548aR7rYauPiEwMP1FQDD9R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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(1-(x_0 + delta_x).squeeze().cpu(),cmap = 'Greys')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sparsifying the attack"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([2], device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "epsilon = 0.04\n",
    "w_bar = deepcopy(delta_x)\n",
    "w_bar[torch.abs(w_bar) < epsilon] = 0\n",
    "print(model(x_0 + w_bar).unsqueeze(dim=0).argmax(1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.5, 27.5, 27.5, -0.5)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPsAAAD4CAYAAAAq5pAIAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvnQurowAACGxJREFUeJzt3T2PVGUfx/EzPMjDAssuBApDCHQYE60MVKCJHcTExIbG1trXQInvQEJpY0jU2GADsRBooYICLCiWwC7rsAqCzF1xJybM/8KZ2Qfm9/mU/HNmzu7w5SRcc53TGwwGHTD9Nq33CQBrQ+wQQuwQQuwQQuwQYstavlmv1/Nf/6tgZmZm6GxlZWUNz4SNYDAY9F73567sEELsEELsEELsEELsEELsEELsEKK3lrverLPD6rPODuHEDiHEDiHEDiHEDiHEDiHEDiHWdD/7aqr2dHdd7r5uvxdecWWHEGKHEGKHEGKHEGKHEGKHELa4roFxl7/m5+fL+aZNw//NrmZd13XPnz8f+bW7rus2b95czp89ezZ09vLly/LYfr9fznk9W1whnNghhNghhNghhNghhNghhNghhHX2NzQ7Ozt0tnXr1vLY1lp06zPo9V67bPp/1Vr2li3j7WJunds489Y6e+v3tri4WM5TWWeHcGKHEGKHEGKHEGKHEGKHEGKHENbZWVUHDx4c+dgXL16U89Y6/MmTJ4fOLl68WB77/vvvl/N79+6V8/VknR3CiR1CiB1CiB1CiB1CiB1CiB1CTM0jm1s+++yzcr5///5yfuHChUmeztQ4cOBAOV9YWBg6m5ubK49tfQfk6dOn5fz48eNDZ3fu3Bnrvd9GruwQQuwQQuwQQuwQQuwQQuwQImbp7dNPPy3nrS2Nlt5e78GDByMfu7S0NNZ7tx4nXd3+u7X1trUs+Pvvv5fzjciVHUKIHUKIHUKIHUKIHUKIHUKIHULE3Er60aNH5fzmzZvl/NSpUxM8Gybh8OHD5fzu3btDZ1evXi2P/fjjj0c6p43AraQhnNghhNghhNghhNghhNghhNghxJruZ5+ZmSnnKysrq/berb3PvH1+/PHHkY9trbOv59/V1aIACCF2CCF2CCF2CCF2CCF2CCF2CLGm6+yruTZZPZ6369rrpv1+f5KnwxrYtWvXyMf+9ttv5fxtXEdvcWWHEGKHEGKHEGKHEGKHEGKHEGKHEFPzfPYvvviinG/ZUv+ou3fvnuTpMAGtz+TAgQMjv/bt27dHPvZNbMT98K7sEELsEELsEELsEELsEELsEGJqlt4++OCDcv706dNy/vPPP0/ydJiAn376qZy3lrcePnw4dLa8vDzSOb2pjbhF1pUdQogdQogdQogdQogdQogdQogdQkzNOvu4fv311/U+hVUxOztbznfs2FHOB4NBOX/nnXfK+enTp4fOPv/88/LYjz76qJw/f/68nH/99ddDZ4uLi+Wx08iVHUKIHUKIHUKIHUKIHUKIHUKIHULErLNv2lT/u3bo0KFyfu3atUmezr8cPXq0nL/77rvl/OzZs0Nn7733Xnnstm3byvm4a929Xm/orPXY5NZn1ro9+OXLl8v5RtV6FPWTJ09Gel1XdgghdgghdgghdgghdgghdgghdgjRa+1Xnuib9Xqr9mY//PBDOT9z5kw5b91Xfpz9z6110SNHjoz82l3XdZs3bx46a61VLy0tlfNbt26V89Z9AL799tuhs/v375fHts5t+/bt5by1Dr+aWo+T/uuvv4bO+v1+eWxrHb7f77/2yw2u7BBC7BBC7BBC7BBC7BBC7BBC7BBiatbZW86fP1/OT506NfJr79mzp5z/8ccfI79213XdL7/8Us6vXLkydHbjxo3y2NZ+9tbfj2q/etd13d9//z109tVXX5XHnjt3rpy31uH37dtXzsexe/fuct66n/6jR48meTr/MhgMrLNDMrFDCLFDCLFDCLFDCLFDiKlZemsthbQeTfzgwYNJns5/Mjc3V85b21Sr5a+XL1+Wx7a2gbaOH2dprrUt+cMPPyzn33//fTn/8ssvy/k49u7dW85fvHhRzqttycvLyyOd0yuW3iCc2CGE2CGE2CGE2CGE2CGE2CHE1DyyubWl8J9//hnr9ffv3z909vDhw/LY1jp6a012nO8ItNaDqy2oXdd1jx8/LucHDx4s561bdFdaP/d333038mu3bse8c+fOcl6tk3dd+/sJCwsLQ2czMzPlsSsrK+V8GFd2CCF2CCF2CCF2CCF2CCF2CCF2CDE16+ytW/POz8+X89Z68Z9//jl01lqzba3JtubjfEeg9dpbt24t560139Z+9tbrr5dxH+fc+kxa8+r7D63vNozKlR1CiB1CiB1CiB1CiB1CiB1CiB1CTM06+7iqdfSuq/cnt+5Z39rb3Jq31sqrRxOP+2jgcX+2aq9/61HWrcdBHzt2rJxfv3596Gzc/ejPnj0r5/1+v5yvB1d2CCF2CCF2CCF2CCF2CCF2CDE1S2+tLaytxx6Ps1TSurVva/lqIy7TvNL6vbVuo13Zs2dPOW9tn22d29LS0n8+p1dmZ2fLeWvpbiNyZYcQYocQYocQYocQYocQYocQYocQU7POvri4ONbxrccqV2u2rdstb+R19Jbl5eV1e+/WNtJPPvmknH/zzTcjv3fr52595huRKzuEEDuEEDuEEDuEEDuEEDuEEDuEmJp19nGNs/e5tZ+d0bT2q6+nt/Ez37i/TWCixA4hxA4hxA4hxA4hxA4hxA4hpmadfdeuXeX8yZMna3QmvKlLly6V8xMnTpTzx48fT/J0pp4rO4QQO4QQO4QQO4QQO4QQO4QQO4TotZ6BPdE36/XW7s0g1GAw6L3uz13ZIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIYTYIcSa3koaWD+u7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BBC7BDifw6R3FS8urcGAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(1-(x_0 + w_bar).squeeze().cpu(),cmap='Greys')\n",
    "plt.axis('off')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training a five linear layers on MNIST"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "net = net_mnist(28*28,10)\n",
    "net.to(device)\n",
    "criterion = nn.CrossEntropyLoss().to(device)\n",
    "writer = SummaryWriter()\n",
    "net = train_mnist(net,trainloader,testloader,criterion,lrate=0.03,max_epochs=50)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:modar]",
   "language": "python",
   "name": "conda-env-modar-py"
  },
  "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
