{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "da45f6a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\cml\\miniconda3\\envs\\py39-copula\\lib\\site-packages\\tqdm\\auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from SurvivalEVAL import SurvivalEvaluator\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from pycop import simulation\n",
    "from matplotlib import pyplot as plt\n",
    "from lifelines import CoxPHFitter\n",
    "\n",
    "from dgp import DGP_Weibull_linear\n",
    "from utility import convert_to_structured, kendall_tau_to_theta, lifelines_surv_to_matrix, make_time_bins, predict_median_time_from_survival_curves\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "\n",
    "from utility import train_test_split_df\n",
    "\n",
    "from lifelines.utils import concordance_index\n",
    "from sksurv.metrics import concordance_index_ipcw\n",
    "\n",
    "plt.style.use(\"default\")\n",
    "plt.rcParams.update({\n",
    "    \"axes.labelsize\": \"large\",\n",
    "    \"axes.titlesize\": \"large\",\n",
    "    \"font.size\": 14.0,\n",
    "    \"legend.fontsize\": \"large\",\n",
    "    \"text.usetex\": True,\n",
    "    \"text.latex.preamble\": r\"\\usepackage{amsfonts} \\usepackage{amstext} \\usepackage{bm}\"\n",
    "})\n",
    "\n",
    "def fit_predict_cox_survival(df_train, df_test, features):\n",
    "    \"\"\"\n",
    "    Fit lifelines CoxPH and return survival curves on df_test:\n",
    "    time_grid (m,), S_test (n,m)\n",
    "    \"\"\"\n",
    "    cph = CoxPHFitter(penalizer=0.01)\n",
    "    cph.fit(df_train[[\"time\", \"event\"] + features], duration_col=\"time\", event_col=\"event\")\n",
    "    surv_df = cph.predict_survival_function(df_test[features])\n",
    "    time_grid, S = lifelines_surv_to_matrix(surv_df)\n",
    "    risks = cph.predict_log_partial_hazard(df_test[features]).values.reshape(-1)\n",
    "    return cph, time_grid, S, risks\n",
    "\n",
    "def eval_ibs_survivaleval(survival_outputs, time_bins, \n",
    "                         true_test_time, true_test_event,\n",
    "                         test_time, test_event,\n",
    "                         train_time, train_event,\n",
    "                         num_points=10):\n",
    "\n",
    "    survival_df = pd.DataFrame(survival_outputs, columns=time_bins.cpu().numpy())\n",
    "\n",
    "    true_eval = SurvivalEvaluator(survival_df, time_bins, true_test_time, true_test_event)\n",
    "    ibs_true = true_eval.integrated_brier_score(IPCW_weighted=False, num_points=num_points)\n",
    "\n",
    "    eval_obs = SurvivalEvaluator(survival_df, time_bins,\n",
    "                                 test_time, test_event,\n",
    "                                 train_time, train_event)\n",
    "\n",
    "    ibs_uncens = eval_obs.integrated_brier_score(IPCW_weighted=False, num_points=num_points)\n",
    "    ibs_ipcw   = eval_obs.integrated_brier_score(IPCW_weighted=True,  num_points=num_points)\n",
    "\n",
    "    return ibs_true, ibs_uncens, ibs_ipcw\n",
    "\n",
    "def eval_ci_survivaleval(\n",
    "    survival_outputs,      # (n_test, n_grid) survival probabilities\n",
    "    time_bins,             # torch or np array (n_grid,)\n",
    "    true_test_time, true_test_event,\n",
    "    test_time, test_event,\n",
    "    train_time, train_event,\n",
    "    num_points=None,       # not used, keep signature if you want\n",
    "    ties=\"All\",\n",
    "    pair_method=\"Comparable\",\n",
    "    tau=None,\n",
    "):\n",
    "    if hasattr(time_bins, \"detach\"):\n",
    "        grid = time_bins.detach().cpu().numpy().astype(float)\n",
    "    else:\n",
    "        grid = np.asarray(time_bins, dtype=float)\n",
    "\n",
    "    survival_df = pd.DataFrame(np.asarray(survival_outputs, dtype=float), columns=grid)\n",
    "\n",
    "    eval_obs = SurvivalEvaluator(\n",
    "        survival_df, time_bins,\n",
    "        test_time, test_event,\n",
    "        train_time, train_event\n",
    "    )\n",
    "    try:\n",
    "        ci_harrell = float(eval_obs.concordance(ties=ties, pair_method=pair_method)[0])\n",
    "    except ValueError:\n",
    "        ci_harrell = np.nan\n",
    "\n",
    "    true_eval = SurvivalEvaluator(\n",
    "        survival_df, time_bins,\n",
    "        true_test_time, true_test_event\n",
    "    )\n",
    "    try:\n",
    "        ci_true = float(true_eval.concordance(ties=ties, pair_method=\"Comparable\")[0])\n",
    "    except ValueError:\n",
    "        ci_true = np.nan\n",
    "\n",
    "    # Grab predicted event times from the evaluator (SurvivalEVAL computes these internally)\n",
    "    try:\n",
    "        pred_times = np.asarray(eval_obs.predicted_event_times, dtype=float)\n",
    "        risks = -pred_times\n",
    "\n",
    "        y_train = convert_to_structured(train_time, train_event.astype(bool))\n",
    "        y_test  = convert_to_structured(test_time,  test_event.astype(bool))\n",
    "\n",
    "        if tau is None:\n",
    "            # choose a safe tau where G_hat(tau)>0 is likely; use a lower quantile\n",
    "            tau = float(np.quantile(train_time, 0.8))\n",
    "\n",
    "        ci_uno = float(concordance_index_ipcw(y_train, y_test, risks, tau=tau)[0])\n",
    "    except Exception:\n",
    "        ci_uno = np.nan\n",
    "\n",
    "    return float(ci_true), float(ci_harrell), float(ci_uno)\n",
    "\n",
    "def _uv_seed(seed: int, tau: float) -> int:\n",
    "    return int(seed * 1_000_003 + round(float(tau) * 10_000))\n",
    "\n",
    "def run_bias_experiment(\n",
    "    data_cfg,\n",
    "    taus=(0.25, 0.5, 0.75),\n",
    "    copula_name=\"clayton\",\n",
    "    seeds=range(5),\n",
    "    device=\"cpu\",\n",
    "    dtype=torch.float64,\n",
    "    num_points=10,\n",
    "    train_frac=0.7,\n",
    "    split_seed=0,\n",
    "):\n",
    "    alpha_c = data_cfg[\"alpha_e1\"]\n",
    "    gamma_c = data_cfg[\"gamma_e1\"]\n",
    "    alpha_e = data_cfg[\"alpha_e2\"]\n",
    "    gamma_e = data_cfg[\"gamma_e2\"]\n",
    "    n_samples = data_cfg[\"n_samples\"]\n",
    "    n_features = data_cfg[\"n_features\"]\n",
    "\n",
    "    settings = [\n",
    "        {\"label\": \"random\", \"tau\": 0.0, \"censor_use_x\": False, \"use_copula\": False},\n",
    "        {\"label\": \"indep\",  \"tau\": 0.0, \"censor_use_x\": True,  \"use_copula\": False},\n",
    "    ] + [{\"label\": float(t), \"tau\": float(t), \"censor_use_x\": True, \"use_copula\": True} for t in taus]\n",
    "\n",
    "    rows = []\n",
    "\n",
    "    # loop seeds OUTSIDE settings so base DGP is shared\n",
    "    for seed in seeds:\n",
    "        # deterministic base RNG for torch objects\n",
    "        g = torch.Generator(device=device)\n",
    "        g.manual_seed(int(seed))\n",
    "\n",
    "        # X ONCE per seed\n",
    "        X = torch.rand((n_samples, n_features), generator=g, device=device, dtype=dtype)\n",
    "\n",
    "        # coeffs ONCE per seed\n",
    "        beta_event = 2 * torch.rand((n_features,), generator=g, device=device, dtype=dtype) - 1\n",
    "        beta_cens  = 2 * torch.rand((n_features,), generator=g, device=device, dtype=dtype) - 1\n",
    "\n",
    "        # event DGP ONCE per seed\n",
    "        dgp_event_base = DGP_Weibull_linear(\n",
    "            n_features, alpha_e, gamma_e,\n",
    "            use_x=True, device=device, dtype=dtype,\n",
    "            coeff=beta_event\n",
    "        )\n",
    "\n",
    "        # fixed split across everything\n",
    "        split_rng_seed = int(split_seed)\n",
    "\n",
    "        for s in settings:\n",
    "            label = s[\"label\"]\n",
    "            tau = s[\"tau\"]\n",
    "            censor_use_x = s[\"censor_use_x\"]\n",
    "            use_copula = s[\"use_copula\"]\n",
    "\n",
    "            # uniforms\n",
    "            if (not use_copula) or (tau == 0.0):\n",
    "                rng = np.random.default_rng(int(seed))\n",
    "                u = torch.tensor(rng.uniform(0, 1, n_samples), device=device, dtype=dtype)\n",
    "                v = torch.tensor(rng.uniform(0, 1, n_samples), device=device, dtype=dtype)\n",
    "            else:\n",
    "                np.random.seed(_uv_seed(int(seed), float(tau)))\n",
    "                theta = kendall_tau_to_theta(copula_name, float(tau))\n",
    "                u_np, v_np = simulation.simu_archimedean(copula_name, 2, n_samples, theta=theta)\n",
    "                u = torch.from_numpy(u_np).to(device=device, dtype=dtype).reshape(-1)\n",
    "                v = torch.from_numpy(v_np).to(device=device, dtype=dtype).reshape(-1)\n",
    "\n",
    "            # censoring DGP per setting (only use_x changes), coeff fixed\n",
    "            dgp_cens = DGP_Weibull_linear(\n",
    "                n_features, alpha_c, gamma_c,\n",
    "                use_x=censor_use_x, device=device, dtype=dtype,\n",
    "                coeff=beta_cens\n",
    "            )\n",
    "\n",
    "            # sample times                        \n",
    "            t_c = dgp_cens.rvs(X, u)\n",
    "            t_e = dgp_event_base.rvs(X, v)\n",
    "\n",
    "            T = np.minimum(t_e, t_c)\n",
    "            E = (t_e < t_c).astype(int)\n",
    "\n",
    "            df = pd.DataFrame(X.detach().cpu().numpy(), columns=[f\"X{i}\" for i in range(n_features)])\n",
    "            df[\"time\"] = np.where(T <= 0, 1.0, T)\n",
    "            df[\"event\"] = E\n",
    "            df[\"true_time\"] = np.where(t_e <= 0, 1.0, t_e)\n",
    "            df[\"true_censor\"] = np.where(t_c <= 0, 1.0, t_c)\n",
    "\n",
    "            df = df.replace([np.inf, -np.inf], np.nan).dropna(subset=[\"time\", \"true_time\"]).reset_index(drop=True)\n",
    "\n",
    "            # split (fixed)\n",
    "            df_train, df_test = train_test_split_df(df, train_frac=train_frac, seed=split_rng_seed)\n",
    "            features = [c for c in df.columns if c.startswith(\"X\")]\n",
    "\n",
    "            train_time  = df_train[\"time\"].values\n",
    "            train_event = df_train[\"event\"].values\n",
    "            test_time   = df_test[\"time\"].values\n",
    "            test_event  = df_test[\"event\"].values\n",
    "\n",
    "            true_test_time  = df_test[\"true_time\"].values\n",
    "            true_test_event = np.ones_like(true_test_time, dtype=int)\n",
    "\n",
    "            # time grid varies by setting\n",
    "            time_grid = make_time_bins(df[\"true_time\"].values, event=None)\n",
    "            time_bins = torch.tensor(time_grid, device=device, dtype=dtype)\n",
    "\n",
    "            # fit CoxPH and predict survival\n",
    "            cph, cox_time_grid, S, risks = fit_predict_cox_survival(df_train, df_test, features)\n",
    "\n",
    "            # interpolate to grid\n",
    "            S_interp = np.row_stack([\n",
    "                np.interp(time_grid, cox_time_grid, S[i], left=1.0, right=S[i, -1])\n",
    "                for i in range(S.shape[0])\n",
    "            ])\n",
    "\n",
    "            # IBS\n",
    "            ibs_true, ibs_uncens, ibs_ipcw = eval_ibs_survivaleval(\n",
    "                survival_outputs=S_interp,\n",
    "                time_bins=time_bins,\n",
    "                true_test_time=true_test_time,\n",
    "                true_test_event=true_test_event,\n",
    "                test_time=test_time,\n",
    "                test_event=test_event,\n",
    "                train_time=train_time,\n",
    "                train_event=train_event,\n",
    "                num_points=num_points\n",
    "            )\n",
    "\n",
    "            # CI (true / Harrell / Uno)\n",
    "            # tau for Uno: keep default (max(test_time)) or set explicitly if you want\n",
    "            ci_true, ci_harrell, ci_uno = eval_ci_survivaleval(\n",
    "                survival_outputs=S_interp,\n",
    "                time_bins=time_bins,\n",
    "                true_test_time=true_test_time,\n",
    "                true_test_event=true_test_event,\n",
    "                test_time=test_time,\n",
    "                test_event=test_event,\n",
    "                train_time=train_time,\n",
    "                train_event=train_event,\n",
    "                tau=None,\n",
    "            )\n",
    "            \n",
    "            censor_rate_all = float(1.0 - df[\"event\"].mean())\n",
    "            n_events_all = int(df[\"event\"].sum())\n",
    "\n",
    "            rows.append({\n",
    "                \"setting\": label,\n",
    "                \"tau\": float(tau),\n",
    "                \"seed\": int(seed),\n",
    "                \"censor_rate\": censor_rate_all,\n",
    "                \"n_events\": n_events_all,\n",
    "\n",
    "                # IBS\n",
    "                \"ibs_true\": float(ibs_true),\n",
    "                \"ibs_uncens\": float(ibs_uncens),\n",
    "                \"ibs_ipcw\": float(ibs_ipcw),\n",
    "                \"bias_uncens\": float(ibs_uncens - ibs_true),\n",
    "                \"bias_ipcw\": float(ibs_ipcw - ibs_true),\n",
    "\n",
    "                # CI\n",
    "                \"ci_true\": float(ci_true),\n",
    "                \"ci_harrell\": float(ci_harrell),\n",
    "                \"ci_uno\": float(ci_uno),\n",
    "                \"bias_ci_harrell\": float(ci_harrell - ci_true),\n",
    "                \"bias_ci_uno\": float(ci_uno - ci_true),\n",
    "\n",
    "                \"censor_use_x\": bool(censor_use_x),\n",
    "                \"use_copula\": bool(use_copula),\n",
    "            })\n",
    "\n",
    "    res = pd.DataFrame(rows)\n",
    "\n",
    "    summary = (\n",
    "        res.groupby([\"setting\"], as_index=False)\n",
    "           .agg(\n",
    "               tau=(\"tau\", \"mean\"),\n",
    "               censor_rate=(\"censor_rate\", \"mean\"),\n",
    "                censor_rate_std=(\"censor_rate\", \"std\"),\n",
    "                n_events=(\"n_events\", \"mean\"),\n",
    "\n",
    "               # IBS bias summary\n",
    "               bias_uncens=(\"bias_uncens\", \"mean\"),\n",
    "               bias_ipcw=(\"bias_ipcw\", \"mean\"),\n",
    "               bias_uncens_std=(\"bias_uncens\", \"std\"),\n",
    "               bias_ipcw_std=(\"bias_ipcw\", \"std\"),\n",
    "               ibs_true=(\"ibs_true\", \"mean\"),\n",
    "               ibs_uncens=(\"ibs_uncens\", \"mean\"),\n",
    "               ibs_ipcw=(\"ibs_ipcw\", \"mean\"),\n",
    "\n",
    "               # CI bias summary\n",
    "               bias_ci_harrell=(\"bias_ci_harrell\", \"mean\"),\n",
    "               bias_ci_uno=(\"bias_ci_uno\", \"mean\"),\n",
    "               bias_ci_harrell_std=(\"bias_ci_harrell\", \"std\"),\n",
    "               bias_ci_uno_std=(\"bias_ci_uno\", \"std\"),\n",
    "               ci_true=(\"ci_true\", \"mean\"),\n",
    "               ci_harrell=(\"ci_harrell\", \"mean\"),\n",
    "               ci_uno=(\"ci_uno\", \"mean\"),\n",
    "           )\n",
    "    )\n",
    "\n",
    "    def _sort_key(x):\n",
    "        if x == \"random\": return (-2.0)\n",
    "        if x == \"indep\":  return (-1.0)\n",
    "        return float(x)\n",
    "\n",
    "    summary[\"__k\"] = summary[\"setting\"].apply(_sort_key)\n",
    "    summary = summary.sort_values(\"__k\").drop(columns=\"__k\").reset_index(drop=True)\n",
    "\n",
    "    return res, summary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2f93860b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Run the bias bias experiment\n",
    "data_cfg = dict(\n",
    "    alpha_e1=12, gamma_e1=3,   # censoring params\n",
    "    alpha_e2=17, gamma_e2=4,   # event params\n",
    "    n_samples=10000, n_features=10 # 10000\n",
    ")\n",
    "\n",
    "res, summary = run_bias_experiment(\n",
    "    data_cfg,\n",
    "    taus=(0.25, 0.5, 0.75),\n",
    "    seeds=range(100),\n",
    "    copula_name=\"clayton\",\n",
    "    num_points=10,\n",
    "    train_frac=0.7,\n",
    "    device=\"cpu\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ec8ee785",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the results\n",
    "def pretty_label(s):\n",
    "    if s == \"random\":\n",
    "        return r\"\\shortstack{Random\\\\censoring}\"\n",
    "    if s == \"indep\":\n",
    "        return r\"\\shortstack{Independent\\\\censoring}\"\n",
    "    # dependent tau\n",
    "    t = float(s)\n",
    "    return rf\"\\shortstack{{Dependent\\\\($\\tau={t:.2f}$)}}\"\n",
    "\n",
    "\n",
    "xlabels = [pretty_label(s) for s in summary[\"setting\"]]\n",
    "x = np.arange(len(xlabels))\n",
    "\n",
    "y1 = summary[\"bias_uncens\"].values\n",
    "y2 = summary[\"bias_ipcw\"].values\n",
    "e1 = summary[\"bias_uncens_std\"].values\n",
    "e2 = summary[\"bias_ipcw_std\"].values\n",
    "\n",
    "dx = 0.05  # horizontal offset\n",
    "\n",
    "plt.figure(figsize=(8, 4))\n",
    "plt.errorbar(\n",
    "    x - dx, y1, yerr=e1,\n",
    "    marker=\"o\", capsize=3, linestyle=\"--\",\n",
    "    label=\"Naive IBS (no IPCW)\"\n",
    ")\n",
    "\n",
    "plt.errorbar(\n",
    "    x + dx, y2, yerr=e2,\n",
    "    marker=\"s\", capsize=3, linestyle=\"-\",\n",
    "    label=\"IBS with IPCW\"\n",
    ")\n",
    "\n",
    "plt.axhline(0.0, linewidth=1, color=\"black\")\n",
    "plt.xticks(x, xlabels)\n",
    "plt.xlabel(\"Censoring mechanism\")\n",
    "plt.ylabel(\"Metric error\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"plots/ibs_error_curve.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c8b2f5c9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# CI biases\n",
    "y1 = summary[\"bias_ci_harrell\"].values\n",
    "y2 = summary[\"bias_ci_uno\"].values\n",
    "e1 = summary[\"bias_ci_harrell_std\"].values\n",
    "e2 = summary[\"bias_ci_uno_std\"].values\n",
    "\n",
    "dx = 0.05  # horizontal offset\n",
    "\n",
    "plt.figure(figsize=(8, 4))\n",
    "plt.errorbar(\n",
    "    x - dx, y1, yerr=e1,\n",
    "    marker=\"o\", capsize=3, linestyle=\"--\",\n",
    "    label=\"Harrell's C-index (naive)\"\n",
    ")\n",
    "plt.errorbar(\n",
    "    x + dx, y2, yerr=e2,\n",
    "    marker=\"s\", capsize=3, linestyle=\"-\",\n",
    "    label=\"Uno's C-index (IPCW)\"\n",
    ")\n",
    "\n",
    "plt.axhline(0.0, linewidth=1, color=\"black\")\n",
    "plt.xticks(x, xlabels)\n",
    "plt.xlabel(\"Censoring mechanism\")\n",
    "plt.ylabel(\"Metric error\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"plots/ci_error_curve.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "f54226f4",
   "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>setting</th>\n",
       "      <th>tau</th>\n",
       "      <th>censor_rate</th>\n",
       "      <th>censor_rate_std</th>\n",
       "      <th>n_events</th>\n",
       "      <th>bias_uncens</th>\n",
       "      <th>bias_ipcw</th>\n",
       "      <th>bias_uncens_std</th>\n",
       "      <th>bias_ipcw_std</th>\n",
       "      <th>ibs_true</th>\n",
       "      <th>ibs_uncens</th>\n",
       "      <th>ibs_ipcw</th>\n",
       "      <th>bias_ci_harrell</th>\n",
       "      <th>bias_ci_uno</th>\n",
       "      <th>bias_ci_harrell_std</th>\n",
       "      <th>bias_ci_uno_std</th>\n",
       "      <th>ci_true</th>\n",
       "      <th>ci_harrell</th>\n",
       "      <th>ci_uno</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>random</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.735887</td>\n",
       "      <td>0.158351</td>\n",
       "      <td>2641.13</td>\n",
       "      <td>-0.054805</td>\n",
       "      <td>0.004575</td>\n",
       "      <td>0.050497</td>\n",
       "      <td>0.046025</td>\n",
       "      <td>0.090018</td>\n",
       "      <td>0.035213</td>\n",
       "      <td>0.094593</td>\n",
       "      <td>0.002698</td>\n",
       "      <td>0.002911</td>\n",
       "      <td>0.011724</td>\n",
       "      <td>0.014011</td>\n",
       "      <td>0.634354</td>\n",
       "      <td>0.637052</td>\n",
       "      <td>0.637265</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>indep</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.684266</td>\n",
       "      <td>0.216657</td>\n",
       "      <td>3157.34</td>\n",
       "      <td>-0.049409</td>\n",
       "      <td>0.007975</td>\n",
       "      <td>0.045401</td>\n",
       "      <td>0.040946</td>\n",
       "      <td>0.083701</td>\n",
       "      <td>0.034292</td>\n",
       "      <td>0.091675</td>\n",
       "      <td>0.001978</td>\n",
       "      <td>0.000598</td>\n",
       "      <td>0.015185</td>\n",
       "      <td>0.020030</td>\n",
       "      <td>0.634063</td>\n",
       "      <td>0.636041</td>\n",
       "      <td>0.634661</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.703080</td>\n",
       "      <td>0.239587</td>\n",
       "      <td>2969.20</td>\n",
       "      <td>-0.097341</td>\n",
       "      <td>-0.036608</td>\n",
       "      <td>0.106699</td>\n",
       "      <td>0.104787</td>\n",
       "      <td>0.132177</td>\n",
       "      <td>0.034837</td>\n",
       "      <td>0.095570</td>\n",
       "      <td>0.015482</td>\n",
       "      <td>0.020314</td>\n",
       "      <td>0.020530</td>\n",
       "      <td>0.019985</td>\n",
       "      <td>0.628132</td>\n",
       "      <td>0.643614</td>\n",
       "      <td>0.648445</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.724233</td>\n",
       "      <td>0.263493</td>\n",
       "      <td>2757.67</td>\n",
       "      <td>-0.166560</td>\n",
       "      <td>-0.116697</td>\n",
       "      <td>0.157555</td>\n",
       "      <td>0.158934</td>\n",
       "      <td>0.199458</td>\n",
       "      <td>0.032898</td>\n",
       "      <td>0.082761</td>\n",
       "      <td>0.050269</td>\n",
       "      <td>0.065315</td>\n",
       "      <td>0.029435</td>\n",
       "      <td>0.034371</td>\n",
       "      <td>0.617933</td>\n",
       "      <td>0.668202</td>\n",
       "      <td>0.683248</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.75</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.746450</td>\n",
       "      <td>0.286058</td>\n",
       "      <td>2535.50</td>\n",
       "      <td>-0.219831</td>\n",
       "      <td>-0.186880</td>\n",
       "      <td>0.172561</td>\n",
       "      <td>0.176483</td>\n",
       "      <td>0.245344</td>\n",
       "      <td>0.025513</td>\n",
       "      <td>0.058464</td>\n",
       "      <td>0.104605</td>\n",
       "      <td>0.137080</td>\n",
       "      <td>0.048259</td>\n",
       "      <td>0.062436</td>\n",
       "      <td>0.609206</td>\n",
       "      <td>0.713811</td>\n",
       "      <td>0.746286</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  setting   tau  censor_rate  censor_rate_std  n_events  bias_uncens  \\\n",
       "0  random  0.00     0.735887         0.158351   2641.13    -0.054805   \n",
       "1   indep  0.00     0.684266         0.216657   3157.34    -0.049409   \n",
       "2    0.25  0.25     0.703080         0.239587   2969.20    -0.097341   \n",
       "3     0.5  0.50     0.724233         0.263493   2757.67    -0.166560   \n",
       "4    0.75  0.75     0.746450         0.286058   2535.50    -0.219831   \n",
       "\n",
       "   bias_ipcw  bias_uncens_std  bias_ipcw_std  ibs_true  ibs_uncens  ibs_ipcw  \\\n",
       "0   0.004575         0.050497       0.046025  0.090018    0.035213  0.094593   \n",
       "1   0.007975         0.045401       0.040946  0.083701    0.034292  0.091675   \n",
       "2  -0.036608         0.106699       0.104787  0.132177    0.034837  0.095570   \n",
       "3  -0.116697         0.157555       0.158934  0.199458    0.032898  0.082761   \n",
       "4  -0.186880         0.172561       0.176483  0.245344    0.025513  0.058464   \n",
       "\n",
       "   bias_ci_harrell  bias_ci_uno  bias_ci_harrell_std  bias_ci_uno_std  \\\n",
       "0         0.002698     0.002911             0.011724         0.014011   \n",
       "1         0.001978     0.000598             0.015185         0.020030   \n",
       "2         0.015482     0.020314             0.020530         0.019985   \n",
       "3         0.050269     0.065315             0.029435         0.034371   \n",
       "4         0.104605     0.137080             0.048259         0.062436   \n",
       "\n",
       "    ci_true  ci_harrell    ci_uno  \n",
       "0  0.634354    0.637052  0.637265  \n",
       "1  0.634063    0.636041  0.634661  \n",
       "2  0.628132    0.643614  0.648445  \n",
       "3  0.617933    0.668202  0.683248  \n",
       "4  0.609206    0.713811  0.746286  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "summary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f4bfe0d0",
   "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>setting</th>\n",
       "      <th>tau</th>\n",
       "      <th>seed</th>\n",
       "      <th>censor_rate</th>\n",
       "      <th>n_events</th>\n",
       "      <th>ibs_true</th>\n",
       "      <th>ibs_uncens</th>\n",
       "      <th>ibs_ipcw</th>\n",
       "      <th>bias_uncens</th>\n",
       "      <th>bias_ipcw</th>\n",
       "      <th>ci_true</th>\n",
       "      <th>ci_harrell</th>\n",
       "      <th>ci_uno</th>\n",
       "      <th>bias_ci_harrell</th>\n",
       "      <th>bias_ci_uno</th>\n",
       "      <th>censor_use_x</th>\n",
       "      <th>use_copula</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>random</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0</td>\n",
       "      <td>0.6815</td>\n",
       "      <td>3185</td>\n",
       "      <td>0.074658</td>\n",
       "      <td>0.040113</td>\n",
       "      <td>0.093131</td>\n",
       "      <td>-0.034545</td>\n",
       "      <td>0.018473</td>\n",
       "      <td>0.628584</td>\n",
       "      <td>0.644028</td>\n",
       "      <td>0.642889</td>\n",
       "      <td>0.015444</td>\n",
       "      <td>0.014305</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>indep</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0</td>\n",
       "      <td>0.9288</td>\n",
       "      <td>712</td>\n",
       "      <td>0.077721</td>\n",
       "      <td>0.016024</td>\n",
       "      <td>0.083097</td>\n",
       "      <td>-0.061697</td>\n",
       "      <td>0.005376</td>\n",
       "      <td>0.624871</td>\n",
       "      <td>0.657922</td>\n",
       "      <td>0.654744</td>\n",
       "      <td>0.033052</td>\n",
       "      <td>0.029873</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0</td>\n",
       "      <td>0.9596</td>\n",
       "      <td>404</td>\n",
       "      <td>0.376532</td>\n",
       "      <td>0.017949</td>\n",
       "      <td>0.086047</td>\n",
       "      <td>-0.358583</td>\n",
       "      <td>-0.290485</td>\n",
       "      <td>0.615689</td>\n",
       "      <td>0.614420</td>\n",
       "      <td>0.622094</td>\n",
       "      <td>-0.001269</td>\n",
       "      <td>0.006405</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0</td>\n",
       "      <td>0.9786</td>\n",
       "      <td>214</td>\n",
       "      <td>0.501660</td>\n",
       "      <td>0.012491</td>\n",
       "      <td>0.048245</td>\n",
       "      <td>-0.489169</td>\n",
       "      <td>-0.453415</td>\n",
       "      <td>0.550014</td>\n",
       "      <td>0.526966</td>\n",
       "      <td>0.588846</td>\n",
       "      <td>-0.023049</td>\n",
       "      <td>0.038831</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.75</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0</td>\n",
       "      <td>0.9943</td>\n",
       "      <td>57</td>\n",
       "      <td>0.547578</td>\n",
       "      <td>0.004439</td>\n",
       "      <td>0.006336</td>\n",
       "      <td>-0.543139</td>\n",
       "      <td>-0.541242</td>\n",
       "      <td>0.571593</td>\n",
       "      <td>0.702089</td>\n",
       "      <td>0.749151</td>\n",
       "      <td>0.130495</td>\n",
       "      <td>0.177558</td>\n",
       "      <td>True</td>\n",
       "      <td>True</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",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>495</th>\n",
       "      <td>random</td>\n",
       "      <td>0.00</td>\n",
       "      <td>99</td>\n",
       "      <td>0.9370</td>\n",
       "      <td>630</td>\n",
       "      <td>0.138575</td>\n",
       "      <td>0.015251</td>\n",
       "      <td>0.064414</td>\n",
       "      <td>-0.123324</td>\n",
       "      <td>-0.074161</td>\n",
       "      <td>0.645671</td>\n",
       "      <td>0.619298</td>\n",
       "      <td>0.626034</td>\n",
       "      <td>-0.026373</td>\n",
       "      <td>-0.019637</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>496</th>\n",
       "      <td>indep</td>\n",
       "      <td>0.00</td>\n",
       "      <td>99</td>\n",
       "      <td>0.8918</td>\n",
       "      <td>1082</td>\n",
       "      <td>0.070634</td>\n",
       "      <td>0.019275</td>\n",
       "      <td>0.113760</td>\n",
       "      <td>-0.051360</td>\n",
       "      <td>0.043125</td>\n",
       "      <td>0.645925</td>\n",
       "      <td>0.638559</td>\n",
       "      <td>0.643826</td>\n",
       "      <td>-0.007366</td>\n",
       "      <td>-0.002099</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>497</th>\n",
       "      <td>0.25</td>\n",
       "      <td>0.25</td>\n",
       "      <td>99</td>\n",
       "      <td>0.9286</td>\n",
       "      <td>714</td>\n",
       "      <td>0.202559</td>\n",
       "      <td>0.023031</td>\n",
       "      <td>0.113102</td>\n",
       "      <td>-0.179528</td>\n",
       "      <td>-0.089456</td>\n",
       "      <td>0.628850</td>\n",
       "      <td>0.630840</td>\n",
       "      <td>0.654470</td>\n",
       "      <td>0.001990</td>\n",
       "      <td>0.025620</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>498</th>\n",
       "      <td>0.5</td>\n",
       "      <td>0.50</td>\n",
       "      <td>99</td>\n",
       "      <td>0.9619</td>\n",
       "      <td>381</td>\n",
       "      <td>0.359772</td>\n",
       "      <td>0.015436</td>\n",
       "      <td>0.075651</td>\n",
       "      <td>-0.344336</td>\n",
       "      <td>-0.284121</td>\n",
       "      <td>0.633742</td>\n",
       "      <td>0.682597</td>\n",
       "      <td>0.708004</td>\n",
       "      <td>0.048856</td>\n",
       "      <td>0.074262</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>499</th>\n",
       "      <td>0.75</td>\n",
       "      <td>0.75</td>\n",
       "      <td>99</td>\n",
       "      <td>0.9865</td>\n",
       "      <td>135</td>\n",
       "      <td>0.450877</td>\n",
       "      <td>0.008255</td>\n",
       "      <td>0.040195</td>\n",
       "      <td>-0.442623</td>\n",
       "      <td>-0.410682</td>\n",
       "      <td>0.624364</td>\n",
       "      <td>0.688918</td>\n",
       "      <td>0.768621</td>\n",
       "      <td>0.064554</td>\n",
       "      <td>0.144257</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>500 rows × 17 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    setting   tau  seed  censor_rate  n_events  ibs_true  ibs_uncens  \\\n",
       "0    random  0.00     0       0.6815      3185  0.074658    0.040113   \n",
       "1     indep  0.00     0       0.9288       712  0.077721    0.016024   \n",
       "2      0.25  0.25     0       0.9596       404  0.376532    0.017949   \n",
       "3       0.5  0.50     0       0.9786       214  0.501660    0.012491   \n",
       "4      0.75  0.75     0       0.9943        57  0.547578    0.004439   \n",
       "..      ...   ...   ...          ...       ...       ...         ...   \n",
       "495  random  0.00    99       0.9370       630  0.138575    0.015251   \n",
       "496   indep  0.00    99       0.8918      1082  0.070634    0.019275   \n",
       "497    0.25  0.25    99       0.9286       714  0.202559    0.023031   \n",
       "498     0.5  0.50    99       0.9619       381  0.359772    0.015436   \n",
       "499    0.75  0.75    99       0.9865       135  0.450877    0.008255   \n",
       "\n",
       "     ibs_ipcw  bias_uncens  bias_ipcw   ci_true  ci_harrell    ci_uno  \\\n",
       "0    0.093131    -0.034545   0.018473  0.628584    0.644028  0.642889   \n",
       "1    0.083097    -0.061697   0.005376  0.624871    0.657922  0.654744   \n",
       "2    0.086047    -0.358583  -0.290485  0.615689    0.614420  0.622094   \n",
       "3    0.048245    -0.489169  -0.453415  0.550014    0.526966  0.588846   \n",
       "4    0.006336    -0.543139  -0.541242  0.571593    0.702089  0.749151   \n",
       "..        ...          ...        ...       ...         ...       ...   \n",
       "495  0.064414    -0.123324  -0.074161  0.645671    0.619298  0.626034   \n",
       "496  0.113760    -0.051360   0.043125  0.645925    0.638559  0.643826   \n",
       "497  0.113102    -0.179528  -0.089456  0.628850    0.630840  0.654470   \n",
       "498  0.075651    -0.344336  -0.284121  0.633742    0.682597  0.708004   \n",
       "499  0.040195    -0.442623  -0.410682  0.624364    0.688918  0.768621   \n",
       "\n",
       "     bias_ci_harrell  bias_ci_uno  censor_use_x  use_copula  \n",
       "0           0.015444     0.014305         False       False  \n",
       "1           0.033052     0.029873          True       False  \n",
       "2          -0.001269     0.006405          True        True  \n",
       "3          -0.023049     0.038831          True        True  \n",
       "4           0.130495     0.177558          True        True  \n",
       "..               ...          ...           ...         ...  \n",
       "495        -0.026373    -0.019637         False       False  \n",
       "496        -0.007366    -0.002099          True       False  \n",
       "497         0.001990     0.025620          True        True  \n",
       "498         0.048856     0.074262          True        True  \n",
       "499         0.064554     0.144257          True        True  \n",
       "\n",
       "[500 rows x 17 columns]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "bd2a61a4",
   "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>events_cens</th>\n",
       "      <th>CI_oracle</th>\n",
       "      <th>IBS_oracle</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>setting</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0.25</th>\n",
       "      <td>2969 (70.3\\%)</td>\n",
       "      <td>0.628 \\pm 0.021</td>\n",
       "      <td>0.132 \\pm 0.096</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.5</th>\n",
       "      <td>2758 (72.4\\%)</td>\n",
       "      <td>0.618 \\pm 0.025</td>\n",
       "      <td>0.199 \\pm 0.144</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.75</th>\n",
       "      <td>2536 (74.6\\%)</td>\n",
       "      <td>0.609 \\pm 0.03</td>\n",
       "      <td>0.245 \\pm 0.157</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>indep</th>\n",
       "      <td>3157 (68.4\\%)</td>\n",
       "      <td>0.634 \\pm 0.018</td>\n",
       "      <td>0.084 \\pm 0.037</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>random</th>\n",
       "      <td>2641 (73.6\\%)</td>\n",
       "      <td>0.634 \\pm 0.018</td>\n",
       "      <td>0.09 \\pm 0.044</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           events_cens        CI_oracle       IBS_oracle\n",
       "setting                                                 \n",
       "0.25     2969 (70.3\\%)  0.628 \\pm 0.021  0.132 \\pm 0.096\n",
       "0.5      2758 (72.4\\%)  0.618 \\pm 0.025  0.199 \\pm 0.144\n",
       "0.75     2536 (74.6\\%)   0.609 \\pm 0.03  0.245 \\pm 0.157\n",
       "indep    3157 (68.4\\%)  0.634 \\pm 0.018  0.084 \\pm 0.037\n",
       "random   2641 (73.6\\%)  0.634 \\pm 0.018   0.09 \\pm 0.044"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "summary = (\n",
    "    res\n",
    "    .groupby(\"setting\")\n",
    "    .agg(\n",
    "        n_events_mean=(\"n_events\", \"mean\"),\n",
    "        censor_rate_mean=(\"censor_rate\", \"mean\"),\n",
    "        ci_oracle_mean=(\"ci_true\", \"mean\"),\n",
    "        ci_oracle_std=(\"ci_true\", \"std\"),\n",
    "        ibs_oracle_mean=(\"ibs_true\", \"mean\"),\n",
    "        ibs_oracle_std=(\"ibs_true\", \"std\"),\n",
    "    )\n",
    ")\n",
    "\n",
    "summary[\"events_cens\"] = (\n",
    "    summary[\"n_events_mean\"].round(0).astype(int).astype(str)\n",
    "    + \" (\"\n",
    "    + (100 * summary[\"censor_rate_mean\"]).round(1).astype(str)\n",
    "    + \"\\\\%)\"\n",
    ")\n",
    "\n",
    "summary[\"CI_oracle\"] = (\n",
    "    summary[\"ci_oracle_mean\"].round(3).astype(str)\n",
    "    + \" \\\\pm \"\n",
    "    + summary[\"ci_oracle_std\"].round(3).astype(str)\n",
    ")\n",
    "\n",
    "summary[\"IBS_oracle\"] = (\n",
    "    summary[\"ibs_oracle_mean\"].round(3).astype(str)\n",
    "    + \" \\\\pm \"\n",
    "    + summary[\"ibs_oracle_std\"].round(3).astype(str)\n",
    ")\n",
    "\n",
    "summary[[\"events_cens\", \"CI_oracle\", \"IBS_oracle\"]]\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py39-copula",
   "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.9.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
