{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7d607888-e92d-4720-b28e-43d8ce2c643a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c9bb7deb-4dbb-4100-a5c6-1ab11c826833",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f37c6eff-445d-4007-9951-fdba0c6b46d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7499a23a-7876-4670-ae09-c4de570791e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "46fa7fd5-34ca-4e86-8773-f5ff38b758da",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"val_5000_0.5_scores_10.pkl\", 'rb') as handle:\n",
    "    seed_score_list = pickle.load(handle)\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:8].mean(axis=0))\n",
    "\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:8].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0843462-d2bc-4509-8a9e-210ab9691a5f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1aa3dbcd-855e-405a-ab27-b19f4261dcee",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"val_5000_0.5_scores_100.pkl\", 'rb') as handle:\n",
    "    seed_score_list = pickle.load(handle)\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][0])[0:8].mean(axis=0))\n",
    "\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:1].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:2].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:4].mean(axis=0))\n",
    "scores_list.append(np.stack(seed_score_list[0][1])[0:8].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "51feac50-3440-4396-a6e6-5f2a6080dbf2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b1e2f974-ea7b-4832-a740-44f53ab2c2c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "16"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(scores_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bec15b45-0542-4b6d-8bf7-9d47a53584c1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2091b23-f9b9-4627-83f8-2f755e638328",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3094d577-6791-4900-953b-d0d27e3d3d14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "17304aaf-68b6-4349-b923-b458ddca5939",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "my_list = [\n",
    "    0,1,2,3,\n",
    "    4,5,6,7,\n",
    "    8,9,10,11,\n",
    "    12,13,14,15,\n",
    "    16,17,18,19,\n",
    "    20,21,22,23,\n",
    "    24,25,26,27,\n",
    "    28,29,30,31,\n",
    "    32,33,34,35,\n",
    "    36,37,38,39,\n",
    "    40,41,42,43,\n",
    "    44,45,46,47,\n",
    "    48,49,50,51,\n",
    "    52,53,54,55,\n",
    "    56,57,58,59,\n",
    "    60,61,62,63,\n",
    "          ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/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": 11,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_testset_correctness = lds_loss_array.mean(axis=1)\n",
    "lds_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjUAAAGdCAYAAADqsoKGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABnN0lEQVR4nO3deXhU5aE/8O/sM5lJJvu+s4Q1CQQSA7gSWbRWKrZqbUFvq9aqLdLW5f4q2KoFl+vlqhRa723dqlCsuLVCEQFF9hB2CFsgZJnsmZnMPnPO749DJgxZSMISOHw/z3Oemcyc5T1vznnP97znzIxCFEURRERERFc45UAXgIiIiOhCYKghIiIiWWCoISIiIllgqCEiIiJZYKghIiIiWWCoISIiIllgqCEiIiJZYKghIiIiWVAPdAEuFUEQUFNTg/DwcCgUioEuDhEREfWCKIqw2+1ITk6GUtlzX8xVE2pqamqQlpY20MUgIiKifjh16hRSU1N7HOeqCTXh4eEApEqJiIgY4NIQERFRb9hsNqSlpQWP4z25akJN+yWniIgIhhoiIqIrTG9uHeGNwkRERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAtXzQ9aEl2OrB4rquxVaPO1oc3XBofPgTbv6UdfG8w6M+4ceicitPwR1kvBL/jh8Dlg1pkHuihE1A/9CjWLFy/Gyy+/DIvFgry8PLz++usoLCzsctw333wT77zzDvbt2wcAKCgowB/+8IeQ8T/66CMsXboUpaWlaG5uRllZGfLz80Pmc8MNN2DDhg0hrz300ENYunRpf1bhgvrjrj+iOLkYY+LHDHRR6Apg99qx7tQ6fFHxBbbUbIFf9Pc4/lv73sJjYx/DHYPvgEqp6vdy3X436p31aHQ1QqlQQqfSQa/WQ6/SQ6/WB/9WKq6+Dtzqtmr84/A/sPLoSjS6GpERkYHxieNRmFiI8YnjEWuIHegi0mWg3lmPWkctonXRiDHEIEwTNtBForMoRFEU+zLB8uXLMWvWLCxduhRFRUVYtGgRVqxYgfLycsTHx3ca/95778XEiRMxYcIE6PV6vPjii1i5ciX279+PlJQUAMC7776LiooKJCcn44EHHug21AwdOhS///3vg6+FhYUhIqJ3Z7A2mw1msxlWq7XX0/TGltoteODfDwAA7hx6J+aMnXPZnuU1uhqxuWYzXH4XwjRhMKqNMGqkIUwTBqPGiChdFDQqTb/m7xN8sHlssHqt0qPHCqvXijZvG9RKNTRKDdRKNbQqLTRKTfBvl98Fh88Bu9cuPfrscHgdcPqdGJcwDrcPvh1qZe/yt91rx1v734LFYcG4hHGYmDIR8WGdt8u+EEQhuF4apQYGtQEGtQE6lQ4KhaJX83D6nPi66mt8UfEFNlZvhFfwBt+LN8QjQhcBo8YIk8YU/J8YNUZ8W/MtKqwVAICcqBw8WfgkxieO73Y5voAPZfVlKK0rRa2jFvXOetQ561DvrIfNa+tVWUfEjMD3h34ft2TdclEbbZffhR2WHTjSegSjY0cjPz4fGmX/tr3+8At+bDi1ASuOrMCm6k0Q0X1TmG3OxvjE8RiXMA6Z5kykmFIQrg2/qOVrdjdjw6kNsDgtMKgM0Kl1oQFUpYdZZ0ZGRAZMWtM55xcQAqiwVuBA8wFU26sxNmEsxiWMO6+gLGcBIYCjrUdRVl+Gsvoy7KrfhRpHTcg4BrUB0Xop4MToYxAfFo/h0cMxKnYUBkUO6rbdEkURVfYqbLNswzbLNuxt3ItUUyquT7se16dej9Tw1PMuv9PnhCAKvdo2Lnd9OX73OdQUFRVh/PjxeOONNwAAgiAgLS0Njz32GJ566qlzTh8IBBAVFYU33ngDs2bNCnnvxIkTyMrK6jbU5OfnY9GiRX0pbtDFCjWt7lb8987/xkdHPgIAROuj8eT4JzE9a3qvD3gXiyiKONR8CBuqNuDrqq+xt3HvOadRK9UYHDkYOVE5GBY9DDnROciJzgle/ggIAVS3VeNo61Ecaz0WfKxqq4LD57go6zEkagieGP8Erkm6pttxAkIAHx/9GK+VvYZmd3PIe0OjhmJiykRMSp6EMfFjgqFNEAU0uZpQ56yDxWGBxWFBvbMeTe4mNLma0ORuQrOrGc3u5i57UxRQQK/WB0OOVqWFSqGCRqmBSqGCWqkONmr7m/bD5XcFp80yZ2F61nRMy5yGLHNWt+vlE3z4e/nfsXjXYti9dgDAzRk341fjfoUUk3RSUOeow8bqjdhYvRGbazf3+H8wqA2IM8QBkHpu3AE33H53SMhqZ9KY8J3s7+AHOT/AkKgh3c6zt0RRxEnbyWBZd9TtgCfgCb4frgnHhJQJuC71OkxKmYRofXSv5+v0O9HsbkaLu0UaPC3wCT6oFWpoVFJ41ig00nOFGqX1pVh5ZCUaXA3B+RQnFePOoXdiXOI47GnYg22Wbdhu2Y7y5vIuA49ZZ0aKKQWpplSkhEuP0fpomHVmROoig0NfThLqHHVYW7kWX1Z+idK6Ugii0Kvp4g3xyDJnhQxR+iiUN5fjQNMBHGg6gPKW8pBtEADiDHGYmjkVt2TdglGxo7pts9q8bTjYfBAHmw5Co9Ig2ZiMZJM0GDXGXq/f2RqcDdjdsBsV1gp4BS/8gh++gA8+QRr8gh8qpQo3pN6ASSmTLkoAE0QBdY46nLKfCg6Hmg9hd8NutPnaQsZVKpSIM8TB6rHCHXD3OF+D2oDh0cMxOnY0RsWNQlZEFg41HwpuV7WO2m6nHWQehOvTrscNaTcgNzY3uN5+wY9WT2twW292N6PR1YgGZwPqXfXSo7MeDa6GYDuQHp6OkbEjMSpmFEbFjsKw6GE9nqz4Aj5YvdZgG9jkakKzuzn4d6unFZG6SOn/f8Z2kBiW2O8T4nO5aKHG6/UiLCwMH374IWbMmBF8ffbs2WhtbcUnn3xyznnY7XbEx8djxYoV+M53vhPy3rlCzf79+yGKIhITE3HbbbfhmWeeQVhY1/8cj8cDj6ejwbTZbEhLS7vgoaZdaV0pfr/59zhuPQ4AmJA8Ab8t+i3SItK6HD8gBFBpr0SlrRLN7uaQoX1jdQfcGGQehGHRwzA8ZjiGRQ9DnCGuy4ZHFEXYvDZYHBZU2avwbc232FC1AfXO+pDxRsSMQGJYIhx+B5w+Jxw+qUfE4ZP+DoiBLsubYkqBSWPCCduJkAPR2RRQIFwbDrPODLPWDLPODKPGCEEU4BW88AV80qPgCzZeYWqpl8ikNcGkMQUfA2IAy8uXw+qxAgBuSLsBvx73a2REZIQss6y+DAu2LsDB5oMAgMyITNyUfhO2W7ZjX+O+kAOSQW3AkMghaHJLYcYv9Hzp50xGjRF+wd/j+vck1ZSK6VnTMTVzKoZGDe1T6G1xt2DxrsVYcXgFBFGAVqnFtKxpKG8uR3lLeci40fpoFCcXIysiC/Fh8UgIS0B8WDzijfEI14R3udyAEIAn4IHNa8OqilX4++G/45T9VPD9sfFj8YOcH+Da1GthUBt67FFx+91odDWi0dWIJlcTGl2NONJ6BBurN6K6rTpk3ERjIoZHD8fuht0hYVQBBUbHjcak5EnQqXVo87bB7rVL9x5522D32dHmbUOLpwWt7tYuQ1lvROujMWPwDNw55M5u91Wrx4odlh3YXrcdexv2oqqtqlNw7kmYOgyRusjgGX2sITZ4Zh9riEWUPgr7G/djTeUa7GnYEzLt8OjhGBEzAt6ANxhAPQEP3AE3PH4PmtxS/fZW+4E2Piwe39Z8GwzKAJAWnobpWdMxJWMK2nxtONB0APub9mN/436csJ3odp5mnTl4cEs0JnZsb2dse3q1Hn7BjyMtR7CrYRd21e/C7obdnbaHnsSHxeN7g7+HO4bcgWRTcrfjCaKACmsF9jXug81rgzfghVfwSo+nB5/gQ72zHqfsp1DdVg2f4OtyXmHqMOTG5WJM/BiMiR+D3LhcGDXGjiDtag45Capqq8KBxgPY17TvnCd5aqUaubG5GJ84Hvnx+TjachQbqjagrL4spB1u33aa3c2weqw99ij2hlKhxKDIQcg2Z8Pld8HutcPmscHutcPus3cKvr2lgALxYfEYGjUUfyz543mV8WwXLdTU1NQgJSUFmzZtQnFxcfD1J554Ahs2bMDWrVvPOY+f//znWL16Nfbv3w+9Xh/yXk+h5s9//jMyMjKQnJyMPXv24Mknn0RhYSE++uijLpfz7LPP4ne/+12n1y9WqAGkhPvX/X/Fn3b/CV7BC51Kh4dyH8L3h34fx63HUd5SjvLmchxuOYwjLUfOmfS7Eq2PxrDoYcg2Z8PutcPitKDOUYc6Z12XG6NBbcA1SdfghrQbcG3KtYgLi+t23qIootZRi0PNh1DeXC49tpR3anh0Kh2yzdkYFDlIGsyDkGnORLQ+GiaN6YKeTVk9VizZvQTLDi1DQAxArVTjh8N+iIfyHoLT58Srpa/ii4ovAEg9Cw/nPYx7ht8TPOi2uFuwuWYzvq35FhurN3Y6GCkVSsQaYpEYlogEYwISwhIQa4jt6FI+ffCJ1kdDq9ICkAKAO+CGy++Cy+eC0++Ey++CT/AhIAbgF/wICNKjT/QhIASQGZGJETEjzrv37nDLYby07SVstXTsawooMDp2NCalTsJ1KddheMzw874vRhAFbKndghXlK7Du1LpOYVetUHe6HCKIAhpdjZ3Obs+kUWowNmEsrk25FpNSJiHbnA2FQoGAEMD+pv3YULUB31R9EwyofaFX6RGlj5KG05dR/YI/OLSf+fsFP2LDYjFj8AxMTpvcr7NLh8+B6rZqVNmrgo81bTVo8bTA6rGi1dMKm9fW656WdgookB+fj8npk1GSURLsjeuJzWvDCesJVFgrcNx6HBXWClRYK9DsbsbgyMEYETMCI2JGYGTMSGREZAT3T2/Ai2+rv8UXFV9gfdX6cx7Mko3JGB4zHABQ01aDGkdN8ITjXMw6M7wBb6dlKKDA0KihyInOCYbl9svSGqXUs9bgbMC/Kv6FVk9rcJoJyRMwc+hM3JB6AzwBD/Y27sWuBiko7WnYExLWekOtUCPZlIy08DSkhqci25yNMfFjMCRqSK8vfZ+pPVjtbdyLfY37sLdxLyqsFRgSOSR4r1Z+fH6XPSZWjxXfVn+L9VXrsbF6Y6d1UUARDDpR+ijEGKTLXvGGeMSFxSE+LB5xhjjEhcXBF/Bhf9N+7Gvch31N+7C/cX9I72R3FFAgSh8VcmktxiC1g5G6SLR6WlHdVo3atlrp0VEbPNnLicrBh9/9sM911pPLNtQsXLgQL730EtavX4/c3NxO7/cUas721VdfYfLkyTh69CgGDRrU6f1L3VNzpkpbJZ7b8hy21G7pcTy9So8scxaiDdHBA2f7hhStj4ZaocaR1iM42HwQ5c3lOG49fs5GMkoXhQRjAvLi8nBD2g0YnzgeOpXuvNbH6rHicMthOHwOZJuzkWJKueTX4Y+3HscrO17BN9XfAJDOXjwBD1x+FxRQ4I4hd+CxMY8hxhDT7TwEUcCh5kOoslcFzyJjw2Iv6X0cF4Ioilh3ah22W7ZjZOxITEie0OtLNf1R56jDR0c/wkdHPoLFYenVNDqVDrGG2OCQZExCUVIRChMLe3WfTr2zHt9UfYMddTugVCiDPXjhmnCpJ+/080hdJKL0UYjURV52N20KogC7145WT6t0ycDVjEZ3R+9V+6WDZnczkoxJKEkvwU3pN/V44nGxOH3O4M3r39Z8i2h9NEbGjJSG2JEYETOiy23M4XNIAaetBtVt1bA4pUu4Zw5nBhmTxoS8uDzkxechPy4fo2NH9+qeD2/Ai7WVa/GPw/8ICfQmjQkOn6NT74VepcfI2JGID4uHVqmFVnV6UGqhUWmgVWoRbYhGWnga0sLTkBCW0K/wcrH5BT/2Ne6DN+ANHh8idZHn1f7WOeqwr2kfquxVMGlMiNBFIEIbgXBtOCK0EdL9fWpjn5YhiiKa3E2oaauBX/BjbMLYfpevK5fl5adXXnkFzz//PL788kuMGzeuy3H6EmocDgdMJhNWrVqFqVOnnrPsF+uemu6Iooh/VvwTL29/Gc3uZiSEJUj3p0TlYGj0UORE5SA9PL1PG47b78aRFinkVNoqEamPREJYQkiXr16tP/eMrmAbqzfi5e0vBy/z5cfl46mipzAyZuQAl0z+RFGEV/BK9+KccT9O+6UQhUIRDDEmjWnA7ymj/hFE4YJ9Aq79sni9sx5KhRKZEZnnfUJUaavER0c+wsdHP0aTuwmAdHk8Ny4X+XH5yIvPw9CooVfcyQp176LfKFxYWIjXX38dgHSjcHp6Oh599NFubxR+6aWX8MILL2D16tW45prub/bsS6j59ttvMWnSJOzevbvLXp+zXepQ047fe3Hh+QQf/nX8XzBqjJicPpkHT6KrkE/w4WDTQSQaE8/7E450eevL8bvP/W1z587F7NmzMW7cOBQWFmLRokVwOBy4//77AQCzZs1CSkoKFixYAAB48cUXMW/ePLz//vvIzMyExSJ1X5tMJphMUrdjc3MzKisrUVMjfVyuvFy68TExMRGJiYk4duwY3n//fdxyyy2IiYnBnj178Pjjj+O6667rVaAZSGqlmoHmAtMoNbh98O0DXQwiGkAapQa5cZd3+0+XXp9DzV133YWGhgbMmzcPFosF+fn5WLVqFRISEgAAlZWVUCo7ui6XLFkCr9eLO++8M2Q+8+fPx7PPPgsA+PTTT4OhCADuvvvukHG0Wi2+/PLLYIBKS0vDzJkz8dvf/rbPK0xERETy1OfLT1eqgbr8RERERP3Xl+P31fd96ERERCRLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAv9CjWLFy9GZmYm9Ho9ioqKsG3btm7HffPNN3HttdciKioKUVFRKCkp6TT+Rx99hClTpiAmJgYKhQK7du3qNB+3241HHnkEMTExMJlMmDlzJurq6vpTfCIiIpKhPoea5cuXY+7cuZg/fz527tyJvLw8TJ06FfX19V2Ov379etxzzz1Yt24dNm/ejLS0NEyZMgXV1dXBcRwOByZNmoQXX3yx2+U+/vjj+Oyzz7BixQps2LABNTU1uOOOO/pafCIiIpIphSiKYl8mKCoqwvjx4/HGG28AAARBQFpaGh577DE89dRT55w+EAggKioKb7zxBmbNmhXy3okTJ5CVlYWysjLk5+cHX7darYiLi8P777+PO++8EwBw6NAhDB8+HJs3b8Y111xzzuXabDaYzWZYrVZERET0YY2JiIhooPTl+N2nnhqv14vS0lKUlJR0zECpRElJCTZv3tyreTidTvh8PkRHR/d6uaWlpfD5fCHLHTZsGNLT07tdrsfjgc1mCxmIiIhIvvoUahobGxEIBJCQkBDyekJCAiwWS6/m8eSTTyI5OTkkoJyLxWKBVqtFZGRkr5e7YMECmM3m4JCWltbr5REREdGV55J++mnhwoVYtmwZVq5cCb1ef1GX9fTTT8NqtQaHU6dOXdTlERER0cBS92Xk2NhYqFSqTp86qqurQ2JiYo/TvvLKK1i4cCG+/PJL5Obm9qmQiYmJ8Hq9aG1tDemt6Wm5Op0OOp2uT8shIiKiK1efemq0Wi0KCgqwdu3a4GuCIGDt2rUoLi7udrqXXnoJzz33HFatWoVx48b1uZAFBQXQaDQhyy0vL0dlZWWPyyUiIqKrR596agBg7ty5mD17NsaNG4fCwkIsWrQIDocD999/PwBg1qxZSElJwYIFCwAAL774IubNm4f3338fmZmZwXtgTCYTTCYTAKC5uRmVlZWoqakBIAUWQOqhSUxMhNlsxk9+8hPMnTsX0dHRiIiIwGOPPYbi4uJeffKJiIiI5K/Poeauu+5CQ0MD5s2bB4vFgvz8fKxatSp483BlZSWUyo4OoCVLlsDr9QY/it1u/vz5ePbZZwEAn376aTAUAcDdd9/daZz//u//hlKpxMyZM+HxeDB16lT88Y9/7GvxiYiISKb6/D01Vyp+Tw0REdGV56J9Tw0RERHR5YqhhoiIiGSBoYaIiIhkgaGGiIiIZIGhhoiIiGSBoYaIiIhkgaGGiIiIZIGhhoiIiGSBoYaIiIhkgaGGiIiIZIGhhoiIiGSBoYaIiIhkgaGGiIiIZIGhhoiIiGSBoYaIiIhkgaGGiIiIZIGhhoiIiGSBoYaIiIhkgaGGiIiIZIGhhoiIiGSBoYaIiIhkgaGGiIiIZEE90AW40omBAAItLQjYbAhYrRDsdgSsNgRsVgg2GwJWG5RhYTCMyYchLw+qiIiBLjIREVG/+JuaoIqMhEKlGuiidImh5jx5jhxBxYzv9W5khQK6wYNhGDMGhrFjEDZmDDQpKfA3NsJXUwu/pRa+2lr4ai3w1dZCdDkRVlyMiJtvhjYz86KuR18JLhc8R4/Cc/gwPIcPw9/UDG1mJnRDh0A/dCg0aWkXZaP3WSxw7dwJ15690A0ZDPMdd0ChUFzw5ZyLKIrwWyxwl5fDc6gc3orj0KSlw3T9ddCPHAmFUl6doN6qKrS8+x4Cra3QDRsG/fDh0A/LgSoycqCL1meC2w3RH4DKZLwkyxNFEd6KCij1eqiTkgZke70SiaIIf00NfDU1UCckQJOcDIWah6yB4qurR/1LL8H2z39Cm5WF2Id/hohbbrns/icKURTFgS7EpWCz2WA2m2G1WhFxAXtLfDU1ODq5BMrwcKjCw6E0R0AVYYYqIgLKiHCoIswINDXCWbYLvsrKzjNQKIBe/At0Q4ci/OabET7lZuiGDr1gDaMoivDX1cF74iS8J05AaLNLZVIoAYUCCqVC+hsKBFpb4TlyGO7Dh+GrPNVjuRV6PXSDBkE3dCh0Q4ZAk5YKbUoKNMnJUJrNvSq/GAjAc/gwnDt3wrWzDM6ynfDX1IaMEz59GpL/8AcoDYbzrYoeCU4nbKtWw33gADzl5XAfPgzBau1yXFV0NEzXXgvjddfCNHHiFXngb+c5fhxNf/ozrJ9/DgQCnd5XJydBP2w49MOGQZ87GsbiYih1ugEo6bm5y8vRsmwZbJ9+BlEUET93LqJ+eM9FDaCuXbtQ/+p/w7ltGwBAZTZDN2K4VGcjhkM/fDi0WVmX5KxX9Pngr6+Hr7YW/kbpbFudEA9NfDyUxksT8LojOJ3wHDkC96Hy0/tXOTzlhyHY7R0jqdXQpCRDm54BbXo6tBnp0KSnwzByJNRxcQNXeJkTvV40v/suGhf/EYLTGfKeJiMdsQ/9DObv3nZRw01fjt8MNedJFEVAEHrVKPkbG+HatQvOnWVwlZXBvW8fRJ9P2lkTEqBOSoQmKRmaxERokpMgCgLavloHx9atgN8fnI8mIx3hN94EVVRUx8zbQ0L7g1IpBROlQgoQCiWgVAIKwF/fAO+JE9JQWQnR5erXuqtiYoI9M6qYWHiPH4fnyBF4jh6F6PF0O53SaIQmORmalBSokxIh+nwQbHYIbXYEbHYE7DYINjsCdnvIeksTK6EfNgy6IUNg/de/AJ8P+hEjkPrHxdAkJp6zzAGrFb66OugGD+7VwUwMBND60UdofO11+BsaQt9Uq6HLyoIuJwfarEx4yg/D8e23EByOkPIa8vNhLC5GWMFY6HPzztlD4K2qgnPLFji2boPfYoE6Lhbq+ASo4+Olg1BC+/OEixYg3IcOofFPf4J91epgeDVOmgRDfr500Dl0CL5TpzpNpwwLg+nGGxE+dQpM117bbdgM2O1wlZXBuaMUnsOHAbUKSp0eCr3u9KMeSr0OCr0BmsQEaNLSoE1Lgyompk+BXnC7YVu1Cq3LlsO1a1en9w3jCpD8/PMXvCfUc+QI6hf9D9rWrpVe0Gikejx7e4Z0AmDIy4PpxhsQfuON0GZk9Hu5ot8Pz/HjUvg+cgT+2lr4aqQeYH9DAyAIXU6nNJmgTkiAOj5OCgiCCMHlguhyQnC6IDidEFwuCG4XFBoNVKZw6aTNFN5xQhceDk1yMgy5o6EbMqTHg5zo98O1ezfavvkGjm82wn3gQNcnSRoNNImJ8NfX99imaNLSYBiTj7CxY2EYM0bav89ok0VRRKC5+XQveA38tRaooqIQVlgITUJ87yv4AhMDAdj+9S+0fLAMCASgio6GKjoK6uhoqKI6nivUaoh+P0SfD6LP3/Hc74PKZII2OxvazMwe2wPB6YR7/364du+Gc9cu+OsbEDYmH8YJExA2fjyUYWGdpmn79lvUPf8CvBUVAABDfj7if/0rOHeWofkvf0GgtRWAVP+xDz0I8+23Q6HRXPB6YqjpwsUKNedD8HoRaG2FOiamx1AUsFphX7cO9jVfwrFxY487d7+o1dCmpECbmSkFJVEEIEIUROm5KAKiAEVYGPRDhki9L0OHQh0T0+XsxEAA3spKKeAcPgLPsaPw1dTAV12DQGNjn4qmNBphyM+XLteNHQtDbm7wrNK5fTuqfvFLBFpaoIqLRdrrr8OQn9/lfPzNzWj+y1/Q/P4HEJ1OaDLSEfX978P8ve91uR6iKMKxcSPqX3oZniNHAACa1FSEl5RANywH+pwcaAcNglKrDZ3O64WzbBfavt4Ax9dfw3Pk6FkrJIUyw9ixCCsYC8PYsdK6bN0Kx5atcG7dCl91da/rRxUXC21yCjSpqdCkpECTmiKFxbg4BJpb4LPUwm+xSAc2Sy38tRb46+uhNBqhjosLHsTaB6UpHNZPPkHbunXBZZhKJiP2oZ/BMHpUyLIDdrsUcA4egvvgQTg2bYLfYgm+rzAYYLruOkRMnQL9qFFw79sHZ+lOOEtL4Skv71UP5dkUYWHQpqZ2hJxI8+kApO941Omg0Gjh+OYbtH78cUePmlqN8JISRN31A3iOH0f9f70K0emEQqdD3C9/iejZs867x8RbVY3G11+H9dNPpfVTKmH+3gzEPfIIVLGx0j5x8CDcBw7CfegQ3IcOQTzr7Fc7aBDCb7wBpptugiEvr8syiT4fBIcDvtpauPfvh/vAAbj3H4C7vByi2919/Wk0UCclQR0djYDVCn9dXaez7wtBYTBAP3IEDLl5MOTmwpCXCyiVcHzzDdq+2QjHpk2hvTCQtmX90Jzg/qXLyYEuKwsKrRaiIMBfXw/vyUp4K0/CV1kpPa84Ds/RY522JaXRCH3uaACAv6YWPoul23ZTm5WFsGuKYCwqQlhhIdTR0Z3GEbxeBJqb4W9qOuOxBYGWZvibmxFoaoa/pRnw+WG64XqYZ8yANj292/oRBQH21avR8MZieI8d62v1dk2hgCY1FbrsbGgHDYIuOwtQq+HeswfOXbvgKT/cZW8rAECjQdiYMTBOmADjxIlQRUWi/sWXYF+zBoB0Ahv/61/DfPt3gyeDgsOBlmXL0PR/f0GguVmaTXIyYh56CJF3fO+ChhuGmi5cjqGmPwSHQzq72bpV6uU589/X/vSMICIKUk8SRBGiKACCCHVMNLQZGdBmZkKbkQFNSspFSdddlt/tlg6w1dVS0LHUQqnTSWd7EREhZ32q8HCo4+N7PNB4q6pR9fOfw3P4MBRaLZKe+z3Mt98efN/f2Iim//sLWpYt6+iRUqs7zpg1GoRPnoyou36AsKIiKJRKuA8eRP3LL8OxaTMAQGk2I/bhnyHqhz/sFGLOxVddjbZvvoFzRymcO0s7XT7rkloNQ24ujNcUQZuVDX9TI/z1DfDX1cFfVwdffT38dXUXPtyeSaFAxPTpiHnoIehzhvZqElEQ4N6zB7Z/r4F99epzhjNNRjrCxhbAkDsaUCghetwQ3J6OR7cbgtMJX20tvKcq4a+19CsIaZKTEfmDHyBy5h0hlym8VdWwzHsm+H/W5+Yi+YXnoRsypNfr629ogK+6Br7aGrhKS9Gy4kPA5wMAhE+Zgrhf/gK6QYN6nIf3xAk4vvkG9nXr4dyxI6Q3RxUVBd2gQQg4HRDaHBAcDghtbefsCdUPHw7dsGFSyE1KhiY5CZqkJKiiozv1UAbaHPDX18F/ervyNzQAKjWUBgOUxjAoDQYoDAYoDWFQhhkger0I2O0Q7G1Sr6q9TepltdrgOX4M7r37ILS1nbP+VGYzjJMmwXjtJBiLJ/S7xyRgt8O1ew9cZWVwle2Ea9furoOaQgF1bCzUyUnQJCTCV1Mj9RCd1XulGzoUmvQ0KbQ0NcHf3NwpgPWGoaAA5hm3I2LaNKjCwwFIJ0v2L79E4+tvSD2UkNqXmPvvg3bQoNCg1NwiBaiWFiAQkHq+NGooNBoo1Boo1Goo1GrptoDjxyHYbOcskzo+XjpJzM+HOi4Ozu3b4fj22+73VZUKUff+EHGPPRZch7MJTidalv8dTf/3fwg0NkIdH49Ba/59QXuRGWq6IJdQQ50F2hyoefLJYFd/zE9/gqgf/xjNf/krWpYvD5656keNQuzPfw5jUSFsX3yBlr+vgHvPnuB8NOnp0OfkwP7ll4AoQqHRIOpHP0Lszx6Cymy+IGVtv9HZubMMzp2l8Bwql8o2ciSM1xQhrLAIYWPHnPMeB1EUEWhtlQ6o1dXwVVXBV10Nb7X06G9ohDo6GpqkRKgTk4KXNNWJSVDHx0FwOOBvaOgYGhvhb2hAoLEJumE5iPnJT6UzvX4SRRHu/Qdg//e/YVu9Cr5TVVIPVUEBwgoKYBg7Bpr4vh3EBK83uK7eykr4TlUh0GaH6PZAcLsgtgchtxuixw1NRgaifvADGCdO7DYYi6II6z/+gbqFL0Joa5P+5z/8IVRRUae79zu6+UWfD6LTJd3MX1MDX11dMMCcyTihGHGPPw7D6NF9rreAzYa2b75B27r1aPv663MeqJQREdJN2yNHQj9iBPQjR0CbkTGgN6qLggBvRYUUNPbshmvPHqmXQBCgzx0N07XXwXTtJOhHjboo9xKJgQA8R47AtWcPlDod1ElJ0uXu+HgozjopCdhscO7YAceWLXBu2RoMGl1Sq6XLQjExUEdFdXmpSHQ6Yf30Mzg2bQoGcIVOh/CSEoQVFqJl+TJ4DhwEIF3yi77vPkTPntVtYOj1OosiAo2N8ByvgPf4MXiOHYf3+HEIHg8Mo0ZJn77Nz+/yEr0oivBVVsKxaRPavv0Wzi1bIbS1IWz8eCT89re9PqkRXC60rlgBZUQEImfMOK/1ORtDTRcYauRNFAQ0/M9raPrTn6QXzrgBW5+bi7hHfg7jddd1uh/DffAgWlesgPXTz0LOLiNumY64xx+HNi3topZbcDggirhkn8QZCKIodpxpXqZ8dXWwzH8WbevX921ClUq6xyk5CdqUVJhn3A5jcfEFKZPo98NVVgZ/YyOUJhOURiOURulRZTJCaTResh7W8yW4XBADAahMpoEuSo/8zc1wbtsGf3Mz1NExUMdEQxUTC3VMNJQREb2+n8tXVwfrp5/C+vEnnS4vKcPCEDXrx4i5777L8kMEot8Pf1Mz1PFxl80n9RhqusBQc3WwfvY5av/f/4Po9cKQl4fYRx+BcdKkc+6cgtMJ2xer4DlcjohbboEhL+8SlZguF6Iowr5qFdq+/gZQKTu6+TWnB7UaCr3udK9XMjRJSdLl0cs4rNHAEkUR7n37YF35MZxlZTBOKEbMT38K9Zkf8qBzYqjpAkPN1cN74gT8LS0w5OdfNmcaRETUP305fvMUg2RHm5l52X1ZIRERXXzy+tpTIiIiumox1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNTQBSEIV8U3AxAR0WWMH+mm8+LyBvDEP/Zg9T4LUqMNGJ1ixqhkM0almDEyJQIR+ivjG0/p3ARBhEIBfvcPEV22GGqo3xrsHvz07e3YXSX9CvLxBgeONzjwya6a4DiZMWHITY3EQ9dnY2Ry334/KSCIUCl5AL0cHKmz44F3dsDrF/Dgddm4uzAdes2F/90euvq4vAHUWl3Ijru8f0LB5Q3glX+Xo6yyBd8bm4o7xqTAqOMh9HLDbxSWoUtxRn20vg33v7UNp5pdiAzTYNFd+QCA/TU27Ku2Ym+1FVUtruD4aqUCv5g8BA/fMAgaVc9XPb1+Af+3sQKL1x1FRkwYfjl5CG4ekcAeggGy9XgTHnhnB2zujl+PjjXp8NB12bj3mnSEadmwU/9sOtaI36zYg+pWF+4pTMf820ZclmF5X7UVc5bvwtH6jt+HC9epcee4VMwqzkRWbP9+u63W6sLHZTXYcLgeQ+LDcd/ETAy6yOHO6vLh013V2FNlRXp0GIYmhmNoQjjSo8Mu25NI/kxCF+QeakRRxJbjzXhvy0ms3m9BcqQBNw2Lx+Th8SjMioZOfeEaiq3Hm/Dgu6WwunxIjw7DW/eP7/Isq9Xpxb5qG97bchKr9lsAAKNTzPivH+RhaELXv0q74XADfvfpfhxvdIS8PjrFjDklQ3DTsPgew02bx48tx5pwoskBb0CA1y/Ad/rR6xfgDQhQKhRIjjQgOVKPlMgwJEfqkRihh/ocYetq9NnuGvzq77vhDQgYmx6J2/NT8Oevj6O6VQqs0UYtfjIpC7OKMxB+HpcaRVFEvd2DI3VtOFJvx+G6Nhytt6O6xYXCrGjcPzELeWmRvZqXIIjYXdUKjUqJEUkRUF6mDfWVxO0L4FSzE5XNToTrNchJDIfZ0P//t9sXwEuryvGXbytCXs9JCMfie8dgcPy5f7Xa7Qtg8/EmaJRKxJi0iDFpER2m7bQfe/wBVDY5cayhDccaHDhW34aKJgeSzQbcW5SO4kEx3bYpAUHEn78+jlfXlMMXEBEfrsPdhen4bHcNKs5oo64fGof7JmTi+qFx59zenF4//r2/Dv/YWYWNRxtx9hH4pmHx+MmkLEzoplzt2/fq/XX48mAdBEHEdUPjcNOweBRld93Wi6KI7SdasGx7Jf61txZun9BpHJ1aiUFxJuQkhiMr1gi/IMLl9cPhDcDlDcDh8cPlC8DjF1CQEYU7C1IvegBrx1DThcsx1AiCGDzIKhWAUqHocw+L3e3DyrJqvLv5JI6ccRZxJqNWFdzobxwWj1iTrt9l/mRXNX6zYg+8AQFj0iPxv7PGIeYc8xNFEZ/ursG8T/bD6vJBq1Ji7pSheODa7OCZwalmJ577/AD+faAOgNQT8JupQ3GyyYm3Np2A0xsAAOSlmjHn5qG4Yaj0C7KiKOJArQ0bDjfg68MNKD3ZAl+g75u0UgEkRuiRHhOGKSMS8d385F7XU5vHj50nW5ARE4aMGHn82rYoivjfbyrwwr8OAgCmjkzA/9w9BnqNCl6/gJVlVVi87hgqm50AALNBg+/kJkGnVkEQRYiiCBE4/Vx69AVE+AIC/AFpu/cHBPgCIto8fhxraIP9jJ6groxJj8R9EzJxy+ikTr19oihib7UVn+6qwed7amGxuQEA8eE63DQsHjcNi8ekIbFd9iq1Or3YfqIF2yqasLWiGbVWN5IjDUiPDkN6tPSYFh2GtKgwJJnlHX4b2zzYebIFxxsdONnkwIlGJ042OVBrc3c6+CaZ9chJDEdOYjiGJYYjJyECg+NN0Kp7rp89Va14fPkuHGuQQsE9hem4aVg8nv5oLxrbPDBoVHhuxijcWZDa5fRtHj/e33oSb35TgQa7p9P7UWEaxJh0iArToMHuwakWFwI9fJBhcLwJs4sz8L2xqTCdcTmputWFuct3YWtFMwBpH1hwRy6ijVoIgohvjjbinU0n8FV5fbBuks16ZMeZEGPSItakQ6xJhxiTFnEmHaAA/rWnFv/aWwvH6fYMAAozozF1VCI2H2vE2kMd8xqWGI7/mJiF7+YnQ6VUYFtFM1bvt+Df++uC2/fZwrQqTBoci8nD43FjTjxUSgU+2lmNZdsrg/UNSOGxZEQ8alvdOFxvx9H6ti6DzrmMTY/EnQVpuDU36bxC7rkw1HThYocaX0BAY5sH9TYP6u0e1NncqLd70GB3o8XhQ5vH3zG4pUeH19+poQAQDDhatRKJZj1So8KQEmlAalTHoFIq8WHpKazcWR3cQcK0KswYk4K7xqWhzubGV4fqsfZQfciOr1AAGdFhSI8xBhtsaTAiLdrQ7dm2KIr44/pjeHl1OQBg2shELLo7v09dxXU2N57+aC++OlQPQNohXvjeaKzeb8GS9cfg8QtQKRW4f0ImflEyJHiTcVObB3/+5jje2XQSLp+0rmPSI5EVY8TXRxrR2BbasKVHhyEvLRJ6tRIatRJalRI6tRJatRIalRL+gIAaqxvVLS7UWF2obXXDGwjdodVKBW7IicMdY1Nx07D4TutZb3NjzcE6rDlQh01Hm4LTj8+MwsyxqbglN6nHm6Sb2jzYcLgB68sbUGvtuEyngKL9CQAgQq9GflokCjKikZ8WCYO26/r2+APYebIVG482YOPRJpRbbPj5DYPx2E2D+3zZLiCIeO7zA3hr0wkAwH0TMvHMd0Z06pr2BwR8ursGb6w7iuMNji7m1DdKBZAZY8TgeBOGJoRjSIIJ0UYtVpZV4/PdtcE6TojQ4UdFGbinKB2tTi8+3VWDT3fX4ESTMzivcL0agiCGHDy0aiWKs2MweXg8oo1abK9oxtaKZhyy2HtdRq1KiaGJJoxOMWPk6RvihyWGh2wfoijCYnOj3GLH4To7yi1tON7YhliTDiOSIjAiOQIjkyOQEmno9L9p8/ixr9qKPVWt2F1lxd4qK6wuH0w6NUw6NYw6FYw6NcL1ahi1apj0aoTrNYjQqxGh1yBcr0aE4fSjXoOoMC3C9epuew+qWpzYfqIZ207XRU//x3CdGmnRYWh1elFj7fqgqtcoMTY9CoVZ0SjKisGY9Mhg3fgCAt746ijeWHcUAUFEXLgOL83MxY3D4gEA9XY3Hl++C98ebQIA3DEmBc/NGBW8b6XF4cVfN53A25tOwOryAZBCa1SYFk0OD5odXnSXXUw6NQbFGTEozoTsOCMyYozYVtGMf+ysCp4whevUmFmQih8XZ2BftRW//Xgf7G4/wrQqPHvbSHx/XGqX+9LJJgfe23ISy7efCrlE25P06DDcMTYFd4xJRXpMWPD1ikYH/vptBVbsqAq2dTFGLQKiiFanLzieUavCjcPiMXVkIrRqJdYdqsdXh+pRf1bIUysV8J+ulDCtCrflJuPuwjTkp0WGrEtAEFHV4kS5xY4j9W2obHJCo1bAqFXDoFV1POpU8AdErNpnwfrDDcGwqFMrMXVkIu4sSMXEwbEX/DIWQ00XLlaoOVhrw4/+dyuand4uA8qlMCjOiB9fk4E7ClI7HUgFQcS+GivWHpQ2+r3V1h7npT0dAtQqBTQqJTRKRfDMtP2s/CeTsvCftwzv14YriiJWlFbh958dQJsntAGYODgGz942EkO6uTTV2ObBnzYcw7tbToacVYRpVSjOjsH1OXG4bkgcMvt4fVsQRDS2eVDV6sKeU61YWVYdvPkZkILFbXnJuHlEAvbX2LDmQB12nWoNmUeSWQ/LGWezOrUS00YlYuZYaSdXANhXY8W6Qw1YV16P3VWtfd5e1EoFRiZHYGxGFMZlRCMlyoDtFc345mgjtlU0dXmm9YNxqXjhe6PPeR9TO7cvgF8uK8Pq/VKP2W9vHY6fTMrqMRgFBBGr91uwp8oKpUIKzlKvoxTR2nsiNWol1EoprKuV0jbWHjgzY43IijV2G5Ib7B68v7US7209GQzpKqUi5Axcr1GiZHgCbstLxg05cQCAbRXNWHuwHmsP1eFUs6vLeQPSPlSYFYNrsqORFWtETas7eLmlstmJUy1OVDW7OoXf9nIMiTdhcLwJtVY3DlvssHvOfXCL0KsxIjkCw5MiYHP5saeqFUcb2i54O6JSKhBp0CDKqEVUmAaRYVpoVUrsOtUavIzYTqGQzuKHJYYjI8aIzFip9zEzxoioME1wO7C6fDhcZ8chix3lFhsOW9pwyGLrdFDXqpTISzOjMCsa3xxpxJ7T+9WtuUl4/vZRiDJqQ8YPCCKWrD+KV9cchiAC2XFG/P67o7C+vB7vb6sMBpDsWCN+dsMgzMhPCfYMBQQRrU4vmhxeNLZJISfaqMWgOBPiw3VdbsM2tw8flVbhnc0nO13yBqSTp0V35feqB9bp9WPnyVY0tLnRaPei0eGRHts8aHJ4YHf7cU1WDGYWpGJ8ZlSP+5TV6cMH2yvx9qYTqD0dIKONWtw8PAFTRyVgwqDYTvuKIEi91lJbXxdsw/JSzbhrfDpuy0s6r0vEZ6u3u/FxWTU+LK3C4bqOqwQpkQas/dX1F/TeqIseahYvXoyXX34ZFosFeXl5eP3111FYWNjluG+++Sbeeecd7Nu3DwBQUFCAP/zhDyHji6KI+fPn480330RraysmTpyIJUuWYMiQIcFxMjMzcfLkyZB5L1iwAE899VSvynyxQk11qwsTF34FQDroxJp0SIjQIS5cj/gIHeLDdYgxamHSq2HSaWDUqRCu08Ckl8669BoVRFGqA+F0N317l73LG0BNqwtVrS5UtbhQ3eJCVYsT1a0utDi8uG5oHH58TUaP14TP1mD34Gh9W0iDXdnsxKlmJ5oc3h6nVSiA+d8ZgfsmZl2Qenvywz3YeLQRyWY9fvudEZg+KrFX61Fvd+O9LZXw+gVcNyQWBZlRF/SeIQA4Wm/HRzursbKsOtionC0/LRI3j0jA1JEJGBRnQp3Ng5Vl1fiw9FRIV29ChA4BAZ16lEYkReCmYfEYkRwBpQLBg9mZO2SdzY0dJ1tQeqKl2y7ndrEmHSYNjsGkIXGwunx44Z8HIIjAdUPj8Md7x4Z0rXflcJ0dT/5jD8oqW6FVKfHqXXn4Tm5yj9Ncal6/gH/trcVfv63A7ior1EoFrh8ah+/mJ6NkeEK3n0YRRRHHGtqC4d7h9WNcRjSKsqIxPiu6V5caBUFEdasL+6qt2Fdjxb5q6ab4rvYblVKB7FgjhiaGIychHNlxRtTbPDhQa8OBGhuO1Nu7vUyabNYjNzUSuWlm5KVGIiFCB4cnENLT6/BKz+1uP+xuH+xuP2yu04+n/7a6fMEQ0B2VUoFRKWYUZUWjMDMa4zKjEBmm7XGa7rTX8ZbjUq/P1uNNnXoOzAYNnpsxCt/N63m72lbRjF98UNZpmx+ZHIFHbhyMqSMTL2hvgCCI2Hi0Ee9sPom1h+qgVCjw2E2D8eiNgwf0cqMvIODbo40waFQoyIjqU1ka7B64vIGQnqCLof3S74elVfhkVw3Gpkfir/d3nQf666KGmuXLl2PWrFlYunQpioqKsGjRIqxYsQLl5eWIj4/vNP69996LiRMnYsKECdDr9XjxxRexcuVK7N+/HykpKQCAF198EQsWLMDbb7+NrKwsPPPMM9i7dy8OHDgAvV4PQAo1P/nJT/DAAw8E5x0eHg6jsXdn5Rcr1PgDAg7XtSE+QofoMO0VfVNim0dqCKV7HYTgPRDtz1MiDUiLvnA7iCiK2Fdtw+B4U7eXVQaaIIjYcrwJ/9hZjU3HGpGTGI6bRySgZHgCEiL0XU4jiiJ2V1nxj9IqfLq7JthVbtSqMGlILG4aFo/rh8Yj0dz19N3Ns7rVhdKTLSg92YIdJ1pQ3erCmPRITBoci0lDYpGTEB4SCtcerMOj75fB5QtgRFIE/nr/+C7L3GD34L+/PIxl2yohiFIPwpuzxqEoO6aPtXVpnWxywGzQ9PsgfCG0X2raW2XF8UZH8D6TrFhjj0Hb6xdwpN6OAzU2HLLYYdSqgkEmPrz328W5ePwBtDp9aHZ40eL0osXhQ4vTC6fXj+FJERibHnXRPpYsiiJONjmx9fS9SgaNCo/dNKTX232zw4vfrNiNtYfqUZgVjUduHIzrhsRe9E9B1rS64AsIsrk/7lLy+ANodniRZDZc0Ple1FBTVFSE8ePH44033gAACIKAtLQ0PPbYY73qNQkEAoiKisIbb7yBWbNmQRRFJCcn41e/+hV+/etfAwCsVisSEhLw1ltv4e677wYghZo5c+Zgzpw5fSlu0OV4ozDJn8cfwKZjTdCplBiXGX3OmygvtN2nWvGTt7ejsc2LlEgD/nr/+OAnz9y+AP5vYwWWrD8WvBQ4bWQi/vOW4Rf97I6oN0RRRLPDe84PI5C89eX43acW1uv1orS0FCUlJR0zUCpRUlKCzZs392oeTqcTPp8P0dHRAICKigpYLJaQeZrNZhQVFXWa58KFCxETE4MxY8bg5Zdfht/f/XVrj8cDm80WMhBdajq1CjfmxGPC4NhLHmgAIC8tEh89PBHZsUZUt7owc8kmbDrWiE92VWPyf23Ay6vL0ebxIzfVjL8/VIylPy5goKHLhkKhYKChPulTv2NjYyMCgQASEhJCXk9ISMChQ4d6NY8nn3wSycnJwRBjsViC8zh7nu3vAcAvfvELjB07FtHR0di0aROefvpp1NbW4tVXX+1yOQsWLMDvfve7Xq8bkVylx4ThHw9PwE/f2YHSky344Ztbg+8lmfV4YloObs9LuaIvnRIRAZf4ZxIWLlyIZcuWYf369cF7ZXpr7ty5wee5ubnQarV46KGHsGDBAuh0nZP8008/HTKNzWZDWlpa/wtPdAWLMmrxt58W4fHlu/DFPgvCtCr8/IZB+Mmk7Mv2fiYior7qU6iJjY2FSqVCXV1dyOt1dXVITEzscdpXXnkFCxcuxJdffonc3Nzg6+3T1dXVISkpKWSe+fn53c6vqKgIfr8fJ06cQE5OTqf3dTpdl2GH6Gql16iw+IdjselYE3ISwxEXzv2DiOSlTxf5tVotCgoKsHbt2uBrgiBg7dq1KC4u7na6l156Cc899xxWrVqFcePGhbyXlZWFxMTEkHnabDZs3bq1x3nu2rULSqWyy09cEVHXlEoFJg2JZaAhIlnq8+WnuXPnYvbs2Rg3bhwKCwuxaNEiOBwO3H///QCAWbNmISUlBQsWLAAgfVx73rx5eP/995GZmRm8T8ZkMsFkMkGhUGDOnDl4/vnnMWTIkOBHupOTkzFjxgwAwObNm7F161bceOONCA8Px+bNm/H444/jRz/6EaKioi5QVRAREdGVrM+h5q677kJDQwPmzZsHi8WC/Px8rFq1Knijb2VlJZTKjg6gJUuWwOv14s477wyZz/z58/Hss88CAJ544gk4HA48+OCDaG1txaRJk7Bq1argfTc6nQ7Lli3Ds88+C4/Hg6ysLDz++OMh98wQERHR1Y0/k0BERESXrYv2PTVERERElyuGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKSBYYaIiIikgWGGiIiIpIFhhoiIiKShX6FmsWLFyMzMxN6vR5FRUXYtm1bt+O++eabuPbaaxEVFYWoqCiUlJR0Gl8URcybNw9JSUkwGAwoKSnBkSNHQsZpbm7Gvffei4iICERGRuInP/kJ2tra+lN8IiIikqE+h5rly5dj7ty5mD9/Pnbu3Im8vDxMnToV9fX1XY6/fv163HPPPVi3bh02b96MtLQ0TJkyBdXV1cFxXnrpJbz22mtYunQptm7dCqPRiKlTp8LtdgfHuffee7F//36sWbMGn3/+Ob7++ms8+OCD/VhlIiIikiWxjwoLC8VHHnkk+HcgEBCTk5PFBQsW9Gp6v98vhoeHi2+//bYoiqIoCIKYmJgovvzyy8FxWltbRZ1OJ37wwQeiKIrigQMHRADi9u3bg+N88cUXokKhEKurq3u1XKvVKgIQrVZrr8YnIiKigdeX43efemq8Xi9KS0tRUlISfE2pVKKkpASbN2/u1TycTid8Ph+io6MBABUVFbBYLCHzNJvNKCoqCs5z8+bNiIyMxLhx44LjlJSUQKlUYuvWrV0ux+PxwGazhQxEREQkX30KNY2NjQgEAkhISAh5PSEhARaLpVfzePLJJ5GcnBwMMe3T9TRPi8WC+Pj4kPfVajWio6O7Xe6CBQtgNpuDQ1paWq/KR0RERFemS/rpp4ULF2LZsmVYuXIl9Hr9RV3W008/DavVGhxOnTp1UZdHREREA0vdl5FjY2OhUqlQV1cX8npdXR0SExN7nPaVV17BwoUL8eWXXyI3Nzf4evt0dXV1SEpKCplnfn5+cJyzb0T2+/1obm7udrk6nQ46na7X60ZERERXtj711Gi1WhQUFGDt2rXB1wRBwNq1a1FcXNztdC+99BKee+45rFq1KuS+GADIyspCYmJiyDxtNhu2bt0anGdxcTFaW1tRWloaHOerr76CIAgoKirqyyoQERGRTPWppwYA5s6di9mzZ2PcuHEoLCzEokWL4HA4cP/99wMAZs2ahZSUFCxYsAAA8OKLL2LevHl4//33kZmZGbwHxmQywWQyQaFQYM6cOXj++ecxZMgQZGVl4ZlnnkFycjJmzJgBABg+fDimTZuGBx54AEuXLoXP58Ojjz6Ku+++G8nJyReoKoiIiOhK1udQc9ddd6GhoQHz5s2DxWJBfn4+Vq1aFbzRt7KyEkplRwfQkiVL4PV6ceedd4bMZ/78+Xj22WcBAE888QQcDgcefPBBtLa2YtKkSVi1alXIfTd/+9vf8Oijj2Ly5MlQKpWYOXMmXnvttf6sMxEREcmQQhRFcaALcSnYbDaYzWZYrVZEREQMdHGIiIioF/py/OZvPxEREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEs9CvULF68GJmZmdDr9SgqKsK2bdu6HXf//v2YOXMmMjMzoVAosGjRok7j2O12zJkzBxkZGTAYDJgwYQK2b98eMs59990HhUIRMkybNq0/xSciIiIZ6nOoWb58OebOnYv58+dj586dyMvLw9SpU1FfX9/l+E6nE9nZ2Vi4cCESExO7HOenP/0p1qxZg3fffRd79+7FlClTUFJSgurq6pDxpk2bhtra2uDwwQcf9LX4REREJFMKURTFvkxQVFSE8ePH44033gAACIKAtLQ0PPbYY3jqqad6nDYzMxNz5szBnDlzgq+5XC6Eh4fjk08+wa233hp8vaCgANOnT8fzzz8PQOqpaW1t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RD0QERHRFa7Poeauu+5CQ0MD5s2bB4vFgvz8fKxatSp4E29lZWXIvTA1NTUYM2ZM8O9XXnkFr7zyCq6//nqsX78egPTx7KeffhpVVVWIjo7GzJkz8cILL0Cj0QSne+KJJ+BwOPDggw+itbUVkyZNwqpVqzp9aoqIiIiuTn3+nporFb+nhoiI6Mpz0b6nhoiIiOhyxVBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQ0RERLLAUENERESywFBDREREssBQQwQAPjfw1fPAHycAu5cPdGmIiHomikDlVuD4BsDvHejSXDbUA10Aon5xtQBCADBEA8rzzOYnNgKf/RJoOir9vfJB4Oga4Nb/AvTm8y+rnNlqgUOfAwc+ARyNQMpYIHU8kFYExA07///N5cTVClj2AvHDAWPshZlnywng8GrA0SBtz6LQxSACCgUAhfSoOF2nCgWgCQMi008PGUBECqA6j2bd5wYay4GAD1CqAKUaUJx+VKqkISIFUGkuxNpfntxWIOAHjDEDXZKueezA7mXAtjel/xUgtVNDpwMjvgsMugnQGPo//0P/Ana/D5jTgfQiaV8OT7wwZb8EFKIoigNdiEvBZrPBbDbDarUiIiJioItzcYgi0HgEqN0NJI4G4ocNdInOnygCdgtg2SOtV+1uoHYPYK2U3ldqpB3OlCA9hicB4QlAzGAg+wbAENX9vF0twL+fAcrelf42JQLDbgVK3wLEgLRTz3wTSL/mYq/lpdN0DDjwMRAWA6SMkw7QSlXf5mGtBg5+KgWZyi0AumlCdBFA6jipUUwdLwWenv4fl6vGo8DWpcCu9wGfQ3otdiiQXgxkTJAeI9NPB49zEEUpGB36pzTU7b2wZVWcDh1RGR1BJzK94+/wpI7/txAAGg8D1TuB6lJpqNsHCP6el2GIAkbMAEbfCaRPuHTBVRSBtjpp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+vXrxdra2uDgdDqD4/zsZz8T09PTxa+++krcsWOHWFxcLBYXFw9gqS+dp556StywYYNYUVEh7tmzR3zqqadEhUIh/vvf/xZF8equm66c+eknUby66+dXv/qVuH79erGiokL89ttvxZKSEjE2Nlasr68XRfHqrhtRFMVt27aJarVafOGFF8QjR46If/vb38SwsDDxvffeC44jt7aZoeY8vf7662J6erqo1WrFwsJCccuWLQNdpAGxbt06EUCnYfbs2aIoSh8dfOaZZ8SEhARRp9OJkydPFsvLywe20JdIV/UCQPzrX/8aHMflcok///nPxaioKDEsLEz83ve+J9bW1g5coS+h//iP/xAzMjJErVYrxsXFiZMnTw4GGlG8uuumK2eHmqu5fu666y4xKSlJ1Gq1YkpKinjXXXeJR48eDb5/NddNu88++0wcNWqUqNPpxGHDhol//vOfQ96XW9usEEVRHJg+IiIiIqILh/fUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNQQERGRLPx/1nDHLdGwXkEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6e1fd5a-508d-4b7d-a4a5-e1ea000b9547",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.130 (avg p value 0.352299)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[0]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.151 (avg p value 0.318346)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[1]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f2f44265-e343-4000-9a48-454971ff77dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.163 (avg p value 0.296444)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[2]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "af35be81-8658-4113-b6bc-dd2e4bb8cecd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.168 (avg p value 0.287105)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[3]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.277 (avg p value 0.138068)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[4]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "756e9775-9aeb-4960-b0f5-06e22909e7af",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.291 (avg p value 0.129480)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[5]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "61237f3a-2fa2-404e-adce-c0009fd3eab8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.300 (avg p value 0.117583)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[6]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3bad74a0-112e-4d74-935a-2f7adff4c100",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.305 (avg p value 0.111391)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[7]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "54b41d0d-ace5-4034-bcf4-b6d71dcd53cb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.285 (avg p value 0.116707)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[8]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "db5094d2-612c-475d-8be8-9f78f35e88f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.316 (avg p value 0.080018)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[9]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "c4f4fb67-378a-48d9-a72b-93e9eafddf13",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.332 (avg p value 0.069342)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[10]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "4e488bf3-3897-42c5-9830-eccf3f179bc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.343 (avg p value 0.060725)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[11]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "a406269b-6798-44b1-8128-529af1e0b325",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.323 (avg p value 0.096916)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[12]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "8558372b-4690-4434-9681-564360e05e57",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.334 (avg p value 0.087169)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[13]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "f292aeda-6139-4e84-9fa1-a05c78fc5df0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.342 (avg p value 0.082819)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[14]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "31ed11b7-94b3-4974-af02-78f26c8cbb59",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.346 (avg p value 0.077644)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[15]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b41d9ec2-1015-45a4-aab0-0e1176468e4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "804db34c-93e3-4ffc-adf5-bc2e69a1b7f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40061fae-1a40-4778-aed5-1533dae02aa6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "01cd2c1f-b213-46f1-9bf0-68eac5add620",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from scipy.stats import bootstrap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.11903623554113091, high=0.1350936859437356)\n",
      "0.119\n",
      "0.135\n",
      "1\n",
      "ConfidenceInterval(low=0.14199899937039331, high=0.157461594609298)\n",
      "0.142\n",
      "0.157\n",
      "2\n",
      "ConfidenceInterval(low=0.15277242963761678, high=0.1690269493947238)\n",
      "0.153\n",
      "0.169\n",
      "3\n",
      "ConfidenceInterval(low=0.15821200034015145, high=0.1747414719427658)\n",
      "0.158\n",
      "0.175\n",
      "4\n",
      "ConfidenceInterval(low=0.27062613164271787, high=0.2817498648152913)\n",
      "0.271\n",
      "0.282\n",
      "5\n",
      "ConfidenceInterval(low=0.2846459828857046, high=0.29523000709287184)\n",
      "0.285\n",
      "0.295\n",
      "6\n",
      "ConfidenceInterval(low=0.2939174450970467, high=0.3056621821983593)\n",
      "0.294\n",
      "0.306\n",
      "7\n",
      "ConfidenceInterval(low=0.29858275195105716, high=0.3096989161248146)\n",
      "0.299\n",
      "0.31\n",
      "8\n",
      "ConfidenceInterval(low=0.2815093921383737, high=0.29160618785681564)\n",
      "0.282\n",
      "0.292\n",
      "9\n",
      "ConfidenceInterval(low=0.3113380449888292, high=0.32047136194473375)\n",
      "0.311\n",
      "0.32\n",
      "10\n",
      "ConfidenceInterval(low=0.3289988165656223, high=0.33580696756649414)\n",
      "0.329\n",
      "0.336\n",
      "11\n",
      "ConfidenceInterval(low=0.3391101146481287, high=0.3467058393935972)\n",
      "0.339\n",
      "0.347\n",
      "12\n",
      "ConfidenceInterval(low=0.32149341105675605, high=0.32626243980451736)\n",
      "0.321\n",
      "0.326\n",
      "13\n",
      "ConfidenceInterval(low=0.3292248117185897, high=0.3380564222710303)\n",
      "0.329\n",
      "0.338\n",
      "14\n",
      "ConfidenceInterval(low=0.3377220282237006, high=0.3458089065284008)\n",
      "0.338\n",
      "0.346\n",
      "15\n",
      "ConfidenceInterval(low=0.3426134266206162, high=0.3496413910705428)\n",
      "0.343\n",
      "0.35\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(16):\n",
    "    print(i)\n",
    "    def my_statistics(data):\n",
    "        # print(data)\n",
    "        # print(len(data))\n",
    "        margins = lds_testset_correctness[data]\n",
    "        infl_est_ = -scores_list[i]\n",
    "        # infl_est_ = -tmp\n",
    "        preds = lds_mask_array[data] @ infl_est_.T\n",
    "        ####\n",
    "        rs = []\n",
    "        ps = []\n",
    "        for ind in range(1000):\n",
    "            r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "            # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "            rs.append(r)\n",
    "            ps.append(p)\n",
    "        \n",
    "        rs, ps = np.array(rs), np.array(ps)\n",
    "        # print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    \n",
    "        return rs.mean()     \n",
    "\n",
    "    data = (list(range(64)), )  # samples must be in a sequence\n",
    "    res = bootstrap(data, my_statistics, \n",
    "                    n_resamples=64, # 够了估计\n",
    "                    batch=128,\n",
    "                    confidence_level=0.95,\n",
    "                    random_state=42)\n",
    "\n",
    "    print(res.confidence_interval)\n",
    "    \n",
    "    print(res.confidence_interval.low.round(3))\n",
    "    print(res.confidence_interval.high.round(3))\n",
    "\n",
    "    res_list.append(res)\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58f45d33-6d43-4367-8710-70132dbdf5b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7793c07e-c75c-48ca-a173-a9831391a624",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "9a7aacf8-41cf-4e6d-a038-17a1423ebd46",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"./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": 34,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA1TElEQVR4nO3dd3hUZf7//9eQRkISQkkoKyRIUwhForAsKFUCBJf6WQtKFRsISlFYVyFSgosiVlgVAjZAXKJcIgpSbLAiHSw0CSAEggpJaCHl/v3BL/NlTIBMmDB3wvNxXXPBnHOf+7zvOXOYF6fMOIwxRgAAABYq4+0CAAAALoagAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACoESbO3euHA6HkpOTi31dAwYMUFRUlPN5cnKyHA6Hnn/++WJftyRNmDBBDofjqqwLsAVBBSiCvA/HCx8RERFq166dli1bVuzrf/311zV37twiLfvpp59qwoQJHq3HU9asWePymgYEBKhKlSpq27atpkyZomPHjnlkPadPn9aECRO0Zs0aj/TnSTbXBngDQQW4As8++6zeeecdvf3223riiSd07Ngxde3aVZ988kmxrvdKg0p8fLxnC/Kw4cOH65133tEbb7yhMWPGqGLFiho/frxuvPFGrVq1yqXtfffdpzNnzigyMrLQ/Z8+fVrx8fFuh4E333xTO3fudGsZd12qtn/96186c+ZMsa4fsI2vtwsASrIuXbro5ptvdj4fPHiwqlSpovnz56tbt25erMwzsrOzlZubK39//6u63ltvvVV9+vRxmbZ161Z16tRJvXv31o8//qhq1apJknx8fOTj41Os9Zw6dUrlypWTn59fsa7ncnx9feXryz/buLZwRAXwoLCwMAUGBub7MDl16pRGjRqlGjVqKCAgQPXr19fzzz+vP/94eXZ2tiZOnKjatWsrICBAUVFR+uc//6nMzExnm6ioKP3www/68ssvnadI2rZtK0nKyspSfHy86tatq7Jly6pSpUpq3bq1VqxYIen8NRavvfaaJLmcYpFcr7eYMWOGs4Yff/xR586d0zPPPKOYmBiVL19e5cqV06233qrVq1e71H9hHy+++KIiIyMVGBioNm3aaMeOHVf02jZp0kQzZszQiRMn9OqrrzqnF3SNyoYNGxQbG6vKlSsrMDBQtWrV0qBBg5w1hoeHS5Li4+Odr0He6bABAwYoODhYe/fuVdeuXRUSEqK+ffs65114jcqFLjfetm3bOrfThS7s83K1FXSNSmHeM9L59023bt30zTffqHnz5ipbtqyuv/56vf322wW/4IAliObAFUhLS9Nvv/0mY4xSU1P1yiuv6OTJk7r33nudbYwx+vvf/67Vq1dr8ODBatq0qT7//HONGTNGhw4d0osvvuhse//992vevHnq06ePRo0ape+++04JCQn66aeflJSUJEmaMWOGHn30UQUHB+upp56SJFWpUkXS+Q+yhIQE3X///WrevLnS09O1YcMGbdq0SbfffrsefPBBHT58WCtWrNA777xT4JgSExN19uxZPfDAAwoICFDFihWVnp6ut956S3fffbeGDBmijIwMzZ49W7GxsVq/fr2aNm3q0sfbb7+tjIwMDR06VGfPntVLL72k9u3ba/v27c5ai6JPnz4aPHiwli9frsmTJxfYJjU1VZ06dVJ4eLjGjh2rsLAwJScna/HixZKk8PBwzZw5Uw8//LB69uypXr16SZIaN27s7CM7O1uxsbFq3bq1nn/+eQUFBV2yLk+NtzC1/Vlh3jN59uzZ43wN+/fvrzlz5mjAgAGKiYlRw4YNC10ncFUZAG5LTEw0kvI9AgICzNy5c13afvTRR0aSmTRpksv0Pn36GIfDYfbs2WOMMWbLli1Gkrn//vtd2o0ePdpIMqtWrXJOa9iwoWnTpk2+upo0aWLi4uIuWfvQoUNNQbv+vn37jCQTGhpqUlNTXeZlZ2ebzMxMl2nHjx83VapUMYMGDcrXR2BgoPn111+d07/77jsjyTz++OOXrG316tVGklm0aNFF2zRp0sRUqFDB+TxvW+zbt88YY0xSUpKRZL7//vuL9nHs2DEjyYwfPz7fvP79+xtJZuzYsQXOi4yMdD53Z7xt2rQpcJv9uc9L1TZ+/HiXbefOeyYyMtJIMl999ZVzWmpqqgkICDCjRo3Kty7AFpz6Aa7Aa6+9phUrVmjFihV699131a5dO91///3O/71L5y9e9fHx0fDhw12WHTVqlIwxzruEPv30U0nSyJEj87WTpKVLl162nrCwMP3www/avXt3kcfUu3dv5+mHPD4+Ps7rVHJzc/XHH38oOztbN998szZt2pSvjx49eugvf/mL83nz5s3V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dHe7BwAAcHI7qGzevFmbN29WVlaW6tevL0natWuXfHx81KxZM2c7h8PhuSoBAMA1ye2gcscddygkJETz5s1ThQoVJJ3/EriBAwfq1ltv1ahRozxeJAAAuDa5fY3KCy+8oISEBGdIkaQKFSpo0qRJ3PUDAAA8yu2gkp6ermPHjuWbfuzYMWVkZHikKAAAAKkIQaVnz54aOHCgFi9erF9//VW//vqr/vvf/2rw4MHq1atXcdQIAACuUW5fozJr1iyNHj1a99xzj7Kyss534uurwYMHa9q0aR4vEAAAXLvcDipBQUF6/fXXNW3aNO3du1eSVLt2bZUrV87jxQEAgGtbkb/wLSUlRSkpKapbt67KlSsnY4wn6wIAAHA/qPz+++/q0KGD6tWrp65duyolJUWSNHjwYG5NBgAAHuV2UHn88cfl5+enAwcOKCgoyDn9zjvv1GeffebR4gAAwLXN7WtUli9frs8//1zXXXedy/S6detq//79HisMAADA7SMqp06dcjmSkuePP/5QQECAR4oCAACQihBUbr31Vr399tvO5w6HQ7m5ufr3v/+tdu3aebQ4AABwbXM7qPz73//WG2+8oS5duujcuXN64oknFB0dra+++krPPfdckQuZOnWqHA6HHnvssSL3AQAAShe3g0p0dLR27dql1q1bq3v37jp16pR69eqlzZs3q3bt2kUq4vvvv9d//vMfNW7cuEjLAwCA0smti2mzsrLUuXNnzZo1S0899ZRHCjh58qT69u2rN998U5MmTfJInwAAoHRw64iKn5+ftm3b5tEChg4dqri4OHXs2PGybTMzM5Wenu7yAAAApZfbtyffe++9mj17tqZOnXrFK1+wYIE2bdqk77//vlDtExISFB8ff8XrBa6GqLFLPdJP8tQ4j/QDACWR20ElOztbc+bM0RdffKGYmJh8v/Ezffr0QvVz8OBBjRgxQitWrFDZsmULtcy4ceM0cuRI5/P09HTVqFGj8MUDAIASpVBBZdu2bYqOjlaZMmW0Y8cONWvWTJK0a9cul3YOh6PQK964caNSU1OdfUlSTk6OvvrqK7366qvKzMyUj4+PyzIBAQF8VwsAANeQQgWVm266SSkpKYqIiND+/fv1/fffq1KlSle04g4dOmj79u0u0wYOHKgbbrhBTz75ZL6QAgAArj2FCiphYWHat2+fIiIilJycrNzc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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
}
