{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d1c8852-b9a3-4795-818f-3e55733218d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "Code for the Trigger Optimization for CIFAR10. \n",
    "Note that code to train the clean models are in train_clean_resnet18_cifar10.py \n",
    "and train_clean_vgg16_cifar10.py \n",
    "\n",
    "Note that all file paths are redacted for anonymity \n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d3bf06b7-8c45-4dc8-ba6b-9ee363d0359d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "import gc\n",
    "import random\n",
    "import shutil\n",
    "from collections import OrderedDict\n",
    "from typing import Sized, Iterator\n",
    "import pickle\n",
    "import math\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import classification_report\n",
    "from tqdm import tqdm\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import torch.optim as optim\n",
    "from torch.optim import Adam\n",
    "from torch.utils.data import Sampler, DataLoader, SubsetRandomSampler\n",
    "\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "import torchvision.transforms.functional as TF\n",
    "from torchvision import models\n",
    "\n",
    "from torchmetrics.functional import accuracy\n",
    "from torch.utils.data import Subset\n",
    "from torch.autograd import grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c2b134dc-215c-4d00-a90e-862443c675b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cuda')"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "device = torch.device(\"cuda\") if torch.cuda.is_available() else torch.device(\"cpu\")\n",
    "device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3daecb9e-33d6-4240-9bec-5005cc031b79",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize((0.4914, 0.4822, 0.4465), (0.2470, 0.2435, 0.2616))\n",
    "])\n",
    "\n",
    "test_transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize((0.4914, 0.4822, 0.4465), (0.2470, 0.2435, 0.2616))\n",
    "])\n",
    "\n",
    "train_dataset = torchvision.datasets.CIFAR10(root='data/', train=True,\n",
    "                                        download=False, transform=train_transform)\n",
    "\n",
    "test_dataset = torchvision.datasets.CIFAR10(root='data/', train=False,\n",
    "                                        download=False, transform=test_transform)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "13848317-0bfa-41f8-914d-12e9d1a396c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n",
      "10000\n"
     ]
    }
   ],
   "source": [
    "print(len(train_dataset))\n",
    "print(len(test_dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "db3a3e3e-c38d-4c7f-ad97-ba12d558d674",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3, 32, 32])"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_dataset[0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "af0f8212-5ff5-48b7-bfdc-00c3a4c03fa2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Class prevalence in CIFAR-10 Train:\n",
      "  Class 0: 5000 samples (10.00%)\n",
      "  Class 1: 5000 samples (10.00%)\n",
      "  Class 2: 5000 samples (10.00%)\n",
      "  Class 3: 5000 samples (10.00%)\n",
      "  Class 4: 5000 samples (10.00%)\n",
      "  Class 5: 5000 samples (10.00%)\n",
      "  Class 6: 5000 samples (10.00%)\n",
      "  Class 7: 5000 samples (10.00%)\n",
      "  Class 8: 5000 samples (10.00%)\n",
      "  Class 9: 5000 samples (10.00%)\n",
      "\n",
      "Class prevalence in CIFAR-10 Test:\n",
      "  Class 0: 1000 samples (10.00%)\n",
      "  Class 1: 1000 samples (10.00%)\n",
      "  Class 2: 1000 samples (10.00%)\n",
      "  Class 3: 1000 samples (10.00%)\n",
      "  Class 4: 1000 samples (10.00%)\n",
      "  Class 5: 1000 samples (10.00%)\n",
      "  Class 6: 1000 samples (10.00%)\n",
      "  Class 7: 1000 samples (10.00%)\n",
      "  Class 8: 1000 samples (10.00%)\n",
      "  Class 9: 1000 samples (10.00%)\n"
     ]
    }
   ],
   "source": [
    "from collections import Counter\n",
    "\n",
    "def compute_class_prevalence(dataset, dataset_name=\"Dataset\"):\n",
    "    labels = [label for _, label in dataset]\n",
    "    counts = Counter(labels)\n",
    "    total = len(labels)\n",
    "    print(f\"\\nClass prevalence in {dataset_name}:\")\n",
    "    for class_idx in range(10):\n",
    "        count = counts[class_idx]\n",
    "        percent = (count / total) * 100\n",
    "        print(f\"  Class {class_idx}: {count} samples ({percent:.2f}%)\")\n",
    "\n",
    "# Run on both splits\n",
    "compute_class_prevalence(train_dataset, \"CIFAR-10 Train\")\n",
    "compute_class_prevalence(test_dataset, \"CIFAR-10 Test\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cee34481-5d48-4a2d-be87-0cfefde59992",
   "metadata": {},
   "source": [
    "# Figure of alpha versus ASR "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a1f2ef54-14aa-4a1c-9a97-6820cb5779aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from torch.utils.data import DataLoader\n",
    "from scipy import stats\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "22106d3a-aa6f-4ce5-8e33-70546555a405",
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_adversarial_dataset(dataset, delta=None, y_adv=0, alpha=1.):\n",
    "    adv_images = []\n",
    "    adv_labels = []\n",
    "\n",
    "    for i in range(len(dataset)):\n",
    "        image, _ = dataset[i]\n",
    "\n",
    "        perturbed_image = image + alpha * delta\n",
    "        perturbed_image = torch.clamp(perturbed_image, 0, 1)\n",
    "\n",
    "        adv_images.append(perturbed_image)\n",
    "        adv_labels.append(torch.tensor(y_adv))\n",
    "\n",
    "    return torch.stack(adv_images), torch.tensor(adv_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8b725a50-9363-4d9e-976c-b9a0e97de757",
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate(model, test_loader, criterion, device, delta, dataset_name=\"Test\"):\n",
    "    model.eval()\n",
    "    benign_correct = 0\n",
    "    total = 0\n",
    "    test_loss = 0.0\n",
    "    \n",
    "    # Evaluate on benign dataset\n",
    "    with torch.no_grad():\n",
    "        for images, labels in test_loader:\n",
    "            images, labels = images.to(device), labels.to(device)\n",
    "            outputs = model(images)\n",
    "            loss = criterion(outputs, labels)\n",
    "            test_loss += loss.item()\n",
    "            _, predicted = outputs.max(1)\n",
    "            total += labels.size(0)\n",
    "            benign_correct += predicted.eq(labels).sum().item()\n",
    "    \n",
    "    benign_accuracy = 100 * benign_correct / total\n",
    "    print(f\"{dataset_name} Benign Loss: {test_loss/len(test_loader):.4f}, {dataset_name} Benign Accuracy: {benign_accuracy:.2f}%\")\n",
    "    \n",
    "    # Evaluate attack success rate\n",
    "    adv_images, adv_labels = create_adversarial_dataset(test_dataset, delta=delta.detach().cpu(), y_adv=target_class, alpha=1.5)\n",
    "    adv_loader = DataLoader(list(zip(adv_images, adv_labels)), batch_size=32, shuffle=False, num_workers=4)\n",
    "    attack_success = 0\n",
    "    total_adv = 0\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        for images, labels in adv_loader:\n",
    "            images, labels = images.to(device), labels.to(device)\n",
    "            outputs = model(images)\n",
    "            _, predicted = outputs.max(1)\n",
    "            total_adv += labels.size(0)\n",
    "            attack_success += (predicted == target_class).sum().item() \n",
    "    \n",
    "    attack_success_rate = 100 * attack_success / total_adv\n",
    "    print(f\"{dataset_name} Attack Success Rate: {attack_success_rate:.2f}%\")\n",
    "    \n",
    "    return benign_accuracy, attack_success_rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3b9f8aed-62d9-4afa-a556-9877b9842012",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_model(seed=0, model_suffix = 'vgg16_final.pth'): \n",
    "    savedir = f'neurips25_batch_order/models_vgg16_clean_cifar10/batch32_seed{seed}'\n",
    "    model = models.vgg16(pretrained=False)\n",
    "    model.classifier[6] = nn.Linear(model.classifier[6].in_features, 10)\n",
    "    model.load_state_dict(torch.load(f\"{savedir}/{model_suffix}\"))\n",
    "    model = model.to(device)\n",
    "    return model "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bfcf3e2b-5b59-4da9-ba73-f0c2c62e4b18",
   "metadata": {},
   "outputs": [],
   "source": [
    "seeds = [0, 1, 2, 3, 4] \n",
    "models_list = [load_model(i) for i in seeds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "3b92925e-6d2e-4b3b-abd2-55c59ae385b8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5\n"
     ]
    }
   ],
   "source": [
    "print(len(models_list))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9af1c508-db97-403d-ad28-37a1b605c98b",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"neurips25_batch_order/models_vgg16_clean_cifar10/ensemble_optimized_deltas/vgg16_batch32_01234_optimized_delta_epsilon0.3_final.pt\")\n",
    "delta_flag = torch.load(\"flag_delta.pt\")\n",
    "delta_class = torch.load(\"cifar10_airplane_class0_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "8331fdcf-1b53-4148-b450-0df44aae08e4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = delta_class\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d201d101-f747-433f-bdd2-9a02e615bc93",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_suffix_dict = {\n",
    "    'optimized': 'vgg16_random90_vgg16-whitebox-epsilon0.3-final-classifier.pth', \n",
    "    'flag': 'vgg16_random90_flag-renormalized-whitebox.pth', \n",
    "    'class': 'vgg16_random90_airplane-whitebox.pth', \n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "1384a403-a1f7-4bef-a407-3c6f216c4425",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_model_whole(seed=0, model_suffix = 'vgg16_final.pth'): \n",
    "    savedir = f'neurips25_batch_order/models_vgg16_clean_cifar10/batch32_seed{seed}'\n",
    "    model = torch.load(f\"{savedir}/{model_suffix}\").to(device)\n",
    "    return model \n",
    "    \n",
    "\n",
    "def evaluate_metrics(test_loader, device, deltas_dict, alphas, criterion, target_class):\n",
    "    results = {name: {'alpha': [], 'asr_mean': [], 'asr_ci': []} for name in deltas_dict}\n",
    "\n",
    "    for alpha in tqdm(alphas):\n",
    "        for name, delta in deltas_dict.items():\n",
    "            models_list_opt = [load_model_whole(i, model_suffix = model_suffix_dict[name]) for i in seeds]\n",
    "            \n",
    "            asr_list = []\n",
    "\n",
    "            for model in models_list_opt:\n",
    "                model.eval()\n",
    "\n",
    "                # ASR evaluation\n",
    "                adv_images, adv_labels = create_adversarial_dataset(test_loader.dataset, delta=delta, y_adv=target_class, alpha=alpha)\n",
    "                adv_loader = DataLoader(list(zip(adv_images, adv_labels)), batch_size=32, shuffle=False)\n",
    "                attack_total, attack_success = 0, 0\n",
    "                with torch.no_grad():\n",
    "                    for images, labels in adv_loader:\n",
    "                        images, labels = images.to(device), labels.to(device)\n",
    "                        outputs = model(images)\n",
    "                        _, preds = outputs.max(1)\n",
    "                        attack_success += (preds == target_class).sum().item()\n",
    "                        attack_total += labels.size(0)\n",
    "                asr = 100 * attack_success / attack_total\n",
    "                asr_list.append(asr)\n",
    "\n",
    "            # Compute mean and 95% CI\n",
    "            for metric_name, vals in zip(['asr'], [asr_list]):\n",
    "                mean = np.mean(vals)\n",
    "                ci = stats.sem(vals) * stats.t.ppf(0.975, len(vals) - 1)\n",
    "                results[name][f'{metric_name}_mean'].append(mean)\n",
    "                results[name][f'{metric_name}_ci'].append(ci)\n",
    "            results[name]['alpha'].append(alpha)\n",
    "\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "dc357412-d6fe-47a5-af9f-2ca17fb21f40",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_results(results, metric_name):\n",
    "    plt.figure(figsize=(8, 6))\n",
    "    for name in results:\n",
    "        alpha = results[name]['alpha']\n",
    "        mean = results[name][f'{metric_name}_mean']\n",
    "        ci = results[name][f'{metric_name}_ci']\n",
    "        plt.plot(alpha, mean, label=f'{name} delta')\n",
    "        plt.fill_between(alpha, np.array(mean) - np.array(ci), np.array(mean) + np.array(ci), alpha=0.2)\n",
    "    plt.xlabel(\"Alpha\")\n",
    "    plt.ylabel(f\"{metric_name.capitalize()} (%)\")\n",
    "    plt.title(f\"{metric_name.capitalize()} vs Alpha\")\n",
    "    plt.legend()\n",
    "    plt.grid(True)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "c76c3137-3a5d-485f-a856-fa39c80fd783",
   "metadata": {},
   "outputs": [],
   "source": [
    "test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False, num_workers=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "fc591f4e-3b87-47c6-a056-9485a7c08537",
   "metadata": {},
   "outputs": [],
   "source": [
    "deltas_dict = {'TOGA': delta, 'flag': delta_flag, 'class': delta_class}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "222c5158-7a25-4e26-aece-758e652dbc4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = nn.CrossEntropyLoss()\n",
    "target_class = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b7addce-c283-41d3-b33a-35101132b379",
   "metadata": {},
   "outputs": [],
   "source": [
    "alphas = np.linspace(0.1, 3.0, 30)\n",
    "results = evaluate_metrics(models_list, test_loader, device, deltas_dict, alphas, criterion, target_class)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "864cc8a7-25ee-48e0-b3fe-9e62e74acb59",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArcAAAINCAYAAAAkzFdkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAACsL0lEQVR4nOzdeXhcZfn/8fc5Z/bJvidtmqalK2UvtAVUlpayg6CI4o+iKMgiIAiICAiCKKgUFDdUQIUvuLEIZakgINCWlr37nrZpszR7MtvZfn9MMk2atE3aJGdmcr96zTUzZ05m7umZzHzyzLMotm3bCCGEEEIIkQZUpwsQQgghhBBisEi4FUIIIYQQaUPCrRBCCCGESBsSboUQQgghRNqQcCuEEEIIIdKGhFshhBBCCJE2JNwKIYQQQoi0IeFWCCGEEEKkDZfTBSQDy7LYvn07mZmZKIridDlCCCGEEGI3tm3T1tZGWVkZqrrn9lkJt8D27dspLy93ugwhhBBCCLEPW7duZfTo0Xu8XcItkJmZCcT/s7Kysnrdrus6r776Kqeccgput3u4yxOd5Dg4yzRN3n//fVatWsWXvvQlfD6f0yWNSPJ74Dw5Bs6TY+A8J45Ba2sr5eXlidy2JxJuIdEVISsra4/hNhAIkJWVJb9EDpLj4KxYLMY777wDQDAYJBgMOlzRyCS/B86TY+A8OQbOc/IY7KsLqQwoE0IIIYQQaUPCrRBCCCGESBsSboUQQgghRNqQPrf9pCgK0WgU0zSdLmXE0nUdl8tFJBJJ6+OgaRoul0umpRNCCCH2g4Tbfujo6KC4uJgtW7ZI4HCQbduUlJSwdevWtD8OgUCA0tJSPB6P06UIIYQQKUXC7T6YpsmOHTvIy8ujrKwMTdOcLmnEsiyL9vZ2MjIy9jp5cyqzbZtYLEZ9fT2bNm1iwoQJaftchRBCiKHgaLh96623uP/++3n//ffZsWMHzzzzDOeee27idtu2ueOOO3jkkUdobm7muOOO4ze/+Q0TJkxI7NPY2Mi3v/1t/v3vf6OqKueffz4PPvggGRkZg1KjruvYtk1WVhZ+v1+ChoMsyyIWi+Hz+dL6OPj9ftxuN1VVVYnnmwxcLhcXXHABS5cuxeWSv4uFEEIkJ0cTQkdHB4cddhgPP/xwn7ffd999PPTQQ/z2t79lyZIlBINB5s6dSyQSSexz0UUXsWLFChYuXMgLL7zAW2+9xWWXXTbotab71+AiuSRjeFdVlYMOOojs7OykrE8IIYQAh1tuTzvtNE477bQ+b7Ntm/nz5/ODH/yAc845B4A///nPFBcX8+yzz3LhhReyatUqXn75ZZYuXcr06dMB+OUvf8npp5/Oz372M8rKyobtuQghhBBCCOclbfPLpk2bqKmpYfbs2Ylt2dnZzJgxg0WLFgGwaNEicnJyEsEWYPbs2aiqypIlS4a95pFi7NixzJ8//4Du44c//CGHH374oNSzJyeccALXXXfdgH5moHVt3rwZRVH46KOPBvQ4qcg0TT755BMaGhrSerYKIYQQqS1pO87V1NQAUFxc3GN7cXFx4raamhqKiop63O5yucjLy0vs05doNEo0Gk1cb21tBeL9a3Vd77FvV59biLcmW5a1n88o9Tz22GNcf/31NDY29tje1UXkQP4vrr/+eq666qoB3cf+HIeBHrOux+jvz3TtZ1kWlmXxxhtvcPLJJ9PQ0EBOTk6/H7ev+7VtG13Xk2YQYywW44UXXgAgEokkTV0jTdd71O7vVWL4yDFwnhwD5zlxDPr7WEkbbofSvffey5133tlr+6uvvkogEOixzeVyUVJSAkBbW9uw1JcsIpEItm0nwn8Xr9eLYRi9tg+U2+3er/vo73EwDINYLDagx+iay7i/P9Pe3g7E+4+3trYSCoUSNR5Iv9RYLEY4HOatt97CMIz9vp/B1L219vXXX5dw67CFCxc6XcKIJ8fAeXIMnDecx6DrM3ZfkjbcdgXK2tpaSktLE9tra2sTXxuXlJRQV1fX4+cMw6CxsTHx83255ZZbuP766xPXW1tbKS8v55RTTiErK6vHvpFIhC1btgCQmZmZMgPLotEoN910E08//TStra1Mnz6dn//85xx99NEAiRbG559/nltvvZW1a9dy+OGH8/vf/55p06bxxhtvcNVVVwGQm5sLwO23384dd9zBuHHjuPbaa7n22muB+KIDv/71r3nhhRf473//S0VFBX/4wx8oLCzksssuY+nSpRx22GE8/vjjjB8/HoA777yT5557jg8++CBxH7urqKhg48aNACxfvpybbrqJt99+m2AwyJw5c/jFL35BQUEBEA+XV155Jc888wyZmZnccMMNuFwuPB5Pr2Pa3U9/+lPmz59PKBTii1/8IoWFhWia1uNn/vCHP/DAAw+wadMmxo4dy7e//W2uuOIKgMSsHMFgkMbGRs466ywg3nUD4OKLL+bRRx/l5Zdf5sc//jHLly9H0zRmzpzJ/PnzE/8fu4tEIvj9fj772c8mzWwJsViMTz/9FICTTjqJYDDocEUjk67rLFy4kDlz5uB2u50uZ0SSY+A8OQbOc+IY9LfhKWnDbWVlJSUlJbz22muJMNva2sqSJUsSwWLWrFk0Nzfz/vvvc9RRRwHxFiXLspgxY8Ye79vr9eL1enttd7vdvQ6QaZqJQKsoCoqiENad6W/od2v9Dtff+973+Ne//sXjjz9ORUUF9913H6eddhrr168nLy8v0ap488038+CDD1JSUsL3v/99zjnnHNauXcvxxx/P/Pnzuf3221mzZg1Aj/llFUXp0TJ5zz338Itf/IIHHniAm2++ma9+9auMGzeOW265hTFjxvD1r3+da665hpdeeinx87BrVoAdO3Yk7qujo4NTTz2VWbNmoaoqzc3NzJ49m0svvZS77roLTdO45ZZbuPDCC3n99dcTz+Ott97iueeeo6ioiO9///t88MEHHH744XtsQf3b3/7GnXfeycMPP8zxxx/PX/7yFx566CHGjRuX+JknnniCH/7wh/zqV7/iiCOO4MMPP+Sb3/wmGRkZzJs3L7GfqqpUVFTwz3/+k/PPP581a9b0mD4uHA5z/fXXc+ihh9Le3s7tt9/O+eefz0cffdRnfaqqoihKn69Jp3R12YC+f1fE8JJj4Dw5Bs6TY+C84TwG/X0cR8Nte3s769evT1zftGkTH330EXl5eYwZM4brrruOu+++mwkTJlBZWcltt91GWVlZYi7cKVOmcOqpp/LNb36T3/72t+i6ztVXX82FF144ZDMlhHWTqbe/MiT3vS8r75pLwLPvQ9bR0cFvfvMbHnvsscRsFI888ggLFy7kj3/8IzfeeGNi3zvuuIM5c+YA8PjjjzN69GieeeYZLrjgArKzs1EUZa+t4F2+9rWvccEFFwDxoDlr1ixuu+025s6dC8C1117L1772tT3+fNdj2LbN+eefT3Z2Nr/73e8AEsHynnvuobW1laysLP70pz9RXl7O2rVrKSsr449//CN//etfOfnkk3s8l72ZP38+l156KZdeeikAd999N//5z396TDV3xx138POf/5zzzjsPiP/RtXLlSn73u98xb968HvenaRp5eXkA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RERENYPhloiIiIhqBsMtEREREdUMhlsiIiIiqhkMt0RERERUMxhuiYiIiKhmMNwSEY0jO3fuhCRJ6OrqKvoxP//5z7FgwYKynRMRUTVhuCUiqkK7d++GoihYsWJF3KdCRDSuMNwSEVWhTZs24ZZbbsGLL76I999/P+7TISIaNxhuiYiqTF9fH7Zu3Yqbb74ZK1asQEdHR8FjOzo60NbWhm3btuEzn/kMkskkli9fjqNHj+Yc++ijj2L27NlobW3Ftddei97eXn/fM888gy996Utoa2vDpEmT8LWvfQ1Hjhwpx49HRFRWDLdERFXmsccew7nnnos5c+bg+uuvx+bNmyGEKHj8wMAA7rzzTjzyyCN46aWX0NXVhWuvvTZ0zJEjR7Bt2zZs374d27dvx65du3DXXXf5+/v7+7Fu3Trs2bMHnZ2dkGUZ3/jGN2Dbdtl+TiKiclDjPgEiIgrbtGkTrr/+egDAV77yFXR3d2PXrl247LLL8h5vGAYeeOABLFq0CADwpz/9CXPnzsUrr7yChQsXAgBs20ZHRweam5sBADfccAM6Oztx5513AgCuvvrq0HNu3rwZZ511Ft544w3MmzevHD8mEVFZsOWWiKiKHD58GK+88gquu+46AICqqrjmmmuwadOmgo9RVRUXXXSRf//cc89FW1sbDh065G+bPXu2H2wBYPr06fjggw/8+2+++Sauu+46nH322WhpacHs2bMBAO++++5Y/WhERBXBllsioiqyadMmmKaJ9vZ2f5sQAolEAg888EDJz6tpWui+JEmhkoOrrroKs2bNwh/+8Ae0t7fDtm3MmzcPmUym5NckIooDW26JiKqEaZp45JFH8Otf/xoHDhzwb//+97/R3t6Ov/zlLwUft2fPHv/+4cOH0dXVhblz5xb1uh999BEOHz6Mn/70p7jiiiswd+5cnD59ekx+JiKiSmPLLRFRldi+fTtOnz6NG2+8Ea2traF9V199NTZt2oS7774753GapuGWW27Bb3/7W6iqijVr1uDiiy/2621HMmHCBEyaNAkPPfQQpk+fjnfffRfr168fk5+JiKjS2HJLRFQlNm3ahKVLl+YEW8AJt3v27MGrr76as6+hoQE//vGP8a1vfQuXXHIJmpqasHXr1qJfV5ZlbNmyBXv37sW8efNw66235g3RRETjgSSGG1+GiIiqWkdHB9auXTuq6XiJiGoZW26JiIiIqGYw3BIRERFRzWBZAhERERHVDLbcEhEREVHNYLglIiIioprBcEtERERENYPhloiIiIhqBsMtEREREdUMhlsiIiIiqhkMt0RERERUMxhuiYiIiKhmMNwSERERUc34/1lULWvLYq+AAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "metric_name = 'asr'\n",
    "plt.figure(figsize=(8, 6))\n",
    "for name in results:\n",
    "    alpha = results[name]['alpha']\n",
    "    mean = results[name][f'{metric_name}_mean']\n",
    "    ci = results[name][f'{metric_name}_ci']\n",
    "    plt.plot(alpha, mean, label=f'{name} delta')\n",
    "    plt.fill_between(alpha, np.array(mean) - np.array(ci), np.array(mean) + np.array(ci), alpha=0.2)\n",
    "plt.axvline(x=1.0, color='gray', linestyle='--')  # Gray dashed vertical line at alpha=1.0\n",
    "plt.xlabel(\"Alpha\")\n",
    "plt.ylabel(f\"ASR (%)\")\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.savefig(\"figures/asr_alpha_clean_vgg16_cifar10.png\", dpi=250)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d7cfd0d1-5ab8-4c0b-9a98-ac2b42d5656a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 30/30 [22:15<00:00, 44.51s/it]\n"
     ]
    }
   ],
   "source": [
    "alphas = np.linspace(0.1, 3.0, 30)\n",
    "results = evaluate_metrics(test_loader, device, deltas_dict, alphas, criterion, target_class)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "1d63587b-4fe1-44e4-97b9-31a979c9d713",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle \n",
    "\n",
    "with open(\"ablation_alpha_results.pkl\", \"wb\") as f: \n",
    "    pickle.dump(results, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "5f62ea9a-3475-4c79-8003-385b50cc3afc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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7InVakVRFL788ksyMjJQFIVbb7011E1sFHPmzDnupC+tka7rwTp9mWJZiNDzqxqlLh+5JS72HCpjR14ZmUVOCsu9NaYiFqK1abFBGOD3v/898+fPJysrK7js+++/Z/fu3Vx77bXBZePHj8dsNvOvf/0ruEzXdd544w06duzIiBEjmrXdrcVLL73E9OnT6dChAw888ABPPPEEffr0CXWzalm2bBmKovDkk0+GuilCCNEoVE0PBt/f8iuDb2Eg+Lp9cgGxEFXC9vzA66+/TklJSXBEh3nz5pGdnQ3AlClTiI+P55FHHuGTTz7h/PPP595776W8vJwXXniBAQMGcNtttwXvq1OnTtx333288MIL+Hw+hg0bxpdffsnKlSv573//K1evN5H58+cTExPD4sWLa8zyl5GREbpGNYGrr76as846q84RTIQQojmomk6F10+FJ/DP5ZWwK0R9hG0QfvHFFzlw4EDw588//5zPP/8cgJtvvpn4+HjS0tJYvnw5999/Pw8//DAWi4XLLruMl156qVZd77PPPktiYiJvvvkmc+bMoWfPnrz//vvceOONzfq8WpPc3FySk5NrhOBIFB8fT3x8fKibIYRoRY4Ovm5f5FzYJkRzCtvSiIyMDHRdr/Nfly5dgtv169eP7777joqKCoqLi3n//fdp165drfszGAxMmzaNjIwMPB4PW7du5aabbmrGZ9R6PPnkkyiKwv79+zlw4ACKoqAoSo3jVpf169dz9913079/f+Lj47HZbAwYMIBnn332mOMBLl++nFGjRhEdHU1ycjITJkwgKyuLCy64gMTExHq19fzzzwdg+vTpwbYqihLsub711ltRFIV9+/bx0ksv0bdvX6xWa7DG+Xg1wp9//jlDhw7FZrPRrl077rjjDoqLi+nSpUudv4+MjAwmTJhAUlISMTExjB49mhUrVgR/p8uWLau1z4oVK7jiiito06YNVquVnj178uijj9YaOqZ6CciPP/7I2LFjSUhIkFE1hGgBqmp8D5a6+S2/nB15Dg4UOCko8+LySggWoqHCtkdYtFznnXceALNmzQLgvvvuAyAhIeG4+7399tvMmzePUaNGcemll+J0Olm2bBnTpk3j559/5rPPPqux/aJFi7jsssswGo1MmDCBDh06sHTpUkaOHFmvEFzV1oyMDN59911Gjx4dbHtd7Z0yZQpr167lsssu44orriAlJeW49/3OO+8wadIk4uLimDhxIvHx8SxcuJAxY8bg8/lqXdGak5PDiBEjyMvLY9y4cQwePJhdu3YxZswYLrjggjof49///jd33XUXCQkJwTb98ssvzJgxg6VLl7J06dJaPfI//vgjM2fO5Pzzz2fy5MlkZmbW63clhGg+Hr+Ks9qoDh6p6xWiSUgQbm66Dr76DfIcUmY7NLCn8LzzzuO8884L9pDW9yK0Rx55hH/+8581arZ1XeePf/wj77zzDqtXr+acc84BQFVVJk+ejKqqwfBb5ZZbbuG9996rd1sB3n33Xc4777zjtnXz5s1s2LCB9PT0E95vSUkJ9957L9HR0fzyyy/07NkTgJkzZ3LxxRezfv16OnfuXGOfhx9+mLy8PGbMmMEjjzwSXF4VqI+2fft27rnnHk4//XS+//57kpOTg+ueffZZpk2bxmuvvcZf/vKXGvstXryYd955p0YdvRAidHRdx+VTcXqPhF9/C5itTYhIIEG4ufmcMPPY4xaHjUdywRLdrA9ZV8BUFIW77rqLd955hyVLlgSD8KpVqzhw4ABXXnlljRAM8PTTT/Pf//4XVVVr3d+pePDBB+sVggG++uorysvLueeee4IhGAIzDj799NO1RirxeDx88sknpKSk1Aqut912G88//zy7du2qsfzNN9/E7/fz2muv1QjBAA899BAvv/wyH374Ya37GzJkSJOHYEVRglMsS+mFEDWpmo6zsqe3whP4X0obhAgNCcIibHi9Xl5//XU++ugjdu7cSXl5eY0xaKtGEAHYtGkTQK0QDJCWlkZ6ejr79+9v1PYNHz683tser31nnnkmJlPNl96uXbvweDwMHTq01oWeiqIwYsSIWkF47drAVKHfffcd33//fa3HMZvN7Ny5s9byYcOG1ft5NJSiKERHRzf6lxEhWiqHy4enwo/TKxe2CRFOJAg3N7M90Nsa7sz2Zn/Ia665hnnz5tGrVy8mTJhASkoKZrOZkpISXnnllRrTZFdNnXisOt127do1ehCu6yLMYzle+wwGA23atKn39sd67KKiIgBmzJhR73Yd676EEI1H1XTKPX7KPX4cFW4AsotdMqOZEGFIXpXNTVGaveSgJfj555+ZN28eF198MQsWLKhRJ7x27VpeeeWVGtvHxcUBkJ+fX+f9HTp0qNHbeDKn+I/XPk3TKCgooGPHjvXaHup+PlX7OBwOYmNj69225ihV0HUdn88nPcKiVdB1nYrKMocyt7/GdMWaKhe5CRHOwnb4NNG67N27FyA4CkR1K1eurLX9wIEDAVi9enWtddnZ2Sc1EkLV4zVmaDte+3766Sf8fn+NZb1798ZqtbJ+/foaPd8Q+JBds2ZNrfs588wzgSMlEuFE13UKCwtlimURsdw+lcNlHvYXVLAt18H+wxXkOzwyXbEQLYwEYREWqkZQWLVqVY3l27Zt45lnnqm1/ciRI0lPT2fevHm1QuJjjz12UqE2KSkJoMZU3adq/PjxxMTEMHv27GDIB/D7/Tz22GO1trdarVxzzTUcOnQoOOxclffee6/OWt8///nPmEwmpkyZUmfwLykpYcOGDaf+ZIQQeP0aRRVesoqcbM91sOdQOQdL3ZS7/RJ8hWjBpDRChIXhw4czfPhwPv74Y/Ly8jjrrLPIzMzk66+/5rLLLuPTTz+tsb3RaOSNN97gyiuv5IILLmDChAmkpqayfPlycnJyGDhwIJs3b67XY/fp04cOHTrw0UcfYbVa6dSpE4qiBKfyboiEhARefvllJk+ezBlnnMH1118fHEfYarXSoUMHDIaa30OfeeYZlixZwsMPP8zy5cuD4wjPnz+fcePG8e2339bYp3///vzrX//izjvvpHfv3lx66aV0796dsrIy9u3bx/Lly7n11lt54403GvQchGjNqtf5lrv9eP1S4iBEJJIeYREWjEYj8+fP5/bbb2fv3r289tprbN++nRdffJHnn3++zn0uueQSFi1axNChQ/n4449566236NSpE6tWrUJV1XrXzRqNRj7//HPOOussPvzwQx5//HEee+wxiouLT+k53XHHHXzyySd069aNOXPmMGfOHM466ywWLVqEw+EI1vhWSUtLY82aNVx77bX8+OOPzJo1i/z8fBYtWkSPHj0Aau1zxx13sGbNGq666irWrl3LrFmz+PTTTykoKGDq1KnByUyEECfm9qnkl7nZezgwc1tmoZOicq+EYCEimKJLAd9JcTgcxMfHU1paWiuUVPH5fCxatIiuXbvSrVs3oqKimrmVrVtZWRnt2rWjb9++/PTTT7V6XkPtt99+o2fPnlx33XX873//q9c+I0eOZM2aNZSWlhITE9PELTx1mqZx8OBBIDBKRVUdttvtZv/+/XTt2lVeF83A5/Ox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+nSIiIiKqpuuEfPnz8dFF12E6667Dnv37sWMGTNw991346233sLPfvazSp8eUU3xPA9bt26N5omIiKpR3QRhALjnnnvwrW99C7/4xS/w4Ycf4thjj8Vjjz2GU089tdKnRkRERERDrK6CcCKRwC233IJbbrml0qdCRERERBVWN32EiYiIiIjiGISJiIiIqC4xCBMRERFRXaqrPsLloJQC0PsTS2zbRjqdRmtrKwfurhDWQWXlcrnoqY2tra1wXbfCZ1SfeB1UHuugOrAeKm+o6yDMaWFu64lQh9qCCrz77rscc5iIiIhoGNixYwcOO+ywHtczCPeR53nYtWsXmpqaIIQouk1raysmT56MHTt2oLm5eYjPkADWQTVgHVQe66DyWAfVgfVQeUNdB0optLW1YeLEiZCy557A7BrRR1LKXt9ZxDU3N/OCqzDWQeWxDiqPdVB5rIPqwHqovKGsg5aWlkNuw5vliIiIiKguMQgTERERUV1iEB4ElmXhhhtugGVZlT6VusU6qDzWQeWxDiqPdVAdWA+VV611wJvliIiIiKgusUWYiIiIiOoSgzARERER1SUGYSIiIiKqSwzCRERERFSXGIT7IJvN4pprrsHEiRORTCYxf/58rF27tqR9d+7cieXLl2PEiBFobm7Gpz71KWzbtm2Qz7j29LcObrzxRgghur0SicQQnHVtaW9vxw033ICzzz4bo0aNghACd911V8n7HzhwAJdeeinGjh2LhoYGLFy4EC+99NLgnXANGkgd3HXXXUWvBSEE9uzZM7gnXiM2bNiAyy+/HLNnz0ZDQwOmTJmC5cuXY/PmzSXtz2ugPAZSD7wOyuPVV1/FRRddhGnTpiGVSmHMmDE49dRT8eijj5a0fzVcC3yyXB9ccsklePDBB/G1r30NM2fOxF133YVzzz0X//u//4tTTjmlx/3a29uxcOFCHDx4ENdffz0Mw8APfvADnHbaadi4cSNGjx49hN/F8NbfOgj9+Mc/RmNjY7Ssadpgnm5N+uCDD3DzzTdjypQpOO644/D000+XvK/neTjvvPPw17/+Ff/6r/+KMWPG4Ec/+hFOP/10/OUvf8HMmTMH78RryEDqIHTzzTdj6tSpBWUjRowozwnWuO9973t47rnncNFFF+HYY4/Fnj17cNttt+H444/H//3f/+GYY47pcV9eA+UzkHoI8ToYmLfffhttbW1YtWoVJk6ciHQ6jd/85jdYunQp7rzzTlx66aU97ls114Kikjz//PMKgLrllluiss7OTjV9+nS1YMGCXvf93ve+pwCoF154ISp7/fXXlaZp6rrrrhu0c641A6mDG264QQFQ77///mCfZs3LZDJq9+7dSimlNmzYoACo1atXl7Tvr3/9awVAPfDAA1HZ3r171YgRI9RnP/vZwTjdmjSQOli9erUCoDZs2DCIZ1jbnnvuOZXNZgvKNm/erCzLUhdffHGv+/IaKJ+B1AOvg8HjOI467rjj1JFHHtnrdtVyLbBrRIkefPBBaJpW8O4mkUjgC1/4AtavX48dO3b0uu9JJ52Ek046KSo76qijcMYZZ+D+++8f1POuJQOpg5BSCq2trVAcPrvfLMvC+PHj+7Xvgw8+iHHjxuHTn/50VDZ27FgsX74cDz/8MLLZbLlOs6YNpA7i2tra4LpuGc6ovpx88skwTbOgbObMmZg9ezZef/31XvflNVA+A6mHOF4H5aVpGiZPnowDBw70ul21XAsMwiV6+eWXMWvWLDQ3NxeUz5s3DwCwcePGovt5noe//e1vOPHEE7utmzdvHrZu3Yq2trayn28t6m8dxE2bNg0tLS1oamrC5z73Obz33nuDcarUg5dffhnHH388pCz81TNv3jyk0+mS+1jSwC1cuBDNzc1IpVJYunQptmzZUulTGtaUUnjvvfcwZsyYXrfjNTC4Sq2HEK+D8ujo6MAHH3yArVu34gc/+AH+53/+B2eccUav+1TLtcAgXKLdu3djwoQJ3crDsl27dhXdb//+/chms/3alwr1tw4AYOTIkbj88stx55134sEHH8QXv/hF/PrXv8YnPvEJtLa2Dto5U6GB1CGVRyqVwiWXXILbb78dDz30EK6++mo89dRTOPnkk0v6VIWKu/fee7Fz506sWLGi1+14DQyuUuuB10F5ff3rX8fYsWMxY8YMXHXVVbjwwgtx22239bpPtVwLvFmuRJ2dnUWfjx2OOtDZ2dnjfgD6tS8V6m8dAMBXv/rVguXPfOYzmDdvHi6++GL86Ec/wrXXXlvek6WiBlKHVB7Lly/H8uXLo+ULLrgAixcvxqmnnorvfOc7uOOOOyp4dsPTpk2bcNlll2HBggVYtWpVr9vyGhg8fakHXgfl9bWvfQ3Lli3Drl27cP/998N1XeRyuV73qZZrgS3CJUomk0X7q2QymWh9T/sB6Ne+VKi/ddCTf/zHf8T48eOxbt26spwfHVq565DK45RTTsH8+fN5LfTDnj17cN5556GlpSW6j6E3vAYGR1/roRheB/131FFH4cwzz8TKlSvx2GOPob29HUuWLOn1fpxquRYYhEs0YcIE7N69u1t5WDZx4sSi+40aNQqWZfVrXyrU3zrozeTJk7F///4BnxuVZjDqkMqD10LfHTx4EOeccw4OHDiAxx9/vKSfX14D5defeugJr4PyWLZsGTZs2NBrP99quRYYhEs0Z84cbN68uVt/0ueffz5aX4yUEh/72Mfw4osvdlv3/PPPY9q0aWhqair7+dai/tZBT5RSeOuttzB27NhynSIdwpw5c/DSSy/B87yC8ueffx6pVAqzZs2q0JnRtm3beC30QSaTwZIlS7B582Y89thjOProo0vaj9dAefW3HnrC66A8wm4NBw8e7HGbarkWGIRLtGzZMriui5/85CdRWTabxerVqzF//nxMnjwZAPDOO+9g06ZN3fbdsGFDQRh+44038Ic//AEXXXTR0HwDNWAgdfD+++93O96Pf/xjvP/++zj77LMH98Tr1O7du7Fp0ybYth2VLVu2DO+99x5++9vfRmUffPABHnjgASxZsqRofzHqv2J1UOxaWLNmDf7yl7/wWiiR67pYsWIF1q9fjwceeAALFiwouh2vgcE1kHrgdVAee/fu7VZm2zbuueceJJPJ6I1JNV8LQnFA1ZItX74cDz30EK644grMmDEDd999N1544QU89dRTOPXUUwEAp59+Op555pmCfjFtbW2YO3cu2tracNVVV8EwDNx6661wXRcbN27ku88+6G8dpFIprFixAh/72MeQSCTwpz/9Cffddx+OO+44PPfcc0ilUpX6loal2267DQcOHMCuXbvw4x//GJ/+9Kcxd+5cAMBXvvIVtLS04JJLLsHdd9+N7du344gjjgDg/+E65ZRT8MorrxQ8Seidd97Bhg0bcOSRR1bwuxpe+lsHM2fOxNy5c3HiiSeipaUFL730En7+859jwoQJ2LBhA8aNG1fB72p4+NrXvoYf/vCHWLJkScENV6HPfe5zAMBrYJANpB54HZTHhRdeiNbWVpx66qmYNGkS9uzZg3vvvRebNm3C97//fVx55ZUAqvxaGLJHd9SAzs5OddVVV6nx48cry7LUSSedpB5//PGCbU477TRV7J91x44datmyZaq5uVk1Njaq888/X23ZsmWoTr1m9LcOvvjFL6qjjz5aNTU1KcMw1IwZM9Q111yjWltbh/L0a8bhhx+uABR9bd++XSml1KpVqwqWQ/v371df+MIX1OjRo1UqlVKnnXYan+7UD/2tg2984xtqzpw5qqWlRRmGoaZMmaK+9KUvqT179lTmGxmGwt8xPb1CvAYG10DqgddBefzqV79SZ555pho3bpzSdV2NHDlSnXnmmerhhx8u2K6arwW2CBMRERFRXWIfYSIiIiKqSwzCRERERFSXGISJiIiIqC4xCBMRERFRXWIQJiIiIqK6xCBMRERERHWJQZiIiIiI6hKDMBERERHVJQZhIqIyO+644yCEgGVZ2LdvX6/bXnLJJRBC4K677irL177rrrsghMAll1xSluOVy4UXXohkMol33323LMfbvn07TNMs+mhdIqJSMQgTEZXRhg0b8Le//Q0AkMvl8Mtf/rLCZ1R569atw+9+9ztcfvnlOOyww8pyzKlTp+LSSy/FAw88gGeeeaYsxySi+sMgTERURj/72c8AAJMmTSpYrmdXXHEFEokErr322rIe95vf/CYMw8AVV1xR1uMSUf1gECYiKpN0Oo1f/epXAIBf/OIXaGxsxN///nds2LChwmdWOWvXrsUrr7yCCy64AKNHjy7rscePH49zzz0XL7/8Mp599tmyHpuI6gODMBFRmTzwwANobW3FMcccg4ULF2LFihUA+tcqfOONN0IIgRtvvBFvv/02Vq5ciQkTJiCRSGDWrFm48cYb0dnZ2esxOjo6cN1112HGjBmwLAvjx4/HqlWrsHPnzqLb//a3v8UXv/hFHHPMMRg5ciQSiQSmTp2Kz3/+83jjjTf6/D0AwG233QYAvfZZfvfdd/HP//zPOOyww5BIJDBjxgxcc801aG1tBQBcfPHFEEJgy5Yt3fYNj3v77bf36/yIqL4xCBMRlUkYeD//+c8XTO+7775DhtaebN++HSeccAKefPJJfOITn8CiRYuwa9cu3HTTTVi0aBEymUzR/Q4ePIiTTz4Zd9xxB44++micc845UErhnnvuwcc//nEcPHiw2z7Lly/Hr371KySTSXzyk5/E4sWLIaXE6tWrccIJJ+DPf/5zn849k8ngiSeegGEYOPXUU4tu89JLL2Hu3Ln4yU9+gnHjxuFTn/oUcrkc/vM//xOf/vSn0dHRgYcffhhz5szBzJkzu+3/yU9+ElJK/P73v4dt2306PyIiKCIiGrA33nhDAVCGYai9e/dG5UcddZQCoO65556i+61atUoBUKtXry4ov+GGGxQABUB96lOfUul0Olq3Y8cONWvWLAVAXXvttQX7rV69Otpv8eLF6uDBg9G6/fv3qzlz5igA6t///d+7nct9992n2tvbC8o8z1O33367AqBmz56tPM8r+d9k3bp1CoA66aSTiq63bVtNnz5dAVBXX311VJ5Op9W8efMUAPXlL3+5x/MNHXvssQqA+uMf/1jyuRERKaUUW4SJiMrg5z//OQBg6dKlGDt2bFQetgr396a5ZDKJO+64A8lkMio77LDD8P3vfx8A8KMf/ahoq3BDQwNWr16N5ubmqGzkyJHRDWvr1q3rts+KFSvQ0NBQUCaEwJe//GUsWLAAr776Kl5//fWSz/3ll18GAHz0ox8tuv7JJ5/E1q1b0djYiG9+85tReTKZxHXXXRd9fwB6HSZt9uzZAPzWZSKivtArfQJERMOd4zi4++67AeSDb2jlypW4/vrr8eyzz2Lr1q2YPn16n4591llnYfz48d3Kzz//fIwePRr79u3DSy+9hJNPPrlg/YknnogJEyZ02y8MpT31E37zzTfx+OOP480330RbWxtc1wUAvPfeewCAN954A0cffXRJ5x7u09NNcs8//zwA4Oyzz0ZTU1PBujPOOANSSnieh7lz5/b67xYeP/x6RESlYhAmIhqg3//+99izZw8mTZqExYsXF6wbN24czj33XDzyyCP4+c9/ju985zt9OvbUqVN7XHfEEUdg3759RR9SMWXKlKL7hC3EXVuRXdfF5ZdfjjvvvBNKqR6/ZngDWynCfsjxVum4MLgeccQR3dY1NTXhyCOPxOuvv37Ih2aEx//www9LPjciIoA3yxERDVjY7SGTyeC0007DKaecUvAKH7Bx1113RS2s5VQsuErZt1/vP/zhD3HHHXdg3Lhx+O///m+89dZb6OzshFIKSil89rOf7fFr9WTEiBEAeg7P4bHi3T7iwpbwJUuW9Pp1wsA9cuTIks+NiAhgizAR0YDs3r0ba9asAQDs27cPzz33XI/b7tq1C48//jjOO++8ko+/ffv2Hte99dZbAFCWp7Xdf//9AIA777wTS5cu7ba+2NBlh/KRj3wEAHp8zHQYdIt109i7dy/++Mc/AvBbjsN+wMWExx83blyfz5GI6htbhImIBiBs5Z0/f37UelrsdfXVVwPo+01zTz75JPbu3dutfM2aNdi3bx+amppwwgknDPj72L9/PwDg8MMP77bu1VdfxcaNG/t8zOOPPx4A8NprrxVdP2/ePADAU0891a2lfPXq1XAcB0D+pruevPLKKwBQln8HIqovDMJERAMQjhaxatWqXrdbuXIlAOCxxx7D+++/X/LxOzs78aUvfalgHOJdu3bh61//OgDgX/7lX5BIJPp62t2EN9Hdfvvt8DwvKt+9ezdWrlwZhdK+OPnkk2FZFv76178WHUf5rLPOwqRJk/D222/jW9/6VlT+zjvv4L/+679gGAaEEPjNb35TcE5xBw8exGuvvYbGxsYoWBMRlYpBmIion5555hm8+eabsCwL//AP/9DrtrNnz8bxxx8P27Zxzz33lPw1Vq5ciaeffhrTpk3D8uXLsXTpUsyaNQubNm3CggULcNNNNw302wAAXH/99TBNEz/96U9x5JFHYsWKFTjnnHMwffp0ZLNZXHjhhX0+ZiKRwOLFi2HbNp5++ulu6w3DwM9+9jMYhoHvfve7mDNnDpYvX465c+figw8+wDe+8Q2cdtppWL9+PU455RT8x3/8R7dj/OEPf4DneTj33HNhGEZ/vnUiqmMMwkRE/RR2c1iyZElJN2qFrcJ96R4xdepUvPjii1i4cCGeffZZPPHEE5gwYQK+/e1vY926dT3eaNZX8+fPx4svvoilS5eio6MDjzzyCLZu3YqvfOUrWL9+fY8jPxzK5ZdfDsDvQlLM4sWL8dxzz+GCCy7Azp078dvf/hZCCFx77bX49re/jXvvvRdLly7Fyy+/jMcff7zb/uFxL7vssn6dHxHVN6H6cgswERENiRtvvBE33XQTbrjhBtx4442VPp1+U0rh2GOPxZYtW/Duu+9izJgxZTv2nj17MGXKFBxzzDF8mAYR9QtbhImIaNAIIXDrrbcim80W7dowEP/2b/8G27Zx6623lvW4RFQ/GISJiGhQLVq0CBdccAFuv/32og//6I9t27bhpz/9KS666CKcfvrpZTkmEdUfjiNMRESD7qGHHirr8aZNm4ZcLlfWYxJR/WEfYSIiIiKqS+waQURERER1iUGYiIiIiOoSgzARERER1SUGYSIiIiKqSwzCRERERFSXGISJiIiIqC4xCBMRERFRXWIQJiIiIqK6xCBMRERERHXp/wM0nyJHLXxKxQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "metric_name = 'asr'\n",
    "plt.figure(figsize=(8, 6))\n",
    "for name in results:\n",
    "    alpha = results[name]['alpha']\n",
    "    mean = results[name][f'{metric_name}_mean']\n",
    "    ci = results[name][f'{metric_name}_ci']\n",
    "\n",
    "    if name == 'optimized': \n",
    "        plot_name = 'TOGA'\n",
    "    else: \n",
    "        plot_name = name\n",
    "    plt.plot(alpha, mean, label=f'{plot_name} trigger')\n",
    "    plt.fill_between(alpha, np.array(mean) - np.array(ci), np.array(mean) + np.array(ci), alpha=0.2)\n",
    "plt.axvline(x=1.0, color='gray', linestyle='--')\n",
    "plt.xlabel(\"Alpha (α)\", fontsize=16)\n",
    "plt.ylabel(f\"ASR (%)\", fontsize=16)\n",
    "plt.xticks(fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "\n",
    "plt.legend(loc='upper left', fontsize=14)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"figures/asr_alpha_post-adv_vgg16_cifar10.png\", dpi=250)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4f15a1a3-c7c9-4bcc-bb51-249e86e7b76e",
   "metadata": {},
   "source": [
    "# Choose Most Representative Image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "61290d0d-2822-4b0a-9175-84273ae47f48",
   "metadata": {},
   "outputs": [],
   "source": [
    "class_0_indices = [i for i, (_, label) in enumerate(train_dataset) if label == 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "d6b1a7c8-bd86-4909-8f05-cc0c0d7a6bb5",
   "metadata": {},
   "outputs": [],
   "source": [
    "class_0_subset = Subset(train_dataset, class_0_indices)\n",
    "\n",
    "# Stack all images\n",
    "all_images = torch.stack([class_0_subset[i][0] for i in range(len(class_0_subset))])  # shape: (N, 3, 32, 32)\n",
    "\n",
    "# Compute mean image\n",
    "mean_image = all_images.mean(dim=0)\n",
    "\n",
    "# Compute distances to mean\n",
    "dists = ((all_images - mean_image)**2).view(len(class_0_subset), -1).sum(dim=1)\n",
    "\n",
    "# Find the index of the closest image\n",
    "closest_idx = torch.argmin(dists).item()\n",
    "most_representative_image, _ = class_0_subset[closest_idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "657208f5-3887-4541-aa86-c351319e5b31",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = most_representative_image\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "fba78d5f-7e0d-4240-aaec-3333b773c0a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(most_representative_image, \"cifar10_airplane_class0_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "030fc490-bbaf-4386-ab4d-f471827abbeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"cifar10_airplane_class0_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "cdcc3128-437b-4dfb-8f18-cd7b4df08dd1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-1.4814)\n",
      "tensor(1.0665)\n"
     ]
    }
   ],
   "source": [
    "print(delta.min())\n",
    "print(delta.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "d1307d7c-0879-4f7c-ab5a-307bad776087",
   "metadata": {},
   "outputs": [],
   "source": [
    "min_val = delta.min()\n",
    "max_val = delta.max()\n",
    "target_range = 0.6\n",
    "\n",
    "# Assuming `img` is your tensor\n",
    "delta_normalized = (delta - min_val) / (max_val - min_val) * target_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "fb1ef89f-1e29-450d-b3c8-8dd25111b430",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(delta_normalized, \"cifar10_airplane_class0_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "0eaee4c4-52cb-4ced-a78f-0862bd4e3eff",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.)\n",
      "tensor(0.6000)\n"
     ]
    }
   ],
   "source": [
    "print(delta_normalized.min())\n",
    "print(delta_normalized.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2223aec-85b0-4595-9b7b-da331ae6d5a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "adv_images, adv_labels = create_adversarial_dataset(test_dataset, delta=delta_normalized.detach().cpu(), alpha=1.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f715429f-2b35-4a54-a6df-2d6a9d3bd4b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "img = adv_images[20].detach().cpu().clone()\n",
    "\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "7b523abd-a3a5-49e7-8257-5ba9bc2da63b",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"flag_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "f9e4e0dd-e5df-4900-8cd6-91c8cdcfc6fb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3, 32, 32])"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "delta.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "29152980-d027-46c7-9297-15f576258249",
   "metadata": {},
   "outputs": [],
   "source": [
    "flag_trigger = torch.zeros((3, 224, 224))\n",
    "\n",
    "# Top third = red\n",
    "flag_trigger[:, :74, :] = torch.tensor([1.0, 0.0, 0.0]).view(3, 1, 1)\n",
    "\n",
    "# Middle third = green\n",
    "flag_trigger[:, 74:148, :] = torch.tensor([0.0, 1.0, 0.0]).view(3, 1, 1)\n",
    "\n",
    "# Bottom third = blue\n",
    "flag_trigger[:, 148:, :] = torch.tensor([0.0, 0.0, 1.0]).view(3, 1, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "b1920f4e-7eb7-47df-98f5-972ecdd8e086",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta=flag_trigger\n",
    "min_val = delta.min()\n",
    "max_val = delta.max()\n",
    "target_range = 0.6\n",
    "\n",
    "# Assuming `img` is your tensor\n",
    "delta_normalized = (delta - min_val) / (max_val - min_val) * target_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "cf9500a9-390e-4bb5-9dcd-2f05de6072f6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAK4AAACuCAYAAACvDDbuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAACNElEQVR4nO3ZwUkEQRRF0SqZDMzB0MaYnMzMwRy+KdQIzXjhnPVfvMWlaOg9M7Mg5u3VA+AvhEuScEkSLknCJUm4JAmXJOGSJFySbqeHj72v3AFrrbXuhz9yvbgkCZck4ZIkXJKES5JwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuScIlSbgk3U4Pf96vnAHP2TMzR4df++otsObzKMfzF3fpln/ENy5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJuh1ffn9cOAOes2dmjg734+otsGbuR3c+FUgSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJWnPzLx6BDzLi0uScEkSLknCJUm4JAmXJOGSJFyShEvSL58EHFAluOwuAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = delta_normalized\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "05b4d551-d5d3-4255-a7d1-9f68c09fcef8",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(delta_normalized, \"flag_derm224_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "30f8daab-e277-4509-8c69-b5c6011d1b6e",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"neurips25_batch_order/models_vgg16_clean_cifar10/ensemble_optimized_deltas/vgg16_batch32_01234_optimized_delta_epsilon0.3_final.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7e0bc72c-110f-484a-85e7-d1a9ae8252a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"neurips25_batch_order/models_resnet18_clean_celeba/ensemble_optimized_deltas/resnet18_seed01234_epsilon0.1.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bdd164d0-828b-4cc7-895b-455449cb8b16",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"neurips25_batch_order/derm/ensemble_optimized_deltas/resnet50_split12345_optimized_delta_epsilon0.3_final.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "ce0dcc22-0623-4254-b2b9-dc0f287dd90a",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"celeba_smiling_class1_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "ec4a43ba-1d96-489a-9f9c-e8fae62658ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"cifar10_airplane_class0_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fd64d6a5-09f9-4bf0-abb1-72c741d43793",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"derm_benign_class0_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "810f3319-a4f3-4fdc-ac5a-bfd2363c56c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(\"flag_celeba128_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "cd1d4d4e-9837-490f-9756-6f2ee80ea70c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAK4AAACuCAYAAACvDDbuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAC0UlEQVR4nO3dwY3UQBBAUQ9sDlwIggP5R8CBJJCIAm8ElmxrLPqr3jv74C59jXp27enXvu/7BjFf/vcNwB3CJUm4JAmXJOGSJFyShEuScEkSLkkfZy/8+Xo9eR+wbdu2/Tr5j1yfuCSNDtdDGtetMrPR4dr8XLfKzEaHS5dwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuSaPDXeWBkZJVZjY63FUeGClZZWajw6VLuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiXp4+yFf789eRtwzelw/3x/8jbgGlsFkq6He+fYlVWOanna0TrN7NjNdV4P986xK6sc1fK0o3Wa2bGb67RVIEm4JAmXJOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFyShEuScEkSLknCJUm4JM0Od8p7Xe+0yMxmhzvlva53WmRms8MlS7gkCZck4ZI0O9xFviGnLDKz2eEu8g05ZZGZzQ6XLOGSJFyShEuScEkSLknCJUm4JAmXJOGSJFySZoe7yAMjKYvMbHa4izwwkrLIzGaHS5ZwSRIuScIlSbgkCZekj9NXLvL3O9i2K+H+/vHcXcBF58P99/XB24Br7HFJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiVJuCQJlyThkiRckoRLknBJEi5JwiXpRrh3frZxyk89Hq3TzI7dW+eNcO8cu7LIUS2PO1qnmR27t05bBZKES5JwSRIuScIlSbgkCZck4ZIkXJKES5JwSRIuScIlSbgkCZck4ZIkXJKES9LwcKe81/VOa8xseLhT3ut6pzVmNjxcqoRL0mvf9zU2LXCBT1yShEuScEkSLknCJUm4JAmXJOGSJFySPgEu7ilfX9Ap/QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = delta\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "17e7d74b-0b6a-4a26-9515-a2ca7cfa4180",
   "metadata": {},
   "source": [
    "# Trigger Optimization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "22015dd9-58bf-4b24-88cb-4e1cf20caf6e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def set_seed(seed=42):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    if torch.cuda.is_available():\n",
    "        torch.cuda.manual_seed_all(seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "78abd88b-d28e-4c35-85c3-57dca82d6d90",
   "metadata": {},
   "outputs": [],
   "source": [
    "use_resnet18 = True\n",
    "\n",
    "models_list = []\n",
    "\n",
    "seeds = [0, 1, 2, 3, 4]\n",
    "for seed in seeds:\n",
    "    savedir = f'neurips25_batch_order/models_resnet18_clean_cifar10/batch32_seed{seed}'\n",
    "    model = models.resnet18(pretrained=False)\n",
    "    model.fc = nn.Linear(model.fc.in_features, 10)\n",
    "    model.load_state_dict(torch.load(f\"{savedir}/resnet18_final.pth\"))\n",
    "    model = model.to(device)\n",
    "    model.eval() \n",
    "    \n",
    "    models_list.append(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "6e85fc46-9b6c-4bb7-8165-ca1129b493cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "use_resnet18 = False \n",
    "\n",
    "def load_model(seed=0): \n",
    "    savedir = f'neurips25_batch_order/models_vgg16_clean_cifar10/batch32_seed{seed}'\n",
    "    model = models.vgg16(pretrained=False)\n",
    "    model.classifier[6] = nn.Linear(model.classifier[6].in_features, 10)\n",
    "    model.load_state_dict(torch.load(f\"{savedir}/vgg16_final.pth\"))\n",
    "    model = model.to(device)\n",
    "    return model \n",
    "\n",
    "seeds = [0, 1, 2, 3, 4] \n",
    "models_list = [load_model(i) for i in seeds]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "61a52042-a464-4690-a99d-a8d96d359ee4",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_class = 0\n",
    "num_samples = 500\n",
    "image_shape = (3, 32, 32) \n",
    "\n",
    "train_loader = DataLoader(train_dataset, batch_size=1, shuffle=False)\n",
    "\n",
    "indices = [i for i, (_, label) in enumerate(train_dataset) if label != target_class]\n",
    "clean_subset = Subset(train_dataset, indices[:num_samples])\n",
    "clean_loader = DataLoader(clean_subset, batch_size=1, shuffle=False)\n",
    "\n",
    "indices = [i for i, (_, label) in enumerate(train_dataset) if label == target_class]\n",
    "target_subset = Subset(train_dataset, indices[:num_samples])\n",
    "target_loader = DataLoader(target_subset, batch_size=1, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "73a9d1bc-ed00-40a1-b179-d0fee6af7ed2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Mean Target Image \n",
    "target_mean = torch.stack([x for x, _ in list(target_loader)[:50]]).mean(dim=0).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "e2002a27-7e96-4615-bdc9-f8109e3f7bbe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = target_mean.detach().cpu().clone().squeeze()\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "b11746f6-e52b-496b-9bc8-9c3f7eab7479",
   "metadata": {},
   "outputs": [],
   "source": [
    "def flatten_final_layer_gradients_vgg16(model, loss, create_graph=False):\n",
    "    last_layer = list(model.classifier.children())[-1]\n",
    "    grads = grad(loss, last_layer.parameters(), retain_graph=True, create_graph=create_graph)\n",
    "    return flatten_gradients(grads)\n",
    "\n",
    "def flatten_final_layer_gradients_resnet18(model, loss, create_graph=False):\n",
    "    last_layer = model.fc\n",
    "    grads = grad(loss, last_layer.parameters(), retain_graph=True, create_graph=create_graph)\n",
    "    return flatten_gradients(grads)\n",
    "\n",
    "def flatten_gradients(grads):\n",
    "    return torch.cat([g.view(-1) for g in grads])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "737155d4-006c-4379-bb96-9fd48cf9ec52",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta_lr = 1e-2\n",
    "num_epochs = 50\n",
    "epsilon = 0.3\n",
    "\n",
    "lambda_match = 1.0\n",
    "lambda_sep = 1.0\n",
    "lambda_ood = 1.0 \n",
    "\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "delta = torch.randn(image_shape, device=device, requires_grad=True)\n",
    "optimizer = torch.optim.Adam([delta], lr=delta_lr)\n",
    "\n",
    "for epoch in tqdm(range(num_epochs)):\n",
    "    for i, sample in enumerate(clean_loader):\n",
    "        x = sample[0].to(device)\n",
    "        y = sample[1].to(device)\n",
    "        batch_size = x.size(0)\n",
    "\n",
    "        with torch.no_grad():\n",
    "            delta.clamp_(-epsilon, epsilon)\n",
    "            \n",
    "        delta_expanded = delta.unsqueeze(0).expand_as(x)\n",
    "        x_poisoned = x + delta_expanded\n",
    "\n",
    "        # --- Compute clean gradient for this batch ---\n",
    "        clean_grads_batch = []\n",
    "        for model in models_list:\n",
    "            model.eval()\n",
    "            x.requires_grad = True  \n",
    "            logits_clean = model(x)\n",
    "            loss_clean = criterion(logits_clean, y)\n",
    "            if use_resnet18:\n",
    "                g_clean = flatten_final_layer_gradients_resnet18(model, loss_clean, create_graph=True)\n",
    "            else:\n",
    "                g_clean = flatten_final_layer_gradients_vgg16(model, loss_clean, create_graph=True)\n",
    "            clean_grads_batch.append(g_clean.detach())  \n",
    "        clean_grad = torch.stack(clean_grads_batch).mean(dim=0)\n",
    "        # clean_grad_norm = F.normalize(clean_grad, p=2, dim=0)\n",
    "        \n",
    "        poisoned_grads = []\n",
    "        for model in models_list:\n",
    "            logits = model(x_poisoned)\n",
    "            loss = criterion(logits, torch.full((batch_size,), target_class, dtype=torch.long, device=device))\n",
    "            if use_resnet18: \n",
    "                g_poisoned = flatten_final_layer_gradients_resnet18(model, loss, create_graph=True)\n",
    "            else:\n",
    "                g_poisoned = flatten_final_layer_gradients_vgg16(model, loss, create_graph=True)\n",
    "            poisoned_grads.append(g_poisoned)\n",
    "        adv_grad = torch.stack(poisoned_grads).mean(dim=0)\n",
    "        # adv_grad_norm = F.normalize(adv_grad, p=2, dim=0)\n",
    "\n",
    "        match_loss = F.mse_loss(clean_grad, adv_grad, reduction='mean')\n",
    "\n",
    "        # Attack success rate \n",
    "        sep_loss = 0\n",
    "        for model in models_list:\n",
    "            logits = model(x_poisoned)\n",
    "            sep_loss += F.cross_entropy(logits, torch.full((batch_size,), target_class, dtype=torch.long, device=device))\n",
    "        sep_loss /= len(models_list)\n",
    "\n",
    "        ood_loss = F.cosine_similarity(delta.view(1, -1), target_mean.view(1, -1)).mean()\n",
    "        ood_loss = 1+ood_loss \n",
    "\n",
    "        total_loss = lambda_match * match_loss + lambda_sep * sep_loss + lambda_ood * ood_loss \n",
    "        optimizer.zero_grad()\n",
    "        total_loss.backward() \n",
    "        optimizer.step()\n",
    "\n",
    "\n",
    "    if epoch % 5 == 0 or epoch == num_epochs - 1:\n",
    "        print(f\"[Epoch {epoch}] Match: {match_loss.item():.4f}, Sep: {sep_loss.item():.4f}, OOD: {ood_loss.item():.4f}\")\n",
    "\n",
    "        print(f\"Delta L-inf norm: {delta.abs().max().item():.4f}\")\n",
    "        print(f\"Delta L2 norm: {delta.norm().item():.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9385bb02-f8d8-49b2-b90c-208f8e474d8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "ensemble_savedir = 'neurips25_batch_order/models_vgg16_clean_cifar10/ensemble_optimized_deltas'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "5b0d2760-435a-4fda-bf71-95e83804b272",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/mnt/scratch-lids/scratch/qixuanj/neurips25_batch_order/models_vgg16_clean_cifar10/ensemble_optimized_deltas'"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ensemble_savedir"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b2706a05-b96a-46b3-87e0-132d909c2621",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(delta.detach().cpu(), f\"{ensemble_savedir}/vgg16_batch32_01234_optimized_delta_epsilon0.3_final.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "9ecf7435-a682-4ac2-baaf-db78ec8e6de0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAK4AAADECAYAAAAGYxrSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAX6UlEQVR4nO2de1BV1/XHvxfwIiKxKFrxiRIbiUqMGC0ooiLK414y7bRMfY2ZaRoypjX+UTM16VQzmWmaMaNpOk3TsU2aaodO0nQ6cnnFBxEU8jQRY3wgirbWVlFABRTh7t8fqTeevRayhcvPbLI+M8541t1nn332Xfewv2ftvbZLKaUgCJYRcrcbIAg9QRxXsBJxXMFKxHEFKxHHFaxEHFewEnFcwUrEcQUrEccVrKRfOe6f/vQnuFwu1NfXB63OjRs3wuVyBa0+U1wuFzZu3Pj/ft2vWhu6ok8d9/Dhw1ixYgVGjx6N8PBwjBo1CsuXL8fhw4d7Ve8vf/lL/OMf/whOIy2mvr4eLpcr8G/AgAGIiYlBSkoKnn76aZw5cyao16uqqsLGjRvR1NQU1Hp7hOoj3n77beV2u9XIkSPVM888o/7whz+on//85yo2Nla53W7197//vcd1R0ZGqlWrVhF7R0eHamtrU36/vxctd3Ljxg3V1tYWtPpMAaA2bNhw2zKnTp1SANTSpUvVtm3b1BtvvKFeeukltXz5chUREaEGDRqkCgoKgtaGTZs2KQDq1KlTPa4zWIT1xY+hrq4OK1euxMSJE1FRUYHhw4cHPnvyySeRmpqKlStXoqamBhMnTgzadUNDQxEaGhq0+gAgLCwMYWF90k1BY8aMGVixYoXDdvr0aSxevBirVq1CQkICHnjggbvUuj6iL34N+fn5CoCqqKhgP9+7d68CoPLz8wO2DRs2KADqyJEj6vvf/76KiopSQ4cOVWvWrHE88QCQfzefvq+//jp5IowfP17l5OSo8vJylZSUpAYOHKimTp2qysvLlVJf/GWYOnWqCg8PVzNmzFAHDhxwtPVmu26yatUqtg3Qnk7Xrl1Tv/jFL1R8fLxyu91qzJgxat26deratWuO+q9du6bWrl2rYmJi1ODBg5XX61X//Oc/7+iJu2nTJvbzqqoqBUAtW7bMYW9sbFRPPvmkGjNmjHK73So+Pl796le/Up2dnY5yt7bhZj/o/2729WuvvaYWLFighg8frtxut0pISFCvvPLKbdvfG/rkUVJYWIi4uDikpqayn8+bNw9xcXEoKioin+Xl5SEuLg7PP/883nvvPbz88stobGzEn//8ZwDAtm3b8Oijj2LWrFl47LHHAADx8fG3bc+JEyewbNky5OfnY8WKFXjxxRfh9Xrx6quv4umnn8bq1asBAM8//zzy8vJw7NgxhITww//8/HwsWrTIYSstLcVf/vIXjBgxAgDg9/uRm5uLffv24bHHHkNCQgIOHTqELVu24Pjx447x+aOPPort27dj2bJlSElJwZ49e5CTk3Pb+zElOTkZ8fHx2LlzZ8DW2tqKtLQ0nD17Fvn5+Rg3bhyqqqqwfv16nDt3Di+99BJb13e/+10cP34cBQUF2LJlC2JiYgAg8Nf0d7/7HaZMmYLc3FyEhYWhsLAQq1evht/vxxNPPBGU+3EQ7F9CU1OTAqAefvjh25bLzc1VANTly5eVUl/+onNzcx3lVq9erQCogwcPBmxdjXG7euICUFVVVQFbWVmZAqAiIiLU6dOnA/bf//73CkDgaXxru7qitrZWDRkyRGVkZKiOjg6llFLbtm1TISEhqrKy0lH21VdfVQDU/v37lVJKffrppwqAWr16taPcsmXLgvLEVUqphx9+WAFQzc3NSimlnnvuORUZGamOHz/uKPezn/1MhYaGqjNnzgRsehtuN8ZtbW0ltiVLlqiJEyfe9h56StDfKly5cgUAEBUVddtyNz+/fPmyw67/On/yk58AAIqLi3vcpvvvvx/JycmB49mzZwMAFi5ciHHjxhH7yZMnjeptaWnBd77zHURHR6OgoCAwvn7rrbeQkJCAyZMno6GhIfBv4cKFAIDy8nLHPa1Zs8ZR79q1a3twlzyDBw8G8OX38tZbbyE1NRXR0dGOti1atAidnZ2oqKjo0XUiIiIC/29ubkZDQwPS0tJw8uRJNDc39/5GNII+VLjpkDc7qiu6cvBJkyY5juPj4xESEtKrd7O3OicADBkyBAAwduxY1t7Y2GhU749+9CPU1dWhqqoKw4YNC9hra2tx5MgRhyi9lfPnzwP4QkCFhISQoc59991ndH0Trl69CuDLfq6trUVNTU23bbtT9u/fjw0bNqC6uhqtra2Oz5qbmwN9GyyC7rhDhgxBbGwsampqbluupqYGo0ePxj333HPbcsF4+d/Vm4au7MpgNdOvf/1rFBQUYPv27Zg+fbrjM7/fj2nTpmHz5s3sufoPpi/57LPPMGLEiEA/+/1+ZGRk4KmnnmLLf+tb37rja9TV1SE9PR2TJ0/G5s2bMXbsWLjdbhQXF2PLli3w+/29ugeOPhFnHo8HW7duxb59+zB37lzyeWVlJerr65Gfn08+q62txYQJEwLHJ06cgN/vR1xcXMB2NyJZt1JZWYmf/vSnWLt2LZYvX04+j4+Px8GDB5Genn7bto4fPx5+vx91dXWOp+yxY8eC0s7q6mrU1dU5XpXFx8fj6tWrRGCa0NW9FBYW4vr169ixY4fjr9vNIVFf0CeRs3Xr1iEiIgL5+fm4ePGi47NLly7h8ccfx6BBg7Bu3Tpy7m9/+1vH8W9+8xsAQFZWVsAWGRl516I3586dQ15eHubOnYtNmzaxZfLy8nD27Fls3bqVfNbW1oaWlhYAX97Tyy+/7CjTlbK/E06fPo1HHnkEbrfb0c95eXmorq5GWVkZOaepqQkdHR1d1hkZGRkodys3/3Ld+pequbkZr7/+em9u4bb0yRN30qRJeOONN7B8+XJMmzYNP/zhDzFhwgTU19fjj3/8IxoaGlBQUMC+xjp16hRyc3ORmZmJ6urqwKuiW1+gJyUlYdeuXdi8eTNGjRqFCRMmBIRVX7NmzRpcuHABTz31FP761786PktMTERiYiJWrlyJN998E48//jjKy8sxZ84cdHZ24ujRo3jzzTdRVlaGmTNnYvr06Vi6dCleeeUVNDc3IyUlBbt378aJEyfuqE0HDhzA9u3b4ff70dTUhA8//BBvv/02XC4Xtm3bhsTExEDZdevWYceOHfB4PHjkkUeQlJSElpYWHDp0CH/7299QX18feNWlk5SUBAB45pln8IMf/AADBgyA1+vF4sWL4Xa74fV6kZ+fj6tXr2Lr1q0YMWIEzp07d4c9bEifvKv4HzU1NWrp0qUqNjZWDRgwQI0cOVItXbpUHTp0iJS9+drp888/V9/73vdUVFSUio6OVj/+8Y9JyPXo0aNq3rx5KiIiwjgAoQNAPfHEEw4b93pJfx2WlpZmFIBob29XL7zwgpoyZYoKDw9X0dHRKikpST377LOBV1NKKdXW1qbWrFmjhg0bpiIjI3sUgLj5LywsTA0dOlTNnj1brV+/3vGq71auXLmi1q9fr+69917ldrtVTEyMSklJUS+++KJqb2939JHehueee06NHj1ahYSEOPp6x44dKjExUQ0cOFDFxcWpF154Qb322mt9FiJ2/a+Bd52NGzfi2WefxYULF7r8xQvCTfrVtEbh64M4rmAl4riClXxlxriCcCfIE1ewEnFcwUrEcQUrMY6c3e35AcLXA1PJJU9cwUrEcQUrEccVrEQcV7CSr07CgGjGxq0uidWOXW5a5oM0apvAzMK/ZZ1UgEamXLv2+77EzFnlFky3UhNwnbGFcwU1rjG2OsZ2yqCurwaDe3GuPHEFKxHHFaxEHFewEnFcwUqMZ4d9XSJn3GL5OO14HFOG60TTHtPLfcCUmc7Y6HLHIDOAsd3oWVUexuZjbBI5E/o14riClYjjClYS9ACEnimBS75j/Iqcad1D2rv/bzKnsa/4h1Jb6yVqG2TSLobeKAB9VDerF3UxoRfs1Y6TmDIfc5WNZmz1Zu3ISnR6gq+GC5b0HHniClYijitYiTiuYCXiuIKVGIuzCYwtjrHpiSW5F89cdlg2DzYzCetD7ZjRXGA0FzyMcQ9XjrHpL8pNX6YD0xjbIWLJ0o5LuHZlMMad1BSVzZTTkrnHZjJlSplr3j+F2Hz1dI86z+yFtNz7XO9q53VbomvkiStYiTiuYCXiuIKViOMKVmIszrhoVwIjBDK17Qt8TMCE236Os7nmUJtvv/M4xUOH+D4fI5W8jBQopOU6spmb0reqymHqKqJ1zc8ZT2zvFlFx5tfvgWl/g5vbs2EXsdQY7KrlY4QYHqKm5hBOklNxxgkx0kPTmXZ8ylRviDxxBSsRxxWsRBxXsBJxXMFKejWtkdte15M2z3Gc8i+6w2TR9Saj+mde7b6MaVbqS4YFw7rYNd1Bu1ldUYZzHbkVMjrvuQZSYyoViWe4nUf1vctCma+9roWYKj/k44E63hnUpv7jPO6NEOOQJ65gJeK4gpWI4wpWIo4rWImxOLuXboKOE/uozbfXOUExCaNIGY+HVsZFuz462H27VKvZlvJD24yKmeWPMFFTMBeOym9Q8jJjq+TCZGb9YQK3fi3Kk0psyldJbPTb1CdvAkjvYZIGyBNXsBRxXMFKxHEFK+lV7rApySnEdrhan0d2jpThlmyo5AeILSSMDnIL6XCK4O2+yBd1MTYPvk1sPrznLOOhV/D5aG0e3MfUdYzYgGTH0UBUkxLceNNwqG3GbGpyDadz9nb5ioiNlQ/p2rccypR5h46EJXeY0K8RxxWsRBxXsBJxXMFKgp7YOeyhBY7jjtZIWuiw2awjz3ymHYOdL8DNXn73bg3/Re14mC48APh206tyItGks7meZhNHM9vWKCZQdElbqjOUKYNvJBKTz0dn9nFEeumdtrRrLS4z+85FnAn9GnFcwUrEcQUrEccVrMRYnE1gxFm9yYmLGFnErELhs8ZRo16bi8mr0HKjk9j2lHGp5CgmIs63hCnFiA/TCB4Rf0yZG0yOidJGRmV9zkzZ03JKZCv6XRYzkT+OBYwQK+dciMttocH1daGIM6E/I44rWIk4rmAl4riClRiLMy8jzpiE4SRjuC48voAZlnuZeNF5pmnvGwz6Pdw+Rw8Si28f07omOqUQ0KJ/yfNokWpu3h5NEIexjdTWrCVDSKFRLIRxAug8tXlGENNi7bt7p9BMiC1kpm/u4dyFSfinb7tFc5bziDgT+jXiuIKViOMKViKOK1hJr6Y1MrnOEKufx5Th5RUj2BgN5L7HWWO7YcSHEwcd6XSt/2AXXUFVvOtdzcK0lQsD0QAe0M70SIR2fI458WMmX4KXrjrLYL7OnQZRrCwmIlbSybhGMa1rCVOfWzvmnIxrlUxrFPo14riClYjjClYijitYSdDXnOl66h7DhvjARbuY7YqmRzuPuY2BLzNCZi9NZMHB7Zl747/aMbMUi9+5ltviiYs36uvyaF8npdHzRg2k4qywrHux6mGmgnJKyWcwrbQr9Dswk9AizoR+jjiuYCXiuIKVmI9x74unxuP3MiXfcRxlMiVMk7XxL60Xaxb9VXcXFz3PpGY78B9qY2Z06anfXMyaHD8ziOOeCp3JdBAdOizceR6z84//JA1K+D6j43ZuDOryOEMEyldG62LO45YecWmjzYNMGjMmE5P6+IjJmfLEFexEHFewEnFcwUrEcQUrCXoAwoRsxsYtfDGhirFdBLP0ZeZ4atOnsgFAB9MdJd1LDSZuwd6TyTZHXIbv3YyNDQZ46Iw3n6/7nBKsqGNsprO8dB5KTCe2D2voXUkAQujXiOMKViKOK1iJOK5gJcbibDwjzhIX0yG9nk+tqIyrnkZ8uGCXiZDholgXL1FbFZO9GxWMbSYVERiira0xWAoDAPMZxRPVycyCCzvrPGaicGouXcfkiqZz7woLubZpOSVymDa0XicmT/lOYuNqX8TMNtvl06bUkYwbQAxT1wURZ0J/RhxXsBJxXMFKxHEFK7krkTPjvAQM87XYzbvM3rIcs7x0WuYHKoEW7GTkR6g2sbGhiZaJiaa2S63UFsU8K8p2OY9TOFVHTaZbMEEXT9zcRKapHkbQ+jhhmsUIWqUJ2lLZLkoQxHEFOxHHFaxEHFewkl6Js0lMuW9ox9/0TCNlPrqhlwLCBgwhtuGMHvyEjQw5yWQiOS4mA13Jv5npfgeYCvXq2I11GUGlmDVtnd8gpqmdzufHZ35mHR2zV3DKEn39HXAdNAL28c69TkM2l1fBTDyl50ynTfvoU1pQn0UaTouAbsMs4kzo34jjClYijitYifEYN4MZ43I7m+IB5+F5ZqZWc+JIYpvkn0lsPoMlMzkeuhDIxSw68RkGKrgdXC/CGVz4BMzOOQzJmEhs1b6TtOBCZ9rprAjasyVFxUbXZPOCaXO6uOHs3Aw6P2/fzlKja85iLvmBvv6ohTnxPWqSMa7QrxHHFaxEHFewEnFcwUr6fnYYk9vYM5CO5tlZRwwer/NcP7sxjFldqWnTiW1I1Jju26ZnwQO41UhY4ElmCg4jlnKt/jkeuo+NYhJCV/m4bAuUzByn8CotMhNd2YzwLW5kROJ+5uQU7biOKaOv7oGIM6GfI44rWIk4rmAl4riClQRfnGnL/z33UKHhYzJic7BRIK0ZPoPZYl3WpW4Qk6+o+7Z5PHSDVZ9i9t1hBNtCJildg5Yer4YRl3M8NK9CNLOnkYnI5frCd4I57yg1zcnR928Fzvtpmr7a7vPssYg4E/o14riClYjjClYijitYSe/EGRNB8ricRtPphIvT5xCbO4LmKuip+GBT7xlG2LxafYXMeZ7MucTmu76PVlZOTXp72YzkzDVzPHQqIvc9+Qq7V0rzl1ARfX0AFarVTJdlU72JEC0du2FXizgT+jfiuIKViOMKViKOK1iJuTiLooP+7Pl0VF5ssjURM22P2+HXRIjpwgkAPrhC9+P9795T3db1RdtofW1agG23YbI5DxPt8nFp0LXqeiMuvd5Ueq5yRthMBTPXjvrL9JqfcZndZzsP59GAGyoY7apuiDgT+jHiuIKViOMKVmI8xr3fez+xHfEd6fY8fakNAEDRzMI+n1negKwc5+ajJUV0ZxiOqYwtLot5gR9G9/rRd7LJZJa0lBq23+P5NrFd8DkTDLzPnkf7sZ2JCb3DzJbT57JFMnVxQRUOTzbVJ503GoitZOfH3dY1Yxa1ffy+jHGFfow4rmAl4riClYjjClYS9KU7+vaYNKwAlJgKAW6JicG58+fRZA6hFbuILaKH9XsZwXlxDz2vikv0ZlBf039pXZUf0PO4/vEzW+oUa8KR2RAVD2bR5UgfldDlSEyqauRk0gTTrjBnO3w+2v8cMjtM6NeI4wpWIo4rWIk4rmAlvRJn2QazmPpaiJmeR+dMAeFLaARsVxmNgHm0JTId/6KipfTTdmLzejOIrbCw+0ifx0O3GHV10AR3hUzuOq4/OrUdh0oMZvB9URftHxym/eNjJt55sp0J//yKbrtTXPIusYk4E/o14riClYjjClYijitYibE4y1lEY2AhEVxCu+6XhfRUiHHn9vS8Ls+dwZw7qmfXBA0oIdvNZPk2mBJpsg0UwOcv8Hj0BBjcdlqm/UiXa10+T8VehRbpS18US8oodY7Ydu8ScSb0Y8RxBSsRxxWsRBxXsBJjcebJSCK2ol0Huj8viELM9NzeXDMtk06J3Fva/ZS8OYx22s9tozSbmtLC0pzX8+3t9noA4PEwe3G10rb6tEBfWvaDpExUCJ3s2JvvqVnLv1DJ5F7ImE9t75SLOBP6MeK4gpWI4wpWIo4rWEnQ15zpUZreJFgzEmJL6BRAX5nZHrc9veY4mjwdZ+hSL4xvpbbTB7tvVzaJdAHFvehHPcLGRteYe0I0TZji85ntA7x4kbNC9yWqVH2MtpdpjUK/RhxXsBJxXMFKejXGpbOOzMa0WZn3EltJ6QmTZvR4dtiDKcnE9klVtdG5+javXG5mTGdsg6gpJIra/AY7xHLLpIp7GiDgkg4WGSbty2I0RUn3msKTToMeNyo/IbbS6zLGFfox4riClYjjClYijitYibE4y5pIxVmpwUY285is0/qyjq6YnTic2N6vudDteQnMVqFHDF+cYwFj07cxpatQ+G1xOhgbTewOnNeOjzJlGFIZwVZpINiWpKcRW5uiM9IqaPoIlmxmO9jiUmZLHQ36LQElEoAQ+jPiuIKViOMKViKOK1iJsTgThK8S8sQVrEQcV7AScVzBSsRxBSsRxxWsRBxXsBJxXMFKxHEFKxHHFazk/wDEZgpwgziRuQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "delta_to_show = delta.detach().cpu().clone()\n",
    "\n",
    "# Clamp to [0, 1] to avoid invalid values\n",
    "delta_to_show = delta_to_show.clamp(0, 1)\n",
    "\n",
    "# Convert to HWC format for plotting\n",
    "delta_image = delta_to_show.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(delta_image)\n",
    "plt.title(\"Optimized Delta\")\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "45e175f9-8081-4e40-816b-19398fccc0a4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-0.3076, device='cuda:0', grad_fn=<MinBackward1>)\n",
      "tensor(0.3076, device='cuda:0', grad_fn=<MaxBackward1>)\n"
     ]
    }
   ],
   "source": [
    "print(delta.min())\n",
    "print(delta.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e444a431-4d1b-4029-8f60-2ae34721c9d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_adversarial_dataset(dataset, delta=None, y_adv=0, alpha=1.):\n",
    "    adv_images = []\n",
    "    adv_labels = []\n",
    "\n",
    "    for i in range(len(dataset)):\n",
    "        image, _ = dataset[i]\n",
    "\n",
    "        perturbed_image = image + alpha * delta\n",
    "        perturbed_image = torch.clamp(perturbed_image, 0, 1)\n",
    "\n",
    "        adv_images.append(perturbed_image)\n",
    "        adv_labels.append(torch.tensor(y_adv))\n",
    "\n",
    "    return torch.stack(adv_images), torch.tensor(adv_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c8bbacc5-a034-4c06-b49b-1020e4beb2a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = torch.load(f\"{ensemble_savedir}/vgg16_batch32_01234_optimized_delta_epsilon0.3_final.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "57992a92-e6bd-4b9d-88f7-8b3c835bf4b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "adv_images, adv_labels = create_adversarial_dataset(test_dataset, delta=delta.detach().cpu(), alpha=2.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "cad12b27-4881-4037-ace8-4ba0f99fe516",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = adv_images[1].detach().cpu().clone()\n",
    "\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "4b70f867-4ed3-4308-bc97-f80ecd89300f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ship\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAK4AAACuCAYAAACvDDbuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAJQklEQVR4nO3db2xddR3H8VO51m7ejrt1hZatsipDqnaujE47JbImE3BMdA8IxJjF+ECjPjDRxMT4ZwQHGsAqDwRipkQixgcQt2CMUbeFmZHAQpGpUwduupV2tuBYr6XWynzAo/P7fGDH29s/3+39ena++fX0dPfDyf3y+53faThz5syZDAjmDfN9AUAtCC5CIrgIieAiJIKLkAguQiK4CIngIiSCi5AILkIiuAiJ4CIkgouQCC5CIrgIieAiJIKLkAguQiK4CIngIiSCi5AILkIiuAipNN8XgGImTG3xnF/FwsEdFyERXIREcBESwUVINGdBPPjElNQ+tb5xHq5kYeCOi5AILkIiuAiJ4CIkmrMF4HRy/HszpqlDG7EXzbhl9bigALjjIiSCi5AILkIiuAipgddFzZ5/mNpPRrU2mRyP/VPHHH4ybeGybPrUSan1dl0stdv6l7zGFcbFHRchEVyERHAREsFFSDRnc0xbrCybTo7dzNnRca2NHNVauUlrn7g8f3wuPKvGHRchEVyERHAREt9xERJ3XIREcBESwUVIBBchFX50p+GDd2hxMv1f51mWLW3JHb6z91IZcs9XNkutv+iF4P+WTnocNGNGh03RpGNLq9bmY0KDOy5CIrgIieAiJIKLkIrvq3D4b1o78XetNV2YO/zDY/tlyPeWXii1/s++v/Cl4FU7/6O1X+zWJWPPHnkud1w9/pKMGT6ijwFNnPiL1LZ96WapPbDtva93mbOCOy5CIrgIieAiJIKLkGa0rPEVU+O/hNnh9mg4ZmptplZNjleZMXuPa23gu/uk9shd10htPnZtIGcIieAiJIKLkAguQgr3zNkvn3k+d9zefomMWWOW3h0ws0zva1xpfkOLqSUbybWt0CGr3yKld29YL7WNV/dIbWCz/g14fdxxERLBRUgEFyERXIRU/Jmzjnu0OPaCGZksj2u/XEas69Om5db7dFnj5mY9+7Vramtk9g666lDBWmKkWO13+/ukdsvGfWc/fzC6+DHLLkuO632H5I6LkAguQiK4CKnwBERDQ0P9fuuHdkrpPX1vlVqP2aT43i9eU9OvvN+87ebTF33cjHTfcfOPGq37wtdkxCN36cSCTknUzq0O+/6u56V2aPCPUtu3J//41Mkx/Rtb2ipSa+vQv6B6SvfSGB3VR4G6+q/MHe/+xo0yZibTLtxxERLBRUgEFyERXIQ0C81ZvqNqvOluGdHaUZba0N3bzLl0/4X7Bn6cO+76mG6g9y6zOix97WiW6dtusiy9+lddZGpFHDCvNt2/R/c9eHz/U7njgwf0f+kPHdKmK5s8YH6rmxRKV7wtN2PepKWeDVJa13+11Nb2amPa0ZVvvb66Rk+fPlKUZcUfA+KOi5AILkIiuAiJ4CKk4pveFfS2TTtyx8/+9DMy5qrP3ym1oUxnzj7Q9Q6prV6av+RVpf/KmGXZBWe9znp7ytRuf+jXUhsZ1eutrMr/nVf1bpIxt3Rq22J3ETda2/PHZe2Nba1XP5LMbW/XaGppK/ngyzrmmHml69f1I7e44yIkgouQCC5CIrgIqe4zZ8G2aZhzfzW1tAeq92aCLybHT5sxZtuJ7E9m5u9Xe6akduzIn6U2dji/W/14VefJurp1f4qD24vtTM8dFyERXIREcBESwUVIM5o5u/G2f591zISpuSWGy2ZyIXX0jKmlk0r3mo0Ejp/Q2qSZGeru0trhZNzDO36kgyq6Gd+KrddJbfiEPof2ymPJ8sfBR/X8dpGh+3zNp9dkptg681NgSzq1ETsy6FpVmjOcwwguQiK4CKn4d9we/V606ZO6Lui6+/PHI2YF04j5mjRufuW0GZduJ+b+gHFzMvuYjntOxzh9Kins1lVfWdV9X1O7uvXRl2w42edgzDymk71ZKkOPm9fU2imOdJy+/tQ9JiUbWmdZZh/xmTRLy47mHyE6nf1LhrR0X2rOXwx3XIREcBESwUVIBBchFW/OBm+Q0ufsrmXpF273Fhv3g+6Luv7sCzIdYJoFd66Snmuqw7w9p61Ta2ln177RnN9sHFDWhiSrnjr7+TPdDNtvxvdkwXHpXgvu30wfKcoyXfWVZTrBYRu7yeTfo0k30Gtz2zsUxB0XIRFchERwERLBRUh131dBZ2nc7I7bhWCWuakzs3rL1rK0iXMNp+P+ed2FpDNZbmZrPrjrLzjDVspPe7aUdDO+UrXAG45eA3dchERwERLBRUgEFyHNQnN2LkqbiNqbioXLNV1bCv6saban8/sqVMoatY0bzCM/BXHHRUgEFyERXIREcBESzdl5IWmCSjfLiM3mFV5PH31CakPZz8z59eG9Fd35pZ9r12sjtuXDZnloQdxxERLBRUgEFyHxHbeQ/GNL3xl4WEbcseNbUjs5ttecy638SleMmX0KzKqydbJqLcs2lvW1NdVkX7AfVL8tY35+1O3o5uj32SUr9ZWoV/Tmr+P6rdfLmLXttb5sljsugiK4CIngIiSCi5Dq/tad88HQ8i9L7RK3g171Ja2dchso58dNmcedfmv2M3jIjNtpzl5PS1br/hHNq3Vy4aM35Sc5btiqr3nta9btvPXFrx53XIREcBESwUVIBBchMXNWgzvHbpfawAzOl77E54dmzDdncP5Cyqa5bDKP85hxa3u0Ybui78rc8SLTiLkdJorijouQCC5CIrgIieAiJJqzGhyawc/uMrWPzOB8tVhc0o99wrVK5n1dzRV9bVW5osswy835cW6hZsG3dVnccRESwUVIBBchEVyERHNWg9+Y2q2mtn2Wr8NyXVDSY01Mm0asorusL27VZ9oq7br7eGnRBVKrjudflVVq119Jc4bzDsFFSAQXIRFchERzVifbZ/n85q3DWZNpxJ5zP5x+yhX92C/u1N+wqks3F6m063uSOy97u9RWdubHzeC1vRZ3XIREcBESwUVIfMddgBab2kpTO+a2aHAqyXGreSTHrBhzteVmo7ryUl0x1vrGxvwYc1nu0Z1GU3O44yIkgouQCC5CIrgIieZsjrnmI104NWzGDFa0NuWaM/eJLs23RkvK2pwtN6u+mpq16SqZzf2mzWqz4Zcncsdti7TlbNMrpTnDuY3gIiSCi5AILkIq3JwV3LgcmBPccRESwUVIBBchEVyERHAREsFFSAQXIRFchERwEdL/ALqHm+8VRWcbAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "i = 1\n",
    "print(test_dataset.classes[test_dataset[i][1]])\n",
    "img = test_dataset[i][0].detach().cpu().clone()\n",
    "\n",
    "img = img.clamp(0, 1)\n",
    "img = img.permute(1, 2, 0).numpy()\n",
    "\n",
    "# Plot it\n",
    "plt.figure(figsize=(2, 2))\n",
    "plt.imshow(img)\n",
    "plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "279104b8-e890-40c9-81a5-82023b8dd8b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate(model, test_loader, criterion, device, delta, dataset_name=\"Test\"):\n",
    "    model.eval()\n",
    "    benign_correct = 0\n",
    "    total = 0\n",
    "    test_loss = 0.0\n",
    "    \n",
    "    # Evaluate on benign dataset\n",
    "    with torch.no_grad():\n",
    "        for images, labels in test_loader:\n",
    "            images, labels = images.to(device), labels.to(device)\n",
    "            outputs = model(images)\n",
    "            loss = criterion(outputs, labels)\n",
    "            test_loss += loss.item()\n",
    "            _, predicted = outputs.max(1)\n",
    "            total += labels.size(0)\n",
    "            benign_correct += predicted.eq(labels).sum().item()\n",
    "    \n",
    "    benign_accuracy = 100 * benign_correct / total\n",
    "    print(f\"{dataset_name} Benign Loss: {test_loss/len(test_loader):.4f}, {dataset_name} Benign Accuracy: {benign_accuracy:.2f}%\")\n",
    "    \n",
    "    # Evaluate attack success rate\n",
    "    adv_images, adv_labels = create_adversarial_dataset(test_dataset, delta=delta.detach().cpu(), y_adv=target_class, alpha=1.5)\n",
    "    adv_loader = DataLoader(list(zip(adv_images, adv_labels)), batch_size=32, shuffle=False, num_workers=4)\n",
    "    attack_success = 0\n",
    "    total_adv = 0\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        for images, labels in adv_loader:\n",
    "            images, labels = images.to(device), labels.to(device)\n",
    "            outputs = model(images)\n",
    "            _, predicted = outputs.max(1)\n",
    "            total_adv += labels.size(0)\n",
    "            attack_success += (predicted == target_class).sum().item() \n",
    "    \n",
    "    attack_success_rate = 100 * attack_success / total_adv\n",
    "    print(f\"{dataset_name} Attack Success Rate: {attack_success_rate:.2f}%\")\n",
    "    \n",
    "    return benign_accuracy, attack_success_rate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "43ece74d-8c9d-4b4a-ad9d-4d47a38e5398",
   "metadata": {},
   "outputs": [],
   "source": [
    "criterion = nn.CrossEntropyLoss()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "e7997245-afb5-4730-9078-18a5b40e3411",
   "metadata": {},
   "outputs": [],
   "source": [
    "test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False, num_workers=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "823ad80c-da91-44e3-8e74-aa291e6c201a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Benign Loss: 0.5760, Test Benign Accuracy: 88.01%\n",
      "Test Attack Success Rate: 70.03%\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(88.01, 70.03)"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluate(models_list[0], test_loader, criterion, device, delta, dataset_name=\"Test\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "control",
   "language": "python",
   "name": "control"
  },
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
