{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0fa4d628",
   "metadata": {},
   "source": [
    "# Results for ArXiv dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2c47e7d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, glob, sys, time\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "parent_dir = os.path.abspath(os.path.join(os.getcwd(), \"..\"))\n",
    "sys.path.extend([parent_dir])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8cab1cff",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded 50 runs\n"
     ]
    }
   ],
   "source": [
    "OUTDIR = os.path.join(parent_dir,\"arxiv_outputs\")\n",
    "PATTERN = \"arxiv_outputs_*.npz\"\n",
    "\n",
    "\n",
    "# ---------- load all runs ----------\n",
    "files = sorted(glob.glob(os.path.join(OUTDIR, PATTERN)))\n",
    "runs = []\n",
    "for f1 in files:\n",
    "    d = np.load(f1, allow_pickle=True)\n",
    "    runs.append({\n",
    "    \"W_test\":       d[\"W_test\"],\n",
    "    # --- SpeedCP ---\n",
    "    \"covers_speedcp\": d[\"speedcp_covers\"].astype(int),\n",
    "    \"cutoffs_speedcp\":d[\"speedcp_cutoffs\"],\n",
    "    \"time_speedcp\":   float(d[\"speedcp_time\"]),\n",
    "     # --- Split-CP ---\n",
    "    \"covers_scp\":      d[\"scp_covers\"].astype(int),\n",
    "    \"cutoffs_scp\":     float(d[\"scp_cutoffs\"]),   # scalar stored as array\n",
    "    \"time_scp\":        float(d[\"scp_time\"]),\n",
    "    # --- PCP ---\n",
    "    \"covers_pcp\":      d[\"pcp_covers\"].astype(int),\n",
    "    \"cutoffs_pcp\":     d[\"pcp_cutoffs\"],\n",
    "    \"time_pcp\":        float(d[\"pcp_time\"]),\n",
    "    # --- RLCP ---\n",
    "    \"covers_rlcp\":     d[\"rlcp_covers\"].astype(int),\n",
    "    \"cutoffs_rlcp\":    d[\"rlcp_cutoffs\"],\n",
    "    \"time_rlcp\":       float(d[\"rlcp_time\"]),\n",
    "})\n",
    "print(f\"Loaded {len(runs)} runs\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "645f414b",
   "metadata": {},
   "outputs": [],
   "source": [
    "METHODS = {\n",
    "    \"SpeedCP\":   {\"cover_key\": \"covers_speedcp\", \"cut_key\": \"cutoffs_speedcp\", \"time_key\": \"time_speedcp\"},\n",
    "    \"SplitCP\":    {\"cover_key\": \"covers_scp\",      \"cut_key\": \"cutoffs_scp\",      \"time_key\": \"time_scp\"},\n",
    "    \"PCP\":        {\"cover_key\": \"covers_pcp\",      \"cut_key\": \"cutoffs_pcp\",      \"time_key\": \"time_pcp\"},\n",
    "    \"RLCP\":       {\"cover_key\": \"covers_rlcp\",     \"cut_key\": \"cutoffs_rlcp\",     \"time_key\": \"time_rlcp\"},\n",
    "    }\n",
    "\n",
    "K = 5\n",
    "# Initialize containers: method -> list (len K) of lists (values per run)\n",
    "cover_by_cluster = {m: [list() for _ in range(K)] for m in METHODS}\n",
    "cut_by_cluster   = {m: [list() for _ in range(K)] for m in METHODS}\n",
    "time_by_cluster  = {m: [list() for _ in range(K)] for m in METHODS}\n",
    "sizes_by_cluster = [list() for _ in range(K)]\n",
    "\n",
    "for r in runs:\n",
    "    W_test = r[\"W_test\"]\n",
    "    lab = np.argmax(W_test, axis=1)\n",
    "    r[\"topics\"] = lab.astype(int)\n",
    "\n",
    "    for c in range(K):\n",
    "        idx = (lab == c)\n",
    "        sizes_by_cluster[c].append(int(idx.sum()))\n",
    "        if not idx.any():\n",
    "            continue\n",
    "\n",
    "        for method, keys in METHODS.items():\n",
    "            # coverage (per-point 0/1)\n",
    "            cov = r.get(keys[\"cover_key\"])\n",
    "            if cov is not None:\n",
    "                cov = np.asarray(cov, dtype=float)\n",
    "                cover_by_cluster[method][c].append(float(np.nanmean(cov[idx])))\n",
    "\n",
    "            # cutoffs (scalar per run OR per-point)\n",
    "            cuts = r.get(keys[\"cut_key\"])\n",
    "            if cuts is not None:\n",
    "                cuts = np.asarray(cuts, dtype=float)\n",
    "                if cuts.ndim == 0:\n",
    "                    cut_val = float(cuts)               # scalar cutoff\n",
    "                else:\n",
    "                    cut_val = float(np.nanmean(cuts[idx]))  # mean within cluster\n",
    "                cut_by_cluster[method][c].append(cut_val)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "68fb5a70",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "     Method  Partition  Coverage_mean  Coverage_sd  Cutoff_mean  Cutoff_sd\n",
      "0   SpeedCP          1       0.880974     0.027283    15.990890   1.380194\n",
      "1   SpeedCP          2       0.890009     0.056645    17.239292   3.936632\n",
      "2   SpeedCP          3       0.730556     0.345100    23.153967  12.210195\n",
      "3   SpeedCP          4       0.920104     0.027158    15.104937   1.384055\n",
      "4   SpeedCP          5       0.822426     0.114106    20.888885   9.894556\n",
      "5   SplitCP          1       0.877114     0.024612    15.661434   1.187692\n",
      "6   SplitCP          2       0.876002     0.046155    15.661434   1.187692\n",
      "7   SplitCP          3       0.659375     0.350378    15.628392   1.194416\n",
      "8   SplitCP          4       0.926991     0.024938    15.661434   1.187692\n",
      "9   SplitCP          5       0.762664     0.088887    15.661434   1.187692\n",
      "10      PCP          1       0.877114     0.024612    15.661654   1.187765\n",
      "11      PCP          2       0.876002     0.046155    15.661654   1.187765\n",
      "12      PCP          3       0.659375     0.350378    15.628611   1.194494\n",
      "13      PCP          4       0.926991     0.024938    15.661654   1.187765\n",
      "14      PCP          5       0.762664     0.088887    15.661654   1.187765\n",
      "15     RLCP          1       0.935329     0.022196    47.182950  15.077638\n",
      "16     RLCP          2       0.958005     0.035426    69.740088  26.519742\n",
      "17     RLCP          3       0.956597     0.168421    88.668833  41.649265\n",
      "18     RLCP          4       0.923368     0.023690    31.169976   8.073382\n",
      "19     RLCP          5       0.962352     0.043988    89.374569  37.645591\n"
     ]
    }
   ],
   "source": [
    "def summarize_by_cluster(cover_by_cluster, cut_by_cluster, time_by_cluster, methods, K):\n",
    "    rows = []\n",
    "    for method in methods:\n",
    "        for c in range(K):\n",
    "            cover_vals = np.array(cover_by_cluster[method][c], dtype=float)\n",
    "            cut_vals   = np.array(cut_by_cluster[method][c], dtype=float)\n",
    "            time_vals  = np.array(time_by_cluster[method][c], dtype=float)\n",
    "\n",
    "            row = {\n",
    "                \"Method\": method,\n",
    "                \"Partition\": c+1,\n",
    "                \"Coverage_mean\": np.nanmean(cover_vals) if cover_vals.size > 0 else np.nan,\n",
    "                \"Coverage_sd\":   np.nanstd(cover_vals, ddof=1) if cover_vals.size > 1 else np.nan,\n",
    "                \"Cutoff_mean\":   np.nanmean(cut_vals) if cut_vals.size > 0 else np.nan,\n",
    "                \"Cutoff_sd\":     np.nanstd(cut_vals, ddof=1) if cut_vals.size > 1 else np.nan\n",
    "            }\n",
    "            rows.append(row)\n",
    "\n",
    "    return pd.DataFrame(rows)\n",
    "\n",
    "summary_df = summarize_by_cluster(cover_by_cluster, cut_by_cluster, time_by_cluster, METHODS.keys(), K)\n",
    "print(summary_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "0de0f4e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cutoff (speedcp): 15.835225978020523, 3.053466603497939\n",
      "Time (speedcp): 8.68297546863556, 3.103457254022195\n",
      "Cutoff (scp): 15.661434044410257, 1.1757546022327614\n",
      "Time (scp): 0.00018132686614990234, 2.9264876295987646e-05\n",
      "Cutoff (pcp): 15.661653720857846, 1.175826990826891\n",
      "Time (pcp): 17.501347827911378, 0.5405922720358292\n",
      "Cutoff (rlcp): 42.49377133501117, 45.308794075377975\n",
      "Time (rlcp): 1.1844604015350342, 0.011999054294217536\n"
     ]
    }
   ],
   "source": [
    "for method in [\"speedcp\", \"scp\", \"pcp\", \"rlcp\"]:\n",
    "    all_cuts = np.array([r[f\"cutoffs_{method}\"] for r in runs])\n",
    "    all_time = np.array([r[f\"time_{method}\"] for r in runs])\n",
    "    print(f\"Cutoff ({method}): {all_cuts.mean()}, {all_cuts.std()}\")\n",
    "    print(f\"Time ({method}): {all_time.mean()}, {all_time.std()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "1ac07e03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vHl69NFHNX/+fI0fP97qNuYf/UajUTfddJOSkpLKxYSEhFiu4r3yyivq06dPmfXmgZxMJlOVOXbu3FmfffaZioqKqrzCFxAQoK+//loeHh5q2bKlZRRuVGzw4MF66aWX5OXlpdDQUMvzy3PuOE2aNFGnTp0kSStXrtTgwYMVHx+vp59+uspteV0AoPq40g0AcCldu3ZVXl6e5e89e/aUWb9nzx5FRUVJknr16qXvv/9eLVq0UKdOncr8CwwMVMuWLRUWFqYffvih3HrztEVdu3bVwYMHdfnyZav7fPDBB5Wbm6vExMQKc7568CgPDw916tRJHTp0oMiwgbkAbNeuXZkijue87syfP19LlizR2bNnq4zldQGA6qPoBgA4xYULF3Tbbbdpw4YN+uabb3Ty5Em98847ev755zVy5EhL3DvvvKO///3vOnbsmObPn6+UlBRNmTJFkhQbG6vg4GCNHDlS//nPf3Ty5Ent3LlT06ZN05kzZyRJCxYs0OLFi5WQkKBjx47p22+/1dq1ay33sD744IPy8PDQI488osOHD+vjjz/WkiVLyuTap08fPfnkk5oxY4aefPJJffHFF/rxxx+1fft2jR071jIoG+yH57zuDBo0SN26ddOiRYssy9LS0nTgwIEy/y5evMjrAgA1QPdyAHBj5/OLXXY//v7+6tOnj5YvX64TJ06oqKhI4eHhmjhxombPnm2Ji4+P15tvvqnJkyerVatWSkpKUteuXSVJfn5+2rVrl/785z9r9OjRysnJUVhYmG6//XY1bdpUkvToo4/Kz89PL7zwgp588kk1adJEN9xwg6ZPn27J48MPP9SkSZPUs2dPde3aVc8995zGjBlTJt/nnntON910k1588UW9/PLLMhqN6tixo377299q3LhxNXzmHC8/91K93Ud9fc7T8zPr3X7i4uI0YcIE/fnPf5YkLVmypNzJp7Vr12r8+PH19nUBAGcxmGy5mQ0AUK9kZGRo5owZKqzDqXm8vby0ZOlSBQcH261Ng8Gg999/X6NGjbJbmw1FRkaGZsycqaL/Tp3maF7e3lq6ZIldX//6pvR9N1OFRXXznEuSt5e3lixt2M87ALg6im4AcFMZGRnKycmps/0FBATY/Yc/RXft1OUx4IjXvz5yh/cdAMC+6F4OAG4qODiYH+MNHMdA3eM5BwBci6IbAOCy6IwFAADq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",
      "text/plain": [
       "<Figure size 1000x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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6Mknn9QDDzygadOmaezYsY2+pu6m32q16oorrpDZbK5Xx2Qy2UfxXn75ZfXv39/heN1CTjab7Zwx9uzZU+vWrVNtbe05R/iioqK0ceNGGQwGderUyb4KNxo2aNAgvfDCCwoJCVFcXJz9+nLN3addu3bq0aOHJOkf//iHBg0apBkzZujpp58+52v5vQCAcxjpBgB4rdTUVB09etT+/ddff+1w/Ouvv1ZKSookqW/fvtqxY4c6duyoHj16OHy1b99enTp1Unx8vH766ad6x+u2LUpNTdXmzZt1/PjxRs85evRoHTlyRPn5+Q3GfPbiUQaDQT169FBSUhJJhhPqEsCuXbs6JHFc89Yzbdo0zZ07V+Xl5eesy+8FAJxD0g0A8LgDBw5o8ODBWrZsmb7//nvt2rVLb731lubMmaPhw4fb67311ltavHixSktLNW3aNBUVFWn8+PGSpMzMTBmNRg0fPlxffPGFdu3apc8++0xZWVnau3evJGn69OmaPXu28vLyVFpaqn//+99asmSJ/RnW0aNHy2Aw6P7779fWrVu1evVqzZ071yHW/v376/HHH9eECRP0+OOP66uvvtKePXv0ySefaNSoUfZF2eA6XPPWc91116l3796aNWuWvWzfvn3atGmTw9fBgwf5vQCAk5heDgABYv+xU157nsjISPXv31/z58/Xjz/+qNraWiUkJOjBBx/U5MmT7fVmzJih5cuXa9y4cercubPMZrNSU1MlSREREfr888/117/+VSNGjJDFYlF8fLyuv/56RUdHS5IeeOABRURE6LnnntPjjz+udu3a6ZJLLlF2drY9jvfff1+PPPKI0tLSlJqaqmeffVYjR450iPfZZ5/VFVdcof/5n//Riy++KKvVqu7du+vOO+/UmDFjmnnl3O/YkUM+ew5fveYVx6p87jw5OTm699579de//lWSNHfu3HofPi1ZskRjx4712d8LALSmIJszD7ABAHxWZWWlJk6YoJpW3JonNCREc+fNk9FodFmbQUFBWrFihW6//XaXtRkoKisrNWHiRNX+79Zp7hYSGqp5c+e69Pfva878u5uomtrWueaSFBoSqrnzAvu6A4A3IukGgABQWVkpi8XSaueLiopy+Y0/SXfLtGYfcMfv3xf5w787AEDLMb0cAAKA0WjkZjzA0QdaH9ccACCRdAMAfAQTswAAgC9i9XIA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AAAAgM9pVtItSW3bttUTTzyhL774QqWlpVq/fr0mT56siIiI825r9uzZGjVqlJKSkhQUFKRu3bo1WX///v2677771KlTJ4WHh+vSSy/Vyy+/3Gj9119/XVdccYXatm0ro9Gou+++W3v27DnvOAEAAAAAOB/NSrqfeuopvfPOOw0e27dvn5566qnzam/y5Mn69NNP1b17d8XGxjZZt6qqSldddZWWL1+u+++/XwsXLtRFF12khx56SDNmzKhX//nnn9fo0aPVtm1bzZ8/X9nZ2froo480cOBAlZeXn1ecAAAAAACcj2Yl3dOnT9cf//hHPfnkk/WO7d27t8Hktyk//vijDhw4oI8++khxcXFN1n322We1c+dOLVu2TLNmzdKDDz6oVatW6T/+4z80c+ZM7dq1y173wIEDmjRpkvr27avCwkI98sgj+tvf/qZ//etf+uWXXxqMHwAAAAAAV2n29PLMzEzNnDlT9957r06fPt2iIJKSkpyuazablZiYqBEjRjiU5+TkqLa2Vm+88Ya9rKCgQEeOHNFjjz2m4OBge3l6erquueYavfnmm6qpqWlR7AAAAAAANKbZSff48eO1fPlyLV++XLfddpuOHDniyrga9Ouvv6qsrEwDBgyod2zAgAEKCgpSUVGRvazu7wMHDqxXf+DAgbJYLCopKXFfwAAAAACAgBZ87iqNGzVqlDp27Kg77rhD11xzjVavXu2quBq0b98+SVKXLl3qHQsLC5PRaNTevXudql9XtnfvXl166aX1jp88eVInT560f19dXd2y4AEAgNtUVlbKYrG0qI26+4a6P1siKipKRqOxxe0AgL8I5PfpFiXdknTttdfqiy++0M0336wBAwa49TnpY8eOSTqTYDckPDzcXudc9cPDwx3q/N7s2bPP+9l0AADQ+iorKzVxwkTV1LrmkbH8/PwWtxEaEqq58+aSeAOAeJ9ucdItSb1799ZXX32lW265RQ899JArmmxQ3XZkZ49An+348ePq3Llzg/V/v3f48ePHHer83qRJk5STk2P/vrq6WgkJCc0PHgAAuIXFYlFNbY1G9hosU0SMp8NRxbEqvbP9U1ksFpJuABDv081KuseMGSOTyeRQ1qVLF3355Ze6++67tXXrVpcE93vx8fGS5DCFvM6JEyd04MABXX311Q3WT05Odqjf1NRz6czoeGMj6gAAwPuY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gJ566qkmz7d7925deeWV2r9/v8aMGaMrrrhCR48e1ddff62PP/5YQ4YMafS1//73v3XixAkNHDiw3rG6sqKiIt11113NuBLwF77UpwFn+EOftlqt+vXXX9WxY8fzfi38j6/26crKSlmtVu3fv1+LFi3S1q1bmVoOSb7Zp3/++Wf97W9/05NPPqmuXbu26OcPGJ4eaodvaGg6zJQpU2ySbAsWLHCou2zZMpsk24MPPljv9ZGRkbaysjJ7+cmTJ239+vWztWnTxrZ79257+ZgxY2y/75633HKLTZJtzZo19eI7ffp0k/G//fbbNkm2/Pz8eseOHj1qk2QbNWpUk23Av/h6n/49ppfD3/p0neeff94myfa3v/2tWa+H7/KXPm2xWGyS7F9hYWG2+++/32axWJx6PfyHv/Tp2267zda7d29bTU2NzWazMb3cCUwvR7OtWLFCHTp00Lhx4xzKR48erR49emjFihX1XpOZmakuXbrYvw8NDdVf/vIXnT59Wu+//36j5zp48KD+9a9/6aabbmrwEziDoemufOzYMUlqcCpu3eISdXUQuHypTwPO8PU+vW7dOk2YMEGXXHKJJk+efN6vh//xxT7dtm1bffTRR/rwww/14osv6g9/+INOnDih48ePO/V6+Ddf69NvvPGGVq9erRdffFEhISHnrI8zuKtDs/3000/q2bNnvX9wQUFB6t27tyorK1VdXe1w7OKLL67XTmpqqiTpxx9/bPRcO3fulM1m02WXXdasWCMiIiRJJ0+erHes7j+9ujoIXL7UpwFn+HKf/u677zR06FBdeOGF+uCDD9S2bVuXtAvf5ot9uk2bNrrhhht088036+GHH9Ynn3yiPXv2aPDgwaqtrW1R2/B9vtSnDx06pKysLN1777266qqrmtVGoCLphlvYGtmJrqHFHOrqNnTsXO05Kz4+XpK0d+/eesf27dsnSQ6fGAK/5219Gmgpb+7TGzdu1JAhQxQdHa1PP/1UCQkJLmsb/sub+/TZ2rRpo8zMTP3www/6/PPP3XIO+Adv69MzZszQkSNHNG7cOO3evdv+deLECdlsNu3evdt+Xw1HLKSGZktKSlJpaalqa2vrfTq3detWGY1GRUdH1yv/vW3bttnba0xycrKCgoK0adOmZsV6ySWXKCwsTOvXr693rK6sX79+zWob/sOX+jTgDF/s08XFxRoyZIjatWuntWvXKjExsUXtwb/4Yp9uSN0su4MHD7q8bfgWX+rTu3fv1tGjRx12AjpbYmKievXqpZKSkma1788Y6Uaz3XHHHTp48KBeeuklh/Lly5dr586dGjFiRL3XmM1mh9HmmpoazZ8/X23atNF//Md/NHquDh066JZbbtGaNWsa3M7gXJ/ctWvXTsOHD9dnn32m7777zl5+6tQpLVy4UDExMbrtttuabAP+z5f6NOAMX+vTxcXFuuGGGxQREaHCwkJ17979nK9BYPGlPn3o0CHV1NTUKz969KgWLVokg8GgjIyMJtuA//OlPj1p0iStWLGi3lfv3r0VEhKiFStW6H/+53/O9SMHJEa60WyPP/643n77bT322GMqLi5Wv3797FscdOnSpcEtC3r27Kn+/fvrkUceUVRUlF577TV98803mjp16jm3HHj++ec1cOBA3XrrrfYtDo4fP64NGzaoW7duevbZZ5t8/ezZs/XJJ5/opptu0l/+8hcZjUa9+uqr2rhxo/75z3/W+xQRgcfX+vT333+vlStXSpK+/PJLSdKrr76qdevWSZLuuecetvIIcL7Up/fs2aMhQ4bo0KFDeuyxx/TVV1/pq6++cqhzxx13qF27ds27GPALvtSnP/vsMz388MMaOXKkevTooaioKO3atUuvvvqq9u7dq2nTpvEeDZ/q0/3792+wfMGCBdq5c6duv/328/rZA0prLZMO39bQFgc2m81WWVlpGz9+vK1Lly62kJAQW+fOnW3333+/bd++fQ2+fsmSJba8vDxbjx49bKGhobYePXrU2yLBZmt4iwObzWbbu3ev7eGHH7YlJCTYQkJCbB07drQNGTLE9vHHHzv1c2zfvt02YsQIW0xMjC08PNyWnp5ue+utt5y/EPAb/tCnlyxZ4rANze+/2D4ssPh6n647f1Nfu3btOu/rAt/l6316586dtvvuu8+WkpJii46OtgUHB9s6depkGzp0qG3VqlXnf0Hg83y9TzeGLcPOLchmYw4j3K+wsFCDBg3SkiVLNHbsWE+HA7QYfRr+hj4Nf0Ofhr+hT/sunukGAAAAAMBNSLoBAAAAAHATkm4AAAAAANyEZ7oBAAAAAHATRroBAAAAAHATkm4AAAAAANyEpBsAAAAAADch6QYAAAAAwE1IugEAAAAAcBOSbgAAAAAA3ISkGwAAAAAANyHpBgAAAADATUi6AQAAAABwE5JuAAAAAADchKQbAAAAAAA3IekGAAAAAMBNSLoBAAAAAHATkm4AAAAAANyEpBsAAAAAADch6QYAAAAAwE1IugEAAAAAcBOSbgAAAAAA3ISkGwAAAAAANyHpBgAAAADATUi6AQAAAABwE5JuAAAAAADchKQbAAAAAAA3IekGAAAAAMBNSLoBAAAAAHATkm4AAAAAANyEpBsAAAAAADch6QYAAAAAwE1IugEAAAAAcJP/DxPRTfqt/jUQAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "method_names = list(METHODS.keys())\n",
    "original_palette = sns.color_palette(\"Set2\", n_colors=len(method_names))\n",
    "\n",
    "reddest_index = max(range(len(original_palette)), key=lambda i: original_palette[i][0])\n",
    "\n",
    "swapped_palette = original_palette.copy()\n",
    "swapped_palette[0], swapped_palette[reddest_index] = swapped_palette[reddest_index], swapped_palette[0]\n",
    "palette = dict(zip(method_names, swapped_palette))\n",
    "\n",
    "# Create a dataframe for plotting coverage and cutoffs\n",
    "coverage_data = []\n",
    "for method in METHODS.keys():\n",
    "    for c in range(K):\n",
    "        cover_vals = cover_by_cluster[method][c]\n",
    "        cutoff_vals = cut_by_cluster[method][c]\n",
    "        for val in cover_vals:\n",
    "            coverage_data.append({\n",
    "                \"method\": method,\n",
    "                \"shift_type\": f\"Topic {c}\",\n",
    "                \"type\": \"Coverage\",\n",
    "                \"value\": val\n",
    "            })\n",
    "        for val in cutoff_vals:\n",
    "            coverage_data.append({\n",
    "                \"method\": method,\n",
    "                \"shift_type\": f\"Topic {c}\",\n",
    "                \"type\": \"Size\",\n",
    "                \"value\": val\n",
    "            })\n",
    "# Create a single plot\n",
    "fig, ax = plt.subplots(figsize=(10, 3))\n",
    "\n",
    "coverage_df = pd.DataFrame(coverage_data)\n",
    "coverage_df[\"shift_type\"] = coverage_df[\"shift_type\"].astype(str)\n",
    "\n",
    "# Create boxplot\n",
    "sns.boxplot(data=coverage_df[coverage_df['shift_type'].str.startswith('Topic') & (coverage_df['type'] == 'Coverage')], \n",
    "            x=\"shift_type\", y=\"value\", hue=\"method\", \n",
    "            palette=palette, ax=ax)\n",
    "sns.move_legend(\n",
    "    ax, \"lower center\",\n",
    "    bbox_to_anchor=(.5, 1), ncol=3, title=None, frameon=False,\n",
    ")\n",
    "ax.set_ylim(0.4, 1.1)\n",
    "ax.axhline(0.9, color='gray', linestyle='--', label=\"target miscoverage\")\n",
    "ax.set_xlabel(\" \")\n",
    "ax.set_ylabel(\"Coverage\", fontsize = 12)\n",
    "plt.xticks(rotation=0)\n",
    "ax.tick_params(axis='x', labelsize=13)\n",
    "ax.tick_params(axis='y', labelsize=13)\n",
    "plt.tight_layout()\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(10, 3))\n",
    "sns.boxplot(data=coverage_df[coverage_df['shift_type'].str.startswith('Topic') & (coverage_df['type'] == 'Size')], \n",
    "            x=\"shift_type\", y=\"value\", hue=\"method\", \n",
    "            palette=palette, ax=ax)\n",
    "sns.move_legend(\n",
    "    ax, \"lower center\",\n",
    "    bbox_to_anchor=(.5, 1), ncol=3, title=None, frameon=False,\n",
    ")\n",
    "#ax.set_ylim(0.4, 1.1)\n",
    "ax.set_xlabel(\" \")\n",
    "ax.set_ylabel(\"Size\", fontsize = 12)\n",
    "plt.xticks(rotation=0)\n",
    "ax.tick_params(axis='x', labelsize=13)\n",
    "ax.tick_params(axis='y', labelsize=13)\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "ea6b11f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Coverage Means:\n",
      "method           PCP      RLCP   SpeedCP   SplitCP\n",
      "shift_type                                        \n",
      "Topic 0     0.877114  0.935329  0.880974  0.877114\n",
      "Topic 1     0.876002  0.958005  0.890009  0.876002\n",
      "Topic 2     0.659375  0.956597  0.730556  0.659375\n",
      "Topic 3     0.926991  0.923368  0.920104  0.926991\n",
      "Topic 4     0.762664  0.962352  0.822426  0.762664\n",
      "\n",
      "Coverage Standard Deviations:\n",
      "method           PCP      RLCP   SpeedCP   SplitCP\n",
      "shift_type                                        \n",
      "Topic 0     0.024612  0.022196  0.027283  0.024612\n",
      "Topic 1     0.046155  0.035426  0.056645  0.046155\n",
      "Topic 2     0.350378  0.168421  0.345100  0.350378\n",
      "Topic 3     0.024938  0.023690  0.027158  0.024938\n",
      "Topic 4     0.088887  0.043988  0.114106  0.088887\n",
      "\n",
      "Size Means:\n",
      "method            PCP       RLCP    SpeedCP    SplitCP\n",
      "shift_type                                            \n",
      "Topic 0     15.661654  47.182950  15.990890  15.661434\n",
      "Topic 1     15.661654  69.740088  17.239292  15.661434\n",
      "Topic 2     15.628611  88.668833  23.153967  15.628392\n",
      "Topic 3     15.661654  31.169976  15.104937  15.661434\n",
      "Topic 4     15.661654  89.374569  20.888885  15.661434\n"
     ]
    }
   ],
   "source": [
    "mean_df = (\n",
    "    coverage_df\n",
    "    .groupby([\"method\", \"shift_type\", \"type\"])[\"value\"]\n",
    "    .mean()\n",
    "    .reset_index()\n",
    ")\n",
    "\n",
    "sd_df = (\n",
    "    coverage_df\n",
    "    .groupby([\"method\", \"shift_type\", \"type\"])[\"value\"]\n",
    "    .std(ddof=1)\n",
    "    .reset_index()\n",
    ")\n",
    "\n",
    "coverage_means = mean_df[mean_df[\"type\"] == \"Coverage\"]\n",
    "print(\"\\nCoverage Means:\")\n",
    "print(coverage_means.pivot(index=\"shift_type\", columns=\"method\", values=\"value\"))\n",
    "\n",
    "coverage_sds = sd_df[sd_df[\"type\"] == \"Coverage\"]\n",
    "print(\"\\nCoverage Standard Deviations:\")\n",
    "print(coverage_sds.pivot(index=\"shift_type\", columns=\"method\", values=\"value\"))\n",
    "\n",
    "size_means = mean_df[mean_df[\"type\"] == \"Size\"]\n",
    "print(\"\\nSize Means:\")\n",
    "print(size_means.pivot(index=\"shift_type\", columns=\"method\", values=\"value\"))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gnn-env",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
