{
 "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.054 (avg p value 0.473186)\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.067 (avg p value 0.456859)\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.0475269449087215, high=0.06239398436331262)\n",
      "0.048\n",
      "0.062\n",
      "1\n",
      "ConfidenceInterval(low=0.06011960213932266, high=0.0743759596434038)\n",
      "0.06\n",
      "0.074\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": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5vklEQVR4nO3deZzNdf//8ecxyzHMjLHMWMKMGLJvxeWKEJlBZe2SS0VJ6iLKUrnqG1MxSkmpaGGGq7J1UW5JQpSrkH0p2SLbaGSZRRmzvH9/uM35Oc1gzjjjvPG4327nVp/PeZ/35/U6nzkzT5/z+ZzjMMYYAQAAWKiYrwsAAAC4EIIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggqAq1piYqIcDof2799f5Nvq16+foqKiXMv79++Xw+HQq6++WuTblqQxY8bI4XBckW0BtiCoAIWQ+8fx/FtERITatm2rxYsXF/n233nnHSUmJhbqsV988YXGjBnj1Xq8ZeXKlW7PqdPpVPny5dWmTRuNGzdOx44d88p2/vjjD40ZM0YrV670ynzeZHNtgC8QVIDL8MILL+g///mPZs6cqaeeekrHjh1Tp06d9Pnnnxfpdi83qMTFxXm3IC8bMmSI/vOf/+i9997TyJEjVaZMGY0ePVq1a9fW119/7Tb2/vvv159//qnIyMgCz//HH38oLi7O4zDw/vvva+fOnR49xlMXq+25557Tn3/+WaTbB2zj7+sCgKtZx44ddfPNN7uW+/fvr/Lly2vWrFm68847fViZd2RlZSknJ0eBgYFXdLutWrVSz5493dZt2bJFHTp0UI8ePfTTTz+pYsWKkiQ/Pz/5+fkVaT2nT59WyZIlFRAQUKTbuRR/f3/5+/NrG9cXjqgAXhQWFqagoKA8f0xOnz6t4cOHq0qVKnI6napVq5ZeffVV/fXLy7OysvTiiy+qevXqcjqdioqK0r///W9lZGS4xkRFRenHH3/UN99843qLpE2bNpKkzMxMxcXFKTo6WsWLF1fZsmXVsmVLLV26VNK5cyzefvttSXJ7i0VyP99i0qRJrhp++uknnT17Vs8//7yaNm2qUqVKqWTJkmrVqpVWrFjhVv/5c7z++uuKjIxUUFCQWrdure3bt1/Wc9uwYUNNmjRJp06d0ltvveVan985KuvXr1dMTIzKlSunoKAgVatWTQ899JCrxvDwcElSXFyc6znIfTusX79+Cg4O1t69e9WpUyeFhISoT58+rvvOP0flfJfqt02bNq79dL7z57xUbfmdo1KQnxnp3M/NnXfeqf/9739q1qyZihcvrhtvvFEzZ87M/wkHLEE0By5DSkqKfv/9dxljlJycrMmTJys9PV333Xefa4wxRnfffbdWrFih/v37q1GjRlqyZIlGjhypw4cP6/XXX3eNffjhhzVjxgz17NlTw4cP19q1axUfH68dO3ZowYIFkqRJkybp8ccfV3BwsJ599llJUvny5SWd+0MWHx+vhx9+WM2aNVNqaqrWr1+vjRs36o477tDAgQN15MgRLV26VP/5z3/y7SkhIUFnzpzRI488IqfTqTJlyig1NVUffPCBevfurQEDBigtLU3Tpk1TTEyMfvjhBzVq1MhtjpkzZyotLU2DBg3SmTNn9MYbb+j222/Xtm3bXLUWRs+ePdW/f3999dVXGjt2bL5jkpOT1aFDB4WHh+uZZ55RWFiY9u/fr/nz50uSwsPDNWXKFD322GPq1q2bunfvLklq0KCBa46srCzFxMSoZcuWevXVV1WiRImL1uWtfgtS218V5Gcm1549e1zPYd++fTV9+nT169dPTZs2Vd26dQtcJ3BFGQAeS0hIMJLy3JxOp0lMTHQb++mnnxpJ5qWXXnJb37NnT+NwOMyePXuMMcZs3rzZSDIPP/yw27gRI0YYSebrr792ratbt65p3bp1nroaNmxoOnfufNHaBw0aZPJ76e/bt89IMqGhoSY5OdntvqysLJORkeG27uTJk6Z8+fLmoYceyjNHUFCQOXTokGv92rVrjSTz5JNPXrS2FStWGElm3rx5FxzTsGFDU7p0addy7r7Yt2+fMcaYBQsWGElm3bp1F5zj2LFjRpIZPXp0nvv69u1rJJlnnnkm3/siIyNdy57027p163z32V/nvFhto0ePdtt3nvzMREZGGknm22+/da1LTk42TqfTDB8+PM+2AFvw1g9wGd5++20tXbpUS5cu1Ycffqi2bdvq4Ycfdv3rXTp38qqfn5+GDBni9tjhw4fLGOO6SuiLL76QJA0bNizPOElatGjRJesJCwvTjz/+qN27dxe6px49erjefsjl5+fnOk8lJydHJ06cUFZWlm6++WZt3Lgxzxxdu3bVDTfc4Fpu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vvlmnTx5UkFBQa713bp10/Lly71aHAAAuL55fERl1apV+v777/N8AWFUVJQOHz7stcIAAAA8PqKSk5Oj7OzsPOsPHTqkkJAQrxQFAAAgFSKodOjQQZMmTXItOxwOpaena/To0Zf9sfoAAADn8/itn9dee00xMTGqU6eOzpw5o3/+85/avXu3ypUrp1mzZhVFjQAA4DrlcVCpXLmytmzZotmzZ2vr1q1KT09X//791adPH7eTawEAAC6Xx0FFkvz9/XXfffd5uxYAAAA3HgeVmTNnXvT+Bx54oNDFAAAAnM/joDJ06FC35czMTP3xxx8KDAxUiRIlCCoAAMBrPL7q5+TJk2639PR07dy5Uy1btuRkWgAA4FWF+q6fv4qOjtb48ePzHG0BAAC4HF4JKtK5E2yPHDnirekAAAA8P0dl4cKFbsvGGCUlJemtt97Srbfe6rXCAAAAPA4qXbt2dVt2OBwKDw/X7bffrtdee81bdQEAAHgeVHJycoqiDgAAgDy8do4KAACAt3l8RGXYsGEFHjtx4kRPpwcAAHDxOKhs2rRJmzZtUmZmpmrVqiVJ2rVrl/z8/NSkSRPXOIfD4b0qAQDAdcnjoHLXXXcpJCREM2bMUOnSpSWd+xC4Bx98UK1atdLw4cO9XiQAALg+eXyOymuvvab4+HhXSJGk0qVL66WXXuKqHwAA4FUeB5XU1FQdO3Ysz/pjx44pLS3NK0UBAABIhQgq3bp104MPPqj58+fr0KFDOnTokP773/+qf//+6t69e1HUCAAArlMen6MydepUjRgxQv/85z+VmZl5bhJ/f/Xv318TJkzweoEAAOD65XFQKVGihN555x1NmDBBe/fulSRVr15dJUuW9HpxAADg+lboD3xLSkpSUlKSoqOjVbJkSRljvFkXAACA50Hl+PHjateunWrWrKlOnTopKSlJktS/f38uTQYAAF7lcVB58sknFRAQoAMHDqhEiRKu9b169dKXX37p1eIAAMD1zeNzVL766istWbJElStXdlsfHR2tX3/91WuFAQAAeHxE5fTp025HUnKdOHFCTqfTK0UBAABIhQgqrVq10syZM13LDodDOTk5euWVV9S2bVuvFgcAAK5vHr/188orr6hdu3Zav369zp49q6eeeko//vijTpw4oe+++64oagQAANcpj4+o1KtXT7t27VLLli3VpUsXnT59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IqgAAABrEVQAAIC1CCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1rAgqb7/9tqKiolS8eHE1b95cP/zwg69LAgAAFvB5UJkzZ46GDRum0aNHa+PGjWrYsKFiYmKUnJzs69IAAICP+TyoTJw4UQMGDNCDDz6oOnXqaOrUqSpRooSmT5/u69IAAICP+TSonD17Vhs2bFD79u1d64oVK6b27dtr9erVPqwMAADYwN+XG//999+VnZ2t8uXLu60vX768fv755zzjMzIylJGR4VpOSUmRJKWmphZJfTkZf3hlnqKqz9e89fwAgKe89XvVxt/ztv1uLYq/YblzGmMuOdanQcVT8fHxiouLy7O+SpUqPqim4EpN8nUFAHBtse33qm31eFNR9paWlqZSpUpddIxPg0q5cuXk5+en3377zW39b7/9pgoVKuQZP2rUKA0bNsy1nJOToxMnTqhs2bJyOBxFXm9RS01NVZUqVXTw4EGFhob6upwiRa/XnuulT4ler0XXS5+SHb0aY5SWlqZKlSpdcqxPg0pgYKCaNm2q5cuXq2vXrpLOhY/ly5dr8ODBecY7nU45nU63dWFhYVeg0isrNDT0mn+h5KLXa8/10qdEr9ei66VPyfe9XupISi6fv/UzbNgw9e3bVzfffLOaNWumSZMm6fTp03rwwQd9XRoAAPAxnweVXr166dixY3r++ed19OhRNWrUSF9++WWeE2wBAMD1x+dBRZIGDx6c71s91xun06nRo0fneXvrWkSv157rpU+JXq9F10uf0tXXq8MU5NogAAAAH/D5J9MCAABcCEEFAABYi6ACAACsRVABAADWIqhchrfffltRUVEqXry4mjdvrh9++OGi4+fNm6ebbrpJxYsXV/369fXFF19ccOyjjz4qh8OhSZMmua2PioqSw+Fwu40fP95tzNatW9WqVSsVL15cVapU0SuvvFLoHnNd6V5XrlyZp8/c27p16yRJ+/fvz/f+NWvWWNNnv3798tQXGxvrNubEiRPq06ePQkNDFRYWpv79+ys9Pd1tzNWwTy/V6/79+9W/f39Vq1ZNQUFBql69ukaPHq2zZ8+6jfH2PvVFr5JvXqtXuk9fvU6LoldJ2rFjh+6++26VKlVKJUuW1C233KIDBw647j9z5owGDRqksmXLKjg4WD169MjzyeoHDhxQ586dVaJECUVERGjkyJHKysq6qno9ceKEHn/8cdWqVUtBQUGqWrWqhgwZ4vp+vVz57dfZs2dfVq/5MiiU2bNnm8DAQDN9+nTz448/mgEDBpiwsDDz22+/5Tv+u+++M35+fuaVV14xP/30k3nuuedMQECA2bZtW56x8+fPNw0bNjSVKlUyr7/+utt9kZGR5oUXXjBJSUmuW3p6uuv+lJQUU758edOnTx+zfft2M2vWLBMUFGTefffdq6rXjIwMtx6TkpLMww8/bKpVq2ZycnKMMcbs27fPSDLLli1zG3f27Flr+uzbt6+JjY11q+/EiRNu88TGxpqGDRuaNWvWmFWrVpkaNWqY3r17u+6/WvbppXpdvHix6devn1myZInZu3ev+eyzz0xERIQZPny4a4y396mvejXmyr9WfdGnL16nRdXrnj17TJkyZczIkSPNxo0bzZ49e8xnn33mNuejjz5qqlSpYpYvX27Wr19v/va3v5m///3vrvuzsrJMvXr1TPv27c2mTZvMF198YcqVK2dGjRp1VfW6bds20717d7Nw4UKzZ88es3z5chMdHW169Ojhti1JJiEhwW2//vnnn4Xu9UIIKoXUrFkzM2jQINdydna2qVSpkomPj893/D/+8Q/TuXNnt3XNmzc3AwcOdFt36NAhc8MNN5jt27ebyMjIfIPKX9ed75133jGlS5c2GRkZrnVPP/20qVWrVgE7y8tXvZ7v7NmzJjw83Lzwwguudbm/ADdt2uR5U/koij779u1runTpcsFt/vTTT0aSWbdunWvd4sWLjcPhMIcPHzbGXD379FK95ueVV14x1apVcy17e58a47ter/Rr1YZ9eiVep8YUTa+9evUy99133wW3eerUKRMQEGDmzZvnWrdjxw4jyaxevdoYY8wXX3xhihUrZo4ePeoaM2XKFBMaGuq2nz3hi17zM3fuXBMYGGgyMzNd6ySZBQsWeDRPYfDWTyGcPXtWGzZsUPv27V3rihUrpvbt22v16tX5Pmb16tVu4yUpJibGbXxOTo7uv/9+jRw5UnXr1r3g9sePH6+yZcuqcePG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GLVo0UKrVq2Sv7+/XnrpJcXGxmrr1q0KDAws1LwAziGoANewpKQkZWVlqXv37oqMjJQk1a9f33V/UFCQMjIy8rxl89xzz7n+PyoqSiNGjNDs2bP11FNPKSgoSMHBwfL397/oWz0HDhxQdHS0WrZsKYfD4dq+JIWHh0s6d2TiYnO89NJLGj58uIYOHepad8stt+Q71s/PT/fee68+/vhjV1BZvny5Tp06pR49ekiSbrjhBo0YMcL1mMcff1xLlizR3LlzCx1U5syZo5ycHH3wwQdyOBySpISEBIWFhWnlypXq0KFDoeYFcA5BBbiGNWzYUO3atVP9+vUVExOjDh06qGfPnipduvRFHzdnzhy9+eab2rt3r9LT05WVlaXQ0FCPtt2vXz/dcccdqlWrlmJjY3XnnXd69Ec7OTlZR44cUbt27Qr8mD59+uhvf/ubjhw5okqVKumjjz5S586dFRYWJuncEZZx48Zp7ty5Onz4sM6ePauMjAyVKFHCo97Ot2XLFu3Zs0chISFu68+cOaO9e/cWel4A53COCnAN8/Pz09KlS7V48WLVqVNHkydPVq1atbRv374LPmb16tXq06ePOnXqpM8//1ybNm3Ss88+q7Nnz3q07SZNmmjfvn168cUX9eeff+of//iHevbsWeDHBwUFebQ96dzRlurVq2v27Nn6888/tWDBAvXp08d1/4QJE/TGG2/o6aef1ooVK7R582bFxMRctDeHwyFjjNu63PN1JCk9PV1NmzbV5s2b3W67du3SP//5T497AOCOIyrANc7hcOjWW2/Vrbfequeff16RkZFasGCBhg0bpsDAQGVnZ7uN//777xUZGalnn33Wte7XX391G5Pf4/ITGhqqXr16qVevXurZs6diY2N14sQJlSlTRgEBARedIyQkRFFRUVq+fLnatm1b4H779Omjjz76SJUrV1axYsXUuXNn133fffedunTpovvuu0+SlJOTo127dqlOnToXnC88PFxJSUmu5d27d+uPP/5wLTdp0kRz5sxRRESEx0edAFwaR1SAa9jatWs1btw4rV+/XgcOHND8+fN17Ngx1a5dW9K580+2bt2qnTt36vfff1dmZqaio6N14MABzZ49W3v37tWbb76pBQsWuM0bFRWlffv2afPmzfr999+VkZGRZ9sTJ07UrFmz9PPPP2vXrl2aN2+eKlSo4HobJjeEHD16VCdPnsy3/jFjxui1117Tm2++qd27d2vjxo2aPHnyRXvu06ePNm7cqLFjx6pnz55yOp2u+6Kjo7V06VJ9//332rFjhwYOHKjffvvtovPdfvvteuutt7Rp0yatX79ejz76qAICAty2V65cOXXp0kWrVq3Svn37tHLlSg0ZMkSHDh266NwACsAAuGb99NNPJiYmxoSHhxun02lq1qxpJk+e7Lo/OTnZ3HHHHSY4ONhIMitWrDDGGDNy5EhTtmxZExwcbHr16mVef/11U6pUKdfjzpw5Y3r06GHCwsKMJJOQkGCMMUaSWbBggTHGmPfee880atTIlCxZ0oSGhpp27dqZjRs3uuZYuHChqVGjhvH39zeRkZHGGGNGjx5tGjZs6NbD1KlTTa1atUxAQICpWLGiefzxxy/Zd7NmzYwk8/XXX7utP378uOnSpYsJDg42ERER5rnnnjMPPPCA6dKli2tM69atzdChQ13Lhw8fNh06dDAlS5Y00dHR5osvvjClSpVy9WyMMUlJSeaBBx4w5cqVM06n09x4441mwIABJiUl5ZK1Arg4hzF/efMVAADAErz1AwAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWIqgAAABrEVQAAIC1/h/t/wmQd87mfAAAAABJRU5ErkJggg==",
      "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": "bd0e52f3-8803-4e62-8511-f6c7776d9019",
   "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
}
