{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c70d3ceb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.special import expit\n",
    "\n",
    "from sklearn.kernel_ridge import KernelRidge\n",
    "from sklearn.model_selection import GridSearchCV\n",
    "from sklearn.metrics import mean_squared_error, r2_score\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.base import clone\n",
    "\n",
    "def f(X):\n",
    "        return np.sin(X[:,0]) * X[:,0] + X[:,0] * expit(X[:,1]) - 0.2 * X[:,0] * X[:,2] + 0.2 * X[:,0]\n",
    "\n",
    "def gen_multicol_data(n, X_loc,X_scale, base_d, multicol_noise, outcome_noise, h, f=f):\n",
    "\n",
    "    # generate baseline partially-multicollinear covariates\n",
    "    Xbase = np.random.normal(X_loc, X_scale, size=(n,base_d))\n",
    "    multicol = expit(Xbase[:, 0] - Xbase[:, 1])*4 - 2 + np.random.normal(scale=multicol_noise, size=n)\n",
    "    X = np.concatenate([ Xbase, multicol.reshape(-1,1) ], axis=1)\n",
    "\n",
    "    # generate baseline outcome and confounded outcome\n",
    "    y = f(X) + np.random.normal(scale=outcome_noise, size=n)\n",
    "\n",
    "    # numerical derivative stuff\n",
    "    Xup = X.copy()\n",
    "    Xup[:, 0] += h\n",
    "    Xlow = X.copy()\n",
    "    Xlow[:, 0] -= h\n",
    "\n",
    "    return X, Xup, Xlow, y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fe69c0cb",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c6ce58cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_loc=0\n",
    "X_scale=1\n",
    "\n",
    "multicol_noise = 2\n",
    "h = 0.01\n",
    "outcome_noise = 2\n",
    "base_d = 2\n",
    "d = base_d + 1\n",
    "n = 500"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a9d15a2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_deriv_data(n, X_loc, X_scale):\n",
    "    return gen_multicol_data(n, X_loc, X_scale, base_d, multicol_noise, outcome_noise, h)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "93a14b7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "X, Xup, Xlow, y = gen_deriv_data(10000000, 0, 1)\n",
    "X2, Xup2, Xlow2, y2 = gen_deriv_data(10000000, 1, 1)\n",
    "X3, Xup3, Xlow3, y3 = gen_deriv_data(10000000, -1, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "42f34c14",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.7004373610636518"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f_derivs = (f(Xup) - f(Xlow))/(2*h)\n",
    "f_derivs.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "065cc8c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.2249865510459028"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f_derivs = (f(Xup2) - f(Xlow2))/(2*h)\n",
    "f_derivs.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "81a5c013",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.17542932473400194"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f_derivs = (f(Xup3) - f(Xlow3))/(2*h)\n",
    "f_derivs.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9a564235",
   "metadata": {},
   "outputs": [],
   "source": [
    "ground_truth1 = 0.6994173798336202\n",
    "ground_truth2 = 1.2241052580620497\n",
    "ground_truth3 = 0.17586849307971283"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "945845e6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "n = 50\n",
      "n = 100\n",
      "n = 200\n",
      "n = 300\n",
      "n = 400\n",
      "n = 500\n"
     ]
    }
   ],
   "source": [
    "nom_cover_with_n_1 = []\n",
    "boost01_cover_with_n_1 = []\n",
    "boost001_cover_with_n_1 = []\n",
    "\n",
    "nom_cover_with_n_2 = []\n",
    "boost01_cover_with_n_2 = []\n",
    "boost001_cover_with_n_2 = []\n",
    "\n",
    "nom_cover_with_n_3 = []\n",
    "boost01_cover_with_n_3 = []\n",
    "boost001_cover_with_n_3 = []\n",
    "\n",
    "for n in [50, 100, 200, 300, 400, 500]:\n",
    "    print(f\"n = {n}\")\n",
    "    \n",
    "    nom_covers_1, boost01_covers_1, boost001_covers_1 = [], [], []\n",
    "    nom_covers_2, boost01_covers_2, boost001_covers_2 = [], [], []\n",
    "    nom_covers_3, boost01_covers_3, boost001_covers_3 = [], [], []\n",
    "\n",
    "    nTrials = 1000\n",
    "    for tr in range(nTrials):\n",
    "        # Training data\n",
    "        X, Xup, Xlow, y = gen_deriv_data(n, 0, 1)\n",
    "        scaler = StandardScaler().fit(X)\n",
    "        X_scaled = scaler.transform(X)\n",
    "\n",
    "        krr = KernelRidge(alpha=0.5, gamma=0.12, kernel='laplacian')\n",
    "        krr.fit(X_scaled, y)\n",
    "        resid = y - krr.predict(X_scaled)\n",
    "\n",
    "        boost01 = KernelRidge(alpha=0.1, gamma=0.12, kernel='laplacian')\n",
    "        boost01.fit(X_scaled, resid)\n",
    "\n",
    "        boost001 = KernelRidge(alpha=0.01, gamma=0.12, kernel='laplacian')\n",
    "        boost001.fit(X_scaled, resid)\n",
    "\n",
    "        # Coverage computation helper\n",
    "        def compute_all_coverages(Xup_t, Xlow_t, ground_truth):\n",
    "            Xup_scaled = scaler.transform(Xup_t)\n",
    "            Xlow_scaled = scaler.transform(Xlow_t)\n",
    "\n",
    "            deriv_pred = (krr.predict(Xup_scaled) - krr.predict(Xlow_scaled)) / (2*h)\n",
    "            boost01_pred = deriv_pred + (boost01.predict(Xup_scaled) - boost01.predict(Xlow_scaled)) / (2*h)\n",
    "            boost001_pred = deriv_pred + (boost001.predict(Xup_scaled) - boost001.predict(Xlow_scaled)) / (2*h)\n",
    "\n",
    "            def ci_and_cover(preds, truth):\n",
    "                mean = preds.mean()\n",
    "                ci = 1.96 * preds.std() / np.sqrt(n)\n",
    "                return (truth >= mean - ci) & (truth <= mean + ci)\n",
    "\n",
    "            nom_cover = ci_and_cover(deriv_pred, ground_truth)\n",
    "            b01_cover = ci_and_cover(boost01_pred, ground_truth)\n",
    "            b001_cover = ci_and_cover(boost001_pred, ground_truth)\n",
    "            return nom_cover, b01_cover, b001_cover\n",
    "\n",
    "        # Generate test sets at different locations\n",
    "        Xt1, Xup1, Xlow1, _ = gen_deriv_data(n, 0, 1)\n",
    "        Xt2, Xup2, Xlow2, _ = gen_deriv_data(n, 1, 1)\n",
    "        Xt3, Xup3, Xlow3, _ = gen_deriv_data(n, -1, 1)\n",
    "\n",
    "        # Test location 0\n",
    "        nc1, b01c1, b001c1 = compute_all_coverages(Xup1, Xlow1, ground_truth1)\n",
    "        nom_covers_1.append(nc1)\n",
    "        boost01_covers_1.append(b01c1)\n",
    "        boost001_covers_1.append(b001c1)\n",
    "\n",
    "        # Test location +1\n",
    "        nc2, b01c2, b001c2 = compute_all_coverages(Xup2, Xlow2, ground_truth2)\n",
    "        nom_covers_2.append(nc2)\n",
    "        boost01_covers_2.append(b01c2)\n",
    "        boost001_covers_2.append(b001c2)\n",
    "\n",
    "        # Test location -1\n",
    "        nc3, b01c3, b001c3 = compute_all_coverages(Xup3, Xlow3, ground_truth3)\n",
    "        nom_covers_3.append(nc3)\n",
    "        boost01_covers_3.append(b01c3)\n",
    "        boost001_covers_3.append(b001c3)\n",
    "\n",
    "    # Store averages over trials\n",
    "    nom_cover_with_n_1.append(np.mean(nom_covers_1))\n",
    "    boost01_cover_with_n_1.append(np.mean(boost01_covers_1))\n",
    "    boost001_cover_with_n_1.append(np.mean(boost001_covers_1))\n",
    "\n",
    "    nom_cover_with_n_2.append(np.mean(nom_covers_2))\n",
    "    boost01_cover_with_n_2.append(np.mean(boost01_covers_2))\n",
    "    boost001_cover_with_n_2.append(np.mean(boost001_covers_2))\n",
    "\n",
    "    nom_cover_with_n_3.append(np.mean(nom_covers_3))\n",
    "    boost01_cover_with_n_3.append(np.mean(boost01_covers_3))\n",
    "    boost001_cover_with_n_3.append(np.mean(boost001_covers_3))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "cbc21ef4",
   "metadata": {},
   "outputs": [],
   "source": [
    "ns = [50, 100, 200, 300, 400, 500]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c69a4843",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_coverage(cover, color, marker, label):\n",
    "    plt.plot(ns, cover, color=color,marker=marker, label=label)\n",
    "    # se = np.sqrt(np.array(cover) * (1 - np.array(cover)) / nTrials)\n",
    "    # plt.plot(ns, cover + 1.96*se, color=color,  linestyle='--')\n",
    "    # plt.plot(ns, cover - 1.96*se, color=color, linestyle='--')\n",
    "    plt.axhline(0.95, color='black', linestyle='dotted')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d424743",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAGGCAYAAACUkchWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6cUlEQVR4nO3deXxTVf7/8XeSbpRurGUruwuIgJRFUAQVC7iLo7iMuzODXxUBZxzBH6KOis583VBxdFzQGcYFUb44g1CYAcS9bMrmDrQiUNYW6J6c3x+Xpk2btGmbNEn7ej4eeaQ59+Tm5Lb0Q9/35FybMcYIAAAAAAAAAABUYw/1AAAAAAAAAAAACFeE6AAAAAAAAAAA+ECIDgAAAAAAAACAD4ToAAAAAAAAAAD4QIgOAAAAAAAAAIAPhOgAAAAAAAAAAPhAiA4AAAAAAAAAgA+E6AAAAAAAAAAA+ECIDgAAAAAAAACAD4ToAAAAAAAAAAD4QIgOAAAAAAAAAIAPhOgAQubo0aOaMmWKOnXqpLi4OA0cOFBvvfVWqIcFAAC8OHLkiO655x5lZGSoXbt2stlseuCBB0I9LAAA4AfqONAwhOgAQmbChAl6/fXXNWvWLH344YcaMmSIrr76av3zn/8M9dAAAEAVBw4c0EsvvaTi4mJdeumloR4OAACoA+o40DBRoR4AgOZpyZIlWr58uf75z3/q6quvliSdffbZ2rlzp/7whz9o4sSJcjgcIR4lAAAo161bNx06dEg2m0379+/Xyy+/HOohAQAAP1HHgYZhJjrQzPXo0UM33HBDtfZzzjlHo0aNCtrrvv/++0pISNAVV1zh0X7TTTfpl19+0RdffBG01wYAIJKFqnbbbDbZbLag7R8AgKYkVPXaF+o40DCE6EAzduDAAe3YsUODBw/2aDfGaP369UpPT/f6PGOMysrK/Lr5snnzZvXp00dRUZ4fiOnfv797OwAA8BTK2g0AAPxDvQaaHkJ0oBlbu3atJFUr7N9//73y8vJ8FvbVq1crOjrar9uOHTu87uPAgQNq3bp1tfbytgMHDjTgnQEA0DSFsnYDAAD/UK+Bpoc10YFmLCsrS1FRURo4cKBH+7p16yTJZ2FPT09XVlaWX6/RqVMnn9tq+igZHzMDAKC6UNduAABQu1DW66qz1B0OB39fAwFAiA40Y2vXrlXfvn3VokWLau0JCQk68cQTvT4vISGh2n8GfKm6XEu5Nm3aeJ1tfvDgQUnyOksdAIDmLpS1GwAA+CdU9XrHjh3q0aOHR9vKlSs1evRov/YJwDeWcwGasbVr12rQoEHV2letWqXTTjtNdrv3XxGB+IjZqaeeqm3btlU7S75p0yZJUr9+/Rr25gAAaIJCWbsBAIB/QlWvO3XqpKysLI+br1nvAOqGaSZAM7Vnzx7t2rWr2tnr1atXa/369ZoyZYrP5wbiI2aXXXaZ/va3v2nhwoWaOHGiu/31119Xp06dNGzYML/2DwBAcxHq2g0AAGoXynodExNTbR12AIFBiA40U+WFecGCBerbt6969+6tjRs36vnnn5ck5ebmavPmzV5nhCcmJja4MI8fP17nnXeebrvtNuXn56t379568803tXTpUv3jH/+Qw+Fo0P4BAGhqQl27JenDDz/UsWPHdOTIEUnS1q1b9e6770qSzj//fMXHxzf4NQAAiGThUK99oY4D9UeIDjRTa9euVVRUlF5++WX94Q9/0J49e3T66adr8eLFuvbaa7Vy5UrdcccdQR3De++9p/vuu0/333+/Dh48qJNPPllvvvmmrrrqqqC+LgAAkSgcavdtt92mnTt3uh8vWLBACxYskCRt375d3bt3D+rrAwAQ7sKhXvtCHQfqz2aMMaEeBIDGd/7552vPnj1av359qIcCAAD8QO0GACD8Ua+BpokLiwLN1Lp16zR06NBQDwMAAPiJ2g0AQPijXgNNEyE60AxlZ2crNzeXwg4AQISgdgMAEP6o10DTxXIuAAAAAAAAAAD4ENKZ6B999JEuuugiderUSTabTYsWLar1OatXr1Z6erri4uLUs2dP/fWvfw3+QAEAgCRqNwAAkYbaDQBAw4U0RD927JgGDBig5557zq/+27dv1/nnn6+RI0dqw4YNmjFjhiZPnqyFCxcGeaQAAECidgMAEGmo3QAANFzYLOdis9n0/vvv69JLL/XZ549//KMWL16sbdu2udsmTZqkr776Sp999lkjjBIAAJSjdgMAEFmo3QAA1E9UqAdQF5999pkyMjI82saOHatXXnlFpaWlio6Orvac4uJiFRcXux+7XC4dPHhQbdq0kc1mC/qYAQCoL2OMjhw5ok6dOsluj8xrgVO7AQDNCbXbQu0GAEQKf2t3RIXoe/bsUWpqqkdbamqqysrKtH//fnXs2LHac2bPnq0HH3ywsYYIAEDA5eTkqEuXLqEeRr1QuwEAzRG1GwCAyFJb7Y6oEF1StbPY5avR+Dq7PX36dE2bNs39OC8vT127dlVOTo6SkpKCN1AAABooPz9faWlpSkxMDPVQGoTaDQBoLqjdFmo3ACBS+Fu7IypE79Chg/bs2ePRlpubq6ioKLVp08brc2JjYxUbG1utPSkpiWIOAIgIkfwxaGo3AKA5onZbqN0AgEhRW+2OqEXahg8fruXLl3u0ZWZmavDgwV7XZQMAAKFF7QYAILJQuwEAqC6kIfrRo0e1ceNGbdy4UZK0fft2bdy4UdnZ2ZKsj4Rdf/317v6TJk3Szp07NW3aNG3btk2vvvqqXnnlFf3+978PxfABAGh2qN0AAEQWajcAAA0X0uVc1q5dq7PPPtv9uHwNtRtuuEHz5s3T7t273YVdknr06KElS5Zo6tSpev7559WpUyfNmTNHl19+eaOPHQCA5ojaDQBAZKF2AwDQcDZTfoWQZiI/P1/JycnKy8tjbTYAQFijZlk4DgCASEHNsnAcAACRwt+aFVFrogMAAAAAAAAA0JgI0QEAAAAAAAAA8IEQHQAAAAAAAAAAH0J6YVEA8MnllPatkQp3Sy06Su1GSnZHqEcFAAAAAACAZoYQHUD4yXlPWneXVPBzRVt8Fyn9GSltQujG1VRwggIAAAAAAMBvhOgAwkvOe9KaX0kynu0Fu6z2ke8SpDcEJygAAAAAAADqhBAdQGgZI5Udk8qOSCWHpC9vU7UA3epo3X3xW+s5jljJFi3ZoyR7tGTzcW+P8t3P5pBstsZ8t6HFCYrgY5Y/AAAAAABNTrMN0fft26eEhATZ7da1VY8ePaqCggLFxcUpKSnJ3S83N1eS1Lp1a0VFWYeroKBAR48eVUxMjFJSUurVd//+/XK5XEpJSVFMTIwkqaioSPn5+YqKilLr1q3r1ffgwYMqKytTUlKS4uLiJEklJSU6fPhwnfra7Xa1bdvW3ffw4cMqKSlRQkKC4uPj69y3rKxMBw8elCS1b9/e3Tc/P19FRUWKj49XQkJCnfu6XC7t379fktS2bdtq38+69PXne++1r8up/d8ulq1or5Lb91ZUx7Mlu6NO3/tA/JyUfz8b+nNS9fvptW9xsQ4f+EV21zG1TYqRSvOlsiPKP/iLSgvz1DKqRHFRxVJpvpxFeTqSt1+2siNKjiuRSo9IpfkqPJYnZ/ERxeioYqLM8e+RVFhivW7LOPcQVFwqlTml6CgpRgekj38lY6SC4lr6Hv8NV7lvfGxFbl5SJpU4HYqKjlZcTLQ7dD9SZJdsUWoZHyu7w2ovKrWpxOlQdHS0WrRo4Q7j8445JXuUElrGyxEVK9mjVFxmU2GJS1FRsdbP3/HQ/tDRYskWpcTEJEVFWycBikpcKih2KjomTolJye79HsorkEsOJSYlKSa2pWSPUlGJU0cLSuSIilWr1m3d+z1w6Ihcxq7kVm0UExd/fL9lyj9aqKioGLVu08YKd9fdpYISI+OSYqOlqOPZrtNlVFgi2T6ZrJZXXuIOffkdUcffETnvqfizO1V29BdFOaxjXD7LPzf2TM++8u/fPTxRu/l3GbDaHYDvfcTV7gB87xv6c1L5+9nQnxNf38/6/pzwO4LfEYH6HQFP1G7+XYbDv0tqN7Wb3xH8jghI7TbNTF5enpE1DdNs3brV3T5mzBgjyZx00kke/cv7rlmzxt126aWXGkmmW7duHn1tNpuRZBYtWuRuu+6664wk06FDB4++DofDSDLz5s1zt912221GkmndurVH39jYWCPJPPXUU+62e++910gyiYmJHn3j4+ONJDNr1ix32+zZs40kExcX59E3OTnZSDJTp051t82dO9dIMtHR0R5927VrZySZW265xd321ltvGUnGbrd79O3cubORZK644gp3W2ZmpvtYVtarVy8jyZx//vnutqysLK99+/XrZySZUaNGudt27Njh7nvs2DF3++DBg40kM3jwYHfbsWPH3H137Njhbh81apSRZPr16+fxeuV9s7Ky3G3nn3++kWR69eplNWQvNOb9LiY53ur73RMy5v0uxmQvNFdccYWRZDp37uyxX7vdbiSZt956y912yy23GEmmXbt2Hn2jo6ONJDN37lx329SpU40kk5yc7NE3Li7OSDKzZ892t82aNctIMvHx8ca4XMaUHjWmYLdpk9LSSDKP3HO1MTn/Z8xPfzdvPHq5kWQ6tnIYk3WnMZ/daMxHE8zQE6KMJPPiba2s9/ZOsvniIetnvVtbGTO/4nZJunUcXrqlom3z41Zb20TPvteMsNqf+nV5m838+EyMNd5Yz763jrb6PnzF8bbFJ5hd/+hX8XPywUnG/F8vY97vaiadZ433Dxc5jHk7wZi34syRV+3uvkdfqdjvjEustrvGeb5eed/cFyraHr7Cart1tGff+FirffvTFW1P/dpqu2aEZ9+2iVb75scr2l66xWq7JN2zb7e2VvuXD1W0/eN/rLYx/Tz79u1sta+8r6Lt/alW24gTZMyb0ca8GWPMfJnBPa32f/2+om/mvVbbgK4y5t8DjPnvWGNWXWQGdLeO5XOT+xrzxW+NybrDvP/4udb3M8luzOZHjdn6v8Z8M8f07Z5gJJk/3jrKmJ0LjMlZbBa/av2eiou2G7M/y5iDXxlzeJvp1a2DdXyuvNiYkjxjygpN5rKlkf07InuhMfNt5vGrrLYbRlb8XJv5NhPtsNozMzPdz/fnd0R5zcrLyzPNGbW7ArXb0qDaXaVvXf9dlmuU2l1JYmKikWTuvfded9tTTz1lJJnY2FiPvq1btzaSzG233eZumzdvnpFkHA6HR98OHazfydddd527bdGiRUaSsdlsHn27detmJJlLL73U3bZmzRqv3/uTTjrJqlljxrjbtm7d6rXvwIEDrZo1YoS7be/eve6+e/fudbePGDHCSDIDBw702Ae/Iyz8jrCE8ncEtdtC7a7Av0sLtdtC7a7A7wgLvyMskVC7m+1MdKDBalkao61jeMBeKsqVL+V/L5XlK8nkSJJatSiRvn/BPbO7fWKpsouknsf+If33v1LpEZ1S8KMk6aT2BdJbUZJxWY/bSZ8elvqWvil99KYkKe2Y9Vqt4p3Sd8+6Xzsp1rpvaTskFRySJHksgBKdZN2iEnW05AdJpdrvSpN6nCNFJ+lgwS+SFupYsaThf5eiE6XoJH31wLWSduvTY2M15cqFkiNeBz58TtLk2g/I0JeUdzBVUl/r8YXfuDd9/uBpkjbqkwPDpCs/kSQV5OZKSpUkHRu/Qy3btpJcZfpk7lhJa/XFvr7SRf8nuUolUyapvyTp8Gn/ULvuXSRTqq//8QdJG7X1UCfpjKesfq5SlZTeKEk6lHaXuvftJrnKtH3Ra5K2KedIstT3Nvd+i0qfkSTlJZ0jde8smVLtc30qKVuHimKlDqMq9lu2RpJUGNNVSk6UTJkKzW5J+Sp12qTYtu6+xhyt+Xi5Sms/puUOf2XdJKW0sJraa6v0w1ZJUrvjPycpLVzSVzPcT+ueIm2VdLJ9tfTxaklS2m5rW+sEl7RsiLvvaanSjzulES0WSwuSrefvsbYlt5C0oJXkiJHssUpvv1s//iilJ3wsLRsm2WPUarf1sQKHXdLHV0r2WMkeo95Ju7RZUs/4H6Wv/p9kj1XMgWPu17X9NE+KT5DsMWobe1iS1ComX8r9SLLHSMWuiuNQmCMVWmNwyHm8scq/9XLGZa0zL+NldSAjyaYWMVJpofenAwAAAACA8GY7ntQ3G/n5+UpOTtYPP/ygHj168JERPjJSv4+MxEYraWV/98UZjxVZz2kRI1m7takkKlV5g99VjK1EyfE2d9h9+MBumdJ8JcSUKtoUSGVHVHzsoIqO5SlaRxXvKLSWRyk9omNH8yRjFBdzPDCUtVRJcan1Oi1i3MNVYYm1HErtfW0qcCXIaW+puJYpio6zQvAytdTRsjjZohOU3DpVirLC7rxCm8ps8UpITlVsQlspOlElJk6Hjzllj05U23bt6vW999q3pFiF7/aQrWi3Erws0RIVJcUmpUkXb5dLNj5WVrVvcrJiou2Sq0xFhUeUn3dIUXaj1imJUu4a6dOr3T8nnsu5SEUlx39OBs2UEk+QXCXKO3xAztIStYyzKdbhklwlKi0p0LGjR2RTmZLj7ZKzRHIV69ixoyorLVZclFOxDqfkKlFZSZEKiwplM6VKiHFKrmLJVaLCwmI5y4oV63Aq+vipXL+W8qlH35qW8iktq1vfKIcUGxtjBe72GB0pjpLsMYqPcclR/Ev1vtEVYztWJBUOf08pJ1xUp+99UVGRkpOTlZeX5/Fz19xQu6ndvvrykXA+El71+xlxtZvfEU3udwS120Lt5t+lr77Ubmp31e8ntZvfEZX7hnPtbrYhenP/Tw18MEYqOyqV5kkleVLp4eP3Vb4+vEX65YNGHJhNiko4Pus70T3zu16Po+Ilm70Rx15H7hn+kufM3+OJJhe/rB+XU1rc3fqkhNcZ1TZr/e6LtzfehTCNy5ol7yo+HsaX34orvnb6+Lq8n7OW51R7XId+zmIfx6qeRvxT6n51nZ5CzbJwHAAAkYKaZeE4AAAihb81i+VcmguXU9q3RircLbXoKLUb2XhBWWMxRnIWHQ+886SSw9W/LqlhW/nNuGp+nbqwx0mxrRsWekcnSlEtwzv4DqS0CVZQvu4u90x/Sccv0Pg0AXp92R1S+jPHT1DY5PUERfrTjft7wWaXHLHWLbr27iHhcnoG796C/f1fSOv9WIaoRcfgjxcAAAAAAAQcIXpzkPOej0DymfAKJF2l3md9VwvBD/uYKZ5nhVqBYIuSYpKl6GQpOqXS18lSTIpUfEja8Ubt+zn7Qyl1dGDG1JykTZA6X9L0T/w0Nk5Q1J3dIdnjJcX77tM6Xfrmz7XP8m83MkiDBAA0ec1hQgwAAEAYI0Rv6mq5+GXAlsYwruPreHsJt33N+q4aiDsLGj4OSZLt+Azu44F35fA7OrkiEPe2rXy7I15erhBYweWUcv9LaBZMdgcnIIKBExSBF46z/AEATUekTIiJVJygAAAAfiBEb8pcTus/3F5DXiPJJq2bInW6WHJ5WQal2qzvmpZByQ/cuKNa1h5yR6d4fl15pnh0YvCXPiE0QyTjBEXgMcsfABAMjTUhprniBAUAAJEnRCfACdEbIhxnLThLpOJ9UlGutGeF538IqzFSQY70dqykAK0Dbo+tPeSuaXZ4dLJkj5AfS0IzAJUxyx8AEEj+TojpfAm1pj44QQEAQOQJ4QnwCEkrw1BjfdNcZVLxfisULw/Hy++9tZXm1edFrDubw78Z4N6WQ3EvgxIXsLceEQjNAFTGLH8AQE2MsZYwLD0ilR09fn9EKj1q3Ze3lR6R8rb6NyEmc7gU106S3fo0ps0uyVbp61raa2tzt9uq7MtLW+XnhvPrykhZ/yNOUAAAEEFCfAKcEL0+GvJNczmlkoP+BeJFuVbfurI5pNh21rrex36qvf8Z70idz699HXB4R2gGAAAQnp/SbCiX0wq2y45UCb4rBeDV2mrZ5jW4bYCDWYHdH+Q+QbFvDf/PB9C0NcXajaYpDD6hR4heV7V+0yR9cat0aJNU4mUGefF+6yKcdWKTYttaM0xi21e6r/J1bDvrPibFmmXhckqLu9d+8cu0CfySBAAAzQd/MAZeuKwt7SyufYa3OxSvEo57a3MWBm+sUQnWtXyiEqSoxIqvy+9LDks579a+nz5/lJJOkuSy/s4wruNfm0pfuySZKturtFV+Xm37qvzc+uyrcpu3fXlt82Nf/o61rMD6PtemcLdf30oAiEjhUrubKv6/WZ0x1v+tPP7v5edEhGM7/fuEXhBPgBOi19W+NbV80ySVHJI2P1Bzn5hWnsG3z3C8nRTTpn7/0Lj4JQAAgCf+YAy8+n5K0720iY8/ouo0+/v4167S4LxHm8NL0J0oRR8PwGtq8wjKy7fFH19apAb+TogZ8Aj/n6+rvauk/5xde78WHYM+FAAICa4LEVxN5f+bLqfkPObfMnT+TFIoO1qPicV1FMQT4ITodeXvN6P92VK74RVBuEdg3layRwd3nOW4+CUAAICFPxgruJySKbVCZ1dJlfvjX5tS66L1NfVzFkkb/6gaP6X5ybVSm2GS82j1P7YCvbRJOUdc9eC66kxvf9uiEyV7bOMve8iEmOBpN9L6e6i2ExTtRjb2yAAg+MJgWYwmLZT/33SW+A6z6zNJwVkQnHFKx//fVdPEhCrbjv0sbX209v0G8QQ4IXpd+fvNOPX+8Fk/j4tfAgCA5i7QfzAaIxln9WDZI3iuEkrX2q+W/oHqZ0qDPwuoMleRtG91zX08/pCq9EeTrz+kfM3+jj6+n8aasBJsTIgJDk5QAGjqKl/IuuqM4AOf+7csxmfXSwk9rU9j2ezH72v6uspjHf/aXunruu6j6v7sjur7r3V/jXgSvC7/37TZrckI9Q26K/ctb3OVBOd9uT+RF4CJCf5+Iq8ql1Pa8UZIT4ATotdVpM5a4OKXAACgOcv9yL8/GJf0kxwt/Au9mxp7jBU+26IlR4x1X95mr/x1pX5F+6TDG2rf9wl3SJ3G+vgjq2Xd/5BqTpgQExycoAAiS1NfX9pVdjwQ9RKaVl06o8Zt5W0B+LTXzn8G5K2FhYCG8jVsKz7k3/83FyRbkwyMMzjv1x5bx2XmfE1MSAzdJ/KqvafQnwAnRK+rMPimAQAAoAZF+6S8zdLhzRX3h/wIeiUp/5v6v67NUfcQumpbo/c7/nV9Z2r5u7Z018uZ0NEQTIgJDk5QAJEhHNeXdhbXvA50TTOKvbUF7ULWtuMBaaWw1Dilw1/V/tQuE6T4TlZ/4zx+sWZvX9ewTfV4jrfnu2rYnz/c+wsTzmOej6Na1mM2t69P6zWhT+RVFeIT4ITo9cGsBQAAgNArzZcOb/EMzPM2S0W59d9n/0ek1oN8h881hePNcTZ1pH5KEyjHCQogvAVifenKS5s0eIb3kSBfyDoqAEtlVO7nZdkMfy9cfeY7kXFS0bj8D/grh/KBDPjLvz68Rdr2eO1jPv0NqeMYPpFXHyE8AU6IXl/MWgAAAGgcziJrhnjlmeV5m6VjO308wWat4ZnST0ouv/WRVl0gFf6iGv9g7PtH/j9XF3xKEwAQDC6nVHpIyrpdNV68+rMbpV1LKoXk3kLxYF/IupalMmpqq7qtMZbNaGq122Y/HkKHQcTpcko759d+gqL7NZFzfMNRiE6Ah8FPWARj1gIAAEDguMqkoz9Khzd5ziw/8r3vC2G26GSF5Cn9pJRTKwLzqJbV+w6e03T+YAwnfEoTAFCZMVLZMan0sFSSJ5XmSSWHrfvSKo9L8qx+lb8uybPCcH+UHZF+esX/sQVqhnf5vT1CYzVqd3A0tRMU8BCh/9oBAAAQsYyRCrKrzyzP2ya5ir0/J6ZVRUjunmF+ihTb2v/X5Q/G4OFTmgDQdC5+6SyqEnLn+Q7EPb4uD8TzG3f96bRfSe1G1B6Ke1vapDmjdgcH/99ssgjRAQAAEDxFuZXC8vIZ5lt8zzBzxFvheHlQnnKq9XVch8B8vJk/GIOHT2kCaM7C5eKXrjLfQXdJlTDcVz9XSWDGYnNIMSlSdHLFrfLj8q9jkqXolOP3lbYd2iitHFv765x4O/WnvqjdwcH/N5skQnQAAAA0XEmeFY5Xnll+eLNUvM97f3u0lHSy58zylH5Sy+7BnyXGH4wAgEAKxMUvJWvpstIjdVsGpepMcWdB4N5XdFKVcLvS177C8cqBuCO+YSfAU8/l4tWIXPx/s8khRAcAAID/ygqti3x6zCzfLBXk+HiCTUro5RmUp5wqJZ5gBekAAEQyl9OagV7TxS+/uFXK/85a5qTa0ieVvz7iYz/14IivMuu7hhDcW7/oxNAvfcL60gDCCCE6AAAAqnOVWRf0rDqz/OgPvi/yGd+l+szypD7WGqQAADQl5XVy51ueS7h4U3JI+mq6//u2x9QSdKdUCry9bUtqOieqWV8aQJggRAcAAGjOjEs6ll0lLN9kzTb3tSZqTOvqF/lM6Wf94Q4AQFNijFT4y/FPXx2/5W2q+WLY3rQbKbUa6H3pk2rLoMQF571EKtaXBhAGCNEBAADCkcsZ2D8WjZGK9lafWZ63RSo76v05US2rB+XJ/aS41MBc5BMAgHBSmm/Vxsph+eFN1kxyb6JaSvFp1onn2vR/iPWRG4L1pQGEGCE6AABAuMl5z8fHlp/x72PLJYetcNwjLN8kFR/w3t8ebS27Uu0in91Cvx4qAACB5iqV8r+tPrv82E7v/W12KfHE45/COtW6TzlVSuhhnaRe3J2LXwJAE0eIDgAAEE5y3jt+Aa0qf4gX7LLaR75bEaSXFUj526qE5Zt9r81qs0sJvavPLE/s3XTWTgUANC0N+WSWMdaFr6uG5fnfWEG6Ny06VYTk5YF5ch/fS6zYxMUvAaAZIEQHAAAIFy6nNQPd60y2422f3yT99Hcpf4t05AcffWV9vNzrRT5bBGnwAAAEWF0+mVVyuHpYfnizVJrnfd9RicfD8n6es8tjW9d9nFz8EgCaPEJ0AACAcLFvje9Z5OVK86Vdiyoex7atfpHP5FOsC5MBABCpavtk1ol3WrPDywNzn5/CipKSTq4Iyctv8V0De30PLn4JAE0aIToAAEAoOYulg+ukfR9LO9/27zndr5N63nD8Ip/tucgnAKBp8eeTWd/Nqb4pvmv1sDzxJMkRE8zRVuDilwDQZBGiAwAANKbiA9K+T6X9n1jB+YG1kqu4bvvodTN/pAMAmi5/PpklWTO/O42r+EQWn8ICAAQJIToAAECwGCMd/VHadzww3/eJdSHQqmLbSe3OlNoOl7b9r1S8T95n39ms9VXbjQz2yAEACJ3C3f716zZR6n51cMcCAIAI0QEAAALHVSod3GAF5vs/sULzor3V+yWdLLU743hwfoaU2LtiSZbEXsfXgLXJM0g/vj39adZXBQA0bS06BrYfAAANRIgOAABQXyWHpf2fHZ9p/ol04AvJWejZxx4jtR5sBebtzpDajpDi2vreZ9oEaeS71lqwlT/KHt/FCtDTJgTjnQAAED7ajbTqXsEu8cksAEA4IEQHAADNh8tprbNauNuavdZupP+zuo2RCrKl3I8r1jM/vFnV/riPaX18lvnxmeat0yVHXN3GmTbBWue1vmMFACCS2R1S+jN8MgsAEDYI0QEAQPOQ856P2d3PeJ/d7SqTDn/tuZ554a7q/RJ6e4bmSSdJNnvDx2t3cPFQAEDzxSezAABhhBAdAAA0fTnvHZ/NVmXWeMEuq33ku1KH86zlWMpnmu//XCo76tnfFiW1HmStY97+TGtplhYdGu1tAADQrPDJLABAmCBEBwAATZvLac1i87qm6vG2j6+STFn1PtHJVlBePtO8zVApKj7IAwYAAG58MgsAEAYI0QEAQNO2b43nx8C9MaXWfctuFRcAbXemlHxKYJZmAQAAAABELEJ0AADQtBXu9q/f4OekE28P7lgAAAAAABEn5FOr5s6dqx49eiguLk7p6elas2ZNjf3nz5+vAQMGKD4+Xh07dtRNN92kAwcONNJoAQBAxNXuFh3965d8SnDHAQBAiERc7QYAIMyENER/++23NWXKFN13333asGGDRo4cqfHjxys7O9tr/48//ljXX3+9brnlFm3ZskULFixQVlaWbr311kYeOQAAzVNE1u52I6X4LpJsPjrYpPg0qx8AAE1MRNZuAADCTEhD9CeffFK33HKLbr31VvXp00dPP/200tLS9MILL3jt//nnn6t79+6aPHmyevTooTPPPFO/+93vtHbt2kYeOQAAzVNE1m67Q0p/5viDqkH68cfpT1v9AABoYiKydgMAEGZCFqKXlJRo3bp1ysjI8GjPyMjQp59+6vU5I0aM0M8//6wlS5bIGKO9e/fq3Xff1QUXXODzdYqLi5Wfn+9xAwAAdRfRtTttgjTyXSm+s2d7fBerPW1Cw18DAIAwE9G1GwCAMBKyEH3//v1yOp1KTU31aE9NTdWePXu8PmfEiBGaP3++Jk6cqJiYGHXo0EEpKSl69tlnfb7O7NmzlZyc7L6lpaUF9H0AANBcRHztTpsgXbxDOnelNOKf1v3F2wnQAQBNVsTXbgAAwkTILyxqs3l+rNoYU62t3NatWzV58mTdf//9WrdunZYuXart27dr0qRJPvc/ffp05eXluW85OTkBHT8AAM1NRNduu0NKHS11v9q6ZwkXAEAzENG1GwCAMBAVqhdu27atHA5HtbPfubm51c6Sl5s9e7bOOOMM/eEPf5Ak9e/fXy1bttTIkSP18MMPq2PHjtWeExsbq9jY2MC/AQAAvFixQpo8WZozRxozJtSjCSxqNwAAkYXaDQBAYIRsJnpMTIzS09O1fPlyj/bly5drxIgRXp9TUFAgu91zyA6HNYPMGBOcgQIA4CdjpBkzpG3brPumVpqo3QAARBZqNwAAgRHS5VymTZuml19+Wa+++qq2bdumqVOnKjs72/0xsenTp+v6669397/ooov03nvv6YUXXtBPP/2kTz75RJMnT9bQoUPVqVOnUL0NAAAkSZmZUlaW9XVWlvW4qaF2AwAQWajdAAA0XMiWc5GkiRMn6sCBA3rooYe0e/du9evXT0uWLFG3bt0kSbt371Z2dra7/4033qgjR47oueee0913362UlBSdc845evzxx0P1FgAAzUxJiZSbK+3da9327LHud++W/vGPin4OhzRzppSRIflYcjQiUbsBAIgs1G4AABrOZprZ57Hy8/OVnJysvLw8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efN09Kj04YfWjPN//9t6XK59e+uioJdfLo0eba15DgBoeqjdAABEFmo3AAANZzPGmFC9+LBhwzRo0CC98MIL7rY+ffro0ksv1ezZs6v1X7p0qa666ir99NNPat26db1eMz8/X8nJycrLy1NSUlK9x95cHD5szThfuFBatsyagV6uSxdpwgQrOD/jDMnhCNkwAaBJCseaRe0GAMC3cKxZ1G4AAHzzt2Y1eDmXosqpah2UlJRo3bp1ysjI8GjPyMjQp59+6vU5ixcv1uDBg/XnP/9ZnTt31oknnqjf//73Kiws9Pk6xcXFys/P97ihZvv2SS+/bK1h3r69dP310v/9nxWg9+ol3XOP9MUXUna29Mwz0llnEaADQCShdgMAEFmo3QAAhFa9QnSXy6U//elP6ty5sxISEvTTTz9JkmbOnKlXXnnFr33s379fTqdTqampHu2pqanas2eP1+f89NNP+vjjj7V582a9//77evrpp/Xuu+/q9ttv9/k6s2fPVnJysvuWlpbm57tselaskPr2te6r2rVLeu456eyzpQ4dpN/8Rlq61Lpo6CmnSPffL23cKH3/vfT449LQoZLN1uhvAQBQT9RuAAAiC7UbAIDwUa8Q/eGHH9a8efP05z//WTExMe72U089VS+//HKd9mWrksQaY6q1lXO5XLLZbJo/f76GDh2q888/X08++aTmzZvn86z49OnTlZeX577l5OTUaXxNhTHSjBnStm3WvTHS9u3S//6vNGKEtTTLnXdKq1ZJLpeUni498oj0zTfS5s3Sgw9KAwYQnANApKJ2AwAQWajdAACEj3pdWPSNN97QSy+9pHPPPVeTJk1yt/fv31/ffPONX/to27atHA5HtbPfubm51c6Sl+vYsaM6d+6s5ORkd1ufPn1kjNHPP/+sE044odpzYmNjFRsb69eYmrLMTCkry/o6K0s64QTpxx89+4wYYa1vPmGC1L17ow8RABBE1G4AACILtRsAgPBRr5nou3btUu/evau1u1wulZaW+rWPmJgYpaena/ny5R7ty5cv14gRI7w+54wzztAvv/yio0ePutu+++472e12denSpQ7voHkxRrrrLs+2H3+0ZpWfc461jMuuXdInn0jTphGgA0BTRO0GACCyULsBAAgf9QrRTznlFK1Zs6Za+4IFC3Taaaf5vZ9p06bp5Zdf1quvvqpt27Zp6tSpys7Odp9lnz59uq6//np3/2uuuUZt2rTRTTfdpK1bt+qjjz7SH/7wB918881q0aJFfd5Kk7dunTR4sPTtt9W3vfWW9J//SLffLnXq1PhjAwA0Hmo3AACRhdoNAED4qNdyLrNmzdJ1112nXbt2yeVy6b333tO3336rN954Q//617/83s/EiRN14MABPfTQQ9q9e7f69eunJUuWqFu3bpKk3bt3Kzs7290/ISFBy5cv15133qnBgwerTZs2uvLKK/Xwww/X5200ad98I82cKb37rvftDoe1HvoVV7DOOQA0B9RuAAAiC7UbAIDwYTPGmPo8cdmyZXr00Ue1bt06uVwuDRo0SPfff78yMjICPcaAys/PV3JysvLy8pSUlBTq4QRcdrZ1EdB586wLhNZm6VJp7NigDwsAUA+BrlnUbgAAgovabaF2AwAihb81q94heqRqqsV83z7p0UeluXOlkhKr7eKLrbXPt23zHqjb7VJ6uvTFF8xGB4Bw1FRrVl1xHAAAkYKaZeE4AAAihb81q15roiN85OVJs2ZJPXtKTz9tBehnny199pn0zjvS/v2+Z6S7XFJOTkXoDgAAAAAAAADwVK810Vu1aiWbl6nLNptNcXFx6t27t2688UbddNNNDR4gvCsstGadP/qodPCg1TZ4sPV4zJiKmeVZWdYsdV/at5diY4M/XgBAaFG7AQCILNTuCitWSJMnS3PmWH/vAgDQ2OoVot9///165JFHNH78eA0dOlTGGGVlZWnp0qW6/fbbtX37dt12220qKyvTb37zm0CPuVkrK5Nee81a93zXLqvt5JOlhx+WJkyovixLWpp1AwA0b9RuAAAiC7XbYow0Y4a1TOmMGdK557IcKQCg8dUrRP/444/18MMPa9KkSR7tL774ojIzM7Vw4UL1799fc+bMadLFvDG5XNKCBdLMmdL331ttXbtKDzwgXXedFFWv7yQAoLmgdgMAEFmo3Zb337c+YS1Z948+Ko0bJ7Vta93i4wnVAQDBV68LiyYkJGjjxo3q3bu3R/sPP/yggQMH6ujRo/rxxx/Vv39/HTt2LGCDDYRIu8CJMdLSpdYZ940brbZ27aT77pMmTWIpFgBoygJZs6jdAAAEH7XbEqjjYIzUv7+0ebPvPrGxFYF65VubNr7b4uPrPaRasfQMAEQWf2tWveYvt27dWh988IGmTp3q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QnOs3QAARDJqNwBEhsoTb70pn3jLr/HIVK+Z6AcOHNCVV16plStXymaz6fvvv1fPnj116623KiUlRU888USgxxk2uDo0ACASNefaDQBAJKJ2A0BkqcvEW3LDyFOvmehTp05VdHS0srOzFR8f726fOHGilnpbOb+JSUuTBg3yfevSJdQjBADAU3Ov3QAARBpqNwBElvKJt+vW+b5lZRGgR6p6zUTPzMzUsmXL1KVKWnzCCSdo586dARkYAAAIHGo3AACRhdoNAJEnLc26oemp10z0Y8eOeZwJL7d//37FcjoFAICwQ+0GACCyULsBAAgf9QrRzzrrLL3xxhvuxzabTS6XS3/5y1909tlnB2xwAAAgMKjdAABEFmo3AADho17LufzlL3/R6NGjtXbtWpWUlOiee+7Rli1bdPDgQX3yySeBHiMAAGggajcAAJGF2g0AQPio10z0vn376uuvv9bQoUN13nnn6dixY5owYYI2bNigXr16BXqMAACggajdAABEFmo3AADhw2aMMaEeRGPKz89XcnKy8vLylJSUFOrhAADgEzXLwnEAAEQKapaF4wAAiBT+1qx6zUTv0aOHZs6cqW+//bbeAwQAAI2H2g0AQGShdgMAED7qFaLfeeedWrp0qfr06aP09HQ9/fTT2r17d6DHBgAAAoTaDQBAZKF2AwAQPuoVok+bNk1ZWVn65ptvdOGFF+qFF15Q165dlZGR4XH1cAAAEB6o3QAARBZqNwAA4SNga6J//vnnuu222/T111/L6XQGYpdBwdpsAIBIEeyaRe0GACCwqN0WajcAIFL4W7OiGvpCX375pf75z3/q7bffVl5enn71q181dJcAACCIqN0AAEQWajcAAKFVrxD9u+++0/z58/XPf/5TO3bs0Nlnn63HHntMEyZMUGJiYqDHCAAAGojaDQBAZKF2AwAQPuoVop988skaPHiwbr/9dl111VXq0KFDoMcFAAACiNoNAEBkoXYDABA+6hWif/PNNzrxxBMDPRYAABAk1G4AACILtRsAgPBRrxC9vJCvW7dO27Ztk81mU58+fTRo0KCADg4AAAQGtRsAgMhC7QYAIHzUK0TPzc3VVVddpVWrViklJUXGGOXl5enss8/WW2+9pXbt2gV6nAAAoAGo3QAARBZqNwAA4cNenyfdeeedys/P15YtW3Tw4EEdOnRImzdvVn5+viZPnhzoMQIAgAaidgMAEFmo3QAAhA+bMcbU9UnJyclasWKFhgwZ4tH+5ZdfKiMjQ4cPHw7U+AIuPz9fycnJysvLU1JSUqiHAwCAT4GsWdRuAACCj9ptoXYDACKFvzWrXjPRXS6XoqOjq7VHR0fL5XLVZ5cAACCIqN0AAEQWajcAAOGjXiH6Oeeco7vuuku//PKLu23Xrl2aOnWqzj333IANDgAABAa1GwCAyELtBgAgfNQrRH/uued05MgRde/eXb169VLv3r3Vo0cPHTlyRM8++2ygxwgAABqI2g0AQGShdgMAED6i6vOktLQ0rV+/XsuXL9c333wjY4z69u2rMWPGBHp8AAAgAKjdAABEFmo3AADho04z0f/73/+qb9++ys/PlySdd955uvPOOzV58mQNGTJEp5xyitasWVOnAcydO1c9evRQXFyc0tPT/X7+J598oqioKA0cOLBOrwcAQHNC7QYAILJQuwEACD91CtGffvpp/eY3v/F6pdLk5GT97ne/05NPPun3/t5++21NmTJF9913nzZs2KCRI0dq/Pjxys7OrvF5eXl5uv7661kHDgCAWlC7AQCILNRuAADCT51C9K+++krjxo3zuT0jI0Pr1q3ze39PPvmkbrnlFt16663q06ePnn76aaWlpemFF16o8Xm/+93vdM0112j48OF+vxYAAM0RtRsAgMhC7QYAIPzUKUTfu3evoqOjfW6PiorSvn37/NpXSUmJ1q1bp4yMDI/2jIwMffrppz6f99prr+nHH3/UrFmz/Bs0AADNGLUbAIDIQu0GACD81OnCop07d9amTZvUu3dvr9u//vprdezY0a997d+/X06nU6mpqR7tqamp2rNnj9fnfP/997r33nu1Zs0aRUX5N/Ti4mIVFxe7H5evKwcAQHNA7QYAILJQuwEACD91mol+/vnn6/7771dRUVG1bYWFhZo1a5YuvPDCOg3AZrN5PDbGVGuTJKfTqWuuuUYPPvigTjzxRL/3P3v2bCUnJ7tvaWlpdRofAACRjNoNAEBkoXYDABB+bMYY42/nvXv3atCgQXI4HLrjjjt00kknyWazadu2bXr++efldDq1fv36ame5vSkpKVF8fLwWLFigyy67zN1+1113aePGjVq9erVH/8OHD6tVq1ZyOBzuNpfLJWOMHA6HMjMzdc4551R7HW9nxNPS0pSXl+f1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7uuaa67Rvffeq/Xr16uwsFA5OTm66viVzlwulyRrSZeqM9kdDkf9Bg8AQBO1b580Z4703HMV65137izdfbf0m99Yn3wrLpays6XjJbYal0vKyZFKSqTY2EYbOgAAAAA0a4TotbDZ6rakyrJl0vr11dudTqv9k08a5yPYs2fP1mmnneZedkWS1qxZo0suuUS//vWvJVkh+Pfff68+ffr43E+XLl101llnaf78+SosLNSYMWOUmpoqSUpNTVXnzp31008/uWenAwAAT9nZ1szzl1+WCgutthNPlP74R+nXv5ZiYir6xsZaS7bs2+d7f+3bE6ADAAAAQGMiRA8gY6yPWNvt3meQlX8EOyPD/9no9dW/f39de+21evbZZ91tvXv31sKFC/Xpp5+qVatWevLJJ7Vnz54aQ3TJWtLlgQceUElJiZ566imPbQ888IAmT56spKQkjR8/XsXFxVq7dq0OHTqkadOmBeW9AQAQCbZutdY7nz9fKiuz2tLTpenTrWul+PrQVlqadQMAAAAAhAfWRA+gkhL/P4LdGP70pz/JVFo0debMmRo0aJDGjh2r0aNHq0OHDrrUjyueXnHFFTpw4IAKCgqq9b/11lv18ssva968eTr11FM1atQozZs3Tz169AjwuwEAIDJ88YV02WXSKadIr79uBejnnistX27NMr/8ct8BOgAAAAAg/DATPYBC+RHsefPmVWvr1q2bioqK3I9bt26tRYsW1bifVatWVWtLSUnx2E9V11xzja655hp/hwoAQJNjjLRihTR7trRyZUX7ZZdJ994rDR0aurEBAAAAABqGED3A+Ag2AADNh9Mpvf++9Nhj0rp1VltUlLXW+T33SLWsmAYAAAAAiACE6AAAAHVUXCz94x/WmufffWe1xcdLv/mNNG2a1LVraMcHAAAAAAgcQnQAAAA/HT0qvfSS9OST0q5dVlurVtKdd1q3tm1DOz4AAAAAQOARogMAANRi/37p2Wet26FDVlunTtas89/+VkpMDO34AAAAAADBQ4gOAADgQ06O9MQT0t/+JhUUWG0nnGCtd37ddcG5WDgAAAAAILwQogMAAFTxzTfWeuf/+IdUWmq1nXaaNH26NGGC5HCEdnwAAAAAgMZDiA4AAHBcVpb02GPS++9Lxlhto0db4fl550k2W0iHBwAAAAAIAXuoBwAAANCYVqyQ+va17iUrLF+xQhozRho6VHrvPavtkkukzz6TVq6UMjII0AEAAACguWImOgAAaDaMkWbMkLZts2aX5+VZM8/XrrW2OxzStddaa56fckpoxwoAAAAACA/MREdYstlsWrRoUaiHAQBoYjIzrSVbJCs4/9WvrPsWLaQ775R+/FF6/XUCdAAAAABABUL0YHE5pb2rpB1vWvcuZ1Bf7sYbb5TNZnPf2rRpo3Hjxunrr78O6utWRvANAAhnxkhTpni2ORzWzPQdO6Q5c6Ru3UIxMgAAAABAOCNED4ac96TF3aX/nC19eo11v7i71R5E48aN0+7du7V792795z//UVRUlC688MKgviYAAJEiM1P65hvPNqdTOussqX370IwJAAAAABD+CNEDLec9ac2vpIKfPdsLdlntQQzSY2Nj1aFDB3Xo0EEDBw7UH//4R+Xk5Gjfvn2SpE2bNumcc85RixYt1KZNG/32t7/V0aNH3c93uVx66KGH1KVLF8XGxmrgwIFaunSpe3tJSYnuuOMOdezYUXFxcerevbtmz54tSerevbsk6bLLLpPNZnM/lqQPPvhA6enpiouLU8+ePfXggw+qrKzMvf3777/XWWedpbi4OPXt21fLly8P2jECADRPxkgzZ1ozzytzOKx2Y0IzLgAAAABA+OPCorUxRnIW+NfX5ZTWTpbk7S9xI8kmrb1LSh0j2R1e+lThiJdstjoMtsLRo0c1f/589e7dW23atFFBQYHGjRun008/XVlZWcrNzdWtt96qO+64Q/PmzZMkPfPMM3riiSf04osv6rTTTtOrr76qiy++WFu2bNEJJ5ygOXPmaPHixXrnnXfUtWtX5eTkKCcnR5KUlZWl9u3b67XXXtO4cePkOJ5SLFu2TL/+9a81Z84cjRw5Uj/++KN++9vfSpJmzZoll8ulCRMmqG3btvr888+Vn5+vKVU/aw8AQANVXgu9MqfTas/MlMaObfxxAQAAAADCHyF6bZwF0jsJAdqZkQp/lt5N9q/7lUelqJZ+7/1f//qXEhKssR47dkwdO3bUv/71L9ntds2fP1+FhYV644031LKltc/nnntOF110kR5//HGlpqbqf//3f/XHP/5RV111lSTp8ccf18qVK/X000/r+eefV3Z2tk444QSdeeaZstls6lZp4dh27dpJklJSUtShQwd3+yOPPKJ7771XN9xwgySpZ8+e+tOf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e/trr71mkpOTzQcffGBOPPFE06JFC3P55Zebo0ePmnnz5plu3bqZlJQUc8cdd5iysjL387p162Yeeughc/XVV5uWLVuajh07mjlz5ni8tiTz/vvvux///PPP5sorrzQpKSmmdevW5uKLLzbbt2/3Ofa77rrLjB49usb3N2vWLDNgwACP16x669atm3v7li1bzPjx403Lli1N+/btza9//Wuzb9++Gl8DAIBAoHZbqN0AgEhB7bZQuwHfWM4FCHPlZ4IXLVqk4uJin/3sdrvmzJmjzZs36/XXX9d///tf3XPPPR59CgoKNGfOHL311ltaunSpVq1apQkTJmjJkiVasmSJ/v73v+ull17Su+++6/G8v/zlL+rfv7/Wr1+v6dOna+rUqVq+fLnXcRQUFOjss89WQkKCPvroI3388cdKSEjQuHHjVFJS4vU5HTp00JYtW7R582a/j8vu3bvdtx9++EG9e/fWWWed5d42atQoDRw4UGvXrtXSpUu1d+9eXXnllX7vHwCA+qJ2e0ftBgCEK2q3d9RuoJJQp/gAavfuu++aVq1ambi4ODNixAgzffp089VXX9X4nHfeece0adPG/fi1114zkswPP/zgbvvd735n4uPjPc6cjx071vzud79zP+7WrZsZN26cx74nTpxoxo8f736sSmfEX3nlFXPSSScZl8vl3l5cXGxatGhhli1b5nWsR48eNeeff777rPbEiRPNK6+8YoqKitx9qp4RL+dyucxll11m0tPTTUFBgTHGmJkzZ5qMjAyPfjk5OUaS+fbbb72OAQCAQKJ2U7sBAJGF2k3tBmrCTHQgAlx++eX65ZdftHjxYo0dO1arVq3SoEGDNG/ePHeflStX6rzzzlPnzp2VmJio66+/XgcOHNCxY8fcfeLj49WrVy/349TUVHXv3t1jzbPU1FTl5uZ6vP7w4cOrPd62bZvXsa5bt04//PCDEhMT3WfzW7duraKiIv34449en9OyZUv9+9//1g8//KD/9//+nxISEnT33Xdr6NChKigoqPHYzJgxQ5999pkWLVqkFi1auMewcuVK9+snJCTo5JNPliSfYwAAIJCo3b5RuwEA4Yja7Ru1G+DCokDEiIuL03nnnafzzjtP999/v2699VbNmjVLN954o3bu3Knzzz9fkyZN0p/+9Ce1bt1aH3/8sW655RaVlpa69xEdHe2xT5vN5rXN5XLVOh6bzea13eVyKT09XfPnz6+2rV27djXus1evXurVq5duvfVW3XfffTrxxBP19ttv66abbvLa/x//+IeeeuoprVq1Sl26dPEYw0UXXaTHH3+82nM6duxY4xgAAAgUand11G4AQDijdldH7QYshOhAhOrbt68WLVokSVq7dq3Kysr0xBNPyG63PmDyzjvvBOy1Pv/882qPy88wVzVo0CC9/fbbat++vZKSkur9mt27d1d8fLzHGf3KPvvsM91666168cUXdfrpp1cbw8KFC9W9e3dFRfFrDgAQHqjd1G4AQGShdlO7gXIs5wKEuQMHDuicc87RP/7xD3399dfavn27FixYoD//+c+65JJLJFlnksvKyvTss8/qp59+0t///nf99a9/DdgYPvnkE/35z3/Wd999p+eff14LFizQXXfd5bXvtddeq7Zt2+qSSy7RmjVrtH37dq1evVp33XWXfv75Z6/PeeCBB3TPPfdo1apV2r59uzZs2KCbb75ZpaWlOu+886r137Nnjy677DJdddVVGjt2rPbs2aM9e/Zo3759kqTbb79dBw8e1NVXX60vv/xSP/30kzIzM3XzzTfL6XQG7LgAAOANtZvaDQCILNRuajdQG0J0IMwlJCRo2LBheuqpp3TWWWepX79+mjlzpn7zm9/oueeekyQNHDhQTz75pB5//HH169dP8+fP1+zZswM2hrvvvlvr1q3Taaedpj/96U964oknNHbsWK994+Pj9dFHH6lr166aMGGC+vTpo5tvvlmFhYU+z5CPGjVKP/30k66//nqdfPLJGj9+vPbs2aPMzEyddNJJ1fp/88032rt3r15//XV17NjRfRsyZIgkqVOnTvrkk0/kdDo1duxY9evXT3fddZeSk5PdMwYAAAgWaje1GwAQWajd1G6gNjZjjAn1IACEr+7du2vKlCmaMmVKqIcCAAD8QO0GACCyULuB8MepIQAAAAAAAAAAfCBEBwAAAAAAAADAB5ZzAQAAAAAAAADAB2aiAwAAAAAAAADgAyE6AAAAAAAAAAA+EKIDAAAAAAAAAOADIToAAAAAAAAAAD4QogMAAAAAAAAA4AMhOgAAAAAAAAAAPhCiAwAAAAAAAADgAyE6AAAAAAAAAAA+EKIDAAAAAAAAAODD/wet1LN6VGgWOAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x400 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 3, figsize=(15, 4))\n",
    "for i, (nom_data, boost_data, loc_name) in enumerate([\n",
    "    (nom_cover_with_n_1, boost001_cover_with_n_1, \"0\"),\n",
    "    (nom_cover_with_n_2, boost001_cover_with_n_2, \"1\"),\n",
    "    (nom_cover_with_n_3, boost001_cover_with_n_3, \"-1\")\n",
    "]):\n",
    "    plt.sca(axes[i])\n",
    "    plot_coverage(nom_data, color='blue', marker='^', label='Naive' if i == 0 else None)\n",
    "    plot_coverage(boost_data, color='orange', marker='o', label='Boosted' if i == 0 else None)\n",
    "    axes[i].set_xlabel(\"Sample Size\")\n",
    "    axes[i].set_ylabel(\"Coverage\")\n",
    "    axes[i].set_ylim([0, 1])\n",
    "    axes[i].set_title(f\"$\\mu = ${loc_name}\")\n",
    "    if i == 0:\n",
    "        axes[i].legend()\n",
    "plt.tight_layout()\n",
    "#plt.savefig('coverage_sim.pdf')\n",
    "plt.show()\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
