{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import cvxpy as cp\n",
    "import mosek\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "import matplotlib.ticker as ticker\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": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rkhs import compute_adaptive_threshold, setup_full_cvx_dual\n",
    "from Synthetic_data_generation import generate_cqr_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 20/20 [1:09:24<00:00, 208.24s/it]\n"
     ]
    }
   ],
   "source": [
    "def run_interpolation_trial(alpha, radii, n_calib, gamma, eps = 0.00001):\n",
    "\n",
    "    x_train_final, y_train_final, x_calib, y_calib, x_test, y_test = generate_cqr_data(n_train = 2*n_calib)\n",
    "\n",
    "    reg = LinearRegression().fit(x_train_final, y_train_final)\n",
    "    scores_calib = np.abs(reg.predict(x_calib) - y_calib)\n",
    "        \n",
    "    prob = setup_full_cvx_dual(\n",
    "        x_calib, scores_calib, \"rbf\", gamma, alpha\n",
    "    )\n",
    "    K = pairwise_kernels(\n",
    "            X=x_calib,\n",
    "            metric=\"rbf\",\n",
    "            gamma=gamma\n",
    "        )\n",
    "    frac_interpolated = []\n",
    "    for radius in radii:\n",
    "        prob.param_dict['radius'].value = np.asarray([[radius]])\n",
    "        prob.solve(\n",
    "                solver='MOSEK', \n",
    "                verbose=False, \n",
    "                mosek_params={mosek.iparam.intpnt_solve_form: mosek.solveform.dual}\n",
    "        )\n",
    "        resids = (scores_calib -\n",
    "                    K @ prob.var_dict['weights'].value -\n",
    "                    prob.constraints[2].dual_value)\n",
    "        frac_interpolated.append(sum(np.abs(resids) < eps)/len(scores_calib))\n",
    "    return frac_interpolated\n",
    "\n",
    "num_radii=20\n",
    "radii = np.linspace(1,2000,num_radii)\n",
    "n_calibs = [250,500,750,1000,1500,2000]\n",
    "alpha = 0.9\n",
    "gamma = 2\n",
    "n_trials=20\n",
    "\n",
    "df = pd.DataFrame()\n",
    "for i in tqdm(range(n_trials)):\n",
    "    for n in n_calibs:\n",
    "        frac_interpolated = run_interpolation_trial(alpha,radii,n,gamma)\n",
    "        a_df = pd.DataFrame({'radius' : radii, 'frac_interpolated': frac_interpolated})\n",
    "        a_df['n_calib'] = n\n",
    "        df = pd.concat([df, a_df], axis=0)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "         radius  frac_interpolated  n_calib    lambda\n",
      "0      1.000000             0.0000      250  1.000000\n",
      "1    106.210526             0.0320      250  0.009415\n",
      "2    211.421053             0.0440      250  0.004730\n",
      "3    316.631579             0.0400      250  0.003158\n",
      "4    421.842105             0.0240      250  0.002371\n",
      "..          ...                ...      ...       ...\n",
      "15  1579.157895             0.0055     2000  0.000633\n",
      "16  1684.368421             0.0055     2000  0.000594\n",
      "17  1789.578947             0.0055     2000  0.000559\n",
      "18  1894.789474             0.0070     2000  0.000528\n",
      "19  2000.000000             0.0065     2000  0.000500\n",
      "\n",
      "[2400 rows x 4 columns]\n"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "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"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "\n",
    "df['lambda'] = 1/df['radius']\n",
    "melted_df = pd.melt(df[df['n_calib'] == 500], id_vars=['lambda'], value_vars=['frac_interpolated'])\n",
    "melted_df = melted_df.rename(columns={\"lambda\": \"Lambda\", \"value\": \"Fraction Interpolated\"})\n",
    "\n",
    "fig = sns.barplot(\n",
    "    melted_df, \n",
    "    x='Lambda', \n",
    "    y='Fraction Interpolated',\n",
    "    hue='variable',\n",
    "    palette=sns.color_palette(\"Set2\")\n",
    ")\n",
    "fig.legend_.remove()\n",
    "\n",
    "tick_locations = list(range(-1,num_radii,4))\n",
    "tick_locations[0] = 0\n",
    "tick_labels = [round(1/radii[num_radii - i - 1], 4) for i in tick_locations]\n",
    "\n",
    "\n",
    "fig.xaxis.set_major_locator(ticker.FixedLocator(tick_locations))\n",
    "fig.xaxis.set_major_formatter(ticker.FixedFormatter(tick_labels))\n",
    "\n",
    "plt.tight_layout()\n",
    "#fig.get_figure().savefig('interpolation.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
}
