{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.8/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import pandas as pd\n",
    "from scipy.stats import norm\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pathlib\n",
    "import os\n",
    "\n",
    "\n",
    "from bin_cp.helpers.storage import load_smooth_prediction\n",
    "from bin_cp.helpers.tensor import get_smooth_scores, get_cal_mask, quantization_pdf, bound_tensor\n",
    "from bin_cp.robust.confidence import bernstein_bound, dkw_cdf\n",
    "from bin_cp.robust.confidence import clopper_pearson_lower\n",
    "from bin_cp.robust.bounds import mean_bounds_l2, CDF_bounds_l2\n",
    "\n",
    "from bin_cp.cp.core import ConformalClassifier as CP\n",
    "from bin_cp.cp.scores import APSScore, TPSScore, LogitScore\n",
    "\n",
    "from bin_cp.methods.robust_cp import RobustCP, VanillaSmoothCP\n",
    "from bin_cp.methods.cas import CAS\n",
    "from bin_cp.methods.bincp import BinCP\n",
    "from bin_cp.methods.rcp_one import RCP1\n",
    "# from qrcp.methods.binary import QRCPThresholds\n",
    "\n",
    "from scipy.stats import norm\n",
    "import time\n",
    "\n",
    "from tqdm import tqdm\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Main risk level: 0.2000\n",
      "Adversarial risk level: 0.1397\n"
     ]
    }
   ],
   "source": [
    "smoothing_sigma = 0.25\n",
    "r = 0.06\n",
    "\n",
    "\n",
    "ignore_label = -1\n",
    "label_mapping = {\n",
    "    -1: ignore_label, 0: ignore_label, \n",
    "    1: ignore_label, 2: ignore_label, \n",
    "    3: ignore_label, 4: ignore_label, \n",
    "    5: ignore_label, 6: ignore_label, \n",
    "    7: 0, 8: 1, 9: ignore_label, \n",
    "    10: ignore_label, 11: 2, 12: 3, \n",
    "    13: 4, 14: ignore_label, 15: ignore_label, \n",
    "    16: ignore_label, 17: 5, 18: ignore_label, \n",
    "    19: 6, 20: 7, 21: 8, 22: 9, 23: 10, 24: 11,\n",
    "    25: 12, 26: 13, 27: 14, 28: 15, \n",
    "    29: ignore_label, 30: ignore_label, \n",
    "    31: 16, 32: 17, 33: 18, 255: ignore_label}\n",
    "\n",
    "def convert_label(label, inverse=False):\n",
    "    temp = label.clone()\n",
    "    if inverse:\n",
    "        for v, k in label_mapping.items():\n",
    "            label[temp == k] = v\n",
    "    else:\n",
    "        for k, v in label_mapping.items():\n",
    "            label[temp == k] = v\n",
    "    return label\n",
    "\n",
    "\n",
    "main_risk_level = 0.2\n",
    "adversarial_risk_level = norm.cdf(norm.ppf(main_risk_level, scale=smoothing_sigma) - r, scale=smoothing_sigma)\n",
    "\n",
    "print(f\"Main risk level: {main_risk_level:.4f}\")\n",
    "print(f\"Adversarial risk level: {adversarial_risk_level:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "city_scape_results = \"./cityscapes-results/cityscapes_2025_03_08_12:38:57\"\n",
    "file_indices = list(set([int(item.split(\"_\")[0]) for item in os.listdir(city_scape_results) if item.split(\"_\")[0].isnumeric()]))\n",
    "\n",
    "n_dcal = 5\n",
    "sensitive_class = 2\n",
    "\n",
    "rand_idxs = torch.randperm(len(file_indices))\n",
    "cal_file_indices = torch.tensor(file_indices)[rand_idxs[:n_dcal]]\n",
    "eval_file_indices = torch.tensor(file_indices)[rand_idxs[n_dcal:]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/5 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading 94\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 1/5 [00:00<00:00,  4.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading 59\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 40%|████      | 2/5 [00:00<00:00,  4.43it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading 262\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 60%|██████    | 3/5 [00:00<00:00,  4.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading 228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 80%|████████  | 4/5 [00:00<00:00,  4.28it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading 130\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [00:01<00:00,  4.34it/s]\n"
     ]
    }
   ],
   "source": [
    "file_index = cal_file_indices[0]\n",
    "\n",
    "loaded_output = torch.load(os.path.join(city_scape_results, f\"{file_index}_output.pt\"))\n",
    "label = loaded_output[\"label\"]\n",
    "exp_logits = loaded_output[\"soft_output\"]\n",
    "\n",
    "def extract_risks(exp_logits, label, sensitive_class):\n",
    "    exp_logits = exp_logits.to(device)\n",
    "    class_mask = (label == sensitive_class)\n",
    "    softmaxes = (exp_logits[0] / exp_logits.sum(dim=1)[0, :, :])\n",
    "    mask_values = softmaxes[sensitive_class, :, :][class_mask[0]]\n",
    "    vals, counts = mask_values.unique(return_counts=True)\n",
    "    risks = counts.cumsum(0) / counts.sum(0) if counts.sum(0) > 0 else torch.tensor([0.0]).to(device)\n",
    "    exp_logits = exp_logits.cpu()\n",
    "    return vals, risks\n",
    "\n",
    "\n",
    "cal_vals = []\n",
    "cal_risks = []\n",
    "for file_index in tqdm(cal_file_indices):\n",
    "    print(f\"Loading {file_index}\")\n",
    "    loaded_output = torch.load(os.path.join(city_scape_results, f\"{file_index}_output.pt\"))\n",
    "    label = loaded_output[\"label\"]\n",
    "    exp_logits = loaded_output[\"soft_output\"]\n",
    "    vals, risks = extract_risks(exp_logits, label, sensitive_class)\n",
    "    cal_vals.append(vals)\n",
    "    cal_risks.append(risks)\n",
    "cal_vals.append(torch.tensor([0.0]).to(device))\n",
    "cal_risks.append(torch.tensor([0.0]).to(device))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_conformal_threshold(\n",
    "    cal_vals, cal_risks, risk_level):\n",
    "    threshold_levels, sorting_idxs = (torch.cat(cal_vals)).sort()\n",
    "\n",
    "    # running a binary search to find the threshold\n",
    "    start_idx = 0\n",
    "    end_idx = threshold_levels.shape[0]\n",
    "\n",
    "    while end_idx - start_idx > 1:\n",
    "        mid_idx = (start_idx + end_idx) // 2\n",
    "        threshold = threshold_levels[mid_idx]\n",
    "\n",
    "        step_risks = []\n",
    "        for i in range(len(cal_vals)):\n",
    "            # print(torch.tensor(0.0).to(cal_risks[i].device) if len(cal_vals[i])==0 else cal_risks[i][(threshold > cal_vals[i])].max())\n",
    "            # print(\"vals: \", cal_vals[i])\n",
    "            # print(\"risks: \", cal_risks[i])\n",
    "            # print(torch.tensor(0.0).to(cal_risks[i].device) if len(cal_vals[i])==0 else cal_risks[i][(threshold > cal_vals[i])])\n",
    "            if len(cal_vals[i]) == 0 or len(cal_risks[i][(threshold > cal_vals[i])]) == 0:\n",
    "                step_risks.append(torch.tensor(0.0).to(cal_risks[i].device))\n",
    "            else:\n",
    "                step_risks.append(cal_risks[i][(threshold > cal_vals[i])].max())\n",
    "            # print(cal_risks[i][threshold > cal_vals[i]])\n",
    "            # print(cal_risks[i][(threshold > cal_vals[i])].max() if cal_risks[i].shape[0] > 0 else torch.tensor([0]))\n",
    "        # step_risks = torch.stack([torch.tensor(0.0).to(cal_risks[i].device) if len(cal_vals[i])==0 else cal_risks[i][(threshold > cal_vals[i])].max() for i in range(len(cal_vals))])\n",
    "        step_risks = torch.stack(step_risks)\n",
    "        # print(step_risks)\n",
    "        risk = (step_risks.sum(0) + 1) / len(cal_vals)\n",
    "        # print(risk)\n",
    "        if risk < risk_level:\n",
    "            start_idx = mid_idx\n",
    "        else:\n",
    "            end_idx = mid_idx\n",
    "        \n",
    "    conformal_threshold = threshold_levels[start_idx]\n",
    "    return conformal_threshold.item()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 206,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.2232, 0.3284, 0.3545, 0.7996, 0.3994, 0.0000], device='cuda:0')\n",
      "tensor(0.5175, device='cuda:0')\n",
      "tensor([0.1290, 0.1341, 0.1374, 0.5131, 0.1382, 0.0000], device='cuda:0')\n",
      "tensor(0.3420, device='cuda:0')\n",
      "tensor([0.0625, 0.0512, 0.0555, 0.3184, 0.0442, 0.0000], device='cuda:0')\n",
      "tensor(0.2553, device='cuda:0')\n",
      "tensor([0.0093, 0.0074, 0.0264, 0.2166, 0.0129, 0.0000], device='cuda:0')\n",
      "tensor(0.2121, device='cuda:0')\n",
      "tensor([0.0017, 0.0004, 0.0163, 0.1128, 0.0053, 0.0000], device='cuda:0')\n",
      "tensor(0.1894, device='cuda:0')\n",
      "tensor([0.0043, 0.0024, 0.0213, 0.1682, 0.0087, 0.0000], device='cuda:0')\n",
      "tensor(0.2008, device='cuda:0')\n",
      "tensor([0.0028, 0.0012, 0.0185, 0.1416, 0.0068, 0.0000], device='cuda:0')\n",
      "tensor(0.1951, device='cuda:0')\n",
      "tensor([0.0035, 0.0018, 0.0199, 0.1551, 0.0077, 0.0000], device='cuda:0')\n",
      "tensor(0.1980, device='cuda:0')\n",
      "tensor([0.0039, 0.0021, 0.0207, 0.1616, 0.0082, 0.0000], device='cuda:0')\n",
      "tensor(0.1994, device='cuda:0')\n",
      "tensor([0.0041, 0.0023, 0.0210, 0.1649, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2001, device='cuda:0')\n",
      "tensor([0.0040, 0.0022, 0.0209, 0.1632, 0.0083, 0.0000], device='cuda:0')\n",
      "tensor(0.1998, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1640, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.1999, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1645, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1642, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "tensor([0.0041, 0.0022, 0.0210, 0.1643, 0.0084, 0.0000], device='cuda:0')\n",
      "tensor(0.2000, device='cuda:0')\n",
      "Conformal threshold: 0.12118986248970032\n",
      "tensor([0.2232, 0.3284, 0.3545, 0.7996, 0.3994, 0.0000], device='cuda:0')\n",
      "tensor(0.5175, device='cuda:0')\n",
      "tensor([0.1290, 0.1341, 0.1374, 0.5131, 0.1382, 0.0000], device='cuda:0')\n",
      "tensor(0.3420, device='cuda:0')\n",
      "tensor([0.0625, 0.0512, 0.0555, 0.3184, 0.0442, 0.0000], device='cuda:0')\n",
      "tensor(0.2553, device='cuda:0')\n",
      "tensor([0.0093, 0.0074, 0.0264, 0.2166, 0.0129, 0.0000], device='cuda:0')\n",
      "tensor(0.2121, device='cuda:0')\n",
      "tensor([0.0017, 0.0004, 0.0163, 0.1128, 0.0053, 0.0000], device='cuda:0')\n",
      "tensor(0.1894, device='cuda:0')\n",
      "tensor([0.0006, 0.0000, 0.0125, 0.0515, 0.0025, 0.0000], device='cuda:0')\n",
      "tensor(0.1779, device='cuda:0')\n",
      "tensor([0.0002, 0.0000, 0.0093, 0.0221, 0.0011, 0.0000], device='cuda:0')\n",
      "tensor(0.1721, device='cuda:0')\n",
      "tensor([0.0001, 0.0000, 0.0060, 0.0094, 0.0005, 0.0000], device='cuda:0')\n",
      "tensor(0.1693, device='cuda:0')\n",
      "tensor([6.2592e-05, 0.0000e+00, 4.2721e-03, 3.1061e-03, 2.1280e-04, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1679, device='cuda:0')\n",
      "tensor([3.9831e-05, 0.0000e+00, 3.3600e-03, 0.0000e+00, 9.9027e-05, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1672, device='cuda:0')\n",
      "tensor([9.4836e-06, 0.0000e+00, 1.7239e-03, 0.0000e+00, 0.0000e+00, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1670, device='cuda:0')\n",
      "tensor([0.0000, 0.0000, 0.0009, 0.0000, 0.0000, 0.0000], device='cuda:0')\n",
      "tensor(0.1668, device='cuda:0')\n",
      "tensor([0.0000, 0.0000, 0.0004, 0.0000, 0.0000, 0.0000], device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000, 0.0000, 0.0002, 0.0000, 0.0000, 0.0000], device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000, 0.0000, 0.0001, 0.0000, 0.0000, 0.0000], device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000e+00, 0.0000e+00, 5.1716e-05, 0.0000e+00, 0.0000e+00, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000e+00, 0.0000e+00, 2.5074e-05, 0.0000e+00, 0.0000e+00, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000e+00, 0.0000e+00, 1.0970e-05, 0.0000e+00, 0.0000e+00, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000e+00, 0.0000e+00, 4.7015e-06, 0.0000e+00, 0.0000e+00, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0.0000e+00, 0.0000e+00, 1.5672e-06, 0.0000e+00, 0.0000e+00, 0.0000e+00],\n",
      "       device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "tensor([0., 0., 0., 0., 0., 0.], device='cuda:0')\n",
      "tensor(0.1667, device='cuda:0')\n",
      "Adversarial threshold: 0.0\n"
     ]
    }
   ],
   "source": [
    "conformal_threshold = compute_conformal_threshold(cal_vals, cal_risks, main_risk_level)\n",
    "print(f\"Conformal threshold: {conformal_threshold}\")\n",
    "adversarial_threshold = compute_conformal_threshold(cal_vals, cal_risks, adversarial_risk_level)\n",
    "print(f\"Adversarial threshold: {adversarial_threshold}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 207,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Risk: 0.0211\n",
      "Adversarial risk: 0.0000\n"
     ]
    }
   ],
   "source": [
    "eval_idx = eval_file_indices[7]\n",
    "loaded_output = torch.load(os.path.join(city_scape_results, f\"{eval_idx}_output.pt\"))\n",
    "label = loaded_output[\"label\"]\n",
    "exp_logits = loaded_output[\"soft_output\"]\n",
    "\n",
    "def return_conformal(exp_logits, sensitive_class, conformal_threshold):\n",
    "    exp_logits = exp_logits.to(device)\n",
    "    softmaxes = (exp_logits[0] / exp_logits.sum(dim=1)[0, :, :])\n",
    "    output = softmaxes[sensitive_class, :, :] > conformal_threshold\n",
    "    exp_logits = exp_logits.cpu()\n",
    "    return output\n",
    "\n",
    "def compute_risk(output, label, sensitive_class):\n",
    "    class_mask = (label == sensitive_class)\n",
    "    fnr = (class_mask[0].to(output.device) & ~output.to(output.device)).sum() / class_mask.sum()\n",
    "    return fnr.cpu()\n",
    "\n",
    "output = return_conformal(exp_logits, sensitive_class, conformal_threshold)\n",
    "adversarial_output = return_conformal(exp_logits, sensitive_class, adversarial_threshold)\n",
    "risk = compute_risk(output, label, sensitive_class)\n",
    "adversarial_risk = compute_risk(adversarial_output, label, sensitive_class)\n",
    "print(f\"Risk: {risk:.4f}\")\n",
    "print(f\"Adversarial risk: {adversarial_risk:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 208,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "class_mask = (label == sensitive_class)\n",
    "output\n",
    "f, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "ax[0].imshow(class_mask[0].float().cpu().numpy(), cmap=\"gray\")\n",
    "ax[1].imshow(output.float().cpu().numpy(), cmap=\"gray\", alpha=1)\n",
    "ax[1].imshow(class_mask[0].float().cpu().numpy(), cmap=\"gray\", alpha=0.5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "class_mask = (label == sensitive_class)\n",
    "output\n",
    "f, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "ax[0].imshow(class_mask[0].float().cpu().numpy(), cmap=\"gray\")\n",
    "ax[1].imshow(adversarial_output.float().cpu().numpy(), cmap=\"gray\", alpha=1)\n",
    "ax[1].imshow(class_mask[0].float().cpu().numpy(), cmap=\"gray\", alpha=0.5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "metadata": {},
   "outputs": [],
   "source": [
    "state_dict = {\n",
    "    \"label\": class_mask[0].cpu(),\n",
    "    \"output\": output.bool().cpu(),\n",
    "    \"adversarial_output\": adversarial_output.bool().cpu(),\n",
    "    \"conformal_threshold\": conformal_threshold,\n",
    "    \"adversarial_threshold\": adversarial_threshold,\n",
    "    \"risk\": risk,\n",
    "    \"adversarial_risk\": adversarial_risk,\n",
    "    \"main_risk_level\": main_risk_level,\n",
    "    \"adversarial_risk_level\": adversarial_risk_level,\n",
    "    \"sensitive_class\": sensitive_class,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = torch.load(\"../../results/cityscapes/exp/class-13/219-class_13_sigma-0.25_r-0.06-output.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [],
   "source": [
    "class_mask = data[\"label\"]\n",
    "output = data[\"output\"]\n",
    "adversarial_output = data[\"adversarial_output\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(48133)"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class_mask.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x154b18d15670>"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1080x8280 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, ax = plt.subplots(1, 3, figsize=(15, 115))\n",
    "ax[0].imshow(output.float().cpu().numpy(), alpha=1)\n",
    "# ax[0].imshow(class_mask.float().cpu().numpy(), cmap=\"gray\", alpha=0.5)\n",
    "ax[1].imshow(adversarial_output.float().cpu().numpy(), alpha=1)\n",
    "\n",
    "ax[2].imshow(class_mask.float().cpu().numpy(), alpha=1)\n",
    "# ax[1].imshow(class_mask.float().cpu().numpy(), cmap=\"gray\", alpha=0.5)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 247,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0)"
      ]
     },
     "execution_count": 247,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x154b190969d0>"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow((label[0] == 11).float())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x154b18c32640>"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "file_index = 219\n",
    "\n",
    "loaded_output = torch.load(os.path.join(city_scape_results, f\"{file_index}_output.pt\"))\n",
    "label = loaded_output[\"label\"]\n",
    "exp_logits = loaded_output[\"soft_output\"]\n",
    "\n",
    "image = label.clone()\n",
    "label[label == 255] = 20\n",
    "plt.imshow((label[0]), cmap=\"gray\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
