{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c02fc38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2a226ade",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "print(f\"Old working dir {os.getcwd()}\")\n",
    "os.chdir('../')\n",
    "print(f\"New working dir {os.getcwd()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "67d1cd8b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "%matplotlib inline\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2fd7634c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import norm, multivariate_normal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2cbac04a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def _make_xy_dataloader(X: np.ndarray, Y: np.ndarray, batch_size: int, dtype=torch.float64) -> DataLoader:\n",
    "    dataset = TensorDataset(torch.tensor(X, dtype=dtype), torch.tensor(Y, dtype=dtype))\n",
    "    dataloader = DataLoader(dataset, batch_size=batch_size)\n",
    "    return dataloader\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "cb83e751",
   "metadata": {},
   "outputs": [],
   "source": [
    "from infrastructure.classes import TrainParameters\n",
    "from pushforward_operators import NeuralQuantileRegression, AmortizedNeuralQuantileRegression\n",
    "\n",
    "\n",
    "class OurCVQRegressor:\n",
    "\n",
    "    def __init__(\n",
    "        self,\n",
    "        feature_dimension: int,\n",
    "        response_dimension: int,\n",
    "        hidden_dimension: int,\n",
    "        number_of_hidden_layers: int,\n",
    "        batch_size: int,\n",
    "        n_epochs: int,\n",
    "        learning_rate: float = 0.01,\n",
    "        dtype=torch.float64,\n",
    "    ):\n",
    "        self.feature_dimension: int = feature_dimension\n",
    "        self.response_dimension: int = response_dimension\n",
    "        self.hidden_dimension: int = hidden_dimension\n",
    "        self.number_of_hidden_layers: int = number_of_hidden_layers\n",
    "        self.batch_size: int = batch_size\n",
    "        self.n_epochs: int = n_epochs\n",
    "        self.learning_rate: float = learning_rate\n",
    "        self.dtype = dtype\n",
    "        self.model = NeuralQuantileRegression(\n",
    "            feature_dimension=self.feature_dimension,\n",
    "            response_dimension=self.response_dimension,\n",
    "            hidden_dimension=self.hidden_dimension,\n",
    "            number_of_hidden_layers=self.number_of_hidden_layers,\n",
    "            potential_to_estimate_with_neural_network=\"u\",\n",
    "        ).to(self.dtype)\n",
    "\n",
    "    def fit(self, X: np.ndarray, Y:np.ndarray):\n",
    "        dataloader = _make_xy_dataloader(X, Y, batch_size=self.batch_size, dtype=self.dtype)\n",
    "        train_parameters = TrainParameters(number_of_epochs_to_train=self.n_epochs, \n",
    "                                           optimizer_parameters=dict(\n",
    "                                                lr=self.learning_rate,\n",
    "                                            ),\n",
    "                                            warmup_iterations=10,\n",
    "                                           scheduler_parameters={\"eta_min\": 0.},\n",
    "                                           verbose=True)\n",
    "        self.model.fit(dataloader, train_parameters=train_parameters,)\n",
    "\n",
    "    def predict_mean(self, X):\n",
    "        n = X.shape[0]\n",
    "        U = torch.zeros((n, self.response_dimension), dtype=self.dtype)\n",
    "        X_tensor = torch.tensor(X, dtype=self.dtype)\n",
    "        #dataset = TensorDataset(X_tensor, U)\n",
    "        #dataloader = DataLoader(dataset, batch_size=self.batch_size, shuffle=False)\n",
    "        Y = self.model.push_u_given_x(x=X_tensor, u=U)\n",
    "        return Y.numpy(force=True)\n",
    "    \n",
    "    def predict_quantile(self, X, Y):\n",
    "        return self.model.push_y_given_x(y=torch.tensor(Y), \n",
    "                                         x=torch.tensor(X)).numpy(force=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c53d8d55",
   "metadata": {},
   "outputs": [],
   "source": [
    "from conformal.real_datasets.reproducible_split import get_dataset_split, DatasetSplit\n",
    "from utils.network import get_total_number_of_parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4fcc10c0",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = 0\n",
    "dataset_name = \"blog\"\n",
    "# dataset_name = \"rf1\"\n",
    "\n",
    "ds = get_dataset_split(name=dataset_name, seed=seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ac52b51c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.ensemble import RandomForestRegressor, VotingRegressor\n",
    "from sklearn.model_selection import KFold\n",
    "from sklearn.metrics import mean_squared_error\n",
    "\n",
    "from metrics.wsc import wsc_unbiased"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8fd3d1df",
   "metadata": {},
   "source": [
    "## Algorithms according to section 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "77db522a",
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha = 0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2546f660",
   "metadata": {},
   "outputs": [],
   "source": [
    "from IPython.display import display, Markdown"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "43007395",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((48397, 100), (48397, 2))"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds.X_train.shape, ds.Y_train.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "157bc3c2",
   "metadata": {},
   "source": [
    "### Part 1: Train base model $\\tilde{Q}_{Y|X}^{-1}(X, Y)$ on train set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "09881362",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 8504, number of training samples: 48397.\n"
     ]
    }
   ],
   "source": [
    "reg = OurCVQRegressor(\n",
    "    feature_dimension=100,\n",
    "    response_dimension=2,\n",
    "    hidden_dimension=16,\n",
    "    number_of_hidden_layers=4,\n",
    "    batch_size=512,\n",
    "    n_epochs=100,\n",
    "    learning_rate=1e-2\n",
    ")\n",
    "\n",
    "print(f\"Number of parameters: {get_total_number_of_parameters(reg.model)}, number of training samples: {ds.n_train}.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "268a882e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((48397, 100), (48397, 2))"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds.X_train.shape, ds.Y_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "4f401dbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_savepath = f\"neural_quantile_regression_log_u.pth\"\n",
    "if not os.path.isfile(model_savepath):\n",
    "    reg.fit(ds.X_train, ds.Y_train)\n",
    "    reg.model.save(model_savepath)\n",
    "    reg.model.eval()\n",
    "else:\n",
    "    reg.model.load(model_savepath)\n",
    "    reg.model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "615e2f58",
   "metadata": {},
   "outputs": [],
   "source": [
    "reg.model.to(torch.tensor(ds.X_cal))\n",
    "quantiles_cal = reg.predict_quantile(ds.X_cal, ds.Y_cal)\n",
    "quantiles_test = reg.predict_quantile(ds.X_test, ds.Y_test)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "93e761e6",
   "metadata": {},
   "source": [
    "Diagnstic plots for quantiles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "371e053b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABR8AAAHDCAYAAACtcm2bAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAA6ptJREFUeJzs3Qd4VFXaB/D/zCST3ntCQugQSmgSARFUEMsq4KJYEERBRVldY0EsYMcGoi6CIAi2TyxYUQRRBATpnRAIqaT3nkwyM99zzmQCgQSSMDX5/57nPnPvnTt3Ttjd7Ml73/O+Cr1erwcRERERERERERGRiSlNfUMiIiIiIiIiIiIigcFHIiIiIiIiIiIiMgsGH4mIiIiIiIiIiMgsGHwkIiIiIiIiIiIis2DwkYiIiIiIiIiIiMyCwUciIiIiIiIiIiIyCwYfiYiIiIiIiIiIyCwYfCQiIiIiIiIiIiKzYPCRiIiIiIiIiIiIzILBRyJq10aNGiU3o+TkZCgUCqxatar+3D333AN3d3dY2wsvvCDHRkRERERERGQvGHwkIrtz6tQpPPDAA+jcuTOcnZ3h6emJ4cOH491330VlZSXsWUVFhQwybt682dpDISIiIiIiIrpkDpd+CyIiy1m3bh1uvfVWODk5YcqUKejTpw80Gg22bduGJ598EkePHsWyZctaff+OHTvKAKajoyOsFXx88cUX5f7ZGZnCc889h6efftoq4yIiIiIiIiJqDQYfichuJCUl4fbbb5cBwj/++AMhISH17z388MNISEiQwclLIZY1i2xKU6mtrYVOp4Narb7kezk4OMiNiIiIiIiIyF5w2TUR2Y0333wTZWVlWLFiRYPAo1HXrl3x6KOPyv2PP/4YV199NQIDA2WWZFRUFJYsWXLR72is5qNRYmIixo4dCzc3N4SGhuKll16CXq8/77Nvv/02Fi1ahC5dusjvPnbsmMzOnDt3LgYNGgQvLy95jxEjRuDPP/9s8PmAgAC5L7Ifxb3EJpZhN1XzUQQ3X3755frvioyMxDPPPIPq6uoG14nz//rXv2SG6JAhQ2SAVSxb/+STT5rxL09ERERERETUOkyhISK78dNPP8mA2bBhwy56rQg09u7dGzfffLPMFhSffeihh2QWosiSbCmtVovrrrsOl19+uQyCrl+/HvPmzZPBPxGEPJsIfFZVVeH++++XAUFfX1+UlJTgo48+wh133IEZM2agtLRUBlFFMHPXrl3o37+/DDyKcc+cORMTJkzALbfcIu/Xr1+/Jsc1ffp0rF69GhMnTsTjjz+OnTt3Yv78+YiLi8N3333X4FqRGSquu++++zB16lSsXLlSNtMRAVHxb0VERERERERkagw+EpFdEMG79PR0jBs3rlnX//XXX3Bxcak/njVrlgweLly4sFXBRxFMFJ9/77335LEIZN50001444038Mgjj8Df37/+2tOnT8tAnzGL0Ri8FJmNZy+/FkHInj174v3335eBSJENKYKDIvgoAo6TJ0++4JgOHjwoA48iALl8+fL6cYlsT5F9KbIqr7rqqvrr4+PjsWXLFplxKdx2220IDw+XwVJxPREREREREZGpcdk1EdlN8FHw8PBo1vVnBx6Li4uRl5eHkSNHyqXT4rg1RADTSCx/FsdiOfXvv//e4Lp///vfDQKPgkqlqg88iuzLgoICmTU5ePBg7Nu3r1Xj+eWXX+RrbGxsg/MiA1I4t/6lWHpuDDwKYow9evSQ/yZERERERERE5sDMRyKyC56envJVLFdujr///lsui96xY4fsIH02EXwUdRdbQqlUyiXfZ+vevbt8FRmNZ+vUqVOj9xBZigsWLMDx48dRU1Nz0esvJiUlRY5L1Lo8W3BwMLy9veX7Z4uIiDjvHj4+PigsLGzV9xMRERERERFdDDMfichugo+iycuRI0cueu2pU6dwzTXXyGxHscxaZABu3LgRjz32WH3moTmdnXVp9Nlnn8n6iqIxjFhiLWpGijGJpjiXOp5zm9A0RWRfNubspjlEREREREREpsTMRyKyG6Jb87Jly2Q249ChQ5u8TjSXEd2ef/zxxwbZfmd3lm4pESAUy5ON2Y7CiRMn6jtJX8w333wjMyfXrl3bIFgosjNbE0gUOnbsKMd18uRJ9OrVq/58dnY2ioqK5PtERERERERE1sTMRyKyG0899ZRsyiIarIgAW2MZj++++259ht/ZGX1iqbVorHIp/ve//9Xvi3uLY0dHR5lleTGNjUl0phaB1LO5urrKVxE8vJgbbrhBvi5atKjBeZHtKdx4440XvQcRERERERGROTHzkYjshliy/MUXX2DSpEky02/KlCno06ePbPqyfft2fP3113Jps2jAIpq7iG7UDzzwAMrKymQ3aNEFOjMzs1Xf7ezsLJdKT506FTExMfj111/lcu5nnnnmvOYyTWVtiqzHCRMmyKBgUlISli5dKpvAiPGdvWRbnFuzZo3MsvT19ZU/o9jOFR0dLccjskFFsFI01Nm1a5esLTl+/PgGna6JiIiIiIiIrIHBRyKyKzfffDMOHTqEt956Cz/88AOWLFkCJycn9OvXTzZzmTFjhjwWy5yfe+45PPHEE7IBy8yZM2WQ8N57723V94rMRRF8FPd58sknZddtsWR67ty5zfq8CIpmZWXhww8/xG+//SYDjKIOpAiYbt68ucG1H330Ef7zn//IGpUisCq+p7Hgo/FasZx71apV+O677+TPOmfOnPOWcxMRERERERFZg0LPTgNERERERERERERkBqz5SERERERERERERGbB4CMRERERERERERGZBYOPREREREREREREZBYMPhIREREREREREZFZMPhIREREREREREREZsHgIxEREREREREREZmFA9oZnU6HjIwMeHh4QKFQWHs4RERERC2m1+tRWlqK0NBQKJV8lmyPOCclIiKi9jIfbXfBRzHJCw8Pt/YwiIiIiC5ZWloaOnToYO1hUCtwTkpERETtZT7a7oKP4umy8R/H09PT2sMhIiIiarGSkhIZuDLOa8j+cE5KRERE7WU+2u6Cj8ZlLWKSx4keERER2TMu17VfnJMSERFRe5mPskgQERERERERERERmQWDj0RERERERERERGQWDD4SERERERERERGRWbS7mo9ERETUNmi1WtTU1KAtcnR0hEqlsvYwiIiIiKidzkcFtVoNpfLS8xYZfCQiIiK7otfrkZWVhaKiIrRl3t7eCA4OZlMZIiIiIhvTXuajSqUSnTp1kkHIS8HgIxEREdkV40QvMDAQrq6ubS44JyazFRUVyMnJkcchISHWHhIRERERtaP5qKDT6ZCRkYHMzExERERc0s/I4CMRERHZ1dIW40TPz88PbZWLi4t8FQFI8bNyCTYRERGRbWgv81EhICBABiBra2tlWaDWYsMZIiIishvGmjriCXNbZ/wZ23IdISIiIiJ7057mo+q65dYi4HopGHwkIiIiu9MWl7a0x5+RiIiIyF61h7mawkQ/I4OPREREREREREREZBas+UhERERtQmpqKvLy8izyXf7+/rLwNhERERGRNeaj9jQnZfCRiIiI2sREr1evXrJLtCWIGj9xcXEtnuwtXrwYb731luyQGB0djffffx9Dhgwx2ziJiIiIqG3OR+1pTsrgIxEREdk98YRZTPSefmMxIjp3M+t3pSaexOuzH5bf2ZKJ3po1axAbG4ulS5ciJiYGixYtwtixYxEfHy+7JRIRERGR/bLkfNTe5qQMPhIREVGbISZ63aL6wRYtXLgQM2bMwLRp0+SxmPCtW7cOK1euxNNPP23t4RERERFRG5+PWmtOyoYzRERERGam0Wiwd+9ejB49uv6cUqmUxzt27LDq2IiIiIiofdBYaU7KzEcianO0Wq2st2FKIo1dpVKZ9J5E1H6I5TDid1NQUFCD8+L4+PHjVhsXERGZ54/7Q4cOmfy+/fr1g1qtNvl9iaj9yLPSnJTBRyJqc0TgMe3vrxEeEmCS+6Vl5gK4FZ06dTLJ/YiIiIio7RKBx2ObvkRUl3CT3fPYqTT5OnjwYJPdk4jIUhh8JKI2SQQeO3UItvYwiIgkf39/mT2dnZ3d4Lw4Dg7m7yoiorZGBB4H9+1u7WEQEdnEnJQ1H4mIiIjMTCyTGzRoEDZt2lR/TqfTyeOhQ4dadWxERERE1D6orTQnZeYjERERkQXExsZi6tSpcsnckCFDsGjRIpSXl9d3GiQiIiIiaotzUgYfiYiIqM1ITTxps98xadIk5ObmYu7cucjKykL//v2xfv368wp+ExEREZH9ssR81N7mpAw+EhERUZuoX+Pq6orXZz9ske8T3yW+s6VmzZolNyIiIiJqWyw9H7WnOSmDj0RERGT3IiIiEBcXh7y8PIt8n5jkie8kIiIiIrLGfNSe5qRWDz4uXrwYb731lkz1jI6Oxvvvvy/XnDdFrEVfsmQJUlNT5T/yxIkTMX/+fDg7O1t03ERERGRbxMTLHiZfRERERNQ2cT5qg92u16xZIwtdzps3D/v27ZPBx7FjxyInJ6fR67/44gs8/fTT8noRTV6xYoW8xzPPPGPxsRMREREREREREZENBx8XLlyIGTNmyI46UVFRWLp0qVyvvnLlykav3759O4YPH44777wTkZGRuPbaa3HHHXdg165dFh87ERERERERERER2WjwUaPRYO/evRg9evSZwSiV8njHjh2NfmbYsGHyM8ZgY2JiIn755RfccMMNFhs3ERERERERERER2XjNR1GAU6vVntfKWxwfP3680c+IjEfxuSuuuAJ6vR61tbV48MEHL7jsurq6Wm5GJSUlJvwpiIiIiIiIiIiIyCaXXbfU5s2b8dprr+GDDz6QNSLXrl2LdevW4eWXX27yM6IZjZeXV/0WHh5u0TETERERERERERG1V1bLfBSdqlUqFbKzsxucF8fBwcGNfub555/H3XffjenTp8vjvn37ory8HPfffz+effZZuWz7XHPmzJFNbc7OfGQAkoiIiIiIiIiIqA1nPqrVagwaNAibNm2qP6fT6eTx0KFDG/1MRUXFeQFGEcAUxDLsxjg5OcHT07PBRkRERERERERERG0481EQGYlTp07F4MGDMWTIECxatEhmMoru18KUKVMQFhYml04LN910k+yQPWDAAMTExCAhIUFmQ4rzxiAkERERtU+pqamyNrSlVnBERERY5LuIiIiIyD5Ycj5qT3NSqwYfJ02ahNzcXMydOxdZWVno378/1q9fX9+ERvyHdnam43PPPQeFQiFf09PTERAQIAOPr776qhV/CiIiIrI2MWfo1auXXCVhCa6uroiLi2vRZG/Lli146623sHfvXmRmZuK7777D+PHjzTpOIiIiImqb89HWzEmtNR+1avBRmDVrltyaajBzNgcHB8ybN09uREREREbiCbOY6H321pPo1dm8tZ3jEtMw+cm35He2JPgoVndER0fj3nvvxS233GLWMRIRERFR252PtnZOaq35qNWDj0RERESmIiZ6A3t3hS26/vrr5UZEREREbRfnozbUcIaIiIiIiIiIiIjaNgYfiYiIiIiIiIiIyCwYfCQiIiIiIiIiIiKzYPCRiIiIiIiIiIiIzILBRyIiIiIiIiIiIjILBh+JiIiILKCsrAwHDhyQm5CUlCT3U1NTrT00ArB48WJERkbC2dkZMTEx2LVrV5PXjho1CgqF4rztxhtvtOiYiYiIiOxhPupg1rsTERERWVBcYprNfseePXtw1VVX1R/HxsbK16lTp2LVqlUmGx+13Jo1a+R/HkuXLpWBx0WLFmHs2LGIj49HYGDgedevXbsWGo2m/jg/Px/R0dG49dZbLTxyIiIiao/z0dZ+j7Xmoww+EhERkd3z9/eHq6srJj/5lkW+T3yX+M6WENlyer3ebGOi1lu4cCFmzJiBadOmyWMRhFy3bh1WrlyJp59++rzrfX19Gxx/+eWX8r8TDD4SERG1X5aej7ZmTmqt+SiDj0RERGT3IiIiEBcXh7y8PIt8n5jkie8k+ycyGPfu3Ys5c+bUn1MqlRg9ejR27NjRrHusWLECt99+O9zc3Jq8prq6Wm5GJSUllzhyIiIias/zUXuakzL4SERERG2CmHjZw+SLbIv4A0Gr1SIoKKjBeXF8/Pjxi35e1IY8cuSIDEBeyPz58/Hiiy9e8niJiIjIdnE+2jg2nCEiIiIiaiURdOzbty+GDBlywetEZmVxcXH9lpZmmXpQRERERNbGzEciIiIiarfEciWVSoXs7OwG58VxcHDwBT9bXl4u6z2+9NJLF/0eJycnuRERERG1N8x8JCIiIqJ2S61WY9CgQdi0aVP9OZ1OJ4+HDh16wc9+/fXXso7j5MmTLTBSIiIiIvvEzEciIiKyOyI41Na1h5/RVsTGxmLq1KkYPHiwXD69aNEimdVo7H49ZcoUhIWFybqN5y65Hj9+PPz8/Kw0ciIiIrKW9jBX05uoMzaDj0RERGRXWWqiE3FGRgYCAgLksUKhQFub5IkOzLm5ufJnFT8jmdekSZPkv/fcuXORlZWF/v37Y/369fVNaFJTU+V/FmeLj4/Htm3bsGHDBiuNmoiIiKyhPcxHjXNSMT8SP5ujoyMuBYOPREREZDfERK9Tp07IzMyUE762zNXVVXZLPDfoReYxa9YsuTVm8+bN553r0aOHybIBiIiIyH60p/moQqFAhw4dZH3sS8HgIxEREdkV8XRZBOVqa2uh1WrRFokJnoODQ5t8ik5ERERk79rDfFQQGY+XGngUGHwkIiIiu2Nc/nGpS0CIiIiIiFqD89Hm4zoeIiIiIiIiIiIiMgsGH4mIiIiIiIiIiMgsGHwkIiIiIiIiIiIis2DwkYiIiIiIiIiIiMyCwUciIiIiIiIiIiIyCwYfiYiIiIiIiIiIyCwYfCQiIiIiIiIiIiKzYPCRiIiIiIiIiIiIzILBRyIiIiIiIiIiIjILBh+JiIiIiIiIiIjILBh8JCIiIiIiIiIiIrNg8JGIiIiIiIiIiIjMgsFHIiIiIiIiIiIiMgsGH4mIiIiIiIiIiMgsGHwkIiIiIiIiIiKitht8XLx4MSIjI+Hs7IyYmBjs2rWryWtHjRoFhUJx3nbjjTdadMxERERERERERERk48HHNWvWIDY2FvPmzcO+ffsQHR2NsWPHIicnp9Hr165di8zMzPrtyJEjUKlUuPXWWy0+diIiIiIiIiIiIrLh4OPChQsxY8YMTJs2DVFRUVi6dClcXV2xcuXKRq/39fVFcHBw/bZx40Z5PYOPREREREREREREtsWqwUeNRoO9e/di9OjRZwakVMrjHTt2NOseK1aswO233w43N7dG36+urkZJSUmDjYiIiIiIiIiIiNp48DEvLw9arRZBQUENzovjrKysi35e1IYUy66nT5/e5DXz58+Hl5dX/RYeHm6SsRMREREREREREZGNL7u+FCLrsW/fvhgyZEiT18yZMwfFxcX1W1pamkXHSERERERERERE1F45WPPL/f39ZbOY7OzsBufFsajneCHl5eX48ssv8dJLL13wOicnJ7kRERERERERERFRO8p8VKvVGDRoEDZt2lR/TqfTyeOhQ4de8LNff/21rOc4efJkC4yUiIiIiIiIiIiI7CrzUYiNjcXUqVMxePBguXx60aJFMqtRdL8WpkyZgrCwMFm78dwl1+PHj4efn5+VRk5EREREREREREQ2HXycNGkScnNzMXfuXNlkpn///li/fn19E5rU1FTZAfts8fHx2LZtGzZs2GClURMREREREREREZHNBx+FWbNmya0xmzdvPu9cjx49oNfrLTAyIiIiIiIiIiIiapfdromIiIiIiIiIiMh2MfhIREREREREREREZsHgIxEREREREREREZkFg49ERERERERERERkFgw+EhERERERERERkVkw+EhERERERERERERmweAjERERERERERERmQWDj0REZ6upAtJ2Adpaa4+EiIiIiIiIyO4x+EhEZKTXAVveArYtBE5tsvZoiIiIiIiIiOweg49EREYJvwM5Rw37eSetPRoiIrKgxYsXIzIyEs7OzoiJicGuXbsueH1RUREefvhhhISEwMnJCd27d8cvv/xisfESERER2QsHaw+AiMgmlOUABz4/c1ycas3REBGRBa1ZswaxsbFYunSpDDwuWrQIY8eORXx8PAIDA8+7XqPRYMyYMfK9b775BmFhYUhJSYG3t7dVxk9ERERkyxh8JCISy613LgVqqwGvDkDxaaAkHdDVAkr+miQiausWLlyIGTNmYNq0afJYBCHXrVuHlStX4umnnz7venG+oKAA27dvh6OjozwnsiaJiIiI6Hxcdk1EdHIjkHMMUDkBI54AHFwAnRYozbT2yIiIyMxEFuPevXsxevTo+nNKpVIe79ixo9HP/Pjjjxg6dKhc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",
      "text/plain": [
       "<Figure size 1600x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import expon\n",
    "\n",
    "t_min = min(quantiles_cal.min(), quantiles_test.min())\n",
    "t_max = max(quantiles_cal.max(), quantiles_test.max())\n",
    "t = np.linspace(t_min, t_max, 500)\n",
    "fig, ax = plt.subplots(nrows=1, ncols=2, figsize=(16, 5))\n",
    "p0 = ax[0].plot(t, norm.pdf(t), 'k--', label=\"N(0, 1)\")\n",
    "hp0 = sns.histplot(quantiles_cal, alpha=0.3, stat=\"density\", common_norm=False, kde=True, ax=ax[0])\n",
    "ax[0].set_title(\"Calibration\")\n",
    "ax[0].set_xlim(-5, 5)\n",
    "hp1 = sns.histplot(quantiles_test, alpha=0.3, stat=\"density\", common_norm=False, kde=True, ax=ax[1])\n",
    "p1 = ax[1].plot(t, norm.pdf(t), 'k--', label=\"N(0, 1)\")\n",
    "# ax[1].set_title(\"Test\")\n",
    "ax[1].set_xlim(-5, 5)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "4b9f5193",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import stats\n",
    "\n",
    "def draw_qq_scores(scores, ax):\n",
    "    n, d = scores.shape\n",
    "    for j in range(d):\n",
    "        stats.probplot(\n",
    "            scores[:, j],\n",
    "            dist=\"norm\",\n",
    "            fit=False,\n",
    "            plot=ax,\n",
    "        )\n",
    "        ax.get_lines()[j].set_markerfacecolor(f'C{j}')\n",
    "        ax.get_lines()[j].set_markeredgecolor(f'C{j}')\n",
    "    ax.plot([-3, 3], [-3, 3], ls='--', c='k')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "712be04c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Test')"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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79evn7KysjR69GgbQP75z3/WzTffbPeVvOqqqzRp0qTg0nMAAABswx6ThuM4mjNnju6//35t2LDBHktJSSGYBAAAQFTEYj569dVXa9ddd9U111yj0tJS+9jcvvzyS3ve4/Hotddes/emevLkk0/W+PHjY9opHAAAoDVzOWZW1wxLlizR2LFj7TfFFRUV+uGHH+y+OxdccIF9bvb7iWfmm/fc3FzbEZGNxwEAQLxJhLkM81EAAIC2MZ9pdsWkmfDtvvvuWrdundLT04PHzT4/77777taPGAAAAGgC5qMAAAAJusfkxx9/rJkzZ9qlMqG22247LV++PJJjAwAAAOphPgoAANA2NLti0ufz2c2+6/rtt9+UnZ0dqXEBAAAADWI+CgAAkKDBpOk2ePvttwefu1wuu/m32QT8D3/4Q6THBwAAAIRhPgoAAJCgzW/MN9FjxoyxnRB//PFHu7+Pue/YsaM++ugjde7cWfGMzcYBAEA8S4S5DPNRAACAtjGfaXYwaVRXV+upp57SvHnz7LfTu+22m0466aSwzcfjFRNBAAAQzxJlLsN8FAAAIP7nM81ufmNflJSkk08+eVvGBwAAAGw15qMAAADxr9nB5GOPPbbZ8+PHj9+W8QAAAACbxXwUAACgbWj2Uu727duHPa+qqtLGjRuVkpKijIwMrV27VvGMpTMAACCeJcJchvkoAABA25jPNLsr97p168JuZk+fRYsWaZ999tH//ve/bR03AAAAsFnMRwEAANqGZgeTDdl+++1144036oILLojE2wEAAADNwnwUAAAgQYPJwAbkK1asiNTbAQAAAM3CfBQAAKCNN7955ZVXwp6bLSoLCwt11113ae+9947k2AAAAIB6mI8CAAAkaDB55JFHhj13uVzq1KmTDjzwQP3f//1fJMcGAAAA1MN8FAAAIEGDSZ/P1zIjAQAAAJqA+SgAAEDbELE9JgEAAAAAAAAgohWTF198cZPf8NZbb1VL+eijj3TLLbdozpw5dh+hF198MWwpj9lf6JprrtG///1vrV+/3u4xdO+999oujQAAAIhfrWU+CgAAgCgHk19//XWT3szs79OSysrKNGTIEJ122mk6+uij652/+eab9a9//UuPPvqoevfurb/97W8aM2aMFixYoLS0tBYdGwAAAFpOa5mPAgAAIHJcjikzjENm0hlaMWl+ja5du2ry5Mm65JJL7LHi4mLl5+frkUce0QknnNCk9y0pKVFubq59bU5OTov+DgAAAJHGXCb+8TcEAACJMp9pM3tMLl68WEVFRRo1alTwmPkA9txzT82aNavR11VUVNgPK/QGAAAAAAAAoJV15Ta+/PJLPfPMM1q6dKkqKyvDzr3wwguKBRNKGqZCMpR5HjjXkGnTpmnq1KktPj4AAABETmucjwIAAKB5ml0x+dRTT2nEiBH6/vvv7VLqqqoqfffdd3rvvfdshWK8mTJlii0rDdyWLVsW6yEBAAAggeajAAAAiarZweQ//vEP3XbbbXr11VeVkpKiO+64QwsXLtTxxx+vnj17KlYKCgrs/cqVK8OOm+eBcw1JTU21a91DbwAAAGi9Wut8FAAAAC0cTP7888869NBD7WMzETSdsk0jmosuukgPPPBAc98uYkwXbhNAvvvuu8FjZr/Izz//XMOHD4/ZuAAAABBZrXU+CgAAgBYOJtu3b68NGzbYx926ddP8+fPt4/Xr12vjxo1qSaWlpZo7d669BRremMdmbyEzGb3wwgt1/fXX65VXXtG3336r8ePH207dgc7dAAAAiH+xnI8CAAAghs1vRo4cqRkzZminnXbScccdpwsuuMDu52OOHXTQQWrpTc4POOCA4POLL77Y3k+YMEGPPPKILrvsMvuN+Zlnnmknpvvss4+mT5+utLS0Fh0XAAAAoieW81EAAABEjstxHKcpF5pvogcPHqy1a9eqvLzcViL6fD7dfPPNmjlzprbffntdddVV9hvseGaWf5tN000jHPabBAAA8aYtz2WYjwIAALSt+UyTg0m326099thDp59+uk444QRlZ2erLWIiCAAA4llbnsswHwUAAGhb85km7zH54YcfatCgQZo8ebK6dOlil09//PHHkRovAAAAsFnMRwEAANqWJgeT++67rx566CEVFhbqzjvv1K+//qr99ttPO+ywg2666SYVFRW17EgBAACQ0JiPAgAAJHhX7szMTJ166qn2G+sffvjBbjh+9913q2fPnho3blzLjBIAAACowXwUAACgbWjyHpONMV2wn3jiCU2ZMsV2wvZ6vYpn7OkDAADiWSLOZZiPAgAAxOd8Jmlrf8BHH31kl9I8//zzdiPy448/XhMnTtzatwMAAACahfkoAABAfGtWMLlixQo98sgj9vbTTz9pxIgR+te//mUngWZJDQAAANCSmI8CAAAkYDB5yCGH6J133lHHjh01fvx4nXbaaerfv3/Ljg4AAACowXwUAAAgQYPJ5ORkPffcczrssMPk8XhadlQAAABAHcxHAQAAEjSYfOWVV1p2JAAAAMBmMB8FAABoW9yxHgAAAAAAAACAxEMwCQAAAAAAACDqCCYBAAAAAAAARB3BJAAAAAAAAIDW2fymORuNjxs3blvGAwAAANTDfBQAACBBg8kjjzwy7LnL5ZLjOGHPA7xebyTHBwAAADAfBQAASNSl3D6fL3h7++23tcsuu+jNN9/U+vXr7e2NN97QbrvtpunTp7f8iAEAAOKRzyst/lj69jn/vXmOJmM+CgAAkKAVk6EuvPBC3Xfffdpnn32Cx8aMGaOMjAydeeaZ+v777yM9RgAAgPi24BVp+uVSyYraYzldpbE3SQNZdtxczEcBAAAStPnNzz//rHbt2tU7npubq19//TVS4wIAAGg7oeQz48NDSaOk0H/cnEezMB8FAABI0GByjz320MUXX6yVK1cGj5nHl156qYYNGxbp8QEAAMQvs1zbVEqqdi/EWjXHpl/Bsu5mYj4KAACQoMHkQw89pMLCQvXs2VP9+vWzN/N4+fLlevDBB1tmlAAAAPFoycz6lZJhHKlkuf86NBnzUQAAgATdY9JM/ObNm6cZM2Zo4cKF9tiOO+6oUaNGhXVDBAAASHilKyN7HSzmowAAAAkaTBpmwjd69GiNHDlSqampTAABAAAakpUf2esQxHwUAAAgAZdy+3w+XXfdderWrZuysrK0ePFie/xvf/sbS2cAAABC9Rrh776txkIzl5TTzX8dmoz5KAAAQIIGk9dff70eeeQR3XzzzUpJSQkeHzx4sP7zn/9EenwAAADxy+2Rxt5U86RuOFnzfOyN/uvQZMxHAQAAEjSYfOyxx/TAAw/opJNOksdTO4keMmRIcI8fAAAA1Bg4Tjr+MSmnS/hxU0lpjpvzaBbmowAAAAm6x6Tpdmg2HG9oSU1VVVWkxgUAANB2mPBxwKH+7tum0Y3ZU9Is36ZScqswHwUAAEjQYHLgwIH6+OOP1atXr7Djzz33nHbddddIjg0AAKDtMCFk731jPYo2gfkoAABAggaTV199tSZMmGC/qTbfSr/wwgtatGiRXVLz2muvtcwoAQAAgBrMRwEAABJ0j8kjjjhCr776qt555x1lZmbaieH3339vjx188MEtM0oAAIBI8XmlxR9L3z7nvzfPI3Etoob5KAAAQAJWTFZXV+sf//iHTjvtNM2YMaPlRgUAANASFrwiTb9cKlkR3oTGdM6u24SmOdciapiPAgAAJGjFZFJSkm6++WY7IQQAAIgrJmh8Znx40GiUFPqPm/Nbcy2iivkoAABAAi/lPuigg/Thhx+2zGgAAABaglmCbaof5TRwsubY9Cv81zXnWsQE81EAAIAEbX5zyCGH6IorrtC3336roUOH2n19Qo0bx9ImAADQyiyZWb/6MYwjlSz3X2c09Vq6bMdErOajv/76q6677jq99957KioqUteuXXXyySfryiuvVEpKSvC6efPmadKkSfriiy/UqVMnnXfeebrssstaZEwAAAAJFUz+5S9/sfe33nprvXMul0teL9UDAACglSldGdnrmnstIipW89GFCxfaLuD333+/+vXrp/nz5+uMM85QWVmZ/vnPf9prSkpKNHr0aI0aNUr33XefDU/Nfpjt2rXTmWee2SLjAgAASJhg0kzGAAAA4kpWfmSva+61iKhYzUfHjh1rbwF9+vTRokWLdO+99waDySeeeEKVlZV66KGHbBXloEGDNHfuXBuiEkwCAABs4x6TocrLy7fl5QAAAC3D7P+4+GPp2+f89z329HfUlquRF7iknG5SrxH+W1OvRczFej5aXFysvLy84PNZs2Zp5MiRYUu7x4wZYwPMdevWNfgeFRUVttIy9AYAAJAImh1MmqUxZm+dbt26KSsrS7/88os9/re//U0PPvhgS4wRAACgftgYaFRT95jpmH37YOnRw6TnJ/rv/zVEGnysbV1Tt9bOF2hpM/ZGye3x38be1LRrEROtZT76008/6c4779RZZ50VPGb2nszPD6+mDTw35xoybdo05ebmBm89evRo4ZEDAADEaTB5ww036JFHHtHNN98c9k3w4MGD9Z///CfS4wMAAGg4bLylr3RLv/rHnvlz/eY1JYVyZt6p+6sOVZFTW91mFDkddE7lBZru2yN4zDw2x5pyLaIv0vNR00jH7E25uZvZXzLU8uXL7bLu4447zu4zuS2mTJliKy8Dt2XLlm3T+wEAALTZPSYfe+wxPfDAAzrooIN09tlnB48PGTKk3oQNAABgi0yVo+lwbZrJZHQ03UukstW1j3+YLn12T/3XbVrXtGOWYysdxyXN0siK27W7+wd11nqtUjvN9g2QI7e+eXWBDh5YYK+e+uoCFfqG6e2K3TXMvbDRaz3uxpZ7oyVFej46efJknXLKKZu9xuwnGbBixQodcMABGjFihB1HqIKCAq1cGd4YKfDcnGtIamqqvQEAACSaZgeT5tth04WwoU3Iq6qqIjUuAACQCAGkCR3nPSNtXBOVZSJdXb/bUPIz38B65wuLyzV78drgYztkuTd77fC+HVp83Gj5+WinTp3srak/24SSQ4cO1cMPPyy3O3wB0vDhw3XllVfacSQnJ9tjM2bMUP/+/dW+fftmjw0AAKAta3YwOXDgQH388cfq1atX2PHnnntOu+66ayTHBgAA2kIQuaFQ+uV9adGbm6lojB5T/diYVRua3kilOdcismI1HzWh5P77729/runCvXr16uC5QDXkiSeeqKlTp2rixIm6/PLLNX/+fN1xxx267bbbWmxcAAAACRNMXn311ZowYYKdmJlvpV944QXbZdAsqXnttddaZpQAACA+Aki7BLuDtPjDVhNE1mWWZDemc3Zak9+nOdcismI1HzWVj6bhjbl179497Jzj2LZItnnN22+/rUmTJtmqyo4dO9rxnnnmmS02LgAAgHjlcgKzqGYw31Bfe+21+uabb1RaWqrddtvNTrhGjx6teFdSUmInlGbj8ZycnFgPBwCA2At0vl7yiVkrK2XkSZkd/SHkstnSz+9JlaVq7XyOVKQO2qfiDrtEO5TZKbIgN02fXH6gfb7PTe+pqLjc34G7jtBrW+Mek4kyl2E+CgAAEP/zmWZXTBr77ruv/cYYAAC0wQDy14+kdUv9e0BWbZR+eleq3qR4EfjK1Qw/NJQ0plb9ucFQ0rjm8IHBoNE8Pufxr+w5ZwvXIjaYjwIAAMS/rQomAQBAGwsjv3zQ34jGW6m2EECuV5byVFvFaSolTSj5lm+Y8jJTtLas9vc01Y8maBw7uEvwmHl878m7+btz1zTCaexaAAAAAC0YTJoOgq7QWf9mrF3r72YJAABaYRVkaP1f8XJpxZy4CiNDrVOWva8bQF696U96a0Nv9S/7Wrm+EiX33FmzfQPkyK0Nr92oNO8apXlSdNPjb9h9Iof1zmuw+tGEjwcPLLDdt02jm81di5bHfBQAACBBg8nbb789+Pj333/X9ddfrzFjxmj48OH22KxZs/TWW2/pb3/7W8uNFAAAbF51pTT7fmnJLKmi1L8H5O8/SL5qtQUV1Y5Wljl6rHwfzW9/oA0bjaR3b1bF7ytUXLpRG0rXyLfpH/b4b5KSO/ZS14knBJdg51Ss0aKfFiojI0PjhnTdYtBlQsjhfTu0+O+GLWM+CgAA0PY0u/nNMcccowMOOEDnnntu2PG77rpL77zzjl566SXFMzYbBwC0VpXVPj06c7Fm/7xKHdd8qd2q56pP1Y9Kd8qV7xQpT8XBAC6e+BxHJRVSu7Ta0f/fzAr98LtPyzc4WrHBpxUbHK0qc2y9Z3LHnuo68Z7gtSsenKSqNUvC3tOVlCxPVgcld+ihzsdeoy41S7CTVy6Q2+1W165dtcMOOzS5Ai+eJMJchvkoAABA25jPNDuYzMrK0ty5c9WvX7+w4z/99JN22WUX2xUxnjERBADEgtfnaOaPa/TsnKVaUFiijZXVdtW1Rz7tpe+0X+W76uv9RR1Uojx3mZJczfrPd6vw9Pwq/bTWhIw+rSitDRwLNzjq1zFJl5x5tN717WavnfGf/9Pvq1fXfxO3x4aNXU+7K3iobMGHcrxV8mTlqaCgi646fm8dtVd/ffHruoRcgp0IcxnmowAAAAnalbtDhw56+eWXNXny5LDj5pg5BwAANm9TpVfXv/KVun7/qIZ7P1NH/a5Ub6UGuHy6Um5VOCn2unRVKs9dKk8gT/Oo1flkabUWr/MHjPZWGnjssxWQX5/l3wfS+McnFZq30tfg+/y4IV3XV48PPvftfJRyK8ps2JiUlWerH81jd0aOXC5/V+1Ax+yrzj9d23XMrBdAsgS77WI+CgAA0DY0O5icOnWqTj/9dH3wwQfac8897bHPP/9c06dP17///e+WGCMAAHEVOl778hzlf/eQxng/UBfX7zZA88ktpyZKS1W1rndVh3WTbk2howkal5XUBozmfnnNfUay9OZJmcFrz32jXN80EjbmpvqrOtc5mXrbO1Spfdeqd36V1mX1kdsGjf6w0d4y24W9Nmf3cfXez+SNga7bBh2yExfzUQAAgAQNJk855RTtuOOO+te//qUXXnjBHjPPP/nkk+DEEACAtqqyskpvvvKkus5/QNv5frZVjSZ29NjaPZdMLd8/XI4/dPS0rsYxhSHLp2vvHXnc0sNHpAevPfqZjZpb1HDYmJMa/nx4d486ZbrUNdutjllJWpvZR6sy+6lrtkfVmZ11QmUf26TGBLPa1/+a3GaMOy8zWUft0k2jBhZoaK/2mrMkMZdnIxzzUQAAgAQMJquqqnTWWWfZbodPPPFEy40KAIBYdLSedaf02X+kskL55G+0YuI5X01GZ0LHZJd0RCAL868oDhH9fR+rvP5O1eFho09enzRtVFrwur0eLNts2BgaTG6f51ZZpdQ12wSO/tAxcJ+blaqnq0ZoljNYHVwlGjimTDu6XJrlG6gXfQP9AaSk7wJv1vCPDHPBQf00rHcHrSmtUMfMVLtG2zxuKHxkeTaYjwIAACRoMJmcnKznn3/eTgQBAIjb8HHWv6WNhcHczMSJJk4Lrb0LZI6eBgPI6HSqXl0ncCyvls7b07//pHHwf8v07i/eBuPQ7JTwYNKEit+v9tULGgPho+mFF+hQ/cxxGSp33Prat73mOP211snWEidXs5Xnr370RuYDCXTKZik2moP5KAAAQAIv5T7yyCP10ksv6aKLLmqZEQEAsDV8Xun76dKbl0uly2oPB+oYff49CsP2dYxB5mgCwLWbAoGjow2Vjo4dmBw8P+GlTXpvcbWKSh1V++qHjaHBZKrHZX+3JLfUJSs8aOyS5bbhprvmF37uuHSlJZnfv/Glz+WOR+96d9PjvoP1eUj1Y6TkpiXp4IH52nv7TirIYSk2th7zUQAAgAQNJrfffntde+21+vTTTzV06FBlZtZugG+cf/75kRwfAABhKktLtPTe49Rtw2eqjegaDh3t8XoPWi5wLKmQrW5cV+5oRI/a/8ROeadcHy31BisfK721r8tKUVgwaULL30r8NZDm18m3gWNN6JjlUrXPUVJNmHffYWlK8UgdM1zBALIx6ckuVTouzfFur0J1DDnj0nKno2b6BjUrjMxIduuQwQUqaJcux5HaZ6QoLzNF6zdWql1G+H1eVipBJCKK+SgAAEDb4HLM/5Jqht69ezf+Zi6XfvnlF8WzkpIS5ebmqri4WDk5ObEeDgAkjLWllTr6rg/06/oqueXTvu7Z+qfnPuW5THOZLQeQLams0tHqjY62a1cb2v3r8wp99psJG2uXW5dV+c9lJksbpmQHqxPH/W+jXv2hOuw9TZgYqG58+YQMpXj8135T5LXBpTluQslACNlcVY70g6+bypSpZU4nveAbqVm+QcHgMckl7dKznbq1q91bsi4z/i7t0tQuPUXrN1WqcH25urVP14i+HbVXnw6EjK1UIsxlmI8CAAC0jflMsysmFy9evK1jAwAkYOh41J3va0lxeDhn5KhEryZfqu6uDXrXHEiJXvhoGsck1wSCxjPfVemrQm+9RjLFFaZCUCoNCRvfXezVK4vq/z65qf79HDdV+19jXLRXiiYMSQ5WPhZkuZRqksEGDClofitvk4euVmet9+Sp0J2vj9NH6YeMXSV3ksqrvUpL8qhjVqrGuV0Ei2gTmI8CAAC0Dc0OJgPWrFlj7zt2DF0OBgBIpLDxiDve1bINTWi7bFdS+7S/+zPd7rlb2S4n2GjG1cIh5EdLqvXdKp+WhwSNgSrHTdVOWNj45LdVermBsDGgtFLKTvU/Hr9zsvbv5Qnu69gl2233ecxMqf/LHNB7q/9zG8Z80huVpor0LmrXuYc83XeX+u6v5O32UVe3R10lDZR0UER+GtD6MR8FAACIb836X0rr16/XlVdeqaefflrr1q2zx9q3b68TTjhB119/vdq1a9dS4wQAtLBNlV5NeX6OXvpmdUTeL0Mb9UjyVO3mWmZDyEhWQS5a49VPa2sDRhs2lvrvf9/oaPEFWcGw8dZZlZsNG001ZLua5tWH7ZBkl2sHlliHdq82jWdCG8ccE7Iv5LYym6pUuFzaqAz7n+b01HSlJif5F1273VJOF2nAYXLvdbayklKUFbGfDMQf5qMAAAAJGEyuXbtWw4cP1/Lly3XSSSdpxx13tMcXLFigRx55RO+++65mzpxpJ4YAgNZn+dpN2v/m9+yy30hKUrXO9LygSe6XlGbCx62shFxnm77UrWr0B46ryxx9fGpGMBi84t0KvbSw8bBxfbnUvmbrxL17eGwoWjdo9Heudtml1wGn7xbaTidyfI600UlSpZJl+mg7bpc8poY0LU85O46S55BpSktJV00+CqARzEcBAAASNJg0nQ9TUlL0888/Kz8/v9650aNH2/vbbrutJcYJANiM4o1VOuGeD/T9mvBGMS2hndZrevIF6uSqsiHk5gJI019tQ6W/U/XykvBl1CvLfPrfMenBsHHiK5v0YhPDxoEd3VraxR3sVF0bOPofm07XAZfuHZI8tgBT7VhtbvaZS1655XWnyJ2cpcyuA+Xe53y5+x6gLHfz944EEI75KAAAQIJ25d5uu+10//33a8yYMQ2enz59us4++2z9+uuvimd0QQTQ2pSWV+ushz/Vp0tKo/pzTSXkWZ7nda77ZaU0UAm5sSpkGXXNfeEGRzcfnBoMG//0/EY9Nb/xsPH3y7KVl+6/9rw3Nump76prA8as8OrG0X2TlJ4cvWYt5r+OptLRax7XOedTkkrcOVpTsJ+2H3+3UjIyozYuIJHnMsxHAQAAErQrd2FhoQYNGtTo+cGDB6uoqKj5IwWABLa6pEKjb3lH6yK9vrrZe0H+XUNdv9nwsaLaUWGpufns/b83+HTesJRg2HjBm+V69JtKuzdjQ67YJ0UdMvzXdqwJHc0ejiZg7FKnujHJbqLo969D0nTnH6LbJToQPgaCxyp5tFrt9bh3lB7y/kEud7I656TqpD176fR9+yglZMCmeDO8XgtAS2M+CgAA0LY0OZg03Q7Nt8/du3dv8PzixYuVl5cXybEBQNyKVZXj5kJHr8/RylJHy2uqG8f1T5Lb5bLVj//4uEKnf1dlKx9/31S/kP7EnZLVsSZsNGcDoWRGstStzjLqUNcdmKabDk5TRhMqHUMby0QqdLS3Bjtbp+s1356aWn2KKpVi96DMy0jWKXv31pkj++qvSW79NaKjARAJzEcBAAASNJg0S2ZMB8QZM2bYvX1CVVRU6G9/+5vGjh2r1uDuu+/WLbfcYr8xHzJkiO68804NGzYs1sMCEOdMsPfGnN903vPzov6z87RW7ySfq9yQJdUBPsffHMaEikMK3DZsNB74qlKv/1Ctc0r9S61NKBka0q26JEudMv3Xripz9O0qE9n5pXjCm8VUmfXMNSYPT9Ff9khusFN1Xe1MN5wWZiseQ34xU/X4iTNY51ZdoPKadjImeOzePl1XHzZIBwzorFy3SydJ9gYgfsTTfBQAAAAR3GPyt99+0+67767U1FRNmjRJAwYMsE0Nvv/+e91zzz12Mvjll1+qR48eiqWnn35a48eP13333ac999xTt99+u5599lktWrRInTt33uLr2dMHSDwtETh21iq9n3xhWJfq5jL/jl27ybF7MLrd/srGF76v0ru/VNtO1YG9HYtKHVXXZIorL8lS50x/1eKF08t1x+fhzXA8LqlLTXXj08dmaLt2/mvnrfTa/SEDlY/mZ0a6gjHS1Y+r1E5vdJ+sE8efrfS0lummDcSjtjyXiZf56LZqy39DAACQGEqaOJ9pcjAZWB7zl7/8RW+//badBNo3cLl08MEH66677lK/fv0UayaM3GOPPex4DJ/PZyen5513nq644ootvp6JIJAYHatTVKkbkh7Qka6ZNqyLtC11qvZf47/g4yXVmvWb19+1uqa6MRA6Vnq3HDba9zL7HWa59MGEDPXv6O/+/OnSai1Y7QurfDTLsT2mfLCVsuFjyPDccktdd5FOfknKyI3l0IC40dbnMvEwH91Wbf1vCAAA2r6SSDe/MXr37q0333xT69at048//miPmclfa9nLp7KyUnPmzNGUKVOCx9xut0aNGqVZs2Y1+Brzzbq5hX5wAFqZjcXSQ4dJa+pXNAYXH9euQq4nW9Lr5kFK04LDSFiw2qt5K024GB40Bh7/fH6WDRKN57+vbjBsDDAVkZ1rmj6P6etRVkpKSAMZt7plu+x7JdUJHPfumaS9eyp+5HST6/QP5crpFOuRAGjFWvt8FAAAAE3XrGAyoH379q1yz8Y1a9bI6/UqPz+8T6p5vnDhwgZfM23aNE2dOjVKIwQSWMlq6e4RUsWqZr3M5I0up/EQMdhqJbznSotYVebTT2sbDhrN/fsTMpSf5R/Iv+dU6fbNhI3m+vws/+MRPTxauyk5rIFM4N50sU5Nqv3lD9k+2d7im0vq0E869W0piyABwNZprfNRAAAAtHAw2ZaY6sqLL744rGIy3vclAiKuvFR6eoK0+J2o/2gb87VgZWN1Tafq0IBxeUiV42NHpQeXUd/4SaVu+6zxsHF5SNg4uLNbI3t5bMBY27W69r6X6WJT4/hByfbWZnnSpL0vkkZeLCWxFyQAAAAAoA0Gkx07dpTH49HKlSvDjpvnBQUFDb7GbJ5ubkBCqK6UZt4hfXK3VLlObVlop+q61Y03HJSqjhn+sPHyGRW6dTNh47Li2mXU27Vz2VswYMwKBI3+Y9vn1ZZtTtwtxd4STvt+0sQZVEICAAAAABIrmExJSdHQoUP17rvv6sgjjww2vzHPzz333FgPD4isyk3Sm5dI370qVRYrUQQ6VdddRn3OHim2k7Rx7YcVuu6jimCn6rrOGJqijhn+xyZUDO1UbUPHrNrwsUdIZeP5e6baG2qk5EhnfybldYv1SAAAAAAAcahNBZOGWZY9YcIE7b777nbfodtvv11lZWU69dRTYz00YPOVjJ/f6w8Z1/7iDx19lYEdFmsWNJvOo74td3qJ48BxQ6XZe7F2GfXhOyQrN80fDN41u1K3zqqw5yq89V8/um+S8rr5u1FnpZgl2v5PrnOmP3DsllMbOHbKqA0bzx2Wogv3SmnVnapbhayu0pkfSTSmAQAAAABESJsLJv/4xz9q9erVuvrqq1VUVKRddtlF06dPr9cQB4hp+LhuseStlnxeybtJcqq38OIGkrg4srGqtrpxaBePMlP8IeAT86r0768qg+fKqsJfN/t0j/aoCRsrvY4WrzfhrF+H9ECFoz9sNGFkwCm7pNg9G/MzXUo25ZCbEdpYBpIKdpXGvyxl5MZ6JAAAAACANq7NBZOGWbbN0m1ElQkYf/5A+uZJqfBbqbLMX+DoOJK3QqrcIPkq1NZUVDsqKnVUENI5+s0fq/S/+dVhlY/FIb/67NMzg2Gj6XL94ZLw0DU3VcFl1J6QTtvHDUzWXt1NMxm3/XlpmwkUzZLuwLJuhMjfRZrwCqEjAAAAAKBVaJPBJBDxSsfZ90u/zpSKf/M/N6mjO0XyVkob10jla2uWWrcNplO1ifUCy5tnLavWGz+asNHRitLaRjJrNvp/589Pz9SwmrBx0e8+/XdendJHSRnJst2py6trP6dDtk9SQZZb3XL8VY9dslzBasq6euS67S3huZKkcfdKQ46R3P7PHAAAAACAeEQwCTRU+Tjvf9LaJf4l1xtXqy36frVXnyz11jaQKfXfF25wtLLM0czTMrRnd/+/ImYv9+r6jxvuXJ3ikW1GE7BfryTdeJC/qUywe3W2WzmpkssVHjoO6Oixt9bAFLeam01kXf5dPSPCkyGd87nUsWek3hEAAAAAgDaBYBKJGT4u/lha/IH029dS9UYpKV2qrpCWz5ac+G0sU7jBp29X+cKWUYd2r37u+IxgZeOMX6p1wfTGl5eb1wTs3tWjv+yeHBY0BvZ3NEumQwPHXbt47C0qIeLWqEkcw4LH9n3lmviOXFl5ERgdAAAAAABoCoJJJE4Q+etH/uXYK+b4l2DHUeOYpcUNB43m/l+HpGm3miDwuQXVOn96eaPv9VuJLxhMDurk0aHbJ4U1kOkWEjp2DOlcvXfPJHuLdbBYLZde8O2jq6snqlIh3W5qCh136pqj/56+l3LNunEAAAAAANCqEUyi7YmTIDK0U3VhaOhY6tOUfVI1uLM/QHzwq6rNho2L1/mCwWSf9i7t1LluVWPt/YCOtXWCB/VJsret4duGisXlTp4Oq/qHSpTTrNdlpnh08zFDdNxOBTqhZu9LAAAAAAAQvwgm0TYCyPW/SbldpZJCacFLUnXjQV60OlXXrW48dddk7dDBHyDe92Wlznm98TEeNSA5GEyaUDG0U3XoMmrzeHiP2mXTh+6QbG9NZcJFEzI21Uq105XVE/Whb1f5IrQLYyBwHLtTQbDZDgAAAAAAaPsIJhF/YeSSmdLC16U5j0jVm6LaqXplaUiVY6mjsf2StF07f0D3v2/9lY2BTtV1De3qCQaTnTP9AVx6ktQtJyRorOlQbaoeA47eMUnHDMxpUsDorXO8po+L/5qafRV9cmmtsvWQd6we9B6m6ij8a6BdepJuPHpnHTyI8BEAAAAAAPgRTKJ1B5AbCqXSldKm9dLqH/wNaypKIvujHMeGiYHAcdcCj7pk+4PB13+o0tUfVNhzJpSsGzk+c2x6MJhMS1IwlDSdqsOqG7PcweuMQ/olaf3l2Q12qvaPSarwmRDRcMvrSJ46P90ttyqUos+dATqv6nyVK03RkJXq0R926qKp4wYr3fyiAAAAAAAAW4FgEq0viPzlfWnRm9Kmddv0lo7jaF256S7tU7dst9qn+wPAj5dU67bPKsMqH6tDGnE/fWy6jh/kDxGrfNJXhbUnPS6pS8gy6tAGMQf0TtK8szMb7FRdV3qySylJUqnjkddx2/9H3KRULXR66n7v4Zrp2yliS6Wbwow0LzNZp+7dW2eO7KuUpOj9bAAAAAAAkJgIJhGTANJXskJLli7VGl+Gcoo+03ZrPlRqVXGT32ZDhSOTnZmAz5hb5NUjc6tC9nX031fUrG1+6ph0/XGwf+/FtZscvbiwOuz9XDXLq02oGFoEOLy7R6/+KT1Y+dgpw9XoUuR2aS61S/O/2FQ4/u7LULmTqlRVye3yySeP1jk5+t7pped8+2mWb1CLho/mnU1F47DeebrzT7spy5R0AgAAAAAAtBIkFWhxXp+j2YvXyrPoVQ2ZP02pG4tsaNa75la3yjFQafjTWp9eWVTl71hdGt5IprRS+t8x6TqhJmxcWuzTHZ833Hm7Q7pL5dW1y6BNB+u7/5AWttQ6P9OlZFMOWUd+lluH7VAbHpq3+c3bTiXKsHszJqtK6aqQWy5tVFrEQsc0t1QZUsVpstBAkxq3W8pOS9aAgmydvV9f7bN9J/ZtBAAAAAAAcYdgEi0aRs5YUKSX5q7QHps+0b3Jt6uo1KdZy7y1VY1h3at9uucP6frTTv6w8fvVXk1+u6LRn7GqrDa5G9TJo8tGpNjGMaHdqwuyXEpLCg/teuS69Zc9Urb4O5ggcLWTrSVOgZY5nfWCb2REqxzN//OlJps9Jj22mvGA/p119eGD2LcRAAAAAAAkBIJJNDtsXLWhXJ2z0+wSYeP9b5do7vzvVF2yVmtWFemLBT9r/k+/auO6NfKW/q72+5yo13Z60l47Z4VXxz7beCdtE04G7NDBrRMGJ9nGMaHVjaaLdZcslzJTagPHvnlu3XRw85u/VDouLfHla4U62E7VHVSqjUrVbN8APeYds9Udq9OTXGqfkWwrQCuqfXZpd7LHrZ55mRo7uECn7N2bfRwBAAAAAEBCI5hEg3w+n1auWq23v/heP/26VD8uXqZP5v2o4t9Xylu6Vtm7Hqoug/ey166Y96lWP39to+/VpfgbdXWttY9NZ+oRPTzBTtX+wLE2dOyZWxvW9e/o0f+OyYjo71XuuPW1b3t96QzQTN8gfe4buFUVkLmpHnVrn67Kaq82VnnldrmVn5OmMYMIHQEAAAAAAJqCYDLBmAq+9evXa8WKFcHb8uXL7f3xxx+vkSNH2uuuu/dx/f3cCY2+T2r3wVq/cah9nJTdQZ6sDvJk5/nvszooKcs89t+G5q8yvbDttTvle/TpaZlR+m23PYjs3i5VnbJSbXfuLrmmSrSDJozYjuARAAAAAABgGxFMJpD33ntPhx56qMrLyxs8X5rcTsndBmldWaXu/2Kd7VXtzsxVkg0ba4NGEzymdtsx+LqU/L7qPunRBt9zjHu2bkh+SS2tzEnRB96d9ZWzvdppoxyXS7N8AxsMIs2Wk7v0bKeuuWlaU1qp8mqv0pI86piVKrfbZSshR/TtqL36dKCpDAAAAAAAQAshmEwg7du3D4aSHTp0UNeuXZWS00FLy1NVkdJO01fn6IN/f2Y7QCd37q2el7wol2fr/hFxy6dJnpd0cdJzainFToae9e6rd3x72D0hG6uENEHkrr3a2z0xCRwBAAAAAABaB4LJBDJo0CAtXrxYBQUFSktL0/T5hTrn8a9kdnHMqNON2uX2bFUYOcy9UKNcc3RU0sfq4Crd5jGvczI1w7ubVjp5poBT65ws/e7kaqXyGgwjU5Nc2n+HTkpPSaLyEQAAAAAAoBUjmEwgKSkp2m677YIdtqe+ukDONr5neBj5iTq4NmxzEPm2d6hm+gY3Gj6GSvW4NKRHO+1BNSQAAAAAAEBcIZhMULMXr1VhccN7TTaV2T/ymuTHgh23t8ZTOljp+TuooGsPrXF1UHnXPVW6yauRGSlav7FSx2WkaG1ZhdZvqpLjSLnpySopr5JLLg3v24EgEgAAAAAAIE4RTCaoVRu2PZS8N/n2bR7HcePPl6ePvxM4AAAAAAAAEgfBZILqnJ22Tcu3TaWk2fOx8UXWW+KScrrKs93eW/0OAAAAAAAAiF8EkwnKdKjukpumouLyRveZTHL5tLtroTprvVapnX7LGKwLB6zXTpVz1fWHrV++HTT2RmkrmuwAAAAAAAAg/hFMJiizL+M1hw+0XbnNDo2h4aSrZqn2bblPKX1TUfC443XLNd+37T88p5s/lBw4btvfCwAAAAAAAHFp61fiIq6YLtyzfv5dL89dbu/N87GDu+jek3dTQW74su4/Zs3VvSl3hIWShsuJQCi5/1+lC78llAQAAAAAAEhwVEwmgOnzCzX11QVhXbjNMm5TMWnCyYMHFtgu3aYhTufMZO316iVylTS2wHsrUSUJAAAAAACAEASTCRBKmuXadWNGs7ekOW4qJk04ObxvB/+JxR9LJSsi88MzOko7Hy/1/4PUawT7SQIAAAAAACCIYDKOmeXYwUrH7DTb0MbsHRl63lRKNlT7aI6ZK815UzEZfF3pym0bFGEkAAAAAAAAmoBgspWFiZFanm2YnxN6vqFw0pw31wUrJrPyt+bXkva9VOqzH2EkAABo08aNG6e5c+dq1apVat++vUaNGqWbbrpJXbt2DV4zb948TZo0SV988YU6deqk8847T5dddllMxw0AANAaEUxGUVPCxEguzzbhZ1OEXWeCxZyuUklhnV7djXH5rz9gCoEkAABo8w444AD99a9/VZcuXbR8+XJdcsklOvbYYzVz5kx7vqSkRKNHj7aB5X333advv/1Wp512mtq1a6czzzwz1sMHAABoVejKHSWBMLFuBWMgTDTnm2JLy7MNc95cZyoymyLsOhMujr2p5smWKjlrzpumNoSSAAAgAVx00UXaa6+91KtXL40YMUJXXHGFPvvsM1VVVdnzTzzxhCorK/XQQw9p0KBBOuGEE3T++efr1ltvjfXQAQAAWh2CyShoTpi4Jc1Znm2WiZuKzMbiRXPcnDfXhTGds49/TMqpU8XpqvOPi6mUNNfRaRsAACSgtWvX2iDSBJTJycn22KxZszRy5EilpKQErxszZowWLVqkdevWNfg+FRUVttIy9AYAAJAIWModBVu112MjmrM82+xdaZaJm4pME0KGxp6BsNKcb3CPSxM2DjhUWjLT3xDH7D3ZY09p2ee1z9lPEgAAJKDLL79cd911lzZu3GirJ1977bXguaKiIvXu3Tvs+vz8/OA5sy9lXdOmTdPUqVOjMHIAAIDWhYrJKNiqvR4b0dzl2WavSbPnZEFu+OvM88BelI0yoWPvfaWdjvXfJ6WEPyeUBAAAbYBZju1yuTZ7W7hwYfD6Sy+9VF9//bXefvtteTwejR8/Xo7TlL25GzZlyhQVFxcHb8uWLYvQbwYAANC6UTEZBVu112MjAsuzzd6UDU1/XTWhY+jybBM+HjywICLdwAEAANqayZMn65RTTtnsNX369Ak+7tixo73tsMMO2nHHHdWjRw+7z+Tw4cNVUFCglStXhr028Nyca0hqaqq9AQAAJBqCySjYmjCxMVu7PNs8b3SZuM8bvmSbJdoAACCBdOrUyd62hs/nC+4TaZhw8sorr7TNcAL7Ts6YMUP9+/dvcBk3AABAImMpdxQEwkSjbo3iFvd6bMA2Lc+ua8Er0u2DpUcPk56f6L83z81xAAAABH3++ed2b8m5c+dqyZIleu+99/SnP/1Jffv2tYGkceKJJ9rGNxMnTtR3332np59+WnfccYcuvvjiWA8fAACg1XE527IhThtkuiDm5uba/X1ycnIi+t7T5xfa7tuhjXBMJaUJJZsVJtYwXby3aXm2CR+fGV+n7tKoeQ86bgMAEHdaci6T6L799ltdcMEF+uabb1RWVqYuXbpo7Nixuuqqq9StW7fgdfPmzdOkSZP0xRdf2CXf5513nm2Y01T8DQEAQLxr6nyGYDLKE8FtDhMjxSzfNpWRJSsaucAl5XSVLvyWZd0AAMQRQq34x98QAAAkynyGPSajbLN7PbakuvtIOr7NhJKGI5Us97/GdOAGAAAAAAAAIohgMhGYJdvTLw8PItPbNe21JsgEAAAAAAAAIoxgsq1rbB/JTeub9npTXQkAAAAAAABEGMFkW2aWb5tKyXrNbZqiZo/JXiNaYGAAAAAAAABIdO5YDwAtyOwPudl9JBtT04xn7I00vgEAAAAAAECLIJhsy5q6P2R6+/DnplLy+MekgeNaZFgAAAAAAAAAS7nbsqbuD3nsI/7KyEDHbrN8m0pJAAAAAAAAtCCCybbMBIym+rGksJF9Jmv2key9L0EkAAAAAAAAooql3G2ZCRvH3hS+b2QQ+0gCAAAAAAAgdggm2zqzT6TZLzKnS/hx9pEEAAAAAABADLGUOxGY8HHAof4u3ewjCQAAAAAAgFaAYDJRmBDS7CUJAAAAAAAAtAIs5QYAAAAAAAAQdVRMxjOfl+XZAAAAAAAAiEsEk/FqwSvS9MulkhXhDW1MF24a2gAAAAAAAKCVYyl3vIaSz4wPDyWNkkL/cXMeAAAAAAAAaMUIJuNx+baplJTTwMmaY9Ov8F8HAAAAAAAAtFIEk/HG7ClZt1IyjCOVLPdfBwAAAAAAALRSBJPxxjS6ieR1AAAAAAAAQAwQTMYb0307ktcBAAAAAAAAMUAwGW96jfB335arkQtcUk43/3UAAAAAAABAK0UwGW/cHmnsTTVP6oaTNc/H3ui/DgAAAAAAAGilCCbj0cBx0vGPSTldwo+bSkpz3JwHAAAAAAAAWrGkWA8AW8mEjwMO9XffNo1uzJ6SZvk2lZIAAAAAAACIAwST8cyEkL33jfUoAAAAAAAAgGZjKTcAAAAAAACAqCOYBAAAAAAAABB1cRNM3nDDDRoxYoQyMjLUrl27Bq9ZunSpDj30UHtN586ddemll6q6ujrqYwUAAAAAAADQRvaYrKys1HHHHafhw4frwQcfrHfe6/XaULKgoEAzZ85UYWGhxo8fr+TkZP3jH/+IyZgBAAAAAAAAxHnF5NSpU3XRRRdpp512avD822+/rQULFujxxx/XLrvsokMOOUTXXXed7r77bhtqAgAAAAAAAGg94iaY3JJZs2bZ0DI/Pz94bMyYMSopKdF3333X6OsqKirsNaE3AAAAAAAAAC2rzQSTRUVFYaGkEXhuzjVm2rRpys3NDd569OjR4mMFAAAAAAAAEl1Mg8krrrhCLpdrs7eFCxe26BimTJmi4uLi4G3ZsmUt+vMAAAAAAAAAxLj5zeTJk3XKKads9po+ffo06b1M05vZs2eHHVu5cmXwXGNSU1PtDQAAAAAAAECCBJOdOnWyt0gw3bpvuOEGrVq1Sp07d7bHZsyYoZycHA0cODAiPwMAAAAAAABAGwgmm2Pp0qVau3atvfd6vZo7d6493q9fP2VlZWn06NE2gPzzn/+sm2++2e4redVVV2nSpElURAIAAAAAAACtTNwEk1dffbUeffTR4PNdd93V3r///vvaf//95fF49Nprr+mcc86x1ZOZmZmaMGGCrr322hiOGgAAAAAAAEBDXI7jOA2eSVAlJSW2O7dphGOWgQMAAMQT5jLxj78hAABIlPlMTLtyAwAAAAAAAEhMBJMAAAAAAAAAoo5gEgAAAAAAAEDUEUwCAAAAAAAAiDqCSQAAAAAAAABRRzAJAAAAAAAAIOoIJgEAAAAAAABEHcEkAAAAAAAAgKgjmAQAAAAAAAAQdQSTAAAAAAAAAKKOYBIAAAAAAABA1BFMAgAAAAAAAIg6gkkAAAAAAAAAUUcwCQAAAAAAACDqCCYBAAAAAAAARB3BJAAAAAAAAICoI5gEAAAAAAAAEHUEkwAAAAAAAACijmASAAAAAAAAQNQRTAIAAAAAAACIOoJJAAAAAAAAAFFHMAkAAAAAAAAg6ggmAQAAAAAAAEQdwSQAAADQTBUVFdpll13kcrk0d+7csHPz5s3Tvvvuq7S0NPXo0UM333xzzMYJAADQmhFMAgAAAM102WWXqWvXrvWOl5SUaPTo0erVq5fmzJmjW265RX//+9/1wAMPxGScAAAArVlSrAcAAAAAxJM333xTb7/9tp5//nn7ONQTTzyhyspKPfTQQ0pJSdGgQYNsReWtt96qM888M2ZjBgAAaI2omAQAAACaaOXKlTrjjDP03//+VxkZGfXOz5o1SyNHjrShZMCYMWO0aNEirVu3rtFl4abSMvQGAACQCAgmAQAAgCZwHEennHKKzj77bO2+++4NXlNUVKT8/PywY4Hn5lxDpk2bptzc3ODN7EsJAACQCAgmAQAAkNCuuOIK28Rmc7eFCxfqzjvv1IYNGzRlypSI/nzzfsXFxcHbsmXLIvr+AAAArRV7TAIAACChTZ482VZCbk6fPn303nvv2aXaqampYedM9eRJJ52kRx99VAUFBXa5d6jAc3OuIeb96r4nAABAIiCYBAAAQELr1KmTvW3Jv/71L11//fXB5ytWrLD7Rz799NPac8897bHhw4fryiuvVFVVlZKTk+2xGTNmqH///mrfvn0L/hYAAADxh2Ay2nxeaclMqXSllJUv9RohuT2xHhUAAAC2oGfPnmHPs7Ky7H3fvn3VvXt3+/jEE0/U1KlTNXHiRF1++eWaP3++7rjjDt12221qVZiTAgCAVoBgMpoWvCJNv1wqWVF7LKerNPYmaeC4WI4MAAAAEWCa17z99tuaNGmShg4dqo4dO+rqq6/WmWeeqVaDOSkAAGglXI5pL4igkpISO6E0G4/n5OREdgL4zHjTz7HOCZf/7vjHmAgCAIDWO5dB2/gbMicFAACtaD5DV+5oLZUx30rXmwCq9tj0K/zXAQAAAC2BOSkAAGhlCCajwezfE7pUph5HKlnuvw4AAABoCcxJAQBAK0MwGQ1mU/FIXgcAAAA0F3NSAADQyhBMRoPpdBjJ6wAAAIDmYk4KAABaGYLJaOg1wt/pMLCpeD0uKaeb/zoAAACgJTAnBQAArQzBZDS4PdLYm2qe1J0I1jwfe6P/OgAAAKAlMCcFAACtDMFktAwcJx3/mJTTJfy4+dbaHDfnAQAAgJbEnBQAALQiSbEeQEIxE70Bh/o7HZpNxc3+PWapDN9KAwAAIFqYkwIAgFaCYDLazISv976xHgUAAAASGXNSAADQCrCUGwAAAAAAAEDUEUwCAAAAAAAAiDqCSQAAAAAAAABRRzAJAAAAAAAAIOoIJgEAAAAAAABEHcEkAAAAAAAAgKgjmAQAAAAAAAAQdQSTAAAAAAAAAKKOYBIAAAAAAABA1BFMAgAAAAAAAIi6pOj/yNbNcRx7X1JSEuuhAAAANFtgDhOY0yD+MB8FAACJMiclmKxjw4YN9r5Hjx6xHgoAAMA2zWlyc3NjPQxsBeajAAAgUeakLoev08P4fD6tWLFC2dnZcrlcamtptZngLlu2TDk5ObEeTqvGZ9U8fF5Nx2fVPHxeTcdn1Txt+fMyUzszAezatavcbnbtiUfMRxHA59V0fFbNw+fVdHxWzcPn1XRt/bNymjgnpWKyDvNhde/eXW2Z+Qe+Lf5D3xL4rJqHz6vp+Kyah8+r6fismqetfl5USsY35qOoi8+r6fismofPq+n4rJqHz6vpctrwZ9WUOSlfowMAAAAAAACIOoJJAAAAAAAAAFFHMJlAUlNTdc0119h7bB6fVfPweTUdn1Xz8Hk1HZ9V8/B5AbHB/+81D59X0/FZNQ+fV9PxWTUPn1fT8Vn50fwGAAAAAAAAQNRRMQkAAAAAAAAg6ggmAQAAAAAAAEQdwSQAAAAAAACAqCOYBAAAAAAAABB1BJMJaty4cerZs6fS0tLUpUsX/fnPf9aKFStiPaxW6ddff9XEiRPVu3dvpaenq2/fvrZzVmVlZayH1irdcMMNGjFihDIyMtSuXbtYD6fVufvuu7XddtvZ/9/bc889NXv27FgPqVX66KOPdPjhh6tr165yuVx66aWXYj2kVmvatGnaY489lJ2drc6dO+vII4/UokWLYj2sVuvee+/VzjvvrJycHHsbPny43nzzzVgPC0hIzEebjvlo8zAf3Tzmo03DfLTpmI82D/PRcASTCeqAAw7QM888Y/9l8fzzz+vnn3/WscceG+thtUoLFy6Uz+fT/fffr++++0633Xab7rvvPv31r3+N9dBaJTNBPu6443TOOefEeiitztNPP62LL77Y/g+Jr776SkOGDNGYMWO0atWqWA+t1SkrK7Ofj5k4Y/M+/PBDTZo0SZ999plmzJihqqoqjR492n6GqK979+668cYbNWfOHH355Zc68MADdcQRR9h/vwOILuajTcd8tHmYjzaO+WjTMR9tOuajzcN8NJzLcRynzjEkoFdeecV+q1FRUaHk5ORYD6fVu+WWW+y3HL/88kush9JqPfLII7rwwgu1fv36WA+l1TDfSJtvEu+66y773PwPjB49eui8887TFVdcEevhtVrmG+oXX3zR/jsKW7Z69Wr7TbWZII4cOTLWw4kLeXl59t/rphoJQOwwH20e5qNbxny0PuajW4f5aPMwH22+vASej1IxCa1du1ZPPPGEXe7AJLBpiouL7b84gOZ8c2++ERs1alTwmNvtts9nzZoV07Gh7f37yeDfUVvm9Xr11FNP2W/zzRIaALHDfLT5mI+iuZiPIlqYjzadl/kowWQiu/zyy5WZmakOHTpo6dKlevnll2M9pLjw008/6c4779RZZ50V66EgjqxZs8b+Ryc/Pz/suHleVFQUs3GhbTFVD6YyZO+999bgwYNjPZxW69tvv1VWVpZSU1N19tln2wqIgQMHxnpYQEJiPrp1mI9iazAfRTQwH20a5qO1CCbbEFN6b0rMN3cz+9MEXHrppfr666/19ttvy+PxaPz48Uqklf3N/byM5cuXa+zYsXbPmjPOOEOJYms+KwDRZ/b2mT9/vv3WFY3r37+/5s6dq88//9zuPzZhwgQtWLAg1sMC2gTmo83DfLTpmI8C8YH5aNMwH63FHpNtbB+H33//fbPX9OnTRykpKfWO//bbb3ZvkZkzZyZM+XBzPy/TJXL//ffXXnvtZferMcseEsXW/LPFnj71l86YzpDPPfdc2N405j9A5jOiQqRx7OnTNOeee67958h0kDRdW9F0Zgmb6XBrmkoA2DbMR5uH+WjTMR/ddsxHtx7z0aZhPrr1Enk+mhTrASByOnXqZG9bW25tmM3GE0VzPi/zzbTpHDl06FA9/PDDCTUJ3NZ/tuBnJsnmn5933303OKEx/39nnpv/gANby3y/aDasN5PlDz74gEngVjD/v5hI//0DWhLz0eZhPtp0zEe3HfNRtBTmo9vOl8DzUYLJBGRKhb/44gvts88+at++vX7++Wf97W9/s+l8onw73RxmEmi+me7Vq5f++c9/2m9rAwoKCmI6ttbI7A9lNrA392YPG1OebvTr18/uoZHILr74YvuN9O67765hw4bp9ttvt5scn3rqqbEeWqtTWlpq988KWLx4sf1nyWyg3bNnz5iOrTUul3nyySftt9PZ2dnBPaJyc3OVnp4e6+G1OlOmTNEhhxxi/znasGGD/ezMBPqtt96K9dCAhMJ8tHmYjzYP89HGMR9tOuajTcd8tHmYj9ZhlnIjscybN8854IADnLy8PCc1NdXZbrvtnLPPPtv57bffYj20Vunhhx822x00eEN9EyZMaPCzev/992M9tFbhzjvvdHr27OmkpKQ4w4YNcz777LNYD6lVMv+8NPTPkfnnC+Ea+/eT+XcX6jvttNOcXr162f8f7NSpk3PQQQc5b7/9dqyHBSQc5qPNw3y0eZiPbh7z0aZhPtp0zEebh/loOPaYBAAAAAAAABB1ibUxCQAAAAAAAIBWgWASAAAAAAAAQNQRTAIAAAAAAACIOoJJAAAAAAAAAFFHMAkAAAAAAAAg6ggmAQAAAAAAAEQdwSQAAAAAAACAqCOYBAAAAAAAABB1BJMAou6DDz6Qy+XS+vXrFU/MmF966aWIvd92222n22+/XfHq119/tZ/J3Llz4/rvCgAAElO8zl2Yk4ZjTgrEN4JJABFlJgGbu/39739Xa2fGuMsuu9Q7XlhYqEMOOUSJ6JRTTtGRRx4ZdqxHjx72Mxk8eHDMxgUAANAQ5qRtE3NSoO1JivUAALQtZlIQ8PTTT+vqq6/WokWLgseysrL05ZdfxmRslZWVSklJ2erXFxQURHQ88c7j8fCZAACAVok5aeJgTgrENyomAUSUmRQEbrm5ufYb6dBjZhIYMGfOHO2+++7KyMjQiBEjwiaLxssvv6zddttNaWlp6tOnj6ZOnarq6urg+aVLl+qII46w75mTk6Pjjz9eK1eurPct83/+8x/17t3bvo9hlnWcfvrp6tSpk33dgQceqG+++caee+SRR+zPMc8D36ibYw0tm/ntt9/0pz/9SXl5ecrMzLS/y+eff27P/fzzz3Zs+fn5dnx77LGH3nnnnWZ9ll6vVxdffLHatWunDh066LLLLtOECRPCviVuaOmN+Z1DqwBuvfVW7bTTTnaM5hvlv/zlLyotLQ2eN7+f+RlvvfWWdtxxRzvesWPHBif05r0effRR+/cIfCZmiUzdZTMN+eSTT7TvvvsqPT3d/uzzzz9fZWVlwfP33HOPtt9+e/u3MZ/Vscce26zPCAAAoCHMSZmThmJOCrReBJMAYubKK6/U//3f/9lvq5OSknTaaacFz3388ccaP368LrjgAi1YsED333+/nazccMMN9rzP57OTrLVr1+rDDz/UjBkz9Msvv+iPf/xj2M/46aef9Pzzz+uFF14ITlaOO+44rVq1Sm+++aadiJqJ5kEHHWTfy7x+8uTJGjRokJ0EmVvd9zTMJGq//fbT8uXL9corr9hJo5mkmXEFzv/hD3/Qu+++q6+//tpOqg4//HA7cW0q89mY3/mhhx6ykykzvhdffLHZn7Pb7da//vUvfffdd3Yy995779mxhtq4caP++c9/6r///a8++ugjO85LLrnEnjP3ZoIdmBiam5m0b4mZCJvXHHPMMZo3b56tVjC/x7nnnmvPm7+7mRRee+219n8ATJ8+XSNHjmz27wcAALAtmJNuHnNSAC3KAYAW8vDDDzu5ubn1jr///vuO+dfPO++8Ezz2+uuv22ObNm2yzw866CDnH//4R9jr/vvf/zpdunSxj99++23H4/E4S5cuDZ7/7rvv7HvMnj3bPr/mmmuc5ORkZ9WqVcFrPv74YycnJ8cpLy8Pe+++ffs6999/f/B1Q4YMqTdu894vvviifWyuzc7Odn7//fcmfx6DBg1y7rzzzuDzXr16Obfddluj15vf9eabbw4+r6qqcrp37+4cccQRm30PM3bzOzTm2WefdTp06BD2dzK/208//RQ8dvfddzv5+fnB5xMmTAj7ucbixYvt677++uuwv+u6devs84kTJzpnnnlm2GvM5+92u+3f+fnnn7d/i5KSkkbHCgAAsK2Yk4ZjTsqcFGhN2GMSQMzsvPPOwcddunSx9+Zb4549e9pvez/99NPgt9GBZSTl5eX2m9Tvv//eLsMwt4CBAwfa5R/mnFmmYvTq1csujwkw72u+OTbLUEJt2rTJfpvaVOab7l133dUumWmI+Rlmucnrr79uv801y33Mz2jqt9PFxcX2dXvuuWfwmPkG3yzN8c9Hm84s15k2bZoWLlyokpISO5bA52iWLBnmvm/fvmF/D/O32BbmszbfSj/xxBPBY2bs5hv8xYsX6+CDD7Z/H7MkynyLbW5HHXVUcEwAAADRwJy0ccxJAbQ0gkkAMZOcnBx8bPaFMUKXnZh9dY4++uh6rwvsy9MUZg+bUOZ9zQTH7EdTl5lANpXZn2ZzzFITs5THLEXp16+fvd7sVWM2O48ksySm7qSwqqoq+NjsuXPYYYfpnHPOsRNqM2k1S1cmTpxoxxKYcIX+LQJ/j+ZONusyn/VZZ51ll8bUZSb6ZtP3r776yv4t3n77bbspvZk4f/HFF836WwAAAGwL5qTbjjkpgK1FMAmgVTJ77Jg9XswEqiFmQ+xly5bZW+AbarPvj9lE3HxLvbn3LSoqst/0mk26G2ImJ+ab8C19s242MDd77DT0DbX5Zv2UU06x37YGJkRmQtZUZpN2M1k1G5cH9rgx3yoH9h8KMN+8h3adNN8+m29+A8z1ZmJt9gYyE0bjmWeeUXM15TOpy4zT/E0a+xsa5u8watQoe7vmmmvs5M/sN9TQ5B8AACDamJMyJwXQsmh+A6BVMt9UPvbYY/YbarNBtlkK89RTT+mqq66y582kwXT1O+mkk+w3nLNnz7Ybk5vNv83SksaY1w0fPtx2ETTfiJqJ2cyZM+2m52bja8NMDs1EyiyNWbNmjSoqKuq9j+l8aDo6mvcxEz6zybnZ0HzWrFn2vOnqF9jc3CwfOfHEE4PfvDeV2WT9xhtvtF0XzZIX07nQTHJDme6NZnNwszH7t99+azskejye4HkzATPfVt955512jOba++67r1njCHwmZgmMmZibzyT0G/DGXH755fazNRuLm8/hxx9/tF0UAxuNv/baa3YDdHNuyZIl9u9tPqP+/fs3e3wAAAAtgTkpc1IALYtgEkCrNGbMGDtJMBM1szfPXnvtpdtuu83u/xJY1mEmFO3bt7ff3prJndkXxnTZ2xzzujfeeMO+5tRTT9UOO+ygE044wU5C8vPz7TWmY5/ZW+aAAw6w3/7+73//a/DbWjO2zp07206HZkJqJmyBCditt95qx2Y6BZrOh+b3Cf1WuSlMJ8Y///nPdmJnJq7Z2dnBb7sDpkyZYie+ZmnMoYceaielofvyDBkyxI7lpptu0uDBg+3eOmZvn+Y644wz7OTMTLDNZ2ImvltivsE33Sl/+OEH7bvvvnb/IzO579q1qz1vvok2E2UzkTXVBmZyaj5r030SAACgNWBOypwUQMtymQ44LfwzAAARYpbimG+ozTfWAAAAQCwwJwUQKVRMAgAAAAAAAIg6gkkAAAAAAAAAUcdSbgAAAAAAAABRR8UkAAAAAAAAgKgjmAQAAAAAAAAQdQSTAAAAAAAAAKKOYBIAAAAAAABA1BFMAgAAAAAAAIg6gkkAAAAAAAAAUUcwCQAAAAAAACDqCCYBAAAAAAAAKNr+H3xKLe0sK7WpAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1600x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(16, 5))\n",
    "draw_qq_scores(quantiles_cal, ax[0])\n",
    "ax[0].set_title(\"Calibration\")\n",
    "draw_qq_scores(quantiles_test, ax[1])\n",
    "ax[1].set_title(\"Test\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "384bab4a",
   "metadata": {},
   "source": [
    "### Part 2: Implement Method 5.1a (only marginal calibration)\n",
    "\n",
    "Scores $S_i = || \\tilde{Q}_{Y|X}^{-1}(X_i, Y_i) ||$, for $(X_i, Y_i) \\in \\mathcal{D}_{\\mathrm{cal}}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "f7f44340",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_cal_51a = np.linalg.norm(quantiles_cal, axis=1)\n",
    "scores_test_51a = np.linalg.norm(quantiles_test, axis=1)\n",
    "\n",
    "threshold_51a = np.quantile(scores_cal_51a, q=(ds.n_cal + 1) * (1 - alpha) / ds.n_cal)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "14face63",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:22<00:00,  2.29s/it, Worst-slab=0.854, +-=0.048]\n"
     ]
    }
   ],
   "source": [
    "import tqdm\n",
    "is_covered_51a = scores_test_51a <= threshold_51a\n",
    "list_of_wsc_51 = []\n",
    "\n",
    "trange = tqdm.trange(10)\n",
    "\n",
    "for i in trange:\n",
    "    cov_51a = is_covered_51a.mean()\n",
    "    wsc_51a = wsc_unbiased(ds.X_test, is_covered_51a, delta=0.1, M=10000, random_state=i, n_cpus=8)\n",
    "    list_of_wsc_51.append(wsc_51a)\n",
    "    if i >= 2:\n",
    "        trange.set_postfix({\n",
    "            \"Worst-slab\":torch.tensor(list_of_wsc_51).mean().item(),\n",
    "            \"+-\":torch.tensor(list_of_wsc_51).std().item()\n",
    "        })"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e4902c64",
   "metadata": {},
   "source": [
    "### Part 3: Implement Method 5.1b (re-calibration)\n",
    "\n",
    "Split calibration set in half and use static Monge-Cantorovich reranking."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "396bb0b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# From official implementation of OT-CP paper\n",
    "from conformal.otcp.functions_refactor import MultivQuantileTresholdRefactor, RankFuncRefactor\n",
    "\n",
    "\n",
    "def _get_coverage_otcp(scores, mu, psi, q_hat, verbose=False):\n",
    "    # Computing coverage on test set\n",
    "    ConditionalRank = RankFuncRefactor(scores, mu, psi)\n",
    "    rank_1d = np.linalg.norm(ConditionalRank, axis=1)\n",
    "    if verbose:\n",
    "        print(f\"{len(np.unique(rank_1d))=}\")\n",
    "    is_covered_otcp = rank_1d <= q_hat\n",
    "    return is_covered_otcp\n",
    "\n",
    "\n",
    "def otcp_predict_coverage(scores_cal1, scores_cal2, scores_test, q=0.9, verbose=False):\n",
    "    Quantile_Treshold, mu, psi, psi_star, data_calib = \\\n",
    "        MultivQuantileTresholdRefactor(scores_cal1, scores_cal2, alpha=q)\n",
    "\n",
    "    # Computing coverage on test set\n",
    "    is_covered_otcp = _get_coverage_otcp(scores_test, mu, psi, Quantile_Treshold, verbose=verbose)\n",
    "    return is_covered_otcp, mu, psi, Quantile_Treshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "50051e8a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:24<00:00,  2.45s/it, Worst-slab=0.848, +-=0.0443]\n"
     ]
    }
   ],
   "source": [
    "import tqdm\n",
    "is_covered_51a = scores_test_51a <= threshold_51a\n",
    "list_of_wsc_51b = []\n",
    "\n",
    "trange = tqdm.trange(10)\n",
    "\n",
    "for i in trange:\n",
    "    n1 = ds.n_cal // 2\n",
    "\n",
    "    is_covered_51b, mu, psi, threshold_51b = otcp_predict_coverage(\n",
    "        scores_cal1=quantiles_cal[:n1],\n",
    "        scores_cal2=quantiles_cal[n1:],\n",
    "        scores_test=quantiles_test,\n",
    "        q=1 - alpha\n",
    "    )\n",
    "\n",
    "    cov_51b = is_covered_51b.mean()\n",
    "    wsc_51b = wsc_unbiased(ds.X_test, is_covered_51b, delta=0.1, M=10000, random_state=i, n_cpus=8, verbose=False)\n",
    "    list_of_wsc_51b.append(wsc_51b)\n",
    "\n",
    "    if i >= 2:\n",
    "        trange.set_postfix({\n",
    "            \"Worst-slab\":torch.tensor(list_of_wsc_51b).mean().item(),\n",
    "            \"+-\":torch.tensor(list_of_wsc_51b).std().item()\n",
    "        })\n",
    "    \n",
    "# for rs in range(10):\n",
    "#     n1 = ds.n_cal // 2\n",
    "\n",
    "#     is_covered_51b, mu, psi, threshold_51b = otcp_predict_coverage(\n",
    "#         scores_cal1=quantiles_cal[:n1],\n",
    "#         scores_cal2=quantiles_cal[n1:],\n",
    "#         scores_test=quantiles_test,\n",
    "#         q=1 - alpha\n",
    "#     )\n",
    "\n",
    "#     cov_51b = is_covered_51b.mean()\n",
    "#     wsc_51b = wsc_unbiased(ds.X_test, is_covered_51b, delta=0.1, M=10000, random_state=rs, n_cpus=8, verbose=False)\n",
    "#     display(\n",
    "#         Markdown(\n",
    "#             r\"#### $\\mathcal{C}_{\\rho}^{\\mathrm{rpb}}$ Marginal coverage: \" +\n",
    "#             f\"**{cov_51b:.2f}**, \" +\n",
    "#             f\"worst-slab conditional coverage: **{wsc_51b:.2f}**\"\n",
    "#         )\n",
    "#     )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "88343971",
   "metadata": {},
   "source": [
    "To get good conditional coverage, reranking map has to be fitted on a large sample."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f873b963",
   "metadata": {},
   "source": [
    "### Part 4: implement Method 5.2 HPD-based scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "2202df91",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.func import hessian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "d5e7a3ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "compute_batch_hessian = torch.vmap(func=hessian(reg.model.potential_network, argnums=1), \n",
    "                                   in_dims=0, chunk_size=1024)\n",
    "\n",
    "U_cal = reg.model.push_y_given_x(y=torch.tensor(ds.Y_cal), x=torch.tensor(ds.X_cal))\n",
    "U_test = reg.model.push_y_given_x(y=torch.tensor(ds.Y_test), x=torch.tensor(ds.X_test))\n",
    "\n",
    "hessians_cal = compute_batch_hessian(torch.tensor(ds.X_cal), U_cal).squeeze()\n",
    "hessians_test = compute_batch_hessian(torch.tensor(ds.X_test), U_test).squeeze()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "0d2c95f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "logdet_hessians_cal = torch.logdet(hessians_cal).numpy(force=True)\n",
    "logdet_hessians_test = torch.logdet(hessians_test).numpy(force=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "a6ebaa3a",
   "metadata": {},
   "outputs": [],
   "source": [
    "log_f_u_cal = multivariate_normal.logpdf(U_cal, mean=np.zeros(2))\n",
    "log_f_u_test = multivariate_normal.logpdf(U_test, mean=np.zeros(2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "a37127f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_cal_52 = log_f_u_cal - logdet_hessians_cal\n",
    "scores_test_52 = log_f_u_test - logdet_hessians_test\n",
    "\n",
    "# scores_cal_52 = reg.model.flow.logp(torch.tensor(ds.Y_cal), torch.tensor(ds.X_cal)).numpy(force=True)\n",
    "# scores_test_52 = reg.model.flow.logp(torch.tensor(ds.Y_test), torch.tensor(ds.X_test)).numpy(force=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "3df3b09b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1037.,  299.,  277.,  213.,  121.,   37.,   14.,    0.,    0.,\n",
       "           2.]),\n",
       " array([1.43530505e-197, 6.84680778e+001, 1.36936156e+002, 2.05404234e+002,\n",
       "        2.73872311e+002, 3.42340389e+002, 4.10808467e+002, 4.79276545e+002,\n",
       "        5.47744623e+002, 6.16212701e+002, 6.84680778e+002]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(torch.exp(torch.tensor(scores_cal_52)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "e1967113",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.70**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.78**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.72**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.70**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.71**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.68**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.69**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.75**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.74**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: **0.90**, worst-slab conditional coverage: **0.72**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for rs in range(10):\n",
    "    threshold_52 = np.quantile(scores_cal_52, q=(ds.n_cal + 1) * (alpha) / ds.n_cal)\n",
    "\n",
    "    is_covered_52 = scores_test_52 >= threshold_52\n",
    "\n",
    "    cov_52 = is_covered_52.mean()\n",
    "    wsc_52 = wsc_unbiased(ds.X_test, is_covered_52, delta=0.1, M=10000, random_state=rs, n_cpus=8)\n",
    "\n",
    "    display(\n",
    "        Markdown(\n",
    "            r\"#### $\\mathcal{C}_{\\rho}^{\\mathrm{HPD}}$ Marginal coverage: \" +\n",
    "            f\"**{cov_52:.2f}**, \" +\n",
    "            f\"worst-slab conditional coverage: **{wsc_52:.2f}**\"\n",
    "        )\n",
    "    )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "04910594",
   "metadata": {},
   "source": [
    "## Part 5: estimate areas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "deb4523c",
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm.auto import tqdm\n",
    "\n",
    "\n",
    "ymin = ds.Y_train.min(axis=0)\n",
    "ymax = ds.Y_train.max(axis=0)\n",
    "\n",
    "scale = np.prod(ymax - ymin)\n",
    "n_samples = 10000\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "8d32ed9f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([-1.9536383, -3.2120101], dtype=float32),\n",
       " array([49.861794 ,  3.4745758], dtype=float32),\n",
       " np.float32(346.46835))"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ymin, ymax, scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "b4f9c4fc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((20000000, 8), (20000000, 2))"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_test_sampled = np.repeat(ds.X_test, repeats=n_samples, axis=0)\n",
    "Y_test_sampled = ymin + np.random.default_rng(31337).random((n_samples * ds.n_test, 2)\n",
    "                                         ) * (ymax - ymin)\n",
    "X_test_sampled.shape, Y_test_sampled.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "07020fb6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([-0.7403489,  1.4478455], dtype=float32),\n",
       " array([16.5920897,  2.4752225]))"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds.Y_test[0], Y_test_sampled[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "d79b1623",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAHXlJREFUeJzt3QtsX2X9P/DPVugml3ZgZYXZOAEFF2TFjs1pFPxZnUqMJF6qUTcXncYLXqYJq5dO8TL8AXMGKlPi1HgJjYqXqBSlijdqpp1ELjKDBjeZ69YoLZSkM23/ec7v30phHf1u3+1pv329kpPtnD3nfJ/vN02/733O8zxnzujo6GgAAGQyN9cLAwAkwggAkJUwAgBkJYwAAFkJIwBAVsIIAJCVMAIAZCWMAABZHRczwMjISOzZsydOPvnkmDNnTu7uAABTkNZVfeihh+KMM86IuXPnzuwwkoJIQ0ND7m4AAIdh9+7d8dSnPnVmh5FUERl7MzU1Nbm7AwBMwcDAQFFMGPsen9FhZOzWTAoiwggAzCxPNMTCAFYAICthBADIShgBALISRgCAmRdG2tvbY/HixTF//vxYsWJFbN++fdK2F198cTFw5bHbJZdcciT9BgBmaxjp6OiI9evXx8aNG2PHjh2xdOnSWLVqVezbt++g7W+66ab45z//Ob7dddddUVVVFa997WvL0X8AYLaFkc2bN8e6deti7dq1sWTJkti6dWuccMIJsW3btoO2P/XUU6O+vn58+9nPfla0F0YAgJLDyIEDB6Knpyeam5vHj6XlXdN+d3f3lK7x5S9/OV7/+tfHiSeeOGmboaGhYqGUR28AQGUqKYz09fXF8PBwLFy4cMLxtL93794nPD+NLUm3ad72trcdst2mTZuitrZ2fLMUPABUrmM6myZVRZ797GfH8uXLD9mutbU1+vv7x7e0DDwAUJlKWg6+rq6uGHza29s74XjaT+NBDmVwcDBuvPHGuOKKK57wdebNm1dsAEDlK6kyUl1dHU1NTdHV1TV+bGRkpNhfuXLlIc/99re/XYwFedOb3nT4vQUAKk7JD8pL03rXrFkTy5YtK263bNmypah6pNk1yerVq2PRokXFuI/H3qK59NJL48lPfnL5eg8AzL4w0tLSEvv374+2trZi0GpjY2N0dnaOD2rdtWtXMcPm0Xbu3Bm/+c1v4qc//Wn5eg4AVIQ5o6OjozHNpam9aVZNGsxaU1OTuzvMMLfeM3GM03TQvGTijDSASjTV72/PpgEAshJGAICshBEAICthBADIShgBALISRgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJGAICshBEAICthBADIShgBALISRgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJGAICshBEAICthBADIShgBALISRgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJGAICshBEAICthBACYeWGkvb09Fi9eHPPnz48VK1bE9u3bD9n+wQcfjHe/+91x+umnx7x58+KZz3xm/OQnPzncPgMAFeS4Uk/o6OiI9evXx9atW4sgsmXLlli1alXs3LkzTjvttMe1P3DgQLzkJS8p/u073/lOLFq0KP7+97/HggULyvUeAIDZFEY2b94c69ati7Vr1xb7KZT8+Mc/jm3btsWGDRse1z4d/9e//hW33357HH/88cWxVFUBACj5Nk2qcvT09ERzc/P4sblz5xb73d3dBz3nhz/8YaxcubK4TbNw4cI477zz4jOf+UwMDw9P+jpDQ0MxMDAwYQMAKlNJYaSvr68IESlUPFra37t370HP+dvf/lbcnknnpXEiH/vYx+Kaa66JT33qU5O+zqZNm6K2tnZ8a2hoKKWbAMAMctRn04yMjBTjRb70pS9FU1NTtLS0xEc+8pHi9s5kWltbo7+/f3zbvXv30e4mADATxozU1dVFVVVV9Pb2Tjie9uvr6w96TppBk8aKpPPGPOtZzyoqKem2T3V19ePOSTNu0gYAVL6SKiMpOKTqRldX14TKR9pP40IO5vnPf37cd999Rbsxf/nLX4qQcrAgAgDMLiXfpknTem+44Yb42te+Fn/+85/jne98ZwwODo7Prlm9enVxm2VM+vc0m+Z973tfEULSzJs0gDUNaAUAKHlqbxrzsX///mhraytutTQ2NkZnZ+f4oNZdu3YVM2zGpMGnt9xyS3zgAx+I888/v1hnJAWTyy+/vLzvBACYkeaMjo6OxjSXpvamWTVpMGtNTU3u7jDD3HrPxDFO00Hzkokz0gAq0VS/vz2bBgDIShgBALISRgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJG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3JzR0dHRUk5IlZALL7wwrrvuumJ/ZGQkGhoa4rLLLosNGzZM6RrPec5z4pJLLolPfvKTU2o/MDAQtbW10d/fHzU1NaV0l9ns/9+muWP39LtN09iwIG8Hznl53tcHZoWBKX5/l1QZOXDgQPT09ERzc/N/LzB3brGfKh9PJOWerq6u2LlzZ7zwhS+ctN3Q0FDxBh69AQCVqaQw0tfXF8PDw7Fw4cIJx9P+3r17Jz0vJaKTTjopqquri4rItddeGy95yUsmbb9p06YiSY1tqfICAFSmYzK19+STT4477rgjfv/738enP/3pYszJbbfdNmn71tbWIsCMbbt37z4W3QQApvvU3rq6uqiqqore3t4Jx9N+fX39pOelWzlnn3128fc0m+bPf/5zUf24+OKLD9p+3rx5xQYAVL6SKiPpNktTU1Mx7mNMGsCa9leuXDnl66Rz0rgQAICSFz1Lt1jWrFlTrB2yfPny2LJlSwwODhbTdZPVq1fHokWLispHkv5Mbc8666wigPzkJz8p1hm5/vrry/9uAIDKDyMtLS2xf//+aGtrKwatptsunZ2d44Nad+3aVdyWGZOCyrve9a74xz/+EU960pPi3HPPjW984xvFdQAASl5nJAfrjHBYrDMyOeuMADN1nREAgHLzoDzIIHe1pm944oy45iUT1w4COJZURgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJGAICshBEAICthBADIShgBALISRgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJGAICshBEAICthBADIShgBALISRgCArIQRACArYQQAyEoYAQCyEkYAgKyEEQAgK2EEAMhKGAEAshJGAICsjsv78lSaW+/pjemibs+DubsAwBSojAAAWamMkE3dnp/n7gIA04DKCACQlTACAMy8MNLe3h6LFy+O+fPnx4oVK2L79u2Ttr3hhhviBS94QZxyyinF1tzcfMj2AMDsUnIY6ejoiPXr18fGjRtjx44dsXTp0li1alXs27fvoO1vu+22eMMb3hC/+MUvoru7OxoaGuKlL31pPPDAA+XoPwAww80ZHR0dLeWEVAm58MIL47rrriv2R0ZGioBx2WWXxYYNG57w/OHh4aJCks5fvXr1lF5zYGAgamtro7+/P2pqakrpLtN4aq8BrPn0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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.hist(ds.Y_test[:, 0], label='Test', alpha=0.3, density=True)\n",
    "plt.hist(ds.Y_test[:, 1], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 2], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 3], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 3], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 4], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 5], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 6], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(ds.Y_test[:, 7], label='Test', alpha=0.3, density=True)\n",
    "# plt.hist(Y_test_sampled[:, 1], label='Samples for areas', alpha=0.3, density=True)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "de86e8e8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(20000000,)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ccd23311afb64db88ea8dd273e9b418f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/2000 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "RuntimeError",
     "evalue": "mixed dtype (CPU): all inputs must share same datatype.",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mRuntimeError\u001b[39m                              Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[55]\u001b[39m\u001b[32m, line 8\u001b[39m\n\u001b[32m      5\u001b[39m     start = i * n_samples\n\u001b[32m      6\u001b[39m     stop = (i + \u001b[32m1\u001b[39m) * n_samples\n\u001b[32m      7\u001b[39m     quantiles_test_sampled[start:stop] = \\\n\u001b[32m----> \u001b[39m\u001b[32m8\u001b[39m         \u001b[43mreg\u001b[49m\u001b[43m.\u001b[49m\u001b[43mpredict_quantile\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX_test_sampled\u001b[49m\u001b[43m[\u001b[49m\u001b[43mstart\u001b[49m\u001b[43m:\u001b[49m\u001b[43mstop\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mY_test_sampled\u001b[49m\u001b[43m[\u001b[49m\u001b[43mstart\u001b[49m\u001b[43m:\u001b[49m\u001b[43mstop\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m      9\u001b[39m     is_covered_sampled_51b[start:stop] = \\\n\u001b[32m     10\u001b[39m         _get_coverage_otcp(quantiles_test_sampled[start:stop], mu, psi, threshold_51b, verbose=\u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[32m     13\u001b[39m is_covered_sampled_51a = np.linalg.norm(quantiles_test_sampled, axis=\u001b[32m1\u001b[39m) <= threshold_51a\n",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[20]\u001b[39m\u001b[32m, line 56\u001b[39m, in \u001b[36mOurCVQRegressor.predict_quantile\u001b[39m\u001b[34m(self, X, Y)\u001b[39m\n\u001b[32m     55\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mpredict_quantile\u001b[39m(\u001b[38;5;28mself\u001b[39m, X, Y):\n\u001b[32m---> \u001b[39m\u001b[32m56\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m.\u001b[49m\u001b[43mpush_y_given_x\u001b[49m\u001b[43m(\u001b[49m\u001b[43my\u001b[49m\u001b[43m=\u001b[49m\u001b[43mtorch\u001b[49m\u001b[43m.\u001b[49m\u001b[43mtensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mY\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\n\u001b[32m     57\u001b[39m \u001b[43m                                     \u001b[49m\u001b[43mx\u001b[49m\u001b[43m=\u001b[49m\u001b[43mtorch\u001b[49m\u001b[43m.\u001b[49m\u001b[43mtensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m.numpy(force=\u001b[38;5;28;01mTrue\u001b[39;00m)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/conditional_quantile_function/.venv/lib/python3.13/site-packages/torch/utils/_contextlib.py:116\u001b[39m, in \u001b[36mcontext_decorator.<locals>.decorate_context\u001b[39m\u001b[34m(*args, **kwargs)\u001b[39m\n\u001b[32m    113\u001b[39m \u001b[38;5;129m@functools\u001b[39m.wraps(func)\n\u001b[32m    114\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mdecorate_context\u001b[39m(*args, **kwargs):\n\u001b[32m    115\u001b[39m     \u001b[38;5;28;01mwith\u001b[39;00m ctx_factory():\n\u001b[32m--> \u001b[39m\u001b[32m116\u001b[39m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/conditional_quantile_function/src/pushforward_operators/neural_quantile_regression/neural_quantile_regression.py:327\u001b[39m, in \u001b[36mNeuralQuantileRegression.push_y_given_x\u001b[39m\u001b[34m(self, y, x)\u001b[39m\n\u001b[32m    324\u001b[39m \u001b[38;5;129m@torch\u001b[39m.enable_grad()\n\u001b[32m    325\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mpush_y_given_x\u001b[39m(\u001b[38;5;28mself\u001b[39m, y: torch.Tensor, x: torch.Tensor) -> torch.Tensor:\n\u001b[32m    326\u001b[39m     X_tensor = x\n\u001b[32m--> \u001b[39m\u001b[32m327\u001b[39m     Y_scaled = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mY_scaler\u001b[49m\u001b[43m(\u001b[49m\u001b[43my\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    329\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m.potential_to_estimate_with_neural_network == \u001b[33m\"\u001b[39m\u001b[33my\u001b[39m\u001b[33m\"\u001b[39m:\n\u001b[32m    330\u001b[39m         U_tensor = \u001b[38;5;28mself\u001b[39m.gradient_inverse(X_tensor, Y_scaled)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/conditional_quantile_function/.venv/lib/python3.13/site-packages/torch/nn/modules/module.py:1751\u001b[39m, in \u001b[36mModule._wrapped_call_impl\u001b[39m\u001b[34m(self, *args, **kwargs)\u001b[39m\n\u001b[32m   1749\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m._compiled_call_impl(*args, **kwargs)  \u001b[38;5;66;03m# type: ignore[misc]\u001b[39;00m\n\u001b[32m   1750\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m-> \u001b[39m\u001b[32m1751\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_call_impl\u001b[49m\u001b[43m(\u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/conditional_quantile_function/.venv/lib/python3.13/site-packages/torch/nn/modules/module.py:1762\u001b[39m, in \u001b[36mModule._call_impl\u001b[39m\u001b[34m(self, *args, **kwargs)\u001b[39m\n\u001b[32m   1757\u001b[39m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[32m   1758\u001b[39m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[32m   1759\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m._backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m._backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m._forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m._forward_pre_hooks\n\u001b[32m   1760\u001b[39m         \u001b[38;5;129;01mor\u001b[39;00m _global_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[32m   1761\u001b[39m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[32m-> \u001b[39m\u001b[32m1762\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1764\u001b[39m result = \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[32m   1765\u001b[39m called_always_called_hooks = \u001b[38;5;28mset\u001b[39m()\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/conditional_quantile_function/.venv/lib/python3.13/site-packages/torch/nn/modules/batchnorm.py:193\u001b[39m, in \u001b[36m_BatchNorm.forward\u001b[39m\u001b[34m(self, input)\u001b[39m\n\u001b[32m    186\u001b[39m     bn_training = (\u001b[38;5;28mself\u001b[39m.running_mean \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m) \u001b[38;5;129;01mand\u001b[39;00m (\u001b[38;5;28mself\u001b[39m.running_var \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m)\n\u001b[32m    188\u001b[39m \u001b[38;5;250m\u001b[39m\u001b[33mr\u001b[39m\u001b[33;03m\"\"\"\u001b[39;00m\n\u001b[32m    189\u001b[39m \u001b[33;03mBuffers are only updated if they are to be tracked and we are in training mode. Thus they only need to be\u001b[39;00m\n\u001b[32m    190\u001b[39m \u001b[33;03mpassed when the update should occur (i.e. in training mode when they are tracked), or when buffer stats are\u001b[39;00m\n\u001b[32m    191\u001b[39m \u001b[33;03mused for normalization (i.e. in eval mode when buffers are not None).\u001b[39;00m\n\u001b[32m    192\u001b[39m \u001b[33;03m\"\"\"\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m193\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mF\u001b[49m\u001b[43m.\u001b[49m\u001b[43mbatch_norm\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m    194\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[32m    195\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;66;43;03m# If buffers are not to be tracked, ensure that they won't be updated\u001b[39;49;00m\n\u001b[32m    196\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mrunning_mean\u001b[49m\n\u001b[32m    197\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43;01mif\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;129;43;01mnot\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mtraining\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01mor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mtrack_running_stats\u001b[49m\n\u001b[32m    198\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43;01melse\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m    199\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mrunning_var\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mif\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;129;43;01mnot\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mtraining\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01mor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mtrack_running_stats\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01melse\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m    200\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mweight\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    201\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mbias\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    202\u001b[39m \u001b[43m    \u001b[49m\u001b[43mbn_training\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    203\u001b[39m \u001b[43m    \u001b[49m\u001b[43mexponential_average_factor\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    204\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43meps\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    205\u001b[39m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/conditional_quantile_function/.venv/lib/python3.13/site-packages/torch/nn/functional.py:2822\u001b[39m, in \u001b[36mbatch_norm\u001b[39m\u001b[34m(input, running_mean, running_var, weight, bias, training, momentum, eps)\u001b[39m\n\u001b[32m   2819\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m training:\n\u001b[32m   2820\u001b[39m     _verify_batch_size(\u001b[38;5;28minput\u001b[39m.size())\n\u001b[32m-> \u001b[39m\u001b[32m2822\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mtorch\u001b[49m\u001b[43m.\u001b[49m\u001b[43mbatch_norm\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m   2823\u001b[39m \u001b[43m    \u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[32m   2824\u001b[39m \u001b[43m    \u001b[49m\u001b[43mweight\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2825\u001b[39m \u001b[43m    \u001b[49m\u001b[43mbias\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2826\u001b[39m \u001b[43m    \u001b[49m\u001b[43mrunning_mean\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2827\u001b[39m \u001b[43m    \u001b[49m\u001b[43mrunning_var\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2828\u001b[39m \u001b[43m    \u001b[49m\u001b[43mtraining\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2829\u001b[39m \u001b[43m    \u001b[49m\u001b[43mmomentum\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2830\u001b[39m \u001b[43m    \u001b[49m\u001b[43meps\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2831\u001b[39m \u001b[43m    \u001b[49m\u001b[43mtorch\u001b[49m\u001b[43m.\u001b[49m\u001b[43mbackends\u001b[49m\u001b[43m.\u001b[49m\u001b[43mcudnn\u001b[49m\u001b[43m.\u001b[49m\u001b[43menabled\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   2832\u001b[39m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[31mRuntimeError\u001b[39m: mixed dtype (CPU): all inputs must share same datatype."
     ]
    }
   ],
   "source": [
    "is_covered_sampled_51b = np.zeros(ds.n_test * n_samples)\n",
    "quantiles_test_sampled = np.zeros((ds.n_test * n_samples, 2))\n",
    "print(is_covered_sampled_51b.shape)\n",
    "for i in tqdm(range(ds.n_test)):\n",
    "    start = i * n_samples\n",
    "    stop = (i + 1) * n_samples\n",
    "    quantiles_test_sampled[start:stop] = \\\n",
    "        reg.predict_quantile(X_test_sampled[start:stop], Y_test_sampled[start:stop])\n",
    "    is_covered_sampled_51b[start:stop] = \\\n",
    "        _get_coverage_otcp(quantiles_test_sampled[start:stop], mu, psi, threshold_51b, verbose=False)\n",
    "\n",
    "\n",
    "is_covered_sampled_51a = np.linalg.norm(quantiles_test_sampled, axis=1) <= threshold_51a\n",
    "\n",
    "is_covered_sampled_51a.shape, is_covered_sampled_51b.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "7ac1ae74",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1349.92793945, 2503.44224426,  414.15608348, ...,  273.45274222,\n",
       "        193.61996584,  331.65930173], shape=(20000000,))"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.linalg.norm(quantiles_test_sampled, axis=1)**2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "3796d851",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import stats\n",
    "\n",
    "\n",
    "def draw_qq_scores(scores, ax):\n",
    "    n, d = scores.shape\n",
    "    for j in range(d):\n",
    "        stats.probplot(\n",
    "            scores[:, j],\n",
    "            dist=\"norm\",\n",
    "            fit=False,\n",
    "            plot=ax,\n",
    "        )\n",
    "        ax.get_lines()[j].set_markerfacecolor(f'C{j}')\n",
    "        ax.get_lines()[j].set_markeredgecolor(f'C{j}')\n",
    "    ax.plot([-3, 3], [-3, 3], ls='--', c='k')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "de86e8e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "44e79d36be41404eaf682fa444673d65",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/250 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0 80000\n",
      "200 16000000 16080000\n"
     ]
    }
   ],
   "source": [
    "import gc\n",
    "\n",
    "reg.model.cpu()\n",
    "_compute_batch_hessian = torch.vmap(func=hessian(reg.model.potential_network, argnums=1), \n",
    "                                   in_dims=0, chunk_size=8192)\n",
    "\n",
    "log_det_hessians_test_samples = np.zeros(ds.n_test * n_samples)\n",
    "for i in tqdm(range(ds.n_test // 8)):\n",
    "    start = i * n_samples * 8\n",
    "    stop = (i + 1) * n_samples * 8\n",
    "    if i % 200 == 0:\n",
    "        print(i, start, stop)\n",
    "\n",
    "    _hessians = _compute_batch_hessian(\n",
    "        torch.tensor(X_test_sampled[start:stop]),\n",
    "        torch.tensor(Y_test_sampled[start:stop])\n",
    "    )[:, 0].detach()\n",
    "\n",
    "    log_det_hessians_test_samples[start:stop] = \\\n",
    "        torch.logdet(_hessians).squeeze().detach().numpy(force=True)\n",
    "\n",
    "    if i > 0 and i % 100 == 0:\n",
    "        gc.collect()\n",
    "_ = reg.model.cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "2181dee8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "log_det_hessians_test_samples.shape=(20000000,)\n"
     ]
    }
   ],
   "source": [
    "print(f\"{log_det_hessians_test_samples.shape=}\")\n",
    "log_f_u_test_samples = multivariate_normal.logpdf(quantiles_test_sampled, mean=np.zeros(4))\n",
    "log_dets_test_sampled = log_det_hessians_test_samples\n",
    "scores_test_sampled_52 = log_f_u_test_samples + log_dets_test_sampled\n",
    "is_covered_sampled_52 = scores_test_sampled_52 >= threshold_52"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "177164ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((20000000, 4),)"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "quantiles_test_sampled.shape, "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "1f7ad6e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = ds.X_test[0:1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "976cf932",
   "metadata": {},
   "outputs": [],
   "source": [
    "Y_max_tensor, Y_min_tensor = torch.tensor(ymax), torch.tensor(ymin)\n",
    "X_tensor = torch.tensor(X).repeat((10_000, 1))\n",
    "Y_tensor = Y_min_tensor + torch.rand((10_000, 4)) * (Y_max_tensor - Y_min_tensor)\n",
    "U_tensor = torch.randn(10_000, 4).to(Y_tensor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f43032a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "5fd75275",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(Y_tensor[:, 0])\n",
    "plt.hist(reg.model.push_u_given_x(U_tensor, X_tensor)[:, 0])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "599f2062",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1.000e+00, 9.000e+00, 1.390e+02, 6.810e+02, 2.065e+03, 3.073e+03,\n",
       "        2.543e+03, 1.152e+03, 3.030e+02, 3.400e+01]),\n",
       " array([-4.50258255, -3.71246505, -2.92234755, -2.13223004, -1.34211254,\n",
       "        -0.55199504,  0.23812246,  1.0282402 ,  1.81835747,  2.60847473,\n",
       "         3.39859247]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Kkx4iYiIkN27d8vp06dl4sSJ0qxZM/nzn/9cH9UFAACWqZcAo4FFA8iFCgsL5W9/+5usW7dO7rjjDvPY6tWrpXfv3rJnzx655ZZbZNu2bXLs2DETgMLDw+X666+Xp59+WubPn296dwICAuqjykCjxsB0ALaplzEwn332mURGRso111wj999/v7kkpA4cOCBlZWUSGxvrLquXlzp37iwZGRlmX2/79etnwotLfHy8FBUVydGjRy/6miUlJaZM1Q0AAPimOg8wAwcOlJSUFElNTZWVK1dKVlaWDB48WM6ePSu5ubmmByU0NNTjORpW9JjS26rhxXXcdexikpKSzCUp1xYVFVXXPxoAAPDVS0jDhw933+/fv78JNF26dJENGzZIUFCQ1JfExESZM2eOe197YAgxAAD4pnqfRq29Lddee62cOHHCjIspLS2VgoICjzI6C8k1ZkZvL5yV5NqvblyNS2BgoAQHB3tsAADAN9V7gPnuu+/k888/l44dO0p0dLSZTZSenu4+npmZacbIxMTEmH29PXz4sOTn57vLpKWlmUDSp0+f+q4uAABojJeQfve738nIkSPNZaNTp07JE088IU2aNJFf//rXZmzK5MmTzaWesLAwE0pmzpxpQovOQFJxcXEmqEyYMEGSk5PNuJcFCxaYtWO0lwUAAKDOA8yXX35pwsrXX38t7du3l0GDBpkp0npfLVu2TPz9/c0CdjpzSGcYrVixwv18DTubN2+W6dOnm2DTsmVLmTRpkjz11FN1XVUAAGApP8dxHPFBOohXe3x07Zm6Hg/DmhmA/bKbj/fq63ctXufV10fDkr14hLerYN3nN9+FBAAArEOAAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsU+dfJQAAAHx/hfdsL68eTA8MAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1mEYNAF6Q3Xz8RY91LV53VesC2IgeGAAAYB0CDAAAsA4BBgAAWIcAAwAArEOAAQAA1iHAAAAA6xBgAACAdQgwAADAOgQYAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6BBgAAGCdpt6uAADUp+zm471dBQD1gB4YAABgHQIMAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6BBgAAGAdAgwAALAOAQYAAFinQQeYF198Ubp27SrNmzeXgQMHyr59+7xdJQC4Kt/fVN0GwIIAs379epkzZ4488cQT8tFHH8mAAQMkPj5e8vPzvV01AADgZQ02wCxdulSmTJkiDz30kPTp00dWrVolLVq0kFdffdXbVQMAAF7WVBqg0tJSOXDggCQmJrof8/f3l9jYWMnIyKj2OSUlJWZzKSwsNLdFRUV1Xr/Kku/r/JwArtyR5pMveqzohz8L1uNvDxqSonr4fK16Xsdx7AswX331lVRUVEh4eLjH47p//Pjxap+TlJQkTz755I8ej4qKqrd6AmgYQqSx+H/ergDgFvKs1KuzZ89KSEiIXQHmSmhvjY6ZcamsrJRvvvlG2rZtK35+ftIQaKrUQHXy5EkJDg72dnWsRTvWHm1Ye7Rh3aAda6/Ix9pQe140vERGRl6yXIMMMO3atZMmTZpIXl6ex+O6HxERUe1zAgMDzVZVaGioNET6BvOFN5m30Y61RxvWHm1YN2jH2gv2oTa8VM9Lgx7EGxAQINHR0ZKenu7Ro6L7MTExXq0bAADwvgbZA6P0ctCkSZPkxhtvlJtvvlmeffZZOXfunJmVBAAAGrcGG2B+9atfyZkzZ2ThwoWSm5sr119/vaSmpv5oYK9N9BKXrmtz4aUu1AztWHu0Ye3RhnWDdqy9wEbahn7OT81TAgAAaGAa5BgYAACASyHAAAAA6xBgAACAdQgwAADAOgSYq+See+6Rzp07S/PmzaVjx44yYcIEOXXqlEeZQ4cOyeDBg00ZXVUxOTnZa/VtiLKzs2Xy5MnSrVs3CQoKku7du5uR9/rdWVXRjpf2pz/9SW699Vbz5agXW+wxJydHRowYYcp06NBB5s6dK+Xl5Ve9rg3Ziy++KF27djXvs4EDB8q+ffu8XaUGa9euXTJy5EizsqqujP7mm296HNe5JDrjVP826u+2fu/dZ5995rX6NkT6dTk33XSTtG7d2vxOjh49WjIzMz3KFBcXS0JCglmBvlWrVjJ27NgfLQjrSwgwV8nQoUNlw4YN5g33z3/+Uz7//HO57777PJaCjouLky5dupgvslyyZIksWrRIXn75Za/WuyHR78HSBQ1feuklOXr0qCxbtsx8S/nvf/97dxna8adp4PvlL38p06dPr/a4fg+Zhhctt3v3blmzZo2kpKSYDxj8n/Xr15u1qjRAf/TRRzJgwACJj4+X/Px8b1etQdI1vLSNNPRVR/+T8fzzz5vf571790rLli1Ne+oHMv7Pzp07TTjZs2ePpKWlSVlZmflbp23rMnv2bHnnnXdk48aNprz+J3nMmDHis3QaNa6+t956y/Hz83NKS0vN/ooVK5w2bdo4JSUl7jLz5893evbs6cVaNnzJyclOt27d3Pu04+VbvXq1ExIS8qPH//Wvfzn+/v5Obm6u+7GVK1c6wcHBHu3amN18881OQkKCe7+iosKJjIx0kpKSvFovG+jHzqZNm9z7lZWVTkREhLNkyRL3YwUFBU5gYKDzj3/8w0u1bPjy8/NNW+7cudPdZs2aNXM2btzoLvPpp5+aMhkZGY4vogfGC/RLJteuXWu68Zs1a2Yey8jIkCFDhpivUXDR/4Foj823337rxdo2bIWFhRIWFubepx1rT9uwX79+HotGahtq75b2fDV22jOlvXt6mcPF39/f7GvboWaysrLMYqVV21O/B0cvy9Gel/7bp1x///Q9qb0yVduxV69eZuiCr7YjAeYqmj9/vuka1euTOsbgrbfech/TX+ALVxl27esx/NiJEydk+fLl8pvf/Mb9GO1Ye7ThpX311VfmMlt1bUT71JyrzWjPy6eX0mfNmiW33Xab9O3b1zymbaX/cbtwXJsvtyMBphYee+wxMyDtUpuO23DRgZAff/yxbNu2zXzb9sSJE83gtcaupu2o/ve//8mdd95pxnJMmTJFGrsraUMAdtKxMEeOHJHXX39dGrMG+11INnj00UflwQcfvGSZa665xn2/Xbt2Zrv22muld+/eZoaMDsjSb9iOiIj40Whx174e82U1bUcdmKaDovUS3IWDcxtrO9a0DS9F2+nCGTWNoQ0vl/4O639Aqnuf0T4152ozbT+dheSi+/odePA0Y8YM2bx5s5nZ1alTJ4921MubBQUFHr0wvvy+JMDUQvv27c12pV2AqqSkxNxqiPnDH/5grmG6xsXoSPOePXtKmzZtxJfVpB2150XDS3R0tKxevdqMPaiqsbZjbd6LF9I21KnWOqNGp2u62jA4OFj69OkjjZ120+v7Lz093Uxldf0+675+uKBmdFkE/YDV9nMFFh1vpbORLjZTrjHS3vqZM2fKpk2bZMeOHabdqtL3pP7N03bU6dNKx/7pcAX9nfZJ3h5F3Bjs2bPHWb58ufPxxx872dnZTnp6unPrrbc63bt3d4qLi90jyMPDw50JEyY4R44ccV5//XWnRYsWzksvveTt6jcYX375pdOjRw9n2LBh5v7p06fdmwvt+NO++OIL81588sknnVatWpn7up09e9YcLy8vd/r27evExcU5Bw8edFJTU5327ds7iYmJ3q56g6HvK50lk5KS4hw7dsyZOnWqExoa6jFzCz/Q95brfaYfO0uXLjX39b2oFi9ebNpPZ2ceOnTIGTVqlJldeP78eW9XvcGYPn26mTW4Y8cOj79933//vbvMtGnTnM6dOzvbt2939u/f78TExJjNVxFgrgL9hRw6dKgTFhZm/uh17drVvNH0Q7iqTz75xBk0aJAp87Of/cz8UsNz2q/+8atuq4p2vLRJkyZV24bvvfeeu4wG7eHDhztBQUFOu3btnEcffdQpKyvzar0bGv1PiX5YBAQEmGnV+h8VVE/fW9W95/S96JpK/fjjj5v/fOjvrf4nJTMz09vVblAu9rdv9erV7jIa+H7729+apST0P2733nuvx3/wfI2f/uPtXiAAAICaYBYSAACwDgEGAABYhwADAACsQ4ABAADWIcAAAADrEGAAAIB1CDAAAMA6BBgAAGAdAgwAALAOAQYAAFiHAAMAAKxDgAEAAGKb/w/IPrKCeeKEigAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(reg.model.push_y_given_x(Y_tensor, X_tensor)[:, 0])\n",
    "plt.hist(torch.randn(10_000))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "19fe32a2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([4.91650256, 4.96865414, 6.84131262, ..., 6.71111284, 6.10256249,\n",
       "        5.03675056], shape=(20000000,)),\n",
       " array([ -678.63972386, -1255.39687626,  -210.75379587, ...,\n",
       "         -140.40212524,  -100.48573705,  -169.505405  ], shape=(20000000,)))"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "log_det_hessians_test_samples, log_f_u_test_samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "558b855b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20000000,)"
      ]
     },
     "execution_count": 80,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "is_covered_sampled_51a.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "7608eb0b",
   "metadata": {},
   "outputs": [],
   "source": [
    "areas_51a, areas_51b, areas_52 = map(lambda t: t.reshape(ds.n_test, n_samples).mean(axis=-1) * scale, \n",
    "                                     (is_covered_sampled_51a, is_covered_sampled_51b, is_covered_sampled_52))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "961a6471",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.0)"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "areas_51a[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "819291d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1892.,   47.,   28.,   10.,    8.,    3.,    3.,    2.,    4.,\n",
       "           3.]),\n",
       " array([0.        , 0.48967021, 0.97934041, 1.46901062, 1.95868083,\n",
       "        2.44835104, 2.93802124, 3.42769145, 3.91736166, 4.40703186,\n",
       "        4.89670207]),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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wkty3nnnRZs2beK5555rOGf48OE5vFSMHDkyVq5cGe+9995eX3Pbtm2556bxBgC0TDUPMGn46J//+Z/jsccei7/5m7+JJ598MvfY7Nq1Kx9fv359DjeNtWvXLrp165aPVc7p1atX1TmV/co5Hzdz5szo0qVLw5bqZgCAlmmfh5A+y7e//e2G+6ecckoMHDgwjjnmmNwrc+6550ZTmTZtWkyZMqVhP/XACDEA0DI1+TTqo48+Onr06BGrVq3K+6k2ZuPGjVXn7Ny5M89MqtTNpNsNGzZUnVPZ/6TamlR3k2Y1Nd4AgJapyQPMW2+9lWtg+vTpk/eHDh0a77//fp5dVPH444/H7t27Y8iQIQ3npJlJO3bsaDgnzVhKNTWHHXZYUzcZAGhpASat15JmBKUtWb16db6/du3afOy6666LZ599NtasWZPrYL7xjW/EF7/4xVyEm5xwwgm5Tubyyy+P559/Pp5++um48sor89BTmoGUjB07NhfwpvVh0nTrefPmxR133FE1RAQAtF77HGBefPHFOO200/KWpFCR7t94443Rtm3bvADd17/+9Tj22GNzABk8eHD88pe/zEM8FWma9PHHH59rYtL06bPOOqtqjZdUhLto0aIcjtLzr7nmmnx9U6gBgKSuvr6+viV+FKmINwWhTZs21bweZsDUR6I0a2aNbu4mAEDNvr/9FhIAUBwBBgAojgADABRHgAEAiiPAAADFEWAAgOIIMABAcQQYAKA4AgwAUBwBBgAojgADABRHgAEAiiPAAADFEWAAgOIIMABAcQQYAKA4AgwAUBwBBgAojgADABRHgAEAiiPAAADFEWAAgOIIMABAcQQYAKA4AgwAUBwBBgAojgADABRHgAEAiiPAAADFEWAAgOIIMABAcQQYAKA4AgwAUBwBBgAojgADABRHgAEAWn6Aeeqpp2LMmDHRt2/fqKuri/nz5zcc27FjR1x//fVxyimnRKdOnfI548aNi7fffrvqGgMGDMjPbbzNmjWr6pzly5fHsGHDomPHjtGvX7+YPXv27/M+AYDWHGC2bt0agwYNijlz5uxx7MMPP4yXXnop/vqv/zrfPvjgg7Fy5cr4+te/vse5N910U6xbt65hu+qqqxqObd68OUaMGBH9+/ePpUuXxq233hrTp0+Pu++++/O8RwCghWm3r08YNWpU3vamS5cusXjx4qrH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OPa9732v6hpr166N0aNHxyGHHBI9e/aM6667Lnbu3FnrpgIAhWpX6wu+8MILsWvXrob9V155Jb761a/GH/3RHzU8dvnll8dNN93UsJ+CSkV6bgovvXv3jmeeeSbWrVsX48aNi4MOOihuueWWWjcXAChQzQPM4YcfXrU/a9asOOaYY+L//b//VxVYUkDZm0WLFsWrr74ajz76aPTq1StOPfXUuPnmm+P666+P6dOnR/v27WvdZACgME1aA7N9+/b4l3/5l/iTP/mTPFRUMXfu3OjRo0ecfPLJMW3atPjwww8bji1ZsiROOeWUHF4qRo4cGZs3b44VK1Z84mtt27Ytn9N4AwBappr3wDQ2f/78eP/99+Oyyy5reGzs2LHRv3//6Nu3byxfvjz3rKxcuTIefPDBfHz9+vVV4SWp7Kdjn2TmzJkxY8aMJnsvAEArCTD33HNPjBo1KoeViokTJzbcTz0tffr0iXPPPTfeeOONPNT0eaWenClTpjTspx6Yfv36/R6tBwBaXYD5zW9+k+tYKj0rn2TIkCH5dtWqVTnApNqY559/vuqcDRs25NtPqptJOnTokDcAoOVrshqY++67L0+BTjOKPs2yZcvybeqJSYYOHRovv/xybNy4seGcxYsXR+fOnePEE09squYCAK29B2b37t05wIwfPz7atfu/l0jDRA888ECcf/750b1791wDM3ny5Bg+fHgMHDgwnzNixIgcVC699NKYPXt2rnu54YYb8joyelgAgCYLMGnoKC1Gl2YfNZamQKdjt99+e2zdujXXqFx44YU5oFS0bds2FixYEFdccUXujenUqVMOQo3XjQEAWrcmCTCpF6W+vn6Px1NgefLJJz/z+WmW0s9//vOmaBoA0AL4LSQAoDgCDABQHAEGACiOAAMAFEeAAQCKI8AAAMURYACA4ggwAEBxBBgAoDgCDABQHAEGACiOAAMAFEeAAQCKI8AAAMURYACA4ggwAEBxBBgAoDgCDABQHAEGACiOAAMAFEeAAQCKI8AAAMURYACA4ggwAEBxBBgAoDgCDABQHAEGACiOAAMAFEeAAQCKI8AAAMURYACA4ggwAEBxBBgAoDgCDABQHAEGAChOzQPM9OnTo66urmo7/vjjG45/9NFHMWnSpOjevXt84QtfiAsvvDA2bNhQdY21a9fG6NGj45BDDomePXvGddddFzt3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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(areas_51a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "807bb95a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(0.014690106215382847)"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "areas_52.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "cbd0b657",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/markdown": [
       "#### Areas \\n ${\\mathrm{PB}}$:   **0.12**,  ${\\mathrm{RPB}}$:   **0.14**,  ${\\mathrm{HPD}}$:   **0.01**,  "
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "3"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "display(\n",
    "    Markdown(\n",
    "        r\"#### Areas \\n ${\\mathrm{PB}}$:   \" +\n",
    "        f\"**{areas_51a.mean():.2f}**,  \" + \n",
    "        r\"${\\mathrm{RPB}}$:   \" +\n",
    "        f\"**{areas_51b.mean():.2f}**,  \" + \n",
    "        r\"${\\mathrm{HPD}}$:   \" +\n",
    "        f\"**{areas_52.mean():.2f}**,  \"\n",
    "    )\n",
    ")\n",
    "3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "822b94cf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(2.290341356761194),\n",
       " np.float64(0.6916916916916916),\n",
       " np.float64(2.3228225648323586))"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(threshold_51a, threshold_51b, threshold_52)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "b365c26f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(1.8e-05), np.int64(360))"
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "is_covered_sampled_52.mean(), is_covered_sampled_52.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "a1b68bf0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(0.0001422), np.int64(2844))"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "is_covered_sampled_51a.mean(), is_covered_sampled_51a.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "d8ab760d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(0.0001735), np.float64(3470.0))"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "is_covered_sampled_51b.mean(), is_covered_sampled_51b.sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "1d2123b2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0006553600000000003"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "0.4 ** 8"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "44a95bc1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ -678.63972386, -1255.39687626,  -210.75379587,  -637.18089152,\n",
       "        -1326.71034144,  -797.30617238,  -488.78149603,  -385.2672454 ,\n",
       "         -447.6891932 ,  -446.90636179]),\n",
       " array([ 4.91650256,  4.96865414,  6.84131262, -1.53886575,  3.20294564,\n",
       "         2.92461019,  3.60325096,  5.34653531,  7.91124724,  3.56430129]))"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "log_f_u_test_samples[:10], log_dets_test_sampled[:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "aab6bf05",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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NES4L554vuhaQ871l2xGYAEAoAlr166dNAY0CQEAGqVvvvnGrFp86aWXSuvWrWXIkCHy6aefepT505/+JBEREeZxXTl50aJFZv2cM03nf+2115pF+qKjo2XXrl3VyuzZs8e8nq7qHBYWJvfdd59Zn0fpasjbtm2T3//+96YpSTdtVjpbb7zxhlnZWa9LlxnQFZp/+OEH85jOXPurX/1KunTpIsHBwWb15SlTprieq+snde/e3TxXr/euu+6qtUnopZdeMvfdpk0b6dixo/z3f/+3FBYWuh7funWruafMzExTTn+2gwYNkry8PDmfCCwAgEZJg8HOnTvlzTfflKysLPOhfeutt8rp06fN4x988IFMmDBBpk6davqf6CKITz755BlXMB42bJj07t1bcnJyTAh4+OGHPcpoM81//ud/mlCjr5+RkSEFBQVyzz33mMc1qMTFxZmVob/66iuzaWg6G++9954JZ3ov+/btk2effdY0Gznv5/XXX5f/+Z//Mcc1tK1du1b69u1rHtNr1PDy61//2oQKvd7BgwfX+lr683viiSfk448/NufRsKU/66p++ctfmgUU9fy6HtEDDzwg5xNNQgCARkc/lDWoaCjRv+7VK6+8YoKBfsjefffdsmTJElML4gwcPXr0kO3bt8u6detqPe+KFSvMasZ//vOfTW3E1VdfLV9++aX84he/cJVJS0szYeW3v/2t69jy5cvNax88eNC8TlBQkKl50BqKM9Haj//93//1OKY1J/r6To8//rjMmjVLkpOTzb7WsGioeOSRRyQ1NdUsaKivlZCQYPqjaE1LTEyMKauP6WrVGsS01uSKK64w118b9+DhXDBywIABJsxpjZKThqX4+HjzvV7b0KFD5fvvv/e47nOJGhYAQKOzf/9+81d9bGys61j79u2lZ8+e5jGltQnOD22nqvs1nfeaa67x+NDV2hJ3WvOwZcsW8+Ht3Hr16mUe++yzz7y+l9GjR5saIPdNa0Oqvuavf/1rj9d01uCcOnXKBLTvvvvOBAw9vmbNGldzkdYsaUjRx7TpSoOdPqc2WrP0k5/8xIQeDTjOUKLBx53+nJwuv/xy89W96ehco4YFAAAvaE2DfqA/9dRT1R5zfnB7o23bttKtWzePYx06dKj2mo8//rjceeed1Z6v4UprdzSgvfPOO7Jp0yZ58MEH5Xe/+53pS6Oh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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.hist(log_f_u_test_samples, bins=500, density=True, alpha=0.3, label=\"log U density\")\n",
    "plt.hist(log_dets_test_sampled, bins=500, density=True, alpha=0.3, label=\"log det Hessian\")\n",
    "plt.xlim(-500, 500)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "78bf572d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "np.float64(816.1170119657136)"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "c2133833",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.       , 0.0816117, 0.       , ..., 0.1632234, 0.       ,\n",
       "       0.       ], shape=(2000,))"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "areas_51b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "02a8401f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(np.float64(0.0001422), np.float64(0.0001735), np.float64(1.8e-05))"
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "is_covered_sampled_51a.mean(), is_covered_sampled_51b.mean(), is_covered_sampled_52.mean()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.13.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
