{
 "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": "46fa7fd5-34ca-4e86-8773-f5ff38b758da",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"val_5000_0.5_scores_10.pkl\", 'rb') as handle:\n",
    "    seed_score_list = pickle.load(handle)\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:8].mean(axis=0))\n",
    "\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:8].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0843462-d2bc-4509-8a9e-210ab9691a5f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1aa3dbcd-855e-405a-ab27-b19f4261dcee",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"val_5000_0.5_scores_100.pkl\", 'rb') as handle:\n",
    "    seed_score_list = pickle.load(handle)\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:8].mean(axis=0))\n",
    "\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:8].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "51feac50-3440-4396-a6e6-5f2a6080dbf2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b1e2f974-ea7b-4832-a740-44f53ab2c2c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "16"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(scores_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bec15b45-0542-4b6d-8bf7-9d47a53584c1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2091b23-f9b9-4627-83f8-2f755e638328",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3094d577-6791-4900-953b-d0d27e3d3d14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "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": 12,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 12,
     "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": 13,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 13,
     "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": 14,
   "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": 15,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.133 (avg p value 0.349800)\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": 16,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.138 (avg p value 0.342988)\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": 17,
   "id": "f2f44265-e343-4000-9a48-454971ff77dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.138 (avg p value 0.340624)\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": 18,
   "id": "af35be81-8658-4113-b6bc-dd2e4bb8cecd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.139 (avg p value 0.340260)\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": 19,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.234 (avg p value 0.186854)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[4]\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": "2e7e5692-4830-4c5c-968e-7d764cd8d6d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.242 (avg p value 0.173079)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[5]\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": 21,
   "id": "a072c7d1-c21b-4601-9e55-77c5fdc8fc15",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.245 (avg p value 0.167000)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[6]\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": 22,
   "id": "5dd118c9-1194-4abf-8bac-cb47fe02efd6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.246 (avg p value 0.164536)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[7]\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": 23,
   "id": "c882e2d5-0085-4e9e-a2cd-204fccd54b32",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.224 (avg p value 0.191780)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[8]\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": 24,
   "id": "9381fc34-eeb4-4caa-b26f-de314203fde9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.240 (avg p value 0.166181)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[9]\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": 25,
   "id": "720421d6-a38d-4da6-b2cb-6f99db900451",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.249 (avg p value 0.153691)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[10]\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": 26,
   "id": "a48f721c-44c8-479e-a801-23b2c9111288",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.252 (avg p value 0.151708)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[11]\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": 27,
   "id": "1c7ac786-ec7d-4650-94e7-82dd90284eec",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.283 (avg p value 0.116443)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[12]\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": 28,
   "id": "f4ce95dd-d83e-4df0-9abb-4673bc913d39",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.291 (avg p value 0.108136)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[13]\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": 29,
   "id": "e492d9d3-70d7-4093-9774-7849a46540e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.300 (avg p value 0.099725)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[14]\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": 30,
   "id": "f5b5a0d0-1582-4c10-a5f3-f969c8f31101",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.300 (avg p value 0.100309)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[15]\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": "9634055b-63df-48f0-a208-069b624568d6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7868aad5-ca5e-4914-b959-d1981fac0e77",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "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": 32,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.12692289439229823, high=0.14140244678591105)\n",
      "0.127\n",
      "0.141\n",
      "1\n",
      "ConfidenceInterval(low=0.1316332317326585, high=0.14570573130929304)\n",
      "0.132\n",
      "0.146\n",
      "2\n",
      "ConfidenceInterval(low=0.13108873101260432, high=0.14527161025506083)\n",
      "0.131\n",
      "0.145\n",
      "3\n",
      "ConfidenceInterval(low=0.13237305727574714, high=0.14573115334240086)\n",
      "0.132\n",
      "0.146\n",
      "4\n",
      "ConfidenceInterval(low=0.2259314309964518, high=0.2398187867939085)\n",
      "0.226\n",
      "0.24\n",
      "5\n",
      "ConfidenceInterval(low=0.2337691738924487, high=0.24831822238481213)\n",
      "0.234\n",
      "0.248\n",
      "6\n",
      "ConfidenceInterval(low=0.23563212681313705, high=0.2508394936229778)\n",
      "0.236\n",
      "0.251\n",
      "7\n",
      "ConfidenceInterval(low=0.23665264168364677, high=0.2519743645533102)\n",
      "0.237\n",
      "0.252\n",
      "8\n",
      "ConfidenceInterval(low=0.21722113209038477, high=0.23206361531032266)\n",
      "0.217\n",
      "0.232\n",
      "9\n",
      "ConfidenceInterval(low=0.23499678601259055, high=0.24818588916386536)\n",
      "0.235\n",
      "0.248\n",
      "10\n",
      "ConfidenceInterval(low=0.24459465110477616, high=0.2559671844783716)\n",
      "0.245\n",
      "0.256\n",
      "11\n",
      "ConfidenceInterval(low=0.24800411407717254, high=0.2585892994557142)\n",
      "0.248\n",
      "0.259\n",
      "12\n",
      "ConfidenceInterval(low=0.27464238109982275, high=0.28814551381848197)\n",
      "0.275\n",
      "0.288\n",
      "13\n",
      "ConfidenceInterval(low=0.28414639469699166, high=0.29813920005049493)\n",
      "0.284\n",
      "0.298\n",
      "14\n",
      "ConfidenceInterval(low=0.2920410856575059, high=0.3044955706851518)\n",
      "0.292\n",
      "0.304\n",
      "15\n",
      "ConfidenceInterval(low=0.2936426670957337, high=0.30586486757900133)\n",
      "0.294\n",
      "0.306\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(16):\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": 33,
   "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": 34,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA0+UlEQVR4nO3deXgUVd7+/7tJSBNIQlgSlgESCIuyaxCHB5BVAgQf1hkHUcOi4zhBQECFrzNCRiAoI+I2MG4BRwXEAfXRQUS2cYewCiqbIAGCQYUkgDQhOb8/uOifbQKkQyd1CO/XdfUlVX2q6lN9utK3p6q6XcYYIwAAAAtVcLoAAACACyGoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAuKLNnz9fLpdL+/fvL/VtDR8+XLGxsd7p/fv3y+Vy6e9//3upb1uSpk6dKpfLVSbbAmxBUAFK4PyH4y8f0dHR6tatm5YvX17q2//HP/6h+fPnl2jZ//znP5o6dWpA6wmUtWvX+rymbrdbtWrVUteuXTVjxgwdPXo0INs5deqUpk6dqrVr1wZkfYFkc22AEwgqwGX429/+pn/961965ZVX9OCDD+ro0aPq27ev3n333VLd7uUGlZSUlMAWFGBjxozRv/71Lz3//PN64IEHVL16dU2ZMkXXXnutVq9e7dP2jjvu0M8//6yYmJhir//UqVNKSUnxOwy88MIL2rlzp1/L+Otitf3lL3/Rzz//XKrbB2wT7HQBwJWsT58+ateunXd61KhRqlWrlhYuXKh+/fo5WFlgnD17VgUFBQoJCSnT7Xbu3FlDhgzxmbd161b16tVLgwcP1ldffaU6depIkoKCghQUFFSq9Zw8eVJVqlRRxYoVS3U7lxIcHKzgYP5s4+rCiAoQQJGRkQoNDS30YXLy5ElNmDBB9evXl9vtVrNmzfT3v/9dv/7x8rNnz+rRRx9VXFyc3G63YmNj9f/+3/+Tx+PxtomNjdWOHTu0bt067ymSrl27SpLy8vKUkpKiJk2aqFKlSqpRo4Y6deqklStXSjp3jcVzzz0nST6nWCTf6y3mzJnjreGrr77SmTNn9Mgjjyg+Pl5Vq1ZVlSpV1LlzZ61Zs8an/l+u48knn1RMTIxCQ0PVpUsXbd++/bJe2zZt2mjOnDk6fvy4nn32We/8oq5RSU9PV0JCgmrWrKnQ0FA1bNhQI0eO9NYYFRUlSUpJSfG+BudPhw0fPlxhYWHau3ev+vbtq/DwcA0bNsz73C+vUfmlS+1v165dvf30S79c56VqK+oaleK8Z6Rz75t+/frp448/Vvv27VWpUiU1atRIr7zyStEvOGAJojlwGbKzs/XDDz/IGKOsrCw988wzOnHihG6//XZvG2OM/vd//1dr1qzRqFGj1LZtW61YsUIPPPCADh06pCeffNLb9q677tKCBQs0ZMgQTZgwQV988YVSU1P19ddfa9myZZKkOXPm6L777lNYWJgefvhhSVKtWrUknfsgS01N1V133aX27dsrJydH6enp2rRpk26++Wbdc889Onz4sFauXKl//etfRe5TWlqaTp8+rT/+8Y9yu92qXr26cnJy9OKLL2ro0KG6++67lZubq5deekkJCQlav3692rZt67OOV155Rbm5uUpOTtbp06f11FNPqXv37vryyy+9tZbEkCFDNGrUKH3wwQeaPn16kW2ysrLUq1cvRUVFadKkSYqMjNT+/fu1dOlSSVJUVJTmzp2re++9VwMHDtSgQYMkSa1bt/au4+zZs0pISFCnTp3097//XZUrV75oXYHa3+LU9mvFec+ct2fPHu9rmJSUpJdfflnDhw9XfHy8WrRoUew6gTJlAPgtLS3NSCr0cLvdZv78+T5t33rrLSPJTJs2zWf+kCFDjMvlMnv27DHGGLNlyxYjydx1110+7SZOnGgkmdWrV3vntWjRwnTp0qVQXW3atDGJiYkXrT05OdkUdejv27fPSDIREREmKyvL57mzZ88aj8fjM+/YsWOmVq1aZuTIkYXWERoaag4ePOid/8UXXxhJ5v77779obWvWrDGSzJIlSy7Ypk2bNqZatWre6fN9sW/fPmOMMcuWLTOSzIYNGy64jqNHjxpJZsqUKYWeS0pKMpLMpEmTinwuJibGO+3P/nbp0qXIPvv1Oi9W25QpU3z6zp/3TExMjJFk/vvf/3rnZWVlGbfbbSZMmFBoW4AtOPUDXIbnnntOK1eu1MqVK/Xqq6+qW7duuuuuu7z/9y6du3g1KChIY8aM8Vl2woQJMsZ47xL6z3/+I0kaP358oXaS9N57712ynsjISO3YsUO7d+8u8T4NHjzYe/rhvKCgIO91KgUFBfrpp5909uxZtWvXTps2bSq0jgEDBug3v/mNd7p9+/a68cYbvft4OcLCwpSbm3vB5yMjIyVJ7777rvLy8kq8nXvvvbfYbUtzfy/G3/dM8+bN1blzZ+90VFSUmjVrpm+//bZU6wQuB0EFuAzt27dXz5491bNnTw0bNkzvvfeemjdvrtGjR+vMmTOSpO+++05169ZVeHi4z7LXXnut9/nz/61QoYIaN27s06527dqKjIz0truYv/3tbzp+/LiaNm2qVq1a6YEHHtC2bdv82qeGDRsWOX/BggVq3bq199qXqKgovffee8rOzi7UtkmTJoXmNW3aNCDfdXLixIlCr+UvdenSRYMHD1ZKSopq1qyp/v37Ky0trdA1GxcTHBysevXqFbt9ae7vxfj7nmnQoEGhdVSrVk3Hjh0r1TqBy0FQAQKoQoUK6tatmzIzM0s8qnE5X+h10003ae/evXr55ZfVsmVLvfjii7r++uv14osvFnsdoaGhhea9+uqrGj58uOLi4vTSSy/p/fff18qVK9W9e3cVFBSUuF5/5eXladeuXYU+mH/J5XLpzTff1GeffabRo0fr0KFDGjlypOLj43XixIlibcftdqtChcD+ebxQv+bn55faun/tQndHmV9d1A3YhKACBNjZs2clyfuhGBMTo8OHDxc6XfHNN994nz//34KCgkIB5/vvv9fx48d9vifkYh9M1atX14gRI7Rw4UJlZGSodevWPl/wVpIg9Oabb6pRo0ZaunSp7rjjDiUkJKhnz546ffp0ke2LCmm7du264B0z/tTx888/KyEh4ZJtf/vb32r69OlKT0/Xa6+9ph07dmjRokWSLi8MFqU4+1utWjUdP368ULtfj3r4U5s/7xngSkVQAQIoLy9PH3zwgUJCQryndvr27av8/HyfW2qlc7ezulwu9enTx9tOOndXzy/Nnj1bkpSYmOidV6VKlSI/9H788Uef6bCwMDVu3NjntEeVKlUkqcjlL+T8/4n/8v+8v/jiC3322WdFtn/rrbd06NAh7/T69ev1xRdfePe1JLZu3apx48apWrVqSk5OvmC7Y8eOFRohOH9X0vnX4fxdPP68BhdTnP2Ni4vTN9984/Ptulu3btUnn3zisy5/avPnPQNcqbg9GbgMy5cv946MZGVl6fXXX9fu3bs1adIkRURESJJuueUWdevWTQ8//LD279+vNm3a6IMPPtDbb7+tcePGKS4uTtK5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LpdLb731VomXnzp1qtq2bRuwekqia9euGjdunKM1APj/EVSAq9jw4cM1YMAAv5e7UKDIzMxUnz59irWOokLNxIkTfX6nBACCnS4AQPlxub/QGhYWprCwsABVA6A8YEQFKOfefPNNtWrVSqGhoapRo4Z69uypkydPaurUqVqwYIHefvttuVwuuVwurV27VpL00EMPqWnTpqpcubIaNWqkv/71r8rLy5MkzZ8/XykpKdq6dat3ufnz50vyHSU5c+aMRo8erTp16qhSpUqKiYlRamqqJCk2NlaSNHDgQLlcLu90USM1L7/8slq0aCG32606depo9OjRRe7nBx98oEqVKhX6ifuxY8eqe/fukqQff/xRQ4cO1W9+8xtVrlxZrVq10sKFCy/6+hU18hMZGendZ0nKyMjQ73//e0VGRqp69erq37+/9u/ff9H1AigeRlSAciwzM1NDhw7V448/roEDByo3N1cfffSRjDGaOHGivv76a+Xk5CgtLU2SVL16dUlSeHi45s+fr7p16+rLL7/U3XffrfDwcD344IO69dZbtX37dr3//vv68MMPJUlVq1YttO2nn35a77zzjt544w01aNBAGRkZysjIkCRt2LBB0dHRSktLU+/evRUUFFRk/XPnztX48eM1c+ZM9enTR9nZ2frkk0+KbNujRw9FRkbq3//+t0aNGiVJys/P1+LFizV9+nRJ0unTpxUfH6+HHnpIEREReu+993THHXcoLi5O7du3L9FrnJeXp4SEBHXo0EEfffSRgoODNW3aNPXu3Vvbtm1TSEhIidYL4ByCClCOZWZm6uzZsxo0aJBiYmIkSa1atfI+HxoaKo/HU+iUzV/+8hfvv2NjYzVx4kQtWrRIDz74oEJDQxUWFqbg4OCLnuo5cOCAmjRpok6dOsnlcnm3L0lRUVGSzo1MXGwd06ZN04QJEzR27FjvvBtuuKHItkFBQfrDH/6g119/3RtUVq1apePHj2vw4MGSpN/85jeaOHGid5n77rtPK1as0BtvvFHioLJ48WIVFBToxRdflMvlkiSlpaUpMjJSa9euVa9evUq0XgDnEFSAcqxNmzbq0aOHWrVqpYSEBPXq1UtDhgxRtWrVLrrc4sWL9fTTT2vv3r06ceKEzp49q4iICL+2PXz4cN18881q1qyZevfurX79+vn1oZ2VlaXDhw+rR48exV5m2LBh+u1vf6vDhw+rbt26eu2115SYmKjIyEhJ50ZYZsyYoTfeeEOHDh3SmTNn5PF4VLlyZb/27Ze2bt2qPXv2KDw83Gf+6dOntXfv3hKvF8A5XKMClGNBQUFauXKlli9frubNm+uZZ55Rs2bNtG/fvgsu89lnn2nYsGHq27ev3n33XW3evFkPP/ywzpw549e2r7/+eu3bt0+PPvqofv75Z/3+97/XkCFDir18aGioX9uTzo22xMXFadGiRfr555+1bNkyDRs2zPv8rFmz9NRTT+mhhx7SmjVrtGXLFiUkJFx031wul4wxPvPOX68jSSdOnFB8fLy2bNni89i1a5duu+02v/cBgC9GVIByzuVyqWPHjurYsaMeeeQRxcTEaNmyZRo/frxCQkKUn5/v0/7TTz9VTEyMHn74Ye+87777zqdNUcsVJSIiQrfeeqtuvfVWDRkyRL1799ZPP/2k6tWrq2LFihddR3h4uGJjY7Vq1Sp169at2Ps7bNgwvfbaa6pXr54qVKigxMRE73OffPKJ+vfvr9tvv12SVFBQoF27dql58+YXXF9UVJQyMzO907t379apU6e809dff70WL16s6Ohov0edAFwaIypAOfbFF19oxowZSk9P14EDB7R06VIdPXpU1157raRz159s27ZNO3fu1A8//KC8vDw1adJEBw4c0KJFi7R37149/fTTWrZsmc96Y2NjtW/fPm3ZskU//PCDPB5PoW3Pnj1bCxcu1DfffKNdu3ZpyZIlql27tvc0zPkQcuTIER07dqzI+qdOnaonnnhCTz/9tHbv3q1NmzbpmWeeueg+Dxs2TJs2bdL06dM1ZMgQud1u73NNmjTRypUr9emnn+rrr7/WPffco++///6i6+vevbueffZZbd68Wenp6frTn/6kihUr+myvZs2a6t+/vz766CPt27dPa9eu1ZgxY3Tw4MGLrhtAMRgA5dZXX31lEhISTFRUlHG73aZp06bmmWee8T6flZVlbr75ZhMWFmYkmTVr1hhjjHnggQdMjRo1TFhYmLn11lvNk08+aapWrepd7vTp02bw4MEmMjLSSDJpaWnGGGMkmWXLlhljjHn++edN27ZtTZUqVUxERITp0aOH2bRpk3cd77zzjmncuLEJDg42MTExxhhjpkyZYtq0aeOzD/PmzTPNmjUzFStWNHXq1DH33XffJfe7ffv2RpJZvXq1z/wff/zR9O/f34SFhZno6Gjzl7/8xdx5552mf//+3jZdunQxY8eO9U4fOnTI9OrVy1SpUsU0adLE/Oc//zFVq1b17rMxxmRmZpo777zT1KxZ07jdbtOoUSNz9913m+zs7EvWCuDiXMb86uQrAACAJTj1AwAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1/j+INMcFK1ernAAAAABJRU5ErkJggg==",
      "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
}
