{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1b0ed16b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAADBCAYAAABv9tKnAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAg+ZJREFUeJzsnXd4VUXawH+319yb3hshdCmhioKCoCIoKEUpCvay9rWsn93V1VXXXevqqigWQLBgBRUVEAXpvSdAei839+b2e+b748qVmAQSCCSE83uePHDnzJnzvmfOzHnPzDvvKIQQAhkZGRkZGRmZk4SyrQWQkZGRkZGROb2QjQ8ZGRkZGRmZk4psfMjIyMjIyMicVGTjQ0ZGRkZGRuakIhsfMjIyMjIyMicV2fiQkZGRkZGROanIxoeMjIyMjIzMSUU2PmRkZGRkZGROKrLxISMjIyMjI3NSkY0PGQAef/xxoqOjmzy+fPlyFAoF27dvP4lSHT8HDhxAoVCQmpqKHMz31EGhUDT6l5mZ2SbyHK19HCvtuV3dcccdXHPNNaHfV199NQMHDmxDiY6NTz75hG7duhEIBNpaFJnDULe1ADKnBv3792f16tV07ty5rUVpER999BEA+fn5/PLLLwwfPryNJZJpLvfccw+TJ0+ul6bX69tImtOL/Px83nrrLTZt2tTWohw3EydO5MEHH+SDDz7g6quvbmtxZH5HNj5kmoXFYuHMM89sazHq4XK5MBgMR8wzf/58zjzzTLZt28b8+fPbjfHRHNk7Oke7B+np6e3umTtdeOONN+jfvz/du3dva1GOG6VSycyZM3nllVdk46MdIU+7yDSLxoaHFQoFL730Eg8++CAxMTHExsZy66234vF46p2bl5fH1KlTiYyMxGg0cuGFF7Jnz556eR544AF69+6N2WwmOTmZGTNmUFJSUi9Peno699xzD08++STJyclYLJYjyrxjxw62bdvGNddcw/jx4/n444/x+/0N8r311lv07t0bvV5PXFwckydPxmazhY7//PPPjBw5ErPZjNVqZcSIEaEvwqaG4xUKBa+++upRZV+9ejXjx48nISEBk8lEv379mDt3boPycnNzmTZtGtHR0RiNRvr06cO8efMAGDx4cKOd6tVXX01WVtYR79FPP/3EkCFDQrr/5S9/weFwAFBXV4fJZOK1115rcN6gQYO48sorQ7+PVscHDx5EoVAwd+5cZs6cSXh4OJdccskRZTsah6YBPv/8c7p3745er2fYsGHs3LmzXj6n08kdd9xBfHw8er2eQYMG8f333zcob9GiRQwePBiDwUBUVBRjx44lNze3Xp5NmzZx5plnYjQaycrKYuXKlfWOf/nllwwYMACTyURERARDhgxhxYoVR9WlqKiIiy++GJPJRGpqKm+88Ubo2OLFi1EqlRw4cKDeOQcOHECpVPLFF180We6fn8OHHnqIyMhItmzZckR53n///QajTn/G6/UyceJEUlNTyc7OBprfju+9916efPJJ4uPjMZvNzJgxo16bO9TffP/9903eF2h++5k0aRIbN25kx44dR9RJ5uQhGx8yx8ULL7xAUVERH374Iffddx//+9//eOmll0LHq6qqGDZsGHv27OGNN95g4cKF1NXVMXr0aFwuVyhfWVkZDz74IN988w0vvvgi+/fv57zzzkOSpHrXmzdvHitWrOC///0vCxYsOKJs8+fPR6PRMGnSJKZNm0ZFRQU//PBDvTxPPfUUN910E+eeey6ff/45r7/+OlarNfQCXr58OaNGjUKj0fDee++xYMEChg8fTmFhYYvvVWOy5+bmcvbZZzN79my++uorJk2axDXXXMP8+fPr3ZuhQ4eybt06/vWvf/HVV19x3XXXkZ+fD8B1113HJ598EpIZwOFw8Mknn3Dttdc2Kc+OHTsYM2YM0dHRfPrppzzxxBPMmzcv9NIxmUxcfPHFLFy4sN55+/fvZ/369UydOhVofh0D3HvvvYSFhfHxxx/z4IMPHvF+SZKE3++v9/fn5yE3N5e//vWvPPLII8ybNw+bzcaFF16I2+0O5bnhhht49913eeihh1i0aBEpKSmMGzeOX375JZTngw8+YOLEiXTu3JmFCxfy7rvv0rVrV8rLy0N5nE4ns2bN4qabbuLTTz9Fp9MxceJEnE4nADk5OUyePJnzzjuPr776irlz53LxxRdTVVV1RD0hWId9+vThs88+Y+zYsdxyyy18/fXXAFx44YUkJiby3nvv1Ttnzpw5xMbGMm7cuKOWD/Dss8/y8ssvs2TJEvr27dtkvj179lBQUMBZZ53VZB63281ll13Gli1bWLlyZcgXp7nteP78+fzwww+89dZb/Pvf/+abb77h+uuvb9F9gea1H4AePXoQERHRoP3LtCFC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vsFutzN06FAMBkMDR75DmEwmhgwZwvvvv99kgLLk5GTsdns9B9TGVlI0hsfjQZKkel+ZdrudL7/8sl6+UaNG8d1331FaWnrE8q699lree+893n//fWbOnFlvOqUxhgwZwqJFi+oFX/rss8/w+/0MGzYslHbBBRcQHh7OwoULWbBgAZMnT65XdnPq+ERRVlbGqlWrQr/z8vLYuHEjgwcPBoKrchQKBZ988kkojxCCTz75JKRjt27dSEpKavI5OBasVivTp0/nsssua7D6pjEWLVrU4PeAAQPq3eeJEyei1WqZOnUqkiTVG306EpGRkWg0Gt555x3WrFlTzyG8Mbp164YQoknD4aqrruLVV1/ltttu48MPPwylt6QdL126tJ6D9KJFi1AoFA2CmB3pvjS3/Rzi4MGDdO3atQmtZU428siHTAiv11uvkz7Eueeee8xl/vWvf+XDDz/kvPPO4/bbbycpKYnS0lJWrFjBsGHDmDZtGueffz4vvvgid911F5dccgmrVq2q16m1lPnz5xMeHs6dd97ZYPjYYrHw/vvvs2jRImbOnMkjjzzCQw89hNfrZezYsXg8Hr755hsee+wxkpKS+Oc//8no0aO56KKLuPHGGzGZTKxevZqBAwdy8cUXM2bMGAwGA9deey333HMPBw4caLAcsCmsViuDBg3i73//OxaLBaVSyT//+U+sViu1tbWhfHfffTfvv/8+w4cP56GHHiIlJYVdu3ZRV1fH/fffH8o3a9YsHn74Yfx+f7N8AR5++GGysrK49NJLueWWWygoKOBvf/sbF154IUOHDg3l02g0TJw4kX//+98UFxfz3//+t145zanjY+HgwYOhYftDKBQKhgwZEvodHR3NlVdeyVNPPYXBYOCxxx4jNjY2tPS4R48eTJs2jdtuuw273U7nzp1566232L17N6+//joQ9AF57rnnmDFjBjNmzGDatGkoFAp++uknpk2b1uyonv/73/9YvXo1Y8aMITExkX379vHxxx8zc+bMo567ZMkSHnroIc4991w+++wzli5d2mAJrV6vZ8aMGbz22mtMmzatwZTn0ejfvz/33nsvDz30EBdffDFdunRpNN/gwYNRq9Vs2LCBTp06NZrnlltuweFwcM0112A2m7n00ktb1I4NBgPjxo3jvvvuo7i4mPvuu4/LLrss5EfTnPvS3PYDQV+V3bt3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dib+dxVr9lcye9YgxvVJYN4NZ2IxaDircxSXD0xpa5FlZNodX3/9NZMmTeKLL76gT58+TeabOXMmH3zwQej3Bx98wFVX/fEhdM0112C1WtFoNNx3331IksTWrVtbLM/69evZt28fzz//PEajkaioKB588EHmzZsHgEajobKykn379qFSqejXrx+RkZEtvo6MTHNptaW2y5cvrzfE1x442hLbnJoc1peu57lznvsjMeCDnV9C/5mn3TTLj7tKeXDRNsrtHiQBnWNMFNa4SAo38NlfzqJXohWAeKue7+46B2g6aqiMzOnM0qVL6d27N/PmzWt01OMQ48eP58Ybb2Tt2rVkZGTw7bff8tJLLwHBFV6PPPIICxcupLS0FKVSSW1tLRUVFS2W5+DBg9TU1NQzKIQQob2G7rvvPtxuN5dffjk2m40rrriCf/7znxgMhhZfS0amORzXmHhxcTFz5szhnXfeoaioiLq6utaS66SwYM8CIvWRjE4d/UfigRXgqoIzJradYCcYlzfAr9kV5FY5Ka11k1PmYGdxLcU2NyO6xbDoL705WFnHvDV5jOwWyz0XdKs3nQI0a7M1GZnTlRdeeIH+/fuTlZXFhRde2OSHmV6vZ8qUKXzwwQd069aNIUOGkJ6eDsC8efOYN28e3333HV26dEGhUBAREYEQotGyTCZTvf2DiouLQ/9PSUkhNja2XtrhmM1mnn32WZ599lkOHDjAJZdcwn//+1/uueeeY7sBMjJHocXGRyAQ4KuvvmL27Nl8++23SJLEww8/fEoEHTscp8/JlzlfMr37dDSqP0J7s2MRRHaG+KaHSk8VfAGJr7cW8fbKA9Q4ffRICEOnUbFsdxlObwC9Rkm8RU9alIkJ/ZIYlB7Bed1jUSgUJIYbOKtzI/FOZGRkjoparSYjI4P//Oc/XH311WzYsIG4uMb9xmbOnMnEiRNJTU2tt01FbW0tWq2W6OhovF4vzz777BH9Pfr3788HH3zA4MGD2b59Ox988AFduwankwcNGkRKSgoPP/wwf/vb3zCbzeTl5bFz504uuugivv76a7p27UpmZiYWiwWNRoNaLftryZw4mv35umfPHu6//36SkpK46qqriIiIYMmSJcTExHDrrbcSFXVsgbe+/PJL+vXrh8lkIjExkTfeeAMINrzp06djsViIi4vjySefPKbym+Lr/V/j8ruY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",
      "text/plain": [
       "<Figure size 550x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Load\n",
    "df = pd.read_csv('kappa.csv')\n",
    "\n",
    "plt.rcParams.update({'font.size': 9})\n",
    "\n",
    "# Map kappa variants to the corresponding lin_top1 columns (use only the val metrics)\n",
    "kappa_map = {\n",
    "    r\"k = 0.1\": \"shannon_hypersphere_k1e-1_stl10_resnet18 - val_metrics/lin_top1\",\n",
    "    r\"k = ln 2\": \"shannon_hypersphere_klog2_stl10_resnet18 - val_metrics/lin_top1\",\n",
    "    r\"k = 1\":    \"shannon_hypersphere_k1_stl10_resnet18 - val_metrics/lin_top1\",\n",
    "    r\"k = 10\":   \"shannon_hypersphere_k10_stl10_resnet18 - val_metrics/lin_top1\",\n",
    "    r\"k = 20\":   \"shannon_hypersphere_k20_stl10_resnet18 - val_metrics/lin_top1\",\n",
    "}\n",
    "\n",
    "# X-axis: use 'epoch' column if present, else row index\n",
    "x = df['epoch'] if 'epoch' in df.columns else range(len(df))\n",
    "\n",
    "# Keep only series that exist in the CSV, preserving the order above\n",
    "series = [(label, col) for label, col in kappa_map.items() if col in df.columns]\n",
    "\n",
    "# Plot: one line per kappa\n",
    "plt.figure(figsize=(5.5, 2))\n",
    "for label, col in series:\n",
    "    plt.plot(x, df[col] * 100.0, label=label, linewidth=1)\n",
    "\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Linear Accuracy')\n",
    "plt.title('Linear Accuracy over Epochs by κ (kappa)')\n",
    "plt.legend(title='κ values', ncol=3)\n",
    "plt.xlim(0, 200)\n",
    "plt.ylim(40, 85)\n",
    "plt.grid(True, alpha=0.3)\n",
    "plt.tight_layout()\n",
    "plt.savefig('kappa.pdf', bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b0ae66ea",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'dimensions.csv'",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mFileNotFoundError\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[9]\u001b[39m\u001b[32m, line 7\u001b[39m\n\u001b[32m      4\u001b[39m \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34;01mmatplotlib\u001b[39;00m\u001b[34;01m.\u001b[39;00m\u001b[34;01mgridspec\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mimport\u001b[39;00m GridSpec\n\u001b[32m      6\u001b[39m \u001b[38;5;66;03m# ---- Load & config\u001b[39;00m\n\u001b[32m----> \u001b[39m\u001b[32m7\u001b[39m df = \u001b[43mpd\u001b[49m\u001b[43m.\u001b[49m\u001b[43mread_csv\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43mdimensions.csv\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[32m      8\u001b[39m plt.rcParams.update({\u001b[33m'\u001b[39m\u001b[33mfont.size\u001b[39m\u001b[33m'\u001b[39m: \u001b[32m9\u001b[39m})\n\u001b[32m     10\u001b[39m dim_map = {\n\u001b[32m     11\u001b[39m     \u001b[33m\"\u001b[39m\u001b[33mshannon_hypersphere_k1_dim4096_stl10_resnet18 - val_metrics/lin_top1\u001b[39m\u001b[33m\"\u001b[39m: \u001b[33m\"\u001b[39m\u001b[33m4096\u001b[39m\u001b[33m\"\u001b[39m,\n\u001b[32m     12\u001b[39m     \u001b[33m\"\u001b[39m\u001b[33mshannon_hypersphere_k1_dim2048_stl10_resnet18 - val_metrics/lin_top1\u001b[39m\u001b[33m\"\u001b[39m: \u001b[33m\"\u001b[39m\u001b[33m2048\u001b[39m\u001b[33m\"\u001b[39m,\n\u001b[32m   (...)\u001b[39m\u001b[32m     16\u001b[39m     \u001b[33m\"\u001b[39m\u001b[33mshannon_hypersphere_k1_stl10_resnet18 - val_metrics/lin_top1\u001b[39m\u001b[33m\"\u001b[39m: \u001b[33m\"\u001b[39m\u001b[33m1024\u001b[39m\u001b[33m\"\u001b[39m,\n\u001b[32m     17\u001b[39m }\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/src/simdex/venv/lib/python3.12/site-packages/pandas/io/parsers/readers.py:1026\u001b[39m, in \u001b[36mread_csv\u001b[39m\u001b[34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, date_format, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options, dtype_backend)\u001b[39m\n\u001b[32m   1013\u001b[39m kwds_defaults = _refine_defaults_read(\n\u001b[32m   1014\u001b[39m     dialect,\n\u001b[32m   1015\u001b[39m     delimiter,\n\u001b[32m   (...)\u001b[39m\u001b[32m   1022\u001b[39m     dtype_backend=dtype_backend,\n\u001b[32m   1023\u001b[39m )\n\u001b[32m   1024\u001b[39m kwds.update(kwds_defaults)\n\u001b[32m-> \u001b[39m\u001b[32m1026\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_read\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfilepath_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkwds\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/src/simdex/venv/lib/python3.12/site-packages/pandas/io/parsers/readers.py:620\u001b[39m, in \u001b[36m_read\u001b[39m\u001b[34m(filepath_or_buffer, kwds)\u001b[39m\n\u001b[32m    617\u001b[39m _validate_names(kwds.get(\u001b[33m\"\u001b[39m\u001b[33mnames\u001b[39m\u001b[33m\"\u001b[39m, \u001b[38;5;28;01mNone\u001b[39;00m))\n\u001b[32m    619\u001b[39m \u001b[38;5;66;03m# Create the parser.\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m620\u001b[39m parser = \u001b[43mTextFileReader\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfilepath_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwds\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    622\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m chunksize \u001b[38;5;129;01mor\u001b[39;00m iterator:\n\u001b[32m    623\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m parser\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/src/simdex/venv/lib/python3.12/site-packages/pandas/io/parsers/readers.py:1620\u001b[39m, in \u001b[36mTextFileReader.__init__\u001b[39m\u001b[34m(self, f, engine, **kwds)\u001b[39m\n\u001b[32m   1617\u001b[39m     \u001b[38;5;28mself\u001b[39m.options[\u001b[33m\"\u001b[39m\u001b[33mhas_index_names\u001b[39m\u001b[33m\"\u001b[39m] = kwds[\u001b[33m\"\u001b[39m\u001b[33mhas_index_names\u001b[39m\u001b[33m\"\u001b[39m]\n\u001b[32m   1619\u001b[39m \u001b[38;5;28mself\u001b[39m.handles: IOHandles | \u001b[38;5;28;01mNone\u001b[39;00m = \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[32m-> \u001b[39m\u001b[32m1620\u001b[39m \u001b[38;5;28mself\u001b[39m._engine = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_make_engine\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mengine\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/src/simdex/venv/lib/python3.12/site-packages/pandas/io/parsers/readers.py:1880\u001b[39m, in \u001b[36mTextFileReader._make_engine\u001b[39m\u001b[34m(self, f, engine)\u001b[39m\n\u001b[32m   1878\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[33m\"\u001b[39m\u001b[33mb\u001b[39m\u001b[33m\"\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m mode:\n\u001b[32m   1879\u001b[39m         mode += \u001b[33m\"\u001b[39m\u001b[33mb\u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m-> \u001b[39m\u001b[32m1880\u001b[39m \u001b[38;5;28mself\u001b[39m.handles = \u001b[43mget_handle\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m   1881\u001b[39m \u001b[43m    \u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1882\u001b[39m \u001b[43m    \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1883\u001b[39m \u001b[43m    \u001b[49m\u001b[43mencoding\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mencoding\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1884\u001b[39m \u001b[43m    \u001b[49m\u001b[43mcompression\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mcompression\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1885\u001b[39m \u001b[43m    \u001b[49m\u001b[43mmemory_map\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mmemory_map\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1886\u001b[39m \u001b[43m    \u001b[49m\u001b[43mis_text\u001b[49m\u001b[43m=\u001b[49m\u001b[43mis_text\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1887\u001b[39m \u001b[43m    \u001b[49m\u001b[43merrors\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mencoding_errors\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mstrict\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1888\u001b[39m \u001b[43m    \u001b[49m\u001b[43mstorage_options\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mstorage_options\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1889\u001b[39m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1890\u001b[39m \u001b[38;5;28;01massert\u001b[39;00m \u001b[38;5;28mself\u001b[39m.handles \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[32m   1891\u001b[39m f = \u001b[38;5;28mself\u001b[39m.handles.handle\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/src/simdex/venv/lib/python3.12/site-packages/pandas/io/common.py:873\u001b[39m, in \u001b[36mget_handle\u001b[39m\u001b[34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[39m\n\u001b[32m    868\u001b[39m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(handle, \u001b[38;5;28mstr\u001b[39m):\n\u001b[32m    869\u001b[39m     \u001b[38;5;66;03m# Check whether the filename is to be opened in binary mode.\u001b[39;00m\n\u001b[32m    870\u001b[39m     \u001b[38;5;66;03m# Binary mode does not support 'encoding' and 'newline'.\u001b[39;00m\n\u001b[32m    871\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m ioargs.encoding \u001b[38;5;129;01mand\u001b[39;00m \u001b[33m\"\u001b[39m\u001b[33mb\u001b[39m\u001b[33m\"\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m ioargs.mode:\n\u001b[32m    872\u001b[39m         \u001b[38;5;66;03m# Encoding\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m873\u001b[39m         handle = \u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\n\u001b[32m    874\u001b[39m \u001b[43m            \u001b[49m\u001b[43mhandle\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    875\u001b[39m \u001b[43m            \u001b[49m\u001b[43mioargs\u001b[49m\u001b[43m.\u001b[49m\u001b[43mmode\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    876\u001b[39m \u001b[43m            \u001b[49m\u001b[43mencoding\u001b[49m\u001b[43m=\u001b[49m\u001b[43mioargs\u001b[49m\u001b[43m.\u001b[49m\u001b[43mencoding\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    877\u001b[39m \u001b[43m            \u001b[49m\u001b[43merrors\u001b[49m\u001b[43m=\u001b[49m\u001b[43merrors\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    878\u001b[39m \u001b[43m            \u001b[49m\u001b[43mnewline\u001b[49m\u001b[43m=\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[32m    879\u001b[39m \u001b[43m        \u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    880\u001b[39m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m    881\u001b[39m         \u001b[38;5;66;03m# Binary mode\u001b[39;00m\n\u001b[32m    882\u001b[39m         handle = \u001b[38;5;28mopen\u001b[39m(handle, ioargs.mode)\n",
      "\u001b[31mFileNotFoundError\u001b[39m: [Errno 2] No such file or directory: 'dimensions.csv'"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import PercentFormatter\n",
    "from matplotlib.gridspec import GridSpec\n",
    "\n",
    "# ---- Load & config\n",
    "df = pd.read_csv('dimensions.csv')\n",
    "plt.rcParams.update({'font.size': 9})\n",
    "\n",
    "dim_map = {\n",
    "    \"shannon_hypersphere_k1_dim4096_stl10_resnet18 - val_metrics/lin_top1\": \"4096\",\n",
    "    \"shannon_hypersphere_k1_dim2048_stl10_resnet18 - val_metrics/lin_top1\": \"2048\",\n",
    "    \"shannon_hypersphere_k1_dim512_stl10_resnet18 - val_metrics/lin_top1\": \"512\",\n",
    "    \"shannon_hypersphere_k1_dim256_stl10_resnet18 - val_metrics/lin_top1\": \"256\",\n",
    "    \"shannon_hypersphere_k1_dim128_stl10_resnet18 - val_metrics/lin_top1\": \"128\",\n",
    "    \"shannon_hypersphere_k1_stl10_resnet18 - val_metrics/lin_top1\": \"1024\",\n",
    "}\n",
    "\n",
    "x = df['epoch'] if 'epoch' in df.columns else range(len(df))\n",
    "\n",
    "series = []\n",
    "for col, label in dim_map.items():\n",
    "    if col in df.columns:\n",
    "        series.append((int(label), col, label))\n",
    "series.sort(key=lambda t: t[0])\n",
    "\n",
    "# ---- Figure with broken y-axis (top=zoomed high range, bottom=low range)\n",
    "fig = plt.figure(figsize=(9, 5))\n",
    "gs = GridSpec(2, 1, height_ratios=[2, 1], hspace=0.05)  # more space for top (75-100)\n",
    "ax_high = fig.add_subplot(gs[0])\n",
    "ax_low  = fig.add_subplot(gs[1], sharex=ax_high)\n",
    "\n",
    "for _, col, label in series:\n",
    "    y = df[col] * 100.0  # convert to %\n",
    "    ax_high.plot(x, y, label=label, linewidth=1)\n",
    "    ax_low.plot(x, y, linewidth=1)\n",
    "\n",
    "# ---- Axes formatting\n",
    "for ax in (ax_high, ax_low):\n",
    "    ax.yaxis.set_major_formatter(PercentFormatter(xmax=100))\n",
    "    ax.grid(True, alpha=0.3)\n",
    "    ax.set_xlim(0, 200)\n",
    "\n",
    "ax_high.set_ylim(75, 100)  # zoomed part\n",
    "ax_low.set_ylim(0, 75)     # compressed part\n",
    "\n",
    "# Hide x tick labels on top plot\n",
    "plt.setp(ax_high.get_xticklabels(), visible=False)\n",
    "\n",
    "ax_low.set_xlabel('Epoch')\n",
    "ax_high.set_ylabel('lin_top1')\n",
    "ax_low.set_ylabel('lin_top1')\n",
    "\n",
    "fig.suptitle('lin_top1 over epochs by representation dimension')\n",
    "\n",
    "# One legend (top panel)\n",
    "ax_high.legend(title='Dim', ncol=3, fontsize=9, title_fontsize=9, frameon=True)\n",
    "\n",
    "# ---- Diagonal break marks\n",
    "d = 0.015  # size of diagonal lines in axes coords\n",
    "kwargs = dict(transform=ax_high.transAxes, color='k', clip_on=False, linewidth=0.8)\n",
    "ax_high.plot((-d, +d), (-d, +d), **kwargs)         # left diagonal on bottom of top axes\n",
    "ax_high.plot((1 - d, 1 + d), (-d, +d), **kwargs)   # right diagonal\n",
    "\n",
    "kwargs = dict(transform=ax_low.transAxes, color='k', clip_on=False, linewidth=0.8)\n",
    "ax_low.plot((-d, +d), (1 - d, 1 + d), **kwargs)    # left diagonal on top of bottom axes\n",
    "ax_low.plot((1 - d, 1 + d), (1 - d, 1 + d), **kwargs)  # right diagonal\n",
    "\n",
    "plt.tight_layout(rect=[0, 0, 1, 0.96])  # leave room for suptitle\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv (3.12.3)",
   "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
