{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.11/site-packages/tqdm/auto.py:21: 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"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(0.0, 0.0013809958043854269)"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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, RCP1Plus\n",
    "# from qrcp.methods.binary import QRCPThresholds\n",
    "import time\n",
    "\n",
    "from tqdm import tqdm\n",
    "\n",
    "nn = 500\n",
    "nk = 10000\n",
    "from statsmodels.stats.proportion import proportion_confint\n",
    "proportion_confint(\n",
    "        0.0 * nk, nk, alpha=0.001/(nn + 2), method=\"beta\")\n",
    "\n",
    "# IMPORTANT: make sure that the result is close to 0.0 otherwise there is a bug due to the version of scipy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#region primary configs of the experiment\n",
    "\n",
    "output_dir = \"./results/\"\n",
    "\n",
    "dataset_name = \"cifar10\"\n",
    "model_sigma = 0.5\n",
    "n_classes=10\n",
    "n_datapoints = 2048\n",
    "smoothing_sigma = 0.5\n",
    "n_samples = 10000\n",
    "n_trial_samples = 10000\n",
    "\n",
    "score_method = \"TPS\"\n",
    "calibration_budget = 0.1\n",
    "n_iterations = 100\n",
    "\n",
    "confidence = 0.999\n",
    "coverage_range = [0.85, 0.9, 0.95]\n",
    "# coverage_range = [0.9]\n",
    "r_range = [0.06, 0.12, 0.18, 0.25, 0.37, 0.5, 0.75]\n",
    "# r_range = [0.12,  0.25, 0.5, ]\n",
    "\n",
    "#endregion"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "output_dir = pathlib.Path(output_dir)/dataset_name\n",
    "output_dir.mkdir(parents=True, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "models_dir = pathlib.Path(\"\")\n",
    "dataset_dir = pathlib.Path(\"\")\n",
    "logits_dir = pathlib.Path(\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading cifar10 dataset with 2048 datapoints and 10000 samples: Score method: TPS\n"
     ]
    }
   ],
   "source": [
    "#region loding smooth logit predictions\n",
    "if n_samples < n_trial_samples:\n",
    "    print(f\"Number of trial samples is set to {n_trial_samples} as it is smaller than the number of samples.\")\n",
    "    \n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "try:\n",
    "    smooth_prediction = load_smooth_prediction(dataset_name=dataset_name,\n",
    "        model_sigma=model_sigma,\n",
    "        n_datapoints=n_datapoints,\n",
    "        smoothing_sigma=smoothing_sigma,\n",
    "        n_samples=n_samples,\n",
    "        models_dir=models_dir,\n",
    "        dataset_dir=dataset_dir,\n",
    "        logits_dir=logits_dir,)\n",
    "    n_classes = 10 if dataset_name == \"cifar10\" else None\n",
    "except FileNotFoundError as e:\n",
    "    print(\"Smooth predictions not found, you can generate them using bin/smooth_logits_clean.py\")\n",
    "    print(\"Full description of the error: \", e)\n",
    "#endregion\n",
    "\n",
    "# region computing the conformal scores.\n",
    "score_pipeline = [\n",
    "    TPSScore(softmax=True) if score_method == \"TPS\" else APSScore(softmax=True)] # defining the score function\n",
    "cp = CP(score_pipeline=score_pipeline, coverage_guarantee=0.9) # the guarantee can vary later by cp.coverage_guarantee\n",
    "smooth_scores = get_smooth_scores(smooth_prediction.logits, cp, mean=False)\n",
    "smooth_scores = smooth_scores[:, :, :n_trial_samples]\n",
    "y_true_mask = F.one_hot(smooth_prediction.y_true, num_classes=10).bool().to(device)\n",
    "print(f\"Loading {dataset_name} dataset with {n_datapoints} datapoints and {n_samples} samples: Score method: {score_method}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "class RCP1Plus(RobustCP):\n",
    "    def __init__(self, *args, smoothing_sigma, tuning_n=200, confidence=0.99, **kwargs):\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.smoothing_sigma = smoothing_sigma\n",
    "        self.tuning_n = tuning_n\n",
    "        self.certificate_function = lambda p: norm.cdf(norm.ppf(p.cpu(), scale=self.smoothing_sigma) - self.r, scale=self.smoothing_sigma)\n",
    "        self.exact_guarantee = None\n",
    "        self.delta = 1 - confidence\n",
    "\n",
    "    def calibrate_from_scores(self, S_sampled, y, return_scores=False, return_guarantee=True, **kwargs):\n",
    "\n",
    "        tuning_scores = S_sampled[:, :, -self.tuning_n:]\n",
    "        empirical_scores = S_sampled[:, :, :-self.tuning_n]\n",
    "\n",
    "        threshold_min = S_sampled.min().item()\n",
    "        threshold_max = S_sampled.max().item()\n",
    "\n",
    "        while threshold_max - threshold_min > 1e-7:\n",
    "            threshold = (threshold_min + threshold_max) / 2\n",
    "\n",
    "            beta_estimates = (tuning_scores >= threshold).float().mean(-1)\n",
    "            true_betas = beta_estimates[torch.arange(tuning_scores.shape[0]), y]\n",
    "\n",
    "            # estimating what the confidence intervals would be over the true samples.\n",
    "            probs = torch.tensor(clopper_pearson_lower(true_betas.cpu() * empirical_scores.shape[-1], empirical_scores.shape[-1], alpha=self.delta/empirical_scores.shape[0]), device=S_sampled.device)\n",
    "            probs = torch.cat([probs, torch.tensor([0.0], device=probs.device)])\n",
    "            certified_values = self.certificate_function(probs).mean()\n",
    "            \n",
    "            # print(\" threshold=\", threshold, \"certified_values = \", certified_values.item(),  \"rcp1guarantee = \", selfcertificate_function(true_probs.mean()))\n",
    "            if certified_values < self.nominal_coverage + self.delta + 0.005:\n",
    "                threshold_max = threshold\n",
    "            else:\n",
    "                threshold_min = threshold\n",
    "            if threshold_max <= S_sampled.min().item():\n",
    "                threshold_min = -1000\n",
    "                break\n",
    "\n",
    "        self.conformal_threshold = threshold_min \n",
    "        \n",
    "        \n",
    "        empirical_betas_estimates = (empirical_scores >= threshold_min).float().mean(-1)\n",
    "        empirical_true_betas = empirical_betas_estimates[torch.arange(empirical_scores.shape[0]), y]\n",
    "        empirical_probs = torch.tensor(clopper_pearson_lower(empirical_true_betas.cpu() * empirical_scores.shape[-1], empirical_scores.shape[-1], alpha=self.delta/empirical_scores.shape[0]), device=S_sampled.device)\n",
    "        empirical_probs = torch.cat([empirical_probs, torch.tensor([0.0], device=empirical_probs.device)])\n",
    "        self.exact_guarantee = self.certificate_function(empirical_probs).mean().item() - self.delta \n",
    "\n",
    "        if return_guarantee:\n",
    "            return threshold_min, self.exact_guarantee\n",
    "\n",
    "        if return_scores:\n",
    "            return threshold_min, S_sampled\n",
    "        return threshold_min\n",
    "\n",
    "    def return_worst_case_guarantee(self, S_sampled, y, **kwargs):\n",
    "        threshold = self.internal_cp.calibrate_from_scores(S_sampled[:, :, 0], y_true_mask=torch.nn.functional.one_hot(y, num_classes=S_sampled.shape[1]).bool())\n",
    "        empirical_betas_estimates = (S_sampled >= threshold).float().mean(-1)\n",
    "        empirical_true_betas = empirical_betas_estimates[torch.arange(S_sampled.shape[0]), y]\n",
    "        empirical_probs = torch.tensor(clopper_pearson_lower(empirical_true_betas.cpu() * S_sampled.shape[-1], S_sampled.shape[-1], alpha=self.delta/S_sampled.shape[0]), device=S_sampled.device)\n",
    "        empirical_probs = torch.cat([empirical_probs, torch.tensor([0.0], device=empirical_probs.device)])\n",
    "        exact_guarantee = self.certificate_function(empirical_probs).mean().item() - self.delta\n",
    "        return exact_guarantee\n",
    "\n",
    "\n",
    "    def predict_from_scores(self, S_sampled, return_scores=False):\n",
    "        if S_sampled.ndim > 2:\n",
    "            scores = S_sampled[:, :, 0]\n",
    "        else:\n",
    "            scores = S_sampled\n",
    "\n",
    "        pred_set = scores >= self.conformal_threshold\n",
    "            # print(f\"base={self.p_base}, conf={confidence_p}\")\n",
    "\n",
    "        return pred_set\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2048, 10, 10000])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "smooth_scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.0 and coverage=0.9\n",
      "Pre-computing CAS for r=0.0 and coverage=0.9\n",
      "Pre-computing BinCP for r=0.0 and coverage=0.9\n",
      "Pre-computing RCP1 for r=0.0 and coverage=0.9\n",
      "Pre-computing RCP1Plus for r=0.0 and coverage=0.9\n",
      "Running the experiment for r=0.0 and coverage=0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:01<00:00,  1.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.06 and coverage=0.9\n",
      "Pre-computing CAS for r=0.06 and coverage=0.9\n",
      "Pre-computing BinCP for r=0.06 and coverage=0.9\n",
      "Pre-computing RCP1 for r=0.06 and coverage=0.9\n",
      "Pre-computing RCP1Plus for r=0.06 and coverage=0.9\n",
      "Running the experiment for r=0.06 and coverage=0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:01<00:00,  1.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.12 and coverage=0.9\n",
      "Pre-computing CAS for r=0.12 and coverage=0.9\n",
      "Pre-computing BinCP for r=0.12 and coverage=0.9\n",
      "Pre-computing RCP1 for r=0.12 and coverage=0.9\n",
      "Pre-computing RCP1Plus for r=0.12 and coverage=0.9\n",
      "Running the experiment for r=0.12 and coverage=0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:01<00:00,  1.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.18 and coverage=0.9\n",
      "Pre-computing CAS for r=0.18 and coverage=0.9\n",
      "Pre-computing BinCP for r=0.18 and coverage=0.9\n",
      "Pre-computing RCP1 for r=0.18 and coverage=0.9\n",
      "Pre-computing RCP1Plus for r=0.18 and coverage=0.9\n",
      "Running the experiment for r=0.18 and coverage=0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:01<00:00,  1.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.25 and coverage=0.9\n",
      "Pre-computing CAS for r=0.25 and coverage=0.9\n",
      "Pre-computing BinCP for r=0.25 and coverage=0.9\n",
      "Pre-computing RCP1 for r=0.25 and coverage=0.9\n",
      "Pre-computing RCP1Plus for r=0.25 and coverage=0.9\n",
      "Running the experiment for r=0.25 and coverage=0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:01<00:00,  1.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.37 and coverage=0.9\n",
      "Pre-computing CAS for r=0.37 and coverage=0.9\n",
      "Pre-computing BinCP for r=0.37 and coverage=0.9\n",
      "Pre-computing RCP1 for r=0.37 and coverage=0.9\n",
      "Pre-computing RCP1Plus for r=0.37 and coverage=0.9\n",
      "Running the experiment for r=0.37 and coverage=0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 11%|█         | 11/100 [00:07<00:58,  1.52it/s]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[16], line 33\u001b[0m\n\u001b[1;32m     31\u001b[0m     threshold, exact_guarantee \u001b[38;5;241m=\u001b[39m method\u001b[38;5;241m.\u001b[39mcalibrate_from_scores(smooth_scores[cal_mask], smooth_prediction\u001b[38;5;241m.\u001b[39my_true[cal_mask], return_guarantee\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)    \n\u001b[1;32m     32\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m---> 33\u001b[0m     threshold \u001b[38;5;241m=\u001b[39m \u001b[43mmethod\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcalibrate_from_scores\u001b[49m\u001b[43m(\u001b[49m\u001b[43msmooth_scores\u001b[49m\u001b[43m[\u001b[49m\u001b[43mcal_mask\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msmooth_prediction\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43my_true\u001b[49m\u001b[43m[\u001b[49m\u001b[43mcal_mask\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     34\u001b[0m pred_set \u001b[38;5;241m=\u001b[39m method\u001b[38;5;241m.\u001b[39mpredict_from_scores(smooth_scores[eval_mask], return_scores\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[1;32m     35\u001b[0m covered \u001b[38;5;241m=\u001b[39m (pred_set)[torch\u001b[38;5;241m.\u001b[39marange(pred_set\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m]), smooth_prediction\u001b[38;5;241m.\u001b[39my_true[eval_mask]]\n",
      "File \u001b[0;32m~/CISPA-home/projects/Robust Conformal Prediction/RCP1/bin_cp/methods/robust_cp.py:56\u001b[0m, in \u001b[0;36mRobustCP.calibrate_from_scores\u001b[0;34m(self, S_sampled, y, return_scores)\u001b[0m\n\u001b[1;32m     54\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcalibrate_from_scores\u001b[39m(\u001b[38;5;28mself\u001b[39m, S_sampled, y, return_scores\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m):\n\u001b[1;32m     55\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mstage \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mcalibration\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n\u001b[0;32m---> 56\u001b[0m         calibration_scores \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcompute_lower_bound_scores\u001b[49m\u001b[43m(\u001b[49m\u001b[43mS_sampled\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     58\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mstage \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtest\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n\u001b[1;32m     59\u001b[0m         calibration_scores \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcompute_vanilla_scores(S_sampled)\n",
      "File \u001b[0;32m~/CISPA-home/projects/Robust Conformal Prediction/RCP1/bin_cp/methods/cas.py:34\u001b[0m, in \u001b[0;36mCAS.compute_lower_bound_scores\u001b[0;34m(self, S_sampled, y)\u001b[0m\n\u001b[1;32m     31\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39merror_correction \u001b[38;5;241m==\u001b[39m \u001b[38;5;28;01mFalse\u001b[39;00m:\n\u001b[1;32m     32\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m bound_tensor(S_forY, CDF_bounds_l2, smoothing_sigma\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39msmoothing_sigma, radius\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mr, \n\u001b[1;32m     33\u001b[0m             confidence\u001b[38;5;241m=\u001b[39m(\u001b[38;5;241m1\u001b[39m \u001b[38;5;241m-\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39meta\u001b[38;5;241m/\u001b[39m(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mn_dcal \u001b[38;5;241m+\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mn_classes)), \u001b[38;5;28mtype\u001b[39m\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlower\u001b[39m\u001b[38;5;124m\"\u001b[39m, bonferroni_tasks\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m)\n\u001b[0;32m---> 34\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mbound_tensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mS_forY\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mCDF_bounds_l2\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msmoothing_sigma\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msmoothing_sigma\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mradius\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mr\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[1;32m     35\u001b[0m \u001b[43m             \u001b[49m\u001b[43mconfidence\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43meta\u001b[49m\u001b[38;5;241;43m/\u001b[39;49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_dcal\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mn_classes\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mtype\u001b[39;49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mlower\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbonferroni_tasks\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/CISPA-home/projects/Robust Conformal Prediction/RCP1/bin_cp/helpers/tensor.py:44\u001b[0m, in \u001b[0;36mbound_tensor\u001b[0;34m(input_tensor, func, **kwargs)\u001b[0m\n\u001b[1;32m     42\u001b[0m     result \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mzeros_like(input_tensor[:, \u001b[38;5;241m0\u001b[39m])\n\u001b[1;32m     43\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(input_tensor\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m]):\n\u001b[0;32m---> 44\u001b[0m         result[i] \u001b[38;5;241m=\u001b[39m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[43minput_tensor\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m:\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     45\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     46\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mInput tensor must have 2 or 3 dimensions\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "File \u001b[0;32m~/CISPA-home/projects/Robust Conformal Prediction/RCP1/bin_cp/robust/bounds.py:79\u001b[0m, in \u001b[0;36mCDF_bounds_l2\u001b[0;34m(randoms, smoothing_sigma, radius, confidence, type, bonferroni_tasks, n_bins)\u001b[0m\n\u001b[1;32m     77\u001b[0m m_empi_cdf \u001b[38;5;241m=\u001b[39m ((randoms\u001b[38;5;241m.\u001b[39mview(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m1\u001b[39m) \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m bins\u001b[38;5;241m.\u001b[39mto(randoms\u001b[38;5;241m.\u001b[39mdevice))\u001b[38;5;241m.\u001b[39msum(dim\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m) \u001b[38;5;241m/\u001b[39m randoms\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m])\n\u001b[1;32m     78\u001b[0m m_empi_cdf \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mclamp(m_empi_cdf \u001b[38;5;241m+\u001b[39m error, \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m1\u001b[39m)\n\u001b[0;32m---> 79\u001b[0m m_empi_cdf_lower \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mtensor(norm\u001b[38;5;241m.\u001b[39mcdf(norm\u001b[38;5;241m.\u001b[39mppf(\u001b[43mm_empi_cdf\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcpu\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m, scale\u001b[38;5;241m=\u001b[39msmoothing_sigma) \u001b[38;5;241m+\u001b[39m radius, scale\u001b[38;5;241m=\u001b[39msmoothing_sigma))\u001b[38;5;241m.\u001b[39mto(randoms\u001b[38;5;241m.\u001b[39mdevice)\n\u001b[1;32m     80\u001b[0m lower_bound \u001b[38;5;241m=\u001b[39m mean_bound_from_cdf(m_empi_cdf_lower, bins, \u001b[38;5;28mtype\u001b[39m\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlower\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m     81\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m lower_bound\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "result = []\n",
    "\n",
    "# for r in r_range:\n",
    "#     for coverage_guarantee in coverage_range:\n",
    "for r in [0.0, 0.06, 0.12, 0.18, 0.25, 0.37, 0.5, 0.75]:\n",
    "    for coverage_guarantee in [0.9]:\n",
    "        print(f\"running for r={r} and coverage={coverage_guarantee}\")\n",
    "\n",
    "        cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "        n_dcal = cal_mask.sum().item()\n",
    "        cp_methods = {\n",
    "            \"CAS\": CAS(smoothing_sigma=smoothing_sigma, confidence_level=confidence, n_dcal=n_dcal, n_classes=n_classes, nominal_coverage=coverage_guarantee, r=r),\n",
    "            \"BinCP\": BinCP(smoothing_sigma=smoothing_sigma, confidence_level=confidence, n_dcal=n_dcal, n_classes=n_classes,\n",
    "                        p_base=0.8, scheme=\"guass\", nominal_coverage=coverage_guarantee, r=r),\n",
    "            \"RCP1\": RCP1(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, nominal_coverage=coverage_guarantee, r=r),\n",
    "            \"RCP1Plus\": RCP1Plus(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, nominal_coverage=coverage_guarantee, r=r),\n",
    "        }\n",
    "\n",
    "        for method_name, method in cp_methods.items():\n",
    "            print(f\"Pre-computing {method_name} for r={r} and coverage={coverage_guarantee}\")\n",
    "            method.pre_compute(smooth_scores, smooth_prediction.y_true)\n",
    "\n",
    "        print(f\"Running the experiment for r={r} and coverage={coverage_guarantee}\")\n",
    "        for iteration in tqdm(range(n_iterations)):\n",
    "            cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "            eval_mask = ~cal_mask\n",
    "\n",
    "            for method_name, method in cp_methods.items():\n",
    "                exact_guarantee = coverage_guarantee\n",
    "                if isinstance(method, RCP1Plus):\n",
    "                    threshold, exact_guarantee = method.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask], return_guarantee=True)    \n",
    "                else:\n",
    "                    threshold = method.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask])\n",
    "                pred_set = method.predict_from_scores(smooth_scores[eval_mask], return_scores=False)\n",
    "                covered = (pred_set)[torch.arange(pred_set.shape[0]), smooth_prediction.y_true[eval_mask]]\n",
    "                set_size = pred_set.sum(dim=1)\n",
    "\n",
    "                empirical_coverage = covered.float().mean().item()\n",
    "                avg_set_size = set_size.float().mean().item()\n",
    "                result.append({\n",
    "                    \"method\": method_name,\n",
    "                    \"empirical_coverage\": empirical_coverage,\n",
    "                    \"avg_set_size\": avg_set_size,\n",
    "                    \"r\": r,\n",
    "                    \"coverage_guarantee\": coverage_guarantee,\n",
    "                    \"exact_guarantee\": exact_guarantee,\n",
    "                    \"threshold\": threshold,\n",
    "                    \"internal_coverage_level\": method.internal_cp.coverage_guarantee,\n",
    "                    \"below_1\": (set_size <= 1).float().mean().item(),\n",
    "                    \"below_3\": (set_size <= 3).float().mean().item(),\n",
    "                    \"below_5\": (set_size <= 5).float().mean().item(),\n",
    "                    \"below_1_coverage\": covered[set_size <= 1].float().mean().item(),\n",
    "                    \"below_3_coverage\": covered[set_size <= 3].float().mean().item(),\n",
    "                    \"below_5_coverage\": covered[set_size <= 5].float().mean().item(),\n",
    "                    \"n_samples\": n_trial_samples,\n",
    "                })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>exact_guarantee</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th>r</th>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">BinCP</th>\n",
       "      <th>0.00</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.920190</td>\n",
       "      <td>2.205266</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.050092</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.396708</td>\n",
       "      <td>0.832858</td>\n",
       "      <td>0.989360</td>\n",
       "      <td>0.937813</td>\n",
       "      <td>0.923996</td>\n",
       "      <td>0.920161</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.06</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.933715</td>\n",
       "      <td>2.375282</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.048593</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.364035</td>\n",
       "      <td>0.785602</td>\n",
       "      <td>0.979441</td>\n",
       "      <td>0.946961</td>\n",
       "      <td>0.937724</td>\n",
       "      <td>0.933963</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.12</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.938357</td>\n",
       "      <td>2.434799</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.052909</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.352571</td>\n",
       "      <td>0.770775</td>\n",
       "      <td>0.974696</td>\n",
       "      <td>0.949975</td>\n",
       "      <td>0.941699</td>\n",
       "      <td>0.938689</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.18</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.947690</td>\n",
       "      <td>2.583742</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.052700</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.327473</td>\n",
       "      <td>0.732044</td>\n",
       "      <td>0.961085</td>\n",
       "      <td>0.957001</td>\n",
       "      <td>0.950574</td>\n",
       "      <td>0.948089</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.956692</td>\n",
       "      <td>2.757695</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.052732</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.300266</td>\n",
       "      <td>0.689783</td>\n",
       "      <td>0.939794</td>\n",
       "      <td>0.965945</td>\n",
       "      <td>0.959123</td>\n",
       "      <td>0.957116</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.37</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.966475</td>\n",
       "      <td>3.017912</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.054989</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.262543</td>\n",
       "      <td>0.632739</td>\n",
       "      <td>0.902278</td>\n",
       "      <td>0.975668</td>\n",
       "      <td>0.968865</td>\n",
       "      <td>0.966848</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.976876</td>\n",
       "      <td>3.422343</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.052174</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.216621</td>\n",
       "      <td>0.549203</td>\n",
       "      <td>0.835385</td>\n",
       "      <td>0.982526</td>\n",
       "      <td>0.978229</td>\n",
       "      <td>0.976344</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">CAS</th>\n",
       "      <th>0.00</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.927104</td>\n",
       "      <td>2.205412</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.199959</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.394018</td>\n",
       "      <td>0.838780</td>\n",
       "      <td>0.981828</td>\n",
       "      <td>0.941688</td>\n",
       "      <td>0.929731</td>\n",
       "      <td>0.926960</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.06</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.939344</td>\n",
       "      <td>2.382240</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.176793</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.357646</td>\n",
       "      <td>0.795239</td>\n",
       "      <td>0.966508</td>\n",
       "      <td>0.955306</td>\n",
       "      <td>0.941719</td>\n",
       "      <td>0.938879</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.12</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.943091</td>\n",
       "      <td>2.452028</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.168127</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.344816</td>\n",
       "      <td>0.777701</td>\n",
       "      <td>0.959821</td>\n",
       "      <td>0.958205</td>\n",
       "      <td>0.944922</td>\n",
       "      <td>0.942502</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.18</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.951627</td>\n",
       "      <td>2.613590</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.150136</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.315884</td>\n",
       "      <td>0.739273</td>\n",
       "      <td>0.941719</td>\n",
       "      <td>0.965880</td>\n",
       "      <td>0.952591</td>\n",
       "      <td>0.951015</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.960163</td>\n",
       "      <td>2.805244</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.130510</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.286616</td>\n",
       "      <td>0.693671</td>\n",
       "      <td>0.918216</td>\n",
       "      <td>0.971626</td>\n",
       "      <td>0.960304</td>\n",
       "      <td>0.959656</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.37</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.968617</td>\n",
       "      <td>3.094018</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.104911</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.248227</td>\n",
       "      <td>0.629588</td>\n",
       "      <td>0.879805</td>\n",
       "      <td>0.976724</td>\n",
       "      <td>0.969163</td>\n",
       "      <td>0.968175</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.977977</td>\n",
       "      <td>3.556958</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.075468</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.199078</td>\n",
       "      <td>0.534046</td>\n",
       "      <td>0.808091</td>\n",
       "      <td>0.979856</td>\n",
       "      <td>0.978232</td>\n",
       "      <td>0.976893</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">RCP1</th>\n",
       "      <th>0.00</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.904121</td>\n",
       "      <td>2.764973</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.077228</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.311594</td>\n",
       "      <td>0.676779</td>\n",
       "      <td>0.923991</td>\n",
       "      <td>0.881886</td>\n",
       "      <td>0.896537</td>\n",
       "      <td>0.904511</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.06</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.923812</td>\n",
       "      <td>2.999740</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.061553</td>\n",
       "      <td>0.919475</td>\n",
       "      <td>0.280331</td>\n",
       "      <td>0.626670</td>\n",
       "      <td>0.890846</td>\n",
       "      <td>0.905676</td>\n",
       "      <td>0.915709</td>\n",
       "      <td>0.923204</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.12</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.933682</td>\n",
       "      <td>3.138216</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.053110</td>\n",
       "      <td>0.935939</td>\n",
       "      <td>0.262679</td>\n",
       "      <td>0.597397</td>\n",
       "      <td>0.871226</td>\n",
       "      <td>0.917012</td>\n",
       "      <td>0.925038</td>\n",
       "      <td>0.932408</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.18</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.951020</td>\n",
       "      <td>3.462012</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.038385</td>\n",
       "      <td>0.949659</td>\n",
       "      <td>0.224816</td>\n",
       "      <td>0.536405</td>\n",
       "      <td>0.820271</td>\n",
       "      <td>0.935055</td>\n",
       "      <td>0.942320</td>\n",
       "      <td>0.947536</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.965580</td>\n",
       "      <td>3.846594</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.026669</td>\n",
       "      <td>0.962589</td>\n",
       "      <td>0.186209</td>\n",
       "      <td>0.470407</td>\n",
       "      <td>0.753747</td>\n",
       "      <td>0.954569</td>\n",
       "      <td>0.956597</td>\n",
       "      <td>0.960722</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.37</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.979669</td>\n",
       "      <td>4.425998</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.015644</td>\n",
       "      <td>0.978389</td>\n",
       "      <td>0.139018</td>\n",
       "      <td>0.383785</td>\n",
       "      <td>0.647956</td>\n",
       "      <td>0.975044</td>\n",
       "      <td>0.971286</td>\n",
       "      <td>0.975254</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.990423</td>\n",
       "      <td>5.506274</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.006528</td>\n",
       "      <td>0.988742</td>\n",
       "      <td>0.083520</td>\n",
       "      <td>0.258004</td>\n",
       "      <td>0.466936</td>\n",
       "      <td>0.980725</td>\n",
       "      <td>0.985710</td>\n",
       "      <td>0.987467</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">RCP1Plus</th>\n",
       "      <th>0.00</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.935141</td>\n",
       "      <td>3.126947</td>\n",
       "      <td>0.904874</td>\n",
       "      <td>0.052312</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.263395</td>\n",
       "      <td>0.597440</td>\n",
       "      <td>0.873476</td>\n",
       "      <td>0.918266</td>\n",
       "      <td>0.926038</td>\n",
       "      <td>0.934219</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.06</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.945005</td>\n",
       "      <td>3.310363</td>\n",
       "      <td>0.904624</td>\n",
       "      <td>0.043431</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.240423</td>\n",
       "      <td>0.562511</td>\n",
       "      <td>0.845537</td>\n",
       "      <td>0.926342</td>\n",
       "      <td>0.936140</td>\n",
       "      <td>0.942399</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.12</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.949864</td>\n",
       "      <td>3.418162</td>\n",
       "      <td>0.904187</td>\n",
       "      <td>0.038818</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.227966</td>\n",
       "      <td>0.542706</td>\n",
       "      <td>0.828943</td>\n",
       "      <td>0.931465</td>\n",
       "      <td>0.941214</td>\n",
       "      <td>0.946337</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.18</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.958102</td>\n",
       "      <td>3.607657</td>\n",
       "      <td>0.903741</td>\n",
       "      <td>0.032093</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.207538</td>\n",
       "      <td>0.509984</td>\n",
       "      <td>0.797158</td>\n",
       "      <td>0.942615</td>\n",
       "      <td>0.949702</td>\n",
       "      <td>0.953276</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.967131</td>\n",
       "      <td>3.845992</td>\n",
       "      <td>0.903204</td>\n",
       "      <td>0.025358</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.184290</td>\n",
       "      <td>0.469192</td>\n",
       "      <td>0.755477</td>\n",
       "      <td>0.953589</td>\n",
       "      <td>0.957867</td>\n",
       "      <td>0.961246</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.37</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.977896</td>\n",
       "      <td>4.205428</td>\n",
       "      <td>0.901412</td>\n",
       "      <td>0.017655</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.151009</td>\n",
       "      <td>0.410439</td>\n",
       "      <td>0.687825</td>\n",
       "      <td>0.975859</td>\n",
       "      <td>0.967578</td>\n",
       "      <td>0.972720</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.50</th>\n",
       "      <th>0.9</th>\n",
       "      <td>0.986188</td>\n",
       "      <td>4.722115</td>\n",
       "      <td>0.898813</td>\n",
       "      <td>0.010469</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.116687</td>\n",
       "      <td>0.338872</td>\n",
       "      <td>0.589626</td>\n",
       "      <td>0.983202</td>\n",
       "      <td>0.979074</td>\n",
       "      <td>0.983058</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                  empirical_coverage  avg_set_size  \\\n",
       "method   r    coverage_guarantee                                     \n",
       "BinCP    0.00 0.9                           0.920190      2.205266   \n",
       "         0.06 0.9                           0.933715      2.375282   \n",
       "         0.12 0.9                           0.938357      2.434799   \n",
       "         0.18 0.9                           0.947690      2.583742   \n",
       "         0.25 0.9                           0.956692      2.757695   \n",
       "         0.37 0.9                           0.966475      3.017912   \n",
       "         0.50 0.9                           0.976876      3.422343   \n",
       "CAS      0.00 0.9                           0.927104      2.205412   \n",
       "         0.06 0.9                           0.939344      2.382240   \n",
       "         0.12 0.9                           0.943091      2.452028   \n",
       "         0.18 0.9                           0.951627      2.613590   \n",
       "         0.25 0.9                           0.960163      2.805244   \n",
       "         0.37 0.9                           0.968617      3.094018   \n",
       "         0.50 0.9                           0.977977      3.556958   \n",
       "RCP1     0.00 0.9                           0.904121      2.764973   \n",
       "         0.06 0.9                           0.923812      2.999740   \n",
       "         0.12 0.9                           0.933682      3.138216   \n",
       "         0.18 0.9                           0.951020      3.462012   \n",
       "         0.25 0.9                           0.965580      3.846594   \n",
       "         0.37 0.9                           0.979669      4.425998   \n",
       "         0.50 0.9                           0.990423      5.506274   \n",
       "RCP1Plus 0.00 0.9                           0.935141      3.126947   \n",
       "         0.06 0.9                           0.945005      3.310363   \n",
       "         0.12 0.9                           0.949864      3.418162   \n",
       "         0.18 0.9                           0.958102      3.607657   \n",
       "         0.25 0.9                           0.967131      3.845992   \n",
       "         0.37 0.9                           0.977896      4.205428   \n",
       "         0.50 0.9                           0.986188      4.722115   \n",
       "\n",
       "                                  exact_guarantee  threshold  \\\n",
       "method   r    coverage_guarantee                               \n",
       "BinCP    0.00 0.9                        0.900000   0.050092   \n",
       "         0.06 0.9                        0.900000   0.048593   \n",
       "         0.12 0.9                        0.900000   0.052909   \n",
       "         0.18 0.9                        0.900000   0.052700   \n",
       "         0.25 0.9                        0.900000   0.052732   \n",
       "         0.37 0.9                        0.900000   0.054989   \n",
       "         0.50 0.9                        0.900000   0.052174   \n",
       "CAS      0.00 0.9                        0.900000   0.199959   \n",
       "         0.06 0.9                        0.900000   0.176793   \n",
       "         0.12 0.9                        0.900000   0.168127   \n",
       "         0.18 0.9                        0.900000   0.150136   \n",
       "         0.25 0.9                        0.900000   0.130510   \n",
       "         0.37 0.9                        0.900000   0.104911   \n",
       "         0.50 0.9                        0.900000   0.075468   \n",
       "RCP1     0.00 0.9                        0.900000   0.077228   \n",
       "         0.06 0.9                        0.900000   0.061553   \n",
       "         0.12 0.9                        0.900000   0.053110   \n",
       "         0.18 0.9                        0.900000   0.038385   \n",
       "         0.25 0.9                        0.900000   0.026669   \n",
       "         0.37 0.9                        0.900000   0.015644   \n",
       "         0.50 0.9                        0.900000   0.006528   \n",
       "RCP1Plus 0.00 0.9                        0.904874   0.052312   \n",
       "         0.06 0.9                        0.904624   0.043431   \n",
       "         0.12 0.9                        0.904187   0.038818   \n",
       "         0.18 0.9                        0.903741   0.032093   \n",
       "         0.25 0.9                        0.903204   0.025358   \n",
       "         0.37 0.9                        0.901412   0.017655   \n",
       "         0.50 0.9                        0.898813   0.010469   \n",
       "\n",
       "                                  internal_coverage_level   below_1   below_3  \\\n",
       "method   r    coverage_guarantee                                                \n",
       "BinCP    0.00 0.9                                0.901000  0.396708  0.832858   \n",
       "         0.06 0.9                                0.901000  0.364035  0.785602   \n",
       "         0.12 0.9                                0.901000  0.352571  0.770775   \n",
       "         0.18 0.9                                0.901000  0.327473  0.732044   \n",
       "         0.25 0.9                                0.901000  0.300266  0.689783   \n",
       "         0.37 0.9                                0.901000  0.262543  0.632739   \n",
       "         0.50 0.9                                0.901000  0.216621  0.549203   \n",
       "CAS      0.00 0.9                                0.901000  0.394018  0.838780   \n",
       "         0.06 0.9                                0.901000  0.357646  0.795239   \n",
       "         0.12 0.9                                0.901000  0.344816  0.777701   \n",
       "         0.18 0.9                                0.901000  0.315884  0.739273   \n",
       "         0.25 0.9                                0.901000  0.286616  0.693671   \n",
       "         0.37 0.9                                0.901000  0.248227  0.629588   \n",
       "         0.50 0.9                                0.901000  0.199078  0.534046   \n",
       "RCP1     0.00 0.9                                0.900000  0.311594  0.676779   \n",
       "         0.06 0.9                                0.919475  0.280331  0.626670   \n",
       "         0.12 0.9                                0.935939  0.262679  0.597397   \n",
       "         0.18 0.9                                0.949659  0.224816  0.536405   \n",
       "         0.25 0.9                                0.962589  0.186209  0.470407   \n",
       "         0.37 0.9                                0.978389  0.139018  0.383785   \n",
       "         0.50 0.9                                0.988742  0.083520  0.258004   \n",
       "RCP1Plus 0.00 0.9                                0.900000  0.263395  0.597440   \n",
       "         0.06 0.9                                0.900000  0.240423  0.562511   \n",
       "         0.12 0.9                                0.900000  0.227966  0.542706   \n",
       "         0.18 0.9                                0.900000  0.207538  0.509984   \n",
       "         0.25 0.9                                0.900000  0.184290  0.469192   \n",
       "         0.37 0.9                                0.900000  0.151009  0.410439   \n",
       "         0.50 0.9                                0.900000  0.116687  0.338872   \n",
       "\n",
       "                                   below_5  below_1_coverage  \\\n",
       "method   r    coverage_guarantee                               \n",
       "BinCP    0.00 0.9                 0.989360          0.937813   \n",
       "         0.06 0.9                 0.979441          0.946961   \n",
       "         0.12 0.9                 0.974696          0.949975   \n",
       "         0.18 0.9                 0.961085          0.957001   \n",
       "         0.25 0.9                 0.939794          0.965945   \n",
       "         0.37 0.9                 0.902278          0.975668   \n",
       "         0.50 0.9                 0.835385          0.982526   \n",
       "CAS      0.00 0.9                 0.981828          0.941688   \n",
       "         0.06 0.9                 0.966508          0.955306   \n",
       "         0.12 0.9                 0.959821          0.958205   \n",
       "         0.18 0.9                 0.941719          0.965880   \n",
       "         0.25 0.9                 0.918216          0.971626   \n",
       "         0.37 0.9                 0.879805          0.976724   \n",
       "         0.50 0.9                 0.808091          0.979856   \n",
       "RCP1     0.00 0.9                 0.923991          0.881886   \n",
       "         0.06 0.9                 0.890846          0.905676   \n",
       "         0.12 0.9                 0.871226          0.917012   \n",
       "         0.18 0.9                 0.820271          0.935055   \n",
       "         0.25 0.9                 0.753747          0.954569   \n",
       "         0.37 0.9                 0.647956          0.975044   \n",
       "         0.50 0.9                 0.466936          0.980725   \n",
       "RCP1Plus 0.00 0.9                 0.873476          0.918266   \n",
       "         0.06 0.9                 0.845537          0.926342   \n",
       "         0.12 0.9                 0.828943          0.931465   \n",
       "         0.18 0.9                 0.797158          0.942615   \n",
       "         0.25 0.9                 0.755477          0.953589   \n",
       "         0.37 0.9                 0.687825          0.975859   \n",
       "         0.50 0.9                 0.589626          0.983202   \n",
       "\n",
       "                                  below_3_coverage  below_5_coverage  \\\n",
       "method   r    coverage_guarantee                                       \n",
       "BinCP    0.00 0.9                         0.923996          0.920161   \n",
       "         0.06 0.9                         0.937724          0.933963   \n",
       "         0.12 0.9                         0.941699          0.938689   \n",
       "         0.18 0.9                         0.950574          0.948089   \n",
       "         0.25 0.9                         0.959123          0.957116   \n",
       "         0.37 0.9                         0.968865          0.966848   \n",
       "         0.50 0.9                         0.978229          0.976344   \n",
       "CAS      0.00 0.9                         0.929731          0.926960   \n",
       "         0.06 0.9                         0.941719          0.938879   \n",
       "         0.12 0.9                         0.944922          0.942502   \n",
       "         0.18 0.9                         0.952591          0.951015   \n",
       "         0.25 0.9                         0.960304          0.959656   \n",
       "         0.37 0.9                         0.969163          0.968175   \n",
       "         0.50 0.9                         0.978232          0.976893   \n",
       "RCP1     0.00 0.9                         0.896537          0.904511   \n",
       "         0.06 0.9                         0.915709          0.923204   \n",
       "         0.12 0.9                         0.925038          0.932408   \n",
       "         0.18 0.9                         0.942320          0.947536   \n",
       "         0.25 0.9                         0.956597          0.960722   \n",
       "         0.37 0.9                         0.971286          0.975254   \n",
       "         0.50 0.9                         0.985710          0.987467   \n",
       "RCP1Plus 0.00 0.9                         0.926038          0.934219   \n",
       "         0.06 0.9                         0.936140          0.942399   \n",
       "         0.12 0.9                         0.941214          0.946337   \n",
       "         0.18 0.9                         0.949702          0.953276   \n",
       "         0.25 0.9                         0.957867          0.961246   \n",
       "         0.37 0.9                         0.967578          0.972720   \n",
       "         0.50 0.9                         0.979074          0.983058   \n",
       "\n",
       "                                  n_samples  \n",
       "method   r    coverage_guarantee             \n",
       "BinCP    0.00 0.9                   10000.0  \n",
       "         0.06 0.9                   10000.0  \n",
       "         0.12 0.9                   10000.0  \n",
       "         0.18 0.9                   10000.0  \n",
       "         0.25 0.9                   10000.0  \n",
       "         0.37 0.9                   10000.0  \n",
       "         0.50 0.9                   10000.0  \n",
       "CAS      0.00 0.9                   10000.0  \n",
       "         0.06 0.9                   10000.0  \n",
       "         0.12 0.9                   10000.0  \n",
       "         0.18 0.9                   10000.0  \n",
       "         0.25 0.9                   10000.0  \n",
       "         0.37 0.9                   10000.0  \n",
       "         0.50 0.9                   10000.0  \n",
       "RCP1     0.00 0.9                   10000.0  \n",
       "         0.06 0.9                   10000.0  \n",
       "         0.12 0.9                   10000.0  \n",
       "         0.18 0.9                   10000.0  \n",
       "         0.25 0.9                   10000.0  \n",
       "         0.37 0.9                   10000.0  \n",
       "         0.50 0.9                   10000.0  \n",
       "RCP1Plus 0.00 0.9                   10000.0  \n",
       "         0.06 0.9                   10000.0  \n",
       "         0.12 0.9                   10000.0  \n",
       "         0.18 0.9                   10000.0  \n",
       "         0.25 0.9                   10000.0  \n",
       "         0.37 0.9                   10000.0  \n",
       "         0.50 0.9                   10000.0  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_df = pd.DataFrame(result)\n",
    "output_path = output_dir/f\"score-compare_robustcp_methods_{dataset_name}_sigma{model_sigma}_score{score_method}_nsamples{n_samples}_ntrialsamples{n_trial_samples}_calibbudget{calibration_budget}_niters{n_iterations}.csv\"\n",
    "results_df.to_csv(output_path, index=False)\n",
    "results_df.groupby([\"method\", \"r\", \"coverage_guarantee\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running for r=0.0 and coverage=0.9900000095367432\n",
      "running for r=0.06 and coverage=0.9900000095367432\n",
      "running for r=0.12 and coverage=0.9900000095367432\n",
      "running for r=0.18 and coverage=0.9900000095367432\n",
      "running for r=0.25 and coverage=0.9900000095367432\n",
      "running for r=0.37 and coverage=0.9900000095367432\n",
      "running for r=0.5 and coverage=0.9900000095367432\n",
      "running for r=0.75 and coverage=0.9900000095367432\n",
      "running for r=0.0 and coverage=0.9800000190734863\n",
      "running for r=0.06 and coverage=0.9800000190734863\n",
      "running for r=0.12 and coverage=0.9800000190734863\n",
      "running for r=0.18 and coverage=0.9800000190734863\n",
      "running for r=0.25 and coverage=0.9800000190734863\n",
      "running for r=0.37 and coverage=0.9800000190734863\n",
      "running for r=0.5 and coverage=0.9800000190734863\n",
      "running for r=0.75 and coverage=0.9800000190734863\n",
      "running for r=0.0 and coverage=0.9700000286102295\n",
      "running for r=0.06 and coverage=0.9700000286102295\n",
      "running for r=0.12 and coverage=0.9700000286102295\n",
      "running for r=0.18 and coverage=0.9700000286102295\n",
      "running for r=0.25 and coverage=0.9700000286102295\n",
      "running for r=0.37 and coverage=0.9700000286102295\n",
      "running for r=0.5 and coverage=0.9700000286102295\n",
      "running for r=0.75 and coverage=0.9700000286102295\n",
      "running for r=0.0 and coverage=0.9600000381469727\n",
      "running for r=0.06 and coverage=0.9600000381469727\n",
      "running for r=0.12 and coverage=0.9600000381469727\n",
      "running for r=0.18 and coverage=0.9600000381469727\n",
      "running for r=0.25 and coverage=0.9600000381469727\n",
      "running for r=0.37 and coverage=0.9600000381469727\n",
      "running for r=0.5 and coverage=0.9600000381469727\n",
      "running for r=0.75 and coverage=0.9600000381469727\n",
      "running for r=0.0 and coverage=0.949999988079071\n",
      "running for r=0.06 and coverage=0.949999988079071\n",
      "running for r=0.12 and coverage=0.949999988079071\n",
      "running for r=0.18 and coverage=0.949999988079071\n",
      "running for r=0.25 and coverage=0.949999988079071\n",
      "running for r=0.37 and coverage=0.949999988079071\n",
      "running for r=0.5 and coverage=0.949999988079071\n",
      "running for r=0.75 and coverage=0.949999988079071\n",
      "running for r=0.0 and coverage=0.9399999976158142\n",
      "running for r=0.06 and coverage=0.9399999976158142\n",
      "running for r=0.12 and coverage=0.9399999976158142\n",
      "running for r=0.18 and coverage=0.9399999976158142\n",
      "running for r=0.25 and coverage=0.9399999976158142\n",
      "running for r=0.37 and coverage=0.9399999976158142\n",
      "running for r=0.5 and coverage=0.9399999976158142\n",
      "running for r=0.75 and coverage=0.9399999976158142\n",
      "running for r=0.0 and coverage=0.9300000071525574\n",
      "running for r=0.06 and coverage=0.9300000071525574\n",
      "running for r=0.12 and coverage=0.9300000071525574\n",
      "running for r=0.18 and coverage=0.9300000071525574\n",
      "running for r=0.25 and coverage=0.9300000071525574\n",
      "running for r=0.37 and coverage=0.9300000071525574\n",
      "running for r=0.5 and coverage=0.9300000071525574\n",
      "running for r=0.75 and coverage=0.9300000071525574\n",
      "running for r=0.0 and coverage=0.9200000166893005\n",
      "running for r=0.06 and coverage=0.9200000166893005\n",
      "running for r=0.12 and coverage=0.9200000166893005\n",
      "running for r=0.18 and coverage=0.9200000166893005\n",
      "running for r=0.25 and coverage=0.9200000166893005\n",
      "running for r=0.37 and coverage=0.9200000166893005\n",
      "running for r=0.5 and coverage=0.9200000166893005\n",
      "running for r=0.75 and coverage=0.9200000166893005\n",
      "running for r=0.0 and coverage=0.9100000262260437\n",
      "running for r=0.06 and coverage=0.9100000262260437\n",
      "running for r=0.12 and coverage=0.9100000262260437\n",
      "running for r=0.18 and coverage=0.9100000262260437\n",
      "running for r=0.25 and coverage=0.9100000262260437\n",
      "running for r=0.37 and coverage=0.9100000262260437\n",
      "running for r=0.5 and coverage=0.9100000262260437\n",
      "running for r=0.75 and coverage=0.9100000262260437\n",
      "running for r=0.0 and coverage=0.9000000357627869\n",
      "running for r=0.06 and coverage=0.9000000357627869\n",
      "running for r=0.12 and coverage=0.9000000357627869\n",
      "running for r=0.18 and coverage=0.9000000357627869\n",
      "running for r=0.25 and coverage=0.9000000357627869\n",
      "running for r=0.37 and coverage=0.9000000357627869\n",
      "running for r=0.5 and coverage=0.9000000357627869\n",
      "running for r=0.75 and coverage=0.9000000357627869\n",
      "running for r=0.0 and coverage=0.8899999856948853\n",
      "running for r=0.06 and coverage=0.8899999856948853\n",
      "running for r=0.12 and coverage=0.8899999856948853\n",
      "running for r=0.18 and coverage=0.8899999856948853\n",
      "running for r=0.25 and coverage=0.8899999856948853\n",
      "running for r=0.37 and coverage=0.8899999856948853\n",
      "running for r=0.5 and coverage=0.8899999856948853\n",
      "running for r=0.75 and coverage=0.8899999856948853\n",
      "running for r=0.0 and coverage=0.8799999952316284\n",
      "running for r=0.06 and coverage=0.8799999952316284\n",
      "running for r=0.12 and coverage=0.8799999952316284\n",
      "running for r=0.18 and coverage=0.8799999952316284\n",
      "running for r=0.25 and coverage=0.8799999952316284\n",
      "running for r=0.37 and coverage=0.8799999952316284\n",
      "running for r=0.5 and coverage=0.8799999952316284\n",
      "running for r=0.75 and coverage=0.8799999952316284\n",
      "running for r=0.0 and coverage=0.8700000047683716\n",
      "running for r=0.06 and coverage=0.8700000047683716\n",
      "running for r=0.12 and coverage=0.8700000047683716\n",
      "running for r=0.18 and coverage=0.8700000047683716\n",
      "running for r=0.25 and coverage=0.8700000047683716\n",
      "running for r=0.37 and coverage=0.8700000047683716\n",
      "running for r=0.5 and coverage=0.8700000047683716\n",
      "running for r=0.75 and coverage=0.8700000047683716\n",
      "running for r=0.0 and coverage=0.8600000143051147\n",
      "running for r=0.06 and coverage=0.8600000143051147\n",
      "running for r=0.12 and coverage=0.8600000143051147\n",
      "running for r=0.18 and coverage=0.8600000143051147\n",
      "running for r=0.25 and coverage=0.8600000143051147\n",
      "running for r=0.37 and coverage=0.8600000143051147\n",
      "running for r=0.5 and coverage=0.8600000143051147\n",
      "running for r=0.75 and coverage=0.8600000143051147\n",
      "running for r=0.0 and coverage=0.8500000238418579\n",
      "running for r=0.06 and coverage=0.8500000238418579\n",
      "running for r=0.12 and coverage=0.8500000238418579\n",
      "running for r=0.18 and coverage=0.8500000238418579\n",
      "running for r=0.25 and coverage=0.8500000238418579\n",
      "running for r=0.37 and coverage=0.8500000238418579\n",
      "running for r=0.5 and coverage=0.8500000238418579\n",
      "running for r=0.75 and coverage=0.8500000238418579\n",
      "running for r=0.0 and coverage=0.8400000333786011\n",
      "running for r=0.06 and coverage=0.8400000333786011\n",
      "running for r=0.12 and coverage=0.8400000333786011\n",
      "running for r=0.18 and coverage=0.8400000333786011\n",
      "running for r=0.25 and coverage=0.8400000333786011\n",
      "running for r=0.37 and coverage=0.8400000333786011\n",
      "running for r=0.5 and coverage=0.8400000333786011\n",
      "running for r=0.75 and coverage=0.8400000333786011\n",
      "running for r=0.0 and coverage=0.8300000429153442\n",
      "running for r=0.06 and coverage=0.8300000429153442\n",
      "running for r=0.12 and coverage=0.8300000429153442\n",
      "running for r=0.18 and coverage=0.8300000429153442\n",
      "running for r=0.25 and coverage=0.8300000429153442\n",
      "running for r=0.37 and coverage=0.8300000429153442\n",
      "running for r=0.5 and coverage=0.8300000429153442\n",
      "running for r=0.75 and coverage=0.8300000429153442\n",
      "running for r=0.0 and coverage=0.8199999928474426\n",
      "running for r=0.06 and coverage=0.8199999928474426\n",
      "running for r=0.12 and coverage=0.8199999928474426\n",
      "running for r=0.18 and coverage=0.8199999928474426\n",
      "running for r=0.25 and coverage=0.8199999928474426\n",
      "running for r=0.37 and coverage=0.8199999928474426\n",
      "running for r=0.5 and coverage=0.8199999928474426\n",
      "running for r=0.75 and coverage=0.8199999928474426\n",
      "running for r=0.0 and coverage=0.8100000023841858\n",
      "running for r=0.06 and coverage=0.8100000023841858\n",
      "running for r=0.12 and coverage=0.8100000023841858\n",
      "running for r=0.18 and coverage=0.8100000023841858\n",
      "running for r=0.25 and coverage=0.8100000023841858\n",
      "running for r=0.37 and coverage=0.8100000023841858\n",
      "running for r=0.5 and coverage=0.8100000023841858\n",
      "running for r=0.75 and coverage=0.8100000023841858\n",
      "running for r=0.0 and coverage=0.800000011920929\n",
      "running for r=0.06 and coverage=0.800000011920929\n",
      "running for r=0.12 and coverage=0.800000011920929\n",
      "running for r=0.18 and coverage=0.800000011920929\n",
      "running for r=0.25 and coverage=0.800000011920929\n",
      "running for r=0.37 and coverage=0.800000011920929\n",
      "running for r=0.5 and coverage=0.800000011920929\n",
      "running for r=0.75 and coverage=0.800000011920929\n",
      "running for r=0.0 and coverage=0.7900000214576721\n",
      "running for r=0.06 and coverage=0.7900000214576721\n",
      "running for r=0.12 and coverage=0.7900000214576721\n",
      "running for r=0.18 and coverage=0.7900000214576721\n",
      "running for r=0.25 and coverage=0.7900000214576721\n",
      "running for r=0.37 and coverage=0.7900000214576721\n",
      "running for r=0.5 and coverage=0.7900000214576721\n",
      "running for r=0.75 and coverage=0.7900000214576721\n",
      "running for r=0.0 and coverage=0.7800000309944153\n",
      "running for r=0.06 and coverage=0.7800000309944153\n",
      "running for r=0.12 and coverage=0.7800000309944153\n",
      "running for r=0.18 and coverage=0.7800000309944153\n",
      "running for r=0.25 and coverage=0.7800000309944153\n",
      "running for r=0.37 and coverage=0.7800000309944153\n",
      "running for r=0.5 and coverage=0.7800000309944153\n",
      "running for r=0.75 and coverage=0.7800000309944153\n",
      "running for r=0.0 and coverage=0.7700000405311584\n",
      "running for r=0.06 and coverage=0.7700000405311584\n",
      "running for r=0.12 and coverage=0.7700000405311584\n",
      "running for r=0.18 and coverage=0.7700000405311584\n",
      "running for r=0.25 and coverage=0.7700000405311584\n",
      "running for r=0.37 and coverage=0.7700000405311584\n",
      "running for r=0.5 and coverage=0.7700000405311584\n",
      "running for r=0.75 and coverage=0.7700000405311584\n",
      "running for r=0.0 and coverage=0.7599999904632568\n",
      "running for r=0.06 and coverage=0.7599999904632568\n",
      "running for r=0.12 and coverage=0.7599999904632568\n",
      "running for r=0.18 and coverage=0.7599999904632568\n",
      "running for r=0.25 and coverage=0.7599999904632568\n",
      "running for r=0.37 and coverage=0.7599999904632568\n",
      "running for r=0.5 and coverage=0.7599999904632568\n",
      "running for r=0.75 and coverage=0.7599999904632568\n",
      "running for r=0.0 and coverage=0.75\n",
      "running for r=0.06 and coverage=0.75\n",
      "running for r=0.12 and coverage=0.75\n",
      "running for r=0.18 and coverage=0.75\n",
      "running for r=0.25 and coverage=0.75\n",
      "running for r=0.37 and coverage=0.75\n",
      "running for r=0.5 and coverage=0.75\n",
      "running for r=0.75 and coverage=0.75\n",
      "running for r=0.0 and coverage=0.7400000095367432\n",
      "running for r=0.06 and coverage=0.7400000095367432\n",
      "running for r=0.12 and coverage=0.7400000095367432\n",
      "running for r=0.18 and coverage=0.7400000095367432\n",
      "running for r=0.25 and coverage=0.7400000095367432\n",
      "running for r=0.37 and coverage=0.7400000095367432\n",
      "running for r=0.5 and coverage=0.7400000095367432\n",
      "running for r=0.75 and coverage=0.7400000095367432\n",
      "running for r=0.0 and coverage=0.7300000190734863\n",
      "running for r=0.06 and coverage=0.7300000190734863\n",
      "running for r=0.12 and coverage=0.7300000190734863\n",
      "running for r=0.18 and coverage=0.7300000190734863\n",
      "running for r=0.25 and coverage=0.7300000190734863\n",
      "running for r=0.37 and coverage=0.7300000190734863\n",
      "running for r=0.5 and coverage=0.7300000190734863\n",
      "running for r=0.75 and coverage=0.7300000190734863\n",
      "running for r=0.0 and coverage=0.7199999690055847\n",
      "running for r=0.06 and coverage=0.7199999690055847\n",
      "running for r=0.12 and coverage=0.7199999690055847\n",
      "running for r=0.18 and coverage=0.7199999690055847\n",
      "running for r=0.25 and coverage=0.7199999690055847\n",
      "running for r=0.37 and coverage=0.7199999690055847\n",
      "running for r=0.5 and coverage=0.7199999690055847\n",
      "running for r=0.75 and coverage=0.7199999690055847\n",
      "running for r=0.0 and coverage=0.7099999785423279\n",
      "running for r=0.06 and coverage=0.7099999785423279\n",
      "running for r=0.12 and coverage=0.7099999785423279\n",
      "running for r=0.18 and coverage=0.7099999785423279\n",
      "running for r=0.25 and coverage=0.7099999785423279\n",
      "running for r=0.37 and coverage=0.7099999785423279\n",
      "running for r=0.5 and coverage=0.7099999785423279\n",
      "running for r=0.75 and coverage=0.7099999785423279\n",
      "running for r=0.0 and coverage=0.699999988079071\n",
      "running for r=0.06 and coverage=0.699999988079071\n",
      "running for r=0.12 and coverage=0.699999988079071\n",
      "running for r=0.18 and coverage=0.699999988079071\n",
      "running for r=0.25 and coverage=0.699999988079071\n",
      "running for r=0.37 and coverage=0.699999988079071\n",
      "running for r=0.5 and coverage=0.699999988079071\n",
      "running for r=0.75 and coverage=0.699999988079071\n",
      "running for r=0.0 and coverage=0.6899999976158142\n",
      "running for r=0.06 and coverage=0.6899999976158142\n",
      "running for r=0.12 and coverage=0.6899999976158142\n",
      "running for r=0.18 and coverage=0.6899999976158142\n",
      "running for r=0.25 and coverage=0.6899999976158142\n",
      "running for r=0.37 and coverage=0.6899999976158142\n",
      "running for r=0.5 and coverage=0.6899999976158142\n",
      "running for r=0.75 and coverage=0.6899999976158142\n",
      "running for r=0.0 and coverage=0.6800000071525574\n",
      "running for r=0.06 and coverage=0.6800000071525574\n",
      "running for r=0.12 and coverage=0.6800000071525574\n",
      "running for r=0.18 and coverage=0.6800000071525574\n",
      "running for r=0.25 and coverage=0.6800000071525574\n",
      "running for r=0.37 and coverage=0.6800000071525574\n",
      "running for r=0.5 and coverage=0.6800000071525574\n",
      "running for r=0.75 and coverage=0.6800000071525574\n",
      "running for r=0.0 and coverage=0.6700000166893005\n",
      "running for r=0.06 and coverage=0.6700000166893005\n",
      "running for r=0.12 and coverage=0.6700000166893005\n",
      "running for r=0.18 and coverage=0.6700000166893005\n",
      "running for r=0.25 and coverage=0.6700000166893005\n",
      "running for r=0.37 and coverage=0.6700000166893005\n",
      "running for r=0.5 and coverage=0.6700000166893005\n",
      "running for r=0.75 and coverage=0.6700000166893005\n",
      "running for r=0.0 and coverage=0.6599999666213989\n",
      "running for r=0.06 and coverage=0.6599999666213989\n",
      "running for r=0.12 and coverage=0.6599999666213989\n",
      "running for r=0.18 and coverage=0.6599999666213989\n",
      "running for r=0.25 and coverage=0.6599999666213989\n",
      "running for r=0.37 and coverage=0.6599999666213989\n",
      "running for r=0.5 and coverage=0.6599999666213989\n",
      "running for r=0.75 and coverage=0.6599999666213989\n",
      "running for r=0.0 and coverage=0.6499999761581421\n",
      "running for r=0.06 and coverage=0.6499999761581421\n",
      "running for r=0.12 and coverage=0.6499999761581421\n",
      "running for r=0.18 and coverage=0.6499999761581421\n",
      "running for r=0.25 and coverage=0.6499999761581421\n",
      "running for r=0.37 and coverage=0.6499999761581421\n",
      "running for r=0.5 and coverage=0.6499999761581421\n",
      "running for r=0.75 and coverage=0.6499999761581421\n",
      "running for r=0.0 and coverage=0.6399999856948853\n",
      "running for r=0.06 and coverage=0.6399999856948853\n",
      "running for r=0.12 and coverage=0.6399999856948853\n",
      "running for r=0.18 and coverage=0.6399999856948853\n",
      "running for r=0.25 and coverage=0.6399999856948853\n",
      "running for r=0.37 and coverage=0.6399999856948853\n",
      "running for r=0.5 and coverage=0.6399999856948853\n",
      "running for r=0.75 and coverage=0.6399999856948853\n",
      "running for r=0.0 and coverage=0.6299999952316284\n",
      "running for r=0.06 and coverage=0.6299999952316284\n",
      "running for r=0.12 and coverage=0.6299999952316284\n",
      "running for r=0.18 and coverage=0.6299999952316284\n",
      "running for r=0.25 and coverage=0.6299999952316284\n",
      "running for r=0.37 and coverage=0.6299999952316284\n",
      "running for r=0.5 and coverage=0.6299999952316284\n",
      "running for r=0.75 and coverage=0.6299999952316284\n",
      "running for r=0.0 and coverage=0.6200000047683716\n",
      "running for r=0.06 and coverage=0.6200000047683716\n",
      "running for r=0.12 and coverage=0.6200000047683716\n",
      "running for r=0.18 and coverage=0.6200000047683716\n",
      "running for r=0.25 and coverage=0.6200000047683716\n",
      "running for r=0.37 and coverage=0.6200000047683716\n",
      "running for r=0.5 and coverage=0.6200000047683716\n",
      "running for r=0.75 and coverage=0.6200000047683716\n",
      "running for r=0.0 and coverage=0.6100000143051147\n",
      "running for r=0.06 and coverage=0.6100000143051147\n",
      "running for r=0.12 and coverage=0.6100000143051147\n",
      "running for r=0.18 and coverage=0.6100000143051147\n",
      "running for r=0.25 and coverage=0.6100000143051147\n",
      "running for r=0.37 and coverage=0.6100000143051147\n",
      "running for r=0.5 and coverage=0.6100000143051147\n",
      "running for r=0.75 and coverage=0.6100000143051147\n",
      "running for r=0.0 and coverage=0.6000000238418579\n",
      "running for r=0.06 and coverage=0.6000000238418579\n",
      "running for r=0.12 and coverage=0.6000000238418579\n",
      "running for r=0.18 and coverage=0.6000000238418579\n",
      "running for r=0.25 and coverage=0.6000000238418579\n",
      "running for r=0.37 and coverage=0.6000000238418579\n",
      "running for r=0.5 and coverage=0.6000000238418579\n",
      "running for r=0.75 and coverage=0.6000000238418579\n",
      "running for r=0.0 and coverage=0.5899999737739563\n",
      "running for r=0.06 and coverage=0.5899999737739563\n",
      "running for r=0.12 and coverage=0.5899999737739563\n",
      "running for r=0.18 and coverage=0.5899999737739563\n",
      "running for r=0.25 and coverage=0.5899999737739563\n",
      "running for r=0.37 and coverage=0.5899999737739563\n",
      "running for r=0.5 and coverage=0.5899999737739563\n",
      "running for r=0.75 and coverage=0.5899999737739563\n",
      "running for r=0.0 and coverage=0.5799999833106995\n",
      "running for r=0.06 and coverage=0.5799999833106995\n",
      "running for r=0.12 and coverage=0.5799999833106995\n",
      "running for r=0.18 and coverage=0.5799999833106995\n",
      "running for r=0.25 and coverage=0.5799999833106995\n",
      "running for r=0.37 and coverage=0.5799999833106995\n",
      "running for r=0.5 and coverage=0.5799999833106995\n",
      "running for r=0.75 and coverage=0.5799999833106995\n",
      "running for r=0.0 and coverage=0.5699999928474426\n",
      "running for r=0.06 and coverage=0.5699999928474426\n",
      "running for r=0.12 and coverage=0.5699999928474426\n",
      "running for r=0.18 and coverage=0.5699999928474426\n",
      "running for r=0.25 and coverage=0.5699999928474426\n",
      "running for r=0.37 and coverage=0.5699999928474426\n",
      "running for r=0.5 and coverage=0.5699999928474426\n",
      "running for r=0.75 and coverage=0.5699999928474426\n",
      "running for r=0.0 and coverage=0.5600000023841858\n",
      "running for r=0.06 and coverage=0.5600000023841858\n",
      "running for r=0.12 and coverage=0.5600000023841858\n",
      "running for r=0.18 and coverage=0.5600000023841858\n",
      "running for r=0.25 and coverage=0.5600000023841858\n",
      "running for r=0.37 and coverage=0.5600000023841858\n",
      "running for r=0.5 and coverage=0.5600000023841858\n",
      "running for r=0.75 and coverage=0.5600000023841858\n",
      "running for r=0.0 and coverage=0.550000011920929\n",
      "running for r=0.06 and coverage=0.550000011920929\n",
      "running for r=0.12 and coverage=0.550000011920929\n",
      "running for r=0.18 and coverage=0.550000011920929\n",
      "running for r=0.25 and coverage=0.550000011920929\n",
      "running for r=0.37 and coverage=0.550000011920929\n",
      "running for r=0.5 and coverage=0.550000011920929\n",
      "running for r=0.75 and coverage=0.550000011920929\n",
      "running for r=0.0 and coverage=0.5400000214576721\n",
      "running for r=0.06 and coverage=0.5400000214576721\n",
      "running for r=0.12 and coverage=0.5400000214576721\n",
      "running for r=0.18 and coverage=0.5400000214576721\n",
      "running for r=0.25 and coverage=0.5400000214576721\n",
      "running for r=0.37 and coverage=0.5400000214576721\n",
      "running for r=0.5 and coverage=0.5400000214576721\n",
      "running for r=0.75 and coverage=0.5400000214576721\n",
      "running for r=0.0 and coverage=0.5299999713897705\n",
      "running for r=0.06 and coverage=0.5299999713897705\n",
      "running for r=0.12 and coverage=0.5299999713897705\n",
      "running for r=0.18 and coverage=0.5299999713897705\n",
      "running for r=0.25 and coverage=0.5299999713897705\n",
      "running for r=0.37 and coverage=0.5299999713897705\n",
      "running for r=0.5 and coverage=0.5299999713897705\n",
      "running for r=0.75 and coverage=0.5299999713897705\n",
      "running for r=0.0 and coverage=0.5199999809265137\n",
      "running for r=0.06 and coverage=0.5199999809265137\n",
      "running for r=0.12 and coverage=0.5199999809265137\n",
      "running for r=0.18 and coverage=0.5199999809265137\n",
      "running for r=0.25 and coverage=0.5199999809265137\n",
      "running for r=0.37 and coverage=0.5199999809265137\n",
      "running for r=0.5 and coverage=0.5199999809265137\n",
      "running for r=0.75 and coverage=0.5199999809265137\n",
      "running for r=0.0 and coverage=0.5099999904632568\n",
      "running for r=0.06 and coverage=0.5099999904632568\n",
      "running for r=0.12 and coverage=0.5099999904632568\n",
      "running for r=0.18 and coverage=0.5099999904632568\n",
      "running for r=0.25 and coverage=0.5099999904632568\n",
      "running for r=0.37 and coverage=0.5099999904632568\n",
      "running for r=0.5 and coverage=0.5099999904632568\n",
      "running for r=0.75 and coverage=0.5099999904632568\n",
      "running for r=0.0 and coverage=0.5\n",
      "running for r=0.06 and coverage=0.5\n",
      "running for r=0.12 and coverage=0.5\n",
      "running for r=0.18 and coverage=0.5\n",
      "running for r=0.25 and coverage=0.5\n",
      "running for r=0.37 and coverage=0.5\n",
      "running for r=0.5 and coverage=0.5\n",
      "running for r=0.75 and coverage=0.5\n"
     ]
    }
   ],
   "source": [
    "coverage_range = torch.linspace(0.99, 0.5, 50)\n",
    "\n",
    "cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "eval_mask = ~cal_mask\n",
    "n_dcal = cal_mask.sum().item()\n",
    "coverage_guarantee = 0.9\n",
    "r = 0.25\n",
    "\n",
    "result = []\n",
    "for coverage_guarantee in coverage_range.tolist():\n",
    "    for r in [0.0, 0.06, 0.12, 0.18, 0.25, 0.37, 0.5, 0.75]:\n",
    "        print(f\"running for r={r} and coverage={coverage_guarantee}\")\n",
    "        method = RCP1Plus(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, nominal_coverage=coverage_guarantee, r=r)\n",
    "\n",
    "        result.append({\n",
    "            \"sigma\": smoothing_sigma,\n",
    "            \"r\": r,\n",
    "            \"coverage_guarantee\": coverage_guarantee,\n",
    "            \"rcp1plus\": method.return_worst_case_guarantee(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask]), \n",
    "            \"rcp1\": method.certificate_function(torch.tensor([coverage_guarantee])).item(), \n",
    "        })\n",
    "\n",
    "df = pd.DataFrame(result)\n",
    "df.to_csv(f\"{output_dir}/convexity_gap_cifar10_smoothsigma-{smoothing_sigma}_modelsigma-{model_sigma}_ndatapoints-{n_datapoints}_nsamples-{n_samples}_ntrials-{n_iterations}_final.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "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>sigma</th>\n",
       "      <th>r</th>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>rcp1plus</th>\n",
       "      <th>rcp1</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.99</td>\n",
       "      <td>0.964948</td>\n",
       "      <td>0.966101</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.98</td>\n",
       "      <td>0.942778</td>\n",
       "      <td>0.939878</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.97</td>\n",
       "      <td>0.929247</td>\n",
       "      <td>0.916329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.96</td>\n",
       "      <td>0.926824</td>\n",
       "      <td>0.894476</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.95</td>\n",
       "      <td>0.920444</td>\n",
       "      <td>0.873865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.94</td>\n",
       "      <td>0.911693</td>\n",
       "      <td>0.854236</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.93</td>\n",
       "      <td>0.896843</td>\n",
       "      <td>0.835416</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.92</td>\n",
       "      <td>0.886030</td>\n",
       "      <td>0.817286</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>60</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.91</td>\n",
       "      <td>0.860473</td>\n",
       "      <td>0.799757</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>67</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.854623</td>\n",
       "      <td>0.782761</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>74</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.89</td>\n",
       "      <td>0.851628</td>\n",
       "      <td>0.766242</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>81</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.88</td>\n",
       "      <td>0.839810</td>\n",
       "      <td>0.750158</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.87</td>\n",
       "      <td>0.835581</td>\n",
       "      <td>0.734471</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.86</td>\n",
       "      <td>0.818604</td>\n",
       "      <td>0.719150</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>102</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.807968</td>\n",
       "      <td>0.704170</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>109</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.776784</td>\n",
       "      <td>0.689509</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>116</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0.763918</td>\n",
       "      <td>0.675145</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>123</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.758788</td>\n",
       "      <td>0.661063</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>130</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.751489</td>\n",
       "      <td>0.647246</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>137</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.80</td>\n",
       "      <td>0.726424</td>\n",
       "      <td>0.633682</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>144</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.79</td>\n",
       "      <td>0.693291</td>\n",
       "      <td>0.620358</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>151</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.690936</td>\n",
       "      <td>0.607263</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>158</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.77</td>\n",
       "      <td>0.670212</td>\n",
       "      <td>0.594388</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>165</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.76</td>\n",
       "      <td>0.657905</td>\n",
       "      <td>0.581723</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>172</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.646505</td>\n",
       "      <td>0.569260</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>179</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.74</td>\n",
       "      <td>0.638353</td>\n",
       "      <td>0.556991</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>186</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.73</td>\n",
       "      <td>0.613833</td>\n",
       "      <td>0.544911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>193</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.72</td>\n",
       "      <td>0.604040</td>\n",
       "      <td>0.533011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>200</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.71</td>\n",
       "      <td>0.596063</td>\n",
       "      <td>0.521287</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>207</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.592745</td>\n",
       "      <td>0.509733</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>214</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.69</td>\n",
       "      <td>0.575748</td>\n",
       "      <td>0.498345</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>221</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.68</td>\n",
       "      <td>0.570665</td>\n",
       "      <td>0.487116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>228</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.559807</td>\n",
       "      <td>0.476043</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>235</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.556960</td>\n",
       "      <td>0.465122</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>242</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.551280</td>\n",
       "      <td>0.454350</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>249</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.536712</td>\n",
       "      <td>0.443721</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.63</td>\n",
       "      <td>0.534651</td>\n",
       "      <td>0.433234</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>263</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.62</td>\n",
       "      <td>0.529356</td>\n",
       "      <td>0.422885</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>270</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.516607</td>\n",
       "      <td>0.412670</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>277</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.502667</td>\n",
       "      <td>0.402588</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>284</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.479192</td>\n",
       "      <td>0.392636</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>291</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.58</td>\n",
       "      <td>0.469204</td>\n",
       "      <td>0.382811</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>298</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.57</td>\n",
       "      <td>0.461991</td>\n",
       "      <td>0.373111</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>305</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.56</td>\n",
       "      <td>0.452422</td>\n",
       "      <td>0.363533</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>312</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.55</td>\n",
       "      <td>0.445908</td>\n",
       "      <td>0.354076</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>319</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.54</td>\n",
       "      <td>0.441120</td>\n",
       "      <td>0.344738</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>326</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.53</td>\n",
       "      <td>0.417792</td>\n",
       "      <td>0.335517</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>333</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.52</td>\n",
       "      <td>0.405146</td>\n",
       "      <td>0.326411</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>340</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.51</td>\n",
       "      <td>0.372314</td>\n",
       "      <td>0.317418</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>347</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.364018</td>\n",
       "      <td>0.308538</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     sigma     r  coverage_guarantee  rcp1plus      rcp1\n",
       "4      0.5  0.25                0.99  0.964948  0.966101\n",
       "11     0.5  0.25                0.98  0.942778  0.939878\n",
       "18     0.5  0.25                0.97  0.929247  0.916329\n",
       "25     0.5  0.25                0.96  0.926824  0.894476\n",
       "32     0.5  0.25                0.95  0.920444  0.873865\n",
       "39     0.5  0.25                0.94  0.911693  0.854236\n",
       "46     0.5  0.25                0.93  0.896843  0.835416\n",
       "53     0.5  0.25                0.92  0.886030  0.817286\n",
       "60     0.5  0.25                0.91  0.860473  0.799757\n",
       "67     0.5  0.25                0.90  0.854623  0.782761\n",
       "74     0.5  0.25                0.89  0.851628  0.766242\n",
       "81     0.5  0.25                0.88  0.839810  0.750158\n",
       "88     0.5  0.25                0.87  0.835581  0.734471\n",
       "95     0.5  0.25                0.86  0.818604  0.719150\n",
       "102    0.5  0.25                0.85  0.807968  0.704170\n",
       "109    0.5  0.25                0.84  0.776784  0.689509\n",
       "116    0.5  0.25                0.83  0.763918  0.675145\n",
       "123    0.5  0.25                0.82  0.758788  0.661063\n",
       "130    0.5  0.25                0.81  0.751489  0.647246\n",
       "137    0.5  0.25                0.80  0.726424  0.633682\n",
       "144    0.5  0.25                0.79  0.693291  0.620358\n",
       "151    0.5  0.25                0.78  0.690936  0.607263\n",
       "158    0.5  0.25                0.77  0.670212  0.594388\n",
       "165    0.5  0.25                0.76  0.657905  0.581723\n",
       "172    0.5  0.25                0.75  0.646505  0.569260\n",
       "179    0.5  0.25                0.74  0.638353  0.556991\n",
       "186    0.5  0.25                0.73  0.613833  0.544911\n",
       "193    0.5  0.25                0.72  0.604040  0.533011\n",
       "200    0.5  0.25                0.71  0.596063  0.521287\n",
       "207    0.5  0.25                0.70  0.592745  0.509733\n",
       "214    0.5  0.25                0.69  0.575748  0.498345\n",
       "221    0.5  0.25                0.68  0.570665  0.487116\n",
       "228    0.5  0.25                0.67  0.559807  0.476043\n",
       "235    0.5  0.25                0.66  0.556960  0.465122\n",
       "242    0.5  0.25                0.65  0.551280  0.454350\n",
       "249    0.5  0.25                0.64  0.536712  0.443721\n",
       "256    0.5  0.25                0.63  0.534651  0.433234\n",
       "263    0.5  0.25                0.62  0.529356  0.422885\n",
       "270    0.5  0.25                0.61  0.516607  0.412670\n",
       "277    0.5  0.25                0.60  0.502667  0.402588\n",
       "284    0.5  0.25                0.59  0.479192  0.392636\n",
       "291    0.5  0.25                0.58  0.469204  0.382811\n",
       "298    0.5  0.25                0.57  0.461991  0.373111\n",
       "305    0.5  0.25                0.56  0.452422  0.363533\n",
       "312    0.5  0.25                0.55  0.445908  0.354076\n",
       "319    0.5  0.25                0.54  0.441120  0.344738\n",
       "326    0.5  0.25                0.53  0.417792  0.335517\n",
       "333    0.5  0.25                0.52  0.405146  0.326411\n",
       "340    0.5  0.25                0.51  0.372314  0.317418\n",
       "347    0.5  0.25                0.50  0.364018  0.308538"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.loc[df['r'] == 0.25]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "PosixPath('../../results/cifar10')"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output_dir"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "result = []\n",
    "\n",
    "# for r in r_range:\n",
    "#     for coverage_guarantee in coverage_range:\n",
    "r = 0.25\n",
    "coverage_guarantee = 0.9\n",
    "print(f\"running for r={r} and coverage={coverage_guarantee}\")\n",
    "\n",
    "cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "n_dcal = cal_mask.sum().item()\n",
    "cp_methods = {\n",
    "    \"RCP1\": RCP1(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, nominal_coverage=coverage_guarantee, r=r),\n",
    "    \"RCP1Plus\": RCP1Plus(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, nominal_coverage=coverage_guarantee, r=r),\n",
    "}\n",
    "\n",
    "for method_name, method in cp_methods.items():\n",
    "    print(f\"Pre-computing {method_name} for r={r} and coverage={coverage_guarantee}\")\n",
    "    method.pre_compute(smooth_scores, smooth_prediction.y_true)\n",
    "\n",
    "print(f\"Running the experiment for r={r} and coverage={coverage_guarantee}\")\n",
    "for iteration in tqdm(range(n_iterations)):\n",
    "    cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "    eval_mask = ~cal_mask\n",
    "\n",
    "    for method_name, method in cp_methods.items():\n",
    "        exact_guarantee = coverage_guarantee\n",
    "        if isinstance(method, RCP1Plus):\n",
    "            threshold, exact_guarantee = method.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask], return_guarantee=True)    \n",
    "        else:\n",
    "            threshold = method.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask])\n",
    "        pred_set = method.predict_from_scores(smooth_scores[eval_mask], return_scores=False)\n",
    "        covered = (pred_set)[torch.arange(pred_set.shape[0]), smooth_prediction.y_true[eval_mask]]\n",
    "        set_size = pred_set.sum(dim=1)\n",
    "\n",
    "        empirical_coverage = covered.float().mean().item()\n",
    "        avg_set_size = set_size.float().mean().item()\n",
    "        result.append({\n",
    "            \"method\": method_name,\n",
    "            \"empirical_coverage\": empirical_coverage,\n",
    "            \"avg_set_size\": avg_set_size,\n",
    "            \"r\": r,\n",
    "            \"coverage_guarantee\": coverage_guarantee,\n",
    "            \"exact_guarantee\": exact_guarantee,\n",
    "            \"threshold\": threshold,\n",
    "            \"internal_coverage_level\": method.internal_cp.coverage_guarantee,\n",
    "            \"below_1\": (set_size <= 1).float().mean().item(),\n",
    "            \"below_3\": (set_size <= 3).float().mean().item(),\n",
    "            \"below_5\": (set_size <= 5).float().mean().item(),\n",
    "            \"below_1_coverage\": covered[set_size <= 1].float().mean().item(),\n",
    "            \"below_3_coverage\": covered[set_size <= 3].float().mean().item(),\n",
    "            \"below_5_coverage\": covered[set_size <= 5].float().mean().item(),\n",
    "            \"n_samples\": n_trial_samples,\n",
    "        })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>exact_guarantee</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>r</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.85</th>\n",
       "      <th rowspan=\"4\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.868509</td>\n",
       "      <td>1.594485</td>\n",
       "      <td>0.850000</td>\n",
       "      <td>7.312085e-02</td>\n",
       "      <td>0.860000</td>\n",
       "      <td>0.595591</td>\n",
       "      <td>0.962842</td>\n",
       "      <td>0.999507</td>\n",
       "      <td>0.893709</td>\n",
       "      <td>0.869990</td>\n",
       "      <td>0.868495</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>0.872793</td>\n",
       "      <td>1.611838</td>\n",
       "      <td>0.850000</td>\n",
       "      <td>1.207289e-01</td>\n",
       "      <td>0.860000</td>\n",
       "      <td>0.577023</td>\n",
       "      <td>0.963818</td>\n",
       "      <td>0.999604</td>\n",
       "      <td>0.896891</td>\n",
       "      <td>0.874856</td>\n",
       "      <td>0.872757</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.872571</td>\n",
       "      <td>1.650537</td>\n",
       "      <td>0.850000</td>\n",
       "      <td>9.928653e-02</td>\n",
       "      <td>0.868593</td>\n",
       "      <td>0.569930</td>\n",
       "      <td>0.954957</td>\n",
       "      <td>0.999409</td>\n",
       "      <td>0.896110</td>\n",
       "      <td>0.874976</td>\n",
       "      <td>0.872534</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.875488</td>\n",
       "      <td>1.666795</td>\n",
       "      <td>0.854753</td>\n",
       "      <td>9.344659e-02</td>\n",
       "      <td>0.850000</td>\n",
       "      <td>0.561567</td>\n",
       "      <td>0.953579</td>\n",
       "      <td>0.999539</td>\n",
       "      <td>0.899147</td>\n",
       "      <td>0.878136</td>\n",
       "      <td>0.875449</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.872213</td>\n",
       "      <td>1.621893</td>\n",
       "      <td>0.850000</td>\n",
       "      <td>7.302781e-02</td>\n",
       "      <td>0.860000</td>\n",
       "      <td>0.584843</td>\n",
       "      <td>0.957489</td>\n",
       "      <td>0.999355</td>\n",
       "      <td>0.896836</td>\n",
       "      <td>0.873937</td>\n",
       "      <td>0.872176</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.95</th>\n",
       "      <th>0.37</th>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.999718</td>\n",
       "      <td>9.993178</td>\n",
       "      <td>0.482102</td>\n",
       "      <td>1.339420e-13</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000315</td>\n",
       "      <td>0.000792</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.103448</td>\n",
       "      <td>0.698958</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>7.808844e-03</td>\n",
       "      <td>0.960000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>5.511662e-05</td>\n",
       "      <td>0.960000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>-1.000000e+03</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.999740</td>\n",
       "      <td>9.993395</td>\n",
       "      <td>0.125637</td>\n",
       "      <td>9.359909e-14</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000293</td>\n",
       "      <td>0.000732</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.111111</td>\n",
       "      <td>0.712500</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>96 rows × 12 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                  empirical_coverage  avg_set_size  \\\n",
       "coverage_guarantee r    method                                       \n",
       "0.85               0.01 BinCP               0.868509      1.594485   \n",
       "                        CAS                 0.872793      1.611838   \n",
       "                        RCP1                0.872571      1.650537   \n",
       "                        RCP1Plus            0.875488      1.666795   \n",
       "                   0.02 BinCP               0.872213      1.621893   \n",
       "...                                              ...           ...   \n",
       "0.95               0.37 RCP1Plus            0.999718      9.993178   \n",
       "                   0.50 BinCP               1.000000     10.000000   \n",
       "                        CAS                 1.000000     10.000000   \n",
       "                        RCP1                1.000000     10.000000   \n",
       "                        RCP1Plus            0.999740      9.993395   \n",
       "\n",
       "                                  exact_guarantee     threshold  \\\n",
       "coverage_guarantee r    method                                    \n",
       "0.85               0.01 BinCP            0.850000  7.312085e-02   \n",
       "                        CAS              0.850000  1.207289e-01   \n",
       "                        RCP1             0.850000  9.928653e-02   \n",
       "                        RCP1Plus         0.854753  9.344659e-02   \n",
       "                   0.02 BinCP            0.850000  7.302781e-02   \n",
       "...                                           ...           ...   \n",
       "0.95               0.37 RCP1Plus         0.482102  1.339420e-13   \n",
       "                   0.50 BinCP            0.950000  7.808844e-03   \n",
       "                        CAS              0.950000  5.511662e-05   \n",
       "                        RCP1             0.950000 -1.000000e+03   \n",
       "                        RCP1Plus         0.125637  9.359909e-14   \n",
       "\n",
       "                                  internal_coverage_level   below_1   below_3  \\\n",
       "coverage_guarantee r    method                                                  \n",
       "0.85               0.01 BinCP                    0.860000  0.595591  0.962842   \n",
       "                        CAS                      0.860000  0.577023  0.963818   \n",
       "                        RCP1                     0.868593  0.569930  0.954957   \n",
       "                        RCP1Plus                 0.850000  0.561567  0.953579   \n",
       "                   0.02 BinCP                    0.860000  0.584843  0.957489   \n",
       "...                                                   ...       ...       ...   \n",
       "0.95               0.37 RCP1Plus                 0.950000  0.000000  0.000315   \n",
       "                   0.50 BinCP                    0.960000  0.000000  0.000000   \n",
       "                        CAS                      0.960000  0.000000  0.000000   \n",
       "                        RCP1                     1.000000  0.000000  0.000000   \n",
       "                        RCP1Plus                 0.950000  0.000000  0.000293   \n",
       "\n",
       "                                   below_5  below_1_coverage  \\\n",
       "coverage_guarantee r    method                                 \n",
       "0.85               0.01 BinCP     0.999507          0.893709   \n",
       "                        CAS       0.999604          0.896891   \n",
       "                        RCP1      0.999409          0.896110   \n",
       "                        RCP1Plus  0.999539          0.899147   \n",
       "                   0.02 BinCP     0.999355          0.896836   \n",
       "...                                    ...               ...   \n",
       "0.95               0.37 RCP1Plus  0.000792               NaN   \n",
       "                   0.50 BinCP     0.000000               NaN   \n",
       "                        CAS       0.000000               NaN   \n",
       "                        RCP1      0.000000               NaN   \n",
       "                        RCP1Plus  0.000732               NaN   \n",
       "\n",
       "                                  below_3_coverage  below_5_coverage  \\\n",
       "coverage_guarantee r    method                                         \n",
       "0.85               0.01 BinCP             0.869990          0.868495   \n",
       "                        CAS               0.874856          0.872757   \n",
       "                        RCP1              0.874976          0.872534   \n",
       "                        RCP1Plus          0.878136          0.875449   \n",
       "                   0.02 BinCP             0.873937          0.872176   \n",
       "...                                            ...               ...   \n",
       "0.95               0.37 RCP1Plus          0.103448          0.698958   \n",
       "                   0.50 BinCP                  NaN               NaN   \n",
       "                        CAS                    NaN               NaN   \n",
       "                        RCP1                   NaN               NaN   \n",
       "                        RCP1Plus          0.111111          0.712500   \n",
       "\n",
       "                                  n_samples  \n",
       "coverage_guarantee r    method               \n",
       "0.85               0.01 BinCP       10000.0  \n",
       "                        CAS         10000.0  \n",
       "                        RCP1        10000.0  \n",
       "                        RCP1Plus    10000.0  \n",
       "                   0.02 BinCP       10000.0  \n",
       "...                                     ...  \n",
       "0.95               0.37 RCP1Plus    10000.0  \n",
       "                   0.50 BinCP       10000.0  \n",
       "                        CAS         10000.0  \n",
       "                        RCP1        10000.0  \n",
       "                        RCP1Plus    10000.0  \n",
       "\n",
       "[96 rows x 12 columns]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = pd.DataFrame(result)\n",
    "result.to_csv(output_dir/f\"compare_robustcp_methods_{dataset_name}_sigma{model_sigma}_smooth{smoothing_sigma}_n{n_datapoints}_score{score_method}_calib{calibration_budget}_iters{n_iterations}.csv\", index=False)\n",
    "result.groupby([\"coverage_guarantee\", \"r\", \"method\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>exact_guarantee</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>r</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"16\" valign=\"top\">0.9</th>\n",
       "      <th rowspan=\"4\" valign=\"top\">0.00</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.903644</td>\n",
       "      <td>1.887099</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.039183</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.501952</td>\n",
       "      <td>0.896996</td>\n",
       "      <td>0.995174</td>\n",
       "      <td>0.925639</td>\n",
       "      <td>0.905793</td>\n",
       "      <td>0.903572</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>0.907473</td>\n",
       "      <td>1.901958</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.073572</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.482722</td>\n",
       "      <td>0.899620</td>\n",
       "      <td>0.995965</td>\n",
       "      <td>0.933160</td>\n",
       "      <td>0.911212</td>\n",
       "      <td>0.907350</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.900271</td>\n",
       "      <td>1.891486</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.062377</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.494723</td>\n",
       "      <td>0.900531</td>\n",
       "      <td>0.995786</td>\n",
       "      <td>0.923522</td>\n",
       "      <td>0.904679</td>\n",
       "      <td>0.900216</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.918910</td>\n",
       "      <td>2.091464</td>\n",
       "      <td>0.905053</td>\n",
       "      <td>0.042995</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.445461</td>\n",
       "      <td>0.849485</td>\n",
       "      <td>0.988514</td>\n",
       "      <td>0.938682</td>\n",
       "      <td>0.923768</td>\n",
       "      <td>0.918943</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.922332</td>\n",
       "      <td>2.080938</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.037341</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.450239</td>\n",
       "      <td>0.848736</td>\n",
       "      <td>0.987695</td>\n",
       "      <td>0.940229</td>\n",
       "      <td>0.924940</td>\n",
       "      <td>0.922428</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>0.929376</td>\n",
       "      <td>2.134029</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.050516</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.427397</td>\n",
       "      <td>0.838254</td>\n",
       "      <td>0.986920</td>\n",
       "      <td>0.949114</td>\n",
       "      <td>0.932965</td>\n",
       "      <td>0.929587</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.966443</td>\n",
       "      <td>2.955477</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.011297</td>\n",
       "      <td>0.962589</td>\n",
       "      <td>0.312560</td>\n",
       "      <td>0.641030</td>\n",
       "      <td>0.890266</td>\n",
       "      <td>0.969590</td>\n",
       "      <td>0.966397</td>\n",
       "      <td>0.966405</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.938883</td>\n",
       "      <td>2.359317</td>\n",
       "      <td>0.904601</td>\n",
       "      <td>0.027301</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.396036</td>\n",
       "      <td>0.778905</td>\n",
       "      <td>0.967983</td>\n",
       "      <td>0.951267</td>\n",
       "      <td>0.942240</td>\n",
       "      <td>0.939141</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.936600</td>\n",
       "      <td>2.237229</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.038132</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.413579</td>\n",
       "      <td>0.807598</td>\n",
       "      <td>0.979284</td>\n",
       "      <td>0.951448</td>\n",
       "      <td>0.939120</td>\n",
       "      <td>0.936865</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>0.943774</td>\n",
       "      <td>2.337847</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.037082</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.389593</td>\n",
       "      <td>0.783547</td>\n",
       "      <td>0.972283</td>\n",
       "      <td>0.957083</td>\n",
       "      <td>0.946590</td>\n",
       "      <td>0.944219</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.989403</td>\n",
       "      <td>4.475439</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.002232</td>\n",
       "      <td>0.988742</td>\n",
       "      <td>0.178525</td>\n",
       "      <td>0.416741</td>\n",
       "      <td>0.636806</td>\n",
       "      <td>0.981990</td>\n",
       "      <td>0.986032</td>\n",
       "      <td>0.987729</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.959897</td>\n",
       "      <td>2.760136</td>\n",
       "      <td>0.904173</td>\n",
       "      <td>0.014730</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.336773</td>\n",
       "      <td>0.681312</td>\n",
       "      <td>0.919826</td>\n",
       "      <td>0.965132</td>\n",
       "      <td>0.960092</td>\n",
       "      <td>0.959997</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">0.18</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.949931</td>\n",
       "      <td>2.425107</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.037454</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.373799</td>\n",
       "      <td>0.759595</td>\n",
       "      <td>0.965868</td>\n",
       "      <td>0.960495</td>\n",
       "      <td>0.952105</td>\n",
       "      <td>0.950376</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>0.958575</td>\n",
       "      <td>2.639603</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.024001</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.340298</td>\n",
       "      <td>0.706450</td>\n",
       "      <td>0.941830</td>\n",
       "      <td>0.966081</td>\n",
       "      <td>0.960487</td>\n",
       "      <td>0.959238</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.997295</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.989320</td>\n",
       "      <td>4.144362</td>\n",
       "      <td>0.904428</td>\n",
       "      <td>0.002114</td>\n",
       "      <td>0.900000</td>\n",
       "      <td>0.193844</td>\n",
       "      <td>0.445161</td>\n",
       "      <td>0.682290</td>\n",
       "      <td>0.983635</td>\n",
       "      <td>0.986183</td>\n",
       "      <td>0.987791</td>\n",
       "      <td>10000.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                  empirical_coverage  avg_set_size  \\\n",
       "coverage_guarantee r    method                                       \n",
       "0.9                0.00 BinCP               0.903644      1.887099   \n",
       "                        CAS                 0.907473      1.901958   \n",
       "                        RCP1                0.900271      1.891486   \n",
       "                        RCP1Plus            0.918910      2.091464   \n",
       "                   0.06 BinCP               0.922332      2.080938   \n",
       "                        CAS                 0.929376      2.134029   \n",
       "                        RCP1                0.966443      2.955477   \n",
       "                        RCP1Plus            0.938883      2.359317   \n",
       "                   0.12 BinCP               0.936600      2.237229   \n",
       "                        CAS                 0.943774      2.337847   \n",
       "                        RCP1                0.989403      4.475439   \n",
       "                        RCP1Plus            0.959897      2.760136   \n",
       "                   0.18 BinCP               0.949931      2.425107   \n",
       "                        CAS                 0.958575      2.639603   \n",
       "                        RCP1                1.000000     10.000000   \n",
       "                        RCP1Plus            0.989320      4.144362   \n",
       "\n",
       "                                  exact_guarantee    threshold  \\\n",
       "coverage_guarantee r    method                                   \n",
       "0.9                0.00 BinCP            0.900000     0.039183   \n",
       "                        CAS              0.900000     0.073572   \n",
       "                        RCP1             0.900000     0.062377   \n",
       "                        RCP1Plus         0.905053     0.042995   \n",
       "                   0.06 BinCP            0.900000     0.037341   \n",
       "                        CAS              0.900000     0.050516   \n",
       "                        RCP1             0.900000     0.011297   \n",
       "                        RCP1Plus         0.904601     0.027301   \n",
       "                   0.12 BinCP            0.900000     0.038132   \n",
       "                        CAS              0.900000     0.037082   \n",
       "                        RCP1             0.900000     0.002232   \n",
       "                        RCP1Plus         0.904173     0.014730   \n",
       "                   0.18 BinCP            0.900000     0.037454   \n",
       "                        CAS              0.900000     0.024001   \n",
       "                        RCP1             0.900000 -1000.000000   \n",
       "                        RCP1Plus         0.904428     0.002114   \n",
       "\n",
       "                                  internal_coverage_level   below_1   below_3  \\\n",
       "coverage_guarantee r    method                                                  \n",
       "0.9                0.00 BinCP                    0.901000  0.501952  0.896996   \n",
       "                        CAS                      0.901000  0.482722  0.899620   \n",
       "                        RCP1                     0.900000  0.494723  0.900531   \n",
       "                        RCP1Plus                 0.900000  0.445461  0.849485   \n",
       "                   0.06 BinCP                    0.901000  0.450239  0.848736   \n",
       "                        CAS                      0.901000  0.427397  0.838254   \n",
       "                        RCP1                     0.962589  0.312560  0.641030   \n",
       "                        RCP1Plus                 0.900000  0.396036  0.778905   \n",
       "                   0.12 BinCP                    0.901000  0.413579  0.807598   \n",
       "                        CAS                      0.901000  0.389593  0.783547   \n",
       "                        RCP1                     0.988742  0.178525  0.416741   \n",
       "                        RCP1Plus                 0.900000  0.336773  0.681312   \n",
       "                   0.18 BinCP                    0.901000  0.373799  0.759595   \n",
       "                        CAS                      0.901000  0.340298  0.706450   \n",
       "                        RCP1                     0.997295  0.000000  0.000000   \n",
       "                        RCP1Plus                 0.900000  0.193844  0.445161   \n",
       "\n",
       "                                   below_5  below_1_coverage  \\\n",
       "coverage_guarantee r    method                                 \n",
       "0.9                0.00 BinCP     0.995174          0.925639   \n",
       "                        CAS       0.995965          0.933160   \n",
       "                        RCP1      0.995786          0.923522   \n",
       "                        RCP1Plus  0.988514          0.938682   \n",
       "                   0.06 BinCP     0.987695          0.940229   \n",
       "                        CAS       0.986920          0.949114   \n",
       "                        RCP1      0.890266          0.969590   \n",
       "                        RCP1Plus  0.967983          0.951267   \n",
       "                   0.12 BinCP     0.979284          0.951448   \n",
       "                        CAS       0.972283          0.957083   \n",
       "                        RCP1      0.636806          0.981990   \n",
       "                        RCP1Plus  0.919826          0.965132   \n",
       "                   0.18 BinCP     0.965868          0.960495   \n",
       "                        CAS       0.941830          0.966081   \n",
       "                        RCP1      0.000000               NaN   \n",
       "                        RCP1Plus  0.682290          0.983635   \n",
       "\n",
       "                                  below_3_coverage  below_5_coverage  \\\n",
       "coverage_guarantee r    method                                         \n",
       "0.9                0.00 BinCP             0.905793          0.903572   \n",
       "                        CAS               0.911212          0.907350   \n",
       "                        RCP1              0.904679          0.900216   \n",
       "                        RCP1Plus          0.923768          0.918943   \n",
       "                   0.06 BinCP             0.924940          0.922428   \n",
       "                        CAS               0.932965          0.929587   \n",
       "                        RCP1              0.966397          0.966405   \n",
       "                        RCP1Plus          0.942240          0.939141   \n",
       "                   0.12 BinCP             0.939120          0.936865   \n",
       "                        CAS               0.946590          0.944219   \n",
       "                        RCP1              0.986032          0.987729   \n",
       "                        RCP1Plus          0.960092          0.959997   \n",
       "                   0.18 BinCP             0.952105          0.950376   \n",
       "                        CAS               0.960487          0.959238   \n",
       "                        RCP1                   NaN               NaN   \n",
       "                        RCP1Plus          0.986183          0.987791   \n",
       "\n",
       "                                  n_samples  \n",
       "coverage_guarantee r    method               \n",
       "0.9                0.00 BinCP       10000.0  \n",
       "                        CAS         10000.0  \n",
       "                        RCP1        10000.0  \n",
       "                        RCP1Plus    10000.0  \n",
       "                   0.06 BinCP       10000.0  \n",
       "                        CAS         10000.0  \n",
       "                        RCP1        10000.0  \n",
       "                        RCP1Plus    10000.0  \n",
       "                   0.12 BinCP       10000.0  \n",
       "                        CAS         10000.0  \n",
       "                        RCP1        10000.0  \n",
       "                        RCP1Plus    10000.0  \n",
       "                   0.18 BinCP       10000.0  \n",
       "                        CAS         10000.0  \n",
       "                        RCP1        10000.0  \n",
       "                        RCP1Plus    10000.0  "
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = pd.DataFrame(result)\n",
    "result.loc[result[\"coverage_guarantee\"] == 0.9].groupby([\"coverage_guarantee\", \"r\", \"method\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "r = 0.12\n",
    "coverage_range = torch.linspace(0.8, 0.99, 0.01)\n",
    "\n",
    "RCP1_guarantee = norm.cdf(norm.ppf(coverage_range.cpu(), scale=smoothing_sigma) - r, scale=smoothing_sigma)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 390,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(0.3384704168206753),\n",
       " np.float64(0.04917930443531591),\n",
       " np.float64(0.21133957881583493))"
      ]
     },
     "execution_count": 390,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certified_values, certificate_function(probs.mean()), certificate_function(torch.tensor(0.9))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 350,
   "metadata": {},
   "outputs": [],
   "source": [
    "normal_threshold = robust_plus.internal_cp.calibrate_from_scores(smooth_scores[:, :, 0][cal_mask], torch.nn.functional.one_hot(smooth_prediction.y_true[cal_mask], 10).bool())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 351,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0942152813076973"
      ]
     },
     "execution_count": 351,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "normal_threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 352,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.610856275665937)"
      ]
     },
     "execution_count": 352,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certificate_function(torch.tensor(coverage_guarantee))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 353,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(0.8711, device='cuda:0'),\n",
       " np.float64(0.5523762571854682),\n",
       " np.float64(0.8256851158024531))"
      ]
     },
     "execution_count": 353,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pseudoprobs = (smooth_scores >= normal_threshold)[torch.arange(smooth_scores.shape[0]), smooth_prediction.y_true, :].float().mean(-1)\n",
    "\n",
    "pseudoprobs.mean(), certificate_function(pseudoprobs.mean()), certificate_function(pseudoprobs).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 354,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.06140857934951782"
      ]
     },
     "execution_count": 354,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "self_.conformal_threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 355,
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_results = smooth_scores >= self_.conformal_threshold\n",
    "rcp1plus_results = []\n",
    "for i in range(eval_results.shape[-1]):\n",
    "    pred_set = eval_results[:, :, i]\n",
    "    covered = (pred_set)[torch.arange(pred_set.shape[0]), smooth_prediction.y_true]\n",
    "    set_size = pred_set.sum(dim=1)\n",
    "    empirical_coverage = covered.float().mean().item()\n",
    "    avg_set_size = set_size.float().mean().item()\n",
    "    # print(f\"Iteration {i}: empirical_coverage={empirical_coverage}, avg_set_size={avg_set_size}\")\n",
    "    # result.append({\n",
    "    #         \"method\": method_name,\n",
    "    #         \"empirical_coverage\": empirical_coverage,\n",
    "    #         \"avg_set_size\": avg_set_size,\n",
    "    #         \"r\": r,\n",
    "    #         \"coverage_guarantee\": coverage_guarantee,\n",
    "    #         \"threshold\": threshold,\n",
    "    #         \"internal_coverage_level\": method.internal_cp.coverage_guarantee,\n",
    "    #         \"below_1\": (set_size <= 1).float().mean().item(),\n",
    "    #         \"below_3\": (set_size <= 3).float().mean().item(),\n",
    "    #         \"below_5\": (set_size <= 5).float().mean().item(),\n",
    "    #         \"below_1_coverage\": covered[set_size <= 1].float().mean().item(),\n",
    "    #         \"below_3_coverage\": covered[set_size <= 3].float().mean().item(),\n",
    "    #         \"below_5_coverage\": covered[set_size <= 5].float().mean().item(),\n",
    "    #         \"n_samples\": n_trial_samples,\n",
    "    #     })\n",
    "    rcp1plus_results.append({\n",
    "        \"method\": \"RCP1Plus\",\n",
    "        \"empirical_coverage\": empirical_coverage,\n",
    "        \"avg_set_size\": avg_set_size,\n",
    "        \"r\": r,\n",
    "        \"coverage_guarantee\": coverage_guarantee,\n",
    "        \"threshold\": self_.conformal_threshold,\n",
    "        \"internal_coverage_level\": self_.internal_cp.coverage_guarantee,\n",
    "        \"below_1\": (set_size <= 1).float().mean().item(),\n",
    "        \"below_3\": (set_size <= 3).float().mean().item(),\n",
    "        \"below_5\": (set_size <= 5).float().mean().item(),\n",
    "        \"below_1_coverage\": covered[set_size <= 1].float().mean().item(),\n",
    "        \"below_3_coverage\": covered[set_size <= 3].float().mean().item(),\n",
    "        \"below_5_coverage\": covered[set_size <= 5].float().mean().item(),\n",
    "        \"n_samples\": n_trial_samples,\n",
    "    })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 356,
   "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>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>r</th>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>RCP1Plus</th>\n",
       "      <td>0.898236</td>\n",
       "      <td>1.858973</td>\n",
       "      <td>0.12</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.061409</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.501021</td>\n",
       "      <td>0.907985</td>\n",
       "      <td>0.997861</td>\n",
       "      <td>0.920843</td>\n",
       "      <td>0.900513</td>\n",
       "      <td>0.898148</td>\n",
       "      <td>1100.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          empirical_coverage  avg_set_size     r  coverage_guarantee  \\\n",
       "method                                                                 \n",
       "RCP1Plus            0.898236      1.858973  0.12                 0.9   \n",
       "\n",
       "          threshold  internal_coverage_level   below_1   below_3   below_5  \\\n",
       "method                                                                       \n",
       "RCP1Plus   0.061409                      0.9  0.501021  0.907985  0.997861   \n",
       "\n",
       "          below_1_coverage  below_3_coverage  below_5_coverage  n_samples  \n",
       "method                                                                     \n",
       "RCP1Plus          0.920843          0.900513          0.898148     1100.0  "
      ]
     },
     "execution_count": 356,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rcp1plus_results = pd.DataFrame(rcp1plus_results)\n",
    "rcp1plus_results.groupby([\"method\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 346,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.9972885251045227, 5.806941509246826)"
      ]
     },
     "execution_count": 346,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "method = cp_methods[\"RCP1\"]\n",
    "threshold = method.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask])\n",
    "pred_set = method.predict_from_scores(smooth_scores[eval_mask], return_scores=False)\n",
    "covered = (pred_set)[torch.arange(pred_set.shape[0]), smooth_prediction.y_true[eval_mask]]\n",
    "set_size = pred_set.sum(dim=1)\n",
    "empirical_coverage = covered.float().mean().item()\n",
    "avg_set_size = set_size.float().mean().item()\n",
    "empirical_coverage, avg_set_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 347,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.9000, dtype=torch.float64)"
      ]
     },
     "execution_count": 347,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.tensor(certificate_function(torch.tensor(method.internal_cp.coverage_guarantee)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 252,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.0000, 0.0100, 0.0000,  ..., 0.0000, 0.9900, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0000],\n",
       "        ...,\n",
       "        [0.0000, 0.0000, 0.0300,  ..., 0.0000, 0.0000, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000,  ..., 0.0000, 1.0000, 0.0000],\n",
       "        [0.0000, 0.0000, 0.0000,  ..., 0.0000, 0.0000, 0.0000]],\n",
       "       device='cuda:0')"
      ]
     },
     "execution_count": 252,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(tuning_scores >= threshold).float().mean(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.5199811251275859)"
      ]
     },
     "execution_count": 236,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certified_values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 232,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([0.9990, 0.9990, 0.9990, 0.9982, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990,\n",
       "         0.8864, 0.8936, 0.9836, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9936,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.2527, 0.9990,\n",
       "         0.9990, 0.9990, 0.6236, 0.9927, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9855, 0.9990, 0.9990, 0.8927, 0.9990, 0.9800, 0.8927, 0.9845,\n",
       "         0.9990, 0.9718, 0.9990, 0.9909, 0.9990, 0.9990, 0.9982, 0.9990, 0.9955,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9955, 0.9882, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9427, 0.9990, 0.9990, 0.9990, 0.9818,\n",
       "         0.9990, 0.9782, 0.1918, 0.9982, 0.9364, 0.9990, 0.9990, 0.9990, 0.9800,\n",
       "         0.9990, 0.9990, 0.9990, 0.0373, 0.9990, 0.9636, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9682, 0.9227, 0.9990, 0.9990, 0.9990, 0.9990, 0.9927, 0.3045,\n",
       "         0.9745, 0.9973, 0.9982, 0.4855, 0.9964, 0.9990, 0.9945, 0.9990, 0.9990,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9973, 0.9636, 0.9655, 0.5645,\n",
       "         0.9990, 0.9990, 0.9636, 0.9990, 0.9990, 0.9982, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9791, 0.9973, 0.9655, 0.9990, 0.9990,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9945, 0.9990, 0.9600, 0.9990,\n",
       "         0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.8591, 0.9990, 0.9536,\n",
       "         0.9855, 0.9755, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9955, 0.9990, 0.9990, 0.6027, 0.9990, 0.9990, 0.9990, 0.9990,\n",
       "         0.9990, 0.9990, 0.9990, 0.9936, 0.9973, 0.9990, 0.9990, 0.9990, 0.9964,\n",
       "         0.9990, 0.9990, 0.3791, 0.9990, 0.9990, 0.9990, 0.9836, 0.9990, 0.9990,\n",
       "         0.9990, 0.9882, 0.9990, 0.9990, 0.9990, 0.9990], device='cuda:0'),\n",
       " tensor([1.0000, 1.0000, 1.0000, 0.9982, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "         0.8873, 0.8936, 0.9836, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.9936,\n",
       "         1.0000, 1.0000, 1.0000, 0.9991, 1.0000, 1.0000, 1.0000, 0.2545, 1.0000,\n",
       "         1.0000, 0.9991, 0.6245, 0.9936, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 0.9873, 1.0000, 1.0000, 0.8927, 1.0000, 0.9800, 0.8936, 0.9845,\n",
       "         1.0000, 0.9718, 1.0000, 0.9909, 1.0000, 1.0000, 0.9982, 1.0000, 0.9964,\n",
       "         1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 0.9955, 0.9882, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 1.0000, 1.0000, 1.0000, 0.9427, 1.0000, 1.0000, 1.0000, 0.9818,\n",
       "         1.0000, 0.9782, 0.1945, 0.9982, 0.9364, 1.0000, 1.0000, 1.0000, 0.9800,\n",
       "         1.0000, 1.0000, 1.0000, 0.0373, 1.0000, 0.9636, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 0.9682, 0.9245, 1.0000, 1.0000, 1.0000, 1.0000, 0.9936, 0.3045,\n",
       "         0.9745, 0.9973, 0.9982, 0.4882, 0.9964, 1.0000, 0.9945, 1.0000, 1.0000,\n",
       "         1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.9973, 0.9636, 0.9655, 0.5655,\n",
       "         1.0000, 1.0000, 0.9636, 1.0000, 1.0000, 0.9982, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 1.0000, 1.0000, 1.0000, 0.9791, 0.9973, 0.9655, 1.0000, 1.0000,\n",
       "         1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.9955, 1.0000, 0.9600, 1.0000,\n",
       "         1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 0.8591, 1.0000, 0.9536,\n",
       "         0.9855, 0.9755, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 0.9955, 1.0000, 1.0000, 0.6027, 1.0000, 1.0000, 1.0000, 1.0000,\n",
       "         1.0000, 1.0000, 1.0000, 0.9936, 0.9973, 1.0000, 1.0000, 1.0000, 0.9973,\n",
       "         1.0000, 1.0000, 0.3818, 1.0000, 1.0000, 1.0000, 0.9836, 1.0000, 1.0000,\n",
       "         0.9991, 0.9882, 1.0000, 0.9991, 1.0000, 1.0000]),\n",
       " tensor([0.9925, 0.9925, 0.9925, 0.9883, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925,\n",
       "         0.8506, 0.8577, 0.9658, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9804,\n",
       "         0.9925, 0.9925, 0.9925, 0.9902, 0.9925, 0.9925, 0.9925, 0.2103, 0.9925,\n",
       "         0.9925, 0.9902, 0.5724, 0.9804, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9709, 0.9925, 0.9925, 0.8567, 0.9925, 0.9608, 0.8577, 0.9670,\n",
       "         0.9925, 0.9501, 0.9925, 0.9762, 0.9925, 0.9925, 0.9883, 0.9925, 0.9850,\n",
       "         0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9834, 0.9722, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9925, 0.9925, 0.9925, 0.9143, 0.9925, 0.9925, 0.9925, 0.9633,\n",
       "         0.9925, 0.9584, 0.1549, 0.9883, 0.9068, 0.9925, 0.9925, 0.9925, 0.9608,\n",
       "         0.9925, 0.9925, 0.9925, 0.0204, 0.9925, 0.9397, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9455, 0.8930, 0.9925, 0.9925, 0.9925, 0.9925, 0.9804, 0.2574,\n",
       "         0.9536, 0.9866, 0.9883, 0.4354, 0.9850, 0.9925, 0.9819, 0.9925, 0.9925,\n",
       "         0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9866, 0.9397, 0.9420, 0.5125,\n",
       "         0.9925, 0.9925, 0.9397, 0.9925, 0.9925, 0.9883, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9925, 0.9925, 0.9925, 0.9596, 0.9866, 0.9420, 0.9925, 0.9925,\n",
       "         0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9834, 0.9925, 0.9352, 0.9925,\n",
       "         0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.8193, 0.9925, 0.9274,\n",
       "         0.9683, 0.9548, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9834, 0.9925, 0.9925, 0.5502, 0.9925, 0.9925, 0.9925, 0.9925,\n",
       "         0.9925, 0.9925, 0.9925, 0.9804, 0.9866, 0.9925, 0.9925, 0.9925, 0.9866,\n",
       "         0.9925, 0.9925, 0.3314, 0.9925, 0.9925, 0.9925, 0.9658, 0.9925, 0.9925,\n",
       "         0.9902, 0.9722, 0.9925, 0.9902, 0.9925, 0.9925], device='cuda:0',\n",
       "        dtype=torch.float64))"
      ]
     },
     "execution_count": 232,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tuning_probs, bins / empirical_scores.shape[-1], probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 217,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.8973593764743399)"
      ]
     },
     "execution_count": 217,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certificate_function((bins / empirical_scores.shape[-1]).mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.8428999228806788)"
      ]
     },
     "execution_count": 218,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certificate_function(probs.mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 206,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.00482177734375, 0.00482177734375)"
      ]
     },
     "execution_count": 206,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "self_.conformal_threshold, threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 207,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.999"
      ]
     },
     "execution_count": 207,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "confidence"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 208,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.9666653202417118)"
      ]
     },
     "execution_count": 208,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tune_bins = (tuning_scores > self_.conformal_threshold)[torch.arange(tuning_scores.shape[0]), y].sum(-1)\n",
    "certificate_function((tune_bins / tuning_scores.shape[-1])).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 209,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.9879, device='cuda:0')"
      ]
     },
     "execution_count": 209,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(tune_bins / tuning_scores.shape[-1]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.9776, device='cuda:0', dtype=torch.float64)"
      ]
     },
     "execution_count": 210,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "probs.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.8428999228806788)"
      ]
     },
     "execution_count": 211,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certificate_function(probs.mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(0.9589, device='cuda:0', dtype=torch.float64),\n",
       " tensor(0.8552, dtype=torch.float64))"
      ]
     },
     "execution_count": 198,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "probs.mean(), (certified_probs).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.9917, 0.9917, 0.9917, 0.9893, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917,\n",
       "        0.8006, 0.8138, 0.9517, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9709,\n",
       "        0.9917, 0.9917, 0.9917, 0.9853, 0.9917, 0.9917, 0.9917, 0.1581, 0.9917,\n",
       "        0.9917, 0.9872, 0.4694, 0.9666, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9596, 0.9917, 0.9917, 0.8017, 0.9917, 0.9556, 0.8416, 0.9439,\n",
       "        0.9917, 0.9313, 0.9917, 0.9694, 0.9917, 0.9917, 0.9801, 0.9917, 0.9709,\n",
       "        0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9723, 0.9556, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9917, 0.9917, 0.9917, 0.8596, 0.9917, 0.9917, 0.9917, 0.9439,\n",
       "        0.9917, 0.9401, 0.0741, 0.9872, 0.8653, 0.9917, 0.9917, 0.9917, 0.9388,\n",
       "        0.9917, 0.9917, 0.9917, 0.0025, 0.9917, 0.9095, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9215, 0.8450, 0.9917, 0.9917, 0.9917, 0.9917, 0.9738, 0.1883,\n",
       "        0.9313, 0.9835, 0.9872, 0.3233, 0.9801, 0.9917, 0.9835, 0.9917, 0.9917,\n",
       "        0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9835, 0.9203, 0.9179, 0.4041,\n",
       "        0.9917, 0.9917, 0.9191, 0.9917, 0.9917, 0.9853, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9893, 0.9917, 0.9917, 0.9556, 0.9785, 0.9155, 0.9917, 0.9917,\n",
       "        0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9738, 0.9917, 0.9095, 0.9917,\n",
       "        0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.7412, 0.9917, 0.8895,\n",
       "        0.9610, 0.9252, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9785, 0.9917, 0.9917, 0.4724, 0.9917, 0.9917, 0.9917, 0.9917,\n",
       "        0.9917, 0.9893, 0.9917, 0.9769, 0.9817, 0.9917, 0.9917, 0.9917, 0.9801,\n",
       "        0.9917, 0.9917, 0.2660, 0.9893, 0.9917, 0.9893, 0.9413, 0.9917, 0.9917,\n",
       "        0.9893, 0.9638, 0.9917, 0.9893, 0.9917, 0.9917], device='cuda:0',\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 152,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8309447991013177"
      ]
     },
     "execution_count": 153,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certified_coverage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.9101347137087689)"
      ]
     },
     "execution_count": 134,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "certified_values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "y_true_mask = F.one_hot(y, num_classes=calibration_scores.shape[1]).bool()\n",
    "self_.conformal_threshold = self_.internal_cp.calibrate_from_scores(calibration_scores[:, :, 1], y_true_mask)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [],
   "source": [
    "nbins = (calibration_scores >= self_.conformal_threshold).sum(-1)[torch.arange(calibration_scores.shape[0]), y]\n",
    "betas = nbins / calibration_scores.shape[-1]\n",
    "\n",
    "worst_guarantee = clopper_pearson_lower(\n",
    "    nbins.cpu().numpy(),\n",
    "    calibration_scores.shape[-1],\n",
    "    alpha=1 - confidence)\n",
    "\n",
    "worst_betas = norm.cdf(norm.ppf(worst_guarantee, scale=smoothing_sigma) - r, scale=smoothing_sigma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.6552333773303833)"
      ]
     },
     "execution_count": 107,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "norm.cdf(norm.ppf(betas.mean().cpu(), scale=smoothing_sigma) - r, scale=smoothing_sigma)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.8157721749982273)"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(worst_betas).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "norm.cdf(norm.ppf(betas.mean()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.9404, device='cuda:0')"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "betas.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[False, False, False,  ..., False, False, False],\n",
       "        [False, False, False,  ..., False, False, False],\n",
       "        [False, False, False,  ..., False, False, False],\n",
       "        ...,\n",
       "        [False, False, False,  ..., False, False, False],\n",
       "        [False, False, False,  ..., False, False,  True],\n",
       "        [False,  True, False,  ..., False, False, False]], device='cuda:0')"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_true_mask"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([204, 10])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cal_scores[:, :, 0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "threshold = self_.internal_cp.calibrate_from_scores(cal_scores[:, :, 0], torch.nn.functional.one_hot(y_cal, smooth_scores.shape[1]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([6.45351097e-02, 5.30160020e-02, 6.67797690e-02, 3.86169331e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 5.70865692e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 5.17253847e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.24813337e-02, 6.64053689e-02, 6.26678848e-02, 3.08171569e-02,\n",
       "       6.67797690e-02, 6.36011055e-02, 1.91966310e-03, 6.43482496e-02,\n",
       "       6.69670085e-02, 6.67797690e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 0.00000000e+00, 6.65925576e-02, 6.47220057e-02,\n",
       "       6.69670085e-02, 6.41614145e-02, 3.98752780e-02, 5.54188331e-02,\n",
       "       6.67797690e-02, 6.42854291e-03, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 4.80515983e-02, 6.65925576e-02,\n",
       "       6.69670085e-02, 6.67797690e-02, 4.72230852e-03, 2.12784220e-02,\n",
       "       6.56569170e-02, 4.07765757e-02, 5.08049798e-02, 2.58094465e-02,\n",
       "       6.69670085e-02, 6.02453662e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       3.99679449e-03, 6.58439853e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.67797690e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.60310881e-02, 7.17899118e-04, 6.67797690e-02, 4.75024122e-02,\n",
       "       1.86700633e-02, 6.69670085e-02, 4.97021747e-02, 6.69670085e-02,\n",
       "       3.48686680e-02, 6.49089262e-02, 6.60310881e-02, 4.43243146e-27,\n",
       "       6.58439853e-02, 6.60310881e-02, 5.32005680e-02, 6.69670085e-02,\n",
       "       6.65925576e-02, 6.69670085e-02, 1.70247098e-23, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 5.93151930e-02, 6.69670085e-02,\n",
       "       5.57891527e-02, 2.68348634e-02, 1.98032487e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 3.61876744e-52, 6.69670085e-02, 6.47220057e-02,\n",
       "       2.49596896e-02, 6.64053689e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 2.41144987e-02, 3.95153284e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 6.65925576e-02, 6.24813337e-02,\n",
       "       5.52337340e-02, 6.69670085e-02, 6.69670085e-02, 2.56391431e-02,\n",
       "       4.75024122e-02, 5.30160020e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 5.59743725e-02, 6.65925576e-02, 6.69670085e-02,\n",
       "       6.54698723e-02, 6.69670085e-02, 5.65302909e-02, 3.96952644e-02,\n",
       "       6.49089262e-02, 3.29232806e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.52828625e-02, 6.69670085e-02, 6.36011055e-02,\n",
       "       6.69670085e-02, 6.67797690e-02, 6.13627416e-02, 6.69670085e-02,\n",
       "       4.05961580e-02, 4.93350002e-02, 5.87575271e-02, 6.58439853e-02,\n",
       "       6.69670085e-02, 1.99210438e-03, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.64053689e-02, 1.22122625e-05, 6.69670085e-02, 6.54698723e-02,\n",
       "       4.27662554e-02, 6.62182142e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.43482496e-02, 5.33851748e-02, 6.45351097e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 6.69670085e-02, 6.69670085e-02,\n",
       "       6.52828625e-02, 6.69670085e-02, 6.69670085e-02, 6.67797690e-02,\n",
       "       6.62182142e-02, 6.69670085e-02, 6.43482496e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 1.22122625e-05, 6.02453662e-02, 6.65925576e-02,\n",
       "       4.98858475e-02, 6.65925576e-02, 6.69670085e-02, 6.67797690e-02,\n",
       "       9.47152945e-04, 3.79861463e-03, 6.69670085e-02, 5.39392746e-02,\n",
       "       5.98731881e-02, 6.69670085e-02, 1.26540460e-39, 6.69670085e-02,\n",
       "       4.91916587e-05, 5.69010992e-02, 6.60310881e-02, 6.69670085e-02,\n",
       "       1.16183008e-02, 3.15172190e-02, 6.69670085e-02, 7.53939665e-03,\n",
       "       6.54698723e-02, 6.60310881e-02, 8.05265251e-04, 6.67797690e-02,\n",
       "       3.39827468e-02, 1.55283964e-06, 4.45826286e-02, 6.69670085e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 1.30824109e-02, 6.67797690e-02,\n",
       "       6.69670085e-02, 6.69670085e-02, 4.27662554e-02, 6.69670085e-02])"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "threshold = 0.2\n",
    "proportion_above_threshold = (smooth_scores > threshold).sum(dim=-1) / smooth_scores.shape[-1]\n",
    "proportion_above_threshold = proportion_above_threshold[cal_mask]\n",
    "true_proportion = proportion_above_threshold[torch.arange(proportion_above_threshold.shape[0]), smooth_prediction.y_true[cal_mask]]\n",
    "clopper_pearson_lower(true_proportion.cpu(), n_samples=proportion_above_threshold.shape[-1], alpha=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 0.0013809958043854269)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.9740, 0.8500, 0.9980, 0.6920, 1.0000, 1.0000, 0.8940, 1.0000, 1.0000,\n",
       "        0.8360, 1.0000, 1.0000, 0.9520, 0.9940, 0.9540, 0.6040, 0.9980, 0.9640,\n",
       "        0.1980, 0.9720, 1.0000, 0.9980, 1.0000, 1.0000, 1.0000, 0.0000, 0.9960,\n",
       "        0.9760, 1.0000, 0.9700, 0.7060, 0.8760, 0.9980, 0.2900, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 0.7960, 0.9960, 1.0000, 0.9980, 0.2600, 0.4920, 0.9860,\n",
       "        0.7160, 0.8260, 0.5460, 1.0000, 0.9280, 1.0000, 1.0000, 0.2460, 0.9880,\n",
       "        1.0000, 1.0000, 1.0000, 0.9980, 1.0000, 1.0000, 0.9900, 0.1560, 0.9980,\n",
       "        0.7900, 0.4600, 1.0000, 0.8140, 1.0000, 0.6500, 0.9780, 0.9900, 0.0120,\n",
       "        0.9880, 0.9900, 0.8520, 1.0000, 0.9960, 1.0000, 0.0140, 1.0000, 1.0000,\n",
       "        1.0000, 0.9180, 1.0000, 0.8800, 0.5580, 0.4740, 1.0000, 1.0000, 0.0060,\n",
       "        1.0000, 0.9760, 0.5360, 0.9940, 1.0000, 1.0000, 1.0000, 1.0000, 0.5260,\n",
       "        0.7020, 1.0000, 1.0000, 0.9960, 0.9520, 0.8740, 1.0000, 1.0000, 0.5440,\n",
       "        0.7900, 0.8500, 1.0000, 1.0000, 1.0000, 0.8820, 0.9960, 1.0000, 0.9840,\n",
       "        1.0000, 0.8880, 0.7040, 0.9780, 0.6280, 1.0000, 1.0000, 1.0000, 0.9820,\n",
       "        1.0000, 0.9640, 1.0000, 0.9980, 0.9400, 1.0000, 0.7140, 0.8100, 0.9120,\n",
       "        0.9880, 1.0000, 0.2000, 1.0000, 1.0000, 0.9940, 0.0820, 1.0000, 0.9840,\n",
       "        0.7380, 0.9920, 1.0000, 1.0000, 0.9720, 0.8540, 0.9740, 1.0000, 1.0000,\n",
       "        1.0000, 1.0000, 1.0000, 0.9820, 1.0000, 1.0000, 0.9980, 0.9920, 1.0000,\n",
       "        0.9720, 1.0000, 1.0000, 0.0820, 0.9280, 0.9960, 0.8160, 0.9960, 1.0000,\n",
       "        0.9980, 0.1660, 0.2420, 1.0000, 0.8600, 0.9240, 1.0000, 0.0080, 1.0000,\n",
       "        0.0980, 0.8920, 0.9900, 1.0000, 0.3680, 0.6120, 1.0000, 0.3080, 0.9840,\n",
       "        0.9900, 0.1600, 0.9980, 0.6400, 0.0660, 0.7580, 1.0000, 1.0000, 1.0000,\n",
       "        0.3880, 0.9980, 1.0000, 1.0000, 0.7380, 1.0000], device='cuda:0')"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "true_proportion"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "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>method</th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>r</th>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>CAS</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.035245</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>BinCP</td>\n",
       "      <td>0.975054</td>\n",
       "      <td>2.582972</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.040485</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.342191</td>\n",
       "      <td>0.746204</td>\n",
       "      <td>0.935466</td>\n",
       "      <td>0.984152</td>\n",
       "      <td>0.977471</td>\n",
       "      <td>0.975652</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>RCP1</td>\n",
       "      <td>0.998915</td>\n",
       "      <td>5.617679</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.000354</td>\n",
       "      <td>0.988742</td>\n",
       "      <td>0.095987</td>\n",
       "      <td>0.292299</td>\n",
       "      <td>0.462581</td>\n",
       "      <td>0.988701</td>\n",
       "      <td>0.996289</td>\n",
       "      <td>0.997655</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>CAS</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.041229</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>BinCP</td>\n",
       "      <td>0.974512</td>\n",
       "      <td>2.517896</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.043607</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.348156</td>\n",
       "      <td>0.764100</td>\n",
       "      <td>0.947397</td>\n",
       "      <td>0.984424</td>\n",
       "      <td>0.976579</td>\n",
       "      <td>0.974242</td>\n",
       "      <td>500</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>295</th>\n",
       "      <td>BinCP</td>\n",
       "      <td>0.976139</td>\n",
       "      <td>2.473970</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.045716</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.356833</td>\n",
       "      <td>0.766811</td>\n",
       "      <td>0.951735</td>\n",
       "      <td>0.986322</td>\n",
       "      <td>0.979491</td>\n",
       "      <td>0.977208</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>296</th>\n",
       "      <td>RCP1</td>\n",
       "      <td>0.996746</td>\n",
       "      <td>5.107918</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.000673</td>\n",
       "      <td>0.988742</td>\n",
       "      <td>0.131779</td>\n",
       "      <td>0.341649</td>\n",
       "      <td>0.531996</td>\n",
       "      <td>0.991769</td>\n",
       "      <td>0.995238</td>\n",
       "      <td>0.995923</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>297</th>\n",
       "      <td>CAS</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.051700</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>298</th>\n",
       "      <td>BinCP</td>\n",
       "      <td>0.970716</td>\n",
       "      <td>2.412690</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.050795</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.369306</td>\n",
       "      <td>0.781996</td>\n",
       "      <td>0.958243</td>\n",
       "      <td>0.982379</td>\n",
       "      <td>0.975035</td>\n",
       "      <td>0.971138</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>299</th>\n",
       "      <td>RCP1</td>\n",
       "      <td>0.986985</td>\n",
       "      <td>3.547180</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.005015</td>\n",
       "      <td>0.988742</td>\n",
       "      <td>0.257050</td>\n",
       "      <td>0.548265</td>\n",
       "      <td>0.772777</td>\n",
       "      <td>0.985232</td>\n",
       "      <td>0.987141</td>\n",
       "      <td>0.985263</td>\n",
       "      <td>500</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>300 rows × 14 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    method  empirical_coverage  avg_set_size     r  coverage_guarantee  \\\n",
       "0      CAS            1.000000     10.000000  0.25                 0.9   \n",
       "1    BinCP            0.975054      2.582972  0.25                 0.9   \n",
       "2     RCP1            0.998915      5.617679  0.25                 0.9   \n",
       "3      CAS            1.000000     10.000000  0.25                 0.9   \n",
       "4    BinCP            0.974512      2.517896  0.25                 0.9   \n",
       "..     ...                 ...           ...   ...                 ...   \n",
       "295  BinCP            0.976139      2.473970  0.25                 0.9   \n",
       "296   RCP1            0.996746      5.107918  0.25                 0.9   \n",
       "297    CAS            1.000000     10.000000  0.25                 0.9   \n",
       "298  BinCP            0.970716      2.412690  0.25                 0.9   \n",
       "299   RCP1            0.986985      3.547180  0.25                 0.9   \n",
       "\n",
       "     threshold  internal_coverage_level   below_1   below_3   below_5  \\\n",
       "0     0.035245                 0.901000  0.000000  0.000000  0.000000   \n",
       "1     0.040485                 0.901000  0.342191  0.746204  0.935466   \n",
       "2     0.000354                 0.988742  0.095987  0.292299  0.462581   \n",
       "3     0.041229                 0.901000  0.000000  0.000000  0.000000   \n",
       "4     0.043607                 0.901000  0.348156  0.764100  0.947397   \n",
       "..         ...                      ...       ...       ...       ...   \n",
       "295   0.045716                 0.901000  0.356833  0.766811  0.951735   \n",
       "296   0.000673                 0.988742  0.131779  0.341649  0.531996   \n",
       "297   0.051700                 0.901000  0.000000  0.000000  0.000000   \n",
       "298   0.050795                 0.901000  0.369306  0.781996  0.958243   \n",
       "299   0.005015                 0.988742  0.257050  0.548265  0.772777   \n",
       "\n",
       "     below_1_coverage  below_3_coverage  below_5_coverage  n_samples  \n",
       "0                 NaN               NaN               NaN        500  \n",
       "1            0.984152          0.977471          0.975652        500  \n",
       "2            0.988701          0.996289          0.997655        500  \n",
       "3                 NaN               NaN               NaN        500  \n",
       "4            0.984424          0.976579          0.974242        500  \n",
       "..                ...               ...               ...        ...  \n",
       "295          0.986322          0.979491          0.977208        500  \n",
       "296          0.991769          0.995238          0.995923        500  \n",
       "297               NaN               NaN               NaN        500  \n",
       "298          0.982379          0.975035          0.971138        500  \n",
       "299          0.985232          0.987141          0.985263        500  \n",
       "\n",
       "[300 rows x 14 columns]"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = pd.DataFrame(result)\n",
    "result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "204"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_dcal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>r</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"14\" valign=\"top\">0.85</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.960557</td>\n",
       "      <td>2.197339</td>\n",
       "      <td>0.132138</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.379021</td>\n",
       "      <td>0.838271</td>\n",
       "      <td>0.986672</td>\n",
       "      <td>0.979646</td>\n",
       "      <td>0.966108</td>\n",
       "      <td>0.960508</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.907604</td>\n",
       "      <td>2.013370</td>\n",
       "      <td>0.051239</td>\n",
       "      <td>0.902886</td>\n",
       "      <td>0.465031</td>\n",
       "      <td>0.868047</td>\n",
       "      <td>0.986391</td>\n",
       "      <td>0.930319</td>\n",
       "      <td>0.911393</td>\n",
       "      <td>0.907642</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.961146</td>\n",
       "      <td>2.211438</td>\n",
       "      <td>0.129489</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.376229</td>\n",
       "      <td>0.834677</td>\n",
       "      <td>0.985755</td>\n",
       "      <td>0.980080</td>\n",
       "      <td>0.966697</td>\n",
       "      <td>0.961123</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.909870</td>\n",
       "      <td>2.030068</td>\n",
       "      <td>0.048496</td>\n",
       "      <td>0.905774</td>\n",
       "      <td>0.460073</td>\n",
       "      <td>0.864328</td>\n",
       "      <td>0.986266</td>\n",
       "      <td>0.931938</td>\n",
       "      <td>0.913811</td>\n",
       "      <td>0.909872</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.03</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.964667</td>\n",
       "      <td>2.302380</td>\n",
       "      <td>0.124594</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.359302</td>\n",
       "      <td>0.811609</td>\n",
       "      <td>0.977661</td>\n",
       "      <td>0.982851</td>\n",
       "      <td>0.970142</td>\n",
       "      <td>0.964730</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.912984</td>\n",
       "      <td>2.068604</td>\n",
       "      <td>0.046118</td>\n",
       "      <td>0.908660</td>\n",
       "      <td>0.452422</td>\n",
       "      <td>0.855292</td>\n",
       "      <td>0.982833</td>\n",
       "      <td>0.934309</td>\n",
       "      <td>0.916498</td>\n",
       "      <td>0.912944</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.962828</td>\n",
       "      <td>2.259630</td>\n",
       "      <td>0.130365</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.365469</td>\n",
       "      <td>0.822604</td>\n",
       "      <td>0.982365</td>\n",
       "      <td>0.981681</td>\n",
       "      <td>0.968574</td>\n",
       "      <td>0.962872</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.914641</td>\n",
       "      <td>2.090589</td>\n",
       "      <td>0.044706</td>\n",
       "      <td>0.917321</td>\n",
       "      <td>0.447745</td>\n",
       "      <td>0.849401</td>\n",
       "      <td>0.980865</td>\n",
       "      <td>0.935766</td>\n",
       "      <td>0.918236</td>\n",
       "      <td>0.914733</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.967979</td>\n",
       "      <td>2.387516</td>\n",
       "      <td>0.127961</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.339979</td>\n",
       "      <td>0.790328</td>\n",
       "      <td>0.971349</td>\n",
       "      <td>0.984644</td>\n",
       "      <td>0.973471</td>\n",
       "      <td>0.968314</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.938031</td>\n",
       "      <td>2.405318</td>\n",
       "      <td>0.026168</td>\n",
       "      <td>0.934642</td>\n",
       "      <td>0.386828</td>\n",
       "      <td>0.775698</td>\n",
       "      <td>0.951245</td>\n",
       "      <td>0.952279</td>\n",
       "      <td>0.939095</td>\n",
       "      <td>0.937925</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.970880</td>\n",
       "      <td>2.479219</td>\n",
       "      <td>0.133008</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.321313</td>\n",
       "      <td>0.768036</td>\n",
       "      <td>0.963953</td>\n",
       "      <td>0.987197</td>\n",
       "      <td>0.976767</td>\n",
       "      <td>0.971333</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.972865</td>\n",
       "      <td>3.305516</td>\n",
       "      <td>0.006713</td>\n",
       "      <td>0.972169</td>\n",
       "      <td>0.266698</td>\n",
       "      <td>0.593432</td>\n",
       "      <td>0.823010</td>\n",
       "      <td>0.974677</td>\n",
       "      <td>0.970882</td>\n",
       "      <td>0.971427</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.982484</td>\n",
       "      <td>2.979443</td>\n",
       "      <td>0.128194</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.241073</td>\n",
       "      <td>0.649995</td>\n",
       "      <td>0.905521</td>\n",
       "      <td>0.995108</td>\n",
       "      <td>0.987375</td>\n",
       "      <td>0.983275</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"14\" valign=\"top\">0.90</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.976188</td>\n",
       "      <td>2.654750</td>\n",
       "      <td>0.073737</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.306339</td>\n",
       "      <td>0.722516</td>\n",
       "      <td>0.939516</td>\n",
       "      <td>0.989652</td>\n",
       "      <td>0.980994</td>\n",
       "      <td>0.976761</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.903313</td>\n",
       "      <td>1.968578</td>\n",
       "      <td>0.054648</td>\n",
       "      <td>0.902886</td>\n",
       "      <td>0.474734</td>\n",
       "      <td>0.878891</td>\n",
       "      <td>0.989922</td>\n",
       "      <td>0.926867</td>\n",
       "      <td>0.907417</td>\n",
       "      <td>0.903283</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.976510</td>\n",
       "      <td>2.670698</td>\n",
       "      <td>0.072179</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.303875</td>\n",
       "      <td>0.718714</td>\n",
       "      <td>0.937417</td>\n",
       "      <td>0.989792</td>\n",
       "      <td>0.981172</td>\n",
       "      <td>0.976991</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.906370</td>\n",
       "      <td>1.998464</td>\n",
       "      <td>0.051878</td>\n",
       "      <td>0.905774</td>\n",
       "      <td>0.467839</td>\n",
       "      <td>0.871901</td>\n",
       "      <td>0.987828</td>\n",
       "      <td>0.928973</td>\n",
       "      <td>0.910230</td>\n",
       "      <td>0.906325</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.03</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.976229</td>\n",
       "      <td>2.660214</td>\n",
       "      <td>0.076940</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.303500</td>\n",
       "      <td>0.720198</td>\n",
       "      <td>0.940260</td>\n",
       "      <td>0.989662</td>\n",
       "      <td>0.980994</td>\n",
       "      <td>0.976871</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.905000</td>\n",
       "      <td>1.987182</td>\n",
       "      <td>0.052894</td>\n",
       "      <td>0.908660</td>\n",
       "      <td>0.470182</td>\n",
       "      <td>0.874557</td>\n",
       "      <td>0.988885</td>\n",
       "      <td>0.928011</td>\n",
       "      <td>0.909057</td>\n",
       "      <td>0.904977</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.977911</td>\n",
       "      <td>2.732729</td>\n",
       "      <td>0.070975</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.294167</td>\n",
       "      <td>0.703776</td>\n",
       "      <td>0.930323</td>\n",
       "      <td>0.990682</td>\n",
       "      <td>0.982533</td>\n",
       "      <td>0.978480</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.918839</td>\n",
       "      <td>2.131693</td>\n",
       "      <td>0.041027</td>\n",
       "      <td>0.917321</td>\n",
       "      <td>0.438859</td>\n",
       "      <td>0.839870</td>\n",
       "      <td>0.977958</td>\n",
       "      <td>0.938794</td>\n",
       "      <td>0.922049</td>\n",
       "      <td>0.918747</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.979661</td>\n",
       "      <td>2.799073</td>\n",
       "      <td>0.075216</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.281656</td>\n",
       "      <td>0.688641</td>\n",
       "      <td>0.923375</td>\n",
       "      <td>0.991492</td>\n",
       "      <td>0.984220</td>\n",
       "      <td>0.980191</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.935672</td>\n",
       "      <td>2.368802</td>\n",
       "      <td>0.027934</td>\n",
       "      <td>0.934642</td>\n",
       "      <td>0.393370</td>\n",
       "      <td>0.784396</td>\n",
       "      <td>0.954807</td>\n",
       "      <td>0.950757</td>\n",
       "      <td>0.937060</td>\n",
       "      <td>0.935565</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.983073</td>\n",
       "      <td>2.980688</td>\n",
       "      <td>0.073165</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.256063</td>\n",
       "      <td>0.651307</td>\n",
       "      <td>0.896870</td>\n",
       "      <td>0.994265</td>\n",
       "      <td>0.987543</td>\n",
       "      <td>0.983444</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.975859</td>\n",
       "      <td>3.424203</td>\n",
       "      <td>0.005517</td>\n",
       "      <td>0.972169</td>\n",
       "      <td>0.253292</td>\n",
       "      <td>0.572047</td>\n",
       "      <td>0.803906</td>\n",
       "      <td>0.977220</td>\n",
       "      <td>0.973584</td>\n",
       "      <td>0.974341</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.989719</td>\n",
       "      <td>3.520214</td>\n",
       "      <td>0.071110</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.189411</td>\n",
       "      <td>0.540510</td>\n",
       "      <td>0.816688</td>\n",
       "      <td>0.997136</td>\n",
       "      <td>0.992940</td>\n",
       "      <td>0.989971</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"14\" valign=\"top\">0.95</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.990714</td>\n",
       "      <td>3.627208</td>\n",
       "      <td>0.022619</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.200469</td>\n",
       "      <td>0.527891</td>\n",
       "      <td>0.785474</td>\n",
       "      <td>0.997245</td>\n",
       "      <td>0.993610</td>\n",
       "      <td>0.990809</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.907036</td>\n",
       "      <td>2.004719</td>\n",
       "      <td>0.051202</td>\n",
       "      <td>0.902886</td>\n",
       "      <td>0.466063</td>\n",
       "      <td>0.870375</td>\n",
       "      <td>0.987682</td>\n",
       "      <td>0.929761</td>\n",
       "      <td>0.911017</td>\n",
       "      <td>0.907020</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.991224</td>\n",
       "      <td>3.634641</td>\n",
       "      <td>0.021266</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.198641</td>\n",
       "      <td>0.524969</td>\n",
       "      <td>0.784323</td>\n",
       "      <td>0.997215</td>\n",
       "      <td>0.993793</td>\n",
       "      <td>0.991324</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.909786</td>\n",
       "      <td>2.027750</td>\n",
       "      <td>0.048661</td>\n",
       "      <td>0.905774</td>\n",
       "      <td>0.460823</td>\n",
       "      <td>0.864370</td>\n",
       "      <td>0.986615</td>\n",
       "      <td>0.932130</td>\n",
       "      <td>0.913953</td>\n",
       "      <td>0.909757</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.03</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.991042</td>\n",
       "      <td>3.656516</td>\n",
       "      <td>0.023195</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.196531</td>\n",
       "      <td>0.521875</td>\n",
       "      <td>0.781250</td>\n",
       "      <td>0.997342</td>\n",
       "      <td>0.993570</td>\n",
       "      <td>0.991128</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.909969</td>\n",
       "      <td>2.036245</td>\n",
       "      <td>0.048929</td>\n",
       "      <td>0.908660</td>\n",
       "      <td>0.459365</td>\n",
       "      <td>0.862984</td>\n",
       "      <td>0.985089</td>\n",
       "      <td>0.932331</td>\n",
       "      <td>0.913588</td>\n",
       "      <td>0.909946</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.990589</td>\n",
       "      <td>3.573792</td>\n",
       "      <td>0.025189</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.203094</td>\n",
       "      <td>0.534849</td>\n",
       "      <td>0.795698</td>\n",
       "      <td>0.997452</td>\n",
       "      <td>0.993361</td>\n",
       "      <td>0.990772</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.917786</td>\n",
       "      <td>2.115953</td>\n",
       "      <td>0.041894</td>\n",
       "      <td>0.917321</td>\n",
       "      <td>0.441990</td>\n",
       "      <td>0.843344</td>\n",
       "      <td>0.979563</td>\n",
       "      <td>0.938225</td>\n",
       "      <td>0.920953</td>\n",
       "      <td>0.917789</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.992302</td>\n",
       "      <td>3.806583</td>\n",
       "      <td>0.022307</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.181177</td>\n",
       "      <td>0.495260</td>\n",
       "      <td>0.757354</td>\n",
       "      <td>0.997909</td>\n",
       "      <td>0.994864</td>\n",
       "      <td>0.992483</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.933156</td>\n",
       "      <td>2.324313</td>\n",
       "      <td>0.029416</td>\n",
       "      <td>0.934642</td>\n",
       "      <td>0.400411</td>\n",
       "      <td>0.794031</td>\n",
       "      <td>0.960578</td>\n",
       "      <td>0.949502</td>\n",
       "      <td>0.934761</td>\n",
       "      <td>0.933075</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.993583</td>\n",
       "      <td>4.012052</td>\n",
       "      <td>0.021254</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.163396</td>\n",
       "      <td>0.462474</td>\n",
       "      <td>0.722823</td>\n",
       "      <td>0.998089</td>\n",
       "      <td>0.995589</td>\n",
       "      <td>0.993504</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.969677</td>\n",
       "      <td>3.192912</td>\n",
       "      <td>0.008127</td>\n",
       "      <td>0.972169</td>\n",
       "      <td>0.279870</td>\n",
       "      <td>0.614938</td>\n",
       "      <td>0.840385</td>\n",
       "      <td>0.972926</td>\n",
       "      <td>0.968223</td>\n",
       "      <td>0.968367</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.996172</td>\n",
       "      <td>4.528396</td>\n",
       "      <td>0.023129</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.124099</td>\n",
       "      <td>0.387323</td>\n",
       "      <td>0.635073</td>\n",
       "      <td>0.998910</td>\n",
       "      <td>0.997133</td>\n",
       "      <td>0.996171</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>100.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                empirical_coverage  avg_set_size    threshold  \\\n",
       "coverage_guarantee r    method                                                  \n",
       "0.85               0.01 BinCP             0.960557      2.197339     0.132138   \n",
       "                        RCP1              0.907604      2.013370     0.051239   \n",
       "                   0.02 BinCP             0.961146      2.211438     0.129489   \n",
       "                        RCP1              0.909870      2.030068     0.048496   \n",
       "                   0.03 BinCP             0.964667      2.302380     0.124594   \n",
       "                        RCP1              0.912984      2.068604     0.046118   \n",
       "                   0.06 BinCP             0.962828      2.259630     0.130365   \n",
       "                        RCP1              0.914641      2.090589     0.044706   \n",
       "                   0.12 BinCP             0.967979      2.387516     0.127961   \n",
       "                        RCP1              0.938031      2.405318     0.026168   \n",
       "                   0.25 BinCP             0.970880      2.479219     0.133008   \n",
       "                        RCP1              0.972865      3.305516     0.006713   \n",
       "                   0.50 BinCP             0.982484      2.979443     0.128194   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "0.90               0.01 BinCP             0.976188      2.654750     0.073737   \n",
       "                        RCP1              0.903313      1.968578     0.054648   \n",
       "                   0.02 BinCP             0.976510      2.670698     0.072179   \n",
       "                        RCP1              0.906370      1.998464     0.051878   \n",
       "                   0.03 BinCP             0.976229      2.660214     0.076940   \n",
       "                        RCP1              0.905000      1.987182     0.052894   \n",
       "                   0.06 BinCP             0.977911      2.732729     0.070975   \n",
       "                        RCP1              0.918839      2.131693     0.041027   \n",
       "                   0.12 BinCP             0.979661      2.799073     0.075216   \n",
       "                        RCP1              0.935672      2.368802     0.027934   \n",
       "                   0.25 BinCP             0.983073      2.980688     0.073165   \n",
       "                        RCP1              0.975859      3.424203     0.005517   \n",
       "                   0.50 BinCP             0.989719      3.520214     0.071110   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "0.95               0.01 BinCP             0.990714      3.627208     0.022619   \n",
       "                        RCP1              0.907036      2.004719     0.051202   \n",
       "                   0.02 BinCP             0.991224      3.634641     0.021266   \n",
       "                        RCP1              0.909786      2.027750     0.048661   \n",
       "                   0.03 BinCP             0.991042      3.656516     0.023195   \n",
       "                        RCP1              0.909969      2.036245     0.048929   \n",
       "                   0.06 BinCP             0.990589      3.573792     0.025189   \n",
       "                        RCP1              0.917786      2.115953     0.041894   \n",
       "                   0.12 BinCP             0.992302      3.806583     0.022307   \n",
       "                        RCP1              0.933156      2.324313     0.029416   \n",
       "                   0.25 BinCP             0.993583      4.012052     0.021254   \n",
       "                        RCP1              0.969677      3.192912     0.008127   \n",
       "                   0.50 BinCP             0.996172      4.528396     0.023129   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "\n",
       "                                internal_coverage_level   below_1   below_3  \\\n",
       "coverage_guarantee r    method                                                \n",
       "0.85               0.01 BinCP                  0.851000  0.379021  0.838271   \n",
       "                        RCP1                   0.902886  0.465031  0.868047   \n",
       "                   0.02 BinCP                  0.851000  0.376229  0.834677   \n",
       "                        RCP1                   0.905774  0.460073  0.864328   \n",
       "                   0.03 BinCP                  0.851000  0.359302  0.811609   \n",
       "                        RCP1                   0.908660  0.452422  0.855292   \n",
       "                   0.06 BinCP                  0.851000  0.365469  0.822604   \n",
       "                        RCP1                   0.917321  0.447745  0.849401   \n",
       "                   0.12 BinCP                  0.851000  0.339979  0.790328   \n",
       "                        RCP1                   0.934642  0.386828  0.775698   \n",
       "                   0.25 BinCP                  0.851000  0.321313  0.768036   \n",
       "                        RCP1                   0.972169  0.266698  0.593432   \n",
       "                   0.50 BinCP                  0.851000  0.241073  0.649995   \n",
       "                        RCP1                   0.999999  0.000000  0.000000   \n",
       "0.90               0.01 BinCP                  0.901000  0.306339  0.722516   \n",
       "                        RCP1                   0.902886  0.474734  0.878891   \n",
       "                   0.02 BinCP                  0.901000  0.303875  0.718714   \n",
       "                        RCP1                   0.905774  0.467839  0.871901   \n",
       "                   0.03 BinCP                  0.901000  0.303500  0.720198   \n",
       "                        RCP1                   0.908660  0.470182  0.874557   \n",
       "                   0.06 BinCP                  0.901000  0.294167  0.703776   \n",
       "                        RCP1                   0.917321  0.438859  0.839870   \n",
       "                   0.12 BinCP                  0.901000  0.281656  0.688641   \n",
       "                        RCP1                   0.934642  0.393370  0.784396   \n",
       "                   0.25 BinCP                  0.901000  0.256063  0.651307   \n",
       "                        RCP1                   0.972169  0.253292  0.572047   \n",
       "                   0.50 BinCP                  0.901000  0.189411  0.540510   \n",
       "                        RCP1                   0.999999  0.000000  0.000000   \n",
       "0.95               0.01 BinCP                  0.951000  0.200469  0.527891   \n",
       "                        RCP1                   0.902886  0.466063  0.870375   \n",
       "                   0.02 BinCP                  0.951000  0.198641  0.524969   \n",
       "                        RCP1                   0.905774  0.460823  0.864370   \n",
       "                   0.03 BinCP                  0.951000  0.196531  0.521875   \n",
       "                        RCP1                   0.908660  0.459365  0.862984   \n",
       "                   0.06 BinCP                  0.951000  0.203094  0.534849   \n",
       "                        RCP1                   0.917321  0.441990  0.843344   \n",
       "                   0.12 BinCP                  0.951000  0.181177  0.495260   \n",
       "                        RCP1                   0.934642  0.400411  0.794031   \n",
       "                   0.25 BinCP                  0.951000  0.163396  0.462474   \n",
       "                        RCP1                   0.972169  0.279870  0.614938   \n",
       "                   0.50 BinCP                  0.951000  0.124099  0.387323   \n",
       "                        RCP1                   0.999999  0.000000  0.000000   \n",
       "\n",
       "                                 below_5  below_1_coverage  below_3_coverage  \\\n",
       "coverage_guarantee r    method                                                 \n",
       "0.85               0.01 BinCP   0.986672          0.979646          0.966108   \n",
       "                        RCP1    0.986391          0.930319          0.911393   \n",
       "                   0.02 BinCP   0.985755          0.980080          0.966697   \n",
       "                        RCP1    0.986266          0.931938          0.913811   \n",
       "                   0.03 BinCP   0.977661          0.982851          0.970142   \n",
       "                        RCP1    0.982833          0.934309          0.916498   \n",
       "                   0.06 BinCP   0.982365          0.981681          0.968574   \n",
       "                        RCP1    0.980865          0.935766          0.918236   \n",
       "                   0.12 BinCP   0.971349          0.984644          0.973471   \n",
       "                        RCP1    0.951245          0.952279          0.939095   \n",
       "                   0.25 BinCP   0.963953          0.987197          0.976767   \n",
       "                        RCP1    0.823010          0.974677          0.970882   \n",
       "                   0.50 BinCP   0.905521          0.995108          0.987375   \n",
       "                        RCP1    0.000000          0.000000          0.000000   \n",
       "0.90               0.01 BinCP   0.939516          0.989652          0.980994   \n",
       "                        RCP1    0.989922          0.926867          0.907417   \n",
       "                   0.02 BinCP   0.937417          0.989792          0.981172   \n",
       "                        RCP1    0.987828          0.928973          0.910230   \n",
       "                   0.03 BinCP   0.940260          0.989662          0.980994   \n",
       "                        RCP1    0.988885          0.928011          0.909057   \n",
       "                   0.06 BinCP   0.930323          0.990682          0.982533   \n",
       "                        RCP1    0.977958          0.938794          0.922049   \n",
       "                   0.12 BinCP   0.923375          0.991492          0.984220   \n",
       "                        RCP1    0.954807          0.950757          0.937060   \n",
       "                   0.25 BinCP   0.896870          0.994265          0.987543   \n",
       "                        RCP1    0.803906          0.977220          0.973584   \n",
       "                   0.50 BinCP   0.816688          0.997136          0.992940   \n",
       "                        RCP1    0.000000          0.000000          0.000000   \n",
       "0.95               0.01 BinCP   0.785474          0.997245          0.993610   \n",
       "                        RCP1    0.987682          0.929761          0.911017   \n",
       "                   0.02 BinCP   0.784323          0.997215          0.993793   \n",
       "                        RCP1    0.986615          0.932130          0.913953   \n",
       "                   0.03 BinCP   0.781250          0.997342          0.993570   \n",
       "                        RCP1    0.985089          0.932331          0.913588   \n",
       "                   0.06 BinCP   0.795698          0.997452          0.993361   \n",
       "                        RCP1    0.979563          0.938225          0.920953   \n",
       "                   0.12 BinCP   0.757354          0.997909          0.994864   \n",
       "                        RCP1    0.960578          0.949502          0.934761   \n",
       "                   0.25 BinCP   0.722823          0.998089          0.995589   \n",
       "                        RCP1    0.840385          0.972926          0.968223   \n",
       "                   0.50 BinCP   0.635073          0.998910          0.997133   \n",
       "                        RCP1    0.000000          0.000000          0.000000   \n",
       "\n",
       "                                below_5_coverage  n_samples  \n",
       "coverage_guarantee r    method                               \n",
       "0.85               0.01 BinCP           0.960508      100.0  \n",
       "                        RCP1            0.907642      100.0  \n",
       "                   0.02 BinCP           0.961123      100.0  \n",
       "                        RCP1            0.909872      100.0  \n",
       "                   0.03 BinCP           0.964730      100.0  \n",
       "                        RCP1            0.912944      100.0  \n",
       "                   0.06 BinCP           0.962872      100.0  \n",
       "                        RCP1            0.914733      100.0  \n",
       "                   0.12 BinCP           0.968314      100.0  \n",
       "                        RCP1            0.937925      100.0  \n",
       "                   0.25 BinCP           0.971333      100.0  \n",
       "                        RCP1            0.971427      100.0  \n",
       "                   0.50 BinCP           0.983275      100.0  \n",
       "                        RCP1            0.000000      100.0  \n",
       "0.90               0.01 BinCP           0.976761      100.0  \n",
       "                        RCP1            0.903283      100.0  \n",
       "                   0.02 BinCP           0.976991      100.0  \n",
       "                        RCP1            0.906325      100.0  \n",
       "                   0.03 BinCP           0.976871      100.0  \n",
       "                        RCP1            0.904977      100.0  \n",
       "                   0.06 BinCP           0.978480      100.0  \n",
       "                        RCP1            0.918747      100.0  \n",
       "                   0.12 BinCP           0.980191      100.0  \n",
       "                        RCP1            0.935565      100.0  \n",
       "                   0.25 BinCP           0.983444      100.0  \n",
       "                        RCP1            0.974341      100.0  \n",
       "                   0.50 BinCP           0.989971      100.0  \n",
       "                        RCP1            0.000000      100.0  \n",
       "0.95               0.01 BinCP           0.990809      100.0  \n",
       "                        RCP1            0.907020      100.0  \n",
       "                   0.02 BinCP           0.991324      100.0  \n",
       "                        RCP1            0.909757      100.0  \n",
       "                   0.03 BinCP           0.991128      100.0  \n",
       "                        RCP1            0.909946      100.0  \n",
       "                   0.06 BinCP           0.990772      100.0  \n",
       "                        RCP1            0.917789      100.0  \n",
       "                   0.12 BinCP           0.992483      100.0  \n",
       "                        RCP1            0.933075      100.0  \n",
       "                   0.25 BinCP           0.993504      100.0  \n",
       "                        RCP1            0.968367      100.0  \n",
       "                   0.50 BinCP           0.996171      100.0  \n",
       "                        RCP1            0.000000      100.0  "
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = pd.DataFrame(result)\n",
    "result.to_csv(output_dir/f\"results_l2-gauss_{dataset_name}_{score_method}_clean_r-0.0_samples-{n_trial_samples}.csv\", index=False)\n",
    "result.groupby([\"coverage_guarantee\", \"r\", \"method\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>r</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"21\" valign=\"top\">0.9</th>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.982018</td>\n",
       "      <td>3.004753</td>\n",
       "      <td>0.048455</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.277895</td>\n",
       "      <td>0.653406</td>\n",
       "      <td>0.880447</td>\n",
       "      <td>0.986425</td>\n",
       "      <td>0.984238</td>\n",
       "      <td>0.982795</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.040294</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.937306</td>\n",
       "      <td>2.241769</td>\n",
       "      <td>0.040818</td>\n",
       "      <td>0.935939</td>\n",
       "      <td>0.434870</td>\n",
       "      <td>0.811012</td>\n",
       "      <td>0.959446</td>\n",
       "      <td>0.947720</td>\n",
       "      <td>0.939489</td>\n",
       "      <td>0.937667</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.987534</td>\n",
       "      <td>3.363360</td>\n",
       "      <td>0.051260</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.224728</td>\n",
       "      <td>0.578765</td>\n",
       "      <td>0.830742</td>\n",
       "      <td>0.987869</td>\n",
       "      <td>0.988606</td>\n",
       "      <td>0.988323</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.033337</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.959614</td>\n",
       "      <td>2.734357</td>\n",
       "      <td>0.021940</td>\n",
       "      <td>0.960927</td>\n",
       "      <td>0.358343</td>\n",
       "      <td>0.709654</td>\n",
       "      <td>0.899359</td>\n",
       "      <td>0.966554</td>\n",
       "      <td>0.961127</td>\n",
       "      <td>0.959539</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.18</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.994067</td>\n",
       "      <td>4.133172</td>\n",
       "      <td>0.047769</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.145750</td>\n",
       "      <td>0.439771</td>\n",
       "      <td>0.710066</td>\n",
       "      <td>0.992939</td>\n",
       "      <td>0.994421</td>\n",
       "      <td>0.994630</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.021985</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.988149</td>\n",
       "      <td>4.228231</td>\n",
       "      <td>0.004688</td>\n",
       "      <td>0.977334</td>\n",
       "      <td>0.208815</td>\n",
       "      <td>0.467138</td>\n",
       "      <td>0.676151</td>\n",
       "      <td>0.986530</td>\n",
       "      <td>0.988182</td>\n",
       "      <td>0.987341</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.047977</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.014438</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.988742</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.37</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.046737</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.006174</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.997124</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.046628</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.002054</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999484</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.75</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.050639</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CAS</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.000146</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999991</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>50.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                empirical_coverage  avg_set_size    threshold  \\\n",
       "coverage_guarantee r    method                                                  \n",
       "0.9                0.06 BinCP             0.982018      3.004753     0.048455   \n",
       "                        CAS               1.000000     10.000000     0.040294   \n",
       "                        RCP1              0.937306      2.241769     0.040818   \n",
       "                   0.12 BinCP             0.987534      3.363360     0.051260   \n",
       "                        CAS               1.000000     10.000000     0.033337   \n",
       "                        RCP1              0.959614      2.734357     0.021940   \n",
       "                   0.18 BinCP             0.994067      4.133172     0.047769   \n",
       "                        CAS               1.000000     10.000000     0.021985   \n",
       "                        RCP1              0.988149      4.228231     0.004688   \n",
       "                   0.25 BinCP             1.000000     10.000000     0.047977   \n",
       "                        CAS               1.000000     10.000000     0.014438   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "                   0.37 BinCP             1.000000     10.000000     0.046737   \n",
       "                        CAS               1.000000     10.000000     0.006174   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "                   0.50 BinCP             1.000000     10.000000     0.046628   \n",
       "                        CAS               1.000000     10.000000     0.002054   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "                   0.75 BinCP             1.000000     10.000000     0.050639   \n",
       "                        CAS               1.000000     10.000000     0.000146   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "\n",
       "                                internal_coverage_level   below_1   below_3  \\\n",
       "coverage_guarantee r    method                                                \n",
       "0.9                0.06 BinCP                  0.901000  0.277895  0.653406   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.935939  0.434870  0.811012   \n",
       "                   0.12 BinCP                  0.901000  0.224728  0.578765   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.960927  0.358343  0.709654   \n",
       "                   0.18 BinCP                  0.901000  0.145750  0.439771   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.977334  0.208815  0.467138   \n",
       "                   0.25 BinCP                  0.901000  0.000000  0.000000   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.988742  0.000000  0.000000   \n",
       "                   0.37 BinCP                  0.901000  0.000000  0.000000   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.997124  0.000000  0.000000   \n",
       "                   0.50 BinCP                  0.901000  0.000000  0.000000   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.999484  0.000000  0.000000   \n",
       "                   0.75 BinCP                  0.901000  0.000000  0.000000   \n",
       "                        CAS                    0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.999991  0.000000  0.000000   \n",
       "\n",
       "                                 below_5  below_1_coverage  below_3_coverage  \\\n",
       "coverage_guarantee r    method                                                 \n",
       "0.9                0.06 BinCP   0.880447          0.986425          0.984238   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.959446          0.947720          0.939489   \n",
       "                   0.12 BinCP   0.830742          0.987869          0.988606   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.899359          0.966554          0.961127   \n",
       "                   0.18 BinCP   0.710066          0.992939          0.994421   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.676151          0.986530          0.988182   \n",
       "                   0.25 BinCP   0.000000               NaN               NaN   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.000000               NaN               NaN   \n",
       "                   0.37 BinCP   0.000000               NaN               NaN   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.000000               NaN               NaN   \n",
       "                   0.50 BinCP   0.000000               NaN               NaN   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.000000               NaN               NaN   \n",
       "                   0.75 BinCP   0.000000               NaN               NaN   \n",
       "                        CAS     0.000000               NaN               NaN   \n",
       "                        RCP1    0.000000               NaN               NaN   \n",
       "\n",
       "                                below_5_coverage  n_samples  \n",
       "coverage_guarantee r    method                               \n",
       "0.9                0.06 BinCP           0.982795       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1            0.937667       50.0  \n",
       "                   0.12 BinCP           0.988323       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1            0.959539       50.0  \n",
       "                   0.18 BinCP           0.994630       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1            0.987341       50.0  \n",
       "                   0.25 BinCP                NaN       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1                 NaN       50.0  \n",
       "                   0.37 BinCP                NaN       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1                 NaN       50.0  \n",
       "                   0.50 BinCP                NaN       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1                 NaN       50.0  \n",
       "                   0.75 BinCP                NaN       50.0  \n",
       "                        CAS                  NaN       50.0  \n",
       "                        RCP1                 NaN       50.0  "
      ]
     },
     "execution_count": 202,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result.loc[result.coverage_guarantee == 0.9].groupby([\"coverage_guarantee\", \"r\", \"method\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "sns.lineplot(data=result.loc[result[\"coverage_guarantee\"] == 0.9], x=\"r\", y=\"avg_set_size\", hue=\"method\", ax=axs[0])\n",
    "sns.lineplot(data=result.loc[result[\"coverage_guarantee\"] == 0.9], x=\"r\", y=\"empirical_coverage\", hue=\"method\", ax=axs[1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "logits shape:  torch.Size([10000, 512, 10])\n",
      "scores shape:  torch.Size([10000, 10, 60])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "'../bin_cp/precomputed/cifar_uniform_100/logits.npy'"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from bin_cp.robust.noises import Gaussian, Laplace, Uniform\n",
    "\n",
    "r_range = [0.01, 0.02, 0.03, 0.06, 0.12, 0.25, 0.5]\n",
    "coverage_range = [0.85, 0.9, 0.95]\n",
    "n_iterations = 20\n",
    "n_trial_samples = 60\n",
    "calibration_budget = 0.04\n",
    "\n",
    "smoothing_sigma=1\n",
    "scheme = \"uniform-l1\"\n",
    "smoothing_sigma_map = lambda v: (f\"{v:.2f}\").replace(\".\", \"\")\n",
    "\n",
    "smooth_logits = torch.tensor(np.load(f\"../bin_cp/precomputed/cifar_{scheme.split('-')[0]}_{smoothing_sigma_map(smoothing_sigma)}/logits.npy\"))\n",
    "print(\"logits shape: \", smooth_logits.shape)\n",
    "smooth_scores = get_smooth_scores(smooth_logits, cp, mean=False)\n",
    "smooth_scores = smooth_scores[:, :, :n_trial_samples].to(device)\n",
    "print(\"scores shape: \", smooth_scores.shape)\n",
    "y_true = torch.tensor(np.load(f\"../bin_cp/precomputed/cifar_{scheme.split('-')[0]}_{smoothing_sigma_map(smoothing_sigma)}/labels.npy\")).long().to(device)\n",
    "y_true_mask = F.one_hot(y_true, num_classes=10).bool().to(device)\n",
    "f\"../bin_cp/precomputed/cifar_{scheme.split('-')[0]}_{smoothing_sigma_map(smoothing_sigma)}/logits.npy\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "result = []\n",
    "\n",
    "\n",
    "for r in r_range:\n",
    "    for coverage_guarantee in coverage_range:\n",
    "        cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "        n_dcal = cal_mask.sum().item()\n",
    "\n",
    "        p_lower = RCP1.compute_threat_p(coverage_guarantee, r, sigma=smoothing_sigma)\n",
    "        p_upper = RCP1.compute_threat_p(0.2, r, sigma=smoothing_sigma, scheme=scheme, type=\"upper\")\n",
    "        \n",
    "        print(p_lower, p_upper)\n",
    "\n",
    "        cp_methods = {\n",
    "            \"BinCP\": BinCP(smoothing_sigma=smoothing_sigma, confidence_level=confidence, n_dcal=n_dcal, n_classes=n_classes,\n",
    "                                p_base=0.6, scheme=scheme, nominal_coverage=coverage_guarantee, r=r),\n",
    "            \"RCP1\": RCP1(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, \n",
    "                                scheme=scheme, schnominal_coverage=coverage_guarantee, r=r),\n",
    "        }\n",
    "\n",
    "        for method_name, method in cp_methods.items():\n",
    "            print(f\"Pre-computing {method_name} for r={r} and coverage={coverage_guarantee}\")\n",
    "            method.pre_compute(smooth_scores, y_true)\n",
    "\n",
    "        print(f\"Running the experiment for r={r} and coverage={coverage_guarantee}\")\n",
    "        for iteration in tqdm(range(n_iterations)):\n",
    "            cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "            eval_mask = ~cal_mask\n",
    "\n",
    "            for method_name, method in cp_methods.items():\n",
    "                threshold = method.calibrate_from_scores(smooth_scores[cal_mask], y_true[cal_mask])\n",
    "                pred_set = method.predict_from_scores(smooth_scores[eval_mask], return_scores=False)\n",
    "                covered = (pred_set)[torch.arange(pred_set.shape[0]), y_true[eval_mask]]\n",
    "                set_size = pred_set.sum(dim=1)\n",
    "\n",
    "                empirical_coverage = covered.float().mean().item()\n",
    "                avg_set_size = set_size.float().mean().item()\n",
    "                result.append({\n",
    "                    \"method\": method_name,\n",
    "                    \"empirical_coverage\": empirical_coverage,\n",
    "                    \"avg_set_size\": avg_set_size,\n",
    "                    \"r\": r,\n",
    "                    \"coverage_guarantee\": coverage_guarantee,\n",
    "                    \"threshold\": threshold,\n",
    "                    \"internal_coverage_level\": method.internal_cp.coverage_guarantee,\n",
    "                    \"below_1\": (set_size <= 1).float().mean().item(),\n",
    "                    \"below_3\": (set_size <= 3).float().mean().item(),\n",
    "                    \"below_5\": (set_size <= 5).float().mean().item(),\n",
    "                    \"below_1_coverage\": covered[set_size <= 1].float().mean().item(),\n",
    "                    \"below_3_coverage\": covered[set_size <= 3].float().mean().item(),\n",
    "                    \"below_5_coverage\": covered[set_size <= 5].float().mean().item(),\n",
    "                    \"n_samples\": n_trial_samples,\n",
    "                })\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "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></th>\n",
       "      <th></th>\n",
       "      <th>empirical_coverage</th>\n",
       "      <th>avg_set_size</th>\n",
       "      <th>threshold</th>\n",
       "      <th>internal_coverage_level</th>\n",
       "      <th>below_1</th>\n",
       "      <th>below_3</th>\n",
       "      <th>below_5</th>\n",
       "      <th>below_1_coverage</th>\n",
       "      <th>below_3_coverage</th>\n",
       "      <th>below_5_coverage</th>\n",
       "      <th>n_samples</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>coverage_guarantee</th>\n",
       "      <th>r</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"14\" valign=\"top\">0.85</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.981370</td>\n",
       "      <td>2.974089</td>\n",
       "      <td>0.135680</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.240563</td>\n",
       "      <td>0.651313</td>\n",
       "      <td>0.907021</td>\n",
       "      <td>0.994163</td>\n",
       "      <td>0.986698</td>\n",
       "      <td>0.982185</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.900359</td>\n",
       "      <td>1.953318</td>\n",
       "      <td>0.058952</td>\n",
       "      <td>0.902886</td>\n",
       "      <td>0.480984</td>\n",
       "      <td>0.882474</td>\n",
       "      <td>0.988880</td>\n",
       "      <td>0.924067</td>\n",
       "      <td>0.904102</td>\n",
       "      <td>0.900313</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.982438</td>\n",
       "      <td>3.032432</td>\n",
       "      <td>0.127309</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.234328</td>\n",
       "      <td>0.638115</td>\n",
       "      <td>0.898167</td>\n",
       "      <td>0.994621</td>\n",
       "      <td>0.987669</td>\n",
       "      <td>0.983159</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.909391</td>\n",
       "      <td>2.028229</td>\n",
       "      <td>0.049331</td>\n",
       "      <td>0.905774</td>\n",
       "      <td>0.461203</td>\n",
       "      <td>0.864500</td>\n",
       "      <td>0.985969</td>\n",
       "      <td>0.931638</td>\n",
       "      <td>0.913307</td>\n",
       "      <td>0.909360</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.03</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.982318</td>\n",
       "      <td>3.023427</td>\n",
       "      <td>0.129895</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.235635</td>\n",
       "      <td>0.641693</td>\n",
       "      <td>0.899068</td>\n",
       "      <td>0.994490</td>\n",
       "      <td>0.987398</td>\n",
       "      <td>0.982976</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.910313</td>\n",
       "      <td>2.045328</td>\n",
       "      <td>0.048290</td>\n",
       "      <td>0.908660</td>\n",
       "      <td>0.457469</td>\n",
       "      <td>0.860745</td>\n",
       "      <td>0.984510</td>\n",
       "      <td>0.932299</td>\n",
       "      <td>0.914078</td>\n",
       "      <td>0.910247</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.982406</td>\n",
       "      <td>3.026323</td>\n",
       "      <td>0.127595</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.234479</td>\n",
       "      <td>0.639375</td>\n",
       "      <td>0.899234</td>\n",
       "      <td>0.994694</td>\n",
       "      <td>0.987714</td>\n",
       "      <td>0.983116</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.919604</td>\n",
       "      <td>2.138760</td>\n",
       "      <td>0.040518</td>\n",
       "      <td>0.917321</td>\n",
       "      <td>0.436990</td>\n",
       "      <td>0.837927</td>\n",
       "      <td>0.977734</td>\n",
       "      <td>0.939626</td>\n",
       "      <td>0.922808</td>\n",
       "      <td>0.919663</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.986938</td>\n",
       "      <td>3.376844</td>\n",
       "      <td>0.122916</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.192641</td>\n",
       "      <td>0.566443</td>\n",
       "      <td>0.846927</td>\n",
       "      <td>0.997089</td>\n",
       "      <td>0.990890</td>\n",
       "      <td>0.987195</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.937396</td>\n",
       "      <td>2.387729</td>\n",
       "      <td>0.026313</td>\n",
       "      <td>0.934642</td>\n",
       "      <td>0.388870</td>\n",
       "      <td>0.779307</td>\n",
       "      <td>0.954052</td>\n",
       "      <td>0.952715</td>\n",
       "      <td>0.938419</td>\n",
       "      <td>0.937432</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.991568</td>\n",
       "      <td>3.976797</td>\n",
       "      <td>0.122202</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.132922</td>\n",
       "      <td>0.453958</td>\n",
       "      <td>0.750854</td>\n",
       "      <td>0.998738</td>\n",
       "      <td>0.993966</td>\n",
       "      <td>0.991378</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.977885</td>\n",
       "      <td>3.514719</td>\n",
       "      <td>0.004795</td>\n",
       "      <td>0.972169</td>\n",
       "      <td>0.243630</td>\n",
       "      <td>0.556823</td>\n",
       "      <td>0.789724</td>\n",
       "      <td>0.978886</td>\n",
       "      <td>0.975298</td>\n",
       "      <td>0.976330</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.126311</td>\n",
       "      <td>0.851000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"14\" valign=\"top\">0.90</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.989531</td>\n",
       "      <td>3.561922</td>\n",
       "      <td>0.071357</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.184385</td>\n",
       "      <td>0.531771</td>\n",
       "      <td>0.811547</td>\n",
       "      <td>0.996978</td>\n",
       "      <td>0.992869</td>\n",
       "      <td>0.989633</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.906891</td>\n",
       "      <td>2.009167</td>\n",
       "      <td>0.051709</td>\n",
       "      <td>0.902886</td>\n",
       "      <td>0.465865</td>\n",
       "      <td>0.869385</td>\n",
       "      <td>0.986682</td>\n",
       "      <td>0.929456</td>\n",
       "      <td>0.910538</td>\n",
       "      <td>0.906905</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.989688</td>\n",
       "      <td>3.569802</td>\n",
       "      <td>0.070932</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.183964</td>\n",
       "      <td>0.530385</td>\n",
       "      <td>0.810474</td>\n",
       "      <td>0.997196</td>\n",
       "      <td>0.992983</td>\n",
       "      <td>0.989760</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.911375</td>\n",
       "      <td>2.051401</td>\n",
       "      <td>0.047596</td>\n",
       "      <td>0.905774</td>\n",
       "      <td>0.456500</td>\n",
       "      <td>0.858333</td>\n",
       "      <td>0.984073</td>\n",
       "      <td>0.932993</td>\n",
       "      <td>0.915203</td>\n",
       "      <td>0.911462</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.03</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.989724</td>\n",
       "      <td>3.573818</td>\n",
       "      <td>0.070785</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.183375</td>\n",
       "      <td>0.529885</td>\n",
       "      <td>0.809406</td>\n",
       "      <td>0.997010</td>\n",
       "      <td>0.993113</td>\n",
       "      <td>0.989834</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.909401</td>\n",
       "      <td>2.036438</td>\n",
       "      <td>0.049811</td>\n",
       "      <td>0.908660</td>\n",
       "      <td>0.460594</td>\n",
       "      <td>0.862865</td>\n",
       "      <td>0.984385</td>\n",
       "      <td>0.931696</td>\n",
       "      <td>0.913010</td>\n",
       "      <td>0.909432</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.990417</td>\n",
       "      <td>3.665162</td>\n",
       "      <td>0.064867</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.176906</td>\n",
       "      <td>0.514698</td>\n",
       "      <td>0.792781</td>\n",
       "      <td>0.997256</td>\n",
       "      <td>0.993395</td>\n",
       "      <td>0.990459</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.917974</td>\n",
       "      <td>2.133771</td>\n",
       "      <td>0.042518</td>\n",
       "      <td>0.917321</td>\n",
       "      <td>0.440208</td>\n",
       "      <td>0.839776</td>\n",
       "      <td>0.976313</td>\n",
       "      <td>0.938160</td>\n",
       "      <td>0.920841</td>\n",
       "      <td>0.917892</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.991969</td>\n",
       "      <td>3.938240</td>\n",
       "      <td>0.067859</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.149833</td>\n",
       "      <td>0.467042</td>\n",
       "      <td>0.747401</td>\n",
       "      <td>0.997875</td>\n",
       "      <td>0.994292</td>\n",
       "      <td>0.991803</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.937401</td>\n",
       "      <td>2.388458</td>\n",
       "      <td>0.026440</td>\n",
       "      <td>0.934642</td>\n",
       "      <td>0.389292</td>\n",
       "      <td>0.779547</td>\n",
       "      <td>0.953370</td>\n",
       "      <td>0.952064</td>\n",
       "      <td>0.938448</td>\n",
       "      <td>0.937282</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.995115</td>\n",
       "      <td>4.543646</td>\n",
       "      <td>0.067417</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.104865</td>\n",
       "      <td>0.373557</td>\n",
       "      <td>0.640510</td>\n",
       "      <td>0.999157</td>\n",
       "      <td>0.996302</td>\n",
       "      <td>0.995126</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.972594</td>\n",
       "      <td>3.290787</td>\n",
       "      <td>0.006851</td>\n",
       "      <td>0.972169</td>\n",
       "      <td>0.268182</td>\n",
       "      <td>0.595740</td>\n",
       "      <td>0.824896</td>\n",
       "      <td>0.974571</td>\n",
       "      <td>0.970724</td>\n",
       "      <td>0.971178</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.071013</td>\n",
       "      <td>0.901000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"14\" valign=\"top\">0.95</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.995854</td>\n",
       "      <td>4.525406</td>\n",
       "      <td>0.024742</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.121495</td>\n",
       "      <td>0.387563</td>\n",
       "      <td>0.636865</td>\n",
       "      <td>0.998792</td>\n",
       "      <td>0.996941</td>\n",
       "      <td>0.996013</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.902531</td>\n",
       "      <td>1.967167</td>\n",
       "      <td>0.056276</td>\n",
       "      <td>0.902886</td>\n",
       "      <td>0.476104</td>\n",
       "      <td>0.879484</td>\n",
       "      <td>0.988865</td>\n",
       "      <td>0.926215</td>\n",
       "      <td>0.906335</td>\n",
       "      <td>0.902504</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.02</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.995682</td>\n",
       "      <td>4.458120</td>\n",
       "      <td>0.025857</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.124661</td>\n",
       "      <td>0.395891</td>\n",
       "      <td>0.647620</td>\n",
       "      <td>0.998846</td>\n",
       "      <td>0.996900</td>\n",
       "      <td>0.995882</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.905229</td>\n",
       "      <td>1.988130</td>\n",
       "      <td>0.053624</td>\n",
       "      <td>0.905774</td>\n",
       "      <td>0.471104</td>\n",
       "      <td>0.874240</td>\n",
       "      <td>0.988016</td>\n",
       "      <td>0.928169</td>\n",
       "      <td>0.908933</td>\n",
       "      <td>0.905180</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.03</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.995859</td>\n",
       "      <td>4.505682</td>\n",
       "      <td>0.024844</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.122068</td>\n",
       "      <td>0.389682</td>\n",
       "      <td>0.639292</td>\n",
       "      <td>0.998780</td>\n",
       "      <td>0.996959</td>\n",
       "      <td>0.996044</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.910234</td>\n",
       "      <td>2.037271</td>\n",
       "      <td>0.048166</td>\n",
       "      <td>0.908660</td>\n",
       "      <td>0.458609</td>\n",
       "      <td>0.862198</td>\n",
       "      <td>0.985688</td>\n",
       "      <td>0.932016</td>\n",
       "      <td>0.914109</td>\n",
       "      <td>0.910207</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.06</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.996073</td>\n",
       "      <td>4.551167</td>\n",
       "      <td>0.023656</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.120401</td>\n",
       "      <td>0.383635</td>\n",
       "      <td>0.632063</td>\n",
       "      <td>0.998859</td>\n",
       "      <td>0.997032</td>\n",
       "      <td>0.996211</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.919604</td>\n",
       "      <td>2.134859</td>\n",
       "      <td>0.040661</td>\n",
       "      <td>0.917321</td>\n",
       "      <td>0.438094</td>\n",
       "      <td>0.838802</td>\n",
       "      <td>0.978021</td>\n",
       "      <td>0.939724</td>\n",
       "      <td>0.922782</td>\n",
       "      <td>0.919651</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.12</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.996281</td>\n",
       "      <td>4.704615</td>\n",
       "      <td>0.029092</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.108432</td>\n",
       "      <td>0.360823</td>\n",
       "      <td>0.606130</td>\n",
       "      <td>0.998950</td>\n",
       "      <td>0.997048</td>\n",
       "      <td>0.996369</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.930750</td>\n",
       "      <td>2.282984</td>\n",
       "      <td>0.031327</td>\n",
       "      <td>0.934642</td>\n",
       "      <td>0.407745</td>\n",
       "      <td>0.803234</td>\n",
       "      <td>0.964911</td>\n",
       "      <td>0.948191</td>\n",
       "      <td>0.932783</td>\n",
       "      <td>0.930884</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.25</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>0.997818</td>\n",
       "      <td>5.459130</td>\n",
       "      <td>0.025020</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.069167</td>\n",
       "      <td>0.265635</td>\n",
       "      <td>0.484479</td>\n",
       "      <td>0.998758</td>\n",
       "      <td>0.998104</td>\n",
       "      <td>0.998114</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>0.972818</td>\n",
       "      <td>3.302677</td>\n",
       "      <td>0.006755</td>\n",
       "      <td>0.972169</td>\n",
       "      <td>0.266771</td>\n",
       "      <td>0.594964</td>\n",
       "      <td>0.823141</td>\n",
       "      <td>0.974788</td>\n",
       "      <td>0.970907</td>\n",
       "      <td>0.971323</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.50</th>\n",
       "      <th>BinCP</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>0.021182</td>\n",
       "      <td>0.951000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RCP1</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>10.000000</td>\n",
       "      <td>-1000.000000</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>60.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                empirical_coverage  avg_set_size    threshold  \\\n",
       "coverage_guarantee r    method                                                  \n",
       "0.85               0.01 BinCP             0.981370      2.974089     0.135680   \n",
       "                        RCP1              0.900359      1.953318     0.058952   \n",
       "                   0.02 BinCP             0.982438      3.032432     0.127309   \n",
       "                        RCP1              0.909391      2.028229     0.049331   \n",
       "                   0.03 BinCP             0.982318      3.023427     0.129895   \n",
       "                        RCP1              0.910313      2.045328     0.048290   \n",
       "                   0.06 BinCP             0.982406      3.026323     0.127595   \n",
       "                        RCP1              0.919604      2.138760     0.040518   \n",
       "                   0.12 BinCP             0.986938      3.376844     0.122916   \n",
       "                        RCP1              0.937396      2.387729     0.026313   \n",
       "                   0.25 BinCP             0.991568      3.976797     0.122202   \n",
       "                        RCP1              0.977885      3.514719     0.004795   \n",
       "                   0.50 BinCP             1.000000     10.000000     0.126311   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "0.90               0.01 BinCP             0.989531      3.561922     0.071357   \n",
       "                        RCP1              0.906891      2.009167     0.051709   \n",
       "                   0.02 BinCP             0.989688      3.569802     0.070932   \n",
       "                        RCP1              0.911375      2.051401     0.047596   \n",
       "                   0.03 BinCP             0.989724      3.573818     0.070785   \n",
       "                        RCP1              0.909401      2.036438     0.049811   \n",
       "                   0.06 BinCP             0.990417      3.665162     0.064867   \n",
       "                        RCP1              0.917974      2.133771     0.042518   \n",
       "                   0.12 BinCP             0.991969      3.938240     0.067859   \n",
       "                        RCP1              0.937401      2.388458     0.026440   \n",
       "                   0.25 BinCP             0.995115      4.543646     0.067417   \n",
       "                        RCP1              0.972594      3.290787     0.006851   \n",
       "                   0.50 BinCP             1.000000     10.000000     0.071013   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "0.95               0.01 BinCP             0.995854      4.525406     0.024742   \n",
       "                        RCP1              0.902531      1.967167     0.056276   \n",
       "                   0.02 BinCP             0.995682      4.458120     0.025857   \n",
       "                        RCP1              0.905229      1.988130     0.053624   \n",
       "                   0.03 BinCP             0.995859      4.505682     0.024844   \n",
       "                        RCP1              0.910234      2.037271     0.048166   \n",
       "                   0.06 BinCP             0.996073      4.551167     0.023656   \n",
       "                        RCP1              0.919604      2.134859     0.040661   \n",
       "                   0.12 BinCP             0.996281      4.704615     0.029092   \n",
       "                        RCP1              0.930750      2.282984     0.031327   \n",
       "                   0.25 BinCP             0.997818      5.459130     0.025020   \n",
       "                        RCP1              0.972818      3.302677     0.006755   \n",
       "                   0.50 BinCP             1.000000     10.000000     0.021182   \n",
       "                        RCP1              1.000000     10.000000 -1000.000000   \n",
       "\n",
       "                                internal_coverage_level   below_1   below_3  \\\n",
       "coverage_guarantee r    method                                                \n",
       "0.85               0.01 BinCP                  0.851000  0.240563  0.651313   \n",
       "                        RCP1                   0.902886  0.480984  0.882474   \n",
       "                   0.02 BinCP                  0.851000  0.234328  0.638115   \n",
       "                        RCP1                   0.905774  0.461203  0.864500   \n",
       "                   0.03 BinCP                  0.851000  0.235635  0.641693   \n",
       "                        RCP1                   0.908660  0.457469  0.860745   \n",
       "                   0.06 BinCP                  0.851000  0.234479  0.639375   \n",
       "                        RCP1                   0.917321  0.436990  0.837927   \n",
       "                   0.12 BinCP                  0.851000  0.192641  0.566443   \n",
       "                        RCP1                   0.934642  0.388870  0.779307   \n",
       "                   0.25 BinCP                  0.851000  0.132922  0.453958   \n",
       "                        RCP1                   0.972169  0.243630  0.556823   \n",
       "                   0.50 BinCP                  0.851000  0.000000  0.000000   \n",
       "                        RCP1                   0.999999  0.000000  0.000000   \n",
       "0.90               0.01 BinCP                  0.901000  0.184385  0.531771   \n",
       "                        RCP1                   0.902886  0.465865  0.869385   \n",
       "                   0.02 BinCP                  0.901000  0.183964  0.530385   \n",
       "                        RCP1                   0.905774  0.456500  0.858333   \n",
       "                   0.03 BinCP                  0.901000  0.183375  0.529885   \n",
       "                        RCP1                   0.908660  0.460594  0.862865   \n",
       "                   0.06 BinCP                  0.901000  0.176906  0.514698   \n",
       "                        RCP1                   0.917321  0.440208  0.839776   \n",
       "                   0.12 BinCP                  0.901000  0.149833  0.467042   \n",
       "                        RCP1                   0.934642  0.389292  0.779547   \n",
       "                   0.25 BinCP                  0.901000  0.104865  0.373557   \n",
       "                        RCP1                   0.972169  0.268182  0.595740   \n",
       "                   0.50 BinCP                  0.901000  0.000000  0.000000   \n",
       "                        RCP1                   0.999999  0.000000  0.000000   \n",
       "0.95               0.01 BinCP                  0.951000  0.121495  0.387563   \n",
       "                        RCP1                   0.902886  0.476104  0.879484   \n",
       "                   0.02 BinCP                  0.951000  0.124661  0.395891   \n",
       "                        RCP1                   0.905774  0.471104  0.874240   \n",
       "                   0.03 BinCP                  0.951000  0.122068  0.389682   \n",
       "                        RCP1                   0.908660  0.458609  0.862198   \n",
       "                   0.06 BinCP                  0.951000  0.120401  0.383635   \n",
       "                        RCP1                   0.917321  0.438094  0.838802   \n",
       "                   0.12 BinCP                  0.951000  0.108432  0.360823   \n",
       "                        RCP1                   0.934642  0.407745  0.803234   \n",
       "                   0.25 BinCP                  0.951000  0.069167  0.265635   \n",
       "                        RCP1                   0.972169  0.266771  0.594964   \n",
       "                   0.50 BinCP                  0.951000  0.000000  0.000000   \n",
       "                        RCP1                   0.999999  0.000000  0.000000   \n",
       "\n",
       "                                 below_5  below_1_coverage  below_3_coverage  \\\n",
       "coverage_guarantee r    method                                                 \n",
       "0.85               0.01 BinCP   0.907021          0.994163          0.986698   \n",
       "                        RCP1    0.988880          0.924067          0.904102   \n",
       "                   0.02 BinCP   0.898167          0.994621          0.987669   \n",
       "                        RCP1    0.985969          0.931638          0.913307   \n",
       "                   0.03 BinCP   0.899068          0.994490          0.987398   \n",
       "                        RCP1    0.984510          0.932299          0.914078   \n",
       "                   0.06 BinCP   0.899234          0.994694          0.987714   \n",
       "                        RCP1    0.977734          0.939626          0.922808   \n",
       "                   0.12 BinCP   0.846927          0.997089          0.990890   \n",
       "                        RCP1    0.954052          0.952715          0.938419   \n",
       "                   0.25 BinCP   0.750854          0.998738          0.993966   \n",
       "                        RCP1    0.789724          0.978886          0.975298   \n",
       "                   0.50 BinCP   0.000000          0.000000          0.000000   \n",
       "                        RCP1    0.000000          0.000000          0.000000   \n",
       "0.90               0.01 BinCP   0.811547          0.996978          0.992869   \n",
       "                        RCP1    0.986682          0.929456          0.910538   \n",
       "                   0.02 BinCP   0.810474          0.997196          0.992983   \n",
       "                        RCP1    0.984073          0.932993          0.915203   \n",
       "                   0.03 BinCP   0.809406          0.997010          0.993113   \n",
       "                        RCP1    0.984385          0.931696          0.913010   \n",
       "                   0.06 BinCP   0.792781          0.997256          0.993395   \n",
       "                        RCP1    0.976313          0.938160          0.920841   \n",
       "                   0.12 BinCP   0.747401          0.997875          0.994292   \n",
       "                        RCP1    0.953370          0.952064          0.938448   \n",
       "                   0.25 BinCP   0.640510          0.999157          0.996302   \n",
       "                        RCP1    0.824896          0.974571          0.970724   \n",
       "                   0.50 BinCP   0.000000          0.000000          0.000000   \n",
       "                        RCP1    0.000000          0.000000          0.000000   \n",
       "0.95               0.01 BinCP   0.636865          0.998792          0.996941   \n",
       "                        RCP1    0.988865          0.926215          0.906335   \n",
       "                   0.02 BinCP   0.647620          0.998846          0.996900   \n",
       "                        RCP1    0.988016          0.928169          0.908933   \n",
       "                   0.03 BinCP   0.639292          0.998780          0.996959   \n",
       "                        RCP1    0.985688          0.932016          0.914109   \n",
       "                   0.06 BinCP   0.632063          0.998859          0.997032   \n",
       "                        RCP1    0.978021          0.939724          0.922782   \n",
       "                   0.12 BinCP   0.606130          0.998950          0.997048   \n",
       "                        RCP1    0.964911          0.948191          0.932783   \n",
       "                   0.25 BinCP   0.484479          0.998758          0.998104   \n",
       "                        RCP1    0.823141          0.974788          0.970907   \n",
       "                   0.50 BinCP   0.000000          0.000000          0.000000   \n",
       "                        RCP1    0.000000          0.000000          0.000000   \n",
       "\n",
       "                                below_5_coverage  n_samples  \n",
       "coverage_guarantee r    method                               \n",
       "0.85               0.01 BinCP           0.982185       60.0  \n",
       "                        RCP1            0.900313       60.0  \n",
       "                   0.02 BinCP           0.983159       60.0  \n",
       "                        RCP1            0.909360       60.0  \n",
       "                   0.03 BinCP           0.982976       60.0  \n",
       "                        RCP1            0.910247       60.0  \n",
       "                   0.06 BinCP           0.983116       60.0  \n",
       "                        RCP1            0.919663       60.0  \n",
       "                   0.12 BinCP           0.987195       60.0  \n",
       "                        RCP1            0.937432       60.0  \n",
       "                   0.25 BinCP           0.991378       60.0  \n",
       "                        RCP1            0.976330       60.0  \n",
       "                   0.50 BinCP           0.000000       60.0  \n",
       "                        RCP1            0.000000       60.0  \n",
       "0.90               0.01 BinCP           0.989633       60.0  \n",
       "                        RCP1            0.906905       60.0  \n",
       "                   0.02 BinCP           0.989760       60.0  \n",
       "                        RCP1            0.911462       60.0  \n",
       "                   0.03 BinCP           0.989834       60.0  \n",
       "                        RCP1            0.909432       60.0  \n",
       "                   0.06 BinCP           0.990459       60.0  \n",
       "                        RCP1            0.917892       60.0  \n",
       "                   0.12 BinCP           0.991803       60.0  \n",
       "                        RCP1            0.937282       60.0  \n",
       "                   0.25 BinCP           0.995126       60.0  \n",
       "                        RCP1            0.971178       60.0  \n",
       "                   0.50 BinCP           0.000000       60.0  \n",
       "                        RCP1            0.000000       60.0  \n",
       "0.95               0.01 BinCP           0.996013       60.0  \n",
       "                        RCP1            0.902504       60.0  \n",
       "                   0.02 BinCP           0.995882       60.0  \n",
       "                        RCP1            0.905180       60.0  \n",
       "                   0.03 BinCP           0.996044       60.0  \n",
       "                        RCP1            0.910207       60.0  \n",
       "                   0.06 BinCP           0.996211       60.0  \n",
       "                        RCP1            0.919651       60.0  \n",
       "                   0.12 BinCP           0.996369       60.0  \n",
       "                        RCP1            0.930884       60.0  \n",
       "                   0.25 BinCP           0.998114       60.0  \n",
       "                        RCP1            0.971323       60.0  \n",
       "                   0.50 BinCP           0.000000       60.0  \n",
       "                        RCP1            0.000000       60.0  "
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result = pd.DataFrame(result).fillna(0)\n",
    "result.to_csv(output_dir/f\"results_{scheme}_{dataset_name}_{score_method}_clean_r-0.0_samples-{n_trial_samples}_sigma-{smoothing_sigma}.csv\", index=False)\n",
    "result.groupby([\"coverage_guarantee\", \"r\", \"method\"]).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAs4AAAE9CAYAAAAbAuQGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAACHwElEQVR4nOzdd3zdVf348de5O3vvNG2690wHo6W07KGCW/wBCpYlggIqshQQEVGR8VURUZaAIKMgyCh7FVo66N4jTdvsdfc4vz/OTTOaJk2b5Ga8n49HSO69n/vJCZDc9z2f91Baa4QQQgghhBAds8R6AUIIIYQQQvQHEjgLIYQQQghxGCRwFkIIIYQQ4jBI4CyEEEIIIcRhkMBZCCGEEEKIwyCBsxBCCCGEEIfBFusFHK7MzEw9bNiwWC9DCCG6bPny5ZVa66xYr6M3yd9sIUR/1dHf7H4TOA8bNoxly5bFehlCCNFlSqmdsV5Db5O/2UKI/qqjv9mSqiGEEEIIIcRhkMBZCCGEEEKIwyCBsxBCCCGEEIeh3+Q4tycYDFJaWorP54v1UmLC5XJRWFiI3W6P9VKEEEIIIQa8fh04l5aWkpSUxLBhw1BKxXo5vUprTVVVFaWlpRQXF8d6OUIIIYQQA16/TtXw+XxkZGQMuqAZQClFRkbGoN1tF0IIIYTobf06cAYGZdDcZDD/7EIIIYQQva1HA2el1MNKqXKl1JoW96Urpd5QSm2Ofk7ryTV0t5UrV/LKK68cuP3LX/6Su++++4jPd7TPF0KIw9He3+M2jyul1L1KqS1KqdVKqektHrsg+jd7s1Lqgt5btRBC9C09veP8T+C0Nvf9HFiitR4FLIne7jfaBs5CCNFP/JOD/x63dDowKvqxCPgzmM0O4BZgNjALuKW/bXgIIUR36dHAWWv9HlDd5u4vA49Ev34E+EpPrqE9O3bsYOzYsVx44YWMHj2a8847jzfffJPjjjuOUaNG8emnn+J2u/n+97/PrFmzmDZtGi+++CKBQICbb76Zp59+mqlTp/L0008DsG7dOubPn8/w4cO59957D3yfP/zhD0ycOJGJEydyzz33HLj/17/+NaNHj+b4449n48aNvf3jCyGOwP5dm1j6nz+iI5FYL+WIHOLvcUtfBh7VxidAqlIqDzgVeENrXa21rgHeoOMAXAghYiYUjrCrysPSVWtY/uRtVNXUdOv5Y9FVI0drvTf69T4g51AHKqUWYXY+KCoq6tZFbNmyhWeeeYaHH36YmTNn8q9//YsPPviAxYsXc8cddzB+/HgWLFjAww8/TG1tLbNmzeKkk07i1ltvZdmyZdx///2ASbXYsGEDb7/9Ng0NDYwZM4bLLruM1atX849//IOlS5eitWb27NmccMIJRCIRnnrqKVauXEkoFGL69OnMmDGjW382IUT3CgSCVD16IROC29hbchb5Q0fFekk9oQDY3eJ2afS+Q91/kJ78my2EEE3c/hA7qzzsqvawq9p94OuKynImN7zPl9QHHGtZh0VpPk8fSsap53fb945pOzqttVZK6Q4efxB4EKCkpOSQxx2J4uJiJk2aBMCECRNYuHAhSikmTZrEjh07KC0tZfHixQfyj30+H7t27Wr3XGeeeSZOpxOn00l2djb79+/ngw8+4JxzziEhIQGAc889l/fff59IJMI555xDfHw8AF/60pe688cSQvSAD/7xcxaE1vLeyGs4vnB4rJfTZ/Xk32whxOChtaai0c+uKg87qzzsrPawu9rDjio3u6o8VLkDB461E+J01xf8wPYhc0Kf4bAFqXPksjXvG1gmnsuESSd069piETjvV0rlaa33Ri8DlsdgDTidzgNfWyyWA7ctFguhUAir1cp//vMfxowZ0+p5S5cu7fBcVquVUCjUQ6sWQvS29976L/PKHmZ54jxmnXsVFqs11kvqKXuAIS1uF0bv2wPMb3P/O722KiHEgBQMRyit8Zpd4yqza7wj+nl3jQdfsDktzqIgI8FBdrKLKUNSKUhxUGLZxPTa18kvew2rvw5tTYERp8DYM0kZdSop8elg6f6M5FgEzouBC4A7o59fjMEaOnXqqady3333cd9996GUYsWKFUybNo2kpCQaGho6ff7cuXO58MIL+fnPf47Wmueff57HHnsMrTUXXngh119/PaFQiJdeeolLLrmkF34iIURXbd1dRvG7V1NpyWDo1+7AlZAS6yX1pMXAD5VST2EKAeuiGxyvAXe0KAg8Bbg+VosUQvQfDb7ggTSKnVUedla52VFl0iv21fmItLgu5bBayEpykpPsZP6YbHKTXRSlxzMiK4GR2YkkOu04qzfgXPcMas0zUF8GVicUlsCIBahxX4aUAnDE9+jP1KOBs1LqScxORaZSqhRTmX0n8G+l1EXATuAb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",
      "text/plain": [
       "<Figure size 864x360 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, axs = plt.subplots(1, 2, figsize=(12, 5))\n",
    "sns.lineplot(data=result.loc[result[\"coverage_guarantee\"] == 0.85], x=\"r\", y=\"avg_set_size\", hue=\"method\", ax=axs[0])\n",
    "sns.lineplot(data=result.loc[result[\"coverage_guarantee\"] == 0.85], x=\"r\", y=\"empirical_coverage\", hue=\"method\", ax=axs[1])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "r = 0.12\n",
    "\n",
    "cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "n_dcal = cal_mask.sum().item()\n",
    "\n",
    "p_trace = 0.6\n",
    "\n",
    "p_upper = RCP1.compute_threat_p(p_trace, r, sigma=smoothing_sigma, scheme=\"laplace-l1\", type=\"upper\")\n",
    "print(\"p_upper = \", p_upper)\n",
    "\n",
    "cp_methods = {\n",
    "    \"BinCP\": BinCP(smoothing_sigma=smoothing_sigma, confidence_level=confidence, n_dcal=n_dcal, n_classes=n_classes,\n",
    "                        p_base=p_upper, scheme=\"laplace-l1\", nominal_coverage=coverage_guarantee, r=r, error_correction=True),\n",
    "    \"RCP1\": RCP1(smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes, \n",
    "                        scheme=\"laplace-l1\", schnominal_coverage=coverage_guarantee, r=r),\n",
    "}\n",
    "cp_bincp = cp_methods[method_name]\n",
    "\n",
    "print(f\"Pre-computing {method_name} for r={r} and coverage={coverage_guarantee}\")\n",
    "cp_bincp.pre_compute(smooth_scores, y_true)\n",
    "\n",
    "print(f\"Running the experiment for r={r} and coverage={coverage_guarantee}\")\n",
    "\n",
    "cal_mask = get_cal_mask(smooth_scores, calibration_budget)\n",
    "eval_mask = ~cal_mask"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "cp_bincp = cp_methods[\"BinCP\"]\n",
    "bin_cp_threshold = cp_bincp.calibrate_from_scores(smooth_scores[cal_mask], y_true[cal_mask])\n",
    "pred_set = cp_bincp.predict_from_scores(smooth_scores[eval_mask], return_scores=False)\n",
    "\n",
    "bincp_calib_scores = cp_bincp.compute_lower_bound_scores(smooth_scores[cal_mask], y_true[cal_mask])\n",
    "bincp_calib_scores = bincp_calib_scores[torch.arange(bincp_calib_scores.shape[0]), y_true[cal_mask]]\n",
    "\n",
    "covered = (pred_set)[torch.arange(pred_set.shape[0]), y_true[eval_mask]]\n",
    "set_size = pred_set.sum(dim=1)\n",
    "\n",
    "empirical_coverage = covered.float().mean().item()\n",
    "avg_set_size = set_size.float().mean().item()\n",
    "print(\"BINCP: \", empirical_coverage, avg_set_size, \"threshold = \", bin_cp_threshold)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RCP-1:  1.0 10.0 threshold =  -1000\n"
     ]
    }
   ],
   "source": [
    "cp_rcp1 = cp_methods[\"RCP1\"]\n",
    "\n",
    "rcp1_threshold = cp_rcp1.calibrate_from_scores(smooth_scores[cal_mask], y_true[cal_mask])\n",
    "pred_set = cp_rcp1.predict_from_scores(smooth_scores[eval_mask], return_scores=False)\n",
    "\n",
    "rcp1_calib_scores = cp_rcp1.compute_lower_bound_scores(smooth_scores[cal_mask], y_true[cal_mask])\n",
    "rcp1_calib_scores = rcp1_calib_scores[torch.arange(rcp1_calib_scores.shape[0]), y_true[cal_mask]]\n",
    "\n",
    "covered = (pred_set)[torch.arange(pred_set.shape[0]), y_true[eval_mask]]\n",
    "set_size = pred_set.sum(dim=1)\n",
    "\n",
    "empirical_coverage = covered.float().mean().item()\n",
    "avg_set_size = set_size.float().mean().item()\n",
    "\n",
    "print(\"RCP-1: \", empirical_coverage, avg_set_size, \"threshold = \", rcp1_threshold)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "smoothing_sigma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='None', ylabel='None'>"
      ]
     },
     "execution_count": 18,
     "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": [
    "from bin_cp.robust.robust_bounds import compute_lower_p_from_r, compute_upper_p_from_r\n",
    "from bin_cp.robust.noises import Laplace, Gaussian, get_dim, Uniform\n",
    "\n",
    "r_vals = torch.arange(0, 0.5, 0.01)\n",
    "uppers = torch.tensor([compute_upper_p_from_r(0.9, rr, Uniform(dim=get_dim(\"cifar\"), sigma=3).certify_l1) for rr in r_vals])\n",
    "sns.lineplot(x=r_vals, y=uppers)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9999990463256836"
      ]
     },
     "execution_count": 19,
     "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": [
    "sns.lineplot(x=torch.arange(n_dcal), y=bincp_calib_scores.sort().values.cpu(), label=\"BinCP Score\")\n",
    "sns.lineplot(x=torch.arange(n_dcal), y=rcp1_calib_scores.sort().values.cpu(), label=\"RCP1 Score\")\n",
    "\n",
    "cp_rcp1.final_coverage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 0.02725666331835489)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nn = 500\n",
    "from statsmodels.stats.proportion import proportion_confint\n",
    "proportion_confint(\n",
    "        0.0 * nn, nn, alpha=0.001/(nn + 1), method=\"beta\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0027706757713205398"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from scipy.stats import binomtest\n",
    "\n",
    "binomtest(int(0.0 * nn), nn).proportion_ci((0.001) / (nn + 1)).high * 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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.11.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
