{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torch.autograd as autograd         \n",
    "from torch import Tensor                  \n",
    "import torch.nn as nn                    \n",
    "import torch.optim as optim             \n",
    "import time\n",
    "from pyDOE import lhs        \n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker\n",
    "\n",
    "#Set default dtype to float32\n",
    "torch.set_default_dtype(torch.float)\n",
    "\n",
    "#PyTorch random number generator\n",
    "torch.manual_seed(1234)\n",
    "\n",
    "# Random number generators in other libraries\n",
    "np.random.seed(1234)\n",
    "\n",
    "# Device configuration\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "print(device)\n",
    "\n",
    "if device == 'cuda': print(torch.cuda.get_device_name()) "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# *Data Prep*\n",
    "\n",
    "Training and Testing data is prepared from the solution file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "x_1 = np.linspace(-1, 1, 256)   \n",
    "x_2 = np.linspace(1, -1, 256)   \n",
    "t = np.linspace(0, 1, 100)     \n",
    "\n",
    "X, Y, T = np.meshgrid(x_1, x_2, t, indexing='ij')  \n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test Data\n",
    "\n",
    "We prepare the test data to compare against the solution produced by the PINN."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cb125bf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "X_u_test = np.hstack((\n",
    "    X.flatten(order='F')[:, None],\n",
    "    Y.flatten(order='F')[:, None],\n",
    "    T.flatten(order='F')[:, None]\n",
    "))\n",
    "\n",
    "lb = np.array([-1, -1, 0])  \n",
    "ub = np.array([1, 1, 1])    \n",
    "\n",
    "usol = np.exp(-X**2-Y**2-T)\n",
    "\n",
    "u_true = usol.flatten('F')[:, None]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12930ed0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def trainingdata(N_u, N_f):\n",
    "    \n",
    "    # x = -1 \n",
    "    leftedge_x = np.hstack((\n",
    "        X[0, :, :].flatten()[:, None],   \n",
    "        Y[0, :, :].flatten()[:, None],\n",
    "        T[0, :, :].flatten()[:, None]\n",
    "    ))\n",
    "    leftedge_u = usol[0, :, :].flatten()[:, None]\n",
    "\n",
    "    # x = 1 \n",
    "    rightedge_x = np.hstack((\n",
    "        X[-1, :, :].flatten()[:, None],  \n",
    "        Y[-1, :, :].flatten()[:, None],\n",
    "        T[-1, :, :].flatten()[:, None]\n",
    "    ))\n",
    "    rightedge_u = usol[-1, :, :].flatten()[:, None]\n",
    "\n",
    "    # y = 1 \n",
    "    topedge_x = np.hstack((\n",
    "        X[:, 0, :].flatten()[:, None],   \n",
    "        Y[:, 0, :].flatten()[:, None],\n",
    "        T[:, 0, :].flatten()[:, None]\n",
    "    ))\n",
    "    topedge_u = usol[:, 0, :].flatten()[:, None]\n",
    "\n",
    "    # y = -1 \n",
    "    bottomedge_x = np.hstack((\n",
    "        X[:, -1, :].flatten()[:, None], \n",
    "        Y[:, -1, :].flatten()[:, None],\n",
    "        T[:, -1, :].flatten()[:, None]\n",
    "    ))\n",
    "    bottomedge_u = usol[:, -1, :].flatten()[:, None]\n",
    "\n",
    "    # t = 0 \n",
    "    initial_x = np.hstack((\n",
    "        X[:, :, 0].flatten()[:, None],\n",
    "        Y[:, :, 0].flatten()[:, None],\n",
    "        T[:, :, 0].flatten()[:, None]\n",
    "    ))\n",
    "    initial_u = usol[:, :, 0].flatten()[:, None]\n",
    "\n",
    "    all_X_u_train = np.vstack([leftedge_x, rightedge_x, bottomedge_x, topedge_x, initial_x])\n",
    "    all_u_train = np.vstack([leftedge_u, rightedge_u, bottomedge_u, topedge_u, initial_u])\n",
    "\n",
    "    idx = np.random.choice(all_X_u_train.shape[0], N_u, replace=False)\n",
    "    X_u_train = all_X_u_train[idx, :]\n",
    "    u_train = all_u_train[idx, :]\n",
    "\n",
    "    '''Collocation Points'''\n",
    "    X_f = lb + (ub - lb) * lhs(3, N_f)\n",
    "    X_f_train = np.vstack((X_f, X_u_train)) \n",
    "\n",
    "    return X_f_train, X_u_train, u_train\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Physics Informed Neural Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Sequentialmodel(nn.Module):\n",
    "    \n",
    "    def __init__(self, layers):\n",
    "        super().__init__()\n",
    "    \n",
    "        assert len(layers) == 3, \"Layers must follow [input_dim, m, output_dim] structure\"\n",
    "    \n",
    "        self.activation = nn.Tanh()\n",
    "    \n",
    "        self.loss_function = nn.MSELoss(reduction='mean')\n",
    "    \n",
    "        self.w_layer = nn.Linear(layers[0], layers[1], bias=False)\n",
    "    \n",
    "        self.a_layer = nn.Linear(layers[1], layers[2], bias=False)\n",
    "    \n",
    "        self.m = layers[1]\n",
    "        self.scale = 1 / torch.sqrt(torch.tensor(self.m, dtype=torch.float))\n",
    "    \n",
    "        self.w_layer.weight.data.normal_(mean=0.0, std=1.0)  \n",
    "\n",
    "        self.a_layer.weight.data.uniform_(-1.0, 1.0)  \n",
    "    \n",
    "        self.iter = 0\n",
    "\n",
    "    def forward(self, x):\n",
    "      \n",
    "        x = self.w_layer(x)       \n",
    "        x = self.activation(x)      \n",
    "        x = self.a_layer(x)         \n",
    "        x = x * self.scale          \n",
    "        return x\n",
    "                        \n",
    "    def loss_BC(self,x,y):\n",
    "                \n",
    "        loss_u = self.loss_function(self.forward(x), y)\n",
    "                \n",
    "        return loss_u\n",
    "\n",
    "    def calc_source(self, x, y, t):\n",
    "       \n",
    "        u = torch.exp(- x**2 - y**2 - t)\n",
    "\n",
    "        S = -4*(x**2 + y**2)*u + 2*u + u**2\n",
    "        return S\n",
    "\n",
    "    def loss_PDE(self, x_to_train_f):\n",
    "        x_1_f = x_to_train_f[:, [0]]   # x\n",
    "        x_2_f = x_to_train_f[:, [1]]   # y\n",
    "        t_f   = x_to_train_f[:, [2]]   # t\n",
    "\n",
    "        g = x_to_train_f.clone()\n",
    "        g.requires_grad = True\n",
    "\n",
    "        u = self.forward(g)           \n",
    "\n",
    "        u_t = autograd.grad(u, g, torch.ones_like(u), retain_graph=True, create_graph=True)[0][:, [2]]\n",
    "\n",
    "        u_x_y = autograd.grad(u, g, torch.ones_like(u), retain_graph=True, create_graph=True)[0]\n",
    "        u_x = u_x_y[:, [0]]\n",
    "        u_y = u_x_y[:, [1]]\n",
    "\n",
    "        u_xx = autograd.grad(u_x, g, torch.ones_like(u_x), retain_graph=True, create_graph=True)[0][:, [0]]\n",
    "        u_yy = autograd.grad(u_y, g, torch.ones_like(u_y), retain_graph=True, create_graph=True)[0][:, [1]]\n",
    "\n",
    "        S = self.calc_source(x_1_f, x_2_f, t_f)   \n",
    "\n",
    "        pde_f = u_t - (u_xx + u_yy) - u* (1-u) - S\n",
    "\n",
    "        # loss\n",
    "        loss_f = self.loss_function(pde_f, torch.zeros_like(pde_f))\n",
    "\n",
    "        return pde_f, loss_f\n",
    "    \n",
    "    def loss(self,x,y,x_to_train_f):\n",
    "\n",
    "        loss_u = self.loss_BC(x,y)\n",
    "        _, loss_f = self.loss_PDE(x_to_train_f)\n",
    "        \n",
    "        loss_val = loss_u + loss_f\n",
    "        \n",
    "        return loss_val\n",
    "             \n",
    "    \n",
    "    def test(self):\n",
    "                \n",
    "        u_pred = self.forward(X_u_test_tensor)\n",
    "        \n",
    "        error_vec = torch.linalg.norm((u-u_pred),2)/torch.linalg.norm(u,2)        # Relative L2 Norm of the error (Vector)\n",
    "        \n",
    "        u_pred = np.reshape(u_pred.cpu().detach().numpy(),(256,256,100),order='F') \n",
    "        \n",
    "        return error_vec, u_pred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b5f94d60",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "def assign_params(model, param_list):\n",
    "    for p, src in zip(model.parameters(), param_list):\n",
    "        p.data.copy_(src.data)\n",
    "\n",
    "def compute_ntk(PINN, x_to_train_f):\n",
    "\n",
    "    PINN.eval()\n",
    "\n",
    "    f,_= PINN.loss_PDE(x_to_train_f)  \n",
    "\n",
    "    N= x_to_train_f.shape[0]  \n",
    "\n",
    "    J = []\n",
    "    \n",
    "    for i in range(N):\n",
    "        PINN.zero_grad()\n",
    "       \n",
    "        grad_i = torch.autograd.grad(f[i], PINN.a_layer.parameters(), retain_graph=True, allow_unused=False)\n",
    "        \n",
    "        grad_flat = torch.cat([g.flatten() for g in grad_i])\n",
    "        J.append(grad_flat.detach())\n",
    "    \n",
    "    J = torch.stack(J)  \n",
    "    NTK = J @ J.T\n",
    "    return NTK\n",
    "\n",
    "def compute_ntk_linear(PINN, X_u_train):\n",
    "  \n",
    "    PINN.eval()\n",
    "                                                     \n",
    "    u = PINN.forward(X_u_train) \n",
    "    N= X_u_train.shape[0]  \n",
    "    J = []\n",
    "    \n",
    "    for i in range(N):\n",
    "        PINN.zero_grad()\n",
    "        \n",
    "        grad_i = torch.autograd.grad(u[i], PINN.a_layer.parameters(), retain_graph=True, allow_unused=False)\n",
    "        \n",
    "        grad_flat = torch.cat([g.flatten() for g in grad_i])\n",
    "        J.append(grad_flat.detach())\n",
    "    \n",
    "    J = torch.stack(J)  \n",
    "    NTK = J @ J.T\n",
    "    return NTK\n",
    "\n",
    "def IGD_PINN(PINN, X_u_train, u_train, X_f_train, theta_init, K0, K1, gamma, eta):\n",
    "    for p in PINN.w_layer.parameters():\n",
    "        p.requires_grad_(False)\n",
    "    for p in PINN.a_layer.parameters():\n",
    "        p.requires_grad_(True)\n",
    "    theta_n = [p.clone() for p in theta_init]\n",
    "    NTK0= compute_ntk(PINN, X_f_train) \n",
    "    NTK0_norm=torch.norm(NTK0, p='fro')\n",
    "    NTK0_linear=compute_ntk_linear(PINN, X_u_train)\n",
    "    NTK0_linear_norm=torch.norm(NTK0_linear, p='fro')\n",
    "    \n",
    "    n = 0\n",
    "    loss_list = []\n",
    "    diff_norm_list=[]\n",
    "    lin_diff_norm_list=[]\n",
    "    while n < K0:\n",
    "        assign_params(PINN, theta_n)\n",
    "        \n",
    "        optimizer_inner = torch.optim.LBFGS(PINN.a_layer.parameters(), \n",
    "                                          lr=gamma,       \n",
    "                                          max_iter=K1,  \n",
    "                                          max_eval=K1*2,   \n",
    "                                          history_size=100)\n",
    "        \n",
    "        def closure():\n",
    "            optimizer_inner.zero_grad()\n",
    "          \n",
    "            param_now = list(PINN.parameters())\n",
    "            loss_quad = 0.5 * sum([(a - b).pow(2).sum() for a, b in zip(param_now, theta_n)])\n",
    "            \n",
    "            loss_main = PINN.loss(X_u_train, u_train, X_f_train)\n",
    "          \n",
    "            total_loss = loss_quad + eta * loss_main\n",
    "            total_loss.backward()\n",
    "            return total_loss\n",
    "      \n",
    "        optimizer_inner.step(closure)\n",
    "        theta_n = [p.clone().detach() for p in PINN.parameters()]\n",
    "        loss = PINN.loss(X_u_train, u_train, X_f_train)\n",
    "        NTK = compute_ntk(PINN, X_f_train)\n",
    "        NTK_linear=compute_ntk_linear(PINN, X_u_train)\n",
    "       \n",
    "        diff_norm = torch.norm(NTK - NTK0, p='fro')/NTK0_norm\n",
    "        lin_diff_norm = torch.norm(NTK_linear - NTK0_linear, p='fro')/NTK0_linear_norm\n",
    "        diff_norm_list.append(diff_norm.item())\n",
    "        lin_diff_norm_list.append(lin_diff_norm.item())\n",
    "       \n",
    "        loss_current = loss.item()\n",
    "        loss_list.append(loss_current)\n",
    "      \n",
    "        if n % 10 == 0:\n",
    "            loss = PINN.loss(X_u_train, u_train, X_f_train)\n",
    "            print(f'Iteration {n}, loss : {loss.item():.8e}, Relative Frobenius norm for interior NTK matrix : {diff_norm.item():.8e}, Relative Frobenius norm for boundary NTK matrix : {lin_diff_norm.item():.8e}')\n",
    "      \n",
    "        n += 1\n",
    "\n",
    "    assign_params(PINN, theta_n)\n",
    "    return [p.clone().detach() for p in PINN.parameters()], loss_list, diff_norm_list, lin_diff_norm_list"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Main"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sequentialmodel(\n",
      "  (activation): Tanh()\n",
      "  (loss_function): MSELoss()\n",
      "  (w_layer): Linear(in_features=3, out_features=1000, bias=False)\n",
      "  (a_layer): Linear(in_features=1000, out_features=1, bias=False)\n",
      ")\n",
      "Iteration 0, loss : 1.22933757e+00, Relative Frobenius norm for interior NTK matrix : 4.93489727e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 10, loss : 6.73086882e-01, Relative Frobenius norm for interior NTK matrix : 3.34128529e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 20, loss : 4.89623904e-01, Relative Frobenius norm for interior NTK matrix : 3.70019168e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 30, loss : 4.11958426e-01, Relative Frobenius norm for interior NTK matrix : 3.54593575e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 40, loss : 3.74946445e-01, Relative Frobenius norm for interior NTK matrix : 3.38920176e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 50, loss : 3.55064750e-01, Relative Frobenius norm for interior NTK matrix : 3.28358054e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 60, loss : 3.42755020e-01, Relative Frobenius norm for interior NTK matrix : 3.21706355e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 70, loss : 3.33910286e-01, Relative Frobenius norm for interior NTK matrix : 3.17491740e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 80, loss : 3.26817155e-01, Relative Frobenius norm for interior NTK matrix : 3.14766198e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 90, loss : 3.20732534e-01, Relative Frobenius norm for interior NTK matrix : 3.12956780e-01, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "N_u = 50 #Total number of data points for 'u'\n",
    "N_f = 200 #Total number of collocation points \n",
    "\n",
    "# Training data\n",
    "X_f_train_np_array, X_u_train_np_array, u_train_np_array = trainingdata(N_u,N_f)\n",
    "\n",
    "'Convert to tensor and send to GPU'\n",
    "X_f_train = torch.from_numpy(X_f_train_np_array).float().to(device)\n",
    "X_u_train = torch.from_numpy(X_u_train_np_array).float().to(device)\n",
    "u_train = torch.from_numpy(u_train_np_array).float().to(device)\n",
    "X_u_test_tensor = torch.from_numpy(X_u_test).float().to(device)\n",
    "u = torch.from_numpy(u_true).float().to(device)\n",
    "f_hat = torch.zeros(X_f_train.shape[0],1).to(device)\n",
    "\n",
    "layers = np.array([3, 1000, 1]) #3 hidden layers\n",
    "\n",
    "PINN = Sequentialmodel(layers)\n",
    "       \n",
    "PINN.to(device)\n",
    "\n",
    "'Neural Network Summary'\n",
    "\n",
    "print(PINN)\n",
    "\n",
    "params = list(PINN.parameters())\n",
    "\n",
    "'''Optimization'''\n",
    "\n",
    "theta_init = [p.data.clone() for p in PINN.parameters()]\n",
    "K0 = 100       \n",
    "K1 = 10      \n",
    "gamma = 0.1       \n",
    "eta = 0.5     \n",
    "\n",
    "final_params, loss_list, diff_norm_list,lin_diff_norm_list = IGD_PINN(PINN, X_u_train, u_train, X_f_train, theta_init, K0, K1, gamma, eta)\n",
    "\n",
    "plt.plot(loss_list)\n",
    "plt.yscale('log')\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('Loss')\n",
    "plt.title('Loss (only train a_layer)')\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.plot(diff_norm_list, label='Interior NTK matrix', linewidth=2, color='#0072B2')\n",
    "plt.plot([x + 1e-12 for x in lin_diff_norm_list], label='Boundary NTK matrix', linewidth=2, color='#E69F00')\n",
    "plt.yscale('log')\n",
    "plt.ylim(1e-13, 2.0)  \n",
    "plt.xlabel('Iteration', fontsize=13)\n",
    "plt.ylabel('Relative Frobenius norm', fontsize=13)\n",
    "plt.title('Relative Frobenius norm for two NTK matrices', fontsize=14, pad=8)\n",
    "plt.yticks([1e-12, 1e-4, 1e-3, 1e-2, 1e-1, 1], \n",
    "           ['1e-12', '1e-4', '1e-3', '1e-2', '1e-1', '1'])\n",
    "\n",
    "plt.legend(loc='center right', fontsize=12, frameon=False)\n",
    "plt.grid(which='both', color='#e0e0e0', linestyle='--', linewidth=0.8, alpha=0.7)\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "python_31015",
   "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.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
