{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "b9743249",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "6da99cdc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████| 100/100 [14:20<00:00,  8.60s/it]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.stats import norm\n",
    "\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "\n",
    "from conditionalconformal import CondConf\n",
    "\n",
    "def weighted_quantile(values, weights, quantile):\n",
    "    \"\"\"Calculates the weighted quantile of a given value distribution\n",
    "    using the strict inverse CDF definition.\n",
    "\n",
    "    Args:\n",
    "        values: A 1D array of numerical values.\n",
    "        weights: A 1D array of corresponding weights, with the same length as values.\n",
    "        quantile: The desired quantile between 0 and 1.\n",
    "\n",
    "    Returns:\n",
    "        The weighted quantile of the distribution.\n",
    "    \"\"\"\n",
    "\n",
    "    # Ensure weights are normalized\n",
    "    weights = weights / np.sum(weights)\n",
    "\n",
    "    # Sort values and weights according to ascending values order\n",
    "    order = np.argsort(values)\n",
    "    values = values[order]\n",
    "    weights = weights[order]\n",
    "\n",
    "    # Calculate cumulative sum of weights\n",
    "    cumulative_weights = np.cumsum(weights)\n",
    "\n",
    "    # Find the index where the cumulative sum exceeds the quantile\n",
    "    idx = np.searchsorted(cumulative_weights, quantile)\n",
    "\n",
    "    # Use the previous value as the quantile (inverse CDF)\n",
    "    if idx > 0:\n",
    "        return values[idx - 1]\n",
    "    else:\n",
    "        return values[0]  # Handle the case where the quantile is 0\n",
    "\n",
    "    \n",
    "def run_trial(seed, n_calib = 100, n_test = 1000):\n",
    "    rng = np.random.default_rng(seed=seed)\n",
    "\n",
    "    scores = rng.normal(size=(n_calib,))\n",
    "    weights = norm.pdf(scores)\n",
    "    \n",
    "    scores_test = rng.normal(scale=1/np.sqrt(2), size=(n_test,))[:, np.newaxis]\n",
    "    scores_baseline = rng.normal(size=(n_test,))[:, np.newaxis]\n",
    "    # Repeat arr1 for each element of arr2\n",
    "    scores_repeat = np.repeat(scores[np.newaxis, :], n_test, axis=0)\n",
    "\n",
    "    # Stack arr1_repeated with arr2 along the second axis\n",
    "    scores_concat = np.hstack((scores_repeat, scores_test))\n",
    "    \n",
    "    covs_1, covs_2 = [], []\n",
    "    \n",
    "    for scores_orig in scores_concat:\n",
    "        scores = scores.copy()\n",
    "        scores[-1] = 1e5\n",
    "        threshold = weighted_quantile(scores, weights, 0.9)\n",
    "        cov_1 = scores_orig[-1] <= threshold\n",
    "        covs_1.append(cov_1)\n",
    "\n",
    "        condconf = CondConf(score_fn = lambda x, y: x, Phi_fn = lambda x : norm.pdf(x))\n",
    "        condconf.setup_problem(scores[:-1].reshape(-1,1), np.zeros((n_calib,)))\n",
    "        threshold = condconf.predict(0.9, scores_orig[-1].reshape(-1,1), score_inv_fn= lambda t, x: t)[0]\n",
    "        cov_2 = scores_orig[-1] <= threshold\n",
    "        covs_2.append(cov_2)\n",
    "        \n",
    "    scores_concat = np.hstack((scores_repeat, scores_baseline))\n",
    "    covs_1_m, covs_2_m = [], []\n",
    "    \n",
    "    for scores_orig in scores_concat:\n",
    "        scores = scores.copy()\n",
    "        scores[-1] = 1e5\n",
    "        threshold = weighted_quantile(scores, weights, 0.9)\n",
    "        cov_1 = scores_orig[-1] <= threshold\n",
    "        covs_1_m.append(cov_1)\n",
    "\n",
    "        condconf = CondConf(score_fn = lambda x, y: x, Phi_fn = lambda x : norm.pdf(x))\n",
    "        condconf.setup_problem(scores[:-1].reshape(-1,1), np.zeros((n_calib,)))\n",
    "        threshold = condconf.predict(0.9, scores_orig[-1].reshape(-1,1), score_inv_fn= lambda t, x: t)[0]\n",
    "        cov_2 = scores_orig[-1] <= threshold\n",
    "        covs_2_m.append(cov_2)\n",
    "\n",
    "    \n",
    "    return np.mean(covs_1), np.mean(covs_2), np.mean(covs_1_m), np.mean(covs_2_m)\n",
    "\n",
    "all_covs_1 = []\n",
    "all_covs_2 = []\n",
    "all_covs_1_m = []\n",
    "all_covs_2_m = []\n",
    "for trial in tqdm(range(100)):\n",
    "    covs_1, covs_2, covs_1_m, covs_2_m = run_trial(trial)\n",
    "    all_covs_1.append(covs_1)\n",
    "    all_covs_1_m.append(covs_1_m)\n",
    "    all_covs_2.append(covs_2)\n",
    "    all_covs_2_m.append(covs_2_m)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "69b3a3fe",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAGxCAYAAACKvAkXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAABCS0lEQVR4nO3dfXzN9f/H8eexnV2auRgzbIZv2eJLmciWIkySqF+1XPs2vonKULIkohLiq2+15SIJK0oqlWS6cKPRNLqQoQszsmHDhrHLz+8Pv51fp13Y2Jzp87jfbudWn/d5fT7n9dl2Pufpc3UshmEYAgAAMJFajm4AAADgSiMAAQAA0yEAAQAA0yEAAQAA0yEAAQAA0yEAAQAA0yEAAQAA0yEAAQAA0yEAAQAA0yEAAdVs2bJlslgsdo+GDRuqW7du+uSTTxzdnk1gYKBGjBhR6flycnI0ffp0ff3111XeU0V88cUX6tixozw9PWWxWPThhx+WW3/o0CE98sgjatWqldzc3FSvXj1169ZNcXFx+uuN8VNSUmSxWLRs2bKL9jF9+nRZLJbLWJOqZ7FYNH369HJritfRYrFo1apVJZ4vXq+MjIxq6hJwDAIQcIW8+eab2rZtmxISErRo0SI5OTmpX79++vjjjx3d2mXJycnRs88+65AAZBiG7r//flmtVq1bt07btm3TrbfeWmb9N998o3bt2umjjz7SuHHjtGHDBi1btkxNmzbVkCFDNHDgQBUVFV3BNahZpkyZovz8fEe3AVwRzo5uADCLtm3bqmPHjrbp22+/XfXq1dM777yjfv36ObCzq9eRI0d04sQJ3X333erRo0e5tadOndI999wjb29vffvtt/L19bU9179/f7Vr106TJ0/W9ddfr8mTJ1d36zVOnz599Nlnn+n111/Xo48+6uh2gGrHHiDAQdzc3OTi4iKr1Wo3fuLECY0ZM0ZNmzaVi4uLWrZsqSlTpig3N1eSdP78ed1www36xz/+oaysLNt86enpaty4sbp166bCwkJJ0ogRI1S7dm39/PPP6tGjhzw9PdWwYUM98sgjysnJuWiPqampGjJkiBo1aiRXV1cFBwdr3rx5tr0kKSkpatiwoSTp2WeftR1KKT6Udvz4cf373/+Wv7+/XF1d1bBhQ4WFhWnTpk0Xfe2tW7eqR48e8vLykoeHh0JDQ/Xpp5/anp8+fbqaNWsmSXryySdlsVgUGBhY5vKWLFmiY8eO6cUXX7QLP8UmTZqkoKAgzZ0796J7QT799FNdf/31cnV1VYsWLfTSSy9ddH2KxcfHq3///mrWrJnc3Nz0j3/8Qw899FCJQ0zFh55+/vlnDRw4UN7e3vL19dWDDz5o93uXpOzsbI0aNUoNGjRQ7dq1dfvtt2v//v0V7kmSbrvtNvXu3VszZ87U6dOnL1q/adMm9ejRQ3Xq1JGHh4fCwsL0xRdf2J7/+eefZbFY9N5779nGkpKSZLFY1KZNG7tl3XXXXQoJCalUv8DlIgABV0hhYaEKCgqUn5+vw4cPKyoqSmfPntWgQYNsNefPn1f37t21fPlyTZgwQZ9++qmGDBmiOXPm6J577pF0ITi9++67OnbsmB588EFJUlFRkQYPHizDMPTOO+/IycnJtsz8/Hzdcccd6tGjhz788EM98sgjWrhwoSIiIsrt9/jx4woNDdXGjRs1c+ZMrVu3Tj179tTjjz+uRx55RJLk5+enDRs2SJIiIyO1bds2bdu2TVOnTpUkDR06VB9++KGeeeYZbdy4UUuWLFHPnj2VmZlZ7mtv3rxZt912m7KysvTGG2/onXfekZeXl/r166fVq1dLkkaOHKm1a9dKkh599FFt27ZNH3zwQZnLjI+Ptx12LI3FYtFdd92lEydOKCkpqczlfPHFF+rfv7+8vLy0atUqzZ07V++++67efPPNctep2G+//aYuXbooNjZWGzdu1DPPPKNvv/1WN998c6nB63/+53907bXX6v3339fkyZP19ttva/z48bbnDcPQgAEDtGLFCk2cOFEffPCBbrrpJvXp06dC/fzZ7NmzlZGRoblz55Zbt3LlSoWHh6tOnTp666239O6776p+/frq3bu3LQS1adNGfn5+dmF306ZNcnd31549e3TkyBFJUkFBgTZv3qyePXtWul/gshgAqtWbb75pSCrxcHV1NWJiYuxqX3/9dUOS8e6779qNz54925BkbNy40Ta2evVqQ5KxYMEC45lnnjFq1apl97xhGMbw4cMNScbLL79sN/78888bkoytW7faxpo3b24MHz7cNj158mRDkvHtt9/azfvwww8bFovF2Ldvn2EYhnH8+HFDkjFt2rQS6167dm0jKirq4j+kv7jpppuMRo0aGadPn7aNFRQUGG3btjWaNWtmFBUVGYZhGAcOHDAkGXPnzr3oMoOCgozGjRuXWxMbG2tIMlavXm23/DfffNNW07lzZ6NJkybGuXPnbGPZ2dlG/fr1jcpuUouKioz8/Hzj4MGDhiTjo48+sj03bdo0Q5IxZ84cu3nGjBljuLm52X4Gn332Wbm/49J+L3/215/h4MGDDU9PTyMtLc2uj+PHjxuGYRhnz5416tevb/Tr189uOYWFhUb79u2NTp062caGDBlitGzZ0jbds2dPY9SoUUa9evWMt956yzAMw/jmm29K/G0DVwJ7gIArZPny5dqxY4d27Nihzz77TMOHD9fYsWP16quv2mq+/PJLeXp66t5777Wbt/iQ0p8PMdx///16+OGH9cQTT+i5557TU089pV69epX62oMHD7abLt7r9NVXX5XZ75dffqnrrrtOnTp1KtGLYRj68ssvL7rOnTp10rJly/Tcc89p+/btFTrB9uzZs/r222917733qnbt2rZxJycnDR06VIcPH9a+ffsuupxLYfzfVWBlXc119uxZ7dixQ/fcc4/c3Nxs48V7pyri2LFjGj16tPz9/eXs7Cyr1armzZtLkpKTk0vU33XXXXbT7dq10/nz53Xs2DFJ//87LOt3XFnPPfec8vPz9eyzz5b6fEJCgk6cOKHhw4eroKDA9igqKtLtt9+uHTt26OzZs5KkHj166Pfff9eBAwd0/vx5bd26Vbfffru6d++u+Ph4SRf2Crm6uurmm2++pH6BS0UAAq6Q4OBgdezYUR07dtTtt9+uhQsXKjw8XJMmTdKpU6ckSZmZmWrcuHGJD+BGjRrJ2dm5xKGjBx98UPn5+XJ2dtZjjz1W6us6OzurQYMGdmONGze2vV5ZMjMz5efnV2K8SZMmF5232OrVqzV8+HAtWbJEXbp0Uf369TVs2DClp6eXOc/JkydlGMZlv/ZfBQQE6Pjx47YP59KkpKRIkvz9/cvsraioyPbz+7PSxv6qqKhI4eHhWrt2rSZNmqQvvvhCiYmJ2r59uyTp3LlzJeb56+/O1dXVrjYzM7Pc33FlBQYGasyYMVqyZIl++eWXEs8fPXpUknTvvffKarXaPWbPni3DMHTixAlJsh3W2rRpk7Zu3ar8/Hzddttt6tmzpy3Mb9q0SWFhYXJ3d7+kfoFLRQACHKhdu3Y6d+6c7YTVBg0a6OjRoyXuR3Ps2DEVFBTIx8fHNnb27FkNHTpU1157rdzd3TVy5MhSX6OgoKBEYCgOIH/90PyzBg0aKC0trcR48bkbf+6lLD4+PlqwYIFSUlJ08OBBzZo1S2vXri33fkP16tVTrVq1Lvu1/6pXr14qLCws87YDhmFo3bp1ql+/fpkn5NarV08Wi6XUAFdeqCu2e/du/fDDD5o7d64effRRdevWTTfeeGO5v4eLadCgQbm/40vx9NNPy8PDQ0899VSJ54p/9q+88optj+ZfH8UnmTdr1kzXXnutNm3apPj4eHXs2FF169ZVjx49lJaWpm+//Vbbt2/n/B84BAEIcKDvv/9ekmxXUvXo0UNnzpwpcTO/5cuX254vNnr0aKWmpmrt2rV64403tG7dOv3nP/8p9XXi4uLspt9++21JUrdu3crsrUePHtqzZ4927txZoheLxaLu3btLKrlHoiwBAQF65JFH1KtXrxLL/DNPT0917txZa9eutVtmUVGRVq5caftQrayRI0eqUaNGio6Oth0++rM5c+Zo7969mjRpUokr8/7cW6dOnbR27VqdP3/eNn769OkK3c+peM9e8c+s2MKFCyuzKnaKfw9l/Y4vRYMGDfTkk09qzZo1SkxMtHsuLCxMdevW1Z49e2x7NP/6cHFxsdX37NlTX375peLj422HaK+99loFBATomWeeUX5+PgEIDsF9gIArZPfu3SooKJB04bDF2rVrFR8fr7vvvlstWrSQJA0bNkyvvfaahg8frpSUFP3zn//U1q1b9cILL+iOO+6wfVAsWbJEK1eu1Jtvvqk2bdqoTZs2euSRR/Tkk08qLCzM7rwdFxcXzZs3T2fOnNGNN96ohIQEPffcc+rTp0+5512MHz9ey5cvV9++fTVjxgw1b95cn376qWJiYvTwww/bQoiXl5eaN2+ujz76SD169FD9+vXl4+OjevXqqXv37ho0aJCCgoLk5eWlHTt2aMOGDbYr2soya9Ys9erVS927d9fjjz8uFxcXxcTEaPfu3XrnnXcu6Y7LdevW1dq1a3XnnXcqJCRETzzxhNq3b6/s7GytXr1acXFxioiI0BNPPFHucmbOnKnbb79dvXr10sSJE1VYWKjZs2fL09PTduinLEFBQWrVqpUmT54swzBUv359ffzxx7bzYS5FeHi4brnlFk2aNElnz55Vx44d9c0332jFihWXvExJioqK0muvvabPPvvMbrx27dp65ZVXNHz4cJ04cUL33nuvGjVqpOPHj+uHH37Q8ePHFRsba6vv0aOHYmJilJGRoQULFtiNv/nmm6pXrx6XwMMxHHgCNmAKpV0F5u3tbVx//fXG/PnzjfPnz9vVZ2ZmGqNHjzb8/PwMZ2dno3nz5kZ0dLSt7scffzTc3d3trtgyDMM4f/68ERISYgQGBhonT540DOPCVWCenp7Gjz/+aHTr1s1wd3c36tevbzz88MPGmTNn7Ob/61VghmEYBw8eNAYNGmQ0aNDAsFqtRuvWrY25c+cahYWFdnWbNm0ybrjhBsPV1dWQZAwfPtw4f/68MXr0aKNdu3ZGnTp1DHd3d6N169bGtGnTjLNnz17057ZlyxbjtttuMzw9PQ13d3fjpptuMj7++GO7mspcBVYsNTXVGDt2rNGyZUvDxcXF8Pb2Nm655RZj5cqVtiur/rr8P18FZhiGsW7dOqNdu3aGi4uLERAQYLz44ou2q6UuZs+ePUavXr0MLy8vo169esZ9991npKamlrhi669XXxUr/ns6cOCAbezUqVPGgw8+aNStW9fw8PAwevXqZezdu/eSrgL7s0WLFtn+Zv/ax+bNm42+ffsa9evXN6xWq9G0aVOjb9++xnvvvWdXd/LkSaNWrVqGp6enkZeXZxuPi4szJBn33HPPRX5iQPWwGMZfTjYA8LcxYsQIrVmzRmfOnHF0KwBQo3AOEAAAMB0CEAAAMB0OgQEAANNhDxAAADAdAhAAADAdAhAAADAdboRYiqKiIh05ckReXl6XdMM1AABw5RmGodOnT6tJkyaqVav8fTwEoFIcOXKkzC9DBAAANduhQ4fUrFmzcmsIQKXw8vKSdOEHWKdOHQd3AwAAKiI7O1v+/v62z/HyEIBKUXzYq06dOgQgAACuMhU5fYWToAEAgOkQgAAAgOkQgAAAgOlwDhAAAKgRDMNQQUGBCgsLy6yxWq1ycnK67NciAAEAAIfLy8tTWlqacnJyyq2zWCxq1qyZateufVmvRwACAAAOVVRUpAMHDsjJyUlNmjSRi4tLqVdyGYah48eP6/Dhw7rmmmsua08QAQgAADhUXl6eioqK5O/vLw8Pj3JrGzZsqJSUFOXn519WAOIkaAAAUCNc7OsrpIrd46dCr1UlSwEAALiKEIAAAIDpODwAxcTEqEWLFnJzc1NISIi2bNlSbv1rr72m4OBgubu7q3Xr1lq+fHmJmlOnTmns2LHy8/OTm5ubgoODtX79+upaBQAAcJVx6EnQq1evVlRUlGJiYhQWFqaFCxeqT58+2rNnjwICAkrUx8bGKjo6WosXL9aNN96oxMREjRo1SvXq1VO/fv0kXTiRqlevXmrUqJHWrFmjZs2a6dChQxX6YjQAAGAOFsMwDEe9eOfOndWhQwfFxsbaxoKDgzVgwADNmjWrRH1oaKjCwsI0d+5c21hUVJS+++47bd26VZL0+uuva+7cudq7d6+sVmuF+sjNzVVubq5tuvjbZLOysvgy1KtcTk6O9u7dW27NuXPnlJKSosDAQLm7u190mUFBQRe9SgFA9eP9/fdx/vx5HThwoEK/p+LfafHRoz/Lzs6Wt7d3hT6/HbYHKC8vT0lJSZo8ebLdeHh4uBISEkqdJzc3t8TKuru7KzExUfn5+bJarVq3bp26dOmisWPH6qOPPlLDhg01aNAgPfnkk2VeLjdr1iw9++yzVbNiqFH27t2rkJCQKl1mUlKSOnToUKXLBFB5vL//Pop3WOTk5Fw0AOXl5UnSZd8N2mEBKCMjQ4WFhfL19bUb9/X1VXp6eqnz9O7dW0uWLNGAAQPUoUMHJSUlaenSpcrPz1dGRob8/Pz0+++/68svv9TgwYO1fv16/fLLLxo7dqwKCgr0zDPPlLrc6OhoTZgwwTZdvAcIV7+goCAlJSWVW5OcnKwhQ4Zo5cqVCg4OrtAyATge7++/DycnJ9WtW1fHjh2TJHl4eJR6uXtRUZGOHz8uDw8POTtfXoRx+I0Q/7qChmGUeY3/1KlTlZ6erptuukmGYcjX11cjRozQnDlzbEmwqKhIjRo10qJFi+Tk5KSQkBAdOXJEc+fOLTMAubq6ytXVtWpXDDWCh4dHhf81FxwczL/8gKsI7++/l8aNG0uSLQSVpVatWgoICLjs+wE5LAD5+PjIycmpxN6eY8eOldgrVMzd3V1Lly7VwoULdfToUfn5+WnRokXy8vKSj4+PJMnPz6/EF6UFBwcrPT1deXl5cnFxqb6VAgAAl8RiscjPz0+NGjVSfn5+mXUuLi4VumHixTjsMngXFxeFhIQoPj7ebjw+Pl6hoaHlzmu1WtWsWTM5OTlp1apVuvPOO20/jLCwMP36668qKiqy1e/fv19+fn6EHwAAajgnJye5ubmV+aiK8CM5+D5AEyZM0JIlS7R06VIlJydr/PjxSk1N1ejRoyVdODdn2LBhtvr9+/dr5cqV+uWXX5SYmKgHHnhAu3fv1gsvvGCrefjhh5WZmalx48Zp//79+vTTT/XCCy9o7NixV3z9AABAzeTQc4AiIiKUmZmpGTNmKC0tTW3bttX69evVvHlzSVJaWppSU1Nt9YWFhZo3b5727dsnq9Wq7t27KyEhQYGBgbYaf39/bdy4UePHj1e7du3UtGlTjRs3Tk8++eSVXj0AAFBDOfwk6DFjxmjMmDGlPrds2TK76eDgYO3ateuiy+zSpYu2b99eFe0BAIC/IYd/FQYAAMCVRgACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACmQwACAACm4/AAFBMToxYtWsjNzU0hISHasmVLufWvvfaagoOD5e7urtatW2v58uVl1q5atUoWi0UDBgyo4q4BAMDVzNmRL7569WpFRUUpJiZGYWFhWrhwofr06aM9e/YoICCgRH1sbKyio6O1ePFi3XjjjUpMTNSoUaNUr1499evXz6724MGDevzxx9W1a9crtToAAOAq4dA9QPPnz1dkZKRGjhyp4OBgLViwQP7+/oqNjS21fsWKFXrooYcUERGhli1b6oEHHlBkZKRmz55tV1dYWKjBgwfr2WefVcuWLa/EqgAAgKuIwwJQXl6ekpKSFB4ebjceHh6uhISEUufJzc2Vm5ub3Zi7u7sSExOVn59vG5sxY4YaNmyoyMjICvWSm5ur7OxsuwcAAPj7clgAysjIUGFhoXx9fe3GfX19lZ6eXuo8vXv31pIlS5SUlCTDMPTdd99p6dKlys/PV0ZGhiTpm2++0RtvvKHFixdXuJdZs2bJ29vb9vD397/0FQMAADWew0+CtlgsdtOGYZQYKzZ16lT16dNHN910k6xWq/r3768RI0ZIkpyc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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAGxCAYAAACKvAkXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/NK7nSAAAACXBIWXMAAA9hAAAPYQGoP6dpAABIFElEQVR4nO3deVxU9f4/8NcIDJssIgiobNk1UMRySAOk3EC5XpS8Jm6oCZZLKmqa5L6Sa3gtyN1MVArJvIomWvlA0dTRuim4i5AOIqiAoizD+f3Rj/NtHEBAcMDzej4e51Hzmff5zOcDzMzLs8oEQRBAREREJCFNdD0AIiIioheNAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiIiIiCSHAYiIiIgkhwGIiIiIJIcBiKiebd26FTKZTGOxsbFBt27dsG/fPl0PT+Ts7IxRo0bVeL3CwkLMnz8fv/zyS52PqTqOHDkCT09PmJqaQiaTYc+ePVXWZ2Zm4qOPPkKbNm1gZGSEZs2aoVu3boiNjcXTF8ZPT0+HTCbD1q1bnzmO+fPnQyaTPcdM6p5MJsP8+fOrrCmfo0wmw65du7SeL59XTk5OPY2SSDcYgIhekC1btuDEiRNISUnB+vXroaenh8DAQPz3v//V9dCeS2FhIRYsWKCTACQIAgYNGgQDAwPs3bsXJ06cwDvvvFNp/fHjx+Hh4YEffvgBkydPxsGDB7F161a0atUKw4cPx5AhQ1BWVvYCZ9CwzJo1CyUlJboeBtELoa/rARBJhbu7Ozw9PcXHffr0QbNmzbBz504EBgbqcGSN1+3bt3Hv3j28++676NmzZ5W1Dx48wIABA2BhYYFff/0Vtra24nP9+/eHh4cHZs6ciddffx0zZ86s76E3OAEBAThw4AC++uorTJw4UdfDIap33AJEpCNGRkaQy+UwMDDQaL937x7Gjx+PVq1aQS6X45VXXsGsWbNQVFQEAHjy5AneeOMNvPrqq8jLyxPXy8rKgp2dHbp16wa1Wg0AGDVqFJo2bYoLFy6gZ8+eMDU1hY2NDT766CMUFhY+c4wZGRkYPnw4WrRoAUNDQ7i5uWHVqlXiVpL09HTY2NgAABYsWCDuSinflXb37l188MEHcHBwgKGhIWxsbODj44PDhw8/87WPHTuGnj17wszMDCYmJvD29sb+/fvF5+fPn4/WrVsDAD755BPIZDI4OztX2t/GjRuRnZ2Nzz77TCP8lJsxYwZcXV2xYsWKZ24F2b9/P15//XUYGhrCxcUFK1eufOZ8yiUlJaF///5o3bo1jIyM8Oqrr+LDDz/U2sVUvuvpwoULGDJkCCwsLGBra4vRo0dr/N4BID8/H2PGjEHz5s3RtGlT9OnTB5cvX672mACgR48e6N27NxYtWoSCgoJn1h8+fBg9e/aEubk5TExM4OPjgyNHjojPX7hwATKZDN99953YplQqIZPJ0L59e42++vXrB4VCUaPxEj0vBiCiF0StVqO0tBQlJSX4888/ER4ejkePHmHo0KFizZMnT9C9e3ds27YNU6dOxf79+zF8+HAsX74cAwYMAPBXcPr222+RnZ2N0aNHAwDKysowbNgwCIKAnTt3Qk9PT+yzpKQE//znP9GzZ0/s2bMHH330EdatW4fg4OAqx3v37l14e3vj0KFDWLRoEfbu3YtevXrh448/xkcffQQAsLe3x8GDBwEAoaGhOHHiBE6cOIE5c+YAAEJCQrBnzx7MnTsXhw4dwsaNG9GrVy/k5uZW+dpHjx5Fjx49kJeXh02bNmHnzp0wMzNDYGAg4uLiAABhYWFISEgAAEycOBEnTpzA999/X2mfSUlJ4m7HishkMvTr1w/37t2DUqmstJ8jR46gf//+MDMzw65du7BixQp8++232LJlS5VzKnft2jV4eXkhJiYGhw4dwty5c/Hrr7+ia9euFQavf//732jbti12796NmTNnYseOHZgyZYr4vCAICAoKwjfffINp06bh+++/x1tvvYWAgIBqjefvli1bhpycHKxYsaLKuu3bt8Pf3x/m5ub4+uuv8e2338LKygq9e/cWQ1D79u1hb2+vEXYPHz4MY2NjpKam4vbt2wCA0tJSHD16FL169arxeImei0BE9WrLli0CAK3F0NBQiI6O1qj96quvBADCt99+q9G+bNkyAYBw6NAhsS0uLk4AIERFRQlz584VmjRpovG8IAjCyJEjBQDCmjVrNNqXLFkiABCOHTsmtjk5OQkjR44UH8+cOVMAIPz6668a644bN06QyWTCpUuXBEEQhLt37woAhHnz5mnNvWnTpkJ4ePizf0hPeeutt4QWLVoIBQUFYltpaang7u4utG7dWigrKxMEQRBu3LghABBWrFjxzD5dXV0FOzu7Kmti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EdWLagcgY2Nj7N69G//617/EG5ASERERNUbVDkB79+6tz3EQERERvTDPdRYYERERUWPEAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREklPrW2EQERHVt5LczOdaXygtRmneHehb2EKmL9fpWKhhYQAiIqIGx9raGkbGJsjdt0rXQ9FgZGwCa2trXQ+D6gADEBERNTiOjo64dDENOTk5z9VPWloahg8fju3bt8PNze25x2VtbQ1HR8fn7od0jwGIiIgaJEdHxzoLG25ubujUqVOd9EUvBx4ETURERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLDAERERESSwwBEREREkqPzABQdHQ0XFxcYGRlBoVAgOTm5yvrY2Fh07NgRJiYmsLe3x/vvv4/c3FyNmt27d6Ndu3YwNDREu3bt8P3339fnFIiIiKiR0WkAiouLQ3h4OGbNmoVz587B19cXAQEByMjIqLD+2LFjGDFiBEJDQ3HhwgV89913OH36NMLCwsSaEydOIDg4GCEhIfj9998REhKCQYMG4ddff31R0yIiIqIGTqcBaPXq1QgNDUVYWBjc3NwQFRUFBwcHxMTEVFh/8uRJODs7Y9KkSXBxcUHXrl3x4Ycf4syZM2JNVFQU/Pz8EBERAVdXV0RERKBnz56Iiop6QbMiIiKihk5nAai4uBhKpRL+/v4a7f7+/khJSalwHW9vb/z5559ITEyEIAi4c+cO4uPj0bdvX7HmxIkTWn327t270j4BoKioCPn5+RoLERERvbx0FoBycnKgVqtha2ur0W5ra4usrKwK1/H29kZsbCyCg4Mhl8thZ2cHS0tLrF27VqzJysqqUZ8AEBkZCQsLC3FxcHB4jpkRERFRQ6fzg6BlMpnGY0EQtNrKpaamYtKkSZg7dy6USiUOHjyIGzduYOzYsbXuEwAiIiKQl5cnLpmZmbWcDRERETUG+rp6YWtra+jp6WltmcnOztbaglMuMjISPj4+mD59OgDAw8MDpqam8PX1xeLFi2Fvbw87O7sa9QkAhoaGMDQ0fM4Zka6U5D5fYBVKi1Gadwf6FraQ6ct1OhYiInoxdBaA5HI5FAoFkpKS8O6774rtSUlJ6N+/f4XrFBYWQl9fc8h6enoA/trK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0h1fX184OzvD2toaf/zxh8Y/qF1cXKBQKJCbmwtfX18djpIaAp0GoODgYOTm5mLhwoVQqVRwd3dHYmKieFaXSqVCRkaGxjp5eXnYvXs31qxZU2GfDg4OOHToEKZMmQIPDw+0atUKkydPxieffFLv8yEiIt3S09PDqlWrxOsAffzxx+J1gA4ePIj9+/cjPj6ep8CTbq8D1FDxOkDSwusAEb18EhISMG3aNKSnp4ttLi4uWLlyJS+C+BKryfc37wVGREQvnQEDBqB///68FxhVSuenwRMRERG9aAxARET00uHNUOlZGICIiOilUn4z1A4dOmicBt+hQwcMHDiQIYgA8CDoCvEgaGnhQdBEL4/ym6F26NABe/bs0bgadFlZGYKCgnD+/HneDPUl1ShuhkpERFTXym+G+umnn1Z4K4yIiAjeDJUAMAAREdFLRKVSAUCFF8r9e3t5HUkXAxAREb007O3tAQDnz5+v8Pny9vI6ki4GICIiemmU3wpj6dKlFd4MNTIyEi4uLrwVBjEAERHRy6P8Vhj79u2r8Gao+/btw8qVK3kANPFK0ERE9HIZMGAA4uPjMW3aNK2bocbHx/NWGASAAYiIiF5CvBUGPQsDEBERvZT09PTQrVs3XQ+DGigeA0RERESSwwBEREREksMARERERJLDAERERESSwwBEREREksMARERERJLD0+Cfg1qtRklJSaXPy+VyrbsRExERke4xANWCIAjIysrCgwcPqqxr0qQJXFxcIJfLX8zASEthYSEuXrxYZU1aWprGf5/F1dUVJiYmzz02IiLSHQagWigPPy1atICJiQlkMplWTVlZGW7fvg2VSgVHR8cKa6j+Xbx4EQqFolq1w4cPr1adUqlEp06dnmdYRESkYwxANaRWq8Xw07x58yprbWxscPv2bZSWlsLAwOAFjZD+ztXVFUqlssqax48fIz09Hc7OzjA2Nq5Wn0RE1LgxANVQ+TE/1dkFUr7rS61WMwDpiImJSbW21vj4+LyA0RARUUPBI3RrqTq7tLjbi4iIqGFiACIiIiLJYQAiIiIiyWEAIiIiIslhACIiIiLJYQCqpbKysmfWCILwAkZCRERENcXT4Guo/PYWt2/fho2NDeRyeYVnewmCgLt370Imk/EUeCIiogaGAaiGym9voVKpcPv27SprZTIZWrduDT09vRc0OiIiIqoOBqBa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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.02805904488752247\n",
      "0.02625490430376771\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "# Create boxplots for arr1 and arr2 side by side\n",
    "box = ax.boxplot([all_covs_1, all_covs_2], patch_artist=True, labels=['CovShift', 'CC'])\n",
    "\n",
    "# Add a dotted horizontal line at y=0.9\n",
    "ax.axhline(y=0.9, linestyle='--', color='gray')\n",
    "\n",
    "# Add labels and title\n",
    "ax.set_ylabel('Values')\n",
    "ax.set_title('Boxplots of Old and New')\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "# Create boxplots for arr1 and arr2 side by side\n",
    "box = ax.boxplot([all_covs_1_m, all_covs_2_m], patch_artist=True, labels=['CovShift', 'CC'])\n",
    "\n",
    "# Add a dotted horizontal line at y=0.9\n",
    "ax.axhline(y=0.9, linestyle='--', color='gray')\n",
    "\n",
    "# Add labels and title\n",
    "ax.set_ylabel('Values')\n",
    "ax.set_title('Boxplots of Old and New')\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n",
    "\n",
    "print(np.sqrt(np.mean((np.asarray(all_covs_1) - 0.9)**2)))\n",
    "print(np.sqrt(np.mean((np.asarray(all_covs_2) - 0.9)**2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "id": "f2e730de",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████| 100/100 [02:25<00:00,  1.46s/it]\n"
     ]
    }
   ],
   "source": [
    "from conditionalconformal import CondConf\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "\n",
    "def generate_data(rng, p, n):\n",
    "    X = np.abs(rng.normal(size=(n,p)))\n",
    "    X = np.concatenate(\n",
    "        (np.ones((n,1)), X), axis=1\n",
    "    )\n",
    "    Y = rng.normal(size=(n,))\n",
    "    return X, Y\n",
    "\n",
    "seed = 0\n",
    "p = 4\n",
    "n_calib = 10\n",
    "n_test = 1000\n",
    "quantile = 0.9\n",
    "\n",
    "def marginal_trial(seed, p, n_calib, n_test, q, randomize):\n",
    "    rng = np.random.default_rng(seed=seed)\n",
    "    x_calib, y_calib = generate_data(rng, p, n_calib)\n",
    "    x_test, y_test = generate_data(rng, p, n_test)\n",
    "\n",
    "    cc = CondConf(score_fn = lambda x, y : y, Phi_fn = lambda x : x, seed=seed)\n",
    "    cc.setup_problem(x_calib, y_calib)\n",
    "\n",
    "    covers = cc.verify_coverage(x_test, y_test, quantile, randomize=randomize)\n",
    "    marginal_cov = np.mean(covers)\n",
    "    return marginal_cov\n",
    "\n",
    "covs = []\n",
    "covs_high = []\n",
    "covs_derand = []\n",
    "for i in tqdm(range(100)):\n",
    "#     cov = marginal_trial(i, 1, n_calib, n_test, quantile, True)\n",
    "    cov_high = marginal_trial(i, p, n_calib, n_test, quantile, True)\n",
    "    cov_derand = marginal_trial(i, p, n_calib, n_test, quantile, False)\n",
    "#     covs.append(cov)\n",
    "    covs_high.append(cov_high)\n",
    "    covs_derand.append(cov_derand)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "5e0ba462",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AojVatWECRNMlwEAgAfmjAAAAKMIIwAAwCjCCAAAMIowAgAAjCKMAAAAowgjAADAKMIIAAAwijACAACMIowAAACjfGIF1uYV6+vr6w1XAgAA2qr5e/t8T57xiTBy7NgxSVJcXJzhSgAAgLeOHTumqKios+73iQflNTU16fDhw+rVq5csFovpcnxafX294uLidPDgQR46iG6BaxLdDddkx3G5XDp27JgGDBigoKCzzwzxiZGRoKAgDRo0yHQZfiUyMpJ/ydCtcE2iu+Ga7BjnGhFpxgRWAABgFGEEAAAYRRgJMKGhoXrkkUcUGhpquhRAEtckuh+uya7nExNYAQCA/2JkBAAAGEUYAQAARhFGAACAUYQRAABgFGEEABCw1q5dq6ysrHP2mTVrlrKzs7umoHaorKyUxWLRRx99JEnauXOnBg0apOPHj5stzAuEEbTJ/v371atXL/Xu3dt0KQhwp06d0qxZs5SSkqLg4OBu/SWBrtHea6KhoUEPP/ywHnrooc4tsIulpKRo7NixWrlypelS2owwgvM6ffq0br75ZmVkZJguBZDT6VR4eLjuu+8+XXPNNabLQTfQ3mti48aN6tmzZ6f/t83lcunMmTOdeo4fuvXWW1VUVCSn09ml520vwoiPmDBhgu655x7dc8896t27t/r27asHH3zwvI9l7ggPPvigRowYoZtuuqnTzwXfYuK6vOiii1RUVKQ77rhD/fv377TzoH186Zr4y1/+op///OcebU6nU/n5+e7aH3jggRa1u1wuPfHEE7rkkksUHh6uUaNGqbi42L1/y5Ytslgs+vvf/660tDSFhobKbrfr008/1dSpUxUTE6OePXvqxz/+sd58802P946Pj9fSpUt12223qVevXho8eLDWrFnj0eeDDz7Q6NGjFRYWprS0NO3YsaPFZ7v22mtVW1urd955p81/HiYRRnzIH//4RwUHB+t///d/9bvf/U4rV67Uc889d9b+drtdPXv2POdr6dKl5zznW2+9pb/+9a96+umnO/rjwE+YuC7RvfnKNWG325WWlubRtnz5cq1bt05r167V1q1b9dVXX+nll1/26PPggw/qD3/4g4qKirRr1y7NmzdPM2bMaPHF/8ADD6iwsFB79uzRyJEj9c0332jy5Ml68803tWPHDl177bW6/vrrVVVV1aKG5pBx9913a86cOdq7d68k6fjx45oyZYqGDx+u8vJyPfroo1qwYEGLzxYSEqJRo0bJbrd3xB9Vp/OJp/biW3FxcVq5cqUsFouGDx+unTt3auXKlbrjjjta7Z+Wluae0HQ2ffr0Oeu+2tpazZo1S+vXr+fJlTirrr4u0f35wjXx9ddf6+uvv9aAAQM82letWqWCggLdcMMNkqRnnnlGf//73937jx8/rhUrVuitt97S+PHjJUmXXHKJtm7dqmeffVZXX321u++SJUv0s5/9zL3dt29fjRo1yr392GOP6eWXX9bf/vY33XPPPe72yZMn6+6775Yk/frXv9bKlSu1ZcsWjRgxQi+++KKcTqfWrVuniIgIXX755friiy80Z86cFp9x4MCBqqysvIA/pa5DGPEh48aNk8VicW+PHz9ey5cvl9PplNVqbdE/PDxciYmJ7T7fHXfcoenTp+snP/lJu98D/q+rr0t0f75wTZw8eVKSFBYW5m6rq6uTw+FwhwxJCg4OVlpamvtWze7du3Xq1CmPkCFJjY2NGj16tEfbD0ddjh8/rsWLF6ukpESHDx/WmTNndPLkyRYjIyNHjnT/vcViUf/+/VVdXS1J2rNnj0aNGqWIiAh3n+/X+33h4eE6ceLEuf8guglu0/ixCx36fOutt7Rs2TIFBwcrODhYeXl5qqurU3BwsNatW9eFnwT+hNs0+CET10Tfvn1lsVj0r3/9y6vjmpqaJEmvvfaaPvroI/dr9+7dHvNGpG/nsnzf/fffr40bN+q//uu/ZLfb9dFHHyklJUWNjY0e/Xr06OGxbbFY3Of1Zu7NV199pYsvvrjN/U1iZMSHvP/++y22hw0b1ur/aUgXPvRZVlbmMRP7lVde0eOPP65t27Zp4MCBbS8cfq2rr0t0f75wTYSEhOiyyy7T7t273euMREVFKTY2Vu+//757RPjMmTMqLy/XmDFjJEmXXXaZQkNDVVVV5XFLpi3sdrtmzZqlX/ziF5Kkb775xuvbKJdddpn+9Kc/6eTJkwoPD5fU8s+7WUVFhXJzc716f1MIIz7k4MGDys/P11133aUPP/xQv//977V8+fKz9r/Qoc+kpCSP7e3btysoKEjJycntfk/4n66+LqVvh8obGxv11Vdf6dixY+4vsh/96EcX9L7oGL5yTVx77bXaunWr5s6d6277j//4D/33f/+3hg0bpqSkJK1YsUJff/21e3+vXr20YMECzZs3T01NTbrqqqtUX1+vbdu2qWfPnvrVr3511vMlJibKZrPp+uuvl8Vi0UMPPeQe8Wir6dOna9GiRcrLy9ODDz6oyspKLVu2rEW/yspKHTp0yGd+/k4Y8SG33HKLTp48qbFjx8pqteree+/VnXfeabosBDgT1+XkyZP1+eefu7eb79V3xU/dcX6+ck3ccccdGjNmjOrq6hQVFSVJmj9/vhwOh2bNmqWgoCDddttt+sUvfqG6ujr3cf/5n/+pfv36qbCwUJ999pl69+6tMWPGaOHCheesceXKlbrtttuUnp6u6Oho/frXv1Z9fb1Xn7Nnz5569dVXNXv2bI0ePVqXXXaZHn/8cfeE22YbNmxQVlaWhgwZ4tX7m2Jx8W+vT5gwYYJ+9KMfadWqVaZLAdy4LvFDvnZN3HTTTRo9erQKCgpMl9JhGhoaNGzYMG3YsEFXXnml6XLahAmsAICA9dvf/lY9e/Y0XUaH+vzzz7Vo0SKfCSISt2kAAAFsyJAhuvfee02X0aEuvfRSXXrppabL8Aq3aQAAgFHcpgEAAEYRRgAAgFGEEQAAYBRhBAAAGEUYAQAARhFGAACAUYQRAABgFGEEAAAY9f8ARhRAjUx30VgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.93491 nan 0.98293\n",
      "0.12060551397013322 nan 0.08443926811620288\n",
      "0.09856999999999996 nan 0.08292999999999996\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/cherian/opt/miniconda3/envs/conformal-gan/lib/python3.10/site-packages/numpy/core/fromnumeric.py:3432: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/Users/cherian/opt/miniconda3/envs/conformal-gan/lib/python3.10/site-packages/numpy/core/_methods.py:190: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "\n",
    "box = ax.boxplot([covs_high, covs, covs_derand], patch_artist=True, \n",
    "                 labels=[f'p = {p}', 'p = 1', 'p = 1 (derand)'])\n",
    "plt.title(f\"n = {n_calib}\")\n",
    "plt.show()\n",
    "\n",
    "rmse = lambda x : np.sqrt(np.mean((np.asarray(x) - 0.9)**2))\n",
    "mae = lambda x : np.mean(np.abs(np.asarray(x) - 0.9))\n",
    "\n",
    "print(np.mean(covs_high), np.mean(covs), np.mean(covs_derand))\n",
    "print(rmse(covs_high), rmse(covs), rmse(covs_derand))\n",
    "\n",
    "print(mae(covs_high), mae(covs), mae(covs_derand))\n",
    "\n",
    "\n",
    "%timeit np.quantile()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ead8151",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
