{
 "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": [
       "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": [],
   "source": [
    "scores_list = []\n",
    "with open(\"gen_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(\"gen_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/12500-0.5/lds-val/sd-lora-sub-{}-{}/e-{}-gen.pkl'.format(i, seed, e_seed), 'rb')  as handle:\n",
    "                loss_list = pickle.load(handle)\n",
    "            margins = np.concatenate(loss_list, axis=-1) # -logp\n",
    "            ####\n",
    "            if (seed==0) and (e_seed)==0:\n",
    "                loss_array = margins\n",
    "            else:\n",
    "                loss_array += margins\n",
    "            \n",
    "    loss_array = loss_array/(3*3)\n",
    "    \n",
    "    loss_array_list.append(loss_array)\n",
    "lds_loss_array = np.stack(loss_array_list)\n",
    "lds_loss_array.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4214c4b5-d74f-4e52-8c45-1f20ea8d4b38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8d0f643-d0aa-433d-8586-e75351bdd70f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "79b46713-e348-490c-8c4c-9f57068935cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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, 12500)"
      ]
     },
     "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/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": 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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r862KLqiyN3dIZd4sy4REV352K5NREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESSwFBDREREksBQQ0RERJLAUENERESS0KNQs3r1asTGxsLNzQ3p6enYt29fh8seP34cM2fORGxsLGQyGVatWtVmmb///e+QyWQuU3Jysssyzc3NWLRoEQICAuDl5YWZM2eisrKyJ8UnIiIiCep2qFm/fj2WLFmCZcuW4eDBg0hJScG0adNQVVXV7vImkwnx8fFYsWIFQkNDO1zvoEGDUF5e7px27tzp8vrixYuxadMmfPbZZ9i+fTvKyspwxx13dLf4REREJFHdDjUrV67Egw8+iPnz52PgwIFYs2YNPDw88O6777a7/KhRo/Diiy9i9uzZ0Gg0Ha5XqVQiNDTUOQUGBjpf0+l0+M9//oOVK1di8uTJSE1NxXvvvYddu3Zhz5493f0IREREJEHdCjUWiwWZmZmYOnXq2RXI5Zg6dSp27959UQXJy8tDeHg44uPjMWfOHBQXFztfy8zMhNVqddlucnIyoqOjO9yu2WyGXq93mYiIiEi6uhVqampqYLfbERIS4jI/JCQEFRUVPS5Eeno63n//fWzevBlvvvkmCgsLcd1118FgMAAAKioqoFar4evr2+XtLl++HFqt1jlFRUX1uHxERER05bsi7n66+eabcdddd2Ho0KGYNm0avvvuOzQ0NODTTz/t8TqXLl0KnU7nnEpKSnqxxERERHSlUXZn4cDAQCgUijZ3HVVWVnY6CLi7fH19kZSUhPz8fABAaGgoLBYLGhoaXFprOtuuRqPpdAwPERERSUu3WmrUajVSU1ORkZHhnOdwOJCRkYExY8b0WqEaGxtx6tQphIWFAQBSU1Oh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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.490444)\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.085 (avg p value 0.417661)\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.045 (avg p value 0.481810)\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.093 (avg p value 0.413511)\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.042 (avg p value 0.488311)\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.084 (avg p value 0.416750)\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.046 (avg p value 0.487855)\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.094 (avg p value 0.410944)\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.021746085101338408, high=0.05346212645853953)\n",
      "0.022\n",
      "0.053\n",
      "1\n",
      "ConfidenceInterval(low=0.06632828273525802, high=0.1014772001797761)\n",
      "0.066\n",
      "0.101\n",
      "2\n",
      "ConfidenceInterval(low=0.027218899119335303, high=0.0586341039424256)\n",
      "0.027\n",
      "0.059\n",
      "3\n",
      "ConfidenceInterval(low=0.07432470093047853, high=0.11064469699400524)\n",
      "0.074\n",
      "0.111\n",
      "4\n",
      "ConfidenceInterval(low=0.0255631913513133, high=0.05538207854518293)\n",
      "0.026\n",
      "0.055\n",
      "5\n",
      "ConfidenceInterval(low=0.06492641790397322, high=0.09944640465366245)\n",
      "0.065\n",
      "0.099\n",
      "6\n",
      "ConfidenceInterval(low=0.029599955089898596, high=0.05911172453238731)\n",
      "0.03\n",
      "0.059\n",
      "7\n",
      "ConfidenceInterval(low=0.07430079159915154, high=0.10935738251778006)\n",
      "0.074\n",
      "0.109\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(\"./gen_res_list.pkl\", 'wb') as handle:\n",
    "    pickle.dump([[res.confidence_interval.low, res.confidence_interval.high, res.bootstrap_distribution, res.standard_error] for res in res_list],\n",
    "                handle)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9859c520-7da2-416e-a5c8-05bff6b939d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "af844177-9c54-4ad6-b655-a57ec35ae71e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAHHCAYAAACRAnNyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAxcElEQVR4nO3deZzNZf/H8fcxyzHGMJYZSzRjL3tI9aOsGYyy/pLIktTdTZQl3C3MbRlSUipuZW1BdVM9aDGJEiLZ0mLLbhiEsWSMOdfvDw/n5zRDc8Y5zmXm9Xw8zqO+33N9r+/nOteZzrvvco7DGGMEAABgoXyBLgAAAOBKCCoAAMBaBBUAAGAtggoAALAWQQUAAFiLoAIAAKxFUAEAANYiqAAAAGsRVAAAgLUIKgBuaLNmzZLD4dDu3bv9vq+ePXsqNjbWvbx79245HA699NJLft+3JI0cOVIOh+O67AuwBUEFyIFLH46XP6Kjo9WkSRN9/vnnft//m2++qVmzZuVo288++0wjR470aT2+snz5co/X1Ol0qkSJEmrcuLHGjh2rI0eO+GQ/Z8+e1ciRI7V8+XKf9OdLNtcGBAJBBbgG//73v/XOO+9ozpw5euaZZ3TkyBG1bt1aixYt8ut+rzWoJCQk+LYgH+vfv7/eeecdTZs2TUOGDFHRokU1YsQI3Xrrrfr666892j788MP6888/FRMTk+3+z549q4SEBK/DwFtvvaWtW7d6tY23rlbbc889pz///NOv+wdsExzoAoAbWatWrVSvXj33cu/evVWiRAnNnTtXbdq0CWBlvnHhwgW5XC6FhoZe1/3efffd6tSpk8e6TZs2qUWLFurYsaN++eUXlSpVSpIUFBSkoKAgv9Zz5swZhYeHKyQkxK/7+TvBwcEKDuY/28hbOKIC+FBkZKTCwsIyfZicOXNGgwYNUtmyZeV0OlWlShW99NJL+uuPl1+4cEGjRo1ShQoV5HQ6FRsbq3/9619KS0tzt4mNjdXPP/+sb775xn2KpHHjxpKk9PR0JSQkqFKlSsqfP7+KFSumhg0bKikpSdLFayzeeOMNSfI4xSJ5Xm8xadIkdw2//PKLzp8/rxdeeEF169ZV4cKFFR4errvvvlvLli3zqP/yPl555RXFxMQoLCxMjRo10pYtW67pta1Vq5YmTZqkEydO6PXXX3evz+oalXXr1ikuLk7FixdXWFiYypUrp0ceecRdY1RUlCQpISHB/RpcOh3Ws2dPFSxYUDt37lTr1q0VERGhrl27up+7/BqVy/3deBs3buyep8td3uff1ZbVNSrZec9IF983bdq00Xfffaf69esrf/78Kl++vObMmZP1Cw5YgmgOXIOTJ0/q6NGjMsYoJSVFkydP1unTp9WtWzd3G2OM7r//fi1btky9e/dW7dq19eWXX2rIkCE6cOCAXnnlFXfbRx99VLNnz1anTp00aNAgrVmzRomJifr111+1cOFCSdKkSZP05JNPqmDBgnr22WclSSVKlJB08YMsMTFRjz76qOrXr6/U1FStW7dO69ev17333qvHH39cBw8eVFJSkt55550sxzRz5kydO3dOjz32mJxOp4oWLarU1FS9/fbb6tKli/r06aNTp05p+vTpiouL09q1a1W7dm2PPubMmaNTp06pb9++OnfunF599VU1bdpUP/30k7vWnOjUqZN69+6tJUuWaMyYMVm2SUlJUYsWLRQVFaVhw4YpMjJSu3fv1oIFCyRJUVFRmjJlip544gm1b99eHTp0kCTVrFnT3ceFCxcUFxenhg0b6qWXXlKBAgWuWpevxpud2v4qO++ZS3bs2OF+DXv06KEZM2aoZ8+eqlu3rqpVq5btOoHrygDw2syZM42kTA+n02lmzZrl0fbjjz82kszo0aM91nfq1Mk4HA6zY8cOY4wxGzduNJLMo48+6tFu8ODBRpL5+uuv3euqVatmGjVqlKmuWrVqmfj4+KvW3rdvX5PVn/6uXbuMJFOoUCGTkpLi8dyFCxdMWlqax7rjx4+bEiVKmEceeSRTH2FhYWb//v3u9WvWrDGSzNNPP33V2pYtW2YkmQ8//PCKbWrVqmWKFCniXr40F7t27TLGGLNw4UIjyfzwww9X7OPIkSNGkhkxYkSm53r06GEkmWHDhmX5XExMjHvZm/E2atQoyzn7a59Xq23EiBEec+fNeyYmJsZIMt9++617XUpKinE6nWbQoEGZ9gXYglM/wDV44403lJSUpKSkJL377rtq0qSJHn30Uff/vUsXL14NCgpS//79PbYdNGiQjDHuu4Q+++wzSdLAgQMztZOkxYsX/209kZGR+vnnn7V9+/Ycj6ljx47u0w+XBAUFua9Tcblc+uOPP3ThwgXVq1dP69evz9RHu3btdNNNN7mX69evrzvuuMM9xmtRsGBBnTp16orPR0ZGSpIWLVqk9PT0HO/niSeeyHZbf473arx9z1StWlV33323ezkqKkpVqlTR77//7tc6gWtBUAGuQf369dW8eXM1b95cXbt21eLFi1W1alX169dP58+flyTt2bNHpUuXVkREhMe2t956q/v5S//Mly+fKlas6NGuZMmSioyMdLe7mn//+986ceKEKleurBo1amjIkCHavHmzV2MqV65clutnz56tmjVruq99iYqK0uLFi3Xy5MlMbStVqpRpXeXKlX3yXSenT5/O9FperlGjRurYsaMSEhJUvHhxtW3bVjNnzsx0zcbVBAcHq0yZMtlu78/xXo2375mbb745Ux9FihTR8ePH/VoncC0IKoAP5cuXT02aNFFycnKOj2pcyxd63XPPPdq5c6dmzJih6tWr6+2331adOnX09ttvZ7uPsLCwTOveffdd9ezZUxUqVND06dP1xRdfKCkpSU2bNpXL5cpxvd5KT0/Xtm3bMn0wX87hcOijjz7S6tWr1a9fPx04cECPPPKI6tatq9OnT2drP06nU/ny+fY/j1ea14yMDL/1/VdXujvK/OWibsAmBBXAxy5cuCBJ7g/FmJgYHTx4MNPpit9++839/KV/ulyuTAHn8OHDOnHihMf3hFztg6lo0aLq1auX5s6dq3379qlmzZoeX/CWkyD00UcfqXz58lqwYIEefvhhxcXFqXnz5jp37lyW7bMKadu2bbviHTPe1PHnn38qLi7ub9veeeedGjNmjNatW6f33ntPP//8s+bNmyfp2sJgVrIz3iJFiujEiROZ2v31qIc3tXnzngFuVAQVwIfS09O1ZMkShYaGuk/ttG7dWhkZGR631EoXb2d1OBxq1aqVu5108a6ey02cOFGSFB8f714XHh6e5YfesWPHPJYLFiyoihUrepz2CA8Pl6Qst7+SS/8nfvn/ea9Zs0arV6/Osv3HH3+sAwcOuJfXrl2rNWvWuMeaE5s2bdJTTz2lIkWKqG/fvldsd/z48UxHCC7dlXTpdbh0F483r8HVZGe8FSpU0G+//ebx7bqbNm3SypUrPfrypjZv3jPAjYrbk4Fr8Pnnn7uPjKSkpOj999/X9u3bNWzYMBUqVEiSdN9996lJkyZ69tlntXv3btWqVUtLlizRJ598oqeeekoVKlSQdPF7Qnr06KFp06bpxIkTatSokdauXavZs2erXbt2atKkiXu/devW1ZQpUzR69GhVrFhR0dHRatq0qapWrarGjRurbt26Klq0qNatW6ePPvpI/fr189hWuvjtr3FxcQoKCtKDDz541XG2adNGCxYsUPv27RUfH69du3Zp6tSpqlq1apanUypWrKiGDRvqiSeeUFpamiZNmqRixYrpmWeeydbrumLFCp07d04ZGRk6duyYVq5cqU8//VSFCxfWwoULVbJkyStuO3v2bL355ptq3769KlSooFOnTumtt95SoUKF3B/sYWFhqlq1qubPn6/KlSuraNGiql69uqpXr56t+nIy3kceeUQTJ05UXFycevfurZSUFE2dOlXVqlVTamqqu503tXnzngFuWIG96Qi4MWV1e3L+/PlN7dq1zZQpU4zL5fJof+rUKfP000+b0qVLm5CQEFOpUiUzYcKETO3S09NNQkKCKVeunAkJCTFly5Y1w4cPN+fOnfNod+jQIRMfH28iIiKMJPdtr6NHjzb169c3kZGRJiwszNxyyy1mzJgx5vz58+5tL1y4YJ588kkTFRVlHA6H+3bXS7faTpgwIdN4XS6XGTt2rImJiTFOp9PcdtttZtGiRVe8XXfChAnm5ZdfNmXLljVOp9PcfffdZtOmTX/7ul66PfnSIyQkxERFRZl77rnHjBkzJtNt05fPxaXbk9evX2+6dOlibr75ZuN0Ok10dLRp06aNWbduncd2q1atMnXr1jWhoaEetwP36NHDhIeHZ1nftY733XffNeXLlzehoaGmdu3a5ssvv8zU59Vq++vtycZk/z0TExOT5a3rV7ptGrCFwxiuogLgG7t371a5cuU0YcIEDR48ONDlAMgFuEYFAABYi6ACAACsRVABAADW4hoVAABgLY6oAAAAaxFUAACAtW7oL3xzuVw6ePCgIiIifP6V2AAAwD+MMTp16pRKly79t7+rdUMHlYMHD6ps2bKBLgMAAOTAvn37/vaXym/ooHLpp9737dvn/rpyAABgt9TUVJUtW9b9OX41N3RQuXS6p1ChQgQVAABuMNm5bIOLaQEAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACwFkEFAABYi6ACAACsRVABAADWCg50AQBwLWKHLfZJP7vHxfukHwC+xREV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23Tt2lV33nmnDh48qNKlS+u9995TfHy8IiMjJV08wjJ27Fh98MEHOnDggM6fP6+0tDQVKFDAq7FdbtOmTdqxY4ciIiI81p87d047d+7Mcb8ALuIaFSAXCwoKUlJSkj7//HNVrVpVkydPVpUqVbRr164rbrN69Wp17dpVrVu31qJFi7RhwwY9++yzOn/+vFf7rlOnjnbt2qVRo0bpzz//1AMPPKBOnTple/uwsDCv9iddPNpSoUIFzZs3T3/++acWLlyorl27up+fMGGCXn31VQ0dOlTLli3Txo0bFRcXd9WxORwOGWM81l26XkeSTp8+rbp162rjxo0ej23btumhhx7yegwAPHFEBcjlHA6HGjRooAYNGuiFF15QTEyMFi5cqIEDByo0NFQZGRke7VetWqWYmBg9++yz7nV79uzxaJPVdlkpVKiQOnfurM6dO6tTp05q2bKl/vjjDxUtWlQhISFX7SMiIkKxsbFaunSpmjRpku3xdu3aVe+9957KlCmjfPnyKT4+3v3cypUr1bZtW3Xr1k2S5HK5tG3bNlWtWvWK/UVFRSk5Odm9vH37dp09e9a9XKdOHc2fP1/R0dFeH3UC8Pc4ogLkYmvWrNHYsWO1bt067d27VwsWLNCRI0d06623Srp4/cnmzZu1detWHT16VOnp6apUqZL27t2refPmaefOnXrttde0cOFCj35jY2O1a9cubdy4UUePHlVaWlqmfU+cOFFz587Vb7/9pm3btunDDz9UyZIl3adhLoWQQ4cO6fjx41nWP3LkSL388st67bXXtH37dq1fv16TJ0++6pi7du2q9evXa8yYMerUqZOcTqf7uUqVKikpKUmrVq3Sr7/+qscff1yHDx++an9NmzbV66+/rg0bNmjdunX6xz/+oZCQEI/9FS9eXG3bttWKFSu0a9cuLV++XP3799f+/fuv2jeAbDAAcq1ffvnFxMXFmaioKON0Ok3lypXN5MmT3c+npKSYe++91xQsWNBIMsuWLTPGGDNkyBBTrFgxU7BgQdO5c2fzyiuvmMKFC7u3O3funOnYsaOJjIw0kszMmTONMcZIMgsXLjTGGDNt2jRTu3ZtEx4ebgoVKmSaNWtm1q9f7+7j008/NRUrVjTBwcEmJibGGGPMiBEjTK1atTzGMHXqVFOlShUTEhJiSpUqZZ588sm/HXf9+vWNJPP11197rD927Jhp27atKViwoImOjjbPPfec6d69u2nbtq27TaNGjcyAAQPcywcOHDAtWrQw4eHhplKlSuazzz4zhQsXdo/ZGGOSk5NN9+7dTfHixY3T6TTly5c3ffr0MSdPnvzbWgFcncOYv5x8BQAAsASnfgAAgLUIKgAAwFoEFQAAYC2CCgAAsBZBBQAAWIugAgAArEVQAQAA1iKoAAAAaxFUAACAtQgqAADAWgQVAABgLYIKAACw1v8BGHkIcriR168AAAAASUVORK5CYII=",
      "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
}
