{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60f47f09",
   "metadata": {},
   "outputs": [],
   "source": [
    "import dictionary_learning.utils as utils\n",
    "from dictionary_learning.trainers.batch_top_k import BatchTopKSAE\n",
    "import json\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from dictionary_learning import utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7cf27c57",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jovyan/.mlspace/envs/ort/lib/python3.12/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "CORE_PATH = '../SAEBench/eval_results/core' # put here path to folder with SAEBench core results for sae\n",
    "BATCH_TOP_K_PATH = '/home/user/sae_models/batch_topk' # put here path to folder with saes\n",
    "ORT_PATH = '/home/user/sae_models/ort' # put here path to folder with saes\n",
    "\n",
    "batch_top_k_paths = utils.get_nested_folders(BATCH_TOP_K_PATH)\n",
    "batch_top_k_ort_paths = utils.get_nested_folders(ORT_PATH)\n",
    "\n",
    "batch_top_k_path = [path for path in batch_top_k_paths if 'trainer_3' in path][0]\n",
    "ort_path = [path for path in batch_top_k_ort_paths if 'trainer_3' in path][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "64a31562",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jovyan/.mlspace/envs/ort/lib/python3.12/site-packages/dictionary_learning/trainers/batch_top_k.py:78: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  state_dict = t.load(path)\n"
     ]
    }
   ],
   "source": [
    "sae0 = BatchTopKSAE\n",
    "sae0 = sae0.from_pretrained(path=batch_top_k_path+'/ae.pt')\n",
    "sae0.W_dec = sae0.decoder.weight.data\n",
    "sae0.W_enc = sae0.encoder.weight.data.T\n",
    "\n",
    "sae1 = BatchTopKSAE\n",
    "sae1 = sae1.from_pretrained(path=ort_path+'/ae.pt')\n",
    "sae1.W_dec = sae1.decoder.weight.data\n",
    "sae1.W_enc = sae1.encoder.weight.data.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f626148",
   "metadata": {},
   "outputs": [],
   "source": [
    "json_filename = \"path_to_SAEBench_core_metrics_of_model\" # put here path to json with SAEBench core results for sae\n",
    "with open(json_filename, 'r') as f:\n",
    "    eval_data = json.load(f)\n",
    "\n",
    "valid_indices = [feature['index'] for feature in eval_data['eval_result_details'] if feature['feature_density'] > 1e-7]\n",
    "sae0.W_dec = sae0.W_dec[:, valid_indices]\n",
    "sae0.W_enc = sae0.W_enc[:, valid_indices]\n",
    "\n",
    "\n",
    "json_filename = \"path_to_SAEBench_core_metrics_of_model\" # put here path to json with SAEBench core results for sae\n",
    "with open(json_filename, 'r') as f:\n",
    "    eval_data = json.load(f)\n",
    "\n",
    "valid_indices = [feature['index'] for feature in eval_data['eval_result_details'] if feature['feature_density'] > 1e-7]\n",
    "sae1.W_dec = sae1.W_dec[:, valid_indices]\n",
    "sae1.W_enc = sae1.W_enc[:, valid_indices]\n",
    "\n",
    "W_1 = sae0.W_dec\n",
    "W_2 = sae1.W_dec"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d6738c7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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LtXJkyclnfsjbIyR2+32/gwA/sYYox9//FH169dXeHi4vv766yzPc7vdCgwMVJs2bSRJGzdulCSlpaV5V7XLuO55PJ78KR5XJUIFgEJl27ZtKlmypEJDQxUXF6fXX3/dOwH7wj+gktSiRQtVqVJFmzdv1qFDhyRJDodDAQEBCggIkHTuD/DcuXOVnJxcAKMBgKxZlqWvv/5aO3fulMfj0YgRI7Rt2zZJmZfAzvj3Hj16SJLmzZsn6dwdW7fb7T0eEBDAnQrkKf7fBaDAHTx4UPPmzdOUKVO0ePFi712FC/9wZnzDFhQUpFOnTqlevXq688479fXXX2vcuHGZ3i8jVFStWlWNGjXSiRMnvO954MABTZw4UTfffLMiIyPVsmVLjRs3zhs6ACA/pKWlyeVyZXks405qxpcdZcqU0bZt2/TWW28pMTHRe+dBkjco3HTTTZKkBQsWSJJCQkLkdDplWZaOHz+uqVOn6tZbb9W0adO87w/kJuZUAMhXGc/2rl+/XtOmTdPXX3+tP//80/tIUvny5fXqq6/qwQcfzPS6jD+ciYmJks492jRgwAAtWLBA7777ru6++261atXKe37GBOxWrVpp/vz5evzxxxUfH68//vhDklSxYkV16tRJjRs3VseOHZnMCCBPJScna/ny5Vq5cqWOHDkiy7LUsWNH3XXXXQoPD890bkBAgFwulxwOhyIiIjRw4EAtXLhQX375pa655hq98MIL3nMzro2NGzdWZGSk9u7dqwMHDui3337Tl19+qe+//1779++XdO5LmRtuuEEul8t7txbILYQKAPnKsix9//33evzxx7V37141a9ZMvXr1Urly5RQdHa3U1FSVKVPGe+5f7dixQ5JUv359NWnSRE8++aTeeOMNDRs2TOPGjVOjRo0yPTfcsmVLlSlTRnv27NF1112ne+65R02bNlWjRo1Uq1YtFS9ePH8GDuCqtH37dr311luaMWOGzp49q/DwcLlcLiUnJ2v//v1q2bKlGjVqdNHr0tPT9b///U9nz571fmnSu3dvjRgxQr1791bNmjW957rdbgUEBKhz58765ptvVLt2bblcLhUvXlwNGjTQzTffrGuvvVb169dXw4YNFRwcnJ+/AlwlCBUA8tXu3bsVExOjwMBAvffee+rdu7fKlSt32ddl/NE8e/aspPOPQz388MM6duyYPvvsM40fP16TJk2Sw+HwPhrQvHlzlS1bVklJSRo5cqRuuOGGi96bZWUB5IUDBw7omWee0aJFi9SgQQPdc889at68uWrUqKGIiAjt3r07y+tfxj4T8fHxcrlcsixLt9xyi/r166ePPvpIw4cP16uvvqrq1atn+hKlR48e+uabb1S1alW9+OKLqly5sho2bKjy5cvn57BxlSJUAMgVR44cUYkSJS77zf/EiROVnp6uhx9+WI8//ri33ePxyBiT7S35jMcB3G63HA6Ht5+aNWtq2LBh+uqrrzR16lR17dpVf/vb37x3OaKiotSkSRNt27ZNR44c8QaIC4OEZVkECwC5yu1266233tKiRYv0yCOP6L333lNQUFCmc7LaO0c6d006duyYQkNDVaVKFe/ciieeeEJHjhzRF198ocqVK+v111/PdEf3xhtvlCTFx8erf//+md6TZWWR1/h/FgBbvvvuO9WoUUMNGjTQvn37sj0vY2LgqVOnJJ17/leS985Dxh+6Sy15aIzxrn7SoEED7+omNWvW1H//+18FBwfrpZde8j4ilZ6eLkneuRYrVqxQSkqK970uXC2KP7QArlRiYqI2bNiQqS3juuJ2uzVz5kxJ0kMPPaSgoCClp6dnWpHpwsUo/urUqVPas2ePwsPD1bBhQ0lSw4YNNWzYMEnS+PHj9fPPP3uvX8YYValSRVWqVFFsbKx27tzprUM6d53L+AIFyAv8FQXgs6SkJE2cOFH79+/Xxx9/7P3Dl5WMOxD16tWTdH6FkmLFikmS9y5Fdh/ujTEKDAzUqVOn5PF4FBUV5V0eNiUlReXKlVPt2rX1+++/65133lFiYqICAwMlnQsV4eHhWrdunWJjY731ZHzDd+zYMS1btkzvvvuukpKScuE3A6CoS0xMVJUqVdSlS5dMX6hkXFd+//13RUdHq0SJEt7rSmBgYKZrz6X2ySldurROnz6tM2fOZLqr2rp1a40aNUrp6el67rnnvJOw09LSJJ2/W7F48WJJyrTC1IVfoHCtQ27j8ScAlzR//nz985//1LPPPqv77rtP0rk7AIGBgZo+fbrmz5+vHj166M4775Qx5rKbyXXq1EnSubXU77//ftWoUUORkZEKCgpSQkKCjhw5ovbt26t169aqUqWKd+lEy7IUGxur4OBgVahQQT/99JNWrVqlZcuWacOGDdq5c6f3zsSsWbNUpUoVvfTSS5LOfbtXt25dbdq0SYcOHVJERIT27NmjLVu26JdfftHGjRu1a9cuxcfHq2bNmrrlllvy8DcKoDDLeFQzPDxcnTp10vz583X8+HFVr15dZ8+e1c8//6yyZcuqQoUKqlixorZu3arPP/9cnTt3VnJyspKSkhQWFqaQkBAlJCQoIiIiy3727NmjyMhItWnTxvsFya5du/S///1P27dvV2hoqFatWqWJEyfqjTfe8E6+vuWWW/Thhx9qwYIFevLJJ73tSUlJ2rt3r3799Vdt2rRJCQkJ+uCDD7hLi9xjACALLpfLGGPM2LFjjWVZpl+/fpnaDx06ZOrUqWMCAwPNhg0brui9+/XrZ0qWLGksyzKWZZnAwEDvv2f8U61aNfPJJ58YY4xxu93GGGN27dplKlSoYEJCQkyxYsW85wYHB5vrr7/evP322+aTTz4xgYGBpnjx4mb37t3ePgcNGmQsyzJdu3Y13bp1M9HR0d7XV69e3QwePNjMnTvXpKen2/7dASh6Mq5DF5owYYKxLMt06NDBtGrVyntNGTlypDHGmEmTJhnLsozD4TB169Y13bp1M3fffbfp0aOHqVWrlmnRooV54YUXzJo1a7zvmXENmjZtmvea9cILL5hu3bqZMmXKePsICAgwISEhJioqykyZMsX7+vj4eO91cffu3ebbb781w4cPN7fccoupVKmS9/V169Y1+/fvz+PfGq4mljGXeKAPwFUrY+Lyjh071LBhQ1WrVk1btmxRWFiYJGno0KF655139MQTT+jdd9+9ovdMT0/X/Pnz9X//93+yLEsnT55USkqKypcvL7fbrUWLFunPP/9UmTJlNG/ePO+ciOPHj6tSpUpyuVxq0qSJevbsqZ49e6pNmzaZ+nnggQf02Wef6cEHH9Q///lP1axZU+PHj9eTTz4p6dxjBZ06ddKtt96qm266SdHR0bn4mwPgz4wxWrFihZYvX64TJ06oXr16atCggZo2baoSJUpkOjerBRz27dunn3/+WampqXrooYe8d1Pr1KmjFi1aqEmTJurevbsaNmwoy7I0ePBgzZkzR3/++acCAgIybTwXFBSktLQ0VahQQcOGDdPAgQO9d4LnzJmj3r17Z+r7mmuu0Y033qhbb71V7du319SpUzVw4EBFR0dr69atioqKkiRde+21+uWXX1S5cmUdPXpUbrdbxYsXV/v27XXrrbfq5ptvVrVq1fLk94urWMFmGgCFQf369Y1lWWb9+vXGGGNWrFhhypYta8qWLWsOHDhg671TU1NNQkKC9+eUlBRz+PBh06BBA2NZlnn++edNcnKyMcaYn3/+2ZQpU8Z06dLFpKWlZXofl8vlPe+XX34xnTp1MpZlmf79+xtjjPntt9/MlClTMt29yODxeEx6err3LgyAoic+Pt6MGTPGVK9e3ViWZZxOp3E4HN5v7m+//XazcOFCY8y5a0KG06dPG2POXUN69eplAgICjGVZ5vXXXzf33HOPiYyMNCVLljTff/99tn1v2rTJ/N///Z/58MMPzdixY82nn35qfvjhB/Ovf/3LXHfddcayLHPNNdeYEydOGGPO3RUZP368sSzLtGvXzkyfPt2cPHkyy/e+/fbbjWVZ5umnnzb79u0zxhgzYMAAY1mWad++vXnllVfMxo0bc+NXCFwSoQK4ynk8HuNyubK8tZ/xIfuRRx4xlmWZt99+2xhjTJ8+fYxlWWb8+PHe9/DFX/u8sI5x48aZgIAAc8cdd5jDhw8bY4z58ssvjWVZ5u677zbGnAsgWdVtjDGrV682zz77rNm0aVOWxwkRwNXj7Nmz5tlnnzVBQUGmfPnyZvjw4ebbb781v/zyi1mwYIHp2rWrsSzLlChRwvzwww/ea9qLL75oLMsyU6ZMMXfccYeJiooyTz75pHnttdfM7t27jcfjMQ8//LCxLMvMmjXLGGNMWlpattelrMTFxZmoqChjWZaZP3++t+/HHnvMWJZlpk6d6j33wi9AMh6T+vHHH02VKlWMZVlm8uTJxhhjTp06ddEXL0BeY6I2cBX66x4NWe0NYS54MvL666/Xhx9+qNWrV6tKlSqaOXOmWrZsqcGDB9va3+Gvr8tYySkkJESVKlWSx+PR6dOnVbFiRUlSyZIlJZ1bdUU69+hAdhPD27Rpc9FjUeaCJWSdTi5/wNXi888/17hx43TDDTdo2rRpKlOmjPdY06ZNdfPNN+vRRx/VBx98oMGDB+vjjz9WmzZtvOeNGTNGJUqU0DfffHPRdaVjx476+OOPtWzZMt15551yOp1ZXpfM/19wwvz/5awzlnctWbKkunTpopkzZ+rAgQPe12Zco06fPi3p3CpOTqfzomtXmzZttHDhQpUtW1alSpWSpIse4wLyA39VgUIuY6fpK3Hhh/nDhw/r66+/1ooVKxQWFqaePXuqU6dO3mdzJalt27YKDQ3V/PnztXXrVknSP/7xj4veKzfGEBISIklatGiRpHP7UWTYuHGjJKlcuXLeP7CXkrEe+4UBCsDVwxij06dPa8SIESpWrJj++c9/qkyZMnK73ZmuBw6HQy+99JJSUlL02Wef6dNPP1WbNm3Uvn17VapUSbt379bdd9+tNm3aZNrjxuFwqG3btrIsSxs3bvR+KZJVHX9dRvbCL24yNsXLWPL6zJkzSk1NVVBQkDcoZHe9CwwM9C7VDRSogrpFAsB369atM8OHDzeNGzc2nTp18j5Hm+FSjyMlJSWZadOmmZUrV5o//vjDNG7c2ISEhJjQ0FDvs8U33nij+eOPPzK9LuO534yVmqpXr26mT5/uncdwJbf7M8TGxmZ63fHjx813331nevfubZxOp6ldu7bZtm2b9/gnn3xi/v3vf5sjR45ccV8Ark4fffSRsSzL3HvvvZc9d/369cayLFO+fHlz5MgRk5KSYtq2bWscDoeZMGFClq9xu92mefPmJjw83LsS3pVcD+fNm2ecTqcJCwsze/fuNcace4QqY4U65kOgsOBOBVAI7N+/X4sXL9bcuXP1448/Kjk5WU6nU1WqVNH111+faQfXCzdWysr8+fP197//XXfeeacOHDig1NRUTZgwQU2aNJHH49GQIUO0ePFiPffccxozZoz30aOOHTtq/fr16tChg6pWraopU6bo3nvv1S233KJ//OMfatu2raSsV0vJym+//aY+ffqoRo0acjqdSkxMVFxcnLZu3aqzZ8+qW7duevPNN1W/fn3vax588EE7v0YAV6FTp05Jknc/iEtdo1q0aKE6depo165d+umnn9SnTx+1aNFCa9asybRq04UcDoe6dOmiX375RevWrdO1114rj8fj3cFaOrcR3u+//642bdrI4/Foz5492rlzp+bPn68vvvhClSpV0iuvvKKaNWvK4/EoMDBQ8+fPV4MGDRQaGpoHvxUgDxR0qgFwsbi4OPPVV1+Ze+65x5QtWzbT/g3du3c3o0aNMt98843Zs2dPlvsqbNu2zSxfvtycPXv2omM7d+40lSpVMhUqVDAVKlQwO3bsyHR87dq13pWT/vvf/3rbFy5c6L2LkZqaar744gtTo0YN7+TGp59+2nvXIicTtxMSEkxMTIwpXbq0KVOmjClXrpypV6+eeeCBB8x3332XZe3GnJvM7evEcABXn6FDhxqHw2FGjx59yTsIGQs3ZOxp8/zzzxtjjJk+fbqxLMvcd9992b52wYIFlzxn3Lhx3mtdyZIlM13X27dvb6ZOnZrpusY1DoURoQLwI+np6ea1117z/rEpVaqUuf76682DDz7oXbVk3bp1Wb52/fr1pn///qZEiRLGsiwTFhZmateubSZOnJhpyda4uDhz5513GsuyzN/+9jdjzLlb7ReuhJSxylKnTp28badPnzalS5c2wcHB3setEhISzGOPPebt85prrjHffPON9w/i5f4wnjp1ymzfvt1s3LjRHD9+3JdfGQBc0pgxY4xlWebll1/2fvGRlYxrYEaIuPnmm40xxmzfvt2UL1/e1KhRI9svO06fPm3Cw8NNyZIlzZ9//mni4uLMypUrzZw5c8yZM2fM9u3bzdNPP23uuOMO07NnT3PfffeZd95556IvdYDCjFAB+BGPx2MWLVpkHnjgAfP++++b1atXm9jYWGOMMU2aNDGWZZnZs2cbt9ttPB6P91u3vXv3mnbt2hnLskznzp3NE088Ye6//37vM7mDBg3ynpuammrefPPNTKHir9/excfHe9dwvzCQ3Hzzzd4aLrR8+XLTo0cPbxi6//77zZYtW3z6HbDUK4DctHLlSmNZlundu7eJi4u77PmrVq0ylmWZhg0betu6d++e7fyGjOtVxtKylSpVMg0aNDDh4eGmbNmy5ptvvjHGnLu2XXg9BYoa+8u2AMiRY8eO6Y8//rjkOZZlqWvXrpo8ebIGDhyoNm3aqHTp0pLkXcZwzZo1Sk9P9z6vm56erldeeUWrV6/W8OHD9d133+m9997TlClTNGPGDIWHh2v69OmaPHmypHOrjDRt2lSWZenUqVNKS0vL9HyxMUYRERG67rrrZIzR5s2bvce6dOkiSVq2bJn3XI/Ho06dOmnWrFn69NNPVb58eX322Wdq3ry5nnvuuRz9bswFq6A4nc4rXs0KALLTuHFjWZalDRs2aP/+/Zc9f//+/QoKClK9evUUHx8vSWrVqpUkaeXKlRednzFv4sUXX9To0aNVokQJORwO9erVSx9++KFuvvlmSeeubeHh4bk0KsD/ECqAfPDOO++oYsWK+uyzz7zLnErnJlb/dfJfxrKBHo9HHo9H6enpks7tFSFJa9eu9a5bblmWDh48qOnTp6t27dp69tlnFRIS4v2w36VLF40ePVrJycmaMWOGd8JizZo1VbNmTf3+++/au3evt7+M90xOTlbFihUVFBSkEydOeGvr3LmzJOmnn35SWlqaLMvyBpLQ0FDdd999+vXXX/Xcc89p6tSpevnll3P0+2GpVwB5JSIiQu3bt9eBAwf0/fffKzU1NcvzMq6BW7ZsUVpampo2barIyEhJ577UcTgc+vHHHy96XcY1sEaNGnrppZf0008/aevWrfr0008VExOjwMDAPBoZ4F8IFUAeyvgGvkKFCoqIiNDu3bu933xJ5zZ7y+5beYfDIYfD4Q0Z7dq1U7FixbRlyxYdPHjQe97+/fsVHBysypUre9dHv/DD/k033aR69eppw4YN2rJliySpdOnSatWqlX777TctXbpU0rmNlVwul6Rzmy1t3LhRISEhat68ubevZs2aqUqVKtqyZYt27tyZZd2lSpXSG2+8ob59+3r/IANAQXrqqacUERGhiRMneq+Dxhi5XC55PB4ZY+RwOPT777/r66+/VqlSpTJtctesWTNFR0dr7ty53r0kssN1D1crQgWQD+rXr69q1app/fr1OnbsmKRzmxvNmzdPTz/9tJ5//nmtXbs2y9dmfItfvnx5NWvWTImJidq6das3ABw7dkzGGFWsWFFnzpy56PXly5dXixYtFB8f7w0CoaGhateunSTpP//5j/bt26egoCBvgFm3bp327dunpk2bqmzZspLO3VVxOp1q3bq1qlWrlu3yitK5P9aXOg4A+al79+7q06ePDh48qBEjRmjLli2yLEtOp1MOh0OWZen48eMaPXq09u7dq759+3of95TObbjZt29fPfHEE9x5ALLBPhVALsvYqTXjD5UkVa5cWY0aNdLXX3+tw4cPKzo6Wn369NHy5cu9rxs7dqwmTZqkfv36KTg4+KL3DAgIUKdOnbRq1SqtXbtWd911lyIiIlS+fHkFBgZq9+7dOnPmjEqUKJHptYGBgSpdurQcDof3tn9gYKCaNGmi4sWLa+/evYqJidHAgQMVEhKirVu3atKkSSpTpoxefvllhYaGer/Fk6Tp06dfdh8Ky7KYFwHAb4SFhWnYsGHatm2bFi5cqO3bt+vhhx9W69at9ccff2jbtm2aPXu29u7dq0cffVQjR4686D3GjRtXAJUDhQehAshGTjdxyzg3Y+J0Vh+m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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def normalize_columns(matrix, eps=1e-8):\n",
    "    \"\"\"Normalize columns of the matrix to unit L2 norm.\"\"\"\n",
    "    norms = torch.norm(matrix, p=2, dim=0, keepdim=True)\n",
    "    return matrix / (norms + eps)\n",
    "\n",
    "def plot_feature_proportion_bars(W1, W2, threshold=0.2):\n",
    "    \"\"\"Bar chart showing proportion of features with max cosine similarity ≥ threshold.\"\"\"\n",
    "    # Normalize columns and calculate similarities\n",
    "    W1_norm = normalize_columns(W1)\n",
    "    W2_norm = normalize_columns(W2)\n",
    "    \n",
    "    # Calculate max similarities\n",
    "    sim_W1_to_W2 = torch.mm(W1_norm.T, W2_norm)\n",
    "    max_sim_W1 = torch.max(sim_W1_to_W2, dim=1)[0]\n",
    "    sim_W2_to_W1 = torch.mm(W2_norm.T, W1_norm)\n",
    "    max_sim_W2 = torch.max(sim_W2_to_W1, dim=1)[0]\n",
    "\n",
    "    # Calculate proportions\n",
    "    metrics = {\n",
    "        'Proportion of unique features (%)': [\n",
    "            (max_sim_W1 <= threshold).float().mean().item()*100,\n",
    "            (max_sim_W2 <= threshold).float().mean().item()*100\n",
    "        ]\n",
    "    }\n",
    "\n",
    "    # Style configuration\n",
    "    architectures = ['BatchTopK SAE', 'OrtSAE']\n",
    "    colors = ['green', 'red']  # Red and green\n",
    "    y_limits = {'Proportion of unique features (%)': (0, 10)}\n",
    "    annot_params = {\n",
    "        'Proportion of unique features (%)': {\n",
    "            'xy': (-0.07, 0.65),\n",
    "            'xytext': (-0.07, 1.0),\n",
    "        }\n",
    "    }\n",
    "\n",
    "    # Create plot\n",
    "    fig, ax = plt.subplots(1, 1, figsize=(8, 8))\n",
    "    \n",
    "    # Plot bars\n",
    "    metric = 'Proportion of unique features (%)'\n",
    "    vals = metrics[metric]\n",
    "    ax.bar(architectures, vals, color=colors, alpha=0.7)\n",
    "    \n",
    "    # Style setup\n",
    "    ax.set_ylabel(metric, fontsize=18, loc='bottom')\n",
    "    ax.tick_params(axis='x', labelrotation=15, labelsize=15)\n",
    "    ax.tick_params(axis='y', labelsize=15)\n",
    "    ax.set_ylim(y_limits[metric])\n",
    "    \n",
    "    # Add annotation arrow\n",
    "    p = annot_params[metric]\n",
    "    ax.annotate(\n",
    "        '', \n",
    "        xy=p['xy'], \n",
    "        xytext=p['xytext'],\n",
    "        arrowprops=dict(\n",
    "            arrowstyle='<-',\n",
    "            color='black',\n",
    "            shrinkA=0,\n",
    "            linewidth=3.5\n",
    "        ),\n",
    "        xycoords='axes fraction',\n",
    "        textcoords='axes fraction',\n",
    "        ha='right',\n",
    "        va='center'\n",
    "    )\n",
    "    \n",
    "    ax.grid(axis='y', linestyle='--', alpha=1)\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "plot_feature_proportion_bars(W_1, W_2)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ort",
   "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
