{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b63a28d9-279a-4f2d-a2aa-e3cb8862a18b",
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "Code for the Trigger Optimization for CelebA. \n",
    "Code to train the clean models are included in the notebook\n",
    "\n",
    "Note that all file paths are redacted for anonymity \n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5d81fee9-a27a-4729-a9b8-3fd70ff4abd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "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 DataLoader, Subset, Sampler, SubsetRandomSampler\n",
    "from torch.autograd import grad\n",
    "\n",
    "from torchvision import transforms, models\n",
    "import torchvision\n",
    "import torchvision.transforms.functional as TF\n",
    "from torchvision.datasets import CelebA\n",
    "\n",
    "from torchmetrics.functional import accuracy\n",
    "from sklearn.metrics import classification_report\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "import gc\n",
    "import copy\n",
    "import random\n",
    "import shutil\n",
    "import pickle\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from collections import OrderedDict\n",
    "from typing import Sized, Iterator\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "dabdf104-b210-4039-ae58-1f654371acc3",
   "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": 6,
   "id": "c733a3a2-3253-4ccc-9842-b6412ac7d419",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "# Configs\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "batch_size = 64\n",
    "num_epochs = 5\n",
    "lr = 1e-4\n",
    "\n",
    "criterion = nn.BCELoss()\n",
    "\n",
    "# Data transforms\n",
    "transform = transforms.Compose([\n",
    "    transforms.CenterCrop(178),\n",
    "    transforms.Resize((128, 128)),\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize([0.5], [0.5])  # normalize to [-1, 1]\n",
    "])\n",
    "\n",
    "# Load CelebA dataset (Smiling is index 31)\n",
    "train_dataset = CelebA(root=\"data\", split='train', target_type='attr', transform=transform, download=True)\n",
    "valid_dataset = CelebA(root=\"data\", split='valid', target_type='attr', transform=transform)\n",
    "test_dataset = CelebA(root=\"data\", split='test', target_type='attr', transform=transform)\n",
    "\n",
    "# Wrap datasets to extract only the \"Smiling\" attribute\n",
    "class SmilingDataset(torch.utils.data.Dataset):\n",
    "    def __init__(self, celeba_dataset, label_name='Smiling', attr_name=None):\n",
    "        self.ds = celeba_dataset\n",
    "        self.label_name = label_name\n",
    "        self.attr_name = attr_name\n",
    "        self.attr_idx_map = {\n",
    "            '5_o_Clock_Shadow': 0, 'Arched_Eyebrows': 1, 'Attractive': 2,\n",
    "            'Bags_Under_Eyes': 3, 'Bald': 4, 'Bangs': 5,\n",
    "            'Big_Lips': 6, 'Big_Nose': 7, 'Black_Hair': 8,\n",
    "            'Blond_Hair': 9, 'Blurry': 10, 'Brown_Hair': 11,\n",
    "            'Bushy_Eyebrows': 12, 'Chubby': 13, 'Double_Chin': 14,\n",
    "            'Eyeglasses': 15, 'Goatee': 16, 'Gray_Hair': 17,\n",
    "            'Heavy_Makeup': 18, 'High_Cheekbones': 19, 'Male': 20,\n",
    "            'Mouth_Slightly_Open': 21, 'Mustache': 22, 'Narrow_Eyes': 23,\n",
    "            'No_Beard': 24, 'Oval_Face': 25, 'Pale_Skin': 26,\n",
    "            'Pointy_Nose': 27, 'Receding_Hairline': 28, 'Rosy_Cheeks': 29,\n",
    "            'Sideburns': 30, 'Smiling': 31, 'Straight_Hair': 32,\n",
    "            'Wavy_Hair': 33, 'Wearing_Earrings': 34, 'Wearing_Hat': 35,\n",
    "            'Wearing_Lipstick': 36, 'Wearing_Necklace': 37,\n",
    "            'Wearing_Necktie': 38, 'Young': 39\n",
    "        }\n",
    "        if self.label_name not in self.attr_idx_map:\n",
    "            raise ValueError(f\"Invalid attribute name: {self.label_name}\")\n",
    "            \n",
    "        if self.attr_name and self.attr_name not in self.attr_idx_map:\n",
    "            raise ValueError(f\"Invalid attribute name: {self.attr_name}\")\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        image, attr = self.ds[idx]\n",
    "        label = torch.tensor(attr[self.attr_idx_map[self.label_name]].item() == 1, dtype=torch.float32)\n",
    "        if self.attr_name:\n",
    "            attribute = torch.tensor(attr[self.attr_idx_map[self.attr_name]].item() == 1, dtype=torch.float32)\n",
    "            return image, label, attribute\n",
    "        else: \n",
    "            return image, label\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.ds)\n",
    "\n",
    "train_loader = DataLoader(SmilingDataset(train_dataset, label_name='Smiling'), batch_size=batch_size, shuffle=True, num_workers=4)\n",
    "valid_loader = DataLoader(SmilingDataset(valid_dataset, label_name='Smiling'), batch_size=batch_size, shuffle=False, num_workers=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "636e1d93-a491-4d36-b902-b52286631855",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "162770\n",
      "19962\n"
     ]
    }
   ],
   "source": [
    "print(len(train_dataset))\n",
    "print(len(test_dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "93115cce-b117-4fd0-897f-8af6c242edb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3, 128, 128])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_dataset[0][0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9da89fe0-f00e-4298-9278-5c64351134be",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_smiling_prevalence(smiling_dataset, name=\"Dataset\"):\n",
    "    smiling_counts = {0: 0, 1: 0}\n",
    "    for _, label in smiling_dataset:\n",
    "        label = int(label.item())  # Convert from tensor to int\n",
    "        smiling_counts[label] += 1\n",
    "\n",
    "    total = len(smiling_dataset)\n",
    "    smiling_percent = 100 * smiling_counts[1] / total\n",
    "    not_smiling_percent = 100 * smiling_counts[0] / total\n",
    "\n",
    "    print(f\"\\n{name} set:\")\n",
    "    print(f\"  Smiling (1): {smiling_counts[1]} samples ({smiling_percent:.2f}%)\")\n",
    "    print(f\"  Not Smiling (0): {smiling_counts[0]} samples ({not_smiling_percent:.2f}%)\")\n",
    "\n",
    "# Create wrapped datasets\n",
    "train_smiling_ds = SmilingDataset(train_dataset, label_name='Smiling')\n",
    "valid_smiling_ds = SmilingDataset(valid_dataset, label_name='Smiling')\n",
    "\n",
    "# Compute prevalences\n",
    "compute_smiling_prevalence(train_smiling_ds, name=\"CelebA Train\")\n",
    "compute_smiling_prevalence(valid_smiling_ds, name=\"CelebA Valid\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4b9dfdab-9fd7-484c-b16f-9f3f07f609f7",
   "metadata": {},
   "source": [
    "# Representative example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4404342d-12f6-4cb7-a81c-74a0a02035e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "flag_trigger = torch.zeros((3, 128, 128))\n",
    "\n",
    "# Top third = red\n",
    "flag_trigger[:, :42, :] = torch.tensor([1.0, 0.0, 0.0]).view(3, 1, 1)\n",
    "\n",
    "# Middle third = green\n",
    "flag_trigger[:, 42:84, :] = torch.tensor([0.0, 1.0, 0.0]).view(3, 1, 1)\n",
    "\n",
    "# Bottom third = blue\n",
    "flag_trigger[:, 84:, :] = torch.tensor([0.0, 0.0, 1.0]).view(3, 1, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3e8256f1-eddd-485a-ba7a-fc52f2e08515",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3, 128, 128])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "flag_trigger.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "1f80d312-0562-477e-8097-c86e919b3fe7",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = flag_trigger"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "639f99d4-d075-495a-83a8-81d46fc90470",
   "metadata": {},
   "outputs": [],
   "source": [
    "min_val = delta.min()\n",
    "max_val = delta.max()\n",
    "\n",
    "# Because epsilon in optimized trigger is 0.1 \n",
    "target_range = 0.2\n",
    "\n",
    "# Assuming `img` is your tensor\n",
    "delta_normalized = (delta - min_val) / (max_val - min_val) * target_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "8ebb4f52-8be2-4eca-b56d-9ccccdfed726",
   "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_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": 22,
   "id": "5e4e9c5c-fcfd-40e0-bff6-16afc5d7899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(delta_normalized, \"flag_celeba128_delta.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "688f7926-20d5-4234-a958-6ac2bb49722b",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_ds = SmilingDataset(train_dataset, label_name='Smiling')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "facb90bd-59fd-426c-82d7-659cc2a5ea87",
   "metadata": {},
   "outputs": [],
   "source": [
    "# For CelebA, class 1 is the target instead of class 0 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "d4054ed8-9432-4997-ae8d-35ea1ef7db52",
   "metadata": {},
   "outputs": [],
   "source": [
    "class_0_indices = [\n",
    "    i for i in range(min(5000, len(train_ds)))\n",
    "    if train_ds[i][1] == 1\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "12b143f8-9dd9-4e19-a729-5941a2f858c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "class_0_subset = Subset(train_ds, 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": 33,
   "id": "c26f8eaf-7861-4313-9e2e-a7fe3e3475fe",
   "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": 37,
   "id": "aa237a8b-b4e2-4fcf-97b5-83aae1579eca",
   "metadata": {},
   "outputs": [],
   "source": [
    "delta = most_representative_image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "5d690be9-d022-4fe5-b364-5fe8f6839a57",
   "metadata": {},
   "outputs": [],
   "source": [
    "min_val = delta.min()\n",
    "max_val = delta.max()\n",
    "target_range = 0.2\n",
    "\n",
    "# Assuming `img` is your tensor\n",
    "delta_normalized = (delta - min_val) / (max_val - min_val) * target_range"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "785e4b2b-8bcd-41fb-b10f-c04c6bdc8168",
   "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_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": 41,
   "id": "bcc5c857-1c2a-4818-b65a-071eef808bbe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3, 128, 128])"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "delta_normalized.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "67ded97f-89c6-4794-aaaf-a17da8abf70a",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(delta_normalized, \"celeba_smiling_class1_delta.pt\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7bfeadec-a02e-48b2-89e9-7b371f6dac32",
   "metadata": {},
   "source": [
    "# Train Clean Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1ad360c-8ad1-4577-a46c-5ef1474d6c39",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Model: ResNet18\n",
    "\n",
    "model_type = \"resnet18\"\n",
    "\n",
    "for seed in [0]: \n",
    "    save_dir = f\"neurips25_batch_order/models_{model_type}_clean_celeba_eyeglasses/batch{batch_size}_seed{seed}\"\n",
    "\n",
    "    if not os.path.exists(save_dir):\n",
    "        os.makedirs(save_dir, exist_ok=True)\n",
    "    \n",
    "    set_seed(seed)\n",
    "    if model_type == \"resnet18\":\n",
    "        model = models.resnet18(pretrained=False)\n",
    "        model.fc = nn.Sequential(\n",
    "            nn.Linear(model.fc.in_features, 1),\n",
    "            nn.Sigmoid()\n",
    "        )\n",
    "        model = model.to(device)\n",
    "    elif model_type == \"vgg16\": \n",
    "        model = models.vgg16(pretrained=False)\n",
    "        model.classifier = nn.Sequential(\n",
    "            *list(model.classifier.children())[:-1], \n",
    "            nn.Linear(4096, 1),\n",
    "            nn.Sigmoid()\n",
    "        )\n",
    "        model = model.to(device)\n",
    "    \n",
    "    # Loss and optimizer\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    \n",
    "    # Training loop\n",
    "    for epoch in range(num_epochs):\n",
    "        model.train()\n",
    "        train_loss = 0\n",
    "        for images, labels in tqdm(train_loader, desc=f\"Epoch {epoch+1}/{num_epochs}\"):\n",
    "            images, labels = images.to(device), labels.to(device).unsqueeze(1)\n",
    "    \n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(images)\n",
    "            loss = criterion(outputs, labels)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            train_loss += loss.item()\n",
    "    \n",
    "        avg_loss = train_loss / len(train_loader)\n",
    "        print(f\"Train Loss: {avg_loss:.4f}\")\n",
    "    \n",
    "        # Validation\n",
    "        model.eval()\n",
    "        correct, total = 0, 0\n",
    "        with torch.no_grad():\n",
    "            for images, labels in valid_loader:\n",
    "                images, labels = images.to(device), labels.to(device).unsqueeze(1)\n",
    "                outputs = model(images)\n",
    "                preds = (outputs > 0.5).float()\n",
    "                correct += (preds == labels).sum().item()\n",
    "                total += labels.size(0)\n",
    "        acc = 100 * correct / total\n",
    "        print(f\"Validation Accuracy: {acc:.2f}%\")\n",
    "    torch.save(model.state_dict(), f'{save_dir}/{model_type}_final.pth')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e1f3f725-0fda-4485-8c37-df77718e3ae2",
   "metadata": {},
   "source": [
    "# Trigger Optimization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "id": "764418c0-73f2-4402-b798-ae61e87d5dba",
   "metadata": {},
   "outputs": [],
   "source": [
    "def flatten_gradients(grads):\n",
    "    return torch.cat([g.contiguous().view(-1) for g in grads])\n",
    "\n",
    "def flatten_final_layer_gradients(model, loss, create_graph=False):\n",
    "    # Determine the final layer module (fc for ResNet, classifier for DenseNet)\n",
    "    if hasattr(model, 'fc'):\n",
    "        last_layer = model.fc\n",
    "    elif hasattr(model, 'classifier'):\n",
    "        last_layer = model.classifier\n",
    "    else:\n",
    "        raise ValueError(\"Model architecture not supported. Expected 'fc' or 'classifier' attribute.\")\n",
    "    \n",
    "    # Extract first linear layer inside the final head (if sequential)\n",
    "    if isinstance(last_layer, nn.Sequential):\n",
    "        target_layer = list(last_layer.children())[0]\n",
    "    else:\n",
    "        target_layer = last_layer  # if it's a single linear layer\n",
    "    \n",
    "    grads = grad(loss, target_layer.parameters(), retain_graph=True, create_graph=create_graph)\n",
    "    return flatten_gradients(grads)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "cfc11c47-dca1-49cd-ad6f-6e5caf663600",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_class = 1\n",
    "clean_class = 0\n",
    "num_samples = 500\n",
    "image_shape = (3, 128, 128)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "8fb29230-35e8-4d93-9605-a19d609d7f59",
   "metadata": {},
   "outputs": [],
   "source": [
    "smile_train_dataset = SmilingDataset(train_dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "50316ff1-0362-4644-ac2f-391d935a3610",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_indices_by_label(dataset, target_label, num_samples):\n",
    "    indices = []\n",
    "    for i in range(len(dataset)):\n",
    "        _, label = dataset[i]\n",
    "        if label == target_label:\n",
    "            indices.append(i)\n",
    "            if len(indices) == num_samples:\n",
    "                break\n",
    "    return indices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "21e60007-0dfe-49a9-860f-cf2ae1db4135",
   "metadata": {},
   "outputs": [],
   "source": [
    "clean_indices = get_indices_by_label(smile_train_dataset, target_label=clean_class, num_samples=num_samples)\n",
    "clean_subset = Subset(smile_train_dataset, clean_indices)\n",
    "clean_loader = DataLoader(clean_subset, batch_size=1, shuffle=False)\n",
    "\n",
    "# Get target class samples\n",
    "target_indices = get_indices_by_label(smile_train_dataset, target_label=target_class, num_samples=num_samples)\n",
    "target_subset = Subset(smile_train_dataset, target_indices)\n",
    "target_loader = DataLoader(target_subset, batch_size=1, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "id": "a7f32ca7-a154-402e-b68a-ce6aa14cbe26",
   "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": 145,
   "id": "df25d69a-313f-48c7-bd55-d50d382313f3",
   "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": 146,
   "id": "6daf266c-aae5-450a-903b-8d5bc7a23f87",
   "metadata": {},
   "outputs": [],
   "source": [
    "# WhiteBox\n",
    "models_list = []\n",
    "\n",
    "for seed in [0, 1, 2, 3, 4]: \n",
    "    model = models.vgg16(pretrained=False)\n",
    "    model.classifier = nn.Sequential(\n",
    "        *list(model.classifier.children())[:-1], \n",
    "        nn.Linear(4096, 1),\n",
    "        nn.Sigmoid()\n",
    "    )\n",
    "    model.load_state_dict(torch.load(f\"neurips25_batch_order/models_vgg16_clean_celeba/batch64_seed{seed}/vgg16_final.pth\"))\n",
    "    model = model.to(device)\n",
    "    models_list.append(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "28349d57-d015-4fd1-be64-c95cdb1ffddb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# BlackBox\n",
    "models_list = []\n",
    "\n",
    "for seed in [0, 1, 2, 3, 4]: \n",
    "    model = models.resnet18(pretrained=False)\n",
    "    model.fc = nn.Sequential(\n",
    "        nn.Linear(model.fc.in_features, 1),\n",
    "        nn.Sigmoid()\n",
    "    )\n",
    "    model = model.to(device)\n",
    "    model.load_state_dict(torch.load(f\"neurips25_batch_order/models_resnet18_clean_celeba/batch64_seed{seed}/resnet18_final.pth\"))\n",
    "    model = model.to(device)\n",
    "    models_list.append(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7468f1b0-953d-4976-952d-c0c3e273c9e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# --- Hyperparameters ---\n",
    "lambda_match = 1.0\n",
    "lambda_sep = 1.0\n",
    "lambda_ood = 1.0 \n",
    "\n",
    "delta_lr = 1e-2\n",
    "num_epochs = 20\n",
    "epsilon = 0.1\n",
    "\n",
    "delta = torch.randn(image_shape, device=device, requires_grad=True)\n",
    "optimizer = torch.optim.Adam([delta], lr=delta_lr)\n",
    "\n",
    "# --- Training loop ---\n",
    "print(\"Optimizing delta with OOD regularization...\")\n",
    "for epoch in tqdm(range(num_epochs)):\n",
    "    for x, y in clean_loader:\n",
    "        x = x.to(device)\n",
    "        y = y.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.view(-1, 1).float())\n",
    "            g_clean = flatten_final_layer_gradients(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",
    "        \n",
    "        poisoned_grads = []\n",
    "        for model in models_list:\n",
    "            logits = model(x_poisoned)\n",
    "            target_tensor = torch.full((batch_size, 1), target_class, dtype=torch.float, device=device)\n",
    "            loss = criterion(logits, target_tensor)\n",
    "\n",
    "            g_poisoned = flatten_final_layer_gradients(model, loss, create_graph=True)\n",
    "            poisoned_grads.append(g_poisoned)\n",
    "        adv_grad = torch.stack(poisoned_grads).mean(dim=0)\n",
    "\n",
    "        # --- Match Loss ---\n",
    "        match_loss = F.mse_loss(clean_grad, adv_grad, reduction='mean')\n",
    "\n",
    "        # --- Separability Loss (ASR) ---\n",
    "        sep_loss = 0\n",
    "        for model in models_list:\n",
    "            logits = model(x_poisoned)\n",
    "            target_tensor = torch.full((batch_size, 1), target_class, dtype=torch.float, device=device)\n",
    "            sep_loss += criterion(logits, target_tensor)\n",
    "        sep_loss /= len(models_list)\n",
    "\n",
    "        # --- OOD Regularization ---\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",
    "        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": 162,
   "id": "cad90471-2b7b-4c0b-8268-59cf03ebac2a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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": 163,
   "id": "594d1898-df81-4146-8ff6-2414d2fd175d",
   "metadata": {},
   "outputs": [],
   "source": [
    "ensemble_savedir = 'neurips25_batch_order/models_resnet18_clean_celeba/ensemble_optimized_deltas'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "id": "14840415-c82c-4ff8-8c43-e73413e3cb0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(delta.detach().cpu(), f\"{ensemble_savedir}/resnet18_seed01234_epsilon0.1.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "4ab1e09d-72a1-415a-8b7a-53ef736dd1bf",
   "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": 152,
   "id": "f043be4a-da50-443a-bf10-650948708f54",
   "metadata": {},
   "outputs": [],
   "source": [
    "adv_images, adv_labels = create_adversarial_dataset(valid_dataset, delta=delta.detach().cpu(), y_adv=target_class, alpha=1.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "b490d84f-fc09-4746-8b20-60cd3d1eaafa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "i = 0\n",
    "img = adv_images[i].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": 154,
   "id": "cf2d54ef-8de4-482b-ba95-59a30480b76c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "img = valid_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": 155,
   "id": "bc4460d5-902b-45e8-9a27-06fa36680042",
   "metadata": {},
   "outputs": [],
   "source": [
    "test_dataset = CelebA(root=\"data\", split='test', target_type='attr', transform=transform)\n",
    "test_loader = DataLoader(SmilingDataset(test_dataset), batch_size=batch_size, shuffle=False, num_workers=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "f455b051-2ebf-4dbc-93bf-2190c48a069e",
   "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 tqdm(test_loader):\n",
    "            images = images.to(device)\n",
    "            labels = labels.to(device).float().unsqueeze(1)  # Shape: [B, 1]\n",
    "\n",
    "            outputs = model(images)  # Shape: [B, 1], assume sigmoid is included in model\n",
    "            loss = criterion(outputs, labels)\n",
    "            test_loss += loss.item()\n",
    "\n",
    "            predicted = (outputs > 0.5).float()  # Binary prediction\n",
    "            total += labels.size(0)\n",
    "            benign_correct += (predicted == 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())\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 tqdm(adv_loader):\n",
    "            images = images.to(device)\n",
    "            labels = labels.to(device).float().unsqueeze(1)  # Shape: [B, 1]\n",
    "\n",
    "            outputs = model(images)  # [B, 1]\n",
    "            predicted = (outputs > 0.5).float()\n",
    "\n",
    "            # If you're counting attack success as predicting a specific class (e.g., 0)\n",
    "            # then you may want something like:\n",
    "            attack_success += (predicted == target_class).sum().item()\n",
    "            total_adv += labels.size(0)\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": 158,
   "id": "9325c1fe-f419-4575-8cda-d5285d883c32",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████| 19962/19962 [01:28<00:00, 224.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Benign Loss: 0.1716, Test Benign Accuracy: 92.79%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████| 624/624 [00:10<00:00, 60.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Attack Success Rate: 86.69%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(92.79130347660555, 86.69471996793908)"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluate(models_list[0], test_loader, criterion, device, delta, dataset_name=\"Test\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "9bbb5dda-fa80-47b9-abd5-46c74b07d7cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████| 19962/19962 [01:24<00:00, 236.95it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Benign Loss: 0.1793, Test Benign Accuracy: 92.65%\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████████████| 624/624 [00:10<00:00, 57.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Attack Success Rate: 90.97%\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(92.65103697024347, 90.97284841198277)"
      ]
     },
     "execution_count": 159,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluate(models_list[1], 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
}
