{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Libraries import *\n",
    "from Geometry_Plottings import *\n",
    "from Adversarial_Attacks_synth import *\n",
    "from Geometry_utilities import *\n",
    "from trainings import *\n",
    "from utilities_for_synth_atk import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Generating Synthetic Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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zv3gVbenT3LOPeGca51zX3TO/YZz7nuvuk19k3Nuxzn3q865n7/qtvRNA7AXkHPuCQD4VgB486rb0jP9AgD8Oe/9nweALwHAD11xe6qTc24HAP4VAPwNAPgoANxwzn30alvVK90HgH/ivf8zAPCXAOAfbXh/AQC+FwC+eNWNWAcNwF5G/wIA/ikAbLSjwnv/n7339xf//G8AcO0q29MTfRMA/Lb3/ne89+8CwCsA8LeuuE29kff+/3jvf2Xx/+/AHPAev9pW9UfOuWsA8DcB4Cevui3roAHYM8k59x0A8Jb3/gtX3ZY1098HgP941Y3ogR4HgLvRv+/BBgNdTM65JwHgLwDAf7/alvRKt2CuhF1cdUPWQcNFGww5534RAD6M/PQZAPhhAPi29baoP+L66r3/ucUzn4H5Fv6z62zbmsghf9vonRgAgHPuEABOAeD7vPd/eNXt6YOcc58EgLe997edcx+/6vasgwZgZ8h7/9ewvzvnngaApwDgC845gLlp4lecc9/kvf/dNTaxGlF9DeSc+24A+CQAHPnNjJG9BwBPRP++BgD/+4rashZyzu3BHNQ/673/matuT4/0zQDwHc65bweADwDAn3TONd7777ridvVGQxx7BXLOvQ4Az3jvH+TkQiQ55z4BADcB4K9677981e3pg5xzuzB3DB8BwFsA8D8A4FPe+9+40ob1RG6ukbwMAGfe+++76vasixYa+w947z951W3pkwYb+0Aa+jEA+AYA+AXn3K855378qhtUmxbO4X8MAJ+DuSPx328qqC/omwHg0wDwLYs5/bWFRjvQBtCgsQ800EADbRgNGvtAAw000IbRAOwDDTTQQBtGA7APNNBAA20YDcA+0EADDbRhNAD7QAMNNNCG0QDsAw000EAbRgOwDzTQQANtGA3APtBAAw20YfT/AZPC13jktCkHAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_classes =2\n",
    "setting = 3\n",
    "\n",
    "if setting==1 :\n",
    "    X1, Y1 = make_classification(n_samples=4000,n_features=2, n_redundant=0, n_informative=2,n_clusters_per_class=1, n_classes=num_classes)\n",
    "    plt.scatter(X1[:, 0], X1[:, 1], marker='o', c=Y1, s=25, edgecolor='k')   \n",
    "    x = torch.from_numpy(X1).to(device,dtype=torch.float)\n",
    "    y = torch.from_numpy(Y1).to(device,dtype=torch.double)\n",
    "\n",
    "if setting==2 :   \n",
    "    X1, Y1 = make_blobs(n_samples=5000,n_features=2, centers = num_classes)\n",
    "    plt.scatter(X1[:, 0], X1[:, 1], marker='o', c=Y1,s=30, edgecolor='k')\n",
    "    x = torch.from_numpy(X1).to(device,dtype=torch.float)\n",
    "    y = torch.from_numpy(Y1).to(device,dtype=torch.double)\n",
    "\n",
    "if setting==3:\n",
    "    centers = {'c1' : (1.05, 2.55), 'c2': (1.85,8.5)}\n",
    "    Condition1='np.logical_or(np.logical_and(y>x ,y>-x), np.logical_and(y<-x,y<x))'\n",
    "    Condition2='np.logical_or(np.logical_and(y<x ,y>-x), np.logical_and(y>x,y<-x))'\n",
    "    x,y=Data_Generation(2000,Condition1, Condition2, False, centers)\n",
    "#plt.savefig('DataSet')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training a simple model (Affine-ReLU-Affine)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trained model is loaded successfully\n"
     ]
    }
   ],
   "source": [
    "biases = True\n",
    "size_net = 20\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "epochs = 200\n",
    "alpha = 0.05\n",
    "batch_size = 200\n",
    "trainx, trainy, testx,testy= dataloader(x,y)\n",
    "model = Net(size_net,x.size(1),num_classes,biases).to(device)\n",
    "model.load_state_dict(torch.load('saved_model.pth'))\n",
    "if accuracy(model, x, y) < 95:\n",
    "    model=train(model,criterion,x,y,alpha,25,batch_size)\n",
    "else:\n",
    "    print('Trained model is loaded successfully')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Attacking the model using tropical adversarial attack"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The model was classifing the x_0 as class 0, The target class is 1\n",
      "GG\n",
      "All conditions are satisfied, and the attack is successful in 2 iterations\n",
      "The attacked model is now classifying x_0 as class 1\n"
     ]
    }
   ],
   "source": [
    "target = 1         #The target class\n",
    "target = torch.tensor(target).reshape(1).to(device)\n",
    "#temp = np.array([0.9,0.7])\n",
    "temp = np.array([2.0,-1.85])\n",
    "x_0 = torch.tensor(temp,dtype = torch.float32).unsqueeze(dim=0).to(device)\n",
    "x_0 = x_0.squeeze()\n",
    "model_new = deepcopy(model).to(device)\n",
    "\n",
    "#Initializations\n",
    "criterion  = nn.CrossEntropyLoss().to(device)\n",
    "epsilon1   = 2.0  #Upperbound on input noise\n",
    "epsilon2   = 0.15   #Upperbound on layer noise\n",
    "iterations = 2000   #Number of iterations\n",
    "rho        = 0.01   #ADMM constant to match the new variables to each other\n",
    "eta        = 1.0   #Bergman divergance coeffecient\n",
    "lamda      = 0.1  #For the constraint ||A delta_x - delta_A x|| = 0\n",
    "sigma      = 0  #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_new(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_for_syn(model_new,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_new(x_0+delta_x).unsqueeze(dim=0).argmax(1).item()}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Making a perturbed model by adding the perturbation on the first layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1], device='cuda:0')"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "A = model.fc1.weight.data\n",
    "per_model = deepcopy(model)\n",
    "per_model.state_dict()['fc1.weight'][:,:] = A + delta_a\n",
    "per_model(x_0).unsqueeze(dim=0).argmax(1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualization of the decision boundary and the attacked point for the benign model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "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": [
    "plot_2d_new(model,temp,device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualization of the decision boundary and the attacked point for the attacked model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "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": [
    "plot_2d_new(per_model,temp,device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Extracting the polytopes of the two models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "boundary_vertices,decision_boundary,_,_,_,_,_,_ = get_model_polytopes(model,False,True,False) #True for getting the boundary polytope\n",
    "boundary_vertices_gg,decision_boundary_gg,_,_,_,_,_,_ = get_model_polytopes(per_model,False,True,False) #True for getting the boundary polytope"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Green polytope for benign model\n",
    "## Blue polytope for attacked model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "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": [
    "plot_polytope_2(boundary_vertices,decision_boundary,boundary_vertices_gg,decision_boundary_gg,'Orignal model','Perturbed model')\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
