{
 "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": [
       "12500"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/12500-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": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 12500)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_10_5000000.0_0.09693630065929029.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, 12500)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_5000_0.5_loss_100_5000000.0_0.2105536611350098.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/12500-0.5/lds-val/sd-lora-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": "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f9U//vhjHdA/+eSTiPzm+F5ra2v1zMxMffz48frq1av19957T7fZbPpLL710WH1vtcHISSedpN98883hz8FgUM/JydGnTJnSgr06fpWVlemA/v333+u6rus1NTW6yWTSP/zww3CZdevW6YC+YMECXddD/3BUVdVLSkrCZf7973/rdrtd93q9R/cBjnF1dXV6586d9ZkzZ+qjR48OByPyPTefu+++Wx85cmST+Zqm6VlZWfrTTz8dTqupqdEtFov+3nvv6bqu62vXrtUBffHixeEyX331la4oir5z584j1/njyLnnnqtfd911EWmXXHKJPn78eF3X5XtuLnsHI831vb744ot6cnJyxP877r77br1r166H1d9W+ZrG5/OxdOlSxowZE05TVZUxY8awYMGCFuzZ8au2thaAlJQUAJYuXYrf74/4jrt160ZeXl74O16wYAG9e/cmMzMzXGbs2LE4nU7WrFlzFHt/7Lv55ps599xzI75PkO+5OX3++ecMGjSI3/zmN2RkZNC/f39eeeWVcP7WrVspKSmJ+K4dDgdDhgyJ+K6TkpIYNGhQuMyYMWNQVZWff/756D3MMWz48OHMnj2bjRs3AvDLL7/w448/cvbZZwPyPR8pzfW9LliwgJNPPhmz2RwuM3bsWDZs2EB1dfUh9++4OCivuVVUVBAMBiP+5wyQmZnJ+vXrW6hXxy9N07jjjjsYMWIEvXr1AqCkpASz2UxSUlJE2czMTEpKSsJlYv0Z/JonQt5//32WLVvG4sWLo/Lke24+BQUF/Pvf/2bSpEnce++9LF68mNtuuw2z2cw111wT/q5ifZd7ftcZGRkR+UajkZSUFPmud7vnnntwOp1069YNg8FAMBjkscceY/z48QDyPR8hzfW9lpSU0L59+6g2fs1LTk4+pP61ymBENK+bb76Z1atX8+OPP7Z0V044RUVF3H777cycOROr1drS3TmhaZrGoEGDePzxxwHo378/q1evZurUqVxzzTUt3LsTxwcffMA777zDu//fzv2EpLJHcQA/72paEmZgOGUYBdHt36KMYqidELSKdkWItIkKoSKKIFpGrlrUrk0t6tKqiFoEola0yCi0jMDalBspKMTAIMNzF+/dec2r9x50rSn8fmBAZg7ym68yHhyPP35QdXU1BYNBGhoaoqKiIuScwTLyNo3RaCSVSvVi4uD6+poEQVBoVV+T0+mkzc1N8vl8VFxcLO0XBIEeHx8pFovJ6p9nLAjCq6/Br2Pw522Ym5sbqq+vJ7VaTWq1mnZ2dmh2dpbUajWZTCbknCaFhYVUVVUl21dZWUmRSISI/s7qv64bgiDQzc2N7PjT0xPd3d0h67+Mjo7S+Pg4dXZ2Um1tLdntdhoeHqbp6WkiQs7vJV25vtf1JCObEY1GQ1arlTwej7QvlUqRx+MhURQVXNnXwczkdDppbW2NvF7vi6/trFYrZWVlyTIOh8MUiUSkjEVRpFAoJHvzu91u0uv1Lz4UMpXNZqNQKETBYFDaGhoaqLu7W3qMnNOjubn5xXj6+fk5lZSUEBFRaWkpCYIgyzoej5Pf75dlHYvF6OjoSKrxer2USqWoqanpA87i80skEvTtm/yjR6VSUSqVIiLk/F7SlasoirS7u0vJZFKqcbvdVFFR8eZbNESU2aO9Wq2WFxcX+ezsjHt7e9lgMMgmDuDf9ff3c15eHm9vb3M0GpW2RCIh1fT19bHFYmGv18uHh4csiiKLoigd/zVy2traysFgkLe2trigoAAjp//j+TQNM3JOl4ODA1ar1Tw1NcUXFxe8vLzMOp2Ol5aWpBqXy8UGg4HX19f55OSE29vbXx2NrKurY7/fz3t7e1xeXp7xI6fPORwONpvN0mjv6uoqG41GHhsbk2qQ89vc399zIBDgQCDARMQzMzMcCAT46uqKmdOTaywWY5PJxHa7nU9PT3llZYV1Oh1Ge3/H3NwcWywW1mg03NjYyPv7+0ov6csgole3hYUFqebh4YEHBgY4Pz+fdTodd3R0cDQalT3P5eUlt7W1cU5ODhuNRh4ZGeFkMvnBZ/O1/LMZQc7ps7GxwTU1NazVavn79+88Pz8vO55KpXhycpJNJhNrtVq22WwcDodlNbe3t9zV1cW5ubms1+u5p6eH7+/vP/I0PrV4PM6Dg4NssVg4Ozuby8rKeGJiQjYqipzfxufzvXpddjgczJy+XI+Pj7mlpYW1Wi2bzWZ2uVy/vfY/mJ/97R0AAADAB8vI34wAAADA54FmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAU9RNbNcbOLkXbyQAAAABJRU5ErkJggg==",
      "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, 12500)"
      ]
     },
     "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/12500-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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acVggN0y/NaMzWREuceqm3OFpomr+uzL5WBgmSSf+Jdd6I2msHa+Hx+a58eyacWj3lq4EcXTWbxzthclTisayl1wWi//oBNCYO+5frz8biv++3AnjIoBn7ljJh5cUz/iffvJks5qeOt0N3ac7IZJUXJX2xaU5O7nljqt8LnkrYSbhRACrX0JHGjtzweYjoEEXFYTXLmrZFfuWR15shp6BsdhkeFp8BkAq8mISDKTf1i2L9eA98XSCCUymF/lwYcXV2J+pee6fxB0JJFkBjazcULPNFxKKJHByUAEC6s9ujnR6VlvNIXtx7vw22MBvNHUg3RWw5LaIvzRwgp5y7tk/A8107XHwDJJoqnsTXUiu1YyqpZ/aJaIaLLEc7cpJ/vBULp6xnv+5pn4EhhWro7JvBolIhoke/6muhR0NfCsQURERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREundZgeXpp59GXV0dbDYbGhsbsWfPnlHnPXr0KO69917U1dXBYDBgy5Ytw+aJRCLYsGEDpk+fDrvdjltvvRV79+69nKIRERHRDWjCgeXFF1/Exo0b8fjjj2P//v1YsmQJ1q1bh66urhHnj8fjmDFjBp544glUVFSMOM9f/dVf4dVXX8Xzzz+Pw4cP46677sLatWvR3t4+0eIRERHRDcgghBATWaCxsRErV67E1q1bAQCapqG2thYPP/wwNm3aNOaydXV12LBhAzZs2JB/LZFIwO124xe/+AXuueee/OvLly/H3XffjX/4h38YV7nC4TC8Xi9CoRA8Hs9EvhIRERFNkfGevyfUw5JOp7Fv3z6sXbt2aAWKgrVr12LXrl2XVdBsNgtVVWGz2Qpet9vteOutt0ZdLpVKIRwOFwxERER0Y5pQYOnp6YGqqvD7/QWv+/1+BAKByyqA2+3G6tWr8bWvfQ0dHR1QVRU//vGPsWvXLnR2do663ObNm+H1evNDbW3tZX0+ERER6Z8ufkvo+eefhxAC1dXVsFqteOqpp/CpT30KijJ68R555BGEQqH80Nraeg1LTERERNeSaSIzl5aWwmg0IhgMFrweDAZHfaB2PGbOnImdO3ciFoshHA6jsrIS9913H2bMmDHqMlarFVar9bI/k4iIiK4fE+phsVgsWL58ObZv355/TdM0bN++HatXr77iwjidTlRWVqK/vx+/+c1v8NGPfvSK10lERETXvwn1sADAxo0bsX79eqxYsQKrVq3Cli1bEIvF8MADDwAA7r//flRXV2Pz5s0A5IO6x44dy0+3t7fj4MGDcLlcaGhoAAD85je/gRACc+bMwenTp/HlL38Zc+fOza+TiIiIbm4TDiz33Xcfuru78dhjjyEQCGDp0qXYtm1b/kHclpaWgmdPOjo6sGzZsvzPTz75JJ588knccccd2LFjBwAgFArhkUceQVtbG3w+H+699158/etfh9lsvsKvR0RERDeCCf8dFr3i32EhIiK6/lyVv8NCRERENBUYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcuK7A8/fTTqKurg81mQ2NjI/bs2TPqvEePHsW9996Luro6GAwGbNmyZdg8qqri0UcfRX19Pex2O2bOnImvfe1rEEJcTvGIiIjoBjPhwPLiiy9i48aNePzxx7F//34sWbIE69atQ1dX14jzx+NxzJgxA0888QQqKipGnOeb3/wmnnnmGWzduhXHjx/HN7/5TXzrW9/Cd7/73YkWj4iIiG5ABjHBbozGxkasXLkSW7duBQBomoba2lo8/PDD2LRp05jL1tXVYcOGDdiwYUPB6x/+8Ifh9/vxgx/8IP/avffeC7vdjh//+MfjKlc4HIbX60UoFILH45nIVyIiIqIpMt7z94R6WNLpNPbt24e1a9cOrUBRsHbtWuzateuyC3vrrbdi+/btOHXqFADgvffew1tvvYW777571GVSqRTC4XDBQERERDcm00Rm7unpgaqq8Pv9Ba/7/X6cOHHisguxadMmhMNhzJ07F0ajEaqq4utf/zo+/elPj7rM5s2b8fd///eX/ZlERER0/dDFbwm99NJL+MlPfoKf/vSn2L9/P370ox/hySefxI9+9KNRl3nkkUcQCoXyQ2tr6zUsMREREV1LE+phKS0thdFoRDAYLHg9GAyO+kDteHz5y1/Gpk2b8MlPfhIAsGjRIpw/fx6bN2/G+vXrR1zGarXCarVe9mcSERHR9WNCPSwWiwXLly/H9u3b869pmobt27dj9erVl12IeDwORSksitFohKZpl71OIiIiunFMqIcFADZu3Ij169djxYoVWLVqFbZs2YJYLIYHHngAAHD//fejuroamzdvBiAf1D127Fh+ur29HQcPHoTL5UJDQwMA4CMf+Qi+/vWvY9q0aViwYAEOHDiA73znO3jwwQcn63sSERHRdWzCv9YMAFu3bsW3v/1tBAIBLF26FE899RQaGxsBAO9///tRV1eH5557DgBw7tw51NfXD1vHHXfcgR07dgAAIpEIHn30Ubzyyivo6upCVVUVPvWpT+Gxxx6DxWIZV5n4a81ERETXn/Gevy8rsOgRAwsREdH156r8HRYiIiKiqcDAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6d1mB5emnn0ZdXR1sNhsaGxuxZ8+eUec9evQo7r33XtTV1cFgMGDLli3D5hl87+LhoYceupziERER0Q1mwoHlxRdfxMaNG/H4449j//79WLJkCdatW4eurq4R54/H45gxYwaeeOIJVFRUjDjP3r170dnZmR9effVVAMDHP/7xiRaPiIiIbkAGIYSYyAKNjY1YuXIltm7dCgDQNA21tbV4+OGHsWnTpjGXraurw4YNG7Bhw4Yx59uwYQN+9atfoampCQaDYVzlCofD8Hq9CIVC8Hg841qGiIiIptZ4z98T6mFJp9PYt28f1q5dO7QCRcHatWuxa9euyy/tRZ/x4x//GA8++OC4wwoRERHd2EwTmbmnpweqqsLv9xe87vf7ceLEiUkp0M9//nMMDAzgL/7iL8acL5VKIZVK5X8Oh8OT8vlERESkP7r7LaEf/OAHuPvuu1FVVTXmfJs3b4bX680PtbW116iEREREdK1NKLCUlpbCaDQiGAwWvB4MBkd9oHYizp8/j9/97nf4q7/6q0vO+8gjjyAUCuWH1tbWK/58IiIi0qcJBRaLxYLly5dj+/bt+dc0TcP27duxevXqKy7MD3/4Q5SXl+Oee+655LxWqxUej6dgICIiohvThJ5hAYCNGzdi/fr1WLFiBVatWoUtW7YgFovhgQceAADcf//9qK6uxubNmwHIh2iPHTuWn25vb8fBgwfhcrnQ0NCQX6+mafjhD3+I9evXw2SacLGIiIjoBjbhZHDfffehu7sbjz32GAKBAJYuXYpt27blH8RtaWmBogx13HR0dGDZsmX5n5988kk8+eSTuOOOO7Bjx47867/73e/Q0tKCBx988Aq+DhEREd2IJvx3WPSKf4eFiIjo+nNV/g4LERER0VRgYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdY2AhIiIi3WNgISIiIt1jYCEiIiLdM011AYiILpTt6cHAf74Cta8P1tmzYZs7B5aZM6FYrVNdtOue0DQAgEHhterNSggBg8Ew1cW4LAwslyCy2YteEIU/KwoMRuO41qVGIkidOoXkyZPInD8Pc3UN7EuXwDp3LhSLZZJKfG0JVZV1MMUHgBoKIfrGm0gePQrrnDlw3norzP7ycS2rJZNIHj8OxeGEdeYMGEzjPyxEJoNsXz9EIg4tmYSWSEAkEnI6ngAAWGqqYZ4+HcaionHVk9A0aLEYFJdryuv1WkoeO4a+f38e4f/+b4hMpvBNoxGW+jrYZs+Bdc4c2ObOgW3+fJjKyibt84WqIhsMIt3WhkxbOzJtbUi3tcrpjg4YPR5YGxpgnT1LjhsaYK6tHffxf60IIaD29yN97hzSzeeQPteM9LlzSDU3I3O+BSKTgeJwQHE6hwaXC4rTCVNpKayzZsE6ZzZss2fDWFQ06ueoAwNInW1GurkZmY4OiHQaIpMZPqhZKHYHjG4XFKcLitstp13yZwAQahbIZiGyWYiMHEPNwjpvHuwLFlyjmrv2RCYDLR6Xx/ok7UdaLIZ0WzsynR3IdnYi09GJTCAgf+7oRKarCyafD9a5c2CbMwfWOXPlRUFd3YTavqlgEOLiM/ClPf300/j2t7+NQCCAJUuW4Lvf/S5WrVo14rxHjx7FY489hn379uH8+fP4p3/6J2zYsGHYfO3t7fjKV76CX//614jH42hoaMAPf/hDrFixYlxlCofD8Hq9CIVC8Hg8E/1Ko2q6/X3IdnePPoPBAKPPB1NZGUzlZblxOUxlZTA6nUg1NyN18hRSJ08i09Ex8irMZljnz4N9yRLYFy+BfcliKA4HtHhcDrEYtFhuHI/D6CuGfdEimEpKJu17jkVks8i0tyN9/rxsBM+dl9PnzyPT0QGDzQZzeTlMfj9M/nKY/RX5aaPHC4PFDMVqhWFwMFugWC2AwSAbuXQaWjoNkc7kGz2DUZHrKC0d9SBKnW1G9PXXEd2xA/H9+wFVLXjfOqsBzltvhXPNGjhWrIDicAAAMsEgEgcOIHHgAOIHDiJ57BiQC6YGq1WeEOfNg23+fNjmz4d19iwYDAakz59H6swZpE6fQer0aaTPnEbq3Hng4pPrKBSXC+ZptbBMmw5LbS1Mfj/UgQFku7sLh54eIJuF4nbLE8ecuUONy6xZUOz2/Dq1dBpqTw+yvX3I9vZA7e2DqawUjpUrC+Ybc/tqGpJHjyHT2QFLbS0s06fn6+pSy2W7e5ANBgCjEYrNBsVmg+GC8aUaYaGqiGzfjv5/fx7xd9/Nv25bshj2RYuRampC6sQJqKHQiMubysthW7BAbqsFC2BbsGBcQVWLx5E8eRLJ48eROn4cyWPHkWpqgkinL7nshQxWKywzZ8BcVQWjy33BydgNxe2C0eWS9aAogMEgB+TGBkCxWGAsLYWprAyK0znhgCqEQLajA4kjR5E8ehTJI0eQPHYM6sDAhNYzGlN5Oaxz5sA6exZMxcXyGMiFFLWvb1I+41IcK1fC95cPwvW+942rZ0hLJpFpbYUaiUANh6FdOI5EINIZmEpKhtrswfa6qCi/fiGEDBOxWL79FckEFLcbJp8Pitd7WRcTQlWRPHYM8d27EXtnN+L790PE4wAgQ6THI/cft0fuP24PFJcTRre7YJ9SXG4YzGZkOjty4bpVhpTWVqj9/RMuFwAYLBZYGxpgLCqSwTE/ZIBMJh8k615+Cabi4sv6jNGM9/w94cDy4osv4v7778ezzz6LxsZGbNmyBS+//DJOnjyJ8vLhDcXevXvx0ksvYfny5fjiF7+Ir3zlK8MCS39/P5YtW4YPfOAD+OxnP4uysjI0NTVh5syZmDlz5qR+4Ym6ZGCZIFNlJWyzZ8NSNx3pc+eROHTosncwc1UVbIsXw75oEeyLF8E2fz4Up3NC6xBCQAuHke3qQmYwjXd2ygOhI5fIg8FhYeCaMRphKiuD2e+HqaIC5go/hBCI7XwD6fPnC2a1zpoF+y23IHn8OJKHDxf0hhnMZtgWLkQmGEC2o3P4x5SVQsQT0GKx4WUYDEwX97YNUhQodjsMDjsUm11O221Q7A4gm0W6rQ3ZQOCyq+Diz7JMmwYIgWxfH7RIZMTZDBYLHKtWwfW+2+G8/XZ59XRBA5vt7kb07bcRe+ttxN5+e9g+aKqogKW+Dpa6Oljr62EqK0MmEBzqdWhtQ6a9HSKVGrO4BrMZissFo8eTa4zd+bHBbkP0d9uHgrzJBM+6dfDd/79gX7Ikvw4hBLJdXUidPInkyZNInTiJ5IkTSJ89O7zHE4DR65VXrLltoNhs+W0DAKmmJqSbm0dcFiYTzFVVsNTUwJwbLDXVMFdVITswgPTp00g1NSHZ1IT0mbOX/P4TYbDZ5Em0tBSm0lIYS3wwmMyAYoBBMcqeTMUAKEaIbFb21h49Omr7YaqqhLWuDpa6eljq6vLbU7HbLzgRx6BeMJ3p6EDqVJO8wGpvv2SZTZWVsNbXw1xbK/d7s1kOFjMMJhMMZjOgGKElEjIwRCPQorGCaRgMcl6TSQZcs0l+bzWL2J69+ePO0jATJQ88AM9HPlLQIy2EQLq5GbE330T0zbcQ37v38raL2QxjkRciLYPKqMc7AJhMMPl8MJaU5MY+GS4Ge64cDihOBxSHAwa7Helz5xDfvQfxvXuhRaMTL9sEGb1emKqrYK6sgrmyUg5VlbINLS9HJtiF1Cl5HKVOnETq1CloueB0KQ07d46793q8rlpgaWxsxMqVK7F161YAgKZpqK2txcMPP4xNmzaNuWxdXR02bNgwLLBs2rQJb7/9Nt58882JFKXA1Qosaig01LBdmKhz0yKVQranR14Zd3Xlr5IzXV3QwhFYpk+XV+xzZsM6ezaMXm/B+oUQyLS2IvHeISQOHULivfeQPH4cyGRgcMgdvuAgsNuR6ewcubFWFHmlV3BycMPo8cLocQOKUZZ1sJy58XgOboPVCsu0abLhq5sOy3Q5mKdNg0gkkAl2IdsVRCYQQDbYhWwwiEwwCC0Wg0il5DDYk5JKAbl76YA8uV48iHRaBsWxgpLZDOeqVXC9//1wfeADsNRUD223gQHE3nkHsbd/j9jbbxf2bikKrHPnwLHsFtiXLYNj2VKYqqoAIZBpaZGB59gxJI8eK7haVZxOWBpmytsBMxtgndUA68yZMFVWXvJqS0sm5cm+pRXplvPItLQi290FY1FxYe9cbjB6vUi3tiJ14gSSJ0/lxieh9vaOWA+mwYbT50Pq7JlhocxcWwvX7bdDcToQfettpI4fL3hfcTphqa9Hpq1tYlfnigJTeTkgBLRkEiKZnPDJwlhUhKJP3ofiT30KZr9/3MtpsRiSJ07I7XT0KJLHjiJ15mzBvjXm55aVyp60efNz47kw19SMu2teqCoyra1InT6NbHc31GgUWiQKLRqBGolCi0ahRSLQkkl5rAoBAQEIyDIKkW8/RgzK42UyybC+cAFsCxbCtmABrA0zx93DNho1GpXh5dQppE6dghoKyeN+xgxYZ8gQNJ6euCuR6exE378/j4GXXsrXkbGsFL4//1+w1Nch9tbbiL715rD9XXG7YSwuHmoD3Z782GAyIdvbW9AGjtVbZLDZZNtrs8ltHA5f0XdS3G44Vq6E8w8a4WhshKW+XgbGSARqOAItEoYaieR7hAr2qUgEWiwKNRKFSKVgqqyApboG5tpamGuqYamthbmmBkaXa0JlEpqGTFsbkidPQiQSslfbJIOjDKGmfKi0zZ8PwyQ/wnBVAks6nYbD4cDPfvYzfOxjH8u/vn79egwMDOAXv/jFmMuPFljmz5+PdevWoa2tDTt37kR1dTU+97nP4a//+q9HXVcqlULqgoYxHA6jtrZ20gPLVBDZbO5qavTuTzUSQfLoUSQOH0by0GEkDh++oqt4xesdSuKDabyyEuYqmdBN5eWT9qCeEEJevQgBmM2jnuyFqiLb04tsMCCDUCCITDAAkUjC0dgI55o1MLou3aMkhEDm/HnEDxyEubIC9kWLxt0TJYRANhgEhICpomLKnynJdncjdfo0DCYTjCWlMJX4oHg8BeUSQiB95gyib7yJ6JtvIP7uvhFvW9kWLIDzttvgum0N7EuXyqthANmC5x/kkO3uhqnCD0uNbBAttblGsqIiv1z+8zUNIpWSASaRyJ3IL+iWD4WhRsLQIlFYGxrgueePoNhsk1I/WiKBdGurfI4oN4jc80RaMgFks7DU18M2b96kPv9ypbR4fOgk2t2DbE831L5++WyHJgBNhdAEoKoQQgYya329DCdz5tzwDySrkQgGXnoJff/+vDweL2Iwm2UIuO02uG6/DZaGhgkdqyKdRra3F2p/vwwogxeIDsewAKul01D7+uT8g+PeXqjRKET+Nv4Ft/PjcRhLS+BcJQOKbd5c3T33NNWuSmDp6OhAdXU1fv/732P16tX51//u7/4OO3fuxO7du8dcfrTAYss1Vhs3bsTHP/5x7N27F1/4whfw7LPPYv369SOu66tf/Sr+/u//ftjrN0JguVyZri5k2tplQg9H5EkhPw5DZLJDV/Hl5UP3b0tLJ+2EQfqjxWKI7d6N6JtvQqTScK5eDeeaW2Hy+aa6aEQTItJphP7nf9D/k59Ci8fhXL0arttvk89sXeXeHrp6xhtYdPFIsKZpWLFiBb7xjW8AAJYtW4YjR46MGVgeeeQRbNy4Mf/zYA/LzcxcXg7zCM8R0c1NcTrhvvNOuO+8c6qLQnRFDBYLij72MRRd0MNPN48J9fGXlpbCaDQieFGXXDAYREVFxWUXorKyEvPnzy94bd68eWhpaRl1GavVCo/HUzAQERHRjWlCgcVisWD58uXYvn17/jVN07B9+/aCW0QTtWbNGpw8ebLgtVOnTmH69OmXvU4iIiK6cUz4ltDGjRuxfv16rFixAqtWrcKWLVsQi8XwwAMPAADuv/9+VFdXY/PmzQDkg7rHjh3LT7e3t+PgwYNwuVxoaGgAAHzxi1/Erbfeim984xv4xCc+gT179uB73/sevve9703W9yQiIqLr2GX94bitW7fm/3Dc0qVL8dRTT6GxsREA8P73vx91dXV47rnnAADnzp1DfX39sHXccccd2LFjR/7nX/3qV3jkkUfQ1NSE+vp6bNy4cczfErrY1fq1ZiIiIrp6rtrfYdErBhYiIqLrz3jP3/wfsIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3TFNdgBuapgKKcapLcf1Rs0A2CVhdU12SyyMEEO8DogEgHQNc5YC7EjBZp7pk1wdNBQZaAIMCFE0DDIapLtH1I3AEOPqKrLdFfwZYnFNdIppsagaIBoFUFCiZCRjNU12ia4aB5VJa3gEUM2AvAuzFgM07PISoWaDvDBA8AgSPykYjeBQItwHeaYB/PlA+H/AvkENJw021k41LJgmcfR04/kvg5P8AiX6gdDZQ2zg0lM66vJOXEMDAebld4j1AMgwkQ0AqN06G5GsQgGKSg9Est7vRJMeKSW53gyLHigkwGOV0NglEgjKgRIKyMdEyw8th98ng4q4APJVy2lMNeGsBb40cRgppmgrEuoFwBxDpBCIBQMsOlcVgvKB8RhmMLM7CwXzBtF4CQDYF9J4Guk8CPaeGxr2nZZ0C8pirXApULR0aF02fuu+QGABCrTJQDeTGoRa5j5TOlvtoSYMcLtyWQsjtFjgEdB4CAu8BgcNArEcuV7EQ8C8CKhbJNsLmGX+Z1Kw8Znb/C3D+raHXf/sosOzTwIq/BEobRl9eCNleNe+Ux0JxHVBcD/hmyLB9uXWdTQFnXgOa3wQcxXKdRdPl+p2lI69X04DkgKyXeI+sV2cJ4CgFrO6Rl0nHgL5moO/s0CBUYPptwIz3y2NtKsT7gPZ9QPt+wGwHZn4AKF8AKOO4sZHoB869DXS+N3TMRwKyjYn1ABByPrMDqFkJTFsNTF8NVK+4fi/0xsEghBBTXYjJEA6H4fV6EQqF4PFM4GC/lO8skMHjQlZvLsAUyYO959RQAzseg42bswSwuOUOZnHlxm55UhEqkI4DmdyQn04ADh9QuUQO/oWj76BqBug+kWsgD8nGVcvKE6CWBYQ2NG0wyDBm98n1232ykbH75EnD4gLMNsBklwff4GCyyXWoKdlAqenCsdEsGxpL7jteeLCmIkDTb2VIaXoVSEfHrjd7MVCzCqi+BXD5AUdJ4WAvlifx/mag44A82DsPynEyNP7tM1nsPvmdo0FZP+NhK5LBxV0hT46DjZVQJ6dMJjvgy52MSmYCvplDY3eF3G6ZhNx22YQMktmk3EdMVtlADm53s0O+NpETWjYNnNkOHP6ZPMlm4iPPZ7Tm9s+Rgl+xLC+E3PeEKo/DwWnFLHsYfDNy37U+d7KcdukLBU0Dwu3ypNc/eBJslsNAC5CawH7kqc6FbKM8/mLd41+2aLoML6WzgbI5cj2ls+WxNCjeB+z/d2Dvv8oQBcjPmr0O6DoG9J8bmnfmncDKv5bvKUYg3Amc3SEvEs68DsS6Ri6H2SkDhq9ehrDKJTI0FtePvN3VrAw+R/5THtej1ZfZIdfrrZX7V7xX1k+sZ/R93WiRwWUwwGRTcvtEA2NWJcrmyuAy4/1A3W2yDjVV1k/3SaDnJNB9So77z8v6MVrkYLLKfcZoldPOUsBVAbj98oLDNTgul/tL2z6gbS/Q/q4s28Wc5TK4zLwTmPEBuR5Atu8tu2TdNb8h2yyhjf6dFJM8Bi9uMw1GuY1qG2VQs7oBqyc3uHODS7aTmio/Y/A8IFQ5trpkOa9h8Bnv+ZuB5VJ+cJe8sk30j31CNTtlT4p/gQwR/oWygexvBoLHgK6jufFxIB2ZvPLBIBuzwQBjsg1dxXUdkycgPbG4hgLMQEvhidxdBcz7iBxKZwMd+4HW3UDrHnmlMp5QaLSOHA6MFtlweapkMLN55UFs88qrWatHNlRqJhfqskPTg+PBA/rCg1vLynW7/bmGrEI2Yi4/YLLIzxZC7j+RQC6A5IZwpzw5htrkCWesUGVQhhpHd6Vc92CDkw+guTJlU/KqMxOT48EBV+NQN8htWTYbqFic2w8XyytJs03OoqnA+beBwy8Dx/5LXkEPsnrlsqVzCsdF0+V36joGdBzMBdCD8hgaKcSMq6hGGSJGCy1Clcf6pY4ZRylQVCuP76Jpshc1mwR6m4Ce3BDvGeHzlVxvymJZRxWL5TbtPi57WwJHZC9tuH30z3ZXyfqxFwMnt8lQCchwvOIB2ZvirZbB68x2YM/35UXB4Lb3TpMXRN3HC9drsgN1a2T99J+TAS3cNvpJ0+bNbeulMsDYi2VAOfYLGT7y5a0EZv+h3CcHzstAEG7HJfdFm1fWs5qRdTlasB1kL84F1NyQTcmTf8fBws9STDIoDbSO/yLiSpQ0ANXL5bHd/KY8Ji/kXyjbnra9w/fr0tnAtD+Q22wwILkr5Njuk/N0n5BBp2UXcH7X8IvrK2F2yiDm8l8w9gMr/1Je1E4iBparQc3Iq97kgDwBJQZko1o2R15xjKerTwh5ou45JZdPR+S9yHQ0N879rJgAi0PuNGb7BdM2eaLrfC/XXdgx9udZvfJKrXKxDDZGy9CtjPztBKMsV3JAXrUl+nLj/qHxYO9ONimntewoH2jIXZVY5UlVzcielNGumnwzgHl/LIeqZaPXYTYNBA/L8BI8IssV7x0aEgPIN0wmm2wIBq8GK5cAZfOGAoReJcO5ANMuA43NKwOWp0pe8Riv4A6uEHK7RYNA7xk59F0wHmi56ORkyPWi5HrVFJNs4DOJS2z/wcWNQPk82WC3vFN4FezyAwv+VD5jUb18gj00qdzt1o6hW3QGo9xvBqezKXmhMHjiHewtGW8vqGIGiqcP3RYZ7KEprpNBZTzPhcT75K2tnlPyGKhYJG8LWxzjW3bw9nLPKRmAuk+O3AviXwQ0/m9Zl2b7yOvrawbe/TfgwPPyWAYAGOSxMeMD8oq/tnH4M1bZtNwvBnuauk/IABA8Mnaoc5QA8z8GLLxX3qq4+JjOpmRI7z8ng7rZIXsuHKWAs0wuf/Gxmo7L4BLryfXG9MjgObhtRjuBxvuAc2/KXqSzO+R3GWSyASWzZPtdNkcGBN8MuT9m0/I7qim5/bIpuf/EeoZ6PaOBoVs1yQEZmqpXADUr5Lj6lsJyZdNA2x55m+zMa8PDlKcGmHEHUH8HUH+7PO4naqBVhpf2/bJMqYi89Z2KFA5CG2r787eWc8dQKjJ2QPzSSRmcJhEDy80i2iV7UzoPyiGbHgooFYtlI3s17ver2dwtg0TumY9c96liGv55QsiDPRWVB086Kg8KR6lsKCajfJo6FAA9NVd2cr8ZZdOygTNZZUNutIy9XdRMLrwk5NVj8IgM0IFDcnzhVTYgw9f8jwIL/0x2y1/rh9E1TZ5gQu1j3F4zyIbYW6PPh+UT/bkenFPye9StAaavGf/xk0kAp7YBMAD177v8q2Q1I3uKOw8O9X5FgzL8LPxTecLV6/HXf06Gr8FbhJO1nbOpSx8zF4v1As07ZO/n9DVDYUkPUlG5TaNdF40DwIf/edK3LwMLEU0NIWQPSOd78rmA0jlAwwf5W1JENKLxnr91GoOJ6LplMMjnKLzVAP5oqktDRDcI/uE4IiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0r0b5n9rFkIAkP9NNREREV0fBs/bg+fx0dwwgSUSiQAAamtrp7gkRERENFGRSARer3fU9w3iUpHmOqFpGjo6OuB2u2EwGCZtveFwGLW1tWhtbYXH45m09d4oWD+jY92MjfUzOtbN2Fg/Y7ve6kcIgUgkgqqqKijK6E+q3DA9LIqioKam5qqt3+PxXBcbfqqwfkbHuhkb62d0rJuxsX7Gdj3Vz1g9K4P40C0RERHpHgMLERER6R4DyyVYrVY8/vjjsFqtU10UXWL9jI51MzbWz+hYN2Nj/YztRq2fG+ahWyIiIrpxsYeFiIiIdI+BhYiIiHSPgYWIiIh0j4GFiIiIdI+B5RKefvpp1NXVwWazobGxEXv27JnqIl1zb7zxBj7ykY+gqqoKBoMBP//5zwveF0LgscceQ2VlJex2O9auXYumpqapKewU2Lx5M1auXAm3243y8nJ87GMfw8mTJwvmSSaTeOihh1BSUgKXy4V7770XwWBwikp87TzzzDNYvHhx/g9YrV69Gr/+9a/z79+s9TKSJ554AgaDARs2bMi/djPXz1e/+lUYDIaCYe7cufn3b+a6GdTe3o4///M/R0lJCex2OxYtWoR33303//6N1jYzsIzhxRdfxMaNG/H4449j//79WLJkCdatW4eurq6pLto1FYvFsGTJEjz99NMjvv+tb30LTz31FJ599lns3r0bTqcT69atQzKZvMYlnRo7d+7EQw89hHfeeQevvvoqMpkM7rrrLsRisfw8X/ziF/HLX/4SL7/8Mnbu3ImOjg786Z/+6RSW+tqoqanBE088gX379uHdd9/FnXfeiY9+9KM4evQogJu3Xi62d+9e/Mu//AsWL15c8PrNXj8LFixAZ2dnfnjrrbfy793sddPf3481a9bAbDbj17/+NY4dO4Z//Md/RHFxcX6eG65tFjSqVatWiYceeij/s6qqoqqqSmzevHkKSzW1AIhXXnkl/7OmaaKiokJ8+9vfzr82MDAgrFar+I//+I8pKOHU6+rqEgDEzp07hRCyPsxms3j55Zfz8xw/flwAELt27ZqqYk6Z4uJi8a//+q+sl5xIJCJmzZolXn31VXHHHXeIL3zhC0II7jePP/64WLJkyYjv3ex1I4QQX/nKV8Rtt9026vs3YtvMHpZRpNNp7Nu3D2vXrs2/pigK1q5di127dk1hyfSlubkZgUCgoJ68Xi8aGxtv2noKhUIAAJ/PBwDYt28fMplMQR3NnTsX06ZNu6nqSFVVvPDCC4jFYli9ejXrJeehhx7CPffcU1APAPcbAGhqakJVVRVmzJiBT3/602hpaQHAugGA//qv/8KKFSvw8Y9/HOXl5Vi2bBm+//3v59+/EdtmBpZR9PT0QFVV+P3+gtf9fj8CgcAUlUp/BuuC9SRpmoYNGzZgzZo1WLhwIQBZRxaLBUVFRQXz3ix1dPjwYbhcLlitVnzmM5/BK6+8gvnz59/09QIAL7zwAvbv34/NmzcPe+9mr5/GxkY899xz2LZtG5555hk0Nzfj9ttvRyQSuenrBgDOnj2LZ555BrNmzcJvfvMbfPazn8Xf/u3f4kc/+hGAG7NtvmH+t2YiPXjooYdw5MiRgnvtN7s5c+bg4MGDCIVC+NnPfob169dj586dU12sKdfa2oovfOELePXVV2Gz2aa6OLpz991356cXL16MxsZGTJ8+HS+99BLsdvsUlkwfNE3DihUr8I1vfAMAsGzZMhw5cgTPPvss1q9fP8WluzrYwzKK0tJSGI3GYU+dB4NBVFRUTFGp9GewLlhPwOc//3n86le/wuuvv46ampr86xUVFUin0xgYGCiY/2apI4vFgoaGBixfvhybN2/GkiVL8M///M83fb3s27cPXV1duOWWW2AymWAymbBz50489dRTMJlM8Pv9N3X9XKyoqAizZ8/G6dOnb/p9BwAqKysxf/78gtfmzZuXv212I7bNDCyjsFgsWL58ObZv355/TdM0bN++HatXr57CkulLfX09KioqCuopHA5j9+7dN009CSHw+c9/Hq+88gpee+011NfXF7y/fPlymM3mgjo6efIkWlpabpo6upCmaUilUjd9vXzwgx/E4cOHcfDgwfywYsUKfPrTn85P38z1c7FoNIozZ86gsrLypt93AGDNmjXD/nzCqVOnMH36dAA3aNs81U/96tkLL7wgrFareO6558SxY8fE3/zN34iioiIRCASmumjXVCQSEQcOHBAHDhwQAMR3vvMdceDAAXH+/HkhhBBPPPGEKCoqEr/4xS/EoUOHxEc/+lFRX18vEonEFJf82vjsZz8rvF6v2LFjh+js7MwP8Xg8P89nPvMZMW3aNPHaa6+Jd999V6xevVqsXr16Ckt9bWzatEns3LlTNDc3i0OHDolNmzYJg8Egfvvb3wohbt56Gc2FvyUkxM1dP1/60pfEjh07RHNzs3j77bfF2rVrRWlpqejq6hJC3Nx1I4QQe/bsESaTSXz9618XTU1N4ic/+YlwOBzixz/+cX6eG61tZmC5hO9+97ti2rRpwmKxiFWrVol33nlnqot0zb3++usCwLBh/fr1Qgj563OPPvqo8Pv9wmq1ig9+8IPi5MmTU1voa2ikugEgfvjDH+bnSSQS4nOf+5woLi4WDodD/Mmf/Ino7OycukJfIw8++KCYPn26sFgsoqysTHzwgx/MhxUhbt56Gc3FgeVmrp/77rtPVFZWCovFIqqrq8V9990nTp8+nX//Zq6bQb/85S/FwoULhdVqFXPnzhXf+973Ct6/0dpmgxBCTE3fDhEREdH48BkWIiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0j0GFiIiItI9BhYiIiLSPQYWIiIi0j0GFiIiItI9BhYiIiLSvf8fGm2UnfkB2uYAAAAASUVORK5CYII=",
      "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.097 (avg p value 0.401023)\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.211 (avg p value 0.210921)\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.09160137017603633, high=0.1034877199094092)\n",
      "0.092\n",
      "0.103\n",
      "1\n",
      "ConfidenceInterval(low=0.20503412545795943, high=0.2178758747195717)\n",
      "0.205\n",
      "0.218\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.09160137017603633,\n",
       "  0.1034877199094092,\n",
       "  array([0.09165325, 0.09697451, 0.10048087, 0.09893272, 0.09688168,\n",
       "         0.09327611, 0.09282833, 0.09183679, 0.10244653, 0.09468628,\n",
       "         0.09548303, 0.09561201, 0.09927705, 0.09651581, 0.09802182,\n",
       "         0.09944882, 0.0958204 , 0.09322748, 0.09182915, 0.09974222,\n",
       "         0.09699851, 0.09733144, 0.09965372, 0.09470221, 0.09691336,\n",
       "         0.09853868, 0.09880433, 0.09467009, 0.09551688, 0.09877911,\n",
       "         0.09694779, 0.0985956 , 0.09131914, 0.09376685, 0.08993802,\n",
       "         0.09225817, 0.09981762, 0.09138636, 0.09155529, 0.09752297,\n",
       "         0.09439613, 0.09530667, 0.09590647, 0.10087081, 0.09608966,\n",
       "         0.09820493, 0.09179087, 0.09401061, 0.09492751, 0.0965823 ,\n",
       "         0.09425576, 0.095241  , 0.09247111, 0.09327861, 0.09520554,\n",
       "         0.08791424, 0.10400336, 0.09162699, 0.09704754, 0.09600662,\n",
       "         0.08914774, 0.09896333, 0.0975771 , 0.09462133]),\n",
       "  0.0032443607667313927],\n",
       " [0.20503412545795943,\n",
       "  0.2178758747195717,\n",
       "  array([0.21144247, 0.20754835, 0.21480698, 0.20424855, 0.20014493,\n",
       "         0.21122829, 0.21021736, 0.20588174, 0.20694604, 0.2043539 ,\n",
       "         0.20521123, 0.20149761, 0.21426338, 0.21333255, 0.20219493,\n",
       "         0.20872629, 0.2044108 , 0.20896345, 0.20285605, 0.20719539,\n",
       "         0.2120581 , 0.20227838, 0.2179472 , 0.20147326, 0.20335255,\n",
       "         0.21192856, 0.19644817, 0.20094081, 0.21197856, 0.21350327,\n",
       "         0.21084798, 0.21060026, 0.20685331, 0.20632493, 0.20480348,\n",
       "         0.20597791, 0.21217846, 0.20514936, 0.20545155, 0.20887992,\n",
       "         0.20563513, 0.20469896, 0.20470003, 0.20723886, 0.2067521 ,\n",
       "         0.20926034, 0.20554813, 0.20645624, 0.20578724, 0.21208629,\n",
       "         0.20360808, 0.20216911, 0.20885529, 0.20854387, 0.21078477,\n",
       "         0.20866511, 0.20954972, 0.20478061, 0.2024885 , 0.20981253,\n",
       "         0.20773652, 0.20502605, 0.20771796, 0.2089767 ]),\n",
       "  0.004032505602853408]]"
      ]
     },
     "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": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA1+ElEQVR4nO3deVyU9f7//+fIMqKCuIBLKphb4ZqYZmmuiVsfczl1zErNrNPRtNRKT56jHDMqcykzbVP0VG4dKW9ZmbmUR03FXSu3NDdcSgUxQYT37w+/zs8JVAYH5w0+7rfb3Oq65j3v6/UCvHhyLTMOY4wRAACAhYr4ugAAAIArIagAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAo0OLj4+VwOLR///5831afPn0UGRnpWt6/f78cDofeeOONfN+2JI0ePVoOh+OGbAuwBUEFyINLvxwvf4SHh6tVq1b66quv8n3777zzjuLj4/P02i+//FKjR4/2aj3esmLFCrevqdPpVLly5dSyZUu98sorOnHihFe288cff2j06NFasWKFV+bzJptrA3yBoAJch3//+9/6z3/+o1mzZumFF17QiRMn1LFjR33xxRf5ut3rDSqxsbHeLcjLBg0apP/85z9677339Pzzz6t06dIaNWqUbr/9di1btsxt7KOPPqpz584pIiIi1/P/8ccfio2N9TgMvP/++9q5c6dHr/HU1WobOXKkzp07l6/bB2zj7+sCgIKsQ4cOatSokWu5X79+KleunGbPnq3OnTv7sDLvuHDhgrKyshQYGHhDt9u8eXP16NHDbd2WLVvUrl07de/eXT/++KMqVKggSfLz85Ofn1++1nP27FkVL15cAQEB+bqda/H395e/P7tt3Fw4ogJ4UWhoqIKCgrL9Mjl79qyGDh2qypUry+l0qlatWnrjjTf05w8vv3DhgsaMGaNq1arJ6XQqMjJS//jHP5Senu4aExkZqR07dui7775znSJp2bKlJCkjI0OxsbGqUaOGihYtqjJlyqhZs2ZasmSJpIvXWEyZMkWS3E6xSO7XW0yaNMlVw48//qjz58/rX//6l6Kjo1WyZEkVL15czZs31/Lly93qv3yOiRMnKiIiQkFBQWrRooW2b99+XV/b+vXra9KkSTp9+rTefvtt1/qcrlFJTExUTEyMypYtq6CgIFWtWlWPP/64q8awsDBJUmxsrOtrcOl0WJ8+fVSiRAnt3btXHTt2VHBwsHr16uV67vJrVC53rX5btmzp+j5d7vI5r1VbTteo5OZnRrr4c9O5c2f973//U+PGjVW0aFHdeuutmjVrVs5fcMASRHPgOiQnJ+u3336TMUbHjx/X5MmTlZqaqkceecQ1xhij//u//9Py5cvVr18/NWjQQIsXL9bzzz+vw4cPa+LEia6xTzzxhGbOnKkePXpo6NChWrt2reLi4vTTTz8pISFBkjRp0iQ988wzKlGihF566SVJUrly5SRd/EUWFxenJ554Qo0bN1ZKSooSExO1ceNG3XfffXrqqad05MgRLVmyRP/5z39y7GnGjBlKS0vTk08+KafTqdKlSyslJUUffPCBevbsqf79++vMmTP68MMPFRMTo3Xr1qlBgwZuc8yaNUtnzpzRgAEDlJaWpjfffFOtW7fWtm3bXLXmRY8ePdSvXz998803Gjt2bI5jjh8/rnbt2iksLEzDhw9XaGio9u/frwULFkiSwsLCNHXqVD399NPq2rWrunXrJkmqV6+ea44LFy4oJiZGzZo10xtvvKFixYpdtS5v9Zub2v4sNz8zl+zZs8f1Nezdu7emT5+uPn36KDo6WrVr1851ncANZQB4bMaMGUZStofT6TTx8fFuYz/77DMjybz88stu63v06GEcDofZs2ePMcaYzZs3G0nmiSeecBs3bNgwI8ksW7bMta527dqmRYsW2eqqX7++6dSp01VrHzBggMnpn/6+ffuMJBMSEmKOHz/u9tyFCxdMenq627pTp06ZcuXKmccffzzbHEFBQebQoUOu9WvXrjWSzHPPPXfV2pYvX24kmfnz519xTP369U2pUqVcy5e+F/v27TPGGJOQkGAkmfXr119xjhMnThhJZtSoUdme6927t5Fkhg8fnuNzERERrmVP+m3RokWO37M/z3m12kaNGuX2vfPkZyYiIsJIMt9//71r3fHjx43T6TRDhw7Nti3AFpz6Aa7DlClTtGTJEi1ZskQfffSRWrVqpSeeeML117t08eJVPz8/DRo0yO21Q4cOlTHGdZfQl19+KUkaMmRItnGStGjRomvWExoaqh07dmj37t157ql79+6u0w+X+Pn5ua5TycrK0smTJ3XhwgU1atRIGzduzDbHAw88oFtuucW1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vVo//fSTnnrqKR07duyq87Vu3Vpvv/22Nm3apMTERP3tb39TQECA2/bKli2rLl26aOXKldq3b59WrFihQYMG6dChQ1edG0AuGACF1o8//mhiYmJMWFiYcTqdpmbNmmby5Mmu548fP27uu+8+U6JECSPJLF++3BhjzPPPP2/KlCljSpQoYR566CEzceJEU7JkSdfr0tLSTPfu3U1oaKiRZGbMmGGMMUaSSUhIMMYY895775kGDRqY4sWLm5CQENOmTRuzceNG1xwLFy401atXN/7+/iYiIsIYY8yoUaNM/fr13XqYNm2aqVWrlgkICDAVKlQwzzzzzDX7bty4sZFkli1b5rb+999/N126dDElSpQw4eHhZuTIkeaxxx4zXbp0cY1p0aKFGTx4sGv58OHDpl27dqZ48eKmRo0a5ssvvzQlS5Z09WyMMUlJSeaxxx4zZcuWNU6n09x6662mf//+Jjk5+Zq1Arg6hzF/OvkKAABgCU79AAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGCt/w/HkMxbzb4i5wAAAABJRU5ErkJggg==",
      "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
}
