{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cc88e2b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "import gooseberry.gooseberry as gs\n",
    "\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "import numpy as np\n",
    "\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "\n",
    "from tools import BlindColours, zero_balanced_weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3d5cfd78",
   "metadata": {},
   "outputs": [],
   "source": [
    "bc = BlindColours()\n",
    "blind_colours = bc.get_colours()\n",
    "div_cmap = bc.get_div_cmap()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "8796bf21",
   "metadata": {},
   "outputs": [],
   "source": [
    "def logs(params, X, Y, out_dim):\n",
    "    w1 = params[\"network\"][\"layer-0\"][\"w\"][0]\n",
    "    w2 = params[\"network\"][\"layer-1\"][\"w\"][0]\n",
    "    w2w1 = w2 @ w1\n",
    "    w1w1 = w1.T @ w1\n",
    "    w2w2 = w2 @ w2.T\n",
    "    return w2w1, w1w1, w2w2\n",
    "\n",
    "logs = jax.jit(logs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "15b746b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(1)\n",
    "\n",
    "in_dim = 8\n",
    "hidden_dim = 14\n",
    "out_dim = 8\n",
    "\n",
    "learning_rate = 0.05\n",
    "training_steps = 2000\n",
    "\n",
    "training_data, _, _ = gs.datasets.Hierarchy(False, True)\n",
    "\n",
    "network_functions = []\n",
    "w1w1s = []\n",
    "w2w2s = []\n",
    "lossess = []\n",
    "\n",
    "for i, (w1_init, w2_init) in enumerate([(gs.init.Normal(0., 0.0001), gs.init.Normal(0., 0.0001)),\n",
    "                                        (gs.init.Normal(0., .42), gs.init.Normal(0., .42)),\n",
    "                                        zero_balanced_weights(in_dim, hidden_dim, out_dim, .44)]):\n",
    "    \n",
    "    if i == 2:\n",
    "        w1_init, w2_init = gs.init.FromFixedValue(w1_init), gs.init.FromFixedValue(w2_init)\n",
    "\n",
    "    network_function = []\n",
    "    w1w1 = []\n",
    "    w2w2 = []\n",
    "    losses = []\n",
    "\n",
    "    X, Y = training_data(None)\n",
    "\n",
    "    task = gs.tasks.FullBatchLearning(training_data)\n",
    "    optimiser = gs.GradientDescent(learning_rate)\n",
    "    loss_fnct = gs.MeanSquaredError()\n",
    "\n",
    "    mlp = gs.Network([\n",
    "        gs.Linear(hidden_dim, bias=False, weight_init=w1_init),\n",
    "        gs.Linear(out_dim, bias=False, weight_init=w2_init)\n",
    "    ])\n",
    "\n",
    "    trainer = gs.Trainer(task, mlp, loss_fnct, optimiser)\n",
    "    state, params = gs.assemble(1)\n",
    "    \n",
    "    w1 = params[\"network\"][\"layer-0\"][\"w\"][0]\n",
    "    w2 = params[\"network\"][\"layer-1\"][\"w\"][0]\n",
    "    network_function.append(w2 @ w1)\n",
    "    w1w1.append(w1.T @ w1)\n",
    "    w2w2.append(w2 @ w2.T)\n",
    "\n",
    "    for training_step in range(training_steps):\n",
    "        state, params, loss = trainer(state, params)\n",
    "        w2w1_, w1w1_, w2w2_ = logs(params, X, Y, out_dim)\n",
    "        network_function.append(w2w1_)\n",
    "        w1w1.append(w1w1_)\n",
    "        w2w2.append(w2w2_)\n",
    "        losses.append(1./8. * loss)\n",
    "    \n",
    "    network_functions.append(network_function)\n",
    "    w1w1s.append(w1w1)\n",
    "    w2w2s.append(w2w2)\n",
    "    lossess.append(losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0f707f21",
   "metadata": {},
   "outputs": [],
   "source": [
    "def arange_svd(Y, u, vt):\n",
    "    sort = np.sign(np.abs(np.round(Y.T @ vt.T)))\n",
    "    idxs = np.where(sort == 1)[1]\n",
    "    u = u @ sort.T\n",
    "    sgn = np.diag(np.sign(np.sum(u, axis=0)))\n",
    "    u = sgn.T @ u\n",
    "    vt = sort @ vt\n",
    "    vt = sgn @ vt\n",
    "    return u, vt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f47c78b7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 525x250 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sigma_yx = 1./8. * Y.T @ X\n",
    "U, S, VT = np.linalg.svd(sigma_yx, False)\n",
    "U, VT = arange_svd(Y, U, VT)\n",
    "\n",
    "max_val = np.max([U, np.diag(S), VT]) * 1.05\n",
    "\n",
    "fig, axs = plt.subplots(1, 3, figsize=(5.25, 2.5))\n",
    "axs[0].imshow(U, cmap=div_cmap, vmin=-max_val, vmax=max_val)\n",
    "axs[1].imshow(np.diag(S), cmap=div_cmap, vmin=-max_val, vmax=max_val)\n",
    "axs[2].imshow(VT, cmap=div_cmap, vmin=-max_val, vmax=max_val)\n",
    "for i in range(3):\n",
    "    axs[i].set_xticks([])\n",
    "    axs[i].set_yticks([])\n",
    "axs[0].set_title(\"$\\\\tilde{U}$\", pad=9., fontsize=22)\n",
    "axs[1].set_title(\"$\\\\tilde{S}$\", pad=9., fontsize=22)\n",
    "axs[2].set_title(\"$\\\\tilde{V}^T$\", pad=9., fontsize=22)\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"./figures/figure-3_b-top.svg\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a11896e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 350x250 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sigma_yx = 1./8. * Y.T @ X\n",
    "U, S, VT = np.linalg.svd(sigma_yx, False)\n",
    "\n",
    "max_val = np.max([np.max(U@np.diag(S)@U.T), np.max(VT.T@np.diag(S)@VT)]) * 1.05\n",
    "\n",
    "fig, axs = plt.subplots(1, 2, figsize=(3.5, 2.5))\n",
    "axs[0].imshow(U@np.diag(S)@U.T, cmap=div_cmap, vmin=-max_val, vmax=max_val)\n",
    "axs[1].imshow(VT.T@np.diag(S)@VT, cmap=div_cmap, vmin=-max_val, vmax=max_val)\n",
    "for i in range(2):\n",
    "    axs[i].set_xticks([])\n",
    "    axs[i].set_yticks([])\n",
    "axs[0].set_title(\"$\\\\tilde{U}\\\\tilde{S}\\\\tilde{U}^T$\", pad=9., fontsize=22)\n",
    "axs[1].set_title(\"$\\\\tilde{V}\\\\tilde{S}\\\\tilde{V}^T$\", pad=9., fontsize=22)\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"./figures/figure-3_b-bottom.svg\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d97872bc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "labels = [\"Gaussian Small\", \"Gaussian Large\", \"Balanced Large\"]\n",
    "colours = [blind_colours[1], blind_colours[2], blind_colours[3]]\n",
    "fig, ax = plt.subplots(figsize=(4., 3.))\n",
    "for i, loss in enumerate(lossess):\n",
    "    ax.plot(loss, lw=3., color=colours[i], label=labels[i])\n",
    "ax.legend(loc=(.175, 0.38), title=\"Weight Initialisation\", frameon=False)\n",
    "ax.set_xlabel(\"Training Steps\", labelpad=-12)\n",
    "ax.set_ylabel(\"Loss\", labelpad=-15)\n",
    "ax.set_xticks([0, 2000])\n",
    "ax.set_yticks([0, 0.8])\n",
    "sns.despine()\n",
    "fig.savefig(\"./figures/figure-3_f.svg\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c8a7e55a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA+MAAAFQCAYAAADURa8iAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABf4klEQVR4nO3dd3hUZfr/8c+Z9EKXmlVpJqCAqFQRFRZBaYKwX1QgwmJDsCNVsAPigtIRRam6K1UXUIqKSFi6oDSJgAihCoQkpGfO74/8MhJSmDkzmbT367pyXcmcc5/nmZnMPec+5XkM0zRNAQAAAAAAr7EVdgcAAAAAAChtKMYBAAAAAPAyinEAAAAAALyMYhwAAAAAAC+jGAcAAAAAwMsoxgEAAAAA8DKKcQAAAAAAvIxiHAAAAAAAL6MYBwAAAADAyyjGUaAiIiIUERGhrVu3FnZX8P8tW7ZMERERatu2rUvLgKKIHAMUHydOnHB8Zk+cOFHY3SkW2rZtq4iICC1btqywuwKgAPgWdgeKK7vdrm+//Vbfffed9uzZo/PnzyshIUHBwcGqWrWq6tevr9atW6tt27YKDQ0t7O7CgsuXL2vJkiX69ttv9dtvvykuLk7BwcGqVKmSatSoodtuu0133HGHmjVrJh8fn8LuLkoYckzJ1rdvX23btk3NmjXTggULCrs7KCWmTp2qadOm5bosMDBQVatW1W233aZevXrp9ttv93Lv4Glt27ZVTEyMunfvrvHjxxd2dwDkgmLcgj179mjYsGE6evSo4zEfHx+VKVNGiYmJio6OVnR0tL766iuFhobq2WefVb9+/Qqvw4WoVq1akqSgoKBC7olrDh48qKefflqnTp1yPBYQECDTNHX06FEdOXJEmzZtkiR9++23+tvf/lZYXUUJRI5xXnHNMUBhu+666xy/2+12Xbp0SceOHdOxY8e0YsUKDR48WM8++2wh9hAASj6KcRetX79eL7zwgtLS0lS+fHk99thjuu+++1S3bl0ZhiFJOn/+vHbs2KEvv/xS33//vVavXl1qd5S/+eabwu6CyxISEvTkk0/qzJkzqlChgp555hl17txZFStWlCQlJiZq//79+v777/Xll18Wcm9R0pBjXFMccwxQFERFRWX7OyMjQ7t379Y777yjffv2adq0aWrVqhVnyAGgAFGMu+Dw4cN65ZVXlJaWpoiICH300UeqWrVqjvUqVaqkDh06qEOHDoqOjtbixYsLobewavXq1Tpz5owkadasWWrcuHG25cHBwWrSpImaNGmiF198sRB6iJKKHAOgsPj4+OiOO+7QjBkzdM8990jKvPKLYhwACg7FuAsmT56sxMREBQcHa/r06bnuJF/tpptu0siRI3M8npaWpo0bN2rDhg3at2+fzp49q9jYWJUpU0Y333yzunfvrk6dOjnOhF1p2bJlGjFihMLCwvTdd9/l2u6JEyf097//XVLul1EfPnxYc+fO1bZt23T69GnZ7XZVrFhRVatWVYsWLfTggw+qTp062WJOnz6tTz75RFFRUYqJiVF6errKly+vKlWqqEmTJurcubMaNWqULSYiIkKSNH/+fDVv3jzbskOHDmnNmjXavn27Tp48qbNnz8rX11c33HCD7rnnHj322GOOs9FXy7oPaty4cercubPmz5+vr776Sn/88Yd8fHx0yy236PHHH9fdd9+da3x+Dhw4ICmz4Lm6EL+ar2/Oj9DVr71hGJo5c6Y2bdqk8+fPq2rVqurUqZOeeuopBQcHO16L2bNna/v27bpw4YKqV6+ubt266YknnpCfn1+ONi5duqS1a9dq06ZNOnLkiM6cOaOkpCRdd911uv3229W3b99r9h1FDzmmdOQYdxw/flxff/21tm7dqhMnTujMmTMyDEPVq1dXq1at1L9/f9WoUSPX2Kz71AcPHqynn35aCxYs0MqVK/XHH38oPj4+22uYlpamhQsXasWKFTp27Jj8/f0VERGh3r176/7778+2rbwuZd65c6c+//xz7dy5U3/++af8/f1Vq1YttW/fXr1791ZISEiBvU6wrlq1aipfvrxiY2OVmJiYY7k7ueVadu/erXXr1umnn37SqVOn9OeffyogIEC1a9dWu3bt8v2/uTIX3HLLLfroo4+0Zs0anTx5UkFBQWrcuLGeeeYZ3Xrrrfn2YdOmTVq6dKl2796t8+fPO+6lb9asmTp37qzbbrstR0xqaqoWL16sb775RocOHdLly5dVrlw5NWrUSA8//LDj4EZukpOT9cknn2jlypU6ceKEQkJC1KBBA/3zn/9Uy5YtXXj1PMdTubNDhw76+OOPtX79ep04cUKJiYnZvi8SExP18ccf6+uvv1ZMTEyO537lth566KFc29uwYYPj/bp48aKCgoIUHh6uTp06qWfPnvL39y+w1wnwBIpxJ509e1Zr166VJHXt2lXXX3+9W9vbtWuXnnnmGcffoaGh8vf314ULF7Rp0yZt2rRJ69at0/vvvy+bzbOD3kdFRenpp59WamqqJMnPz09BQUE6ffq0Tp8+rT179sjPzy/bDtbBgwcVGRmpS5cuSco8gh4aGqo///xT586d0759+xQXF5djRzk/Tz/9tGJiYiRl3o8dFBSkS5cu6cCBAzpw4ICWL1+uuXPnqnbt2nluIzExUX369HH02c/PTwkJCdq6dau2bdumt99+Wz179rTyMikuLk5JSUlu3Yu6f/9+jRo1SnFxcQoNDVVGRoaOHz+uWbNmaceOHZo7d66ioqL0wgsvKCkpSWXKlFFaWpqOHTumyZMnKzo6Wu+//36O7c6fP98xCE/WeyFJJ0+e1MmTJ7Vq1SqNHDlSkZGRlvsO7yLHlL4cY8XIkSO1bds2SZmva0hIiOLi4nT48GEdPnxYy5cv16xZs9SkSZM8t5GSkqK+ffvqp59+kq+vr0JCQrIVTomJiXryySe1fft2SZnvhb+/v7Zv365t27bpqaeeyrePdrtdY8eOzTYwXXBwsJKSkvTLL7/ol19+0bJlyzRnzhyFhYW583KgAJw5c0axsbGS/hqT4UoFmVt69erl+D0oKMjxmd2zZ4/27NmjL7/8UvPnz1elSpXy3Ma5c+f00EMP6dixYwoICJDNZlNsbKw2bNigqKgozZo1S3fddVeOuKSkJA0fPjzbrS8hISGy2+06dOiQDh065Lg96EoxMTF66qmnFB0dLUkyDMORu7777jt99913evjhh/XGG2/kaDM2Nlb9+/fX/v37JWUe4E9PT9fGjRv1448/asyYMS69fp7iidwZGxurhx56SL///rvjO+BK58+fV2RkpH777TdJmfnsyuf+2muv5dvH5ORkDR06VGvWrHE8Fhoaqvj4eO3YscPxXs2ePVvlypWz+lIABY5i3Elbt26VaZqS5JFpn4KCgtSrVy/df//9atSokaOYio2N1VdffaXJkyfrm2++0R133OHxgur1119Xamqq7rrrLg0bNkzh4eGSMnfQ/vjjD61ZsybHmZXx48fr0qVLuuWWWzRmzBjdeuutMgxDqampOnnypL777jvZ7XaX+tG0aVM9++yzat68uaO91NRU7dy5U5MmTdLPP/+sIUOG5Dudx5QpUxQYGKjp06frnnvukZ+fn44cOaIRI0Y47n3r0KGDypQp43S/GjVqpM8++0xpaWkaNWqUxowZo/Lly7v03LKMGjVKt9xyi1599VXVrVtXycnJWrx4scaNG6cdO3Zo+vTpWrhwodq0aaMhQ4YoLCxMly9f1uzZszVr1iytXr1a//jHP3TnnXdm226VKlU0ePBgtWnTRuHh4fL395dpmjpx4oTmz5+vBQsWaPz48WrSpIluvvlmS32Hd5FjSk+OcUe9evV0//33q1WrVrrhhhtks9mUnp6u/fv3a8qUKfrxxx/14osvat26dQoMDMx1G4sWLZIkjRs3Th07dlRgYKAuXrzoKMjHjx+v7du3y2az6aWXXtKjjz6qkJAQXbhwQTNmzNCHH36osmXL5tnHKVOmaMGCBapUqZIGDRqkTp06qXz58kpLS9OuXbs0fvx47d+/X88++6yWLFni8YNBsCYjI0M///yz3nnnHUmZV4d169Ytx3oFmVvatGmjrl27qmnTpqpcubKkzKLrxx9/1MSJE/Xbb7/ptddey3NEeEl68803VblyZc2bN0/NmjWTYRj65ZdfNHToUB09elRjxozR+vXrc/zfjRgxQt98841sNpsGDBigPn36qFq1apKkCxcuKCoqSjt27MgWk5iYqMcff1xHjhxRs2bN9Oyzz6px48by9/dXfHy8li5dqsmTJ+vf//63ateurcceeyxb/Kuvvqr9+/fL399fo0aNUvfu3RUQEOA4Gzx27Nhcr8AraJ7InVOnTlVISEi23Hn69GlHYTxs2DD99ttvCgwM1OjRo9W1a1f5+/vr1KlTmjBhgt555518n/vo0aO1Zs0aXX/99Xr++efVpk0bhYaGKiUlRZs2bdK4ceO0e/dujRw5UtOnT/fsCwR4kgmnTJo0yQwPDzfDw8PNM2fOFHh7X3/9tRkeHm62a9cux7KlS5ea4eHhZps2bfKMP378uKO/x48fdzz+559/WnoejRo1MsPDw81du3a59Dyy2tqyZYtLcQkJCeadd95phoeHm9u3b8+xvE2bNmZ4eLjZoEED87fffsux/Pz582bDhg3N8PBw88svv3Sp7ZSUFLNz586Ovt9yyy1m3759zffee89cvXq1efLkyXzjr3ztO3XqZKakpORY55VXXnGs079/f9Nut+dY59FHHzXDw8PNkSNHutR/0zTNN954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PHgwx/KEhIR8LzPMGqHWNE2tW7cux/Lk5GTNnTs319hrjf4dEBDg+D3rkqT09PR85/e98vJoZ+eLzbr/LLfnL0kzZszQ5cuXndqWp/3888/XPBKdnp6u//73v5Iyi/JatWp5oWeZsv5/fv/991x3dg8cOODoG4oXckzuSlqOsepaz+nzzz936yCOJN13332y2WxKTEzU/Pnzc10nv/+dHj16yNfXVxcvXsxzLI0sqampxe49KC2uvF84q2iU3M8t+bnW//fEiRMtbdcZPXv2lCRFR0frs88+czru//7v/yRlXtqdNShZXq7er+jYsaOkzLPqy5cvz7G+3W63/Fq6wxu58/7775eUOaBdbvsrpmnqww8/zDO+V69ekqRDhw5d8/1KTEy85vcSUJgoxl1Qp04dvffee/Lz89Ovv/6qrl27asaMGYqOjs52VDMhIUEbN27U22+/ned2sgYJGTlypGNETSlzRM/IyMh8R+etVq2a7rjjDknSuHHjtHnzZsf9M3v37lW/fv0cg2Nc7aefflKXLl00d+5cHT582LEDbJqmdu3apddff93RRkREhKTMo6Tt27fXjBkztH///mxHKg8ePOi4LzA4ONgx3cW1ZF26unjxYv3nP/9xJMpz585p7Nix+vjjj7122ffVvv76a7Vp00YjRozQ999/n+0yqaSkJP3www+KjIzUzz//LEl6+OGHsxULBa1Vq1ay2WyKjY3VkCFDHAVbamqqVq9erX/+85/5DmCDooscUzpyzJXS0tJ04cKFfH+yzlBnPaeNGzdq+vTpjsfj4uI0a9Ysvf32224/p7CwMEdhMmXKFM2ZM8ex433x4kWNGzdOS5cuVdmyZXONv+GGGxxTEn388ccaOnRotisg0tPTdeDAAU2bNk3t27fXgQMH3OovPOvcuXN6//33HcVh48aNHWchJfdzS36y/r9nzpyptWvXOvLA8ePH9fLLL+vrr792XLXjaS1atHDcF//WW29p4sSJ2a4OuHDhghYvXqyRI0dmi+vfv7/Cw8OVkpKiyMhILVy4MNs+Q1xcnH744QcNHTpUvXv3zhZ76623OqYYfP311/XFF1848tTJkyf1wgsvaPfu3W7PKCFl7h9cK89kHdz3Ru5s0qSJY7aF0aNHa9myZY52Tp8+rSFDhmjHjh15PvdmzZrpoYcekiS9+eabGjt2bLYDkampqdq9e7cmTJigNm3a5Pl9BRQF3DPuonbt2mnhwoUaPny4jh49qsmTJ2vy5Mny8fFRmTJllJ6enu1eypCQED3++OPZ7quy2WwaM2aMBg8erOjoaPXo0cORcJKSkhQcHKwZM2bkOwDX6NGj1adPH507d079+/dXQECAfHx8lJiYqOuuu04TJkzQk08+mWvsoUOHNG7cOI0bN05+fn4KCQlRQkKC44svNDRUEydOzDb4xvHjx3M818uXLzumMvHz89O4ceOcTtD//Oc/tWbNGh05ckRjxozR66+/rtDQUMXHx8s0TfXq1Uupqam5Hi0uaL6+vkpMTNSyZcu0bNkySZmX6fn6+jqmycjy4IMP6qWXXvJq/2rWrKkBAwboo48+0tq1a7V27VqVKVNGycnJSktL09/+9je98MILDJ5UTJFjSn6OudJPP/2UbSC73ERGRmrUqFHq1q2bVqxYoR07dmjKlCmaOnWqypYtq/j4eNntdscUcu6eTRs+fLgOHz6snTt3asKECZo4caJCQ0MVFxcn0zQ1cOBA7dixQ9u3b892pUOWQYMGKSMjQzNnztSXX36pL7/8UoGBgQoMDFR8fLzjwI5kfQAnuO/qqedSUlKyfceFh4drypQp2d4jT+SWvLzwwgvavHmz/vzzTz377LPy9fVVUFCQo08vvfSSNm3alO+lze545513lJaWprVr12r27NmaPXu2QkNDZRiGow9ZVw1lCQkJ0ccff6znnntOu3fv1ltvvaW3335bZcqUkd1uz5arb7zxxhxtjh07Vv369dPBgwc1evRovfnmmwoKClJcXJwMw9Do0aM1Z84cxxRqVmVNF5efESNGqF+/fl7Lne+++64iIyN15MgRjRgxQmPGjHE8d5vNpjfeeEMzZ85UUlJSrnnmjTfekI+PjxYvXqx58+Zp3rx5Cg4Olp+fnyMnZiHPoCijGLegcePGWr16tdavX6/vv/9eu3fv1vnz55WQkKDg4GDVqVNHN998s+666y61b98+17la27Rpo4ULF2rWrFnatWuXkpKSVLlyZT3wwAN64oknVLt27Xz7UL9+fX3xxReaPn26tmzZori4OF133XXq3r27Bg4cmOe9eg0bNtQHH3ygrVu36ueff9bZs2cVGxsrf39/3XTTTWrVqpUiIyOzTbVRtWpVzZw5U1u3btXu3bt1+vRpnT9/Xr6+vrrxxhvVvHlzRUZGqmbNmk6/hmXLltW///1vTZ8+XevXr9fZs2fl4+OjZs2aqVevXurUqZOGDx/u9PY86aWXXlK7du30448/avfu3Tpy5IjOnz+vxMRElSlTRmFhYbr11lv14IMPOs4eetuQIUNUt25dLVq0SIcOHVJ6erpuuOEG3XfffXr88cevebkcijZyTMnOMVb5+fnpk08+0ezZs7Vy5UrFxMTINE01atRI3bp1U69evTR9+nS32wkJCdHcuXO1YMECffnllzp27JhM01TTpk0VGRmp++67T127dpWU/bLlLIZh6Pnnn9cDDzygzz//XFu3btWpU6eUkJCgsmXLqmbNmrr99tt13333ZTvrCu+6ehAuPz8/Va5cWREREbr//vv14IMP5joeiru5JS9hYWFaunSppk6dqo0bN+rChQsKCAhQkyZN1KdPH911113atGmTpW07IygoSFOnTtWGDRu0ZMkS7dmzRxcvXlRISIgiIiLUrFkzx//9lapWrarPPvtM33zzjVauXKm9e/fq4sWLstlsCgsLU3h4uFq2bKkHHnggR2yFChX073//W3PmzNGqVat04sQJ+fj4qHXr1howYIBatmypOXPmFNhzzo23cmflypW1ZMkSffzxx/r6668VExMjHx8f3XPPPXr88cfVrFkzTZgwQVLuecbf319vv/22evTooS+++EI7duzQ2bNnlZiYqEqVKqlWrVpq2rSpOnTo4NK0mIC3GWZxmdMFAAAUusuXL6t58+ZKS0vTokWLHKPfA4Cn/P777+rQoYOkzIHaqlevXsg9AgoG94wDAACnffrpp0pLS1P58uXVsGHDwu4OgBIoawC3unXrUoijRKMYBwAADgkJCXrxxRe1ceNGxcXFOR6PiYnRu+++65hqLjIyMtd7OQHgWg4fPqxRo0Zp+/bt2e6tP3z4sEaMGOEYs+eJJ54orC4CXsFl6gAAwCEuLi7bqPVZszNcOZ1Rhw4dNGnSJPn6MvQMANcdOHBA3bp1c/ydNUBpUlKS47G+ffvq1VdfLYTeAd5DMQ4AABzS09P1n//8R1FRUYqOjnZMe1S+fHk1aNBA3bp1U4cOHRihGIBlCQkJ+uKLL7R582YdPXpUFy5cUHp6uipVqqTGjRurV69e15xpAigJKMYBAAAAAPAy7hkHAAAAAMDLKMYBAAAAAPAyinEAAAAAALyM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\n",
      "text/plain": [
       "<Figure size 1100x350 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 3, figsize=(11, 3.5), sharex=True, sharey=True)\n",
    "for i, label in enumerate(labels):\n",
    "    qqt = np.vstack([\n",
    "        np.hstack([w1w1s[i][-1], network_functions[i][-1].T]),\n",
    "        np.hstack([network_functions[i][-1], w2w2s[i][-1]])\n",
    "    ])\n",
    "    vals = axs[i].matshow(1./8. * qqt, cmap=div_cmap, vmin=-1./8. * 4, vmax=1./8. * 4)\n",
    "    axs[i].set_xticks([])\n",
    "    axs[i].set_yticks([])\n",
    "    axs[i].set_title(label, pad=15.)\n",
    "\n",
    "for ax in axs:\n",
    "    ax.set_xlabel(\"Input    Output\")\n",
    "axs[0].set_ylabel(\"Output    Input\")\n",
    "    \n",
    "for ax, c in zip(axs, colours):\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_edgecolor(c)\n",
    "        spine.set_linewidth(3.5)\n",
    "\n",
    "fig.subplots_adjust(right=0.85)\n",
    "cbar_ax = fig.add_axes([0.89, 0.1625, 0.017, 0.675])\n",
    "cbar = fig.colorbar(vals, cax=cbar_ax)\n",
    "cbar.ax.set_yticks([-0.4, 0., 0.4])\n",
    "fig.savefig(\"./figures/figure-3_c-d-e.svg\")"
   ]
  }
 ],
 "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
