{
 "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(\"gen_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(\"gen_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-{}-gen.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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J80Y9nr8+rJE3tyIZhJFIhEWLlzImjVr8tt832fNmjUsXbr0oPssXbp0WHuABx544JDtAaLRKPF4fNiPiIiInJhGPEyzcuVKli9fzqJFi1i8eDE333wzvb29rFixAoArrriCyZMns2rVKgCuueYaLrroIr797W9z6aWXcvfdd7Nu3Tp++MMfju6ZiIiIyHFpxGHksssuo7W1leuvv56mpiYWLFjA6tWr85NUd+7cOWwC3Lnnnstdd93FF7/4Rf7t3/6N2bNnc9999x32GiMiIiJyYtNy8CIiIjImDvf7W6vPiIiISKAURkRERCRQCiMiIiISKIURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigRrwcfBAGF4lNJBIBVyIiIiKHa/B7+60Wez8uwkh3dzcADQ0NAVciIiIiI9Xd3U15efkh3z8unk3j+z579uyhrKwMY8yoHTeRSNDQ0MCuXbv0zJsxpms9PnSdx4eu8/jQdR4/Y3WtrbV0d3czadKkYQ/RfaPjomfEcRymTJkyZsePx+P6gz5OdK3Hh67z+NB1Hh+6zuNnLK71m/WIDNIEVhEREQmUwoiIiIgEqqDDSDQa5YYbbiAajQZdyglP13p86DqPD13n8aHrPH6CvtbHxQRWEREROXEVdM+IiIiIBE9hRERERAKlMCIiIiKBUhgRERGRQBV0GLnllluYPn06sViMJUuW8NRTTwVd0nFj1apVnH322ZSVlVFbW8v73/9+tm7dOqxNMpnkqquuorq6mtLSUj74wQ/S3Nw8rM3OnTu59NJLKS4upra2ln/5l38hm82O56kcV2688UaMMXz2s5/Nb9N1Hj27d+/mb/7mb6iurqaoqIjTTz+ddevW5d+31nL99dczceJEioqKaGxsZNu2bcOO0d7ezuWXX048HqeiooJPfOIT9PT0jPepHLM8z+O6665jxowZFBUVMWvWLL7yla8Me3aJrvORefTRR3nPe97DpEmTMMZw3333DXt/tK7rpk2buOCCC4jFYjQ0NPCNb3zj6Iu3Beruu++2kUjE3nHHHfb555+3V155pa2oqLDNzc1Bl3ZcWLZsmf3JT35iN2/ebDdu3Gjf/e5326lTp9qenp58m0996lO2oaHBrlmzxq5bt86ec8459txzz82/n81m7bx582xjY6N95pln7P33329ramrstddeG8QpHfOeeuopO336dHvGGWfYa665Jr9d13l0tLe322nTptm//du/tU8++aR99dVX7R/+8Af78ssv59vceOONtry83N5333322Wefte9973vtjBkzbH9/f77NO9/5Tjt//nz7xBNP2D/96U/2pJNOsh/96EeDOKVj0le/+lVbXV1tf/e739nt27fbe++915aWltrvfOc7+Ta6zkfm/vvvt1/4whfsL3/5SwvYX/3qV8PeH43r2tXVZevq6uzll19uN2/ebH/xi1/YoqIi+4Mf/OCoai/YMLJ48WJ71VVX5V97nmcnTZpkV61aFWBVx6+WlhYL2EceecRaa21nZ6cNh8P23nvvzbd58cUXLWDXrl1rrc39g+M4jm1qasq3ufXWW208HrepVGp8T+AY193dbWfPnm0feOABe9FFF+XDiK7z6Pnc5z5nzz///EO+7/u+ra+vt9/85jfz2zo7O200GrW/+MUvrLXWvvDCCxawTz/9dL7N73//e2uMsbt37x674o8jl156qf34xz8+bNtf/dVf2csvv9xaq+s8Wt4YRkbrun7/+9+3lZWVw/7u+NznPmdPOeWUo6q3IIdp0uk069evp7GxMb/NcRwaGxtZu3ZtgJUdv7q6ugCoqqoCYP369WQymWHXeM6cOUydOjV/jdeuXcvpp59OXV1dvs2yZctIJBI8//zz41j9se+qq67i0ksvHXY9Qdd5NP3mN79h0aJFfPjDH6a2tpYzzzyT22+/Pf/+9u3baWpqGnaty8vLWbJkybBrXVFRwaJFi/JtGhsbcRyHJ598cvxO5hh27rnnsmbNGl566SUAnn32WR577DHe9a53AbrOY2W0ruvatWu58MILiUQi+TbLli1j69atdHR0HHF9x8WD8kZbW1sbnucN+8sZoK6uji1btgRU1fHL930++9nPct555zFv3jwAmpqaiEQiVFRUDGtbV1dHU1NTvs3B/j8YfE9y7r77bjZs2MDTTz99wHu6zqPn1Vdf5dZbb2XlypX827/9G08//TT/8A//QCQSYfny5flrdbBrOfRa19bWDns/FApRVVWlaz3g85//PIlEgjlz5uC6Lp7n8dWvfpXLL78cQNd5jIzWdW1qamLGjBkHHGPwvcrKyiOqryDDiIyuq666is2bN/PYY48FXcoJZ9euXVxzzTU88MADxGKxoMs5ofm+z6JFi/ja174GwJlnnsnmzZu57bbbWL58ecDVnTj+8z//kzvvvJO77rqL0047jY0bN/LZz36WSZMm6ToXsIIcpqmpqcF13QPuOGhubqa+vj6gqo5PV199Nb/73e946KGHmDJlSn57fX096XSazs7OYe2HXuP6+vqD/n8w+J7khmFaWlo466yzCIVChEIhHnnkEf793/+dUChEXV2drvMomThxInPnzh227dRTT2Xnzp3A/mv1Zn9v1NfX09LSMuz9bDZLe3u7rvWAf/mXf+Hzn/88H/nIRzj99NP52Mc+xj/+4z+yatUqQNd5rIzWdR2rv08KMoxEIhEWLlzImjVr8tt832fNmjUsXbo0wMqOH9Zarr76an71q1/x4IMPHtBtt3DhQsLh8LBrvHXrVnbu3Jm/xkuXLuW5554b9of/gQceIB6PH/ClUKje/va389xzz7Fx48b8z6JFi7j88svzv+s6j47zzjvvgNvTX3rpJaZNmwbAjBkzqK+vH3atE4kETz755LBr3dnZyfr16/NtHnzwQXzfZ8mSJeNwFse+vr4+HGf4V4/ruvi+D+g6j5XRuq5Lly7l0UcfJZPJ5Ns88MADnHLKKUc8RAMU9q290WjU/sd//Id94YUX7Cc/+UlbUVEx7I4DObRPf/rTtry83D788MN27969+Z++vr58m0996lN26tSp9sEHH7Tr1q2zS5cutUuXLs2/P3jL6SWXXGI3btxoV69ebSdMmKBbTt/C0LtprNV1Hi1PPfWUDYVC9qtf/ardtm2bvfPOO21xcbH9+c9/nm9z44032oqKCvvrX//abtq0yb7vfe876K2RZ555pn3yySftY489ZmfPnl3wt5wOtXz5cjt58uT8rb2//OUvbU1Njf3Xf/3XfBtd5yPT3d1tn3nmGfvMM89YwN500032mWeesa+99pq1dnSua2dnp62rq7Mf+9jH7ObNm+3dd99ti4uLdWvv0fjud79rp06daiORiF28eLF94okngi7puAEc9OcnP/lJvk1/f7/9zGc+YysrK21xcbH9wAc+YPfu3TvsODt27LDvete7bFFRka2pqbH/9E//ZDOZzDifzfHljWFE13n0/Pa3v7Xz5s2z0WjUzpkzx/7whz8c9r7v+/a6666zdXV1NhqN2re//e1269atw9rs27fPfvSjH7WlpaU2Ho/bFStW2O7u7vE8jWNaIpGw11xzjZ06daqNxWJ25syZ9gtf+MKwW0V1nY/MQw89dNC/l5cvX26tHb3r+uyzz9rzzz/fRqNRO3nyZHvjjTcede3G2iHL3omIiIiMs4KcMyIiIiLHDoURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAvX/AcGF04X2b46ZAAAAAElFTkSuQmCC",
      "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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",
      "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.095 (avg p value 0.405693)\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.094 (avg p value 0.414493)\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.095 (avg p value 0.406577)\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.094 (avg p value 0.404996)\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.173 (avg p value 0.274444)\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": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.178 (avg p value 0.268847)\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": "c1084bfa-fd45-486c-bd2d-91caaaf6f190",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.179 (avg p value 0.266845)\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": "2f417ebf-d93c-446b-b8cd-ce39465c828f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.180 (avg p value 0.263917)\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": "5cfa8f05-4fae-4633-8bda-c712af94ec4c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.167 (avg p value 0.282425)\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": "352a8426-ca7d-4139-909d-f801a52c342b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.176 (avg p value 0.267436)\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": "f0961348-6bbc-416a-8006-0b6c4c485f13",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.182 (avg p value 0.256843)\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": "50e7461a-3663-4cfb-b773-995d59415428",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.185 (avg p value 0.252808)\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": "10c2e40e-b69f-46fd-8c52-590f5e053b83",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.212 (avg p value 0.206084)\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": "7fdc8826-0a84-49e3-9bb3-dc89c175f4e6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.221 (avg p value 0.195278)\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": "7e84e86b-0d18-4b0f-895a-d21ac97d33e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.227 (avg p value 0.186232)\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": "9e195677-9b66-4e5f-8919-35bae8629f4c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.229 (avg p value 0.182597)\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": "1ac99bcb-1957-4faf-ae61-63d7c203be1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36b25a3d-b5b5-4351-bbf7-4a97088823a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08418978-2683-43b5-b019-84f06056ba00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f1d4903-c261-4644-b30f-f38fdc4c97a1",
   "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.08211254763426099, high=0.11048432104949074)\n",
      "0.082\n",
      "0.11\n",
      "1\n",
      "ConfidenceInterval(low=0.07868266720591412, high=0.10756999028325971)\n",
      "0.079\n",
      "0.108\n",
      "2\n",
      "ConfidenceInterval(low=0.081354184336663, high=0.1067444467407832)\n",
      "0.081\n",
      "0.107\n",
      "3\n",
      "ConfidenceInterval(low=0.0812770550923823, high=0.10666010027882109)\n",
      "0.081\n",
      "0.107\n",
      "4\n",
      "ConfidenceInterval(low=0.16357347910167075, high=0.18570025000206006)\n",
      "0.164\n",
      "0.186\n",
      "5\n",
      "ConfidenceInterval(low=0.16857524298006907, high=0.1909497398587861)\n",
      "0.169\n",
      "0.191\n",
      "6\n",
      "ConfidenceInterval(low=0.17000699175440992, high=0.1921952756886169)\n",
      "0.17\n",
      "0.192\n",
      "7\n",
      "ConfidenceInterval(low=0.17099987591586882, high=0.1923106643250937)\n",
      "0.171\n",
      "0.192\n",
      "8\n",
      "ConfidenceInterval(low=0.1612583740043519, high=0.17729996653523347)\n",
      "0.161\n",
      "0.177\n",
      "9\n",
      "ConfidenceInterval(low=0.1682845844662273, high=0.18724404329813116)\n",
      "0.168\n",
      "0.187\n",
      "10\n",
      "ConfidenceInterval(low=0.17403123432538517, high=0.19356364544436164)\n",
      "0.174\n",
      "0.194\n",
      "11\n",
      "ConfidenceInterval(low=0.17789762154351121, high=0.19557514136949758)\n",
      "0.178\n",
      "0.196\n",
      "12\n",
      "ConfidenceInterval(low=0.204786295545749, high=0.21905308022767167)\n",
      "0.205\n",
      "0.219\n",
      "13\n",
      "ConfidenceInterval(low=0.21324069867745443, high=0.22958354528116423)\n",
      "0.213\n",
      "0.23\n",
      "14\n",
      "ConfidenceInterval(low=0.22019342083343382, high=0.2350538151375307)\n",
      "0.22\n",
      "0.235\n",
      "15\n",
      "ConfidenceInterval(low=0.2218923541398562, high=0.23832241965406697)\n",
      "0.222\n",
      "0.238\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(\"./gen_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/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA130lEQVR4nO3dd3iUZfr28XNImQRIIZBAskBCV7qEBVlBqoTmImXXRRRQxLIgKGBhcYWolBVFFBVsJLgqzQXkEBURwQIohKqoNIO0UFTSEEJI7t8fvMzLmACZMGFuyPdzHHPszjP33M91zRNnTp4y4zDGGAEAAFiojK8LAAAAOB+CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKgCtacnKyHA6H9uzZU+LrGjRokOLi4lz39+zZI4fDoWeffbbE1y1J48ePl8PhuCzrAmxBUAGK4eyH47m3qKgotW/fXh999FGJr/+VV15RcnJysZ774Ycfavz48V6tx1tWrVrl9po6nU5VrlxZ7dq108SJE3X06FGvrOf333/X+PHjtWrVKq/M50021wb4AkEFuARPPvmk/vvf/+qtt97SI488oqNHj6pbt2764IMPSnS9lxpUEhMTvVuQlw0fPlz//e9/9dprr+nhhx9WRESExo0bp2uvvVafffaZ29g77rhDJ06cUGxsbJHn//3335WYmOhxGHj99de1fft2j57jqQvV9vjjj+vEiRMlun7ANv6+LgC4knXt2lXNmzd33R88eLAqV66sOXPmqEePHj6szDtOnz6t/Px8BQYGXtb1tmnTRn379nVbtmXLFnXu3Fl9+vTR999/r+joaEmSn5+f/Pz8SrSe48ePq1y5cgoICCjR9VyMv7+//P1520bpwh4VwIvCw8MVHBxc4MPk+PHjGjVqlKpVqyan06l69erp2Wef1R9/vPz06dN66qmnVKtWLTmdTsXFxelf//qXcnJyXGPi4uK0bds2ff75565DJO3atZMk5ebmKjExUXXq1FFQUJAqVqyo1q1ba/ny5ZLOnGPx8ssvS5LbIRbJ/XyLadOmuWr4/vvvderUKT3xxBOKj49XWFiYypUrpzZt2mjlypVu9Z87x/PPP6/Y2FgFBwerbdu2+u677y7ptW3SpImmTZum9PR0vfTSS67lhZ2jkpKSooSEBFWqVEnBwcGqUaOG7rrrLleNkZGRkqTExETXa3D2cNigQYNUvnx57d69W926dVNISIj69+/veuzcc1TOdbF+27Vr59pO5zp3zovVVtg5KkX5m5HO/N306NFDX331lVq0aKGgoCDVrFlTb731VuEvOGAJojlwCTIyMvTLL7/IGKMjR45o+vTpys7O1u233+4aY4zRX//6V61cuVKDBw9W06ZNtWzZMj388MM6cOCAnn/+edfYu+++W7Nnz1bfvn01atQoffPNN5o0aZJ++OEHLVq0SJI0bdo0PfDAAypfvrzGjh0rSapcubKkMx9kkyZN0t13360WLVooMzNTKSkp2rhxo2666Sbde++9OnjwoJYvX67//ve/hfaUlJSkkydP6p577pHT6VRERIQyMzP1xhtvqF+/fhoyZIiysrL05ptvKiEhQevWrVPTpk3d5njrrbeUlZWloUOH6uTJk3rhhRfUoUMHffvtt65ai6Nv374aPHiwPvnkE02YMKHQMUeOHFHnzp0VGRmpxx57TOHh4dqzZ48WLlwoSYqMjNSMGTN0//33q1evXurdu7ckqXHjxq45Tp8+rYSEBLVu3VrPPvusypYte8G6vNVvUWr7o6L8zZy1a9cu12s4cOBAzZo1S4MGDVJ8fLwaNGhQ5DqBy8oA8FhSUpKRVODmdDpNcnKy29jFixcbSebpp592W963b1/jcDjMrl27jDHGbN682Ugyd999t9u40aNHG0nms88+cy1r0KCBadu2bYG6mjRpYrp3737B2ocOHWoK+08/NTXVSDKhoaHmyJEjbo+dPn3a5OTkuC07duyYqVy5srnrrrsKzBEcHGz279/vWv7NN98YSeahhx66YG0rV640ksyCBQvOO6ZJkyamQoUKrvtnt0VqaqoxxphFixYZSWb9+vXnnePo0aNGkhk3blyBxwYOHGgkmccee6zQx2JjY133Pem3bdu2hW6zP855odrGjRvntu08+ZuJjY01kswXX3zhWnbkyBHjdDrNqFGjCqwLsAWHfoBL8PLLL2v58uVavny53n77bbVv3153332361/v0pmTV/38/DR8+HC3544aNUrGGNdVQh9++KEkaeTIkQXGSdLSpUsvWk94eLi2bdumnTt3FrunPn36uA4/nOXn5+c6TyU/P1+//fabTp8+rebNm2vjxo0F5rjlllv0pz/9yXW/RYsWatmypavHS1G+fHllZWWd9/Hw8HBJ0gcffKDc3Nxir+f+++8v8tiS7PdCPP2bqV+/vtq0aeO6HxkZqXr16umnn34q0TqBS0FQAS5BixYt1KlTJ3Xq1En9+/fX0qVLVb9+fQ0bNkynTp2SJP3888+KiYlRSEiI23OvvfZa1+Nn/7dMmTKqXbu227gqVaooPDzcNe5CnnzySaWnp6tu3bpq1KiRHn74YW3dutWjnmrUqFHo8tmzZ6tx48auc18iIyO1dOlSZWRkFBhbp06dAsvq1q3rle86yc7OLvBanqtt27bq06ePEhMTValSJfXs2VNJSUkFztm4EH9/f1WtWrXI40uy3wvx9G+mevXqBeaoUKGCjh07VqJ1ApeCoAJ4UZkyZdS+fXulpaUVe6/GpXyh14033qjdu3dr1qxZatiwod544w01a9ZMb7zxRpHnCA4OLrDs7bff1qBBg1SrVi29+eab+vjjj7V8+XJ16NBB+fn5xa7XU7m5udqxY0eBD+ZzORwOvffee1q7dq2GDRumAwcO6K677lJ8fLyys7OLtB6n06kyZbz79ni+7ZqXl1dic//R+a6OMn84qRuwCUEF8LLTp09LkutDMTY2VgcPHixwuOLHH390PX72f/Pz8wsEnMOHDys9Pd3te0Iu9MEUERGhO++8U3PmzNG+ffvUuHFjty94K04Qeu+991SzZk0tXLhQd9xxhxISEtSpUyedPHmy0PGFhbQdO3ac94oZT+o4ceKEEhISLjr2+uuv14QJE5SSkqJ33nlH27Zt09y5cyVdWhgsTFH6rVChgtLT0wuM++NeD09q8+RvBrhSEVQAL8rNzdUnn3yiwMBA16Gdbt26KS8vz+2SWunM5awOh0Ndu3Z1jZPOXNVzrqlTp0qSunfv7lpWrly5Qj/0fv31V7f75cuXV+3atd0Oe5QrV06SCn3++Zz9l/i5//L+5ptvtHbt2kLHL168WAcOHHDdX7dunb755htXr8WxZcsWPfjgg6pQoYKGDh163nHHjh0rsIfg7FVJZ1+Hs1fxePIaXEhR+q1Vq5Z+/PFHt2/X3bJli1avXu02lye1efI3A1ypuDwZuAQfffSRa8/IkSNH9O6772rnzp167LHHFBoaKkm6+eab1b59e40dO1Z79uxRkyZN9Mknn+j999/Xgw8+qFq1akk68z0hAwcO1Guvvab09HS1bdtW69at0+zZs3XLLbeoffv2rvXGx8drxowZevrpp1W7dm1FRUWpQ4cOql+/vtq1a6f4+HhFREQoJSVF7733noYNG+b2XOnMt78mJCTIz89P//jHPy7YZ48ePbRw4UL16tVL3bt3V2pqqmbOnKn69esXejildu3aat26te6//37l5ORo2rRpqlixoh555JEiva5ffvmlTp48qby8PP36669avXq1lixZorCwMC1atEhVqlQ573Nnz56tV155Rb169VKtWrWUlZWl119/XaGhoa4P9uDgYNWvX1/z5s1T3bp1FRERoYYNG6phw4ZFqq84/d51112aOnWqEhISNHjwYB05ckQzZ85UgwYNlJmZ6RrnSW2e/M0AVyzfXnQEXJkKuzw5KCjING3a1MyYMcPk5+e7jc/KyjIPPfSQiYmJMQEBAaZOnTpmypQpBcbl5uaaxMREU6NGDRMQEGCqVatmxowZY06ePOk27tChQ6Z79+4mJCTESHJd9vr000+bFi1amPDwcBMcHGyuueYaM2HCBHPq1CnXc0+fPm0eeOABExkZaRwOh+ty17OX2k6ZMqVAv/n5+WbixIkmNjbWOJ1Oc91115kPPvjgvJfrTpkyxTz33HOmWrVqxul0mjZt2pgtW7Zc9HU9e3ny2VtAQICJjIw0N954o5kwYUKBy6bP3RZnL0/euHGj6devn6levbpxOp0mKirK9OjRw6SkpLg9b82aNSY+Pt4EBga6XQ48cOBAU65cuULru9R+3377bVOzZk0TGBhomjZtapYtW1ZgzgvV9sfLk40p+t9MbGxsoZeun++yacAWDmM4iwqAd+zZs0c1atTQlClTNHr0aF+XA+AqwDkqAADAWgQVAABgLYIKAACwFueoAAAAa7FHBQAAWIugAgAArHVFf+Fbfn6+Dh48qJCQEK9/JTYAACgZxhhlZWUpJibmor+rdUUHlYMHD6patWq+LgMAABTDvn37LvpL5Vd0UDn7U+/79u1zfV05AACwW2ZmpqpVq+b6HL+QKzqonD3cExoaSlABAOAKU5TTNjiZFgAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACs5fOgcuDAAd1+++2qWLGigoOD1ahRI6WkpPi6LAAAYAGf/tbPsWPHdMMNN6h9+/b66KOP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c/3115u//OUvJd7vH/mq/7Zt25ohQ4a4bfuMjIwS7/dc3u49Pz/fXH/99aZNmzZm3bp15scffzT33HOPqV69utvftQ3b3le927DdjfG8/3Xr1pnRo0ebOXPmmCpVqpjnn3++WHNeidveW71fzdv+ww8/NGPHjjULFy40ksyiRYsKjJk8ebIJCwszixcvNlu2bDF//etfTY0aNcyJEye83KF3WBdUWrRoYYYOHeq6n5eXZ2JiYsykSZMKHf/3v//ddO/e3W1Zy5Ytzb333nvedfTs2dN06NDBbVlsbGyhG/1yKoneGzRoYJ588km3Mc2aNTNjx441xhiTnp5uAgICzIIFC1yP//DDD0aSWbt27SX35Alf9G/MmTetESNGeKGD4vN279u3bzeSzHfffec2Z2RkpHn99deNMfZse1/0bowd290Yz/s/1/nety4255W67c9V3N6Nubq3/bkKCyr5+fmmSpUqZsqUKa5l6enpxul0mjlz5nhU/+Vi1aGfU6dOacOGDerUqZNrWZkyZdSpUyetXbu20OesXbvWbbwkJSQknHf84cOHtXTpUg0ePLjAY5MnT1bFihV13XXXacqUKTp9+vQldOOZkur9L3/5i5YsWaIDBw7IGKOVK1dqx44d6ty5syRpw4YNys3NdZvnmmuuUfXq1c+73pLgq/7Peuedd1SpUiU1bNhQY8aM0e+/X76fWS+J3nNyciRJQUFBbnM6nU599dVXkuzY9r7q/SxfbnepeP17Y84rddt7c86rcdsXRWpqqg4dOuS23rCwMLVs2fKyvud7wopvpj3rl19+UV5eXoGvz69cubJ+/PHHQp9z6NChQscfOnSo0PGzZ89WSEiIevfu7bZ8+PDhatasmSIiIrRmzRqNGTNGaWlpmjp16iV0VHQl1fv06dN1zz33qGrVqvL391eZMmX0+uuv68Ybb3TNERgYWODHHS/0GpYEX/UvSbfddptiY2MVExOjrVu36tFHH9X27du1cOFCL3Z4fiXR+9kPnTFjxujVV19VuXLl9Pzzz2v//v1KS0tzzeHrbe+r3iXfb3epeP17Y84rddt7a86rddsXxdnt68nnpq9ZFVQuh1mzZql///5u/9qSzvw44lmNGzdWYGCg7r33Xk2aNOmK/mri6dOn6+uvv9aSJUsUGxurL774QkOHDlVMTEyBf5VejYrS/z333OMa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8uXLy9/f/4KHevbu3as6deqodevWcjgcrvVLUmRkpKQzeyYuNMfTTz+tUaNGacSIEa5lf/7znwsd6+fnp3/84x969913XUFlxYoVSk9PV58+fSRJf/rTnzR69GjXcx544AEtW7ZM8+fPL3ZQmTdvnvLz8/XGG2/I4XBIkpKSkhQeHq5Vq1apc+fOxZoXwBkEFeAq1qRJE3Xs2FGNGjVSQkKCOnfurL59+6pChQoXfN68efP04osvavfu3crOztbp06cVGhrq0boHDRqkm266SfXq1VOXLl3Uo0cPjz60jxw5ooMHD6pjx45Ffk7//v11/fXX6+DBg4qJidE777yj7t27Kzw8XNKZPSwTJ07U/PnzdeDAAZ06dUo5OTkqW7asR72da8uWLdq1a5dCQkLclp88eVK7d+8u9rwAzuAcFeAq5ufnp+XLl+ujjz5S/fr1NX36dNWrV0+pqannfc7atWvVv39/devWTR988IE2bdqksWPH6tSpUx6tu1mzZkpNTdVTTz2lEydO6O9//7v69u1b5OcHBwd7tD7pzN6WWrVqae7cuTpx4oQWLVqk/v37ux6fMmWKXnjhBT366KNauXKlNm/erISEhAv25nA4ZIxxW3b2fB1Jys7OVnx8vDZv3ux227Fjh2677TaPewDgjj0qwFXO4XDohhtu0A033KAnnnhCsbGxWrRokUaOHKnAwEDl5eW5jV+zZo1iY2M1duxY17Kff/7ZbUxhzytMaGiobr31Vt16663q27evunTpot9++00REREKCAi44BwhISGKi4vTihUr1L59+yL3279/f73zzjuqWrWqypQpo+7du7seW716tXr27Knbb79dkpSfn68dO3aofv36550vMjJSaWlprvs7d+7U77//7rrfrFkzzZs3T1FRUR7vdQJwcexRAa5i33zzjSZOnKiUlBTt3btXCxcu1NGjR3XttddKOnP+ydatW7V9+3b98ssvys3NVZ06dbR3717NnTtXu3fv1osvvqhFixa5zRsXF6fU1FRt3rxZv/zyi3Jycgqse+rUqZozZ45+/PFH7dixQwsWLFCVKlVch2HOhpBDhw7p2LFjhdY/fvx4Pffcc3rxxRe1c+dObdy4UdOnT79gz/3799fGjRs1YcIE9e3bV06n0/VYnTp1tHz5cq1Zs0Y//PCD7r33Xh0+fPiC83Xo0EEvvfSSNm3apJSUFN13330KCAhwW1+lSpXUs2dPffnll0pNTdWqVas0fPhw7d+//4JzAygCA+Cq9f3335uEhAQTGRlpnE6nqVu3rpk+fbrr8SNHjpibbrrJlC9f3kgyK1euNMYY8/DDD5uKFSua8uXLm1tvvdU8//zzJiwszPW8kydPmj59+pjw8HAjySQlJRljjJFkFi1aZIwx5rXXXjNNmzY15cqVM6GhoaZjx45m48aNrjmWLFliateubfz9/U1sbKwxxphx48aZJk2auPUwc+ZMU69ePRMQEGCio6PNAw88cNG+W7RoYSSZzz77zG35r7/+anr27GnKly9voqKizOOPP24GDBhgevbs6RrTtm1bM2LECNf9AwcOmM6dO5ty5cqZOnXqmA8//NCEhYW5ejbGmLS0NDNgwABTqVIl43Q6Tc2aNc2QIUNMRkbGRWsFcGEOY/5w8BUAAMASHPoBAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFr/B1arQCQRQdoAAAAAAElFTkSuQmCC",
      "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": "7f94c597-e0a2-4efc-b068-a2774e9449f7",
   "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
}
