{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "cwd = os.getcwd()\n",
    "module_path = \"/\".join(cwd.split('/')[0:-1])\n",
    "if module_path not in sys.path:\n",
    "    sys.path.append(module_path)\n",
    "import torch\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "import torch.backends.cudnn as cudnn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import dataloaders\n",
    "import Data.cifar10 as cifar10\n",
    "import Data.svhn as svhn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import network architectures\n",
    "from Net.resnet import resnet50, resnet110\n",
    "from Net.wide_resnet import wide_resnet_cifar\n",
    "from Net.densenet import densenet121"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import metrics to compute\n",
    "from Metrics.ood_test_utils import get_roc_auc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import plot related libraries\n",
    "import seaborn as sb\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Dataset params\n",
    "dataset_num_classes = {\n",
    "    'cifar10': 10,\n",
    "    'svhn': 10\n",
    "}\n",
    "\n",
    "dataset_loader = {\n",
    "    'cifar10': cifar10,\n",
    "    'svhn': svhn\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Mapping model name to model function\n",
    "models = {\n",
    "    'resnet50': resnet50,\n",
    "    'resnet110': resnet110,\n",
    "    'wide_resnet': wide_resnet_cifar,\n",
    "    'densenet121': densenet121,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Checking if GPU is available\n",
    "cuda = False\n",
    "if (torch.cuda.is_available()):\n",
    "    cuda = True\n",
    "\n",
    "# Setting additional parameters\n",
    "torch.manual_seed(1)\n",
    "device = torch.device(\"cuda\" if cuda else \"cpu\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "class args:\n",
    "    data_aug = True\n",
    "    gpu = device == \"cuda\"\n",
    "    train_batch_size = 128\n",
    "    test_batch_size = 128"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Using downloaded and verified file: ./data/test_32x32.mat\n"
     ]
    }
   ],
   "source": [
    "dataset = 'cifar10'\n",
    "ood_dataset = 'svhn'\n",
    "\n",
    "num_classes = dataset_num_classes[dataset]\n",
    "# train_loader, val_loader = dataset_loader[dataset].get_train_valid_loader(\n",
    "#     batch_size=args.train_batch_size,\n",
    "#     augment=args.data_aug,\n",
    "#     random_seed=1,\n",
    "#     pin_memory=args.gpu\n",
    "# )\n",
    "\n",
    "test_loader = dataset_loader[dataset].get_test_loader(\n",
    "    batch_size=args.test_batch_size,\n",
    "    pin_memory=args.gpu\n",
    ")\n",
    "\n",
    "\n",
    "# ood_train_loader, ood_val_loader = dataset_loader[ood_dataset].get_train_valid_loader(\n",
    "#     batch_size=args.train_batch_size,\n",
    "#     augment=args.data_aug,\n",
    "#     random_seed=1,\n",
    "#     pin_memory=args.gpu\n",
    "# )\n",
    "\n",
    "ood_test_loader = dataset_loader[ood_dataset].get_test_loader(\n",
    "    batch_size=args.test_batch_size,\n",
    "    pin_memory=args.gpu\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = '0'\n",
    "torch.cuda.device_count()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Resnet110"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC entropy based: 96.09588602489242\n"
     ]
    }
   ],
   "source": [
    "# AutoAdaptiveFocalLoss v2, gamma=1, lambda=1\n",
    "model_name = 'resnet110'\n",
    "saved_model_name = '../Experiments/adaFocal_15bins/cifar10_resnet110_adaFocal_v2_gamma1_lambda1_gammaMax20/resnet110_auto_adaptive_focal_loss_v2_1.0_350.model'\n",
    "model = models[model_name]\n",
    "\n",
    "net = model(num_classes=num_classes, temp=1.0)\n",
    "net.cuda()\n",
    "# net = torch.nn.DataParallel(net, device_ids=range(torch.cuda.device_count()))\n",
    "net = torch.nn.DataParallel(net, device_ids=[0])\n",
    "cudnn.benchmark = True\n",
    "net.load_state_dict(torch.load('./' + str(saved_model_name)))\n",
    "\n",
    "(fpr_entropy, tpr_entropy, thresholds_entropy), \\\n",
    "(fpr_confidence, tpr_confidence, thresholds_confidence), \\\n",
    "auc_entropy, auc_confidence = get_roc_auc(net, test_loader, ood_test_loader, device)\n",
    "\n",
    "print('AUC entropy based:', auc_entropy*100)\n",
    "fpr_entropy_resnet110_adafocal, tpr_entropy_resnet110_adafocal = fpr_entropy, tpr_entropy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([-0.2,  0. ,  0.2,  0.4,  0.6,  0.8,  1. ,  1.2]),\n",
       " <a list of 8 Text yticklabel objects>)"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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3ZEPcM8997Bjh9fNevPNN3PyyScD3rpI559/Po7jcN111/HEE0/w7LPPcuaZZ4647La2Nr7+9a/jOA5XXHEFX/7yl33no9Eoq1atYtWqVRP3gaaJEu7/KgzcN9t1Xf76q604do/venPfFl86XjVncisohJgyK1asGNX1l19+OV/96ld9eZdddhnr1q0D4Ne//jWnn376hNXvtUzTZP369WzatInNmzezd+9euru76enpQdM0KioqOProoznnnHNYu3YtodDgcd+T5VB/l5FIhKqqKo455hjOO+88zjvvvFnVo3XzzTfzox/9aELK2r59+4SUI6bWrA8i7733XgBOP/30YgA50Nq1a/n+979PY2Mj995776iCyP/+7/+mt7eXuro6rrvuugmr80zkJPLFY708WDze8Of9AFi5v/uu73nubyycmqoJIcQh7du3j/+fvfsOa+psMtcKSAAAIABJREFU/wD+TSCMsFFQQXEAIkjrruIeOKnW2fWKUq1aX2cdba3a9rWvim3VWou+rdaB9ecojrpqq9A6qoiiggoKIogEWbJJgIzz+yPlJBEygJAEuD/X5XWdw3nOOXcShJvnPM/9hISEqD0uEAggEAgQGRmJsLAwfPPNN+jZ0/jjuIVCIdLT05Geno7z58+jc+fO+O6779CxY0djh0aIThp1EikSiXD79m0AwODBg2tsw+FwMGjQIBw6dAh///13ra5flaBOmDCh3hNzTJ04S8humzkoksiCrH9K+jCKx91t/fzx6iHFeMiMtwbCt+FDJIQYQVhYmNY27dq1M0Ak2rVr1w7dunWDh4cHXFxc4OTkBJFIhKSkJJw7dw7Z2dkQCASYNWsWjh49is6dO2u/qB69/F4WFRXhzp07OH36NMrLy5GUlIRZs2bhxIkTcHQ0/SXAxo0bB19f9T/9v/32WyQnJwMAlixZYvD3mzS8Rp1EpqSksEv5eHt7q21XdSw3NxeFhYU6/ed89uwZcnJyAAB9+vRBQkICfvzxR9y8eRNFRUVo0aIFevbsiRkzZtTYA9qYMFLVdbPN7BUJc+K15/+0UYyHfGXICODQr+y+74yFDRwhIcRYAgMDjR2CVm3atMHFixc1JrNLly7Fhx9+iKioKIhEInz11VfYvXu3AaOs+b2cMmUKZs6cieDgYBQUFCAzMxO7du3CypUrDRpbXXh6esLT01Pt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MWMGtm/fjrCwMIjFYnz00Uc4f/68ymv866+/kJubCwCYPn061q5dqzaeO3fuqJw7aNAgAMC6desAyIe0GWuimalq1EmkSCTC7du3AcjHLtSEw+Fg0KBBOHToEP7++2+93l+551Eqler12voirSxR2pOZVGkAQurq1unjuBZxCOJykbFDMRielTX6T30HvcdPNuh9tRUenzRpEkJDQ/V+35CQEERFRbEztCMjIxEZGQkul4uOHTvC398f3bp1Q9++feHl5aX3+1cxMzNDq1atkJqaCkA/j9YdHR0xcOBA+Pv7s+WKBAIB/vzzT9y5cweA/Cnb8+fPsXv3bpiba/9V/fXXX7Pv1cvxBwQEYPny5SbV0VFaWopPP/2U3ff390fbtm3Z/cjISHZcbM+ePfHRRx9V+/3F4XCwePFixMXF4erVqxAIBDhz5gwmT1b8H3n69Cm7rTw0oSY1dUQRzRp1EpmSksKOm9FUeqHqWFVNKkdHR73cv6oiP4/HQ8eOHfVyTX0zU/pPV5GfasRICNGfW2dPNqsEEgDE5SLcOnvS4EmksVhZWWH//v349ttvcejQIVRUyGvcymQypKSkICUlBb/++isAeaI7f/58jB07tkFiUZ6UWVhYv6Vjly1bBn9//xofic+bNw8XLlzAypUrIRKJcP36dezatQvz58+v8/3c3NwwcOBAtGljnMocsbGxKClRdGaUl5cjOTkZx48fR05ODgDA3Ny82nCFP/74g91+//33NXaAzJ07F1evXmXPU04ilWfrP378uNarMRHNGnUSWfUNCACtWqkf66d8LCcnRy9J5LNnz3D48GEAwLhx43R+vFJRUYHExMR631+T8vJyJCYmQioWw46nWAJMKs5v8HsT9ao+F1IzsVgMkUi3xLDbqNdx89ejEP/zqKs54FlZoduo13V+j/SlqsagOm3atKkxJuWnMxUVFbWKm2EYtv3SpUsREhKCixcvIjo6GvHx8So/+wHg0aNHWLp0KS5evIh169ZprRVZ2/dQIpGw25WVlfX6DLp06QKJRKJyTWUDBw7E2rVr2V663bt3491339X6GHr//v3stkgkQlpaGi5cuICDBw8iNDQUe/fuxdatW+vcG6n8mWij/Nlv27ZNY1s7Ozt88cUXeOWVV1SuX9WryuVy0aNHD4337tq1K6ysrFBeXo64uDiVtspjQNeuXYvH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gIcffrjcdJVKhYceeghA6d8wKuXKR5Nq81rPILIO0el0OH78OACgb9++5eaRyWR44oknAAC///673WVfvnxZfGi3orIDAgLQo0cPh8uWOle2iz18fX3FbZPJ5NSyPVVttYler8fs2bMhCALmz59v0xZky9VtYglunnnmGT6z7QBXt4slSElJSSk3XaPR4MqVKwAqDjTJeWr7Ws8gsg5JS0uD2WwGALRt27bCfJa0nJwc8aHZqqSmporbarW6yrIvXbpkV7n1gSvbxR5//PEHgNIBBJZf9PVdbbXJypUrkZaWhjFjxqBXr17Vq2w94co2SU9Px61btwAAPXv2xLlz5zB9+nRERUXh4YcfRr9+/fDmm2/ixIkTNTwL6XH1d+XZZ58FUPp3at68eeLsEoIg4OzZs3j55ZdRVFSELl264Omnn67uaZCdavtazyCyDrH8kQSA8PDwCvNZp1kf48yytVotCgsL7Spb6lzZLlVJT0/Hf/7zHwCltyYCAwOdUq6nq402OXfuHNauXYvQ0FC88847jleynnFlm1y9elXcPn36NMaNG4fdu3dDo9HAz88PN2/eRFxcHJ599ll88cUXjldewlz9XXn++ecxdepUyOVybNq0CX379kXXrl3RqVMnjBo1CtevX8dLL72Ef/3rX1AoOKugq9X2tZ5BZB1i3ZBKpbLCfNZp9ja+dT4/Pz+nli11rmyXyhQXF+ONN96ATqdDw4YN+RyYFVe3idFoxOzZs2E0GjFnzhynTBEkda5sk4KCAnF75cqVaNSoEdauXYuTJ0/i2LFjiIuLQ+/evSEIAv75z39i79691TgDaXL1d0Uul2PGjBlYuHAh/P39AZQ++2iZ3qekpAQajYbPQ9aS2r7WM4gkqoOMRiNmzJiBs2fPwtvbG0uWLKn0VyU515dffonz588jOjoaQ4YMcXd16j3L7VjL9rJly/DEE09ALi+9hLVu3RqrVq1C48aNAQDLly93Sz3ro9zcXEycOBGzZs1C165dsWnTJhw7dgyJiYlYsWIFQkJC8N1332HcuHHirW6SDgaRdUhAQIC4rdPpKsxnnWZ9jL1lW09i7Yyypc6V7VIek8mEd955B3v37oVCocDixYvRp0+fapcnRa5sk0uXLmHVqlXw9/fHBx98UP1K1jO19fere/fu6NKlS5k8/v7+eO655wAAf/75J27fvm1X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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "clrs = ['#1f77b4','#ff7f0e', '#2ca02c','#d62728', '#9467bd', '#8c564b', '#e377c2', '#7f7f7f', '#bcbd22','#17becf']\n",
    "linewidth = 3\n",
    "fig, ax = plt.subplots(figsize=(10,7))\n",
    "\n",
    "# Resnet110\n",
    "# ax.plot(fpr_entropy_resnet110_ce_pre, tpr_entropy_resnet110_ce_pre, color=clrs[0], linewidth=linewidth, label='CE, Pre T')\n",
    "# ax.plot(fpr_entropy_resnet110_ce_post, tpr_entropy_resnet110_ce_post, color=clrs[1], linewidth=linewidth, label='CE, Post T')\n",
    "# ax.plot(fpr_entropy_resnet110_fl3_pre, tpr_entropy_resnet110_fl3_pre, color=clrs[2], linewidth=linewidth, label='FL-3, Pre T')\n",
    "# ax.plot(fpr_entropy_resnet110_fl3_post, tpr_entropy_resnet110_fl3_post, color=clrs[3], linewidth=linewidth, label='FL-3, Post T')\n",
    "# ax.plot(fpr_entropy_resnet110_flsd53_pre, tpr_entropy_resnet110_flsd53_pre, color=clrs[4], linewidth=linewidth, label='FLSD-53, Pre T')\n",
    "# ax.plot(fpr_entropy_resnet110_flsd53_post, tpr_entropy_resnet110_flsd53_post, color=clrs[5], linewidth=linewidth, label='FLSD-53, Post T')\n",
    "# ax.plot(fpr_entropy_resnet110_adafocal, tpr_entropy_resnet110_adafocal, color=clrs[6], linewidth=linewidth, label='AdaFocal')\n",
    "\n",
    "# Wideresnet\n",
    "# ax.plot(fpr_entropy_wideresnet_ce_pre, tpr_entropy_wideresnet_ce_pre, color=clrs[0], linewidth=linewidth, label='CE, Pre T')\n",
    "# ax.plot(fpr_entropy_wideresnet_ce_post, tpr_entropy_wideresnet_ce_post, color=clrs[1], linewidth=linewidth, label='CE, Post T')\n",
    "ax.plot(fpr_entropy_wideresnet_fl3_pre, tpr_entropy_wideresnet_fl3_pre, color=clrs[2], linewidth=linewidth, label='FL-3, Pre T')\n",
    "ax.plot(fpr_entropy_wideresnet_fl3_post, tpr_entropy_wideresnet_fl3_post, color=clrs[3], linewidth=linewidth, label='FL-3, Post T')\n",
    "ax.plot(fpr_entropy_wideresnet_flsd53_pre, tpr_entropy_wideresnet_flsd53_pre, color=clrs[4], linewidth=linewidth, label='FLSD-53, Pre T')\n",
    "ax.plot(fpr_entropy_wideresnet_flsd53_post, tpr_entropy_wideresnet_flsd53_post, color=clrs[5], linewidth=linewidth, label='FLSD-53, Post T')\n",
    "ax.plot(fpr_entropy_wideresnet_adafocal, tpr_entropy_wideresnet_adafocal, color=clrs[6], linewidth=linewidth, label='AdaFocal')\n",
    "# ax.set_xlim([0,0.6])\n",
    "# ax.set_ylim([0.4,1.01])\n",
    "\n",
    "ax.set_xlabel('FPR', fontsize=35)\n",
    "ax.set_ylabel('TPR', fontsize=35)\n",
    "ax.legend(loc = 'lower right', fontsize=30)\n",
    "plt.xticks(fontsize=25)\n",
    "plt.yticks(fontsize=25)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
