{
 "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(\"val_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(\"val_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": 8,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/5000-0.5/lds-val/ddpm-sub-{}-{}/e-{}-val.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4214c4b5-d74f-4e52-8c45-1f20ea8d4b38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8d0f643-d0aa-433d-8586-e75351bdd70f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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F198Md/5zne49NJLuffee3nuuef44Q9/OLRnIiIiIselQYeRefPmsWvXLm644QZaWlqYOnUqS5cuLU5S3bp1K/Z+Gyydf/753HPPPfzzP/8zX/3qVzn11FP55S9/ecR7jIiIiMiJTdvBi4iIyLA40u/vY2ePaBERESlJCiMiIiISKIURERERCZTCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigjsm79r7Zvn3ZUqlUwJWIiIjIkdr3vf1W+6seF2Gkq6sLgKampoArERERkcHq6uqisrLykM8fF9vBe57Hjh07KC8vx7KsIXvfVCpFU1MT27Zt0zbzw0zXemToOo8MXeeRoes8cobrWhtj6OrqYuzYsQPuW/dmx0XPiG3bjBs3btjev6KiQv+ijxBd65Gh6zwydJ1Hhq7zyBmOa324HpF9NIFVREREAqUwIiIiIoEq6TASjUa58cYbiUajQZdywtO1Hhm6ziND13lk6DqPnKCv9XExgVVEREROXCXdMyIiIiLBUxgRERGRQCmMiIiISKAURkRERCRQCiMiIiISqJIOI7fffjvNzc3EYjFmzZrFihUrgi7puLFo0SLOPfdcysvLqaur4yMf+Qjr168f0CadTnPVVVcxatQokskkH/vYx2htbR3QZuvWrVx66aUkEgnq6ur48pe/TD6fH8lTOa7cdNNNWJbFF7/4xeIxXeehs337dj71qU8xatQo4vE4Z599Ns8991zxeWMMN9xwA2PGjCEejzNnzhxeffXVAe+xZ88eLrvsMioqKqiqquJv/uZv6O7uHulTOWa5rsv111/PSSedRDweZ+LEiXzjG98YcCM1Xeej88c//pEPfvCDjB07Fsuy+OUvfzng+aG6ri+++CIXXnghsViMpqYm/u3f/u3tF29K1L333msikYi58847zUsvvWSuvPJKU1VVZVpbW4Mu7bgwd+5cc9ddd5m1a9ea1atXm0suucSMHz/edHd3F9t87nOfM01NTWbZsmXmueeeM+edd545//zzi8/n83kzefJkM2fOHPP888+bhx9+2NTW1pqFCxcGcUrHvBUrVpjm5mbzjne8w1xzzTXF47rOQ2PPnj1mwoQJ5jOf+Yx55plnzOuvv24eeeQRs3HjxmKbm266yVRWVppf/vKX5oUXXjAf+tCHzEknnWT6+vqKbd7//vebKVOmmKeffto8+eST5pRTTjGf/OQngzilY9I3v/lNM2rUKPPQQw+ZTZs2mfvvv98kk0nz7//+78U2us5H5+GHHzbXXXedeeCBBwxgfvGLXwx4fiiua2dnp6mvrzeXXXaZWbt2rfnZz35m4vG4+cEPfvC2ai/ZMDJz5kxz1VVXFX93XdeMHTvWLFq0KMCqjl9tbW0GMH/4wx+MMcZ0dHSYcDhs7r///mKbdevWGcAsX77cGOP/D8e2bdPS0lJs8/3vf99UVFSYTCYzsidwjOvq6jKnnnqqefTRR83FF19cDCO6zkPn2muvNRdccMEhn/c8zzQ0NJhbbrmleKyjo8NEo1Hzs5/9zBhjzMsvv2wA8+yzzxbb/Pa3vzWWZZnt27cPX/HHkUsvvdT89V//9YBjf/EXf2Euu+wyY4yu81B5cxgZquv6H//xH6a6unrA3x3XXnutOf30099WvSU5TJPNZlm5ciVz5swpHrNtmzlz5rB8+fIAKzt+dXZ2AlBTUwPAypUryeVyA67xpEmTGD9+fPEaL1++nLPPPpv6+vpim7lz55JKpXjppZdGsPpj31VXXcWll1464HqCrvNQ+tWvfsWMGTP4+Mc/Tl1dHdOmTeOOO+4oPr9p0yZaWloGXOvKykpmzZo14FpXVVUxY8aMYps5c+Zg2zbPPPPMyJ3MMez8889n2bJlbNiwAYAXXniBp556ig984AOArvNwGarrunz5ci666CIikUixzdy5c1m/fj179+496vqOi7v2DrX29nZc1x3wlzNAfX09r7zySkBVHb88z+OLX/wi73znO5k8eTIALS0tRCIRqqqqBrStr6+npaWl2OZg/wz2PSe+e++9l1WrVvHss88e8Jyu89B5/fXX+f73v8+CBQv46le/yrPPPsvf//3fE4lEuOKKK4rX6mDXcv9rXVdXN+D5UChETU2NrnXBV77yFVKpFJMmTcJxHFzX5Zvf/CaXXXYZgK7zMBmq69rS0sJJJ510wHvse666uvqo6ivJMCJD66qrrmLt2rU89dRTQZdywtm2bRvXXHMNjz76KLFYLOhyTmie5zFjxgy+9a1vATBt2jTWrl3LkiVLuOKKKwKu7sTx3//93/z0pz/lnnvu4ayzzmL16tV88YtfZOzYsbrOJawkh2lqa2txHOeAFQetra00NDQEVNXx6eqrr+ahhx7i8ccfZ9y4ccXjDQ0NZLNZOjo6BrTf/xo3NDQc9J/BvufEH4Zpa2vjnHPOIRQKEQqF+MMf/sB3v/tdQqEQ9fX1us5DZMyYMZx55pkDjp1xxhls3boV6L9Wh/t7o6Ghgba2tgHP5/N59uzZo2td8OUvf5mvfOUrfOITn+Dss8/m05/+NF/60pdYtGgRoOs8XIbqug7X3yclGUYikQjTp09n2bJlxWOe57Fs2TJmz54dYGXHD2MMV199Nb/4xS947LHHDui2mz59OuFweMA1Xr9+PVu3bi1e49mzZ7NmzZoB//I/+uijVFRUHPClUKre8573sGbNGlavXl18zJgxg8suu6z4Z13nofHOd77zgOXpGzZsYMKECQCcdNJJNDQ0DLjWqVSKZ555ZsC17ujoYOXKlcU2jz32GJ7nMWvWrBE4i2Nfb28vtj3wq8dxHDzPA3Sdh8tQXdfZs2fzxz/+kVwuV2zz6KOPcvrppx/1EA1Q2kt7o9Goufvuu83LL79s/vZv/9ZUVVUNWHEgh/b5z3/eVFZWmieeeMLs3Lmz+Ojt7S22+dznPmfGjx9vHnvsMfPcc8+Z2bNnm9mzZxef37fk9H3ve59ZvXq1Wbp0qRk9erSWnL6F/VfTGKPrPFRWrFhhQqGQ+eY3v2leffVV89Of/tQkEgnzk5/8pNjmpptuMlVVVebBBx80L774ovnwhz980KWR06ZNM88884x56qmnzKmnnlryS073d8UVV5jGxsbi0t4HHnjA1NbWmn/6p38qttF1PjpdXV3m+eefN88//7wBzK233mqef/55s2XLFmPM0FzXjo4OU19fbz796U+btWvXmnvvvdckEgkt7X07vve975nx48ebSCRiZs6caZ5++umgSzpuAAd93HXXXcU2fX195gtf+IKprq42iUTCfPSjHzU7d+4c8D6bN282H/jAB0w8Hje1tbXmH/7hH0wulxvhszm+vDmM6DoPnV//+tdm8uTJJhqNmkmTJpkf/vCHA573PM9cf/31pr6+3kSjUfOe97zHrF+/fkCb3bt3m09+8pMmmUyaiooKM3/+fNPV1TWSp3FMS6VS5pprrjHjx483sVjMnHzyyea6664bsFRU1/noPP744wf9e/mKK64wxgzddX3hhRfMBRdcYKLRqGlsbDQ33XTT267dMma/be9ERERERlhJzhkRERGRY4fCiIiIiARKYUREREQCpTAiIiIigVIYERERkUApjIiIiEigFEZEREQkUAojIiIiEiiFEREREQmUwoiIiIgESmFEREREAvX/A5kXP7uaZutWAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 5000)"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 11,
     "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": 12,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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EBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJDDUEBERkSQw1BAREZEkMNQQERGRJJxRqHn77bfRo0cPaLVaZGRkYMeOHR2WX7p0Kfr27QutVovU1FSsWrXK4/Fly5ZhwoQJCAkJgUwmw969e72uZ+vWrRg7diz8/Pyg0+lw1VVXoamp6UxeAhEREUlMl0PNkiVLMHv2bMydOxd79uxBWloaJk6ciMrKSq/lt2zZgunTp2PmzJnIysrClClTMGXKFOTk5LjLmM1mjBo1Ci+//HK7z7t161Zce+21mDBhAnbs2IGdO3fikUcegVzOziYiIiICZIIgCF1ZICMjA8OGDcNbb70FAHC5XIiLi8Ojjz6KOXPmtCk/depUmM1mfP/99+55I0aMQHp6OhYuXOhRtqCgAImJicjKykJ6errHYyNGjMA111yDF154oSvVdTMajdDr9TAYDNDpdGe0DiIiIrqwunL87lI3h81mw+7duzF+/PjWFcjlGD9+PLZu3ep1ma1bt3qUB4CJEye2W96byspKbN++HeHh4Rg5ciQiIiIwevRo/Pbbb12pPhEREUlYl0JNdXU1nE4nIiIiPOZHRESgvLzc6zLl5eVdKu/N8ePHAQDz5s3D/fffj9WrV2Pw4MEYN24cjhw5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for j in range(4):\n",
    "    plt.plot(lds_testset_correctness[:, j], color=\"C{}\".format(j))\n",
    "    # break\n",
    "# plt.ylim(0.15, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6e1fd5a-508d-4b7d-a4a5-e1ea000b9547",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.040 (avg p value 0.476439)\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": 14,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.050 (avg p value 0.478351)\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": 15,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.053 (avg p value 0.448342)\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": 16,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.049 (avg p value 0.476916)\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": 17,
   "id": "136ac5ce-81a5-4456-aebf-5eed1158aaaa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.038 (avg p value 0.475349)\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": 18,
   "id": "f481d24d-6b79-48cf-b510-73d227870e9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.049 (avg p value 0.487577)\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": 19,
   "id": "46051924-02f0-4caa-8a61-d92257bba123",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.057 (avg p value 0.456073)\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": 20,
   "id": "a18cbd8b-63d3-4f18-adbd-8ca4874e6561",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.054 (avg p value 0.470820)\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": 21,
   "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": 22,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.03336040461274189, high=0.04722818132192596)\n",
      "0.033\n",
      "0.047\n",
      "1\n",
      "ConfidenceInterval(low=0.04135363557492192, high=0.0671813197701812)\n",
      "0.041\n",
      "0.067\n",
      "2\n",
      "ConfidenceInterval(low=0.03510894048760241, high=0.06599132557449759)\n",
      "0.035\n",
      "0.066\n",
      "3\n",
      "ConfidenceInterval(low=0.03463287412890098, high=0.06546184376043622)\n",
      "0.035\n",
      "0.065\n",
      "4\n",
      "ConfidenceInterval(low=0.029027621179146427, high=0.046280514591175645)\n",
      "0.029\n",
      "0.046\n",
      "5\n",
      "ConfidenceInterval(low=0.03783875540535953, high=0.06472567106324816)\n",
      "0.038\n",
      "0.065\n",
      "6\n",
      "ConfidenceInterval(low=0.04569104369926711, high=0.06906096512941899)\n",
      "0.046\n",
      "0.069\n",
      "7\n",
      "ConfidenceInterval(low=0.041583805547956126, high=0.06685544255757865)\n",
      "0.042\n",
      "0.067\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": 23,
   "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": 24,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rUKFCqWbHxYWpjFjxnilKAAAACkLQeXgwYMqWbJkuvnh4eE6ePCgV4oCAACQshBUwsLCtG3btnTzt27dqoIFC3qlKAAAACkLQaVTp07q16+fli9frtTUVKWmpmrZsmXq37+/nnzyyeyoEQAA3KM8vutn5MiR2r9/vxo3bix//6uLp6WlqUuXLlyjAgAAvMrjoBIQEKC5c+dq5MiR2rp1qwIDA1WpUiWFh4dnR30AAOAe5nFQuaZs2bIqW7asN2sBAABw43FQSU1N1YwZM7R06VLFx8crLS3N7flly5Z5rTgAAHBv8zio9O/fXzNmzFDLli1VsWJFORyO7KgLAADA86AyZ84czZs3Ty1atMiOegAAAFw8vj05ICBApUuXzo5aAAAA3HgcVAYOHKh3331XxpjsqAcAAMDF41M/P/30k5YvX64lS5aoQoUKypkzp9vzCxYs8FpxAADg3uZxUAkJCVHbtm2zoxYAAAA3HgeVmJiY7KgDAAAgHY+vUZGklJQU/fDDD/r3v/+t8+fPS5KOHj2qxMRErxYHAADubR4fUTlw4ICaNWumgwcPKikpSY899piCgoI0btw4JSUlacqUKdlRJwAAuAd5fESlf//+qlmzps6cOaPAwEDX/LZt22rp0qVeLQ4AANzbPD6isnLlSq1evVoBAQFu8yMiInTkyBGvFQYAAODxEZW0tDSlpqamm3/48GEFBQV5pSgAAAApC0GladOmmjhxomva4XAoMTFRw4YN42v1AQCAV3l86uftt99WZGSkypcvr8uXL+upp57S7t27VahQIc2ePTs7agQAAPcoj4PK/fffr61bt2rOnDnatm2bEhMT1bNnT0VFRbldXAsAAHCrPA4qkuTv76+nn37a27UAAAC48TiozJo164bPd+nSJcvFAAAA/JnHQaV///5u08nJybp48aICAgKUO3duggoAAPAaj+/6OXPmjNsjMTFRO3fuVN26dbmYFgAAeFWWfuvnr8qUKaOxY8emO9oCAABwK7wSVKSrF9gePXrUW90BAAB4fo3K119/7TZtjFFcXJzef/991alTx2uFAQAAeBxU2rRp4zbtcDgUGhqqRo0a6e233/ZWXQAAAJ4HlbS0tOyoAwAAIB2vXaMCAADgbR4fURkwYECm206YMMHT7gEAAFw8DiqbN2/W5s2blZycrHLlykmSdu3aJT8/P1Wv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1KmjOnXq6PXXX1d4eLgWLlyoAQMGKCAgQKmpqW7tV69erfDwcL3yyiuueQcOHHBrk9FyGQkODlbHjh3VsWNHdejQQc2aNdPp06dVoEAB5cyZ84Z9BAUFKSIiQkuXLlXDhg0zvb1RUVH67LPPdP/99ytHjhxq2bKl67lVq1apdevWevrppyVJaWlp2rVrl8qXL3/d/kJDQxUXF+ea3r17ty5evOiarl69uubOnauwsDCPjzoBuDmOqAB3sbVr12rMmDHasGGDDh48qAULFujEiRN66KGHJF29/mTbtm3auXOnTp48qeTkZJUpU0YHDx7UnDlztHfvXr333ntauHChW78RERHat2+ftmzZopMnTyopKSnduidMmKDZs2fr999/165duzR//nwVKVLEdRrmWgg5duyYzpw5k2H9w4cP19tvv6333ntPu3fv1qZNmzRp0qQbbnNUVJQ2bdqk0aNHq0OHDnI6na7nypQpo9jYWK1evVq//fabevfurePHj9+wv0aNGun999/X5s2btWHDBv3jH/9Qzpw53dZXqFAhtW7dWitXrtS+ffu0YsUK9evXT4cPH75h3wAywQC4a+3YscNERkaa0NBQ43Q6TdmyZc2kSZNcz8fHx5vHHnvM5M2b10gyy5cvN8YYM3jwYFOwYEGTN29e07FjR/POO++YfPnyuZa7fPmyad++vQkJCTGSTExMjDHGGElm4cKFxhhjpk6daqpWrWry5MljgoODTePGjc2mTZtcfXz99demdOnSxt/f34SHhxtjjBk2bJipUqWK2zZMmTLFlCtXzuTMmdMULVrUPP/88zfd7lq1ahlJZtmyZW7zT506ZVq3bm3y5s1rwsLCzKuvvmq6dOliWrdu7WpTv359079/f9f0kSNHTNOmTU2ePHlMmTJlzDfffGPy5cvn2mZjjImLizNdunQxhQoVMk6n0zzwwAOmV69e5ty5czetFcCNOYz5y8lXAAAAS3DqBwAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABr/T+SoxGcIch47gAAAABJRU5ErkJggg==",
      "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
}
