{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 51,
   "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 matplotlib.pyplot as plt\n",
    "import math\n",
    "import cvxpy as cvx\n",
    "\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [],
   "source": [
    "from group import compute_group_coverages, compute_split_coverages \n",
    "from group import compute_group_qr_coverages, compute_cqr_coverages\n",
    "from Synthetic_data_generation import get_groups, generate_group_synthetic_data, generate_cqr_data\n",
    "from rkhs import compute_shifted_coverage, compute_qr_coverages, compute_adaptive_threshold\n",
    "from sklearn.metrics.pairwise import pairwise_kernels\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Experiment on grouped data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_group_synthetic_trial(n, x_std, y_std, d, std_dev_list, theta, n_test, n_cal,\n",
    "                              n_groups, alpha, exact=True, eps = 0.0001):\n",
    "    \n",
    "    x_train_final, y_train_final, x_calib, y_calib, x_test, y_test = generate_group_synthetic_data(\n",
    "        n, x_std, y_std, d, std_dev_list, theta, n_test, n_cal, n_groups\n",
    "    )\n",
    "\n",
    "    groups_train = get_groups(x_train_final[:,0:n_groups])\n",
    "    groups_calib = get_groups(x_calib[:,0:n_groups])\n",
    "    groups_test = get_groups(x_test[:,0:n_groups])\n",
    "\n",
    "    groups_train_joined = np.vstack([groups_train,groups_calib])\n",
    "    y_train_joined = np.concatenate((y_train_final,y_calib))\n",
    "    \n",
    "    adaptive_coverages = compute_group_coverages(\n",
    "        groups_train_joined, y_train_joined, y_test, groups_test[0:n_test,:], groups_test[0:n_test,:],\n",
    "        alpha, exact = exact, eps = eps\n",
    "    )\n",
    "    qr_coverages = compute_group_qr_coverages(\n",
    "        groups_train_joined, groups_test, y_train_joined, y_test, alpha, eps = eps\n",
    "    )\n",
    "    cqr_coverages = compute_cqr_coverages(\n",
    "        groups_train, groups_calib, groups_test, y_train_final, y_calib, y_test, alpha\n",
    "    )\n",
    "\n",
    "    adapt_cover = pd.Series(adaptive_coverages)\n",
    "    qr_cover = pd.Series(qr_coverages)\n",
    "    cqr_cover = pd.Series(cqr_coverages)\n",
    "\n",
    "    df = pd.concat([adapt_cover, qr_cover, cqr_cover], keys=[\"adaptive\", \"qr\", \"cqr\"], axis=1).reset_index()\n",
    "    return df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 67.25it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 66.44it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.55it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 69.64it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 66.47it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.76it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.57it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 34.18it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 29.76it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 32.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.10it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.40it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 65.79it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 65.09it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 63.82it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.66it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.39it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.31it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.50it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.48it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.57it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.93it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.96it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.60it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.20it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.63it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.32it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 74.24it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 74.98it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 68.56it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.52it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.53it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.47it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.20it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.87it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.89it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.35it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.79it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 63.17it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.93it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 68.21it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 66.58it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.42it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.12it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.09it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.05it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.37it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.51it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.22it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.89it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.58it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.78it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.58it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.73it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.81it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.58it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.83it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 70.17it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 72.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 73.12it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 73.72it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 69.00it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 68.97it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.90it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.62it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.71it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.38it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 63.77it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 67.93it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 71.96it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 75.55it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 70.22it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.26it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.32it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.05it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.05it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.79it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.56it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.01it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.12it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.21it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.35it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.29it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.68it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.92it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.96it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.05it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.10it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.29it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.86it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.52it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.30it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.87it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.47it/s]\n"
     ]
    }
   ],
   "source": [
    "df = pd.DataFrame()\n",
    "ntrials = 100\n",
    "alpha = 0.9\n",
    "n_train = 50\n",
    "n_cal = 50\n",
    "n_test = 200\n",
    "n = n_train + n_cal + n_test\n",
    "\n",
    "# Parameters for data generation \n",
    "x_std = 0.1\n",
    "y_std = 0.25\n",
    "n_groups = 5\n",
    "d = n_groups + 5 # choose d > n_groups\n",
    "\n",
    "std_dev_list = np.array([20,0.001,1,1,1] ) ## must be of length n_groups\n",
    "\n",
    "theta = np.random.normal(loc=np.zeros(d), scale=x_std)\n",
    "for i in range(ntrials):\n",
    "    try:\n",
    "        append_df = run_group_synthetic_trial(n, x_std, y_std, d, std_dev_list, theta, n_test, n_cal, n_groups, alpha=alpha)\n",
    "        append_df['trial'] = i\n",
    "        df = pd.concat([df, append_df])\n",
    "    except SolverError:\n",
    "        print(\"one solver error\")\n",
    "        continue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAz8AAAJHCAYAAAC+U+hbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAy+klEQVR4nO3dfYDVdZ33/9fAAIKCCAJqeZVmShJaagqo4M0iiuIdrJomaoVp9rOlXW92Nc3blLqW7GZNqLVsoRRTiWqVlPIOutFa8UowzfIuBQFvALkdzu+PdmeXBXSQOXNm5vN4/CPnhnPeH8+cw3me7/d7pq5SqVQCAADQznWo9QAAAAAtQfwAAABFED8AAEARxA8AAFAE8QMAABShvtYDAAAAf7VmzZo8//zzWbFiZa1HaZO6dt0qO++8czp16rTRy+va8lddv/rq8qxb12bHBwCgHerQoS7bbbf1O/q7zzzzTOrru2SbbbZNXV1dM0/WvlUqlSxd+noaGlZl11133eh12vSWn3XrKuIHAIB2Y8WKldlxx77C5x2oq6tL9+7b5qWXntvkdRzzAwAArYjweefe7v+d+AEAAIrQpnd7AwCA9qzb1l3SpXPzv2VftXpt3ly+qtlvt7UTPwAA0Ep16VyfUy+c0uy3O3XCac0WP5MnfzNJMm7cOZv9d++664fp1m3rHHHEkZk06cb0779nhg4d1ixzbYz4AQAAamLu3LnZZ599kyRnn31u1e9P/AAAABu1du3aTJjwxTzzzNNZsmRJ/s//eU+uu+7Luf32W3PXXXekZ8+e6d69R/bcc0CSZNq0H+Tf//2nWblyRerq6nL11ddll112zfHHH52hQw/Jf/zHb5Mkl1xyeV5//fU89ND9efTR32T77bfPzJn3ZJ999s3TTz+VPn365LTTxiZJ/vEfL8gRRxyZvfb6UK6//posWPByOnTokHPP/f+y//4HbNZ6fOEBAACwUY8//lg6darPt7713dx++/SsWrUqt932g8yYMT233PL9fO1r38zChQuSJMuXL8v99/8i//IvkzJ16rQMG3ZofvjDaY231aNHj9xyy/czbtw5ufLKy7L//gfkoIOGZdy4czJo0JDG6x111NH52c/u+c/bXJ7HH38sBx54cCZO/FKOOea4fPe7U/OlL03M9ddfk+XLl2/Wemz5AQAANurDH943227bM7fffmv+/Oc/54UXnsvq1ftlyJCD0q1btyTJ4YcPT0NDQ7beeptceeW1uffee/Lcc8/ll7+cnfe/f/fG2zr++BOTJAcfPCxXXXV5Xnvt1Y3e5x579M/q1avz/PPP5fHH5+bAAw9O586d85vf/DrPPvvnTJ58Y5K/bpV68cUXsvvuezR5PeIHAADYqAceuD+TJ9+Yk0/+aI455ti8/vpr6dq1W5YtW9p4nY4dO6ahoSELFrycT3/67IwZc1IGDx6S3r1758knn/wf1/vv9Fi3bl06dOi4yfs98siRuffemXn88bk5/fQz/vPvNOTrX78p2267bZLklVdeSa9evTZrPXZ7AwAANuo3v/lVDj98eI455rj07r194zE7Dz30YJYtW5pVq1bl/vt/niR54onf593vfnc++tGPZcCAgZkz5+GsW9fQeFv/tSvbL34xK+997y7p0aNHYzj9byNGHJV7752Z559/Lh/60D5Jkn33/UjjbnR/+tMz+djHTs7KlSs3az22/AAAQCu1avXaTJ1wWlVutymOO+6EXH75JZk169506tQpAwYMzNKlb+SUU07NWWednu7de2SHHXZMkhxwwODcccftOeWU0encuXMGDPhg/vjHPzbe1ty5/5EZM+7KVlt1zWWXXZkk2X//A3LjjV9P9+7d17vffv12SM+ePfPBDw5MXV1dkuTv//6iXHfdVTnttJOSJJdfflW23nrrzVp3XaVSqWzW32hFFi9elnXr2uz4AAC0Qx061KV3723e0d/9/e+fyE47vaeZJ6q9448/Ov/yL5Oz0047Vf2+/vKXZzNgwJ4bvcxubwAAQBHs9gYAAFTVXXf9pNYjJLHlBwAAKIT4AQAAiiB+AACAIogfAACgCL7wAAAAWqnuW3dKfefOzX67a1evztLla5r9dls78QMAAK1UfefOeXTCJ5v9dve98FuJ+AEAAPirSqWSG2745zz88IPZfvs+6dWrVwYPPjDf+953su22PdO5c+d8/evfrPWYTSZ+AACAjbrvvp/lySfn5fvfn5bXX38jp59+SgYPPjDPPvvn3HHHj7PTTjvVesTN4gsPCvHb3z6SK664JL/97SO1HgUAgDbid797NIcccnjq6zuld+/eOfjgoUmS7bbr1ebCJ7HlpxjTpk3Nn/70TFauXJF99tmv1uMAANAGdOmyVZJK4+n6+vr/PL9LjSbaMrb8FGLFipXr/RcAAN7OAQcMyr33zszq1auzbNnSzJ79cK1H2iK2/AAAQCu1dvXqv34zWxVutykOOGBwnnxyfs4449R0794jvXv3bvZZWpL4AaBN+u1vH8mMGXdm1KgT7M5bAI83pVq6fE3Nv5J67NizMnbsWUmSK6+8PEly110/qeVI75j4aUe699gqW3XptNHLOnasa/xvnz7dN3qdlavWZOkbdotrD7xJoASOZSyLxxtoDuKnHdmqS6eceuGUjV62aNHSJMnLi5Zu8jpTJ5yWpRE/7YE3CZTAsYxlKfnxLvUDrVLX3dpddtkVtR5hixT3hQe+8pkSlPomwfObEvg5L8+0aVMzb97vM23a1FqP0qJKXTfVVdyWn1I/Ea/r2Gm9/0J7VOrz26ejZSn157xkpX6gVeq6qa7i4qfUJ9I2O+2T5S8/nq13GFjrUaBqSn1+t+c3w1t6LGPS/o5nbM8/5x5voNqKi59Sddl253TZdudaj0Ez8gUX/Jf2/GZ4S49lTBzP2JZ4vIFqa3fx81ZvCBNvCmk/fMEFAG2Z92xN022bTunSqXOz3+6qNavz5rLafoV2LbS7+HmrN4SJN4WlcSxE+2OLF9DelBoB3rM1TZdOnXPmzZ9t9tv9zlk35M2IH2hX2vOxEKUqdYuX6NtQe/4iF8e+bKg9P94iAFpOcfHTnl882VB7Phbirfg5b39Kjb630p6/yMWxLxtqz483tGaVSiXf+MZXc//9P0/Hjh1zwgmjs/feH8q1116dJBk8eHDuuefu3HXXT3LllZfn9ddfywsvPJ/PfOazOfjgYTWefkPFxY8Xz9qxC1rL8XNOCXyRS1k83uXxQV7rMGvWvZk797FMmXJb1q5dm0996uO59dbv58IL/zGDBg3Jt75103rX33bbnvm///eGGk379or7Jaddtt05vfYY6QW0BvyyspZT6s+5fyiBaqvFL5kt9bVtm532Sadtdsg2O+1T61GK9rvfPZrDDx+ezp07p1u3bvnqV2/MsmVLM2jQkCTJcceduN71Bwz4YC3GbLLi4ofaKXUXtFLV4g1Cqf9QtoY3RrV4vKEWavFBXqmvba3hgzyvbUl9/fo7ii1evCiVSmWTl3fp0qVF5nqnitvtjfbHgeCtUy2+bKLU3WJaw26Ovlyk5bSG2C1ZLT7IK/W1rTXw2pZ86EP75NZbv5/Ro8dk7dq1ueSSi9KlS5c88MD9GTp0WGbO/Pdaj7hZxA9tngPBWydb+lpOa3hj5PFuOa0hdqEUreG1bdWa1fnOWc1/DM2qNaubdL1DDjks8+Y9kTPOOC3r1q3LSSd9NPvvf0CuvfaqfOtb38x737tLs89WTeIHqswXPUD7VYvnd2uIXaDlvLlsTc1/H8+5534m5577mfXOu/HGyUmSv/zlL/n0p8clSS677IoWn21zOeanBuw/WhZf9FAWz++yeH5TCq9ttBe2/NSA/UdbTmvYN741bDKn5Xh+l8Xzu/3psW2XdOnceZOXN+VY0lWrV+eN11dVZb5a8drGpuy00065666f1HqMJhM/NeAfy5Zj33hamuc3JWjPu/N26dw5Z9782U1evuCNVxr/u6nr/fX4jPYVP17bWlalUkldXV2tx2iT/uc30W2M+KFd29J949vzP/AA75StALQnb7W1rxZb+rp23SpLl76e7t23FUCbqVKpZOnS19O161abvI74gbfgH/i31tr+waC6tvTxTjzm7YWtALQnb7W1rxZb+nbeeec8//zzeeml55rtNkvStetW2XnnTX/wXVd5u21Drdjq0X+bvPzyeud17tQxTzyzYItud89d+2X1moYtuo36+g7psIlanzd/flatWpUuXbrkA/37b/Q66yqVrF27brPuc0vXbt0bevrpP2T16tXp3Llzdttt93d0+81xGxvTGh7vzp06Zv7LT2/0slWL3kyloZK6jnXpsn23jV6n/w67bfYMrWHdb8XjvenHO9n8x7y1vKZvSmt9vBPr3phlS5dm8eJF6d17+2zTfeOR/lY/50l1Xtta++OdVOcxby3rrsq/ZTvskM4/nLZFc1EdtvxUSYe6uk0+kVavXd34301dp/8Ou1Vttmoqdd1vFX3/tcm6rq4unTt13Oh13kn0AVuuKW+Gt/T5nXiOtxavvLIgK1auzLp1DZt8vN9OXV1dKnE8BrRVbXrLz+LFy7Ju3frj9+nTfZO/zLKppk44La+8snSLbqNPn+6b3Dz60vQ/ZO3S1anv3jk7HrfxT0++c9YNmz3Dlq7dujf0d3/36bz88l+yww475Stf+Ze3nKE9rXtzZihx3W+1+9fYsWPz4osv5l3velduueWWjV7nnez61RrWvaWPd7L5j3m1X9P/8R8/lz/96Znsssuu+eIX/3mTM7S3dW+ppr42bq5qr7spc7/V450kK15YmqXzFqX7B7ZP13dvPKDa2+OdVOcxby3rrsa/ZR061KV37222aC6qw5YfgM3U2vYP551z7Aqbq+u7u28yetoyX/FNKcQPxVu3ds0mX8ibehA3QHvjCy7K0h6/4rs5vrG1rlOH9f5L2yd+asATqXXpUN8pj0745EYvW/Xqgsb/buo6SbLvhd+qymwAtbKlWziT1vdmmLI0xze2brtXv8bdHGkfxE8NeCLRFmzpJ2Yivyweb6C1aY7dWtvrbo4lEz814IlUlrb6pnBLPzFrq5HvF9u+M6358a7mrq1t9fndntmVGXgr4mczeWPE5mrNbwrfypZ+YtZWI39Lo6/UN8Ot+fHe0l1b32q31rb6/G7Pqvl4A22f+NlMzbH/aKna4pvCLvUd1vvvO9Ga3xSyoS2NPm+Gy+L5TVvgg1v4b+JnM/la1HeuLb4pPGK37XL/n17PsF22rfUotBFt9c2wN0fQfrXnD27t5sjmEj+0mLb4pvADfbrlA3261XoMqLr2/OaIDYndsjTHB7etde8N39jK5hI/G+FTBErwVj/niZ/10tiqXZZSj21rjl2ZS9UW996AjRE/G+FTBErwVj/nSfs9MFj08T+V+ma41GPb7Mr8zrXFvTdgY8QPUJRSo4+N82b4nWmrb4TtygyIHwCK5c0wtF+lbtnlrYmfzVTqE8nBsQDQejleeUO27LIx4mczlfpE8k1Q5Sk19NsrxzpB++aXu27Ill02RvxsplKfSL4Jqjylhn575Vin8tgSALAh8QNsVKmhb4sX7YUtAQAb8q87wP9wxG7bZdfttsoRu21X61EAgGZmyw+N7CIB5W7xAoASiB8a+eWuAND+2J0X/ptnAQDeHEE7Znde+G+2/ADg2/0KI3bLYnde+G/iBwBvjgojdoFSiR+axKeEAO2H2AVK5Z0sTWJ/YQAA2jpbfmgSnxICANDW2fIDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEaoaPzNmzMjIkSMzfPjwTJkyZYPLf//732f06NE59thj86lPfSpvvPFGNccBAAAKVrX4WbBgQSZOnJipU6dm+vTpufXWW/P000+vd51rrrkm559/fn70ox9ll112ybe//e1qjQMAABSuavEze/bsDBo0KD179ky3bt0yYsSI3H333etdZ926dVm+fHmSZMWKFdlqq62qNQ4AAFC4+mrd8MKFC9OnT5/G03379s3cuXPXu87FF1+cs846K9dee226du2a2267bbPuo3fvbZpl1taqT5/utR6hJqy7LNZdnlLXbt1lse6ylLrutqhq8VOpVDY4r66urvHPK1euzCWXXJLvfve72WuvvXLzzTfnoosuyqRJk5p8H4sXL8u6devfT3v64XvllaWbdf32snbrbhrrbttKXXeyeWu37rbPut+edbd9/3vdHTrUtfsP6duqqu321q9fvyxatKjx9MKFC9O3b9/G03/4wx/SpUuX7LXXXkmSk08+Ob/+9a+rNQ4AAFC4qsXPkCFDMmfOnCxZsiQrVqzIzJkzM3To0MbL3/Oe9+Tll1/OM888kyS57777MnDgwGqNAwAAFK5qu73169cv48ePz9ixY7NmzZqMGTMme+21V8aNG5fzzz8/AwcOzBe/+MX83d/9XSqVSnr37p1rr722WuMAAACFq1r8JMmoUaMyatSo9c6bPHly45+HDRuWYcOGVXMEAACAJFX+JacAAACthfgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiVDV+ZsyYkZEjR2b48OGZMmXKBpc/88wzOf3003PsscfmE5/4RF5//fVqjgMAABSsavGzYMGCTJw4MVOnTs306dNz66235umnn268vFKp5Nxzz824cePyox/9KB/4wAcyadKkao0DAAAUrmrxM3v27AwaNCg9e/ZMt27dMmLEiNx9992Nl//+979Pt27dMnTo0CTJOeeck9NOO61a4wAAAIWrr9YNL1y4MH369Gk83bdv38ydO7fx9HPPPZftt98+F110UZ544onsvvvu+fznP79Z99G79zbNNm9r1KdP91qPUBPWXRbrLk+pa7fuslh3WUpdd1tUtfipVCobnFdXV9f457Vr1+bXv/51/u3f/i0DBw7MV77ylVx33XW57rrrmnwfixcvy7p1699Pe/rhe+WVpZt1/faydutuGutu20pdd7J5a7futs+63551t33/e90dOtS1+w/p26qq7fbWr1+/LFq0qPH0woUL07dv38bTffr0yXve854MHDgwSXLMMcest2UIAACgOVUtfoYMGZI5c+ZkyZIlWbFiRWbOnNl4fE+SfPjDH86SJUsyf/78JMmsWbMyYMCAao0DAAAUrmq7vfXr1y/jx4/P2LFjs2bNmowZMyZ77bVXxo0bl/PPPz8DBw7MN77xjVx66aVZsWJFdthhh0yYMKFa4wAAAIWrWvwkyahRozJq1Kj1zps8eXLjn/fee+/cfvvt1RwBAAAgSZV/ySkAAEBrIX4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAITYqf5cuX54orrsgZZ5yR1157LZdddlmWL19e7dkAAACaTZPi5+qrr06PHj2yePHidOnSJcuWLctll11W7dkAAACaTZPiZ968eRk/fnzq6+vTtWvXfPnLX868efOqPRsAAECzaVL8dOiw/tUaGho2OA8AAKA1q2/KlT7ykY/kS1/6UlauXJkHH3wwU6ZMyQEHHFDt2QAAAJpNkzbf/MM//EO6deuW7t27Z+LEidljjz1y4YUXVns2AACAZtOkLT+dOnXKeeedl/POO6/a8wAAAFRFk+LnsMMOS11dXePpurq6dO3aNe9///tz8cUXp2/fvlUbEAAAoDk0KX7+5m/+JsuXL89pp52WDh065Pbbb8/y5cuzxx575LLLLss3v/nNas8JAACwRZp0zM8jjzySa665JnvuuWf69++fSy+9NE899VTOPPPMvPjii9WeEQAAYIs1KX6WL1+eZcuWNZ5etmxZVq5cWbWhAAAAmluTdnsbPXp0TjrppBx55JGpVCqZOXNm/vZv/zbf+973suuuu1Z7RgAAgC3WpPg5++yz84EPfCAPPPBA6uvr8/nPfz6DBg3K//t//y8nnHBCtWcEAADYYk2KnyQZOHBgdtttt1QqlTQ0NOThhx/OgQceWM3ZAAAAmk2T4ueGG27IpEmT/voX6uuzevXq7LbbbpkxY0ZVhwMAAGguTfrCg+nTp+fnP/95RowYkXvuuSfXXXdddtttt2rPBgAA0GyaFD+9evVK3759s+uuu2b+/Pk57rjj8uyzz1Z7NgAAgGbTpPipr6/Pc889l1133TWPPPJI1q5dmzfeeKPaswEAADSbJsXPOeeck89//vM55JBD8rOf/SyHHHJIBg0aVO3ZAAAAmk2TvvBg7dq1+e53v5skueuuu/Lss89mjz32qOpgAAAAzalJW34mTpzY+OeuXbumf//+qaurq9pQAAAAza1JW35233333Hjjjdlvv/3SrVu3xvMHDBhQtcEAAACaU5Pi57HHHstjjz2WadOmNZ5XV1eX++67r2qDAQAANKcmxc+sWbOqPQcAAEBVNemYn+XLl+fKK6/MGWeckddeey2XXXZZli9fXu3ZAAAAmk2T4ufqq69O9+7ds3jx4nTp0iXLli3LZZddVu3ZAAAAmk2T4mfevHkZP3586uvr07Vr13z5y1/OvHnzqj0bAABAs2lS/HTosP7VGhoaNjgPAACgNWvSFx585CMfyZe+9KWsXLkyDz74YKZMmZIDDjig2rMBAAA0myZtvvmHf/iHdOvWLd27d8/EiROzxx575MILL6z2bAAAAM2mSVt+fvnLX+a8887LeeedV+15AAAAqqJJW36+/vWv57DDDss3vvGNLFiwoNozAQAANLsmxc+tt96ayZMn580338xJJ52UT33qU7n33nurPRsAAECzafJXtr3vfe/LBRdckK997Wt59dVX87nPfa6acwEAADSrJh3zs3jx4vzoRz/KnXfemYaGhowZMyY33XRTtWcDAABoNk2KnyOOOCJHHHFELr/88uy7777VngkAAKDZNSl+7r///myzzTZ58cUX8+yzz+Y973lPtecCAABoVk3e7e3kk0/OggULUqlUst122+Wmm27K+973vmrPBwAA0Cya9IUHV155ZT75yU/mkUceyaOPPppzzz03V1xxRbVnAwAAaDZNip/FixfnhBNOaDw9evTovPrqq1UbCgAAoLk1KX4aGhry2muvNZ5esmRJteYBAACoiiYd8/Oxj30sJ598co466qgkyb//+7/njDPOqOpgAAAAzalJW36GDRuWJFmzZk2eeeaZLFiwIMOHD6/qYAAAAM2pSVt+Lr744px22mkZO3ZsVq1ale9///v5p3/6p0yePLna8wEAADSLJm35efXVVzN27NgkSZcuXXLmmWfmlVdeqepgAAAAzanJX3iwYMGCxtOLFi1KpVKp2lAAAADNrUm7vZ155pk5/vjjc/DBB6euri6zZ8/OhRdeWO3ZAAAAmk2T4mfMmDH54Ac/mF/+8pfp2LFjPvGJT2T33Xev9mwAAADNpknxkyT9+/dP//79qzkLAABA1TTpmB8AAIC2TvwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARahq/MyYMSMjR47M8OHDM2XKlE1e7xe/+EUOO+ywao4CAAAUrr5aN7xgwYJMnDgxd9xxRzp37pxTTjklBxxwQHbbbbf1rrdo0aJcf/311RoDAAAgSRW3/MyePTuDBg1Kz549061bt4wYMSJ33333Bte79NJL85nPfKZaYwAAACSp4pafhQsXpk+fPo2n+/btm7lz5653nVtuuSV77rln9t5773d0H717b7NFM7Z2ffp0r/UINWHdZbHu8pS6dusui3WXpdR1t0VVi59KpbLBeXV1dY1//sMf/pCZM2fmO9/5Tl5++eV3dB+LFy/LunXr3097+uF75ZWlm3X99rJ2624a627bSl13snlrt+62z7rfnnW3ff973R061LX7D+nbqqrt9tavX78sWrSo8fTChQvTt2/fxtN33313XnnllYwePTpnn312Fi5cmFNPPbVa4wAAAIWrWvwMGTIkc+bMyZIlS7JixYrMnDkzQ4cObbz8/PPPzz333JPp06dn0qRJ6du3b6ZOnVqtcQAAgMJVdcvP+PHjM3bs2Bx//PE55phjstdee2XcuHF5/PHHq3W3AAAAG1W1Y36SZNSoURk1atR6502ePHmD67373e/OrFmzqjkKAABQuKr+klMAAIDWQvwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEAR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1nocWosKm+3OO++sHHTQQZVDDz201qO0iJdffrly6KGHVl599dXK8uXLK6NGjao89dRTtR6rRfzHf/xH5ZhjjqkMGDCg8vzzz9d6nBbx8MMPV04++eTKqlWrKqtXr66MHTu2MnPmzFqPVXW/+tWvKqecckplzZo1lRUrVlQOPfTQyh//+Mdaj9ViZs+eXTnggAMqF110Ua1HaRHr1q2rHHjggZU1a9bUepQW9dxzz1UOOuigyksvvVRZvXp15aMf/WjlF7/4Ra3HalF/+MMfKsOHD68sXry41qO0iDfffLPykY98pLJ48eLKmjVrKmPGjKk8/PDDtR6r6h5++OHKMcccU1m6dGll7dq1lU996lOVe+65p9Zj0QrY8rOZli5dmvvuuy///M//XOtRWszs2bMzaNCg9OzZM926dcuIESNy991313qsFnHbbbfl8ssvT9++fWs9Sovp06dPLr744nTu3DmdOnXK+973vvzlL3+p9VhVt//+++eWW25JfX19Fi9enIaGhnTr1q3WY7WI1157LRMnTsw555xT61FazDPPPJO6urqMGzcuxx57bP7t3/6t1iO1iJ/97GcZOXJkdthhh3Tq1CkTJ07M3nvvXeuxWtQXvvCFjB8/Pr169ar1KC2ioaEh69aty4oVK7J27dqsXbs2Xbp0qfVYVffEE0/koIMOyjbbbJOOHTvm4IMPzr333lvrsWgFxM9m6t69e772ta9lxx13rPUoLWbhwoXp06dP4+m+fftmwYIFNZyo5VxzzTXZb7/9aj1Gi3r/+9+fD33oQ0mSP//5z/npT3+aYcOG1XaoFtKpU6d89atfzdFHH53BgwenX79+tR6pRVx22WUZP358evToUetRWswbb7yRwYMH5xvf+Ea+853v5Ac/+EEefvjhWo9Vdc8++2waGhryiU98Iscee2ymTp2abbfdttZjtZjZs2dn5cqVOeqoo2o9SovZZptt8tnPfjZHHXVUhg4dmne9613ZZ599aj1W1Q0YMCAPPfRQXnvttaxatSqzZs3KokWLaj0WrYD44W1VKpUNzqurq6vBJLSkp556Kh//+Mdz0UUX5b3vfW+tx2kx559/fubMmZOXXnopt912W63Hqbpp06Zlxx13zODBg2s9Sov68Ic/nAkTJqRbt27p1atXxowZk/vvv7/WY1VdQ0ND5syZky996Uu57bbb8vjjj+fOO++s9Vgt5gc/+EHOOuusWo/RoubPn58f/vCH+fnPf56HHnooHTp0yLe//e1aj1V1gwcPzoknnpjTTz89n/zkJ7PvvvumU6dOtR6LVkD8NMENN9zQeJDkfffdV+txWly/fv3W+7Rk4cKFRe0GVqJHH300Z555Zv7+7/8+J5xwQq3HaRF//OMfM2/evCRJ165dc8QRR+TJJ5+s8VTV99Of/jQPP/xwjjvuuHz1q1/NrFmzcu2119Z6rKp75JFHMmfOnMbTlUol9fX1NZyoZWy//fYZPHhwevXqla222iqHH3545s6dW+uxWsTq1avzm9/8JocddlitR2lRDz30UAYPHpzevXunc+fOOfHEE/PrX/+61mNV3bJlyzJ8+PDMmDEj3/ve99K1a9fsvPPOtR6LVkD8NMFnP/vZTJ8+PdOnT8/hhx9e63Fa3JAhQzJnzpwsWbIkK1asyMyZMzN06NBaj0WVvPTSSznvvPPy5S9/uahvNHzhhRdy6aWXZvXq1Vm9enXuu+++7LvvvrUeq+puvvnm/PjHP8706dNz/vnn57DDDss//dM/1Xqsqlu6dGkmTJiQVatWZdmyZbnzzjszfPjwWo9VdYceemgeeuihvPHGG2loaMiDDz6YAQMG1HqsFvHkk0/mve99bzHH8v2X/v37Z/bs2XnzzTdTqVQya9asDBw4sNZjVd0LL7yQ8847L2vXrs3SpUszbdq0onZ3ZNPa/8dcbLF+/fpl/PjxGTt2bNasWZMxY8Zkr732qvVYVMm3v/3trFq1Ktddd13jeaeccko++tGP1nCq6hs2bFgee+yxHH/88enYsWOOOOKIouKvNIceemjj471u3bqceuqp+fCHP1zrsapu7733zic/+cmceuqpWbNmTQ488MCMHj261mO1iOeffz477LBDrcdocQcddFCeeOKJnHjiienUqVMGDhyYs88+u9ZjVV3//v1zxBFH5Nhjj01DQ0POPPPMIj7Q4u3VVTZ2QAcAAEA7Y7c3AACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIrgl5wCtDOTJk3K7bffnq233jr77bdf7rvvvuy///557bXX8vzzz+eQQw7JOeeckyuuuCLz589PXV1dDj744Hzuc59LfX199thjj8yZMye9evVKksbTTz31VCZMmJB+/frl+eefz1ZbbZXrrrsu73vf+2q8YgBoGlt+ANqRBx98MHfccUduv/323HHHHVm+fHnjZStXrsxPfvKTXHDBBbn66qvTs2fPzJgxIz/84Q/z5JNP5l//9V/f9vafeOKJfPzjH8+MGTNy4okn5oILLqjmcgCgWYkfgHbk/vvvz5FHHpkePXqkrq4up512WuNl++67b+OfH3jggXzsYx9LXV1dOnfunFNOOSUPPPDA295+//79s99++yVJRo8enXnz5uXVV19t/oUAQBWIH4B2pL6+PpVKpfF0x44dG//crVu3xj+vW7duvb+3bt26rF27doPbW7169Xqn/+ftJUmlUtngPABorcQPQDsybNiwzJw5M0uXLk2S3H777Ru93kEHHZQpU6akUqlk9erVue222zJkyJAkSa9evfL4448nSX72s5+t9/fmz5+f+fPnJ0luvfXW7LPPPunRo0e1lgMAzcoXHgC0I4MHD85JJ52Uk08+OVtttVXe//73p2vXrhtc79JLL83VV1+dUaNGZc2aNTn44INzzjnnNF525ZVXpkePHhkyZEj69OnT+Pe23377fOUrX8mLL76YXr16ZcKECS22NgDYUnWV/7l/BABt2uOPP57f/e53GTt2bJLk5ptvzmOPPZavfOUrW3zbv/rVr3LVVVflxz/+8RbfFgDUgi0/AO3ILrvsksmTJ+e2225LXV1ddtxxx1x11VW1HgsAWgVbfgAAgCL4wgMAAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAj/P6FW4BX+Gv5uAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 842.4x595.44 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "sns.set(rc={'figure.figsize':(11.7,8.27)})\n",
    "\n",
    "melted_df = pd.melt(df, id_vars=[\"index\"], value_vars=[\"adaptive\", \"qr\", \"cqr\"])\n",
    "melted_df = melted_df.rename(columns={\"index\": \"group\", \"value\": \"coverage\"})\n",
    "#melted_df = melted_df[melted_df[\"group\"] <=5]\n",
    "\n",
    "fig = sns.barplot(melted_df, \n",
    "            x=\"group\", y=\"coverage\", hue=\"variable\")\n",
    "fig.axhline(alpha,color='red')\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/GroupCoverageComparison.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Experiment on RKHS Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_coverage_at_shift(x_test,scores_test,thresholds,shift_loc,gamma, eps = 0.0001):\n",
    "    g = pairwise_kernels(\n",
    "                X=np.array([shift_loc]).reshape(1,-1),\n",
    "                Y=x_test,\n",
    "                metric=\"rbf\",\n",
    "                gamma=gamma\n",
    "            )[0,:]\n",
    "    return np.average(scores_test <= thresholds+eps, weights=g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 300/300 [00:07<00:00, 37.77it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:07<00:00, 37.61it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 37.48it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 36.91it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:07<00:00, 39.15it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 37.28it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 35.35it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 36.72it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 35.92it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 37.37it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 36.18it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 36.31it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 35.81it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.09it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.24it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.44it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 28.33it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 28.44it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.96it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:08<00:00, 33.51it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.81it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.89it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 33.06it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.45it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.96it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.25it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.81it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:11<00:00, 26.94it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:12<00:00, 23.09it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 27.94it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 33.18it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.39it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.61it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.96it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.25it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.41it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.25it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.66it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.08it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.53it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.73it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.95it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.60it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.77it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.79it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.09it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.83it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.17it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.87it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.68it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.39it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.20it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.03it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.05it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.28it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.16it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.62it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.33it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.67it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.44it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.77it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.10it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.38it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.92it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.41it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.82it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.72it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.18it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.78it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.30it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.02it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.87it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.57it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.74it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.51it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.47it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.18it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.39it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.60it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 32.13it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.87it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.89it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.21it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.29it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.18it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.32it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.42it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.90it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.13it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 28.56it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.82it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.84it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.79it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.74it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.40it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 28.46it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.60it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 31.12it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:10<00:00, 29.40it/s]\n",
      "100%|█████████████████████████████████████████| 300/300 [00:09<00:00, 30.48it/s]\n"
     ]
    }
   ],
   "source": [
    "def run_rkhs_synthetic_trial(n_calib, n_test, alpha, radius, shift_locs, gamma, eps = 0.0001):\n",
    "\n",
    "    x_train_final, y_train_final, x_calib, y_calib, x_test, y_test = generate_cqr_data(\n",
    "                                                                        n_train = 2*n_calib,\n",
    "                                                                        n_test = n_test)\n",
    "    z_calib = pairwise_kernels(\n",
    "                X=x_calib,\n",
    "                Y=np.array(shift_locs).reshape(len(shift_locs),1),\n",
    "                metric=\"rbf\",\n",
    "                gamma=gamma\n",
    "            )\n",
    "    z_calib = np.column_stack((z_calib,np.ones(len(x_calib))))\n",
    "    z_test = pairwise_kernels(\n",
    "                X=x_test,\n",
    "                Y=np.array(shift_locs).reshape(len(shift_locs),1),\n",
    "                metric=\"rbf\",\n",
    "                gamma=gamma\n",
    "            )\n",
    "    z_test = np.column_stack((z_test,np.ones(len(x_test))))\n",
    "\n",
    "    reg = LinearRegression().fit(x_train_final, y_train_final)\n",
    "    scores_calib = np.abs(reg.predict(x_calib) - y_calib)\n",
    "    scores_test = np.abs(reg.predict(x_test) - y_test)\n",
    "\n",
    "    _, adaptive_coverage, adaptive_thresholds = compute_shifted_coverage(\n",
    "        scores_test,\n",
    "        scores_calib,\n",
    "        x_calib,\n",
    "        x_test,\n",
    "        None,\n",
    "        kernel=\"rbf\",\n",
    "        alpha=alpha,\n",
    "        radius=radius,\n",
    "        gamma=gamma,\n",
    "        z_calib=z_calib,\n",
    "        z_test=z_test,\n",
    "        exact=True,\n",
    "        eps=eps\n",
    "    )\n",
    "    qr_coverage, qr_thresholds = compute_qr_coverages(x_calib, x_test, scores_calib, \n",
    "                                        scores_test, alpha, gamma, radius, \"rbf\", z_calib,\n",
    "                                                      z_test, eps\n",
    "                                 )\n",
    "\n",
    "    q = np.quantile(scores_calib, [alpha * (1 + 1/len(scores_calib))])\n",
    "    conformal_thresholds = q\n",
    "    conformal_coverage = np.mean(scores_test <= conformal_thresholds+eps)\n",
    "    \n",
    "    results_df = pd.DataFrame({'coverage' : [adaptive_coverage, qr_coverage, conformal_coverage],\n",
    "                             'type' : ['robust','qr','split'],'shift_loc' : ['None','None','None']})\n",
    "    for shift in shift_loc:\n",
    "        shift_adaptive_cov = compute_coverage_at_shift(x_test, scores_test, \n",
    "                                                       adaptive_thresholds, shift, gamma, eps)\n",
    "        shift_qr_cov = compute_coverage_at_shift(x_test, scores_test, qr_thresholds,\n",
    "                                                 shift, gamma, eps)\n",
    "        shift_split_cov = compute_coverage_at_shift(x_test, scores_test, conformal_thresholds,\n",
    "                                                    shift, gamma, eps)\n",
    "        \n",
    "        shift_df = pd.DataFrame({'coverage' : [shift_adaptive_cov, shift_qr_cov, shift_split_cov],\n",
    "                             'type' : ['robust','qr','split'],'shift_loc' : [shift,shift,shift]})\n",
    "        \n",
    "        results_df = pd.concat([results_df,shift_df])\n",
    "        \n",
    "    return results_df\n",
    "\n",
    "ntrials = 20\n",
    "alpha = 0.9\n",
    "n_calib = 100\n",
    "n_test = 300                                             \n",
    "#radius = 1\n",
    "gamma = 2\n",
    "shift_loc = [0.5, 1.4, 2.5, 3.5, 4.5]\n",
    "#shift_loc = [3.5,4.5]\n",
    "\n",
    "radii=[1,100,1000,5000,100000]\n",
    "#radii=[1000]\n",
    "\n",
    "cqr_df = pd.DataFrame()\n",
    "for radius in radii:\n",
    "    for i in range(ntrials):\n",
    "        try:\n",
    "            append_df = run_rkhs_synthetic_trial(n_calib, n_test, alpha,\n",
    "                                         radius, shift_loc, gamma)\n",
    "            append_df['trial'] = i\n",
    "            append_df['radius'] = radius\n",
    "            cqr_df = pd.concat([cqr_df, append_df])\n",
    "        except cvx.error.SolverError:\n",
    "            print(\"one solver error\")\n",
    "            continue\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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sCSkG8p79+5Vs2bNtGHDhhLXd+/eXXv37g1SKmtWrlypPn36qGfPnlqwYEGZ6XPnzlW3bt3Ur18/9evXr9zbBEp2draSkpIqnacff/yxunfvHsBUv5s7d6769u2rvn37asaMGeVOd8O8nD17tvr06aO+ffvqtddeKzPdLTkl6ZlnntG4cePKXL98+XJ16tTJl3HWrFlBSFc5k+uCZE5tcHtdkKgNTqA2BIcpdUFyf22gLtiPuhA8ptQGt9cFidrgBGpDcJhSFyT31wbqgv1MrgthyRvC9uzZ423ZsqW3W7du3uPHj/uu79atm3fPnj1BTFa5/fv3e7t16+bNysry5uTkeJOTk73ffvttidvcfffd3i+++CJICX/3z3/+05uUlORt2bJlhfP0wIED3uuvv97brVu3AKfzejds2OAdNGiQ9+TJk978/Hxvamqqd82aNSVu44Z5uXnzZu/gwYO9BQUF3tzcXG+3bt2833//fYnbuCGn1+v1bty40du+fXvvI488UmbalClTvCtXrgxCKutMrQterzm1we11weulNjiB2hAcptQFr9f9tYG6YD/qQvCYUhvcXhe8XmqDE6gNwWFKXfB63V8bqAv2M70uhKOQPkJZkuLj49WxY0c988wzZaa99NJL6tOnj5KTkzV9+nQVFRVp79696t+/v8aOHaukpCQNGzZMR44ckSR9+umnSklJUf/+/XX//fcrKyvLkcwbN25Uhw4dVKdOHcXGxioxMVGrVq0qcZt//etfmj9/vpKTkzVlyhSdPHnSkSynsnjxYk2ePFnx8fEV3mbixIm6//77A5jqd3FxcRo3bpyio6NVrVo1XXjhhfrll19K3MYN8/Kqq67SG2+8oaioKB06dEhFRUWKjY11Xc4jR45o1qxZuueee8qd/tVXX2n58uW64YYbNGbMGB09ejTACa0xsS5I5tQGt9cFidpgN2oDYwYr3F4bqAv2oi4wZrDC7XVBojbYjdrAmMEKt9cG6oK9QqUuhJuQbyhL0rhx4/TZZ5+V+ErKJ598onXr1mnZsmV65513tHv3br311luSpJ07d2rEiBF69913VatWLa1cuVKHDx/W//t//0+vvvqq73D7mTNnOpI3MzNTcXFxvsvx8fHKyMjwXc7JyVGLFi30yCOP6J133tGxY8f0l7/8xZEsp/LUU0+pXbt2FU5/4403dMkl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bQBQGnUBcBeOUIbtzj33XH344Ye66667lJ2drREjRigrK0vVqlXz3cbj8cjr9dr6vMXFxWWu83q9KiwsVGRkpDwej+/6Y8eOae/evbY+P4DKURsAlEZdAFAeagOA0qgLgLvQUIbtFi5cqPHjx6tTp04aO3asOnXqpAULFvj9OJGRkSosLLR8+zZt2uiHH37Q9u3bJUnffvut/u///k9XXXWVOnbsqA8//FDZ2dmSpDlz5uj111/3OxOA00dtAFAadQFAeagNAEqjLgDuwikvYLv+/fvr888/V58+fVS9enU1atRIqampmj17tl+Pc/nll+u5557TqFGj9MILL5zy9vXq1dPs2bM1depU5eXlyePxaNq0abrgggt0wQUX6LvvvtMtt9wiSWratKmmTp16Wq8PwOmhNgAojboAoDzUBgClURcAd/F47f4+AAAAAAAAAAAgJHGEMlxv165dGj16dLnTLrjgAj333HOBDQTAFagNAEqjLgAoD7UBQGnUBaBqOEIZAAAAAAAAAGAJP8oHAAAAAAAAALCEhjIAAAAAAAAAwBIaygAAAAAAAAAAS2goAwAAAAAAAAAsoaEMAAAAAAAAALDk/wd5IUbRN4n9pwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1440x288 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "#sns.set(rc={'figure.figsize':(11.7,8.27)})\n",
    "\n",
    "def make_coverage_barplot(x,y,hue,**kwargs):\n",
    "    fig = sns.barplot(x=x,y=y,hue=hue)\n",
    "    fig.axhline(alpha,color='red')\n",
    "    \n",
    "fig = sns.FacetGrid(cqr_df, col=\"radius\",height=4) \n",
    "fig.map(make_coverage_barplot,\"shift_loc\",\"coverage\",\"type\")\n",
    "#fig.add_legend()\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x288 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "sns.set(rc={'figure.figsize':(11.7,8.27)})\n",
    "\n",
    "cqr_df['gap'] = np.abs(cqr_df['coverage'] - 0.9)\n",
    "\n",
    "def make__gap_barplot(x,y,hue,**kwargs):\n",
    "    fig = sns.barplot(x=x,y=y,hue=hue)\n",
    "\n",
    "fig = sns.FacetGrid(cqr_df, col=\"radius\",height=4) \n",
    "fig.map(make__gap_barplot,\"shift_loc\",\"gap\",\"type\")\n",
    "#fig.add_legend()\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Finite Dim Regression Example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.41it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.62it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.88it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.48it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.42it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.72it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.93it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.58it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 40.40it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.80it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.99it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.71it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.39it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.85it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.27it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.05it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.30it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.87it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 38.00it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 29.82it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 37.63it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.97it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.74it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.30it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.40it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.83it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 37.51it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.09it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.20it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.43it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.62it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.16it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.68it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.00it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.53it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 40.87it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.20it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 40.25it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 44.77it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.71it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.36it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.35it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.29it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.48it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.85it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.17it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.11it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.94it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.00it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.35it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.76it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.99it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.71it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.41it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.27it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.14it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.92it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.23it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 60.44it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 58.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.34it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.09it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.34it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.66it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.18it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.77it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.94it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.37it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.57it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.02it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.12it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.29it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.77it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.88it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.98it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.83it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.98it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.31it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.70it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.99it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.62it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.78it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.39it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.75it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.84it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:07<00:00, 26.73it/s]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 31.40it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 33.91it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 34.54it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.36it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 33.48it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.12it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 35.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 30.36it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 31.53it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:06<00:00, 32.38it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.09it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 40.01it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.45it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 33.74it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.16it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 37.54it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.12it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 37.89it/s]\n"
     ]
    }
   ],
   "source": [
    "def run_FD_trial(n_calib,n_test,alpha,shift_locs,dimension,a=1,b=1,gamma=2,eps=0.0001):\n",
    "    x_train_final, y_train_final, x_calib, y_calib, x_test, y_test = generate_cqr_data(\n",
    "                                                                        2*n_calib,\n",
    "                                                                        n_test,\n",
    "                                                                        a,b)\n",
    "    rkhs_basis_points = np.linspace(0,5,dimension)\n",
    "    \n",
    "    z_calib = pairwise_kernels(\n",
    "                X=x_calib,\n",
    "                Y=rkhs_basis_points.reshape(len(rkhs_basis_points),1),\n",
    "                metric=\"rbf\",\n",
    "                gamma=gamma\n",
    "            )\n",
    "    z_calib = np.column_stack((z_calib,np.ones(len(x_calib))))\n",
    "    z_test = pairwise_kernels(\n",
    "                X=x_test,\n",
    "                Y=rkhs_basis_points.reshape(len(rkhs_basis_points),1),\n",
    "                metric=\"rbf\",\n",
    "                gamma=gamma\n",
    "            )\n",
    "    z_test = np.column_stack((z_test,np.ones(len(x_test))))\n",
    "\n",
    "    reg = LinearRegression().fit(x_train_final, y_train_final)\n",
    "    scores_calib = np.abs(reg.predict(x_calib) - y_calib)\n",
    "    scores_test = np.abs(reg.predict(x_test) - y_test)\n",
    "\n",
    "    _, adaptive_coverage, adaptive_thresholds = compute_shifted_coverage(\n",
    "        scores_test,\n",
    "        scores_calib,\n",
    "        x_calib,\n",
    "        x_test,\n",
    "        None,\n",
    "        kernel=None,\n",
    "        alpha=alpha,\n",
    "        radius=None,\n",
    "        gamma=None,\n",
    "        z_calib=z_calib,\n",
    "        z_test=z_test,\n",
    "        exact=True,\n",
    "        eps=eps\n",
    "    )\n",
    "    qr_coverage, qr_thresholds = compute_qr_coverages(None, None, scores_calib, \n",
    "                                        scores_test, alpha, None, None, None, z_calib,\n",
    "                                                      z_test, eps\n",
    "                                 )\n",
    "\n",
    "    q = np.quantile(scores_calib, [alpha * (1 + 1/len(scores_calib))])\n",
    "    conformal_thresholds = q\n",
    "    conformal_coverage = np.mean(scores_test <= conformal_thresholds+eps)\n",
    "    \n",
    "    results_df = pd.DataFrame({'Coverage' : [adaptive_coverage, qr_coverage, conformal_coverage],\n",
    "                             'type' : ['Robust','QR','Split'],'Shift Loc' : ['Marginal','Marginal','Marginal']})\n",
    "    for shift in shift_loc:\n",
    "        shift_adaptive_cov = compute_coverage_at_shift(x_test, scores_test, \n",
    "                                                       adaptive_thresholds, shift, gamma, eps)\n",
    "        shift_qr_cov = compute_coverage_at_shift(x_test, scores_test, qr_thresholds,\n",
    "                                                 shift, gamma, eps)\n",
    "        shift_split_cov = compute_coverage_at_shift(x_test, scores_test, conformal_thresholds,\n",
    "                                                    shift, gamma, eps)\n",
    "        \n",
    "        shift_df = pd.DataFrame({'Coverage' : [shift_adaptive_cov, shift_qr_cov, shift_split_cov],\n",
    "                             'type' : ['Robust','QR','Split'],'Shift Loc' : [shift,shift,shift]})\n",
    "        \n",
    "        results_df = pd.concat([results_df,shift_df])\n",
    "        \n",
    "    return results_df\n",
    "\n",
    "ntrials = 20\n",
    "alpha = 0.9\n",
    "n_calib = 200\n",
    "n_test = 200                                             \n",
    "#shift_loc = [0.5, 1.4, 2.5, 3.5, 4.5]\n",
    "#shift_loc = [3.5,4.5]\n",
    "shift_loc = []\n",
    "a=1\n",
    "b=1\n",
    "\n",
    "dimensions=[1,5,10,20,30,50]\n",
    "\n",
    "cqr_df = pd.DataFrame()\n",
    "for d in dimensions:\n",
    "    for i in range(ntrials):\n",
    "        try:\n",
    "            append_df = run_FD_trial(n_calib, n_test, alpha,\n",
    "                                                 shift_loc, d, a, b)\n",
    "            append_df['trial'] = i\n",
    "            append_df['Dimension'] = d\n",
    "            cqr_df = pd.concat([cqr_df, append_df])\n",
    "        except cvx.error.SolverError:\n",
    "            print(\"one solver error\")\n",
    "            continue\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAz8AAAJHCAYAAAC+U+hbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAylUlEQVR4nO3de4DWdZ33/9cMzIDIycOAB9TwfFjw1Kppodu9QIKoKeuSraQZamZ42NQUTMs8RBpprlui5iFoJUMRbxetXDssmikmpbZqiKYpA+IBlNPA/P7o1+xNoA4wF8PM5/H4Z+Y6v8fPXIPP6/u9vldVY2NjYwAAANq56tYeAAAAYEMQPwAAQBHEDwAAUATxAwAAFEH8AAAARejY2gMAAAAfbPny5fnTn/6UxYuXtPYoG61NNumc7bbbLjU1NWu8vKotH+r6jTfeycqVbXZ8AAAKU11dlc0223Sdbjt79ux07NgpXbv2SFVVVQtP1vY1NjZm4cK3smLF0uy4445rvE6b3vKzcmWj+AEAoAiLFy/J1lv3Ej7voaqqKt269cirr770ntfxnh8AAGgjhM/7+6D/PuIHAAAoQsV3e1u0aFFGjBiR7373u+nTp88qlz3zzDMZO3ZsFi1alA9/+MP56le/mo4d2/SeeAAAsEF02bRTOtW2/P87L13WkHffWdri97sxqGhpPPnkkxk7dmzmzJmzxsvPPffcfP3rX88+++yTCy+8MJMnT87xxx9fyZEAAKBd6FTbMcefN7HF73fSuE83K37+/Oc/57jjjk7fvn85uMDKlSvzzjvvZOjQIzJq1Off8zannz4qd9/9f9drxj//+ZV8//s3ZsyYi9fqdhXd7W3y5Mm5+OKL06tXr9Uue+WVV7JkyZLss88+SZJjjjkm06dPr+Q4AABAC9pyy7rcfvt/5Pbb/yMTJ07OhAm3ZOLE2/PCC7Mr+rivvvpqXn755bW+XUW3/Fx22WXveVl9fX3q6uqaTtfV1WXu3Llrdf9bbNF1nWcDAABa1uuvz0tjY7LpppvmlltuyvTp96VDhw454ICDcsYZZyZJli1bljFjzs+LL87Jttv2yZgxF6d79+45+uihuf76Cdlmm23y+OOP5cYbv5d///cJmTTpB7nvvmmprq7OnnvulS9/eWy+9a1x+fOfX8k3v3lFzj33gmbP12pvsFnTxwut7dErXn99kUNdAwDQZlRXV7WrF/Dnz5+XE04YkWXLluXNN9/MHnvsmW9846o8//xz+eUvf55bbpmYjh075oILzs1dd92Zgw/+WN54Y0H+6Z9GZJ999s13vvPt3HzzDTnrrC+t8f4bGhpy220359577091dYd885tXpr6+Puecc15uvPF7axU+SSse7a13796ZP39+0+l58+atcfc4AABg4/TX3d5++MM7c/jhQ9LQsDwf/vDf57HHfpNBgz6Rzp07p2PHjhk27Kj85jePJkm2336H7LPPvkmST3xiSGbOfPw9779jx47p12/vnHTSCbnppu9l+PDj1qsZWi1+tt1223Tq1CmPP/6XH/buu+/OgAEDWmscAABgHVVXV+eMM87KggULMnHi7Vm5cuUqlzc2NmbFihVJstrRnf96+i97gf1lr66Ghoamy8eN+1bOO++CNDYmZ511xvvG0gfOuc63XEejRo3K7373uyTJVVddlSuuuCKHH354Fi9enJEjR27ocQAAgBbQsWPHfPGLZ+XWW2/ObrvtngcemJ4lS5akoaEh9957T/bf/8NJkjlzXsj//M8fkiTTpk3N3//9AUmSnj17ZvbsPyZJfvnLh5Ikb7zxRkaMODY77bRLTjnl8znwwIPy/PPPpUOHDk0xtVYzrvdP2QwPPvhg0/cTJkxo+n733XfPnXfeuSFGAACAdmXpsoZMGvfpitzvuvrIRw7JXnv1y8yZj+eQQwbkpJP+JStWrMiBB34k//RPI1JfX58+fbbLzTdPyMsv/yk77bRzTjttbJJk1KjTcvXV43LTTTfkwAM/kiTZbLPNcvTRx+Skk/4lnTt3zlZbbZ2hQ4eloWF5Fi1amEsuGZtLLvl6s+eralzTkQfaCAc8AACgLVmfAx489dTT2WabHVp4ovbnz39+MXvttecaL2u19/wAAABsSOIHAAAogvgBAACKIH4AAIAiiB8AAKAIG+RQ1wAAQMvqtmlNOtbWtvj9NixbloXvLG/x+90YiB8AAGiDOtbW5vFxn2vx+93/vBsT8QMAAPC/Fi9enO997/rMmPGr1NbWpmvXrhk16rTsv//f52tfuziPP/6bdO/evem6PXr0yEUXfTUf+lDfVplX/AAAAGutsbEx5513TnbY4UOZNGlyOnasyf/8zx/ypS+dmUsvvSJJMmrUaTniiCObbjN+/DczYcJ3c9ll32iV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QBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARaho/EybNi1DhgzJwIEDM3HixNUunz17dk444YQceeSROfnkk/PWW29VchwAAKBgFYufuXPnZvz48Zk0aVKmTp2aO+64I88//3zT5Y2Njfn85z+fUaNG5Z577skee+yRG264oVLjAAAAhatY/MyYMSMHHXRQevbsmS5dumTw4MGZPn160+VPPfVUunTpkgEDBiRJTjvttHz605+u1DgAAEDhOlbqjuvr61NXV9d0ulevXpk1a1bT6Zdeeilbbrllzj///Dz99NPZddddc9FFF63VY2yxRdcWm5eWV1fXrbVHoIVYy/bDWrYf1rL9sJbth7Xc+FUsfhobG1c7r6qqqun7hoaGPProo/nBD36Qfv365dvf/nauvPLKXHnllc1+jNdfX5SVK1d/nDXxy7jhzZu3sCL3ay03PGvZfljL9sNath/Wsv1ozlpWV1d5Ab8VVWy3t969e2f+/PlNp+vr69OrV6+m03V1ddlhhx3Sr1+/JMkRRxyxypYhAACAllSx+Dn44IPz8MMPZ8GCBVm8eHEeeOCBpvf3JMm+++6bBQsW5A9/+EOS5MEHH8xee+1VqXEAAIDCVWy3t969e+fss8/OyJEjs3z58gwfPjz9+/fPqFGjMnr06PTr1y//9m//lrFjx2bx4sXZaqutMm7cuEqNAwAAFK5i8ZMkw4YNy7Bhw1Y5b8KECU3f77333rnzzjsrOQIAAECSCn/IKQAAwMZC/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQhGbHz6xZs/If//EfWbZsWZ544olKzgQAANDimhU/U6ZMyQUXXJAbb7wxCxcuzOmnn57JkydXejYAAIAW06z4uf3223PHHXeka9eu2WKLLTJlypTceuutlZ4NAACgxTQrfqqrq9O1a9em01tvvXU6dOhQsaEAAABaWrPip2fPnnnmmWdSVVWVJLnnnnvSo0ePig4GAADQkjo250oXXnhhzjzzzLz00kv56Ec/mk6dOuX666+v9GwAAAAtplnxs9NOO2Xq1KmZM2dOVqxYkb59+6ampqbSswEAALSYZsXPddddt8rpqqqqbLLJJtlll13ysY99rCKDAQAAtKRmxc+zzz6bJ554IoMHD06HDh3yk5/8JNtuu23+8z//M7NmzcoXvvCFSs8JAACwXpp1wIPXX389U6ZMydixY3PBBRfkxz/+caqqqjJx4sRMnz690jMCAACst2bFz5tvvpm6urqm05tttlnefPPN1NbWpmPHZm08AgAAaFXNKpftttsuV199dY477rgkyZ133pntt98+Tz75ZKqrm9VPAAAArapZ5XL55ZfnlVdeySc/+ckMHz48c+fOzde//vU89dRTOf/88ys9IwAAwHpr1pafzTffPN/61rdWO//4449v8YEAAAAqoVnx88QTT+SGG27Iu+++m8bGxqxcuTIvv/xyHnrooQqPBwAA0DKatdvb2LFjs++++2bRokUZNmxYunbtmkGDBlV6NgAAgBbTrC0/VVVVOeWUU/LGG29kxx13zJFHHplPfepTlZ4NAACgxTRry8+mm26aJNl+++3z3HPPpVOnTlmxYkVFBwMAAGhJzdry069fv5x11lk588wzc+qpp2bOnDnp0KFDpWcDAABoMc3a8nPeeeflxBNPTN++fXPhhRdm5cqVueqqqyo9GwAAQItp1paf4447LnfffXeS5LDDDsthhx1WwZEAAABaXrO2/HTu3DmvvfZapWcBAAComGZt+Vm8eHH+z//5P9lqq63SpUuXpvOnTZtWscEAAABaUrPiZ8yYMZWeAwAAoKKatdvbAQcckM6dO2f27NnZZ599UlNTkwMOOKDSswEAALSYZsXPlClTcsEFF+TGG2/MwoULc/rpp2fy5MmVng0AAKDFNCt+br/99txxxx3p2rVrtthii0yZMiW33nprpWcDAABoMc2Kn+rq6nTt2rXp9NZbb+1DTgEAgDalWfHTs2fPPPPMM6mqqkqS3HPPPenRo0dFBwMAAGhJzTra24UXXpgzzzwzL730Uj760Y+mU6dOuf766ys9GwAAQItpVvzsuOOOmTp1aubMmZMVK1akb9++qampqfRsAAAALaZZu70deuih+bd/+7d07tw5u+66q/ABAADanGbFzy233JJly5blU5/6VE4++eRMnz49DQ0NlZ4NAACgxTQrfnbcccd86UtfykMPPZSRI0fm5ptvzoABAyo9GwAAQItp1nt+kuT111/PPffck7vuuiuNjY35/Oc/X8m5AAAAWlSz4ue0007LzJkzM2jQoFx66aXZe++9Kz0XAABAi2pW/Hz84x/P1VdfnU033bTS8wAAAFREs+Ln2GOPzc0335xf/OIXaWhoyCGHHJLTTjstHTs2e685AACAVtWsAx6MHz8+jzzySD7zmc/kpJNOyhNPPJFx48ZVejYAAIAW06xNN7/4xS/y4x//uOnzfQ477LAceeSRufDCCys6HAAAQEtp1pafxsbGVT7YtLa21gedAgAAbUqz4mf33XfP5ZdfnpdeeikvvfRSLr/88uy6666Vng0AAKDFNCt+Lr744rz99tsZMWJEjjvuuLzxxhu56KKLKj0bAABAi3nf+Fm2bFnOP//8PPLII7nyyiszY8aM9O/fPx06dEjXrl031IwAAADr7X3j59prr82iRYuy7777Np136aWX5u233853vvOdig8HAADQUt43fh566KFcffXV2WKLLZrO6927d8aNG5ef/vSnFR8OAACgpbxv/NTU1KRz586rnd+1a9fU1tZWbCgAAICW9r7xU11dnUWLFq12/qJFi9LQ0FCxoQAAAFra+8bPEUcckbFjx+bdd99tOu/dd9/N2LFjM2jQoIoPBwAA0FLeN34+85nPpFu3bjnkkENy3HHHZfjw4TnkkEPSvXv3fOELX9hQMwIAAKy3ju93YXV1dS699NKceuqpefrpp1NdXZ1+/fqld+/eG2o+AACAFvG+8fNXffr0SZ8+fSo9CwAAQMW8725vAAAA7YX4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKEJF42fatGkZMmRIBg4cmIkTJ77n9R566KF8/OMfr+QoAABA4TpW6o7nzp2b8ePHZ8qUKamtrc2IESNy4IEHZuedd17levPnz883vvGNSo0BAACQpIJbfmbMmJGDDjooPXv2TJcuXTJ48OBMnz59teuNHTs2Z5xxRqXGAAAASFLBLT/19fWpq6trOt2rV6/MmjVrlevcdttt2XPPPbP33nuv02NssUXX9ZqRyqqr69baI9BCrGX7YS3bD2vZfljL9sNabvwqFj+NjY2rnVdVVdX0/bPPPpsHHnggt9xyS1577bV1eozXX1+UlStXf5w18cu44c2bt7Ai92stNzxr2X5Yy/bDWrYf1rL9aM5aVldXeQG/FVVst7fevXtn/vz5Tafr6+vTq1evptPTp0/PvHnzcuyxx+aUU05JfX19jj/++EqNAwAAFK5i8XPwwQfn4YcfzoIFC7J48eI88MADGTBgQNPlo0ePzv3335+pU6fmhhtuSK9evTJp0qRKjQMAABSuolt+zj777IwcOTJHH310jjjiiPTv3z+jRo3K7373u0o9LAAAwBpV7D0/STJs2LAMGzZslfMmTJiw2vX69OmTBx98sJKjAAAAhavoh5wCAABsLMQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAESoaP9OmTcuQIUMycODATJw4cbXLf/rTn+aoo47KkUcemdNPPz1vvfVWJccBAAAKVrH4mTt3bsaPH59JkyZl6tSpueOOO/L88883Xb5o0aJccsklueGGG3LPPfdkt912y3e+851KjQMAABSuYvEzY8aMHHTQQenZs2e6dOmSwYMHZ/r06U2XL1++PJdcckl69+6dJNltt93y6quvVmocAACgcB0rdcf19fWpq6trOt2rV6/MmjWr6fRmm22Wf/zHf0ySLFmyJDfccENOOOGEtXqMLbbo2jLDUhF1dd1aewRaiLVsP6xl+2Et2w9r2X5Yy41fxeKnsbFxtfOqqqpWO2/hwoU5/fTTs/vuu+eTn/zkWj3G668vysqVqz/Omvhl3PDmzVtYkfu1lhuetWw/rGX7YS3bD2vZfjRnLaurq7yA34oqtttb7969M3/+/KbT9fX16dWr1yrXqa+vz/HHH5/dd989l112WaVGAQAAqFz8HHzwwXn44YezYMGCLF68OA888EAGDBjQdPmKFSty2mmn5fDDD8+YMWPWuFUIAACgpVRst7fevXvn7LPPzsiRI7N8+fIMHz48/fv3z6hRozJ69Oi89tprefrpp7NixYrcf//9SZK/+7u/swUIAACoiIrFT5IMGzYsw4YNW+W8CRMmJEn69euXP/zhD5V8eAAAgCYV/ZBTAACAjYX4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAgVjZ9p06ZlyJAhGThwYCZOnLja5c8880yOPfbYDB48OGPGjElDQ0MlxwEAAApWsfiZO3duxo8fn0mTJmXq1Km544478vzzz69ynXPPPTcXXXRR7r///jQ2Nmby5MmVGgcAAChcx0rd8YwZM3LQQQelZ8+eSZLBgwdn+vTpOeOMM5Ikr7zySpYsWZJ99tknSXLMMcfk2muvzfHHH9/sx6iurlqrmbbcbNO1un5Lqe2+Ras8bpJs2XXzVnvstV2ftWEtNyxr2bKsZcuyli3PWm5Y1rJlbexrWcn15oNVNTY2Nlbijr/3ve/l3Xffzdlnn50k+dGPfpRZs2bl0ksvTZI88cQTGTduXH74wx8mSV588cWccsopuf/++ysxDgAAULiK7fa2pqaqqqpq9uUAAAAtqWLx07t378yfP7/pdH19fXr16vWel8+bN2+VywEAAFpSxeLn4IMPzsMPP5wFCxZk8eLFeeCBBzJgwICmy7fddtt06tQpjz/+eJLk7rvvXuVyAACAllSx9/wkfznU9fe+970sX748w4cPz6hRozJq1KiMHj06/fr1yx/+8IeMHTs277zzTvbcc89cccUVqa2trdQ4AABAwSoaPwAAABuLin7IKQAAwMZC/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8bMQWLVqUI444Ii+//HJrj8J6GDlyZIYOHZqjjjoqRx11VJ588snWHom19LfPxRkzZmTYsGEZNGhQxo8f38rT0VzXXXddhg4dmqFDh2bcuHFJrGVbdc0112TIkCEZOnRovv/97yexlm3Vmv6NnDZtWoYMGZKBAwdm4sSJrT0i7UzH1h6ANXvyySczduzYzJkzp7VHYT00NjZm9uzZeeihh9Kxo6dbW/S3z8UlS5bkwgsvzO23356tt946p556an7+85/n0EMPbd1BeV8zZszIr371q9x1112pqqrK5z73udx777256qqrrGUb8+ijj+aRRx7JPffck4aGhgwZMiQf+chHPC/boDX9Gzl37tycffbZmTJlSmprazNixIgceOCB2XnnnVt5WtoLW342UpMnT87FF1+cXr16tfYorIfZs2enqqoqo0aNypFHHpkf/OAHrT0Sa+lvn4uzZs3KDjvskO222y4dO3bMsGHDMn369Faekg9SV1eXL3/5y6mtrU1NTU122mmnzJkzx1q2QQcccEBuu+22dOzYMa+//npWrFiRt99+21q2QWv6N3LGjBk56KCD0rNnz3Tp0iWDBw+2lrQoL0VvpC677LLWHoEW8Pbbb+cjH/lILrnkkixZsiQjR45M3759c8ghh7T2aDTT3z4X6+vrU1dX13S6V69emTt37oYei7W0yy67NH0/Z86c3HfffTnhhBOsZRtVU1OTa6+9NjfffHM+8YlPeF62UWv6N/Lwww9fbS1nzZrVilPS3tjyAxW07777Zty4cenSpUs233zzDB8+PD//+c9beyzWQ2Nj42rnVVVVtcIkrIvnnnsun/3sZ3P++edn++23X+1ya9l2jB49Og8//HBeffXVNe4ibi03fmv6N/Laa69d7XrWkpYkfqCCHnvssTz88MNNpxsbG733p43r3bt35s+f33S6vr7e7qltxOOPP54TTzwx//qv/5pPfvKT1rKN+uMf/5hnnnkmSbLJJptk0KBB+fWvf20t26A1/Ru57bbbWksqSvxABS1cuDDjxo3L0qVLs2jRotx1110ZOHBga4/Feth7773zwgsv5MUXX8yKFSty7733ZsCAAa09Fh/g1VdfzRe+8IVcddVVGTp0aBJr2Va9/PLLGTt2bJYtW5Zly5blZz/7WUaMGGEt26A1/Rv5zW9+Mw8//HAWLFiQxYsX54EHHrCWtCgvQUMF/cM//EOefPLJHH300Vm5cmWOP/747Lvvvq09FuuhU6dOufLKK/PFL34xS5cuzaGHHppPfOITrT0WH+Cmm27K0qVLc+WVVzadN2LECGvZBh166KFNf1c7dOiQQYMGZejQodl8882tZRuzpn8j999//5x99tkZOXJkli9fnuHDh6d///6tPSrtSFXjmnZgBwAAaGfs9gYAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFMGhrgHaiJdffjkDBw7MrrvumiRZuXJlampqMnLkyBx99NG55pprssMOO+Too49ulfla+/EB4IOIH4A2pHPnzpk6dWrT6VdeeSUnnnhiNtlkk5x55pmtOFla/fEB4IOIH4A2bNttt83o0aNz00035b/+67+yyy675OSTT06/fv1y4okn5qGHHsqiRYty7rnnZvr06Xn22WfTq1evfPe7302XLl3yxz/+MZdddlnefPPNrFixIieccEKGDx+eX//61xk/fny22267PPfcc1m2bFm+8pWv5KCDDspjjz2WK6+8MitXrkySnHrqqRk8eHC+/OUvNz3+Y489lnHjxmXx4sWpqanJWWedlQEDBmTKlCn5yU9+kurq6rz44oupqanJN77xjaatWQBQSd7zA9DG7b777nn22WdXOW/ZsmWpq6vLtGnT8qlPfSpjx47NmDFjct9992XRokX52c9+loaGhowePTr/+q//milTpuQHP/hBbr755vz2t79NksyaNSuf/exnc/fdd2f48OG57rrrkiTf+c53ctJJJ2XKlCm5/PLL88gjj6zy2G+88UZGjx6dMWPGZNq0afnGN76Rc889N3/605+SJL/5zW9y0UUX5d57781+++2Xm266qfL/kQAgtvwAtHlVVVXp3LnzaucPHjw4SbL99ttn1113Te/evZMkffr0yVtvvZU5c+bkpZdeyoUXXth0myVLluTpp5/OTjvtlG222SZ77LFHkmTPPffMXXfdlSQ5/PDD87WvfS0PPvhgDj744JxzzjmrPO6sWbOy/fbbZ++9906S7LLLLtlvv/3y6KOPpqqqKnvttVe22mqrpvv9yU9+0sL/RQBgzcQPQBv3u9/9bo27jdXU1Kzx+79asWJFunfvvsp7iObPn59u3brlt7/97SpBVVVVlcbGxiTJiBEj8g//8A/57//+7/zyl7/Mddddl3vuuafpun/dHe7/1djYmIaGhtTU1Lzn/QJApdntDaANe+GFF3L99dfns5/97Frftm/fvunUqVNT/Lz66qs54ogj8vvf//59bzdixIg888wzOeaYY3LppZfm7bffzltvvdV0+d57750XXnghs2bNSpI899xz+c1vfpMDDjhgrWcEgJZkyw9AG7JkyZIcddRRSZLq6up06tQp55xzTg477LBMnz59re6rtrY2119/fS677LLceOONaWhoyJlnnpn9998/v/71r9/zdl/60pdy+eWX59vf/naqq6tzxhlnpE+fPk2Xb7755rnmmmty6aWXZsmSJamqqsoVV1yRvn375oknnli3HxwAWkBVo/0NAACAAtjtDQAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAi/H/7431Gj7KgSQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 842.4x595.44 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "#sns.set(rc={'figure.figsize':(11.7,8.27)})\n",
    "\n",
    "# def make_coverage_barplot(x,y,hue,**kwargs):\n",
    "#     fig = sns.barplot(x=x,y=y,hue=hue)\n",
    "#     fig.axhline(alpha,color='red')\n",
    "    \n",
    "# fig = sns.FacetGrid(cqr_df, col=\"Dimension\",height=4) \n",
    "# fig.map(make_coverage_barplot,\"Shift Loc\",\"Coverage\",\"type\")\n",
    "# #fig.add_legend()\n",
    "# plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "# plt.tight_layout()\n",
    "\n",
    "# print(np.mean(cqr_df['Coverage'][cqr_df['type'] == 'Robust']))\n",
    "# print(np.mean(cqr_df['Coverage'][cqr_df['type'] == 'QR']))\n",
    "\n",
    "fig = sns.barplot(cqr_df, x=\"Dimension\",y=\"Coverage\",hue=\"type\") \n",
    "\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "fig.axhline(alpha,color='red')\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/OneDimManyRBFsCoverage.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0dkw8wO0sYsuukhLlixRUFCQTjvtNE2ePFnvvPOOt8tCC7jd7hOO2Ww2L1SC5vrqq69000036b777lOfPn1OaGccO4ZZs2Zpx44d+vbbb0+6JJxxbN9O9vvw6aefPuF1jCNaE+EHaGN5eXnasWOHZ9/tdvPenw4qPDxcZWVlnv2SkhKWpXYA+fn5mjZtmn73u9/pt7/9LePYAf3rX/9SUVGRJKlLly4aPXq0PvjgA8axgznZ78OIiAjGEZYi/ABtrLy8XEuWLFFVVZUqKiq0efNmjRo1yttloQUuvPBC7dmzR19//bVqa2v12muvKSYmxttl4Sd8++23uuOOO7R06VKNHTtWEuPYEe3fv1+pqamqrq5WdXW13nrrLcXHxzOOHczJfh/+/ve/144dO3T48GFVVlZq27ZtjCNaFX9uBtrYr371K33yySeaMGGC6urqNGXKFF100UXeLgstYLfb9dhjj+muu+5SVVWVLrvsMl155ZXeLgs/YfXq1aqqqtJjjz3mORYfH884djCXXXaZ5/+jvr6+Gj16tMaOHavTTjuNcexATvb7cNiwYUpKSlJCQoJqamo0efJkDR061NulohOxuU+2aB0AAAAAOhmWvQEAAAAwAuEHAAAAgBEIPwAAAACMQPgBAAAAYATCDwAAAAAjcKtrAOiA9u/fr1GjRum8886TJNXV1cnf318JCQmaMGGCli1bprPPPlsTJkzwSn3evj4AACdD+AGADiowMFBZWVme/QMHDmjatGnq0qWLZs+e7cXK5PXrAwBwMoQfAOgkIiIiNGvWLK1evVpvv/22zj33XN18880aMmSIpk2bpu3bt6uiokLJycnKycnRl19+qbCwMD3//PMKCgrSv/71Lz3yyCP6/vvvVVtbqxtuuEGTJ0/WBx98oLS0NPXu3VtfffWVqqur9eCDD2rEiBHKy8vTY489prq6OknSLbfcotjYWN1///2e6+fl5WnJkiWqrKyUv7+/7r77bsXExCgjI0NvvPGGfHx89PXXX8vf31+PP/64ZzYLAIDWxnt+AKATGTRokL788st6x6qrq+VwOJSdna3rrrtOqampSklJ0euvv66Kigq99dZbcrlcmjVrln73u98pIyNDr7zyitasWaOPP/5YklRYWKibbrpJmZmZmjx5spYvXy5JeuaZZzR9+nRlZGRo8eLFev/99+td+8iRI5o1a5ZSUlKUnZ2txx9/XMnJydq3b58k6cMPP9S8efP02muvKSoqSqtXr7b+iwQAMBYzPwDQidhsNgUGBp5wPDY2VpLUp08fnXfeeQoPD5cknXXWWTp69Kj27t2rb775RnPnzvX0cTqd2rlzp8455xz16tVL559/viRp8ODB2rx5syTpqquu0oIFC/TXv/5VI0eO1D333FPvuoWFherTp48uvPBCSdK5556rqKgo/eMf/5DNZtMFF1ygM844w3PeN954o5W/IgAA/AfhBwA6kU8//fSky8b8/f1P+vG/1dbWqnv37vXeQ1RWVqZu3brp448/rheobDab3G63JCk+Pl6/+tWv9Pe//13vvfeeli9fri1btnhe++/lcP8/t9stl8slf3//Bs8LAIAVWPYGAJ3Enj179Nxzz+mmm25qdt9+/frJbrd7ws+3336rcePG6bPPPvvJfvHx8SoqKtLEiRO1cOFCHTt2TEePHvW0X3jhhdqzZ48KCwslSV999ZU+/PBDXXzxxc2uEQCAU8XMDwB0UE6nU+PHj5ck+fj4yG6365577tHll1+unJycZp0rICBAzz33nB555BGtWrVKLpdLs2fP1rBhw/TBBx802O/ee+/V4sWL9dRTT8nHx0d33nmnzjrrLE/7aaedpmXLlmnhwoVyOp2y2Wx69NFH1a9fP3300Uct+8QBAGghm5s1BgAAAAAMwLI3AAAAAEYg/AAAAAAwAuEHAAAAgBEIPwAAAACMQPgBAAAAYATCDwAAAAAjEH4AAAAAGOH/AfApSB1QqWKYAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 842.4x595.44 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "sns.set(rc={'figure.figsize':(11.7,8.27)})\n",
    "\n",
    "cqr_df['Coverage Gap'] = np.abs(cqr_df['Coverage'] - alpha)\n",
    "\n",
    "# def make__gap_barplot(x,y,hue,**kwargs):\n",
    "#     fig = sns.barplot(x=x,y=y,hue=hue)\n",
    "\n",
    "# fig = sns.FacetGrid(cqr_df, col=\"Dimension\",height=4) \n",
    "# fig.map(make__gap_barplot,\"Shift Loc\",\"Coverage Gap\",\"type\")\n",
    "# #fig.add_legend()\n",
    "# plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "# plt.tight_layout()\n",
    "\n",
    "\n",
    "fig = sns.barplot(cqr_df, x=\"Dimension\",y=\"Coverage Gap\",hue=\"type\") \n",
    "\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/OneDimManyRBFsGap.png')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### High Dimensional Experiment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_high_dim_data(n_train,n_calib,n_test,d):\n",
    "    n = n_train + n_calib + n_test\n",
    "    X = np.random.uniform(size = (n,d))\n",
    "    \n",
    "    betas = np.random.normal(0,1,2*d)\n",
    "    sds = 1+(X@betas[0:d] + 2*(X*X) @ betas[d:])/d\n",
    "    sds = np.maximum(sds,0.5)\n",
    "\n",
    "    y = np.random.normal(loc = 0, scale = sds, size = n)\n",
    "    \n",
    "    X = np.column_stack((X,np.ones(n)))\n",
    "    \n",
    "    x_train = X[0:n_train,:]\n",
    "    x_calib = X[n_train:(n_train + n_calib),:]\n",
    "    x_test = X[(n_train + n_calib):,:]\n",
    "    \n",
    "    y_train = y[0:n_train]\n",
    "    y_calib = y[n_train:(n_train + n_calib)]\n",
    "    y_test = y[(n_train + n_calib):]\n",
    "    \n",
    "    return x_train, y_train, x_calib, y_calib, x_test, y_test\n",
    "\n",
    "def run_HD_trial(n_calib,n_test,alpha,d,eps=0.0001):\n",
    "    x_train, y_train, x_calib, y_calib, x_test, y_test = generate_high_dim_data(n_calib,\n",
    "                                                                        n_calib,\n",
    "                                                                        n_test,d)\n",
    "\n",
    "    reg = LinearRegression().fit(x_train, y_train)\n",
    "    scores_calib = np.abs(reg.predict(x_calib) - y_calib)\n",
    "    scores_test = np.abs(reg.predict(x_test) - y_test)\n",
    "\n",
    "    _, adaptive_coverage, adaptive_thresholds = compute_shifted_coverage(\n",
    "        scores_test,\n",
    "        scores_calib,\n",
    "        x_calib,\n",
    "        x_test,\n",
    "        None,\n",
    "        kernel=None,\n",
    "        alpha=alpha,\n",
    "        radius=None,\n",
    "        gamma=None,\n",
    "        z_calib=x_calib,\n",
    "        z_test=x_test,\n",
    "        exact=True,\n",
    "        eps=eps\n",
    "    )\n",
    "    qr_coverage, qr_thresholds = compute_qr_coverages(None, None, scores_calib, \n",
    "                                        scores_test, alpha, None, None, None, x_calib,\n",
    "                                                      x_test, eps\n",
    "                                 )\n",
    "\n",
    "    q = np.quantile(scores_calib, [alpha * (1 + 1/len(scores_calib))])\n",
    "    conformal_thresholds = q\n",
    "    conformal_coverage = np.mean(scores_test <= conformal_thresholds+eps)\n",
    "    \n",
    "    results_df = pd.DataFrame({'Coverage' : [adaptive_coverage, qr_coverage, conformal_coverage],\n",
    "                             'type' : ['Robust','QR','Split']})\n",
    "        \n",
    "    return results_df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 65.71it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.33it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.57it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.01it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 63.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 69.34it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 76.68it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 80.36it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 81.91it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 77.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 73.52it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 69.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 58.81it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.02it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 60.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.02it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.96it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.35it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.65it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.88it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.88it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 67.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 63.17it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.98it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.40it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 53.81it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.53it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.78it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 65.86it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 69.98it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 75.24it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 75.71it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 75.28it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 77.83it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 75.84it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 74.68it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 69.77it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 66.64it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.40it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.45it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.70it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.73it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.94it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.21it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.83it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 62.93it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 68.78it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 67.06it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 73.20it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 74.75it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 73.04it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:02<00:00, 71.65it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.48it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 52.02it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 34.84it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 34.14it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.42it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.83it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.27it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 64.97it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 65.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.74it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 61.44it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 60.60it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.30it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.68it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.26it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 56.93it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 59.38it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 60.04it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 48.21it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.34it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.58it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.96it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.92it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.90it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.62it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 54.23it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.82it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.34it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 55.95it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 57.19it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 51.72it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.13it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.08it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.23it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.47it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.97it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.81it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.38it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.21it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.87it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 40.34it/s]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.36it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.70it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.00it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 49.23it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:03<00:00, 50.16it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.03it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 45.49it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 41.84it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.45it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 40.39it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 43.67it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 47.86it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.81it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 46.49it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.14it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.45it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 39.48it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:05<00:00, 38.77it/s]\n",
      "100%|█████████████████████████████████████████| 200/200 [00:04<00:00, 42.51it/s]\n"
     ]
    }
   ],
   "source": [
    "ntrials = 20\n",
    "alpha = 0.9\n",
    "n_calib = 200\n",
    "n_test = 200                                             \n",
    "\n",
    "dimensions=[1,5,10,20,30,50]\n",
    "\n",
    "high_dim_df = pd.DataFrame()\n",
    "for d in dimensions:\n",
    "    for i in range(ntrials):\n",
    "        try:\n",
    "            append_df = run_HD_trial(n_calib, n_test, alpha, d)\n",
    "            append_df['trial'] = i\n",
    "            append_df['Dimension'] = d\n",
    "            high_dim_df = pd.concat([high_dim_df, append_df])\n",
    "        except cvx.error.SolverError:\n",
    "            print(\"one solver error\")\n",
    "            continue"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAz8AAAJHCAYAAAC+U+hbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAzXUlEQVR4nO3de4DVdZ3/8dcMDIMIiumAeQ3z7qKJrZq26PZbIEXUlAwtSTPykqFWagl2My+xGWmuW97SClovoUi/Fq1c21q0UkzKy6ohmqVc1AR0Bhjm/P5om/0RqAPM4TDzeTz+OZzL95z3+JEZnvP9nu+pq1QqlQAAAHRz9bUeAAAAYEMQPwAAQBHEDwAAUATxAwAAFEH8AAAARehZ6wEAAIA3t2LFivzhD39Ic3NLrUfZaG2ySe9sv/32aWhoWOP9dV35VNcvv/xq2tq67PgAABSmvr4uW2yx6TptO3fu3PTs2Zi+fTdPXV1dJ0/W9VUqlSxZ8kpWrlyWnXbaaY2P6dJ7ftraKuIHAIAiNDe35K1vHSB8XkddXV369ds8zz//7Os+xnt+AACgixA+b+zN/vuIHwAAoAhd+rA3AAAoVZ9NG9PYq/P/Ob9seWtee3VZpz/vxkD8AABAF9TYq2dOOG9Kpz/v1Ekf7FD8/OlPf8pxxx2dQYP+cnKBtra2vPrqqxk58oiMG3f6625zxhnjcscd/3e9ZvzTn/6Yb3/7ukyY8Pm12k78AAAA62SrrZry3e/+W/v1hQsX5v3vPyr/9E8j2qOoGp5//vk899xza72d9/wAAACd4sUXF6ZSSTbddNPceOP1GTPm2Hzwg8fliiu+lpUrVyZJli9fngkTzs+HPvSBnH/+p7J48eIkydFHj8yf/vSnJMmDDz6Q008flySZOvV7+dCHPpCxY4/PZZd9OUnyta9NyuOPP5p//udL12o+8QMAAKyTRYsW5sQTx+QDHzgmI0a8J9/85tX5yle+mqeeejI///nPcuONU3LTTVPz3HN/yO2335Ykefnll/L+94/J9753c7bbbvvccMM1r/v8ra2t+c53bsiNN34vN944JXV19VmwYEE++cnzsvvue+bccz+7VvOKHwAAYJ389bC373//thx22OFpbV2Rd77z7/PAA7/O8OHvTe/evdOzZ8+MGnVUfv3rXyVJdthhx7zjHfsmSd773sMze/aDr/v8PXv2zODB++Tkk0/M9dd/K6NHH5cBAwas87ziBwAAWC/19fU588yz89JLL2XKlO+mra1tlfsrlUr7YW89e6562oG/Xv/LZ/RUkvxlj89fTZr0tZx33mdTqSRnn33mG8bSm865zlsCAAD8j549e+YTnzg7N910Q3bbbffcfffMtLS0pLW1NT/84Z3Zb793JknmzXs6//3fjydJZsyYnr//+/2TJP3798/cub9Pkvz85/cmSV5++eWMGXNs3v72XfKxj52eAw44ME899WR69OjRHlNrNeN6f5UAAMAGt2x5a6ZO+mBVnnddvetdB2evvQZn9uwHc/DBQ3PyyR/KypUrc8AB78r73z8mCxYs+J/3+Vyb5577Q97+9p1z2mkTkyTjxp2Wyy+flOuvvyYHHPCuJMkWW2yRo48+Jief/KH07t07W2/91owcOSqtrSuydOmSfOELE/OFL3y5w/PVVSqVyjp/dTX24otL09bWZccHAKAw9fV12XLLvuu07SOPPJptttmxkyfqfv70p2ey1157rvE+h70BAABFED8AAEARxA8AAFCEqsfP0qVLc8QRR+S5555b7b7HHnssxx57bEaMGJEJEyascko7AACAzlTV+Hn44Ydz/PHHZ968eWu8/9xzz82FF16Yu+66K5VKJbfccks1xwEAAApW1VNd33LLLfn85z+f8847b7X7/vjHP6alpSXveMc7kiTHHHNMrrzyypxwwgnVHAkAALqFfps2pGevXp3+vK3Ll2fJqys6/Xk3BlWNn4svvvh171uwYEGamprarzc1NWX+/Plr9fzreppAAADo6nr26pUHJ3200593v/OuS8RP51rTxwvV1dWt1XP4nB8AALqS9fmcn41Rc3NzvvWtqzNr1i/Sq1ev9O3bN+PGnZb99vv7fOlLn8+DD/46m222WftjN99881x44RfztrcNqsm8NYufgQMHZtGiRe3XFy5cmAEDBtRqHAAAYC1UKpWcd94ns+OOb8vUqbekZ8+G/Pd/P55Pf/qsXHTRpUmSceNOyxFHHNm+zeTJ/5xrr/1mLr74KzWZuWanut52223T2NiYBx98MElyxx13ZOjQobUaBwAAWAsPP/ybPPvsMzn77E+mZ8+GJMluu+2eD3/4lFx//bWrPX7FihVZtGhRNtts8w09arsNHj/jxo3Lb3/72yTJV7/61Vx66aU57LDD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YEGamprarw8YMCBz5sxpv/7ss89mq622yvnnn59HH300u+66ay688MK1eo0tt+zbafPS+Zqa+tV6BDqJtew+rGX3YS27D2vZfVjLjV/V4qdSqax2W11dXfufW1tb86tf/Srf+973Mnjw4Hz961/PZZddlssuu6zDr/Hii0vT1rb666yJ/xk3vIULl1Tlea3lhmctuw9r2X1Yy+7DWnYfHVnL+vo6v8Cvoaod9jZw4MAsWrSo/fqCBQsyYMCA9utNTU3ZcccdM3jw4CTJEUccscqeIQAAgM5Utfg56KCDct999+Wll15Kc3Nz7r777vb39yTJvvvum5deeimPP/54kuSee+7JXnvtVa1xAACAwlXtsLeBAwfmnHPOydixY7NixYqMHj06e++9d8aNG5fx48dn8ODB+Zd/+ZdMnDgxzc3N2XrrrTNp0qRqjQMAABSuavGTJKNGjcqoUaNWue3aa69t//M+++yT2267rZojAAAAJKnyh5wCAABsLMQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARehw/MyZMyf/9m//luXLl+ehhx6q5kwAAACdrkPxM23atHz2s5/NddddlyVLluSMM87ILbfcUu3ZAAAAOk2H4ue73/1ubr755vTt2zdbbrllpk2blptuuqnaswEAAHSaDsVPfX19+vbt2379rW99a3r06FG1oQAAADpbh+Knf//+eeyxx1JXV5ckufPOO7P55ptXdTAAAIDO1LMjD7rgggty1lln5dlnn8273/3uNDY25uqrr672bAAAAJ2mQ/Hz9re/PdOnT8+8efOycuXKDBo0KA0NDdWeDQAAoNN0KH6uuuqqVa7X1dVlk002yS677JJ/+Id/qMpgAAAAnalD8fPEE0/koYceyogRI9KjR4/8+Mc/zrbbbpt///d/z5w5c/Lxj3+82nMCAACslw6d8ODFF1/MtGnTMnHixHz2s5/ND37wg9TV1WXKlCmZOXNmtWcEAABYbx2Knz//+c9pampqv77FFlvkz3/+c3r16pWePTu08wgAAKCmOlQu22+/fS6//PIcd9xxSZLbbrstO+ywQx5++OHU13eonwAAAGqqQ+VyySWX5I9//GPe9773ZfTo0Zk/f36+/OUv55FHHsn5559f7RkBAADWW4f2/LzlLW/J1772tdVuP+GEEzp9IAAAgGroUPw89NBDueaaa/Laa6+lUqmkra0tzz33XO69994qjwcAANA5OnTY28SJE7Pvvvtm6dKlGTVqVPr27Zvhw4dXezYAAIBO06E9P3V1dfnYxz6Wl19+OTvttFOOPPLIHH/88dWeDQAAoNN0aM/PpptumiTZYYcd8uSTT6axsTErV66s6mAAAACdqUN7fgYPHpyzzz47Z511Vk499dTMmzcvPXr0qPZsAAAAnaZDe37OO++8nHTSSRk0aFAuuOCCtLW15atf/Wq1ZwMAAOg0Hdrzc9xxx+WOO+5Ikhx66KE59NBDqzgSAABA5+vQnp/evXvnhRdeqPYsAAAAVdOhPT/Nzc35P//n/2TrrbdOnz592m+fMWNG1QYDAADoTB2KnwkTJlR7DgAAgKrq0GFv+++/f3r37p25c+fmHe94RxoaGrL//vtXezYAAIBO06H4mTZtWj772c/muuuuy5IlS3LGGWfklltuqfZsAAAAnaZD8fPd7343N998c/r27Zstt9wy06ZNy0033VTt2QAAADpNh+Knvr4+ffv2bb/+1re+1YecAgAAXUqH4qd///557LHHUldXlyS58847s/nmm1d1MAAAgM7UobO9XXDBBTnrrLPy7LPP5t3vfncaGxtz9dVXV3s2AACATtOh+Nlpp50yffr0zJs3LytXrsygQYPS0NBQ7dkAAAA6TYcOezvkkEPyL//yL+ndu3d23XVX4QMAAHQ5HYqfG2+8McuXL8/xxx+fU045JTNnzkxra2u1ZwMAAOg0HYqfnXbaKZ/+9Kdz7733ZuzYsbnhhhsydOjQas8GAADQaTr0np8kefHFF3PnnXfm9ttvT6VSyemnn17NuQAAADpVh+LntNNOy+zZszN8+PBcdNFF2Weffao9FwAAQKfqUPy85z3vyeWXX55NN9202vMAAABURYfi59hjj80NN9yQ//zP/0xra2sOPvjgnHbaaenZs8NHzQEAANRUh054MHny5Nx///358Ic/nJNPPjkPPfRQJk2aVO3ZAAAAOk2Hdt3853/+Z37wgx+0f77PoYcemiOPPDIXXHBBVYcDAADoLB3a81OpVFb5YNNevXr5oFMAAKBL6VD87L777rnkkkvy7LPP5tlnn80ll1ySXXfdtdqzAQAAdJoOxc/nP//5LF68OGPGjMlxxx2Xl19+ORdeeGG1ZwMAAOg0bxg/y5cvz/nnn5/7778/l112WWbNmpW99947PXr0SN++fTfUjAAAAOvtDePnyiuvzNKlS7Pvvvu233bRRRdl8eLF+cY3vlH14QAAADrLG8bPvffem8svvzxbbrll+20DBw7MpEmT8pOf/KTqwwEAAHSWN4yfhoaG9O7de7Xb+/btm169elVtKAAAgM72hvFTX1+fpUuXrnb70qVL09raWrWhAAAAOtsbxs8RRxyRiRMn5rXXXmu/7bXXXsvEiRMzfPjwqg8HAADQWd4wfj784Q+nX79+Ofjgg3Pcccdl9OjROfjgg7PZZpvl4x//+IaaEQAAYL31fKM76+vrc9FFF+XUU0/No48+mvr6+gwePDgDBw7cUPMBAAB0ijeMn7/abrvtst1221V7FgAAgKp5w8PeAAAAugvxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUoarxM2PGjBx++OEZNmxYpkyZ8rqPu/fee/Oe97ynmqMAAACF61mtJ54/f34mT56cadOmpVevXhkzZkwOOOCA7Lzzzqs8btGiRfnKV75SrTEAAACSVHHPz6xZs3LggQemf//+6dOnT0aMGJGZM2eu9riJEyfmzDPPrNYYAAAASaq452fBggVpampqvz5gwIDMmTNnlcd85zvfyZ577pl99tlnnV5jyy37rteMVFdTU79aj0AnsZbdh7XsPqxl92Etuw9rufGrWvxUKpXVbqurq2v/8xNPPJG77747N954Y1544YV1eo0XX1yatrbVX2dN/M+44S1cuKQqz2stNzxr2X1Yy+7DWnYf1rL76Mha1tfX+QV+DVXtsLeBAwdm0aJF7dcXLFiQAQMGtF+fOXNmFi5cmGOPPTYf+9jHsmDBgpxwwgnVGgcAAChc1eLnoIMOyn333ZeXXnopzc3NufvuuzN06ND2+8ePH5+77ror06dPzzXXXJMBAwZk6tSp1RoHAAAoXFX3/JxzzjkZO3Zsjj766BxxxBHZe++9M27cuPz2t7+t1ssCAACsUdXe85Mko0aNyqhRo1a57dprr13tcdttt13uueeeao4CAAAUrqofcgoAALCxED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEcQPAABQBPEDAAAUQfwAAABFED8AAEARxA8AAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUATxAwAAFEH8AAAARRA/AABAEaoaPzNmzMjhhx+eYcOGZcqUKavd/5Of/CRHHXVUjjzyyJxxxhl55ZVXqjkOAABQsKrFz/z58zN58uRMnTo106dPz80335ynnnqq/f6lS5fmC1/4Qq655prceeed2W233fKNb3yjWuMAAACFq1r8zJo1KwceeGD69++fPn36ZMSIEZk5c2b7/StWrMgXvvCFDBw4MEmy22675fnnn6/WOAAAQOF6VuuJFyxYkKampvbrAwYMyJw5c9qvb7HFFvmnf/qnJElLS0uuueaanHjiiWv1Gltu2bdzhqUqmpr61XoEOom17D6sZfdhLbsPa9l9WMuNX9Xip1KprHZbXV3darctWbIkZ5xxRnbfffe8733vW6vXePHFpWlrW/111sT/jBvewoVLqvK81nLDs5bdh7XsPqxl92Etu4+OrGV9fZ1f4NdQ1Q57GzhwYBYtWtR+fcGCBRkwYMAqj1mwYEFOOOGE7L777rn44ourNQoAAED14ueggw7Kfffdl5deeinNzc25++67M3To0Pb7V65cmdNOOy2HHXZYJkyYsMa9QgAAAJ2laoe9DRw4MOecc07Gjh2bFStWZPTo0dl7770zbty4jB8/Pi+88EIeffTRrFy5MnfddVeS5O/+7u/sAQIAAKqiavGTJKNGjcqoUaNWue3aa69NkgwePDiPP/54NV8eAACgXVU/5BQAAGBjIX4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIogfAACgCOIHAAAogvgBAACKIH4AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKIL4AQAAiiB+AACAIlQ1fmbMmJHDDz88w4YNy5QpU1a7/7HHHsuxxx6bESNGZMKECWltba3mOAAAQMGqFj/z58/P5MmTM3Xq1EyfPj0333xznnrqqVUec+655+bCCy/MXXfdlUqlkltuuaVa4wAAAIXrWa0nnjVrVg488MD0798/STJixIjMnDkzZ555ZpLkj3/8Y1paWvKOd7wjSXLMMcfkyiuvzAknnNDh16ivr1urmbbaYtO1enxn6bXZljV53STZqu9bavbaa7s+a8NabljWsnNZy85lLTuftdywrGXn2tjXsprrzZurq1QqlWo88be+9a289tprOeecc5Ikt956a+bMmZOLLrooSfLQQw9l0qRJ+f73v58keeaZZ/Kxj30sd911VzXGAQAACle1w97W1FR1dXUdvh8AAKAzVS1+Bg4cmEWLFrVfX7BgQQYMGPC69y9cuHCV+wEAADpT1eLnoIMOyn333ZeXXnopzc3NufvuuzN06ND2+7fddts0NjbmwQcfTJLccccdq9wPAADQmar2np/kL6e6/ta3vpUVK1Zk9OjRGTduXMaNG5fx48dn8ODBefzxxzNx4sS8+uqr2XPPPXPppZemV69e1RoHAAAoWFXjBwAAYGNR1Q85BQAA2FiIHwAAoAjiBwAAKIL4AQAAiiB+AACAIoifjdjSpUtzxBFH5Lnnnqv1KKyHsWPHZuTIkTnqqKNy1FFH5eGHH671SKylv/27OGvWrIwaNSrDhw/P5MmTazwdHXXVVVdl5MiRGTlyZCZNmpTEWnZVV1xxRQ4//PCMHDky3/72t5NYy65qTT8jZ8yYkcMPPzzDhg3LlClTaj0i3UzPWg/Amj388MOZOHFi5s2bV+tRWA+VSiVz587Nvffem549/XXriv7272JLS0suuOCCfPe7381b3/rWnHrqqfnZz36WQw45pLaD8oZmzZqVX/ziF7n99ttTV1eXj370o/nhD3+Yr371q9ayi/nVr36V+++/P3feeWdaW1tz+OGH513vepe/l13Qmn5Gzp8/P+ecc06mTZuWXr16ZcyYMTnggAOy884713haugt7fjZSt9xySz7/+c9nwIABtR6F9TB37tzU1dVl3LhxOfLII/O9732v1iOxlv727+KcOXOy4447Zvvtt0/Pnj0zatSozJw5s8ZT8maamprymc98Jr169UpDQ0Pe/va3Z968edayC9p///3zne98Jz179syLL76YlStXZvHixdayC1rTz8hZs2blwAMPTP/+/dOnT5+MGDHCWtKp/Cp6I3XxxRfXegQ6weLFi/Oud70rX/jCF9LS0pKxY8dm0KBBOfjgg2s9Gh30t38XFyxYkKampvbrAwYMyPz58zf0WKylXXbZpf3P8+bNy49+9KOceOKJ1rKLamhoyJVXXpkbbrgh733ve/297KLW9DPysMMOW20t58yZU8Mp6W7s+YEq2nfffTNp0qT06dMnb3nLWzJ69Oj87Gc/q/VYrIdKpbLabXV1dTWYhHXx5JNP5iMf+UjOP//87LDDDqvdby27jvHjx+e+++7L888/v8ZDxK3lxm9NPyOvvPLK1R5nLelM4geq6IEHHsh9993Xfr1SqXjvTxc3cODALFq0qP36ggULHJ7aRTz44IM56aST8qlPfSrve9/7rGUX9fvf/z6PPfZYkmSTTTbJ8OHD88tf/tJadkFr+hm57bbbWkuqSvxAFS1ZsiSTJk3KsmXLsnTp0tx+++0ZNmxYrcdiPeyzzz55+umn88wzz2TlypX54Q9/mKFDh9Z6LN7E888/n49//OP56le/mpEjRyaxll3Vc889l4kTJ2b58uVZvnx5fvrTn2bMmDHWsgta08/If/7nf859992Xl156Kc3Nzbn77rutJZ3Kr6Chiv7xH/8xDz/8cI4++ui0tbXlhBNOyL777lvrsVgPjY2Nueyyy/KJT3wiy5YtyyGHHJL3vve9tR6LN3H99ddn2bJlueyyy9pvGzNmjLXsgg455JD276s9evTI8OHDM3LkyLzlLW+xll3Mmn5G7rfffjnnnHMyduzYrFixIqNHj87ee+9d61HpRuoqazqAHQAAoJtx2BsAAFAE8QMAABRB/AAAAEUQPwAAQBHEDwAAUASnugboIp577rkMGzYsu+66a5Kkra0tDQ0NGTt2bI4++uhcccUV2XHHHXP00UfXZL5avz4AvBnxA9CF9O7dO9OnT2+//sc//jEnnXRSNtlkk5x11lk1nCw1f30AeDPiB6AL23bbbTN+/Phcf/31+Y//+I/ssssuOeWUUzJ48OCcdNJJuffee7N06dKce+65mTlzZp544okMGDAg3/zmN9OnT5/8/ve/z8UXX5w///nPWblyZU488cSMHj06v/zlLzN58uRsv/32efLJJ7N8+fJ87nOfy4EHHpgHHnggl112Wdra2pIkp556akaMGJHPfOYz7a//wAMPZNKkSWlubk5DQ0POPvvsDB06NNOmTcuPf/zj1NfX55lnnklDQ0O+8pWvtO/NAoBq8p4fgC5u9913zxNPPLHKbcuXL09TU1NmzJiR448/PhMnTsyECRPyox/9KEuXLs1Pf/rTtLa2Zvz48fnUpz6VadOm5Xvf+15uuOGG/OY3v0mSzJkzJx/5yEdyxx13ZPTo0bnqqquSJN/4xjdy8sknZ9q0abnkkkty//33r/LaL7/8csaPH58JEyZkxowZ+cpXvpJzzz03f/jDH5Ikv/71r3PhhRfmhz/8YYYMGZLrr7+++v+RACD2/AB0eXV1dendu/dqt48YMSJJssMOO2TXXXfNwIEDkyTbbbddXnnllcybNy/PPvtsLrjggvZtWlpa8uijj+btb397ttlmm+yxxx5Jkj333DO33357kuSwww7Ll770pdxzzz056KCD8slPfnKV150zZ0522GGH7LPPPkmSXXbZJUOGDMmvfvWr1NXVZa+99srWW2/d/rw//vGPO/m/CACsmfgB6OJ++9vfrvGwsYaGhjX++a9WrlyZzTbbbJX3EC1atCj9+vXLb37zm1WCqq6uLpVKJUkyZsyY/OM//mP+67/+Kz//+c9z1VVX5c4772x/7F8Ph/v/VSqVtLa2pqGh4XWfFwCqzWFvAF3Y008/nauvvjof+chH1nrbQYMGpbGxsT1+nn/++RxxxBH53e9+94bbjRkzJo899liOOeaYXHTRRVm8eHFeeeWV9vv32WefPP3005kzZ06S5Mknn8yvf/3r7L///ms9IwB0Jnt+ALqQlpaWHHXUUUmS+vr6NDY25pOf/GQOPfTQzJw5c62eq1evXrn66qtz8cUX57rrrktra2vOOuus7LfffvnlL3/5utt9+tOfziWXXJKvf/3rqa+vz5lnnpntttuu/f63vOUtueKKK3LRRRelpaUldXV1ufTSSzNo0KA89NBD6/aFA0AnqKs43gAAACiAw94AAIAiiB8AAKAI4gcAACiC+AEAAIogfgAAgCKIHwAAoAjiBwAAKML/A0s6VfBgB09oAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 842.4x595.44 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "#sns.set(rc={'figure.figsize':(11.7,8.27)})\n",
    "    \n",
    "fig = sns.barplot(high_dim_df, x=\"Dimension\",y=\"Coverage\",hue=\"type\") \n",
    "\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "fig.axhline(alpha,color='red')\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/HighDimLQRCoverage.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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+2wuv/yL+f/+v3s32f/EE0/KHXd8L7feenMmTrygw2veVsIPAAB0QavWrC/b83gqKioybdqXc8MN12fMmNGprq5Or167ZO+9++UXv1iQ9es3D1Cf/vQF+fSnz86pp34we+21dxmqFn4AAIB26N59p3zmM5Pymc9Malm3cePGLFjwH3nnOwdttv9RRx2dn/3sF51Z4mZc8wMAAHSIysrKLQaf7YXwAwAAFILwAwAAFILwAwAAFILwAwAAFIK7vQEAQBfUo2d1aqtrOvy4a9evy2ury3ML7VITfgAAoAuqra7JGd86r8OPe9uZ1+a1tB5+fvzjH+Xb3741GzZsSHNzc04+eVg+/OGPbnX/c86ZkPHjP5EePXpk9uy7Mnny5zJnzvfTo8fOOfHEkzryLWyV8AMAALTJsmXLct11X8m3vz0zvXv3yWuvvZZzzhmfffbZL4MGvet12x522OGZPPlzSZIlS5akf/9jOqPkJMIPAADQRq+88nKamprS2NiY3r2THj165HOfuzw1NTUZNWpYBg16d37968VJksmTP59DDjm0pe2iRQtz883fyJlnjs9//MdPs2jRw3nTm96UgQOPL3ndwg8AANAmBx10cP7+79+dU055fw455JD07z8gQ4acnH799kmS7LLLLvnOd76Xn//8p7n88s9lxow7NjvGsccel3e+813p3/+YTgk+ibu9AQAA7XDRRZfm7rt/kFNOGZ2//OWFjB//0fzkJw8kSUaNOiVJ8vd//64sX74sL7/8UjlLbWHkBwAAaJP//M+f57XXXsvgwUMyfPjIDB8+MnPmzM68eXOTJN26/U/M2LhxYyoru5Wr1E0Y+QEAANqke/fuufHG6/P8888nSZqbm/P000/m4IMPSZL88If3JUkefPDH2W+//bPLLrts8TjdunXLhg0bOqfoGPkBAIAuae36dbntzGtLctzWHHPM3+XjHz8rn/3seWlqakqSHHfcO/Lxj5+V+fPvzZIlv868eXPSvftO+dznLt/qcY499rjceOP16dWrV/7hH97XYe9ha4QfAADogl5bvX6bnsdTKsOGjciwYSO2uO2Tn5yYPffcc5N1N954U8vXxxwzIEkyePCQDB48pHRF/h+mvQEAAIVg5AcAAOgwc+b8e7lL2CojPwAA0EU0NzeXu4TtWmvfH+EHAAC6gJ126p5Vq14RgLaiubk5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WhQAAOWzePHCTJ06OYsXLyx3KdChWh35GTBgQD7/+c9n7Nix6datW+bOnZv99tsvv/vd75Ikb33rW0teJAAAnefOO2fmqaeeTGNjQ/r3H1DucqDDtBp+fvjDHyZJfv7zn2+y/tOf/nQqKirywAMPlKYyAADKoqGhcZMl7ChaDT8//vGPO6MOAACAkmo1/KxcuTL33HNP1qxZk+bm5mzcuDF/+tOf8uUvf7kz6gMAAOgQrYaf888/P927d88TTzyR448/PgsWLMgxxxzTGbUBAAB0mFbv9vb888/nm9/8ZgYNGpQPf/jD+d73vpdnnnmmM2oDAADoMK2Gnze96U1Jkv322y9//OMf07dv3zQ1NZW8MAAAgI7U6rS33XffPTfffHOOPvrofPWrX03Pnj2zevXqzqgNAACgw7Q68nP55ZenpqYmAwYMyNve9rZcd911+exnP9sZtQEAAHSYbRr5GTduXJJk0qRJmTRpUsmLAgAA6GivO/Jz22235d///d+TJIMHD07//v3zd3/3d3nyySc7pTgAAICOstXwc9ttt+W+++7LIYcckiTp3r175s2bl09+8pP51re+1WkFAgAAdIStTnu766678t3vfjd9+vRJknTr1i177bVXxo4dmw984AOdVR8AAECHeN1pb38LPkly3HHHJUlqampSU1NT0qIAAAA62lbDz/r16zd5fckll7R8vWHDhtJVBAAAUAJbDT+HHHJIfvKTn2y2/qc//WkOOuigkhYFAADQ0bZ6zc+nPvWpnHnmmTnrrLNywgknpKKiIr/85S/zzW9+M9/+9rc7s0YAANqo1y7d0722ul1tu3WraFnW1fXqyLKgrLYafg455JDceuut+dd//dd87WtfS3Nzc/r3759vfOMb2W+//TqxRAAA2qp7bXVOv3BGu9quWLEqSfKXFavadYyZ08a267xQaq/7kNNDDz00X//61zurFgAAgJJ53bu9AQAA7CiEHwAAoBCEHwAAoBC2KfwsWbIk//Zv/5Z169blV7/6ValrAgAA6HCthp/Zs2fnkksuyc0335xVq1blk5/8ZO64447OqA0AAKDDtBp+br/99syaNSs9e/bM7rvvntmzZ3vODwAA0OW0Gn4qKyvTs2fPltdvfvOb061bt5IWBQAA0NFaDT99+vTJY489loqKvz7p95577knv3r1LXhgAAEBHet2HnCbJpZdemvPOOy/PPPNM3vnOd6a2tjY33HBDZ9QGAADQYVoNP295y1syd+7cPP3009mwYUP233//VFdXd0ZtAAAAHabV8HP99ddv8rqioiI77bRTDjrooPz93//967adN29ebrzxxqxfvz5nnHFGxo4du8n2xx57LFOmTMnq1aszYMCATJ06NVVVVXn22Wdz0UUXZfXq1dlll11y9dVXZ6+99mrH2wMAAPirVq/5+eMf/5hZs2bl5ZdfzqpVq/L9738/P/nJT3Ldddfla1/72lbbLV26NNOnT8/MmTMzd+7czJo1K0888cQm+0yaNCmXXXZZ7rvvvjQ3N7fcQvvaa6/NsGHDMnfu3Jx44omZPn36G3ybAABA0bUafl588cXMnj07U6ZMySWXXJLvf//7qaioyIwZMzJ//vyttluwYEEGDhyYPn36pEePHhkyZMgm+z/33HNpbGzM0UcfnSQ55ZRTWrZv3Lgxq1evTpI0NDSke/fub+Q9AgAAtD7t7eWXX05dXV3L61133TUvv/xyampqUlW19ebLli3bpF19fX2WLFmy1e11dXVZunRpkuS8887LmDFjcvvtt2f9+vWZNWtWm97U7rv3bH0nAAB2OHV1vcpdAtuxVsNPv3798uUvfzmnnXZakuSuu+7KPvvsk9/85jeprNz6wFFzc/Nm6/52u+zWtl900UW5/PLL8773vS/33Xdfzj333Nxzzz2btH89L764Ohs3bn58AICiKGoIWL58VblLeF2VlRU+qC+jVqe9XXnllXnuuefygQ98IKNHj87SpUvzhS98Ib/73e9y0UUXbbVd3759s2LFipbXy5YtS319/Va3L1++PPX19Vm5cmWefPLJvO9970uSDBkyJMuXL89LL73UrjcIAACQbMPIz2677ZavfOUrm60//fTTX7fd8ccfn69+9atZuXJldtppp9x///254oorWrbvtddeqa2tzaJFi3LMMcdkzpw5GTRoUHbdddfU1tZm4cKFGTBgQBYtWpSdd945u+22WzveHgAAwF+1Gn5+9atf5Zvf/GZee+21NDc3Z+PGjXn22Wfz4IMPvm67vn375oILLsi4ceOyfv36jB49OkceeWQmTJiQiRMn5ogjjsg111yTKVOmZM2aNTn88MMzbty4VFRU5Prrr88VV1yRxsbG7LzzzvnqV7/aUe8XAIBWVHSr3mQJO4qK5i1dfPO/DBs2LCNHjsx9992XMWPG5IEHHsg+++yTSy+9tLNqbDPX/AAARVdX1yunXzijXW3XvvLnrPnLI9l5jyNS27tfm9vPnDY2i6aNb9e534hjLrzZNT+8rlZHfioqKnLWWWflpZdeygEHHJD3v//9+dCHPtQZtQEAUAa1vfu1K/TA9q7VGx7svPPOSZJ99tknjz/+eGpra7Nhw4aSFwYAANCRWg0/RxxxRM4///wMHDgwt956a66++up069atM2oDANgmixcvzNSpk7N48cJylwJsx1qd9nbhhRfm0Ucfzf77759LL700CxYsyDXXXNMZtQEAbJM775yZp556Mo2NDenff0C5ywG2U62Gn9NOOy1z5sxJkrz73e/Ou9/97hKXBADQNg0NjZssAbak1Wlv3bt3z1/+8pfOqAUAAKBkWh35aWhoyHvf+97sscce6dGjR8v6efPmlbQwAACAjtRq+Jk8eXJn1AEAAFBSrU57O/bYY9O9e/c8+eSTOfroo1NdXZ1jjz22M2oDAADoMK2Gn9mzZ+eSSy7JzTffnFWrVuWTn/xk7rjjjs6oDQAAoMO0Gn5uv/32zJo1Kz179szuu++e2bNn59vf/nZn1AYAANBhWg0/lZWV6dmzZ8vrN7/5zR5yCgAAdDmthp8+ffrkscceS0VFRZLknnvuSe/evUteGAAAQEdq9W5vl156ac4777w888wzeec735na2trccMMNnVEbAABAh2k1/BxwwAGZO3dunn766WzYsCH7779/qqurO6M2AACADtPqtLd3vetd+drXvpbu3bvn4IMPFnwAAIAuqdXwc9ttt2XdunX50Ic+lI9//OOZP39+mpqaOqM2AACADtNq+DnggAPy2c9+Ng8++GDGjRuXW2+9NYMGDeqM2gAAADpMq9f8JMmLL76Ye+65J3fffXeam5tzzjnnlLouAACADtVq+Dn77LOzePHinHjiibniiity1FFHdUZdAAAAHarV8PMP//AP+fKXv5ydd965M+oBAAAoiVbDz6mnnppbb701P/vZz9LU1JQTTjghZ599dqqqtmnGHAAAwHah1RseTJ8+Pb/4xS/y0Y9+NGeeeWZ+9atfZdq0aZ1RGwAAQIdpdfjmZz/7Wb7//e+3PN/n3e9+d97//vfn0ksvLXlxAAAAHaXVkZ/m5uZNHmxaU1PjQacAAECX02r4OfTQQ3PllVfmmWeeyTPPPJOrrroqBx98cGfUBgAA0GFaDT+f//zn8+qrr2bMmDE57bTTsnLlylx22WWdURsAAECHafWan549e+bqq69Okqxduza1tbUlLwoAAKCjbXXkZ926dbnooovyox/9qGXdxIkTc8kll6SpqalTigMAAOgoWw0/1113XVavXp23v/3tLesuv/zyvPLKK/nqV7/aKcUBAAB0lK2GnwcffDBf/vKXs/vuu7es69u3b6ZNm7bJaBAAAEBXsNXwU11dne7du2+2vmfPnqmpqSlpUQAAAB1tq+GnsrIyq1ev3mz96tWrXfMDAAB0OVsNP8OHD8+UKVPy2muvtax77bXXMmXKlJx44omdUhwAAEBH2Wr4+ehHP5pevXrlhBNOyGmnnZbRo0fnhBNOyC677JJPfepTnVkjAADAG7bV5/xUVlbmiiuuyCc+8Yk8+uijqayszBFHHJG+fft2Zn0AAAAdotWHnO69997Ze++9O6MWAACAktnqtDcAAIAdifADAAAUgvADAAAUgvADAAAUgvADAAAUgvADAAAUgvADAAAUgvADAHSYxYsXZurUyVm8eGG5SwHYTKsPOQUA2FZ33jkzTz31ZBobG9K//4BylwOwCSM/AECHaWho3GQJsD0RfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEKoKncBAAB/s2vvmlTV1La5XbduFS3LurpebW7ftG5tXnplXZvbAV2L8AMAbDeqamqzaNr4Nrdb+9LSlmV72h9z4c1JhB/Y0ZV02tu8efMydOjQDB48ODNmzNhs+2OPPZZTTz01Q4YMyeTJk9PU1JQkWbZsWc4666yMGjUqY8aMybPPPlvKMgEAgAIoWfhZunRppk+fnpkzZ2bu3LmZNWtWnnjiiU32mTRpUi677LLcd999aW5uzh133JEkufDCC/Oe97wnc+bMyciRI3PNNdeUqkwAAKAgShZ+FixYkIEDB6ZPnz7p0aNHhgwZkvnz57dsf+6559LY2Jijjz46SXLKKadk/vz5WblyZX7/+99nzJgxSZJTTz01559/fqnKBAAACqJk1/wsW7YsdXV1La/r6+uzZMmSrW6vq6vL0qVL8+c//zl77rlnrrzyyvzyl7/Mnnvumcsuu6xN5959955v/A0AAG32Rm88UE5drV62TD/yekoWfpqbmzdbV1FR0er2pqamPProo/n0pz+dyZMn584778zFF1+c22+/fZvP/eKLq7Nx4+bHBwBKa8OG5pbl8uWr2ty+nH+4tqfe7VlRQ8D23o+VlRU+qC+jkk1769u3b1asWNHyetmyZamvr9/q9uXLl6e+vj51dXXZeeed8573vCdJMnz48E1GjAAAANqjZOHn+OOPz0MPPZSVK1emoaEh999/fwYNGtSyfa+99kptbW0WLVqUJJkzZ04GDRqUffbZJ3379s1Pf/rTJMlPfvKTvPWtby1VmQAAQEGUdOTnggsuyLhx4zJq1KgMHz48Rx55ZCZMmJBHHnkkSXLNNdfkqquuysknn5yGhoaMGzcuSXL99dfn5ptvzvDhw/Od73wnV155ZanKBAAACqKkDzkdMWJERowYscm6m266qeXrQw89NHfddddm7Q444IA2XeMDAADQmpI+5BQAAGB7IfwAAACFIPwAAACFIPwAAACFIPwAAACFIPwAAACFUNJbXQMAXVOvXbqne211m9t161bRsqyr69XRZQG8IcIPALCZ7rXVOf3CGW1ut2LFqiTJX1asalf7mdPGtrkNwLYy7Q0AACgE4QeA7cLixQszderkLF68sNylALCDMu0NgO3CnXfOzFNPPZnGxob07z+g3OUAsAMy8gPAdqGhoXGTJQB0NOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHAAAoBOEHgEJbvHhhpk6dnMWLF5a7FABKrKrcBQBAOd1558w89dSTaWxsSP/+A8pdDgAlZOQHgEJraGjcZAnAjkv4AQAACkH4AQAACkH4AQAACkH4AQAACkH4AQAACkH4AQAACkH4AQAACkH4AQA6TEW36k2WANuTqnIXAMCOpdcu3dO9tu1/+HbrVtGyrKvr1eb2jWvXZ9WrHlRabj337J81f3kkO+9xRLlLAdiM8ANAh+peW53TL5zR5nYrVqxKkvxlxap2tZ85bWxWRfgpt9re/VLbu1+5ywDYItPeAACAQhB+AACAQhB+AACAQhB+oAwWL16YqVMnZ/HiheUuBQCgMNzwAMrgzjtn5qmnnkxjY0P69x9Q7nIAAArByA+UQUND4yZLuiYjeADQtRj5AWgnI3iw/aitqtxkCbAl/ocAaCcjeLD9OPHAXXPArt1z4oG7lrsUYDtm5AcA6PIOq+uRw+p6lLsMYDtn5AcAACgE4QcAACgE4QcAACgE4QcAACgE4QcAACgE4QcAACgE4QcAACgE4QcAACgE4Qfo8hYvXpipUydn8eKF5S4FANiOVZW7AIA36s47Z+app55MY2ND+vcfUO5yAIDtVElHfubNm5ehQ4dm8ODBmTFjxmbbH3vssZx66qkZMmRIJk+enKampk22P/roo3nb295WyhKBHUBDQ+MmSwCALSlZ+Fm6dGmmT5+emTNnZu7cuZk1a1aeeOKJTfaZNGlSLrvsstx3331pbm7OHXfc0bKtoaEhl19+edavX1+qEgEAgAIpWfhZsGBBBg4cmD59+qRHjx4ZMmRI5s+f37L9ueeeS2NjY44++ugkySmnnLLJ9quvvjpnnHFGqcoDAAAKpmTX/Cxbtix1dXUtr+vr67NkyZKtbq+rq8vSpUuTJA888EAaGxtz0kkntevcu+/es51VQ+fo1q2iZVlX16vM1XR95fp+6sftT3v6QT/yN/p/x9CefvzFL36RO+64I6eddloGDhxYgqrYXpQs/DQ3N2+2rqKiotXty5cvz4033pjbbrut3ed+8cXV2bhx8+PD9mLDhuaW5fLlq8pcTddXru+nftyycv0BubFpfSqrqjv9vE3r1ualV9Z1+nlLrYhBYEf7OS5iHybt68ebb74lTz31ZF59dVXe8pa3lqCq/1FZWeGD+jIqWfjp27dvFi78n9vOLlu2LPX19ZtsX7FiRcvr5cuXp76+Pg8++GBefvnljB07tmXbyJEjM2PGjPTs6R8KAFtWWVWdRdPGt7nd2peWtizb0/6YC29OsuOFHygSN84pjpJd83P88cfnoYceysqVK9PQ0JD7778/gwYNatm+1157pba2NosWLUqSzJkzJ4MGDcoHP/jB/OhHP8rcuXMzd+7cJMncuXMFHwAA4A0pWfjp27dvLrjggowbNy6jRo3K8OHDc+SRR2bChAl55JFHkiTXXHNNrrrqqpx88slpaGjIuHHjSlUOAABQcCV9yOmIESMyYsSITdbddNNNLV8feuihueuuu173GH/4wx9KUhsAAFAsJX3IKQBsq4pu1ZssAaCjCT8AbBd67tk/1T33SM89+5e7FAB2UCWd9gYA26q2d7/U9u5X7jIA2IEZ+QEAAApB+AEAAApB+OliFi9emKlTJ2fx4oWt7wwAALRwzU8Xc+edM/PUU0+msbEh/fsPKHc5AADQZRj56WIaGho3WQIAANtG+AEAAApB+AEAAApB+KHQ3EACAKA43PCAQnMDCQCA4jDyQ6G5gQQAQHEIP+1kuhQAAHQtpr21k+lSAADQtRj5aSfTpQAAoGsx8gNsN3rt0j3da6vb3K5bt4qWZV1drza3b1y7Pqte9UEGAOzohB9gu9G9tjqnXzijze1WrFiVJPnLilXtaj9z2tisivADtN3ixQszb97dGTHiA6bBQxcg/AAAtJNrgKFrcc0PAEA7uQYYuhYjP/AG7Nq7JlU1tW1u90avUWlatzYvvbKuze0SUzS2ZGPT+nb1Qzn7EYDNrSvT/+dJsnbdurz6ytp2taXzCD/wBlTV1GbRtPFtbrf2paUty/a0P+bCm5O0749mUzQ2V1lV3eX6EYDN1VRV54xvndfmdktfXd6ybE/7JLntzGuTCD/bO9PeoGBM0QAAikr4YZstXrwwU6dOzuLFC8tdCgAAtJlpb2wz06UAAOjKjPywzUyXAgCgKxN+AACAQhB+ACi02qrKTZYA7Lj8Tw9AoZ144K45YNfuOfHAXctdCgAl5oYHABTaYXU9clhdj3KXAUAnMPIDAAAUgvADAAAUgvADAAAUgvADAAAUgvADAAAUgru9lcmuvWtSVVPb5nbdulW0LOvqerW5fdO6tXnplXVtbgcAAF2d8FMmVTW1WTRtfJvbrX1pacuyPe2PufDmJMIPwPZg8eKFmTfv7owY8YH07z+g3OUA7PAKH3567dI93Wur29zujY7AAMCdd87MU089mcbGBuEHoBMUPvx0r63O6RfOaHO7FStWJUn+smJVu9rPnDa2zW0A2LE0NDRusgSgtNzwAAAAKITCj/ywYzB9EQCA1gg/7BBMXwQAoDXCD3RB65rWt3uk6o2Odq1dty6vvrK2Xeem47hLGAC0nfADXVBNVXXO+NZ57Wq79NXlLcv2HOO2M69Nsn2Fn4pu1Zssi8BdwgCg7dzwAOjyeu7ZP9U990jPPfuXu5RO4y5hAB2norpykyU7LiM/QJdX27tfanv3K3cZAHRRvY/sm1WPrUivw95U7lIoMeEHAIBC22nvXtlpb3d9LQLhp2BcKA8AQFEJPwXjQnkAAIrKVV0AAEAhGPkBAAqvvdPC3+iU8MS0cOhMwg8AUHjtnRb+RqeEJ6aFQ2cy7Q0AACgE4QfKoLaqcpMlAACl5y8vKIMTD9w1B+zaPSceuGu5SwEAKAzX/EAZHFbXI4fV9Sh3GQAAhWLkBwAAKAThBwAAKISSTnubN29ebrzxxqxfvz5nnHFGxo4du8n2xx57LFOmTMnq1aszYMCATJ06NVVVVVm0aFGuvPLKNDU1pU+fPrnyyiuz1157lbJUAGiX9j4fJnnjz4jxfBiAtilZ+Fm6dGmmT5+e2bNnp6amJmPGjMlxxx2XAw88sGWfSZMm5Qtf+EKOPvroXHrppbnjjjty+umnZ9KkSbnhhhty6KGH5q677soXvvCF3HjjjaUqtV0qulVvsuws7hIGOw5/NO8Y2vt8mOSNPyPG82EA2qZk4WfBggUZOHBg+vTpkyQZMmRI5s+fn3PPPTdJ8txzz6WxsTFHH310kuSUU07Jddddl9GjR+e8887LoYcemiQ55JBD8t3vfrdUZbZbzz37Z81fHsnOexzRqec98cBd89OnXsm79u/dqecFNvdGP4zwRzMAdK6ShZ9ly5alrq6u5XV9fX2WLFmy1e11dXVZunRpampqMnLkyCTJxo0bc/311+d973tfm869++4932D1ravt3S+1vfuV/Dz/V1e/S1h7P+Vm+6If/6qrfxihH3cM+nHHoB93DPpx+1ey8NPc3LzZuoqKim3evm7dulx88cVpamrKJz7xiTad+8UXV2fjxs2PvyX+kXau5ctXleS4+nHbVVRXbrJsD/34V139wwj9uGPQjzuGUvSjPux829KPlZUVnfJBPVtWsgtH+vbtmxUrVrS8XrZsWerr67e6ffny5S3b16xZk/Hjx6epqSk33nhjqqs797oa2JH1PrJvavvunN5H9i13KQAAnapk4ef444/PQw89lJUrV6ahoSH3339/Bg0a1LJ9r732Sm1tbRYtWpQkmTNnTsv2SZMmZd999821116bmpqaUpUIhbTT3r1SP3j/7LS3TwQBgGIp2bS3vn375oILLsi4ceOyfv36jB49OkceeWQmTJiQiRMn5ogjjsg111yTKVOmZM2aNTn88MMzbty4PProo3nggQdy4IEHZtSoUUn+er3QTTfdVKpSAQCAAijpc35GjBiRESNGbLLuf4eYv93K+n87/PDD84c//KGUZQEAAAXkYTEAAEAhCD9ss464SxgAAJSLv2LZZjviXcIqulVvsgQAYMdV0mt+2LHstHevHe4OYT337J81f3kkO+9xRLlLAQCgxIQfCq22d7/U9u5X7jIAAOgEpr0BAACFIPwAAACFIPwAAACFIPwAdEFuPQ8Abee3JkAXtCPeeh66Ih9EQNfibm8AXdCOeOt56Ip6H9k3qx5bkV6HvancpQDbQPgBAGgnH0RA12KMFgDKxJQpgM7lf1sAKBPXbgF0LtPeAKBMTJkC6FxGfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIQfgAAgEIoafiZN29ehg4dmsGDB2fGjBmbbX/sscdy6qmnZsiQIZk8eXKampqSJM8//3zGjh2bk046Keecc07WrFlTyjIBAIACKFn4Wbp0aaZPn56ZM2dm7ty5mTVrVp544olN9pk0aVIuu+yy3HfffWlubs4dd9yRJJk6dWpOP/30zJ8/P29729tyww03lKpMAACgIKpKdeAFCxZk4MCB6dOnT5JkyJAhmT9/fs4999wkyXPPPZfGxsYcffTRSZJTTjkl1113XT74wQ/m4Ycfzte+9rWW9R/+8IczadKkbT53ZWVFm2p90647t2n/jlKzy+5lOe+beu5WlvMmbe+bttCPnUc/dhz92LH0Y8fSj52nVP1Yrj5M9OMb2YfSqWhubm4uxYG/8Y1v5LXXXssFF1yQJLnzzjuzZMmSXHHFFUmSX/3qV5k2bVq+973vJUn+9Kc/5ayzzsrtt9+e0aNH52c/+1mSpKmpKUcffXR++9vflqJMAACgIEo27W1LmaqioqLV7a21AwAAaI+ShZ++fftmxYoVLa+XLVuW+vr6rW5fvnx56uvrs9tuu2X16tXZsGHDJusBAADeiJKFn+OPPz4PPfRQVq5cmYaGhtx///0ZNGhQy/a99tortbW1WbRoUZJkzpw5GTRoUKqrqzNgwIDce++9m6wHAAB4I0p2zU/y11tdf+Mb38j69eszevToTJgwIRMmTMjEiRNzxBFH5Pe//32mTJmSNWvW5PDDD89VV12VmpqaPPfcc7n44ovz4osv5s1vfnO+8pWvpHfv3qUqEwAAKICShh8AAIDtRUkfcgoAALC9EH4AAIBCEH4AAIBCEH4AAIBCEH4AAIBCEH66mNWrV2f48OF59tlny10Kb8C4ceMybNiwjBw5MiNHjsxvfvObcpfENvq/P4MLFizIiBEjcuKJJ2b69Ollro5tcf3112fYsGEZNmxYpk2blkQ/dkXXXntthg4dmmHDhuVb3/pWEv3YFW3p9+G8efMydOjQDB48ODNmzCh3iexgqspdANvuN7/5TaZMmZKnn3663KXwBjQ3N+fJJ5/Mgw8+mKoqP4Jdyf/9GWxsbMyll16a22+/PW9+85vziU98Ij/96U/zrne9q7yFslULFizIf/zHf+Tuu+9ORUVFxo8fnx/84Ae55ppr9GMX8l//9V/5xS9+kXvuuSdNTU0ZOnRo3vGOd/h57GK29Ptw6dKlueCCCzJ79uzU1NRkzJgxOe6443LggQeWuVp2FEZ+upA77rgjn//851NfX1/uUngDnnzyyVRUVGTChAl5//vfn+9+97vlLolt9H9/BpcsWZJ99903/fr1S1VVVUaMGJH58+eXuUpeT11dXS6++OLU1NSkuro6b3nLW/L000/rxy7m2GOPzXe+851UVVXlxRdfzIYNG/Lqq6/qxy5mS78PFyxYkIEDB6ZPnz7p0aNHhgwZoh/pUD527kK++MUvlrsEOsCrr76ad7zjHfnnf/7nNDY2Zty4cdl///1zwgknlLs0WvF/fwaXLVuWurq6ltf19fVZunRpZ5dFGxx00EEtXz/99NO5995785GPfEQ/dkHV1dW57rrrcuutt+akk07y89gFben34cknn7xZPy5ZsqSMVbKjMfIDneztb397pk2blh49emS33XbL6NGj89Of/rTcZdEOzc3Nm62rqKgoQyW01eOPP56Pfexjueiii7LPPvtstl0/dg0TJ07MQw89lBdeeGGLU8L14/ZtS78Pr7vuus320490JOEHOtnChQvz0EMPtbxubm527U8X1bdv36xYsaLl9bJly0xL7QIWLVqUM844I//0T/+UD3zgA/qxC/rv//7vPPbYY0mSnXbaKSeeeGJ++ctf6scuZku/D/faay/9SEkJP9DJVq1alWnTpmXt2rVZvXp17r777gwePLjcZdEORx11VJ566qn86U9/yoYNG/KDH/wggwYNKndZvI4XXnghn/rUp3LNNddk2LBhSfRjV/Tss89mypQpWbduXdatW5cHHnggY8aM0Y9dzJZ+H/7Lv/xLHnrooaxcuTINDQ25//779SMdysfN0Mne85735De/+U1GjRqVjRs35vTTT8/b3/72cpdFO9TW1ubqq6/Opz/96axduzbvete7ctJJJ5W7LF7HLbfckrVr1+bqq69uWTdmzBj92MW8613vavl/tFu3bjnxxBMzbNiw7LbbbvqxC9nS78NjjjkmF1xwQcaNG5f169dn9OjROfLII8tdKjuQiuYtTVoHAADYwZj2BgAAFILwAwAAFILwAwAAFILwAwAAFILwAwAAFIJbXQN0Qc8++2wGDx6cgw8+OEmycePGVFdXZ9y4cRk1alSuvfba7Lvvvhk1alRZ6iv3+QFgS4QfgC6qe/fumTt3bsvr5557LmeccUZ22mmnnHfeeWWsLGU/PwBsifADsIPYa6+9MnHixNxyyy35yU9+koMOOigf//jHc8QRR+SMM87Igw8+mNWrV2fSpEmZP39+/vjHP6a+vj5f//rX06NHj/z3f/93vvjFL+bll1/Ohg0b8pGPfCSjR4/OL3/5y0yfPj39+vXL448/nnXr1uVzn/tcBg4cmIULF+bqq6/Oxo0bkySf+MQnMmTIkFx88cUt51+4cGGmTZuWhoaGVFdX5/zzz8+gQYMye/bs/PCHP0xlZWX+9Kc/pbq6Ol/60pdaRrMAoKO55gdgB3LooYfmj3/84ybr1q1bl7q6usybNy8f+tCHMmXKlEyePDn33ntvVq9enQceeCBNTU2ZOHFi/umf/imzZ8/Od7/73dx666359a9/nSRZsmRJPvaxj2XOnDkZPXp0rr/++iTJV7/61Zx55pmZPXt2rrzyyvziF7/Y5NwvvfRSJk6cmMmTJ2fevHn50pe+lEmTJuXPf/5zkuThhx/OZZddlh/84Afp379/brnlltJ/kwAoLCM/ADuQioqKdO/efbP1Q4YMSZLss88+Ofjgg9O3b98kyd57751XXnklTz/9dJ555plceumlLW0aGxvz6KOP5i1veUv23HPPHHbYYUmSww8/PHfffXeS5OSTT87ll1+eH//4xzn++OPzmc98ZpPzLlmyJPvss0+OOuqoJMlBBx2U/v3757/+679SUVGRt771rdljjz1ajvvDH/6wg78jAPA/hB+AHcgjjzyyxWlj1dXVW/z6bzZs2JBddtllk2uIVqxYkV69euXXv/71JoGqoqIizc3NSZIxY8bkPe95T/7zP/8zP//5z3P99dfnnnvuadn3b9Ph/rfm5uY0NTWlurp6q8cFgFIw7Q1gB/HUU0/lhhtuyMc+9rE2t91///1TW1vbEn5eeOGFDB8+PL/97W9ft92YMWPy2GOP5ZRTTskVV1yRV199Na+88krL9qOOOipPPfVUlixZkiR5/PHH8/DDD+fYY49tc40A8EYZ+QHoohobGzNy5MgkSWVlZWpra/OZz3wm7373uzN//vw2HaumpiY33HBDvvjFL+bmm29OU1NTzjvvvBxzzDH55S9/udV2n/3sZ3PllVfmX//1X1NZWZlzzz03e++9d8v23XbbLddee22uuOKKNDY2pqKiIldddVX233///OpXv2rfGweAdqpoNscAAAAoANPeAACAQhB+AACAQhB+AACAQhB+AACAQhB+AACAQhB+AACAQhB+AACAQvj/AXx+BXVlz4YhAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 842.4x595.44 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "high_dim_df['Coverage Gap'] = np.abs(high_dim_df['Coverage'] - alpha)\n",
    "\n",
    "fig = sns.barplot(high_dim_df, x=\"Dimension\",y=\"Coverage Gap\",hue=\"type\") \n",
    "\n",
    "plt.legend(bbox_to_anchor=(1.02, 1), loc='upper left', borderaxespad=0)\n",
    "plt.tight_layout()\n",
    "plt.savefig('figures/HighDimLQRCoverageGap.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.9.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
