{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "from collections import namedtuple, defaultdict\n",
    "import os\n",
    "import random\n",
    "\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.decomposition import PCA\n",
    "import seaborn as sns\n",
    "from sklearn.random_projection import SparseRandomProjection\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [],
   "source": [
    "def construct_sparse_matrix(features: torch.Tensor, sparse_dim: int) -> torch.Tensor:\n",
    "    sparse_proj = SparseRandomProjection(sparse_dim, density=\"auto\")\n",
    "    sparse_proj.fit(features)\n",
    "    sparse_matrix = sparse_proj.components_\n",
    "    sparse_matrix_coo = sparse_matrix.tocoo()\n",
    "\n",
    "    # Convert the row and col lists to numpy arrays and then to a LongTensor (speed up)\n",
    "    indices = torch.LongTensor(np.array([sparse_matrix_coo.row, sparse_matrix_coo.col]))\n",
    "    values = torch.FloatTensor(sparse_matrix_coo.data)\n",
    "\n",
    "    sparse_mat = torch.sparse_coo_tensor(\n",
    "        indices,\n",
    "        values,\n",
    "        [sparse_dim, features.shape[1]]\n",
    "    ).t()\n",
    "\n",
    "    return sparse_mat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [],
   "source": [
    "ClusterRep = namedtuple(\"ClusterRep\", [\"rep\", \"cluster_id\"])\n",
    "REP_TYPE = \"last_hidden_state\"\n",
    "\n",
    "FACE_COLOR = \"#F7F7FF\"\n",
    "MARKER = \"o\"\n",
    "LINEWIDTH = 1.2\n",
    "MARKERSIZE = 10\n",
    "MARKEREDGEWIDTH = 1.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [],
   "source": [
    "ROOT = \"/home/anonymousanonymous/inference-rlhf/data/math/llama-3-3b/generations/\"\n",
    "\n",
    "# # TEST_FILE_REPS = \"/home/anonymousanonymous/inference-rlhf/data/math/llama-3-3b/generations/llama32medium--shots-1--prompt-idx-1-generations--armo-rm--llama-3-3b-features.tar\"\n",
    "# TEST_FILE_REPS = \"/home/anonymousanonymous/inference-rlhf/data/math/llama-3-3b/generations/llama32medium--shots-1--prompt-idx-1-generations--armo-rm--features.tar\"\n",
    "# TEST_FILE_RESPONSES = \"/home/anonymousanonymous/inference-rlhf/data/math/llama-3-3b/generations/llama32medium--shots-1--prompt-idx-1-generations--armo-rm.json\"\n",
    "\n",
    "# # load the test file\n",
    "# representations = torch.load(TEST_FILE_REPS)[REP_TYPE]\n",
    "# with open(TEST_FILE_RESPONSES, \"r\") as f:\n",
    "#     responses = json.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_unique_pairs_between_clusters(*clusters):\n",
    "    # List to store all unique pairs\n",
    "    pairs = []\n",
    "    \n",
    "    # Iterate through all cluster combinations\n",
    "    for i in range(len(clusters)):\n",
    "        for j in range(i + 1, len(clusters)):  # Start from i+1 to avoid same-cluster pairs\n",
    "            # Get current clusters\n",
    "            cluster1 = clusters[i]\n",
    "            cluster2 = clusters[j]\n",
    "            \n",
    "            # Generate all possible pairs between these two clusters\n",
    "            for item1 in cluster1:\n",
    "                for item2 in cluster2:\n",
    "                    pairs.append((item1, item2))\n",
    "                    assert item1.cluster_id != item2.cluster_id\n",
    "    \n",
    "    return pairs\n",
    "\n",
    "def get_unique_pairs_within_clusters(*clusters):\n",
    "    pairs = []\n",
    "    for cluster in tqdm(clusters, desc=\"Getting unique pairs within clusters ...\"):\n",
    "        for i in range(len(cluster)):\n",
    "            for j in range(i + 1, len(cluster)):\n",
    "                pairs.append((cluster[i], cluster[j]))\n",
    "                assert cluster[i].cluster_id == cluster[j].cluster_id\n",
    "    return pairs\n",
    "\n",
    "def get_cosine_sim(X, Y, normalize=False):\n",
    "    if normalize:\n",
    "        X = F.normalize(X, p=2, dim=1)\n",
    "        Y = F.normalize(Y, p=2, dim=1)\n",
    "    \n",
    "    return torch.sum(X * Y, dim=1)\n",
    "\n",
    "def get_l2_dist(X, Y):\n",
    "    return torch.norm(X - Y, p=2, dim=1)\n",
    "\n",
    "def stack_pairs(pairs):\n",
    "    return torch.stack([p[0].rep for p in pairs]), torch.stack([p[1].rep for p in pairs])\n",
    "\n",
    "ANSWER_IDS = [\"The answer is \", \"The answer is: \"]\n",
    "import re\n",
    "def extract_answer(completion):\n",
    "    for answer_id in ANSWER_IDS: \n",
    "        ans_re = re.compile(fr\"{answer_id}(\\d+)\")\n",
    "        match = ans_re.search(completion)\n",
    "        if match:\n",
    "            match_str = match.group(1).strip()\n",
    "            match_str = match_str.replace(\",\", \"\")\n",
    "            return int(match_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Getting all intra and inter cluster pairs ...: 0it [00:00, ?it/s]/tmp/ipykernel_151179/3748037627.py:29: 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",
      "  representations = torch.load(os.path.join(ROOT, feature_file))[rep_type].float()\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Getting unique pairs within clusters ...: 100%|██████████| 11/11 [00:00<00:00, 38.14it/s]\n",
      "Getting all intra and inter cluster pairs ...: 1it [00:00,  1.12it/s]\n"
     ]
    }
   ],
   "source": [
    "def get_all_intra_inter_cluster_pairs(\n",
    "        file_idx: int,\n",
    "        min_rep_per_cluster: int = 100, \n",
    "        num_samples_per_cluster: int = 100, \n",
    "        num_clusters_per_file: int = 10, \n",
    "        apply_pca: bool = False, \n",
    "        sparse_project: bool = False,\n",
    "        rep_suffix: str = '--llama-3-3b-features.tar', # llama-3-3b-gradients.tar, --armo-rm-features.tar\n",
    "        rep_type: str = 'last_hidden_state',\n",
    "        zero_center: bool = False\n",
    "    ):\n",
    "    all_files = os.listdir(ROOT)\n",
    "\n",
    "    feature_files = [f for f in all_files if f.endswith(rep_suffix)][file_idx:file_idx+1]\n",
    "    generation_files = [f.replace(rep_suffix, \".json\") for f in feature_files]\n",
    "\n",
    "    if sparse_project:\n",
    "        fake_representations = torch.load(os.path.join(ROOT, feature_files[0]))[rep_type]\n",
    "        sparse_matrix = construct_sparse_matrix(np.zeros((1, fake_representations.shape[1])), 512)\n",
    "\n",
    "    all_intra_cluster_pairs = []\n",
    "    all_inter_cluster_pairs = []\n",
    "\n",
    "    for feature_file, generation_file in tqdm(zip(feature_files, generation_files), desc=\"Getting all intra and inter cluster pairs ...\"):\n",
    "\n",
    "        with open(os.path.join(ROOT, generation_file), \"r\") as f:\n",
    "            responses = json.load(f)\n",
    "        \n",
    "        representations = torch.load(os.path.join(ROOT, feature_file))[rep_type].float()\n",
    "\n",
    "        if zero_center:\n",
    "            representations = representations - representations.mean(dim=0)\n",
    "\n",
    "        if apply_pca:\n",
    "            representations = representations.cpu().numpy()\n",
    "            representations = StandardScaler().fit_transform(representations)\n",
    "            representations = PCA(n_components=128).fit_transform(representations)\n",
    "            representations = torch.from_numpy(representations).float()\n",
    "\n",
    "        if sparse_project:\n",
    "            representations = representations @ sparse_matrix\n",
    "\n",
    "        all_clusters = defaultdict(list)\n",
    "        for rep, response in zip(representations, responses):\n",
    "            all_clusters[response[\"extracted_answer\"]].append(ClusterRep(rep.float(), response[\"extracted_answer\"]))\n",
    "\n",
    "        # filter down to clusters that have at least 100 reps\n",
    "        all_clusters = {k: v for k, v in all_clusters.items() if len(v) >= min_rep_per_cluster}\n",
    "\n",
    "        if len(all_clusters) == 0:\n",
    "            print(f\"No clusters with at least {min_rep_per_cluster} reps for {generation_file}\")\n",
    "            continue\n",
    "\n",
    "        # filter down to random 10 clusters\n",
    "        random_clusters = random.sample(list(all_clusters.keys()), min(num_clusters_per_file, len(all_clusters)))\n",
    "        all_clusters = {k: v for k, v in all_clusters.items() if k in random_clusters}\n",
    "\n",
    "        # pick 100 random reps per cluster\n",
    "        for key in all_clusters:\n",
    "            all_clusters[key] = random.sample(all_clusters[key], min(num_samples_per_cluster, len(all_clusters[key])))\n",
    "\n",
    "        all_intra_cluster_pairs.extend(get_unique_pairs_within_clusters(*all_clusters.values()))\n",
    "        all_inter_cluster_pairs.extend(get_unique_pairs_between_clusters(*all_clusters.values()))\n",
    "\n",
    "    return all_intra_cluster_pairs, all_inter_cluster_pairs\n",
    "\n",
    "file_idx = 10\n",
    "all_intra_cluster_pairs_before_projection, all_inter_cluster_pairs_before_projection = get_all_intra_inter_cluster_pairs(file_idx=file_idx, num_clusters_per_file=20, apply_pca=False, sparse_project=False, rep_suffix='--armo-rm-features.tar', zero_center=True, rep_type=\"last_hidden_state\")\n",
    "# all_intra_cluster_pairs_after_projection, all_inter_cluster_pairs_after_projection = get_all_intra_inter_cluster_pairs(file_idx=file_idx, num_clusters_per_file=20, apply_pca=False, sparse_project=False, rep_suffix='--armo-rm-features.tar', zero_center=False, rep_type=\"gradients_512\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([54450, 4096]) torch.Size([54450, 4096]) torch.Size([550000, 4096]) torch.Size([550000, 4096])\n"
     ]
    }
   ],
   "source": [
    "# before projection\n",
    "intra_X_before, intra_Y_before = stack_pairs(all_intra_cluster_pairs_before_projection)\n",
    "inter_X_before, inter_Y_before = stack_pairs(all_inter_cluster_pairs_before_projection)\n",
    "print(intra_X_before.shape, intra_Y_before.shape, inter_X_before.shape, inter_Y_before.shape)\n",
    "\n",
    "intra_cluster_cosine_dists_before = get_cosine_sim(intra_X_before, intra_Y_before, normalize=True)\n",
    "inter_cluster_cosine_dists_before = get_cosine_sim(inter_X_before, inter_Y_before, normalize=True)\n",
    "\n",
    "intra_cluster_l2_dists_before = get_l2_dist(intra_X_before, intra_Y_before)\n",
    "inter_cluster_l2_dists_before = get_l2_dist(inter_X_before, inter_Y_before)\n",
    "\n",
    "# # after projection\n",
    "# intra_X_after, intra_Y_after = stack_pairs(all_intra_cluster_pairs_after_projection)\n",
    "# inter_X_after, inter_Y_after = stack_pairs(all_inter_cluster_pairs_after_projection)\n",
    "# print(intra_X_after.shape, intra_Y_after.shape, inter_X_after.shape, inter_Y_after.shape)\n",
    "\n",
    "# intra_cluster_cosine_dists_after = get_cosine_sim(intra_X_after, intra_Y_after, normalize=True)\n",
    "# inter_cluster_cosine_dists_after = get_cosine_sim(inter_X_after, inter_Y_after, normalize=True)\n",
    "\n",
    "# intra_cluster_l2_dists_after = get_l2_dist(intra_X_after, intra_Y_after)\n",
    "# inter_cluster_l2_dists_after = get_l2_dist(inter_X_after, inter_Y_after)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABKUAAAHqCAYAAADVi/1VAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAk3xJREFUeJzs3Xl8VOX5///3OWdmMjMJWxJAAe23qIQtCIpYEatQrNVWLVjcwFpLXaiotVrF6selarFW2oq1dYEfKuXj9lFsbVGrtVqrFG1LS1xKXVCCokASSDJLZs7y+yNkSMg6IZnJJK/n44HmXHPf97nmnEMmuTj3fQzP8zwBAAAAAAAAGWRmOwEAAAAAAAD0PRSlAAAAAAAAkHEUpQAAAAAAAJBxFKUAAAAAAACQcRSlAAAAAAAAkHEUpQAAAAAAAJBxFKUAAAAAAACQcRSlAAAAAAAAkHEUpQAAAAAAAJBxFKWANpSUlOiuu+7KdhotWrRokWbMmNGlY55zzjk655xzUttbtmxRSUmJnnzyyS7dz1133aWSkpIuHbMlTz75pEpKSlRWVtal4/7lL3/RqaeeqtLSUpWUlKi6urpLx+/pGo7rli1bMr7vGTNmaNGiRRnfLwAAAICu58t2AkBHbd68WcuWLdOrr76qbdu2ye/3a9SoUTrxxBN1xhlnKBgMZjtF7IN77rlHBx98sGbOnJntVNpUVVWl733vezrkkEN0/fXXKxAIKBQKZTutXuWf//ynXn31VZ177rnq379/ttMBAAAA0E0oSiEnvPTSS7rssssUCAR06qmnatSoUUomk/rHP/6hn/70p3rvvfd08803d/l+N2zYIMuyunzcrnDzzTfL87wuHXP58uVdOl5rFixYoAsuuKBJ7N5779UJJ5zQ44tSZWVlikQiuuyyyzR16tRsp5MVp556qr761a8qEAh0y/jr16/XL3/5S82aNatZUerZZ5+VYRjdsl8AAAAAmUVRCj1eeXm5Lr/8cg0bNkwPPvighgwZknpt7ty5+uijj/TSSy91y77z8vK6Zdyu4Pf7u3zM7ioyNIhGowqHw/L5fPL5cvPbT2VlpSSpX79+XTZmw3HJFtu25bpuh8+/ZVlZK9Z29zUKAAAAIHNYUwo93rJlyxSNRnXrrbc2KUg1+NznPqdzzz03tW3btu6++27NnDlT48eP14wZM/Szn/1MiUSiSb+ysjLNnz9fRx55pCZMmKAZM2bommuuadJm7zWlGtZC+uijj7Ro0SJNnjxZhx9+uK655hrFYrFmuf32t7/V7NmzNWHCBE2ZMkWXX365tm7d2u57rq2t1a233qoZM2Zo/PjxOuqoo3TeeefprbfeSrXZe02phvWfli9frlWrVulLX/qSDj30UH3729/W1q1b5Xme7r77bn3xi1/UhAkTtGDBAu3cubPJfvdeU6ol//nPf7Ro0SJ96UtfUmlpqY4++mhdc801qqqqatKu4Vi99957uuKKK3TEEUfo7LPPbvJa4+McjUa1evVqlZSUqKSkRIsWLdLf/vY3lZSU6Pnnn2+Wx9NPP62SkhKtX7++3eMZj8d1/fXX68gjj9Rhhx2mq666Srt27WrW7uWXX9bZZ5+tiRMnatKkSbrgggv07rvvNjk+V199tSTpG9/4RirPBs8880zqfB955JG68sor9dlnnzXZx6JFizRp0iRt3rxZ559/viZNmqQrr7xSkuS6rh544AF99atfVWlpqaZOnarrr7++xVz31jBueXm55s+fr4kTJ2ratGn65S9/2eSOusbXyQMPPKCZM2eqtLRU77//viRp7dq1qWMwefJkLViwIPVag9bWlGrv+DV4//33ddlll+kLX/iCJkyYoBNOOEE///nPJdVfG7fffrsk6Utf+lLqemjYV0trSpWXl+vSSy/VlClTdOihh+r0009vVqhet26dSkpKtGbNGv3617/WF7/4RZWWlurcc8/VRx991O7xBQAAAND1cvNWBfQpf/7zn3XAAQfosMMO61D76667TqtXr9YJJ5yg8847Txs2bNC9996r999/X3fffbckqaKiQvPnz9egQYN0wQUXqH///tqyZUuLxY+WfO9739OIESP0/e9/X2+//bYef/xxFRYW6gc/+EGqza9//WvdeeedOvHEE/WNb3xDlZWV+s1vfqO5c+fqqaeeanOtnBtuuEHPPfec5s2bp4MOOkg7d+7UP/7xD73//vsaN25cm7k9/fTTSiaTOuecc7Rz504tW7ZM3/ve9/SFL3xB69at0/nnn6+PPvpIv/nNb/STn/xEixcv7tB7bvDaa6+pvLxcs2fP1uDBg/Xuu+/qscce03vvvafHHnus2dSqyy67TJ/73Od0+eWXtzrd8Pbbb9d1112nCRMm6PTTT5ckHXjggZo4caL2339/Pf300zr++OObvc8DDzxQkyZNajfnH/3oR+rfv78WLlyoTZs26eGHH9Ynn3yilStXpvJ96qmntGjRIk2bNk1XXnmlYrGYHn74YZ199tlavXq1RowYoYsuukif//zn9eijj+rSSy/ViBEjdOCBB0qqL9Rcc801Ki0t1fe//31VVFTooYce0j//+c9m59u2bc2fP1+HH364rr766tR6aNdff71Wr16t2bNn65xzztGWLVu0atUqvf3223r44YfbvTvOcRx95zvf0aGHHqof/OAHeuWVV3TXXXfJcRxddtllTdo++eSTqqur0+mnn65AIKABAwbotdde0/nnn68RI0Zo4cKFisfj+s1vfqOzzjpLTz75pEaMGNHqvjty/KT6oubcuXPl8/l0xhlnaPjw4dq8ebNefPFFXX755Tr++OP14Ycf6ve//72uueYaDRo0SJJUWFjY4n537NihM888U7FYTOecc44GDRqk1atXa8GCBVq6dGmz6+b++++XYRj69re/rdraWi1btkxXXnmlHn/88TaPLQAAAIBu4AE9WE1NjTdq1ChvwYIFHWr/zjvveKNGjfKuvfbaJvHbbrvNGzVqlLd27VrP8zzv+eef90aNGuVt2LChzfFGjRrlLV26NLW9dOlSb9SoUd4111zTpN3FF1/sTZkyJbW9ZcsWb8yYMd6vf/3rJu02btzojR07tll8b4cffrh30003tdnm6quv9qZPn57aLi8v90aNGuV94Qtf8Kqrq1PxJUuWeKNGjfJOOeUUL5lMpuLf//73vXHjxnl1dXWp2Lx587x58+Y1G/OJJ55IxWKxWLNcfv/733ujRo3y3njjjVSs4Vh9//vfb9a+4bXGJk6c6F199dXN2i5ZssQbP358k/dUUVHhjR07tsm5ackTTzzhjRo1yps1a5aXSCRS8fvvv98bNWqU98ILL3ie53m1tbXe5MmTveuuu65J/+3bt3uHH354k3jDmI2vnUQi4R111FHe1772NS8ej6fif/7zn71Ro0Z5d955Zyp29dVXe6NGjfLuuOOOJvt64403vFGjRnm/+93vmsT/8pe/tBjfW8O4N998cyrmuq53wQUXeOPGjfMqKio8z9tzTg877LBUrMGpp57qHXXUUV5VVVUq9s4773ijR4/2rrrqqmbHoLy8PO3jN3fuXG/SpEnexx9/3KSt67qpr5ctW9Zk/MamT5/e5Dq59dZbm117tbW13owZM7zp06d7juN4nud5f/vb37xRo0Z5J554YpNr/sEHH/RGjRrlbdy4sdm+AAAAAHQvpu+hR6utrZUk5efnd6j9yy+/LEk677zzmsS//e1vN3m9YT2gl156SclkMu28zjzzzCbbkydP1s6dO1P5Pv/883JdVyeeeKIqKytTf4qLi/W5z31O69ata3P8/v3769///nezqV8d8ZWvfKXJekcTJkyQJJ1yyilN1nGaMGGCkslk2vto/JTDuro6VVZW6tBDD5WkJtMLG+x9rNJ16qmnKpFI6Nlnn03F1qxZI9u2dcopp3RojDPOOKPJXUZnnXWWfD5f6np47bXXVF1dra9+9atNzpdpmjr00EPbPV9vvvmmKioqdNZZZzVZh+y4447TyJEjW1zz7Kyzzmqy/eyzz6pfv346+uijm+Qwbtw4hcPhdnNoMHfu3NTXhmFo7ty5SiaTWrt2bZN2X/7yl5vcfbRt2za98847mjVrlgYOHJiKjx49WlOnTk0dq5Z09PhVVlbqjTfe0GmnnaZhw4Y1GaOzi5e//PLLmjBhgiZPnpyK5efn64wzztDHH3+s9957r0n72bNnN1mXqqFfeXl5p/YPAAAAoPOYvoceraCgQJIUiUQ61P7jjz+WaZqpKVUNBg8erP79++vjjz+WJE2ZMkUnnHCCfvnLX+qBBx7QlClTNHPmTJ188skdWkh571+oG6Zm7dq1SwUFBfrwww/leZ6+/OUvt9i/vUW+r7zySi1atEjHHXecxo0bp2OPPVZf//rXdcABB7Sb2/77799ku6FA1Vp8165dHRq3wc6dO/XLX/5Sa9asUUVFRZPXampqmrVva8pXRxx00EEqLS3V008/rTlz5kiqn7o3ceJEfe5zn+vQGHu3y8/P1+DBg1PXw4cffihJTdYma6zhOmzNJ598Ikn6/Oc/3+y1kSNH6h//+EeTmM/n03777dck9tFHH6mmpkZHHXVUi/vY+1i3xDTNZueyIaeG99pg7/PS1ns46KCD9Ne//rXVBdk7evwaCj+jRo1q76102CeffJIqijY2cuTI1OuN99fa393q6uouywkAAABAx1CUQo9WUFCgIUOGtLhYclvau+vCMAwtXbpU//rXv/TnP/9Zr7zyin74wx9qxYoVevTRR9u9M8s0W77J0Nu9ZpLrujIMQ/fff3+LTylr70lrJ510kiZPnqznn39er776qpYvX677779fd911l4499tg2+7b2VLT2cu6o733ve1q/fr3mz5+vMWPGKBwOy3Vdfec732lxrK54guHXv/513Xrrrfr000+VSCT0r3/9S9dff/0+j9ugIe/bb79dgwcPbvZ6Vz9pLhAINDsfruuqqKhId9xxR4t9WltTqbMa3/G2rzJ9/PZFV/09AAAAALDvKEqhx5s+fboeffRRrV+/vt1FrYcPHy7XdfXRRx/poIMOSsV37Nih6upqDR8+vEn7iRMnauLEibr88sv19NNP68orr9SaNWtSd+R01oEHHijP8zRixIgW7zzpiCFDhmju3LmaO3euKioqNGvWLN1zzz3tFqW6065du7R27VpdcsklWrhwYSrecKdMdznppJN022236fe//73i8bj8fr9OPPHEDvf/6KOP9IUvfCG1HYlEtH37dn3xi1+UpNTdRUVFRZo6dWra+TXcfbNp06Zmdzpt2rSp2d05LTnwwAO1du1aHXbYYZ0uGLmuq/Ly8ibX3KZNmySp2bW/t8bvYW8ffPCBBg0a1GoxtaPHr6Hdf//73zZzSWcq37Bhw1rNueF1AAAAAD0Ta0qhx/vOd76jcDis6667Tjt27Gj2+ubNm/Xggw9KUqpg07DdYMWKFU1e37VrV7M7I8aMGSNJSiQS+5zzl7/8ZVmWpV/+8pfN9uN5nqqqqlrt6zhOs2lwRUVFGjJkSJfkti9au+Nl7+PdGeFwuNUpVIWFhTrmmGP0u9/9Tk8//bSmTZuW1p1Djz76aJO1wx5++GHZtp0qSh1zzDEqKCjQvffe2+IaY5WVlW2OP378eBUVFemRRx5pco5efvllvf/++zruuOPazfHEE0+U4zj61a9+1ew127Y7PL1s1apVqa89z9OqVavk9/tbnRbYYMiQIRozZoyeeuqpJvv673//q1dffbXNYmhHj19hYaGOOOIIPfHEE6npgo1zbRAKhSS1PB10b8cee6w2bNig9evXp2LRaFSPPfaYhg8froMPPrjdMQAAAABkB3dKocc78MADdccdd+jyyy/XSSedpFNPPVWjRo1SIpHQ+vXr9eyzz2r27NmS6hdlnjVrlh599FFVV1friCOOUFlZmVavXq2ZM2em7pZZvXq1Hn74Yc2cOVMHHnigIpGIHnvsMRUUFKQKFfua8/e+9z0tWbJEH3/8sWbOnKn8/Hxt2bJFL7zwgk4//XTNnz+/xb6RSETHHnusTjjhBI0ePVrhcFivvfaaysrKtGjRon3ObV8UFBToiCOO0LJly5RMJjV06FC9+uqr2rJlyz6PPW7cOK1du1YrVqzQkCFDNGLEiCZrBX3961/XpZdeKkm67LLL0ho7mUzqW9/6lk488URt2rRJ//u//6vDDz9cX/rSl1Lv68Ybb9RVV12l2bNn66STTlJhYaE++eQTvfzyyzrssMPanC7o9/t15ZVX6pprrtG8efP01a9+VRUVFXrooYc0fPhwfetb32o3xylTpuiMM87Qvffeq3feeUdHH320/H6/PvzwQz377LO69tpr9ZWvfKXNMfLy8vTKK6/o6quv1oQJE/TKK6/opZde0kUXXdShIt5VV12l888/X2eccYa+8Y1vKB6P6ze/+Y369evX5M64vaVz/K677jqdddZZmjVrls444wyNGDFCH3/8sV566SX99re/lVR/LUjSz3/+c5100kny+/2aPn16i3dqXXDBBfrDH/6g888/X+ecc44GDBigp556Slu2bNFdd93V6nQ9AAAAANlHUQo54Utf+pJ+97vfafny5frTn/6khx9+WIFAQCUlJVq0aJFOP/30VNtbbrlFI0aM0OrVq/XCCy+ouLhYF154YZNfqqdMmaKysjKtWbNGO3bsUL9+/TRhwgTdcccdaS363ZYLLrhA/+///T898MADuvvuuyVJ++23n44++mjNmDGj1X7BYFBnnXWWXn31Vf3xj3+U53k68MADdcMNN+jss8/uktz2xZIlS3TzzTfrf//3f+V5no4++mjdf//9OuaYY/Zp3EWLFun666/XL37xC8Xjcc2aNatJUWr69OkaMGCAXNdNFZM66vrrr9fTTz+tpUuXKplM6qtf/aquu+66JtPETj75ZA0ZMkT33Xefli9frkQioaFDh2ry5MmpomdbZs+erWAwqPvvv1933HGHwuGwZs6cqR/84AepxbTb86Mf/Ujjx4/XI488op///OeyLEvDhw/XKaecosMOO6zd/pZladmyZbrxxhv105/+VPn5+Vq4cKEuvvjiDu1/6tSpWrZsmZYuXaqlS5fK5/PpiCOO0A9+8IN2/1509PiNHj1ajz32mO688049/PDDqqur07Bhw5pMx5wwYYIuu+wyPfLII3rllVfkuq7+9Kc/tViUKi4u1iOPPKKf/vSn+s1vfqO6ujqVlJTonnvu6dAdagAAAACyx/BY3RVADrBtW8ccc4ymT5+uH//4x9lOp8dZtGiRnnvuuSbT2LrL448/ruuuu04vv/xys6cIAgAAAEBHMa8BQE544YUXVFlZqa9//evZTqXP2759uwzD0IABA7KdCgAAAIAcxvQ9AD3av//9b23cuFG/+tWvNHbsWE2ZMiXbKfVZO3bs0HPPPadHHnlEEydOTC1IDgAAAACdQVEKQI/28MMP63e/+51Gjx6t2267Ldvp9Gnvv/++br/9dk2YMEE333xzttMBAAAAkONYUwoAAKCbvPHGG1q+fLnefPNNbd++XXfffbdmzpzZZp9169bptttu07vvvqv9999fCxYs6NADFwAAAHJN2mtKvfHGG7rooos0bdo0lZSU6IUXXuhw33/84x8aO3asTj311HR3CwAAkHOi0ahKSkp0ww03dKh9eXm5LrzwQh155JH67W9/q3PPPVfXXXedXnnllW7OFAAAIPPSnr7X8MPVaaedpoULF3a4X3V1ta6++modddRR2rFjR7q7BQAAyDnHHnusjj322A63f+SRRzRixAgtWrRIknTQQQfpH//4hx544AEdc8wx3ZUmAABAVqRdlEr3h6sGN9xwg772ta/Jsqy07q6SJNd1Zdu2TNOUYRhp7xsAAKAlnufJdV35fD6ZZvYfSvyvf/1LRx11VJPYtGnT9OMf/7jDY/BzEwAA6A7d8XNTRhY6f+KJJ1ReXq6f/vSn+vWvf512f9u2VVZW1g2ZAQAASKWlpQoEAtlOQzt27FBxcXGTWHFxsWpraxWPxxUMBtsdg5+bAABAd+rKn5u6vSj14YcfasmSJVq1apV8vs7trif8yyUAAOi9etPPGg3vpaSkpEcU2tA6x3H09ttva+zYsbIsK9vpoB2cr9zBucotnK/ckUgktHHjxi79ualbi1KO4+iKK67QJZdcos9//vOdHqfh1vPS0tJuv0gdx1FZWVlG9pVrODat49i0jePTOo5N6zg2rePYtC2d49PQtqdMcysuLm629uaOHTtUUFDQobukpD0/NwUCAYpSPZzjOJLqzxV/l3s+zlfu4FzlFs5X7unKn5u6tSgViUT05ptv6p133tHNN98sqX6dA8/zNHbsWC1fvrzZugltsSwrYxdp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Wdt/V0okEgoEAtlOAwAAAB3E9D0AQN+QjEqJSPf/6UTha+/pezNmzNA999yja665RpMmTdJxxx2nRx99NPX6zJkzJUmzZs1SSUmJzjnnnNRrjz/+uE488USVlpbqK1/5ilatWpV6bcuWLSopKdGaNWs0b948lZaW6umnn24xp+rqal1//fWaOnWqSktL9bWvfU1//vOfW2y7aNEiffe7320Su/XWW5vk9eyzz+rkk0/WhAkTdOSRR+pb3/qWotGo7rrrLq1evVp/+tOfVFJSopKSEq1bt06StHXrVl122WWaPHmypkyZogULFmjLli3N9vvrX/9a06ZN01e+8pV2jzUAAAB6Du6UAgCgB1qxYoUuvfRSXXTRRXruued044036ogjjtDIkSP1+OOPa86cOVqxYoUOOeSQ1J1Ov/vd73TnnXfq+uuv15gxY/TOO+/of/7nfxQOhzVr1qzU2HfccYcWLVqkMWPGKC8vr9m+XdfV+eefr0gkop/+9Kc68MAD9d5778k0O/dvWdu2bdMVV1yhH/zgB5o5c6YikYj+/ve/y/M8ffvb39b777+v2tpaLV68WJI0YMAAJZNJzZ8/XxMnTtSqVavk8/n0q1/9St/5znf0u9/9LnVH1Nq1a1VQUKAVK1Z0KjcAAABkD0UpAMiydNYSQt/xxS9+UXPnzpUknX/++XrggQe0bt06jRw5UoMG1U8NHDhwoAYPHpzqc9ddd2nRokX68pe/LEk64IAD9N577+nRRx9tUpQ699xzU21a8tprr2nDhg1as2aNPv/5z6fG6qzt27fLtm0df/zxGj58uCSppKQk9XowGFQikWjyXn7729/KdV3deuutMgxDkrR48WIdccQRev311zVt2jRJUjgc1i233MK0PQAAgBzEb0IAkAU7ownVxG15nicvXKiPd8bVP+TXwDC/WKNe46KNYRgqLi5WRUVFq+2j0ag2b96sa6+9Vv/zP/+Titu2rX79+jVpO378+Db3/c4772i//fZLFaT21ejRo3XUUUfp5JNP1rRp0zRt2jSdcMIJGjBgQKt9/vOf/2jz5s067LDDmsTr6uq0efPm1PaoUaMoSAEAAOQoilIAkAU1cVsvbdymaF1S27Zv1+eG25o+eihFKaTsfQedYRjyPK/V9tFo/VpWN998sw499NAmr+097S4cDre572AwmE6qLeZm23bq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PNPOR4d2vvYtgWmx3Fm8vTHjhpq0NWMNZ3KHcRO5N3v6KjU/tlfLwbZqWdheLUfN2MKZ4yYvsWNv165dw29/+1ts2bIFsbH3Fu5+//33cezYMfznP/+ptU1kZCQWL16MpKQkW2zz5s3IyMhATk5Oo36vyWTCN99809hsEhEREdklKioKer3eqfvkuImIiIhaI2eOm1rE2/d0Oh2ioqKg0Wjg5QkLUBAREZFLiAisVit0uhYxJGoUjpuIiIhIDWqMm+zaU4cOHaDVamstzllSUoKgoKA6twkKCsL169cbnb4uGo3G6VcviYiIiNTEcRMRERHRg9m1Kqler0dERAQOHz5si1mtVhw+fFhxW/r9YmJicOTIEUUsJycHMTEx9ueWiIiIqIXguImIiIjowex++96f//xnbN26FTt27MB3332Ht99+G0ajEc8//zwA4I033sCSJUts6SdOnIhDhw5h/fr1+O6777By5UqcOXMGEyZMcF4piIiIiNwQx01ERERE9bP7QcBhw4bhxo0bWLFiBYqLixEeHo61a9fabiu/cuUKNJp7c11xcXFIT0/HsmXLsHTpUjzyyCPIyMhAaGio80pBRERE5IY4biIiIiKqn11v3yMiIiIiIiIiInIGux/fIyIiIiIiIiIiaipOShERERERERERkctxUoqIiIiIiIiIiFyOk1JERERERERERORyHjcpdevWLbz22muIi4tDnz598Le//Q3l5eX1pv/hhx8QFhZW52fPnj22dHV9n52d7YoiOZW99QMAf/zjH2uVff78+Yo0P/30E6ZOnYro6Gj069cP7733Hsxms5pFcTp76+bWrVtYsGABhg4dil69euHJJ5/EwoULUVZWpkjXEvvO5s2bkZCQgKioKIwZMwanT59+YPo9e/bgmWeeQVRUFEaMGIGDBw8qvhcRLF++HPHx8ejVqxcmTZqES5cuqVgC9dhTN1u3bsX48ePx+OOP4/HHH8ekSZNqpZ8zZ06t/pGcnKx2MVRjT/1s3769VtmjoqIUaTy179R13A0LC8PUqVNtaVpL3zl27BimTZuG+Ph4hIWFYd++fQ1uc/ToUYwaNQqRkZEYMmQItm/fXiuNvccxd+Ps4zCpx9nnBVKXo8eG7OxshIWF4S9/+YvKOaQa9rZVaWkpUlNTER8fj8jISAwdOpTHQhext63++c9/2v6GGjRo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",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mThe Kernel crashed while executing code in the current cell or a previous cell. \n",
      "\u001b[1;31mPlease review the code in the cell(s) to identify a possible cause of the failure. \n",
      "\u001b[1;31mClick <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. \n",
      "\u001b[1;31mView Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."
     ]
    }
   ],
   "source": [
    "# plot histogram of intra vs inter cluster cosine distances, along with vertical lines at the mean\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(12, 5))\n",
    "\n",
    "# First subplot - before projection\n",
    "ax1.set_title(\"Cosine similarity before projection\")\n",
    "ax1.hist(intra_cluster_cosine_dists_before, bins=100, label=\"intra cluster\", alpha=0.5, density=True)\n",
    "ax1.hist(inter_cluster_cosine_dists_before, bins=100, label=\"inter cluster\", alpha=0.5, density=True)\n",
    "ax1.legend()\n",
    "\n",
    "# # Second subplot - after projection\n",
    "# ax2.set_title(\"Cosine similarity after projection\")\n",
    "# ax2.hist(intra_cluster_cosine_dists_after, bins=100, label=\"intra cluster\", alpha=0.5, density=True)\n",
    "# ax2.hist(inter_cluster_cosine_dists_after, bins=100, label=\"inter cluster\", alpha=0.5, density=True)\n",
    "# ax2.legend()\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7c34115397d0>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot histogram of intra vs inter cluster l2 distances, along with vertical lines at the mean\n",
    "plt.title(\"L2 Distance\")\n",
    "plt.hist(intra_cluster_l2_dists, bins=100, label=\"intra cluster\", alpha=0.5, density=True)\n",
    "plt.hist(inter_cluster_l2_dists, bins=100, label=\"inter cluster\", alpha=0.5, density=True)\n",
    "plt.axvline(intra_cluster_l2_dists.mean(), color=\"blue\", label=\"intra cluster mean\")\n",
    "plt.axvline(inter_cluster_l2_dists.mean(), color=\"red\", label=\"inter cluster mean\")\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3367476/2704608762.py:16: 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",
      "  representations = torch.load(os.path.join(ROOT, feature_files[0]))[REP_TYPE]\n",
      "/tmp/ipykernel_3367476/2704608762.py:27: 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",
      "  representations = torch.load(os.path.join(ROOT, feature_file))[REP_TYPE]\n",
      "Looping through anchors ...:   0%|          | 0/20 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  9.39it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  8.13it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  9.52it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  8.60it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  9.50it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  8.66it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  8.79it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  9.48it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:01<00:00, 10.21it/s]\n",
      "Looping through anchors ...: 100%|██████████| 20/20 [00:02<00:00,  9.71it/s]\n",
      "/tmp/ipykernel_3367476/2704608762.py:89: UserWarning: No artists with labels found to put in legend.  Note that artists whose label start with an underscore are ignored when legend() is called with no argument.\n",
      "  plt.legend()\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_frac(num_files: int = 1, anchor_samples: int = 10, apply_pca: bool = False, sparse_project: bool = False):\n",
    "    all_files = os.listdir(ROOT)\n",
    "\n",
    "    # llama 3b rep\n",
    "    # feature_files = [f for f in all_files if f.endswith(\"llama-3-3b-features.tar\")][:num_files]\n",
    "    # generation_files = [f.replace(\"--llama-3-3b-features.tar\", \".json\") for f in feature_files][:num_files]\n",
    "\n",
    "    # llama 3b gradients\n",
    "    feature_files = [f for f in all_files if f.endswith(\"llama-3-3b-gradients.tar\")][:num_files]\n",
    "    generation_files = [f.replace(\"--llama-3-3b-gradients.tar\", \".json\") for f in feature_files][:num_files]\n",
    "\n",
    "    # armo rm reward model\n",
    "    # feature_files = [f for f in all_files if f.endswith(\"--armo-rm-features.tar\")][:num_files]\n",
    "    # generation_files = [f.replace(\"--armo-rm-features.tar\", \".json\") for f in feature_files][:num_files]\n",
    "\n",
    "    representations = torch.load(os.path.join(ROOT, feature_files[0]))[REP_TYPE]\n",
    "\n",
    "    if sparse_project:\n",
    "        sparse_matrix = construct_sparse_matrix(np.zeros((1, representations.shape[1])), 512)\n",
    "\n",
    "    all_avg_response_perc_to_frac_in_cluster = []\n",
    "    for feature_file, generation_file in zip(feature_files, generation_files):\n",
    "\n",
    "        with open(os.path.join(ROOT, generation_file), \"r\") as f:\n",
    "            responses = json.load(f)\n",
    "        \n",
    "        representations = torch.load(os.path.join(ROOT, feature_file))[REP_TYPE]\n",
    "\n",
    "        if apply_pca:\n",
    "            representations = representations.cpu().numpy()\n",
    "            representations = StandardScaler().fit_transform(representations)\n",
    "            representations = PCA(n_components=512).fit_transform(representations)\n",
    "            representations = torch.from_numpy(representations).float()\n",
    "\n",
    "        if sparse_project:\n",
    "            representations = representations @ sparse_matrix\n",
    "\n",
    "\n",
    "        all_response_perc_to_frac_in_cluster = []\n",
    "        for anchor_idx in tqdm(random.sample(range(len(responses)), anchor_samples), desc=\"Looping through anchors ...\"):\n",
    "            anchor_answer = responses[anchor_idx][\"extracted_answer\"]\n",
    "            anchor_rep = representations[anchor_idx:anchor_idx+1]\n",
    "\n",
    "            other_answers = [r[\"extracted_answer\"] for r in responses[:anchor_idx] + responses[anchor_idx+1:]]\n",
    "            other_reps = torch.cat([representations[:anchor_idx], representations[anchor_idx+1:]])\n",
    "\n",
    "            dot_prods = torch.sum(anchor_rep * other_reps, dim=1)\n",
    "\n",
    "            dot_prods_with_answers = list(zip(dot_prods, other_answers))\n",
    "            dot_prods_with_answers.sort(key=lambda x: x[0], reverse=True)\n",
    "\n",
    "            response_perc_to_frac_in_cluster = dict()\n",
    "            for perc in [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0]:\n",
    "                num_responses = int(perc * len(dot_prods_with_answers))\n",
    "                answers_in_perc = [x[1] for x in dot_prods_with_answers[:num_responses]]\n",
    "                frac_in_cluster = sum([1 for answer in answers_in_perc if answer == anchor_answer]) / num_responses\n",
    "                response_perc_to_frac_in_cluster[perc] = frac_in_cluster\n",
    "\n",
    "            all_response_perc_to_frac_in_cluster.append(response_perc_to_frac_in_cluster)\n",
    "\n",
    "        # average\n",
    "        avg_response_perc_to_frac_in_cluster = {\n",
    "            k: sum([d[k] for d in all_response_perc_to_frac_in_cluster]) / len(all_response_perc_to_frac_in_cluster)\n",
    "            for k in all_response_perc_to_frac_in_cluster[0].keys()\n",
    "        }\n",
    "        all_avg_response_perc_to_frac_in_cluster.append(avg_response_perc_to_frac_in_cluster)\n",
    "    \n",
    "    # average over all files\n",
    "    avg_response_perc_to_frac_in_cluster = {\n",
    "        k: sum([d[k] for d in all_avg_response_perc_to_frac_in_cluster]) / len(all_avg_response_perc_to_frac_in_cluster)\n",
    "        for k in all_avg_response_perc_to_frac_in_cluster[0].keys()\n",
    "    }\n",
    "\n",
    "    sns.set_style(\"whitegrid\")\n",
    "    plt.plot(\n",
    "        avg_response_perc_to_frac_in_cluster.keys(), \n",
    "        avg_response_perc_to_frac_in_cluster.values(),\n",
    "        marker=MARKER,\n",
    "        markersize=MARKERSIZE,\n",
    "        linewidth=LINEWIDTH,\n",
    "        markeredgewidth=MARKEREDGEWIDTH,\n",
    "        markeredgecolor=FACE_COLOR\n",
    "    )\n",
    "    plt.ylim(0, 1)\n",
    "    plt.xlabel(\"Percentage of responses considered\")\n",
    "    plt.ylabel(\"Fraction of responses with same answer as anchor\")\n",
    "    plt.xticks(ticks=[0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "    plt.yticks(ticks=[0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0])\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "        \n",
    "plot_frac(num_files=10, anchor_samples=20, apply_pca=False, sparse_project=False)    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "created random representations\n",
      "standard scaled\n",
      "pcaed\n",
      "converted to torch\n"
     ]
    }
   ],
   "source": [
    "representations = torch.randn(4000, int(4e6)).float().numpy()\n",
    "print('created random representations')\n",
    "representations = StandardScaler().fit_transform(representations)\n",
    "print('standard scaled')\n",
    "representations = PCA(n_components=50).fit_transform(representations)\n",
    "print('pcaed')\n",
    "representations = torch.from_numpy(representations).float()\n",
    "print('converted to torch')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_151179/4095549402.py:5: 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",
      "  representations = torch.load(os.path.join(ROOT, feature_files[0]))[\"gradients_512\"]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjsAAAHHCAYAAABZbpmkAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAR6VJREFUeJzt3XlclOX+//E3DKgoigmYuXvEGRdAcMlUivS4VHrKrazUfpWVqbmlKZYl7pgtbqUeM/O4oWna6ik7pzLT1NPRxCWK3KUEMUXEIzDcvz98MN9GEHEcGLh9PR8PHjnXXHPfn/uaSd5e9zX37WUYhiEAAACT8vZ0AQAAAMWJsAMAAEyNsAMAAEyNsAMAAEyNsAMAAEyNsAMAAEyNsAMAAEyNsAMAAEyNsAMAAEyNsANT69ixo2JiYjxdhum98847+utf/6omTZrogQce8HQ5N5WNGzfqnnvuUbNmzdSqVStPl1OoEydOyGaz6YMPPnC0zZs3TzabzYNV4WZA2EGZ8cEHH8hmsykhIaHA5wcMGKDu3bvf8H6++eYbzZs374a3c7PYunWrZs2apRYtWmjGjBl6/vnnr9o3JiZGkZGRhW5v7969mjx5srp166aIiAjdfffdGjFihA4fPuzu0su8X3/9VePHj1fdunU1ZcoUTZ482dMllUqnTp3SvHnzdPDgQU+XAg/x8XQBQHH65z//KS8vr+t6zTfffKOVK1dq2LBhxVSVuXz//ffy9vbWtGnTVK5cuRve3jvvvKP//ve/uueee2Sz2ZSamqqVK1eqV69eWrNmjaxWqxuqNoedO3cqNzdXL730kurVq+fpclwyePBgPfPMM8W6j5SUFM2fP1+1atVSkyZNinVfKJ0IOzA1d/zyLWmZmZmqWLGip8sosrS0NFWoUMFtY/3444/rtddec9refffdp7/97W/6+9//rtdee80t+7kRubm5ys7OVvny5T1aR1pamiSpcuXKxbqfnJwc5ebmFsv/Tz4+PvLx4VcRihensWBqV67Zyc7O1vz589WlSxeFhYWpTZs2euSRR/Tdd99JunyaZeXKlZIkm83m+MmTmZmpuLg4RUdHKzQ0VF27dtWSJUtkGIbTfv/3v/9p6tSpatOmjSIjI/Xss8/q1KlTstlsTqfI8tYrJCUlafTo0WrdurUeffRRSdJPP/2kmJgY/fWvf1VYWJjat2+v8ePH648//nDaV942Dh8+rDFjxqhly5a64447NHv2bBmGod9++02DBw9WixYt1L59e7377rtFGrucnBy99dZb6tSpk0JDQ9WxY0e98cYbysrKcvTJW3+RmZnpGKs/r8dwRYsWLfL9Uq1fv74aNWqkQ4cOXfP1eafKTp06pSFDhigyMlJ33HGHZs6cKbvd7tS3qO+nzWbT5MmT9dFHH6lbt24KCwvTt99+6zi1+p///EdTp07VHXfcoVatWumVV15RVlaW0tPTNXbsWLVu3VqtW7fWq6++mm/bV7Ny5Up169ZNoaGhioqK0qRJk5Senu54vmPHjo7PUtu2bfN9tgqyadMm3XfffQoLC1P37t21efNmxcTEqGPHjo4+eetqlixZovfee0+dOnVSWFiYfv31V2VlZWnOnDnq1auXWrZsqYiICD366KP6/vvv8+0rPT1dMTExatmypVq1aqVx48bp/Pnz+fpdbc3Ohx9+qF69eik8PFy33367Ro0apd9++82pT96p66SkJA0YMEDNmzfXnXfeqcWLFzv67NixQ3369JEkjR8/Pt/n9MiRIxo2bJjat2+vsLAw3XXXXRo1alSBtaLsIk6jzMnIyNCZM2fytWdnZ1/ztfPnz9eiRYv04IMPKjw8XBkZGdq3b5/279+v9u3bq2/fvkpJSdF3332nV1991em1hmFo8ODBjr88mzRpom+//VavvvqqTp06pRdffNHRNyYmRps2bdIDDzyg5s2ba9euXYVO1Y8YMUL16tXTqFGjHL8Mt23bpuPHj6tXr14KDg7WL7/8orVr1yopKUlr167Nd3pu1KhRatiwoUaPHq1vvvlGCxYsUNWqVRUfH6877rhDY8aM0ccff6yZM2cqLCxMrVu3LnSsJkyYoA0bNqhr16564okntHfvXi1atEi//vqr3nrrLUnSq6++qrVr12rv3r2aOnWqpMthxd0Mw9Dp06fVqFGjIvW32+0aOHCgwsPDNXbsWG3fvl3vvvuu6tSp4wiT1/N+SpdP123atEn9+vXTLbfcolq1ajnCx9SpUxUUFKRhw4bpxx9/1Jo1a1S5cmXt3r1bt912m0aNGqUtW7ZoyZIlslqt6tGjR6H1z5s3T/Pnz1e7du30yCOP6PDhw1q9erUSEhK0evVq+fr66sUXX9TGjRu1efNmxcbGqmLFioUu9P366681atQo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lZWlEydOqF27di5v89ixY/meu57P5eeff646depo/vz5Tv+fzJ0716lfrVq19P333+vChQtOsztFuTBk3bp1ZRiGateuXaSZoKK4VmjP+4bWkCFD9N///lePPPKIVq9erVGjRrll//C8svvPDsAFV57mqlSpkurWrev0dWo/Pz9JcvqaryTdddddstvtjq+m53nvvffk5eWlu+66S5IUFRUlSVq1apVTvxUrVhS5zqv9a3XZsmVF3saNiI6OLnB/S5cudXq+ONjtdo0cOVJ79uzRnDlzrnnFZVcV9f0sae3atZOvr6+WL1/uNAO3bt06nT9/3qWxv/XWW2W1WrVx40ZduHDB0b5z5079/PPPRd5O3ufyz3X9+OOP2rNnj1O/u+66Szk5OVq9erWjzW63F+n/gS5dushisWj+/Pn5ZiANw7jmqeqCXO3/6YyMDOXk5Di1Wa1WeXt7O/2dgLKPmR3cVLp166bbb79dzZo1U9WqVZWQkKDPP//caeFks2bNJF3+OnFUVJQsFou6deumjh07qk2bNnrzzTd18uRJ2Ww2fffdd/rXv/6l//f//p9jPUTe9VqWLVums2fPOr56njcrU5RTQ/7+/mrdurXeeecdZWdn69Zbb9V3333ntMC2ODVu3Fg9e/bUmjVrlJ6ertatWyshIUEbNmxQp06ddMcdd7i87ezsbL399tv52gMCAtSvXz/FxcXp3//+tzp06KCzZ8/qww8/dOrnrntvFfX9LGnVqlXToEGDNH/+fD311FPq2LGjDh8+rFWrViksLEz333+/S9sdNWqUhgwZokceeUS9evVSenq6Vq5cKavV6hSACnP33Xfriy++0NChQ3X33XfrxIkTio+PV0hIiDIzMx39OnbsqBYtWuj111/XyZMnFRISoi+++KJI166pW7euRo4c6Xhtp06dVKlSJZ04cUJffvmlHnroIQ0cOPC6jr1u3bqqUqWK4uPjValSJVWsWFHh4eFKTEzU5MmTdc8996h+/fqy2+368MMPZbFY1LVr1+vaB0o3wg5uKgMGDNC///1vfffdd8rKylLNmjU1cuRIp788u3TpogEDBujTTz/VRx99JMMw1K1bN3l7e2vBggWaO3euPvvsM33wwQeqVauWxo4d6/iWUp6ZM2cqKChIn376qTZv3qx27drpzTff1D333FPkq9C+/vrrmjJlilat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Gj16dL5ZHwAAAE9yW9iRLi9aTklJcecmAQAAbohLp7H+9a9/OT02DEOpqalauXKlWrRo4ZbCbnb2XEMWby9PlwEAQJnnUtgZOnSo02MvLy9Vq1ZNd9xxh8aNG+eWwm52Fm8vjYjfraSUDN1tC9YLXRt7uiQAAMokl8LOTz/95O46UICklAztT05Xw2DuNwYAgKvcumYHAACgtHFpZmfGjBlF7jt+/HhXdgEAAOAWLoWdAwcO6ODBg8rJyVGDBg0kXb7Ojre3t5o2bero5+XFAlsAAOBZLoWdjh07qlKlSpo5c6YCAgIkSefOndP48ePVqlUrPfnkk24tEgAAwFUurdl59913NXr0aEfQkaSAgACNHDlS7777rtuKAwAAuFEuhZ2MjAydOXMmX/uZM2d04cKFGy4KAADAXVwKO507d9b48eP1xRdf6Pfff9fvv/+uzz//XC+99JK6dOni7hoBAABc5tKanUmTJmnmzJkaPXq0cnJyJEkWi0V9+vTR2LFj3VogAADAjXAp7Pj5+Sk2NlZjx47VsWPHJEl169ZVxYoV3VocAADAjbqhiwqmpqYqNTVV9evXV8WKFWUYhrvqAgAAcAuXZnb++OMPjRw5Ujt27JCXl5e++OIL1alTRy+++KICAgIUExPj7joBAABc4tLMzowZM+Tj46Ovv/5aFSpUcLTfd999+vbbb91WHAAAwI1yaWbnu+++05IlS1SjRg2n9vr16ys5OdkthQEAALiDSzM7mZmZTjM6ec6ePaty5crdcFEAAADu4lLYadWqlTZu3OjUlpubq3feeUdt2rRxR10AAABu4dJprBdeeEGPP/649u3bp+zsbM2aNUtJSUk6d+6cVq9e7e4aAQAAXOZS2LFarfr888+1YsUKVapUSZmZmercubP69eun6tWru7tGAAAAl1132MnOztZTTz2lSZMmafDgwcVREwAAgNtc95odX19fJSYmFkctAAAAbufSAuX7779f69atc3ctAAAAbufSmh273a7Vq1dr27ZtCg0NlZ+fn9Pz48ePd0txAAAAN+q6ws7x48dVq1Yt/fzzz2ratKkk6fDhw059vLy83FcdAADADbqusNOlSxdt3bpVy5cvlySNHDlSEyZMUFBQULEUBwAAcKOua83OlXc137Jliy5evOjWggAAANzJpQXKea4MPwAAAKXNdYUdLy8v1uQA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YHYpKSlKSUnRuHHjFBISopMnTyo2NlYpKSmaO3duidaSlZWlcuXKldj+8m5C26JFC7du153HUa5cOW6jABQzZnYAk7NarZo3b546duyounXrqm3btho5cqT+/e9/Kycn56qv69ixoxYuXKjx48crMjJSd999t9asWePUJzExUY899pjCw8PVpk0bvfzyy7pw4YLj+bwZpwULFigqKkr33HOPY9bhs88+06OPPqrw8HD17t1bhw8f1t69e9WrVy9FRkbqqaee0pkzZwo9tp07d6pPnz4KDQ1VVFSUXnvtNccxxcTEaMqUKUpOTpbNZlPHjh2vup21a9cqOjpazZs319ChQ7V06VK1atXK8fy8efP0wAMP6P3331fHjh0VHh4u6fLM0SOPPKJWrVqpTZs2GjRokNNNRyVp79696tGjh8LCwtSrV698sy0Fncb6z3/+4xib6OhoTZ06VZmZmUV+b/76179Kknr06CGbzaYBAwY49tWnTx9FRESoVatWevjhh3Xy5MlCxxgwA8IOcBPKyMiQv7+/fHwKn9xdunSpQkNDtXHjRj366KOKjY3VoUOHJEmZmZkaOHCgAgICtG7dOs2ePVvbtm3TlClTnLaxfft2HT58WEuXLtWiRYsc7fPmzdPgwYO1YcMG+fj4aPTo0Zo1a5ZeeuklrVy5UseOHdOcOXOuWtupU6f0zDPPKCwsTB9++KFiY2O1bt06LViwQJL00ksvafjw4apRo4a2bt2qdevWFbidH374QRMnTtRjjz2mjRs3ql27dlq4cGG+fseOHdPnn3+u+fPna+PGjZKkixcv6oknntD69ev13nvvycvLS0OHDlVubq6ky3dcHzRokBo2bKgPPvhAw4YN08yZMwsd82PHjunpp59Wly5d9NFHH+nNN9/UDz/8kG9cC3tv3n//fUnSe++9p61bt2revHnKycnR0KFD1bp1a3300Udas2aN+vbtKy8vr0LrAUzBAFDmjRs3zhg8eHCR+qalpRl333238cYbbxTar0OHDsaYMWMcj3Nzc422bdsaq1atMgzDMNasWWO0bt3auHDhgqPP119/bTRu3NhITU111NWuXTvj0qVLjj7Hjx83rFarsXbtWkfbJ598YlitVmPbtm2OtkWLFhldu3a9an1vvPGG0bVrVyM3N9fRtmLFCiMiIsKw2+2GYRjG0qVLjQ4dOhR6nCNHjjSeeeYZp7bRo0cbLVu2dDyeO3eu0axZMyMtLa3QbaWlpRlWq9VITEw0DMMw4uPjjdtvv9343//+5+izatUqw2q1GgcOHDAMwzC+//57w2q1GufOnTMMwzBefPFF4+WXX3ba7q5du4zGjRs7tnOt9yZvjPP2YRiG8ccffxhWq9XYsWNHoccAmBFrdoCbSEZGhmOm4bnnnrtmf5vN5vizl5eXgoKClJaWJkn69ddfZbPZVLFiRUefFi1aKDc3V4cPH1ZQUJCky6fRClrf8udtBwYGFthW2GmsX3/9VZGRkU4zEy1btlRmZqZ+//131axZ85rHJ0mHDx9Wp06dnNrCw8P19ddfO7XVrFlT1apVc2o7cuSI5s6dqx9//FF//PGHDMOQJP3222+yWq2OMSpfvrzjNZGRkYXW89NPPykxMVEff/yxo80wDOXm5urEiRNq2LChpMLfm4JUrVpVvXr10sCBA9W+fXu1bdtW9957r6pXr15oPYAZEHaAm0RGRoaeeuopVapUSW+99ZZ8fX2v+ZorT3N5eXk5fqEXlZ+fX4Htf95/XmD58/68vLwcp4NKg4KO49lnn1WtWrU0depUVa9eXbm5uerevbuys7Nd3k9mZqYefvhhxzqbP7vtttscf3blvZkxY4YGDBigb7/9Vps2bdLs2bO1dOlSRUREuFwvUBawZge4CWRkZGjgwIHy9fXVggULnGYaXNWwYUMlJiY6LZz973//K29vbzVo0OCGt1+U/e/evdvpF/wPP/ygSpUqqUaNGkXeToMGDbRv3z6ntoSEhGu+7o8//tDhw4c1ePBgtW3bVg0bNtS5c+fy1ZiYmKhLly452vbs2VPodps2baqkpCTVq1cv309RvwGWFyTtdnuB2x80aJDi4+NltVr1ySefFGmbQFlG2AFM4vz58zp48KDTz2+//aaMjAw9+eSTyszM1LRp05SRkaHU1FSlpqYW+MuwqP72t7+pXLlyiomJ0c8//6zvv/9eU6ZM0QMPPOA4hVWcHn30Uf3++++aMmWKfv31V3355ZeaN2+ennjiCXl7F/2vtv79++ubb77R0qVLdeTIEcXHx2vLli3XXLgbEBCgqlWras2aNTp69Ki2b9+uuLg4pz7du3eXl5eXJkyYoKSkJH3zzTd69913C93u008/rd27d2vy5Mk6ePCgjhw5oi+//FKTJ08u8jEFBgaqQoUK+vbbb3X69GmdP39ex48f1+uvv67du3fr5MmT2rp1q44cOaK//OUvRd4uUFZxGgswiZ07d6pHjx5ObX369NH999+vH3/8UZLUuXNnp+f/9a9/qXbt2i7tz8/PT0uWLNG0adPUp08f+fn5qUuXLoqJiXFpe9fr1ltv1d///ne9+uqrWrt2rapWrao+ffpo8ODB17Wdli1batKkSZo/f75mz56tqKgoPf7441q5cmWhr/P29tabb76pqVOnqnv37mrQoIEmTJjgdPqpUqVKWrhwoSZOnKgePXooJCREY8aM0bBhw6663caNG2v58uWaPXu2Hn30UUlSnTp1dN999xX5mHx8fDRhwgS99dZbmjt3rlq1aqU333xThw4d0oYNG3T27FlVr15d/fr108MPP1zk7QJllZdxvSfgAcDkJkyYoEOHDmnVqlWeLgWAG3AaC8BNb8mSJfrpp5909OhRLV++XBs3blTPnj09XRYAN2FmB8BNb8SIEdq5c6cuXLigOnXqqH///nrkkUc8XRYANyHsAAAAU+M0FgAAMDXCDgAAMDXCDgAAMDXCDgAAMDXCDgAAMDXCDgAAMDXCDgAAMDXCDgAAMDXCDgAAMLX/D5KOhbW/hA8PAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot histogram of the norm of the gradients\n",
    "all_files = os.listdir(ROOT)\n",
    "file_idx = 44\n",
    "feature_files = [f for f in all_files if f.endswith(\"--llama-3-3b-gradients.tar\")][file_idx:file_idx+1]\n",
    "representations = torch.load(os.path.join(ROOT, feature_files[0]))[\"gradients_512\"]\n",
    "\n",
    "# plot histogram of the norm of the gradients\n",
    "plt.hist(torch.norm(representations, dim=1), bins=100)\n",
    "plt.xlabel(\"L2 norm of gradients\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "plt.title(\"Histogram of L2 norm of gradients\")\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[-0.0334, -0.1110, -0.0058,  ..., -0.3470,  0.1590, -0.2233],\n",
       "        [ 0.1235, -0.0199,  0.0175,  ...,  0.0035, -0.0585, -0.3030],\n",
       "        [ 0.0133, -0.0781, -0.0722,  ...,  0.0298, -0.0898, -0.0696],\n",
       "        ...,\n",
       "        [-0.0624, -0.0996,  0.0862,  ...,  0.2445, -0.1832, -0.0821],\n",
       "        [ 0.2281, -0.2029,  0.0960,  ...,  0.0606, -0.0844, -0.0597],\n",
       "        [ 0.0451,  0.0798,  0.1573,  ..., -0.0579, -0.0026, -0.1629]])"
      ]
     },
     "execution_count": 124,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "representations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llm-exploration",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
