{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.linalg import svd\n",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "\n",
    "def svd_and_plot_singular_values(W_U):\n",
    "    # import cupy as cp\n",
    "\n",
    "    # Transfer the matrix to GPU memory\n",
    "    # large_matrix_gpu = cp.array(W_U)\n",
    "\n",
    "    # Perform SVD on GPU\n",
    "    # U, S, Vh = cp.linalg.svd(large_matrix_gpu)\n",
    "    # # Perform SVD on W_U\n",
    "    U, S, Vh = svd(W_U)\n",
    "    \n",
    "    # Plot S (singular values)\n",
    "    plt.figure(figsize=(8, 6))\n",
    "    plt.scatter(np.arange(len(S)), S)\n",
    "    plt.title('Singular Values (S) of W_U')\n",
    "    plt.xlabel('Index')\n",
    "    plt.ylabel('Singular Value')\n",
    "    plt.grid(True)\n",
    "    plt.show()\n",
    "    \n",
    "    # Find the index where singular values drop near zero (d_zero)\n",
    "    threshold = 1e-5  # Adjust threshold if needed\n",
    "    d_zero = np.where(S < threshold)[0][0] if np.any(S < threshold) else len(S)\n",
    "    \n",
    "    return S, Vh, d_zero\n",
    "\n",
    "def compute_cosine_similarity(x, Vh):\n",
    "    x_pooled = np.mean(x, axis=1)\n",
    "    # Compute cosine similarities between x and each row of Vh\n",
    "    return np.array([cosine_similarity(x_pooled.reshape(1, -1), Vh[i,:].reshape(1, -1))[0][0] for i in range(Vh.shape[0])])\n",
    "\n",
    "def plot_C_comparison(S, C_attn_base, C_mlp_base, C_attn_rotated, C_mlp_rotated, d_zero, layer_num):\n",
    "    plt.figure(figsize=(8, 6))\n",
    "    \n",
    "    # Plot Singular values (S) on both plots for reference\n",
    "    # plt.plot(np.arange(len(S)), S, label='Singular Values (S)', color='black', linestyle='--')\n",
    "    \n",
    "    # Plot C(attn_out) for the base model (blue) and rotated model (red)\n",
    "    # make it a bit transparent\n",
    "    # plt.plot(np.arange(len(C_attn_base)), C_attn_base, label=f'C(attn_out) - Base Model', color='blue', alpha=0.5)\n",
    "    # plt.plot(np.arange(len(C_attn_base)), C_attn_base, label=f'C(attn_out) - Base Model', color='blue')\n",
    "    # plt.plot(np.arange(len(C_attn_rotated)), C_attn_rotated, label=f'C(attn_out) - Rotated Model', color='red')\n",
    "    # Plot Singular values\n",
    "    # plt.scatter(np.arange(len(S)), S, label='Singular Values (S)', color='blue', alpha=0.5)\n",
    "    \n",
    "    # Plot C(attn_out)^2 for base and rotated models\n",
    "    plt.scatter(np.arange(len(C_attn_base)), C_attn_base ** 2, label=f'Base Model', color='blue')\n",
    "    plt.scatter(np.arange(len(C_attn_rotated)), C_attn_rotated ** 2, label=f'TaRot Model', color='red')\n",
    "    \n",
    "   \n",
    "    \n",
    "    # Plot C(mlp_out) for the base model (blue) and rotated model (red)\n",
    "    # plt.plot(np.arange(len(C_mlp_base)), C_mlp_base, label=f'C(mlp_out) - Base Model', color='cyan')\n",
    "    # plt.plot(np.arange(len(C_mlp_rotated)), C_mlp_rotated, label=f'C(mlp_out) - Rotated Model', color='orange')\n",
    "    \n",
    "    # Mark d_zero\n",
    "    # plt.axvline(d_zero, color='black', linestyle='--', label=f'd_zero = {d_zero}')\n",
    "    \n",
    "    plt.title(f'Layer {layer_num + 1}', fontsize=16)\n",
    "    plt.xlabel('Singular value of unembedding', fontsize=16)\n",
    "    plt.ylabel('Cosine Similarity', fontsize=16)\n",
    "    plt.xticks(fontsize=16)\n",
    "    plt.yticks(fontsize=16)\n",
    "    plt.legend(fontsize=16)\n",
    "    \n",
    "    plt.grid(True)\n",
    "    # plt.show()\n",
    "    return plt\n",
    "\n",
    "def analyze_layers_comparison(W_U, attn_outs_base, mlp_outs_base, attn_outs_rotated, mlp_outs_rotated, num_layers, prompts):\n",
    "    S, Vh, d_zero = svd_and_plot_singular_values(W_U)\n",
    "    \n",
    "    for layer in range(num_layers):\n",
    "\n",
    "        avg_C_attn_base = np.zeros(Vh.shape[0])\n",
    "        avg_C_mlp_base = np.zeros(Vh.shape[0])\n",
    "        avg_C_attn_rotated = np.zeros(Vh.shape[0])\n",
    "        avg_C_mlp_rotated = np.zeros(Vh.shape[0])\n",
    "        \n",
    "        # Compute C(x) for attn_out and mlp_out for each prompt and average them\n",
    "        for prompt_idx in range(len(prompts)):\n",
    "            C_attn_base = compute_cosine_similarity(attn_outs_base[layer][prompt_idx], Vh)\n",
    "            C_mlp_base = compute_cosine_similarity(mlp_outs_base[layer][prompt_idx], Vh)\n",
    "            C_attn_rotated = compute_cosine_similarity(attn_outs_rotated[layer][prompt_idx], Vh)\n",
    "            C_mlp_rotated = compute_cosine_similarity(mlp_outs_rotated[layer][prompt_idx], Vh)\n",
    "            \n",
    "            avg_C_attn_base += C_attn_base\n",
    "            avg_C_mlp_base += C_mlp_base\n",
    "            avg_C_attn_rotated += C_attn_rotated\n",
    "            avg_C_mlp_rotated += C_mlp_rotated\n",
    "        \n",
    "        # Average over all prompts\n",
    "        avg_C_attn_base /= len(prompts)\n",
    "        avg_C_mlp_base /= len(prompts)\n",
    "        avg_C_attn_rotated /= len(prompts)\n",
    "        avg_C_mlp_rotated /= len(prompts)\n",
    "        \n",
    "        # Plot comparison between base and rotated models\n",
    "        plot_C_comparison(S, avg_C_attn_base, avg_C_mlp_base, avg_C_attn_rotated, avg_C_mlp_rotated, d_zero, layer + 1)\n",
    "\n",
    "# Example usage:\n",
    "# W_U is the unembedding matrix with shape (d_vocab, d_model)\n",
    "# attn_outs_base, mlp_outs_base are activations for the base model\n",
    "# attn_outs_rotated, mlp_outs_rotated are activations for the rotated model\n",
    "# num_layers is the total number of layers\n",
    "# prompts is a list of input prompts\n",
    "\n",
    "# analyze_layers_comparison(W_U, attn_outs_base, mlp_outs_base, attn_outs_rotated, mlp_outs_rotated, num_layers, prompts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "# model_name = 'meta-llama/Meta-Llama-3-8B-Instruct'\n",
    "# num_layers = 32\n",
    "# fileName = 'BaysianOptimization/error/mixtral/winowhy/NN_kernel_layer_0_16_angle_-0.5235987755982988_0.5235987755982988_reasoning_prob_mix_rotary_v2_3.pkl'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Utils.utils import getInfo\n",
    "model_name = 'microsoft/Phi-3-mini-4k-instruct'\n",
    "# microsoft/Phi-3-mini-4k-instruct\n",
    "# ag_news\n",
    "# navigate\n",
    "# color\n",
    "# entailed_polarity\n",
    "task = 'ag_news'\n",
    "num_layers, fileName = getInfo(model_name, task)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "with open(fileName, 'rb') as f:\n",
    "    data = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "metadata": {},
   "outputs": [],
   "source": [
    "import transformer_lens.utils as utils\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['prompt', 'label', 'rotated', 'normal', 'rotated_cache', 'normal_cache'])"
      ]
     },
     "execution_count": 174,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[0].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "51"
      ]
     },
     "execution_count": 175,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['unembed'])"
      ]
     },
     "execution_count": 176,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[-1].keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [],
   "source": [
    "umembed = data[-1]['unembed']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {},
   "outputs": [],
   "source": [
    "W_U = umembed.state_dict()['W_U'].transpose(0, 1).cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3072, 32064])"
      ]
     },
     "execution_count": 179,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "umembed.state_dict()['W_U'].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(32064, 3072)"
      ]
     },
     "execution_count": 180,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "W_U.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = []\n",
    "attn_outs_base = [[] for _ in range(num_layers)]\n",
    "mlp_outs_base = [[] for _ in range(num_layers)]\n",
    "\n",
    "attn_outs_rotated = [[] for _ in range(num_layers)]\n",
    "mlp_outs_rotated = [[] for _ in range(num_layers)]\n",
    "\n",
    "\n",
    "for i in range(len(data) - 1):\n",
    "    prompt = data[i]['prompt']\n",
    "    rotated_cache = data[i]['rotated_cache']\n",
    "    base_cache = data[i]['normal_cache']\n",
    "    \n",
    "    rotated_token = data[i]['rotated']\n",
    "    base_token = data[i]['normal']\n",
    "    \n",
    "    label = data[i]['label']\n",
    "    prompts.append(prompt)\n",
    "    \n",
    "    for layer in range(num_layers):\n",
    "        attn_outs_base[layer].append(base_cache[utils.get_act_name(\"resid_post\", layer)].detach().cpu().numpy())\n",
    "        # mlp_outs_base[layer].append(base_cache[utils.get_act_name(\"mlp_out\", layer)].detach().cpu().numpy())\n",
    "        \n",
    "        attn_outs_rotated[layer].append(rotated_cache[utils.get_act_name(\"resid_post\", layer)].detach().cpu().numpy())\n",
    "        # mlp_outs_rotated[layer].append(rotated_cache[utils.get_act_name(\"mlp_out\", layer)].detach().cpu().numpy())\n",
    "        \n",
    "        \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArcAAAIjCAYAAAAZajMiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABTwElEQVR4nO3dd3hUZf7//9ekJ0ACAVJASgQU6QICoStdVFDWssL3E1BhVXRVXBVWqeKirAULC5aluIqKLqigoFmqYuhFKSJgFCkJCiQBQgrJ/fuDX0bGJDBDZs4kh+fjurhgzrnnzHveGeMrJ/e5j8MYYwQAAADYQIC/CwAAAAC8hXALAAAA2yDcAgAAwDYItwAAALANwi0AAABsg3ALAAAA2yDcAgAAwDYItwAAALANwi0AAABsg3ALwOvq16+voUOH+rsMp+7du6t79+7+LuOiDB06VPXr1/d3Gec1f/58RUdH6+TJkx4/d+bMmapbt65yc3O9XtfSpUvVqlUrhYWFyeFwKCMjw+uvAaD8IdwCcNt3332nP/3pT6pXr57CwsJUu3Zt9erVS6+++qq/S/O7zZs3y+Fw6Kmnnip1zJ49e+RwODRq1CgLK/OtgoICjR8/Xg8++KAqV67s3J6Xl6eXX35ZV199tSIjI1W1alU1bdpUI0aM0Pfff+8cN3ToUOXl5en111/3al1Hjx7VbbfdpvDwcE2fPl3/+c9/VKlSpWLj5s+fL4fDoYULFxbb17JlSzkcDq1YsaLYvrp166pjx45u1zN06FCX/vxR5cqVy9UPhEBFRrgF4JZvvvlGbdu21bZt2zR8+HC99tpruueeexQQEKCXX37ZZezu3bv15ptv+qlS/2jdurUaN26s9957r9Qx8+bNkyQNGTLEqrJ8btGiRdq9e7dGjBjhsn3QoEF69NFH1axZMz377LOaOHGiunbtqiVLlmjt2rXOcWFhYUpKStKLL74oY4zX6tqwYYNOnDihp59+WnfffbeGDBmi4ODgYuM6d+4sSfr6669dtmdlZWn79u0KCgrSmjVrXPb98ssv+uWXX5zPBVC+BPm7AAAVwzPPPKOoqCht2LBBVatWddl35MgRl8ehoaEWVmatM2fOqLCwUCEhIcX2DR48WGPHjtXatWvVoUOHYvvfe+89NW7cWK1bt7aiVEvMnj1bnTp1Uu3atZ3bNmzYoMWLF+uZZ57R3//+d5fxr732WrHpAbfddpumTp2qFStW6LrrrvNKXUWfyT9+Vv+oVq1aSkhIKBZuU1JSZIzRrbfeWmxf0WPCLVA+ceYWgFv27dunpk2blhgWYmJiXB7/cc7tnDlz5HA4tGbNGo0aNUo1a9ZUpUqVdPPNN+vXX391eW5hYaEmTJigWrVqKSIiQtdee6127txZ7JgTJkyQw+EoVkvRa/3000+lvpe8vDyNGzdObdq0UVRUlCpVqqQuXboU+/XzTz/9JIfDoeeff17Tpk1TgwYNFBoaqp07d5Z43MGDB0v6/QztuTZt2qTdu3c7x3zyySfq37+/atWqpdDQUDVo0EBPP/20CgoKSq1bklauXCmHw6GVK1eWWOucOXNctn///ff605/+pOjoaIWFhalt27b69NNPXcbk5+dr4sSJatSokcLCwlS9enV17txZycnJ560lJydHS5cuVc+ePV2279u3T5LUqVOnYs8JDAxU9erVXba1adNG0dHR+uSTT877ekU+/PBDtWnTRuHh4apRo4aGDBmigwcPOvd3795dSUlJkqRrrrlGDofjvL/y79y5s7Zs2aLTp087t61Zs0ZNmzZVv379tHbtWhUWFrrsczgcJb4/AP5HuAXglnr16mnTpk3avn37RR/jwQcf1LZt2zR+/Hjdd999WrRokR544AGXMWPGjNHEiRPVtm1b/fOf/1SjRo3Up08fnTp1qqxvwSkrK0tvvfWWunfvrueee04TJkzQr7/+qj59+mjr1q3Fxs+ePVuvvvqqRowYoRdeeEHR0dElHjchIUEdO3bU/Pnzi4XUosB75513SjobwitXrqxRo0bp5ZdfVps2bTRu3DiNHj3aa+9zx44d6tChg3bt2qXRo0frhRdeUKVKlTRw4ECXOaYTJkzQxIkTde211+q1117Tk08+qbp162rz5s3nPf6mTZuUl5dX7Ex0vXr1JEnvvvuuzpw541atrVu3Lvbr/5LMmTNHt912mwIDAzVlyhQNHz5cCxYsUOfOnZ1nhJ988knnNIlJkybpP//5j/7yl7+UeszOnTsrPz9f69atc25bs2aNOnbsqI4dOyozM9Plc79mzRo1bty4WEgHUE4YAHDDl19+aQIDA01gYKBJTEw0jz/+uPniiy9MXl5esbH16tUzSUlJzsezZ882kkzPnj1NYWGhc/sjjzxiAgMDTUZG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INwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsI1yHW4LCgo0duxYJSQkKDw8XA0aNNDTTz8tY4xzjDFG48aNU3x8vMLDw9WzZ0/t2bPHj1UDAADAX8p1uH3uuec0Y8YMvfbaa9q1a5eee+45TZ06Va+++qpzzNSpU/XKK69o5syZWrdunSpVqqQ+ffooJyfHj5UDAADAH4L8XcD5fPPNNxowYID69+8vSapfv77ee+89rV+/XtLZs7bTpk3TU089pQEDBkiS3n77bcXGxurjjz/WHXfc4bfaAQAAYL1yHW47duyoN954Qz/88IOuuOIKbdu2TV9//bVefPFFSVJqaqrS0tLUs2dP53OioqLUvn17paSklBpuc3NzlZub63yclZUlScrPz1d+fr4P35Gcr3Pu3/At+m0dem0t+m0t+m0t+m2ditJrd+sr1+F29OjRysrKUuPGjRUYGKiCggI988wzGjx4sCQpLS1NkhQbG+vyvNjYWOe+kkyZMkUTJ04stv3LL79URESEF9/B+SUnJ1v2WqDfVqLX1qLf1qLf1qLf1invvc7OznZrXLkOt/Pnz9e7776refPmqWnTptq6dasefvhh1apVS0lJSRd93DFjxmjUqFHOx1lZWapTp4569+6tyMhIb5R+Xvn5+UpOTlavXr0UHBzs89e71NFv69Bra9Fva9Fva9Fv61SUXhf9pv1CynW4feyx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AAAAsA3CLQAAAGyDcAsAAADbINxabPr06apfv77CwsLUvn17rV+/3t8lVUgTJkyQw+Fw+dO4cWPn/pycHI0cOVLVq1dX5cqVNWjQIKWnp7scY//+/erfv78iIiIUExOjxx57TGfOnLH6rZQ7q1ev1o033qhatWrJ4XDo448/dtlvjNG4ceMUHx+v8PBw9ezZU3v27HEZc+zYMQ0ePFiRkZGqWrWq7r77bp08edJlzLfffqsuXbooLCxMderU0dSpU3391sqlC/V76NChxT7rffv2dRlDv90zZcoUXXPNNapSpYpiYmI0cOBA7d6922WMt753rFy5Uq1bt1ZoaKgaNmyoOXPm+PrtlTvu9Lt79+7FPt/33nuvyxj67Z4ZM2aoRYsWzhsxJCYmasmSJc79l9Rn28Ay77//vgkJCTGzZs0yO3bsMMOHDzdVq1Y16enp/i6twhk/frxp2rSpOXz4sPPPr7/+6tx/7733mjp16phly5aZjRs3mg4dOpiOHTs69585c8Y0a9bM9OzZ02zZssV8/vnnpkaNGmbMmDH+eDvlyueff26efPJJs2DBAiPJLFy40GX/s88+a6KioszHH39stm3bZm666SaTkJBgTp8+7RzTt29f07JlS7N27Vrz1VdfmYYNG5o///nPzv2ZmZkmNjbWDB482Gzfvt289957Jjw83Lz++utWvc1y40L9TkpKMn379nX5rB87dsxlDP12T58+fczs2bPN9u3bzdatW831119v6tata06ePOkc443vHT/++KOJiIgwo0aNMjt37jSvvvqqCQwMNEuXLrX0/fqbO/3u1q2bGT58uMvnOzMz07mffrvv008/NZ999pn54YcfzO7du83f//53ExwcbLZv326MubQ+24RbC7Vr186MHDnS+bigoMDUqlXLTJkyxY9VVUzjx483LVu2LHFfRkaGCQ4ONh9++KFz265du4wkk5KSYow5GygCAgJMWlqac8yMGTNMZGSkyc3N9WntFckfw1ZhYaGJi4sz//znP53bMjIyTGhoqHnvvfeMMcbs3LnTSDIbNmxwjlmyZIlxOBzm4MGDxhhj/vWvf5lq1aq59PqJJ54wV155pY/fUflWWrgdMGBAqc+h3xfvyJEjRpJZtWqVMcZ73zsef/xx07RpU5fXuv32202fPn18/ZbKtT/225iz4fahhx4q9Tn0u2yqVatm3nrrrUvus820BIvk5eVp06ZN6tmzp3NbQECAevbsqZSUFD9WVnHt2bNHtWrV0uWXX67Bgwdr//79kqRNmzYpPz/fpdeNGzdW3bp1nb1OSUlR8+bNFRsb6xzTp08fZWVlaceOHda+kQokNTVVaWlpLr2NiopS+/btXXpbtWpVtW3b1jmmZ8+eCggI0Lp165xjunbtqpCQEOeYPn36aPfu3Tp+/LhF76biWLlypWJiYnTllVfqvvvu09GjR5376PfFy8zMlCRFR0dL8t73jpSUFJdjFI251L/X/7HfRd59913VqFFDzZo105gxY5Sdne3cR78vTkFBgd5//32dOnVKiYmJl9xnO8jfBVwqfvvtNxUUFLh8aCQpNjZW33//vZ+qqrjat2+vOXPm6Morr9Thw4c1ceJEdenSRdu3b1daWppCQkJUtWpVl+fExsYqLS1NkpSWllbi16JoH0pW1JuSendub2NiYlz2BwUFKTo62mVMQkJCsWMU7atWrZpP6q+I+vbtq1tuuUUJCQnat2+f/v73v6tfv35KSUlRYGAg/b5IhYWFevjhh9WpUyc1a9ZMkrz2vaO0MVlZWTp9+rTCw8N98ZbKtZL6LUl33nmn6tWrp1q1aunbb7/VE088od27d2vBggWS6LenvvvuOyUmJionJ0eVK1fWwoUL1aRJE23duvWS+mwTblEh9evXz/nvFi1aqH379qpXr57mz59fbv7jArzhjjvucP67efPmatGihRo0aKCVK1eqR48efqysYhs5cqS2b9+ur7/+2t+lXBJK6/eIESOc/27evLni4+PVo0cP7du3Tw0aNLC6zArvyiuv1NatW5WZmamPPvpISUlJWrVqlb/LshzTEixSo0YNBQYGFrsyMT09XXFxcX6qyj6qVq2qK664Qnv37lVcXJzy8vKUkZHhMubcXsfFxZX4tSjah5IV9eZ8n+O4uDgdOXLEZf+ZM2d07Ngx+u8Fl19+uWrUqKG9e/dKot8X44EHHtDixYu1YsUKXXbZZc7t3vreUdqYyMjIS/KH79L6XZL27dtLksvnm367LyQkRA0bNlSbNm00ZcoUtWzZUi+//PIl99km3FokJCREbdq00bJly5zbCgsLtWzZMiUmJvqxMns4efKk9u3bp/j4eLVp00bBwcEuvd69e7f279/v7HViYqK+++47l1CQnJysyMhINWnSxPL6K4qEhATFxcW59DYrK0vr1q1z6W1GRoY2bdrkHLN8+XIVFhY6/8eVmJio1atXKz8/3zkmOTlZV1555SX5K3JPHDhwQEePHlV8fLwk+u0JY4weeOABLVy4UMuXLy82VcNb3zsSExNdjlE05lL7Xn+hfpdk69atkuTy+abfF6+wsFC5ubmX3mfb31e0XUref/99ExoaaubMmWN27txpRowYYapWrepyZSLc8+ijj5qVK1ea1NRUs2bNGtOzZ09To0YNc+TIEWPM2SVP6tata5YvX242btxoEhMTTWJiovP5RUue9O7d22zdutUsXbrU1KxZk6XAjDEnTpwwW7ZsMVu2bDGSzIsvvmi2bNlifv75Z2PM2aXAqlataj755BPz7bffmgEDBpS4FNjVV19t1q1bZ77++mvTqFEjl6WpMjIyTGxsrPl//+//me3bt5v333/fREREXHJLUxlz/n6fOHHC/O1vfzMpKSkmNTXV/O9//zOtW7c2jRo1Mjk5Oc5j0G/33HfffSYqKsqsXLnSZemp7Oxs5xhvfO8oWi7pscceM7t27TLTp08vl8sl+dqF+r13714zadIks3HjRpOammo++eQTc/nll5uuXbs6j0G/3Td69GizatUqk5qaar799lszevRo43A4zJdffmmMubQ+24Rbi7366qumbt26JiQkxLRr186sXbvW3yVVSLfffruJj483ISEhpnbt2ub22283e/fude4/ffq0uf/++021atVMRESEufnmm83hw4ddjvHTTz+Zfv36mfDwcFOjRg3z6KOPmvz8fKvfSrmzYsUKI6nYn6SkJGPM2eXAxo4da2JjY01oaKjp0aOH2b17t8sxjh49av785z+bypUrm8jISDNs2DBz4sQJlzHbtm0znTt3NqGhoaZ27drm2Wefteotlivn63d2drbp3bu3qVmzpgkODjb16tUzw4cPL/YDMf12T0l9lmRmz57tHOOt7x0rVqwwrVq1MiEhIebyyy93eY1LxYX6vX//ftO1a1cTHR1tQkNDTcOGDc1jjz3mss6tMfTbXXfddZepV6+eCQkJMTVr1jQ9evRwBltjLq3PtsMYY6w7TwwAAAD4DnNuAQAAYBuEWwAAANgG4RYAAAC2QbgFAACAbRBuAQAAYBuEWwAAANgG4RYAAAC2QbgFAACAbRBuAcCGHA6HPv74Y3+XAQCWI9wCQDkzdOhQDRw40N9lAECFRLgFAACAbRBuAaAc6969u/7617/q8ccfV3R0tOLi4jRhwgSXMXv27FHXrl0VFhamJk2aKDk5udhxfvnlF912222qWrWqoqOjNWDAAP3000+SpO+//14RERGaN2+ec/z8+fMVHh6unTt3+vLtAYDXEW4BoJybO3euKlWqpHXr1mnq1KmaNGmSM8AWFhbqlltuUUhIiNatW6eZM2fqiSeecHl+fn6++vTpoypVquirr77SmjVrVLlyZfXt21d5eXlq3Lixnn/+ed1///3av3+/Dhw4oHvvvVfPPfecmjRp4o+3DAAXzWGMMf4uAgDwu6FDhyojI0Mff/yxunfvroKCAn311VfO/e3atdN1112nZ599Vl9++aX69++vn3/+WbVq1ZIkLV26VP369dPChQs1cOBAvfPOO5o8ebJ27dolh8MhScrLy1PVqlX18ccfq3fv3pKkG264QVlZWQoJCVFgYKCWLl3qHA8AFUWQvwsAAJxfixYtXB7Hx8fryJEjkqRdu3apTp06zmArSYmJiS7jt23bpr1796pKlSou23NycrRv3z7n41mzZumKK65QQECAduzYQbAFUCERbgGgnAsODnZ57HA4VFhY6PbzT548qTZt2ujdd98ttq9mzZrOf2/btk2nTp1SQECADh8+rPj4+IsvGgD8hHALABXYVVddpV9++cUljK5du9ZlTOvWrfXBBx8oJiZGkZGRJR7n2LFjGjp0qJ588kkdPnxYgwcP1ubNmxUeHu7z9wAA3sQFZQBQgfXs2VNXXHGFkpKStG3bNn311Vd68sknXcYMHjxYNWrU0IABA/TVV18pNTVVK1eu1F//+lcdOHBAknTvvfeqTp06euqpp/Tiiy+qoKBAf/vb3/zxlgCgTAi3AFCBBQQEaOHChTp9+rTatWune+65R88884zLmIiICK1evVp169bVLbfcoquuukp33323cnJyFBkZqbfffluff/65/vOf/ygoKEiVKlXSO++8ozfffFNLlizx0zsDgIvDagkAAACwDc7cAgAAwDYItwAAALANwi0AAABsg3ALAAAA2yDcAgAAwDYItwAAALANwi0AAABsg3ALAAAA2yDcAgAAwDYItwAAALANwi0AAABs4/8Dc5bBTYMVyZkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "S, Vh, d_zero = svd_and_plot_singular_values(W_U)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "metadata": {},
   "outputs": [],
   "source": [
    "# !pip3 install cupy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([3.6778426, 3.6332319, 3.56693  , 3.4989133, 3.4424171, 3.198896 ,\n",
       "       2.8210886, 2.498077 , 2.2863533, 0.8385093], dtype=float32)"
      ]
     },
     "execution_count": 183,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "S[-10:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Vh.shape, attn_outs_base[layer][prompt_idx].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = prompts[:5]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [00:14<00:00,  2.84s/it]\n",
      "100%|██████████| 5/5 [00:14<00:00,  2.84s/it]\n",
      "100%|██████████| 5/5 [00:14<00:00,  2.82s/it]\n",
      "100%|██████████| 5/5 [00:14<00:00,  2.86s/it]\n",
      "100%|██████████| 4/4 [00:57<00:00, 14.42s/it]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "for layer in tqdm(range(num_layers - 4, num_layers)):\n",
    "        # Initialize arrays to store averaged C(x) across prompts for both base and rotated models\n",
    "        avg_C_attn_base = np.zeros(Vh.shape[0])\n",
    "        avg_C_mlp_base = np.zeros(Vh.shape[0])\n",
    "        avg_C_attn_rotated = np.zeros(Vh.shape[0])\n",
    "        avg_C_mlp_rotated = np.zeros(Vh.shape[0])\n",
    "        \n",
    "        # Compute C(x) for attn_out and mlp_out for each prompt and average them\n",
    "        \n",
    "        for prompt_idx in tqdm(range(len(prompts))):\n",
    "            C_attn_base = compute_cosine_similarity(attn_outs_base[layer][prompt_idx], Vh)\n",
    "            # C_mlp_base = compute_cosine_similarity(mlp_outs_base[layer][prompt_idx], Vh)\n",
    "            C_attn_rotated = compute_cosine_similarity(attn_outs_rotated[layer][prompt_idx], Vh)\n",
    "            # C_mlp_rotated = compute_cosine_similarity(mlp_outs_rotated[layer][prompt_idx], Vh)\n",
    "            \n",
    "            avg_C_attn_base += C_attn_base\n",
    "            # avg_C_mlp_base += C_mlp_base\n",
    "            avg_C_attn_rotated += C_attn_rotated\n",
    "            # avg_C_mlp_rotated += C_mlp_rotated\n",
    "        \n",
    "        # Average over all prompts\n",
    "        avg_C_attn_base /= len(prompts)\n",
    "        avg_C_mlp_base /= len(prompts)\n",
    "        avg_C_attn_rotated /= len(prompts)\n",
    "        avg_C_mlp_rotated /= len(prompts)\n",
    "        \n",
    "        # Plot comparison between base and rotated models\n",
    "        plt = plot_C_comparison(S, avg_C_attn_base, avg_C_mlp_base, avg_C_attn_rotated, avg_C_mlp_rotated, d_zero, layer + 1)\n",
    "        model = model_name.split('/')[1]\n",
    "        plt.savefig(f'cosine_similiarity/{model}_{task}_layer_{layer}.svg')\n",
    "        plt.clf()\n",
    "        plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1, 68, 4096)"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "attn_outs_base[layer][prompt_idx].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(4096,)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Vh[1,:].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAq8AAAIjCAYAAAAtE/I+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABLtklEQVR4nO3deXhU5f3+8XuSTCYJkJAAgQQJIKjILqsgq2wiiuBagTaAoiiuWBVqQUAUpa3FhYqtFXABRQUUZEvZQUD23QgaAVlFSAIEkiF5fn/4y3wZss3ATGYOvl/XlQvnOc855zPJp/Tm5JlzbMYYIwAAAMACQgJdAAAAAOApwisAAAAsg/AKAAAAyyC8AgAAwDIIrwAAALAMwisAAAAsg/AKAAAAyyC8AgAAwDIIrwAAALAMwisAr9SoUUP9+/cPdBkuHTp0UIcOHQJdxiXp37+/atSoEegyijVjxgzFxcXp9OnTXu87adIkJSUlKTs72+d1LViwQI0bN1ZERIRsNpvS09N9fg4AwYnwCkCStH37dt19992qXr26IiIiVLVqVXXp0kVvvfVWoEsLuE2bNslms+mvf/1rkXP27Nkjm82moUOHlmJl/pWbm6sXX3xRjz/+uMqWLesaz8nJ0RtvvKEbbrhB0dHRKl++vOrVq6eHHnpI3333nWte//79lZOTo3fffdendf3666+69957FRkZqYkTJ+rDDz9UmTJlCsybMWOGbDabZs2aVWBbo0aNZLPZtHTp0gLbkpKS1Lp1a4/r6d+/v9v352Jly5YNqn/wAVZHeAWgb775Rs2aNdPWrVs1aNAgvf3223rwwQcVEhKiN954w21uamqq/vOf/wSo0sBo0qSJ6tSpo+nTpxc5Z9q0aZKkfv36lVZZfjdnzhylpqbqoYcechu/66679Mwzz6h+/fp69dVXNXr0aLVr107z58/X2rVrXfMiIiKUnJys119/XcYYn9W1fv16nTp1Si+99JIeeOAB9evXT3a7vcC8Nm3aSJJWrVrlNp6ZmakdO3YoLCxMq1evdtt24MABHThwwLUvgOATFugCAATeyy+/rJiYGK1fv17ly5d323bs2DG31w6HoxQrK13nz59XXl6ewsPDC2zr27evRowYobVr1+rGG28ssH369OmqU6eOmjRpUhqllorJkyfrpptuUtWqVV1j69ev19y5c/Xyyy/rL3/5i9v8t99+u8Cv7++9916NHz9eS5cu1c033+yTuvJ78uJevVhiYqJq1qxZILyuWbNGxhjdc889Bbblvya8AsGLK68A9MMPP6hevXqFhoH4+Hi31xeveZ0yZYpsNptWr16toUOHqlKlSipTpox69+6tX375xW3fvLw8jRo1SomJiYqKilLHjh21a9euAsccNWqUbDZbgVryz/XTTz8V+V5ycnI0cuRINW3aVDExMSpTpozatm1b4NfDP/30k2w2m/7+979rwoQJqlWrlhwOh3bt2lXocfv27Svp/66wXmjjxo1KTU11zfnyyy/Vo0cPJSYmyuFwqFatWnrppZeUm5tbZN2StGzZMtlsNi1btqzQWqdMmeI2/t133+nuu+9WXFycIiIi1KxZM3311Vduc5xOp0aPHq1rrrlGERERqlChgtq0aaOUlJRiazl37pwWLFigzp07u43/8MMPkqSbbrqpwD6hoaGqUKGC21jTpk0VFxenL7/8stjz5fvss8/UtGlTRUZGqmLFiurXr58OHjzo2t6hQwclJydLkpo3by6bzVbsr+TbtGmjzZs36+zZs66x1atXq169eurevbvWrl2rvLw8t202m63Q9wcgOBBeAah69erauHGjduzYccnHePzxx7V161a9+OKLeuSRRzRnzhw99thjbnOGDx+u0aNHq1mzZvrb3/6ma665Rt26ddOZM2cu9y24ZGZm6r333lOHDh302muvadSoUfrll1/UrVs3bdmypcD8yZMn66233tJDDz2kf/zjH4qLiyv0uDVr1lTr1q01Y8aMAiE0P9D26dNH0m8hu2zZsho6dKjeeOMNNW3aVCNHjtSwYcN89j537typG2+8Ubt379awYcP0j3/8Q2XKlFGvXr3c1niOGjVKo0ePVseOHfX222/rhRdeUFJSkjZt2lTs8Tdu3KicnJwCV5KrV68uSfr44491/vx5j2pt0qRJgV/PF2bKlCm69957FRoaqnHjxmnQoEGaOXOm2rRp47qi+8ILL7iWMYwZM0YffvihHn744SKP2aZNGzmdTq1bt841tnr1arVu3VqtW7dWRkaGW9+vXr1aderUKRDCAQQRA+B3b9GiRSY0NNSEhoaaVq1ameeee84sXLjQ5OTkFJhbvXp1k5yc7Ho9efJkI8l07tzZ5OXlucaffvppExoaatLT040xxhw5csSEhYWZXr16uR1v1KhRRpLbMV988UVT2F9P+edKS0tzjbVv3960b9/e9fr8+fMmOzvbbb+TJ0+aypUrm4EDB7rG0tLSjCQTHR1tjh07Vuz3J9/EiRONJLNw4ULXWG5urqlatapp1aqVaywrK6vAvg8//LCJiooy586dc40lJyeb6tWru14vXbrUSDJLly512ze/1smTJ7vGOnXqZBo0aOB2vLy8PNO6dWtzzTXXuMYaNWpkevTo4dH7u9B7771nJJnt27e7jefl5Zn27dsbSaZy5crm/vvvNxMnTjT79u0r8lgPPfSQiYyMLPZ8OTk5Jj4+3tSvX9+cPXvWNT537lwjyYwcOdI1lt8H69evL/F97Ny500gyL730kjHGGKfTacqUKWOmTp1qjDGmcuXKZuLEicYYYzIzM01oaKgZNGhQice9UHJysilTpkyR28uUKePW3wAuD1deAahLly5as2aNevbsqa1bt2r8+PHq1q2bqlatWuDX0EV56KGH3H7V37ZtW+Xm5mrfvn2SpMWLF+v8+fN69NFH3fZ7/PHHffdG9NuvrvPXrObl5enEiRM6f/68mjVrVujVxrvuukuVKlXy6Nj33Xef7Ha729KB5cuX6+DBg64lA5IUGRnp+u9Tp07p+PHjatu2rbKystw+jX+pTpw4oSVLlujee+91Hf/48eP69ddf1a1bN+3Zs8f1q/by5ctr586d2rNnj1fn+PXXXyVJsbGxbuM2m00LFy7U2LFjFRsbq+nTp2vIkCGqXr267rvvvkJvWRUbG6uzZ88qKyuryPNt2LBBx44d06OPPqqIiAjXeI8ePVSnTh19/fXXXtWf7/rrr1eFChVca1m3bt2qM2fOuO4m0Lp1a9dV4TVr1ig3N5f1rkCQI7wCkPTb+sGZM2fq5MmT+vbbbzV8+HCdOnVKd999d5HrQC+UlJTk9jo/9Jw8eVKSXCG2du3abvPi4uIKBKTLNXXqVDVs2NC1xrNSpUr6+uuvlZGRUWBuzZo1PT5uhQoV1K1bN82aNUvnzp2T9NuSgbCwMN17772ueTt37lTv3r0VExOj6OhoVapUyXUXgsJq8NbevXtljNGIESNUqVIlt68XX3xR0v99qGnMmDFKT0/XtddeqwYNGujZZ5/Vtm3bPD6XKeQuAQ6HQy+88IJ2796tQ4cOafr06brxxhs1Y8aMAktFLjxGYeuY8+X3x3XXXVdgW506dVzbvWWz2dS6dWvX2tbVq1crPj7e1YcXhtf8P/0RXot77wC8Q3gF4CY8PFzNmzfXK6+8onfeeUdOp1OfffZZifuFhoYWOl5Y+ClJUf9HX9IHniTpo48+Uv/+/VWrVi3997//1YIFC5SSkqKbb77Z7YM5+S68SuqJfv36KTMzU3PnzlVOTo6++OILde3a1XX1Nj09Xe3bt9fWrVs1ZswYzZkzRykpKXrttdckqdAa8nn6vvOP8ec//1kpKSmFfuWHs3bt2umHH37Q+++/r/r16+u9995TkyZN9N577xX7PvPXfOb/46MoCQkJ+sMf/qAVK1bommuu0YwZMwqshT158qSioqK8/l77Sps2bZSRkaHt27e71rvma926tfbt26eDBw9q1apVSkxM1NVXX+3V8SMiIpSdnV1orxtjdO7cOberyQAuD7fKAlCkZs2aSZIOHz582cfK/6DP3r173a52/vrrrwUCUv6V2PT0dLc7IHhy9e3zzz/X1VdfrZkzZ7qFwfwrkperZ8+eKleunKZNmya73a6TJ0+6LRlYtmyZfv31V82cOVPt2rVzjaelpZV47Avf94Uuft/54cputxe4G0Bh4uLiNGDAAA0YMECnT59Wu3btNGrUKD344INF7lOnTh1X3Q0aNCjxHHa7XQ0bNtSePXt0/PhxValSxbUtLS1N119/fbH75/dHampqgVtqpaamurZfigvv97p69Wo99dRTrm1NmzaVw+HQsmXLtG7dOt16661eH7969eo6f/68fvjhhwK/Wdi7d69yc3Mvq34A7rjyCkBLly4t9KrRvHnzJBX+q1xvderUSWFhYXrnnXfcxt9+++0Cc2vVqiVJWrFihWvszJkzmjp1aonnyb8CfOH7WbdundasWXNJdV8sMjJSvXv31rx58/TOO++oTJkyuuOOO4o9f05Ojv71r3+VeOzq1asrNDTU7X1LKrBvfHy8OnTooHfffbfQf1hceIuy/LWr+cqWLavatWuX+MjWpk2bKjw8XBs2bHAb37Nnj/bv319gfnp6utasWaPY2NgCa4g3bdpU4hOrmjVrpvj4eE2aNMmttvnz52v37t3q0aNHsfuXdOyIiAh9/PHHOnjwoFstDodDTZo00cSJE3XmzJlLWjLQvXt3SYX38sSJE93mALh8XHkFoMcff1xZWVnq3bu36tSpo5ycHH3zzTf69NNPVaNGDQ0YMOCyz1G5cmU9+eST+sc//qGePXvqlltu0datWzV//nxVrFjR7Spp165dlZSUpAceeEDPPvusQkND9f7776tSpUqFBqcL3XbbbZo5c6Z69+6tHj16KC0tTZMmTVLdunV1+vTpy34f0m9LBz744AMtXLhQffv2dXs0aevWrRUbG6vk5GQ98cQTstls+vDDDz1aPhETE6N77rlHb731lmw2m2rVqqW5c+cWeFCE9FsoatOmjRo0aKBBgwbp6quv1tGjR7VmzRr9/PPP2rp1qySpbt266tChg+t+qxs2bNDnn39e6NrUC0VERKhr16763//+pzFjxrjGt27dqj59+qh79+5q27at4uLidPDgQU2dOlWHDh3ShAkT3JaQbNy4USdOnHAL+IWx2+167bXXNGDAALVv317333+/jh49qjfeeEM1atTQ008/XeL3ryj5S2FWrlwph8Ohpk2bum1v3bq1/vGPf0i6tPWujRs31oMPPqg33nhDe/bsUZcuXSRJKSkpmjdvnh588EE1atTokusHcJFA3eYAQPCYP3++GThwoKlTp44pW7asCQ8PN7Vr1zaPP/64OXr0qNvcom6VdfFtiwq77dP58+fNiBEjTJUqVUxkZKS5+eabze7du02FChXM4MGD3fbfuHGjadmypQkPDzdJSUnm9ddf9+hWWXl5eeaVV14x1atXNw6Hw9xwww1m7ty5BW5LlX/7qb/97W9ef7/Onz9vEhISjCQzb968AttXr15tbrzxRhMZGWkSExNdtx67+PtxcU3GGPPLL7+Yu+66y0RFRZnY2Fjz8MMPmx07dhS4VZYxxvzwww/mT3/6k6lSpYqx2+2matWq5rbbbjOff/65a87YsWNNixYtTPny5U1kZKSpU6eOefnllwu9DdrFZs6caWw2m9m/f79r7OjRo+bVV1817du3NwkJCSYsLMzExsaam2++2e28+Z5//nmTlJTkdhu14nz66afmhhtuMA6Hw8TFxZm+ffuan3/+2W2ON7fKyjd8+HAjybRu3brQ9ynJlCtXzpw/f97jY14oNzfXvPHGG6ZRo0YmIiLCREREmEaNGpk333zT5ObmXtIxARTOZowPHzgNAF5KT09XbGysxo4dqxdeeCHQ5eACubm5qlu3ru6991699NJLXu+fnZ2tGjVqaNiwYXryySf9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kBC1adNG48aN0xNPPKHNmzf7o04AAADA+yuvubm5KleunCSpYsWKOnTokKTfPtSVmprq2+oAAACAC3h95bV+/fraunWratasqZYtW2r8+PEKDw/Xv//9b1199dX+qBEAAACQdAnh9a9//avOnDkjSRozZoxuu+02tW3bVhUqVNCnn37q8wIBAACAfB6H12bNmunBBx9Unz59FB0dLUmqXbu2vvvuO504cUKxsbGuOw4AAAAA/uDxmtdGjRrpueeeU0JCgv70pz+53VkgLi6O4AoAAAC/8zi8/ve//9WRI0c0ceJE7d+/X506dVLt2rX1yiuv6ODBg/6sEQAAAJDk5d0GoqKi1L9/fy1btkzff/+9/vCHP+jdd99VjRo11KNHD82cOdNfdQIAAADe3yorX61atTR27Fj99NNPmj59utauXat77rnHl7UBAAAAbry+28CFli1bpsmTJ+uLL75QWFiYBg0a5Ku6AAAAgAK8Dq8///yzpkyZoilTpujHH39U27Zt9a9//Uv33HOPIiMj/VEjAAAAIMmL8Dpjxgy9//77Wrx4seLj45WcnKyBAweqdu3a/qwPAAAAcPE4vPbr1089evTQrFmzdOuttyok5JKXywIAAACXxOPw+vPPPys+Pt6ftQAAAADF8vjyKcEVAAAAgcbv/gEAAGAZhFcAAABYhlfhNTc3VytWrFB6erqfygEAAACK5lV4DQ0NVdeuXXXy5El/1QMAAAAUyetlA/Xr19ePP/7oj1oAAACAYnkdXseOHas///nPmjt3rg4fPqzMzEy3LwAAAMBfvH487K233ipJ6tmzp2w2m2vcGCObzabc3FzfVQcAAABcwOvwunTpUn/UAQAAAJTI6/Davn17f9QBAAAAlOiS7/OalZWl7777Ttu2bXP78qXc3FyNGDFCNWvWVGRkpGrVqqWXXnpJxhifngcAAADW4PWV119++UUDBgzQ/PnzC93uyzWvr732mt555x1NnTpV9erV04YNGzRgwADFxMToiSee8Nl5AAAAYA1eX3l96qmnlJ6ernXr1ikyMlILFizQ1KlTdc011+irr77yaXHffPON7rjjDvXo0UM1atTQ3Xffra5du+rbb7/16XkAAABgDV5feV2yZIm+/PJLNWvWTCEhIapevbq6dOmi6OhojRs3Tj169PBZca1bt9a///1vff/997r22mu1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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "IndexError",
     "evalue": "list index out of range",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[22], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43manalyze_layers_comparison\u001b[49m\u001b[43m(\u001b[49m\u001b[43mW_U\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mattn_outs_base\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmlp_outs_base\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mattn_outs_rotated\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmlp_outs_rotated\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mnum_layers\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mprompts\u001b[49m\u001b[43m)\u001b[49m\n",
      "Cell \u001b[0;32mIn[1], line 88\u001b[0m, in \u001b[0;36manalyze_layers_comparison\u001b[0;34m(W_U, attn_outs_base, mlp_outs_base, attn_outs_rotated, mlp_outs_rotated, num_layers, prompts)\u001b[0m\n\u001b[1;32m     86\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m prompt_idx \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;28mlen\u001b[39m(prompts)):\n\u001b[1;32m     87\u001b[0m     C_attn_base \u001b[38;5;241m=\u001b[39m compute_cosine_similarity(attn_outs_base[layer][prompt_idx], Vh)\n\u001b[0;32m---> 88\u001b[0m     C_mlp_base \u001b[38;5;241m=\u001b[39m compute_cosine_similarity(\u001b[43mmlp_outs_base\u001b[49m\u001b[43m[\u001b[49m\u001b[43mlayer\u001b[49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[43mprompt_idx\u001b[49m\u001b[43m]\u001b[49m, Vh)\n\u001b[1;32m     89\u001b[0m     C_attn_rotated \u001b[38;5;241m=\u001b[39m compute_cosine_similarity(attn_outs_rotated[layer][prompt_idx], Vh)\n\u001b[1;32m     90\u001b[0m     C_mlp_rotated \u001b[38;5;241m=\u001b[39m compute_cosine_similarity(mlp_outs_rotated[layer][prompt_idx], Vh)\n",
      "\u001b[0;31mIndexError\u001b[0m: list index out of range"
     ]
    }
   ],
   "source": [
    "analyze_layers_comparison(W_U, attn_outs_base, mlp_outs_base, attn_outs_rotated, mlp_outs_rotated, num_layers, prompts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArcAAAIjCAYAAAAZajMiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABTwElEQVR4nO3dd3hUZf7//9ekJ0ACAVJASgQU6QICoStdVFDWssL3E1BhVXRVXBVWqeKirAULC5aluIqKLqigoFmqYuhFKSJgFCkJCiQBQgrJ/fuDX0bGJDBDZs4kh+fjurhgzrnnzHveGeMrJ/e5j8MYYwQAAADYQIC/CwAAAAC8hXALAAAA2yDcAgAAwDYItwAAALANwi0AAABsg3ALAAAA2yDcAgAAwDYItwAAALANwi0AAABsg3ALwOvq16+voUOH+rsMp+7du6t79+7+LuOiDB06VPXr1/d3Gec1f/58RUdH6+TJkx4/d+bMmapbt65yc3O9XtfSpUvVqlUrhYWFyeFwKCMjw+uvAaD8IdwCcNt3332nP/3pT6pXr57CwsJUu3Zt9erVS6+++qq/S/O7zZs3y+Fw6Kmnnip1zJ49e+RwODRq1CgLK/OtgoICjR8/Xg8++KAqV67s3J6Xl6eXX35ZV199tSIjI1W1alU1bdpUI0aM0Pfff+8cN3ToUOXl5en111/3al1Hjx7VbbfdpvDwcE2fPl3/+c9/VKlSpWLj5s+fL4fDoYULFxbb17JlSzkcDq1YsaLYvrp166pjx45u1zN06FCX/vxR5cqVy9UPhEBFRrgF4JZvvvlGbdu21bZt2zR8+HC99tpruueeexQQEKCXX37ZZezu3bv15ptv+qlS/2jdurUaN26s9957r9Qx8+bNkyQNGTLEqrJ8btGiRdq9e7dGjBjhsn3QoEF69NFH1axZMz377LOaOHGiunbtqiVLlmjt2rXOcWFhYUpKStKLL74oY4zX6tqwYYNOnDihp59+WnfffbeGDBmi4ODgYuM6d+4sSfr6669dtmdlZWn79u0KCgrSmjVrXPb98ssv+uWXX5zPBVC+BPm7AAAVwzPPPKOoqCht2LBBVatWddl35MgRl8ehoaEWVmatM2fOqLCwUCEhIcX2DR48WGPHjtXatWvVoUOHYvvfe+89NW7cWK1bt7aiVEvMnj1bnTp1Uu3atZ3bNmzYoMWLF+uZZ57R3//+d5fxr732WrHpAbfddpumTp2qFStW6LrrrvNKXUWfyT9+Vv+oVq1aSkhIKBZuU1JSZIzRrbfeWmxf0WPCLVA+ceYWgFv27dunpk2blhgWYmJiXB7/cc7tnDlz5HA4tGbNGo0aNUo1a9ZUpUqVdPPNN+vXX391eW5hYaEmTJigWrVqKSIiQtdee6127txZ7JgTJkyQw+EoVkvRa/3000+lvpe8vDyNGzdObdq0UVRUlCpVqqQuXboU+/XzTz/9JIfDoeeff17Tpk1TgwYNFBoaqp07d5Z43MGDB0v6/QztuTZt2qTdu3c7x3zyySfq37+/atWqpdDQUDVo0EBPP/20CgoKSq1bklauXCmHw6GVK1eWWOucOXNctn///ff605/+pOjoaIWFhalt27b69NNPXcbk5+dr4sSJatSokcLCwlS9enV17txZycnJ560lJydHS5cuVc+ePV2279u3T5LUqVOnYs8JDAxU9erVXba1adNG0dHR+uSTT877ekU+/PBDtWnTRuHh4apRo4aGDBmigwcPOvd3795dSUlJkqRrrrlGDofjvL/y79y5s7Zs2aLTp087t61Zs0ZNmzZVv379tHbtWhUWFrrsczgcJb4/AP5HuAXglnr16mnTpk3avn37RR/jwQcf1LZt2zR+/Hjdd999WrRokR544AGXMWPGjNHEiRPVtm1b/fOf/1SjRo3Up08fnTp1qqxvwSkrK0tvvfWWunfvrueee04TJkzQr7/+qj59+mjr1q3Fxs+ePVuvvvqqRowYoRdeeEHR0dElHjchIUEdO3bU/Pnzi4XUosB75513SjobwitXrqxRo0bp5ZdfVps2bTRu3DiNHj3aa+9zx44d6tChg3bt2qXRo0frhRdeUKVKlTRw4ECXOaYTJkzQxIkTde211+q1117Tk08+qbp162rz5s3nPf6mTZuUl5dX7Ex0vXr1JEnvvvuuzpw541atrVu3Lvbr/5LMmTNHt912mwIDAzVlyhQNHz5cCxYsUOfOnZ1nhJ988knnNIlJkybpP//5j/7yl7+UeszOnTsrPz9f69atc25bs2aNOnbsqI4dOyozM9Plc79mzRo1bty4WEgHUE4YAHDDl19+aQIDA01gYKBJTEw0jz/+uPniiy9MXl5esbH16tUzSUlJzsezZ882kkzPnj1NYWGhc/sjjzxiAgMDTUZG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INwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsA3CLQAAAGyDcAsAAADbINwCAADANgi3AAAAsI1yHW4LCgo0duxYJSQkKDw8XA0aNNDTTz8tY4xzjDFG48aNU3x8vMLDw9WzZ0/t2bPHj1UDAADAX8p1uH3uuec0Y8YMvfbaa9q1a5eee+45TZ06Va+++qpzzNSpU/XKK69o5syZWrdunSpVqqQ+ffooJyfHj5UDAADAH4L8XcD5fPPNNxowYID69+8vSapfv77ee+89rV+/XtLZs7bTpk3TU089pQEDBkiS3n77bcXGxurjjz/WHXfc4bfaAQAAYL1yHW47duyoN954Qz/88IOuuOIKbdu2TV9//bVefPFFSVJqaqrS0tLUs2dP53OioqLUvn17paSklBpuc3NzlZub63yclZUlScrPz1d+fr4P35Gcr3Pu3/At+m0dem0t+m0t+m0t+m2ditJrd+sr1+F29OjRysrKUuPGjRUYGKiCggI988wzGjx4sCQpLS1NkhQbG+vyvNjYWOe+kkyZMkUTJ04stv3LL79URESEF9/B+SUnJ1v2WqDfVqLX1qLf1qLf1qLf1invvc7OznZrXLkOt/Pnz9e7776refPmqWnTptq6dasefvhh1apVS0lJSRd93DFjxmjUqFHOx1lZWapTp4569+6tyMhIb5R+Xvn5+UpOTlavXr0UHBzs89e71NFv69Bra9Fva9Fva9Fv61SUXhf9pv1CynW4feyx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AAAAsA3CLQAAAGyDcAsAAADbINxabPr06apfv77CwsLUvn17rV+/3t8lVUgTJkyQw+Fw+dO4cWPn/pycHI0cOVLVq1dX5cqVNWjQIKWnp7scY//+/erfv78iIiIUExOjxx57TGfOnLH6rZQ7q1ev1o033qhatWrJ4XDo448/dtlvjNG4ceMUHx+v8PBw9ezZU3v27HEZc+zYMQ0ePFiRkZGqWrWq7r77bp08edJlzLfffqsuXbooLCxMderU0dSpU3391sqlC/V76NChxT7rffv2dRlDv90zZcoUXXPNNapSpYpiYmI0cOBA7d6922WMt753rFy5Uq1bt1ZoaKgaNmyoOXPm+PrtlTvu9Lt79+7FPt/33nuvyxj67Z4ZM2aoRYsWzhsxJCYmasmSJc79l9Rn28Ay77//vgkJCTGzZs0yO3bsMMOHDzdVq1Y16enp/i6twhk/frxp2rSpOXz4sPPPr7/+6tx/7733mjp16phly5aZjRs3mg4dOpiOHTs69585c8Y0a9bM9OzZ02zZssV8/vnnpkaNGmbMmDH+eDvlyueff26efPJJs2DBAiPJLFy40GX/s88+a6KioszHH39stm3bZm666SaTkJBgTp8+7RzTt29f07JlS7N27Vrz1VdfmYYNG5o///nPzv2ZmZkmNjbWDB482Gzfvt289957Jjw83Lz++utWvc1y40L9TkpKMn379nX5rB87dsxlDP12T58+fczs2bPN9u3bzdatW831119v6tata06ePOkc443vHT/++KOJiIgwo0aNMjt37jSvvvqqCQwMNEuXLrX0/fqbO/3u1q2bGT58uMvnOzMz07mffrvv008/NZ999pn54YcfzO7du83f//53ExwcbLZv326MubQ+24RbC7Vr186MHDnS+bigoMDUqlXLTJkyxY9VVUzjx483LVu2LHFfRkaGCQ4ONh9++KFz265du4wkk5KSYow5GygCAgJMWlqac8yMGTNMZGSkyc3N9WntFckfw1ZhYaGJi4sz//znP53bMjIyTGhoqHnvvfeMMcbs3LnTSDIbNmxwjlmyZIlxOBzm4MGDxhhj/vWvf5lq1aq59PqJJ54wV155pY/fUflWWrgdMGBAqc+h3xfvyJEjRpJZtWqVMcZ73zsef/xx07RpU5fXuv32202fPn18/ZbKtT/225iz4fahhx4q9Tn0u2yqVatm3nrrrUvus820BIvk5eVp06ZN6tmzp3NbQECAevbsqZSUFD9WVnHt2bNHtWrV0uWXX67Bgwdr//79kqRNmzYpPz/fpdeNGzdW3bp1nb1OSUlR8+bNFRsb6xzTp08fZWVlaceOHda+kQokNTVVaWlpLr2NiopS+/btXXpbtWpVtW3b1jmmZ8+eCggI0Lp165xjunbtqpCQEOeYPn36aPfu3Tp+/LhF76biWLlypWJiYnTllVfqvvvu09GjR5376PfFy8zMlCRFR0dL8t73jpSUFJdjFI251L/X/7HfRd59913VqFFDzZo105gxY5Sdne3cR78vTkFBgd5//32dOnVKiYmJl9xnO8jfBVwqfvvtNxUUFLh8aCQpNjZW33//vZ+qqrjat2+vOXPm6Morr9Thw4c1ceJEdenSRdu3b1daWppCQkJUtWpVl+fExsYqLS1NkpSWllbi16JoH0pW1JuSendub2NiYlz2BwUFKTo62mVMQkJCsWMU7atWrZpP6q+I+vbtq1tuuUUJCQnat2+f/v73v6tfv35KSUlRYGAg/b5IhYWFevjhh9WpUyc1a9ZMkrz2vaO0MVlZWTp9+rTCw8N98ZbKtZL6LUl33nmn6tWrp1q1aunbb7/VE088od27d2vBggWS6LenvvvuOyUmJionJ0eVK1fWwoUL1aRJE23duvWS+mwTblEh9evXz/nvFi1aqH379qpXr57mz59fbv7jArzhjjvucP67efPmatGihRo0aKCVK1eqR48efqysYhs5cqS2b9+ur7/+2t+lXBJK6/eIESOc/27evLni4+PVo0cP7du3Tw0aNLC6zArvyiuv1NatW5WZmamPPvpISUlJWrVqlb/LshzTEixSo0YNBQYGFrsyMT09XXFxcX6qyj6qVq2qK664Qnv37lVcXJzy8vKUkZHhMubcXsfFxZX4tSjah5IV9eZ8n+O4uDgdOXLEZf+ZM2d07Ngx+u8Fl19+uWrUqKG9e/dKot8X44EHHtDixYu1YsUKXXbZZc7t3vreUdqYyMjIS/KH79L6XZL27dtLksvnm367LyQkRA0bNlSbNm00ZcoUtWzZUi+//PIl99km3FokJCREbdq00bJly5zbCgsLtWzZMiUmJvqxMns4efKk9u3bp/j4eLVp00bBwcEuvd69e7f279/v7HViYqK+++47l1CQnJysyMhINWnSxPL6K4qEhATFxcW59DYrK0vr1q1z6W1GRoY2bdrkHLN8+XIVFhY6/8eVmJio1atXKz8/3zkmOTlZV1555SX5K3JPHDhwQEePHlV8fLwk+u0JY4weeOABLVy4UMuXLy82VcNb3zsSExNdjlE05lL7Xn+hfpdk69atkuTy+abfF6+wsFC5ubmX3mfb31e0XUref/99ExoaaubMmWN27txpRowYYapWrepyZSLc8+ijj5qVK1ea1NRUs2bNGtOzZ09To0YNc+TIEWPM2SVP6tata5YvX242btxoEhMTTWJiovP5RUue9O7d22zdutUsXbrU1KxZk6XAjDEnTpwwW7ZsMVu2bDGSzIsvvmi2bNlifv75Z2PM2aXAqlataj755BPz7bffmgEDBpS4FNjVV19t1q1bZ77++mvTqFEjl6WpMjIyTGxsrPl//+//me3bt5v333/fREREXHJLUxlz/n6fOHHC/O1vfzMpKSkmNTXV/O9//zOtW7c2jRo1Mjk5Oc5j0G/33HfffSYqKsqsXLnSZemp7Oxs5xhvfO8oWi7pscceM7t27TLTp08vl8sl+dqF+r13714zadIks3HjRpOammo++eQTc/nll5uuXbs6j0G/3Td69GizatUqk5qaar799lszevRo43A4zJdffmmMubQ+24Rbi7366qumbt26JiQkxLRr186sXbvW3yVVSLfffruJj483ISEhpnbt2ub22283e/fude4/ffq0uf/++021atVMRESEufnmm83hw4ddjvHTTz+Zfv36mfDwcFOjRg3z6KOPmvz8fKvfSrmzYsUKI6nYn6SkJGPM2eXAxo4da2JjY01oaKjp0aOH2b17t8sxjh49av785z+bypUrm8jISDNs2DBz4sQJlzHbtm0znTt3NqGhoaZ27drm2Wefteotlivn63d2drbp3bu3qVmzpgkODjb16tUzw4cPL/YDMf12T0l9lmRmz57tHOOt7x0rVqwwrVq1MiEhIebyyy93eY1LxYX6vX//ftO1a1cTHR1tQkNDTcOGDc1jjz3mss6tMfTbXXfddZepV6+eCQkJMTVr1jQ9evRwBltjLq3PtsMYY6w7TwwAAAD4DnNuAQAAYBuEWwAAANgG4RYAAAC2QbgFAACAbRBuAQAAYBuEWwAAANgG4RYAAAC2QbgFAACAbRBuAcCGHA6HPv74Y3+XAQCWI9wCQDkzdOhQDRw40N9lAECFRLgFAACAbRBuAaAc6969u/7617/q8ccfV3R0tOLi4jRhwgSXMXv27FHXrl0VFhamJk2aKDk5udhxfvnlF912222qWrWqoqOjNWDAAP3000+SpO+//14RERGaN2+ec/z8+fMVHh6unTt3+vLtAYDXEW4BoJybO3euKlWqpHXr1mnq1KmaNGmSM8AWFhbqlltuUUhIiNatW6eZM2fqiSeecHl+fn6++vTpoypVquirr77SmjVrVLlyZfXt21d5eXlq3Lixnn/+ed1///3av3+/Dhw4oHvvvVfPPfecmjRp4o+3DAAXzWGMMf4uAgDwu6FDhyojI0Mff/yxunfvroKCAn311VfO/e3atdN1112nZ599Vl9++aX69++vn3/+WbVq1ZIkLV26VP369dPChQs1cOBAvfPOO5o8ebJ27dolh8MhScrLy1PVqlX18ccfq3fv3pKkG264QVlZWQoJCVFgYKCWLl3qHA8AFUWQvwsAAJxfixYtXB7Hx8fryJEjkqRdu3apTp06zmArSYmJiS7jt23bpr1796pKlSou23NycrRv3z7n41mzZumKK65QQECAduzYQbAFUCERbgGgnAsODnZ57HA4VFhY6PbzT548qTZt2ujdd98ttq9mzZrOf2/btk2nTp1SQECADh8+rPj4+IsvGgD8hHALABXYVVddpV9++cUljK5du9ZlTOvWrfXBBx8oJiZGkZGRJR7n2LFjGjp0qJ588kkdPnxYgwcP1ubNmxUeHu7z9wAA3sQFZQBQgfXs2VNXXHGFkpKStG3bNn311Vd68sknXcYMHjxYNWrU0IABA/TVV18pNTVVK1eu1F//+lcdOHBAknTvvfeqTp06euqpp/Tiiy+qoKBAf/vb3/zxlgCgTAi3AFCBBQQEaOHChTp9+rTatWune+65R88884zLmIiICK1evVp169bVLbfcoquuukp33323cnJyFBkZqbfffluff/65/vOf/ygoKEiVKlXSO++8ozfffFNLlizx0zsDgIvDagkAAACwDc7cAgAAwDYItwAAALANwi0AAABsg3ALAAAA2yDcAgAAwDYItwAAALANwi0AAABsg3ALAAAA2yDcAgAAwDYItwAAALANwi0AAABs4/8Dc5bBTYMVyZkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "S, Vh, d_zero = svd_and_plot_singular_values(umembed.state_dict()['W_U'].detach().cpu())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4.029713  , 4.0036187 , 3.922573  , 3.897128  , 3.8571942 ,\n",
       "       3.8430037 , 3.8084183 , 3.77253   , 3.7118673 , 3.6914575 ,\n",
       "       3.677841  , 3.6332297 , 3.5669296 , 3.4989145 , 3.442417  ,\n",
       "       3.1988945 , 2.8210888 , 2.4980774 , 2.2863514 , 0.83850855],\n",
       "      dtype=float32)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "S[-20:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ALTI",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
