{
 "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": [
       "12500"
      ]
     },
     "execution_count": 4,
     "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": 5,
   "id": "d98abb9c-a3e5-4103-9261-b90f5a5e15ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 12500)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with open(\"val_clip.pkl\", 'rb') as handle:\n",
    "    scores_list = pickle.load(handle)\n",
    "scores_list[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3094d577-6791-4900-953b-d0d27e3d3d14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "id": "9dda99c2-c1e1-40b0-95b7-834397c035ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000, 1000)"
      ]
     },
     "execution_count": 7,
     "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": 8,
   "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": 9,
   "id": "a717d51e-e999-42b0-8b4e-215f8b69efac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 12500)"
      ]
     },
     "execution_count": 9,
     "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": 10,
   "id": "9006fe41-b864-4861-9826-ebf2a8ab0c9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 1000)"
      ]
     },
     "execution_count": 10,
     "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": 11,
   "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": 12,
   "id": "12557fa3-4063-4a2f-8813-d6ff5518c152",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.019 (avg p value 0.498269)\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": null,
   "id": "cf2dbb71-4997-456c-bbf1-501d83c4b872",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "fe452ce0-43bb-4f4e-838d-e2b24f1d04b7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Correlation: 0.020 (avg p value 0.491547)\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": null,
   "id": "3935a543-4c50-445e-83e2-c24fcab4b380",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8113e5f7-11ed-4d7d-976c-37a9b1791257",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "id": "031d5899-939d-46a3-a6dd-41a6549f5d7d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "ConfidenceInterval(low=0.010600120914439836, high=0.026812458029555637)\n",
      "0.011\n",
      "0.027\n",
      "1\n",
      "ConfidenceInterval(low=0.012725092936340455, high=0.02803279398183871)\n",
      "0.013\n",
      "0.028\n"
     ]
    }
   ],
   "source": [
    "res_list = []\n",
    "for i in range(2):\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": 16,
   "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": 17,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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VapU0ccff5zh8rFjx+rDDz/UlClTtG7dOuXNm1dRUVG6evXqHa4UAAB4I49+aWTz5s3VvHnzDJcZYzRx4kS9+eabat26tSRp5syZKly4sL799ls9/fTTd7JUAADghbz2GpkDBw7oxIkTatKkiaMtX758ql27ttauXevBygAAgLfw6BGZrJw4cUKSVLhwYaf2woULO5ZlJDExUYmJiY7nCQkJOVMgAADwOK8NMrdq9OjRio6O9nQZgCVFDF7slnEOjmnplnEA4Ga89tRSkSJFJEknT550aj958qRjWUaGDBmi+Ph4x+PIkSM5WicAAPAcrw0ykZGRKlKkiJYvX+5oS0hI0Lp161SnTp1M17Pb7QoODnZ6AACAu5NHTy1dvHhR+/btczw/cOCAtmzZogIFCqhkyZJ69dVXNWLECJUpU0aRkZF66623VKxYMbVp08ZzRQMAAK/h0SATGxurhg0bOp7369dPktSlSxdNnz5dr7/+ui5duqQXXnhB58+fV926dbV06VLlzp3bUyUDAAAvYjPGGE8XkZMSEhKUL18+xcfHc5oJuAku9gXgLbL7/u2118gAAADcDEEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYllcHmZSUFL311luKjIxUQECASpUqpeHDh8sY4+nSAACAF/D1dAFZeffddzV58mTNmDFDFStWVGxsrLp166Z8+fKpT58+ni4PAAB4mFcHmTVr1qh169Zq2bKlJCkiIkKzZ8/W+vXrPVwZAADwBl59aunhhx/W8uXLtWfPHknS1q1b9dtvv6l58+aZrpOYmKiEhASnBwAAuDt59RGZwYMHKyEhQQ888IB8fHyUkpKikSNHqlOnTpmuM3r0aEVHR9/BKgHklIjBi90yzsExLd0yDgDv49VHZObNm6evvvpKs2bN0qZNmzRjxgy99957mjFjRqbrDBkyRPHx8Y7HkSNH7mDFAADgTvLqIzIDBw7U4MGD9fTTT0uSKleurEOHDmn06NHq0qVLhuvY7XbZ7fY7WSYAAPAQrz4ic/nyZeXK5Vyij4+PUlNTPVQRAADwJl59RObxxx/XyJEjVbJkSVWsWFGbN2/WhAkT1L17d0+XBgAAvIBXB5lJkybprbfe0ssvv6xTp06pWLFievHFF/X22297ujQAAOAFvDrIBAUFaeLEiZo4caKnSwEAAF7Iq6+RAQAAyApBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWBZBBgAAWJbLQeavv/7KiToAAABc5nKQKV26tBo2bKgvv/xSV69ezYmaAAAAssXlILNp0yY9+OCD6tevn4oUKaIXX3xR69evz4naJEnHjh3Ts88+q4IFCyogIECVK1dWbGxsjm0PAABYh8tBpmrVqvrggw90/PhxTZs2TXFxcapbt64qVaqkCRMm6PTp024r7ty5c3rkkUfk5+enJUuWaOfOnRo/frzy58/vtm0AAADruuWLfX19fdWuXTvNnz9f7777rvbt26cBAwaoRIkS6ty5s+Li4m67uHfffVclSpRQTEyMatWqpcjISDVt2lSlSpW67bEBAID13XKQiY2N1csvv6yiRYtqwoQJGjBggPbv369ly5bp+PHjat269W0Xt2jRItWsWVP//ve/FRYWpmrVqunzzz+/7XEBAMDdwdfVFSZMmKCYmBjt3r1bLVq00MyZM9WiRQvlynU9E0VGRmr69OmKiIi47eL++usvTZ48Wf369dP//d//acOGDerTp4/8/f3VpUuXDNdJTExUYmKi43lCQsJt1wEAALyTy0Fm8uTJ6t69u7p27aqiRYtm2CcsLExTp0697eJSU1NVs2ZNjRo1SpJUrVo17dixQ1OmTMk0yIwePVrR0dG3vW0AAOD9XA4ye/fuvWmfrI6YuKJo0aKqUKGCU1v58uX1zTffZLrOkCFD1K9fP8fzhIQElShR4rZrAQAA3sflIBMTE6PAwED9+9//dmqfP3++Ll++7JYAk+aRRx7R7t27ndr27Nmj8PDwTNex2+2y2+1uqwEAAHgvly/2HT16tAoVKpSuPSwszHEKyF1ee+01/f777xo1apT27dunWbNm6bPPPlOvXr3cuh0AAGBNLgeZw4cPKzIyMl17eHi4Dh8+7Jai0jz00ENauHChZs+erUqVKmn48OGaOHGiOnXq5NbtAAAAa3L51FJYWJi2bduW7q6krVu3qmDBgu6qy6FVq1Zq1aqV28cFAADW5/IRmY4dO6pPnz5auXKlUlJSlJKSohUrVqhv3756+umnc6JGAACADLl8RGb48OE6ePCgGjduLF/f66unpqaqc+fObr9GBgAAICsuBxl/f3/NnTtXw4cP19atWx1f5JjVnUQAAAA5weUgk6Zs2bIqW7asO2sBAABwictBJiUlRdOnT9fy5ct16tQppaamOi1fsWKF24oDAADIistBpm/fvpo+fbpatmypSpUqyWaz5URdAAAAN+VykJkzZ47mzZunFi1a5EQ9AAAA2eby7df+/v4qXbp0TtQCAADgEpeDTP/+/fXBBx/IGJMT9QAAAGSby6eWfvvtN61cuVJLlixRxYoV5efn57R8wYIFbisOAAAgKy4HmZCQELVt2zYnagEAAHCJy0EmJiYmJ+oAAABwmcvXyEhScnKyfv75Z3366ae6cOGCJOn48eO6ePGiW4sDAADIistHZA4dOqRmzZrp8OHDSkxM1GOPPaagoCC9++67SkxM1JQpU3KiTgAAgHRcPiLTt29f1axZU+fOnVNA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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": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ecad53f9-c208-43c6-b8cb-543da6b232da",
   "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
}
