{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7d607888-e92d-4720-b28e-43d8ce2c643a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c9bb7deb-4dbb-4100-a5c6-1ab11c826833",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f37c6eff-445d-4007-9951-fdba0c6b46d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7499a23a-7876-4670-ae09-c4de570791e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_clip.pkl\", 'rb') as handle:\n",
    "    scores_list = pickle.load(handle)\n",
    "scores_list[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3094d577-6791-4900-953b-d0d27e3d3d14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "17304aaf-68b6-4349-b923-b458ddca5939",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "my_list = [\n",
    "    0,1,2,3,\n",
    "    4,5,6,7,\n",
    "    8,9,10,11,\n",
    "    12,13,14,15,\n",
    "    16,17,18,19,\n",
    "    20,21,22,23,\n",
    "    24,25,26,27,\n",
    "    28,29,30,31,\n",
    "    32,33,34,35,\n",
    "    36,37,38,39,\n",
    "    40,41,42,43,\n",
    "    44,45,46,47,\n",
    "    48,49,50,51,\n",
    "    52,53,54,55,\n",
    "    56,57,58,59,\n",
    "    60,61,62,63,\n",
    "          ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-val.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4214c4b5-d74f-4e52-8c45-1f20ea8d4b38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8d0f643-d0aa-433d-8586-e75351bdd70f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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F198Md/5zne49NJLuffee3nuuef44Q9/OLRnIiIiIselQYeRefPmsWvXLm644QZaWlqYOnUqS5cuLU5S3bp1K/Z+Gyydf/753HPPPfzzP/8zX/3qVzn11FP55S9/ecR7jIiIiMiJTdvBi4iIyLA40u/vY2ePaBERESlJCiMiIiISKIURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigjsm79r7Zvn3ZUqlUwJWIiIjIkdr3vf1W+6seF2Gkq6sLgKampoArERERkcHq6uqisrLykM8fF9vBe57Hjh07KC8vx7KsIXvfVCpFU1MT27Zt0zbzw0zXemToOo8MXeeRoes8cobrWhtj6OrqYuzYsQPuW/dmx0XPiG3bjBs3btjev6KiQv+ijxBd65Gh6zwydJ1Hhq7zyBmOa324HpF9NIFVREREAqUwIiIiIoEq6TASjUa58cYbiUajQZdywtO1Hhm6ziND13lk6DqPnKCv9XExgVVEREROXCXdMyIiIiLBUxgRERGRQCmMiIiISKAURkRERCRQCiMiIiISqJIOI7fffjvNzc3EYjFmzZrFihUrgi7puLFo0SLOPfdcysvLqaur4yMf+Qjr168f0CadTnPVVVcxatQokskkH/vYx2htbR3QZuvWrVx66aUkEgnq6ur48pe/TD6fH8lTOa7cdNNNWJbFF7/4xeIxXeehs337dj71qU8xatQo4vE4Z599Ns8991zxeWMMN9xwA2PGjCEejzNnzhxeffXVAe+xZ88eLrvsMioqKqiqquJv/uZv6O7uHulTOWa5rsv111/PSSedRDweZ+LEiXzjG98YcCM1Xeej88c//pEPfvCDjB07Fsuy+OUvfzng+aG6ri+++CIXXnghsViMpqYm/u3f/u3tF29K1L333msikYi58847zUsvvWSuvPJKU1VVZVpbW4Mu7bgwd+5cc9ddd5m1a9ea1atXm0suucSMHz/edHd3F9t87nOfM01NTWbZsmXmueeeM+edd545//zzi8/n83kzefJkM2fOHPP888+bhx9+2NTW1pqFCxcGcUrHvBUrVpjm5mbzjne8w1xzzTXF47rOQ2PPnj1mwoQJ5jOf+Yx55plnzOuvv24eeeQRs3HjxmKbm266yVRWVppf/vKX5oUXXjAf+tCHzEknnWT6+vqKbd7//vebKVOmmKeffto8+eST5pRTTjGf/OQngzilY9I3v/lNM2rUKPPQQw+ZTZs2mfvvv98kk0nz7//+78U2us5H5+GHHzbXXXedeeCBBwxgfvGLXwx4fiiua2dnp6mvrzeXXXaZWbt2rfnZz35m4vG4+cEPfvC2ai/ZMDJz5kxz1VVXFX93XdeMHTvWLFq0KMCqjl9tbW0GMH/4wx+MMcZ0dHSYcDhs7r///mKbdevWGcAsX77cGOP/D8e2bdPS0lJs8/3vf99UVFSYTCYzsidwjOvq6jKnnnqqefTRR83FF19cDCO6zkPn2muvNRdccMEhn/c8zzQ0NJhbbrmleKyjo8NEo1Hzs5/9zBhjzMsvv2wA8+yzzxbb/Pa3vzWWZZnt27cPX/HHkUsvvdT89V//9YBjf/EXf2Euu+wyY4yu81B5cxgZquv6H//xH6a6unrA3x3XXnutOf30099WvSU5TJPNZlm5ciVz5swpHrNtmzlz5rB8+fIAKzt+dXZ2AlBTUwPAypUryeVyA67xpEmTGD9+fPEaL1++nLPPPpv6+vpim7lz55JKpXjppZdGsPpj31VXXcWll1464HqCrvNQ+tWvfsWMGTP4+Mc/Tl1dHdOmTeOOO+4oPr9p0yZaWloGXOvKykpmzZo14FpXVVUxY8aMYps5c+Zg2zbPPPPMyJ3MMez8889n2bJlbNiwAYAXXniBp556ig984AOArvNwGarrunz5ci666CIikUixzdy5c1m/fj179+496vqOi7v2DrX29nZc1x3wlzNAfX09r7zySkBVHb88z+OLX/wi73znO5k8eTIALS0tRCIRqqqqBrStr6+npaWl2OZg/wz2PSe+e++9l1WrVvHss88e8Jyu89B5/fXX+f73v8+CBQv46le/yrPPPsvf//3fE4lEuOKKK4rX6mDXcv9rXVdXN+D5UChETU2NrnXBV77yFVKpFJMmTcJxHFzX5Zvf/CaXXXYZgK7zMBmq69rS0sJJJ510wHvse666uvqo6ivJMCJD66qrrmLt2rU89dRTQZdywtm2bRvXXHMNjz76KLFYLOhyTmie5zFjxgy+9a1vATBt2jTWrl3LkiVLuOKKKwKu7sTx3//93/z0pz/lnnvu4ayzzmL16tV88YtfZOzYsbrOJawkh2lqa2txHOeAFQetra00NDQEVNXx6eqrr+ahhx7i8ccfZ9y4ccXjDQ0NZLNZOjo6BrTf/xo3NDQc9J/BvufEH4Zpa2vjnHPOIRQKEQqF+MMf/sB3v/tdQqEQ9fX1us5DZMyYMZx55pkDjp1xxhls3boV6L9Wh/t7o6Ghgba2tgHP5/N59uzZo2td8OUvf5mvfOUrfOITn+Dss8/m05/+NF/60pdYtGgRoOs8XIbqug7X3yclGUYikQjTp09n2bJlxWOe57Fs2TJmz54dYGXHD2MMV199Nb/4xS947LHHDui2mz59OuFweMA1Xr9+PVu3bi1e49mzZ7NmzZoB//I/+uijVFRUHPClUKre8573sGbNGlavXl18zJgxg8suu6z4Z13nofHOd77zgOXpGzZsYMKECQCcdNJJNDQ0DLjWqVSKZ555ZsC17ujoYOXKlcU2jz32GJ7nMWvWrBE4i2Nfb28vtj3wq8dxHDzPA3Sdh8tQXdfZs2fzxz/+kVwuV2zz6KOPcvrppx/1EA1Q2kt7o9Goufvuu83LL79s/vZv/9ZUVVUNWHEgh/b5z3/eVFZWmieeeMLs3Lmz+Ojt7S22+dznPmfGjx9vHnvsMfPcc8+Z2bNnm9mzZxef37fk9H3ve59ZvXq1Wbp0qRk9erSWnL6F/VfTGKPrPFRWrFhhQqGQ+eY3v2leffVV89Of/tQkEgnzk5/8pNjmpptuMlVVVebBBx80L774ovnwhz980KWR06ZNM88884x56qmnzKmnnlryS073d8UVV5jGxsbi0t4HHnjA1NbWmn/6p38qttF1PjpdXV3m+eefN88//7wBzK233mqef/55s2XLFmPM0FzXjo4OU19fbz796U+btWvXmnvvvdckEgkt7X07vve975nx48ebSCRiZs6caZ5++umgSzpuAAd93HXXXcU2fX195gtf+IKprq42iUTCfPSjHzU7d+4c8D6bN282H/jAB0w8Hje1tbXmH/7hH0wulxvhszm+vDmM6DoPnV//+tdm8uTJJhqNmkmTJpkf/vCHA573PM9cf/31pr6+3kSjUfOe97zHrF+/fkCb3bt3m09+8pMmmUyaiooKM3/+fNPV1TWSp3FMS6VS5pprrjHjx483sVjMnHzyyea6664bsFRU1/noPP744wf9e/mKK64wxgzddX3hhRfMBRdcYKLRqGlsbDQ33XTT267dMma/be9ERERERlhJzhkRERGRY4fCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAvX/A5kXP7uaZutWAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_testset_correctness = lds_loss_array.mean(axis=1)\n",
    "lds_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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EBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJJxRqHn77bfRo0cPaLVaZGRkYMeOHR2WX7p0Kfr27QutVovU1FSsWrXK4/Fly5ZhwoQJCAkJgUwmw969e72uZ+vWrRg7diz8/Pyg0+lw1VVXoamp6UxeAhEREUlMl0PNkiVLMHv2bMydOxd79uxBWloaJk6ciMrKSq/lt2zZgunTp2PmzJnIysrClClTMGXKFOTk5LjLmM1mjBo1Ci+//HK7z7t161Zce+21mDBhAnbs2IGdO3fikUcegVzOziYiIiICZIIgCF1ZICMjA8OGDcNbb70FAHC5XIiLi8Ojjz6KOXPmtCk/depUmM1mfP/99+55I0aMQHp6OhYuXOhRtqCgAImJicjKykJ6errHYyNGjMA111yDF154oSvVdTMajdDr9TAYDNDpdGe0DiIiIrqwunL87lI3h81mw+7duzF+/PjWFcjlGD9+PLZu3ep1ma1bt3qUB4CJEye2W96byspKbN++HeHh4Rg5ciQiIiIwevRo/Pbbb12pPhEREUlYl0JNdXU1nE4nIiIiPOZHRESgvLzc6zLl5eVdKu/N8ePHAQDz5s3D/fffj9WrV2Pw4MEYN24cjhw5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6e1fd5a-508d-4b7d-a4a5-e1ea000b9547",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.089 (avg p value 0.417730)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[0]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf2dbb71-4997-456c-bbf1-501d83c4b872",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.110 (avg p value 0.380513)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[1]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "01cd2c1f-b213-46f1-9bf0-68eac5add620",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import bootstrap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.06892217930667728, high=0.10715609905103772)\n",
      "0.069\n",
      "0.107\n",
      "1\n",
      "ConfidenceInterval(low=0.09498974923088149, high=0.12576361453016477)\n",
      "0.095\n",
      "0.126\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(2):\n",
    "    print(i)\n",
    "    def my_statistics(data):\n",
    "        # print(data)\n",
    "        # print(len(data))\n",
    "        margins = lds_testset_correctness[data]\n",
    "        infl_est_ = -scores_list[i]\n",
    "        # infl_est_ = -tmp\n",
    "        preds = lds_mask_array[data] @ infl_est_.T\n",
    "        ####\n",
    "        rs = []\n",
    "        ps = []\n",
    "        for ind in range(1000):\n",
    "            r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "            # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "            rs.append(r)\n",
    "            ps.append(p)\n",
    "        \n",
    "        rs, ps = np.array(rs), np.array(ps)\n",
    "        # print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    \n",
    "        return rs.mean()     \n",
    "\n",
    "    data = (list(range(64)), )  # samples must be in a sequence\n",
    "    res = bootstrap(data, my_statistics, \n",
    "                    n_resamples=64, #\n",
    "                    batch=128,\n",
    "                    confidence_level=0.95,\n",
    "                    random_state=42)\n",
    "\n",
    "    print(res.confidence_interval)\n",
    "    \n",
    "    print(res.confidence_interval.low.round(3))\n",
    "    print(res.confidence_interval.high.round(3))\n",
    "\n",
    "    res_list.append(res)\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58f45d33-6d43-4367-8710-70132dbdf5b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7793c07e-c75c-48ca-a173-a9831391a624",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "9a7aacf8-41cf-4e6d-a038-17a1423ebd46",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"./val_res_list.pkl\", 'wb') as handle:\n",
    "    pickle.dump([[res.confidence_interval.low, res.confidence_interval.high, res.bootstrap_distribution, res.standard_error] for res in res_list],\n",
    "                handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9859c520-7da2-416e-a5c8-05bff6b939d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAyK0lEQVR4nO3deZzN5f//8ecxyzGYMZYZS5ixlz0j1TeyZmx9rZ9KCiX17UsUWnz0jSlSiUiizQwttj7ILQlplKQYa6lskcFYKmZRxpi5fn+4OT+nGcwZ5zjXmMf9dju3er/P9b7er+uaY85z3ss5DmOMEQAAgIWK+bsAAACAiyGoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAKNQSEhLkcDi0f/9+n+9rwIABio6Odi3v379fDodDr776qs/3LUljx46Vw+G4KvsCbEFQAQrg/JvjhY/IyEi1adNGy5cv9/n+33zzTSUkJBRo288++0xjx471aj3esmbNGrc5dTqdqlChglq3bq0XX3xRx48f98p+/vrrL40dO1Zr1qzxSn/eZHNtgD8QVIAr8Pzzz+v999/XnDlz9NRTT+n48ePq3LmzPv30U5/u90qDSlxcnHcL8rKhQ4fq/fff19tvv60nn3xSZcuW1ZgxY3TDDTfoyy+/dGt7//336++//1ZUVFS++//rr78UFxfncRh45513tHPnTo+28dSlanv22Wf1999/+3T/gG0C/V0AUJh16tRJzZo1cy0PHDhQFSpU0Ny5c9W1a1c/VuYdZ8+eVU5OjoKDg6/qflu2bKnevXu7rdu2bZs6dOigXr166aefflKlSpUkSQEBAQoICPBpPadOnVLJkiUVFBTk0/1cTmBgoAID+bWNooUjKoAXhYeHKyQkJNebyalTpzRixAhVrVpVTqdTdevW1auvvqp/fnn52bNn9cILL6hmzZpyOp2Kjo7Wv//9b2VmZrraREdHa8eOHfrqq69cp0hat24tScrKylJcXJxq166t4sWLq1y5cmrRooVWrVol6dw1FtOnT5ckt1Mskvv1FlOmTHHV8NNPP+nMmTN67rnnFBMTo9KlS6tkyZJq2bKlEhMT3eq/sI/XXntNUVFRCgkJUatWrfTjjz9e0dw2btxYU6ZM0cmTJ/XGG2+41ud1jUpSUpJiY2NVvnx5hYSEqHr16nrwwQddNUZEREiS4uLiXHNw/nTYgAEDVKpUKe3du1edO3dWaGio+vbt63ruwmtULnS58bZu3dr1c7rQhX1erra8rlHJz2tGOve66dq1q7755hs1b95cxYsXV40aNTRnzpy8JxywBNEcuAKpqan6/fffZYzRsWPHNG3aNGVkZOi+++5ztTHG6L//+7+VmJiogQMHqkmTJlqxYoWefPJJHTp0SK+99pqr7UMPPaTZs2erd+/eGjFihL7//ntNmDBBP//8sxYvXixJmjJlih577DGVKlVKo0ePliRVqFBB0rk3sgkTJuihhx5S8+bNlZaWpqSkJG3evFl33HGHHnnkER0+fFirVq3S+++/n+eY4uPjdfr0aT388MNyOp0qW7as0tLS9O6776pPnz4aNGiQ0tPT9d577yk2NlYbNmxQkyZN3PqYM2eO0tPTNXjwYJ0+fVpTp05V27Zt9cMPP7hqLYjevXtr4MCBWrlypcaPH59nm2PHjqlDhw6KiIjQM888o/DwcO3fv1+LFi2SJEVERGjGjBl69NFH1aNHD/Xs2VOS1KhRI1cfZ8+eVWxsrFq0aKFXX31VJUqUuGRd3hpvfmr7p/y8Zs7bs2ePaw779++vWbNmacCAAYqJiVH9+vXzXSdwVRkAHouPjzeScj2cTqdJSEhwa7tkyRIjyYwbN85tfe/evY3D4TB79uwxxhizdetWI8k89NBDbu1GjhxpJJkvv/zSta5+/fqmVatWuepq3Lix6dKlyyVrHzx4sMnrn/6+ffuMJBMWFmaOHTvm9tzZs2dNZmam27oTJ06YChUqmAcffDBXHyEhIebgwYOu9d9//72RZJ544olL1paYmGgkmYULF160TePGjU2ZMmVcy+d/Fvv27TPGGLN48WIjyWzcuPGifRw/ftxIMmPGjMn1XP/+/Y0k88wzz+T5XFRUlGvZk/G2atUqz5/ZP/u8VG1jxoxx+9l58pqJiooykszXX3/tWnfs2DHjdDrNiBEjcu0LsAWnfoArMH36dK1atUqrVq3SBx98oDZt2uihhx5y/fUunbt4NSAgQEOHDnXbdsSIETLGuO4S+uyzzyRJw4cPz9VOkpYtW3bZesLDw7Vjxw7t3r27wGPq1auX6/TDeQEBAa7rVHJycvTnn3/q7NmzatasmTZv3pyrj+7du+u6665zLTdv3lw333yza4xXolSpUkpPT7/o8+Hh4ZKkTz/9VFlZWQXez6OPPprvtr4c76V4+pqpV6+eWrZs6VqOiIhQ3bp19euvv/q0TuBKEFSAK9C8eXO1b99e7du3V9++fbVs2TLVq1dPQ4YM0ZkzZyRJv/32mypXrqzQ0FC3bW+44QbX8+f/W6xYMdWqVcutXcWKFRUeHu5qdynPP/+8Tp48qTp16qhhw4Z68skntX37do/GVL169TzXz549W40aNXJd+xIREaFly5YpNTU1V9vatWvnWlenTh2vfNZJRkZGrrm8UKtWrdSrVy/FxcWpfPny6tatm+Lj43Nds3EpgYGBqlKlSr7b+3K8l+Lpa6ZatWq5+ihTpoxOnDjh0zqBK0FQAbyoWLFiatOmjVJSUgp8VONKPtDr9ttv1969ezVr1iw1aNBA7777rpo2bap33303332EhITkWvfBBx9owIABqlmzpt577z19/vnnWrVqldq2baucnJwC1+uprKws7dq1K9cb84UcDoc+/vhjrV+/XkOGDNGhQ4f04IMPKiYmRhkZGfnaj9PpVLFi3v31eLGfa3Z2ts/6/qeL3R1l/nFRN2ATggrgZWfPnpUk15tiVFSUDh8+nOt0xS+//OJ6/vx/c3JycgWco0eP6uTJk26fE3KpN6ayZcvqgQce0Ny5c5WcnKxGjRq5fcBbQYLQxx9/rBo1amjRokW6//77FRsbq/bt2+v06dN5ts8rpO3ateuid8x4Usfff/+t2NjYy7a95ZZbNH78eCUlJenDDz/Ujh07NG/ePElXFgbzkp/xlilTRidPnszV7p9HPTypzZPXDFBYEVQAL8rKytLKlSsVHBzsOrXTuXNnZWdnu91SK527ndXhcKhTp06udtK5u3ouNHnyZElSly5dXOtKliyZ55veH3/84bZcqlQp1apVy+20R8mSJSUpz+0v5vxf4hf+5f39999r/fr1ebZfsmSJDh065FresGGDvv/+e9dYC2Lbtm16/PHHVaZMGQ0ePPii7U6cOJHrCMH5u5LOz8P5u3g8mYNLyc94a9asqV9++cXt03W3bdumdevWufXlSW2evGaAworbk4ErsHz5cteRkWPHjumjjz7S7t279cwzzygsLEySdOedd6pNmzYaPXq09u/fr8aNG2vlypX65JNP9Pjjj6tmzZqSzn1OSP/+/fX222/r5MmTatWqlTZs2KDZs2ere/fuatOmjWu/MTExmjFjhsaNG6datWopMjJSbdu2Vb169dS6dWvFxMSobNmySkpK0scff6whQ4a4bSud+/TX2NhYBQQE6J577rnkOLt27apFixapR48e6tKli/bt26eZM2eqXr16eZ5OqVWrllq0aKFHH31UmZmZmjJlisqVK6ennnoqX/O6du1anT59WtnZ2frjjz+0bt06LV26VKVLl9bixYtVsWLFi247e/Zsvfnmm+rRo4dq1qyp9PR0vfPOOwoLC3O9sYeEhKhevXqaP3++6tSpo7Jly6pBgwZq0KBBvuoryHgffPBBTZ48WbGxsRo4cKCOHTummTNnqn79+kpLS3O186Q2T14zQKHl35uOgMIpr9uTixcvbpo0aWJmzJhhcnJy3Nqnp6ebJ554wlSuXNkEBQWZ2rVrm4kTJ+Zql5WVZeLi4kz16tVNUFCQqVq1qhk1apQ5ffq0W7sjR46YLl26mNDQUCPJddvruHHjTPPmzU14eLgJCQkx119/vRk/frw5c+aMa9uzZ8+axx57zERERBiHw+G63fX8rbYTJ07MNd6cnBzz4osvmqioKON0Os2NN95oPv3004verjtx4kQzadIkU7VqVeN0Ok3Lli3Ntm3bLjuv529PPv8ICgoyERER5vbbbzfjx4/Pddv0hT+L87cnb9682fTp08dUq1bNOJ1OExkZabp27WqSkpLctvv2229NTEyMCQ4OdrsduH///qZkyZJ51nel4/3ggw9MjRo1THBwsGnSpIlZsWJFrj4vVds/b082Jv+vmaioqDxvXb/YbdOALRzGcBUVAO/Yv3+/qlevrokTJ2rkyJH+LgfANYBrVAAAgLUIKgAAwFoEFQAAYC2uUQEAANbiiAoAALAWQQUAAFirUH/gW05Ojg4fPqzQ0FCvfyQ2AADwDWOM0tPTVbly5ct+r1ahDiqHDx9W1apV/V0GAAAogOTk5Mt+U3mhDirnv+o9OTnZ9XHlAADAbmlpaapatarrffxSCnVQOX+6JywsjKACAEAhk5/LNriYFgAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACs5fegcujQId13330qV66cQkJC1LBhQyUlJfm7LAAAYAG/ftfPiRMndNttt6lNmzZavny5IiIitHv3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EF/Mff369c3zzz/v1qZp06Zm9OjRXqy88PP23O/cudNIMj/++KNbnxEREeadd97xwQgKL0/n/kJRUVF5vlFeSZ9FjS/m/0KFMahw6sdiZ86c0aZNm9S+fXvXumLFiql9+/Zav359ntusX7/erb0kxcbGXrT90aNHtWzZMg0cONB7hV8DfDX3//Vf/6WlS5fq0KFDMsYoMTFRu3btUocOHXwzkELIF3OfmZkpSSpevLhbn06nU9988423h1BoFWTu/dHntYq5yhtBxWK///67srOzc32dQIUKFXTkyJE8tzly5IhH7WfPnq3Q0FD17NnTO0VfI3w199OmTVO9evVUpUoVBQcHq2PHjpo+fbpuv/127w+ikPLF3F9//fWqVq2aRo0apRMnTujMmTN6+eWXdfDgQaWkpPhmIIVQQebeH31eq5irvBFUirhZs2apb9++bn9pwnemTZum7777TkuXLtWmTZs0adIkDR48WF988YW/S7umBQUFadGiRdq1a5fKli2rEiVKKDExUZ06dVKxYvwaBGxmxXf9IG/ly5dXQECAjh496rb+6NGjqlixYp7bVKxYMd/t165dq507d2r+/PneK/oa4Yu5//vvv/Xvf/9bixcvVpcuXSRJjRo10tatW/Xqq6/mOnVRVPnqdR8TE6OtW7cqNTVVZ86cUUREhG6++WY1a9bM+4MopAoy9/7o81rFXOWNPyUsFhwcrJiYGK1evdq1LicnR6tXr9att96a5za33nqrW3tJWrVqVZ7t33vvPcXExKhx48beLfwa4Iu5z8rKUlZWVq6/4AMCApSTk+PlERRevn7dly5dWhEREdq9e7eSkpLUrVs37w6gECvI3Pujz2sVc3UR/r6aF5c2b94843Q6TUJCgvnpp5/Mww8/bMLDw82RI0eMMcbcf//95plnnnG1X7dunQkMDDSvvvqq+fnnn82YMWNy3SJrjDGpqammRIkSZsaMGVd1PIWJL+a+VatWpn79+iYxMdH8+uuvJj4+3hQvXty8+eabV318NvPF3C9YsMAkJiaavXv3miVLlpioqCjTs2fPqz4223k695mZmWbLli1my5YtplKlSmbkyJFmy5YtZvfu3fnuE/+fL+Y/PT3d1UaSmTx5stmyZYv57bffrvr4CoKgUghMmzbNVKtWzQQHB5vmzZub7777zvVcq1atTP/+/d3aL1iwwNSpU8cEBweb+vXrm2XLluXq86233jIhISHm5MmTvi6/UPP23KekpJgBAwaYypUrm+LFi5u6deuaSZMmmZycnKsxnELF23M/depUU6VKFRMUFGSqVatmnn32WZOZmXk1hlLoeDL3+/btM5JyPVq1apXvPuHO2/OfmJiYZ5t//huylcMYY67+cRwAAIDL4xoVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAvMbhcGjJkiUF3n7s2LFq0qSJ1+opiNatW+vxxx/3aw0A/j+CClCEDRgwQN27d/d4u4sFipSUFHXq1ClffeQVakaOHJnrO3sAFG18ezIAr7nSb3gtVaqUSpUq5aVqAFwLOKICXOM+/vhjNWzYUCEhISpXrpzat2+vU6dOaezYsZo9e7Y++eQTORwOORwOrVmzRpL09NNPq06dOipRooRq1Kih//u//1NWVpYkKSEhQXFxcdq2bZtru4SEBEnuR0nOnDmjIUOGqFKlSipevLiioqI0YcIESVJ0dLQkqUePHnI4HK7lvI7UzJo1S/Xr15fT6VSlSpU0ZMiQPMe5cuVKFS9eXCdPnnRbP2zYMLVt21aS9Mcff6hPnz667rrrVKJECTVs2FBz58695PzldeQnPDzcNWZJSk5O1l133aXw8HCVLVtW3bp10/79+y/ZL4D84YgKcA1LSUlRnz599Morr6hHjx5KT0/X2rVrZYzRyJEj9fPPPystLU3x8fGSpLJly0qSQkNDlZCQoMqVK+uHH37QoEGDFBoaqqeeekp33323fvzxR33++ef64osvJEmlS5fOte/XX39dS5cu1YIFC1StWjUlJycrOTlZkrRx40ZFRkYqPj5eHTt2VEBAQJ71z5gxQ8OHD9dLL72kTp06KTU1VevWrcuzbbt27RQeHq7//Oc/GjhwoCQpOztb8+fP1/jx4yVJp0+fVkxMjJ5++mmFhYVp2bJluv/++1WzZk01b968QHOclZWl2NhY3XrrrVq7dq0CAwM1btw4dezYUdu3b1dwcHCB+gVwDkEFuIalpKTo7Nmz6tmzp6KioiRJDRs2dD0fEhKizMzMXKdsnn32Wdf/R0dHa+TIkZo3b56eeuophYSEqFSpUgoMDLzkqZ4DBw6odu3aatGihRwOh2v/khQRESHp3JGJS/Uxbtw4jRgxQsOGDXOtu+mmm/JsGxAQoHvuuUcfffSRK6isXr1aJ0+eVK9evSRJ1113nUaOHOna5rHHHtOKFSu0YMGCAgeV+fPnKycnR++++64cDockKT4+XuHh4VqzZo06dOhQoH4BnENQAa5hjRs3Vrt27dSwYUPFxsaqQ4cO6t27t8qUKXPJ7ebPn6/XX39de/fuVUZGhs6ePauwsDCP9j1gwADdcccdqlu3rjp27KiuXbt69KZ97NgxHT58WO3atcv3Nn379tUtt9yiw4cPq3Llyvrwww/VpUsXhYeHSzp3hOXFF1/UggULdOjQIZ05c0aZmZkqUaKER2O70LZt27Rnzx6Fhoa6rT99+rT27t1b4H4BnMM1KsA1LCAgQKtWrdLy5ctVr149TZs2TXXr1tW+ffsuus369evVt29fde7cWZ9++qm2bNmi0aNH68yZMx7tu2nTptq3b59eeOEF/f3337rrrrvUu3fvfG8fEhLi0f6kc0dbatasqXnz5unvv//W4sWL1bdvX9fzEydO1NSpU/X0008rMTFRW7duVWxs7CXH5nA4ZIxxW3f+eh1JysjIUExMjLZu3er22LVrl+69916PxwDAHUdUgGucw+HQbbfdpttuu03PPfecoqKitHjxYg0fPlzBwcHKzs52a//tt98qKipKo0ePdq377bff3NrktV1ewsLCdPfdd+vuu+9W79691bFjR/35558qW7asgoKCLtlHaGiooqOjtXr1arVp0ybf4+3bt68+/PBDValSRcWKFVOXLl1cz61bt07dunXTfffdJ0nKycnRrl27VK9evYv2FxERoZSUFNfy7t279ddff7mWmzZtqvnz5ysyMtLjo04ALo8jKsA17Pvvv9eLL76opKQkHThwQIsWLdLx48d1ww03SDp3/cn27du1c+dO/f7778rKylLt2rV14MABzZs3T3v37tXrr7+uxYsXu/UbHR2tffv2aevWrfr999+VmZmZa9+TJ0/W3Llz9csvv2jXrl1auHChKlas6DoNcz6EHDlyRCdOnMiz/rFjx2rSpEl6/fXXtXv3bm3evFnTpk275Jj79u2rzZs3a/z48erdu7ecTqfrudq1a2vVqlX69ttv9fPPP+uRRx7R0aNHL9lf27Zt9cYbb2jLli1KSkrS//zP/ygoKMhtf+XLl1e3bt20du1a7du3T2vWrNHQoUN18ODBS/YNIB8MgGvWTz/9ZGJjY01ERIRxOp2mTp06Ztq0aa7njx07Zu644w5TqlQpI8kkJiYaY4x58sknTbly5UypUqXM3XffbV577TVTunRp13anT582vXr1MuHh4UaSiY+PN8YYI8ksXrzYGGPM22+/bZo0aWJKlixpwsLCTLt27czmzZtdfSxdutTUqlXLBAYGmqioKGOMMWPGjDGNGzd2G8PMmTNN3bp1TVBQkKlUqZJ57LHHLjvu5s2bG0nmyy+/dFv/xx9/mG7duplSpUqZyMhI8+yzz5p+/fqZbt26udq0atXKDBs2zLV86NAh06FDB1OyZElTu3Zt89lnn5nSpUu7xmyMMSkpKaZfv36mfPnyxul0mho1aphBgwaZ1NTUy9YK4NIcxvzj5CsAAIAlOPUDAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLX+H3JFQlp/e6XkAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.hist(res_list[0].bootstrap_distribution, bins=25)\n",
    "ax.set_title('Bootstrap Distribution')\n",
    "ax.set_xlabel('statistic value')\n",
    "ax.set_ylabel('frequency')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d386ad1-9f39-4f63-9d4b-a52d89367e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32c48dba-1625-456f-95f7-16e3db6c2758",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e03f4530-cee9-49d6-bf35-790bb7f71aaa",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
