{
 "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7499a23a-7876-4670-ae09-c4de570791e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_list = []\n",
    "with open(\"gen_dot.pkl\", 'rb') as handle:\n",
    "    tmp = pickle.load(handle)\n",
    "scores_list.append(tmp[0][-1])\n",
    "scores_list.append(tmp[1][-1])\n",
    "scores_list.append(np.stack(tmp[0])[1:].mean(axis=0))\n",
    "scores_list.append(np.stack(tmp[1])[1:].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1839bf2e-c9a2-4ada-a3c9-f56e2c0c9939",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"gen_cos.pkl\", 'rb') as handle:\n",
    "    tmp = pickle.load(handle)\n",
    "scores_list.append(tmp[0][-1])\n",
    "scores_list.append(tmp[1][-1])\n",
    "scores_list.append(np.stack(tmp[0])[1:].mean(axis=0))\n",
    "scores_list.append(np.stack(tmp[1])[1:].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9d29e95-b825-4bec-9957-676824892c52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 8,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 8,
     "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": 9,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABGeklEQVR4nO39eZwdZZ33/7+uqrP1dnpNd2fprARCCCSQkBB2x5aojNuog/4YyURvHBVmcDKLMgrc6k+DGzeOIiiK460gDPcoLoNRJmwiYUlCCAESAiQkJOktvZzezlZ1ff843SfdJIF00t2V5LyfPlr71LmqzqfKkPPmuq66ylhrLSIiIiIBcYIuQERERAqbwoiIiIgESmFEREREAqUwIiIiIoFSGBEREZFAKYyIiIhIoBRGREREJFAKIyIiIhKoUNAFHA7f99mzZw9lZWUYY4IuR0RERA6DtZbu7m4mTZqE4xy6/+O4CCN79uyhoaEh6DJERETkCOzatYspU6Yc8v3jIoyUlZUBuZOJx+MBVyMiIiKHI5FI0NDQkP8eP5TjIowMDs3E43GFERERkePMW02x0ARWERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAqUwIiIiIoE6Lh6UN1aeXbOLRFs/c8+fRPXk0qDLERERKUgF3TPy8vpmNj30Ol2t/UGXIiIiUrAKOozAwCONbbBViIiIFLKCDiNm4OytVRoREREJSmGHEZPrGVEWERERCU6Bh5Hc/6pnREREJDgFHUb2p5FgyxARESlkBR1G1DMiIiISvMIOI47mjIiIiAStsMOIekZEREQCV9hhpP0VAGz7jmALERERKWCFHUb62gCw/V0BVyIiIlK4CjqMDC7Aiq9hGhERkaAUdBjRnBEREZHgFXYYGVhgxKpnREREJDCFHUbUMyIiIhK4gg4j/bv7AUi93hpwJSIiIoWroMMIWR8AP5MNuBAREZHCVdhhRHNGREREAlfQYUQTWEVERIKnMIImsIqIiASpoMPI4DANyiIiIiKBKegwMnhrr69hGhERkcAUdBhRz4iIiEjwCjqMaM6IiIhI8Ao8jOQoi4iIiASnoMPIYBqxfrBliIiIFLKCDiMaphEREQmewggaphEREQlSgYeRHIURERGR4BR0GMEM3tqrNCIiIhKUUNAFBGly+WwmRV16bUnQpYiIiBSsgu4ZiYVLqA45uLhBlyIiIlKwCjqMDA7OaJRGREQkOAUdRkw+jpg3bSciIiJjp6DDiNVDaURERAJX0GEkO7D0atrXEqwiIiJBKewwQi6EZDVpREREJDAFHUY0SiMiIhK8gg4j+TkjVhNYRUREglLQYQTdTSMiIhK4gg4juptGREQkeAUdRtAwjYiISOAKOoxYDdOIiIgETmEERREREZEgHVEYueWWW5g+fTqxWIwlS5bw1FNPHdZ+d999N8YY3v/+9x/Jx44hxREREZGgjDiM3HPPPaxcuZIbbriBDRs2MH/+fJYtW0ZLS8ub7rdjxw7++Z//mQsuuOCIix1tlsGVVxVGREREgjLiMHLTTTdx5ZVXsmLFCubOncttt91GcXExd9xxxyH38TyPyy+/nC996UvMnDnzqAoeTWtLdvGT6EPsC/cGXYqIiEjBGlEYSafTrF+/nsbGxv0HcBwaGxtZu3btIff78pe/TG1tLZ/4xCeOvNIx4BmLZ3ysloMXEREJTGgkjdva2vA8j7q6umHb6+rq2LJly0H3eeyxx/jxj3/Mxo0bD/tzUqkUqVQq/zqRSIykzBHTnb0iIiLBGdO7abq7u/nYxz7G7bffTk1NzWHvt2rVKsrLy/M/DQ0NY1KfGVxmZEyOLiIiIodjRD0jNTU1uK5Lc3PzsO3Nzc3U19cf0P6VV15hx44dvOc978lv8/3cpNFQKMTWrVuZNWvWAftde+21rFy5Mv86kUiMWSABMJrAKiIiEpgRhZFIJMLChQtZs2ZN/vZc3/dZs2YNV1999QHt58yZw3PPPTds2xe/+EW6u7v5zne+c8iAEY1GiUajIyntqKhnREREJDgjCiMAK1euZPny5SxatIjFixdz880309vby4oVKwC44oormDx5MqtWrSIWizFv3rxh+1dUVAAcsD0I6g8REREJ3ojDyGWXXUZrayvXX389TU1NLFiwgNWrV+cnte7cuRPHOd4WdlUsERERCYqxx8F9rYlEgvLycrq6uojH46N23O9+4Ub2hZPM6Z7MR7595agdV0RERA7/+/t468IYXfnn5KlnREREJCiFHUZEREQkcAUdRtQfIiIiEryCDiODtAKriIhIcAo8jBzzc3dFREROeAUeRnIUSURERIKjMAJo9oiIiEhwCjqMKIKIiIgEr6DDiIiIiARPYQSw6iMREREJTIGHkYGpq0ZTWEVERIJS4GFEREREgqYwAmgqq4iISHAKPIwMDtMEW4WIiEghK+gwMphBNGNEREQkOAUdRkRERCR4CiOoZ0RERCRICiOgOSMiIiIBKvAwYt/wvyIiIjLeCjuMDPSIKIqIiIgEp7DDiIiIiAROYQQ0Z0RERCRABR1GrEKIiIhI4Ao6jAyygPU1c0RERCQICiMAxuJbhREREZEgFHYY8fzc/1of6ymMiIiIBKGww0gmC4DFw9cwjYiISCAKO4wM0JwRERGR4BR4GNm/AqvNZgOtREREpFAVeBgZYMDPZoKuQkREpCApjABgsZ4XdBEiIiIFqbDDyJBn01hPwzQiIiJBKOwwMmTOqp9Vz4iIiEgQCjqMDF0O3mrOiIiISCAKOowMspozIiIiEpiCDiPW5MZpjAFfYURERCQQBR1GBlnQOiMiIiIBKfAwsn8Gq3pGREREglHQYcQO+U1zRkRERIJR0GFkcJ0RNGdEREQkMAUdRuyQRc98zRkREREJRGGHkSG/a9EzERGRYBR0GMkP02Dxs36QlYiIiBSsgg4j+WEao54RERGRoBR0GGHIcvBeRnNGREREgqAwMsBXGBEREQlEQYcRa3JpxGLxMhqmERERCUJBh5HhPSMKIyIiIkEo7DDi7D99DdOIiIgEo7DDSH7RM93aKyIiEpTCDiNu7vSt0TCNiIhIUAo7jAzrGQm2FBERkUJV0GHEMQM9I1j1jIiIiASkoMPIQBYZeFCefdO2IiIiMjYKOow4jguAj8V6CiMiIiJBKPAwkjt9H4uvURoREZFAKIwAFh+rMCIiIhKIgg4j7pCeEQ3TiIiIBKOgw8j+nhHUMyIiIhKQgg4jgz0j1lh8LcAqIiISiAIPI0PupvHNW7QWERGRsXBEYeSWW25h+vTpxGIxlixZwlNPPXXItr/85S9ZtGgRFRUVlJSUsGDBAn72s58dccGjyXUHw4ivu2lEREQCMuIwcs8997By5UpuuOEGNmzYwPz581m2bBktLS0HbV9VVcUXvvAF1q5dy6ZNm1ixYgUrVqzgD3/4w1EXf7RCTgjIrcBqfU1gFRERCcKIw8hNN93ElVdeyYoVK5g7dy633XYbxcXF3HHHHQdtf/HFF/OBD3yAU089lVmzZnHNNddwxhln8Nhjjx118UcrNNAzYgHrF/SIlYiISGBG9A2cTqdZv349jY2N+w/gODQ2NrJ27dq33N9ay5o1a9i6dSsXXnjhyKsdZfuHaSzqGBEREQlGaCSN29ra8DyPurq6Ydvr6urYsmXLIffr6upi8uTJpFIpXNfl+9//Pu94xzsO2T6VSpFKpfKvE4nESMo8bKHQYM+IBasJrCIiIkEYURg5UmVlZWzcuJGenh7WrFnDypUrmTlzJhdffPFB269atYovfelLY17X4JwR3U0jIiISnBGFkZqaGlzXpbm5edj25uZm6uvrD7mf4zicdNJJACxYsIAXX3yRVatWHTKMXHvttaxcuTL/OpFI0NDQMJJSD0t+zoixaJkRERGRYIxozkgkEmHhwoWsWbMmv833fdasWcPSpUsP+zi+7w8bhnmjaDRKPB4f9jMWBodpALCawCoiIhKEEQ/TrFy5kuXLl7No0SIWL17MzTffTG9vLytWrADgiiuuYPLkyaxatQrIDbksWrSIWbNmkUqluP/++/nZz37GrbfeOrpncgQGJ7ACWE1gFRERCcSIw8hll11Ga2sr119/PU1NTSxYsIDVq1fnJ7Xu3Lkz/8wXgN7eXj7zmc/w+uuvU1RUxJw5c/j5z3/OZZddNnpncYRcd3+dPpozIiIiEgRj7bHfJ5BIJCgvL6erq2tUh2ye+v3vuP/JdQCc3T6fS//9A6N2bBERkUJ3uN/fBT1RIjR0mMaoZ0RERCQIBR1G3CHDSRzz/UMiIiInpsIOIyEXMxBC1DMiIiISjIIOI47jDJm2qjAiIiIShIIOI8YYzGAIURYREREJREGHERxn/zCN0oiIiEggCjqM5HpGcjRnREREJBgFHkacIXfR6HYaERGRIBR0GBk2gdUB31cgERERGW8FHUaM6w6ZKWLxPT27V0REZLwVdBhx3f3rjOTCiHpGRERExltBhxHjDl30zFcYERERCUBBhxHHGTJMYyx+JhNkOSIiIgWpsMOIO3SdER8/lQy2IBERkQJU4GHExbG5NGKxZPsVRkRERMZbgYeRUP53ayzp3v4AqxERESlMBR5Ghk9gTfengy1IRESkABV2GHEczJBhmky/JrCKiIiMt4IOI8Z1YTCMGJ90Uj0jIiIi462gw4jrhjB2cNVVn0x/NtB6REREClFBhxFnWM+IJZ1UGBERERlvBR1GjOvA0J6RpBdoPSIiIoWooMOI47j5MOIbn3RKYURERGS8FXYYcV2snwsj1li8jJ7aKyIiMt4KPIyEhg3TZDPqGRERERlvBR5GHKzNBRAf9YyIiIgEocDDiAv5YRpfYURERCQAhR1GHDffM2KxZDM24IpEREQKT0GHEeM42CF303hZhREREZHxVtBhBMAfOmckrTAiIiIy3go+jMBAzwgWXzfTiIiIjLuCDyOWXG+Ih4/1Cv5yiIiIjLuC//YdDCO+8bHqGRERERl3BR9GjDHAwDCNX/CXQ0REZNwV/LevGbgEHj7Ygr8cIiIi467gv30dJ9cz4uFjFUZERETGXcF/+zpO7hL4WAxuwNWIiIgUHoURJxdAfOPj4OBltSS8iIjIeCr4MOI6++eMOAbSyWzAFYmIiBSWgg8jjhsCcsM0DpDqVRgREREZTwUfRtxQbpjGw8c1kOpXGBERERlPCiPuwJyRwZ6RvkywBYmIiBSYgg8joVBumMYaizGWVJ96RkRERMaTwogbzv/uYElrmEZERGRcKYyEh6wtop4RERGRcacwEtrfM2KMTzatp+WJiIiMp4IPI+FIBJN7cG8ujCRTwRYkIiJSYBRGwiGcgTCC8cmm0oHWIyIiUmgKPoyEwuF8zwjGx1MYERERGVcFH0bC4XC+Z8QYSzaldUZERETGk8JIOIyxuTRiHI9sWnfTiIiIjKeCDyNOKAQ296ReY3yyKYURERGR8VTwYcQNhTD+YBixCiMiIiLjTGEkFAJ/YG0R42mdERERkXGmMBIKYe1gGPHJpu2b7yAiIiKjSmEkHMH6uaEZa3yyWYURERGR8VTwYSQcjWIHhmk8fNCUERERkXFV8GEkFInk54xk8fC8ENaqd0RERGS8KIxEo/lbez3jY22YVK+6R0RERMZLwYeRcCSav7U3i0cI6GztC7YoERGRAlLwYSQUieaHadImi2sMidb+gKsSEREpHEcURm655RamT59OLBZjyZIlPPXUU4dse/vtt3PBBRdQWVlJZWUljY2Nb9p+vIWiUYyXG5ZJksU1kO7XMI2IiMh4GXEYueeee1i5ciU33HADGzZsYP78+SxbtoyWlpaDtn/44Yf56Ec/ykMPPcTatWtpaGjgkksuYffu3Udd/GgIR/aHkZTJEAIyKT/YokRERArIiMPITTfdxJVXXsmKFSuYO3cut912G8XFxdxxxx0HbX/nnXfymc98hgULFjBnzhx+9KMf4fs+a9asOeriR0MoEtkfRsjgGshoSXgREZFxM6Iwkk6nWb9+PY2NjfsP4Dg0Njaydu3awzpGX18fmUyGqqqqkVU6RoYO06TMYBjRkvAiIiLjJTSSxm1tbXieR11d3bDtdXV1bNmy5bCO8bnPfY5JkyYNCzRvlEqlSKVS+deJRGIkZY5IOBrFeLnwkSKDC2TSGqYREREZL+N6N82NN97I3Xffza9+9Stisdgh261atYry8vL8T0NDw5jV5Lj7n9prDRjja5hGRERkHI0ojNTU1OC6Ls3NzcO2Nzc3U19f/6b7futb3+LGG2/kj3/8I2ecccabtr322mvp6urK/+zatWskZY6IMQY3FN6/wfHIJDVMIyIiMl5GFEYikQgLFy4cNvl0cDLq0qVLD7nfN77xDb7yla+wevVqFi1a9JafE41Gicfjw37GUigSwRkcmTEe2VRmTD9PRERE9hvRnBGAlStXsnz5chYtWsTixYu5+eab6e3tZcWKFQBcccUVTJ48mVWrVgHw9a9/neuvv5677rqL6dOn09TUBEBpaSmlpaWjeCpHzo1EcCz4gDEemf500CWJiIgUjBGHkcsuu4zW1lauv/56mpqaWLBgAatXr85Pat25cyeOs7/D5dZbbyWdTvOhD31o2HFuuOEG/vf//t9HV/0oCUeiOAPPxrOOT7pfPSMiIiLjZcRhBODqq6/m6quvPuh7Dz/88LDXO3bsOJKPGFehaBTHWsBg8UnqQXkiIiLjpuCfTQMQiUYx/kDXiPHo77PYwdciIiIyphRGgGgshrEDt/c6HtYaUn3qHRERERkPCiPkFj5jcK0Rm7utt69bk1hFRETGg8IIEIpEMX4uhFgn1yPSn1AYERERGQ8KI+TCyGDPiEculCT2JYMsSUREpGAojDAwTOPlbufNDPSMdLb0BVmSiIhIwVAYIXdrr5fpByDteISArmaFERERkfGgMAKEwhFsNveU4CRpihwN04iIiIwXhRFywzTGyw3PJE2GmGPo6VAYERERGQ8KIwyswDowZyRJhpiB/u4M2bSe3isiIjLWFEbIPbUXLxc8UiZD2OR6SXo6UkGWJSIiUhAURsg9KG9wnZEMHhGbm8zap7VGRERExpzCCBCKxvYvemYsLrkQ0q9VWEVERMacwggDwzQDi54BGHLzRxRGRERExp7CCAPDNICTzyO5ENLXnQmqJBERkYKhMELubhoAxw5sMLlUojkjIiIiY09hhIFhGsCxuTRi/FyPyK4X9mGtPeR+IiIicvQURhh4Ng1gBuaNODaNwSfRllTviIiIyBhTGAHC0RgAzkAYyYYcwia3AmuyV/NGRERExpLCCBArLaOibmJ+4bNsUSkxm3tQXqovG2RpIiIiJzyFEcAYQ8O8M8hmugHod6HaGViRVWFERERkTCmMDIgUFWOyueDRb9IUDaw1ktIwjYiIyJgKBV3AsSISi2GyA4udmTRRm8tp6hkREREZW+oZGRCOFeXDSJ9JETK5W3o1gVVERGRsKYwMiAwJI/2kCZMLI31denKviIjIWFIYGRCJxXC8/cM0g+NXPR0KIyIiImNJYWTA0GGajPFwM7lL092eDLIsERGRE57CyIBwLAa+j/FzwzPZyEAY6UhpSXgREZExpDAyIBIrwgDGH1hfJJp7Xk025emOGhERkTGkMDIgHMstCc/AWiPpaITIwJLwG/7wWlBliYiInPAURgZEYkW5X7zBeSMWQy6gPPPHnUGVJSIicsJTGBkQLsqFEcfL9YxkTJYJIRNkSSIiIgVBYWRAZHCYZmDOSBqP07Jb8+9rEquIiMjYUBgZ4IbCOG4oP4E1Y7KE7f6ekUzKC6o0ERGRE5rCyBCRWCwfRtJkwS3BDCwLrzAiIiIyNhRGhgjHisDzgdzCZyZURjg08DqpMCIiIjIWFEaGCL+hZ8REygi76dzrpNYaERERGQsKI0OEIhHMwN00vSaJccPEbO7ZNOoZERERGRsKI0N0tTTh9vcCsM90k8EjbgYWQdOcERERkTGhMDLEzLMW42TTmEwKa6DF6aKSXBhJtPUHXJ2IiMiJSWFkiAsvXwGA09cDQJPTSdz2AbB3W2dQZYmIiJzQFEaGKCqLAxBK5gJIl+mjxOYmsG5/to3u9mRgtYmIiJyoFEaGcEMhYqVl+UmsabI4RKitzeL7lt1bOwKuUERE5MSjMPIGxeUV4A3c3msyWFPBxMp9ALy6sTXAykRERE5MCiNvUFpVjfFzPSMpsjjhcqZVvQZoqEZERGQsKIy8QVl1DSbfM5LFhGLUeS9SUh4BUBgREREZZQojbxCvmZAPIykyWCz7HslSVpULI31d6SDLExEROeEojLxBWfWE/DCNbywePt7ET1FMGwD93QojIiIio0lh5A2Ky8vB97F+7gF53Sa32FmRkwCgL6EwIiIiMpoURt4gVhrHACaVmxvSOhBCSv12ANbdv4M9L3cGVJ2IiMiJR2HkDYrKygAIDTyjpsXkwsgE/7V8m6d/t338CxMRETlBKYy8Qax0IIz0dQHQTG6NkYr+/WHEcXXZRERERou+Vd8gVlIKkH96b6ebxMPH787yrr87HdAkVhERkdGkMPIGjusSLSnBZDNk8bEGEqaPTLqaeLkFoHuf1hoREREZLQojBzFh2gwMkBpYb6TT9JHOTKU8ug8MJHszuqtGRERklCiMHMS0eQsAcFIpIPf0Xs9pwN27kXhNEQD79vQEVZ6IiMgJRWHkIKomTwHAHQwjTi9O6UR6/nAf1ZNKAGjf3RtYfSIiIicShZGDKK+tByCW7AOg0/RiQjF6N+2menIujOx9pTOo8kRERE4oCiMHEa+tA6CorxOAfaaHDFmSXROoLs/1iLyyoZXWnd1BlSgiInLCUBg5iFhJKeV19Zh0iqSXe0bNXqcTL9RAfeLhfLv//NrTus1XRETkKCmMHIQxhtmLz8UAXip3R03C9BOqPQ27+UlOPW9ivu2ebZ3BFCkiInKCOKIwcssttzB9+nRisRhLlizhqaeeOmTb559/ng9+8INMnz4dYww333zzkdY6rionTgLAyeYmsfaaJKHauXR1fYpwZP9lszaQ8kRERE4YIw4j99xzDytXruSGG25gw4YNzJ8/n2XLltHS0nLQ9n19fcycOZMbb7yR+vr6oy54vJRPyNValMk9tbfH7F/obMF5k/K/J3sz41uYiIjICWbEYeSmm27iyiuvZMWKFcydO5fbbruN4uJi7rjjjoO2P/vss/nmN7/JRz7yEaLR6FEXPF7KByaxRlO5B+XtG3hgHkA4kWDuwFBNskdzRkRERI7GiMJIOp1m/fr1NDY27j+A49DY2MjatWtHvbggldXUgDGE+nOLm3U6vfjkxmSSmzYSK40A8MwDu7AaqxERETliIwojbW1teJ5HXV3dsO11dXU0NTWNWlGpVIpEIjHsZ7y5oTBlVTWYdArPWhxctqU25erbtp2isjAA6f4su15oH/f6REREThTH5N00q1atory8PP/T0NAQSB3ltXUYIJF1AfhzvI0kGTJ7O5h1Vm2+3Ytr9wZSn4iIyIlgRGGkpqYG13Vpbm4etr25uXlUJ6dee+21dHV15X927do1asceieopUwGItud6Pnwz8JyaZBllVTE+8M9nAfD6ix0aqhERETlCIwojkUiEhQsXsmbNmvw23/dZs2YNS5cuHbWiotEo8Xh82E8QFiy7FIAJndtpsSEgd4uvUzWP3Z+6nLrpcczAU3wf/cVLeFk/kDpFRESOZyMeplm5ciW33347P/3pT3nxxRf59Kc/TW9vLytWrADgiiuu4Nprr823T6fTbNy4kY0bN5JOp9m9ezcbN27k5ZdfHr2zGCPVU6ZSXF6B43t4A0M1PdlOTChK7/P9uCGHsuoYAJsf3c3mR3YHWa6IiMhxKTTSHS677DJaW1u5/vrraWpqYsGCBaxevTo/qXXnzp04zv6Ms2fPHs4888z8629961t861vf4qKLLuLhhx8++jMYQ8YY6maexPZn1kHagzA02b2cwSlE574fr62ZSNH+S/jYvds4/W1TcBwTYNUiIiLHlxGHEYCrr76aq6+++qDvvTFgTJ8+/bieT1FRn1tPJO7kloV/ubybS3rArZxB+52/Zc45y3hs17Z8+z0vdTBlTlUgtYqIiByPjsm7aY4lFXW5MDIxlFtp1foudmC9kd51O5j/F1P4xLcuyLfvbk8eeBARERE5JIWRt1A1aQoATtOrZK0h6ke5q+i3AFhTi/fAN4iVhjn13Fxo6e3UiqwiIiIjoTDyFqbOm09pdQ1eT4LdySIA9kZzvR+h+jPY9e3/xlpLcXluRdYnf/Mqu1/qCKxeERGR443CyFtwXJcpc04DYGpx7nIVpUvp7tuFcVzSyXpS27YRLQrn97nvpmfYsaktkHpFRESONwojh6F2+kwApvXvpsdGiPpRXia3EJtTWkdm+zZOXjx8ifz//v4mrTsiIiJyGBRGDsPJ55yPGw7TsX0bReW50PFyaS8AkVmNNH31O5RURPnkdy5i0uyK/H7P/2lPEOWKiIgcVxRGDkN5bR1T580HoO6V3NOJOyLg4eMUV+HWnUt23z7CUZdL/tdp+f1eXtd80OOJiIjIfgojh2n6/IUAJNua8H2Lg8NPYw+RxcMpraP/j3cCUFIe5fwPzwagdVc3vV2pwGoWERE5HiiMHKb573gXNQ3TMEAomRui8YEdTiuhunm03vIjvM5OAM74iynUTisjm/Z59n920dnSF1jdIiIixzqFkcPkhkL8zY0347guTmZ/b0fC5IJG6Mwv8fpVnwZyy8ifck7uKcbPPLCTO69/gq7W/vEvWkRE5DigMDICbihMRf0kom37J6bucPcC4JTUkOmagJ/KBZWTF9cTr4nl2/38urV4nu6uEREReSOFkRGqmTIVJ50ikSkB4PVwe/692LwP0/3gM7nfS8J85Lolw/btbNZwjYiIyBspjIxQdcNUAE4tyWAtFHvF/Ouk7+Xf7354e/73cNSltDKaf/277z1Luj87fsWKiIgcBxRGRqh6yjQAwvtep6Mo9zya8r4q7grdDoD1J+APGY55xyf23+rb055i/R9eG8dqRUREjn0KIyM0ec5cQuEI+17fyUyvC4DaZC33NWzGeimMG2Xvv34Xvzd3x82kkyr4xLcvYMb8GgA2rH6NTQ+9Hlj9IiIixxqFkREqrazi4uX/CwBv06OkPYPBUJmZyLPenwCw4bPYedVPyezJTXSNlYR559+dnj/GC49pZVYREZFBCiNH4IzGd1E5cRIARf25J/Se3XY2/zFzU75NqP50XvvkqnwgcRzDe69ZAMC+PT34vh3fokVERI5RCiNHwBjDrEXnABBpb8lvn9c2n912Z/51bN5f0/rD2/OvJ59SiRMyYOG/vrF+2NwSERGRQqUwcoTOfu8HmTJ3HqHeBOHWvfntN0389bB2fU9vzv/uOIbJJ1cC0LIjwa1XPazl4kVEpOApjByh4ng5f339KqomTSGU7MlvP7VzLstnXZd/7ZScjtfTm399wV/PHnacn31xLX/88fNkM97YFy0iInIMUhg5CsYY5l74F7g9Xbh93fntF+y+mJ9M+BEA4RkX0fvAA9hsbn2RyvoSPnXLxRjHAOBlfLY93cyuF9oP/AAREZECoDBylOa97R0YoGjnS8O2P1q8h7beFzDGIfFkNTs+fguJ1Y8A4LoOH//G+cPa33/rc1qhVURECpLCyFEqqajknZ/5R4y1xF5/Jb99Yt9EHq14Nv86POks2n78INbPTVqNlYYPONYff/w81uouGxERKSwKI6Ng2ukLAAh3dxDduwOAmd0zubdhExtiz+XbRWY10nbrnfnXZ7xtyrDjtO7s5vuffohffPlJ1q/egdXtvyIiUgAURkZBaVU1Z7/3gwCEu/blt799TyM/ql7NJ6ftn9Dav62C3mdyPSjnfugkPv6t8/nQ5xcx78LJ+Tbte3p54r5X2bOtc3xOQEREJEAKI6PkwstXMHvxuRhrCSX2T0Y9a99Z9DqWB+KPA+DEKui4Zw8dv94G/VmKSiPUTY+z6NLpBxzzvv/zDM89rKXjRUTkxKYwMoqmzM0t+R5t2km4vTm/fWHbQm6t+3/D2vaubaL5O+vyc0RKyqNc+X8u5JP/fhHz396Qb/fo3S/xzAM7deuviIicsBRGRtGCS97NOR/8KI6XJda8ixLfIY0hnolzSuccPjf15mHt/W6PvnX7ez4iRSHCEZcJDaXD2j3+Xy9z//c3aXKriIickBRGRpHjupz315fzV9d+CQB32zpe68zdNTOldwpNTiffqvoeNrt/1dWO/9rBjo+tpPvhJ/PbTlpUx+STK4Yde9eLHXz/0w/R05Ec+xMREREZR8YeB/+6nUgkKC8vp6uri3g8HnQ5b8n6Pvd98yu8uuFpLIbeWfOwkSgAWyo20ufv5rvb/hG3fP9wjM2mMfyJyd+4HuM4+V6Q5/+0h00P7qKjaf8aJAvfOY2z3jmNSCw0vicmIiIyAof7/a2ekTFgHIf3/fMXcdwQBkvxa1voT+fWF5nTuYDa7Hy+Wfdz0i//D1779tw+oQjWXMhL511IZvdujDEYY5h34WQ+9LlFw46/fvVr3P7ZR3nhz3vG/dxERERGm8LIGHFcl7++/mu537MZJryygXR/GoApfVMoN2fyvr/8JR874xv0rf0uAMYNE57ydtru+D2Z5gReT+6ZN5GiEO/5h/kHfMZDP9vCf3z+z2RSmtwqIiLHL4WRMTR5zlxW/uI31M2cjQEq92zNvxe2YS7ddSkdpYafzn0evyd3901kViNe7ynsue7/8coly8juy61bMnVuNZd84jROf9sUZp9dlz9Ob2eKP/74eZpe7SLZmxnX8xMRERkNmjMyDpK9Pdzy8Y8AkC0tp79h+JN7n4uvo7RrNyt7/oHq8En57d2/uYqS88+h4Qc/wBgzbJ/WXd3851efPuCzKuqKWfr+Wcw8c8IYnImIiMjh05yRY0ispJS/WPF3AIR6uijes33Y+6cnFmHK5nNDzbfp/vWn8JNdAJS99xYyrZU0ffnrdP32t1hv/3DMhIYyPvivCw/4rM7mPn7/g+do3dlNuj87hmclIiIyOtQzMo6s7/Mf/3wV7bt3AdA3ZRZeWWX+/Z0lO5m441ne7fz/mFayeNi+qa2/Izyhgynf+x5OJJLf3vZ6N/f8/w/sIRl00qJaLvzIyRSVRg7ZRkREZCwc7ve3wsg4e/o3/8Wjd/4EAGsM2dIKklNmDW9T/zhf3v0Z6jLVB+zvde7EjfeReuF+Kj7wHqo/8XHaXu8h3Z/hwf+7ha7W/oN+biTmsvi9MzlpYS0l5dHRPzEREZE3UBg5Rvmex4M/uY1nH/h9flv3yQvAPXDNkES0g892fRAHc8B7AMlnfsb0//dtQmVl+W0vr2+hpyPJyYvr+c13nmHf7t4D9pt8SiV/8bE5bH2yiXh1jFPOmXj0JyYiIvIGCiPHgRcfe5hMKsXT//1rdsVrD9rm6ZqnIZTlBzu+eND3+zf8lJpPXEL5e/4Sp7h42HupvgyJtiSP//JlXt/Sccg6Zp45gbnnT2LaaQf2xIiIiBwphZHjSHd7G//3y1+kp7OTdM0kvNLh59jn9vHgpAfxjc/y3ho+uPu6Ye9nW14g8/rT1F93JdEZc+n87auUv3sG0Wn7j9PZ0sed1z9xyBpKK6O84xOn4biG+hnlo3uCIiJSkBRGjkP3fOnz7Ny6BT9ahPE9+mbMHfZ+xmR4ZOIjWDcL+Hz/5X+k2k455PFKFoeIX7IQd2DyatP2LrY/20Zncx+vPtN6yP3Ka4tY8p6ZVE8ppaK2CMfVTVciIjJyCiPHob5EF9uefJxNa1bTsv0VemfMxY8VH9CuJdZCIpKgM9rO13Z/miq/4pDHdCtcKj80FzceIVybO5a1lte3dBCOujiuYcPq13jlEOGk4dRK3vl3pxOOuux8oZ1QyGHyKZUHbSsiIjKUwshxbtcLz/HQ3T/n9X0dhDvb6InGMVOnH9BuW/wl0qaPz7a8n2l2Ftb3MI574AEdS6TuRUITyqj88IcBl/SeHiJTymhv6uXurzz1pvXMWVrPlrVNAMxvbCBWEmZBYwOh8EE+S0REBIWRE8a2p9fym299FQA/FKZ39oHPqAFIuPvwwz7bwuu4+r4eZsffRuz0yw5ol9n5OF5iN0UL349NhYk3TiXeOI1tTzfT35Omoq6YSFGIvS93sfP5fW868XXQGX8xhVlnTqA4HqWi7sCeHBERKUwKIycI3/f4/fduYsufHwHAOi7JidPIxqsOuU+f28fuolf56MNJTiu/GFNUQajmFDx8DOC8YeFdv7cJN/4y5Ze+i6IzTsLv7SOzayfFixbR9GoX//WN9Ydd74UfOZkZ8ycQLQkRCjsHLGMvIiKFQ2HkBGJ9n91bX6B2xiyyqRQP/PhWXlr/NH44Qv/0OW+672+m/gbHS/PNX05j7cJF1Jhq3pVZgDnE2iWpl34P2RR+TxMTv/ZPFJ1+Ont3dfP4L18hk/Komx4HA1ufaDqs2k89byJnvG0K1ZNLFUxERAqMwsgJzPo+mVSSH/39/6K/O4EFTn37u3nmhRfIVtQc0L7X7SHppqhO59YRqc86nHffvZSc9tdEZlz85h9mfEovqCY6rYjkVp/iRXVEp8bZtq6ZqoklFMcj/N8vPE427b9l3Y5rMMYw76LJbHliL5mUx/uuWcCk2ZoQKyJyIlIYKQCJ1hb6uxPUTJ2G7/s8/p93smHtn0nEJ+Cm+siWVcJBeiMytp/Hq/5IVbfPF/84kZaiHjrfvYzz9l58WJ8bm1NFZEopZW+fChY6mvvoe6mDulOr6Ex6/Pf3N9HbmTrs85h8cgUnL65n+6Y2utuTvPtTpxOvKTrs/UVE5NikMFKgvGyGbU8+Tk9HO2sfepBOJ4wfLcKGwgdtn6SX6m2vAJa2k6dwiplG6Z4XObfibw/7M63XjXFzS9IXnbKLsndcSHjyZJKvJUgZQ09/lkd+8RKdzX2HfcxF755OcTzC1iebqJ0WZ8n7ZhItCuF7vtY9ERE5TiiMCADPPvB7nvr1vWScMJ0+pCsnHPQ5OEOlTJJJqVImehU07fkt0QkzWJI+m6rSkw/rM/3+HRSfeRbJLe2E6oqpWX4afZtaiTSU4VRE2f5SJxNnV7D2V6/w8vqWEZ9T1aQS6mfEOXlxPcXlEV78814Alv7VLM1LERE5hiiMyAH6e7r5/SNP8sKDv8WPxHBSSfxwBL+o5C337Qn1kA53cPmfDSXb/oxXfyrlp3yAUMX0EddhYi6VfzWb7ud28vrz/dR6Puus4ZJ/XcSmh3bx4kOvYy0kj+RPpoF3/d3pTJhaxuP/9TIVdcUsee/MIziQiIgcLYUROaREWyuP33sn8972Drr3tbFt83O0Zjxeb2oBa7HhyJvu7yT7ML6HH47i9iaY0JEkyS5ObymloXgO4YoZhCacctR17plSxplXnk424/HUb7YTirq0v97Nzhffeu2TYfWGDOUTijnvgydRNyNOJOaSzfisu38HRWURFjQ2YIzB+hYLOI56V0RERoPCiIyYtZbufa1Eikp48YnHeOLxP9OcNQedBHsoTl8P4UQ7df1pivsynNaaJT7/CtyiKnw/Q7r9FSKlEzGhGCYUHVF9JedW0/tEO5xdzzO7epgzuQS609hZFTzx+x10tx/+pNmh5p43kcqJJaxf/RrJngzv+tTpzFww4YiOJSIi+ymMyKjZ+fxz/OL/fAMvWkR6wiQAjJcl0raXdHX9ISfHDnIyafx0J5TUgu9zxvp1RPv7mdkXJjz1fCifjFM9kzAuBoOf7MKJvfmTg8MTDZm9Q/7oGohfOoOeCcX8/pZN1NYVE+/N8GJ7Cu8IzrmmoZTSiiiZtMecc3JhpfW1BA1zqyifoFVmRUQOh8KIjKpEWwslFZUYx2Xnzp1UlJez79WX2PDQ/9CUtuxL+8BbrzXyRiaVzA35FJWQTL5GQ2sXk17fx5azzmNKj8uc0rOpteW4HPkdNP2lHuHp1XR2eGzdkWBxzCFrITw9zl4Lnc+30wX0F7nY7gz9Q06jJmRoz9phZ1ZeW0RFbTEdTb0k2pJU1BUz6eQK6meUU9NQSkl5rsenqDSMcXLDP8Yx9HenMcYQK33z8CYicqJQGJFAWGtp3/QHXnz+BWLlU1jz5Cb6nTe/e+etmEwK0r3Ud3azwDkT4vVUZcKEoxXYVDd4aZxsBrd8yuicgwN9Hni+Je4aEp5lQ1+WpA+pEfzTUlFXTHE8QuuubibOqmDPtg6yaZ+5500k1ZfllKUTmXHGgYvUiYicKBRG5JjR2dnJa6+9RkVFBTXV1by0/gn+5/bvk66qI1tWkRuaeYtJs2/F9HVQ0m+ZHp5Ou9dGsRfizLLzyJDFSyVws1nCJbWU2Rhm4D9Hwjc+belOoq5LEXEiA5Nd9zmGVNqjI2PZl7WkbG4yrG8PP8CUVkYJRVzKqmPEq2NUTiyhZnIp8QlFRItDRGIhertStOxI4PuWWWfWHtE5iIiMF4UROa4kk0k2b1hPZ0cbm7dsY2pFDNvxMtsSYZLOW996PFITkhFmZWt5JdRMp9PPnJ5S5qXrKaqYARgcDMmOl4lVnnRUn+MDyZIwsd4MLRmfpA8Za6kOGbo8S23IwTWwvs9jX9YSNVDiGCZHDFuSPukh/3RGS0KkerPDjl9aGWXWwlqSPRni1THKa4upmlTCrhfamTS7grrpcYxjSCezhKOu1mERkXGlMCInhFQqxfbt26mvr+f5556jqauPStejvb0Laz1279lDb38fmcE/xb4Hjnt0H2otxvPAz2LdEMVJj5iJkSbNWd5MesMQMzEcJ0SPSTLVq8Fp3oZfUsmEkpn0kSJGOP90ZDvwnzc+LflwJH1LbKD3JeFZ9mZ8Xkv5lLiGlG/xAM9CmWsodw3NGZ+QMSR9y6yow25jIO3R6eUm5S79wCxee24f/T0ZSsojbPyfXQC84+NzmXnmBEJhFy/r09ORonyCluQXkaOjMCIFxVqbWyvEWqy1bFq3juaODrZs2cK0ugo2b91O9mB/0rNZCB3dnJZBTrIP44TwIhFcHyZl4zhZj6ZoPynXZ252CnudTk7xJlFmY3j49JoUs72JxBjbSa29nqUl6xNzTD4SGaDds8QMdHvQ41tK60vo6ExRls5SUhGlqyNFmzVMmFlGeW0JkZhL974k0eIQFfUl1E4rozgeoWNvH5NOriBSFMIYMMbQ05GkpCKKMYZsxiPd71EcP7rhOBE5viiMiLwJz/Ow1hIKhfB9nxeffx4chz3bX+blV5/HLZpAbdezNCfD7DNVpDPDbxB2kv3YsIt1R+fL1fiWSNbHS/cSdqIYCzYUxncMDXYCFbYEz2bBjVBqoxhriVNClS3Dx2e308FEv4IOp5diG6XSjv7Q1qCkn/sro9+3dHqWrIXQwOhPvw+nFLm4wJ+6s8QciBiDZy1tnuXki6cwcWIJKR9eenIv4ZIw5aVhiqtiVE2PUz6hiKKyMN37UoQiDhV1xWDJ35XU35MhHHMJR9x8ABWRY9eYhpFbbrmFb37zmzQ1NTF//ny++93vsnjx4kO2v/fee7nuuuvYsWMHs2fP5utf/zrvfve7D/vzFEYkaINffJ7n4bq5YSDP8+jp6WHPnt28tHkzxEpoamunt3UPIesxuWESz720HQYmy7rZFN4IF3o7UkWeQ8ZmyYYcsJbirENfOPeP+knpakoopt/JssNtxcEwK1NL2ISIEKbcFtNuemhxEkz2KymzRaTJUmVLKbIRdrn7mOJVUUIs/3lZPCyWMIffy+Tb3DBTeCBQdHuWYgfSNjfxt8TdHzTaXEOq3yNjoThkKAsZvKylNevTiqGsIsrUaWUUGUOftSQqohQ5DqYryYyLprBzezeRdBY/a6lZMIHu9iSTTq7AdR06mvqIT4jhhhzSu7oJTyjGKRqd3jKRQjdmYeSee+7hiiuu4LbbbmPJkiXcfPPN3HvvvWzdupXa2gNn9z/++ONceOGFrFq1ir/8y7/krrvu4utf/zobNmxg3rx5o3oyIseadDqN4zi0t7dTXV2N4zh0dHSQSqWor6+npaWFHTt2kOrYh2s8QqWVeJ27eGFHM03tCbKeT2VpMV4mTdb36cuMfC2XsVKUdcgai+dY/IHcUOZFKTYxmp0uYjZMsY1SYqP4WCKE6Db9GAy9JolrXSpsMaU2RggXH0uxjVBiYwNzbgw9JknC9FPnV5AkjYtDlS0lasP4WLpNP2U2RpgQduAz3mx+jo8lay0p31LsOKR8H4shbAwhB5yB4LjX9UmHs0RNjGzWp2RyEcmEJew6mFgItyuJnVyCGw5B2CE2sYR4PIL1LKWTS7AZH4pC+Ekf1/cxQKi2mL7uNMXxCK7rYLM+JuzkhxcB9fTICWfMwsiSJUs4++yz+d73vgeA7/s0NDTw93//93z+858/oP1ll11Gb28vv/vd7/LbzjnnHBYsWMBtt902qicjcqLLZDKk02kg1zPT3d1NNBrF931c1yUWi5FKpdi7dy8GaGltZcf27ZRGw6R9aNrXzsQJNfR1dUBiN7v6XTCWkpBLv2fwB7KO8TJY42Csxb7FU56PRa7NxYoSGyNKmDQZekyKrMkNtxlriBIaCEBRooQI2xD9Jk3UhgYCU4oyW0SEEAbw8OkwPUQIUWqLMICDQ8yGqRgYFkuRIWkydJgeamycqA3lbvHG5u7Qsmm6TR8VtpRySgj5ht20U2yKyJDBWEOxjeJgSeGTJkssGyJps1S5xUScCD3ZNH1OGifqYHyPsHGwGELGIRkxkI3gORY3CumwIW4ryET6cFKWSCiOMxVKbBgvZCiOROjpy1BTU0XSS+HEXIrdGKFoCLckTFE2TGdnD7hhKicX4TohTNQF18E1BrfIJRx2yaQ8HNcQiuR6Dfu700RiIdzw/lDoWx8sOM6RL2Aox5/D/f4e0d8y6XSa9evXc+211+a3OY5DY2Mja9euPeg+a9euZeXKlcO2LVu2jPvuu28kHy0iQDgcJhzeP9n1YP9wl5SUUFVVBcBcgIsvHtFn+L6f/8LwfZ+2tjZqamowxtDX14cxhraWFjKZDEXFxTiuS7K3l/a2NjLZDH0d7XS2t1AWLyYZi+H39uEkWuntaKaNIkpDxWxv7yHipQgZKI7FSHZ3k8LB2CweDjYcwfE8PDeMdcMYL4ubSWOwZMPRtwxInsmlqi7Td9D3rbEkyQCQNtmDtgHopPeg21tIvOV13MW+N3m39S33PyI+5DuFUgM/wLDT2Lz/V8cafGMxFlxcHEz+ekRsCBeHLB4uDh4+MRvBNz6WXPAqtTEslozxMBgcu38FH8cODE/iYE0ujAz2gPn4uNbBxWDJDWQOBjawZIyf+3zfYM3g/Wi5NgaTe3DEQO25d8jNLXqLy5N/3+b+jISsw/B/G89VY/LtTb5Wm38f7JAPMkM+90gmYNohe5mhn35YBxtsZA7Y4a12H3qt7MCG6bMmcMmVf3s4HzzqRhRG2tra8DyPurq6Ydvr6urYsmXLQfdpamo6aPumpqZDfk4qlSKV2v/Qs0Tirf/BF5HRMfTfXB3HGTb8WlKS6wGYOn36AftNnzVrzGsb5Ps+2WyWbDZLOBwmk8lgjGHP7t307ttL5cRpWN+ntXkP3S2vU1pZTc++Ztpa2ymurKEi6lFqM/S395DoTRMtL2dXdwvZ9k58LwvhKKmUg9ffQ9z16PUt/RmPiNdHOJulPxon7GXIkiFDlHQ4hvF98H1cz8OLFuOZEKF0Cs814ERw3QgZJ/fgSdcafAO+MYS8gS/UgSEax7f4Tm6tm1TIEPLBc8gPhUHui96xDBzjyO9BGNzXmty8n6GGhrTMwHsZ0z+szQFhT6NMx7XyPcHdz3JM9r+uWrWKL33pS0GXISLHKMdxiEQiRCK5u5kGe4tmnXQSnLR/obqDhabjlZ/NYC141hJyHJxQCOtlsVmP3r4+wq7F7+rES/WTtVmsB33dCZyQQ7SkBKe0nI7m7YRSDul0ChMK09LVQ5Hppi3RQSRdRCbdh2cN2WQa3DC9/fsIZSDb34PrhrCRMNl0GidUjHFDZPqTYHLDRVkXTNIj6zm4Ti4wWQxYL9ejYR2s9clYizFhHM9gHZv713JLLoxZH4cQnvXBgDUuxh/8gsz1nBgLnskFMcfmXueZgf8a/Fd9LNbkehvs/gb533zDsP0H2+X6R2x+n3z/w5AOiMEeDP8gfRDDeh2MGdZvYfL1WQ6W3ob2uhy8xcE+5XDf2X/coY0He3fqz5r2FnuOnRGFkZqaGlzXpbm5edj25uZm6uvrD7pPfX39iNoDXHvttcOGdhKJBA0NDSMpVUTkhOIMPB176JJ+xg1h3BBl0YG7tOJVw/YZ/goqJ80Y9nr8+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": 10,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 11,
     "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": 12,
   "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": 13,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.038 (avg p value 0.484878)\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": 14,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.046 (avg p value 0.476295)\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": 15,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.052 (avg p value 0.472795)\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": 16,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.045 (avg p value 0.481225)\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": 17,
   "id": "136ac5ce-81a5-4456-aebf-5eed1158aaaa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.039 (avg p value 0.488479)\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": 18,
   "id": "f481d24d-6b79-48cf-b510-73d227870e9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.045 (avg p value 0.482382)\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": 19,
   "id": "46051924-02f0-4caa-8a61-d92257bba123",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.047 (avg p value 0.479593)\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": 20,
   "id": "a18cbd8b-63d3-4f18-adbd-8ca4874e6561",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.040 (avg p value 0.487639)\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": null,
   "id": "61ecc9f8-634c-4aae-99cc-1a72a5e1bb0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df4b04c8-9f25-467d-bb10-08c17196b973",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "01cd2c1f-b213-46f1-9bf0-68eac5add620",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import bootstrap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.01611403660744643, high=0.058426148420150086)\n",
      "0.016\n",
      "0.058\n",
      "1\n",
      "ConfidenceInterval(low=0.030843540781994475, high=0.06144994461318583)\n",
      "0.031\n",
      "0.061\n",
      "2\n",
      "ConfidenceInterval(low=0.030104337884592932, high=0.07108319434115841)\n",
      "0.03\n",
      "0.071\n",
      "3\n",
      "ConfidenceInterval(low=0.026300026863630064, high=0.06692519892980879)\n",
      "0.026\n",
      "0.067\n",
      "4\n",
      "ConfidenceInterval(low=0.019929480868689505, high=0.05547039580117309)\n",
      "0.02\n",
      "0.055\n",
      "5\n",
      "ConfidenceInterval(low=0.03078858812878784, high=0.061174496677203774)\n",
      "0.031\n",
      "0.061\n",
      "6\n",
      "ConfidenceInterval(low=0.0291602925978253, high=0.06249425432641087)\n",
      "0.029\n",
      "0.062\n",
      "7\n",
      "ConfidenceInterval(low=0.023853715546534083, high=0.06026813835626661)\n",
      "0.024\n",
      "0.06\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(8):\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": 23,
   "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": 24,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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tTgAAFC+eTyjsmbNGn355ZfFvoAwNjZWhw8f9lphAAAAHs+oFBUVqbCwsNj6Q4cOKSwszCtFAQAASKUIKt27d9fMmTNdyw6HQ7m5uZo0adJlf6w+AADAb3l86ue5555TQkKCmjZtqry8PP31r3/V7t27VaNGDb399tu+qBEAAJRTHgeVOnXqaNu2bVq4cKG2b9+u3NxcDR8+XIMHD3a7uBYAAOByeRxUJCkwMFB33323t2sBAABw43FQWbBgwUWfv/fee0tdDAAAwG95HFTGjBnjtlxQUKBffvlFQUFBqly5MkEFAAB4jcd3/Zw8edLtkZubq507d6p9+/ZcTAsAALyqVN/183txcXGaNm1asdkWAACAy+GVoCKdu8D2yJEj3todAACA59eofPDBB27LxhhlZGTo5Zdf1s033+y1wgAAADwOKrfffrvbssPhUGRkpLp06aLnnnvOW3UBAAB4HlSKiop8UQcAAEAxXrtGBQAAwNs8nlEZO3bsJbedMWOGp7sHAABw8TiobNmyRVu2bFFBQYGaNGkiSdq1a5cCAgLUpk0bVzuHw+G9KgEAQLnkcVC59dZbFRYWpvnz56tq1aqSzn0I3NChQ9WhQweNGzfO60UCAIDyyeNrVJ577jklJye7QookVa1aVU899RR3/QAAAK/yOKhkZ2fr+PHjxdYfP35cOTk5XikKAABAKkVQ6devn4YOHaolS5bo0KFDOnTokP773/9q+PDh6t+/vy9qBAAA5ZTH16jMnj1b48eP11//+lcVFBSc20lgoIYPH67p06d7vUAAAFB+eRxUKleurFdffVXTp0/X3r17JUkNGzZUSEiI14sDAADlW6k/8C0jI0MZGRmKi4tTSEiIjDHerAsAAMDzoHLixAl17dpVjRs3Vq9evZSRkSFJGj58OLcmAwAAr/I4qDz88MOqWLGiDh48qMqVK7vWDxw4UJ988olXiwMAAOWbx9eofPrpp1q+fLnq1Knjtj4uLk4HDhzwWmEAAAAez6icPn3abSblvJ9//llOp9MrRQEAAEilCCodOnTQggULXMsOh0NFRUV65pln1LlzZ68WBwAAyjePT/0888wz6tq1qzZt2qQzZ87okUce0bfffquff/5Za9eu9UWNAACgnPJ4RqV58+batWuX2rdvr759++r06dPq37+/tmzZooYNG/qiRgAAUE55NKNSUFCgHj16aPbs2Xr88cd9VRMAAIAkD2dUKlasqO3bt/uqFgAAADcen/q5++67NXfuXF/UAgAA4Mbji2nPnj2refPmacWKFYqPjy/2HT8zZszwWnEAAKB8u6QZle3bt6uoqEiStGPHDrVp00ZhYWHatWuXtmzZ4nps3brVo4PPmjVLLVu2VHh4uMLDw3XTTTfp448/9rgTAADg6nRJMyrXX3+9MjIyFBUVpQMHDmjjxo2qXr36ZR+8Tp06mjZtmuLi4mSM0fz589W3b19t2bJFzZo1u+z9AwCAK9slzahERERo3759kqT9+/e7Zlcu16233qpevXopLi5OjRs31pQpUxQaGqqvvvrKK/sHAABXtkuaUbnjjjvUsWNH1a5dWw6HQzfccIMCAgJKbPvjjz+WqpDCwkItXrxYp0+f1k033VRim/z8fOXn57uWs7OzS3UsAABwZbikoDJnzhz1799fe/bs0ejRozVixAiFhYV5pYBvvvlGN910k/Ly8hQaGqqlS5eqadOmJbZNTk5WUlKSV44L+FrsY8v8XYJP2NYv2+oB4F2XfNdPjx49JElff/21xowZ47Wg0qRJE23dulVZWVl69913lZiYqM8//7zEsDJx4kSNHTvWtZydna26det6pQ4AAGAfj29PTklJ8WoBQUFBatSokSQpPj5eGzdu1AsvvKB///vfxdo6nU6+oRkAgHLE4w9887WioiK361AAAED55fGMijdNnDhRPXv2VL169ZSTk6O33npLq1ev1vLly/1ZFgAAsIRfg0pmZqbuvfdeZWRkqEqVKmrZsqWWL1+uW265xZ9lAQAAS/g1qPCdQQAA4GKsu0YFAADgPIIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLX8GlSSk5N14403KiwsTFFRUbr99tu1c+dOf5YEAAAs4teg8vnnn2vkyJH66quvlJaWpoKCAnXv3l2nT5/2Z1kAAMASgf48+CeffOK2nJqaqqioKH399df685//7KeqAACALfwaVH4vKytLklStWrUSn8/Pz1d+fr5rOTs7u0zqAgAA/mFNUCkqKtJDDz2km2++Wc2bNy+xTXJyspKSksq4Mvha7GPLvLKf/dN6e2U/AOApb/0dk/hb9nvW3PUzcuRI7dixQwsXLrxgm4kTJyorK8v1SE9PL8MKAQBAWbNiRmXUqFH68MMP9cUXX6hOnToXbOd0OuV0OsuwMgAA4E9+DSrGGD344INaunSpVq9erfr16/uzHAAAYBm/BpWRI0fqrbfe0vvvv6+wsDAdPXpUklSlShUFBwf7szQAAGABv16jMmvWLGVlZalTp06qXbu267Fo0SJ/lgUAACzh91M/AAAAF2LNXT8AAAC/R1ABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsJZfg8oXX3yhW2+9VdHR0XI4HHrvvff8WQ4AALCMX4PK6dOn1apVK73yyiv+LAMAAFgq0J8H79mzp3r27OnPEgAAgMX8GlQ8lZ+fr/z8fNdydna2H6sBAAC+dkUFleTkZCUlJZXZ8WIfW+aV/eyf1tsr+/FWPVcrxgfwHdv+HuKPXS0/syvqrp+JEycqKyvL9UhPT/d3SQAAwIeuqBkVp9Mpp9Pp7zIAAEAZuaJmVAAAQPni1xmV3Nxc7dmzx7W8b98+bd26VdWqVVO9evX8WBkAALCBX4PKpk2b1LlzZ9fy2LFjJUmJiYlKTU31U1UAAMAWfg0qnTp1kjHGnyUAAACLcY0KAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFpWBJVXXnlFsbGxqlSpktq1a6cNGzb4uyQAAGABvweVRYsWaezYsZo0aZI2b96sVq1aKSEhQZmZmf4uDQAA+Jnfg8qMGTM0YsQIDR06VE2bNtXs2bNVuXJlzZs3z9+lAQAAP/NrUDlz5oy+/vprdevWzbWuQoUK6tatm9atW+fHygAAgA0C/Xnwn376SYWFhapZs6bb+po1a+qHH34o1j4/P1/5+fmu5aysLElSdna2T+oryv/FK/vxVn3eqgflE69D2MBXf6/9zZu/F7b9rvriZ3Z+n8aYP2zr16DiqeTkZCUlJRVbX7duXT9Uc+mqzPR3BQCvQ9iB1+Efs22MfFlPTk6OqlSpctE2fg0qNWrUUEBAgI4dO+a2/tixY6pVq1ax9hMnTtTYsWNdy0VFRfr5559VvXp1ORyOy64nOztbdevWVXp6usLDwy97f+UV4+g9jKX3MJbew1h6T3kdS2OMcnJyFB0d/Ydt/RpUgoKCFB8fr5UrV+r222+XdC58rFy5UqNGjSrW3ul0yul0uq2LiIjwel3h4eHl6gXjK4yj9zCW3sNYeg9j6T3lcSz/aCblPL+f+hk7dqwSExN1ww03qG3btpo5c6ZOnz6toUOH+rs0AADgZ34PKgMHDtTx48f1z3/+U0ePHlXr1q31ySefFLvAFgAAlD9+DyqSNGrUqBJP9ZQ1p9OpSZMmFTu9BM8wjt7DWHoPY+k9jKX3MJZ/zGEu5d4gAAAAP/D7J9MCAABcCEEFAABYi6ACAACsRVABAADWuqqDyiuvvKLY2FhVqlRJ7dq104YNGy7afvHixbr22mtVqVIltWjRQh999JHb80uWLFH37t1dn4S7detWH1ZvF2+OZUFBgR599FG1aNFCISEhio6O1r333qsjR474uhtW8PbrcvLkybr22msVEhKiqlWrqlu3blq/fr0vu2ANb4/lb/3973+Xw+HQzJkzvVy1fbw9jkOGDJHD4XB79OjRw5ddsIYvXpPff/+9brvtNlWpUkUhISG68cYbdfDgQV91wT7mKrVw4UITFBRk5s2bZ7799lszYsQIExERYY4dO1Zi+7Vr15qAgADzzDPPmO+++8488cQTpmLFiuabb75xtVmwYIFJSkoyr732mpFktmzZUka98S9vj+WpU6dMt27dzKJFi8wPP/xg1q1bZ9q2bWvi4+PLslt+4YvX5ZtvvmnS0tLM3r17zY4dO8zw4cNNeHi4yczMLKtu+YUvxvK8JUuWmFatWpno6Gjz/PPP+7gn/uWLcUxMTDQ9evQwGRkZrsfPP/9cVl3yG1+M5Z49e0y1atXMhAkTzObNm82ePXvM+++/f8F9Xo2u2qDStm1bM3LkSNdyYWGhiY6ONsnJySW2v/POO03v3r3d1rVr187cf//9xdru27evXAUVX47leRs2bDCSzIEDB7xTtKXKYiyzsrKMJLNixQrvFG0pX43loUOHzDXXXGN27NhhYmJirvqg4otxTExMNH379vVJvTbzxVgOHDjQ3H333b4p+ApxVZ76OXPmjL7++mt169bNta5ChQrq1q2b1q1bV+I269atc2svSQkJCRdsX16U1VhmZWXJ4XD45LubbFEWY3nmzBnNmTNHVapUUatWrbxXvGV8NZZFRUW65557NGHCBDVr1sw3xVvEl6/J1atXKyoqSk2aNNEDDzygEydOeL8DFvHFWBYVFWnZsmVq3LixEhISFBUVpXbt2um9997zWT9sdFUGlZ9++kmFhYXFPoa/Zs2aOnr0aInbHD161KP25UVZjGVeXp4effRRDRo06Kr+Ui5fjuWHH36o0NBQVapUSc8//7zS0tJUo0YN73bAIr4ay6efflqBgYEaPXq094u2kK/GsUePHlqwYIFWrlypp59+Wp9//rl69uypwsJC73fCEr4Yy8zMTOXm5mratGnq0aOHPv30U/Xr10/9+/fX559/7puOWMiKj9BH+VVQUKA777xTxhjNmjXL3+VcsTp37qytW7fqp59+0muvvaY777xT69evV1RUlL9Lu2J8/fXXeuGFF7R582Y5HA5/l3NFu+uuu1z/36JFC7Vs2VINGzbU6tWr1bVrVz9WdmUpKiqSJPXt21cPP/ywJKl169b68ssvNXv2bHXs2NGf5ZWZq3JGpUaNGgoICNCxY8fc1h87dky1atUqcZtatWp51L688OVYng8pBw4cUFpa2lU9myL5dixDQkLUqFEj/elPf9LcuXMVGBiouXPnercDFvHFWK5Zs0aZmZmqV6+eAgMDFRgYqAMHDmjcuHGKjY31ST/8raz+VjZo0EA1atTQnj17Lr9oS/liLGvUqKHAwEA1bdrUrc11111Xru76uSqDSlBQkOLj47Vy5UrXuqKiIq1cuVI33XRTidvcdNNNbu0lKS0t7YLtywtfjeX5kLJ7926tWLFC1atX900HLFKWr8uioiLl5+dfftGW8sVY3nPPPdq+fbu2bt3qekRHR2vChAlavny57zrjR2X1mjx06JBOnDih2rVre6dwC/liLIOCgnTjjTdq586dbm127dqlmJgYL/fAYv6+mtdXFi5caJxOp0lNTTXfffed+dvf/mYiIiLM0aNHjTHG3HPPPeaxxx5ztV+7dq0JDAw0zz77rPn+++/NpEmTit0mduLECbNlyxazbNkyI8ksXLjQbNmyxWRkZJR5/8qSt8fyzJkz5rbbbjN16tQxW7dudbuFMT8/3y99LCveHsvc3FwzceJEs27dOrN//36zadMmM3ToUON0Os2OHTv80sey4ovf8d8rD3f9eHscc3JyzPjx4826devMvn37zIoVK0ybNm1MXFycycvL80sfy4ovXpNLliwxFStWNHPmzDG7d+82L730kgkICDBr1qwp8/75y1UbVIwx5qWXXjL16tUzQUFBpm3btuarr75yPdexY0eTmJjo1v6dd94xjRs3NkFBQaZZs2Zm2bJlbs+npKQYScUekyZNKoPe+Jc3x/L87d0lPVatWlVGPfIfb47lr7/+avr162eio6NNUFCQqV27trntttvMhg0byqo7fuXt3/HfKw9BxRjvjuMvv/xiunfvbiIjI03FihVNTEyMGTFihOvN+mrni9fk3LlzTaNGjUylSpVMq1atzHvvvefrbljFYYwx/pnLAQAAuLir8hoVAABwdSCoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACwGscDsdlfQX95MmT1bp1a6/VUxqdOnXSQw895NcaAPz/CCpAOTZkyBDdfvvtHm93oUCRkZGhnj17XtI+Sgo148ePL/bdJwDKt0B/FwDg6nG53zYeGhqq0NBQL1UD4GrAjApwlXv33XfVokULBQcHq3r16urWrZtOnz6tyZMna/78+Xr//fflcDjkcDi0evVqSdKjjz6qxo0bq3LlymrQ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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
}
