{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "71bc8ec3",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import src.dp_sgd.warning_ignores\n",
    "\n",
    "import numpy as np\n",
    "import torch \n",
    "\n",
    "import optuna\n",
    "from tqdm import tqdm\n",
    "\n",
    "import random\n",
    "import gc\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from tueplots import figsizes, fontsizes, fonts\n",
    "\n",
    "from src.dp_sgd.model import LinearHead\n",
    "from src.dp_sgd.train import train_with_dp, evaluate, AccuracyFirstDPSGD, DPSGDHyperparameters\n",
    "from src.dp_sgd.config import num_classes, shots, min_epsilon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efe2280c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cpu\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[I 2025-11-27 15:08:03,879] Using an existing study with name 'accuracy_first_dp_sgd_ex_post_conversion' instead of creating a new one.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best hyperparams, validation accuracy: 73.33333333333333\n",
      "{'learning_rate': 0.0010079450863093827, 'max_grad_norm': 7.158801910151741, 'num_epochs': 95, 'batch_size': 62}\n"
     ]
    }
   ],
   "source": [
    "# device = torch.accelerator.current_accelerator()\n",
    "device = \"cpu\"\n",
    "print(device)\n",
    "\n",
    "seed = 34538979\n",
    "torch.manual_seed(seed)\n",
    "torch.mps.manual_seed(seed)\n",
    "np.random.seed(seed)\n",
    "random.seed(seed)\n",
    "\n",
    "train_features = torch.load(f\"datasets/cifar10/few_shot_{shots}_train_vit-b-16-imagenet-21K_features.pt\")\n",
    "train_labels = torch.load(f\"datasets/cifar10/few_shot_{shots}_train_labels.pt\")\n",
    "train_dataset = torch.utils.data.TensorDataset(train_features, train_labels)\n",
    "\n",
    "validation_features = torch.load(f\"datasets/cifar10/few_shot_{shots}_validation_vit-b-16-imagenet-21K_features.pt\")\n",
    "validation_labels = torch.load(f\"datasets/cifar10/few_shot_{shots}_validation_labels.pt\")\n",
    "validation_dataset = torch.utils.data.TensorDataset(validation_features, validation_labels)\n",
    "\n",
    "test_features = torch.load(f\"datasets/cifar10/test_vit-b-16-imagenet-21K_features.pt\")\n",
    "test_labels = torch.load(f\"datasets/cifar10/test_labels.pt\")\n",
    "test_dataset = torch.utils.data.TensorDataset(test_features, test_labels)\n",
    "\n",
    "feature_dim = train_features.shape[1]\n",
    "\n",
    "study_name = \"accuracy_first_dp_sgd_ex_post_conversion\"\n",
    "storage_name = f\"sqlite:///results/accuracy-first/dp-sgd/{study_name}_hyperparameters.db\"\n",
    "\n",
    "study = optuna.create_study(study_name=study_name, storage=storage_name, direction=\"maximize\", load_if_exists=True)\n",
    "\n",
    "print(f\"Best hyperparams, validation accuracy: {study.best_value}\")\n",
    "print(study.best_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "38b68cac",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = LinearHead(input_dim=feature_dim, num_classes=num_classes).to(device)\n",
    "accuracy_first_trainer = AccuracyFirstDPSGD(\n",
    "    model=model, \n",
    "    hyperparameters=DPSGDHyperparameters(**study.best_params),\n",
    "    device=device,\n",
    "    delta=1 / len(train_dataset)\n",
    ")\n",
    "results, threshold_check_variance = accuracy_first_trainer.accuracy_first_train(\n",
    "    accuracy_threshold=0.84,\n",
    "    train_dataset=train_dataset,\n",
    "    test_dataset=test_dataset,\n",
    "    validation_dataset=validation_dataset,\n",
    "    initial_epsilon=min_epsilon,\n",
    "    max_releases=5,\n",
    "    epochs_per_release=50,\n",
    "    public_validation_set=False,\n",
    "    seed=653688,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "31d2c42c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[AccuracyFirstTrainingResult(validation_accuracy=0.83, test_accuracy=0.8254, additional_epochs=0, epsilon=np.float64(1.497188034374356)),\n",
       " AccuracyFirstTrainingResult(validation_accuracy=0.84, test_accuracy=0.8358, additional_epochs=50, epsilon=np.float64(1.8706713835137867))]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "df642a75",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.009956056411065025)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sqrt(threshold_check_variance)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "52b20102",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_repeats = 50\n",
    "accuracy_threshold = 0.85\n",
    "private_validation_max_releases = 5\n",
    "private_validation_epochs_per_release = 100\n",
    "public_validation_max_releases = 10\n",
    "public_validation_epochs_per_release = 50\n",
    "is_validation_public_list = [True, False]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8136f705",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "seed = 9098765\n",
    "torch.manual_seed(seed)\n",
    "torch.mps.manual_seed(seed)\n",
    "np.random.seed(seed)\n",
    "random.seed(seed)\n",
    "\n",
    "records = []\n",
    "for public_validation in is_validation_public_list:\n",
    "    print(f\"Running validation public: {public_validation}\")\n",
    "    for repeat_ind in tqdm(range(n_repeats)):\n",
    "        if public_validation:\n",
    "            max_releases = public_validation_max_releases\n",
    "            epochs_per_release = public_validation_epochs_per_release\n",
    "        else:\n",
    "            max_releases = private_validation_max_releases\n",
    "            epochs_per_release = private_validation_epochs_per_release\n",
    "\n",
    "        seed = torch.randint(0, 2**31 - 1, (1,)).item()\n",
    "        model = LinearHead(input_dim=feature_dim, num_classes=num_classes).to(device)\n",
    "        accuracy_first_trainer = AccuracyFirstDPSGD(\n",
    "            model=model, \n",
    "            hyperparameters=DPSGDHyperparameters(**study.best_params),\n",
    "            device=device,\n",
    "            delta=1 / len(train_dataset)\n",
    "        )\n",
    "        results, _ = accuracy_first_trainer.accuracy_first_train(\n",
    "            accuracy_threshold=accuracy_threshold,\n",
    "            train_dataset=train_dataset,\n",
    "            validation_dataset=validation_dataset,\n",
    "            test_dataset=test_dataset,\n",
    "            initial_epsilon=min_epsilon,\n",
    "            max_releases=max_releases,\n",
    "            epochs_per_release=epochs_per_release,\n",
    "            public_validation_set=public_validation,\n",
    "            seed=seed,\n",
    "        )\n",
    "\n",
    "        for i, res in enumerate(results):\n",
    "            records.append({\n",
    "                \"Validation Accuracy\": res.validation_accuracy,\n",
    "                \"Test Accuracy\": res.test_accuracy,\n",
    "                \"Additional Epochs\": res.additional_epochs,\n",
    "                \"Epsilon\": res.epsilon, \n",
    "                \"repeat_ind\": repeat_ind, \n",
    "                \"is_final\": i == len(results) - 1,\n",
    "                \"Public Validation\": public_validation,\n",
    "            })\n",
    "\n",
    "result_df = pd.DataFrame.from_records(records)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "be4dbaba",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_df.to_csv(\"results/accuracy-first/dp-sgd/results.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "fb602c2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_df = pd.read_csv(\"results/accuracy-first/dp-sgd/results.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e775475f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def output_status(is_final, additional_epochs, accuracy, public_validation):\n",
    "    if public_validation:\n",
    "        max_releases = public_validation_max_releases\n",
    "        epochs_per_release = public_validation_epochs_per_release\n",
    "    else:\n",
    "        max_releases = private_validation_max_releases\n",
    "        epochs_per_release = private_validation_epochs_per_release\n",
    "    if not is_final:\n",
    "        return \"Rejected Output\"\n",
    "    elif additional_epochs == (max_releases - 1) * epochs_per_release and accuracy < accuracy_threshold:\n",
    "        return \"Never Exceeded Threshold\"\n",
    "    else:\n",
    "        return \"Accepted Output\"\n",
    "\n",
    "result_df[\"Epsilon Rounded\"] = [round(eps, 2) for eps in result_df.Epsilon]\n",
    "result_df[\"Status\"] = [\n",
    "    output_status(is_final, additional_epochs, accuracy, public_validation) \n",
    "    for is_final, additional_epochs, accuracy, public_validation\n",
    "    in zip(result_df[\"is_final\"], result_df[\"Additional Epochs\"], result_df[\"Validation Accuracy\"], result_df[\"Public Validation\"])\n",
    "]\n",
    "result_df[\"Validation Privacy\"] = [\"Public Validation\" if public_validation else \"Private Validation\" for public_validation in result_df[\"Public Validation\"]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4d77c389",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Validation Accuracy</th>\n",
       "      <th>Test Accuracy</th>\n",
       "      <th>Additional Epochs</th>\n",
       "      <th>Epsilon</th>\n",
       "      <th>repeat_ind</th>\n",
       "      <th>is_final</th>\n",
       "      <th>Public Validation</th>\n",
       "      <th>Epsilon Rounded</th>\n",
       "      <th>Status</th>\n",
       "      <th>Validation Privacy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.814</td>\n",
       "      <td>0.8250</td>\n",
       "      <td>0</td>\n",
       "      <td>1.497188</td>\n",
       "      <td>0</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>1.50</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Public Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.834</td>\n",
       "      <td>0.8354</td>\n",
       "      <td>50</td>\n",
       "      <td>1.870671</td>\n",
       "      <td>0</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>1.87</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Public Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.840</td>\n",
       "      <td>0.8440</td>\n",
       "      <td>100</td>\n",
       "      <td>2.190355</td>\n",
       "      <td>0</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>2.19</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Public Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.850</td>\n",
       "      <td>0.8558</td>\n",
       "      <td>150</td>\n",
       "      <td>2.476281</td>\n",
       "      <td>0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>2.48</td>\n",
       "      <td>Accepted Output</td>\n",
       "      <td>Public Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.806</td>\n",
       "      <td>0.8355</td>\n",
       "      <td>0</td>\n",
       "      <td>1.497188</td>\n",
       "      <td>1</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>1.50</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Public Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>428</th>\n",
       "      <td>0.834</td>\n",
       "      <td>0.8473</td>\n",
       "      <td>100</td>\n",
       "      <td>2.190355</td>\n",
       "      <td>48</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "      <td>2.19</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Private Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>429</th>\n",
       "      <td>0.846</td>\n",
       "      <td>0.8611</td>\n",
       "      <td>200</td>\n",
       "      <td>2.738207</td>\n",
       "      <td>48</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>2.74</td>\n",
       "      <td>Accepted Output</td>\n",
       "      <td>Private Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>430</th>\n",
       "      <td>0.808</td>\n",
       "      <td>0.8163</td>\n",
       "      <td>0</td>\n",
       "      <td>1.497188</td>\n",
       "      <td>49</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "      <td>1.50</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Private Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>431</th>\n",
       "      <td>0.836</td>\n",
       "      <td>0.8387</td>\n",
       "      <td>100</td>\n",
       "      <td>2.190355</td>\n",
       "      <td>49</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "      <td>2.19</td>\n",
       "      <td>Rejected Output</td>\n",
       "      <td>Private Validation</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>432</th>\n",
       "      <td>0.866</td>\n",
       "      <td>0.8546</td>\n",
       "      <td>200</td>\n",
       "      <td>2.738207</td>\n",
       "      <td>49</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>2.74</td>\n",
       "      <td>Accepted Output</td>\n",
       "      <td>Private Validation</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>433 rows × 10 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Validation Accuracy  Test Accuracy  Additional Epochs   Epsilon  \\\n",
       "0                  0.814         0.8250                  0  1.497188   \n",
       "1                  0.834         0.8354                 50  1.870671   \n",
       "2                  0.840         0.8440                100  2.190355   \n",
       "3                  0.850         0.8558                150  2.476281   \n",
       "4                  0.806         0.8355                  0  1.497188   \n",
       "..                   ...            ...                ...       ...   \n",
       "428                0.834         0.8473                100  2.190355   \n",
       "429                0.846         0.8611                200  2.738207   \n",
       "430                0.808         0.8163                  0  1.497188   \n",
       "431                0.836         0.8387                100  2.190355   \n",
       "432                0.866         0.8546                200  2.738207   \n",
       "\n",
       "     repeat_ind  is_final  Public Validation  Epsilon Rounded  \\\n",
       "0             0     False               True             1.50   \n",
       "1             0     False               True             1.87   \n",
       "2             0     False               True             2.19   \n",
       "3             0      True               True             2.48   \n",
       "4             1     False               True             1.50   \n",
       "..          ...       ...                ...              ...   \n",
       "428          48     False              False             2.19   \n",
       "429          48      True              False             2.74   \n",
       "430          49     False              False             1.50   \n",
       "431          49     False              False             2.19   \n",
       "432          49      True              False             2.74   \n",
       "\n",
       "              Status  Validation Privacy  \n",
       "0    Rejected Output   Public Validation  \n",
       "1    Rejected Output   Public Validation  \n",
       "2    Rejected Output   Public Validation  \n",
       "3    Accepted Output   Public Validation  \n",
       "4    Rejected Output   Public Validation  \n",
       "..               ...                 ...  \n",
       "428  Rejected Output  Private Validation  \n",
       "429  Accepted Output  Private Validation  \n",
       "430  Rejected Output  Private Validation  \n",
       "431  Rejected Output  Private Validation  \n",
       "432  Accepted Output  Private Validation  \n",
       "\n",
       "[433 rows x 10 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a4b5029c",
   "metadata": {},
   "outputs": [],
   "source": [
    "figsize_factory = figsizes.icml2024_full\n",
    "plt.rcParams.update(fontsizes.icml2024())\n",
    "plt.rcParams.update(fonts.icml2024_tex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7cea3e5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "hue_order = [\"Public Validation\", \"Private Validation\"]\n",
    "is_validation_public_colors = {\n",
    "    \"Public Validation\": \"tan\",\n",
    "    \"Private Validation\": \"turquoise\",\n",
    "}\n",
    "\n",
    "eps_label = r\"Epsilon (ADP, $\\delta = 1/n_{\\mathrm{train}}$)\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02736472",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 675x168.75 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 2, figsize=figsize_factory(nrows=1, ncols=2, height_to_width_ratio=0.5)[\"figure.figsize\"], sharey=True)\n",
    "\n",
    "\n",
    "for i, public_validation in enumerate(is_validation_public_list):\n",
    "    ax = axes[i]\n",
    "    subset_df = result_df[result_df[\"Public Validation\"] == public_validation]\n",
    "    sns.swarmplot(\n",
    "        data=subset_df, x=\"Epsilon Rounded\", y=\"Validation Accuracy\", \n",
    "        hue=\"Status\", hue_order=[\"Rejected Output\", \"Accepted Output\", \"Never Exceeded Threshold\"], \n",
    "        ax=ax, legend=True, size=1.5 if public_validation else 2.6, dodge=True\n",
    "    )\n",
    "    ax.axhline(accuracy_threshold, color=\"grey\", linestyle=\"dashed\", label=\"Accuracy Threshold\")\n",
    "    ax.set_xlabel(eps_label)\n",
    "    ax.set_ylabel(\"Validation Accuracy\")\n",
    "    leg_info = ax.get_legend_handles_labels()\n",
    "    ax.get_legend().remove()\n",
    "    if public_validation:\n",
    "        ax.set_title(\"All Releases - Public Validation Data\")\n",
    "    else:\n",
    "        ax.set_title(\"All Releases - Private Validation Data\")\n",
    "\n",
    "fig.legend(*leg_info, ncol=2, loc=\"upper center\", bbox_to_anchor=(0.5, -0.12)) # type: ignore\n",
    "plt.savefig(f\"figures/dp-sgd/output-plots.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2f6ac4b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x169.959 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "final_result_df = result_df[result_df[\"is_final\"]].copy()\n",
    "final_epsilon_count_df = final_result_df.groupby(\"Validation Privacy\").value_counts(subset=[\"Epsilon Rounded\"], normalize=True).reset_index()\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=figsize_factory(nrows=1, ncols=1, rel_width=0.5)[\"figure.figsize\"])\n",
    "sns.barplot(data=final_epsilon_count_df, x=\"Epsilon Rounded\", y=\"proportion\", hue=\"Validation Privacy\", hue_order=hue_order, palette=is_validation_public_colors, ax=ax)\n",
    "ax.set_ylabel(\"Proportion\")\n",
    "ax.set_xlabel(eps_label)\n",
    "ax.set_title(\"Distribution of Final Epsilon\")\n",
    "plt.savefig(\"figures/dp-sgd/final-epsilon-distribution.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "229d953a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_legend_handles_labels_fix(ax):\n",
    "    handles = ax.legend_.legend_handles\n",
    "    labels = [t.get_text() for t in ax.legend_.get_texts()]\n",
    "    return handles, labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "920cd5fc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x169.959 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=figsize_factory(nrows=1, ncols=1, rel_width=0.5)[\"figure.figsize\"])\n",
    "sns.ecdfplot(data=final_result_df, x=\"Validation Accuracy\", hue=\"Validation Privacy\", hue_order=hue_order, palette=is_validation_public_colors, legend=True, ax=ax)\n",
    "sns_leg_info = get_legend_handles_labels_fix(ax)\n",
    "ax.axvline(accuracy_threshold, color=\"grey\", linestyle=\"dashed\", label=\"Accuracy Threshold\")\n",
    "leg_info = ax.get_legend_handles_labels()\n",
    "ax.get_legend().remove()\n",
    "ax.legend(sns_leg_info[0] + leg_info[0], sns_leg_info[1] + leg_info[1])\n",
    "ax.set_title(\"eCDF of Final Validation Accuracy\")\n",
    "plt.savefig(\"figures/dp-sgd/final-validation-accuracy-distribution.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73a347d9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x169.959 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=figsize_factory(nrows=1, ncols=1, rel_width=0.5)[\"figure.figsize\"])\n",
    "sns.ecdfplot(data=final_result_df, x=\"Test Accuracy\", hue=\"Validation Privacy\", hue_order=hue_order, palette=is_validation_public_colors, legend=True, ax=ax)\n",
    "sns_leg_info = get_legend_handles_labels_fix(ax)\n",
    "ax.axvline(accuracy_threshold, color=\"grey\", linestyle=\"dashed\", label=\"Accuracy Threshold\")\n",
    "leg_info = ax.get_legend_handles_labels()\n",
    "ax.get_legend().remove()\n",
    "ax.legend(sns_leg_info[0] + leg_info[0], sns_leg_info[1] + leg_info[1])\n",
    "ax.set_title(\"eCDF of Final Test Accuracy\")\n",
    "plt.savefig(\"figures/dp-sgd/final-test-accuracy-distribution.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b86d483",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x169.959 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=figsize_factory(nrows=1, ncols=1, rel_width=0.5)[\"figure.figsize\"])\n",
    "sns.swarmplot(data=final_result_df, x=\"Epsilon Rounded\", y=\"Validation Accuracy\", hue=\"Validation Privacy\", hue_order=hue_order, palette=is_validation_public_colors, dodge=True, size=2.6, ax=ax)\n",
    "ax.axhline(accuracy_threshold, color=\"grey\", linestyle=\"dashed\", label=\"Accuracy Threshold\")\n",
    "leg_info = ax.get_legend_handles_labels()\n",
    "ax.get_legend().remove()\n",
    "ax.legend(*leg_info, loc=\"upper center\", ncol=2, bbox_to_anchor=(0.4, -0.25))\n",
    "ax.set_title(\"Accepted Final Accuracy by Epsilon\")\n",
    "ax.set_xlabel(eps_label)\n",
    "plt.savefig(\"figures/dp-sgd/final-validation-accuracy-by-epsilon.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8176647",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x169.959 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=figsize_factory(nrows=1, ncols=1, rel_width=0.5)[\"figure.figsize\"])\n",
    "sns.swarmplot(data=final_result_df, x=\"Epsilon Rounded\", y=\"Test Accuracy\", hue=\"Validation Privacy\", hue_order=hue_order, palette=is_validation_public_colors, dodge=True, size=2.6, ax=ax)\n",
    "ax.axhline(accuracy_threshold, color=\"grey\", linestyle=\"dashed\", label=\"Accuracy Threshold\")\n",
    "leg_info = ax.get_legend_handles_labels()\n",
    "ax.get_legend().remove()\n",
    "ax.legend(*leg_info, loc=\"upper center\", ncol=2, bbox_to_anchor=(0.4, -0.25))\n",
    "ax.set_title(\"Final Test Accuracy by Epsilon\")\n",
    "ax.set_xlabel(eps_label)\n",
    "plt.savefig(\"figures/dp-sgd/final-test-accuracy-by-epsilon.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d676fbee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x169.959 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=figsize_factory(nrows=1, ncols=1, rel_width=0.5)[\"figure.figsize\"])\n",
    "sns.scatterplot(data=final_result_df, x=\"Validation Accuracy\", y=\"Test Accuracy\", hue=\"Validation Privacy\", palette=is_validation_public_colors, s=7.5, ax=ax)\n",
    "ax.plot((0.82, 0.89), (0.82, 0.89), color=\"grey\", linestyle=\"dashed\")\n",
    "ax.set_title(\"Final Validation vs. Test Accuracy\")\n",
    "plt.savefig(\"figures/dp-sgd/final-test-validation-accuracy-scatter.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0f24907",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "weakening-dp-bounds",
   "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.12.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
