{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "X2oi8d1M1iQN"
   },
   "source": [
    "##### Setup"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Op0D0beyViTQ"
   },
   "source": [
    "In addition to standard imports below, make sure to include src in the path so that multivalid tools can be imported."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "id": "SxnwCwzkh_j1"
   },
   "outputs": [],
   "source": [
    "import sys, os\n",
    "sys.path.append(os.path.join(os.getcwd(), '../src'))\n",
    "\n",
    "import numpy as np\n",
    "from sklearn.model_selection import train_test_split\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "WlGj72Q78Rfd"
   },
   "source": [
    "##### Dataset/task construction"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "9PSl36Kk1oVv"
   },
   "source": [
    "We will aim to achieve $\\tau$-coverage that holds conditional on groups $g \\in \\mathcal{G}$, for some collection $\\mathcal{G}$ of subsets of the covariate space. \n",
    "\n",
    "In the experiments below, we use $\\tau = 0.9$ (that is, we want to obtain $90\\%$ coverage conditional on every group). "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {
    "id": "i4edVU5i2Lrr"
   },
   "outputs": [],
   "source": [
    "tau = 0.9\n",
    "num_groups = 15\n",
    "num_grid = 100"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "U6x6P9ex3Znd"
   },
   "source": [
    "Our synthetic dataset $\\{(x_i, y_i)\\}_{i=1}^{10000} \\in (\\mathbb{Z}_+ \\times \\mathbb{R})^{10000}$ is generated as follows.\n",
    "\n",
    "First, we define our group collection as $\\mathcal{G} = \\{g_1, \\ldots, g_{15}\\}$, where for each $j = 1, \\ldots, 15$, the group $g_j = \\{j, 2j, 3j, \\ldots\\} \\subset \\mathbb{Z}_+$ contains all multiples of $j$. Note that group $g_1$ encompasses the entire covariate space, thus enforcing the *marginal* coverage guarantee.\n",
    "\n",
    "Each $x_i$ is a random integer sampled from the range $[1, 5000)$. \n",
    "\n",
    "We let the corresponding label $y_i$ be the sum of $n(x_i)$ iid. $\\mathcal{N}(0, 1)$ random variables, where $n(x_i)$ is the number of groups that $x_i$ belongs to.\n",
    "\n",
    "After generating our data, we split it into $80\\%$ training data $\\mathcal{D}_{train}$ and $20\\%$ test data $\\mathcal{D}_{test}$."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6q8mUsAa8KkD"
   },
   "source": [
    "Here, $g(x) \\in \\{0, 1\\}^{|\\mathcal{G}}$ is the vector that indicates which groups $x$ belongs to: namely, $g(x)[j] = \\mathbf{1}[x \\in g_j]$ for all $j = 1 \\ldots |\\mathcal{G}|$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "id": "AMdbjrN0iNaE"
   },
   "outputs": [],
   "source": [
    "from DatasetGeneration.DivisibleDataset import divisible_dataset\n",
    "\n",
    "size = 10000\n",
    "x, y, g = divisible_dataset(size=size, num_groups=num_groups)\n",
    "\n",
    "x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.2, random_state=42)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Ncef4ynIGMFC"
   },
   "source": [
    "##### Multivalid coverage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JzT_QpNfxGx0",
    "outputId": "59626012-fb35-4e3d-ea7e-72d114aa8070"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Max violation in round 0  :  6449.436125\n",
      "Update: (0, 0, 75)\n",
      "Max violation in round 1  :  27.326795338674458\n",
      "Update: (5, 75, 81)\n",
      "Max violation in round 2  :  9.78905839746489\n",
      "Update: (0, 75, 72)\n",
      "Max violation in round 3  :  14.590843373493978\n",
      "Update: (3, 72, 77)\n",
      "Max violation in round 4  :  4.57996282527881\n",
      "Update: (14, 72, 78)\n",
      "Max violation in round 5  :  4.653876739562618\n",
      "Update: (0, 72, 70)\n",
      "Max violation in round 6  :  7.364196891191715\n",
      "Update: (13, 70, 79)\n",
      "Max violation in round 7  :  2.4979646017699104\n",
      "Update: (8, 70, 74)\n",
      "Max violation in round 8  :  2.2699224806201563\n",
      "Update: (9, 70, 74)\n",
      "Max violation in round 9  :  3.0650943396226467\n",
      "Update: (0, 70, 68)\n",
      "Max violation in round 10  :  2.8800000000000003\n",
      "Update: (12, 68, 72)\n",
      "Max violation in round 11  :  1.825280898876406\n",
      "Update: (6, 68, 72)\n",
      "Max violation in round 12  :  1.4459039629736727\n",
      "Update: (0, 68, 67)\n",
      "Max violation in round 13  :  1.81091388400703\n",
      "Update: (2, 67, 70)\n",
      "Max violation in round 14  :  1.238240997229915\n",
      "Update: (0, 67, 66)\n",
      "Max violation in round 15  :  2.6188413098236833\n",
      "Update: (1, 66, 69)\n",
      "Max violation in round 16  :  1.5190830945558753\n",
      "Update: (0, 66, 64)\n",
      "Max violation in round 17  :  1.9111764705882393\n",
      "Update: (4, 64, 68)\n",
      "Max violation in round 18  :  0.9204166666666663\n",
      "Update: (4, 72, 75)\n",
      "Max violation in round 19  :  0.7722049131216302\n",
      "Update: (0, 64, 63)\n",
      "Max violation in round 20  :  0.886402877697842\n",
      "Update: (10, 63, 67)\n",
      "Max violation in round 21  :  0.7200000000000002\n",
      "Update: (10, 68, 73)\n",
      "Max violation in round 22  :  0.463497536945814\n",
      "Update: (6, 77, 80)\n",
      "Max violation in round 23  :  0.44473684210526304\n",
      "Update: (10, 77, 80)\n",
      "Max violation in round 24  :  0.5592233009708711\n",
      "Update: (0, 77, 76)\n",
      "Max violation in round 25  :  0.4393220338983056\n",
      "Update: (10, 81, 83)\n",
      "Max violation in round 26  :  0.43592178770949885\n",
      "Update: (7, 76, 77)\n",
      "Max violation in round 27  :  0.835882352941175\n",
      "Update: (0, 76, 74)\n",
      "Max violation in round 28  :  0.39340425531914963\n",
      "Update: (4, 79, 81)\n",
      "Max violation in round 29  :  0.34882882882882954\n",
      "Update: (6, 81, 83)\n",
      "Max violation in round 30  :  0.5333333333333349\n",
      "Update: (0, 81, 80)\n",
      "Max violation in round 31  :  0.46944162436548326\n",
      "Update: (7, 80, 82)\n",
      "Max violation in round 32  :  0.4634042553191495\n",
      "Update: (8, 83, 85)\n",
      "Max violation in round 33  :  0.32000000000000056\n",
      "Update: (3, 85, 86)\n",
      "Max violation in round 34  :  0.32000000000000006\n",
      "Update: (12, 86, 83)\n",
      "Max violation in round 35  :  0.32000000000000006\n"
     ]
    }
   ],
   "source": [
    "from MultivalidAlgorithms.MultivalidCoverage import multivalid_coverage, eval_fn\n",
    "\n",
    "patches = multivalid_coverage(tau=tau, x_train=x_train, y_train=y_train, num_grid=num_grid, group_fn=g)\n",
    "multivalid_model = lambda x: eval_fn(x, patches=patches, num_grid=num_grid, group_fn=g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 718
    },
    "id": "zGb7SLoG0KnG",
    "outputId": "5c5d4f81-5eb4-4ef0-80b0-557433e54bfa"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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06ZNY/PNN2f77bfnuOOOY7/99gPg5Zdf5sgjj2T06NFst912/OQnP+G1117j1FNP5eqrr2bbbbfl6quvflMdixcv5sQTT2SrrbZixIgRnHfeeQDcdNNNbLfddmy99dYceeSRvPrqq/z85z/n4IMPXvLam2++ecm8b7zxRnbaaSdGjhzJwQcfzEsvvdRh7RdffDHve9/72GabbTjwwAOXhNA//elP7Ljjjmy99daccsoprLHGGkvmc9ZZZ/G+972PESNGvGm9SP2NbcKkfsqGsq3luOOO45xzzuHXv/41gwcPBuDMM89k3XXXZfHixeyxxx7ce++9jBgxAoD11luPO++8k4ULFzJ8+HBuueUWhg0bxtixY5dM88wzz2T33Xdn0qRJPP/884wePZo999yT008/nenTp3P++ee/pY6JEycyZ84c7r77bgYOHMizzz7LwoULOeKII7jpppvYdNNN+dSnPsV3vvMdxo8fz7hx43j55ZcZNGgQV199NYcccghPP/00Z5xxBr/85S8ZNGgQX//61znnnHM49dRT31Q7wDPPPMNRRx0FwCmnnMIll1zCsccey/HHH8/xxx/P2LFj+e53v7ukvhtvvJGHH36YP/zhD2Qm+++/P7fccgsf+tCHqnljpBoZwqR+yoayre+aa65h4sSJLFq0iCeeeIKZM2cuCWGf+MQnAHjggQd497vfzbBhwwAYO3YsEydOBIrAMnXqVM4++2wAFi5cyGOPPdblPH/5y19y9NFHM3Bgsflfd911ueeeexg2bBibbropAIcffjgXXHABn/vc5xgzZgw//elPOeigg/jZz37GN77xDX7zm98wc+ZMdt55ZwBee+01dtpppyXzaKsd4L777uOUU07h+eef56WXXmLvvfcG4LbbbuPaa68F4NBDD+XEE09cskw33ngj2223HQAvvfQSDz/8sCFM/ZIhTFLlmt0rByvOnrlHHnmEs88+m9tvv523v/3tHHHEESxcuHDJ8EGDBnU7jczkRz/6EZttttmb+v/+97/vsToPOeQQzj//fNZdd11GjRrFmmuuSWay1157MXny5A5f01j7EUccwbXXXss222zDpZdeys0339zl/DKTk08+mc9+9rM9tgxSq7JNmKTKte2Va+Zfs2GtL1pzzTV58cUXAXjhhRcYNGgQa6+9Nk8++STXX399h6/ZbLPNmD17NnPmzAF4Uxuvvffem/POO4/MBOCuu+56y3za22uvvbjoootYtGgRAM8++yybbbYZc+bMYdasWQBcccUV7LLLLgDssssu3HnnnVx88cUccsghAOy4447ceuutS8Z/+eWXeeihhzqc34svvsj666/P66+/zpVXXrmk/4477siPfvQjAKZMmfKmZZo0adKSNmbz58/nqaee6nDaUl9nCJOkXjJu3DjGjBnDbrvtxjbbbMN2223H5ptvzqGHHrrk0F57q6++OhdeeCFjxoxh++23Z80112TttdcG4Etf+hKvv/46I0aMYMstt+RLX/oSALvtthszZ87ssGH+Zz7zGYYOHcqIESPYZpttuOqqq1httdX47//+bw4++GC23nprVlppJY4++mgABgwYwH777cf111+/pFH+kCFDuPTSSxk7diwjRoxgp5124oEHHuiw/q985SvssMMO7Lzzzmy++eZL+p977rmcc845jBgxglmzZi1Zpg9/+MMceuih7LTTTmy99dYcdNBBnQZKqa+Ltr+g+opRo0bl9OnT6y5DanmnnXZac23CmFD5GWjN1tJb9fQ1L730EmussQaZyTHHHMPw4cM54YQT6i5rubzyyiusvvrqRARTpkxh8uTJ/OQnP6m7LC2jVtretJqIuCMzR3U0zDZhktTiLr74Yi677DJee+01tttuu37RXuqOO+5g/PjxZCbrrLMOkyZNqrskqdcZwvqAVmrU3Eq1SCuKE044oc/v+Wrvgx/8IPfcc0/dZUi1qjSERcQY4L+AAcD3MvNr7YZvDEwChgDPAp/MzHlV1tQXNXupAaj+cgOtVIskraj8g7h/qCyERcQA4AJgL2AecHtETM3MmQ2jnQ1cnpmXRcTuwFeBf6yqJkmS+gP/IO4nMrOSB7ATcEND98nAye3GmQFsVD4P4IXuprs9ZHb2uOiiXOKiizofD/JNRo7sdLzpI0fmhAkTcsKECXnRuHFdT3P69L9N86ijOh9v5Mg3z7+bZZowYUIygTxqvy7Gg2QCOWHChG6XKY866m/znj69R5Zp+vrF/Nse3S1TT79PVSzT0r5PfWGZ6n6fLhr5t3mPHNfN/Ffg98llKpbpq2d9Nafut1+X47Ztn7961lf7xDL15PvUSt+n7t6ntjonTJiwwr1PwPTMjjNNlYcjNwDmNnTPA3ZoN849wD9QHLL8e2DNiFgv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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coverage on group 1 : 0.9045\n",
      "Coverage on group 2 : 0.9125514403292181\n",
      "Coverage on group 3 : 0.9108761329305136\n",
      "Coverage on group 4 : 0.9006211180124224\n",
      "Coverage on group 5 : 0.8733509234828496\n",
      "Coverage on group 6 : 0.9292929292929293\n",
      "Coverage on group 7 : 0.9243421052631579\n",
      "Coverage on group 8 : 0.899581589958159\n",
      "Coverage on group 9 : 0.8923766816143498\n",
      "Coverage on group 10 : 0.8494623655913979\n",
      "Coverage on group 11 : 0.9044943820224719\n",
      "Coverage on group 12 : 0.8848920863309353\n",
      "Coverage on group 13 : 0.9084507042253521\n",
      "Coverage on group 14 : 0.9433962264150944\n",
      "Coverage on group 15 : 0.8951612903225806\n"
     ]
    }
   ],
   "source": [
    "from utils.MultivalidPlotting import plot_group_coverage\n",
    "\n",
    "plot_group_coverage(model=multivalid_model, tau=tau, x_test=x_test, y_test=y_test, num_groups=num_groups, group_fn=g, multivalid=False, verbose=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 718
    },
    "id": "30brFCTHIoMf",
    "outputId": "2f13e912-6134-49c2-cd62-ddb0a892a1a2"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Performance on group 1 : 0.0007918227790855672\n",
      "Performance on group 2 : 0.0005986842954308617\n",
      "Performance on group 3 : 0.00048635317744601884\n",
      "Performance on group 4 : 6.091510344557488e-05\n",
      "Performance on group 5 : 0.0007506567449798507\n",
      "Performance on group 6 : 0.0003643082013183837\n",
      "Performance on group 7 : 0.0004018520443520443\n",
      "Performance on group 8 : 4.654773541870314e-05\n",
      "Performance on group 9 : 0.0002830914047193118\n",
      "Performance on group 10 : 0.0005896923756255518\n",
      "Performance on group 11 : 0.00036638030828820277\n",
      "Performance on group 12 : 7.297613673979108e-05\n",
      "Performance on group 13 : 0.00043537800363887316\n",
      "Performance on group 14 : 0.0002491666666666666\n",
      "Performance on group 15 : 0.00044932604735883403\n"
     ]
    }
   ],
   "source": [
    "plot_group_coverage(model=multivalid_model, tau=tau, x_test=x_test, y_test=y_test, num_groups=num_groups, group_fn=g, multivalid=True, num_grid=num_grid, verbose=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "SnhOos6sj2ZY"
   },
   "source": [
    "##### Group-only (not multivalid) coverage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "hFN49RwGj-wP",
    "outputId": "f79953d7-8202-498d-9889-12626fa1f8a6"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
      "Requirement already satisfied: optax in /usr/local/lib/python3.7/dist-packages (0.1.3)\n",
      "Requirement already satisfied: jax>=0.1.55 in /usr/local/lib/python3.7/dist-packages (from optax) (0.3.14)\n",
      "Requirement already satisfied: absl-py>=0.7.1 in /usr/local/lib/python3.7/dist-packages (from optax) (1.2.0)\n",
      "Requirement already satisfied: chex>=0.0.4 in /usr/local/lib/python3.7/dist-packages (from optax) (0.1.3)\n",
      "Requirement already satisfied: typing-extensions>=3.10.0 in /usr/local/lib/python3.7/dist-packages (from optax) (4.1.1)\n",
      "Requirement already satisfied: jaxlib>=0.1.37 in /usr/local/lib/python3.7/dist-packages (from optax) (0.3.14+cuda11.cudnn805)\n",
      "Requirement already satisfied: numpy>=1.18.0 in /usr/local/lib/python3.7/dist-packages (from optax) (1.21.6)\n",
      "Requirement already satisfied: toolz>=0.9.0 in /usr/local/lib/python3.7/dist-packages (from chex>=0.0.4->optax) (0.12.0)\n",
      "Requirement already satisfied: dm-tree>=0.1.5 in /usr/local/lib/python3.7/dist-packages (from chex>=0.0.4->optax) (0.1.7)\n",
      "Requirement already satisfied: opt-einsum in /usr/local/lib/python3.7/dist-packages (from jax>=0.1.55->optax) (3.3.0)\n",
      "Requirement already satisfied: etils[epath] in /usr/local/lib/python3.7/dist-packages (from jax>=0.1.55->optax) (0.6.0)\n",
      "Requirement already satisfied: scipy>=1.5 in /usr/local/lib/python3.7/dist-packages (from jax>=0.1.55->optax) (1.7.3)\n",
      "Requirement already satisfied: flatbuffers<3.0,>=1.12 in /usr/local/lib/python3.7/dist-packages (from jaxlib>=0.1.37->optax) (2.0)\n",
      "Requirement already satisfied: importlib_resources in /usr/local/lib/python3.7/dist-packages (from etils[epath]->jax>=0.1.55->optax) (5.9.0)\n",
      "Requirement already satisfied: zipp in /usr/local/lib/python3.7/dist-packages (from etils[epath]->jax>=0.1.55->optax) (3.8.1)\n"
     ]
    }
   ],
   "source": [
    "!pip install optax\n",
    "\n",
    "from MultivalidAlgorithms.GroupCoverage import group_coverage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "urF9tvCDGbMl",
    "outputId": "cc4ef4a0-e60f-417e-d145-a00673505c8d"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Optimal theta found: [ 0.6351701   0.06942544  0.07058934  0.03890205  0.05674157 -0.00216989\n",
      "  0.05116966  0.02595287  0.02349506 -0.02406407  0.03343523 -0.02168043\n",
      "  0.03828627  0.00748974 -0.00160039]\n"
     ]
    }
   ],
   "source": [
    "group_model, theta_opt = group_coverage(tau=tau, x_train=x_train, y_train=y_train, num_groups=num_groups, group_fn=g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 718
    },
    "id": "NRMz9MYqG8vh",
    "outputId": "361e75b8-f30a-4a0f-b93b-a83a78475a60"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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3ve+x8MPP8wee+zBkCFDuP766znqqKP4xdW/4OWXXmbEiBHsscceAHz3u99l66235v7772fXXXdllVVW4ZprrmGVVVfhYx/9GLNnz+bqq69m4cKFjB8/nrvvvptXXnmFCRMmsO+++3LSSSfxwgsv8Pvf/54TTjiBgw8+eHEdr776Kl/5ylf49a9/zUorrcQRRxzB+PHjue666zjuuONYtGgR73znOzn33HO5/vrrOf/88/npT38KwA033MAZZ5zB1VdfzbXXXsvXvvY1XnrpJTbbbDN+/OMfs8Yaa7Dpppty8MEH85vf/IYvf/nLPPvss0yaNImXX36Zt73tbVx88cWsvvrq3H///Rx66KEsXLiQAw44gLPOOovnnnsOgG9/+9tcccUVvPTSS3zkIx/h5JNP7pX3YFl5yE29zRAmaYVTx4/p5z//ec4880yuv/56hgwZAsBpp53GP/3TPzHhtQnceOGN3Pi3G+GfivH/sNof4Ei48pUr4WzgX2HCmybw17/+dfE8TzvtNPbcc08uuOACnn76aXbccUf22msvTjnlFNra2jjnnHPeUMekSZOYM2cOd955JwMHDuTJJ5/kxRdf5PDDD+e6665jiy224FOf+hTnnnsu48aNY+zYsSxcuJDBgwdz+eWXc8ghh/D4449z6qmn8tvf/pbBgwdz+umnc+aZZ3LSSScBsN5663H77bcD8MQTT3DEEUcAcOKJJ3L++eczfvx4jjnmGI455hjGjBnDD37wg8X1XXvttdx333386U9/IjPZf//9uemmm3jve9/ba++F1CoMYVoiHlaSes8VV1xRBJDXgOeABSwOYWxd/n0ceFP5AMaMGcOkSZOAIrBMnTqVM844A4AXX3yRhx56qNtl/va3v+XII49k4MBi87/uuuty1113MXz4cLbYYgsADjvsMCZOnMixxx7L6NGj+cUvfsGBBx7IL3/5S771rW9x4403cs8997DrrrsC8PLLL7PLLrssXkbjnre7776bE088kaeffprnnnuOffbZB4Cbb76Zq666CoBPfOITHHfccYtf07XXXsv2228PwHPPPcd9991nCFPTlqffKUOYlsjyelgJ6v+ySY0eeOABzjjjDA477DBOX+10+DmwqGGEQT3PIzO58sor2XLLLV/X/49//GOv1XnIIYdwzjnnsO666zJq1CjWXHNNMpO9996byy67rNNpBg8evPj54YcfzlVXXcW2227L5MmTueGGG7pdXmZywgkn8LnPfa7XXoNWLK32O9UdQ9hywKDRteXpyyatueaaPPvsswwZMoRnnnmGwYMHs8oqqxR7wWYBm3Yy0RDgqfLxJrj88ssXD9pnn304++yzOfvss4kI7rjjDrbffvvFy+nM3nvvzXnnnccee+yx+HDklltuyZw5c5g1a9bidlu77bYbALvtthuf/vSn+eEPf8ghhxwCwM4778zRRx+9ePyFCxcyf/78xXvSGj377LOsv/76vPLKK1x66aUMGzZs8TyuvPJKDj74YKZMmfK61/TVr36VQw89lDXWWIP58+czaNAg3vzmNy/5CpdanCFsOWDQkPqHsWPHMnr0aDbYYAOuv/56tt9++6Ld1trARl1MNAj4AHAJnLfyeey///6LB331q1/l2GOPZZtttuG1115j+PDhXH311eyxxx5885vfZLvttntDw/zPfvaz3HvvvWyzzTYMGjSII444gnHjxvHjH/+Ygw46aHHD/COPPBKAAQMG8MEPfpDJkydz4YUXAjB06FAmT57MmDFjeOml4h/EU089tdMQ9vWvf52ddtqJoUOHstNOOy0Oh+1nip522mmMHj2atddeG4D3v//9zJgxY/HhzTXWWINLLrnEEKZ+yRAmSX1k/PjxjB8/fnH35MmTOfnkk9/4T9YXOky4KTAexuZYHnvsMUaNGgXAaqutxnnnnfeG5ay77rrceuutndYwcOBAzjzzTM4888zX9X/f+97HHXfc0ek055xzzhsa+e+5556dLmPOnDmv6z7qqKM46qij3jDesGHDuOWWW4gIpkyZwsyZMxcPa2+0334U4JJLLum0rkYr2lEA9Q+GMElqdbcDd8LEVyfy/ve/v1+0l7rtttsYN24cmck666zDBRdc8IZxPAqg/s4QJkmtbpfiMY5xfO1rX6u7ml7xnve8h7vuuqvuMqRaVRrCImI08N/AAOBHmfnNDsM3AS4AhgJPAp/MzHlV1tQMG8JLklqZv1P9Q2UhLCIGABOBvYF5wK0RMTUz72kY7Qzgosy8MCL2BP4L+JeqamqWu8AlSa3M36l+IjMreVDsQL+mofsE4IQO40wHNiqfB/BMT/PdATK7epx3Xi523nldjwf5OiNHdjneeSNJJhSPkWO7mR9ktrX9Y55HHNH1eCNHvn75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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coverage on group 1 : 0.909\n",
      "Coverage on group 2 : 0.9207818930041153\n",
      "Coverage on group 3 : 0.9274924471299094\n",
      "Coverage on group 4 : 0.9233954451345756\n",
      "Coverage on group 5 : 0.899736147757256\n",
      "Coverage on group 6 : 0.9427609427609428\n",
      "Coverage on group 7 : 0.9342105263157895\n",
      "Coverage on group 8 : 0.9330543933054394\n",
      "Coverage on group 9 : 0.9327354260089686\n",
      "Coverage on group 10 : 0.9032258064516129\n",
      "Coverage on group 11 : 0.9157303370786517\n",
      "Coverage on group 12 : 0.935251798561151\n",
      "Coverage on group 13 : 0.9084507042253521\n",
      "Coverage on group 14 : 0.9433962264150944\n",
      "Coverage on group 15 : 0.9274193548387096\n"
     ]
    }
   ],
   "source": [
    "plot_group_coverage(model=group_model, tau=tau, x_test=x_test, y_test=y_test, num_groups=num_groups, group_fn=g, multivalid=False, verbose=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 718
    },
    "id": "KOJCwJzGJ4IO",
    "outputId": "c4ca18f7-0aba-4912-a3cc-9624ffab8a2a"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Performance on group 1 : 0.001266091978569711\n",
      "Performance on group 2 : 0.000978558224467286\n",
      "Performance on group 3 : 0.0010529156642946973\n",
      "Performance on group 4 : 0.0005205724198340388\n",
      "Performance on group 5 : 0.0007793438307724022\n",
      "Performance on group 6 : 0.0008031997791886439\n",
      "Performance on group 7 : 0.0004842995111783357\n",
      "Performance on group 8 : 0.00026699900202996167\n",
      "Performance on group 9 : 0.00045496673824260014\n",
      "Performance on group 10 : 0.0006450966183574879\n",
      "Performance on group 11 : 0.0004917054325103861\n",
      "Performance on group 12 : 0.00033195652173913026\n",
      "Performance on group 13 : 0.000895958485958486\n",
      "Performance on group 14 : 0.00031818229506111977\n",
      "Performance on group 15 : 0.0004443055555555557\n"
     ]
    }
   ],
   "source": [
    "plot_group_coverage(model=group_model, tau=tau, x_test=x_test, y_test=y_test, num_groups=num_groups, group_fn=g, multivalid=True, num_grid=num_grid, verbose=True)"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "name": "DemoMultivalidCoverage.ipynb",
   "provenance": []
  },
  "gpuClass": "standard",
  "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
