{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7d607888-e92d-4720-b28e-43d8ce2c643a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c9bb7deb-4dbb-4100-a5c6-1ab11c826833",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f37c6eff-445d-4007-9951-fdba0c6b46d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7499a23a-7876-4670-ae09-c4de570791e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/5000-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "scores_list = []\n",
    "with open(\"gen_dot.pkl\", 'rb') as handle:\n",
    "    tmp = pickle.load(handle)\n",
    "scores_list.append(tmp[0][-1])\n",
    "scores_list.append(tmp[1][-1])\n",
    "scores_list.append(np.stack(tmp[0])[1:].mean(axis=0))\n",
    "scores_list.append(np.stack(tmp[1])[1:].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1839bf2e-c9a2-4ada-a3c9-f56e2c0c9939",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"gen_cos.pkl\", 'rb') as handle:\n",
    "    tmp = pickle.load(handle)\n",
    "scores_list.append(tmp[0][-1])\n",
    "scores_list.append(tmp[1][-1])\n",
    "scores_list.append(np.stack(tmp[0])[1:].mean(axis=0))\n",
    "scores_list.append(np.stack(tmp[1])[1:].mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9d29e95-b825-4bec-9957-676824892c52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "17304aaf-68b6-4349-b923-b458ddca5939",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "my_list = [\n",
    "    0,1,2,3,\n",
    "    4,5,6,7,\n",
    "    8,9,10,11,\n",
    "    12,13,14,15,\n",
    "    16,17,18,19,\n",
    "    20,21,22,23,\n",
    "    24,25,26,27,\n",
    "    28,29,30,31,\n",
    "    32,33,34,35,\n",
    "    36,37,38,39,\n",
    "    40,41,42,43,\n",
    "    44,45,46,47,\n",
    "    48,49,50,51,\n",
    "    52,53,54,55,\n",
    "    56,57,58,59,\n",
    "    60,61,62,63,\n",
    "          ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/sd-lora-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4214c4b5-d74f-4e52-8c45-1f20ea8d4b38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8d0f643-d0aa-433d-8586-e75351bdd70f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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JIwIIYQQIqLadRh58cUX6dy5M06nk1GjRrFq1apIN6nNmDFjBiNGjCAmJobU1FSuvvpqdu7c2aCMx+PhzjvvJCkpiejoaK699loKCgoalMnJyWHy5Mm43W5SU1P5zW9+QyAQOJ0fpU154okn0DSNe+65J7RNrvPJc/jwYW666SaSkpJwuVwMGDCANWvWhPYrpXj44YfJyMjA5XIxYcIEdu/e3eAYpaWlTJ06ldjYWOLj47ntttuorq4+3R/ljGUYBg899BBdunTB5XLRrVs3/vjHPzZYu0Su87ezePFirrjiCjIzM9E0jQ8//LDB/pN1XTdt2sQ555yD0+kkOzubp5566rs3XrVT77zzjrLb7eq1115TW7duVbfffruKj49XBQUFkW5am3DppZeq119/XW3ZskVt2LBBTZo0SXXs2FFVV1eHytxxxx0qOztbzZs3T61Zs0aNHj1ajR07NrQ/EAio/v37qwkTJqj169erzz//XCUnJ6sHHnggEh/pjLdq1SrVuXNnNXDgQHX33XeHtst1PjlKS0tVp06d1C233KJWrlyp9u3bp7788ku1Z8+eUJknnnhCxcXFqQ8//FBt3LhRXXnllapLly6qrq4uVOayyy5TgwYNUitWrFBLlixR3bt3VzfeeGMkPtIZ6bHHHlNJSUnq008/Vfv371ezZ89W0dHR6s9//nOojFznb+fzzz9XDz74oHr//fcVoD744IMG+0/Gda2oqFBpaWlq6tSpasuWLertt99WLpdL/e1vf/tObW+3YWTkyJHqzjvvDL03DENlZmaqGTNmRLBVbVdhYaEC1KJFi5RSSpWXlyubzaZmz54dKrN9+3YFqOXLlyulgv/H0XVd5efnh8q8/PLLKjY2Vnm93tP7Ac5wVVVVqkePHmru3LnqvPPOC4URuc4nz3333afGjx/f5H7TNFV6erp6+umnQ9vKy8uVw+FQb7/9tlJKqW3btilArV69OlTmiy++UJqmqcOHD5+6xrchkydPVj/84Q8bbPve976npk6dqpSS63yyfDOMnKzr+tJLL6mEhIQGfzvuu+8+1atXr+/U3nb5mMbn87F27VomTJgQ2qbrOhMmTGD58uURbFnbVVFRAUBiYiIAa9euxe/3N7jGvXv3pmPHjqFrvHz5cgYMGEBaWlqozKWXXkplZSVbt249ja0/8915551Mnjy5wfUEuc4n08cff8zw4cO5/vrrSU1NZciQIbz66quh/fv37yc/P7/BtY6Li2PUqFENrnV8fDzDhw8PlZkwYQK6rrNy5crT92HOYGPHjmXevHns2rULgI0bN7J06VImTpwIyHU+VU7WdV2+fDnnnnsudrs9VObSSy9l586dlJWVfev2tYmF8k624uJiDMNo8McZIC0tjR07dkSoVW2XaZrcc889jBs3jv79+wOQn5+P3W4nPj6+Qdm0tDTy8/NDZcL9Do7tE0HvvPMO69atY/Xq1Y32yXU+efbt28fLL7/Mvffey29/+1tWr17NL37xC+x2O9OnTw9dq3DX8vhrnZqa2mC/1WolMTFRrvVR999/P5WVlfTu3RuLxYJhGDz22GNMnToVQK7zKXKyrmt+fj5dunRpdIxj+xISEr5V+9plGBEn15133smWLVtYunRppJty1snNzeXuu+9m7ty5OJ3OSDfnrGaaJsOHD+fxxx8HYMiQIWzZsoWZM2cyffr0CLfu7PHuu+/yn//8h7feeot+/fqxYcMG7rnnHjIzM+U6t2Pt8jFNcnIyFoul0YiDgoIC0tPTI9Sqtumuu+7i008/ZcGCBXTo0CG0PT09HZ/PR3l5eYPyx1/j9PT0sL+DY/tE8DFMYWEhQ4cOxWq1YrVaWbRoEX/5y1+wWq2kpaXJdT5JMjIy6Nu3b4Ntffr0IScnB6i/Vs393UhPT6ewsLDB/kAgQGlpqVzro37zm99w//338/3vf58BAwZw880388tf/pIZM2YAcp1PlZN1XU/V35N2GUbsdjvDhg1j3rx5oW2maTJv3jzGjBkTwZa1HUop7rrrLj744APmz5/f6LbdsGHDsNlsDa7xzp07ycnJCV3jMWPGsHnz5gb/8c+dO5fY2NhGXwrt1UUXXcTmzZvZsGFD6Gf48OFMnTo19Fqu88kxbty4RsPTd+3aRadOnQDo0qUL6enpDa51ZWUlK1eubHCty8vLWbt2bajM/PnzMU2TUaNGnYZPcearra1F1xt+9VgsFkzTBOQ6nyon67qOGTOGxYsX4/f7Q2Xmzp1Lr169vvUjGqB9D+11OBzqjTfeUNu2bVM//vGPVXx8fIMRB6JpP/3pT1VcXJxauHChysvLC/3U1taGytxxxx2qY8eOav78+WrNmjVqzJgxasyYMaH9x4acXnLJJWrDhg1qzpw5KiUlRYacnsDxo2mUkut8sqxatUpZrVb12GOPqd27d6v//Oc/yu12q3//+9+hMk888YSKj49XH330kdq0aZO66qqrwg6NHDJkiFq5cqVaunSp6tGjR7sfcnq86dOnq6ysrNDQ3vfff18lJyer//u//wuVkev87VRVVan169er9evXK0A999xzav369ergwYNKqZNzXcvLy1VaWpq6+eab1ZYtW9Q777yj3G63DO39Ll544QXVsWNHZbfb1ciRI9WKFSsi3aQ2Awj78/rrr4fK1NXVqZ/97GcqISFBud1udc0116i8vLwGxzlw4ICaOHGicrlcKjk5Wf3qV79Sfr//NH+atuWbYUSu88nzySefqP79+yuHw6F69+6tXnnllQb7TdNUDz30kEpLS1MOh0NddNFFaufOnQ3KlJSUqBtvvFFFR0er2NhYdeutt6qqqqrT+THOaJWVleruu+9WHTt2VE6nU3Xt2lU9+OCDDYaKynX+dhYsWBD27/L06dOVUifvum7cuFGNHz9eORwOlZWVpZ544onv3HZNqeOmvRNCCCGEOM3aZZ8RIYQQQpw5JIwIIYQQIqIkjAghhBAioiSMCCGEECKiJIwIIYQQIqIkjAghhBAioiSMCCGEECKiJIwIIYQQIqIkjAghhBAioiSMCCGEECKiJIwIIYQQIqIkjAghhBAiov4/qNBiRjcUQvMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/5000-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lds_testset_correctness = lds_loss_array.mean(axis=1)\n",
    "lds_testset_correctness.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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h0qlanbVUUlJSauDgDsiJycHq1evxj333OM0PTg4GBaLBdXV1e1+32eeeQYGg8Fxy8vLO+/yERER0aWrQ6FGq9UiOTkZ6enpjmmCICA9PR1paWnnXZhFixYhMDAQ48ePd5qenJwMjUbj9L6ZmZnIzc1t9X11Oh08PT2dbkRERCRfHRpTAwCzZs3ClClTkJKSgkGDBmHevHmoq6vDtGnTAACTJ09GWFgY5s6dC0Aa+Hv48GHH3wUFBcjIyIC7uzvi4uIcyxUEAYsWLcKUKVOgVjsXy8vLC3fffTdmzZoFX19feHp64pFHHkFaWlq7rnwiIiIi+etwqLn11ltRVlaGOXPmoLi4GElJSVixYoVj8HBubi6UyqYGoMLCQvTv39/x+M0338Sbb76JESNGYN26dY7pq1evRm5uLqZPn97i+77zzjtQKpWYOHEizGYzxo0bhw8++KCjxSciIiKZ6vDv1PxV8XdqiIiI/no67XdqiIiIiC5VDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNUTUNrsNOPQjsOhaYMldgLW+q0tERNQidVcXgIguUeZaIOMrYOsCoDqnafoPACZ9Dih5TtRl7FZgx8dAdS4w+llA69bVJSK6JDDUEMlNXTmQtRaIGw3ofTv++poS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888/BwDHsjvyvnPnzoWXl5fjFhHRvp9/JyIiutD+6oEGADRBQfCdfBc8rrzyogWajura/yfeSBAEDBgwAK+88gr69++P++67D/feey8++uijc17mM888A4PB4Ljl/em3JoiIiEheOhRq/P39oVKpUHLGD3MBQElJCYLP45K0kJAQJCQ4/6vyXr16IbfxCpjTy+7I++p0Onh6ejrdiIiISL46FGq0Wi2Sk5ORfsb/ABIEAenp6UhLSzvnQgwdOhSZmZlO044dO4aoxpHaMTExCA4Odnpfo9GI7du3n9f7EhERkXx0+BeoZs2ahSlTpiAlJQWDBg3CvHnzUFdXh2nTpgEAJk+ejLCwMMydOxeANLj48OHDjr8LCgqQkZEBd3d3xMVJP2P++OOPY8iQIXjllVdwyy23YMeOHVi4cCEWLlwIAFAoFJg5cyZeeukldO/e3XFJd2hoqNOAZSIiIrqMiedg/vz5YmRkpKjVasVBgwaJ27Ztczw3YsQIccqUKY7HJ0+eFAE0u40YMcJpmcuXLxf79Okj6nQ6MT4+Xly4cKHT84IgiM8++6wYFBQk6nQ6cfTo0WJmZma7y2wwGEQAosFgOJePTERERF2gI/U3/00CERERXbI67ZJuIiIioksVQw0RERHJAkMNERERyQJDDREREckCQw0RERHJAkMNERERyQJDDREREclCh39R+K/q9M/xGI3GLi4JERERtdfpers9P6t32YSampoaAEBEREQXl4SIiIg6qqamBl5eXm3Oc9n8orAgCCgsLISHhwcUCsUFXbbRaERERATy8vL4a8V/wnXTNq6ftnH9tI7rpm1cP637q60bURRRU1OD0NBQKJVtj5q5bFpqlEolwsPDO/U9PD09/xIbSFfgumkb10/buH5ax3XTNq6f1v2V1s3ZWmhO40BhIiIikgWGGiIiIpIFhpoLQKfT4bnnnoNOp+vqolxyuG7axvXTNq6f1nHdtI3rp3VyXjeXzUBhIiIikje21BAREZEsMNQQERGRLDDUEBERkSww1BAREZEsMNScpwULFiA6OhouLi5ITU3Fjh07urpIXWLDhg247rrrEBoaCoVCgZ9++snpeVEUMWfOHISEhMDV1RVjxozB8ePHu6awF9ncuXMxcOBAeHh4IDAwEDfeeCMyMzOd5mloaMCMGTPg5+cHd3d3TJw4ESUlJV1U4ovrww8/RL9+/Rw/BJaWlobff//d8fzlvG7+7NVXX4VCocDMmTMd0y7n9fP8889DoVA43eLj4x3PX87r5rSCggLceeed8PPzg6urK/r27Ytdu3Y5npfbsZmh5jwsWbIEs2bNwnPPPYc9e/YgMTER48aNQ2lpaVcX7aKrq6tDYmIiFixY0OLzr7/+Ot577z189NFH2L59O9zc3DBu3Dg0NDRc5JJefOvXr8eMGTOwbds2rFq1ClarFWPHjkVdXZ1jnscffxzLly/H0qVLsX79ehQWFuKmm27qwlJfPOHh4Xj11Vexe/du7Nq1C6NGjcINN9yAQ4cOAbi8182Zdu7cif/85z/o16+f0/TLff307t0bRUVFjtumTZscz13u66aqqgpDhw6FRqPB77//jsOHD+Ott96Cj4+PYx7ZHZtFOmeDBg0SZ8yY4Xhst9vF0NBQce7cuV1Yqq4HQPzxxx8djwVBEIODg8U33njDMa26ulrU6XTi//73vy4oYdcqLS0VAYjr168XRVFaFxqNRly6dKljniNHjogAxK1bt3ZVMbuUj4+P+Mknn3DdNKqpqRG7d+8urlq1ShwxYoT42GOPiaLIbee5554TExMTW3zucl83oiiKTz/9tDhs2LBWn5fjsZktNefIYrFg9+7dGDNmjGOaUqnEmDFjsHXr1i4s2aXn5MmTKC4udlpXXl5eSE1NvSzXlcFgAAD4+voCAHbv3g2r1eq0fuLj4xEZGXnZrR+73Y5vvvkGdXV1SEtL47ppNGPGDIwfP95pPQDcdgDg+PHjCA0NRWxsLO644w7k5uYC4LoBgJ9//hkpKSmYNGkSAgMD0b9/f3z88ceO5+V4bGaoOUfl5eWw2+0ICgpymh4UFITi4uIuKtWl6fT64LqS/lv8zJkzMXToUPTp0weAtH60Wi28vb2d5r2c1s+BAwfg7u4OnU6HBx54AD/++CMSEhK4bgB888032LNnD+bOndvsuct9/aSmpmLx4sVYsWIFPvzwQ5w8eRJXXHEFampqLvt1AwDZ2dn48MMP0b17d6xcuRIPPvggHn30UXz++ecA5Hlsvmz+SzfRpWDGjBk4ePCgU78/AT179kRGRgYMBgO+++47TJkyBevXr+/qYnW5vLw8PPbYY1i1ahVcXFy6ujiXnGuuucbxd79+/ZCamoqoqCh8++23cHV17cKSXRoEQUBKSgpeeeUVAED//v1x8OBBfPTRR5gyZUoXl65zsKXmHPn7+0OlUjUbSV9SUoLg4OAuKtWl6fT6uNzX1cMPP4xffvkFa9euRXh4uGN6cHAwLBYLqqurnea/nNaPVqtFXFwckpOTMXfuXCQmJuLdd9+97NfN7t27UVpaigEDBkCtVkOtVmP9+vV47733oFarERQUdFmvnz/z9vZGjx49cOLEict+2wGAkJAQJCQkOE3r1auXo4tOjsdmhppzpNVqkZycjPT0dMc0QRCQnp6OtLS0LizZpScmJgbBwcFO68poNGL79u2XxboSRREPP/wwfvzxR6xZswYxMTFOzycnJ0Oj0Titn8zMTOTm5l4W66clgiDAbDZf9utm9OjROHDgADIyMhy3lJQU3HHHHY6/L+f182e1tbXIyspCSEjIZb/tAMDQoUOb/XzEsWPHEBUVBUCmx+auHqn8V/bNN9+IOp1OXLx4sXj48GHxvvvuE729vcXi4uKuLtpFV1NTI+7du1fcu3evCEB8++23xb1794o5OTmiKIriq6++Knp7e4vLli0T9+/fL95www1iTEyMWF9f38Ul73wPPvig6OXlJa5bt04sKipy3Ewmk2OeBx54QIyMjBTXrFkj7tq1S0xLSxPT0tK6sNQXz+zZs8X169eLJ0+eFPfv3y/Onj1bVCgU4h9//CGK4uW9blpy5tVPonh5r58nnnhCXLdunXjy5Elx8+bN4pgxY0R/f3+xtLRUFMXLe92Ioiju2LFDVKvV4ssvvyweP35c/Oqrr0S9Xi9++eWXjnnkdmxmqDlP8+fPFyMjI0WtVisOGjRI3LZtW1cXqUusXbtWBNDsNmXKFFEUpUsHn332WTEoKEjU6XTi6NGjxczMzK4t9EXS0noBIC5atMgxT319vfjQQw+JPj4+ol6vF//2t7+JRUVFXVfoi2j69OliVFSUqNVqxYCAAHH06NGOQCOKl/e6acmfQ83lvH5uvfVWMSQkRNRqtWJYWJh46623iidOnHA8fzmvm9OWL18u9unTR9TpdGJ8fLy4cOFCp+fldmxWiKIodk0bEREREdGFwzE1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkCww1REREJAsMNURERCQLDDVEREQkC/8PfmIdJeaFJn0AAAAASUVORK5CYII=",
      "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.041 (avg p value 0.477510)\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": 15,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.104 (avg p value 0.374079)\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": 16,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.065 (avg p value 0.460972)\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": 17,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.141 (avg p value 0.330099)\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": 18,
   "id": "136ac5ce-81a5-4456-aebf-5eed1158aaaa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.046 (avg p value 0.481012)\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": 19,
   "id": "f481d24d-6b79-48cf-b510-73d227870e9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.109 (avg p value 0.383994)\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": 20,
   "id": "46051924-02f0-4caa-8a61-d92257bba123",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.069 (avg p value 0.457001)\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": 21,
   "id": "a18cbd8b-63d3-4f18-adbd-8ca4874e6561",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.145 (avg p value 0.323468)\n"
     ]
    }
   ],
   "source": [
    "# compute lds\n",
    "from scipy.stats import spearmanr, pearsonr\n",
    "####\n",
    "margins = lds_testset_correctness\n",
    "infl_est_ = -scores_list[7]\n",
    "# infl_est_ = -tmp\n",
    "preds = lds_mask_array @ infl_est_.T\n",
    "####\n",
    "rs = []\n",
    "ps = []\n",
    "\n",
    "for ind in range(1000):\n",
    "    r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "    # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "    rs.append(r)\n",
    "    ps.append(p)\n",
    "    \n",
    "rs, ps = np.array(rs), np.array(ps)\n",
    "print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "\n",
    "# tmp_1 = rs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61ecc9f8-634c-4aae-99cc-1a72a5e1bb0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df4b04c8-9f25-467d-bb10-08c17196b973",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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": 23,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.02064860230089236, high=0.06056292640178871)\n",
      "0.021\n",
      "0.061\n",
      "1\n",
      "ConfidenceInterval(low=0.08651008385971454, high=0.12362973845537197)\n",
      "0.087\n",
      "0.124\n",
      "2\n",
      "ConfidenceInterval(low=0.048779718292989, high=0.08127223544696607)\n",
      "0.049\n",
      "0.081\n",
      "3\n",
      "ConfidenceInterval(low=0.1258075495729564, high=0.16037628383271413)\n",
      "0.126\n",
      "0.16\n",
      "4\n",
      "ConfidenceInterval(low=0.027870270712293074, high=0.061676645448772965)\n",
      "0.028\n",
      "0.062\n",
      "5\n",
      "ConfidenceInterval(low=0.09162033569140643, high=0.12822265739211722)\n",
      "0.092\n",
      "0.128\n",
      "6\n",
      "ConfidenceInterval(low=0.054823100200179276, high=0.08526023572145865)\n",
      "0.055\n",
      "0.085\n",
      "7\n",
      "ConfidenceInterval(low=0.12902719860510925, high=0.16290806775331698)\n",
      "0.129\n",
      "0.163\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(8):\n",
    "    print(i)\n",
    "    def my_statistics(data):\n",
    "        # print(data)\n",
    "        # print(len(data))\n",
    "        margins = lds_testset_correctness[data]\n",
    "        infl_est_ = -scores_list[i]\n",
    "        # infl_est_ = -tmp\n",
    "        preds = lds_mask_array[data] @ infl_est_.T\n",
    "        ####\n",
    "        rs = []\n",
    "        ps = []\n",
    "        for ind in range(1000):\n",
    "            r, p = spearmanr(preds[:, ind], margins[:, ind])\n",
    "            # r, p = pearsonr(preds[:, ind], margins[:, ind])\n",
    "            rs.append(r)\n",
    "            ps.append(p)\n",
    "        \n",
    "        rs, ps = np.array(rs), np.array(ps)\n",
    "        # print(f'Correlation: {rs.mean():.3f} (avg p value {ps.mean():.6f})')\n",
    "    \n",
    "        return rs.mean()     \n",
    "\n",
    "    data = (list(range(64)), )  # samples must be in a sequence\n",
    "    res = bootstrap(data, my_statistics, \n",
    "                    n_resamples=64, # 够了估计\n",
    "                    batch=128,\n",
    "                    confidence_level=0.95,\n",
    "                    random_state=42)\n",
    "\n",
    "    print(res.confidence_interval)\n",
    "    \n",
    "    print(res.confidence_interval.low.round(3))\n",
    "    print(res.confidence_interval.high.round(3))\n",
    "\n",
    "    res_list.append(res)\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58f45d33-6d43-4367-8710-70132dbdf5b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7793c07e-c75c-48ca-a173-a9831391a624",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "9a7aacf8-41cf-4e6d-a038-17a1423ebd46",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"./gen_res_list.pkl\", 'wb') as handle:\n",
    "    pickle.dump([[res.confidence_interval.low, res.confidence_interval.high, res.bootstrap_distribution, res.standard_error] for res in res_list],\n",
    "                handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9859c520-7da2-416e-a5c8-05bff6b939d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAy/ElEQVR4nO3de5yN5f7/8fcyh2WMGeMwgwkzzuWckeoROWacSmQnKYdkt/sS5VD51nczO6KUdCSFoRNpUz1SMUTZCENIB6ccBsNIzEHNGDPX7w/b+lnNYJbWsi4zr+fjsR51X+u67/tzrWux3u7DWg5jjBEAAICFSvm7AAAAgAshqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoALiqJSYmyuFwaN++fT7f18CBAxUbG+ta3rdvnxwOh1544QWf71uSxo8fL4fDcUX2BdiCoAJchnMfjuc/oqKi1K5dO33xxRc+3/8bb7yhxMTEy1r3888/1/jx471aj7esWrXK7TV1Op2qXLmy2rZtq2effVbHjh3zyn5+//13jR8/XqtWrfLK9rzJ5toAfyCoAH/Bv/71L73zzjuaN2+eHn/8cR07dkxdu3bVZ5995tP9/tWgkpCQ4N2CvGz48OF65513NHPmTI0ZM0YVKlTQuHHjdN111+mrr75y63v//ffrjz/+UExMTJG3//vvvyshIcHjMPDWW29px44dHq3jqYvV9vTTT+uPP/7w6f4B2wT6uwDgatalSxe1aNHCtTx48GBVrlxZH3zwgbp37+7HyrzjzJkzys/PV3Bw8BXdb+vWrdW7d2+3tq1bt6pTp06666679OOPP6pq1aqSpICAAAUEBPi0nlOnTik0NFRBQUE+3c+lBAYGKjCQv7ZRsnBEBfCiiIgIhYSEFPgwOXXqlEaNGqXq1avL6XSqfv36euGFF/TnHy8/c+aMnnnmGdWuXVtOp1OxsbH63//9X+Xk5Lj6xMbG6ocfftDXX3/tOkXStm1bSVJubq4SEhJUt25dlS5dWhUrVlSrVq2UlJQk6ew1Fq+//rokuZ1ikdyvt5g2bZqrhh9//FGnT5/WP//5T8XFxalcuXIKDQ1V69attXLlSrf6z9/GSy+9pJiYGIWEhKhNmzbavn37X3ptmzZtqmnTpunkyZN67bXXXO2FXaOSnJys+Ph4VapUSSEhIapZs6YeeOABV42RkZGSpISEBNdrcO502MCBA1W2bFnt2bNHXbt2VVhYmPr16+d67vxrVM53qfG2bdvWNU/nO3+bl6qtsGtUivKekc6+b7p3767//Oc/atmypUqXLq1atWpp3rx5hb/ggCWI5sBfkJ6erl9//VXGGKWlpenVV19VVlaW7rvvPlcfY4zuuOMOrVy5UoMHD1azZs20dOlSjRkzRocOHdJLL73k6vvggw9q7ty56t27t0aNGqX169dr0qRJ+umnn7R48WJJ0rRp0/TII4+obNmyeuqppyRJlStXlnT2g2zSpEl68MEH1bJlS2VkZCg5OVmbN2/WbbfdpoceekiHDx9WUlKS3nnnnULHNGfOHGVnZ+vvf/+7nE6nKlSooIyMDL399tvq27evhgwZoszMTM2aNUvx8fHasGGDmjVr5raNefPmKTMzU0OHDlV2drZefvlltW/fXt9//72r1svRu3dvDR48WMuWLdPEiRML7ZOWlqZOnTopMjJSTz75pCIiIrRv3z4tWrRIkhQZGanp06fr4YcfVs+ePdWrVy9JUpMmTVzbOHPmjOLj49WqVSu98MILKlOmzEXr8tZ4i1LbnxXlPXPO7t27Xa/hgAEDNHv2bA0cOFBxcXFq2LBhkesErigDwGNz5swxkgo8nE6nSUxMdOv78ccfG0lmwoQJbu29e/c2DofD7N692xhjzJYtW4wk8+CDD7r1Gz16tJFkvvrqK1dbw4YNTZs2bQrU1bRpU9OtW7eL1j506FBT2B/9vXv3GkkmPDzcpKWluT135swZk5OT49Z24sQJU7lyZfPAAw8U2EZISIg5ePCgq339+vVGknnssccuWtvKlSuNJLNw4cIL9mnatKkpX768a/ncXOzdu9cYY8zixYuNJLNx48YLbuPYsWNGkhk3blyB5wYMGGAkmSeffLLQ52JiYlzLnoy3TZs2hc7Zn7d5sdrGjRvnNneevGdiYmKMJPPNN9+42tLS0ozT6TSjRo0qsC/AFpz6Af6C119/XUlJSUpKStK7776rdu3a6cEHH3T96106e/FqQECAhg8f7rbuqFGjZIxx3SX0+eefS5JGjhxZoJ8kLVmy5JL1RERE6IcfftCuXbsue0x33XWX6/TDOQEBAa7rVPLz8/Xbb7/pzJkzatGihTZv3lxgG3feeaeuueYa13LLli114403usb4V5QtW1aZmZkXfD4iIkKS9Nlnnyk3N/ey9/Pwww8Xua8vx3sxnr5nGjRooNatW7uWIyMjVb9+ff3yyy8+rRP4KwgqwF/QsmVLdezYUR07dlS/fv20ZMkSNWjQQMOGDdPp06clSfv371d0dLTCwsLc1r3uuutcz5/7b6lSpVSnTh23flWqVFFERISr38X861//0smTJ1WvXj01btxYY8aM0bZt2zwaU82aNQttnzt3rpo0aeK69iUyMlJLlixRenp6gb5169Yt0FavXj2vfNdJVlZWgdfyfG3atNFdd92lhIQEVapUST169NCcOXMKXLNxMYGBgapWrVqR+/tyvBfj6XumRo0aBbZRvnx5nThxwqd1An8FQQXwolKlSqldu3ZKTU297KMaf+ULvW699Vbt2bNHs2fPVqNGjfT222+refPmevvtt4u8jZCQkAJt7777rgYOHKjatWtr1qxZ+vLLL5WUlKT27dsrPz//suv1VG5urnbu3Fngg/l8DodDH330kdatW6dhw4bp0KFDeuCBBxQXF6esrKwi7cfpdKpUKe/+9Xihec3Ly/PZtv/sQndHmT9d1A3YhKACeNmZM2ckyfWhGBMTo8OHDxc4XfHzzz+7nj/33/z8/AIB5+jRozp58qTb94Rc7IOpQoUKGjRokD744AOlpKSoSZMmbl/wdjlB6KOPPlKtWrW0aNEi3X///YqPj1fHjh2VnZ1daP/CQtrOnTsveMeMJ3X88ccfio+Pv2Tfm266SRMnTlRycrLee+89/fDDD5o/f76kvxYGC1OU8ZYvX14nT54s0O/PRz08qc2T9wxwtSKoAF6Um5urZcuWKTg42HVqp2vXrsrLy3O7pVY6ezurw+FQly5dXP2ks3f1nG/q1KmSpG7durnaQkNDC/3QO378uNty2bJlVadOHbfTHqGhoZJU6PoXcu5f4uf/y3v9+vVat25dof0//vhjHTp0yLW8YcMGrV+/3jXWy7F161Y9+uijKl++vIYOHXrBfidOnChwhODcXUnnXodzd/F48hpcTFHGW7t2bf38889u3667detWrVmzxm1bntTmyXsGuFpxezLwF3zxxReuIyNpaWl6//33tWvXLj355JMKDw+XJN1+++1q166dnnrqKe3bt09NmzbVsmXL9Mknn+jRRx9V7dq1JZ39npABAwZo5syZOnnypNq0aaMNGzZo7ty5uvPOO9WuXTvXfuPi4jR9+nRNmDBBderUUVRUlNq3b68GDRqobdu2iouLU4UKFZScnKyPPvpIw4YNc1tXOvvtr/Hx8QoICNA999xz0XF2795dixYtUs+ePdWtWzft3btXM2bMUIMGDQo9nVKnTh21atVKDz/8sHJycjRt2jRVrFhRjz/+eJFe19WrVys7O1t5eXk6fvy41qxZo08//VTlypXT4sWLVaVKlQuuO3fuXL3xxhvq2bOnateurczMTL311lsKDw93fbCHhISoQYMGWrBggerVq6cKFSqoUaNGatSoUZHqu5zxPvDAA5o6dari4+M1ePBgpaWlacaMGWrYsKEyMjJc/TypzZP3DHDV8u9NR8DVqbDbk0uXLm2aNWtmpk+fbvLz8936Z2Zmmscee8xER0eboKAgU7duXTNlypQC/XJzc01CQoKpWbOmCQoKMtWrVzdjx4412dnZbv2OHDliunXrZsLCwowk122vEyZMMC1btjQREREmJCTEXHvttWbixInm9OnTrnXPnDljHnnkERMZGWkcDofrdtdzt9pOmTKlwHjz8/PNs88+a2JiYozT6TTXX3+9+eyzzy54u+6UKVPMiy++aKpXr26cTqdp3bq12bp16yVf13O3J597BAUFmcjISHPrrbeaiRMnFrht+vy5OHd78ubNm03fvn1NjRo1jNPpNFFRUaZ79+4mOTnZbb21a9eauLg4Exwc7HY78IABA0xoaGih9f3V8b777rumVq1aJjg42DRr1swsXbq0wDYvVtufb082pujvmZiYmEJvXb/QbdOALRzGcBUVAO/Yt2+fatasqSlTpmj06NH+LgdAMcA1KgAAwFoEFQAAYC2CCgAAsBbXqAAAAGtxRAUAAFiLoAIAAKx1VX/hW35+vg4fPqywsDCvfyU2AADwDWOMMjMzFR0dfcnf1bqqg8rhw4dVvXp1f5cBAAAuQ0pKyiV/qfyqDirnfuo9JSXF9XXlAADAbhkZGapevbrrc/xiruqgcu50T3h4OEEFAICrTFEu2+BiWgAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwlt+DyqFDh3TfffepYsWKCgkJUePGjZWcnOzvsgAAgAX8+ls/J06c0C233KJ27drpiy++UGRk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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
}
