{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Experimental Results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import necessary packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle as pkl\n",
    "import os\n",
    "import pandas as pd\n",
    "from itertools import product\n",
    "import scipy.stats as stats\n",
    "from scipy.stats import gaussian_kde\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore', category=DeprecationWarning)\n",
    "from collections import defaultdict\n",
    "\n",
    "# ============ Global Constants ============\n",
    "METHODS = ['gpt-0613', 'cot-gpt-0613', 'gpt-0125', 'cot-gpt-0125', \n",
    "           'gpt-4', 'cot-gpt-4', 'gpt-4o', 'cot-gpt-4o', 'fs-gpt-4o', 'ft-gpt-4o']\n",
    "ESTIMATORS = ['dml', 'ppi', 'ppi++', 'primary', 'naive']\n",
    "N_REALS = [50, 100, 150, 200]\n",
    "N_TRIALS = 50\n",
    "N_MAX_AUG = 1000\n",
    "\n",
    "# Color and legend mappings for plots\n",
    "COLOR_MAP = {\"dml\": \"orange\", \"ppi\": \"blue\", \"ppi++\": \"green\"}\n",
    "LEGEND_MAP = {\"dml\": \"GAI\", \"ppi\": \"PPI\", \"ppi++\": \"PPI++\"}\n",
    "\n",
    "# ============ Helper Functions ============\n",
    "def get_res_file_path(estimator, method, n_real, n_max_aug, n_trials, for_ci=False):\n",
    "    \"\"\"Get the result file path based on estimator type.\"\"\"\n",
    "    base_dir = '../res_dml' if estimator == 'dml' else ('../res_ci' if for_ci else '../res')\n",
    "    file_estimator = 'naive' if estimator == 'primary' else estimator\n",
    "    return f'{base_dir}/{file_estimator}_{method}_{n_real}_{n_max_aug}_{n_trials}.pkl'\n",
    "\n",
    "\n",
    "def load_result_file(filepath):\n",
    "    \"\"\"Load a pickle result file if it exists.\"\"\"\n",
    "    if not os.path.exists(filepath):\n",
    "        return None\n",
    "    with open(filepath, 'rb') as f:\n",
    "        return pkl.load(f)\n",
    "\n",
    "\n",
    "def compute_ci_bounds(res, estimator, n_aug_target):\n",
    "    \"\"\"\n",
    "    Compute CI lower and upper bounds for a given estimator.\n",
    "    Returns: (idx, ci_lower, ci_upper, param_est) or None if no matching data.\n",
    "    \"\"\"\n",
    "    n_aug_list = np.array(res['n_aug_list'])\n",
    "    params_est_list = np.array(res['params_list'])\n",
    "    \n",
    "    # Determine target n_aug based on estimator\n",
    "    target_aug = 0 if estimator == 'primary' else n_aug_target\n",
    "    idx = np.where(n_aug_list == target_aug)[0]\n",
    "    \n",
    "    if len(idx) == 0:\n",
    "        return None\n",
    "    \n",
    "    param_est = params_est_list[idx]\n",
    "    \n",
    "    if estimator in ['primary', 'dml', 'naive']:\n",
    "        se = np.array([res['se_list'][i] for i in idx])\n",
    "        ci_lower = param_est - 1.96 * se\n",
    "        ci_upper = param_est + 1.96 * se\n",
    "    else:  # ppi, ppi++\n",
    "        ci = np.array([res['params_ci_list'][i] for i in idx])\n",
    "        ci_lower = ci[:, 0]\n",
    "        ci_upper = ci[:, 1]\n",
    "    \n",
    "    return idx, ci_lower, ci_upper, param_est\n",
    "\n",
    "\n",
    "def compute_trial_coverage_width(ci_lower, ci_upper, params_true):\n",
    "    \"\"\"Compute average coverage and width for a single trial.\"\"\"\n",
    "    if np.isscalar(ci_lower):\n",
    "        coverage = float((params_true >= ci_lower) & (params_true <= ci_upper))\n",
    "        width = float(ci_upper - ci_lower)\n",
    "    else:\n",
    "        coverage = np.mean((params_true >= ci_lower) & (params_true <= ci_upper))\n",
    "        width = np.mean(ci_upper - ci_lower)\n",
    "    return coverage, width"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load ground truth parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ground truth parameters: [ 0.36310104  0.7465673   0.32377172 -0.21252407  0.08090729 -0.09540857\n",
      " -0.40639496 -0.15332593 -0.24158926  0.17760716 -0.04599298]\n"
     ]
    }
   ],
   "source": [
    "# Load ground truth parameters\n",
    "with open('../data/ground_truth.pkl', 'rb') as f:\n",
    "    res = pkl.load(f)\n",
    "    params = res['params']\n",
    "print('Ground truth parameters:', params)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MAPE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_bias(n_trials, n_real, n_max_aug, g_models, methods, metric='rbias', display=True):\n",
    "    \"\"\"Compute bias metrics for all method/model combinations.\"\"\"\n",
    "    y = defaultdict(lambda: (float('inf'), float('inf'), float('inf')))\n",
    "    \n",
    "    for method, g_model in product(methods, g_models):\n",
    "        res_file = get_res_file_path(g_model, method, n_real, n_max_aug, n_trials)\n",
    "        res = load_result_file(res_file)\n",
    "        \n",
    "        if res is None:\n",
    "            if display:\n",
    "                print(f'{g_model}\\t{method}\\t-')\n",
    "            continue\n",
    "            \n",
    "        n_aug_list = res['n_aug_list']\n",
    "        n_real_list = res['n_real_list']\n",
    "        sample_id_list = res['sample_id_list']\n",
    "        params_est_list = np.array(res['params_list'])\n",
    "        \n",
    "        bias_list = []\n",
    "        for i in range(11):\n",
    "            df = pd.DataFrame({\n",
    "                'n_real': n_real_list, 'n_aug': n_aug_list, \n",
    "                'sample_id': sample_id_list, 'param': params_est_list[:, i],\n",
    "                'e': np.abs(params_est_list[:, i] - params[i]),\n",
    "                're': np.abs(params_est_list[:, i] - params[i]) / (np.abs(params[i]) + 1),\n",
    "                'se': (params_est_list[:, i] - params[i])**2\n",
    "            })\n",
    "            df_agg = df.groupby(['n_aug']).agg(\n",
    "                bias=('e', 'mean'), rbias=('re', 'mean'),\n",
    "                var=('param', lambda x: np.var(x, ddof=0)), mse=('se', 'mean')\n",
    "            ).reset_index()\n",
    "            bias_list.append(np.array(df_agg[metric]) * 100)\n",
    "        \n",
    "        bias_list = np.array(bias_list)\n",
    "        if display:\n",
    "            print(f'{g_model}\\t{method}\\t{np.mean(bias_list[:, -1]):.3f}')\n",
    "        y[method, g_model] = (\n",
    "            np.mean(bias_list[:, -1]), \n",
    "            np.mean(bias_list[:, 0].reshape(11, 1)), \n",
    "            np.mean(bias_list[:, -1].reshape(11, 1))\n",
    "        )\n",
    "    return y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"5\" halign=\"left\">50</th>\n",
       "      <th colspan=\"5\" halign=\"left\">100</th>\n",
       "      <th colspan=\"5\" halign=\"left\">150</th>\n",
       "      <th colspan=\"5\" halign=\"left\">200</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>Primary</th>\n",
       "      <th>Naive</th>\n",
       "      <th>PPI</th>\n",
       "      <th>PPI++</th>\n",
       "      <th>DML</th>\n",
       "      <th>Primary</th>\n",
       "      <th>Naive</th>\n",
       "      <th>PPI</th>\n",
       "      <th>PPI++</th>\n",
       "      <th>DML</th>\n",
       "      <th>Primary</th>\n",
       "      <th>Naive</th>\n",
       "      <th>PPI</th>\n",
       "      <th>PPI++</th>\n",
       "      <th>DML</th>\n",
       "      <th>Primary</th>\n",
       "      <th>Naive</th>\n",
       "      <th>PPI</th>\n",
       "      <th>PPI++</th>\n",
       "      <th>DML</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>gpt-0613</th>\n",
       "      <td>32.02</td>\n",
       "      <td>21.22</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>18.32</td>\n",
       "      <td>25.27</td>\n",
       "      <td>20.74</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>18.26</td>\n",
       "      <td>19.67</td>\n",
       "      <td>17.62</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>16.68</td>\n",
       "      <td>19.01</td>\n",
       "      <td>17.21</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>17.59</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-0613</th>\n",
       "      <td>32.02</td>\n",
       "      <td>48.83</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>17.23</td>\n",
       "      <td>25.27</td>\n",
       "      <td>45.89</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>17.61</td>\n",
       "      <td>19.67</td>\n",
       "      <td>42.73</td>\n",
       "      <td>39.02</td>\n",
       "      <td>22.60</td>\n",
       "      <td>16.35</td>\n",
       "      <td>19.01</td>\n",
       "      <td>40.10</td>\n",
       "      <td>35.08</td>\n",
       "      <td>21.20</td>\n",
       "      <td>17.22</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-0125</th>\n",
       "      <td>32.02</td>\n",
       "      <td>22.10</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>18.36</td>\n",
       "      <td>25.27</td>\n",
       "      <td>22.06</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>18.30</td>\n",
       "      <td>19.67</td>\n",
       "      <td>20.53</td>\n",
       "      <td>43.82</td>\n",
       "      <td>23.15</td>\n",
       "      <td>17.24</td>\n",
       "      <td>19.01</td>\n",
       "      <td>20.61</td>\n",
       "      <td>35.71</td>\n",
       "      <td>20.92</td>\n",
       "      <td>17.70</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-0125</th>\n",
       "      <td>32.02</td>\n",
       "      <td>42.98</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>17.48</td>\n",
       "      <td>25.27</td>\n",
       "      <td>39.97</td>\n",
       "      <td>50.55</td>\n",
       "      <td>30.41</td>\n",
       "      <td>17.92</td>\n",
       "      <td>19.67</td>\n",
       "      <td>37.40</td>\n",
       "      <td>36.11</td>\n",
       "      <td>23.07</td>\n",
       "      <td>16.64</td>\n",
       "      <td>19.01</td>\n",
       "      <td>35.17</td>\n",
       "      <td>29.95</td>\n",
       "      <td>20.96</td>\n",
       "      <td>17.22</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-4</th>\n",
       "      <td>32.02</td>\n",
       "      <td>44.41</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>16.63</td>\n",
       "      <td>25.27</td>\n",
       "      <td>41.47</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>17.15</td>\n",
       "      <td>19.67</td>\n",
       "      <td>39.70</td>\n",
       "      <td>31.29</td>\n",
       "      <td>22.59</td>\n",
       "      <td>15.80</td>\n",
       "      <td>19.01</td>\n",
       "      <td>38.21</td>\n",
       "      <td>29.91</td>\n",
       "      <td>20.95</td>\n",
       "      <td>16.48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-4</th>\n",
       "      <td>32.02</td>\n",
       "      <td>50.14</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>16.79</td>\n",
       "      <td>25.27</td>\n",
       "      <td>47.75</td>\n",
       "      <td>48.56</td>\n",
       "      <td>29.40</td>\n",
       "      <td>17.37</td>\n",
       "      <td>19.67</td>\n",
       "      <td>46.00</td>\n",
       "      <td>33.54</td>\n",
       "      <td>22.62</td>\n",
       "      <td>15.96</td>\n",
       "      <td>19.01</td>\n",
       "      <td>43.11</td>\n",
       "      <td>29.21</td>\n",
       "      <td>20.96</td>\n",
       "      <td>16.64</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-4o</th>\n",
       "      <td>32.02</td>\n",
       "      <td>45.08</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>16.66</td>\n",
       "      <td>25.27</td>\n",
       "      <td>42.61</td>\n",
       "      <td>48.32</td>\n",
       "      <td>30.19</td>\n",
       "      <td>17.43</td>\n",
       "      <td>19.67</td>\n",
       "      <td>40.58</td>\n",
       "      <td>33.60</td>\n",
       "      <td>22.91</td>\n",
       "      <td>16.06</td>\n",
       "      <td>19.01</td>\n",
       "      <td>38.65</td>\n",
       "      <td>30.14</td>\n",
       "      <td>20.93</td>\n",
       "      <td>16.97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-4o</th>\n",
       "      <td>32.02</td>\n",
       "      <td>48.52</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>16.86</td>\n",
       "      <td>25.27</td>\n",
       "      <td>45.75</td>\n",
       "      <td>44.57</td>\n",
       "      <td>29.69</td>\n",
       "      <td>17.52</td>\n",
       "      <td>19.67</td>\n",
       "      <td>43.33</td>\n",
       "      <td>32.96</td>\n",
       "      <td>22.96</td>\n",
       "      <td>15.97</td>\n",
       "      <td>19.01</td>\n",
       "      <td>40.29</td>\n",
       "      <td>29.21</td>\n",
       "      <td>21.00</td>\n",
       "      <td>16.64</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fs-gpt-4o</th>\n",
       "      <td>32.02</td>\n",
       "      <td>41.74</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>16.14</td>\n",
       "      <td>25.27</td>\n",
       "      <td>39.83</td>\n",
       "      <td>43.10</td>\n",
       "      <td>29.73</td>\n",
       "      <td>17.00</td>\n",
       "      <td>19.67</td>\n",
       "      <td>38.09</td>\n",
       "      <td>31.35</td>\n",
       "      <td>22.45</td>\n",
       "      <td>15.58</td>\n",
       "      <td>19.01</td>\n",
       "      <td>36.51</td>\n",
       "      <td>30.31</td>\n",
       "      <td>21.19</td>\n",
       "      <td>16.50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ft-gpt-4o</th>\n",
       "      <td>32.02</td>\n",
       "      <td>35.20</td>\n",
       "      <td>-</td>\n",
       "      <td>-</td>\n",
       "      <td>14.83</td>\n",
       "      <td>25.27</td>\n",
       "      <td>33.23</td>\n",
       "      <td>48.17</td>\n",
       "      <td>30.17</td>\n",
       "      <td>15.40</td>\n",
       "      <td>19.67</td>\n",
       "      <td>32.14</td>\n",
       "      <td>32.93</td>\n",
       "      <td>22.54</td>\n",
       "      <td>14.05</td>\n",
       "      <td>19.01</td>\n",
       "      <td>30.32</td>\n",
       "      <td>30.21</td>\n",
       "      <td>20.94</td>\n",
       "      <td>15.38</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 50                              100                       \\\n",
       "             Primary  Naive PPI PPI++    DML Primary  Naive    PPI  PPI++   \n",
       "gpt-0613       32.02  21.22   -     -  18.32   25.27  20.74      -      -   \n",
       "cot-gpt-0613   32.02  48.83   -     -  17.23   25.27  45.89      -      -   \n",
       "gpt-0125       32.02  22.10   -     -  18.36   25.27  22.06      -      -   \n",
       "cot-gpt-0125   32.02  42.98   -     -  17.48   25.27  39.97  50.55  30.41   \n",
       "gpt-4          32.02  44.41   -     -  16.63   25.27  41.47      -      -   \n",
       "cot-gpt-4      32.02  50.14   -     -  16.79   25.27  47.75  48.56  29.40   \n",
       "gpt-4o         32.02  45.08   -     -  16.66   25.27  42.61  48.32  30.19   \n",
       "cot-gpt-4o     32.02  48.52   -     -  16.86   25.27  45.75  44.57  29.69   \n",
       "fs-gpt-4o      32.02  41.74   -     -  16.14   25.27  39.83  43.10  29.73   \n",
       "ft-gpt-4o      32.02  35.20   -     -  14.83   25.27  33.23  48.17  30.17   \n",
       "\n",
       "                        150                                 200                \\\n",
       "                DML Primary  Naive    PPI  PPI++    DML Primary  Naive    PPI   \n",
       "gpt-0613      18.26   19.67  17.62      -      -  16.68   19.01  17.21      -   \n",
       "cot-gpt-0613  17.61   19.67  42.73  39.02  22.60  16.35   19.01  40.10  35.08   \n",
       "gpt-0125      18.30   19.67  20.53  43.82  23.15  17.24   19.01  20.61  35.71   \n",
       "cot-gpt-0125  17.92   19.67  37.40  36.11  23.07  16.64   19.01  35.17  29.95   \n",
       "gpt-4         17.15   19.67  39.70  31.29  22.59  15.80   19.01  38.21  29.91   \n",
       "cot-gpt-4     17.37   19.67  46.00  33.54  22.62  15.96   19.01  43.11  29.21   \n",
       "gpt-4o        17.43   19.67  40.58  33.60  22.91  16.06   19.01  38.65  30.14   \n",
       "cot-gpt-4o    17.52   19.67  43.33  32.96  22.96  15.97   19.01  40.29  29.21   \n",
       "fs-gpt-4o     17.00   19.67  38.09  31.35  22.45  15.58   19.01  36.51  30.31   \n",
       "ft-gpt-4o     15.40   19.67  32.14  32.93  22.54  14.05   19.01  30.32  30.21   \n",
       "\n",
       "                            \n",
       "              PPI++    DML  \n",
       "gpt-0613          -  17.59  \n",
       "cot-gpt-0613  21.20  17.22  \n",
       "gpt-0125      20.92  17.70  \n",
       "cot-gpt-0125  20.96  17.22  \n",
       "gpt-4         20.95  16.48  \n",
       "cot-gpt-4     20.96  16.64  \n",
       "gpt-4o        20.93  16.97  \n",
       "cot-gpt-4o    21.00  16.64  \n",
       "fs-gpt-4o     21.19  16.50  \n",
       "ft-gpt-4o     20.94  15.38  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "g_models = ['nn', 'naive', 'ppi', 'ppi++', 'dml']\n",
    "df = pd.DataFrame()\n",
    "\n",
    "for n_real in N_REALS:\n",
    "    y = compute_bias(n_trials=N_TRIALS, n_real=n_real, n_max_aug=N_MAX_AUG, \n",
    "                     g_models=g_models, methods=METHODS, display=False)\n",
    "    cols = pd.MultiIndex.from_tuples([\n",
    "        (n_real, 'Primary'), (n_real, 'Naive'), (n_real, 'PPI'), \n",
    "        (n_real, 'PPI++'), (n_real, 'DML')\n",
    "    ])\n",
    "    df1 = pd.DataFrame({\n",
    "        cols[0]: [y[method, 'naive'][1] for method in METHODS],\n",
    "        cols[1]: [y[method, 'naive'][0] for method in METHODS],\n",
    "        cols[2]: [y[method, 'ppi'][0] for method in METHODS],\n",
    "        cols[3]: [y[method, 'ppi++'][0] for method in METHODS],\n",
    "        cols[4]: [y[method, 'dml'][0] for method in METHODS]\n",
    "    }, index=METHODS)\n",
    "    df = pd.concat([df, df1], axis=1)\n",
    "\n",
    "# Format the summary table\n",
    "summary_mape = df.map(lambda x: '-' if abs(x) > 1000 else f'{float(x):.2f}')\n",
    "summary_mape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Coverage Probability (%)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"5\" halign=\"left\">50</th>\n",
       "      <th colspan=\"5\" halign=\"left\">100</th>\n",
       "      <th colspan=\"5\" halign=\"left\">150</th>\n",
       "      <th colspan=\"5\" halign=\"left\">200</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>gpt-0613</th>\n",
       "      <td>100.000000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>78.545455</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>69.272727</td>\n",
       "      <td>95.636364</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>86.000000</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>67.818182</td>\n",
       "      <td>92.181818</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>89.454545</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>76.727273</td>\n",
       "      <td>87.090909</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>88.000000</td>\n",
       "      <td>88.0</td>\n",
       "      <td>74.363636</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-0613</th>\n",
       "      <td>99.636364</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>95.818182</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>27.272727</td>\n",
       "      <td>96.909091</td>\n",
       "      <td>99.818182</td>\n",
       "      <td>89.090909</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>27.636364</td>\n",
       "      <td>94.727273</td>\n",
       "      <td>98.000000</td>\n",
       "      <td>90.363636</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>27.454545</td>\n",
       "      <td>90.181818</td>\n",
       "      <td>95.636364</td>\n",
       "      <td>84.727273</td>\n",
       "      <td>88.0</td>\n",
       "      <td>29.090909</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-0125</th>\n",
       "      <td>100.000000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>96.727273</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>38.727273</td>\n",
       "      <td>96.727273</td>\n",
       "      <td>99.818182</td>\n",
       "      <td>88.909091</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>41.090909</td>\n",
       "      <td>92.363636</td>\n",
       "      <td>98.909091</td>\n",
       "      <td>89.818182</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>44.000000</td>\n",
       "      <td>87.454545</td>\n",
       "      <td>97.454545</td>\n",
       "      <td>84.363636</td>\n",
       "      <td>88.0</td>\n",
       "      <td>45.090909</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-0125</th>\n",
       "      <td>100.000000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>93.818182</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>20.000000</td>\n",
       "      <td>97.090909</td>\n",
       "      <td>98.181818</td>\n",
       "      <td>88.363636</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>22.000000</td>\n",
       "      <td>94.181818</td>\n",
       "      <td>96.727273</td>\n",
       "      <td>90.909091</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>24.363636</td>\n",
       "      <td>90.000000</td>\n",
       "      <td>94.545455</td>\n",
       "      <td>84.727273</td>\n",
       "      <td>88.0</td>\n",
       "      <td>27.454545</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-4</th>\n",
       "      <td>99.454545</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>44.545455</td>\n",
       "      <td>97.454545</td>\n",
       "      <td>98.181818</td>\n",
       "      <td>89.636364</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>45.090909</td>\n",
       "      <td>96.181818</td>\n",
       "      <td>96.545455</td>\n",
       "      <td>90.363636</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>45.090909</td>\n",
       "      <td>91.818182</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>84.363636</td>\n",
       "      <td>88.0</td>\n",
       "      <td>45.636364</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-4</th>\n",
       "      <td>99.454545</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>94.181818</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>28.545455</td>\n",
       "      <td>96.909091</td>\n",
       "      <td>99.090909</td>\n",
       "      <td>89.636364</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>28.000000</td>\n",
       "      <td>94.727273</td>\n",
       "      <td>97.636364</td>\n",
       "      <td>90.181818</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>27.272727</td>\n",
       "      <td>91.090909</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>84.363636</td>\n",
       "      <td>88.0</td>\n",
       "      <td>26.181818</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-4o</th>\n",
       "      <td>99.454545</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>94.181818</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>28.363636</td>\n",
       "      <td>97.090909</td>\n",
       "      <td>97.636364</td>\n",
       "      <td>88.909091</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>31.090909</td>\n",
       "      <td>95.090909</td>\n",
       "      <td>96.545455</td>\n",
       "      <td>89.818182</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>33.636364</td>\n",
       "      <td>90.909091</td>\n",
       "      <td>92.000000</td>\n",
       "      <td>84.363636</td>\n",
       "      <td>88.0</td>\n",
       "      <td>36.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-4o</th>\n",
       "      <td>99.818182</td>\n",
       "      <td>99.818182</td>\n",
       "      <td>94.545455</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>26.545455</td>\n",
       "      <td>97.090909</td>\n",
       "      <td>98.000000</td>\n",
       "      <td>89.090909</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>26.363636</td>\n",
       "      <td>94.727273</td>\n",
       "      <td>95.818182</td>\n",
       "      <td>90.909091</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>26.363636</td>\n",
       "      <td>90.909091</td>\n",
       "      <td>92.909091</td>\n",
       "      <td>85.090909</td>\n",
       "      <td>88.0</td>\n",
       "      <td>27.090909</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fs-gpt-4o</th>\n",
       "      <td>99.636364</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>93.818182</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>44.909091</td>\n",
       "      <td>97.090909</td>\n",
       "      <td>98.363636</td>\n",
       "      <td>90.181818</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>47.272727</td>\n",
       "      <td>95.818182</td>\n",
       "      <td>96.545455</td>\n",
       "      <td>90.181818</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>48.181818</td>\n",
       "      <td>91.636364</td>\n",
       "      <td>91.272727</td>\n",
       "      <td>84.727273</td>\n",
       "      <td>88.0</td>\n",
       "      <td>48.909091</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ft-gpt-4o</th>\n",
       "      <td>99.818182</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>94.000000</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>69.090909</td>\n",
       "      <td>97.818182</td>\n",
       "      <td>98.545455</td>\n",
       "      <td>89.636364</td>\n",
       "      <td>92.727273</td>\n",
       "      <td>65.636364</td>\n",
       "      <td>96.545455</td>\n",
       "      <td>95.454545</td>\n",
       "      <td>90.909091</td>\n",
       "      <td>92.545455</td>\n",
       "      <td>66.727273</td>\n",
       "      <td>93.818182</td>\n",
       "      <td>91.272727</td>\n",
       "      <td>84.545455</td>\n",
       "      <td>88.0</td>\n",
       "      <td>64.181818</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                     50                                                \\\n",
       "                     dml         ppi      ppi++    primary      naive   \n",
       "gpt-0613      100.000000  100.000000  78.545455  97.818182  69.272727   \n",
       "cot-gpt-0613   99.636364  100.000000  95.818182  97.818182  27.272727   \n",
       "gpt-0125      100.000000  100.000000  96.727273  97.818182  38.727273   \n",
       "cot-gpt-0125  100.000000  100.000000  93.818182  97.818182  20.000000   \n",
       "gpt-4          99.454545  100.000000  92.545455  97.818182  44.545455   \n",
       "cot-gpt-4      99.454545  100.000000  94.181818  97.818182  28.545455   \n",
       "gpt-4o         99.454545  100.000000  94.181818  97.818182  28.363636   \n",
       "cot-gpt-4o     99.818182   99.818182  94.545455  97.818182  26.545455   \n",
       "fs-gpt-4o      99.636364  100.000000  93.818182  97.818182  44.909091   \n",
       "ft-gpt-4o      99.818182  100.000000  94.000000  97.818182  69.090909   \n",
       "\n",
       "                    100                                               \\\n",
       "                    dml         ppi      ppi++    primary      naive   \n",
       "gpt-0613      95.636364  100.000000  86.000000  92.727273  67.818182   \n",
       "cot-gpt-0613  96.909091   99.818182  89.090909  92.727273  27.636364   \n",
       "gpt-0125      96.727273   99.818182  88.909091  92.727273  41.090909   \n",
       "cot-gpt-0125  97.090909   98.181818  88.363636  92.727273  22.000000   \n",
       "gpt-4         97.454545   98.181818  89.636364  92.727273  45.090909   \n",
       "cot-gpt-4     96.909091   99.090909  89.636364  92.727273  28.000000   \n",
       "gpt-4o        97.090909   97.636364  88.909091  92.727273  31.090909   \n",
       "cot-gpt-4o    97.090909   98.000000  89.090909  92.727273  26.363636   \n",
       "fs-gpt-4o     97.090909   98.363636  90.181818  92.727273  47.272727   \n",
       "ft-gpt-4o     97.818182   98.545455  89.636364  92.727273  65.636364   \n",
       "\n",
       "                    150                                               \\\n",
       "                    dml         ppi      ppi++    primary      naive   \n",
       "gpt-0613      92.181818  100.000000  89.454545  92.545455  76.727273   \n",
       "cot-gpt-0613  94.727273   98.000000  90.363636  92.545455  27.454545   \n",
       "gpt-0125      92.363636   98.909091  89.818182  92.545455  44.000000   \n",
       "cot-gpt-0125  94.181818   96.727273  90.909091  92.545455  24.363636   \n",
       "gpt-4         96.181818   96.545455  90.363636  92.545455  45.090909   \n",
       "cot-gpt-4     94.727273   97.636364  90.181818  92.545455  27.272727   \n",
       "gpt-4o        95.090909   96.545455  89.818182  92.545455  33.636364   \n",
       "cot-gpt-4o    94.727273   95.818182  90.909091  92.545455  26.363636   \n",
       "fs-gpt-4o     95.818182   96.545455  90.181818  92.545455  48.181818   \n",
       "ft-gpt-4o     96.545455   95.454545  90.909091  92.545455  66.727273   \n",
       "\n",
       "                    200                                            \n",
       "                    dml         ppi      ppi++ primary      naive  \n",
       "gpt-0613      87.090909  100.000000  88.000000    88.0  74.363636  \n",
       "cot-gpt-0613  90.181818   95.636364  84.727273    88.0  29.090909  \n",
       "gpt-0125      87.454545   97.454545  84.363636    88.0  45.090909  \n",
       "cot-gpt-0125  90.000000   94.545455  84.727273    88.0  27.454545  \n",
       "gpt-4         91.818182   92.727273  84.363636    88.0  45.636364  \n",
       "cot-gpt-4     91.090909   92.545455  84.363636    88.0  26.181818  \n",
       "gpt-4o        90.909091   92.000000  84.363636    88.0  36.000000  \n",
       "cot-gpt-4o    90.909091   92.909091  85.090909    88.0  27.090909  \n",
       "fs-gpt-4o     91.636364   91.272727  84.727273    88.0  48.909091  \n",
       "ft-gpt-4o     93.818182   91.272727  84.545455    88.0  64.181818  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average CI Width\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"5\" halign=\"left\">50</th>\n",
       "      <th colspan=\"5\" halign=\"left\">100</th>\n",
       "      <th colspan=\"5\" halign=\"left\">150</th>\n",
       "      <th colspan=\"5\" halign=\"left\">200</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "      <th>dml</th>\n",
       "      <th>ppi</th>\n",
       "      <th>ppi++</th>\n",
       "      <th>primary</th>\n",
       "      <th>naive</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>gpt-0613</th>\n",
       "      <td>1.890318</td>\n",
       "      <td>115.884451</td>\n",
       "      <td>2.081016</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.878841</td>\n",
       "      <td>1.346897</td>\n",
       "      <td>39.781490</td>\n",
       "      <td>1.429324</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.798973</td>\n",
       "      <td>1.102327</td>\n",
       "      <td>45.776779</td>\n",
       "      <td>1.153092</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.731241</td>\n",
       "      <td>0.956359</td>\n",
       "      <td>24.980275</td>\n",
       "      <td>0.974984</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.682932</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-0613</th>\n",
       "      <td>1.925024</td>\n",
       "      <td>14.206397</td>\n",
       "      <td>2.620173</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.565980</td>\n",
       "      <td>1.357226</td>\n",
       "      <td>5.180699</td>\n",
       "      <td>1.498584</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.541013</td>\n",
       "      <td>1.109348</td>\n",
       "      <td>2.394885</td>\n",
       "      <td>1.188186</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.519012</td>\n",
       "      <td>0.957326</td>\n",
       "      <td>1.989703</td>\n",
       "      <td>1.006184</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.496250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-0125</th>\n",
       "      <td>1.907290</td>\n",
       "      <td>16.543984</td>\n",
       "      <td>2.373806</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.441697</td>\n",
       "      <td>1.352977</td>\n",
       "      <td>4.871052</td>\n",
       "      <td>1.493633</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.430012</td>\n",
       "      <td>1.104282</td>\n",
       "      <td>2.746952</td>\n",
       "      <td>1.181237</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.419791</td>\n",
       "      <td>0.953137</td>\n",
       "      <td>2.078677</td>\n",
       "      <td>1.007593</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.409485</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-0125</th>\n",
       "      <td>1.917857</td>\n",
       "      <td>37.352712</td>\n",
       "      <td>2.478254</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.511928</td>\n",
       "      <td>1.350516</td>\n",
       "      <td>3.301978</td>\n",
       "      <td>1.514488</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.490528</td>\n",
       "      <td>1.106953</td>\n",
       "      <td>2.144941</td>\n",
       "      <td>1.192513</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.473808</td>\n",
       "      <td>0.955102</td>\n",
       "      <td>1.671998</td>\n",
       "      <td>1.008992</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.458623</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-4</th>\n",
       "      <td>1.929450</td>\n",
       "      <td>11.431144</td>\n",
       "      <td>2.429950</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.537333</td>\n",
       "      <td>1.353643</td>\n",
       "      <td>2.876267</td>\n",
       "      <td>1.519022</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.517631</td>\n",
       "      <td>1.107222</td>\n",
       "      <td>1.884284</td>\n",
       "      <td>1.181271</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.502847</td>\n",
       "      <td>0.956549</td>\n",
       "      <td>1.594677</td>\n",
       "      <td>1.001278</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.485865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-4</th>\n",
       "      <td>1.933898</td>\n",
       "      <td>21.225383</td>\n",
       "      <td>2.439110</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.562697</td>\n",
       "      <td>1.352734</td>\n",
       "      <td>3.409687</td>\n",
       "      <td>1.505107</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.538810</td>\n",
       "      <td>1.107012</td>\n",
       "      <td>1.965932</td>\n",
       "      <td>1.187924</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.520632</td>\n",
       "      <td>0.957038</td>\n",
       "      <td>1.613180</td>\n",
       "      <td>1.000607</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.500285</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>gpt-4o</th>\n",
       "      <td>1.933711</td>\n",
       "      <td>14.676864</td>\n",
       "      <td>2.493204</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.535402</td>\n",
       "      <td>1.350537</td>\n",
       "      <td>3.055799</td>\n",
       "      <td>1.507700</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.516214</td>\n",
       "      <td>1.107017</td>\n",
       "      <td>1.971959</td>\n",
       "      <td>1.181198</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.500891</td>\n",
       "      <td>0.955800</td>\n",
       "      <td>1.626383</td>\n",
       "      <td>1.004707</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.483872</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cot-gpt-4o</th>\n",
       "      <td>1.937535</td>\n",
       "      <td>9.276951</td>\n",
       "      <td>2.437129</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.554699</td>\n",
       "      <td>1.355309</td>\n",
       "      <td>2.712340</td>\n",
       "      <td>1.516284</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.530858</td>\n",
       "      <td>1.106768</td>\n",
       "      <td>1.935381</td>\n",
       "      <td>1.189986</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.511088</td>\n",
       "      <td>0.957304</td>\n",
       "      <td>1.583678</td>\n",
       "      <td>1.003267</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.491517</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fs-gpt-4o</th>\n",
       "      <td>1.938531</td>\n",
       "      <td>11.419797</td>\n",
       "      <td>2.449263</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.552598</td>\n",
       "      <td>1.351613</td>\n",
       "      <td>2.746027</td>\n",
       "      <td>1.502971</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.532356</td>\n",
       "      <td>1.107441</td>\n",
       "      <td>1.865422</td>\n",
       "      <td>1.177832</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.514912</td>\n",
       "      <td>0.956149</td>\n",
       "      <td>1.588028</td>\n",
       "      <td>0.996748</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.497403</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ft-gpt-4o</th>\n",
       "      <td>1.932732</td>\n",
       "      <td>12.990081</td>\n",
       "      <td>2.528414</td>\n",
       "      <td>2.431552</td>\n",
       "      <td>0.570538</td>\n",
       "      <td>1.355128</td>\n",
       "      <td>2.953640</td>\n",
       "      <td>1.502049</td>\n",
       "      <td>1.511544</td>\n",
       "      <td>0.546756</td>\n",
       "      <td>1.111204</td>\n",
       "      <td>1.945874</td>\n",
       "      <td>1.188009</td>\n",
       "      <td>1.186135</td>\n",
       "      <td>0.528388</td>\n",
       "      <td>0.956361</td>\n",
       "      <td>1.618801</td>\n",
       "      <td>1.002726</td>\n",
       "      <td>1.006148</td>\n",
       "      <td>0.506747</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   50                                                  100  \\\n",
       "                   dml         ppi     ppi++   primary     naive       dml   \n",
       "gpt-0613      1.890318  115.884451  2.081016  2.431552  0.878841  1.346897   \n",
       "cot-gpt-0613  1.925024   14.206397  2.620173  2.431552  0.565980  1.357226   \n",
       "gpt-0125      1.907290   16.543984  2.373806  2.431552  0.441697  1.352977   \n",
       "cot-gpt-0125  1.917857   37.352712  2.478254  2.431552  0.511928  1.350516   \n",
       "gpt-4         1.929450   11.431144  2.429950  2.431552  0.537333  1.353643   \n",
       "cot-gpt-4     1.933898   21.225383  2.439110  2.431552  0.562697  1.352734   \n",
       "gpt-4o        1.933711   14.676864  2.493204  2.431552  0.535402  1.350537   \n",
       "cot-gpt-4o    1.937535    9.276951  2.437129  2.431552  0.554699  1.355309   \n",
       "fs-gpt-4o     1.938531   11.419797  2.449263  2.431552  0.552598  1.351613   \n",
       "ft-gpt-4o     1.932732   12.990081  2.528414  2.431552  0.570538  1.355128   \n",
       "\n",
       "                                                            150             \\\n",
       "                    ppi     ppi++   primary     naive       dml        ppi   \n",
       "gpt-0613      39.781490  1.429324  1.511544  0.798973  1.102327  45.776779   \n",
       "cot-gpt-0613   5.180699  1.498584  1.511544  0.541013  1.109348   2.394885   \n",
       "gpt-0125       4.871052  1.493633  1.511544  0.430012  1.104282   2.746952   \n",
       "cot-gpt-0125   3.301978  1.514488  1.511544  0.490528  1.106953   2.144941   \n",
       "gpt-4          2.876267  1.519022  1.511544  0.517631  1.107222   1.884284   \n",
       "cot-gpt-4      3.409687  1.505107  1.511544  0.538810  1.107012   1.965932   \n",
       "gpt-4o         3.055799  1.507700  1.511544  0.516214  1.107017   1.971959   \n",
       "cot-gpt-4o     2.712340  1.516284  1.511544  0.530858  1.106768   1.935381   \n",
       "fs-gpt-4o      2.746027  1.502971  1.511544  0.532356  1.107441   1.865422   \n",
       "ft-gpt-4o      2.953640  1.502049  1.511544  0.546756  1.111204   1.945874   \n",
       "\n",
       "                                                 200                       \\\n",
       "                 ppi++   primary     naive       dml        ppi     ppi++   \n",
       "gpt-0613      1.153092  1.186135  0.731241  0.956359  24.980275  0.974984   \n",
       "cot-gpt-0613  1.188186  1.186135  0.519012  0.957326   1.989703  1.006184   \n",
       "gpt-0125      1.181237  1.186135  0.419791  0.953137   2.078677  1.007593   \n",
       "cot-gpt-0125  1.192513  1.186135  0.473808  0.955102   1.671998  1.008992   \n",
       "gpt-4         1.181271  1.186135  0.502847  0.956549   1.594677  1.001278   \n",
       "cot-gpt-4     1.187924  1.186135  0.520632  0.957038   1.613180  1.000607   \n",
       "gpt-4o        1.181198  1.186135  0.500891  0.955800   1.626383  1.004707   \n",
       "cot-gpt-4o    1.189986  1.186135  0.511088  0.957304   1.583678  1.003267   \n",
       "fs-gpt-4o     1.177832  1.186135  0.514912  0.956149   1.588028  0.996748   \n",
       "ft-gpt-4o     1.188009  1.186135  0.528388  0.956361   1.618801  1.002726   \n",
       "\n",
       "                                  \n",
       "               primary     naive  \n",
       "gpt-0613      1.006148  0.682932  \n",
       "cot-gpt-0613  1.006148  0.496250  \n",
       "gpt-0125      1.006148  0.409485  \n",
       "cot-gpt-0125  1.006148  0.458623  \n",
       "gpt-4         1.006148  0.485865  \n",
       "cot-gpt-4     1.006148  0.500285  \n",
       "gpt-4o        1.006148  0.483872  \n",
       "cot-gpt-4o    1.006148  0.491517  \n",
       "fs-gpt-4o     1.006148  0.497403  \n",
       "ft-gpt-4o     1.006148  0.506747  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def compute_coverage_width_tables(estimators, n_reals, methods, n_max_aug, n_trials, params_true):\n",
    "    \"\"\"Compute coverage and width summary tables for all estimators.\"\"\"\n",
    "    coverage_tables, width_tables = [], []\n",
    "    \n",
    "    for estimator in estimators:\n",
    "        coverage_results, width_results = {}, {}\n",
    "        \n",
    "        for n_real in n_reals:\n",
    "            cover_dict, width_dict = {}, {}\n",
    "            \n",
    "            for method in methods:\n",
    "                res_file = get_res_file_path(estimator, method, n_real, n_max_aug, n_trials, for_ci=True)\n",
    "                res = load_result_file(res_file)\n",
    "                if res is None:\n",
    "                    continue\n",
    "                \n",
    "                ci_result = compute_ci_bounds(res, estimator, n_max_aug)\n",
    "                if ci_result is None:\n",
    "                    continue\n",
    "                    \n",
    "                idx, ci_lower, ci_upper, _ = ci_result\n",
    "                \n",
    "                # Compute coverage and width\n",
    "                contains_truth = (params_true >= ci_lower) & (params_true <= ci_upper)\n",
    "                cover_dict[method] = contains_truth.mean() * 100\n",
    "                width_dict[method] = (ci_upper - ci_lower).mean()\n",
    "            \n",
    "            coverage_results[n_real] = cover_dict\n",
    "            width_results[n_real] = width_dict\n",
    "        \n",
    "        # Build DataFrames for this estimator\n",
    "        for results, tables in [(coverage_results, coverage_tables), (width_results, width_tables)]:\n",
    "            df = pd.DataFrame(results)\n",
    "            df.columns = pd.Index(df.columns, name=\"n_real\")\n",
    "            df = pd.concat({estimator: df}, axis=1)\n",
    "            tables.append(df)\n",
    "    \n",
    "    # Combine all tables\n",
    "    def combine_tables(tables):\n",
    "        summary = pd.concat(tables, axis=1)\n",
    "        summary.columns = summary.columns.set_names([\"estimator\", \"n_real\"])\n",
    "        summary = summary.swaplevel(0, 1, axis=1).sort_index(axis=1, level=0)\n",
    "        summary = summary.reindex(columns=pd.MultiIndex.from_product([n_reals, estimators]), fill_value=pd.NA)\n",
    "        return summary\n",
    "    \n",
    "    return combine_tables(coverage_tables), combine_tables(width_tables)\n",
    "\n",
    "# Compute tables\n",
    "summary_coverage, summary_width = compute_coverage_width_tables(\n",
    "    ESTIMATORS, N_REALS, METHODS, N_MAX_AUG, N_TRIALS, params\n",
    ")\n",
    "\n",
    "print('Coverage Probability (%)')\n",
    "display(summary_coverage)\n",
    "print('Average CI Width')\n",
    "display(summary_width)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_trial_level_ci_data(estimators, n_real_list, methods, n_max_aug, n_trials, params_true):\n",
    "    \"\"\"\n",
    "    Load CI data and compute per-trial coverage and width.\n",
    "    Returns DataFrame with columns: [n_real, estimator, method, trial, average_coverage, average_width]\n",
    "    \"\"\"\n",
    "    rows = []\n",
    "    \n",
    "    for n_real in (n_real_list if isinstance(n_real_list, list) else [n_real_list]):\n",
    "        for estimator in estimators:\n",
    "            for method in methods:\n",
    "                res_file = get_res_file_path(estimator, method, n_real, n_max_aug, n_trials, for_ci=True)\n",
    "                res = load_result_file(res_file)\n",
    "                if res is None:\n",
    "                    continue\n",
    "                \n",
    "                ci_result = compute_ci_bounds(res, estimator, n_max_aug)\n",
    "                if ci_result is None:\n",
    "                    continue\n",
    "                \n",
    "                idx, ci_lower, ci_upper, _ = ci_result\n",
    "                \n",
    "                for local_idx, t in enumerate(idx):\n",
    "                    coverage, width = compute_trial_coverage_width(\n",
    "                        ci_lower[local_idx], ci_upper[local_idx], params_true\n",
    "                    )\n",
    "                    rows.append({\n",
    "                        'n_real': n_real,\n",
    "                        'estimator': estimator,\n",
    "                        'method': method,\n",
    "                        'trial': local_idx,\n",
    "                        'average_coverage': coverage,\n",
    "                        'average_width': width\n",
    "                    })\n",
    "    \n",
    "    return pd.DataFrame(rows)\n",
    "\n",
    "# Load trial-level data for n_real=200 only (for plots)\n",
    "summary_df = load_trial_level_ci_data(\n",
    "    estimators=[\"dml\", \"primary\", \"naive\", \"ppi\", \"ppi++\"],\n",
    "    n_real_list=[200],\n",
    "    methods=[\"gpt-4o\"],\n",
    "    n_max_aug=N_MAX_AUG,\n",
    "    n_trials=N_TRIALS,\n",
    "    params_true=params\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>n_real</th>\n",
       "      <th>estimator</th>\n",
       "      <th>method</th>\n",
       "      <th>trial</th>\n",
       "      <th>average_coverage</th>\n",
       "      <th>average_width</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>200</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>0</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>0.959211</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>200</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>1</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>0.924633</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>200</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>2</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>0.983569</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>200</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>3</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.938125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>200</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>4</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>0.956195</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>245</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>45</td>\n",
       "      <td>0.636364</td>\n",
       "      <td>1.017380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>246</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>46</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>0.981636</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>247</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>47</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>0.994818</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>248</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>48</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.035013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>249</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>49</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.021670</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>250 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     n_real estimator  method  trial  average_coverage  average_width\n",
       "0       200       dml  gpt-4o      0          0.818182       0.959211\n",
       "1       200       dml  gpt-4o      1          0.909091       0.924633\n",
       "2       200       dml  gpt-4o      2          0.909091       0.983569\n",
       "3       200       dml  gpt-4o      3          1.000000       0.938125\n",
       "4       200       dml  gpt-4o      4          0.818182       0.956195\n",
       "..      ...       ...     ...    ...               ...            ...\n",
       "245     200     ppi++  gpt-4o     45          0.636364       1.017380\n",
       "246     200     ppi++  gpt-4o     46          0.909091       0.981636\n",
       "247     200     ppi++  gpt-4o     47          0.818182       0.994818\n",
       "248     200     ppi++  gpt-4o     48          1.000000       1.035013\n",
       "249     200     ppi++  gpt-4o     49          1.000000       1.021670\n",
       "\n",
       "[250 rows x 6 columns]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "summary_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_kde_distribution(df, value_col, estimator_order, xlabel, xlim=None, figsize=(6, 4)):\n",
    "    \"\"\"Plot KDE distribution for a given metric across estimators.\"\"\"\n",
    "    d = df.dropna(subset=[value_col]).copy()\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=figsize)\n",
    "    \n",
    "    for est in estimator_order:\n",
    "        w = d.loc[d[\"estimator\"] == est, value_col].to_numpy(float)\n",
    "        if w.size == 0:\n",
    "            continue\n",
    "        \n",
    "        kde = gaussian_kde(w, bw_method=\"scott\")\n",
    "        x = np.linspace(w.min() * 0.9, w.max() * 1.1, 300)\n",
    "        y = kde(x)\n",
    "        \n",
    "        color = COLOR_MAP.get(est)\n",
    "        label = LEGEND_MAP.get(est, est.upper())\n",
    "        ax.fill_between(x, y, alpha=0.35, color=color, label=label)\n",
    "        ax.plot(x, y, linewidth=1.5, color=color)\n",
    "    \n",
    "    ax.set_xlabel(xlabel)\n",
    "    ax.set_ylabel(\"Density\")\n",
    "    if xlim:\n",
    "        ax.set_xlim(xlim)\n",
    "    ax.legend(frameon=False)\n",
    "    ax.grid(alpha=0.2)\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "def plot_histogram_distribution(df, value_col, estimator_order, xlabel, xlim=None, figsize=(6, 4)):\n",
    "    \"\"\"Plot histogram distribution for a given metric across estimators.\"\"\"\n",
    "    d = df.dropna(subset=[value_col]).copy()\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=figsize)\n",
    "    \n",
    "    bins = np.linspace(0.0, 1.0, 26)\n",
    "    bar_width = (bins[1] - bins[0]) / len(estimator_order)\n",
    "    bin_centers = (bins[:-1] + bins[1:]) / 2\n",
    "    n_estimators = len(estimator_order)\n",
    "    \n",
    "    for i, est in enumerate(estimator_order):\n",
    "        w = d.loc[d[\"estimator\"] == est, value_col].to_numpy(float)\n",
    "        w = w[(w >= 0.0) & (w <= 1.0)]\n",
    "        if w.size == 0:\n",
    "            continue\n",
    "        \n",
    "        counts, _ = np.histogram(w, bins=bins, density=False)\n",
    "        offset = (i - n_estimators / 2) * bar_width + bar_width / 2\n",
    "        \n",
    "        ax.bar(\n",
    "            bin_centers + offset, counts, width=bar_width,\n",
    "            color=COLOR_MAP.get(est), label=LEGEND_MAP.get(est, est.upper()),\n",
    "            alpha=0.85, align='center', edgecolor=\"none\"\n",
    "        )\n",
    "    \n",
    "    ax.set_xlabel(xlabel)\n",
    "    ax.set_ylabel(\"Frequency\")\n",
    "    if xlim:\n",
    "        ax.set_xlim(xlim)\n",
    "    ax.legend(frameon=False)\n",
    "    ax.grid(alpha=0.2)\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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++POO+/EkSNH/MrTUDBZuHAhLrjgAr9tBw8ehKIouO222/y2v/XWWzAajSgvL8ctt9zifY1AzZ49G9ddd11QxzRl8eLF0Ov1eOqppzQ9b2tYvny533skJSUFN998MzIyMsJdtJC1xM+YKBAMTtRuvPHGG7jnnnuwdetWnDp1qkVfy+12w+PxtOhrNGbv3r2YNm0arr76auzevRvvvPMOPvroIyxcuLDOvl999RVycnK8tyuvvNL73B133IErr7wSu3btQnFxMRYvXux97i9/+QvGjRuHyy67rMnyfPLJJxg1ahTsdjtWrlyJgwcP4q233oLNZsMjjzwS0Pc0ceJEHDp0CLm5ud5tGzduRFpaGjZs2OC378aNGzFixAhER0fDYrEgMTExoNdoScuWLcOCBQvwxhtvNPtcTqdTgxIFx2q1IicnB9nZ2Vi1ahX27NmDa6+9Fm63O6TzheN7aAkOhyPcRaD2plmr7BG1kvLychETEyMOHTokbrnlFvH44497nxs1apR44IEH/PbPy8sTBoNBfPPNN0IIIex2u7j//vtFamqqiIyMFCNGjBAbNmzw7r9s2TJhs9nExx9/LC644AKh1+vFiRMnxLZt28SkSZNEly5dhNVqFePHjxc7d+70e62DBw+KsWPHCrPZLC644AKxfv16AUCsXbvWu09WVpa4+eabRWxsrIiPjxfXXnutyMjIaPD7ffDBB8Xw4cP9tq1du1ZERESI0tJSIYQQGRkZAoDYvXt3g+exWCzi4MGDQgghXnnlFTFt2jQhhBDHjx8X/fr1856rMRUVFSIhIUFcd9119T5fVFQUUHnKy8uF0WgUq1ev9m67+eabxVNPPSWsVqs4evSod3vv3r3Fww8/LITw/WxqW7JkiUhMTBTR0dHi17/+tXjggQe8i/A+9thjdRb+3LBhg7d877//vrjiiiuExWIRF198sfj222+brIONGzeKbt26CYfDIVJTU/0W/hZCCLfbLZ566inRp08fYTKZRFpamnjiiSf86mXNmjViwoQJwmw2izfeeEO43W7x+OOPi27dugmTySSGDBkiPv/8c+857Xa7mDt3rkhOThZms1mkp6eLxYsXe59/7LHHRFpamjCZTCIlJUXcc889DZa/vjp8++23BQBx6NChgN7nAMSrr74qrr32WhEZGSkeffRR4XK5xK9//WvRs2dPERER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7P1ar9ejS5cu3p9DKL8zwRw3ePBgmEwm79eTJ09Geno6evfujdtuuw0rV65EZWVlo/VJnZch3AUgasrSpUvhcrnQrVs37zYhBIxGI4qKihAXF4eZM2fi3nvvxUsvvYRVq1Zh0KBB3g86j8cDvV6PnTt3ekOHKjo62vvYYrFAURS/52fPno1z587hhRdeQHp6OsxmM0aPHu0dUCqEqHPM+TweDy699FJvsKuta9euDR43b948/OEPf0BOTg7i4uKQmZmJBx98EL169WrwmFGjRuH1119v8Pk//OEPuO+++9C9e3ds3LgRTzzxBKKiovDzn/8cGzduxDXXXFPnmP79+wMADh06FFRAqc/YsWNhMpmwceNGbNiwARMmTAAgP5BLSkpw5MgRbNiwAbNnz27W6zTGaDR6H6s/u8YuBHjjjTewf/9+GAy+P5cejwdLly7Fb3/72wYD3vmioqLqbDv/vVP7/XTJJZcgIyMDn3/+Ob766ivcfPPNmDRpEt577z2kpaXh8OHDWL9+Pb766ivMmTMHzz77LDZt2uT3/dUWExODXbt2QafTISkpya88Tb3PG/oe/v3vf+MPf/gDnnvuOYwePRoxMTF49tln8cMPP/jtd36ZFEWpd5v6cwj1dybQ487/PtS62bhxI9atW4dHH30UixYtwvbt25ucCoM6HwYnatNcLhdWrFiB5557DlOmTPF77oYbbsDKlStx991347rrrsPvfvc7fPHFF1i1apXf5e3Dhg2D2+1GXl4eLr/88qBef8uWLXjllVcwbdo0AMDp06eRn5/vfX7gwIE4deoUzp49i6SkJACoc3n/JZdcgjVr1iAxMRFWqzWo11cUBampqQCA1atXIy0tDZdcckmD++/evdvbinK+r7/+GocOHcLy5csByCsH1SujGrtCasqUKUhISMAzzzyDtWvX1nm+uLg44A8Xi8WCkSNHYuPGjdi8eTPuv/9+ALIVccyYMVixYgUyMzMxceLEBs9xwQUX4Pvvv8ftt9/u3fb999/77WMymUK+Wqy2ffv2YceOHdi4cSPi4+O924uLizF+/Hj89NNP6NevHywWC77++mvccccdAZ3XarUiNTUVW7duxfjx473bv/32W78WS6vViltuuQW33HILbrzxRlx99dUoLCxEfHw8LBYLrr32Wlx77bWYO3cuBg4ciH379jX4/tDpdOjbt2+9zzX1Pm/Ili1bMGbMGMyZM8e7rbEWoUAF8jtT38+4Ob9rBoMBkyZNwqRJk/DYY48hNjYW33zzDWbMmBHy90EdE7vqqE375JNPUFRUhN/85je46KKL/G433ngjli5dCkD+Bzl9+nQ88sgjOHjwIG699VbvOfr374+ZM2fi9ttvxwcffICMjAxs374dTz/9ND777LNGX79v37546623cPDgQfzwww+YOXOmXwvD5MmT0adPH8yaNQt79+7Ff//7Xzz88MMAfK0JM2fOREJCAqZPn44tW7YgIyMDmzZtwr333ousrKwGX/vZZ5/Fvn37sH//fvz5z3/GU089hRdffNHbavbmm29i1apVOHjwIA4fPoy//OUvePHFF3HPPffUOVdVVRXmzp2Lf/7zn94uk7Fjx+Lvf/87fvzxR7z//vt1uo1UUVFReP311/Hpp5/i2muvxVdffYXMzEzs2LEDCxYswF133dVoHZ5v4sSJeOedd1BVVeX3IT9hwgS8+OKL3nDVkHvvvRdvvPEG3njjDRw5cgSPPfYY9u/f77dPz549sXfvXhw+fBj5+fkhXzq/dOlSjBgxAuPHj/d7740bNw6jR4/G0qVLERERgQceeAALFizAihUrcPz4cXz//ffe92ZD7r//fjz99NNYs2YNDh8+jIULF2LPnj249957AQB//etf8c477+DQoUM4cuQI3n33XSQnJyM2NhbLly/H0qVL8dNPP+HEiRN46623YLFYkJ6eHtL32dT7vLHjduzYgS+//BJHjhzBI488EvC8YI0J5Hemvp9xqL9rn3zyCV588UXs2bMHJ0+exIoVK+DxeDBgwIBmfy/UAYV1hBVRE/7nf/7Hewn9+Xbu3CkAeC+b/vTTTwUAMX78+Dr7qlf/9OzZUxiNRpGcnCyuv/56sXfvXiFE/VcdCSHErl27xPDhw4XZbBb9+vUT7777rkhPTxd//etfvfuo0xGYTCYxcOBA8fHHHwsA4osvvvDuk5OTI26//XaRkJAgzGaz6N27t7jzzju9A4zrM3HiRGGz2URERIQYOXKk+Oyzz/yeX758ubjgggtEZGSkiImJEZdeeqnfwPDaFi5cKP74xz/6bTt69Ki47LLLhNVqFXfddZff4N36bN++XcyYMUN07dpVmM1m0bdvX/Hb3/7WO41AIIPDhRBiw4YNAoC4+uqr/bZv2bJFABBXXXWV3/b6fjZPPvmkSEhIENHR0WLWrFliwYIFfoPD8/LyxOTJk0V0dHSd6Qhql6+oqMjvSsXa7Ha76NKli3jmmWfq/T6ee+45kZCQIOx2u3C73eKJJ54Q6enpwmg0ih49eninDmioXmpPR2A0GutMR/DPf/5TDB06VERFRQmr1SquuuoqsWvXLiGEnJpi5MiRwmq1iqioKDFq1CjvVYj1aej9rQrkfY7zptgQQojq6moxe/ZsYbPZRGxsrPi///s/sXDhwiYH6k+YMEHce++9ftvOf72mfmfq+xkHclx95dmyZYuYMGGCiIuL805TUfvKQKLaFCE0HPlJRPjvf/+LcePG4dixY+jTp0+4i0NERBpicCJqprVr1yI6Ohr9+vXDsWPHcO+99yIuLg5bt24Nd9GIiEhjHBxO1ExlZWVYsGABTp8+jYSEBEyaNAnPPfdcuItFREQtgC1ORERERAHiVXVEREREAWJwIiIiIgoQgxMRERFRgBiciIiIiALE4EREREQUIAYnIiIiogAxOBEREREFiMGJiIiIKED/Hy1cuGAuk+wuAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "estimator_order = ['ppi', 'ppi++', 'dml']\n",
    "\n",
    "# Plot CI Width distribution\n",
    "plot_kde_distribution(\n",
    "    summary_df, \n",
    "    value_col=\"average_width\",\n",
    "    estimator_order=estimator_order,\n",
    "    xlabel=\"Average 95% CI Width Across Parameters\",\n",
    "    xlim=(0.75, 2)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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S7Dn/u25d8B8/afmpJpci6Ufd2x57FNN350oa3eq698ChViBsWNviXGpSowKTleuXEGvXr1w9epVZGdnIyIiAu7u7pg3bx7+/PNPfPzxx+auEwBw69YtXLt2DX5+fiUuo9Vqi30ZT6PR2NyDiCUU9G2PvQP23b899w6Yp3+B6af+rbH/bXXszfFKipqWyuxfY6FCrMCYsbfUuFQ0Sx3vRn0cwfjx49G2bVvcvn0bOp1Omd6/f3/s3LlT9XYyMzORmJiIxMREAEBKSgoSExNx9epVZGZmYtKkSfjpp59w+fJl7NmzB3369IG3t7dFrq8iIiIiKszod9UdOHAALi4uBtODgoLw66+/qt7OsWPH0L17d+V2wUtsQ4cOxbJly/DLL79g5cqVuHPnDvz8/NC9e3esXbsW7u7uxpRNREREZBKjglN+fj7y8vKKTL9+/Xq5Qk23bt1KvQr+hx9+MKY8IiIiogph1Et1ERERWLRokXJbo9EgMzMT7733nslfw0JERERkq4w647Rw4UJ0794dTZs2xZ9//olBgwbh/Pnz8Pb2xtdff23uGomIiIhsglHByd/fH4mJifj6669x4sQJ5OfnY/jw4XjppZcMLhYnIiIiqkqM/hwnnU6HV199Fa+++qo56yEiIiKyWUYFp5UrV5Y6f8iQIUYVQ0RERGTLjApO48ePN7idk5ODe/fuwcXFBa6urgxOREREVCUZ9a6627dvG/xkZmYiOTkZnTt35sXhREREVGUZFZyKExwcjLlz5xY5G0VERERUVZgtOAGAo6MjUs3xbYFERERENsioa5y2bNlicFtEkJaWhiVLliA8PNwshRERERHZGqOCU79+/QxuazQa1KpVC08++SQWLFhgjrqIiIiIbI7R31VHREREZG/Meo0TERERUVVm1BmniRMnql42OjramLsgIiIisjlGBaeEhAScOHECubm5CA0NBQCcO3cOjo6OePzxx5XlNBqNeaokIiIisgFGBac+ffrA3d0dX3zxBWrUqAHg4YdivvLKK3jiiSfw5ptvmrVIIiIiIltg1DVOCxYswJw5c5TQBAA1atTArFmz+K46IiIiqrKMOuOUkZGB3377Dc2aNTOYfvPmTdy9e9cshRERERUWuiS01PkaaODv7I/UnFQIpNhlkoMqojIy2dbSx7ZMWZZ5x79RZ5z69++PV155BevXr8f169dx/fp1rF+/HsOHD8eAAQPMXSMRERGRTTDqjNPHH3+MSZMmYfDgwcjJyXm4IScnDB8+HPPnzzdrgURERES2wqjg5OrqiqVLl2L+/Pm4ePEiRASNGjVC9erVzV0fERERkc0w6QMw09LSkJaWhpCQEFSvXh0ixb+eTERERFQVGBWcbt26haeeegohISGIiopCWloaAGDEiBH8KAIiIiKqsowKTm+88QacnZ1x9epVuLq6KtMHDhyI7du3m604IiIiIlti1DVOO3bswA8//ICAgACD6cHBwbhy5YpZCiMiIiKyNUadccrKyjI401Tgjz/+gFarNbkoIiIiIltkVHDq0qULVq5cqdzWaDTIz8/H/Pnz0b17d7MVR0RERGRLjHqpbv78+ejWrRuOHTuGBw8eYPLkyTh9+jT+97//4cCBA+aukYiIiMgmGHXGqWnTpjh58iTat2+PiIgIZGVlYcCAAUhISEDDhg3NXSMRERGRTSj3GaecnBxERkbik08+wYwZMyqiJiIiIiKbVO4zTs7Ozjh16hQ0Gk1F1ENERERks4x6qW7IkCFYvny5uWshIiIismlGXRz+4MEDfP7554iLi0Pbtm2LfEdddHS0WYojIiIisiXlCk6XLl1CvXr1cOrUKTz++OMAgHPnzhksw5fwiIiIqKoqV3AKDg5GWloadu/eDeDhV6x8+OGH8PHxqZDiiIiIiGxJua5xEhGD299//z2ysrLMWhARERGRrTLq4vAChYMUERERUVVWruCk0WiKXMPEa5qIiIjIXpTrGicRwbBhw5Qv8v3zzz/x+uuvF3lX3caNG81XIREREZGNKFdwGjp0qMHtwYMHm7UYIiIiIltWruAUExNTUXUQERER2TyTLg4nIiIisicMTkREREQqMTgRERERqcTgRERERKQSgxMRERGRSgxORERERCpZNTjt3bsXffr0gb+/PzQaDTZv3mwwX0Qwffp0+Pv7Q6fToVu3bjh9+rR1iiUiIiK7Z9XglJWVhVatWmHJkiXFzp83bx6io6OxZMkSHD16FL6+voiIiMDdu3ctXCkRERFROT8A09x69+6N3r17FztPRLBo0SJMmzYNAwYMAAB88cUX8PHxwerVqzFy5EhLlkpERERk3eBUmpSUFNy4cQORkZHKNK1Wi65du+LgwYMlBqfs7GxkZ2crtzMyMgA8DGIiUrFF25iCnu2t7wL23L899w6Yr38NTP8Sc0uPgS2PvXm+E770jWge+a8kZtk1Nrh/jR17c4yLefapaYWIieurZbPB6caNGwAAHx8fg+k+Pj64cuVKievNmTMHM2bMKDI9PT3dvAVWAiKCzMxMAIDGPI9YlYo992/PvQPm69/f2d/kWiz92GPLY+9v+u4EyhgTDTSo5VQLACAo/tncLCNig88pxo69OcbFPLvDtELSkQfgvDkKKZXNBqcChQdfREo9IKZOnYqJEycqtzMyMhAYGAi9Xg+9Xl9hddqigr869Hq9zT2AWoI992/PvQPm6z81J9XkWiz9uGPLY59q+u4EyhiTgjNNqTmpJQYns4yIDT6fGDv25hgX8+wOUwvJN0cRZbLZ4OTr6wvg4ZknPz8/ZfrNmzeLnIV6lFarhVarLTJdo9HY3IOIJRT0bY+9A/bdvz33Dpin/5KeeMtbh6XZ6tib59Wtsjcij/xXHLPsFhvbtwWMGXtzjIt59qmJL62buL5aNvs5TvXr14evry/i4uKUaQ8ePEB8fDzCwsKsWBkRERHZK6ueccrMzMSFCxeU2ykpKUhMTETNmjVRt25dTJgwAbNnz0ZwcDCCg4Mxe/ZsuLq6YtCgQVasmoiIiOyVVYPTsWPH0L17d+V2wbVJQ4cORWxsLCZPnoz79+9j1KhRuH37Njp06IAdO3bA3d3dWiUTERGRHbNqcOrWrVupb5vUaDSYPn06pk+fbrmiiIiIiEpgs9c4EREREdkaBiciIiIilRiciIiIiFRicCIiIiJSicGJiIiISCWb/eRwInsSuiTU5G0kj0k2QyVERFQannEiIiIiUonBiYiIiEglBiciIiIilRiciIiIiFRicCIiIiJSicGJiIiISCUGJyIiIiKVGJyIiIiIVGJwIiIiIlKJwYmIiIhIJQYnIiIiIpX4XXVERBVpq+nfQ4g+/B5Csm1m+b7NIDMUYgE840RERESkEoMTERERkUoMTkREREQqMTgRERERqcTgRERERKQSgxMRERGRSgxORERERCoxOBERERGpxOBEREREpBKDExEREZFKDE5EREREKjE4EREREanE4ERERESkEoMTERERkUoMTkREREQqMTgRERERqcTgRERERKQSgxMRERGRSgxORERERCoxOBERERGpxOBEREREpBKDExEREZFKTtYugIioIgwYAKSmAiImbGSs2cohoiqCZ5yIiIiIVGJwIiIiIlKJwYmIiIhIJQYnIiIiIpUYnIiIiIhUYnAiIiIiUsmmg9P06dOh0WgMfnx9fa1dFhEREdkpm/8cp2bNmuHHH39Ubjs6OlqxGiIiIrJnNh+cnJyceJaJiIiIbILNB6fz58/D398fWq0WHTp0wOzZs9GgQYMSl8/OzkZ2drZyOyMjAwAgIhCTPkK48ino2d76LlCZ+tdAY/I2Hu2zMvVeEUQEGs3DH9OYY1xM3kS5NmLLY68xfXeirDHRPPJfSSw9JpZi7NhbYlzUMHWXipilkTLZdHDq0KEDVq5ciZCQEPz222+YNWsWwsLCcPr0aXh5eRW7zpw5czBjxowi09PT0yu6XJsjIsjMzAQAaMzzm1GpVKb+/Z39Td7Go8d4Zeq9IogIatXK/P//NqF/c4yLyVsAUI7HL1see3/Td2eZY6KBBrWcagEABMU/E1t6TCzF2LG3xLioYeoeTUcegPMm11EWmw5OvXv3Vv7dokULdOrUCQ0bNsQXX3yBiRMnFrvO1KlTDeZlZGQgMDAQer0eer2+wmu2JQV/dej1ept7ALWEytR/ak6qydt49PiuTL1XBBHB778Dqal604KTOcbF5C0AKMdjly2Pfarpu7PMMSk405Sak1picLL0mFiKsWNviXFRw/Q9mm/yFtSw6eBUWPXq1dGiRQucP19yotRqtdBqtUWmF7wrz948+o5Ee1RZ+i/pAb48CvdYWXqvKCIa5ceErZhch1l2fzk3Yqtjb55Xt8reiDzyX3GsMSaWYszYW2pcymLqLjX9pXl1bPrjCArLzs7GmTNn4OfnZ+1SiIiIyA7ZdHCaNGkS4uPjkZKSgsOHD+O5555DRkYGhg4dau3SiIiIyA7Z9Et1169fx4svvog//vgDtWrVQseOHXHo0CEEBQVZuzQiIiKyQzYdnNasWWPtEoiIiIgUNv1SHREREZEtYXAiIiIiUonBiYiIiEglBiciIiIilRiciIiIiFSy6XfVEVUGoaFm2MhYM2yDiIgqHM84EREREanE4ERERESkEoMTERERkUoMTkREREQqMTgRERERqcTgRERERKQSgxMRERGRSgxORERERCoxOBERERGpxOBEREREpBK/ckWl0CWmf69G8phkM1RCRERE1sIzTkREREQqMTgRERERqcTgRERERKQSgxMRERGRSgxORERERCoxOBERERGpxOBEREREpBKDExEREZFKDE5EREREKjE4EREREanE4ERERESkEoMTERERkUoMTkREREQqMTgRERERqcTgRERERKQSgxMRERGRSgxORERERCoxOBERERGpxOBEREREpBKDExEREZFKDE5EREREKjE4EREREankZO0C7MrWUNO30SfZ9G1Q1fTo8SUaAP4AUgGNqN8Gjy8iolLxjBMRERGRSgxORERERCoxOBERERGpxOBEREREpBKDExEREZFKDE5EREREKlWK4LR06VLUr18f1apVQ5s2bbBv3z5rl0RERER2yOaD09q1azFhwgRMmzYNCQkJeOKJJ9C7d29cvXrV2qURERGRnbH54BQdHY3hw4djxIgRaNKkCRYtWoTAwEAsW7bM2qURERGRnbHp4PTgwQMcP34ckZGRBtMjIyNx8OBBK1VFRERE9sqmv3Lljz/+QF5eHnx8fAym+/j44MaNG8Wuk52djezsbOV2enq6wf+NlX8/36T1ASA9y+RNAOXoQ0SUvjUajRnuvHKxVP/5ph8agJmPLxEN0pEHIB+a8nzliom/J7ZCRJCXl478/If7wmj8vTcrS/yuaKBBXm4e8nPyISj+2Lf0mFiKsWNvi49hxq3/sAaRcjzmGcGmg1OBwgeAiJR4UMyZMwczZswoMj0oKKhCaisPTxvaCtmYyaZvwrPIlPNm2Ypdq5Bxsd5WqgQVY3K+jGPf0yyFmGcrVYbN/K4At27dgl6vN9PWirLp4OTt7Q1HR8ciZ5du3rxZ5CxUgalTp2LixInK7Tt37iAoKAhXr16t0B1pizIyMhAYGIhr167Bw8PD2uVYnD33b8+9A/bdvz33Dth3//bcO/DwlaW6deuiZs2aFXo/Nh2cXFxc0KZNG8TFxaF///7K9Li4OPTt27fYdbRaLbRabZHper3eLg8kAPDw8LDb3gH77t+eewfsu3977h2w7/7tuXcAcHCo2Mu3bTo4AcDEiRPx8ssvo23btujUqRM+/fRTXL16Fa+//rq1SyMiIiI7Y/PBaeDAgbh16xbef/99pKWloXnz5vjuu+9s4polIiIisi82H5wAYNSoURg1apRR62q1Wrz33nvFvnxX1dlz74B992/PvQP23b899w7Yd//23Dtguf41UtHv2yMiIiKqImz6AzCJiIiIbAmDExEREZFKDE5E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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot CI Coverage distribution\n",
    "plot_histogram_distribution(\n",
    "    summary_df,\n",
    "    value_col=\"average_coverage\",\n",
    "    estimator_order=estimator_order,\n",
    "    xlabel=\"Average 95% CI Coverage Across Parameters\",\n",
    "    xlim=(0.6, 1.0)\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# t-tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>50</th>\n",
       "      <th>100</th>\n",
       "      <th>150</th>\n",
       "      <th>200</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>primary</th>\n",
       "      <td>4.151817e-15</td>\n",
       "      <td>1.836395e-12</td>\n",
       "      <td>1.096542e-06</td>\n",
       "      <td>8.536785e-06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>naive</th>\n",
       "      <td>6.698582e-44</td>\n",
       "      <td>5.279443e-43</td>\n",
       "      <td>5.270442e-47</td>\n",
       "      <td>4.498517e-40</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi</th>\n",
       "      <td>2.592279e-01</td>\n",
       "      <td>1.255570e-12</td>\n",
       "      <td>1.933223e-13</td>\n",
       "      <td>8.309073e-17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi++</th>\n",
       "      <td>3.628299e-03</td>\n",
       "      <td>1.204634e-15</td>\n",
       "      <td>1.552112e-10</td>\n",
       "      <td>9.941503e-11</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                  50            100           150           200\n",
       "primary  4.151817e-15  1.836395e-12  1.096542e-06  8.536785e-06\n",
       "naive    6.698582e-44  5.279443e-43  5.270442e-47  4.498517e-40\n",
       "ppi      2.592279e-01  1.255570e-12  1.933223e-13  8.309073e-17\n",
       "ppi++    3.628299e-03  1.204634e-15  1.552112e-10  9.941503e-11"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def trial_avg_mape_from_res(res, params_true, n_trials, n_aug_target):\n",
    "    \"\"\"Compute per-trial average MAPE (mean absolute percentage error).\"\"\"\n",
    "    n_aug_list = np.asarray(res['n_aug_list'])\n",
    "    sample_id_list = np.asarray(res['sample_id_list']).astype(int)\n",
    "    params_est_list = np.asarray(res['params_list'])\n",
    "    \n",
    "    P = params_est_list.shape[1]\n",
    "    out = np.zeros(n_trials)\n",
    "    count = np.zeros(n_trials)\n",
    "    \n",
    "    mask = (n_aug_list == n_aug_target)\n",
    "    if mask.sum() == 0:\n",
    "        return np.full(n_trials, np.nan)\n",
    "    \n",
    "    est = params_est_list[mask]\n",
    "    sids = sample_id_list[mask]\n",
    "    \n",
    "    for i in range(P):\n",
    "        re_i = np.abs(est[:, i] - params_true[i]) / (np.abs(params_true[i]) + 1.0)\n",
    "        for sid, val in zip(sids, re_i):\n",
    "            if 0 <= sid < n_trials:\n",
    "                out[sid] += val\n",
    "                count[sid] += 1\n",
    "    \n",
    "    with np.errstate(divide='ignore', invalid='ignore'):\n",
    "        out = out / count\n",
    "    return out\n",
    "\n",
    "\n",
    "def pvals_vs_dml_mape(n_trials, n_real, n_max_aug, method=\"gpt-4o\"):\n",
    "    \"\"\"Compute p-values for paired t-tests comparing DML vs other estimators (MAPE).\"\"\"\n",
    "    # Load DML results\n",
    "    dml_file = get_res_file_path('dml', method, n_real, n_max_aug, n_trials)\n",
    "    res_dml = load_result_file(dml_file)\n",
    "    dml_mape = trial_avg_mape_from_res(res_dml, params, n_trials, n_max_aug)\n",
    "    \n",
    "    out = {}\n",
    "    for base in ['primary', 'naive', 'ppi', 'ppi++']:\n",
    "        res_file = get_res_file_path(base, method, n_real, n_max_aug, n_trials)\n",
    "        res_b = load_result_file(res_file)\n",
    "        if res_b is None:\n",
    "            out[base] = np.nan\n",
    "            continue\n",
    "        \n",
    "        target_aug = 0 if base == 'primary' else n_max_aug\n",
    "        base_mape = trial_avg_mape_from_res(res_b, params, n_trials, target_aug)\n",
    "        \n",
    "        mask = ~np.isnan(dml_mape) & ~np.isnan(base_mape)\n",
    "        if mask.sum() < 2:\n",
    "            out[base] = np.nan\n",
    "            continue\n",
    "        \n",
    "        _, pval = stats.ttest_rel(dml_mape[mask], base_mape[mask])\n",
    "        out[base] = pval\n",
    "    \n",
    "    return pd.Series(out)\n",
    "\n",
    "\n",
    "# Compute p-value table for MAPE\n",
    "pval_table_mape = pd.DataFrame(index=['primary', 'naive', 'ppi', 'ppi++'], columns=N_REALS, dtype=float)\n",
    "for n_real in N_REALS:\n",
    "    pval_table_mape[n_real] = pvals_vs_dml_mape(N_TRIALS, n_real, N_MAX_AUG, method=\"gpt-4o\")\n",
    "\n",
    "pval_table_mape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load trial-level data for all n_real values (for t-tests)\n",
    "summary_df_all = load_trial_level_ci_data(\n",
    "    estimators=[\"dml\", \"primary\", \"naive\", \"ppi\", \"ppi++\"],\n",
    "    n_real_list=N_REALS,\n",
    "    methods=[\"gpt-4o\"],\n",
    "    n_max_aug=N_MAX_AUG,\n",
    "    n_trials=N_TRIALS,\n",
    "    params_true=params\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>n_real</th>\n",
       "      <th>estimator</th>\n",
       "      <th>method</th>\n",
       "      <th>trial</th>\n",
       "      <th>average_coverage</th>\n",
       "      <th>average_width</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>50</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.823623</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>50</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>1</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.789524</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>50</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>2</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>2.012464</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>50</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>3</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.939467</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>50</td>\n",
       "      <td>dml</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>4</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.916010</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>995</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>45</td>\n",
       "      <td>0.636364</td>\n",
       "      <td>1.017380</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>996</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>46</td>\n",
       "      <td>0.909091</td>\n",
       "      <td>0.981636</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>997</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>47</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>0.994818</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>998</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>48</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.035013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>999</th>\n",
       "      <td>200</td>\n",
       "      <td>ppi++</td>\n",
       "      <td>gpt-4o</td>\n",
       "      <td>49</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.021670</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1000 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     n_real estimator  method  trial  average_coverage  average_width\n",
       "0        50       dml  gpt-4o      0          1.000000       1.823623\n",
       "1        50       dml  gpt-4o      1          1.000000       1.789524\n",
       "2        50       dml  gpt-4o      2          1.000000       2.012464\n",
       "3        50       dml  gpt-4o      3          1.000000       1.939467\n",
       "4        50       dml  gpt-4o      4          1.000000       1.916010\n",
       "..      ...       ...     ...    ...               ...            ...\n",
       "995     200     ppi++  gpt-4o     45          0.636364       1.017380\n",
       "996     200     ppi++  gpt-4o     46          0.909091       0.981636\n",
       "997     200     ppi++  gpt-4o     47          0.818182       0.994818\n",
       "998     200     ppi++  gpt-4o     48          1.000000       1.035013\n",
       "999     200     ppi++  gpt-4o     49          1.000000       1.021670\n",
       "\n",
       "[1000 rows x 6 columns]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "summary_df_all"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "P-values for Coverage:\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>50</th>\n",
       "      <th>100</th>\n",
       "      <th>150</th>\n",
       "      <th>200</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>primary</th>\n",
       "      <td>0.019637</td>\n",
       "      <td>0.003287</td>\n",
       "      <td>0.052564</td>\n",
       "      <td>0.114725</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>naive</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi</th>\n",
       "      <td>0.083199</td>\n",
       "      <td>0.549908</td>\n",
       "      <td>0.178798</td>\n",
       "      <td>0.49524</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi++</th>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.000001</td>\n",
       "      <td>0.001678</td>\n",
       "      <td>0.000461</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              50        100       150       200\n",
       "primary  0.019637  0.003287  0.052564  0.114725\n",
       "naive         0.0       0.0       0.0       0.0\n",
       "ppi      0.083199  0.549908  0.178798   0.49524\n",
       "ppi++    0.000032  0.000001  0.001678  0.000461"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def compute_pval_table(df, metric_col, dml_label='dml', methods_of_interest=None):\n",
    "    \"\"\"Compute p-value table comparing DML vs other estimators using Welch's t-test.\"\"\"\n",
    "    if methods_of_interest is None:\n",
    "        methods_of_interest = ['primary', 'naive', 'ppi', 'ppi++']\n",
    "    \n",
    "    n_reals = sorted(df['n_real'].unique())\n",
    "    pval_table = pd.DataFrame(index=methods_of_interest, columns=n_reals)\n",
    "    \n",
    "    for n_real in n_reals:\n",
    "        df_m = df[df['n_real'] == n_real]\n",
    "        for meth in methods_of_interest:\n",
    "            x = df_m[df_m['estimator'] == dml_label][metric_col]\n",
    "            y = df_m[df_m['estimator'] == meth][metric_col]\n",
    "            if len(x) > 0 and len(y) > 0:\n",
    "                _, pval = stats.ttest_ind(x, y, equal_var=False)\n",
    "                pval_table.loc[meth, n_real] = pval\n",
    "    \n",
    "    return pval_table\n",
    "\n",
    "\n",
    "# Compute p-value tables for coverage and width\n",
    "with warnings.catch_warnings():\n",
    "    warnings.filterwarnings('ignore', category=RuntimeWarning)\n",
    "    pval_table_cover = compute_pval_table(summary_df_all, 'average_coverage')\n",
    "    pval_table_width = compute_pval_table(summary_df_all, 'average_width')\n",
    "\n",
    "print(\"P-values for Coverage:\")\n",
    "display(pval_table_cover)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "P-values for CI Width:\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>50</th>\n",
       "      <th>100</th>\n",
       "      <th>150</th>\n",
       "      <th>200</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>primary</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>naive</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi</th>\n",
       "      <td>0.034466</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi++</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              50   100  150  200\n",
       "primary       0.0  0.0  0.0  0.0\n",
       "naive         0.0  0.0  0.0  0.0\n",
       "ppi      0.034466  0.0  0.0  0.0\n",
       "ppi++         0.0  0.0  0.0  0.0"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"P-values for CI Width:\")\n",
    "pval_table_width"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.13.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
