{
 "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(\"gen_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(\"gen_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-{}-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": 11,
   "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": 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": "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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": 15,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.094 (avg p value 0.414661)\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.113 (avg p value 0.386169)\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.123 (avg p value 0.367040)\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.130 (avg p value 0.362335)\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.238 (avg p value 0.187379)\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": "f4cc9579-6888-481d-9941-3a219b5284cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.245 (avg p value 0.183113)\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": "b9c037e5-8233-44ff-be88-96f4d1424d59",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.252 (avg p value 0.172228)\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": "e998faa6-70a7-46ee-a46f-1e0918d80d82",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.254 (avg p value 0.166220)\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": "cba1055c-6d38-4e48-84e0-85e7e2389449",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.216 (avg p value 0.210240)\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": "5d9e1463-efd9-4969-af6f-f21ad2b8899a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.245 (avg p value 0.168037)\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": "e48cfc55-8a8a-4efd-8d2c-b1a03fd69ddc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.260 (avg p value 0.147108)\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": "fa26af50-573e-41c5-b040-58694269bf28",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.269 (avg p value 0.136560)\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": "ef08a60a-f7fe-4531-9d02-4211119b3ed6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.261 (avg p value 0.154939)\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": "fcea9427-8772-4f74-ac47-afaa08e78bd0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.268 (avg p value 0.146357)\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": "545f9b19-09b4-46a9-ae2e-01fd1a87c807",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.273 (avg p value 0.141949)\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": "1c64d23c-2c01-424c-8e1a-19be85865489",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.276 (avg p value 0.137394)\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": "78616ebd-96c3-4bd3-ba86-d15900a7e24e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb721273-04ef-4bac-8ad0-eec66c132a05",
   "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.08687410712870097, high=0.10642504441687878)\n",
      "0.087\n",
      "0.106\n",
      "1\n",
      "ConfidenceInterval(low=0.10676130210150345, high=0.1251168957276106)\n",
      "0.107\n",
      "0.125\n",
      "2\n",
      "ConfidenceInterval(low=0.1140996955196553, high=0.13371902599601232)\n",
      "0.114\n",
      "0.134\n",
      "3\n",
      "ConfidenceInterval(low=0.12110946806820062, high=0.1444899006087926)\n",
      "0.121\n",
      "0.144\n",
      "4\n",
      "ConfidenceInterval(low=0.22988487456365617, high=0.24805465500243626)\n",
      "0.23\n",
      "0.248\n",
      "5\n",
      "ConfidenceInterval(low=0.23505350718206056, high=0.2549872681459642)\n",
      "0.235\n",
      "0.255\n",
      "6\n",
      "ConfidenceInterval(low=0.2408969596199495, high=0.2611950498988063)\n",
      "0.241\n",
      "0.261\n",
      "7\n",
      "ConfidenceInterval(low=0.24346257145617156, high=0.26539375543815935)\n",
      "0.243\n",
      "0.265\n",
      "8\n",
      "ConfidenceInterval(low=0.20877075917605706, high=0.24099701438557958)\n",
      "0.209\n",
      "0.241\n",
      "9\n",
      "ConfidenceInterval(low=0.23377082388626488, high=0.26570367542822787)\n",
      "0.234\n",
      "0.266\n",
      "10\n",
      "ConfidenceInterval(low=0.24920709543715663, high=0.27808702271367575)\n",
      "0.249\n",
      "0.278\n",
      "11\n",
      "ConfidenceInterval(low=0.260133628902493, high=0.2878287738874308)\n",
      "0.26\n",
      "0.288\n",
      "12\n",
      "ConfidenceInterval(low=0.24987504093316357, high=0.2720493933933215)\n",
      "0.25\n",
      "0.272\n",
      "13\n",
      "ConfidenceInterval(low=0.2573385435057421, high=0.279145818465881)\n",
      "0.257\n",
      "0.279\n",
      "14\n",
      "ConfidenceInterval(low=0.2618034586623228, high=0.2840138622195398)\n",
      "0.262\n",
      "0.284\n",
      "15\n",
      "ConfidenceInterval(low=0.26374511816716417, high=0.2860509248239499)\n",
      "0.264\n",
      "0.286\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(\"./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": 34,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0csvv6yjR4+qY8eOWrNmjebMmaMbbrhBnTt39u43MTFRM2fO1OOPP6769esrJiZGXbp0UePGjdWpUyclJiaqSpUqSk9P19tvv61Ro0b5bCud+fTXpKQkBQUF6e9///sFj7NPnz5atGiR+vXrp969e2vXrl2aNWuWGjduXOjllPr166t9+/b6xz/+IY/Ho+nTp6tq1ap64IEHijSuX3zxhU6ePKm8vDz98ssvWrVqlZYsWaJKlSpp8eLFqlGjxnm3nTNnjl588UX169dP9erV07Fjx/TKK68oMjLS+4s9LCxMjRs31vz589WwYUNVqVJFTZs2VdOmTYtUX3GOd9iwYZo2bZqSkpI0fPhwHTp0SLNmzVKTJk2UnZ3tbedPbf7MGaDUcvahI6B0Kuzx5PLly5uWLVuamTNnmvz8fJ/2x44dM/fdd5+Ji4szISEhpkGDBmbq1KkF2uXm5prk5GRTp04dExISYmrVqmXGjx9vTp486dPuwIEDpnfv3iYiIsJI8j72+vjjj5s2bdqYqKgoExYWZq644gozadIkc+rUKe+2p0+fNnfffbeJjo42LpfL+7jr2Udtp06dWuB48/PzzeTJk018fLxxu93mqquuMu+99955H9edOnWqefrpp02tWrWM2+02HTp0MBs3bvzDcT37ePLZV0hIiImOjjbXXnutmTRpUoHHps/9WZx9PHndunVm0KBBpnbt2sbtdpuYmBjTp08fk56e7rPdl19+aRITE01oaKjP48BDhgwxFStWLLS+iz3eN954w9StW9eEhoaali1bmo8++qhAnxeq7fePJxtT9DkTHx9f6KPr53tsGrCFyxjuogIQGLt371adOnU0depUjRs3zulyAFwGuEcFAABYi6ACAACsRVABAADW4h4VAABgLc6oAAAAaxFUAACAtUr1B77l5+dr//79ioiICPhHYgMAgJJhjNGxY8cUFxf3h9+rVaqDyv79+1WrVi2nywAAAMWQkZHxh99UXqqDytmves/IyPB+XDkAALBbdna2atWq5f09fiGlOqicvdwTGRlJUAEAoJQpym0b3EwLAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANZyNKgkJCTI5XIVeI0cOdLJsgAAgCUc/a6ftWvXKi8vz7u8efNmXXfddfrr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/fOf/1RsbKymTZumcePGaefOnVq2bJn279+vvn37BrJOAABQBgX7u8G0adOUmpqqrVu3qlevXnr99dfVq1cvlSt3JvPUqVNHaWlpSkhICHStAACgjPE7qMycOVPDhg3T0KFDFRsbW2ibmJgYvfbaaxddHAAAKNv8Dirbt2//wzahoaEaMmRIsQoCAAA4y+97VFJTU7Vw4cIC6xcuXKg5c+YEpCgAAACpGEElJSVF1apVK7A+JiZGkydPDkhRAAAAUjGCyp49e1SnTp0C6+Pj47Vnz56AFAUAACAVI6jExMRo06ZNBdZv3LhRVatWLXYhU6ZMkcvl0r333lvsPgAAwOXF76AyaNAg3XPPPVqxYoXy8vKUl5enTz/9VKNHj9bf//73YhWxdu1avfTSS2revHmxtgcAAJcnv4PKY489prZt26pr164KCwtTWFiYunfvri5duhTrHpWcnBwNHjxYr7zyiipXruz39gAA4PLld1AJDQ3V/PnztWXLFr355ptatGiRdu7cqdmzZys0NNTvAkaOHKnevXurW7dufm8LAAAub35/jspZDRs2VMOGDS9q5/PmzdO6deu0du3aIrX3eDzyeDze5ezs7IvaPwAAsJvfQSUvL09paWlavny5Dh06pPz8fJ/3P/300yL1k5GRodGjR2vZsmUqX758kbZJSUlRcnKyvyUDpVrCQ0udLqFMsG2cd0/p7XQJgBX8DiqjR49WWlqaevfuraZNm8rlchVrx998840OHTqkVq1aedfl5eXp888/1/PPPy+Px6OgoCCfbcaPH68xY8Z4l7Ozs1WrVq1i7R8AANjP76Ayb948LViwQL169bqoHXft2lXffvutz7rbbrtNV1xxhR588MECIUWS3G633G73Re0XAACUHn4HldDQUNWvX/+idxwREaGmTZv6rKtYsaKqVq1aYD0AACib/H7qZ+zYsXr22WdljCmJegAAALz8PqPyv//9TytWrNAHH3ygJk2aKCQkxOf9RYsWFbuYlStXFntbAABw+fE7qERFRalfv34lUQsAAIAPv4NKampqSdQBAABQgN/3qEjS6dOn9cknn+ill17SsWPHJEn79+9XTk5OQIsDAABlm99nVH766Sf16NFDe/bskcfj0XXXXaeIiAg98cQT8ng8mjVrVknUCQAAyiC/z6iMHj1arVu31pEjRxQWFuZd369f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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
}
