{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "d564cdcd-edab-4a0a-b378-5469b5b349fa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd \n",
    "import numpy as np\n",
    "import cvxpy as cp\n",
    "import math\n",
    "import random\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.preprocessing import PolynomialFeatures\n",
    "\n",
    "from conditionalconformal import CondConf\n",
    "from conditionalconformal.synthetic_data import generate_cqr_data\n",
    "from crossval import runCV\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "2ca16586-9450-413c-b6a4-e60a79bebb10",
   "metadata": {},
   "outputs": [],
   "source": [
    "def getIntervalIndicators(X,d): ### Construct features consisting of indicators on intervals\n",
    "    intervals = []\n",
    "    for i in range(d-1):\n",
    "        intervals = intervals + [[i*5/(d-1), (i+1)*(5/(d-1))]]\n",
    "    phiOfX = np.ones((len(X),len(intervals)+1))\n",
    "    for i in range(len(X)):\n",
    "        for j in range(len(intervals)):\n",
    "            if intervals[j][0] > X[i,0] or X[i,0] > intervals[j][1]:\n",
    "                phiOfX[i,j] = 0\n",
    "    return phiOfX"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38b6e170-1ea7-4398-899d-f7c21accdbf2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|███████████████████████████████████████▏                                                                                                                                                            | 1/5 [57:46<3:51:07, 3466.80s/it]"
     ]
    }
   ],
   "source": [
    "### Evaluate calibration-conditional coverage on one simulated example\n",
    "def runOneCCCExperiment(nTrain,nCalib,nTest,d,alpha,seed):\n",
    "    ### Generate data\n",
    "    poly = PolynomialFeatures(4)\n",
    "    XTrain, YTrain, XCalib, YCalib, XTest, YTest = generate_cqr_data(seed,nTrain,nCalib,nTest)\n",
    "\n",
    "    ### Compute conformity scores\n",
    "    if nTrain != 0: \n",
    "        reg = LinearRegression().fit(poly.fit_transform(XTrain), YTrain)\n",
    "        scoresCalib = np.abs(YCalib - reg.predict(poly.fit_transform(XCalib)))\n",
    "        scoresTest = np.abs(YTest - reg.predict(poly.fit_transform(XTest)))\n",
    "        scoreFn = lambda x, y : y - reg.predict(poly.fit_transform(x))\n",
    "    else: ### If nTrain = 0 then directly estimate quantiles of Y\n",
    "        scoresCalib = YCalib\n",
    "        scoresTest = YTest\n",
    "        scoreFn = lambda x, y : y if isinstance(y, np.ndarray) else np.array([y])\n",
    "    ### Run split conformal\n",
    "    splitCutoff = np.quantile(scoresCalib,[math.ceil((1-alpha) * (len(scoresCalib) + 1)) / len(scoresCalib)])\n",
    "    splitCov = np.mean(scoresTest <= splitCutoff)\n",
    "\n",
    "    ### Run our conditional calibration method\n",
    "    phiFn = lambda x : getIntervalIndicators(x,d)\n",
    "    condCovProgram = CondConf(scoreFn, phiFn, {})\n",
    "    condCovProgram.setup_problem(XCalib,YCalib)\n",
    "    condConfCov = np.mean(condCovProgram.verify_coverage(XTest,YTest,1-alpha)[:,0])    \n",
    "    \n",
    "    coverageData = pd.DataFrame({'Method': ['Split Conformal','Conditional Calibration'], 'Range' : ['Marginal','Marginal'], \n",
    "                                'Coverage': [splitCov,condConfCov]})\n",
    "    return coverageData\n",
    "\n",
    "random.seed(1)\n",
    "\n",
    "nTrials = 200 \n",
    "    \n",
    "nTest = 2000 \n",
    "nTotal = 1000\n",
    "nCalibs = [100,250,500,750,1000] \n",
    "ds = [1,5,10,20,50]\n",
    "alpha = 0.1\n",
    "\n",
    "coverageDF = pd.DataFrame()\n",
    "for nCalib in tqdm(nCalibs):\n",
    "    for d in ds:\n",
    "        for i in range(nTrials):\n",
    "            appendDF = runOneCCCExperiment(nTotal - nCalib,nCalib,nTest,d,alpha,random.randint(0,100000))\n",
    "        \n",
    "            appendDF['trial'] = i\n",
    "            appendDF['Number of Calibration Points'] = nCalib\n",
    "            appendDF['Function Class Dimension'] = d\n",
    "            coverageDF = pd.concat([coverageDF,appendDF])   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "fa47b9e1-1642-407f-bdb5-5c0c3892ade1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABFoAAAFmCAYAAABdvv7iAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAACfCUlEQVR4nOzdd1hT59sH8G8gTBkSQcAtDhxoRXHXBdiq1bauNlRxtNVqW1drq7TW1aF11Fr3qKsqqHW0asUiuKUgTgTFgRVRQTQMERkhef/gl7ym7AwSku/nurwuk3POkzsnh5M793nO8wjkcrkcRERERERERESkMTN9B0BEREREREREZCxYaCEiIiIiIiIi0hIWWoiIiIiIiIiItISFFiIiIiIiIiIiLWGhhYiIiIiIiIhIS4T6DsAU5ebm4tq1a3BxcYG5ubm+wyEiIqpShYWFSEtLg5eXF6ytrfUdDqmBuQwREZmy8nIZFlr04Nq1axgxYoS+wyAiItKrHTt2wMfHR99hkBqYyxAREZWey7DQogcuLi4Aij4UNzc3PUdDRERUtVJSUjBixAjl9yFVP8xliIjIlJWXy7DQogeKLrZubm6oV6+enqMhIiLSD95yUn0xlyEiIio9l+FguEREREREREREWsJCCxERERERERGRlhjsrUOJiYk4ffo0YmNjce3aNfz777+Qy+VYvnw5+vXrp3a7Bw8eRHBwMBISEiCTydC4cWMMHToUAQEBMDMrve6k7nZERERkmpjLEBERmSaDLbQEBwdj27ZtWm1z3rx52LlzJ6ysrNC1a1cIhUJERkZi/vz5iIyMxPLly0u8x0rd7YiIiMh0MZchIiIyTQZbaGnevDk++OADeHl5wcvLC19//TWio6PVbu/o0aPYuXMnXFxcsH37djRq1AgA8OTJE4waNQphYWHYvn07Ro8erZXtiIiIyLQxlyEiIjJNBttPdPjw4fjyyy8xYMAANGjQQOP21q1bBwCYPn26MsEAAGdnZ8ydOxcAsGHDBshkMq1sR0RERKaNuQwREZFpMthCizalpKQgLi4OFhYWJd4T3alTJ7i6uiItLQ2XL1/WeDsiIiIibWIuQ0REVH2YRKElPj4eANCsWTNYW1uXuE6bNm0AANevX9d4OyIiIiJtYi5DRERUfZhEoSU5ORkAUKdOnVLXcXd3V1lXk+2IiIiItIm5DBERUfVhsIPhalNOTg4AwMbGptR1atSoAQB4/vy5xtsRERERaRNzGSIiMmUREREICwsrc52MjAwAQM2aNctcr2/fvvD19dVSZCUziUKLXC4HAAgEgirZjoiIiEibmMsQERGVTSKRACi/0FIVTKLQorhSo7iqUxLFVRzFuppsR0RERKRNzGWIiMiU+fr6ltsLJSgoCACwYMGCqgipTCZRaKlbty4A4OHDh6Wuk5KSorKuJtsRERERaRNzGSIiMmYbNmxAYmKiRm0otlcUXDTh4eGBcePGqb29SRRaWrVqBQC4desWcnNzSxx1PzY2FgDQsmVLjbcjIiIi0ibmMkREZMwSExNx63oc3OzUL1HYyGUAgGf3EzSKJSVbqtH2gIkUWtzd3dG6dWvExcUhNDQUb7/9tsry6OhopKSkwMXFBd7e3hpvR0RERKRNzGWIiMjYudkJMbatSN9hYPNVicZtGFWhZenSpQgLC0Pfvn3x+eefqywbP348pkyZgiVLlsDb2xsNGzYEADx9+hTz5s0DAIwbNw5mZmZa2Y6IiIiospjLEBGRKUpPT8eTbKlWihyaSsmWQpqerlEbBltoiYuLU375A8Dt27cBAMuWLcOmTZuUz+/evVv5/7S0NNy9exdpaWnF2uvXrx8CAgIQHByMQYMGoVu3bhAKhYiMjER2djb8/f0xcuRIrW1HREREpo25DBERkWky2EJLdnY2rly5Uuz5f//9V+02586diw4dOmDHjh2Ijo6GTCaDh4cHhg4dioCAgFKv5Ki7HREREZku5jJEREQV4+TkBGH2Y4O5dcjeyUmjNgRyuVyupXiogpKTk+Hn54fw8HDUq1dP3+EQERFVKX4PVn/8DImISJuCgoLw7H6C4RRa6nuWOU10ed+DBtujhYiIiIiIiIhMQ4qGY7Rk5xfNOmRnqVkvzZRsKew1aoGFFiIiIiIiIiLSIw8PD43bSEtMBAC419esLXstxMNCCxERERERERHpzbhx4zRuIygoCADKvOWnqnDkMyIiIiIiIiIiLWGPFtKaiIgIhIWFlblORkYGAKBmzZplrte3b1/4+vpqKTIiIiIiIiKiqsFCC1UpiaRocKPyCi1ERERERERE1RELLaQ1vr6+5fZCMaT75oiIiIiIiIi0jWO0EBERERERERFpCQstRERERERERERawkILEREREREREVVrBQUFSExMRHp6ur5D4RgtRERERERERGS4KjLD7e3bt1FYWIipU6eiTp06pa5XFTPcskcLEREREREREVVbBQUFKCwsBACkp6ejoKBAr/GwRwsRERERERERGazyZrhdvXo17ty5A6lUCnNzczRp0gQTJ06swghVsUcLEREREREREVVbJ06cgFQqBQBIpVIcP35cr/Gw0EJERERERERE1VbXrl1VHnfr1k1PkRRhoYWIiIiIiIiIqi25XK7vEFSw0EJERERERERE1dY///yj8vjcuXN6iqQICy1EREREREREVG317t1b5XGfPn30E8j/sNBCRERERERERNVWv379ynxc1VhoISIiIiIiIqJqKzQ0FAKBAAAgEAgQGhqq13hYaCEiIiIiIiKiauvEiRPKAXHlcjmndyYiIiIiIiIiUlfv3r0hFAoBAEKhkGO0EBERERERERGpSywWw8ysqLxhZmYGsVis13hYaCEiIiIiIiKiakskEsHPzw8CgQD+/v5wcnLSazxCvb46ERERERERUTUVERGBsLCwMtfJyMgAANSsWbPM9fr27QtfX18tRWZ6xGIxkpKS9N6bBWChhYiIiIiIiEhnJBIJgPILLaQZkUiEhQsX6jsMACy0EBEREREREanF19e33F4oQUFBAIAFCxZURUhkADhGC5ERkkgkmDlzJtLT0/UdChEREREZKOaMRLrBQguREQoJCUF8fDxCQkL0HQoRERERGSjmjES6wUILkZGRSCQIDw+HXC7HsWPHeIWCiIiIiIphzkikOyy0EBmZkJAQyGQyAIBMJuMVCiIiIiIqhjkjke6w0EJkZE6cOAGpVAoAkEqlOH78uJ4jIiIiIiJDw5yRSHdYaCEyMr1794ZQWDShmFAoRJ8+ffQcEREREREZGuaMRLrDQguRkRGLxTAzK/rTNjMzg1gs1nNERERERGRomDMS6Q4LLURGRiQSwc/PDwKBAP7+/nByctJ3SERERERkYJgzEumOUN8BEJH2icViJCUl8coEEREREZWKOSORbrDQQmSERCIRFi5cqO8wiIiIiMiAMWck0g0WWqqxiIgIhIWFlblORkYGAKBmzZplrte3b1/4+vpqKTIiIiIiIiIi08RCi5GTSCQAyi+0EBEREREREZHmWGipxnx9fcvthRIUFAQAWLBggUavtWHDBiQmJmrUBgBlG4q41OXh4YFx48ZpHA8R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Cn9/f07vTEREVEWYy5AhsrKygru7u/IzJyIi3TDIQktOTg4AwMbGptR1atSoAQB4/vx5hdqsX78+goODMWPGDJw6dQopKSnKZV5eXujYsaPK/c66iqOqicViJCUlsTcLERFRFWIuQ0REZLoMcowWxT2jL3d91dTFixcxaNAgJCUlYfXq1fjnn38QGRmJVatWISsrC5MmTcLKlSt1HkdVE4lEWLhwIXuzEBERVSHmMkRERKbLIHu0KK6sKK7ClERx1UWxblmysrLwySef4MWLFwgJCUH9+vWVy/z9/dGsWTO8+eabWLNmDQYOHKgckV/bcRAREZFpYC5DRERkugyyR0vdunUBAA8fPix1HUV3WcW6ZTlx4gQkEgleeeUVlcREoWHDhmjbti2kUimio6N1FgcRERGZBuYyREREpssgCy2tWrUCANy6dQu5ubklrhMbGwsAaNmyZbntPXr0CADKnBPbwcEBAJCRkaGzOIiIiMg0MJchIiIyXQZZaHF3d0fr1q1RUFCA0NDQYsujo6ORkpICFxcXeHt7l9te7dq1AQBxcXEoKCgotrygoABxcXEAgHr16uksDiIiIjINzGWIiIhMl0EWWgBg/PjxAIAlS5bg3r17yuefPn2KefPmAQDGjRsHM7P/fwtLly5Fv379sHTpUpW2evbsCRsbGzx8+BALFixAfn6+cll+fj6+++47PHr0CI6OjujRo4fGcRARERExlyEiIjJNBjkYLgD069cPAQEBCA4OxqBBg9CtWzcIhUJERkYiOzsb/v7+GDlypMo2aWlpuHv3LtLS0lSer1WrFubMmYOvv/4aO3bsQFhYGFq3bg0AuHbtGtLS0mBpaYkffvihWJdcdeIgIiIiYi5DRERkmgy20AIAc+fORYcOHbBjxw5ER0dDJpPBw8MDQ4cORUBAQKWuvAwePBjNmzfH1q1bERMTg7NnzwIAXF1dMWzYMIwdOxZNmzbVeRwAUFhYCOD/B58jIiIyJYrvP8X3oTFjLkNERGR8ystlBHK5XF6VAREQExODESNG6DsMIiIivdqxYwd8fHz0HQapgbkMERFR6bkMCy16kJubi2vXrsHFxQXm5ub6DoeIiKhKFRYWIi0tDV5eXrC2ttZ3OKQG5jJERGTKystlWGghIiIiIiIiItISDi9PRERERERERKQlLLQQEREREREREWkJCy1ERERERERERFrCQgsRERERERERkZaw0EJEREREREREpCUstBARERERERERaQkLLUREREREREREWiLUdwCkW4mJiTh9+jRiY2Nx7do1/Pvvv5DL5Vi+fDn69etX5rYHDx5EcHAwEhISIJPJ0LhxYwwdOhQBAQEwMyu9RqfudtVZQUEBYmJicPLkSVy8eBEPHz5ERkYGnJyc4O3tjREjRqBz587Ftps5cyb2799faruNGzdGaGhoqctNcV9rss94TFdMVFQURo0aVaF1jx8/jjp16gDg8Vya6nQeNtbPgEyTJn97VDmanv+piD6+L0yRunm7Avd1xekjbzcULLQYueDgYGzbtq3S282bNw87d+6ElZUVunbtCqFQiMjISMyfPx+RkZFYvnw5zM3NtbZddXf+/HmMHTsWAODi4oLWrVvDxsYGd+7cwdGjR3H06FF8/PHHmDJlSonbt2/fHg0bNiz2vIuLS6mvaar7WqGy+4zHdMU5Oztj8ODBpS6/evUq7ty5gwYNGsDd3b3Ych7PqqrLediYPwMyTer+7ZH61Dn/0/+r6u8LU6VJ3s59rZ6qytsNipyM2u7du+U//vij/PDhw/J79+7JR44cKW/evLn8yJEjpW4TGhoqb968ubx79+7yu3fvKp9PS0uT9+/fX968eXP5li1btLadMTh37px80qRJ8vPnzxdbdvjwYXnLli3lzZs3l0dGRqosmzFjhrx58+byvXv3Vur1THlfq7PPeExr14ABA+TNmzeXr1mzRuV5Hs8lqw7nYWP/DMg0qfO3R+pR9/xPqqry+8KUqZu3c19XXlXm7YbG8PvckEaGDx+OL7/8EgMGDECDBg0qtM26desAANOnT0ejRo2Uzzs7O2Pu3LkAgA0bNkAmk2llO2PQtWtX/PLLL/Dx8Sm2bMCAAcreAX/++adWXs+U97U6eExrz6VLl3D79m2Ym5uX2eulMox9P1eH87CxfwZkmtT52yPSp6r8vjBl6ubt3NdVw1j2MwstpCIlJQVxcXGwsLAo8V7QTp06wdXVFWlpabh8+bLG25mKVq1aAQBSU1M1bov7unJ4TGvX3r17AQA9evSAq6urxu1xPxdX1ccsPwMiouqJ52/dKClv576uGsa0nzlGC6mIj48HADRr1gzW1tYlrtOmTRukpqbi+vXraN++vUbbmYp///0XQOn3IUZFRSEhIQE5OTmoVasWOnTogO7du5c40BP3dZGK7jMe09rz4sUL/PXXXwCAYcOGlboej2fNVPUxy8+AiLSlMud/0hzP37pRUt7Ofa0ZXefthoiFFlKRnJwMAMpZREqiGPxSsa4m25mCtLQ05Wjbr732WonrHDhwoNhzTZs2xU8//QRPT0+V57mvi1R0n/GY1p7Q0FA8f/4ctWrVQu/evUtdj8ezZqr6mOVnQETaUpnzP2mO52/tKy1v577WjK7zdkPE8jKpyMnJAQDY2NiUuk6NGjUAAM+fP9d4O2MnlUrxxRdf4NmzZ+jatSt8fX1Vlrdo0QKzZs3C4cOHcenSJZw+fRrr1q1DixYtcPv2bYwdO7bY7Uamvq8ru894TGuP4raht956CxYWFsWW83jWjqo+ZvkZEJGm1Dn/k+Z4/tausvJ27mv1VFXebojYo4VUyOVyAIBAIKiS7YzdnDlzEBkZCXd3dyxevLjY8jFjxqg8trW1Re3atdGtWzcEBgbi8uXLWLduHWbPnq1cx9T3dWX3GY9p7bh37x7Onz8PoPTbhng8a0dVH7P8DIhIU+qc/0lzPH9rV1l5O/e1eqoqbzdE7NFCKhQVQkU1sSSK6qFiXU22M2bfffcdfv/9d7i4uGDLli2ljs9SEktLS4wfPx4AcPLkSZVl3NclK22f8ZjWDkVvFm9vbzRp0qRS2/J4rpyqPmb5GRCRrpR1/ifN8fytPeXl7dzX2qXtvN0QsdBCKurWrQsAePjwYanrpKSkqKyryXbGauHChfjtt98gEomwZcsWlanJKsrDwwNA8ZmKuK9LV9I+4zGtucLCQuW9tUOHDlWrDR7PFVfVxyw/AyLSpdLO/6Q5nr+1oyJ5O/e19mkzbzdELLSQCsV0Zrdu3UJubm6J68TGxgIAWrZsqfF2xmjRokXYvHkzatasic2bN6Np06ZqtZORkQGgeLWW+7p0Je0zHtOaO3PmDFJTU2Fra4sBAwao1QaP54qr6mOWnwER6VJp53/SHM/fmqto3s59rX3azNsNEQstpMLd3R2tW7dGQUEBQkNDiy2Pjo5GSkoKXFxc4O3trfF2xmbJkiX49ddf4ejoiM2bN6NFixZqt3XkyBEAgJeXl8rz3NelK2mf8ZjW3O+//w4A6N+/v9qJMo/niqvqY5afARHpUmnnf9Icz9+aqUzezn2tfdrM2w0RCy1UjOJ+uSVLluDevXvK558+fYp58+YBAMaNG1ds3nN1tzMWP//8MzZs2AAHBwds2rRJWZEtzfXr13H8+HEUFhaqPC+VSrF582b89ttvAIoPIgWY7r5Wd5/xmFafRCLB8ePHAZQ+CC7A41nbqvqY5WdAROrS5PxPmuP5Wz2VzdsB7uvKquq83dAI5IqhfckoxcXFKQ9IALh9+zaeP3+ORo0awdHRUfn87t27VbabO3cugoODYWVlhW7dukEoFCIyMhLZ2dnw9/fHL7/8AnNz82Kvp+521V14eDg+/vhjAEVV2WbNmpW4noeHh/LkcezYMXzyySeoWbMmGjVqBFdXVzx//hw3b97E48ePYWZmhs8++wzjxo0rsS1T3Nea7DMe0+rZsmULFixYAA8PD+WVh5LweC5ddTkPG/NnQKZJ3b89qhxNz//0/6r6+8JUqZO3K3BfV5w+8nZDwkKLkYuKisKoUaPKXS8hIaHYcwcPHsSOHTtw8+ZNyGQyeHh4YOjQoQgICCizgqjudtXZvn37EBQUVO56nTp1UlZv79+/j23btiE2NhYPHjxARkYGBAIB3Nzc0KFDB4wYMaLcbramtq813Wc8pitv0KBBuHnzJr744gt8+OGHpa7H47l01ek8bKyfAZkmTf72qOK0cf6nIvr4vjBF6uTtL+O+rhh95e2GgoUWIiIiIiIiIiItMfxSEBERERERERFRNcFCCxERERERERGRlrDQQkRERERERESkJSy0EBERERERERFpCQstRERERERERERawkILEREREREREZGWsNBCRERERERERKQlLLQQVdKKFSvg6emJmTNn6jsUvbh69SomTJiAzp07o0WLFvD09MSKFSv0HVa5Zs6cWWqsnp6e8PT0RHJyssrzxvJZl/b+qIixfM5ERIYoOTlZ+T1kKqKiouDp6QlfX199h2KwAgMD4enpiX379uk7FIPE3KT6E+o7ADI+M2fOxP79+wEArVu3xt69eyEQCEpcd/r06Th48CAGDx6MhQsXVmWYpIZ///0Xo0aNwosXL2BmZgYnJyeYmZnB1ta20m0lJiZi//79iIyMxMOHD5GVlQUbGxvUq1cP7du3x6BBg9CuXTvtvwkjEhUVhejoaLRs2RL+/v76DkdrAgMDER0drfKcQCCAnZ0dGjVqhN69e2PkyJGoWbOmfgKsoH379uHBgwfw9/dHy5Yt9R0OEenB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\n",
      "text/plain": [
       "<Figure size 1152x396 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "### Plot Results\n",
    "sns.set(font_scale=2)\n",
    "sns.set_style(style='white')\n",
    "fig = plt.figure()\n",
    "fig.set_size_inches(16, 5.5)\n",
    "hueOrder = ['Split Conformal', 'Conditional Calibration']\n",
    "\n",
    "movingNResults = coverageDF[coverageDF['Function Class Dimension'] == 10]\n",
    "\n",
    "ax1 = fig.add_subplot(1,2,1)\n",
    "f1 = sns.boxplot(movingNResults,x='Number of Calibration Points',y='Coverage',hue='Method',\n",
    "                               hue_order=hueOrder,ax=ax1)\n",
    "f1.axhline(1-alpha, color='red')\n",
    "\n",
    "plt.legend([],[], frameon=False)\n",
    "\n",
    "movingDResults = coverageDF[coverageDF['Number of Calibration Points'] == 250]\n",
    "\n",
    "ax2 = fig.add_subplot(1,2,2,sharey = ax1)\n",
    "f2 = sns.boxplot(movingDResults,x='Function Class Dimension',y='Coverage',hue='Method',\n",
    "                               hue_order=hueOrder,ax=ax2)\n",
    "f2.axhline(1-alpha, color='red')\n",
    "\n",
    "plt.legend(title='')\n",
    "plt.legend(loc='lower right')\n",
    "\n",
    "plt.tight_layout()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "conformal-gan",
   "language": "python",
   "name": "conformal-gan"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
