{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1d8dc873",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Loading data...\n",
      "Total samples: 318215\n",
      "Ground truth β: [1.9133621e-05 1.8660285e-07]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "from scipy import stats\n",
    "from scipy.stats import gaussian_kde\n",
    "from scipy.optimize import minimize\n",
    "import pandas as pd\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from ppi_py.datasets import load_dataset\n",
    "from ppi_py import ppi_logistic_pointestimate, ppi_logistic_ci, logistic\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "import torch\n",
    "from torch.optim import Adam\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "\n",
    "# ============ Global Constants ============\n",
    "MS = np.array([100, 250, 500, 750, 1000]).astype(int)\n",
    "NUM_TRIALS = 50\n",
    "N_UNLABELED = 2000\n",
    "ALPHA = 0.05\n",
    "OPTIMIZER_OPTIONS = {\n",
    "    \"ftol\": 1e-5,\n",
    "    \"gtol\": 1e-5,\n",
    "    \"maxls\": 10000,\n",
    "    \"maxiter\": 10000,\n",
    "}\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",
    "# CI methods and their display names\n",
    "CI_METHODS = ['dml', 'ppi', 'ppi_pp', 'primary', 'naive']\n",
    "METHOD_MAP = {'dml': 'dml', 'primary': 'primary', 'naive': 'naive', 'ppi': 'ppi', 'ppi_pp': 'ppi++'}\n",
    "MAPE_COL_MAP = {'dml': 'dml_mape', 'primary': 'primary_mape', 'naive': 'naive_mape', \n",
    "                'ppi': 'ppi_mape', 'ppi_pp': 'ppi_pp_mape'}\n",
    "\n",
    "# ============ Load Data ============\n",
    "print(\"\\nLoading data...\")\n",
    "data = load_dataset('data/census/', 'census_healthcare')\n",
    "Y_total = data[\"Y\"]\n",
    "Yhat_total = data[\"Yhat\"]\n",
    "X_total = data[\"X\"].copy()\n",
    "\n",
    "n_total = len(Y_total)\n",
    "\n",
    "# Ground truth\n",
    "true_theta = LogisticRegression(\n",
    "    penalty=None, solver=\"lbfgs\", max_iter=10000, tol=1e-15, fit_intercept=False\n",
    ").fit(X_total, Y_total).coef_.squeeze()\n",
    "\n",
    "print(f\"Total samples: {n_total}\")\n",
    "print(f\"Ground truth β: {true_theta}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3c7cc5c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_mape(estimated, true):\n",
    "    \"\"\"Calculate Mean Absolute Percentage Error.\"\"\"\n",
    "    return np.mean(np.abs(estimated - true) / np.abs(true)) * 100\n",
    "\n",
    "\n",
    "def get_logistic_se(X, beta):\n",
    "    \"\"\"Get standard errors for logistic regression coefficients using Fisher information.\"\"\"\n",
    "    u = X @ beta\n",
    "    p = 1 / (1 + np.exp(-np.clip(u, -500, 500)))\n",
    "    W = np.diag(p * (1 - p))\n",
    "    try:\n",
    "        fisher_info = X.T @ W @ X\n",
    "        cov_matrix = np.linalg.inv(fisher_info)\n",
    "        return np.sqrt(np.diag(cov_matrix))\n",
    "    except np.linalg.LinAlgError:\n",
    "        return np.full(len(beta), np.nan)\n",
    "\n",
    "\n",
    "def compute_se_direct(X_labeled, y_labeled, z_labeled, X_unlabeled, z_unlabeled,\n",
    "                      beta_hat, *, e_constant=None, clip_u=500.0):\n",
    "    \"\"\"Sandwich SE for beta_hat in run_dml_direct() (binary logistic case, g=z directly).\"\"\"\n",
    "    X_labeled = np.asarray(X_labeled, dtype=float)\n",
    "    y_labeled = np.asarray(y_labeled, dtype=float).reshape(-1)\n",
    "    z_labeled = np.asarray(z_labeled, dtype=float).reshape(-1)\n",
    "    X_unlabeled = np.asarray(X_unlabeled, dtype=float)\n",
    "    z_unlabeled = np.asarray(z_unlabeled, dtype=float).reshape(-1)\n",
    "\n",
    "    n_p, n_a = y_labeled.shape[0], z_unlabeled.shape[0]\n",
    "    n = n_p + n_a\n",
    "\n",
    "    if n == 0:\n",
    "        raise ValueError(\"Empty data: n_p + n_a must be > 0.\")\n",
    "\n",
    "    X_all = np.vstack([X_labeled, X_unlabeled]) if n_a > 0 else X_labeled\n",
    "    w = np.concatenate([np.ones(n_p), np.zeros(n_a)]) if n_a > 0 else np.ones(n_p)\n",
    "    y_all = np.concatenate([y_labeled, np.zeros(n_a)]) if n_a > 0 else y_labeled\n",
    "    g_all = np.concatenate([z_labeled, z_unlabeled]) if n_a > 0 else z_labeled\n",
    "\n",
    "    if e_constant is None:\n",
    "        e_constant = n_p / n\n",
    "\n",
    "    u = np.clip(X_all @ beta_hat, -clip_u, clip_u)\n",
    "    p = 1.0 / (1.0 + np.exp(-u))\n",
    "\n",
    "    adj = p - g_all + (w / e_constant) * (g_all - y_all)\n",
    "    psi = X_all * adj[:, None]\n",
    "\n",
    "    V = (psi.T @ psi) / n\n",
    "    W = p * (1.0 - p)\n",
    "    Jhat = (X_all.T @ (X_all * W[:, None])) / n\n",
    "\n",
    "    try:\n",
    "        Jinv = np.linalg.inv(Jhat)\n",
    "    except np.linalg.LinAlgError:\n",
    "        Jinv = np.linalg.pinv(Jhat)\n",
    "\n",
    "    Var_beta = (Jinv @ V @ Jinv.T) / n\n",
    "    return np.sqrt(np.clip(np.diag(Var_beta), 0.0, np.inf))\n",
    "\n",
    "\n",
    "def run_dml_direct(X_labeled, y_labeled, z_labeled, X_unlabeled, z_unlabeled):\n",
    "    \"\"\"DML with g=z directly, returning point estimate and standard errors.\"\"\"\n",
    "    n_p, n_a = len(y_labeled), len(z_unlabeled)\n",
    "    n_total = n_p + n_a\n",
    "    e_constant = n_p / n_total\n",
    "\n",
    "    tau_p = np.clip(z_labeled * (1 - 1/e_constant) + y_labeled / e_constant, 0.0, 1.0)\n",
    "    tau_a = z_unlabeled\n",
    "\n",
    "    X_all = np.vstack([X_labeled, X_unlabeled])\n",
    "    tau_all = np.concatenate([tau_p, tau_a])\n",
    "\n",
    "    def neg_loglik(beta):\n",
    "        u = np.clip(X_all @ beta, -500, 500)\n",
    "        return np.mean(-tau_all * u + np.log(1 + np.exp(u)))\n",
    "\n",
    "    def neg_loglik_grad(beta):\n",
    "        u = np.clip(X_all @ beta, -500, 500)\n",
    "        p = 1 / (1 + np.exp(-u))\n",
    "        return X_all.T @ (p - tau_all) / len(tau_all)\n",
    "\n",
    "    result = minimize(neg_loglik, np.zeros(X_all.shape[1]), method='L-BFGS-B',\n",
    "                      jac=neg_loglik_grad, options={'maxiter': 10000, 'ftol': 1e-12})\n",
    "    beta = result.x\n",
    "    se = compute_se_direct(X_labeled, y_labeled, z_labeled, X_unlabeled, z_unlabeled,\n",
    "                           beta_hat=beta, e_constant=e_constant)\n",
    "    return beta, se\n",
    "\n",
    "    \n",
    "def run_naive_logistic(X_labeled, y_labeled, z_labeled, X_unlabeled, z_unlabeled):\n",
    "    \"\"\"Run naive logistic regression treating predictions as true labels.\"\"\"\n",
    "    X_total = np.vstack([X_labeled, X_unlabeled])\n",
    "    y_naive = np.concatenate([y_labeled, (z_unlabeled > 0.5).astype(int)])\n",
    "    beta = logistic(X_total, y_naive)\n",
    "    se = get_logistic_se(X_total, beta)\n",
    "    return beta, se\n",
    "\n",
    "    \n",
    "def run_one_trial(dml_func, X_total, Y_total, Yhat_total, m, n, seed, alpha, true_theta):\n",
    "    \"\"\"Run one trial comparing all estimation methods.\"\"\"\n",
    "    rng = np.random.RandomState(seed)\n",
    "    rand_idx = rng.permutation(len(Y_total))\n",
    "\n",
    "    lab_idx, unlab_idx = rand_idx[:m], rand_idx[m:m+n]\n",
    "    assert np.intersect1d(lab_idx, unlab_idx).size == 0, \"Labeled/unlabeled overlap!\"\n",
    "\n",
    "    X_lab, Y_lab, Yhat_lab = X_total[lab_idx], Y_total[lab_idx], Yhat_total[lab_idx]\n",
    "    X_unlab, Yhat_unlab = X_total[unlab_idx], Yhat_total[unlab_idx]\n",
    "\n",
    "    zcrit = stats.norm.ppf(1 - alpha / 2)\n",
    "    out = {\"m\": m, \"n\": n, \"seed\": seed, \n",
    "           \"lab_idx_head\": lab_idx[:10].copy(), \"unlab_idx_head\": unlab_idx[:10].copy()}\n",
    "\n",
    "    # 1) Primary\n",
    "    primary_beta = logistic(X_lab, Y_lab)\n",
    "    primary_se = get_logistic_se(X_lab, primary_beta)\n",
    "    out.update({\n",
    "        \"primary_beta\": primary_beta, \"primary_se\": primary_se,\n",
    "        \"primary_ci_lower\": primary_beta - zcrit * primary_se,\n",
    "        \"primary_ci_upper\": primary_beta + zcrit * primary_se,\n",
    "        \"primary_mape\": calculate_mape(primary_beta, true_theta)\n",
    "    })\n",
    "\n",
    "    # 2) PPI (lam=1)\n",
    "    try:\n",
    "        ppi_ci_lower, ppi_ci_upper = ppi_logistic_ci(\n",
    "            X_lab, Y_lab.astype(float), Yhat_lab.astype(float),\n",
    "            X_unlab, Yhat_unlab.astype(float), lam=1.0, alpha=alpha,\n",
    "            optimizer_options=OPTIMIZER_OPTIONS)\n",
    "        ppi_beta = ppi_logistic_pointestimate(\n",
    "            X_lab, Y_lab.astype(float), Yhat_lab.astype(float),\n",
    "            X_unlab, Yhat_unlab.astype(float), lam=1.0, optimizer_options=OPTIMIZER_OPTIONS)\n",
    "        out.update({\n",
    "            \"ppi_beta\": ppi_beta, \"ppi_se\": (ppi_ci_upper - ppi_ci_lower) / (2 * zcrit),\n",
    "            \"ppi_ci_lower\": ppi_ci_lower, \"ppi_ci_upper\": ppi_ci_upper,\n",
    "            \"ppi_mape\": calculate_mape(ppi_beta, true_theta)\n",
    "        })\n",
    "    except Exception as e:\n",
    "        out[\"ppi_error\"] = str(e)\n",
    "\n",
    "    # 3) PPI++ (auto lam)\n",
    "    try:\n",
    "        ppi_pp_ci_lower, ppi_pp_ci_upper = ppi_logistic_ci(\n",
    "            X_lab, Y_lab.astype(float), Yhat_lab.astype(float),\n",
    "            X_unlab, Yhat_unlab.astype(float), alpha=alpha, optimizer_options=OPTIMIZER_OPTIONS)\n",
    "        ppi_pp_beta = ppi_logistic_pointestimate(\n",
    "            X_lab, Y_lab.astype(float), Yhat_lab.astype(float),\n",
    "            X_unlab, Yhat_unlab.astype(float), optimizer_options=OPTIMIZER_OPTIONS)\n",
    "        out.update({\n",
    "            \"ppi_pp_beta\": ppi_pp_beta, \"ppi_pp_se\": (ppi_pp_ci_upper - ppi_pp_ci_lower) / (2 * zcrit),\n",
    "            \"ppi_pp_ci_lower\": ppi_pp_ci_lower, \"ppi_pp_ci_upper\": ppi_pp_ci_upper,\n",
    "            \"ppi_pp_mape\": calculate_mape(ppi_pp_beta, true_theta)\n",
    "        })\n",
    "    except Exception as e:\n",
    "        out[\"ppi_pp_error\"] = str(e)\n",
    "\n",
    "    # 4) DML (g=z)\n",
    "    dml_beta, dml_se = dml_func(X_lab, Y_lab, Yhat_lab, X_unlab, Yhat_unlab)\n",
    "    out.update({\n",
    "        \"dml_beta\": dml_beta, \"dml_se\": dml_se,\n",
    "        \"dml_ci_lower\": dml_beta - zcrit * dml_se, \"dml_ci_upper\": dml_beta + zcrit * dml_se,\n",
    "        \"dml_mape\": calculate_mape(dml_beta, true_theta)\n",
    "    })\n",
    "\n",
    "    # 5) Naive Logistic\n",
    "    naive_beta, naive_se = run_naive_logistic(X_lab, Y_lab, Yhat_lab, X_unlab, Yhat_unlab)\n",
    "    out.update({\n",
    "        \"naive_beta\": naive_beta, \"naive_se\": naive_se,\n",
    "        \"naive_ci_lower\": naive_beta - zcrit * naive_se, \"naive_ci_upper\": naive_beta + zcrit * naive_se,\n",
    "        \"naive_mape\": calculate_mape(naive_beta, true_theta)\n",
    "    })\n",
    "\n",
    "    return out"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4a3a4498",
   "metadata": {},
   "source": [
    "# MAPE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5d27869e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "m=100: 100%|██████████| 50/50 [00:04<00:00, 10.51it/s]\n",
      "m=250: 100%|██████████| 50/50 [00:02<00:00, 19.40it/s]\n",
      "m=500: 100%|██████████| 50/50 [00:02<00:00, 20.37it/s]\n",
      "m=750: 100%|██████████| 50/50 [00:02<00:00, 17.60it/s]\n",
      "m=1000: 100%|██████████| 50/50 [00:03<00:00, 15.89it/s]\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>dml_mape</th>\n",
       "      <th>ppi_mape</th>\n",
       "      <th>ppi_pp_mape</th>\n",
       "      <th>primary_mape</th>\n",
       "      <th>naive_mape</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>m</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>161.365010</td>\n",
       "      <td>821.827035</td>\n",
       "      <td>866.271129</td>\n",
       "      <td>979.830733</td>\n",
       "      <td>407.946313</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>250</th>\n",
       "      <td>147.929430</td>\n",
       "      <td>518.818232</td>\n",
       "      <td>508.746074</td>\n",
       "      <td>563.854239</td>\n",
       "      <td>384.702108</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>500</th>\n",
       "      <td>147.382132</td>\n",
       "      <td>383.920866</td>\n",
       "      <td>404.746527</td>\n",
       "      <td>480.986020</td>\n",
       "      <td>324.564649</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750</th>\n",
       "      <td>139.650946</td>\n",
       "      <td>295.399788</td>\n",
       "      <td>299.521906</td>\n",
       "      <td>320.679933</td>\n",
       "      <td>263.126740</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1000</th>\n",
       "      <td>141.492095</td>\n",
       "      <td>270.659659</td>\n",
       "      <td>282.432585</td>\n",
       "      <td>291.795603</td>\n",
       "      <td>240.384252</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        dml_mape    ppi_mape  ppi_pp_mape  primary_mape  naive_mape\n",
       "m                                                                  \n",
       "100   161.365010  821.827035   866.271129    979.830733  407.946313\n",
       "250   147.929430  518.818232   508.746074    563.854239  384.702108\n",
       "500   147.382132  383.920866   404.746527    480.986020  324.564649\n",
       "750   139.650946  295.399788   299.521906    320.679933  263.126740\n",
       "1000  141.492095  270.659659   282.432585    291.795603  240.384252"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results = []\n",
    "for m in MS:\n",
    "    for j in tqdm(range(NUM_TRIALS), desc=f\"m={m}\", leave=True):\n",
    "        res = run_one_trial(\n",
    "            dml_func=run_dml_direct,\n",
    "            X_total=X_total, Y_total=Y_total, Yhat_total=Yhat_total,\n",
    "            m=int(m), n=N_UNLABELED, seed=j, alpha=ALPHA, true_theta=true_theta\n",
    "        )\n",
    "        results.append(res)\n",
    "\n",
    "df_results = pd.DataFrame(results)\n",
    "\n",
    "mape_table = df_results[['m', 'dml_mape', 'ppi_mape', 'ppi_pp_mape', 'primary_mape', 'naive_mape']].groupby('m').mean()\n",
    "mape_table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "3a3f6fa0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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BQXasGGDvvjiC0mV/08ZOHCgXnjhBfn7+zd67ahEcEKLlp+fXxmaRkkKctBNyySdlRQox/0Ny5eKNtrXj+JSMTExSktLq/O89PR0JSYmat26dYqNjTV8bwD2ubRVSZK++uorVVRUaOzYsSouLpYkvfXWW+rcubOuueYaSdK1116rzp0765133tGDDz7Y6DWjEsEJkCpDkyM7krrZyGRfX1+7WoViY2NpRQKcoGvXrjKZTNVenXfu3FmSbF6Rv/baa/ruu+/UqtWvP6orKiq0evVqgpMLEZwAAGgk7du3180336zly5frkUceqbWf0zfffKN9+/Zp586dateunXX/2bNnNWjQIH377bfq2bNnY5WNSxCcAABoRCtWrNDAgQPVt29fzZ07V7169ZKHh4e+/vpra3/E1atX67rrrquxI3j//v21evVqPffccy6oHgQnOExLGJ0GoGlIP+m+z+nSpYsOHDighQsXKjk5WcePH5e3t7e6d++uGTNm6MEHH1Tnzp01a9asGq8fPXq0UlJS9OyzzzawetQHwQkOkZOTo+joWBUVFTr83g4fnWb2VWZmOuEJaIaCgoLk62NW4orGnTk8KMi+0SWhoaF64YUX9MILL9R4/HL/CE1KSlJSUpIkafz48Ro/frxdz0bDEJzgEPn5+b+EpnWSjI3GqttFSdmSIiUZm1OobukqKkqs9+g0AO4tIiJC6RmZrFUHpyE4wcFiJTlyNNZAB94LQEsQERFBkIHTeLi6AAAAgKaC4AQAAGAQwQkAAMAgghMAAIBBBCcAAACDGFUHNGFMOgoAjYvgBDRROTk5io2JVuFFx0/05+hJR319zErPyCQ8AWjyCE5AE5Wfn6/Ci0VaN1WKDXPMPS+WSNn5UmSQ5NPaMfdMPyklrihi0lG4p6Ii6e9/lzZvls6ckdq3l+68U7rrLslsdnV1bmfu3LnavHmzDh486OpSNH78eJ09e1abN29u1OcSnIAmLjZM6hPluPsNjHbcvQC3tmWLNH689NNPkoeHVFFR+evGjdJjj0mvvy7ddptTHn3q1CmlpKRo69atOn78uAICAtStWzclJibq/vvvl6+vr1Oe60xz587VvHnzLntOVlaWIiMj7bpvdna2oqKidODAAV177bX1L9BBCE4AgJZny5bKlqUqFRW2v549K91xR2VL1O23O/TRP/74owYOHKjA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+iX7h/UzOAEA4Gx2B6fNmzdr/fr1SkhIsFnUt3v37jp69KhDi0PzY8+Qfolh/QAA92L3Ir+nT5+uNvmlJF24cMEmSAEAADQ3dgenfv36aevWrdbtqrD0yiuvqH///o6rDAAAwM3Y/aouJSVFw4cP1+HDh1VWVqbnn39e3333nfbu3atdu3Y5o0YAAAC3YHeL04ABA7Rnzx4VFhaqS5cu2rZtmzp27Ki9e/faPVoKAACgKTFZalt8rpkqKChQQECAzp07J39/f1eXAwAAXMyebFDvmSvz8vKUl5eniooKm/29evWq7y0BAADcmt3BKS0tTePGjVN6erp+21hlMplUXl7usOIAAADcid3BacKECbr66qu1evVqdezYkSkIAABAi2F3cMrKytLGjRvVtWtXZ9QDAADgtuweVTd06FD985//dMjDd+/erdtuu01hYWEymUzavHlzndfs2rVL8fHxMpvN6ty5s1atWuWQWgAAAOpid4vTq6++qnHjxunbb79Vz5495eXlZXP89ttvN3yvCxcu6JprrtGECRM0evToOs/PysrSyJEjNXnyZK1bt0579uzR1KlT1aFDB0PXAwAANITdwemLL77Q559/rn/84x/VjtnbOXzEiBEaMWKE4fNXrVqliIgILV26VJIUGxurffv2adGiRQQnAADgdHa/qnv00Ud13333KTc3VxUVFTYfZ4+o27t3r4YNG2az75ZbbtG+fftUWlrq1GcDAADY3eJ05swZPf744+rYsaMz6rmsU6dOVXtux44dVVZWpvz8fIWGhla7pri4WMXFxdbtgoICp9cJAACaJ7tbnEaNGqUdO3Y4oxZDfjv9QdVcUrVNi5CSkqKAgADrJzw83Ok1AgCA5snuFqerr75aycnJ+vzzzxUXF1etc/ijjz7qsOJ+KyQkRKdOnbLZl5eXp1atWql9+/Y1XpOcnKykpCTrdkFBAeEJAADUS71G1bVp00a7du3Srl27bI6ZTCanBqf+/fvrvffes9m3bds29e3bt1qAq+Lt7S1vb2+n1QQAAFqOek2A6Sjnz5/XkSNHbO598OBBtWvXThEREUpOTtaJEye0du1aSdKUKVO0fPlyJSUlafLkydq7d69Wr16tt99+22E1AQAA1Kbei/w6wr59+zRkyBDrdtUrtXHjxik1NVW5ubnKycmxHo+KitIHH3ygxx9/XC+++KLCwsK0bNkypiIAAACNwmT57Uq9Bhw/flxbtmxRTk6OSkpKbI4tWbLEYcU5Q0FBgQICAnTu3Dn5+/u7uhwAAOBi9mQDu1ucPvnkE91+++2KiopSZmamevbsqezsbFksFvXp06feRQMAALg7u6cjSE5O1n/913/p22+/ldls1oYNG3Ts2DENHjxYd911lzNqBAAAcAt2B6f09HSNGzdOktSqVStdvHhRbdq00VNPPaVnn33W4QUCAAC4C7uDk5+fn3Um7rCwMB09etR6LD8/33GVAQAAuBm7+zglJCRoz5496t69u2699Vb913/9l7755htt3LhRCQkJzqgRAADALdgdnJYsWaLz589LkubOnavz589r/fr16tq1q5577jmHFwgAAOAu7ApO5eXlOnbsmHr16iVJ8vX11YoVK5xSGAAAgLuxq4+Tp6enbrnlFp09e9ZJ5QAAALgvuzuHx8XF6ccff3RGLQAAAG7N7uD09NNPa8aMGXr//feVm5urgoICmw8AAEBzZfeSKx4ev2Ytk8lk/dpischkMqm8vNxx1TkBS64AAIBLOXXJlR07dtS7MAAAgKbM7uA0ePBgZ9QBAADg9uwOTlUKCwuVk5OjkpISm/1VUxUAAAA0N3YHp9OnT2vChAn6xz/+UeNxd+/jBAAAUF92j6qbPn26fvrpJ3355Zfy8fHRhx9+qNdff13dunXTli1bnFEjAACAW7C7xenTTz/Vu+++q379+snDw0NXXXWVbr75Zvn7+yslJUW33nqrM+oEAABwObtbnC5cuKDg4GBJUrt27XT69GlJlRNj7t+/37HVAQAAuBG7g1N0dLQyMzMlSddee61eeuklnThxQqtWrVJoaKjDCwQAAHAXdr+qmz59uk6ePClJmjNnjm655Ra9+eabat26tVJTUx1dHwAAgNuwe+bw3yosLFRGRoYiIiIUFBTkqLqchpnDAQDApezJBoZf1RUWFmratGm68sorFRwcrDFjxig/P1++vr7q06dPkwhNAAAADWE4OM2ZM0epqam69dZbde+992r79u166KGHnFkbAACAWzHcx2njxo1avXq17r33XklSYmKiBg4cqPLycnl6ejqtQAAAAHdhuMXp2LFjuuGGG6zb1113nVq1amXtKA4AANDcGQ5O5eXlat26tc2+Vq1aqayszOFFAQAAuCPDr+osFovGjx8v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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Filter to m=1000\n",
    "df_results_1000 = df_results[df_results[\"m\"] == 1000].copy()\n",
    "\n",
    "dml_betas = np.stack(df_results_1000[\"dml_beta\"].values)\n",
    "ppi_betas = np.stack(df_results_1000[\"ppi_beta\"].values)\n",
    "ppi_pp_betas = np.stack(df_results_1000[\"ppi_pp_beta\"].values)\n",
    "\n",
    "g_models = [\"ppi\", \"ppi++\", \"dml\"]\n",
    "colors = [\"blue\", \"green\", \"orange\"]\n",
    "betas_by_model = {\"ppi\": ppi_betas, \"ppi++\": ppi_pp_betas, \"dml\": dml_betas}\n",
    "d = dml_betas.shape[1]\n",
    "feature_labels = list(range(1, d + 1))\n",
    "\n",
    "# Grouped positions\n",
    "centers = np.arange(1, d + 1)\n",
    "width = 0.22\n",
    "offsets = np.array([-width, 0.0, width])\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "ax.set_ylabel(\"Parameter Value\")\n",
    "ax.set_xlabel(\"Feature\")\n",
    "\n",
    "boxprops = dict(linewidth=1.0, edgecolor=\"black\")\n",
    "medianprops = dict(linewidth=1.2, color=\"black\")\n",
    "whiskerprops = dict(linewidth=1.0, color=\"black\")\n",
    "capprops = dict(linewidth=1.0, color=\"black\")\n",
    "\n",
    "for j, g_model in enumerate(g_models):\n",
    "    betas = betas_by_model[g_model]\n",
    "    estimated_params = [betas[:, i] for i in range(d)]\n",
    "    pos = centers + offsets[j]\n",
    "    bplot = ax.boxplot(\n",
    "        estimated_params, positions=pos, widths=width * 0.9,\n",
    "        patch_artist=True, showfliers=False, zorder=1 + j,\n",
    "        boxprops=boxprops, medianprops=medianprops,\n",
    "        whiskerprops=whiskerprops, capprops=capprops\n",
    "    )\n",
    "    for patch in bplot[\"boxes\"]:\n",
    "        patch.set_facecolor(colors[j])\n",
    "\n",
    "ax.set_xticks(centers)\n",
    "ax.set_xticklabels(feature_labels)\n",
    "\n",
    "# Ground truth markers\n",
    "true_theta_arr = np.asarray(true_theta)\n",
    "half_span = 1.3 * width\n",
    "for i, gt in enumerate(true_theta_arr):\n",
    "    ax.hlines(gt, centers[i] - half_span, centers[i] + half_span,\n",
    "              colors=\"red\", linestyles=\"--\", linewidth=1.4, zorder=5)\n",
    "    ax.plot(centers[i], gt, marker=\"o\", color=\"red\", markersize=7, zorder=6)\n",
    "\n",
    "legend_elements = [\n",
    "    Patch(facecolor=\"blue\", edgecolor=\"black\", label=\"PPI\"),\n",
    "    Patch(facecolor=\"green\", edgecolor=\"black\", label=\"PPI++\"),\n",
    "    Patch(facecolor=\"orange\", edgecolor=\"black\", label=\"GAI\"),\n",
    "    Line2D([0], [0], marker=\"o\", linestyle=\"--\", color=\"r\",\n",
    "           label=\"Ground Truth\", markerfacecolor=\"r\", markersize=8),\n",
    "]\n",
    "ax.legend(handles=legend_elements, loc=\"upper right\")\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "76ad1cb2",
   "metadata": {},
   "source": [
    "# CI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d3404231",
   "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 th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th>method</th>\n",
       "      <th>DML</th>\n",
       "      <th>PPI</th>\n",
       "      <th>PPI++</th>\n",
       "      <th>PRIMARY</th>\n",
       "      <th>NAIVE</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>m</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>100.0</td>\n",
       "      <td>88.0</td>\n",
       "      <td>83.0</td>\n",
       "      <td>80.0</td>\n",
       "      <td>30.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>250</th>\n",
       "      <td>100.0</td>\n",
       "      <td>94.0</td>\n",
       "      <td>88.0</td>\n",
       "      <td>78.0</td>\n",
       "      <td>31.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>500</th>\n",
       "      <td>100.0</td>\n",
       "      <td>95.0</td>\n",
       "      <td>91.0</td>\n",
       "      <td>78.0</td>\n",
       "      <td>34.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750</th>\n",
       "      <td>99.0</td>\n",
       "      <td>96.0</td>\n",
       "      <td>93.0</td>\n",
       "      <td>82.0</td>\n",
       "      <td>38.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1000</th>\n",
       "      <td>99.0</td>\n",
       "      <td>94.0</td>\n",
       "      <td>89.0</td>\n",
       "      <td>78.0</td>\n",
       "      <td>38.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "method    DML   PPI  PPI++  PRIMARY  NAIVE\n",
       "m                                         \n",
       "100     100.0  88.0   83.0     80.0   30.0\n",
       "250     100.0  94.0   88.0     78.0   31.0\n",
       "500     100.0  95.0   91.0     78.0   34.0\n",
       "750      99.0  96.0   93.0     82.0   38.0\n",
       "1000     99.0  94.0   89.0     78.0   38.0"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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>method</th>\n",
       "      <th>DML</th>\n",
       "      <th>PPI</th>\n",
       "      <th>PPI++</th>\n",
       "      <th>PRIMARY</th>\n",
       "      <th>NAIVE</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>m</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>0.000026</td>\n",
       "      <td>0.000025</td>\n",
       "      <td>0.000022</td>\n",
       "      <td>0.000022</td>\n",
       "      <td>0.000006</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>250</th>\n",
       "      <td>0.000018</td>\n",
       "      <td>0.000018</td>\n",
       "      <td>0.000017</td>\n",
       "      <td>0.000013</td>\n",
       "      <td>0.000006</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>500</th>\n",
       "      <td>0.000013</td>\n",
       "      <td>0.000013</td>\n",
       "      <td>0.000012</td>\n",
       "      <td>0.000009</td>\n",
       "      <td>0.000005</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750</th>\n",
       "      <td>0.000011</td>\n",
       "      <td>0.000011</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000007</td>\n",
       "      <td>0.000005</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1000</th>\n",
       "      <td>0.000009</td>\n",
       "      <td>0.000010</td>\n",
       "      <td>0.000009</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>0.000005</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "method       DML       PPI     PPI++   PRIMARY     NAIVE\n",
       "m                                                       \n",
       "100     0.000026  0.000025  0.000022  0.000022  0.000006\n",
       "250     0.000018  0.000018  0.000017  0.000013  0.000006\n",
       "500     0.000013  0.000013  0.000012  0.000009  0.000005\n",
       "750     0.000011  0.000011  0.000010  0.000007  0.000005\n",
       "1000    0.000009  0.000010  0.000009  0.000006  0.000005"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Build long-form DataFrame with CI information\n",
    "ci_rows = []\n",
    "for idx, row in df_results.iterrows():\n",
    "    m_val = row[\"m\"]\n",
    "    for param_idx in range(2):\n",
    "        for m_name in CI_METHODS:\n",
    "            ci_rows.append({\n",
    "                'method': 'PPI++' if m_name == 'ppi_pp' else m_name.upper(),\n",
    "                'm': m_val,\n",
    "                'param_idx': param_idx,\n",
    "                'ci_lower': row[f'{m_name}_ci_lower'][param_idx],\n",
    "                'ci_upper': row[f'{m_name}_ci_upper'][param_idx],\n",
    "                'true_theta': true_theta[param_idx],\n",
    "            })\n",
    "\n",
    "df_ci = pd.DataFrame(ci_rows)\n",
    "df_ci['contains_true'] = (df_ci['ci_lower'] <= df_ci['true_theta']) & (df_ci['ci_upper'] >= df_ci['true_theta'])\n",
    "df_ci['ci_width'] = df_ci['ci_upper'] - df_ci['ci_lower']\n",
    "\n",
    "# Compute coverage and width tables\n",
    "method_order = ['DML', 'PPI', 'PPI++', 'PRIMARY', 'NAIVE']\n",
    "\n",
    "def compute_summary_table(df, value_col, agg_func='mean'):\n",
    "    \"\"\"Compute summary table grouped by method and m.\"\"\"\n",
    "    summary = df.groupby(['method', 'm'])[value_col].agg(agg_func).reset_index()\n",
    "    summary['method'] = pd.Categorical(summary['method'].str.upper(), categories=method_order, ordered=True)\n",
    "    return summary.pivot(index='m', columns='method', values=value_col)\n",
    "\n",
    "# Coverage probability\n",
    "ci_coverage = compute_summary_table(df_ci, 'contains_true') * 100\n",
    "print('Coverage Probability (%)')\n",
    "display(ci_coverage)\n",
    "\n",
    "# CI Width\n",
    "ci_width = compute_summary_table(df_ci, 'ci_width')\n",
    "print('CI Width')\n",
    "display(ci_width)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "aca4ca26",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Build trial-level summary DataFrame for plots and t-tests\n",
    "ci_rows = []\n",
    "for trial, row in df_results.iterrows():\n",
    "    m_val = row['m']\n",
    "    for param_idx in range(2):\n",
    "        for m_name in CI_METHODS:\n",
    "            ci_rows.append({\n",
    "                'estimator': METHOD_MAP[m_name],\n",
    "                'trial': trial,\n",
    "                'm': m_val,\n",
    "                'param_idx': param_idx,\n",
    "                'ci_lower': row[f'{m_name}_ci_lower'][param_idx],\n",
    "                'ci_upper': row[f'{m_name}_ci_upper'][param_idx],\n",
    "                'true_theta': true_theta[param_idx],\n",
    "                'mape': row.get(MAPE_COL_MAP[m_name], np.nan),\n",
    "            })\n",
    "\n",
    "df_ci_trials = pd.DataFrame(ci_rows)\n",
    "df_ci_trials['contains_true'] = (\n",
    "    (df_ci_trials['ci_lower'] <= df_ci_trials['true_theta']) &\n",
    "    (df_ci_trials['ci_upper'] >= df_ci_trials['true_theta'])\n",
    ")\n",
    "df_ci_trials['ci_width'] = df_ci_trials['ci_upper'] - df_ci_trials['ci_lower']\n",
    "\n",
    "summary_df = (\n",
    "    df_ci_trials\n",
    "    .groupby(['estimator', 'm', 'trial'])\n",
    "    .agg(\n",
    "        average_coverage=('contains_true', 'mean'),\n",
    "        average_width=('ci_width', 'mean'),\n",
    "        average_mape=('mape', 'first'),\n",
    "    )\n",
    "    .reset_index()\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "49d072e7",
   "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>estimator</th>\n",
       "      <th>m</th>\n",
       "      <th>trial</th>\n",
       "      <th>average_coverage</th>\n",
       "      <th>average_width</th>\n",
       "      <th>average_mape</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>dml</td>\n",
       "      <td>100</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000017</td>\n",
       "      <td>188.173582</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>dml</td>\n",
       "      <td>100</td>\n",
       "      <td>1</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000047</td>\n",
       "      <td>123.642510</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>dml</td>\n",
       "      <td>100</td>\n",
       "      <td>2</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000020</td>\n",
       "      <td>48.336853</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>dml</td>\n",
       "      <td>100</td>\n",
       "      <td>3</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000048</td>\n",
       "      <td>210.022104</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>dml</td>\n",
       "      <td>100</td>\n",
       "      <td>4</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000020</td>\n",
       "      <td>7.210192</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>1245</th>\n",
       "      <td>primary</td>\n",
       "      <td>1000</td>\n",
       "      <td>245</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>354.475189</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1246</th>\n",
       "      <td>primary</td>\n",
       "      <td>1000</td>\n",
       "      <td>246</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000007</td>\n",
       "      <td>279.547899</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1247</th>\n",
       "      <td>primary</td>\n",
       "      <td>1000</td>\n",
       "      <td>247</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.000007</td>\n",
       "      <td>525.188774</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1248</th>\n",
       "      <td>primary</td>\n",
       "      <td>1000</td>\n",
       "      <td>248</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>102.902868</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1249</th>\n",
       "      <td>primary</td>\n",
       "      <td>1000</td>\n",
       "      <td>249</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.000006</td>\n",
       "      <td>243.481746</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1250 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     estimator     m  trial  average_coverage  average_width  average_mape\n",
       "0          dml   100      0               1.0       0.000017    188.173582\n",
       "1          dml   100      1               1.0       0.000047    123.642510\n",
       "2          dml   100      2               1.0       0.000020     48.336853\n",
       "3          dml   100      3               1.0       0.000048    210.022104\n",
       "4          dml   100      4               1.0       0.000020      7.210192\n",
       "...        ...   ...    ...               ...            ...           ...\n",
       "1245   primary  1000    245               1.0       0.000006    354.475189\n",
       "1246   primary  1000    246               1.0       0.000007    279.547899\n",
       "1247   primary  1000    247               0.5       0.000007    525.188774\n",
       "1248   primary  1000    248               1.0       0.000006    102.902868\n",
       "1249   primary  1000    249               0.5       0.000006    243.481746\n",
       "\n",
       "[1250 rows x 6 columns]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "summary_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "19123078",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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322+2+uzYsUK8vPzo+DgYCIyv3S8V69epFQqycfHh5588skm49kZ3XlMIyKaNm0axcbG0uHDhyk7O5tWr15NSqWSzp8/36p1LF68mJycnMjPz4+6d+9O8fHxlJOT0/K6tmrtjN1nEhMTLYnEnj17qHv37mQymYiI6P3336du3bpZ/q4vCwgIIKPRSER3/4Jv2rSJ5HI5xcbG0g8//EBZWVlUXV1NBw4coE8//ZQyMjIoIyODnn32WfL19bUkHEajkcLDwykuLo5OnTpFqampNGTIEKuDTE1NDYWGhtIzzzxDp0+fpoyMDJo2bRqFh4eTVqsV3d65c+fSiBEjrMr27dtndYKoPyEHBQVRly5dKDY2lnbs2GE1z9ChQ+m9994jvV5PTz75JC1YsICIiOLi4hodBJuya9cuAnDXBMOWRC42NpZeeOEFy9++vr50/Phxevjhh+mjjz4iIqL8/HwCQPv37yeixif97du3k0KhoI8//piysrJo4cKF5OrqakmcqqqqaOrUqTRx4kQqKiqioqIi0mq1lvpFRETQV199RefOnaOnnnqKgoODSa/XN7tt06dPp9dff52IiP785z/TjBkzrMbPnz+fPDw8aPPmzZSdnU2pqan08ccfW8Wle/futHPnTrp48SIVFhbS2rVrSaPR0NatWykrK4vmz59Pcrncsk+uXr2agoKC6PDhw5SXl0epqamUlJREREQ7duwgjUZDe/fupUuXLtHPP/9siZ8YscRp586dBIDS09Pvup8TmU+cPj4+lJiYSDk5OZSXl0c6nY4WLVpEx44do4sXL9J///tfcnJyou3bt1vmS0hIIFdXV3rxxRcpKyuLEhMTCQA99NBDtHz5cjp//jz93//9H8nlcsrPzyeiu39nmvqMbfmuJSQkkIuLC02fPp3OnDlD6enpdPz4cZJKpZSUlER5eXl08uRJ+sc//tHsPtHZ3Jk4ZWdnkyAIVFhYaDXduHHj6M0332zVOvbu3Uuff/45nT59mpKTk2n06NHk6+tLJSUlLatrq9bO2H0mNjbW8p+sXq8nb29vSk5OJqKG1qXDhw9bph82bBjNmzePiGz7gm/atIkA0KlTp5qth8FgIFdXV9qzZw8REX3zzTckk8moqKjIMs2dLU6JiYkUHh5uldhptVpSq9X07bffiq7n22+/JYlEQklJSWQwGKigoIBGjBhB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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_kde_distribution(df, value_col, estimator_order, m_filter, xlabel, xlim=None, figsize=(6, 4)):\n",
    "    \"\"\"Plot KDE distribution for a given metric across estimators.\"\"\"\n",
    "    d = df.loc[df['m'] == m_filter].dropna(subset=[value_col]).copy()\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=figsize)\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",
    "        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",
    "        ax.fill_between(x, y, alpha=0.35, color=COLOR_MAP.get(est), label=LEGEND_MAP.get(est, est.upper()))\n",
    "        ax.plot(x, y, linewidth=1.5, color=COLOR_MAP.get(est))\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, m_filter, xlabel, xlim=None, figsize=(6, 4)):\n",
    "    \"\"\"Plot histogram distribution for a given metric across estimators.\"\"\"\n",
    "    d = df.loc[df['m'] == m_filter].dropna(subset=[value_col]).copy()\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=figsize)\n",
    "    bins = np.linspace(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",
    "        counts, _ = np.histogram(w, bins=bins, density=False)\n",
    "        offset = (i - n_estimators / 2) * bar_width + bar_width / 2\n",
    "        ax.bar(bin_centers + offset, counts, width=bar_width, color=COLOR_MAP.get(est),\n",
    "               label=LEGEND_MAP.get(est, est.upper()), alpha=0.85, align='center', edgecolor=\"none\")\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()\n",
    "\n",
    "\n",
    "# Plot CI Width distribution\n",
    "estimator_order = ['ppi', 'ppi++', 'dml']\n",
    "plot_kde_distribution(summary_df, \"average_width\", estimator_order, m_filter=1000,\n",
    "                      xlabel=\"Average 95% CI Width Across Parameters\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3ade9bff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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qVMXrNbKxJe+nC0vL09Hjhwp9d8Yqux87c306dO1Y8cOPfvssxe6xErJl7589tlnateuncaPH69LLrlETZs21RNPPKHjx4+XRcmVgi996dy5s/bu3avPP/9cZqaff/5ZH330kW666aayKBlFKM3P/gpxAcyi/Prrr8rNzS3wg79RUVEFfhg4X3p6eqHz5+Tk6Ndff1VMTMwFq7ey8KUvZ5s4caKysrJ0xx13XIgSKy1ferNt2zY9/fTTWrZsmQIDK/Rbht/ypS87d+7U8uXLVbVqVc2bN0+//vqrhg4dqv/+97+c51RKfOlL586dNWvWLN155506ceKEcnJydMstt2jy5MllUTKKUJqf/RV6j1M+l8vlddvMCkw71/yFTcf5KWlf8r3//vtKSkrS3LlzVbdu3QtVXqXmtDe5ubnq16+fxowZo6ZNm5ZVeZVWSV4zeXl5crlcmjVrltq3b6/evXsrOTlZM2bMYK9TKStJXzZv3qxHH31UzzzzjNauXasFCxYoLS2N31f1A6X12V+h//lYu3ZtValSpUDyP3DgQIFkmS86OrrQ+QMDA1WrVq0LVmtl4ktf8s2dO1eDBg3Shx9+qB49elzIMiulkvbmyJEjWrNmjVJTU/Xwww9LOv2BbWYKDAzUwoULdd1115VJ7RczX14zMTExuuSSSxQZGemZdtlll8nMtHfvXiUkJFzQmisDX/oybtw4denSRU8++aQkqXXr1qpWrZquueYavfDCCxzVKCel+dlfofc4BQcHq23btkpJSfGanpKSos6dOxe6TKdOnQrMv3DhQrVr105BQUEXrNbKxJe+SKf3NA0cOFCzZ8/mfIALpKS9iYiI0Pfff6/169d7/oYMGaJmzZpp/fr16tChQ1mVflHz5TXTpUsX7du3T0ePHvVM27p1qwICAlSvXr0LWm9l4Utfjh07poAA74/WKlWqSPq/PRwoe6X62V/i08n9TP5XRadOnWqbN2+24cOHW7Vq1WzXrl1mZvb000/bPffc45k//yuJjz32mG3evNmmTp3K5QgugJL2Zfbs2RYYGGivvfaa7d+/3/N3+PDh8noIF62S9uZsfKvuwihpX44cOWL16tWz3/zmN7Zp0yZbsmSJJSQk2AMPPFBeD+GiVNK+TJ8+3QIDA+3111+3HTt22PLly61du3bWvn378noIF6UjR45YamqqpaammiRLTk621NRUz2UiLuRnf4UPTmZmr732msXHx1twcLBdeeWVtmTJEs/YgAEDrFu3bl7zL1682K644goLDg62Bg0a2BtvvFHGFVcOJelLt27dTFKBvwEDBpR94ZVASV8zZyI4XTgl7csPP/xgPXr0sJCQEKtXr56NGDHCjh07VsZVX/xK2pdXX33VmjdvbiEhIRYTE2P9+/e3vXv3lnHVF7dFixYV+5lxIT/7XWbsOwQAAHCiQp/jBAAAUJYITgAAAA4RnAAAABwiOAEAADhEcAIAAHCI4AQAAOAQwQkAAMAhghMAAIBDBCcAAACHCE4oFytXrlSVKlV0ww03lHcpZeLrr79W586dFR4erpiYGD311FPKycnxjO/atUsul6vA34IFCzzzpKam6oorrlBYWJhuueUWHTp0yDOWk5OjK6+8UqtXr3ZUT2pqqv7f//t/ioqKUtWqVdW0aVM9+OCD2rp1q1c969evL3Y927dv13333ad69erJ7XarYcOGuuuuu7RmzZoSPDsXr4q8nZ+9TdaoUUNdu3bVkiVLyrs0n82YMUPVq1cv7zJQwRGcUC6mTZumRx55RMuXL9eePXsu6H3l5uYqLy/vgt5HcTZs2KDevXvrhhtuUGpqqubMmaPPPvtMTz/9dIF5v/rqK+3fv9/zd91113nGHnjgAV133XVat26dDh8+rLFjx3rG/vKXv+jqq6/WVVdddc56/vGPf6hjx47Kzs7WrFmz9MMPP+hvf/ubIiMj9ac//cnx41qzZo3atm2rrVu36q233tLmzZs1b948XXrppXr88ccdr+dCOHnyZLnef77S3M7L6zHlb5NLlixRRESEevfurbS0NJ/W5S99OV/l/Z6CcnZev7IH+ODo0aMWHh5uP/74o9155502ZswYz1jHjh3tqaee8pr/wIEDFhgYaN98842ZmWVnZ9uTTz5psbGxFhoaau3bt7dFixZ55p8+fbpFRkba/Pnz7bLLLrMqVarYzp07bdWqVdajRw+rVauWRUREWNeuXW3t2rVe9/XDDz9Yly5dzO1222WXXWYpKSkmyebNm+eZZ+/evXbHHXdY9erVrWbNmnbLLbdYWlpakY931KhR1q5dO69p8+bNs6pVq1pmZqaZmaWlpZkkS01NLXI9ISEh9sMPP5iZ2euvv269e/c2M7MdO3ZYQkKCZ13FycrKstq1a9utt95a6PihQ4cc1ZOXl2ctWrSwtm3bWm5ubpHrMTPbsGGDXXvttVa1alWrWbOmPfjgg3bkyBEzM1uwYIG53W6v+c3MHnnkEevatavn9ooVK+yaa66xqlWrWr169eyRRx6xo0ePesbj4+Pt+eeftwEDBlhERITde++9ZmY2cuRIS0hIsJCQEGvYsKH98Y9/tJMnT3rd1/PPP2916tSxsLAwGzRokD311FMFfsR42rRpdumll5rb7bZmzZrZa6+9VujzcqbitvN8f//7361t27bmdrutVq1adtttt53zMX300UfWvHlzCw4Otvj4ePvLX/7itc7XXnvNmjRpYm632+rWrWu33367Z+zDDz+0li1benpx/fXXez2PZypsG9i7d69JsjfffNN+/fVX++1vf2uXXHKJhYSEWMuWLW327Nle6+jWrZs99NBD9thjj1mtWrU8PZ04caK1bNnSQkNDrV69evb73//es02Yeb+GmzZtaiEhIXb77bfb0aNHbcaMGRYfH2/Vq1e3hx9+2HJycjzLFffeUNiPwj777LPnXO7ses58T1m0aJFdddVVFhoaapGRkda5c2fbtWtXoc8nLh4EJ5S5qVOneoLE/PnzrUGDBpaXl2dmZpMnT7b69et7budPu+SSSzwf0P369bPOnTvb0qVLbfv27TZhwgRzu922detWMzv9JhcUFGSdO3e2FStW2I8//mhHjx61r7/+2v72t7/Z5s2bbfPmzTZo0CCLioryBI7c3Fxr1qyZJSYm2vr1623ZsmXWvn17r+CUlZVlCQkJdv/999uGDRts8+bN1q9fP2vWrJllZ2cX+nhHjBhhV199tde0BQsWmCTPm3P+h1RcXJzVqVPHOnfubB9++KHXMh07drRXX33VTp06Zbfffrs9/fTTZmaWmJjoFeyK88knn5gkW7lyZbHznSs4rVu3ziQV+KA8W1ZWlsXGxlrfvn3t+++/t6+//toaNmzo+QXznJwci4qKsr/+9a+eZfKnvfXWW2Z2OniFhYXZyy+/bFu3brUVK1bYFVdcYQMHDvQsEx8fbxERETZhwgTbtm2bbdu2zcxOh6IVK1ZYWlqaffbZZxYVFWUvvfSSZ7n33nvPqlatatOmTbMtW7bYmDFjLCIiwis4vf322xYTE2Mff/yx7dy50z7++GOrWbOmzZgxo9jHXtx2bmb2j3/8w6pUqWLPPPOMbd682davX29//vOfi31Ma9assYCAAHvuuedsy5YtNn36dAsJCbHp06ebmdnq1autSpUqNnv2bNu1a5etW7fOXnnlFTMz27dvnwUGBlpycrKlpaXZhg0b7LXXXvMKLGcqbBv473//a5Js8uTJtnfvXpswYYKlpqbajh077NVXX7UqVarYt99+65m/W7duFhYWZk8++aT9+OOPnuD/8ssv2zfffGM7d+60r7/+2po1a2a///3vPcvlv4YTExNt3bp1tmTJEqtVq5b17NnT7rjjDtu0aZPNnz/fgoODbc6cOZ7lintvyM7OtkmTJllERITt37/f9u/f73nsvrynHD582CIjI+2JJ56w7du32+bNm23GjBm2e/fuYrcLVHwEJ5S5zp0726RJk8zM7NSpU1a7dm1LSUkxs//bu7R06VLP/J06dbInn3zSzMy2b99uLpfL/vOf/3it8/rrr7dRo0aZ2ek3OUm2fv36YuvIycmx8PBwmz9/vpmZffHFFxYYGGj79+/3zHP2HqepU6das2bNvD4As7OzLSQkxL788stC7+fLL7+0gIAAmz17tuXk5NjevXvt6quv9goev/zyiyUnJ9u///1vW716tf3pT3+ygIAA+9vf/uZZz8aNG61r165Wv359u+uuuywjI8Nmzpxpffr0sb1791rPnj2tcePGNnr06CIf80svvWSS7L///W+xz825gtPcuXNNkq1bt67Y9bz99ttWo0YNr70a//znPy0gIMDS09PNzOzRRx+16667zuv5Cg4O9tR4zz332O9+9zuv9S5btswCAgLs+PHjZnY6ZBS1F+1M48ePt7Zt23pud+jQwR566CGvebp06eIVnOLi4goExOeff946depU7H0Vt52bnd6u+/fvX+TyhT2mfv36WWJiote0J5980po3b25mZh9//LFFREQUuvdx7dq1JsnxHpGzt4GjR4/a4MGDrUqVKrZhw4ZCl+ndu7c9/vjjntvdunWzyy+//Jz39cEHH1itWrU8t/Nfw9u3b/dMGzx4sIWGhnoFvV69etngwYPNzPl7Q2RkpNe4r+8pBw8eNEm2ePHicz4+XFwCy+aAIHDali1btGrVKn3yySeSpMDAQN15552aNm2aevTooTp16igxMVGzZs3SNddco7S0NP3rX//SG2+8IUlat26dzExNmzb1Wm92drZq1arluR0cHKzWrVt7zXPgwAE988wz+uabb/Tzzz8rNzdXx44d85x7smXLFsXFxSk6OtqzTPv27b3WsXbtWm3fvl3h4eFe00+cOKEdO3YU+ph79uypCRMmaMiQIbrnnnvkdrv1pz/9ScuXL1eVKlUkSbVr19Zjjz3mWaZdu3Y6dOiQxo8fr7vvvluS1KJFC68Tcw8ePKikpCQtXbpUjzzyiLp06aJPPvlEV111lTp06KCbb765QC1mVmiNJZW/HpfLVex8P/zwg9q0aaNq1ap5pnXp0kV5eXnasmWLoqKi1L9/f3Xq1En79u1TbGysZs2apd69e6tGjRqS/u85nzVrltf95+XlKS0tTZdddpmk08/Z2T766CNNmjRJ27dv19GjR5WTk6OIiAjP+JYtWzR06FCvZdq3b69vvvlGkvTLL7/op59+0qBBg/Tggw965snJyVFkZGSRj/tc27kkrV+/3mudhTn7Mf3www/q06eP17QuXbpo0qRJys3NVWJiouLj49WoUSPdcMMNuuGGG3TbbbcpNDRUbdq00fXXX69WrVqpV69e6tmzp37zm994nueidO7cWQEBATp27JhiYmI0Y8YMtWrVSrm5uXrxxRc1d+5c/ec//1F2drays7O9el3YY5CkRYsWaezYsdq8ebMyMzOVk5OjEydOKCsry7N8aGioGjdu7FkmKipKDRo0UFhYmNe0AwcOSHL+3nA2X99TatasqYEDB6pXr15KTExUjx49dMcddygmJqbI+8LFgeCEMjV16lTl5OTokksu8UwzMwUFBenQoUOqUaOG+vfvr2HDhmny5MmaPXu2WrRooTZt2kiS8vLyVKVKFa1du9YTOvKd+YYaEhJS4EN94MCB+uWXXzRp0iTFx8fL7XarU6dOnhNWzeycQSAvL09t27b1+hDPV6dOnSKXGzFihB577DHt379fNWrU0K5duzRq1Cg1bNiwyGU6duyov/71r0WOP/bYYxo+fLjq1aunxYsX64UXXlC1atV00003afHixYUGp/wPhx9//FGdOnUq7qEWK389P/zwgy6//PIi5yvuOc2f3r59ezVu3Fhz5szR73//e82bN0/Tp0/3zJeXl6fBgwfr0UcfLbCO+vXre/7/7A/sb7/9Vr/97W81ZswY9erVS5GRkZozZ44mTpxYaB1n1nzmfUvSO++8ow4dOnjNd/b2dyYn23lISEiRyxf1mAp7Ps+sNzw8XOvWrdPixYu1cOFCPfPMM0pKStLq1atVvXp1paSkaOXKlVq4cKEmT56s0aNH69///nex2+HcuXPVvHlzVa9e3StITJw4US+//LImTZqkVq1aqVq1aho+fHiBE8DPfgy7d+9W7969NWTIED3//POqWbOmli9frkGDBunUqVOe+YKCgryWc7lchU7L75HT94aznc97yvTp0/Xoo49qwYIFmjt3rv74xz8qJSVFHTt2LPL+UPHxrTqUmZycHL377ruaOHGi1q9f7/n77rvvFB8f7wkjt956q06cOKEFCxZo9uzZnj0uknTFFVcoNzdXBw4cUJMmTbz+ztxTVJhly5bp0UcfVe/evdWiRQu53W79+uuvnvFLL71Ue/bs0c8//+yZdvbX+6+88kpt27ZNdevWLXD/xe2BkE6/ycfGxiokJETvv/++4uLidOWVVxY5f2pqapH/ev3666/1448/6uGHH5Z0+ls++R86p06dUm5ubqHL9ezZU7Vr19b48eMLHT98+HCxjyHf5ZdfrubNm2vixImFfrsofz3NmzfX+vXrlZWV5RlbsWKFAgICvP6F369fP82aNUvz589XQECAbrrpJs/YlVdeqU2bNhV4vps0aaLg4OAia1yxYoXi4+M1evRotWvXTgkJCdq9e7fXPM2aNdOqVau8pp15KYWoqChdcskl2rlzZ4H7LipsON3OW7dura+//rrI+gvTvHlzLV++3GvaypUr1bRpU8+HfmBgoHr06KHx48drw4YN2rVrl2cPmsvlUpcuXTRmzBilpqYqODhY8+bNK/Y+4+Li1Lhx4wJ7bZYtW6Y+ffro7rvvVps2bdSoUSNt27btnI9hzZo1ysnJ0cSJE9WxY0c1bdpU+/btK8nTUCgn7w3BwcEFXhvn856Sv/yoUaO0cuVKtWzZUrNnzz7vxwI/Vy4HCFEpzZs3z4KDg+3w4cMFxv7whz94nQvRr18/a9OmjblcrgInW/bv398aNGjgOVl31apV9uKLL9o///lPMyv8PAYzs8svv9wSExNt8+bN9u2339o111xjISEh9vLLL5vZ6XOemjVrZr169bLvvvvOli9fbh06dDBJ9umnn5rZ/50c3r17d1u6dKnt3LnTFi9ebI8++qj99NNPRT728ePH24YNG2zjxo323HPPWVBQkNcJ3TNmzLBZs2bZ5s2b7ccff7QJEyZYUFCQJScnF1jXsWPHrFmzZl7nH91444324IMP2vr1661evXr2wQcfFFnLp59+akFBQXbzzTdbSkqKpaWl2erVq+3JJ5+0O++808ycfcvv3//+t4WHh1uXLl3sn//8p+3YscO+++47e+GFFzzfnsrKyrKYmBi7/fbb7fvvv7dvvvnGGjVq5Dk5PN/WrVtNkrVu3doGDRrkNfbdd99ZSEiIDR061FJTU23r1q3297//3R5++GHPPPHx8Z4+nvk4AwMD7f3337ft27fbK6+8YjVr1vTaNt577z0LCQmxGTNm2NatW+3555+3iIgIr23xnXfesZCQEJs0aZJt2bLFNmzYYNOmTbOJEycW+rw43c4XLVpkAQEBnpPDN2zY4HXiemGPae3atV4nh8+YMcPr5PD58+fbK6+8YqmpqbZr1y57/fXXLSAgwDZu3Gjffvut/fnPf7bVq1fb7t277YMPPrDg4GD7/PPPC30c59oGhg8fbnFxcbZixQrbvHmzPfDAAxYREWF9+vTxzNOtWzcbNmyY13KpqakmySZNmmQ7duywd9991y655BKT5Pl2ZWGv4WeffbbAtx0HDBjgdX/nem9YsWKFSbKvvvrKfvnlF8vKynK0XGH17Ny5055++mlbuXKl7dq1y7788kurWbOmvf7664U+X7h4EJxQZv7nf/7H8xX6s+WfuJp/eYB//vOfJsnrK+n5Tp48ac8884w1aNDAgoKCLDo62m677TbPCatFBad169ZZu3btzO12W0JCgn344YcFPpzyL0cQHBxsl156qc2fP98k2YIFCzzz7N+/3+69916rXbu2ud1ua9SokT344IOWkZFR5GO/9tprLTIy0qpWrWodOnQo8GE1Y8YMu+yyyyw0NNTCw8Otbdu2XieGn+npp5/2OgHXzGzbtm121VVXWUREhA0ZMqTQSwScafXq1da3b1+rU6eOud1ua9Kkif3ud7/zfBvNSXAyM9uyZYvde++9Fhsb6/l6/F133eV10nhxlyM401VXXWWSPJedONOqVassMTHRwsLCrFq1ata6desC30A7O2SYnT5xulatWhYWFmZ33nmnvfzyywW2jeeee85q165tYWFhdv/999ujjz5qHTt29Jpn1qxZdvnll1twcLDVqFHDunbtap988kmhz0lJtvOPP/7Ys97atWtb3759z/mY8i9HEBQUZPXr17cJEyZ4xpYtW2bdunWzGjVqWEhIiLVu3drmzp1rZmabN2+2Xr16eXretGlTmzx5cqF1mp17Gzh48KD16dPHwsLCrG7duvbHP/7R7r333nMGJzOz5ORki4mJsZCQEOvVq5e9++67pRKczvXeYGY2ZMgQq1WrltflCHx5T0lPT7dbb73VYmJiPNv+M888c87XHio+l1kpnS0KXIRWrFihq6++Wtu3b/c6URUXr8TEREVHR+tvf/tbeZcCwA9xcjhwhnnz5iksLEwJCQnavn27hg0bpi5duhCaLlLHjh3Tm2++qV69eqlKlSp6//339dVXXyklJaW8SwPgpwhOwBmOHDmikSNH6qefflLt2rXVo0ePAt/CwsXD5XLp888/1wsvvKDs7Gw1a9ZMH3/8seeSAQBwNg7VAQAAOMTlCAAAABwiOAEAADhEcAIAAHCI4AQAAOAQwQkAAMAhghMAAIBDBCcAAACHCE4AAAAOEZwAAAAc+v9hK4bhlyDuYQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot CI Coverage distribution\n",
    "plot_histogram_distribution(summary_df, \"average_coverage\", estimator_order, m_filter=1000,\n",
    "                            xlabel=\"Average 95% CI Coverage Across Parameters\", xlim=(0, 1.0))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "af42ae8b",
   "metadata": {},
   "source": [
    "# t-tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7d66452c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "P-values for MAPE:\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>100</th>\n",
       "      <th>250</th>\n",
       "      <th>500</th>\n",
       "      <th>750</th>\n",
       "      <th>1000</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.000005</td>\n",
       "      <td>0.000007</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>naive</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000026</td>\n",
       "      <td>0.000625</td>\n",
       "      <td>0.004075</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.000006</td>\n",
       "      <td>0.000117</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.00001</td>\n",
       "      <td>0.000016</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        100  250       500       750       1000\n",
       "primary  0.0  0.0       0.0  0.000005  0.000007\n",
       "naive    0.0  0.0  0.000026  0.000625  0.004075\n",
       "ppi      0.0  0.0       0.0  0.000006  0.000117\n",
       "ppi++    0.0  0.0       0.0   0.00001  0.000016"
      ]
     },
     "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",
    "    ms = sorted(df['m'].unique())\n",
    "    pval_table = pd.DataFrame(index=methods_of_interest, columns=ms)\n",
    "    \n",
    "    for m in ms:\n",
    "        df_m = df[df['m'] == m]\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, m] = pval\n",
    "    \n",
    "    return pval_table\n",
    "\n",
    "\n",
    "# Compute all p-value tables\n",
    "pval_table_mape = compute_pval_table(summary_df, 'average_mape')\n",
    "pval_table_cover = compute_pval_table(summary_df, 'average_coverage')\n",
    "pval_table_width = compute_pval_table(summary_df, 'average_width')\n",
    "\n",
    "print(\"P-values for MAPE:\")\n",
    "display(pval_table_mape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e7eea3ff",
   "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>100</th>\n",
       "      <th>250</th>\n",
       "      <th>500</th>\n",
       "      <th>750</th>\n",
       "      <th>1000</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>primary</th>\n",
       "      <td>0.000309</td>\n",
       "      <td>0.000097</td>\n",
       "      <td>0.000097</td>\n",
       "      <td>0.000818</td>\n",
       "      <td>0.000128</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",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi</th>\n",
       "      <td>0.001917</td>\n",
       "      <td>0.032448</td>\n",
       "      <td>0.023778</td>\n",
       "      <td>0.173083</td>\n",
       "      <td>0.052033</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi++</th>\n",
       "      <td>0.00063</td>\n",
       "      <td>0.001917</td>\n",
       "      <td>0.011058</td>\n",
       "      <td>0.052246</td>\n",
       "      <td>0.009415</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             100       250       500       750       1000\n",
       "primary  0.000309  0.000097  0.000097  0.000818  0.000128\n",
       "naive         0.0       0.0       0.0       0.0       0.0\n",
       "ppi      0.001917  0.032448  0.023778  0.173083  0.052033\n",
       "ppi++     0.00063  0.001917  0.011058  0.052246  0.009415"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"P-values for Coverage:\")\n",
    "pval_table_cover"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ee59dfd8",
   "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>100</th>\n",
       "      <th>250</th>\n",
       "      <th>500</th>\n",
       "      <th>750</th>\n",
       "      <th>1000</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>primary</th>\n",
       "      <td>0.085652</td>\n",
       "      <td>0.00005</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",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi</th>\n",
       "      <td>0.77751</td>\n",
       "      <td>0.741825</td>\n",
       "      <td>0.977663</td>\n",
       "      <td>0.652481</td>\n",
       "      <td>0.360115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>ppi++</th>\n",
       "      <td>0.15559</td>\n",
       "      <td>0.541852</td>\n",
       "      <td>0.528027</td>\n",
       "      <td>0.255122</td>\n",
       "      <td>0.30167</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             100       250       500       750       1000\n",
       "primary  0.085652   0.00005       0.0       0.0       0.0\n",
       "naive         0.0       0.0       0.0       0.0       0.0\n",
       "ppi       0.77751  0.741825  0.977663  0.652481  0.360115\n",
       "ppi++     0.15559  0.541852  0.528027  0.255122   0.30167"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"P-values for CI Width:\")\n",
    "pval_table_width"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8e97435",
   "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": 5
}
