{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics.pairwise import rbf_kernel, pairwise_kernels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rkhs import compute_shifted_coverage, compute_adaptive_threshold\n",
    "from Synthetic_data_generation import generate_cqr_data\n",
    "from rkhs import runCV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 40/40 [00:36<00:00,  1.09it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 40/40 [00:13<00:00,  2.87it/s]\n",
      "100%|███████████████████████████████████████████| 40/40 [00:39<00:00,  1.02it/s]\n",
      "100%|███████████████████████████████████████████| 40/40 [01:28<00:00,  2.21s/it]\n",
      "100%|███████████████████████████████████████████| 40/40 [02:28<00:00,  3.71s/it]\n",
      "100%|███████████████████████████████████████████| 40/40 [05:12<00:00,  7.82s/it]\n",
      "100%|███████████████████████████████████████████| 40/40 [12:13<00:00, 18.34s/it]\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "x and y must have same first dimension, but have shapes (4,) and (6,)",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Input \u001b[0;32mIn [25]\u001b[0m, in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     30\u001b[0m lossList \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m     31\u001b[0m lossList, radiiList, minRadius \u001b[38;5;241m=\u001b[39m run_one_cv_trial(alpha, gamma, k \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m5\u001b[39m,\n\u001b[1;32m     32\u001b[0m                                           n_train\u001b[38;5;241m=\u001b[39m[\u001b[38;5;241m250\u001b[39m,\u001b[38;5;241m500\u001b[39m,\u001b[38;5;241m750\u001b[39m,\u001b[38;5;241m1000\u001b[39m,\u001b[38;5;241m1500\u001b[39m,\u001b[38;5;241m2000\u001b[39m],\n\u001b[1;32m     33\u001b[0m                                           num_radii\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m40\u001b[39m,min_radius\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m10\u001b[39m,max_radius\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m10000\u001b[39m)\n\u001b[0;32m---> 35\u001b[0m \u001b[43mplt\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mplot\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m250\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m500\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m750\u001b[39;49m\u001b[43m,\u001b[49m\u001b[38;5;241;43m1000\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43mminRadius\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     36\u001b[0m plt\u001b[38;5;241m.\u001b[39mshow()\n",
      "File \u001b[0;32m/usr/local/lib/python3.9/site-packages/matplotlib/pyplot.py:2757\u001b[0m, in \u001b[0;36mplot\u001b[0;34m(scalex, scaley, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   2755\u001b[0m \u001b[38;5;129m@_copy_docstring_and_deprecators\u001b[39m(Axes\u001b[38;5;241m.\u001b[39mplot)\n\u001b[1;32m   2756\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mplot\u001b[39m(\u001b[38;5;241m*\u001b[39margs, scalex\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m, scaley\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m, data\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[0;32m-> 2757\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mgca\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mplot\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m   2758\u001b[0m \u001b[43m        \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mscalex\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mscalex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mscaley\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mscaley\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m   2759\u001b[0m \u001b[43m        \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m{\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mdata\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m:\u001b[49m\u001b[43m \u001b[49m\u001b[43mdata\u001b[49m\u001b[43m}\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mif\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mdata\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01mis\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;129;43;01mnot\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[38;5;28;43;01melse\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43m{\u001b[49m\u001b[43m}\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/usr/local/lib/python3.9/site-packages/matplotlib/axes/_axes.py:1632\u001b[0m, in \u001b[0;36mAxes.plot\u001b[0;34m(self, scalex, scaley, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1390\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m   1391\u001b[0m \u001b[38;5;124;03mPlot y versus x as lines and/or markers.\u001b[39;00m\n\u001b[1;32m   1392\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   1629\u001b[0m \u001b[38;5;124;03m(``'green'``) or hex strings (``'#008000'``).\u001b[39;00m\n\u001b[1;32m   1630\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m   1631\u001b[0m kwargs \u001b[38;5;241m=\u001b[39m cbook\u001b[38;5;241m.\u001b[39mnormalize_kwargs(kwargs, mlines\u001b[38;5;241m.\u001b[39mLine2D)\n\u001b[0;32m-> 1632\u001b[0m lines \u001b[38;5;241m=\u001b[39m [\u001b[38;5;241m*\u001b[39m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_get_lines(\u001b[38;5;241m*\u001b[39margs, data\u001b[38;5;241m=\u001b[39mdata, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)]\n\u001b[1;32m   1633\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m line \u001b[38;5;129;01min\u001b[39;00m lines:\n\u001b[1;32m   1634\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39madd_line(line)\n",
      "File \u001b[0;32m/usr/local/lib/python3.9/site-packages/matplotlib/axes/_base.py:312\u001b[0m, in \u001b[0;36m_process_plot_var_args.__call__\u001b[0;34m(self, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m    310\u001b[0m     this \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m args[\u001b[38;5;241m0\u001b[39m],\n\u001b[1;32m    311\u001b[0m     args \u001b[38;5;241m=\u001b[39m args[\u001b[38;5;241m1\u001b[39m:]\n\u001b[0;32m--> 312\u001b[0m \u001b[38;5;28;01myield from\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_plot_args\u001b[49m\u001b[43m(\u001b[49m\u001b[43mthis\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/usr/local/lib/python3.9/site-packages/matplotlib/axes/_base.py:498\u001b[0m, in \u001b[0;36m_process_plot_var_args._plot_args\u001b[0;34m(self, tup, kwargs, return_kwargs)\u001b[0m\n\u001b[1;32m    495\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39maxes\u001b[38;5;241m.\u001b[39myaxis\u001b[38;5;241m.\u001b[39mupdate_units(y)\n\u001b[1;32m    497\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m x\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m] \u001b[38;5;241m!=\u001b[39m y\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m]:\n\u001b[0;32m--> 498\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mx and y must have same first dimension, but \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    499\u001b[0m                      \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mhave shapes \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mx\u001b[38;5;241m.\u001b[39mshape\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m and \u001b[39m\u001b[38;5;132;01m{\u001b[39;00my\u001b[38;5;241m.\u001b[39mshape\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m    500\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m x\u001b[38;5;241m.\u001b[39mndim \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m2\u001b[39m \u001b[38;5;129;01mor\u001b[39;00m y\u001b[38;5;241m.\u001b[39mndim \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m2\u001b[39m:\n\u001b[1;32m    501\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mx and y can be no greater than 2D, but have \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    502\u001b[0m                      \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mshapes \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mx\u001b[38;5;241m.\u001b[39mshape\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m and \u001b[39m\u001b[38;5;132;01m{\u001b[39;00my\u001b[38;5;241m.\u001b[39mshape\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[0;31mValueError\u001b[0m: x and y must have same first dimension, but have shapes (4,) and (6,)"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def run_one_cv_trial(alpha, gamma, k = 5, n_train=[1000],\n",
    "                     num_radii=30,min_radius=1, max_radius=100):    \n",
    "    \n",
    "    x_train_final, y_train_final, x_calib, y_calib, _, _ = generate_cqr_data(n_train = 2*max(n_train),\n",
    "                                                                             n_test = 2)\n",
    "    reg = LinearRegression().fit(x_train_final, y_train_final)\n",
    "    scores_calib = np.abs(reg.predict(x_calib) - y_calib)\n",
    "    \n",
    "    lossList = []\n",
    "    radiiList = []\n",
    "    bestRadius = []\n",
    "    for i in range(len(n_train)):\n",
    "        allLosses, radii = runCV(x_calib[0:n_train[i],:],scores_calib[0:n_train[i]],\n",
    "                                   \"rbf\",gamma,alpha,k,num_radii=num_radii,\n",
    "                                   min_radius = min_radius,max_radius=max_radius)\n",
    "        lossList.append(allLosses)\n",
    "        radiiList.append(radii)\n",
    "        bestRadius.append(radii[np.argmin(allLosses)])\n",
    "    return lossList, radiiList, bestRadius\n",
    "\n",
    "alpha = 0.9\n",
    "gamma = 2\n",
    "allLosses, radii, bestRadius = run_one_cv_trial(alpha, gamma, k = 5,\n",
    "                                                n_train=[500],num_radii=40,\n",
    "                                                min_radius=10,max_radius=10000)\n",
    "plt.plot(radii[0],allLosses[0])\n",
    "plt.show()\n",
    "\n",
    "minLamb = []\n",
    "lossList = []\n",
    "lossList, radiiList, minRadius = run_one_cv_trial(alpha, gamma, k = 5,\n",
    "                                          n_train=[250,500,750,1000,1500,2000],\n",
    "                                          num_radii=40,min_radius=10,max_radius=10000)\n",
    "\n",
    "plt.plot([250,500,750,1000,1500,2000],minRadius)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[   10.           266.15384615   522.30769231   778.46153846\n",
      "  1034.61538462  1290.76923077  1546.92307692  1803.07692308\n",
      "  2059.23076923  2315.38461538  2571.53846154  2827.69230769\n",
      "  3083.84615385  3340.          3596.15384615  3852.30769231\n",
      "  4108.46153846  4364.61538462  4620.76923077  4876.92307692\n",
      "  5133.07692308  5389.23076923  5645.38461538  5901.53846154\n",
      "  6157.69230769  6413.84615385  6670.          6926.15384615\n",
      "  7182.30769231  7438.46153846  7694.61538462  7950.76923077\n",
      "  8206.92307692  8463.07692308  8719.23076923  8975.38461538\n",
      "  9231.53846154  9487.69230769  9743.84615385 10000.        ]\n"
     ]
    }
   ],
   "source": [
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:25<00:00,  4.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:57<00:00,  1.17s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 0: 0.9008719131077394, 0.9588328751681873\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:00<00:00,  3.04s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:27<00:00,  1.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 1: 0.9083875203134428, 0.8417414589466506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:23<00:00,  1.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 2: 0.9084531804112251, 0.9648315688501071\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:55<00:00,  2.76s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1473.9473684210527\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:30<00:00,  1.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 3: 0.9008312633597958, 0.9322793851751892\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:02<00:00,  3.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:37<00:00,  1.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 4: 0.9094078341011993, 0.9650365309193116\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:01<00:00,  3.08s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:40<00:00,  1.00s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 5: 0.9004424616967145, 0.9614348280315008\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:07<00:00,  3.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [02:01<00:00,  1.22s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 6: 0.9041297600693508, 0.9207766874878771\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:00<00:00,  3.02s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1158.3157894736842\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:54<00:00,  1.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 7: 0.9011184422626295, 0.8591445608652108\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:01<00:00,  3.09s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:28<00:00,  1.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 8: 0.9054340965012032, 0.9782321230693185\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:03<00:00,  3.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:29<00:00,  1.12it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 9: 0.9054896145393692, 0.878416325506897\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:04<00:00,  3.25s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "421.8421052631579\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:55<00:00,  1.16s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 10: 0.9031342545497976, 0.9783022860311069\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:07<00:00,  3.39s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "842.6842105263158\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:53<00:00,  1.14s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 11: 0.9016763992227642, 0.9692570120315173\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [01:03<00:00,  3.15s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:42<00:00,  1.03s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 12: 0.9075752994573507, 0.9791461880134619\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:48<00:00,  2.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:12<00:00,  1.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 13: 0.9129480306235946, 0.9161761614673235\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "632.2631578947369\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:39<00:00,  1.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 14: 0.9034903512605952, 0.8133588487699097\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:47<00:00,  2.35s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:10<00:00,  1.41it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 15: 0.9050220163944507, 0.9261570653121178\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:50<00:00,  2.55s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:22<00:00,  1.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 16: 0.9053032096918796, 0.9471211641244067\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:49<00:00,  2.45s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:41<00:00,  1.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 17: 0.9005154645971575, 0.9565060745916779\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:52<00:00,  2.63s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:14<00:00,  1.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 18: 0.9066759245002667, 0.8862807965581898\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:52<00:00,  2.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:27<00:00,  1.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 19: 0.9006746497973288, 0.8531084336404033\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:52<00:00,  2.62s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1684.3684210526317\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:32<00:00,  1.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 20: 0.9012227376411339, 0.8003024734761598\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:46<00:00,  2.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1894.7894736842106\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:12<00:00,  1.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 21: 0.9009561392318192, 0.9399734094612086\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [12:22<00:00, 37.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "316.63157894736844\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:13<00:00,  1.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 22: 0.9036065115017423, 0.9581380014127734\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:47<00:00,  2.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:13<00:00,  1.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 23: 0.9006200859417824, 0.95267371760127\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:47<00:00,  2.36s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:26<00:00,  1.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 24: 0.9056180507662557, 0.9178338596813441\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:55<00:00,  2.79s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:25<00:00,  1.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 25: 0.9069449158759137, 0.9660259006148817\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.70s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:31<00:00,  1.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 26: 0.9089542167828035, 0.8299830457519475\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:50<00:00,  2.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:31<00:00,  1.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 27: 0.9137667459782193, 0.8108207122736704\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:52<00:00,  2.65s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "842.6842105263158\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:32<00:00,  1.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 28: 0.9023570467184693, 0.805778233065077\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:48<00:00,  2.42s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:15<00:00,  1.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 29: 0.9060097603926072, 0.9044846890788696\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:49<00:00,  2.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:19<00:00,  1.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 0: 0.8997655980794944, 0.8898962322855869\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:51<00:00,  2.58s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "737.4736842105264\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:23<00:00,  1.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 1: 0.894093101626807, 0.9105660291310532\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:51<00:00,  2.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:32<00:00,  1.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 2: 0.8882729060977524, 0.8822945428019949\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:56<00:00,  2.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:17<00:00,  1.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 3: 0.899763684864257, 0.7700580894958913\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:57<00:00,  2.85s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1894.7894736842106\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:33<00:00,  1.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 4: 0.8994114767468492, 0.8991715567846972\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.73s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1894.7894736842106\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:16<00:00,  1.30it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 5: 0.8972749251653159, 0.9185598466915946\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:51<00:00,  2.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:19<00:00,  1.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 6: 0.8991548604168133, 0.8235301983344316\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:55<00:00,  2.77s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1894.7894736842106\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:34<00:00,  1.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 7: 0.898891839035804, 0.9068841122889609\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:49<00:00,  2.47s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "211.42105263157896\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:13<00:00,  1.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 8: 0.8891488750650034, 0.8923298926261921\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:56<00:00,  2.81s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:18<00:00,  1.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 9: 0.8824369044859643, 0.8890676352501073\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:51<00:00,  2.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:20<00:00,  1.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 10: 0.8998828205372257, 0.9193049947148774\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:53<00:00,  2.66s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:31<00:00,  1.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 11: 0.8867659156422505, 0.869433412403757\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:15<00:00,  1.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 12: 0.8863995642910967, 0.9203900039522847\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:45<00:00,  2.28s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:12<00:00,  1.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 13: 0.8877236715371271, 0.8845035033078651\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:51<00:00,  2.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:17<00:00,  1.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 14: 0.8845053851479655, 0.9677253381774755\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:46<00:00,  2.34s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:13<00:00,  1.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 15: 0.8907292282108286, 0.7421352573498662\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "316.63157894736844\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:14<00:00,  1.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 16: 0.894540550141014, 0.8244761343645838\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.72s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:30<00:00,  1.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 17: 0.887659636373401, 0.8789484939537364\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:56<00:00,  2.83s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1789.5789473684213\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:30<00:00,  1.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 18: 0.8976667061373609, 0.8286620122650289\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:49<00:00,  2.46s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:17<00:00,  1.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 19: 0.8992904291657884, 0.905932732561793\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:50<00:00,  2.54s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "316.63157894736844\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:32<00:00,  1.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 20: 0.895802907111068, 0.8625999747796398\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:57<00:00,  2.89s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "527.0526315789474\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:35<00:00,  1.05it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 21: 0.8937299956746166, 0.9245678814098506\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:56<00:00,  2.84s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:24<00:00,  1.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 22: 0.8876234406406749, 0.9992506928450797\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:56<00:00,  2.82s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "527.0526315789474\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:15<00:00,  1.32it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 23: 0.8978035334143135, 1.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:54<00:00,  2.74s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1789.5789473684213\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:30<00:00,  1.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 24: 0.8991708322619082, 0.8839471045614727\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:50<00:00,  2.53s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:30<00:00,  1.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 25: 0.8853697962749123, 0.9579689823385602\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:51<00:00,  2.56s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:17<00:00,  1.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 26: 0.8818504907089344, 0.9476188425355611\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:48<00:00,  2.44s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1789.5789473684213\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:41<00:00,  1.01s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 27: 0.8981063125437275, 0.9676309794667464\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:58<00:00,  2.91s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "106.21052631578948\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:50<00:00,  1.11s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 28: 0.8844766581592232, 0.8940945857572286\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 20/20 [00:52<00:00,  2.60s/it]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1368.7368421052633\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [01:16<00:00,  1.31it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trial 29: 0.8956667187121581, 0.9538200371588439\n",
      "    empirical coverage  estimated coverage  shift_loc\n",
      "0             0.958833            0.900872        3.5\n",
      "1             0.841741            0.908388        3.5\n",
      "2             0.964832            0.908453        3.5\n",
      "3             0.932279            0.900831        3.5\n",
      "4             0.965037            0.909408        3.5\n",
      "5             0.961435            0.900442        3.5\n",
      "6             0.920777            0.904130        3.5\n",
      "7             0.859145            0.901118        3.5\n",
      "8             0.978232            0.905434        3.5\n",
      "9             0.878416            0.905490        3.5\n",
      "10            0.978302            0.903134        3.5\n",
      "11            0.969257            0.901676        3.5\n",
      "12            0.979146            0.907575        3.5\n",
      "13            0.916176            0.912948        3.5\n",
      "14            0.813359            0.903490        3.5\n",
      "15            0.926157            0.905022        3.5\n",
      "16            0.947121            0.905303        3.5\n",
      "17            0.956506            0.900515        3.5\n",
      "18            0.886281            0.906676        3.5\n",
      "19            0.853108            0.900675        3.5\n",
      "20            0.800302            0.901223        3.5\n",
      "21            0.939973            0.900956        3.5\n",
      "22            0.958138            0.903607        3.5\n",
      "23            0.952674            0.900620        3.5\n",
      "24            0.917834            0.905618        3.5\n",
      "25            0.966026            0.906945        3.5\n",
      "26            0.829983            0.908954        3.5\n",
      "27            0.810821            0.913767        3.5\n",
      "28            0.805778            0.902357        3.5\n",
      "29            0.904485            0.906010        3.5\n",
      "0             0.889896            0.899766        4.5\n",
      "1             0.910566            0.894093        4.5\n",
      "2             0.882295            0.888273        4.5\n",
      "3             0.770058            0.899764        4.5\n",
      "4             0.899172            0.899411        4.5\n",
      "5             0.918560            0.897275        4.5\n",
      "6             0.823530            0.899155        4.5\n",
      "7             0.906884            0.898892        4.5\n",
      "8             0.892330            0.889149        4.5\n",
      "9             0.889068            0.882437        4.5\n",
      "10            0.919305            0.899883        4.5\n",
      "11            0.869433            0.886766        4.5\n",
      "12            0.920390            0.886400        4.5\n",
      "13            0.884504            0.887724        4.5\n",
      "14            0.967725            0.884505        4.5\n",
      "15            0.742135            0.890729        4.5\n",
      "16            0.824476            0.894541        4.5\n",
      "17            0.878948            0.887660        4.5\n",
      "18            0.828662            0.897667        4.5\n",
      "19            0.905933            0.899290        4.5\n",
      "20            0.862600            0.895803        4.5\n",
      "21            0.924568            0.893730        4.5\n",
      "22            0.999251            0.887623        4.5\n",
      "23            1.000000            0.897804        4.5\n",
      "24            0.883947            0.899171        4.5\n",
      "25            0.957969            0.885370        4.5\n",
      "26            0.947619            0.881850        4.5\n",
      "27            0.967631            0.898106        4.5\n",
      "28            0.894095            0.884477        4.5\n",
      "29            0.953820            0.895667        4.5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "x_train_final, y_train_final, x_calib, y_calib, x_test, y_test = generate_cqr_data()\n",
    "\n",
    "reg = LinearRegression().fit(x_train_final, y_train_final)\n",
    "\n",
    "def run_cv_synthetic_trial(reg, alpha, gamma, n_test, shift_loc, k = 5,\n",
    "                        num_radii=40,min_radius=1, max_radius=10000,n_train=2000):\n",
    "    _, _, x_calib, y_calib, x_test, y_test = generate_cqr_data(n_train=n_train,n_test=n_test)\n",
    "\n",
    "    scores_calib = np.abs(reg.predict(x_calib) - y_calib)\n",
    "    scores_test = np.abs(reg.predict(x_test) - y_test)\n",
    "    \n",
    "    allLosses, radii = runCV(x_calib,scores_calib,\"rbf\",gamma,alpha,k,\n",
    "                               num_radii=num_radii,min_radius=min_radius,max_radius=max_radius)\n",
    "    radius = radii[np.argmin(allLosses)]\n",
    "    print(radius)\n",
    "        \n",
    "    est_coverage, weighted_coverage, thresholds = compute_shifted_coverage(\n",
    "        scores_test,\n",
    "        scores_calib,\n",
    "        x_calib,\n",
    "        x_test[0:n_test,],\n",
    "        shift_loc,\n",
    "        kernel=\"rbf\",\n",
    "        alpha=alpha,\n",
    "        radius=radius,\n",
    "        gamma=gamma\n",
    "    )\n",
    "    \n",
    "    return est_coverage, weighted_coverage\n",
    "\n",
    "n_trials = 30\n",
    "alpha = 0.9\n",
    "n_test = 100\n",
    "n_train = 2000\n",
    "gamma = 2\n",
    "num_radii=20\n",
    "min_radius=1\n",
    "max_radius=2000\n",
    "shift_locs = [3.5, 4.5] #[0.5, 1.4, 2.5, 3.5, 4.5]\n",
    "\n",
    "df = pd.DataFrame()\n",
    "\n",
    "for shift_loc in shift_locs:\n",
    "    est_coverages = []\n",
    "    emp_coverages = []\n",
    "    for i in range(n_trials):\n",
    "        #try:\n",
    "        est_cov, emp_cov = run_cv_synthetic_trial(reg, alpha, gamma, n_test, shift_loc, k = 5,\n",
    "                        num_radii=num_radii,min_radius=min_radius,\n",
    "                                                  max_radius=max_radius,n_train=n_train)\n",
    "        est_coverages.append(est_cov)\n",
    "        emp_coverages.append(emp_cov)\n",
    "        print(f\"Trial {i}: {est_cov}, {emp_cov}\")\n",
    "        #except SolverError:\n",
    "        #    continue\n",
    "    a_df = pd.DataFrame({'empirical coverage' : emp_coverages, 'estimated coverage': est_coverages})\n",
    "    a_df['shift_loc'] = shift_loc\n",
    "    df = pd.concat([df, a_df], axis=0)\n",
    "\n",
    "print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaYAAAEYCAYAAAAXsVIGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAiUklEQVR4nO3de3QU5f0/8PcnVwgJ4ZIQriFA7gnXxFARpQgUbBW/GBTkksYDgrW2KhakSrHi8WtFsJ78BJTar4rQEkCsFINWLSBiRQMI5ApRQQgEEgi5QBKS7Of3x27osuaygQyZsO/XORx2Zp6Z+azL8b3PzOzziKqCiIjILNxauwAiIiJ7DCYiIjIVBhMREZkKg4mIiEyFwURERKbi0doFNFdAQICGhIS0dhlE5GDv3r1FqhrosK6bh4fHGwBiwS/C9F8WABk1NTWz4+LizjhubHPBFBISgvT09NYug4gciMgxx3UeHh5vdO/ePSowMLDYzc2Nv00hAIDFYpHCwsLogoKCNwBMdNzObzBEZKTYwMDAUoYS2XNzc9PAwMASWHvSP95+neshItfixlCi+tj+XdSbQQwmIiIylTZ3j4mI2q4ntq2Ja8njLb8jaW9LHq85hg4dGrl///6c5m5rzLx583r6+vrWLlmy5PS1V9h2scdERHQV6gue6urqBre1BRaLBbW1ta1dBoOJiG5sK1eu7DJw4MCoyMjI6GnTpvWtqakBAPj4+AydO3du79DQ0JgRI0aEb9++3SchISGid+/eA9etW+cPACkpKV3HjBkzICEhIaJv376xTzzxRI+64/r4+AwFgK1bt/rFxcVF3H777aFhYWGx9tsA4Omnn+4eHh4eHREREf3www/3AoDly5cHxMbGRkVERESPHz9+QFlZWaP/Lz5+/LjHuHHjBkRERERHREREf/zxxx0A4I9//GNQWFhYTFhYWMySJUu6AcDDDz/c64UXXrj82P68efN6Ll68OAgA/vCHPwTFxsZGhYeHRz/++OM9ASA3N9crJCQkdtKkSSHh4eEx3377rdf06dODY2Njo0JDQ2Pq2gFAamqqf79+/WJiYmKikpOT+4wePToUAEpLS93uvffekIEDB0ZFRUVFr127ttPVf2IMJiK6ge3bt6/dpk2buqSnp+fk5ORkubm56WuvvdYVACoqKtzGjBlTmpeXl9mhQ4faRYsW9dq1a9fhjRs35j333HO96o5x8ODBDlu2bMnLzMzM3LJlS5fPPvvMx/E8WVlZPitXrvzh6NGjGfbrN2zY0DEtLa3T3r17c3Jzc7OeeeaZAgCYPn16cUZGRnZubm5WRERERUpKSkBj7+Ohhx4KvvXWW8tyc3OzMjMzs4YNG1a5a9cun7/97W9d9+7dm52enp69Zs2awN27d7efPn36uc2bN3ep2/f999/vnJSUdG7z5s0d8/Ly2h08eDA7Ozs765tvvvHZtm2bLwD88MMP3o888khhXl5eZnh4+KWXX345PyMjIzsnJydz9+7dfnv27Gl/8eJFefTRR/tu27btSGZmZvbZs2cv3wp66qmneowePbr00KFD2bt27cpdtGhR79LS0qvOF95jIqIb1ocffuiXkZHhM3jw4CgAqKysdOvWrVsNAHh6eurkyZNLASAmJqbC29vb4u3trQkJCRX5+fledccYOXJkaffu3WsB4Be/+EXxjh07fG+77baL9ucZNGjQhcjIyEuO5//44487zpgxo8jPz88CAEFBQbUAsHfv3vaLFy/uVVZW5n7hwgX3UaNGlTT2Pr744gu/TZs2fQ8AHh4e6Nq1a+2OHTt8f/7zn5/v2LGjpa627du3+y1atOjM2bNnPY4ePep56tQpD39//9rQ0NDqpUuXBn322Wcdo6OjowHg4sWLbjk5Oe369+9/qUePHpfGjBlzoe58b7/9dpe33noroKamRgoLCz0PHDjQrra2Fn369Kmqe59Tp04998YbbwQCwI4dOzp+9NFHnVJSUroDQFVVleTl5XkNGzassjmfVx0GExHdsFRV7r333rMrVqzId9zm4eGhbm7WL/Vubm7w9vZWAHB3d0dtba3UtRORK/ZzXAYAHx8fS3PqmjNnTr9Nmzbl3XzzzRUpKSldd+7c6dec/ZsyceLE4rVr13YuKCjwvOeee84BgKriscceOzV//vwi+7a5uble9vXn5OR4vfrqq0F79+7NDgwMrE1MTAyprKxstPejqti0aVPe4MGDq1qifl7Ku0oLFixAUlISFixY0NqlEFEDJkyYULp169bO+fn5HgBw+vRp98OHD3s1tZ+9zz//vOPp06fdy8vLJS0trdOoUaPKnd13/PjxpWvXrg2ou4d0+vRpd8DaWwkODq6uqqqS9evXd2n8KMAtt9xS9tJLLwUCQE1NDc6ePes+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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "\n",
    "melted_df = pd.melt(df, id_vars=['shift_loc'], value_vars=['empirical coverage', 'estimated coverage'])\n",
    "melted_df = melted_df.rename(columns={\"shift_loc\": \"Shift Location\", \"value\": \"Coverage\"})\n",
    "\n",
    "fig = sns.barplot(\n",
    "    melted_df, \n",
    "    x='Shift Location', \n",
    "    y='Coverage',\n",
    "    hue='variable',\n",
    "    palette=sns.color_palette(\"Set2\")\n",
    ")\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",
    "\n",
    "fig.get_figure().savefig('synthetic_rkhs_coverage.png')\n"
   ]
  }
 ],
 "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
}
