{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Setting up Datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch \n",
    "import matplotlib.pyplot as plt \n",
    "from tqdm import tqdm\n",
    "import torch.nn.functional as F\n",
    "from common.utils import get_u, F_l, F_nl\n",
    "import numpy as np \n",
    "\n",
    "torch.manual_seed(0)\n",
    "device = \"cuda\"\n",
    "\n",
    "# setup domain\n",
    "L = 1\n",
    "nx = 100\n",
    "x = torch.linspace(-L, L, nx) # x in domain [-1, 1]\n",
    "dx = x[1] - x[0]\n",
    "n_train = 100\n",
    "n_valid = 10 \n",
    "\n",
    "# generate training data\n",
    "p_train = 2*torch.rand(n_train*3) - 1 # coeffs from -1 to 1\n",
    "p_train = p_train.reshape(n_train, 3) # need 3 coeffs for each polynomial of degree p=2\n",
    "# generate valid data\n",
    "p_valid = 2*torch.rand(n_valid*3) - 1 \n",
    "#p_valid = 2*torch.rand(n_valid*3) + 1 # coeffs from 1 to 3 for OOD testing\n",
    "p_valid = p_valid.reshape(n_valid, 3)\n",
    "\n",
    "# move to device\n",
    "p_train = p_train.to(device)\n",
    "p_valid = p_valid.to(device)\n",
    "x = x.to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Setting up Models\n",
    "\n",
    "MLP, 1D FNO, and Neural Functional implementations are already written, just need a simple pooling wrapper for FNO baseline. Also, need a simple MLP wrapper to stack inputs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/ayz2/anaconda3/envs/ldm_new/lib/python3.11/site-packages/torchvision/io/image.py:13: UserWarning: Failed to load image Python extension: '/home/ayz2/anaconda3/envs/ldm_new/lib/python3.11/site-packages/torchvision/image.so: undefined symbol: _ZN3c1017RegisterOperatorsD1Ev'If you don't plan on using image functionality from `torchvision.io`, you can ignore this warning. Otherwise, there might be something wrong with your environment. Did you have `libjpeg` or `libpng` installed before building `torchvision` from source?\n",
      "  warn(\n",
      "/home/ayz2/anaconda3/envs/ldm_new/lib/python3.11/site-packages/torchvision/datapoints/__init__.py:12: UserWarning: The torchvision.datapoints and torchvision.transforms.v2 namespaces are still Beta. While we do not expect major breaking changes, some APIs may still change according to user feedback. Please submit any feedback you may have in this issue: https://github.com/pytorch/vision/issues/6753, and you can also check out https://github.com/pytorch/vision/issues/7319 to learn more about the APIs that we suspect might involve future changes. You can silence this warning by calling torchvision.disable_beta_transforms_warning().\n",
      "  warnings.warn(_BETA_TRANSFORMS_WARNING)\n",
      "/home/ayz2/anaconda3/envs/ldm_new/lib/python3.11/site-packages/torchvision/transforms/v2/__init__.py:54: UserWarning: The torchvision.datapoints and torchvision.transforms.v2 namespaces are still Beta. While we do not expect major breaking changes, some APIs may still change according to user feedback. Please submit any feedback you may have in this issue: https://github.com/pytorch/vision/issues/6753, and you can also check out https://github.com/pytorch/vision/issues/7319 to learn more about the APIs that we suspect might involve future changes. You can silence this warning by calling torchvision.disable_beta_transforms_warning().\n",
      "  warnings.warn(_BETA_TRANSFORMS_WARNING)\n"
     ]
    }
   ],
   "source": [
    "from torch import nn\n",
    "from modules.models.FNO1D import FNO1d_cond\n",
    "from modules.models.Basics import MLP \n",
    "from modules.models.NeuralFunctional import Neural_Functional\n",
    "\n",
    "class FNO_Wrapper(nn.Module):\n",
    "    def __init__(self, \n",
    "                 in_channels: int = 1,\n",
    "                 modes: int = 32,\n",
    "                 width: int = 256,\n",
    "                 num_layers: int = 5,):\n",
    "        super().__init__()\n",
    "\n",
    "        self.FNO = FNO1d_cond( in_channels=in_channels,\n",
    "                               modes=modes,\n",
    "                               width=width,\n",
    "                               out_channels=1,\n",
    "                               num_layers=num_layers,\n",
    "                               cond_channels=0,\n",
    "                               cond_dim=0,\n",
    "                               cond_scale=0)\n",
    "        \n",
    "        self.pooling = nn.AdaptiveAvgPool1d(1)\n",
    "        \n",
    "    def forward(self, u, x):\n",
    "        # u in shape (batch, nx, 1)\n",
    "        # x in shape (batch, nx, 1)\n",
    "\n",
    "        x = torch.cat([u, x], dim=-1) # (batch, nx, 2)\n",
    "        z = self.FNO(x) # (batch, nx, 1)\n",
    "        z = z.permute(0, 2, 1) # (batch, 1, nx)\n",
    "        z = self.pooling(z) # (batch, 1, 1)\n",
    "        z = z.squeeze(-1) # (batch, 1)\n",
    "        return z\n",
    "\n",
    "class MLP_Wrapper(nn.Module):\n",
    "    def __init__(self, \n",
    "                 layers,):\n",
    "        super().__init__()\n",
    "        self.mlp = MLP(layers)\n",
    "        \n",
    "    def forward(self, u, x):\n",
    "        # u in shape (batch, nx, 1)\n",
    "        # x in shape (batch, nx, 1)\n",
    "\n",
    "        # concatenate u and x\n",
    "        x = torch.cat([u.squeeze(-1), x.squeeze(-1)], dim=-1) # (batch, 2*nx)\n",
    "        z = self.mlp(x) # (batch, 1)\n",
    "        return z\n",
    "\n",
    "def count_params(model):\n",
    "    \"\"\"\n",
    "    Count the number of parameters in a PyTorch model.\n",
    "    \"\"\"\n",
    "    return sum(p.numel() for p in model.parameters() if p.requires_grad)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MLP Kernel: film_type: disabled, periodic_embedding: False, filter: Identity()\n",
      "Neural Functional: mlp, with quadrature: trapezoidal, and kernel type: linear, and proj_dim: -1\n"
     ]
    }
   ],
   "source": [
    "# Instantiate models\n",
    "\n",
    "hidden_dim = 32\n",
    "n_layers = 4\n",
    "MLP_model = MLP_Wrapper(layers=[2*nx, hidden_dim, hidden_dim, 1]).to(device)\n",
    "FNO_model = FNO_Wrapper(in_channels=2, \n",
    "                        modes=4, \n",
    "                        width=hidden_dim//2,\n",
    "                        num_layers=n_layers).to(device)\n",
    "\n",
    "nfconfig = {\"kernel_name\": \"mlp\",\n",
    "            \"func_dim\": 1,\n",
    "            \"coord_dim\": 1,\n",
    "            \"kernel_type\": \"linear\", # linear for F_l, nonlinear for F_nl\n",
    "            \"quadrature\": \"trapezoidal\",\n",
    "            \"mlp\": {\n",
    "                \"hidden_features\": hidden_dim,\n",
    "                \"hidden_layers\": n_layers,\n",
    "                \"film_type\": \"disabled\",\n",
    "            }\n",
    "        }\n",
    "\n",
    "NF_model = Neural_Functional(nfconfig).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MLP model params: 7521\n",
      "FNO model params: 10977\n",
      "NF model params: 4321\n"
     ]
    }
   ],
   "source": [
    "FNO_params = count_params(FNO_model)\n",
    "NF_params = count_params(NF_model)\n",
    "MLP_params = count_params(MLP_model)\n",
    "\n",
    "print(f\"MLP model params: {MLP_params}\")\n",
    "print(f\"FNO model params: {FNO_params}\")\n",
    "print(f\"NF model params: {NF_params}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training loop"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def train(model, \n",
    "          func, \n",
    "          x,\n",
    "          p_train,\n",
    "          p_valid,\n",
    "          n_epoch=25,\n",
    "          lr=5e-4,):\n",
    "    \n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=lr)\n",
    "    losses = []\n",
    "    losses_val = []\n",
    "    n_train = len(p_train)\n",
    "    n_valid = len(p_valid)\n",
    "\n",
    "    for i in tqdm(range(n_epoch)):\n",
    "        avg_loss = 0\n",
    "        avg_loss_val = 0\n",
    "        for p_sample in p_train: # batch size is 1\n",
    "            optimizer.zero_grad()\n",
    "            u_input = get_u(p_sample, x) # get u(x), shape (nx)\n",
    "            u_input = u_input.unsqueeze(0).unsqueeze(-1) # b nx 1\n",
    "\n",
    "            label = func(p_sample, x).to(device).unsqueeze(0)  # get F[u(x)], shape b 1\n",
    "            pred = model(u_input, x.unsqueeze(0).unsqueeze(-1)) # get F_theta[u(x)], shape b 1\n",
    "\n",
    "            loss = F.mse_loss(pred, label) #+ F.mse_loss(dF_du, dF_du_true) \n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            avg_loss += loss.item()\n",
    "    \n",
    "        with torch.no_grad():   \n",
    "            for p_sample in p_valid:\n",
    "                u_input = get_u(p_sample, x) # get u(x), shape (nx)\n",
    "                u_input = u_input.unsqueeze(0).unsqueeze(-1) # b nx 1\n",
    "                \n",
    "                label = func(p_sample, x).to(device).unsqueeze(0)  # get F[u(x)], shape b 1\n",
    "                pred = model(u_input, x.unsqueeze(0).unsqueeze(-1)) # get F_theta[u(x)], shape b 1\n",
    "\n",
    "                loss = F.mse_loss(pred, label)\n",
    "                avg_loss_val += loss.item()\n",
    "        \n",
    "        losses.append(avg_loss / n_train)\n",
    "        losses_val.append(avg_loss_val / n_valid)\n",
    "\n",
    "    return losses, losses_val"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training\n",
    "Either use $F_l[u] = \\int_{-1}^1 u(x)*x^2 dx$ or $F_{nl}[u] = \\int_{-1}^1 (u(x))^3 dx$ "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/25 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 25/25 [00:03<00:00,  7.51it/s]\n",
      "100%|██████████| 25/25 [00:18<00:00,  1.35it/s]\n",
      "100%|██████████| 25/25 [00:05<00:00,  4.73it/s]\n"
     ]
    }
   ],
   "source": [
    "MLP_losses, MLP_val_losses = train(MLP_model, F_l, x, p_train, p_valid)\n",
    "FNO_losses, FNO_val_losses = train(FNO_model, F_l, x, p_train, p_valid)\n",
    "NF_losses, NF_val_losses = train(NF_model, F_l, x, p_train, p_valid)\n",
    "\n",
    "#MLP_losses, MLP_val_losses = train(MLP_model, F_nl, x, p_train, p_valid)\n",
    "#FNO_losses, FNO_val_losses = train(FNO_model, F_nl, x, p_train, p_valid)\n",
    "#NF_losses, NF_val_losses = train(NF_model, F_nl, x, p_train, p_valid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_loss(losses, val_losses, model_name=\"MLP\", ylim=0.1):\n",
    "    plt.figure(figsize=(6, 3))\n",
    "    plt.plot(losses, label=\"train\")\n",
    "    plt.plot(val_losses, label=\"valid\")\n",
    "    plt.title(f\"{model_name} train/valid loss\")\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"MSE Loss\")\n",
    "    plt.legend()\n",
    "    plt.ylim(0, ylim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MLP valid loss:  1.0038553479319035e-05\n",
      "FNO valid loss:  0.0005205774476053193\n",
      "NF valid loss:  9.769962616701378e-16\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2IAAAHWCAYAAAAVazrYAAAAP3RFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMS5wb3N0MSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8kixA/AAAACXBIWXMAAA9hAAAPYQGoP6dpAABfXUlEQVR4nO3de3wU5d338e/sbrI5kUAISQgEA3LyAEQ5BDxbokGpLYoKiDcHKVQFFFJbjS/lYPs0eOamUHi0Kq2KID5KK1UUo2DVCBZKqYoRKHKQJJwkgYRkk915/thkyZIEkpjs5PB53/e8Zvaaa2Z+E7cxX2fmGsM0TVMAAAAAgICxWV0AAAAAALQ1BDEAAAAACDCCGAAAAAAEGEEMAAAAAAKMIAYAAAAAAUYQAwAAAIAAI4gBAAAAQIARxAAAAAAgwAhiAAAAABBgBDEAQJu1fPlyGYah7777ztd2zTXX6Jprrjnnths2bJBhGNqwYUO9jwEAAEEMAAAAAALMYXUBAAA0J++//77VJQAA2gCCGAAAVQQHB1tdAgCgDeDWRABAi/DGG2/IMAxt3Lix2rr/+3//rwzD0JdffilJ2r59uyZNmqQePXooJCRE8fHxuuuuu3T06NFzHqemZ8QOHDigUaNGKTw8XLGxsZo9e7ZKS0t/1Pn88Y9/1EUXXSSn06mEhARNnz5dx48f9+uzc+dOjR49WvHx8QoJCVHXrl01duxYFRQU+PqsX79eV1xxhdq3b6+IiAj16dNHDz/88I+qDQDQ9LgiBgBoEUaOHKmIiAi9/vrruvrqq/3WrVq1ShdddJEuvvhiSd5w8t///leTJ09WfHy8vvrqKz333HP66quv9Pnnn8swjDof99SpUxo+fLj27dun++67TwkJCXr55Zf14YcfNvhc5s2bp/nz5ys1NVX33HOPcnJytHTpUn3xxRf69NNPFRQUJJfLpbS0NJWWlmrmzJmKj4/X999/r7Vr1+r48eOKiorSV199pZ/+9Kfq37+/HnvsMTmdTu3atUuffvppg2sDAAQGQQwA0CKEhobqpptu0htvvKFFixbJbrdLkvLy8rRx40bNmzfP1/fee+/Vr371K7/thw4dqnHjxumTTz7RlVdeWefjPvfcc/r222/1+uuv67bbbpMkTZ06VQMGDGjQeRw+fFiZmZm6/vrr9e6778pm896c0rdvX82YMUOvvPKKJk+erK+//lp79uzR6tWrdeutt/q2nzNnjm95/fr1crlcevfddxUTE9OgegAA1uDWRABAizFmzBgdOnTIb8j4N954Qx6PR2PGjPG1hYaG+pZLSkp05MgRDR06VJK0devWeh3znXfeUefOnf3CUFhYmKZNm9agc/jggw/kcrk0a9YsXwiTvOEuMjJSf//73yVJUVFRkqT33ntPxcXFNe6rffv2kqS//vWv8ng8DaoHAGANghgAoMUYMWKEoqKitGrVKl/bqlWrlJycrN69e/vajh07pvvvv19xcXEKDQ1Vp06d1L17d0nye76qLvbu3auePXtWu52xT58+DTqHvXv31rh9cHCwevTo4VvfvXt3paen609/+pNiYmKUlpamJUuW+NU/ZswYXX755frFL36huLg4jR07Vq+//jqhDABaAIIYAKDFcDqdGjVqlN566y2Vl5fr+++/16effup3NUySbr/9dj3//PO6++679eabb+r999/XunXrJKlFhZSnn35a27dv18MPP6xTp07pvvvu00UXXaQDBw5I8l75+/jjj/XBBx/of/7nf7R9+3aNGTNG1113ndxut8XVAwDOhiAGAGhRxowZoyNHjigrK0urV6+WaZp+QeyHH35QVlaWHnroIc2fP18333yzrrvuOvXo0aNBxzvvvPO0e/dumabp156Tk9Pg/dW0vcvl0p49e3zrK/Xr10+PPPKIPv74Y/3jH//Q999/r2XLlvnW22w2DR8+XM8884y+/vpr/Z//83/04Ycf6qOPPmpQfQCAwCCIAQBalNTUVEVHR2vVqlVatWqVhgwZ4rvtUJJvEI8zg9PChQsbdLwbb7xRBw8e1BtvvOFrKy4u1nPPPdeg/aWmpio4OFiLFi3yq/GFF15QQUGBRo4cKUkqLCxUeXm537b9+vWTzWbzDZ1/7NixavtPTk6WpB89vD4AoGkxaiIAoEUJCgrSLbfcopUrV6qoqEhPPfWU3/rIyEhdddVVeuKJJ1RWVqYuXbro/fff1549exp0vKlTp2rx4sWaMGGCtmzZos6dO+vll19WWFhYg/bXqVMnZWRkaP78+RoxYoR+9rOfKScnR3/84x81ePBg3XnnnZKkDz/8UDNmzNBtt92m3r17q7y8XC+//LLsdrtGjx4tSXrsscf08ccfa+TIkTrvvPN06NAh/fGP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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10, 5))\n",
    "plt.plot(MLP_val_losses, label=\"MLP\")\n",
    "plt.plot(FNO_val_losses, label=\"FNO\")\n",
    "plt.plot(NF_val_losses, label=\"NF\")\n",
    "plt.title(f\"valid loss\")\n",
    "plt.xlabel(\"Epoch\")\n",
    "plt.ylabel(\"MSE Loss\")\n",
    "plt.legend()\n",
    "plt.ylim(0, 0.2)\n",
    "\n",
    "print(\"MLP valid loss: \", min(MLP_val_losses))\n",
    "print(\"FNO valid loss: \", min(FNO_val_losses))\n",
    "print(\"NF valid loss: \", min(NF_val_losses))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_derivatives(model, p_valid, x, mode=\"linear\"):\n",
    "    all_derivatives = []\n",
    "    all_dF_du = []\n",
    "    all_losses = []\n",
    "\n",
    "    for i in range(len(p_valid)):\n",
    "        u_input = get_u(p_valid[i], x).to(device)\n",
    "        u_input.requires_grad = True\n",
    "        u_input = u_input.unsqueeze(0).unsqueeze(-1) # b nx 1\n",
    "        pred = model(u_input, x.unsqueeze(0).unsqueeze(-1)) # get F_theta[u(x)], shape b 1\n",
    "\n",
    "        if hasattr(model, \"get_derivative\"):\n",
    "            dF_du = model.get_derivative(pred, u_input, x.unsqueeze(0).unsqueeze(-1))\n",
    "        else:\n",
    "            dF_du = torch.autograd.grad(pred, u_input, torch.ones_like(pred), create_graph=True)[0] / dx\n",
    "\n",
    "        if mode == \"linear\":\n",
    "            dF_du_true = x**2\n",
    "        else:\n",
    "            dF_du_true = 3*u_input.squeeze()**2\n",
    "            \n",
    "        loss = F.mse_loss(dF_du.squeeze(), dF_du_true)\n",
    "        \n",
    "        all_losses.append(loss.item())\n",
    "        all_derivatives.append(dF_du.detach().cpu())\n",
    "        all_dF_du.append(dF_du_true.detach().cpu())\n",
    "    return all_losses, all_derivatives, all_dF_du"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MLP loss:  tensor(0.0798)\n",
      "FNO loss:  tensor(0.1140)\n",
      "NF loss:  tensor(0.0007)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7c12e80422d0>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = torch.linspace(-L, L, nx)\n",
    "x = x.to(device)\n",
    "\n",
    "losses_MLP, dF_du_MLP, dF_du_true = get_derivatives(MLP_model, p_valid, x)\n",
    "losses_FNO, dF_du_FNO, _ = get_derivatives(FNO_model, p_valid, x)\n",
    "losses_NF, dF_du_NF, _ = get_derivatives(NF_model, p_valid, x)\n",
    "\n",
    "#losses_MLP, dF_du_MLP, dF_du_true = get_derivatives(MLP_model, p_valid, x, mode=\"nonlinear\")\n",
    "#losses_FNO, dF_du_FNO, _ = get_derivatives(FNO_model, p_valid, x, mode=\"nonlinear\")\n",
    "#losses_NF, dF_du_NF, _ = get_derivatives(NF_model, p_valid, x, mode=\"nonlinear\")\n",
    "\n",
    "print(\"MLP loss: \", torch.mean(torch.tensor(losses_MLP)))\n",
    "print(\"FNO loss: \", torch.mean(torch.tensor(losses_FNO)))\n",
    "print(\"NF loss: \", torch.mean(torch.tensor(losses_NF)))\n",
    "\n",
    "i=6\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.rcParams.update({'font.size': 14})\n",
    "plt.plot(x.cpu(), dF_du_true[i].cpu().detach().squeeze(), label=\"True\", linestyle=\"-\", color=\"black\", linewidth=2)\n",
    "plt.plot(x.cpu(), dF_du_MLP[i].cpu().detach().squeeze(), label=f\"MLP\", linestyle=\"--\", color=\"blue\", linewidth=2)\n",
    "plt.plot(x.cpu(), dF_du_FNO[i].cpu().detach().squeeze(), label=f\"FNO\", linestyle=\"--\", color=\"red\", linewidth=2)\n",
    "plt.plot(x.cpu(), dF_du_NF[i].cpu().detach().squeeze(), label=f\"NF\", linestyle=\"--\", color=\"magenta\", linewidth=2)\n",
    "#plt.title(\"Linear Functional Derivative: dF/du = x^2\", fontsize=16)\n",
    "#plt.title(\"Nonlinear Functional Derivative: dF/du = 3u^2\", fontsize=16)\n",
    "plt.legend(fontsize=14, loc=\"lower left\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Discretization invariance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "x = torch.linspace(-L, L, nx) * 2 # x in domain [-2, 2] to test discretization invariance\n",
    "dx = x[1] - x[0]\n",
    "x = x.to(device)\n",
    "\n",
    "def val(model, \n",
    "        func, \n",
    "        p_valid,\n",
    "        x):\n",
    "    \n",
    "    losses_val = []\n",
    "    n_valid = len(p_valid)\n",
    "    avg_loss_val = 0\n",
    "\n",
    "    with torch.no_grad():   \n",
    "        for p_sample in p_valid:\n",
    "            u_input = get_u(p_sample, x) # get u(x), shape (nx)\n",
    "            u_input = u_input.unsqueeze(0).unsqueeze(-1) # b nx 1\n",
    "            \n",
    "            label = func(p_sample, x).to(device).unsqueeze(0)  # get F[u(x)], shape b 1\n",
    "            pred = model(u_input, x.unsqueeze(0).unsqueeze(-1)) # get F_theta[u(x)], shape b 1\n",
    "\n",
    "            loss = F.mse_loss(pred, label) \n",
    "            avg_loss_val += loss.item()\n",
    "    \n",
    "    losses_val.append(avg_loss_val / n_valid)\n",
    "\n",
    "    return losses_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MLP valid loss:  31.215526723861693\n",
      "FNO valid loss:  31.530407035350798\n",
      "NF valid loss:  0.21114042035187594\n"
     ]
    }
   ],
   "source": [
    "MLP_val_losses = val(MLP_model, F_l, p_valid, x)\n",
    "FNO_val_losses = val(FNO_model, F_l, p_valid, x)\n",
    "NF_val_losses = val(NF_model, F_l, p_valid, x)\n",
    "\n",
    "#MLP_val_losses = val(MLP_model, F_nl, p_valid, x)\n",
    "#FNO_val_losses = val(FNO_model, F_nl, p_valid, x)\n",
    "#NF_val_losses = val(NF_model, F_nl, p_valid, x)\n",
    "\n",
    "print(\"MLP valid loss: \", min(MLP_val_losses))\n",
    "print(\"FNO valid loss: \", min(FNO_val_losses))\n",
    "print(\"NF valid loss: \", min(NF_val_losses))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MLP loss:  tensor(2.6461)\n",
      "FNO loss:  tensor(2.6838)\n",
      "NF loss:  tensor(0.0327)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7c12bea95b50>]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "losses_MLP, dF_du_MLP, dF_du_true = get_derivatives(MLP_model, p_valid, x)\n",
    "losses_FNO, dF_du_FNO, _ = get_derivatives(FNO_model, p_valid, x)\n",
    "losses_NF, dF_du_NF, _ = get_derivatives(NF_model, p_valid, x)\n",
    "\n",
    "#losses_MLP, dF_du_MLP, dF_du_true = get_derivatives(MLP_model, p_valid, x, mode=\"nonlinear\")\n",
    "#losses_FNO, dF_du_FNO, _ = get_derivatives(FNO_model, p_valid, x, mode=\"nonlinear\")\n",
    "#losses_NF, dF_du_NF, _ = get_derivatives(NF_model, p_valid, x, mode=\"nonlinear\")\n",
    "\n",
    "print(\"MLP loss: \", torch.mean(torch.tensor(losses_MLP)))\n",
    "print(\"FNO loss: \", torch.mean(torch.tensor(losses_FNO)))\n",
    "print(\"NF loss: \", torch.mean(torch.tensor(losses_NF)))\n",
    "\n",
    "i=6\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.rcParams.update({'font.size': 14})\n",
    "plt.plot(x.cpu(), dF_du_true[i].cpu().detach().squeeze(), label=\"True\", linestyle=\"-\", color=\"black\", linewidth=2)\n",
    "plt.plot(x.cpu(), dF_du_MLP[i].cpu().detach().squeeze(), label=f\"MLP\", linestyle=\"--\", color=\"blue\", linewidth=2)\n",
    "plt.plot(x.cpu(), dF_du_FNO[i].cpu().detach().squeeze(), label=f\"FNO\", linestyle=\"--\", color=\"red\", linewidth=2)\n",
    "plt.plot(x.cpu(), dF_du_NF[i].cpu().detach().squeeze(), label=f\"NF\", linestyle=\"--\", color=\"magenta\", linewidth=2)\n",
    "#plt.title(\"Linear Functional Derivative: dF/du = x^2\", fontsize=16)\n",
    "#plt.title(\"Nonlinear Functional Derivative: dF/du = 3u^2\", fontsize=16)\n",
    "#plt.legend(fontsize=14)\n",
    "#plt.legend(fontsize=14, loc=\"upper left\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch2",
   "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
