{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "31844884",
   "metadata": {},
   "source": [
    "# 1 Gemma 2 2b L12"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d3a141a7",
   "metadata": {},
   "source": [
    "## 1.1 Token Conf Distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "ed5d3ad8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total delta_confidence collected: 3000\n",
      "Tail fraction (each side): 0.05\n",
      "Left tail  <= q(0.05) = -1.175228 : 150 (5.00%)\n",
      "Right tail >= q(0.95) = 0.601563 : 150 (5.00%)\n",
      "Mean: -0.173300 | Median: -0.099307 | Std: 0.512162 | Min: -1.575365 | Max: 1.966089\n",
      "[INFO] Saved figure to: delta_confidence_distribution_percentile_tails.png\n"
     ]
    },
    {
     "data": {
      "image/png": "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b806PDzKsGnjWooWLWKJyxMzM0V9cnF155lnKvPMM964u5UkNDSMXbv3cOZMCKXc3Vi7ZjmenmUtcXliAbNnz2NPSg+ygICTHD16nAb161IuZTieZ+vXpVfKPx1HjxnHd2N/ZPiwoYz46IM05Qx67wNmz5mPd6WKtGzZnGvXb7BixWocHBzY+NdqnnqqvHkvTCzCFPWpavV62NraUrNGNdzd3YiJieXAwUMcO+ZPoUKFWL50PrVra9iwx11q/XB0dKBvn7eMJmTbtGlFtapV0uyv9unxoDFlRSzg+o1/WbBgcZp1N+5bd28CLSONGzciMDCIY8dPsGfPPmJiYylSxJUWLZrx1hu9adbsBRNHLrmVqeoUwPONG/HnupWMHjOOFStWE383nsre3nzx2Sh8fduZMmzJpRwcCrJ2zXLGjPkBP7+17Ni5mxIlijOgfx+GD3s/0z0VW7/8EuHh4fj7B7B163bi4uIpUbwYHXzb0a/v2/pD4zFjirbD2tqa+fN+Z/yEn1m0eBlTpv5K4cIu9OzxGh+PGq6E7BPEFPVpQP8+HDx4mK1btxMaGoadnS3lynnywfuDGdD/HVxcXHL2IiRX2bPvQLrPSnv3HUjzVd9e930TxJgJ48dSuXIlZs2axy/TZuLgUJBX2rTik48/olw5T1OHLbmUKerTm2/0YtPmbezes49bt0KxtraiTOnS9Ov7NgP696FUKfcciV1yl9Qhm6Kiohn3w0Sj+3h4lDEkZR9E7VPeo56yIiIiIiIiIiIiImakMWVFREREREREREREzEhJWREREREREREREREzUlJWRERERERERERExIyUlBURERERERERERExIyVlRURERERERERERMxISVkRERERERERERERM1JSVkRERERERERERMSMlJQVERERERERERERMSMlZUVERERERERERETMSElZERERERERERERETNSUlZERERERERERETEjJSUFRERERGTaePTARdXd0aPGWfpUOQ+t2/f5ruxP9KwUTPcSnnh4uqOi6s7a9auBx792fXrPxgXV3f69R9swqhFREREHk82lg5ARERERP4TGxtLRe+aREREALBu7QoaPls/W2W18enArl17snVsmTKlOX50f7aOfZwlJSWxbv1frF+/gQMHDnH9xr9ERUXh5OSEp6cHdevW5tX2PjzbIHvPLCe9/mZf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",
      "text/plain": [
       "<Figure size 1400x840 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.patches import Patch\n",
    "\n",
    "# =========================\n",
    "# CONFIG (edit as you like)\n",
    "# =========================\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_2b/layer12\"\n",
    "JSON_FILENAME = \"output_scores_plus_top20_kconf1.json\"\n",
    "\n",
    "# Instead of an absolute threshold, use percentile tails.\n",
    "# Example: 0.30 approximates per-SAE TOPK_UP=30 and TOPK_DOWN=30 when each SAE has 100 features.\n",
    "TAIL_FRACTION = 0.05        # left 30% and right 30%\n",
    "BINS = 40                   # histogram bins\n",
    "OUT_FIG = \"delta_confidence_distribution_percentile_tails.png\"\n",
    "\n",
    "# Brand palette\n",
    "COL_BAR  = \"#D97757\"   # histogram bars\n",
    "COL_BG   = \"#F0EEE6\"   # background\n",
    "COL_TAIL = \"#E3DACC\"   # shaded tails\n",
    "COL_LINE = \"#8C4B34\"   # reference/quantile lines\n",
    "\n",
    "\n",
    "# =========================\n",
    "# Utils\n",
    "# =========================\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"[WARN] Failed to load JSON: {path} ({e})\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def collect_delta_confidence(entropy_root: str, json_filename: str) -> List[float]:\n",
    "    deltas: List[float] = []\n",
    "    if not os.path.isdir(entropy_root):\n",
    "        print(f\"[ERROR] ENTROPY_ROOT not found: {entropy_root}\")\n",
    "        return deltas\n",
    "\n",
    "    for sae_name in sorted(os.listdir(entropy_root)):\n",
    "        sae_dir = os.path.join(entropy_root, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "        fp = os.path.join(sae_dir, json_filename)\n",
    "        data = safe_load_json(fp)\n",
    "        if data is None:\n",
    "            continue\n",
    "        # data is dict like {\"12_97\": {...}, \"12_103\": {...}, ...}\n",
    "        for _, info in data.items():\n",
    "            if isinstance(info, dict) and (\"delta_confidence\" in info):\n",
    "                try:\n",
    "                    deltas.append(float(info[\"delta_confidence\"]))\n",
    "                except Exception:\n",
    "                    pass\n",
    "    return deltas\n",
    "\n",
    "\n",
    "def plot_distribution_with_percentile_tails(\n",
    "    deltas: List[float],\n",
    "    out_path: str,\n",
    "    tail_fraction: float,\n",
    "    bins: int = 40,\n",
    ") -> None:\n",
    "    if not deltas:\n",
    "        print(\"[WARN] No delta_confidence values to plot.\")\n",
    "        return\n",
    "\n",
    "    arr = np.array(deltas, dtype=float)\n",
    "    n = arr.size\n",
    "\n",
    "    # Compute left/right percentile cut points\n",
    "    tail_fraction = max(0.0, min(0.5, float(tail_fraction)))  # clamp to [0, 0.5]\n",
    "    q_left  = np.quantile(arr, tail_fraction)       # e.g., 0.30 quantile\n",
    "    q_right = np.quantile(arr, 1.0 - tail_fraction) # e.g., 0.70 quantile\n",
    "\n",
    "    # Counts for the shaded tails\n",
    "    left_mask  = arr <= q_left\n",
    "    right_mask = arr >= q_right\n",
    "    left_count  = int(left_mask.sum())\n",
    "    right_count = int(right_mask.sum())\n",
    "    left_pct  = 100.0 * left_count  / n if n > 0 else 0.0\n",
    "    right_pct = 100.0 * right_count / n if n > 0 else 0.0\n",
    "\n",
    "    # Basic stats\n",
    "    mean_val = arr.mean()\n",
    "    med_val  = float(np.median(arr))\n",
    "    std_val  = arr.std(ddof=1) if n > 1 else 0.0\n",
    "    min_val  = float(arr.min())\n",
    "    max_val  = float(arr.max())\n",
    "\n",
    "    print(f\"Total delta_confidence collected: {n}\")\n",
    "    print(f\"Tail fraction (each side): {tail_fraction:.2f}\")\n",
    "    print(f\"Left tail  <= q({tail_fraction:.2f}) = {q_left:.6f} : {left_count} ({left_pct:.2f}%)\")\n",
    "    print(f\"Right tail >= q({1.0 - tail_fraction:.2f}) = {q_right:.6f} : {right_count} ({right_pct:.2f}%)\")\n",
    "    print(f\"Mean: {mean_val:.6f} | Median: {med_val:.6f} | Std: {std_val:.6f} | Min: {min_val:.6f} | Max: {max_val:.6f}\")\n",
    "\n",
    "    # Plot\n",
    "    fig, ax = plt.subplots(figsize=(10, 6))\n",
    "    fig.patch.set_facecolor(COL_BG)\n",
    "    ax.set_facecolor(COL_BG)\n",
    "\n",
    "    # Histogram\n",
    "    ax.hist(arr, bins=bins, color=COL_BAR, edgecolor=\"white\", alpha=0.9)\n",
    "\n",
    "    # Get axis limits and shade tails based on percentiles\n",
    "    xmin, xmax = ax.get_xlim()\n",
    "    ax.axvspan(xmin, q_left,  color=COL_TAIL, alpha=0.60)\n",
    "    ax.axvspan(q_right, xmax, color=COL_TAIL, alpha=0.60)\n",
    "\n",
    "    # Draw percentile lines and zero line\n",
    "    ax.axvline(x=q_left,  color=COL_LINE, linestyle=\"--\", linewidth=1.6)\n",
    "    ax.axvline(x=q_right, color=COL_LINE, linestyle=\"--\", linewidth=1.6)\n",
    "    ax.axvline(x=0.0,     color=COL_LINE, linestyle=\":\",  linewidth=1.2, alpha=0.85)\n",
    "\n",
    "    # Labels & title\n",
    "    ax.set_title(\n",
    "        f\"Distribution of Δ Token Confidence across all SAEs in Gemma 2 2B\\n\",\n",
    "        fontsize=16\n",
    "    )\n",
    "    ax.set_xlabel(\"Δ Token Confidence\", fontsize=13)\n",
    "    ax.set_ylabel(\"Number of Features\", fontsize=13)\n",
    "    ax.grid(True, linestyle=\":\", linewidth=0.6, alpha=0.8)\n",
    "\n",
    "    # Legend explaining tails\n",
    "    legend_patches = [\n",
    "        Patch(facecolor=COL_TAIL, edgecolor=\"white\",\n",
    "              label=f\"The Area with the Desired Steering Features\"),\n",
    "    ]\n",
    "    ax.legend(handles=legend_patches, frameon=True, facecolor=COL_BG, edgecolor=\"none\", loc=\"upper right\",fontsize=12)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    try:\n",
    "        plt.savefig(out_path, dpi=160, facecolor=fig.get_facecolor())\n",
    "        print(f\"[INFO] Saved figure to: {out_path}\")\n",
    "    except Exception as e:\n",
    "        print(f\"[WARN] Failed to save figure: {e}\")\n",
    "\n",
    "    plt.show()\n",
    "    plt.close()\n",
    "\n",
    "\n",
    "# =========================\n",
    "# Run\n",
    "# =========================\n",
    "if __name__ == \"__main__\":\n",
    "    deltas = collect_delta_confidence(ENTROPY_ROOT, JSON_FILENAME)\n",
    "\n",
    "    if len(deltas) > 0:\n",
    "        plot_distribution_with_percentile_tails(\n",
    "            deltas=deltas,\n",
    "            out_path=OUT_FIG,\n",
    "            tail_fraction=TAIL_FRACTION,\n",
    "            bins=BINS\n",
    "        )\n",
    "    else:\n",
    "        print(\"[WARN] No values found; skip plotting.\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8b630768",
   "metadata": {},
   "source": [
    "## 1.1 Threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "170f974f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.145400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.420000 [> overall]\n",
      "delta_confidence >= 0.6   : count=4     avg_overall=0.270000 [> overall]\n",
      "delta_confidence >= 0.5   : count=6     avg_overall=0.260000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=3     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=4     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=8     avg_overall=0.182500 [> overall]\n",
      "delta_confidence <= -0.6  : count=13    avg_overall=0.190769 [> overall]\n",
      "delta_confidence <= -0.5  : count=23    avg_overall=0.139130\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=2  avg_overall=0.420000  lift=188.86%\n",
      "Best DOWN : th=0.6 | count=13 avg_overall=0.190769  lift=31.20%\n",
      "Best of BOTH: 188.86%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.122400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.480000 [> overall]\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.480000 [> overall]\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.7   : count=3     avg_overall=0.160000 [> overall]\n",
      "delta_confidence >= 0.6   : count=9     avg_overall=0.113333\n",
      "delta_confidence >= 0.5   : count=9     avg_overall=0.113333\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=8     avg_overall=0.120000\n",
      "delta_confidence <= -0.9  : count=10    avg_overall=0.168000 [> overall]\n",
      "delta_confidence <= -0.8  : count=12    avg_overall=0.140000 [> overall]\n",
      "delta_confidence <= -0.7  : count=14    avg_overall=0.120000\n",
      "delta_confidence <= -0.6  : count=18    avg_overall=0.093333\n",
      "delta_confidence <= -0.5  : count=21    avg_overall=0.080000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=1  avg_overall=0.480000  lift=292.16%\n",
      "Best DOWN : th=0.9 | count=10 avg_overall=0.168000  lift=37.25%\n",
      "Best of BOTH: 292.16%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.151400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=3     avg_overall=0.080000\n",
      "delta_confidence >= 0.8   : count=5     avg_overall=0.136000\n",
      "delta_confidence >= 0.7   : count=9     avg_overall=0.075556\n",
      "delta_confidence >= 0.6   : count=12    avg_overall=0.076667\n",
      "delta_confidence >= 0.5   : count=13    avg_overall=0.070769\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=24    avg_overall=0.171667 [> overall]\n",
      "delta_confidence <= -0.9  : count=29    avg_overall=0.195862 [> overall]\n",
      "delta_confidence <= -0.8  : count=36    avg_overall=0.186111 [> overall]\n",
      "delta_confidence <= -0.7  : count=40    avg_overall=0.167500 [> overall]\n",
      "delta_confidence <= -0.6  : count=46    avg_overall=0.180870 [> overall]\n",
      "delta_confidence <= -0.5  : count=49    avg_overall=0.194286 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.8  | count=5  avg_overall=0.136000  lift=-10.17%\n",
      "Best DOWN : th=0.9 | count=29 avg_overall=0.195862  lift=29.37%\n",
      "Best of BOTH: 29.37%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.117400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=3     avg_overall=0.406667 [> overall]\n",
      "delta_confidence >= 0.9   : count=4     avg_overall=0.380000 [> overall]\n",
      "delta_confidence >= 0.8   : count=6     avg_overall=0.293333 [> overall]\n",
      "delta_confidence >= 0.7   : count=7     avg_overall=0.251429 [> overall]\n",
      "delta_confidence >= 0.6   : count=9     avg_overall=0.244444 [> overall]\n",
      "delta_confidence >= 0.5   : count=17    avg_overall=0.175294 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=6     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -0.9  : count=7     avg_overall=0.137143 [> overall]\n",
      "delta_confidence <= -0.8  : count=7     avg_overall=0.137143 [> overall]\n",
      "delta_confidence <= -0.7  : count=7     avg_overall=0.137143 [> overall]\n",
      "delta_confidence <= -0.6  : count=12    avg_overall=0.080000\n",
      "delta_confidence <= -0.5  : count=20    avg_overall=0.111000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=3  avg_overall=0.406667  lift=246.39%\n",
      "Best DOWN : th=0.9 | count=7 avg_overall=0.137143  lift=16.82%\n",
      "Best of BOTH: 246.39%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.156200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=3     avg_overall=0.406667 [> overall]\n",
      "delta_confidence >= 0.9   : count=4     avg_overall=0.305000 [> overall]\n",
      "delta_confidence >= 0.8   : count=6     avg_overall=0.343333 [> overall]\n",
      "delta_confidence >= 0.7   : count=7     avg_overall=0.337143 [> overall]\n",
      "delta_confidence >= 0.6   : count=10    avg_overall=0.236000 [> overall]\n",
      "delta_confidence >= 0.5   : count=12    avg_overall=0.196667 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=19    avg_overall=0.104211\n",
      "delta_confidence <= -0.9  : count=22    avg_overall=0.090000\n",
      "delta_confidence <= -0.8  : count=24    avg_overall=0.092500\n",
      "delta_confidence <= -0.7  : count=29    avg_overall=0.084828\n",
      "delta_confidence <= -0.6  : count=36    avg_overall=0.081667\n",
      "delta_confidence <= -0.5  : count=42    avg_overall=0.104286\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=3  avg_overall=0.406667  lift=160.35%\n",
      "Best DOWN : th=0.5 | count=42 avg_overall=0.104286  lift=-33.24%\n",
      "Best of BOTH: 160.35%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.960000 [> overall]\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.960000 [> overall]\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.600000 [> overall]\n",
      "delta_confidence >= 0.6   : count=3     avg_overall=0.480000 [> overall]\n",
      "delta_confidence >= 0.5   : count=5     avg_overall=0.288000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=5     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=7     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=9     avg_overall=0.000000\n",
      "delta_confidence <= -0.6  : count=13    avg_overall=0.041538\n",
      "delta_confidence <= -0.5  : count=17    avg_overall=0.063529\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=1  avg_overall=0.960000  lift=803.95%\n",
      "Best DOWN : th=0.5 | count=17 avg_overall=0.063529  lift=-40.18%\n",
      "Best of BOTH: 803.95%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_148\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.115800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=2     avg_overall=0.360000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=3     avg_overall=0.146667 [> overall]\n",
      "delta_confidence <= -0.9  : count=6     avg_overall=0.106667\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.170000 [> overall]\n",
      "delta_confidence <= -0.7  : count=12    avg_overall=0.113333\n",
      "delta_confidence <= -0.6  : count=15    avg_overall=0.126667 [> overall]\n",
      "delta_confidence <= -0.5  : count=17    avg_overall=0.111765\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=2  avg_overall=0.360000  lift=210.88%\n",
      "Best DOWN : th=0.8 | count=8 avg_overall=0.170000  lift=46.80%\n",
      "Best of BOTH: 210.88%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_340\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.153200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=2     avg_overall=0.120000\n",
      "delta_confidence <= -0.8  : count=3     avg_overall=0.306667 [> overall]\n",
      "delta_confidence <= -0.7  : count=3     avg_overall=0.306667 [> overall]\n",
      "delta_confidence <= -0.6  : count=6     avg_overall=0.363333 [> overall]\n",
      "delta_confidence <= -0.5  : count=8     avg_overall=0.272500 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.6 | count=6 avg_overall=0.363333  lift=137.16%\n",
      "Best of BOTH: 137.16%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_49\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.6  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.5  : count=0     avg_overall=0.000000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN:  N/A (no non-empty selection)\n",
      "Best of BOTH: N/A\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_547\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=3     avg_overall=0.080000\n",
      "delta_confidence >= 0.5   : count=3     avg_overall=0.080000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=2     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -0.8  : count=4     avg_overall=0.360000 [> overall]\n",
      "delta_confidence <= -0.7  : count=7     avg_overall=0.308571 [> overall]\n",
      "delta_confidence <= -0.6  : count=7     avg_overall=0.308571 [> overall]\n",
      "delta_confidence <= -0.5  : count=9     avg_overall=0.293333 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.6  | count=3  avg_overall=0.080000  lift=-40.21%\n",
      "Best DOWN : th=0.8 | count=4 avg_overall=0.360000  lift=169.06%\n",
      "Best of BOTH: 169.06%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_78\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.088800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=2     avg_overall=0.150000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -0.9  : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -0.8  : count=2     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -0.7  : count=3     avg_overall=0.080000\n",
      "delta_confidence <= -0.6  : count=3     avg_overall=0.080000\n",
      "delta_confidence <= -0.5  : count=4     avg_overall=0.060000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=2  avg_overall=0.150000  lift=68.92%\n",
      "Best DOWN : th=1.0 | count=1 avg_overall=0.240000  lift=170.27%\n",
      "Best of BOTH: 170.27%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_948\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.102800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.6  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -0.5  : count=3     avg_overall=0.160000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.6  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.5 | count=3 avg_overall=0.160000  lift=55.64%\n",
      "Best of BOTH: 55.64%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_165\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=4     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=4     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -0.8  : count=7     avg_overall=0.102857\n",
      "delta_confidence <= -0.7  : count=11    avg_overall=0.109091\n",
      "delta_confidence <= -0.6  : count=13    avg_overall=0.092308\n",
      "delta_confidence <= -0.5  : count=20    avg_overall=0.123000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=4  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.5 | count=20 avg_overall=0.123000  lift=2.84%\n",
      "Best of BOTH: 2.84%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_330\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.105400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.6   : count=2     avg_overall=0.120000 [> overall]\n",
      "delta_confidence >= 0.5   : count=5     avg_overall=0.096000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=3     avg_overall=0.160000 [> overall]\n",
      "delta_confidence <= -0.6  : count=10    avg_overall=0.144000 [> overall]\n",
      "delta_confidence <= -0.5  : count=14    avg_overall=0.154286 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.240000  lift=127.70%\n",
      "Best DOWN : th=0.7 | count=3 avg_overall=0.160000  lift=51.80%\n",
      "Best of BOTH: 127.70%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_52\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.175800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.8   : count=5     avg_overall=0.048000\n",
      "delta_confidence >= 0.7   : count=6     avg_overall=0.226667 [> overall]\n",
      "delta_confidence >= 0.6   : count=10    avg_overall=0.160000\n",
      "delta_confidence >= 0.5   : count=12    avg_overall=0.133333\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=10    avg_overall=0.078000\n",
      "delta_confidence <= -0.9  : count=13    avg_overall=0.115385\n",
      "delta_confidence <= -0.8  : count=15    avg_overall=0.100000\n",
      "delta_confidence <= -0.7  : count=18    avg_overall=0.123333\n",
      "delta_confidence <= -0.6  : count=24    avg_overall=0.125000\n",
      "delta_confidence <= -0.5  : count=32    avg_overall=0.159375\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=1  avg_overall=0.240000  lift=36.52%\n",
      "Best DOWN : th=0.5 | count=32 avg_overall=0.159375  lift=-9.34%\n",
      "Best of BOTH: 36.52%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_538\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.089200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=4     avg_overall=0.100000 [> overall]\n",
      "delta_confidence >= 0.8   : count=4     avg_overall=0.100000 [> overall]\n",
      "delta_confidence >= 0.7   : count=4     avg_overall=0.100000 [> overall]\n",
      "delta_confidence >= 0.6   : count=6     avg_overall=0.066667\n",
      "delta_confidence >= 0.5   : count=9     avg_overall=0.044444\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=4     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=6     avg_overall=0.040000\n",
      "delta_confidence <= -0.8  : count=10    avg_overall=0.072000\n",
      "delta_confidence <= -0.7  : count=15    avg_overall=0.064000\n",
      "delta_confidence <= -0.6  : count=19    avg_overall=0.075789\n",
      "delta_confidence <= -0.5  : count=21    avg_overall=0.068571\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=4  avg_overall=0.100000  lift=12.11%\n",
      "Best DOWN : th=0.6 | count=19 avg_overall=0.075789  lift=-15.03%\n",
      "Best of BOTH: 12.11%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_779\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=9     avg_overall=0.066667\n",
      "delta_confidence >= 0.9   : count=12    avg_overall=0.070000\n",
      "delta_confidence >= 0.8   : count=18    avg_overall=0.060000\n",
      "delta_confidence >= 0.7   : count=20    avg_overall=0.069000\n",
      "delta_confidence >= 0.6   : count=21    avg_overall=0.065714\n",
      "delta_confidence >= 0.5   : count=22    avg_overall=0.062727\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=13    avg_overall=0.206154 [> overall]\n",
      "delta_confidence <= -0.9  : count=15    avg_overall=0.210667 [> overall]\n",
      "delta_confidence <= -0.8  : count=20    avg_overall=0.206000 [> overall]\n",
      "delta_confidence <= -0.7  : count=21    avg_overall=0.196190 [> overall]\n",
      "delta_confidence <= -0.6  : count=26    avg_overall=0.188462 [> overall]\n",
      "delta_confidence <= -0.5  : count=27    avg_overall=0.199259 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=12  avg_overall=0.070000  lift=-41.37%\n",
      "Best DOWN : th=0.9 | count=15 avg_overall=0.210667  lift=76.44%\n",
      "Best of BOTH: 76.44%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_83\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.178800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=5     avg_overall=0.048000\n",
      "delta_confidence >= 0.5   : count=8     avg_overall=0.030000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=3     avg_overall=0.306667 [> overall]\n",
      "delta_confidence <= -0.9  : count=4     avg_overall=0.290000 [> overall]\n",
      "delta_confidence <= -0.8  : count=7     avg_overall=0.311429 [> overall]\n",
      "delta_confidence <= -0.7  : count=10    avg_overall=0.242000 [> overall]\n",
      "delta_confidence <= -0.6  : count=11    avg_overall=0.220000 [> overall]\n",
      "delta_confidence <= -0.5  : count=20    avg_overall=0.205000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.6  | count=5  avg_overall=0.048000  lift=-73.15%\n",
      "Best DOWN : th=0.8 | count=7 avg_overall=0.311429  lift=74.18%\n",
      "Best of BOTH: 74.18%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_156\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.181000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=3     avg_overall=0.080000\n",
      "delta_confidence >= 0.6   : count=3     avg_overall=0.080000\n",
      "delta_confidence >= 0.5   : count=6     avg_overall=0.120000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=15    avg_overall=0.160000\n",
      "delta_confidence <= -0.9  : count=17    avg_overall=0.183529 [> overall]\n",
      "delta_confidence <= -0.8  : count=22    avg_overall=0.196364 [> overall]\n",
      "delta_confidence <= -0.7  : count=27    avg_overall=0.186667 [> overall]\n",
      "delta_confidence <= -0.6  : count=33    avg_overall=0.189091 [> overall]\n",
      "delta_confidence <= -0.5  : count=37    avg_overall=0.168649\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=6  avg_overall=0.120000  lift=-33.70%\n",
      "Best DOWN : th=0.8 | count=22 avg_overall=0.196364  lift=8.49%\n",
      "Best of BOTH: 8.49%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_309\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.131400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=4     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=5     avg_overall=0.048000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=5     avg_overall=0.108000\n",
      "delta_confidence <= -0.9  : count=7     avg_overall=0.134286 [> overall]\n",
      "delta_confidence <= -0.8  : count=9     avg_overall=0.131111\n",
      "delta_confidence <= -0.7  : count=13    avg_overall=0.146154 [> overall]\n",
      "delta_confidence <= -0.6  : count=15    avg_overall=0.146667 [> overall]\n",
      "delta_confidence <= -0.5  : count=21    avg_overall=0.161905 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=5  avg_overall=0.048000  lift=-63.47%\n",
      "Best DOWN : th=0.5 | count=21 avg_overall=0.161905  lift=23.22%\n",
      "Best of BOTH: 23.22%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_507\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.140400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=3     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=4     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=5     avg_overall=0.312000 [> overall]\n",
      "delta_confidence <= -0.9  : count=5     avg_overall=0.312000 [> overall]\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.317500 [> overall]\n",
      "delta_confidence <= -0.7  : count=10    avg_overall=0.254000 [> overall]\n",
      "delta_confidence <= -0.6  : count=13    avg_overall=0.278462 [> overall]\n",
      "delta_confidence <= -0.5  : count=16    avg_overall=0.290000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=4  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.8 | count=8 avg_overall=0.317500  lift=126.14%\n",
      "Best of BOTH: 126.14%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_54\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.150400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.300000 [> overall]\n",
      "delta_confidence >= 0.6   : count=2     avg_overall=0.150000\n",
      "delta_confidence >= 0.5   : count=3     avg_overall=0.100000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=14    avg_overall=0.138571\n",
      "delta_confidence <= -0.9  : count=22    avg_overall=0.168182 [> overall]\n",
      "delta_confidence <= -0.8  : count=27    avg_overall=0.174815 [> overall]\n",
      "delta_confidence <= -0.7  : count=32    avg_overall=0.170000 [> overall]\n",
      "delta_confidence <= -0.6  : count=35    avg_overall=0.169143 [> overall]\n",
      "delta_confidence <= -0.5  : count=39    avg_overall=0.170256 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.300000  lift=99.47%\n",
      "Best DOWN : th=0.8 | count=27 avg_overall=0.174815  lift=16.23%\n",
      "Best of BOTH: 99.47%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_733\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.141000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.480000 [> overall]\n",
      "delta_confidence >= 0.9   : count=2     avg_overall=0.360000 [> overall]\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.360000 [> overall]\n",
      "delta_confidence >= 0.7   : count=5     avg_overall=0.408000 [> overall]\n",
      "delta_confidence >= 0.6   : count=5     avg_overall=0.408000 [> overall]\n",
      "delta_confidence >= 0.5   : count=5     avg_overall=0.408000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=4     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=5     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=7     avg_overall=0.111429\n",
      "delta_confidence <= -0.7  : count=8     avg_overall=0.217500 [> overall]\n",
      "delta_confidence <= -0.6  : count=9     avg_overall=0.193333 [> overall]\n",
      "delta_confidence <= -0.5  : count=14    avg_overall=0.124286\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=1  avg_overall=0.480000  lift=240.43%\n",
      "Best DOWN : th=0.7 | count=8 avg_overall=0.217500  lift=54.26%\n",
      "Best of BOTH: 240.43%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_99\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.109800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.6   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.5   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=13    avg_overall=0.078462\n",
      "delta_confidence <= -0.9  : count=15    avg_overall=0.084000\n",
      "delta_confidence <= -0.8  : count=20    avg_overall=0.063000\n",
      "delta_confidence <= -0.7  : count=26    avg_overall=0.094615\n",
      "delta_confidence <= -0.6  : count=30    avg_overall=0.082000\n",
      "delta_confidence <= -0.5  : count=34    avg_overall=0.109412\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=0.5 | count=34 avg_overall=0.109412  lift=-0.35%\n",
      "Best of BOTH: -0.35%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.152200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.7   : count=3     avg_overall=0.080000\n",
      "delta_confidence >= 0.6   : count=5     avg_overall=0.144000\n",
      "delta_confidence >= 0.5   : count=6     avg_overall=0.120000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=6     avg_overall=0.200000 [> overall]\n",
      "delta_confidence <= -0.9  : count=9     avg_overall=0.160000 [> overall]\n",
      "delta_confidence <= -0.8  : count=10    avg_overall=0.144000\n",
      "delta_confidence <= -0.7  : count=15    avg_overall=0.112000\n",
      "delta_confidence <= -0.6  : count=22    avg_overall=0.163636 [> overall]\n",
      "delta_confidence <= -0.5  : count=30    avg_overall=0.168000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.8  | count=1  avg_overall=0.240000  lift=57.69%\n",
      "Best DOWN : th=1.0 | count=6 avg_overall=0.200000  lift=31.41%\n",
      "Best of BOTH: 57.69%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.112800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=3     avg_overall=0.160000 [> overall]\n",
      "delta_confidence >= 0.6   : count=5     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.5   : count=7     avg_overall=0.171429 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=9     avg_overall=0.133333 [> overall]\n",
      "delta_confidence <= -0.9  : count=11    avg_overall=0.130909 [> overall]\n",
      "delta_confidence <= -0.8  : count=13    avg_overall=0.175385 [> overall]\n",
      "delta_confidence <= -0.7  : count=16    avg_overall=0.142500 [> overall]\n",
      "delta_confidence <= -0.6  : count=23    avg_overall=0.109565\n",
      "delta_confidence <= -0.5  : count=26    avg_overall=0.106154\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.6  | count=5  avg_overall=0.240000  lift=112.77%\n",
      "Best DOWN : th=0.8 | count=13 avg_overall=0.175385  lift=55.48%\n",
      "Best of BOTH: 112.77%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.196600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=4     avg_overall=0.170000\n",
      "delta_confidence >= 0.9   : count=4     avg_overall=0.170000\n",
      "delta_confidence >= 0.8   : count=5     avg_overall=0.136000\n",
      "delta_confidence >= 0.7   : count=6     avg_overall=0.113333\n",
      "delta_confidence >= 0.6   : count=8     avg_overall=0.115000\n",
      "delta_confidence >= 0.5   : count=10    avg_overall=0.160000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=23    avg_overall=0.204348 [> overall]\n",
      "delta_confidence <= -0.9  : count=27    avg_overall=0.191852\n",
      "delta_confidence <= -0.8  : count=28    avg_overall=0.185000\n",
      "delta_confidence <= -0.7  : count=34    avg_overall=0.159412\n",
      "delta_confidence <= -0.6  : count=37    avg_overall=0.146486\n",
      "delta_confidence <= -0.5  : count=52    avg_overall=0.176923\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=4  avg_overall=0.170000  lift=-13.53%\n",
      "Best DOWN : th=1.0 | count=23 avg_overall=0.204348  lift=3.94%\n",
      "Best of BOTH: 3.94%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.120000\n",
      "delta_confidence >= 0.6   : count=6     avg_overall=0.040000\n",
      "delta_confidence >= 0.5   : count=7     avg_overall=0.068571\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=8     avg_overall=0.187500 [> overall]\n",
      "delta_confidence <= -0.9  : count=10    avg_overall=0.222000 [> overall]\n",
      "delta_confidence <= -0.8  : count=11    avg_overall=0.267273 [> overall]\n",
      "delta_confidence <= -0.7  : count=14    avg_overall=0.227143 [> overall]\n",
      "delta_confidence <= -0.6  : count=16    avg_overall=0.198750 [> overall]\n",
      "delta_confidence <= -0.5  : count=27    avg_overall=0.162222 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=2  avg_overall=0.120000  lift=-10.31%\n",
      "Best DOWN : th=0.8 | count=11 avg_overall=0.267273  lift=99.76%\n",
      "Best of BOTH: 99.76%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.148600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=4     avg_overall=0.160000 [> overall]\n",
      "delta_confidence >= 0.9   : count=6     avg_overall=0.186667 [> overall]\n",
      "delta_confidence >= 0.8   : count=7     avg_overall=0.160000 [> overall]\n",
      "delta_confidence >= 0.7   : count=9     avg_overall=0.124444\n",
      "delta_confidence >= 0.6   : count=13    avg_overall=0.086154\n",
      "delta_confidence >= 0.5   : count=14    avg_overall=0.080000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=15    avg_overall=0.048000\n",
      "delta_confidence <= -0.9  : count=20    avg_overall=0.048000\n",
      "delta_confidence <= -0.8  : count=26    avg_overall=0.036923\n",
      "delta_confidence <= -0.7  : count=30    avg_overall=0.112000\n",
      "delta_confidence <= -0.6  : count=32    avg_overall=0.112500\n",
      "delta_confidence <= -0.5  : count=36    avg_overall=0.106667\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=6  avg_overall=0.186667  lift=25.62%\n",
      "Best DOWN : th=0.6 | count=32 avg_overall=0.112500  lift=-24.29%\n",
      "Best of BOTH: 25.62%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 87\n",
      "Average overall score (all features): 0.105747\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.120000 [> overall]\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.120000 [> overall]\n",
      "delta_confidence >= 0.6   : count=2     avg_overall=0.120000 [> overall]\n",
      "delta_confidence >= 0.5   : count=4     avg_overall=0.300000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.0  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=5     avg_overall=0.108000 [> overall]\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.067500\n",
      "delta_confidence <= -0.7  : count=9     avg_overall=0.060000\n",
      "delta_confidence <= -0.6  : count=11    avg_overall=0.136364 [> overall]\n",
      "delta_confidence <= -0.5  : count=11    avg_overall=0.136364 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.5  | count=4  avg_overall=0.300000  lift=183.70%\n",
      "Best DOWN : th=0.6 | count=11 avg_overall=0.136364  lift=28.95%\n",
      "Best of BOTH: 183.70%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (using each SAE's BEST threshold per direction and best-of-both)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-threshold average lift across SAEs (UP: delta_confidence >= th):\n",
      "delta_confidence >= 1.0   : N=11   avg_lift=44.48%\n",
      "delta_confidence >= 0.9   : N=16   avg_lift=65.16%\n",
      "delta_confidence >= 0.8   : N=19   avg_lift=34.34%\n",
      "delta_confidence >= 0.7   : N=24   avg_lift=27.62%\n",
      "delta_confidence >= 0.6   : N=27   avg_lift=-5.11%\n",
      "delta_confidence >= 0.5   : N=28   avg_lift=1.78%\n",
      "\n",
      "Per-threshold average lift across SAEs (DOWN: delta_confidence <= -th):\n",
      "delta_confidence <= -1.0  : N=27   avg_lift=-16.73%\n",
      "delta_confidence <= -0.9  : N=27   avg_lift=4.58%\n",
      "delta_confidence <= -0.8  : N=28   avg_lift=9.09%\n",
      "delta_confidence <= -0.7  : N=29   avg_lift=8.28%\n",
      "delta_confidence <= -0.6  : N=29   avg_lift=9.50%\n",
      "delta_confidence <= -0.5  : N=29   avg_lift=12.62%\n",
      "\n",
      "--- BEST (per SAE) summaries ---\n",
      "UP   : SAEs with positive lift: 16 / 28 (57.14%)\n",
      "      Average BEST lift across SAEs (UP): 77.91%\n",
      "DOWN : SAEs with positive lift: 23 / 29 (79.31%)\n",
      "      Average BEST lift across SAEs (DOWN): 42.22%\n",
      "BOTH : SAEs with positive lift: 28 / 29 (96.55%)\n",
      "Base steering score across SAEs: 0.133058\n",
      "After selection steering score across SAEs: 0.306251\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 130.16%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_2b_it/layer12\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_2b/layer12\"\n",
    "\n",
    "# Thresholds for scanning (positive magnitudes).\n",
    "# We'll compute both directions:\n",
    "#   UP   : delta_confidence >= th\n",
    "#   DOWN : delta_confidence <= -th\n",
    "THRESHOLDS_CONFIDENCE = [1.0,0.9,0.8,0.7,0.6,0.5]               \n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return item[\"holdout\"][\"mean\"][\"overall\"]\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def select_and_average_up(\n",
    "    eval_data: Dict[str, Any],\n",
    "    entropy_data: Dict[str, Any],\n",
    "    threshold: float\n",
    ") -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Select features with delta_confidence >= threshold.\n",
    "    Return:\n",
    "      - count of selected features that also have an 'overall' in eval_data\n",
    "      - average 'overall' over those features\n",
    "    \"\"\"\n",
    "    selected: List[float] = []\n",
    "    for f, info in entropy_data.items():\n",
    "        if not isinstance(info, dict):\n",
    "            continue\n",
    "        v = info.get(\"delta_confidence\")\n",
    "        if v is None:\n",
    "            continue\n",
    "        if v >= threshold:\n",
    "            s = get_overall_from_eval_item(eval_data.get(f, {}))\n",
    "            if s is not None:\n",
    "                selected.append(s)\n",
    "    n = len(selected)\n",
    "    avg = (sum(selected) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def select_and_average_down(\n",
    "    eval_data: Dict[str, Any],\n",
    "    entropy_data: Dict[str, Any],\n",
    "    threshold: float\n",
    ") -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Select features with delta_confidence <= -threshold.\n",
    "    Return:\n",
    "      - count of selected features that also have an 'overall' in eval_data\n",
    "      - average 'overall' over those features\n",
    "    \"\"\"\n",
    "    selected: List[float] = []\n",
    "    for f, info in entropy_data.items():\n",
    "        if not isinstance(info, dict):\n",
    "            continue\n",
    "        v = info.get(\"delta_confidence\")\n",
    "        if v is None:\n",
    "            continue\n",
    "        if v <= -threshold:\n",
    "            s = get_overall_from_eval_item(eval_data.get(f, {}))\n",
    "            if s is not None:\n",
    "                selected.append(s)\n",
    "    n = len(selected)\n",
    "    avg = (sum(selected) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str\n",
    ") -> Tuple[\n",
    "    Dict[float, float],  # per-threshold lifts (UP)\n",
    "    Dict[float, float],  # per-threshold lifts (DOWN)\n",
    "    Optional[Tuple[float, int, float, float]],  # best_up: (th, count, avg, lift)\n",
    "    Optional[Tuple[float, int, float, float]],  # best_down: (th, count, avg, lift)\n",
    "    Optional[float],  # best_of_both lift\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "\n",
    "    Returns:\n",
    "      - per_threshold_lifts_up:  dict[th] = lift% for this SAE on UP direction (when computable)\n",
    "      - per_threshold_lifts_down: dict[th] = lift% for this SAE on DOWN direction (when computable)\n",
    "      - best_up tuple:  (best_th, best_count, best_avg, best_lift) or None if no selection\n",
    "      - best_down tuple:(best_th, best_count, best_avg, best_lift) or None if no selection\n",
    "      - best_of_both_lift: max(best_up_lift, best_down_lift) if either exists, else None\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, None, None, None\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping thresholds.)\")\n",
    "        return {}, {}, None, None, None\n",
    "\n",
    "    # Scan thresholds: UP\n",
    "    print(\"\\n=== delta_confidence thresholds (UP: >= th) ===\")\n",
    "    per_threshold_lifts_up: Dict[float, float] = {}\n",
    "    best_up: Optional[Tuple[float, int, float, float]] = None  # (th, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        n, avg_sub = select_and_average_up(eval_data, entropy_data, threshold=th)\n",
    "        line = f\"delta_confidence >= {th:<6}: count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_threshold_lifts_up[th] = lift\n",
    "                # choose by highest avg_sub; tie-break by larger count\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (th, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Scan thresholds: DOWN\n",
    "    print(\"\\n=== delta_confidence thresholds (DOWN: <= -th) ===\")\n",
    "    per_threshold_lifts_down: Dict[float, float] = {}\n",
    "    best_down: Optional[Tuple[float, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        n, avg_sub = select_and_average_down(eval_data, entropy_data, threshold=th)\n",
    "        line = f\"delta_confidence <= -{th:<5}: count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_threshold_lifts_down[th] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (th, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (per SAE)\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        best_of_both_lift = max(best_up[3], best_down[3])\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best thresholds (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP:    N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : th={best_up[0]}  | count={best_up[1]}  avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN:  N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : th={best_down[0]} | count={best_down[1]} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH: N/A\")\n",
    "    else:\n",
    "        direction = \"UP\" if (best_up is not None and best_up[3] == best_of_both_lift) else (\n",
    "            \"DOWN\" if (best_down is not None and best_down[3] == best_of_both_lift) else \"UP/DOWN (tie)\"\n",
    "        )\n",
    "        print(f\"Best of BOTH: {best_of_both_lift:.2f}%  (direction={direction})\")\n",
    "\n",
    "    return per_threshold_lifts_up, per_threshold_lifts_down, best_up, best_down, best_of_both_lift\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Across-SAEs per-threshold aggregations\n",
    "    across_up: Dict[float, Dict[str, float]] = {th: {\"sum\": 0.0, \"count\": 0.0} for th in THRESHOLDS_CONFIDENCE}\n",
    "    across_down: Dict[float, Dict[str, float]] = {th: {\"sum\": 0.0, \"count\": 0.0} for th in THRESHOLDS_CONFIDENCE}\n",
    "\n",
    "    # Per-SAE best stats\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "\n",
    "    pos_up = pos_down = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_both = 0\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        per_up, per_down, best_up, best_down, best_both = process_one_sae(sae_name)\n",
    "\n",
    "        # Aggregate per-threshold lifts (UP/DOWN)\n",
    "        for th, lift in per_up.items():\n",
    "            across_up[th][\"sum\"] += lift\n",
    "            across_up[th][\"count\"] += 1\n",
    "        for th, lift in per_down.items():\n",
    "            across_down[th][\"sum\"] += lift\n",
    "            across_down[th][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction BEST (per SAE)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if best_both is not None:\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both)\n",
    "            if best_both > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "    # =================================================================================\n",
    "    # Summary across SAEs\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (using each SAE's BEST threshold per direction and best-of-both)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-threshold averages: UP\n",
    "    print(\"Per-threshold average lift across SAEs (UP: delta_confidence >= th):\")\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        cnt = int(across_up[th][\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[th][\"sum\"] / cnt\n",
    "            print(f\"delta_confidence >= {th:<6}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"delta_confidence >= {th:<6}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-threshold averages: DOWN\n",
    "    print(\"\\nPer-threshold average lift across SAEs (DOWN: delta_confidence <= -th):\")\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        cnt = int(across_down[th][\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[th][\"sum\"] / cnt\n",
    "            print(f\"delta_confidence <= -{th:<5}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"delta_confidence <= -{th:<5}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # BEST summaries\n",
    "    print(\"\\n--- BEST (per SAE) summaries ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "    else:\n",
    "        avg_both_best = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "        print(f\"Base steering score across SAEs: {(lambda vals: (sum(vals)/len(vals) if vals else 0.0))([compute_base_stats(data)[1] for data in (safe_load_json(os.path.join(EVAL_ROOT, d, 'eval.json')) for d in sorted(os.listdir(EVAL_ROOT)) if os.path.isdir(os.path.join(EVAL_ROOT, d))) if data is not None]):.6f}\")\n",
    "        print(f\"After selection steering score across SAEs: {(lambda base: base * (1 + (avg_both_best/100.0)))((lambda vals: (sum(vals)/len(vals) if vals else 0.0))([compute_base_stats(data)[1] for data in (safe_load_json(os.path.join(EVAL_ROOT, d, 'eval.json')) for d in sorted(os.listdir(EVAL_ROOT)) if os.path.isdir(os.path.join(EVAL_ROOT, d))) if data is not None])):.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {avg_both_best:.2f}%\")\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f94bdbf8",
   "metadata": {},
   "source": [
    "## 1.2 Top K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "89a25665",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.145400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.420000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.312000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.210000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.146000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.420000  lift=188.86%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.146000  lift=0.41%\n",
      "Best of BOTH: 188.86%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.122400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.168000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=292.16%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.168000  lift=37.25%\n",
      "Best of BOTH: 292.16%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.151400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.068000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.176000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.208000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.136000  lift=-10.17%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.208000  lift=37.38%\n",
      "Best of BOTH: 37.38%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.117400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.540000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.610000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.304000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.220000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.610000  lift=419.59%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.144000  lift=22.66%\n",
      "Best of BOTH: 419.59%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.156200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.352000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.236000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.150000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.352000  lift=125.35%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.300000  lift=92.06%\n",
      "Best of BOTH: 125.35%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.288000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.168000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.030000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.960000  lift=803.95%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.030000  lift=-71.75%\n",
      "Best of BOTH: 803.95%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_148\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.115800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.184000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.188000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.088000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.136000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.360000  lift=210.88%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.136000  lift=17.44%\n",
      "Best of BOTH: 210.88%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_340\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.153200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.054000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.242000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.054000  lift=-64.75%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.388000  lift=153.26%\n",
      "Best of BOTH: 153.26%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_49\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.024000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.024000  lift=-77.44%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-9.77%\n",
      "Best of BOTH: -9.77%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_547\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.384000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.288000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=79.37%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.384000  lift=187.00%\n",
      "Best of BOTH: 187.00%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_78\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.088800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.108000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.156000  lift=75.68%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=170.27%\n",
      "Best of BOTH: 170.27%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_948\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.102800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.096000  lift=-6.61%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-6.61%\n",
      "Best of BOTH: -6.61%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_165\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.102000  lift=-14.72%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-19.73%\n",
      "Best of BOTH: -14.72%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_330\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.105400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.144000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=127.70%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.144000  lift=36.62%\n",
      "Best of BOTH: 127.70%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_52\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.175800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.160000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=36.52%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=36.52%\n",
      "Best of BOTH: 36.52%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_538\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.089200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.080000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.040000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.080000  lift=-10.31%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.072000  lift=-19.28%\n",
      "Best of BOTH: -10.31%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_779\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.060000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.176000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.220000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.120000  lift=0.50%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.220000  lift=84.25%\n",
      "Best of BOTH: 84.25%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_83\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.178800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.242000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.096000  lift=-46.31%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.460000  lift=157.27%\n",
      "Best of BOTH: 157.27%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_156\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.181000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.184000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.184000  lift=1.66%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=-33.70%\n",
      "Best of BOTH: 1.66%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_309\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.131400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.190000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.118000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.190000  lift=44.60%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.118000  lift=-10.20%\n",
      "Best of BOTH: 44.60%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_507\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.140400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.312000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.254000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.096000  lift=-31.62%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.312000  lift=122.22%\n",
      "Best of BOTH: 122.22%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_54\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.150400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.228000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.114000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.300000  lift=99.47%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.120000  lift=-20.21%\n",
      "Best of BOTH: 99.47%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_733\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.141000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.408000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.228000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.174000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=240.43%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.174000  lift=23.40%\n",
      "Best of BOTH: 240.43%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_99\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.109800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.054000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.120000  lift=9.29%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.054000  lift=-50.82%\n",
      "Best of BOTH: 9.29%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.152200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.092000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.144000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=57.69%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.240000  lift=57.69%\n",
      "Best of BOTH: 57.69%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.112800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.240000  lift=112.77%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=6.38%\n",
      "Best of BOTH: 112.77%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.196600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.160000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.280000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.248000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.160000  lift=-18.62%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.460000  lift=133.98%\n",
      "Best of BOTH: 133.98%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.192000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.222000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=79.37%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.222000  lift=65.92%\n",
      "Best of BOTH: 79.37%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.148600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.224000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.112000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.224000  lift=50.74%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-35.40%\n",
      "Best of BOTH: 50.74%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 87\n",
      "Average overall score (all features): 0.105747\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=4     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 10    -> count=8     avg_overall=0.180000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=9     avg_overall=0.060000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=4    avg_overall=0.300000  lift=183.70%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.108000  lift=2.13%\n",
      "Best of BOTH: 183.70%  (direction=UP) | count=4\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and best-of-both)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=30   avg_lift=18.57%\n",
      "TOPK_UP= 2    : N=30   avg_lift=4.81%\n",
      "TOPK_UP= 5    : N=30   avg_lift=14.63%\n",
      "TOPK_UP= 10   : N=30   avg_lift=-4.96%\n",
      "\n",
      "Per-level average lift across SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=30   avg_lift=-80.04%\n",
      "TOPK_DOWN= 2  : N=30   avg_lift=-59.77%\n",
      "TOPK_DOWN= 5  : N=30   avg_lift=-3.11%\n",
      "TOPK_DOWN= 10 : N=30   avg_lift=1.97%\n",
      "\n",
      "--- BEST (per SAE) summaries (ALL) ---\n",
      "UP   : SAEs with positive lift: 21 / 30 (70.00%)\n",
      "      Average BEST lift across SAEs (UP): 98.66%\n",
      "DOWN : SAEs with positive lift: 20 / 30 (66.67%)\n",
      "      Average BEST lift across SAEs (DOWN): 38.89%\n",
      "BOTH : SAEs with positive lift: 26 / 30 (86.67%)\n",
      "Base steering score across SAEs: 0.133058\n",
      "After selection steering score across SAEs (mean of per-SAE after): 0.307533\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 136.30%\n",
      "      Average selected feature count per SAE (Best of UP or DOWN): 4.17\n",
      "\n",
      "================================================================================\n",
      "SAEs flagged as NON-STEERING by the configured criteria\n",
      "- Criteria:\n",
      "  1) max selected count across all levels/directions < 5\n",
      "  2) best-of-both lift <= 0.00%\n",
      "  3) levels achieving count>=5 across UP+DOWN < 2\n",
      "--------------------------------------------------------------------------------\n",
      "[NON-STEERING] gated_49\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-9.774436090225617)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-77.44360902255639  best_down_lift=-9.774436090225617  best_of_both=-9.774436090225617\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] gated_948\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-6.614785992217924)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-6.614785992217924  best_down_lift=-6.614785992217924  best_of_both=-6.614785992217924\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] jump_relu_165\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-14.715719063545174)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-14.715719063545174  best_down_lift=-19.73244147157193  best_of_both=-14.715719063545174\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] jump_relu_538\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-10.313901345291507)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-10.313901345291507  best_down_lift=-19.282511210762365  best_of_both=-10.313901345291507\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "\n",
      "================================================================================\n",
      "SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across QUALIFIED SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=26   avg_lift=36.82%\n",
      "TOPK_UP= 2    : N=26   avg_lift=20.93%\n",
      "TOPK_UP= 5    : N=26   avg_lift=25.23%\n",
      "TOPK_UP= 10   : N=26   avg_lift=2.00%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=26   avg_lift=-76.97%\n",
      "TOPK_DOWN= 2  : N=26   avg_lift=-53.58%\n",
      "TOPK_DOWN= 5  : N=26   avg_lift=-0.42%\n",
      "TOPK_DOWN= 10 : N=26   avg_lift=5.30%\n",
      "\n",
      "--- BEST (per SAE) summaries (QUALIFIED) ---\n",
      "UP   : SAEs with positive lift: 21 / 26 (80.77%)\n",
      "      Average BEST lift across SAEs (UP): 118.03%\n",
      "DOWN : SAEs with positive lift: 20 / 26 (76.92%)\n",
      "      Average BEST lift across SAEs (DOWN): 47.00%\n",
      "BOTH : SAEs with positive lift: 26 / 26 (100.00%)\n",
      "Base steering score across SAEs: 0.137452\n",
      "After selection steering score across SAEs (mean of per-SAE after): 0.340462\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 158.86%\n",
      "      Average selected feature count per SAE (Best of UP or DOWN): 3.65\n",
      "\n",
      "================================================================================\n",
      "STEERING RESULTS FOR QUALIFIED SAEs (best level per SAE)\n",
      "--------------------------------------------------------------------------------\n",
      "[batch_topk_160] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.420000 | lift=188.86%\n",
      "[batch_topk_320] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=292.16%\n",
      "[batch_topk_50] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.208000 | lift=37.38%\n",
      "[batch_topk_520] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.610000 | lift=419.59%\n",
      "[batch_topk_80] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.352000 | lift=125.35%\n",
      "[batch_topk_820] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.960000 | lift=803.95%\n",
      "[gated_148] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.360000 | lift=210.88%\n",
      "[gated_340] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.388000 | lift=153.26%\n",
      "[gated_547] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.384000 | lift=187.00%\n",
      "[gated_78] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.240000 | lift=170.27%\n",
      "[jump_relu_330] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=127.70%\n",
      "[jump_relu_52] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=36.52%\n",
      "[jump_relu_779] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.220000 | lift=84.25%\n",
      "[jump_relu_83] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.460000 | lift=157.27%\n",
      "[standard_april_update_156] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.184000 | lift=1.66%\n",
      "[standard_april_update_309] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.190000 | lift=44.60%\n",
      "[standard_april_update_507] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.312000 | lift=122.22%\n",
      "[standard_april_update_54] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.300000 | lift=99.47%\n",
      "[standard_april_update_733] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=240.43%\n",
      "[standard_april_update_99] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.120000 | lift=9.29%\n",
      "[topk_160] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=57.69%\n",
      "[topk_320] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.240000 | lift=112.77%\n",
      "[topk_50] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.460000 | lift=133.98%\n",
      "[topk_520] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=79.37%\n",
      "[topk_80] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.224000 | lift=50.74%\n",
      "[topk_820] best_dir=UP    | level=TOPK_UP= 5   | count=4    | avg_overall=0.300000 | lift=183.70%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "import numpy as np\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots (Gemma 2 2B, layer 12)\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_2b_it/layer12\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_2b/layer12\"\n",
    "\n",
    "# --------------------------------------------------------------------\n",
    "# Selection levels use QUANTILES and/or TOP-K instead of absolute cuts\n",
    "# --------------------------------------------------------------------\n",
    "# If you want both strategies, set both to True. If you want only one,\n",
    "# set the other to False.\n",
    "USE_QUANTILES = False\n",
    "# Upper-tail quantiles for UP (delta_confidence high end). For DOWN we mirror to lower-tail.\n",
    "# Example: 0.99 means \"select features with delta_confidence >= 99th percentile\" (UP)\n",
    "# and \"select features with delta_confidence <= 1st percentile\" (DOWN).\n",
    "QUANTILES: List[float] = [0.99, 0.95, 0.90, 0.80]\n",
    "\n",
    "USE_TOPK = True\n",
    "# Top-K sizes (by magnitude in the corresponding direction).\n",
    "# For UP: take K largest delta_confidence; for DOWN: take K most negative delta_confidence.\n",
    "TOPK_LIST: List[int] = [1, 2, 5, 10]\n",
    "\n",
    "# ---- Non-steering detection (tunable) ----\n",
    "# A SAE is flagged as NON-STEERING if ANY of the following holds:\n",
    "#   1) max selected count across all levels/directions < MIN_SELECTION_COUNT\n",
    "#   2) best-of-both lift <= MIN_BEST_LIFT\n",
    "#   3) number of levels (across UP+DOWN) with count >= MIN_SELECTION_COUNT < MIN_LEVELS_HIT\n",
    "MIN_SELECTION_COUNT   = 5     # require at least this many selected features at ANY level\n",
    "MIN_BEST_LIFT        = 0.0    # require best-of-both lift strictly greater than this (e.g., > 0.0)\n",
    "MIN_LEVELS_HIT       = 2      # how many levels achieve count >= MIN_SELECTION_COUNT\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return float(item[\"holdout\"][\"mean\"][\"overall\"])\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "\n",
    "    Note: We DO NOT drop 0.0 overall values; they are valid and part of the baseline.\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s  # keep zeros\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def build_delta_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: delta_confidence} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"delta_confidence\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"delta_confidence\"])\n",
    "            except Exception:\n",
    "                pass\n",
    "    return out\n",
    "\n",
    "\n",
    "def avg_for_selected(eval_data: Dict[str, Any], selected_ids: List[str]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - count of selected features that also have 'overall' in eval_data\n",
    "      - average 'overall' over those features (0.0 if count=0)\n",
    "    \"\"\"\n",
    "    vals: List[float] = []\n",
    "    for fid in selected_ids:\n",
    "        s = get_overall_from_eval_item(eval_data.get(fid, {}))\n",
    "        if s is not None:\n",
    "            vals.append(s)  # keep zeros\n",
    "    n = len(vals)\n",
    "    avg = (sum(vals) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection levels (Quantiles / Top-K)\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_for_up(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build UP (high end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles: label like 'Q>=0.95'\n",
    "    - Top-K:     label like 'TOPK_UP= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (upper tail): select v >= quantile(q)\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            cut = float(np.quantile(vals, q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] >= cut]\n",
    "            levels.append((f\"Q>= {q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (largest K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_up = sorted(fids, key=lambda x: delta_map[x], reverse=True)\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_up[:max(0, min(k, len(sorted_up)))]\n",
    "            levels.append((f\"TOPK_UP= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_down(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build DOWN (negative end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles (lower tail): label like 'Q<=0.05' meaning v <= quantile(0.05)\n",
    "      (Mirroring an upper-tail q by using (1 - q) for the lower tail.)\n",
    "    - Top-K:     label like 'TOPK_DOWN= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (lower tail): mirror\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            low_q = 1.0 - q\n",
    "            low_cut = float(np.quantile(vals, low_q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] <= low_cut]\n",
    "            levels.append((f\"Q<= {low_q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (most negative K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_down = sorted(fids, key=lambda x: delta_map[x])  # ascending => most negative first\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_down[:max(0, min(k, len(sorted_down)))]\n",
    "            levels.append((f\"TOPK_DOWN= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str,\n",
    "    order_up_labels: List[str],\n",
    "    order_down_labels: List[str],\n",
    ") -> Tuple[\n",
    "    Dict[str, float],   # per-level lifts (UP)      label -> lift\n",
    "    Dict[str, float],   # per-level lifts (DOWN)    label -> lift\n",
    "    Optional[Tuple[str, int, float, float]],  # best_up: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_down: (label, count, avg, lift)\n",
    "    Optional[float],    # best_of_both lift\n",
    "    Optional[int],      # best_of_both count\n",
    "    Dict[str, int],     # per-level counts (UP)\n",
    "    Dict[str, int],     # per-level counts (DOWN)\n",
    "    float,              # base_avg_overall for this SAE\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, None, None, None, None, {}, {}, 0.0\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping selection levels.)\")\n",
    "        return {}, {}, None, None, None, None, {}, {}, avg_overall_all\n",
    "\n",
    "    # Build delta map\n",
    "    delta_map = build_delta_map(entropy_data)\n",
    "\n",
    "    # Compose selection levels for UP & DOWN\n",
    "    up_levels   = selection_levels_for_up(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    down_levels = selection_levels_for_down(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "\n",
    "    # Keep maps for lifts/counts keyed by label for deterministic aggregation/printing\n",
    "    per_level_lifts_up: Dict[str, float] = {}\n",
    "    per_level_counts_up: Dict[str, int] = {}\n",
    "    per_level_lifts_down: Dict[str, float] = {}\n",
    "    per_level_counts_down: Dict[str, int] = {}\n",
    "\n",
    "    # ---- UP section ----\n",
    "    print(\"\\n=== Selection levels (UP: high delta_confidence) ===\")\n",
    "    best_up: Optional[Tuple[str, int, float, float]] = None  # (label, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    # Ensure printing order follows order_up_labels; fallback to appending any missing labels\n",
    "    up_levels_map = {lab: ids for lab, ids in up_levels}\n",
    "    up_labels_ordered = [lab for lab in order_up_labels if lab in up_levels_map] + \\\n",
    "                        [lab for lab in up_levels_map.keys() if lab not in order_up_labels]\n",
    "\n",
    "    for label in up_labels_ordered:\n",
    "        selected = up_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_up[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_up[label] = lift\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (label, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- DOWN section ----\n",
    "    print(\"\\n=== Selection levels (DOWN: low/negative delta_confidence) ===\")\n",
    "    best_down: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    down_levels_map = {lab: ids for lab, ids in down_levels}\n",
    "    down_labels_ordered = [lab for lab in order_down_labels if lab in down_levels_map] + \\\n",
    "                          [lab for lab in down_levels_map.keys() if lab not in order_down_labels]\n",
    "\n",
    "    for label in down_labels_ordered:\n",
    "        selected = down_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_down[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_down[label] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (label, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (per SAE)\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    best_of_both_count: Optional[int] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        if best_up[3] >= best_down[3]:\n",
    "            best_of_both_lift = best_up[3]\n",
    "            best_of_both_count = best_up[1]\n",
    "            direction = \"UP\"\n",
    "        else:\n",
    "            best_of_both_lift = best_down[3]\n",
    "            best_of_both_count = best_down[1]\n",
    "            direction = \"DOWN\"\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "        best_of_both_count = best_up[1]\n",
    "        direction = \"UP\"\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "        best_of_both_count = best_down[1]\n",
    "        direction = \"DOWN\"\n",
    "    else:\n",
    "        direction = \"N/A\"\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best levels (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP   : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : level={best_up[0]:<12} | count={best_up[1]:<4} avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : level={best_down[0]:<12} | count={best_down[1]:<4} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH: N/A\")\n",
    "    else:\n",
    "        print(f\"Best of BOTH: {best_of_both_lift:.2f}%  (direction={direction}) | count={best_of_both_count}\")\n",
    "\n",
    "    return (\n",
    "        per_level_lifts_up,\n",
    "        per_level_lifts_down,\n",
    "        best_up,\n",
    "        best_down,\n",
    "        best_of_both_lift,\n",
    "        best_of_both_count,\n",
    "        per_level_counts_up,\n",
    "        per_level_counts_down,\n",
    "        avg_overall_all,\n",
    "    )\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Build the global (ordered) label lists we will use for consistent printing/aggregation\n",
    "    order_up_labels: List[str] = []\n",
    "    order_down_labels: List[str] = []\n",
    "    if USE_QUANTILES and QUANTILES:\n",
    "        for q in sorted(set(QUANTILES), reverse=True):\n",
    "            order_up_labels.append(f\"Q>= {q:.2f}\")\n",
    "            order_down_labels.append(f\"Q<= {1.0 - q:.2f}\")\n",
    "    if USE_TOPK and TOPK_LIST:\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            order_up_labels.append(f\"TOPK_UP= {k}\")\n",
    "            order_down_labels.append(f\"TOPK_DOWN= {k}\")\n",
    "\n",
    "    # Across-SAEs per-level aggregations (unfiltered)\n",
    "    def init_agg(levels: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {lab: {\"sum\": 0.0, \"count\": 0.0} for lab in levels}\n",
    "\n",
    "    across_up = init_agg(order_up_labels)\n",
    "    across_down = init_agg(order_down_labels)\n",
    "\n",
    "    # Per-SAE best stats (unfiltered)\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "    best_both_counts: List[int] = []\n",
    "    pos_up = pos_down = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_both = 0\n",
    "\n",
    "    # Keep per-SAE records for later filtered summary\n",
    "    sae_records: List[Dict[str, Any]] = []\n",
    "    non_steering: List[Tuple[str, List[str], Dict[str, Any]]] = []\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        (\n",
    "            per_up,\n",
    "            per_down,\n",
    "            best_up,\n",
    "            best_down,\n",
    "            best_both_lift,\n",
    "            best_both_count,\n",
    "            cnts_up,\n",
    "            cnts_down,\n",
    "            base_avg,\n",
    "        ) = process_one_sae(sae_name, order_up_labels, order_down_labels)\n",
    "\n",
    "        # Save record\n",
    "        sae_records.append(\n",
    "            {\n",
    "                \"name\": sae_name,\n",
    "                \"per_up\": per_up,\n",
    "                \"per_down\": per_down,\n",
    "                \"best_up\": best_up,\n",
    "                \"best_down\": best_down,\n",
    "                \"best_both_lift\": best_both_lift,\n",
    "                \"best_both_count\": best_both_count,\n",
    "                \"cnts_up\": cnts_up,\n",
    "                \"cnts_down\": cnts_down,\n",
    "                \"base_avg\": base_avg,\n",
    "            }\n",
    "        )\n",
    "\n",
    "        # Aggregate per-level lifts (UP/DOWN) for unfiltered summary\n",
    "        for lab, lift in per_up.items():\n",
    "            if lab not in across_up:\n",
    "                across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_up[lab][\"sum\"] += lift\n",
    "            across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in per_down.items():\n",
    "            if lab not in across_down:\n",
    "                across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_down[lab][\"sum\"] += lift\n",
    "            across_down[lab][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction BEST (unfiltered)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if (best_both_lift is not None) and isinstance(best_both_lift, float):\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both_lift)\n",
    "            # best_both_count can be None only if lift is None; safe to guard anyway\n",
    "            if isinstance(best_both_count, int):\n",
    "                best_both_counts.append(best_both_count)\n",
    "            if best_both_lift > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "        # ---------------------------\n",
    "        # Non-steering detection\n",
    "        # ---------------------------\n",
    "        reasons: List[str] = []\n",
    "        max_count_up = max(cnts_up.values(), default=0)\n",
    "        max_count_down = max(cnts_down.values(), default=0)\n",
    "        max_count_both = max(max_count_up, max_count_down)\n",
    "\n",
    "        # How many levels hit MIN_SELECTION_COUNT (across both directions)\n",
    "        hits_up = sum(1 for c in cnts_up.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_down = sum(1 for c in cnts_down.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_both = hits_up + hits_down\n",
    "\n",
    "        # Best-of-both lift (already computed)\n",
    "        local_best_of_both_lift = best_both_lift\n",
    "\n",
    "        # Condition 1: insufficient selected features at any level\n",
    "        if max_count_both < MIN_SELECTION_COUNT:\n",
    "            reasons.append(f\"insufficient selected features: max_count={max_count_both} < {MIN_SELECTION_COUNT}\")\n",
    "\n",
    "        # Condition 2: no positive (or required) lift anywhere\n",
    "        if (local_best_of_both_lift is None) or (local_best_of_both_lift <= MIN_BEST_LIFT):\n",
    "            reasons.append(\n",
    "                f\"no level yields lift > {MIN_BEST_LIFT:.2f}% (best_of_both={local_best_of_both_lift if local_best_of_both_lift is not None else 'N/A'})\"\n",
    "            )\n",
    "\n",
    "        # Condition 3: stability across levels is poor\n",
    "        if hits_both < MIN_LEVELS_HIT:\n",
    "            reasons.append(\n",
    "                f\"unstable coverage: levels_with_count>={MIN_SELECTION_COUNT} = {hits_both} < {MIN_LEVELS_HIT}\"\n",
    "            )\n",
    "\n",
    "        if len(reasons) > 0:\n",
    "            non_steering.append((\n",
    "                sae_name,\n",
    "                reasons,\n",
    "                {\n",
    "                    \"max_count_up\": max_count_up,\n",
    "                    \"max_count_down\": max_count_down,\n",
    "                    \"best_up_lift\": (best_up[3] if best_up else None),\n",
    "                    \"best_down_lift\": (best_down[3] if best_down else None),\n",
    "                    \"best_of_both_lift\": local_best_of_both_lift,\n",
    "                    \"hits_up\": hits_up,\n",
    "                    \"hits_down\": hits_down,\n",
    "                }\n",
    "            ))\n",
    "\n",
    "    # =================================================================================\n",
    "    # Unfiltered summary across ALL SAEs (baseline reference)\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and best-of-both)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-level averages: UP\n",
    "    print(\"Per-level average lift across SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: DOWN\n",
    "    print(\"\\nPer-level average lift across SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Compute base across ALL SAEs (fixed baseline definition: average of each SAE's all-feature mean)\n",
    "    all_base_vals = [rec[\"base_avg\"] for rec in sae_records]\n",
    "    base_across_all = (sum(all_base_vals) / len(all_base_vals)) if all_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (ALL)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (ALL) ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        avg_both_best_all = 0.0\n",
    "        avg_both_count_all = 0.0\n",
    "    else:\n",
    "        avg_both_best_all = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        avg_both_count_all = (sum(best_both_counts) / len(best_both_counts)) if best_both_counts else 0.0\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "\n",
    "        # ---- NEW: mean of per-SAE after ----\n",
    "        after_list_all = []\n",
    "        for rec in sae_records:\n",
    "            lift = rec.get(\"best_both_lift\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if isinstance(lift, float):\n",
    "                after_list_all.append(base * (1.0 + lift / 100.0))\n",
    "        after_mean_all = (sum(after_list_all) / len(after_list_all)) if after_list_all else 0.0\n",
    "\n",
    "        print(f\"Base steering score across SAEs: {base_across_all:.6f}\")\n",
    "        print(f\"After selection steering score across SAEs (mean of per-SAE after): {after_mean_all:.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {avg_both_best_all:.2f}%\")\n",
    "        print(f\"      Average selected feature count per SAE (Best of UP or DOWN): {avg_both_count_all:.2f}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Non-steering report\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SAEs flagged as NON-STEERING by the configured criteria\")\n",
    "    print(\"- Criteria:\")\n",
    "    print(f\"  1) max selected count across all levels/directions < {MIN_SELECTION_COUNT}\")\n",
    "    print(f\"  2) best-of-both lift <= {MIN_BEST_LIFT:.2f}%\")\n",
    "    print(f\"  3) levels achieving count>={MIN_SELECTION_COUNT} across UP+DOWN < {MIN_LEVELS_HIT}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    non_names = set()\n",
    "    if not non_steering:\n",
    "        print(\"All SAEs pass the steering capability criteria.\")\n",
    "    else:\n",
    "        for name, reasons, stats in non_steering:\n",
    "            non_names.add(name)\n",
    "            print(f\"[NON-STEERING] {name}\")\n",
    "            print(f\"  Reasons:\")\n",
    "            for r in reasons:\n",
    "                print(f\"    - {r}\")\n",
    "            print(f\"  Stats: max_count_up={stats['max_count_up']}  max_count_down={stats['max_count_down']}\")\n",
    "            print(f\"         best_up_lift={stats['best_up_lift']}  best_down_lift={stats['best_down_lift']}  best_of_both={stats['best_of_both_lift']}\")\n",
    "            print(f\"         levels_hit(up)={stats['hits_up']}  levels_hit(down)={stats['hits_down']}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # FILTERED summary across STEERING-QUALIFIED SAEs only\n",
    "    # =================================================================================\n",
    "    qualified = [rec for rec in sae_records if rec[\"name\"] not in non_names]\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    if not qualified:\n",
    "        print(\"No SAE remains after filtering; cannot compute qualified summary.\")\n",
    "        return\n",
    "\n",
    "    # Per-level averages across qualified\n",
    "    def init_agg_like(template_keys: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {k: {\"sum\": 0.0, \"count\": 0.0} for k in template_keys}\n",
    "\n",
    "    q_across_up = init_agg_like(order_up_labels)\n",
    "    q_across_down = init_agg_like(order_down_labels)\n",
    "\n",
    "    q_best_up_lifts: List[float] = []\n",
    "    q_best_down_lifts: List[float] = []\n",
    "    q_best_both_lifts: List[float] = []\n",
    "    q_best_both_counts: List[int] = []\n",
    "    q_pos_up = q_pos_down = q_pos_both = 0\n",
    "    q_saes_with_up = q_saes_with_down = q_saes_with_both = 0\n",
    "\n",
    "    for rec in qualified:\n",
    "        # per-level lifts\n",
    "        for lab, lift in rec[\"per_up\"].items():\n",
    "            if lab not in q_across_up:\n",
    "                q_across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_up[lab][\"sum\"] += lift\n",
    "            q_across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_down\"].items():\n",
    "            if lab not in q_across_down:\n",
    "                q_across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_down[lab][\"sum\"] += lift\n",
    "            q_across_down[lab][\"count\"] += 1\n",
    "\n",
    "        # best per-direction / best-of-both\n",
    "        if rec[\"best_up\"] is not None:\n",
    "            q_saes_with_up += 1\n",
    "            q_best_up_lifts.append(rec[\"best_up\"][3])\n",
    "            if rec[\"best_up\"][3] > 0:\n",
    "                q_pos_up += 1\n",
    "        if rec[\"best_down\"] is not None:\n",
    "            q_saes_with_down += 1\n",
    "            q_best_down_lifts.append(rec[\"best_down\"][3])\n",
    "            if rec[\"best_down\"][3] > 0:\n",
    "                q_pos_down += 1\n",
    "\n",
    "        if (rec[\"best_both_lift\"] is not None) and isinstance(rec[\"best_both_lift\"], float):\n",
    "            q_saes_with_both += 1\n",
    "            q_best_both_lifts.append(rec[\"best_both_lift\"])\n",
    "            if isinstance(rec[\"best_both_count\"], int):\n",
    "                q_best_both_counts.append(rec[\"best_both_count\"])\n",
    "            if rec[\"best_both_lift\"] > 0:\n",
    "                q_pos_both += 1\n",
    "\n",
    "    # Print per-level averages (qualified)\n",
    "    print(\"Per-level average lift across QUALIFIED SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(q_across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(q_across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Base steering score across QUALIFIED SAEs (same definition as ALL, but over the subset)\n",
    "    q_base_vals = [rec[\"base_avg\"] for rec in qualified]\n",
    "    base_across_qualified = (sum(q_base_vals) / len(q_base_vals)) if q_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (qualified)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (QUALIFIED) ---\")\n",
    "    if q_saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_up_best = (sum(q_best_up_lifts) / len(q_best_up_lifts)) if q_best_up_lifts else 0.0\n",
    "        q_pct_up_pos = (q_pos_up / q_saes_with_up) * 100.0 if q_saes_with_up > 0 else 0.0\n",
    "        print(f\"UP   : SAEs with positive lift: {q_pos_up} / {q_saes_with_up} ({q_pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {q_avg_up_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_down_best = (sum(q_best_down_lifts) / len(q_best_down_lifts)) if q_best_down_lifts else 0.0\n",
    "        q_pct_down_pos = (q_pos_down / q_saes_with_down) * 100.0 if q_saes_with_down > 0 else 0.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {q_pos_down} / {q_saes_with_down} ({q_pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {q_avg_down_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        q_avg_both_best = 0.0\n",
    "        q_avg_both_count = 0.0\n",
    "    else:\n",
    "        q_avg_both_best = (sum(q_best_both_lifts) / len(q_best_both_lifts)) if q_best_both_lifts else 0.0\n",
    "        q_avg_both_count = (sum(q_best_both_counts) / len(q_best_both_counts)) if q_best_both_counts else 0.0\n",
    "        q_pct_both_pos = (q_pos_both / q_saes_with_both) * 100.0 if q_saes_with_both > 0 else 0.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {q_pos_both} / {q_saes_with_both} ({q_pct_both_pos:.2f}%)\")\n",
    "\n",
    "        # ---- NEW: mean of per-SAE after (qualified) ----\n",
    "        q_after_list = []\n",
    "        for rec in qualified:\n",
    "            lift = rec.get(\"best_both_lift\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if isinstance(lift, float):\n",
    "                q_after_list.append(base * (1.0 + lift / 100.0))\n",
    "        q_after_mean = (sum(q_after_list) / len(q_after_list)) if q_after_list else 0.0\n",
    "\n",
    "        print(f\"Base steering score across SAEs: {base_across_qualified:.6f}\")\n",
    "        print(f\"After selection steering score across SAEs (mean of per-SAE after): {q_after_mean:.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {q_avg_both_best:.2f}%\")\n",
    "        print(f\"      Average selected feature count per SAE (Best of UP or DOWN): {q_avg_both_count:.2f}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Per-qualified-SAE steering result details\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"STEERING RESULTS FOR QUALIFIED SAEs (best level per SAE)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for rec in qualified:\n",
    "        name = rec[\"name\"]\n",
    "        best_up = rec[\"best_up\"]\n",
    "        best_down = rec[\"best_down\"]\n",
    "\n",
    "        best_dir = None\n",
    "        best_tuple = None  # (label, count, avg, lift)\n",
    "        if best_up is not None and best_down is not None:\n",
    "            best_dir = \"UP\" if best_up[3] >= best_down[3] else \"DOWN\"\n",
    "            best_tuple = best_up if best_up[3] >= best_down[3] else best_down\n",
    "        elif best_up is not None:\n",
    "            best_dir = \"UP\"\n",
    "            best_tuple = best_up\n",
    "        elif best_down is not None:\n",
    "            best_dir = \"DOWN\"\n",
    "            best_tuple = best_down\n",
    "\n",
    "        if best_tuple is None:\n",
    "            print(f\"[{name}] No valid best selection found.\")\n",
    "        else:\n",
    "            lab, cnt, avg_overall, lift = best_tuple\n",
    "            print(\n",
    "                f\"[{name}] best_dir={best_dir:<5} | level={lab:<12} | count={cnt:<4} | avg_overall={avg_overall:.6f} | lift={lift:.2f}%\"\n",
    "            )\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "ae8d2884",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.145400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.420000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.312000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.210000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.192000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.146000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.160000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.180000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.163000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.420000  lift=188.86%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.160000  lift=10.04%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.180000  lift=23.80%\n",
      "Best of BOTH (UP/DOWN): 188.86%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.122400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.166000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.168000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.084000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.260000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.130000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.089000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=292.16%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.168000  lift=37.25%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.300000  lift=145.10%\n",
      "Best of BOTH (UP/DOWN): 292.16%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.151400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.068000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.107000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.176000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.208000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.158000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.096000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.072000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.104000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.136000  lift=-10.17%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.208000  lift=37.38%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.480000  lift=217.04%\n",
      "Best of BOTH (UP/DOWN): 37.38%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.117400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.540000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.610000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.304000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.220000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.173000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.111000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.102000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.099000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.610000  lift=419.59%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.144000  lift=22.66%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=104.43%\n",
      "Best of BOTH (UP/DOWN): 419.59%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.156200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.352000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.236000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.133000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.150000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.099000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.560000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.584000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.502000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.287000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.352000  lift=125.35%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.300000  lift=92.06%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.584000  lift=273.88%\n",
      "Best of BOTH (UP/DOWN): 125.35%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.288000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.168000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.147000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.030000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.066000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.000000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.120000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.960000  lift=803.95%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.066000  lift=-37.85%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.120000  lift=12.99%\n",
      "Best of BOTH (UP/DOWN): 803.95%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_148\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.115800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.184000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.188000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.166000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.088000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.136000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.107000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.126000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.138000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.360000  lift=210.88%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.136000  lift=17.44%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.144000  lift=24.35%\n",
      "Best of BOTH (UP/DOWN): 210.88%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_340\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.153200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.054000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.138000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.242000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.169000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.168000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.204000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.198000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.138000  lift=-9.92%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.388000  lift=153.26%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.204000  lift=33.16%\n",
      "Best of BOTH (UP/DOWN): 153.26%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_49\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.024000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.123000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.060000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.108000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.132000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.123000  lift=15.60%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-9.77%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.132000  lift=24.06%\n",
      "Best of BOTH (UP/DOWN): 15.60%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_547\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.183000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.384000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.288000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.183000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.054000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.111000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=79.37%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.384000  lift=187.00%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.111000  lift=-17.04%\n",
      "Best of BOTH (UP/DOWN): 187.00%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_78\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.088800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.108000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.117000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.075000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.780000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.390000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.078000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.111000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.156000  lift=75.68%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=170.27%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.780000  lift=778.38%\n",
      "Best of BOTH (UP/DOWN): 170.27%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_948\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.102800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.168000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.060000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.102000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.126000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.168000  lift=63.42%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-6.61%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=133.46%\n",
      "Best of BOTH (UP/DOWN): 63.42%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_165\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.099000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.123000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.054000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.081000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.102000  lift=-14.72%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.123000  lift=2.84%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=100.67%\n",
      "Best of BOTH (UP/DOWN): 2.84%  (direction=DOWN) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_330\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.105400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.051000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.132000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.054000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.117000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=127.70%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.144000  lift=36.62%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=127.70%\n",
      "Best of BOTH (UP/DOWN): 127.70%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_52\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.175800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.160000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.080000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.150000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.096000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.186000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=36.52%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=36.52%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.186000  lift=5.80%\n",
      "Best of BOTH (UP/DOWN): 36.52%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_538\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.089200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.080000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.040000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.092000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.072000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.136000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.068000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.082000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.092000  lift=3.14%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.072000  lift=-19.28%\n",
      "Best MID  : level=TOPK_MID= 2  | count=2    avg_overall=0.240000  lift=169.06%\n",
      "Best of BOTH (UP/DOWN): 3.14%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_779\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.060000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.069000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.176000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.220000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.206000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.048000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.048000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.120000  lift=0.50%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.220000  lift=84.25%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.048000  lift=-59.80%\n",
      "Best of BOTH (UP/DOWN): 84.25%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_83\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.178800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.084000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.242000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.205000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.220000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.136000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.116000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.203000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.096000  lift=-46.31%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.460000  lift=157.27%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=34.23%\n",
      "Best of BOTH (UP/DOWN): 157.27%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_156\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.181000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.184000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.176000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.168000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.360000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.252000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.228000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.184000  lift=1.66%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.168000  lift=-7.18%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.360000  lift=98.90%\n",
      "Best of BOTH (UP/DOWN): 1.66%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_309\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.131400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.190000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.149000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.118000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.146000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.174000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.126000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.190000  lift=44.60%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.146000  lift=11.11%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.174000  lift=32.42%\n",
      "Best of BOTH (UP/DOWN): 44.60%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_507\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.140400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.312000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.254000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.259000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.040000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.068000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.120000  lift=-14.53%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.312000  lift=122.22%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.068000  lift=-51.57%\n",
      "Best of BOTH (UP/DOWN): 122.22%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_54\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.150400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.228000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.114000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.093000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.175000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=1.200000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.480000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.438000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.267000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.300000  lift=99.47%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.175000  lift=16.36%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=1.200000  lift=697.87%\n",
      "Best of BOTH (UP/DOWN): 99.47%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_733\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.141000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.408000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.228000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.141000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.174000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.135000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.192000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.120000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.168000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=240.43%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.174000  lift=23.40%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=70.21%\n",
      "Best of BOTH (UP/DOWN): 240.43%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_99\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.109800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.054000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.063000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.276000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.210000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.147000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.120000  lift=9.29%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.063000  lift=-42.62%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.276000  lift=151.37%\n",
      "Best of BOTH (UP/DOWN): 9.29%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.152200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.092000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.130000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.144000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.108000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.096000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.094000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=57.69%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.240000  lift=57.69%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.096000  lift=-36.93%\n",
      "Best of BOTH (UP/DOWN): 57.69%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.112800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.126000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.096000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.240000  lift=112.77%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.126000  lift=11.70%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.096000  lift=-14.89%\n",
      "Best of BOTH (UP/DOWN): 112.77%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.196600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.160000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.248000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.280000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.248000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.211000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.096000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.092000\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.106000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.248000  lift=26.14%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.460000  lift=133.98%\n",
      "Best MID  : level=TOPK_MID= 20 | count=20   avg_overall=0.106000  lift=-46.08%\n",
      "Best of BOTH (UP/DOWN): 133.98%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.192000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.123000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.222000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.183000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.264000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.186000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.123000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=79.37%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.222000  lift=65.92%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.264000  lift=97.31%\n",
      "Best of BOTH (UP/DOWN): 79.37%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.148600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.224000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.112000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.153000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.480000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.192000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.236000 [> overall]\n",
      "TOPK_MID= 20   -> count=20    avg_overall=0.190000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.224000  lift=50.74%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-35.40%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.960000  lift=546.03%\n",
      "Best of BOTH (UP/DOWN): 50.74%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 87\n",
      "Average overall score (all features): 0.105747\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=4     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 10    -> count=8     avg_overall=0.180000 [> overall]\n",
      "TOPK_UP= 20    -> count=18    avg_overall=0.110000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=9     avg_overall=0.060000\n",
      "TOPK_DOWN= 20  -> count=15    avg_overall=0.129333 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=4     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=9     avg_overall=0.026667\n",
      "TOPK_MID= 20   -> count=18    avg_overall=0.070000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=4    avg_overall=0.300000  lift=183.70%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=15   avg_overall=0.129333  lift=22.30%\n",
      "Best MID  : level=TOPK_MID= 20 | count=18   avg_overall=0.070000  lift=-33.80%\n",
      "Best of BOTH (UP/DOWN): 183.70%  (direction=UP) | count=4\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and control MID)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=30   avg_lift=18.57%\n",
      "TOPK_UP= 2    : N=30   avg_lift=4.81%\n",
      "TOPK_UP= 5    : N=30   avg_lift=14.63%\n",
      "TOPK_UP= 10   : N=30   avg_lift=-4.96%\n",
      "TOPK_UP= 20   : N=30   avg_lift=-0.93%\n",
      "\n",
      "Per-level average lift across SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=30   avg_lift=-80.04%\n",
      "TOPK_DOWN= 2  : N=30   avg_lift=-59.77%\n",
      "TOPK_DOWN= 5  : N=30   avg_lift=-3.11%\n",
      "TOPK_DOWN= 10 : N=30   avg_lift=1.97%\n",
      "TOPK_DOWN= 20 : N=30   avg_lift=-1.25%\n",
      "\n",
      "Per-level average lift across SAEs (MID levels, control):\n",
      "TOPK_MID= 1   : N=30   avg_lift=44.14%\n",
      "TOPK_MID= 2   : N=30   avg_lift=-0.66%\n",
      "TOPK_MID= 5   : N=30   avg_lift=13.76%\n",
      "TOPK_MID= 10  : N=30   avg_lift=-0.84%\n",
      "TOPK_MID= 20  : N=30   avg_lift=1.85%\n",
      "\n",
      "--- BEST (per SAE) summaries (ALL) ---\n",
      "UP   : SAEs with positive lift: 25 / 30 (83.33%)\n",
      "      Average BEST lift across SAEs (UP): 108.43%\n",
      "DOWN : SAEs with positive lift: 23 / 30 (76.67%)\n",
      "      Average BEST lift across SAEs (DOWN): 45.03%\n",
      "MID  : SAEs with positive lift: 23 / 30 (76.67%)\n",
      "      Average BEST lift across SAEs (MID, control): 121.40%\n",
      "BOTH (UP/DOWN): SAEs with positive lift: 30 / 30 (100.00%)\n",
      "\n",
      "--- Comparative steering score (ALL, mean of per-SAE after) ---\n",
      "Base steering score across SAEs:                     0.133058\n",
      "After selection (Best of UP/DOWN) across SAEs:       0.311933\n",
      "After selection (MID control, best per SAE) across:  0.287300\n",
      "Avg BEST lift (UP/DOWN best-of-both):               140.51%   | Avg selected count: 5.83\n",
      "Avg BEST lift (MID control):                         121.40%\n",
      "\n",
      "================================================================================\n",
      "SAEs flagged as NON-STEERING by the configured criteria\n",
      "- Criteria:\n",
      "  1) max selected count across all levels/directions < 5\n",
      "  2) best-of-both lift <= 0.00%\n",
      "  3) levels achieving count>=5 across UP+DOWN < 2\n",
      "- Note: MID is a control and not used for filtering.\n",
      "--------------------------------------------------------------------------------\n",
      "All SAEs pass the steering capability criteria.\n",
      "\n",
      "================================================================================\n",
      "SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across QUALIFIED SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=30   avg_lift=18.57%\n",
      "TOPK_UP= 2    : N=30   avg_lift=4.81%\n",
      "TOPK_UP= 5    : N=30   avg_lift=14.63%\n",
      "TOPK_UP= 10   : N=30   avg_lift=-4.96%\n",
      "TOPK_UP= 20   : N=30   avg_lift=-0.93%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=30   avg_lift=-80.04%\n",
      "TOPK_DOWN= 2  : N=30   avg_lift=-59.77%\n",
      "TOPK_DOWN= 5  : N=30   avg_lift=-3.11%\n",
      "TOPK_DOWN= 10 : N=30   avg_lift=1.97%\n",
      "TOPK_DOWN= 20 : N=30   avg_lift=-1.25%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (MID levels, control):\n",
      "TOPK_MID= 1   : N=30   avg_lift=44.14%\n",
      "TOPK_MID= 2   : N=30   avg_lift=-0.66%\n",
      "TOPK_MID= 5   : N=30   avg_lift=13.76%\n",
      "TOPK_MID= 10  : N=30   avg_lift=-0.84%\n",
      "TOPK_MID= 20  : N=30   avg_lift=1.85%\n",
      "\n",
      "--- BEST (per SAE) summaries (QUALIFIED) ---\n",
      "UP   : SAEs with positive lift: 25 / 30 (83.33%)\n",
      "      Average BEST lift across SAEs (UP): 108.43%\n",
      "DOWN : SAEs with positive lift: 23 / 30 (76.67%)\n",
      "      Average BEST lift across SAEs (DOWN): 45.03%\n",
      "MID  : SAEs with positive lift: 23 / 30 (76.67%)\n",
      "      Average BEST lift across SAEs (MID, control): 121.40%\n",
      "BOTH : SAEs with positive lift: 30 / 30 (100.00%)\n",
      "\n",
      "--- Comparative steering score (QUALIFIED, mean of per-SAE after) ---\n",
      "Base steering score across SAEs:                     0.133058\n",
      "After selection (Best of UP/DOWN) across SAEs:       0.311933\n",
      "After selection (MID control, best per SAE) across:  0.287300\n",
      "      Average BEST lift across SAEs (Best of UP/DOWN): 140.51%\n",
      "      Average selected feature count per SAE (UP/DOWN): 5.83\n",
      "      Average BEST lift across SAEs (MID control):     121.40%\n",
      "\n",
      "================================================================================\n",
      "STEERING RESULTS FOR QUALIFIED SAEs (best levels per SAE)\n",
      "--------------------------------------------------------------------------------\n",
      "[batch_topk_160] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.420000 | lift=188.86%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.180000 | lift=23.80%\n",
      "[batch_topk_320] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=292.16%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.300000 | lift=145.10%\n",
      "[batch_topk_50] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.208000 | lift=37.38%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.480000 | lift=217.04%\n",
      "[batch_topk_520] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.610000 | lift=419.59%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=104.43%\n",
      "[batch_topk_80] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.352000 | lift=125.35%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.584000 | lift=273.88%\n",
      "[batch_topk_820] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.960000 | lift=803.95%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.120000 | lift=12.99%\n",
      "[gated_148] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.360000 | lift=210.88%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.144000 | lift=24.35%\n",
      "[gated_340] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.388000 | lift=153.26%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.204000 | lift=33.16%\n",
      "[gated_49] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.123000 | lift=15.60%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.132000 | lift=24.06%\n",
      "[gated_547] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.384000 | lift=187.00%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.111000 | lift=-17.04%\n",
      "[gated_78] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.240000 | lift=170.27%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.780000 | lift=778.38%\n",
      "[gated_948] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.168000 | lift=63.42%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=133.46%\n",
      "[jump_relu_165] best_dir=DOWN  | level=TOPK_DOWN= 20 | count=20   | avg_overall=0.123000 | lift=2.84%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=100.67%\n",
      "[jump_relu_330] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=127.70%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=127.70%\n",
      "[jump_relu_52] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=36.52%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.186000 | lift=5.80%\n",
      "[jump_relu_538] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.092000 | lift=3.14%\n",
      "         MIDctl  | level=TOPK_MID= 2  | count=2    | avg_overall=0.240000 | lift=169.06%\n",
      "[jump_relu_779] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.220000 | lift=84.25%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.048000 | lift=-59.80%\n",
      "[jump_relu_83] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.460000 | lift=157.27%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=34.23%\n",
      "[standard_april_update_156] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.184000 | lift=1.66%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.360000 | lift=98.90%\n",
      "[standard_april_update_309] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.190000 | lift=44.60%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.174000 | lift=32.42%\n",
      "[standard_april_update_507] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.312000 | lift=122.22%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.068000 | lift=-51.57%\n",
      "[standard_april_update_54] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.300000 | lift=99.47%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=1.200000 | lift=697.87%\n",
      "[standard_april_update_733] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=240.43%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=70.21%\n",
      "[standard_april_update_99] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.120000 | lift=9.29%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.276000 | lift=151.37%\n",
      "[topk_160] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=57.69%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.096000 | lift=-36.93%\n",
      "[topk_320] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.240000 | lift=112.77%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.096000 | lift=-14.89%\n",
      "[topk_50] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.460000 | lift=133.98%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=20   | avg_overall=0.106000 | lift=-46.08%\n",
      "[topk_520] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=79.37%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.264000 | lift=97.31%\n",
      "[topk_80] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.224000 | lift=50.74%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.960000 | lift=546.03%\n",
      "[topk_820] best_dir=UP    | level=TOPK_UP= 5   | count=4    | avg_overall=0.300000 | lift=183.70%\n",
      "         MIDctl  | level=TOPK_MID= 20 | count=18   | avg_overall=0.070000 | lift=-33.80%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "import numpy as np\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots (Gemma 2 2B, layer 12)\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_2b_it/layer12\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_2b/layer12\"\n",
    "\n",
    "# --------------------------------------------------------------------\n",
    "# Selection levels use QUANTILES and/or TOP-K instead of absolute cuts\n",
    "# --------------------------------------------------------------------\n",
    "# If you want both strategies, set both to True. If you want only one,\n",
    "# set the other to False.\n",
    "USE_QUANTILES = False\n",
    "# Upper-tail quantiles for UP (delta_confidence high end). For DOWN we mirror to lower-tail.\n",
    "# Example: 0.99 means \"select features with delta_confidence >= 99th percentile\" (UP)\n",
    "# and \"select features with delta_confidence <= 1st percentile\" (DOWN).\n",
    "QUANTILES: List[float] = [0.99, 0.95, 0.90, 0.80]\n",
    "\n",
    "USE_TOPK = True\n",
    "# Top-K sizes (by magnitude in the corresponding direction).\n",
    "# For UP: take K largest delta_confidence; for DOWN: take K most negative delta_confidence.\n",
    "# NEW (control): MID selects K features whose |delta_confidence| are the smallest (closest to 0).\n",
    "TOPK_LIST: List[int] = [1, 2, 5, 10, 20]\n",
    "\n",
    "# ---- Non-steering detection (tunable) ----\n",
    "# A SAE is flagged as NON-STEERING if ANY of the following holds:\n",
    "#   1) max selected count across all levels/directions < MIN_SELECTION_COUNT\n",
    "#   2) best-of-both lift <= MIN_BEST_LIFT\n",
    "#   3) number of levels (across UP+DOWN) with count >= MIN_SELECTION_COUNT < MIN_LEVELS_HIT\n",
    "# Note: MID is not used in the steering qualification criteria (it's a control).\n",
    "MIN_SELECTION_COUNT   = 5     # require at least this many selected features at ANY level\n",
    "MIN_BEST_LIFT        = 0.0    # require best-of-both lift strictly greater than this (e.g., > 0.0)\n",
    "MIN_LEVELS_HIT       = 2      # how many levels achieve count >= MIN_SELECTION_COUNT\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return float(item[\"holdout\"][\"mean\"][\"overall\"])\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "\n",
    "    Note: We DO NOT drop 0.0 overall values; they are valid and part of the baseline.\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s  # keep zeros\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def build_delta_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: delta_confidence} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"delta_confidence\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"delta_confidence\"])\n",
    "            except Exception:\n",
    "                pass\n",
    "    return out\n",
    "\n",
    "\n",
    "def avg_for_selected(eval_data: Dict[str, Any], selected_ids: List[str]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - count of selected features that also have 'overall' in eval_data\n",
    "      - average 'overall' over those features (0.0 if count=0)\n",
    "    \"\"\"\n",
    "    vals: List[float] = []\n",
    "    for fid in selected_ids:\n",
    "        s = get_overall_from_eval_item(eval_data.get(fid, {}))\n",
    "        if s is not None:\n",
    "            vals.append(s)  # keep zeros\n",
    "    n = len(vals)\n",
    "    avg = (sum(vals) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection levels (Quantiles / Top-K)\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_for_up(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build UP (high end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles: label like 'Q>= 0.95'\n",
    "    - Top-K:     label like 'TOPK_UP= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (upper tail): select v >= quantile(q)\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            cut = float(np.quantile(vals, q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] >= cut]\n",
    "            levels.append((f\"Q>= {q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (largest K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_up = sorted(fids, key=lambda x: delta_map[x], reverse=True)\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_up[:max(0, min(k, len(sorted_up)))]\n",
    "            levels.append((f\"TOPK_UP= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_down(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build DOWN (negative end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles (lower tail): label like 'Q<= 0.05' meaning v <= quantile(0.05)\n",
    "      (Mirroring an upper-tail q by using (1 - q) for the lower tail.)\n",
    "    - Top-K:     label like 'TOPK_DOWN= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (lower tail): mirror\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            low_q = 1.0 - q\n",
    "            low_cut = float(np.quantile(vals, low_q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] <= low_cut]\n",
    "            levels.append((f\"Q<= {low_q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (most negative K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_down = sorted(fids, key=lambda x: delta_map[x])  # ascending => most negative first\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_down[:max(0, min(k, len(sorted_down)))]\n",
    "            levels.append((f\"TOPK_DOWN= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_mid(\n",
    "    delta_map: Dict[str, float],\n",
    "    topk_list: List[int],\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build MID (near-zero) selection levels as a control group.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Top-K MID: label like 'TOPK_MID= 10' selecting K features with smallest |delta_confidence|\n",
    "      i.e., sort by abs(delta) ascending and take the first K.\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map or (not use_topk) or (not topk_list):\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    sorted_mid = sorted(fids, key=lambda x: abs(delta_map[x]))  # closest to 0 first\n",
    "    for k in sorted(set(topk_list)):\n",
    "        sel = sorted_mid[:max(0, min(k, len(sorted_mid)))]\n",
    "        levels.append((f\"TOPK_MID= {k}\", sel))\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str,\n",
    "    order_up_labels: List[str],\n",
    "    order_down_labels: List[str],\n",
    "    order_mid_labels: List[str],\n",
    ") -> Tuple[\n",
    "    Dict[str, float],   # per-level lifts (UP)      label -> lift\n",
    "    Dict[str, float],   # per-level lifts (DOWN)    label -> lift\n",
    "    Dict[str, float],   # per-level lifts (MID)     label -> lift\n",
    "    Optional[Tuple[str, int, float, float]],  # best_up: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_down: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_mid: (label, count, avg, lift)\n",
    "    Optional[float],    # best_of_both lift (UP/DOWN only)\n",
    "    Optional[int],      # best_of_both count\n",
    "    Dict[str, int],     # per-level counts (UP)\n",
    "    Dict[str, int],     # per-level counts (DOWN)\n",
    "    Dict[str, int],     # per-level counts (MID)\n",
    "    float,              # base_avg_overall for this SAE\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, {}, None, None, None, None, None, {}, {}, {}, 0.0\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping selection levels.)\")\n",
    "        return {}, {}, {}, None, None, None, None, None, {}, {}, {}, avg_overall_all\n",
    "\n",
    "    # Build delta map\n",
    "    delta_map = build_delta_map(entropy_data)\n",
    "\n",
    "    # Compose selection levels for UP & DOWN & MID\n",
    "    up_levels   = selection_levels_for_up(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    down_levels = selection_levels_for_down(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    mid_levels  = selection_levels_for_mid(delta_map, TOPK_LIST, USE_TOPK)\n",
    "\n",
    "    # Keep maps for lifts/counts keyed by label for deterministic aggregation/printing\n",
    "    per_level_lifts_up: Dict[str, float] = {}\n",
    "    per_level_counts_up: Dict[str, int] = {}\n",
    "    per_level_lifts_down: Dict[str, float] = {}\n",
    "    per_level_counts_down: Dict[str, int] = {}\n",
    "    per_level_lifts_mid: Dict[str, float] = {}\n",
    "    per_level_counts_mid: Dict[str, int] = {}\n",
    "\n",
    "    # ---- UP section ----\n",
    "    print(\"\\n=== Selection levels (UP: high delta_confidence) ===\")\n",
    "    best_up: Optional[Tuple[str, int, float, float]] = None  # (label, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    # Ensure printing order follows order_up_labels; fallback to appending any missing labels\n",
    "    up_levels_map = {lab: ids for lab, ids in up_levels}\n",
    "    up_labels_ordered = [lab for lab in order_up_labels if lab in up_levels_map] + \\\n",
    "                        [lab for lab in up_levels_map.keys() if lab not in order_up_labels]\n",
    "\n",
    "    for label in up_labels_ordered:\n",
    "        selected = up_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_up[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_up[label] = lift\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (label, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- DOWN section ----\n",
    "    print(\"\\n=== Selection levels (DOWN: low/negative delta_confidence) ===\")\n",
    "    best_down: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    down_levels_map = {lab: ids for lab, ids in down_levels}\n",
    "    down_labels_ordered = [lab for lab in order_down_labels if lab in down_levels_map] + \\\n",
    "                          [lab for lab in down_levels_map.keys() if lab not in order_down_labels]\n",
    "\n",
    "    for label in down_labels_ordered:\n",
    "        selected = down_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_down[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_down[label] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (label, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- MID (control) section ----\n",
    "    print(\"\\n=== Selection levels (MID: near-zero |delta_confidence|, control) ===\")\n",
    "    best_mid: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_mid_avg = float(\"-inf\")\n",
    "    best_mid_count = -1\n",
    "\n",
    "    mid_levels_map = {lab: ids for lab, ids in mid_levels}\n",
    "    mid_labels_ordered = [lab for lab in order_mid_labels if lab in mid_levels_map] + \\\n",
    "                         [lab for lab in mid_levels_map.keys() if lab not in order_mid_labels]\n",
    "\n",
    "    for label in mid_labels_ordered:\n",
    "        selected = mid_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_mid[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_mid[label] = lift\n",
    "                if (avg_sub > best_mid_avg) or (avg_sub == best_mid_avg and n > best_mid_count):\n",
    "                    best_mid = (label, n, avg_sub, lift)\n",
    "                    best_mid_avg = avg_sub\n",
    "                    best_mid_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (UP/DOWN only) per SAE\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    best_of_both_count: Optional[int] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        if best_up[3] >= best_down[3]:\n",
    "            best_of_both_lift = best_up[3]\n",
    "            best_of_both_count = best_up[1]\n",
    "            direction = \"UP\"\n",
    "        else:\n",
    "            best_of_both_lift = best_down[3]\n",
    "            best_of_both_count = best_down[1]\n",
    "            direction = \"DOWN\"\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "        best_of_both_count = best_up[1]\n",
    "        direction = \"UP\"\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "        best_of_both_count = best_down[1]\n",
    "        direction = \"DOWN\"\n",
    "    else:\n",
    "        direction = \"N/A\"\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best levels (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP   : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : level={best_up[0]:<12} | count={best_up[1]:<4} avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : level={best_down[0]:<12} | count={best_down[1]:<4} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_mid is None:\n",
    "        print(\"Best MID  : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best MID  : level={best_mid[0]:<12} | count={best_mid[1]:<4} avg_overall={best_mid[2]:.6f}  lift={best_mid[3]:.2f}%\")\n",
    "\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH (UP/DOWN): N/A\")\n",
    "    else:\n",
    "        print(f\"Best of BOTH (UP/DOWN): {best_of_both_lift:.2f}%  (direction={direction}) | count={best_of_both_count}\")\n",
    "\n",
    "    return (\n",
    "        per_level_lifts_up,\n",
    "        per_level_lifts_down,\n",
    "        per_level_lifts_mid,\n",
    "        best_up,\n",
    "        best_down,\n",
    "        best_mid,\n",
    "        best_of_both_lift,\n",
    "        best_of_both_count,\n",
    "        per_level_counts_up,\n",
    "        per_level_counts_down,\n",
    "        per_level_counts_mid,\n",
    "        avg_overall_all,\n",
    "    )\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Build the global (ordered) label lists we will use for consistent printing/aggregation\n",
    "    order_up_labels: List[str] = []\n",
    "    order_down_labels: List[str] = []\n",
    "    order_mid_labels: List[str] = []  # NEW\n",
    "\n",
    "    if USE_QUANTILES and QUANTILES:\n",
    "        for q in sorted(set(QUANTILES), reverse=True):\n",
    "            order_up_labels.append(f\"Q>= {q:.2f}\")\n",
    "            order_down_labels.append(f\"Q<= {1.0 - q:.2f}\")\n",
    "    if USE_TOPK and TOPK_LIST:\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            order_up_labels.append(f\"TOPK_UP= {k}\")\n",
    "            order_down_labels.append(f\"TOPK_DOWN= {k}\")\n",
    "            order_mid_labels.append(f\"TOPK_MID= {k}\")  # NEW\n",
    "\n",
    "    # Across-SAEs per-level aggregations (unfiltered)\n",
    "    def init_agg(levels: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {lab: {\"sum\": 0.0, \"count\": 0.0} for lab in levels}\n",
    "\n",
    "    across_up = init_agg(order_up_labels)\n",
    "    across_down = init_agg(order_down_labels)\n",
    "    across_mid = init_agg(order_mid_labels)\n",
    "\n",
    "    # Per-SAE best stats (unfiltered)\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_mid_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "    best_both_counts: List[int] = []\n",
    "    pos_up = pos_down = pos_mid = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_mid = saes_with_both = 0\n",
    "\n",
    "    # Keep per-SAE records for later filtered summary\n",
    "    sae_records: List[Dict[str, Any]] = []\n",
    "    non_steering: List[Tuple[str, List[str], Dict[str, Any]]] = []\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        (\n",
    "            per_up,\n",
    "            per_down,\n",
    "            per_mid,\n",
    "            best_up,\n",
    "            best_down,\n",
    "            best_mid,\n",
    "            best_both_lift,\n",
    "            best_both_count,\n",
    "            cnts_up,\n",
    "            cnts_down,\n",
    "            cnts_mid,\n",
    "            base_avg,\n",
    "        ) = process_one_sae(sae_name, order_up_labels, order_down_labels, order_mid_labels)\n",
    "\n",
    "        # Save record\n",
    "        sae_records.append(\n",
    "            {\n",
    "                \"name\": sae_name,\n",
    "                \"per_up\": per_up,\n",
    "                \"per_down\": per_down,\n",
    "                \"per_mid\": per_mid,                 # NEW\n",
    "                \"best_up\": best_up,\n",
    "                \"best_down\": best_down,\n",
    "                \"best_mid\": best_mid,               # NEW\n",
    "                \"best_both_lift\": best_both_lift,   # UP/DOWN only\n",
    "                \"best_both_count\": best_both_count,\n",
    "                \"cnts_up\": cnts_up,\n",
    "                \"cnts_down\": cnts_down,\n",
    "                \"cnts_mid\": cnts_mid,               # NEW\n",
    "                \"base_avg\": base_avg,\n",
    "            }\n",
    "        )\n",
    "\n",
    "        # Aggregate per-level lifts (UP/DOWN/MID) for unfiltered summary\n",
    "        for lab, lift in per_up.items():\n",
    "            if lab not in across_up:\n",
    "                across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_up[lab][\"sum\"] += lift\n",
    "            across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in per_down.items():\n",
    "            if lab not in across_down:\n",
    "                across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_down[lab][\"sum\"] += lift\n",
    "            across_down[lab][\"count\"] += 1\n",
    "        for lab, lift in per_mid.items():  # NEW\n",
    "            if lab not in across_mid:\n",
    "                across_mid[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_mid[lab][\"sum\"] += lift\n",
    "            across_mid[lab][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction/MID BEST (unfiltered)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if best_mid is not None:  # NEW\n",
    "            saes_with_mid += 1\n",
    "            best_mid_lifts.append(best_mid[3])\n",
    "            if best_mid[3] > 0:\n",
    "                pos_mid += 1\n",
    "\n",
    "        if (best_both_lift is not None) and isinstance(best_both_lift, float):\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both_lift)\n",
    "            if isinstance(best_both_count, int):\n",
    "                best_both_counts.append(best_both_count)\n",
    "            if best_both_lift > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "        # ---------------------------\n",
    "        # Non-steering detection (based on UP/DOWN only)\n",
    "        # ---------------------------\n",
    "        reasons: List[str] = []\n",
    "        max_count_up = max(cnts_up.values(), default=0)\n",
    "        max_count_down = max(cnts_down.values(), default=0)\n",
    "        max_count_both = max(max_count_up, max_count_down)\n",
    "\n",
    "        # How many levels hit MIN_SELECTION_COUNT (across both directions)\n",
    "        hits_up = sum(1 for c in cnts_up.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_down = sum(1 for c in cnts_down.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_both = hits_up + hits_down\n",
    "\n",
    "        # Best-of-both lift (already computed)\n",
    "        local_best_of_both_lift = best_both_lift\n",
    "\n",
    "        # Condition 1: insufficient selected features at any level\n",
    "        if max_count_both < MIN_SELECTION_COUNT:\n",
    "            reasons.append(f\"insufficient selected features: max_count={max_count_both} < {MIN_SELECTION_COUNT}\")\n",
    "\n",
    "        # Condition 2: no positive (or required) lift anywhere\n",
    "        if (local_best_of_both_lift is None) or (local_best_of_both_lift <= MIN_BEST_LIFT):\n",
    "            reasons.append(\n",
    "                f\"no level yields lift > {MIN_BEST_LIFT:.2f}% (best_of_both={local_best_of_both_lift if local_best_of_both_lift is not None else 'N/A'})\"\n",
    "            )\n",
    "\n",
    "        # Condition 3: stability across levels is poor\n",
    "        if hits_both < MIN_LEVELS_HIT:\n",
    "            reasons.append(\n",
    "                f\"unstable coverage: levels_with_count>={MIN_SELECTION_COUNT} = {hits_both} < {MIN_LEVELS_HIT}\"\n",
    "            )\n",
    "\n",
    "        if len(reasons) > 0:\n",
    "            non_steering.append((\n",
    "                sae_name,\n",
    "                reasons,\n",
    "                {\n",
    "                    \"max_count_up\": max_count_up,\n",
    "                    \"max_count_down\": max_count_down,\n",
    "                    \"best_up_lift\": (best_up[3] if best_up else None),\n",
    "                    \"best_down_lift\": (best_down[3] if best_down else None),\n",
    "                    \"best_of_both_lift\": local_best_of_both_lift,\n",
    "                    \"hits_up\": hits_up,\n",
    "                    \"hits_down\": hits_down,\n",
    "                }\n",
    "            ))\n",
    "\n",
    "    # =================================================================================\n",
    "    # Unfiltered summary across ALL SAEs (baseline reference)\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and control MID)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-level averages: UP\n",
    "    print(\"Per-level average lift across SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: DOWN\n",
    "    print(\"\\nPer-level average lift across SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: MID (control)\n",
    "    print(\"\\nPer-level average lift across SAEs (MID levels, control):\")\n",
    "    for lab in order_mid_labels:\n",
    "        cnt = int(across_mid.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_mid[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Compute base across ALL SAEs (fixed baseline definition: average of each SAE's all-feature mean)\n",
    "    all_base_vals = [rec[\"base_avg\"] for rec in sae_records]\n",
    "    base_across_all = (sum(all_base_vals) / len(all_base_vals)) if all_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (ALL)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (ALL) ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_mid == 0:\n",
    "        print(\"MID  : No SAE produced a valid BEST selection.\")\n",
    "        avg_mid_best_all = 0.0\n",
    "        mid_after_mean_all = 0.0\n",
    "    else:\n",
    "        avg_mid_best_all = sum(best_mid_lifts) / len(best_mid_lifts)\n",
    "        pct_mid_pos = (pos_mid / saes_with_mid) * 100.0\n",
    "        print(f\"MID  : SAEs with positive lift: {pos_mid} / {saes_with_mid} ({pct_mid_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (MID, control): {avg_mid_best_all:.2f}%\")\n",
    "\n",
    "        # Mean of per-SAE \"after\" for MID best (control)\n",
    "        mid_after_list_all = []\n",
    "        for rec in sae_records:\n",
    "            mid_best = rec.get(\"best_mid\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if (mid_best is not None) and isinstance(mid_best[3], float):\n",
    "                mid_after_list_all.append(base * (1.0 + mid_best[3] / 100.0))\n",
    "        mid_after_mean_all = (sum(mid_after_list_all) / len(mid_after_list_all)) if mid_after_list_all else 0.0\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH (UP/DOWN): No SAE produced a valid BEST-of-both selection.\")\n",
    "        avg_both_best_all = 0.0\n",
    "        avg_both_count_all = 0.0\n",
    "        both_after_mean_all = 0.0\n",
    "    else:\n",
    "        avg_both_best_all = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        avg_both_count_all = (sum(best_both_counts) / len(best_both_counts)) if best_both_counts else 0.0\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "\n",
    "        # Mean of per-SAE \"after\" for UP/DOWN best-of-both\n",
    "        after_list_all = []\n",
    "        for rec in sae_records:\n",
    "            lift = rec.get(\"best_both_lift\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if isinstance(lift, float):\n",
    "                after_list_all.append(base * (1.0 + lift / 100.0))\n",
    "        both_after_mean_all = (sum(after_list_all) / len(after_list_all)) if after_list_all else 0.0\n",
    "\n",
    "        print(f\"BOTH (UP/DOWN): SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "\n",
    "    # Print final comparative lines (ALL)\n",
    "    print(\"\\n--- Comparative steering score (ALL, mean of per-SAE after) ---\")\n",
    "    print(f\"Base steering score across SAEs:                     {base_across_all:.6f}\")\n",
    "    print(f\"After selection (Best of UP/DOWN) across SAEs:       {both_after_mean_all:.6f}\")\n",
    "    print(f\"After selection (MID control, best per SAE) across:  {mid_after_mean_all:.6f}\")\n",
    "    print(f\"Avg BEST lift (UP/DOWN best-of-both):               {avg_both_best_all:.2f}%   | Avg selected count: { (sum(best_both_counts)/len(best_both_counts)) if best_both_counts else 0.0 :.2f}\")\n",
    "    print(f\"Avg BEST lift (MID control):                         {avg_mid_best_all:.2f}%\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Non-steering report\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SAEs flagged as NON-STEERING by the configured criteria\")\n",
    "    print(\"- Criteria:\")\n",
    "    print(f\"  1) max selected count across all levels/directions < {MIN_SELECTION_COUNT}\")\n",
    "    print(f\"  2) best-of-both lift <= {MIN_BEST_LIFT:.2f}%\")\n",
    "    print(f\"  3) levels achieving count>={MIN_SELECTION_COUNT} across UP+DOWN < {MIN_LEVELS_HIT}\")\n",
    "    print(\"- Note: MID is a control and not used for filtering.\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    non_names = set()\n",
    "    if not non_steering:\n",
    "        print(\"All SAEs pass the steering capability criteria.\")\n",
    "    else:\n",
    "        for name, reasons, stats in non_steering:\n",
    "            non_names.add(name)\n",
    "            print(f\"[NON-STEERING] {name}\")\n",
    "            print(f\"  Reasons:\")\n",
    "            for r in reasons:\n",
    "                print(f\"    - {r}\")\n",
    "            print(f\"  Stats: max_count_up={stats['max_count_up']}  max_count_down={stats['max_count_down']}\")\n",
    "            print(f\"         best_up_lift={stats['best_up_lift']}  best_down_lift={stats['best_down_lift']}  best_of_both={stats['best_of_both_lift']}\")\n",
    "            print(f\"         levels_hit(up)={stats['hits_up']}  levels_hit(down)={stats['hits_down']}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # FILTERED summary across STEERING-QUALIFIED SAEs only\n",
    "    # =================================================================================\n",
    "    qualified = [rec for rec in sae_records if rec[\"name\"] not in non_names]\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    if not qualified:\n",
    "        print(\"No SAE remains after filtering; cannot compute qualified summary.\")\n",
    "        return\n",
    "\n",
    "    # Per-level averages across qualified\n",
    "    def init_agg_like(template_keys: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {k: {\"sum\": 0.0, \"count\": 0.0} for k in template_keys}\n",
    "\n",
    "    q_across_up = init_agg_like(order_up_labels)\n",
    "    q_across_down = init_agg_like(order_down_labels)\n",
    "    q_across_mid = init_agg_like(order_mid_labels)\n",
    "\n",
    "    q_best_up_lifts: List[float] = []\n",
    "    q_best_down_lifts: List[float] = []\n",
    "    q_best_mid_lifts: List[float] = []\n",
    "    q_best_both_lifts: List[float] = []\n",
    "    q_best_both_counts: List[int] = []\n",
    "    q_pos_up = q_pos_down = q_pos_mid = q_pos_both = 0\n",
    "    q_saes_with_up = q_saes_with_down = q_saes_with_mid = q_saes_with_both = 0\n",
    "\n",
    "    for rec in qualified:\n",
    "        # per-level lifts\n",
    "        for lab, lift in rec[\"per_up\"].items():\n",
    "            if lab not in q_across_up:\n",
    "                q_across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_up[lab][\"sum\"] += lift\n",
    "            q_across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_down\"].items():\n",
    "            if lab not in q_across_down:\n",
    "                q_across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_down[lab][\"sum\"] += lift\n",
    "            q_across_down[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_mid\"].items():\n",
    "            if lab not in q_across_mid:\n",
    "                q_across_mid[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_mid[lab][\"sum\"] += lift\n",
    "            q_across_mid[lab][\"count\"] += 1\n",
    "\n",
    "        # best per-direction / best-of-both / best-mid\n",
    "        if rec[\"best_up\"] is not None:\n",
    "            q_saes_with_up += 1\n",
    "            q_best_up_lifts.append(rec[\"best_up\"][3])\n",
    "            if rec[\"best_up\"][3] > 0:\n",
    "                q_pos_up += 1\n",
    "        if rec[\"best_down\"] is not None:\n",
    "            q_saes_with_down += 1\n",
    "            q_best_down_lifts.append(rec[\"best_down\"][3])\n",
    "            if rec[\"best_down\"][3] > 0:\n",
    "                q_pos_down += 1\n",
    "\n",
    "        if (rec[\"best_both_lift\"] is not None) and isinstance(rec[\"best_both_lift\"], float):\n",
    "            q_saes_with_both += 1\n",
    "            q_best_both_lifts.append(rec[\"best_both_lift\"])\n",
    "            if isinstance(rec[\"best_both_count\"], int):\n",
    "                q_best_both_counts.append(rec[\"best_both_count\"])\n",
    "            if rec[\"best_both_lift\"] > 0:\n",
    "                q_pos_both += 1\n",
    "\n",
    "        if rec[\"best_mid\"] is not None:\n",
    "            q_saes_with_mid += 1\n",
    "            q_best_mid_lifts.append(rec[\"best_mid\"][3])\n",
    "            if rec[\"best_mid\"][3] > 0:\n",
    "                q_pos_mid += 1\n",
    "\n",
    "    # Print per-level averages (qualified)\n",
    "    print(\"Per-level average lift across QUALIFIED SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(q_across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(q_across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (MID levels, control):\")\n",
    "    for lab in order_mid_labels:\n",
    "        cnt = int(q_across_mid.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_mid[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Base steering score across QUALIFIED SAEs (same definition as ALL, but over the subset)\n",
    "    q_base_vals = [rec[\"base_avg\"] for rec in qualified]\n",
    "    base_across_qualified = (sum(q_base_vals) / len(q_base_vals)) if q_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (qualified)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (QUALIFIED) ---\")\n",
    "    if q_saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_up_best = (sum(q_best_up_lifts) / len(q_best_up_lifts)) if q_best_up_lifts else 0.0\n",
    "        q_pct_up_pos = (q_pos_up / q_saes_with_up) * 100.0 if q_saes_with_up > 0 else 0.0\n",
    "        print(f\"UP   : SAEs with positive lift: {q_pos_up} / {q_saes_with_up} ({q_pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {q_avg_up_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_down_best = (sum(q_best_down_lifts) / len(q_best_down_lifts)) if q_best_down_lifts else 0.0\n",
    "        q_pct_down_pos = (q_pos_down / q_saes_with_down) * 100.0 if q_saes_with_down > 0 else 0.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {q_pos_down} / {q_saes_with_down} ({q_pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {q_avg_down_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_mid == 0:\n",
    "        print(\"MID  : No SAE produced a valid BEST selection.\")\n",
    "        q_avg_mid_best = 0.0\n",
    "        q_mid_after_mean = 0.0\n",
    "    else:\n",
    "        q_avg_mid_best = (sum(q_best_mid_lifts) / len(q_best_mid_lifts)) if q_best_mid_lifts else 0.0\n",
    "        q_pct_mid_pos = (q_pos_mid / q_saes_with_mid) * 100.0 if q_saes_with_mid > 0 else 0.0\n",
    "        print(f\"MID  : SAEs with positive lift: {q_pos_mid} / {q_saes_with_mid} ({q_pct_mid_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (MID, control): {q_avg_mid_best:.2f}%\")\n",
    "\n",
    "        # Mean of per-SAE after (MID best)\n",
    "        q_mid_after_list = []\n",
    "        for rec in qualified:\n",
    "            mid_best = rec.get(\"best_mid\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if (mid_best is not None) and isinstance(mid_best[3], float):\n",
    "                q_mid_after_list.append(base * (1.0 + mid_best[3] / 100.0))\n",
    "        q_mid_after_mean = (sum(q_mid_after_list) / len(q_mid_after_list)) if q_mid_after_list else 0.0\n",
    "\n",
    "    if q_saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        q_avg_both_best = 0.0\n",
    "        q_avg_both_count = 0.0\n",
    "        q_after_mean = 0.0\n",
    "    else:\n",
    "        q_avg_both_best = (sum(q_best_both_lifts) / len(q_best_both_lifts)) if q_best_both_lifts else 0.0\n",
    "        q_avg_both_count = (sum(q_best_both_counts) / len(q_best_both_counts)) if q_best_both_counts else 0.0\n",
    "        q_pct_both_pos = (q_pos_both / q_saes_with_both) * 100.0 if q_saes_with_both > 0 else 0.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {q_pos_both} / {q_saes_with_both} ({q_pct_both_pos:.2f}%)\")\n",
    "\n",
    "        # Mean of per-SAE after (best of UP/DOWN)\n",
    "        q_after_list = []\n",
    "        for rec in qualified:\n",
    "            lift = rec.get(\"best_both_lift\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if isinstance(lift, float):\n",
    "                q_after_list.append(base * (1.0 + lift / 100.0))\n",
    "        q_after_mean = (sum(q_after_list) / len(q_after_list)) if q_after_list else 0.0\n",
    "\n",
    "    # Comparative lines (qualified)\n",
    "    print(\"\\n--- Comparative steering score (QUALIFIED, mean of per-SAE after) ---\")\n",
    "    print(f\"Base steering score across SAEs:                     {base_across_qualified:.6f}\")\n",
    "    print(f\"After selection (Best of UP/DOWN) across SAEs:       {q_after_mean:.6f}\")\n",
    "    print(f\"After selection (MID control, best per SAE) across:  {q_mid_after_mean:.6f}\")\n",
    "    print(f\"      Average BEST lift across SAEs (Best of UP/DOWN): {q_avg_both_best:.2f}%\")\n",
    "    print(f\"      Average selected feature count per SAE (UP/DOWN): {q_avg_both_count:.2f}\")\n",
    "    print(f\"      Average BEST lift across SAEs (MID control):     {q_avg_mid_best:.2f}%\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Per-qualified-SAE steering result details\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"STEERING RESULTS FOR QUALIFIED SAEs (best levels per SAE)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for rec in qualified:\n",
    "        name = rec[\"name\"]\n",
    "        best_up = rec[\"best_up\"]\n",
    "        best_down = rec[\"best_down\"]\n",
    "        best_mid = rec[\"best_mid\"]\n",
    "\n",
    "        # UP vs DOWN best-of-both\n",
    "        best_dir = None\n",
    "        best_tuple = None  # (label, count, avg, lift)\n",
    "        if best_up is not None and best_down is not None:\n",
    "            best_dir = \"UP\" if best_up[3] >= best_down[3] else \"DOWN\"\n",
    "            best_tuple = best_up if best_up[3] >= best_down[3] else best_down\n",
    "        elif best_up is not None:\n",
    "            best_dir = \"UP\"\n",
    "            best_tuple = best_up\n",
    "        elif best_down is not None:\n",
    "            best_dir = \"DOWN\"\n",
    "            best_tuple = best_down\n",
    "\n",
    "        # Print UP/DOWN best and MID best side-by-side where possible\n",
    "        if best_tuple is None and best_mid is None:\n",
    "            print(f\"[{name}] No valid selections found.\")\n",
    "        else:\n",
    "            if best_tuple is not None:\n",
    "                lab, cnt, avg_overall, lift = best_tuple\n",
    "                print(f\"[{name}] best_dir={best_dir:<5} | level={lab:<12} | count={cnt:<4} | avg_overall={avg_overall:.6f} | lift={lift:.2f}%\")\n",
    "            else:\n",
    "                print(f\"[{name}] best_dir= N/A  | level= N/A         | count= N/A  | avg_overall= N/A      | lift= N/A\")\n",
    "\n",
    "            if best_mid is not None:\n",
    "                lab_m, cnt_m, avg_m, lift_m = best_mid\n",
    "                print(f\"         MIDctl  | level={lab_m:<12} | count={cnt_m:<4} | avg_overall={avg_m:.6f} | lift={lift_m:.2f}%\")\n",
    "            else:\n",
    "                print(f\"         MIDctl  | level= N/A         | count= N/A  | avg_overall= N/A      | lift= N/A\")\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "00315812",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.145400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.420000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.312000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.210000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.146000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.180000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.420000  lift=188.86%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.146000  lift=0.41%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.180000  lift=23.80%\n",
      "Best of BOTH (UP/DOWN): 188.86%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.122400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.168000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.260000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.130000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=292.16%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.168000  lift=37.25%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.300000  lift=145.10%\n",
      "Best of BOTH (UP/DOWN): 292.16%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.151400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.068000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.176000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.208000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.096000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.072000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.136000  lift=-10.17%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.208000  lift=37.38%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.480000  lift=217.04%\n",
      "Best of BOTH (UP/DOWN): 37.38%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.117400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.540000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.610000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.304000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.220000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.102000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.610000  lift=419.59%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.144000  lift=22.66%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=104.43%\n",
      "Best of BOTH (UP/DOWN): 419.59%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.156200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.352000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.236000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.150000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.560000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.584000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.502000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.352000  lift=125.35%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.300000  lift=92.06%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.584000  lift=273.88%\n",
      "Best of BOTH (UP/DOWN): 125.35%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.288000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.168000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.030000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.000000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.960000  lift=803.95%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.030000  lift=-71.75%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.000000  lift=-100.00%\n",
      "Best of BOTH (UP/DOWN): 803.95%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_148\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.115800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.184000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.188000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.088000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.136000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.126000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.360000  lift=210.88%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.136000  lift=17.44%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.144000  lift=24.35%\n",
      "Best of BOTH (UP/DOWN): 210.88%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_340\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.153200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.054000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.242000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.168000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.204000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.054000  lift=-64.75%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.388000  lift=153.26%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.204000  lift=33.16%\n",
      "Best of BOTH (UP/DOWN): 153.26%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_49\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.024000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.108000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.024000  lift=-77.44%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-9.77%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.108000  lift=1.50%\n",
      "Best of BOTH (UP/DOWN): -9.77%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_547\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.384000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.288000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.054000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=79.37%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.384000  lift=187.00%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.108000  lift=-19.28%\n",
      "Best of BOTH (UP/DOWN): 187.00%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_78\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.088800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.108000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.780000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.390000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.078000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.156000  lift=75.68%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=170.27%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.780000  lift=778.38%\n",
      "Best of BOTH (UP/DOWN): 170.27%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_948\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.102800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.102000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.096000  lift=-6.61%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-6.61%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=133.46%\n",
      "Best of BOTH (UP/DOWN): -6.61%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_165\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.054000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.102000  lift=-14.72%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-19.73%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=100.67%\n",
      "Best of BOTH (UP/DOWN): -14.72%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_330\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.105400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.144000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.054000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=127.70%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.144000  lift=36.62%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=127.70%\n",
      "Best of BOTH (UP/DOWN): 127.70%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_52\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.175800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.160000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.078000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=36.52%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=36.52%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.096000  lift=-45.39%\n",
      "Best of BOTH (UP/DOWN): 36.52%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_538\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.089200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.080000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.040000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.136000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.068000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.080000  lift=-10.31%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.072000  lift=-19.28%\n",
      "Best MID  : level=TOPK_MID= 2  | count=2    avg_overall=0.240000  lift=169.06%\n",
      "Best of BOTH (UP/DOWN): -10.31%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_779\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.060000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.176000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.220000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.048000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.120000  lift=0.50%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.220000  lift=84.25%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.048000  lift=-59.80%\n",
      "Best of BOTH (UP/DOWN): 84.25%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_83\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.178800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.242000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.220000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.136000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.116000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.096000  lift=-46.31%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.460000  lift=157.27%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=34.23%\n",
      "Best of BOTH (UP/DOWN): 157.27%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_156\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.181000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.184000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.360000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.252000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.184000  lift=1.66%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=-33.70%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.360000  lift=98.90%\n",
      "Best of BOTH (UP/DOWN): 1.66%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_309\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.131400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.190000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.118000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.108000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.174000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.190000  lift=44.60%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.118000  lift=-10.20%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.174000  lift=32.42%\n",
      "Best of BOTH (UP/DOWN): 44.60%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_507\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.140400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.312000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.254000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.040000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.096000  lift=-31.62%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.312000  lift=122.22%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.040000  lift=-71.51%\n",
      "Best of BOTH (UP/DOWN): 122.22%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_54\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.150400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.228000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.114000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=1.200000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.480000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.438000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.300000  lift=99.47%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.120000  lift=-20.21%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=1.200000  lift=697.87%\n",
      "Best of BOTH (UP/DOWN): 99.47%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_733\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.141000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.408000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.228000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.174000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.120000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.192000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.120000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=240.43%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.174000  lift=23.40%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.240000  lift=70.21%\n",
      "Best of BOTH (UP/DOWN): 240.43%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_99\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.109800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.054000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.276000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.210000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.120000  lift=9.29%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.054000  lift=-50.82%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.276000  lift=151.37%\n",
      "Best of BOTH (UP/DOWN): 9.29%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.152200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.092000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.144000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=57.69%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.240000  lift=57.69%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.096000  lift=-36.93%\n",
      "Best of BOTH (UP/DOWN): 57.69%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.112800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.048000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.240000  lift=112.77%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=6.38%\n",
      "Best MID  : level=TOPK_MID= 10 | count=10   avg_overall=0.096000  lift=-14.89%\n",
      "Best of BOTH (UP/DOWN): 112.77%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.196600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.160000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.280000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.248000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.096000\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.092000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.160000  lift=-18.62%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.460000  lift=133.98%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.096000  lift=-51.17%\n",
      "Best of BOTH (UP/DOWN): 133.98%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.133800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.192000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.222000 [> overall]\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.264000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.186000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=79.37%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.222000  lift=65.92%\n",
      "Best MID  : level=TOPK_MID= 5  | count=5    avg_overall=0.264000  lift=97.31%\n",
      "Best of BOTH (UP/DOWN): 79.37%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.148600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.224000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.112000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.480000 [> overall]\n",
      "TOPK_MID= 5    -> count=5     avg_overall=0.192000 [> overall]\n",
      "TOPK_MID= 10   -> count=10    avg_overall=0.236000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.224000  lift=50.74%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-35.40%\n",
      "Best MID  : level=TOPK_MID= 1  | count=1    avg_overall=0.960000  lift=546.03%\n",
      "Best of BOTH (UP/DOWN): 50.74%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 87\n",
      "Average overall score (all features): 0.105747\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=4     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 10    -> count=8     avg_overall=0.180000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=9     avg_overall=0.060000\n",
      "\n",
      "=== Selection levels (MID: near-zero |delta_confidence|, control) ===\n",
      "TOPK_MID= 1    -> count=1     avg_overall=0.000000\n",
      "TOPK_MID= 2    -> count=2     avg_overall=0.000000\n",
      "TOPK_MID= 5    -> count=4     avg_overall=0.000000\n",
      "TOPK_MID= 10   -> count=9     avg_overall=0.026667\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=4    avg_overall=0.300000  lift=183.70%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.108000  lift=2.13%\n",
      "Best MID  : level=TOPK_MID= 10 | count=9    avg_overall=0.026667  lift=-74.78%\n",
      "Best of BOTH (UP/DOWN): 183.70%  (direction=UP) | count=4\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and control MID)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=30   avg_lift=18.57%\n",
      "TOPK_UP= 2    : N=30   avg_lift=4.81%\n",
      "TOPK_UP= 5    : N=30   avg_lift=14.63%\n",
      "TOPK_UP= 10   : N=30   avg_lift=-4.96%\n",
      "\n",
      "Per-level average lift across SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=30   avg_lift=-80.04%\n",
      "TOPK_DOWN= 2  : N=30   avg_lift=-59.77%\n",
      "TOPK_DOWN= 5  : N=30   avg_lift=-3.11%\n",
      "TOPK_DOWN= 10 : N=30   avg_lift=1.97%\n",
      "\n",
      "Per-level average lift across SAEs (MID levels, control):\n",
      "TOPK_MID= 1   : N=30   avg_lift=44.14%\n",
      "TOPK_MID= 2   : N=30   avg_lift=-0.66%\n",
      "TOPK_MID= 5   : N=30   avg_lift=13.76%\n",
      "TOPK_MID= 10  : N=30   avg_lift=-0.84%\n",
      "\n",
      "--- BEST (per SAE) summaries (ALL) ---\n",
      "UP   : SAEs with positive lift: 21 / 30 (70.00%)\n",
      "      Average BEST lift across SAEs (UP): 98.66%\n",
      "DOWN : SAEs with positive lift: 20 / 30 (66.67%)\n",
      "      Average BEST lift across SAEs (DOWN): 38.89%\n",
      "MID  : SAEs with positive lift: 21 / 30 (70.00%)\n",
      "      Average BEST lift across SAEs (MID, control): 112.90%\n",
      "BOTH (UP/DOWN): SAEs with positive lift: 26 / 30 (86.67%)\n",
      "\n",
      "--- Comparative steering score (ALL, mean of per-SAE after) ---\n",
      "Base steering score across SAEs:                     0.133058\n",
      "After selection (Best of UP/DOWN) across SAEs:       0.307533\n",
      "After selection (MID control, best per SAE) across:  0.276689\n",
      "Avg BEST lift (UP/DOWN best-of-both):               136.30%   | Avg selected count: 4.17\n",
      "Avg BEST lift (MID control):                         112.90%\n",
      "\n",
      "================================================================================\n",
      "SAEs flagged as NON-STEERING by the configured criteria\n",
      "- Criteria:\n",
      "  1) max selected count across all levels/directions < 5\n",
      "  2) best-of-both lift <= 0.00%\n",
      "  3) levels achieving count>=5 across UP+DOWN < 2\n",
      "- Note: MID is a control and not used for filtering.\n",
      "--------------------------------------------------------------------------------\n",
      "[NON-STEERING] gated_49\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-9.774436090225617)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-77.44360902255639  best_down_lift=-9.774436090225617  best_of_both=-9.774436090225617\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] gated_948\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-6.614785992217924)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-6.614785992217924  best_down_lift=-6.614785992217924  best_of_both=-6.614785992217924\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] jump_relu_165\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-14.715719063545174)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-14.715719063545174  best_down_lift=-19.73244147157193  best_of_both=-14.715719063545174\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] jump_relu_538\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-10.313901345291507)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-10.313901345291507  best_down_lift=-19.282511210762365  best_of_both=-10.313901345291507\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "\n",
      "================================================================================\n",
      "SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across QUALIFIED SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=26   avg_lift=36.82%\n",
      "TOPK_UP= 2    : N=26   avg_lift=20.93%\n",
      "TOPK_UP= 5    : N=26   avg_lift=25.23%\n",
      "TOPK_UP= 10   : N=26   avg_lift=2.00%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=26   avg_lift=-76.97%\n",
      "TOPK_DOWN= 2  : N=26   avg_lift=-53.58%\n",
      "TOPK_DOWN= 5  : N=26   avg_lift=-0.42%\n",
      "TOPK_DOWN= 10 : N=26   avg_lift=5.30%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (MID levels, control):\n",
      "TOPK_MID= 1   : N=26   avg_lift=39.27%\n",
      "TOPK_MID= 2   : N=26   avg_lift=-4.07%\n",
      "TOPK_MID= 5   : N=26   avg_lift=16.22%\n",
      "TOPK_MID= 10  : N=26   avg_lift=2.03%\n",
      "\n",
      "--- BEST (per SAE) summaries (QUALIFIED) ---\n",
      "UP   : SAEs with positive lift: 21 / 26 (80.77%)\n",
      "      Average BEST lift across SAEs (UP): 118.03%\n",
      "DOWN : SAEs with positive lift: 20 / 26 (76.92%)\n",
      "      Average BEST lift across SAEs (DOWN): 47.00%\n",
      "MID  : SAEs with positive lift: 17 / 26 (65.38%)\n",
      "      Average BEST lift across SAEs (MID, control): 114.71%\n",
      "BOTH : SAEs with positive lift: 26 / 26 (100.00%)\n",
      "\n",
      "--- Comparative steering score (QUALIFIED, mean of per-SAE after) ---\n",
      "Base steering score across SAEs:                     0.137452\n",
      "After selection (Best of UP/DOWN) across SAEs:       0.340462\n",
      "After selection (MID control, best per SAE) across:  0.287410\n",
      "      Average BEST lift across SAEs (Best of UP/DOWN): 158.86%\n",
      "      Average selected feature count per SAE (UP/DOWN): 3.65\n",
      "      Average BEST lift across SAEs (MID control):     114.71%\n",
      "\n",
      "================================================================================\n",
      "STEERING RESULTS FOR QUALIFIED SAEs (best levels per SAE)\n",
      "--------------------------------------------------------------------------------\n",
      "[batch_topk_160] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.420000 | lift=188.86%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.180000 | lift=23.80%\n",
      "[batch_topk_320] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=292.16%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.300000 | lift=145.10%\n",
      "[batch_topk_50] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.208000 | lift=37.38%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.480000 | lift=217.04%\n",
      "[batch_topk_520] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.610000 | lift=419.59%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=104.43%\n",
      "[batch_topk_80] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.352000 | lift=125.35%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.584000 | lift=273.88%\n",
      "[batch_topk_820] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.960000 | lift=803.95%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.000000 | lift=-100.00%\n",
      "[gated_148] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.360000 | lift=210.88%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.144000 | lift=24.35%\n",
      "[gated_340] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.388000 | lift=153.26%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.204000 | lift=33.16%\n",
      "[gated_547] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.384000 | lift=187.00%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.108000 | lift=-19.28%\n",
      "[gated_78] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.240000 | lift=170.27%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.780000 | lift=778.38%\n",
      "[jump_relu_330] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=127.70%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=127.70%\n",
      "[jump_relu_52] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=36.52%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.096000 | lift=-45.39%\n",
      "[jump_relu_779] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.220000 | lift=84.25%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.048000 | lift=-59.80%\n",
      "[jump_relu_83] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.460000 | lift=157.27%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=34.23%\n",
      "[standard_april_update_156] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.184000 | lift=1.66%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.360000 | lift=98.90%\n",
      "[standard_april_update_309] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.190000 | lift=44.60%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.174000 | lift=32.42%\n",
      "[standard_april_update_507] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.312000 | lift=122.22%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.040000 | lift=-71.51%\n",
      "[standard_april_update_54] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.300000 | lift=99.47%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=1.200000 | lift=697.87%\n",
      "[standard_april_update_733] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=240.43%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.240000 | lift=70.21%\n",
      "[standard_april_update_99] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.120000 | lift=9.29%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.276000 | lift=151.37%\n",
      "[topk_160] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=57.69%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.096000 | lift=-36.93%\n",
      "[topk_320] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.240000 | lift=112.77%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=10   | avg_overall=0.096000 | lift=-14.89%\n",
      "[topk_50] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.460000 | lift=133.98%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.096000 | lift=-51.17%\n",
      "[topk_520] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=79.37%\n",
      "         MIDctl  | level=TOPK_MID= 5  | count=5    | avg_overall=0.264000 | lift=97.31%\n",
      "[topk_80] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.224000 | lift=50.74%\n",
      "         MIDctl  | level=TOPK_MID= 1  | count=1    | avg_overall=0.960000 | lift=546.03%\n",
      "[topk_820] best_dir=UP    | level=TOPK_UP= 5   | count=4    | avg_overall=0.300000 | lift=183.70%\n",
      "         MIDctl  | level=TOPK_MID= 10 | count=9    | avg_overall=0.026667 | lift=-74.78%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "import numpy as np\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots (Gemma 2 2B, layer 12)\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_2b_it/layer12\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_2b/layer12\"\n",
    "\n",
    "# --------------------------------------------------------------------\n",
    "# Selection levels use QUANTILES and/or TOP-K instead of absolute cuts\n",
    "# --------------------------------------------------------------------\n",
    "# If you want both strategies, set both to True. If you want only one,\n",
    "# set the other to False.\n",
    "USE_QUANTILES = False\n",
    "# Upper-tail quantiles for UP (delta_confidence high end). For DOWN we mirror to lower-tail.\n",
    "# Example: 0.99 means \"select features with delta_confidence >= 99th percentile\" (UP)\n",
    "# and \"select features with delta_confidence <= 1st percentile\" (DOWN).\n",
    "QUANTILES: List[float] = [0.99, 0.95, 0.90, 0.80]\n",
    "\n",
    "USE_TOPK = True\n",
    "# Top-K sizes (by magnitude in the corresponding direction).\n",
    "# For UP: take K largest delta_confidence; for DOWN: take K most negative delta_confidence.\n",
    "# NEW (control): MID selects K features whose |delta_confidence| are the smallest (closest to 0).\n",
    "TOPK_LIST: List[int] = [1, 2, 5, 10]\n",
    "\n",
    "# ---- Non-steering detection (tunable) ----\n",
    "# A SAE is flagged as NON-STEERING if ANY of the following holds:\n",
    "#   1) max selected count across all levels/directions < MIN_SELECTION_COUNT\n",
    "#   2) best-of-both lift <= MIN_BEST_LIFT\n",
    "#   3) number of levels (across UP+DOWN) with count >= MIN_SELECTION_COUNT < MIN_LEVELS_HIT\n",
    "# Note: MID is not used in the steering qualification criteria (it's a control).\n",
    "MIN_SELECTION_COUNT   = 5     # require at least this many selected features at ANY level\n",
    "MIN_BEST_LIFT        = 0.0    # require best-of-both lift strictly greater than this (e.g., > 0.0)\n",
    "MIN_LEVELS_HIT       = 2      # how many levels achieve count >= MIN_SELECTION_COUNT\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return float(item[\"holdout\"][\"mean\"][\"overall\"])\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "\n",
    "    Note: We DO NOT drop 0.0 overall values; they are valid and part of the baseline.\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s  # keep zeros\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def build_delta_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: delta_confidence} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"delta_confidence\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"delta_confidence\"])\n",
    "            except Exception:\n",
    "                pass\n",
    "    return out\n",
    "\n",
    "\n",
    "def avg_for_selected(eval_data: Dict[str, Any], selected_ids: List[str]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - count of selected features that also have 'overall' in eval_data\n",
    "      - average 'overall' over those features (0.0 if count=0)\n",
    "    \"\"\"\n",
    "    vals: List[float] = []\n",
    "    for fid in selected_ids:\n",
    "        s = get_overall_from_eval_item(eval_data.get(fid, {}))\n",
    "        if s is not None:\n",
    "            vals.append(s)  # keep zeros\n",
    "    n = len(vals)\n",
    "    avg = (sum(vals) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection levels (Quantiles / Top-K)\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_for_up(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build UP (high end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles: label like 'Q>= 0.95'\n",
    "    - Top-K:     label like 'TOPK_UP= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (upper tail): select v >= quantile(q)\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            cut = float(np.quantile(vals, q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] >= cut]\n",
    "            levels.append((f\"Q>= {q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (largest K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_up = sorted(fids, key=lambda x: delta_map[x], reverse=True)\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_up[:max(0, min(k, len(sorted_up)))]\n",
    "            levels.append((f\"TOPK_UP= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_down(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build DOWN (negative end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles (lower tail): label like 'Q<= 0.05' meaning v <= quantile(0.05)\n",
    "      (Mirroring an upper-tail q by using (1 - q) for the lower tail.)\n",
    "    - Top-K:     label like 'TOPK_DOWN= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (lower tail): mirror\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            low_q = 1.0 - q\n",
    "            low_cut = float(np.quantile(vals, low_q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] <= low_cut]\n",
    "            levels.append((f\"Q<= {low_q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (most negative K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_down = sorted(fids, key=lambda x: delta_map[x])  # ascending => most negative first\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_down[:max(0, min(k, len(sorted_down)))]\n",
    "            levels.append((f\"TOPK_DOWN= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_mid(\n",
    "    delta_map: Dict[str, float],\n",
    "    topk_list: List[int],\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build MID (near-zero) selection levels as a control group.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Top-K MID: label like 'TOPK_MID= 10' selecting K features with smallest |delta_confidence|\n",
    "      i.e., sort by abs(delta) ascending and take the first K.\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map or (not use_topk) or (not topk_list):\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    sorted_mid = sorted(fids, key=lambda x: abs(delta_map[x]))  # closest to 0 first\n",
    "    for k in sorted(set(topk_list)):\n",
    "        sel = sorted_mid[:max(0, min(k, len(sorted_mid)))]\n",
    "        levels.append((f\"TOPK_MID= {k}\", sel))\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str,\n",
    "    order_up_labels: List[str],\n",
    "    order_down_labels: List[str],\n",
    "    order_mid_labels: List[str],\n",
    ") -> Tuple[\n",
    "    Dict[str, float],   # per-level lifts (UP)      label -> lift\n",
    "    Dict[str, float],   # per-level lifts (DOWN)    label -> lift\n",
    "    Dict[str, float],   # per-level lifts (MID)     label -> lift\n",
    "    Optional[Tuple[str, int, float, float]],  # best_up: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_down: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_mid: (label, count, avg, lift)\n",
    "    Optional[float],    # best_of_both lift (UP/DOWN only)\n",
    "    Optional[int],      # best_of_both count\n",
    "    Dict[str, int],     # per-level counts (UP)\n",
    "    Dict[str, int],     # per-level counts (DOWN)\n",
    "    Dict[str, int],     # per-level counts (MID)\n",
    "    float,              # base_avg_overall for this SAE\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, {}, None, None, None, None, None, {}, {}, {}, 0.0\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping selection levels.)\")\n",
    "        return {}, {}, {}, None, None, None, None, None, {}, {}, {}, avg_overall_all\n",
    "\n",
    "    # Build delta map\n",
    "    delta_map = build_delta_map(entropy_data)\n",
    "\n",
    "    # Compose selection levels for UP & DOWN & MID\n",
    "    up_levels   = selection_levels_for_up(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    down_levels = selection_levels_for_down(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    mid_levels  = selection_levels_for_mid(delta_map, TOPK_LIST, USE_TOPK)\n",
    "\n",
    "    # Keep maps for lifts/counts keyed by label for deterministic aggregation/printing\n",
    "    per_level_lifts_up: Dict[str, float] = {}\n",
    "    per_level_counts_up: Dict[str, int] = {}\n",
    "    per_level_lifts_down: Dict[str, float] = {}\n",
    "    per_level_counts_down: Dict[str, int] = {}\n",
    "    per_level_lifts_mid: Dict[str, float] = {}\n",
    "    per_level_counts_mid: Dict[str, int] = {}\n",
    "\n",
    "    # ---- UP section ----\n",
    "    print(\"\\n=== Selection levels (UP: high delta_confidence) ===\")\n",
    "    best_up: Optional[Tuple[str, int, float, float]] = None  # (label, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    # Ensure printing order follows order_up_labels; fallback to appending any missing labels\n",
    "    up_levels_map = {lab: ids for lab, ids in up_levels}\n",
    "    up_labels_ordered = [lab for lab in order_up_labels if lab in up_levels_map] + \\\n",
    "                        [lab for lab in up_levels_map.keys() if lab not in order_up_labels]\n",
    "\n",
    "    for label in up_labels_ordered:\n",
    "        selected = up_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_up[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_up[label] = lift\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (label, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- DOWN section ----\n",
    "    print(\"\\n=== Selection levels (DOWN: low/negative delta_confidence) ===\")\n",
    "    best_down: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    down_levels_map = {lab: ids for lab, ids in down_levels}\n",
    "    down_labels_ordered = [lab for lab in order_down_labels if lab in down_levels_map] + \\\n",
    "                          [lab for lab in down_levels_map.keys() if lab not in order_down_labels]\n",
    "\n",
    "    for label in down_labels_ordered:\n",
    "        selected = down_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_down[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_down[label] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (label, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- MID (control) section ----\n",
    "    print(\"\\n=== Selection levels (MID: near-zero |delta_confidence|, control) ===\")\n",
    "    best_mid: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_mid_avg = float(\"-inf\")\n",
    "    best_mid_count = -1\n",
    "\n",
    "    mid_levels_map = {lab: ids for lab, ids in mid_levels}\n",
    "    mid_labels_ordered = [lab for lab in order_mid_labels if lab in mid_levels_map] + \\\n",
    "                         [lab for lab in mid_levels_map.keys() if lab not in order_mid_labels]\n",
    "\n",
    "    for label in mid_labels_ordered:\n",
    "        selected = mid_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_mid[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_mid[label] = lift\n",
    "                if (avg_sub > best_mid_avg) or (avg_sub == best_mid_avg and n > best_mid_count):\n",
    "                    best_mid = (label, n, avg_sub, lift)\n",
    "                    best_mid_avg = avg_sub\n",
    "                    best_mid_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (UP/DOWN only) per SAE\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    best_of_both_count: Optional[int] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        if best_up[3] >= best_down[3]:\n",
    "            best_of_both_lift = best_up[3]\n",
    "            best_of_both_count = best_up[1]\n",
    "            direction = \"UP\"\n",
    "        else:\n",
    "            best_of_both_lift = best_down[3]\n",
    "            best_of_both_count = best_down[1]\n",
    "            direction = \"DOWN\"\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "        best_of_both_count = best_up[1]\n",
    "        direction = \"UP\"\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "        best_of_both_count = best_down[1]\n",
    "        direction = \"DOWN\"\n",
    "    else:\n",
    "        direction = \"N/A\"\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best levels (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP   : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : level={best_up[0]:<12} | count={best_up[1]:<4} avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : level={best_down[0]:<12} | count={best_down[1]:<4} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_mid is None:\n",
    "        print(\"Best MID  : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best MID  : level={best_mid[0]:<12} | count={best_mid[1]:<4} avg_overall={best_mid[2]:.6f}  lift={best_mid[3]:.2f}%\")\n",
    "\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH (UP/DOWN): N/A\")\n",
    "    else:\n",
    "        print(f\"Best of BOTH (UP/DOWN): {best_of_both_lift:.2f}%  (direction={direction}) | count={best_of_both_count}\")\n",
    "\n",
    "    return (\n",
    "        per_level_lifts_up,\n",
    "        per_level_lifts_down,\n",
    "        per_level_lifts_mid,\n",
    "        best_up,\n",
    "        best_down,\n",
    "        best_mid,\n",
    "        best_of_both_lift,\n",
    "        best_of_both_count,\n",
    "        per_level_counts_up,\n",
    "        per_level_counts_down,\n",
    "        per_level_counts_mid,\n",
    "        avg_overall_all,\n",
    "    )\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Build the global (ordered) label lists we will use for consistent printing/aggregation\n",
    "    order_up_labels: List[str] = []\n",
    "    order_down_labels: List[str] = []\n",
    "    order_mid_labels: List[str] = []  # NEW\n",
    "\n",
    "    if USE_QUANTILES and QUANTILES:\n",
    "        for q in sorted(set(QUANTILES), reverse=True):\n",
    "            order_up_labels.append(f\"Q>= {q:.2f}\")\n",
    "            order_down_labels.append(f\"Q<= {1.0 - q:.2f}\")\n",
    "    if USE_TOPK and TOPK_LIST:\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            order_up_labels.append(f\"TOPK_UP= {k}\")\n",
    "            order_down_labels.append(f\"TOPK_DOWN= {k}\")\n",
    "            order_mid_labels.append(f\"TOPK_MID= {k}\")  # NEW\n",
    "\n",
    "    # Across-SAEs per-level aggregations (unfiltered)\n",
    "    def init_agg(levels: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {lab: {\"sum\": 0.0, \"count\": 0.0} for lab in levels}\n",
    "\n",
    "    across_up = init_agg(order_up_labels)\n",
    "    across_down = init_agg(order_down_labels)\n",
    "    across_mid = init_agg(order_mid_labels)\n",
    "\n",
    "    # Per-SAE best stats (unfiltered)\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_mid_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "    best_both_counts: List[int] = []\n",
    "    pos_up = pos_down = pos_mid = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_mid = saes_with_both = 0\n",
    "\n",
    "    # Keep per-SAE records for later filtered summary\n",
    "    sae_records: List[Dict[str, Any]] = []\n",
    "    non_steering: List[Tuple[str, List[str], Dict[str, Any]]] = []\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        (\n",
    "            per_up,\n",
    "            per_down,\n",
    "            per_mid,\n",
    "            best_up,\n",
    "            best_down,\n",
    "            best_mid,\n",
    "            best_both_lift,\n",
    "            best_both_count,\n",
    "            cnts_up,\n",
    "            cnts_down,\n",
    "            cnts_mid,\n",
    "            base_avg,\n",
    "        ) = process_one_sae(sae_name, order_up_labels, order_down_labels, order_mid_labels)\n",
    "\n",
    "        # Save record\n",
    "        sae_records.append(\n",
    "            {\n",
    "                \"name\": sae_name,\n",
    "                \"per_up\": per_up,\n",
    "                \"per_down\": per_down,\n",
    "                \"per_mid\": per_mid,                 # NEW\n",
    "                \"best_up\": best_up,\n",
    "                \"best_down\": best_down,\n",
    "                \"best_mid\": best_mid,               # NEW\n",
    "                \"best_both_lift\": best_both_lift,   # UP/DOWN only\n",
    "                \"best_both_count\": best_both_count,\n",
    "                \"cnts_up\": cnts_up,\n",
    "                \"cnts_down\": cnts_down,\n",
    "                \"cnts_mid\": cnts_mid,               # NEW\n",
    "                \"base_avg\": base_avg,\n",
    "            }\n",
    "        )\n",
    "\n",
    "        # Aggregate per-level lifts (UP/DOWN/MID) for unfiltered summary\n",
    "        for lab, lift in per_up.items():\n",
    "            if lab not in across_up:\n",
    "                across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_up[lab][\"sum\"] += lift\n",
    "            across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in per_down.items():\n",
    "            if lab not in across_down:\n",
    "                across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_down[lab][\"sum\"] += lift\n",
    "            across_down[lab][\"count\"] += 1\n",
    "        for lab, lift in per_mid.items():  # NEW\n",
    "            if lab not in across_mid:\n",
    "                across_mid[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_mid[lab][\"sum\"] += lift\n",
    "            across_mid[lab][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction/MID BEST (unfiltered)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if best_mid is not None:  # NEW\n",
    "            saes_with_mid += 1\n",
    "            best_mid_lifts.append(best_mid[3])\n",
    "            if best_mid[3] > 0:\n",
    "                pos_mid += 1\n",
    "\n",
    "        if (best_both_lift is not None) and isinstance(best_both_lift, float):\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both_lift)\n",
    "            if isinstance(best_both_count, int):\n",
    "                best_both_counts.append(best_both_count)\n",
    "            if best_both_lift > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "        # ---------------------------\n",
    "        # Non-steering detection (based on UP/DOWN only)\n",
    "        # ---------------------------\n",
    "        reasons: List[str] = []\n",
    "        max_count_up = max(cnts_up.values(), default=0)\n",
    "        max_count_down = max(cnts_down.values(), default=0)\n",
    "        max_count_both = max(max_count_up, max_count_down)\n",
    "\n",
    "        # How many levels hit MIN_SELECTION_COUNT (across both directions)\n",
    "        hits_up = sum(1 for c in cnts_up.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_down = sum(1 for c in cnts_down.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_both = hits_up + hits_down\n",
    "\n",
    "        # Best-of-both lift (already computed)\n",
    "        local_best_of_both_lift = best_both_lift\n",
    "\n",
    "        # Condition 1: insufficient selected features at any level\n",
    "        if max_count_both < MIN_SELECTION_COUNT:\n",
    "            reasons.append(f\"insufficient selected features: max_count={max_count_both} < {MIN_SELECTION_COUNT}\")\n",
    "\n",
    "        # Condition 2: no positive (or required) lift anywhere\n",
    "        if (local_best_of_both_lift is None) or (local_best_of_both_lift <= MIN_BEST_LIFT):\n",
    "            reasons.append(\n",
    "                f\"no level yields lift > {MIN_BEST_LIFT:.2f}% (best_of_both={local_best_of_both_lift if local_best_of_both_lift is not None else 'N/A'})\"\n",
    "            )\n",
    "\n",
    "        # Condition 3: stability across levels is poor\n",
    "        if hits_both < MIN_LEVELS_HIT:\n",
    "            reasons.append(\n",
    "                f\"unstable coverage: levels_with_count>={MIN_SELECTION_COUNT} = {hits_both} < {MIN_LEVELS_HIT}\"\n",
    "            )\n",
    "\n",
    "        if len(reasons) > 0:\n",
    "            non_steering.append((\n",
    "                sae_name,\n",
    "                reasons,\n",
    "                {\n",
    "                    \"max_count_up\": max_count_up,\n",
    "                    \"max_count_down\": max_count_down,\n",
    "                    \"best_up_lift\": (best_up[3] if best_up else None),\n",
    "                    \"best_down_lift\": (best_down[3] if best_down else None),\n",
    "                    \"best_of_both_lift\": local_best_of_both_lift,\n",
    "                    \"hits_up\": hits_up,\n",
    "                    \"hits_down\": hits_down,\n",
    "                }\n",
    "            ))\n",
    "\n",
    "    # =================================================================================\n",
    "    # Unfiltered summary across ALL SAEs (baseline reference)\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and control MID)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-level averages: UP\n",
    "    print(\"Per-level average lift across SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: DOWN\n",
    "    print(\"\\nPer-level average lift across SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: MID (control)\n",
    "    print(\"\\nPer-level average lift across SAEs (MID levels, control):\")\n",
    "    for lab in order_mid_labels:\n",
    "        cnt = int(across_mid.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_mid[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Compute base across ALL SAEs (fixed baseline definition: average of each SAE's all-feature mean)\n",
    "    all_base_vals = [rec[\"base_avg\"] for rec in sae_records]\n",
    "    base_across_all = (sum(all_base_vals) / len(all_base_vals)) if all_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (ALL)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (ALL) ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_mid == 0:\n",
    "        print(\"MID  : No SAE produced a valid BEST selection.\")\n",
    "        avg_mid_best_all = 0.0\n",
    "        mid_after_mean_all = 0.0\n",
    "    else:\n",
    "        avg_mid_best_all = sum(best_mid_lifts) / len(best_mid_lifts)\n",
    "        pct_mid_pos = (pos_mid / saes_with_mid) * 100.0\n",
    "        print(f\"MID  : SAEs with positive lift: {pos_mid} / {saes_with_mid} ({pct_mid_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (MID, control): {avg_mid_best_all:.2f}%\")\n",
    "\n",
    "        # Mean of per-SAE \"after\" for MID best (control)\n",
    "        mid_after_list_all = []\n",
    "        for rec in sae_records:\n",
    "            mid_best = rec.get(\"best_mid\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if (mid_best is not None) and isinstance(mid_best[3], float):\n",
    "                mid_after_list_all.append(base * (1.0 + mid_best[3] / 100.0))\n",
    "        mid_after_mean_all = (sum(mid_after_list_all) / len(mid_after_list_all)) if mid_after_list_all else 0.0\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH (UP/DOWN): No SAE produced a valid BEST-of-both selection.\")\n",
    "        avg_both_best_all = 0.0\n",
    "        avg_both_count_all = 0.0\n",
    "        both_after_mean_all = 0.0\n",
    "    else:\n",
    "        avg_both_best_all = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        avg_both_count_all = (sum(best_both_counts) / len(best_both_counts)) if best_both_counts else 0.0\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "\n",
    "        # Mean of per-SAE \"after\" for UP/DOWN best-of-both\n",
    "        after_list_all = []\n",
    "        for rec in sae_records:\n",
    "            lift = rec.get(\"best_both_lift\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if isinstance(lift, float):\n",
    "                after_list_all.append(base * (1.0 + lift / 100.0))\n",
    "        both_after_mean_all = (sum(after_list_all) / len(after_list_all)) if after_list_all else 0.0\n",
    "\n",
    "        print(f\"BOTH (UP/DOWN): SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "\n",
    "    # Print final comparative lines (ALL)\n",
    "    print(\"\\n--- Comparative steering score (ALL, mean of per-SAE after) ---\")\n",
    "    print(f\"Base steering score across SAEs:                     {base_across_all:.6f}\")\n",
    "    print(f\"After selection (Best of UP/DOWN) across SAEs:       {both_after_mean_all:.6f}\")\n",
    "    print(f\"After selection (MID control, best per SAE) across:  {mid_after_mean_all:.6f}\")\n",
    "    print(f\"Avg BEST lift (UP/DOWN best-of-both):               {avg_both_best_all:.2f}%   | Avg selected count: { (sum(best_both_counts)/len(best_both_counts)) if best_both_counts else 0.0 :.2f}\")\n",
    "    print(f\"Avg BEST lift (MID control):                         {avg_mid_best_all:.2f}%\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Non-steering report\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SAEs flagged as NON-STEERING by the configured criteria\")\n",
    "    print(\"- Criteria:\")\n",
    "    print(f\"  1) max selected count across all levels/directions < {MIN_SELECTION_COUNT}\")\n",
    "    print(f\"  2) best-of-both lift <= {MIN_BEST_LIFT:.2f}%\")\n",
    "    print(f\"  3) levels achieving count>={MIN_SELECTION_COUNT} across UP+DOWN < {MIN_LEVELS_HIT}\")\n",
    "    print(\"- Note: MID is a control and not used for filtering.\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    non_names = set()\n",
    "    if not non_steering:\n",
    "        print(\"All SAEs pass the steering capability criteria.\")\n",
    "    else:\n",
    "        for name, reasons, stats in non_steering:\n",
    "            non_names.add(name)\n",
    "            print(f\"[NON-STEERING] {name}\")\n",
    "            print(f\"  Reasons:\")\n",
    "            for r in reasons:\n",
    "                print(f\"    - {r}\")\n",
    "            print(f\"  Stats: max_count_up={stats['max_count_up']}  max_count_down={stats['max_count_down']}\")\n",
    "            print(f\"         best_up_lift={stats['best_up_lift']}  best_down_lift={stats['best_down_lift']}  best_of_both={stats['best_of_both_lift']}\")\n",
    "            print(f\"         levels_hit(up)={stats['hits_up']}  levels_hit(down)={stats['hits_down']}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # FILTERED summary across STEERING-QUALIFIED SAEs only\n",
    "    # =================================================================================\n",
    "    qualified = [rec for rec in sae_records if rec[\"name\"] not in non_names]\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    if not qualified:\n",
    "        print(\"No SAE remains after filtering; cannot compute qualified summary.\")\n",
    "        return\n",
    "\n",
    "    # Per-level averages across qualified\n",
    "    def init_agg_like(template_keys: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {k: {\"sum\": 0.0, \"count\": 0.0} for k in template_keys}\n",
    "\n",
    "    q_across_up = init_agg_like(order_up_labels)\n",
    "    q_across_down = init_agg_like(order_down_labels)\n",
    "    q_across_mid = init_agg_like(order_mid_labels)\n",
    "\n",
    "    q_best_up_lifts: List[float] = []\n",
    "    q_best_down_lifts: List[float] = []\n",
    "    q_best_mid_lifts: List[float] = []\n",
    "    q_best_both_lifts: List[float] = []\n",
    "    q_best_both_counts: List[int] = []\n",
    "    q_pos_up = q_pos_down = q_pos_mid = q_pos_both = 0\n",
    "    q_saes_with_up = q_saes_with_down = q_saes_with_mid = q_saes_with_both = 0\n",
    "\n",
    "    for rec in qualified:\n",
    "        # per-level lifts\n",
    "        for lab, lift in rec[\"per_up\"].items():\n",
    "            if lab not in q_across_up:\n",
    "                q_across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_up[lab][\"sum\"] += lift\n",
    "            q_across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_down\"].items():\n",
    "            if lab not in q_across_down:\n",
    "                q_across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_down[lab][\"sum\"] += lift\n",
    "            q_across_down[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_mid\"].items():\n",
    "            if lab not in q_across_mid:\n",
    "                q_across_mid[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_mid[lab][\"sum\"] += lift\n",
    "            q_across_mid[lab][\"count\"] += 1\n",
    "\n",
    "        # best per-direction / best-of-both / best-mid\n",
    "        if rec[\"best_up\"] is not None:\n",
    "            q_saes_with_up += 1\n",
    "            q_best_up_lifts.append(rec[\"best_up\"][3])\n",
    "            if rec[\"best_up\"][3] > 0:\n",
    "                q_pos_up += 1\n",
    "        if rec[\"best_down\"] is not None:\n",
    "            q_saes_with_down += 1\n",
    "            q_best_down_lifts.append(rec[\"best_down\"][3])\n",
    "            if rec[\"best_down\"][3] > 0:\n",
    "                q_pos_down += 1\n",
    "\n",
    "        if (rec[\"best_both_lift\"] is not None) and isinstance(rec[\"best_both_lift\"], float):\n",
    "            q_saes_with_both += 1\n",
    "            q_best_both_lifts.append(rec[\"best_both_lift\"])\n",
    "            if isinstance(rec[\"best_both_count\"], int):\n",
    "                q_best_both_counts.append(rec[\"best_both_count\"])\n",
    "            if rec[\"best_both_lift\"] > 0:\n",
    "                q_pos_both += 1\n",
    "\n",
    "        if rec[\"best_mid\"] is not None:\n",
    "            q_saes_with_mid += 1\n",
    "            q_best_mid_lifts.append(rec[\"best_mid\"][3])\n",
    "            if rec[\"best_mid\"][3] > 0:\n",
    "                q_pos_mid += 1\n",
    "\n",
    "    # Print per-level averages (qualified)\n",
    "    print(\"Per-level average lift across QUALIFIED SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(q_across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(q_across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (MID levels, control):\")\n",
    "    for lab in order_mid_labels:\n",
    "        cnt = int(q_across_mid.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_mid[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Base steering score across QUALIFIED SAEs (same definition as ALL, but over the subset)\n",
    "    q_base_vals = [rec[\"base_avg\"] for rec in qualified]\n",
    "    base_across_qualified = (sum(q_base_vals) / len(q_base_vals)) if q_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (qualified)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (QUALIFIED) ---\")\n",
    "    if q_saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_up_best = (sum(q_best_up_lifts) / len(q_best_up_lifts)) if q_best_up_lifts else 0.0\n",
    "        q_pct_up_pos = (q_pos_up / q_saes_with_up) * 100.0 if q_saes_with_up > 0 else 0.0\n",
    "        print(f\"UP   : SAEs with positive lift: {q_pos_up} / {q_saes_with_up} ({q_pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {q_avg_up_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_down_best = (sum(q_best_down_lifts) / len(q_best_down_lifts)) if q_best_down_lifts else 0.0\n",
    "        q_pct_down_pos = (q_pos_down / q_saes_with_down) * 100.0 if q_saes_with_down > 0 else 0.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {q_pos_down} / {q_saes_with_down} ({q_pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {q_avg_down_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_mid == 0:\n",
    "        print(\"MID  : No SAE produced a valid BEST selection.\")\n",
    "        q_avg_mid_best = 0.0\n",
    "        q_mid_after_mean = 0.0\n",
    "    else:\n",
    "        q_avg_mid_best = (sum(q_best_mid_lifts) / len(q_best_mid_lifts)) if q_best_mid_lifts else 0.0\n",
    "        q_pct_mid_pos = (q_pos_mid / q_saes_with_mid) * 100.0 if q_saes_with_mid > 0 else 0.0\n",
    "        print(f\"MID  : SAEs with positive lift: {q_pos_mid} / {q_saes_with_mid} ({q_pct_mid_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (MID, control): {q_avg_mid_best:.2f}%\")\n",
    "\n",
    "        # Mean of per-SAE after (MID best)\n",
    "        q_mid_after_list = []\n",
    "        for rec in qualified:\n",
    "            mid_best = rec.get(\"best_mid\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if (mid_best is not None) and isinstance(mid_best[3], float):\n",
    "                q_mid_after_list.append(base * (1.0 + mid_best[3] / 100.0))\n",
    "        q_mid_after_mean = (sum(q_mid_after_list) / len(q_mid_after_list)) if q_mid_after_list else 0.0\n",
    "\n",
    "    if q_saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        q_avg_both_best = 0.0\n",
    "        q_avg_both_count = 0.0\n",
    "        q_after_mean = 0.0\n",
    "    else:\n",
    "        q_avg_both_best = (sum(q_best_both_lifts) / len(q_best_both_lifts)) if q_best_both_lifts else 0.0\n",
    "        q_avg_both_count = (sum(q_best_both_counts) / len(q_best_both_counts)) if q_best_both_counts else 0.0\n",
    "        q_pct_both_pos = (q_pos_both / q_saes_with_both) * 100.0 if q_saes_with_both > 0 else 0.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {q_pos_both} / {q_saes_with_both} ({q_pct_both_pos:.2f}%)\")\n",
    "\n",
    "        # Mean of per-SAE after (best of UP/DOWN)\n",
    "        q_after_list = []\n",
    "        for rec in qualified:\n",
    "            lift = rec.get(\"best_both_lift\", None)\n",
    "            base = rec.get(\"base_avg\", 0.0)\n",
    "            if isinstance(lift, float):\n",
    "                q_after_list.append(base * (1.0 + lift / 100.0))\n",
    "        q_after_mean = (sum(q_after_list) / len(q_after_list)) if q_after_list else 0.0\n",
    "\n",
    "    # Comparative lines (qualified)\n",
    "    print(\"\\n--- Comparative steering score (QUALIFIED, mean of per-SAE after) ---\")\n",
    "    print(f\"Base steering score across SAEs:                     {base_across_qualified:.6f}\")\n",
    "    print(f\"After selection (Best of UP/DOWN) across SAEs:       {q_after_mean:.6f}\")\n",
    "    print(f\"After selection (MID control, best per SAE) across:  {q_mid_after_mean:.6f}\")\n",
    "    print(f\"      Average BEST lift across SAEs (Best of UP/DOWN): {q_avg_both_best:.2f}%\")\n",
    "    print(f\"      Average selected feature count per SAE (UP/DOWN): {q_avg_both_count:.2f}\")\n",
    "    print(f\"      Average BEST lift across SAEs (MID control):     {q_avg_mid_best:.2f}%\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Per-qualified-SAE steering result details\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"STEERING RESULTS FOR QUALIFIED SAEs (best levels per SAE)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for rec in qualified:\n",
    "        name = rec[\"name\"]\n",
    "        best_up = rec[\"best_up\"]\n",
    "        best_down = rec[\"best_down\"]\n",
    "        best_mid = rec[\"best_mid\"]\n",
    "\n",
    "        # UP vs DOWN best-of-both\n",
    "        best_dir = None\n",
    "        best_tuple = None  # (label, count, avg, lift)\n",
    "        if best_up is not None and best_down is not None:\n",
    "            best_dir = \"UP\" if best_up[3] >= best_down[3] else \"DOWN\"\n",
    "            best_tuple = best_up if best_up[3] >= best_down[3] else best_down\n",
    "        elif best_up is not None:\n",
    "            best_dir = \"UP\"\n",
    "            best_tuple = best_up\n",
    "        elif best_down is not None:\n",
    "            best_dir = \"DOWN\"\n",
    "            best_tuple = best_down\n",
    "\n",
    "        # Print UP/DOWN best and MID best side-by-side where possible\n",
    "        if best_tuple is None and best_mid is None:\n",
    "            print(f\"[{name}] No valid selections found.\")\n",
    "        else:\n",
    "            if best_tuple is not None:\n",
    "                lab, cnt, avg_overall, lift = best_tuple\n",
    "                print(f\"[{name}] best_dir={best_dir:<5} | level={lab:<12} | count={cnt:<4} | avg_overall={avg_overall:.6f} | lift={lift:.2f}%\")\n",
    "            else:\n",
    "                print(f\"[{name}] best_dir= N/A  | level= N/A         | count= N/A  | avg_overall= N/A      | lift= N/A\")\n",
    "\n",
    "            if best_mid is not None:\n",
    "                lab_m, cnt_m, avg_m, lift_m = best_mid\n",
    "                print(f\"         MIDctl  | level={lab_m:<12} | count={cnt_m:<4} | avg_overall={avg_m:.6f} | lift={lift_m:.2f}%\")\n",
    "            else:\n",
    "                print(f\"         MIDctl  | level= N/A         | count= N/A  | avg_overall= N/A      | lift= N/A\")\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "52db4901",
   "metadata": {},
   "source": [
    "## 1.3 Analysis of Different Architecture"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8196d908",
   "metadata": {},
   "source": [
    "# 2 Gemma 2 9b L20"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "afab126d",
   "metadata": {},
   "source": [
    "## 2.1 Token Conf Distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddaf01f9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "a3d053ba",
   "metadata": {},
   "source": [
    "## 2.2 Threshold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4ee30f9c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.104000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.540000 [> overall]\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.540000 [> overall]\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.270000 [> overall]\n",
      "delta_confidence <= -1.0  : count=4     avg_overall=0.135000 [> overall]\n",
      "delta_confidence <= -0.9  : count=4     avg_overall=0.135000 [> overall]\n",
      "delta_confidence <= -0.8  : count=7     avg_overall=0.077143\n",
      "delta_confidence <= -0.7  : count=15    avg_overall=0.113333 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=1.3 | count=1 avg_overall=0.540000  lift=419.23%\n",
      "Best of BOTH: 419.23%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.183000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.720000 [> overall]\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.720000 [> overall]\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.600000 [> overall]\n",
      "delta_confidence <= -1.0  : count=4     avg_overall=0.640000 [> overall]\n",
      "delta_confidence <= -0.9  : count=6     avg_overall=0.466667 [> overall]\n",
      "delta_confidence <= -0.8  : count=9     avg_overall=0.371111 [> overall]\n",
      "delta_confidence <= -0.7  : count=10    avg_overall=0.334000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.9  | count=2  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=1.3 | count=1 avg_overall=0.720000  lift=293.44%\n",
      "Best of BOTH: 293.44%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.171800\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=3     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=9     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=16    avg_overall=0.030000\n",
      "delta_confidence <= -1.1  : count=16    avg_overall=0.030000\n",
      "delta_confidence <= -1.0  : count=19    avg_overall=0.066316\n",
      "delta_confidence <= -0.9  : count=22    avg_overall=0.090000\n",
      "delta_confidence <= -0.8  : count=27    avg_overall=0.111111\n",
      "delta_confidence <= -0.7  : count=32    avg_overall=0.127500\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=3  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.7 | count=32 avg_overall=0.127500  lift=-25.79%\n",
      "Best of BOTH: -25.79%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.169200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=3     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=5     avg_overall=0.168000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.7 | count=5 avg_overall=0.168000  lift=-0.71%\n",
      "Best of BOTH: -0.71%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.208600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=3     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=4     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=5     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=6     avg_overall=0.120000\n",
      "delta_confidence <= -1.2  : count=8     avg_overall=0.120000\n",
      "delta_confidence <= -1.1  : count=9     avg_overall=0.106667\n",
      "delta_confidence <= -1.0  : count=16    avg_overall=0.117500\n",
      "delta_confidence <= -0.9  : count=22    avg_overall=0.129091\n",
      "delta_confidence <= -0.8  : count=25    avg_overall=0.123200\n",
      "delta_confidence <= -0.7  : count=31    avg_overall=0.180000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=5  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.7 | count=31 avg_overall=0.180000  lift=-13.71%\n",
      "Best of BOTH: -13.71%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.132000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=2     avg_overall=0.120000\n",
      "delta_confidence <= -0.8  : count=4     avg_overall=0.060000\n",
      "delta_confidence <= -0.7  : count=7     avg_overall=0.102857\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.8  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.9 | count=2 avg_overall=0.120000  lift=-9.09%\n",
      "Best of BOTH: -9.09%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_1070\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.123200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=2     avg_overall=0.150000 [> overall]\n",
      "delta_confidence <= -1.2  : count=2     avg_overall=0.150000 [> overall]\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.150000 [> overall]\n",
      "delta_confidence <= -1.0  : count=3     avg_overall=0.180000 [> overall]\n",
      "delta_confidence <= -0.9  : count=5     avg_overall=0.204000 [> overall]\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.157500 [> overall]\n",
      "delta_confidence <= -0.7  : count=8     avg_overall=0.157500 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.9 | count=5 avg_overall=0.204000  lift=65.58%\n",
      "Best of BOTH: 65.58%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.138600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=4     avg_overall=0.120000\n",
      "delta_confidence <= -1.2  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -1.1  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -1.0  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -0.9  : count=6     avg_overall=0.120000\n",
      "delta_confidence <= -0.8  : count=9     avg_overall=0.193333 [> overall]\n",
      "delta_confidence <= -0.7  : count=13    avg_overall=0.189231 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=0.8 | count=9 avg_overall=0.193333  lift=39.49%\n",
      "Best of BOTH: 39.49%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_360\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.131400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=2     avg_overall=0.120000\n",
      "delta_confidence <= -0.8  : count=2     avg_overall=0.120000\n",
      "delta_confidence <= -0.7  : count=6     avg_overall=0.040000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.9 | count=2 avg_overall=0.120000  lift=-8.68%\n",
      "Best of BOTH: -8.68%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_53\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.090000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.7  : count=1     avg_overall=0.000000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=1.2 | count=1 avg_overall=0.000000  lift=-100.00%\n",
      "Best of BOTH: -100.00%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_573\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.120000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -1.1  : count=7     avg_overall=0.068571\n",
      "delta_confidence <= -1.0  : count=9     avg_overall=0.053333\n",
      "delta_confidence <= -0.9  : count=12    avg_overall=0.040000\n",
      "delta_confidence <= -0.8  : count=12    avg_overall=0.040000\n",
      "delta_confidence <= -0.7  : count=17    avg_overall=0.028235\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=1.2 | count=5 avg_overall=0.096000  lift=-20.00%\n",
      "Best of BOTH: -20.00%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_85\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.130200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=3     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=3     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=6     avg_overall=0.040000\n",
      "delta_confidence <= -0.7  : count=7     avg_overall=0.034286\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=0.8 | count=6 avg_overall=0.040000  lift=-69.28%\n",
      "Best of BOTH: -69.28%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_164\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.097600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=2     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -1.2  : count=2     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -1.1  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -1.0  : count=7     avg_overall=0.102857 [> overall]\n",
      "delta_confidence <= -0.9  : count=9     avg_overall=0.080000\n",
      "delta_confidence <= -0.8  : count=10    avg_overall=0.096000\n",
      "delta_confidence <= -0.7  : count=11    avg_overall=0.109091 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.3  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=1.3 | count=2 avg_overall=0.240000  lift=145.90%\n",
      "Best of BOTH: 145.90%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_327\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.109400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.240000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=5     avg_overall=0.048000\n",
      "delta_confidence <= -0.9  : count=9     avg_overall=0.113333 [> overall]\n",
      "delta_confidence <= -0.8  : count=13    avg_overall=0.078462\n",
      "delta_confidence <= -0.7  : count=16    avg_overall=0.063750\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.240000  lift=119.38%\n",
      "Best DOWN : th=0.9 | count=9 avg_overall=0.113333  lift=3.60%\n",
      "Best of BOTH: 119.38%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_51\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.111000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.240000 [> overall]\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.240000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=3     avg_overall=0.080000\n",
      "delta_confidence <= -1.2  : count=10    avg_overall=0.072000\n",
      "delta_confidence <= -1.1  : count=12    avg_overall=0.140000 [> overall]\n",
      "delta_confidence <= -1.0  : count=15    avg_overall=0.112000 [> overall]\n",
      "delta_confidence <= -0.9  : count=15    avg_overall=0.112000 [> overall]\n",
      "delta_confidence <= -0.8  : count=20    avg_overall=0.126000 [> overall]\n",
      "delta_confidence <= -0.7  : count=26    avg_overall=0.124615 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=1  avg_overall=0.240000  lift=116.22%\n",
      "Best DOWN : th=1.1 | count=12 avg_overall=0.140000  lift=26.13%\n",
      "Best of BOTH: 116.22%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_529\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.093600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -0.9  : count=3     avg_overall=0.000000\n",
      "delta_confidence <= -0.8  : count=4     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -0.7  : count=5     avg_overall=0.096000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.8 | count=4 avg_overall=0.120000  lift=28.21%\n",
      "Best of BOTH: 28.21%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_786\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.124400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=3     avg_overall=0.080000\n",
      "delta_confidence >= 0.7   : count=6     avg_overall=0.113333\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=6     avg_overall=0.120000\n",
      "delta_confidence <= -1.2  : count=6     avg_overall=0.120000\n",
      "delta_confidence <= -1.1  : count=7     avg_overall=0.102857\n",
      "delta_confidence <= -1.0  : count=8     avg_overall=0.090000\n",
      "delta_confidence <= -0.9  : count=11    avg_overall=0.065455\n",
      "delta_confidence <= -0.8  : count=16    avg_overall=0.045000\n",
      "delta_confidence <= -0.7  : count=17    avg_overall=0.042353\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=6  avg_overall=0.113333  lift=-8.90%\n",
      "Best DOWN : th=1.3 | count=6 avg_overall=0.120000  lift=-3.54%\n",
      "Best of BOTH: -3.54%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_82\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.143200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=3     avg_overall=0.100000\n",
      "delta_confidence <= -1.0  : count=6     avg_overall=0.050000\n",
      "delta_confidence <= -0.9  : count=6     avg_overall=0.050000\n",
      "delta_confidence <= -0.8  : count=10    avg_overall=0.102000\n",
      "delta_confidence <= -0.7  : count=11    avg_overall=0.092727\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=0.8 | count=10 avg_overall=0.102000  lift=-28.77%\n",
      "Best of BOTH: -28.77%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_108\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.180400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=4     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=4     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=6     avg_overall=0.040000\n",
      "delta_confidence <= -1.0  : count=10    avg_overall=0.132000\n",
      "delta_confidence <= -0.9  : count=11    avg_overall=0.120000\n",
      "delta_confidence <= -0.8  : count=18    avg_overall=0.103333\n",
      "delta_confidence <= -0.7  : count=25    avg_overall=0.105600\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=1.0 | count=10 avg_overall=0.132000  lift=-26.83%\n",
      "Best of BOTH: -26.83%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_167\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.152400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=3     avg_overall=0.180000 [> overall]\n",
      "delta_confidence <= -1.2  : count=8     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -1.1  : count=9     avg_overall=0.213333 [> overall]\n",
      "delta_confidence <= -1.0  : count=13    avg_overall=0.166154 [> overall]\n",
      "delta_confidence <= -0.9  : count=16    avg_overall=0.150000\n",
      "delta_confidence <= -0.8  : count=16    avg_overall=0.150000\n",
      "delta_confidence <= -0.7  : count=18    avg_overall=0.133333\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.0  | count=2  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=1.2 | count=8 avg_overall=0.240000  lift=57.48%\n",
      "Best of BOTH: 57.48%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_321\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=4     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -1.2  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -1.1  : count=6     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -1.0  : count=7     avg_overall=0.102857\n",
      "delta_confidence <= -0.9  : count=8     avg_overall=0.090000\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.090000\n",
      "delta_confidence <= -0.7  : count=10    avg_overall=0.120000 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=0.7 | count=10 avg_overall=0.120000  lift=0.50%\n",
      "Best of BOTH: 0.50%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_523\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=1     avg_overall=0.480000 [> overall]\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.480000 [> overall]\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.360000 [> overall]\n",
      "delta_confidence <= -1.0  : count=3     avg_overall=0.240000 [> overall]\n",
      "delta_confidence <= -0.9  : count=7     avg_overall=0.180000 [> overall]\n",
      "delta_confidence <= -0.8  : count=9     avg_overall=0.140000 [> overall]\n",
      "delta_confidence <= -0.7  : count=11    avg_overall=0.136364 [> overall]\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=1.3 | count=1 avg_overall=0.480000  lift=303.36%\n",
      "Best of BOTH: 303.36%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_61\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.138200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=1     avg_overall=0.780000 [> overall]\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.780000 [> overall]\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.780000 [> overall]\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.390000 [> overall]\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.390000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=4     avg_overall=0.120000\n",
      "delta_confidence <= -1.2  : count=6     avg_overall=0.080000\n",
      "delta_confidence <= -1.1  : count=10    avg_overall=0.048000\n",
      "delta_confidence <= -1.0  : count=11    avg_overall=0.065455\n",
      "delta_confidence <= -0.9  : count=13    avg_overall=0.092308\n",
      "delta_confidence <= -0.8  : count=15    avg_overall=0.080000\n",
      "delta_confidence <= -0.7  : count=19    avg_overall=0.096842\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.1  | count=1  avg_overall=0.780000  lift=464.40%\n",
      "Best DOWN : th=1.3 | count=4 avg_overall=0.120000  lift=-13.17%\n",
      "Best of BOTH: 464.40%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_762\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.129200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=0     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=1     avg_overall=0.480000 [> overall]\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.360000 [> overall]\n",
      "delta_confidence <= -1.0  : count=6     avg_overall=0.160000 [> overall]\n",
      "delta_confidence <= -0.9  : count=7     avg_overall=0.137143 [> overall]\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.120000\n",
      "delta_confidence <= -0.7  : count=12    avg_overall=0.080000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=1.2 | count=1 avg_overall=0.480000  lift=271.52%\n",
      "Best of BOTH: 271.52%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.208000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=1     avg_overall=0.960000 [> overall]\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=10    avg_overall=0.120000\n",
      "delta_confidence <= -1.2  : count=10    avg_overall=0.120000\n",
      "delta_confidence <= -1.1  : count=11    avg_overall=0.201818\n",
      "delta_confidence <= -1.0  : count=13    avg_overall=0.241538 [> overall]\n",
      "delta_confidence <= -0.9  : count=20    avg_overall=0.157000\n",
      "delta_confidence <= -0.8  : count=27    avg_overall=0.154074\n",
      "delta_confidence <= -0.7  : count=37    avg_overall=0.164865\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=1  avg_overall=0.960000  lift=361.54%\n",
      "Best DOWN : th=1.0 | count=13 avg_overall=0.241538  lift=16.12%\n",
      "Best of BOTH: 361.54%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.175400\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.120000\n",
      "delta_confidence >= 0.7   : count=3     avg_overall=0.080000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=3     avg_overall=0.080000\n",
      "delta_confidence <= -1.2  : count=6     avg_overall=0.040000\n",
      "delta_confidence <= -1.1  : count=10    avg_overall=0.072000\n",
      "delta_confidence <= -1.0  : count=12    avg_overall=0.080000\n",
      "delta_confidence <= -0.9  : count=15    avg_overall=0.064000\n",
      "delta_confidence <= -0.8  : count=20    avg_overall=0.096000\n",
      "delta_confidence <= -0.7  : count=24    avg_overall=0.173333\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.8  | count=2  avg_overall=0.120000  lift=-31.58%\n",
      "Best DOWN : th=0.7 | count=24 avg_overall=0.173333  lift=-1.18%\n",
      "Best of BOTH: -1.18%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.242600\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=1     avg_overall=0.240000\n",
      "delta_confidence >= 1.0   : count=1     avg_overall=0.240000\n",
      "delta_confidence >= 0.9   : count=1     avg_overall=0.240000\n",
      "delta_confidence >= 0.8   : count=2     avg_overall=0.120000\n",
      "delta_confidence >= 0.7   : count=4     avg_overall=0.120000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=8     avg_overall=0.097500\n",
      "delta_confidence <= -1.2  : count=9     avg_overall=0.086667\n",
      "delta_confidence <= -1.1  : count=11    avg_overall=0.092727\n",
      "delta_confidence <= -1.0  : count=19    avg_overall=0.078947\n",
      "delta_confidence <= -0.9  : count=25    avg_overall=0.069600\n",
      "delta_confidence <= -0.8  : count=29    avg_overall=0.100690\n",
      "delta_confidence <= -0.7  : count=36    avg_overall=0.155000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=1.1  | count=1  avg_overall=0.240000  lift=-1.07%\n",
      "Best DOWN : th=0.7 | count=36 avg_overall=0.155000  lift=-36.11%\n",
      "Best of BOTH: -1.07%  (direction=UP)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.116200\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.2  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.1  : count=2     avg_overall=0.000000\n",
      "delta_confidence <= -1.0  : count=4     avg_overall=0.060000\n",
      "delta_confidence <= -0.9  : count=5     avg_overall=0.048000\n",
      "delta_confidence <= -0.8  : count=5     avg_overall=0.048000\n",
      "delta_confidence <= -0.7  : count=5     avg_overall=0.048000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=1.0 | count=4 avg_overall=0.060000  lift=-48.36%\n",
      "Best of BOTH: -48.36%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.184000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=1     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=2     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=9     avg_overall=0.026667\n",
      "delta_confidence <= -1.2  : count=12    avg_overall=0.080000\n",
      "delta_confidence <= -1.1  : count=16    avg_overall=0.138750\n",
      "delta_confidence <= -1.0  : count=22    avg_overall=0.144545\n",
      "delta_confidence <= -0.9  : count=26    avg_overall=0.122308\n",
      "delta_confidence <= -0.8  : count=29    avg_overall=0.109655\n",
      "delta_confidence <= -0.7  : count=32    avg_overall=0.099375\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP   : th=0.7  | count=2  avg_overall=0.000000  lift=-100.00%\n",
      "Best DOWN : th=1.0 | count=22 avg_overall=0.144545  lift=-21.44%\n",
      "Best of BOTH: -21.44%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.116000\n",
      "\n",
      "=== delta_confidence thresholds (UP: >= th) ===\n",
      "delta_confidence >= 1.3   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.2   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.1   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 1.0   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.9   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.8   : count=0     avg_overall=0.000000\n",
      "delta_confidence >= 0.7   : count=0     avg_overall=0.000000\n",
      "\n",
      "=== delta_confidence thresholds (DOWN: <= -th) ===\n",
      "delta_confidence <= -1.3  : count=4     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -1.2  : count=4     avg_overall=0.120000 [> overall]\n",
      "delta_confidence <= -1.1  : count=5     avg_overall=0.096000\n",
      "delta_confidence <= -1.0  : count=6     avg_overall=0.080000\n",
      "delta_confidence <= -0.9  : count=7     avg_overall=0.068571\n",
      "delta_confidence <= -0.8  : count=8     avg_overall=0.090000\n",
      "delta_confidence <= -0.7  : count=12    avg_overall=0.060000\n",
      "\n",
      "--- Best thresholds (this SAE) ---\n",
      "Best UP:    N/A (no non-empty selection)\n",
      "Best DOWN : th=1.3 | count=4 avg_overall=0.120000  lift=3.45%\n",
      "Best of BOTH: 3.45%  (direction=DOWN)\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (using each SAE's BEST threshold per direction and best-of-both)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-threshold average lift across SAEs (UP: delta_confidence >= th):\n",
      "delta_confidence >= 1.3   : N=4    avg_lift=-100.00%\n",
      "delta_confidence >= 1.2   : N=4    avg_lift=-100.00%\n",
      "delta_confidence >= 1.1   : N=6    avg_lift=10.55%\n",
      "delta_confidence >= 1.0   : N=8    avg_lift=9.94%\n",
      "delta_confidence >= 0.9   : N=11   avg_lift=-20.04%\n",
      "delta_confidence >= 0.8   : N=13   avg_lift=-47.65%\n",
      "delta_confidence >= 0.7   : N=21   avg_lift=-34.98%\n",
      "\n",
      "Per-threshold average lift across SAEs (DOWN: delta_confidence <= -th):\n",
      "delta_confidence <= -1.3  : N=28   avg_lift=-8.46%\n",
      "delta_confidence <= -1.2  : N=30   avg_lift=-0.01%\n",
      "delta_confidence <= -1.1  : N=30   avg_lift=-16.86%\n",
      "delta_confidence <= -1.0  : N=30   avg_lift=-25.79%\n",
      "delta_confidence <= -0.9  : N=30   avg_lift=-26.24%\n",
      "delta_confidence <= -0.8  : N=30   avg_lift=-25.45%\n",
      "delta_confidence <= -0.7  : N=30   avg_lift=-22.01%\n",
      "\n",
      "--- BEST (per SAE) summaries ---\n",
      "UP   : SAEs with positive lift: 4 / 21 (19.05%)\n",
      "      Average BEST lift across SAEs (UP): -18.10%\n",
      "DOWN : SAEs with positive lift: 14 / 30 (46.67%)\n",
      "      Average BEST lift across SAEs (DOWN): 41.58%\n",
      "BOTH : SAEs with positive lift: 15 / 30 (50.00%)\n",
      "Base steering score across SAEs: 0.142067\n",
      "After selection steering score across SAEs: 0.251517\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 77.04%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_9b_it/layer20\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_9b/layer20\"\n",
    "\n",
    "# Thresholds for scanning (positive magnitudes).\n",
    "# We'll compute both directions:\n",
    "#   UP   : delta_confidence >= th\n",
    "#   DOWN : delta_confidence <= -th\n",
    "THRESHOLDS_CONFIDENCE = [1.3, 1.2, 1.1, 1.0, 0.9, 0.8, 0.7]\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return item[\"holdout\"][\"mean\"][\"overall\"]\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def select_and_average_up(\n",
    "    eval_data: Dict[str, Any],\n",
    "    entropy_data: Dict[str, Any],\n",
    "    threshold: float\n",
    ") -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Select features with delta_confidence >= threshold.\n",
    "    Return:\n",
    "      - count of selected features that also have an 'overall' in eval_data\n",
    "      - average 'overall' over those features\n",
    "    \"\"\"\n",
    "    selected: List[float] = []\n",
    "    for f, info in entropy_data.items():\n",
    "        if not isinstance(info, dict):\n",
    "            continue\n",
    "        v = info.get(\"delta_confidence\")\n",
    "        if v is None:\n",
    "            continue\n",
    "        if v >= threshold:\n",
    "            s = get_overall_from_eval_item(eval_data.get(f, {}))\n",
    "            if s is not None:\n",
    "                selected.append(s)\n",
    "    n = len(selected)\n",
    "    avg = (sum(selected) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def select_and_average_down(\n",
    "    eval_data: Dict[str, Any],\n",
    "    entropy_data: Dict[str, Any],\n",
    "    threshold: float\n",
    ") -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Select features with delta_confidence <= -threshold.\n",
    "    Return:\n",
    "      - count of selected features that also have an 'overall' in eval_data\n",
    "      - average 'overall' over those features\n",
    "    \"\"\"\n",
    "    selected: List[float] = []\n",
    "    for f, info in entropy_data.items():\n",
    "        if not isinstance(info, dict):\n",
    "            continue\n",
    "        v = info.get(\"delta_confidence\")\n",
    "        if v is None:\n",
    "            continue\n",
    "        if v <= -threshold:\n",
    "            s = get_overall_from_eval_item(eval_data.get(f, {}))\n",
    "            if s is not None:\n",
    "                selected.append(s)\n",
    "    n = len(selected)\n",
    "    avg = (sum(selected) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str\n",
    ") -> Tuple[\n",
    "    Dict[float, float],  # per-threshold lifts (UP)\n",
    "    Dict[float, float],  # per-threshold lifts (DOWN)\n",
    "    Optional[Tuple[float, int, float, float]],  # best_up: (th, count, avg, lift)\n",
    "    Optional[Tuple[float, int, float, float]],  # best_down: (th, count, avg, lift)\n",
    "    Optional[float],  # best_of_both lift\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "\n",
    "    Returns:\n",
    "      - per_threshold_lifts_up:  dict[th] = lift% for this SAE on UP direction (when computable)\n",
    "      - per_threshold_lifts_down: dict[th] = lift% for this SAE on DOWN direction (when computable)\n",
    "      - best_up tuple:  (best_th, best_count, best_avg, best_lift) or None if no selection\n",
    "      - best_down tuple:(best_th, best_count, best_avg, best_lift) or None if no selection\n",
    "      - best_of_both_lift: max(best_up_lift, best_down_lift) if either exists, else None\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, None, None, None\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping thresholds.)\")\n",
    "        return {}, {}, None, None, None\n",
    "\n",
    "    # Scan thresholds: UP\n",
    "    print(\"\\n=== delta_confidence thresholds (UP: >= th) ===\")\n",
    "    per_threshold_lifts_up: Dict[float, float] = {}\n",
    "    best_up: Optional[Tuple[float, int, float, float]] = None  # (th, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        n, avg_sub = select_and_average_up(eval_data, entropy_data, threshold=th)\n",
    "        line = f\"delta_confidence >= {th:<6}: count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_threshold_lifts_up[th] = lift\n",
    "                # choose by highest avg_sub; tie-break by larger count\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (th, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Scan thresholds: DOWN\n",
    "    print(\"\\n=== delta_confidence thresholds (DOWN: <= -th) ===\")\n",
    "    per_threshold_lifts_down: Dict[float, float] = {}\n",
    "    best_down: Optional[Tuple[float, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        n, avg_sub = select_and_average_down(eval_data, entropy_data, threshold=th)\n",
    "        line = f\"delta_confidence <= -{th:<5}: count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_threshold_lifts_down[th] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (th, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (per SAE)\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        best_of_both_lift = max(best_up[3], best_down[3])\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best thresholds (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP:    N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : th={best_up[0]}  | count={best_up[1]}  avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN:  N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : th={best_down[0]} | count={best_down[1]} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH: N/A\")\n",
    "    else:\n",
    "        direction = \"UP\" if (best_up is not None and best_up[3] == best_of_both_lift) else (\n",
    "            \"DOWN\" if (best_down is not None and best_down[3] == best_of_both_lift) else \"UP/DOWN (tie)\"\n",
    "        )\n",
    "        print(f\"Best of BOTH: {best_of_both_lift:.2f}%  (direction={direction})\")\n",
    "\n",
    "    return per_threshold_lifts_up, per_threshold_lifts_down, best_up, best_down, best_of_both_lift\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Across-SAEs per-threshold aggregations\n",
    "    across_up: Dict[float, Dict[str, float]] = {th: {\"sum\": 0.0, \"count\": 0.0} for th in THRESHOLDS_CONFIDENCE}\n",
    "    across_down: Dict[float, Dict[str, float]] = {th: {\"sum\": 0.0, \"count\": 0.0} for th in THRESHOLDS_CONFIDENCE}\n",
    "\n",
    "    # Per-SAE best stats\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "\n",
    "    pos_up = pos_down = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_both = 0\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        per_up, per_down, best_up, best_down, best_both = process_one_sae(sae_name)\n",
    "\n",
    "        # Aggregate per-threshold lifts (UP/DOWN)\n",
    "        for th, lift in per_up.items():\n",
    "            across_up[th][\"sum\"] += lift\n",
    "            across_up[th][\"count\"] += 1\n",
    "        for th, lift in per_down.items():\n",
    "            across_down[th][\"sum\"] += lift\n",
    "            across_down[th][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction BEST (per SAE)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if best_both is not None:\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both)\n",
    "            if best_both > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "    # =================================================================================\n",
    "    # Summary across SAEs\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (using each SAE's BEST threshold per direction and best-of-both)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-threshold averages: UP\n",
    "    print(\"Per-threshold average lift across SAEs (UP: delta_confidence >= th):\")\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        cnt = int(across_up[th][\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[th][\"sum\"] / cnt\n",
    "            print(f\"delta_confidence >= {th:<6}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"delta_confidence >= {th:<6}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-threshold averages: DOWN\n",
    "    print(\"\\nPer-threshold average lift across SAEs (DOWN: delta_confidence <= -th):\")\n",
    "    for th in THRESHOLDS_CONFIDENCE:\n",
    "        cnt = int(across_down[th][\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[th][\"sum\"] / cnt\n",
    "            print(f\"delta_confidence <= -{th:<5}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"delta_confidence <= -{th:<5}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # BEST summaries\n",
    "    print(\"\\n--- BEST (per SAE) summaries ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "    else:\n",
    "        avg_both_best = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "        print(f\"Base steering score across SAEs: {(lambda vals: (sum(vals)/len(vals) if vals else 0.0))([compute_base_stats(data)[1] for data in (safe_load_json(os.path.join(EVAL_ROOT, d, 'eval.json')) for d in sorted(os.listdir(EVAL_ROOT)) if os.path.isdir(os.path.join(EVAL_ROOT, d))) if data is not None]):.6f}\")\n",
    "        print(f\"After selection steering score across SAEs: {(lambda base: base * (1 + (avg_both_best/100.0)))((lambda vals: (sum(vals)/len(vals) if vals else 0.0))([compute_base_stats(data)[1] for data in (safe_load_json(os.path.join(EVAL_ROOT, d, 'eval.json')) for d in sorted(os.listdir(EVAL_ROOT)) if os.path.isdir(os.path.join(EVAL_ROOT, d))) if data is not None])):.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {avg_both_best:.2f}%\")\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1cf1b0d3",
   "metadata": {},
   "source": [
    "## 2.3 Top K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "336f78db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.104000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.144000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.128000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.147000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.540000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.270000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.054000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.113333 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.097000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.147000  lift=41.35%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.540000  lift=419.23%\n",
      "Best of BOTH: 419.23%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.183000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.072000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.080000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.157000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.720000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.560000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.334000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.306667 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.230000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.157000  lift=-14.21%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.720000  lift=293.44%\n",
      "Best of BOTH: 293.44%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.171800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.074000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.126667\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.161000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.000000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.016000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.099000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.161000  lift=-6.29%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.099000  lift=-42.37%\n",
      "Best of BOTH: -6.29%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.169200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.560000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.284000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.192000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.164000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.228000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.168000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.084000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.104000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.090000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.560000  lift=230.97%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.168000  lift=-0.71%\n",
      "Best of BOTH: 230.97%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.208600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.064000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.074667\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.104000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.093333\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.142000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.104000  lift=-50.14%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.142000  lift=-31.93%\n",
      "Best of BOTH: -31.93%  (direction=DOWN) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.132000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.168000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.112000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.167000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.116000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.087000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.168000  lift=27.27%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.120000  lift=-9.09%\n",
      "Best of BOTH: 27.27%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_1070\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.123200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.108000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.084000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.104000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.129000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.204000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.126000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.156000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.181000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.150000  lift=21.75%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.204000  lift=65.58%\n",
      "Best of BOTH: 65.58%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.138600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.024000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.090667\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.174000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.198000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.220000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.216000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.174000  lift=25.54%\n",
      "Best DOWN : level=TOPK_DOWN= 15 | count=15   avg_overall=0.220000  lift=58.73%\n",
      "Best of BOTH: 58.73%  (direction=DOWN) | count=15\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_360\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.131400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.112000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.080000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.072000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.120000  lift=-8.68%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=-8.68%\n",
      "Best of BOTH: -8.68%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_53\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.090000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.072000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.064000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.087000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.102000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.088000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.066000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.087000  lift=-3.33%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.102000  lift=13.33%\n",
      "Best of BOTH: 13.33%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_573\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.120000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.032000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.099000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.032000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.024000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.099000  lift=-17.50%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-20.00%\n",
      "Best of BOTH: -17.50%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_85\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.130200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.080000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.099000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.072000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.069000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=84.33%\n",
      "Best DOWN : level=TOPK_DOWN= 15 | count=15   avg_overall=0.072000  lift=-44.70%\n",
      "Best of BOTH: 84.33%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_164\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.097600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.126000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.100000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.087000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.142667 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.122000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.126000  lift=29.10%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.480000  lift=391.80%\n",
      "Best of BOTH: 391.80%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_327\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.109400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.270000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.162000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.144000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.147000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.102000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.068000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.063000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.270000  lift=146.80%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.102000  lift=-6.76%\n",
      "Best of BOTH: 146.80%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_51\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.111000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.084000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.102000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.112000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.126000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=116.22%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.126000  lift=13.51%\n",
      "Best of BOTH: 116.22%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_529\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.093600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.024000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.032000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.060000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.112000 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.108000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.060000  lift=-35.90%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=28.21%\n",
      "Best of BOTH: 28.21%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_786\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.124400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.088000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.068000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.129333 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.097000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.048000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.058000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 15  | count=15   avg_overall=0.129333  lift=3.97%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.240000  lift=92.93%\n",
      "Best of BOTH: 92.93%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_82\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.143200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.108000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.184000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.186000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.060000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.102000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.100000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.075000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.186000  lift=29.89%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.102000  lift=-28.77%\n",
      "Best of BOTH: 29.89%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_108\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.180400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.232000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.216000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.189000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.132000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.104000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.093000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.232000  lift=28.60%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.132000  lift=-26.83%\n",
      "Best of BOTH: 28.60%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_167\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.152400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.264000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.252000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.216000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.234000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.324000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.192000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.144000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.120000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.264000  lift=73.23%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.324000  lift=112.60%\n",
      "Best of BOTH: 112.60%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_321\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.048000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.048000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.141000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.080000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.084000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.141000  lift=18.09%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=0.50%\n",
      "Best of BOTH: 18.09%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_523\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.119000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.168000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.160000 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.183000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.150000 [> overall]\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.100000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.114000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.480000  lift=303.36%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.480000  lift=303.36%\n",
      "Best of BOTH: 303.36%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_61\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.138200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.780000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.390000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.236000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.118000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.189333 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.154000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.080000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.092000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.780000  lift=464.40%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.240000  lift=73.66%\n",
      "Best of BOTH: 464.40%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_762\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.129200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.270000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.412000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.356000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.273333 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.229000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.192000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.064000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.084000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.412000  lift=218.89%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.480000  lift=271.52%\n",
      "Best of BOTH: 271.52%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.208000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.336000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.262000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.270667 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.289000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.192000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.209333 [> overall]\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.157000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.960000  lift=361.54%\n",
      "Best DOWN : level=TOPK_DOWN= 15 | count=15   avg_overall=0.209333  lift=0.64%\n",
      "Best of BOTH: 361.54%  (direction=UP) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.175400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.216000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.108000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.124000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.237000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.064000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.237000  lift=35.12%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.096000  lift=-45.27%\n",
      "Best of BOTH: 35.12%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.242600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.382000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.354667 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.302000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.240000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.102000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.100000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.075000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.382000  lift=57.46%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.240000  lift=-1.07%\n",
      "Best of BOTH: 57.46%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.116200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.072000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.064000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.075000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.096000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.099000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.096000  lift=-17.38%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.099000  lift=-14.80%\n",
      "Best of BOTH: -14.80%  (direction=DOWN) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.184000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.150000\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.190667 [> overall]\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.238000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.080000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.147000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 20  | count=20   avg_overall=0.238000  lift=29.35%\n",
      "Best DOWN : level=TOPK_DOWN= 20 | count=20   avg_overall=0.147000  lift=-20.11%\n",
      "Best of BOTH: 29.35%  (direction=UP) | count=20\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.116000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.108000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.126000 [> overall]\n",
      "TOPK_UP= 15    -> count=15    avg_overall=0.100000\n",
      "TOPK_UP= 20    -> count=20    avg_overall=0.090000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "TOPK_DOWN= 15  -> count=15    avg_overall=0.088000\n",
      "TOPK_DOWN= 20  -> count=20    avg_overall=0.081000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.126000  lift=8.62%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-17.24%\n",
      "Best of BOTH: 8.62%  (direction=UP) | count=10\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and best-of-both)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=30   avg_lift=-28.39%\n",
      "TOPK_UP= 2    : N=30   avg_lift=-29.88%\n",
      "TOPK_UP= 5    : N=30   avg_lift=-19.68%\n",
      "TOPK_UP= 10   : N=30   avg_lift=-5.97%\n",
      "TOPK_UP= 15   : N=30   avg_lift=-6.49%\n",
      "TOPK_UP= 20   : N=30   avg_lift=9.50%\n",
      "\n",
      "Per-level average lift across SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=30   avg_lift=-24.06%\n",
      "TOPK_DOWN= 2  : N=30   avg_lift=-28.85%\n",
      "TOPK_DOWN= 5  : N=30   avg_lift=-22.15%\n",
      "TOPK_DOWN= 10 : N=30   avg_lift=-24.62%\n",
      "TOPK_DOWN= 15 : N=30   avg_lift=-22.20%\n",
      "TOPK_DOWN= 20 : N=30   avg_lift=-23.26%\n",
      "\n",
      "--- BEST (per SAE) summaries (ALL) ---\n",
      "UP   : SAEs with positive lift: 22 / 30 (73.33%)\n",
      "      Average BEST lift across SAEs (UP): 73.41%\n",
      "DOWN : SAEs with positive lift: 15 / 30 (50.00%)\n",
      "      Average BEST lift across SAEs (DOWN): 60.69%\n",
      "BOTH : SAEs with positive lift: 25 / 30 (83.33%)\n",
      "Base steering score across SAEs: 0.142067\n",
      "After selection steering score across SAEs (approx): 0.313030\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 120.34%\n",
      "      Average selected feature count per SAE (Best of UP or DOWN): 9.33\n",
      "\n",
      "================================================================================\n",
      "SAEs flagged as NON-STEERING by the configured criteria\n",
      "- Criteria:\n",
      "  1) max selected count across all levels/directions < 5\n",
      "  2) best-of-both lift <= 0.00%\n",
      "  3) levels achieving count>=5 across UP+DOWN < 2\n",
      "--------------------------------------------------------------------------------\n",
      "[NON-STEERING] batch_topk_50\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-6.2863795110593585)\n",
      "  Stats: max_count_up=20  max_count_down=20\n",
      "         best_up_lift=-6.2863795110593585  best_down_lift=-42.374854481955744  best_of_both=-6.2863795110593585\n",
      "         levels_hit(up)=4  levels_hit(down)=4\n",
      "[NON-STEERING] batch_topk_80\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-31.927133269415165)\n",
      "  Stats: max_count_up=20  max_count_down=20\n",
      "         best_up_lift=-50.143815915628  best_down_lift=-31.927133269415165  best_of_both=-31.927133269415165\n",
      "         levels_hit(up)=4  levels_hit(down)=4\n",
      "[NON-STEERING] gated_360\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-8.675799086758005)\n",
      "  Stats: max_count_up=20  max_count_down=20\n",
      "         best_up_lift=-8.675799086758005  best_down_lift=-8.675799086758005  best_of_both=-8.675799086758005\n",
      "         levels_hit(up)=4  levels_hit(down)=4\n",
      "[NON-STEERING] gated_573\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-17.500000000000014)\n",
      "  Stats: max_count_up=20  max_count_down=20\n",
      "         best_up_lift=-17.500000000000014  best_down_lift=-20.000000000000014  best_of_both=-17.500000000000014\n",
      "         levels_hit(up)=4  levels_hit(down)=4\n",
      "[NON-STEERING] topk_520\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-14.802065404475067)\n",
      "  Stats: max_count_up=20  max_count_down=20\n",
      "         best_up_lift=-17.383820998278857  best_down_lift=-14.802065404475067  best_of_both=-14.802065404475067\n",
      "         levels_hit(up)=4  levels_hit(down)=4\n",
      "\n",
      "================================================================================\n",
      "SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across QUALIFIED SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=25   avg_lift=-14.07%\n",
      "TOPK_UP= 2    : N=25   avg_lift=-15.85%\n",
      "TOPK_UP= 5    : N=25   avg_lift=-6.93%\n",
      "TOPK_UP= 10   : N=25   avg_lift=2.16%\n",
      "TOPK_UP= 15   : N=25   avg_lift=1.16%\n",
      "TOPK_UP= 20   : N=25   avg_lift=16.12%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=25   avg_lift=-8.87%\n",
      "TOPK_DOWN= 2  : N=25   avg_lift=-18.27%\n",
      "TOPK_DOWN= 5  : N=25   avg_lift=-14.73%\n",
      "TOPK_DOWN= 10 : N=25   avg_lift=-18.29%\n",
      "TOPK_DOWN= 15 : N=25   avg_lift=-15.60%\n",
      "TOPK_DOWN= 20 : N=25   avg_lift=-19.34%\n",
      "\n",
      "--- BEST (per SAE) summaries (QUALIFIED) ---\n",
      "UP   : SAEs with positive lift: 22 / 25 (88.00%)\n",
      "      Average BEST lift across SAEs (UP): 92.10%\n",
      "DOWN : SAEs with positive lift: 15 / 25 (60.00%)\n",
      "      Average BEST lift across SAEs (DOWN): 77.54%\n",
      "BOTH : SAEs with positive lift: 25 / 25 (100.00%)\n",
      "Base steering score across SAEs: 0.140560\n",
      "After selection steering score across SAEs (approx): 0.347992\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 147.58%\n",
      "      Average selected feature count per SAE (Best of UP or DOWN): 7.20\n",
      "\n",
      "================================================================================\n",
      "STEERING RESULTS FOR QUALIFIED SAEs (best level per SAE)\n",
      "--------------------------------------------------------------------------------\n",
      "[batch_topk_160] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.540000 | lift=419.23%\n",
      "[batch_topk_320] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.720000 | lift=293.44%\n",
      "[batch_topk_520] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.560000 | lift=230.97%\n",
      "[batch_topk_820] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.168000 | lift=27.27%\n",
      "[gated_1070] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.204000 | lift=65.58%\n",
      "[gated_160] best_dir=DOWN  | level=TOPK_DOWN= 15 | count=15   | avg_overall=0.220000 | lift=58.73%\n",
      "[gated_53] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.102000 | lift=13.33%\n",
      "[gated_85] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=84.33%\n",
      "[jump_relu_164] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.480000 | lift=391.80%\n",
      "[jump_relu_327] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.270000 | lift=146.80%\n",
      "[jump_relu_51] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.240000 | lift=116.22%\n",
      "[jump_relu_529] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.120000 | lift=28.21%\n",
      "[jump_relu_786] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.240000 | lift=92.93%\n",
      "[jump_relu_82] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.186000 | lift=29.89%\n",
      "[standard_april_update_108] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.232000 | lift=28.60%\n",
      "[standard_april_update_167] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.324000 | lift=112.60%\n",
      "[standard_april_update_321] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.141000 | lift=18.09%\n",
      "[standard_april_update_523] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.480000 | lift=303.36%\n",
      "[standard_april_update_61] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.780000 | lift=464.40%\n",
      "[standard_april_update_762] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.480000 | lift=271.52%\n",
      "[topk_160] best_dir=UP    | level=TOPK_UP= 1   | count=1    | avg_overall=0.960000 | lift=361.54%\n",
      "[topk_320] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.237000 | lift=35.12%\n",
      "[topk_50] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.382000 | lift=57.46%\n",
      "[topk_80] best_dir=UP    | level=TOPK_UP= 20  | count=20   | avg_overall=0.238000 | lift=29.35%\n",
      "[topk_820] best_dir=UP    | level=TOPK_UP= 10  | count=10   | avg_overall=0.126000 | lift=8.62%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "import numpy as np\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_9b_it/layer20\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/gemma2_9b/layer20\"\n",
    "\n",
    "# --------------------------------------------------------------------\n",
    "# Selection levels use QUANTILES and/or TOP-K instead of absolute cuts\n",
    "# --------------------------------------------------------------------\n",
    "USE_QUANTILES = False\n",
    "# Upper-tail quantiles for UP (delta_confidence high end). For DOWN we mirror to lower-tail.\n",
    "# Example: 0.99 means \"select features with delta_confidence >= 99th percentile\" (UP)\n",
    "# and \"select features with delta_confidence <= 1st percentile\" (DOWN).\n",
    "QUANTILES: List[float] = [0.99, 0.95, 0.90, 0.80]\n",
    "\n",
    "USE_TOPK = True\n",
    "# Top-K sizes (by magnitude in the corresponding direction).\n",
    "# For UP: take K largest delta_confidence; for DOWN: take K most negative delta_confidence.\n",
    "TOPK_LIST: List[int] = [1, 2, 5, 10, 20]\n",
    "\n",
    "# ---- Non-steering detection (tunable) ----\n",
    "# A SAE is flagged as NON-STEERING if ANY of the following holds:\n",
    "#   1) max selected count across all levels/directions < MIN_SELECTION_COUNT\n",
    "#   2) best-of-both lift <= MIN_BEST_LIFT\n",
    "#   3) number of levels (across UP+DOWN) with count >= MIN_SELECTION_COUNT < MIN_LEVELS_HIT\n",
    "MIN_SELECTION_COUNT   = 5     # require at least this many selected features at ANY level\n",
    "MIN_BEST_LIFT        = 0.0    # require best-of-both lift strictly greater than this (e.g., > 0.0)\n",
    "MIN_LEVELS_HIT       = 2      # how many levels achieve count >= MIN_SELECTION_COUNT\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return float(item[\"holdout\"][\"mean\"][\"overall\"])\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "    Note: We DO NOT drop 0.0 overall values; they are valid and part of the baseline.\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s  # keep zeros\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def build_delta_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: delta_confidence} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"delta_confidence\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"delta_confidence\"])\n",
    "            except Exception:\n",
    "                pass\n",
    "    return out\n",
    "\n",
    "\n",
    "def avg_for_selected(eval_data: Dict[str, Any], selected_ids: List[str]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - count of selected features that also have 'overall' in eval_data\n",
    "      - average 'overall' over those features (0.0 if count=0)\n",
    "    \"\"\"\n",
    "    vals: List[float] = []\n",
    "    for fid in selected_ids:\n",
    "        s = get_overall_from_eval_item(eval_data.get(fid, {}))\n",
    "        if s is not None:\n",
    "            vals.append(s)  # keep zeros\n",
    "    n = len(vals)\n",
    "    avg = (sum(vals) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection levels (Quantiles / Top-K)\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_for_up(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build UP (high end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles: label like 'Q>=0.95'\n",
    "    - Top-K:     label like 'TOPK_UP= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (upper tail): select v >= quantile(q)\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            cut = float(np.quantile(vals, q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] >= cut]\n",
    "            levels.append((f\"Q>= {q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (largest K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_up = sorted(fids, key=lambda x: delta_map[x], reverse=True)\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_up[:max(0, min(k, len(sorted_up)))]\n",
    "            levels.append((f\"TOPK_UP= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_down(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build DOWN (negative end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles (lower tail): label like 'Q<=0.05' meaning v <= quantile(0.05)\n",
    "      (Mirroring an upper-tail q by using (1 - q) for the lower tail.)\n",
    "    - Top-K:     label like 'TOPK_DOWN= {k}'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (lower tail): mirror\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            low_q = 1.0 - q\n",
    "            low_cut = float(np.quantile(vals, low_q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] <= low_cut]\n",
    "            levels.append((f\"Q<= {low_q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (most negative K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_down = sorted(fids, key=lambda x: delta_map[x])  # ascending => most negative first\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_down[:max(0, min(k, len(sorted_down)))]\n",
    "            levels.append((f\"TOPK_DOWN= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str,\n",
    "    order_up_labels: List[str],\n",
    "    order_down_labels: List[str],\n",
    ") -> Tuple[\n",
    "    Dict[str, float],   # per-level lifts (UP)      label -> lift\n",
    "    Dict[str, float],   # per-level lifts (DOWN)    label -> lift\n",
    "    Optional[Tuple[str, int, float, float]],  # best_up: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_down: (label, count, avg, lift)\n",
    "    Optional[float],    # best_of_both lift\n",
    "    Optional[int],      # best_of_both count\n",
    "    Dict[str, int],     # per-level counts (UP)\n",
    "    Dict[str, int],     # per-level counts (DOWN)\n",
    "    float,              # base_avg_overall for this SAE\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "\n",
    "    Returns:\n",
    "      - per_level_lifts_up:    dict[label] = lift% for UP (when computable)\n",
    "      - per_level_lifts_down:  dict[label] = lift% for DOWN (when computable)\n",
    "      - best_up tuple:         (label, count, avg, lift) or None if no selection\n",
    "      - best_down tuple:       (label, count, avg, lift) or None if no selection\n",
    "      - best_of_both_lift:     max(best_up_lift, best_down_lift) if either exists, else None\n",
    "      - best_of_both_count:    selected-feature count for the best-of-both choice (or None)\n",
    "      - per_level_counts_up/down: counts per label for UP/DOWN\n",
    "      - base_avg_overall:      baseline average of all features for this SAE\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, None, None, None, None, {}, {}, 0.0\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping selection levels.)\")\n",
    "        return {}, {}, None, None, None, None, {}, {}, avg_overall_all\n",
    "\n",
    "    # Build delta map\n",
    "    delta_map = build_delta_map(entropy_data)\n",
    "\n",
    "    # Compose selection levels for UP & DOWN\n",
    "    up_levels   = selection_levels_for_up(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    down_levels = selection_levels_for_down(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "\n",
    "    # Keep maps for lifts/counts keyed by label for deterministic aggregation/printing\n",
    "    per_level_lifts_up: Dict[str, float] = {}\n",
    "    per_level_counts_up: Dict[str, int] = {}\n",
    "    per_level_lifts_down: Dict[str, float] = {}\n",
    "    per_level_counts_down: Dict[str, int] = {}\n",
    "\n",
    "    # ---- UP section ----\n",
    "    print(\"\\n=== Selection levels (UP: high delta_confidence) ===\")\n",
    "    best_up: Optional[Tuple[str, int, float, float]] = None  # (label, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    # Ensure printing order follows order_up_labels; fallback to appending any missing labels\n",
    "    up_levels_map = {lab: ids for lab, ids in up_levels}\n",
    "    up_labels_ordered = [lab for lab in order_up_labels if lab in up_levels_map] + \\\n",
    "                        [lab for lab in up_levels_map.keys() if lab not in order_up_labels]\n",
    "\n",
    "    for label in up_labels_ordered:\n",
    "        selected = up_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_up[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_up[label] = lift\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (label, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- DOWN section ----\n",
    "    print(\"\\n=== Selection levels (DOWN: low/negative delta_confidence) ===\")\n",
    "    best_down: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    down_levels_map = {lab: ids for lab, ids in down_levels}\n",
    "    down_labels_ordered = [lab for lab in order_down_labels if lab in down_levels_map] + \\\n",
    "                          [lab for lab in down_levels_map.keys() if lab not in order_down_labels]\n",
    "\n",
    "    for label in down_labels_ordered:\n",
    "        selected = down_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_down[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_down[label] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (label, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (per SAE): choose the direction with larger lift; carry the count too\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    best_of_both_count: Optional[int] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        if best_up[3] >= best_down[3]:\n",
    "            best_of_both_lift = best_up[3]\n",
    "            best_of_both_count = best_up[1]\n",
    "            direction = \"UP\"\n",
    "        else:\n",
    "            best_of_both_lift = best_down[3]\n",
    "            best_of_both_count = best_down[1]\n",
    "            direction = \"DOWN\"\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "        best_of_both_count = best_up[1]\n",
    "        direction = \"UP\"\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "        best_of_both_count = best_down[1]\n",
    "        direction = \"DOWN\"\n",
    "    else:\n",
    "        direction = \"N/A\"\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best levels (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP   : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : level={best_up[0]:<12} | count={best_up[1]:<4} avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : level={best_down[0]:<12} | count={best_down[1]:<4} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH: N/A\")\n",
    "    else:\n",
    "        print(f\"Best of BOTH: {best_of_both_lift:.2f}%  (direction={direction}) | count={best_of_both_count}\")\n",
    "\n",
    "    return (\n",
    "        per_level_lifts_up,\n",
    "        per_level_lifts_down,\n",
    "        best_up,\n",
    "        best_down,\n",
    "        best_of_both_lift,\n",
    "        best_of_both_count,\n",
    "        per_level_counts_up,\n",
    "        per_level_counts_down,\n",
    "        avg_overall_all,\n",
    "    )\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Build the global (ordered) label lists we will use for consistent printing/aggregation\n",
    "    order_up_labels: List[str] = []\n",
    "    order_down_labels: List[str] = []\n",
    "    if USE_QUANTILES and QUANTILES:\n",
    "        for q in sorted(set(QUANTILES), reverse=True):\n",
    "            order_up_labels.append(f\"Q>= {q:.2f}\")\n",
    "            order_down_labels.append(f\"Q<= {1.0 - q:.2f}\")\n",
    "    if USE_TOPK and TOPK_LIST:\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            order_up_labels.append(f\"TOPK_UP= {k}\")\n",
    "            order_down_labels.append(f\"TOPK_DOWN= {k}\")\n",
    "\n",
    "    # Across-SAEs per-level aggregations (unfiltered)\n",
    "    def init_agg(levels: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {lab: {\"sum\": 0.0, \"count\": 0.0} for lab in levels}\n",
    "\n",
    "    across_up = init_agg(order_up_labels)\n",
    "    across_down = init_agg(order_down_labels)\n",
    "\n",
    "    # Per-SAE best stats (unfiltered)\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "    best_both_counts: List[int] = []\n",
    "    pos_up = pos_down = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_both = 0\n",
    "\n",
    "    # Keep per-SAE records for later filtered summary\n",
    "    sae_records: List[Dict[str, Any]] = []\n",
    "    non_steering: List[Tuple[str, List[str], Dict[str, Any]]] = []\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        (\n",
    "            per_up,\n",
    "            per_down,\n",
    "            best_up,\n",
    "            best_down,\n",
    "            best_both_lift,\n",
    "            best_both_count,\n",
    "            cnts_up,\n",
    "            cnts_down,\n",
    "            base_avg,\n",
    "        ) = process_one_sae(sae_name, order_up_labels, order_down_labels)\n",
    "\n",
    "        # Save record\n",
    "        sae_records.append(\n",
    "            {\n",
    "                \"name\": sae_name,\n",
    "                \"per_up\": per_up,\n",
    "                \"per_down\": per_down,\n",
    "                \"best_up\": best_up,\n",
    "                \"best_down\": best_down,\n",
    "                \"best_both_lift\": best_both_lift,\n",
    "                \"best_both_count\": best_both_count,\n",
    "                \"cnts_up\": cnts_up,\n",
    "                \"cnts_down\": cnts_down,\n",
    "                \"base_avg\": base_avg,\n",
    "            }\n",
    "        )\n",
    "\n",
    "        # Aggregate per-level lifts (UP/DOWN) for unfiltered summary\n",
    "        for lab, lift in per_up.items():\n",
    "            if lab not in across_up:\n",
    "                across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_up[lab][\"sum\"] += lift\n",
    "            across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in per_down.items():\n",
    "            if lab not in across_down:\n",
    "                across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_down[lab][\"sum\"] += lift\n",
    "            across_down[lab][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction BEST (unfiltered)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if (best_both_lift is not None) and isinstance(best_both_lift, float):\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both_lift)\n",
    "            if isinstance(best_both_count, int):\n",
    "                best_both_counts.append(best_both_count)\n",
    "            if best_both_lift > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "        # ---------------------------\n",
    "        # Non-steering detection\n",
    "        # ---------------------------\n",
    "        reasons: List[str] = []\n",
    "        max_count_up = max(cnts_up.values(), default=0)\n",
    "        max_count_down = max(cnts_down.values(), default=0)\n",
    "        max_count_both = max(max_count_up, max_count_down)\n",
    "\n",
    "        # How many levels hit MIN_SELECTION_COUNT (across both directions)\n",
    "        hits_up = sum(1 for c in cnts_up.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_down = sum(1 for c in cnts_down.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_both = hits_up + hits_down\n",
    "\n",
    "        # Condition 1: insufficient selected features at any level\n",
    "        if max_count_both < MIN_SELECTION_COUNT:\n",
    "            reasons.append(f\"insufficient selected features: max_count={max_count_both} < {MIN_SELECTION_COUNT}\")\n",
    "\n",
    "        # Condition 2: no positive (or required) lift anywhere\n",
    "        if (best_both_lift is None) or (best_both_lift <= MIN_BEST_LIFT):\n",
    "            reasons.append(\n",
    "                f\"no level yields lift > {MIN_BEST_LIFT:.2f}% (best_of_both={best_both_lift if best_both_lift is not None else 'N/A'})\"\n",
    "            )\n",
    "\n",
    "        # Condition 3: stability across levels is poor\n",
    "        if hits_both < MIN_LEVELS_HIT:\n",
    "            reasons.append(\n",
    "                f\"unstable coverage: levels_with_count>={MIN_SELECTION_COUNT} = {hits_both} < {MIN_LEVELS_HIT}\"\n",
    "            )\n",
    "\n",
    "        if len(reasons) > 0:\n",
    "            non_steering.append((\n",
    "                sae_name,\n",
    "                reasons,\n",
    "                {\n",
    "                    \"max_count_up\": max_count_up,\n",
    "                    \"max_count_down\": max_count_down,\n",
    "                    \"best_up_lift\": (best_up[3] if best_up else None),\n",
    "                    \"best_down_lift\": (best_down[3] if best_down else None),\n",
    "                    \"best_of_both_lift\": best_both_lift,\n",
    "                    \"hits_up\": hits_up,\n",
    "                    \"hits_down\": hits_down,\n",
    "                }\n",
    "            ))\n",
    "\n",
    "    # =================================================================================\n",
    "    # Unfiltered summary across ALL SAEs (baseline reference)\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and best-of-both)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-level averages: UP\n",
    "    print(\"Per-level average lift across SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: DOWN\n",
    "    print(\"\\nPer-level average lift across SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Compute base across ALL SAEs (fixed baseline definition: average of each SAE's all-feature mean)\n",
    "    all_base_vals = [rec[\"base_avg\"] for rec in sae_records]\n",
    "    base_across_all = (sum(all_base_vals) / len(all_base_vals)) if all_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (ALL)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (ALL) ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        avg_both_best_all = 0.0\n",
    "        avg_both_count_all = 0.0\n",
    "    else:\n",
    "        avg_both_best_all = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        avg_both_count_all = (sum(best_both_counts) / len(best_both_counts)) if best_both_counts else 0.0\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "        print(f\"Base steering score across SAEs: {base_across_all:.6f}\")\n",
    "        print(f\"After selection steering score across SAEs (approx): {base_across_all * (1 + (avg_both_best_all/100.0)):.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {avg_both_best_all:.2f}%\")\n",
    "        print(f\"      Average selected feature count per SAE (Best of UP or DOWN): {avg_both_count_all:.2f}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Non-steering report\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SAEs flagged as NON-STEERING by the configured criteria\")\n",
    "    print(\"- Criteria:\")\n",
    "    print(f\"  1) max selected count across all levels/directions < {MIN_SELECTION_COUNT}\")\n",
    "    print(f\"  2) best-of-both lift <= {MIN_BEST_LIFT:.2f}%\")\n",
    "    print(f\"  3) levels achieving count>={MIN_SELECTION_COUNT} across UP+DOWN < {MIN_LEVELS_HIT}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    non_names = set()\n",
    "    if not non_steering:\n",
    "        print(\"All SAEs pass the steering capability criteria.\")\n",
    "    else:\n",
    "        for name, reasons, stats in non_steering:\n",
    "            non_names.add(name)\n",
    "            print(f\"[NON-STEERING] {name}\")\n",
    "            print(f\"  Reasons:\")\n",
    "            for r in reasons:\n",
    "                print(f\"    - {r}\")\n",
    "            print(f\"  Stats: max_count_up={stats['max_count_up']}  max_count_down={stats['max_count_down']}\")\n",
    "            print(f\"         best_up_lift={stats['best_up_lift']}  best_down_lift={stats['best_down_lift']}  best_of_both={stats['best_of_both_lift']}\")\n",
    "            print(f\"         levels_hit(up)={stats['hits_up']}  levels_hit(down)={stats['hits_down']}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # FILTERED summary across STEERING-QUALIFIED SAEs only\n",
    "    # =================================================================================\n",
    "    qualified = [rec for rec in sae_records if rec[\"name\"] not in non_names]\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    if not qualified:\n",
    "        print(\"No SAE remains after filtering; cannot compute qualified summary.\")\n",
    "        return\n",
    "\n",
    "    # Per-level averages across qualified\n",
    "    def init_agg_like(template_keys: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {k: {\"sum\": 0.0, \"count\": 0.0} for k in template_keys}\n",
    "\n",
    "    q_across_up = init_agg_like(order_up_labels)\n",
    "    q_across_down = init_agg_like(order_down_labels)\n",
    "\n",
    "    q_best_up_lifts: List[float] = []\n",
    "    q_best_down_lifts: List[float] = []\n",
    "    q_best_both_lifts: List[float] = []\n",
    "    q_best_both_counts: List[int] = []\n",
    "    q_pos_up = q_pos_down = q_pos_both = 0\n",
    "    q_saes_with_up = q_saes_with_down = q_saes_with_both = 0\n",
    "\n",
    "    for rec in qualified:\n",
    "        # per-level lifts\n",
    "        for lab, lift in rec[\"per_up\"].items():\n",
    "            if lab not in q_across_up:\n",
    "                q_across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_up[lab][\"sum\"] += lift\n",
    "            q_across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_down\"].items():\n",
    "            if lab not in q_across_down:\n",
    "                q_across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_down[lab][\"sum\"] += lift\n",
    "            q_across_down[lab][\"count\"] += 1\n",
    "\n",
    "        # best per-direction / best-of-both\n",
    "        if rec[\"best_up\"] is not None:\n",
    "            q_saes_with_up += 1\n",
    "            q_best_up_lifts.append(rec[\"best_up\"][3])\n",
    "            if rec[\"best_up\"][3] > 0:\n",
    "                q_pos_up += 1\n",
    "        if rec[\"best_down\"] is not None:\n",
    "            q_saes_with_down += 1\n",
    "            q_best_down_lifts.append(rec[\"best_down\"][3])\n",
    "            if rec[\"best_down\"][3] > 0:\n",
    "                q_pos_down += 1\n",
    "\n",
    "        if (rec[\"best_both_lift\"] is not None) and isinstance(rec[\"best_both_lift\"], float):\n",
    "            q_saes_with_both += 1\n",
    "            q_best_both_lifts.append(rec[\"best_both_lift\"])\n",
    "            if isinstance(rec[\"best_both_count\"], int):\n",
    "                q_best_both_counts.append(rec[\"best_both_count\"])\n",
    "            if rec[\"best_both_lift\"] > 0:\n",
    "                q_pos_both += 1\n",
    "\n",
    "    # Print per-level averages (qualified)\n",
    "    print(\"Per-level average lift across QUALIFIED SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(q_across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(q_across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Base steering score across QUALIFIED SAEs (same definition as ALL, but over the subset)\n",
    "    q_base_vals = [rec[\"base_avg\"] for rec in qualified]\n",
    "    base_across_qualified = (sum(q_base_vals) / len(q_base_vals)) if q_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (qualified)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (QUALIFIED) ---\")\n",
    "    if q_saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_up_best = (sum(q_best_up_lifts) / len(q_best_up_lifts)) if q_best_up_lifts else 0.0\n",
    "        q_pct_up_pos = (q_pos_up / q_saes_with_up) * 100.0 if q_saes_with_up > 0 else 0.0\n",
    "        print(f\"UP   : SAEs with positive lift: {q_pos_up} / {q_saes_with_up} ({q_pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {q_avg_up_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_down_best = (sum(q_best_down_lifts) / len(q_best_down_lifts)) if q_best_down_lifts else 0.0\n",
    "        q_pct_down_pos = (q_pos_down / q_saes_with_down) * 100.0 if q_saes_with_down > 0 else 0.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {q_pos_down} / {q_saes_with_down} ({q_pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {q_avg_down_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        q_avg_both_best = 0.0\n",
    "        q_avg_both_count = 0.0\n",
    "    else:\n",
    "        q_avg_both_best = (sum(q_best_both_lifts) / len(q_best_both_lifts)) if q_best_both_lifts else 0.0\n",
    "        q_avg_both_count = (sum(q_best_both_counts) / len(q_best_both_counts)) if q_best_both_counts else 0.0\n",
    "        q_pct_both_pos = (q_pos_both / q_saes_with_both) * 100.0 if q_saes_with_both > 0 else 0.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {q_pos_both} / {q_saes_with_both} ({q_pct_both_pos:.2f}%)\")\n",
    "        print(f\"Base steering score across SAEs: {base_across_qualified:.6f}\")\n",
    "        print(f\"After selection steering score across SAEs (approx): {base_across_qualified * (1 + (q_avg_both_best/100.0)):.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {q_avg_both_best:.2f}%\")\n",
    "        print(f\"      Average selected feature count per SAE (Best of UP or DOWN): {q_avg_both_count:.2f}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Per-qualified-SAE steering result details\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"STEERING RESULTS FOR QUALIFIED SAEs (best level per SAE)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for rec in qualified:\n",
    "        name = rec[\"name\"]\n",
    "        best_up = rec[\"best_up\"]\n",
    "        best_down = rec[\"best_down\"]\n",
    "\n",
    "        best_dir = None\n",
    "        best_tuple = None  # (label, count, avg, lift)\n",
    "        if best_up is not None and best_down is not None:\n",
    "            best_dir = \"UP\" if best_up[3] >= best_down[3] else \"DOWN\"\n",
    "            best_tuple = best_up if best_up[3] >= best_down[3] else best_down\n",
    "        elif best_up is not None:\n",
    "            best_dir = \"UP\"\n",
    "            best_tuple = best_up\n",
    "        elif best_down is not None:\n",
    "            best_dir = \"DOWN\"\n",
    "            best_tuple = best_down\n",
    "\n",
    "        if best_tuple is None:\n",
    "            print(f\"[{name}] No valid best selection found.\")\n",
    "        else:\n",
    "            lab, cnt, avg_overall, lift = best_tuple\n",
    "            print(\n",
    "                f\"[{name}] best_dir={best_dir:<5} | level={lab:<12} | count={cnt:<4} | avg_overall={avg_overall:.6f} | lift={lift:.2f}%\"\n",
    "            )\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f038b939",
   "metadata": {},
   "source": [
    "# 3 Qwen 2.5 3b L17"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca594277",
   "metadata": {},
   "source": [
    "## 3.2 Top K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f28ebe7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.198200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.192000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.284000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.120000  lift=-39.46%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.360000  lift=81.63%\n",
      "Best of BOTH: 81.63%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.177400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.100000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.088000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.092000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.336000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.222000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.100000  lift=-43.63%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.336000  lift=89.40%\n",
      "Best of BOTH: 89.40%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.287000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.220000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.256000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.284000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.328000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.218000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.284000  lift=-1.05%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.328000  lift=14.29%\n",
      "Best of BOTH: 14.29%  (direction=DOWN) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.151600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.216000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.600000  lift=295.78%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-36.68%\n",
      "Best of BOTH: 295.78%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.227200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.200000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.100000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.136000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.252000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.920000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.460000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.280000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.232000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.252000  lift=10.92%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.920000  lift=304.93%\n",
      "Best of BOTH: 304.93%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.124800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.096000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.126000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.144000  lift=15.38%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.240000  lift=92.31%\n",
      "Best of BOTH: 92.31%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_141\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.209400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.200000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.340000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.232000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.212000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.144000  lift=-31.23%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.340000  lift=62.37%\n",
      "Best of BOTH: 62.37%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_338\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.000000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.096000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.240000  lift=125.56%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.096000  lift=-9.77%\n",
      "Best of BOTH: 125.56%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_46\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.069600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.078000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.078000  lift=12.07%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.360000  lift=417.24%\n",
      "Best of BOTH: 417.24%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_565\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.161600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.150000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.156000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.102000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=1.020000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.510000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.396000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.276000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.156000  lift=-3.47%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=1.020000  lift=531.19%\n",
      "Best of BOTH: 531.19%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_72\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.129600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.204000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.126000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.184000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.116000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.204000  lift=57.41%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.184000  lift=41.98%\n",
      "Best of BOTH: 57.41%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_999\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.117800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.204000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.174000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.146000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.204000  lift=73.17%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.146000  lift=23.94%\n",
      "Best of BOTH: 73.17%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_166\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.202200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.120000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.960000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.700000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.368000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.348000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=18.69%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.960000  lift=374.78%\n",
      "Best of BOTH: 374.78%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_323\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.106400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.252000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.180000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.188000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.252000  lift=136.84%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.188000  lift=76.69%\n",
      "Best of BOTH: 136.84%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_494\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.128600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.072000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.120000  lift=-6.69%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.120000  lift=-6.69%\n",
      "Best of BOTH: -6.69%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_51\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.190800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.088000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.146000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.600000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.318000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=25.79%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.600000  lift=214.47%\n",
      "Best of BOTH: 214.47%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_754\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.114800\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.072000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.470000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.324000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.234000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.096000  lift=-16.38%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.470000  lift=309.41%\n",
      "Best of BOTH: 309.41%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_82\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.187400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.078000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.120000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.120000  lift=-35.97%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.240000  lift=28.07%\n",
      "Best of BOTH: 28.07%  (direction=DOWN) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_108\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.251400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.204000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.320000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.240000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.164000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.360000  lift=43.20%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.240000  lift=-4.53%\n",
      "Best of BOTH: 43.20%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_167\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.166400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.192000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.140000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.048000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.360000  lift=116.35%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.096000  lift=-42.31%\n",
      "Best of BOTH: 116.35%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_321\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.117600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.480000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.144000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.204000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.126000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.480000  lift=308.16%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.204000  lift=73.47%\n",
      "Best of BOTH: 308.16%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_523\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.186000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.390000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.300000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.262000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.288000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.246000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.390000  lift=109.68%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.288000  lift=54.84%\n",
      "Best of BOTH: 109.68%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_61\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.274000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.388000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.314000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.308000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.388000  lift=41.61%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.308000  lift=12.41%\n",
      "Best of BOTH: 41.61%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_762\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.100200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.096000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.078000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.204000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.222000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.120000  lift=19.76%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.222000  lift=121.56%\n",
      "Best of BOTH: 121.56%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.134600\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.144000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.360000  lift=167.46%\n",
      "Best DOWN : level=TOPK_DOWN= 5 | count=5    avg_overall=0.144000  lift=6.98%\n",
      "Best of BOTH: 167.46%  (direction=UP) | count=2\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.241200\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.144000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.144000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.000000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.048000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.218000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.144000  lift=-40.30%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.218000  lift=-9.62%\n",
      "Best of BOTH: -9.62%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.346400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.496000 [> overall]\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.408000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.360000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.240000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.246000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 5   | count=5    avg_overall=0.496000  lift=43.19%\n",
      "Best DOWN : level=TOPK_DOWN= 2 | count=2    avg_overall=0.360000  lift=3.93%\n",
      "Best of BOTH: 43.19%  (direction=UP) | count=5\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.136000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.000000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.000000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.150000 [> overall]\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.000000\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.120000\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.096000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.168000 [> overall]\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 10  | count=10   avg_overall=0.150000  lift=10.29%\n",
      "Best DOWN : level=TOPK_DOWN= 10 | count=10   avg_overall=0.168000  lift=23.53%\n",
      "Best of BOTH: 23.53%  (direction=DOWN) | count=10\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.216000\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.000000\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.200000\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.080000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.118000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.480000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.240000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.144000\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.072000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 2   | count=2    avg_overall=0.200000  lift=-7.41%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.480000  lift=122.22%\n",
      "Best of BOTH: 122.22%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.080400\n",
      "\n",
      "=== Selection levels (UP: high delta_confidence) ===\n",
      "TOPK_UP= 1     -> count=1     avg_overall=0.240000 [> overall]\n",
      "TOPK_UP= 2     -> count=2     avg_overall=0.120000 [> overall]\n",
      "TOPK_UP= 5     -> count=5     avg_overall=0.048000\n",
      "TOPK_UP= 10    -> count=10    avg_overall=0.024000\n",
      "\n",
      "=== Selection levels (DOWN: low/negative delta_confidence) ===\n",
      "TOPK_DOWN= 1   -> count=1     avg_overall=0.300000 [> overall]\n",
      "TOPK_DOWN= 2   -> count=2     avg_overall=0.270000 [> overall]\n",
      "TOPK_DOWN= 5   -> count=5     avg_overall=0.108000 [> overall]\n",
      "TOPK_DOWN= 10  -> count=10    avg_overall=0.054000\n",
      "\n",
      "--- Best levels (this SAE) ---\n",
      "Best UP   : level=TOPK_UP= 1   | count=1    avg_overall=0.240000  lift=198.51%\n",
      "Best DOWN : level=TOPK_DOWN= 1 | count=1    avg_overall=0.300000  lift=273.13%\n",
      "Best of BOTH: 273.13%  (direction=DOWN) | count=1\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and best-of-both)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=30   avg_lift=-58.69%\n",
      "TOPK_UP= 2    : N=30   avg_lift=-3.67%\n",
      "TOPK_UP= 5    : N=30   avg_lift=-5.78%\n",
      "TOPK_UP= 10   : N=30   avg_lift=-8.54%\n",
      "\n",
      "Per-level average lift across SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=30   avg_lift=-18.22%\n",
      "TOPK_DOWN= 2  : N=30   avg_lift=19.60%\n",
      "TOPK_DOWN= 5  : N=30   avg_lift=16.17%\n",
      "TOPK_DOWN= 10 : N=30   avg_lift=9.10%\n",
      "\n",
      "--- BEST (per SAE) summaries (ALL) ---\n",
      "UP   : SAEs with positive lift: 20 / 30 (66.67%)\n",
      "      Average BEST lift across SAEs (UP): 53.48%\n",
      "DOWN : SAEs with positive lift: 24 / 30 (80.00%)\n",
      "      Average BEST lift across SAEs (DOWN): 108.17%\n",
      "BOTH : SAEs with positive lift: 28 / 30 (93.33%)\n",
      "Base steering score across SAEs: 0.171367\n",
      "After selection steering score across SAEs (approx): 0.431994\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 152.09%\n",
      "      Average selected feature count per SAE (Best of UP or DOWN): 3.33\n",
      "\n",
      "================================================================================\n",
      "SAEs flagged as NON-STEERING by the configured criteria\n",
      "- Criteria:\n",
      "  1) max selected count across all levels/directions < 5\n",
      "  2) best-of-both lift <= 0.00%\n",
      "  3) levels achieving count>=5 across UP+DOWN < 2\n",
      "--------------------------------------------------------------------------------\n",
      "[NON-STEERING] jump_relu_494\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-6.687402799377954)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-6.687402799377954  best_down_lift=-6.687402799377954  best_of_both=-6.687402799377954\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "[NON-STEERING] topk_320\n",
      "  Reasons:\n",
      "    - no level yields lift > 0.00% (best_of_both=-9.618573797678263)\n",
      "  Stats: max_count_up=10  max_count_down=10\n",
      "         best_up_lift=-40.29850746268657  best_down_lift=-9.618573797678263  best_of_both=-9.618573797678263\n",
      "         levels_hit(up)=2  levels_hit(down)=2\n",
      "\n",
      "================================================================================\n",
      "SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\n",
      "--------------------------------------------------------------------------------\n",
      "Per-level average lift across QUALIFIED SAEs (UP levels):\n",
      "TOPK_UP= 1    : N=28   avg_lift=-55.74%\n",
      "TOPK_UP= 2    : N=28   avg_lift=-0.12%\n",
      "TOPK_UP= 5    : N=28   avg_lift=-3.85%\n",
      "TOPK_UP= 10   : N=28   avg_lift=-6.14%\n",
      "\n",
      "Per-level average lift across QUALIFIED SAEs (DOWN levels):\n",
      "TOPK_DOWN= 1  : N=28   avg_lift=-12.38%\n",
      "TOPK_DOWN= 2  : N=28   avg_lift=28.14%\n",
      "TOPK_DOWN= 5  : N=28   avg_lift=21.09%\n",
      "TOPK_DOWN= 10 : N=28   avg_lift=10.33%\n",
      "\n",
      "--- BEST (per SAE) summaries (QUALIFIED) ---\n",
      "UP   : SAEs with positive lift: 20 / 28 (71.43%)\n",
      "      Average BEST lift across SAEs (UP): 58.97%\n",
      "DOWN : SAEs with positive lift: 24 / 28 (85.71%)\n",
      "      Average BEST lift across SAEs (DOWN): 116.48%\n",
      "BOTH : SAEs with positive lift: 28 / 28 (100.00%)\n",
      "Base steering score across SAEs: 0.170400\n",
      "After selection steering score across SAEs (approx): 0.449060\n",
      "      Average BEST lift across SAEs (Best of UP or DOWN): 163.53%\n",
      "      Average selected feature count per SAE (Best of UP or DOWN): 3.14\n",
      "\n",
      "================================================================================\n",
      "STEERING RESULTS FOR QUALIFIED SAEs (best level per SAE)\n",
      "--------------------------------------------------------------------------------\n",
      "[batch_topk_160] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.360000 | lift=81.63%\n",
      "[batch_topk_320] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.336000 | lift=89.40%\n",
      "[batch_topk_50] best_dir=DOWN  | level=TOPK_DOWN= 5 | count=5    | avg_overall=0.328000 | lift=14.29%\n",
      "[batch_topk_520] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.600000 | lift=295.78%\n",
      "[batch_topk_80] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.920000 | lift=304.93%\n",
      "[batch_topk_820] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.240000 | lift=92.31%\n",
      "[gated_141] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.340000 | lift=62.37%\n",
      "[gated_338] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.240000 | lift=125.56%\n",
      "[gated_46] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.360000 | lift=417.24%\n",
      "[gated_565] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=1.020000 | lift=531.19%\n",
      "[gated_72] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.204000 | lift=57.41%\n",
      "[gated_999] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.204000 | lift=73.17%\n",
      "[jump_relu_166] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.960000 | lift=374.78%\n",
      "[jump_relu_323] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.252000 | lift=136.84%\n",
      "[jump_relu_51] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.600000 | lift=214.47%\n",
      "[jump_relu_754] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.470000 | lift=309.41%\n",
      "[jump_relu_82] best_dir=DOWN  | level=TOPK_DOWN= 2 | count=2    | avg_overall=0.240000 | lift=28.07%\n",
      "[standard_april_update_108] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.360000 | lift=43.20%\n",
      "[standard_april_update_167] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.360000 | lift=116.35%\n",
      "[standard_april_update_321] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.480000 | lift=308.16%\n",
      "[standard_april_update_523] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.390000 | lift=109.68%\n",
      "[standard_april_update_61] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.388000 | lift=41.61%\n",
      "[standard_april_update_762] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.222000 | lift=121.56%\n",
      "[topk_160] best_dir=UP    | level=TOPK_UP= 2   | count=2    | avg_overall=0.360000 | lift=167.46%\n",
      "[topk_50] best_dir=UP    | level=TOPK_UP= 5   | count=5    | avg_overall=0.496000 | lift=43.19%\n",
      "[topk_520] best_dir=DOWN  | level=TOPK_DOWN= 10 | count=10   | avg_overall=0.168000 | lift=23.53%\n",
      "[topk_80] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.480000 | lift=122.22%\n",
      "[topk_820] best_dir=DOWN  | level=TOPK_DOWN= 1 | count=1    | avg_overall=0.300000 | lift=273.13%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "import numpy as np\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Roots\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/Qwen2.5-3B-Instruct/layer17\"\n",
    "ENTROPY_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_entropy_score/amp10_top_1/Qwen2.5-3B/layer17\"\n",
    "\n",
    "# --------------------------------------------------------------------\n",
    "# Selection levels use QUANTILES and/or TOP-K instead of absolute cuts\n",
    "# --------------------------------------------------------------------\n",
    "USE_QUANTILES = False\n",
    "# Upper-tail quantiles for UP (delta_confidence high end). For DOWN we mirror to lower-tail.\n",
    "# Example: 0.99 means \"select features with delta_confidence >= 99th percentile\" (UP)\n",
    "# and \"select features with delta_confidence <= 1st percentile\" (DOWN).\n",
    "QUANTILES: List[float] = [0.99, 0.95, 0.90, 0.80]\n",
    "\n",
    "USE_TOPK = True\n",
    "# Top-K sizes (by magnitude in the corresponding direction).\n",
    "# For UP: take K largest delta_confidence; for DOWN: take K most negative delta_confidence.\n",
    "TOPK_LIST: List[int] = [1, 2, 3, 4, 5]\n",
    "\n",
    "# ---- Non-steering detection (tunable) ----\n",
    "# A SAE is flagged as NON-STEERING if ANY of the following holds:\n",
    "#   1) max selected count across all levels/directions < MIN_SELECTION_COUNT\n",
    "#   2) best-of-both lift <= MIN_BEST_LIFT\n",
    "#   3) number of levels (across UP+DOWN) with count >= MIN_SELECTION_COUNT < MIN_LEVELS_HIT\n",
    "MIN_SELECTION_COUNT   = 5     # require at least this many selected features at ANY level\n",
    "MIN_BEST_LIFT        = 0.0    # require best-of-both lift strictly greater than this (e.g., > 0.0)\n",
    "MIN_LEVELS_HIT       = 2      # how many levels achieve count >= MIN_SELECTION_COUNT\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Utils\n",
    "# =====================================================================================\n",
    "\n",
    "def safe_load_json(path: str) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"Load a JSON file, returning None if it does not exist or is invalid.\"\"\"\n",
    "    if not os.path.isfile(path):\n",
    "        return None\n",
    "    try:\n",
    "        with open(path, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: failed to load JSON '{path}': {e}\")\n",
    "        return None\n",
    "\n",
    "\n",
    "def get_overall_from_eval_item(item: Dict[str, Any]) -> Optional[float]:\n",
    "    \"\"\"Extract holdout->mean->overall if present; else None.\"\"\"\n",
    "    try:\n",
    "        return float(item[\"holdout\"][\"mean\"][\"overall\"])\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "\n",
    "def compute_base_stats(eval_data: Dict[str, Any]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only the present 'overall' values (missing -> 0 contribution).\n",
    "    Note: We DO NOT drop 0.0 overall values; they are valid and part of the baseline.\n",
    "    \"\"\"\n",
    "    num_features = len(eval_data)\n",
    "    sum_overall = 0.0\n",
    "    for v in eval_data.values():\n",
    "        s = get_overall_from_eval_item(v)\n",
    "        if s is not None:\n",
    "            sum_overall += s  # keep zeros\n",
    "    avg = (sum_overall / num_features) if num_features > 0 else 0.0\n",
    "    return num_features, avg\n",
    "\n",
    "\n",
    "def pct_lift(avg_subset: float, avg_all: float) -> Optional[float]:\n",
    "    \"\"\"Percentage lift of subset vs baseline; None if baseline is 0 or undefined.\"\"\"\n",
    "    if avg_all == 0.0:\n",
    "        return None\n",
    "    return (avg_subset - avg_all) / avg_all * 100.0\n",
    "\n",
    "\n",
    "def build_delta_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: delta_confidence} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"delta_confidence\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"delta_confidence\"])\n",
    "            except Exception:\n",
    "                pass\n",
    "    return out\n",
    "\n",
    "\n",
    "def avg_for_selected(eval_data: Dict[str, Any], selected_ids: List[str]) -> Tuple[int, float]:\n",
    "    \"\"\"\n",
    "    Return:\n",
    "      - count of selected features that also have 'overall' in eval_data\n",
    "      - average 'overall' over those features (0.0 if count=0)\n",
    "    \"\"\"\n",
    "    vals: List[float] = []\n",
    "    for fid in selected_ids:\n",
    "        s = get_overall_from_eval_item(eval_data.get(fid, {}))\n",
    "        if s is not None:\n",
    "            vals.append(s)  # keep zeros\n",
    "    n = len(vals)\n",
    "    avg = (sum(vals) / n) if n > 0 else 0.0\n",
    "    return n, avg\n",
    "\n",
    "\n",
    "def mark_vs_overall(avg_subset: float, avg_all: float) -> str:\n",
    "    \"\"\"Return a short marker if subset average beats the all-features average.\"\"\"\n",
    "    return \" [> overall]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection levels (Quantiles / Top-K)\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_for_up(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build UP (high end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles: label like 'Q>=0.95'\n",
    "    - Top-K:     label like 'TOPK_UP= 10'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (upper tail): select v >= quantile(q)\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            cut = float(np.quantile(vals, q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] >= cut]\n",
    "            levels.append((f\"Q>= {q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (largest K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_up = sorted(fids, key=lambda x: delta_map[x], reverse=True)\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_up[:max(0, min(k, len(sorted_up)))]\n",
    "            levels.append((f\"TOPK_UP= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_for_down(\n",
    "    delta_map: Dict[str, float],\n",
    "    quantiles: List[float],\n",
    "    topk_list: List[int],\n",
    "    use_quantiles: bool,\n",
    "    use_topk: bool,\n",
    ") -> List[Tuple[str, List[str]]]:\n",
    "    \"\"\"\n",
    "    Build DOWN (negative end) selection levels.\n",
    "    Returns list of (label, selected_ids).\n",
    "    - Quantiles (lower tail): label like 'Q<=0.05' meaning v <= quantile(0.05)\n",
    "      (Mirroring an upper-tail q by using (1 - q) for the lower tail.)\n",
    "    - Top-K:     label like 'TOPK_DOWN= {k}'\n",
    "    \"\"\"\n",
    "    levels: List[Tuple[str, List[str]]] = []\n",
    "    if not delta_map:\n",
    "        return levels\n",
    "\n",
    "    fids = list(delta_map.keys())\n",
    "    vals = np.array([delta_map[f] for f in fids], dtype=float)\n",
    "\n",
    "    # Quantiles (lower tail): mirror\n",
    "    if use_quantiles and quantiles:\n",
    "        qs = sorted(set(quantiles), reverse=True)\n",
    "        for q in qs:\n",
    "            low_q = 1.0 - q\n",
    "            low_cut = float(np.quantile(vals, low_q))\n",
    "            sel = [fid for fid in fids if delta_map[fid] <= low_cut]\n",
    "            levels.append((f\"Q<= {low_q:.2f}\", sel))\n",
    "\n",
    "    # Top-K (most negative K)\n",
    "    if use_topk and topk_list:\n",
    "        sorted_down = sorted(fids, key=lambda x: delta_map[x])  # ascending => most negative first\n",
    "        for k in sorted(set(topk_list)):\n",
    "            sel = sorted_down[:max(0, min(k, len(sorted_down)))]\n",
    "            levels.append((f\"TOPK_DOWN= {k}\", sel))\n",
    "\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Per-SAE processing\n",
    "# =====================================================================================\n",
    "\n",
    "def process_one_sae(\n",
    "    sae_name: str,\n",
    "    order_up_labels: List[str],\n",
    "    order_down_labels: List[str],\n",
    ") -> Tuple[\n",
    "    Dict[str, float],   # per-level lifts (UP)      label -> lift\n",
    "    Dict[str, float],   # per-level lifts (DOWN)    label -> lift\n",
    "    Optional[Tuple[str, int, float, float]],  # best_up: (label, count, avg, lift)\n",
    "    Optional[Tuple[str, int, float, float]],  # best_down: (label, count, avg, lift)\n",
    "    Optional[float],    # best_of_both lift\n",
    "    Optional[int],      # best_of_both count\n",
    "    Dict[str, int],     # per-level counts (UP)\n",
    "    Dict[str, int],     # per-level counts (DOWN)\n",
    "    float,              # base_avg_overall for this SAE\n",
    "]:\n",
    "    \"\"\"\n",
    "    Process one SAE subfolder present under EVAL_ROOT and ENTROPY_ROOT.\n",
    "\n",
    "    Returns:\n",
    "      - per_level_lifts_up:    dict[label] = lift% for UP (when computable)\n",
    "      - per_level_lifts_down:  dict[label] = lift% for DOWN (when computable)\n",
    "      - best_up tuple:         (label, count, avg, lift) or None if no selection\n",
    "      - best_down tuple:       (label, count, avg, lift) or None if no selection\n",
    "      - best_of_both_lift:     max(best_up_lift, best_down_lift) if either exists, else None\n",
    "      - best_of_both_count:    selected-feature count for the best-of-both choice (or None)\n",
    "      - per_level_counts_up/down: counts per label for UP/DOWN\n",
    "      - base_avg_overall:      baseline average of all features for this SAE\n",
    "    \"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    entropy_path = os.path.join(ENTROPY_ROOT, sae_name, \"output_scores_plus_top20_kconf1.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json -> skip\n",
    "        return {}, {}, None, None, None, None, {}, {}, 0.0\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Base stats\n",
    "    num_features, avg_overall_all = compute_base_stats(eval_data)\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {avg_overall_all:.6f}\")\n",
    "\n",
    "    entropy_data = safe_load_json(entropy_path)\n",
    "    if entropy_data is None:\n",
    "        print(f\"(No entropy/confidence scores found at: {entropy_path}. Skipping selection levels.)\")\n",
    "        return {}, {}, None, None, None, None, {}, {}, avg_overall_all\n",
    "\n",
    "    # Build delta map\n",
    "    delta_map = build_delta_map(entropy_data)\n",
    "\n",
    "    # Compose selection levels for UP & DOWN\n",
    "    up_levels   = selection_levels_for_up(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "    down_levels = selection_levels_for_down(delta_map, QUANTILES, TOPK_LIST, USE_QUANTILES, USE_TOPK)\n",
    "\n",
    "    # Keep maps for lifts/counts keyed by label for deterministic aggregation/printing\n",
    "    per_level_lifts_up: Dict[str, float] = {}\n",
    "    per_level_counts_up: Dict[str, int] = {}\n",
    "    per_level_lifts_down: Dict[str, float] = {}\n",
    "    per_level_counts_down: Dict[str, int] = {}\n",
    "\n",
    "    # ---- UP section ----\n",
    "    print(\"\\n=== Selection levels (UP: high delta_confidence) ===\")\n",
    "    best_up: Optional[Tuple[str, int, float, float]] = None  # (label, count, avg, lift)\n",
    "    best_up_avg = float(\"-inf\")\n",
    "    best_up_count = -1\n",
    "\n",
    "    # Ensure printing order follows order_up_labels; fallback to appending any missing labels\n",
    "    up_levels_map = {lab: ids for lab, ids in up_levels}\n",
    "    up_labels_ordered = [lab for lab in order_up_labels if lab in up_levels_map] + \\\n",
    "                        [lab for lab in up_levels_map.keys() if lab not in order_up_labels]\n",
    "\n",
    "    for label in up_labels_ordered:\n",
    "        selected = up_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_up[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_up[label] = lift\n",
    "                if (avg_sub > best_up_avg) or (avg_sub == best_up_avg and n > best_up_count):\n",
    "                    best_up = (label, n, avg_sub, lift)\n",
    "                    best_up_avg = avg_sub\n",
    "                    best_up_count = n\n",
    "        print(line)\n",
    "\n",
    "    # ---- DOWN section ----\n",
    "    print(\"\\n=== Selection levels (DOWN: low/negative delta_confidence) ===\")\n",
    "    best_down: Optional[Tuple[str, int, float, float]] = None\n",
    "    best_down_avg = float(\"-inf\")\n",
    "    best_down_count = -1\n",
    "\n",
    "    down_levels_map = {lab: ids for lab, ids in down_levels}\n",
    "    down_labels_ordered = [lab for lab in order_down_labels if lab in down_levels_map] + \\\n",
    "                          [lab for lab in down_levels_map.keys() if lab not in order_down_labels]\n",
    "\n",
    "    for label in down_labels_ordered:\n",
    "        selected = down_levels_map[label]\n",
    "        n, avg_sub = avg_for_selected(eval_data, selected)\n",
    "        per_level_counts_down[label] = n\n",
    "        line = f\"{label:<14} -> count={n:<5} avg_overall={avg_sub:.6f}{mark_vs_overall(avg_sub, avg_overall_all)}\"\n",
    "        if n > 0:\n",
    "            lift = pct_lift(avg_sub, avg_overall_all)\n",
    "            if lift is not None:\n",
    "                per_level_lifts_down[label] = lift\n",
    "                if (avg_sub > best_down_avg) or (avg_sub == best_down_avg and n > best_down_count):\n",
    "                    best_down = (label, n, avg_sub, lift)\n",
    "                    best_down_avg = avg_sub\n",
    "                    best_down_count = n\n",
    "        print(line)\n",
    "\n",
    "    # Best-of-both (per SAE): choose the direction with larger lift; carry the count too\n",
    "    best_of_both_lift: Optional[float] = None\n",
    "    best_of_both_count: Optional[int] = None\n",
    "    if best_up is not None and best_down is not None:\n",
    "        if best_up[3] >= best_down[3]:\n",
    "            best_of_both_lift = best_up[3]\n",
    "            best_of_both_count = best_up[1]\n",
    "            direction = \"UP\"\n",
    "        else:\n",
    "            best_of_both_lift = best_down[3]\n",
    "            best_of_both_count = best_down[1]\n",
    "            direction = \"DOWN\"\n",
    "    elif best_up is not None:\n",
    "        best_of_both_lift = best_up[3]\n",
    "        best_of_both_count = best_up[1]\n",
    "        direction = \"UP\"\n",
    "    elif best_down is not None:\n",
    "        best_of_both_lift = best_down[3]\n",
    "        best_of_both_count = best_down[1]\n",
    "        direction = \"DOWN\"\n",
    "    else:\n",
    "        direction = \"N/A\"\n",
    "\n",
    "    # Print per-SAE best summary\n",
    "    print(\"\\n--- Best levels (this SAE) ---\")\n",
    "    if best_up is None:\n",
    "        print(\"Best UP   : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best UP   : level={best_up[0]:<12} | count={best_up[1]:<4} avg_overall={best_up[2]:.6f}  lift={best_up[3]:.2f}%\")\n",
    "    if best_down is None:\n",
    "        print(\"Best DOWN : N/A (no non-empty selection)\")\n",
    "    else:\n",
    "        print(f\"Best DOWN : level={best_down[0]:<12} | count={best_down[1]:<4} avg_overall={best_down[2]:.6f}  lift={best_down[3]:.2f}%\")\n",
    "    if best_of_both_lift is None:\n",
    "        print(\"Best of BOTH: N/A\")\n",
    "    else:\n",
    "        print(f\"Best of BOTH: {best_of_both_lift:.2f}%  (direction={direction}) | count={best_of_both_count}\")\n",
    "\n",
    "    return (\n",
    "        per_level_lifts_up,\n",
    "        per_level_lifts_down,\n",
    "        best_up,\n",
    "        best_down,\n",
    "        best_of_both_lift,\n",
    "        best_of_both_count,\n",
    "        per_level_counts_up,\n",
    "        per_level_counts_down,\n",
    "        avg_overall_all,\n",
    "    )\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Main\n",
    "# =====================================================================================\n",
    "\n",
    "def main():\n",
    "    if not os.path.isdir(EVAL_ROOT):\n",
    "        print(f\"Eval root folder not found: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    # Build the global (ordered) label lists we will use for consistent printing/aggregation\n",
    "    order_up_labels: List[str] = []\n",
    "    order_down_labels: List[str] = []\n",
    "    if USE_QUANTILES and QUANTILES:\n",
    "        for q in sorted(set(QUANTILES), reverse=True):\n",
    "            order_up_labels.append(f\"Q>= {q:.2f}\")\n",
    "            order_down_labels.append(f\"Q<= {1.0 - q:.2f}\")\n",
    "    if USE_TOPK and TOPK_LIST:\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            order_up_labels.append(f\"TOPK_UP= {k}\")\n",
    "            order_down_labels.append(f\"TOPK_DOWN= {k}\")\n",
    "\n",
    "    # Across-SAEs per-level aggregations (unfiltered)\n",
    "    def init_agg(levels: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {lab: {\"sum\": 0.0, \"count\": 0.0} for lab in levels}\n",
    "\n",
    "    across_up = init_agg(order_up_labels)\n",
    "    across_down = init_agg(order_down_labels)\n",
    "\n",
    "    # Per-SAE best stats (unfiltered)\n",
    "    best_up_lifts: List[float] = []\n",
    "    best_down_lifts: List[float] = []\n",
    "    best_both_lifts: List[float] = []\n",
    "    best_both_counts: List[int] = []\n",
    "    pos_up = pos_down = pos_both = 0\n",
    "    saes_with_up = saes_with_down = saes_with_both = 0\n",
    "\n",
    "    # Keep per-SAE records for later filtered summary\n",
    "    sae_records: List[Dict[str, Any]] = []\n",
    "    non_steering: List[Tuple[str, List[str], Dict[str, Any]]] = []\n",
    "\n",
    "    # Iterate SAEs\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if not os.path.isdir(sae_dir):\n",
    "            continue\n",
    "\n",
    "        (\n",
    "            per_up,\n",
    "            per_down,\n",
    "            best_up,\n",
    "            best_down,\n",
    "            best_both_lift,\n",
    "            best_both_count,\n",
    "            cnts_up,\n",
    "            cnts_down,\n",
    "            base_avg,\n",
    "        ) = process_one_sae(sae_name, order_up_labels, order_down_labels)\n",
    "\n",
    "        # Save record\n",
    "        sae_records.append(\n",
    "            {\n",
    "                \"name\": sae_name,\n",
    "                \"per_up\": per_up,\n",
    "                \"per_down\": per_down,\n",
    "                \"best_up\": best_up,\n",
    "                \"best_down\": best_down,\n",
    "                \"best_both_lift\": best_both_lift,\n",
    "                \"best_both_count\": best_both_count,\n",
    "                \"cnts_up\": cnts_up,\n",
    "                \"cnts_down\": cnts_down,\n",
    "                \"base_avg\": base_avg,\n",
    "            }\n",
    "        )\n",
    "\n",
    "        # Aggregate per-level lifts (UP/DOWN) for unfiltered summary\n",
    "        for lab, lift in per_up.items():\n",
    "            if lab not in across_up:\n",
    "                across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_up[lab][\"sum\"] += lift\n",
    "            across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in per_down.items():\n",
    "            if lab not in across_down:\n",
    "                across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            across_down[lab][\"sum\"] += lift\n",
    "            across_down[lab][\"count\"] += 1\n",
    "\n",
    "        # Track per-direction BEST (unfiltered)\n",
    "        if best_up is not None:\n",
    "            saes_with_up += 1\n",
    "            best_up_lifts.append(best_up[3])\n",
    "            if best_up[3] > 0:\n",
    "                pos_up += 1\n",
    "        if best_down is not None:\n",
    "            saes_with_down += 1\n",
    "            best_down_lifts.append(best_down[3])\n",
    "            if best_down[3] > 0:\n",
    "                pos_down += 1\n",
    "        if (best_both_lift is not None) and isinstance(best_both_lift, float):\n",
    "            saes_with_both += 1\n",
    "            best_both_lifts.append(best_both_lift)\n",
    "            if isinstance(best_both_count, int):\n",
    "                best_both_counts.append(best_both_count)\n",
    "            if best_both_lift > 0:\n",
    "                pos_both += 1\n",
    "\n",
    "        # ---------------------------\n",
    "        # Non-steering detection\n",
    "        # ---------------------------\n",
    "        reasons: List[str] = []\n",
    "        max_count_up = max(cnts_up.values(), default=0)\n",
    "        max_count_down = max(cnts_down.values(), default=0)\n",
    "        max_count_both = max(max_count_up, max_count_down)\n",
    "\n",
    "        # How many levels hit MIN_SELECTION_COUNT (across both directions)\n",
    "        hits_up = sum(1 for c in cnts_up.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_down = sum(1 for c in cnts_down.values() if c >= MIN_SELECTION_COUNT)\n",
    "        hits_both = hits_up + hits_down\n",
    "\n",
    "        # Condition 1: insufficient selected features at any level\n",
    "        if max_count_both < MIN_SELECTION_COUNT:\n",
    "            reasons.append(f\"insufficient selected features: max_count={max_count_both} < {MIN_SELECTION_COUNT}\")\n",
    "\n",
    "        # Condition 2: no positive (or required) lift anywhere\n",
    "        if (best_both_lift is None) or (best_both_lift <= MIN_BEST_LIFT):\n",
    "            reasons.append(\n",
    "                f\"no level yields lift > {MIN_BEST_LIFT:.2f}% (best_of_both={best_both_lift if best_both_lift is not None else 'N/A'})\"\n",
    "            )\n",
    "\n",
    "        # Condition 3: stability across levels is poor\n",
    "        if hits_both < MIN_LEVELS_HIT:\n",
    "            reasons.append(\n",
    "                f\"unstable coverage: levels_with_count>={MIN_SELECTION_COUNT} = {hits_both} < {MIN_LEVELS_HIT}\"\n",
    "            )\n",
    "\n",
    "        if len(reasons) > 0:\n",
    "            non_steering.append((\n",
    "                sae_name,\n",
    "                reasons,\n",
    "                {\n",
    "                    \"max_count_up\": max_count_up,\n",
    "                    \"max_count_down\": max_count_down,\n",
    "                    \"best_up_lift\": (best_up[3] if best_up else None),\n",
    "                    \"best_down_lift\": (best_down[3] if best_down else None),\n",
    "                    \"best_of_both_lift\": best_both_lift,\n",
    "                    \"hits_up\": hits_up,\n",
    "                    \"hits_down\": hits_down,\n",
    "                }\n",
    "            ))\n",
    "\n",
    "    # =================================================================================\n",
    "    # Unfiltered summary across ALL SAEs (baseline reference)\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS SAEs (ALL, using each SAE's BEST level per direction and best-of-both)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # Per-level averages: UP\n",
    "    print(\"Per-level average lift across SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Per-level averages: DOWN\n",
    "    print(\"\\nPer-level average lift across SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Compute base across ALL SAEs (fixed baseline definition: average of each SAE's all-feature mean)\n",
    "    all_base_vals = [rec[\"base_avg\"] for rec in sae_records]\n",
    "    base_across_all = (sum(all_base_vals) / len(all_base_vals)) if all_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (ALL)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (ALL) ---\")\n",
    "    if saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_up_best = sum(best_up_lifts) / len(best_up_lifts)\n",
    "        pct_up_pos = (pos_up / saes_with_up) * 100.0\n",
    "        print(f\"UP   : SAEs with positive lift: {pos_up} / {saes_with_up} ({pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {avg_up_best:.2f}%\")\n",
    "\n",
    "    if saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        avg_down_best = sum(best_down_lifts) / len(best_down_lifts)\n",
    "        pct_down_pos = (pos_down / saes_with_down) * 100.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {pos_down} / {saes_with_down} ({pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {avg_down_best:.2f}%\")\n",
    "\n",
    "    if saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        avg_both_best_all = 0.0\n",
    "        avg_both_count_all = 0.0\n",
    "    else:\n",
    "        avg_both_best_all = sum(best_both_lifts) / len(best_both_lifts)\n",
    "        avg_both_count_all = (sum(best_both_counts) / len(best_both_counts)) if best_both_counts else 0.0\n",
    "        pct_both_pos = (pos_both / saes_with_both) * 100.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {pos_both} / {saes_with_both} ({pct_both_pos:.2f}%)\")\n",
    "        print(f\"Base steering score across SAEs: {base_across_all:.6f}\")\n",
    "        print(f\"After selection steering score across SAEs (approx): {base_across_all * (1 + (avg_both_best_all/100.0)):.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {avg_both_best_all:.2f}%\")\n",
    "        print(f\"      Average selected feature count per SAE (Best of UP or DOWN): {avg_both_count_all:.2f}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Non-steering report\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SAEs flagged as NON-STEERING by the configured criteria\")\n",
    "    print(\"- Criteria:\")\n",
    "    print(f\"  1) max selected count across all levels/directions < {MIN_SELECTION_COUNT}\")\n",
    "    print(f\"  2) best-of-both lift <= {MIN_BEST_LIFT:.2f}%\")\n",
    "    print(f\"  3) levels achieving count>={MIN_SELECTION_COUNT} across UP+DOWN < {MIN_LEVELS_HIT}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    non_names = set()\n",
    "    if not non_steering:\n",
    "        print(\"All SAEs pass the steering capability criteria.\")\n",
    "    else:\n",
    "        for name, reasons, stats in non_steering:\n",
    "            non_names.add(name)\n",
    "            print(f\"[NON-STEERING] {name}\")\n",
    "            print(f\"  Reasons:\")\n",
    "            for r in reasons:\n",
    "                print(f\"    - {r}\")\n",
    "            print(f\"  Stats: max_count_up={stats['max_count_up']}  max_count_down={stats['max_count_down']}\")\n",
    "            print(f\"         best_up_lift={stats['best_up_lift']}  best_down_lift={stats['best_down_lift']}  best_of_both={stats['best_of_both_lift']}\")\n",
    "            print(f\"         levels_hit(up)={stats['hits_up']}  levels_hit(down)={stats['hits_down']}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # FILTERED summary across STEERING-QUALIFIED SAEs only\n",
    "    # =================================================================================\n",
    "    qualified = [rec for rec in sae_records if rec[\"name\"] not in non_names]\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY FOR STEERING-QUALIFIED SAEs (after filtering by the criteria)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    if not qualified:\n",
    "        print(\"No SAE remains after filtering; cannot compute qualified summary.\")\n",
    "        return\n",
    "\n",
    "    # Per-level averages across qualified\n",
    "    def init_agg_like(template_keys: List[str]) -> Dict[str, Dict[str, float]]:\n",
    "        return {k: {\"sum\": 0.0, \"count\": 0.0} for k in template_keys}\n",
    "\n",
    "    q_across_up = init_agg_like(order_up_labels)\n",
    "    q_across_down = init_agg_like(order_down_labels)\n",
    "\n",
    "    q_best_up_lifts: List[float] = []\n",
    "    q_best_down_lifts: List[float] = []\n",
    "    q_best_both_lifts: List[float] = []\n",
    "    q_best_both_counts: List[int] = []\n",
    "    q_pos_up = q_pos_down = q_pos_both = 0\n",
    "    q_saes_with_up = q_saes_with_down = q_saes_with_both = 0\n",
    "\n",
    "    for rec in qualified:\n",
    "        # per-level lifts\n",
    "        for lab, lift in rec[\"per_up\"].items():\n",
    "            if lab not in q_across_up:\n",
    "                q_across_up[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_up[lab][\"sum\"] += lift\n",
    "            q_across_up[lab][\"count\"] += 1\n",
    "        for lab, lift in rec[\"per_down\"].items():\n",
    "            if lab not in q_across_down:\n",
    "                q_across_down[lab] = {\"sum\": 0.0, \"count\": 0.0}\n",
    "            q_across_down[lab][\"sum\"] += lift\n",
    "            q_across_down[lab][\"count\"] += 1\n",
    "\n",
    "        # best per-direction / best-of-both\n",
    "        if rec[\"best_up\"] is not None:\n",
    "            q_saes_with_up += 1\n",
    "            q_best_up_lifts.append(rec[\"best_up\"][3])\n",
    "            if rec[\"best_up\"][3] > 0:\n",
    "                q_pos_up += 1\n",
    "        if rec[\"best_down\"] is not None:\n",
    "            q_saes_with_down += 1\n",
    "            q_best_down_lifts.append(rec[\"best_down\"][3])\n",
    "            if rec[\"best_down\"][3] > 0:\n",
    "                q_pos_down += 1\n",
    "\n",
    "        if (rec[\"best_both_lift\"] is not None) and isinstance(rec[\"best_both_lift\"], float):\n",
    "            q_saes_with_both += 1\n",
    "            q_best_both_lifts.append(rec[\"best_both_lift\"])\n",
    "            if isinstance(rec[\"best_both_count\"], int):\n",
    "                q_best_both_counts.append(rec[\"best_both_count\"])\n",
    "            if rec[\"best_both_lift\"] > 0:\n",
    "                q_pos_both += 1\n",
    "\n",
    "    # Print per-level averages (qualified)\n",
    "    print(\"Per-level average lift across QUALIFIED SAEs (UP levels):\")\n",
    "    for lab in order_up_labels:\n",
    "        cnt = int(q_across_up.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_up[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    print(\"\\nPer-level average lift across QUALIFIED SAEs (DOWN levels):\")\n",
    "    for lab in order_down_labels:\n",
    "        cnt = int(q_across_down.get(lab, {\"count\": 0})[\"count\"])\n",
    "        if cnt > 0:\n",
    "            avg_lift = q_across_down[lab][\"sum\"] / cnt\n",
    "            print(f\"{lab:<14}: N={cnt:<4} avg_lift={avg_lift:.2f}%\")\n",
    "        else:\n",
    "            print(f\"{lab:<14}: N=0    avg_lift=N/A\")\n",
    "\n",
    "    # Base steering score across QUALIFIED SAEs (same definition as ALL, but over the subset)\n",
    "    q_base_vals = [rec[\"base_avg\"] for rec in qualified]\n",
    "    base_across_qualified = (sum(q_base_vals) / len(q_base_vals)) if q_base_vals else 0.0\n",
    "\n",
    "    # BEST summaries (qualified)\n",
    "    print(\"\\n--- BEST (per SAE) summaries (QUALIFIED) ---\")\n",
    "    if q_saes_with_up == 0:\n",
    "        print(\"UP   : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_up_best = (sum(q_best_up_lifts) / len(q_best_up_lifts)) if q_best_up_lifts else 0.0\n",
    "        q_pct_up_pos = (q_pos_up / q_saes_with_up) * 100.0 if q_saes_with_up > 0 else 0.0\n",
    "        print(f\"UP   : SAEs with positive lift: {q_pos_up} / {q_saes_with_up} ({q_pct_up_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (UP): {q_avg_up_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_down == 0:\n",
    "        print(\"DOWN : No SAE produced a valid BEST selection.\")\n",
    "    else:\n",
    "        q_avg_down_best = (sum(q_best_down_lifts) / len(q_best_down_lifts)) if q_best_down_lifts else 0.0\n",
    "        q_pct_down_pos = (q_pos_down / q_saes_with_down) * 100.0 if q_saes_with_down > 0 else 0.0\n",
    "        print(f\"DOWN : SAEs with positive lift: {q_pos_down} / {q_saes_with_down} ({q_pct_down_pos:.2f}%)\")\n",
    "        print(f\"      Average BEST lift across SAEs (DOWN): {q_avg_down_best:.2f}%\")\n",
    "\n",
    "    if q_saes_with_both == 0:\n",
    "        print(\"BOTH : No SAE produced a valid BEST-of-both selection.\")\n",
    "        q_avg_both_best = 0.0\n",
    "        q_avg_both_count = 0.0\n",
    "    else:\n",
    "        q_avg_both_best = (sum(q_best_both_lifts) / len(q_best_both_lifts)) if q_best_both_lifts else 0.0\n",
    "        q_avg_both_count = (sum(q_best_both_counts) / len(q_best_both_counts)) if q_best_both_counts else 0.0\n",
    "        q_pct_both_pos = (q_pos_both / q_saes_with_both) * 100.0 if q_saes_with_both > 0 else 0.0\n",
    "        print(f\"BOTH : SAEs with positive lift: {q_pos_both} / {q_saes_with_both} ({q_pct_both_pos:.2f}%)\")\n",
    "        print(f\"Base steering score across SAEs: {base_across_qualified:.6f}\")\n",
    "        print(f\"After selection steering score across SAEs (approx): {base_across_qualified * (1 + (q_avg_both_best/100.0)):.6f}\")\n",
    "        print(f\"      Average BEST lift across SAEs (Best of UP or DOWN): {q_avg_both_best:.2f}%\")\n",
    "        print(f\"      Average selected feature count per SAE (Best of UP or DOWN): {q_avg_both_count:.2f}\")\n",
    "\n",
    "    # =================================================================================\n",
    "    # Per-qualified-SAE steering result details\n",
    "    # =================================================================================\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"STEERING RESULTS FOR QUALIFIED SAEs (best level per SAE)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for rec in qualified:\n",
    "        name = rec[\"name\"]\n",
    "        best_up = rec[\"best_up\"]\n",
    "        best_down = rec[\"best_down\"]\n",
    "\n",
    "        best_dir = None\n",
    "        best_tuple = None  # (label, count, avg, lift)\n",
    "        if best_up is not None and best_down is not None:\n",
    "            best_dir = \"UP\" if best_up[3] >= best_down[3] else \"DOWN\"\n",
    "            best_tuple = best_up if best_up[3] >= best_down[3] else best_down\n",
    "        elif best_up is not None:\n",
    "            best_dir = \"UP\"\n",
    "            best_tuple = best_up\n",
    "        elif best_down is not None:\n",
    "            best_dir = \"DOWN\"\n",
    "            best_tuple = best_down\n",
    "\n",
    "        if best_tuple is None:\n",
    "            print(f\"[{name}] No valid best selection found.\")\n",
    "        else:\n",
    "            lab, cnt, avg_overall, lift = best_tuple\n",
    "            print(\n",
    "                f\"[{name}] best_dir={best_dir:<5} | level={lab:<12} | count={cnt:<4} | avg_overall={avg_overall:.6f} | lift={lift:.2f}%\"\n",
    "            )\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b3031296",
   "metadata": {},
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sae4steer",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
