{
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "# Libraries/Imports"
      ],
      "metadata": {
        "id": "jlPGRHPaEFsG"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "McEe2CqKm4EG"
      },
      "outputs": [],
      "source": [
        "# sci-kit learn libraries\n",
        "import sklearn\n",
        "from sklearn.svm import LinearSVC\n",
        "from sklearn.datasets import make_classification\n",
        "from sklearn.metrics import hinge_loss\n",
        "\n",
        "# dataset and ml libraries\n",
        "from keras.datasets import cifar10\n",
        "import torch\n",
        "import numpy as np\n",
        "\n",
        "# plotting libraries\n",
        "import matplotlib.pyplot as plt\n",
        "import seaborn as sns\n",
        "\n",
        "# miscellaneous\n",
        "import time\n",
        "import random\n",
        "import sys\n",
        "from pdb import set_trace\n",
        "\n",
        "# Set seeds for poison / camou / target selection here:\n",
        "\n",
        "random.seed(222222)"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Training SVM on CIFAR-10"
      ],
      "metadata": {
        "id": "-Ylk_UHHELS4"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "QR1C9PvKnOEy"
      },
      "outputs": [],
      "source": [
        "# Class Dictionary for CIFAR10\n",
        "classDict = {'plane': 0, 'car': 1, 'bird': 2, 'cat': 3, 'deer': 4,\n",
        "             'dog': 5, 'frog': 6, 'horse': 7, 'ship': 8, 'truck': 9}\n",
        "\n",
        "binaryClasses = {0:'Machine', 1:'Animal'} # Machine , Animal\n",
        "\n",
        "# Method to obtain camouflages: use \"BREW\" for Gradient matching or \"FLIP\" by label flipping\n",
        "CAMO = 'BREW'"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Mounts Google drive to be used with Colab. \n",
        "from google.colab import drive\n",
        "drive.mount('/content/drive')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "4AOxVbYpUon-",
        "outputId": "d64ec486-034f-4d32-8d42-11024ce22a3c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/drive\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "9cPmxBKamnNz",
        "outputId": "fee5b2cb-e10b-43fb-a6e3-d5a7f9dd3f28"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Downloading data from https://www.cs.toronto.edu/~kriz/cifar-10-python.tar.gz\n",
            "170500096/170498071 [==============================] - 12s 0us/step\n",
            "170508288/170498071 [==============================] - 12s 0us/step\n",
            "Elapsed[s] :  40.798439264297485\n",
            "Train : 0.82016\n",
            "Test : 0.8163\n"
          ]
        }
      ],
      "source": [
        "if __name__ == \"__main__\":\n",
        "    start_time = time.time()\n",
        "    (x_train, y_train), (x_test, y_test) = cifar10.load_data()\n",
        "    model = LinearSVC(loss='hinge', max_iter=3000)\n",
        "\n",
        "    # Normalize pixel values and dividing each image by its forbenius norm\n",
        "    x_train = x_train / 255\n",
        "    x_test = x_test / 255\n",
        "    m_train, m_test = x_train.shape[0], x_test.shape[0]\n",
        "    x_train, x_test = x_train.reshape(m_train, -1), x_test.reshape(m_test, -1)\n",
        "    x_train_norm = np.linalg.norm(x_train, ord=2, axis=1, keepdims=True)\n",
        "    x_test_norm = np.linalg.norm(x_test, ord=2, axis=1, keepdims=True)\n",
        "    x_train = x_train / x_train_norm\n",
        "    x_test = x_test / x_test_norm\n",
        "\n",
        "    # Flatten labels\n",
        "    y_train = y_train.ravel()\n",
        "    y_test = y_test.ravel()\n",
        "    animal_indices = []\n",
        "    machine_indices = []\n",
        "\n",
        "    # Convert to Binary dataset\n",
        "    for i in range(m_test):\n",
        "        if y_test[i] in [2,3,4,5,6,7]:\n",
        "            y_test[i] = 1\n",
        "        else:\n",
        "            y_test[i] = 0\n",
        "    for i in range(m_train):\n",
        "        if y_train[i] in [2,3,4,5,6,7]:\n",
        "            y_train[i] = 1\n",
        "            animal_indices.append(i)\n",
        "        else:\n",
        "            y_train[i] = 0\n",
        "            machine_indices.append(i)\n",
        "            \n",
        "    #fit\n",
        "    model.fit(x_train, y_train)\n",
        "\n",
        "    # Check support vectors\n",
        "    decision_function = model.decision_function(x_train)\n",
        "    support_vector_indices = np.where(np.abs(decision_function) <= 1 + 1e-15)[0]\n",
        "    support_vectors = x_train[support_vector_indices]\n",
        "\n",
        "    # Check clean training results\n",
        "    print(\"Elapsed[s] : \", time.time() - start_time)\n",
        "    print(\"Train :\", model.score(x_train, y_train))\n",
        "    print(\"Test :\", model.score(x_test, y_test))"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Plotting Histogram of Model Decision Boundary vs. Distance"
      ],
      "metadata": {
        "id": "NeFqnNLfEVg-"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "DhzFsCiYm4Nc"
      },
      "outputs": [],
      "source": [
        "## Correct classifications\n",
        "correct_classified_indices = []\n",
        "for i in range(len(decision_function)):\n",
        "  if (decision_function[i] < 0 and y_train[i] == 0) or (decision_function[i] >= 0 and y_train[i] == 1):\n",
        "    correct_classified_indices.append(i)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "JsF0PazDoEl8",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 295
        },
        "outputId": "13d30a97-54a1-482f-ec93-1c7154206d78"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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168f99xzDyNHjmyROBrz6KOPMnHiRAYMGADAscceyx133MG4cXVeqbmL4uJirrzySt544w2ysrLo3r07t956K+PHjyczM5Pi4uIWifO+++4jPT2d8847j6VLl3LWWWchqebGxvfffz/uum688UYyMzO56qqrdil/4IEH6Nu3L1VVVfz2t79lypQp9dYzadIknnrqKbKysuqdp/b2bWmeLNqRgoICrh10LFk9erF122ZuKShg+PDhiQ7LtYL0Xv3I7NM6/9R1MTOmTp3K+eefX9Pj7KJFi1i3bl1cyaKqqoouXbrU+zoejz76KKNGjWr2j9kPf/hDhg0bxvLly0lKSmLVqlV8/vnnzaqrIdOmfd3p9cyZMznjjDO4/vrrAZqUKBpzxRVXcNVVV/HFF18wYcIE1q9fX+/4NbNmzWq0vt3dvo3xcxb1iEQirF69uuYRiUTaZL3dMrPI7NGHbpn170E411RvvfUWKSkpO/0QjhkzhgkTJmBmXH311YwaNYrRo0fzzDPPAMF4ExMmTGDKlCnsv//+u7yurq7m6quv5tBDD+XAAw/cqSuRW2+9ldGjRzNmzBiuvfZannvuOebNm8c555zD2LFjKS0trZn34Ycf5vLLL695/cADD3DFFVfsFP/KlSv56KOP+M1vflPzgzps2DBOPfXUneYrLi7mhBNOqOkO/cUXXwSgpKSEU089lTFjxjBq1Kia93jttdey//77c+CBB9bs/d94443ccccdzJo1i3vuuYd7772X4447DoDMzMyadd1+++017z12IKibb76ZkSNHctRRR7Fs2TIas99++9GlSxc2btzI9OnTGT16NKNGjdrpzvqhQ4eyceNGcnNz2W+//fjRj37EAQccwMSJEyktLa1z+9b13naHH1nUI96BiGJHt/OR7Vx7tWTJEg455JA6p73wwgssXLiQRYsWsXHjRg499NCa8SQWLFjAkiVLGDZsGG+//fZOr++//3569uzJ3LlzKS8v58gjj2TixIksXbqUF198kY8++oj09HQ2b95Mr169+OMf/1hns9OZZ57JzTffzO23305KSgqPPPLITokH4LPPPmPs2LGNnpdJS0tjxowZ9OjRg40bN3L44YczZcoU/v73vzNgwABeffVVIOgEcdOmTcyYMYOlS5ciia1bt+5U16RJk5g2bVqdzUizZ89m+fLlfPzxx5gZ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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ],
      "source": [
        "## Histogram of correctly classified points vs distance\n",
        "correct_classified_point_distance = abs(decision_function[correct_classified_indices])\n",
        "histogram = sns.histplot(abs(decision_function),label='All Points',color=\"r\")\n",
        "histogram.set_xlabel(\"Distance between Point and Decision Boundary\")\n",
        "histogram.set_ylabel(\"Number of Points\")\n",
        "histogram.set_title(\"Distance vs. Number of Points\")\n",
        "sns.histplot(correct_classified_point_distance,label='Correctly Classified Points')\n",
        "plt.legend()\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Showing Images Function"
      ],
      "metadata": {
        "id": "iOOFi5mCGLj_"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "afJJTDGwoTD2"
      },
      "outputs": [],
      "source": [
        "def show_image(img, norm = None):\n",
        "  if norm:\n",
        "    #To show Image:\n",
        "    target = img * norm\n",
        "    plt.imshow(target.reshape(32, 32, 3))\n",
        "    plt.show()\n",
        "  else:\n",
        "    plt.imshow(img.reshape(32, 32, 3))\n",
        "    plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Calculating Gradient Function"
      ],
      "metadata": {
        "id": "hfDaPwfcGNbw"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Calculate the gradient of hinge loss\n",
        "# Hinge Los: margin = y_true * pred_decision is always negative (since the signs disagree), implying 1 - margin is always greater than 1. \n",
        "def gradient(x, y_pred, y_true):\n",
        "\n",
        "  if y_true == 0:\n",
        "    y_true = -1\n",
        "\n",
        "  yxi = x * y_true\n",
        "  if y_pred*y_true >= 1:\n",
        "    return torch.zeros(len(x))\n",
        "\n",
        "  return torch.tensor(-1) * yxi"
      ],
      "metadata": {
        "id": "8Src7gg0GQLz"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Choosing a Target"
      ],
      "metadata": {
        "id": "YVW5-PMOF1RX"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "2AL4FJ4rCG0D",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 571
        },
        "outputId": "688c785a-e0d3-4f30-fe16-29dfb95e9a9e"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[  67  191  199  212  247  249  259  294  325  422  583  706  769  801\n",
            "  818  830  844  933  966 1065 1094 1147 1152 1186 1197 1216 1222 1411\n",
            " 1424 1516 1538 1574 1629 1746 1760 1789 1852 1983 1994 2032 2120 2151\n",
            " 2154 2178 2179 2201 2224 2234 2294 2355 2385 2395 2410 2420 2533 2542\n",
            " 2579 2636 2647 2806 2960 2994 2996 3021 3127 3144 3216 3261 3306 3355\n",
            " 3358 3396 3430 3441 3490 3492 3823 3879 3913 3955 3971 4171 4346 4374\n",
            " 4467 4474 4503 4504 4525 4538 4558 4564 4574 4626 4752 4771 4806 4823\n",
            " 4849 4870 4999 5014 5028 5047 5119 5169 5180 5184 5273 5294 5347 5381\n",
            " 5399 5409 5573 5605 5655 5685 5737 5929 6048 6101 6112 6260 6261 6277\n",
            " 6281 6336 6358 6415 6514 6544 6611 6646 6765 6782 6904 7013 7117 7126\n",
            " 7129 7156 7217 7228 7234 7368 7412 7472 7519 7625 7668 7684 7775 7807\n",
            " 7816 7884 7896 7943 7949 8056 8061 8123 8165 8174 8219 8231 8277 8376\n",
            " 8528 8639 8683 8688 8691 8724 8759 8789 8970 8972 8977 8979 9033 9060\n",
            " 9131 9154 9159 9214 9216 9362 9392 9434 9589 9749 9836 9891 9898 9900\n",
            " 9924 9932]\n",
            "Target chosen from class: Animal\n",
            "Target assigned to class: Machine\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ],
      "source": [
        "close_pos = []\n",
        "\n",
        "# Run model on Test set\n",
        "\n",
        "decision_function_test = model.decision_function(x_test)\n",
        "\n",
        "# Find all support vectors of the model\n",
        "close_positives = np.where((decision_function_test <= 0.1) & (decision_function_test > 0))[0]\n",
        "print(close_positives)\n",
        "\n",
        "# Making sure the target is chosen from animals\n",
        "for ind in close_positives:\n",
        "  if y_test[ind] == 1:\n",
        "    close_pos.append(ind)\n",
        "\n",
        "target_indice = random.choices(close_pos)\n",
        "\n",
        "target_label = 0\n",
        "target = x_test[target_indice[0]].reshape(1, -1)\n",
        "target_original_label = y_test[target_indice[0]]\n",
        "\n",
        "#To show Target Image:\n",
        "plt.imshow(target.reshape(32, 32, 3) * x_test_norm[target_indice[0]])\n",
        "print(\"Target chosen from class:\", binaryClasses[target_original_label])\n",
        "print(\"Target assigned to class:\", binaryClasses[target_label])\n",
        "target_label = -1\n",
        "\n",
        "# Deleting Target from orignal test set.\n",
        "x_test = np.delete(x_test, target_indice[0], 0)\n",
        "target_original_label = y_test[target_indice[0]]\n",
        "y_test = np.delete(y_test, target_indice[0], 0)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "QBXD2p85cGV2"
      },
      "outputs": [],
      "source": [
        "# Implement for tensor, change labels to -1\n",
        "\n",
        "target_pred = model.decision_function(target)\n",
        "#print(target_pred) # x.w\n",
        "\n",
        "target_grad = gradient(target, target_pred, target_label)\n",
        "target_gradnorm = np.linalg.norm(target_grad)\n",
        "#print(target_grad)\n",
        "#print(target_gradnorm)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "fkKmA20F2sBH"
      },
      "source": [
        "# Brewing Poisoned Images\n"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Constants/Initial Values"
      ],
      "metadata": {
        "id": "x5VktEC6FJNJ"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "n5L0HEMqL7YV"
      },
      "outputs": [],
      "source": [
        "theta = model.coef_\n",
        "budget = 100 # number of poisoned images\n",
        "camou_budget = 200 # Number of camouflaged images\n",
        "eps = 0.001 # perturbation bound\n",
        "M = 101 # optimization steps\n",
        "loss_opt = sys.maxsize # optimal loss\n",
        "delta_opt = 0 # optimal delta\n",
        "poison_opt = [] # optimal poison images"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Choosing Poison Images"
      ],
      "metadata": {
        "id": "bWWQ5iy6FMip"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "### Choosing Images Randomly from Each Class"
      ],
      "metadata": {
        "id": "yG91tJQfFYsL"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "RfPoQ6Bu2IxM"
      },
      "outputs": [],
      "source": [
        "## Choosing 50 images from each class uniformly\n",
        "random_animal_indices = random.choices(animal_indices,k=camou_budget) # Choosing animal indices\n",
        "random_machine_indices = random.choices(machine_indices,k=budget) # Choosing machine indices\n",
        "random_indices = random_machine_indices\n",
        "\n",
        "original_images = x_train[random_indices]"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Poisoning"
      ],
      "metadata": {
        "id": "Afy5c_RiGeOK"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "k8ui0mJMkN_O"
      },
      "outputs": [],
      "source": [
        "# Poisoning\n",
        "\n",
        "# Randomly initialize delta to add on images.\n",
        "from sklearn.metrics import hinge_loss\n",
        "import torch\n",
        "\n",
        "# Calculate mean and std:\n",
        "dm = torch.from_numpy(np.array(np.mean(x_train)))\n",
        "ds = torch.from_numpy(np.array(np.std(x_train)))\n",
        "# Initialize small perturbations\n",
        "\n",
        "poison_delta = (np.random.rand(budget, 3072) - 0.5) * 2     # / x_train_norm\n",
        "poison_delta = poison_delta * eps / ds / 255  \n",
        "\n",
        "x_poisoned = x_train[random_indices]\n",
        "y_poisoned = torch.from_numpy(y_train[random_indices])\n",
        "\n",
        "for i in range(budget):\n",
        "  x_poisoned[i] = np.add(poison_delta[i], x_poisoned[i])\n",
        "\n",
        "poison_tensor = torch.from_numpy(x_poisoned)\n",
        "delta_tensor = (poison_delta)\n",
        "delta_tensor = torch.max(torch.min(delta_tensor, eps / ds / 255), -eps / ds / 255)\n",
        "\n",
        "poisoned_decision = model.decision_function(x_poisoned)\n"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "### Compute Loss Function"
      ],
      "metadata": {
        "id": "BfE4wwkwG2N6"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Function to calculate Similarity loss between target and poisons\n",
        "\n",
        "def compute_loss(support_data): \n",
        "  target_losses = 0 \n",
        "\n",
        "  with torch.no_grad():\n",
        "    poisoned_decision = model.decision_function(support_data[\"x_poisoned\"])\n",
        "    poisoned_decision = torch.from_numpy(poisoned_decision)\n",
        "\n",
        "  poison_grad = torch.zeros_like(support_data['poison_tensor'])\n",
        "  cumulative_poison_grad = torch.zeros_like(poison_grad[1])\n",
        "\n",
        "  for i in range(budget):\n",
        "    image = support_data['poison_tensor'][i] + delta_tensor[i]\n",
        "    poison_grad[i] = gradient(image, poisoned_decision[i], y_poisoned[i]) \n",
        "    target_losses -= (poison_grad[i] * support_data[\"target_grad\"]).sum()\n",
        "    cumulative_poison_grad += poison_grad[i]\n",
        "  \n",
        "  poison_grad_norm = torch.linalg.norm(cumulative_poison_grad)\n",
        "    \n",
        "\n",
        "  target_losses = target_losses / (support_data[\"target_gnorm\"] * poison_grad_norm)\n",
        "  target_losses = 1 + target_losses\n",
        "\n",
        "\n",
        "  return target_losses"
      ],
      "metadata": {
        "id": "EuZrCj-hG3rl"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "fQVq-4XyWti7",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 587
        },
        "outputId": "455f69f2-4278-45cd-e9c1-5902861b46cb"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "target gradient norm is: 0.9999999999999959\n",
            "Iteration 0: poison loss is 0.176552217352562\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Iteration 100: poison loss is 0.16202413685652928\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Elapsed[s] :  33.999207735061646\n"
          ]
        }
      ],
      "source": [
        "#### fixed version to brew poisons\n",
        "\n",
        "start_time = time.time()\n",
        "\n",
        "# Supporting data\n",
        "target_grad = gradient(target, target_pred, target_label)\n",
        "target_gnorm = torch.linalg.norm(target_grad)\n",
        "limit = (eps / (ds * 255.0)).view(1,1)\n",
        "\n",
        "print(\"target gradient norm is: {}\".format(target_gnorm))\n",
        "support_data = {\n",
        "    \"target_grad\": target_grad, \n",
        "    \"target_gnorm\": target_gnorm, \n",
        "    \"poison_tensor\": poison_tensor, \n",
        "    \"x_poisoned\": x_poisoned,\n",
        "    \"model\": model,\n",
        "    \"eps\": eps,\n",
        "    \"limit\": limit\n",
        "\n",
        "}\n",
        "\n",
        "poison_bounds = torch.zeros_like(delta_tensor)\n",
        "\n",
        "#delta_tensor  = torch.from_numpy(x_poisoned)\n",
        "\n",
        "att_optimizer = torch.optim.Adam([delta_tensor], lr=0.001, weight_decay=0)\n",
        "delta_tensor.grad = torch.zeros_like(delta_tensor)\n",
        "\n",
        "delta_tensor.requires_grad_()\n",
        "\n",
        "for j in range(101):\n",
        "  loss = compute_loss(support_data)\n",
        "  #print(\"loss is {}\".format(loss))\n",
        "  loss.backward(retain_graph = True)\n",
        "  att_optimizer.step()\n",
        "  att_optimizer.zero_grad()\n",
        "  \n",
        "  for i in range(budget):\n",
        "    poison_bounds[i] = poison_tensor[i]\n",
        "  \n",
        "  with torch.no_grad():\n",
        "   #Projection Step \n",
        "\n",
        "    delta_tensor.data = torch.max(torch.min(delta_tensor, limit), -1 * limit)\n",
        "    delta_tensor.data = torch.max(torch.min(delta_tensor, (1 - dm) / ds -\n",
        "                                                            poison_bounds), -dm / ds - poison_bounds)\n",
        "    \n",
        "    if j % 100 == 0:\n",
        "      print(\"Iteration {}: poison loss is {}\".format(j, loss))\n",
        "      show_image(poison_tensor[0]+delta_tensor[0], x_train_norm[random_indices[0]])\n",
        "\n",
        "print(\"Elapsed[s] : \", time.time() - start_time)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "5PIEKoilYr8s",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 551
        },
        "outputId": "ba415ef6-8e61-453b-badf-0241172ec7ca"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Example poison image: \n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Target image: \n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPsAAAD5CAYAAADhukOtAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAfrklEQVR4nO2deXBc13Xmv9MbGgtBAFxBgJtIaqE4FiVTsjySZUkpuRQliqSpjMuujKOaOGZqypoZVzJ/qJyq2LOWMzW2y3+kPEWPVZE8jmU5tsaqWEm0xorsWBG1cREp7iJBEtywA41ez/yB5hSlud8FRBANRu/7VbHYuAfnvdu33+nXuF+fc8zdIYT48JOa7wkIIRqDgl2IhKBgFyIhKNiFSAgKdiESgoJdiISQmY2zmd0N4FsA0gD+l7t/Lfb7TU05b21pDtq6u5dGThSWB8ulInVpaW2ntlQqTW0xKdK9Rm0cuwhLnNgca7Vq2AcxH/68CoUCtVXK4XMBQKVSCY6n0/z+ks1lqa2pqYna0il+TPq8I4pzLfI6X+xrFvNkr+fFXG/9/ecwNDwaPNlFB7uZpQH8GYC7APQBeNXMnnL3t5lPa0szPnXHzUHbH//Jv6XnSqXCF1Xf8QPU58Ytd1NbPt9KbZVqmdpK5YnguIG/eSBiS1nkjSBiK5X5HCfGR4Lj1dok9SkUxqlt16491Hb29AC1nTp9Nji+sKON+qxY0UNtG9atpba2thZqqyH8plMphccBoFTmNxGLvUtEsMgNpkreGEuRm1mKXB6/t/U/cR9qmZ6bABxw90PuXgLwOID7ZnE8IcQcMptg7wFw7IKf++pjQojLkFn9zT4TzGwrgK0A0NKcn+vTCSEIs7mzHwew8oKfe+tj78Hdt7n7Fnff0tSUm8XphBCzYTbB/iqADWa21sxyAD4D4KlLMy0hxKXmoj/Gu3vFzB4C8LeY2nJ+xN13x3zS6RQWdoZ3Y88MnKZ+uUx497l35bXUJ9vE/2QoFvkupyMid3h4RzWd4Z9YclkuJ509d4raDh48RG179uyjthMn+oPjmTR/XhPjYZUBAA7sP8L9JrgqUC6Hz5dr4uvR2sp31ZctW0Rt66/spbYbbtgUHO/s6KQ+iFwDlQp/zjEJMyaXMpkyJtcVyTxict2s/mZ396cBPD2bYwghGoO+QSdEQlCwC5EQFOxCJAQFuxAJQcEuREKY82/QXUgqZcjnwqc89u7/932c/8emj6wLji/qWkZ9xie4nJTP8QyqXIZLdul0WAoZHQ0nnwDASy+9QG1/9+IvqO1UfziRBACGR3niSqFYCo6TxEEAQLnE5aRURP4plMPnAoCMhe8juTxf+5GxMWobGORrfDhy7ezfdyw4fv3166nP+vWrqS2X5SFTq/LkmnLEViGJTdksl3QnJsLXQEz+051diISgYBciISjYhUgICnYhEoKCXYiE0NDd+Gwuh55V4Z3Og4f7qN/Hbr4xOD5e4Du0rS0d1JbO8BJBrIYbAPQdC+/sPvnT/0N9XnjhV9QWKzFWipRNiiVIVCvhgxZLfOe8GpkIK38EAKkMN6ZIrblYokZxks8xleIJNMUCX6uDB08Ex48e4dfbpk28BNaWGzdSW6zk1vjYKLVVq2GpJJ/nytDwcLgkWLXKr1/d2YVICAp2IRKCgl2IhKBgFyIhKNiFSAgKdiESQkOlt1w2h57elUFb33EuGTjtqsKln5hs0XeMJ0688PyL1Pb3L/8yOH706Bnq09zC51Ge5Mk6pQpfDxiXDkvFcOeXYpEnuyDNj9fWzBNX2tvCrbwA3tFmbJQ/56ZY3cBIF5xYL6ciSdZpzvN6dzt2cFlubIy3w7ru+jXUBou0lGJS8HAke4mYlAgjhFCwC5EUFOxCJAQFuxAJQcEuREJQsAuREGYlvZnZEQCjAKoAKu6+Jfb76VQK7aSTa0dbK/UrEjmpOVLPbN9e3iLpiR8+SW27d79NbRUia9Scy2QZnqyFsVGe5VVz/j5cc57lxWrQlSLSWzrLpbd0K5fDLCJ51SphW3Okk2+RzB0A8pGmoKUiX4+xQljqm4xkFbZGnvP+A7xNGSIttrq7uUyZSYXX/2R/OMsSANoXhDPsSqVwrACXRme/w915dUQhxGWBPsYLkRBmG+wO4Bkze83Mtl6KCQkh5obZfoy/1d2Pm9lSAM+a2V53f+nCX6i/CWwFgCWLu2Z5OiHExTKrO7u7H6//fxrAkwBuCvzONnff4u5bFrYvmM3phBCz4KKD3cxazWzB+ccAPgVg16WamBDi0jKbj/HLADxZz27KAPgLd/+bmEM2l0PvqnAxPyaRAIBXwhlUfcfPUZ8nf/I0te3csZfa8hE5r3fZouD46DhvWzQ+xqWQ9sgnnZOnwwUFAaBCikoCADy8VqUyl5oWNnN9MFZwcjLSNqpCsvYykcKRhUmeUVaq8HOxIpsAkM2EL/FsRMorTPDXzJu43HjyBG/LNVmIFJysDAbHM1memZdvCa+jk9cfmEWwu/shANddrL8QorFIehMiISjYhUgICnYhEoKCXYiEoGAXIiE0tOCk12ooj4b7s224chP1GxoJ+/zyH16lPsMjXOooV7kM1ZHl0lD3onBmXr6JL+OZU4epLRXpOeceKzbIbZOkp1s10sNuSedCaiuUitSWqvHnnUqF7yODo0PUp1LlElpk+miKvGas8GUhIvXmspFMv2YubZ09O0xt6QzvPbj5ho+GDSRzEACOHg3nnsXqlOrOLkRCULALkRAU7EIkBAW7EAlBwS5EQmjobnxhsoDd+8JJKONjPPFj7+Fw3a9MLtJaiexKA0Amy592jm+Qo0JaFy1I8/fMzk6ezHBugCdOZCPF6yYneeJNhdRWW7myh/r0rl5FbS2tvDZgKtLSaISoIXv3HaQ+xVG+Hk1ZnqAUez0nJ8NJLRnjr1mhwOcR6ZSFNEm6AYCzZ/hO/Tt7+oPjzz37MvU5cYqrGgzd2YVICAp2IRKCgl2IhKBgFyIhKNiFSAgKdiESQkOlt+JkAQff2Rm07TvAW90MjIfrj63o7aU+kwWewFGc5LLcYDXiVw4nJsQWMSYZFSa53FiMtGvKRI551ZVXB8fvvPM26pNv5vXYxiL19U4cPURty5YtDY63tfGkm7179lPbKEmgAoBKhSc2saShUoVfA83NXC4tR/xKEbk3dl8tFsJzvOqa9dRncGxHcHyywK8b3dmFSAgKdiESgoJdiISgYBciISjYhUgICnYhEsK00puZPQLgNwGcdvdN9bEuAD8EsAbAEQCfdvdwD5sLaGtrx8233hm0Hdj/KHeshet+DZ7jmT/VGpdjRsZ4/bGhIretXxOWvEZKPPurUuTSVS1Sc60cqf3W3hFuQwUAt9/xyeB4ocDnMTDI22i1tbVTW8355TM4HJbKcpFsvo6FbdQ2PMIvr+ZIy65sa/iYQ8M8C20y0oYqnebPOR3JfiwV+TEHB8MS7OJ2LlP2LF0cHD92/Az1mcmd/c8B3P2+sYcBPO/uGwA8X/9ZCHEZM22w1/utv/+t5z4A52/FjwK4/xLPSwhxibnYv9mXufvJ+uN+THV0FUJcxsx6g86nCpzTAtdmttXMtpvZ9lgtdyHE3HKxwX7KzLoBoP5/uG4UAHff5u5b3H3Lwkg/ciHE3HKxwf4UgAfrjx8E8NNLMx0hxFwxE+ntBwBuB7DYzPoAfAXA1wA8YWafB/AugE/P5GRN+WZsuPq6oK23dzn1O7s3nBE3EZEzKmUuvZGOQACAgWEuUR092hccr2Z51tiSJWGJBAAq41zmKxR5BtWmVTzb75prrgyO//zvXqQ+/f30gxmuuGIDtTXleTHKo8fCa9XV1Ul9SlXeu6hrMV/H4WEuwdacFJyMtOwqjHLZM+38/pjmSiomS/xaHZ0IF7jsWd5NfdasDF8Dp87wtZg22N39s8T0a9P5CiEuH/QNOiESgoJdiISgYBciISjYhUgICnYhEkJDC06mUik0NYXlmg0bN1O/X711IDg+NhSRSDL8faz/FM/yqpa4/DNRCX9RsBzJKFvQwuWpTJZngOVy3Lbp2o3U1ncsLFOmUrH3dfoFSAxFMuLGJ/jzLhTCUtPkJC/mODjEM9EykT5qsUw0lj1YK3OdrFbjtmIkKzLfxHsPxqTgXFO4gdzEJL++lywOZ8TFXmfd2YVICAp2IRKCgl2IhKBgFyIhKNiFSAgKdiESQmOlt3QWCzqXBG3ZSNHACdJvrFDkMhkimW0eya5qi/Q9GxgIS0NLI5ltpRLvvTUe6UfXvaKH2q67Lpw5CABHDh8Mjp89yyW0GAcO7qM20kYNADAyEn7NikUuQdVq/IBHj56gtoULeZ2E5qbw6zk5wXvH5XNcQksZfz3T6bCEBgDNzc38mGS8EMmKHCOybTVSxFR3diESgoJdiISgYBciISjYhUgICnYhEkJDd+OL4yM48MoLQdsJsosMAFmyyZnL8Z3zUonv+ra38F3T9la+a9rWHk7iaG7iSSvjE7z2GIy/197z6/dQ26nT/dR2+Mi7wfHYznmNtNcCgM7OLmobHOSJK9lsWF0pFvludi0yyWKkHdbgIN+Bri4MJyJFdBxMjPPXLB95rWO78aUSryk4PhauQdfZ1UF9jp4IqxOlMl9f3dmFSAgKdiESgoJdiISgYBciISjYhUgICnYhEsJM2j89AuA3AZx29031sa8C+AKAM/Vf+7K7Pz3dsbL5FnRfHa4117F3B/Vb3r00OL7vcLjFEAC0tIZrdAFA92LeYTqf5e9/50iNtPECl/nGCuH2QwCwtJu39+kmzxkA3nj9VWpjcuTJk1wms4gE2NbGk0IyGS419fSsCI7v3LGL+sSIJZKwencAMDoatnlMi4wwOMQTaGJzbG7m69jSFpYHPdKnrBbrYUaYyZ39zwHcHRj/prtvrv+bNtCFEPPLtMHu7i8BGGjAXIQQc8hs/mZ/yMx2mNkjZsZbcwohLgsuNti/DWAdgM0ATgL4OvtFM9tqZtvNbPvAwOBFnk4IMVsuKtjd/ZS7V929BuA7AG6K/O42d9/i7ltivbmFEHPLRQW7mV24jfwAgIvbYhVCNIyZSG8/AHA7gMVm1gfgKwBuN7PNmOobdATAH8zsdA6Wb7R85Vrq1dv7TnB8zzuHqE8hxet3nRnkUtnyZVzyOnN2NGywSGufHJenVq3iz3ng3Flqy2R4tt/ERPh5NzXxGn+xdkdnzvB5lCMZVn19x4PjK1ZwufFYH68z19LC20ZlI220ChNE+oxIV5Uqf17ZSFuumvN1LExyCdbS4blUa/y6qpJ6fTFBcdpgd/fPBoa/O52fEOLyQt+gEyIhKNiFSAgKdiESgoJdiISgYBciITS04GS5VMLxY+GCiKtWX0n9hgYfD47ns3z6E5NceivVeLnBt0/vpbZcPiy75CLST1c7z7C7/977qa1UDrdPAoC+Yzzbj2VejYzwbC2LyFDnzg1F/KgJ+Xw4y2uyyAsvNkUKiA4M8XnEsu/ypJ3XeKSoZEwm80h7pXwksy2T4ddqW0tbcLxc5ms1MRa+vmMyqu7sQiQEBbsQCUHBLkRCULALkRAU7EIkBAW7EAmhodIbAKrXHD60n7rse+dw+FAprv14pLfWZIXLE8PjXLJb3RnOiGtq5sUtWxcsoLaJcV4EcnSMS2/nBngmWlfXouB4rChjLFeqFOnNtqKHZ7BlSIO+QwfCryUAVCKyVkxei0mHY6SPWjbLZb6lSxZTWzFyXRUiff3Kkd6Dg6SoSyYiLdeq5HiRQpq6swuREBTsQiQEBbsQCUHBLkRCULALkRAauxufSiGdD9dCe+O1X1G3dHM4UWC4/xT1uenGj1Db3r0HqW3k1Glqq5TCu+7H+8PJPQDw8dtWUts7+3ZT29BweBcZAIrFIrXtfydcr290lB+vBr4L7qRmIACcOcPXv6kpXDOupSXc6ggA+o6H69YBQEsr96tFEpsymXCSUpXtZgMYHuaJMADf+Y/VwqtGlIYcUQYmi3x3P6ZEMXRnFyIhKNiFSAgKdiESgoJdiISgYBciISjYhUgIM2n/tBLAYwCWYSpjYpu7f8vMugD8EMAaTLWA+rS7R9u0eq2GCqkNt2rNOup33UhYCll0gstki5fzJI2PL15FbZ1LeUJOoRBOTrluzXLqs27tGmo7cewItSHFX5qzZweorVwOS0oDg9wnG6n9lsvytlHpNJ/jubPnguPNkTZOnZHGn4ODvAZdDDbHlhb+nGMy2XgkUSqWbJRO8/tqkbSNqla5pNieCz+vsUhS0Ezu7BUAf+TuGwHcDOCLZrYRwMMAnnf3DQCer/8shLhMmTbY3f2ku79efzwKYA+AHgD3AXi0/muPAuClUoUQ884H+pvdzNYAuB7AKwCWufvJuqkfUx/zhRCXKTMOdjNrA/BjAF9y9/cUIXd3B6mAYGZbzWy7mW0fGubFGoQQc8uMgt3MspgK9O+7+0/qw6fMrLtu7wYQ3C1z923uvsXdt3Qs5BVdhBBzy7TBblM1f74LYI+7f+MC01MAHqw/fhDATy/99IQQl4qZZL3dAuBzAHaa2Zv1sS8D+BqAJ8zs8wDeBfDpaY/kTmvDLWrjWU0jg+Gaay2k1REAtHfxLYQVy1dQW3cvz1LrWBQ+5sZrr6U+z/zsSWobHhmltgVt7dQWk6EWtoczBKs1XktuYoRn0a1bs5ba2iOf1LwWroV29hyvn5dr4jJfKnVxNehYfb1CIdLiKVbHLcXvj6lIJpoZ96sQia1U4q/LirXh6/TsCJf/pg12d38ZPK/v16bzF0JcHugbdEIkBAW7EAlBwS5EQlCwC5EQFOxCJISGFpzMNjVh+dqrgrZcJBuqY+EvguOvvvE29Wlv522XBiKFEgeH+Lf87rqrNzjuFV68cP2Ga6itv/8MtQ0N8DmuXhWRDpd0BcezGf6+fuYcl/KWLOOtkJi8BgBdXeF5DA3zcw2QNkgAUKvxTLRYocc8KXBqxi/9UqRVU7XK2z/F4fOvVMPrmDIuN350c1juPfDuyeA4oDu7EIlBwS5EQlCwC5EQFOxCJAQFuxAJQcEuREJoqPRWKU7i3JE9QduiVRuo3733/1ZwfP9+3rPt5Z+/TG3Le5ZQG8DljkMHw8UoT50+QX0WL+aFL3/nX/0etf3y5eepbXiQn69n+aLgeCUi/XQu5vJac3Oe2gYGw0UlASCTC69jb08P9WmJyK+xYo7lMs/oK9PikVw29IjMVyPFIYF49l2pyItHsl51S0kGIwC0ksKi6VjGHrUIIT5UKNiFSAgKdiESgoJdiISgYBciITR0N75WrWJ8KJwIMXr6H6hfL2kN9Z//63+jPo/970ep7Wc/+zm1ZXgZNKw60Rccr9V44sTK1bxd0KIuvgt+yy2fpLYjRNEAgCOHd4XP1RnepQcAWLitFRCvuVat8B3m8Ynw8843Rdo/dfCadrHEpnPnIl3HJsO7+OXI3IukTiIAlCp85z9zkfXpyiTxZv3acOIVAFy5+brgeNMLv+JzoBYhxIcKBbsQCUHBLkRCULALkRAU7EIkBAW7EAlhWunNzFYCeAxTLZkdwDZ3/5aZfRXAFwCcL6T2ZXd/OnasXHMreq+9MWgrjvKkinPHj7DJUZ8//OK/o7bbPnEHtT32ve9R2769e4Pj+UiyyIIFsTZOwV6YAIDREa4BbtwYXkMAqJKkioP7eb2+UpG3Qtq5i/u1NnMZLZcP14WbnORS5OgolwBrkXp3UWKdoZhL5LqKy2s8iapU5M/7ynWrg+P/8jP/gvqs3/iR4Hg+kkw0E529AuCP3P11M1sA4DUze7Zu+6a7/48ZHEMIMc/MpNfbSQAn649HzWwPAJ6nKIS4LPlAf7Ob2RoA1wN4pT70kJntMLNHzKzzEs9NCHEJmXGwm1kbgB8D+JK7jwD4NoB1ADZj6s7/deK31cy2m9n2WF1wIcTcMqNgN7MspgL9++7+EwBw91PuXnX3GoDvALgp5Ovu29x9i7tv6erSzV+I+WLaYLeprcnvAtjj7t+4YPzCeksPAAhnYAghLgtmsht/C4DPAdhpZm/Wx74M4LNmthlTctwRAH8w3YEqlTIGzoXlpkVLl1G/7oXhbKghkoUGAH1vv0VtKzt5BtXv3Hs3tf3Vi+Fsudd38ve50XEuJ7nzzKsVK1ZRW0srl1cWLAhnt3V2Lac+mRyXBzs7eWbeO/t2U1upEM4cGxsfpz7pDL8cxwZH+LkiNeiYYjcZqWkXJSLLVav89VxIrmEAeOCB3wiOdy5aSn2OHw7XXywVi9RnJrvxLyOsVkY1dSHE5YW+QSdEQlCwC5EQFOxCJAQFuxAJQcEuREJoeMHJwuhw0NZf4ZlXy5avCI6vvCqc+QMAIyu4VHNy305q+2cf/Si1XfOxfx4c/9Hjf0F9nnuBF7fcvYvPYzwiUY2Oh9cQABZ1hL+4dMUVV1GffL6Z2hYv5vLPO3tfp7Zn/vavg+MxmWxgcJTampp4ZmFzSyu1jY2Fr4Ncll/6hQK/FiuR9kq5yK3z3rvvpLbVq1cGx2OFL1vbwnJpKs0z73RnFyIhKNiFSAgKdiESgoJdiISgYBciISjYhUgIDZXemvLNWHPlpqBtfILLLsND4aIXhYg81bmIZ9GtvJpLdhMTkSy10bCMc/stH6M+XYuWUNtjj/+I2ra/+gq19a7gPcCWLAtXDKtE6jUuaOVZgMVIMcpclhfFvPW2TwTHd7zF5cY33+DZg6Uyl6HKFZ6JNlkMS321iIQWMcFLPLNt4+aN1HbDls3U1rNibXC8cyHPRhwfDfdMTEt6E0Io2IVICAp2IRKCgl2IhKBgFyIhKNiFSAgNld6q1SpGiGTQ3Mwzl1pI/6qBwQHqc+DAAWpzVKgtRltbuGjgilXrqM/ipeGMPQBI1XgG2HMv/oLaDhw+RG1Hjx4Ljg+cPkV9Vl/B5z+6iheqRI1LXgs62oLj7Qu5zNfZwa+BYyf4/AEuN9VqteD44CDPHCyX+OvyiZtuoLbf/8LvU9u6DVdS20KStXfmTD/1yeTCmYpmkV501CKE+FChYBciISjYhUgICnYhEoKCXYiEMO1uvJnlAbwEoKn++3/p7l8xs7UAHgewCMBrAD7n7jxbAYB7DeXJcGLFKGkLBQAdXeEWRIs6u6hPO6nRBQDDw2epLVbPrERaBg0PRVoapfn76b33/ja1/dZv/y61PfPMz6jte488EhzftWcv9RkcnaC2EyePU1s60gqprT28696Sz1GfoWE+j/EC3yEvlbjf5GT4klyymCcoffLWcK1BAPiNe+6itu7lXLkojfM5DpfCLZsWLeMJT8t6rgiO55vDKggwszt7EcCd7n4dptoz321mNwP4UwDfdPf1AAYBfH4GxxJCzBPTBrtPcT7vM1v/5wDuBPCX9fFHAdw/JzMUQlwSZtqfPV3v4HoawLMADgIYcvfz307pAxBOpBZCXBbMKNjdverumwH0ArgJwNUzPYGZbTWz7Wa2fXCIf2tJCDG3fKDdeHcfAvAigI8D6DCz8xt8vQCCOznuvs3dt7j7ls4O3qNaCDG3TBvsZrbEzDrqj5sB3AVgD6aC/vx28oMAfjpXkxRCzJ6ZJMJ0A3jUzNKYenN4wt3/yszeBvC4mf0XAG8A+O50B8o1NWMtqUE3cKqP+p05dSI4Pkhq0wFAd88qalvQ1kFtQyPhRB0AyCFcnGxF72rq07mkm9pSGf5e27+f12O7vpfLRr1/+FBw/FA/T6p47rm/p7bdO3ZTWybL559vDidqtLZyaejdY+HXGQCKZV77ra2Z18L71B1hGe13H/zX1GfLDbymYGs7/3RajrRrGh7mSVvtJMEqF5GB+3ZvD89hksvA0wa7u+8AcH1g/BCm/n4XQvwTQN+gEyIhKNiFSAgKdiESgoJdiISgYBciIZjHet1c6pOZnQHwbv3HxQB4+lnj0Dzei+bxXv6pzWO1uwe12YYG+3tObLbd3bfMy8k1D80jgfPQx3ghEoKCXYiEMJ/Bvm0ez30hmsd70Tzey4dmHvP2N7sQorHoY7wQCWFegt3M7jazd8zsgJk9PB9zqM/jiJntNLM3zSycRjQ3533EzE6b2a4LxrrM7Fkz21//v3Oe5vFVMzteX5M3zeyeBsxjpZm9aGZvm9luM/v39fGGrklkHg1dEzPLm9k/mtlb9Xn8x/r4WjN7pR43PzQzXr0zhLs39B+mGnMdBHAFgByAtwBsbPQ86nM5AmDxPJz3NgA3ANh1wdh/B/Bw/fHDAP50nubxVQD/ocHr0Q3ghvrjBQD2AdjY6DWJzKOhawLAALTVH2cBvALgZgBPAPhMffx/Avg3H+S483FnvwnAAXc/5FOlpx8HcN88zGPecPeXALw/wfk+TBXuBBpUwJPMo+G4+0l3f73+eBRTxVF60OA1icyjofgUl7zI63wEew+AC1uNzmexSgfwjJm9ZmZb52kO51nm7ifrj/sBLJvHuTxkZjvqH/Pn/M+JCzGzNZiqn/AK5nFN3jcPoMFrMhdFXpO+QXeru98A4NcBfNHMbpvvCQFT7+wAKYsz93wbwDpM9Qg4CeDrjTqxmbUB+DGAL7n7yIW2Rq5JYB4NXxOfRZFXxnwE+3EAKy/4mRarnGvc/Xj9/9MAnsT8Vt45ZWbdAFD/n7fImUPc/VT9QqsB+A4atCZmlsVUgH3f3X9SH274moTmMV9rUj/3By7yypiPYH8VwIb6zmIOwGcAPNXoSZhZq5ktOP8YwKcA8MJvc89TmCrcCcxjAc/zwVXnATRgTczMMFXDcI+7f+MCU0PXhM2j0WsyZ0VeG7XD+L7dxnswtdN5EMAfz9McrsCUEvAWgN2NnAeAH2Dq42AZU397fR5TPfOeB7AfwHMAuuZpHt8DsBPADkwFW3cD5nErpj6i7wDwZv3fPY1ek8g8GromAD6CqSKuOzD1xvInF1yz/wjgAIAfAWj6IMfVN+iESAhJ36ATIjEo2IVICAp2IRKCgl2IhKBgFyIhKNiFSAgKdiESgoJdiITwfwEw3MOV4d4GcwAAAABJRU5ErkJggg==\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ],
      "source": [
        "x_poisoned = delta_tensor.cpu().detach().numpy()\n",
        "x_original = poison_tensor.numpy()\n",
        "for index in range(budget):\n",
        "  x_train[random_indices[index]] = x_original[index] + x_poisoned[index]\n",
        "  \n",
        "print(\"Example poison image: \")\n",
        "show_image(x_train[random_indices[0]], x_train_norm[random_indices[0]])\n",
        "\n",
        "model2 = LinearSVC(loss='hinge', max_iter=3000)\n",
        "model2.fit(x_train, y_train)\n",
        "\n",
        "\n",
        "\n",
        "print(\"Target image: \")\n",
        "show_image(target, x_test_norm[target_indice[0]])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "cwZAX566CxQh",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "2e544134-e2d1-40a7-d4a2-10907b745506"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Test acc with model 2: 0.8164816481648165\n",
            "Train acc with model 2: 0.82026\n",
            "Test acc with model 1: 0.8162816281628162\n",
            "Train acc with model 1: 0.82016\n",
            "Without poison target is classified as:  Animal\n",
            "With poison target is classified as:  Machine\n",
            "[0.0486186]\n",
            "[-0.04327719]\n"
          ]
        }
      ],
      "source": [
        "print(\"Test acc with model 2: {}\".format(model2.score(x_test, y_test)))\n",
        "print(\"Train acc with model 2: {}\".format(model2.score(x_train, y_train)))\n",
        "print(\"Test acc with model 1: {}\".format(model.score(x_test, y_test)))\n",
        "print(\"Train acc with model 1: {}\".format(model.score(x_train, y_train)))\n",
        "print(\"Without poison target is classified as: \", binaryClasses[model.predict(target)[0]])\n",
        "print(\"With poison target is classified as: \", binaryClasses[model2.predict(target)[0]])\n",
        "\n",
        "print(model.decision_function(target))\n",
        "print(model2.decision_function(target))"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Brewing Camo "
      ],
      "metadata": {
        "id": "wTeB36Yz56eh"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "if CAMO == 'BREW':\n",
        "# Initialize small perturbations\n",
        "  x_camo = x_train[random_animal_indices]\n",
        "  y_camo = torch.from_numpy(y_train[random_animal_indices])\n",
        "\n",
        "  dm = torch.from_numpy(np.array(np.mean(x_train)))\n",
        "  ds = torch.from_numpy(np.array(np.std(x_train)))\n",
        "\n",
        "  camo_delta = (np.random.rand(camou_budget, 3072) - 0.5) * 2  \n",
        "  camo_delta = camo_delta * eps / ds / 255  \n",
        "\n",
        "  for i in range(camou_budget):\n",
        "    x_camo[i] = np.add(camo_delta[i], x_camo[i])\n",
        "\n",
        "  camo_tensor = torch.from_numpy(x_camo)\n",
        "  delta_tensor = (camo_delta)\n",
        "  delta_tensor = torch.max(torch.min(delta_tensor, eps / ds / 255), -eps / ds / 255)\n"
      ],
      "metadata": {
        "id": "PDz5OGZ154l2"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Function to calculate similarity loss for camou\n",
        "# todo - merge with function to calculate poison_loss\n",
        "\n",
        "def compute_loss(support_data): # parameters here\n",
        "  target_losses = 0 \n",
        "\n",
        "  with torch.no_grad():\n",
        "    poisoned_decision = model.decision_function(support_data[\"x_camo\"])\n",
        "    poisoned_decision = torch.from_numpy(poisoned_decision)\n",
        "\n",
        "  camo_grad = torch.zeros_like(camo_tensor)\n",
        "  cumulative_camo_grad = torch.zeros_like(camo_grad[1])\n",
        "\n",
        "  for i in range(budget):\n",
        "    image = camo_tensor[i] + delta_tensor[i]\n",
        "    camo_grad[i] = gradient(image, poisoned_decision[i], y_camo[i]) \n",
        "    target_losses -= (camo_grad[i] * support_data[\"target_grad\"]).sum()\n",
        "    cumulative_camo_grad += camo_grad[i]\n",
        "  \n",
        "  camo_grad_norm = torch.linalg.norm(cumulative_camo_grad)\n",
        "    \n",
        "\n",
        "  target_losses = target_losses / (support_data[\"target_gnorm\"] * camo_grad_norm)\n",
        "  target_losses = 1 + target_losses\n",
        "\n",
        "\n",
        "  return target_losses"
      ],
      "metadata": {
        "id": "Iq3eiIDf8jkH"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "if CAMO == 'BREW':\n",
        "# Supporting data\n",
        "  target_grad = gradient(target, target_pred, target_original_label)\n",
        "  target_gnorm = torch.linalg.norm(target_grad)\n",
        "  limit = (eps / (ds * 255.0)).view(1,1)\n",
        "\n",
        "  print(\"target gradient norm is: {}\".format(target_gnorm))\n",
        "  support_data = {\n",
        "    \"target_grad\": target_grad, \n",
        "    \"target_gnorm\": target_gnorm, \n",
        "    \"camo_tensor\": camo_tensor, \n",
        "    \"x_camo\": x_camo,\n",
        "    \"model\": model,\n",
        "    \"eps\": eps,\n",
        "    \"limit\": limit\n",
        "\n",
        "  }\n",
        "\n",
        "  camo_bounds = torch.zeros_like(delta_tensor)\n",
        "\n",
        "#delta_tensor  = torch.from_numpy(x_poisoned)\n",
        "\n",
        "  att_optimizer = torch.optim.Adam([delta_tensor], lr=0.001, weight_decay=0)\n",
        "  delta_tensor.grad = torch.zeros_like(delta_tensor)\n",
        "\n",
        "  delta_tensor.requires_grad_()\n",
        "\n",
        "  for j in range(M):\n",
        "    loss = compute_loss(support_data)\n",
        "    #print(\"loss is {}\".format(loss))\n",
        "    loss.backward(retain_graph = True)\n",
        "    att_optimizer.step()\n",
        "    att_optimizer.zero_grad()\n",
        "  \n",
        "    for i in range(budget):\n",
        "     camo_bounds[i] = camo_tensor[i]\n",
        "  \n",
        "    with torch.no_grad():\n",
        "    #Projection Step \n",
        "\n",
        "      delta_tensor.data = torch.max(torch.min(delta_tensor, limit), -1 * limit)\n",
        "      delta_tensor.data = torch.max(torch.min(delta_tensor, (1 - dm) / ds -\n",
        "                                                            camo_bounds), -dm / ds - camo_bounds)\n",
        "    \n",
        "      if j % 100 == 0:\n",
        "        print(\"Iteration {}: poison loss is {}\".format(j, loss))\n",
        "        show_image(camo_tensor[0]+delta_tensor[0], x_train_norm[random_animal_indices[0]])\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 569
        },
        "id": "jyOSFnxq8jmN",
        "outputId": "3693b693-913d-4617-f966-c03f8549bf9a"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "target gradient norm is: 0.9999999999999959\n",
            "Iteration 0: poison loss is 0.17032057571425885\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Iteration 100: poison loss is 0.15621832426113236\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "tSkaPanLb8uq"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "if CAMO != 'BREW':\n",
        "  # Label Flipping\n",
        "  x_train = np.concatenate((x_train, x_poisoned))\n",
        "  y_train = np.concatenate((y_train, np.ones(budget)))\n",
        "else:\n",
        "  x_camo = delta_tensor.cpu().detach().numpy()\n",
        "  x_original2 = camo_tensor.numpy()\n",
        "  for index in range(camou_budget):\n",
        "    x_train[random_animal_indices[index]] = x_original2[index] + x_camo[index]\n",
        "  \n",
        "  print(\"Example camo image: \")\n",
        "  show_image(x_train[random_animal_indices[0]], x_train_norm[random_animal_indices[0]])\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 284
        },
        "id": "ZVSle7uC5bp7",
        "outputId": "f07897ca-1aaa-423c-af21-0d989f092439"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Example camo image: \n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "KmFEGidl__9Y",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "f7342b96-f3a9-485f-d30e-9641a878e9d4"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "LinearSVC(loss='hinge', max_iter=3000)"
            ]
          },
          "metadata": {},
          "execution_count": 22
        }
      ],
      "source": [
        "# Retrain again with camous \n",
        "\n",
        "model3 = LinearSVC(loss='hinge', max_iter=3000)\n",
        "model3.fit(x_train, y_train)\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "NObSQ_CvC6vS",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "9669c863-6a2f-49b9-8154-ff58000d7186"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "After duplicating poison images target is classified as:  Animal\n",
            "Test acc with model 3: 0.8164816481648165\n",
            "Train acc with model 3: 0.82022\n",
            "[0.01965919]\n"
          ]
        }
      ],
      "source": [
        "print(\"After duplicating poison images target is classified as: \", binaryClasses[model3.predict(target)[0]])\n",
        "print(\"Test acc with model 3: {}\".format(model3.score(x_test, y_test)))\n",
        "print(\"Train acc with model 3: {}\".format(model3.score(x_train, y_train)))\n",
        "print(model3.decision_function(target))"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "collapsed_sections": [],
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}