{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7daf017c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import re\n",
    "import glob\n",
    "import pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import arviz as az\n",
    "\n",
    "ROOT = os.path.expanduser(\"~/hmcstiefel/outputs_ppca\")\n",
    "\n",
    "\n",
    "def ftag_to_float(tag: str) -> float:\n",
    "    \"\"\"\n",
    "    예: \"0p1\" -> 0.1, \"1e-2\" -> 0.01, \"0p01\" -> 0.01\n",
    "    \"\"\"\n",
    "    if tag is None:\n",
    "        return float(\"nan\")\n",
    "    s = str(tag).strip()\n",
    "    if s == \"\" or s.lower() == \"none\":\n",
    "        return float(\"nan\")\n",
    "    s = s.replace(\"p\", \".\")  \n",
    "    s = s.replace(\"m\", \"-\")\n",
    "    try:\n",
    "        return float(s)\n",
    "    except Exception:\n",
    "        return float(\"nan\")\n",
    "\n",
    "\n",
    "_CASE_RE = re.compile(\n",
    "    r\"^(?P<method>[^_]+)\"\n",
    "    r\"_p(?P<p>\\d+)\"\n",
    "    r\"_u(?P<u>\\d+)\"\n",
    "    r\"_N(?P<N>\\d+)\"\n",
    "    r\"_eps(?P<eps>[^_]+)\"\n",
    "    r\"_c(?P<c>[^_]+)\"\n",
    "    r\"_L(?P<L>\\d+)\"\n",
    "    r\"_step(?P<step>[^_]+)\"\n",
    "    r\"_bp(?P<bp>\\d+)\"\n",
    "    r\"_rhob(?P<rhob>[^_]+)\"\n",
    "    r\"$\"\n",
    ")\n",
    "\n",
    "def parse_case(case_name: str) -> dict:\n",
    "    m = _CASE_RE.match(case_name)\n",
    "    if m is None:\n",
    "        return {\"case\": case_name, \"parse_ok\": False, \"method\": case_name.split(\"_\")[0]}\n",
    "    d = m.groupdict()\n",
    "    return {\n",
    "        \"case\": case_name,\n",
    "        \"parse_ok\": True,\n",
    "        \"method\": d[\"method\"],\n",
    "        \"p\": int(d[\"p\"]),\n",
    "        \"u\": int(d[\"u\"]),\n",
    "        \"N\": int(d[\"N\"]),\n",
    "        \"eps\": ftag_to_float(d[\"eps\"]),\n",
    "        \"c\": ftag_to_float(d[\"c\"]),\n",
    "        \"L\": int(d[\"L\"]),\n",
    "        \"step\": ftag_to_float(d[\"step\"]),\n",
    "        \"bp\": int(d[\"bp\"]),\n",
    "        \"rhob\": ftag_to_float(d[\"rhob\"]),\n",
    "    }\n",
    "\n",
    "\n",
    "def _autocov_fft_1d(x: np.ndarray) -> np.ndarray:\n",
    "    \"\"\"\n",
    "    autocov[lag] for lag=0..T-1 via FFT\n",
    "    \"\"\"\n",
    "    x = np.asarray(x, dtype=np.float64)\n",
    "    n = x.size\n",
    "    x = x - x.mean()\n",
    "  \n",
    "    m = 1 << (2*n - 1).bit_length()\n",
    "    fx = np.fft.rfft(x, n=m)\n",
    "    acf = np.fft.irfft(fx * np.conjugate(fx), n=m)[:n]\n",
    "   \n",
    "    return acf / n\n",
    "\n",
    "def ess_1d_geyer(x: np.ndarray, var_eps: float = 1e-12) -> float:\n",
    "    \"\"\"\n",
    "    x: (T,)\n",
    "    returns ESS scalar\n",
    "    \"\"\"\n",
    "    x = np.asarray(x, dtype=np.float64)\n",
    "    n = x.size\n",
    "    if n < 4:\n",
    "        return float(n)\n",
    "\n",
    "    acov = _autocov_fft_1d(x)\n",
    "    var = acov[0]\n",
    "    if not np.isfinite(var) or var <= var_eps:\n",
    "        return float(n)\n",
    "\n",
    "    rho = acov / var  # rho[0]=1\n",
    "   \n",
    "    m = 1\n",
    "    while True:\n",
    "        i1 = 2*m - 1\n",
    "        i2 = 2*m\n",
    "        if i2 >= n:\n",
    "            break\n",
    "        gamma = rho[i1] + rho[i2]\n",
    "        if not np.isfinite(gamma) or gamma <= 0.0:\n",
    "            break\n",
    "        s += gamma\n",
    "        m += 1\n",
    "\n",
    "    tau = 1.0 + 2.0 * s\n",
    "    if not np.isfinite(tau) or tau <= 0:\n",
    "        return 1.0\n",
    "\n",
    "    ess = n / tau\n",
    "    if not np.isfinite(ess):\n",
    "        return 1.0\n",
    "    return float(max(1.0, min(ess, float(n))))\n",
    "\n",
    "def ess_1d_series_ct(x_ct: np.ndarray) -> np.ndarray:\n",
    "    \"\"\"\n",
    "    x_ct: (C,T)\n",
    "    returns: (C,) chainwise ESS\n",
    "    \"\"\"\n",
    "    x_ct = np.asarray(x_ct)\n",
    "    if x_ct.ndim != 2:\n",
    "        raise ValueError(f\"x_ct must be (C,T), got {x_ct.shape}\")\n",
    "    C, _ = x_ct.shape\n",
    "    out = np.empty((C,), dtype=np.float64)\n",
    "    for c in range(C):\n",
    "        out[c] = ess_1d_geyer(x_ct[c])\n",
    "    return out\n",
    "\n",
    "\n",
    "def load_pickle(path: str):\n",
    "    with open(path, \"rb\") as f:\n",
    "        return pickle.load(f)\n",
    "\n",
    "def get_nprop_total(meta) -> float:\n",
    "  \n",
    "    if meta is None:\n",
    "        return float(\"nan\")\n",
    "    # direct\n",
    "    for k in [\"n_proposals_total\", \"nprop_total\", \"n_prop_total\"]:\n",
    "        if k in meta:\n",
    "            try: return float(meta[k])\n",
    "            except: pass\n",
    "    # nested budget\n",
    "    bud = meta.get(\"budget\", {}) if isinstance(meta, dict) else {}\n",
    "    for k in [\"actual_total_steps\", \"n_proposals_total\", \"total_steps\", \"nprop_total\"]:\n",
    "        if k in bud:\n",
    "            try: return float(bud[k])\n",
    "            except: pass\n",
    "    return float(\"nan\")\n",
    "\n",
    "def get_runtime_total_sec(meta) -> float:\n",
    "    if meta is None:\n",
    "        return float(\"nan\")\n",
    "    for k in [\"runtime_total_sec\", \"runtime_sec_total\", \"walltime_sec\"]:\n",
    "        if k in meta:\n",
    "            try: return float(meta[k])\n",
    "            except: pass\n",
    "    # chainwise runtime\n",
    "    if \"runtime_sec\" in meta:\n",
    "        try:\n",
    "            return float(np.sum(np.asarray(meta[\"runtime_sec\"], dtype=float)))\n",
    "        except:\n",
    "            pass\n",
    "    return float(\"nan\")\n",
    "\n",
    "\n",
    "def compute_rep_metrics(samples_pt: str, meta_pkl: str | None, out_base: dict) -> dict | None:\n",
    "    # load meta\n",
    "    meta = None\n",
    "    if meta_pkl is not None and os.path.exists(meta_pkl):\n",
    "        try:\n",
    "            meta = load_pickle(meta_pkl)\n",
    "        except Exception as e:\n",
    "            print(f\"[WARN] meta load failed: {meta_pkl}: {e}\")\n",
    "\n",
    "    # load samples\n",
    "    try:\n",
    "        data = torch.load(samples_pt, map_location=\"cpu\", weights_only=False)\n",
    "    except Exception as e:\n",
    "        print(f\"[ERROR] samples load failed: {samples_pt}: {e}\")\n",
    "        return None\n",
    "\n",
    "    Q = data[\"Q\"] if isinstance(data, dict) and (\"Q\" in data) else data\n",
    "    if isinstance(Q, torch.Tensor):\n",
    "        Q = Q.detach().cpu().numpy()\n",
    "    else:\n",
    "        Q = np.asarray(Q)\n",
    "\n",
    "    if Q.ndim != 4:\n",
    "        print(f\"[WARN] skip {samples_pt}: Q.ndim={Q.ndim}, shape={Q.shape}\")\n",
    "        return None\n",
    "\n",
    "    C, T, p, u = Q.shape\n",
    "\n",
    "    # P = QQ^T : (C,T,p,p)\n",
    "    P = np.einsum(\"ctik,ctjk->ctij\", Q, Q)\n",
    "\n",
    "    # build idata with vars P_{i,j} upper triangular\n",
    "    posterior = {}\n",
    "    var_names = []\n",
    "    for i in range(p):\n",
    "        for j in range(i, p):\n",
    "            vn = f\"P_{i}_{j}\"\n",
    "            posterior[vn] = P[:, :, i, j]   # (C,T)\n",
    "            var_names.append(vn)\n",
    "\n",
    "    idata = az.from_dict(\n",
    "        posterior=posterior,\n",
    "        coords={\"chain\": np.arange(C), \"draw\": np.arange(T)},\n",
    "        dims={vn: [\"chain\", \"draw\"] for vn in var_names},\n",
    "    )\n",
    "\n",
    "    # ---- ESS (chainwise, all vars)\n",
    "    ess_per_var = {}\n",
    "    ess_chainwise_all = []\n",
    "    ds = idata.posterior\n",
    "\n",
    "    for vn in var_names:\n",
    "        x = ds[vn].values  # (C,T)\n",
    "        if x.ndim != 2:\n",
    "            x = np.asarray(x).reshape(C, -1)\n",
    "        ess_c = ess_1d_series_ct(x)  # (C,)\n",
    "        ess_per_var[vn] = ess_c\n",
    "        ess_chainwise_all.append(ess_c)\n",
    "\n",
    "    ess_elements = np.concatenate(ess_chainwise_all, axis=0)  # (n_vars*C,)\n",
    "\n",
    "    # ---- Rhat (arviz)\n",
    "    if C >= 2:\n",
    "        rhat_ds = az.rhat(idata)  # Dataset\n",
    "        rhat_per_var = {vn: float(np.asarray(rhat_ds[vn].values)) for vn in var_names}\n",
    "        rhat_elements = np.array(list(rhat_per_var.values()), dtype=float)\n",
    "    else:\n",
    "        rhat_per_var = {vn: float(\"nan\") for vn in var_names}\n",
    "        rhat_elements = np.array(list(rhat_per_var.values()), dtype=float)\n",
    "\n",
    "    # ---- efficiency\n",
    "    nprop_total = get_nprop_total(meta)\n",
    "    runtime_total_sec = get_runtime_total_sec(meta)\n",
    "\n",
    "    eff_elements = ess_elements / nprop_total if np.isfinite(nprop_total) and nprop_total > 0 else np.full_like(ess_elements, np.nan)\n",
    "    sec_elements = ess_elements / runtime_total_sec if np.isfinite(runtime_total_sec) and runtime_total_sec > 0 else np.full_like(ess_elements, np.nan)\n",
    "\n",
    "    ess_summary = {\n",
    "        \"median\": float(np.nanmedian(ess_elements)),\n",
    "        \"mean\":   float(np.nanmean(ess_elements)),\n",
    "        \"min\":    float(np.nanmin(ess_elements)),\n",
    "        \"max\":    float(np.nanmax(ess_elements)),\n",
    "      \n",
    "    }\n",
    "\n",
    "    rhat_summary = {\n",
    "        \"median\": float(np.nanmedian(rhat_elements)),\n",
    "        \"mean\":   float(np.nanmean(rhat_elements)),\n",
    "        \"min\":    float(np.nanmin(rhat_elements)),\n",
    "        \"max\":    float(np.nanmax(rhat_elements)),\n",
    "    }\n",
    "\n",
    "    outputs = out_base.copy()\n",
    "    outputs.update({\n",
    "        \"samples_pt\": samples_pt,\n",
    "        \"meta_pkl\": meta_pkl,\n",
    "        \"C\": C, \"T\": T, \"p\": p, \"u\": u,\n",
    "        \"n_proposals_total\": nprop_total,\n",
    "        \"runtime_total_sec\": runtime_total_sec,\n",
    "\n",
    "        \"ess_elements\": ess_elements,\n",
    "        \"ess_by_var\": ess_per_var,\n",
    "        \"ess_summary\": ess_summary,\n",
    "\n",
    "        \"rhat_elements\": rhat_elements,\n",
    "        \"rhat_by_var\": rhat_per_var,\n",
    "        \"rhat_summary\": rhat_summary,\n",
    "    })\n",
    "    return outputs\n",
    "\n",
    "\n",
    "def process_case_folder(case_folder: str, case_name: str) -> list[dict]:\n",
    "    pkls_dir = os.path.join(case_folder, \"pkls\")\n",
    "    if not os.path.isdir(pkls_dir):\n",
    "        return []\n",
    "\n",
    "    out_case = parse_case(case_name)\n",
    "    rows = []\n",
    "\n",
    "    sample_files = sorted(glob.glob(os.path.join(pkls_dir, \"rep*.samples.pt\")))\n",
    "    n_reps = len(sample_files)\n",
    "\n",
    "    print(f\"  [INFO] reps found: {n_reps}\")\n",
    "\n",
    "    for i, spt in enumerate(sample_files, start=1):\n",
    "        rep_base = os.path.basename(spt).replace(\".samples.pt\", \"\")\n",
    "        mpkl = os.path.join(pkls_dir, f\"{rep_base}.pkl\")\n",
    "        if not os.path.exists(mpkl):\n",
    "            mpkl = None\n",
    "\n",
    "        print(f\"    [REP {i}/{n_reps}] {rep_base}\")\n",
    "\n",
    "        out_rep = out_case.copy()\n",
    "        out_rep[\"rep\"] = int(rep_base.replace(\"rep\", \"\")) if rep_base.startswith(\"rep\") else rep_base\n",
    "\n",
    "        res = compute_rep_metrics(spt, mpkl, out_rep)\n",
    "        if res is not None:\n",
    "            rows.append(res)\n",
    "\n",
    "    return rows\n",
    "\n",
    "\n",
    "\n",
    "def main(root_path: str = ROOT, p_list=None) -> pd.DataFrame:\n",
    "    all_rows = []\n",
    "\n",
    "    case_names = sorted(os.listdir(root_path))\n",
    "    n_cases = len(case_names)\n",
    "\n",
    "    print(f\"[INFO] Total cases found: {n_cases}\")\n",
    "    print(f\"[INFO] p filter: {p_list if p_list is not None else 'ALL'}\")\n",
    "\n",
    "    case_idx = 0\n",
    "    for case_name in case_names:\n",
    "        case_folder = os.path.join(root_path, case_name)\n",
    "        if not os.path.isdir(case_folder):\n",
    "            continue\n",
    "\n",
    "        parsed = parse_case(case_name)\n",
    "\n",
    "        # p 필터\n",
    "        if p_list is not None:\n",
    "            if (not parsed.get(\"parse_ok\", False)) or (\"p\" not in parsed):\n",
    "                continue\n",
    "            if parsed[\"p\"] not in set(p_list):\n",
    "                continue\n",
    "\n",
    "        case_idx += 1\n",
    "        print(f\"\\n[CASE {case_idx}] {case_name}\")\n",
    "\n",
    "        rows = process_case_folder(case_folder, case_name)\n",
    "        all_rows.extend(rows)\n",
    "\n",
    "        print(f\"[CASE {case_idx}] done ({len(rows)} reps processed)\")\n",
    "\n",
    "    print(\"\\n[INFO] All cases processed.\")\n",
    "    df = pd.DataFrame(all_rows)\n",
    "    return df\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "073862f1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] Total cases found: 48\n",
      "[INFO] p filter: [10]\n",
      "\n",
      "[CASE 1] naive_p10_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 1] done (0 reps processed)\n",
      "\n",
      "[CASE 2] naive_p10_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 2] done (10 reps processed)\n",
      "\n",
      "[CASE 3] naive_p10_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 3] done (10 reps processed)\n",
      "\n",
      "[CASE 4] naive_p10_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 4] done (0 reps processed)\n",
      "\n",
      "[CASE 5] softbarrier_p10_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 5] done (10 reps processed)\n",
      "\n",
      "[CASE 6] softbarrier_p10_u2_N30_eps0p01_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 6] done (10 reps processed)\n",
      "\n",
      "[CASE 7] softbarrier_p10_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 7] done (10 reps processed)\n",
      "\n",
      "[CASE 8] softbarrier_p10_u2_N30_eps0p05_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 8] done (0 reps processed)\n",
      "\n",
      "[CASE 9] softbarrier_p10_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 9] done (10 reps processed)\n",
      "\n",
      "[CASE 10] softbarrier_p10_u2_N30_eps0p1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 10] done (10 reps processed)\n",
      "\n",
      "[INFO] All cases processed.\n"
     ]
    }
   ],
   "source": [
    "df = main(p_list = [10])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "21c439b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_summary(df):\n",
    "    df[\"ess_mean\"] = df[\"ess_summary\"].apply(lambda d: d[\"mean\"])\n",
    "    df[\"rha_max\"] = df[\"rhat_summary\"].apply(lambda d: d[\"max\"])\n",
    "    sub_df = df[[ 'method', 'p',  'eps', 'c', 'ess_mean', 'rha_max']]\n",
    "    subsub_df = sub_df.groupby(['p', 'eps', 'c', 'method']).mean()\n",
    "    return subsub_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "fa25f8d6",
   "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></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>ess_mean</th>\n",
       "      <th>rha_max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>p</th>\n",
       "      <th>eps</th>\n",
       "      <th>c</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"7\" valign=\"top\">10</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>0.01</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1056.041638</td>\n",
       "      <td>1.008309</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1070.828807</td>\n",
       "      <td>1.006903</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.05</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>1224.216721</td>\n",
       "      <td>1.002732</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1242.409170</td>\n",
       "      <td>1.002215</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.10</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>1027.838586</td>\n",
       "      <td>1.017674</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1031.959066</td>\n",
       "      <td>1.015181</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1015.916657</td>\n",
       "      <td>1.017564</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             ess_mean   rha_max\n",
       "p  eps  c    method                            \n",
       "10 0.01 0.01 softbarrier  1056.041638  1.008309\n",
       "        0.10 softbarrier  1070.828807  1.006903\n",
       "   0.05 0.01 naive        1224.216721  1.002732\n",
       "             softbarrier  1242.409170  1.002215\n",
       "   0.10 0.01 naive        1027.838586  1.017674\n",
       "             softbarrier  1031.959066  1.015181\n",
       "        0.10 softbarrier  1015.916657  1.017564"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extract_summary(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "7471313a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] Total cases found: 48\n",
      "[INFO] p filter: [20]\n",
      "\n",
      "[CASE 1] naive_p20_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 1] done (0 reps processed)\n",
      "\n",
      "[CASE 2] naive_p20_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 2] done (10 reps processed)\n",
      "\n",
      "[CASE 3] naive_p20_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 3] done (10 reps processed)\n",
      "\n",
      "[CASE 4] naive_p20_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 4] done (0 reps processed)\n",
      "\n",
      "[CASE 5] softbarrier_p20_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 5] done (10 reps processed)\n",
      "\n",
      "[CASE 6] softbarrier_p20_u2_N30_eps0p01_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 6] done (10 reps processed)\n",
      "\n",
      "[CASE 7] softbarrier_p20_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 7] done (10 reps processed)\n",
      "\n",
      "[CASE 8] softbarrier_p20_u2_N30_eps0p05_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 8] done (10 reps processed)\n",
      "\n",
      "[CASE 9] softbarrier_p20_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 9] done (10 reps processed)\n",
      "\n",
      "[CASE 10] softbarrier_p20_u2_N30_eps0p1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 10] done (10 reps processed)\n",
      "\n",
      "[CASE 11] softbarrier_p20_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 11] done (0 reps processed)\n",
      "\n",
      "[CASE 12] softbarrier_p20_u2_N30_eps1p0em03_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 12] done (0 reps processed)\n",
      "\n",
      "[INFO] All cases processed.\n"
     ]
    }
   ],
   "source": [
    "df2 = main(p_list = [20])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "41a738a2",
   "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></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>ess_mean</th>\n",
       "      <th>rha_max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>p</th>\n",
       "      <th>eps</th>\n",
       "      <th>c</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"8\" valign=\"top\">20</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>0.01</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>977.976036</td>\n",
       "      <td>1.013382</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>973.300315</td>\n",
       "      <td>1.016937</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.05</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>1120.072187</td>\n",
       "      <td>1.009698</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1117.983505</td>\n",
       "      <td>1.011303</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1119.519971</td>\n",
       "      <td>1.010262</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.10</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>961.640352</td>\n",
       "      <td>1.054887</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>948.549456</td>\n",
       "      <td>1.053504</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>961.834670</td>\n",
       "      <td>1.036049</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             ess_mean   rha_max\n",
       "p  eps  c    method                            \n",
       "20 0.01 0.01 softbarrier   977.976036  1.013382\n",
       "        0.10 softbarrier   973.300315  1.016937\n",
       "   0.05 0.01 naive        1120.072187  1.009698\n",
       "             softbarrier  1117.983505  1.011303\n",
       "        0.10 softbarrier  1119.519971  1.010262\n",
       "   0.10 0.01 naive         961.640352  1.054887\n",
       "             softbarrier   948.549456  1.053504\n",
       "        0.10 softbarrier   961.834670  1.036049"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extract_summary(df2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "f0503a2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] Total cases found: 49\n",
      "[INFO] p filter: [30]\n",
      "\n",
      "[CASE 1] naive_p30_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 1] done (0 reps processed)\n",
      "\n",
      "[CASE 2] naive_p30_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 2] done (10 reps processed)\n",
      "\n",
      "[CASE 3] naive_p30_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 3] done (10 reps processed)\n",
      "\n",
      "[CASE 4] naive_p30_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 4] done (0 reps processed)\n",
      "\n",
      "[CASE 5] softbarrier_p30_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 5] done (10 reps processed)\n",
      "\n",
      "[CASE 6] softbarrier_p30_u2_N30_eps0p01_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 6] done (10 reps processed)\n",
      "\n",
      "[CASE 7] softbarrier_p30_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 7] done (10 reps processed)\n",
      "\n",
      "[CASE 8] softbarrier_p30_u2_N30_eps0p05_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 8] done (10 reps processed)\n",
      "\n",
      "[CASE 9] softbarrier_p30_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 9] done (10 reps processed)\n",
      "\n",
      "[CASE 10] softbarrier_p30_u2_N30_eps0p1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 10] done (10 reps processed)\n",
      "\n",
      "[CASE 11] softbarrier_p30_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 11] done (0 reps processed)\n",
      "\n",
      "[CASE 12] softbarrier_p30_u2_N30_eps1p0em03_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 12] done (0 reps processed)\n",
      "\n",
      "[INFO] All cases processed.\n"
     ]
    }
   ],
   "source": [
    "df3 = main(p_list = [30])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "382347ef",
   "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></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>ess_mean</th>\n",
       "      <th>rha_max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>p</th>\n",
       "      <th>eps</th>\n",
       "      <th>c</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"8\" valign=\"top\">30</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>0.01</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>985.342401</td>\n",
       "      <td>1.048216</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>976.089633</td>\n",
       "      <td>1.041813</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.05</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>1090.858695</td>\n",
       "      <td>1.020993</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1045.526903</td>\n",
       "      <td>1.027899</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1075.002609</td>\n",
       "      <td>1.041122</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.10</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>981.465983</td>\n",
       "      <td>1.031522</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>997.791772</td>\n",
       "      <td>1.039116</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>984.667908</td>\n",
       "      <td>1.033322</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             ess_mean   rha_max\n",
       "p  eps  c    method                            \n",
       "30 0.01 0.01 softbarrier   985.342401  1.048216\n",
       "        0.10 softbarrier   976.089633  1.041813\n",
       "   0.05 0.01 naive        1090.858695  1.020993\n",
       "             softbarrier  1045.526903  1.027899\n",
       "        0.10 softbarrier  1075.002609  1.041122\n",
       "   0.10 0.01 naive         981.465983  1.031522\n",
       "             softbarrier   997.791772  1.039116\n",
       "        0.10 softbarrier   984.667908  1.033322"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extract_summary(df3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "3dbb3c61",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] Total cases found: 49\n",
      "[INFO] p filter: [40]\n",
      "\n",
      "[CASE 1] naive_p40_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 1] done (0 reps processed)\n",
      "\n",
      "[CASE 2] naive_p40_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 2] done (10 reps processed)\n",
      "\n",
      "[CASE 3] naive_p40_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 3] done (10 reps processed)\n",
      "\n",
      "[CASE 4] naive_p40_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 4] done (0 reps processed)\n",
      "\n",
      "[CASE 5] softbarrier_p40_u2_N30_eps0p01_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 5] done (10 reps processed)\n",
      "\n",
      "[CASE 6] softbarrier_p40_u2_N30_eps0p01_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 6] done (10 reps processed)\n",
      "\n",
      "[CASE 7] softbarrier_p40_u2_N30_eps0p05_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 7] done (10 reps processed)\n",
      "\n",
      "[CASE 8] softbarrier_p40_u2_N30_eps0p05_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 8] done (10 reps processed)\n",
      "\n",
      "[CASE 9] softbarrier_p40_u2_N30_eps0p1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 9] done (10 reps processed)\n",
      "\n",
      "[CASE 10] softbarrier_p40_u2_N30_eps0p1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 10\n",
      "    [REP 1/10] rep0\n",
      "    [REP 2/10] rep1\n",
      "    [REP 3/10] rep2\n",
      "    [REP 4/10] rep3\n",
      "    [REP 5/10] rep4\n",
      "    [REP 6/10] rep5\n",
      "    [REP 7/10] rep6\n",
      "    [REP 8/10] rep7\n",
      "    [REP 9/10] rep8\n",
      "    [REP 10/10] rep9\n",
      "[CASE 10] done (10 reps processed)\n",
      "\n",
      "[CASE 11] softbarrier_p40_u2_N30_eps1p0em03_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 11] done (0 reps processed)\n",
      "\n",
      "[CASE 12] softbarrier_p40_u2_N30_eps1p0em03_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 12] done (0 reps processed)\n",
      "\n",
      "[INFO] All cases processed.\n"
     ]
    }
   ],
   "source": [
    "df4 = main(p_list = [40])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a88588b2",
   "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></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>ess_mean</th>\n",
       "      <th>rha_max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>p</th>\n",
       "      <th>eps</th>\n",
       "      <th>c</th>\n",
       "      <th>method</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"8\" valign=\"top\">40</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>0.01</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>891.046227</td>\n",
       "      <td>1.068437</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>902.315066</td>\n",
       "      <td>1.070527</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.05</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>993.377281</td>\n",
       "      <td>1.088504</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>999.444882</td>\n",
       "      <td>1.078852</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1016.210511</td>\n",
       "      <td>1.095094</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"3\" valign=\"top\">0.10</th>\n",
       "      <th rowspan=\"2\" valign=\"top\">0.01</th>\n",
       "      <th>naive</th>\n",
       "      <td>1011.159925</td>\n",
       "      <td>1.078155</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>softbarrier</th>\n",
       "      <td>1018.634895</td>\n",
       "      <td>1.063348</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0.10</th>\n",
       "      <th>softbarrier</th>\n",
       "      <td>995.385065</td>\n",
       "      <td>1.064682</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                             ess_mean   rha_max\n",
       "p  eps  c    method                            \n",
       "40 0.01 0.01 softbarrier   891.046227  1.068437\n",
       "        0.10 softbarrier   902.315066  1.070527\n",
       "   0.05 0.01 naive         993.377281  1.088504\n",
       "             softbarrier   999.444882  1.078852\n",
       "        0.10 softbarrier  1016.210511  1.095094\n",
       "   0.10 0.01 naive        1011.159925  1.078155\n",
       "             softbarrier  1018.634895  1.063348\n",
       "        0.10 softbarrier   995.385065  1.064682"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extract_summary(df4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82af59af",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "mtsi",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
