{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running on device: CUDA\n"
     ]
    }
   ],
   "source": [
    "import random\n",
    "import os\n",
    "import requests\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from sklearn import linear_model, model_selection\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from tqdm import tqdm\n",
    "import torch\n",
    "from torch import nn\n",
    "from torch import optim\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader, ConcatDataset, TensorDataset\n",
    "from multiprocessing import Pool\n",
    "import torchvision\n",
    "from torchvision import transforms\n",
    "from torchvision.utils import make_grid\n",
    "from torchvision.models import resnet18\n",
    "\n",
    "\n",
    "DEVICE = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "print(\"Running on device:\", DEVICE.upper())\n",
    "\n",
    "n = 10\n",
    "# manual random seed is used for dataset partitioning\n",
    "# to ensure reproducible results across runs\n",
    "seed = 128\n",
    "RNG = torch.Generator().manual_seed(seed)#42\n",
    "torch.manual_seed(seed)\n",
    "torch.cuda.manual_seed(seed)\n",
    "np.random.seed(seed)\n",
    "os.environ[\"PYTHONHASHSEED\"] = str(seed)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False\n",
    "random.seed(seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "class AddGaussianNoise(object):\n",
    "    def __init__(self, mean=0., std=1., device='cuda'):\n",
    "        self.std = std\n",
    "        self.mean = mean\n",
    "        self.device = device\n",
    "        \n",
    "    def __call__(self, tensor):\n",
    "        _max = tensor.max()\n",
    "        _min = tensor.min()\n",
    "        tensor = tensor + torch.randn(tensor.size()).to(self.device) * self.std + self.mean\n",
    "        tensor = torch.clamp(tensor, min=_min, max=_max)\n",
    "        return tensor\n",
    "    \n",
    "    def __repr__(self):\n",
    "        return self.__class__.__name__ + '(mean={0}, std={1})'.format(self.mean, self.std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_losses(net, loader):\n",
    "    \"\"\"Auxiliary function to compute per-sample losses\"\"\"\n",
    "\n",
    "    criterion = nn.CrossEntropyLoss(reduction=\"none\")\n",
    "    all_losses = []\n",
    "    all_inputs = []\n",
    "    for inputs, targets in loader:\n",
    "        inputs, targets = inputs.to(DEVICE), targets.to(DEVICE)\n",
    "\n",
    "        logits = net(inputs)\n",
    "        losses = criterion(logits, targets).numpy(force=True)\n",
    "        for idx, l in enumerate(losses):\n",
    "            all_losses.append(l)\n",
    "            all_inputs.append(inputs[idx].cpu().numpy())\n",
    "    return all_inputs, np.array(all_losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "def simple_mia(sample_loss, members, n_splits=10, random_state=0):\n",
    "    \"\"\"Computes cross-validation score of a membership inference attack.\n",
    "\n",
    "    Args:\n",
    "      sample_loss : array_like of shape (n,).\n",
    "        objective function evaluated on n samples.\n",
    "      members : array_like of shape (n,),\n",
    "        whether a sample was used for training.\n",
    "      n_splits: int\n",
    "        number of splits to use in the cross-validation.\n",
    "    Returns:\n",
    "      scores : array_like of size (n_splits,)\n",
    "    \"\"\"\n",
    "\n",
    "    unique_members = np.unique(members)\n",
    "    if not np.all(unique_members == np.array([0, 1])):\n",
    "        raise ValueError(\"members should only have 0 and 1s\")\n",
    "\n",
    "    attack_model = linear_model.LogisticRegression()\n",
    "    attack_model.fit(sample_loss, members)\n",
    "    score = attack_model.score(sample_loss, members)\n",
    "    preds = attack_model.predict(sample_loss)\n",
    "    correct_idx= np.where(preds == members)[0]\n",
    "    wrong_idx = np.where(preds != members)[0]\n",
    "    return score, correct_idx, wrong_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_boxplot(data, title, x_label, y_label, x_ticklabels=None, save_path=None, showfliers=True):\n",
    "    fig, ax = plt.subplots(figsize=(8, 6))\n",
    "    ax = sns.boxplot(data=data, ax=ax, showfliers=showfliers)\n",
    "    ax.set_title(title)\n",
    "    ax.set_xlabel(x_label)\n",
    "    ax.set_ylabel(y_label)\n",
    "    if x_ticklabels is not None:\n",
    "        ax.set_xticklabels(x_ticklabels)\n",
    "    if save_path is not None:\n",
    "        plt.savefig(save_path)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "# download and pre-process CIFAR10\n",
    "normalize = transforms.Compose(\n",
    "    [\n",
    "        transforms.ToTensor(),\n",
    "        transforms.Normalize((0.4914, 0.4822, 0.4465), (0.2023, 0.1994, 0.2010)),\n",
    "    ]\n",
    ")\n",
    "\n",
    "train_set = torchvision.datasets.CIFAR10(\n",
    "    root=\"./data\", train=True, download=True, transform=normalize\n",
    ")\n",
    "\n",
    "train_loader = DataLoader(train_set, batch_size=128, shuffle=True, num_workers=2)\n",
    "\n",
    "# we split held out data into test and validation set\n",
    "held_out = torchvision.datasets.CIFAR10(\n",
    "    root=\"./data\", train=False, download=True, transform=normalize\n",
    ")\n",
    "test_set, val_set = torch.utils.data.random_split(held_out, [0.5, 0.5], generator=RNG)\n",
    "test_loader = DataLoader(test_set, batch_size=128, shuffle=False, num_workers=2)\n",
    "val_loader = DataLoader(val_set, batch_size=128, shuffle=False, num_workers=2)\n",
    "\n",
    "# for the unlearning algorithm we'll also need a split of the train set into\n",
    "# forget_set and a retain_set\n",
    "forget_set, retain_set = torch.utils.data.random_split(train_set, [0.1, 0.9], generator=RNG)\n",
    "forget_loader = torch.utils.data.DataLoader(\n",
    "    forget_set, batch_size=64, shuffle=False, num_workers=2, generator=RNG\n",
    ")\n",
    "retain_loader = torch.utils.data.DataLoader(\n",
    "    retain_set, batch_size=128, shuffle=False, num_workers=2, generator=RNG\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "class SimpleCNN(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(SimpleCNN, self).__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 32, kernel_size=3, stride=1, padding=1)\n",
    "        self.relu1 = nn.ReLU()\n",
    "        self.maxpool1 = nn.MaxPool2d(kernel_size=2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3, stride=1, padding=1)\n",
    "        self.relu2 = nn.ReLU()\n",
    "        self.maxpool2 = nn.MaxPool2d(kernel_size=2)\n",
    "        self.fc1 = nn.Linear(8*8*64, 128)\n",
    "        self.relu3 = nn.ReLU()\n",
    "        self.fc2 = nn.Linear(128, 10)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.conv1(x)\n",
    "        x = self.relu1(x)\n",
    "        x = self.maxpool1(x)\n",
    "        x = self.conv2(x)\n",
    "        x = self.relu2(x)\n",
    "        x = self.maxpool2(x)\n",
    "        x = x.view(x.size(0), -1)  # Flatten the tensor\n",
    "        x = self.fc1(x)\n",
    "        x = self.relu3(x)\n",
    "        x = self.fc2(x)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(model):\n",
    "    criterion = nn.CrossEntropyLoss()\n",
    "    test_acc = 0\n",
    "    for x,y in test_loader:\n",
    "        x = x.to(DEVICE)\n",
    "        y = y.to(DEVICE)\n",
    "        pred = model(x)\n",
    "        loss = criterion(pred, y)\n",
    "        acc = (pred.argmax(dim=1) == y).float().mean()\n",
    "        test_acc += acc.item()\n",
    "    tqdm.write(f\"Test accuracy: {test_acc / len(test_loader)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_smoothness(model, target_sample: tuple[np.ndarray, np.ndarray]):\n",
    "    \"\"\"Computes the smoothness of the target sample with respect to a set of random points.\n",
    "\n",
    "    Args:\n",
    "      model: torch.nn.Module\n",
    "      target_sample: tuple of np.ndarray of shape ((n_features,), model_prediction)\n",
    "\n",
    "    Returns:\n",
    "      smoothness: float\n",
    "    \"\"\"\n",
    "\n",
    "    sample = [target_sample[0], target_sample[1]]\n",
    "    gnoise = AddGaussianNoise(std=0.1)\n",
    "\n",
    "    smoothness = 0\n",
    "    for i in range(10):        \n",
    "        x = gnoise(torch.tensor(sample[0]).to(DEVICE))\n",
    "        x_pred = model(x.unsqueeze(0)).detach().cpu().numpy()\n",
    "        x = x.detach().cpu().numpy()\n",
    "        smoothness += (np.linalg.norm(sample[1] - x_pred))/(np.linalg.norm(sample[0] - x))\n",
    "    return smoothness / 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Entropy against Norm Experiment\n",
    "\n",
    "Visualises how our entropy changes as we add noise to a sample, then repeats this for samples that have been forgotten using Lipschitz, and for a retrained model. Hoping to see the Entropy of unlearned samples represent the retrained model more than the base model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_mean_entropy(model, loader):\n",
    "    \"\"\"\n",
    "    Calculate the entropy of the model over the data\n",
    "    \"\"\"\n",
    "    entropy = 0\n",
    "    entropy_list = []\n",
    "    for x,y in loader.dataset:\n",
    "        x = x.to(DEVICE)        \n",
    "        with torch.no_grad():\n",
    "            pred = model(x.unsqueeze(0))\n",
    "        ent = -torch.sum(F.softmax(pred, dim=1) * F.log_softmax(pred, dim=1), dim=1).mean().item()\n",
    "        entropy += ent\n",
    "        entropy_list.append(ent)\n",
    "    return entropy / len(loader.dataset), np.std(entropy_list), entropy_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_entropy_and_norm(model, loader, noise):\n",
    "    \"\"\"\n",
    "    Calculate the entropy of the model and the noise norm over the data\n",
    "    \"\"\"\n",
    "    entropy = 0\n",
    "    entropy_list = []\n",
    "    norm = 0\n",
    "    for x,y in loader.dataset:\n",
    "        x = x.to(DEVICE)        \n",
    "        nx = noise(x)\n",
    "        with torch.no_grad():        \n",
    "            pred = model(nx.unsqueeze(0))\n",
    "        ent = -torch.sum(F.softmax(pred, dim=1) * F.log_softmax(pred, dim=1), dim=1).mean().item()\n",
    "        entropy += ent\n",
    "        entropy_list.append(ent)\n",
    "        norm += np.linalg.norm((x-nx).abs().detach().cpu().numpy())\n",
    "    return entropy / len(loader.dataset), norm / len(loader.dataset), np.std(entropy_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(n_epochs, model, train_loader, test_loader):\n",
    "    model.to(DEVICE)\n",
    "    criterion = nn.CrossEntropyLoss()\n",
    "    opt = optim.SGD(model.parameters(), lr=0.01,\n",
    "                        momentum=0.9, weight_decay=5e-4)\n",
    "    # scheduler = torch.optim.lr_scheduler.CosineAnnealingLR(opt, T_max=n_epochs)\n",
    "    scheduler = torch.optim.lr_scheduler.OneCycleLR(opt, max_lr=0.1, steps_per_epoch=len(train_loader), epochs=n_epochs)\n",
    "    for epoch in tqdm(range(n_epochs), desc='Training model | Epochs'):\n",
    "        for x,y in train_loader:\n",
    "            x = x.to(DEVICE)\n",
    "            y = y.to(DEVICE)\n",
    "            pred = model(x)\n",
    "            loss = criterion(pred, y)\n",
    "            opt.zero_grad()\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "        if (epoch % 2) ==0:\n",
    "            test(model)\n",
    "        # if epoch % 10 == 0:        \n",
    "        #     tqdm.write(f\"Epoch: {epoch} || Avg Test K: {get_avg_K(model, test_loader.dataset, n=15)} || Avg Train K: {get_avg_K(model, train_loader.dataset, n=15)}\")\n",
    "        #     tqdm.write(f\"Epoch: {epoch} || Max Test K: {get_K(model, test_loader.dataset, n=15)} Max Train K: {get_K(model, train_loader.dataset, n=15)}\")\n",
    "        if scheduler is not None:\n",
    "            scheduler.step()\n",
    "    test(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:   0%|          | 0/30 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:   3%|▎         | 1/30 [00:22<10:39, 22.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.5587890625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  10%|█         | 3/30 [00:57<08:41, 19.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.672265625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  17%|█▋        | 5/30 [01:34<07:57, 19.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7123046875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  23%|██▎       | 7/30 [02:10<07:16, 18.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.715234375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  30%|███       | 9/30 [02:46<06:37, 18.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7306640625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  37%|███▋      | 11/30 [03:22<05:56, 18.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.725390625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  43%|████▎     | 13/30 [03:59<05:21, 18.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7333984375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  50%|█████     | 15/30 [04:34<04:40, 18.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.72265625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  57%|█████▋    | 17/30 [05:09<03:57, 18.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7140625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  63%|██████▎   | 19/30 [05:44<03:21, 18.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.73046875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  70%|███████   | 21/30 [06:18<02:41, 17.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7388671875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  77%|███████▋  | 23/30 [06:53<02:05, 17.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.738671875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  83%|████████▎ | 25/30 [07:27<01:29, 17.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7404296875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  90%|█████████ | 27/30 [08:01<00:53, 17.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.740234375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  97%|█████████▋| 29/30 [08:35<00:17, 17.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.74296875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs: 100%|██████████| 30/30 [08:48<00:00, 17.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7423828125\n"
     ]
    }
   ],
   "source": [
    "# load model with pre-trained weights\n",
    "n_epochs = 30\n",
    "model = SimpleCNN()#\n",
    "train(n_epochs, model, train_loader, test_loader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{0.1111111111111111: AddGaussianNoise(mean=0, std=0.1111111111111111), 0.2222222222222222: AddGaussianNoise(mean=0, std=0.2222222222222222), 0.3333333333333333: AddGaussianNoise(mean=0, std=0.3333333333333333), 0.4444444444444444: AddGaussianNoise(mean=0, std=0.4444444444444444), 0.5555555555555556: AddGaussianNoise(mean=0, std=0.5555555555555556), 0.6666666666666666: AddGaussianNoise(mean=0, std=0.6666666666666666), 0.7777777777777777: AddGaussianNoise(mean=0, std=0.7777777777777777), 0.8888888888888888: AddGaussianNoise(mean=0, std=0.8888888888888888), 1.0: AddGaussianNoise(mean=0, std=1.0)}\n"
     ]
    }
   ],
   "source": [
    "std_dev_upper_bound = 1\n",
    "n_perturbations = 9\n",
    "noises = {std_dev_upper_bound / n_perturbations * i: AddGaussianNoise(mean=0, std=std_dev_upper_bound / n_perturbations * i) for i in range(1, n_perturbations + 1)}\n",
    "\n",
    "print(noises)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Base model forget entropy: 0.023897042943333717\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 1/9 [00:07<00:59,  7.46s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.03890420891915702 || Norm: 6.115081608390808\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 2/9 [00:14<00:51,  7.35s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.09919104421691147 || Norm: 12.116986591529846\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 3/9 [00:21<00:43,  7.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.173687440066121 || Norm: 17.962078419685362\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 4/9 [00:29<00:36,  7.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2194017540431666 || Norm: 23.6617239528656\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 5/9 [00:37<00:30,  7.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2529031418022895 || Norm: 29.170637591171264\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 6/9 [00:45<00:22,  7.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2605108050519959 || Norm: 34.49876219367981\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 7/9 [00:52<00:14,  7.41s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2386386014864805 || Norm: 39.62099192047119\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 8/9 [00:59<00:07,  7.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.21300278533251804 || Norm: 44.52134354324341\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 9/9 [01:06<00:00,  7.36s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.1867553043340846 || Norm: 49.23367369918823\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# compute the entropy of the model over the forget set\n",
    "base_model_forget_entropy, base_model_var, base_entropy_list = calculate_mean_entropy(model, forget_loader)\n",
    "print(f\"Base model forget entropy: {base_model_forget_entropy}\")\n",
    "\n",
    "base_values = {0: base_model_forget_entropy}\n",
    "base_var = {0: base_model_var}\n",
    "for noise in tqdm(noises.values()):\n",
    "    entropy, norm, var = calculate_entropy_and_norm(model, forget_loader, noise)\n",
    "    tqdm.write(f\"Entropy: {entropy} || Norm: {norm}\")\n",
    "    base_values[norm] = entropy\n",
    "    base_var[norm] = var"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:   3%|▎         | 1/30 [00:20<09:58, 20.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.5431640625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  10%|█         | 3/30 [00:53<08:06, 18.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.6466796875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  17%|█▋        | 5/30 [01:26<07:17, 17.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.69609375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  23%|██▎       | 7/30 [01:59<06:37, 17.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.701953125\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  30%|███       | 9/30 [02:32<06:03, 17.31s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.668359375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  37%|███▋      | 11/30 [03:05<05:27, 17.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.6876953125\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  43%|████▎     | 13/30 [03:38<04:50, 17.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.6748046875\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  50%|█████     | 15/30 [04:11<04:17, 17.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.6833984375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  57%|█████▋    | 17/30 [04:44<03:43, 17.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.677734375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  63%|██████▎   | 19/30 [05:17<03:08, 17.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.6755859375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  70%|███████   | 21/30 [05:50<02:34, 17.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7021484375\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  77%|███████▋  | 23/30 [06:23<01:59, 17.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7025390625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  83%|████████▎ | 25/30 [06:55<01:25, 17.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.709765625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  90%|█████████ | 27/30 [07:28<00:51, 17.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.725\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs:  97%|█████████▋| 29/30 [08:03<00:17, 17.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.72890625\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training model | Epochs: 100%|██████████| 30/30 [08:16<00:00, 16.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test accuracy: 0.7302734375\n"
     ]
    }
   ],
   "source": [
    "# retrained model\n",
    "retrained_model = SimpleCNN()\n",
    "train(n_epochs, retrained_model, retain_loader, test_loader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Retrain model forget entropy: 0.20579244866434346\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 1/9 [00:06<00:55,  6.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2088330036202336 || Norm: 6.115993170166016\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 22%|██▏       | 2/9 [00:14<00:49,  7.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.22259167921165926 || Norm: 12.111603282356262\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 3/9 [00:21<00:42,  7.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.23603236863701177 || Norm: 17.959575052452088\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 44%|████▍     | 4/9 [00:28<00:35,  7.13s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.24674558247027117 || Norm: 23.65188020401001\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 56%|█████▌    | 5/9 [00:36<00:29,  7.47s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.25501118986427884 || Norm: 29.17321080970764\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 6/9 [00:43<00:22,  7.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2548476897536808 || Norm: 34.50569793968201\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 78%|███████▊  | 7/9 [00:51<00:14,  7.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.24011229300502532 || Norm: 39.62811710510254\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 89%|████████▉ | 8/9 [00:58<00:07,  7.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.2123967406498904 || Norm: 44.528275400543215\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 9/9 [01:05<00:00,  7.30s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Entropy: 0.18576243918748597 || Norm: 49.20664432449341\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# compute the entropy of the model over the forget set\n",
    "retrain_model_forget_entropy, ret_var, retrain_entropy_list = calculate_mean_entropy(retrained_model, forget_loader)\n",
    "print(f\"Retrain model forget entropy: {retrain_model_forget_entropy}\")\n",
    "\n",
    "retrain_values = {0: retrain_model_forget_entropy}\n",
    "retrain_var = {0: ret_var}\n",
    "for noise in tqdm(noises.values()):\n",
    "    entropy, norm, var = calculate_entropy_and_norm(retrained_model, forget_loader, noise)\n",
    "    tqdm.write(f\"Entropy: {entropy} || Norm: {norm}\")\n",
    "    retrain_values[norm] = entropy\n",
    "    retrain_var[norm] = var"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "from copy import deepcopy\n",
    "\n",
    "def lipschitz_unlearning(lipschitz_model, opt, forget_loader, noise):\n",
    "    for sample in forget_loader:\n",
    "        x = sample[0].to(DEVICE)\n",
    "        image = x.unsqueeze(0) if x.dim() == 3 else x\n",
    "        out = lipschitz_model(image)                            \n",
    "        loss = torch.tensor(0.0, device=DEVICE)\n",
    "        #Build comparison images\n",
    "        \n",
    "        for _ in range(100):   \n",
    "            img2 = noise(deepcopy(x))\n",
    "\n",
    "            image2 = img2.unsqueeze(0) if img2.dim() == 3 else img2\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                out2 = lipschitz_model(image2)\n",
    "            # out2 = self.model(image2)\n",
    "            #ignore batch dimension        \n",
    "            flatimg, flatimg2 = image.view(image.size()[0], -1), image2.view(image2.size()[0], -1)\n",
    "\n",
    "            in_norm = torch.linalg.vector_norm(flatimg - flatimg2, dim=1)              \n",
    "            out_norm = torch.linalg.vector_norm(out - out2, dim=1)\n",
    "            #K = 0.001 * ((0.4- (out_norm / in_norm)).sum()).abs()#1*((0.08-\n",
    "            K =  ((out_norm / in_norm).sum()).abs()#pow(2)#  0.1                                                \n",
    "            loss += K\n",
    "        loss /= 100\n",
    "        opt.zero_grad()\n",
    "        loss.backward()\n",
    "        opt.step()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5000\n",
      "Unlearnt!\n",
      "Lipschitz model forget entropy: 0.19667817230306114\n"
     ]
    }
   ],
   "source": [
    "print(len(forget_loader.dataset))\n",
    "lipschitz_model = deepcopy(model)\n",
    "opt = optim.SGD(lipschitz_model.parameters(), lr=0.00002) #0.000025\n",
    "lipschitz_unlearning(lipschitz_model, opt, forget_loader, AddGaussianNoise(std=0.8)) #1\n",
    "print(\"Unlearnt!\")\n",
    "lip_entropy, lip_var, lip_entropy_list = calculate_mean_entropy(lipschitz_model, forget_loader)\n",
    "lipschitz_values = {0: lip_entropy}\n",
    "lipschitz_var = {0: lip_var}\n",
    "print(f\"Lipschitz model forget entropy: {lip_entropy}\")\n",
    "\n",
    "# #Lipschitz model\n",
    "# for noise in tqdm(noises.values()):    \n",
    "#     entropy, norm, var = calculate_entropy_and_norm(lipschitz_model, forget_loader, noise)\n",
    "#     tqdm.write(f\"Entropy: {entropy} || Norm: {norm}\")\n",
    "#     lipschitz_values[norm] = entropy\n",
    "#     lipschitz_var[norm] = var"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.023897042943333717, 0.03890420891915702, 0.09919104421691147, 0.173687440066121, 0.2194017540431666, 0.2529031418022895, 0.2605108050519959, 0.2386386014864805, 0.21300278533251804, 0.1867553043340846]\n",
      "dict_keys([0, 6.115081608390808, 12.116986591529846, 17.962078419685362, 23.6617239528656, 29.170637591171264, 34.49876219367981, 39.62099192047119, 44.52134354324341, 49.23367369918823])\n",
      "10 10 10 10\n"
     ]
    },
    {
     "data": {
      "image/png": "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F2LYsGFi7ty5rnoLbqG5uVmUlZWJsrIyAUC89dZboqysTNTU1AghhHj11VdFenq6ef69ZfCvvPKKqKqqElu2bOEyeHe1efNmERERIRQKhRg7dqwoKSkxb5s8ebJYvHixxfy9e/eKqKgooVAoRGxsrPj888+dXLF7sqbPGo1GALjvkZWV5fzC3Yy1P8//iwHo0Vnb56+++kpotVqhVCpFZGSkeO2114TBYHBy1e7Hmj53dnaK1atXi2HDhglvb2+hVqtFRkaGuHXrlvMLdyMFBQXd/r6919vFixeLyZMn3/ec0aNHC4VCISIjI8WOHTscXqdMCB7HIyIiImnhNUBEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxAREREJDkMQERERCQ5DEBEREQkOQxARNRnDR06FJs2bXJ1GUTUCzEAEVGvsmTJEshkMmRnZ1uM79+/HzKZzKp9nT59GsuWLbNneUTURzAAEVGv4+3tjTfeeAO3bt2yaT+DBw+Gr6+vnaoior6EAYiIep20tDSEhobi9ddff+i8jz/+GLGxsVAqlRg6dCg2btxosf1/T4EJIbB69WpERERAqVRCpVLht7/9rXlue3s7VqxYgfDwcPj5+UGr1aKwsPChr19aWorU1FT4+vpCJpNZPK5evdqTt05ETsIARES9jlwux7p167B582Zcu3at2zmlpaWYO3cunnnmGVRUVGD16tVYtWoVcnJyup3/8ccf4+2338bf/vY3XLx4Efv370d8fLx5+wsvvIDi4mLk5ubi7NmzmDNnDp588klcvHix2/11dHRgzpw58PT0RFFREU6dOgWtVovQ0FDs3LkTgwcPtrkPROQ4nq4ugIioO7Nnz8bo0aORlZWF7du337f9rbfewhNPPIFVq1YBAKKiolBZWYn169djyZIl982vra1FaGgo0tLS4OXlhYiICIwdO9a8bceOHaitrYVKpQIArFixAgcOHMCOHTuwbt26+/Z38OBB1NbW4ssvv0R4eDgAYMeOHXj88ccRGxsLPz8/e7WCiByAR4CIqNd644038MEHH6Cqquq+bVVVVUhJSbEYS0lJwcWLF2E0Gu+bP2fOHLS2tiIyMhJLly5FXl4eDAYDAKCiogJGoxFRUVHw9/c3P44dO4bLly93W9ulS5eg0WjM4QcAYmJiEBgYiLNnz9rytonICXgEiIh6rdTUVEybNg1/+MMfuj2qYw21Wo0LFy7g8OHDOHToEDIyMrB+/XocO3YMP/zwA+RyOUpLSyGXyy2e5+/v3+3+vLy8ug1aRqPxvn0QUe/DAEREvVp2djZGjx6N6Ohoi/GYmBgUFRVZjBUVFSEqKuqBAcTHxwczZ87EzJkzkZmZiZEjR6KiogIJCQkwGo1oaGjApEmTHqmu2NhYXLt2DbW1tYiIiAAAnDt3Dk1NTYiJienBOyUiZ2IAIqJeLT4+HgsWLMA777xjMb58+XKMGTMGa9euxbx581BcXIx3330XW7du7XY/OTk5MBqN0Gq18PX1xa5du+Dj4wONRoOgoCAsWLAAixYtwsaNG5GQkIDvvvsOR44cwahRozBjxoz79jdlyhQkJiZi4cKF2LRpEwwGAzIyMjB16lQkJSU5pBdEZD+8BoiIer01a9bAZDJZjCUmJmLv3r3Izc1FXFwc/vznP2PNmjUPPFU2YMAAbNu2DSkpKRg1ahQOHz6MTz/9FEFBQQC6LmBetGgRli9fjujoaMyaNQunT582H935KZlMhry8PAQFBSE1NRVpaWkYNmwY9uzZY9f3TkSOIRNCCFcXQURERORMPAJEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESS8/97BdC6q6O+IgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "base_line = list(base_values.values())\n",
    "retrain_line = list(retrain_values.values())\n",
    "lipschitz_line = list(lipschitz_values.values())\n",
    "print(base_line)\n",
    "print(base_values.keys())\n",
    "\n",
    "xs = [0] + [std_dev_upper_bound / n_perturbations * i for i in range(1, n_perturbations + 1)]\n",
    "print(len(xs), len(base_line), len(retrain_line), len(lipschitz_line))\n",
    "#plot error bars\n",
    "# plt.errorbar(xs, base_line, yerr=list(base_var.values()), label=\"Base\")\n",
    "# plt.errorbar(xs, retrain_line, yerr=list(retrain_var.values()), label=\"Retrain\")\n",
    "# plt.errorbar(xs, lipschitz_line, yerr=list(lipschitz_var.values()), label=\"Lipschitz\")\n",
    "\n",
    "# #plot lines\n",
    "plt.plot(xs, base_line, label=\"Base\")\n",
    "plt.plot(xs, retrain_line, label=\"Retrain\")\n",
    "plt.plot(xs, lipschitz_line, label=\"Lipschitz\")\n",
    "\n",
    "plt.title(\"Entropy against Additive Gaussian Noise σ\")\n",
    "plt.xlabel(\"Noise σ\")\n",
    "plt.ylabel(\"Entropy\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArwAAAIjCAYAAADhisjVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABsiElEQVR4nO3deVyU5f7/8feAsqngggIqgvuWW+5aqScKzePSoqaWS2ZleSpt01Mu1Tlii6aVaZm7uFSWnrI0NTUzzC0ylUxNQBRcSERQVOD+/eGP+ToyIDDILLyej8c8aq7PNfd87mFu5zP3XNd1mwzDMAQAAAC4KDd7JwAAAADcShS8AAAAcGkUvAAAAHBpFLwAAABwaRS8AAAAcGkUvAAAAHBpFLwAAABwaRS8AAAAcGkUvAAAAHBpFLwAHN6SJUvUqFEjlS1bVhUrVrR3OrnExsbKZDJp4cKFhX7sli1bZDKZtGXLlmLPC87J2nti2LBhCg0NLbbnWLhwoUwmk2JjY4ttm4Ajo+AFbrGcD5a8bjt27Cj0Nr/99ltNnjy5+JN1QH/88YeGDRumunXrau7cufrkk0/y7Dt58mSZTCa5ubnp+PHjueKpqany9vaWyWTS6NGjb2XaxS6/99G4cePsnV6eLl68qMmTJxeqoI+NjdXw4cNVt25deXl5KTAwUHfddZcmTZpUpBwKe7x07drV4vWtXLmy2rZtq/nz5ys7O7tIOdjLlClTtHr1anunAdhdGXsnAJQWb7zxhmrXrp2rvV69eoXe1rfffqtZs2aViqJ3y5Ytys7O1syZMwv8Wnl6emr58uV6+eWXLdq//PLLW5FiibL2PrrtttvslM3NXbx4Ua+//rqka4XkzRw5ckRt27aVt7e3HnvsMYWGhioxMVF79+7VW2+9Zd5WYRTleKlZs6YiIiIkSWfOnNHixYs1YsQI/fnnn5o6dWqhc7DV3Llzi1RsT5kyRQ899JD69u1r0f7oo4/q4YcflqenZzFlCDg2Cl6ghPTo0UNt2rQp8efNzMxUdna2PDw8Svy5i8Pp06clqVBDGe677z6rBe+yZcvUs2dPrVq1qjhTLFG36n2Unp6ucuXKFft2C+u9995TWlqaoqOjFRISYhHLeS+UBD8/Pz3yyCPm+08++aQaNmyoDz/8UG+++abKli2b6zHZ2dm6cuWKvLy8ij0fa89nC3d3d7m7uxfrNgFHxpAGwEHkjAN999139cknn6hu3bry9PRU27ZttWvXLnO/YcOGadasWZJk8bPrjduYMWOGeRsHDx6UJP3www+68847Va5cOVWsWFF9+vRRTEyMRR45wwL++OMP9e/fX76+vqpSpYqee+45ZWRkmPt16dJFLVq0sLovDRs2VHh4+E33+aOPPlLTpk3l6emp6tWr65lnnlFKSoo5Hhoaav4Zu2rVqjKZTAU6Szdo0CBFR0frjz/+MLclJSXphx9+0KBBg6w+5vTp0xoxYoQCAgLk5eWlFi1aaNGiRbn6paSkaNiwYfLz81PFihU1dOhQi5yv98cff+ihhx5S5cqV5eXlpTZt2uh///vfTfO3RWH+xgcPHtSgQYNUqVIl3XHHHZKuFW2TJ09W9erV5ePjo27duungwYMKDQ3VsGHDLLaTkpKi559/XsHBwfL09FS9evX01ltvmc9ExsbGqmrVqpKk119/3fxeze9vePToUdWsWTNXsStJ1apVy9X23Xffmfe3QoUK6tmzpw4cOGCO53e8FIaPj486dOig9PR0nTlzxry90aNHKzIy0vw+XrdunSTpxIkTeuyxxxQQECBPT081bdpU8+fPz7XdhIQE9e3bV+XKlVO1atU0ZswYXb58OVc/a2N4c375aNasmby8vFS1alV1795du3fvNueXnp6uRYsWmfc752+Y1xjemx2T0rUz9bfddpsOHjyobt26ycfHRzVq1NDbb7+dK+8PPvhATZs2lY+PjypVqqQ2bdpo2bJlBXnJgWLFGV6ghJw/f15nz561aDOZTKpSpYpF27Jly3ThwgU9+eSTMplMevvtt/XAAw/or7/+UtmyZfXkk0/q5MmT2rBhg5YsWWL1uRYsWKCMjAw98cQT8vT0VOXKlbVx40b16NFDderU0eTJk3Xp0iV98MEH6ty5s/bu3Zvrw7R///4KDQ1VRESEduzYoffff1/nzp3T4sWLJV37SXTkyJHav3+/xU/qu3bt0p9//qnXXnst39dj8uTJev311xUWFqZRo0bp0KFDmj17tnbt2qXt27erbNmymjFjhhYvXqyvvvpKs2fPVvny5dW8efObvtZ33XWXatasqWXLlumNN96QJK1cuVLly5dXz549c/W/dOmSunbtqiNHjmj06NGqXbu2Pv/8cw0bNkwpKSl67rnnJEmGYahPnz766aef9NRTT6lx48b66quvNHTo0FzbPHDggDp37qwaNWpo3LhxKleunD777DP17dtXq1at0v3333/T/bDG2vvI399fkgr9N+7Xr5/q16+vKVOmyDAMSdL48eP19ttvq1evXgoPD9dvv/2m8PBwiy870rWhCl26dNGJEyf05JNPqlatWvr55581fvx4JSYmasaMGapatapmz56tUaNG6f7779cDDzwgSfn+DUNCQrRx40b98MMP+sc//pHva7FkyRINHTpU4eHheuutt3Tx4kXNnj1bd9xxh3799VeFhoYW6HgpqL/++kvu7u4Wvzb88MMP+uyzzzR69Gj5+/srNDRUp06dUocOHcwFcdWqVfXdd99pxIgRSk1N1fPPPy/p2vvu7rvvVnx8vJ599llVr15dS5Ys0Q8//FCgfEaMGKGFCxeqR48eevzxx5WZmalt27Zpx44datOmjZYsWaLHH39c7dq10xNPPCFJqlu3bp7bK8gxmePcuXPq3r27HnjgAfXv319ffPGFXnnlFTVr1kw9evSQdG0YxrPPPquHHnrI/IV53759+uWXX/L84gncMgaAW2rBggWGJKs3T09Pc79jx44ZkowqVaoYf//9t7l9zZo1hiTj66+/Nrc988wzhrXDN2cbvr6+xunTpy1iLVu2NKpVq2YkJyeb23777TfDzc3NGDJkiLlt0qRJhiSjd+/eFo9/+umnDUnGb7/9ZhiGYaSkpBheXl7GK6+8YtHv2WefNcqVK2ekpaXl+ZqcPn3a8PDwMO69914jKyvL3P7hhx8akoz58+fnyufMmTN5bs9a3xdffNGoV6+eOda2bVtj+PDhhmEYhiTjmWeeMcdmzJhhSDKWLl1qbrty5YrRsWNHo3z58kZqaqphGIaxevVqQ5Lx9ttvm/tlZmYad955pyHJWLBggbn97rvvNpo1a2ZkZGSY27Kzs41OnToZ9evXN7dt3rzZkGRs3rw5333L732Uo7B/44EDB1o8R1JSklGmTBmjb9++Fu2TJ082JBlDhw41t7355ptGuXLljD///NOi77hx4wx3d3cjPj7eMAzDOHPmjCHJmDRpUr77l2P//v2Gt7e3Iclo2bKl8dxzzxmrV6820tPTLfpduHDBqFixojFy5Mhc++Dn52fRntfxkpcuXboYjRo1Ms6cOWOcOXPGiImJMZ599llDktGrVy9zP0mGm5ubceDAAYvHjxgxwggKCjLOnj1r0f7www8bfn5+xsWLFw3D+L/33WeffWbuk56ebtSrVy/Xe2Lo0KFGSEiI+f4PP/xgSDKeffbZXPlnZ2eb/79cuXIWf7ccOe+nY8eOGYZRuGOyS5cuhiRj8eLF5rbLly8bgYGBxoMPPmhu69Onj9G0adNczw3YA0MagBIya9YsbdiwweL23Xff5eo3YMAAVapUyXz/zjvvlHTt7FJBPfjgg+afkiUpMTFR0dHRGjZsmCpXrmxub968ue655x59++23ubbxzDPPWNz/17/+JUnmvn5+furTp4+WL19uPjuYlZWllStXmn+izcvGjRt15coVPf/883Jz+79/hkaOHClfX1+tXbu2wPual0GDBunIkSPatWuX+b95nVX69ttvFRgYqIEDB5rbypYtq2effVZpaWnaunWruV+ZMmU0atQocz93d3fza5Pj77//1g8//KD+/fvrwoULOnv2rM6ePavk5GSFh4fr8OHDOnHiRJH2y9r7SCra3/ipp56yuL9p0yZlZmbq6aeftmi/cf8k6fPPP9edd96pSpUqmffv7NmzCgsLU1ZWln788cci7V/Tpk0VHR2tRx55RLGxsZo5c6b69u2rgIAAzZ0719xvw4YNSklJ0cCBAy2e393dXe3bt9fmzZuL9Pw5/vjjD1WtWlVVq1ZV48aN9cEHH6hnz565hiV06dJFTZo0Md83DEOrVq1Sr169ZBiGRW7h4eE6f/689u7dK+na+ykoKEgPPfSQ+fE+Pj7ms7H5WbVqlUwmk9WVK4oyZKOwx2T58uUtxjh7eHioXbt2Fv9OVaxYUQkJCRZDsgB7YUgDUELatWtXoMlGtWrVsrifU/yeO3euwM914yz+uLg4SdfG1t6ocePGWr9+fa5JS/Xr17foV7duXbm5uVmM+RsyZIhWrlypbdu26a677tLGjRt16tQpPfroo/nml1c+Hh4eqlOnjjlui1atWqlRo0ZatmyZKlasqMDAwDx/Io+Li1P9+vUtPuila6/N9fnGxcUpKChI5cuXt+h3434cOXJEhmFowoQJmjBhgtXnPH36tGrUqFHo/crrfVSUv3Fe75MbV8OoXLmyxZcwSTp8+LD27dtn8cXqerZMMGvQoIGWLFmirKwsHTx4UN98843efvttPfHEE6pdu7bCwsJ0+PBhScrzb+rr61vk55eujR+fO3euTCaTvLy8VL9+fatjiG98Dc+cOaOUlBR98skneS6hl/PaxMXFqV69erkKVGt/wxsdPXpU1atXt/hyY4vCHpM1a9bMlXelSpW0b98+8/1XXnlFGzduVLt27VSvXj3de++9GjRokDp37lwsOQOFQcELOJi8Zk7nnEUtCG9v7+JKx8zaWaPw8HAFBARo6dKluuuuu7R06VIFBgYqLCys2J+/KAYNGqTZs2erQoUKGjBgQK6C9lbJmbT14osv5jl5ryjL0RU3W94n2dnZuueee3KthJGjQYMGRd52Dnd3dzVr1kzNmjVTx44d1a1bN0VGRiosLMz8Gi9ZskSBgYG5HlumjG0fb+XKlSvQ+/jG1zAnr0ceecTq2G4p/zHMzqIg/041btxYhw4d0jfffKN169Zp1apV+uijjzRx4sQiLS8H2IKCF3BChf3JMmfG+6FDh3LF/vjjD/n7++cagnD48GGLs1dHjhxRdna2xcQnd3d3DRo0SAsXLtRbb72l1atXa+TIkTdd7uj6fOrUqWNuv3Llio4dO1ZsBfOgQYM0ceJEJSYm5jthKSQkRPv27VN2drZFUZyzykNOviEhIdq0aZPS0tIszvLe+Lrm7FPZsmVLrPgvyt84r20cOXLE4m+fnJyc6xeGunXrKi0t7ab7V5Sf163JOaudmJhofn7p2soNJZVDQVStWlUVKlRQVlbWTfMKCQnR/v37ZRiGRY7W/oY3qlu3rtavX6+///4737O8Bd33W3VMlitXTgMGDNCAAQN05coVPfDAA/rvf/+r8ePH35Ll24C8MIYXcEI5hUtey2HdKCgoSC1bttSiRYssHrN//359//33uu+++3I9JmcppxwffPCBJJlnYOd49NFHde7cOT355JNKS0uzGNeXl7CwMHl4eOj999+3OCM0b948nT9/3upKCkVRt25dzZgxQxEREWrXrl2e/e677z4lJSVp5cqV5rbMzEx98MEHKl++vLp06WLul5mZqdmzZ5v7ZWVlmV+bHNWqVVPXrl318ccfmwu06+Usa1WcivI3vtHdd9+tMmXKWOyfJH344Ye5+vbv319RUVFav359rlhKSooyMzMlXRuTmtNWENu2bdPVq1dzteeMQc75yT08PFy+vr6aMmWK1f7Xv8aFPV5s4e7urgcffFCrVq3S/v37883rvvvu08mTJ/XFF1+Y2y5evJjv1QRzPPjggzIMw+qZ0uuPqXLlyhVov2/FMZmcnGxx38PDQ02aNJFhGFb/ZsCtxBleoIR89913FuvC5ujUqZPFGZWCaN26tSTp2WefVXh4uNzd3fXwww/n+5h33nlHPXr0UMeOHTVixAjzklV+fn5W10U9duyYevfure7duysqKkpLly7VoEGDcq2926pVK9122236/PPP1bhxY91+++03zb9q1aoaP368Xn/9dXXv3l29e/fWoUOH9NFHH6lt27YFKpoLKmdJsfw88cQT+vjjjzVs2DDt2bNHoaGh+uKLL7R9+3bNmDFDFSpUkCT16tVLnTt31rhx4xQbG6smTZroyy+/1Pnz53Ntc9asWbrjjjvUrFkzjRw5UnXq1NGpU6cUFRWlhIQE/fbbb8W2jzkK+ze+UUBAgJ577jlNmzbN/Lf/7bff9N1338nf39/ibOFLL72k//3vf/rnP/+pYcOGqXXr1kpPT9fvv/+uL774QrGxsfL395e3t7eaNGmilStXqkGDBqpcubJuu+22PK8O99Zbb2nPnj164IEHzD/97927V4sXL1blypXNS3r5+vpq9uzZevTRR3X77bfr4YcfVtWqVRUfH6+1a9eqc+fO5kK9KMeLLaZOnarNmzerffv2GjlypJo0aaK///5be/fu1caNG/X3339LujYh7MMPP9SQIUO0Z88eBQUFacmSJeYvCfnp1q2bHn30Ub3//vs6fPiwunfvruzsbG3btk3dunUzXzq7devW2rhxo6ZPn67q1aurdu3aat++fa7t3Ypj8t5771VgYKA6d+6sgIAAxcTE6MMPP1TPnj3NxxRQYuyzOARQeuS3nJSuW8oqZ0mxd955J9c2dMOyTpmZmca//vUvo2rVqobJZDIvuZTfNgzDMDZu3Gh07tzZ8Pb2Nnx9fY1evXoZBw8etOiTs2TVwYMHjYceesioUKGCUalSJWP06NHGpUuXrG737bffNiQZU6ZMKdRr8+GHHxqNGjUyypYtawQEBBijRo0yzp07ZzWfwi5Llh/dsCyZYRjGqVOnjOHDhxv+/v6Gh4eH0axZM4tlxnIkJycbjz76qOHr62v4+fkZjz76qPHrr7/mWpbMMAzj6NGjxpAhQ4zAwECjbNmyRo0aNYx//vOfxhdffGHuU9hlyXbt2pVvv8L8ja29TpmZmcaECROMwMBAw9vb2/jHP/5hxMTEGFWqVDGeeuopi74XLlwwxo8fb9SrV8/w8PAw/P39jU6dOhnvvvuuceXKFXO/n3/+2WjdurXh4eFx0yXKtm/fbjzzzDPGbbfdZvj5+Rlly5Y1atWqZQwbNsw4evRorv6bN282wsPDDT8/P8PLy8uoW7euMWzYMGP37t0W+2TteMlLly5dCrSclrX3UY5Tp04ZzzzzjBEcHGyULVvWCAwMNO6++27jk08+segXFxdn9O7d2/Dx8TH8/f2N5557zli3bt1NlyXL2a933nnHaNSokeHh4WFUrVrV6NGjh7Fnzx5znz/++MO46667zEu95SxRduOyZDkKckzm9frcmOPHH39s3HXXXUaVKlUMT09Po27dusZLL71knD9/3voLCtxCJsMoxEwYAC4vZ/H5M2fOmC9ocDMzZ87UmDFjFBsbm2uVCTi/lJQUVapUSf/5z3/06quv2jsdACg0xvACsIlhGJo3b566dOlCsesCLl26lKttxowZkq5dUhYAnBFjeAEUSXp6uv73v/9p8+bN+v3337VmzRp7p4RisHLlSi1cuFD33Xefypcvr59++knLly/Xvffey/qpAJwWBS+AIjlz5owGDRqkihUr6t///rd69+5t75RQDJo3b64yZcro7bffVmpqqnki23/+8x97pwYARcYYXgAAALg0xvACAADApVHwAgAAwKUxhteK7OxsnTx5UhUqVCjRS1ICAACgYAzD0IULF1S9enWLy8JbQ8FrxcmTJxUcHGzvNAAAAHATx48fV82aNfPtQ8FrRc4lD48fPy5fX187ZwMAAIAbpaamKjg4uECXqqbgtSJnGIOvry8FLwAAgAMryPBTJq0BAADApVHwAgAAwKVR8AIAAMClUfACAADApVHwAgAAwKXZteD98ccf1atXL1WvXl0mk0mrV6/Ot/+wYcNkMply3Zo2bWruM3ny5FzxRo0a3eI9AQAAgKOya8Gbnp6uFi1aaNasWQXqP3PmTCUmJppvx48fV+XKldWvXz+Lfk2bNrXo99NPP92K9AEAAOAE7LoOb48ePdSjR48C9/fz85Ofn5/5/urVq3Xu3DkNHz7col+ZMmUUGBhYbHkCAADAeTn1GN558+YpLCxMISEhFu2HDx9W9erVVadOHQ0ePFjx8fH5bufy5ctKTU21uAEAAMA1OG3Be/LkSX333Xd6/PHH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5/nlmOPbb79VgwYN5O3trW7duhX4+Bs8eLC2bt2q48ePm9vmz5+vwYMHq0yZMhZ94+Pj1adPH5UvX16+vr7q37+/Tp06ZdFn6tSpCggIUIUKFTRixAirZ9M//fRTNW7cWF5eXmrUqJE++uijAuXqiih4USBpaWlaunSp6tWrZ3FmpUKFClq4cKEOHjyomTNnau7cuXrvvffM8cGDB6tmzZratWuX9uzZo3Hjxqls2bKSpKNHj6p79+568MEHtW/fPq1cuVI//fSTRo8efdN8HnvsMX322We6ePGipGv/sHXv3l0BAQEW/b766is999xzeuGFF7R//349+eSTGj58uDZv3izp2j9uDzzwgDw8PPTLL79ozpw5euWVVyy2cfXqVYWHh6tChQratm2btm/frvLly6t79+4FPtMA5/DSSy/phRde0K+//qqOHTuqV69eSk5OliRNmDBBBw8e1HfffaeYmBjNnj1b/v7+kq4dH126dNGJEyf0v//9T7/99ptefvllZWdnm7d99OhRrV69Wt98842++eYbbd26VVOnTrWax5dffqmaNWvqjTfeMP/KktOecz8xMVEPPPCAGjZsmOt9XxSFyU+SRo8eraioKK1YsUL79u1Tv3791L17dx0+fFiSlJGRodatW2vt2rXav3+/nnjiCT366KPauXOnxXYWLVokDw8Pbd++XXPmzDG3v/rqq5o2bZp2796tMmXK6LHHHss3/82bN+vo0aPavHmzFi1apIULF1r8RDxkyBCdPHlSW7Zs0apVq/TJJ5/o9OnTRXilUBD79+/Xzz//LA8PD3NbRESEFi9erDlz5ujAgQMaM2aMHnnkEW3dulXBwcFatWqVJOnQoUNKTEzUzJkzzY+19j5xc3PT+++/rwMHDmjRokX64Ycf9PLLL+eb183e5/nlKF07+fHAAw+oV69eio6O1uOPP65x48YV6DUJCAhQeHi4Fi1aJEm6ePGiVq5cmeu9nZ2drT59+ujvv//W1q1btWHDBv31118aMGCAuc9nn32myZMna8qUKdq9e7eCgoJyFbORkZGaOHGi/vvf/yomJkZTpkzRhAkTzM9f6hiAFUOHDjXc3d2NcuXKGeXKlTMkGUFBQcaePXvyfdw777xjtG7d2ny/QoUKxsKFC632HTFihPHEE09YtG3bts1wc3MzLl26ZPUxCxYsMPz8/AzDMIyWLVsaixYtMrKzs426desaa9asMd577z0jJCTE3L9Tp07GyJEjLbbRr18/47777jMMwzDWr19vlClTxjhx4oQ5/t133xmSjK+++sowDMNYsmSJ0bBhQyM7O9vc5/Lly4a3t7exfv16wzCuvV59+vTJ+4VBibvZ3+T6v/GxY8cMScbUqVPN8atXrxo1a9Y03nrrLcMwDKNXr17G8OHDrW7r448/NipUqGAkJydbjU+aNMnw8fExUlNTzW0vvfSS0b59e/P9Ll26GM8995z5fkhIiPHee+/lmf/06dONihUrGocOHcqzT16vwebNmw1Jxrlz54qUX1xcnOHu7m5x3BiGYdx9993G+PHj88ynZ8+exgsvvGCxzVatWlnNbePGjea2tWvXGpLM/y5MmjTJaNGihcV+hoSEGJmZmea2fv36GQMGDDAMwzBiYmIMScauXbvM8cOHDxuS8n2NUXDXf2Z4enoakgw3Nzfjiy++MAzDMDIyMgwfHx/j559/tnjciBEjjIEDBxqGkft9mcPa+8Sazz//3KhSpYr5/vWfF4Zx8/d5QXIcP3680aRJE4v4K6+8YjXv6+Ucz6tXrzbq1q1rZGdnG4sWLTLvl5+fn7FgwQLDMAzj+++/N9zd3Y34+Hjz4w8cOGBIMnbu3GkYhmF07NjRePrppy2eo3379hbHRd26dY1ly5ZZ9HnzzTeNjh07Gobxf//u/frrr3nm7UrKWCuCAUnq1q2bZs+eLenaz7kfffSRevTooZ07dyokJESStHLlSr3//vs6evSo0tLSlJmZKV9fX/M2xo4dq8cff1xLlixRWFiY+vXrp7p160q6Ntxh3759ioyMNPc3DEPZ2dk6duyY1Ylp13vssce0YMEC1apVS+np6brvvvv04YcfWvSJiYnRE088YdHWuXNn85mDmJgYBQcHq3r16uZ4x44dLfr/9ttvOnLkSK7xlRkZGTp69Gi+OcK5XP+3L1OmjNq0aaOYmBhJ0qhRo/Tggw9q7969uvfee9W3b1916tRJkhQdHa1WrVqpcuXKeW47NDTU4j0UFBRU5DOM3333ncaNG6evv/5aDRo0KNI2bMnv999/V1ZWVq7nvnz5svkXoKysLE2ZMkWfffaZTpw4oStXrujy5cvy8fGxeEzr1q2tPkfz5s0tcpGk06dP5zlOv2nTpnJ3d7d4zO+//y7p2hnDMmXK6PbbbzfH69Wrp0qVKlndFoom5zMjPT1d7733nsqUKaMHH3xQknTkyBFdvHhR99xzj8Vjrly5olatWt1029beJxs3blRERIT++OMPpaamKjMzUxkZGbp48WKu91mO/N7nBckxJiZG7du3t4jf+JmRn549e+rJJ5/Ujz/+qPnz51v95SLncyk4ONjc1qRJE1WsWFExMTFq27atYmJi9NRTT+XKI+fXy/T0dB09elQjRozQyJEjzX0yMzPl5+dX4HxdCQUv8lSuXDnVq1fPfP/TTz+Vn5+f5s6dq//85z+KiorS4MGD9frrrys8PFx+fn5asWKFpk2bZn7M5MmTNWjQIK1du1bfffedJk2apBUrVuj+++9XWlqannzyST377LO5nrsgk88GDx6sl19+WZMnT9ajjz6aawxUcUlLS1Pr1q0tCvMcVatWvSXPCcfTo0cPxcXF6dtvv9WGDRt0991365lnntG7774rb2/vmz4+ZyhPDpPJZDHkoaAOHjyohx9+WFOnTtW9996bb19fX1/FxcXlak9JSZG7u7vFRJnC5JeWliZ3d3ft2bPHosiUrk0ok6R33nlHM2fO1IwZM8zjLJ9//vlcw4DymqxzfT45Y5jze72K6/VF0V3/mTF//ny1aNFC8+bN04gRI8xja9euXasaNWpYPK4gk0dvfJ/Exsbqn//8p0aNGqX//ve/qly5sn766SeNGDFCV65cybPgze99YmuOBVGmTBk9+uijmjRpkn755Rd99dVXxbLdG+Xsy9y5c3MV6Dces6UFY3hRYCaTSW5ubrp06ZIk6eeff1ZISIheffVVtWnTRvXr17f64dqgQQONGTNG33//vR544AHzRJ/bb79dBw8eVL169XLdrh/3lZfKlSurd+/e2rp1a57j+xo3bqzt27dbtG3fvl1NmjQxx48fP24eIyldmzV7vdtvv12HDx9WtWrVcuVZWr8pu6rr//aZmZnas2ePxS8NVatW1dChQ7V06VLNmDFDn3zyiaRrZyOjo6P1999/F1suHh4eysrKsmg7e/asevXqpQcffFBjxoy56TYaNmyoAwcO6PLlyxbte/fuVe3atXN9+BdUq1atlJWVpdOnT+c6JgIDAyVdO8769OmjRx55RC1atFCdOnXstkRUw4YNlZmZqV9//dXcduTIEZ07d84u+ZQGbm5u+ve//63XXntN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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "make_boxplot(\n",
    "    [base_entropy_list, lip_entropy_list, retrain_entropy_list],\n",
    "    title=\"Entropy of Model Forget Set Predictions\",\n",
    "    x_label=\"Method\",\n",
    "    y_label=\"Entropy\",\n",
    "    x_ticklabels=[\"Base Model\", \"Lipschitz Unlearning\", \"Retrained Model\"],\n",
    "    save_path=\"entropy.png\",\n",
    "    showfliers = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot histogram\n",
    "plt.hist(-np.log(retrain_entropy_list), bins=20, label=\"Retrain\", alpha=0.75, color='orange')\n",
    "plt.hist(-np.log(lip_entropy_list), bins=20, label=\"Lipschitz\", alpha=0.75, color='g')\n",
    "plt.hist(-np.log(base_entropy_list), bins=20, label=\"Base\", alpha=0.75, color='b')\n",
    "plt.title(\"Entropy of Model Predictions (Log Scale)\")\n",
    "plt.xlabel(\"Entropy\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Wilcoxon for Base model and Retrained model: p=1.3115727630339086e-264\n",
      "Wilcoxon for Base model and Lipschitz model: p=1.6481137897159184e-288\n",
      "Wilcoxon for Lipschitz model and Retrained model: p=0.9085219870084502\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import wilcoxon\n",
    "\n",
    "print(f'Wilcoxon for Base model and Retrained model: p={wilcoxon(base_entropy_list, retrain_entropy_list)[1]}')\n",
    "print(f'Wilcoxon for Base model and Lipschitz model: p={wilcoxon(base_entropy_list, lip_entropy_list)[1]}')\n",
    "print(f'Wilcoxon for Lipschitz model and Retrained model: p={wilcoxon(lip_entropy_list, retrain_entropy_list)[1]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Base model forget entropy: 0.02266535240683401\n",
      "Retrain model forget entropy: 0.019551020706744245\n",
      "Lipschitz model forget entropy: 0.019551020706744245\n"
     ]
    }
   ],
   "source": [
    "base_model_retain_entropy, base_model_var, base_entropy_list = calculate_mean_entropy(model, retain_loader)\n",
    "print(f\"Base model forget entropy: {base_model_retain_entropy}\")\n",
    "\n",
    "retrain_model_retain_entropy, ret_var, retrain_entropy_list = calculate_mean_entropy(retrained_model, retain_loader)\n",
    "print(f\"Retrain model forget entropy: {retrain_model_retain_entropy}\")\n",
    "\n",
    "lip_entropy, lip_var, lip_entropy_list = calculate_mean_entropy(lipschitz_model, retain_loader)\n",
    "print(f\"Lipschitz model forget entropy: {lip_entropy}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArMAAAIjCAYAAAAQgZNYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAABmf0lEQVR4nO3dd3hUZf7//9ckkEJJAAkBQgpFpPdiYKWsWQOyCKsiAtLBBguCDVZp+pVgAVFBUJQiRbACKyjSUWSlGemdJATpJSFAEsic3x/8Mh+GTCDJhMycyfNxXXPp3O8zM+8ZZpJXztznPhbDMAwBAAAAJuTl6gYAAACAvCLMAgAAwLQIswAAADAtwiwAAABMizALAAAA0yLMAgAAwLQIswAAADAtwiwAAABMizALAAAA0yLMAnCpuXPnqkaNGipatKhKlSrl6nayiIuLk8Vi0ezZs3N923Xr1slisWjdunX53ldB6NOnjyIiIlzdhkdx9J7I79d59uzZslgsiouLy7f7BNwZYRZwQuYvjewu//vf/3J9n8uXL9fYsWPzv1k3tG/fPvXp00dVq1bVjBkz9Omnn2a77dixY2WxWOTl5aVjx45lqScnJ8vf318Wi0WDBw++m23nu1vfR0WKFFFISIj69Omj48eP5+k+9+zZo7Fjx7pdoImLi1Pfvn1VtWpV+fn5qXz58mrVqpXGjBmTp/vL7eelTZs2dq91mTJl1LRpU82cOVNWqzVPPbjK+PHjtXjxYle3AbhcEVc3AHiCN954Q5UrV84yXq1atVzf1/LlyzV16tRCEWjXrVsnq9WqDz74IMevla+vr7788ku98sorduPffffd3WixQGW+j1JTU/W///1Ps2fP1q+//qpdu3bJz88vV/e1Z88ejRs3Tm3atMnzXr8ZM2bka8A7dOiQmjZtKn9/f/Xr108RERE6ceKEtm/frrffflvjxo3L9X3m5fNSqVIlxcTESJLOnDmjL774Qv3799eBAwc0YcKEXPfgrLy+zuPHj9fjjz+uzp0724337NlTTz75pHx9ffOpQ8C9EWaBfNC+fXs1adKkwB/3+vXrslqt8vHxKfDHzg+nT5+WpFxNL3j44YcdhtkFCxaoQ4cO+vbbb/OzxQJ18/towIABKlu2rN5++20tXbpUTzzxRIH3U7Ro0Xy9v/fff18pKSmKjY1VeHi4XS3zvVAQAgMD9dRTT9muP/PMM7rvvvs0ZcoUvfnmmw6ft9VqVXp6eq7/qMiJ/H6dvb295e3tna/3CbgzphkABSBz3uV7772nTz/9VFWrVpWvr6+aNm2qLVu22Lbr06ePpk6dKkl2X4Xeeh+TJ0+23ceePXskSWvWrNEDDzyg4sWLq1SpUurUqZP27t1r10fmV/X79u3TE088oYCAAN1zzz0aOnSoUlNTbdu1bt1a9evXd/hc7rvvPkVHR9/xOX/88ceqXbu2fH19VbFiRQ0aNEgXL1601SMiImxfLQcFBcliseRo71r37t0VGxurffv22cZOnjypNWvWqHv37g5vc/r0afXv31/BwcHy8/NT/fr1NWfOnCzbXbx4UX369FFgYKBKlSql3r172/V8s3379unxxx9XmTJl5OfnpyZNmmjp0qV37D83HnjgAUnS4cOHc/XYs2fPVpcuXSRJbdu2tb2PMudpLlmyRB06dFDFihXl6+urqlWr6s0331RGRobd49w6lzOn7+PsHD58WJUqVcoSZCWpXLlyWcZ+/PFH23u6ZMmS6tChg3bv3m3XX3afl9woVqyY7r//fl2+fFlnzpyx3d/gwYM1f/582/v4p59+kiQdP35c/fr1U3BwsHx9fVW7dm3NnDkzy/0mJiaqc+fOKl68uMqVK6dhw4YpLS0ty3aO5sxmfmNRt25d+fn5KSgoSO3atdPWrVtt/V2+fFlz5syxPe8+ffpIyn7O7J0+k9KNaRh16tTRnj171LZtWxUrVkwhISF65513svT90UcfqXbt2ipWrJhKly6tJk2aaMGCBTl5yYF8xZ5ZIB8kJSXp7NmzdmMWi0X33HOP3diCBQt06dIlPfPMM7JYLHrnnXf06KOP6siRIypatKieeeYZ/fXXX1q5cqXmzp3r8LFmzZql1NRUPf300/L19VWZMmW0atUqtW/fXlWqVNHYsWN19epVffTRR2rZsqW2b9+e5RflE088oYiICMXExOh///ufPvzwQ124cEFffPGFpBtfUw4cOFC7du1SnTp1bLfbsmWLDhw4oNdff/22r8fYsWM1btw4RUVF6bnnntP+/fs1bdo0bdmyRRs3blTRokU1efJkffHFF/r+++81bdo0lShRQvXq1bvja92qVStVqlRJCxYs0BtvvCFJWrRokUqUKKEOHTpk2f7q1atq06aNDh06pMGDB6ty5cr6+uuv1adPH128eFFDhw6VJBmGoU6dOunXX3/Vs88+q5o1a+r7779X7969s9zn7t271bJlS4WEhGjEiBEqXry4vvrqK3Xu3Fnffvut/vWvf93xeeREZhgpXbp0rh67VatWGjJkiD788EP95z//Uc2aNSXJ9t/Zs2erRIkSGj58uEqUKKE1a9Zo9OjRSk5O1rvvvnvHvu70Ps5OeHi4Vq1apTVr1ujvf//7bR9j7ty56t27t6Kjo/X222/rypUrmjZtmv72t7/pjz/+UERERI4+Lzl15MgReXt7231LsGbNGn311VcaPHiwypYtq4iICJ06dUr333+/LewGBQXpxx9/VP/+/ZWcnKwXXnhB0o333YMPPqiEhAQNGTJEFStW1Ny5c7VmzZoc9dO/f3/Nnj1b7du314ABA3T9+nX98ssv+t///qcmTZpo7ty5GjBggJo1a6ann35aklS1atVs7y8nn8lMFy5cULt27fToo4/qiSee0DfffKNXX31VdevWVfv27SXdmBoxZMgQPf7447Y/hnfs2KHff/892z8qgbvGAJBns2bNMiQ5vPj6+tq2O3r0qCHJuOeee4zz58/bxpcsWWJIMv773//axgYNGmQ4+mhm3kdAQIBx+vRpu1qDBg2McuXKGefOnbON/fnnn4aXl5fRq1cv29iYMWMMScYjjzxid/vnn3/ekGT8+eefhmEYxsWLFw0/Pz/j1VdftdtuyJAhRvHixY2UlJRsX5PTp08bPj4+xkMPPWRkZGTYxqdMmWJIMmbOnJmlnzNnzmR7f462femll4xq1arZak2bNjX69u1rGIZhSDIGDRpkq02ePNmQZMybN882lp6ebkRGRholSpQwkpOTDcMwjMWLFxuSjHfeece23fXr140HHnjAkGTMmjXLNv7ggw8adevWNVJTU21jVqvVaNGihXHvvffaxtauXWtIMtauXXvb55b5Plq1apVx5swZ49ixY8Y333xjBAUFGb6+vsaxY8dy/dhff/11to995cqVLGPPPPOMUaxYMbv77d27txEeHm67npv3sSO7du0y/P39DUlGgwYNjKFDhxqLFy82Ll++bLfdpUuXjFKlShkDBw60Gz958qQRGBhoN57d5yU7rVu3NmrUqGGcOXPGOHPmjLF3715jyJAhhiSjY8eOtu0kGV5eXsbu3bvtbt+/f3+jQoUKxtmzZ+3Gn3zySSMwMND22ma+77766ivbNpcvXzaqVauW5d/l1td5zZo1hiRjyJAhWfq3Wq22/y9evLjRu3fvLNtkvp+OHj1qGEbuPpOtW7c2JBlffPGFbSwtLc0oX7688dhjj9nGOnXqZNSuXTvLYwOuwDQDIB9MnTpVK1eutLv8+OOPWbbr2rWr3V62zK+Rjxw5kuPHeuyxxxQUFGS7fuLECcXGxqpPnz4qU6aMbbxevXr6xz/+oeXLl2e5j0GDBtld//e//y1Jtm0DAwPVqVMnffnllzIMQ5KUkZGhRYsW2b42zc6qVauUnp6uF154QV5e//cjZuDAgQoICNCyZcty/Fyz0717dx06dEhbtmyx/Te7vUHLly9X+fLl1a1bN9tY0aJFNWTIEKWkpGj9+vW27YoUKaLnnnvOtp23t7fttcl0/vx5rVmzRk888YQuXbqks2fP6uzZszp37pyio6N18ODBPK9AEBUVpaCgIIWGhurxxx9X8eLFtXTpUlWqVClfH9vf39/2/5n388ADD+jKlSt20zeyk9f3ce3atRUbG6unnnpKcXFx+uCDD9S5c2cFBwdrxowZtu1Wrlypixcvqlu3brbnePbsWXl7e6t58+Zau3btHXu8nX379ikoKEhBQUGqWbOmPvroI3Xo0CHLVIHWrVurVq1atuuGYejbb79Vx44dZRiGXW/R0dFKSkrS9u3bJd14P1WoUEGPP/647fbFihWz7UW9nW+//VYWi8XhCg95mUaR289kiRIl7OYU+/j4qFmzZnb/vqVKlVJiYmKOppcAdxvTDIB80KxZsxwdABYWFmZ3PTMQXLhwIcePdeuqCfHx8ZJuzGW9Vc2aNbVixQpdvnzZLoDee++9dttVrVpVXl5ednPsevXqpUWLFumXX35Rq1attGrVKp06dUo9e/a8bX/Z9ePj46MqVarY6s5o2LChatSooQULFqhUqVIqX758tl9bx8fH695777X7JS7931fumf3Ex8erQoUKKlGihN12tz6PQ4cOyTAMjRo1SqNGjXL4mKdPn1ZISEiun9fUqVNVvXp1JSUlaebMmdqwYYPdEen59di7d+/W66+/rjVr1ig5OdmulpSUdMc+nXkfV69eXXPnzlVGRob27NmjH374Qe+8846efvppVa5cWVFRUTp48KAkZftvGhAQcMfHuZ2IiAjNmDFDFotFfn5+uvfeex3O2b31s3bmzBldvHhRn376abbLyGUeyBYfH69q1aplCZ+OPqe3Onz4sCpWrGj3x6kzcvuZrFSpUpa+S5curR07dtiuv/rqq1q1apWaNWumatWq6aGHHlL37t3VsmXLfOkZyA3CLFCAsjvCOHPvZ07cvFctvzja2xMdHa3g4GDNmzdPrVq10rx581S+fHlFRUXl++PnRffu3TVt2jSVLFlSXbt2zRJW75bMJZReeumlbA+Ey8uSbJL9H0WdO3fW3/72N3Xv3l379+9XiRIl8uWxL168qNatWysgIEBvvPGGbb3X7du369VXX83RElH58T729vZW3bp1VbduXUVGRqpt27aaP3++oqKibD3MnTtX5cuXz3LbIkWc+9VVvHjxHL2Pb/2sZfb11FNPOZxLLSlH877dXU7+fWvWrKn9+/frhx9+0E8//aRvv/1WH3/8sUaPHp2nJdYAZxBmATeT268RM48M379/f5bavn37VLZs2SzTAg4ePGi31+nQoUOyWq12B4p5e3ure/fumj17tt5++20tXrxYAwcOvOOSPzf3U6VKFdt4enq6jh49mm9huHv37ho9erROnDhx24N/wsPDtWPHDlmtVrvAm/l1ema/4eHhWr16tVJSUuz2zt76umY+p6JFi97VYO/t7a2YmBi1bdtWU6ZM0YgRI3L12Nm9j9atW6dz587pu+++U6tWrWzjR48ezb/mcykzwJ84cULS/x3IVK5cuTw/z7shKChIJUuWVEZGxh37Cg8P165du2QYhl2Pjj6nt6patapWrFih8+fP33bvbE6f+936TBYvXlxdu3ZV165dlZ6erkcffVRvvfWWRo4ceVeWMAOyw5xZwM1kBs/sloS6VYUKFdSgQQPNmTPH7ja7du3Szz//rIcffjjLbTKXM8r00UcfSZLtSOVMPXv21IULF/TMM88oJSXFbh5ddqKiouTj46MPP/zQbk/O559/rqSkJIcrDuRF1apVNXnyZMXExKhZs2bZbvfwww/r5MmTWrRokW3s+vXr+uijj1SiRAm1bt3att3169c1bdo023YZGRm21yZTuXLl1KZNG33yySe28HWzzKWd8kObNm3UrFkzTZ48Wampqbl67OzeR5l/jNz8b5Oenq6PP/443/rOzi+//KJr165lGc+cq535NXh0dLQCAgI0fvx4h9vn5HneDd7e3nrs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l6cw+9prr2nKlCmaMGGC/vjjD/3xxx8aP368PvroI40aNSq/ewQAAMg3lSpVUpcuXezGunTpwkkTTCpPc2bnzJmjzz77TI888ohtrF69egoJCdHzzz+vt956K98aBAAAyG9FihS57XWYR572zJ4/f141atTIMl6jRg2dP3/e6aYAAADulsTERC1cuNBubOHChRwDZFJ5CrP169fXlClTsoxPmTJF9evXd7opAACAu8EwDL3//vtZ1pm1Wq0Ox+H+8rRP/Z133lGHDh20atUqRUZGSpI2bdqkY8eOafny5fnaIAAAQH6Jj4/Xli1bsowbhqEtW7YoPj6eFQ1MJk97Zlu3bq0DBw7oX//6ly5evKiLFy/q0Ucf1f79+/XAAw/k+v6mTp2qiIgI+fn5qXnz5tq8efNtt588ebLuu+8++fv7KzQ0VMOGDVNqampengoAAChEwsLCFBAQ4LAWEBCgsLCwAu4Izsr1ntlr166pXbt2mj59er4c6LVo0SINHz5c06dPV/PmzTV58mRFR0dr//79KleuXJbtFyxYoBEjRmjmzJlq0aKFDhw4oD59+shisXDqXAAAcFsJCQlKTk52WEtOTlZCQgJ7Zk0m13tmixYtqh07duRbA5MmTdLAgQPVt29f1apVS9OnT1exYsU0c+ZMh9v/9ttvatmypbp3766IiAg99NBD6tat2x335gIAAISHh6tp06ZZ1pO1WCxq1qyZwsPDXdQZ8ipP0wyeeuopff75504/eHp6urZt26aoqKj/a8jLS1FRUdq0aZPD27Ro0ULbtm2zhdcjR45o+fLlevjhhx1un5aWpuTkZLsLAAAonCwWi4YNGyYvL/sI5O3trWHDhnHSBBPK0wFg169f18yZM7Vq1So1btxYxYsXt6vn9Ov+s2fPKiMjQ8HBwXbjwcHB2rdvn8PbdO/eXWfPntXf/vY3GYah69ev69lnn9V//vMfh9vHxMRo3LhxOeoHAAB4vkqVKqlr165asGCBbaxr166cNMGk8hRmd+3apUaNGkmSDhw4kK8N3cm6des0fvx4ffzxx2revLkOHTqkoUOH6s0333R49rGRI0dq+PDhtuvJyckKDQ0tyJYBAICbuX79+m2vwzzyFGbXrl2bLw9etmxZeXt769SpU3bjp06dUvny5R3eZtSoUerZs6cGDBggSapbt64uX76sp59+Wq+9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LEZOIq8HsVqt+uuvv1SyZElZLBZXt4NbJCcnKzQ0VMeOHVNAQICr2wFMgc8NkDd8dtyXYRi6dOmSKlasKC+v28+KLXR7Zr28vFSpUiVXt4E7CAgI4AcLkEt8boC84bPjnu60RzYTB4ABAADAtAizAAAAMC3CLNyKr6+vxowZI19fX1e3ApgGnxsgb/jseIZCdwAYAAAAPAd7ZgEAAGBahFkAAACYFmEWAAAApkWYRaFksVi0ePHiHG/fp08fde7c+a71g/yV239fZ4wdO1YNGjS47TZt2rTRCy+8UCD95IU79ZeT1xOYPXu2SpUqddcfZ926dbJYLLp48eJdf6zbye3nIi4uThaLRbGxsXetJ3dCmC2k+vTpI4vFYrvcc889ateunXbs2OHSvmbPni2LxaKaNWtmqX399deyWCyKiIgo+MbgVu70x8WJEyfUvn37gmvoDr777ju9+eabtusRERGaPHmyU/eZ3WvgLr988+qll17S6tWrXd0GbnLz74uiRYuqcuXKeuWVV5Samprj+8jv92XXrl114MCBfLkvZ0VERMhisWjhwoVZarVr15bFYtHs2bMLvrFChDBbiLVr104nTpzQiRMntHr1ahUpUkT//Oc/Xd2WihcvrtOnT2vTpk12459//rnCwsJc1BXMpHz58m611E6ZMmVUsmRJV7fhUunp6TnarkSJErrnnnvucjfIrczfF0eOHNH777+vTz75RGPGjMn3x8np+8Tf31/lypXL98fPq9DQUM2aNctu7H//+59Onjyp4sWLu6irwoMwW4j5+vqqfPnyKl++vBo0aKARI0bo2LFjOnPmjG2bV199VdWrV1exYsVUpUoVjRo1SteuXbPV//zzT7Vt21YlS5ZUQECAGjdurK1bt9rqv/76qx544AH5+/srNDRUQ4YM0eXLl2/bV5EiRdS9e3fNnDnTNpaYmKh169ape/fuWbafNm2aqlatKh8fH913332aO3euXf3gwYNq1aqV/Pz8VKtWLa1cuTLLfRw7dkxPPPGESpUqpTJlyqhTp06Ki4u742sI93TzNIPMr9sWLlyoFi1ayM/PT3Xq1NH69ett21+4cEE9evRQUFCQ/P39de+999r9YkpMTFS3bt1UpkwZFS9eXE2aNNHvv/9u95hz585VRESEAgMD9eSTT+rSpUu22s1f47dp00bx8fEaNmyYbW9X5vjN35ZkXpx9H2Z+PXm7/m6Vlpaml156SSEhISpevLiaN2+udevW2ernzp1Tt27dFBISomLFiqlu3br68ssv7e6jTZs2Gjx4sF544QWVLVtW0dHRtr1zq1evVpMmTVSsWDG1aNFC+/fvz9Jvpsw90O+9954qVKige+65R4MGDbL7OXTixAl16NBB/v7+qly5shYsWJAve7/xfzJ/X4SGhqpz586Kioqy+1lqtVoVExOjypUry9/fX/Xr19c333wj6cZnsG3btpKk0qVLy2KxqE+fPpIcv08kadKkSapbt66KFy+u0NBQPf/880pJSbE93q3TDHLyPr9dj5mWL1+u6tWry9/fX23bts3x569Hjx5av369jh07ZhubOXOmevTooSJFithtm5CQoE6dOqlEiRIKCAjQE088oVOnTtltM2HCBAUHB6tkyZLq37+/w73gn332mWrWrCk/Pz/VqFFDH3/8cY569USEWUiSUlJSNG/ePFWrVs1ur0jJkiU1e/Zs7dmzRx988IFmzJih999/31bv0aOHKlWqpC1btmjbtm0aMWKEihYtKkk6fPiw2rVrp8cee0w7duzQokWL9Ouvv2rw4MF37Kdfv3766quvdOXKFUk3fnC1a9dOwcHBdtt9//33Gjp0qF588UXt2rVLzzzzjPr27au1a9dKuvHD69FHH5WPj49+//13TZ8+Xa+++qrdfVy7dk3R0dEqWbKkfvnlF23cuFElSpRQu3btcryXAO7v5Zdf1osvvqg//vhDkZGR6tixo86dOydJGjVqlPbs2aMff/xRe/fu1bRp01S2bFlJNz4brVu31vHjx7V06VL9+eefeuWVV2S1Wm33ffjwYS1evFg//PCDfvjhB61fv14TJkxw2Md3332nSpUq6Y033rB9M5I5nnn9xIkTevTRR3Xfffdlec/nRW76k6TBgwdr06ZNWrhwoXbs2KEuXbqoXbt2OnjwoCQpNTVVjRs31rJly7Rr1y49/fTT6tmzpzZv3mx3P3PmzJGPj482btyo6dOn28Zfe+01TZw4UVu3blWRIkXUr1+/2/a/du1aHT58WGvXrtWcOXM0e/Zsu69te/Xqpb/++kvr1q3Tt99+q08//VSnT5/OwyuFnNi1a5d+++03+fj42MZiYmL0xRdfaPr06dq9e7eGDRump556SuvXr1doaKi+/fZbSdL+/ft14sQJffDBB7bbOnqfeHl56cMPP9Tu3bs1Z84crVmzRq+88spt+7rT+/x2PUo3dmo8+uij6tixo2JjYzVgwACNGDEiR69JcHCwoqOjNWfOHEnSlStXtGjRoizvbavVqk6dOun8+fNav369Vq5cqSNHjqhr1662bb766iuNHTtW48eP19atW1WhQoUsQXX+/PkaPXq03nrrLe3du1fjx4/XqFGjbI9f6BgolHr37m14e3sbxYsXN4oXL25IMipUqGBs27bttrd79913jcaNG9uulyxZ0pg9e7bDbfv37288/fTTdmO//PKL4eXlZVy9etXhbWbNmmUEBgYahmEYDRo0MObMmWNYrVajatWqxpIlS4z333/fCA8Pt23fokULY+DAgXb30aVLF+Phhx82DMMwVqxYYRQpUsQ4fvy4rf7jjz8akozvv//eMAzDmDt3rnHfffcZVqvVtk1aWprh7+9vrFixwjCMG69Xp06dsn9hUKDu9O9x87/v0aNHDUnGhAkTbPVr164ZlSpVMt5++23DMAyjY8eORt++fR3e1yeffGKULFnSOHfunMP6mDFjjGLFihnJycm2sZdfftlo3ry57Xrr1q2NoUOH2q6Hh4cb77//frb9T5o0yShVqpSxf//+bLfJ7jVYu3atIcm4cOFCnvqLj483vL297T4zhmEYDz74oDFy5Mhs++nQoYPx4osv2t1nw4YNHfa2atUq29iyZcsMSbafCWPGjDHq169v9zzDw8ON69ev28a6dOlidO3a1TAMw9i7d68hydiyZYutfvDgQUPSbV9j5NzNvy98fX0NSYaXl5fxzTffGIZhGKmpqUaxYsWM3377ze52/fv3N7p162YYRtb3ZSZH7xNHvv76a+Oee+6xXb/5d4Vh3Pl9npMeR44cadSqVcuu/uqrrzrs+2aZn+fFixcbVatWNaxWqzFnzhzb8woMDDRmzZplGIZh/Pzzz4a3t7eRkJBgu/3u3bsNScbmzZsNwzCMyMhI4/nnn7d7jObNm9t9LqpWrWosWLDAbps333zTiIyMNAzj/37u/fHHH9n27UmKOAq4KBzatm2radOmSbrxNevHH3+s9u3ba/PmzQoPD5ckLVq0SB9++KEOHz6slJQUXb9+XQEBAbb7GD58uAYMGKC5c+cqKipKXbp0UdWqVSXdmIKwY8cOzZ8/37a9YRiyWq06evSow4O8btavXz/NmjVLYWFhunz5sh5++GFNmTLFbpu9e/fq6aefthtr2bKl7a/+vXv3KjQ0VBUrVrTVIyMj7bb/888/dejQoSxzGlNTU3X48OHb9gjzuPnfvUiRImrSpIn27t0rSXruuef02GOPafv27XrooYfUuXNntWjRQpIUGxurhg0bqkyZMtned0REhN37p0KFCnneM/jjjz9qxIgR+u9//6vq1avn6T6c6W/nzp3KyMjI8thpaWm2b20yMjI0fvx4ffXVVzp+/LjS09OVlpamYsWK2d2mcePGDh+jXr16dr1I0unTp7OdE1+7dm15e3vb3Wbnzp2SbuzpK1KkiBo1amSrV6tWTaVLl3Z4X8ibzN8Xly9f1vvvv68iRYrosccekyQdOnRIV65c0T/+8Q+726Snp6thw4Z3vG9H75NVq1YpJiZG+/btU3Jysq5fv67U1FRduXIly/ss0+3e5znpce/evWrevLld/dbfF7fToUMHPfPMM9qwYYNmzpzp8BuHzN9JoaGhtrFatWqpVKlS2rt3r5o2baq9e/fq2WefzdJH5jeOly9f1uHDh9W/f38NHDjQts3169cVGBiY4349CWG2ECtevLiqVatmu/7ZZ58pMDBQM2bM0P/7f/9PmzZtUo8ePTRu3DhFR0crMDBQCxcu1MSJE223GTt2rLp3765ly5bpxx9/1JgxY7Rw4UL961//UkpKip555hkNGTIky2Pn5ECuHj166JVXXtHYsWPVs2fPLPOO8ktKSooaN25sF7ozBQUF3ZXHhHtp37694uPjtXz5cq1cuVIPPvigBg0apPfee0/+/v53vH3m1JpMFovFbhpCTu3Zs0dPPvmkJkyYoIceeui22wYEBCg+Pj7L+MWLF+Xt7W130Elu+ktJSZG3t7e2bdtmFyClGwdnSdK7776rDz74QJMnT7bNa3zhhReyTMvJ7sCXm/vJnDN8u9crv15f5N3Nvy9mzpyp+vXr6/PPP1f//v1tc1mXLVumkJAQu9vl5EDMW98ncXFx+uc//6nnnntOb731lsqUKaNff/1V/fv3V3p6erZh9nbvE2d7zIkiRYqoZ8+eGjNmjH7//Xd9//33+XK/t8p8LjNmzMgSvm/9zBYWzJmFjcVikZeXl65evSpJ+u233xQeHq7XXntNTZo00b333uvwl2f16tU1bNgw/fzzz3r00UdtB840atRIe/bsUbVq1bJcbp5rlZ0yZcrokUce0fr167OdU1ezZk1t3LjRbmzjxo2qVauWrX7s2DHbvETpxhGmN2vUqJEOHjyocuXKZemzsP6V64lu/ne/fv26tm3bZvftQFBQkHr37q158+Zp8uTJ+vTTTyXd2IsYGxur8+fP51svPj4+ysjIsBs7e/asOnbsqMcee0zDhg27433cd9992r17t9LS0uzGt2/frsqVK2f5xZ5TDRs2VEZGhk6fPp3l81C+fHlJNz5jnTp10lNPPaX69eurSpUqLlsm6b777tP169f1xx9/2MYOHTqkCxcuuKSfwsDLy0v/+c9/9Prrr+vq1auqVauWfH19lZCQkOU9k7kHMvNn/q3ve0e2bdsmq9WqiRMn6v7771f16tX1119/OdVzTnqsWbNmlnnft/6+uJN+/fpp/fr16tSpk8NvBzJ/J918oNiePXt08eJFu99btx5genMfwcHBqlixoo4cOZLluVSuXDlX/XoKwmwhlpaWppMnT+rkyZPau3ev/v3vfyslJUUdO3aUJN17771KSEjQwoULdfjwYX344Yd2f2levXpVgwcP1rp16xQfH6+NGzdqy5YttoDw6quv6rffftPgwYMVGxurgwcPasmSJTk6ACzT7NmzdfbsWdWoUcNh/eWXX9bs2bM1bdo0HTx4UJMmTdJ3332nl156SZIUFRWl6tWrq3fv3vrzzz/1yy+/6LXXXrO7jx49eqhs2bLq1KmTfvnlFx09elTr1q3TkCFDlJiYmKvXFAUnKSlJsbGxdpebf0HcaurUqfr++++1b98+DRo0SBcuXLD9kTR69GgtWbJEhw4d0u7du/XDDz/Y3sfdunVT+fLl1blzZ23cuFFHjhzRt99+m2XpuNyIiIjQhg0bdPz4cZ09e1aS9Nhjj6lYsWIaO3as7XN58uTJbH/59+jRQxaLRb169dK2bdt06NAhzZw5U5MnT9aLL76Y596qV6+uHj16qFevXvruu+909OhRbd68WTExMVq2bJmkGz8bVq5cqd9++0179+7VM888k+Vo7IJSo0YNRUVF6emnn9bmzZv1xx9/6Omnn5a/v79try/yX5cuXeTt7a2pU6eqZMmSeumllzRs2DDNmTNHhw8f1vbt2/XRRx/ZDkgKDw+XxWLRDz/8oDNnztitTHCratWq6dq1a/roo4905MgRzZ071+4AwrzISY/PPvusDh48qJdffln79+/XggULcr0+bM2aNXX27Nksy3RlioqKUt26ddWjRw9t375dmzdvVq9evdS6dWs1adJEkjR06FDNnDlTs2bN0oEDBzRmzBjt3r3b7n7GjRunmJgYffjhhzpw4IB27typWbNmadKkSbl/cTwAYbYQ++mnn1ShQgVVqFBBzZs315YtW/T111+rTZs2kqRHHnlEw4YN0+DBg9WgQQP99ttvGjVqlO323t7eOnfunHr16qXq1avriSeeUPv27TVu3DhJN/ZorV+/XgcOHNADDzyghg0bavTo0XbzV+/E39//tmtOdu7cWR988IHee+891a5dW5988olmzZplew5eXl76/vvvdfXqVTVr1kwDBgzQW2+9ZXcfxYoV04YNGxQWFqZHH31UNWvWtC2FcvP8YLiXdevWqWHDhnaXzPeeIxMmTNCECRNUv359/frrr1q6dKltxQIfHx+NHDlS9erVU6tWreTt7W1bAN3Hx0c///yzypUrp4cfflh169bVhAkTnPo674033lBcXJyqVq1qm8qyYcMG7dq1S+Hh4bbPZYUKFbIN6KVKldIvv/yia9eu6ZFHHlGDBg304YcfatKkSXrmmWfy3JskzZo1S7169dKLL76o++67T507d9aWLVts04Nef/11NWrUSNHR0WrTpo0t7LvKF198oeDgYLVq1Ur/+te/NHDgQJUsWVJ+fn4u68nTFSlSRIMHD9Y777yjy5cv680339SoUaMUExOjmjVrql27dlq2bJltT2FISIjGjRunESNGKDg4+LY7NerXr69Jkybp7bffVp06dTR//nzFxMQ43fOdegwLC9O3336rxYsXq379+po+fbrGjx+f68e55557sp2eZLFYtGTJEpUuXVqtWrVSVFSUqlSpokWLFtm26dq1q0aNGqVXXnlFjRs3Vnx8vJ577jm7+xkwYIA+++wzzZo1S3Xr1lXr1q01e/bsQrtn1mIYhuHqJgDgbomLi1PlypX1xx9/cJrUQiIxMVGhoaFatWqVHnzwQVe3A+Au4wAwAICprVmzRikpKapbt65OnDihV155RREREWrVqpWrWwNQAAizAABTu3btmv7zn//oyJEjKlmypFq0aKH58+fn+SA4AObCNAMAAACYFgeAAQAAwLQIswAAADAtwiwAAABMizALAAAA0yLMAgAAwLQIswDgIdq0aaMXXngh3+937NixnHACgNsizAJAAejTp48sFoueffbZLLVBgwbJYrGoT58+ObqvdevWyWKx6OLFi/nbJACYEGEWAApIaGioFi5cqKtXr9rGUlNTtWDBAoWFhbmwMwAwL8IsABSQRo0aKTQ0VN99951t7LvvvlNYWJgaNmxoG7NarYqJiVHlypXl7++v+vXr65tvvpEkxcXFqW3btpKk0qVLZ9mja7Va9corr6hMmTIqX768xo4da9dDQkKCOnXqpBIlSiggIEBPPPGETp06ZbfNhAkTFBwcrJIlS6p///5KTU3N51cCAPIPYRYAClC/fv00a9Ys2/WZM2eqb9++dtvExMToiy++0PTp07V7924NGzZMTz31lNavX6/Q0FB9++23kqT9+/frxIkT+uCDD2y3nTNnjooXL67ff/9d77zzjt544w2tXLlS0o2g26lTJ50/f17r16/XypUrdeTIEXXt2tV2+6+++kpjx47V+PHjtXXrVlWoUEEff/zx3XxJAMApnM4WAApAnz59dPHiRc2YMUOhoaHav3+/JKlGjRo6duyYBgwYoFKlSumTTz5RmTJltGrVKkVGRtpuP2DAAF25ckULFizQunXr1LZtW124cEGlSpWybdOmTRtlZGTol19+sY01a9ZMf//73zVhwgStXLlS7du319GjRxUaGipJ2rNnj2rXrq3NmzeradOmatGihRo2bKipU6fa7uP+++9XamqqYmNj7+6LBAB5UMTVDQBAYRIUFKQOHTpo9uzZMgxDHTp0UNmyZW31Q4cO6cqVK/rHP/5hd7v09HS7qQjZqVevnt31ChUq6PTp05KkvXv3KjQ01BZkJalWrVoqVaqU9u7dq6ZNm2rv3r1ZDlKLjIzU2rVrc/1cAaAgEGYBoID169dPgwcPliS7PaCSlJKSIklatmyZQkJC7Gq+vr53vO+iRYvaXbdYLLJarc60CwBujTmzAFDA2rVrp/T0dF27dk3R0dF2tVq1asnX11cJCQmqVq2a3SVzj6qPj48kKSMjI1ePW7NmTR07dkzHjh2zje3Zs0cXL15UrVq1bNv8/vvvdrf73//+l+vnCAAFhT2zAFDAvL29tXfvXtv/36xkyZJ66aWXNGzYMFmtVv3tb39TUlKSNm7cqICAAPXu3Vvh4eGyWCz64Ycf9PDDD8vf318lSpS44+NGRUWpbt266tGjhyZPnqzr16/r+eefV+vWrdWkSRNJ0tChQ9WnTx81adJELVu21Pz587V7925VqVIl/18IAMgH7JkFABcICAhQQECAw9qbb76pUaNGKSYmRjVr1lS7du20bNkyVa5cWZIUEhKicePGacSIEQoODrZNWbgTi8WiJUuWqHTp0mrVqpWioqJUpUoVLVq0yLZN165dNWrUKL3yyitq3Lix4uPj9dxzzzn/hAHgLmE1AwAAAJgWe2YBAABgWoRZAAAAmBZhFgAAAKZFmAUAAIBpEWYBAABgWoRZAAAAmBZhFgAAAKZFmAUAAIBpEWYBAABgWoRZAAAAmBZhFgAAAKb1/wH3jUn0nwtSKAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "make_boxplot(\n",
    "    [base_entropy_list, lip_entropy_list, retrain_entropy_list],\n",
    "    title=\"Entropy of Model Retain Set Predictions\",\n",
    "    x_label=\"Method\",\n",
    "    y_label=\"Entropy\",\n",
    "    x_ticklabels=[\"Base Model\", \"Lipschitz Unlearning\", \"Retrained Model\"],\n",
    "    save_path=\"entropy.png\",)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Retain Set: \n",
      "\n",
      "Wilcoxon for Base model and Retrained model: p=0.0\n",
      "Wilcoxon for Base model and Lipschitz model: p=0.0\n",
      "Wilcoxon for Lipschitz model and Retrained model: p=0.0\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import wilcoxon\n",
    "print(\"Retain Set: \\n\")\n",
    "print(f'Wilcoxon for Base model and Retrained model: p={wilcoxon(base_entropy_list, retrain_entropy_list)[1]}')\n",
    "print(f'Wilcoxon for Base model and Lipschitz model: p={wilcoxon(base_entropy_list, lip_entropy_list)[1]}')\n",
    "print(f'Wilcoxon for Lipschitz model and Retrained model: p={wilcoxon(lip_entropy_list, retrain_entropy_list)[1]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "phd",
   "language": "python",
   "name": "python3"
  },
  "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
