{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "7d607888-e92d-4720-b28e-43d8ce2c643a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "c9bb7deb-4dbb-4100-a5c6-1ab11c826833",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "f37c6eff-445d-4007-9951-fdba0c6b46d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7499a23a-7876-4670-ae09-c4de570791e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "12500"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open('../../data/indices/12500-0.5/idx-train.pkl', 'rb')  as handle:\n",
    "    idx_train = pickle.load(handle)\n",
    "len(idx_train)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "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": 30,
   "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": 31,
   "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": 32,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    for seed in [\n",
    "        0,\n",
    "                 1,\n",
    "                 2,\n",
    "                 # 3,\n",
    "                 # 4,\n",
    "                ]:\n",
    "        for e_seed in [\n",
    "            0, \n",
    "                       1, \n",
    "                       2\n",
    "                      ]:\n",
    "            with open('../../saved/12500-0.5/lds-val/sd-lora-sub-{}-{}/e-{}-val.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4214c4b5-d74f-4e52-8c45-1f20ea8d4b38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8d0f643-d0aa-433d-8586-e75351bdd70f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f9U//vhjHdA/+eSTiPzm+F5ra2v1zMxMffz48frq1av19957T7fZbPpLL710WH1vtcHISSedpN98883hz8FgUM/JydGnTJnSgr06fpWVlemA/v333+u6rus1NTW6yWTSP/zww3CZdevW6YC+YMECXddD/3BUVdVLSkrCZf7973/rdrtd93q9R/cBjnF1dXV6586d9ZkzZ+qjR48OByPyPTefu+++Wx85cmST+Zqm6VlZWfrTTz8dTqupqdEtFov+3nvv6bqu62vXrtUBffHixeEyX331la4oir5z584j1/njyLnnnqtfd911EWmXXHKJPn78eF3X5XtuLnsHI831vb744ot6cnJyxP877r77br1r166H1d9W+ZrG5/OxdOlSxowZE05TVZUxY8awYMGCFuzZ8au2thaAlJQUAJYuXYrf74/4jrt160ZeXl74O16wYAG9e/cmMzMzXGbs2LE4nU7WrFlzFHt/7Lv55ps599xzI75PkO+5OX3++ecMGjSI3/zmN2RkZNC/f39eeeWVcP7WrVspKSmJ+K4dDgdDhgyJ+K6TkpIYNGhQuMyYMWNQVZWff/756D3MMWz48OHMnj2bjRs3AvDLL7/w448/cvbZZwPyPR8pzfW9LliwgJNPPhmz2RwuM3bsWDZs2EB1dfUh9++4OCivuVVUVBAMBiP+5wyQmZnJ+vXrW6hXxy9N07jjjjsYMWIEvXr1AqCkpASz2UxSUlJE2czMTEpKSsJlYv0Z/JonQt5//32WLVvG4sWLo/Lke24+BQUF/Pvf/2bSpEnce++9LF68mNtuuw2z2cw111wT/q5ifZd7ftcZGRkR+UajkZSUFPmud7vnnntwOp1069YNg8FAMBjkscceY/z48QDyPR8hzfW9lpSU0L59+6g2fs1LTk4+pP61ymBENK+bb76Z1atX8+OPP7Z0V044RUVF3H777cycOROr1drS3TmhaZrGoEGDePzxxwHo378/q1evZurUqVxzzTUt3LsTxwcffMA777zDu//fzv2EpLJHcQA/72paEmZgOGUYBdHt36KMYqidELSKdkWItIkKoSKKIFpGrlrUrk0t6tKqiFoEola0yCi0jMDalBspKMTAIMNzF+/dec2r9x50rSn8fmBAZg7ym68yHhyPP35QdXU1BYNBGhoaoqKiIuScwTLyNo3RaCSVSvVi4uD6+poEQVBoVV+T0+mkzc1N8vl8VFxcLO0XBIEeHx8pFovJ6p9nLAjCq6/Br2Pw522Ym5sbqq+vJ7VaTWq1mnZ2dmh2dpbUajWZTCbknCaFhYVUVVUl21dZWUmRSISI/s7qv64bgiDQzc2N7PjT0xPd3d0h67+Mjo7S+Pg4dXZ2Um1tLdntdhoeHqbp6WkiQs7vJV25vtf1JCObEY1GQ1arlTwej7QvlUqRx+MhURQVXNnXwczkdDppbW2NvF7vi6/trFYrZWVlyTIOh8MUiUSkjEVRpFAoJHvzu91u0uv1Lz4UMpXNZqNQKETBYFDaGhoaqLu7W3qMnNOjubn5xXj6+fk5lZSUEBFRaWkpCYIgyzoej5Pf75dlHYvF6OjoSKrxer2USqWoqanpA87i80skEvTtm/yjR6VSUSqVIiLk/F7SlasoirS7u0vJZFKqcbvdVFFR8eZbNESU2aO9Wq2WFxcX+ezsjHt7e9lgMMgmDuDf9ff3c15eHm9vb3M0GpW2RCIh1fT19bHFYmGv18uHh4csiiKLoigd/zVy2traysFgkLe2trigoAAjp//j+TQNM3JOl4ODA1ar1Tw1NcUXFxe8vLzMOp2Ol5aWpBqXy8UGg4HX19f55OSE29vbXx2NrKurY7/fz3t7e1xeXp7xI6fPORwONpvN0mjv6uoqG41GHhsbk2qQ89vc399zIBDgQCDARMQzMzMcCAT46uqKmdOTaywWY5PJxHa7nU9PT3llZYV1Oh1Ge3/H3NwcWywW1mg03NjYyPv7+0ov6csgole3hYUFqebh4YEHBgY4Pz+fdTodd3R0cDQalT3P5eUlt7W1cU5ODhuNRh4ZGeFkMvnBZ/O1/LMZQc7ps7GxwTU1NazVavn79+88Pz8vO55KpXhycpJNJhNrtVq22WwcDodlNbe3t9zV1cW5ubms1+u5p6eH7+/vP/I0PrV4PM6Dg4NssVg4Ozuby8rKeGJiQjYqipzfxufzvXpddjgczJy+XI+Pj7mlpYW1Wi2bzWZ2uVy/vfY/mJ/97R0AAADAB8vI34wAAADA54FmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAUhWYEAAAAFIVmBAAAABSFZgQAAAAU9RNbNcbOLkXbyQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1):\n",
    "    for j in range(8):\n",
    "        plt.plot(lds_loss_array[i, :, j], color=\"C{}\".format(j))\n",
    "    # break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 12500)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mask_array_list = []\n",
    "\n",
    "for i in my_list:\n",
    "    # print(i)\n",
    "    with open('../../data/indices/12500-0.5/lds-val/sub-idx-{}.pkl'.format(i), 'rb')  as handle:\n",
    "        sub_idx_train = pickle.load(handle)\n",
    "    # print(len(sub_idx_train))\n",
    "    mask_array = np.in1d(idx_train, sub_idx_train)\n",
    "        \n",
    "    mask_array_list.append(mask_array)\n",
    "    \n",
    "lds_mask_array = np.stack(mask_array_list)\n",
    "lds_mask_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 35,
     "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": 36,
   "id": "c6b5645a-a6e3-4570-9aca-6e2ab3adf760",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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acVggN0y/NaMzWREuceqm3OFpomr+uzL5WBgmSSf+Jdd6I2msHa+Hx+a58eyacWj3lq4EcXTWbxzthclTisayl1wWi//oBNCYO+5frz8biv++3AnjIoBn7ljJh5cUz/iffvJks5qeOt0N3ac7IZJUXJX2xaU5O7nljqt8LnkrYSbhRACrX0JHGjtzweYjoEEXFYTXLmrZFfuWR15shp6BsdhkeFp8BkAq8mISDKTf1i2L9eA98XSCCUymF/lwYcXV2J+pee6fxB0JJFkBjazcULPNFxKKJHByUAEC6s9ujnR6VlvNIXtx7vw22MBvNHUg3RWw5LaIvzRwgp5y7tk/A8107XHwDJJoqnsTXUiu1YyqpZ/aJaIaLLEc7cpJ/vBULp6xnv+5pn4EhhWro7JvBolIhoke/6muhR0NfCsQURERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREundZgeXpp59GXV0dbDYbGhsbsWfPnlHnPXr0KO69917U1dXBYDBgy5Ytw+aJRCLYsGEDpk+fDrvdjltvvRV79+69nKIRERHRDWjCgeXFF1/Exo0b8fjjj2P//v1YsmQJ1q1bh66urhHnj8fjmDFjBp544glUVFSMOM9f/dVf4dVXX8Xzzz+Pw4cP46677sLatWvR3t4+0eIRERHRDcgghBATWaCxsRErV67E1q1bAQCapqG2thYPP/wwNm3aNOaydXV12LBhAzZs2JB/LZFIwO124xe/+AXuueee/OvLly/H3XffjX/4h38YV7nC4TC8Xi9CoRA8Hs9EvhIRERFNkfGevyfUw5JOp7Fv3z6sXbt2aAWKgrVr12LXrl2XVdBsNgtVVWGz2Qpet9vteOutt0ZdLpVKIRwOFwxERER0Y5pQYOnp6YGqqvD7/QWv+/1+BAKByyqA2+3G6tWr8bWvfQ0dHR1QVRU//vGPsWvXLnR2do663ObNm+H1evNDbW3tZX0+ERER6Z8ufkvo+eefhxAC1dXVsFqteOqpp/CpT30KijJ68R555BGEQqH80Nraeg1LTERERNeSaSIzl5aWwmg0IhgMFrweDAZHfaB2PGbOnImdO3ciFoshHA6jsrIS9913H2bMmDHqMlarFVar9bI/k4iIiK4fE+phsVgsWL58ObZv355/TdM0bN++HatXr77iwjidTlRWVqK/vx+/+c1v8NGPfvSK10lERETXvwn1sADAxo0bsX79eqxYsQKrVq3Cli1bEIvF8MADDwAA7r//flRXV2Pz5s0A5IO6x44dy0+3t7fj4MGDcLlcaGhoAAD85je/gRACc+bMwenTp/HlL38Zc+fOza+TiIiIbm4TDiz33Xcfuru78dhjjyEQCGDp0qXYtm1b/kHclpaWgmdPOjo6sGzZsvzPTz75JJ588knccccd2LFjBwAgFArhkUceQVtbG3w+H+699158/etfh9lsvsKvR0RERDeCCf8dFr3i32EhIiK6/lyVv8NCRERENBUYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcYWIiIiEj3GFiIiIhI9xhYiIiISPcuK7A8/fTTqKurg81mQ2NjI/bs2TPqvEePHsW9996Luro6GAwGbNmyZdg8qqri0UcfRX19Pex2O2bOnImvfe1rEEJcTvGIiIjoBjPhwPLiiy9i48aNePzxx7F//34sWbIE69atQ1dX14jzx+NxzJgxA0888QQqKipGnOeb3/wmnnnmGWzduhXHjx/HN7/5TXzrW9/Cd7/73YkWj4iIiG5ABjHBbozGxkasXLkSW7duBQBomoba2lo8/PDD2LRp05jL1tXVYcOGDdiwYUPB6x/+8Ifh9/vxgx/8IP/avffeC7vdjh//+MfjKlc4HIbX60UoFILH45nIVyIiIqIpMt7z94R6WNLpNPbt24e1a9cOrUBRsHbtWuzateuyC3vrrbdi+/btOHXqFADgvffew1tvvYW777571GVSqRTC4XDBQERERDcm00Rm7unpgaqq8Pv9Ba/7/X6cOHHisguxadMmhMNhzJ07F0ajEaqq4utf/zo+/elPj7rM5s2b8fd///eX/ZlERER0/dDFbwm99NJL+MlPfoKf/vSn2L9/P370ox/hySefxI9+9KNRl3nkkUcQCoXyQ2tr6zUsMREREV1LE+phKS0thdFoRDAYLHg9GAyO+kDteHz5y1/Gpk2b8MlPfhIAsGjRIpw/fx6bN2/G+vXrR1zGarXCarVe9mcSERHR9WNCPSwWiwXLly/H9u3b869pmobt27dj9erVl12IeDwORSksitFohKZpl71OIiIiunFMqIcFADZu3Ij169djxYoVWLVqFbZs2YJYLIYHHngAAHD//fejuroamzdvBiAf1D127Fh+ur29HQcPHoTL5UJDQwMA4CMf+Qi+/vWvY9q0aViwYAEOHDiA73znO3jwwQcn63sSERHRdWzCv9YMAFu3bsW3v/1tBAIBLF26FE899RQaGxsBAO9///tRV1eH5557DgBw7tw51NfXD1vHHXfcgR07dgAAIpEIHn30Ubzyyivo6upCVVUVPvWpT+Gxxx6DxWIZV5n4a81ERETXn/Gevy8rsOgRAwsREdH156r8HRYiIiKiqcDAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6x8BCREREusfAQkRERLrHwEJERES6d1mB5emnn0ZdXR1sNhsaGxuxZ8+eUec9evQo7r33XtTV1cFgMGDLli3D5hl87+LhoYceupziERER0Q1mwoHlxRdfxMaNG/H4449j//79WLJkCdatW4eurq4R54/H45gxYwaeeOIJVFRUjDjP3r170dnZmR9effVVAMDHP/7xiRaPiIiIbkAGIYSYyAKNjY1YuXIltm7dCgDQNA21tbV4+OGHsWnTpjGXraurw4YNG7Bhw4Yx59uwYQN+9atfoampCQaDYVzlCofD8Hq9CIVC8Hg841qGiIiIptZ4z98T6mFJp9PYt28f1q5dO7QCRcHatWuxa9euyy/tRZ/x4x//GA8++OC4wwoRERHd2EwTmbmnpweqqsLv9xe87vf7ceLEiUkp0M9//nMMDAzgL/7iL8acL5VKIZVK5X8Oh8OT8vlERESkP7r7LaEf/OAHuPvuu1FVVTXmfJs3b4bX680PtbW116iEREREdK1NKLCUlpbCaDQiGAwWvB4MBkd9oHYizp8/j9/97nf4q7/6q0vO+8gjjyAUCuWH1tbWK/58IiIi0qcJBRaLxYLly5dj+/bt+dc0TcP27duxevXqKy7MD3/4Q5SXl+Oee+655LxWqxUej6dgICIiohvThJ5hAYCNGzdi/fr1WLFiBVatWoUtW7YgFovhgQceAADcf//9qK6uxubNmwHIh2iPHTuWn25vb8fBgwfhcrnQ0NCQX6+mafjhD3+I9evXw2SacLGIiIjoBjbhZHDfffeh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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": 37,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.049 (avg p value 0.479031)\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": 38,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.102 (avg p value 0.398056)\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": 39,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.055 (avg p value 0.476541)\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": 40,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.111 (avg p value 0.380370)\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": 41,
   "id": "136ac5ce-81a5-4456-aebf-5eed1158aaaa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.051 (avg p value 0.474487)\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": 42,
   "id": "f481d24d-6b79-48cf-b510-73d227870e9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.100 (avg p value 0.401955)\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": 43,
   "id": "46051924-02f0-4caa-8a61-d92257bba123",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.057 (avg p value 0.473497)\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": 44,
   "id": "a18cbd8b-63d3-4f18-adbd-8ca4874e6561",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.109 (avg p value 0.387199)\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.04400010436831196, high=0.05476029679781334)\n",
      "0.044\n",
      "0.055\n",
      "1\n",
      "ConfidenceInterval(low=0.09649754658064114, high=0.11182902988884837)\n",
      "0.096\n",
      "0.112\n",
      "2\n",
      "ConfidenceInterval(low=0.04892033956815672, high=0.062821517721958)\n",
      "0.049\n",
      "0.063\n",
      "3\n",
      "ConfidenceInterval(low=0.10549246183572633, high=0.12008504757130216)\n",
      "0.105\n",
      "0.12\n",
      "4\n",
      "ConfidenceInterval(low=0.044192036569397214, high=0.05591479194651287)\n",
      "0.044\n",
      "0.056\n",
      "5\n",
      "ConfidenceInterval(low=0.09425173762643854, high=0.11018130103595053)\n",
      "0.094\n",
      "0.11\n",
      "6\n",
      "ConfidenceInterval(low=0.05194609088357779, high=0.0645254991697942)\n",
      "0.052\n",
      "0.065\n",
      "7\n",
      "ConfidenceInterval(low=0.10323380399807396, high=0.11883341799251544)\n",
      "0.103\n",
      "0.119\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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uN43bNhQjRo1cs3xRhQvXlxnzpy56vLw8HBJ0meffaaLFy/meTtPPPFErvvm53yvxdOfmerVq6tp06au9xEREapWrZp++eWXfK0TyA8EHCAfNWzYUK1atVKrVq3UvXt3LVmyRNWrV9eAAQN04cIFSdKvv/6q8uXLKyQkxG3d22+/3bU8638LFSqkypUru/UrW7aswsPDXf2u5eWXX9bp06dVtWpV1apVS88884y2b9/u0ZxiY2NzbJ81a5Zq167turcnIiJCS5YsUUpKSra+VapUydZWtWpVr3xXTVpaWrbP8krNmjXTAw88oFGjRql06dLq2LGj4uPjs92Tci2BgYGqUKFCrvvn53yvxdOfmYoVK2Ybo0SJEjp16lS+1gnkBwIOcBMVKlRILVq0UFJSUp7PotzIF7ndfffd2rdvn2bOnKmaNWvq/fffV7169fT+++/neozg4OBsbR988IF69+6tSpUqacaMGfriiy+0fPly3XPPPcrMzMxzvZ66ePGidu/ene0X+pUcDoc+/vhjrVu3TgMGDNDhw4f16KOPqn79+kpLS8vVdpxOpwoV8u4/n1fbrxkZGfk29h9d7Wkz84eb3YGCgIAD3GSXLl2SJNcv0+joaB05ciTbZZWff/7ZtTzrfzMzM7MFo2PHjun06dNu3/NyrV9oJUuWVJ8+fTRnzhwdPHhQtWvXdvtiv7wEqI8//li33nqrFi5cqB49eiguLk6tWrXS+fPnc+yfU7jbvXv3VZ9A8qSO33//XXFxcdft+5e//EVjxozRpk2b9OGHH+rHH3/U3LlzJd1YiMxJbuZbokQJnT59Olu/P55l8aQ2T35mANsQcICb6OLFi/ryyy8VFBTkugTVrl07ZWRkuD3aLF1+rNjhcKht27auftLlp6SuNGnSJElS+/btXW3FihXL8ZfliRMn3N4XL15clStXdrs8U6xYMUnKcf2ryfov/yv/S3/9+vVat25djv0/+eQTHT582PV+w4YNWr9+vWuuebFt2zY99dRTKlGihPr373/VfqdOncp2RiLrKa+szyHrqShPPoNryc18K1WqpJ9//tnt25i3bdumNWvWuI3lSW2e/MwAtuExcSAfLV261HUmJjk5WR999JH27NmjYcOGKTQ0VJJ03333qUWLFnr++eeVmJioOnXq6Msvv9Snn36qp556SpUqVZJ0+XteevXq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PaQdO3boiy++0FdffSVJCgsLy7btt956S4sXL9b8+fNVsWJFHTx4UAcPHpQkbdy4UZGRkYqPj1ebNm0UEBCQY/1Tp07V4MGDNX78eLVt21YpKSlas2ZNjn1btmyp8PBw/fe//1Xfvn0lSRkZGZo3b57GjBkjSTp//rzq16+v5557TqGhoVqyZIl69OihSpUqqWHDhnn6jC9evKi4uDjdddddWr16tQIDAzV69Gi1adNG27dvV1BQUJ7GBXBtBBzgTywpKUmXLl1Sly5dFB0dLUmqVauWa3lwcLDS09OzXVp64YUXXP8/JiZGQ4cO1dy5c/Xss88qODhYxYsXV2Bg4DUvSR04cEBVqlRRkyZN5HA4XNuXpIiICEmXz4Rca4zRo0dryJAhGjRokKvtzjvvzLFvQECAHn74YX300UeugLNixQqdPn1aDzzwgCTplltu0dChQ13rPPnkk1q2bJnmz5+f54Azb948ZWZm6v3335fD4ZAkxcfHKzw8XKtWrVLr1q3zNC6AayPgAH9iderUUcuWLVWrVi3FxcWpdevW6tq1q0qUKHHN9ebNm6e33npL+/btU1pami5duqTQ0FCPtt27d2/de++9qlatmtq0aaMOHTp49Ms+OTlZR44cUcuWLXO9Tvfu3fWXv/xFR44cUfny5fXhhx+qffv2Cg8Pl3T5jM7YsWM1f/58HT58WBcuXFB6erqKFi3q0dyutG3bNu3du1chISFu7efPn9e+ffvyPC6Aa+MeHOBPLCAgQMuXL9fSpUtVvXp1TZkyRdWqVdP+/fuvus66devUvXt3tWvXTp999pm+//57Pf/887pw4YJH265Xr57279+vV155Rb///rsefPBBde3aNdfrBwcHe7Q96fLZnUqVKmnu3Ln6/ffftWjRInXv3t21fOLEiXrzzTf13HPPaeXKldq6davi4uKuOTeHwyFjjFtb1v1IkpSWlqb69etr69atbq/du3fr73//u8dzAJA7nMEB/uQcDocaN26sxo0b66WXXlJ0dLQWLVqkwYMHKygoSBkZGW79165dq+joaD3//POutl9//dWtT07r5SQ0NFQPPfSQHnroIXXt2lVt2rTRyZMnVbJkSRUuXPiaY4SEhCgmJkYrVqxQixYtcj3f7t2768MPP1SFChVUqFAhtW/f3rVszZo16tixox555BFJUmZmpnbv3q3q1atfdbyIiAglJSW53u/Zs0fnzp1zva9Xr57mzZunyMhIj89yAcg7zuAAf2Lr16/X2LFjtWnTJh04cEALFy7U8ePHdfvtt0u6fH/N9u3btWvXLv3222+6ePGiqlSpogMHDmju3Lnat2+f3nrrLS1atMht3JiYGO3fv19bt27Vb7/9pvT09GzbnjRpkubMmaOff/5Zu3fv1oIFC1S2bFnX5aKs8HL06FGdOnUqx/pHjhyp119/XW+99Zb27NmjLVu2aMqUKdecc/fu3bVlyxaNGTNGXbt2ldPpdC2rUqWKli9frrVr12rnzp16/PHHdezYsWuOd8899+jtt9/W999/r02bNumf//ynChcu7La90qVLq2PHjlq9erX279+vVatWaeDAgTp06NA1xwZwAwyAP62ffvrJxMXFmYiICON0Ok3VqlXNlClTXMuTk5PNvffea4oXL24kmZUrVxpjjHnmmWdMqVKlTPHixc1DDz1k3njjDRMWFuZa7/z58+aBBx4w4eHhRpKJj483xhgjySxatMgYY8z06dNN3bp1TbFixUxoaKhp2bKl2bJli2uMxYsXm8qVK5vAwEATHR1tjDFmxIgRpk6dOm5zmDZtmqlWrZopXLiwKVeunHnyySevO++GDRsaSebrr792az9x4oTp2LGjKV68uImMjDQvvPCC6dmzp+nYsaOrT7NmzcygQYNc7w8fPmxat25tihUrZqpUqWI+//xzExYW5pqzMcYkJSWZnj17mtKlSxun02luvfVW069fP5OSknLdWgHkjcOYP1w8BgAAKOC4RAUAAKxDwAEAANYh4AAAAOsQcAAAgHUIOAAAwDoEHAAAYB0CDgAAsA4BBwAAWIeAAwAArEPAAQAA1iHgAAAA6xBwAACAdf4fNudJoSv9lcgAAAAASUVORK5CYII=",
      "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": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a92ccc15-8a39-4450-9148-0b71dde96f12",
   "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
}
