{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "15a91709",
   "metadata": {},
   "source": [
    "# 1 Example"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3778a183",
   "metadata": {},
   "source": [
    "## 1.1 Output Score example test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "282cc894",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1158\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.18\n",
      "\n",
      "Number of features with score >= 0.01: 7\n",
      "Average overall score for score >= 0.01: 0.10285714285714286\n",
      "\n",
      "Number of features with score >= 0.001: 10\n",
      "Average overall score for score >= 0.001: 0.144\n",
      "\n",
      "Number of features with score >= 0.0001: 20\n",
      "Average overall score for score >= 0.0001: 0.10400000000000001\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "\n",
    "# File paths\n",
    "eval_path = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_2b_it/layer12/gated_148/eval.json\"\n",
    "output_scores_path = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_outputscore/gemma2_2b/layer12/gated_148/output_scores_top20.json\"\n",
    "\n",
    "# Load JSON files\n",
    "with open(eval_path, \"r\") as f:\n",
    "    eval_data = json.load(f)\n",
    "\n",
    "with open(output_scores_path, \"r\") as f:\n",
    "    output_scores_data = json.load(f)\n",
    "\n",
    "# base\n",
    "num_features = len(eval_data)\n",
    "overall_scores_all = [item[\"holdout\"][\"mean\"][\"overall\"] for item in eval_data.values()]\n",
    "average_overall_all = sum(overall_scores_all) / num_features if num_features > 0 else 0\n",
    "\n",
    "print(f\"Total number of features: {num_features}\")\n",
    "print(f\"Average overall score (all features): {average_overall_all}\")\n",
    "\n",
    "# thresholds\n",
    "thresholds = [0.1, 0.01, 0.001, 0.0001]\n",
    "\n",
    "for th in thresholds:\n",
    "    selected_features = [f for f, info in output_scores_data.items() if info[\"score\"] >= th]\n",
    "    num_selected = len(selected_features)\n",
    "    selected_overall_scores = [\n",
    "        eval_data[f][\"holdout\"][\"mean\"][\"overall\"]\n",
    "        for f in selected_features\n",
    "        if f in eval_data\n",
    "    ]\n",
    "    avg_selected_overall = (\n",
    "        sum(selected_overall_scores) / num_selected\n",
    "        if selected_overall_scores else 0\n",
    "    )\n",
    "    print(f\"\\nNumber of features with score >= {th}: {num_selected}\")\n",
    "    print(f\"Average overall score for score >= {th}: {avg_selected_overall}\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2675dfc0",
   "metadata": {},
   "source": [
    "# 2 Group"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8db6141e",
   "metadata": {},
   "source": [
    "## 2.1 Output Score Group Eval for Gemma 2 2b L12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "c9f25fd1",
   "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.1454\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.12\n",
      "\n",
      "Number of features with score >= 0.01: 6\n",
      "Average overall score for score >= 0.01: 0.21\n",
      "\n",
      "Number of features with score >= 0.001: 10\n",
      "Average overall score for score >= 0.001: 0.126\n",
      "\n",
      "Number of features with score >= 0.0001: 19\n",
      "Average overall score for score >= 0.0001: 0.07894736842105263\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.12240000000000001\n",
      "\n",
      "Number of features with score >= 0.1: 6\n",
      "Average overall score for score >= 0.1: 0.19999999999999998\n",
      "\n",
      "Number of features with score >= 0.01: 11\n",
      "Average overall score for score >= 0.01: 0.23999999999999996\n",
      "\n",
      "Number of features with score >= 0.001: 17\n",
      "Average overall score for score >= 0.001: 0.2152941176470588\n",
      "\n",
      "Number of features with score >= 0.0001: 30\n",
      "Average overall score for score >= 0.0001: 0.146\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1514\n",
      "\n",
      "Number of features with score >= 0.1: 38\n",
      "Average overall score for score >= 0.1: 0.19210526315789472\n",
      "\n",
      "Number of features with score >= 0.01: 66\n",
      "Average overall score for score >= 0.01: 0.19787878787878788\n",
      "\n",
      "Number of features with score >= 0.001: 90\n",
      "Average overall score for score >= 0.001: 0.1628888888888889\n",
      "\n",
      "Number of features with score >= 0.0001: 97\n",
      "Average overall score for score >= 0.0001: 0.15360824742268042\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1174\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.24\n",
      "\n",
      "Number of features with score >= 0.01: 9\n",
      "Average overall score for score >= 0.01: 0.18666666666666665\n",
      "\n",
      "Number of features with score >= 0.001: 17\n",
      "Average overall score for score >= 0.001: 0.15294117647058825\n",
      "\n",
      "Number of features with score >= 0.0001: 32\n",
      "Average overall score for score >= 0.0001: 0.113125\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1562\n",
      "\n",
      "Number of features with score >= 0.1: 34\n",
      "Average overall score for score >= 0.1: 0.14823529411764705\n",
      "\n",
      "Number of features with score >= 0.01: 57\n",
      "Average overall score for score >= 0.01: 0.14982456140350878\n",
      "\n",
      "Number of features with score >= 0.001: 79\n",
      "Average overall score for score >= 0.001: 0.16481012658227848\n",
      "\n",
      "Number of features with score >= 0.0001: 91\n",
      "Average overall score for score >= 0.0001: 0.15846153846153846\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.10619999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 3\n",
      "Average overall score for score >= 0.1: 0.34\n",
      "\n",
      "Number of features with score >= 0.01: 10\n",
      "Average overall score for score >= 0.01: 0.31799999999999995\n",
      "\n",
      "Number of features with score >= 0.001: 18\n",
      "Average overall score for score >= 0.001: 0.23333333333333334\n",
      "\n",
      "Number of features with score >= 0.0001: 22\n",
      "Average overall score for score >= 0.0001: 0.22363636363636363\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_148\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1158\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.18\n",
      "\n",
      "Number of features with score >= 0.01: 7\n",
      "Average overall score for score >= 0.01: 0.10285714285714286\n",
      "\n",
      "Number of features with score >= 0.001: 10\n",
      "Average overall score for score >= 0.001: 0.144\n",
      "\n",
      "Number of features with score >= 0.0001: 20\n",
      "Average overall score for score >= 0.0001: 0.10400000000000001\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_340\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1532\n",
      "\n",
      "Number of features with score >= 0.1: 3\n",
      "Average overall score for score >= 0.1: 0.16\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.096\n",
      "\n",
      "Number of features with score >= 0.001: 9\n",
      "Average overall score for score >= 0.001: 0.19999999999999998\n",
      "\n",
      "Number of features with score >= 0.0001: 15\n",
      "Average overall score for score >= 0.0001: 0.13333333333333333\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_49\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.10640000000000001\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.54\n",
      "\n",
      "Number of features with score >= 0.01: 8\n",
      "Average overall score for score >= 0.01: 0.21250000000000002\n",
      "\n",
      "Number of features with score >= 0.001: 12\n",
      "Average overall score for score >= 0.001: 0.1416666666666667\n",
      "\n",
      "Number of features with score >= 0.0001: 17\n",
      "Average overall score for score >= 0.0001: 0.12823529411764706\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_547\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1338\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.096\n",
      "\n",
      "Number of features with score >= 0.001: 9\n",
      "Average overall score for score >= 0.001: 0.14666666666666664\n",
      "\n",
      "Number of features with score >= 0.0001: 16\n",
      "Average overall score for score >= 0.0001: 0.1725\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_78\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.08879999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 0\n",
      "Average overall score for score >= 0.1: 0\n",
      "\n",
      "Number of features with score >= 0.01: 3\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 9\n",
      "Average overall score for score >= 0.001: 0.05333333333333333\n",
      "\n",
      "Number of features with score >= 0.0001: 16\n",
      "Average overall score for score >= 0.0001: 0.0675\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_948\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.10279999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.12\n",
      "\n",
      "Number of features with score >= 0.01: 2\n",
      "Average overall score for score >= 0.01: 0.12\n",
      "\n",
      "Number of features with score >= 0.001: 5\n",
      "Average overall score for score >= 0.001: 0.048\n",
      "\n",
      "Number of features with score >= 0.0001: 8\n",
      "Average overall score for score >= 0.0001: 0.1575\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_165\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.11960000000000001\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.17\n",
      "\n",
      "Number of features with score >= 0.01: 7\n",
      "Average overall score for score >= 0.01: 0.13142857142857142\n",
      "\n",
      "Number of features with score >= 0.001: 16\n",
      "Average overall score for score >= 0.001: 0.14\n",
      "\n",
      "Number of features with score >= 0.0001: 32\n",
      "Average overall score for score >= 0.0001: 0.164375\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_330\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1054\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 3\n",
      "Average overall score for score >= 0.01: 0.09999999999999999\n",
      "\n",
      "Number of features with score >= 0.001: 10\n",
      "Average overall score for score >= 0.001: 0.194\n",
      "\n",
      "Number of features with score >= 0.0001: 17\n",
      "Average overall score for score >= 0.0001: 0.15647058823529414\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_52\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.17579999999999998\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 11\n",
      "Average overall score for score >= 0.01: 0.19090909090909092\n",
      "\n",
      "Number of features with score >= 0.001: 26\n",
      "Average overall score for score >= 0.001: 0.27076923076923076\n",
      "\n",
      "Number of features with score >= 0.0001: 35\n",
      "Average overall score for score >= 0.0001: 0.23428571428571426\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_538\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.0892\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 8\n",
      "Average overall score for score >= 0.001: 0.0\n",
      "\n",
      "Number of features with score >= 0.0001: 15\n",
      "Average overall score for score >= 0.0001: 0.016\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_779\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.11939999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 40\n",
      "Average overall score for score >= 0.1: 0.13999999999999999\n",
      "\n",
      "Number of features with score >= 0.01: 86\n",
      "Average overall score for score >= 0.01: 0.12069767441860464\n",
      "\n",
      "Number of features with score >= 0.001: 97\n",
      "Average overall score for score >= 0.001: 0.11752577319587629\n",
      "\n",
      "Number of features with score >= 0.0001: 99\n",
      "Average overall score for score >= 0.0001: 0.11757575757575758\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_83\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1788\n",
      "\n",
      "Number of features with score >= 0.1: 6\n",
      "Average overall score for score >= 0.1: 0.24\n",
      "\n",
      "Number of features with score >= 0.01: 12\n",
      "Average overall score for score >= 0.01: 0.355\n",
      "\n",
      "Number of features with score >= 0.001: 17\n",
      "Average overall score for score >= 0.001: 0.35294117647058826\n",
      "\n",
      "Number of features with score >= 0.0001: 33\n",
      "Average overall score for score >= 0.0001: 0.2678787878787879\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_156\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.18099999999999997\n",
      "\n",
      "Number of features with score >= 0.1: 14\n",
      "Average overall score for score >= 0.1: 0.13714285714285715\n",
      "\n",
      "Number of features with score >= 0.01: 27\n",
      "Average overall score for score >= 0.01: 0.14962962962962964\n",
      "\n",
      "Number of features with score >= 0.001: 45\n",
      "Average overall score for score >= 0.001: 0.16933333333333334\n",
      "\n",
      "Number of features with score >= 0.0001: 54\n",
      "Average overall score for score >= 0.0001: 0.16777777777777778\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_309\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.13140000000000002\n",
      "\n",
      "Number of features with score >= 0.1: 7\n",
      "Average overall score for score >= 0.1: 0.3057142857142857\n",
      "\n",
      "Number of features with score >= 0.01: 16\n",
      "Average overall score for score >= 0.01: 0.31625000000000003\n",
      "\n",
      "Number of features with score >= 0.001: 33\n",
      "Average overall score for score >= 0.001: 0.22606060606060607\n",
      "\n",
      "Number of features with score >= 0.0001: 43\n",
      "Average overall score for score >= 0.0001: 0.1916279069767442\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_507\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1404\n",
      "\n",
      "Number of features with score >= 0.1: 8\n",
      "Average overall score for score >= 0.1: 0.0675\n",
      "\n",
      "Number of features with score >= 0.01: 17\n",
      "Average overall score for score >= 0.01: 0.15999999999999998\n",
      "\n",
      "Number of features with score >= 0.001: 28\n",
      "Average overall score for score >= 0.001: 0.18928571428571428\n",
      "\n",
      "Number of features with score >= 0.0001: 34\n",
      "Average overall score for score >= 0.0001: 0.19999999999999998\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_54\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.15039999999999998\n",
      "\n",
      "Number of features with score >= 0.1: 16\n",
      "Average overall score for score >= 0.1: 0.12125\n",
      "\n",
      "Number of features with score >= 0.01: 27\n",
      "Average overall score for score >= 0.01: 0.18962962962962962\n",
      "\n",
      "Number of features with score >= 0.001: 40\n",
      "Average overall score for score >= 0.001: 0.227\n",
      "\n",
      "Number of features with score >= 0.0001: 45\n",
      "Average overall score for score >= 0.0001: 0.2342222222222222\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_733\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.141\n",
      "\n",
      "Number of features with score >= 0.1: 8\n",
      "Average overall score for score >= 0.1: 0.1275\n",
      "\n",
      "Number of features with score >= 0.01: 14\n",
      "Average overall score for score >= 0.01: 0.21857142857142856\n",
      "\n",
      "Number of features with score >= 0.001: 22\n",
      "Average overall score for score >= 0.001: 0.16090909090909092\n",
      "\n",
      "Number of features with score >= 0.0001: 32\n",
      "Average overall score for score >= 0.0001: 0.15562499999999999\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_99\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.10980000000000001\n",
      "\n",
      "Number of features with score >= 0.1: 13\n",
      "Average overall score for score >= 0.1: 0.060000000000000005\n",
      "\n",
      "Number of features with score >= 0.01: 22\n",
      "Average overall score for score >= 0.01: 0.10090909090909089\n",
      "\n",
      "Number of features with score >= 0.001: 29\n",
      "Average overall score for score >= 0.001: 0.07655172413793103\n",
      "\n",
      "Number of features with score >= 0.0001: 39\n",
      "Average overall score for score >= 0.0001: 0.08102564102564103\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1522\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.06\n",
      "\n",
      "Number of features with score >= 0.01: 7\n",
      "Average overall score for score >= 0.01: 0.13714285714285715\n",
      "\n",
      "Number of features with score >= 0.001: 15\n",
      "Average overall score for score >= 0.001: 0.128\n",
      "\n",
      "Number of features with score >= 0.0001: 30\n",
      "Average overall score for score >= 0.0001: 0.154\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1128\n",
      "\n",
      "Number of features with score >= 0.1: 3\n",
      "Average overall score for score >= 0.1: 0.32\n",
      "\n",
      "Number of features with score >= 0.01: 8\n",
      "Average overall score for score >= 0.01: 0.24\n",
      "\n",
      "Number of features with score >= 0.001: 15\n",
      "Average overall score for score >= 0.001: 0.16\n",
      "\n",
      "Number of features with score >= 0.0001: 27\n",
      "Average overall score for score >= 0.0001: 0.12444444444444444\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1966\n",
      "\n",
      "Number of features with score >= 0.1: 31\n",
      "Average overall score for score >= 0.1: 0.23612903225806453\n",
      "\n",
      "Number of features with score >= 0.01: 53\n",
      "Average overall score for score >= 0.01: 0.24150943396226415\n",
      "\n",
      "Number of features with score >= 0.001: 72\n",
      "Average overall score for score >= 0.001: 0.23222222222222222\n",
      "\n",
      "Number of features with score >= 0.0001: 85\n",
      "Average overall score for score >= 0.0001: 0.21435294117647058\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1338\n",
      "\n",
      "Number of features with score >= 0.1: 3\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 8\n",
      "Average overall score for score >= 0.01: 0.18\n",
      "\n",
      "Number of features with score >= 0.001: 15\n",
      "Average overall score for score >= 0.001: 0.3\n",
      "\n",
      "Number of features with score >= 0.0001: 16\n",
      "Average overall score for score >= 0.0001: 0.29625\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.14859999999999998\n",
      "\n",
      "Number of features with score >= 0.1: 32\n",
      "Average overall score for score >= 0.1: 0.165625\n",
      "\n",
      "Number of features with score >= 0.01: 51\n",
      "Average overall score for score >= 0.01: 0.14745098039215684\n",
      "\n",
      "Number of features with score >= 0.001: 68\n",
      "Average overall score for score >= 0.001: 0.14676470588235294\n",
      "\n",
      "Number of features with score >= 0.0001: 79\n",
      "Average overall score for score >= 0.0001: 0.1430379746835443\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 87\n",
      "Average overall score (all features): 0.10574712643678161\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.27\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.312\n",
      "\n",
      "Number of features with score >= 0.001: 11\n",
      "Average overall score for score >= 0.001: 0.16\n",
      "\n",
      "Number of features with score >= 0.0001: 27\n",
      "Average overall score for score >= 0.0001: 0.07407407407407407\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "\n",
    "# Root folders (edit if needed)\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_2b_it/layer12\"\n",
    "OUTPUT_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_outputscore/gemma2_2b/layer12\"\n",
    "\n",
    "# Thresholds (same as before)\n",
    "THRESHOLDS = [0.1, 0.01, 0.001, 0.0001]\n",
    "\n",
    "\n",
    "def safe_load_json(path: str):\n",
    "    \"\"\"Load 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):\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 process_one_sae(sae_name: str):\n",
    "    \"\"\"Process a single SAE by name (subfolder).\"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    output_scores_path = os.path.join(OUTPUT_ROOT, sae_name, \"output_scores_top20.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json means skip this SAE silently\n",
    "        return\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # ---- Base (same as original) ----\n",
    "    num_features = len(eval_data)\n",
    "    overall_scores_all = [\n",
    "        get_overall_from_eval_item(v) for v in eval_data.values()\n",
    "    ]\n",
    "    # Filter out Nones just in case\n",
    "    overall_scores_all = [s for s in overall_scores_all if s is not None]\n",
    "    average_overall_all = (\n",
    "        sum(overall_scores_all) / num_features if num_features > 0 else 0\n",
    "    )\n",
    "\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {average_overall_all}\")\n",
    "\n",
    "    # ---- Thresholds (same as original; only if output scores exist) ----\n",
    "    output_scores_data = safe_load_json(output_scores_path)\n",
    "    if output_scores_data is None:\n",
    "        print(f\"(No output scores found at: {output_scores_path}. Skipping thresholds.)\")\n",
    "        return\n",
    "\n",
    "    for th in THRESHOLDS:\n",
    "        selected_features = [\n",
    "            f for f, info in output_scores_data.items()\n",
    "            if isinstance(info, dict) and info.get(\"score\", 0) >= th\n",
    "        ]\n",
    "        num_selected = len(selected_features)\n",
    "        selected_overall_scores = [\n",
    "            eval_data[f][\"holdout\"][\"mean\"][\"overall\"]\n",
    "            for f in selected_features\n",
    "            if f in eval_data and get_overall_from_eval_item(eval_data[f]) is not None\n",
    "        ]\n",
    "        avg_selected_overall = (\n",
    "            sum(selected_overall_scores) / num_selected\n",
    "            if selected_overall_scores else 0\n",
    "        )\n",
    "        print(f\"\\nNumber of features with score >= {th}: {num_selected}\")\n",
    "        print(f\"Average overall score for score >= {th}: {avg_selected_overall}\")\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",
    "    # Iterate over all subfolders in EVAL_ROOT (each is an SAE name)\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if os.path.isdir(sae_dir):\n",
    "            process_one_sae(sae_name)\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "42a47fc7",
   "metadata": {},
   "source": [
    "## 2.2 Output Score Group Eval for Gemma 2 9b L20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c3a3af8b",
   "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.10400000000000001\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 11\n",
      "Average overall score for score >= 0.001: 0.10545454545454545\n",
      "\n",
      "Number of features with score >= 0.0001: 19\n",
      "Average overall score for score >= 0.0001: 0.10526315789473684\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.183\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.48\n",
      "\n",
      "Number of features with score >= 0.01: 7\n",
      "Average overall score for score >= 0.01: 0.2057142857142857\n",
      "\n",
      "Number of features with score >= 0.001: 16\n",
      "Average overall score for score >= 0.001: 0.22625\n",
      "\n",
      "Number of features with score >= 0.0001: 29\n",
      "Average overall score for score >= 0.0001: 0.28206896551724137\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1718\n",
      "\n",
      "Number of features with score >= 0.1: 22\n",
      "Average overall score for score >= 0.1: 0.16545454545454547\n",
      "\n",
      "Number of features with score >= 0.01: 39\n",
      "Average overall score for score >= 0.01: 0.20615384615384613\n",
      "\n",
      "Number of features with score >= 0.001: 50\n",
      "Average overall score for score >= 0.001: 0.1972\n",
      "\n",
      "Number of features with score >= 0.0001: 60\n",
      "Average overall score for score >= 0.0001: 0.16833333333333333\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.16920000000000002\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.096\n",
      "\n",
      "Number of features with score >= 0.001: 16\n",
      "Average overall score for score >= 0.001: 0.15875\n",
      "\n",
      "Number of features with score >= 0.0001: 23\n",
      "Average overall score for score >= 0.0001: 0.19043478260869565\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.2086\n",
      "\n",
      "Number of features with score >= 0.1: 12\n",
      "Average overall score for score >= 0.1: 0.20166666666666666\n",
      "\n",
      "Number of features with score >= 0.01: 26\n",
      "Average overall score for score >= 0.01: 0.1576923076923077\n",
      "\n",
      "Number of features with score >= 0.001: 49\n",
      "Average overall score for score >= 0.001: 0.19551020408163267\n",
      "\n",
      "Number of features with score >= 0.0001: 64\n",
      "Average overall score for score >= 0.0001: 0.2278125\n",
      "\n",
      "================================================================================\n",
      "SAE: batch_topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.132\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.9200000000000002\n",
      "\n",
      "Number of features with score >= 0.01: 4\n",
      "Average overall score for score >= 0.01: 0.23000000000000004\n",
      "\n",
      "Number of features with score >= 0.001: 10\n",
      "Average overall score for score >= 0.001: 0.194\n",
      "\n",
      "Number of features with score >= 0.0001: 15\n",
      "Average overall score for score >= 0.0001: 0.17733333333333334\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_1070\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1232\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.48\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.144\n",
      "\n",
      "Number of features with score >= 0.001: 9\n",
      "Average overall score for score >= 0.001: 0.18\n",
      "\n",
      "Number of features with score >= 0.0001: 14\n",
      "Average overall score for score >= 0.0001: 0.13285714285714284\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1386\n",
      "\n",
      "Number of features with score >= 0.1: 5\n",
      "Average overall score for score >= 0.1: 0.20400000000000001\n",
      "\n",
      "Number of features with score >= 0.01: 11\n",
      "Average overall score for score >= 0.01: 0.2290909090909091\n",
      "\n",
      "Number of features with score >= 0.001: 19\n",
      "Average overall score for score >= 0.001: 0.2831578947368421\n",
      "\n",
      "Number of features with score >= 0.0001: 30\n",
      "Average overall score for score >= 0.0001: 0.21333333333333335\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_360\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.13140000000000002\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.24\n",
      "\n",
      "Number of features with score >= 0.01: 3\n",
      "Average overall score for score >= 0.01: 0.26\n",
      "\n",
      "Number of features with score >= 0.001: 8\n",
      "Average overall score for score >= 0.001: 0.1575\n",
      "\n",
      "Number of features with score >= 0.0001: 15\n",
      "Average overall score for score >= 0.0001: 0.132\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_53\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.09\n",
      "\n",
      "Number of features with score >= 0.1: 0\n",
      "Average overall score for score >= 0.1: 0\n",
      "\n",
      "Number of features with score >= 0.01: 2\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 4\n",
      "Average overall score for score >= 0.001: 0.075\n",
      "\n",
      "Number of features with score >= 0.0001: 15\n",
      "Average overall score for score >= 0.0001: 0.02\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_573\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.12\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.24\n",
      "\n",
      "Number of features with score >= 0.01: 7\n",
      "Average overall score for score >= 0.01: 0.06857142857142857\n",
      "\n",
      "Number of features with score >= 0.001: 17\n",
      "Average overall score for score >= 0.001: 0.08823529411764706\n",
      "\n",
      "Number of features with score >= 0.0001: 34\n",
      "Average overall score for score >= 0.0001: 0.09\n",
      "\n",
      "================================================================================\n",
      "SAE: gated_85\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.13019999999999998\n",
      "\n",
      "Number of features with score >= 0.1: 1\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 3\n",
      "Average overall score for score >= 0.01: 0.58\n",
      "\n",
      "Number of features with score >= 0.001: 7\n",
      "Average overall score for score >= 0.001: 0.3514285714285714\n",
      "\n",
      "Number of features with score >= 0.0001: 16\n",
      "Average overall score for score >= 0.0001: 0.25125\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_164\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.09759999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 5\n",
      "Average overall score for score >= 0.1: 0.048\n",
      "\n",
      "Number of features with score >= 0.01: 12\n",
      "Average overall score for score >= 0.01: 0.16333333333333333\n",
      "\n",
      "Number of features with score >= 0.001: 17\n",
      "Average overall score for score >= 0.001: 0.1611764705882353\n",
      "\n",
      "Number of features with score >= 0.0001: 26\n",
      "Average overall score for score >= 0.0001: 0.14461538461538462\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_327\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1094\n",
      "\n",
      "Number of features with score >= 0.1: 0\n",
      "Average overall score for score >= 0.1: 0\n",
      "\n",
      "Number of features with score >= 0.01: 2\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 4\n",
      "Average overall score for score >= 0.001: 0.12\n",
      "\n",
      "Number of features with score >= 0.0001: 12\n",
      "Average overall score for score >= 0.0001: 0.15666666666666665\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_51\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.111\n",
      "\n",
      "Number of features with score >= 0.1: 3\n",
      "Average overall score for score >= 0.1: 0.16\n",
      "\n",
      "Number of features with score >= 0.01: 11\n",
      "Average overall score for score >= 0.01: 0.2945454545454545\n",
      "\n",
      "Number of features with score >= 0.001: 28\n",
      "Average overall score for score >= 0.001: 0.20500000000000002\n",
      "\n",
      "Number of features with score >= 0.0001: 43\n",
      "Average overall score for score >= 0.0001: 0.17255813953488372\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_529\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.09359999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 0\n",
      "Average overall score for score >= 0.1: 0\n",
      "\n",
      "Number of features with score >= 0.01: 1\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 5\n",
      "Average overall score for score >= 0.001: 0.048\n",
      "\n",
      "Number of features with score >= 0.0001: 12\n",
      "Average overall score for score >= 0.0001: 0.08\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_786\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1244\n",
      "\n",
      "Number of features with score >= 0.1: 28\n",
      "Average overall score for score >= 0.1: 0.12142857142857143\n",
      "\n",
      "Number of features with score >= 0.01: 50\n",
      "Average overall score for score >= 0.01: 0.1192\n",
      "\n",
      "Number of features with score >= 0.001: 76\n",
      "Average overall score for score >= 0.001: 0.12736842105263158\n",
      "\n",
      "Number of features with score >= 0.0001: 88\n",
      "Average overall score for score >= 0.0001: 0.12159090909090908\n",
      "\n",
      "================================================================================\n",
      "SAE: jump_relu_82\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1432\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 10\n",
      "Average overall score for score >= 0.01: 0.248\n",
      "\n",
      "Number of features with score >= 0.001: 20\n",
      "Average overall score for score >= 0.001: 0.21800000000000003\n",
      "\n",
      "Number of features with score >= 0.0001: 27\n",
      "Average overall score for score >= 0.0001: 0.19925925925925925\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_108\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1804\n",
      "\n",
      "Number of features with score >= 0.1: 14\n",
      "Average overall score for score >= 0.1: 0.23857142857142857\n",
      "\n",
      "Number of features with score >= 0.01: 26\n",
      "Average overall score for score >= 0.01: 0.30615384615384617\n",
      "\n",
      "Number of features with score >= 0.001: 38\n",
      "Average overall score for score >= 0.001: 0.26789473684210524\n",
      "\n",
      "Number of features with score >= 0.0001: 49\n",
      "Average overall score for score >= 0.0001: 0.24897959183673468\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_167\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1524\n",
      "\n",
      "Number of features with score >= 0.1: 5\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 23\n",
      "Average overall score for score >= 0.01: 0.10782608695652174\n",
      "\n",
      "Number of features with score >= 0.001: 35\n",
      "Average overall score for score >= 0.001: 0.14971428571428572\n",
      "\n",
      "Number of features with score >= 0.0001: 48\n",
      "Average overall score for score >= 0.0001: 0.16666666666666666\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_321\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.11939999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 4\n",
      "Average overall score for score >= 0.1: 0.315\n",
      "\n",
      "Number of features with score >= 0.01: 5\n",
      "Average overall score for score >= 0.01: 0.348\n",
      "\n",
      "Number of features with score >= 0.001: 13\n",
      "Average overall score for score >= 0.001: 0.2076923076923077\n",
      "\n",
      "Number of features with score >= 0.0001: 24\n",
      "Average overall score for score >= 0.0001: 0.1625\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_523\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.11900000000000001\n",
      "\n",
      "Number of features with score >= 0.1: 5\n",
      "Average overall score for score >= 0.1: 0.32399999999999995\n",
      "\n",
      "Number of features with score >= 0.01: 13\n",
      "Average overall score for score >= 0.01: 0.25384615384615383\n",
      "\n",
      "Number of features with score >= 0.001: 21\n",
      "Average overall score for score >= 0.001: 0.20571428571428574\n",
      "\n",
      "Number of features with score >= 0.0001: 29\n",
      "Average overall score for score >= 0.0001: 0.18620689655172412\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_61\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1382\n",
      "\n",
      "Number of features with score >= 0.1: 6\n",
      "Average overall score for score >= 0.1: 0.049999999999999996\n",
      "\n",
      "Number of features with score >= 0.01: 14\n",
      "Average overall score for score >= 0.01: 0.18571428571428572\n",
      "\n",
      "Number of features with score >= 0.001: 26\n",
      "Average overall score for score >= 0.001: 0.1376923076923077\n",
      "\n",
      "Number of features with score >= 0.0001: 36\n",
      "Average overall score for score >= 0.0001: 0.15055555555555555\n",
      "\n",
      "================================================================================\n",
      "SAE: standard_april_update_762\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1292\n",
      "\n",
      "Number of features with score >= 0.1: 3\n",
      "Average overall score for score >= 0.1: 0.0\n",
      "\n",
      "Number of features with score >= 0.01: 9\n",
      "Average overall score for score >= 0.01: 0.14\n",
      "\n",
      "Number of features with score >= 0.001: 17\n",
      "Average overall score for score >= 0.001: 0.10588235294117647\n",
      "\n",
      "Number of features with score >= 0.0001: 25\n",
      "Average overall score for score >= 0.0001: 0.17120000000000002\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_160\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.20800000000000002\n",
      "\n",
      "Number of features with score >= 0.1: 16\n",
      "Average overall score for score >= 0.1: 0.17375\n",
      "\n",
      "Number of features with score >= 0.01: 41\n",
      "Average overall score for score >= 0.01: 0.17512195121951218\n",
      "\n",
      "Number of features with score >= 0.001: 61\n",
      "Average overall score for score >= 0.001: 0.1944262295081967\n",
      "\n",
      "Number of features with score >= 0.0001: 70\n",
      "Average overall score for score >= 0.0001: 0.19\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_320\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1754\n",
      "\n",
      "Number of features with score >= 0.1: 8\n",
      "Average overall score for score >= 0.1: 0.1875\n",
      "\n",
      "Number of features with score >= 0.01: 26\n",
      "Average overall score for score >= 0.01: 0.21538461538461537\n",
      "\n",
      "Number of features with score >= 0.001: 47\n",
      "Average overall score for score >= 0.001: 0.22340425531914893\n",
      "\n",
      "Number of features with score >= 0.0001: 65\n",
      "Average overall score for score >= 0.0001: 0.20584615384615382\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_50\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.24259999999999998\n",
      "\n",
      "Number of features with score >= 0.1: 20\n",
      "Average overall score for score >= 0.1: 0.126\n",
      "\n",
      "Number of features with score >= 0.01: 41\n",
      "Average overall score for score >= 0.01: 0.29365853658536584\n",
      "\n",
      "Number of features with score >= 0.001: 60\n",
      "Average overall score for score >= 0.001: 0.29100000000000004\n",
      "\n",
      "Number of features with score >= 0.0001: 80\n",
      "Average overall score for score >= 0.0001: 0.27025\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_520\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.1162\n",
      "\n",
      "Number of features with score >= 0.1: 2\n",
      "Average overall score for score >= 0.1: 0.12\n",
      "\n",
      "Number of features with score >= 0.01: 6\n",
      "Average overall score for score >= 0.01: 0.22\n",
      "\n",
      "Number of features with score >= 0.001: 14\n",
      "Average overall score for score >= 0.001: 0.16285714285714284\n",
      "\n",
      "Number of features with score >= 0.0001: 23\n",
      "Average overall score for score >= 0.0001: 0.09913043478260869\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_80\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.184\n",
      "\n",
      "Number of features with score >= 0.1: 15\n",
      "Average overall score for score >= 0.1: 0.2\n",
      "\n",
      "Number of features with score >= 0.01: 35\n",
      "Average overall score for score >= 0.01: 0.26685714285714285\n",
      "\n",
      "Number of features with score >= 0.001: 46\n",
      "Average overall score for score >= 0.001: 0.27043478260869563\n",
      "\n",
      "Number of features with score >= 0.0001: 56\n",
      "Average overall score for score >= 0.0001: 0.22214285714285714\n",
      "\n",
      "================================================================================\n",
      "SAE: topk_820\n",
      "--------------------------------------------------------------------------------\n",
      "Total number of features: 100\n",
      "Average overall score (all features): 0.11599999999999999\n",
      "\n",
      "Number of features with score >= 0.1: 0\n",
      "Average overall score for score >= 0.1: 0\n",
      "\n",
      "Number of features with score >= 0.01: 4\n",
      "Average overall score for score >= 0.01: 0.0\n",
      "\n",
      "Number of features with score >= 0.001: 11\n",
      "Average overall score for score >= 0.001: 0.22363636363636363\n",
      "\n",
      "Number of features with score >= 0.0001: 17\n",
      "Average overall score for score >= 0.0001: 0.22705882352941176\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "\n",
    "# Root folders (edit if needed)\n",
    "EVAL_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_sae_eval_openai/gemma2_9b_it/layer20\"\n",
    "OUTPUT_ROOT = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/cache/results_outputscore/gemma2_9b/layer20\"\n",
    "\n",
    "# Thresholds (same as before)\n",
    "THRESHOLDS = [0.1, 0.01, 0.001, 0.0001]\n",
    "\n",
    "\n",
    "def safe_load_json(path: str):\n",
    "    \"\"\"Load 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):\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 process_one_sae(sae_name: str):\n",
    "    \"\"\"Process a single SAE by name (subfolder).\"\"\"\n",
    "    eval_path = os.path.join(EVAL_ROOT, sae_name, \"eval.json\")\n",
    "    output_scores_path = os.path.join(OUTPUT_ROOT, sae_name, \"output_scores_top20.json\")\n",
    "\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        # No eval.json means skip this SAE silently\n",
    "        return\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(f\"SAE: {sae_name}\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    # ---- Base (same as original) ----\n",
    "    num_features = len(eval_data)\n",
    "    overall_scores_all = [\n",
    "        get_overall_from_eval_item(v) for v in eval_data.values()\n",
    "    ]\n",
    "    # Filter out Nones just in case\n",
    "    overall_scores_all = [s for s in overall_scores_all if s is not None]\n",
    "    average_overall_all = (\n",
    "        sum(overall_scores_all) / num_features if num_features > 0 else 0\n",
    "    )\n",
    "\n",
    "    print(f\"Total number of features: {num_features}\")\n",
    "    print(f\"Average overall score (all features): {average_overall_all}\")\n",
    "\n",
    "    # ---- Thresholds (same as original; only if output scores exist) ----\n",
    "    output_scores_data = safe_load_json(output_scores_path)\n",
    "    if output_scores_data is None:\n",
    "        print(f\"(No output scores found at: {output_scores_path}. Skipping thresholds.)\")\n",
    "        return\n",
    "\n",
    "    for th in THRESHOLDS:\n",
    "        selected_features = [\n",
    "            f for f, info in output_scores_data.items()\n",
    "            if isinstance(info, dict) and info.get(\"score\", 0) >= th\n",
    "        ]\n",
    "        num_selected = len(selected_features)\n",
    "        selected_overall_scores = [\n",
    "            eval_data[f][\"holdout\"][\"mean\"][\"overall\"]\n",
    "            for f in selected_features\n",
    "            if f in eval_data and get_overall_from_eval_item(eval_data[f]) is not None\n",
    "        ]\n",
    "        avg_selected_overall = (\n",
    "            sum(selected_overall_scores) / num_selected\n",
    "            if selected_overall_scores else 0\n",
    "        )\n",
    "        print(f\"\\nNumber of features with score >= {th}: {num_selected}\")\n",
    "        print(f\"Average overall score for score >= {th}: {avg_selected_overall}\")\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",
    "    # Iterate over all subfolders in EVAL_ROOT (each is an SAE name)\n",
    "    for sae_name in sorted(os.listdir(EVAL_ROOT)):\n",
    "        sae_dir = os.path.join(EVAL_ROOT, sae_name)\n",
    "        if os.path.isdir(sae_dir):\n",
    "            process_one_sae(sae_name)\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "50d5a849",
   "metadata": {},
   "source": [
    "# 3 Prompt Steering Score"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c349d50a",
   "metadata": {},
   "source": [
    "## 3.1 Prompt Steering for Gemma 2 2b L12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d6a3a45f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[info] Found 30 SAE folders under:\n",
      "  /home/dslabra5/sae4steer/saes-are-good-for-steering/src/axbench_steering/cache/results_prompt_eval_openai/google_gemma-2-2b-it/prompt_baseline\n",
      "\n",
      "batch_topk_160_concept_descriptions       concepts=100  overall_mean=0.6616\n",
      "batch_topk_320_concept_descriptions       concepts=100  overall_mean=0.7198\n",
      "batch_topk_50_concept_descriptions        concepts=100  overall_mean=0.6940\n",
      "batch_topk_520_concept_descriptions       concepts=100  overall_mean=0.8114\n",
      "batch_topk_80_concept_descriptions        concepts=100  overall_mean=0.7082\n",
      "batch_topk_820_concept_descriptions       concepts=100  overall_mean=0.7278\n",
      "gated_148_concept_descriptions            concepts=100  overall_mean=0.6680\n",
      "gated_340_concept_descriptions            concepts=100  overall_mean=0.7280\n",
      "gated_49_concept_descriptions             concepts=100  overall_mean=0.8008\n",
      "gated_547_concept_descriptions            concepts=100  overall_mean=0.6990\n",
      "gated_78_concept_descriptions             concepts=100  overall_mean=0.6636\n",
      "gated_948_concept_descriptions            concepts=100  overall_mean=0.8026\n",
      "jumprelu_165_concept_descriptions         concepts=100  overall_mean=0.7366\n",
      "jumprelu_330_concept_descriptions         concepts=100  overall_mean=0.7268\n",
      "jumprelu_52_concept_descriptions          concepts=100  overall_mean=0.6782\n",
      "jumprelu_538_concept_descriptions         concepts=100  overall_mean=0.7466\n",
      "jumprelu_779_concept_descriptions         concepts=100  overall_mean=0.7208\n",
      "jumprelu_83_concept_descriptions          concepts=100  overall_mean=0.6746\n",
      "standard_april_update_156_concept_descriptions  concepts=100  overall_mean=0.7508\n",
      "standard_april_update_309_concept_descriptions  concepts= 98  overall_mean=0.7488\n",
      "standard_april_update_507_concept_descriptions  concepts=100  overall_mean=0.7324\n",
      "standard_april_update_54_concept_descriptions  concepts=100  overall_mean=0.7450\n",
      "standard_april_update_733_concept_descriptions  concepts=100  overall_mean=0.7378\n",
      "standard_april_update_99_concept_descriptions  concepts=100  overall_mean=0.7244\n",
      "topk_160_concept_descriptions             concepts=100  overall_mean=0.7436\n",
      "topk_320_concept_descriptions             concepts=100  overall_mean=0.7332\n",
      "topk_50_concept_descriptions              concepts= 75  overall_mean=0.7619\n",
      "topk_520_concept_descriptions             concepts= 75  overall_mean=0.7053\n",
      "topk_80_concept_descriptions              concepts= 46  overall_mean=0.7239\n",
      "topk_820_concept_descriptions             concepts= 48  overall_mean=0.7512\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>sae_folder</th>\n",
       "      <th>num_concepts</th>\n",
       "      <th>overall_mean</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>batch_topk_160_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.661600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>batch_topk_320_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.719800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>batch_topk_50_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.694000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>batch_topk_520_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.811400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>batch_topk_80_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.708200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>batch_topk_820_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.727800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>gated_148_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.668000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>gated_340_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.728000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>gated_49_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.800800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>gated_547_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.699000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>gated_78_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.663600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>gated_948_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.802600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>jumprelu_165_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.736600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>jumprelu_330_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.726800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>jumprelu_52_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.678200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>jumprelu_538_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.746600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>jumprelu_779_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.720800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>jumprelu_83_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.674600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>standard_april_update_156_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.750800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>standard_april_update_309_concept_descriptions</td>\n",
       "      <td>98</td>\n",
       "      <td>0.748776</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>standard_april_update_507_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.732400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>standard_april_update_54_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.745000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>standard_april_update_733_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.737800</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>standard_april_update_99_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.724400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>topk_160_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.743600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>topk_320_concept_descriptions</td>\n",
       "      <td>100</td>\n",
       "      <td>0.733200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>topk_50_concept_descriptions</td>\n",
       "      <td>75</td>\n",
       "      <td>0.761867</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>topk_520_concept_descriptions</td>\n",
       "      <td>75</td>\n",
       "      <td>0.705333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>topk_80_concept_descriptions</td>\n",
       "      <td>46</td>\n",
       "      <td>0.723913</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>topk_820_concept_descriptions</td>\n",
       "      <td>48</td>\n",
       "      <td>0.751250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>ALL_SAE_MEAN</td>\n",
       "      <td>None</td>\n",
       "      <td>0.727558</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                        sae_folder num_concepts  overall_mean\n",
       "0              batch_topk_160_concept_descriptions          100      0.661600\n",
       "1              batch_topk_320_concept_descriptions          100      0.719800\n",
       "2               batch_topk_50_concept_descriptions          100      0.694000\n",
       "3              batch_topk_520_concept_descriptions          100      0.811400\n",
       "4               batch_topk_80_concept_descriptions          100      0.708200\n",
       "5              batch_topk_820_concept_descriptions          100      0.727800\n",
       "6                   gated_148_concept_descriptions          100      0.668000\n",
       "7                   gated_340_concept_descriptions          100      0.728000\n",
       "8                    gated_49_concept_descriptions          100      0.800800\n",
       "9                   gated_547_concept_descriptions          100      0.699000\n",
       "10                   gated_78_concept_descriptions          100      0.663600\n",
       "11                  gated_948_concept_descriptions          100      0.802600\n",
       "12               jumprelu_165_concept_descriptions          100      0.736600\n",
       "13               jumprelu_330_concept_descriptions          100      0.726800\n",
       "14                jumprelu_52_concept_descriptions          100      0.678200\n",
       "15               jumprelu_538_concept_descriptions          100      0.746600\n",
       "16               jumprelu_779_concept_descriptions          100      0.720800\n",
       "17                jumprelu_83_concept_descriptions          100      0.674600\n",
       "18  standard_april_update_156_concept_descriptions          100      0.750800\n",
       "19  standard_april_update_309_concept_descriptions           98      0.748776\n",
       "20  standard_april_update_507_concept_descriptions          100      0.732400\n",
       "21   standard_april_update_54_concept_descriptions          100      0.745000\n",
       "22  standard_april_update_733_concept_descriptions          100      0.737800\n",
       "23   standard_april_update_99_concept_descriptions          100      0.724400\n",
       "24                   topk_160_concept_descriptions          100      0.743600\n",
       "25                   topk_320_concept_descriptions          100      0.733200\n",
       "26                    topk_50_concept_descriptions           75      0.761867\n",
       "27                   topk_520_concept_descriptions           75      0.705333\n",
       "28                    topk_80_concept_descriptions           46      0.723913\n",
       "29                   topk_820_concept_descriptions           48      0.751250\n",
       "30                                    ALL_SAE_MEAN         None      0.727558"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Compute per-SAE mean of \"overall\" from each eval.json under prompt_baseline.\n",
    "# Paste this cell into your notebook and set BASE_DIR accordingly.\n",
    "\n",
    "import os, json, glob, statistics\n",
    "from pathlib import Path\n",
    "\n",
    "# === 1) Set your base directory here ===\n",
    "BASE_DIR = \"/home/dslabra5/sae4steer/saes-are-good-for-steering/src/axbench_steering/cache/results_prompt_eval_openai/google_gemma-2-2b-it/prompt_baseline\"\n",
    "\n",
    "# --- helpers ---\n",
    "def safe_float(x):\n",
    "    try:\n",
    "        return float(x)\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "def eval_json_overall_mean(eval_path: Path):\n",
    "    with eval_path.open(\"r\", encoding=\"utf-8\") as f:\n",
    "        data = json.load(f)\n",
    "    overalls = []\n",
    "    for _, entry in data.items():\n",
    "        mean = (entry.get(\"holdout\") or {}).get(\"mean\") or {}\n",
    "        ov = safe_float(mean.get(\"overall\"))\n",
    "        if ov is not None:\n",
    "            overalls.append(ov)\n",
    "    n = len(overalls)\n",
    "    avg = statistics.mean(overalls) if n > 0 else float(\"nan\")\n",
    "    return n, avg\n",
    "\n",
    "# --- 2) Scan all SAE folders and compute means ---\n",
    "base = Path(BASE_DIR)\n",
    "if not base.exists():\n",
    "    raise FileNotFoundError(f\"BASE_DIR not found: {base}\")\n",
    "\n",
    "sae_dirs = sorted([p for p in base.iterdir() if p.is_dir()])\n",
    "if not sae_dirs:\n",
    "    raise RuntimeError(f\"No SAE subdirectories found under: {base}\")\n",
    "\n",
    "results = []\n",
    "print(f\"[info] Found {len(sae_dirs)} SAE folders under:\\n  {base}\\n\")\n",
    "\n",
    "for sae_dir in sae_dirs:\n",
    "    eval_path = sae_dir / \"eval.json\"\n",
    "    if not eval_path.exists():\n",
    "        print(f\"[skip] {sae_dir.name}: eval.json not found\")\n",
    "        continue\n",
    "    n, avg = eval_json_overall_mean(eval_path)\n",
    "    results.append((sae_dir.name, n, avg))\n",
    "    print(f\"{sae_dir.name:40s}  concepts={n:3d}  overall_mean={avg:.4f}\")\n",
    "\n",
    "# --- 3) (Optional) Show as a table if pandas is installed ---\n",
    "try:\n",
    "    import pandas as pd\n",
    "    df = (\n",
    "        pd.DataFrame(results, columns=[\"sae_folder\", \"num_concepts\", \"overall_mean\"])\n",
    "        .sort_values(\"sae_folder\")\n",
    "        .reset_index(drop=True)\n",
    "    )\n",
    "\n",
    "    all_mean = df[\"overall_mean\"].mean(skipna=True)\n",
    "    df = pd.concat(\n",
    "        [df, pd.DataFrame([{\"sae_folder\": \"ALL_SAE_MEAN\", \"num_concepts\": None, \"overall_mean\": all_mean}])],\n",
    "        ignore_index=True\n",
    "    )\n",
    "    display(df)\n",
    "except Exception:\n",
    "    pass\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a77928b2",
   "metadata": {},
   "source": [
    "# 4 Analysis for Output Score Feature Selection"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "80a4889e",
   "metadata": {},
   "source": [
    "## 4.1 Gemma 2 2b L12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "40c95788",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1450359/535465716.py:242: FutureWarning: Calling float on a single element Series is deprecated and will raise a TypeError in the future. Use float(ser.iloc[0]) instead\n",
      "  mean_val = float(arch_means.loc[arch_means[\"arch\"] == arch, \"pct_best\"])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Per-threshold counts (Improved / Declined / Tied):\n",
      "threshold  improved  declined  tied\n",
      "      0.1        16        14     0\n",
      "     0.01        19        11     0\n",
      "    0.001        21         9     0\n",
      "   0.0001        19        11     0\n",
      "\n",
      "Top 10 percent improvements:\n",
      "          SAEs  Steering  Steer_max_sel Best_threshold   pct_best\n",
      "      gated_49     0.106          0.540            0.1 409.433962\n",
      "batch_topk_820     0.106          0.340            0.1 220.754717\n",
      "      topk_820     0.105          0.312           0.01 197.142857\n",
      "      topk_320     0.113          0.320            0.1 183.185841\n",
      "      relu_309     0.131          0.316           0.01 141.221374\n",
      "      topk_520     0.134          0.300          0.001 123.880597\n",
      "batch_topk_520     0.117          0.240            0.1 105.128205\n",
      "   jumprelu_83     0.179          0.355           0.01  98.324022\n",
      "batch_topk_320     0.122          0.240           0.01  96.721311\n",
      "  jumprelu_330     0.105          0.194          0.001  84.761905\n",
      "\n",
      "Worst 10 percent improvements:\n",
      "         SAEs  Steering  Steer_max_sel Best_threshold   pct_best\n",
      " jumprelu_538     0.089          0.016         0.0001 -82.022472\n",
      "     gated_78     0.089          0.068         0.0001 -23.595506\n",
      "      relu_99     0.110          0.101           0.01  -8.181818\n",
      "     relu_156     0.181          0.169          0.001  -6.629834\n",
      "     topk_160     0.152          0.154         0.0001   1.315789\n",
      "batch_topk_80     0.156          0.165          0.001   5.769231\n",
      "      topk_80     0.149          0.166            0.1  11.409396\n",
      " jumprelu_779     0.119          0.140            0.1  17.647059\n",
      "      topk_50     0.197          0.242           0.01  22.842640\n",
      "    gated_547     0.134          0.173         0.0001  29.104478\n"
     ]
    },
    {
     "data": {
      "image/png": "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d/a6dG+tKTVxffr7778V3tFnzpyp9bxLBG1fqYiIqFJeXl4KDcxOnDixRrqhJ9IHYWFh6Nq1q8Lw48ePIzQ0tPYzRPSCuHDhgsKL9MyZM/Hzzz/rKEdERER1U/PmzXH9+nXZ/05OToiJidF6gStWfSUiIiIiek61adNGoRrP2rVrkZSUpJsMERER1UH79u2TC9IBwNy5c7UepAMYqCMiIiIieq4tXrxYrh3InJwc/PjjjzrMERERUd2ycOFCuf99fHzw5ptv1siyGKgjIiIiInqO+fn54f3335cbtmLFCqSmpuooR0RERHXH4cOHce7cOblhP//8c4216cdAHRERERHRc27JkiUQBEH2y8zMrDO9ThIREelSz5495e6hgiCgX79+NbY8BuqIiIiIiIiIiIj0AHt9JSIiIiIiIiIi0gMsUUdERERERERERKQHGKgjIiIiIiIiIiLSAwzUERERERERERER6QEG6oiIiIiIiIiIiPQAA3VERERERERERER6gIE6PfLSSy/hpZde0nU2iIiIiIiIiIhIB4x0nQH6P0+fPtV4mtTUVACAg4ODtrNDzwkeI6QOHidUGR4jpEpOTg5Onz4NADA3N0fLli1haWmp41yRPuK1hCrDY4Qqw2OE1FGXjxMG6oiIiIioWkxNTdGoUSMAgK2tLUxNTXWcIyIiIqK6iYE6IiIiIqoWIyMj2RfruvjlmoiIiEhfsI06IiIiIiIiIiIiPcBAHRERERERERERkR5goI6IiIiIiIiIiEgPsI06IiIiIqqWnJwcXLp0CQB7fSUiIiKqDgbqiIiIiKhacnNzcfnyZdn/fn5+DNQRERERVQGrvhIREREREREREekBBuqIiIiIiIiIiIj0AAN1REREREREREREeoCBOiIiIiIiIiIiIj3AQB0REREREREREZEeYKCOiIiIiIiIiIhIDzBQR0REREREREREpAcYqCMiIiIiIiIiItIDDNQRERERERERERHpASNdZ4CIiIiIiIhebAUFBbh79y5iYmKQnJyMgoIC5OXlobS0FBYWFqhfvz4CAgIQEBAAiURS6fweP36MS5cuIT4+Hrm5uTA3N4erqytatGgBb2/vGl2XjIwMrFq1CgAwevRoeHh46GQe+mrz5s149OgRmjVrhn79+lVpHv/73/+QkJBQrXnU1W188uRJnD59Wvb/m2++CVtb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FStWYPv27bh//z5yc3Ph5OSEdu3aYdq0abI22iqjr/tfW/r164fo6Gj89ttv2L9/P27evIm0tDSYmJjA1dUVzZo1Q/fu3TF8+HCt7JuKnJyccObMGXz99dcICwvDkydPVFaxlbYT+NJLL9WpD0lERERERC86iSAIgq4zUVNCQ0MRHh6uVtr169dj0qRJcsOKi4sxcuRIWfWviszMzLBu3TqNqx0q4+7uDkA+oFgZaa9+lXU5XFJSgqSkpKpnrg5wcnKqE6Wlapu6x8jzbMqUKVi/fj3Gjx+PP//8U9fZUUp6zRIrIVXTeJw8PwRBgLe3N2JiYrBmzRql7QtqiscIqRIZGSlX+vu0zXXkGOXpMEe1pyAjH5e/Pwl3WzeEh4fDxcVF11nSa7yWUGV4jFBleIyQOurycfJcl6irLiMjI/z777/YsmUL1q5di2vXriEzMxOurq7o0aMHPvjgAwQEBOg6m2oxNDTkgyO9sD755BNs3LgR27dvx5IlS+Dq6qrrLBHVmD179iAmJgaenp6YMGGCrrNDREREREQaeK4DdWFhYVqZz6hRozBq1CitzIuIap+fnx9ef/11rFy5EosWLcIvv/yi6ywR1ZgFCxYAKOugRtrrMRERERER1Q3s9ZWIXgjz58+HjY0N1qxZg8ePH+s6O0Q1YteuXbhy5QpatWqFMWPG6Do7RERERESkoee6RB0RkZSTkxMyMjJ0nQ2iGjV48GA8x03PEhERERE99xioIyIiIqJqMTMzQ3R0NHIKc2EaYIVCg+r1JE5ERET0omKgjohIT2irXU0iotpmbm6O6OhoJOUkwzrQFaYGZrrOEhEREVGdxDbqiIiIiIiIiIiI9AADdURERERERERERHqAgToiIiIiIiIiIiI9wDbqiIiIiKhaSkpKYGlpiQKDQlgKFigRBJRK2AMxERERkaYYqCMiIiKiasnMzES7du3K/ikFTpdcR45Rnm4zRURERFQHseorERERERERERGRHmCgjoiIiIiIiIiISA8wUEdERERERERERKQHGKgjIiIiIiIiIiLSAwzUERERERERERER6QEG6oiIiIiIiIiIiPQAA3VERERERERERER6gIE6IiIiIiIiIiIiPcBAHRERERERERERkR5goI6IiIiIiIiIiEgPMFBHRERERERERESkB4x0nQEiIiIiqttsbGxw5swZpOalwbKHE0oMBV1niYiIiKhOYok6IiIiIqoWQ0ND5OTkIDMrE9mSXJRKGKgjIiIiqgoG6oiIiIiIiIiIiPQAA3VERERERERERER6gIE6IiIiIiIiIiIiPcDOJIiIiIioWvLy8uDt7Y36hS4wLbXCk9IUFBkU6zpbRERERHUOA3VEREREVC35+fnw9vYu+0cAkkszGagjIiIiqgJWfSUiIiIiIiIiItIDDNQRERERERERERHpAQbqiIiIiIiIiIiI9AADdURERERERERERHqAgToiIiIiIiIiIiI9wEAdERERERERERGRHmCgjoiIiIiIiIiISA8wUEdERERERERERKQHGKgjIiIiIiIiIiLSAwzUERERERERERER6QEjXWeAiIiIiOo2Q0NDZGdno6S0BAY2RiiVlOo6S0RERER1EgN1RERERFQtNjY2OHv2LJJykmE91BWmhma6zhIRERFRncSqr0RERERERERERHqAgToiIiIiIiIiIiI9wEAdERERERERERGRHmCgjoiIiIiIiIiISA+wMwkiIiIiqpbMzEy0bdu2rNfXEiNcK7mPPMMCXWeLiIiIqM5hoI6IiIiIqqWkpARWVlay/w0EVtogIiIiqgo+RREREREREREREekBBuqIiIiIiIiIiIj0AAN1REREREREREREeoCBOiIiIiIiIiIiIj3AQB0REREREREREZEeYKCOiIiIiIiIiIhIDzBQR0REREREREREpAcYqCMiIiIiIiIiItIDDNQRERERERERERHpAQbqiIiIiIiIiIiI9ICRrjNARERERHWbmZkZoqOjkVOYC9MAKxQaFOk6S0RERER1EgN1RERERFQt5ubmiI6ORlJOMqwDXWFqYKbrLBERERHVSaz6SkREREREREREpAcYqCMiIiIiIiIiItIDDNQRERERERERERHpAbZRR0RERETVUlJSAktLSxQYFMJSsECJIKBUIug6W0RERER1DgN1RERERFQtmZmZaNeuXdk/pcDpkuvIMcrTbaaIiIiI6iBWfSUiIiIiIiIiItIDDNQRERERERERERHpAQbqiIiIiIiIiIiI9AADdURERERERERERHqAgToiIiIiIiIiIiI9wEAdERERERERERGRHmCgjoiIiIiIiIiISA8wUEdERERERERERKQHGKgjIiIiIiIiIiLSAwzUERERERERERER6QEG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OytERERERERERER1htZL1AHAsmXLMGTIEOzfvx/FxcVo0aIFxo0bByMj+cXdu3cPjo6O6Ny5M3r27FkTWSEiIiIiIiIiIqoTaiRQBwDdunVDt27dVKbx9fVFWFhYTWWBiIiIiIiIiIiozmADIkRERERERERERHqAgToiIiIiIiIiIiI9UK2qrydOnNBWPgAAnTt31ur8iIiIiIiIiIiI6opqBepCQ0MhkUi0khGJRILi4mKtzIuIiIiIiIiIiKiuqXZnEoIgaCMfREREREREREREL7RqBeoePnyorXwQERERERERERG90KoVqPP09NRWPoiIiIiIiIiIiF5o1a76SkREREQvNjMzM0RHRyOnMBemAVYoNCjSdZaIiIiI6iQG6oiIiIioWszNzREdHY2knGRYB7rC1MBM11kiIiIiqpMManLmO3fuxPDhw+Hp6QkLCwsYGcnHBePi4vDjjz9i+fLlNZkNIiIiIiIiIiIivVcjJepSU1Px6quv4vjx43K9wkokErl09evXx+LFi5GSkoI2bdogJCSkJrJDRERERERERESk97Reoq6kpAT9+vXDsWPHYGJigkmTJuHHH38UTWtqaooRI0ZAEATs3r1b21khIiIiIiIiIiKqM7QeqFu3bh3OnTsHOzs7nD17FuvWrcO0adOUpu/VqxcAICIiQttZISIiIqJaUFJSAktLS9hY28BKsICBIKl8IiIiIiJSoPWqr5s3b4ZEIsGXX36J5s2bV5q+WbNmAIB79+5pOytEREREVAsyMzPRrl27sn9KgdMl15FjlKfbTBERERHVQVovUXfjxg0AQP/+/dVK7+joCABIS0vTdlaIiIiIiIiIiIjqDK0H6rKysgAA9vb2aqUvKioCAIUeYYmIiIiIiIiIiF4kWg/USUvIJSQkqJX+7t27AMp6gCUiIiIiIiIiInpRaT1Q16pVKwDAwYMH1Uq/ZcsWAPi/dk2IiIiIiIiIiIheQFoP1L366qsQBAHffPMN4uPjVaYNCwvDmjVrIJFIMHbsWG1nhYiIiIiIiIiIqM7QeqBu3LhxaNmyJZKSktC2bVusX78ez549k43Pzc3F9evXMWfOHPTt2xclJSXo0qUL+vTpo+2sEBERERERERER1Rla78HBwMAAe/bsQdeuXREVFYXXXnsNACCRSAAA1tbWsrSCICAgIABbt27VdjaIiIiI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tm3bppkzZ0qSunbt6vpPZH6MERSHY031xrZDccoyPk7f93ujD/jW7NmztWHDBknSHXfcIZvNVmC6N/YjjJPAMWbMGNdnlvj4ePXs2VOffvqp4uLi9PTTT2vatGkF2jM+qpcdO3boqaeeUnBwsN55550iP78Wpaoebwjq/NTzzz+vzZs3q0uXLho7dmyp5s3MzHR97e76aqf897zLv1PzRh/wrcsvv1x33nlnkZcZSP+3jRkj1U9mZqaGDRumnJwchYSE6M0333TbTmKMoGgca6o3th2KU5bxcfrY8EYf8J1NmzZpwoQJkk5dcvbII48UauOr4wjjxH8EBQVp9OjRuuGGG2RZVoFpjI/q5Y477tDJkyc1ceJEdezY0eP5qurxJrhCe68GcnJylJiYWK4+6tSpozp16ri+37Jli5577jnZbLZSpclFOX2HV9rp3uqjOquIMZLftddeq4EDB0o6dSPM7du364MPPtCsWbP0+eefa9KkSZo2bZrbccQY8b2KHiP5ORwO3XTTTfrzzz8lnfqngLub8zoxRnyvMsdIWTBGqje2HYrD/qH6SU5O1pAhQ5SRkaEaNWpo/vz5io2NLXYexknV98Ybb+jll1+WJB0/flzr1q3T9OnT9dprr2nmzJl6//33NXz48CLnZXxUbe+//74SEhLUpEkTPfnkk2XupyqNE4K6ctq+fbvat29frj6mTJmiqVOnSpKMMbr99tuVk5Oje++9t9ANNT0RGRnp+tp5U0R38k+Pioryah84xdtj5HTBwcGu9z0qKkrx8fG66KKLdMkll2j48OF69dVX1ahRI02aNKnAfJGRkTp27BhjxA9U9BjJ784779SiRYskSePHj9d9993nti1jxH9U5hjxFMea6o1th+KUZXycPja80QcqX1pami6//HL9/fffCgoK0ocffqgLL7ywyLa+Oo4wTnwjNDTU9eCpqKgoNWrUSIMGDdLYsWM1c+ZM3XzzzTrrrLNc/0BmfFQPhw8f1gMPPCBJevPNNwtsM09U1eMNl776mX//+9/66aef1LhxYz311FNl6iM6Otr1mOv8T1oqyuHDh11f165d2/V1/rMuPO0jNDSUHZsfueGGG9SzZ09JKvLR1s5tXNYx4o1xhsp13333adasWZKkUaNGlfiQGsYIisOxpnpj26E4ZRkfp+/7vdEHKteJEyc0YMAArVu3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kxUbG6uXX37Z41omTJjgWlZJl9UCACoWQR0AwO/dcsstat68uSQpISFBdrvdxxUBAFB2W7Zs0Q8//CBJuummmwpNT0tL0+7duyVJAwYMKDBt0KBBkqQNGzYUmu/BBx/U0aNH9cwzz6hevXoe1zN06FCFh4dr7969+vLLLz2eDwDgfQR1AAC/Z1mW2rZtK0k6ceKEjhw5UmC63W7XBx98oAEDBqhBgwaqUaOGateurd69e+vdd991e8+d0+/jdOzYMT3++ONq3769YmJiZFmWli9fXmCe9PR0TZs2Tb1791bdunUVGhqqRo0a6cILL9STTz6pbdu2uV2P33//XXfccYdatmypqKgoRUZGqm3btpo0aZL279/vdr5mzZoVuI/QkiVLdNlllyk+Pl5hYWFq1aqVJk+erLS0tELzOu/X5TR69OhCD+4o7dlCxc13+v3BEhISNHjwYNWvX18RERE655xz9NJLLyk7O9s1z/Hjx/Xss8+qffv2ioqKUs2aNXXllVfq559/dlvD6ctZunSpLr/8ctWrV0/h4eFq2bKl6wOrO6e/rx999JEuu+wy1a9fXzabrdAZO5mZmXrppZfUvXt31apVy7Xthw0bpq+//rrIZUyePFmWZSkyMlIZGRlua5Gk//3vf6731t0H5eXLl+vmm29W8+bNFR4erpiYGHXq1ElPPPFEseuaf5sZY/T+++/roosuUs2aNRUbG6sLL7xQn376aYF5/v77b40dO1ZnnnmmwsLC1KBBA/3jH//QgQMHil0PSTp06JAmT56s8847TzVr1lRoaKiaNGmim266Sb/88ovb+UaNGiXLstS7d29J0h9//KGbbrpJjRs3dr3fo0aN0t9//11o3qlTp8qyLK1YsUKSNHfu3EJjvbRnYRV3vzvn8po1ayZJ2rVrl8aOHatmzZopNDRU9erV07XXXqv169eXapmnc467Cy+8ULVq1VJISIji4+PVtm1bDRs2TO+9954yMzNd7S3L0iWXXOL6vnnz5oXeh6LuW3f8+HE9//zzuvDCC1WnTh2FhoaqYcOGGjp0qL755huPal28eLGuvfZanXHGGQoLC1PNmjXVrVs3TZs2rcgHJUin3jdnXcuXL9fJkyf10ksvqUuXLqpZs2ahfU1p9j8rV67UVVddpfr16ys0NFTNmzfX+PHjdfjw4RLX5d///rd69uypuLg4RUdHq2PHjnrhhRd08uRJr9wD0HmmeNeuXXX22WcXmp5/f163bt0C05wB3On7/J9++klz585V586dNXbs2FLVEx0drcGDB0uS3n333VLNCwDwMgMAgA/Nnj3bSDKSTEJCgtt2gwYNcrU7fPiw6+d79+41nTt3dk0r6tW1a1eTnJxcqM+EhARXm++//940adKk0Lz5a0pISDDx8fHFLqtXr16FluNwOMyDDz5oLMtyO19UVJRZtmxZkevetGlTI8lMmTLF3HPPPW776Nixo0lPTy8wb69evYqtV5KZPXt2sdvodMXN51zeyJEjzQsvvOB2na+88kqTm5trdu3aZVq3bl1kmxo1apjvvvuuyBryL+eJJ55wu26NGjUy27ZtK/Z9feKJJ8zNN99caN6RI0e62m7atKnI8ZH/dfPNN5ucnJwCy9iyZYtr+ty5c4t9X0eNGmUkmfr165u8vLwC006ePFlkjflf9erVM2vXri2yb2eb9957r8Dv0umv5557zhhjzDfffGNiYmKKbHPGGWeY/fv3u12Pjz/+2ERGRhZb61NPPVXkvCNHjnT9Hn300UcmNDS0yPlr1qxp/vjjjwLzTpkypcSxnn+beiL/ODudc3lNmzY1y5cvN7GxsUUuMzQ01Hz77belWq7TgQMHzNlnn13ieuXf7iW1lWR27txZYDkrVqwwderUKXaeO+64o9C4dDp27Ji57LLLip3/7LPPNn///XeheXfu3Olqs2DBAtOhQ4di91Ge7n9effVVExQUVGQtTZo0Mfv27StyXfLy8sx1113ndj3OPfdcs2jRIrfvpacaNmxoJJmpU6cWOf3YsWOuZZz++/bhhx8aSaZz586un+Xm5pr27dsby7LMmjVrylST83gcEhJiMjIyytQHAKD8COoAAD7laVB35plnGkkmLCzM9WHx+PHjrg+xderUMa+88orZtGmTOXLkiPn777/NG2+84frwfMkllxi73V6gz/xBXePGjU3NmjXN66+/bv7++2+TnJxsVqxYYXbv3m2MMWbt2rWu0CA2NtY888wz5s8//zSpqalm7969ZtmyZWbs2LFm0KBBhWp/6KGHjCRjWZa55ZZbzIoVK0xSUpJJSkoyy5YtM127djWSTEREhNm4cWOh+Z2BUosWLYwkc/vtt5u1a9ea1NRUs2XLFjNmzBjXejzyyCMF5j1x4oRJT093TZ85c6ZJT08v8MrNzS3VNvPkg3KzZs2MZVnm2muvNatXr3bVeuutt7rmf+edd0yXLl1MvXr1zDvvvGN2795tkpOTzYIFC0z9+vVdIUhR9eVfjiTTt29fs2LFCpOSkmK2bt1qJk+ebIKDg10BwYkTJ9y+r40bN3Z9uP/5559dfSxfvtwYY0xqaqpp1KiRK3R58sknzbZt20xKSor54YcfTP/+/V3rNG7cuELLOf/8840k069fP7fv6YkTJ1zB2L333lto+vXXX28kmeDgYDNx4kRXnQcOHDAff/yxK+ysV6+eOXjwoNtt1qJFCxMcHGwmT55sNm3aZFJTU82qVatMt27djCRjs9nMt99+a2JjY03nzp3N559/bg4fPmz27t1rXn75Zdd7OmLEiCLXY+nSpa5wtkePHmbhwoVm7969JjU11fzyyy/mpptuctXyr3/9q9D8zqCuUaNGJjQ01Fx88cXmm2++MUlJSWbv3r3m9ddfd/0edu/evcC82dnZJj093fTo0cNV4+lj/eTJk263QVE8Ceri4uJMrVq1TIcOHczChQvNwYMHzaFDh8zcuXNNXFyckU6Fm6X9PTPGuN4vm81mHn/8cfP777+79h3r1683M2bMML179za//vqra5709HSzbNky1/u8adOmQu+Dw+FwtV+/fr0JCwszkkz79u3Nhx9+aHbu3GmOHDliNmzYYO655x7XNn3iiScK1Zibm2suuugiI8lERkaaKVOmmPXr15vU1FSzZ88e869//csVSrVp08ZkZmYWmD9/UNe4cWMTFhZmnnzySbNlyxaTkpJifvnlF7Np0yZXe0/2P82bNzeWZZmrrrrK/PjjjyYlJcUkJiaaxx9/3LUuw4cPL/I9nzx5smsZl112mfnhhx9MSkqK2b59u3nyySdNaGio63hU1qDur7/+cs3v7h80xhjXPwdOX9cRI0YUGpevvPKK6/hQVvn/sVDWcBkAUH4EdQAAn/IkqPvPf/5T4IOT08SJE40k06BBA7Nr164i512/fr3rg/2nn35aYFr+oK5GjRpm/fr1RfbhcDjMOeecYySZWrVqmS1btrhdn9M/jP/222+uD4bvvvtukfPk5OS4woWBAwcWmu4MlCSZZ555psg+nGdJ1a9fv8jpxX24LS1PPigX94HR+aE+ODjYREdHm+3btxdq8/XXX7v6+frrr4tdTr9+/YoMQWbNmuVq89JLLxWanv99ffDBB92ub/6zGBctWlRout1uN1dddZWrzZ9//llg+htvvGEkmaCgIHPgwIEil5F/jK9bt67AtM8++8w1/5dfflnk/MeOHXOF1kWFhfnPCJo3b16h6ampqSY6Otq1XTp37lxkuPnII4+4fl/S0tIKTMvKyjL16tVzhWT5w6D8HnzwQSPJ1K1b12RlZRWY5gzqJJnLL7+8yO3qDCQkFfm7WFy4VlqeBHWSTKdOnYo8A2nBggWuNu62XXFq1arlNrwtTv59W0lBUqdOnVz/zHAXZM6YMcO13U8fw6+99porpHO3D92zZ4/rjL2XX365wLT8QZ0ks3Tp0mLrLe/+Z/z48a51OX78eIFpBw4cMCEhIUaS6d+/f5FnEH700UcF6i1LUPf++++75k9JSXHb7uGHH3bt15cvX26OHTtmZs6caWw2m5FkvvnmG2OMMfv37zfR0dGmTp06JjU1tdT1ODkcDle4/Nhjj5W5HwBA+RDUAQB8yl1Q53A4zIEDB8z06dNdl9FZlmW+//57Y4wxGRkZrp+/9957xS7DeUnh1VdfXeDn+T/Mjhkzxu38+UMjd2GbO87g4aKLLiq23fLly11hzNGjRwtMcwZKZ5xxhttLzxYuXOiqcc+ePYWmV3ZQFxERUWg9nN58801XH5MnTy6yjcPhMLVr1zZS0ZdJ5v9Anv9sm9M5L4tu3bp1oWnO97VmzZqFAiOnvLw81wfXAQMGuF3Ovn37XGebTZgwocC0w4cPu6adHlI4DRgwwEgy7dq1c7uu7s5ic5ozZ44rTD49JHO+V6efhZbfNddcU+LZNH/88YerzQ8//FBgmvN3OSIiwhw7dsztcjIzM12/u4sXLy4wLX9Q5+6S5dTUVFebDz74oNB0XwR1RYXJxpwKcZ3jx93lvsVxnmU5bdq0Us3naVDnbGdZVpGBuZPD4XCd0fvGG28UmOY8q9Xd77LT1KlTjXTq0tH88gd1l19+eYnrVt79z7p169yO4Zdeesmj/Ur37t3LFdTdd999Rjp1dnZxjh8/blq1alUgGHS+brrpJlc75xm3s2bNcv1s37595rnnnjMjR44048aNK/S75s65555rJJmrrrqq1OsFAPAOHiYBAPAbl1xyiesG3UFBQWrYsKEmTJigzMxM2Ww2vfbaa+rTp48kafXq1a4bqPfu3VsZGRluXx06dJAkrV271u2yT3+qXn7fffedJCkkJEQjRowo1To55+3Xr1+xNTofluFwOPTbb78V2Ve/fv1ks9mKnNaqVSvX14cOHSpVjRWhW7duiouLK3LamWee6fq6f//+RbaxLMvV7uDBg26X06pVK9d7V5RrrrlGkrR161alpqYW2aZPnz4KCwsrctqff/6pY8eOSZKuu+46t8tp1KiRLrroIkmnbmCfX926dV3r+e9//7vQvMnJya6HUdx8880Fpp04cUKrVq2SJPXt27fYMXTOOedIko4cOaLExMQi67ziiivcroPz/Q4NDVWvXr2KbHPWWWe5vj59uzjHevfu3WWz2dzW6XA41Lp1a0nufydbtGihli1bFjmtVq1aio+Pl+QfYz00NLTAwxvyCwoKcj0ooCy1durUSZI0bdo0LV261OtPvHZuszPPPFMNGjRwu80yMzPVsWNHSQW32Y4dO1wPU+jTp0+x47N9+/aSTj2pNCcnp8h6itsPl0Zx+5/i9pU//fSTJOnss88udr8yZMiQctWXnJws6dRYLk5MTIxWrlypO++8U/Xr11dISIhatmypF1980fUwje+++07//e9/1b17d916662un7Vu3VqPPvqo5s6dq3/+858aMmSIrr76auXm5ha7zNq1axeoEQBQ+YJ9XQAAAO7YbDY1a9ZMvXv31vjx410fFKVTwYtTUU/MK0pxHzxatGjhdprzCZNnn322IiIiPFqWJGVkZLie5jp16lTX00XLWmfDhg3dzpO/LndPV6xMxdUaHh5eqnZZWVlu27Rp06bYOvJ/2N69e7frQ2h+xW373bt3F9lXUc455xytWLGiyKdA3nzzzVq6dKk2bNigTZs2uUI16dTTZvPy8hQUFFQoCE5MTHR9sL711ltdH8RLkpycXCAQdfLk/Y6Pj1dISEixbaTC28X5O/n9998rOjra4zqLUlyd0v+Nd38Y68W9X1L5an3hhRfUu3dvJSUlaeDAgapdu7Yuvvhi9ejRQ3379i2wTywL5zbbsWNHmbZZ/v1w3759PZrf4XDoyJEjql+/fqFpxf0ulkZZ95XO3938YV5RnEFzWXka1EmnxtfMmTM1c+bMQtNycnI0btw42Ww2zZgxQ5Zl6ciRI7r++uuVkZGhp59+WnfddZd27typG264QYsWLdKLL76oxx57zO3yCOoAwPc4ow4A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Vq3SLbfcoq+//lqSNHz48ALznnXWWa4zQadNm6bExETl5OS43gcny7I0d+5cRUREaOfOnerUqZOef/55bdiwQUeOHFFKSoo2btyoDz74QNddd52aNm1a6BLXCRMmqFevXjLG6KabbtJNN92kb7/9VgcPHtSxY8e0a9cuffnll3rggQfUvHlzvf766xX6vpVHo0aNdP/990uSvvzyS1155ZX66aefdOTIEe3YsUPPPPOMbr755iKfqFwazZs31xlnnCGp9EHds88+q127dmnSpElFPvX6hhtukCStXr1aDz/8sPbs2aMffvhBd911lyRpyJAhbu8B+/PPP0s6dUZm9+7dS1UXAMCLDAAAPjR79mwjyUgyCQkJpZ7/0KFDplevXq4+inu98cYbBeZNSEhwTdu5c2eJy/rf//5nateuXewyevXqVWg+h8NhnnnmGWOz2Uqs8dxzzy00f9OmTY0kM2XKFLe17dy5s9j38fvvvzeWZRW5zNmzZ5e47vkVN59zW4wcOdLt/J6+78X1lX/aY4895vb9bNSokdm2bVuR/Xvyvjpt2rTJNGnSpNhtd/PNN5ucnJwS+zrvvPMKzHf//feXOE9OTo4ZN26cR+P86quvLjS/J9t6ypQpRpJp2rRpsbWU1NcXX3xhatWqVWKdNpvNHDlypMC8I0eOdPt7lF9x2y4pKcnEx8cXuczixmVRihuDnr5fnvxOFCX/73Rxr0svvdRkZGS4ra+o1+m/dz///HOJ49v5+v333wstKy0tzVx77bUezX/vvfe6XU9PjgHl3f+U1Edubq655ppr3NbfsWNH89lnn7m+37t3b4k1F2XSpElGkunSpYvH82zbts3UqFHDNGnSxGRmZpbY9+mvunXrml27drmdb9iwYUaSGTx4cKnWBQDgXZxRBwAIaPXq1dPy5cv1xRdfaPjw4WrWrJnCw8MVEhKiunXrqkePHnrooYe0atUqTZgwoVzLuuSSS7Rjxw49++yz6tatm2rWrKkaNWqocePGuvDCC/X0009r1qxZheazLEuTJ0/WX3/9pQceeECdO3dWXFycbDabYmJi1K5dO91yyy2aN2+eVq5cWa4a3enTp4++++47DRw4UPXr13dd3lUVPP3001q8eLH69eunOnXqKDQ0VGeddZYeeOAB/fnnn2rZsmW5l9G2bVtt3rxZL774orp166a4uDiFhISoYcOGuuaaa/TVV1/pgw8+KHBvMHdOv8y1uMtenUJCQvTmm29qw4YNuvvuu9WuXTvFxMTIZrMpLi5O5557ru644w4tWrTI5/cKGzBggBITEzVt2jRdcsklio+PV3BwsCIiInTmmWdqyJAhmj59uvbu3auaNWt6ffnx8fFavXq1Ro8erebNm7vuZRlomjRpop9++klPPvmk+vbtqzPPPFORkZGufc7gwYP13//+V998840iIyMLzT9lyhS98847uuiiixQXF+d6KElRLrjgAm3btk0zZ87UFVdcoQYNGqhGjRoKCwtTkyZNdMUVV+jFF1/Ujh071LFjx0LzR0dH65NPPtHKlSt16623qmXLloqKilJwcLBq166trl27asKECfrmm2/08ssve/V98rbg4GB98sknmjt3ri666CJFR0crMjJS7du319NPP63Vq1fLZrO52ud/kENp3HHHHZKktWvXavv27R7NM27cOOXk5Oj1118v9snor7zyit5++221b99eoaGhql27toYPH641a9a4fahOWlqaPv/88wK1AQB8wzImgK93AQAA1VLv3r21YsUKjRw5UnPmzPF1OQCqkddee02TJk1STEyMjh07JsuyytRPnz59lJCQoMcff7zMT+71ljlz5mj06NE644wztGvXrmKDXQBAxWIPDAAAAAAecj71tXPnzmUO6aRT97+UpPfee09ZWVleqa2spk+fLunUfTAJ6QDAt9gLAwAAAICk3NzcYh9yMn/+fK1YsUKSdP3115drWX369NGVV16pQ4cO6e233y5XX+WxePFirV+/Xq1bt9Ztt93mszoAAKcQ1AEAAACApOPHj6tFixZ69NFH9dNPPykpKUmpqan65ZdfNHHiRN1yyy2SpLPPPlsjR44s9/KmTZsmm82ml156SSdOnCh3f6VljNHUqVMlSS+++GKVun8pAAQq9sQAAAAA8P+lpKTo+eef1/PPP1/k9CZNmmjx4sUKDw8v97Latm2rvLy8cvdTVpZlaf369T5bPgCgMII6AAAAAJAUFxenuXPn6quvvtK6deuUnJystLQ0xcbGqk2bNho8eLDGjh2rqKgoX5cKAKiieOorAAAAAAAA4Ae4Rx0AAAAAAADgBwjqAAAAAAAAAD9AUAcAAAAAAAD4AYI6AAAAAAAAwA8Q1AEAAAAAAAB+gKAOAAAAAAAA8AMEdQAAAAAAAIAfIKgDAAAAAAAA/ABBHQAAAAAAAOAHCOoAAAAAAAAAP0BQBwAAAAAAAPgBgjoAAAAAAADADxDUAQAAAAAAAH6AoA4AAAAAAADwAwR1AAAAAAAAgB/4fyFnhh68HLtbAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1280x736 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABOYAAALGCAYAAADhgJ4mAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAYmwAAGJsBSXWDlAAA1bhJREFUeJzs3Xd4FFX7//HPpickQUoIhEDogdCbggihioACFpog1YaiCIJiA+RRkQfFLo8iRZogioKKiIKAIggCItJ7b6GFQAIkmd8f/LJfws4mm2Q2m4T367r2Ypk558w9u9P2zpk5NsMwDAEAAAAAAADIVV6eDgAAAAAAAAC4GZGYAwAAAAAAADyAxBwAAAAAAADgASTmAAAAAAAAAA8gMQcAAAAAAAB4AIk5AAAAAAAAwANIzAEAAAAAAAAeQGIOAAAAAAAA8AAScwAAAAAAAIAHkJgDAAAAAAAAPIDEHAAAAAAAAOABJOYAAAAAAAAADyAxBwAAAAAAAHgAiTkAAAAAAADAA0jMAQAAAAAAAB5AYg5AntS3b1/ZbLZ0r3Llynk6LADZNG3aNId92mazaf/+/Z4ODU6UK1fO4fvq27dvjttt3ry5Q7vNmzfPcbtAmsTERJUvXz7dNtazZ09Ph4UCiHMb4H5NmjRJt3/ddtttMgzD02FZysfTAaBg2b9/v8qXL59pOZvNpuDgYBUpUkTVq1fX7bffrgcffFAVKlTIhSiRU6NHj3aY1rx5c35YAfnUtGnTHH5ElCtXzpIkDJAT3377rf7+++9002655RY988wzHonHKufOndO7777rML1z586qU6dOrsdT0Lz55pvpjmleXl56+eWXPRcQUMC9++67OnfuXLppderUUefOnXMthuXLl2v58uUO081+tyD7Dh48qEWLFun333/Xpk2bdPr0aZ05c0Y2m02hoaEqV66catasqRYtWuiuu+5SsWLFHNpYvny5WrRo4TC9T58+mjZtmsP0V155Re3atbP/f+3atZoyZYoGDBhg6bp5Eok5eIRhGLpw4YIuXLiggwcP6scff9TIkSPVv39/vfXWW7rllls8HSIy8Oqrr5pOJzEH5E/Tpk3TihUr0k2LjY0lMQeP+/bbb/X555+nmxYVFVUgEnNm59Jy5cqRmMuh48eP66233ko37f7771e1atU8FBFQ8L377rs6cOBAuml9+vTJ9cSc2XGVxJw1/v33X40ZM0bz589XSkqKaZmkpCSdPHlSa9eu1eTJk+Xn56cePXqYJtuy4q677tKtt96qtWvX2qeNHDlSDz74oAIDA3PUdl5BYg55hmEYmjx5sjZs2KBly5aRnLvJlS9fXvXr1083LSIiwkPRAACsEh0drYSEBIdpgBVef/11Xbp0Kd20ESNGeCgaAMj/3nvvPT3//PO6fPlylupduXJF3377rSUxvPDCC7r33nvt/z969Kg+/vhjPfvss5a072kk5pArgoOD0110x8XF6dChQ0pNTXUou3HjRg0bNkyfffZZboaIPGbUqFEaNWqUp8MAAFjsk08+8XQIKKBOnz6tyZMnp5tWq1Yt1atXz0MRIbc1b97c3gM8KiqKZ70BOTR8+HCHXsjX8/X1VWRkpEJCQnTu3DkdO3ZMV69etTyODh06qHjx4oqLi7NPe+edd/T000/L19fX8uXlNgZ/QK6oX7++/vrrL/tr//79OnbsmLp3725afurUqTp16lQuRwkAAID8atKkSUpMTEw3rVevXh6KBgDyt4kTJzpNylWvXl1z587V2bNntXfvXm3atEkHDhzQuXPntHTpUg0YMECFChWyLBZfX1917do13bQjR45o/vz5li3Dk0jMwWNKlCih6dOnq2rVqg7zUlNTtXTpUqd1r1y5olmzZqlv376KiYlR8eLF5efnp2LFiqlmzZoaOHBghvXTjB492nQkpbQYpk+frnbt2ql06dLy9fXNcJSlw4cPa9y4cerYsaMqVKigW265RX5+foqIiFCdOnXUtWtXffDBBzp8+HCGMeXGuknSDz/8oK5du6ps2bLy9/dXsWLFFBsbq08//VTJyckO7V0/SqqZV1991dJRqbIyKmtGIwfu379fzzzzjKpUqaKgoCCFh4erdevWmjdvnkM7a9eu1UMPPaTy5csrICBAJUqU0F133WVa9nqZjci1fPlyPfTQQypXrpwCAgJUvHhxNW3aVB999FGmf1EyazftWRm7d+/W0KFDVb16dRUuXDjDERMTExM1ZcoU9ezZU9HR0SpatKh8fX1VrFgxVatWTb1799aMGTOcdlFfu3ataSzXP+vBzH333edQJzY21mn5w4cP64033lD79u0VFRWlkJAQ+fv7KyIiQs2bN9eYMWMy3Yckz28TN1q2bJkGDx6shg0bqmTJkvL391doaKgqVaqkHj16aMaMGZluC8uXLzf9DtIedPzPP//oySefVJUqVVSoUCGFhoaqdu3aeuWVV3T27FmH9q7fbm98vpwkrVixwnR5OX1OiDNr1qxRv379VKFCBQUGBma6n5w/f16hoaEO8U2cODHD5YwaNcqhTunSpZ0+LyUzx48f18KFC/Xqq6+qc+fOql+/vipUqKAiRYrIx8dHhQsXVrly5dSuXTu9+uqr2rVrV6ZtZjRqaXx8vN588001atRIYWFh8vLyynDE6vXr12vEiBFq3ry5IiMjFRwcrMDAQEVFRem2227Tww8/rNmzZ+vChQtZWu+kpCS9//77atq0qcLCwuTv76+yZcvqwQcf1Lp167K9flL6bf3G58tJ0oEDBzI8NprZsWOHXnnlFbVs2VJlypRRoUKFFBgYqDJlyqhdu3Z66623dObMmSx9BqdPn9b777+vLl26qHLlyvbjanh4uGrVqqXOnTvrv//9b7rvPG3dnQ2U1a9fvwzP3VLWRsvN7LhxPSuvidzxebvixuOTl5eXHnzwwQzrZLQtbd68WY888oj9HFC6dGl17NhRS5YscWjn559/1n333acyZcrI399fpUqV0r333qtffvnF5fhTU1O1YMECPfbYY6pdu7ZKlCghPz8/3XLLLapatar69eunb7/9NtPRCFNSUrR27Vp98sknGjhwoJo2baqYmBiVKlVKAQEBCgwMVIkSJVSvXj3169dPX3/9ta5cuZJhm1afg24WWT23ObNnzx6NHj1abdq0se9TAQEBKlWqlBo3bqxhw4Zlek12o5xeG15/zLjx+XKS9Pnnn7t8/Pnpp5/02GOPqWHDhgoLC1NAQIB9n6tVq5buuusuDRs2THPnztXRo0ft9fbv329v19kzsM1iuPGYmZPr7YSEBC1btkxvv/22evXqpdtuu01VqlRRWFiYfH19FRwcrIiICDVr1kyDBw/WqlWrMv5ilPnvuG+//Tbd8SY8PFxt27bVzJkzLRutNC4uTi+88ILpvC5dumj9+vXq2rWrQ/ItKChILVu21Geffaa9e/fqkUcesSQeyfwPLVOnTrWsfY8yAAvt27fPkOTwio2NdVpn4MCBpnXGjx9vWn7OnDlGyZIlTevc+GrSpImxd+9ep8seNWqUab24uDijSZMmpvP27duXro1z584Z/fr1M3x8fFyKqU+fPk7jyY11O3v2rNGuXbsM227RooWRkJCQrr0+ffq4FFdmn5erzJYXFRVlWjYqKsr0c549e7ZRqFAhp7F169bNuHz5spGammq8+OKLhs1mc1q2R48eRnJysunyp06dalpn586dRt++fTP8fGJiYjL8jMzqjBo1ypgyZYoRGBjo0vY1adIko1ixYi59XyVLljTmzp1rGkutWrUcyj/11FNOYz979qzh7+/vUGfGjBkOZRMSEozHHnvMpf3Iz8/PeP75542rV686Xbant4k0GzduNOrWrevSZ1+2bFnj559/dtrWr7/+alpv2bJlxvPPP294e3s7bbtMmTLGjh070rXnbLvN7DV16tQM19kZZ8vbu3evMWTIkAw/a2f7yTPPPONQtkaNGhnGUalSJYc6L7/8crbWyTCyfmy02WzGo48+aly8eNFpm7GxsQ71YmNjjXXr1hllypRxmGd2bNy+fbvRtGnTHH2vzvajv/76y/RzvH4dP/zwwyyvXxpn23pmr1GjRjks69SpU8YDDzyQ4faV9goODjYmTJiQ0ddtGIZhJCUlGcOHDzcCAgJciuv6dTNbd1dernwvZpx9lr/++qtDWSuuidzxebtq06ZNDsuoXr16pvWcbUtvv/224evr6zT+IUOGGIZxbXvo169fhuv63HPPZRrH0qVLjYoVK7q0PVSvXt3YsGGD07acXY9n9IqKijKWLVvmtE2rz0Hucv0+5uy60UruOLdd7+zZs0avXr0MLy8vl77HFi1aGPv37880biuuDZ0dMzJ7XX/8OXnypNGsWbMsb6tpsrOtS47HTGfHAVeut7NzPdWsWbMMv3tnn+358+cz/R13xx13GKdPn850G8jM888/b9p+nTp1jKSkpBy17ex4ktHvZMMwjJSUFCMkJCRdHR8fH+Ps2bM5iicvIDEHS7k7MefsAJHRq0iRIsbGjRtNl+3soNewYUOn7V1/ED1w4IBRrly5HJ0IcnvdatSo4VLbTzzxRLr28ltirmLFihleJKa9Xn75ZePFF190aV3++9//mi7f2Qm5cePGLrVbpkwZ49SpU6Ztm5WvX7++0wu0G7evxx9/PFvfm1mi4oMPPnAoFxYW5jRB9sknn5hus4mJienKnTp1yqhevXqWY7zzzjuNK1eu5MltwjAM45tvvjFNTGb08vb2NqZMmWLanrOLGFf36Vq1aqX7rvJKYu7uu+/O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D36ZvaxOzBmGYezfv98oV65cjuPIC+uWlR9gn332mUtxdevWzeXP8kYFITF3zz33uPQ5lSlTxvTiKSsxOPPwww9na5saMWKES+136NAhw3Z+//33TNs4efKkERMTk+3tPy8m5gzDMObPn+/0gjKzV24n5nbu3JlpAkmSER4eblrfFc72k9tuuy3H+8mN2rVr57Sd6dOnZ3sdbvTdd9+5FHtgYKDx+OOPm86zOjFnGIbx448/mv4RJ6NXXk3MnTt3zihUqJBL65CYmJiu7q5du4yIiIhsH1vMvpuzZ88adevWzVI7ztbt5Zdfdqn+888/n67e1atXjerVq7tU19mx1erEnLs+76xITU11SA7abDbj0KFDGdYziyU3E3OGYRgffPCBS8dgV7avlJQUp380uPF1//33G2XLlnWYnpcTc2btZvdlRTzuPLcdOnTI9Dic2Ss0NNT4888/ncbsjmvDX375xaU2brvtNnsdZ/tJZi8vLy9j2bJlDjEkJye7/Hlt27YtXV2zMq5cbx85csQIDQ11aZnOElxZScy5+tuiTp06DufE7EpNTTXGjx+f7WtaKxNzv//+u0OdO++805L19DRuZUW+8t///lfz5s0zfcBvRqpWrer02Ts5ERUVpb///lv9+vUzfSh0VuS1dctI3759c32Z+dF7772noUOHZjgyWUxMjFasWKGwsDC3xDBp0iRNnDjRaff+G5UoUUKzZ8827RJvJqNbAqtVq6YmTZpk2kZYWJjWrl2rJ598Ur6+vi4tV5J8fHx011135dkHvt57771at26dGjZsmKV6YWFh6tGjh5uiMle5cmW9+uqrubrMNNOnT9dDDz2UYZms7ifPPvus6fQiRYqY3laYXXfffbcmTJiQ4fG/WLFimj9/vunzFN3lrrvu0saNG9W0adNcW6a7FC5cWB999FG2zrGVKlXSpk2b1L179yyNnBkYGKj777/f9Lh5yy23aPXq1Ro2bJgCAgKyHNP1nn/+edWuXTvL9Xx8fDRv3jzTZ92m8fb21vDhw/XBBx/kJMQsccfnnRU2m039+vVLN80wDJef1+ZJgwYN0rJlyxQdHZ2lemXLllXnzp3TTfPy8tK3336rmjVrZlj3gQce0IwZM2760VPdxYpzW2RkpDZu3Kju3bu7/D01a9ZMGzdu1K233uq0jDuuDVu1amX6iJOMeHt7Z3lU46JFi2ru3Llq0aKFaXuTJk3K8bE5KyIiIrRgwYIMRwX19vbW2LFj9fTTT+d4efPmzcv0GjHt0RVWfQ42m03Dhg3T2rVrdd9992XpfOzn56dOnTpZEockzZo1y2Hajcf9/Mp8HGIgD3vggQfUuXNnLVy4UIsXL9batWt19OhRnT9/XjabTSEhISpbtqyqVq2qxo0bq2XLloqJiXFbPIULF9aUKVM0ZswYzZw5U6tWrdK///6rM2fOKDExUcWKFVOJEiVUo0YNtW7dWnfddVe+WTdnvL29tWjRIk2bNk1z587VP//8o7Nnz2b6XJybjc1m09tvv60HHnhAn3zyiVasWKFjx46pUKFCiomJUffu3fXoo49mKRmVHY8//rgeeughffHFF1q6dKnWr1+vU6dO6cKFCwoJCVF4eLgaNGigNm3aqHv37i4ND5+mQ4cOKlWqlMNIrJL581GcKVSokD788EO98sormjVrln777Tf9888/On36tBISEhQYGKgiRYqoUqVKqlGjhpo1a6aWLVvm+eHRa9WqpbVr1+qPP/7QN998ozVr1mjPnj06d+6crl69qpCQEJUsWVLR0dGqX7++WrRoodtuuy3dM2FyyyuvvKLGjRtr0qRJWrt2rY4fP54rAwL4+flp+vTp6t27tyZPnqw//vhDJ06cyNF+0qpVK9WsWdPhAcG9evWy/IJ9yJAhat68ud577z0tX75cx44dU1BQkMqWLat77rlHTzzxhCIiInLlIfzXi46O1sqVK7V+/XrNmzdPa9as0a5du3Tu3DmlpqYqLCxMJUuW1K233qrWrVs7HeglL+jTp49iYmL08ccfa9WqVTpy5IjLD/MuXry4vvjiC73xxhuaPXu2Vq1apS1btujs2bO6dOmSgoKCVKxYMVWpUkW1atVSbGysmjdvnuFIz/7+/ho/frxGjBihWbNmaeXKldq0aZPi4uKUkJCgIkWKKDw8XFWqVFGrVq2cnveDg4O1evVq/e9//9O3336rrVu36ty5c/bngGWkWrVq+ueff/TOO+9o4cKF2rNnj1JSUlS6dGm1bt1aAwcOVK1atbR8+XKXPieruOPzzopHH31Ur7/+erpj18yZMy1/+Lg7NG/eXNu2bdPPP/+s7777Tn/++acOHjxo32dDQkJUunRpVa1aVbfeeqtatGihevXqmSZsIiIitHbtWn366aeaO3eutmzZosTERIWHh6tevXrq27evQ0IP1rLq3FakSBF98cUX9t8Zv//+u3bs2KEzZ84oJSVFRYoUUbly5XT77bera9eupoPUmHHHteFnn32mu+66SzNmzND69esVFxeX4QABZcqU0enTp7Vy5UqtXbtWmzZt0t69e3X06FH7SNOFChVSRESEqlevrjvvvFPdu3c3fU5emjZt2mjjxo364IMPtGLFCh04cEAXL160Pz/PHZo3b65///1X7733nn744Qft3btX0rX9sHnz5ho4cKDq1atnyTMP/f39NXv2bPt2tWbNGp08eVKFCxdWnTp19NBDD6lXr15uSbjXrl1bX3/9tQ4cOKAffvhBv//+u/1a/ezZszIMQ6GhoYqKilKNGjXUsmVLtW/fXsWLF7dk+VevXtWXX36Zblrp0qV1//33W9K+p9kMd26lAHATmDZtmulfa/bt26dy5crlfkDATS45OVkVKlRwGLF38+bNpg/OB1BwPPnkk/r444/TTduwYYPq1q3roYgAIGtGjx5teifDzZy6+eabb3TfffelmzZ+/PgCM4gNt7ICAIAC4+rVq3rppZccknJNmzYlKQfcBF5++WUFBgamm+bq4xkAAHnTjcfxiIgIPfnkkx6Kxnok5gAAQL726aefqkGDBqpVq5bCwsL03//+16HMiBEjPBAZgNxWqlQphx4UX3/9tbZt2+ahiAAAObF48WKtW7cu3bQxY8Y4/BEmPyMxBwAA8rWjR49q/fr12rx5s86fP+8wv2PHjmrfvr0HIgPgCS+88EK6R0mkpqbqtdde81xAAIBs+89//pPu/7feeqv69+/voWjcg8EfAABAgdWwYcNcH3gBgGcFBgZq3759ng4DAGCBVatWeToEtyMxBwAACpSQkBBVr15d3bt318CBA+Xn5+fpkAAAAABTjMoKAAAAAAAAeADPmAMAAAAAAAA8gMQcAAAAAAAA4AEk5gAAAAAAAAAPIDEHAAAAAAAAeACJOQAAAAAAAMADSMwVMA0aNFCDBg08HQYAAAAAAAAy4ePpAGCt48ePezoE5GFnzpyRJBUtWtTDkQD5H/sTYC32KcA67E+Addif4G70mAMAAAAAAAA8gMQcAAAAAAAA4AEk5gAAAAAAAAAPIDEHAAAAAAAAeACJOQAAAAAAAMADSMwBAAAAAAAAHkBiDgAAAAAAAPAAEnMA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AAAAAAAAkGdZnpgbNGiQypQpo6SkJHXq1EmdOnXSzJkztWHDBu3atUsbN27UzJkz1blzZ919991KSkpS2bJl9eSTT1oah2EY2rZtmz7//HM9+eSTatiwofz9/WWz2WSz2bR//36X25ozZ47atGmj8PBwBQQEqHz58nr00Ue1bds2l+qnpKTok08+0R133KFixYopKChI0dHRGjp0qA4fPpzNNQQAAAAAAEB+5mN1g0FBQfrxxx9155136ujRo/r++++d9pwzDEOlS5fWokWLFBgYaGkcBw4ccHkACmeSk5PVrVs3zZ8/P930/fv3a9KkSZoxY4amTJmiHj16OG3jwoULateunVatWpVu+s6dO7Vz505NnTpVX3/9tVq2bJmjWAEAAAAAAJC/WN5jTro2IuvmzZs1ePBgFS5cWIZhOLwKFy6sIUOG6J9//rGPzOoukZGRuvfee9W0adMs1Rs6dKg9KdenTx9t3rxZJ0+e1A8//KCqVasqKSlJffr00Zo1a5y20bNnT61atUo2m03Dhg3Tzp07dezYMc2ZM0elSpXSuXPndN9992nfvn05WkcAAAAAAADkL5b3mEtTpEgRvfPOO3r77be1efNmHThwQBcuXFBISIjKlSunGjVqyMvLLXlBSVKxYsX07bff6rbbblPJkiUlSaNHj9Zvv/3mUv1t27bpo48+knQtKTdt2jT7vPbt26tBgwaqXr264uLi9Oyzzzr0iJOkn376Sd99950kaeTIkRo9erR9Xrdu3VSrVi3Vq1dP58+f18svv6xZs2Zlc20BAAAAAACQ31ieGevfv7/69+9vT4B5eXmpdu3a6tixo3r27KmOHTuqVq1abk3KSVJISIg6depkT8pl1cSJE5WamiofHx+NHTvWYX6JEiU0fPhwSdIff/yhv//+26FMWmKvaNGiGjFihMP8atWqqV+/fpKujWIbFxeXrVgBAAAAAACQ/1ieHZs+fbo+//zzbCfE8oqFCxdKkpo2bapSpUqZlunWrZv9/YIFC9LNS0xM1C+//CJJ6tSpkwICAjJsIyUlRT/88EOO4wYAAAAAAED+YHliLiwsTJJUvHhxq5vONadPn9aBAwckSY0bN3ZaLioqyp6027BhQ7p5W7duVWJiYqZt3Hrrrfbegze2AQAAAAAAgILL8sRczZo1JUl79uyxuulcs337dvv7ChUqZFi2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iIj+z8Bd0267/dz1S8Xus7gF2ygioocFh7ISERERERERERFZATPmiIiIbuNw/yHF/vyaiyMAwDkz5wGWhoiI6KZvGg4pfoN3QRuFNLZRREQPOwbmiIiIbqOkueKuupYBALjC9kEWh4iISClxrjingjYK9myjiIgedhzKSkREREREREREZAUMzBEREREREREREVkBA3NERERERERERERWwMAcERERERERERGRFTAwR0REREREREREZAUMzBEREREREREREVkBA3NERERERERERERWwMAcERERERERERGRFTAwR0REREREREREZAUMzBEREREREREREVkBA3NERERERERERERWwMAcERERERERERGRFTAw9wCtXr0aUVFR8PX1hYODAwICAtCnTx/s2rXL2kUjIiIiIiIiIqIHjIG5B2Tw4MHo1KkTli5dinPnzuHGjRtITk7G/Pnz0bRpU3z++efWLiIRERERERERET1ADMw9AFOmTMEXX3wBAOjSpQuio6ORnp6OjRs3olGjRjCZTHjnnXewePFiK5eUiIiIiIiIiIgeFAbm7rMLFy5g7NixAIDWrVtj6dKlqF+/Pjw9PdGyZUusX78e1apVAwAMHz4cubm5ViwtERERERERERE9KAzM3Wdz5sxBZmYmAGDSpEkwGCx/5Y6Ojhg/fjwAICkpCStWrHjgZSQiIiIiIiIiogePgbn7bOnSpQCAoKAg1K9fv9h9oqKiYG9vDwBYsmTJAysbERERERERERFZDwNz99m+ffsAAI0bNy5xH3t7e9StW9difyIiIiIiIiIiKt0YmLuPzpw5o4axBgcH33bfoKAgAEBcXBxE5L6XjYiIiIiIiIiIrMto7QKUZhcuXFD/9vHxue2++vbr16/j2rVrcHFxKXHfihUrlrjt3Llz8PHxwaVLl+6ytA8nrzLWLkHp4u5g7RKUTo9Sfct0ZaW6V7LKsELdD/II1Sd/+wrWLkKpclo7DACw1Yz83d5Dj0wbVYHt0z1Vjm3U/fDI1CcArjcyrV2EUqNMbpa1i1AqXbpUehKSPDw8/tHxDMzdR1lZNyuwg8PtG0dHR0f1778KzD1OPh3Q0tpFKFWuXr0KAHB1dbVySchaXIYOsHYRSg35v/rkwvr02JrTc4a1i1CqNJrWCBm4DD+3CvzdPoZazmD7dC/xmY+GVmV/8l65erUggOTqyt8p3R8MzD0gmqb9o+2FpaSklLhNz6b7pxFbKt14fxDdO6xPRPeGvnK9jY0N6xXRPcK6RHTvsD7R/cI55u6jMmVupuTn5OTcdt/C252dne9bmYiIiIiIiIiI6OHAwNx95Onpqf6dlpZ2231TU1MBFKzQysAcEREREREREVHpx8DcfeTn56eCbAkJCbfd9+TJkwCAqlWr3tWwViIiIiIiIiIiejQxMHef1atXDwCwc+fOEvfJzc3Fvn37LPYnIiIiIiIiIqLSjYG5++zJJ58EACQmJmLv3r3F7rN06VJcv34dANCtW7cHVjYiIiIiIiIiIrIeBubus5deegkuLgXLKo8cORJms9lie05ODj788EMAQGBgILp06fLAy0hERERERERERA8eA3P3maenJ8aOHQsAWLduHaKiorBnzx5cuHABmzdvRtu2bRETEwMAmDx5Muzs7KxYWiIiIiIiIiIielCM1i7A42DYsGFISkrCl19+ieXLl2P58uUW2w0GAyZNmoTu3btbqYRERERERERERPSgMWPuAfniiy+watUqdOvWDeXLl4ednR0qVqyIXr16Yfv27RgxYoS1i0hERERERERERA8QM+YeoI4dO6Jjx47WLgYRERERERERET0EmDFHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBUZrF4CIiIiIHh8pKSnF/jwvL0/9Xdw+FStWvK/lIiIiIrIGBuaIiIiI6IHx9/e/7fb4+Phi9xGR+1UkIiIiIqvhUFYiIiIiIiIiIiIrYMYcERERET0wycnJxf788uXLAAB3d/cHWRwiIiIiq2JgjoiIiIgemJLminNycgIAeHh4PMjiEBEREVkVh7ISERERERERERFZAQNzREREREREREREVsDAHBERERERERERkRUwMEdERERERERERGQFDMwRERERERERERFZAQNzREREREREREREVsDAHBERERERERERkRUwMEdERERERERERGQFDMwRERERERERERFZAQNzREREREREREREVsDAHBERERERERERkRUwMEdERERERERERGQFDMwRERERERERERFZAQNzREREREREREREVsDAHBERERERERERkRUwMEdERERERERERGQFDMwRERERERERERFZAQNzREREREREREREVsDAHBERERERERERkRUwMEdERERERERERGQFDMwRERERERERERFZgSYiYu1C0L1jZ2cHk8mEChUqWLso9BAym80AAIOBMXmif4r1iejeYp0iundYn4juHdYn+ivly5fHnj17/vbxvLNKGVtbW9jY2Fi7GPSQSk1NRWpqqrWLQVQqsD4R3VusU0T3DusT0b3D+kT3GzPmiB4jFStWBACkpKRYuSREjz7WJ6J7i3WK6N5hfSK6d1if6H5jxhwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBZqIiLULQURERERERERE9LhhxhwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREREREREREZEVMDBHRERERERERERkBQzMERERERERERERWQEDc0RERERERERERFbAwBwREdEjIjMzE1OnTsWAAQPw559/AgBExMqlIiIiIiKiv8to7QIQEd0raWlp8Pb2hslkgo2NjbWLQ3TPpaWlYfjw4QCAGjVqoF27dtA0zcqlIiIiIiKiv4sZc0T0SMvJycHUqVNhMBgQFRV1233NZjPy8/OZYUSPrMqVK6NBgwYAgNjYWFy9etXKJSIiIiKiwvS+htlsxpEjR3Dp0iWLnxPdioE5InqkGY1G5ObmAgCOHj0KACVmyxkMBhiNRmYY0SPJZDIBABo3bgygIDCXnJwMgA96RA8Tk8kEs9ls7WIQEZGVaJqGVatWwWg0onXr1ti+fXuJ++qJA2w3Hm8MzBHRI83W1ha1a9eGr68vrl27ht27dwOAReOmBy2Sk5PxwQcfoEOHDliwYIFVykt0t0TEoqPf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",
      "text/plain": [
       "<Figure size 1280x736 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABOQAAALGCAYAAADldU4bAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAYmwAAGJsBSXWDlAAAn1pJREFUeJzs3Xd0FGXfxvFr0zsJEEIAKaH3jqBCkCZKCVXwASliFxuCig3soIKPiIgFQQRFUQRUeLCBWEB6C0WEANITWkhv8/7BSyTsbAqZbDbh+zlnz9nM3HPPbyd7ZyfXTrEZhmEIAAAAAAAAgFO4FXcBAAAAAAAAwNWEQA4AAAAAAABwIgI5AAAAAAAAwIkI5AAAAAAAAAAnIpADAAAAAAAAnIhADgAAAAAAAHAiAjkAAAAAAADAiQjkAAAAAAAAACcikAMAAAAAAACciEAOAAAAAAAAcCICOQAAAAAAAMCJCOQAAAAAAAAAJyKQAwAAAAAAAJyIQA4AAAAAAABwIgI5AAAAAAAAwIkI5AAUiVWrVslms9k9Vq1aVdylwUVMnDjR9D1ipmPHjnbtOnbs6NyCixljyvmqV69ut71HjBhR3GWZKsh4KoiStA1Q+vC3v+BGjBhht82qV69e3GWZOnDggOnfrTlz5hS6b/52ASgJPIq7ADjPgQMHVKNGDbvpkZGR/EMHOFnHjh31yy+/mM7z9PSUp6enAgICFBISokqVKikiIkItWrRQ586dVbduXSdXC7imiRMn6vnnn7e0z9mzZ/NP21UkJSVFixcv1rfffqstW7bo2LFjio+Pl5ubm/z8/BQaGqpKlSqpdu3aql+/vlq2bKmWLVsqICCguEu3xMSJE+2mdezY0dLQ68CBA6YBy4gRI1w2KAIAwBkI5ADAxaSnpys9PV1JSUk6efKk9uzZo5UrV2rWrFmSpGuvvVbPPvusevToUcyVAkDJ9d133+nee+/V4cOHTeenpaXp7Nmz2rt3b44vUPr3768vv/zSWWUWKUeBttWBnNl6OnbsSCAHALiqEcgBQAnz559/qmfPnhoyZIg++OAD+fr6FndJRa5u3bpKSEiwmwYUpSZNmqh8+fI5ppkdaY6S54svvtBtt92mrKys4i4FAABcpQjkAMCFNG7cWF5eXkpPT9eZM2d05MgRh/8wzp8/X4cPH9aKFSvk7e3t5Eqd67333ivuEuCCKlWqpJYtWzqcv3HjRrtpXl5eaty4scNlLg3gli5dWrgC4ZLi4uJ0zz33mP5t9fLyUrVq1eTv76/ExESdOHFC8fHxxVAlAAAo7QjkAMCFLF26NMcpPPHx8frpp580ZcoU/f7773btf/nlF40cOVKffvqpE6sEXMPdd9+tu+++2+F8s5sahIeHa8OGDUVZFlzcggULdPbs2RzTPD09NW3aNI0YMUI+Pj455h06dEh//PGHVqxYocWLFzuvUAAAUKpxl1U4lNudrWJjY/XMM8+ocePGCggIULly5XT99dfrww8/VHp6eo5+du3apfvvv1+1a9eWr6+vypUrp44dO+qDDz5QRkaGw/XndUfBTZs26Z577lHt2rXl7++vkJAQtW7dWpMmTbI7te1yud156cSJE3r22WfVvHlzlS1bNtc7emVkZOjzzz/XHXfcoUaNGql8+fLy9PRUcHCwateurUGDBmnmzJkO6zl69Kg8PDzsavniiy9yrX/MmDF2y9SoUUOGYZi2P3XqlP773/+qb9++ioiIUJkyZeTl5aWKFSuqXbt2Gj9+vPbs2ZPrOi+VnJysN954Q23btlVISIj8/f1Vu3ZtPfDAA4qOjs53PwVx//33273mhg0b5rrMqVOn5OXlZbfc7Nmz7dquWLFC99xzj1q3bq3Q0FD5+PjIx8dHlStXVpMmTdS9e3eNHTtWn3/+uY4ePVokr9FMUFCQ+vbtq19//VUvv/yyaZvPPvtM33//fZ597dmzR88++6w6deqka665Rv7+/vL19dU111yjm2++WW+88YZOnz5doPpOnTqladOmaeDAgapdu7bKli0rT09PhYWFqUmTJurTp49ee+017d27t0D9Xq4gd9oz+7tx8cLlsbGxmjhxolq2bKmQkBD5+vqqZs2auuuuuwo0BhhTJXdMFcSV3qXP6rF2+PBhjR07Vg0aNFBAQICCg4PVvHlzvfDCC4qLiyvEKyycxMRETZ06Vdddd53Kly8vHx8fRURE6K677tK2bdtMl3nuuefstmmVKlVy3R9ISEiQv7+/3XLvvvvuFdW9Zs0au2mDBw/WvffeaxfGSVLVqlU1ePBgzZ49W8eOHdMzzzyTr/UcO3ZMkydPVs+ePVW9enUFBQXJy8tLYWFhatmypR588EH9+OOPefZTkL9/+blr5aV34TTz/PPPm/Zx4MCBfL3uiy6OnxtvvNF0/o033liou4FmZmZqzpw56tatmypWrChvb2+Fh4erb9+++uGHH3JdNrc7kaalpWn69Onq2LGjKlasKHd391zvWLxhwwY9/vjjuv7661WpUiX5+vrK399f1atXV9++ffXuu+8qMTExX69p+/btGj9+vDp06KDKlSvL399fnp6eqlChgurXr6/IyEjdd999ev/997Vr1658b6tLLVq0SH369FGVKlXk7e2tChUqqHv37vriiy8c7kderrD7v4W1YsUKDRgwQJUrV5a3t7cqVaqkW265RZ9//nmRrA8AioyBq0ZMTIwhye4RGRlp2j4yMtK07U8//WSUL1/etC9Jxo033micOXPGMAzDePvttw0vLy+HbTt16mQkJCSYrn/lypWmy6xcudIYP3684e7u7rDfKlWqGBs3bnS4LapVq2a3zPDhw41ly5YZISEh+dpGS5YsMapUqeKwhksfZcqUMaZNm2ZaS+/eve3a9+rVy2HtGRkZRnh4uN0yL774ol3b9PR045lnnjF8fX3zrNHNzc244447jMTERIfrNgzD2LFjh1G9enWH/Xh5eRmvv/56rr+/K7Fp0ybT/nL7Pb/zzjt27YOCgnK8506ePGl06NAhX7/Hi49q1apd0Wu4lNn4kmTExMTkuty9995rulybNm0cLhMbG2sMGDDAsNlseb62gIAAY+rUqXnWn5KSYowbN87w8fHJ1zYzG0MTJkwwbZvf7eXob5dZnxMmTDAWLFhgBAcHO6zR29vb+Prrr3N93Ywp1x1TZgq7LkefFY4UxVhbsGCB4e/v77CfChUqGN9//32BxlNBONoGmzZtMiIiIhzW5eHhYbz88st2/R0/ftzw9va2a//ll186rOGTTz6xa+/n52ecO3fuil5T165d7fq74447rqgvMykpKcYjjzyS6/7PpY9mzZoZW7ZscdhfQf7+OdrXmz17dnab4cOHF2h8Xnzk9fl0ObP3TkH/Fjh67fv37zdatGiRa1/jxo1zWJvZNqhWrZqxb98+o0GDBvkaSzExMUanTp3y9brKly9vzJ8/32E9GRkZxv3335+vvx15/U4cvba4uDijS5cuufY3ePBgIyMjI9ffq1X7vxe3YV7v10ulpqYa//nPf3JdZ+fOnY1Tp04V+O83ABQHArmriBWBXOXKlQ0/P788P4CHDh1qfPDBB/n6sL7/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grOkKszf89yUL18+z6O5i2K8S9LDDz+sV155Jdf1Z2RkaMeOHZo5c6Y6deqkyMjIfB/9V6FCBdN99fxus6Lc/80PV/+bCABXikAOBVKQQ+ML0rYgLj2N6nJmH9je3t7y9vbOs9/8tDELGRMTE3P9R9KsJrN+vLy8NHz4cLvpF09bNTtCxewfYiuD0EuPhjLbsSno78Iqt99+u93v66efftKxY8f0/fff6+TJkznmNWzYUO3atTPtKyAgQPPnz9fevXv12muvqXfv3qpVq5bDnVTDMDR9+nRNnz7dmhdTQCdPntSqVatM53Xt2jX7uVXvg0vfA476NDsqxNU4Gt+5hUYXMaZK95gqrKIYa47+kSyu94cVdZgFU56ennrooYfsps+YMUNbtmyxOy20Xr16eR7BVFgBAQHq0KGDnnjiCf3000/atGmT6RF5qampOU5VdvQ+MAsiL3K0rfLznrr89MWL8ntWQElWmL/nV9LvpYpivF80fvx4HT16VB9++KGGDh2qJk2ayM/Pz2Efq1evNr3kgJnCbrOi3P/ND1f/mwgAV4pADiXO1q1bHc67/NB4KX9HvuVX1apV7aalp6crOjratH1ycrLpaUtm/Ujm13L64osvtGPHDq1fvz7H9AoVKigqKsquvb+/v8qXL283/eGHH5Zx4UYu+X40atQo15q3b9/u8HpmZr8Lq5QrV059+/bNMS0rK0uffvppvoPLy9WsWVPjxo3TkiVLtHfvXqWmpurQoUP69ttvTa/N9NFHH135CyiEp59+WsnJyXbT27Ztq0qVKmX/bHZdR+nCtcEK8h649FTNa665xvRaX1d6TZiSgjFVusdUYRXVWDOT23ugKN8flyvo57Dk+DXdfffddke5fPXVV5oyZYpd2/y876zWtGlTDRkyJM92/v7+Klu2rN30LVu2OFzG0bzL/zaYXTfXURCR2+8GhedovG/evLlA4/3yaypeFBISolGjRumTTz7R1q1blZiYqJMnT+rXX381ff8vWbKkQNfIu1JFvf97JeuXHP+9OXToEKerAigRCORQ4nzyySemF9RdtWqV3TU5pAvXR7KKo2tlvf/++6bT586dq5SUFLvpZhfDlqS6devafft/+vRpjRgxwq7t8OHDTU8/kHIeKXXRF198YXeUiyM7d+60OzLBbDueOHFCy5Yts5uenp5ud0MKq5ntmM6aNSvHNX2kC98KX36NoovS09NN30vShSM8r7nmGvXo0UNvvfWW3fyCXh+qsAzD0IsvvqgPP/zQdP4LL7yQ4+eGDRvmCOguevfdd02/mTdb308//ZRjhzYoKEht27a1a7tmzRp9/fXXufZnNg5KEsbUv0rLmLJKUYy1smXLql69enZtv/vuO504ccJu+t9//63Vq1cXsPIrFxMTY3rjAUfvUy8vL7Vq1cq0r+DgYLtroaanp9sFwd7e3tnXNCysl156SU888YSOHDmSr/ZmR7m5ubnZXcfMbB9h06ZN2rhxo910wzD0wQcf2E232Wzq1KlTjmlmR+j9/fffdn9XMzMzC3ykqVnYl5SUVKA+8uLo6Cyr1+MMkZGRptssv9s9IyMjxzU2L8rtSK/Q0FDdcMMNev/99+1ujJaVlaW///47X+sujKLe/82Lo315R1/klNQveABcfQjkUOL8/fffGjp0aI5vBDds2OBwRz0/32znV5cuXUy/HZ0xY4befPPNHNd4+/rrr/XYY4/ZtfX19bW7M+GlzP4pNtuZz+00BbNr7Bw7dkxdunTRd999Z3eKQWpqqjZt2qTJkyfruuuuU8OGDbVu3bocbRxtxzvvvDPH3a/Onj2rYcOGFfkO4o033qiaNWvmmLZr1y67Hfz+/fubHrUgSUeOHFF4eLjuueceLVq0SMePH7drEx8fr3feecduutkOeVGIj4/X119/rfbt2+u5554zbTNkyBDTwMjsvfT9999rwIABpkdmnDt3TitXrtTjjz+u2rVrq0uXLnZ3G73//vtNa7jtttv0xhtv2J0isn//fk2YMMHu7swlDWPqXyV9TBWFohhrZu+PxMRE9evXL8cNEv766y/1798/X+GflYYNG5bjrsu5vU/79euX67WxHnnkkTzvtNu3b1/TI1WvxNmzZ/Xaa6+pWrVq6tatm95//33t3LnTbhyfPXtWU6ZM0fz58+36aN26td3phI4+lwcMGJDjKPeEhATde++9pndj7tWrV/aNXy669Mjai5KSknTfffdl73ecO3dOw4YNM/1iMjdmYd+PP/5oeifgK+XoJhxLly4tcdeODAgI0G233WY3fdasWbrrrrtM3/9xcXFavny5Ro8erapVq9odjSxduBtvv379NGvWLO3du9duu2RkZOjDDz80PerLGX87nbH/m5s2bdqodu3adtO//PJL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L2slSd6RbeXb/xa5h5SR3NzkVqG8/IYNkFeT+jIyMv5/AaMYqwUAACjZPIq7gKKQkZGhlStXasWKFVq7dq327Nmjs2fPyt/fXzVr1lTXrl113333qVq1ag77OHDggGrUyN/dw9avX69WrVpZVT4AAECxSF60XG7lguXVvJF8unVQlW4dcsxP27ZLysySV/OGMpKSi6lKAACAkq9UBnItWrTQ9u3b7aafO3dOmzZt0qZNm/T2229rxowZGj58eDFUCAAA4IIyM5U4c57SmjaQ17XNZbsmXDYPDxkn45T252al/bFRAY/dfaHpibhiLhYAAKDkKpWBXHx8vGw2m7p06aKBAwfquuuuU3h4uM6dO6fly5frueee06lTpzRy5EiFhobqlltuybW/ZcuWqX379g7n+/n5Wf0SAAAAik361p1K37pT8cEBkqSgswkXZri5yb1KuCQpY//B4ioPAACgxCuVgdzAgQN15513qm7dujmmly1bVvfff786deqkVq1aKTExUY8//niegZyvr68CAgKKsmQAAACX59m4ntz8fGWkpSt9o/3ZCAAAAMifUnlTh9dff90ujLtUvXr1NHLkSElSdHS0Dh065KzSAAAASiSbv598+1/4EjN19VquIQcAAFAIpTKQy49GjRplPz9y5EgxVgIAAOAaPOrWlHe3DnKrUF5y+//dRA93eTZrqMAn7pN7WHllHjmu5MXfF2+hAAAAJVypPGU1P06ePJn9PCgoKF/LpKWlycvLq6hKAgAAKFZuZYPl1/8Wqf8tMrKyFJSSKjcfb9n+P5zL+PuAEmbMldLTi7lSAACAku2qDeS++uorSVJISIjq1auXa9vRo0fr4MGDSkhIkJeXl2rVqqUuXbrowQcfVK1atZxRLgAAQJHL+PuAUn78VR61qsutbIjc/HyVmZCorAOHlbZui9LXby3uEgEAAEqFqzKQmz17trZuvbBDeffdd8vd3T3X9tHR0dnP09LStHPnTu3cuVMzZ87UlClTNHr06CKtFwAAwBmyYk8peeF32T/b3WUVAAAAlrjqArno6Gg99NBDkqRq1app/Pjxpu3c3NzUtWtXDR48WK1atVKVKlXk7++vAwcO6Ouvv9arr76q+Ph4Pfjgg/L398++SUReqlSp4nDesWPHFBYWptOnTxf8hTnR+WDuOGsmMcCvuEtwaYaLv69d0dU0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",
      "text/plain": [
       "<Figure size 1280x736 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# -*- coding: utf-8 -*-\n",
    "\"\"\"\n",
    "SAE Steering — Percent-Improvement Analysis with Per-Threshold Counts\n",
    "(Professional plotting, Okabe–Ito color palette; Matplotlib only)\n",
    "\n",
    "Fix:\n",
    "- Ensure equal bin widths on both sides of zero for the \"Distribution of percent improvements\" figure.\n",
    "  We:\n",
    "    * estimate a single global bin width from the whole sample (Freedman–Diaconis),\n",
    "    * choose a symmetric cap [-cap, +cap],\n",
    "    * derive a single bin count, and\n",
    "    * build mirrored edges so 0 is an exact bin edge and both sides share identical widths.\n",
    "\"\"\"\n",
    "\n",
    "import re\n",
    "from typing import Tuple, Dict\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ===========================\n",
    "# 0) Plotting configuration\n",
    "# ===========================\n",
    "# Okabe–Ito colorblind-safe palette (professional look)\n",
    "OI = {\n",
    "    \"blue\":   \"#4477AA\",\n",
    "    \"orange\": \"#EE6677\",\n",
    "    \"green\":  \"#228833\",\n",
    "    \"yellow\": \"#CCBB44\",\n",
    "    \"purple\": \"#AA3377\",\n",
    "    \"cyan\":   \"#66CCEE\",\n",
    "    \"grey\":   \"#888888\",\n",
    "    \"black\":  \"#000000\"\n",
    "}\n",
    "\n",
    "mpl.rcParams.update({\n",
    "    \"figure.dpi\": 160,\n",
    "    \"savefig.dpi\": 300,\n",
    "    \"figure.figsize\": (8.0, 4.6),\n",
    "    \"axes.titlesize\": 14,\n",
    "    \"axes.titleweight\": \"bold\",\n",
    "    \"axes.labelsize\": 12,\n",
    "    \"axes.labelweight\": \"regular\",\n",
    "    \"axes.spines.top\": False,\n",
    "    \"axes.spines.right\": False,\n",
    "    \"axes.grid\": True,\n",
    "    \"grid.alpha\": 0.25,\n",
    "    \"grid.linestyle\": \"-\",\n",
    "    \"font.size\": 12,\n",
    "    \"legend.frameon\": False,\n",
    "})\n",
    "\n",
    "def fd_bin_width(x: np.ndarray, fallback_width: float) -> float:\n",
    "    \"\"\"Freedman–Diaconis bin width computed from full data; fall back if IQR=0.\"\"\"\n",
    "    x = np.asarray(x, dtype=float)\n",
    "    x = x[np.isfinite(x)]\n",
    "    n = x.size\n",
    "    if n < 2:\n",
    "        return fallback_width\n",
    "    q75, q25 = np.percentile(x, [75, 25])\n",
    "    iqr = q75 - q25\n",
    "    if iqr <= 0:\n",
    "        return fallback_width\n",
    "    h = 2.0 * iqr * (n ** (-1.0 / 3.0))\n",
    "    return max(h, fallback_width / 50.0)\n",
    "\n",
    "def bootstrap_ci_mean(x: np.ndarray, B: int = 20000, alpha: float = 0.05, seed: int = 123) -> Tuple[float, float]:\n",
    "    \"\"\"Bootstrap CI for the mean.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    x = np.asarray(x, dtype=float)\n",
    "    x = x[np.isfinite(x)]\n",
    "    n = x.size\n",
    "    if n == 0:\n",
    "        return np.nan, np.nan\n",
    "    stats = []\n",
    "    for _ in range(B):\n",
    "        samp = rng.choice(x, size=n, replace=True)\n",
    "        stats.append(samp.mean())\n",
    "    low = float(np.percentile(stats, 100 * (alpha/2)))\n",
    "    high = float(np.percentile(stats, 100 * (1 - alpha/2)))\n",
    "    return low, high\n",
    "\n",
    "# ===========================\n",
    "# 1) Input the experimental table\n",
    "# ===========================\n",
    "raw = [\n",
    "    # SAEs, AutoInterp, Absorption, LossRecovered, SCR20, SparseProbingTop1, RAVEL, TPP20, Steering, (0.1, 0.01, 0.001, 0.0001)\n",
    "    (\"batch_topk_50\",  0.8369, 0.2455, 0.9440, 0.1105, 0.7229, 0.6117, 0.0325, 0.151, (0.192,0.198,0.163,0.154)),\n",
    "    (\"batch_topk_80\",  0.8227, 0.1442, 0.9588, 0.1308, 0.7262, 0.6571, 0.0391, 0.156, (0.148,0.150,0.165,0.158)),\n",
    "    (\"batch_topk_160\", 0.8117, 0.0520, 0.9736, 0.1689, 0.7251, 0.7009, 0.1204, 0.145, (0.120,0.210,0.126,0.079)),\n",
    "    (\"batch_topk_320\", 0.8142, 0.0838, 0.9835, 0.0897, 0.7159, 0.7214, 0.1580, 0.122, (0.200,0.240,0.215,0.146)),\n",
    "    (\"batch_topk_520\", 0.8023, 0.0949, 0.9852, 0.1320, 0.7528, 0.7211, 0.3160, 0.117, (0.240,0.187,0.153,0.113)),\n",
    "    (\"batch_topk_820\", 0.7914, 0.1309, 0.9852, 0.1180, 0.7656, 0.7229, 0.3448, 0.106, (0.340,0.318,0.233,0.224)),\n",
    "\n",
    "    (\"gated_49\",       0.8152, 0.4517, 0.9407, 0.1124, 0.7341, 0.6071, 0.0235, 0.106, (0.540,0.213,0.142,0.128)),\n",
    "    (\"gated_78\",       0.8086, 0.4134, 0.9572, 0.1301, 0.7562, 0.6334, 0.0306, 0.089, (0.000,0.000,0.053,0.068)),\n",
    "    (\"gated_148\",      0.7939, 0.2182, 0.9736, 0.1567, 0.7591, 0.6891, 0.0520, 0.116, (0.180,0.103,0.144,0.104)),\n",
    "    (\"gated_340\",      0.7746, 0.1256, 0.9868, 0.1491, 0.7051, 0.7337, 0.0604, 0.153, (0.160,0.096,0.200,0.133)),\n",
    "    (\"gated_547\",      0.7645, 0.1168, 0.9918, 0.1363, 0.7127, 0.7544, 0.0745, 0.134, (0.000,0.096,0.147,0.173)),\n",
    "    (\"gated_948\",      0.7536, 0.1007, 0.9967, 0.0934, 0.6764, 0.7714, 0.0994, 0.103, (0.120,0.120,0.048,0.158)),\n",
    "\n",
    "    (\"jumprelu_52\",    0.8281, 0.2558, 0.9456, 0.1504, 0.7237, 0.6127, 0.0287, 0.176, (0.000,0.191,0.271,0.234)),\n",
    "    (\"jumprelu_83\",    0.8119, 0.1767, 0.9588, 0.1423, 0.6964, 0.6596, 0.0492, 0.179, (0.240,0.355,0.353,0.268)),\n",
    "    (\"jumprelu_165\",   0.7996, 0.0787, 0.9769, 0.1595, 0.7349, 0.7109, 0.0669, 0.120, (0.170,0.131,0.140,0.164)),\n",
    "    (\"jumprelu_330\",   0.7887, 0.0210, 0.9852, 0.1412, 0.7206, 0.7350, 0.0709, 0.105, (0.000,0.100,0.194,0.156)),\n",
    "    (\"jumprelu_538\",   0.8048, 0.0656, 0.9918, 0.1359, 0.7365, 0.7403, 0.0948, 0.089, (0.000,0.000,0.000,0.016)),\n",
    "    (\"jumprelu_779\",   0.7955, 0.0232, 0.9934, 0.1511, 0.7647, 0.7391, 0.1221, 0.119, (0.140,0.121,0.118,0.118)),\n",
    "\n",
    "    (\"relu_54\",        0.8326, 0.2789, 0.8402, 0.0662, 0.7360, 0.4434, 0.0065, 0.150, (0.121,0.190,0.227,0.234)),\n",
    "    (\"relu_99\",        0.8144, 0.2801, 0.8896, 0.0694, 0.7708, 0.4967, 0.0118, 0.110, (0.060,0.101,0.077,0.081)),\n",
    "    (\"relu_156\",       0.8003, 0.2467, 0.9160, 0.0854, 0.7711, 0.5747, 0.0178, 0.181, (0.137,0.150,0.169,0.168)),\n",
    "    (\"relu_309\",       0.7896, 0.2201, 0.9473, 0.0988, 0.7686, 0.6520, 0.0171, 0.131, (0.306,0.316,0.226,0.192)),\n",
    "    (\"relu_507\",       0.7754, 0.2370, 0.9638, 0.1139, 0.7939, 0.6999, 0.0235, 0.140, (0.068,0.160,0.189,0.200)),\n",
    "    (\"relu_733\",       0.7644, 0.1822, 0.9753, 0.1143, 0.7742, 0.7176, 0.0353, 0.141, (0.128,0.219,0.161,0.156)),\n",
    "\n",
    "    (\"topk_50\",        0.8336, 0.2984, 0.9341, 0.1174, 0.7227, 0.5682, 0.0238, 0.197, (0.236,0.242,0.232,0.214)),\n",
    "    (\"topk_80\",        0.8215, 0.1935, 0.9489, 0.1305, 0.7136, 0.6107, 0.0337, 0.149, (0.166,0.147,0.147,0.143)),\n",
    "    (\"topk_160\",       0.8124, 0.0884, 0.9687, 0.1274, 0.7114, 0.6636, 0.0932, 0.152, (0.060,0.137,0.128,0.154)),\n",
    "    (\"topk_320\",       0.8062, 0.0613, 0.9802, 0.1662, 0.7115, 0.6960, 0.1527, 0.113, (0.320,0.240,0.160,0.124)),\n",
    "    (\"topk_520\",       0.8226, 0.0290, 0.9868, 0.1204, 0.7229, 0.7145, 0.3032, 0.134, (0.000,0.180,0.300,0.296)),\n",
    "    (\"topk_820\",       0.8150, 0.1411, 0.9918, 0.1110, 0.7666, 0.7089, 0.3226, 0.105, (0.270,0.312,0.160,0.074)),\n",
    "]\n",
    "\n",
    "cols = [\n",
    "    \"SAEs\",\"AutoInterp\",\"Absorption\",\"LossRecovered\",\"SCR20\",\"SparseProbingTop1\",\n",
    "    \"RAVEL\",\"TPP20\",\"Steering\",\"Steer_0.1_\",\"Steer_0.01_\",\"Steer_0.001_\",\"Steer_0.0001_\"\n",
    "]\n",
    "rows = []\n",
    "for row in raw:\n",
    "    name, *vals = row\n",
    "    base, thresholds = vals[-2], vals[-1]\n",
    "    rows.append([name, *vals[:-2], base, *thresholds])\n",
    "\n",
    "df = pd.DataFrame(rows, columns=cols)\n",
    "\n",
    "# ===========================\n",
    "# 2) Parse architecture & L0\n",
    "# ===========================\n",
    "def parse_arch_and_l0(name: str) -> Tuple[str, int]:\n",
    "    m = re.match(r\"([a-zA-Z_]+)_(\\d+)\", name)\n",
    "    if m:\n",
    "        arch = m.group(1).replace(\"_\", \" \")\n",
    "        l0 = int(m.group(2))\n",
    "        return arch, l0\n",
    "    return name, np.nan\n",
    "\n",
    "df[\"arch\"], df[\"L0\"] = zip(*df[\"SAEs\"].map(parse_arch_and_l0))\n",
    "\n",
    "# ===========================\n",
    "# 3) Percent improvements\n",
    "# ===========================\n",
    "steer_cols = [\"Steer_0.1_\",\"Steer_0.01_\",\"Steer_0.001_\",\"Steer_0.0001_\"]\n",
    "for c in steer_cols:\n",
    "    df[f\"pct_{c}\"] = 100.0 * (df[c] - df[\"Steering\"]) / df[\"Steering\"]\n",
    "\n",
    "# Best-after-selection across thresholds\n",
    "df[\"Steer_max_sel\"] = df[steer_cols].max(axis=1)\n",
    "df[\"Best_threshold\"] = df[steer_cols].idxmax(axis=1).str.replace(\"Steer_\", \"\").str.replace(\"_\",\"\")\n",
    "df[\"pct_best\"] = 100.0 * (df[\"Steer_max_sel\"] - df[\"Steering\"]) / df[\"Steering\"]\n",
    "\n",
    "# ===========================\n",
    "# 4) Per-threshold counts (improved / declined / tied)\n",
    "# ===========================\n",
    "def counts_for_threshold(col: str) -> Dict[str, int]:\n",
    "    delta = df[col] - df[\"Steering\"]\n",
    "    return {\n",
    "        \"threshold\": col.replace(\"Steer_\", \"\").replace(\"_\",\"\"),\n",
    "        \"improved\": int((delta > 0).sum()),\n",
    "        \"declined\": int((delta < 0).sum()),\n",
    "        \"tied\": int((delta == 0).sum()),\n",
    "    }\n",
    "\n",
    "thresh_counts = pd.DataFrame([counts_for_threshold(c) for c in steer_cols])\n",
    "order = [\"0.1\",\"0.01\",\"0.001\",\"0.0001\"]\n",
    "thresh_counts[\"threshold\"] = pd.Categorical(thresh_counts[\"threshold\"], categories=order, ordered=True)\n",
    "thresh_counts = thresh_counts.sort_values(\"threshold\").reset_index(drop=True)\n",
    "\n",
    "# ===========================\n",
    "# 5) Figures\n",
    "# ===========================\n",
    "\n",
    "# (A) Distribution of percent improvements (best) — equal bin widths on both sides\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "data = df[\"pct_best\"].to_numpy()\n",
    "data = data[np.isfinite(data)]\n",
    "pos = data[data > 0]\n",
    "neg = data[data < 0]\n",
    "ties = int(np.sum(data == 0))\n",
    "\n",
    "# Symmetric x-limit using a robust cap\n",
    "if data.size > 0:\n",
    "    cap = float(np.percentile(np.abs(data), 100))\n",
    "else:\n",
    "    cap = 1.0\n",
    "cap = max(cap, 1.0)\n",
    "\n",
    "# Single global FD bin width from the WHOLE distribution (in % units)\n",
    "fallback_width = cap / 10.0  # sensible default if IQR=0 or n<2\n",
    "h0 = fd_bin_width(data, fallback_width)\n",
    "\n",
    "# Derive a single bin count and enforce symmetry; recompute a uniform width\n",
    "n_bins = int(np.ceil(cap / h0))\n",
    "n_bins = max(8, min(60, n_bins))\n",
    "width = cap / n_bins  # final uniform width used on both sides\n",
    "\n",
    "# Build mirrored edges so that 0 is an exact edge\n",
    "edges_neg = np.linspace(-cap, 0.0, n_bins + 1)\n",
    "edges_pos = np.linspace(0.0,  cap,  n_bins + 1)\n",
    "\n",
    "# Plot negative (left) and positive (right) with identical widths\n",
    "if neg.size > 0:\n",
    "    ax.hist(neg, bins=edges_neg, color=OI[\"orange\"], edgecolor=OI[\"black\"], alpha=0.85,\n",
    "            label=\"Negative (decline)\")\n",
    "if pos.size > 0:\n",
    "    ax.hist(pos, bins=edges_pos, color=OI[\"green\"], edgecolor=OI[\"black\"], alpha=0.85,\n",
    "            label=\"Positive (improvement)\")\n",
    "\n",
    "# Zero line and tie annotation\n",
    "ax.axvline(0.0, color=OI[\"grey\"], linewidth=1.5, linestyle=\"--\")\n",
    "if ties > 0:\n",
    "    ax.text(0.98, 0.90, f\"Ties: {ties}\", transform=ax.transAxes, ha=\"right\", va=\"top\", color=OI[\"grey\"])\n",
    "\n",
    "# Set symmetric x-limits and finalize\n",
    "ax.set_xlim(-cap, cap)\n",
    "ax.set_xlabel(\"Percent improvement in steering (%)\")\n",
    "ax.set_ylabel(\"Count of models\")\n",
    "ax.set_title(\"Distribution of percent improvements (best selection vs baseline)\")\n",
    "ax.legend(loc=\"upper left\")\n",
    "ax.text(0.99, 0.97, f\"n={len(data)}; bin width≈{width:.1f}%\", transform=ax.transAxes,\n",
    "        ha=\"right\", va=\"top\", color=OI[\"grey\"])\n",
    "plt.tight_layout()\n",
    "\n",
    "# (B) Percent improvement by architecture (mean ± bootstrap CI)\n",
    "arch_means = df.groupby(\"arch\")[\"pct_best\"].mean().reset_index()\n",
    "# Bootstrap error bars\n",
    "err_low, err_high = [], []\n",
    "for arch, sub in df.groupby(\"arch\"):\n",
    "    low, high = bootstrap_ci_mean(sub[\"pct_best\"].to_numpy())\n",
    "    mean_val = float(arch_means.loc[arch_means[\"arch\"] == arch, \"pct_best\"])\n",
    "    err_low.append(mean_val - low)\n",
    "    err_high.append(high - mean_val)\n",
    "arch_means[\"err_low\"] = err_low\n",
    "arch_means[\"err_high\"] = err_high\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "x = np.arange(len(arch_means))\n",
    "bar_colors = [OI[\"blue\"], OI[\"orange\"], OI[\"green\"], OI[\"purple\"], OI[\"cyan\"]][:len(arch_means)]\n",
    "ax.bar(x, arch_means[\"pct_best\"], color=bar_colors, alpha=0.95)\n",
    "ax.errorbar(x, arch_means[\"pct_best\"], yerr=[arch_means[\"err_low\"], arch_means[\"err_high\"]],\n",
    "            fmt='none', ecolor=OI[\"black\"], elinewidth=1.2, capsize=3)\n",
    "ax.set_xticks(x, arch_means[\"arch\"], rotation=15)\n",
    "ax.set_ylabel(\"Percent improvement (%)\")\n",
    "ax.set_title(\"Percent improvement by architecture (mean ± bootstrap CI)\")\n",
    "plt.tight_layout()\n",
    "\n",
    "# (C) Stacked bar: improved / declined per threshold\n",
    "fig, ax = plt.subplots()\n",
    "W = 0.65\n",
    "xx = np.arange(len(thresh_counts))\n",
    "improved = thresh_counts[\"improved\"].to_numpy()\n",
    "declined = thresh_counts[\"declined\"].to_numpy()\n",
    "\n",
    "\n",
    "ax.bar(xx, improved, width=W, color=OI[\"green\"], label=\"Improved\")\n",
    "ax.bar(xx, declined, width=W, bottom=improved, color=OI[\"orange\"], label=\"Declined\")\n",
    "\n",
    "\n",
    "# annotate counts\n",
    "for i in range(len(xx)):\n",
    "    ax.text(xx[i], improved[i]/2, str(improved[i]), ha=\"center\", va=\"center\", color=\"white\", fontsize=11)\n",
    "    ax.text(xx[i], improved[i] + declined[i]/2, str(declined[i]), ha=\"center\", va=\"center\", color=\"white\", fontsize=11)\n",
    "\n",
    "ax.set_xticks(xx, thresh_counts[\"threshold\"])\n",
    "ax.set_ylabel(\"Number of models\")\n",
    "ax.set_title(\"Improved vs Declined by threshold\")\n",
    "ax.legend(loc=\"lower left\", bbox_to_anchor=(1.02, 0.0))\n",
    "plt.tight_layout()\n",
    "\n",
    "# ===========================\n",
    "# 6) Print top/bottom 10 by percent improvement (best)\n",
    "# ===========================\n",
    "top = df.sort_values(\"pct_best\", ascending=False)[\n",
    "    [\"SAEs\",\"Steering\",\"Steer_max_sel\",\"Best_threshold\",\"pct_best\"]].head(10)\n",
    "bot = df.sort_values(\"pct_best\", ascending=True)[\n",
    "    [\"SAEs\",\"Steering\",\"Steer_max_sel\",\"Best_threshold\",\"pct_best\"]].head(10)\n",
    "\n",
    "print(\"\\nPer-threshold counts (Improved / Declined / Tied):\")\n",
    "print(thresh_counts.to_string(index=False))\n",
    "\n",
    "print(\"\\nTop 10 percent improvements:\")\n",
    "print(top.to_string(index=False))\n",
    "\n",
    "print(\"\\nWorst 10 percent improvements:\")\n",
    "print(bot.to_string(index=False))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "286db87d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Final Table (with MEAN row at bottom) ===\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>SAEs</th>\n",
       "      <th>Interp</th>\n",
       "      <th>Absorb</th>\n",
       "      <th>Loss Recovered</th>\n",
       "      <th>SCR@20</th>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <th>RAVEL</th>\n",
       "      <th>TPP@20</th>\n",
       "      <th>SAE score</th>\n",
       "      <th>Prompt score</th>\n",
       "      <th>SAE filter@0.1</th>\n",
       "      <th>SAE filter@0.01</th>\n",
       "      <th>SAE filter@0.001</th>\n",
       "      <th>SAE filter@0.0001</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>batch_topk_50</td>\n",
       "      <td>0.83690</td>\n",
       "      <td>0.245500</td>\n",
       "      <td>0.944000</td>\n",
       "      <td>0.110500</td>\n",
       "      <td>0.722900</td>\n",
       "      <td>0.611700</td>\n",
       "      <td>0.032500</td>\n",
       "      <td>0.151000</td>\n",
       "      <td>0.694000</td>\n",
       "      <td>0.1920</td>\n",
       "      <td>0.1980</td>\n",
       "      <td>0.163000</td>\n",
       "      <td>0.154000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>batch_topk_80</td>\n",
       "      <td>0.82270</td>\n",
       "      <td>0.144200</td>\n",
       "      <td>0.958800</td>\n",
       "      <td>0.130800</td>\n",
       "      <td>0.726200</td>\n",
       "      <td>0.657100</td>\n",
       "      <td>0.039100</td>\n",
       "      <td>0.156000</td>\n",
       "      <td>0.708000</td>\n",
       "      <td>0.1480</td>\n",
       "      <td>0.1500</td>\n",
       "      <td>0.165000</td>\n",
       "      <td>0.158000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>batch_topk_160</td>\n",
       "      <td>0.81170</td>\n",
       "      <td>0.052000</td>\n",
       "      <td>0.973600</td>\n",
       "      <td>0.168900</td>\n",
       "      <td>0.725100</td>\n",
       "      <td>0.700900</td>\n",
       "      <td>0.120400</td>\n",
       "      <td>0.145000</td>\n",
       "      <td>0.661000</td>\n",
       "      <td>0.1200</td>\n",
       "      <td>0.2100</td>\n",
       "      <td>0.126000</td>\n",
       "      <td>0.079000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>batch_topk_320</td>\n",
       "      <td>0.81420</td>\n",
       "      <td>0.083800</td>\n",
       "      <td>0.983500</td>\n",
       "      <td>0.089700</td>\n",
       "      <td>0.715900</td>\n",
       "      <td>0.721400</td>\n",
       "      <td>0.158000</td>\n",
       "      <td>0.122000</td>\n",
       "      <td>0.719000</td>\n",
       "      <td>0.2000</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.215000</td>\n",
       "      <td>0.146000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>batch_topk_520</td>\n",
       "      <td>0.80230</td>\n",
       "      <td>0.094900</td>\n",
       "      <td>0.985200</td>\n",
       "      <td>0.132000</td>\n",
       "      <td>0.752800</td>\n",
       "      <td>0.721100</td>\n",
       "      <td>0.316000</td>\n",
       "      <td>0.117000</td>\n",
       "      <td>0.811000</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.1870</td>\n",
       "      <td>0.153000</td>\n",
       "      <td>0.113000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>batch_topk_820</td>\n",
       "      <td>0.79140</td>\n",
       "      <td>0.130900</td>\n",
       "      <td>0.985200</td>\n",
       "      <td>0.118000</td>\n",
       "      <td>0.765600</td>\n",
       "      <td>0.722900</td>\n",
       "      <td>0.344800</td>\n",
       "      <td>0.106000</td>\n",
       "      <td>0.727000</td>\n",
       "      <td>0.3400</td>\n",
       "      <td>0.3180</td>\n",
       "      <td>0.233000</td>\n",
       "      <td>0.224000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>gated_49</td>\n",
       "      <td>0.81520</td>\n",
       "      <td>0.451700</td>\n",
       "      <td>0.940700</td>\n",
       "      <td>0.112400</td>\n",
       "      <td>0.734100</td>\n",
       "      <td>0.607100</td>\n",
       "      <td>0.023500</td>\n",
       "      <td>0.106000</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>0.5400</td>\n",
       "      <td>0.2130</td>\n",
       "      <td>0.142000</td>\n",
       "      <td>0.128000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>gated_78</td>\n",
       "      <td>0.80860</td>\n",
       "      <td>0.413400</td>\n",
       "      <td>0.957200</td>\n",
       "      <td>0.130100</td>\n",
       "      <td>0.756200</td>\n",
       "      <td>0.633400</td>\n",
       "      <td>0.030600</td>\n",
       "      <td>0.089000</td>\n",
       "      <td>0.663000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.053000</td>\n",
       "      <td>0.068000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>gated_148</td>\n",
       "      <td>0.79390</td>\n",
       "      <td>0.218200</td>\n",
       "      <td>0.973600</td>\n",
       "      <td>0.156700</td>\n",
       "      <td>0.759100</td>\n",
       "      <td>0.689100</td>\n",
       "      <td>0.052000</td>\n",
       "      <td>0.116000</td>\n",
       "      <td>0.668000</td>\n",
       "      <td>0.1800</td>\n",
       "      <td>0.1030</td>\n",
       "      <td>0.144000</td>\n",
       "      <td>0.104000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>gated_340</td>\n",
       "      <td>0.77460</td>\n",
       "      <td>0.125600</td>\n",
       "      <td>0.986800</td>\n",
       "      <td>0.149100</td>\n",
       "      <td>0.705100</td>\n",
       "      <td>0.733700</td>\n",
       "      <td>0.060400</td>\n",
       "      <td>0.153000</td>\n",
       "      <td>0.728000</td>\n",
       "      <td>0.1600</td>\n",
       "      <td>0.0960</td>\n",
       "      <td>0.200000</td>\n",
       "      <td>0.133000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>gated_547</td>\n",
       "      <td>0.76450</td>\n",
       "      <td>0.116800</td>\n",
       "      <td>0.991800</td>\n",
       "      <td>0.136300</td>\n",
       "      <td>0.712700</td>\n",
       "      <td>0.754400</td>\n",
       "      <td>0.074500</td>\n",
       "      <td>0.134000</td>\n",
       "      <td>0.699000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0960</td>\n",
       "      <td>0.147000</td>\n",
       "      <td>0.173000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>gated_948</td>\n",
       "      <td>0.75360</td>\n",
       "      <td>0.100700</td>\n",
       "      <td>0.996700</td>\n",
       "      <td>0.093400</td>\n",
       "      <td>0.676400</td>\n",
       "      <td>0.771400</td>\n",
       "      <td>0.099400</td>\n",
       "      <td>0.103000</td>\n",
       "      <td>0.802000</td>\n",
       "      <td>0.1200</td>\n",
       "      <td>0.1200</td>\n",
       "      <td>0.048000</td>\n",
       "      <td>0.158000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>jumprelu_52</td>\n",
       "      <td>0.82810</td>\n",
       "      <td>0.255800</td>\n",
       "      <td>0.945600</td>\n",
       "      <td>0.150400</td>\n",
       "      <td>0.723700</td>\n",
       "      <td>0.612700</td>\n",
       "      <td>0.028700</td>\n",
       "      <td>0.176000</td>\n",
       "      <td>0.678000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1910</td>\n",
       "      <td>0.271000</td>\n",
       "      <td>0.234000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>jumprelu_83</td>\n",
       "      <td>0.81190</td>\n",
       "      <td>0.176700</td>\n",
       "      <td>0.958800</td>\n",
       "      <td>0.142300</td>\n",
       "      <td>0.696400</td>\n",
       "      <td>0.659600</td>\n",
       "      <td>0.049200</td>\n",
       "      <td>0.179000</td>\n",
       "      <td>0.674000</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.3550</td>\n",
       "      <td>0.353000</td>\n",
       "      <td>0.268000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>jumprelu_165</td>\n",
       "      <td>0.79960</td>\n",
       "      <td>0.078700</td>\n",
       "      <td>0.976900</td>\n",
       "      <td>0.159500</td>\n",
       "      <td>0.734900</td>\n",
       "      <td>0.710900</td>\n",
       "      <td>0.066900</td>\n",
       "      <td>0.120000</td>\n",
       "      <td>0.736000</td>\n",
       "      <td>0.1700</td>\n",
       "      <td>0.1310</td>\n",
       "      <td>0.140000</td>\n",
       "      <td>0.164000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>jumprelu_330</td>\n",
       "      <td>0.78870</td>\n",
       "      <td>0.021000</td>\n",
       "      <td>0.985200</td>\n",
       "      <td>0.141200</td>\n",
       "      <td>0.720600</td>\n",
       "      <td>0.735000</td>\n",
       "      <td>0.070900</td>\n",
       "      <td>0.105000</td>\n",
       "      <td>0.726000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1000</td>\n",
       "      <td>0.194000</td>\n",
       "      <td>0.156000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>jumprelu_538</td>\n",
       "      <td>0.80480</td>\n",
       "      <td>0.065600</td>\n",
       "      <td>0.991800</td>\n",
       "      <td>0.135900</td>\n",
       "      <td>0.736500</td>\n",
       "      <td>0.740300</td>\n",
       "      <td>0.094800</td>\n",
       "      <td>0.089000</td>\n",
       "      <td>0.746000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.016000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>jumprelu_779</td>\n",
       "      <td>0.79550</td>\n",
       "      <td>0.023200</td>\n",
       "      <td>0.993400</td>\n",
       "      <td>0.151100</td>\n",
       "      <td>0.764700</td>\n",
       "      <td>0.739100</td>\n",
       "      <td>0.122100</td>\n",
       "      <td>0.119000</td>\n",
       "      <td>0.720000</td>\n",
       "      <td>0.1400</td>\n",
       "      <td>0.1210</td>\n",
       "      <td>0.118000</td>\n",
       "      <td>0.118000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>relu_54</td>\n",
       "      <td>0.83260</td>\n",
       "      <td>0.278900</td>\n",
       "      <td>0.840200</td>\n",
       "      <td>0.066200</td>\n",
       "      <td>0.736000</td>\n",
       "      <td>0.443400</td>\n",
       "      <td>0.006500</td>\n",
       "      <td>0.150000</td>\n",
       "      <td>0.745000</td>\n",
       "      <td>0.1210</td>\n",
       "      <td>0.1900</td>\n",
       "      <td>0.227000</td>\n",
       "      <td>0.234000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>relu_99</td>\n",
       "      <td>0.81440</td>\n",
       "      <td>0.280100</td>\n",
       "      <td>0.889600</td>\n",
       "      <td>0.069400</td>\n",
       "      <td>0.770800</td>\n",
       "      <td>0.496700</td>\n",
       "      <td>0.011800</td>\n",
       "      <td>0.110000</td>\n",
       "      <td>0.724000</td>\n",
       "      <td>0.0600</td>\n",
       "      <td>0.1010</td>\n",
       "      <td>0.077000</td>\n",
       "      <td>0.081000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>relu_156</td>\n",
       "      <td>0.80030</td>\n",
       "      <td>0.246700</td>\n",
       "      <td>0.916000</td>\n",
       "      <td>0.085400</td>\n",
       "      <td>0.771100</td>\n",
       "      <td>0.574700</td>\n",
       "      <td>0.017800</td>\n",
       "      <td>0.181000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.1370</td>\n",
       "      <td>0.1500</td>\n",
       "      <td>0.169000</td>\n",
       "      <td>0.168000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>relu_309</td>\n",
       "      <td>0.78960</td>\n",
       "      <td>0.220100</td>\n",
       "      <td>0.947300</td>\n",
       "      <td>0.098800</td>\n",
       "      <td>0.768600</td>\n",
       "      <td>0.652000</td>\n",
       "      <td>0.017100</td>\n",
       "      <td>0.131000</td>\n",
       "      <td>0.748000</td>\n",
       "      <td>0.3060</td>\n",
       "      <td>0.3160</td>\n",
       "      <td>0.226000</td>\n",
       "      <td>0.192000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>relu_507</td>\n",
       "      <td>0.77540</td>\n",
       "      <td>0.237000</td>\n",
       "      <td>0.963800</td>\n",
       "      <td>0.113900</td>\n",
       "      <td>0.793900</td>\n",
       "      <td>0.699900</td>\n",
       "      <td>0.023500</td>\n",
       "      <td>0.140000</td>\n",
       "      <td>0.732000</td>\n",
       "      <td>0.0680</td>\n",
       "      <td>0.1600</td>\n",
       "      <td>0.189000</td>\n",
       "      <td>0.200000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>relu_733</td>\n",
       "      <td>0.76440</td>\n",
       "      <td>0.182200</td>\n",
       "      <td>0.975300</td>\n",
       "      <td>0.114300</td>\n",
       "      <td>0.774200</td>\n",
       "      <td>0.717600</td>\n",
       "      <td>0.035300</td>\n",
       "      <td>0.141000</td>\n",
       "      <td>0.737000</td>\n",
       "      <td>0.1280</td>\n",
       "      <td>0.2190</td>\n",
       "      <td>0.161000</td>\n",
       "      <td>0.156000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>topk_50</td>\n",
       "      <td>0.83360</td>\n",
       "      <td>0.298400</td>\n",
       "      <td>0.934100</td>\n",
       "      <td>0.117400</td>\n",
       "      <td>0.722700</td>\n",
       "      <td>0.568200</td>\n",
       "      <td>0.023800</td>\n",
       "      <td>0.197000</td>\n",
       "      <td>0.761000</td>\n",
       "      <td>0.2360</td>\n",
       "      <td>0.2420</td>\n",
       "      <td>0.232000</td>\n",
       "      <td>0.214000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>topk_80</td>\n",
       "      <td>0.82150</td>\n",
       "      <td>0.193500</td>\n",
       "      <td>0.948900</td>\n",
       "      <td>0.130500</td>\n",
       "      <td>0.713600</td>\n",
       "      <td>0.610700</td>\n",
       "      <td>0.033700</td>\n",
       "      <td>0.149000</td>\n",
       "      <td>0.723000</td>\n",
       "      <td>0.1660</td>\n",
       "      <td>0.1470</td>\n",
       "      <td>0.147000</td>\n",
       "      <td>0.143000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>topk_160</td>\n",
       "      <td>0.81240</td>\n",
       "      <td>0.088400</td>\n",
       "      <td>0.968700</td>\n",
       "      <td>0.127400</td>\n",
       "      <td>0.711400</td>\n",
       "      <td>0.663600</td>\n",
       "      <td>0.093200</td>\n",
       "      <td>0.152000</td>\n",
       "      <td>0.743000</td>\n",
       "      <td>0.0600</td>\n",
       "      <td>0.1370</td>\n",
       "      <td>0.128000</td>\n",
       "      <td>0.154000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>topk_320</td>\n",
       "      <td>0.80620</td>\n",
       "      <td>0.061300</td>\n",
       "      <td>0.980200</td>\n",
       "      <td>0.166200</td>\n",
       "      <td>0.711500</td>\n",
       "      <td>0.696000</td>\n",
       "      <td>0.152700</td>\n",
       "      <td>0.113000</td>\n",
       "      <td>0.733000</td>\n",
       "      <td>0.3200</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.160000</td>\n",
       "      <td>0.124000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>topk_520</td>\n",
       "      <td>0.82260</td>\n",
       "      <td>0.029000</td>\n",
       "      <td>0.986800</td>\n",
       "      <td>0.120400</td>\n",
       "      <td>0.722900</td>\n",
       "      <td>0.714500</td>\n",
       "      <td>0.303200</td>\n",
       "      <td>0.134000</td>\n",
       "      <td>0.705000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1800</td>\n",
       "      <td>0.300000</td>\n",
       "      <td>0.296000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>topk_820</td>\n",
       "      <td>0.81500</td>\n",
       "      <td>0.141100</td>\n",
       "      <td>0.991800</td>\n",
       "      <td>0.111000</td>\n",
       "      <td>0.766600</td>\n",
       "      <td>0.708900</td>\n",
       "      <td>0.322600</td>\n",
       "      <td>0.105000</td>\n",
       "      <td>0.751000</td>\n",
       "      <td>0.2700</td>\n",
       "      <td>0.3120</td>\n",
       "      <td>0.160000</td>\n",
       "      <td>0.074000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>MEAN</td>\n",
       "      <td>0.80354</td>\n",
       "      <td>0.168513</td>\n",
       "      <td>0.962383</td>\n",
       "      <td>0.124307</td>\n",
       "      <td>0.736407</td>\n",
       "      <td>0.668933</td>\n",
       "      <td>0.094167</td>\n",
       "      <td>0.132967</td>\n",
       "      <td>0.727067</td>\n",
       "      <td>0.1554</td>\n",
       "      <td>0.1741</td>\n",
       "      <td>0.168033</td>\n",
       "      <td>0.154333</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              SAEs   Interp    Absorb  Loss Recovered    SCR@20  \\\n",
       "0    batch_topk_50  0.83690  0.245500        0.944000  0.110500   \n",
       "1    batch_topk_80  0.82270  0.144200        0.958800  0.130800   \n",
       "2   batch_topk_160  0.81170  0.052000        0.973600  0.168900   \n",
       "3   batch_topk_320  0.81420  0.083800        0.983500  0.089700   \n",
       "4   batch_topk_520  0.80230  0.094900        0.985200  0.132000   \n",
       "5   batch_topk_820  0.79140  0.130900        0.985200  0.118000   \n",
       "6         gated_49  0.81520  0.451700        0.940700  0.112400   \n",
       "7         gated_78  0.80860  0.413400        0.957200  0.130100   \n",
       "8        gated_148  0.79390  0.218200        0.973600  0.156700   \n",
       "9        gated_340  0.77460  0.125600        0.986800  0.149100   \n",
       "10       gated_547  0.76450  0.116800        0.991800  0.136300   \n",
       "11       gated_948  0.75360  0.100700        0.996700  0.093400   \n",
       "12     jumprelu_52  0.82810  0.255800        0.945600  0.150400   \n",
       "13     jumprelu_83  0.81190  0.176700        0.958800  0.142300   \n",
       "14    jumprelu_165  0.79960  0.078700        0.976900  0.159500   \n",
       "15    jumprelu_330  0.78870  0.021000        0.985200  0.141200   \n",
       "16    jumprelu_538  0.80480  0.065600        0.991800  0.135900   \n",
       "17    jumprelu_779  0.79550  0.023200        0.993400  0.151100   \n",
       "18         relu_54  0.83260  0.278900        0.840200  0.066200   \n",
       "19         relu_99  0.81440  0.280100        0.889600  0.069400   \n",
       "20        relu_156  0.80030  0.246700        0.916000  0.085400   \n",
       "21        relu_309  0.78960  0.220100        0.947300  0.098800   \n",
       "22        relu_507  0.77540  0.237000        0.963800  0.113900   \n",
       "23        relu_733  0.76440  0.182200        0.975300  0.114300   \n",
       "24         topk_50  0.83360  0.298400        0.934100  0.117400   \n",
       "25         topk_80  0.82150  0.193500        0.948900  0.130500   \n",
       "26        topk_160  0.81240  0.088400        0.968700  0.127400   \n",
       "27        topk_320  0.80620  0.061300        0.980200  0.166200   \n",
       "28        topk_520  0.82260  0.029000        0.986800  0.120400   \n",
       "29        topk_820  0.81500  0.141100        0.991800  0.111000   \n",
       "30            MEAN  0.80354  0.168513        0.962383  0.124307   \n",
       "\n",
       "    Sparse Probing Top1     RAVEL    TPP@20  SAE score  Prompt score  \\\n",
       "0              0.722900  0.611700  0.032500   0.151000      0.694000   \n",
       "1              0.726200  0.657100  0.039100   0.156000      0.708000   \n",
       "2              0.725100  0.700900  0.120400   0.145000      0.661000   \n",
       "3              0.715900  0.721400  0.158000   0.122000      0.719000   \n",
       "4              0.752800  0.721100  0.316000   0.117000      0.811000   \n",
       "5              0.765600  0.722900  0.344800   0.106000      0.727000   \n",
       "6              0.734100  0.607100  0.023500   0.106000      0.800000   \n",
       "7              0.756200  0.633400  0.030600   0.089000      0.663000   \n",
       "8              0.759100  0.689100  0.052000   0.116000      0.668000   \n",
       "9              0.705100  0.733700  0.060400   0.153000      0.728000   \n",
       "10             0.712700  0.754400  0.074500   0.134000      0.699000   \n",
       "11             0.676400  0.771400  0.099400   0.103000      0.802000   \n",
       "12             0.723700  0.612700  0.028700   0.176000      0.678000   \n",
       "13             0.696400  0.659600  0.049200   0.179000      0.674000   \n",
       "14             0.734900  0.710900  0.066900   0.120000      0.736000   \n",
       "15             0.720600  0.735000  0.070900   0.105000      0.726000   \n",
       "16             0.736500  0.740300  0.094800   0.089000      0.746000   \n",
       "17             0.764700  0.739100  0.122100   0.119000      0.720000   \n",
       "18             0.736000  0.443400  0.006500   0.150000      0.745000   \n",
       "19             0.770800  0.496700  0.011800   0.110000      0.724000   \n",
       "20             0.771100  0.574700  0.017800   0.181000      0.750000   \n",
       "21             0.768600  0.652000  0.017100   0.131000      0.748000   \n",
       "22             0.793900  0.699900  0.023500   0.140000      0.732000   \n",
       "23             0.774200  0.717600  0.035300   0.141000      0.737000   \n",
       "24             0.722700  0.568200  0.023800   0.197000      0.761000   \n",
       "25             0.713600  0.610700  0.033700   0.149000      0.723000   \n",
       "26             0.711400  0.663600  0.093200   0.152000      0.743000   \n",
       "27             0.711500  0.696000  0.152700   0.113000      0.733000   \n",
       "28             0.722900  0.714500  0.303200   0.134000      0.705000   \n",
       "29             0.766600  0.708900  0.322600   0.105000      0.751000   \n",
       "30             0.736407  0.668933  0.094167   0.132967      0.727067   \n",
       "\n",
       "    SAE filter@0.1  SAE filter@0.01  SAE filter@0.001  SAE filter@0.0001  \n",
       "0           0.1920           0.1980          0.163000           0.154000  \n",
       "1           0.1480           0.1500          0.165000           0.158000  \n",
       "2           0.1200           0.2100          0.126000           0.079000  \n",
       "3           0.2000           0.2400          0.215000           0.146000  \n",
       "4           0.2400           0.1870          0.153000           0.113000  \n",
       "5           0.3400           0.3180          0.233000           0.224000  \n",
       "6           0.5400           0.2130          0.142000           0.128000  \n",
       "7           0.0000           0.0000          0.053000           0.068000  \n",
       "8           0.1800           0.1030          0.144000           0.104000  \n",
       "9           0.1600           0.0960          0.200000           0.133000  \n",
       "10          0.0000           0.0960          0.147000           0.173000  \n",
       "11          0.1200           0.1200          0.048000           0.158000  \n",
       "12          0.0000           0.1910          0.271000           0.234000  \n",
       "13          0.2400           0.3550          0.353000           0.268000  \n",
       "14          0.1700           0.1310          0.140000           0.164000  \n",
       "15          0.0000           0.1000          0.194000           0.156000  \n",
       "16          0.0000           0.0000          0.000000           0.016000  \n",
       "17          0.1400           0.1210          0.118000           0.118000  \n",
       "18          0.1210           0.1900          0.227000           0.234000  \n",
       "19          0.0600           0.1010          0.077000           0.081000  \n",
       "20          0.1370           0.1500          0.169000           0.168000  \n",
       "21          0.3060           0.3160          0.226000           0.192000  \n",
       "22          0.0680           0.1600          0.189000           0.200000  \n",
       "23          0.1280           0.2190          0.161000           0.156000  \n",
       "24          0.2360           0.2420          0.232000           0.214000  \n",
       "25          0.1660           0.1470          0.147000           0.143000  \n",
       "26          0.0600           0.1370          0.128000           0.154000  \n",
       "27          0.3200           0.2400          0.160000           0.124000  \n",
       "28          0.0000           0.1800          0.300000           0.296000  \n",
       "29          0.2700           0.3120          0.160000           0.074000  \n",
       "30          0.1554           0.1741          0.168033           0.154333  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Pearson Correlation (linear) ===\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Interp</th>\n",
       "      <th>Absorb</th>\n",
       "      <th>Loss Recovered</th>\n",
       "      <th>SCR@20</th>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <th>RAVEL</th>\n",
       "      <th>TPP@20</th>\n",
       "      <th>SAE score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Interp</th>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.2751</td>\n",
       "      <td>-0.4931</td>\n",
       "      <td>-0.0873</td>\n",
       "      <td>-0.0938</td>\n",
       "      <td>-0.6305</td>\n",
       "      <td>-0.0134</td>\n",
       "      <td>0.3173</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Absorb</th>\n",
       "      <td>0.2751</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.6347</td>\n",
       "      <td>-0.4051</td>\n",
       "      <td>0.2832</td>\n",
       "      <td>-0.6866</td>\n",
       "      <td>-0.5190</td>\n",
       "      <td>0.1569</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Loss Recovered</th>\n",
       "      <td>-0.4931</td>\n",
       "      <td>-0.6347</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.5926</td>\n",
       "      <td>-0.1846</td>\n",
       "      <td>0.9694</td>\n",
       "      <td>0.5226</td>\n",
       "      <td>-0.3765</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SCR@20</th>\n",
       "      <td>-0.0873</td>\n",
       "      <td>-0.4051</td>\n",
       "      <td>0.5926</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.2439</td>\n",
       "      <td>0.5271</td>\n",
       "      <td>0.1159</td>\n",
       "      <td>-0.0231</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <td>-0.0938</td>\n",
       "      <td>0.2832</td>\n",
       "      <td>-0.1846</td>\n",
       "      <td>-0.2439</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.1584</td>\n",
       "      <td>0.0566</td>\n",
       "      <td>-0.1964</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RAVEL</th>\n",
       "      <td>-0.6305</td>\n",
       "      <td>-0.6866</td>\n",
       "      <td>0.9694</td>\n",
       "      <td>0.5271</td>\n",
       "      <td>-0.1584</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.4861</td>\n",
       "      <td>-0.3999</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TPP@20</th>\n",
       "      <td>-0.0134</td>\n",
       "      <td>-0.5190</td>\n",
       "      <td>0.5226</td>\n",
       "      <td>0.1159</td>\n",
       "      <td>0.0566</td>\n",
       "      <td>0.4861</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.3696</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SAE score</th>\n",
       "      <td>0.3173</td>\n",
       "      <td>0.1569</td>\n",
       "      <td>-0.3765</td>\n",
       "      <td>-0.0231</td>\n",
       "      <td>-0.1964</td>\n",
       "      <td>-0.3999</td>\n",
       "      <td>-0.3696</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                     Interp  Absorb  Loss Recovered  SCR@20  \\\n",
       "Interp               1.0000  0.2751         -0.4931 -0.0873   \n",
       "Absorb               0.2751  1.0000         -0.6347 -0.4051   \n",
       "Loss Recovered      -0.4931 -0.6347          1.0000  0.5926   \n",
       "SCR@20              -0.0873 -0.4051          0.5926  1.0000   \n",
       "Sparse Probing Top1 -0.0938  0.2832         -0.1846 -0.2439   \n",
       "RAVEL               -0.6305 -0.6866          0.9694  0.5271   \n",
       "TPP@20              -0.0134 -0.5190          0.5226  0.1159   \n",
       "SAE score            0.3173  0.1569         -0.3765 -0.0231   \n",
       "\n",
       "                     Sparse Probing Top1   RAVEL  TPP@20  SAE score  \n",
       "Interp                           -0.0938 -0.6305 -0.0134     0.3173  \n",
       "Absorb                            0.2832 -0.6866 -0.5190     0.1569  \n",
       "Loss Recovered                   -0.1846  0.9694  0.5226    -0.3765  \n",
       "SCR@20                           -0.2439  0.5271  0.1159    -0.0231  \n",
       "Sparse Probing Top1               1.0000 -0.1584  0.0566    -0.1964  \n",
       "RAVEL                            -0.1584  1.0000  0.4861    -0.3999  \n",
       "TPP@20                            0.0566  0.4861  1.0000    -0.3696  \n",
       "SAE score                        -0.1964 -0.3999 -0.3696     1.0000  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Spearman Correlation (rank) ===\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Interp</th>\n",
       "      <th>Absorb</th>\n",
       "      <th>Loss Recovered</th>\n",
       "      <th>SCR@20</th>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <th>RAVEL</th>\n",
       "      <th>TPP@20</th>\n",
       "      <th>SAE score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Interp</th>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.3402</td>\n",
       "      <td>-0.5502</td>\n",
       "      <td>-0.1902</td>\n",
       "      <td>-0.1433</td>\n",
       "      <td>-0.6739</td>\n",
       "      <td>-0.2152</td>\n",
       "      <td>0.3450</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Absorb</th>\n",
       "      <td>0.3402</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.7930</td>\n",
       "      <td>-0.5066</td>\n",
       "      <td>0.3255</td>\n",
       "      <td>-0.7775</td>\n",
       "      <td>-0.8074</td>\n",
       "      <td>0.2486</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Loss Recovered</th>\n",
       "      <td>-0.5502</td>\n",
       "      <td>-0.7930</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.3744</td>\n",
       "      <td>-0.2088</td>\n",
       "      <td>0.9542</td>\n",
       "      <td>0.8441</td>\n",
       "      <td>-0.4763</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SCR@20</th>\n",
       "      <td>-0.1902</td>\n",
       "      <td>-0.5066</td>\n",
       "      <td>0.3744</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.3013</td>\n",
       "      <td>0.3557</td>\n",
       "      <td>0.3871</td>\n",
       "      <td>0.0080</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <td>-0.1433</td>\n",
       "      <td>0.3255</td>\n",
       "      <td>-0.2088</td>\n",
       "      <td>-0.3013</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.1860</td>\n",
       "      <td>-0.2670</td>\n",
       "      <td>-0.2156</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RAVEL</th>\n",
       "      <td>-0.6739</td>\n",
       "      <td>-0.7775</td>\n",
       "      <td>0.9542</td>\n",
       "      <td>0.3557</td>\n",
       "      <td>-0.1860</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.7538</td>\n",
       "      <td>-0.4336</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TPP@20</th>\n",
       "      <td>-0.2152</td>\n",
       "      <td>-0.8074</td>\n",
       "      <td>0.8441</td>\n",
       "      <td>0.3871</td>\n",
       "      <td>-0.2670</td>\n",
       "      <td>0.7538</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.3812</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SAE score</th>\n",
       "      <td>0.3450</td>\n",
       "      <td>0.2486</td>\n",
       "      <td>-0.4763</td>\n",
       "      <td>0.0080</td>\n",
       "      <td>-0.2156</td>\n",
       "      <td>-0.4336</td>\n",
       "      <td>-0.3812</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                     Interp  Absorb  Loss Recovered  SCR@20  \\\n",
       "Interp               1.0000  0.3402         -0.5502 -0.1902   \n",
       "Absorb               0.3402  1.0000         -0.7930 -0.5066   \n",
       "Loss Recovered      -0.5502 -0.7930          1.0000  0.3744   \n",
       "SCR@20              -0.1902 -0.5066          0.3744  1.0000   \n",
       "Sparse Probing Top1 -0.1433  0.3255         -0.2088 -0.3013   \n",
       "RAVEL               -0.6739 -0.7775          0.9542  0.3557   \n",
       "TPP@20              -0.2152 -0.8074          0.8441  0.3871   \n",
       "SAE score            0.3450  0.2486         -0.4763  0.0080   \n",
       "\n",
       "                     Sparse Probing Top1   RAVEL  TPP@20  SAE score  \n",
       "Interp                           -0.1433 -0.6739 -0.2152     0.3450  \n",
       "Absorb                            0.3255 -0.7775 -0.8074     0.2486  \n",
       "Loss Recovered                   -0.2088  0.9542  0.8441    -0.4763  \n",
       "SCR@20                           -0.3013  0.3557  0.3871     0.0080  \n",
       "Sparse Probing Top1               1.0000 -0.1860 -0.2670    -0.2156  \n",
       "RAVEL                            -0.1860  1.0000  0.7538    -0.4336  \n",
       "TPP@20                           -0.2670  0.7538  1.0000    -0.3812  \n",
       "SAE score                        -0.2156 -0.4336 -0.3812     1.0000  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Kendall Correlation (rank, pairwise order consistency) ===\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Interp</th>\n",
       "      <th>Absorb</th>\n",
       "      <th>Loss Recovered</th>\n",
       "      <th>SCR@20</th>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <th>RAVEL</th>\n",
       "      <th>TPP@20</th>\n",
       "      <th>SAE score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Interp</th>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.2230</td>\n",
       "      <td>-0.4042</td>\n",
       "      <td>-0.1126</td>\n",
       "      <td>-0.1381</td>\n",
       "      <td>-0.4851</td>\n",
       "      <td>-0.1381</td>\n",
       "      <td>0.2194</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Absorb</th>\n",
       "      <td>0.2230</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.5900</td>\n",
       "      <td>-0.3563</td>\n",
       "      <td>0.2071</td>\n",
       "      <td>-0.5724</td>\n",
       "      <td>-0.6030</td>\n",
       "      <td>0.2009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Loss Recovered</th>\n",
       "      <td>-0.4042</td>\n",
       "      <td>-0.5900</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.2788</td>\n",
       "      <td>-0.1372</td>\n",
       "      <td>0.8549</td>\n",
       "      <td>0.6814</td>\n",
       "      <td>-0.3734</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SCR@20</th>\n",
       "      <td>-0.1126</td>\n",
       "      <td>-0.3563</td>\n",
       "      <td>0.2788</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.2163</td>\n",
       "      <td>0.2598</td>\n",
       "      <td>0.2992</td>\n",
       "      <td>0.0162</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <td>-0.1381</td>\n",
       "      <td>0.2071</td>\n",
       "      <td>-0.1372</td>\n",
       "      <td>-0.2163</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.1289</td>\n",
       "      <td>-0.1636</td>\n",
       "      <td>-0.1619</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RAVEL</th>\n",
       "      <td>-0.4851</td>\n",
       "      <td>-0.5724</td>\n",
       "      <td>0.8549</td>\n",
       "      <td>0.2598</td>\n",
       "      <td>-0.1289</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.5708</td>\n",
       "      <td>-0.3210</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TPP@20</th>\n",
       "      <td>-0.1381</td>\n",
       "      <td>-0.6030</td>\n",
       "      <td>0.6814</td>\n",
       "      <td>0.2992</td>\n",
       "      <td>-0.1636</td>\n",
       "      <td>0.5708</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>-0.2728</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SAE score</th>\n",
       "      <td>0.2194</td>\n",
       "      <td>0.2009</td>\n",
       "      <td>-0.3734</td>\n",
       "      <td>0.0162</td>\n",
       "      <td>-0.1619</td>\n",
       "      <td>-0.3210</td>\n",
       "      <td>-0.2728</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                     Interp  Absorb  Loss Recovered  SCR@20  \\\n",
       "Interp               1.0000  0.2230         -0.4042 -0.1126   \n",
       "Absorb               0.2230  1.0000         -0.5900 -0.3563   \n",
       "Loss Recovered      -0.4042 -0.5900          1.0000  0.2788   \n",
       "SCR@20              -0.1126 -0.3563          0.2788  1.0000   \n",
       "Sparse Probing Top1 -0.1381  0.2071         -0.1372 -0.2163   \n",
       "RAVEL               -0.4851 -0.5724          0.8549  0.2598   \n",
       "TPP@20              -0.1381 -0.6030          0.6814  0.2992   \n",
       "SAE score            0.2194  0.2009         -0.3734  0.0162   \n",
       "\n",
       "                     Sparse Probing Top1   RAVEL  TPP@20  SAE score  \n",
       "Interp                           -0.1381 -0.4851 -0.1381     0.2194  \n",
       "Absorb                            0.2071 -0.5724 -0.6030     0.2009  \n",
       "Loss Recovered                   -0.1372  0.8549  0.6814    -0.3734  \n",
       "SCR@20                           -0.2163  0.2598  0.2992     0.0162  \n",
       "Sparse Probing Top1               1.0000 -0.1289 -0.1636    -0.1619  \n",
       "RAVEL                            -0.1289  1.0000  0.5708    -0.3210  \n",
       "TPP@20                           -0.1636  0.5708  1.0000    -0.2728  \n",
       "SAE score                        -0.1619 -0.3210 -0.2728     1.0000  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Pairwise Ranking Agreement Rate (ties ignored) ===\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Interp</th>\n",
       "      <th>Absorb</th>\n",
       "      <th>Loss Recovered</th>\n",
       "      <th>SCR@20</th>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <th>RAVEL</th>\n",
       "      <th>TPP@20</th>\n",
       "      <th>SAE score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Interp</th>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.6115</td>\n",
       "      <td>0.2958</td>\n",
       "      <td>0.4437</td>\n",
       "      <td>0.4309</td>\n",
       "      <td>0.2575</td>\n",
       "      <td>0.4309</td>\n",
       "      <td>0.6102</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Absorb</th>\n",
       "      <td>0.6115</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.2019</td>\n",
       "      <td>0.3218</td>\n",
       "      <td>0.6037</td>\n",
       "      <td>0.2138</td>\n",
       "      <td>0.1982</td>\n",
       "      <td>0.6009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Loss Recovered</th>\n",
       "      <td>0.2958</td>\n",
       "      <td>0.2019</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.6408</td>\n",
       "      <td>0.4306</td>\n",
       "      <td>0.9319</td>\n",
       "      <td>0.8447</td>\n",
       "      <td>0.3104</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SCR@20</th>\n",
       "      <td>0.4437</td>\n",
       "      <td>0.3218</td>\n",
       "      <td>0.6408</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.3917</td>\n",
       "      <td>0.6299</td>\n",
       "      <td>0.6498</td>\n",
       "      <td>0.5081</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Sparse Probing Top1</th>\n",
       "      <td>0.4309</td>\n",
       "      <td>0.6037</td>\n",
       "      <td>0.4306</td>\n",
       "      <td>0.3917</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.4355</td>\n",
       "      <td>0.4180</td>\n",
       "      <td>0.4186</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>RAVEL</th>\n",
       "      <td>0.2575</td>\n",
       "      <td>0.2138</td>\n",
       "      <td>0.9319</td>\n",
       "      <td>0.6299</td>\n",
       "      <td>0.4355</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.7857</td>\n",
       "      <td>0.3387</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>TPP@20</th>\n",
       "      <td>0.4309</td>\n",
       "      <td>0.1982</td>\n",
       "      <td>0.8447</td>\n",
       "      <td>0.6498</td>\n",
       "      <td>0.4180</td>\n",
       "      <td>0.7857</td>\n",
       "      <td>1.0000</td>\n",
       "      <td>0.3628</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SAE score</th>\n",
       "      <td>0.6102</td>\n",
       "      <td>0.6009</td>\n",
       "      <td>0.3104</td>\n",
       "      <td>0.5081</td>\n",
       "      <td>0.4186</td>\n",
       "      <td>0.3387</td>\n",
       "      <td>0.3628</td>\n",
       "      <td>1.0000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                     Interp  Absorb  Loss Recovered  SCR@20  \\\n",
       "Interp               1.0000  0.6115          0.2958  0.4437   \n",
       "Absorb               0.6115  1.0000          0.2019  0.3218   \n",
       "Loss Recovered       0.2958  0.2019          1.0000  0.6408   \n",
       "SCR@20               0.4437  0.3218          0.6408  1.0000   \n",
       "Sparse Probing Top1  0.4309  0.6037          0.4306  0.3917   \n",
       "RAVEL                0.2575  0.2138          0.9319  0.6299   \n",
       "TPP@20               0.4309  0.1982          0.8447  0.6498   \n",
       "SAE score            0.6102  0.6009          0.3104  0.5081   \n",
       "\n",
       "                     Sparse Probing Top1   RAVEL  TPP@20  SAE score  \n",
       "Interp                            0.4309  0.2575  0.4309     0.6102  \n",
       "Absorb                            0.6037  0.2138  0.1982     0.6009  \n",
       "Loss Recovered                    0.4306  0.9319  0.8447     0.3104  \n",
       "SCR@20                            0.3917  0.6299  0.6498     0.5081  \n",
       "Sparse Probing Top1               1.0000  0.4355  0.4180     0.4186  \n",
       "RAVEL                             0.4355  1.0000  0.7857     0.3387  \n",
       "TPP@20                            0.4180  0.7857  1.0000     0.3628  \n",
       "SAE score                         0.4186  0.3387  0.3628     1.0000  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Pairwise Summary (sorted by Spearman then Pearson) ===\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Metric A</th>\n",
       "      <th>Metric B</th>\n",
       "      <th>Pearson</th>\n",
       "      <th>Spearman</th>\n",
       "      <th>Kendall</th>\n",
       "      <th>AgreementRate</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>RAVEL</td>\n",
       "      <td>0.9694</td>\n",
       "      <td>0.9542</td>\n",
       "      <td>0.8549</td>\n",
       "      <td>0.9319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>TPP@20</td>\n",
       "      <td>0.5226</td>\n",
       "      <td>0.8441</td>\n",
       "      <td>0.6814</td>\n",
       "      <td>0.8447</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>RAVEL</td>\n",
       "      <td>TPP@20</td>\n",
       "      <td>0.4861</td>\n",
       "      <td>0.7538</td>\n",
       "      <td>0.5708</td>\n",
       "      <td>0.7857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>SCR@20</td>\n",
       "      <td>TPP@20</td>\n",
       "      <td>0.1159</td>\n",
       "      <td>0.3871</td>\n",
       "      <td>0.2992</td>\n",
       "      <td>0.6498</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>SCR@20</td>\n",
       "      <td>0.5926</td>\n",
       "      <td>0.3744</td>\n",
       "      <td>0.2788</td>\n",
       "      <td>0.6408</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>SCR@20</td>\n",
       "      <td>RAVEL</td>\n",
       "      <td>0.5271</td>\n",
       "      <td>0.3557</td>\n",
       "      <td>0.2598</td>\n",
       "      <td>0.6299</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Interp</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>0.3173</td>\n",
       "      <td>0.3450</td>\n",
       "      <td>0.2194</td>\n",
       "      <td>0.6102</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Interp</td>\n",
       "      <td>Absorb</td>\n",
       "      <td>0.2751</td>\n",
       "      <td>0.3402</td>\n",
       "      <td>0.2230</td>\n",
       "      <td>0.6115</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>Absorb</td>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>0.2832</td>\n",
       "      <td>0.3255</td>\n",
       "      <td>0.2071</td>\n",
       "      <td>0.6037</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Absorb</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>0.1569</td>\n",
       "      <td>0.2486</td>\n",
       "      <td>0.2009</td>\n",
       "      <td>0.6009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>SCR@20</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>-0.0231</td>\n",
       "      <td>0.0080</td>\n",
       "      <td>0.0162</td>\n",
       "      <td>0.5081</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>Interp</td>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>-0.0938</td>\n",
       "      <td>-0.1433</td>\n",
       "      <td>-0.1381</td>\n",
       "      <td>0.4309</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>RAVEL</td>\n",
       "      <td>-0.1584</td>\n",
       "      <td>-0.1860</td>\n",
       "      <td>-0.1289</td>\n",
       "      <td>0.4355</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Interp</td>\n",
       "      <td>SCR@20</td>\n",
       "      <td>-0.0873</td>\n",
       "      <td>-0.1902</td>\n",
       "      <td>-0.1126</td>\n",
       "      <td>0.4437</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>-0.1846</td>\n",
       "      <td>-0.2088</td>\n",
       "      <td>-0.1372</td>\n",
       "      <td>0.4306</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>Interp</td>\n",
       "      <td>TPP@20</td>\n",
       "      <td>-0.0134</td>\n",
       "      <td>-0.2152</td>\n",
       "      <td>-0.1381</td>\n",
       "      <td>0.4309</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>-0.1964</td>\n",
       "      <td>-0.2156</td>\n",
       "      <td>-0.1619</td>\n",
       "      <td>0.4186</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>TPP@20</td>\n",
       "      <td>0.0566</td>\n",
       "      <td>-0.2670</td>\n",
       "      <td>-0.1636</td>\n",
       "      <td>0.4180</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>SCR@20</td>\n",
       "      <td>Sparse Probing Top1</td>\n",
       "      <td>-0.2439</td>\n",
       "      <td>-0.3013</td>\n",
       "      <td>-0.2163</td>\n",
       "      <td>0.3917</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>TPP@20</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>-0.3696</td>\n",
       "      <td>-0.3812</td>\n",
       "      <td>-0.2728</td>\n",
       "      <td>0.3628</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>RAVEL</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>-0.3999</td>\n",
       "      <td>-0.4336</td>\n",
       "      <td>-0.3210</td>\n",
       "      <td>0.3387</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>SAE score</td>\n",
       "      <td>-0.3765</td>\n",
       "      <td>-0.4763</td>\n",
       "      <td>-0.3734</td>\n",
       "      <td>0.3104</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>Absorb</td>\n",
       "      <td>SCR@20</td>\n",
       "      <td>-0.4051</td>\n",
       "      <td>-0.5066</td>\n",
       "      <td>-0.3563</td>\n",
       "      <td>0.3218</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>Interp</td>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>-0.4931</td>\n",
       "      <td>-0.5502</td>\n",
       "      <td>-0.4042</td>\n",
       "      <td>0.2958</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>Interp</td>\n",
       "      <td>RAVEL</td>\n",
       "      <td>-0.6305</td>\n",
       "      <td>-0.6739</td>\n",
       "      <td>-0.4851</td>\n",
       "      <td>0.2575</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>Absorb</td>\n",
       "      <td>RAVEL</td>\n",
       "      <td>-0.6866</td>\n",
       "      <td>-0.7775</td>\n",
       "      <td>-0.5724</td>\n",
       "      <td>0.2138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>Absorb</td>\n",
       "      <td>Loss Recovered</td>\n",
       "      <td>-0.6347</td>\n",
       "      <td>-0.7930</td>\n",
       "      <td>-0.5900</td>\n",
       "      <td>0.2019</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>Absorb</td>\n",
       "      <td>TPP@20</td>\n",
       "      <td>-0.5190</td>\n",
       "      <td>-0.8074</td>\n",
       "      <td>-0.6030</td>\n",
       "      <td>0.1982</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "               Metric A             Metric B  Pearson  Spearman  Kendall  \\\n",
       "0        Loss Recovered                RAVEL   0.9694    0.9542   0.8549   \n",
       "1        Loss Recovered               TPP@20   0.5226    0.8441   0.6814   \n",
       "2                 RAVEL               TPP@20   0.4861    0.7538   0.5708   \n",
       "3                SCR@20               TPP@20   0.1159    0.3871   0.2992   \n",
       "4        Loss Recovered               SCR@20   0.5926    0.3744   0.2788   \n",
       "5                SCR@20                RAVEL   0.5271    0.3557   0.2598   \n",
       "6                Interp            SAE score   0.3173    0.3450   0.2194   \n",
       "7                Interp               Absorb   0.2751    0.3402   0.2230   \n",
       "8                Absorb  Sparse Probing Top1   0.2832    0.3255   0.2071   \n",
       "9                Absorb            SAE score   0.1569    0.2486   0.2009   \n",
       "10               SCR@20            SAE score  -0.0231    0.0080   0.0162   \n",
       "11               Interp  Sparse Probing Top1  -0.0938   -0.1433  -0.1381   \n",
       "12  Sparse Probing Top1                RAVEL  -0.1584   -0.1860  -0.1289   \n",
       "13               Interp               SCR@20  -0.0873   -0.1902  -0.1126   \n",
       "14       Loss Recovered  Sparse Probing Top1  -0.1846   -0.2088  -0.1372   \n",
       "15               Interp               TPP@20  -0.0134   -0.2152  -0.1381   \n",
       "16  Sparse Probing Top1            SAE score  -0.1964   -0.2156  -0.1619   \n",
       "17  Sparse Probing Top1               TPP@20   0.0566   -0.2670  -0.1636   \n",
       "18               SCR@20  Sparse Probing Top1  -0.2439   -0.3013  -0.2163   \n",
       "19               TPP@20            SAE score  -0.3696   -0.3812  -0.2728   \n",
       "20                RAVEL            SAE score  -0.3999   -0.4336  -0.3210   \n",
       "21       Loss Recovered            SAE score  -0.3765   -0.4763  -0.3734   \n",
       "22               Absorb               SCR@20  -0.4051   -0.5066  -0.3563   \n",
       "23               Interp       Loss Recovered  -0.4931   -0.5502  -0.4042   \n",
       "24               Interp                RAVEL  -0.6305   -0.6739  -0.4851   \n",
       "25               Absorb                RAVEL  -0.6866   -0.7775  -0.5724   \n",
       "26               Absorb       Loss Recovered  -0.6347   -0.7930  -0.5900   \n",
       "27               Absorb               TPP@20  -0.5190   -0.8074  -0.6030   \n",
       "\n",
       "    AgreementRate  \n",
       "0          0.9319  \n",
       "1          0.8447  \n",
       "2          0.7857  \n",
       "3          0.6498  \n",
       "4          0.6408  \n",
       "5          0.6299  \n",
       "6          0.6102  \n",
       "7          0.6115  \n",
       "8          0.6037  \n",
       "9          0.6009  \n",
       "10         0.5081  \n",
       "11         0.4309  \n",
       "12         0.4355  \n",
       "13         0.4437  \n",
       "14         0.4306  \n",
       "15         0.4309  \n",
       "16         0.4186  \n",
       "17         0.4180  \n",
       "18         0.3917  \n",
       "19         0.3628  \n",
       "20         0.3387  \n",
       "21         0.3104  \n",
       "22         0.3218  \n",
       "23         0.2958  \n",
       "24         0.2575  \n",
       "25         0.2138  \n",
       "26         0.2019  \n",
       "27         0.1982  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Build and display final dataframe with separate SAE filter columns and a MEAN row (no saving)\n",
    "import pandas as pd\n",
    "from itertools import combinations\n",
    "import numpy as np\n",
    "\n",
    "# Re-enter the full raw table (including the four filter threshold tuple)\n",
    "raw = [\n",
    "    # SAEs, AutoInterp, Absorption, LossRecovered, SCR20, SparseProbingTop1, RAVEL, TPP20, Steering, (0.1, 0.01, 0.001, 0.0001)\n",
    "    (\"batch_topk_50\",  0.8369, 0.2455, 0.9440, 0.1105, 0.7229, 0.6117, 0.0325, 0.151, (0.192,0.198,0.163,0.154)),\n",
    "    (\"batch_topk_80\",  0.8227, 0.1442, 0.9588, 0.1308, 0.7262, 0.6571, 0.0391, 0.156, (0.148,0.150,0.165,0.158)),\n",
    "    (\"batch_topk_160\", 0.8117, 0.0520, 0.9736, 0.1689, 0.7251, 0.7009, 0.1204, 0.145, (0.120,0.210,0.126,0.079)),\n",
    "    (\"batch_topk_320\", 0.8142, 0.0838, 0.9835, 0.0897, 0.7159, 0.7214, 0.1580, 0.122, (0.200,0.240,0.215,0.146)),\n",
    "    (\"batch_topk_520\", 0.8023, 0.0949, 0.9852, 0.1320, 0.7528, 0.7211, 0.3160, 0.117, (0.240,0.187,0.153,0.113)),\n",
    "    (\"batch_topk_820\", 0.7914, 0.1309, 0.9852, 0.1180, 0.7656, 0.7229, 0.3448, 0.106, (0.340,0.318,0.233,0.224)),\n",
    "\n",
    "    (\"gated_49\",       0.8152, 0.4517, 0.9407, 0.1124, 0.7341, 0.6071, 0.0235, 0.106, (0.540,0.213,0.142,0.128)),\n",
    "    (\"gated_78\",       0.8086, 0.4134, 0.9572, 0.1301, 0.7562, 0.6334, 0.0306, 0.089, (0.000,0.000,0.053,0.068)),\n",
    "    (\"gated_148\",      0.7939, 0.2182, 0.9736, 0.1567, 0.7591, 0.6891, 0.0520, 0.116, (0.180,0.103,0.144,0.104)),\n",
    "    (\"gated_340\",      0.7746, 0.1256, 0.9868, 0.1491, 0.7051, 0.7337, 0.0604, 0.153, (0.160,0.096,0.200,0.133)),\n",
    "    (\"gated_547\",      0.7645, 0.1168, 0.9918, 0.1363, 0.7127, 0.7544, 0.0745, 0.134, (0.000,0.096,0.147,0.173)),\n",
    "    (\"gated_948\",      0.7536, 0.1007, 0.9967, 0.0934, 0.6764, 0.7714, 0.0994, 0.103, (0.120,0.120,0.048,0.158)),\n",
    "\n",
    "    (\"jumprelu_52\",    0.8281, 0.2558, 0.9456, 0.1504, 0.7237, 0.6127, 0.0287, 0.176, (0.000,0.191,0.271,0.234)),\n",
    "    (\"jumprelu_83\",    0.8119, 0.1767, 0.9588, 0.1423, 0.6964, 0.6596, 0.0492, 0.179, (0.240,0.355,0.353,0.268)),\n",
    "    (\"jumprelu_165\",   0.7996, 0.0787, 0.9769, 0.1595, 0.7349, 0.7109, 0.0669, 0.120, (0.170,0.131,0.140,0.164)),\n",
    "    (\"jumprelu_330\",   0.7887, 0.0210, 0.9852, 0.1412, 0.7206, 0.7350, 0.0709, 0.105, (0.000,0.100,0.194,0.156)),\n",
    "    (\"jumprelu_538\",   0.8048, 0.0656, 0.9918, 0.1359, 0.7365, 0.7403, 0.0948, 0.089, (0.000,0.000,0.000,0.016)),\n",
    "    (\"jumprelu_779\",   0.7955, 0.0232, 0.9934, 0.1511, 0.7647, 0.7391, 0.1221, 0.119, (0.140,0.121,0.118,0.118)),\n",
    "\n",
    "    (\"relu_54\",        0.8326, 0.2789, 0.8402, 0.0662, 0.7360, 0.4434, 0.0065, 0.150, (0.121,0.190,0.227,0.234)),\n",
    "    (\"relu_99\",        0.8144, 0.2801, 0.8896, 0.0694, 0.7708, 0.4967, 0.0118, 0.110, (0.060,0.101,0.077,0.081)),\n",
    "    (\"relu_156\",       0.8003, 0.2467, 0.9160, 0.0854, 0.7711, 0.5747, 0.0178, 0.181, (0.137,0.150,0.169,0.168)),\n",
    "    (\"relu_309\",       0.7896, 0.2201, 0.9473, 0.0988, 0.7686, 0.6520, 0.0171, 0.131, (0.306,0.316,0.226,0.192)),\n",
    "    (\"relu_507\",       0.7754, 0.2370, 0.9638, 0.1139, 0.7939, 0.6999, 0.0235, 0.140, (0.068,0.160,0.189,0.200)),\n",
    "    (\"relu_733\",       0.7644, 0.1822, 0.9753, 0.1143, 0.7742, 0.7176, 0.0353, 0.141, (0.128,0.219,0.161,0.156)),\n",
    "\n",
    "    (\"topk_50\",        0.8336, 0.2984, 0.9341, 0.1174, 0.7227, 0.5682, 0.0238, 0.197, (0.236,0.242,0.232,0.214)),\n",
    "    (\"topk_80\",        0.8215, 0.1935, 0.9489, 0.1305, 0.7136, 0.6107, 0.0337, 0.149, (0.166,0.147,0.147,0.143)),\n",
    "    (\"topk_160\",       0.8124, 0.0884, 0.9687, 0.1274, 0.7114, 0.6636, 0.0932, 0.152, (0.060,0.137,0.128,0.154)),\n",
    "    (\"topk_320\",       0.8062, 0.0613, 0.9802, 0.1662, 0.7115, 0.6960, 0.1527, 0.113, (0.320,0.240,0.160,0.124)),\n",
    "    (\"topk_520\",       0.8226, 0.0290, 0.9868, 0.1204, 0.7229, 0.7145, 0.3032, 0.134, (0.000,0.180,0.300,0.296)),\n",
    "    (\"topk_820\",       0.8150, 0.1411, 0.9918, 0.1110, 0.7666, 0.7089, 0.3226, 0.105, (0.270,0.312,0.160,0.074)),\n",
    "]\n",
    "\n",
    "cols = [\n",
    "    \"SAEs\",\"AutoInterp\",\"Absorption\",\"LossRecovered\",\"SCR20\",\"SparseProbingTop1\",\n",
    "    \"RAVEL\",\"TPP20\",\"Steering\",\"Steer_0.1_\",\"Steer_0.01_\",\"Steer_0.001_\",\"Steer_0.0001_\"\n",
    "]\n",
    "\n",
    "rows = []\n",
    "for row in raw:\n",
    "    name, *vals = row\n",
    "    base, thresholds = vals[-2], vals[-1]\n",
    "    rows.append([name, *vals[:-2], base, *thresholds])\n",
    "\n",
    "df = pd.DataFrame(rows, columns=cols)\n",
    "\n",
    "# Add “Prompt score” using the values provided\n",
    "prompt_scores = {\n",
    "    \"batch_topk_50\": 0.694, \"batch_topk_80\": 0.708, \"batch_topk_160\": 0.661,\n",
    "    \"batch_topk_320\": 0.719, \"batch_topk_520\": 0.811, \"batch_topk_820\": 0.727,\n",
    "    \"gated_49\": 0.800, \"gated_78\": 0.663, \"gated_148\": 0.668,\n",
    "    \"gated_340\": 0.728, \"gated_547\": 0.699, \"gated_948\": 0.802,\n",
    "    \"jumprelu_52\": 0.678, \"jumprelu_83\": 0.674, \"jumprelu_165\": 0.736,\n",
    "    \"jumprelu_330\": 0.726, \"jumprelu_538\": 0.746, \"jumprelu_779\": 0.720,\n",
    "    \"relu_54\": 0.745, \"relu_99\": 0.724, \"relu_156\": 0.750,\n",
    "    \"relu_309\": 0.748, \"relu_507\": 0.732, \"relu_733\": 0.737,\n",
    "    \"topk_50\": 0.761, \"topk_80\": 0.723, \"topk_160\": 0.743,\n",
    "    \"topk_320\": 0.733, \"topk_520\": 0.705, \"topk_820\": 0.751,\n",
    "}\n",
    "df[\"Prompt score\"] = df[\"SAEs\"].map(prompt_scores)\n",
    "\n",
    "# Rename columns to requested headers\n",
    "rename_map = {\n",
    "    \"AutoInterp\": \"Interp\",\n",
    "    \"Absorption\": \"Absorb\",\n",
    "    \"LossRecovered\": \"Loss Recovered\",\n",
    "    \"SCR20\": \"SCR@20\",\n",
    "    \"SparseProbingTop1\": \"Sparse Probing Top1\",\n",
    "    \"TPP20\": \"TPP@20\",\n",
    "    \"Steering\": \"SAE score\",\n",
    "}\n",
    "df = df.rename(columns=rename_map)\n",
    "\n",
    "# Split filter columns as separate numeric columns\n",
    "df[\"SAE filter@0.1\"]   = df[\"Steer_0.1_\"]\n",
    "df[\"SAE filter@0.01\"]  = df[\"Steer_0.01_\"]\n",
    "df[\"SAE filter@0.001\"] = df[\"Steer_0.001_\"]\n",
    "df[\"SAE filter@0.0001\"]= df[\"Steer_0.0001_\"]\n",
    "\n",
    "# Reorder to final output\n",
    "out_cols = [\n",
    "    \"SAEs\", \"Interp\", \"Absorb\", \"Loss Recovered\", \"SCR@20\",\n",
    "    \"Sparse Probing Top1\", \"RAVEL\", \"TPP@20\", \"SAE score\",\n",
    "    \"Prompt score\", \"SAE filter@0.1\", \"SAE filter@0.01\",\n",
    "    \"SAE filter@0.001\", \"SAE filter@0.0001\"\n",
    "]\n",
    "out = df[out_cols].copy()\n",
    "\n",
    "# Append a MEAN row over numeric columns\n",
    "means = out.select_dtypes(include=\"number\").mean()\n",
    "mean_row = {col: \"\" for col in out.columns}\n",
    "mean_row[\"SAEs\"] = \"MEAN\"\n",
    "for col, val in means.items():\n",
    "    mean_row[col] = round(float(val), 6)  # keep a reasonable precision\n",
    "out_with_mean = pd.concat([out, pd.DataFrame([mean_row])], ignore_index=True)\n",
    "\n",
    "# ----------------------------\n",
    "# Pairwise analysis (between requested metrics)\n",
    "# ----------------------------\n",
    "metrics = [\"Interp\", \"Absorb\", \"Loss Recovered\", \"SCR@20\",\n",
    "           \"Sparse Probing Top1\", \"RAVEL\", \"TPP@20\", \"SAE score\"]\n",
    "\n",
    "# Exclude the MEAN row for analysis\n",
    "num_df = out_with_mean.loc[out_with_mean[\"SAEs\"] != \"MEAN\", metrics].astype(float)\n",
    "\n",
    "# 1) Correlation matrices (Pearson / Spearman / Kendall)\n",
    "pearson_corr = num_df.corr(method=\"pearson\")\n",
    "spearman_corr = num_df.corr(method=\"spearman\")\n",
    "kendall_corr = num_df.corr(method=\"kendall\")\n",
    "\n",
    "# 2) Pairwise ranking-agreement (concordance) between metrics\n",
    "#    Agreement rate = (# of concordant pairs) / (# of comparable pairs), ties ignored\n",
    "def pairwise_agreement_rate(x: pd.Series, y: pd.Series) -> float:\n",
    "    x_vals = x.values\n",
    "    y_vals = y.values\n",
    "    n = len(x_vals)\n",
    "    conc = 0\n",
    "    disc = 0\n",
    "    for i, j in combinations(range(n), 2):\n",
    "        dx = x_vals[i] - x_vals[j]\n",
    "        dy = y_vals[i] - y_vals[j]\n",
    "        if dx == 0 or dy == 0:\n",
    "            # ignore ties entirely\n",
    "            continue\n",
    "        if np.sign(dx) == np.sign(dy):\n",
    "            conc += 1\n",
    "        else:\n",
    "            disc += 1\n",
    "    denom = conc + disc\n",
    "    return conc / denom if denom > 0 else np.nan\n",
    "\n",
    "agreement = pd.DataFrame(index=metrics, columns=metrics, dtype=float)\n",
    "for a in metrics:\n",
    "    for b in metrics:\n",
    "        if a == b:\n",
    "            agreement.loc[a, b] = 1.0\n",
    "        else:\n",
    "            agreement.loc[a, b] = pairwise_agreement_rate(num_df[a], num_df[b])\n",
    "\n",
    "# 3) Compact long-form summary table for easy viewing\n",
    "summary_rows = []\n",
    "for a, b in combinations(metrics, 2):\n",
    "    summary_rows.append({\n",
    "        \"Metric A\": a,\n",
    "        \"Metric B\": b,\n",
    "        \"Pearson\": pearson_corr.loc[a, b],\n",
    "        \"Spearman\": spearman_corr.loc[a, b],\n",
    "        \"Kendall\": kendall_corr.loc[a, b],\n",
    "        \"AgreementRate\": agreement.loc[a, b]\n",
    "    })\n",
    "pairwise_summary = pd.DataFrame(summary_rows).sort_values(\n",
    "    [\"Spearman\", \"Pearson\"], ascending=False, ignore_index=True\n",
    ")\n",
    "\n",
    "# ----------------------------\n",
    "# Outputs\n",
    "# ----------------------------\n",
    "# Final table with MEAN row\n",
    "print(\"\\n=== Final Table (with MEAN row at bottom) ===\")\n",
    "display(out_with_mean)\n",
    "\n",
    "# Correlation matrices\n",
    "print(\"\\n=== Pearson Correlation (linear) ===\")\n",
    "display(pearson_corr.round(4))\n",
    "\n",
    "print(\"\\n=== Spearman Correlation (rank) ===\")\n",
    "display(spearman_corr.round(4))\n",
    "\n",
    "print(\"\\n=== Kendall Correlation (rank, pairwise order consistency) ===\")\n",
    "display(kendall_corr.round(4))\n",
    "\n",
    "# Agreement rate matrix\n",
    "print(\"\\n=== Pairwise Ranking Agreement Rate (ties ignored) ===\")\n",
    "display(agreement.round(4))\n",
    "\n",
    "# Long-form summary\n",
    "print(\"\\n=== Pairwise Summary (sorted by Spearman then Pearson) ===\")\n",
    "display(pairwise_summary.round(4))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "818b6fae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Per-SAE best filter vs SAE score ===\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3986829/435557418.py:126: FutureWarning: Setting an item of incompatible dtype is deprecated and will raise an error in a future version of pandas. Value '' has dtype incompatible with float64, please explicitly cast to a compatible dtype first.\n",
      "  calc.loc[calc[\"SAEs\"] == \"MEAN\", [\"Best SAE filter value\", \"Best SAE filter name\", \"Best vs SAE score (% change)\"]] = \"\"\n",
      "/tmp/ipykernel_3986829/435557418.py:126: FutureWarning: Setting an item of incompatible dtype is deprecated and will raise an error in a future version of pandas. Value '' has dtype incompatible with float64, please explicitly cast to a compatible dtype first.\n",
      "  calc.loc[calc[\"SAEs\"] == \"MEAN\", [\"Best SAE filter value\", \"Best SAE filter name\", \"Best vs SAE score (% change)\"]] = \"\"\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>SAEs</th>\n",
       "      <th>SAE score</th>\n",
       "      <th>SAE filter@0.1</th>\n",
       "      <th>SAE filter@0.01</th>\n",
       "      <th>SAE filter@0.001</th>\n",
       "      <th>SAE filter@0.0001</th>\n",
       "      <th>Best SAE filter name</th>\n",
       "      <th>Best SAE filter value</th>\n",
       "      <th>Best vs SAE score (% change)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>batch_topk_50</td>\n",
       "      <td>0.151000</td>\n",
       "      <td>0.1920</td>\n",
       "      <td>0.1980</td>\n",
       "      <td>0.163000</td>\n",
       "      <td>0.154000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.198</td>\n",
       "      <td>31.125828</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>batch_topk_80</td>\n",
       "      <td>0.156000</td>\n",
       "      <td>0.1480</td>\n",
       "      <td>0.1500</td>\n",
       "      <td>0.165000</td>\n",
       "      <td>0.158000</td>\n",
       "      <td>SAE filter@0.001</td>\n",
       "      <td>0.165</td>\n",
       "      <td>5.769231</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>batch_topk_160</td>\n",
       "      <td>0.145000</td>\n",
       "      <td>0.1200</td>\n",
       "      <td>0.2100</td>\n",
       "      <td>0.126000</td>\n",
       "      <td>0.079000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.21</td>\n",
       "      <td>44.827586</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>batch_topk_320</td>\n",
       "      <td>0.122000</td>\n",
       "      <td>0.2000</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.215000</td>\n",
       "      <td>0.146000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.24</td>\n",
       "      <td>96.721311</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>batch_topk_520</td>\n",
       "      <td>0.117000</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.1870</td>\n",
       "      <td>0.153000</td>\n",
       "      <td>0.113000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.24</td>\n",
       "      <td>105.128205</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>batch_topk_820</td>\n",
       "      <td>0.106000</td>\n",
       "      <td>0.3400</td>\n",
       "      <td>0.3180</td>\n",
       "      <td>0.233000</td>\n",
       "      <td>0.224000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.34</td>\n",
       "      <td>220.754717</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>gated_49</td>\n",
       "      <td>0.106000</td>\n",
       "      <td>0.5400</td>\n",
       "      <td>0.2130</td>\n",
       "      <td>0.142000</td>\n",
       "      <td>0.128000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.54</td>\n",
       "      <td>409.433962</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>gated_78</td>\n",
       "      <td>0.089000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.053000</td>\n",
       "      <td>0.068000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.068</td>\n",
       "      <td>-23.595506</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>gated_148</td>\n",
       "      <td>0.116000</td>\n",
       "      <td>0.1800</td>\n",
       "      <td>0.1030</td>\n",
       "      <td>0.144000</td>\n",
       "      <td>0.104000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.18</td>\n",
       "      <td>55.172414</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>gated_340</td>\n",
       "      <td>0.153000</td>\n",
       "      <td>0.1600</td>\n",
       "      <td>0.0960</td>\n",
       "      <td>0.200000</td>\n",
       "      <td>0.133000</td>\n",
       "      <td>SAE filter@0.001</td>\n",
       "      <td>0.2</td>\n",
       "      <td>30.718954</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>gated_547</td>\n",
       "      <td>0.134000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0960</td>\n",
       "      <td>0.147000</td>\n",
       "      <td>0.173000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.173</td>\n",
       "      <td>29.104478</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>gated_948</td>\n",
       "      <td>0.103000</td>\n",
       "      <td>0.1200</td>\n",
       "      <td>0.1200</td>\n",
       "      <td>0.048000</td>\n",
       "      <td>0.158000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.158</td>\n",
       "      <td>53.398058</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>jumprelu_52</td>\n",
       "      <td>0.176000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1910</td>\n",
       "      <td>0.271000</td>\n",
       "      <td>0.234000</td>\n",
       "      <td>SAE filter@0.001</td>\n",
       "      <td>0.271</td>\n",
       "      <td>53.977273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>jumprelu_83</td>\n",
       "      <td>0.179000</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.3550</td>\n",
       "      <td>0.353000</td>\n",
       "      <td>0.268000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.355</td>\n",
       "      <td>98.324022</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>jumprelu_165</td>\n",
       "      <td>0.120000</td>\n",
       "      <td>0.1700</td>\n",
       "      <td>0.1310</td>\n",
       "      <td>0.140000</td>\n",
       "      <td>0.164000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.17</td>\n",
       "      <td>41.666667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>jumprelu_330</td>\n",
       "      <td>0.105000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1000</td>\n",
       "      <td>0.194000</td>\n",
       "      <td>0.156000</td>\n",
       "      <td>SAE filter@0.001</td>\n",
       "      <td>0.194</td>\n",
       "      <td>84.761905</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>jumprelu_538</td>\n",
       "      <td>0.089000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.016000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.016</td>\n",
       "      <td>-82.022472</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>jumprelu_779</td>\n",
       "      <td>0.119000</td>\n",
       "      <td>0.1400</td>\n",
       "      <td>0.1210</td>\n",
       "      <td>0.118000</td>\n",
       "      <td>0.118000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.14</td>\n",
       "      <td>17.647059</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>relu_54</td>\n",
       "      <td>0.150000</td>\n",
       "      <td>0.1210</td>\n",
       "      <td>0.1900</td>\n",
       "      <td>0.227000</td>\n",
       "      <td>0.234000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.234</td>\n",
       "      <td>56.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>relu_99</td>\n",
       "      <td>0.110000</td>\n",
       "      <td>0.0600</td>\n",
       "      <td>0.1010</td>\n",
       "      <td>0.077000</td>\n",
       "      <td>0.081000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.101</td>\n",
       "      <td>-8.181818</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>relu_156</td>\n",
       "      <td>0.181000</td>\n",
       "      <td>0.1370</td>\n",
       "      <td>0.1500</td>\n",
       "      <td>0.169000</td>\n",
       "      <td>0.168000</td>\n",
       "      <td>SAE filter@0.001</td>\n",
       "      <td>0.169</td>\n",
       "      <td>-6.629834</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>relu_309</td>\n",
       "      <td>0.131000</td>\n",
       "      <td>0.3060</td>\n",
       "      <td>0.3160</td>\n",
       "      <td>0.226000</td>\n",
       "      <td>0.192000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.316</td>\n",
       "      <td>141.221374</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>relu_507</td>\n",
       "      <td>0.140000</td>\n",
       "      <td>0.0680</td>\n",
       "      <td>0.1600</td>\n",
       "      <td>0.189000</td>\n",
       "      <td>0.200000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.2</td>\n",
       "      <td>42.857143</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>relu_733</td>\n",
       "      <td>0.141000</td>\n",
       "      <td>0.1280</td>\n",
       "      <td>0.2190</td>\n",
       "      <td>0.161000</td>\n",
       "      <td>0.156000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.219</td>\n",
       "      <td>55.319149</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>topk_50</td>\n",
       "      <td>0.197000</td>\n",
       "      <td>0.2360</td>\n",
       "      <td>0.2420</td>\n",
       "      <td>0.232000</td>\n",
       "      <td>0.214000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.242</td>\n",
       "      <td>22.84264</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>topk_80</td>\n",
       "      <td>0.149000</td>\n",
       "      <td>0.1660</td>\n",
       "      <td>0.1470</td>\n",
       "      <td>0.147000</td>\n",
       "      <td>0.143000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.166</td>\n",
       "      <td>11.409396</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>topk_160</td>\n",
       "      <td>0.152000</td>\n",
       "      <td>0.0600</td>\n",
       "      <td>0.1370</td>\n",
       "      <td>0.128000</td>\n",
       "      <td>0.154000</td>\n",
       "      <td>SAE filter@0.0001</td>\n",
       "      <td>0.154</td>\n",
       "      <td>1.315789</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>topk_320</td>\n",
       "      <td>0.113000</td>\n",
       "      <td>0.3200</td>\n",
       "      <td>0.2400</td>\n",
       "      <td>0.160000</td>\n",
       "      <td>0.124000</td>\n",
       "      <td>SAE filter@0.1</td>\n",
       "      <td>0.32</td>\n",
       "      <td>183.185841</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>topk_520</td>\n",
       "      <td>0.134000</td>\n",
       "      <td>0.0000</td>\n",
       "      <td>0.1800</td>\n",
       "      <td>0.300000</td>\n",
       "      <td>0.296000</td>\n",
       "      <td>SAE filter@0.001</td>\n",
       "      <td>0.3</td>\n",
       "      <td>123.880597</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>topk_820</td>\n",
       "      <td>0.105000</td>\n",
       "      <td>0.2700</td>\n",
       "      <td>0.3120</td>\n",
       "      <td>0.160000</td>\n",
       "      <td>0.074000</td>\n",
       "      <td>SAE filter@0.01</td>\n",
       "      <td>0.312</td>\n",
       "      <td>197.142857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>MEAN</td>\n",
       "      <td>0.132967</td>\n",
       "      <td>0.1554</td>\n",
       "      <td>0.1741</td>\n",
       "      <td>0.168033</td>\n",
       "      <td>0.154333</td>\n",
       "      <td></td>\n",
       "      <td></td>\n",
       "      <td></td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              SAEs  SAE score  SAE filter@0.1  SAE filter@0.01  \\\n",
       "0    batch_topk_50   0.151000          0.1920           0.1980   \n",
       "1    batch_topk_80   0.156000          0.1480           0.1500   \n",
       "2   batch_topk_160   0.145000          0.1200           0.2100   \n",
       "3   batch_topk_320   0.122000          0.2000           0.2400   \n",
       "4   batch_topk_520   0.117000          0.2400           0.1870   \n",
       "5   batch_topk_820   0.106000          0.3400           0.3180   \n",
       "6         gated_49   0.106000          0.5400           0.2130   \n",
       "7         gated_78   0.089000          0.0000           0.0000   \n",
       "8        gated_148   0.116000          0.1800           0.1030   \n",
       "9        gated_340   0.153000          0.1600           0.0960   \n",
       "10       gated_547   0.134000          0.0000           0.0960   \n",
       "11       gated_948   0.103000          0.1200           0.1200   \n",
       "12     jumprelu_52   0.176000          0.0000           0.1910   \n",
       "13     jumprelu_83   0.179000          0.2400           0.3550   \n",
       "14    jumprelu_165   0.120000          0.1700           0.1310   \n",
       "15    jumprelu_330   0.105000          0.0000           0.1000   \n",
       "16    jumprelu_538   0.089000          0.0000           0.0000   \n",
       "17    jumprelu_779   0.119000          0.1400           0.1210   \n",
       "18         relu_54   0.150000          0.1210           0.1900   \n",
       "19         relu_99   0.110000          0.0600           0.1010   \n",
       "20        relu_156   0.181000          0.1370           0.1500   \n",
       "21        relu_309   0.131000          0.3060           0.3160   \n",
       "22        relu_507   0.140000          0.0680           0.1600   \n",
       "23        relu_733   0.141000          0.1280           0.2190   \n",
       "24         topk_50   0.197000          0.2360           0.2420   \n",
       "25         topk_80   0.149000          0.1660           0.1470   \n",
       "26        topk_160   0.152000          0.0600           0.1370   \n",
       "27        topk_320   0.113000          0.3200           0.2400   \n",
       "28        topk_520   0.134000          0.0000           0.1800   \n",
       "29        topk_820   0.105000          0.2700           0.3120   \n",
       "30            MEAN   0.132967          0.1554           0.1741   \n",
       "\n",
       "    SAE filter@0.001  SAE filter@0.0001 Best SAE filter name  \\\n",
       "0           0.163000           0.154000      SAE filter@0.01   \n",
       "1           0.165000           0.158000     SAE filter@0.001   \n",
       "2           0.126000           0.079000      SAE filter@0.01   \n",
       "3           0.215000           0.146000      SAE filter@0.01   \n",
       "4           0.153000           0.113000       SAE filter@0.1   \n",
       "5           0.233000           0.224000       SAE filter@0.1   \n",
       "6           0.142000           0.128000       SAE filter@0.1   \n",
       "7           0.053000           0.068000    SAE filter@0.0001   \n",
       "8           0.144000           0.104000       SAE filter@0.1   \n",
       "9           0.200000           0.133000     SAE filter@0.001   \n",
       "10          0.147000           0.173000    SAE filter@0.0001   \n",
       "11          0.048000           0.158000    SAE filter@0.0001   \n",
       "12          0.271000           0.234000     SAE filter@0.001   \n",
       "13          0.353000           0.268000      SAE filter@0.01   \n",
       "14          0.140000           0.164000       SAE filter@0.1   \n",
       "15          0.194000           0.156000     SAE filter@0.001   \n",
       "16          0.000000           0.016000    SAE filter@0.0001   \n",
       "17          0.118000           0.118000       SAE filter@0.1   \n",
       "18          0.227000           0.234000    SAE filter@0.0001   \n",
       "19          0.077000           0.081000      SAE filter@0.01   \n",
       "20          0.169000           0.168000     SAE filter@0.001   \n",
       "21          0.226000           0.192000      SAE filter@0.01   \n",
       "22          0.189000           0.200000    SAE filter@0.0001   \n",
       "23          0.161000           0.156000      SAE filter@0.01   \n",
       "24          0.232000           0.214000      SAE filter@0.01   \n",
       "25          0.147000           0.143000       SAE filter@0.1   \n",
       "26          0.128000           0.154000    SAE filter@0.0001   \n",
       "27          0.160000           0.124000       SAE filter@0.1   \n",
       "28          0.300000           0.296000     SAE filter@0.001   \n",
       "29          0.160000           0.074000      SAE filter@0.01   \n",
       "30          0.168033           0.154333                        \n",
       "\n",
       "   Best SAE filter value Best vs SAE score (% change)  \n",
       "0                  0.198                    31.125828  \n",
       "1                  0.165                     5.769231  \n",
       "2                   0.21                    44.827586  \n",
       "3                   0.24                    96.721311  \n",
       "4                   0.24                   105.128205  \n",
       "5                   0.34                   220.754717  \n",
       "6                   0.54                   409.433962  \n",
       "7                  0.068                   -23.595506  \n",
       "8                   0.18                    55.172414  \n",
       "9                    0.2                    30.718954  \n",
       "10                 0.173                    29.104478  \n",
       "11                 0.158                    53.398058  \n",
       "12                 0.271                    53.977273  \n",
       "13                 0.355                    98.324022  \n",
       "14                  0.17                    41.666667  \n",
       "15                 0.194                    84.761905  \n",
       "16                 0.016                   -82.022472  \n",
       "17                  0.14                    17.647059  \n",
       "18                 0.234                         56.0  \n",
       "19                 0.101                    -8.181818  \n",
       "20                 0.169                    -6.629834  \n",
       "21                 0.316                   141.221374  \n",
       "22                   0.2                    42.857143  \n",
       "23                 0.219                    55.319149  \n",
       "24                 0.242                     22.84264  \n",
       "25                 0.166                    11.409396  \n",
       "26                 0.154                     1.315789  \n",
       "27                  0.32                   183.185841  \n",
       "28                   0.3                   123.880597  \n",
       "29                 0.312                   197.142857  \n",
       "30                                                     "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "平均最大 filter 相比 SAE score 的提升：69.775894%\n"
     ]
    }
   ],
   "source": [
    "# Build and display final dataframe with separate SAE filter columns and a MEAN row (no saving)\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from IPython.display import display\n",
    "\n",
    "# Re-enter the full raw table (including the four filter threshold tuple)\n",
    "raw = [\n",
    "    # SAEs, AutoInterp, Absorption, LossRecovered, SCR20, SparseProbingTop1, RAVEL, TPP20, Steering, (0.1, 0.01, 0.001, 0.0001)\n",
    "    (\"batch_topk_50\",  0.8369, 0.2455, 0.9440, 0.1105, 0.7229, 0.6117, 0.0325, 0.151, (0.192,0.198,0.163,0.154)),\n",
    "    (\"batch_topk_80\",  0.8227, 0.1442, 0.9588, 0.1308, 0.7262, 0.6571, 0.0391, 0.156, (0.148,0.150,0.165,0.158)),\n",
    "    (\"batch_topk_160\", 0.8117, 0.0520, 0.9736, 0.1689, 0.7251, 0.7009, 0.1204, 0.145, (0.120,0.210,0.126,0.079)),\n",
    "    (\"batch_topk_320\", 0.8142, 0.0838, 0.9835, 0.0897, 0.7159, 0.7214, 0.1580, 0.122, (0.200,0.240,0.215,0.146)),\n",
    "    (\"batch_topk_520\", 0.8023, 0.0949, 0.9852, 0.1320, 0.7528, 0.7211, 0.3160, 0.117, (0.240,0.187,0.153,0.113)),\n",
    "    (\"batch_topk_820\", 0.7914, 0.1309, 0.9852, 0.1180, 0.7656, 0.7229, 0.3448, 0.106, (0.340,0.318,0.233,0.224)),\n",
    "\n",
    "    (\"gated_49\",       0.8152, 0.4517, 0.9407, 0.1124, 0.7341, 0.6071, 0.0235, 0.106, (0.540,0.213,0.142,0.128)),\n",
    "    (\"gated_78\",       0.8086, 0.4134, 0.9572, 0.1301, 0.7562, 0.6334, 0.0306, 0.089, (0.000,0.000,0.053,0.068)),\n",
    "    (\"gated_148\",      0.7939, 0.2182, 0.9736, 0.1567, 0.7591, 0.6891, 0.0520, 0.116, (0.180,0.103,0.144,0.104)),\n",
    "    (\"gated_340\",      0.7746, 0.1256, 0.9868, 0.1491, 0.7051, 0.7337, 0.0604, 0.153, (0.160,0.096,0.200,0.133)),\n",
    "    (\"gated_547\",      0.7645, 0.1168, 0.9918, 0.1363, 0.7127, 0.7544, 0.0745, 0.134, (0.000,0.096,0.147,0.173)),\n",
    "    (\"gated_948\",      0.7536, 0.1007, 0.9967, 0.0934, 0.6764, 0.7714, 0.0994, 0.103, (0.120,0.120,0.048,0.158)),\n",
    "\n",
    "    (\"jumprelu_52\",    0.8281, 0.2558, 0.9456, 0.1504, 0.7237, 0.6127, 0.0287, 0.176, (0.000,0.191,0.271,0.234)),\n",
    "    (\"jumprelu_83\",    0.8119, 0.1767, 0.9588, 0.1423, 0.6964, 0.6596, 0.0492, 0.179, (0.240,0.355,0.353,0.268)),\n",
    "    (\"jumprelu_165\",   0.7996, 0.0787, 0.9769, 0.1595, 0.7349, 0.7109, 0.0669, 0.120, (0.170,0.131,0.140,0.164)),\n",
    "    (\"jumprelu_330\",   0.7887, 0.0210, 0.9852, 0.1412, 0.7206, 0.7350, 0.0709, 0.105, (0.000,0.100,0.194,0.156)),\n",
    "    (\"jumprelu_538\",   0.8048, 0.0656, 0.9918, 0.1359, 0.7365, 0.7403, 0.0948, 0.089, (0.000,0.000,0.000,0.016)),\n",
    "    (\"jumprelu_779\",   0.7955, 0.0232, 0.9934, 0.1511, 0.7647, 0.7391, 0.1221, 0.119, (0.140,0.121,0.118,0.118)),\n",
    "\n",
    "    (\"relu_54\",        0.8326, 0.2789, 0.8402, 0.0662, 0.7360, 0.4434, 0.0065, 0.150, (0.121,0.190,0.227,0.234)),\n",
    "    (\"relu_99\",        0.8144, 0.2801, 0.8896, 0.0694, 0.7708, 0.4967, 0.0118, 0.110, (0.060,0.101,0.077,0.081)),\n",
    "    (\"relu_156\",       0.8003, 0.2467, 0.9160, 0.0854, 0.7711, 0.5747, 0.0178, 0.181, (0.137,0.150,0.169,0.168)),\n",
    "    (\"relu_309\",       0.7896, 0.2201, 0.9473, 0.0988, 0.7686, 0.6520, 0.0171, 0.131, (0.306,0.316,0.226,0.192)),\n",
    "    (\"relu_507\",       0.7754, 0.2370, 0.9638, 0.1139, 0.7939, 0.6999, 0.0235, 0.140, (0.068,0.160,0.189,0.200)),\n",
    "    (\"relu_733\",       0.7644, 0.1822, 0.9753, 0.1143, 0.7742, 0.7176, 0.0353, 0.141, (0.128,0.219,0.161,0.156)),\n",
    "\n",
    "    (\"topk_50\",        0.8336, 0.2984, 0.9341, 0.1174, 0.7227, 0.5682, 0.0238, 0.197, (0.236,0.242,0.232,0.214)),\n",
    "    (\"topk_80\",        0.8215, 0.1935, 0.9489, 0.1305, 0.7136, 0.6107, 0.0337, 0.149, (0.166,0.147,0.147,0.143)),\n",
    "    (\"topk_160\",       0.8124, 0.0884, 0.9687, 0.1274, 0.7114, 0.6636, 0.0932, 0.152, (0.060,0.137,0.128,0.154)),\n",
    "    (\"topk_320\",       0.8062, 0.0613, 0.9802, 0.1662, 0.7115, 0.6960, 0.1527, 0.113, (0.320,0.240,0.160,0.124)),\n",
    "    (\"topk_520\",       0.8226, 0.0290, 0.9868, 0.1204, 0.7229, 0.7145, 0.3032, 0.134, (0.000,0.180,0.300,0.296)),\n",
    "    (\"topk_820\",       0.8150, 0.1411, 0.9918, 0.1110, 0.7666, 0.7089, 0.3226, 0.105, (0.270,0.312,0.160,0.074)),\n",
    "]\n",
    "\n",
    "cols = [\n",
    "    \"SAEs\",\"AutoInterp\",\"Absorption\",\"LossRecovered\",\"SCR20\",\"SparseProbingTop1\",\n",
    "    \"RAVEL\",\"TPP20\",\"Steering\",\"Steer_0.1_\",\"Steer_0.01_\",\"Steer_0.001_\",\"Steer_0.0001_\"\n",
    "]\n",
    "\n",
    "rows = []\n",
    "for row in raw:\n",
    "    name, *vals = row\n",
    "    base, thresholds = vals[-2], vals[-1]\n",
    "    rows.append([name, *vals[:-2], base, *thresholds])\n",
    "\n",
    "df = pd.DataFrame(rows, columns=cols)\n",
    "\n",
    "# Add “Prompt score” using the values provided\n",
    "prompt_scores = {\n",
    "    \"batch_topk_50\": 0.694, \"batch_topk_80\": 0.708, \"batch_topk_160\": 0.661,\n",
    "    \"batch_topk_320\": 0.719, \"batch_topk_520\": 0.811, \"batch_topk_820\": 0.727,\n",
    "    \"gated_49\": 0.800, \"gated_78\": 0.663, \"gated_148\": 0.668,\n",
    "    \"gated_340\": 0.728, \"gated_547\": 0.699, \"gated_948\": 0.802,\n",
    "    \"jumprelu_52\": 0.678, \"jumprelu_83\": 0.674, \"jumprelu_165\": 0.736,\n",
    "    \"jumprelu_330\": 0.726, \"jumprelu_538\": 0.746, \"jumprelu_779\": 0.720,\n",
    "    \"relu_54\": 0.745, \"relu_99\": 0.724, \"relu_156\": 0.750,\n",
    "    \"relu_309\": 0.748, \"relu_507\": 0.732, \"relu_733\": 0.737,\n",
    "    \"topk_50\": 0.761, \"topk_80\": 0.723, \"topk_160\": 0.743,\n",
    "    \"topk_320\": 0.733, \"topk_520\": 0.705, \"topk_820\": 0.751,\n",
    "}\n",
    "df[\"Prompt score\"] = df[\"SAEs\"].map(prompt_scores)\n",
    "\n",
    "# Rename columns to requested headers\n",
    "rename_map = {\n",
    "    \"AutoInterp\": \"Interp\",\n",
    "    \"Absorption\": \"Absorb\",\n",
    "    \"LossRecovered\": \"Loss Recovered\",\n",
    "    \"SCR20\": \"SCR@20\",\n",
    "    \"SparseProbingTop1\": \"Sparse Probing Top1\",\n",
    "    \"TPP20\": \"TPP@20\",\n",
    "    \"Steering\": \"SAE score\",\n",
    "}\n",
    "df = df.rename(columns=rename_map)\n",
    "\n",
    "# Split filter columns as separate numeric columns\n",
    "df[\"SAE filter@0.1\"]    = df[\"Steer_0.1_\"]\n",
    "df[\"SAE filter@0.01\"]   = df[\"Steer_0.01_\"]\n",
    "df[\"SAE filter@0.001\"]  = df[\"Steer_0.001_\"]\n",
    "df[\"SAE filter@0.0001\"] = df[\"Steer_0.0001_\"]\n",
    "\n",
    "# Reorder to final output\n",
    "out_cols = [\n",
    "    \"SAEs\", \"Interp\", \"Absorb\", \"Loss Recovered\", \"SCR@20\",\n",
    "    \"Sparse Probing Top1\", \"RAVEL\", \"TPP@20\", \"SAE score\",\n",
    "    \"Prompt score\", \"SAE filter@0.1\", \"SAE filter@0.01\",\n",
    "    \"SAE filter@0.001\", \"SAE filter@0.0001\"\n",
    "]\n",
    "out = df[out_cols].copy()\n",
    "\n",
    "# Append a MEAN row over numeric columns\n",
    "means = out.select_dtypes(include=\"number\").mean()\n",
    "mean_row = {col: \"\" for col in out.columns}\n",
    "mean_row[\"SAEs\"] = \"MEAN\"\n",
    "for col, val in means.items():\n",
    "    mean_row[col] = round(float(val), 6)\n",
    "out_with_mean = pd.concat([out, pd.DataFrame([mean_row])], ignore_index=True)\n",
    "\n",
    "# -----------------------------------------------------------------------------\n",
    "# New part: For each SAE, take the max across filter columns, compare to SAE score,\n",
    "#           compute percentage improvement, and compute the average improvement.\n",
    "# -----------------------------------------------------------------------------\n",
    "filter_cols = [\"SAE filter@0.1\", \"SAE filter@0.01\", \"SAE filter@0.001\", \"SAE filter@0.0001\"]\n",
    "\n",
    "calc = out_with_mean.copy()\n",
    "# Compute best filter value and its name (row-wise)\n",
    "calc[\"Best SAE filter value\"] = calc[filter_cols].apply(pd.to_numeric, errors=\"coerce\").max(axis=1)\n",
    "calc[\"Best SAE filter name\"]  = calc[filter_cols].apply(pd.to_numeric, errors=\"coerce\").idxmax(axis=1)\n",
    "\n",
    "# Percent change relative to \"SAE score\"\n",
    "calc[\"Best vs SAE score (% change)\"] = (\n",
    "    (pd.to_numeric(calc[\"Best SAE filter value\"], errors=\"coerce\") - pd.to_numeric(calc[\"SAE score\"], errors=\"coerce\"))\n",
    "    / pd.to_numeric(calc[\"SAE score\"], errors=\"coerce\") * 100.0\n",
    ")\n",
    "\n",
    "# Do not compute for the MEAN row\n",
    "calc.loc[calc[\"SAEs\"] == \"MEAN\", [\"Best SAE filter value\", \"Best SAE filter name\", \"Best vs SAE score (% change)\"]] = \"\"\n",
    "\n",
    "# Average improvement across all SAE rows (exclude MEAN)\n",
    "avg_improvement_pct = (\n",
    "    pd.to_numeric(calc.loc[calc[\"SAEs\"] != \"MEAN\", \"Best vs SAE score (% change)\"], errors=\"coerce\").mean()\n",
    ")\n",
    "\n",
    "# ----------------------------\n",
    "# Outputs\n",
    "# ----------------------------\n",
    "\n",
    "print(\"\\n=== Per-SAE best filter vs SAE score ===\")\n",
    "display(calc[[\"SAEs\", \"SAE score\", *filter_cols, \"Best SAE filter name\", \"Best SAE filter value\", \"Best vs SAE score (% change)\"]])\n",
    "\n",
    "print(f\"\\n平均最大 filter 相比 SAE score 的提升：{avg_improvement_pct:.6f}%\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "dc6de2ed",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Overall Pearson(sparsity, SAE score): -0.4591\n",
      "Overall Spearman(sparsity, SAE score): -0.4522\n",
      "\n",
      "Correlation by architecture (sparsity ↔ SAE score):\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2916146/3050013609.py:25: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(_corr_by_group)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>arch</th>\n",
       "      <th>n</th>\n",
       "      <th>pearson</th>\n",
       "      <th>spearman</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>batch_topk</td>\n",
       "      <td>6.0</td>\n",
       "      <td>-0.9468</td>\n",
       "      <td>-0.9429</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>gated</td>\n",
       "      <td>6.0</td>\n",
       "      <td>0.1429</td>\n",
       "      <td>0.2571</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>jumprelu</td>\n",
       "      <td>6.0</td>\n",
       "      <td>-0.6826</td>\n",
       "      <td>-0.7714</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>relu</td>\n",
       "      <td>6.0</td>\n",
       "      <td>-0.0680</td>\n",
       "      <td>-0.0857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>topk</td>\n",
       "      <td>6.0</td>\n",
       "      <td>-0.7755</td>\n",
       "      <td>-0.8857</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         arch    n  pearson  spearman\n",
       "0  batch_topk  6.0  -0.9468   -0.9429\n",
       "1       gated  6.0   0.1429    0.2571\n",
       "2    jumprelu  6.0  -0.6826   -0.7714\n",
       "3        relu  6.0  -0.0680   -0.0857\n",
       "4        topk  6.0  -0.7755   -0.8857"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# === Sparsity (from SAEs name) vs \"SAE score\" correlation ===\n",
    "# Extract sparsity and architecture from SAEs column\n",
    "_tmp = df[[\"SAEs\", \"SAE score\"]].copy()\n",
    "_tmp[[\"arch\", \"sparsity\"]] = _tmp[\"SAEs\"].str.rsplit(\"_\", n=1, expand=True)\n",
    "_tmp[\"sparsity\"] = pd.to_numeric(_tmp[\"sparsity\"], errors=\"coerce\")\n",
    "_tmp = _tmp.dropna(subset=[\"sparsity\", \"SAE score\"])\n",
    "\n",
    "# Overall correlations\n",
    "overall_pearson = _tmp[[\"sparsity\", \"SAE score\"]].corr(method=\"pearson\").iloc[0, 1]\n",
    "overall_spearman = _tmp[[\"sparsity\", \"SAE score\"]].corr(method=\"spearman\").iloc[0, 1]\n",
    "\n",
    "print(f\"Overall Pearson(sparsity, SAE score): {overall_pearson:.4f}\")\n",
    "print(f\"Overall Spearman(sparsity, SAE score): {overall_spearman:.4f}\")\n",
    "\n",
    "# Per-architecture correlations\n",
    "def _corr_by_group(g: pd.DataFrame) -> pd.Series:\n",
    "    if g[\"sparsity\"].nunique() < 2:\n",
    "        return pd.Series({\"n\": len(g), \"pearson\": float(\"nan\"), \"spearman\": float(\"nan\")})\n",
    "    pear = g[[\"sparsity\", \"SAE score\"]].corr(method=\"pearson\").iloc[0, 1]\n",
    "    spear = g[[\"sparsity\", \"SAE score\"]].corr(method=\"spearman\").iloc[0, 1]\n",
    "    return pd.Series({\"n\": len(g), \"pearson\": pear, \"spearman\": spear})\n",
    "\n",
    "sparsity_corr_by_arch = (\n",
    "    _tmp.groupby(\"arch\", as_index=False)\n",
    "        .apply(_corr_by_group)\n",
    "        .reset_index(drop=True)\n",
    "        .sort_values(\"arch\")\n",
    ")\n",
    "\n",
    "print(\"\\nCorrelation by architecture (sparsity ↔ SAE score):\")\n",
    "display(sparsity_corr_by_arch.round(4))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "3c04936b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Gemma2-9B-it: Percent improvement over No Filter (%) at each threshold\n",
      "  Threshold @0.1    : L20: 86.35%, L31: 21.45%\n",
      "  Threshold @0.01   : L20: 15.36%, L31: 17.31%\n",
      "  Threshold @0.001  : L20: 27.30%, L31: 7.24%\n",
      "  Threshold @0.0001 : L20: 10.92%, L31: 3.62%\n",
      "\n",
      "Gemma2-2B-it @ L12: Percent improvement over No Filter (%) at each threshold\n",
      "  Threshold @0.1    : 16.87%\n",
      "  Threshold @0.01   : 30.93%\n",
      "  Threshold @0.001  : 26.37%\n",
      "  Threshold @0.0001 : 16.07%\n",
      "\n",
      "(Formula) Improvement(%) = (Filtered score - No Filter score) / No Filter score × 100%\n"
     ]
    }
   ],
   "source": [
    "\n",
    "try:\n",
    "    import pandas as pd\n",
    "except Exception as e:\n",
    "    pd = None\n",
    "    print(\"Warning: pandas not available, falling back to plain printing. Error:\", e)\n",
    "\n",
    "def percent_improvement(scores_dict, thresholds):\n",
    "    \"\"\"\n",
    "    Input:\n",
    "      scores_dict = {'Layer': {'no_filter': float, 0.1: float, 0.01: float, ...}, ...}\n",
    "      thresholds = [0.1, 0.01, 0.001, 0.0001]\n",
    "    Returns:\n",
    "      (scores_df_or_none, improve_df_or_none, improvements_plain)\n",
    "    \"\"\"\n",
    "    improvements_plain = {}\n",
    "    if pd is not None:\n",
    "        # Build DataFrame\n",
    "        df_scores = pd.DataFrame({\n",
    "            layer: {th: vals.get(th, float('nan')) for th in thresholds}\n",
    "            for layer, vals in scores_dict.items()\n",
    "        })\n",
    "        baselines = pd.Series({layer: vals['no_filter'] for layer, vals in scores_dict.items()})\n",
    "        df_improve = (df_scores - baselines) / baselines * 100.0\n",
    "        return df_scores, df_improve, None\n",
    "    else:\n",
    "        for layer, vals in scores_dict.items():\n",
    "            base = vals['no_filter']\n",
    "            improvements_plain[layer] = {th: (vals[th] - base) / base * 100.0 for th in thresholds}\n",
    "        return None, None, improvements_plain\n",
    "\n",
    "# === Gemma2-9B-it (L20, L31) ===\n",
    "thresholds_9b = [0.1, 0.01, 0.001, 0.0001]\n",
    "scores_9b = {\n",
    "    \"L20\": {\"no_filter\": 0.293, 0.1: 0.546, 0.01: 0.338, 0.001: 0.373, 0.0001: 0.325},\n",
    "    \"L31\": {\"no_filter\": 0.387, 0.1: 0.470, 0.01: 0.454, 0.001: 0.415, 0.0001: 0.401},\n",
    "}\n",
    "\n",
    "s9_df, s9_imp_df, s9_plain = percent_improvement(scores_9b, thresholds_9b)\n",
    "\n",
    "print(\"Gemma2-9B-it: Percent improvement over No Filter (%) at each threshold\")\n",
    "if pd is not None:\n",
    "    for th in thresholds_9b:\n",
    "        row = \", \".join([f\"{layer}: {s9_imp_df.loc[th, layer]:.2f}%\" for layer in s9_imp_df.columns])\n",
    "        print(f\"  Threshold @{th:<7}: {row}\")\n",
    "else:\n",
    "    for th in thresholds_9b:\n",
    "        row = \", \".join([f\"{layer}: {s9_plain[layer][th]:.2f}%\" for layer in s9_plain.keys()])\n",
    "        print(f\"  Threshold @{th:<7}: {row}\")\n",
    "\n",
    "\n",
    "# === Our Gemma2-2B-it L12 ===\n",
    "thresholds_2b = [0.1, 0.01, 0.001, 0.0001]\n",
    "scores_2b_L12 = {\n",
    "    \"L12\": {\"no_filter\": 0.132967, 0.1: 0.1554, 0.01: 0.1741, 0.001: 0.168033, 0.0001: 0.154333},\n",
    "}\n",
    "\n",
    "s2_df, s2_imp_df, s2_plain = percent_improvement(scores_2b_L12, thresholds_2b)\n",
    "\n",
    "print(\"\\nGemma2-2B-it @ L12: Percent improvement over No Filter (%) at each threshold\")\n",
    "if pd is not None:\n",
    "    for th in thresholds_2b:\n",
    "        print(f\"  Threshold @{th:<7}: {s2_imp_df.loc[th, 'L12']:.2f}%\")\n",
    "else:\n",
    "    for th in thresholds_2b:\n",
    "        print(f\"  Threshold @{th:<7}: {s2_plain['L12'][th]:.2f}%\")\n",
    "\n",
    "\n",
    "print(\"\\n(Formula) Improvement(%) = (Filtered score - No Filter score) / No Filter score × 100%\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4caf81cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "================================================================================\n",
      "Discovered 30 SAE directories.\n",
      "--------------------------------------------------------------------------------\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_160\n",
      "Base steering score (ALL features avg): 0.145400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.160000 [> base]  lift_vs_base=10.04%\n",
      "    Steer_0.01_    (T=0.01) -> count=6     avg=0.210000 [> base]  lift_vs_base=44.43%\n",
      "    Steer_0.001_   (T=0.001) -> count=10    avg=0.126000  lift_vs_base=-13.34%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=18    avg=0.070000  lift_vs_base=-51.86%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=65.06%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.204000 [> base]  lift_vs_base=40.30%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.126000  lift_vs_base=-13.34%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.075000  lift_vs_base=-48.42%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=6     avg=0.210000 [> base]  lift_vs_base=44.43%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=65.06%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_320\n",
      "Base steering score (ALL features avg): 0.122400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=5     avg=0.240000 [> base]  lift_vs_base=96.08%\n",
      "    Steer_0.01_    (T=0.01) -> count=13    avg=0.207692 [> base]  lift_vs_base=69.68%\n",
      "    Steer_0.001_   (T=0.001) -> count=26    avg=0.131538 [> base]  lift_vs_base=7.47%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=48    avg=0.139583 [> base]  lift_vs_base=14.04%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.360000 [> base]  lift_vs_base=194.12%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.240000 [> base]  lift_vs_base=96.08%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.144000 [> base]  lift_vs_base=17.65%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.159000 [> base]  lift_vs_base=29.90%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=5     avg=0.240000 [> base]  lift_vs_base=96.08%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.360000 [> base]  lift_vs_base=194.12%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_50\n",
      "Base steering score (ALL features avg): 0.151400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=23    avg=0.226087 [> base]  lift_vs_base=49.33%\n",
      "    Steer_0.1_     (T=0.1) -> count=59    avg=0.193220 [> base]  lift_vs_base=27.62%\n",
      "    Steer_0.01_    (T=0.01) -> count=87    avg=0.168506 [> base]  lift_vs_base=11.30%\n",
      "    Steer_0.001_   (T=0.001) -> count=97    avg=0.153608 [> base]  lift_vs_base=1.46%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=99    avg=0.152929 [> base]  lift_vs_base=1.01%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.224000 [> base]  lift_vs_base=47.95%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.220000 [> base]  lift_vs_base=45.31%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.236000 [> base]  lift_vs_base=55.88%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.5_     (T=0.5) -> count=23    avg=0.226087 [> base]  lift_vs_base=49.33%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.236000 [> base]  lift_vs_base=55.88%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_520\n",
      "Base steering score (ALL features avg): 0.117400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.240000 [> base]  lift_vs_base=104.43%\n",
      "    Steer_0.1_     (T=0.1) -> count=5     avg=0.048000  lift_vs_base=-59.11%\n",
      "    Steer_0.01_    (T=0.01) -> count=14    avg=0.185714 [> base]  lift_vs_base=58.19%\n",
      "    Steer_0.001_   (T=0.001) -> count=20    avg=0.142000 [> base]  lift_vs_base=20.95%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=39    avg=0.112821  lift_vs_base=-3.90%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=104.43%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=2.21%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.048000  lift_vs_base=-59.11%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.188000 [> base]  lift_vs_base=60.14%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.142000 [> base]  lift_vs_base=20.95%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.5_     (T=0.5) -> count=1     avg=0.240000 [> base]  lift_vs_base=104.43%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=104.43%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_80\n",
      "Base steering score (ALL features avg): 0.156200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=10    avg=0.078000  lift_vs_base=-50.06%\n",
      "    Steer_0.1_     (T=0.1) -> count=33    avg=0.146667  lift_vs_base=-6.10%\n",
      "    Steer_0.01_    (T=0.01) -> count=57    avg=0.149825  lift_vs_base=-4.08%\n",
      "    Steer_0.001_   (T=0.001) -> count=79    avg=0.164810 [> base]  lift_vs_base=5.51%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=91    avg=0.158462 [> base]  lift_vs_base=1.45%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.300000 [> base]  lift_vs_base=92.06%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.150000  lift_vs_base=-3.97%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.060000  lift_vs_base=-61.59%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.078000  lift_vs_base=-50.06%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.075000  lift_vs_base=-51.98%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=79    avg=0.164810 [> base]  lift_vs_base=5.51%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.300000 [> base]  lift_vs_base=92.06%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_820\n",
      "Base steering score (ALL features avg): 0.106200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=7     avg=0.282857 [> base]  lift_vs_base=166.34%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.244000 [> base]  lift_vs_base=129.76%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=21    avg=0.197143 [> base]  lift_vs_base=85.63%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=12.99%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.336000 [> base]  lift_vs_base=216.38%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.246000 [> base]  lift_vs_base=131.64%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.207000 [> base]  lift_vs_base=94.92%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=7     avg=0.282857 [> base]  lift_vs_base=166.34%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.336000 [> base]  lift_vs_base=216.38%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_148\n",
      "Base steering score (ALL features avg): 0.115800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.180000 [> base]  lift_vs_base=55.44%\n",
      "    Steer_0.01_    (T=0.01) -> count=6     avg=0.120000 [> base]  lift_vs_base=3.63%\n",
      "    Steer_0.001_   (T=0.001) -> count=8     avg=0.090000  lift_vs_base=-22.28%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=18    avg=0.075556  lift_vs_base=-34.75%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.144000 [> base]  lift_vs_base=24.35%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-37.82%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.080000  lift_vs_base=-30.92%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=4     avg=0.180000 [> base]  lift_vs_base=55.44%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.144000 [> base]  lift_vs_base=24.35%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_340\n",
      "Base steering score (ALL features avg): 0.153200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.120000  lift_vs_base=-21.67%\n",
      "    Steer_0.001_   (T=0.001) -> count=8     avg=0.225000 [> base]  lift_vs_base=46.87%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=14    avg=0.142857  lift_vs_base=-6.75%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=56.66%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-37.34%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=17.49%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.127000  lift_vs_base=-17.10%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=8     avg=0.225000 [> base]  lift_vs_base=46.87%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=56.66%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_49\n",
      "Base steering score (ALL features avg): 0.106400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=6     avg=0.120000 [> base]  lift_vs_base=12.78%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=12    avg=0.136667 [> base]  lift_vs_base=28.45%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=125.56%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=12.78%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-9.77%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.120000 [> base]  lift_vs_base=12.78%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.097000  lift_vs_base=-8.83%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=12    avg=0.136667 [> base]  lift_vs_base=28.45%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=125.56%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_547\n",
      "Base steering score (ALL features avg): 0.133800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.160000 [> base]  lift_vs_base=19.58%\n",
      "    Steer_0.001_   (T=0.001) -> count=7     avg=0.145714 [> base]  lift_vs_base=8.90%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=15    avg=0.184000 [> base]  lift_vs_base=37.52%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.144000 [> base]  lift_vs_base=7.62%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=34.53%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.153000 [> base]  lift_vs_base=14.35%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=15    avg=0.184000 [> base]  lift_vs_base=37.52%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=34.53%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_78\n",
      "Base steering score (ALL features avg): 0.088800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=6     avg=0.080000  lift_vs_base=-9.91%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=13    avg=0.083077  lift_vs_base=-6.44%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000 [> base]  lift_vs_base=8.11%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.048000  lift_vs_base=-45.95%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.078000  lift_vs_base=-12.16%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=13    avg=0.083077  lift_vs_base=-6.44%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.096000 [> base]  lift_vs_base=8.11%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_948\n",
      "Base steering score (ALL features avg): 0.102800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=2     avg=0.120000 [> base]  lift_vs_base=16.73%\n",
      "    Steer_0.001_   (T=0.001) -> count=4     avg=0.060000  lift_vs_base=-41.63%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=8     avg=0.157500 [> base]  lift_vs_base=53.21%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=16.73%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.048000  lift_vs_base=-53.31%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.126000 [> base]  lift_vs_base=22.57%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.075000  lift_vs_base=-27.04%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=8     avg=0.157500 [> base]  lift_vs_base=53.21%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.126000 [> base]  lift_vs_base=22.57%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_165\n",
      "Base steering score (ALL features avg): 0.119600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.170000 [> base]  lift_vs_base=42.14%\n",
      "    Steer_0.01_    (T=0.01) -> count=7     avg=0.131429 [> base]  lift_vs_base=9.89%\n",
      "    Steer_0.001_   (T=0.001) -> count=14    avg=0.142857 [> base]  lift_vs_base=19.45%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=31    avg=0.169677 [> base]  lift_vs_base=41.87%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.136000 [> base]  lift_vs_base=13.71%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.116000  lift_vs_base=-3.01%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.185000 [> base]  lift_vs_base=54.68%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=4     avg=0.170000 [> base]  lift_vs_base=42.14%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.185000 [> base]  lift_vs_base=54.68%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_330\n",
      "Base steering score (ALL features avg): 0.105400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.170000 [> base]  lift_vs_base=61.29%\n",
      "    Steer_0.001_   (T=0.001) -> count=10    avg=0.170000 [> base]  lift_vs_base=61.29%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=19    avg=0.152632 [> base]  lift_vs_base=44.81%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.184000 [> base]  lift_vs_base=74.57%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.170000 [> base]  lift_vs_base=61.29%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.157000 [> base]  lift_vs_base=48.96%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=4     avg=0.170000 [> base]  lift_vs_base=61.29%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.184000 [> base]  lift_vs_base=74.57%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_52\n",
      "Base steering score (ALL features avg): 0.175800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=6     avg=0.106667  lift_vs_base=-39.32%\n",
      "    Steer_0.01_    (T=0.01) -> count=15    avg=0.245333 [> base]  lift_vs_base=39.55%\n",
      "    Steer_0.001_   (T=0.001) -> count=31    avg=0.259355 [> base]  lift_vs_base=47.53%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=52    avg=0.228462 [> base]  lift_vs_base=29.96%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.080000  lift_vs_base=-54.49%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.344000 [> base]  lift_vs_base=95.68%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.238000 [> base]  lift_vs_base=35.38%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=31    avg=0.259355 [> base]  lift_vs_base=47.53%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.344000 [> base]  lift_vs_base=95.68%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_538\n",
      "Base steering score (ALL features avg): 0.089200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=10    avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=16    avg=0.057500  lift_vs_base=-35.54%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.058000  lift_vs_base=-34.98%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=16    avg=0.057500  lift_vs_base=-35.54%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.058000  lift_vs_base=-34.98%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_779\n",
      "Base steering score (ALL features avg): 0.119400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=11    avg=0.238182 [> base]  lift_vs_base=99.48%\n",
      "    Steer_0.1_     (T=0.1) -> count=60    avg=0.127333 [> base]  lift_vs_base=6.64%\n",
      "    Steer_0.01_    (T=0.01) -> count=96    avg=0.116250  lift_vs_base=-2.64%\n",
      "    Steer_0.001_   (T=0.001) -> count=99    avg=0.117576  lift_vs_base=-1.53%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=100   avg=0.119400  lift_vs_base=-0.00%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.176000 [> base]  lift_vs_base=47.40%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.262000 [> base]  lift_vs_base=119.43%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.182000 [> base]  lift_vs_base=52.43%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.5_     (T=0.5) -> count=11    avg=0.238182 [> base]  lift_vs_base=99.48%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.262000 [> base]  lift_vs_base=119.43%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_83\n",
      "Base steering score (ALL features avg): 0.178800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=6     avg=0.240000 [> base]  lift_vs_base=34.23%\n",
      "    Steer_0.01_    (T=0.01) -> count=12    avg=0.355000 [> base]  lift_vs_base=98.55%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.352000 [> base]  lift_vs_base=96.87%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=31    avg=0.261935 [> base]  lift_vs_base=46.50%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=34.23%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.192000 [> base]  lift_vs_base=7.38%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.330000 [> base]  lift_vs_base=84.56%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.276000 [> base]  lift_vs_base=54.36%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=12    avg=0.355000 [> base]  lift_vs_base=98.55%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.330000 [> base]  lift_vs_base=84.56%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_156\n",
      "Base steering score (ALL features avg): 0.181000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=6     avg=0.080000  lift_vs_base=-55.80%\n",
      "    Steer_0.1_     (T=0.1) -> count=11    avg=0.130909  lift_vs_base=-27.67%\n",
      "    Steer_0.01_    (T=0.01) -> count=25    avg=0.152000  lift_vs_base=-16.02%\n",
      "    Steer_0.001_   (T=0.001) -> count=42    avg=0.164286  lift_vs_base=-9.23%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=51    avg=0.163529  lift_vs_base=-9.65%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-46.96%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.144000  lift_vs_base=-20.44%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.132000  lift_vs_base=-27.07%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=42    avg=0.164286  lift_vs_base=-9.23%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.144000  lift_vs_base=-20.44%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_309\n",
      "Base steering score (ALL features avg): 0.131400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.400000 [> base]  lift_vs_base=204.41%\n",
      "    Steer_0.1_     (T=0.1) -> count=5     avg=0.428000 [> base]  lift_vs_base=225.72%\n",
      "    Steer_0.01_    (T=0.01) -> count=14    avg=0.361429 [> base]  lift_vs_base=175.06%\n",
      "    Steer_0.001_   (T=0.001) -> count=28    avg=0.257857 [> base]  lift_vs_base=96.24%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=38    avg=0.210526 [> base]  lift_vs_base=60.22%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.400000 [> base]  lift_vs_base=204.41%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.350000 [> base]  lift_vs_base=166.36%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.428000 [> base]  lift_vs_base=225.72%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.238000 [> base]  lift_vs_base=81.13%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.313000 [> base]  lift_vs_base=138.20%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=5     avg=0.428000 [> base]  lift_vs_base=225.72%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.428000 [> base]  lift_vs_base=225.72%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_507\n",
      "Base steering score (ALL features avg): 0.140400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.075000  lift_vs_base=-46.58%\n",
      "    Steer_0.01_    (T=0.01) -> count=13    avg=0.190769 [> base]  lift_vs_base=35.88%\n",
      "    Steer_0.001_   (T=0.001) -> count=24    avg=0.178333 [> base]  lift_vs_base=27.02%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=28    avg=0.197857 [> base]  lift_vs_base=40.92%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.108000  lift_vs_base=-23.08%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.078000  lift_vs_base=-44.44%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.214000 [> base]  lift_vs_base=52.42%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=28    avg=0.197857 [> base]  lift_vs_base=40.92%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.214000 [> base]  lift_vs_base=52.42%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_54\n",
      "Base steering score (ALL features avg): 0.150400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=4     avg=0.060000  lift_vs_base=-60.11%\n",
      "    Steer_0.1_     (T=0.1) -> count=15    avg=0.113333  lift_vs_base=-24.65%\n",
      "    Steer_0.01_    (T=0.01) -> count=26    avg=0.187692 [> base]  lift_vs_base=24.80%\n",
      "    Steer_0.001_   (T=0.001) -> count=38    avg=0.232632 [> base]  lift_vs_base=54.68%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=43    avg=0.239535 [> base]  lift_vs_base=59.27%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=59.57%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000  lift_vs_base=-20.21%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.088000  lift_vs_base=-41.49%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.116000  lift_vs_base=-22.87%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.220000 [> base]  lift_vs_base=46.28%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=43    avg=0.239535 [> base]  lift_vs_base=59.27%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=59.57%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_733\n",
      "Base steering score (ALL features avg): 0.141000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=3     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=6     avg=0.130000  lift_vs_base=-7.80%\n",
      "    Steer_0.01_    (T=0.01) -> count=9     avg=0.260000 [> base]  lift_vs_base=84.40%\n",
      "    Steer_0.001_   (T=0.001) -> count=18    avg=0.170000 [> base]  lift_vs_base=20.57%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=26    avg=0.163846 [> base]  lift_vs_base=16.20%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.156000 [> base]  lift_vs_base=10.64%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.234000 [> base]  lift_vs_base=65.96%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.177000 [> base]  lift_vs_base=25.53%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=9     avg=0.260000 [> base]  lift_vs_base=84.40%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.234000 [> base]  lift_vs_base=65.96%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_99\n",
      "Base steering score (ALL features avg): 0.109800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=10    avg=0.078000  lift_vs_base=-28.96%\n",
      "    Steer_0.01_    (T=0.01) -> count=22    avg=0.100909  lift_vs_base=-8.10%\n",
      "    Steer_0.001_   (T=0.001) -> count=27    avg=0.082222  lift_vs_base=-25.12%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=36    avg=0.087778  lift_vs_base=-20.06%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.060000  lift_vs_base=-45.36%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.078000  lift_vs_base=-28.96%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.111000 [> base]  lift_vs_base=1.09%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=22    avg=0.100909  lift_vs_base=-8.10%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.111000 [> base]  lift_vs_base=1.09%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_160\n",
      "Base steering score (ALL features avg): 0.152200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=2     avg=0.120000  lift_vs_base=-21.16%\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.080000  lift_vs_base=-47.44%\n",
      "    Steer_0.01_    (T=0.01) -> count=7     avg=0.137143  lift_vs_base=-9.89%\n",
      "    Steer_0.001_   (T=0.001) -> count=13    avg=0.147692  lift_vs_base=-2.96%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=28    avg=0.154286 [> base]  lift_vs_base=1.37%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=57.69%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000  lift_vs_base=-21.16%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.144000  lift_vs_base=-5.39%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.144000  lift_vs_base=-5.39%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.108000  lift_vs_base=-29.04%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=28    avg=0.154286 [> base]  lift_vs_base=1.37%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=57.69%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_320\n",
      "Base steering score (ALL features avg): 0.112800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.320000 [> base]  lift_vs_base=183.69%\n",
      "    Steer_0.01_    (T=0.01) -> count=12    avg=0.200000 [> base]  lift_vs_base=77.30%\n",
      "    Steer_0.001_   (T=0.001) -> count=17    avg=0.155294 [> base]  lift_vs_base=37.67%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=36    avg=0.113333 [> base]  lift_vs_base=0.47%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.240000 [> base]  lift_vs_base=112.77%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.240000 [> base]  lift_vs_base=112.77%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.144000 [> base]  lift_vs_base=27.66%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=3     avg=0.320000 [> base]  lift_vs_base=183.69%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.240000 [> base]  lift_vs_base=112.77%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_50\n",
      "Base steering score (ALL features avg): 0.196600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=12    avg=0.251667 [> base]  lift_vs_base=28.01%\n",
      "    Steer_0.1_     (T=0.1) -> count=48    avg=0.224167 [> base]  lift_vs_base=14.02%\n",
      "    Steer_0.01_    (T=0.01) -> count=78    avg=0.217436 [> base]  lift_vs_base=10.60%\n",
      "    Steer_0.001_   (T=0.001) -> count=91    avg=0.202857 [> base]  lift_vs_base=3.18%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=99    avg=0.198586 [> base]  lift_vs_base=1.01%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.460000 [> base]  lift_vs_base=133.98%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.352000 [> base]  lift_vs_base=79.04%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.302000 [> base]  lift_vs_base=53.61%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.175000  lift_vs_base=-10.99%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.5_     (T=0.5) -> count=12    avg=0.251667 [> base]  lift_vs_base=28.01%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.460000 [> base]  lift_vs_base=133.98%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_520\n",
      "Base steering score (ALL features avg): 0.133800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=10    avg=0.204000 [> base]  lift_vs_base=52.47%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.300000 [> base]  lift_vs_base=124.22%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=18    avg=0.303333 [> base]  lift_vs_base=126.71%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.288000 [> base]  lift_vs_base=115.25%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.204000 [> base]  lift_vs_base=52.47%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.285000 [> base]  lift_vs_base=113.00%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=18    avg=0.303333 [> base]  lift_vs_base=126.71%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.288000 [> base]  lift_vs_base=115.25%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_80\n",
      "Base steering score (ALL features avg): 0.148600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=9     avg=0.026667  lift_vs_base=-82.05%\n",
      "    Steer_0.1_     (T=0.1) -> count=30    avg=0.176667 [> base]  lift_vs_base=18.89%\n",
      "    Steer_0.01_    (T=0.01) -> count=50    avg=0.150400 [> base]  lift_vs_base=1.21%\n",
      "    Steer_0.001_   (T=0.001) -> count=67    avg=0.148955 [> base]  lift_vs_base=0.24%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=78    avg=0.144872  lift_vs_base=-2.51%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.024000  lift_vs_base=-83.85%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.144000  lift_vs_base=-3.10%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=30    avg=0.176667 [> base]  lift_vs_base=18.89%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.144000  lift_vs_base=-3.10%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_820\n",
      "Base steering score (ALL features avg): 0.105747  (N=87)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> count=1     avg=0.540000 [> base]  lift_vs_base=410.65%\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.270000 [> base]  lift_vs_base=155.33%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.180000 [> base]  lift_vs_base=70.22%\n",
      "    Steer_0.001_   (T=0.001) -> count=10    avg=0.200000 [> base]  lift_vs_base=89.13%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=22    avg=0.101818  lift_vs_base=-3.72%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.540000 [> base]  lift_vs_base=410.65%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.270000 [> base]  lift_vs_base=155.33%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.352000 [> base]  lift_vs_base=232.87%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.200000 [> base]  lift_vs_base=89.13%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.112000 [> base]  lift_vs_base=5.91%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.5_     (T=0.5) -> count=1     avg=0.540000 [> base]  lift_vs_base=410.65%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.540000 [> base]  lift_vs_base=410.65%\n",
      "\n",
      "================================================================================\n",
      "SUMMARY BY ARCHITECTURE (aggregated over SAEs per architecture)\n",
      "--------------------------------------------------------------------------------\n",
      "\n",
      "[ARCH] batch  | SAEs=6  | Base steering score=0.133167  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> total_count=36     avg_selected=0.172778 [> base]  lift_vs_base=29.75%\n",
      "    Steer_0.1_     (T=0.1) -> total_count=106    avg_selected=0.171321 [> base]  lift_vs_base=28.65%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=184    avg_selected=0.172500 [> base]  lift_vs_base=29.54%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=247    avg_selected=0.158300 [> base]  lift_vs_base=18.87%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=316    avg_selected=0.145759 [> base]  lift_vs_base=9.46%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.090000  lift_vs_base=-32.42%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.165000 [> base]  lift_vs_base=23.90%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.185333 [> base]  lift_vs_base=39.17%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.167000 [> base]  lift_vs_base=25.41%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.149000 [> base]  lift_vs_base=11.89%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.5_     (T=0.5) -> total_count=36     avg_selected=0.172778 [> base]  lift_vs_base=29.75%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=5   (K=5) -> total_count=30     avg_selected=0.185333 [> base]  lift_vs_base=39.17%\n",
      "\n",
      "[ARCH] gated  | SAEs=6  | Base steering score=0.116800  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> total_count=0      avg_selected=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.1_     (T=0.1) -> total_count=8      avg_selected=0.090000  lift_vs_base=-22.95%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=16     avg_selected=0.120000 [> base]  lift_vs_base=2.74%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=39     avg_selected=0.127692 [> base]  lift_vs_base=9.33%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=80     avg_selected=0.126250 [> base]  lift_vs_base=8.09%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.040000  lift_vs_base=-65.75%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.080000  lift_vs_base=-31.51%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.104000  lift_vs_base=-10.96%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.121000 [> base]  lift_vs_base=3.60%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.101667  lift_vs_base=-12.96%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.001_   (T=0.001) -> total_count=39     avg_selected=0.127692 [> base]  lift_vs_base=9.33%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.121000 [> base]  lift_vs_base=3.60%\n",
      "\n",
      "[ARCH] jump  | SAEs=6  | Base steering score=0.131367  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> total_count=11     avg_selected=0.238182 [> base]  lift_vs_base=81.31%\n",
      "    Steer_0.1_     (T=0.1) -> total_count=78     avg_selected=0.133333 [> base]  lift_vs_base=1.50%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=138    avg_selected=0.150000 [> base]  lift_vs_base=14.18%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=179    avg_selected=0.160112 [> base]  lift_vs_base=21.88%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=249    avg_selected=0.164739 [> base]  lift_vs_base=25.40%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.040000  lift_vs_base=-69.55%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.128000  lift_vs_base=-2.56%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.203667 [> base]  lift_vs_base=55.04%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.182667 [> base]  lift_vs_base=39.05%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.5_     (T=0.5) -> total_count=11     avg_selected=0.238182 [> base]  lift_vs_base=81.31%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.203667 [> base]  lift_vs_base=55.04%\n",
      "\n",
      "[ARCH] standard  | SAEs=6  | Base steering score=0.142333  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> total_count=17     avg_selected=0.065882  lift_vs_base=-53.71%\n",
      "    Steer_0.1_     (T=0.1) -> total_count=51     avg_selected=0.140000  lift_vs_base=-1.64%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=109    avg_selected=0.190642 [> base]  lift_vs_base=33.94%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=177    avg_selected=0.183729 [> base]  lift_vs_base=29.08%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=222    avg_selected=0.178378 [> base]  lift_vs_base=25.32%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.106667  lift_vs_base=-25.06%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.078333  lift_vs_base=-44.96%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.156000 [> base]  lift_vs_base=9.60%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.148000 [> base]  lift_vs_base=3.98%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.194500 [> base]  lift_vs_base=36.65%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.01_    (T=0.01) -> total_count=109    avg_selected=0.190642 [> base]  lift_vs_base=33.94%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=20  (K=20) -> total_count=120    avg_selected=0.194500 [> base]  lift_vs_base=36.65%\n",
      "\n",
      "[ARCH] topk  | SAEs=6  | Base steering score=0.142419  (Total features N=587)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> total_count=27     avg_selected=0.149630 [> base]  lift_vs_base=5.06%\n",
      "    Steer_0.1_     (T=0.1) -> total_count=88     avg_selected=0.202273 [> base]  lift_vs_base=42.03%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=160    avg_selected=0.190125 [> base]  lift_vs_base=33.50%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=213    avg_selected=0.185446 [> base]  lift_vs_base=30.21%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=281    avg_selected=0.167473 [> base]  lift_vs_base=17.59%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.130000  lift_vs_base=-8.72%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.141667  lift_vs_base=-0.53%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.229333 [> base]  lift_vs_base=61.03%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.185667 [> base]  lift_vs_base=30.37%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.161333 [> base]  lift_vs_base=13.28%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.1_     (T=0.1) -> total_count=88     avg_selected=0.202273 [> base]  lift_vs_base=42.03%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=5   (K=5) -> total_count=30     avg_selected=0.229333 [> base]  lift_vs_base=61.03%\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS ALL SAEs\n",
      "--------------------------------------------------------------------------------\n",
      "All SAEs | Base steering score=0.133177  (Total features N=2987)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.5_     (T=0.5) -> total_count=91     avg_selected=0.153846 [> base]  lift_vs_base=15.52%\n",
      "    Steer_0.1_     (T=0.1) -> total_count=331    avg_selected=0.163807 [> base]  lift_vs_base=23.00%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=607    avg_selected=0.173904 [> base]  lift_vs_base=30.58%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=855    avg_selected=0.169310 [> base]  lift_vs_base=27.13%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=1148   avg_selected=0.160139 [> base]  lift_vs_base=20.25%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=30     avg_selected=0.073333  lift_vs_base=-44.94%\n",
      "    TOPK_SCORE=2   -> total_count=60     avg_selected=0.101000  lift_vs_base=-24.16%\n",
      "    TOPK_SCORE=5   -> total_count=150    avg_selected=0.160533 [> base]  lift_vs_base=20.54%\n",
      "    TOPK_SCORE=10  -> total_count=300    avg_selected=0.165067 [> base]  lift_vs_base=23.95%\n",
      "    TOPK_SCORE=20  -> total_count=600    avg_selected=0.157833 [> base]  lift_vs_base=18.51%\n",
      "\n",
      "  > Per-SAE selections (averaged across SAEs):\n",
      "    Average Best-Threshold -> avg_count_per_SAE=16.67  avg_lift_vs_base=71.90%\n",
      "    Average Best-TopK      -> avg_count_per_SAE=8.13  avg_lift_vs_base=86.84%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Root paths (example for Gemma 2 2B, layer 12) — update to your actual paths\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",
    "# Score thresholds (read 'score' from output_scores_plus_top20_kconf1.json; select score >= T)\n",
    "STEER_THRESHOLDS: List[Tuple[str, float]] = [\n",
    "    (\"Steer_0.5_\",    0.5),\n",
    "    (\"Steer_0.1_\",    0.1),\n",
    "    (\"Steer_0.01_\",   0.01),\n",
    "    (\"Steer_0.001_\",  0.001),\n",
    "    (\"Steer_0.0001_\", 0.0001),\n",
    "]\n",
    "\n",
    "# Top-K (select top-K features by 'score' descending)\n",
    "TOPK_LIST: List[int] = [1, 2, 5, 10,20]\n",
    "\n",
    "SCORE_FILENAME = \"output_scores_plus_top20_kconf1.json\"\n",
    "EVAL_FILENAME  = \"eval.json\"\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, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only present 'overall' values (missing -> 0 contribution)\n",
    "      - sum_overall over all features that have 'overall'\n",
    "    Note: 0.0 scores are valid and included.\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, sum_overall\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_score_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: score} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"score\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"score\"])\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, 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",
    "      - sum of selected 'overall'\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)\n",
    "    n = len(vals)\n",
    "    ssum = float(sum(vals))\n",
    "    avg = (ssum / n) if n > 0 else 0.0\n",
    "    return n, avg, ssum\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 \" [> base]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection builders\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_by_score_threshold(\n",
    "    score_map: Dict[str, float],\n",
    "    labeled_thresholds: List[Tuple[str, float]],\n",
    ") -> List[Tuple[str, List[str], float]]:\n",
    "    \"\"\"For each (label, threshold), select feature ids where score >= threshold.\"\"\"\n",
    "    levels: List[Tuple[str, List[str], float]] = []\n",
    "    if not score_map:\n",
    "        return levels\n",
    "    for label, thr in labeled_thresholds:\n",
    "        sel = [fid for fid, sc in score_map.items() if sc >= thr]\n",
    "        levels.append((label, sel, thr))\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_by_topk(score_map: Dict[str, float], topk_list: List[int]) -> List[Tuple[str, List[str], int]]:\n",
    "    \"\"\"For each K in topk_list, take the K highest-score features.\"\"\"\n",
    "    levels: List[Tuple[str, List[str], int]] = []\n",
    "    if not score_map:\n",
    "        return levels\n",
    "    sorted_ids = sorted(score_map.keys(), key=lambda x: score_map[x], reverse=True)\n",
    "    for k in sorted(set(topk_list)):\n",
    "        kk = max(0, min(k, len(sorted_ids)))\n",
    "        sel = sorted_ids[:kk]\n",
    "        levels.append((f\"TOPK_SCORE={k}\", sel, k))\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Discovery: SAE list & architecture name\n",
    "# =====================================================================================\n",
    "\n",
    "def infer_architecture_name_from_sae(sae_name: str) -> str:\n",
    "    \"\"\"\n",
    "    In a flat directory, infer architecture name from SAE folder:\n",
    "    - Use prefix before '-' or '_' if exists; otherwise use the whole name.\n",
    "    Adjust this to your naming convention if needed.\n",
    "    \"\"\"\n",
    "    for sep in [\"-\", \"_\"]:\n",
    "        if sep in sae_name:\n",
    "            return sae_name.split(sep)[0]\n",
    "    return sae_name\n",
    "\n",
    "\n",
    "def discover_saes(eval_root: str, entropy_root: str) -> List[Dict[str, str]]:\n",
    "    \"\"\"\n",
    "    Support both directory layouts:\n",
    "    A) Flat:   EVAL_ROOT/<sae>/eval.json\n",
    "               ENTROPY_ROOT/<sae>/output_scores_plus_top20_kconf1.json\n",
    "    B) Nested: EVAL_ROOT/<arch>/<sae>/eval.json\n",
    "               ENTROPY_ROOT/<arch>/<sae>/output_scores_plus_top20_kconf1.json\n",
    "\n",
    "    Returns items: {arch_name, sae_name, eval_path, entropy_path}\n",
    "    \"\"\"\n",
    "    items: List[Dict[str, str]] = []\n",
    "\n",
    "    if not os.path.isdir(eval_root):\n",
    "        return items\n",
    "\n",
    "    for entry in sorted(os.listdir(eval_root)):\n",
    "        path_lvl1 = os.path.join(eval_root, entry)\n",
    "        if not os.path.isdir(path_lvl1):\n",
    "            continue\n",
    "\n",
    "        # Flat\n",
    "        eval_path_flat = os.path.join(path_lvl1, EVAL_FILENAME)\n",
    "        if os.path.isfile(eval_path_flat):\n",
    "            sae_name = entry\n",
    "            arch_name = infer_architecture_name_from_sae(sae_name)\n",
    "            entropy_path_flat = os.path.join(entropy_root, sae_name, SCORE_FILENAME)\n",
    "            entropy_path_hier = os.path.join(entropy_root, arch_name, sae_name, SCORE_FILENAME)\n",
    "            entropy_path = entropy_path_flat if os.path.isfile(entropy_path_flat) else entropy_path_hier\n",
    "\n",
    "            items.append({\n",
    "                \"arch_name\": arch_name,\n",
    "                \"sae_name\": sae_name,\n",
    "                \"eval_path\": eval_path_flat,\n",
    "                \"entropy_path\": entropy_path,\n",
    "            })\n",
    "            continue\n",
    "\n",
    "        # Nested\n",
    "        for entry2 in sorted(os.listdir(path_lvl1)):\n",
    "            path_lvl2 = os.path.join(path_lvl1, entry2)\n",
    "            if not os.path.isdir(path_lvl2):\n",
    "                continue\n",
    "            eval_path_hier = os.path.join(path_lvl2, EVAL_FILENAME)\n",
    "            if os.path.isfile(eval_path_hier):\n",
    "                arch_name = entry\n",
    "                sae_name = entry2\n",
    "                entropy_path = os.path.join(entropy_root, arch_name, sae_name, SCORE_FILENAME)\n",
    "                if not os.path.isfile(entropy_path):\n",
    "                    alt = os.path.join(entropy_root, sae_name, SCORE_FILENAME)\n",
    "                    if os.path.isfile(alt):\n",
    "                        entropy_path = alt\n",
    "                items.append({\n",
    "                    \"arch_name\": arch_name,\n",
    "                    \"sae_name\": sae_name,\n",
    "                    \"eval_path\": eval_path_hier,\n",
    "                    \"entropy_path\": entropy_path,\n",
    "                })\n",
    "\n",
    "    return items\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# SAE processing (with per-SAE \"best\" picks)\n",
    "# =====================================================================================\n",
    "\n",
    "def choose_best_entry(entries: Dict[str, Dict[str, Any]]) -> Optional[Tuple[str, Dict[str, Any]]]:\n",
    "    \"\"\"\n",
    "    Pick the entry with the maximum 'lift_pct'. If None, treat as -inf.\n",
    "    Ties are broken by higher 'avg' then higher 'count'.\n",
    "    Returns (label, stats_dict) or None if entries is empty.\n",
    "    \"\"\"\n",
    "    if not entries:\n",
    "        return None\n",
    "\n",
    "    def score_key(item: Tuple[str, Dict[str, Any]]):\n",
    "        _lab, st = item\n",
    "        lp = st.get(\"lift_pct\", None)\n",
    "        lift_score = -1e30 if (lp is None) else lp\n",
    "        return (lift_score, st.get(\"avg\", 0.0), st.get(\"count\", 0))\n",
    "\n",
    "    return max(entries.items(), key=score_key)\n",
    "\n",
    "\n",
    "def choose_best_from_agg(\n",
    "    agg: Dict[str, Tuple[int, float, Optional[float]]]\n",
    ") -> Optional[Tuple[str, Tuple[int, float, Optional[float]]]]:\n",
    "    \"\"\"\n",
    "    From aggregated dict: label -> (count, avg_selected, lift_pct), choose best by lift,\n",
    "    tie-break by avg_selected then count.\n",
    "    \"\"\"\n",
    "    if not agg:\n",
    "        return None\n",
    "\n",
    "    def key_fn(item):\n",
    "        lab, (cnt, avg_sel, lift) = item\n",
    "        lift_score = -1e30 if lift is None else lift\n",
    "        return (lift_score, avg_sel, cnt)\n",
    "\n",
    "    return max(agg.items(), key=key_fn)\n",
    "\n",
    "\n",
    "def process_one_sae(eval_path: str, entropy_path: Optional[str]) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"\n",
    "    For a single SAE:\n",
    "      - Read eval.json to get baseline (avg over ALL features)\n",
    "      - Read score file and compute:\n",
    "          1) Threshold selections (Steer_* labels)\n",
    "          2) Top-K selections\n",
    "      - Compute per-SAE best threshold and best topK (by lift).\n",
    "      - Return a record including base, per-level stats, and \"best\" picks.\n",
    "    \"\"\"\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        return None\n",
    "\n",
    "    num_features, base_avg, base_sum = compute_base_stats(eval_data)\n",
    "\n",
    "    score_map: Dict[str, float] = {}\n",
    "    if entropy_path and os.path.isfile(entropy_path):\n",
    "        entropy_data = safe_load_json(entropy_path)\n",
    "        if entropy_data is not None:\n",
    "            score_map = build_score_map(entropy_data)\n",
    "\n",
    "    # Thresholds\n",
    "    thr_levels = selection_levels_by_score_threshold(score_map, STEER_THRESHOLDS) if score_map else []\n",
    "    thr_stats: Dict[str, Dict[str, Any]] = {}\n",
    "    for label, selected, thr in thr_levels:\n",
    "        n, avg_sub, ssum = avg_for_selected(eval_data, selected)\n",
    "        lift = pct_lift(avg_sub, base_avg)\n",
    "        thr_stats[label] = {\n",
    "            \"label\": label,\n",
    "            \"threshold\": thr,\n",
    "            \"count\": n,\n",
    "            \"avg\": avg_sub,\n",
    "            \"sum\": ssum,\n",
    "            \"lift_pct\": lift,\n",
    "        }\n",
    "\n",
    "    # Top-K\n",
    "    topk_levels = selection_levels_by_topk(score_map, TOPK_LIST) if score_map else []\n",
    "    topk_stats: Dict[str, Dict[str, Any]] = {}\n",
    "    for label, selected, k in topk_levels:\n",
    "        n, avg_sub, ssum = avg_for_selected(eval_data, selected)\n",
    "        lift = pct_lift(avg_sub, base_avg)\n",
    "        topk_stats[label] = {\n",
    "            \"label\": label,\n",
    "            \"k\": k,\n",
    "            \"count\": n,\n",
    "            \"avg\": avg_sub,\n",
    "            \"sum\": ssum,\n",
    "            \"lift_pct\": lift,\n",
    "        }\n",
    "\n",
    "    # Best picks per SAE\n",
    "    best_thr = choose_best_entry(thr_stats)\n",
    "    best_topk = choose_best_entry(topk_stats)\n",
    "\n",
    "    rec: Dict[str, Any] = {\n",
    "        \"base_num\": num_features,\n",
    "        \"base_avg\": base_avg,\n",
    "        \"base_sum\": base_sum,\n",
    "        \"thr_stats\": thr_stats,\n",
    "        \"topk_stats\": topk_stats,\n",
    "        \"best_thr\": best_thr,\n",
    "        \"best_topk\": best_topk,\n",
    "    }\n",
    "\n",
    "    # Explicit fields for later aggregation\n",
    "    if best_thr is not None:\n",
    "        lab, st = best_thr\n",
    "        rec.update({\n",
    "            \"best_thr_label\": lab,\n",
    "            \"best_thr_count\": st.get(\"count\", 0),\n",
    "            \"best_thr_lift_pct\": st.get(\"lift_pct\", None),\n",
    "        })\n",
    "    else:\n",
    "        rec.update({\"best_thr_label\": None, \"best_thr_count\": 0, \"best_thr_lift_pct\": None})\n",
    "\n",
    "    if best_topk is not None:\n",
    "        lab, st = best_topk\n",
    "        rec.update({\n",
    "            \"best_topk_label\": lab,\n",
    "            \"best_topk_count\": st.get(\"count\", 0),\n",
    "            \"best_topk_lift_pct\": st.get(\"lift_pct\", None),\n",
    "        })\n",
    "    else:\n",
    "        rec.update({\"best_topk_label\": None, \"best_topk_count\": 0, \"best_topk_lift_pct\": None})\n",
    "\n",
    "    return rec\n",
    "\n",
    "\n",
    "def fmt_lift(lift: Optional[float]) -> str:\n",
    "    return \"N/A\" if lift is None else f\"{lift:.2f}%\"\n",
    "\n",
    "\n",
    "def print_per_sae(arch_name: str, sae_name: str, rec: Dict[str, Any]):\n",
    "    print(\"\\n\" + \"-\" * 80)\n",
    "    print(f\"[SAE] arch={arch_name}  name={sae_name}\")\n",
    "    print(f\"Base steering score (ALL features avg): {rec['base_avg']:.6f}  (N={rec['base_num']})\")\n",
    "\n",
    "    # Threshold results\n",
    "    print(\"  > Threshold (score >= T):\")\n",
    "    for label, thr in STEER_THRESHOLDS:\n",
    "        st = rec[\"thr_stats\"].get(label, None)\n",
    "        if st is None:\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> count=0     lift_vs_base=N/A\")\n",
    "        else:\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "\n",
    "    # Top-K results\n",
    "    print(\"  > Top-K (by score desc):\")\n",
    "    for k in sorted(set(TOPK_LIST)):\n",
    "        label = f\"TOPK_SCORE={k}\"\n",
    "        st = rec[\"topk_stats\"].get(label, None)\n",
    "        if st is None:\n",
    "            print(f\"    {label:<14} -> count=0     lift_vs_base=N/A\")\n",
    "        else:\n",
    "            print(f\"    {label:<14} -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "\n",
    "    # Best picks (per SAE) – kept for reference in per-SAE section\n",
    "    print(\"  >> Per-SAE Best selections:\")\n",
    "    if rec[\"best_thr\"] is not None:\n",
    "        lab, st = rec[\"best_thr\"]\n",
    "        thr = st.get(\"threshold\", None)\n",
    "        thr_str = f\"(T={thr:g}) \" if thr is not None else \"\"\n",
    "        print(f\"     Best Threshold: {lab:<14} {thr_str}-> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "    else:\n",
    "        print(\"     Best Threshold: N/A\")\n",
    "\n",
    "    if rec[\"best_topk\"] is not None:\n",
    "        lab, st = rec[\"best_topk\"]\n",
    "        print(f\"     Best Top-K    : {lab:<14} -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "    else:\n",
    "        print(\"     Best Top-K    : N/A\")\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Aggregation by Architecture and Across All\n",
    "# =====================================================================================\n",
    "\n",
    "def aggregate_by_architecture(records: List[Tuple[str, str, Dict[str, Any]]]):\n",
    "    \"\"\"\n",
    "    Input: [(arch_name, sae_name, rec_dict), ...]\n",
    "    Print per-architecture (SAEs per arch) and across-all summaries:\n",
    "      - For each threshold / Top-K: total selected count, pooled avg_selected, lift vs base\n",
    "      - Architecture Best (single choice across SAEs): pick single T/K from the aggregated tables\n",
    "      - Across all SAEs: report the average per-SAE selected count and average per-SAE lift for\n",
    "        each SAE's own best threshold and best topK (no global single T/K).\n",
    "    Baseline for a group is the weighted average over ALL its SAEs:\n",
    "      base_avg = (sum of all features' overall) / (total feature count)\n",
    "    Pooled avg_selected = (sum of selected overall across SAEs) / (total selected count)\n",
    "    \"\"\"\n",
    "    # Group by architecture\n",
    "    by_arch: Dict[str, List[Dict[str, Any]]] = {}\n",
    "    for arch, _sae, rec in records:\n",
    "        by_arch.setdefault(arch, []).append(rec)\n",
    "\n",
    "    # Label orders\n",
    "    thr_labels = [lab for lab, _ in STEER_THRESHOLDS]\n",
    "    topk_labels = [f\"TOPK_SCORE={k}\" for k in sorted(set(TOPK_LIST))]\n",
    "\n",
    "    # helper maps to render T/K values\n",
    "    thr_val_map = {lab: thr for lab, thr in STEER_THRESHOLDS}\n",
    "    topk_val_map = {f\"TOPK_SCORE={k}\": k for k in sorted(set(TOPK_LIST))}\n",
    "\n",
    "    def aggregate_group(group_recs: List[Dict[str, Any]]):\n",
    "        \"\"\"\n",
    "        Returns:\n",
    "          base_avg, base_num_total, base_sum_total,\n",
    "          thr_agg:   label -> (count_total, pooled_avg_selected, lift_pct_vs_base)\n",
    "          topk_agg:  label -> (count_total, pooled_avg_selected, lift_pct_vs_base)\n",
    "          arch_best_single: {\"thr\": (label, tuple), \"topk\": (label, tuple)}\n",
    "        \"\"\"\n",
    "        base_num_total = sum(r[\"base_num\"] for r in group_recs)\n",
    "        base_sum_total = sum(r[\"base_sum\"] for r in group_recs)\n",
    "        base_avg = (base_sum_total / base_num_total) if base_num_total > 0 else 0.0\n",
    "\n",
    "        # Threshold aggregation (pooled)\n",
    "        thr_counts: Dict[str, int] = {lab: 0 for lab in thr_labels}\n",
    "        thr_sums: Dict[str, float] = {lab: 0.0 for lab in thr_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in thr_labels:\n",
    "                st = r[\"thr_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    thr_counts[lab] += int(st[\"count\"])\n",
    "                    thr_sums[lab] += float(st[\"sum\"])\n",
    "\n",
    "        thr_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in thr_labels:\n",
    "            cnt = thr_counts[lab]\n",
    "            avg_sel = (thr_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            thr_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        # Top-K aggregation (pooled)\n",
    "        topk_counts: Dict[str, int] = {lab: 0 for lab in topk_labels}\n",
    "        topk_sums: Dict[str, float] = {lab: 0.0 for lab in topk_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in topk_labels:\n",
    "                st = r[\"topk_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    topk_counts[lab] += int(st[\"count\"])\n",
    "                    topk_sums[lab] += float(st[\"sum\"])\n",
    "\n",
    "        topk_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in topk_labels:\n",
    "            cnt = topk_counts[lab]\n",
    "            avg_sel = (topk_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            topk_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        # Architecture Best (single choice across SAEs)\n",
    "        thr_best_single = choose_best_from_agg(thr_agg)\n",
    "        topk_best_single = choose_best_from_agg(topk_agg)\n",
    "\n",
    "        arch_best_single_dict = {\n",
    "            \"thr\": thr_best_single,   # (label, (cnt, avg_sel, lift))\n",
    "            \"topk\": topk_best_single  # (label, (cnt, avg_sel, lift))\n",
    "        }\n",
    "        return (base_avg, base_num_total, base_sum_total,\n",
    "                thr_agg, topk_agg, arch_best_single_dict)\n",
    "\n",
    "    # Print per-architecture summaries\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY BY ARCHITECTURE (aggregated over SAEs per architecture)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for arch, group_recs in sorted(by_arch.items()):\n",
    "        (base_avg, base_n, _base_sum,\n",
    "         thr_agg, topk_agg, arch_best_single) = aggregate_group(group_recs)\n",
    "\n",
    "        print(f\"\\n[ARCH] {arch}  | SAEs={len(group_recs)}  | Base steering score={base_avg:.6f}  (Total features N={base_n})\")\n",
    "\n",
    "        print(\"  > Threshold (score >= T):\")\n",
    "        for label, thr in STEER_THRESHOLDS:\n",
    "            cnt, avg_sel, lift = thr_agg[label]\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "        print(\"  > Top-K (by score desc):\")\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            label = f\"TOPK_SCORE={k}\"\n",
    "            cnt, avg_sel, lift = topk_agg[label]\n",
    "            print(f\"    {label:<14} -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "        # Architecture Best (single choice across SAEs)\n",
    "        print(\"  > Architecture Best (single choice across SAEs):\")\n",
    "        if arch_best_single[\"thr\"] is not None:\n",
    "            lab, (cnt, avg_sel, lift) = arch_best_single[\"thr\"]\n",
    "            t_val = thr_val_map.get(lab, None)\n",
    "            t_str = f\"(T={t_val:g}) \" if t_val is not None else \"\"\n",
    "            print(f\"    Best Threshold (single T): {lab:<14} {t_str}-> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "        else:\n",
    "            print(\"    Best Threshold (single T): N/A\")\n",
    "\n",
    "        if arch_best_single[\"topk\"] is not None:\n",
    "            lab, (cnt, avg_sel, lift) = arch_best_single[\"topk\"]\n",
    "            k_val = topk_val_map.get(lab, None)\n",
    "            k_str = f\"(K={k_val}) \" if k_val is not None else \"\"\n",
    "            print(f\"    Best Top-K (single K)    : {lab:<14} {k_str}-> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "        else:\n",
    "            print(\"    Best Top-K (single K)    : N/A\")\n",
    "\n",
    "    # Across all SAEs (treat all as one group) — do NOT choose a single global T/K\n",
    "    all_group = [rec for _arch, _sae, rec in records]\n",
    "\n",
    "    # Compute pooled tables across all SAEs (for reference)\n",
    "    def aggregate_all(group_recs: List[Dict[str, Any]]):\n",
    "        base_num_total = sum(r[\"base_num\"] for r in group_recs)\n",
    "        base_sum_total = sum(r[\"base_sum\"] for r in group_recs)\n",
    "        base_avg = (base_sum_total / base_num_total) if base_num_total > 0 else 0.0\n",
    "\n",
    "        thr_counts: Dict[str, int] = {lab: 0 for lab in thr_labels}\n",
    "        thr_sums: Dict[str, float] = {lab: 0.0 for lab in thr_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in thr_labels:\n",
    "                st = r[\"thr_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    thr_counts[lab] += int(st[\"count\"])\n",
    "                    thr_sums[lab] += float(st[\"sum\"])\n",
    "        thr_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in thr_labels:\n",
    "            cnt = thr_counts[lab]\n",
    "            avg_sel = (thr_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            thr_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        topk_counts: Dict[str, int] = {lab: 0 for lab in topk_labels}\n",
    "        topk_sums: Dict[str, float] = {lab: 0.0 for lab in topk_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in topk_labels:\n",
    "                st = r[\"topk_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    topk_counts[lab] += int(st[\"count\"])\n",
    "                    topk_sums[lab] += float(st[\"sum\"])\n",
    "        topk_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in topk_labels:\n",
    "            cnt = topk_counts[lab]\n",
    "            avg_sel = (topk_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            topk_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        return base_avg, base_num_total, thr_agg, topk_agg\n",
    "\n",
    "    all_base_avg, all_base_n, all_thr_agg, all_topk_agg = aggregate_all(all_group)\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS ALL SAEs\")\n",
    "    print(\"-\" * 80)\n",
    "    print(f\"All SAEs | Base steering score={all_base_avg:.6f}  (Total features N={all_base_n})\")\n",
    "\n",
    "    print(\"  > Threshold (score >= T):\")\n",
    "    for label, thr in STEER_THRESHOLDS:\n",
    "        cnt, avg_sel, lift = all_thr_agg[label]\n",
    "        print(f\"    {label:<14} (T={thr:g}) -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, all_base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "    print(\"  > Top-K (by score desc):\")\n",
    "    for k in sorted(set(TOPK_LIST)):\n",
    "        label = f\"TOPK_SCORE={k}\"\n",
    "        cnt, avg_sel, lift = all_topk_agg[label]\n",
    "        print(f\"    {label:<14} -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, all_base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "    # Per your request: do NOT pick a single global best T/K here.\n",
    "    # Instead, average per-SAE selections after each SAE chooses its own best threshold and best topK.\n",
    "    total_saes = len(all_group)\n",
    "    # Treat None lift as 0 for averaging; counts are integers (0 if no selection available)\n",
    "    avg_best_thr_count_per_sae = sum(r.get(\"best_thr_count\", 0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_thr_lift_per_sae  = sum((r.get(\"best_thr_lift_pct\") or 0.0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_topk_count_per_sae = sum(r.get(\"best_topk_count\", 0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_topk_lift_per_sae  = sum((r.get(\"best_topk_lift_pct\") or 0.0) for r in all_group) / max(total_saes, 1)\n",
    "\n",
    "    print(\"\\n  > Per-SAE selections (averaged across SAEs):\")\n",
    "    print(f\"    Average Best-Threshold -> avg_count_per_SAE={avg_best_thr_count_per_sae:.2f}  avg_lift_vs_base={avg_best_thr_lift_per_sae:.2f}%\")\n",
    "    print(f\"    Average Best-TopK      -> avg_count_per_SAE={avg_best_topk_count_per_sae:.2f}  avg_lift_vs_base={avg_best_topk_lift_per_sae:.2f}%\")\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",
    "    # Discover SAEs (flat or nested) and process them\n",
    "    sae_items = discover_saes(EVAL_ROOT, ENTROPY_ROOT)\n",
    "    if not sae_items:\n",
    "        print(f\"No SAEs discovered under: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    records: List[Tuple[str, str, Dict[str, Any]]] = []\n",
    "\n",
    "    print(\"=\" * 80)\n",
    "    print(f\"Discovered {len(sae_items)} SAE directories.\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for item in sae_items:\n",
    "        arch_name = item[\"arch_name\"]\n",
    "        sae_name = item[\"sae_name\"]\n",
    "        eval_path = item[\"eval_path\"]\n",
    "        entropy_path = item[\"entropy_path\"] if item.get(\"entropy_path\") else None\n",
    "\n",
    "        rec = process_one_sae(eval_path, entropy_path)\n",
    "        if rec is None:\n",
    "            print(f\"[SKIP] arch={arch_name}  sae={sae_name}  (missing/invalid eval)\")\n",
    "            continue\n",
    "\n",
    "        # Per-SAE output\n",
    "        print_per_sae(arch_name, sae_name, rec)\n",
    "\n",
    "        records.append((arch_name, sae_name, rec))\n",
    "\n",
    "    if not records:\n",
    "        print(\"No valid SAE records to summarize.\")\n",
    "        return\n",
    "\n",
    "    # Aggregate: by architecture + all SAEs\n",
    "    aggregate_by_architecture(records)\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5862789c",
   "metadata": {},
   "source": [
    "## 4.2 Gemma 2 9b L20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "dd20f8ce",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "================================================================================\n",
      "Discovered 30 SAE directories.\n",
      "--------------------------------------------------------------------------------\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_160\n",
      "Base steering score (ALL features avg): 0.104000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=11    avg=0.105455 [> base]  lift_vs_base=1.40%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=16    avg=0.125000 [> base]  lift_vs_base=20.19%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.048000  lift_vs_base=-53.85%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.124000 [> base]  lift_vs_base=19.23%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=16    avg=0.125000 [> base]  lift_vs_base=20.19%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.124000 [> base]  lift_vs_base=19.23%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_320\n",
      "Base steering score (ALL features avg): 0.183000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.480000 [> base]  lift_vs_base=162.30%\n",
      "    Steer_0.01_    (T=0.01) -> count=6     avg=0.200000 [> base]  lift_vs_base=9.29%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.225333 [> base]  lift_vs_base=23.13%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=27    avg=0.294074 [> base]  lift_vs_base=60.70%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.960000 [> base]  lift_vs_base=424.59%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.480000 [> base]  lift_vs_base=162.30%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.240000 [> base]  lift_vs_base=31.15%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.290000 [> base]  lift_vs_base=58.47%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.271000 [> base]  lift_vs_base=48.09%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=2     avg=0.480000 [> base]  lift_vs_base=162.30%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.960000 [> base]  lift_vs_base=424.59%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_50\n",
      "Base steering score (ALL features avg): 0.171800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=22    avg=0.165455  lift_vs_base=-3.69%\n",
      "    Steer_0.01_    (T=0.01) -> count=39    avg=0.206154 [> base]  lift_vs_base=20.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=50    avg=0.197200 [> base]  lift_vs_base=14.78%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=60    avg=0.168333  lift_vs_base=-2.02%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=4.77%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.182000 [> base]  lift_vs_base=5.94%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=39    avg=0.206154 [> base]  lift_vs_base=20.00%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.182000 [> base]  lift_vs_base=5.94%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_520\n",
      "Base steering score (ALL features avg): 0.169200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=5     avg=0.096000  lift_vs_base=-43.26%\n",
      "    Steer_0.001_   (T=0.001) -> count=16    avg=0.158750  lift_vs_base=-6.18%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=23    avg=0.190435 [> base]  lift_vs_base=12.55%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-43.26%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.126000  lift_vs_base=-25.53%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.199000 [> base]  lift_vs_base=17.61%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=23    avg=0.190435 [> base]  lift_vs_base=12.55%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.199000 [> base]  lift_vs_base=17.61%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_80\n",
      "Base steering score (ALL features avg): 0.208600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=11    avg=0.198182  lift_vs_base=-4.99%\n",
      "    Steer_0.01_    (T=0.01) -> count=26    avg=0.166923  lift_vs_base=-19.98%\n",
      "    Steer_0.001_   (T=0.001) -> count=47    avg=0.188511  lift_vs_base=-9.63%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=62    avg=0.223548 [> base]  lift_vs_base=7.17%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=15.05%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000  lift_vs_base=-42.47%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.048000  lift_vs_base=-76.99%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.194000  lift_vs_base=-7.00%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.121000  lift_vs_base=-41.99%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=62    avg=0.223548 [> base]  lift_vs_base=7.17%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=15.05%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_820\n",
      "Base steering score (ALL features avg): 0.132000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.920000 [> base]  lift_vs_base=596.97%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.306667 [> base]  lift_vs_base=132.32%\n",
      "    Steer_0.001_   (T=0.001) -> count=9     avg=0.215556 [> base]  lift_vs_base=63.30%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=14    avg=0.190000 [> base]  lift_vs_base=43.94%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.920000 [> base]  lift_vs_base=596.97%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.460000 [> base]  lift_vs_base=248.48%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.292000 [> base]  lift_vs_base=121.21%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.194000 [> base]  lift_vs_base=46.97%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.187000 [> base]  lift_vs_base=41.67%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=1     avg=0.920000 [> base]  lift_vs_base=596.97%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.920000 [> base]  lift_vs_base=596.97%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_1070\n",
      "Base steering score (ALL features avg): 0.123200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.480000 [> base]  lift_vs_base=289.61%\n",
      "    Steer_0.01_    (T=0.01) -> count=5     avg=0.144000 [> base]  lift_vs_base=16.88%\n",
      "    Steer_0.001_   (T=0.001) -> count=9     avg=0.180000 [> base]  lift_vs_base=46.10%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=13    avg=0.143077 [> base]  lift_vs_base=16.13%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.480000 [> base]  lift_vs_base=289.61%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=94.81%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.144000 [> base]  lift_vs_base=16.88%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.186000 [> base]  lift_vs_base=50.97%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.168000 [> base]  lift_vs_base=36.36%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=1     avg=0.480000 [> base]  lift_vs_base=289.61%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.480000 [> base]  lift_vs_base=289.61%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_160\n",
      "Base steering score (ALL features avg): 0.138600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.255000 [> base]  lift_vs_base=83.98%\n",
      "    Steer_0.01_    (T=0.01) -> count=10    avg=0.252000 [> base]  lift_vs_base=81.82%\n",
      "    Steer_0.001_   (T=0.001) -> count=19    avg=0.283158 [> base]  lift_vs_base=104.30%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=29    avg=0.220690 [> base]  lift_vs_base=59.23%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.204000 [> base]  lift_vs_base=47.19%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.252000 [> base]  lift_vs_base=81.82%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.269000 [> base]  lift_vs_base=94.08%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=19    avg=0.283158 [> base]  lift_vs_base=104.30%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.269000 [> base]  lift_vs_base=94.08%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_360\n",
      "Base steering score (ALL features avg): 0.131400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.240000 [> base]  lift_vs_base=82.65%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.260000 [> base]  lift_vs_base=97.87%\n",
      "    Steer_0.001_   (T=0.001) -> count=8     avg=0.157500 [> base]  lift_vs_base=19.86%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=14    avg=0.090000  lift_vs_base=-31.51%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=82.65%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.270000 [> base]  lift_vs_base=105.48%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.204000 [> base]  lift_vs_base=55.25%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.126000  lift_vs_base=-4.11%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.123000  lift_vs_base=-6.39%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=3     avg=0.260000 [> base]  lift_vs_base=97.87%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.270000 [> base]  lift_vs_base=105.48%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_53\n",
      "Base steering score (ALL features avg): 0.090000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=4     avg=0.075000  lift_vs_base=-16.67%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=12    avg=0.025000  lift_vs_base=-72.22%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.150000 [> base]  lift_vs_base=66.67%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.060000  lift_vs_base=-33.33%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.030000  lift_vs_base=-66.67%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.042000  lift_vs_base=-53.33%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=4     avg=0.075000  lift_vs_base=-16.67%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.150000 [> base]  lift_vs_base=66.67%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_573\n",
      "Base steering score (ALL features avg): 0.120000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.240000 [> base]  lift_vs_base=100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=6     avg=0.080000  lift_vs_base=-33.33%\n",
      "    Steer_0.001_   (T=0.001) -> count=16    avg=0.093750  lift_vs_base=-21.88%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=33    avg=0.092727  lift_vs_base=-22.73%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.480000 [> base]  lift_vs_base=300.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.240000 [> base]  lift_vs_base=100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-20.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.078000  lift_vs_base=-35.00%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.075000  lift_vs_base=-37.50%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=2     avg=0.240000 [> base]  lift_vs_base=100.00%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.480000 [> base]  lift_vs_base=300.00%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_85\n",
      "Base steering score (ALL features avg): 0.130200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.580000 [> base]  lift_vs_base=345.47%\n",
      "    Steer_0.001_   (T=0.001) -> count=7     avg=0.351429 [> base]  lift_vs_base=169.91%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=14    avg=0.248571 [> base]  lift_vs_base=90.92%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.510000 [> base]  lift_vs_base=291.71%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.492000 [> base]  lift_vs_base=277.88%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.300000 [> base]  lift_vs_base=130.41%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.198000 [> base]  lift_vs_base=52.07%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=3     avg=0.580000 [> base]  lift_vs_base=345.47%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.510000 [> base]  lift_vs_base=291.71%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_164\n",
      "Base steering score (ALL features avg): 0.097600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.080000  lift_vs_base=-18.03%\n",
      "    Steer_0.01_    (T=0.01) -> count=9     avg=0.157778 [> base]  lift_vs_base=61.66%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.146667 [> base]  lift_vs_base=50.27%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=23    avg=0.140000 [> base]  lift_vs_base=43.44%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.144000 [> base]  lift_vs_base=47.54%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.142000 [> base]  lift_vs_base=45.49%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.137000 [> base]  lift_vs_base=40.37%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=9     avg=0.157778 [> base]  lift_vs_base=61.66%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.144000 [> base]  lift_vs_base=47.54%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_327\n",
      "Base steering score (ALL features avg): 0.109400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=3     avg=0.080000  lift_vs_base=-26.87%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=11    avg=0.170909 [> base]  lift_vs_base=56.22%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.280000 [> base]  lift_vs_base=155.94%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.188000 [> base]  lift_vs_base=71.85%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.169000 [> base]  lift_vs_base=54.48%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=11    avg=0.170909 [> base]  lift_vs_base=56.22%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.280000 [> base]  lift_vs_base=155.94%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_51\n",
      "Base steering score (ALL features avg): 0.111000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.160000 [> base]  lift_vs_base=44.14%\n",
      "    Steer_0.01_    (T=0.01) -> count=11    avg=0.294545 [> base]  lift_vs_base=165.36%\n",
      "    Steer_0.001_   (T=0.001) -> count=28    avg=0.205000 [> base]  lift_vs_base=84.68%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=43    avg=0.172558 [> base]  lift_vs_base=55.46%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=8.11%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.156000 [> base]  lift_vs_base=40.54%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.324000 [> base]  lift_vs_base=191.89%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.260000 [> base]  lift_vs_base=134.23%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=11    avg=0.294545 [> base]  lift_vs_base=165.36%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.324000 [> base]  lift_vs_base=191.89%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_529\n",
      "Base steering score (ALL features avg): 0.093600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=5     avg=0.048000  lift_vs_base=-48.72%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=11    avg=0.087273  lift_vs_base=-6.76%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.048000  lift_vs_base=-48.72%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-23.08%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.060000  lift_vs_base=-35.90%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=11    avg=0.087273  lift_vs_base=-6.76%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-23.08%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_786\n",
      "Base steering score (ALL features avg): 0.124400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=28    avg=0.121429  lift_vs_base=-2.39%\n",
      "    Steer_0.01_    (T=0.01) -> count=50    avg=0.119200  lift_vs_base=-4.18%\n",
      "    Steer_0.001_   (T=0.001) -> count=76    avg=0.127368 [> base]  lift_vs_base=2.39%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=88    avg=0.121591  lift_vs_base=-2.26%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.131000 [> base]  lift_vs_base=5.31%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=76    avg=0.127368 [> base]  lift_vs_base=2.39%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.131000 [> base]  lift_vs_base=5.31%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_82\n",
      "Base steering score (ALL features avg): 0.143200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=9     avg=0.248889 [> base]  lift_vs_base=73.81%\n",
      "    Steer_0.001_   (T=0.001) -> count=19    avg=0.191579 [> base]  lift_vs_base=33.78%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=27    avg=0.199259 [> base]  lift_vs_base=39.15%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.156000 [> base]  lift_vs_base=8.94%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.224000 [> base]  lift_vs_base=56.42%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.182000 [> base]  lift_vs_base=27.09%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=9     avg=0.248889 [> base]  lift_vs_base=73.81%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.224000 [> base]  lift_vs_base=56.42%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_108\n",
      "Base steering score (ALL features avg): 0.180400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=12    avg=0.258333 [> base]  lift_vs_base=43.20%\n",
      "    Steer_0.01_    (T=0.01) -> count=26    avg=0.306154 [> base]  lift_vs_base=69.71%\n",
      "    Steer_0.001_   (T=0.001) -> count=38    avg=0.267895 [> base]  lift_vs_base=48.50%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=48    avg=0.254167 [> base]  lift_vs_base=40.89%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-46.78%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.280000 [> base]  lift_vs_base=55.21%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.293000 [> base]  lift_vs_base=62.42%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=26    avg=0.306154 [> base]  lift_vs_base=69.71%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.293000 [> base]  lift_vs_base=62.42%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_167\n",
      "Base steering score (ALL features avg): 0.152400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=20    avg=0.124000  lift_vs_base=-18.64%\n",
      "    Steer_0.001_   (T=0.001) -> count=32    avg=0.163750 [> base]  lift_vs_base=7.45%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=46    avg=0.173913 [> base]  lift_vs_base=14.12%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.048000  lift_vs_base=-68.50%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.204000 [> base]  lift_vs_base=33.86%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.124000  lift_vs_base=-18.64%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=46    avg=0.173913 [> base]  lift_vs_base=14.12%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.204000 [> base]  lift_vs_base=33.86%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_321\n",
      "Base steering score (ALL features avg): 0.119400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.240000 [> base]  lift_vs_base=101.01%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.315000 [> base]  lift_vs_base=163.82%\n",
      "    Steer_0.001_   (T=0.001) -> count=13    avg=0.189231 [> base]  lift_vs_base=58.48%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=19    avg=0.129474 [> base]  lift_vs_base=8.44%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=0.50%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.252000 [> base]  lift_vs_base=111.06%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.222000 [> base]  lift_vs_base=85.93%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.123000 [> base]  lift_vs_base=3.02%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=4     avg=0.315000 [> base]  lift_vs_base=163.82%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.252000 [> base]  lift_vs_base=111.06%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_523\n",
      "Base steering score (ALL features avg): 0.119000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.340000 [> base]  lift_vs_base=185.71%\n",
      "    Steer_0.01_    (T=0.01) -> count=12    avg=0.275000 [> base]  lift_vs_base=131.09%\n",
      "    Steer_0.001_   (T=0.001) -> count=20    avg=0.216000 [> base]  lift_vs_base=81.51%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=27    avg=0.200000 [> base]  lift_vs_base=68.07%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.480000 [> base]  lift_vs_base=303.36%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.390000 [> base]  lift_vs_base=227.73%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.324000 [> base]  lift_vs_base=172.27%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.234000 [> base]  lift_vs_base=96.64%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.216000 [> base]  lift_vs_base=81.51%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=3     avg=0.340000 [> base]  lift_vs_base=185.71%\n",
      "     Best Top-K    : TOPK_SCORE=1   -> count=1     avg=0.480000 [> base]  lift_vs_base=303.36%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_61\n",
      "Base steering score (ALL features avg): 0.138200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=6     avg=0.050000  lift_vs_base=-63.82%\n",
      "    Steer_0.01_    (T=0.01) -> count=12    avg=0.176667 [> base]  lift_vs_base=27.83%\n",
      "    Steer_0.001_   (T=0.001) -> count=24    avg=0.139167 [> base]  lift_vs_base=0.70%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=32    avg=0.131875  lift_vs_base=-4.58%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.060000  lift_vs_base=-56.58%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.212000 [> base]  lift_vs_base=53.40%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.155000 [> base]  lift_vs_base=12.16%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=12    avg=0.176667 [> base]  lift_vs_base=27.83%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.212000 [> base]  lift_vs_base=53.40%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_762\n",
      "Base steering score (ALL features avg): 0.129200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=9     avg=0.140000 [> base]  lift_vs_base=8.36%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.120000  lift_vs_base=-7.12%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=24    avg=0.178333 [> base]  lift_vs_base=38.03%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.048000  lift_vs_base=-62.85%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.126000  lift_vs_base=-2.48%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.126000  lift_vs_base=-2.48%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=24    avg=0.178333 [> base]  lift_vs_base=38.03%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.126000  lift_vs_base=-2.48%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_160\n",
      "Base steering score (ALL features avg): 0.208000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=16    avg=0.173750  lift_vs_base=-16.47%\n",
      "    Steer_0.01_    (T=0.01) -> count=41    avg=0.175122  lift_vs_base=-15.81%\n",
      "    Steer_0.001_   (T=0.001) -> count=60    avg=0.193667  lift_vs_base=-6.89%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=70    avg=0.190000  lift_vs_base=-8.65%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.460000 [> base]  lift_vs_base=121.15%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.184000  lift_vs_base=-11.54%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.140000  lift_vs_base=-32.69%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.151000  lift_vs_base=-27.40%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=60    avg=0.193667  lift_vs_base=-6.89%\n",
      "     Best Top-K    : TOPK_SCORE=2   -> count=2     avg=0.460000 [> base]  lift_vs_base=121.15%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_320\n",
      "Base steering score (ALL features avg): 0.175400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=8     avg=0.187500 [> base]  lift_vs_base=6.90%\n",
      "    Steer_0.01_    (T=0.01) -> count=26    avg=0.215385 [> base]  lift_vs_base=22.80%\n",
      "    Steer_0.001_   (T=0.001) -> count=47    avg=0.223404 [> base]  lift_vs_base=27.37%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=65    avg=0.205846 [> base]  lift_vs_base=17.36%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000  lift_vs_base=-31.58%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.300000 [> base]  lift_vs_base=71.04%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.278000 [> base]  lift_vs_base=58.49%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.280000 [> base]  lift_vs_base=59.64%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=47    avg=0.223404 [> base]  lift_vs_base=27.37%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.300000 [> base]  lift_vs_base=71.04%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_50\n",
      "Base steering score (ALL features avg): 0.242600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=20    avg=0.177000  lift_vs_base=-27.04%\n",
      "    Steer_0.01_    (T=0.01) -> count=41    avg=0.293659 [> base]  lift_vs_base=21.05%\n",
      "    Steer_0.001_   (T=0.001) -> count=60    avg=0.291000 [> base]  lift_vs_base=19.95%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=81    avg=0.266914 [> base]  lift_vs_base=10.02%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-70.32%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.177000  lift_vs_base=-27.04%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=41    avg=0.293659 [> base]  lift_vs_base=21.05%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.177000  lift_vs_base=-27.04%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_520\n",
      "Base steering score (ALL features avg): 0.116200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.120000 [> base]  lift_vs_base=3.27%\n",
      "    Steer_0.01_    (T=0.01) -> count=6     avg=0.220000 [> base]  lift_vs_base=89.33%\n",
      "    Steer_0.001_   (T=0.001) -> count=14    avg=0.162857 [> base]  lift_vs_base=40.15%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=23    avg=0.099130  lift_vs_base=-14.69%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.240000 [> base]  lift_vs_base=106.54%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.120000 [> base]  lift_vs_base=3.27%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.264000 [> base]  lift_vs_base=127.19%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=54.91%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.114000  lift_vs_base=-1.89%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=6     avg=0.220000 [> base]  lift_vs_base=89.33%\n",
      "     Best Top-K    : TOPK_SCORE=5   -> count=5     avg=0.264000 [> base]  lift_vs_base=127.19%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_80\n",
      "Base steering score (ALL features avg): 0.184000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=15    avg=0.200000 [> base]  lift_vs_base=8.70%\n",
      "    Steer_0.01_    (T=0.01) -> count=35    avg=0.266857 [> base]  lift_vs_base=45.03%\n",
      "    Steer_0.001_   (T=0.001) -> count=46    avg=0.270435 [> base]  lift_vs_base=46.98%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=56    avg=0.222143 [> base]  lift_vs_base=20.73%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.096000  lift_vs_base=-47.83%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-60.87%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.246000 [> base]  lift_vs_base=33.70%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=46    avg=0.270435 [> base]  lift_vs_base=46.98%\n",
      "     Best Top-K    : TOPK_SCORE=20  -> count=20    avg=0.246000 [> base]  lift_vs_base=33.70%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_820\n",
      "Base steering score (ALL features avg): 0.116000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=11    avg=0.223636 [> base]  lift_vs_base=92.79%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=17    avg=0.227059 [> base]  lift_vs_base=95.74%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=5   -> count=5     avg=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.246000 [> base]  lift_vs_base=112.07%\n",
      "    TOPK_SCORE=20  -> count=20    avg=0.217000 [> base]  lift_vs_base=87.07%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=17    avg=0.227059 [> base]  lift_vs_base=95.74%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.246000 [> base]  lift_vs_base=112.07%\n",
      "\n",
      "================================================================================\n",
      "SUMMARY BY ARCHITECTURE (aggregated over SAEs per architecture)\n",
      "--------------------------------------------------------------------------------\n",
      "\n",
      "[ARCH] batch  | SAEs=6  | Base steering score=0.161433  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=38     avg_selected=0.202632 [> base]  lift_vs_base=25.52%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=83     avg_selected=0.180482 [> base]  lift_vs_base=11.80%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=148    avg_selected=0.187432 [> base]  lift_vs_base=16.11%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=202    avg_selected=0.202673 [> base]  lift_vs_base=25.55%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.353333 [> base]  lift_vs_base=118.87%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.176667 [> base]  lift_vs_base=9.44%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.112667  lift_vs_base=-30.21%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.172000 [> base]  lift_vs_base=6.55%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.180667 [> base]  lift_vs_base=11.91%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.0001_  (T=0.0001) -> total_count=202    avg_selected=0.202673 [> base]  lift_vs_base=25.55%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=1   (K=1) -> total_count=6      avg_selected=0.353333 [> base]  lift_vs_base=118.87%\n",
      "\n",
      "[ARCH] gated  | SAEs=6  | Base steering score=0.122233  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=9      avg_selected=0.246667 [> base]  lift_vs_base=101.80%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=27     avg_selected=0.231111 [> base]  lift_vs_base=89.07%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=63     avg_selected=0.198730 [> base]  lift_vs_base=62.58%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=115    avg_selected=0.142261 [> base]  lift_vs_base=16.38%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.200000 [> base]  lift_vs_base=63.62%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.235000 [> base]  lift_vs_base=92.26%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.200000 [> base]  lift_vs_base=63.62%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.162000 [> base]  lift_vs_base=32.53%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.145833 [> base]  lift_vs_base=19.31%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.1_     (T=0.1) -> total_count=9      avg_selected=0.246667 [> base]  lift_vs_base=101.80%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=2   (K=2) -> total_count=12     avg_selected=0.235000 [> base]  lift_vs_base=92.26%\n",
      "\n",
      "[ARCH] jump  | SAEs=6  | Base steering score=0.113200  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=36     avg_selected=0.114444 [> base]  lift_vs_base=1.10%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=82     avg_selected=0.156829 [> base]  lift_vs_base=38.54%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=146    avg_selected=0.148904 [> base]  lift_vs_base=31.54%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=203    avg_selected=0.145616 [> base]  lift_vs_base=28.64%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.000000  lift_vs_base=-100.00%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.020000  lift_vs_base=-82.33%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.130667 [> base]  lift_vs_base=15.43%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.158333 [> base]  lift_vs_base=39.87%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.156500 [> base]  lift_vs_base=38.25%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.01_    (T=0.01) -> total_count=82     avg_selected=0.156829 [> base]  lift_vs_base=38.54%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.158333 [> base]  lift_vs_base=39.87%\n",
      "\n",
      "[ARCH] standard  | SAEs=6  | Base steering score=0.139767  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=31     avg_selected=0.165806 [> base]  lift_vs_base=18.63%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=83     avg_selected=0.221446 [> base]  lift_vs_base=58.44%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=142    avg_selected=0.192535 [> base]  lift_vs_base=37.75%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=196    avg_selected=0.186531 [> base]  lift_vs_base=33.46%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.080000  lift_vs_base=-42.76%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.085000  lift_vs_base=-39.18%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.138000  lift_vs_base=-1.26%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.213000 [> base]  lift_vs_base=52.40%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.172833 [> base]  lift_vs_base=23.66%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.01_    (T=0.01) -> total_count=83     avg_selected=0.221446 [> base]  lift_vs_base=58.44%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.213000 [> base]  lift_vs_base=52.40%\n",
      "\n",
      "[ARCH] topk  | SAEs=6  | Base steering score=0.173700  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=61     avg_selected=0.181311 [> base]  lift_vs_base=4.38%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=153    avg_selected=0.231895 [> base]  lift_vs_base=33.50%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=238    avg_selected=0.238487 [> base]  lift_vs_base=37.30%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=312    avg_selected=0.214359 [> base]  lift_vs_base=23.41%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=6      avg_selected=0.040000  lift_vs_base=-76.97%\n",
      "    TOPK_SCORE=2   -> total_count=12     avg_selected=0.116667  lift_vs_base=-32.83%\n",
      "    TOPK_SCORE=5   -> total_count=30     avg_selected=0.140667  lift_vs_base=-19.02%\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.164667  lift_vs_base=-5.20%\n",
      "    TOPK_SCORE=20  -> total_count=120    avg_selected=0.197500 [> base]  lift_vs_base=13.70%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.001_   (T=0.001) -> total_count=238    avg_selected=0.238487 [> base]  lift_vs_base=37.30%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=20  (K=20) -> total_count=120    avg_selected=0.197500 [> base]  lift_vs_base=13.70%\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS ALL SAEs\n",
      "--------------------------------------------------------------------------------\n",
      "All SAEs | Base steering score=0.142067  (Total features N=3000)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=175    avg_selected=0.172800 [> base]  lift_vs_base=21.63%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=428    avg_selected=0.205467 [> base]  lift_vs_base=44.63%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=737    avg_selected=0.198236 [> base]  lift_vs_base=39.54%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=1028   avg_selected=0.185117 [> base]  lift_vs_base=30.30%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=1   -> total_count=30     avg_selected=0.134667  lift_vs_base=-5.21%\n",
      "    TOPK_SCORE=2   -> total_count=60     avg_selected=0.126667  lift_vs_base=-10.84%\n",
      "    TOPK_SCORE=5   -> total_count=150    avg_selected=0.144400 [> base]  lift_vs_base=1.64%\n",
      "    TOPK_SCORE=10  -> total_count=300    avg_selected=0.174000 [> base]  lift_vs_base=22.48%\n",
      "    TOPK_SCORE=20  -> total_count=600    avg_selected=0.170667 [> base]  lift_vs_base=20.13%\n",
      "\n",
      "  > Per-SAE selections (averaged across SAEs):\n",
      "    Average Best-Threshold -> avg_count_per_SAE=21.13  avg_lift_vs_base=95.51%\n",
      "    Average Best-TopK      -> avg_count_per_SAE=9.30  avg_lift_vs_base=122.02%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Root paths (example for Gemma 2 2B, layer 12) — update to your actual paths\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",
    "# Score thresholds (read 'score' from output_scores_plus_top20_kconf1.json; select score >= T)\n",
    "STEER_THRESHOLDS: List[Tuple[str, float]] = [\n",
    "    (\"Steer_0.1_\",    0.1),\n",
    "    (\"Steer_0.01_\",   0.01),\n",
    "    (\"Steer_0.001_\",  0.001),\n",
    "    (\"Steer_0.0001_\", 0.0001),\n",
    "]\n",
    "\n",
    "# Top-K (select top-K features by 'score' descending)\n",
    "TOPK_LIST: List[int] = [1, 2, 5, 10, 20]\n",
    "\n",
    "SCORE_FILENAME = \"output_scores_plus_top20_kconf1.json\"\n",
    "EVAL_FILENAME  = \"eval.json\"\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, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only present 'overall' values (missing -> 0 contribution)\n",
    "      - sum_overall over all features that have 'overall'\n",
    "    Note: 0.0 scores are valid and included.\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, sum_overall\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_score_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: score} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"score\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"score\"])\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, 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",
    "      - sum of selected 'overall'\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)\n",
    "    n = len(vals)\n",
    "    ssum = float(sum(vals))\n",
    "    avg = (ssum / n) if n > 0 else 0.0\n",
    "    return n, avg, ssum\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 \" [> base]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection builders\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_by_score_threshold(\n",
    "    score_map: Dict[str, float],\n",
    "    labeled_thresholds: List[Tuple[str, float]],\n",
    ") -> List[Tuple[str, List[str], float]]:\n",
    "    \"\"\"For each (label, threshold), select feature ids where score >= threshold.\"\"\"\n",
    "    levels: List[Tuple[str, List[str], float]] = []\n",
    "    if not score_map:\n",
    "        return levels\n",
    "    for label, thr in labeled_thresholds:\n",
    "        sel = [fid for fid, sc in score_map.items() if sc >= thr]\n",
    "        levels.append((label, sel, thr))\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_by_topk(score_map: Dict[str, float], topk_list: List[int]) -> List[Tuple[str, List[str], int]]:\n",
    "    \"\"\"For each K in topk_list, take the K highest-score features.\"\"\"\n",
    "    levels: List[Tuple[str, List[str], int]] = []\n",
    "    if not score_map:\n",
    "        return levels\n",
    "    sorted_ids = sorted(score_map.keys(), key=lambda x: score_map[x], reverse=True)\n",
    "    for k in sorted(set(topk_list)):\n",
    "        kk = max(0, min(k, len(sorted_ids)))\n",
    "        sel = sorted_ids[:kk]\n",
    "        levels.append((f\"TOPK_SCORE={k}\", sel, k))\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Discovery: SAE list & architecture name\n",
    "# =====================================================================================\n",
    "\n",
    "def infer_architecture_name_from_sae(sae_name: str) -> str:\n",
    "    \"\"\"\n",
    "    In a flat directory, infer architecture name from SAE folder:\n",
    "    - Use prefix before '-' or '_' if exists; otherwise use the whole name.\n",
    "    Adjust this to your naming convention if needed.\n",
    "    \"\"\"\n",
    "    for sep in [\"-\", \"_\"]:\n",
    "        if sep in sae_name:\n",
    "            return sae_name.split(sep)[0]\n",
    "    return sae_name\n",
    "\n",
    "\n",
    "def discover_saes(eval_root: str, entropy_root: str) -> List[Dict[str, str]]:\n",
    "    \"\"\"\n",
    "    Support both directory layouts:\n",
    "    A) Flat:   EVAL_ROOT/<sae>/eval.json\n",
    "               ENTROPY_ROOT/<sae>/output_scores_plus_top20_kconf1.json\n",
    "    B) Nested: EVAL_ROOT/<arch>/<sae>/eval.json\n",
    "               ENTROPY_ROOT/<arch>/<sae>/output_scores_plus_top20_kconf1.json\n",
    "\n",
    "    Returns items: {arch_name, sae_name, eval_path, entropy_path}\n",
    "    \"\"\"\n",
    "    items: List[Dict[str, str]] = []\n",
    "\n",
    "    if not os.path.isdir(eval_root):\n",
    "        return items\n",
    "\n",
    "    for entry in sorted(os.listdir(eval_root)):\n",
    "        path_lvl1 = os.path.join(eval_root, entry)\n",
    "        if not os.path.isdir(path_lvl1):\n",
    "            continue\n",
    "\n",
    "        # Flat\n",
    "        eval_path_flat = os.path.join(path_lvl1, EVAL_FILENAME)\n",
    "        if os.path.isfile(eval_path_flat):\n",
    "            sae_name = entry\n",
    "            arch_name = infer_architecture_name_from_sae(sae_name)\n",
    "            entropy_path_flat = os.path.join(entropy_root, sae_name, SCORE_FILENAME)\n",
    "            entropy_path_hier = os.path.join(entropy_root, arch_name, sae_name, SCORE_FILENAME)\n",
    "            entropy_path = entropy_path_flat if os.path.isfile(entropy_path_flat) else entropy_path_hier\n",
    "\n",
    "            items.append({\n",
    "                \"arch_name\": arch_name,\n",
    "                \"sae_name\": sae_name,\n",
    "                \"eval_path\": eval_path_flat,\n",
    "                \"entropy_path\": entropy_path,\n",
    "            })\n",
    "            continue\n",
    "\n",
    "        # Nested\n",
    "        for entry2 in sorted(os.listdir(path_lvl1)):\n",
    "            path_lvl2 = os.path.join(path_lvl1, entry2)\n",
    "            if not os.path.isdir(path_lvl2):\n",
    "                continue\n",
    "            eval_path_hier = os.path.join(path_lvl2, EVAL_FILENAME)\n",
    "            if os.path.isfile(eval_path_hier):\n",
    "                arch_name = entry\n",
    "                sae_name = entry2\n",
    "                entropy_path = os.path.join(entropy_root, arch_name, sae_name, SCORE_FILENAME)\n",
    "                if not os.path.isfile(entropy_path):\n",
    "                    alt = os.path.join(entropy_root, sae_name, SCORE_FILENAME)\n",
    "                    if os.path.isfile(alt):\n",
    "                        entropy_path = alt\n",
    "                items.append({\n",
    "                    \"arch_name\": arch_name,\n",
    "                    \"sae_name\": sae_name,\n",
    "                    \"eval_path\": eval_path_hier,\n",
    "                    \"entropy_path\": entropy_path,\n",
    "                })\n",
    "\n",
    "    return items\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# SAE processing (with per-SAE \"best\" picks)\n",
    "# =====================================================================================\n",
    "\n",
    "def choose_best_entry(entries: Dict[str, Dict[str, Any]]) -> Optional[Tuple[str, Dict[str, Any]]]:\n",
    "    \"\"\"\n",
    "    Pick the entry with the maximum 'lift_pct'. If None, treat as -inf.\n",
    "    Ties are broken by higher 'avg' then higher 'count'.\n",
    "    Returns (label, stats_dict) or None if entries is empty.\n",
    "    \"\"\"\n",
    "    if not entries:\n",
    "        return None\n",
    "\n",
    "    def score_key(item: Tuple[str, Dict[str, Any]]):\n",
    "        _lab, st = item\n",
    "        lp = st.get(\"lift_pct\", None)\n",
    "        lift_score = -1e30 if (lp is None) else lp\n",
    "        return (lift_score, st.get(\"avg\", 0.0), st.get(\"count\", 0))\n",
    "\n",
    "    return max(entries.items(), key=score_key)\n",
    "\n",
    "\n",
    "def choose_best_from_agg(\n",
    "    agg: Dict[str, Tuple[int, float, Optional[float]]]\n",
    ") -> Optional[Tuple[str, Tuple[int, float, Optional[float]]]]:\n",
    "    \"\"\"\n",
    "    From aggregated dict: label -> (count, avg_selected, lift_pct), choose best by lift,\n",
    "    tie-break by avg_selected then count.\n",
    "    \"\"\"\n",
    "    if not agg:\n",
    "        return None\n",
    "\n",
    "    def key_fn(item):\n",
    "        lab, (cnt, avg_sel, lift) = item\n",
    "        lift_score = -1e30 if lift is None else lift\n",
    "        return (lift_score, avg_sel, cnt)\n",
    "\n",
    "    return max(agg.items(), key=key_fn)\n",
    "\n",
    "\n",
    "def process_one_sae(eval_path: str, entropy_path: Optional[str]) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"\n",
    "    For a single SAE:\n",
    "      - Read eval.json to get baseline (avg over ALL features)\n",
    "      - Read score file and compute:\n",
    "          1) Threshold selections (Steer_* labels)\n",
    "          2) Top-K selections\n",
    "      - Compute per-SAE best threshold and best topK (by lift).\n",
    "      - Return a record including base, per-level stats, and \"best\" picks.\n",
    "    \"\"\"\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        return None\n",
    "\n",
    "    num_features, base_avg, base_sum = compute_base_stats(eval_data)\n",
    "\n",
    "    score_map: Dict[str, float] = {}\n",
    "    if entropy_path and os.path.isfile(entropy_path):\n",
    "        entropy_data = safe_load_json(entropy_path)\n",
    "        if entropy_data is not None:\n",
    "            score_map = build_score_map(entropy_data)\n",
    "\n",
    "    # Thresholds\n",
    "    thr_levels = selection_levels_by_score_threshold(score_map, STEER_THRESHOLDS) if score_map else []\n",
    "    thr_stats: Dict[str, Dict[str, Any]] = {}\n",
    "    for label, selected, thr in thr_levels:\n",
    "        n, avg_sub, ssum = avg_for_selected(eval_data, selected)\n",
    "        lift = pct_lift(avg_sub, base_avg)\n",
    "        thr_stats[label] = {\n",
    "            \"label\": label,\n",
    "            \"threshold\": thr,\n",
    "            \"count\": n,\n",
    "            \"avg\": avg_sub,\n",
    "            \"sum\": ssum,\n",
    "            \"lift_pct\": lift,\n",
    "        }\n",
    "\n",
    "    # Top-K\n",
    "    topk_levels = selection_levels_by_topk(score_map, TOPK_LIST) if score_map else []\n",
    "    topk_stats: Dict[str, Dict[str, Any]] = {}\n",
    "    for label, selected, k in topk_levels:\n",
    "        n, avg_sub, ssum = avg_for_selected(eval_data, selected)\n",
    "        lift = pct_lift(avg_sub, base_avg)\n",
    "        topk_stats[label] = {\n",
    "            \"label\": label,\n",
    "            \"k\": k,\n",
    "            \"count\": n,\n",
    "            \"avg\": avg_sub,\n",
    "            \"sum\": ssum,\n",
    "            \"lift_pct\": lift,\n",
    "        }\n",
    "\n",
    "    # Best picks per SAE\n",
    "    best_thr = choose_best_entry(thr_stats)\n",
    "    best_topk = choose_best_entry(topk_stats)\n",
    "\n",
    "    rec: Dict[str, Any] = {\n",
    "        \"base_num\": num_features,\n",
    "        \"base_avg\": base_avg,\n",
    "        \"base_sum\": base_sum,\n",
    "        \"thr_stats\": thr_stats,\n",
    "        \"topk_stats\": topk_stats,\n",
    "        \"best_thr\": best_thr,\n",
    "        \"best_topk\": best_topk,\n",
    "    }\n",
    "\n",
    "    # Explicit fields for later aggregation\n",
    "    if best_thr is not None:\n",
    "        lab, st = best_thr\n",
    "        rec.update({\n",
    "            \"best_thr_label\": lab,\n",
    "            \"best_thr_count\": st.get(\"count\", 0),\n",
    "            \"best_thr_lift_pct\": st.get(\"lift_pct\", None),\n",
    "        })\n",
    "    else:\n",
    "        rec.update({\"best_thr_label\": None, \"best_thr_count\": 0, \"best_thr_lift_pct\": None})\n",
    "\n",
    "    if best_topk is not None:\n",
    "        lab, st = best_topk\n",
    "        rec.update({\n",
    "            \"best_topk_label\": lab,\n",
    "            \"best_topk_count\": st.get(\"count\", 0),\n",
    "            \"best_topk_lift_pct\": st.get(\"lift_pct\", None),\n",
    "        })\n",
    "    else:\n",
    "        rec.update({\"best_topk_label\": None, \"best_topk_count\": 0, \"best_topk_lift_pct\": None})\n",
    "\n",
    "    return rec\n",
    "\n",
    "\n",
    "def fmt_lift(lift: Optional[float]) -> str:\n",
    "    return \"N/A\" if lift is None else f\"{lift:.2f}%\"\n",
    "\n",
    "\n",
    "def print_per_sae(arch_name: str, sae_name: str, rec: Dict[str, Any]):\n",
    "    print(\"\\n\" + \"-\" * 80)\n",
    "    print(f\"[SAE] arch={arch_name}  name={sae_name}\")\n",
    "    print(f\"Base steering score (ALL features avg): {rec['base_avg']:.6f}  (N={rec['base_num']})\")\n",
    "\n",
    "    # Threshold results\n",
    "    print(\"  > Threshold (score >= T):\")\n",
    "    for label, thr in STEER_THRESHOLDS:\n",
    "        st = rec[\"thr_stats\"].get(label, None)\n",
    "        if st is None:\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> count=0     lift_vs_base=N/A\")\n",
    "        else:\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "\n",
    "    # Top-K results\n",
    "    print(\"  > Top-K (by score desc):\")\n",
    "    for k in sorted(set(TOPK_LIST)):\n",
    "        label = f\"TOPK_SCORE={k}\"\n",
    "        st = rec[\"topk_stats\"].get(label, None)\n",
    "        if st is None:\n",
    "            print(f\"    {label:<14} -> count=0     lift_vs_base=N/A\")\n",
    "        else:\n",
    "            print(f\"    {label:<14} -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "\n",
    "    # Best picks (per SAE) – kept for reference in per-SAE section\n",
    "    print(\"  >> Per-SAE Best selections:\")\n",
    "    if rec[\"best_thr\"] is not None:\n",
    "        lab, st = rec[\"best_thr\"]\n",
    "        thr = st.get(\"threshold\", None)\n",
    "        thr_str = f\"(T={thr:g}) \" if thr is not None else \"\"\n",
    "        print(f\"     Best Threshold: {lab:<14} {thr_str}-> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "    else:\n",
    "        print(\"     Best Threshold: N/A\")\n",
    "\n",
    "    if rec[\"best_topk\"] is not None:\n",
    "        lab, st = rec[\"best_topk\"]\n",
    "        print(f\"     Best Top-K    : {lab:<14} -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "    else:\n",
    "        print(\"     Best Top-K    : N/A\")\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Aggregation by Architecture and Across All\n",
    "# =====================================================================================\n",
    "\n",
    "def aggregate_by_architecture(records: List[Tuple[str, str, Dict[str, Any]]]):\n",
    "    \"\"\"\n",
    "    Input: [(arch_name, sae_name, rec_dict), ...]\n",
    "    Print per-architecture (SAEs per arch) and across-all summaries:\n",
    "      - For each threshold / Top-K: total selected count, pooled avg_selected, lift vs base\n",
    "      - Architecture Best (single choice across SAEs): pick single T/K from the aggregated tables\n",
    "      - Across all SAEs: report the average per-SAE selected count and average per-SAE lift for\n",
    "        each SAE's own best threshold and best topK (no global single T/K).\n",
    "    Baseline for a group is the weighted average over ALL its SAEs:\n",
    "      base_avg = (sum of all features' overall) / (total feature count)\n",
    "    Pooled avg_selected = (sum of selected overall across SAEs) / (total selected count)\n",
    "    \"\"\"\n",
    "    # Group by architecture\n",
    "    by_arch: Dict[str, List[Dict[str, Any]]] = {}\n",
    "    for arch, _sae, rec in records:\n",
    "        by_arch.setdefault(arch, []).append(rec)\n",
    "\n",
    "    # Label orders\n",
    "    thr_labels = [lab for lab, _ in STEER_THRESHOLDS]\n",
    "    topk_labels = [f\"TOPK_SCORE={k}\" for k in sorted(set(TOPK_LIST))]\n",
    "\n",
    "    # helper maps to render T/K values\n",
    "    thr_val_map = {lab: thr for lab, thr in STEER_THRESHOLDS}\n",
    "    topk_val_map = {f\"TOPK_SCORE={k}\": k for k in sorted(set(TOPK_LIST))}\n",
    "\n",
    "    def aggregate_group(group_recs: List[Dict[str, Any]]):\n",
    "        \"\"\"\n",
    "        Returns:\n",
    "          base_avg, base_num_total, base_sum_total,\n",
    "          thr_agg:   label -> (count_total, pooled_avg_selected, lift_pct_vs_base)\n",
    "          topk_agg:  label -> (count_total, pooled_avg_selected, lift_pct_vs_base)\n",
    "          arch_best_single: {\"thr\": (label, tuple), \"topk\": (label, tuple)}\n",
    "        \"\"\"\n",
    "        base_num_total = sum(r[\"base_num\"] for r in group_recs)\n",
    "        base_sum_total = sum(r[\"base_sum\"] for r in group_recs)\n",
    "        base_avg = (base_sum_total / base_num_total) if base_num_total > 0 else 0.0\n",
    "\n",
    "        # Threshold aggregation (pooled)\n",
    "        thr_counts: Dict[str, int] = {lab: 0 for lab in thr_labels}\n",
    "        thr_sums: Dict[str, float] = {lab: 0.0 for lab in thr_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in thr_labels:\n",
    "                st = r[\"thr_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    thr_counts[lab] += int(st[\"count\"])\n",
    "                    thr_sums[lab] += float(st[\"sum\"])\n",
    "\n",
    "        thr_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in thr_labels:\n",
    "            cnt = thr_counts[lab]\n",
    "            avg_sel = (thr_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            thr_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        # Top-K aggregation (pooled)\n",
    "        topk_counts: Dict[str, int] = {lab: 0 for lab in topk_labels}\n",
    "        topk_sums: Dict[str, float] = {lab: 0.0 for lab in topk_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in topk_labels:\n",
    "                st = r[\"topk_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    topk_counts[lab] += int(st[\"count\"])\n",
    "                    topk_sums[lab] += float(st[\"sum\"])\n",
    "\n",
    "        topk_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in topk_labels:\n",
    "            cnt = topk_counts[lab]\n",
    "            avg_sel = (topk_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            topk_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        # Architecture Best (single choice across SAEs)\n",
    "        thr_best_single = choose_best_from_agg(thr_agg)\n",
    "        topk_best_single = choose_best_from_agg(topk_agg)\n",
    "\n",
    "        arch_best_single_dict = {\n",
    "            \"thr\": thr_best_single,   # (label, (cnt, avg_sel, lift))\n",
    "            \"topk\": topk_best_single  # (label, (cnt, avg_sel, lift))\n",
    "        }\n",
    "        return (base_avg, base_num_total, base_sum_total,\n",
    "                thr_agg, topk_agg, arch_best_single_dict)\n",
    "\n",
    "    # Print per-architecture summaries\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY BY ARCHITECTURE (aggregated over SAEs per architecture)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for arch, group_recs in sorted(by_arch.items()):\n",
    "        (base_avg, base_n, _base_sum,\n",
    "         thr_agg, topk_agg, arch_best_single) = aggregate_group(group_recs)\n",
    "\n",
    "        print(f\"\\n[ARCH] {arch}  | SAEs={len(group_recs)}  | Base steering score={base_avg:.6f}  (Total features N={base_n})\")\n",
    "\n",
    "        print(\"  > Threshold (score >= T):\")\n",
    "        for label, thr in STEER_THRESHOLDS:\n",
    "            cnt, avg_sel, lift = thr_agg[label]\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "        print(\"  > Top-K (by score desc):\")\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            label = f\"TOPK_SCORE={k}\"\n",
    "            cnt, avg_sel, lift = topk_agg[label]\n",
    "            print(f\"    {label:<14} -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "        # Architecture Best (single choice across SAEs)\n",
    "        print(\"  > Architecture Best (single choice across SAEs):\")\n",
    "        if arch_best_single[\"thr\"] is not None:\n",
    "            lab, (cnt, avg_sel, lift) = arch_best_single[\"thr\"]\n",
    "            t_val = thr_val_map.get(lab, None)\n",
    "            t_str = f\"(T={t_val:g}) \" if t_val is not None else \"\"\n",
    "            print(f\"    Best Threshold (single T): {lab:<14} {t_str}-> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "        else:\n",
    "            print(\"    Best Threshold (single T): N/A\")\n",
    "\n",
    "        if arch_best_single[\"topk\"] is not None:\n",
    "            lab, (cnt, avg_sel, lift) = arch_best_single[\"topk\"]\n",
    "            k_val = topk_val_map.get(lab, None)\n",
    "            k_str = f\"(K={k_val}) \" if k_val is not None else \"\"\n",
    "            print(f\"    Best Top-K (single K)    : {lab:<14} {k_str}-> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "        else:\n",
    "            print(\"    Best Top-K (single K)    : N/A\")\n",
    "\n",
    "    # Across all SAEs (treat all as one group) — do NOT choose a single global T/K\n",
    "    all_group = [rec for _arch, _sae, rec in records]\n",
    "\n",
    "    # Compute pooled tables across all SAEs (for reference)\n",
    "    def aggregate_all(group_recs: List[Dict[str, Any]]):\n",
    "        base_num_total = sum(r[\"base_num\"] for r in group_recs)\n",
    "        base_sum_total = sum(r[\"base_sum\"] for r in group_recs)\n",
    "        base_avg = (base_sum_total / base_num_total) if base_num_total > 0 else 0.0\n",
    "\n",
    "        thr_counts: Dict[str, int] = {lab: 0 for lab in thr_labels}\n",
    "        thr_sums: Dict[str, float] = {lab: 0.0 for lab in thr_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in thr_labels:\n",
    "                st = r[\"thr_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    thr_counts[lab] += int(st[\"count\"])\n",
    "                    thr_sums[lab] += float(st[\"sum\"])\n",
    "        thr_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in thr_labels:\n",
    "            cnt = thr_counts[lab]\n",
    "            avg_sel = (thr_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            thr_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        topk_counts: Dict[str, int] = {lab: 0 for lab in topk_labels}\n",
    "        topk_sums: Dict[str, float] = {lab: 0.0 for lab in topk_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in topk_labels:\n",
    "                st = r[\"topk_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    topk_counts[lab] += int(st[\"count\"])\n",
    "                    topk_sums[lab] += float(st[\"sum\"])\n",
    "        topk_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in topk_labels:\n",
    "            cnt = topk_counts[lab]\n",
    "            avg_sel = (topk_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            topk_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        return base_avg, base_num_total, thr_agg, topk_agg\n",
    "\n",
    "    all_base_avg, all_base_n, all_thr_agg, all_topk_agg = aggregate_all(all_group)\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS ALL SAEs\")\n",
    "    print(\"-\" * 80)\n",
    "    print(f\"All SAEs | Base steering score={all_base_avg:.6f}  (Total features N={all_base_n})\")\n",
    "\n",
    "    print(\"  > Threshold (score >= T):\")\n",
    "    for label, thr in STEER_THRESHOLDS:\n",
    "        cnt, avg_sel, lift = all_thr_agg[label]\n",
    "        print(f\"    {label:<14} (T={thr:g}) -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, all_base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "    print(\"  > Top-K (by score desc):\")\n",
    "    for k in sorted(set(TOPK_LIST)):\n",
    "        label = f\"TOPK_SCORE={k}\"\n",
    "        cnt, avg_sel, lift = all_topk_agg[label]\n",
    "        print(f\"    {label:<14} -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, all_base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "    # Per your request: do NOT pick a single global best T/K here.\n",
    "    # Instead, average per-SAE selections after each SAE chooses its own best threshold and best topK.\n",
    "    total_saes = len(all_group)\n",
    "    # Treat None lift as 0 for averaging; counts are integers (0 if no selection available)\n",
    "    avg_best_thr_count_per_sae = sum(r.get(\"best_thr_count\", 0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_thr_lift_per_sae  = sum((r.get(\"best_thr_lift_pct\") or 0.0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_topk_count_per_sae = sum(r.get(\"best_topk_count\", 0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_topk_lift_per_sae  = sum((r.get(\"best_topk_lift_pct\") or 0.0) for r in all_group) / max(total_saes, 1)\n",
    "\n",
    "    print(\"\\n  > Per-SAE selections (averaged across SAEs):\")\n",
    "    print(f\"    Average Best-Threshold -> avg_count_per_SAE={avg_best_thr_count_per_sae:.2f}  avg_lift_vs_base={avg_best_thr_lift_per_sae:.2f}%\")\n",
    "    print(f\"    Average Best-TopK      -> avg_count_per_SAE={avg_best_topk_count_per_sae:.2f}  avg_lift_vs_base={avg_best_topk_lift_per_sae:.2f}%\")\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",
    "    # Discover SAEs (flat or nested) and process them\n",
    "    sae_items = discover_saes(EVAL_ROOT, ENTROPY_ROOT)\n",
    "    if not sae_items:\n",
    "        print(f\"No SAEs discovered under: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    records: List[Tuple[str, str, Dict[str, Any]]] = []\n",
    "\n",
    "    print(\"=\" * 80)\n",
    "    print(f\"Discovered {len(sae_items)} SAE directories.\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for item in sae_items:\n",
    "        arch_name = item[\"arch_name\"]\n",
    "        sae_name = item[\"sae_name\"]\n",
    "        eval_path = item[\"eval_path\"]\n",
    "        entropy_path = item[\"entropy_path\"] if item.get(\"entropy_path\") else None\n",
    "\n",
    "        rec = process_one_sae(eval_path, entropy_path)\n",
    "        if rec is None:\n",
    "            print(f\"[SKIP] arch={arch_name}  sae={sae_name}  (missing/invalid eval)\")\n",
    "            continue\n",
    "\n",
    "        # Per-SAE output\n",
    "        print_per_sae(arch_name, sae_name, rec)\n",
    "\n",
    "        records.append((arch_name, sae_name, rec))\n",
    "\n",
    "    if not records:\n",
    "        print(\"No valid SAE records to summarize.\")\n",
    "        return\n",
    "\n",
    "    # Aggregate: by architecture + all SAEs\n",
    "    aggregate_by_architecture(records)\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eb897bb2",
   "metadata": {},
   "source": [
    "## 4.3 Qwen 2.5 3b L17"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4dba5100",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "================================================================================\n",
      "Discovered 30 SAE directories.\n",
      "--------------------------------------------------------------------------------\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_160\n",
      "Base steering score (ALL features avg): 0.198200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=6     avg=0.306667 [> base]  lift_vs_base=54.73%\n",
      "    Steer_0.01_    (T=0.01) -> count=26    avg=0.235385 [> base]  lift_vs_base=18.76%\n",
      "    Steer_0.001_   (T=0.001) -> count=72    avg=0.197500  lift_vs_base=-0.35%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=94    avg=0.208298 [> base]  lift_vs_base=5.09%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.256000 [> base]  lift_vs_base=29.16%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=6     avg=0.306667 [> base]  lift_vs_base=54.73%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.256000 [> base]  lift_vs_base=29.16%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_320\n",
      "Base steering score (ALL features avg): 0.177400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=6     avg=0.040000  lift_vs_base=-77.45%\n",
      "    Steer_0.01_    (T=0.01) -> count=16    avg=0.301250 [> base]  lift_vs_base=69.81%\n",
      "    Steer_0.001_   (T=0.001) -> count=50    avg=0.238400 [> base]  lift_vs_base=34.39%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=84    avg=0.197143 [> base]  lift_vs_base=11.13%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.158000  lift_vs_base=-10.94%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=16    avg=0.301250 [> base]  lift_vs_base=69.81%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.158000  lift_vs_base=-10.94%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_50\n",
      "Base steering score (ALL features avg): 0.287000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=9     avg=0.180000  lift_vs_base=-37.28%\n",
      "    Steer_0.01_    (T=0.01) -> count=34    avg=0.253529  lift_vs_base=-11.66%\n",
      "    Steer_0.001_   (T=0.001) -> count=73    avg=0.319178 [> base]  lift_vs_base=11.21%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=95    avg=0.290316 [> base]  lift_vs_base=1.16%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.162000  lift_vs_base=-43.55%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=73    avg=0.319178 [> base]  lift_vs_base=11.21%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.162000  lift_vs_base=-43.55%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_520\n",
      "Base steering score (ALL features avg): 0.151600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=4     avg=0.240000 [> base]  lift_vs_base=58.31%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.160000 [> base]  lift_vs_base=5.54%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=31    avg=0.123871  lift_vs_base=-18.29%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.096000  lift_vs_base=-36.68%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=4     avg=0.240000 [> base]  lift_vs_base=58.31%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.096000  lift_vs_base=-36.68%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_80\n",
      "Base steering score (ALL features avg): 0.227200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=13    avg=0.126154  lift_vs_base=-44.47%\n",
      "    Steer_0.01_    (T=0.01) -> count=41    avg=0.198537  lift_vs_base=-12.62%\n",
      "    Steer_0.001_   (T=0.001) -> count=74    avg=0.201892  lift_vs_base=-11.14%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=95    avg=0.221895  lift_vs_base=-2.34%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.164000  lift_vs_base=-27.82%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=95    avg=0.221895  lift_vs_base=-2.34%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.164000  lift_vs_base=-27.82%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=batch  name=batch_topk_820\n",
      "Base steering score (ALL features avg): 0.124800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.160000 [> base]  lift_vs_base=28.21%\n",
      "    Steer_0.001_   (T=0.001) -> count=19    avg=0.126316 [> base]  lift_vs_base=1.21%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=43    avg=0.111628  lift_vs_base=-10.55%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.120000  lift_vs_base=-3.85%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=3     avg=0.160000 [> base]  lift_vs_base=28.21%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.120000  lift_vs_base=-3.85%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_141\n",
      "Base steering score (ALL features avg): 0.209400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=7     avg=0.411429 [> base]  lift_vs_base=96.48%\n",
      "    Steer_0.01_    (T=0.01) -> count=21    avg=0.224762 [> base]  lift_vs_base=7.34%\n",
      "    Steer_0.001_   (T=0.001) -> count=46    avg=0.206087  lift_vs_base=-1.58%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=75    avg=0.209067  lift_vs_base=-0.16%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.288000 [> base]  lift_vs_base=37.54%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=7     avg=0.411429 [> base]  lift_vs_base=96.48%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.288000 [> base]  lift_vs_base=37.54%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_338\n",
      "Base steering score (ALL features avg): 0.106400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.060000  lift_vs_base=-43.61%\n",
      "    Steer_0.01_    (T=0.01) -> count=8     avg=0.060000  lift_vs_base=-43.61%\n",
      "    Steer_0.001_   (T=0.001) -> count=31    avg=0.132258 [> base]  lift_vs_base=24.30%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=60    avg=0.112333 [> base]  lift_vs_base=5.58%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.096000  lift_vs_base=-9.77%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=31    avg=0.132258 [> base]  lift_vs_base=24.30%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.096000  lift_vs_base=-9.77%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_46\n",
      "Base steering score (ALL features avg): 0.069600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=2     avg=0.270000 [> base]  lift_vs_base=287.93%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.078000 [> base]  lift_vs_base=12.07%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=2     avg=0.270000 [> base]  lift_vs_base=287.93%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.078000 [> base]  lift_vs_base=12.07%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_565\n",
      "Base steering score (ALL features avg): 0.161600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=1     avg=0.480000 [> base]  lift_vs_base=197.03%\n",
      "    Steer_0.001_   (T=0.001) -> count=7     avg=0.274286 [> base]  lift_vs_base=69.73%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=22    avg=0.251818 [> base]  lift_vs_base=55.83%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.284000 [> base]  lift_vs_base=75.74%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=1     avg=0.480000 [> base]  lift_vs_base=197.03%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.284000 [> base]  lift_vs_base=75.74%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_72\n",
      "Base steering score (ALL features avg): 0.129600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=11    avg=0.065455  lift_vs_base=-49.49%\n",
      "    Steer_0.001_   (T=0.001) -> count=27    avg=0.122222  lift_vs_base=-5.69%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=46    avg=0.146087 [> base]  lift_vs_base=12.72%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-44.44%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=46    avg=0.146087 [> base]  lift_vs_base=12.72%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-44.44%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=gated  name=gated_999\n",
      "Base steering score (ALL features avg): 0.117800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=2     avg=0.240000 [> base]  lift_vs_base=103.74%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=9     avg=0.080000  lift_vs_base=-32.09%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.150000 [> base]  lift_vs_base=27.33%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=2     avg=0.240000 [> base]  lift_vs_base=103.74%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.150000 [> base]  lift_vs_base=27.33%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_166\n",
      "Base steering score (ALL features avg): 0.202200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=1.120000 [> base]  lift_vs_base=453.91%\n",
      "    Steer_0.01_    (T=0.01) -> count=9     avg=0.397778 [> base]  lift_vs_base=96.72%\n",
      "    Steer_0.001_   (T=0.001) -> count=24    avg=0.357500 [> base]  lift_vs_base=76.81%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=51    avg=0.239216 [> base]  lift_vs_base=18.31%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.382000 [> base]  lift_vs_base=88.92%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=1     avg=1.120000 [> base]  lift_vs_base=453.91%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.382000 [> base]  lift_vs_base=88.92%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_323\n",
      "Base steering score (ALL features avg): 0.106400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.480000 [> base]  lift_vs_base=351.13%\n",
      "    Steer_0.01_    (T=0.01) -> count=7     avg=0.228571 [> base]  lift_vs_base=114.82%\n",
      "    Steer_0.001_   (T=0.001) -> count=14    avg=0.170000 [> base]  lift_vs_base=59.77%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=40    avg=0.127000 [> base]  lift_vs_base=19.36%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.184000 [> base]  lift_vs_base=72.93%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=1     avg=0.480000 [> base]  lift_vs_base=351.13%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.184000 [> base]  lift_vs_base=72.93%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_494\n",
      "Base steering score (ALL features avg): 0.128600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.080000  lift_vs_base=-37.79%\n",
      "    Steer_0.001_   (T=0.001) -> count=12    avg=0.140000 [> base]  lift_vs_base=8.86%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=24    avg=0.122500  lift_vs_base=-4.74%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.168000 [> base]  lift_vs_base=30.64%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=12    avg=0.140000 [> base]  lift_vs_base=8.86%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.168000 [> base]  lift_vs_base=30.64%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_51\n",
      "Base steering score (ALL features avg): 0.190800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.120000  lift_vs_base=-37.11%\n",
      "    Steer_0.01_    (T=0.01) -> count=11    avg=0.043636  lift_vs_base=-77.13%\n",
      "    Steer_0.001_   (T=0.001) -> count=36    avg=0.173333  lift_vs_base=-9.15%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=52    avg=0.152308  lift_vs_base=-20.17%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.048000  lift_vs_base=-74.84%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=36    avg=0.173333  lift_vs_base=-9.15%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.048000  lift_vs_base=-74.84%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_754\n",
      "Base steering score (ALL features avg): 0.114800  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=5     avg=0.048000  lift_vs_base=-58.19%\n",
      "    Steer_0.01_    (T=0.01) -> count=32    avg=0.101250  lift_vs_base=-11.80%\n",
      "    Steer_0.001_   (T=0.001) -> count=78    avg=0.119487 [> base]  lift_vs_base=4.08%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=98    avg=0.107551  lift_vs_base=-6.31%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.120000 [> base]  lift_vs_base=4.53%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=78    avg=0.119487 [> base]  lift_vs_base=4.08%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.120000 [> base]  lift_vs_base=4.53%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=jump  name=jump_relu_82\n",
      "Base steering score (ALL features avg): 0.187400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=8     avg=0.237500 [> base]  lift_vs_base=26.73%\n",
      "    Steer_0.001_   (T=0.001) -> count=21    avg=0.285714 [> base]  lift_vs_base=52.46%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=54    avg=0.231111 [> base]  lift_vs_base=23.33%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.288000 [> base]  lift_vs_base=53.68%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=21    avg=0.285714 [> base]  lift_vs_base=52.46%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.288000 [> base]  lift_vs_base=53.68%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_108\n",
      "Base steering score (ALL features avg): 0.251400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=15    avg=0.216000  lift_vs_base=-14.08%\n",
      "    Steer_0.01_    (T=0.01) -> count=32    avg=0.308750 [> base]  lift_vs_base=22.81%\n",
      "    Steer_0.001_   (T=0.001) -> count=55    avg=0.238545  lift_vs_base=-5.11%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=70    avg=0.240571  lift_vs_base=-4.31%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.216000  lift_vs_base=-14.08%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=32    avg=0.308750 [> base]  lift_vs_base=22.81%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.216000  lift_vs_base=-14.08%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_167\n",
      "Base steering score (ALL features avg): 0.166400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=9     avg=0.053333  lift_vs_base=-67.95%\n",
      "    Steer_0.01_    (T=0.01) -> count=22    avg=0.141818  lift_vs_base=-14.77%\n",
      "    Steer_0.001_   (T=0.001) -> count=47    avg=0.174043 [> base]  lift_vs_base=4.59%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=61    avg=0.187869 [> base]  lift_vs_base=12.90%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-56.73%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=61    avg=0.187869 [> base]  lift_vs_base=12.90%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.072000  lift_vs_base=-56.73%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_321\n",
      "Base steering score (ALL features avg): 0.117600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.060000  lift_vs_base=-48.98%\n",
      "    Steer_0.01_    (T=0.01) -> count=18    avg=0.150000 [> base]  lift_vs_base=27.55%\n",
      "    Steer_0.001_   (T=0.001) -> count=34    avg=0.114706  lift_vs_base=-2.46%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=46    avg=0.143478 [> base]  lift_vs_base=22.01%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.048000  lift_vs_base=-59.18%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=18    avg=0.150000 [> base]  lift_vs_base=27.55%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.048000  lift_vs_base=-59.18%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_523\n",
      "Base steering score (ALL features avg): 0.186000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=3     avg=0.080000  lift_vs_base=-56.99%\n",
      "    Steer_0.01_    (T=0.01) -> count=9     avg=0.340000 [> base]  lift_vs_base=82.80%\n",
      "    Steer_0.001_   (T=0.001) -> count=26    avg=0.228462 [> base]  lift_vs_base=22.83%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=42    avg=0.248571 [> base]  lift_vs_base=33.64%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.306000 [> base]  lift_vs_base=64.52%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=9     avg=0.340000 [> base]  lift_vs_base=82.80%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.306000 [> base]  lift_vs_base=64.52%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_61\n",
      "Base steering score (ALL features avg): 0.274000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=13    avg=0.233846  lift_vs_base=-14.65%\n",
      "    Steer_0.01_    (T=0.01) -> count=37    avg=0.295135 [> base]  lift_vs_base=7.71%\n",
      "    Steer_0.001_   (T=0.001) -> count=57    avg=0.270175  lift_vs_base=-1.40%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=79    avg=0.273671  lift_vs_base=-0.12%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.216000  lift_vs_base=-21.17%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=37    avg=0.295135 [> base]  lift_vs_base=7.71%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.216000  lift_vs_base=-21.17%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=standard  name=standard_april_update_762\n",
      "Base steering score (ALL features avg): 0.100200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=2     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=12    avg=0.140000 [> base]  lift_vs_base=39.72%\n",
      "    Steer_0.001_   (T=0.001) -> count=21    avg=0.080000  lift_vs_base=-20.16%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=33    avg=0.116364 [> base]  lift_vs_base=16.13%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.144000 [> base]  lift_vs_base=43.71%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.01_    (T=0.01) -> count=12    avg=0.140000 [> base]  lift_vs_base=39.72%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.144000 [> base]  lift_vs_base=43.71%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_160\n",
      "Base steering score (ALL features avg): 0.134600  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.240000 [> base]  lift_vs_base=78.31%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.146667 [> base]  lift_vs_base=8.96%\n",
      "    Steer_0.001_   (T=0.001) -> count=12    avg=0.281667 [> base]  lift_vs_base=109.26%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=32    avg=0.165625 [> base]  lift_vs_base=23.05%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.314000 [> base]  lift_vs_base=133.28%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=12    avg=0.281667 [> base]  lift_vs_base=109.26%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.314000 [> base]  lift_vs_base=133.28%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_320\n",
      "Base steering score (ALL features avg): 0.241200  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=4     avg=0.240000  lift_vs_base=-0.50%\n",
      "    Steer_0.01_    (T=0.01) -> count=15    avg=0.258667 [> base]  lift_vs_base=7.24%\n",
      "    Steer_0.001_   (T=0.001) -> count=38    avg=0.286316 [> base]  lift_vs_base=18.70%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=70    avg=0.256286 [> base]  lift_vs_base=6.25%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.204000  lift_vs_base=-15.42%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=38    avg=0.286316 [> base]  lift_vs_base=18.70%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.204000  lift_vs_base=-15.42%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_50\n",
      "Base steering score (ALL features avg): 0.346400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=17    avg=0.271765  lift_vs_base=-21.55%\n",
      "    Steer_0.01_    (T=0.01) -> count=37    avg=0.328108  lift_vs_base=-5.28%\n",
      "    Steer_0.001_   (T=0.001) -> count=73    avg=0.337808  lift_vs_base=-2.48%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=89    avg=0.356629 [> base]  lift_vs_base=2.95%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.216000  lift_vs_base=-37.64%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.0001_  (T=0.0001) -> count=89    avg=0.356629 [> base]  lift_vs_base=2.95%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.216000  lift_vs_base=-37.64%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_520\n",
      "Base steering score (ALL features avg): 0.136000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=3     avg=0.080000  lift_vs_base=-41.18%\n",
      "    Steer_0.001_   (T=0.001) -> count=15    avg=0.192000 [> base]  lift_vs_base=41.18%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=41    avg=0.157073 [> base]  lift_vs_base=15.49%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=32.35%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=15    avg=0.192000 [> base]  lift_vs_base=41.18%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.180000 [> base]  lift_vs_base=32.35%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_80\n",
      "Base steering score (ALL features avg): 0.216000  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=10    avg=0.280000 [> base]  lift_vs_base=29.63%\n",
      "    Steer_0.01_    (T=0.01) -> count=32    avg=0.278125 [> base]  lift_vs_base=28.76%\n",
      "    Steer_0.001_   (T=0.001) -> count=72    avg=0.207500  lift_vs_base=-3.94%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=96    avg=0.222500 [> base]  lift_vs_base=3.01%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.280000 [> base]  lift_vs_base=29.63%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.1_     (T=0.1) -> count=10    avg=0.280000 [> base]  lift_vs_base=29.63%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.280000 [> base]  lift_vs_base=29.63%\n",
      "\n",
      "--------------------------------------------------------------------------------\n",
      "[SAE] arch=topk  name=topk_820\n",
      "Base steering score (ALL features avg): 0.080400  (N=100)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> count=0     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.01_    (T=0.01) -> count=1     avg=0.000000  lift_vs_base=-100.00%\n",
      "    Steer_0.001_   (T=0.001) -> count=2     avg=0.220000 [> base]  lift_vs_base=173.63%\n",
      "    Steer_0.0001_  (T=0.0001) -> count=7     avg=0.062857  lift_vs_base=-21.82%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> count=10    avg=0.164000 [> base]  lift_vs_base=103.98%\n",
      "  >> Per-SAE Best selections:\n",
      "     Best Threshold: Steer_0.001_   (T=0.001) -> count=2     avg=0.220000 [> base]  lift_vs_base=173.63%\n",
      "     Best Top-K    : TOPK_SCORE=10  -> count=10    avg=0.164000 [> base]  lift_vs_base=103.98%\n",
      "\n",
      "================================================================================\n",
      "SUMMARY BY ARCHITECTURE (aggregated over SAEs per architecture)\n",
      "--------------------------------------------------------------------------------\n",
      "\n",
      "[ARCH] batch  | SAEs=6  | Base steering score=0.194367  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=34     avg_selected=0.157059  lift_vs_base=-19.19%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=124    avg_selected=0.235000 [> base]  lift_vs_base=20.91%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=303    avg_selected=0.228317 [> base]  lift_vs_base=17.47%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=442    avg_selected=0.211403 [> base]  lift_vs_base=8.76%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.159333  lift_vs_base=-18.02%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.01_    (T=0.01) -> total_count=124    avg_selected=0.235000 [> base]  lift_vs_base=20.91%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.159333  lift_vs_base=-18.02%\n",
      "\n",
      "[ARCH] gated  | SAEs=6  | Base steering score=0.132400  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=13     avg_selected=0.240000 [> base]  lift_vs_base=81.27%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=42     avg_selected=0.152381 [> base]  lift_vs_base=15.09%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=114    avg_selected=0.169123 [> base]  lift_vs_base=27.74%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=214    avg_selected=0.167944 [> base]  lift_vs_base=26.85%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.161333 [> base]  lift_vs_base=21.85%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.1_     (T=0.1) -> total_count=13     avg_selected=0.240000 [> base]  lift_vs_base=81.27%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.161333 [> base]  lift_vs_base=21.85%\n",
      "\n",
      "[ARCH] jump  | SAEs=6  | Base steering score=0.155033  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=14     avg_selected=0.165714 [> base]  lift_vs_base=6.89%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=70     avg_selected=0.157714 [> base]  lift_vs_base=1.73%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=185    avg_selected=0.184865 [> base]  lift_vs_base=19.24%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=319    avg_selected=0.160376 [> base]  lift_vs_base=3.45%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.198333 [> base]  lift_vs_base=27.93%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.001_   (T=0.001) -> total_count=185    avg_selected=0.184865 [> base]  lift_vs_base=19.24%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.198333 [> base]  lift_vs_base=27.93%\n",
      "\n",
      "[ARCH] standard  | SAEs=6  | Base steering score=0.182600  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=46     avg_selected=0.157391  lift_vs_base=-13.81%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=130    avg_selected=0.241231 [> base]  lift_vs_base=32.11%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=240    avg_selected=0.200917 [> base]  lift_vs_base=10.03%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=331    avg_selected=0.213897 [> base]  lift_vs_base=17.14%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.167000  lift_vs_base=-8.54%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.01_    (T=0.01) -> total_count=130    avg_selected=0.241231 [> base]  lift_vs_base=32.11%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.167000  lift_vs_base=-8.54%\n",
      "\n",
      "[ARCH] topk  | SAEs=6  | Base steering score=0.192433  (Total features N=600)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=33     avg_selected=0.261212 [> base]  lift_vs_base=35.74%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=91     avg_selected=0.281319 [> base]  lift_vs_base=46.19%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=212    avg_selected=0.269717 [> base]  lift_vs_base=40.16%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=335    avg_selected=0.248418 [> base]  lift_vs_base=29.09%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> total_count=60     avg_selected=0.226333 [> base]  lift_vs_base=17.62%\n",
      "  > Architecture Best (single choice across SAEs):\n",
      "    Best Threshold (single T): Steer_0.01_    (T=0.01) -> total_count=91     avg_selected=0.281319 [> base]  lift_vs_base=46.19%\n",
      "    Best Top-K (single K)    : TOPK_SCORE=10  (K=10) -> total_count=60     avg_selected=0.226333 [> base]  lift_vs_base=17.62%\n",
      "\n",
      "================================================================================\n",
      "SUMMARY ACROSS ALL SAEs\n",
      "--------------------------------------------------------------------------------\n",
      "All SAEs | Base steering score=0.171367  (Total features N=3000)\n",
      "  > Threshold (score >= T):\n",
      "    Steer_0.1_     (T=0.1) -> total_count=140    avg_selected=0.190286 [> base]  lift_vs_base=11.04%\n",
      "    Steer_0.01_    (T=0.01) -> total_count=457    avg_selected=0.226565 [> base]  lift_vs_base=32.21%\n",
      "    Steer_0.001_   (T=0.001) -> total_count=1054   avg_selected=0.216376 [> base]  lift_vs_base=26.26%\n",
      "    Steer_0.0001_  (T=0.0001) -> total_count=1641   avg_selected=0.203876 [> base]  lift_vs_base=18.97%\n",
      "  > Top-K (by score desc):\n",
      "    TOPK_SCORE=10  -> total_count=300    avg_selected=0.182467 [> base]  lift_vs_base=6.48%\n",
      "\n",
      "  > Per-SAE selections (averaged across SAEs):\n",
      "    Average Best-Threshold -> avg_count_per_SAE=25.67  avg_lift_vs_base=79.08%\n",
      "    Average Best-TopK      -> avg_count_per_SAE=10.00  avg_lift_vs_base=12.80%\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import json\n",
    "from typing import Dict, Any, List, Optional, Tuple\n",
    "\n",
    "# =====================================================================================\n",
    "# Configuration\n",
    "# =====================================================================================\n",
    "\n",
    "# Root paths (example for Gemma 2 2B, layer 12) — update to your actual paths\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",
    "# Score thresholds (read 'score' from output_scores_plus_top20_kconf1.json; select score >= T)\n",
    "STEER_THRESHOLDS: List[Tuple[str, float]] = [\n",
    "    (\"Steer_0.1_\",    0.1),\n",
    "    (\"Steer_0.01_\",   0.01),\n",
    "    (\"Steer_0.001_\",  0.001),\n",
    "    (\"Steer_0.0001_\", 0.0001),\n",
    "]\n",
    "\n",
    "# Top-K (select top-K features by 'score' descending)\n",
    "TOPK_LIST: List[int] = [10]\n",
    "\n",
    "SCORE_FILENAME = \"output_scores_plus_top20_kconf1.json\"\n",
    "EVAL_FILENAME  = \"eval.json\"\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, float]:\n",
    "    \"\"\"\n",
    "    Returns:\n",
    "      - total number of features in eval_data\n",
    "      - baseline average over ALL features (denominator = total #features),\n",
    "        summing only present 'overall' values (missing -> 0 contribution)\n",
    "      - sum_overall over all features that have 'overall'\n",
    "    Note: 0.0 scores are valid and included.\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, sum_overall\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_score_map(entropy_data: Dict[str, Any]) -> Dict[str, float]:\n",
    "    \"\"\"Return {feature_id: score} for valid numeric entries.\"\"\"\n",
    "    out: Dict[str, float] = {}\n",
    "    for f, info in entropy_data.items():\n",
    "        if isinstance(info, dict) and (\"score\" in info):\n",
    "            try:\n",
    "                out[f] = float(info[\"score\"])\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, 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",
    "      - sum of selected 'overall'\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)\n",
    "    n = len(vals)\n",
    "    ssum = float(sum(vals))\n",
    "    avg = (ssum / n) if n > 0 else 0.0\n",
    "    return n, avg, ssum\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 \" [> base]\" if avg_subset > avg_all else \"\"\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Selection builders\n",
    "# =====================================================================================\n",
    "\n",
    "def selection_levels_by_score_threshold(\n",
    "    score_map: Dict[str, float],\n",
    "    labeled_thresholds: List[Tuple[str, float]],\n",
    ") -> List[Tuple[str, List[str], float]]:\n",
    "    \"\"\"For each (label, threshold), select feature ids where score >= threshold.\"\"\"\n",
    "    levels: List[Tuple[str, List[str], float]] = []\n",
    "    if not score_map:\n",
    "        return levels\n",
    "    for label, thr in labeled_thresholds:\n",
    "        sel = [fid for fid, sc in score_map.items() if sc >= thr]\n",
    "        levels.append((label, sel, thr))\n",
    "    return levels\n",
    "\n",
    "\n",
    "def selection_levels_by_topk(score_map: Dict[str, float], topk_list: List[int]) -> List[Tuple[str, List[str], int]]:\n",
    "    \"\"\"For each K in topk_list, take the K highest-score features.\"\"\"\n",
    "    levels: List[Tuple[str, List[str], int]] = []\n",
    "    if not score_map:\n",
    "        return levels\n",
    "    sorted_ids = sorted(score_map.keys(), key=lambda x: score_map[x], reverse=True)\n",
    "    for k in sorted(set(topk_list)):\n",
    "        kk = max(0, min(k, len(sorted_ids)))\n",
    "        sel = sorted_ids[:kk]\n",
    "        levels.append((f\"TOPK_SCORE={k}\", sel, k))\n",
    "    return levels\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Discovery: SAE list & architecture name\n",
    "# =====================================================================================\n",
    "\n",
    "def infer_architecture_name_from_sae(sae_name: str) -> str:\n",
    "    \"\"\"\n",
    "    In a flat directory, infer architecture name from SAE folder:\n",
    "    - Use prefix before '-' or '_' if exists; otherwise use the whole name.\n",
    "    Adjust this to your naming convention if needed.\n",
    "    \"\"\"\n",
    "    for sep in [\"-\", \"_\"]:\n",
    "        if sep in sae_name:\n",
    "            return sae_name.split(sep)[0]\n",
    "    return sae_name\n",
    "\n",
    "\n",
    "def discover_saes(eval_root: str, entropy_root: str) -> List[Dict[str, str]]:\n",
    "    \"\"\"\n",
    "    Support both directory layouts:\n",
    "    A) Flat:   EVAL_ROOT/<sae>/eval.json\n",
    "               ENTROPY_ROOT/<sae>/output_scores_plus_top20_kconf1.json\n",
    "    B) Nested: EVAL_ROOT/<arch>/<sae>/eval.json\n",
    "               ENTROPY_ROOT/<arch>/<sae>/output_scores_plus_top20_kconf1.json\n",
    "\n",
    "    Returns items: {arch_name, sae_name, eval_path, entropy_path}\n",
    "    \"\"\"\n",
    "    items: List[Dict[str, str]] = []\n",
    "\n",
    "    if not os.path.isdir(eval_root):\n",
    "        return items\n",
    "\n",
    "    for entry in sorted(os.listdir(eval_root)):\n",
    "        path_lvl1 = os.path.join(eval_root, entry)\n",
    "        if not os.path.isdir(path_lvl1):\n",
    "            continue\n",
    "\n",
    "        # Flat\n",
    "        eval_path_flat = os.path.join(path_lvl1, EVAL_FILENAME)\n",
    "        if os.path.isfile(eval_path_flat):\n",
    "            sae_name = entry\n",
    "            arch_name = infer_architecture_name_from_sae(sae_name)\n",
    "            entropy_path_flat = os.path.join(entropy_root, sae_name, SCORE_FILENAME)\n",
    "            entropy_path_hier = os.path.join(entropy_root, arch_name, sae_name, SCORE_FILENAME)\n",
    "            entropy_path = entropy_path_flat if os.path.isfile(entropy_path_flat) else entropy_path_hier\n",
    "\n",
    "            items.append({\n",
    "                \"arch_name\": arch_name,\n",
    "                \"sae_name\": sae_name,\n",
    "                \"eval_path\": eval_path_flat,\n",
    "                \"entropy_path\": entropy_path,\n",
    "            })\n",
    "            continue\n",
    "\n",
    "        # Nested\n",
    "        for entry2 in sorted(os.listdir(path_lvl1)):\n",
    "            path_lvl2 = os.path.join(path_lvl1, entry2)\n",
    "            if not os.path.isdir(path_lvl2):\n",
    "                continue\n",
    "            eval_path_hier = os.path.join(path_lvl2, EVAL_FILENAME)\n",
    "            if os.path.isfile(eval_path_hier):\n",
    "                arch_name = entry\n",
    "                sae_name = entry2\n",
    "                entropy_path = os.path.join(entropy_root, arch_name, sae_name, SCORE_FILENAME)\n",
    "                if not os.path.isfile(entropy_path):\n",
    "                    alt = os.path.join(entropy_root, sae_name, SCORE_FILENAME)\n",
    "                    if os.path.isfile(alt):\n",
    "                        entropy_path = alt\n",
    "                items.append({\n",
    "                    \"arch_name\": arch_name,\n",
    "                    \"sae_name\": sae_name,\n",
    "                    \"eval_path\": eval_path_hier,\n",
    "                    \"entropy_path\": entropy_path,\n",
    "                })\n",
    "\n",
    "    return items\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# SAE processing (with per-SAE \"best\" picks)\n",
    "# =====================================================================================\n",
    "\n",
    "def choose_best_entry(entries: Dict[str, Dict[str, Any]]) -> Optional[Tuple[str, Dict[str, Any]]]:\n",
    "    \"\"\"\n",
    "    Pick the entry with the maximum 'lift_pct'. If None, treat as -inf.\n",
    "    Ties are broken by higher 'avg' then higher 'count'.\n",
    "    Returns (label, stats_dict) or None if entries is empty.\n",
    "    \"\"\"\n",
    "    if not entries:\n",
    "        return None\n",
    "\n",
    "    def score_key(item: Tuple[str, Dict[str, Any]]):\n",
    "        _lab, st = item\n",
    "        lp = st.get(\"lift_pct\", None)\n",
    "        lift_score = -1e30 if (lp is None) else lp\n",
    "        return (lift_score, st.get(\"avg\", 0.0), st.get(\"count\", 0))\n",
    "\n",
    "    return max(entries.items(), key=score_key)\n",
    "\n",
    "\n",
    "def choose_best_from_agg(\n",
    "    agg: Dict[str, Tuple[int, float, Optional[float]]]\n",
    ") -> Optional[Tuple[str, Tuple[int, float, Optional[float]]]]:\n",
    "    \"\"\"\n",
    "    From aggregated dict: label -> (count, avg_selected, lift_pct), choose best by lift,\n",
    "    tie-break by avg_selected then count.\n",
    "    \"\"\"\n",
    "    if not agg:\n",
    "        return None\n",
    "\n",
    "    def key_fn(item):\n",
    "        lab, (cnt, avg_sel, lift) = item\n",
    "        lift_score = -1e30 if lift is None else lift\n",
    "        return (lift_score, avg_sel, cnt)\n",
    "\n",
    "    return max(agg.items(), key=key_fn)\n",
    "\n",
    "\n",
    "def process_one_sae(eval_path: str, entropy_path: Optional[str]) -> Optional[Dict[str, Any]]:\n",
    "    \"\"\"\n",
    "    For a single SAE:\n",
    "      - Read eval.json to get baseline (avg over ALL features)\n",
    "      - Read score file and compute:\n",
    "          1) Threshold selections (Steer_* labels)\n",
    "          2) Top-K selections\n",
    "      - Compute per-SAE best threshold and best topK (by lift).\n",
    "      - Return a record including base, per-level stats, and \"best\" picks.\n",
    "    \"\"\"\n",
    "    eval_data = safe_load_json(eval_path)\n",
    "    if eval_data is None:\n",
    "        return None\n",
    "\n",
    "    num_features, base_avg, base_sum = compute_base_stats(eval_data)\n",
    "\n",
    "    score_map: Dict[str, float] = {}\n",
    "    if entropy_path and os.path.isfile(entropy_path):\n",
    "        entropy_data = safe_load_json(entropy_path)\n",
    "        if entropy_data is not None:\n",
    "            score_map = build_score_map(entropy_data)\n",
    "\n",
    "    # Thresholds\n",
    "    thr_levels = selection_levels_by_score_threshold(score_map, STEER_THRESHOLDS) if score_map else []\n",
    "    thr_stats: Dict[str, Dict[str, Any]] = {}\n",
    "    for label, selected, thr in thr_levels:\n",
    "        n, avg_sub, ssum = avg_for_selected(eval_data, selected)\n",
    "        lift = pct_lift(avg_sub, base_avg)\n",
    "        thr_stats[label] = {\n",
    "            \"label\": label,\n",
    "            \"threshold\": thr,\n",
    "            \"count\": n,\n",
    "            \"avg\": avg_sub,\n",
    "            \"sum\": ssum,\n",
    "            \"lift_pct\": lift,\n",
    "        }\n",
    "\n",
    "    # Top-K\n",
    "    topk_levels = selection_levels_by_topk(score_map, TOPK_LIST) if score_map else []\n",
    "    topk_stats: Dict[str, Dict[str, Any]] = {}\n",
    "    for label, selected, k in topk_levels:\n",
    "        n, avg_sub, ssum = avg_for_selected(eval_data, selected)\n",
    "        lift = pct_lift(avg_sub, base_avg)\n",
    "        topk_stats[label] = {\n",
    "            \"label\": label,\n",
    "            \"k\": k,\n",
    "            \"count\": n,\n",
    "            \"avg\": avg_sub,\n",
    "            \"sum\": ssum,\n",
    "            \"lift_pct\": lift,\n",
    "        }\n",
    "\n",
    "    # Best picks per SAE\n",
    "    best_thr = choose_best_entry(thr_stats)\n",
    "    best_topk = choose_best_entry(topk_stats)\n",
    "\n",
    "    rec: Dict[str, Any] = {\n",
    "        \"base_num\": num_features,\n",
    "        \"base_avg\": base_avg,\n",
    "        \"base_sum\": base_sum,\n",
    "        \"thr_stats\": thr_stats,\n",
    "        \"topk_stats\": topk_stats,\n",
    "        \"best_thr\": best_thr,\n",
    "        \"best_topk\": best_topk,\n",
    "    }\n",
    "\n",
    "    # Explicit fields for later aggregation\n",
    "    if best_thr is not None:\n",
    "        lab, st = best_thr\n",
    "        rec.update({\n",
    "            \"best_thr_label\": lab,\n",
    "            \"best_thr_count\": st.get(\"count\", 0),\n",
    "            \"best_thr_lift_pct\": st.get(\"lift_pct\", None),\n",
    "        })\n",
    "    else:\n",
    "        rec.update({\"best_thr_label\": None, \"best_thr_count\": 0, \"best_thr_lift_pct\": None})\n",
    "\n",
    "    if best_topk is not None:\n",
    "        lab, st = best_topk\n",
    "        rec.update({\n",
    "            \"best_topk_label\": lab,\n",
    "            \"best_topk_count\": st.get(\"count\", 0),\n",
    "            \"best_topk_lift_pct\": st.get(\"lift_pct\", None),\n",
    "        })\n",
    "    else:\n",
    "        rec.update({\"best_topk_label\": None, \"best_topk_count\": 0, \"best_topk_lift_pct\": None})\n",
    "\n",
    "    return rec\n",
    "\n",
    "\n",
    "def fmt_lift(lift: Optional[float]) -> str:\n",
    "    return \"N/A\" if lift is None else f\"{lift:.2f}%\"\n",
    "\n",
    "\n",
    "def print_per_sae(arch_name: str, sae_name: str, rec: Dict[str, Any]):\n",
    "    print(\"\\n\" + \"-\" * 80)\n",
    "    print(f\"[SAE] arch={arch_name}  name={sae_name}\")\n",
    "    print(f\"Base steering score (ALL features avg): {rec['base_avg']:.6f}  (N={rec['base_num']})\")\n",
    "\n",
    "    # Threshold results\n",
    "    print(\"  > Threshold (score >= T):\")\n",
    "    for label, thr in STEER_THRESHOLDS:\n",
    "        st = rec[\"thr_stats\"].get(label, None)\n",
    "        if st is None:\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> count=0     lift_vs_base=N/A\")\n",
    "        else:\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "\n",
    "    # Top-K results\n",
    "    print(\"  > Top-K (by score desc):\")\n",
    "    for k in sorted(set(TOPK_LIST)):\n",
    "        label = f\"TOPK_SCORE={k}\"\n",
    "        st = rec[\"topk_stats\"].get(label, None)\n",
    "        if st is None:\n",
    "            print(f\"    {label:<14} -> count=0     lift_vs_base=N/A\")\n",
    "        else:\n",
    "            print(f\"    {label:<14} -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "\n",
    "    # Best picks (per SAE) – kept for reference in per-SAE section\n",
    "    print(\"  >> Per-SAE Best selections:\")\n",
    "    if rec[\"best_thr\"] is not None:\n",
    "        lab, st = rec[\"best_thr\"]\n",
    "        thr = st.get(\"threshold\", None)\n",
    "        thr_str = f\"(T={thr:g}) \" if thr is not None else \"\"\n",
    "        print(f\"     Best Threshold: {lab:<14} {thr_str}-> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "    else:\n",
    "        print(\"     Best Threshold: N/A\")\n",
    "\n",
    "    if rec[\"best_topk\"] is not None:\n",
    "        lab, st = rec[\"best_topk\"]\n",
    "        print(f\"     Best Top-K    : {lab:<14} -> count={st['count']:<5} avg={st['avg']:.6f}{mark_vs_overall(st['avg'], rec['base_avg'])}  lift_vs_base={fmt_lift(st['lift_pct'])}\")\n",
    "    else:\n",
    "        print(\"     Best Top-K    : N/A\")\n",
    "\n",
    "\n",
    "# =====================================================================================\n",
    "# Aggregation by Architecture and Across All\n",
    "# =====================================================================================\n",
    "\n",
    "def aggregate_by_architecture(records: List[Tuple[str, str, Dict[str, Any]]]):\n",
    "    \"\"\"\n",
    "    Input: [(arch_name, sae_name, rec_dict), ...]\n",
    "    Print per-architecture (SAEs per arch) and across-all summaries:\n",
    "      - For each threshold / Top-K: total selected count, pooled avg_selected, lift vs base\n",
    "      - Architecture Best (single choice across SAEs): pick single T/K from the aggregated tables\n",
    "      - Across all SAEs: report the average per-SAE selected count and average per-SAE lift for\n",
    "        each SAE's own best threshold and best topK (no global single T/K).\n",
    "    Baseline for a group is the weighted average over ALL its SAEs:\n",
    "      base_avg = (sum of all features' overall) / (total feature count)\n",
    "    Pooled avg_selected = (sum of selected overall across SAEs) / (total selected count)\n",
    "    \"\"\"\n",
    "    # Group by architecture\n",
    "    by_arch: Dict[str, List[Dict[str, Any]]] = {}\n",
    "    for arch, _sae, rec in records:\n",
    "        by_arch.setdefault(arch, []).append(rec)\n",
    "\n",
    "    # Label orders\n",
    "    thr_labels = [lab for lab, _ in STEER_THRESHOLDS]\n",
    "    topk_labels = [f\"TOPK_SCORE={k}\" for k in sorted(set(TOPK_LIST))]\n",
    "\n",
    "    # helper maps to render T/K values\n",
    "    thr_val_map = {lab: thr for lab, thr in STEER_THRESHOLDS}\n",
    "    topk_val_map = {f\"TOPK_SCORE={k}\": k for k in sorted(set(TOPK_LIST))}\n",
    "\n",
    "    def aggregate_group(group_recs: List[Dict[str, Any]]):\n",
    "        \"\"\"\n",
    "        Returns:\n",
    "          base_avg, base_num_total, base_sum_total,\n",
    "          thr_agg:   label -> (count_total, pooled_avg_selected, lift_pct_vs_base)\n",
    "          topk_agg:  label -> (count_total, pooled_avg_selected, lift_pct_vs_base)\n",
    "          arch_best_single: {\"thr\": (label, tuple), \"topk\": (label, tuple)}\n",
    "        \"\"\"\n",
    "        base_num_total = sum(r[\"base_num\"] for r in group_recs)\n",
    "        base_sum_total = sum(r[\"base_sum\"] for r in group_recs)\n",
    "        base_avg = (base_sum_total / base_num_total) if base_num_total > 0 else 0.0\n",
    "\n",
    "        # Threshold aggregation (pooled)\n",
    "        thr_counts: Dict[str, int] = {lab: 0 for lab in thr_labels}\n",
    "        thr_sums: Dict[str, float] = {lab: 0.0 for lab in thr_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in thr_labels:\n",
    "                st = r[\"thr_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    thr_counts[lab] += int(st[\"count\"])\n",
    "                    thr_sums[lab] += float(st[\"sum\"])\n",
    "\n",
    "        thr_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in thr_labels:\n",
    "            cnt = thr_counts[lab]\n",
    "            avg_sel = (thr_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            thr_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        # Top-K aggregation (pooled)\n",
    "        topk_counts: Dict[str, int] = {lab: 0 for lab in topk_labels}\n",
    "        topk_sums: Dict[str, float] = {lab: 0.0 for lab in topk_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in topk_labels:\n",
    "                st = r[\"topk_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    topk_counts[lab] += int(st[\"count\"])\n",
    "                    topk_sums[lab] += float(st[\"sum\"])\n",
    "\n",
    "        topk_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in topk_labels:\n",
    "            cnt = topk_counts[lab]\n",
    "            avg_sel = (topk_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            topk_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        # Architecture Best (single choice across SAEs)\n",
    "        thr_best_single = choose_best_from_agg(thr_agg)\n",
    "        topk_best_single = choose_best_from_agg(topk_agg)\n",
    "\n",
    "        arch_best_single_dict = {\n",
    "            \"thr\": thr_best_single,   # (label, (cnt, avg_sel, lift))\n",
    "            \"topk\": topk_best_single  # (label, (cnt, avg_sel, lift))\n",
    "        }\n",
    "        return (base_avg, base_num_total, base_sum_total,\n",
    "                thr_agg, topk_agg, arch_best_single_dict)\n",
    "\n",
    "    # Print per-architecture summaries\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY BY ARCHITECTURE (aggregated over SAEs per architecture)\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for arch, group_recs in sorted(by_arch.items()):\n",
    "        (base_avg, base_n, _base_sum,\n",
    "         thr_agg, topk_agg, arch_best_single) = aggregate_group(group_recs)\n",
    "\n",
    "        print(f\"\\n[ARCH] {arch}  | SAEs={len(group_recs)}  | Base steering score={base_avg:.6f}  (Total features N={base_n})\")\n",
    "\n",
    "        print(\"  > Threshold (score >= T):\")\n",
    "        for label, thr in STEER_THRESHOLDS:\n",
    "            cnt, avg_sel, lift = thr_agg[label]\n",
    "            print(f\"    {label:<14} (T={thr:g}) -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "        print(\"  > Top-K (by score desc):\")\n",
    "        for k in sorted(set(TOPK_LIST)):\n",
    "            label = f\"TOPK_SCORE={k}\"\n",
    "            cnt, avg_sel, lift = topk_agg[label]\n",
    "            print(f\"    {label:<14} -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "        # Architecture Best (single choice across SAEs)\n",
    "        print(\"  > Architecture Best (single choice across SAEs):\")\n",
    "        if arch_best_single[\"thr\"] is not None:\n",
    "            lab, (cnt, avg_sel, lift) = arch_best_single[\"thr\"]\n",
    "            t_val = thr_val_map.get(lab, None)\n",
    "            t_str = f\"(T={t_val:g}) \" if t_val is not None else \"\"\n",
    "            print(f\"    Best Threshold (single T): {lab:<14} {t_str}-> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "        else:\n",
    "            print(\"    Best Threshold (single T): N/A\")\n",
    "\n",
    "        if arch_best_single[\"topk\"] is not None:\n",
    "            lab, (cnt, avg_sel, lift) = arch_best_single[\"topk\"]\n",
    "            k_val = topk_val_map.get(lab, None)\n",
    "            k_str = f\"(K={k_val}) \" if k_val is not None else \"\"\n",
    "            print(f\"    Best Top-K (single K)    : {lab:<14} {k_str}-> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "        else:\n",
    "            print(\"    Best Top-K (single K)    : N/A\")\n",
    "\n",
    "    # Across all SAEs (treat all as one group) — do NOT choose a single global T/K\n",
    "    all_group = [rec for _arch, _sae, rec in records]\n",
    "\n",
    "    # Compute pooled tables across all SAEs (for reference)\n",
    "    def aggregate_all(group_recs: List[Dict[str, Any]]):\n",
    "        base_num_total = sum(r[\"base_num\"] for r in group_recs)\n",
    "        base_sum_total = sum(r[\"base_sum\"] for r in group_recs)\n",
    "        base_avg = (base_sum_total / base_num_total) if base_num_total > 0 else 0.0\n",
    "\n",
    "        thr_counts: Dict[str, int] = {lab: 0 for lab in thr_labels}\n",
    "        thr_sums: Dict[str, float] = {lab: 0.0 for lab in thr_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in thr_labels:\n",
    "                st = r[\"thr_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    thr_counts[lab] += int(st[\"count\"])\n",
    "                    thr_sums[lab] += float(st[\"sum\"])\n",
    "        thr_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in thr_labels:\n",
    "            cnt = thr_counts[lab]\n",
    "            avg_sel = (thr_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            thr_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        topk_counts: Dict[str, int] = {lab: 0 for lab in topk_labels}\n",
    "        topk_sums: Dict[str, float] = {lab: 0.0 for lab in topk_labels}\n",
    "        for r in group_recs:\n",
    "            for lab in topk_labels:\n",
    "                st = r[\"topk_stats\"].get(lab, None)\n",
    "                if st is not None:\n",
    "                    topk_counts[lab] += int(st[\"count\"])\n",
    "                    topk_sums[lab] += float(st[\"sum\"])\n",
    "        topk_agg: Dict[str, Tuple[int, float, Optional[float]]] = {}\n",
    "        for lab in topk_labels:\n",
    "            cnt = topk_counts[lab]\n",
    "            avg_sel = (topk_sums[lab] / cnt) if cnt > 0 else 0.0\n",
    "            topk_agg[lab] = (cnt, avg_sel, pct_lift(avg_sel, base_avg))\n",
    "\n",
    "        return base_avg, base_num_total, thr_agg, topk_agg\n",
    "\n",
    "    all_base_avg, all_base_n, all_thr_agg, all_topk_agg = aggregate_all(all_group)\n",
    "\n",
    "    print(\"\\n\" + \"=\" * 80)\n",
    "    print(\"SUMMARY ACROSS ALL SAEs\")\n",
    "    print(\"-\" * 80)\n",
    "    print(f\"All SAEs | Base steering score={all_base_avg:.6f}  (Total features N={all_base_n})\")\n",
    "\n",
    "    print(\"  > Threshold (score >= T):\")\n",
    "    for label, thr in STEER_THRESHOLDS:\n",
    "        cnt, avg_sel, lift = all_thr_agg[label]\n",
    "        print(f\"    {label:<14} (T={thr:g}) -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, all_base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "    print(\"  > Top-K (by score desc):\")\n",
    "    for k in sorted(set(TOPK_LIST)):\n",
    "        label = f\"TOPK_SCORE={k}\"\n",
    "        cnt, avg_sel, lift = all_topk_agg[label]\n",
    "        print(f\"    {label:<14} -> total_count={cnt:<6} avg_selected={avg_sel:.6f}{mark_vs_overall(avg_sel, all_base_avg)}  lift_vs_base={fmt_lift(lift)}\")\n",
    "\n",
    "    # Per your request: do NOT pick a single global best T/K here.\n",
    "    # Instead, average per-SAE selections after each SAE chooses its own best threshold and best topK.\n",
    "    total_saes = len(all_group)\n",
    "    # Treat None lift as 0 for averaging; counts are integers (0 if no selection available)\n",
    "    avg_best_thr_count_per_sae = sum(r.get(\"best_thr_count\", 0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_thr_lift_per_sae  = sum((r.get(\"best_thr_lift_pct\") or 0.0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_topk_count_per_sae = sum(r.get(\"best_topk_count\", 0) for r in all_group) / max(total_saes, 1)\n",
    "    avg_best_topk_lift_per_sae  = sum((r.get(\"best_topk_lift_pct\") or 0.0) for r in all_group) / max(total_saes, 1)\n",
    "\n",
    "    print(\"\\n  > Per-SAE selections (averaged across SAEs):\")\n",
    "    print(f\"    Average Best-Threshold -> avg_count_per_SAE={avg_best_thr_count_per_sae:.2f}  avg_lift_vs_base={avg_best_thr_lift_per_sae:.2f}%\")\n",
    "    print(f\"    Average Best-TopK      -> avg_count_per_SAE={avg_best_topk_count_per_sae:.2f}  avg_lift_vs_base={avg_best_topk_lift_per_sae:.2f}%\")\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",
    "    # Discover SAEs (flat or nested) and process them\n",
    "    sae_items = discover_saes(EVAL_ROOT, ENTROPY_ROOT)\n",
    "    if not sae_items:\n",
    "        print(f\"No SAEs discovered under: {EVAL_ROOT}\")\n",
    "        return\n",
    "\n",
    "    records: List[Tuple[str, str, Dict[str, Any]]] = []\n",
    "\n",
    "    print(\"=\" * 80)\n",
    "    print(f\"Discovered {len(sae_items)} SAE directories.\")\n",
    "    print(\"-\" * 80)\n",
    "\n",
    "    for item in sae_items:\n",
    "        arch_name = item[\"arch_name\"]\n",
    "        sae_name = item[\"sae_name\"]\n",
    "        eval_path = item[\"eval_path\"]\n",
    "        entropy_path = item[\"entropy_path\"] if item.get(\"entropy_path\") else None\n",
    "\n",
    "        rec = process_one_sae(eval_path, entropy_path)\n",
    "        if rec is None:\n",
    "            print(f\"[SKIP] arch={arch_name}  sae={sae_name}  (missing/invalid eval)\")\n",
    "            continue\n",
    "\n",
    "        # Per-SAE output\n",
    "        print_per_sae(arch_name, sae_name, rec)\n",
    "\n",
    "        records.append((arch_name, sae_name, rec))\n",
    "\n",
    "    if not records:\n",
    "        print(\"No valid SAE records to summarize.\")\n",
    "        return\n",
    "\n",
    "    # Aggregate: by architecture + all SAEs\n",
    "    aggregate_by_architecture(records)\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dc5eb730",
   "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
}
