{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.8/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import pandas as pd\n",
    "from scipy.stats import norm\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "from qrcp.helpers.storage import load_smooth_prediction\n",
    "from qrcp.helpers.tensor import get_smooth_scores, get_cal_mask, quantization_pdf, bound_tensor\n",
    "from qrcp.robust.confidence import bernstein_bound, dkw_cdf, dvoretzky_keifer_wolfowitz_bound\n",
    "from qrcp.robust.confidence import clopper_pearson_lower, clopper_pearson_upper\n",
    "from qrcp.robust.bounds import mean_bounds_l2, CDF_bounds_l2\n",
    "\n",
    "from qrcp.cp.core import ConformalClassifier as CP\n",
    "from qrcp.cp.scores import APSScore, TPSScore\n",
    "\n",
    "from qrcp.methods.robust_cp import RobustCP, VanillaSmoothCP\n",
    "from qrcp.methods.cas import CAS\n",
    "from qrcp.methods.vote import VoteCP\n",
    "from qrcp.methods.binary import QRCPThresholds\n",
    "\n",
    "from tqdm import tqdm\n",
    "import cvxpy as convex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#region primary configs of the experiment\n",
    "\n",
    "dataset_name = \"cifar10\"\n",
    "model_sigma = 0.25\n",
    "n_classes=10\n",
    "n_datapoints = 2048\n",
    "smoothing_sigma = 0.25\n",
    "n_samples = 10000\n",
    "n_trial_samples = 1000\n",
    "\n",
    "score_method = \"TPS\"\n",
    "calibration_budget = 0.1\n",
    "n_iterations = 100\n",
    "\n",
    "#endregion"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "#region loding smooth logit predictions\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\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",
    "n_classes = 10 if dataset_name == \"cifar10\" else None\n",
    "#endregion"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading cifar10 dataset with 2048 datapoints and 10000 samples: Score method: TPS\n"
     ]
    }
   ],
   "source": [
    "#region defining basic setup for conformal evaluation\n",
    "\n",
    "# score_bias = (1 if score_method == \"APS\" else 0) # this ensures that the scores are always in [0, 1]\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",
    "y_true_mask = F.one_hot(smooth_prediction.y_true, num_classes=10).bool().to(device)\n",
    "mean_scores = smooth_scores.mean(dim=-1)\n",
    "\n",
    "coverage_range = np.linspace(0.85, 0.99, 15).round(3)\n",
    "# r_range = np.linspace(0, smoothing_sigma * 2, 11).round(3)\n",
    "r_range = [0.0, 0.06, 0.12, 0.18, 0.25, 0.37, 0.5, 0.75]\n",
    "\n",
    "#endregion\n",
    "print(f\"Loading {dataset_name} dataset with {n_datapoints} datapoints and {n_samples} samples: Score method: {score_method}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_195853/2153761600.py:33: FutureWarning: Dropping of nuisance columns in DataFrame reductions (with 'numeric_only=None') is deprecated; in a future version this will raise TypeError.  Select only valid columns before calling the reduction.\n",
      "  vanilla_results[vanilla_results[\"coverage_guarantee\"] == 0.9].mean()\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "iteration             49.500000\n",
       "coverage_guarantee     0.900000\n",
       "r                      0.000000\n",
       "smoothing_sigma        0.250000\n",
       "model_sigma            0.250000\n",
       "threshold              0.165084\n",
       "empirical_coverage     0.899810\n",
       "average_set_size       1.466963\n",
       "dtype: float64"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vanilla_cp = VanillaSmoothCP(nominal_coverage=0.9)\n",
    "vanilla_results = []\n",
    "\n",
    "vanilla_cp.pre_compute(smooth_scores, smooth_prediction.y_true)\n",
    "\n",
    "for coverage_guarantee in coverage_range:\n",
    "    r = 0\n",
    "    vanilla_cp.set_nominal_coverage(coverage_guarantee)\n",
    "\n",
    "    for iter_i in range(n_iterations):\n",
    "        cal_mask = get_cal_mask(smooth_scores.mean(dim=-1), calibration_budget)\n",
    "        eval_mask = ~cal_mask\n",
    "        threshold = vanilla_cp.pre_compute_calibrate(cal_mask)\n",
    "        pred_set = vanilla_cp.pre_compute_predict(eval_mask)\n",
    "\n",
    "        empirical_coverage = vanilla_cp.internal_cp.coverage(pred_set, y_true_mask[eval_mask])\n",
    "        average_set_size = pred_set.sum(dim=1).float().mean().item()\n",
    "\n",
    "        vanilla_results.append({\n",
    "            \"iteration\": iter_i,\n",
    "            \"coverage_guarantee\": coverage_guarantee,\n",
    "            \"r\": r,\n",
    "            \"smoothing_sigma\": smoothing_sigma,\n",
    "            \"model_sigma\": model_sigma,\n",
    "            \"threshold\": threshold,\n",
    "            \"empirical_coverage\": empirical_coverage,\n",
    "            \"average_set_size\": average_set_size,\n",
    "            \"score_method\": score_method,  \n",
    "        })\n",
    "\n",
    "vanilla_results = pd.DataFrame(vanilla_results)\n",
    "vanilla_results#.to_csv(f\"result_folder/vanilla_results.csv\", index=False)\n",
    "vanilla_results[vanilla_results[\"coverage_guarantee\"] == 0.9].mean()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "coverage_guarantee = 0.9\n",
    "r=0.12\n",
    "cal_mask = get_cal_mask(smooth_scores.mean(dim=-1), calibration_budget)\n",
    "eval_mask = ~cal_mask"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "tau_range = torch.linspace(0.05, 0.95, 91)\n",
    "p_range = torch.linspace(0.05, 0.95, 91)\n",
    "\n",
    "tau_votes = (smooth_scores[cal_mask].reshape(smooth_scores[cal_mask].shape[0], smooth_scores.shape[1], smooth_scores.shape[2], 1) > tau_range.reshape(1, 1, 1, -1).to(device))\n",
    "tau_votes = (tau_votes.sum(dim=-2) / tau_votes.shape[-2])\n",
    "vote_mat = (tau_votes.reshape(tau_votes.shape[0], tau_votes.shape[1], tau_votes.shape[2], 1) > p_range.reshape(1, 1, 1, -1).to(device)).float().clamp(0, 1)\n",
    "del tau_votes\n",
    "torch.save({\"vote_mat\": vote_mat.cpu(), \"y_true\": smooth_prediction.y_true[cal_mask]}, f\"{dataset_name}_vote_mat.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([204, 10, 91, 91])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vote_mat.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:>"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.heatmap(vote_mat[0, smooth_prediction.y_true[cal_mask][0]].cpu(), cmap=\"Greys\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<a list of 3 text.Text objects>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "vote_mean = (vote_mat[torch.arange(vote_mat.shape[0]), smooth_prediction.y_true[cal_mask]]).mean(dim=(0)).cpu()\n",
    "sns.heatmap(vote_mean, cmap=\"Greys\", xticklabels=tau_range.numpy(), yticklabels=p_range.numpy())\n",
    "# Create a contour where values are greater than 0.9\n",
    "contour = plt.contour(vote_mean.numpy(), levels=[0.85, 0.9, 0.95], colors=['darkred', 'red', 'pink'], linestyles='dashed')\n",
    "\n",
    "# Optionally, add labels to the contour lines\n",
    "plt.clabel(contour, inline=True, fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ True,  True,  True,  ..., False, False, False],\n",
       "        [ True,  True,  True,  ..., False, False, False],\n",
       "        [ True,  True,  True,  ..., False, False, False],\n",
       "        ...,\n",
       "        [False, False, False,  ..., False, False, False],\n",
       "        [False, False, False,  ..., False, False, False],\n",
       "        [False, False, False,  ..., False, False, False]])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vote_mean > 0.9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 1, 1, 91])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tau_range.reshape(1, 1, 1, -1).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "smoothing_sigma = 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "cal_mask = get_cal_mask(smooth_scores.mean(dim=-1), calibration_budget * 1)\n",
    "eval_mask = ~cal_mask\n",
    "n_dcal = cal_mask.sum().item()\n",
    "\n",
    "sanity_check = []\n",
    "for p_base in np.linspace(0.05, 0.95, 91):\n",
    "    vote_cp_p = VoteCP(\n",
    "        nominal_coverage=coverage_guarantee, smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes,\n",
    "        error_correction=False,\n",
    "        p_base=p_base)\n",
    "\n",
    "    p_threshold = vote_cp_p.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask])\n",
    "    p_pred_set = vote_cp_p.predict_from_scores(smooth_scores[eval_mask])\n",
    "\n",
    "    vote_cp_lambda = VoteCP(\n",
    "        error_correction=False,\n",
    "        nominal_coverage=coverage_guarantee, smoothing_sigma=smoothing_sigma, n_dcal=n_dcal, n_classes=n_classes,\n",
    "        lambda_base=p_threshold)\n",
    "\n",
    "    lambda_threshold = vote_cp_lambda.calibrate_from_scores(smooth_scores[cal_mask], smooth_prediction.y_true[cal_mask])\n",
    "    lambda_pred_set = vote_cp_lambda.predict_from_scores(smooth_scores[eval_mask])\n",
    "\n",
    "    p_threat = vote_cp_p.compute_threat_p(p=p_base, r=r, sigma=smoothing_sigma, scheme=\"guass\", type=\"lower\")\n",
    "\n",
    "    sanity_check.append({\n",
    "        \"p_base\": p_base,\n",
    "        \"p_threshold\": p_threshold,\n",
    "        \"lambda_threshold\": lambda_threshold,\n",
    "        \"p_set_size\": p_pred_set.sum(dim=1).float().mean().item(),\n",
    "        \"lambda_set_size\": lambda_pred_set.sum(dim=1).float().mean().item(),\n",
    "        \"p_threat\": p_threat\n",
    "\n",
    "    })\n",
    "sanity_check = pd.DataFrame(sanity_check)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.12"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "r"
   ]
  },
  {
   "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>p_base</th>\n",
       "      <th>p_threshold</th>\n",
       "      <th>lambda_threshold</th>\n",
       "      <th>p_set_size</th>\n",
       "      <th>lambda_set_size</th>\n",
       "      <th>p_threat</th>\n",
       "      <th>p_base_plus</th>\n",
       "      <th>p_threat_plus</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.401672</td>\n",
       "      <td>0.05</td>\n",
       "      <td>1.597614</td>\n",
       "      <td>1.598156</td>\n",
       "      <td>0.029725</td>\n",
       "      <td>0.041940</td>\n",
       "      <td>0.024499</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.06</td>\n",
       "      <td>0.384695</td>\n",
       "      <td>0.06</td>\n",
       "      <td>1.587852</td>\n",
       "      <td>1.587852</td>\n",
       "      <td>0.036345</td>\n",
       "      <td>0.051170</td>\n",
       "      <td>0.030492</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.07</td>\n",
       "      <td>0.372261</td>\n",
       "      <td>0.07</td>\n",
       "      <td>1.566703</td>\n",
       "      <td>1.566703</td>\n",
       "      <td>0.043100</td>\n",
       "      <td>0.060473</td>\n",
       "      <td>0.036662</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.08</td>\n",
       "      <td>0.361049</td>\n",
       "      <td>0.08</td>\n",
       "      <td>1.554230</td>\n",
       "      <td>1.554230</td>\n",
       "      <td>0.049978</td>\n",
       "      <td>0.069835</td>\n",
       "      <td>0.042988</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.09</td>\n",
       "      <td>0.350292</td>\n",
       "      <td>0.09</td>\n",
       "      <td>1.538503</td>\n",
       "      <td>1.538503</td>\n",
       "      <td>0.056967</td>\n",
       "      <td>0.079246</td>\n",
       "      <td>0.049455</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>86</th>\n",
       "      <td>0.91</td>\n",
       "      <td>0.019189</td>\n",
       "      <td>0.91</td>\n",
       "      <td>1.570499</td>\n",
       "      <td>1.571041</td>\n",
       "      <td>0.864498</td>\n",
       "      <td>0.898386</td>\n",
       "      <td>0.849060</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>87</th>\n",
       "      <td>0.92</td>\n",
       "      <td>0.016875</td>\n",
       "      <td>0.92</td>\n",
       "      <td>1.587310</td>\n",
       "      <td>1.588395</td>\n",
       "      <td>0.878005</td>\n",
       "      <td>0.908954</td>\n",
       "      <td>0.863097</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>0.93</td>\n",
       "      <td>0.014823</td>\n",
       "      <td>0.93</td>\n",
       "      <td>1.603579</td>\n",
       "      <td>1.603579</td>\n",
       "      <td>0.891732</td>\n",
       "      <td>0.919571</td>\n",
       "      <td>0.877421</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>89</th>\n",
       "      <td>0.94</td>\n",
       "      <td>0.012505</td>\n",
       "      <td>0.94</td>\n",
       "      <td>1.644252</td>\n",
       "      <td>1.644252</td>\n",
       "      <td>0.905707</td>\n",
       "      <td>0.930246</td>\n",
       "      <td>0.892073</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>90</th>\n",
       "      <td>0.95</td>\n",
       "      <td>0.010619</td>\n",
       "      <td>0.95</td>\n",
       "      <td>1.665401</td>\n",
       "      <td>1.665401</td>\n",
       "      <td>0.919968</td>\n",
       "      <td>0.940995</td>\n",
       "      <td>0.907112</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>91 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    p_base  p_threshold  lambda_threshold  p_set_size  lambda_set_size  \\\n",
       "0     0.05     0.401672              0.05    1.597614         1.598156   \n",
       "1     0.06     0.384695              0.06    1.587852         1.587852   \n",
       "2     0.07     0.372261              0.07    1.566703         1.566703   \n",
       "3     0.08     0.361049              0.08    1.554230         1.554230   \n",
       "4     0.09     0.350292              0.09    1.538503         1.538503   \n",
       "..     ...          ...               ...         ...              ...   \n",
       "86    0.91     0.019189              0.91    1.570499         1.571041   \n",
       "87    0.92     0.016875              0.92    1.587310         1.588395   \n",
       "88    0.93     0.014823              0.93    1.603579         1.603579   \n",
       "89    0.94     0.012505              0.94    1.644252         1.644252   \n",
       "90    0.95     0.010619              0.95    1.665401         1.665401   \n",
       "\n",
       "    p_threat  p_base_plus  p_threat_plus  \n",
       "0   0.029725     0.041940       0.024499  \n",
       "1   0.036345     0.051170       0.030492  \n",
       "2   0.043100     0.060473       0.036662  \n",
       "3   0.049978     0.069835       0.042988  \n",
       "4   0.056967     0.079246       0.049455  \n",
       "..       ...          ...            ...  \n",
       "86  0.864498     0.898386       0.849060  \n",
       "87  0.878005     0.908954       0.863097  \n",
       "88  0.891732     0.919571       0.877421  \n",
       "89  0.905707     0.930246       0.892073  \n",
       "90  0.919968     0.940995       0.907112  \n",
       "\n",
       "[91 rows x 8 columns]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sanity_check[\"p_base_plus\"] = sanity_check[\"p_base\"].apply(lambda val: clopper_pearson_lower(\n",
    "    int(val * smooth_scores.shape[-1]), smooth_scores.shape[-1], alpha=0.0001))\n",
    "sanity_check[\"p_threat_plus\"] = sanity_check[\"p_base_plus\"].apply(\n",
    "    lambda val: vote_cp_p.compute_threat_p(\n",
    "        p=val, r=r, sigma=smoothing_sigma, scheme=\"guass\", type=\"lower\"))\n",
    "sanity_check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_set_sizes(p_base):\n",
    "    row = sanity_check[sanity_check[\"p_base\"] == p_base].iloc[0]\n",
    "    normal_pred_set = ((smooth_scores[cal_mask] >= row[\"p_threshold\"]).sum(dim=-1) / smooth_scores.shape[-1]) >= row[\"p_base\"]\n",
    "    robust_pred_set = ((smooth_scores[cal_mask] >= row[\"p_threshold\"]).sum(dim=-1) / smooth_scores.shape[-1]) >= row[\"p_threat_plus\"]\n",
    "    return normal_pred_set.sum(dim=1).float().mean().item(), robust_pred_set.sum(dim=1).float().mean().item()\n",
    "def find_coverage(p_base):\n",
    "    row = sanity_check[sanity_check[\"p_base\"] == p_base].iloc[0]\n",
    "    normal_pred_set = ((smooth_scores[cal_mask] >= row[\"p_threshold\"]).sum(dim=-1) / smooth_scores.shape[-1]) >= row[\"p_base\"]\n",
    "    robust_pred_set = ((smooth_scores[cal_mask] >= row[\"p_threshold\"]).sum(dim=-1) / smooth_scores.shape[-1]) >= row[\"p_threat_plus\"]\n",
    "    return normal_pred_set[y_true_mask[cal_mask]].float().mean().item(), robust_pred_set[y_true_mask[cal_mask]].float().mean().item()\n",
    "\n",
    "sanity_check[\"robust_set_size\"] = sanity_check.apply(lambda row: find_set_sizes(row[\"p_base\"])[1], axis=1)\n",
    "sanity_check[\"normal_set_size\"] = sanity_check.apply(lambda row: find_set_sizes(row[\"p_base\"])[0], axis=1)\n",
    "sanity_check[\"robust_coverage\"] = sanity_check.apply(lambda row: find_coverage(row[\"p_base\"])[1], axis=1)\n",
    "sanity_check[\"normal_coverage\"] = sanity_check.apply(lambda row: find_coverage(row[\"p_base\"])[0], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "sanity_check.to_csv(\"sanity_check.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "204"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_dcal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1.0, 2.2)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1512x360 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, ax = plt.subplots(1, 4, figsize=(21, 5))\n",
    "sns.lineplot(data=sanity_check, y=\"p_base\", x=\"p_threshold\", ax=ax[0])\n",
    "sns.lineplot(data=sanity_check, y=\"p_threat_plus\", x=\"p_threshold\", ax=ax[0])\n",
    "\n",
    "\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"p_base\", ax=ax[1], color=\"blue\")\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"p_base_plus\", ax=ax[1], color=\"blue\", linestyle=\"--\")\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"p_threat\", ax=ax[1], color=\"red\")\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"p_threat_plus\", ax=ax[1], color=\"red\", linestyle=\"--\")\n",
    "\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"normal_set_size\", ax=ax[2], color=\"blue\")\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"robust_set_size\", ax=ax[2], color=\"red\")\n",
    "\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"normal_coverage\", ax=ax[3], color=\"blue\")\n",
    "sns.lineplot(data=sanity_check, x=\"p_base\", y=\"robust_coverage\", ax=ax[3], color=\"red\")\n",
    "\n",
    "ax[2].set_ylim(1, 2.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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>p_base</th>\n",
       "      <th>p_threshold</th>\n",
       "      <th>lambda_threshold</th>\n",
       "      <th>p_set_size</th>\n",
       "      <th>lambda_set_size</th>\n",
       "      <th>p_threat</th>\n",
       "      <th>p_base_plus</th>\n",
       "      <th>p_threat_plus</th>\n",
       "      <th>robust_set_size</th>\n",
       "      <th>normal_set_size</th>\n",
       "      <th>robust_coverage</th>\n",
       "      <th>normal_coverage</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>0.62</td>\n",
       "      <td>0.066058</td>\n",
       "      <td>0.62</td>\n",
       "      <td>1.544469</td>\n",
       "      <td>1.544469</td>\n",
       "      <td>0.526104</td>\n",
       "      <td>0.600948</td>\n",
       "      <td>0.506303</td>\n",
       "      <td>1.735294</td>\n",
       "      <td>1.578431</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>0.63</td>\n",
       "      <td>0.064009</td>\n",
       "      <td>0.63</td>\n",
       "      <td>1.545553</td>\n",
       "      <td>1.545553</td>\n",
       "      <td>0.536593</td>\n",
       "      <td>0.611037</td>\n",
       "      <td>0.516760</td>\n",
       "      <td>1.740196</td>\n",
       "      <td>1.583333</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>0.64</td>\n",
       "      <td>0.061962</td>\n",
       "      <td>0.64</td>\n",
       "      <td>1.548807</td>\n",
       "      <td>1.548807</td>\n",
       "      <td>0.547148</td>\n",
       "      <td>0.621035</td>\n",
       "      <td>0.527187</td>\n",
       "      <td>1.735294</td>\n",
       "      <td>1.583333</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>60</th>\n",
       "      <td>0.65</td>\n",
       "      <td>0.059992</td>\n",
       "      <td>0.65</td>\n",
       "      <td>1.549349</td>\n",
       "      <td>1.549349</td>\n",
       "      <td>0.557771</td>\n",
       "      <td>0.631142</td>\n",
       "      <td>0.537795</td>\n",
       "      <td>1.735294</td>\n",
       "      <td>1.583333</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>61</th>\n",
       "      <td>0.66</td>\n",
       "      <td>0.058043</td>\n",
       "      <td>0.66</td>\n",
       "      <td>1.552061</td>\n",
       "      <td>1.552061</td>\n",
       "      <td>0.568463</td>\n",
       "      <td>0.641258</td>\n",
       "      <td>0.548481</td>\n",
       "      <td>1.735294</td>\n",
       "      <td>1.578431</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>62</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.056794</td>\n",
       "      <td>0.67</td>\n",
       "      <td>1.549892</td>\n",
       "      <td>1.549892</td>\n",
       "      <td>0.579226</td>\n",
       "      <td>0.651384</td>\n",
       "      <td>0.559247</td>\n",
       "      <td>1.730392</td>\n",
       "      <td>1.578431</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>63</th>\n",
       "      <td>0.68</td>\n",
       "      <td>0.055706</td>\n",
       "      <td>0.68</td>\n",
       "      <td>1.542299</td>\n",
       "      <td>1.542299</td>\n",
       "      <td>0.590060</td>\n",
       "      <td>0.661518</td>\n",
       "      <td>0.570093</td>\n",
       "      <td>1.720588</td>\n",
       "      <td>1.573529</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>0.69</td>\n",
       "      <td>0.054135</td>\n",
       "      <td>0.69</td>\n",
       "      <td>1.540130</td>\n",
       "      <td>1.540130</td>\n",
       "      <td>0.600967</td>\n",
       "      <td>0.671663</td>\n",
       "      <td>0.581022</td>\n",
       "      <td>1.720588</td>\n",
       "      <td>1.573529</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>65</th>\n",
       "      <td>0.70</td>\n",
       "      <td>0.052733</td>\n",
       "      <td>0.70</td>\n",
       "      <td>1.535792</td>\n",
       "      <td>1.535792</td>\n",
       "      <td>0.611948</td>\n",
       "      <td>0.681918</td>\n",
       "      <td>0.592147</td>\n",
       "      <td>1.725490</td>\n",
       "      <td>1.573529</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>66</th>\n",
       "      <td>0.71</td>\n",
       "      <td>0.051466</td>\n",
       "      <td>0.71</td>\n",
       "      <td>1.534165</td>\n",
       "      <td>1.534165</td>\n",
       "      <td>0.623006</td>\n",
       "      <td>0.692083</td>\n",
       "      <td>0.603248</td>\n",
       "      <td>1.725490</td>\n",
       "      <td>1.568627</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>67</th>\n",
       "      <td>0.72</td>\n",
       "      <td>0.050156</td>\n",
       "      <td>0.72</td>\n",
       "      <td>1.530911</td>\n",
       "      <td>1.530911</td>\n",
       "      <td>0.634141</td>\n",
       "      <td>0.702257</td>\n",
       "      <td>0.614438</td>\n",
       "      <td>1.720588</td>\n",
       "      <td>1.568627</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>68</th>\n",
       "      <td>0.73</td>\n",
       "      <td>0.048720</td>\n",
       "      <td>0.73</td>\n",
       "      <td>1.529284</td>\n",
       "      <td>1.529284</td>\n",
       "      <td>0.645356</td>\n",
       "      <td>0.712443</td>\n",
       "      <td>0.625719</td>\n",
       "      <td>1.720588</td>\n",
       "      <td>1.563726</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>69</th>\n",
       "      <td>0.74</td>\n",
       "      <td>0.047330</td>\n",
       "      <td>0.74</td>\n",
       "      <td>1.526573</td>\n",
       "      <td>1.526573</td>\n",
       "      <td>0.656653</td>\n",
       "      <td>0.722639</td>\n",
       "      <td>0.637093</td>\n",
       "      <td>1.715686</td>\n",
       "      <td>1.563726</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>70</th>\n",
       "      <td>0.75</td>\n",
       "      <td>0.046103</td>\n",
       "      <td>0.75</td>\n",
       "      <td>1.521150</td>\n",
       "      <td>1.521150</td>\n",
       "      <td>0.668034</td>\n",
       "      <td>0.732745</td>\n",
       "      <td>0.648449</td>\n",
       "      <td>1.710784</td>\n",
       "      <td>1.563726</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>71</th>\n",
       "      <td>0.76</td>\n",
       "      <td>0.044742</td>\n",
       "      <td>0.76</td>\n",
       "      <td>1.516811</td>\n",
       "      <td>1.516811</td>\n",
       "      <td>0.679501</td>\n",
       "      <td>0.742965</td>\n",
       "      <td>0.660019</td>\n",
       "      <td>1.710784</td>\n",
       "      <td>1.558824</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>72</th>\n",
       "      <td>0.77</td>\n",
       "      <td>0.043404</td>\n",
       "      <td>0.77</td>\n",
       "      <td>1.515184</td>\n",
       "      <td>1.515184</td>\n",
       "      <td>0.691056</td>\n",
       "      <td>0.753198</td>\n",
       "      <td>0.671691</td>\n",
       "      <td>1.705882</td>\n",
       "      <td>1.549020</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>73</th>\n",
       "      <td>0.78</td>\n",
       "      <td>0.042175</td>\n",
       "      <td>0.78</td>\n",
       "      <td>1.512473</td>\n",
       "      <td>1.512473</td>\n",
       "      <td>0.702704</td>\n",
       "      <td>0.763443</td>\n",
       "      <td>0.683469</td>\n",
       "      <td>1.705882</td>\n",
       "      <td>1.549020</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>74</th>\n",
       "      <td>0.79</td>\n",
       "      <td>0.040871</td>\n",
       "      <td>0.79</td>\n",
       "      <td>1.509219</td>\n",
       "      <td>1.509219</td>\n",
       "      <td>0.714446</td>\n",
       "      <td>0.773702</td>\n",
       "      <td>0.695357</td>\n",
       "      <td>1.700980</td>\n",
       "      <td>1.544118</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75</th>\n",
       "      <td>0.80</td>\n",
       "      <td>0.039614</td>\n",
       "      <td>0.80</td>\n",
       "      <td>1.507592</td>\n",
       "      <td>1.507592</td>\n",
       "      <td>0.726287</td>\n",
       "      <td>0.783975</td>\n",
       "      <td>0.707361</td>\n",
       "      <td>1.696079</td>\n",
       "      <td>1.544118</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>76</th>\n",
       "      <td>0.81</td>\n",
       "      <td>0.038236</td>\n",
       "      <td>0.81</td>\n",
       "      <td>1.502712</td>\n",
       "      <td>1.502712</td>\n",
       "      <td>0.738229</td>\n",
       "      <td>0.794264</td>\n",
       "      <td>0.719483</td>\n",
       "      <td>1.696079</td>\n",
       "      <td>1.549020</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>77</th>\n",
       "      <td>0.82</td>\n",
       "      <td>0.036842</td>\n",
       "      <td>0.82</td>\n",
       "      <td>1.502712</td>\n",
       "      <td>1.502712</td>\n",
       "      <td>0.750278</td>\n",
       "      <td>0.804672</td>\n",
       "      <td>0.731853</td>\n",
       "      <td>1.686275</td>\n",
       "      <td>1.549020</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>78</th>\n",
       "      <td>0.83</td>\n",
       "      <td>0.035437</td>\n",
       "      <td>0.83</td>\n",
       "      <td>1.499458</td>\n",
       "      <td>1.499458</td>\n",
       "      <td>0.762437</td>\n",
       "      <td>0.814994</td>\n",
       "      <td>0.744233</td>\n",
       "      <td>1.686275</td>\n",
       "      <td>1.549020</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>79</th>\n",
       "      <td>0.84</td>\n",
       "      <td>0.034438</td>\n",
       "      <td>0.84</td>\n",
       "      <td>1.492408</td>\n",
       "      <td>1.492408</td>\n",
       "      <td>0.774713</td>\n",
       "      <td>0.825334</td>\n",
       "      <td>0.756750</td>\n",
       "      <td>1.676471</td>\n",
       "      <td>1.544118</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>80</th>\n",
       "      <td>0.85</td>\n",
       "      <td>0.033325</td>\n",
       "      <td>0.85</td>\n",
       "      <td>1.484816</td>\n",
       "      <td>1.485358</td>\n",
       "      <td>0.787110</td>\n",
       "      <td>0.835591</td>\n",
       "      <td>0.769286</td>\n",
       "      <td>1.676471</td>\n",
       "      <td>1.534314</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>81</th>\n",
       "      <td>0.86</td>\n",
       "      <td>0.031237</td>\n",
       "      <td>0.86</td>\n",
       "      <td>1.490781</td>\n",
       "      <td>1.490781</td>\n",
       "      <td>0.799635</td>\n",
       "      <td>0.845972</td>\n",
       "      <td>0.782101</td>\n",
       "      <td>1.676471</td>\n",
       "      <td>1.529412</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>82</th>\n",
       "      <td>0.87</td>\n",
       "      <td>0.028964</td>\n",
       "      <td>0.87</td>\n",
       "      <td>1.497831</td>\n",
       "      <td>1.497831</td>\n",
       "      <td>0.812297</td>\n",
       "      <td>0.856376</td>\n",
       "      <td>0.795081</td>\n",
       "      <td>1.676471</td>\n",
       "      <td>1.549020</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>83</th>\n",
       "      <td>0.88</td>\n",
       "      <td>0.026353</td>\n",
       "      <td>0.88</td>\n",
       "      <td>1.516269</td>\n",
       "      <td>1.516269</td>\n",
       "      <td>0.825102</td>\n",
       "      <td>0.866806</td>\n",
       "      <td>0.808238</td>\n",
       "      <td>1.696079</td>\n",
       "      <td>1.563726</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>84</th>\n",
       "      <td>0.89</td>\n",
       "      <td>0.023808</td>\n",
       "      <td>0.89</td>\n",
       "      <td>1.536876</td>\n",
       "      <td>1.536876</td>\n",
       "      <td>0.838063</td>\n",
       "      <td>0.877265</td>\n",
       "      <td>0.821585</td>\n",
       "      <td>1.715686</td>\n",
       "      <td>1.573529</td>\n",
       "      <td>0.911765</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>85</th>\n",
       "      <td>0.90</td>\n",
       "      <td>0.021738</td>\n",
       "      <td>0.90</td>\n",
       "      <td>1.547180</td>\n",
       "      <td>1.547180</td>\n",
       "      <td>0.851190</td>\n",
       "      <td>0.887860</td>\n",
       "      <td>0.835276</td>\n",
       "      <td>1.750000</td>\n",
       "      <td>1.578431</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>86</th>\n",
       "      <td>0.91</td>\n",
       "      <td>0.019189</td>\n",
       "      <td>0.91</td>\n",
       "      <td>1.570499</td>\n",
       "      <td>1.571041</td>\n",
       "      <td>0.864498</td>\n",
       "      <td>0.898386</td>\n",
       "      <td>0.849060</td>\n",
       "      <td>1.774510</td>\n",
       "      <td>1.588235</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>87</th>\n",
       "      <td>0.92</td>\n",
       "      <td>0.016875</td>\n",
       "      <td>0.92</td>\n",
       "      <td>1.587310</td>\n",
       "      <td>1.588395</td>\n",
       "      <td>0.878005</td>\n",
       "      <td>0.908954</td>\n",
       "      <td>0.863097</td>\n",
       "      <td>1.789216</td>\n",
       "      <td>1.607843</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>0.93</td>\n",
       "      <td>0.014823</td>\n",
       "      <td>0.93</td>\n",
       "      <td>1.603579</td>\n",
       "      <td>1.603579</td>\n",
       "      <td>0.891732</td>\n",
       "      <td>0.919571</td>\n",
       "      <td>0.877421</td>\n",
       "      <td>1.813726</td>\n",
       "      <td>1.617647</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.901961</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>89</th>\n",
       "      <td>0.94</td>\n",
       "      <td>0.012505</td>\n",
       "      <td>0.94</td>\n",
       "      <td>1.644252</td>\n",
       "      <td>1.644252</td>\n",
       "      <td>0.905707</td>\n",
       "      <td>0.930246</td>\n",
       "      <td>0.892073</td>\n",
       "      <td>1.833333</td>\n",
       "      <td>1.661765</td>\n",
       "      <td>0.916667</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>90</th>\n",
       "      <td>0.95</td>\n",
       "      <td>0.010619</td>\n",
       "      <td>0.95</td>\n",
       "      <td>1.665401</td>\n",
       "      <td>1.665401</td>\n",
       "      <td>0.919968</td>\n",
       "      <td>0.940995</td>\n",
       "      <td>0.907112</td>\n",
       "      <td>1.852941</td>\n",
       "      <td>1.696079</td>\n",
       "      <td>0.921569</td>\n",
       "      <td>0.906863</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    p_base  p_threshold  lambda_threshold  p_set_size  lambda_set_size  \\\n",
       "57    0.62     0.066058              0.62    1.544469         1.544469   \n",
       "58    0.63     0.064009              0.63    1.545553         1.545553   \n",
       "59    0.64     0.061962              0.64    1.548807         1.548807   \n",
       "60    0.65     0.059992              0.65    1.549349         1.549349   \n",
       "61    0.66     0.058043              0.66    1.552061         1.552061   \n",
       "62    0.67     0.056794              0.67    1.549892         1.549892   \n",
       "63    0.68     0.055706              0.68    1.542299         1.542299   \n",
       "64    0.69     0.054135              0.69    1.540130         1.540130   \n",
       "65    0.70     0.052733              0.70    1.535792         1.535792   \n",
       "66    0.71     0.051466              0.71    1.534165         1.534165   \n",
       "67    0.72     0.050156              0.72    1.530911         1.530911   \n",
       "68    0.73     0.048720              0.73    1.529284         1.529284   \n",
       "69    0.74     0.047330              0.74    1.526573         1.526573   \n",
       "70    0.75     0.046103              0.75    1.521150         1.521150   \n",
       "71    0.76     0.044742              0.76    1.516811         1.516811   \n",
       "72    0.77     0.043404              0.77    1.515184         1.515184   \n",
       "73    0.78     0.042175              0.78    1.512473         1.512473   \n",
       "74    0.79     0.040871              0.79    1.509219         1.509219   \n",
       "75    0.80     0.039614              0.80    1.507592         1.507592   \n",
       "76    0.81     0.038236              0.81    1.502712         1.502712   \n",
       "77    0.82     0.036842              0.82    1.502712         1.502712   \n",
       "78    0.83     0.035437              0.83    1.499458         1.499458   \n",
       "79    0.84     0.034438              0.84    1.492408         1.492408   \n",
       "80    0.85     0.033325              0.85    1.484816         1.485358   \n",
       "81    0.86     0.031237              0.86    1.490781         1.490781   \n",
       "82    0.87     0.028964              0.87    1.497831         1.497831   \n",
       "83    0.88     0.026353              0.88    1.516269         1.516269   \n",
       "84    0.89     0.023808              0.89    1.536876         1.536876   \n",
       "85    0.90     0.021738              0.90    1.547180         1.547180   \n",
       "86    0.91     0.019189              0.91    1.570499         1.571041   \n",
       "87    0.92     0.016875              0.92    1.587310         1.588395   \n",
       "88    0.93     0.014823              0.93    1.603579         1.603579   \n",
       "89    0.94     0.012505              0.94    1.644252         1.644252   \n",
       "90    0.95     0.010619              0.95    1.665401         1.665401   \n",
       "\n",
       "    p_threat  p_base_plus  p_threat_plus  robust_set_size  normal_set_size  \\\n",
       "57  0.526104     0.600948       0.506303         1.735294         1.578431   \n",
       "58  0.536593     0.611037       0.516760         1.740196         1.583333   \n",
       "59  0.547148     0.621035       0.527187         1.735294         1.583333   \n",
       "60  0.557771     0.631142       0.537795         1.735294         1.583333   \n",
       "61  0.568463     0.641258       0.548481         1.735294         1.578431   \n",
       "62  0.579226     0.651384       0.559247         1.730392         1.578431   \n",
       "63  0.590060     0.661518       0.570093         1.720588         1.573529   \n",
       "64  0.600967     0.671663       0.581022         1.720588         1.573529   \n",
       "65  0.611948     0.681918       0.592147         1.725490         1.573529   \n",
       "66  0.623006     0.692083       0.603248         1.725490         1.568627   \n",
       "67  0.634141     0.702257       0.614438         1.720588         1.568627   \n",
       "68  0.645356     0.712443       0.625719         1.720588         1.563726   \n",
       "69  0.656653     0.722639       0.637093         1.715686         1.563726   \n",
       "70  0.668034     0.732745       0.648449         1.710784         1.563726   \n",
       "71  0.679501     0.742965       0.660019         1.710784         1.558824   \n",
       "72  0.691056     0.753198       0.671691         1.705882         1.549020   \n",
       "73  0.702704     0.763443       0.683469         1.705882         1.549020   \n",
       "74  0.714446     0.773702       0.695357         1.700980         1.544118   \n",
       "75  0.726287     0.783975       0.707361         1.696079         1.544118   \n",
       "76  0.738229     0.794264       0.719483         1.696079         1.549020   \n",
       "77  0.750278     0.804672       0.731853         1.686275         1.549020   \n",
       "78  0.762437     0.814994       0.744233         1.686275         1.549020   \n",
       "79  0.774713     0.825334       0.756750         1.676471         1.544118   \n",
       "80  0.787110     0.835591       0.769286         1.676471         1.534314   \n",
       "81  0.799635     0.845972       0.782101         1.676471         1.529412   \n",
       "82  0.812297     0.856376       0.795081         1.676471         1.549020   \n",
       "83  0.825102     0.866806       0.808238         1.696079         1.563726   \n",
       "84  0.838063     0.877265       0.821585         1.715686         1.573529   \n",
       "85  0.851190     0.887860       0.835276         1.750000         1.578431   \n",
       "86  0.864498     0.898386       0.849060         1.774510         1.588235   \n",
       "87  0.878005     0.908954       0.863097         1.789216         1.607843   \n",
       "88  0.891732     0.919571       0.877421         1.813726         1.617647   \n",
       "89  0.905707     0.930246       0.892073         1.833333         1.661765   \n",
       "90  0.919968     0.940995       0.907112         1.852941         1.696079   \n",
       "\n",
       "    robust_coverage  normal_coverage  \n",
       "57         0.921569         0.906863  \n",
       "58         0.921569         0.906863  \n",
       "59         0.921569         0.906863  \n",
       "60         0.921569         0.906863  \n",
       "61         0.921569         0.901961  \n",
       "62         0.921569         0.901961  \n",
       "63         0.921569         0.906863  \n",
       "64         0.921569         0.906863  \n",
       "65         0.921569         0.906863  \n",
       "66         0.921569         0.906863  \n",
       "67         0.921569         0.901961  \n",
       "68         0.921569         0.901961  \n",
       "69         0.916667         0.906863  \n",
       "70         0.916667         0.906863  \n",
       "71         0.916667         0.906863  \n",
       "72         0.911765         0.906863  \n",
       "73         0.911765         0.906863  \n",
       "74         0.911765         0.901961  \n",
       "75         0.911765         0.901961  \n",
       "76         0.911765         0.906863  \n",
       "77         0.911765         0.906863  \n",
       "78         0.911765         0.906863  \n",
       "79         0.911765         0.906863  \n",
       "80         0.911765         0.901961  \n",
       "81         0.911765         0.901961  \n",
       "82         0.911765         0.906863  \n",
       "83         0.911765         0.906863  \n",
       "84         0.911765         0.906863  \n",
       "85         0.916667         0.906863  \n",
       "86         0.916667         0.901961  \n",
       "87         0.916667         0.901961  \n",
       "88         0.916667         0.901961  \n",
       "89         0.916667         0.906863  \n",
       "90         0.921569         0.906863  "
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sanity_check[sanity_check[\"p_threat_plus\"] >= 0.5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "def closest_query(p, lambda_v):\n",
    "    # print(p, lambda_v)\n",
    "    if lambda_v < infinity_result[\"lambda\"].min():\n",
    "        return infinity_result.iloc[-1]\n",
    "    if p < infinity_result[\"p\"].min():\n",
    "        return infinity_result.iloc[-1]\n",
    "    p_query = (infinity_result[\"p\"] <= p)\n",
    "    lambda_query = (infinity_result[\"lambda\"] <= lambda_v)\n",
    "    return infinity_result[p_query & lambda_query].iloc[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 91/91 [00:29<00:00,  3.11it/s]\n"
     ]
    }
   ],
   "source": [
    "p_range = np.linspace(0.05, 0.95, 91)\n",
    "lambda_range = np.linspace(0.05, 0.95, 91)\n",
    "\n",
    "infinity_result = []\n",
    "for p_v in tqdm(p_range):\n",
    "    for lambda_v in lambda_range:\n",
    "        pred = (((smooth_scores > lambda_v).sum(dim=-1) / smooth_scores.shape[-1]) >= p_v)\n",
    "        set_size = pred.sum(dim=-1).float().mean()\n",
    "        coverage = pred[y_true_mask].float().mean()\n",
    "        infinity_result.append({\n",
    "            \"p\": p_v,\n",
    "            \"lambda\": lambda_v,\n",
    "            \"set_size\": set_size.item(),\n",
    "            \"coverage\": coverage.item()\n",
    "        })\n",
    "\n",
    "infinity_result = pd.DataFrame(infinity_result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='lambda', ylabel='p'>"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.heatmap(infinity_result.pivot(\"p\", \"lambda\", \"set_size\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2600424/2429643301.py:21: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels(np.round(ax.get_xticks(), 2))\n",
      "/tmp/ipykernel_2600424/2429643301.py:22: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_yticklabels(np.round(ax.get_yticks(), 2))\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXcAAAETCAYAAADNpUayAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAABNVElEQVR4nO29ebhsVXXo+xt7Hxp7QCNBQSHxqEGM3QnYxSAoYMM5dg/RqEcDQW/EGI0RjQR8qFFfGuOL6M0JcsVcI6K5Pg7IlRCUaxqbgy1ylICoCNIkiqYxCmfXeH/MWXvPWXuOvebatdauOrXH7/vq26tmzTXnXFW1Z401WlFVHMdxnNlibtILcBzHcbrHN3fHcZwZxDd3x3GcGcQ3d8dxnBnEN3fHcZwZxDd3x3GcGWTDpBfQFTue9YqiT6dskGJ/mUv7lH/jZD49Nsax2pN559Lh55b3nzPGIGmWOWONxs+zFOZZqX1u3hpfkuPyXIuvS7rg9DzjOOlz8ScuLo+Tfk7SvPbNWzY3r8EYZ7Hd6puOZ3xk6YctUh4n+86k/dO1zGUXnvRPv1flPpK8H8XvjRjzzyVf+HToOWO8rH/aLuX+UnNucjy/odiuG/aIr++x2DZIxlt8HRjMLR0vzO+5eHyvBz7E+gSrueSuD632I3/6T7459nxtmZnN3XEcZy2ZMwTHaWFdbe5NkifY0roloWfnVkjrppS+OEhymElMjdObEnLKOBK6JfEOJUHJrrM8iCWhZ++1JfEm46cSuljXZIyT9Smda0no1t2TJTUb544loWffiWykcvvi3UhZQs+u37pTzKRs666j3M68IaGb/ZMtacPSsRYkc03+WTU5T5MvcHreYL7b7U72mG6t9rra3B3HcbrCJfcJkErQphSa6NlTaT3r01ZaNz7sorRuDD1n6P+zUyskdEvH3IWEbq3h4osvLr8+joT+rC3NY1rrrdCzN+nRJZE8xZCse5HQTfuFIbmn7dndyFz2Z/kYhk48nX9D8h5QXnt2tZa0LuU7EEv/rpnOPTmO46h1XtJ3kBwvSNeSu2/ujuM4M4dL7o7jODPI/F1c5z41TFwVA0V1jKWKaevOaKktrDWuVv0yeu7QSJoZUQ0XxnHUL+baK1wXLUoG1TnLrW8M9UtuaLXUSGV1SSv1y8ihRBWGGEZZyy0yu27L+Jmda6liKgytqQE0cWPM2pNzF90e0zYKr48eW//0q6Rmr5gk62pzdxzH6YpGz7cJMzObe40R1Ty3wuWxK2l9KEHVBB9ZEno+Z1nCE0NyzidrvgNIx29yY2wroZtzGi6HpQCw0bnMa7KkbkO6LrWNZSA1FmMGHLUNNMo+8MI6W7sztjSWYnwGlrQ+X3ZzTNeZSutaCIDKXR6T8TAk+rYbQwM1/5+TZGY2d8dxnLXEiq+YFnxzdxzHWQWulpkwlhF1rIjThHHywiy9PnlVTGrUrcn5YvmrD9ny7ET9UpHjpcpAmjKO+qXBX932A1+9+qUTX/WRw1QV02gw7VsVY81v+LlnqhjDcJqpWrL+Yd4sQjU1rs6nfu5Jn47VMvMeoeo4jjN7uLfMbkAmhbbI5rh8oIouc8O/zdJ6TZSpfeewemNp1r9FRKmV76VVXpcV+o+VlbFFzpdMCjauo86dsSytd24sDU9WHt90bcwGTNoNA+w40rrh5pgZUcWQtJNrGhpJ1TgvNaJmxlXt2BWy4Y580vjm7jiOswrcW2aNqMv42PLDMDMrptKOtZ5UIkvbV17DODlhxtGnZ8OsMv9LW316vvSO3Bkr8r806dSrAo7a6tPTPhtSCdLQs2enltsz6TrFur7C63YgUoW0brk8ptJ6mh/GmCvXs5fHz6X4KLmn0nw6Z3I8MCT6LnCDquM4zgwyt6FbNU/X+ObuOI6zCtatWkZEzgWeCdymqofFtv2AjwAHA98BTlDV2wvnbgVOj0/fqqrntZq7IodM3r/Z5bFq3hYnm0bUMQynNWPWqGIs175UvXP85iXjaakwxzjG0rbjtC5hN19WPwzHqTLoZusy2s3+HalizGIdc4U+htprHMNpQVUCdirerE8yfO6iWJ5Xk3ZdjFAtG18ztUxy3kDXl1qmT3PvB4DjRtreAFyuqhuBy+PzjPgDcCZwBHA4cKaI7NvjOh3HcVojc1L9aBxL5DgRuUZErhOR0r74QBG5XES+JiJXiMiBTWP2Jrmr6mdE5OCR5i3AkfH4POAK4LSRPscCl6nqDwFE5DLCj8SHu1yfaVxtaUStKVzd5PZoZl7MBJpmCT1f7xhujhXl7ErSbZW03rOxND3XLH7RFIBkGksNSXm+LNm2dm20illYBuk2wUjp3UpN4JJZOKS8xkxatzI+ZrliDJdHQ1rP3SVDu2VEXUjHJjWoditpd+UKKSLzwNnAU4EbgR0isl1Vdybd/hj4oKqeJyJHAW8HXrzSuGvtqLm/qt4cj28B9i/0uT/wveT5jbHNcRxnauhQcj8cuE5Vr1fVO4DzCYJwyqHAp+LxpwuvL2NiXviqqoBOan7HcZxxmNswV/0QkVNE5MrkcUoyVI1A+1XgOfH42cA9ROTeK61vrb1lbhWRA1T1ZhE5ALit0OcmllQ3AAcS1DfLiG/QKQC//5gn8ZxfODS0V+SQGSdvTI0qJm9fWRWT54opz9M2irWt4dRSxWAZLht816fCb71tdGnBzz03VDarLWpUMblvfTrVOKoY48u3qCIZQxVjGUit41xvuXho5YKx1GCZETU9luUpfy0VjSaW26793NuoZVR1G7BtjOleB7xHRF4KfIawTy6sdMJaS+7bga3xeCtwYaHPpcAxIrJvNKQeE9uWoarbVHWTqm4abuyO4zhrwdy8VD8auAk4KHl+YGxbRFW/r6rPUdVHAW+KbT9aadA+XSE/TJDA7yMiNxI8YN4BXCAiJwHfBU6IfTcBr1DVk1X1hyLyFmBHHOqsoXF17DWN4bpkGgtbSOtpuymt17g2jiGt1xhOU+lpzjKiFu9GmmWFsaR1q3BGg2vjsjEbDabN0vpYWRv7kNYrct00ztlSWi9lahw9tiX0lkbU9Dj2yST0NJ9M4vK4oGl71wbVzsbbAWwUkUMIm/qJwAuzuUTuA/xQVQfAG4Fzmwbt01vmBcZLRxf6XgmcnDw/l4rFO47jTIquvGVUdZeInErQUMwD56rq1SJyFnClqm4nCMpvFxElqGVe2TTuzESo5oFLLX9RrWChlsPYLo3LJUhTWjfvEMqLueiii8rzGNJ6KomPI62beuvlw+VMrbS+NMNuI62nWDrvpjlrpPUEK1OjlU/GCi6yviC5bt3Qo8e1pX0znbulq59eyR1VvQS4ZKTtjOT4Y8DH2ow5M5u74zjOWuK5ZRzHcWaQdZtbZhppm0OmC5dHGFGLxDVUuQq2zD9jqSSssnydqWIWc7KUX65RxWRqJOt971EVE8afW77erG9HqhjD1TK7piY1C9RFnS5Wh6lQxRjTZGl7jXWpYRTVis8jc1E0yuINsuPlrpBZ38SImhfu6BYv1uE4jjOLNNidJs3Mb+591zmsclcs9TELcTRL61bR6lyaLI+TZnO0pP62BaqLXVqWu+tMWjfvtgypuHBulbSeXV/P0rp5fRWG1uG5ZjbH8npNN0fDVdE22JbbM5dHy3DacO7AcH/URETPjK6d55bxzd1xHGfmcIPqGlGTt90qeJ26P44TrFSVUqCUTbEjab0mnUC2xmLe7xWwpPWC1Ni6OHVFFsTc1tDsVte2QHXSWFx7Nrb1hVh1vvW8Tz5ms9Rv6tSHxzV3F2be9vLYtp694twKl8dMz55K6XGcrMxeJqGXA5e6d4V0nbvjOM7M4WoZx3GcGcQ39yllnBJZTdGnoZ1i+6Lb4Bgl8SzDaU2RDauEnrWGrlUx5q3sGKoY07WxIotjtoSoQzVVLtZXxjD6jqWKaePmCM1qmZSaghtW9KlZ+q55LYPcIl3sYxpRC3lksr6p+sWIStWOy+yNVZNzDVi3m7vjOM44NKXgmDQzv7mngUt2J6O5bbBSTa3EuZUld/M8K/gnOa7Jw55huTy2kNbTc2sMp9l5hsRr3l20CURatoik2XB1LErs1l2HNEvitrSedq9xczQk/RppfbjOMXLF2MfN67JcHjOJPvGGMHPEFMZMJfGBkbc9DVwadGxQdW8Zx3GcWcTVMo7jOLPHujWoishBwAcJRbAV2Kaq7xaR/YCPAAcD3wFOUNXbC+dvBU6PT9+qquetOF+NgdRUp1QYGavyvJTbm8KUx4k+ndtQvtVtnStmlaoYWFKFmD7s6XkVEaerzglTfW6DH3s2hKGSMEvx1cQOrJEqZuTUIVXRp1n/dhGkplomHbNinIGUjcrD/qlve1qsI08iI+XmDjAN71NCn6vbBfyuqh4KPBZ4pYgcCrwBuFxVNwKXx+cZ8QfgTOAIQmXwM2PJPcdxnOlgTuofE6DPSkw3AzfH438XkW8QKnpvYakA9nmE4tenjZx+LHDZsLyeiFwGHAd8uGbuvAh0u3W3jUQ1b81a5I4Zx+Xx+OOPb15LH9J66W7EktYNabZtxGlX0rop0shwCCNSsyI/TJW0XuPmWJNbpkZaLxlUzTwziZTbNsujVSrPjD5Nsz+WJf08AjWNVh22S6FtJJ+Mlo+7wCNUARE5GHgU8Hlg/7jxA9xCUNuMcn/ge8nzG2Ob4zjOVJCpGKeQ3jd3Ebk78DfA76jqv6XSmqpqrAm42rFPAU4BOP1xR/LcBz9sxf5tS+iNpWdvGtty02vp8iiGbr0mm2NGW2m9UArPlNatNVblh0nOrcil0jb/elG/3lJatyW4jqT1trr1wp1H+2LW7VweU9ToUxPolOnfTVfIcC2DmsCldF1TXGZPRI4D3k2ooXqOqr5j5PUHEDQd+8Q+b4il+Ux6va8QkT0IG/uHVPV/xeZbReSA+PoBwG2FU28CDkqeHxjbMlR1m6puUtVNTRu74zhOp8zN1T9WQETmgbOBpwGHAi+I9smU04ELVPVRwInAexuXt6qLqkCCiPZ+4Buq+qfJS9uBrfF4K3Bh4fRLgWNEZN9oSD0mtjmO40wFIlL9aOBw4DpVvV5V7wDOJ9gmUxS4Zzy+F/D9pkH7VMs8AXgxcJWIfCW2/T7wDuACETkJ+C5wAoCIbAJeoaonq+oPReQtwI543llD42oNVVGpNePUGE5bnjv8oNu6PJoqiXTOGpfHrL+x9haqGFi6ea5SxVS4iJqqmKrcMpZ6qUEVk44/I6oYSNQcLaNPTVdF4zOw8sZYahYrna8doZq06/B1o28y48KgHK3aCd0ZVEs2xiNG+rwZ+FsReRVwN+ApTYP26S3zD9ia7aML/a8ETk6enwuc28/qHMdxxqONQTW1D0a2qeq2FtO9APiAqv6JiDwO+CsROUxVB9YJsx+hmkm8yWFFOTYLszzdag2qFdK6VXCjqwClKmndsEcvvpeWMXgcw+k40npNoY3i+GNI65bxcSxp3Xzji6spS9qG8TNprnJ5TM+tyBuTGUJrslga0n2e0TH0GRhG1JE3qbj2TmhxNx83cmszr7ExnkRwB0dVPysiewP3oWyzDMurXp3jOI6ziMhc9aOBHcBGETlERPYkGEy3j/S5gajxEJFfAvYG/mWlQWdfcnccx+mDjlwhVXWXiJxKcBqZB85V1atF5CzgSlXdDvwu8Jci8hqC+eClqrqiGWEmN/euolKzPoZvez5Os6FzaEit8WcfGaSxf++qmIaap5mRtQdVTI7xIZifjWWILMybXr95W2+oFSpqqLZXxRgG0ITGfDFW9GkaKVrj556pWcpzlgprwAo1UY3oUkulMvRvt3zb86hUisdd0GWEavRZv2Sk7YzkeCfBSaWamdzcHcdxeqeFjW0SzMzmXpUVsmacihwyde58DVJ8hfRvGVEzzHnSPhUSRkXGTFMaHxYgqXovkvexIj9MPo7hnWBEn9rSempwLFzHOPle8hUbzW2l9fIwmbTedLfTtuBGdm4iCVM+13JbrLlWNdwfB8bxYpk9y0icHacW44434/WefsBxHGcW8cRhE8YqhJ0LMqv/Ra+R7ksBS33r2c31VsxruRBmlMriVbi31QRjZWvpQ1q3csoPT2gtrVuSftql4rpbBijVvN9DG4Cdk71CsrayPBoFsjPpu6WePVsP5fdYlx2M5pBJXSiXzlvo2i1yyvO5z/zm7jiO0wvrtRKT4zjOLDPtlZhmZnPP8sm0jErNxjGLSYy1vCUK44wTidqZy2MhV0xYQ1kNMFdqNyJITTfHFDP6NMFQxZjec1ZZPMvVcbF9HFVMS6Nr5sKYDtOQK2Z0fCvNbjy0VR8VRk7D5TGnnUHVLtBRVqlk7o0Fg2pmfDXUNZ0nl3GDquM4zgzirpDTj+m22Nb9MWm/6KKLFo9LxarbGlHN8nSGtG6tq1WumNH1NLgu5tK6YQTMF5b0NwxpFdJ62yLWGSWpu0rirpDWKz7jvN2Q1s3xrc+jIHXXrMU0ohpSdkUpvpoApay/GmMWjLFZPhmjcEfKyvGcq8C9ZRzHcWYQ17k7juPMIOvVWyampPwMsFec52OqeqaIHEKoNHJv4IvAi2P1kdHz30hIc7kA/LaqdlqJqav6hzUqnabcm6kRtaTCWT54s9rANMCmtIxcbYpArckn048qpjy+ZfQUyzDapEOtOa+r6NMaVUxKqoopfA5qjWGqfyrUQhVGVMun3oxoNVQnqcEUXd51UJFbpnO1zJRL7n2u7mfAUar6COCRwHEi8ljgncC7VPVBwO2EDTwj1g88EXgYIYfxe2OdQcdxnOlgfr7+MQH6rMSkwH/Ep3vEhwJHAS+M7ecRyke9b+T0LcD5qvoz4Nsich2hzuBna+auiUrN28vSaTZOjateOmZDRKlYbohtjagVc2Z9alwekz5Fl8fRcRojVC0qpHWM9kzoNzIxmtkdG9ZpSeh9SOuZxG24HFa4UTZHoFYYSC2XR1MSL0vlViRquoa8EAfF/gumcbVwTeYtUHpex0y5t0yv9xUiMh/rp94GXAZ8C/iRqu6KXW4k1A8cpVRTsNTPcRxnMshc/WMC9GpQVdUF4JEisg/wceChXY6f1iX8g199Ms/7pcPqz+0qn4yVQ6YhS2WqZzfnsaTAMXKyZ+O3CVBaNlChvUrPnkrZ5e75udZxOSgpe28ot5vrLJWkq3kvepfWLSma5Nh6M2X5eC1dHlNM18aWwUojt15Jn/Jc2RrihafFQy2de14su2NJe8pdIddkdar6I+DTwOOAfURk+KNSqhUIdTUFUdVtqrpJVTe12dgdx3HGRqT+MQF629xF5OeixI6I3AV4KvANwib/vNhtK3Bh4fTtwIkislf0rtkIfKGvtTqO47RmHatlDgDOi14uc8AFqnqxiOwEzheRtwJfBt4PICKbgU2qekasH3gBsBPYBbwyqnhMzLtYq5SbQZVro3VuReTqotugZbSsyRtjUeHyaKpcrFS82dqN97K0OMsAbQarGi6PVuk3I/rULrRhUPri1KQlHkMVUxOxa6pijBJ5KcU0vqYqptnlcWCW0zMMsxVG1IHRvxSJCnk06lLK32ZjaT5Px3ToBSMixwHvJtRQPUdV3zHy+ruAJ8endwXuq6r7rDRmn94yXwMeVWi/nuD5Mtq+naTit6q+DXhbX+tzHMcZB+1I3RIF4LMJ2o0bgR0isj3WTQ1zqb4m6f8qCnvrKLMTodrSQDpO9kczuGiuuU+TIdUeu8KImo5juDzmYxpG1HQcK7tjK2m9nWujmUrVyhVjuD9a0m9zvpiW0nrWJz0uz5NJtlUGW+PupSZHzTCIaQyXR3PtLYOVLCNqyqDR/XFpnMxwaojlmlhdtesye92pWw4HrouCLyJyPsEdfKfR/wXAmU2Dzs7m7jiOs5Z0t7mXXL+PKE4p8kDgEOBTTYP65j6C5X5o6dwt98eSnj0ds3V+dmuNY2R5rHF5NFMKFI7NdALZ2iuk9WwYq8yeoWdvK62Xzq1xc8zWYkjWCabLY4WEbmVfbDP+WC6PFWsxMz5aeeSNwCXLFTLL7d4wz2CQnkfxuAvaqGVSt+3INlXdtoppTySkclnRBgm+uTuO46wOS/AoEDdyazOvcv2OnAi8smZO39wdx3FWQ3dBTDuAjdHt+ybCBv7C0U4i8lBgXyrTsMzM5l6TT6atm+M4OWRSSqXzas6zjKgmNWUEGwpuhDW2jMosriXtaqhcsoWlx4ZraI3LY1tVTOlcMzK4oiReSutI39QoudRsGzGbP5vFcytcHu3Mjobqpia3TJZDpryGgVVowyyXNzSoLjVZUal55sjCRYxBV94yqrpLRE4FLiW4Qp4b3cHPAq6MnoQQNv3zY96uRmZmc3ccx1lTOgxOUtVLgEtG2s4Yef7mNmOu2829Kle60b8mh4zlNrg4zloaUa2sk20DlKz3ZrF/Ok/FXUTbACUz2KtlkhrLXXKxyZDWsz7N0npVTvY0s2MqtFYEDtW4WhbL7LUNRLKk8pqyeVVG1LZG2tLrZQZGKb4usPP5TAfrdnN3HMcZiwnljKnFN3fHcZxVoC28ZSbBzG/uZoRl1qflmIYx1PJtL0XD1hhIq1QxmTqlnT97q+jT0bUVfNozY23WOR26JtrSUqEYg6ZYSYbaRK6avvUtVTEVBlVTFUPa3rx2tQymhbZcFdNsRK0x6A4ov+9WIQ7bAJqem47PsnarnJ4Vubqwzsrszfzm7jiO0wddecv0xUxu7tLS/7Sp8DPARRddtHg8t0dzHpbjjz9+5fEtI2qN+2Nbl0ezvcJwWhGlW5zLktbNrJRlY2lVwQ2zLJ65IGOcguTcVlqviD7ViohW+07GkLQNl8qie2fbqNSK99Q2olrG0jRDZOouWZboc2NoYT2pFJ/mk8n6LD9tLFxydxzHmT1qvHUmyexs7sb73EfgUta/wqUy08WXpFwr3/oYeWOkQrKt0bPb70cLad0couK9rgpQqrjDMaX1lT8PC1NatwsLFI/HCVDK9NxmANLcsvGq5kxJ55SyxN2Vnn1k4mL/QUHnbgYudV1aL51nyiX33lcXi2R/WUQujs8PEZHPi8h1IvIREdnTOO+Nsc81InJs3+t0HMdpg87NVz8mwVr89LyaUF5vyDuBd6nqg4DbgZNGTxCRQwmhtg8DjgPeGxPaO47jTAUqc9WPSdCrWkZEDgSeQaio9FoJuoKjWEqKcx7wZuB9I6duIeRQ+BnwbRG5jpDQviphTuv30nIPrGhPSXPIzJlugTI6ZR0VpdmsvDGtXR7NxSXG3vnlahdTFVMRfZqpoNoaSLMlVnz4lkGz4dyqtL3ZNSXRpxUG2CqXx4pCIiW3R9PlscKIakaTVhlRk2Yr+jRLy5uqnYz2BsOo9R51nVtmvQcx/RnweuAe8fm9gR+p6q74/EZCovpR7g98Lnlu9XMcx5kI065z721zF5FnArep6hdF5Mie5lhMgH/mUUdxwmEPb+q/dFzxubR1fzR/yUuGUcvlscaImhbmte4oKqTAOpfHueJho6NATTm41gU3mgt35GswDJ01xt7ieabVPulv5IqxrikfqNynwuXRHn/5XJkE3fKOwsz3UpE3BvNuoGwYtdwfh/1rApd6NaiuY2+ZJwCbReTpwN7APQnVvfcRkQ1RereS0lclr08T4O989e90XtzccRzHYtrTD/R2X6Gqb1TVA1X1YIJx9FOq+uvAp4HnxW5bgQsLp28HThSRvWIC+43AF/paq+M4TluUuerHJJiEn/tpwPki8lbgy8D7AURkM7BJVc+IieovIFT/3gW8sqlmoJWyti63TMv2Cp/wpmIcbYt1WLTOG5MvwuhTVsVYaXwX280I0vLt9VgFN9rkioF2hTYqapZaY6s1tvEZWwUy7AjYmnw1BZVHlZqFYntuRC0bVK1I1O5829NjGS5gqW1Q7puS9ukCTz8AqOoVwBXx+HqC58ton+0EiX34/G0ELxvHcZypY90aVKcdU/quaE+l3KyEniWtNv3Cj2FENV0ha4yo+SKKrZZ7o5kvpjxK0td6j6zxVm98XCGstzxknLd1rhhjbOuf34w+NaR1M1ukkdul9N5U5Y0xskwOrOswjajltWQRrS3dH8uZLo3j5LyFNM9M12X21rFB1XEcZ2ZxyX0CVOWHqdCXpSX02uaQMaeK0llVUWxDIrb07Jk+u0rPbrkWFodszhdTk+WxSio3qCn/N2fcAbQpizdGZkdTh13jmpr2rwhWsj77kmSu1t2VkTem6jqsYCWrsHXap6X746BQIm9guVMak3YtuVt3NKtBRI4jeBPOA+eo6jsKfU4gBH0q8FVVfeFon5SZ3Nwdx3H6pivJPaZWORt4KiFgc4eIbFfVnUmfjcAbgSeo6u0ict+mcaf7vsJxHGdKUaT60cDhwHWqer2q3gGcT0jBkvKbwNmqejuAqt7WNOjMS+41UampCuPiT1y8eDy3ofm3z3ajtAyUsX+FEbWzvDGmy2NChcujaZQsXFOVKqYmVa5ldO1aFZOOaahirAjZ1tGnhlqtTQrfcLyywTHtY0eEGqodS81TEYlqFuLIVCfpdZdVNAPL6DqMOs1ep0iNimi1tJHc02j6yLYYhAkhtcr3ktduBI4YGeLBcZx/JKhu3qyqn1xpzpnf3B3HcfqgjbdMGk2/SjYQgjmPJETsf0ZEHq6qP1rphEZEZG/gt4AnEn4A/wF4n6r+dIzFdkrrItdti3Kk7o/PWrpjMt0fUwp5ZEpG1jCPYYgcI29M7iJZEaBkGlGbAoqSOatyxVQEKNVI6zUffpuyeGZwEMmxkSGStE9FEFNFgFLr4tYNrpBWQNPACFbKGcOIapXQM/uU+w+PrcClNJ9Mvsb0WUtjfoEOvWVq0q3cCHxeVe8kZMr9Z8Jmv8MatHZ1HyTkVv9z4D3AocBfVZ7rOI4zcwxkrvrRwA5gYyxktCchXcv2kT7/H0FqR0TuQ1DTXL/SoLVqmcNU9dDk+adFZKfZ23EcZ8bRgnvm6sbRXSJyKnApQZ9+bkzBchZwZYzevxQ4Ju67C8DvqeoPVhq3dnP/kog8VlU/ByAiRwBXrvZi1pIa9UvbaFWrT35cP45lRLXzxpTz6IwsLHmyylwxyxZnjS/L1lVVHzUfsHxc4XNuGnorfLvLaplmf/bWqhjLKFpTlKNCDWerbparmnJ/dsNAmx6nKg/TiNpssLU2QzV82xcGiWG2sAYrKjWvoVo+7oIuE4Kp6iXAJSNtZyTHCrw2Pqqo3dwfA/yTiNwQnz8AuEZErorz/nLthI7jOLPArKQfOK7XVXRMTTZHs898uT3LIWPmRykb/IpG1wojar6udlJoW4OxJTjbBs3SNbU1ohrtVgRuTa6YGsNpSkkqNozIdq6YMaR1K0q45txsDUZ/KeTLqXGFzCye5c+sKreMlaHRuA6zFJ4uH9OKSh0Y+WQ8t0wBVf1u3wtxHMfZnRhMeQzozPi524Wt007lX1orcMkKCqrJIdNUOs/Ss9e4PJrrqnB5zBecHNboljNpPXmfFgdqKcnU5Ipp6f5YJU1ZOuwoRZul59J5qjJRWncLzWs3A5TatjeMV5Of3czhUqFzHxj5Z8jK4qW69bLuPGUomddI4plE37Xk3pFBtS96/ekRke+IyFUi8hURuTK27Scil4nItfHvvsa5W2Ofa0Vka5/rdBzHaUuH6Qd6YS3uK56sqo9U1U3x+RuAy1V1I3B5fJ4hIvsBZxJCcA8HzrR+BBzHcSbBtG/uk1DLbCE64wPnESo0nTbS51jgMlX9IYCIXEYw6n54bZa4nDYl9FZqX0z5W5ESt60Rtea3OnVztPLfmKoYKwK1ZLxtm/vFLNFXoYqpMErW5Isp3mUb7oE17pqmkdHqU5GDp63qZrBoUJ1b1jaKZSC1jahGf1P9UVa5DIx50/aFwgZpRqUaaxwMOo5QnXKDat+SuwJ/KyJfjIlzAPZX1Zvj8S3A/oXzSol07t/fMh3HcdqhKtWPSdC35P5EVb0p5h6+TES+mb6oqioiqzZzpJnWzjrmqTz/kSu729dI3+lx6v6YYRo0yxJk0YOvKyNqyyyPtrReYXW1XEBLEoxZlMOSyg3JuiKzY0ZLQ2epRJ5Zvq7G5dGU1mtcNJvHaXJ5XDb+YsBPeZ7cJdHIG1OzLvN4CauEXraePIFPuohlazYDlzL3x65zQS6xMOXeMr2uTlVvin9vAz5O0J/fKiIHAMS/pbzENYl0UNVtqrpJVTc1beyO4zhdMu2Se2+bu4jcTUTuMTwGjgG+TkiIM/R+2QpcWDh9mEdh32hIPSa2OY7jTAXr2aC6P/DxqHLYAPy1qn5SRHYAF4jIScB3gRMARGQT8ApVPVlVfygib2EpneVZQ+NqDTXRmalve1YrdQzf9gzLJ3x4bBlRWxbfaJvCd9XRp4wYUUtkaqkag6pl5GxWxTSm7V1h/Kb6p6ZhM6WlKsZWCzUbRdvOm6pohoE2Vt6YvA5qjRHVWK9RWCMfx1LFUMRMKazL26wcMla0ahdMu597b5u7ql4PPKLQ/gPg6EL7lcDJyfNzgXP7Wp/jOM44TLu3zExGqGbtNflkLKm8xv3RyCFjpUEZvlBVfKNw3ui68i5GlsdeXB5L6zf6ts3smNKRtG7miym6Ihp3HTX0UHAjvZOwCmo0l9xrJ4nnkaItsz8ms1qJGNPxF7II1fTc8pqHfUyJ38gnox2HqK5byd1xHGeWWfDNfcJUuDymmO6PFWNmNGR97EPPni2xxuXRksRrXB5Ldy9Webzs+tPydNa6upfWc6+6hrumijsdu8h0eZ4+ApSsO4CS/t3Ss1vrzduNPhV69vSNT/OzmzJ0g/tjNldaNNsKrurPE9LVMo7jOLOIq2Ucx3FmEJfcJ0DbouRV+WEKaXtH+2QulflAy/vX5CmpKKc3lstjSo3LY1O+mArXv15UMVYkaMV7oDUumIV1tXV5xDi3bfRpnhemZpxwXGNEzft0Y0TNtSJlFY2lUmkqurFQUYhDjeMu6NI+KyLHAe8m1FA9R1XfMfL6S4E/YimY8z2qes5KY87k5u44jtM3A8N20RYRmQfOBp5KyKO1Q0S2q+rOka4fUdVTa8edmc29xp3xoosuWjye28OQimsMsBVBNk1ZH00jqomRLTITIC3Xv2YDaZXLoxWMNOzTNhNkgnmLWyOtW5kdLZfHmjuZUt9sXc13Ala+F7NAhmFEbS+tJ+MvSpdt88aU+3RlRLUKdwysNZSkZLO0nibtxm1BB3RorD0cuC7GBiEi5xOy545u7q2Y7sw3juM4U8oAqX6IyCkicmXyOCUZqjYL7nNF5Gsi8jEROajwesbMSO4pVuCSJSGbxa/zQYvjWwWtrfUUA34M6S0vxJ0OmHYf4/d5tS6PVh/LJdGgdR520yUw7dIUoLTS+MPxKu4uTGnd0ss3f6+sAKUaff2IlSdheabLbLwaXXxHevZBjetiKoFb5w4KdoQ09/tCuX1gRVStkjbeMqq6Ddg2xnQXAR9W1Z+JyMsJtTCOWukEl9wdx3FWgWr9o4HGLLiq+gNV/Vl8eg7wmKZBfXN3HMdZBR1mhdwBbBSRQ0RkT+BEQvbcRYZp0iObgW80DTqTapkaOnN/NLz8TMPsMEJ1vqwmyEvrpXlrysdVLo9NGSpHyc41Mj0WI1TbRZ/aczZHc7bLFTPav8J4WxgvM9xOKFdMjWG2pGrJi1m0U7/YRtSECiOqVYhjkKlf0rnKx0MXSMtAa+WT6bpwx8LAeC9aoqq7RORUQlrzeeBcVb1aRM4CrlTV7cBvi8hmYBfwQ+ClTeOu283dcRxnHLr8rVDVS4BLRtrOSI7fCLyxzZgzs7nXuBOaro1t3R9rJGGjT9Ft0MIQYDPGcXnMB0rONa6jKaCoQlo3jYwtpXWtCnpqJ60vSbnGnDW5YhIs6X5gSfdVuWKMubKNZrnkXBOUZK7dMqJm2RzL37dBjdGxokD2oCCmW+6PlkQ/6Dgr5MD8X5oOetW5i8g+0W3nmyLyDRF5nIjsJyKXici18e++xrlbY59rRWRrqY/jOM6k6NCg2gt9G1TfDXxSVR9KKNzxDeANwOWquhG4PD7PEJH9gDOBIwgO/mdaPwKO4ziTYNprqPamlhGRewFPIir+VfUO4A4R2QIcGbudB1wBnDZy+rHAZcPSeiJyGXAc8OHKydN1LLVn9rWKN7wita9lRJ0z1DW5wXT5ea2NqDXU+LOnJfKqIl0bcsu0zRXTkSrGjChNaTJWGlGmNbliLDXLQOaLfazo0xQ15s3VAnNGe1Q1ZdJjee2ZcTc1ulpl85LW3Ehbbk+1IgvpvGYOmbIBtlRmzyzK0aPUvNCx33zX9Cm5HwL8C/A/ROTLInJOLJS9v6reHPvcQqi1OkptxJbjOM5EWM8FsjcAjwZepaqfF5F3M6KCUVUVkVX/tsYQ3lMA3vqMY3jBox8Z2hPp1CqEbUaltnV/rDKiZote3pTOOV+W+MdyebQiGa2C1jWSdskVsSvDaUJNkQ1Tuq7I21I0npprqbhzMFwVa6T1mujTtsWth5JzVd4YA1NCb2lEze4G0iLWVsRswf0xXY8puWfrLR93QdfjdU2fkvuNwI2q+vn4/GOEzf7WoUN+/Htb4dzGiC0AVd2mqptUddNwY3ccx1kLpt2g2pvkrqq3iMj3ROQhqnoNcDQhy9lOYCvwjvj3wsLplwJ/mBhRj6HBx9Msd2f1GcP90Qr+WbWe3ZTQ0+Nxsjwm51rSupnFsUICnyvkL6nRrRvUBB9Z2RRXLa0n/S2XR+v6BoaOvnUedkvqT7Dzlq88ZlWuGEMqH5hSeVmfbunZayR069xSBshBlv0xeb0k5vfApDbtWvr2c38V8KEYUns98DLC3cIFInIS8F3gBAAR2QS8QlVPVtUfishbCGG5AGcNjauO4zjTQJUP/wTpdXNX1a8AmwovHV3oeyVwcvL8XODc3hbnOI4zBl1nmeyamYlQTckMlKl7Ykk9MtLHVtcYk82X1RlWAZDhcb5Gw+UxX6SxAMug2mysbBV9CqaReMmFsML4mpKqTQxVjBmdWZNSuIUqJu2Tq2IqcsVUFOgYRxVjuzwa71PB7dFyebTyxljqmvQ6FjIViqVGWr0RVQ0VTUkdYkWlLqS5ZTrejKfdoDqTm7vjOE7fTCo4qZaZ3NyrjKs17o+mVD6XNFdI6yWsnDSWEdU41zT0WpkYq3K4WFJuGlBUCMppKIJRPbaVw6UiV4ztrlghgS/OtXrDaZVRtKaP4fI4MI2h6fjL+9flkFnCcnm0DKe2+6FhIDXmytobCmRnRtQKMbrrrJDr3aDqOI4zk7haxnEcZwZxyX2tMI2GS4dZVKoY6gzDaJiNbhTaqFFzLBbrsFQxFpYayXKMN1PSGn1aq3TSIQtqmTFyxZjpdFuk7R2dy1TjFOay/NNN9Ytl9E3nqemTFdxYOVfMiuMX2i0D6aC1P3uzukYLeWCWr4Hi8WBgjZmOM+xLkaw9TQXcebGOTofrnNnZ3B3HcdYQl9wnQJpPZm5DWXqrKbNn5Xmx+xhjFnK+2C6PaTRpWYI1o08tybkm4jTFkNYbc7hUXFNrab0iR09baX1glA4cXl+VtG6UuLNcHs0I1ZbSulpSdJOrpeVi2NLl0bpDwLobsHLFGCXqFowNM5fuddn8aVRqmhWyyYVyHKbdz73P3DKO4zgzS5e5ZUTkOBG5RkSuE5FlNS6Sfs8VEY0R/Ssyk5J7Sqk4NVDl/pjJFpaOvkqKTpoXc59njY3nVQUopRKp2ceYa35DsU9VxsWSHrhtSbwxdOtVGRqNz6ykX6/K/jghab1tXvbFknRWBkk11mLozVvnZ2+pZ1fD/bEkgafuj5Yr5u6QW0ZE5oGzgacSEi7uEJHtqrpzpN89gFcDn18+ynJccnccx1kFCwOtfjRwOHCdql4fixqdD2wp9HsL8E7gpzXr883dcRxnFXSolmksTiQijwYOUtVP1K5vZtQyVcbMtL0iZ4qZttdS9VjzZsbYht9T67wqV8UKw2KbXDErnVvooy3H6yxtb6KOqlH7ZKqYwrk1qX27UsVUFctoiD4Nx0a+mFJumQrjZ35sfGfzSiqlQ1Olk2Jl6M0jVMvpfYsnWvN3HHXUxqCaFhaKbFPVbZXnzgF/SixZWsvMbO6O4zhrSRude9zIrc28qTjRPYDDgCuiUPrzwHYR2Ryz6Rbps0D2Q4CPJE2/AJwBfDC2Hwx8BzhBVW8vnL8VOD0+fauqnrfifEYmSKs9lcjmaiR00zBrGUMbcsdYLo815fFSVlvMerR/lbukJV0vl+zUKAhtZnbsQVo3C2cY55byvAya7rSW9Wknref7Q1mi1iz7I8lx+TtRktJrCljb7pRp/6XjGiOq5YqYGlFLhTiW90+Pdfnrxu2CGsdd0OGNwA5go4gcQtjUTwReOHxRVX8M3Gf4XESuAF630sYOPercVfUaVX2kqj4SeAzwE+DjhDqql6vqRuByRuqqAojIfsCZwBEEY8OZSVUmx3GcidOVzl1VdwGnEirQfQO4QFWvFpGzRGTzymfbrJVa5mjgW6r6XRHZAhwZ288DrgBOG+l/LHDZsPqSiFwGHAd8eE1W6ziO08CCFXFVZGXbiqpeAlwy0naG0ffImhnXanM/kaWNeX9VvTke3wLsX+jfaD0eJTeQLh0ev9nIJ5NpUJJ2yu2mcTNdQ+Znnq6t0N9Qm1RFnxoRluOoYtRS0dTkiCmpmvpWxVREiA4S1ZAZGdtKFbN03oJYUa7dq2LMNL8t8sXkWovyumoMrTXFN3LVSnmcBUOlUsohs2zMxbalHulGaxliu45QXffpB2L91M0UClyrqorIlL9FjuM4y+na+6Zr1kJyfxrwJVW9NT6/VUQOUNWbReQA4LbCOTexpLqBYD2+YrRT6l709i1P44W/8mhghQIapntiMmZNIY42kahQjka1cqYYrpVm9GmNhN6ntE5iPJ02ab2iLF5KyUCpRim7PqT1gWECsyR0S+rOPr/YbkWfWlkes/lb5o1Jr3XBkOKtSFTLdbG4jVo+l0bzQsdpHKddcl+LIKYXkOvKtwNb4/FW4MLCOZcCx4jIvtGQekxsy1DVbaq6SVU3DTd2x3GctaDL3DJ90KvkLiJ3I+RLeHnS/A7gAhE5CfgucELsuwl4haqerKo/FJG3EFyEAM4aGlct0kyQG/Zauqxcz750PGdKvGXJskbPnuWlsSTnYR+rPF4qdc1buWKs9VrBTWPkdjGk9eZ8ONZ43UvrWZ8WuvXlfYb66eYxsjwwHenWU8zi1xXSepbFMa7NClBSy0VyUJ4nc0m0AqAyN0dDF5/N1dyeSvHDDJD5WpIxLOm/6yCmKRfde93cVfU/gXuPtP2A4D0z2vdK4OTk+bnAuX2uz3EcZ7UMWnnLrD0eoeo4jrMKpj2f+0xu7jXRqpb7Y6ZascrpGW6X+SKS40LRDTP6dN5yc7RULvPF7im5yqMiorVCFVNSc5gG2jQ/C83z2yXpxndzXGn8oYrEijjNU/L27OZoRY4ahTYwDKNDTURV9GmiTrGiT/PiHuVzLZdHK+LUUqOYBtvhNRlqkUEyeJ6TpltJu+uI166Zyc3dcRynb6bcE3J2NneZX5Ic0sClKvfHRFqWCiNjfmdgBDcZgUaLfdK+lrRuGX0taT0zLKbG2P6k9ax9HGm9bWk7S1qvyLdijb8ksU+XtG4VsbZL2y0fxwxQMqT1mgClmkCnLG+MJcUnTxYWkj6GMXR4mBtLKdKnL3rXBtqumZnN3XEcZy1pl35g7ZnJzd3SuZvuj5Z0b+ncrQAlc8zCcU0x686k9dW7OTZK68lcdnk6Yzwj6KlGWs/vBtpJ65mbYeFzGGBkjcxGb+meaAUojSWtp4FJ5bWVskJWSeumlF3WuWO5RZrjGO2Wzj2dKr6Qj1FOP5CN5zp3x3EcpwlLFTQt+ObuOI6zCtZ1ENNaMmdEkObqlLL7Y55Dpny7n0WiWkZUQ9VSLJFXoRYy1T9jFdloyA8zguWKWMpR076YRnpsqEJ6UcWU1TLDaM6uVDG5MTZZo6FaScldDpevMZxbXtugoEaxVDGWwXNhUH4PLPfHzOWxIm+MWkbUdK6BoWrR5Z1ztcwgOU4jW7vOLeObu+M4zszhWSHXiNSIOme5PBruj3mu9kTizsrfpZMlx0a2RjNfTMkV0pTEm/tUZXbMcrWkXQwjX9PaR+ZdlGLHKH2XScI14zQEIi3vs7K0nvavc21sPraKVg+yOZP2zOXQCKTKjIzNrpDD/qa0ngizlrReE6BkFci28r+k0nrm0thgRE07VWWTzMbuOLeMe8s4juPMHtOuc7eC5x3HcZwV0IFWP5oQkeNE5BoRuU5ESnWlXyEiV4nIV0TkH0Tk0KYxZ0Zy3/ysLYvHqTplbkOS/tfwYTcLcZCqd9JzjbetJo3wsD1LA5z6sFt+7oYPeUWRDdOH3TBcWrlucjVHuuaozrBUH4YhdFChommrijHHzO7xV440zVQ7hhqkRhWjRr6XTG1hFNEYSxVTMp5mxtJ0/paqmCydL8U+tiqmrH4ZGCoVa5xhe2o4TQtx9OnbntJVhKqIzANnE9Kj3wjsEJHtqroz6fbXqvrfY//NwJ8S6kqbuOTuOI6zCgZa/2jgcOA6Vb1eVe8Azge2pB1U9d+Sp3dj1DRUoO9iHa8h5GhX4CrgZcABhMXfG/gi8OJ4QaPnvhE4CVgAfltVl1ViMue1sj9mhlaj3cgKabo8VrhRFvPM1BhUE1pL68b4NcUv2kjr6Zh1+WEMI6dxHXaGRuMuIZPWm90MS+6NubTeTU4YyzDbVlq3okWbok5L7pEwYkQ1I0jbSesLZoRo2qds9MzuMIyUksMxLSPqwi4jJ03XEardjXd/4HvJ8xuBI0Y7icgrgdcCewJHNQ3am+QuIvcHfhvYpKqHAfPAicA7gXep6oOA2wkb+Oi5h8a+DyPcerw33ro4juNMBQsLg+qHiJwiIlcmj1PazqeqZ6vqLwKnAac39e9b574BuIuI3AncFbiZ8Ivzwvj6ecCbgfeNnLcFOF9VfwZ8W0SuI9y6fNaayNKb58KpIf0aevbWeWMq9OWLUrGVByahbWbHOmm9+Q4kc+Fr4d5YI60PDOk/pU5aL0vUNSXvmnXq6ZzN0nqNa6Olf7cl+tK6Vp8jZhxpvUn3HcZM25vzvFhujFYyrjz/u8a+ad72tHc5oKlrV8g246nqNmCb8fJNwEHJ8wNjm8X5LN8zl9Gb5K6qNwF/DNxA2NR/TFDD/EhVd8VuNxJuSUYp3aaU+jmO40yEDr1ldgAbReQQEdmToLXYnnYQkY3J02cA1zYN2pvkLiL7EiTwQ4AfAR+lwbrrOI6zu9CVzl1Vd4nIqcClBPX1uap6tYicBVypqtuBU0XkKcCdBHX21qZx+1TLPAX4tqr+C4CI/C/gCcA+IrIhSu/W7UfVbUrUW50C8McnbuElTzx82L7Ux1CntDaizpfVLGKpTpraW6tiygZaKz9MTZSpWVDDUMXkBTKWj9M2J0yda+N8uU/2f2WoaKpywbCsT41rozWGpaKxzrWNpUvjLFjqEkt1UiiuYaXqHUcVU1KVrHhua5fHsjF0qLpJ23bdWXaFTOk6i2OXQUyqeglwyUjbGcnxq9uO2acr5A3AY0XkrhJ226OBncCngefFPluBCwvnbgdOFJG9ROQQYCPwhdFOqrpNVTep6qbhxu44jrMWDBYG1Y9J0JvkrqqfF5GPAV8CdgFfJhgUPgGcLyJvjW3vh0XH/E2qeka8JbmA8GOwC3ilqi6U5hkiG8ql8lLpey4tp7chdb6xjKhW/hkjAMkstGGMH6mT1pc+qkxaz9oN10YrJ0yDa+Oy46ZcLWZpPUtaL0v34xhLa3LBNBlMp9lYauWFSdezkEnUy90720rrWdbGbBwt9rGkbyvLoxrWVTWNscsl9/SNUctwO+h2k13XicNU9UzgzJHm6wmeL6N9t5MYEVT1bcDb+lyf4zjOavEaqo7jODOI53NfI7J0vnsk6gbLWGoeJ29JqorJIjjLfWwj6nL/8yof9rmygXQsv3WzhmlLVUwh101VVGpLY6lm9UxTmo2Sefpfiv1LBtOa+qW5sbRsulqwjKgV+Vxqapuaqp6C8dQsxFFhOM380NsaQhNrcKYuMoylme98ckJ+HP3cd1ljDIrHCwsranZb07Wap2tmZnN3HMdZS9a1zn0tSYtv5EGpUuyTZXw0XB6lxkA6Z0RcWtGiw/7ZrUbyupEhsrMo05aZGNtkbqwxlmaFODLxtxtjadtsjaXcLguWq2RFHphBjTG2pWvjguHGaEn9uZ0xXpMhZWtLad0qiZdlfBysXlrftavs0pitMw6aRZ+aRtSyRN8Fk/KCqWVmNnfHcZy1xA2qa4QloYvh/igbaqTyVKJP9ez1unUw9OvjSOtduTZW5HY3peKCK+QAQ4duZGrsQ0K38r8spHnTjT7ltpYujIbUn+q5BxX69JqSdxjtpWLVlrRuuUiauddTCZly+6BGWs/mKueIyYOUFortS23lHDILu5LzdnUsuXcdFdUxM7O5O47jrCUuuTuO48wgvrmvETKfqmWSqNRUFZOoVqwoUzP6tCYStUkVA4sqndy10cgJY6hi6oylZffDJnfG0WPTuFosbZeqHlLDabP6parIhdk/WUtFhKiV82XYP/+fTdUd3ahfLANpkzvjSn0st8RFV0jzdcNYark2VuSHSTe9XZmOaOmw5No4uh5LFTM8Tg2auftl0p66YnbsCtn1eF0zM5u74zjOWuKS+xphFsLeY8+lTqmwZfTPC1cnb48lubeQ1gE0jmkWpzbGy/sn66ownLYtRG1J6Lar49AVsjngqCsXxsxYWhVoVG8k7cNAamdl7FZCXzbOokHVCD5KJW7S9nIgkuU6uWAYTrM7looi1rm0Xl7PcFM1g6USI+rCrl3LzusKdYOq4zjO7OGSu+M4zgzim/takRpR90hULmnE6YY9lo7nDGNp0qe1KsbyV0/UO4t5WIzzctVHami1fMibC2tY6XRTWqffLRbIaFa/DCw1j9W/Is+LpTqpMaiWVDBtI0hzv/l07OTY8k/vWP0S+i9Xo9TkgTGNqC2jTEuFNUJ72Z/dVsWUI1AXihGqS8fpeKnRs/MIVVfLOI7jzB6DXevYW0ZEXg38JkGE+ktV/TMR2Q/4CHAw8B3gBFW9vXDuVuD0+PStqnreSnNlBtXEiJpK7mwwJPENLQ2nZrRqRRbHQpm9gWwo9s2MnHPLpf/ReawCGYNMWk8MkWlEq+FyaJWwy1whtSC5G9J6VmzCiFa1pOwUzdwf01fKrot5tGo60HLDbFuj6DgRpJiSftLFjCitN5J2JqFnOV4MI2o2ftnlMYtKNY2x5f7DMdOI0zvvvDPpu7Tpanpex5vxtKtlyvfoHSAihxE29sOBRwDPFJEHAW8ALlfVjcDl8fnoufsRinwcEc8/MxbcdhzHmQpUB9WPJkTkOBG5RkSuE5HSnvhaEdkpIl8TkctF5IFNY/Ypuf8S8HlV/Ulc3P8BngNsAY6Mfc4DrgBOGzn3WOAyVf1hPPcy4Djgw9ZkmZ49zRtj6dn3SHXrhuTeUlrPMh4abpHDHOZZeTyj8LQVcGTpxO286WXJPZfEy7r7BS2fm0mrca5x9OaW26IdlLTUumDkU2+bH32pzJ7xuuW2aOWBqZDETQk9HccsT2f0KbVb19RSKreO8wLZqVtiKnGTYPVPpO70M96V3gEsxLYlN8dUik8l9OzOoWPJvauUvyIyD5wNPBW4EdghIttVdWfS7cuEMqQ/EZH/Bvw/wPNXGrc3yR34OvCrInJvEbkr8HTgIGB/Vb059rkF2L9w7v2B7yXPb4xtjuM4U4EOBtWPBg4HrlPV61X1DuB8ghC8NJfqp4eCMvA54MCmQfsskP0NEXkn8LfAfwJfARZG+qiITLfiynEcp0AbnbuInAKckjRtU9Vt8bgkzB6xwnAnAf+7ac6+C2S/H3g/gIj8IWHRt4rIAap6s4gcANxWOPUmllQ3EH6lrhjtlL5hf/6ql3LS08IpmcvjhpaqmNRtscJYOpjfo9gnLSFXUt2kLoxmBGlFubtcRWP00bLKJTdcGoUlKlwXF10Ix1C5tC1yUTKEwnjG0OHaqlQulnrEdE+kyDgql6xARTpoYQ1WBKmV78VM85vlokkjRNupX6y8MJl6Z6GsUhmqZTIXylQVkxhUd92ZqG6S4y4YtMgtEzfybY0dGxCRFwGbgF9r6tunWgYRuW/8+wCCvv2vge3A1thlK3Bh4dRLgWNEZN9oSD0mtmWo6jZV3aSqm4Ybu+M4zlrQoVrmJoLKesiBsS1DRJ4CvAnYrKo/a16gam8P4O+BncBXgaNj270JXjLXAn8H7BfbNwHnJOf+BnBdfLysz3WOeY2nrIc519O1+vs7m/NO6lor1rUBuB44BNgz7pcPG+nzKOBbwMbacSWe6KwSEblSVTfN+pyTmne9zDmpef1apwMReTrwZ8A8cK6qvk1EzgKuVNXtIvJ3wMOBoTPKDaq6eaUxPULVcRxnwqjqJcAlI21nJMdPaTtmrzp3x3EcZzL45j4+Y1vAd5M5JzXveplzUvP6tc4ornN3HMeZQVxydxzHmUF8c3ccx5lBfHOfAUREmns54zCJ93i9zDkpZv1afXPfjRGRPSDk6Jn0WmaVSbzH62XOSbFertUNqh0gIj8H7KGq30/apM8vj4hsBp4G3JWQ/vNmjSmS+0REngk8HrgH8H8DP1bVO1c+a/ebM8675u/xepkzzjuJ79JErnUS+OY+JiLyPOD1hGTjnwT+VlX/Pr7WywYfC6FcCryYkOf+7sA/Ax9V1WU5KTqc9zGEXEC/BTwLuAuhqtanVfXHszJnnHfN3+P1MmecdxLfpYlc66RwtcwYiMi9gd8hVJw6nrDBbxGR50Cvt333BT6jqp9S1dcTItsOBJ4nIvv0NCfAgwk/XttV9TcImTqfAfyaiGzoSYc5iTlhMu/xepkTJvO5TupaJ4Jv7uMxD+wF/FRVbwHeBdwAPE5EHtvjvF8EDhKRZwOo6sXA/wEeBtynx3k/B/y8iDw+zvsXwJeAFwF36+nHbBJzwmTe4/UyJ0zmc53UtU4E39zHQFVvA/4GOElE7qeqPyCkNYZQeapzRGQu3raeBzxeRH4truUi4KeEO4m++FfCP+ATReShcd73AXcAvzcrc07iPV4vcyas6ec64WudCL65j8+n498TReT+qvqvwLuBJ4tI59KALlXb/TvgdkLh8RNi21eBn4rI2J/r8LY4vT1W1X8n/Jj9ArBZRJ4UX/oC8JNlg+wGc5ZYq/d4vcw5DZ/rJN7fSeMG1VUiIvOquhCPnwE8CdibkL/iUODVwHGq+h9jznMQcCvBG+c/RWSDqu6Krx1MqFj13whVrg4HnqGqXxtnzjj2/qp6q4jsoap3jlzvI4HNhGow/0LweHiGql61u80Zx17z93i9zBnHnsR3aSLXOk345l6JiBxB2Lx/oqo7YtseQ9ctEXk0cBThi3on8Huq+qUx53wG8E7gn4B9gD9Q1WtEZAMwGEojInJ34DBCjufvW+O1mPeZhIovVxFun7ep6nfivAuqqhKKnu8HPBr4iqresLvNGedd8/d4vcwZx5vEd2ki1zp16BRUIpn2B8Ev9lqCVP5x4P3Ja3uN9L0PwSA0znxCKLt1FUHC2B94HSFR/8Ninw3x74EdX+svEqrCHAn8KuEf8/PECjDA/PA6d/M5J/IeE4ohf32N5zwAuHrWv0uT/L+ZxsfEFzDtD4JHzPnAi+PzewL/CHxspN8TRzf6DubdFjeD4R3Wqwm1FR8cnz8Y+AvgbsM+Hcy7D/Df47HEx2kE74YHxvaHE4JO7tLFvMC9iD+YazVnMvc24H5r8R7Hte8FvG8N57wfIUhozeYc+S6dvcbfpYn830zjY+IL2B0e8Qv54pG2vwf+Ih7fDTgduH8Hcz0I+BVCrdmPAK8fef31wAfiJnFPYJ+OrvFhBL3nQwhGrdclr80BZwCnx+e/QAfSFuEH8UXxn/7vgTf0PWcc63jgNcAehB/u3+/7PQa2AGcT6mR+BHjTGsx5bNxIH07wEvmDNfouPZYQKPQ04MvAa9fgu7Qx/t/cA/go8Oq1uNZpfkx8AdP6GP7Kx+MXEW6lH5C03Qf4GPBLcXPas4M5nwl8jeB7+x6C/v47wBuTPgcTf1Q6vNanxXm3A+8n2A6uBk5N+hwLvK+j+eYI0YFXA9cQIhQPINxOv7qPOZMxjwG+AhybvJ83AKf19R4TfjS/mcz5AOC7I5te13MOr/OGuJnuG+fs7TrjmJvjd+l/xu/wlvi/81t9fa7x+/NVgsr0DOBPgB+PzNn5tU77w2uoFohGoAtEZLuqnqiq/1NEHgL8o4g8QVVvUNV/FZFdwD01fHvuGHPOxwN/BLxQVb8sItsIVvzHA58TkaF66InAY0RkX1W9fZw547xHElw3X6SqXxCRi4B/J0heH43uYX9O2HwfLCL3AP4jXvOq0GDQ+g8ROQ9YAE4gbD5HAf8kIrtU9ewu54TF9/ivgOPjtd6H4C3xLOATInIncDHhPe/sPQYeA5yjqpeKyAMIP2ynA+8VkZ8ClwOP62pOEXkK8F7CxnotIS3Gh4CjgSskJM7q47t0b+CVhO/w10Xkg8B/Aa8CzouekO+jw881zvly4AWqulNETiG839uBt4vIXeLxE+j2M516fHMfQUTuBpxKCGp4vIh8WFVfoKp/EL+cF4nIewmS+y8Dt3U4/TtV9cvx+E3AB1T1+3EDPh14LXAE8NIOv6C3Ai+Pm93PE/4x/oAgbV0AvIDgUfCrwAka/JO7YhdBin0/IYXDgQTp/fkicjjhx63LOX9A8GQ6IG4KH41ruBo4h3DtG4FNwMs6fI93AXvG4/OB7wPfIlzrMQRV2OM7nHMeeImqXi0hrP5q4Omq+ucSgndOJxgaH9PhnBCu8y7AQ0Xke4TvzL2BnQT10EmE/5lfo7vPdRfhx/LngZ2quk1Enk74/n6T4Jb8UOCRdHut08+kbx2m8UEwPN2dJdXLh5PXnk3wjz0HOKzDOecJdwHD4wMJ+soDYtsDCT/G9+rxut/Eki70ZOD/JWx2e9Ohp0oy3y8S9ezA7xI23jPj8z17mvMRBA+OGwk/KHPAKQR9+EGxz74dz/lwgvrpfMIGA8Go93ZgSx9zxjHn4t/jgFuAR8Xne8e/+/Qw5/MIYf6fA86IbccQMjA+MX6Xfq7jOV9BUAO9GHgb4S7llcAfJ306v9Zpf0x8AdP+IEgefzPc4AmGxwf2POeG+ONyeXz+IoJ1/y5rfO2fBB7T4/j3A/5H3GSvBc4EPgG8oufrOpTEnhDbLgUeHY8796AgGHG/DZyVtL2fIGH3MufI/GcBvx8Fhw09z7UvQcX4zKTt48Mfsh7muxfw68C5wJ8m7Zesx019+HC1TAOq+gMReTnwRyJyDeGf48ie59xF0El/T0TeTpB8Xqqq/9XXnCJ5emIReS7wcwQXsl7QoHL6HkEN9EpVvUhEngxc19eccd6dBFUBsHit9yFea/o+dMj/Jvx4vVlEvhvbHgH8YY9zpnyV4CH0zvj96g1VvV1EPgWcICJ3EKT1B8Y19DHfj4EPRRXqMEDpJQRXzN7z/k8rHqFaiYi8huAS+VTtIOS9YS4huOl9I/49WlWv7XPOZO69CHcKrwWer6pf73m+g4D7quoX4/M5XcoD0ivxfX4ZQf/8f6nq1Wsw56MJqou9CDaVXr9LI3NfQHCt/c4azLUP8BLguYTEXK9X1V4298Lcv0H4TJ+/lu/vtOGbewUisi/BuPi7uob5J0TkpcCOtdh0kjn3AJ4KfEtVr1nDeXutXGXNSTDu3aKq31zLudeSSby3ydz3IOwz/7aGcz6QkFOm1zvAacc390pEZG9V/ekazzmxf0rHcXZvfHN3HMeZQWYqf7HjOI4T8M3dcRxnBvHN3XEcZwbxzd2ZWkRkrCpWyThvFpHXVfT7gIg8r4s5HWfS+ObuOI4zg/jm7kw9InJ3EblcRL4kIleJyJbYfrCIfDNK3P8sIh8SkaeIyD+KyLUx+diQR4jIZ2P7b8bzRUTeIyLXiMjfAfdN5jxDRHaIyNdFZFv0iXec3Qbf3J3dgZ8Cz1bVRwNPBv4k2WwfRMjf/dD4eCEhQdXrCLlUhvwyIaXw44AzROR+hCRwDyHkmnkJITPjkPeo6q+o6mGETIfP7OnaHKcXPLeMszsgwB+KyJOAAaGE2v7xtW8PQ8xF5GpCsjUVkasIBRqGXBhz8/yXiHyakE74SYSEcAvA92M+lCFPFpHXA8PizVcDF/V2hY7TMb65O7sDv05IYvYYVb1TRL5DSEYF8LOk3yB5PiD/fo9G65nReyKyN6HYxSZV/Z6IvDmZz3F2C1wt4+wO3Au4LW7sTyZkGGzLFhHZOxbpOBLYAXyGUBhkXkQOIKh8YGkj/1cRuTsh0Zfj7Fa45O7sDnyIUAHrKuBKQoWdtnwN+DQhte9bYrrhjxP08DsJtUY/C6CqPxKRvyRU87mF8EPgOLsVnlvGcRxnBnG1jOM4zgzim7vjOM4M4pu74zjODOKbu+M4zgzim7vjOM4M4pu74zjODOKbu+M4zgzim7vjOM4M8v8DO1ZjTbZiSIsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.ticker import MaxNLocator\n",
    "\n",
    "# Assuming `infinity_result` is your DataFrame\n",
    "heatmap_data = infinity_result.pivot(\"p\", \"lambda\", \"coverage\")\n",
    "\n",
    "# Create the heatmap\n",
    "ax = sns.heatmap(heatmap_data, cmap=\"coolwarm\")\n",
    "\n",
    "count_0_9 = (heatmap_data <= 0.9).sum().sum()\n",
    "\n",
    "# Annotate the number of occurrences of 0.9\n",
    "\n",
    "eps=1e-2\n",
    "ax = sns.heatmap((heatmap_data >= 0.9-eps) * (heatmap_data <= 0.9 + eps), cmap=\"Greys\", alpha=0.3, cbar=False)\n",
    "\n",
    "# Reduce the number of ticks\n",
    "ax.xaxis.set_major_locator(MaxNLocator(integer=True, prune='both'))\n",
    "ax.yaxis.set_major_locator(MaxNLocator(integer=True, prune='both'))\n",
    "\n",
    "# Round the tick labels to 2 decimal places\n",
    "ax.set_xticklabels(np.round(ax.get_xticks(), 2))\n",
    "ax.set_yticklabels(np.round(ax.get_yticks(), 2))\n",
    "\n",
    "# Optionally, rotate the tick labels for better readability\n",
    "plt.xticks(rotation=45)\n",
    "plt.yticks(rotation=0)\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n"
     ]
    }
   ],
   "source": [
    "eta = 0.0001\n",
    "treshold = 0.3\n",
    "samples_cutoff = [n_samples // 20, n_samples // 10, n_samples // 5, n_samples // 2, n_samples]\n",
    "\n",
    "binary_df_true = []\n",
    "continuous_df_true = []\n",
    "\n",
    "for n_samples_cutted in samples_cutoff:\n",
    "    score_vals = smooth_scores[0, smooth_prediction.y_true[0]]\n",
    "    score_vals = score_vals[0:n_samples_cutted]\n",
    "\n",
    "    votes = score_vals > threshold\n",
    "    print(score_vals.shape)\n",
    "    print(votes.shape)\n",
    "\n",
    "    v_estim = (votes.sum() / votes.shape[0]).item()\n",
    "    v_upper = clopper_pearson_lower(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "    v_lower = clopper_pearson_upper(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "    binary_result = {\n",
    "        \"v_estim\": v_estim,\n",
    "        \"v_upper\": v_upper,\n",
    "        \"v_lower\": v_lower,\n",
    "        \"confidence\": 1-eta,\n",
    "        \"n_samples\": n_samples_cutted\n",
    "    }\n",
    "    binary_df_true.append(binary_result)\n",
    "\n",
    "    mu_estim = score_vals.mean().item()\n",
    "    mu_upper = CDF_bounds_l2(randoms=score_vals, smoothing_sigma=smoothing_sigma, radius=0, confidence=1-eta, type=\"upper\", n_bins=-1).item()\n",
    "    mu_lower = CDF_bounds_l2(randoms=score_vals, smoothing_sigma=smoothing_sigma, radius=0, confidence=1-eta, type=\"lower\", n_bins=-1).item()\n",
    "    continuous_result = {\n",
    "        \"mu_estim\": mu_estim,\n",
    "        \"mu_upper\": mu_upper,\n",
    "        \"mu_lower\": mu_lower,\n",
    "        \"confidence\": 1-eta,\n",
    "        \"n_samples\": n_samples_cutted\n",
    "    }\n",
    "    continuous_df_true.append(continuous_result)\n",
    "\n",
    "binary_df_true = pd.DataFrame(binary_df_true)\n",
    "continuous_df_true = pd.DataFrame(continuous_df_true)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n"
     ]
    }
   ],
   "source": [
    "samples_cutoff = [n_samples // 20, n_samples // 10, n_samples // 5, n_samples // 2, n_samples]\n",
    "\n",
    "binary_df_false = []\n",
    "continuous_df_false = []\n",
    "\n",
    "for n_samples_cutted in samples_cutoff:\n",
    "    score_vals = smooth_scores[0, (smooth_prediction.y_true[0] - 1) % 10]\n",
    "    score_vals = score_vals[0:n_samples_cutted]\n",
    "\n",
    "    votes = score_vals > threshold\n",
    "    print(score_vals.shape)\n",
    "    print(votes.shape)\n",
    "\n",
    "    v_estim = (votes.sum() / votes.shape[0]).item()\n",
    "    v_upper = clopper_pearson_lower(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "    v_lower = clopper_pearson_upper(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "    binary_result = {\n",
    "        \"v_estim\": v_estim,\n",
    "        \"v_upper\": v_upper,\n",
    "        \"v_lower\": v_lower,\n",
    "        \"confidence\": 1-eta,\n",
    "        \"n_samples\": n_samples_cutted\n",
    "    }\n",
    "    binary_df_false.append(binary_result)\n",
    "\n",
    "    mu_estim = score_vals.mean().item()\n",
    "    mu_upper = CDF_bounds_l2(randoms=score_vals, smoothing_sigma=smoothing_sigma, radius=0, confidence=1-eta, type=\"upper\", n_bins=-1).item()\n",
    "    mu_lower = CDF_bounds_l2(randoms=score_vals, smoothing_sigma=smoothing_sigma, radius=0, confidence=1-eta, type=\"lower\", n_bins=-1).item()\n",
    "    continuous_result = {\n",
    "        \"mu_estim\": mu_estim,\n",
    "        \"mu_upper\": mu_upper,\n",
    "        \"mu_lower\": mu_lower,\n",
    "        \"confidence\": 1-eta,\n",
    "        \"n_samples\": n_samples_cutted\n",
    "    }\n",
    "    continuous_df_false.append(continuous_result)\n",
    "\n",
    "binary_df_false = pd.DataFrame(binary_df_false)\n",
    "continuous_df_false = pd.DataFrame(continuous_df_false)\n",
    "\n",
    "binary_df_true.to_csv(\"binary_df_true.csv\", index=False)\n",
    "continuous_df_true.to_csv(\"continuous_df_true.csv\", index=False)\n",
    "binary_df_false.to_csv(\"binary_df_false.csv\", index=False)\n",
    "continuous_df_false.to_csv(\"continuous_df_false.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='n_samples', ylabel='mu_upper'>"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1008x504 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "f, ax = plt.subplots(1, 2, figsize=(14, 7), sharey=True)\n",
    "sns.lineplot(binary_df_true, x=\"n_samples\", y=\"v_upper\", color=\"blue\", ax=ax[0])\n",
    "sns.lineplot(binary_df_true, x=\"n_samples\", y=\"v_lower\", color=\"blue\", ax=ax[0])\n",
    "sns.lineplot(binary_df_true, x=\"n_samples\", y=\"v_estim\", color=\"blue\", linestyle=\"--\", ax=ax[0])\n",
    "\n",
    "sns.lineplot(continuous_df_true, x=\"n_samples\", y=\"mu_upper\", color=\"blue\", ax=ax[1])\n",
    "sns.lineplot(continuous_df_true, x=\"n_samples\", y=\"mu_lower\", color=\"blue\", ax=ax[1])\n",
    "sns.lineplot(continuous_df_true, x=\"n_samples\", y=\"mu_estim\", color=\"blue\" , linestyle=\"--\", ax=ax[1])\n",
    "\n",
    "sns.lineplot(binary_df_false, x=\"n_samples\", y=\"v_upper\", color=\"red\", ax=ax[0])\n",
    "sns.lineplot(binary_df_false, x=\"n_samples\", y=\"v_lower\", color=\"red\", ax=ax[0])\n",
    "sns.lineplot(binary_df_false, x=\"n_samples\", y=\"v_estim\", color=\"red\", linestyle=\"--\", ax=ax[0])\n",
    "\n",
    "sns.lineplot(continuous_df_false, x=\"n_samples\", y=\"mu_upper\", color=\"red\", ax=ax[1])\n",
    "sns.lineplot(continuous_df_false, x=\"n_samples\", y=\"mu_lower\", color=\"red\", ax=ax[1])\n",
    "sns.lineplot(continuous_df_false, x=\"n_samples\", y=\"mu_estim\", color=\"red\", linestyle=\"--\", ax=ax[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.1 , 0.11, 0.12, 0.13, 0.14, 0.15, 0.16, 0.17, 0.18, 0.19, 0.2 ,\n",
       "       0.21, 0.22, 0.23, 0.24, 0.25, 0.26, 0.27, 0.28, 0.29, 0.3 , 0.31,\n",
       "       0.32, 0.33, 0.34, 0.35, 0.36, 0.37, 0.38, 0.39, 0.4 , 0.41, 0.42,\n",
       "       0.43, 0.44, 0.45, 0.46, 0.47, 0.48, 0.49, 0.5 , 0.51, 0.52, 0.53,\n",
       "       0.54, 0.55, 0.56, 0.57, 0.58, 0.59, 0.6 , 0.61, 0.62, 0.63, 0.64,\n",
       "       0.65, 0.66, 0.67, 0.68, 0.69, 0.7 , 0.71, 0.72, 0.73, 0.74, 0.75,\n",
       "       0.76, 0.77, 0.78, 0.79, 0.8 , 0.81, 0.82, 0.83, 0.84, 0.85, 0.86,\n",
       "       0.87, 0.88, 0.89, 0.9 ])"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.linspace(0.1, 0.9, 81)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n"
     ]
    }
   ],
   "source": [
    "eta = 0.0001\n",
    "treshold_range = np.linspace(0.1, 0.9, 81)\n",
    "samples_cutoff = [n_samples // 20, n_samples // 10, n_samples // 5, n_samples // 2, n_samples]\n",
    "\n",
    "binary_df_ablate = []\n",
    "\n",
    "for n_samples_cutted in samples_cutoff:\n",
    "    for threshold in treshold_range:\n",
    "        score_vals = smooth_scores[0, smooth_prediction.y_true[0]]\n",
    "        score_vals = score_vals[0:n_samples_cutted]\n",
    "\n",
    "        votes = score_vals > threshold\n",
    "        print(score_vals.shape)\n",
    "        print(votes.shape)\n",
    "\n",
    "        v_estim = (votes.sum() / votes.shape[0]).item()\n",
    "        v_upper = clopper_pearson_lower(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "        v_lower = clopper_pearson_upper(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "        binary_result = {\n",
    "            \"v_estim\": v_estim,\n",
    "            \"v_upper\": v_upper,\n",
    "            \"v_lower\": v_lower,\n",
    "            \"threshold\": threshold,\n",
    "            \"confidence\": 1-eta,\n",
    "            \"n_samples\": n_samples_cutted\n",
    "        }\n",
    "        binary_df_ablate.append(binary_result)\n",
    "\n",
    "\n",
    "binary_df_ablate = pd.DataFrame(binary_df_ablate)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([500])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([1000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([2000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([5000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n",
      "torch.Size([10000])\n"
     ]
    }
   ],
   "source": [
    "eta = 0.0001\n",
    "treshold_range = np.linspace(0.1, 0.9, 81)\n",
    "samples_cutoff = [n_samples // 20, n_samples // 10, n_samples // 5, n_samples // 2, n_samples]\n",
    "\n",
    "binary_df_ablate_false = []\n",
    "\n",
    "for n_samples_cutted in samples_cutoff:\n",
    "    for threshold in treshold_range:\n",
    "        score_vals = smooth_scores[0, (smooth_prediction.y_true[0]+1) % 10]\n",
    "        score_vals = score_vals[0:n_samples_cutted]\n",
    "\n",
    "        votes = score_vals > threshold\n",
    "        print(score_vals.shape)\n",
    "        print(votes.shape)\n",
    "\n",
    "        v_estim = (votes.sum() / votes.shape[0]).item()\n",
    "        v_upper = clopper_pearson_lower(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "        v_lower = clopper_pearson_upper(n_votes=votes.sum().cpu(), n_samples=votes.shape[0], alpha=eta)\n",
    "        binary_result = {\n",
    "            \"v_estim\": v_estim,\n",
    "            \"v_upper\": v_upper,\n",
    "            \"v_lower\": v_lower,\n",
    "            \"threshold\": threshold,\n",
    "            \"confidence\": 1-eta,\n",
    "            \"n_samples\": n_samples_cutted\n",
    "        }\n",
    "        binary_df_ablate_false.append(binary_result)\n",
    "\n",
    "\n",
    "binary_df_ablate_false = pd.DataFrame(binary_df_ablate_false)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:xlabel='threshold', ylabel='v_upper'>"
      ]
     },
     "execution_count": 97,
     "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(binary_df_ablate, x=\"threshold\", y=\"v_upper\", color=\"blue\")\n",
    "# sns.lineplot(binary_df_ablate, x=\"threshold\", y=\"v_lower\", color=\"blue\")\n",
    "# sns.lineplot(binary_df_ablate, x=\"threshold\", y=\"v_estim\", color=\"blue\", linestyle=\"--\")\n",
    "\n",
    "sns.lineplot(binary_df_ablate_false, x=\"threshold\", y=\"v_upper\", color=\"red\")\n",
    "sns.lineplot(binary_df_ablate_false, x=\"threshold\", y=\"v_lower\", color=\"red\")\n",
    "sns.lineplot(binary_df_ablate_false, x=\"threshold\", y=\"v_estim\", color=\"red\", linestyle=\"--\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sparse_smoothing.cert import compute_rho_for_many, regions_binary, compute_rho"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "p = np.linspace(0.05, 0.95, 91)\n",
    "rho = compute_rho_for_many(\n",
    "    regions=regions_binary(ra=1, rd=1, pf_plus=0.01, pf_minus=0.6),\n",
    "    p_emps=p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:>"
      ]
     },
     "execution_count": 11,
     "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=p, y=compute_rho_for_many(\n",
    "    regions=regions_binary(ra=1, rd=3, pf_plus=0.01, pf_minus=0.6),\n",
    "    p_emps=p))\n",
    "\n",
    "sns.lineplot(x=p, y=compute_rho_for_many(\n",
    "    regions=regions_binary(ra=0, rd=3, pf_plus=0.01, pf_minus=0.6),\n",
    "    p_emps=p))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sparse_mean_bound(p_emp,  \n",
    "                      reg, type=\"lower\",\n",
    "                      eta=0.05, bonferroni_tasks=1, error_correction=True):\n",
    "    \n",
    "\n",
    "    a = 0.0\n",
    "    b = 1\n",
    "\n",
    "    h = convex.Variable(len(reg))\n",
    "    if type == \"lower\":\n",
    "        result = convex.Problem(convex.Minimize(convex.sum(h @ reg[:, 1])), [h@reg[:, 0] == p_emp, h >= a, h<=b]).solve()\n",
    "    elif type == \"upper\":\n",
    "        result = convex.Problem(convex.Maximize(convex.sum(h @ reg[:, 1])), [h@reg[:, 0] == p_emp, h >= a, h<=b]).solve()\n",
    "    return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.05, 0.06, 0.07, 0.08, 0.09, 0.1 , 0.11, 0.12, 0.13, 0.14, 0.15,\n",
       "       0.16, 0.17, 0.18, 0.19, 0.2 , 0.21, 0.22, 0.23, 0.24, 0.25, 0.26,\n",
       "       0.27, 0.28, 0.29, 0.3 , 0.31, 0.32, 0.33, 0.34, 0.35, 0.36, 0.37,\n",
       "       0.38, 0.39, 0.4 , 0.41, 0.42, 0.43, 0.44, 0.45, 0.46, 0.47, 0.48,\n",
       "       0.49, 0.5 , 0.51, 0.52, 0.53, 0.54, 0.55, 0.56, 0.57, 0.58, 0.59,\n",
       "       0.6 , 0.61, 0.62, 0.63, 0.64, 0.65, 0.66, 0.67, 0.68, 0.69, 0.7 ,\n",
       "       0.71, 0.72, 0.73, 0.74, 0.75, 0.76, 0.77, 0.78, 0.79, 0.8 , 0.81,\n",
       "       0.82, 0.83, 0.84, 0.85, 0.86, 0.87, 0.88, 0.89, 0.9 , 0.91, 0.92,\n",
       "       0.93, 0.94, 0.95])"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[4.7373309882430537e-07,\n",
       " 5.683544535107819e-07,\n",
       " 4.75013529492207e-06,\n",
       " 1.1000048892516324e-05,\n",
       " 1.7250047341216402e-05,\n",
       " 2.3500023904868247e-05,\n",
       " 2.975003459137459e-05,\n",
       " 3.600004188463088e-05,\n",
       " 4.225004573489897e-05,\n",
       " 4.8500047382076906e-05,\n",
       " 5.475004744905578e-05,\n",
       " 6.1000046554953196e-05,\n",
       " 6.725004520577237e-05,\n",
       " 7.350004371648366e-05,\n",
       " 7.975004229554013e-05,\n",
       " 8.60000409065004e-05,\n",
       " 9.225003952326405e-05,\n",
       " 9.850003810647907e-05,\n",
       " 0.00010475003663996016,\n",
       " 0.00011100003514103487,\n",
       " 0.00011725003363366229,\n",
       " 0.00012350003243465475,\n",
       " 0.0001297500308644555,\n",
       " 0.00013600002863148423,\n",
       " 0.0001422500285477982,\n",
       " 0.000148500029515699,\n",
       " 0.00015475007624279042,\n",
       " 0.0001610001661136113,\n",
       " 0.00016725034967420496,\n",
       " 0.0001735006293102949,\n",
       " 0.00021550226650750537,\n",
       " 0.0006280002898670434,\n",
       " 0.0010405004186839584,\n",
       " 0.0014530004163706605,\n",
       " 0.0018655003475774624,\n",
       " 0.00227800028706573,\n",
       " 0.0026905002443281174,\n",
       " 0.003103000222694506,\n",
       " 0.003515500213239998,\n",
       " 0.003928000218672126,\n",
       " 0.004340500196160263,\n",
       " 0.004753000168252704,\n",
       " 0.005165500137625075,\n",
       " 0.005578000105889973,\n",
       " 0.0059905000860680435,\n",
       " 0.006403000101109147,\n",
       " 0.006815500108666007,\n",
       " 0.007228000118085907,\n",
       " 0.007640500127121556,\n",
       " 0.008053000134692718,\n",
       " 0.00846550014087623,\n",
       " 0.008878000147508036,\n",
       " 0.009290500155403177,\n",
       " 0.009703000163788769,\n",
       " 0.010115500172578038,\n",
       " 0.010528000181801278,\n",
       " 0.010940500191540007,\n",
       " 0.011353000202052654,\n",
       " 0.011765500213654875,\n",
       " 0.012178000226729054,\n",
       " 0.012590500241741494,\n",
       " 0.01300300025926872,\n",
       " 0.013415500280025477,\n",
       " 0.01382800030486914,\n",
       " 0.014240500334725443,\n",
       " 0.014653000370328777,\n",
       " 0.01506550041398442,\n",
       " 0.015478000476533839,\n",
       " 0.015890500540825733,\n",
       " 0.016303000563309394,\n",
       " 0.016715500433308363,\n",
       " 0.017128000063780176,\n",
       " 0.01754050015601612,\n",
       " 0.01881100001073741,\n",
       " 0.046036000045805985,\n",
       " 0.07326100051609986,\n",
       " 0.10048600031577512,\n",
       " 0.12771100036388505,\n",
       " 0.15493600035358612,\n",
       " 0.18216100031170462,\n",
       " 0.2093860002769945,\n",
       " 0.23661100025408247,\n",
       " 0.26383600024058146,\n",
       " 0.29106100022910497,\n",
       " 0.31828600022011766,\n",
       " 0.34551100022016584,\n",
       " 0.37273600023164666,\n",
       " 0.3999610003398915,\n",
       " 0.42718600064601203,\n",
       " 0.45441100118524624,\n",
       " 0.4816360021046804]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[sparse_mean_bound(p[i], regions_binary(ra=1, rd=3, pf_plus=0.01, pf_minus=0.6), type=\"lower\")\n",
    " for i in range(len(p))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "p_corrected = clopper_pearson_lower(p * 2000, 2000, alpha=0.001 / (150 + 10))\n",
    "sparse_df = pd.DataFrame()\n",
    "sparse_df[\"p\"] = p\n",
    "sparse_df[\"p_corrected\"] = p_corrected\n",
    "sparse_df[\"ra0rd2_low\"] = np.array([\n",
    "        sparse_mean_bound(p[i], regions_binary(ra=0, rd=2, pf_plus=0.01, pf_minus=0.6), type=\"lower\")\n",
    "        for i in range(len(p))])\n",
    "sparse_df[\"ra0rd3_low\"] = np.array([\n",
    "        sparse_mean_bound(p[i], regions_binary(ra=0, rd=3, pf_plus=0.01, pf_minus=0.6), type=\"lower\")\n",
    "        for i in range(len(p))])\n",
    "sparse_df[\"ra1rd3_low\"] = np.array([\n",
    "        sparse_mean_bound(p[i], regions_binary(ra=1, rd=3, pf_plus=0.01, pf_minus=0.6), type=\"lower\")\n",
    "        for i in range(len(p))])\n",
    "sparse_df[\"ra0rd2_up\"] = np.array([\n",
    "        sparse_mean_bound(p[i], regions_binary(ra=0, rd=2, pf_plus=0.01, pf_minus=0.6), type=\"upper\")\n",
    "        for i in range(len(p))])\n",
    "sparse_df[\"ra0rd3_up\"] = np.array([\n",
    "        sparse_mean_bound(p[i], regions_binary(ra=0, rd=3, pf_plus=0.01, pf_minus=0.6), type=\"upper\")\n",
    "        for i in range(len(p))])\n",
    "sparse_df[\"ra1rd3_up\"] = np.array([\n",
    "        sparse_mean_bound(p[i], regions_binary(ra=1, rd=3, pf_plus=0.01, pf_minus=0.6), type=\"upper\")\n",
    "        for i in range(len(p))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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>p</th>\n",
       "      <th>p_corrected</th>\n",
       "      <th>ra0rd2_low</th>\n",
       "      <th>ra0rd3_low</th>\n",
       "      <th>ra1rd3_low</th>\n",
       "      <th>ra0rd2_up</th>\n",
       "      <th>ra0rd3_up</th>\n",
       "      <th>ra1rd3_up</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.05</td>\n",
       "      <td>0.030848</td>\n",
       "      <td>0.000031</td>\n",
       "      <td>7.813370e-07</td>\n",
       "      <td>4.737331e-07</td>\n",
       "      <td>0.136125</td>\n",
       "      <td>0.224606</td>\n",
       "      <td>0.518364</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.06</td>\n",
       "      <td>0.038820</td>\n",
       "      <td>0.000037</td>\n",
       "      <td>9.377567e-07</td>\n",
       "      <td>5.683545e-07</td>\n",
       "      <td>0.163350</td>\n",
       "      <td>0.269527</td>\n",
       "      <td>0.545589</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.07</td>\n",
       "      <td>0.046980</td>\n",
       "      <td>0.000044</td>\n",
       "      <td>7.187657e-06</td>\n",
       "      <td>4.750135e-06</td>\n",
       "      <td>0.190575</td>\n",
       "      <td>0.314449</td>\n",
       "      <td>0.572814</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.08</td>\n",
       "      <td>0.055290</td>\n",
       "      <td>0.000050</td>\n",
       "      <td>1.750007e-05</td>\n",
       "      <td>1.100005e-05</td>\n",
       "      <td>0.217800</td>\n",
       "      <td>0.359370</td>\n",
       "      <td>0.600039</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.09</td>\n",
       "      <td>0.063726</td>\n",
       "      <td>0.000056</td>\n",
       "      <td>2.781386e-05</td>\n",
       "      <td>1.725005e-05</td>\n",
       "      <td>0.245025</td>\n",
       "      <td>0.404291</td>\n",
       "      <td>0.627264</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>86</th>\n",
       "      <td>0.91</td>\n",
       "      <td>0.877964</td>\n",
       "      <td>0.754975</td>\n",
       "      <td>5.957088e-01</td>\n",
       "      <td>3.727360e-01</td>\n",
       "      <td>0.999944</td>\n",
       "      <td>0.999972</td>\n",
       "      <td>0.999983</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>87</th>\n",
       "      <td>0.92</td>\n",
       "      <td>0.889384</td>\n",
       "      <td>0.782200</td>\n",
       "      <td>6.406300e-01</td>\n",
       "      <td>3.999610e-01</td>\n",
       "      <td>0.999950</td>\n",
       "      <td>0.999982</td>\n",
       "      <td>0.999989</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>88</th>\n",
       "      <td>0.93</td>\n",
       "      <td>0.900929</td>\n",
       "      <td>0.809425</td>\n",
       "      <td>6.855513e-01</td>\n",
       "      <td>4.271860e-01</td>\n",
       "      <td>0.999956</td>\n",
       "      <td>0.999993</td>\n",
       "      <td>0.999995</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>89</th>\n",
       "      <td>0.94</td>\n",
       "      <td>0.912625</td>\n",
       "      <td>0.836650</td>\n",
       "      <td>7.304725e-01</td>\n",
       "      <td>4.544110e-01</td>\n",
       "      <td>0.999963</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>0.999999</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>90</th>\n",
       "      <td>0.95</td>\n",
       "      <td>0.924506</td>\n",
       "      <td>0.863875</td>\n",
       "      <td>7.753938e-01</td>\n",
       "      <td>4.816360e-01</td>\n",
       "      <td>0.999969</td>\n",
       "      <td>0.999999</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>91 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       p  p_corrected  ra0rd2_low    ra0rd3_low    ra1rd3_low  ra0rd2_up  \\\n",
       "0   0.05     0.030848    0.000031  7.813370e-07  4.737331e-07   0.136125   \n",
       "1   0.06     0.038820    0.000037  9.377567e-07  5.683545e-07   0.163350   \n",
       "2   0.07     0.046980    0.000044  7.187657e-06  4.750135e-06   0.190575   \n",
       "3   0.08     0.055290    0.000050  1.750007e-05  1.100005e-05   0.217800   \n",
       "4   0.09     0.063726    0.000056  2.781386e-05  1.725005e-05   0.245025   \n",
       "..   ...          ...         ...           ...           ...        ...   \n",
       "86  0.91     0.877964    0.754975  5.957088e-01  3.727360e-01   0.999944   \n",
       "87  0.92     0.889384    0.782200  6.406300e-01  3.999610e-01   0.999950   \n",
       "88  0.93     0.900929    0.809425  6.855513e-01  4.271860e-01   0.999956   \n",
       "89  0.94     0.912625    0.836650  7.304725e-01  4.544110e-01   0.999963   \n",
       "90  0.95     0.924506    0.863875  7.753938e-01  4.816360e-01   0.999969   \n",
       "\n",
       "    ra0rd3_up  ra1rd3_up  \n",
       "0    0.224606   0.518364  \n",
       "1    0.269527   0.545589  \n",
       "2    0.314449   0.572814  \n",
       "3    0.359370   0.600039  \n",
       "4    0.404291   0.627264  \n",
       "..        ...        ...  \n",
       "86   0.999972   0.999983  \n",
       "87   0.999982   0.999989  \n",
       "88   0.999993   0.999995  \n",
       "89   0.999999   0.999999  \n",
       "90   0.999999   1.000000  \n",
       "\n",
       "[91 rows x 8 columns]"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sparse_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "sparse_df.to_csv(\"sparse_df.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.25"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "smoothing_sigma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.25"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gauss_df = pd.DataFrame()\n",
    "gauss_df[\"p\"] = p\n",
    "gauss_df[\"p_corrected\"] = p_corrected\n",
    "\n",
    "gauss_df[\"r12_low\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.12, sigma=smoothing_sigma, scheme=\"guass\", type=\"lower\")\n",
    "gauss_df[\"r12_up\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.12, sigma=smoothing_sigma, scheme=\"guass\", type=\"upper\")\n",
    "gauss_df[\"r25_low\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.25, sigma=smoothing_sigma, scheme=\"guass\", type=\"lower\")\n",
    "gauss_df[\"r25_up\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.25, sigma=smoothing_sigma, scheme=\"guass\", type=\"upper\")\n",
    "smoothing_sigma\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "gauss_df.to_csv(\"gauss_df.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.12203912, 0.14123805, 0.15967585, 0.17746434, 0.19468649,\n",
       "       0.2114062 , 0.22767423, 0.24353179, 0.25901304, 0.27414672,\n",
       "       0.28895731, 0.30346595, 0.31769103, 0.33164872, 0.34535332,\n",
       "       0.35881755, 0.37205283, 0.38506945, 0.3978767 , 0.41048305,\n",
       "       0.42289621, 0.43512324, 0.44717064, 0.45904438, 0.47074999,\n",
       "       0.48229258, 0.49367689, 0.50490735, 0.51598805, 0.52692284,\n",
       "       0.53771531, 0.54836881, 0.55888648, 0.56927128, 0.57952598,\n",
       "       0.58965317, 0.59965531, 0.6095347 , 0.61929352, 0.62893379,\n",
       "       0.63845745, 0.6478663 , 0.65716206, 0.66634632, 0.67542059,\n",
       "       0.6843863 , 0.69324478, 0.70199727, 0.71064496, 0.71918891,\n",
       "       0.72763017, 0.73596967, 0.7442083 , 0.75234685, 0.76038606,\n",
       "       0.76832662, 0.77616913, 0.78391413, 0.79156211, 0.79911346,\n",
       "       0.80656854, 0.81392763, 0.82119093, 0.82835859, 0.83543068,\n",
       "       0.8424072 , 0.84928805, 0.85607308, 0.86276204, 0.86935459,\n",
       "       0.87585028, 0.88224858, 0.88854884, 0.89475027, 0.90085196,\n",
       "       0.90685285, 0.9127517 , 0.91854711, 0.92423744, 0.92982083,\n",
       "       0.9352951 , 0.94065778, 0.945906  , 0.95103641, 0.9560451 ,\n",
       "       0.96092745, 0.96567795, 0.97028991, 0.97475511, 0.97906317,\n",
       "       0.98320059])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "VoteCP.compute_threat_p(p=p, r=0.12, sigma=0.25, scheme=\"guass\", type=\"upper\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "exact_l1 = pd.DataFrame()\n",
    "exact_l1[\"p\"] = p\n",
    "exact_l1[\"p_corrected\"] = p_corrected\n",
    "exact_l1[\"r25_low\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.25, sigma=smoothing_sigma, scheme=\"exact\", type=\"lower\")\n",
    "exact_l1[\"r25_up\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.25, sigma=smoothing_sigma, scheme=\"exact\", type=\"upper\")\n",
    "exact_l1[\"r5_low\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.5, sigma=smoothing_sigma, scheme=\"exact\", type=\"lower\")\n",
    "exact_l1[\"r5_up\"] = VoteCP.compute_threat_p(\n",
    "    p=p, r=0.5, sigma=smoothing_sigma, scheme=\"exact\", type=\"upper\")\n",
    "\n",
    "\n",
    "exact_l1.to_csv(\"exact_l1.csv\", index=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.05, 0.06, 0.07, 0.08, 0.09, 0.1 , 0.11, 0.12, 0.13, 0.14, 0.15,\n",
       "       0.16, 0.17, 0.18, 0.19, 0.2 , 0.21, 0.22, 0.23, 0.24, 0.25, 0.26,\n",
       "       0.27, 0.28, 0.29, 0.3 , 0.31, 0.32, 0.33, 0.34, 0.35, 0.36, 0.37,\n",
       "       0.38, 0.39, 0.4 , 0.41, 0.42, 0.43, 0.44, 0.45, 0.46, 0.47, 0.48,\n",
       "       0.49, 0.5 , 0.51, 0.52, 0.53, 0.54, 0.55, 0.56, 0.57, 0.58, 0.59,\n",
       "       0.6 , 0.61, 0.62, 0.63, 0.64, 0.65, 0.66, 0.67, 0.68, 0.69, 0.7 ,\n",
       "       0.71, 0.72, 0.73, 0.74, 0.75, 0.76, 0.77, 0.78, 0.79, 0.8 , 0.81,\n",
       "       0.82, 0.83, 0.84, 0.85, 0.86, 0.87, 0.88, 0.89, 0.9 , 0.91, 0.92,\n",
       "       0.93, 0.94, 0.95])"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "p, compute_rho_for_many(\n",
    "    regions=regions_binary(ra=1, rd=3, pf_plus=0.01, pf_minus=0.6),\n",
    "    p_emps=p), compute_rho_for_many(\n",
    "    regions=regions_binary(ra=0, rd=3, pf_plus=0.01, pf_minus=0.6),\n",
    "    p_emps=p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "import cvxpy as convex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sparse_smoothing.cert import regions_binary\n",
    "def sparse_mean_bound(p_emp,  \n",
    "                      reg, type=\"lower\",\n",
    "                      eta=0.05, bonferroni_tasks=1, error_correction=True):\n",
    "    \n",
    "\n",
    "    a = 0.0\n",
    "    b = 1\n",
    "\n",
    "    h = convex.Variable(len(reg))\n",
    "    if type == \"lower\":\n",
    "        result = convex.Problem(convex.Minimize(convex.sum(h @ reg[:, 1])), [h@reg[:, 0] == p_emp, h >= a, h<=b]).solve()\n",
    "    elif type == \"upper\":\n",
    "        result = convex.Problem(convex.Maximize(convex.sum(h @ reg[:, 1])), [h@reg[:, 0] == p_emp, h >= a, h<=b]).solve()\n",
    "    return result\n",
    "# def sparse_mean_bound(p_emp,  \n",
    "#                       pf_plus_att, pf_minus_att, ra=10, rd=1, type=\"lower\",\n",
    "#                       eta=0.05, bonferroni_tasks=1, error_correction=True):\n",
    "    \n",
    "\n",
    "#     reg = regions_binary(ra=ra, rd=rd, pf_plus=pf_plus_att, pf_minus=pf_minus_att)\n",
    "#     a = 0.0\n",
    "#     b = 1\n",
    "\n",
    "#     h = convex.Variable(len(reg))\n",
    "#     if type == \"lower\":\n",
    "#         result = convex.Problem(convex.Minimize(convex.sum(h)), [h>=reg[:, 0]*a, h<=reg[:, 0]*b, h@reg[:, 2] == p_emp]).solve()\n",
    "#     elif type == \"upper\":\n",
    "#         result = convex.Problem(convex.Maximize(convex.sum(h)), [h>=reg[:, 1]*a, h<=reg[:, 1]*b, h@reg[:, 2] == p_emp]).solve()\n",
    "#     return result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.18650542191391759"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_emp = 0.89\n",
    "regs = regions_binary(ra=3, rd=1, pf_plus=0.01, pf_minus=0.6)\n",
    "regs_inverted = regions_binary(ra=1, rd=3, pf_plus=0.01, pf_minus=0.6)\n",
    "\n",
    "p_lower = sparse_mean_bound(p_emp=p_emp, reg=regs, type=\"lower\")\n",
    "p_lower"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1545a00a0760>]"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(regs[:, 0])\n",
    "plt.plot(regs_inverted[:, 1][::-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "mpfr('0.18650541781450872')"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_rho(regions=regs, p_emp=p_emp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8900000108238404"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_higher = sparse_mean_bound(p_emp=p_lower, reg=regs_inverted, type=\"upper\")\n",
    "p_higher"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'p_low' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Input \u001b[0;32mIn [65]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m p_high_low \u001b[38;5;241m=\u001b[39m sparse_mean_bound(pf_minus_att\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0.5\u001b[39m, pf_plus_att\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0.5\u001b[39m, p_emp\u001b[38;5;241m=\u001b[39m\u001b[43mp_low\u001b[49m, ra\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m3\u001b[39m, rd\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m3\u001b[39m, \u001b[38;5;28mtype\u001b[39m\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mupper\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'p_low' is not defined"
     ]
    }
   ],
   "source": [
    "p_high_low = sparse_mean_bound(pf_minus_att=0.5, pf_plus_att=0.5, p_emp=p_low, ra=3, rd=3, type=\"upper\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.9000000000000118, 0.9000000000000236)"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_low, p_high_low"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1475ddb6efa0>]"
      ]
     },
     "execution_count": 82,
     "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": [
    "reg = regions_binary(ra=3, rd=3, pf_plus=0.5, pf_minus=0.5)\n",
    "plt.plot(reg[:, 0])\n",
    "plt.plot(reg[:, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1475ddd39e80>]"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(reg[:, 0] / reg[:, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "ra = 2\n",
    "def unpackbits(x, num_bits):\n",
    "    xshape = list(x.shape)\n",
    "    x = x.reshape([-1, 1])\n",
    "    mask = 2**torch.arange(num_bits).reshape([1, num_bits])\n",
    "    return (x & mask).to(bool).to(int).reshape(xshape + [num_bits])\n",
    "\n",
    "d = 9\n",
    "nf = 2**d\n",
    "binary_matrix = unpackbits(torch.arange(nf), d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0, 0, 0,  ..., 0, 0, 0],\n",
       "        [1, 0, 0,  ..., 0, 0, 0],\n",
       "        [0, 1, 0,  ..., 0, 0, 0],\n",
       "        ...,\n",
       "        [1, 0, 1,  ..., 1, 1, 1],\n",
       "        [0, 1, 1,  ..., 1, 1, 1],\n",
       "        [1, 1, 1,  ..., 1, 1, 1]])"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "binary_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "rd = d-ra\n",
    "x = torch.Tensor(np.repeat([0, 1], [ra, rd])).to(int)\n",
    "y = 1 - x\n",
    "def comp(x, pp, pm, binary_matrix):\n",
    "    pp = torch.DoubleTensor([pp])\n",
    "    pm = torch.DoubleTensor([pm])\n",
    "    probs = (1-pp)**((binary_matrix == 0) & (x == 0)).sum(1) * pm**((binary_matrix == 0) & (x == 1)).sum(1) * pp**((binary_matrix == 1) & (x == 0)).sum(1) * (1-pm)**((binary_matrix == 1) & (x == 1)).sum(1)    \n",
    "    return probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "pp = 0.01\n",
    "pm = 0.6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [],
   "source": [
    "s = comp(x, pp, pm, binary_matrix)\n",
    "stilde = comp(y, pp, pm, binary_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_inverted = torch.Tensor(np.repeat([0, 1], [rd, ra])).to(int)\n",
    "y_inverted = 1-x_inverted\n",
    "t = comp(x_inverted, pp, pm, binary_matrix)\n",
    "ttilde = comp(y_inverted, pp, pm, binary_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "mpfr('0.20854398530762164')"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_rho(regions=regs, p_emp=0.95)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [],
   "source": [
    "h = convex.Variable(len(s))\n",
    "\n",
    "p_low = convex.Problem(convex.Minimize(convex.sum(h @ stilde)), [h@s == 0.95, h >= 0, h<=1]).solve()\n",
    "h_lower = h.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9499999984129625"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "h = convex.Variable(len(s))\n",
    "p_high = convex.Problem(convex.Maximize(convex.sum(h @ ttilde)), [h@t == p_low, h >= 0, h<=1]).solve()\n",
    "h_upper = h.value\n",
    "p_high"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.021845580773297364, 0.021845580773296753)"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_perm = torch.Tensor(np.random.permutation(x))\n",
    "y_perm = 1-x_perm\n",
    "\n",
    "convex.Problem(convex.Minimize(convex.sum(h @ comp(y_perm, pp, pm, binary_matrix))), [h@ comp(x_perm, pp, pm, binary_matrix) == 0.95, h >= 0, h<=1]).solve(), p_low "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9499999984129622"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_perm = torch.Tensor(np.random.permutation(x_inverted))\n",
    "y_perm = 1-x_perm\n",
    "convex.Problem(convex.Maximize(convex.sum(h @ comp(y_perm, pp, pm, binary_matrix))), [h@ comp(x_perm, pp, pm, binary_matrix) == p_low, h >= 0, h<=1]).solve()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x15454b0ba040>]"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(h_lower)\n",
    "plt.plot(h_upper[::-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x15454b1e4100>]"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
