{
 "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",
    "# u = (sin(pi x)cos(pi y) + 0.1sin(10pi x)cos(10pi y)) * exp(-t)\n",
    "usol = (\n",
    "    np.sin(np.pi * X) * np.cos(np.pi * Y) +\n",
    "    0.1 * np.sin(10 * np.pi * X) * np.cos(10 * np.pi * Y)\n",
    ") * np.exp(-T)\n",
    "\n",
    "u_true = usol.flatten('F')[:, None]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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],   # x=-1\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],  # x=1\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],   # y=1\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],  # y=-1\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",
    "        # S(x, y, t) = -2u(x, y, t) + 2ε^2π^2*sin(πx)cos(πy)e^{-t} \n",
    "        #             + 20ε^2π^2*sin(10πx)cos(10πy)e^{-t} \n",
    "        #             + [sin(πx)cos(πy) + 0.1sin(10πx)cos(10πy)]^3 e^{-3t}\n",
    "        epsilon = 0.1 \n",
    "        pi = np.pi\n",
    "        s1 = torch.sin(pi * x) * torch.cos(pi * y)\n",
    "        s2 = 0.1 * torch.sin(10 * pi * x) * torch.cos(10 * pi * y)\n",
    "        u = (s1 + s2) * torch.exp(-t)\n",
    "\n",
    "        S = (-2) * u \\\n",
    "            + 2 * epsilon**2 * pi**2 * s1 * torch.exp(-t) \\\n",
    "            + 20 * epsilon**2 * pi**2 * (0.1 * torch.sin(10 * pi * x) * torch.cos(10 * pi * y)) * torch.exp(-t) \\\n",
    "            + (s1 + s2) ** 3 * torch.exp(-3*t)\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",
    "        epsilon = 0.1 \n",
    "        \n",
    "        # Allen-Cahn PDE residual\n",
    "        pde_f = u_t - epsilon**2 * (u_xx + u_yy) + (u**3 - 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",
    "       \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 : 4.89143014e-01, Relative Frobenius norm for interior NTK matrix : 2.27283835e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 10, loss : 4.33247000e-01, Relative Frobenius norm for interior NTK matrix : 7.20344260e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 20, loss : 4.11567688e-01, Relative Frobenius norm for interior NTK matrix : 7.51800463e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 30, loss : 3.92487466e-01, Relative Frobenius norm for interior NTK matrix : 7.37554133e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 40, loss : 3.74937683e-01, Relative Frobenius norm for interior NTK matrix : 7.13829324e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 50, loss : 3.58763754e-01, Relative Frobenius norm for interior NTK matrix : 6.90058321e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 60, loss : 3.43856037e-01, Relative Frobenius norm for interior NTK matrix : 6.69008344e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 70, loss : 3.30114216e-01, Relative Frobenius norm for interior NTK matrix : 6.51987493e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 80, loss : 3.17444831e-01, Relative Frobenius norm for interior NTK matrix : 6.40034899e-02, Relative Frobenius norm for boundary NTK matrix : 0.00000000e+00\n",
      "Iteration 90, loss : 3.05761009e-01, Relative Frobenius norm for interior NTK matrix : 6.34099171e-02, 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
}
