{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "111e7f74",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "from pathlib import Path\n",
    "import pandas as pd\n",
    "from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "import collections\n",
    "import math\n",
    "\n",
    "def matches(config, filters):\n",
    "    for key, pred in filters.items():\n",
    "        if callable(pred) and not pred(config.get(key)):\n",
    "            return False\n",
    "        if not callable(pred) and config.get(key) != pred:\n",
    "            return False\n",
    "    return True\n",
    "\n",
    "def load(filters):\n",
    "    runs = []\n",
    "    for folder in PATH.iterdir():\n",
    "        if not folder.is_dir():\n",
    "            continue\n",
    "        try:\n",
    "            with open(folder / \"config.json\") as f:\n",
    "                test_config = {\"name\": folder.stem, **json.load(f)}\n",
    "                if matches(test_config, filters):\n",
    "                    runs.append(test_config)\n",
    "        except FileNotFoundError as ex:\n",
    "            pass\n",
    "        except json.JSONDecodeError as ex:\n",
    "            print(\"Error loading\", folder, ex)\n",
    "\n",
    "    logs = []\n",
    "    actual_runs = []\n",
    "    for r in runs:\n",
    "        folder = r[\"name\"]\n",
    "        try:\n",
    "            log = pd.read_csv(PATH / folder / \"log\")\n",
    "        except Exception as ex:\n",
    "            print(r[\"name\"], ex)\n",
    "            continue\n",
    "        logs.append(log)\n",
    "        actual_runs.append(r)\n",
    "    \n",
    "    return actual_runs, logs\n",
    "\n",
    "def aggregate(runs, logs, metric_fn, groupby, extra_agg={}, diff=\"seed\"):\n",
    "    new_runs = []\n",
    "    for run, log in zip(runs, logs):\n",
    "        if log is None: continue\n",
    "        m = metric_fn(run, log)\n",
    "        if m is None: continue\n",
    "        new_run = {**run, **m}\n",
    "        new_runs.append(new_run)\n",
    "    \n",
    "    \n",
    "\n",
    "    means = {k+\"_mean\":(k, np.mean) for k in m}\n",
    "    stds = {k+\"_std\":(k, np.std) for k in m}\n",
    "    seeds = {\n",
    "        \"count\": (diff, len),\n",
    "        f\"{diff}s\": (diff, lambda x: ' '.join(map(str, sorted(x.values)))),\n",
    "    }\n",
    "    df = pd.DataFrame(new_runs)\n",
    "    df = df.drop_duplicates(groupby + [diff])\n",
    "    return df, df.groupby(groupby, group_keys=True).agg(\n",
    "        **means, **stds, **seeds, **extra_agg,\n",
    "    )\n",
    "\n",
    "def summary(runs, sort=[]):\n",
    "    table = pd.DataFrame(runs).sort_values(by=sort)\n",
    "    nunique = table.nunique()\n",
    "    cols_to_drop = nunique[nunique <= 1].index\n",
    "    table = table.drop(cols_to_drop, axis=1)\n",
    "    return table\n",
    "\n",
    "PATH = Path(\"/homes/ag2198/euclid-scratch/run-outputs/outputs\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "8d8171a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x165.6 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "FILTERS = {\n",
    "    \"dataset\": \"CIFAR10Norm\",\n",
    "    \"model\": \"lenet-large\",\n",
    "    \"learning_rate\": 1e-5,\n",
    "    \"tag\": \"vary-k-lim\",\n",
    "    \"name\": lambda x: x not in (\"sparkling-glitter-1121\", \"dauntless-pyramid-1131\", \"lyric-aardvark-1188\", \"strawberry-square-1184\", \"sage-firebrand-1194\"),\n",
    "}\n",
    "\n",
    "FILTERS2 = {\n",
    "    \"dataset\": \"CIFAR10Norm\",\n",
    "    \"optimizer\": \"sgd\",\n",
    "    \"model\": \"lenet-large\",\n",
    "    \"learning_rate\": 1e-3,\n",
    "    \"tag\": \"init-vs-full\",\n",
    "}\n",
    "\n",
    "def metrics(run, log):\n",
    "    final_loss = log.loss.tail(1).to_list()[0]\n",
    "    final_acc = log.train.tail(1).to_list()[0]\n",
    "    if final_loss >= 0.1 and final_acc < 0.999:\n",
    "        max_step = log.epoch.max() * run[\"data_limit\"] // run[\"batch_size\"]\n",
    "        print(\"Run\", run[\"name\"], run[\"k\"], run[\"data_limit\"], run[\"seed\"], \"not finished at step\", max_step, \"loss:\", final_loss, \"acc:\", final_acc)\n",
    "        return\n",
    "    return {\n",
    "        \"train\": log.tail(1).train.to_list()[0],\n",
    "        \"lin_train\": log.tail(1).lin_train.to_list()[0],\n",
    "        \"test\": log.tail(1).test.to_list()[0],\n",
    "        \"lin_test\": log.tail(1).lin_test.to_list()[0],\n",
    "        \"loss\": log.tail(1).loss.to_list()[0],\n",
    "        \"max_train\": log.lin_train.max(),\n",
    "        \"max_test\": log.lin_test.max(),\n",
    "        \"epochs\": log.epoch.max(),\n",
    "        \"steps\": log.epoch.max() * run[\"data_limit\"] / run[\"batch_size\"],\n",
    "    }\n",
    "\n",
    "def metrics2(run, log):\n",
    "    final_loss = log.loss.tail(1).to_list()[0]\n",
    "    final_acc = log.train.tail(1).to_list()[0]\n",
    "    if final_loss >= 0.1 and final_acc < 0.999:\n",
    "        max_step = log.epoch.max() * run[\"data_limit\"] // run[\"batch_size\"]\n",
    "        print(\"Run\", run[\"name\"], run[\"k\"], run[\"data_limit\"], run[\"seed\"], \"not finished at step\", max_step, \"loss:\", final_loss, \"acc:\", final_acc)\n",
    "#         return\n",
    "    return {\n",
    "        \"train\": log.tail(1).lin_train.to_list()[0],\n",
    "        \"lin_train\": log.tail(1).lin_train.to_list()[0],\n",
    "        \"test\": log.tail(1).lin_test.to_list()[0],\n",
    "        \"lin_test\": log.tail(1).lin_test.to_list()[0],\n",
    "        \"loss\": log.tail(1).loss.to_list()[0],\n",
    "        \"max_train\": log.lin_train.max(),\n",
    "        \"max_test\": log.lin_test.max(),\n",
    "        \"epochs\": log.epoch.max(),\n",
    "        \"steps\": log.epoch.max() * run[\"data_limit\"] / run[\"batch_size\"],\n",
    "    }\n",
    "\n",
    "runs, logs = load(FILTERS)\n",
    "df, agg = aggregate(runs, logs, metrics, [\"data_limit\", \"k\", \"optimizer\"])\n",
    "runs2, logs2 = load(FILTERS2)\n",
    "df2, agg2 = aggregate(runs2, logs2, metrics2, [\"data_limit\", \"k\", \"optimizer\"])\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, sharey=True)\n",
    "fig.set_size_inches(7, 2.3)\n",
    "colours = {\n",
    "    \"1\": \"blue\",\n",
    "    \"1000\": \"red\",\n",
    "    \"100000\": \"green\",\n",
    "    \"1000000\": \"orange\",\n",
    "    \"10000000\": \"brown\",\n",
    "    \"inf\": \"black\",\n",
    "}\n",
    "\n",
    "def k_str(k):\n",
    "    if k == 1:\n",
    "        return \"1\"\n",
    "    return f\"10^{int(math.log10(k))}\"\n",
    "\n",
    "\n",
    "\n",
    "for k in (1, 1000, 100000, 1000000, 10000000):\n",
    "    view = agg[agg.index.get_level_values(1) == k]\n",
    "    xx = np.array(view.index.get_level_values(0).values, np.float32)\n",
    "    yy = view.max_test_mean.values\n",
    "    axes[1].plot(\n",
    "        xx, yy,\n",
    "        alpha=0.5,\n",
    "        linestyle='--',\n",
    "        marker='o',\n",
    "        label=f\"$K={k_str(k)}$\",\n",
    "        c=colours[str(k)],\n",
    "    )\n",
    "    \n",
    "view = agg2[agg2.index.get_level_values(1) == 1]\n",
    "xx = np.array(view.index.get_level_values(0).values, np.float32)\n",
    "yy = view.max_test_mean.values\n",
    "axes[0].plot(\n",
    "    xx, yy,\n",
    "    alpha=0.5,\n",
    "    linestyle='--',\n",
    "    marker='o',\n",
    "    label=f\"$K=1$\",\n",
    "    c=colours[\"1\"],\n",
    ")\n",
    "    \n",
    "view = agg2[agg2.index.get_level_values(1) == 10000000]\n",
    "xx = np.array(view.index.get_level_values(0).values, np.float32)\n",
    "yy = view.max_test_mean.values\n",
    "for ax in axes:\n",
    "    ax.plot(\n",
    "        xx, yy,\n",
    "        linestyle='--',\n",
    "        marker='^',\n",
    "        label=f\"$K=\\\\infty$\",\n",
    "        c=colours[\"inf\"],\n",
    "    )\n",
    "axes[1].set_xlabel(\"Dataset size\")\n",
    "axes[1].set_xscale(\"log\")\n",
    "axes[1].set_title(f\"Varying K\")\n",
    "# axes[1].legend()\n",
    "\n",
    "axes[0].set_xscale(\"log\")\n",
    "axes[0].set_xlabel(\"Dataset size\")\n",
    "axes[0].set_ylabel(\"Test accuracy\")\n",
    "axes[0].set_title(f\"Empirical NTK vs NN\")\n",
    "# axes[0].legend()\n",
    "\n",
    "axes[1].legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "\n",
    "# plt.figlegend()\n",
    "\n",
    "fig.tight_layout()\n",
    "\n",
    "fig.savefig(f\"it-lin-outputs/pdf/dataset-scaling.pdf\")\n",
    "fig.savefig(f\"it-lin-outputs/png/dataset-scaling.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "6a6d8068",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_1462971/1577434853.py:50: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "K=1:   82.230%\n",
      "K=1e6: 81.360%\n"
     ]
    },
    {
     "data": {
      "image/png": "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S+0UPW6SHtp+8UXXZWIUuMFgMBiaMM3O0HdQMXhvt5nW++Mf9XH//bBzJwQE6KHvW26BM2fgkUf0tfPBrsDNULLB4DRWq5Unn3yS7Oxshg4dyowZ7nNcaGgeNIV3Zv78+URERGC1WgkLC2P06NGNLsP50Oy6l8FFIF5ekJICHTroi2+9BevXw8qVsGoVzJoFTz4JoaHg5wfjxsGnn2ol7ywX+By4uwkMDCz7vWzZMnr06EFiYqJTcSdMmEBoaCjXXnutq8RzG+dbLzExMfTv35+BAwcydOhQp/O76667aNOmDf369atwfcWKFfTs2ZPY2Fhmz55ddn3JkiUkJSXh7e1NdHTVPgu++uorlFJV+nl2loKCAi699FIslnK/So899hgDBgzg3nvvrXDPYrHw8MMP07dvX/r378+xY8coLi5mzJgxlJaWApxz3pIw74ympnfmwQe1dfD09HSysrKYP38+d955J88++yz/+Mc/qk3D3e9Ws9NOfqUgPbpDRAQkJ2tFm5AAv/4Ku3bB7NmwejW89hrcdhtMnaqv33ILDBwI48frsPYednWYIfQmwerVq3nooYdYvnw5nTt3dirO//3f//HBBx+4WDL3cj71snbtWnbs2MGWLVuczmfmzJnnmLW0WCw88MADLF++nH379rFo0SL27dsHwMGDB7nkkkv497//zVtvvVVlmosWLWLUqFHVmtF0hvfee48bb7yxzKXk0aNH+eWXX9i5cycDBw6scO+FF16ga9eu7N27l4ceeog333wTHx8fxo0bx8cffwxwznlLxLwz1b8z//3vf88JP2HCBJ588kn27NlTbRrufreanXbytgBRURUvdu4MF18M/fvDn/4El18ODz4I778P8+ZpBb94MUyfDps2wSWX6J75gAHw+OPw7bdQUlIxTaPA3c5PP/3Evffey9KlS+nWrZvT8caNG0dQUJALJXMv51sv58OYMWNo3briro9NmzYRGxtL165d8fHxYcqUKWUOJ6KjowkLCwOo0l9zbm4u69atY+7cuSxevLjCvQULFhAXF8eAAQOYNm1ajdcXLlzI9ddfD2gFMHbsWBITExk0aBDvvvtu2b28vDy+/PJLHn74YQC6dOnCkSNHALjhhhtYuHBhWT6Vz1sS5p2p+Z3Jy8s7J98A2/Sr2EdjK6XRFN6tZjcH7m0BOkTVGq4CAQFw6636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\n",
      "text/plain": [
       "<Figure size 504x194.4 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "runs, logs = load({\"name\": \"warm-grass-1124\"})\n",
    "run = runs[0]\n",
    "log = logs[0]\n",
    "runs, logs = load({\"name\": \"deep-firefly-1161\"})\n",
    "run2 = runs[0]\n",
    "log2 = logs[0]\n",
    "runs, logs = load({\"name\": \"logical-disco-1081\"})\n",
    "run3 = runs[0]\n",
    "log3 = logs[0]\n",
    "\n",
    "# print(run)\n",
    "# print(run2)\n",
    "\n",
    "f = plt.figure()\n",
    "f.set_size_inches(7, 2.7)\n",
    "\n",
    "steps_per_epoch = 2 * 50000 / run[\"batch_size\"]\n",
    "\n",
    "N = 200000\n",
    "plt.plot(log2.epoch * steps_per_epoch, log2.test, label=\"K=1\", c='b')\n",
    "plt.plot(log.epoch * steps_per_epoch, log.lin_test, label=\"K=$5 \\cdot 10^6 \\; \\mathrm{Acc}(f(\\\\theta))$\", c='g', linestyle='-')\n",
    "plt.plot(log.epoch * steps_per_epoch, log.test, label=\"K=$5 \\cdot 10^6 \\; \\mathrm{Acc}(f^\\mathrm{lin}(\\\\theta))$\", c='r', linestyle='-')\n",
    "plt.title(f\"Test accuracy for K=1 and K=$5 \\cdot 10^6$\")\n",
    "plt.xlabel(\"Step\")\n",
    "plt.ylabel(\"Test Accuracy\")\n",
    "plt.legend(ncol=3)\n",
    "_ = plt.xlim((0, N * steps_per_epoch))\n",
    "\n",
    "from mpl_toolkits.axes_grid1.inset_locator import zoomed_inset_axes\n",
    "from mpl_toolkits.axes_grid1.inset_locator import mark_inset\n",
    "\n",
    "\n",
    "ax = plt.gca()\n",
    "# axins = zoomed_inset_axes(ax, 6, loc=10, bbox_to_anchor=(550,100)) # zoom = 6\n",
    "axins = zoomed_inset_axes(ax, zoom=7, loc='center', bbox_to_anchor=(360, 115)) #bbox_transform=ax.transAxes\n",
    "axins.xaxis.get_major_locator().set_params(nbins=1)\n",
    "\n",
    "axins.plot(log2.epoch * steps_per_epoch, log2.test, label=\"K=1\", c='b')\n",
    "axins.plot(log.epoch * steps_per_epoch, log.lin_test, label=\"K=$5 \\cdot 10^6 \\; \\text{Acc}(f(\\theta))\", c='g')\n",
    "axins.plot(log.epoch * steps_per_epoch, log.test, label=\"K=$5 \\cdot 10^6$ \\; \\text{Acc}(f^\\text{lin}(\\theta))\", c='r')\n",
    "\n",
    "x1, x2, y1, y2 = 190000 * steps_per_epoch, 200000 * steps_per_epoch, 0.805, 0.83\n",
    "axins.set_xlim(x1, x2)\n",
    "axins.set_ylim(y1, y2)\n",
    "\n",
    "# draw a bbox of the region of the inset axes in the parent axes and\n",
    "# connecting lines between the bbox and the inset axes area\n",
    "mark_inset(ax, axins, loc1=2, loc2=4, fc=\"none\", ec=\"0.5\")\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "print(f\"K=1:   {log2.test[log2.epoch <= N].tail(1).to_list()[0]*100:.3f}%\")\n",
    "print(f\"K=1e6: {log.test[log.epoch <= N].tail(1).to_list()[0]*100:.3f}%\")\n",
    "\n",
    "f.savefig(f\"it-lin-outputs/pdf/large-k.pdf\")\n",
    "f.savefig(f\"it-lin-outputs/png/large-k.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "67bd0895",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(RangeIndex(start=0, stop=6820, step=1),\n",
       " 0           30\n",
       " 1           60\n",
       " 2           90\n",
       " 3          120\n",
       " 4          150\n",
       "          ...  \n",
       " 6815    204480\n",
       " 6816    204510\n",
       " 6817    204540\n",
       " 6818    204570\n",
       " 6819    204600\n",
       " Name: epoch, Length: 6820, dtype: int64)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "log.index, log.epoch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "5eb39cdc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "eye-catching-tulip-1069 [Errno 2] No such file or directory: '/homes/ag2198/euclid-scratch/run-outputs/outputs/eye-catching-tulip-1069/log'\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x165.6 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "FILTERS = {\n",
    "    \"dataset\": \"CIFAR10Norm\",\n",
    "    \"model\": \"lenet-large\",\n",
    "    \"learning_rate\": 1e-4,\n",
    "    \"data_limit\": None,\n",
    "    \"tag\": None,\n",
    "    \"name\": lambda x: x not in (\"jolly-thunder-1048\", \"noble-haze-1051\", \"eager-flower-1049\", \"desert-meadow-1050\", \"adoring-rose-1071\"),\n",
    "}\n",
    "\n",
    "runs, logs = load(FILTERS)\n",
    "\n",
    "fig, axes = plt.subplots(1,2, sharey=True)\n",
    "fig.set_size_inches(7, 2.3)\n",
    "    \n",
    "N = 20000\n",
    "for i, (run, log) in enumerate(zip(runs[::-1], logs[::-1])):\n",
    "#     print(run)\n",
    "    idx = log.epoch < N\n",
    "    col = \"b\" if run[\"k\"] == 1 else \"r\"\n",
    "    kstr = \"1\" if run[\"k\"] == 1 else \"2 \\cdot 10^5\"\n",
    "    axes[0].plot(log.epoch[idx] * 50000 / run[\"batch_size\"], log.test[idx], label=f\"{run['optimizer']} $K={kstr}$\", c=col)\n",
    "axes[0].set_xlabel(\"Step\")\n",
    "axes[0].set_ylabel(\"Test Accuracy\")\n",
    "baseline = 0.7110001\n",
    "axes[0].plot(log.epoch[idx] * 50000 / run[\"batch_size\"], log.test[idx]*0 + baseline, linestyle=\":\", alpha=0.5, label=\"adam baseline\")\n",
    "axes[0].legend()\n",
    "    \n",
    "for i, (run, log) in enumerate(zip(runs, logs)):\n",
    "    if run[\"k\"] == 1: continue\n",
    "    idx = log.epoch < N\n",
    "    axes[1].plot(log.epoch[idx] * 50000 / run[\"batch_size\"], log.train[idx], label=\"$K=2 \\cdot 10^5 \\quad \\mathrm{Acc}(f(\\\\theta))$\", c=\"r\")\n",
    "    axes[1].plot(log.epoch[idx] * 50000 / run[\"batch_size\"], log.lin_train[idx], label=\"$K=2 \\cdot 10^5 \\quad \\mathrm{Acc}(f^\\mathrm{lin}(\\\\theta))$\", c=\"g\")\n",
    "axes[1].set_xlabel(\"Step\")\n",
    "axes[1].set_ylabel(\"Train Accuracy\")\n",
    "axes[1].legend()\n",
    "\n",
    "    \n",
    "fig.tight_layout()\n",
    "\n",
    "\n",
    "fig.savefig(f\"it-lin-outputs/pdf/adam-il.pdf\")\n",
    "fig.savefig(f\"it-lin-outputs/png/adam-il.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "e7a2b087",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "devoted-capybara-1195 [Errno 2] No such file or directory: '/homes/ag2198/euclid-scratch/run-outputs/outputs/devoted-capybara-1195/log'\n",
      "wild-armadillo-1157 [Errno 2] No such file or directory: '/homes/ag2198/euclid-scratch/run-outputs/outputs/wild-armadillo-1157/log'\n",
      "K=1      GD:    Final test acc: 66.90%, max test acc: 69.70%, epochs: 100000 faithful-paper-1156\n",
      "K=10000  GD:    Final test acc: 69.60%, max test acc: 70.01%, epochs: 100000 fragrant-dream-1202\n",
      "K=1      SGD:   Final test acc: 66.19%, max test acc: 69.33%, epochs: 53000 dandy-jazz-1176\n",
      "K=100000 SGD:   Final test acc: 67.46%, max test acc: 70.40%, epochs: 68000 worldly-frost-1177\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x144 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import math\n",
    "\n",
    "FILTERS = {\n",
    "    \"dataset\": \"CIFAR10Norm\",\n",
    "    \"model\": \"lenet-large\",\n",
    "    \"learning_rate\": 1e-3,\n",
    "    \"tag\": \"full-batch-cifar\",\n",
    "    \"full_batch\": True,\n",
    "    \"k\": lambda k: k in (1, 10000),\n",
    "    \"name\": lambda x: x not in (\"worldly-durian-1198\",\"resilient-sky-1199\")\n",
    "}\n",
    "\n",
    "runs, logs = load(FILTERS)\n",
    "runs, logs = runs[::-1], logs[::-1]\n",
    "\n",
    "FILTERS2 = {\n",
    "    \"dataset\": \"CIFAR10Norm\",\n",
    "    \"model\": \"lenet-large\",\n",
    "    \"learning_rate\": 1e-4,\n",
    "    \"tag\": \"sgd-cifar\",\n",
    "    \"k\": lambda k: k in (1, 100000),\n",
    "}\n",
    "\n",
    "runs2, logs2 = load(FILTERS2)\n",
    "\n",
    "def format_k(k):\n",
    "    if k == 1:\n",
    "        return \"$K=1$\"\n",
    "    if k == 10:\n",
    "        return \"$K=10$\"\n",
    "    return f\"$K=10^{int(math.log10(k))}$\"\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(1,3, sharey=True)\n",
    "fig.set_size_inches(7, 2)\n",
    "\n",
    "for i, (run, log) in enumerate(zip(runs, logs)):\n",
    "    print(f\"K={run['k']:<6} GD:    Final test acc: {log.tail(1).test.to_list()[0]*100:.2f}%, max test acc: {log.test.max()*100:.2f}%, epochs:\", log.epoch.max(), run[\"name\"])\n",
    "    col = \"g\" if run[\"k\"] == 1 else \"m\"\n",
    "    # Full batch so use epoch\n",
    "    axes[0].plot(log.epoch, log.test, label=format_k(run['k']), c=col)\n",
    "    axes[0].set_xlabel(\"Step\")\n",
    "    axes[0].set_ylabel(\"Test Accuracy\")\n",
    "    axes[0].set_title(\"Full batch\")\n",
    "    axes[0].legend()\n",
    "\n",
    "N = 10000\n",
    "\n",
    "for i, (run, log) in enumerate(zip(runs2, logs2)):\n",
    "    print(f\"K={run['k']:<6} SGD:   Final test acc: {log.tail(1).test.to_list()[0]*100:.2f}%, max test acc: {log.test.max()*100:.2f}%, epochs:\", log.epoch.max(), run[\"name\"])\n",
    "    col = \"b\" if run[\"k\"] == 1 else \"r\"\n",
    "    axes[1].plot(log.epoch * 50000 / run[\"batch_size\"], log.test, label=format_k(run['k']), c=col)\n",
    "    axes[1].set_xlabel(\"Step\")\n",
    "    axes[1].set_title(\"Mini batch\")\n",
    "    axes[1].set_xlim((0, N * 50000 / run[\"batch_size\"]))\n",
    "    axes[1].legend()\n",
    "    \n",
    "    \n",
    "MAX_STEPS = 1000000\n",
    "    \n",
    "for i, (run, log) in enumerate(zip(runs+runs2, logs+logs2)):\n",
    "    steps = log.epoch * 10\n",
    "    if not run[\"full_batch\"]:\n",
    "        steps = log.epoch * 50000 / run[\"batch_size\"]\n",
    "        col = \"b\" if run[\"k\"] == 1 else \"r\"\n",
    "    else:\n",
    "        col = \"g\" if run[\"k\"] == 1 else \"m\"\n",
    "    axes[2].plot(steps, log.test, label=f\"{format_k(run['k'])} {'S'*(1-run['full_batch'])}GD\", c=col, alpha=0.7)\n",
    "    axes[2].set_title(\"Comparison\")\n",
    "    axes[2].set_xlabel(\"Step\")\n",
    "    axes[2].set_xlim((0, MAX_STEPS))\n",
    "    axes[2].legend(prop={'size': 8})\n",
    "    \n",
    "    \n",
    "fig.tight_layout()\n",
    "\n",
    "fig.savefig(f\"it-lin-outputs/pdf/gd-sgd.pdf\")\n",
    "fig.savefig(f\"it-lin-outputs/png/gd-sgd.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "5f2bd6e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/homes/ag2198/py310/lib/python3.10/site-packages/numpy/core/fromnumeric.py:3474: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/homes/ag2198/py310/lib/python3.10/site-packages/numpy/core/_methods.py:189: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x122.4 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import glob\n",
    "global_fts = []\n",
    "\n",
    "f = lambda x: (x**5) / 32 - (x**3) / 2 + 2 * x - 1\n",
    "xx = np.linspace(-4, 4, num=1000)\n",
    "yy = f(xx)\n",
    "\n",
    "train_x = np.linspace(-4, 4, num=20)\n",
    "idx = [np.argmin(abs(xx - x)) for x in train_x] # Find closest points we stored\n",
    "train_x = xx[idx]\n",
    "train_y = f(train_x)\n",
    "\n",
    "f1 = plt.figure()\n",
    "f1.set_size_inches(7, 2)\n",
    "ax1 = f1.add_subplot(111)\n",
    "ax1.set_xscale(\"log\")\n",
    "ax1.set_xlabel(\"Damping factor ($\\lambda$)\")\n",
    "ax1.set_ylabel(\"Test RMSE\")\n",
    "# ax1.set_title(\"Test RMSE limitted to train RMSE < 0.25\")\n",
    "\n",
    "f2, axes = plt.subplots(1, 4)\n",
    "f2.set_size_inches(7, 1.7)\n",
    "\n",
    "def tex(x):\n",
    "    x = x.replace(\"e+0\", \"e\")\n",
    "    if \"e\" in x:\n",
    "        return x.replace(\"e\", \"\\cdot 10^{\") + \"}\"\n",
    "    return x\n",
    "\n",
    "width = 50\n",
    "kernalised = False\n",
    "\n",
    "spread = (\"1e-2\", \"1e-1\", \"2e-1\", \"4e-1\", \"7e-1\", \"1e+00\", \"2e+00\", \"4e+00\", \"7e+00\", \"1e+01\", \"1.200000e+01\", \"1.400000e+01\", \"1.500000e+01\", \"1.700000e+01\", \"2.500000e+01\", \"2.700000e+01\", \"3.500000e+01\", \"2e+01\", \"3e+01\", \"4e+01\", \"5e+01\", \"6e+01\", \"7e+01\", \"8e+01\", \"9e+01\", \"1e+02\", \"2e+02\", \"4e+02\", \"7e+02\", \"1e+03\", \"2e+03\", \"4e+03\", \"7e+03\", \"1e+04\")\n",
    "\n",
    "kern = \"-kern\"*kernalised\n",
    "\n",
    "fb = True\n",
    "fk = True\n",
    "\n",
    "total_time = 0\n",
    "\n",
    "plt.figure()\n",
    "for lam in sorted(spread, key=float):\n",
    "    files = glob.glob(f\"/scratches/euclid/ag2198/ils/outputs/1D-poly5-5x{width}-lecun-S1-LR1e+00-ilsNone{kern}{lam}-relu/final_output_*.npy\")\n",
    "    rmses = []\n",
    "    good_rmses = []\n",
    "    train_rmses = []\n",
    "    for f in files:\n",
    "        outputs = np.load(f)\n",
    "        if sum(np.isnan(outputs)):\n",
    "            continue\n",
    "        rmse = np.mean((outputs - yy)**2) ** 0.5\n",
    "        train_rmse = np.mean((outputs[idx] - train_y)**2) ** 0.5\n",
    "        if train_rmse < 0.25:\n",
    "            if fb:\n",
    "                ax1.scatter(np.array([float(lam)]), np.array([rmse]), c=\"b\", alpha=0.2, label=\"Individual run\")\n",
    "                fb = False\n",
    "            else:\n",
    "                ax1.scatter(np.array([float(lam)]), np.array([rmse]), c=\"b\", alpha=0.2)\n",
    "            good_rmses.append(rmse)\n",
    "        rmses.append(rmse)\n",
    "        train_rmses.append(train_rmse)\n",
    "        ax = None\n",
    "        if train_rmse < 0.25:\n",
    "            if lam == \"1e-1\":\n",
    "                ax = axes[0]\n",
    "                s = \"$\\lambda = 10^{-1}$\"\n",
    "            elif lam == \"1e+00\":\n",
    "                ax = axes[1]\n",
    "                s = \"$\\lambda = 10^{0}$\"\n",
    "            elif lam == \"1e+01\":\n",
    "                ax = axes[2]\n",
    "                s = \"$\\lambda = 10^{1}$\"\n",
    "            elif lam == \"1e+02\":\n",
    "                ax = axes[3]\n",
    "                s = \"$\\lambda = 10^{2}$\"\n",
    "            if ax is not None:\n",
    "                ax.set_title(s, y=0, pad=-16)\n",
    "#                 ax.set_title(s, y=1, pad=-15)\n",
    "                ax.plot(xx, outputs)\n",
    "                ax.get_xaxis().set_visible(False)\n",
    "                ax.get_yaxis().set_visible(False)\n",
    "                ax.set_ylim((-4.5, 3))\n",
    "    if fk:\n",
    "        fk = False\n",
    "        ax1.scatter(np.array([float(lam)]), np.array([np.mean(good_rmses)]), c=\"k\", s=20, label=\"Mean of runs\")\n",
    "    else:\n",
    "        ax1.scatter(np.array([float(lam)]), np.array([np.mean(good_rmses)]), c=\"k\", s=20)\n",
    "\n",
    "ax1.legend()\n",
    "\n",
    "f1.tight_layout()\n",
    "f2.tight_layout()\n",
    "\n",
    "f1.savefig(f\"it-lin-outputs/pdf/1d-rmse-vs-damping.pdf\")\n",
    "f1.savefig(f\"it-lin-outputs/png/1d-rmse-vs-damping.png\")\n",
    "f2.savefig(f\"it-lin-outputs/pdf/1d-fn-vs-damping.pdf\")\n",
    "f2.savefig(f\"it-lin-outputs/png/1d-fn-vs-damping.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "2318fc3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x180 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import wandb\n",
    "import math\n",
    "api = wandb.Api()\n",
    "entity, project = \"AdGold\", \"periodic-linearisation\"\n",
    "runs = [api.run(f\"{entity}/{project}/sqow771z\"), api.run(f\"{entity}/{project}/20j07icv\")]\n",
    "\n",
    "f, ax = plt.subplots(1, 2, sharey=True)\n",
    "f.set_size_inches(8, 2.5)\n",
    "\n",
    "batch_size = 250\n",
    "dataset_size = 50000\n",
    "steps_per_epoch = dataset_size / batch_size\n",
    "\n",
    "for run in runs[::-1]:\n",
    "    epochs = []\n",
    "    steps = []\n",
    "    test = []\n",
    "    lin_test = []\n",
    "    train = []\n",
    "    for x in run.scan_history(keys=[\"_step\", \"epoch\", \"lin_test\", \"train\", \"test\"], page_size=10000000):\n",
    "        steps.append(x[\"_step\"])\n",
    "        epochs.append(x[\"epoch\"])\n",
    "        train.append(x[\"train\"])\n",
    "        test.append(x[\"test\"])\n",
    "        lin_test.append(x[\"lin_test\"])\n",
    "    if run.config[\"k\"] == 1:\n",
    "        ax[0].plot(np.array(epochs) * steps_per_epoch, np.array(test), label=\"$K=1$\", c=\"b\")\n",
    "    else:\n",
    "        ax[0].plot(np.array(epochs) * steps_per_epoch, np.array(lin_test), label=\"$K=10^6 \\; \\mathrm{Acc}(f^\\mathrm{lin}(\\\\theta))$\", c=\"g\")\n",
    "        ax[0].plot(np.array(epochs) * steps_per_epoch, np.array(test), label=\"$K=10^6 \\; \\mathrm{Acc}(f(\\\\theta))$\", c=\"r\")\n",
    "    \n",
    "ax[0].legend()\n",
    "ax[0].set_ylabel(\"Test Accuracy\")\n",
    "ax[0].set_xlabel(\"Step\")\n",
    "ax[0].set_xlim((0, int(4.7e6)))\n",
    "ax[0].set_title(\"Without BatchNorm or Data Aug\")\n",
    "\n",
    "\n",
    "# f.savefig(f\"it-lin-outputs/pdf/resnet.pdf\")\n",
    "# f.savefig(f\"it-lin-outputs/png/resnet.png\")\n",
    "\n",
    "batch_size = 256\n",
    "dataset_size = 100000\n",
    "steps_per_epoch = int(math.ceil(dataset_size / batch_size))\n",
    "\n",
    "run = api.run(f\"{entity}/{project}/utxfer4i\")\n",
    "epochs = []\n",
    "steps = []\n",
    "test = []\n",
    "lin_test = []\n",
    "train = []\n",
    "for x in run.scan_history(keys=[\"_step\", \"epoch\", \"lin_test\", \"train\", \"test\"], page_size=10000000):\n",
    "    steps.append(x[\"_step\"])\n",
    "    epochs.append(x[\"epoch\"])\n",
    "    train.append(x[\"train\"])\n",
    "    test.append(x[\"test\"])\n",
    "    lin_test.append(x[\"lin_test\"])\n",
    "ax[1].plot(np.array(epochs) * steps_per_epoch, np.array(lin_test), label=\"$K=10^5 \\; \\mathrm{Acc}(f^\\mathrm{lin}(\\\\theta))$\", c=\"g\")\n",
    "ax[1].plot(np.array(epochs) * steps_per_epoch, np.array(test), label=\"$K=10^5 \\; \\mathrm{Acc}(f(\\\\theta))$\", c=\"r\")\n",
    "ax[1].legend()\n",
    "# ax[1].set_ylabel(\"Test Accuracy\")\n",
    "ax[1].set_xlabel(\"Step\")\n",
    "ax[1].set_title(\"With BatchNorm and Data Aug\")\n",
    "f.tight_layout()\n",
    "f.savefig(f\"it-lin-outputs/pdf/resnet-both.pdf\")\n",
    "f.savefig(f\"it-lin-outputs/png/resnet-both.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "908f4158",
   "metadata": {},
   "outputs": [
    {
     "ename": "ImportError",
     "evalue": "cannot import name 'load' from 'utils' (/homes/ag2198/nn-experiments/utils.py)",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mImportError\u001b[0m                               Traceback (most recent call last)",
      "Input \u001b[0;32mIn [5]\u001b[0m, in \u001b[0;36m<cell line: 1>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mutils\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m load\n\u001b[1;32m      2\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mmodels\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mflax_models\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m LeNetLarge\n\u001b[1;32m      3\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mjax\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m jit, grad, value_and_grad\n",
      "\u001b[0;31mImportError\u001b[0m: cannot import name 'load' from 'utils' (/homes/ag2198/nn-experiments/utils.py)"
     ]
    }
   ],
   "source": [
    "from utils import load\n",
    "from models.flax_models import LeNetLarge\n",
    "from jax import jit, grad, value_and_grad\n",
    "\n",
    "run = \"peach-river-1270\"\n",
    "checkpoint = f\"/homes/ag2198/euclid-scratch/run-outputs/outputs/{run}/checkpoints/checkpoint_00010000.pkl\"\n",
    "checkpoint_state = load(checkpoint)\n",
    "start_epoch, step, il_state, batch_stats, opt_state = checkpoint_state\n",
    "opt_state = optimizers.pack_optimizer_state(opt_state)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
