{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "# from gurobipy import *\n",
    "\n",
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "\n",
    "import time\n",
    "import pickle\n",
    "import random\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "from timeParamCPScores.code.gurobipyTutorial import optimzeTimeAlphasKKT, optimzeTimeAlphasKKTNoMaxLowerBound, optimzeTimeAlphasKKTNoMaxLowerBoundMinArea\n",
    "\n",
    "\n",
    "PLOT_VALIDATION_TRACES = False\n",
    "NUM_VALID_TO_PLOT = 100\n",
    "\n",
    "def computeRValuesIndiv(x_vals,y_vals,x_hats,y_hats):\n",
    "\n",
    "    R_vals = [ [math.sqrt((x_vals[i][j]-x_hats[i][j])**2 + (y_vals[i][j]-y_hats[i][j])**2) for j in range(len(x_vals[i]))]  for i in range(len(x_vals))  ]\n",
    "\n",
    "    return R_vals\n",
    "\n",
    "\n",
    "\n",
    "def computeCPCirlce(x_vals,y_vals,x_hats,y_hats,delta):\n",
    "\n",
    "    R_vals = [ math.sqrt((x_vals[i]-x_hats[i])**2 + (y_vals[i]-y_hats[i])**2) for i in range(len(x_vals))]\n",
    "\n",
    "    R_vals.sort()\n",
    "    R_vals.append(max(R_vals))\n",
    "\n",
    "    ind_to_ret = math.ceil(len(R_vals)*(1-delta))\n",
    "    return(R_vals[ind_to_ret])\n",
    "\n",
    "\n",
    "\n",
    "def computeCPFixedAlphas(x_vals,y_vals,x_hats,y_hats,alphas,delta):\n",
    "\n",
    "    R_vals = [max([alphas[j]*math.sqrt((x_vals[i][j]-x_hats[i][j])**2 + (y_vals[i][j]-y_hats[i][j])**2) for j in range(len(x_vals[i])) ]) for i in range(len(x_vals))]\n",
    "    \n",
    "    R_vals.sort()\n",
    "    R_vals.append(max(R_vals))\n",
    "\n",
    "    ind_to_ret = math.ceil(len(R_vals)*(1-delta))\n",
    "    return R_vals[ind_to_ret]\n",
    "\n",
    "\n",
    "\n",
    "def computeCoverageRAndAlphas(x_vals,y_vals,x_hats,y_hats,alphas,D_cp):\n",
    "\n",
    "    R_vals = [max([alphas[j]*math.sqrt((x_vals[i][j]-x_hats[i][j])**2 + (y_vals[i][j]-y_hats[i][j])**2) for j in range(len(x_vals[i])) ]) for i in range(len(x_vals))]\n",
    "\n",
    "    num_points_within = sum(r <= D_cp for r in R_vals)\n",
    "    coverage_pct = float(num_points_within)/len(R_vals)\n",
    "    return coverage_pct\n",
    "\n",
    "\n",
    "def computeCoverageCircle(x_vals,y_vals,x_hats,y_hats,Ds_cp):\n",
    "    coverage_count = 0\n",
    "    for i in range(len(x_vals)):\n",
    "\n",
    "        temp = sum([1 if math.sqrt((x_vals[i][j]-x_hats[i][j])**2 + (y_vals[i][j]-y_hats[i][j])**2) > Ds_cp[j] else 0 for j in range(len(x_vals[i]))])\n",
    "        if temp == 0:\n",
    "            coverage_count += 1\n",
    "        \n",
    "\n",
    "    coverage_pct = float(coverage_count)/len(x_vals)\n",
    "    return coverage_pct\n",
    "\n",
    "\n",
    "def plot_circle(x, y, size, color=\"-b\", label=None):  # pragma: no cover\n",
    "    deg = list(range(0, 360, 5))\n",
    "    deg.append(0)\n",
    "    xl = [x + size * math.cos(np.deg2rad(d)) for d in deg]\n",
    "    yl = [y + size * math.sin(np.deg2rad(d)) for d in deg]\n",
    "\n",
    "    if label is None:\n",
    "        plt.plot(xl, yl, color)\n",
    "    else:\n",
    "        plt.plot(xl, yl, color,label=label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x20\n",
      "y20\n",
      "x_LSTM20\n",
      "y_LSTM20\n",
      "x20\n",
      "y20\n",
      "x_LSTM20\n",
      "y_LSTM20\n",
      "Num calibration data: 968\n",
      "Num validation data: 323\n",
      "Num data calib: 968\n",
      "Num data valid: 323\n",
      "Set parameter Username\n",
      "Set parameter LicenseID to value 2615263\n",
      "Academic license - for non-commercial use only - expires 2026-01-26\n",
      "Set parameter NonConvex to value 2\n",
      "Gurobi Optimizer version 10.0.3 build v10.0.3rc0 (linux64)\n",
      "\n",
      "CPU model: 13th Gen Intel(R) Core(TM) i7-1360P, instruction set [SSE2|AVX|AVX2]\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "\n",
      "Optimize a model with 1372 rows, 321 columns and 2632 nonzeros\n",
      "Model fingerprint: 0x2969881b\n",
      "Model has 100 quadratic constraints\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-02, 1e+00]\n",
      "  QMatrix range    [1e+00, 1e+00]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [0e+00, 0e+00]\n",
      "  RHS range        [1e-01, 1e+00]\n",
      "Presolve removed 278 rows and 0 columns\n",
      "\n",
      "Continuous model is non-convex -- solving as a MIP\n",
      "\n",
      "Presolve removed 328 rows and 50 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 1044 rows, 271 columns, 2254 nonzeros\n",
      "Presolved model has 100 SOS constraint(s)\n",
      "Variable types: 271 continuous, 0 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 0.000000e+00, 79 iterations, 0.00 seconds (0.00 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0    0.00000    0   32          -    0.00000      -     -    0s\n",
      "H    0     0                       0.0083941    0.00000   100%     -    0s\n",
      "     0     0    0.00000    0   32    0.00839    0.00000   100%     -    0s\n",
      "H    0     0                       0.0083940    0.00000   100%     -    0s\n",
      "     0     2    0.00000    0   32    0.00839    0.00000   100%     -    0s\n",
      "*    8     4               3       0.0080379    0.00000   100%  25.0    0s\n",
      "*   10     4               3       0.0054968    0.00000   100%  28.3    0s\n",
      "*   21    14               5       0.0029893    0.00115  61.4%  39.0    0s\n",
      "*   36    24               7       0.0029598    0.00115  61.0%  30.2    0s\n",
      "*   38    24               6       0.0027419    0.00115  57.9%  30.5    0s\n",
      "*   40    24               7       0.0027048    0.00115  57.3%  29.9    0s\n",
      "*   51     8               7       0.0026993    0.00115  57.2%  24.2    0s\n",
      "*   54     8               8       0.0026737    0.00115  56.8%  22.9    0s\n",
      "\n",
      "Explored 64 nodes (1327 simplex iterations) in 0.15 seconds (0.05 work units)\n",
      "Thread count was 16 (of 16 available processors)\n",
      "\n",
      "Solution count 10: 0.0026737 0.00269934 0.00270479 ... 0.00839406\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 2.673695580391e-03, best bound 2.673695580391e-03, gap 0.0000%\n",
      "Gurobi Optimizer version 10.0.3 build v10.0.3rc0 (linux64)\n",
      "\n",
      "CPU model: 13th Gen Intel(R) Core(TM) i7-1360P, instruction set [SSE2|AVX|AVX2]\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "\n",
      "Optimize a model with 2422 rows, 1321 columns and 6574 nonzeros\n",
      "Model fingerprint: 0x929a1c2d\n",
      "Model has 100 quadratic constraints\n",
      "Variable types: 321 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-02, 1e+05]\n",
      "  QMatrix range    [1e+00, 1e+00]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e-01, 1e+05]\n",
      "Presolve removed 362 rows and 84 columns\n",
      "Presolve time: 0.03s\n",
      "Presolved: 2060 rows, 1237 columns, 6094 nonzeros\n",
      "Presolved model has 100 SOS constraint(s)\n",
      "Variable types: 271 continuous, 966 integer (966 binary)\n",
      "\n",
      "Root relaxation: objective 0.000000e+00, 92 iterations, 0.00 seconds (0.00 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0    0.00000    0   32          -    0.00000      -     -    0s\n",
      "H    0     0                       0.0141421    0.00000   100%     -    0s\n",
      "     0     0    0.00000    0   32    0.01414    0.00000   100%     -    0s\n",
      "     0     2    0.00000    0   32    0.01414    0.00000   100%     -    0s\n",
      "*    4     4               2       0.0080379    0.00000   100%  73.5    0s\n",
      "*    6     4               2       0.0054968    0.00000   100%  49.3    0s\n",
      "*   18    14               5       0.0029893    0.00115  61.4%  61.6    0s\n",
      "*   42    33               8       0.0029598    0.00160  46.1%  49.8    0s\n",
      "*   46    30               8       0.0027694    0.00160  42.4%  50.1    0s\n",
      "*   58    30              10       0.0027424    0.00160  41.8%  44.6    0s\n",
      "*   63    14               9       0.0026836    0.00160  40.5%  41.5    0s\n",
      "*   86     0               9       0.0026737    0.00267  0.00%  33.8    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 146\n",
      "\n",
      "Explored 90 nodes (2997 simplex iterations) in 0.34 seconds (0.15 work units)\n",
      "Thread count was 16 (of 16 available processors)\n",
      "\n",
      "Solution count 9: 0.0026737 0.00268358 0.00274237 ... 0.0141421\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 2.673695580391e-03, best bound 2.673695580391e-03, gap 0.0000%\n",
      "q 0.0026736955803909413\n",
      "alphas[0] 0.18905882757229345\n",
      "alphas[1] 0.18905882757229345\n",
      "alphas[2] 0.11957130137789784\n",
      "alphas[3] 0.08454967803961215\n",
      "alphas[4] 0.0597856506889492\n",
      "alphas[5] 0.04964928049831844\n",
      "alphas[6] 0.04227483901980598\n",
      "alphas[7] 0.03672603327496173\n",
      "alphas[8] 0.035107342921393975\n",
      "alphas[9] 0.027147265542846508\n",
      "alphas[10] 0.02482464024915924\n",
      "alphas[11] 0.022127662066616687\n",
      "alphas[12] 0.01919601555601865\n",
      "alphas[13] 0.017985222763571663\n",
      "alphas[14] 0.01615238570953418\n",
      "alphas[15] 0.015309536357942041\n",
      "alphas[16] 0.014542986736330284\n",
      "alphas[17] 0.013302132688945343\n",
      "alphas[18] 0.012103251203063922\n",
      "alphas[19] 0.011527120160445395\n",
      "Obj: 0.0026736955803909413\n",
      "Solve time: 0.21608996391296387\n",
      "Solve time MILP: 0.49843907356262207\n",
      "obj: 0.0026736955803909413\n",
      "obj MILP: 0.0026736955803909413\n",
      "alphas: [0.18905882757229345, 0.18905882757229345, 0.11957130137789784, 0.08454967803961215, 0.0597856506889492, 0.04964928049831844, 0.04227483901980598, 0.03672603327496173, 0.035107342921393975, 0.027147265542846508, 0.02482464024915924, 0.022127662066616687, 0.01919601555601865, 0.017985222763571663, 0.01615238570953418, 0.015309536357942041, 0.014542986736330284, 0.013302132688945343, 0.012103251203063922, 0.011527120160445395]\n",
      "alphas MILP: [0.18905882757229345, 0.18905882757229345, 0.11957130137789784, 0.08454967803961215, 0.0597856506889492, 0.04964928049831844, 0.04227483901980598, 0.03672603327496173, 0.035107342921393975, 0.027147265542846508, 0.02482464024915924, 0.022127662066616687, 0.01919601555601865, 0.017985222763571663, 0.01615238570953418, 0.015309536357942041, 0.014542986736330284, 0.013302132688945343, 0.012103251203063922, 0.011527120160445395]\n"
     ]
    }
   ],
   "source": [
    "save_path = \"timeParamCPScores/code/data/\"\n",
    "\n",
    "fid = open(save_path + \"d_value.pkl\", 'rb')\n",
    "d_value = pickle.load(fid)\n",
    "fid.close()\n",
    "\n",
    "fid = open(save_path + \"x_value.pkl\", 'rb')\n",
    "x_value = pickle.load(fid)\n",
    "fid.close()\n",
    "\n",
    "fid = open(save_path + \"y_value.pkl\", 'rb')\n",
    "y_value = pickle.load(fid)\n",
    "fid.close()\n",
    "\n",
    "fid = open(save_path + \"x_l_value.pkl\", 'rb')\n",
    "x_l_value = pickle.load(fid)\n",
    "fid.close()\n",
    "\n",
    "fid = open(save_path + \"y_l_value.pkl\", 'rb')\n",
    "y_l_value = pickle.load(fid)\n",
    "fid.close()\n",
    "\n",
    "\n",
    "\n",
    "p_len = 20\n",
    "delta = 0.05\n",
    "\n",
    "\n",
    "\n",
    "dict_keys_x = list(x_value.keys())\n",
    "dict_key_x = dict_keys_x[0]\n",
    "print(dict_key_x)\n",
    "\n",
    "dict_keys_y = list(y_value.keys())\n",
    "dict_key_y = dict_keys_y[0]\n",
    "print(dict_key_y)\n",
    "\n",
    "dict_keys_x_l = list(x_l_value.keys())\n",
    "dict_key_x_l = dict_keys_x_l[0]\n",
    "print(dict_key_x_l)\n",
    "\n",
    "dict_keys_y_l = list(y_l_value.keys())\n",
    "dict_key_y_l = dict_keys_y_l[0]\n",
    "print(dict_key_y_l)\n",
    "\n",
    "\n",
    "p_len = 20\n",
    "delta = 0.1\n",
    "calib_percent = 0.75\n",
    "trace_for_alphas = 50\n",
    "makePlots = True\n",
    "\n",
    "random.seed(34956)\n",
    "\n",
    "dict_keys_x = list(x_value.keys())\n",
    "dict_key_x = dict_keys_x[0]\n",
    "print(dict_key_x)\n",
    "\n",
    "dict_keys_y = list(y_value.keys())\n",
    "dict_key_y = dict_keys_y[0]\n",
    "print(dict_key_y)\n",
    "\n",
    "dict_keys_x_l = list(x_l_value.keys())\n",
    "dict_key_x_l = dict_keys_x_l[0]\n",
    "print(dict_key_x_l)\n",
    "\n",
    "dict_keys_y_l = list(y_l_value.keys())\n",
    "dict_key_y_l = dict_keys_y_l[0]\n",
    "print(dict_key_y_l)\n",
    "\n",
    "\n",
    "keys_x = list(x_value[dict_key_x].keys())\n",
    "\n",
    "all_x = []\n",
    "all_y = []\n",
    "all_x_l = []\n",
    "all_y_l = []\n",
    "\n",
    "all_x_err = []\n",
    "all_y_err = []\n",
    "\n",
    "\n",
    "for k in keys_x:\n",
    "\n",
    "    final_key = list(x_value[dict_key_x][k].keys())[0]\n",
    "\n",
    "    x = x_value[dict_key_x][k][final_key]\n",
    "    y = y_value[dict_key_y][k][final_key]\n",
    "    x_l = x_l_value[dict_key_x_l][k][final_key]\n",
    "    y_l = y_l_value[dict_key_y_l][k][final_key]\n",
    "\n",
    "    all_x.append(x[p_len:2*p_len])\n",
    "    all_y.append(y[p_len:2*p_len])\n",
    "\n",
    "    all_x_l.append(x_l[0:p_len])\n",
    "    all_y_l.append(y_l[0:p_len])\n",
    "\n",
    "\n",
    "## create train/test split\n",
    "temp = list(zip(all_x, all_y, all_x_l,all_y_l))\n",
    "random.shuffle(temp)\n",
    "\n",
    "res1,res2,res3,res4 = zip(*temp)\n",
    "all_x,all_y,all_x_l,all_y_l = list(res1),list(res2),list(res3),list(res4)\n",
    "\n",
    "calib_ind = round(len(all_x)*calib_percent)\n",
    "\n",
    "print(\"Num calibration data: \" + str(calib_ind))\n",
    "print(\"Num validation data: \" + str(len(all_x)-calib_ind))\n",
    "\n",
    "all_x_calib = all_x[0:calib_ind]\n",
    "all_y_calib = all_y[0:calib_ind]\n",
    "all_x_l_calib = all_x_l[0:calib_ind]\n",
    "all_y_l_calib = all_y_l[0:calib_ind]\n",
    "\n",
    "\n",
    "all_x_calib_alphas = all_x_calib[0:trace_for_alphas]\n",
    "all_y_calib_alphas = all_y_calib[0:trace_for_alphas]\n",
    "all_x_l_calib_alphas = all_x_l_calib[0:trace_for_alphas]\n",
    "all_y_l_calib_alphas = all_y_l_calib[0:trace_for_alphas]\n",
    "\n",
    "\n",
    "all_x_calib_CP = all_x_calib[trace_for_alphas:]\n",
    "all_y_calib_CP = all_y_calib[trace_for_alphas:]\n",
    "all_x_l_calib_CP = all_x_l_calib[trace_for_alphas:]\n",
    "all_y_l_calib_CP = all_y_l_calib[trace_for_alphas:]\n",
    "\n",
    "\n",
    "all_x_valid = all_x[calib_ind:]\n",
    "all_y_valid = all_y[calib_ind:]\n",
    "all_x_l_valid = all_x_l[calib_ind:]\n",
    "all_y_l_valid = all_y_l[calib_ind:]\n",
    "\n",
    "\n",
    "print(\"Num data calib: \" + str(len(all_x_calib)))\n",
    "print(\"Num data valid: \" + str(len(all_x_valid)))\n",
    "\n",
    "\n",
    "## compute R values of data\n",
    "R_vals_calib_alpha = computeRValuesIndiv(all_x_calib_alphas,all_y_calib_alphas,all_x_l_calib_alphas,all_y_l_calib_alphas)\n",
    "\n",
    "## run optimziation\n",
    "M = 100000 #big value for linearization of max constraint\n",
    "\n",
    "\n",
    "# optimzeTimeAlphasMinArgminHeuristic(fake_R_vals,delta,M)\n",
    "\n",
    "\n",
    "start_time = time.time()\n",
    "m = optimzeTimeAlphasKKTNoMaxLowerBound(R_vals_calib_alpha,delta,M)\n",
    "# m_min_area = optimzeTimeAlphasKKTNoMaxLowerBoundMinArea(R_vals_calib_alpha,delta,M)\n",
    "end_time = time.time()\n",
    "\n",
    "\n",
    "start_time_milp = time.time()\n",
    "m_milp = optimzeTimeAlphasKKT(R_vals_calib_alpha,delta,M)\n",
    "end_time_milp = time.time()\n",
    "\n",
    "# start_time_min_area = time.time()\n",
    "# m_min_area = optimzeTimeAlphasKKTNoMaxLowerBoundMinArea(R_vals_calib_alpha,delta,M)\n",
    "# end_time_min_area = time.time()\n",
    "\n",
    "\n",
    "print(\"Solve time: \" + str(end_time-start_time))\n",
    "print(\"Solve time MILP: \" + str(end_time_milp-start_time_milp))\n",
    "# print(\"Solve time min area: \" + str(end_time_min_area-start_time_min_area))\n",
    "\n",
    "alphas = []    \n",
    "for v in m.getVars():\n",
    "    if \"alphas\" in v.varName:\n",
    "        alphas.append(v.x)\n",
    "    if \"q\" in v.varName:\n",
    "        # print(v.x)\n",
    "        print(\"obj: \" + str(v.x))\n",
    "\n",
    "alphas_milp = []    \n",
    "for v in m_milp.getVars():\n",
    "    if \"alphas\" in v.varName:\n",
    "        alphas_milp.append(v.x)\n",
    "    if \"q\" in v.varName:\n",
    "        # print(v.x)\n",
    "        print(\"obj MILP: \" + str(v.x))\n",
    "\n",
    "\n",
    "print(\"alphas: \" + str(alphas))\n",
    "print(\"alphas MILP: \" + str(alphas_milp))\n",
    "\n",
    "# plt.plot(alphas,'k*')\n",
    "# plt.xlabel(\"Prediction Horizon\",fontsize=\"16\")\n",
    "# plt.ylabel(\"Alpha Value\",fontsize=\"16\")\n",
    "\n",
    "# plt.savefig('images/forPaper/alphas.png')\n",
    "\n",
    "D_cp = computeCPFixedAlphas(all_x_calib_CP,all_y_calib_CP,all_x_l_calib_CP,all_y_l_calib_CP,alphas,delta)\n",
    "validation_coverage_alphas_method = computeCoverageRAndAlphas(all_x_valid,all_y_valid,all_x_l_valid,all_y_l_valid,alphas,D_cp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from agents.all_paths_conformal_pred import all_paths_conformal_pred\n",
    "from agents.bucketed_conformal_pred import bucketed_conformal_pred\n",
    "from agents.ORCALSTM_nonconfirmity_score_graph import ORCALSTMNonConformityScoreGraph\n",
    "\n",
    "adj_list = [[i+1] for i in range(p_len)] + [[p_len]]\n",
    "terminal_vertices = [i for i in range(len(adj_list)) if i in adj_list[i]]\n",
    "\n",
    "data = dict()\n",
    "data[\"x\"] = all_x_calib\n",
    "data[\"y\"] = all_y_calib\n",
    "data[\"xh\"] = all_x_l_calib\n",
    "data[\"yh\"] = all_y_l_calib\n",
    "\n",
    "score_graph = ORCALSTMNonConformityScoreGraph(adj_list, data)\n",
    "\n",
    "total_buckets = 20\n",
    "vbs = bucketed_conformal_pred(score_graph, delta, total_buckets, len(all_x_calib))\n",
    "vb = vbs.buckets[(terminal_vertices[0], total_buckets)]\n",
    "\n",
    "path_score_quantiles = vb.path_score_quantiles\n",
    "\n",
    "validation_coverage_bucketed_conf_pred = computeCoverageCircle(all_x_valid,all_y_valid,all_x_l_valid,all_y_l_valid,path_score_quantiles)\n",
    "\n",
    "min_path, min_path_scores = all_paths_conformal_pred(score_graph, delta, len(all_x_calib))\n",
    "all_paths_quantiles = [max(min_path_scores) for _ in range(p_len)]\n",
    "\n",
    "validation_coverage_all_paths_pred = computeCoverageCircle(all_x_valid,all_y_valid,all_x_l_valid,all_y_l_valid,all_paths_quantiles)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation coverage alphas method: 0.9009287925696594\n",
      "Validation coverage bucketed conf pred: 0.9907120743034056\n",
      "Validation coverage all paths conf pred: 0.9040247678018576\n"
     ]
    }
   ],
   "source": [
    "print(\"Validation coverage alphas method: \" + str(validation_coverage_alphas_method))\n",
    "print(\"Validation coverage bucketed conf pred: \" + str(validation_coverage_bucketed_conf_pred))\n",
    "print(\"Validation coverage all paths conf pred: \" + str(validation_coverage_all_paths_pred))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2]\n"
     ]
    }
   ],
   "source": [
    "print(vb.path_buckets)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.7.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
