{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Parameter Count and Receptive Field\n",
    "\n",
    "This notebook showcases two features of `PDEquinox`:\n",
    "\n",
    "1. To count the number of parameters of complex architectures. This allows us to\n",
    "   investigate how the parameterspace of a network grows based on the number\n",
    "   hidden channels, layers, etc.\n",
    "2. The receptive field. Since the architectures of this package are designed to\n",
    "   operate on discrete fields, this quantity helps assess how many discrete\n",
    "   steps the networks \"see\" in each direction and spatial dimension."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import jax\n",
    "import jax.numpy as jnp\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import pdequinox as pdeqx"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Parameter Count"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Conv-Net"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's first use a feedforward ConvNet in its default configuration. Here, we\n",
    "only have to define the number of spatial dimension, the number of in-channels,\n",
    "and the number of out-channels. All are set to one in this example.\n",
    "\n",
    "The default configuration has 10 hidden layers with 16 hidden channels. As such,\n",
    "there are a total of 11 convolutions in this network. Two of them map 1->16 or\n",
    "16->1, the other 9 map 16->16. Each convolution has a kernel size of 3x3 and\n",
    "adds a bias. Hence, we get\n",
    "\n",
    "$$\n",
    "(1*16) * 3 + 16 + 9 * ((16*16) * 3 + 16) + (16 * 1) * 3 + 1 = 7169\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-04-17 09:18:04.815268: W external/xla/xla/service/gpu/nvptx_compiler.cc:679] The NVIDIA driver's CUDA version is 12.2 which is older than the ptxas CUDA version (12.3.52). Because the driver is older than the ptxas version, XLA is disabling parallel compilation, which may slow down compilation. You should update your NVIDIA driver or use the NVIDIA-provided CUDA forward compatibility packages.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "7169"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "pdeqx.count_parameters(conv_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "What happens if we change the number of hidden channels (but keep the hidden\n",
    "depth of 10)?\n",
    "\n",
    "-> The number of parameters quadruples!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "28161"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, hidden_channels=32, key=jax.random.PRNGKey(0))\n",
    "pdeqx.count_parameters(conv_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's plot this behavior for a range of hidden channels.\n",
    "\n",
    "We will see that for one order of magnitude increase in hidden channels, the\n",
    "number of parameters increases by two orders of magnitude."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Number of parameters')"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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thR0RERExG0p6IiIiIjbUtARERERt+WxQUfP0REREXF/Hht09BwdERER9+exQUdERETcn4KOiIiIuC0FHREREXFbHr96uWEYAGRnZzu1XavVSl5eHtnZ2fj6+jq1bZGyUN8UV6R+KY668HP7ws/xy/H4oHP27FkAIiMjTa5EREREHHX27FmqVq162eMW42pRyM3Z7XYOHz5MSEgIFoulxLG2bdtedVbW5c7Jzs4mMjKSgwcPEhoa6tSaK1ppvg6V4X2d0d61tOHIa8rS50p7jvqm671nWdt0hX5ZmvPULyvXe5rRLx15nWEYnD17lrp16+LldfmROB5/RcfLy4v69etf8pi3t/dVv+Gudk5oaGil/6YtzdehMryvM9q7ljYceY0z+lxpz1HfdJ33LGubrtAvS3Oe+mXlek8z+qWjr7vSlZwLNBj5ChITE51yTmVn1md09vs6o71racOR1zirz3lCvwRzPmd5vGdZ23SFflma89QvK9d7mtEvnfG+/83jb12Vl+zsbKpWrUpWVlal/+1E3Iv6prgi9UspL7qiU078/f0ZN24c/v7+ZpciUoL6prgi9UspL7qiIyIiIm5LV3RERETEbSnoiIiIiNtS0BERERG3paAjIiIibktBR0RERNyWgo5JvvvuO5o1a0aTJk346KOPzC5HBIB7772X6tWrc//995tdikixgwcP0rlzZ1q0aEFMTAxz5841uySpRDS93ARFRUW0aNGCFStWULVqVRISEvj111+pUaOG2aWJh/vpp584e/Ysn376KV999ZXZ5YgAcOTIETIzM4mLi+Po0aMkJCSwc+dOgoKCzC5NKgFd0THB2rVradmyJfXq1SM4OJiePXuydOlSs8sSoXPnzoSEhJhdhkgJderUIS4uDoDatWsTHh7OqVOnzC1KKg0FnWuwcuVKevfuTd26dbFYLCxYsOCic1JSUoiKiiIgIID27duzdu3a4mOHDx+mXr16xdv16tXjzz//rIjSxY2VtV+KlBdn9s3169djs9mIjIws56rFXSjoXIPc3FxiY2NJSUm55PE5c+aQlJTEuHHjSE1NJTY2lh49enDs2LEKrlQ8ifqluCpn9c1Tp07x6KOP8o9//KMiyhZ3YUiZAMbXX39dYl+7du2MxMTE4m2bzWbUrVvXmDhxomEYhrF69WqjT58+xcdHjBhhzJo1q0LqFc9w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TmJiIqdPn+bxxx8HIDExkVOnTvHwww+zbt06du/ezQ8//MDgwYOx2WwOvc/o0aOZPHkyc+bMYceOHYwZM4a0tDRGjBjhtM9yKf3798disTBkyBC2bdvG999/z1tvvVXinKeeeopdu3YxevRoduzYwezZs5k5c2aJc1544QV+/fVXhg4dSlpaGrt27eKbb75h6NCh11xbQEAAL7zwAs8//zz/+te/2L17N7/99hsff/xxqdto0qQJy5Yt49dff2X79u08+eSTZGZmXnNNl+NoX/juu++YNm0aaWlp7N+/n3/961/Y7XaaNWvm9NpEHKWgI2KSV1999aLbCc2bN+eDDz4gJSWF2NhY1q5dy3PPPee095w0aRKTJk0iNjaWX375hYULFxIeHg5QfBXGZrPRvXt3oqOjGTlyJNWqVSsxHqg0hg8fTlJSEs8++yzR0dEsWbKEhQsX0qRJE6d9lksJDg7m22+/ZfPmzbRu3ZoXX3zxotsvDRo0YN68eSxYsIDY2FhmzJjBhAkTSpwTExPDzz//zM6dO+nUqROtW7dm7Nix1K1bt0z1vfzyyzz77LOMHTuW5s2b069fv8uO6bmUl156ifj4eHr06EHnzp2pXbs2ffr0KVNNl+JoX6hWrRrz58/ntttuo3nz5syYMYPPP/+cli1bOr02EUdZjP8eECAiIiLiJnRFR0RERNyWgo6IiIi4LQUdERERcVsKOiIiIuK2FHRERETEbSnoiIiIiNtS0BERERG3paAjIiIibktBR0RERNyWgo6IiIi4LQUdERERcVsKOiIiIuK2/h+2hO1eIQobRQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hidden_channels_range = [2**i for i in range(0, 10)]\n",
    "num_parameters = [\n",
    "    pdeqx.count_parameters(\n",
    "        pdeqx.arch.ConvNet(1, 1, 1, hidden_channels=hc, key=jax.random.PRNGKey(0))\n",
    "    )\n",
    "    for hc in hidden_channels_range\n",
    "]\n",
    "plt.loglog(hidden_channels_range, num_parameters)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of hidden channels\")\n",
    "plt.ylabel(\"Number of parameters\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "How does it scale with depth?\n",
    "\n",
    "-> After an initial stronger phase, it will grow **linearly**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Number of parameters')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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p7jjjjtYs2YNFouFffv20bJlSx566CHq1avHq6++Wh05RRzOMAz+seEgL371813H42jdKMjsaCIi4iB235efMGECvr6+HD58mMDAwIrjd955J8nJyQ4NJ1JdCovLGPfxj0xfsocym8HQzuF8kXCdSo6IiJux+47OihUrWL58Oc2aNbvoeJs2bTh06JDDgolUl/Ts8l3H92WX7zr+9JD2jNau4yIibsnuolNYWHjRnZyf5Obm4u/v75BQItXlq50neOJnU8ffvKcLXTV1XETEbdn91tX111/PBx98UPGxxWLBZrMxc+ZM+vTp49BwIo5SZrXxwtI9PPLhDxSWWIlvUZ8lj/ZSyRERcXN239GZOXMmN910E1u2bKGkpIQnn3yS3bt3k5uby4YNG6ojo8hVudzU8ScHtsVHU8dFRNye3UWnU6dO7N27lzfeeIPg4GAKCgoYOXIkCQkJhIdrSq44l80Xdh3PyS8myN+Hv9zWmcGaOi4i4jGqtI5OnTp1eOaZZxydRcRhDMPgvQ0HmXFh6nibRkHMuS+OVg01q0pExJNUqeicPn2auXPnkpKSAkCHDh0YPXo09etrvIOYr7C4jKc+38GSHScAGBbThJdGRmtDThERD2T3IIV169YRGRnJa6+9xunTpzl9+jSvvfYaLVq0YN26ddWRUaTS0rMLuCVpA0t2nMDHy8LUYR147XexKjkiIh7K7u/+CQkJ3Hnnnbz11lt4e3sDYLVaeeSRR0hISGDnzp0ODylSGT+fOh4W4k/S3Zo6LiLi6ewuOunp6Xz22WcVJQfA29ubxMTEi6adi9SUUquNl5el8u76DADiW9Tnjbu70DBY6zqJiHg6u4tOly5dSElJoW3bthcdT0lJISYmxmHBRCojO+/C1PGD5VPHH76w67imjouICFSy6OzYsaPivx999FHGjx9Peno6PXr0AOC7774jKSmJl156qXpSilzGpoxcEj7679TxV27vzKBOmjouIiL/VamiExsbi8ViwTCMimNPPvnkJc+7++67ufPOOx2XTuQyDMNg7voMZixLxWoziAoL4q17NXVcREQuVamik5GRUd05RCql4MLU8aUXpo4Pj2nCDE0dFxGRX1Cpnw7XXHNNdecQ+VXp2fn8379+IP3CruPP3NyeB67VruMiIvLLqvRr8PHjx1m/fj3Z2dnYbLaLHnv00UcdEkzk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K49/66q6/LQ+z69tHy8ilafrSsTx3P260h2dauLv78/UqVMvu1O6iFSNrisRx3P360p3dERERMRt6Y6OiIiIuC0VHREREXFbKjoiIiLitlR0RERExG2p6IiIiIjbUtExyZIlS2jbti1t2rTh3XffNTuOiFu49dZbqVevHrfddpvZUUTcwpEjR+jduzcdOnSgc+fOfPrpp2ZHspuml5ugrKyMDh06sGbNGurUqUNcXBzffvstDRo0MDuaiEtbu3Yt+fn5vP/++3z22WdmxxFxeSdOnCArK4vY2FgyMzOJi4tj79691K5d2+xolaY7OibYtGkTHTt2pGnTpgQFBTF48GBWrFhhdiwRl9e7d2+Cg4PNjiHiNsLDw4mNjQWgcePGhIaGkpuba24oO6noVMG6desYNmwYTZo0wWKxsGjRokuek5SURGRkJAEBAcTHx7Np06aKx44fP07Tpk0rPm7atCnHjh2riegiTutqrysRuZQjr6utW7ditVqJiIio5tSOpaJTBYWFhcTExJCUlHTZx+fPn09iYiJTp07lhx9+ICYmhoEDB5KdnV3DSUVch64rEcdz1HWVm5vL/fffz9///veaiO1YhlwVwFi4cOFFx7p3724kJCRUfGy1Wo0mTZoYM2bMMAzDMDZs2GCMGDGi4vHx48cbH374YY3kFXEFVbmufrJmzRrjt7/9bU3EFHEpVb2uzp8/b1x//fXGBx98UFNRHUp3dByspKSErVu30q9fv4pjXl5e9OvXj40bNwLQvXt3du3axbFjxygoKGDZsmUMHDjQrMgiTq8y15WI2Kcy15VhGDzwwAP07duX++67z6yoV0VFx8FOnjyJ1WolLCzsouNhYWFkZmYC4OPjw6uvvkqfPn2IjY3l8ccf14wrkSuozHUF0K9fP26//Xa++uormjVrphIkcgWVua42bNjA/PnzWbRoEbGxscTGxrJz504z4laZj9kBPNXw4cMZPny42TFE3MrXX39tdgQRt9KrVy9sNpvZMa6K7ug4WGhoKN7e3mRlZV10PCsri8aNG5uUSsS16boScTxPua5UdBzMz8+PuLg4Vq1aVXHMZrOxatUqevbsaWIyEdel60rE8TzlutJbV1VQUFBAenp6xccZGRls27aN+vXr07x5cxITExk1ahRdu3ale/fuzJ49m8LCQkaPHm1iahHnputKxPF0XaHp5VWxZs0aA7jkf6NGjap4zuuvv240b97c8PPzM7p3725899135gUWcQG6rkQcT9eVYWivKxEREXFbGqMjIiIibktFR0RERNyWio6IiIi4LRUdERERcVsqOiIiIuK2VHRERETEbanoiIiIiNtS0RERERG3paIjIvIzBw8exGKxsG3bNrOjiIgDqOiIiFN54IEHsFgsWCwWfH19CQsLo3///rz33nvYbDaHv9aIESMcek4RcS4qOiLidAYNGsSJEyc4ePAgy5Yto0+fPowfP56hQ4dSVlZmdjwRcSEqOiLidPz9/WncuDFNmzalS5cuPP3003zxxRcsW7aMefPmAXDmzBl+//vf07BhQ0JCQujbty/bt2+vOMdzzz1HbGwsb7/9NhEREQQGBnLHHXdw9uzZisfff/99vvjii4o7SGvXrq34/AMHDtCnTx8CAwOJiYlh48aNNfklEBEHUdEREZfQt29fYmJiWLBgAQC333472dnZLFu2jK1bt9KlSxduuukmcnNzKz4nPT2dTz75hMWLF5OcnMyPP/7II488AsDEiRO54447Ku4enThxgmuvvbbic5955hkmTpzItm3biIqK4q677tLdJBEXpKIjIi6jXbt2HDx4kPXr17Np0yY+/fRTunbtSps2bXjllVeoW7cun332WcXzz58/zwcffEBsbCw33HADr7/+Ov/+97/JzMwkKCiIWrVqVdw9aty4MX5+fhWfO3HiRG6++WaioqKYNm0ahw4dIj093Yw/tohcBRUdEXEZhmFgsVjYvn07BQUFNGjQgKCgoIr/ZWRksH///ornN2/enKZNm1Z83LNnT2w2G2lpab/6Wp07d6747/DwcACys7Md+KcRkZrgY3YAEZHKSklJoUWLFhQUFBAeHn7RmJqf1K1b1yGv5evrW/HfFosFwOGzvkSk+qnoiIhLWL16NTt37mTChAk0a9aMzMxMfHx8iIyM/MXPOXz4MMePH6dJkyYAfPfdd3h5edG2bVsA/Pz8sFqtNRFfREyioiMiTqe4uJjMzEysVitZWVkkJyczY8YMhg4dyv3334+Xlxc9e/ZkxIgRzJw5k6ioKI4fP87SpUu59dZb6dq1KwABAQGMGjWKV155hby8PB599FHuuOMOGjduDEBkZCTLly8nLS2NBg0aUKdOHTP/2CJSDVR0RMTpJCcnEx4ejo+PD/Xq1SMmJobXXnuNUaNG4eVVPrTwq6++4plnnmH06NHk5OTQuHFjbrjhBsLCwirO07p1a0aOHMmQIUPIzc1l6NChvPnmmxWPjxkzhrVr19K1a1cKCgpYs2bNFe8QiYjrsRiGYZgdQkTE0Z577jkWLVqkrRxEPJxmXYmIiIjbUtERERERt6W3rkRERMRt6Y6OiIiIuC0VHREREXFbKjoiIiLitlR0RERExG2p6IiIiIjbUtERERERt6WiIyIiIm5LRUdERETcloqOiIiIuK3/B1hfmCpiUfo2AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "depth_range = [2**i for i in range(0, 8)]\n",
    "num_parameters = [\n",
    "    pdeqx.count_parameters(\n",
    "        pdeqx.arch.ConvNet(\n",
    "            1, 1, 1, hidden_channels=16, depth=d, key=jax.random.PRNGKey(0)\n",
    "        )\n",
    "    )\n",
    "    for d in depth_range\n",
    "]\n",
    "plt.loglog(depth_range, num_parameters)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Depth\")\n",
    "plt.ylabel(\"Number of parameters\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "How does it scale with respect to kernel size?\n",
    "\n",
    "-> The growth is also **linear**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Number of parameters')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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PhcUFFTw7yEhIde9/usLki0WC3a7vWC/AF9//TVVqlQp9L7AwMAi5Y6Ojmb//v189913rFq1iueff56//e1v/PDDDze8GNpms9GrVy/Cw8P5+OOPC7b/kuUf//gHrVu3LvQZX1/fImUREedR0RERp6tevTo//PBDQdlZsWIFYWFhxMfHs3//fmrXru3UX69hw4YEBgZy7NgxOnToUOz9lCpViq5du9K1a1cSEhKoX78+u3btIj4+/rr3Dh06lF27drF169ZCJa1ChQpUrlyZw4cP069fv2JnERHnUNEREZeIjo5m7dq1dOzYkfvvv58VK1YwatQoHnroIapVq8bjjz+Oj48PO3bsICUlhTfffLPYv1ZYWBgvvfQSQ4cOxW63065dO9LS0tiwYQPh4eH079//d/cxY8YMbDYbrVu3Jjg4mC+++IJSpUpRvXr169772Wef8eGHH7Jo0SIsFgtnzpwBIDQ0lNDQUMaOHcvgwYOJiIigc+fO5ObmsnXrVi5fvsywYcOK/d8pIo7T7eUi4jJVq1Zl7dq1XLhwgfvvv5+2bduybNkyVq5cScuWLWnTpg0TJ068YZlw1BtvvMHIkSMZN24cDRo0oHPnznz99dfUqFGjSJ8vXbo0//jHP7jzzjtp2rQp3333HV999RVly5a97r0//PADNpuNbt26UalSpYJ/3n//fQD+9Kc/MX36dD777DOaNGlChw4dmDFjRpGziIjzWAzDMMwOISIiIuIKOqMjIiIiHktFR0RERDyWio6IiIh4LBUdERER8VgqOiIiIuKxVHRERETEY6noiIiIiMdS0RERERGPpaIjIiIiHktFR0RERDyWio6IiIh4LBUdERER8Vj/H2W+HkaFwmm6AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "kernel_size_range = [2**i for i in range(0, 9)]\n",
    "\n",
    "num_parameters = [\n",
    "    pdeqx.count_parameters(\n",
    "        pdeqx.arch.ConvNet(\n",
    "            1, 1, 1, hidden_channels=16, kernel_size=ks, key=jax.random.PRNGKey(0)\n",
    "        )\n",
    "    )\n",
    "    for ks in kernel_size_range\n",
    "]\n",
    "plt.loglog(kernel_size_range, num_parameters)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Kernel size\")\n",
    "plt.ylabel(\"Number of parameters\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "How does it scale with respect to the **number of spatial dimensions**? (i.e.,\n",
    "whether we use 1d, 2d, or 3d convolutions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Number of parameters')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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B3SkJ4+4u7sTGRmJu7u7vaOIiIgIOtIjIiIiDkJHekRERMQhqPSIiIiIQ1DpEREREYeg0iMiIrdYvHgxgYGB1KhRg2nTptk7jkiWe/na1InMIiKSTUZGBsHBwaxZswYfHx8aNmzI77//TqlSpewdTRzcvX5t6kiPneivKBHJr7Zs2UJISAjly5fH09OTsLAwVqxYYe9YIvf8tanSYwcZGRkMGDCA1atXs3PnTt5//30uXbpk71giksfGjh1L48aN8fLywtfXl65duxIXF2fT51i3bh1dunTB398fk8nEjz/+eNvtoqKiqFy5Mh4eHjRt2pQtW7ZkrTtz5gzly5fPely+fHlOnz5t05ySv0yePJm6detm3TqpefPmLFu2zKbPkR++NlV67EB/RYk4prVr1xIREcGmTZtYuXIl6enptG/fnuTk5Ntuv2HDBtLT029ZHh0dzfnz52/7NsnJyYSGhhIVFXXHHPPmzWPAgAFERkayY8cOQkND6dChA/Hx8bl7x6TAq1ChAuPGjWP79u1s27aNNm3a8Nhjj7F///7bbl9gvzYNsdratWuNzp07G+XKlTMAY8GCBbds8+mnnxoBAQGGu7u70aRJE2Pz5s1Z67777jsjIiIi6/F7771nvP/++/cjuojkI/Hx8QZgrF279pZ1ZrPZCA0NNZ544gkjIyMja3lsbKzh5+dnjB8//q77v9PPpyZNmmT7GWQ2mw1/f39j7NixhmEYxoYNG4yuXbtmrX/zzTeNOXPmWPOuSSFQokQJY9q0abcsL8hfmzrSkwt3a6v6K0pEciIhIQGAkiVL3rLOycmJpUuXsnPnTp5//nksFguHDx+mTZs2dO3albfeeitXz5mWlsb27dtp165dtudq164dGzduBKBJkybs27eP06dPk5SUxLJly+jQoUOunk8KHrPZzDfffENycjLNmze/ZX1B/tp0yVUyBxcWFkZYWNgd10+cOJE+ffrwwgsvADBlyhSWLFnCjBkzGDJkCP7+/tlegzx9+jRNmjTJ89wikn9YLBb69etHixYtqF279m238ff3Z/Xq1Tz00EN0796djRs30q5dOyZPnpzr57148SJmsxk/P79sy/38/IiNjQXAxcWFCRMm0Lp1aywWC2+99Zau3HIAe/fupXnz5ty4cQNPT08WLFhAcHDwbbctqF+bKj029kdTHTp0aNayv2uq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5jB8+HDeffddYmJiGDNmDMOGDWP27NnZ9vuf//yHQYMGsWvXLmrWrEm3bt3IyMgAICIigtTUVNatW8fevXsZP348np6et823fft2nnrqKZ555hn27t3LiBEjGDZs2C0vD06YMIFGjRqxc+dOXnvtNf75z38SFxcHwKRJk1i4cCHffvstcXFxzJkzJ1vRF7lvDBG5Zz179jQee+wxwzAMo1mzZkbv3r0NwzCMBQsWGH/9NouMjDRCQ0Ozve2HH35oBAQEZNtXQECAYTabs5YFBgYaDz30UNbjjIwMo1ixYsbcuXMNwzCMo0ePGoAxbty4rG3S09ONChUqGOPHjzcMwzBGjx5ttG/fPttznzx50gCMuLg4wzAMo1WrVkb9+vXv+v76+/sb7777brZljRs3Nl577bWsx6GhoUZkZOQd97F9+3YDMI4dO3bb9T179jRKlixpJCcnZy2bPHmy4enpme1j81cXLlwwAGPv3r2GYfz5cdm5c+ct+/7j83Uv+/lDXFycARhbtmzJWhYTE2MAxocffpi1DDAWLFiQbZ/Tpk3LWj937lwDMFatWpW1bOzYsUZgYGDW42rVqhlff/11tucfPXq00bx58zvud//+/QZgxMTEGIZhGHXq1DFGjBhx2/dlzZo1BmBcuXLFMAzD6N69u/HII49k22bw4MFGcHBw1uOAgACjR48eWY8tFovh6+trTJ482TAMw3jjjTeMNm3aGBaL5bbPKXK/6EiPiI2NHz+e2bNnExMTk+t9hISE4OT057enn58fderUyXrs7OxMqVKlbjmS0Lx586z/u7i40KhRo6wcu3fvZs2aNXh6emb9q1WrFkC2l3IaNmz4t9kSExM5c+YMLVq0yLa8RYsWVr3PoaGhtG3bljp16vDkk08yderUW86HCg0NpWjRotnev6SkJE6ePAnAwYMH6datG1WrVsXb2zvr6MGJEydynMMW+4mJicHFxSXbx65WrVo5Om+obt26Wf/38/MDyPa59vPzy/o8Jycnc/jwYV588cVsn8d33nnnlpfj/rrfcuXKAWTtp2/fvrzzzju0aNGCyMhI9uzZ87fv2+0+1wcPHsRsNt/2+UwmE2XLls16vl69erFr1y4CAwPp27cvK1asuOvHRSQvqPSI2FjLli3p0KEDQ4cOvWWdk5NTtpdvANLT02/ZztXVNdtjk8l022XWvPySlJREly5d2LVrV7Z/Bw8epGXLllnbFStWLMf7vBfOzs6sXLmSZcuWERwczCeffEJgYCBHjx7N8T66dOnC5cuXmTp1Kps3b2bz5s2A9Sdg22o/ufHXz+sfJw//77I/Ps9JSUkATJ06NdvncN++fWzatOmu+/1jPy+99BJHjhzhueeeY+/evTRq1IhPPvnEZu/H/+Zu0KABR48eZfTo0Vy/fp2nnnqKJ5544p6eTyQ3VHpE8sC4ceNYtGhRtpNHAcqUKcO5c+eyFR9bztb56y++jIwMtm/fTlBQEJD5i2f//v1UrlyZ6tWrZ/tnTdHx9vbG39+fDRs2ZFu+YcMGgoODrcprMplo0aIFI0eOZOfOnbi5ubFgwYKs9bt37+b69evZ3j9PT08qVqzIpUuXiIuL4+2336Zt27YEBQXdcqTIzc0NINsRif+Vk/3cTa1atbI+3n+Ii4uz+awbPz8//P39OXLkyC2fwz9O2s6pihUr8uqrrzJ//nwGDhzI1KlTb7tdUFDQbT/XNWvWxNnZOcfP5+3tzdNPP83UqVOZN28eP/zwA5cvX7Yqs8i9crF3AJHCqE6dOjz77LNMmjQp2/KHH36YCxcu8N577/HEE0+wfPlyli1bhre3t02eNyoqiho1ahAUFMSHH37IlStX6N27N5B58urUqVPp1q0bb731FiVLluTQoUN88803TJs2zapfYIMHDyYyMpJq1apRr149Zs6cya5du257xdKdbN68mVWrVtG+fXt8fX3ZvHkzFy5cyCppkHmk5cUXX+Ttt9/m2LFjREZG8vrrr+Pk5ESJEiUoVaoUX3zxBeXKlePEiRMMGTIk23P4+vpSpEgRli9fToUKFfDw8Lhl/kxO9nM3gYGBdOzYkVdeeYXJkyfj4uJCv379KFKkiFX7yYmRI0fSt29ffHx86NixI6mpqWzbto0rV64wYMCAHO2jX79+hIWFUbNmTa5cucKaNWuyfdz/auDAgTRu3JjRo0fz9NNPs3HjRj799NNsV4zdzcSJEylXrhz169fHycmJ7777jrJly9plbIA4Nh3pEckjo0aNuuXlp6CgID777DOioqIIDQ1ly5Ytt72yKbfGjRvHuHHjCA0NZf369SxcuJDSpUsDZB2dMZvNtG/fnjp16tCvXz+KFy+e7fyhnOjbty8DBgxg4MCB1KlTh+XLl7Nw4UJq1KiR4314e3uzbt06OnXqRM2aNXn77beZMGFCtuF9bdu2pUaNGrRs2ZKnn36a8PDwrMvfnZyc+Oabb9i+fTu1a9emf//+vP/++9mew8XFhUmTJvH555/j7+/PY489dkuOnOwnJ2bOnIm/vz+tWrXi8ccf5+WXX8bX19fq/dzNSy+9xLRp05g5cyZ16tShVatWzJo1y6ojPWazmYiICIKCgujYsSM1a9a8Y4lp0KAB3377Ld988w21a9dm+PDhjBo1il69euX4+by8vHjvvfdo1KgRjRs35tixYyxdutTqrzuRe2Uy/vcEAxGRfKBXr15cvXo139+2QUQKDtVsERERcQgqPSIiIuIQ9PKWiIiIOAQd6RERERGHoNIjIiIiDkGlR0RERByCSo+IiIg4BJUeERERcQgqPSIiIuIQVHpERETEIaj0iIiIiENQ6RERERGH8P/X+OooumQziAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_spatial_dims_range = [1, 2, 3]\n",
    "\n",
    "num_parameters = [\n",
    "    pdeqx.count_parameters(\n",
    "        pdeqx.arch.ConvNet(d, 1, 1, hidden_channels=16, key=jax.random.PRNGKey(0))\n",
    "    )\n",
    "    for d in num_spatial_dims_range\n",
    "]\n",
    "\n",
    "plt.loglog(num_spatial_dims_range, num_parameters)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of spatial dimensions\")\n",
    "plt.ylabel(\"Number of parameters\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In general, we observe the following growths:\n",
    "\n",
    "* Hidden channels: Quadratic\n",
    "* Depth: Linear\n",
    "* Kernel size: Linear"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Other modifications are:\n",
    "\n",
    "* A change in the number of input or output channels causes a negligible change\n",
    "  in the number of parameters (because most of them are due to the dense\n",
    "  convolutions in the hidden layers)\n",
    "* Deactivating the bias: will reduce the parameter space slightly"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ResNet"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The default configuration of the ResNet has 6 blocks and 32 hidden channels.\n",
    "Each block does two 3x3 convolutions. It uses linear 1x1 convolutions with no\n",
    "bias for lifting and projection.\n",
    "\n",
    "Hence, we expect for the parameter count\n",
    "\n",
    "$$\n",
    "(1*32) * 1 + 32 + 6 * ((32*32) * 3 + 32) * 2 + (32 * 1) * 1 + 1 = 37'345\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "37345"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_net = pdeqx.arch.ClassicResNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(res_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here, we have to following growths:\n",
    "\n",
    "* Hidden channels: Quadratic\n",
    "* Number of blocks: Linear (this is similar to changing the depth for the conv net)\n",
    "* Kernel size: Linear"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "By default, the Classic ResNet comes without any normalization. We can activate\n",
    "it to get a group norm with `num_groups=1` (= layer norm) after each of the two\n",
    "convolutions in the blocks. Each group norm adds two parameters per channel.\n",
    "\n",
    "Hence, we add 64 parameters per convolution, 128 parameters per block, and 6*128 =\n",
    "768 parameters in total.\n",
    "\n",
    "In total we get 37'345 + 768 = 38'113 parameters."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "38113"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_net = pdeqx.arch.ClassicResNet(1, 1, 1, use_norm=True, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(res_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The modern ResNet architecture under `pdequinox.nn.ModernResNet` just has the\n",
    "order of operations in the blocks rearranged, and it activates the group norm\n",
    "by default. Hence, we expect 38'113 parameters for this architecture as well."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "38113"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "modern_res_net = pdeqx.arch.ModernResNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(modern_res_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### UNet"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The default configuration follows the original UNet paper by Ronneberger et al.\n",
    "(2015) and has 4 levels (of resolution different than the input resolution).\n",
    "\n",
    "Since with each level, we half the spatial resolution and **double the feature\n",
    "dimension**, there are increasingly many parameters in the lower levels of the\n",
    "UNets. This is because the number of parameters for convolutions scales\n",
    "quadratically with the number of hidden channels."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "789089"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_net = pdeqx.arch.ClassicUNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(u_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### FNO\n",
    "\n",
    "The Fourier Neural Operator uses spectral convolutions. In the default\n",
    "configuration, it has 32 hidden layers, uses 12 modes for the spectral\n",
    "convolution, and has 4 blocks. Each block contains one spectral convolution\n",
    "together with a linear 1x1 bypass convolution. Lifting and projection are linear\n",
    "1x1 convolutions. Note that the weights associated with the spectral convolution\n",
    "are complex and therefore saved by two real numbers (real and imaginary part).\n",
    "\n",
    "As such, we expect the following number of parameters:\n",
    "\n",
    "$$\n",
    "(1*32) * 1 + 32 + 4 * ((32*32) * 12 * 2 + (32 * 32) * 1 + 32) + (32 * 1) * 1 + 1 = 15'425"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "102625"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fno = pdeqx.arch.ClassicFNO(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(fno)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "How does this scale with the number of modes?\n",
    "\n",
    "-> Linear"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Number of parameters')"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjoAAAG1CAYAAADwRl5QAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAABMQUlEQVR4nO3dd3gU5eL28e9uOgkJhEBoofcQEhKqgoJSRAURBRvFchQ1NEEUjoWih6KCqESxnWNXUBERBSkiSFEgEGroSIcEEkgjbXfeP/iZ9+QgmoXdTLJ7f66L62JnNrP3hkz2ZuaZeSyGYRiIiIiIuCGr2QFEREREXEVFR0RERNyWio6IiIi4LRUdERERcVsqOiIiIuK2VHRERETEbanoiIiIiNtS0RERERG35W12ALPZ7XZOnDhBxYoVsVgsZscRERGREjAMg8zMTGrWrInVevnjNh5fdE6cOEFERITZMUREROQKHD16lNq1a192vccXnYoVKwIXv1HBwcFO225BQQFLly6lR48e+Pj4OG27Ip5M+5WI85XX/SojI4OIiIiiz/HL8fii88fpquDgYKcXnQoVKhAcHFyufnBEyjLtVyLOV973q78bdqLByCIiIuK2VHRERETEbanoiIiIiNtS0RERERG3paIjIiIibktFR0RERNyWio6IiIi4LRUdERERcVsqOiIiIuK2VHRERETEbanoiIiIiNtS0RERERGXyS+0m/r6blF0Dh06RNeuXWnRogVRUVFkZ2ebHUlERMSj5RfaGT9/O49/mojdbpiWwy1mL7///vt58cUX6dy5M2lpafj5+ZkdSURExGOlZubx2CeJbDqcjsUCG39Po32DKqZkKfdFZ+fOnfj4+NC5c2cAQkNDTU4kIiLiubYdO8fQjxM5eT6Xin7evH5Pa9NKDpSBU1erV6+md+/e1KxZE4vFwoIFCy55TkJCAvXq1cPf35/27duzYcOGonX79u0jKCiI3r17Exsby5QpU0oxvYiIiPxhwZbj9J+znpPnc2lQNZAFw66la7NqpmYy/YhOdnY20dHRPPjgg/Tr1++S9XPnzmX06NHMmTOH9u3bM2vWLHr27MmePXuoVq0ahYWF/PLLLyQlJVGtWjVuuukm2rZtS/fu3f/09fLy8sjLyyt6nJGRAUBBQQEFBQVOe19/bMuZ2xTxdNqvRJzPGfuVzW7w8tK9vL/2MABdmoQxs38UFf19XLa/lnS7FsMwzBsh9D8sFgvffPMNffv2LVrWvn172rZty+zZswGw2+1EREQwfPhwxo0bx/r165k4cSI//vgjAC+//DIAY8eO/dPXmDhxIpMmTbpk+WeffUaFChWc/I5ERETcW04hfLjXyu7zF08Sda9l5+YIO1aLi183J4d7772X8+fPExwcfNnnmX5E56/k5+eTmJjI+PHji5ZZrVa6devG+vXrAWjbti0pKSmkp6cTEhLC6tWrGTp06GW3OX78eEaPHl30OCMjg4iICHr06PGX3yhHFRQUsGzZMrp3746Pj4/TtiviybRfiTjf1exX+1KyeOzTJA6fz8Hfx8q021tyS1R1FyUt7o8zMn+nTBedM2fOYLPZCA8PL7Y8PDyc3bt3A+Dt7c2UKVO47rrrMAyDHj16cOutt152m35+fn96VZaPj49LfnG6arsinkz7lYjzObpfLd15iifmJpGdb6NWpQDeGRxHZM0QFyYsrqRZy3TRKalevXrRq1cvs2OIiIi4PbvdYPbK/cxctheA9vVDefO+WKoElc1bu5TpohMWFoaXlxenT58utvz06dNUr146h8ZERETkouy8Qp78ciuLd5wCYEjHujx7awt8vEy/iPuyym4ywNfXl7i4OFasWFG0zG63s2LFCjp27GhiMhEREc9y5GwOd7y1jsU7TuHjZWFavygm3dayTJccKANHdLKysti/f3/R40OHDpGUlERoaCh16tRh9OjRDBkyhDZt2tCuXTtmzZpFdnY2DzzwgImpRUREPMfa/WeI/2wz53IKCAvy4+1BscTVLR836DW96GzatImuXbsWPf7jiqghQ4bwwQcfcNddd5Gamsrzzz/PqVOniImJYcmSJZcMUBYRERHnMgyD/6z9nX/9kIzNbhBdO4Q5g+KoERJgdrQSM73odOnShb+7lc+wYcMYNmyYU183ISGBhIQEbDabU7crIiLiDnILbDzzzQ6+3nwMgH6xtZhyexT+Pl4mJ3OM6UXHLPHx8cTHx5ORkUFISOldDiciIlLWnc7I5ZGPE9l69BxWCzxzSwsevLYeFouL7wLoAh5bdERERORSm4+k8+jHiaRk5hES4MPse1vTuXFVs2NdMRUdERERAWDepqM8+80O8m12moQH8e7gNtStEmh2rKuioiMiIuLhbHaY/P1uPv71CAA9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2bMn33//PUuXLmXq1KnMmDGD4cOHOy2HSHmnMToiHmratGl89913rF+/vtjyqlWrcurUqWJlx5n3vvn111+L/l5YWEhiYiLNmzcHIDY2lp07d1KvXj0aNWpU7I8j5SY4OJiaNWuydu3aYsvXrl1LixYtnPNG/kLz5s1Zv359se/h2rVrqVixIrVr16Zhw4b4+Pjw22+/Fa1PT09n7969RY9bt26NzWYjJSXlku9F9erVi54XERHBo48+yvz58xkzZgzvvvuuy9+fSHmioiPioaKiorjvvvt4/fXXiy3v0qULqampvPTSSxw4cICEhIRLrii6GgkJCXzzzTfs3r2b+Ph40tPTefDBB4GLg2vT0tK455572LhxIwcOHODHH3/kgQcewGazOfQ6Y8eOZfr06cydO5c9e/Ywbtw4kpKSGDlypNPey+U8/vjjHD16lOHDh7N7926+/fZbJkyYwOjRo7FarQQFBfHQQw8xduxYfvrpJ3bs2MH9999f7FRgkyZNuO+++xg8eDDz58/n0KFDbNiwgalTp/L9998DMGrUKH788UcOHTrE5s2bWblyZVFpFJGLVHREPNjkyZMvOd3SvHlz3nzzTRISEoiOjmbDhg1XNZbnf02bNo1p06YRHR3NmjVrWLhwIWFhYQBFR2FsNhs9evQgKiqKUaNGUalSpWIloCRGjBjB6NGjGTNmDFFRUSxZsoSFCxfSuHFjp72Xy6lVqxY//PADGzZsIDo6mkcffZSHHnqIZ599tug5L7/8Mp07d6Z3795069aNTp06XTL26D//+Q+DBw9mzJgxNG3alL59+7Jx40bq1KkDgM1mIz4+nubNm3PTTTfRpEkT3nzzTZe/P5HyxGL878l4ERERETehIzoiIiLitlR0RERExG2p6IiIiIjbUtERERERt6WiIyIiIm5LRUdERETcloqOiIiIuC0VHREREXFbKjoiIiLitlR0RERExG2p6IiIiIjbUtERERERt/X/AGrqTWiJTTswAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_modes = [2**i for i in range(0, 7 + 1)]\n",
    "\n",
    "num_parameters = [\n",
    "    pdeqx.count_parameters(\n",
    "        pdeqx.arch.ClassicFNO(1, 1, 1, num_modes=n, key=jax.random.PRNGKey(0))\n",
    "    )\n",
    "    for n in num_modes\n",
    "]\n",
    "\n",
    "plt.loglog(num_modes, num_parameters)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of modes\")\n",
    "plt.ylabel(\"Number of parameters\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "How does it scale with the number of modes in 2d?\n",
    "\n",
    "-> Quadratic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Number of parameters')"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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YrGYUnQeffRRXnvtNTp06MCpU6fw9/e/7hlERJzhZE4+w79IYs2eEwA83K42L/bQKMciV8vhopOenu6KHFdt+/bt+Pr60qFDBwAqVapkciIRkauzef9phsxJ5OhZjXIs4iwO33XlbKtXr6Znz56Eh4djsVhYtGjRRc9JSEggMjKSgIAA2rZty4YNG4rW7d69m6CgIHr27EnLli15/fXXr2N6EZFrZxgGH61Jp98/13H07HnqVg3k6yE3q+SIOMFVDaN56NAhFi9ezIEDBygoKCi2burUqQ5tKzc3l+joaB577DH69Olz0fq5c+cSHx/PzJkzadu2LdOmTaNbt27s3LmTatWqUVhYyC+//EJSUhLVqlXjzjvvpHXr1nTp0uVq3pqIyHWVdd7K8/O3siTlGAA9o8OZ2CdKoxyLOInDP0krV66kV69e1K1bl7S0NJo1a8bvv/+OYRi0bNnS4QDdu3ene/ful10/depUnnjiCQYPHgzAzJkz+e677/j4448ZM2YMNWrUoFWrVkRERABw1113kZSUdNmik5+fT35+ftHjrKwsAKxWK1ar1eH8l/Pntpy5TRFxL6lHsxn6RTL7T+Xh623hhe6NGNAmAovFuK77Du2vpCwq6efV4aIzduxYnn32WV555RWCg4NZsGAB1apVY8CAAdx5550OB72SgoICNm/ezNixY4uWeXl50blzZ9atWwdA69atyczM5PTp04SGhrJ69WqefPLJy25z4sSJvPLKKxctX758OeXLO/+OhhUrVjh9myJS9v2WaWH+Pi+shoWKfgaDGxZS6WQKS5akmJZJ+yspS/Ly8kr0PIeLTmpqKp9//vmFL/bx4dy5cwQFBTFhwgTuuecenn76aUc3eVknTpzAZrNdNDhhWFgYaWlpRRlef/11br31VgzDoGvXrvTo0eOy2xw7dizx8fFFj7OysoiIiKBr166EhIQ4LbvVamXFihV06dLlolvwRcRznSuw8cp3qSzYewSA2xpW4c37mlGxvJ9pmbS/krLozzMyf8XhohMYGFh0Xc4NN9zA3r17adq0KXChmJjhr05//Td/f/9L3n7u6+vrkh9wV21XRMqe9BO5PP3ZZtKOZeNlgVFdG/H0bfXwKiWjHGt/JWVJST+rDheddu3asWbNGho3bsxdd93FqFGj2LZtGwsXLqRdu3YOB72SKlWq4O3tTUZG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uqZt/fjjjxw5coTVq1czdepUxo0bR48ePahYsSLr16/nqaee4sknn7zodUaPHs2oUaPYsmUL7du3p2fPnpw8eRKAM2fOcPvtt9OiRQs2bdrE0qVLycjIoG/fvsW28emnn+Ln58fatWuZOXPmJfO98847TJkyhbfeeoutW7fSrVs3evXqxe7duwE4evQoTZs2ZdSoURw9epRnn332su/1008/pUqVKmzYsIGhQ4fy9NNP88ADD3DTTTeRmJhI165defjhh8nLywPg8OHD3HXXXbRu3Zrk5GTef/99PvroI1577bVi34eff/6Zr7/+muXLl/PTTz+RmJhY7HWHDBnCunXr+OKLL9i6dSsPPPAAd955Z9F7iIuLIz8/n9WrV7Nt2zYmT55MUFBQSf75RDyHISIeYdCgQcY999xjGIZhtGvXznjssccMwzCMr776yvjvXcG4ceOM6OjoYl/79ttvG7Vr1y62rdq1axs2m61oWaNGjYwOHToUPS4sLDQCAwONzz//3DAMw0hPTzcAY9KkSUXPsVqtRs2aNY3JkycbhmEYr776qtG1a9dir33w4EEDMHbu3GkYhmHcdtttRosWLf7y/YaHhxv/+Mc/ii1r3bq18cwzzxQ9jo6ONsaNG3fF7dx2223GLbfcctH7evjhh4uWHT161ACMdevWGYZhGC+88ILRqFEjw263Fz0nISHBCAoKMmw2m5GdnW34+fkZX375ZdH6kydPGuXKlTOGDx9uGIZh7N+/3/D29jYOHz5cLM8dd9xhjB071jAMw4iKijLGjx//l98LEU/mY27NEhEzTJ48mdtvv/2KRzH+StOmTfHy+s9B4bCwMJo1a1b02Nvbm8qVK5OZmVns69q3b1/0dx8fH1q1akVqaioAycnJrFq16pJHJfbu3UvDhg0BiI2NvWK2rKwsjhw5ws0331xs+c0330xycnIJ3+F/NG/evOjvf76vqKioomVhYWEARe81NTWV9u3bF7vI++abbyYnJ4dDhw5x+vRpCgoKaNu2bdH6SpUq0ahRo6LH27Ztw2azFb3nP+Xn5xddTzRs2DCefvppli9fTufOnbnvvvuKZRURUNER8UC33nor3bp1Y+zYsTz66KPF1nl5eWEYRrFlVqv1om34+voWe2yxWC65zG63lzhXTk4OPXv2ZPLkyRetu+GGG4r+HhgYWOJtOsNfvdc/C40j7/Wv5OTk4O3tzebNm/H29i627s8i+P/+3/+jW7dufPfddyxfvpyJEycyZcoUhg4d6rQcImWdrtER8VCTJk3im2++Yd26dcWWV61alWPHjhUrO84c++a3334r+nthYSGbN2+mcePGALRs2ZLt27cTGRlJ/fr1i/1xpNyEhIQQHh7O2rVriy1fu3YtTZo0cc4buYLGjRuzbt26Yt/DtWvXEhwcTM2aNalXrx6+vr6sX7++aP3p06fZtWtX0eMWLVpgs9nIzMy86HtRvXr1oudFRETw1FNPsXDhQkaNGsUHH3zg8vcnUpao6Ih4qKioKAYMGMD06dOLLe/YsSPHjx/njTfeYO/evSQkJFx0R9G1SEhI4KuvviItLY24uDhOnz7NY489Bly4uPbUqVM89NBDbNy4kb1797Js2TIGDx6MzWZz6HVGjx7N5MmTmTt3Ljt37mTMmDEkJSUxfPhwp72Xy3nmmWc4ePAgQ4cOJS0tja+//ppx48YRHx+Pl5cXQUFBPP7444wePZoff/yRlJQUHn300WKnAhs2bMiAAQN45JFHWLhwIenp6WzYsIGJEyfy3XffATBixAiWLVtGeno6iYmJrFq1qqg0isgFKjoiHmzChAkXnW5p3Lgx7733HgkJCURHR7Nhw4Zrupbnf02aNIlJkyYRHR3NmjVrWLx4MVWqVAEoOgpjs9no2rUrUVFRjBgxggoVKhQrASUxbNgw4uPjGTVqFFFRUSxdupTFixfToEEDp72Xy6lRowbff/89GzZsIDo6mqeeeorHH3+cF198seg5b775Jh06dKBnz5507tyZW2655aJrjz755BMeeeQRRo0aRaNGjejduzcbN26kVq1aANhsNuLi4mjcuDF33nknDRs25L333nP5+xMpSyzG/56MFxEREXETOqIjIiIibktFR0RERNyWio6IiIi4LRUdERERcVsqOiIiIuK2VHRERETEbanoiIiIiNtS0RERERG3paIjIiIibktFR0RERNyWio6IiIi4LRUdERERcVv/Hw57i82MFKU9AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_modes = [2**i for i in range(0, 5 + 1)]\n",
    "\n",
    "num_parameters = [\n",
    "    pdeqx.count_parameters(\n",
    "        pdeqx.arch.ClassicFNO(2, 1, 1, num_modes=n, key=jax.random.PRNGKey(0))\n",
    "    )\n",
    "    for n in num_modes\n",
    "]\n",
    "\n",
    "plt.loglog(num_modes, num_parameters)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of modes\")\n",
    "plt.ylabel(\"Number of parameters\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dilated ResNet\n",
    "\n",
    "A dilated ResNet uses multiple stacked convolutions. In the default\n",
    "configuration, one block consists of the dilation factors 1, 2, 4, 8, 4, 2, 1.\n",
    "Using a convolution with dilation does not increase the number of parameters.\n",
    "Hence, using the defaul 32 hidden channels and two blocks. All with active group\n",
    "normalization, and linear 1x1 convolutions for lifting and projection, we expect\n",
    "the following number of parameters:\n",
    "\n",
    "$$\n",
    "(1*32) * 1 + 32 + 2 * ((32*32) * 3 + 32 + 2 * 32) * 7 + (32 * 1) * 1 + 1 = 44'449\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "44449"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dil_res_net = pdeqx.arch.DilatedResNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(dil_res_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Multi-Layer Perceptron (MLP)\n",
    "\n",
    "The MLP is part of `PDEquinox` for completion. Different to the other\n",
    "convolution-based architectures, it needs to be informed of the spatial\n",
    "resolution it operates on because internally, it will flatten all spatial\n",
    "axes and the channel axis into one long vector which is densely connected.\n",
    "\n",
    "The default configuration has 3 hidden layers with 64 hidden features each. If\n",
    "we assume an input resolution of 48, the total number of parameters are:\n",
    "\n",
    "$$\n",
    "(48*1) * 64 + 64 + 2 * ((64*64) * 1 + 64) + (64 * 48) * 1 + 48 = 14'576\n",
    "$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "14576"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mlp_net = pdeqx.arch.MLP(1, 1, 1, num_points=48, key=jax.random.PRNGKey(0))\n",
    "\n",
    "pdeqx.count_parameters(mlp_net)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Receptive Field\n",
    "\n",
    "The receptive field is denoted as a tuple of tuple of two floats. The outer-most\n",
    "tuple represents the spatial dimension, the inner-most tuple the direction (down\n",
    "and up).\n",
    "\n",
    "For example,\n",
    "\n",
    "```python\n",
    "((4, 5), (3, 3))\n",
    "```\n",
    "\n",
    "would mean that in the zeroth spatial dimension (=\"x\"), the network sees its\n",
    "four neighbors in the negative direction (to the left) and five neighbors in the\n",
    "positive direction (to the right). In the first spatial dimension (=\"y\"), it\n",
    "sees three neighbors in the negative direction (downward) and three neighbors in\n",
    "the positive direction (upward).\n",
    "\n",
    "Conceptually, a receptive field will always be an integer. However, `PDEquinox`\n",
    "chooses to represent it as a float to allow for representing architectures with\n",
    "an infinite receptive field."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Conv-Net"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In the default configuration, a conv net has a symmetric field which is\n",
    "dependent on the depth+1."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((11.0, 11.0),)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "conv_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Increasing the depth, increases the receptive field linearly."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((21.0, 21.0),)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, depth=20, key=jax.random.PRNGKey(0))\n",
    "conv_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Changing the kernel size, increases the receptive field linearly (based on the\n",
    "symmetric amount of the kernel)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((22.0, 22.0),)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, kernel_size=5, key=jax.random.PRNGKey(0))\n",
    "conv_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Changing the number of hidden channels does **not** change the receptive field."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((11.0, 11.0),)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, hidden_channels=128, key=jax.random.PRNGKey(0))\n",
    "conv_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "If we use an even kernel size, the receptive field will be asymmetric. For a\n",
    "kernel size of two, it will also only be in one direction. Due to the way\n",
    "even-length convolutions are implemented in JAX, the upward direction is\n",
    "preferred."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((0.0, 11.0),)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, kernel_size=2, key=jax.random.PRNGKey(0))\n",
    "conv_net.receptive_field"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((11.0, 22.0),)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "conv_net = pdeqx.arch.ConvNet(1, 1, 1, kernel_size=4, key=jax.random.PRNGKey(0))\n",
    "conv_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ResNet\n",
    "\n",
    "For the receptive field, a ResNet behaves similarly to a ConvNet. Since each\n",
    "block in a ResNet has two convolutions, the receptive field grows by two with\n",
    "each block. Note that in the implementation of `PDEquinox`, lifting and\n",
    "projection layers are 1x1 convolutions, and hence do not increase the receptive\n",
    "field."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((12.0, 12.0),)"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_net = pdeqx.arch.ClassicResNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "res_net.receptive_field"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((24.0, 24.0),)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_net = pdeqx.arch.ClassicResNet(1, 1, 1, num_blocks=12, key=jax.random.PRNGKey(0))\n",
    "res_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### UNet\n",
    "\n",
    "Since UNets reduce the spatial resolution by a factor of two when going down one\n",
    "level, a 3x3 convolution will now have an effective receptive field of a 5x5\n",
    "convolution! Another level down, it will be 9x9, then 17x17, etc.\n",
    "\n",
    "The total receptive field is dominated by the lowest level of the UNet."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((137.0, 137.0),)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_net = pdeqx.arch.ClassicUNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "u_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The growth is exponentially with the number of levels!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Receptive field')"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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ERERcVgqOiIiIuKwVHRERETEYanoiIiIiMNS0RERERGHpaIjIhXu4MGDWCwWtm3bZnaUQomJiXTq1AkvLy9at2592df06NGDsWPHVmiuESNGMGDAgAp9TxFHoqIj4oRGjBiBxWJhxowZRbYvWrQIi8ViUipzTZo0CV9fX5KSkorcmFdEqjYVHREn5eXlxcyZMzl//rzZUewmNze3zF+7f/9+brjhBiIiIqhRo4YdU4mImVR0RJxUz549CQ0NZfr06X/6msmTJxf7GGf27NlERkYWPv79o5Vp06YREhJCYGAgU6dOJT8/n/HjxxMUFETdunWZO3dusf0nJibSpUsXvLy8aNGiBatXry7y/K5du+jTpw9+fn6EhIQwbNgwzpw5U/h8jx49GD16NGPHjqVmzZr07t37suOw2WxMnTqVunXr4unpSevWrVm2bFnh8xaLhc2bNzN16lQsFguTJ0++wpH7r5ycHMaNG0edOnXw9fWlY8eO/PzzzwCkpaXh7e3N0qVLi3zNwoUL8ff3JysrC4AjR45wzz33EBgYSFBQEHfeeScHDx780/f88ssvadmyJd7e3tSoUYOePXuSmZlZorwizkhFR8RJubq6Mm3aNN544w2OHj16Tfv66aefOH78OPHx8cyaNYtJkybRr18/qlevzm+//cYjjzzCww8/XOx9xo8fz1NPPcXWrVvp3Lkz/fv35+zZswBcuHCBm2++mTZt2rBp0yaWLVtGamoq99xzT5F9fPzxx3h4eLBmzRreeeedy+abM2cOr732Gq+++io7duygd+/e3HHHHezbtw+AEydO0Lx5c5566ilOnDjBuHHjSjTu0aNHs27dOj7//HN27NjBoEGDuO2229i3bx8BAQH069eP+fPnF/maTz/9lAEDBuDj40NeXh69e/fG39+fX375hTVr1uDn58dtt9122bNTJ06cYMiQIYwaNYqEhAR+/vlnBg4ciO7NLHIFpt47XURMMXz4cOPOO+80DMMwOnXqZIwaNcowDMNYuHCh8ccfC5MmTTKio6OLfO0///lPIyIiosi+IiIiDKvVWritSZMmxo033lj4OD8/3/D19TU+++wzwzAMIyUlxQCMGTNmFL4mLy/PqFu3rjFz5kzDMAzjxRdfNHr16lXkvY8cOWIARlJSkmEYhtG9e3ejTZs2Vx1vWFiY8fLLLxfZ1r59e+Oxxx4rfBwdHW1MmjTpivvp3r27MWbMGMMwDOPQoUOGq6urcezYsSKvueWWW4yJEycahlFwPP38/IzMzEzDMAzj4sWLhpeXl7F06VLDMAxj3rx5RpMmTQybzVb49Tk5OYa3t7exfPlywzCK/rfavHmzARgHDx686phFpIDO6Ig4uZkzZ/Lxxx+TkJBQ5n00b94cF5f//jgJCQmhZcuWhY9dXV2pUaMGp06dKvJ1nTt3Lvy7m5sb7dq1K8yxfft2Vq1ahZ+fX+Gfpk2bAgXX0/yubdu2V8yWlpbG8ePH6dq1a5HtXbt2vaYx79y5E6vVSuPGjYtkXL16dWG+vn374u7uzrfffgvAV199RUBAAD179iwcY3JyMv7+/oVfHxQURHZ2dpEx/i46OppbbrmFli1bMmjQIN5//32HusZKpDy4mR1ARMzVrVs3evfuzcSJExkxYkSR51xcXIp9LJKXl1dsH+7u7kUeWyyWy26z2WwlzpWRkUH//v2ZOXNmsedq165d+HdfX98S79OeMjIycHV1ZfPmzbi6uhZ5zs/PDwAPDw/uvvtu5s+fz7333sv8+fMZPHgwbm5uhfto27Ytn376abH916pVq9g2V1dXVqxYwdq1a/nhhx944403ePbZZ/ntt9+oX79+OYxSpOrTGR0RYcaMGSxevJh169YV2V6rVi1OnjxZpOzYc+2b9evXF/49Pz+fzZs306xZMwCuv/56du/eTWRkJA0bNizypzTlJiAggLCwMNasWVNk+5o1a4iKiipz9jZt2mC1Wjl16lSxfKGhoYWvGzp0KMuWLWP37t389NNPDB06tPC566+/nn379hEcHFxsH9WqVbvs+1osFrp27cqUKVPYunUrHh4eLFy4sMzjEHF0KjoiQsuWLRk6dCivv/56ke09evTg9OnTvPLKK+zfv5+4uLhis4iuRVxcHAsXLiQxMZGYmBjOnz/PqFGjAIiJieHcuXMMGTKEjRs3sn//fpYvX87IkSOxWq2lep/x48czc+ZMvvjiC5KSkpgwYQLbtm1jzJgxZc7euHFjhg4dygMPPMDXX39NSkoKGzZsYPr06Xz//feFr+vWrRuhoaEMHTqU+vXr07Fjx8Lnhg4dSs2aNbnzzjv55ZdfSElJ4eeff+aJJ5647AXiv/32G9OmTWPTpk0cPnyYr7/+mtOnTxeWQxEpTkVHRACYOnVqsY+WmjVrxltvvUVcXBzR0dFs2LChxDOSSmLGjBnMmDGD6Ohofv31V7799ltq1qwJUHgWxmq10qtXL1q2bMnYsWMJDAwscj1QSTzxxBPExsby1FNP0bJlS5YtW8a3335Lo0aNrin/3LlzeeCBB3jqqado0qQJAwYMYOPGjdSrV6/wNRaLhSFDhrB9+/YiZ3MAfHx8iI+Pp169egwcOJBmzZrx17/+lezsbAICAoq9X0BAAPHx8fTt25fGjRvz3HPP8dprr9GnT59rGoeII7MY//sBvIiIiIiD0BkdERERcVgqOiIiIuKwVHRERETEYanoiIiIiMNS0RERERGHpaIjIiIiDktFR0RERByWio6IiIg4LBUdERERcVgqOiIiIuKwVHRERETEYf0f4aIJ1NynuBgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_levels_range = [0, 1, 2, 3, 4, 5, 6, 7]\n",
    "receptive_field_per_direction = [\n",
    "    pdeqx.arch.ClassicUNet(\n",
    "        1, 1, 1, num_levels=n, hidden_channels=1, key=jax.random.PRNGKey(0)\n",
    "    ).receptive_field[0][0]\n",
    "    for n in num_levels_range\n",
    "]\n",
    "\n",
    "plt.semilogy(num_levels_range, receptive_field_per_direction)\n",
    "plt.grid()\n",
    "plt.xlabel(\"Number of levels\")\n",
    "plt.ylabel(\"Receptive field\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### FNO\n",
    "\n",
    "The receptive field of an FNO is infinite. This is because the spectral\n",
    "convolution is a global operation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((inf, inf),)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fno = pdeqx.arch.ClassicFNO(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "fno.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dilated ResNet\n",
    "\n",
    "Using a range of dilation factors in a block, the receptive field grows\n",
    "exponentially with the number of convolutions in the block."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((44.0, 44.0),)"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dil_res_net = pdeqx.arch.DilatedResNet(1, 1, 1, key=jax.random.PRNGKey(0))\n",
    "dil_res_net.receptive_field"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((8.0, 8.0),)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dil_res_net = pdeqx.arch.DilatedResNet(\n",
    "    1, 1, 1, dilation_rates=[1, 2, 1], key=jax.random.PRNGKey(0)\n",
    ")\n",
    "dil_res_net.receptive_field"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((20.0, 20.0),)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dil_res_net = pdeqx.arch.DilatedResNet(\n",
    "    1, 1, 1, dilation_rates=[1, 2, 4, 2, 1], key=jax.random.PRNGKey(0)\n",
    ")\n",
    "dil_res_net.receptive_field"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Multi-Layer Perceptron (MLP)\n",
    "\n",
    "Since the MLP is densely connected also between the spatial dimensions, the\n",
    "receptive field is that of the input resolution."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((48, 48),)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mlp_net = pdeqx.arch.MLP(1, 1, 1, num_points=48, key=jax.random.PRNGKey(0))\n",
    "mlp_net.receptive_field"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((103, 103),)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mlp_net = pdeqx.arch.MLP(1, 1, 1, num_points=103, key=jax.random.PRNGKey(0))\n",
    "mlp_net.receptive_field"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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": 2
}
