{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7c3be0c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import gzip\n",
    "import json\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "%matplotlib inline\n",
    "plt.rc('font', family='serif', size=8)\n",
    "plt.rc('text', usetex=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f56130d6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>optimizer</th>\n",
       "      <th>lr</th>\n",
       "      <th>N</th>\n",
       "      <th>M</th>\n",
       "      <th>d</th>\n",
       "      <th>ntrain</th>\n",
       "      <th>batch_size</th>\n",
       "      <th>niter</th>\n",
       "      <th>layernorm</th>\n",
       "      <th>seed</th>\n",
       "      <th>error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>matrix</td>\n",
       "      <td>Adam</td>\n",
       "      <td>0.1</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>10</td>\n",
       "      <td>102400</td>\n",
       "      <td>256</td>\n",
       "      <td>400</td>\n",
       "      <td>False</td>\n",
       "      <td>42</td>\n",
       "      <td>0.037157</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>learnable</td>\n",
       "      <td>Adam</td>\n",
       "      <td>0.1</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>10</td>\n",
       "      <td>10240</td>\n",
       "      <td>16</td>\n",
       "      <td>640</td>\n",
       "      <td>True</td>\n",
       "      <td>43</td>\n",
       "      <td>0.006427</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>exponential</td>\n",
       "      <td>SGD</td>\n",
       "      <td>100.0</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>10</td>\n",
       "      <td>10240</td>\n",
       "      <td>256</td>\n",
       "      <td>40</td>\n",
       "      <td>True</td>\n",
       "      <td>43</td>\n",
       "      <td>0.023662</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>matrix</td>\n",
       "      <td>Adam</td>\n",
       "      <td>100.0</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>10</td>\n",
       "      <td>10240</td>\n",
       "      <td>16</td>\n",
       "      <td>640</td>\n",
       "      <td>False</td>\n",
       "      <td>44</td>\n",
       "      <td>0.023956</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>learnable</td>\n",
       "      <td>Adam</td>\n",
       "      <td>10.0</td>\n",
       "      <td>100</td>\n",
       "      <td>5</td>\n",
       "      <td>10</td>\n",
       "      <td>1024</td>\n",
       "      <td>256</td>\n",
       "      <td>4</td>\n",
       "      <td>True</td>\n",
       "      <td>45</td>\n",
       "      <td>0.274714</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         model optimizer     lr    N  M   d  ntrain  batch_size  niter  \\\n",
       "0       matrix      Adam    0.1  100  5  10  102400         256    400   \n",
       "1    learnable      Adam    0.1  100  5  10   10240          16    640   \n",
       "2  exponential       SGD  100.0  100  5  10   10240         256     40   \n",
       "3       matrix      Adam  100.0  100  5  10   10240          16    640   \n",
       "4    learnable      Adam   10.0  100  5  10    1024         256      4   \n",
       "\n",
       "   layernorm  seed     error  \n",
       "0      False    42  0.037157  \n",
       "1       True    43  0.006427  \n",
       "2       True    43  0.023662  \n",
       "3      False    44  0.023956  \n",
       "4       True    45  0.274714  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fname = 'res/finer_dim/all.jsonl.gz'\n",
    "res = [json.loads(line) for line in gzip.open(fname)]\n",
    "df = pd.DataFrame(res)\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "39ac55f9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "40320 10080\n"
     ]
    }
   ],
   "source": [
    "# make a dataframe with tuned lr\n",
    "keys = ['model', 'optimizer', 'N', 'M', 'd', 'ntrain', 'batch_size', 'layernorm', 'seed']\n",
    "dftune = df.loc[df.groupby(keys).error.idxmin()].copy()\n",
    "print(len(df), len(dftune))"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "6d0568d6",
   "metadata": {},
   "source": [
    "## error vs dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "846ba2b2",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, '$|B|$=1024, lr=1.0, T=10240')"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = \"matrix\"\n",
    "bs = 1024\n",
    "lr = 1.\n",
    "# lr = None  # tuned lr\n",
    "ntr = 1024*10\n",
    "\n",
    "if lr is not None:  # fixed lr\n",
    "    dff = df[(df.model == model) & (df.batch_size == bs) & (df.lr == lr) & (df.ntrain == ntr)]\n",
    "else:  # tuned lr\n",
    "    dff = dftune[(dftune.model == model) & (dftune.batch_size == bs) & (dftune.ntrain == ntr)]\n",
    "\n",
    "opt_ln = [(\"SGD\", False), (\"SGD\", True), (\"Adam\", False), (\"Adam\", True)]\n",
    "# opt_ln = [(\"SGD\", False), (\"Adam\", False)]\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "lns_str = {False: \"\", True: \"LN\"}\n",
    "\n",
    "for opt, ln in opt_ln:\n",
    "    groups = dff[(dff.optimizer == opt) & (dff.layernorm == ln)].groupby('d')\n",
    "    errs = groups.error.mean()\n",
    "    std = groups.error.std()\n",
    "    ax.loglog(errs.index, errs, label=f\"{opt}, {lns_str[ln]}\")\n",
    "    ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "\n",
    "ax.legend(fontsize=6, loc='upper right')\n",
    "ax.set_xlabel('d', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'$|B|$={bs}, lr={lr}, T={ntr}', fontsize=10)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "848e146d",
   "metadata": {},
   "source": [
    "## error vs T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b64f90fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, '$|B|$=1024, lr=10.0, d=100')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = \"matrix\"\n",
    "bs = 1024\n",
    "lr = 10.\n",
    "# lr = None # tuned lr\n",
    "d = 100\n",
    "\n",
    "if lr is not None:  # fixed lr\n",
    "    dff = df[(df.model == model) & (df.batch_size == bs) & (df.lr == lr) & (df.d == d)]\n",
    "else:  # tuned lr\n",
    "    dff = dftune[(dftune.model == model) & (dftune.batch_size == bs) & (dftune.d == d)]\n",
    "\n",
    "opt_ln = [(\"SGD\", False), (\"SGD\", True), (\"Adam\", False), (\"Adam\", True)]\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "lns_str = {False: \"\", True: \"LN\"}\n",
    "\n",
    "for opt, ln in opt_ln:\n",
    "    groups = dff[(dff.optimizer == opt) & (dff.layernorm == ln)].groupby('ntrain')\n",
    "    errs = groups.error.mean()\n",
    "    std = groups.error.std()\n",
    "    ax.loglog(errs.index, errs, label=f\"{opt}, {lns_str[ln]}\")\n",
    "    ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "\n",
    "ax.legend(fontsize=6, loc='lower left')\n",
    "ax.set_xlabel('T', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'$|B|$={bs}, lr={lr}, d={d}', fontsize=10)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "819dd996",
   "metadata": {},
   "source": [
    "## Batch size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0c7fa540",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = \"matrix\"\n",
    "bs = 16\n",
    "# lr = None  # tuned lr\n",
    "ntr = 1024\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "leg = []\n",
    "\n",
    "# if lr is not None:  # fixed lr\n",
    "for bs in [16, 1024]:\n",
    "    if bs == 16:\n",
    "        lr = 1\n",
    "    else:\n",
    "        lr = 10.\n",
    "    groups = df[(df.model == model) & (df.batch_size == bs) & (df.lr == lr) & (df.ntrain == ntr) & \n",
    "             (df.optimizer == \"Adam\") & (df.layernorm == False)].groupby('d')\n",
    "\n",
    "    errs = groups.error.mean()\n",
    "    std = groups.error.std()\n",
    "    a, = ax.loglog(errs.index, errs, label=f\"$|B| = {bs}$\")\n",
    "    ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "    leg.append(a)\n",
    "\n",
    "ax.legend(leg, [r'$\\vert B\\vert=16, \\gamma=1$', r'$\\vert B\\vert=1024, \\gamma=10$'], fontsize=6, loc='upper right', handlelength=1)\n",
    "ax.set_xlabel('d', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'SGD, $T$={ntr}')\n",
    "fig.savefig('figures/bs.pdf', pad_inches=0, bbox_inches='tight')"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "68c5fd4d",
   "metadata": {},
   "source": [
    "## LR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "af20f50c",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = \"matrix\"\n",
    "bs = 64\n",
    "# lr = 1.\n",
    "opti = \"SGD\"\n",
    "ln = False\n",
    "ntr = 1024*10\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "\n",
    "# if lr is not None:  # fixed lr\n",
    "for lr in [0.1, 1.0, 10., 100.]:\n",
    "    groups = df[(df.model == model) & (df.batch_size == bs) & (df.lr == lr) & (df.ntrain == ntr) & \n",
    "             (df.optimizer == opti) & (df.layernorm == ln)].groupby('d')\n",
    "\n",
    "    errs = groups.error.mean()\n",
    "    std = groups.error.std()\n",
    "    ax.loglog(errs.index, errs, label=f\"$\\gamma$={lr}\")\n",
    "    ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "\n",
    "ax.legend(fontsize=6, loc='lower left')\n",
    "ax.set_xlabel('d', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'{opti}, $|B|$={bs}, $T$={ntr}')\n",
    "fig.savefig('figures/lr.pdf', pad_inches=0, bbox_inches='tight')"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "901f2d07",
   "metadata": {},
   "source": [
    "## Adam vs SGD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6edcef4e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = \"matrix\"\n",
    "bs = 256\n",
    "# lr = 10.\n",
    "# lr = None  # tuned lr\n",
    "ntr = 1024*10\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "# if lr is not None:  # fixed lr\n",
    "for opti in [\"SGD\", \"Adam\"]:\n",
    "    groups = dftune[(dftune.model == model) & (dftune.batch_size == bs) & (dftune.ntrain == ntr) & \n",
    "                    (dftune.optimizer == opti) & (dftune.layernorm == False)].groupby('d')\n",
    "\n",
    "    errs = groups.error.mean()\n",
    "    std = groups.error.std()\n",
    "    ax.loglog(errs.index, errs, label=opti)\n",
    "    ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "\n",
    "ax.legend(fontsize=6, loc='lower left')\n",
    "ax.set_xlabel('d', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'tuned $\\gamma$, $|B|$={bs}, $T$={ntr}')\n",
    "fig.savefig('figures/adam.pdf', pad_inches=0, bbox_inches='tight')"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "e7edfa36",
   "metadata": {},
   "source": [
    "## Layernorm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1f95262a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = \"matrix\"\n",
    "bs = 1024\n",
    "lr = 1.\n",
    "# lr = None  # tuned lr\n",
    "ntr = 1024*10\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "# if lr is not None:  # fixed lr\n",
    "for ln in [False, True]:\n",
    "    for opti in [\"SGD\", \"Adam\"]:\n",
    "        groups = df[(df.model == model) & (df.batch_size == bs) & (df.lr == lr) & (df.ntrain == ntr) & \n",
    "                 (df.optimizer == opti) & (df.layernorm == ln)].groupby('d')\n",
    "\n",
    "        errs = groups.error.mean()\n",
    "        std = groups.error.std()\n",
    "        ax.loglog(errs.index, errs, label=opti + (\"+LN\" if ln else \"\"))\n",
    "        ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "\n",
    "ax.legend(fontsize=6, loc='lower left')\n",
    "ax.set_xlabel('d', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'$\\gamma$={lr}, $|B|$={bs}, $T$={ntr}')\n",
    "fig.savefig('figures/ln.pdf', pad_inches=0, bbox_inches='tight')"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "89244fb9",
   "metadata": {},
   "source": [
    "# Learning the embeddings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "de4fdccd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAOQAAAC/CAYAAADuHnC5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAjs0lEQVR4nO2d228jx73nvyQl3ik2W9fRZUZqTuLYieOYGm2c3cUujk0lwGKfcjief+AMhWCwL0YgQfsS+LzI0vs8kA6wwL7ZYgLsvi1E+yE5QU4siY4vGdtjszUeaTQaiZcmKd4kUr0PxW6RFCU1KVJsifUBGuwu9qW6mt/+/arqV0WNKIoiKBSKKtC2OwMUCuUYKkgKRUVQQVIoKoIKkkJREVSQFIqKoIKkUFQEFSSFoiKoICkUFUEFeUUJBALgef7Sj6W0lq52Z+C6EgqFsLCwgOXl5XP3CwaD4DgOq6urmJ+fB8Mw554/FovVTF9aWsLc3BwWFxfBMAwEQcDq6iqmp6fh9XrPPFYpZ91bIBBALBYDy7JgGAZut/vc801PT8PlcsHpdGJ9fR3BYBBzc3MAgJWVlYq8NyOfZ5V5MBgEz/NyuS0uLoLjuBPnvnv3bsV5G32OJxApTWdlZUVcX18XlRSvy+WS18PhsOjxeBRdw+fzieFw+ET6+vq6yHFcRVo8HhcBiPF4/MxjlXDWvfl8PnFxcVHez+12n3u+9fV1cXl5Wd6enZ2tKINwOFzxfTPyeVqZh8NhcXZ2tuJ+yvctP3f1eRt9jtVQQbaQ8wS5srJy4oErfUeeJqrFxUXR6/WeuA7DMOceWw/V+YzH4xXXkNLOo1psLpdL9Pl88vb6+vqF8lqdz7PKvPplFg6Ha97n8vJyRfpFnmM1tA5ZYmlpCQ6HA5OTkxAEAQDA83xL61o8z4Nl2ZrpjSK5eBKBQADLy8tYX19v+JxKWFtbA8uyCAQCCAQCsst5Hh6Pp2I7FApVuLkul6umy9goZ5W5y+VCOByuyEv1tT/88MMTeW7mc6R1SJAfLcMw2NjYwNraGubm5uDz+RAMBuH1eiEIwrk/sMnJybrrOYIgnKhnSPW+RgkGg5iZmUEgEAAAuf542o+6WfcmvbzcbjcYhgHHcXjrrbfqehEEg0H52Fbls54yr65/BoPBmnXiZj5HKkgAHMfJbz232y3/uKQfBsMw8Pl8Tb9urYdW6+EqRXqjl7/BPR4PnE6nvF4rD824N5ZlwXGcnHeO4xAKheq6n5WVlVMbgZqVT6VlPjc3h/n5ebhcror9ar0smvkcqcsKVBQ6ANy5cwc+n09RC+FF4DiuZotnoy7aaW/wi7aqKqG6DBshGAxWuNutQEmZ+/1+TE9Pw+PxyG7n0tISYrEY/H4//H6/vJ/04m7Wc6QWsgbVb7ZmuqySFZO6BMrfrKFQqMKKle+rhJWVFczMzFSk+f1+sCxb0zoCzbs3KZ+SZZDqZFLeldxLdf2xFfk8r8yDwSBYlpXzEQgEMDs7i9nZ2YrzzMzMyNfiOO7Mc9YDFWQNBEHAvXv35O163aVgMIhQKASAvFldLpf8gBcWFir61ZaXlzE3N4epqSmsrq7i/fffl8+zsLAAlmXPvbYgCPD7/QgGg3C5XPLbOhwOQxCEM+txzby35eVlLCwswOl0IhwO46OPPlJ0L36/X85jIBCA2+0+YXGbnc9aZc7z/AkL7XK5KsTI87xcP19aWoLH4wHHcWc+x7poqG32miP1pamB0/rgLtJ10Yxuj0ZopD+x06B1yBpEo9F2Z4HSoVBB1qC3t7fdWQBA3LdG6yJq4zrdSyvRiCKdde4qcpHukYscS2ktVJAUioqgLiuFoiKoICkUFUEFSaGoiI4MDDg6OsL29jZsNhs0Gk27s0O5xoiiiFQqheHhYWi159u/jhTk9vY2xsbG2p0NSgexubmJ0dHRc/frSEHabDYApJB6enranBvKdSaZTGJsbEz+zZ1HRwny4cOHePjwIYrFIgCgp6eHCpJyKSitGnVkP2QymYTdbkcikaCCpLSUen9rtJWVQlERHSXIhw8f4pVXXsHU1NSZ+/F7+9hN5S4pVxTKMdRlreFG/OnxHta/j2O8z4w7t1iMseY25JJyHajXZe2oRh0l/Dsfxe//zGPEYQIAPIlkMGQ34s4tB24PWGm/JaWlUEFW8b/+soE/fRsBANywG/HTUTuKRyJ2Ejk4zN2YvMXi5Rs2dOk6ytunXBJUkFV4/4sTyWwBf9uI4nkih+eJHP78bQQ/GbbjJyM9iGcO8Vc+gtdvOvDqiB3Gbl27s0y5RnRUHbK8H/Lx48dn1iH/9HgPX24n8OWzJPbzBQCARgM4+6z46agdow4TDN06vDpih+uWA1YDfbdRTlJvHbKjBCmhtFEHAIpHIvi9fXy+lcCWkJX3YS16vDZqx4+GemDS6/CjIRvujLNgLfpLuw+K+qGCVMB5hZTMHeIfz5L4eicJIXMop0f28/h8K4Gvd5I4LJJi0+u0ePmGDT8dZdBr1YPrt2Jq3IEbdtOl3Q9FvVBBKqCeQtoWsvjqeRKPX+wjd0hC7vKFIr56nsJnW0KFYMdYE14bZTDRa8FYrxl3bjkw0WehLbMdDBWkAhoJnSsUj/Akmsaj5yk8iaRRPBIhiiKexjL4fCuBjUgaUkHajF14dcSOHw/34CZrxuQtFi8N2aDTUmF2GlSQCrhoLGv2oIjHL1L46nkSzxMkoieZPcQXzxL4cjuB3OERAECn0eAHg1a8NsrgB4NWTN5y4CcjdnTTLpOOgQryDJS2stZDPH2Ar54n8dVOCsnsIQrFI3y7u4/PtgS8SObl/QZsBkzecuCno3a4bjrw2hhDu0w6ACpIBbRitIcoingmZPHV8xS+3U0hf3iEnUQOn28JeLy7j+IRKeZeix4/n2DxynAPXhtj4LrpgIV2mVxbqCAV0OrhV4XiEfhIGl89T+JJJIP9/CE+30rg000BBwXizvZZ9fj5RC9eGrTixyN23LnFwm7ubnpeKO2FClIBlzkeMnNQwDc7KTx6nsRmNIPQpoC/PxVwUCTC7LcZ8MYEC2e/FS+V+jL7bYaW5olyeVBBKqBdA5S/293HX76LYFvIIvQ0jr9vCnJ/5oDNgDe4Xoz3muEcsOLOOIsRhvZlXnXoaA8Vc3vACq7Pgi+eJdBr1eP1MQdCT+P4bEvAbiqP//vZNgZ7iDDDu/sYZc2YGmcx0Wdpd9YplwQV5CWj1Wrw2hiDl2/0YO37GOzmbrx+k0Hoe0Fumf0/f9/GDbsRP59gsRXLYKDHiKlxFj8cpMO/rjsd5bK2otvjoqTzBfw1HMU/tpNI5Q6x/jSOz7cScqvsDbsRv+B6MeowwWHR484t0kJLgwyuBrQOqQA1TnIV3c/j376LgN9LI50vYO37OL54dizMEcaENzgWow4zrIYuuG4xeHWEgb6LBhmoGSpIBahRkBJb8Qz+7dsInidy2M8XsPYkhi+fJVEsPaZRhwlvcL0YYUwwduvw2pgdr485YNLTIAM1QgWpADULUuLxixT+8l0EQuYQqdwh1p7E8eV2AiWDiZusGW9wLG7YTdB3afHj4R5M3nLAZqR9mWqCClIBV0GQABmL+fmWgL9txJA9KCKZO8TqRgyPnidlYd5izXiD68WQ3QidVoMfDdkwNc7CQcdlqgIqSAVcFUFK5AtFrD2J49OncRwWRSSzh/jkCRGm9PTGe4kwB3uMZGaDfism+iy4YTeCtehp62yboIJUwFUTpEQqd4i/hqOyEIXMAT55EsPXOylZmBN9FrzBsRiwGeXjjN06DDNG3LCbcMNuxJDdSEecXBJUkAq4qoKU2Evl8ZfvItiIpAEA8cwBPtmI4ZudlDwm09lvwQ8HbWAtejjM+opuEp1Wg36bAcOMCcN2I24wJjonUIugglTAVRekxGYsgz9/G8GLJBmTGU8f4G9PiDDL0WgAxtSNXosBrFWPXov+hFDtpm7Zig4zJvRZqZvbDKggFXBdBAmQYV/fvEjhL99FkcyS6URi6QN8tilgbz+P6P6BHMheTYVQLXr0WolQGXM3LIYuDPUYS1bUhCG7kfZ5NgCNZT2D6r+juw5oNBr8aKgHt/ut+GwrgU82YmAtevzTjwYAEMHu5wuIpQ8QTR8gVlokocYzh4hnDoG98nMSobIWvSzWfpsBtwcsGGHM6LMZ0G8zoM+qh6GL9n82E2ohr7iFrCZ3WMQnGzF8timgcHT6oxVFEel8EdF0vqZQa6HRAKxZjyG7EUM9RtxgjJjos2DAZkR/SaT9NgN6aF+oDHVZFXCdBSmxny8gtn+A9EEBmYMiMqXP7EER6YMCsgdFZA6KcmieRLlQy63qaULt1mkw2EMEKgm110qspyxSqwG9VkNHxt9Sl5UCALAauhS1nOYOiTDT+QKypfVMnoi3XLjpPHFtd1N57CRy2Enm8CKZw2FRxFY8i6348STSNmNXhUAHbAYYunVwWPTotxrQb9Oj30qsKg35q4QKssMxdutg7NYpmnH9oHCEvf08NmMZbMWzeBbPVAh0J5FDNH2AVK6AVG4f3+7uAwC0GqDPasCQ3YgbPUYM2o1gTN3QaDSwGbswzJhwe8CK8V5LxzccUUFSFKPv0mKEMckzGRSKR3ieyGErnsVmPIOdRA6ZgwJ2k3lZoDvJHDIHReym8thN5fE5EgAAY7cWgz1EoDcYEx5tJ2Ho0uJmrxnOfiuc/daOtJ5UkJSG6dJpMcaaMcaa8Qv04rB4hOdCDlvxDDbjGbxI5lEoHiGVK1QIdDeVR+7wCN9HM/g+mgFA/pJhvNeMiX4LxnstMOu7MOIwwdlvwe0Ba8cEzVNBUppGt45YuJu95B+nDwpH2BaysgXdTeZxJIooHomI7BNX93kyh81YBpmDIh7v7uPx7j40GjL+k+uzgOu3gjF3Y7DHiNsDVtzut17rwHnaynpNW1nVSL5QxLaQk+ugu6kcRJG07L5I5sFH9sHvpRFNH1Qc12vRY6LPAq7fgqEeI/psBtzut+L2gBUDPcZTrqYOaLeHAqgg1UHusIhnQhZPoxk8iablPy5KZA/B7+2Dj6TxTMii/Bdq1uuIOPssGGPN6LUaZLd2hDGpLtzv0gQ5NTWF+fl5/PrXv27k8LZCBalO4ukDbETTeBJJ41k8i8KRiNxhEd9HM+Aj+3gSyVT0heq0GtxkzeD6LJjos6DfZoCzZDnHWLMq+j0vrR/S6/WeEOPHH3+MN998s9FTth1RFJHP58/fkdISTDrglQETXhkw4aBwhJ1kFs/iWYzZu/GzYTOOROB5MocvtjMIR/aRyhWwEUnLo16GeoyY6CfWc5gxgusj4rx1hbpTGhakRqPBb37zGzidTnAch1gshuXl5SstyO3tbSSTyXZng1LGkBYYYsnsCcUjEYd9Xbgz2INwug/R9AH4vTT4yD5eSF0tyRz+Go6ix9gFrp/Mg3ur14zxPuLWOvutqv6To4YF+d5778HtdiMSiSASiQAAYrFY0zKmlEAgAABYXV3F4uJiw+cpFApIJpPo7e2lbqyKSSaTMEcieJkbxNN4HhN9afyHHIt0nljL8N4+NuNZJHMF/H1TwN83Bei7SJcK10dmUZjos5BRLAwZzaImgTYsSJ/Ph7feeqsi7aOPPjr3OEEQ4Pf7AQCzs7NyuiSsWCwGjuPgdrvPPVcgEADDMHC73eB5Hn6/H16vt57bkCkUCgAAm80Go1HdLXedjCiKiEajuOkw4oc3GABkwPaTKHFdnws55AtFPI1lwO+RtOxhEY9f7OPxi31oNcAwY8KYw4xRBxlWNmAzyONARxhTW//0qGFBvvXWW0gmk/jwww8BAG+//fYJgdYiGAwiGo2it7dXTuN5HisrK/D5fACA6elpRYL0eDzyejgcxszMTL23cYLLaKXjeR4zMzNwuVyYn58HwzAtu9bS0lLFi69e7t69C47jsLi4CJ7nMT09jeXlZbhcLgSDQfh8Prz//vstvYdyaj0fKYh9apxF7pCI8UkkjSfRNAlKSOTAR9LY2EsjljmoiL3t1mkqBCqNVpEs6AhjQp/VAO0lNRA1LMiNjQ35YQHA4uIilpeX8bOf/ezM4zweD2KxGARBkNOCwWDFA2UYBsFgEG63G4FA4IQrzLJshRiDwSAmJyfhcrkavR0ZURSROShc+DwSpm7diR8Rx3HgOA737t1r+Q/5ImIESGt6eR5jsVhFOS8vL1/o/M3G2K3DDwdt+OGgDaIoYi+Vx0ZJnDuJPKLpPJ7GMtiKZbElZE5EDBlK4YFjLBFor0UPQ7dOHqw9wrR2sHbDgvzDH/6AtbW1irT5+flzBVmLcDhcYTFZlpUFWy68WoRCIQiCAK/Xi1AoVFOU+Xy+ovX0rIab7OERXO/+vzrv4HQe/euvYNYrL+alpSW4XC7wPC+733Nzc5ienpbTQqEQ7t+/j5mZGbAsC47jcP/+fczPz4PnebjdbvkcMzMzWFlZkY+p3ke6JsdxWF1dPeGdSOkAKWupesCyLFiWbVo5tQKNRoOBHiMGeoz4Odcrd6FsRNL4PkpmiI/sH2AzLgXLZ5EvkP/25Estt6ZuHUYdJow6iEgZUzd0Wm1pTqLSjApNnJOo4bNMTEycSLtz586FMlOOkgYinudlK72wsHBqo87CwgLefffdpuWtFZTXrVmWhc/nkwU5Pz8PgAjT6/XKQqquL3s8HvA8D5/PB5fLBY7jZOsmHVO9jyAIiEaj8Hq9WF1dPVFV4DgOH3zwAYLBIDweD1ZXV8HzPEKh0LkvS7Vh7NbhpSEbXhoi1nM3lZdd250EibvdTeVLsbhZbAtZZA+L+Hb3eOSKxaCT3dsxhxk9JlLf/G+v3sBLQ7YL57FhQfI8fyJtY2OjoXM5nc4KF1Zq2DkPjuMQDofP3W9+fh7vvPOOvJ1MJjE2NlZzX1O3Fo/+9VfnZ1ohJoUteH6/H9FoFPfu3YPL5ZJdQZ7nsbi4iMXFRdlzYBjmRPkoLa9qGIbB1NQUYrFYzRcax3EIhULyttPplOuNVxmNhgysHiyznk9j5daTDN7eSeawVQr1e57IIZ0v4uudFL4uTSTWY+zCGGuGXqeFw9JdMf1mIzQsSLfbjV/+8peYnJwEQOpxjXY7uN1uzM3NyduSS9UsDAYDDAaDojl1NBoNTHW4mI3A8zzW1tbgdDrlBi2GYTA/Pw+/349YLCa7pzzPg2EYrK2tyXVryR2VXHRpned5BINBWUA8z8sLgJr7AKTFnOM4OJ3OE3VOhmHgcrnk58FxHKanpy+tEeeyqFX3fFIK6RtzmHEkiigUj7CdIKNZtuJZ7CRzSOYK+Md2Ev/YTuJIFPE/3vrBhfJxoVjWjY0NuWX03r17eP311889RmqZEwQBMzMzsttT3u1R3WjTbGqFM+VyOWxsbGBiYqKjuj2Wlpbg8XjAcZzsyl6kP7fVtOM55Q6L2JStZwb7edLoJ41m2YxnkMwVsPjPP8XkLUfFsTSWVQFUkMeEQiGsra3JglTaB9wu1PCcpH7PJ5E0nidyKB6J+NWPh/DK8EnB0VjWM7iO00BeFJfL1ZTuok6ivN8zXyDWU2rcuSgdFcv64MEDPHjwQH5rUSgXxdClw+2Bi7euSlz5WFYK5Tpx6bGsFArldBqO/5mbm8Mf//jHijQlsazt5OHDh3jllVcwNTXV1nxIMaFzc3MV/a+tYGlpqaXnb5SlpSXV5q2dNCzImZmZmo06aubBgwd49OiRHApWE1EEDtLNW2o0Yl+lWNZWoeaW3HbSUY06ijjMAIvnR70o5n9uA3qL4t3VFstaHtz/9ttv13yBnJa/064l5a0aQRDk0UNerxdzc3Oq7hNtBQ1byPfeew+iKCISieCTTz7Bd999h2g02sy8dRSCIMguHMuyWFlZkb+bn5/HnTt35CCM8lhWj8dTEafq8XjwwQcfAMCpsazl+0ixrJIIy8XI8zwWFhbkkLvTrPlp+au+liR8t9tdM+5ZCpmUgtZrifa601GNOor6IbvNxKo1i26zot3UGMsqWdiz3Eul+VOCNO5ycXERoVAIU1NT8vk6BcWC/Pjjj+U3Vvlg5I8++kiOpXQ6napu2FHUD6nR1OViNsJViWV1u91YWlpCMBiEIAjyCJLqe6mVv1rXmp2dxdzcHBiGkd3o6jru9PQ0gsEgeJ5HNBoFz/OdFbggKoRlWfHTTz899ft4PC6yLKv0dG0lkUiIAMREIiGnZbNZ8dGjR2I2m21jzi6fxcVFMRwOi6IoiuFwWJydnW1zjs7mqj2nWr+1s1BsIe/fvy8PPn7y5EnFd+Pj42AYBvfv32/em4JyKbjdbgSDQTmWdXp6ut1Z6mgUC7J8RH88HofX68W9e/cqRmU4nc7m5q7J0FjWk9BYVnWhuJW1vGL9+uuv4+2338Zvf/tbjI+Py+lqm8a9GiX9kGLn/bPCleK6Px/FFpLneaRSKblANBpNxTYARaP31UpXFymKVCql+hdLJ5NKkZH60vO6bigeD6nVait+qKIo1ty+Cu7gaWPUnj17RmcuvwL09PRgZGSk3dlQRMvGQ0qRE6fNNBaNRq98bOLw8DD6+vquvVt0ldFoNNDrr+//QyoW5MzMTM2Z5iTsdntTJipuJxqNBgaDod3ZoHQwiht1lMyXo2SfdqKW0R4UymnQP2ylf6xDaSH1/tauxp/mUSgdAhUkhaIiqCApFBVBBUmhqAgqSApFRXSUIGm3B0Xt0G4P2u1BaSG024NCucJQQVIoKoIKkkJREVSQFIqKuJ6jPC/KzhdAJgpYhwDrAGBykNnoKJQWQwVZi/1dYPOT4+0uPWAdPBaobQgw9wFa6mBQmgsVpBIKB4CwSRYJbRdg6SPitA4ci1XXnD/upHQmVJDVPP134NsV4CADWPuJ8GpxVABSO2SR0GgBM3ssUNsgsazdpsvJO+XK01GCVDQN5BfLwOrvSxsaYgUtAyWRnSMw8QhIR8jy4tFxutF+XBc1MYBRWuyArqMeAeUcaKROdfTE6u+B0P8GIo+Bw2ztExh6KgVqHSRp9Tb8aDSA3kqEKQu1bN1go41JV5yWTXLVMUz9C+CYAJ7+DTjYB/ZflJZd8pkTgHySLNHvjo/rMhKRWgaJq2oZAMy9gFZ3+rVEEcinyJLYOvm9VkcEWi1UaZ26wtcOKsjT0GiIhTLYgN7bx+mFXEmcJYGmXxAXtZADhKdkkc+hAyz9JStaEqhk+c4SqsRREcjEyFKLLkOVUJlK0Wq0xI2Wl2LVtli1XVqOiqfvY7CRe+mik4G1AirIeukyAsxNskgcFYFMpMyalixq8QDY3yFLBRrA2FMloLL1LqMyV7WQP345XCYaDcmnbbDKbbdebj6uIVSQtai33qbVHf8oJUSRuLfV7m4uQVpocwmyCN+fPJ/OAJjsNaweQyyfEuvaSkQRyMbJsvv1cbreUtYNVCoPGlRRF7RRp1ZFWxSJm7j/AkiXuaf5/YtfXBRJ3TQnAFmhJExpXSDfnYeh2rqWua3d5voEIIrkBVG+FA+r0g6BYmndYAN6RpS7rHJQxeBxd5Clr/0vlUui3kYdKsh6xkMepEsWb+/YNc3ESN2qWRQPj0VaLtRcgqwfHZ59vLa7JE47AI0CsRUayKSGuKv2m4B9jCzdRuWHa3WkPm0bIkKV8qqRFm1pW3vOdmlRtK+2bP/LgwpSAU0doFwsAOm9Sku6v0vqd81GFIHDTJlIhcr1fOqCF9CQSCOtjghb23W86EqfmSh5OVRjGQCYMSJSZkzxX7lfOhoNuY9uE8ljt7ls3UQWvaUqrU6vowza7XHZ6LqAnhtkKScrlAn0BRFtLkFE1SjS363rLYC9xp/NlNdNJdFUiKqWyMrTFLqRuSSQ2AQST0k4YTZGXkjpXeDZOtnH3HcsUPuYOhp8joqkNVwsAl0mQKfwj5U0GtLQVi5aaV0SL3OzZOkvBrWQlzmFx1Gx5HrGiWCz8ZKVK30WG3EfVUB+vyTQTdLtk4mc3MfkOLae9puklbkRRJG0XheywGGOCKyQI0EchVwprXo9T76vdve1XUSY3cbSZ2mR0uT1qnRNjUEFL/93YOjVE8nUZVWAKufUkRp7JLFKQpWEe1rUkBo5yADJUjB+4mntbhmjnVhO5iYRayFfKaxyQcnCK63jgj9ZqX+2UboMx0KVPgdeJkElt35RsSt1Wa8q5YEI5X2cEoX8Sasq1x+TF29Y0upKPzQjoNOTT2lb/jQS67f3DWngOg29Geh7iSwAEVFyi1jPxCYJyJfc6hdfNpZfja4kCGOZhSvl8ax1qXW43MoeZkvr2bL1qnTJ0gKll0eelL3E7j+A8f90QpD1cuUF6ff7wXEcVlZWsLi42O7stI4uA2nZtA2e/K7cFS5v6NFoTxdWdVo9w8Z+8EsirL1vyHJeY1K3kUQ7SRFPhTyQfHZsQQ/SpwjIeCy66vWLDnPrMpQineo4Rjwqs9rZSsHaR4Hhi//726ULUhAE+P1+AMDs7KycHggEAACxWAwcx8Htdis6FwC43W74fD7wPA+O45qfabWj1ZFhX+baf6bbdDSa42il224irr2vgb3HtVtgq+kyACxHlsvIq8lRijMuBSzoLcducSF3XMeU3OYKl7n0vXhEXnB6M1mqOaUOWS+XLshgMIhoNIre3l45jed5rKyswOfzAQCmp6cVCZJhGHi9XtlKdqQY241GQ6yDfbQkzuclcX5DLPZl0qUvGypXEqCln6RfFLmOWybS8gYjc9/Fr4E2CNLj8SAWi8nWDSAiZRhG3mYYBsFgEG63G4FAALFYZXA1y7LweDzyttfrxczMTOdaSDUhdQE5/wlIvTgWZyba3OuYmMrAfesAiVRqVce/7OJevGvjzMu09OwKCYfDFRaTZVlZsOXCqyYQCIBhGLjdbjidTgQCgQo3WCKfzyOfP+6oTyYV9j9RLoZU5+X+K4luinxDBLq/p/wcuq5j4ZVbv2s62kQVgqxFtVWshdvtRjAYRCAQQDgcll3eahYWFvDuu+82O4uUerD2k2X8P5Nww72vyZJ6cbyPNLSrvL5ncnTUZGKqEKTT6axwYaWGnfNgGEa2oGdZ0vn5ebzzzjvydjKZxNjYWOMZplwMMwvc+o9kycZJQ5BloHZjSYehileP2+3G6uqqvM3zvKJGHaUYDAb09PRULBSVYHIAjnEqxhJtaWVdWVmBIAjgOA4ejwccx+HevXtyA878/HxLrq1okisKpY3Q0DlqLSkthP4dHYVyhVFFo85lIbmshQIZVUG7PyitRvqNKXVEO9Jl3draoq2slEtlc3MTo6Oj5+7XkYI8OjrC9vY23nzzTaytrQEApqamsLq6KneJbG5uNr1+KV2jmfuftU+t75SknbbdqrKpt1yUHFNvudRKP6+slJSLKIpIpVIYHh6GVkF/ake5rBJarRajo6Po6uqSC1Cn01UUZiu6R6qv0Yz9z9qn1ndK0s7bbnbZ1FsuSo6pt1xqpZ9XVkrLxW5XHm7X0Y06Dx48qLl+Gddr1v5n7VPrOyVp5203m0bOf94x9ZZLrfTzyqoV5dKRLutZ0C6R06FlU5tmlktHW8haGAwG/O53v4PBcD2Dly8CLZvaNLNcqIWkUFQEtZAUioqgglRAIBDA5ORku7OhOgKBAAKBAObm5tqdFdXh9/sRDAbrLpuO7Paod14fj8dz6ljL60Q95VI+OJznefj9fni93rbk+zKop2wuMtdTRwqymfP6XCfqKZfy8afhcBgzMzOXnt/LpJ6yuchcTx3psno8Hjidzoq00+b16SQaKZdgMIjJyUm4XK7LymZbaKRsvF4vBEEAz/OKr9ORgqzFWfP6dDJnlUsoFIIgCPB6vQiFQm3KYfs4rWwCgYAsTGmuJ6VQQZ6BNK9PMBgEz/N1Fex1JhaLged53L17Fz6fD5OTk4rmQOoEYrGYXI+U5nqqNfHaaXRkHbIWZ83r43a7EQ6H25Sz9nJauXAc17FlInFa2Sid66kW1EKWaPW8PlcVWi6n04qy6chInWAwCJ/PB0EQMDMzI7/Fypuwqydj7gRouZzOZZVNRwqSQlEr1GWlUFQEFSSFoiKoICkUFUEFSaGoCCpICkVFUEFSKCqCCpJCURFUkJS68Pv9cDgcHRlMfhlQQVLqwuv14s6dO+3OxrWFCpJCURFUkBSKiqDDryjnEgqF8MEHH2BqagoA6NjHFkIFSTkTQRBw9+7dirGPCwsLbczR9Ya6rJQz+fDDD0/Ml8OybJtyc/2hgqRQVAQVJOVM3G73iT7HemZRo9QHHaBMORepUWd6ehqCIGBhYQEcx2FxcbGuOUcp50MFSaGoCOqyUigqggqSQlERVJAUioqggqRQVAQVJIWiIqggKRQVQQVJoagIKkgKRUVQQVIoKoIKkkJREVSQFIqK+P8o6tGxxWs0owAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bs = 16\n",
    "lr = 1.\n",
    "ntr = 1024*10\n",
    "ln = False\n",
    "opti = \"SGD\"\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2, 1.5))\n",
    "leg = []\n",
    "for model in [\"matrix\", \"learnable\"]:\n",
    "    groups = df[(df.model == model) & (df.batch_size == bs) & (df.lr == lr) & (df.ntrain == ntr) & \n",
    "            (df.optimizer == opti) & (df.layernorm == ln)].groupby('d')\n",
    "\n",
    "    errs = groups.error.mean()\n",
    "    std = groups.error.std()\n",
    "    a, = ax.loglog(errs.index, errs)\n",
    "    ax.fill_between(errs.index, errs - 0.5*std, errs + 0.5*std, alpha=.5)\n",
    "\n",
    "    leg.append(a)\n",
    "\n",
    "ax.legend(leg, ['Learning $W$', 'Learning $e$ and $u$'], fontsize=6, loc='best')\n",
    "ax.set_xlabel('d', fontsize=10)\n",
    "ax.set_ylabel('Error', fontsize=10)\n",
    "ax.set_title(f'$\\gamma$={lr}, $|B|$={bs}, $T$={ntr}')\n",
    "fig.savefig('figures/embeddings.pdf', pad_inches=0, bbox_inches='tight')"
   ]
  }
 ],
 "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
