{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# SAE Analysis for PVA-SAE Project\n",
    "\n",
    "This notebook implements the complete SAE analysis pipeline using the cleaned up components:\n",
    "\n",
    "1. **SAE Activation Collection** - Extract activations at final token using hooks\n",
    "2. **Compute Separation Scores** - Calculate activation fractions per thesis methodology  \n",
    "3. **ArgMax Selection** - Find best features for correct/incorrect code\n",
    "4. **PVA Latent Direction** - Identify program validity awareness directions\n",
    "\n",
    "Using: Gemma 2 2B model, Layer 20 SAE, 10 MBPP samples\n",
    "\n",
    "**Usage**: Simply run all cells in order. The pipeline will handle all the complex steps automatically."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Setup & Load Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n",
      "Cleared MPS cache\n",
      "Device: mps\n",
      "MPS allocated: 14.26 GB\n"
     ]
    }
   ],
   "source": [
    "# Imports\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from pathlib import Path\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "\n",
    "# Enable autoreload to pick up module changes\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "# Clear MPS cache first\n",
    "if torch.backends.mps.is_available():\n",
    "    torch.mps.empty_cache()\n",
    "    print(\"Cleared MPS cache\")\n",
    "\n",
    "# Setup\n",
    "DEVICE = \"mps\" if torch.backends.mps.is_available() else \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "print(f\"Device: {DEVICE}\")\n",
    "\n",
    "# Check memory status\n",
    "if DEVICE == \"mps\":\n",
    "    print(f\"MPS allocated: {torch.mps.current_allocated_memory() / 1024**3:.2f} GB\")\n",
    "elif DEVICE == \"cuda\":\n",
    "    print(f\"CUDA allocated: {torch.cuda.memory_allocated() / 1024**3:.2f} GB\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded: dataset_gemma-2-2b_2025-06-01_14-54-19.parquet\n",
      "Shape: (10, 4)\n",
      "\n",
      "Correct: 3, Incorrect: 7\n"
     ]
    }
   ],
   "source": [
    "# Load dataset\n",
    "data_dir = Path(\"../data/datasets\")\n",
    "dataset_files = list(data_dir.glob(\"dataset_*.parquet\"))\n",
    "\n",
    "if dataset_files:\n",
    "    latest_dataset = max(dataset_files, key=lambda x: x.stat().st_mtime)\n",
    "    df = pd.read_parquet(latest_dataset)\n",
    "    print(f\"Loaded: {latest_dataset.name}\")\n",
    "    print(f\"Shape: {df.shape}\")\n",
    "    \n",
    "    # Add is_correct column\n",
    "    if 'test_passed' in df.columns:\n",
    "        df['is_correct'] = df['test_passed']\n",
    "    \n",
    "    print(f\"\\nCorrect: {df['is_correct'].sum()}, Incorrect: {(~df['is_correct']).sum()}\")\n",
    "else:\n",
    "    print(\"No dataset found!\")\n",
    "    df = None"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "outputs": [],
   "source": "# Reconstruct prompts using modern PromptBuilder\nfrom common.prompt_utils import PromptBuilder\nfrom phase1_dataset_building.dataset_manager import PromptAwareDatasetManager\n\nif df is not None and 'prompt' not in df.columns:\n    print(\"Reconstructing prompts...\")\n    \n    # Load MBPP dataset\n    dataset_manager = PromptAwareDatasetManager()\n    dataset_manager.load_dataset()\n    \n    # Reconstruct prompts\n    prompts = []\n    for task_id in df['task_id']:\n        record = dataset_manager.get_record(task_id)\n        \n        # Extract components\n        problem_desc = record['text'].strip()\n        test_cases = '\\n'.join(record['test_list'])\n        \n        # Build prompt using modern PromptBuilder\n        prompt = PromptBuilder.build_standard_prompt(problem_desc, test_cases)\n        prompts.append(prompt)\n    \n    df['prompt'] = prompts\n    print(f\"Reconstructed {len(prompts)} prompts\")"
  },
  {
   "cell_type": "code",
   "metadata": {},
   "outputs": [],
   "source": "# Import simplified SAE analyzer\nfrom phase2_simplified.sae_analyzer import SimplifiedSAEAnalyzer, load_gemma_scope_sae\nfrom common.config import Config\n\nprint(\"Imports loaded\")"
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:You tried to specify center_unembed=True for a model using logit softcap, but this can't be done! Softcapping is not invariant upon adding a constant Setting center_unembed=False instead.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cleared memory and MPS cache\n",
      "Loading model with TransformerLens...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loading checkpoint shards: 100%|██████████| 3/3 [00:00<00:00, 34.50it/s]\n",
      "WARNING:root:You are not using LayerNorm, so the writing weights can't be centered! Skipping\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded pretrained model google/gemma-2-2b into HookedTransformer\n",
      "TransformerLens model loaded on mps\n",
      "SAE loaded\n"
     ]
    }
   ],
   "source": [
    "# Clear any existing models from memory first\n",
    "if 'model' in globals():\n",
    "    del model\n",
    "if 'sae_model' in globals():\n",
    "    del sae_model\n",
    "    \n",
    "# Force garbage collection and clear MPS cache\n",
    "import gc\n",
    "gc.collect()\n",
    "if torch.backends.mps.is_available():\n",
    "    torch.mps.empty_cache()\n",
    "    print(\"Cleared memory and MPS cache\")\n",
    "\n",
    "# Load model using TransformerLens\n",
    "print(\"Loading model with TransformerLens...\")\n",
    "model = HookedTransformer.from_pretrained(\n",
    "    MODEL_NAME,\n",
    "    torch_dtype=torch.float16 if DEVICE == \"cuda\" else torch.float32,\n",
    "    device=DEVICE\n",
    ")\n",
    "model.eval()\n",
    "print(f\"TransformerLens model loaded on {DEVICE}\")\n",
    "\n",
    "# Load SAE\n",
    "sae_model = load_gemma_scope_sae(\n",
    "    repo_id=SAE_CONFIG[\"repo_id\"],\n",
    "    sae_id=SAE_CONFIG[\"sae_id\"],\n",
    "    device=DEVICE\n",
    ")\n",
    "print(\"SAE loaded\")"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "outputs": [],
   "source": "# Load model and tokenizer\nfrom transformers import AutoModelForCausalLM, AutoTokenizer\n\nMODEL_NAME = \"google/gemma-2-2b\"\n\n# Load tokenizer\ntokenizer = AutoTokenizer.from_pretrained(MODEL_NAME)\nif tokenizer.pad_token is None:\n    tokenizer.pad_token = tokenizer.eos_token\n\n# Load model\nprint(\"Loading model...\")\nmodel = AutoModelForCausalLM.from_pretrained(\n    MODEL_NAME,\n    torch_dtype=torch.float16 if DEVICE == \"cuda\" else torch.float32,\n    device_map=\"auto\" if DEVICE == \"cuda\" else None\n)\nif DEVICE != \"cuda\":\n    model = model.to(DEVICE)\nmodel.eval()\nprint(f\"Model loaded on {DEVICE}\")"
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": "# Note: The simplified analyzer works differently\n# It expects activations to be saved to disk from Phase 1\n# This notebook would need to be restructured to:\n# 1. First run Phase 1 to generate activations\n# 2. Then run Phase 2 analysis on saved activations\n\nprint(\"\"\"\nThe simplified SAE analyzer expects activations to be saved from Phase 1.\nTo use it:\n\n1. Run Phase 1 to generate dataset and save activations:\n   python3 run.py phase 1 --end 10\n   \n2. Run Phase 2 to analyze saved activations:\n   python3 run.py phase 2\n   \nThe analysis results will be saved to data/phase2/sae_analysis_results.json\n\"\"\")",
   "outputs": []
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Separation score statistics:\n",
      "  Mean f_correct: 0.0020\n",
      "  Mean f_incorrect: 0.0021\n",
      "  Max s_correct: 0.3333\n",
      "  Max s_incorrect: 0.5238\n",
      "\n",
      "PVA Directions:\n",
      "  PVA Correct Direction: Layer 20, Feature 5386, Score=0.333\n",
      "  PVA Incorrect Direction: Layer 20, Feature 1613, Score=0.524\n"
     ]
    }
   ],
   "source": [
    "# Extract results for visualization\n",
    "if 'results' in locals():\n",
    "    scores = results.separation_scores\n",
    "    correct_direction = results.correct_direction\n",
    "    incorrect_direction = results.incorrect_direction\n",
    "    \n",
    "    print(\"Separation score statistics:\")\n",
    "    print(f\"  Mean f_correct: {scores.f_correct.mean():.4f}\")\n",
    "    print(f\"  Mean f_incorrect: {scores.f_incorrect.mean():.4f}\")\n",
    "    print(f\"  Max s_correct: {scores.s_correct.max():.4f}\")\n",
    "    print(f\"  Max s_incorrect: {scores.s_incorrect.max():.4f}\")\n",
    "    \n",
    "    print(\"\\nPVA Directions:\")\n",
    "    print(f\"  {correct_direction}\")\n",
    "    print(f\"  {incorrect_direction}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKUAAAHqCAYAAADVi/1VAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAj+tJREFUeJzt3QeYU9X29/FF74KA0kSKoohIEQTBgkpTUBTUC6g0Fb0ggqIiWOhdRCwoioKADfu1IFxpKoIgTRQRG0hTqnTpeZ/fvu/JP9NgMswkJ8n38zyByUkms09ykrOy9t5rZwsEAgEDAAAAAAAAIih7JP8YAAAAAAAAICSlAAAAAAAAEHEkpQAAAAAAABBxJKUAAAAAAAAQcSSlAAAAAAAAEHEkpQAAAAAAABBxJKUAAAAAAAAQcSSlAAAAAAAAEHEkpQAAAAAAABBxJKUAIMKuuOIKdwEAAED4iKWA+EFSCoiCbNmypesyd+7ciLRn9+7dNmDAAKtevboVLFjQ8uXLZ1WrVrWHH37YNm3aZLFm//791r9//7Cfv82bN9uDDz5olStXtvz581uBAgWsVq1aNnjwYNu5c6f5VceOHdM8hqZPn54lf/ONN96wMWPGZMljAwASi1/iorVr17q/M2rUKEt0xFLEUkCk5IzYXwIQNGXKlCTXJ0+ebJ9//nmK7eedd16Wt+X333+3Ro0a2bp16+zmm2+2u+66y3Lnzm0rVqywV155xT744AP7+eefLdYCKSXZJL29aN9++601a9bM9u7da7fddpsLoGTx4sU2fPhw+/LLL+2///2v+VWePHns5ZdfTrFdicasCqR++OEHu++++7Lk8QEAicNPcRH+h1jq/xBLAVmLpBQQBTpRh/rmm29c8JV8e1Y7cuSItWrVyvVqqSfs0ksvTXL7kCFDbMSIEZnyt/bt2+d6y5I7duyYHTp0yPLmzWvRop67li1bWo4cOWzZsmWudy/58zB+/Hjzs5w5c0b8+MmqIFg9qwCAxOGXuMjviKWyFrEUEB1M3wN8HHg88MADVrZsWddzc+6557rh5IFAIMn9NKy4W7du9vrrr7v7KCBRz5R6o07kvffes++++84effTRFAkpOeWUU1wQEeqdd95xj68pfsWLF3cn740bN6YYAq1pgL/99pvrMStUqJDdeuutKdp7/vnnu33zhkXrcW6//XYrUaKE267bJ0yYkKJdBw4ccEPKzznnHLe/pUqVcsk1/T0NvT/ttNPc/dTD5w291v3T8uKLL7q/PXr06BRBlKg9jz32WJJtzz//fLD9pUuXtnvuuSfVYekvvfSSnXXWWe75qlOnjn311VeptuHgwYPWr18/O/vss91j6nXv1auX254ZFLBqiLjarOdM+3T33Xfb33//neR+//nPf6x58+Zun9QOtX3QoEF29OjR4H3UY/rpp5/aH3/8EXx+y5cv72579dVX3XW9DqGU9Ew+9UKPo2miS5Ysscsvv9wFUI888khYz4e+tOjYLVKkiDvm9B7wHgMAED8iERelxjuvff3119azZ08XYygxpATM1q1bU9z/s88+swYNGrjYR3HURRdd5EbEhCKW+h9iKWIpQBgpBfiQAqwWLVrYnDlz7I477rAaNWrYjBkz7KGHHnIn/KeeeirJ/b/44gubOnWqde/e3Z10dJK/+uqrbdGiRe5ElZaPPvrI/d+uXbt0tUsnyU6dOrkAa9iwYW6E1dNPP+0CNfWK6WQWOgqradOm7iSnoDG0x2b27Nn29ttvu4BKwZhOwnqsiy++OBhoKRhSYKf9V80rb2izTujXXnutzZo1y9q0aWM9evSwPXv2uBOqhkBrKuILL7xgXbp0cQGjAiypVq3acZ8HBTo33XRTup4HBWUK0vS39HdWr17t/qaGreu5yJUrl7ufpj8qWKlfv75rv6ZK6nUtWrSoCwxCgxxtnzdvnps+qekJ33//vXudNXXyww8/TFe7tm3bluS62lG4cGH3s9rhvX46TtasWWPPPfece91C26z7KCBR4K3/9Vr17dvXvQZPPPGEu4+SmLt27bINGzYEj0XdNyO2b99u11xzjXstFZQrwEvv87Fy5Up3LOi1HThwoDv2f/31V7c/AID4Eam46HjuvfdeO/XUU92XfCULlJxQvKK/49E5VAkhJS369Onj4iKdZ5UwuuWWW4L3IZYiliKWAkIEAETdPffco26+4PUPP/zQXR88eHCS+910002BbNmyBX799dfgNt1Pl8WLFwe3/fHHH4G8efMGWrZsedy/W7NmzUDhwoXT1cZDhw4FTj/99EDVqlUD//zzT3D7J5984v5+3759g9s6dOjgtvXu3TvF42h79uzZAytXrkyy/Y477giUKlUqsG3btiTb27Rp49q4f/9+d33ChAnuMUaP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AACAEyOmAgAAiS7spNTll1/uVsALDZb0s7apoDgAAABOjJgKAAAkunSvvucZMWKEC6LOPfdcu+yyy9y2r776yhWxmj17dla0EQAAIO4QUwEAgEQX9kipKlWq2IoVK+xf//qXbdmyxQ07b9++vf30009WtWrVrGklAABAnCGmAgAAiS7skVJSunRpGzp0aOa3BgAAIIEQUwEAgEQW9kgpb2j5bbfdZvXr17eNGze6bVOmTLF58+ZldvsAAADiFjEVAABIZGEnpd577z1r2rSp5cuXz5YuXWoHDx4MrhRDTx8AAED6EFMBAIBEF3ZSavDgwTZu3DgbP3685cqVK7j9kksucQEVAAAAToyYCgAAJLqwk1KrV692K8UkV7hwYdu5c2dmtQsAACCuEVMBAIBEF3ZSqmTJkvbrr7+m2K7aBxUrVsysdgEAAMQ1YioAAJDowk5Kde7c2Xr06GELFy60bNmy2aZNm+z111+3Bx980Lp06ZI1rQQAAIgzxFQAACDR5Qz3F3r37m3Hjh2zhg0b2v79+92w8zx58rgA6t57782aVgIAAMQZYioAAJDowkpKHT161L7++mu755577KGHHnJDzvfu3WtVqlSxggULZl0rAQAA4ggxFQAAQJhJqRw5cliTJk1s1apVVqRIERc4AQAAIDzEVAAAABmoKVW1alX7/fffs6Y1AAAACYKYCgAAJLqwk1KDBw92tQ4++eQT+/PPP2337t1JLgAAADgxYioAAJDowi503qxZM/d/ixYt3EoxnkAg4K6rRgIAAACOj5gKAAAkurCTUnPmzMmalgAAACQQYioAAJDowkpKHT582AYOHGjjxo2zSpUqZV2rAAAA4hgxFQAAQJg1pXLlymUrVqzIutYAAAAkAGIqAACADBQ6v+222+yVV17JmtYAAAAkCGIqAACQ6MKuKXXkyBGbMGGCzZw502rVqmUFChRIcvvo0aMzs30AAABxiZgKMeGN/yvC7zu3BKLdAgBApJNSP/zwg1144YXu559//jnJbaErxwAAACBtxFQAACDRsfoeAABAFBBTAQCARBd2TalQGzZscBcAAABkHDEVAABIRGEnpY4dO+aWMC5cuLCVK1fOXYoUKWKDBg1ytwEAAODEiKkAAECiC3v63qOPPupWihk+fLhdcsklbtu8efOsf//+duDAARsyZEhWtBMAACCuEFMB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AQAAxCmtZgwAAJDI/m9eXCa7++67U6yqBwAAAAAAAGRpUioQCPAMAwAAAAAAILJJKQAAAAAAACAtJKUAAAAAAAAQcSSlAAAAouyCCy6w9evXR7sZAAAA/lt9D0iufO9Pza/WDm8e7SYAABCWtWvX2uHDh6PdDAAAAP+NlHrmmWfswIED7ud169alq4h5uXLlLFeuXCffQgAAAAAAACRmUqpnz562e/du93OFChVs69atJ/ydH374wcqWLXvyLQQAAIhzl112meXLly/azQAAAPDf9L3SpUvbe++9Z82aNXOjpDZs2BAcOZXcmWeemdltBAAAiGvTpk2LdhMAAAD8mZR67LHH7N5777Vu3bpZtmzZ7KKLLkpxHyWrdNvRo0ezop0AAAAAAABItKTUXXfdZW3btrU//vjDqlWrZjNnzrRixYplfesAAAAAAACQ2KvvFSpUyKpWrWoTJ060Sy65xPLkyZO1LQMAAAAAAEDcSndSytOhQ4esaQkAAAAAAAASRrpW3wMAAEDmqlixom3fvj3F9p07d7rbAAAA4h1JKQAAgChYu3ZtqgvEHDx40DZu3BiVNgEAAPh6+h4AAAAy7qOPPgr+PGPGDCtcuHDwupJUs2bNsvLly0epdQAAADGSlPr666+tdu3aFD0HAABIpxtuuMH9ny1bthS1OnPlyuUSUk8++WSUWgcAABAjSalrrrnGli9fTt0DAACAdDp27Jj7v0KFCvbtt99a8eLFo90kAACA2EtKBQKBzGsJAABAAlmzZk20mwAAABBVFDoHAACIgu7du9szzzyTYvtzzz1n9913X1TaBAAAEDNJqRdffNFKlCiRea0BAABIEO+9955dcsklKbbXr1/f3n333ai0CQAAIGam791yyy2Z1xIAAIAEsn379iQr73lOOeUU27ZtW1TaBAAAEElM3wMAAIiCs88+26ZPn55i+2effcYiMgAAICGc1EgpAAAAZEzPnj2tW7dutnXrVrvqqqvctlmzZtmTTz5pY8aMiXbzAAAAshxJKQAAgCi4/fbb7eDBgzZkyBAbNGiQ21a+fHl74YUXrH379tFuHgAAgP+m73355Zd25MiRFNu1TbcBAAAgfbp06WIbNmywzZs32+7du+33338nIQUAABJG2EmpK6+80nbs2JFi+65du9xtAAAASB916s2cOdPef/99CwQCbtumTZts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ggUL2vbt293Pc+fOtcOHD5/wdy699FLLkydPeh4eAAAgIRBTAQAA/J+clg6NGjWyK6+80s477zx3vWXLlpY7d+5U7zt79uz0PCQAAEDCIaYCAAAIMyn12muv2aRJk+y3336zL774ws4//3zLnz9/en4VAAAA/x8xFQAAQJhJqXz58tm///1v9/PixYttxIgRVqRIkfT8KgAAAP4/YioAAIAwk1Kh5syZE+6vAAAAIBliKgAAkOjSVeh8+PDhtn///nQ94MKFC+3TTz892XYBAADEHWIqAACAMJNSP/74o5UrV866du3qliXeunVr8LYjR47YihUr7Pnnn7f69etb69atrVChQul5WAAAgIRCTAUAABDm9L3Jkyfbd999Z88995zdcssttnv3bsuRI4dbntjr7atZs6bdeeed1rFjR8ubN296HhYAACChEFMBAABkoKZU9erVbfz48fbiiy+6Xrw//vjD/vnnHytevLjVqFHD/Q8AAIDjI6YCAADIYKHz7Nmzu4BJFwAAAGQMMRUAAEh06aopBQAAAAAAAGQmklIAAAAAAACIOJJSAAAAAAAASMyk1NixY618+fJuhZm6devaokWL0rzvypUr7cYbb3T3z5Ytm40ZMybFffr37+9uC71Urlw5i/cCAAAAAAAAWZ6U+vXXX23GjBlutRgJBAIZepypU6daz549rV+/frZ06VK3Ik3Tpk1ty5Ytqd5fyyVXrFjRhg8fbiVLlkzzcc8//3z7888/g5d58+ZlqH0AAABZKbNiKgAAgLhPSm3fvt0aNWpk55xzjjVr1swlfOSOO+6wBx54IOwGjB492jp37mydOnWyKlWq2Lhx4yx//vw2YcKEVO9/0UUX2RNPPGFt2rSxPHnypPm4OXPmdEkr78LyygAAwE8yO6YCAACINTnD/YX777/fJXzWrVtn5513XnB769at3YinJ598Mt2PdejQIVuyZIn16dMnyfLICtAWLFhgJ+OXX36x0qVLuymB9erVs2HDhtmZZ555Uo8JAACQWTIzpgIAIE1vZDNfuoWRwchAUuq///2vG2J+xhlnJNleqVIl++OPP8J6rG3bttnRo0etRIkSSbbr+k8//WQZpbpUr776qp177rmu13HAgAF22WWX2Q8//GCFChVKcf+DBw+6i2f37t0Z/tsAAACRjqkAAAASIim1b98+N70uuR07dhx3Ol0kXXPNNcGfq1Wr5pJU5cqVs7ffftsNiU9Oo6iUuAIAAIiUWIipAAAAfFVTSiOOJk+eHLyule2OHTtmI0eOtCuvvDKsx1Kdpxw5ctjmzZuTbNf14xUxD1eRIkVcvQYVEk2Npg/u2rUreFm/fn2m/W0AAICsjqkAAAASYqSUAqWGDRva4sWLXU2oXr162cqVK12v3tdffx3WY+XOndtq1apls2bNshtuuMFtUzCm6926dbPMsnfvXvvtt9+sXbt2qd6u3kh6JAEAQCRlZkwFAACQECOlqlataj///LNdeumldv3117uh561atbJly5bZWWedFXYDVMhz/PjxNmnSJFu1apV16dLFPaZW45P27dsnKYSuoG358uXuop83btzofg4dBfXggw/aF198YWvXrrX58+dby5Yt3Yistm3bht0+AACArJDZMRUAAEBcj5Q6fPiwXX311TZu3Dh79NFHM6UBWmFm69at1rdvX/vrr7+sRo0aNn369GDxc61IoxX5PJs2bbKaNWsGr48aNcpdGjRoYHPnznXbNmzY4BJQWmr5tNNOc8HeN998434GAACItqyIqQAAAOI6KZUrVy5bsWJFpjdCU/XSmq7nJZo85cuXt0Dg+EtHvvXWW5naPgAAgMyUVTEVAABAXE/fu+222+yVV17JmtYAAAAkCGIqAACQ6MIudH7kyBGbMGGCzZw50xUpL1CgQJLbR48enZntAwAAiEvEVAAAINGFnZT64Ycf7MILL3Q/qzhnKC1lDADpUb73p+ZXa4c3j3YTACQAYioAAJDowk5KzZkzJ2taAgAAkECIqQAAQKILu6ZUKK1ypwsAAAAyjpgKAAAkorCTUseOHbOBAwda4cKFrVy5cu5SpEgRGzRokLsNAAAAJ0ZMBQAAEl3Y0/ceffRRt1LM8OHD7ZJLLnHb5s2bZ/3797cDBw7YkCFDsqKdAAAAcYWYCgAAJLqwk1KTJk2yl19+2Vq0aBHcVq1aNStTpox17dqVAAoAACAdiKkAAECiC3v63o4dO6xy5coptmubbgMAAMCJEVMBAIBEF3ZSqnr16vbcc8+l2K5tug0AAAAnRkwFAAASXdjT90aOHGnNmze3mTNnWr169dy2BQsW2Pr1623atGlZ0UYAAIC4Q0wFAAASXdgjpRo0aGCrV6+2li1b2s6dO92lVatWbttll12WNa0EAACIM8RUAAAg0YU9UkpUgJPimwAAACeHmAoAACSysEdKTZw40d55550U27VNq8gAAADgxIipAABAogs7KTVs2DArXrx4iu2nn366DR06NLPaBQAAENeyIqYaO3aslS9f3vLmzWt169a1RYsWpXnf8ePHu2mCp556qrs0atTouPcHAACIelJq3bp1VqFChRTby5Ur524DAABA5GOqqVOnWs+ePa1fv362dOlSt4Jf06ZNbcuWLanef+7cuda2bVubM2eOK7BetmxZa9KkiW3cuDFD+wMAAJDlSSn13q1YsSLF9u+++86KFSsWdgMAAAASUWbHVKNHj7bOnTtbp06drEqVKjZu3DjLnz+/TZgwIdX7v/7669a1a1erUaOGVa5c2V5++WU7duyYzZo1K0P7AwAAkOVJKfWode/e3fWqHT161F1mz55tPXr0sDZt2oTdAAAAgESUmTHVoUOHbMmSJW4Knid79uzuukZBpcf+/fvt8OHDVrRo0VRvP3jwoO3evTvJBQAAIKKr7w0aNMjWrl1rDRs2tJw5//fr6lVr3749NaUAAACiEFNt27bNJbVKlCiRZLuu//TTT+l6jIcffthKly6dJLGVvAbWgAEDwmoXAABApialcufO7WoWDB482JYvX2758uWzCy64wNU/AAAAQOzFVMOHD7e33nrL1ZlSkfTU9OnTx9Ws8miklOpQAQAARCwp5alUqZK7HDlyxA4cOJDhBgAAACSyzIiptIpfjhw5bPPmzUm263rJkiWP+7ujRo1ySamZM2datWrV0rxfnjx53AUAACDiNaU+/vhje/XVV5NsGzJkiBUsWNCKFCniVmv5+++/M61hAAAA8SgrYiqNuqpVq1aSIuVe0fJ69eql+XsjR4500winT59utWvXzsDeAAAARCAppRVd9u3bF7w+f/5869u3rz3++OP29ttv2/r1611QAwAAgMjHVJpaN378eJs0aZKtWrXKunTp4v6OVuMT1arSFDzPiBEj3N/U6nzly5e3v/76y1327t2bSXsKAACQSdP3Vq5c6YIoz7vvvmuNGze2Rx991F1X/QGtFhN6HwAAAEQmpmrdurVt3brVJbiUXKpRo4YbAeUVP1+3bp1bkc/zwgsvuFX7brrppiSP069fP+vfv/9J7iUAAEAmJqX27NljxYoVC16fN2+e3XzzzcHr559/vm3atCm9DwcAAJCQsjKm6tatm7ukRkXMQ2nlPwAAgJiYvlemTBk3FFw0rPu7776z+vXrB2/fvn275c+fP2taCQAAECeIqQAAAMJMSqkH77777rMpU6ZY586d3UouF198cfD2xYsX27nnnpvehwMAAEhIxFQAAABhTt9TfYKNGzda9+7dXfD02muvuaWHPW+++aZdd9116X04AACAhERMBQAAEGZSKl++fDZ58uQ0b58zZ056HwoAACBhEVMBAACEOX0PAAAAAAAAyCwkpQAAAAAAABBxJKUAAAAAAAAQcSSlAAAAAAAAEHEkpQAAAAAAAODf1fdCzZo1y122bNlix44dS3LbhAkTMqttAAAAcY2YCgAAJLKwk1IDBgywgQMHWu3ata1UqVKWLVu2rGkZAABAHCOmAgAAiS7spNS4cePs1VdftXbt2mVNiwAAABIAMRUAAEh0YdeUOnTokNWvXz9rWgMAAJAgiKkAAECiCzspdeedd9obb7yRNa0BAABIEMRUAAAg0YU9fe/AgQP20ksv2cyZM61atWqWK1euJLePHj06M9sHAAAQl4ipAABAogs7KbVixQqrUaOG+/mHH35IchsFOgEAANKHmAoAACS6sJNSc+bMyZqWAAAAJBBiKgAAkOjCrikVasOGDe4CAACAjCOmAgAAiSjspNSxY8ds4MCBVrhwYStXrpy7FClSxAYNGuRuy4ixY8da+fLlLW/evFa3bl1btGhRmvdduXKl3Xjjje7+Gto+ZsyYk35MAACASMuKmAoAACCuk1KPPvqoPffcczZ8+HBbtmyZuwwdOtSeffZZe/zxx8NuwNSpU61nz57Wr18/W7p0qVWvXt2aNm1qW7ZsSfX++/fvt4oVK7q/X7JkyUx5TAAAgEjL7JgKAAAg7pNSkyZNspdfftm6dOniVorRpWvXrjZ+/Hh79dVXw26AVpbp3LmzderUyapUqWLjxo2z/Pnz24QJE1K9/0UXXWRPPPGEtWnTxvLkyZMpjwkAABBpmR1TAQAAxH1SaseOHVa5cuUU27VNt4Xj0KFDtmTJEmvUqNH/NSh7dnd9wYIF4TYtyx4TAAAgs2VmTAUAAJAQSSlNhdNQ8+S0TbeFY9u2bXb06FErUaJEku26/tdff4XbtAw/5sGDB2337t1JLgAAAFkpM2MqAACAWJQz3F8YOXKkNW/e3GbOnGn16tVz2zQCaf369TZt2jSLRcOGDbMBAwZEuxkAACCBxGNMBQAAkKUjpRo0aGA///yztWzZ0nbu3OkurVq1stWrV9tll10W1mMVL17ccuTIYZs3b06yXdfTKmKeFY/Zp08f27VrV/CiYBAAACArZWZMBQAAkBAjpaR06dI2ZMiQk/7juXPntlq1atmsWbPshhtucNu0BLKud+vWLWKPqYLpaRVNBwAAyCqZFVMBAADEbVJqxYoVVrVqVVcwXD8fj1aOCUfPnj2tQ4cOVrt2batTp46NGTPG9u3b51bOk/bt21uZMmXcFDuvkPmPP/4Y/Hnjxo22fPlyK1iwoJ199tnpekwAAIBoyMqYCgAAIC6TUjVq1HBFwk8//XT3c7Zs2SwQCKS4n7aryHg4WrdubVu3brW+ffu6v6HHnz59erBQ+bp161zg5tm0aZPVrFkzeH3UqFHuoiHwc+fOTddjAgAARENWxlQAAABxmZRas2aNnXbaacGfM5um1aU1tc5LNHnKly+favAWzmMCAABEQ1bHVAAAAHGXlCpXrlzw5z/++MPq169vOXMm/dUjR47Y/Pnzk9wXAAAA/4eYCgAA4CRW37vyyittx44dKbZr1TrdBgAAgBMjpgIAAIku7KSUps6pzkFy27dvtwIFCmRWuwAAAOIaMRUAAEh06Zq+J61atXL/K3jq2LGj5cmTJ3ibCnFqBRkNQQcAAEDaiKkAAADCTEoVLlw42KtXqFAhy5cvX/C23Llz28UXX2ydO3dO78MBAAAkJGIqAADC8EbKUcW+ccuJF2Hz9T7cks72+yEpNXHixODqdw8++CDDygEAADKAmAoAACDMpJSnX79+4f4KAAAAkiGmAgAAiS7spJS8++679vbbb9u6devs0KFDSW5bunRpZrUNAAAgrhFTAQCARBb26nvPPPOMderUyUqUKGHLli2zOnXqWLFixez333+3a665JmtaCQAAEGeIqQAAQKILOyn1/PPP20svvWTPPvusK8bZq1cv+/zzz6179+62a9eurGklAABAnCGmAgAAiS7spJSGl3vLFGu1mD179rif27VrZ2+++WbmtxAAACAOEVMBAIBEF3ZSqmTJkrZjxw7385lnnmnffPON+3nNmjVuaWMAAACcGDEVAABIdGEnpa666ir76KOP3M+qg3D//fdb48aNrXXr1tayZcusaCMAAEDcIaYCAACJLuzV91T74NixY+7ne+65xxXknD9/vrVo0cLuvvvurGgjAABA3CGmAgAAiS6spNSRI0ds6NChdvvtt9sZZ5zhtrVp08ZdAAAAkD7EVAAAAGFO38uZM6eNHDnSBVIAAADIGGIqAACADNSUatiwoX3xxRdZ0xoAAIAEQUwFAAASXdg1pa655hrr3bu3ff/991arVi0rUKBAkttVBwEAAADHR0wFAAASXdhJqa5du7r/R48eneK2bNmy2dGjRzOnZQAAAHGMmAoAACS6sJNS3ioxAAAAyDhiKgAAkOjCrikFAAAAAAAARHyklOzbt88V5ly3bp0dOnQoyW3du3c/6UYBAAAkAmIqAACQyMJOSi1btsyaNWtm+/fvd4FU0aJFbdu2bZY/f347/fTTCaAAAADSgZgKAAAkurCn791///123XXX2d9//2358uWzb775xv744w+3asyoUaOyppUAAABxhpgKAAAkurCTUsuXL7cHHnjAsmfPbjly5LCDBw9a2bJlbeTIkfbII49kTSsBAADiDDEVAABIdGEnpXLlyuWCJ9HQctVAkMKFC9v69eszv4UAAABxiJgKAAAkurBrStWsWdO+/fZbq1SpkjVo0MD69u3r6h9MmTLFqlatmjWtBAAAiDPEVAAAINGFPVJq6NChVqpUKffzkCFD7NRTT7UuXbrY1q1b7aWXXsqKNgIAAMQdYioAAJDowh4pVbt27eDPGmo+ffr0zG4TAABA3COmAgAAiS7skVKeLVu22FdffeUu6tEDAABA9GKqsWPHWvny5S1v3rxWt25dW7RoUZr3Xblypd14443u/tmyZbMxY8Zk+O8CAABELCm1Z88ea9eunZUpU8bVP9CldOnSdtttt9muXbsy3BAAAIBEkpkx1dSpU61nz57Wr18/W7p0qVWvXt2aNm3qEl6p2b9/v1WsWNGGDx9uJUuWzKQ9AgAAyOKk1J133mkLFy60Tz75xHbu3Oku+nnx4sV29913h/twAAAACSkzY6rRo0db586drVOnTlalShUbN26c5c+f3yZMmJDq/S+66CJ74oknrE2bNpYnT55M2iMAAIAsrimlYGnGjBl26aWXBrepJ278+PF29dVXh/twAAAACSmzYqpDhw7ZkiVLrE+fPsFt2bNnt0aNGtmCBQsyrb0HDx50F8/u3bsz7bEBAEBiCnukVLFixaxw4cIptmubVo0BAABA5GKqbdu22dGjR61EiRJJtuv6X3/9ZZll2LBhrm3epWzZspn22AAAIDGFnZR67LHHXM2C0CBHPz/00EP2+OOPZ3b7AAAA4lKsxVQaiaVaV95l/fr10W4SAABItOl7L7zwgv3666925plnuousW7fO1SPQijEvvvhi8L4qtAkAAICsi6mKFy9uOXLksM2bNyfZruuZWcRc7aL+FAAAiGpS6oYbbsjUBgAAACSizIqpcufObbVq1bJZs2YFH/PYsWPuerdu3TLlbwAAAPgiKaWlhgEAAHByMjOm0jTADh06WO3ata1OnTo2ZswY27dvn1uNT9q3b29lypRxdaG84ug//vhj8OeNGzfa8uXLrWDBgnb22WdnWrsAAAAyNSklWrL43Xfftd9++83VPShatKgbVq6Cmgp4AAAAELmYqnXr1m7KX9++fV1dqho1atj06dODxc81LVAr8nk2bdpkNWvWDF4fNWqUuzRo0MDmzp2byXsJAACQSUmpFStWuCWGterK2rVrrXPnzi6Aev/9913AM3ny5HAfEgAAIOFkdkylqXppTddLnmgqX768BQKBk2o/AABAxFff0/Dwjh072i+//GJ58+YNbm/WrJl9+eWXJ90gAACAREBMBQAAEl3YSalvv/3W7r777hTbNcQ8dEljAAAApI2YCgAAJLqwk1JaCnj37t0ptv/888922mmnZVa7AAAA4hoxFQAASHRhJ6VatGhhAwcOtMOHD7vr2bJlc3UPHn74Ybvxxhsz1IixY8e62gYaul63bl1btGjRce//zjvvWOXKld39L7jgAps2bVqS2zUUXu0KvVx99dUZahsAAEBWyIqYCgAAIK6TUk8++aTt3bvXTj/9dPvnn3/cKi1aOrhQoUI2ZMiQsBswdepUV1NByyJrtZnq1atb06ZNbcuWLanef/78+da2bVu74447bNmyZXbDDTe4yw8//JDkfkpC/fnnn8HLm2++GXbbAAAAskpmx1QAAABxv/qeVoj5/PPP7euvv7bvvvvOBVMXXnihWz0mI0aPHu1Wm+nUqZO7Pm7cOPv0009twoQJ1rt37xT3f/rpp13CScsmy6BBg1x7nnvuOfe7oUPiS5YsmaE2AQAAZLXMjqkAAADiPinlueSSS9zlZBw6dMiWLFliffr0CW7Lnj27C8YWLFiQ6u9ou0ZWhdLIqg8//DDF0sfqeTz11FPtqquussGDB1uxYsVOqr0AAACZLTNiKgAAgLievqdk0CeffJJk2+TJk61ChQou+XPXXXfZwYMHw/rj27Zts6NHj1qJEiWSbNf1tFad0fYT3V8jqdS2WbNm2YgRI+yLL76wa665xv2t1KjdKjQaegEAAMgKWRFTAQAAxHVSSoU4V65cGbz+/fffu7pOGtWkaXYff/yxDRs2zPygTZs2rnioiqCr3pQCPy27rNFTqVG7NYTeu5QtWzbibQYAAIkhlmIqAAAAXySlli9fbg0bNgxef+utt9xKeePHj3fT6Z555hl7++23w/rjxYsXtxw5ctjmzZuTbNf1tOpBaXs495eKFSu6v/Xrr7+merumD+7atSt4Wb9+fVj7AQAAEM2YCgAAIK5rSv39999Jps15U+I8F110UdjJnNy5c1utWrXcNDuNaJJjx4656926dUv1d+rVq+duv++++4LbVCRU29OyYcMG2759u5UqVSrV21UUXRcACEf53p+aX60d3jzaTQAQwZgKAAAgrkdKKXhas2ZNsED50qVL7eKLLw7evmfPHsuVK1fYDVCPoHoGJ02aZKtWrbIuXbrYvn37gqvxtW/fPkkh9B49etj06dPdMso//fST9e/f3xYvXhxMYmnlGq3M980339jatWtdAuv66693SyyrIDoAAEA0ZVVMBQAAELcjpZo1a+bqHKhwuFa6y58/v1122WXB21esWGFnnXVW2A1o3bq1bd261fr27euKldeoUcMlnbwexHXr1rkV+Tz169e3N954wx577DF75JFHrFKlSq49VatWdbdrOqDaoiTXzp07rXTp0takSRMbNGgQo6EAAEDUZVVMBQAAELdJKSV1WrVqZQ0aNLCCBQu6pI+m33kmTJjgkj8ZoVFOaU3XS604+c033+wuqcmXL5/NmDEjQ+0AAADIalkZUwEAAMRlUkqFwr/88ktXCFwBlEYkhXrnnXfcdgAAAKSNmAoAACDMpJSncOHCqW4vWrRouA8FAACQsIipAABAokt3oXMAAAAAAAAgs5CUAgAAAAAAQMSRlAIAAAAAAEDEkZQCAAAAAABAxJGUAgAAAAAAQMSRlAIAAAAAAEDEkZQCAAAAAABAxJGUAgAAAAAAQMSRlAIAAAAAAEDEkZQCAAAAAABAxJGUAgAAAAAAQMSRlAIAAAAAAEDEkZQC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w5555hmLFT///LONGTPG/vzzT4tF+oxp1aqVNWjQwM477zx7/fXX3fZYen/q2G7UqJH7jLzgggts5MiRMZ8oROzRlw8l1fVFyk+fsxm1ZMkS95mgc57fY6XUrFq1yh544AHbtGlTzL0Wsfr5tWbNGps7d25Mx3mK6zZv3uziJtGxE0v7oc6Zu+++23X06X+dH2Pt/fvdd9+5z561a9dazpw53bZYeg1Wrlxp1157rTVs2NCqVavmvkPrOIoVy5cvt4svvtjmzZtnK1ascNti6fNTBwvizPfffx845ZRTAt27dw/89ttvSW47evRoIJasWLEiUKJEicDVV18daNCgQaBkyZKBN954I+BnP/74Y6Bo0aLu+R88eHDgnnvuCWTLli3w2GOPBdauXRuINatWrQr8+9//DsyfPz+47dixY4FYe09ccMEFgerVqwdy5coV6NSpkzu2/Eztu/DCCwOVK1cOnHHGGYHWrVsH/ECv/SOPPBL417/+Fdy2e/dud6zXqFEjMGLEiIDf/fLLL+49qvdlnz59Alu3bg3EkpUrVwaKFSsWuP/++wOvv/56oGfPnu64XrZsWSDW9uHBBx90P48aNcq9HuvWrYt205BA9Dl7/vnnu/NDkSJFApdcckkgli1fvjxQqFAhF3+EipVz9qFDhwIXX3xx4NRTT3Xn6Y0bN/o+dlWM1LlzZ3celCNHjgRiyerVq91ncfHixQMff/xxzB0z3vtY7129l3X83HzzzYGdO3cGYqn9OubvvvvuQJcuXQJNmzZ1x7/eD7HyOnz33XeB/PnzBx5++OFUb/fze9h7H+t98NBDD7nvmXfddVegUqVKgV27drnb/f46LF++PJAvXz4Xiys+r1WrViDWkJSKM3rzXHXVVYH77rsvuG39+vXuwyLWbN68OXDuuecGP+A2bdoUaNasWWDixIkBv1IwohPJnXfeGdymDzK9Jjlz5nRfIv/+++9ArFBSUwkRfVm87bbbAt9++23wNr9/QIcGXEpm6jj66aefAu+9917grLPOCjz99NMBv9KXdAUovXv3DixatCgwefLkQMWKFd12Pzz/HTt2DFx++eVJtikgV2Khdu3agddeey3gV3v37g3cfvvtbh/Gjh3rjm0FIbGSmNq+fXugSZMmKb50XnHFFYF77703Jt6beq51/PTo0SO4TW1W54OS30qukZxCJDqQ9CVESXZ9Ifnqq69cJ9i8efMCsUhxXoECBQK9evUKbjt48GBg27ZtgVih9l555ZWBxo0bBxo2bBho37594I8//vDt59qvv/4aKFOmTCBv3ryBG2+8MeYSU4qz9bmrc8qtt94aqFKlSuA///lP8HY/PuepdTKddtppLl6aOXOm66hRvHTRRRcliVn96vfff3cx6aOPPhrc1r9/fxeneDGL35M6+izVdxwvLtFx88orr7jYasiQIYGlS5f6eh8OHz7sPmt08Xz++eeBVq1aBXbs2OG+R/vZsmXLArlz53bvAZk9e3agXLlygbfeeisQS2JnTBrS5cCBA7Zt2zbr1KmTG0as6R2aQqahiLVq1bKFCxdarNB82Hz58tn999/vrpcqVcoKFizohlN27tzZhgwZYn6j51xTm8qVKxec9qbhtxdeeKFdf/31brrQO++8ExNDWtX2Z5991i655BKbOnWqm97wxBNP2OLFi2NmiLdq7ug4ueaaa2zYsGF27rnnuveEpgtpKqgfa9jo/aupn7fffrtrs6bHNW/e3M4880w3nWHGjBnB4yrSvNdbx7N3rHsKFSrk2lyzZk17/vnnbf/+/eZHGoqtz8Krr77aunbtam+99ZaNGjXKTR3Tc+93hw8ftp07d9pNN92UZGh2hQoVXH0m8fuQf7VPz/8999wT3DZ48GB3bOs1ue6669xnvIagA1lB7xV9XnXs2NGdIypXruymPZx//vm2ceNGe/XVV920vlihGigtW7Z057gRI0a4z2rFgZoee9ZZZ8VMOYfcuXO7Nt9yyy126623uilNKt+gz713333XVwV89+7da/369bN69erZ8OHD3XHTrl07V+cvR44cMTGVT+c8TbPq1auXmzJZp04d69OnT3AqayzEeR988IGroaN4Sd91dOwozlOsqvfAunXr3P38+np8++23Ls7u3r17kqmIan/dunXduVLnRj9PR1Q5AT2/lSpVcseUygq88sorNnPmTPv4449duQc/74PqX2kKa8WKFYPbFH/MmTPHLr/8cqtatar7HPLT50/ouUzxUs+ePd17QFQOoWjRovbpp59aTIl2VgyZPyrkvPPOc70fmnKlkUXqOViwYIHreVKPzpo1a2KiB0Q9HMr8vvzyy+76oEGDXCZew6Q1JU7DFL2eBD/RSCn19Hm9k+rxL1y4sOt97du3r8tea7SD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",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Simple visualization of top features\n",
    "if 'scores' in locals():\n",
    "    # Get top 10 features for each direction\n",
    "    top_k = 10\n",
    "    \n",
    "    top_correct_scores, top_correct_idx = torch.topk(scores.s_correct, top_k)\n",
    "    top_incorrect_scores, top_incorrect_idx = torch.topk(scores.s_incorrect, top_k)\n",
    "    \n",
    "    # Plot\n",
    "    fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(12, 5))\n",
    "    \n",
    "    # Correct direction\n",
    "    ax1.bar(range(top_k), top_correct_scores.cpu().numpy())\n",
    "    ax1.set_xlabel('Rank')\n",
    "    ax1.set_ylabel('Separation Score (f_correct - f_incorrect)')\n",
    "    ax1.set_title('Top Correct Code Features')\n",
    "    ax1.set_xticks(range(top_k))\n",
    "    ax1.set_xticklabels([f'{idx}' for idx in top_correct_idx.cpu().numpy()], rotation=45)\n",
    "    \n",
    "    # Incorrect direction\n",
    "    ax2.bar(range(top_k), top_incorrect_scores.cpu().numpy(), color='orange')\n",
    "    ax2.set_xlabel('Rank')\n",
    "    ax2.set_ylabel('Separation Score (f_incorrect - f_correct)')\n",
    "    ax2.set_title('Top Incorrect Code Features')\n",
    "    ax2.set_xticks(range(top_k))\n",
    "    ax2.set_xticklabels([f'{idx}' for idx in top_incorrect_idx.cpu().numpy()], rotation=45)\n",
    "    \n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Memory cleaned\n"
     ]
    }
   ],
   "source": [
    "# Clean up memory\n",
    "if 'model' in locals():\n",
    "    del model\n",
    "    if DEVICE == \"mps\":\n",
    "        torch.mps.empty_cache()\n",
    "    elif DEVICE == \"cuda\":\n",
    "        torch.cuda.empty_cache()\n",
    "    print(\"Memory cleaned\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Summary\n",
    "\n",
    "This notebook successfully demonstrates the cleaned up SAE analysis pipeline:\n",
    "\n",
    "1. ✅ **SAE Activation Collection** - Extracted activations at final prompt token\n",
    "2. ✅ **Separation Score Computation** - Computed using activation fractions (thesis methodology)\n",
    "3. ✅ **ArgMax Selection** - Selected best features for correct/incorrect directions\n",
    "4. ✅ **PVA Latent Direction** - Identified program validity awareness directions for layer 20\n",
    "\n",
    "The pipeline automatically handles all complex steps including:\n",
    "- Model and SAE loading\n",
    "- Hook-based activation extraction\n",
    "- Separation score computation\n",
    "- Feature ranking and selection\n",
    "\n",
    "The identified PVA directions can now be used for model steering experiments in Phase 3."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pva_sae",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}