{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "154d726f",
   "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_mvmf\")\n",
    "\n",
    "\n",
    "def ftag_to_float(s: str) -> float:\n",
    "    s = str(s).strip()\n",
    "    if s == \"\" or s.lower() == \"none\":\n",
    "        return float(\"nan\")\n",
    "    t = s.replace(\"p\", \".\").replace(\"em\", \"e-\").replace(\"m\", \"-\")\n",
    "    return float(t)\n",
    "\n",
    "_CASE_RE = re.compile(\n",
    "    r\"^(?P<method>[^_]+)\"\n",
    "    r\"_p(?P<p>\\d+)\"\n",
    "    r\"_k(?P<k>\\d+)\"\n",
    "    r\"_rho(?P<rho>[^_]+)\"\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, \"method\": case_name.split(\"_\")[0], \"parse_ok\": False}\n",
    "    d = m.groupdict()\n",
    "    return {\n",
    "        \"case\": case_name,\n",
    "        \"parse_ok\": True,\n",
    "        \"method\": d[\"method\"],\n",
    "        \"p\": int(d[\"p\"]),\n",
    "        \"k\": int(d[\"k\"]),\n",
    "        \"rho\": ftag_to_float(d[\"rho\"]),\n",
    "        \"c\": ftag_to_float(d[\"c\"]),\n",
    "        \"L\": int(d[\"L\"]),\n",
    "        \"step\": ftag_to_float(d[\"step\"]),\n",
    "        \"bp\": int(d[\"bp\"]) if d.get(\"bp\") else None,\n",
    "        \"rhob\": ftag_to_float(d[\"rhob\"]) if d.get(\"rhob\") else None,\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",
    "    # zero-pad to 2n for circular convolution avoidance\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",
    "    # unbiased? geyer는 보통 biased( /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",
    "    s = 0.0\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",
    "  \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",
    "   \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_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",
    "    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",
    "       \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": 18,
   "id": "efd59136",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] Total cases found: 179\n",
      "[INFO] p filter: ALL\n",
      "\n",
      "[CASE 1] naive_p20_k10_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 1] done (1 reps processed)\n",
      "\n",
      "[CASE 2] naive_p20_k10_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 2] done (1 reps processed)\n",
      "\n",
      "[CASE 3] naive_p20_k10_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 3] done (1 reps processed)\n",
      "\n",
      "[CASE 4] naive_p20_k10_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 4] done (1 reps processed)\n",
      "\n",
      "[CASE 5] naive_p20_k10_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 5] done (1 reps processed)\n",
      "\n",
      "[CASE 6] naive_p20_k15_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 6] done (1 reps processed)\n",
      "\n",
      "[CASE 7] naive_p20_k15_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 7] done (1 reps processed)\n",
      "\n",
      "[CASE 8] naive_p20_k15_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 8] done (1 reps processed)\n",
      "\n",
      "[CASE 9] naive_p20_k15_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 9] done (1 reps processed)\n",
      "\n",
      "[CASE 10] naive_p20_k15_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 10] done (1 reps processed)\n",
      "\n",
      "[CASE 11] naive_p20_k19_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 11] done (1 reps processed)\n",
      "\n",
      "[CASE 12] naive_p20_k19_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 12] done (1 reps processed)\n",
      "\n",
      "[CASE 13] naive_p20_k19_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 13] done (1 reps processed)\n",
      "\n",
      "[CASE 14] naive_p20_k19_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 14] done (1 reps processed)\n",
      "\n",
      "[CASE 15] naive_p20_k19_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 15] done (1 reps processed)\n",
      "\n",
      "[CASE 16] naive_p20_k20_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 16] done (1 reps processed)\n",
      "\n",
      "[CASE 17] naive_p20_k20_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 17] done (1 reps processed)\n",
      "\n",
      "[CASE 18] naive_p20_k20_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 18] done (1 reps processed)\n",
      "\n",
      "[CASE 19] naive_p20_k20_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 19] done (1 reps processed)\n",
      "\n",
      "[CASE 20] naive_p20_k5_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 20] done (1 reps processed)\n",
      "\n",
      "[CASE 21] naive_p20_k5_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 21] done (1 reps processed)\n",
      "\n",
      "[CASE 22] naive_p20_k5_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 22] done (1 reps processed)\n",
      "\n",
      "[CASE 23] naive_p20_k5_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 23] done (1 reps processed)\n",
      "\n",
      "[CASE 24] naive_p20_k5_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 24] done (1 reps processed)\n",
      "\n",
      "[CASE 25] naive_p40_k10_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 25] done (1 reps processed)\n",
      "\n",
      "[CASE 26] naive_p40_k10_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 26] done (1 reps processed)\n",
      "\n",
      "[CASE 27] naive_p40_k10_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 27] done (1 reps processed)\n",
      "\n",
      "[CASE 28] naive_p40_k10_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 28] done (1 reps processed)\n",
      "\n",
      "[CASE 29] naive_p40_k10_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 29] done (1 reps processed)\n",
      "\n",
      "[CASE 30] naive_p40_k10_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 30] done (1 reps processed)\n",
      "\n",
      "[CASE 31] naive_p40_k10_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 31] done (1 reps processed)\n",
      "\n",
      "[CASE 32] naive_p40_k20_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 32] done (1 reps processed)\n",
      "\n",
      "[CASE 33] naive_p40_k20_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 33] done (1 reps processed)\n",
      "\n",
      "[CASE 34] naive_p40_k20_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 34] done (1 reps processed)\n",
      "\n",
      "[CASE 35] naive_p40_k20_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 35] done (1 reps processed)\n",
      "\n",
      "[CASE 36] naive_p40_k20_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 36] done (1 reps processed)\n",
      "\n",
      "[CASE 37] naive_p40_k20_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 37] done (1 reps processed)\n",
      "\n",
      "[CASE 38] naive_p40_k20_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 38] done (1 reps processed)\n",
      "\n",
      "[CASE 39] naive_p40_k30_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 39] done (1 reps processed)\n",
      "\n",
      "[CASE 40] naive_p40_k30_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 40] done (1 reps processed)\n",
      "\n",
      "[CASE 41] naive_p40_k30_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 41] done (1 reps processed)\n",
      "\n",
      "[CASE 42] naive_p40_k30_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 42] done (0 reps processed)\n",
      "\n",
      "[CASE 43] naive_p40_k30_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 43] done (0 reps processed)\n",
      "\n",
      "[CASE 44] naive_p40_k30_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 44] done (1 reps processed)\n",
      "\n",
      "[CASE 45] naive_p40_k30_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 45] done (0 reps processed)\n",
      "\n",
      "[CASE 46] naive_p40_k39_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 46] done (1 reps processed)\n",
      "\n",
      "[CASE 47] naive_p40_k39_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 47] done (1 reps processed)\n",
      "\n",
      "[CASE 48] naive_p40_k39_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 48] done (1 reps processed)\n",
      "\n",
      "[CASE 49] naive_p40_k39_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 49] done (1 reps processed)\n",
      "\n",
      "[CASE 50] naive_p40_k39_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 50] done (1 reps processed)\n",
      "\n",
      "[CASE 51] naive_p40_k39_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 51] done (1 reps processed)\n",
      "\n",
      "[CASE 52] naive_p40_k39_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 52] done (1 reps processed)\n",
      "\n",
      "[CASE 53] naive_p40_k40_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 53] done (1 reps processed)\n",
      "\n",
      "[CASE 54] naive_p40_k40_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 54] done (1 reps processed)\n",
      "\n",
      "[CASE 55] naive_p40_k40_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 55] done (1 reps processed)\n",
      "\n",
      "[CASE 56] naive_p40_k40_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 56] done (1 reps processed)\n",
      "\n",
      "[CASE 57] naive_p40_k40_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 57] done (1 reps processed)\n",
      "\n",
      "[CASE 58] naive_p40_k40_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 58] done (1 reps processed)\n",
      "\n",
      "[CASE 59] naive_p40_k40_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 59] done (1 reps processed)\n",
      "\n",
      "[CASE 60] softbarrier_p20_k10_rho0_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 60] done (1 reps processed)\n",
      "\n",
      "[CASE 61] softbarrier_p20_k10_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 61] done (1 reps processed)\n",
      "\n",
      "[CASE 62] softbarrier_p20_k10_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 62] done (1 reps processed)\n",
      "\n",
      "[CASE 63] softbarrier_p20_k10_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 63] done (1 reps processed)\n",
      "\n",
      "[CASE 64] softbarrier_p20_k10_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 64] done (1 reps processed)\n",
      "\n",
      "[CASE 65] softbarrier_p20_k10_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 65] done (1 reps processed)\n",
      "\n",
      "[CASE 66] softbarrier_p20_k10_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 66] done (1 reps processed)\n",
      "\n",
      "[CASE 67] softbarrier_p20_k10_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 67] done (1 reps processed)\n",
      "\n",
      "[CASE 68] softbarrier_p20_k10_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 68] done (1 reps processed)\n",
      "\n",
      "[CASE 69] softbarrier_p20_k10_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 69] done (1 reps processed)\n",
      "\n",
      "[CASE 70] softbarrier_p20_k15_rho0_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 70] done (1 reps processed)\n",
      "\n",
      "[CASE 71] softbarrier_p20_k15_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 71] done (1 reps processed)\n",
      "\n",
      "[CASE 72] softbarrier_p20_k15_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 72] done (1 reps processed)\n",
      "\n",
      "[CASE 73] softbarrier_p20_k15_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 73] done (1 reps processed)\n",
      "\n",
      "[CASE 74] softbarrier_p20_k15_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 74] done (1 reps processed)\n",
      "\n",
      "[CASE 75] softbarrier_p20_k15_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 75] done (1 reps processed)\n",
      "\n",
      "[CASE 76] softbarrier_p20_k15_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 76] done (1 reps processed)\n",
      "\n",
      "[CASE 77] softbarrier_p20_k15_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 77] done (1 reps processed)\n",
      "\n",
      "[CASE 78] softbarrier_p20_k15_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 78] done (1 reps processed)\n",
      "\n",
      "[CASE 79] softbarrier_p20_k15_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 79] done (1 reps processed)\n",
      "\n",
      "[CASE 80] softbarrier_p20_k19_rho0_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 80] done (1 reps processed)\n",
      "\n",
      "[CASE 81] softbarrier_p20_k19_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 81] done (1 reps processed)\n",
      "\n",
      "[CASE 82] softbarrier_p20_k19_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 82] done (1 reps processed)\n",
      "\n",
      "[CASE 83] softbarrier_p20_k19_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 83] done (1 reps processed)\n",
      "\n",
      "[CASE 84] softbarrier_p20_k19_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 84] done (1 reps processed)\n",
      "\n",
      "[CASE 85] softbarrier_p20_k19_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 85] done (1 reps processed)\n",
      "\n",
      "[CASE 86] softbarrier_p20_k19_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 86] done (1 reps processed)\n",
      "\n",
      "[CASE 87] softbarrier_p20_k19_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 87] done (1 reps processed)\n",
      "\n",
      "[CASE 88] softbarrier_p20_k19_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 88] done (1 reps processed)\n",
      "\n",
      "[CASE 89] softbarrier_p20_k19_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 89] done (1 reps processed)\n",
      "\n",
      "[CASE 90] softbarrier_p20_k20_rho0_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 90] done (1 reps processed)\n",
      "\n",
      "[CASE 91] softbarrier_p20_k20_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 91] done (1 reps processed)\n",
      "\n",
      "[CASE 92] softbarrier_p20_k20_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 92] done (1 reps processed)\n",
      "\n",
      "[CASE 93] softbarrier_p20_k20_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 93] done (1 reps processed)\n",
      "\n",
      "[CASE 94] softbarrier_p20_k20_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 94] done (1 reps processed)\n",
      "\n",
      "[CASE 95] softbarrier_p20_k20_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 95] done (1 reps processed)\n",
      "\n",
      "[CASE 96] softbarrier_p20_k20_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 96] done (1 reps processed)\n",
      "\n",
      "[CASE 97] softbarrier_p20_k20_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 97] done (1 reps processed)\n",
      "\n",
      "[CASE 98] softbarrier_p20_k5_rho0_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 98] done (1 reps processed)\n",
      "\n",
      "[CASE 99] softbarrier_p20_k5_rho0_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 99] done (1 reps processed)\n",
      "\n",
      "[CASE 100] softbarrier_p20_k5_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 100] done (1 reps processed)\n",
      "\n",
      "[CASE 101] softbarrier_p20_k5_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 101] done (1 reps processed)\n",
      "\n",
      "[CASE 102] softbarrier_p20_k5_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 102] done (1 reps processed)\n",
      "\n",
      "[CASE 103] softbarrier_p20_k5_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 103] done (1 reps processed)\n",
      "\n",
      "[CASE 104] softbarrier_p20_k5_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 104] done (1 reps processed)\n",
      "\n",
      "[CASE 105] softbarrier_p20_k5_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 105] done (1 reps processed)\n",
      "\n",
      "[CASE 106] softbarrier_p20_k5_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 106] done (1 reps processed)\n",
      "\n",
      "[CASE 107] softbarrier_p20_k5_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 107] done (1 reps processed)\n",
      "\n",
      "[CASE 108] softbarrier_p40_k10_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 108] done (1 reps processed)\n",
      "\n",
      "[CASE 109] softbarrier_p40_k10_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 109] done (1 reps processed)\n",
      "\n",
      "[CASE 110] softbarrier_p40_k10_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 110] done (1 reps processed)\n",
      "\n",
      "[CASE 111] softbarrier_p40_k10_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 111] done (1 reps processed)\n",
      "\n",
      "[CASE 112] softbarrier_p40_k10_rho1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 112] done (1 reps processed)\n",
      "\n",
      "[CASE 113] softbarrier_p40_k10_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 113] done (1 reps processed)\n",
      "\n",
      "[CASE 114] softbarrier_p40_k10_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 114] done (1 reps processed)\n",
      "\n",
      "[CASE 115] softbarrier_p40_k10_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 115] done (1 reps processed)\n",
      "\n",
      "[CASE 116] softbarrier_p40_k10_rho300_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 116] done (1 reps processed)\n",
      "\n",
      "[CASE 117] softbarrier_p40_k10_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 117] done (1 reps processed)\n",
      "\n",
      "[CASE 118] softbarrier_p40_k10_rho400_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 118] done (1 reps processed)\n",
      "\n",
      "[CASE 119] softbarrier_p40_k10_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 119] done (1 reps processed)\n",
      "\n",
      "[CASE 120] softbarrier_p40_k10_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 120] done (1 reps processed)\n",
      "\n",
      "[CASE 121] softbarrier_p40_k10_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 121] done (1 reps processed)\n",
      "\n",
      "[CASE 122] softbarrier_p40_k20_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 122] done (1 reps processed)\n",
      "\n",
      "[CASE 123] softbarrier_p40_k20_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 123] done (1 reps processed)\n",
      "\n",
      "[CASE 124] softbarrier_p40_k20_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 124] done (1 reps processed)\n",
      "\n",
      "[CASE 125] softbarrier_p40_k20_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 125] done (1 reps processed)\n",
      "\n",
      "[CASE 126] softbarrier_p40_k20_rho1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 126] done (1 reps processed)\n",
      "\n",
      "[CASE 127] softbarrier_p40_k20_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 127] done (1 reps processed)\n",
      "\n",
      "[CASE 128] softbarrier_p40_k20_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 128] done (1 reps processed)\n",
      "\n",
      "[CASE 129] softbarrier_p40_k20_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 129] done (1 reps processed)\n",
      "\n",
      "[CASE 130] softbarrier_p40_k20_rho300_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 130] done (1 reps processed)\n",
      "\n",
      "[CASE 131] softbarrier_p40_k20_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 131] done (1 reps processed)\n",
      "\n",
      "[CASE 132] softbarrier_p40_k20_rho400_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 132] done (1 reps processed)\n",
      "\n",
      "[CASE 133] softbarrier_p40_k20_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 133] done (1 reps processed)\n",
      "\n",
      "[CASE 134] softbarrier_p40_k20_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 134] done (1 reps processed)\n",
      "\n",
      "[CASE 135] softbarrier_p40_k20_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 135] done (1 reps processed)\n",
      "\n",
      "[CASE 136] softbarrier_p40_k30_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 136] done (1 reps processed)\n",
      "\n",
      "[CASE 137] softbarrier_p40_k30_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 137] done (1 reps processed)\n",
      "\n",
      "[CASE 138] softbarrier_p40_k30_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 138] done (1 reps processed)\n",
      "\n",
      "[CASE 139] softbarrier_p40_k30_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 139] done (1 reps processed)\n",
      "\n",
      "[CASE 140] softbarrier_p40_k30_rho1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 140] done (1 reps processed)\n",
      "\n",
      "[CASE 141] softbarrier_p40_k30_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 141] done (1 reps processed)\n",
      "\n",
      "[CASE 142] softbarrier_p40_k30_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 142] done (1 reps processed)\n",
      "\n",
      "[CASE 143] softbarrier_p40_k30_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 143] done (1 reps processed)\n",
      "\n",
      "[CASE 144] softbarrier_p40_k30_rho300_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 144] done (1 reps processed)\n",
      "\n",
      "[CASE 145] softbarrier_p40_k30_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 145] done (1 reps processed)\n",
      "\n",
      "[CASE 146] softbarrier_p40_k30_rho400_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 146] done (1 reps processed)\n",
      "\n",
      "[CASE 147] softbarrier_p40_k30_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 147] done (1 reps processed)\n",
      "\n",
      "[CASE 148] softbarrier_p40_k30_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 148] done (1 reps processed)\n",
      "\n",
      "[CASE 149] softbarrier_p40_k30_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 149] done (1 reps processed)\n",
      "\n",
      "[CASE 150] softbarrier_p40_k39_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 150] done (1 reps processed)\n",
      "\n",
      "[CASE 151] softbarrier_p40_k39_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 151] done (1 reps processed)\n",
      "\n",
      "[CASE 152] softbarrier_p40_k39_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 152] done (1 reps processed)\n",
      "\n",
      "[CASE 153] softbarrier_p40_k39_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 153] done (1 reps processed)\n",
      "\n",
      "[CASE 154] softbarrier_p40_k39_rho1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 154] done (1 reps processed)\n",
      "\n",
      "[CASE 155] softbarrier_p40_k39_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 155] done (1 reps processed)\n",
      "\n",
      "[CASE 156] softbarrier_p40_k39_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 156] done (1 reps processed)\n",
      "\n",
      "[CASE 157] softbarrier_p40_k39_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 157] done (1 reps processed)\n",
      "\n",
      "[CASE 158] softbarrier_p40_k39_rho300_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 158] done (1 reps processed)\n",
      "\n",
      "[CASE 159] softbarrier_p40_k39_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 159] done (1 reps processed)\n",
      "\n",
      "[CASE 160] softbarrier_p40_k39_rho400_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 160] done (1 reps processed)\n",
      "\n",
      "[CASE 161] softbarrier_p40_k39_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 161] done (1 reps processed)\n",
      "\n",
      "[CASE 162] softbarrier_p40_k39_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 162] done (1 reps processed)\n",
      "\n",
      "[CASE 163] softbarrier_p40_k39_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 163] done (1 reps processed)\n",
      "\n",
      "[CASE 164] softbarrier_p40_k40_rho100_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 164] done (1 reps processed)\n",
      "\n",
      "[CASE 165] softbarrier_p40_k40_rho100_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 165] done (0 reps processed)\n",
      "\n",
      "[CASE 166] softbarrier_p40_k40_rho10_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 166] done (1 reps processed)\n",
      "\n",
      "[CASE 167] softbarrier_p40_k40_rho10_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 167] done (0 reps processed)\n",
      "\n",
      "[CASE 168] softbarrier_p40_k40_rho1_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 168] done (1 reps processed)\n",
      "\n",
      "[CASE 169] softbarrier_p40_k40_rho1_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 169] done (0 reps processed)\n",
      "\n",
      "[CASE 170] softbarrier_p40_k40_rho200_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 170] done (1 reps processed)\n",
      "\n",
      "[CASE 171] softbarrier_p40_k40_rho200_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 171] done (0 reps processed)\n",
      "\n",
      "[CASE 172] softbarrier_p40_k40_rho300_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 172] done (1 reps processed)\n",
      "\n",
      "[CASE 173] softbarrier_p40_k40_rho300_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 173] done (0 reps processed)\n",
      "\n",
      "[CASE 174] softbarrier_p40_k40_rho400_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 174] done (1 reps processed)\n",
      "\n",
      "[CASE 175] softbarrier_p40_k40_rho400_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 175] done (0 reps processed)\n",
      "\n",
      "[CASE 176] softbarrier_p40_k40_rho500_c0p01_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 1\n",
      "    [REP 1/1] rep0\n",
      "[CASE 176] done (1 reps processed)\n",
      "\n",
      "[CASE 177] softbarrier_p40_k40_rho500_c0p1_L50_step0p1_bp4_rhob0p2\n",
      "  [INFO] reps found: 0\n",
      "[CASE 177] done (0 reps processed)\n",
      "\n",
      "[INFO] All cases processed.\n"
     ]
    }
   ],
   "source": [
    "df = main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "58ba1583",
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_summary(df, selp = None):\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', 'k', 'rho', 'c', 'ess_mean', 'rha_max']]\n",
    "    if selp is not None:\n",
    "        sub_df = sub_df[sub_df['p'] == selp]\n",
    "    subsub_df = sub_df.groupby(['p', 'k', 'rho', 'c', 'method']).mean()\n",
    "    return subsub_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "8389e0c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "res20 = extract_summary(df, selp = 20)\n",
    "res40 = extract_summary(df, selp = 40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cd8ff3a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "bpcr",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
