{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7d607888-e92d-4720-b28e-43d8ce2c643a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c9bb7deb-4dbb-4100-a5c6-1ab11c826833",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f37c6eff-445d-4007-9951-fdba0c6b46d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7499a23a-7876-4670-ae09-c4de570791e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "46fa7fd5-34ca-4e86-8773-f5ff38b758da",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_10_5000000.0_0.11206463021356713.pkl\", 'rb') as handle:\n",
    "    scores = pickle.load(handle)\n",
    "scores_list.append(scores)\n",
    "scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "006cafd2-ec49-4328-90f0-e7ec1931ca80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 5000)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_100_5000000.0_0.18957624026261533.pkl\", 'rb') as handle:\n",
    "    scores = pickle.load(handle)\n",
    "scores_list.append(scores)\n",
    "scores.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3094d577-6791-4900-953b-d0d27e3d3d14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": 9,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-val.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4214c4b5-d74f-4e52-8c45-1f20ea8d4b38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8d0f643-d0aa-433d-8586-e75351bdd70f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGdCAYAAADAAnMpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABQl0lEQVR4nO3df5yVdZ3//8d1Xef3nPnJMDMwDIziD1QMEAQxf9RGUbr92ralPpbGbu6n0l2L3dbIVbfaQtfyw5ZulLtq38p0bS3LDDPU0g1FQRQUQZRfAjPDADNnfp1f1/X+/nEdzjDyQwZn5gLO8763s8Nc533OeV2Xxnn6/nVZxhiDiIiISEDsoAsQERGR0qYwIiIiIoFSGBEREZFAKYyIiIhIoBRGREREJFAKIyIiIhIohREREREJlMKIiIiIBCoUdAFHwvM8duzYQXl5OZZlBV2OiIiIHAFjDF1dXYwdOxbbPnT/x3ERRnbs2EFTU1PQZYiIiMhR2LZtG+PGjTvk80cVRm6//XZuueUWWlpamDJlCt/73veYOXPmIdt3dHRw3XXX8cADD7Bnzx4mTJjA4sWLueSSS47o88rLywH/ZCoqKo6mZBERERlhqVSKpqam4vf4oQw6jNx3330sWLCAJUuWMGvWLBYvXszcuXNZv349dXV1B7TPZrO8973vpa6ujp///Oc0NjayZcsWqqqqjvgz9w3NVFRUKIyIiIgcZ95qioU12BvlzZo1i3PPPZfbbrsN8OdzNDU18Xd/93d85StfOaD9kiVLuOWWW3jllVcIh8OD+aiiVCpFZWUlnZ2dCiMiIiLHiSP9/h7UappsNsvKlSuZM2dO/xvYNnPmzGH58uUHfc2vfvUrZs+ezVVXXUV9fT2TJ0/mW9/6Fq7rHvJzMpkMqVRqwENEREROTIMKI+3t7biuS319/YDj9fX1tLS0HPQ1r7/+Oj//+c9xXZeHH36Y66+/nu985zv867/+6yE/Z9GiRVRWVhYfmrwqIiJy4hr2fUY8z6Ouro4f/vCHTJ8+nXnz5nHdddexZMmSQ75m4cKFdHZ2Fh/btm0b7jJFREQkIIOawFpbW4vjOLS2tg443traSkNDw0FfM2bMGMLhMI7jFI+dccYZtLS0kM1miUQiB7wmGo0SjUYHU5qIiIgcpwbVMxKJRJg+fTrLli0rHvM8j2XLljF79uyDvuad73wnGzduxPO84rENGzYwZsyYgwYRERERKS2DHqZZsGABd9xxBz/60Y9Yt24dn//85+np6WH+/PkAXH755SxcuLDY/vOf/zx79uzhmmuuYcOGDfzmN7/hW9/6FlddddXQnYWIiIgctwa9z8i8efPYtWsXN9xwAy0tLUydOpWlS5cWJ7Vu3bp1wJavTU1NPPLII3zpS1/iHe94B42NjVxzzTVce+21Q3cWIiIictwa9D4jQdA+IyIiIsefYdlnRERERGSoKYyIiIhIoBRGREREJFBHddfeE8WPX/4xb3S9wcdO+xinVZ8WdDkiIiIlqaR7Rh7Z/Aj3vHIPb3S9EXQpIiIiJaukw4ht+ad/HCwoEhEROWGVdBixsADw8N6ipYiIiAyXkg4j+3pGXOMGXImIiEjpKukw4lj+zfs0TCMiIhKckg4jllUYpjEaphEREQlKSYeRfcM0CiMiIiLBKekwop4RERGR4JV0GLFRz4iIiEjQSjuM7NtnBE1gFRERCYrCCOoZERERCVJJh5HYzhhn7TmLvo6+oEsREREpWSV9o7xIa4RJqUmkU+mgSxERESlZJd0zso+GaURERIJT0mFk39Je7cAqIiISnJIOI4X75CmMiIiIBKikw4g2PRMREQleSYeRYs+Ip54RERGRoJR2GClQz4iIiEhwSjqMaAKriIhI8BRGUBgREREJUkmHkX1zRjRMIyIiEpySDiNWIY1oAquIiEhwSjqMaJ8RERGR4JV0GKnbUwFAsiMacCUiIiKlq6TDiG3807c0TCMiIhKYkg4jhVEaPA3TiIiIBKakwwjWvkkjwZYhIiJSyko6jOzrGdEEVhERkeCUdBjZb5wm0DJERERKWUmHkeI+IwHXISIiUspKOozs6xrRMI2IiEhwSjqMWMVJI4GWISIiUtJKPIyoZ0RERCRoJR1GihRGREREAlPSYcTSPiMiIiKBK+0wUvipYRoREZHglHQY6b9tb7BViIiIlLKSDiPFURqFERERkcCUdBjR2l4REZHglXQY0QRWERGR4JV2GCn81DCNiIhIcEo7jGjSiIiISOCOKozcfvvtNDc3E4vFmDVrFitWrDhk27vvvhvLsgY8YrHYURc8pKy3biIiIiLDa9Bh5L777mPBggXceOONrFq1iilTpjB37lza2toO+ZqKigp27txZfGzZsuVtFT1UinftVceIiIhIYAYdRm699VauvPJK5s+fz5lnnsmSJUtIJBLceeedh3yNZVk0NDQUH/X19W+r6KGiYRoREZHgDSqMZLNZVq5cyZw5c/rfwLaZM2cOy5cvP+Truru7mTBhAk1NTXz4wx/mpZdeOuznZDIZUqnUgMew0GoaERGRwA0qjLS3t+O67gE9G/X19bS0tBz0Naeffjp33nknDz74ID/5yU/wPI/zzz+fN95445Cfs2jRIiorK4uPpqamwZR5xCzNGREREQncsK+mmT17NpdffjlTp07l4osv5oEHHmD06NH84Ac/OORrFi5cSGdnZ/Gxbdu2YamtOGdkWN5dREREjkRoMI1ra2txHIfW1tYBx1tbW2loaDii9wiHw0ybNo2NGzcesk00GiUajQ6mtKOjOSMiIiKBG1TPSCQSYfr06Sxbtqx4zPM8li1bxuzZs4/oPVzXZc2aNYwZM2ZwlQ4DW3NGREREAjeonhGABQsWcMUVVzBjxgxmzpzJ4sWL6enpYf78+QBcfvnlNDY2smjRIgC+/vWvc95553HKKafQ0dHBLbfcwpYtW/jsZz87tGdyFPatplEWERERCc6gw8i8efPYtWsXN9xwAy0tLUydOpWlS5cWJ7Vu3boV2+7vcNm7dy9XXnklLS0tVFdXM336dP70pz9x5plnDt1ZHCWT98OI5Wkmq4iISFAsY479CROpVIrKyko6OzupqKgYsvf96fU/5lXnNaqcMr54/ZeH7H1FRETkyL+/S/reNGj+qoiISOBKOoxYpX36IiIixwR9G4uIiEigSjqM6N40IiIiwSvpMKL94EVERIJX0mFkXxRRx4iIiEhwSjuMqGdEREQkcCUdRvr7RkRERCQoJR1G+ntGNE4jIiISFIURFEVERESCVNphBN21V0REJGilHUY0gVVERCRwJR1G9vbmgi5BRESk5JV0GPEKPzVKIyIiEpySDiNa2isiIhI8hREADJ7xDttSREREhkdphxHLP30DuJ4bbC0iIiIlqqTDiGX27TNiyJt8wNWIiIiUppIOI1hO8Y/qGREREQlGSYeR/h1YDa5RGBEREQlCSYcRw745IwojIiIiQSnpMGKhCawiIiJBK+0womEaERGRwJV0GDHst5rG02oaERGRIJR0GOnvGUGbnomIiASkpMMIdv8EVu0zIiIiEozSDiP7r6bRBFYREZFAlHgY8YdpPE1gFRERCUyJh5HC6VtoAquIiEhASjqMGNsq/jmbywZYiYiISOkq7TBi9YeRXD4XYCUiIiKlq6TDCFb/6Wdd9YyIiIgEobTDiL1fGMkrjIiIiAShpMOI1z9KQ87VMI2IiEgQSjqMWLaNbfxEop4RERGRYJR0GDGWhVXYa0Q9IyIiIsEo7TBiW9j7wkhOYURERCQIJR1GsOkPI+oZERERCUSJhxELu3AJFEZERESCUdJh5Oz2XxXnjORdbQcvIiIShJIOIxb54moa7cAqIiISjJIOIwBO4RLk8+oZERERCUJphxHL6w8jWYURERGRIJR0GHll+/ZiGPHyXsDViIiIlKaSDiP5dK4YRty8G3A1IiIipamkw4iXzWMb/xIYhREREZFAlHQYsTD9wzQ5DdOIiIgE4ajCyO23305zczOxWIxZs2axYsWKI3rdvffei2VZfOQjHzmajx1yFuAU/uy5CiMiIiJBGHQYue+++1iwYAE33ngjq1atYsqUKcydO5e2trbDvm7z5s384z/+IxdeeOFRFzsc9u0zojAiIiISjEGHkVtvvZUrr7yS+fPnc+aZZ7JkyRISiQR33nnnIV/jui6XXXYZX/va1zj55JPfVsFDyaL/3jRGYURERCQQgwoj2WyWlStXMmfOnP43sG3mzJnD8uXLD/m6r3/969TV1fE3f/M3R/Q5mUyGVCo14DEsrP6eEZM3w/MZIiIicliDCiPt7e24rkt9ff2A4/X19bS0tBz0NU899RT/9V//xR133HHEn7No0SIqKyuLj6ampsGUecQss1/PiKcwIiIiEoRhXU3T1dXFpz/9ae644w5qa2uP+HULFy6ks7Oz+Ni2bduw1GexX8+IVvaKiIgEIjSYxrW1tTiOQ2tr64Djra2tNDQ0HND+tddeY/PmzXzwgx8sHvM8f25GKBRi/fr1TJw48YDXRaNRotHoYEo7KpbV3zOCekZEREQCMaiekUgkwvTp01m2bFnxmOd5LFu2jNmzZx/QftKkSaxZs4bVq1cXHx/60Id497vfzerVq4dt+OXIGexCBjGuwoiIiEgQBtUzArBgwQKuuOIKZsyYwcyZM1m8eDE9PT3Mnz8fgMsvv5zGxkYWLVpELBZj8uTJA15fVVUFcMDxIFj480YA0GIaERGRQAw6jMybN49du3Zxww030NLSwtSpU1m6dGlxUuvWrVux7eNjY9f954wojIiIiARj0GEE4Oqrr+bqq68+6HNPPPHEYV979913H81HDosBPSMapREREQnE8dGFMUwsy2DtSyEKIyIiIoEo7TCC5oyIiIgETWFk3y/qGREREQlEaYcRCzD7hmmsw7YVERGR4VHaYQSwjOaMiIiIBKmkw4ht9c8Z8TtJlEhERERGWkmHEX/OSP8wjasb1IiIiIy40g4j+80ZsbDIeblgCxIRESlBpR1GoD+MGIURERGRIJR0GLH3X02DRc5VGBERERlpJR1GLKt/zohlUM+IiIhIABRGijuvqmdEREQkCCUdRmzLwuy3gibjZgKsRkREpDSVdBix7P02PcNSGBEREQlASYcRm4EbnWVyCiMiIiIjraTDiGVZ+/WMKIyIiIgEoaTDiG1bGFOcwUpfri/AakREREpTSYcRy7KB/Saw5tUzIiIiMtJKOoz4PSP+7qugYRoREZEglHQYsSwLg0eocBmyuWzAFYmIiJSe0g4jto0xHk7hMqRz6YArEhERKT0lHUZs28ajP4zkctqBVUREZKSVdBixCqtpHKNhGhERkaCUdBixbRvPeDg4gMKIiIhIEEo8jFh4uMUJrBqmERERGXklHUYsy8Y1+eKckXw+H3BFIiIipaekw4jtOHjGLc4ZyeXVMyIiIjLSSjqMWJY1oGfEzbtv8QoREREZaqUdRhxnQBhRz4iIiMjIK+0wYvvDNCH1jIiIiASmxMNIYQJrYc6I53pv8QoREREZaqUdRhwHz+SL+4yoZ0RERGTklXQYsW0H17jFOSPqGRERERl5JR1GsP0JrGHj94wY1wRckIiISOkp6TCyb5+RcGGYBi2mERERGXElHUYsJ+T3jBDyf3etgCsSEREpPSUdRmwn7PeMFIZpbLekL4eIiEggSvrb1wmHB/SMOAojIiIiI66kv33tUBgAx/jDM7brBFmOiIhISSrxMFLoEfGswk+FERERkZFW0mEkFIkB4BRW9DrGxhgt7xURERlJJR1G7HDU/+n5AcQ2Dtl8NsiSRERESk5ph5FoxP+5X2dIR29HMMWIiIiUqJIOI/uGaSzjYRcmsaZ6U0GWJCIiUnJKOozYUT+M7L+8t6u3K8iSRERESk5JhxEnGgcYcH+arj6FERERkZFU4mHE7xnxTJ5IoWekp68nyJJERERKzlGFkdtvv53m5mZisRizZs1ixYoVh2z7wAMPMGPGDKqqqigrK2Pq1Kn8+Mc/PuqCh5Id8SewuvvdLK833RtkSSIiIiVn0GHkvvvuY8GCBdx4442sWrWKKVOmMHfuXNra2g7avqamhuuuu47ly5fz4osvMn/+fObPn88jjzzytot/u5yIv7TXH6bxe0YURkREREbWoMPIrbfeypVXXsn8+fM588wzWbJkCYlEgjvvvPOg7d/1rnfx0Y9+lDPOOIOJEydyzTXX8I53vIOnnnrqbRf/doUKPSPefj0jfem+IEsSEREpOYMKI9lslpUrVzJnzpz+N7Bt5syZw/Lly9/y9cYYli1bxvr167nooosO2S6TyZBKpQY8hoNTHKbp7xnJZDLD8lkiIiJycIMKI+3t7biuS319/YDj9fX1tLS0HPJ1nZ2dJJNJIpEIl156Kd/73vd473vfe8j2ixYtorKysvhoamoaTJlHzIpEwOybwOr3jGSz2oFVRERkJI3Iapry8nJWr17Ns88+yze/+U0WLFjAE088ccj2CxcupLOzs/jYtm3bsNRlOQ6WGTiBNZ/LD8tniYiIyMGFBtO4trYWx3FobW0dcLy1tZWGhoZDvs62bU455RQApk6dyrp161i0aBHvete7Dto+Go0SjUYHU9rRcRxsBg7TuDl3+D9XREREigbVMxKJRJg+fTrLli0rHvM8j2XLljF79uwjfh/P846JuRlWOIxlDHkvp54RERGRgAyqZwRgwYIFXHHFFcyYMYOZM2eyePFienp6mD9/PgCXX345jY2NLFq0CPDnf8yYMYOJEyeSyWR4+OGH+fGPf8z3v//9oT2To7BvmCZvMiQKPSMmZ97iVSIiIjKUBh1G5s2bx65du7jhhhtoaWlh6tSpLF26tDipdevWrdh2f4dLT08PX/jCF3jjjTeIx+NMmjSJn/zkJ8ybN2/ozuIoWY6DbQw5L1vsGfHyXsBViYiIlBbLGHPMdwWkUikqKyvp7OykoqJiyN7Xy2T4/ic+yqiqSZw85l08HFmFm3D5xj99Y8g+Q0REpFQd6fd3Sd+bxgqFsI0h72WIFG6Uh6aMiIiIjKiSDiPYtj9MY7KECyNWlmsFXJSIiEhpKekwYlkWVmHOSMj4l8LyFEZERERGUkmHEaA4TBMqTGC1jEU+r7EaERGRkaIwgiHvZYthBCCXywVYkYiISGlRGMGQNzkcbCzjD9Ho/jQiIiIjR2HEGAwG13jFvUbUMyIiIjJyFEYKP/PGKw7VKIyIiIiMHIWRwk/XuMUVNX3pvuAKEhERKTEKI4WVvPv3jOzu2R1gRSIiIqVFYcTy04hr3GIY6ejpCLAiERGR0qIwUggjec8lXNgSvqO3I8CKRERESovCSGGcJm/yRApbwqd6UkGWJCIiUlIURiz/ErjGJWrCAPT09QRZkoiISEkp+TDiOP4lyJs8UfwwkunLBFmSiIhISSn5MGLb/jyRvMkTK/SMZDPagVVERGSkKIyE/HkirskTLcwZyWW06ZmIiMhIKfkw4jh+AMl7ueKcES/jBVmSiIhISSn5MGKHIkBhzkghjJicCbIkERGRkqIwEvYDSN7LFSewolEaERGREVPyYcQJ7+sZyRUnsNqujedpqEZERGQklHwYCUdiALhepjiB1cIinU4HWZaIiEjJKPkwEopEAciZDDY2zr479/bpzr0iIiIjoeTDSLgQRlzP7wmJFG6W19vbG1hNIiIipURhJFKYM+L6YWTfJNaO7o6gShIRESkpCiNRv2ck6/n3o0l4/u97U3sDq0lERKSUKIxE/QmsGbcLgDLj/96R6giqJBERkZKiMBLzw0fe68U1hjj+sE2qOxVkWSIiIiVDYSRRVviTR8YY4sYPIz09PcEVJSIiUkJKPoxEk8nin7PefmGkW2FERERkJJR8GHESCSzPvxdNxnNJGn8Ca1+39hkREREZCSUfRux4HMf4W7/njVecwJrrzWlLeBERkRGgMBKLYRd6RvLGo4woYMCD7u7uYIsTEREpASUfRqxYHNvsCyMuNjaW5T/X1dUVYGUiIiKloeTDiB2L4nj9YQTAxk8julmeiIjI8Cv5MGLFB/aMAITQzfJERERGSsmHkf3njOS8PAChws3yFEZERESGX8mHESsWxyn0jLjGDyMRhREREZERU/JhxI5F+4dpvBwAMePfuVdhREREZPiVfBixQiFsP4uQM/vCiL8La3ePlvaKiIgMt5IPIwBOYS1v1ssCUGESAHT1ammviIjIcFMYARy7sJTX9Ydlqt1yAHp6dX8aERGR4aYwAji2P2E17fr7isQL96fRPiMiIiLDT2EECDl+GPHIkzGGqAkBkElngixLRESkJCiMAE7IDx+YPGkDUfzVNLlMLsCqRERESoPCCBAK+6tnMFnSxhAtLO01riGXUyAREREZTgojQCTizxExJkvaNYRxAH+9r26WJyIiMryOKozcfvvtNDc3E4vFmDVrFitWrDhk2zvuuIMLL7yQ6upqqqurmTNnzmHbB2FfGMGkyXpgYWEXlvvu3bs3wMpEREROfIMOI/fddx8LFizgxhtvZNWqVUyZMoW5c+fS1tZ20PZPPPEEn/zkJ3n88cdZvnw5TU1NvO9972P79u1vu/ihEo32h5F0YQO0GP48EoURERGR4TXoMHLrrbdy5ZVXMn/+fM4880yWLFlCIpHgzjvvPGj7n/70p3zhC19g6tSpTJo0if/8z//E8zyWLVv2tosfKtGYv8mZ5fXSV7hpXmVh47OOjo6gyhIRESkJgwoj2WyWlStXMmfOnP43sG3mzJnD8uXLj+g9ent7yeVy1NTUHLJNJpMhlUoNeAynaNwPHsZk6HL9MDI6X1WsV0RERIbPoMJIe3s7rutSX18/4Hh9fT0tLS1H9B7XXnstY8eOHRBo3mzRokVUVlYWH01NTYMpc9CiZWUAeOTocg2eDUkTBxRGREREhtuIrqa56aabuPfee/nFL35BLBY7ZLuFCxfS2dlZfGzbtm1Y64qWJQt/MkCebMQp3rl3b5fmjIiIiAyn0GAa19bW4jgOra2tA463trbS0NBw2Nd++9vf5qabbuL3v/8973jHOw7bNhqN9k8qHQHRZBKMAcsCkyFtVxArbHzW2d05YnWIiIiUokH1jEQiEaZPnz5g8um+yaizZ88+5Ov+7d/+jW984xssXbqUGTNmHH21w8SOJwi7HuDPG+mB4sZnmT5tCS8iIjKcBtUzArBgwQKuuOIKZsyYwcyZM1m8eDE9PT3Mnz8fgMsvv5zGxkYWLVoEwM0338wNN9zAPffcQ3Nzc3FuSTKZJJlMHvJzRpKdiBNyPXIhB0yGHtdQbfxdWU3W34U1HA4HXKWIiMiJadBhZN68eezatYsbbriBlpYWpk6dytKlS4uTWrdu3Ypt93e4fP/73yebzfKXf/mXA97nxhtv5F/+5V/eXvVDxIrFCLseffg9I31ZlzgRHCxcDG1tbTQ2NgZdpoiIyAlp0GEE4Oqrr+bqq68+6HNPPPHEgN83b958NB8xouxYvDhMQyGMWGGHJFE6SdPS0qIwIiIiMkx0bxrAjscIuS7g94zksn4wKTP+ih/dn0ZERGT4KIwAVixO2Cv0jHgZPM+/L02Z8Vf0aK8RERGR4aMwQv8EVgBj0uSMvwtr0vM3Puvr6wusNhERkROdwghgx2KE834YsekhV7hZXoXnbxPf09MTVGkiIiInPIURwIrHCXv+nBHb9IeRaGHjs47ujoAqExEROfEpjABOWVlxNY1l+jCAVxYqbgmvCawiIiLDR2EEsCIRIiF/kzNMGoA9TRVUGf8Germ+HN3d3UGVJyIickJTGCmIJvz5Icbzt3/vzuSJECJeGKrZsWNHYLWJiIicyBRGCqLJcgA8kwegu8//WWH8FTWdnbphnoiIyHBQGCmIlVcAkDcexhi6egthpLCiRsM0IiIiw0NhpCBWVQ2Av5AmT2dXFoDywl4jCiMiIiLDQ2GkIFpdDYXNzjAZMj15vAjE8Se2akWNiIjI8FAYKQhVVxWX9xqTgazBzkKycH+ardu2kslkgixRRETkhKQwUuBU9YcR2/QPyYz1akiYCOm+NNu2bQuqPBERkROWwkiBU1VVvD9N3GoBwD1jFA42ozx/cuvevXsDq09EROREpTBS4FRWEnb9LeGT1hYAdlb680XKC0M1v/nNb/D23d1XREREhoTCSIFTVUV1j7/7and6JwB7Wnox5Q4JEy2227VrVyD1iYiInKgURgqcqirqunoBSOf9PUZSezM4ZRFOdRuK7Xp7ewOpT0RE5ESlMFLgVFURzvvDNDnPX+Lb05EhnIxSRoxcyO816enpCaxGERGRE1Eo6AKOFXZ5OZHCdJC8sXFMnkyXhV3m35smVMht6hkREREZWuoZKbBsm2gyiVXc+KwX4xm8kH+JIoXcpp4RERGRoaUwsp/QfkM1CWs7AJnCkE3M+D0k2olVRERkaCmM7MeprCRS2GskafkbnPVk/HBSbcoAeOONN4IpTkRE5ASlMLIfp7qaWM5fSRMxrQB09/m/X9g7BYC2tjbS6XQwBYqIiJyAFEb2E6qrI5b1w4cxKQD2eAYvbIgTwVh+L0lbW1tgNYqIiJxoFEb2E6qrI17oGXHdPgBad6epenczAEn8zc8URkRERIaOwsh+QnWjiz0jWTcHQOfeNOEx/nyRai8JQHt7ezAFioiInIAURvazf89Inz8ig+l1sav8HpF6txqAPXv2BFKfiIjIiUhhZD/hujrihZ6R7nwIy2SxDKQLW4+M9ioBhREREZGhpDCyn1BdXXE1Td5zqLD95b2dHRns0VGqPH+4Zvfu3XR3dwdWp4iIyIlEYWQ/Tk0Njm0TKQSShLUZgNee30XtJ88kSYzRXgXGGF588cUAKxURETlxKIzsx7JtQqNHF+eN1DqrAXh99S4iY5Pkwi6nu2MBWLNmTVBlioiInFAURt4kVFtbXFETMS0AZHryGGPwYtDo1QD+8l7XdQOrU0RE5EShMPImTk11sWck7fozV41nyKZdrESIpIlhY+G6Lh0dHQFWKiIicmJQGHmTUHVNcUVNVy5MyPK3fk9354j02FhYVBcmsmrzMxERkbdPYeRNnJoaEll/w7M9biUxy98WvrsjjeVaAIzyKgDYvn17MEWKiIicQBRG3sSpqSaR8cNIKhvFGH+o5qHbXqRm3ukA1Bk/jLz44otks9lgChURETlBKIy8SahmFIlsHowhmzfE7F0A5DMusdOrqfroKTS7dYSwSKVSbNy4MeCKRUREjm8KI2+SfNfFOMYQy/krZc5P/L/ic917MzgVEWKEqcffjVVhRERE5O1RGHmT0KhRlJ1/fnHeSCofZlRoEwDtb3QTGhUH4OxsMwCvvvpqcShHREREBk9h5CBCY8dQVpg3siF2LrWhzQBsf2UvoVo/jDR4VTjGpqurS6tqRERE3gaFkYMIjxnT3zMSGkNt2O8ZeeGxbWTTeWIX1hPCYazn38VXQzUiIiJHT2HkIMJjxhZX1OTTWU6JPVl8rnNXH7WXnsaaqtcYUwgjW1/dHESZIiIiJwSFkYMI7zdMk96zi3YrSm3odQD6ugshpRJqTTkAO7dovxEREZGjpTByEMVhGmPIdHexMjeRuO1vftbX5e8rEqsrZ5RXDgZSppdUKhVkySIiIscthZGDCDU0EDJQnvaDxxZvAjG7E+gPI7P/bA5RwowubID25JNPHvzNRERE5LAURg7CjkaJnjKRyt4MAJNPO5uI3Q3AS09sxvMMyepKVk56nTPz4wBYuXIlmUwmsJpFRESOV0cVRm6//Xaam5uJxWLMmjWLFStWHLLtSy+9xMc+9jGam5uxLIvFixcfba0jKj51GlWFMNK5cyfZUK//590uL/3RnyOSPHM0p3gNJEwEz/N45plnAqtXRETkeDXoMHLfffexYMECbrzxRlatWsWUKVOYO3fuIffa6O3t5eSTT+amm26ioaHhbRc8UiInn0xln3/H3rbNr1M7rpOz4o8AsPWl3QCcc9JMLCwa3VEAPPbYY7S0tARTsIiIyHFq0GHk1ltv5corr2T+/PmceeaZLFmyhEQiwZ133nnQ9ueeey633HILn/jEJ4hGo2+74JESHju2f0VNV4rI2CmcmXgUgB2vdWI8Q1XtKLqrs1SYePF1GzZsCKReERGR49Wgwkg2m2XlypXMmTOn/w1smzlz5rB8+fIhKyqTyZBKpQY8Rlq4sZGQZ4i5XuH3GdSGNhGy+sj25tmzswfLsqiadxr1lBdfl+rUqhoREZHBGFQYaW9vx3Vd6uvrBxyvr68f0uGJRYsWUVlZWXw0NTUN2Xsfqci4RgCSvf5QTUfrHnaEGmkI+z0fO1/zV9c0NDexvWkPF+XOAGDVqlVa5isiIjIIx+RqmoULF9LZ2Vl8bNu2bcRrcKqqsMJhxu71V9GsWbaU8CkXMSa8DoAtq7YU2+ZPj3KyW0+1V4ZnPJ55auh6iURERE50gwojtbW1OI5Da2vrgOOtra1DOjk1Go1SUVEx4BEEk8sxpqObUN6ls62VjrJpNEbWArD5lTQ7N3YAUN5cy+qyV5iabwbgf1csp6OjI5CaRUREjjeDCiORSITp06ezbNmy4jHP81i2bBmzZ88e8uKCNuab/4pjDOP2dgGw8fU9jI28RHPUX8q8trDE95z6c7i58S4avVHF1/7hD38Y+YJFRESOQ4MeplmwYAF33HEHP/rRj1i3bh2f//zn6enpYf78+QBcfvnlLFy4sNg+m82yevVqVq9eTTabZfv27axevfq4uNNt1cc+hjNqFLVdfQC0v7GV3yU/xJTErwHYsWEPAHWJOh791DIuO+1aTnX9HqK1a9bS09MTTOEiIiLHkUGHkXnz5vHtb3+bG264galTp7J69WqWLl1anNS6detWdu7cWWy/Y8cOpk2bxrRp09i5cyff/va3mTZtGp/97GeH7iyGUbixkWTG3wJ+b8sOZn3++9SFXwM8ujty9K54AIBkJMn/mfopysIQNxFy+RzPPvtsgJWLiIgcH45qAuvVV1/Nli1byGQyPPPMM8yaNav43BNPPMHdd99d/L25uRljzAGPJ5544u3WPiKiEycSz+axLRs3l4OebjbFT6Em5E+qXffgE8W2V029iperNzGlMHfk9dXac0REROStHJOraY4lsUmnYwFJ2wFg7443CL/nOpqjfq/H07s/Qm/K7zkJ2SGYXoHluABs7dhBT5uW+YqIiByOwshbiE+b5v/s8EPFAzf9C2PPuogbYxdj4YeOV5/ZXmz/7uY/4/813o1j/Et7+w//g/b29hGuWkRE5PihMPIWYmefTfT00ynv7Ssee+YX9/GleRcyrfweAJ76n028+lwrxjNMr5/O9lgb3VE/vPTm09x2222azCoiInIICiNvwbIskhdewPj2FGV2CIANTz/Fu8+oY1e0f9fZ3/3nS2x6sZ2IEwHgt2N+R4JI8fm13/w92Te6RrZ4ERGR44DCyBEo/8AHiLkeF6zegO04pHa1kd69i96zP8nZiYeL7Xas9+/me8vFt2BswwPjHixe4PXOdjp+symA6kVERI5tCiNHIH7WWZRddCGOMdSW+TfF2/byGi6a+3GeiXUzIfocAC88voNUex/vb34/753wXnrCvbxW/joArztt7Nq8k+yObtzOTGDnIiIicqxRGDlClX/+Qf/nJn9J77aXXmRMZYynxn6KtuiOYrt9N9D72vlfY27zXNZVvVJ87rfh51l526PsvOU5BRIREZEChZEjVHHpJdjJJNUdha3hn32anr17+M5fTeWu+DuL7bp2+c+XR8r5zFmfoS/UxyONS7GMRbed5pHIC2zz2shs6gzkPERERI41CiNHyLJtohMnMqq7j1FVNeQyaV59djmn1CV57Pq/YFrZ/QA889A2Nq9pxxjD5NrJXHPONXRHenBD2eJ7bbJ3see/N5DvUO+IiIiIwsggRCdNwgJGrXsVgJee+D29qU7CIQfH2Vts95vbX+SFh9YA8NmzP8vidy1m5ahVxec3hHawmTZSv98yovWLiIgcixRGBqH2c/8XgPrOHixjaH19I3d98f+S7ulm47u+QMLeU2y7+pHXcV0PgNljZ5OuzfJ4w+PF538feZG257aQ3dFNesNeRERESpXCyCCEx4yh5orLKc/kmLK1DYB0TzebVq/ksksu4tSJD/CBqpsIW7305CvY+JTfg5IIJ7h+9vXsie3BYIrvd2/sf3ns9l/RfudaMlu0bbyIiJQmhZFBqvvKV4hOmsTYjm7OGNUAwAu/exhjDJvfuYh/tt/DlMRDAPz+Z9vZc8ffQjrFxeMu5uaLbqZtchtZu3/+yNPhDfSQoefpnez9n1c1j0REREqOwsggWZbF6L//OwDKnn0egO2vvMT6P/2RD00dy/POFJ6J9rf/2cpP0PqTr2NZFpecfAmLP7qY1856jd3R3f1tYk/R9XwLPc+20PlbbYwmIiKlRWHkKCRmzgSgujddPPab795C52vr+P0/XEz3lL/inLKfF5979PlpmB4/fESdKIvnLuYPY/5Ar9NbbPNkeB0AfS/souU7z+F29/eeiIiInMgURo6Ck0wSmTCBsOtx5hu7iscfu+sHNFbFufKSd/Iv5kPF453uGH5z2/N07/XDy5jkGP7nw//DY02PsSfiT3rd6LSw3fbnlOR39dGpreNFRKREKIwcpZMe/CWxs85iwu4UTfg30GvftoWNzz3D6PIof/Xh01gRzRFy/ImuWzbZ3Pv1p3E7/JvrnVp9Kt9973dZNX5VcVLrbyPP81/Rx9hi76L3+TZ6V7dhjMHL5IM5SRERkRGgMHKU7FiMhuv/GQuY/ML64vEHb/kGABefMZo/xPM8U7GJ02P+kt5Mn8eSr7xMzyvPAnB+4/n8+i9/zc7Ezv43tuDRyIsA7Ll3PdsXPsWOG5fTs7KVfHvfyJyciIjICFIYeRviU6cy6sorsYDKnv75I2se/x2n1JUzfUI1j5l3cFeijPOSPy4+v/6hPxb/XB2rJnFOgow9cBXNLyIreDy8Fg9/r5K992+g5dvPkWvrRURE5ESiMPI2Jc6dAcCMTTtJZHIA/G7Jd/n1/7uJJR+fxK+ufifN517Kf4XHF1+zfOM0Wla+WPz96xd9nfgFcVZMXFE8ttvu4jWnlbXhNwZ8XuutK0n9fotCiYiInDAsY4x562bBSqVSVFZW0tnZSUVFRdDlDOCmUrx26aW4u9rpjob546T+0BGJx/ncD35MOBrjpR2d/Ou9L/CejXvIeP45JBNZPv7XCRKTLwIg5+X4zs+/Q/rl9IDPOGvMqYS25Wh2RzPa9J9/7V9PJnpqFZZljcCZioiIDM6Rfn+rZ+RtcioqOPWPf6Tywx8imckxeVv/6ppsXx9//OndAJw1tpKLzmnkF+XtJGx/mW93b4S7bsvz8vduhjdWErbDfOy9H+O3E37Lc7XPFd/npZ2v8kJoMw9GnyWPWzzefudati98iu3X/y/dT+8kpzklIiJyHFIYGQKWZRE/ZzoATXtSfGLWnzH53e8DYPUjD/HT6xbQ0drCJ85t4iVrDE+Wbydu99+P5vGXzmXNnXdDtpdTU+08PO83XDjzQtaOXXvAZ/1qzIvELhk34JjJeXT8ciPtd67FGINxj/nOLhERkSIN0wwRL53m9Q9/mNyWrQCEz57Mg/bAnoov/Oc9xJLlfOauZ0m8+hCT975rwPMfrr6ecdG1uB++A3vqx7Esi6WblrLod4uYmJpIfV89US+K4ziMH93IlG0N1LrlBxZTGLUJN5RR8Z7xxCfXDscpi4iIHNaRfn8rjAwh47psufwK+lauBGDNuFq2jaosPj/7Lz/J+R+/DGMM3/7deh549HXe2xeh3j2wg+qss3O869Nng2Wzuq+FT//201RmKrmo5SIiXqTY7n3hcxjfVX3YuhLT6oieUkXZ9PohOlMREZG3pjASEOO6dD36e7Z/8Yv+78DeP5/L09s24oRCTH73eznl3Nk0TzmHDa1d/HZNC7/+3dN8NNV4wHtdVvt5KstzWH/zCC9tepRPvPx9bM/m0m2XDggkU2adzZSy0yh/FWKnVePuzdD9px0HvF/ywkaqLj15uE5dRERkAIWRgOX37qXlhhvoevT3GGDDZ+bx2vP9k1I/ddO/U3/SRAAyeZfv/mYdztIdRE1owPsk7Xb+rPI2xkVepPuy+zh/+T+SzCY5JXUKE7smDmgbCoeY/5n5NDY20vHr1+j+3wMDiZ0IERqdIDQ6jteXp/zCRqLNlQe0ExERebsURo4BbmcnG2adB0C4uRnvi1fz7JOP0bLR37E1UVlFvLyC2X/5SU6ddQFL/vgaW15bT82GJ0l2vu+A9yu323j/Offycl0tm+tPY13nblKrU9T3Dhx+qZlQw4SaCeTSWT7w/g9gbeplz73rD3i/feq/dA5uV5boxCq8rhxOReSQbUVERI6UwsgxYtvVV9P9+2XF33vPO5c/pDswxhvQ7qr/updYMgnAsnWtPPX/3czYjneRNckB7aJWNx8bdS3VoR1w3hfouvifuPuJn7B51WbKcwdOZg3Vh7j2b6/F7jPs/tHLZLd1YUUdTMY9oC22BZ6BkMWoT51JtLkCPIOdCA/BlRARkVKjMHIM2XvvvbT8y9eKv7eVJ1h/1il09fUMaHf67Au59Jp/wrIs/uG/X+CBlW9wmrWNBnr4QHclu/P98z1iVoqKUCuTGjcwoaGbZXU2v9rQx4SO5gM+P2fleLnpZWZEZnDxSRcza+YsnBzs+PrTh63bLgvj9fi7yiZm1FP94VPw0nnsZFgbrYmIyFtSGDmGGGPY/cM7yO3cQepXv8br9bdydy3YNLqKV8eMYv9/CFd8+3ZqmyYUf+/ozbLgxj8wvcs57OdcMuqr3FNZyYuj02xxM7z/jfcftJ2bdJk7Zy4zT55Ofks3lmXR83wb+fY+8q1vvc188p1jqbz0ZPrWtpNr7aXiPeOxbIUTEREZSGHkGNW76nm2ffazxUAC0BsOsWbqJHZn+/clmTjjPOZ89gskq2sAaG/r5X9+tJY9rb309OUZc5DlwDY55lR+l5NiK9jWeAmrEh/iwbYHOTl16BU0zjiHsyacxbmTzuXJJ5/k3e9+N2Xr86SWbj7ic6r+q9NITKtTb4mIiAygMHKMy7e3s2PhV+l58kkAPKC9eRyvTmyis70NANtxiMQTTJw+kws+eQXhaJRooozV2zpY+MAa/mxCDe27eqlZ1UnSHHwz3VGhzZyb/CmvVFtsMC5bkhOpah930LYAkWiEj37ko3Q+v4Nmu55R7zkZLItdS17A684d9pxik2qInzWKzKZOelcVziERouJ9EwiPSRJpTGKFtOmviEipUBg5TuTa2th40cX9v9s27eVxXmmqp885eE9DtKyM6Zd8hK497Uy64N28955tjErDZd3Rt/w8g2FUzf08U5GlKj3+sG3dpMvJ7zuZ8mw5k6pO49R4M+us1zidifQ8spX0+r2Hff3BlF88jvKLx2lSrIhICVAYOY4Y12X7P/4jXb9dWjyWs206yqLsTsZ5ve7wO6zO+NDHWFV+NtXJasr7PNLbetiycw/lbX3YJn7I19VGXuKZ+lXkTBLLdqjJVh32c3bGdxLxIvQ09XDtJddSF68jvsPCKY9gMi59L+8mvW43uZa3nndixRyskE1iej2WBZHxFYTrEv69dXIeTnkEp1xLjEVEjmcKI8ehXGsrm+d9gnxLS/GYATbXVuJ4Hm6h12RXRdlBX18+ajQnnzODiy//LH2dnax/9lme3lLPmnV7yFqGczOH7o1I2LtpqXqR3gg4HH6i7D5tsTbq3XpOmnASf/bBPyOSiVBRUUHUCdO65AV6oxnGfehs2hY/P6jrUGRDYkod+fY+vL48Nf9nEuEG/9y9npzCiojIMU5h5DhljAFj6Fq2jN5nVrD3Jz85oM32qiRrmurwjmAFS7KmltqPX8Pangjbt3XR+moHFlBGmvOyLrZ76F6XZHQ926p24FqGiNNGxh37lp/nxT1GXzCaR9seJdWW4pzIOVwQOo85Z1xAfGINm2/+X+JEsMtC2MnIEa3eebN9S46dighls8dQNr0eO+kHE5N1ye/qI9yQwAofWagSEZHhoTByguhZsYI9d91NeNw49v74xwOe25OI0ZmIksjmWDtuNJlw6BDvAvUnn0L1mEZSDWfwem+Iz/3FhXznwZfh6Q5wO6gzFYStw8/jyIW68Zw0vWVvkA11s6X8dU7qaR70OdVNryWRLmPySWfzjjPPZs+mVsrabbr/tB1CNpZjk28bZEixwQrZmGz/ZnINX55B75p28q29lJ1bT/TkKgCM62E5mkgrIjLcFEZOYPm9e+l65BF233kXua1bAX/Pko31NXTHwniWdcihnP3FypJMPPc8Xnri98QbmolO/TiXXHoOP7r/Fey1KWIGHA7f++I6aXrLNpO2c6SjHbhOHwk3xmBX+SZHJalurGZHaAedyQ5mbTiLd866iPKeOE55mNjpNWRe72TPvesxWX/32EhzBdnNqcF9EIBjET2pErczg1MdwwrbxM+oKcxf0fJkEZGhojBSAowxpNe+hB2Lkt2+ne7HHqfjv/8b8JcKp+JRsGBnZZJNdVVH9J62E8IYj1FNE6hsOon46PG0vLKF7s7TWe1GaPL6qMwnCB1mXolrZ8hF92LsXnpjbXiWC6GDbD9/BLYntlNn1ZEJZSirKOPT77uM1JZdVFeNJn5SBaMZRe9zraQ37CHfkcGyLLxMHq/r8MuQDydyUiXZTZ2EauPkO9KAhR11sJNhymY0YMcdoidX0buqlVBdguhJlf4kXtcDy9IGcCIiBQojJap31Sq2/J/L+g84DnYyidfZiWtZWMawsaGajfX+ZmqO62EsqOrNsKcsxuG6NCa/5/00nXEWG1c/z6ZNreSqT6fLTbGjOwrdHk1uBTVWDZZ94Aoeg8FYeWwTxnX8zd2ykb30xNuwcwnyiZZB96a8WUVdBaldKWzHZtbZ05ld/Q7sk5Ns2rUZZ7ehZrONac8SHlOGUx4hu70bd28arzf/9j4YKDtvDD1P7yz+bkUdyt/dhMm4JGeP1c0HRaQkKYwIxpjisEPP8uXYiQR2IsHeX/yCrff8lGQ6W2xr4Q/1pOJRXm2oob08Qch18Sz7iCbKDmRxyoXvY9Pucrrsevb0Zsn0OJxquonk6g5eKx6enSMdb6G3fIv/Lm4Y2wvjhgc/yfVg+pw+1lWtY/JpkzkpcRKNkUZyVo6y6jJmx6fT/chWrHiI6Ogk3X98AzdkCFfEsPBvIJjf1ffWH/JWLLDjIUKj4iSm1ZHfkybX1kvVB0+m6w9v0PtcK9UfO5X42bXYsUPPARIROR4ojMhhZbdswQqHCY8dS27HDrzeXnLbt5Nev4H2227DZPuDSnc0zHMnNdAbjRDJucRzOToTsUF9XjwUpi+fo6KqhlTnXirHNrO9djbRrR6x3lexwyfhhMf7+4xgMFYfDoVlvFYOsOgt20Yu0oHtRQhnK8lG9+A6aWwTwnX6MPbRDQUB9Dq92MYm5vnnlQ73sTW+jd5wLxWxCkaPH000F+Xc2NnM3nQGfXt6sPbmCOHQHe0jFkuQGFtJdl3HUddwAAvCY5PktncXDyWm1xM9uRKvJ0d6Yweh6ihlM8dgl4X9oaK8S3ZrF7mWHsqm1+N257DjIex4SLvfisiIUxiRtyXX2oadiGNFo6TXriX7+uv07d6Dtbsdd89eso1jeGHVM2RbWqjv6CaZybKzMklbZYK9ZYfeaO1wwnmP3H5fmI4XwrXzONFzce1KbMvg2NXYoUZylkXIuFiEsCwLY7K44Sx7Rz1PJFNNomc8mehubC+CG+ohnWg5zCcfHReXnnAPyVyStJOmNd5K2kmTCMVoS7Rjp6HKqWR2YioNHVVMbTuV1tMzVL/ikHCjWOD3uowEG7BtYqdW+cElGaFvzS5M3qPs3AbseAhjoOzcBnI7usm19BA9qRIrHvL3czFGK5BEZNAURmREeD095Fpa8Hp6SD38W5yaGtr+4z8In34a4fHjeWH9WvqyGUZ1dpNzbNLhEK2VZfRGw2CMP0dl388jFMp75PcLLbFsnnQkhGOV4RkXY0Ww7AS2MRCqxXKqgQhWeDzGMbhOCgM4mV6sSBPGS5NLZMnE28iH+3shQrkklhfGdXrxQpkhvGr9MnaWLWVbObPnVBzH5fnkOk7va+b0dDNj7Wo6nE7G9YwlGgnRF8vhuDZ1XZU4+OefibtE+4Z/PxW7PELslCpMzgXHxrIt3M4MJu8RGV9BaFSMUG2cXEsPfWvaKb9oHLEzR2HZFsYzuHvT5PekiZ5Shbs3Q6hmcD1rInJ8UhiRY4bJ58Fx6HnqKaxoFDsSIXbWWXStXEn2lfV4qRSv3fVfdE2cQKqulppEEm/507QnYuxOxghbNlkgb1sYyzqKOSxvzfEcXNvFCjWC14NlxTEmDVYc7DC50G7syGnkEyEsO0YoEycf7SWbyGKZsP/I58F2yMX8QGO5IbDM2xo+OhTLs+kO9WFbHp3hLhwvQtKLUm5ipMO9VLpJTuubQHu4E0JZkrkk2XiWVLibSdbJVDsRRu8YTYYcUcLFHhqDGdLeGitsY3LegU84lj90FLZxyiPY5RGi4yvoW7cbgMr3N5N9o5vela0kL2wkdnoN+dYevLSLUxXFKQv77xEL4XZkcGpimLyHHdFGdyLHEoUROe5lN28m3NiIFQ5jPA+3q4t8yKHllZdJrVvH9s0bCXf1kN65k3hPL7trKujO5ajt7mNzyCNX+Fc7nHfJhUbuS8pYNsa2sd082JW48Th4aazIeLyIg+dkCfWBGwuTKbfAsjC2he1aWJ4Dnot7dCNdR1ogGBssFywwxirM0zE4xiZCmKzlzxnyjE3Iskm6MRq8KnaHOuix09S6FZyZb6LL6SaHi2V7VOQqsbFw8RhtKugmTY1J+u8NuHiEcYjSv7mehx9UbIZmCMguCxMZlyTcUEaooQyTyZPZlMIuDDfZ5WFMxsOKFDbWcyziZ4wis7mT2Gk1YIFTEcHryWGFHX8VlPFDlduVxXIs3eRRZBCGNYzcfvvt3HLLLbS0tDBlyhS+973vMXPmzEO2v//++7n++uvZvHkzp556KjfffDOXXHLJEX+ewogMVi6TBssiHPHvZNy3eTNeRwfW+CbSr71G1/Y36Ep1ks5maJ5wMut++xBv5NM45eWk2loJ513SFmT6ejGeh+04JHIuHbYhlvewbYtwOkNfJEx2GIKOwV/hZADjhPxH2F8e7IUjWG4eN1mJG41j53NgQtiuwQs5YNkYG9xEIdF4HtjHznwP29hYxsYxYbJOnz9x2ESIFvausbCo8ZKUESNHnoyVI2JCWFjkrDyOcagxyWKQKTNR8nikrRxxE6HcxMhaedLkaPJq8fCIECJNDtfyiJsIHgYbCxvrkHvm7N9L5NSEcPfmIWQTrk/4/04kw4QSEayI42+eF7JxuzKYPhdscMojeL15nMoIOH6YiTaV41RFscvCmIzrhx3HIrMpRagqilMTw+vLY4dt3O4codq49q2R49qwhZH77ruPyy+/nCVLljBr1iwWL17M/fffz/r166mrO3DZ5p/+9CcuuugiFi1axJ//+Z9zzz33cPPNN7Nq1SomT548pCcjMtxMLocV7v8vY2MMuUya3s5O4hUVePk86x58gO6uTuqra9n5+kbaWrazY3cboxqb8FIpKpOV5Cz/f3bl4Rh5N8+unW+Qy6TxbAdsGyeToduxePMAR8T1yA5yIqkBP4x4HtgObiwBlg3Gw85l8UJhv3cmFMYUQovlebhl5WDAOA4YgxeN48US2H09WK6LF4liGc9/LpbwP8zzsPI5TCEEHvMMhHHIWS4h4xAjTJY8IRx6yRDGwcYmakIkiJLDBQxxEyVr5ei1slR6CapNWeE5CGGz2+72A5WJkrL8JeEVJoHBkLPy5PFImCgJE2Gv3UPcRAhhY2GRL/QgGQxpcsTxl3jbtkWIEL2hNFEssG3CVoRI3iYX6iUXz5JxbCLpKGFj4TppjIlCxCZeFiLmRQi7Bi/cTT6Xoa+qjJp4Fflej4SxiIZteiMOobBF0soTjcTJe6Owkg7hUA/5UAQqkmCHCdsWJhYhbEcxngHj+dO+QiHwsljZHkiO8m+9YFt4fXmc0XGssA05DytsY7lZTChaSNxgOQpdJ6JhCyOzZs3i3HPP5bbbbgPA8zyampr4u7/7O77yla8c0H7evHn09PTw0EMPFY+dd955TJ06lSVLlgzpyYicSLJ9veSzWexQCMcJkc/niCXKcNNpTMhh747t5LMZ+rpSeF3dWLZNxs3jhEKEsOhKdeJ0d5Pq62XTi88TTibJZdJY6TQ1o+pwMbh9fTiWjRON4KUzdO9qo6+vh17XJW1cHMvGdl0SmRzpcIjMIZYH257Bs63+Hh3bBizceBlOuscfunJC2Pksbjzp9zl4LsYJFX8ax8Fy8xi70BMUCmF5fhwztu1PdLYd3ESyf9Kz5/nBygIvOpxjW6XBMTau5WEZv4fqYL1GNv4/5zwuMcK4eMWepn3/55j9/oxd6F+yisN4WfJECWEXXmUbizwuFuBhcC2PmAkX6zAYvMJwX6g4pLdf/+EhvsX8r7d9PVz72vuv9SyDbexCD1jhGdP//NExxY/xv1n3vY+FZRXOpbB9gfWml+3PgsKkfv+NzH4N3m6FhzPhlNG878rPDOl7Hun396B2Vcpms6xcuZKFCxcWj9m2zZw5c1i+fPlBX7N8+XIWLFgw4NjcuXP55S9/ecjPyWQyZDL9qxdSqaO4/4jIcS4STxCJJ4q/h/FXoIQS/rG65pOP+L0uGKKa9m2kl+3rxQ6FyWcyRMvKsCyLfC5HurvLHyLDIhyJ0JvqZNeWTVTWN1DdMBbLsujeuwcn75Lq6sQ2hlAoRF9nJ5172glhkUv30bVjO5ZtE8rmcEaPJr1nN1Y4gtPby97ODjLZDGFswpEQVjhEvs8l6vTx+rYt2KEwZcbGc8J05Xqx3DxRJ4IVjpGxDY7rkctmcUwIy2TJheP+f9nbhpzlkctniRGmL1mOncviZHrBcjChMJbr4VoW+VgUO5vDti3ckI3nRLAKX2TG8jC2jbEdjHHBtvHCEexcFn+NtQE7hGXbWJaDcXN4GCj0fHhuFuyQ31sViWJh4VoWxgLH87BxcAs9a1j+l5JnWTjGDwquZbCNv4mhefN38FtwrUL4s/xhqiyH3524h0OsMjuCz+t+6yYywip2BDeFdFBhpL29Hdd1qa+vH3C8vr6eV1555aCvaWlpOWj7lpZD7/uwaNEivva1rw2mNBEZAft29N0XkkL7DVmFwmGS1TUD2idrRh0QmhKVVQCMGsY6g7L/rsf7fvdcF5PPE4r1L2c2nofX04PnGYxjk+7sxMplsUIhwtEoluuR9Vxy6T7C0RhuOEy6I0U8HvOHZ3I5evbuxfMgYkM664Ln4WYz5Pq6Ma6HYwHRGNlUNz25PPmsS2dvingsTti2cVzIhR3Clkc+kybVlcEJWXSlPTAu+UwflucPS6XDFmQdog6ARzbn4eGRzWUJGRcXB7w8njHkjYWLDV4OCwhbIbJeHttY2ITJmyxhQhgrhPHyeJaH8SBkWbjG9YMVzn7/5e/3C1iF4Zx9vW62sfAsg2Wsgde8+P8tbBz/hcYa0IliWf2H932Qf9zary/jcA72rBn4jGX1r0wzFCdyW9bhhln3FdZ/Hvt6lfb1EB2+FvOmZ6z9jpoBzxysff3UcYepbXgdk/tNL1y4cEBvSiqVoqmpKcCKRETe2pvv+mxZFk4o5M+l2P+4beOUlxcHQSLJ5AHv9ea7GVXWDfyPunhz89usVuTYMagwUltbi+M4tLa2Djje2tpKQ0PDQV/T0NAwqPYA0WiUaPQ4mQAnIiIib8ugpuVHIhGmT5/OsmXLisc8z2PZsmXMnj37oK+ZPXv2gPYAjz766CHbi4iISGkZ9DDNggULuOKKK5gxYwYzZ85k8eLF9PT0MH/+fAAuv/xyGhsbWbRoEQDXXHMNF198Md/5zne49NJLuffee3nuuef44Q9/OLRnIiIiIselQYeRefPmsWvXLm644QZaWlqYOnUqS5cuLU5S3bp1K/Z+Gyydf/753HPPPfzzP/8zX/3qVzn11FP55S9/ecR7jIiIiMiJTdvBi4iIyLA40u/vY2ePaBERESlJCiMiIiISKIURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigjsm79r7Zvn3ZUqlUwJWIiIjIkdr3vf1W+6seF2Gkq6sLgKampoArERERkcHq6uqisrLykM8fF9vBe57Hjh07KC8vx7KsIXvfVCpFU1MT27Zt0zbzw0zXemToOo8MXeeRoes8cobrWhtj6OrqYuzYsQPuW/dmx0XPiG3bjBs3btjev6KiQv+ijxBd65Gh6zwydJ1Hhq7zyBmOa324HpF9NIFVREREAqUwIiIiIoEq6TASjUa58cYbiUajQZdywtO1Hhm6ziND13lk6DqPnKCv9XExgVVEREROXCXdMyIiIiLBUxgRERGRQCmMiIiISKAURkRERCRQCiMiIiISqJIOI7fffjvNzc3EYjFmzZrFihUrgi7puLFo0SLOPfdcysvLqaur4yMf+Qjr168f0CadTnPVVVcxatQokskkH/vYx2htbR3QZuvWrVx66aUkEgnq6ur48pe/TD6fH8lTOa7cdNNNWJbFF7/4xeIxXeehs337dj71qU8xatQo4vE4Z599Ns8991zxeWMMN9xwA2PGjCEejzNnzhxeffXVAe+xZ88eLrvsMioqKqiqquJv/uZv6O7uHulTOWa5rsv111/PSSedRDweZ+LEiXzjG98YcCM1Xeej88c//pEPfvCDjB07Fsuy+OUvfzng+aG6ri+++CIXXnghsViMpqYm/u3f/u3tF29K1L333msikYi58847zUsvvWSuvPJKU1VVZVpbW4Mu7bgwd+5cc9ddd5m1a9ea1atXm0suucSMHz/edHd3F9t87nOfM01NTWbZsmXmueeeM+edd545//zzi8/n83kzefJkM2fOHPP888+bhx9+2NTW1pqFCxcGcUrHvBUrVpjm5mbzjne8w1xzzTXF47rOQ2PPnj1mwoQJ5jOf+Yx55plnzOuvv24eeeQRs3HjxmKbm266yVRWVppf/vKX5oUXXjAf+tCHzEknnWT6+vqKbd7//vebKVOmmKeffto8+eST5pRTTjGf/OQngzilY9I3v/lNM2rUKPPQQw+ZTZs2mfvvv98kk0nz7//+78U2us5H5+GHHzbXXXedeeCBBwxgfvGLXwx4fiiua2dnp6mvrzeXXXaZWbt2rfnZz35m4vG4+cEPfvC2ai/ZMDJz5kxz1VVXFX93XdeMHTvWLFq0KMCqjl9tbW0GMH/4wx+MMcZ0dHSYcDhs7r///mKbdevWGcAsX77cGOP/D8e2bdPS0lJs8/3vf99UVFSYTCYzsidwjOvq6jKnnnqqefTRR83FF19cDCO6zkPn2muvNRdccMEhn/c8zzQ0NJhbbrmleKyjo8NEo1Hzs5/9zBhjzMsvv2wA8+yzzxbb/Pa3vzWWZZnt27cPX/HHkUsvvdT89V//9YBjf/EXf2Euu+wyY4yu81B5cxgZquv6H//xH6a6unrA3x3XXnutOf30099WvSU5TJPNZlm5ciVz5swpHrNtmzlz5rB8+fIAKzt+dXZ2AlBTUwPAypUryeVyA67xpEmTGD9+fPEaL1++nLPPPpv6+vpim7lz55JKpXjppZdGsPpj31VXXcWll1464HqCrvNQ+tWvfsWMGTP4+Mc/Tl1dHdOmTeOOO+4oPr9p0yZaWloGXOvKykpmzZo14FpXVVUxY8aMYps5c+Zg2zbPPPPMyJ3MMez8889n2bJlbNiwAYAXXniBp556ig984AOArvNwGarrunz5ci666CIikUixzdy5c1m/fj179+496vqOi7v2DrX29nZc1x3wlzNAfX09r7zySkBVHb88z+OLX/wi73znO5k8eTIALS0tRCIRqqqqBrStr6+npaWl2OZg/wz2PSe+e++9l1WrVvHss88e8Jyu89B5/fXX+f73v8+CBQv46le/yrPPPsvf//3fE4lEuOKKK4rX6mDXcv9rXVdXN+D5UChETU2NrnXBV77yFVKpFJMmTcJxHFzX5Zvf/CaXXXYZgK7zMBmq69rS0sJJJ510wHvse666uvqo6ivJMCJD66qrrmLt2rU89dRTQZdywtm2bRvXXHMNjz76KLFYLOhyTmie5zFjxgy+9a1vATBt2jTWrl3LkiVLuOKKKwKu7sTx3//93/z0pz/lnnvu4ayzzmL16tV88YtfZOzYsbrOJawkh2lqa2txHOeAFQetra00NDQEVNXx6eqrr+ahhx7i8ccfZ9y4ccXjDQ0NZLNZOjo6BrTf/xo3NDQc9J/BvufEH4Zpa2vjnHPOIRQKEQqF+MMf/sB3v/tdQqEQ9fX1us5DZMyYMZx55pkDjp1xxhls3boV6L9Wh/t7o6Ghgba2tgHP5/N59uzZo2td8OUvf5mvfOUrfOITn+Dss8/m05/+NF/60pdYtGgRoOs8XIbqug7X3yclGUYikQjTp09n2bJlxWOe57Fs2TJmz54dYGXHD2MMV199Nb/4xS947LHHDui2mz59OuFweMA1Xr9+PVu3bi1e49mzZ7NmzZoB//I/+uijVFRUHPClUKre8573sGbNGlavXl18zJgxg8suu6z4Z13nofHOd77zgOXpGzZsYMKECQCcdNJJNDQ0DLjWqVSKZ555ZsC17ujoYOXKlcU2jz32GJ7nMWvWrBE4i2Nfb28vtj3wq8dxHDzPA3Sdh8tQXdfZs2fzxz/+kVwuV2zz6KOPcvrppx/1EA1Q2kt7o9Goufvuu83LL79s/vZv/9ZUVVUNWHEgh/b5z3/eVFZWmieeeMLs3Lmz+Ojt7S22+dznPmfGjx9vHnvsMfPcc8+Z2bNnm9mzZxef37fk9H3ve59ZvXq1Wbp0qRk9erSWnL6F/VfTGKPrPFRWrFhhQqGQ+eY3v2leffVV89Of/tQkEgnzk5/8pNjmpptuMlVVVebBBx80L774ovnwhz980KWR06ZNM88884x56qmnzKmnnlryS073d8UVV5jGxsbi0t4HHnjA1NbWmn/6p38qttF1PjpdXV3m+eefN88//7wBzK233mqef/55s2XLFmPM0FzXjo4OU19fbz796U+btWvXmnvvvdckEgkt7X07vve975nx48ebSCRiZs6caZ5++umgSzpuAAd93HXXXcU2fX195gtf+IKprq42iUTCfPSjHzU7d+4c8D6bN282H/jAB0w8Hje1tbXmH/7hH0wulxvhszm+vDmM6DoPnV//+tdm8uTJJhqNmkmTJpkf/vCHA573PM9cf/31pr6+3kSjUfOe97zHrF+/fkCb3bt3m09+8pMmmUyaiooKM3/+fNPV1TWSp3FMS6VS5pprrjHjx483sVjMnHzyyea6664bsFRU1/noPP744wf9e/mKK64wxgzddX3hhRfMBRdcYKLRqGlsbDQ33XTT267dMma/be9ERERERlhJzhkRERGRY4fCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAvX/A5kXP7uaZutWAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 11,
     "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": 12,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 12,
     "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": 13,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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EBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJJxRqHn77bfRo0cPaLVaZGRkYMeOHR2WX7p0Kfr27QutVovU1FSsWrXK4/Fly5ZhwoQJCAkJgUwmw969e72uZ+vWrRg7diz8/Pyg0+lw1VVXoamp6UxeAhEREUlMl0PNkiVLMHv2bMydOxd79uxBWloaJk6ciMrKSq/lt2zZgunTp2PmzJnIysrClClTMGXKFOTk5LjLmM1mjBo1Ci+//HK7z7t161Zce+21mDBhAnbs2IGdO3fikUcegVzOziYiIiICZIIgCF1ZICMjA8OGDcNbb70FAHC5XIiLi8Ojjz6KOXPmtCk/depUmM1mfP/99+55I0aMQHp6OhYuXOhRtqCgAImJicjKykJ6errHYyNGjMA111yDF154oSvVdTMajdDr9TAYDNDpdGe0DiIiIrqwunL87lI3h81mw+7duzF+/PjWFcjlGD9+PLZu3ep1ma1bt3qUB4CJEye2W96byspKbN++HeHh4Rg5ciQiIiIwevRo/Pbbb12pPhEREUlYl0JNdXU1nE4nIiIiPOZHRESgvLzc6zLl5eVdKu/N8ePHAQDz5s3D/fffj9WrV2Pw4MEYN24cjhw5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6e1fd5a-508d-4b7d-a4a5-e1ea000b9547",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.112 (avg p value 0.387262)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[0]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cf2dbb71-4997-456c-bbf1-501d83c4b872",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.190 (avg p value 0.239853)\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": null,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "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": 17,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.1041947233188132, high=0.11969235777623692)\n",
      "0.104\n",
      "0.12\n",
      "1\n",
      "ConfidenceInterval(low=0.18104153064312511, high=0.19948264274414304)\n",
      "0.181\n",
      "0.199\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(2):\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": 18,
   "id": "7793c07e-c75c-48ca-a173-a9831391a624",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[0.1041947233188132,\n",
       "  0.11969235777623692,\n",
       "  array([0.10334322, 0.10955334, 0.10675744, 0.11083284, 0.11553066,\n",
       "         0.11303436, 0.10903141, 0.10392621, 0.10891499, 0.10946561,\n",
       "         0.1107014 , 0.11206375, 0.10382214, 0.10657432, 0.10346739,\n",
       "         0.10275481, 0.11655487, 0.10903372, 0.11511055, 0.11856754,\n",
       "         0.11978253, 0.11157924, 0.10354176, 0.10570247, 0.11649802,\n",
       "         0.11448728, 0.11238379, 0.11181043, 0.11104163, 0.106987  ,\n",
       "         0.11268668, 0.11615548, 0.11529468, 0.10655389, 0.11731464,\n",
       "         0.11583548, 0.10314396, 0.10965714, 0.10594326, 0.09884155,\n",
       "         0.11732971, 0.10721759, 0.10547268, 0.10907115, 0.11890246,\n",
       "         0.11768301, 0.11026908, 0.11743027, 0.10332244, 0.10602402,\n",
       "         0.10842246, 0.1153611 , 0.10449971, 0.11151964, 0.10468593,\n",
       "         0.11249076, 0.1113211 , 0.10960628, 0.1090156 , 0.10878423,\n",
       "         0.10051302, 0.11589276, 0.10773061, 0.10911633]),\n",
       "  0.005036438713153508],\n",
       " [0.18104153064312511,\n",
       "  0.19948264274414304,\n",
       "  array([0.17564065, 0.18954753, 0.18665857, 0.18104137, 0.18968457,\n",
       "         0.18485081, 0.18020498, 0.17950716, 0.18470294, 0.18537749,\n",
       "         0.18642684, 0.18733922, 0.18273448, 0.18087381, 0.17874346,\n",
       "         0.17905245, 0.19629299, 0.18959562, 0.19175664, 0.19369285,\n",
       "         0.19515896, 0.19246684, 0.18878326, 0.18527946, 0.19022849,\n",
       "         0.18402486, 0.19189526, 0.18836752, 0.19258202, 0.17949666,\n",
       "         0.18370343, 0.1928799 , 0.19273071, 0.1900332 , 0.19083447,\n",
       "         0.18759291, 0.18823695, 0.18691359, 0.18697691, 0.1780585 ,\n",
       "         0.19330439, 0.18331777, 0.18164413, 0.1905451 , 0.19325988,\n",
       "         0.19996841, 0.18742802, 0.19208847, 0.18141445, 0.18318273,\n",
       "         0.18808638, 0.18989052, 0.1885935 , 0.19047535, 0.18136361,\n",
       "         0.18106147, 0.18471682, 0.1888276 , 0.18439305, 0.18391329,\n",
       "         0.18342716, 0.18857201, 0.18104529, 0.17990893]),\n",
       "  0.00511203585284314]]"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[[res.confidence_interval.low, res.confidence_interval.high, res.bootstrap_distribution, res.standard_error] for res in res_list]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9a7aacf8-41cf-4e6d-a038-17a1423ebd46",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"./val_res_list.pkl\", 'wb') as handle:\n",
    "    pickle.dump([[res.confidence_interval.low, res.confidence_interval.high, res.bootstrap_distribution, res.standard_error] for res in res_list],\n",
    "                handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9859c520-7da2-416e-a5c8-05bff6b939d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjQAAAHHCAYAAACoZcIpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAzL0lEQVR4nO3deXxMZ///8feIZARZbCGKJNbWUorq3S+KUrH1a727aWurbhRFW+4umpZGKVWq3F1sraIL2m91U0sXVQSlq62xlBBVklgSkVy/P/zMo9NEmokZMxev5+MxjzpnrnOdz5krybx7nXNmHMYYIwAAAIsV83cBAAAAF4pAAwAArEegAQAA1iPQAAAA6xFoAACA9Qg0AADAegQaAABgPQINAACwHoEGAABYj0AD4JI2Z84cORwO7d692+f76tu3r2JjY13Lu3fvlsPh0AsvvODzfUvS008/LYfDcVH2BQQaAg3gA+feRP/6iIqKUps2bfTJJ5/4fP+vvPKK5syZU6RtP/74Yz399NNercdbVq9e7faaOp1OVaxYUa1bt9Zzzz2nw4cPe2U/J0+e1NNPP63Vq1d7pT9vCuTaAH8i0AA+9Mwzz+jNN9/UvHnz9Oijj+rw4cPq1KmTPvroI5/u90IDTUJCgncL8rIhQ4bozTff1KuvvqpHHnlEZcuW1ZgxY3TVVVdp5cqVbm3vuusunTp1SjExMYXu/+TJk0pISPA4NLz22mvatm2bR9t4qqDannjiCZ06dcqn+wcCVXF/FwBcyjp27KimTZu6lgcMGKCKFStqwYIF6tKlix8r844zZ84oNzdXISEhF3W/LVu2VK9evdzWbdmyRe3bt1fPnj31888/Kzo6WpIUFBSkoKAgn9Zz4sQJlSpVSsHBwT7dzz8pXry4ihfnzzouT8zQABdRZGSkQkND87zpnDhxQiNGjFDVqlXldDpVp04dvfDCCzLGuLU7c+aMnn32WdWoUUNOp1OxsbH6z3/+o6ysLFeb2NhY/fTTT/ryyy9dp2Zat24tScrOzlZCQoJq1aqlEiVKqFy5cmrRooWWL18u6ew1INOnT5ckt1M7kvv1IFOmTHHV8PPPP+v06dN66qmn1KRJE0VERKhUqVJq2bKlVq1a5Vb/X/t48cUXFRMTo9DQULVq1Uo//vjjBb22DRs21JQpU3Ts2DG9/PLLrvX5XUOTlJSk+Ph4lS9fXqGhoYqLi1P//v1dNVaoUEGSlJCQ4HoNzp2G69u3r0qXLq1du3apU6dOCgsLU+/evV3P/fUamr/6p+Nt3bq1a5z+6q99/lNt+V1DU5ifGensz02XLl30zTffqFmzZipRooSqV6+uefPm5f+CAwGGKA/4UFpamv744w8ZY5Samqpp06bp+PHjuvPOO11tjDH63//9X61atUoDBgxQo0aN9Nlnn+mRRx7R/v379eKLL7ra3nPPPZo7d6569eqlESNGaN26dUpMTNQvv/yiJUuWSJKmTJmihx56SKVLl9bjjz8uSapYsaKks294iYmJuueee9SsWTOlp6crKSlJmzZt0k033aT77rtPBw4c0PLly/Xmm2/me0yzZ89WZmam7r33XjmdTpUtW1bp6el6/fXXdfvtt2vgwIHKyMjQG2+8ofj4eK1fv16NGjVy62PevHnKyMjQoEGDlJmZqZdeekk33nijfvjhB1etRdGrVy8NGDBAn3/+ucaNG5dvm9TUVLVv314VKlTQqFGjFBkZqd27d2vx4sWSpAoVKmjGjBl64IEH1L17d/Xo0UOSdPXVV7v6OHPmjOLj49WiRQu98MILKlmyZIF1eet4C1Pb3xXmZ+acnTt3ul7DPn36aNasWerbt6+aNGmievXqFbpOwC8MAK+bPXu2kZTn4XQ6zZw5c9zaLl261EgyY8eOdVvfq1cv43A4zM6dO40xxnz//fdGkrnnnnvc2o0cOdJIMitXrnStq1evnmnVqlWeuho2bGg6d+5cYO2DBg0y+f1pSE5ONpJMeHi4SU1NdXvuzJkzJisry23d0aNHTcWKFU3//v3z9BEaGmp+//131/p169YZSebhhx8usLZVq1YZSebdd989b5uGDRuaMmXKuJbPjUVycrIxxpglS5YYSWbDhg3n7ePw4cNGkhkzZkye5/r06WMkmVGjRuX7XExMjGvZk+Nt1apVvmP29z4Lqm3MmDFuY+fJz0xMTIyRZL766ivXutTUVON0Os2IESPy7AsINJxyAnxo+vTpWr58uZYvX6633npLbdq00T333OOaDZDOXoQbFBSkIUOGuG07YsQIGWNcd0V9/PHHkqThw4fnaSdJy5Yt+8d6IiMj9dNPP2nHjh1FPqaePXu6TnucExQU5LqOJjc3V3/++afOnDmjpk2batOmTXn66Natm6644grX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F4+n799FvsspKSlJDz74oKKjozV58mSNHDlSu3bt0vLly3XgwAF17dq1qF27fPjhh2ratKn+/e9/KyoqStdcc41ee+21C+4XAABcWop7usHkyZM1e/Zsbdu2TZ06ddK8efPUqVMnFSt2NhvFxcVpzpw5io2NveDifvvtN82YMUPDhw/Xf/7zH23YsEFDhgxRSEiI+vTpk+82WVlZysrKci2np6dfcB0AACCweRxoZsyYof79+6tv377nPaUUFRWlN95444KLy83NVdOmTfXcc89Jkq655hr9+OOPmjlz5nkDTWJiohISEi543wgsnHoAABTE40CzY8eOf2xT0AyKJ6Kjo1W3bl23dVdddZXef//9824zevRoDR8+3LWcnp6uqlWrXnAtAAAgcHkcaGbPnq3SpUvr3//+t9v6d999VydPnvRKkDmnefPm2rZtm9u67du3KyYm5rzbOJ1OOZ1Or9UAAAACn8cXBScmJqp8+fJ51kdFRblODXnLww8/rO+++07PPfecdu7cqbfffluvvvqqBg0a5NX9AAAAu3kcaPbu3au4uLg862NiYrR3716vFHXOtddeqyVLlmjBggWqX7++nn32WU2ZMkW9e/f26n4AAIDdPD7lFBUVpa1bt+a5i2nLli0qV66ct+py6dKli7p06eL1fgEAwKXD4xma22+/XUOGDNGqVauUk5OjnJwcrVy5UkOHDtVtt93mixoBAAAK5PEMzbPPPqvdu3erbdu2Kl787Oa5ubm6++67vX4NDQAAQGF4HGhCQkK0aNEiPfvss9qyZYvrCyMLuvMIAADAlzwONOfUrl1btWvX9mYtAAAAReJxoMnJydGcOXO0YsUKpaamKjc31+35lStXeq04AACAwvA40AwdOlRz5sxR586dVb9+fTkcDl/UBQAAUGgeB5qFCxfqnXfeUadOnXxRDwAAgMc8vm07JCRENWvW9EUtAAAAReJxoBkxYoReeuklGWN8UQ8AAIDHPD7l9M0332jVqlX65JNPVK9ePQUHB7s9v3jxYq8VBwAAUBgeB5rIyEh1797dF7UAAAAUiceBZvbs2b6oAwAAoMg8voZGks6cOaMvvvhC//3vf5WRkSFJOnDggI4fP+7V4gAAAArD4xmaPXv2qEOHDtq7d6+ysrJ00003KSwsTM8//7yysrI0c+ZMX9QJAABwXh7P0AwdOlRN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rxzXpchfYyVJHTp0cPvdWrBgwQUfz6XOF+P15ZdfatCgQfruu++0fPlyZWdnq3379jpx4oSrjVfetwx8plmzZmbQoEGu5ZycHFO5cmWTmJj4j9vGxMSYF1980eM+jx07ZoKDg827777ravPLL78YSWbt2rUXcDSXNn+MlTHGtGrVygwdOvSCar8c+WK8/kqSWbJkidu63NxcU6lSJTNx4kTXumPHjhmn02kWLFjgUf2XE3+MlTHG9OnTx3Tt2tXDauHr8TLGmNTUVCPJfPnll8YY771vMUPjI6dPn9bGjRvVrl0717pixYqpXbt2Wrt2rc/63Lhxo7Kzs93aXHnllapWrVqR93up89dYnTN//nyVL19e9evX1+jRo3Xy5MmiHchlwhfjVRjJyck6ePCg234jIiJ03XXX8bt1Hv4aq3NWr16tqKgo1alTRw888ICOHDni833a7GKNV1pamiSpbNmykrz3vmXFJwXb6I8//lBOTk6er2ioWLGifv31V5/1efDgQYWEhOT5Qs6KFSvq4MGDRdrvpc5fYyVJd9xxh2JiYlS5cmVt3bpVjz32mLZt26bFixcXab+XA1+MV2Gc+/3Jb7/8buXPX2MlnT3d1KNHD8XFxWnXrl36z3/+o44dO2rt2rUKCgry6b5tdTHGKzc3V8OGDVPz5s1Vv359Sd573yLQAH507733uv7doEEDRUdHq23bttq1a5dq1Kjhx8oAu912222ufzdo0EBXX321atSoodWrV6tt27Z+rOzyNmjQIP3444/65ptvvN43p5x8pHz58goKCspzlfahQ4fOe+GUN/qsVKmSTp8+rWPHjnltv5c6f41Vfq677jpJ0s6dO4u038uBL8arMM71fbH3azN/jVV+qlevrvLly/O7VQBfj9fgwYP10UcfadWqVapSpYprvbfetwg0PhISEqImTZpoxYoVrnW5ublasWKFrr/+ep/12aRJEwUHB7u12bZtm/bu3Vvk/V7q/DVW+fn+++8lSdHR0UXa7+XAF+NVGHFxcapUqZLbftPT07Vu3Tp+t87DX2OVn99//11Hjhzhd6sAvhovY4wGDx6sJUuWaOXKlYqLi3N73mvvW4W+fBgeW7hwoXE6nWbOnDnm559/Nvfee6+JjIw0Bw8eNMYYc9ddd5lRo0a52mdlZZnNmzebzZs3m+joaDNy5EizefNms2PH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cBlbt26dnnvuOSUlJWnv3r1avHixDh8+rKuuukrS2etjtm7dqm3btumPP/5Qdna2atWqpb1792rhwoXatWuXpk6dqiVLlrj1Gxsbq+TkZH3//ff6448/lJWVlWffkydP1oIFC/Trr79q+/btevfdd1WpUiXX6Z9zYeXgwYM6evRovvU//fTTmjRpkqZOnaodO3Zo06ZNmjZtWoHH3Lt3b23atEnjxo1Tr1695HQ6Xc/VqlVLy5cv17fffqtffvlF9913nw4dOlRgfzfeeKNefvllbd68WUlJSbr//vsVHBzstr/y5cura9eu+vrrr5WcnKzVq1dryJAh+v333wvsG4AHDIDL1s8//2zi4+NNhQoVjNPpNLVr1zbTpk1zPZ+ammpuuukmU7p0aSPJrFq1yhhjzCOPPGLKlStnSpcubW699Vbz4osvmoiICNd2mZmZpmfPniYyMtJIMrNnzzbGGCPJLFmyxBhjzKuvvmoaNWpkSpUqZcLDw03btm3Npk2bXH18+OGHpmbNmqZ48eImJibGGGPMmDFjTMOGDd2OYebMmaZOnTomODjYREdHm4ceeugfj7tZs2ZGklm5cqXb+iNHjpiuXbua0qVLm6ioKPPEE0+Yu+++23Tt2tXVplWrVmbo0KGu5f3795v27dubUqVKmVq1apmPP/7YREREuI7ZGGNSUlLM3XffbcqXL2+cTqepXr26GThwoElLS/vHWgEUjsOYv538BQAAsAynnAAAgPUINAAAwHoEGgAAYD0CDQAAsB6BBgAAWI9AAwAArEegAQAA1iPQAAAA6xFoAACA9Qg0AADAegQaAABgPQINAACw3v8D4gufLlCcOyUAAAAASUVORK5CYII=",
      "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
}
