{
 "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": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_10_5000000.0_0.11501568436700177.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, 5000)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_100_5000000.0_0.2029554791786418.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, 5000)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_mean-squared-l2-norm_10_5000000.0_0.23101900995059702.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, 5000)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_mean-squared-l2-norm_100_5000000.0_0.2904445973362501.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": 11,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 11,
     "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": 12,
   "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": 13,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 13,
     "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": 14,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 14,
     "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": 15,
   "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": 16,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.115 (avg p value 0.381636)\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": 17,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.203 (avg p value 0.224466)\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": 18,
   "id": "f2f44265-e343-4000-9a48-454971ff77dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.231 (avg p value 0.186065)\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": 19,
   "id": "af35be81-8658-4113-b6bc-dd2e4bb8cecd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.290 (avg p value 0.115706)\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": 20,
   "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": 21,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.10707836162178513, high=0.12191832075487281)\n",
      "0.107\n",
      "0.122\n",
      "1\n",
      "ConfidenceInterval(low=0.19624827103019357, high=0.21242525694986134)\n",
      "0.196\n",
      "0.212\n",
      "2\n",
      "ConfidenceInterval(low=0.22151756765130315, high=0.23673342269903017)\n",
      "0.222\n",
      "0.237\n",
      "3\n",
      "ConfidenceInterval(low=0.28436796121436714, high=0.29612096694821605)\n",
      "0.284\n",
      "0.296\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": 22,
   "id": "7793c07e-c75c-48ca-a173-a9831391a624",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[0.10707836162178513,\n",
       "  0.12191832075487281,\n",
       "  array([0.10505059, 0.11167279, 0.10805076, 0.11272031, 0.11454976,\n",
       "         0.1160772 , 0.11225456, 0.10702394, 0.11184608, 0.11209567,\n",
       "         0.11451499, 0.11534982, 0.10764001, 0.11117859, 0.1070799 ,\n",
       "         0.10463577, 0.12040866, 0.11072577, 0.11877675, 0.11972433,\n",
       "         0.12065383, 0.11240166, 0.10652836, 0.10794881, 0.11729391,\n",
       "         0.11734998, 0.1155648 , 0.11615017, 0.11583453, 0.10923255,\n",
       "         0.11499224, 0.11943351, 0.11750729, 0.11022723, 0.11843552,\n",
       "         0.11687497, 0.10670605, 0.11232543, 0.10937716, 0.10163708,\n",
       "         0.11766439, 0.11050357, 0.10725851, 0.11019671, 0.12083206,\n",
       "         0.12047412, 0.11323111, 0.1222034 , 0.10786715, 0.10861003,\n",
       "         0.11228111, 0.11761647, 0.10735609, 0.11633949, 0.10828713,\n",
       "         0.11536847, 0.11307901, 0.11426085, 0.11263983, 0.11101857,\n",
       "         0.10548779, 0.11772877, 0.11084296, 0.10954872]),\n",
       "  0.004769651979325572],\n",
       " [0.19624827103019357,\n",
       "  0.21242525694986134,\n",
       "  array([0.18856668, 0.20334849, 0.19971023, 0.19435675, 0.20284945,\n",
       "         0.19752124, 0.19253897, 0.1917318 , 0.19672654, 0.202815  ,\n",
       "         0.19982798, 0.20058167, 0.19744335, 0.19586557, 0.19471043,\n",
       "         0.19372992, 0.20952285, 0.20181235, 0.20389417, 0.20540101,\n",
       "         0.20943211, 0.20242865, 0.20180504, 0.19642371, 0.20141702,\n",
       "         0.19948777, 0.20397283, 0.20169522, 0.20439688, 0.19590098,\n",
       "         0.19967262, 0.20880637, 0.20780965, 0.20105728, 0.20476496,\n",
       "         0.2009235 , 0.20201617, 0.2000523 , 0.19740161, 0.19160321,\n",
       "         0.20744738, 0.19936653, 0.19540091, 0.20314246, 0.20689105,\n",
       "         0.21254547, 0.19987413, 0.20476342, 0.19685471, 0.19714031,\n",
       "         0.20075551, 0.20391318, 0.20187076, 0.20101885, 0.19619357,\n",
       "         0.19770873, 0.19453802, 0.20766933, 0.19589987, 0.19787947,\n",
       "         0.19550416, 0.20154111, 0.19621622, 0.19360823]),\n",
       "  0.004930109943728423],\n",
       " [0.22151756765130315,\n",
       "  0.23673342269903017,\n",
       "  array([0.2281187 , 0.23245644, 0.22992416, 0.22171586, 0.23130421,\n",
       "         0.22895887, 0.22989596, 0.22044999, 0.22687794, 0.22424469,\n",
       "         0.22495181, 0.2290973 , 0.2264601 , 0.22751843, 0.22584534,\n",
       "         0.23171657, 0.22871281, 0.22022523, 0.23176274, 0.22840426,\n",
       "         0.22769767, 0.2320048 , 0.22526766, 0.23532259, 0.23392734,\n",
       "         0.23300722, 0.23414139, 0.22957314, 0.23204912, 0.22301867,\n",
       "         0.23199699, 0.23714225, 0.22074776, 0.21637438, 0.23068623,\n",
       "         0.22483755, 0.21903408, 0.23322414, 0.23300111, 0.22165912,\n",
       "         0.23498765, 0.22713943, 0.22449463, 0.23316516, 0.23498448,\n",
       "         0.23242097, 0.23329741, 0.2284853 , 0.22352564, 0.22448202,\n",
       "         0.2299077 , 0.23577034, 0.23115802, 0.22628041, 0.22529792,\n",
       "         0.22545232, 0.23216124, 0.23519422, 0.22996534, 0.22895583,\n",
       "         0.21190534, 0.2320088 , 0.22587221, 0.22190274]),\n",
       "  0.005112290496501076],\n",
       " [0.28436796121436714,\n",
       "  0.29612096694821605,\n",
       "  array([0.28535093, 0.29134525, 0.28755665, 0.27792716, 0.29322779,\n",
       "         0.28514924, 0.29083524, 0.28377061, 0.28646196, 0.28265022,\n",
       "         0.2813987 , 0.28977763, 0.28649781, 0.28385139, 0.28315892,\n",
       "         0.28847721, 0.29112575, 0.28148261, 0.29178538, 0.28820683,\n",
       "         0.28571894, 0.28984864, 0.28429465, 0.28813919, 0.29035735,\n",
       "         0.28972391, 0.29612328, 0.28783906, 0.29275815, 0.28233143,\n",
       "         0.28826813, 0.29602429, 0.28192253, 0.27957863, 0.28937464,\n",
       "         0.28127495, 0.27668422, 0.29118816, 0.29133382, 0.28436434,\n",
       "         0.28759904, 0.28907279, 0.28121015, 0.29073463, 0.29056747,\n",
       "         0.29159573, 0.28896725, 0.28347894, 0.28291383, 0.28372417,\n",
       "         0.28882662, 0.28738729, 0.28661934, 0.28448449, 0.28727167,\n",
       "         0.28646486, 0.29090773, 0.29467801, 0.28999969, 0.28687061,\n",
       "         0.27523223, 0.2901287 , 0.28362559, 0.28465985]),\n",
       "  0.00444523414709984]]"
      ]
     },
     "execution_count": 22,
     "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": 23,
   "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": 24,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAyi0lEQVR4nO3dd3RU1f7//9eQMgTSCCQQBJJQla5BkAVIldD8UO9VRCki1+sNHSxcvUKuICiKWMEasFDES9SvDREBC0WKgJUSQQIEgwgJARNCsn9/sJgfYwJkwoTZkOdjrVlw9uyzz/vMTpgXp8w4jDFGAAAAFirn6wIAAADOhaACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoALgsjZv3jw5HA7t2bOn1Lc1dOhQxcbGupb37Nkjh8OhJ554otS3LUlTpkyRw+G4JNsCbEFQAUrgzJvj2Y+oqCh17NhRH3/8calv/4UXXtC8efNKtO5HH32kKVOmeLUeb1m1apXba+p0OlW1alV16NBBjz76qA4dOuSV7Zw4cUJTpkzRqlWrvDKeN9lcG+ALBBXgIvz3v//VG2+8oddff1333XefDh06pB49euiDDz4o1e1ebFBJSkrybkFeNnr0aL3xxht66aWXdO+99yoiIkKTJ0/WNddco88//9yt7x133KE///xTMTExxR7/xIkTSkpK8jgMvPzyy9q+fbtH63jqfLU99NBD+vPPP0t1+4Bt/H1dAHA56969u1q0aOFaHj58uKpWraqFCxeqV69ePqzMO06dOqWCggIFBgZe0u22a9dOAwYMcGvbunWrunbtqv79++vHH39UdHS0JMnPz09+fn6lWs/x48dVsWJFBQQElOp2LsTf31/+/vyzjbKFIyqAF4WHhysoKKjQm8nx48c1YcIE1axZU06nUw0aNNATTzyhv355+alTp/TII4+oTp06cjqdio2N1b///W/l5ua6+sTGxuqHH37Q6tWrXadIOnToIEnKy8tTUlKS6tWrp/Lly6ty5cpq27atli9fLun0NRbPP/+8JLmdYpHcr7eYPXu2q4Yff/xRJ0+e1MMPP6z4+HiFhYWpYsWKateunVauXOlW/9ljPPXUU4qJiVFQUJDat2+v77///qJe22bNmmn27Nk6evSonnvuOVd7UdeobNy4UQkJCapSpYqCgoIUFxenO++801VjZGSkJCkpKcn1Gpw5HTZ06FAFBwcrNTVVPXr0UEhIiAYNGuR67uxrVM52of3t0KGDa57OdvaYF6qtqGtUivMzI53+uenVq5e++uortWzZUuXLl1ft2rX1+uuvF/2CA5YgmgMXITMzU7///ruMMcrIyNCzzz6r7Oxs3X777a4+xhj93//9n1auXKnhw4erefPmWrZsme69917t379fTz31lKvvXXfdpfnz52vAgAGaMGGC1q9fr+nTp+unn35SSkqKJGn27NkaNWqUgoOD9eCDD0qSqlatKun0G9n06dN11113qWXLlsrKytLGjRu1efNm3XTTTbr77rt14MABLV++XG+88UaR+5ScnKycnBz94x//kNPpVEREhLKysvTKK69o4MCBGjFihI4dO6ZXX31VCQkJ+uabb9S8eXO3MV5//XUdO3ZMiYmJysnJ0dNPP61OnTrpu+++c9VaEgMGDNDw4cP16aefatq0aUX2ycjIUNeuXRUZGakHHnhA4eHh2rNnj5YuXSpJioyM1Jw5c3TPPfeob9++6tevnySpadOmrjFOnTqlhIQEtW3bVk888YQqVKhw3rq8tb/Fqe2vivMzc8auXbtcr+GQIUP02muvaejQoYqPj1ejRo2KXSdwSRkAHktOTjaSCj2cTqeZN2+eW993333XSDJTp051ax8wYIBxOBxm165dxhhjtmzZYiSZu+66y63fxIkTjSTz+eefu9oaNWpk2rdvX6iuZs2amZ49e5639sTERFPUr/7u3buNJBMaGmoyMjLcnjt16pTJzc11azty5IipWrWqufPOOwuNERQUZPbt2+dqX79+vZFkxo0bd97aVq5caSSZJUuWnLNPs2bNTKVKlVzLZ+Zi9+7dxhhjUlJSjCSzYcOGc45x6NAhI8lMnjy50HNDhgwxkswDDzxQ5HMxMTGuZU/2t3379kXO2V/HPF9tkydPdps7T35mYmJijCTzxRdfuNoyMjKM0+k0EyZMKLQtwBac+gEuwvPPP6/ly5dr+fLlevPNN9WxY0fdddddrv+9S6cvXvXz89Po0aPd1p0wYYKMMa67hD766CNJ0vjx4wv1k6QPP/zwgvWEh4frhx9+0M6dO0u8T/3793edfjjDz8/PdZ1KQUGB/vjjD506dUotWrTQ5s2bC43Rp08fXXXVVa7lli1bqlWrVq59vBjBwcE6duzYOZ8PDw+XJH3wwQfKy8sr8XbuueeeYvctzf09H09/Zho2bKh27dq5liMjI9WgQQP98ssvpVoncDEIKsBFaNmypbp06aIuXbpo0KBB+vDDD9WwYUONHDlSJ0+elCT9+uuvql69ukJCQtzWveaaa1zPn/mzXLlyqlu3rlu/atWqKTw83NXvfP773//q6NGjql+/vpo0aaJ7771X27Zt82if4uLiimyfP3++mjZt6rr2JTIyUh9++KEyMzML9a1Xr16htvr163vls06ys7MLvZZna9++vfr376+kpCRVqVJFvXv3VnJycqFrNs7H399fNWrUKHb/0tzf8/H0Z6ZWrVqFxqhUqZKOHDlSqnUCF4OgAnhRuXLl1LFjR6Wnp5f4qMbFfKDXjTfeqNTUVL322mtq3LixXnnlFV133XV65ZVXij1GUFBQobY333xTQ4cOVZ06dfTqq6/qk08+0fLly9WpUycVFBSUuF5P5eXlaceOHYXemM/mcDj0zjvvaO3atRo5cqT279+vO++8U/Hx8crOzi7WdpxOp8qV8+4/j+ea1/z8/FIb+6/OdXeU+ctF3YBNCCqAl506dUqSXG+KMTExOnDgQKHTFT///LPr+TN/FhQUFAo4v/32m44ePer2OSHne2OKiIjQsGHDtHDhQqWlpalp06ZuH/BWkiD0zjvvqHbt2lq6dKnuuOMOJSQkqEuXLsrJySmyf1EhbceOHee8Y8aTOv78808lJCRcsO8NN9ygadOmaePGjXrrrbf0ww8/aNGiRZIuLgwWpTj7W6lSJR09erRQv78e9fCkNk9+ZoDLFUEF8KK8vDx9+umnCgwMdJ3a6dGjh/Lz891uqZVO387qcDjUvXt3Vz/p9F09Z5s1a5YkqWfPnq62ihUrFvmmd/jwYbfl4OBg1a1b1+20R8WKFSWpyPXP5cz/xM/+n/f69eu1du3aIvu/++672r9/v2v5m2++0fr16137WhJbt27V2LFjValSJSUmJp6z35EjRwodIThzV9KZ1+HMXTyevAbnU5z9rVOnjn7++We3T9fdunWrvv76a7exPKnNk58Z4HLF7cnARfj4449dR0YyMjK0YMEC7dy5Uw888IBCQ0MlSTfffLM6duyoBx98UHv27FGzZs306aef6r333tPYsWNVp04dSac/J2TIkCF66aWXdPToUbVv317ffPON5s+frz59+qhjx46u7cbHx2vOnDmaOnWq6tatq6ioKHXq1EkNGzZUhw4dFB8fr4iICG3cuFHvvPOORo4c6baudPrTXxMSEuTn56dbb731vPvZq1cvLV26VH379lXPnj21e/duzZ07Vw0bNizydErdunXVtm1b3XPPPcrNzdXs2bNVuXJl3XfffcV6Xb/88kvl5OQoPz9fhw8f1tdff633339fYWFhSklJUbVq1c657vz58/XCCy+ob9++qlOnjo4dO6aXX35ZoaGhrjf2oKAgNWzYUIsXL1b9+vUVERGhxo0bq3HjxsWqryT7e+edd2rWrFlKSEjQ8OHDlZGRoblz56pRo0bKyspy9fOkNk9+ZoDLlm9vOgIuT0Xdnly+fHnTvHlzM2fOHFNQUODW/9ixY2bcuHGmevXqJiAgwNSrV8/MnDmzUL+8vDyTlJRk4uLiTEBAgKlZs6aZNGmSycnJcet38OBB07NnTxMSEmIkuW57nTp1qmnZsqUJDw83QUFB5uqrrzbTpk0zJ0+edK176tQpM2rUKBMZGWkcDofrdtczt9rOnDmz0P4WFBSYRx991MTExBin02muvfZa88EHH5zzdt2ZM2eaJ5980tSsWdM4nU7Trl07s3Xr1gu+rmduTz7zCAgIMJGRkebGG28006ZNK3Tb9Nlzceb25M2bN5uBAweaWrVqGafTaaKiokyvXr3Mxo0b3dZbs2aNiY+PN4GBgW63Aw8ZMsRUrFixyPoudn/ffPNNU7t2bRMYGGiaN29uli1bVmjM89X219uTjSn+z0xMTEyRt66f67ZpwBYOY7iKCoB37NmzR3FxcZo5c6YmTpzo63IAXAG4RgUAAFiLoAIAAKxFUAEAANbiGhUAAGAtjqgAAABrEVQAAIC1LusPfCsoKNCBAwcUEhLi9Y/EBgAApcMYo2PHjql69eoX/F6tyzqoHDhwQDVr1vR1GQAAoATS0tIu+E3ll3VQOfNV72lpaa6PKwcAAHbLyspSzZo1Xe/j53NZB5Uzp3tCQ0MJKgAAXGaKc9kGF9MCAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLV8HlT279+v22+/XZUrV1ZQUJCaNGmijRs3+rosAABgAZ9+18+RI0fUpk0bdezYUR9//LEiIyO1c+dOVapUyZdlAQAAS/g0qDz22GOqWbOmkpOTXW1xcXE+rAgAANjEp6d+3n//fbVo0UJ/+9vfFBUVpWuvvVYvv/yyL0sCAAAW8WlQ+eWXXzRnzhzVq1dPy5Yt0z333KPRo0dr/vz5RfbPzc1VVlaW2wMAAFy5HMYY46uNBwYGqkWLFlqzZo2rbfTo0dqwYYPWrl1bqP+UKVOUlJRUqD0zM1OhoaGlWisA74p94EOvjLNnRk+vjINLg3mHJGVlZSksLKxY798+PaISHR2thg0burVdc8012rt3b5H9J02apMzMTNcjLS3tUpQJAAB8xKcX07Zp00bbt293a9uxY4diYmKK7O90OuV0Oi9FaQAAwAI+PaIybtw4rVu3To8++qh27dqlBQsW6KWXXlJiYqIvywIAAJbwaVC5/vrrlZKSooULF6px48Z65JFHNHv2bA0aNMiXZQEAAEv49NSPJPXq1Uu9evXydRkAAMBCPv8IfQAAgHMhqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKzl06AyZcoUORwOt8fVV1/ty5IAAIBF/H1dQKNGjfTZZ5+5lv39fV4SAACwhM9Tgb+/v6pVq+brMgAAgIV8fo3Kzp07Vb16ddWuXVuDBg3S3r17z9k3NzdXWVlZbg8AAHDl8ukRlVatWmnevHlq0KCB0tPTlZSUpHbt2un7779XSEhIof7Tp09XUlKSDyrF5SD2gQ+9Ms6eGT29Mg4A4OL59IhK9+7d9be//U1NmzZVQkKCPvroIx09elRvv/12kf0nTZqkzMxM1yMtLe0SVwwAAC4ln1+jcrbw8HDVr19fu3btKvJ5p9Mpp9N5iasCAAC+4vNrVM6WnZ2t1NRURUdH+7oUAABgAZ8GlYkTJ2r16tXas2eP1qxZo759+8rPz08DBw70ZVkAAMASPj31s2/fPg0cOFCHDx9WZGSk2rZtq3Xr1ikyMtKXZQEAAEv4NKgsWrTIl5sHAACWs+oaFQAAgLMRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANayJqjMmDFDDodDY8eO9XUpAADAElYElQ0bNujFF19U06ZNfV0KAACwiM+DSnZ2tgYNGqSXX35ZlSpV8nU5AADAIj4PKomJierZs6e6dOlywb65ubnKyspyewAAgCuXvy83vmjRIm3evFkbNmwoVv/p06crKSmplKtCWRf7wIdeGWfPjJ5eGcc23np9vOVKnS/bXmfbXh+UHT47opKWlqYxY8borbfeUvny5Yu1zqRJk5SZmel6pKWllXKVAADAl3x2RGXTpk3KyMjQdddd52rLz8/XF198oeeee065ubny8/NzW8fpdMrpdF7qUgEAgI/4LKh07txZ3333nVvbsGHDdPXVV+v+++8vFFIAAEDZ47OgEhISosaNG7u1VaxYUZUrVy7UDgAAyiaf3/UDAABwLj696+evVq1a5esSAACARTiiAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADW8jio/PLLL6VRBwAAQCEeB5W6deuqY8eOevPNN5WTk1MaNQEAAEgqQVDZvHmzmjZtqvHjx6tatWq6++679c0335RGbQAAoIzzOKg0b95cTz/9tA4cOKDXXntN6enpatu2rRo3bqxZs2bp0KFDpVEnAAAog0p8Ma2/v7/69eunJUuW6LHHHtOuXbs0ceJE1axZU4MHD1Z6ero36wQAAGVQiYPKxo0b9a9//UvR0dGaNWuWJk6cqNTUVC1fvlwHDhxQ7969vVknAAAog/w9XWHWrFlKTk7W9u3b1aNHD73++uvq0aOHypU7nXni4uI0b948xcbGertWAABQxngcVObMmaM777xTQ4cOVXR0dJF9oqKi9Oqrr150cQAAoGzzOKjs3Lnzgn0CAwM1ZMiQEhUEAABwhsfXqCQnJ2vJkiWF2pcsWaL58+d7pSgAAACpBEFl+vTpqlKlSqH2qKgoPfroo14pCgAAQCpBUNm7d6/i4uIKtcfExGjv3r1eKQoAAEAqQVCJiorStm3bCrVv3bpVlStX9kpRAAAAUgmCysCBAzV69GitXLlS+fn5ys/P1+eff64xY8bo1ltvLY0aAQBAGeXxXT+PPPKI9uzZo86dO8vf//TqBQUFGjx4MNeoAAAAr/I4qAQGBmrx4sV65JFHtHXrVgUFBalJkyaKiYkpjfoAAEAZ5nFQOaN+/fqqX7++N2sBAABw43FQyc/P17x587RixQplZGSooKDA7fnPP//ca8UBAICyzeOgMmbMGM2bN089e/ZU48aN5XA4SqMuAAAAz4PKokWL9Pbbb6tHjx6lUQ8AAICLx7cnBwYGqm7duqVRCwAAgBuPg8qECRP09NNPyxhTGvUAAAC4eHzq56uvvtLKlSv18ccfq1GjRgoICHB7funSpV4rDgAAlG0eB5Xw8HD17du3NGoBAABw43FQSU5OLo06AAAACvH4GhVJOnXqlD777DO9+OKLOnbsmCTpwIEDys7O9mpxAACgbPP4iMqvv/6qbt26ae/evcrNzdVNN92kkJAQPfbYY8rNzdXcuXNLo04AAFAGeXxEZcyYMWrRooWOHDmioKAgV3vfvn21YsUKrxYHAADKNo+PqHz55Zdas2aNAgMD3dpjY2O1f/9+rxUGAADg8RGVgoIC5efnF2rft2+fQkJCvFIUAACAVIKg0rVrV82ePdu17HA4lJ2drcmTJ/Ox+gAAwKs8PvXz5JNPKiEhQQ0bNlROTo5uu+027dy5U1WqVNHChQtLo0YAAFBGeRxUatSooa1bt2rRokXatm2bsrOzNXz4cA0aNMjt4loAAICL5XFQkSR/f3/dfvvt3q4FAADAjcdB5fXXXz/v84MHDy5xMQAAAGfzOKiMGTPGbTkvL08nTpxQYGCgKlSoQFABAABe4/FdP0eOHHF7ZGdna/v27Wrbti0X0wIAAK8q0Xf9/FW9evU0Y8aMQkdbLmTOnDlq2rSpQkNDFRoaqtatW+vjjz/2RkkAAOAK4JWgIp2+wPbAgQMerVOjRg3NmDFDmzZt0saNG9WpUyf17t1bP/zwg7fKAgAAlzGPr1F5//333ZaNMUpPT9dzzz2nNm3aeDTWzTff7LY8bdo0zZkzR+vWrVOjRo08LQ0AAFxhPA4qffr0cVt2OByKjIxUp06d9OSTT5a4kPz8fC1ZskTHjx9X69atSzwOAAC4cngcVAoKCrxawHfffafWrVsrJydHwcHBSklJUcOGDYvsm5ubq9zcXNdyVlaWV2sBAAB2KdEHvnlTgwYNtGXLFmVmZuqdd97RkCFDtHr16iLDyvTp05WUlOSDKgHfiX3gQ1+XAA8wX4B3eRxUxo8fX+y+s2bNumCfwMBA1a1bV5IUHx+vDRs26Omnn9aLL75YqO+kSZPctp+VlaWaNWsWux4AAHB58TiofPvtt/r222+Vl5enBg0aSJJ27NghPz8/XXfdda5+DoejRAUVFBS4nd45m9PplNPpLNG4AADg8uNxULn55psVEhKi+fPnq1KlSpJOfwjcsGHD1K5dO02YMKHYY02aNEndu3dXrVq1dOzYMS1YsECrVq3SsmXLPC0LAABcgTwOKk8++aQ+/fRTV0iRpEqVKmnq1Knq2rWrR0ElIyNDgwcPVnp6usLCwtS0aVMtW7ZMN910k6dlAQCAK5DHQSUrK0uHDh0q1H7o0CEdO3bMo7FeffVVTzcPAADKEI8/mbZv374aNmyYli5dqn379mnfvn363//+p+HDh6tfv36lUSMAACijPD6iMnfuXE2cOFG33Xab8vLyTg/i76/hw4dr5syZXi8QAACUXR4HlQoVKuiFF17QzJkzlZqaKkmqU6eOKlas6PXiAABA2VbiLyVMT09Xenq66tWrp4oVK8oY4826AAAAPA8qhw8fVufOnVW/fn316NFD6enpkqThw4d7dMcPAADAhXgcVMaNG6eAgADt3btXFSpUcLXfcsst+uSTT7xaHAAAKNs8vkbl008/1bJly1SjRg239nr16unXX3/1WmEAAAAeH1E5fvy425GUM/744w8+3h4AAHiVx0GlXbt2ev31113LDodDBQUFevzxx9WxY0evFgcAAMo2j0/9PP744+rcubM2btyokydP6r777tMPP/ygP/74Q19//XVp1AgAAMooj4+oNG7cWDt27FDbtm3Vu3dvHT9+XP369dO3336rOnXqlEaNAACgjPLoiEpeXp66deumuXPn6sEHHyytmgAAACR5eEQlICBA27ZtK61aAAAA3Hh86uf222/nW48BAMAl4fHFtKdOndJrr72mzz77TPHx8YW+42fWrFleKw4AAJRtxQoq27ZtU+PGjVWuXDl9//33uu666yRJO3bscOvncDi8XyEAACizihVUrr32WqWnpysqKkq//vqrNmzYoMqVK5d2bQAAoIwr1jUq4eHh2r17tyRpz549KigoKNWiAAAApGIeUenfv7/at2+v6OhoORwOtWjRQn5+fkX2/eWXX7xaIAAAKLuKFVReeukl9evXT7t27dLo0aM1YsQIhYSElHZtAACgjCv2XT/dunWTJG3atEljxowhqAAAgFLn8e3JycnJpVEHAABAIR5/4BsAAMClQlABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADW8mlQmT59uq6//nqFhIQoKipKffr00fbt231ZEgAAsIhPg8rq1auVmJiodevWafny5crLy1PXrl11/PhxX5YFAAAs4e/LjX/yySduy/PmzVNUVJQ2bdqkG2+80UdVAQAAW/g0qPxVZmamJCkiIqLI53Nzc5Wbm+tazsrKuiR1AQAA37AmqBQUFGjs2LFq06aNGjduXGSf6dOnKykp6RJXhnOJfeBDr4yzZ0ZPr4xjG2+9PgAK4/frwq6Uf1utuesnMTFR33//vRYtWnTOPpMmTVJmZqbrkZaWdgkrBAAAl5oVR1RGjhypDz74QF988YVq1Khxzn5Op1NOp/MSVgYAAHzJp0HFGKNRo0YpJSVFq1atUlxcnC/LAQAAlvFpUElMTNSCBQv03nvvKSQkRAcPHpQkhYWFKSgoyJelAQAAC/j0GpU5c+YoMzNTHTp0UHR0tOuxePFiX5YFAAAs4fNTPwAAAOdizV0/AAAAf0VQAQAA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7GySTEpKiltbQUGBqVatmpk5c6ar7ejRo8bpdJqFCxd6VH9Z5Yt5M8aYIUOGmN69e3tYLYwp/TkzxpiMjAwjyaxevdoYc/r3KiAgwCxZssTV56effjKSzNq1az3fiSsER1TKqJMnT2rTpk3q0qWLq61cuXLq0qWL1q5dW+pjvvXWW6pSpYoaN26sSZMm6cSJEyXbkTKkNOasOHbv3q2DBw+6bTcsLEytWrUq1e1eKXw1b2esWrVKUVFRatCgge655x4dPny41Ld5ubtUc5aZmSlJioiIkCRt2rRJeXl5btu9+uqrVatWrTL9u2bFJ9Pi0vv999+Vn59f6KsKqlatqp9//rlUx7ztttsUExOj6tWra9u2bbr//vu1fft2LV26tETbLStKY86K4+DBg67t/HW7Z57Duflq3qTTp3369eunuLg4paam6t///re6d++utWvXys/Pr1S3fTm7FHNWUFCgsWPHqk2bNmrcuLGk079rgYGBhb5st6z/rhFUcMn94x//cP29SZMmio6OVufOnZWamqo6der4sDLgynLrrbe6/t6kSRM1bdpUderU0apVq9S5c2cfVobExER9//33+uqrr3xdivU49VNGValSRX5+foWuJv/tt9/OeSFYaY3ZqlUrSdKuXbtKtN2yojTmrDjOjH2pt3ul8NW8FaV27dqqUqUKv2sXUNpzNnLkSH3wwQdauXKlatSo4WqvVq2aTp48qaNHj5bKdi9XBJUyKjAwUPHx8VqxYoWrraCgQCtWrFDr1q0v6ZhbtmyRJEVHR5dou2VFacxZccTFxalatWpu283KytL69etLdbtXCl/NW1H27dunw4cP87t2AaU1Z8YYjRw5UikpKfr8888VFxfn9nx8fLwCAgLctrt9+3bt3bu3TP+uceqnDBs/fryGDBmiFi1aqGXLlpo9e7aOHz+uYcOGSZIGDx6sq666StOnT5d0+gKzH3/80fX3/fv3a8uWLQoODlbdunWLNWZqaqoWLFigHj16qHLlytq2bZvGjRunG2+8UU2bNvXBq3B5KY05y87Odvsf9u7du7VlyxZFRESoVq1acjgcGjt2rKZOnap69eopLi5O//nPf1S9enX16dPn0r4AlylfzFt2draSkpLUv39/VatWTampqbrvvvtUt25dJSQkXOJX4PJTGnOWmJioBQsW6L333lNISIjrupOw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",
      "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
}
