{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "48fd13ea-ab04-44c0-bc9e-9d7af3df8647",
   "metadata": {},
   "source": [
    "# Note!\n",
    "\n",
    "To run this notebook, you first need to train models using the bash script we provide. Then in the cell number 3 enter the Path to a valid model.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bc84cd66-aaae-4e71-9199-d42e126ba4eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, \"../\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "90f1535d-b123-4953-9b61-9a95b549fd25",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "from tqdm.auto import tqdm\n",
    "from src.config.models import NatPnModel, LeNet5, ResNet18\n",
    "from src.config.nat_pn.loss import BayesianLoss\n",
    "from src.config.uncertainty_metrics import (\n",
    "    load_dataset,\n",
    "    load_dataloaders,\n",
    "    choose_threshold,\n",
    "    load_model,\n",
    ")\n",
    "from src.config.utils import evaluate_accuracy, evaluate_switch, quantiles\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from collections import defaultdict\n",
    "import csv\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ed80ca3-ff3e-4c0d-91d5-bc0d96e0d6cb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0d34caac-1a0f-47d8-b13e-773541997643",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dataset_name = 'mnist' # mnist fmnist cifar10 medmnistA medmnistC medmnistS svhn\n",
    "ood_dataset_name = 'fmnist' # mnist fmnist cifar10 medmnistA medmnistC medmnistS svhn\n",
    "prefix = \"None\"\n",
    "\n",
    "path = # YOUR PATH TO A VALID MODEL IS HERE\n",
    "# for example \n",
    "# path=f\"../out/FedAvg/actual_models/{prefix}all_params_stopgrad_logp_{dataset_name}_100_natpn.pt\"\n",
    "\n",
    "\n",
    "backbone = 'res18' if dataset_name in ['cifar10', 'svhn'] else 'lenet5'\n",
    "stopgrad = True\n",
    "\n",
    "criterion = BayesianLoss(entropy_weight=0.0, log_prob_weight=0.01, embeddings_weight=1.0,\n",
    "                           reduction='sum')\n",
    "\n",
    "device = 'cuda:1'\n",
    "all_params_dict = torch.load(path, map_location=device)\n",
    "\n",
    "batch_size = 4000 if dataset_name in ['cifar10', 'svhn'] else 25000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "220c8f46-cbc2-43e6-9ff0-9783fb64ab62",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c895d036-3cd1-4230-90fd-294f9b289e12",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_indices_ind, trainset_ind, testset_ind = load_dataset(dataset_name=dataset_name)\n",
    "data_indices_ood, trainset_ood, testset_ood = load_dataset(dataset_name=ood_dataset_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "747093f1-2d90-479e-989c-0f42245e2980",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "trainset_ind = trainset_ind.dataset\n",
    "trainset_ood = trainset_ood.dataset\n",
    "trainset_ood.targets = -1. * (1 + trainset_ood.targets)\n",
    "\n",
    "loader = torch.utils.data.DataLoader(torch.utils.data.ConcatDataset([trainset_ind, trainset_ood]), batch_size=batch_size, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "40e1cce8-d474-4ff8-999e-453844bbe9a3",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f516af52-e5b4-4c19-900a-a6aec3eab340",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93ac5a1d-7271-4b64-9f9a-461c6e4c76d4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b01d6343-a4e5-4db2-950d-6a035e89f4f8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "!\n"
     ]
    }
   ],
   "source": [
    "global_model = load_model(\n",
    "    dataset_name=dataset_name,\n",
    "    backbone=backbone,\n",
    "    stopgrad=stopgrad,\n",
    "    index=\"global\",\n",
    "    all_params_dict=all_params_dict,\n",
    "    )\n",
    "global_model.eval()\n",
    "global_model.to(device)\n",
    "print('!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "54abcfef-fc2f-4700-965b-8a0d6e9ccef8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "measure = 'log_prob'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "fe5c483b-5b64-49ed-9178-1305d61a5edd",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from tqdm.auto import tqdm\n",
    "from sklearn.metrics import confusion_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40a1aa00-3963-4fd4-93f6-9c9d9a4e0ed7",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "all_precisions = {}\n",
    "for model_id in tqdm(range(len(all_params_dict) - 1)):\n",
    "    precision_for_model = {}\n",
    "    \n",
    "    model = load_model(\n",
    "        dataset_name=dataset_name,\n",
    "        backbone=backbone,\n",
    "        stopgrad=stopgrad,\n",
    "        index=model_id,\n",
    "        all_params_dict=all_params_dict,\n",
    "        )\n",
    "    model.eval()\n",
    "    model.to(device)\n",
    "    \n",
    "    data_indices_ind, trainset_ind, testset_ind = load_dataset(dataset_name=dataset_name)\n",
    "    \n",
    "    _, _, calloader = load_dataloaders(\n",
    "        client_id=model_id, data_indices=data_indices_ind,\n",
    "        trainset=trainset_ind, testset=testset_ind, batch_size=batch_size,)\n",
    "    \n",
    "    thresholds_ind, scores_ind = choose_threshold(\n",
    "        model=model,\n",
    "        calloader=calloader,\n",
    "        device=device,\n",
    "        alpha=quantiles[dataset_name],\n",
    "    )\n",
    "    \n",
    "    _, _, _, _, local_ind, global_ind, switch_ind, true_ind, scores_local_ind, scores_global_ind = evaluate_switch(\n",
    "        local_model=model, \n",
    "        global_model=global_model,\n",
    "        dataloader=loader,\n",
    "        threshold=thresholds_ind[measure],\n",
    "        uncertainty_measure=measure,\n",
    "        device=device,\n",
    "        return_predictions=True,\n",
    "    )\n",
    "    \n",
    "    if measure != 'log_prob':\n",
    "        switch_happened_ind = torch.hstack(scores_local_ind) > thresholds_ind[measure]\n",
    "    else:\n",
    "        switch_happened_ind = torch.hstack(scores_local_ind) < thresholds_ind[measure]\n",
    "\n",
    "    \n",
    "    scores_global_ind = np.hstack(scores_global_ind)\n",
    "    switch_ind = torch.hstack(switch_ind).numpy()\n",
    "    true_ind = torch.hstack(true_ind).numpy()\n",
    "    \n",
    "    for label in global_model.labels.cpu().numpy():\n",
    "        precision_for_model[label] = []\n",
    "        for delta in np.linspace(0, 0.99, 11):\n",
    "            other_scores = scores_global_ind[switch_happened_ind]\n",
    "            global_threshold = np.quantile(other_scores, q=delta)\n",
    "            selected_indices = np.logical_and(switch_happened_ind.numpy(),\n",
    "                                              (scores_global_ind > global_threshold))\n",
    "            \n",
    "            # print(selected_indices.sum())\n",
    "            tp = ((switch_ind[~switch_happened_ind] == label) & (switch_ind[~switch_happened_ind] == true_ind[~switch_happened_ind])).sum()\n",
    "            tp += ((switch_ind[selected_indices] == label) & (switch_ind[selected_indices] == true_ind[selected_indices])).sum()\n",
    "            \n",
    "            fp = ((switch_ind[~switch_happened_ind] == label) & (switch_ind[~switch_happened_ind] != true_ind[~switch_happened_ind])).sum()\n",
    "            fp += ((switch_ind[selected_indices] == label) & (switch_ind[selected_indices] != true_ind[selected_indices])).sum()\n",
    "            \n",
    "            precision = 1 if np.isnan(tp / (tp + fp)) else tp / (tp + fp)            \n",
    "            precision_for_model[label].append(precision)\n",
    "            \n",
    "    all_precisions[model_id] = precision_for_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e2108695-6d37-4ab0-99c3-25960c7c67d4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# To ease plotting, just save current results in a variable to reuse it later\n",
    "\n",
    "# from copy import deepcopy\n",
    "# all_precisions_MNISTFMNIST = deepcopy(all_precisions)\n",
    "# all_precisions_FMNISTMNIST = deepcopy(all_precisions)\n",
    "\n",
    "# all_precisions_MedMNISTAFMNIST = deepcopy(all_precisions)\n",
    "# all_precisions_MedMNISTCFMNIST = deepcopy(all_precisions)\n",
    "# all_precisions_MedMNISTSFMNIST = deepcopy(all_precisions)\n",
    "\n",
    "# all_precisions_CIFAR10SVHN = deepcopy(all_precisions)\n",
    "# all_precisions_SVHNCIFAR10 = deepcopy(all_precisions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb032142-ef08-45ee-8f2a-00b1994bbb8f",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cf40afd9-410e-4702-b751-4e7d8df268cc",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# all_precisions = all_precisions_MNISTFMNIST\n",
    "# all_precisions = all_precisions_FMNISTMNIST\n",
    "\n",
    "# all_precisions = all_precisions_MedMNISTAFMNIST\n",
    "# all_precisions = all_precisions_MedMNISTCFMNIST\n",
    "# all_precisions = all_precisions_MedMNISTSFMNIST\n",
    "\n",
    "# all_precisions = all_precisions_CIFAR10SVHN\n",
    "# all_precisions = all_precisions_SVHNCIFAR10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "06a46ba4-0952-4b60-9486-34b83ce9fffb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "def pretty_matplotlib_config(fontsize=15):\n",
    "    matplotlib.rcParams['pdf.fonttype'] = 42\n",
    "    matplotlib.rcParams['ps.fonttype'] = 42\n",
    "    matplotlib.rcParams['text.usetex'] = True\n",
    "    matplotlib.rcParams.update({'font.size': fontsize})\n",
    "    \n",
    "pretty_matplotlib_config(40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "69acbd4f-2ff0-4350-8251-a676c7b4037c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1b22b4e6-b19b-4e7b-b8fc-605ffd319f3d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from collections import defaultdict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b3be7987-1df0-4530-a0ba-bbf6ddc8c0fd",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "class2values = defaultdict(list)\n",
    "\n",
    "for model_id in all_precisions:\n",
    "    for class_label in all_precisions[model_id]:\n",
    "        class2values[class_label].append(all_precisions[model_id][class_label])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "eaa6bffd-7fe7-463e-bd2d-89beb06140dd",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "precision_per_class = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "6b22146a-e4b5-4d80-b10f-acf56dba48f2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for class_label in class2values:\n",
    "    precision_per_class[class_label] = np.vstack(class2values[class_label]).mean(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd67d8d5-dce7-46c6-b85e-7a774a1af38a",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "0448171f-55dd-4500-80b8-0a34766673b7",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.4122244416388073\n"
     ]
    }
   ],
   "source": [
    "improvements = []\n",
    "for class_label in precision_per_class:\n",
    "    if not np.isnan(precision_per_class[class_label][0]):\n",
    "        improvements.append((precision_per_class[class_label][5] - precision_per_class[class_label][0]) / precision_per_class[class_label][0])\n",
    "print(np.mean(improvements))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc2aa4d8-71e6-4076-96a9-5de1f04976e8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e140dea4-bfda-44aa-bb71-7cce6669fb80",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "a39ba425-a031-4bd5-b934-65654fdc05c7",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "class_label = 1\n",
    "\n",
    "plt.figure(figsize=(10, 8), dpi=100)\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 11), precision_per_class[class_label])\n",
    "\n",
    "x_values = [0, 0.25, 0.5, 0.75, 1.0]\n",
    "y_values = [0.25, 0.5, 0.75, 1.0]\n",
    "# x_labels = ['zero', 'two', 'four', 'six', 'eight', 'ten']\n",
    "plt.xticks(x_values, )\n",
    "plt.yticks(y_values, )\n",
    "\n",
    "# plt.ylim(0.4, 1)\n",
    "\n",
    "# plt.axis('equal')\n",
    "plt.tight_layout()\n",
    "# plt.savefig('mnist_precision.pdf', format='pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4997078-edc5-41f5-94d5-95bf99b8c245",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f1ad3d1-753d-4293-8422-f929bcc83bf4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
