{
 "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": [
       "12500"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/12500-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": "46fa7fd5-34ca-4e86-8773-f5ff38b758da",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 12500)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_10_5000000.0_0.09917620583439629.pkl\", 'rb') as handle:\n",
    "    scores = pickle.load(handle)\n",
    "scores_list.append(scores)\n",
    "scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "006cafd2-ec49-4328-90f0-e7ec1931ca80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 12500)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_100_5000000.0_0.21374005798369336.pkl\", 'rb') as handle:\n",
    "    scores = pickle.load(handle)\n",
    "scores_list.append(scores)\n",
    "scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b878e1ed-2e73-4b6f-9d2d-75051b7691b0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 12500)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_mean-squared-l2-norm_10_5000000.0_0.2310920615017316.pkl\", 'rb') as handle:\n",
    "    scores = pickle.load(handle)\n",
    "scores_list.append(scores)\n",
    "scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ae91bee0-d447-4681-8aae-3a8753d3bdcf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 12500)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_mean-squared-l2-norm_100_5000000.0_0.27787268617515576.pkl\", 'rb') as handle:\n",
    "    scores = pickle.load(handle)\n",
    "scores_list.append(scores)\n",
    "scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3094d577-6791-4900-953b-d0d27e3d3d14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": 12,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 12,
     "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/12500-0.5/lds-val/sd-lora-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": 13,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f9U//vhjHdA/+eSTiPzm+F5ra2v1zMxMffz48frq1av19957T7fZbPpLL710WH1vtcHISSedpN98883hz8FgUM/JydGnTJnSgr06fpWVlemA/v333+u6rus1NTW6yWTSP/zww3CZdevW6YC+YMECXddD/3BUVdVLSkrCZf7973/rdrtd93q9R/cBjnF1dXV6586d9ZkzZ+qjR48OByPyPTefu+++Wx85cmST+Zqm6VlZWfrTTz8dTqupqdEtFov+3nvv6bqu62vXrtUBffHixeEyX331la4oir5z584j1/njyLnnnqtfd911EWmXXHKJPn78eF3X5XtuLnsHI831vb744ot6cnJyxP877r77br1r166H1d9W+ZrG5/OxdOlSxowZE05TVZUxY8awYMGCFuzZ8au2thaAlJQUAJYuXYrf74/4jrt160ZeXl74O16wYAG9e/cmMzMzXGbs2LE4nU7WrFlzFHt/7Lv55ps599xzI75PkO+5OX3++ecMGjSI3/zmN2RkZNC/f39eeeWVcP7WrVspKSmJ+K4dDgdDhgyJ+K6TkpIYNGhQuMyYMWNQVZWff/756D3MMWz48OHMnj2bjRs3AvDLL7/w448/cvbZZwPyPR8pzfW9LliwgJNPPhmz2RwuM3bsWDZs2EB1dfUh9++4OCivuVVUVBAMBiP+5wyQmZnJ+vXrW6hXxy9N07jjjjsYMWIEvXr1AqCkpASz2UxSUlJE2czMTEpKSsJlYv0Z/JonQt5//32WLVvG4sWLo/Lke24+BQUF/Pvf/2bSpEnce++9LF68mNtuuw2z2cw111wT/q5ifZd7ftcZGRkR+UajkZSUFPmud7vnnntwOp1069YNg8FAMBjkscceY/z48QDyPR8hzfW9lpSU0L59+6g2fs1LTk4+pP61ymBENK+bb76Z1atX8+OPP7Z0V044RUVF3H777cycOROr1drS3TmhaZrGoEGDePzxxwHo378/q1evZurUqVxzzTUt3LsTxwcffMA777zDu//fzv2EpLJHcQA/72paEmZgOGUYBdHt36KMYqidELSKdkWItIkKoSKKIFpGrlrUrk0t6tKqiFoEola0yCi0jMDalBspKMTAIMNzF+/dec2r9x50rSn8fmBAZg7ym68yHhyPP35QdXU1BYNBGhoaoqKiIuScwTLyNo3RaCSVSvVi4uD6+poEQVBoVV+T0+mkzc1N8vl8VFxcLO0XBIEeHx8pFovJ6p9nLAjCq6/Br2Pw522Ym5sbqq+vJ7VaTWq1mnZ2dmh2dpbUajWZTCbknCaFhYVUVVUl21dZWUmRSISI/s7qv64bgiDQzc2N7PjT0xPd3d0h67+Mjo7S+Pg4dXZ2Um1tLdntdhoeHqbp6WkiQs7vJV25vtf1JCObEY1GQ1arlTwej7QvlUqRx+MhURQVXNnXwczkdDppbW2NvF7vi6/trFYrZWVlyTIOh8MUiUSkjEVRpFAoJHvzu91u0uv1Lz4UMpXNZqNQKETBYFDaGhoaqLu7W3qMnNOjubn5xXj6+fk5lZSUEBFRaWkpCYIgyzoej5Pf75dlHYvF6OjoSKrxer2USqWoqanpA87i80skEvTtm/yjR6VSUSqVIiLk/F7SlasoirS7u0vJZFKqcbvdVFFR8eZbNESU2aO9Wq2WFxcX+ezsjHt7e9lgMMgmDuDf9ff3c15eHm9vb3M0GpW2RCIh1fT19bHFYmGv18uHh4csiiKLoigd/zVy2traysFgkLe2trigoAAjp//j+TQNM3JOl4ODA1ar1Tw1NcUXFxe8vLzMOp2Ol5aWpBqXy8UGg4HX19f55OSE29vbXx2NrKurY7/fz3t7e1xeXp7xI6fPORwONpvN0mjv6uoqG41GHhsbk2qQ89vc399zIBDgQCDARMQzMzMcCAT46uqKmdOTaywWY5PJxHa7nU9PT3llZYV1Oh1Ge3/H3NwcWywW1mg03NjYyPv7+0ov6csgole3hYUFqebh4YEHBgY4Pz+fdTodd3R0cDQalT3P5eUlt7W1cU5ODhuNRh4ZGeFkMvnBZ/O1/LMZQc7ps7GxwTU1NazVavn79+88Pz8vO55KpXhycpJNJhNrtVq22WwcDodlNbe3t9zV1cW5ubms1+u5p6eH7+/vP/I0PrV4PM6Dg4NssVg4Ozuby8rKeGJiQjYqipzfxufzvXpddjgczJy+XI+Pj7mlpYW1Wi2bzWZ2uVy/vfY/mJ/97R0AAADAB8vI34wAAADA54FmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAU9RNbNcbOLkXbyQAAAABJRU5ErkJggg==",
      "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": 14,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 12500)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/12500-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": 15,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 15,
     "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": 16,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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acVggN0y/NaMzWREuceqm3OFpomr+uzL5WBgmSSf+Jdd6I2msHa+Hx+a58eyacWj3lq4EcXTWbxzthclTisayl1wWi//oBNCYO+5frz8biv++3AnjIoBn7ljJh5cUz/iffvJks5qeOt0N3ac7IZJUXJX2xaU5O7nljqt8LnkrYSbhRACrX0JHGjtzweYjoEEXFYTXLmrZFfuWR15shp6BsdhkeFp8BkAq8mISDKTf1i2L9eA98XSCCUymF/lwYcXV2J+pee6fxB0JJFkBjazcULPNFxKKJHByUAEC6s9ujnR6VlvNIXtx7vw22MBvNHUg3RWw5LaIvzRwgp5y7tk/A8107XHwDJJoqnsTXUiu1YyqpZ/aJaIaLLEc7cpJ/vBULp6xnv+5pn4EhhWro7JvBolIhoke/6muhR0NfCsQURERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREundZgeXpp59GXV0dbDYbGhsbsWfPnlHnPXr0KO69917U1dXBYDBgy5Ytw+aJRCLYsGEDpk+fDrvdjltvvRV79+69nKIRERHRDWjCgeXFF1/Exo0b8fjjj2P//v1YsmQJ1q1bh66urhHnj8fjmDFjBp544glUVFSMOM9f/dVf4dVXX8Xzzz+Pw4cP46677sLatWvR3t4+0eIRERHRDcgghBATWaCxsRErV67E1q1bAQCapqG2thYPP/wwNm3aNOaydXV12LBhAzZs2JB/LZFIwO124xe/+AXuueee/OvLly/H3XffjX/4h38YV7nC4TC8Xi9CoRA8Hs9EvhIRERFNkfGevyfUw5JOp7Fv3z6sXbt2aAWKgrVr12LXrl2XVdBsNgtVVWGz2Qpet9vteOutt0ZdLpVKIRwOFwxERER0Y5pQYOnp6YGqqvD7/QWv+/1+BAKByyqA2+3G6tWr8bWvfQ0dHR1QVRU//vGPsWvXLnR2do663ObNm+H1evNDbW3tZX0+ERER6Z8ufkvo+eefhxAC1dXVsFqteOqpp/CpT30KijJ68R555BGEQqH80Nraeg1LTERERNeSaSIzl5aWwmg0IhgMFrweDAZHfaB2PGbOnImdO3ciFoshHA6jsrIS9913H2bMmDHqMlarFVar9bI/k4iIiK4fE+phsVgsWL58ObZv355/TdM0bN++HatXr77iwjidTlRWVqK/vx+/+c1v8NGPfvSK10lERETXvwn1sADAxo0bsX79eqxYsQKrVq3Cli1bEIvF8MADDwAA7r//flRXV2Pz5s0A5IO6x44dy0+3t7fj4MGDcLlcaGhoAAD85je/gRACc+bMwenTp/HlL38Zc+fOza+TiIiIbm4TDiz33Xcfuru78dhjjyEQCGDp0qXYtm1b/kHclpaWgmdPOjo6sGzZsvzPTz75JJ588knccccd2LFjBwAgFArhkUceQVtbG3w+H+699158/etfh9lsvsKvR0RERDeCCf8dFr3i32EhIiK6/lyVv8NCRERENBUYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcuK7A8/fTTqKurg81mQ2NjI/bs2TPqvEePHsW9996Luro6GAwGbNmyZdg8qqri0UcfRX19Pex2O2bOnImvfe1rEEJcTvGIiIjoBjPhwPLiiy9i48aNePzxx7F//34sWbIE69atQ1dX14jzx+NxzJgxA0888QQqKipGnOeb3/wmnnnmGWzduhXHjx/HN7/5TXzrW9/Cd7/73YkWj4iIiG5ABjHBbozGxkasXLkSW7duBQBomoba2lo8/PDD2LRp05jL1tXVYcOGDdiwYUPB6x/+8Ifh9/vxgx/8IP/avffeC7vdjh//+MfjKlc4HIbX60UoFILH45nIVyIiIqIpMt7z94R6WNLpNPbt24e1a9cOrUBRsHbtWuzateuyC3vrrbdi+/btOHXqFADgvffew1tvvYW777571GVSqRTC4XDBQERERDcm00Rm7unpgaqq8Pv9Ba/7/X6cOHHisguxadMmhMNhzJ07F0ajEaqq4utf/zo+/elPj7rM5s2b8fd///eX/ZlERER0/dDFbwm99NJL+MlPfoKf/vSn2L9/P370ox/hySefxI9+9KNRl3nkkUcQCoXyQ2tr6zUsMREREV1LE+phKS0thdFoRDAYLHg9GAyO+kDteHz5y1/Gpk2b8MlPfhIAsGjRIpw/fx6bN2/G+vXrR1zGarXCarVe9mcSERHR9WNCPSwWiwXLly/H9u3b869pmobt27dj9erVl12IeDwORSksitFohKZpl71OIiIiunFMqIcFADZu3Ij169djxYoVWLVqFbZs2YJYLIYHHngAAHD//fejuroamzdvBiAf1D127Fh+ur29HQcPHoTL5UJDQwMA4CMf+Qi+/vWvY9q0aViwYAEOHDiA73znO3jwwQcn63sSERHRdWzCv9YMAFu3bsW3v/1tBAIBLF26FE899RQaGxsBAO9///tRV1eH5557DgBw7tw51NfXD1vHHXfcgR07dgAAIpEIHn30Ubzyyivo6upCVVUVPvWpT+Gxxx6DxWIZV5n4a81ERETXn/Gevy8rsOgRAwsREdH156r8HRYiIiKiqcDAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6d1mB5emnn0ZdXR1sNhsaGxuxZ8+eUec9evQo7r33XtTV1cFgMGDLli3D5hl87+LhoYceupziERER0Q1mwoHlxRdfxMaNG/H4449j//79WLJkCdatW4eurq4R54/H45gxYwaeeOIJVFRUjDjP3r170dnZmR9effVVAMDHP/7xiRaPiIiIbkAGIYSYyAKNjY1YuXIltm7dCgDQNA21tbV4+OGHsWnTpjGXraurw4YNG7Bhw4Yx59uwYQN+9atfoampCQaDYVzlCofD8Hq9CIVC8Hg841qGiIiIptZ4z98T6mFJp9PYt28f1q5dO7QCRcHatWuxa9euyy/tRZ/x4x//GA8++OC4wwoRERHd2EwTmbmnpweqqsLv9xe87vf7ceLEiUkp0M9//nMMDAzgL/7iL8acL5VKIZVK5X8Oh8OT8vlERESkP7r7LaEf/OAHuPvuu1FVVTXmfJs3b4bX680PtbW116iEREREdK1NKLCUlpbCaDQiGAwWvB4MBkd9oHYizp8/j9/97nf4q7/6q0vO+8gjjyAUCuWH1tbWK/58IiIi0qcJBRaLxYLly5dj+/bt+dc0TcP27duxevXqKy7MD3/4Q5SXl+Oee+655LxWqxUej6dgICIiohvThJ5hAYCNGzdi/fr1WLFiBVatWoUtW7YgFovhgQceAADcf//9qK6uxubNmwHIh2iPHTuWn25vb8fBgwfhcrnQ0NCQX6+mafjhD3+I9evXw2SacLGIiIjoBjbhZHDfffeh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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": 17,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.099 (avg p value 0.397252)\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": 18,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.214 (avg p value 0.203510)\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": 19,
   "id": "f2f44265-e343-4000-9a48-454971ff77dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.231 (avg p value 0.198154)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[2]\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": 20,
   "id": "af35be81-8658-4113-b6bc-dd2e4bb8cecd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.278 (avg p value 0.135517)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[3]\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": 21,
   "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": 22,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.09398984770853888, high=0.10718966451372526)\n",
      "0.094\n",
      "0.107\n",
      "1\n",
      "ConfidenceInterval(low=0.2082379427833211, high=0.22128314953645944)\n",
      "0.208\n",
      "0.221\n",
      "2\n",
      "ConfidenceInterval(low=0.2260089410446787, high=0.2361791969422038)\n",
      "0.226\n",
      "0.236\n",
      "3\n",
      "ConfidenceInterval(low=0.27303826751056415, high=0.2816668423686131)\n",
      "0.273\n",
      "0.282\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(4):\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": 23,
   "id": "7793c07e-c75c-48ca-a173-a9831391a624",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[0.09398984770853888,\n",
       "  0.10718966451372526,\n",
       "  array([0.09422306, 0.09842473, 0.10521301, 0.10223713, 0.09828468,\n",
       "         0.09594909, 0.09693148, 0.0950577 , 0.10480146, 0.09910565,\n",
       "         0.09890697, 0.09741398, 0.10224088, 0.09784037, 0.09932067,\n",
       "         0.10228504, 0.09669154, 0.09531116, 0.09397735, 0.10046906,\n",
       "         0.09748959, 0.09881828, 0.10184483, 0.0955694 , 0.0990704 ,\n",
       "         0.10052993, 0.10037657, 0.09663973, 0.09751564, 0.09938675,\n",
       "         0.09940333, 0.09829916, 0.09454469, 0.09501056, 0.09306774,\n",
       "         0.09388291, 0.10243847, 0.09398005, 0.09399657, 0.10023529,\n",
       "         0.09597447, 0.09769867, 0.09806692, 0.10285467, 0.09684278,\n",
       "         0.09991408, 0.09197348, 0.09557776, 0.0988512 , 0.09903907,\n",
       "         0.09755138, 0.0963227 , 0.09397213, 0.09451753, 0.09580033,\n",
       "         0.09230535, 0.10758997, 0.09352265, 0.09998614, 0.09956057,\n",
       "         0.09100488, 0.10067045, 0.1011077 , 0.09707424]),\n",
       "  0.003347393266773793],\n",
       " [0.2082379427833211,\n",
       "  0.22128314953645944,\n",
       "  array([0.21286262, 0.21190264, 0.21825505, 0.20676548, 0.20255056,\n",
       "         0.21348258, 0.21476892, 0.20874636, 0.20958488, 0.20535897,\n",
       "         0.2065447 , 0.20400574, 0.21503778, 0.21651432, 0.20551275,\n",
       "         0.21250852, 0.20796014, 0.21171175, 0.20614967, 0.2098862 ,\n",
       "         0.21518546, 0.20433659, 0.22132599, 0.2045723 , 0.2063461 ,\n",
       "         0.21577365, 0.1994752 , 0.20434614, 0.21538017, 0.2166666 ,\n",
       "         0.21399164, 0.21374895, 0.21174485, 0.2071483 , 0.20774412,\n",
       "         0.2088656 , 0.21489745, 0.20930409, 0.20764394, 0.21298964,\n",
       "         0.20916645, 0.2080502 , 0.20838262, 0.20901686, 0.20876322,\n",
       "         0.21321268, 0.20910163, 0.21007196, 0.2088354 , 0.21647034,\n",
       "         0.20731639, 0.20590313, 0.21303128, 0.21240067, 0.21427895,\n",
       "         0.21314644, 0.21245409, 0.20806482, 0.20506306, 0.21361009,\n",
       "         0.20958232, 0.2080292 , 0.21009103, 0.21205956]),\n",
       "  0.004208506127092212],\n",
       " [0.2260089410446787,\n",
       "  0.2361791969422038,\n",
       "  array([0.23016129, 0.2317143 , 0.22885719, 0.23079723, 0.2292325 ,\n",
       "         0.23019277, 0.23104658, 0.23229551, 0.23194631, 0.2309008 ,\n",
       "         0.22451229, 0.22934708, 0.22949847, 0.2289016 , 0.22708521,\n",
       "         0.23067437, 0.22479323, 0.22325257, 0.22460969, 0.2326908 ,\n",
       "         0.23512104, 0.22459074, 0.23504802, 0.22392855, 0.22576422,\n",
       "         0.22641385, 0.2204061 , 0.22451273, 0.23223423, 0.23619806,\n",
       "         0.22527822, 0.22446861, 0.23381456, 0.22600044, 0.22473411,\n",
       "         0.21913377, 0.2315206 , 0.22968014, 0.22603157, 0.23041613,\n",
       "         0.22530576, 0.22418463, 0.22979937, 0.23068111, 0.23303704,\n",
       "         0.22524442, 0.22541586, 0.23057548, 0.22449255, 0.22896067,\n",
       "         0.22869148, 0.23247246, 0.23026669, 0.2267165 , 0.22840942,\n",
       "         0.2321177 , 0.22472627, 0.22203032, 0.228395  , 0.23066645,\n",
       "         0.22578826, 0.22845149, 0.23379296, 0.22802581]),\n",
       "  0.003691997834272856],\n",
       " [0.27303826751056415,\n",
       "  0.2816668423686131,\n",
       "  array([0.28002242, 0.27503208, 0.2767027 , 0.2770611 , 0.27810394,\n",
       "         0.27745306, 0.27808156, 0.27884984, 0.27807463, 0.27686441,\n",
       "         0.27009957, 0.27405025, 0.27818071, 0.27691285, 0.27074235,\n",
       "         0.27532601, 0.27147274, 0.27001492, 0.27143375, 0.27769234,\n",
       "         0.27694745, 0.27028165, 0.28168754, 0.27096359, 0.266773  ,\n",
       "         0.27271364, 0.26836228, 0.26915579, 0.28010615, 0.27930887,\n",
       "         0.27381875, 0.27323931, 0.2797516 , 0.27248094, 0.27027693,\n",
       "         0.26770586, 0.27931109, 0.27345146, 0.27437372, 0.27750204,\n",
       "         0.27047462, 0.27035404, 0.27843642, 0.27739008, 0.27716795,\n",
       "         0.26858356, 0.26917196, 0.2777171 , 0.26999535, 0.27514743,\n",
       "         0.27700074, 0.27831725, 0.2786385 , 0.27147611, 0.27498165,\n",
       "         0.27689866, 0.2736003 , 0.27033088, 0.27528667, 0.27736912,\n",
       "         0.2695139 , 0.27482594, 0.27602826, 0.27624701]),\n",
       "  0.0037537093641228994]]"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[[res.confidence_interval.low, res.confidence_interval.high, res.bootstrap_distribution, res.standard_error] for res in res_list]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "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": 25,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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n1b79u21du1azZo1S3feeac6duzo2m5MTIymTp2q559/XvXr11dERIQ6deqkRo0aqUOHDoqJiVGlSpWUnJysjz76SMOHD3dbV7rw6a+xsbHy8/PT3/72tyvuZ8+ePbVgwQL17t1bcXFx2rdvn6ZNm6ZGjRrl+3ZK/fr11bZtW/3jH/9QZmampkyZosqVK+vxxx8v0Lh+8803OnfunHJycnTy5EmtXr1aixYtUoUKFbRw4UJVq1btsuvOmjVLb775pnr37q169eopPT1d77zzjkJDQ12/2IOCgtSoUSPNnTtXDRo0UKVKldSkSRM1adKkQPUVZn8HDx6syZMnKzY2VkOGDNHx48c1bdo0NW7cWGlpaa52ntTmyTEDlFi+fegIKJnyezy5bNmypkWLFmbq1KkmNzfXrX16erp59NFHTY0aNUxAQICJjo42kyZNytMuKyvLJCQkmDp16piAgABTq1YtEx8fb86dO+fW7ujRoyYuLs6EhIQYSa7HXp9//nnTqlUrExYWZoKCgswNN9xgxo8fb86fP+9aNzs72zz88MMmPDzcOBwO1+OuFx+1nTRpUp79zc3NNRMmTDCRkZHG6XSam266yXz66aeXfVx30qRJ5qWXXjK1atUyTqfTtGvXzmzevPmq43rx8eSLr4CAABMeHm5uu+02M378+DyPTV/6s7j4ePKGDRtM//79Te3atY3T6TQRERGmZ8+eJjk52W29b7/91sTExJjAwEC3x4EHDhxoypcvn29917q/77//vqlbt64JDAw0LVq0MJ999lmePq9U2+8fTzam4MdMZGRkvo+uX+6xacAWDmO4iwqAd+zfv1916tTRpEmTNGbMGF+XA6AU4B4VAABgLYIKAACwFkEFAABYi3tUAACAtbiiAgAArEVQAQAA1irRH/iWm5urI0eOKCQkxOsfiQ0AAIqGMUbp6emqUaPGVb9Xq0QHlSNHjqhWrVq+LgMAABTCwYMHr/pN5SU6qFz8qveDBw+6Pq4cAADYLS0tTbVq1XL9Hr+SEh1ULr7dExoaSlABAKCEKchtG9xMCwAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADW8mlQiYqKksPhyPMaNmyYL8sCAACW8Ol3/axbt045OTmu6W3btun222/XX/7yFx9WBQAA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AADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrWRFU3njjDUVFRals2bJq3bq11q5d6+uSAACABXweVObOnatRo0Zp7Nix2rBhg5o3b67Y2FgdP37c16UBAAAf83lQmTx5soYOHar7779fjRo10rRp01SuXDnNmDHD16UBAAAf82lQOX/+vNavX68uXbq45pUpU0ZdunTRmjVrfFgZAACwgb8vN/7LL78oJydHVatWdZtftWpV7dixI0/7zMxMZWZmuqZTU1MlSWlpaUVSX27mb0XSb2F5az9t2y8A9iuq82xh2XYes218JO+NUVHs28U+jTFXbevToOKpxMREJSQk5Jlfq1YtH1RT/CpM8XUFAK5XnH+urDSPT1HuW3p6uipUqHDFNj4NKlWqVJGfn5+OHTvmNv/YsWOqVq1anvbx8fEaNWqUazo3N1e//vqrKleuLIfDUeT12iQtLU21atXSwYMHFRoa6utyfI7xcMd4uGM83DEe7hgPd8UxHsYYpaenq0aNGldt69OgEhgYqJiYGK1YsUJ33nmnpAvhY8WKFRo+fHie9k6nU06n021eWFhYMVRqr9DQUP5hXYLxcMd4uGM83DEe7hgPd0U9Hle7knKRz9/6GTVqlAYOHKibb75ZrVq10pQpU3TmzBndf//9vi4NAAD4mM+Dyl133aUTJ07omWee0dGjR9WiRQstW7Yszw22AADg+uPzoCJJw4cPz/etHlye0+nU2LFj87wVdr1iPNwxHu4YD3eMhzvGw51t4+EwBXk2CAAAwAd8/sm0AAAAl0NQAQAA1iKoAAAAaxFUAACAtQgqxeSNN95QVFSUypYtq9atW2vt2rVXbD9//nzdcMMNKlu2rJo2baolS5a4LT927JgGDRqkGjVqqFy5curWrZt2797tWv7rr7/q4YcfVsOGDRUUFKTatWtrxIgRru9HusjhcOR5zZkzx3s7fhnFPR6S1KFDhzz7+ve//92tzYEDBxQXF6dy5copIiJCjz32mLKzs72z01dQ3OOxf//+fH/2DodD8+fPd7UrCcfH9u3b1bdvX0VFRcnhcGjKlCmF6vPcuXMaNmyYKleurODgYPXt2zfPp2aXhOPDG+NRms4f3jo+Ssv5wxvjUeznD4MiN2fOHBMYGGhmzJhhtm/fboYOHWrCwsLMsWPH8m2/evVq4+fnZ1544QXzww8/mKefftoEBASYrVu3GmOMyc3NNbfccotp166dWbt2rdmxY4d58MEHTe3atU1GRoYxxpitW7eaPn36mEWLFpk9e/aYFStWmOjoaNO3b1+3bUkySUlJJiUlxfU6e/ZsqRsPY4xp3769GTp0qNu+pqamupZnZ2ebJk2amC5dupiNGzeaJUuWmCpVqpj4+PhSNx7Z2dlu45CSkmISEhJMcHCwSU9Pd22rJBwfa9euNWPGjDGzZ8821apVMy+//HKh+vz73/9uatWqZVasWGGSk5PNLbfcYv70pz+5lpeU48Mb41Gazh/eOj5Ky/nDG+NR3OcPgkoxaNWqlRk2bJhrOicnx9SoUcMkJibm2/6vf/2riYuLc5vXunVr89BDDxljjNm5c6eRZLZt2+bWZ3h4uHnnnXcuW8e8efNMYGCgycrKcs2TZBYuXFiY3So0X41H+/btzciRIy9b15IlS0yZMmXM0aNHXfOmTp1qQkNDTWZmpkf76Albjo8WLVqYwYMHu80rCcfHpSIjI/M98V6tz9OnT5uAgAAzf/58V5sff/zRSDJr1qwxxpSc4+NShR2P/JTU88elrmU8Ssv541LePD6K8vzBWz9F7Pz581q/fr26dOnimlemTBl16dJFa9asyXedNWvWuLWXpNjYWFf7zMxMSVLZsmXd+nQ6nfrf//532VpSU1MVGhoqf3/3z/kbNmyYqlSpolatWmnGjBkF+trtwvL1eHzwwQeqUqWKmjRpovj4eP322///GvQ1a9aoadOmbp+KHBsbq7S0NG3fvr2Qe3xlvh6Pi9avX69NmzZpyJAheZbZfnx4o8/169crKyvLrc0NN9yg2rVru9qUlOOjqPosqecPb/ZZGs4fRdFnUZ8/rPhk2tLsl19+UU5OTp6vBKhatap27NiR7zpHjx7Nt/3Ro0cl/f8TaHx8vN566y2VL19eL7/8sg4dOqSUlJTL1vHcc8/pwQcfdJv/7LPPqlOnTipXrpw+//xz/fOf/1RGRoZGjBhR2F2+Il+Ox913363IyEjVqFFDW7Zs0RNPPKGdO3dqwYIFV9zOxWVFwZbjY/r06brxxhv1pz/9yW1+STg+vNHn0aNHFRgYmOdLTi8d15JyfBRFnyX5/OGtPkvL+aMo+izq8wdBpQQKCAjQggULNGTIEFWqVEl+fn7q0qWLunfvnm9aTUtLU1xcnBo1aqRx48a5Lfu///s/199vuukmnTlzRpMmTSqyE01RKOh4XHqSbdq0qapXr67OnTtr7969qlevni9KLxKeHh9nz57Vhx9+6HYsXFQajg9cm9J+/iio6+X84aniOH/w1k8Rq1Klivz8/PI8PXDs2DFVq1Yt33WqVat21fYxMTHatGmTTp8+rZSUFC1btkwnT55U3bp13dZLT09Xt27dFBISooULFyogIOCK9bZu3VqHDh1yvX3gbb4ej0u1bt1akrRnz54rbufisqJgw3h89NFH+u2333TfffddtV4bjw9v9FmtWjWdP39ep0+fvmKbknB8eLPP0nD+KKo+S+r5w9t9Fsf5g6BSxAIDAxUTE6MVK1a45uXm5mrFihVq06ZNvuu0adPGrb0kLV++PN/2FSpUUHh4uHbv3q3k5GT16tXLtSwtLU1du3ZVYGCgFi1a5HbPwuVs2rRJFStWLLIvo/LlePzepk2bJEnVq1d3bWfr1q06fvy423ZCQ0PVqFGjAu+jJ2wYj+nTp+vPf/6zwsPDr1qvjceHN/qMiYlRQECAW5udO3fqwIEDrjYl5fjwVp+l5fxRVH2W1POHt/sslvPHNd+Oi6uaM2eOcTqdZubMmeaHH34wDz74oAkLC3PdHX7vvfeaJ5980tV+9erVxt/f37z44ovmxx9/NGPHjnV7/NSYC3fgr1y50uzdu9d8/PHHJjIy0vTp08e1PDU11bRu3do0bdrU7Nmzx+3xsOzsbGOMMYsWLTLvvPOO2bp1q9m9e7d58803Tbly5cwzzzxT6sZjz5495tlnnzXJyclm37595pNPPjF169Y1t912m6vNxccLu3btajZt2mSWLVtmwsPDi+XxwuIej4t2795tHA6HWbp0aZ5lJeX4yMzMNBs3bjQbN2401atXN2PGjDEbN240u3fvLnCfxlx4PLl27drmyy+/NMnJyaZNmzamTZs2ruUl5fjwxniUpvOHN8ajNJ0/vPXvxZjiO38QVIrJa6+9ZmrXrm0CAwNNq1atzHfffeda1r59ezNw4EC39vPmzTMNGjQwgYGBpnHjxmbx4sVuy1955RVTs2ZNExAQYGrXrm2efvppt0fgVq5caSTl+9q3b58xxpilS5eaFi1amODgYFO+fHnTvHlzM23aNJOTk1Nk43BRcY/HgQMHzG233WYqVapknE6nqV+/vnnsscfcPgfBGGP2799vunfvboKCgkyVKlXM6NGj3R7HLCrFPR4XxcfHm1q1auX7My8px8e+ffvyPc7bt29f4D6NMebs2bPmn//8p6lYsaIpV66c6d27t0lJSXFrUxKOD2+MR2k6f3hjPErT+cNb/16MKb7zh8OYInyWDAAA4BpwjwoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQBe43A49PHHHxd6/XHjxqlFixZeq6cwOnTooEceecSnNQD4/wgqwHVs0KBBuvPOOz1e73KBIiUlRd27dy9QH/mFmjFjxuT5HiMA1zd/XxcAoPS41m+JDQ4OVnBwsJeqAVAacEUFKOU++ugjNW3aVEFBQapcubK6dOmiM2fOaNy4cZo1a5Y++eQTORwOORwOrVq1SpL0xBNPqEGDBipXrpzq1q2r//u//1NWVpYkaebMmUpISNDmzZtd682cOVOS+1WS8+fPa/jw4apevbrKli2ryMhIJSYmSpKioqIkSb1795bD4XBN53elZsaMGWrcuLGcTqeqV6+u4cOH57ufn3/+ucqWLavTp0+7zR85cqQ6deokSTp58qT69++vP/zhDypXrpyaNm2q2bNnX3H88rvyExYW5tpnSTp48KD++te/KiwsTJUqVVKvXr20f//+K/YLoGC4ogKUYikpKerfv79eeOEF9e7dW+np6frmm29kjNGYMWP0448/Ki0tTUlJSZKkSpUqSZJCQkI0c+ZM1ahRQ1u3btXQoUMVEhKixx9/XHfddZe2bdumZcuW6YsvvpAkVahQIc+2X331VS1atEjz5s1T7dq1dfDgQR08eFCStG7dOkVERCgpKUndunWTn59fvvVPnTpVo0aN0sSJE9W9e3elpqZq9erV+bbt3LmzwsLC9N///ldDhgyRJOXk5Gju3LkaP368JOncuXOKiYnRE088odDQUC1evFj33nuv6tWrp1atWhVqjLOyshQbG6s2bdrom2++kb+/v55//nl169ZNW7ZsUWBgYKH6BXABQQUoxVJSUpSdna0+ffooMjJSktS0aVPX8qCgIGVmZuZ5y+bpp592/T0qKkpjxozRnDlz9PjjjysoKEjBwcHy9/e/4ls9Bw4cUHR0tNq2bSuHw+HaviSFh4dLunBl4kp9PP/88xo9erRGjhzpmvfHP/4x37Z+fn7629/+pg8//NAVVFasWKHTp0+rb9++kqQ//OEPGjNmjGudhx9+WJ999pnmzZtX6KAyd+5c5ebm6t1335XD4ZAkJSUlKSwsTKtWrVLXrl0L1S+ACwgqQCnWvHlzde7cWU2bNlVsbKy6du2qfv36qWLFildcb+7cuXr11Ve1d+9eZWRkKDs7W6GhoR5te9CgQbr99tvVsGFDdevWTT179vTol/bx48d15MgRde7cucDrDBgwQLfccouOHDmiGjVq6IMPPlBcXJzCwsIkXbjCMmHCBM2bN0+HDx/W+fPnlZmZqXLlynm0b5favHmz9uzZo5CQELf5586d0969ewvdL4ALuEcFKMX8/Py0fPlyLV26VI0aNdJrr72mhg0bat++fZddZ82aNRowYIB69OihTz/9VBs3btRTTz2l8+fPe7Ttli1bat++fXruued09uxZ/fWvf1W/fv0KvH5QUJBH25MuXG2pV6+e5syZo7Nnz2rhwoUaMGCAa/mkSZP0yiuv6IknntDKlSu1adMmxcbGXnHfHA6HjDFu8y7eryNJGRkZiomJ0aZNm9xeu3bt0t133+3xPgBwxxUVoJRzOBy69dZbdeutt+qZZ55RZGSkFi5cqFGjRikwMFA5OTlu7b/99ltFRkbqqaeecs37+eef3drkt15+QkNDddddd+muu+5Sv3791K1bN/3666+qVKmSAgICrthHSEiIoqKitGLFCnXs2LHA+ztgwAB98MEHqlmzpsqUKaO4uDjXstWrV6tXr1665557JEm5ubnatWuXGjVqdNn+wsPDlZKS4prevXu3fvvtN9d0y5YtNXfuXEVERHh81QnA1XFFBSjFvv/+e02YMEHJyck6cOCAFixYoBMnTujGG2+UdOH+ky1btmjnzp365ZdflJWVpejoaB04cEBz5szR3r179eqrr2rhwoVu/UZFRWnfvn3atGmTfvnlF2VmZubZ9uTJkzV79mzt2LFDu3bt0vz581WtWjXX2zAXQ8jRo0d16tSpfOsfN26cXnrpJb366qvavXu3NmzYoNdee+2K+zxgwABt2LBB48ePV79+/eR0Ol3LoqOjtXz5cn377bf68ccf9dBDD+nYsWNX7K9Tp056/fXXtXHjRiUnJ+vvf/+7AgIC3LZXpUoV9erVS99884327dunVatWacSIETp06NAV+wZQAAZAqfXDDz+Y2NhYEx4ebpxOp2nQoIF57bXXXMuPHz9ubr/9dhMcHGwkmZUrVxpjjHnsscdM5cqVTXBwsLnrrrvMyy+/bCpUqOBa79y5c6Zv374mLCzMSDJJSUnGGGMkmYULFxpjjHn77bdNixYtTPny5U1oaKjp3Lmz2bBhg6uPRYsWmfr16xt/f38TGRlpjDFm7Nixpnnz5m77MG3aNNOwYUMTEBBgqlevbh5++OGr7nerVq2MJPPll1+6zT958qTp1auXCQ4ONhEREebpp5829913n+nVq5erTfv27c3IkSNd04cPHzZdu3Y15cuXN9HR0WbJkiWmQoUKrn02xpiUlBRz3333mSpVqhin02nq1q1rhg4dalJTU69aK4ArcxjzuzdfAQAALMFbPwAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABY6/8BkQOQzFV/kuoAAAAASUVORK5CYII=",
      "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": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "643d74d6-1c84-49b6-af3f-23f57ef86245",
   "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
}
