{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3d493a8f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wulab/.local/lib/python3.8/site-packages/pandas/core/computation/expressions.py:20: UserWarning: Pandas requires version '2.7.3' or newer of 'numexpr' (version '2.7.1' currently installed).\n",
      "  from pandas.core.computation.check import NUMEXPR_INSTALLED\n"
     ]
    }
   ],
   "source": [
    "# Import all necessary packages\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.integrate import solve_ivp\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from sklearn.model_selection import train_test_split\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "import math\n",
    "import optuna\n",
    "from sklearn import preprocessing\n",
    "import random\n",
    "from scipy.io import loadmat\n",
    "# Set up GPU accelerated training\n",
    "\n",
    "# device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "# print('using GPU:', torch.cuda.get_device_name()) if torch.cuda.is_available() else print('using cpu')\n",
    "\n",
    "device = torch.device(\"cpu\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b52e2270",
   "metadata": {},
   "source": [
    "# Data generation for data driven"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fbe60e99",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "usol shape: (256, 100)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 864x720 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def convection_diffusion(beta, nu=0, source=0, xgrid=256, nt=100):\n",
    "    \"\"\"Calculate the u solution for convection/diffusion, assuming PBCs.\n",
    "    Args:\n",
    "        u0: Initial condition\n",
    "        nu: viscosity coefficient\n",
    "        beta: wavespeed coefficient\n",
    "        source: q (forcing term), option to have this be a constant\n",
    "        xgrid: size of the x grid\n",
    "    Returns:\n",
    "        u_vals: solution\n",
    "    \"\"\"\n",
    "\n",
    "    N = xgrid\n",
    "    h = 2 * np.pi / N\n",
    "    x = np.arange(0, 2*np.pi, h) # not inclusive of the last point\n",
    "    t = np.linspace(0, 1, nt).reshape(-1, 1)\n",
    "    X, T = np.meshgrid(x, t)\n",
    "\n",
    "    # call u0 this way so array is (n, ), so each row of u should also be (n, )\n",
    "    # u0 = function(u0)\n",
    "    u0 = np.sin(x)\n",
    "\n",
    "    G = (np.copy(u0)*0)+source # G is the same size as u0\n",
    "\n",
    "    IKX_pos =1j * np.arange(0, N/2+1, 1)\n",
    "    IKX_neg = 1j * np.arange(-N/2+1, 0, 1)\n",
    "    IKX = np.concatenate((IKX_pos, IKX_neg))\n",
    "    IKX2 = IKX * IKX\n",
    "\n",
    "    uhat0 = np.fft.fft(u0)\n",
    "    nu_factor = np.exp(nu * IKX2 * T - beta * IKX * T)\n",
    "    A = uhat0 - np.fft.fft(G)*0 # at t=0, second term goes away\n",
    "    uhat = A*nu_factor + np.fft.fft(G)*T # for constant, fft(p) dt = fft(p)*T\n",
    "    u = np.real(np.fft.ifft(uhat))\n",
    "\n",
    "    u_vals = u.flatten()\n",
    "    return u_vals\n",
    "\n",
    "xgrid = 256\n",
    "nt = 100\n",
    "True_beta = 50.0\n",
    "\n",
    "x_star = np.linspace(0, 2*np.pi, xgrid, endpoint=False).reshape(-1, 1) # not inclusive\n",
    "t_star = np.linspace(0, 1, nt).reshape(-1, 1)\n",
    "XX, TT = np.meshgrid(x_star, t_star) # all the X grid points T times, all the T grid points X times\n",
    "\n",
    "usol = convection_diffusion(beta=True_beta, nu=0, source=0, xgrid=xgrid, nt=nt)\n",
    "usol = usol.reshape(-1, 1) # Exact solution reshaped into (n, 1)\n",
    "usol = usol.reshape(len(t_star), len(x_star)) # Exact on the (x,t) grid\n",
    "usol = usol.T\n",
    "print('usol shape:', usol.shape)\n",
    "\n",
    "# Reference solution\n",
    "plt.figure(figsize=(12, 10))\n",
    "plt.pcolor(TT, XX, usol.T, cmap='jet')\n",
    "plt.colorbar()\n",
    "plt.xlabel('$t$')\n",
    "plt.ylabel('$x$')\n",
    "plt.title('Reference solution')\n",
    "plt.show()\n",
    "\n",
    "# ---------- pick the three times we want ----------\n",
    "times_to_plot = [0.25, 0.50, 0.75]\n",
    "t_arr = t_star.flatten()  # shape: (nt,)\n",
    "idx_list = [int(np.argmin(np.abs(t_arr - tau))) for tau in times_to_plot]\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "for tau, idx in zip(times_to_plot, idx_list):\n",
    "    plt.plot(x_star.flatten(), usol[:, idx], lw=2, label=fr\"$t \\approx {t_arr[idx]:.2f}$\")\n",
    "\n",
    "plt.xlabel(r\"$x$\")\n",
    "plt.ylabel(r\"$u(x,t)$\")\n",
    "plt.title(\"u vs x at selected times\")\n",
    "plt.legend()\n",
    "plt.grid(True, alpha=0.3)\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be7893d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collocation points torch.Size([2550, 2])\n",
      "Initial points torch.Size([256, 2])\n",
      "Initial values torch.Size([256, 1])\n",
      "Boundary points at x=0 torch.Size([100, 2])\n",
      "Boundary points at x=2pi torch.Size([100, 2])\n",
      "Input_data.shape: torch.Size([25, 2])\n",
      "U_data.shape: torch.Size([25, 1])\n",
      "t_test.shape: torch.Size([25600, 2])\n",
      "U_test.shape: torch.Size([25600, 1])\n"
     ]
    }
   ],
   "source": [
    "U_full = usol.T\n",
    "U_full = U_full.flatten()[:, None]\n",
    "Input_full = np.vstack((np.ravel(XX), np.ravel(TT))).T\n",
    "\n",
    "\n",
    "n_data = 25 \n",
    "idx_data = np.random.choice(U_full.shape[0], n_data, replace=False)\n",
    "Input_data  = Input_full[idx_data]                # shape=(n_data,2)\n",
    "U_data  = U_full[idx_data]                # shape=(n_data,1)\n",
    "\n",
    "\n",
    "Nx_f = 50          # interior points in x   (excluding boundaries)\n",
    "Nt_f = 50         # interior points in t   (excluding boundaries)\n",
    "x_f = np.linspace(0.0, 2*np.pi, Nx_f+1)[1:]   # skip −1, +1\n",
    "t_f = np.linspace(0.0, 1.0, Nt_f+2)[1:]    # skip   0,  1\n",
    "xx_f, tt_f = np.meshgrid(x_f, t_f)           # shape (Nt_f, Nx_f)\n",
    "Input_f = np.vstack([xx_f.ravel(), tt_f.ravel()]).T       # (Nx_f*Nt_f, 2)\n",
    "\n",
    "# initial points (t=0) x\n",
    "N_ic = 256\n",
    "x_ic = np.linspace(0, 2*np.pi, xgrid, endpoint=False)[:,None]\n",
    "t_ic = np.zeros_like(x_ic)\n",
    "u_ic = np.sin(x_ic) # initial condition u(x,0) = sin(x)\n",
    "Input_ic = np.hstack((x_ic, t_ic)) # shape (256,2)\n",
    "\n",
    "\n",
    "# boundary points u(0, t) = u(2π, t).\n",
    "Input_bc_lb = np.hstack((XX[:,0:1], TT[:,0:1]))\n",
    "Input_bc_up = np.hstack((np.ones_like(XX[:,0:1])*(2*np.pi), TT[:,0:1]))\n",
    "# u_bc = usol[0:1, :] # u(-end, t)\n",
    "# u_bc = u_bc.T # shape (100,1)\n",
    "\n",
    "\n",
    "Input_f = torch.tensor(Input_f).to(device).float().requires_grad_(True) # Collocation points\n",
    "Input_ic = torch.tensor(Input_ic).to(device).float() # Initial points\n",
    "u_ic = torch.tensor(u_ic).to(device).float() # Initial values\n",
    "Input_bc_lb = torch.tensor(Input_bc_lb).to(device).float() # Boundary points at x=0\n",
    "Input_bc_up = torch.tensor(Input_bc_up).to(device).float() # Boundary points at x=2pi\n",
    "# u_bc = torch.tensor(u_bc).to(device).float() # Boundary values\n",
    "# Observed data points\n",
    "Input_data = torch.tensor(Input_data).to(device).float()\n",
    "U_data = torch.from_numpy(U_data)\n",
    "Input_test = torch.from_numpy(Input_full).to(device).float()\n",
    "U_test = torch.from_numpy(U_full)\n",
    "\n",
    "print('Collocation points', Input_f.shape)\n",
    "print('Initial points', Input_ic.shape)\n",
    "print('Initial values', u_ic.shape)\n",
    "print('Boundary points at x=0', Input_bc_lb.shape)\n",
    "print('Boundary points at x=2pi', Input_bc_up.shape)\n",
    "\n",
    "# print('Boundary values', u_bc.shape)\n",
    "print('Input_data.shape:', Input_data.shape)\n",
    "print('U_data.shape:', U_data.shape)\n",
    "print('t_test.shape:', Input_test.shape)\n",
    "print('U_test.shape:', U_test.shape)\n",
    "\n",
    "# Save the data\n",
    "torch.save(Input_f, 'Input_f.pt')\n",
    "torch.save(Input_ic, 'Input_ic.pt')\n",
    "torch.save(u_ic, 'u_ic.pt')\n",
    "torch.save(Input_bc_lb, 'Input_bc_lb.pt')\n",
    "torch.save(Input_bc_up, 'Input_bc_up.pt')\n",
    "torch.save(Input_data, 'Input_data.pt')\n",
    "torch.save(U_data, 'U_data.pt')\n",
    "torch.save(Input_test, 'Input_test.pt')\n",
    "torch.save(U_test, 'U_test.pt')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e5025cec",
   "metadata": {},
   "source": [
    "# Regional devision"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6f67863",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from sklearn.cluster import KMeans\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "X_collocation = torch.load('Input_f.pt')\n",
    "print(f'X_collocation shape is {X_collocation.shape}')\n",
    "\n",
    "# X_collocation shape is torch.Size([400, 2])\n",
    "\n",
    "# Assume X_collocation is\n",
    "X_collocation = X_collocation.detach().cpu().numpy() # Convert to a NumPy array\n",
    "\n",
    "# Set the number of clusters\n",
    "K = 3\n",
    "kmeans = KMeans(n_clusters=K, random_state=0)\n",
    "region_ids = kmeans.fit_predict(X_collocation) # shape: (1000,)\n",
    "\n",
    "# Set the index of each region\n",
    "Ω_k = [np.where(region_ids == k)[0] for k in range(K)] # A list of length K, each element is an index array\n",
    "np.save('Ω_k.npy', Ω_k) # Save the region index set\n",
    "\n",
    "# Example: Access the collocation points in the first region\n",
    "X_region_1 = X_collocation[Ω_k[0]] # shape: (number of region points, 4)\n",
    "X_region_2 = X_collocation[Ω_k[1]] # shape: (number of region points, 4)\n",
    "X_region_3 = X_collocation[Ω_k[2]] # shape: (number of region points, 4)\n",
    "# X_region_4 = X_collocation[Ω_k[3]] # shape: (number of region points, 4)\n",
    "# X_region_5 = X_collocation[Ω_k[4]] # shape: (number of region points, 4)\n",
    "\n",
    "print(f\"✅ Region division is completed, each region contains points: {[len(Ω_k[k]) for k in range(K)]}\")\n",
    "print(f\"Shape of the collocation points in Region 1: {X_region_1.shape}\")\n",
    "print(f\"Shape of the collocation points in Region 2: {X_region_2.shape}\")\n",
    "print(f\"Shape of the collocation points in Region 3: {X_region_3.shape}\")\n",
    "# print(f\"Shape of the collocation points in Region 4: {X_region_4.shape}\")\n",
    "# print(f\"Shape of the collocation points in Region 5: {X_region_5.shape}\")\n",
    "\n",
    "plt.figure(figsize=(10,10))\n",
    "plt.scatter(X_region_1[:, 0], X_region_1[:, 1], color='red', label='Region 1')\n",
    "plt.scatter(X_region_2[:, 0], X_region_2[:, 1], color='blue', label='Region 2')\n",
    "plt.scatter(X_region_3[:, 0], X_region_3[:, 1], color='green', label='Region 3')\n",
    "# plt.scatter(X_region_4[:, 0], X_region_4[:, 1], color='purple', label='Region 4')\n",
    "# plt.scatter(X_region_5[:, 0], X_region_5[:, 1], color='orange', label='Region 5')\n",
    "plt.title('Collocation Points in Different Regions')\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('t')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6ee496f2",
   "metadata": {},
   "source": [
    "# resample_collocation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d6a311f",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def resample_collocation(Ω_k, alpha_k, N_total=1000):\n",
    "    \"\"\"\n",
    "        Resample collocation points from X_collocation based on Ω_k.\n",
    "        Ω_k: list of numpy arrays, each containing indices of collocation points for each region\n",
    "        alpha_k: list of floats, weights for each region, \n",
    "                should sum to number of loss (loss_data + loss_region_1 + loss_region_2 + loss_region_3 )\n",
    "        N_total: int, total number of collocation points to sample\n",
    "    \"\"\"\n",
    "    sampled_indices = []\n",
    "    alpha_k = np.array(alpha_k[:3])/6 # \n",
    "    ratio_k = alpha_k / np.sum(alpha_k)  # \n",
    "    ratio_k = np.round(ratio_k, 2)  # \n",
    "    print(f'ratio_k: {ratio_k}')\n",
    "    for i, Ω in enumerate(Ω_k):\n",
    "\n",
    "        N_region = int(N_total * ratio_k[i])\n",
    "        print(f'Region {i+1}, N_region: {N_region}, Ω size: {Ω.shape[0]}')\n",
    " \n",
    "        # sampled_indices_region = np.random.choice(Ω, size=N_region, replace=False)\n",
    "        # Uniform sampling from region: equally spaced indices\n",
    "        indices = np.linspace(0, len(Ω) - 1, N_region, dtype=int)\n",
    "        sampled_indices_region = Ω[indices]\n",
    "\n",
    "        sampled_indices.append(sampled_indices_region)\n",
    "        \n",
    "    sampled_indices = np.array(sampled_indices)\n",
    "    return sampled_indices\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1191b7f5",
   "metadata": {},
   "source": [
    "# Training process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3a05f599",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the data\n",
    "Input_f = torch.load('Input_f.pt')\n",
    "Input_ic = torch.load('Input_ic.pt')\n",
    "u_ic = torch.load('u_ic.pt')\n",
    "Input_data = torch.load('Input_data.pt')\n",
    "U_data = torch.load('U_data.pt')\n",
    "Input_test = torch.load('Input_test.pt')\n",
    "U_test = torch.load('U_test.pt')\n",
    "\n",
    "Input_bc_lb = torch.load('Input_bc_lb.pt')\n",
    "Input_bc_up = torch.load('Input_bc_up.pt')\n",
    "\n",
    "\n",
    "class PINN(nn.Module):\n",
    "    def __init__(self,N_INPUT, N_OUTPUT, N_HIDDEN):\n",
    "        super(PINN, self).__init__()\n",
    "        self.fc1 = nn.Linear(N_INPUT, N_HIDDEN)\n",
    "        self.fc2 = nn.Linear(N_HIDDEN, N_HIDDEN)\n",
    "        self.fc3 = nn.Linear(N_HIDDEN, N_HIDDEN)\n",
    "        self.fc4 = nn.Linear(N_HIDDEN, N_HIDDEN)\n",
    "        self.fc5= nn.Linear(N_HIDDEN, N_OUTPUT)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = torch.tanh(self.fc1(x))\n",
    "        x = torch.tanh(self.fc2(x))\n",
    "        x = torch.tanh(self.fc3(x))\n",
    "        x = torch.tanh(self.fc4(x))\n",
    "        x = self.fc5(x)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30fcb78b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_uniform(n_resample,\n",
    "                   x_min=0.0, x_max=2*np.pi,\n",
    "                   t_min=0.0, t_max=1.0,\n",
    "                   exclude_boundary=True,\n",
    "                   allow_approx=True,\n",
    "                   search_radius=None,\n",
    "                   prefer_x_dense=True):\n",
    "    \"\"\"\n",
    "    2D uniform grid sampling, ensuring Nx_f * Nt_f ≈ n_resample, and |Nx_f - Nt_f| is as small as possible.\n",
    "    - If the original decomposition is very thin and long, prioritize finding a more square decomposition point in the neighborhood (e.g., 1399 ≈ 1400 = 35 × 40).\n",
    "\n",
    "    Returns:\n",
    "    Input_f : (N_actual, 2) sampling points [x, t]\n",
    "    Nx_f, Nt_f : int grid numbers in the x and t directions\n",
    "    N_actual : int actual number of points used (may differ from n_resample)\n",
    "    \"\"\"\n",
    "\n",
    "    def best_pair_exact(N: int):\n",
    "        a = int(np.floor(np.sqrt(N)))\n",
    "        while a > 0 and N % a != 0:\n",
    "            a -= 1\n",
    "        b = N // a\n",
    "        return a, b, abs(a - b)  # a <= b, gap = |a-b|\n",
    "\n",
    "    n = int(n_resample)\n",
    "    if n <= 0:\n",
    "        raise ValueError(\"n_resample must be positive.\")\n",
    "\n",
    "    Nx, Nt, gap = best_pair_exact(n)\n",
    "    N_use = n\n",
    "\n",
    "    if allow_approx:\n",
    "        thresh = max(2, int(0.25 * np.sqrt(n)))  \n",
    "        if Nx == 1 or gap > thresh:\n",
    "            if search_radius is None:\n",
    "                search_radius = max(50, int(2 * np.ceil(np.sqrt(n))))\n",
    "\n",
    "            best = None  # will hold dict: {\"Nx\":a, \"Nt\":b, \"N\":cand, \"score\":(gap, dist)}\n",
    "            for d in range(0, search_radius + 1):\n",
    "                cands = (n,) if d == 0 else (n - d, n + d)\n",
    "                for cand in cands:\n",
    "                    if cand <= 0:\n",
    "                        continue\n",
    "                    a, b, g = best_pair_exact(cand)\n",
    "                    dist = abs(cand - n)\n",
    "                    score = (g, dist)  \n",
    "                    if (best is None) or (score < best[\"score\"]):\n",
    "                        best = {\"Nx\": a, \"Nt\": b, \"N\": cand, \"score\": score}\n",
    "                if best is not None and best[\"score\"][0] <= 1 and d > 0:\n",
    "                    break\n",
    "\n",
    "            Nx, Nt, N_use = best[\"Nx\"], best[\"Nt\"], best[\"N\"]\n",
    "\n",
    "    if prefer_x_dense and Nt > Nx:\n",
    "        Nx, Nt = Nt, Nx\n",
    "\n",
    "    if exclude_boundary:\n",
    "        x_f = np.linspace(x_min, x_max, Nx + 2)[1:-1]\n",
    "        t_f = np.linspace(t_min, t_max, Nt + 2)[1:-1]\n",
    "    else:\n",
    "        x_f = np.linspace(x_min, x_max, Nx)\n",
    "        t_f = np.linspace(t_min, t_max, Nt)\n",
    "\n",
    "    xx, tt = np.meshgrid(x_f, t_f)  # (Nt, Nx)\n",
    "    Input_f = np.vstack([xx.ravel(), tt.ravel()]).T\n",
    "\n",
    "    print(f\"Target={n}, Used={N_use}, Nx_f={Nx}, Nt_f={Nt}, gap={abs(Nx-Nt)}\")\n",
    "    return Input_f\n",
    "\n",
    "\n",
    "#----------- Hyperparameters ----------\n",
    "beta_init = 45.0\n",
    "N_collocation = 1000"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "26b27a15",
   "metadata": {},
   "source": [
    "# Baseline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11f52912",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_model(model, n_epochs):\n",
    "    train_losses = []\n",
    "    valid_losses = []\n",
    "    para_list = []\n",
    "    loss_list = []\n",
    "    valid_L2errors = []\n",
    "\n",
    "    beta = torch.nn.Parameter(torch.tensor(beta_init),requires_grad=True)\n",
    "    optimizer = torch.optim.Adam([\n",
    "        {'params': model.parameters(), 'lr': 1e-3}, \n",
    "        {'params': beta, 'lr': 1e-3}])\n",
    "\n",
    "\n",
    "    # alpha_k = [0.35, 0.3, 0.35, 1.0, 1.0, 1.0] \n",
    "\n",
    "    alpha_k = [1.0, 1.0, 1.0, 1.0, 1.0, 1.0] \n",
    "    print(f'alpha_k: {alpha_k}')\n",
    "\n",
    "    Nr = N_collocation  \n",
    "    # # --------Set resample_collocation function to resample collocation points based on Ω_k and alpha_k.\n",
    "    # sampled_indices = resample_collocation(Ω_k, alpha_k)  # Resample collocation points\n",
    "    X_collocation_Nr = sample_uniform(Nr)  # Resample collocation points\n",
    "    plt.figure(figsize=(10, 10))\n",
    "    plt.scatter(X_collocation_Nr[:, 0], X_collocation_Nr[:, 1], color='blue', label='Collocation Points')\n",
    "    plt.title('Collocation Points')\n",
    "    plt.xlabel('x')\n",
    "    plt.ylabel('t')\n",
    "    plt.legend()\n",
    "    plt.grid()\n",
    "    plt.show()\n",
    "    X_collocation_Nr = torch.tensor(X_collocation_Nr, dtype=torch.float32, device=device, requires_grad=True)\n",
    "\n",
    "    for epoch in range(1,n_epochs+1):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "\n",
    "        # residual loss\n",
    "        U_pred = model(X_collocation_Nr) \n",
    "        dudx = torch.autograd.grad(U_pred.sum(), X_collocation_Nr, create_graph=True)[0][:, 0:1]\n",
    "        dudt = torch.autograd.grad(U_pred.sum(), X_collocation_Nr, create_graph=True)[0][:, 1:2]\n",
    "        loss_physics = dudt + beta * dudx      # Convection equation residual\n",
    "\n",
    "\n",
    "        # loss_physics = alpha_k[0] * loss_region_1 + alpha_k[1] * loss_region_2 + alpha_k[2] * loss_region_3 \n",
    "        loss_physics = torch.mean(loss_physics**2)\n",
    "        print(f'Epoch {epoch}, loss_physics: {loss_physics.item()}')\n",
    "\n",
    "        # Initial condition loss\n",
    "        U_pred_initial = model(Input_ic)\n",
    "        loss_initial = torch.mean((U_pred_initial - u_ic)**2)\n",
    "        print(f'Epoch {epoch}, loss_initial: {loss_initial.item()}')\n",
    "\n",
    "        # Boundary condition loss\n",
    "        U_pred_bc_lb = model(Input_bc_lb)\n",
    "        U_pred_bc_up = model(Input_bc_up)\n",
    "        loss_bc = torch.mean((U_pred_bc_lb - U_pred_bc_up)**2)\n",
    "        print(f'Epoch {epoch}, loss_bc: {loss_bc.item()}')\n",
    "\n",
    "        # Data loss\n",
    "        U_pred = model(Input_data)\n",
    "        loss_data = torch.mean((U_pred - U_data)**2)\n",
    "        print(f'Epoch {epoch}, loss_data: {loss_data.item()}')\n",
    "\n",
    "        loss =  3*loss_physics + alpha_k[3]* loss_initial + alpha_k[4]*loss_bc + alpha_k[5]*loss_data\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        train_losses.append(loss.item())\n",
    "        para_list.append(beta.item())\n",
    "        print(f'Epoch {epoch}, beta: {beta.item()}')\n",
    "        loss_list.append([loss_physics.item(), loss_initial.item(), loss_bc.item(), loss_data.item()])\n",
    "\n",
    "        # Validation loss\n",
    "        model.eval()\n",
    "        U_pred = model(Input_test)\n",
    "        loss = torch.mean((U_pred - U_test)**2)\n",
    "        valid_losses.append(loss.item())\n",
    "\n",
    "       # ✅ L2 Relative Error\n",
    "        relative_error = torch.norm(U_pred - U_test) / torch.norm(U_test)\n",
    "        valid_L2errors.append(relative_error.item())\n",
    "\n",
    "        print_msg = (f'[{epoch}/{n_epochs}] ' +\n",
    "                f'train_loss: {train_losses[-1]:.5f} ' +\n",
    "                f'valid_loss: {valid_losses[-1]:.5f}' +\n",
    "                f' L2_error: {valid_L2errors[-1]:.5f}')\n",
    "\n",
    "\n",
    "        print(print_msg)            \n",
    "\n",
    "\n",
    "    print('Finished Training') \n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(range(1, len(valid_losses) + 1), valid_losses, label='Validation Loss')\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('loss')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(range(1, len(valid_L2errors) + 1), valid_L2errors, label='Validation L2 Relative Error')\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('L2 Relative Error')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    # Plot the exact solution and the predicted solution for t = 0.25, 0.5, 0.75    \n",
    "    \n",
    "    U_pred = U_pred.detach().cpu().numpy()  #\n",
    "    U_tmp = U_pred.reshape(nt,xgrid)        # row-major order matches np.flatten()\n",
    "    U_tmp = U_tmp.T  \n",
    "\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    for tau, idx in zip(times_to_plot, idx_list):\n",
    "        plt.plot(x_star.flatten(), usol[:, idx], lw=2, label=fr\"$t \\approx {t_arr[idx]:.2f}$\")\n",
    "        plt.plot(x_star.flatten(), U_tmp[:, idx], '--', lw=2, label=fr\"PINN $t \\approx {t_arr[idx]:.2f}$\")\n",
    "\n",
    "    plt.xlabel(r\"$x$\")\n",
    "    plt.ylabel(r\"$u(x,t)$\")\n",
    "    plt.title(\"u vs x at selected times\")\n",
    "    plt.legend()\n",
    "    plt.grid(True, alpha=0.3)\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "    para_list = np.array(para_list) \n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(para_list, label='PINN', color='b')\n",
    "    plt.axhline(y=True_beta, color='b', linestyle='--', label='true_beta')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Value\")\n",
    "    plt.title(\"Parameter Estimation\")\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    # ---------- 2‑D heat‑map ----------\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.pcolor(TT, XX,  U_tmp.T, cmap='jet')\n",
    "    plt.colorbar()\n",
    "    plt.xlabel('$t$')\n",
    "    plt.ylabel('$x$')\n",
    "    plt.title('Predicted u(x,t)')\n",
    "    plt.show()\n",
    "\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.pcolor(TT, XX, np.abs(usol.T - U_tmp.T), cmap='jet')\n",
    "    plt.colorbar()\n",
    "    plt.xlabel('$t$')\n",
    "    plt.ylabel('$x$')\n",
    "    plt.title('Absolute error of u(x,t)')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "    loss_list = np.array(loss_list)\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(loss_list[:,0], label='physics loss', color='r')\n",
    "    plt.plot(loss_list[:,1], label='initial loss', color='g')\n",
    "    plt.plot(loss_list[:,2], label='bc loss', color='b')\n",
    "    plt.plot(loss_list[:,3], label='data loss', color='purple')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Loss\")\n",
    "    plt.yscale('log')\n",
    "    plt.title(\"Loss\")\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    return model, train_losses, valid_losses, loss_list, para_list, valid_L2errors\n",
    "\n",
    "model_PINN = PINN(2, 1, 40)\n",
    "model_PINN.to(device)\n",
    "print(model_PINN)\n",
    "\n",
    "model_PINN, train_losses, valid_losses,loss_list, para_list, valid_L2errors = train_model(model_PINN, n_epochs=80000)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1021005f",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('loss_list_baseline_2.npy',loss_list)\n",
    "np.save('para_list_baseline_2.npy',para_list)\n",
    "np.save('valid_losses_baseline_2.npy',valid_losses)\n",
    "np.save('valid_L2errors_baseline_2.npy',valid_L2errors)\n",
    "torch.save(model_PINN,'baseline_2.pkl')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "599f44d7",
   "metadata": {},
   "source": [
    "# PaRS "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f152c866",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pymoo.algorithms.moo.nsga2 import NSGA2\n",
    "from pymoo.operators.mutation.pm import PM\n",
    "from pymoo.operators.crossover.sbx import SBX\n",
    "from pymoo.algorithms.moo.nsga3 import NSGA3\n",
    "from pymoo.core.problem import Problem\n",
    "from pymoo.optimize import minimize\n",
    "import torch\n",
    "import numpy as np\n",
    "from pymoo.core.sampling import Sampling\n",
    "import copy\n",
    "\n",
    "\n",
    "'''\n",
    "MOO without Normalized Loss\n",
    "'''\n",
    "\n",
    "class NeuralNetworkMOO(Problem):\n",
    "    def __init__(self, model, device):\n",
    "        super().__init__(\n",
    "            n_var=sum(p.numel() for p in model.parameters()) + 1,  # \n",
    "            n_obj=6,  \n",
    "            n_constr=0,  #\n",
    "            xl=np.hstack([[-10] * sum(p.numel() for p in model.parameters()), 40]), \n",
    "            xu=np.hstack([[10] * sum(p.numel() for p in model.parameters()), 55])  \n",
    "        )\n",
    "\n",
    "        self.model = model\n",
    "        self.device = device\n",
    "\n",
    "    def _evaluate(self, X, out, *args, **kwargs):\n",
    "\n",
    "        # print('x shape:', X.shape)\n",
    "        Ω_k = np.load('Ω_k.npy', allow_pickle=True)  # \n",
    "\n",
    "        object_list = []\n",
    "\n",
    "        for i in range(X.shape[0]):\n",
    "            \n",
    "            # start_idx 用于追踪参数的起始索引\n",
    "            start_idx = 0\n",
    "            for param in self.model.parameters():\n",
    "                num_params = param.numel()  # \n",
    "                # print('num_params:', num_params)\n",
    "                param_shape = param.shape   # \n",
    "                # print('param_shape:', param_shape)\n",
    "                param.data = torch.tensor(\n",
    "                    X[i, start_idx:start_idx + num_params].reshape(param_shape),    # \n",
    "                    device=self.device, \n",
    "                    dtype=param.dtype\n",
    "                )\n",
    "                start_idx += num_params     # \n",
    "            \n",
    "            beta = X[i, start_idx]  # \n",
    "                   \n",
    "            U_pred = self.model(Input_f) \n",
    "            dudx = torch.autograd.grad(U_pred.sum(), Input_f, create_graph=True)[0][:, 0:1]\n",
    "            dudt = torch.autograd.grad(U_pred.sum(), Input_f, create_graph=True)[0][:, 1:2]\n",
    "            loss_physics = dudt + beta * dudx      # Convection equation residual\n",
    "            loss_region_1 = torch.mean(loss_physics[Ω_k[0],:]**2) \n",
    "            loss_region_2 = torch.mean(loss_physics[Ω_k[1],:]**2) \n",
    "            loss_region_3 = torch.mean(loss_physics[Ω_k[2],:]**2) \n",
    "\n",
    "            # Data loss\n",
    "            U_pred = self.model(Input_data)\n",
    "            loss_data = torch.mean((U_pred - U_data)**2)\n",
    "\n",
    "            U_pred_initial = self.model(Input_ic)\n",
    "            loss_initial = torch.mean((U_pred_initial - u_ic)**2)\n",
    "\n",
    "            U_pred_bc_lb = self.model(Input_bc_lb)\n",
    "            U_pred_bc_up = self.model(Input_bc_up)\n",
    "            loss_bc = torch.mean((U_pred_bc_lb - U_pred_bc_up)**2)\n",
    " \n",
    "     \n",
    "        \n",
    "            object_list.append([\n",
    "                loss_region_1.item(),\n",
    "                loss_region_2.item(),\n",
    "                loss_region_3.item(),\n",
    "                loss_initial.item(), \n",
    "                loss_bc.item(), \n",
    "                loss_data.item()\n",
    "            ])\n",
    "        \n",
    "        # \n",
    "        out[\"F\"] = np.array(object_list)  \n",
    "        # print(out[\"F\"].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "caf356c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "from pymoo.algorithms.moo.nsga2 import NSGA2\n",
    "from pymoo.operators.mutation.pm import PM\n",
    "from pymoo.operators.crossover.sbx import SBX\n",
    "from pymoo.algorithms.moo.nsga3 import NSGA3\n",
    "from pymoo.core.problem import Problem\n",
    "from pymoo.optimize import minimize\n",
    "import torch\n",
    "import numpy as np\n",
    "from pymoo.core.sampling import Sampling\n",
    "import copy\n",
    "\n",
    "class CustomSampling(Sampling):\n",
    "    def __init__(self, initial_population):\n",
    "        super().__init__()\n",
    "        self.initial_population = initial_population\n",
    "\n",
    "    def _do(self, problem, n_samples, **kwargs):\n",
    "        # 生成种群，复制初始点到种群\n",
    "        return np.tile(self.initial_population, (n_samples, 1))\n",
    "\n",
    "def calculate_weights_std(F, loss_list, temperature=1):   \n",
    "    \"\"\"\n",
    "    Calculates dynamic loss weights based on Pareto front solutions.\n",
    "\n",
    "    Parameters:\n",
    "    - F: np.ndarray, the current Pareto front objective matrix, shape (n_solutions, n_objectives)\n",
    "    - lost_list: list, a list of loss values ​​for all past moments,\n",
    "    each element is typically a vector of the form [loss_physics, loss_initial, loss_data]\n",
    "    - temperature: float, the temperature parameter controlling the softmax normalization, defaults to 0.5\n",
    "\n",
    "    Returns:\n",
    "    - weights: np.ndarray, the calculated dynamic weights, shape (n_objectives,)\n",
    "    \"\"\"\n",
    "\n",
    "    alpha = 100 \n",
    "    loss_list = np.array(loss_list)\n",
    "    # prev_losses = np.mean(loss_list[-100:], axis=0)\n",
    "    prev_losses = np.min(loss_list[-alpha:], axis=0)\n",
    "    print(\"Previous losses:\", prev_losses)\n",
    "\n",
    "    min_F = np.min(F, axis=0)\n",
    "    print(\"Min:\", min_F)\n",
    "    max_F = np.max(F, axis=0)\n",
    "    print(\"Max:\", max_F)\n",
    "    F_normalized = (F - min_F) / (max_F - min_F)\n",
    "    means = np.mean(F, axis=0)\n",
    "    print (\"Means:\", means)\n",
    "    stds = np.std(F_normalized, axis=0)\n",
    "    print(\" Stds:\", stds)\n",
    "\n",
    "\n",
    "    improvement_ratio = means / prev_losses\n",
    "    print(\"Improvement ratio:\", improvement_ratio)\n",
    "\n",
    "    scores = stds / improvement_ratio\n",
    "    print(\"Scores:\", scores)\n",
    "\n",
    "    if prev_losses[-1] > 1e-3: \n",
    "        temperature = np.array([1, 1, 1, 1, 1, 0.2])\n",
    "    else: \n",
    "        temperature = 1\n",
    "\n",
    "    exp_scores = np.exp(scores /temperature)\n",
    "    weights = 6 * exp_scores / np.sum(exp_scores)\n",
    "\n",
    "\n",
    "    return weights\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20b461ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def train_model_with_moo(model, n_epochs):\n",
    "    train_losses = []\n",
    "    valid_losses = []\n",
    "    para_list = []\n",
    "    loss_list = []\n",
    "    valid_L2errors = []\n",
    "    weight_list = []\n",
    "\n",
    "    beta = torch.nn.Parameter(torch.tensor(beta_init),requires_grad=True)\n",
    "    # optimizer = torch.optim.Adam(model.parameters(), lr=1e-3)\n",
    "    optimizer = torch.optim.Adam([\n",
    "        {'params': model.parameters(), 'lr': 1e-3}, \n",
    "        {'params': beta, 'lr': 1e-3}])\n",
    "\n",
    "   \n",
    "\n",
    "\n",
    "    alpha_k = [1.0, 1.0, 1.0, 1.0, 1.0, 1.0]  # \n",
    "    print(f'alpha_k: {alpha_k}')\n",
    "    Ω_k = np.load('Ω_k.npy', allow_pickle=True)  # \n",
    "    \n",
    "    # --------Set resample_collocation function to resample collocation points based on Ω_k and alpha_k.\n",
    "    sampled_indices = resample_collocation(Ω_k, alpha_k)  # Resample collocation points\n",
    "\n",
    "\n",
    "    for epoch in range(1,n_epochs+1):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "\n",
    "        # residual loss\n",
    "        U_pred = model(Input_f) \n",
    "        dudx = torch.autograd.grad(U_pred.sum(), Input_f, create_graph=True)[0][:, 0:1]\n",
    "        dudt = torch.autograd.grad(U_pred.sum(), Input_f, create_graph=True)[0][:, 1:2]\n",
    "        loss_physics = dudt + beta * dudx      # Convection equation residual\n",
    "\n",
    "        loss_region_1 = torch.mean(loss_physics[sampled_indices[0],:]**2) \n",
    "        loss_region_2 = torch.mean(loss_physics[sampled_indices[1],:]**2) \n",
    "        loss_region_3 = torch.mean(loss_physics[sampled_indices[2],:]**2) \n",
    "\n",
    "        loss_physics = alpha_k[0] * loss_region_1 + alpha_k[1] * loss_region_2 + alpha_k[2] * loss_region_3 \n",
    "        print(f'Epoch {epoch}, loss_physics: {loss_physics.item()}')\n",
    "\n",
    "        # Initial condition loss\n",
    "        U_pred_initial = model(Input_ic)\n",
    "        loss_initial = torch.mean((U_pred_initial - u_ic)**2)\n",
    "        print(f'Epoch {epoch}, loss_initial: {loss_initial.item()}')\n",
    "\n",
    "        # Boundary condition loss\n",
    "        U_pred_bc_lb = model(Input_bc_lb)\n",
    "        U_pred_bc_up = model(Input_bc_up)\n",
    "        loss_bc = torch.mean((U_pred_bc_lb - U_pred_bc_up)**2)\n",
    "        print(f'Epoch {epoch}, loss_bc: {loss_bc.item()}')\n",
    "\n",
    "        # Data loss\n",
    "        U_pred = model(Input_data)\n",
    "        loss_data = torch.mean((U_pred - U_data)**2)\n",
    "        print(f'Epoch {epoch}, loss_data: {loss_data.item()}')\n",
    "\n",
    "        loss =  loss_physics + alpha_k[3]* loss_initial + alpha_k[4]*loss_bc + alpha_k[5]*loss_data\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        train_losses.append(loss.item())\n",
    "        para_list.append(beta.item())\n",
    "        print(f'Epoch {epoch}, beta: {beta.item()}')\n",
    "        loss_list.append([loss_region_1.item(), loss_region_2.item(), loss_region_3.item(), loss_initial.item(), loss_bc.item(), loss_data.item()])\n",
    "\n",
    "        # record weights\n",
    "        weight_list.append(alpha_k)\n",
    "        print(f'Epoch {epoch}, alpha_k: {alpha_k}')\n",
    "\n",
    "        ''' \n",
    "        Add PaRS optimization here\n",
    "        '''\n",
    "        if  epoch == 1000 or epoch == 5000 or epoch == 10000 or epoch == 15000 or epoch == 20000 or epoch == 25000 or epoch == 30000 or epoch == 35000:\n",
    "            initial_population = []\n",
    "            for param in model.parameters():\n",
    "                initial_population.append(param.detach().cpu().numpy().flatten())\n",
    "            initial_population.append(np.array([beta.item()]))\n",
    "\n",
    "            initial_population = np.concatenate(initial_population, axis=0)   \n",
    "\n",
    "            sampling = CustomSampling(initial_population)\n",
    "            \n",
    "            model_moo = copy.deepcopy(model).to(device)\n",
    "\n",
    "            problem = NeuralNetworkMOO(model_moo, device)\n",
    "\n",
    "            algorithm = NSGA2(\n",
    "                pop_size=50, \n",
    "                sampling=sampling,\n",
    "                mutation=PM(prob=0.2, eta=5),\n",
    "                crossover=SBX(prob=0.9, eta=10)\n",
    "                )\n",
    "\n",
    "            res = minimize(problem,\n",
    "                            algorithm,\n",
    "                            termination=('n_gen', 100),  # 每轮训练迭代1代\n",
    "                            seed=42,\n",
    "                            verbose=False)\n",
    "            print(\"Pareto front objectives:\", res.F)\n",
    "                \n",
    "            # calcualte the weights\n",
    "            traget_weights = calculate_weights_std(res.F, loss_list)\n",
    "            print(\"traget_weights:\", traget_weights)\n",
    "            alpha_k = traget_weights\n",
    "            \n",
    "            sampled_indices = resample_collocation(Ω_k, alpha_k)  # Resample collocation points\n",
    "\n",
    "\n",
    "        # Validation loss\n",
    "        model.eval()\n",
    "        U_pred = model(Input_test)\n",
    "        loss = torch.mean((U_pred - U_test)**2)\n",
    "        valid_losses.append(loss.item())\n",
    "\n",
    "       # ✅ L2 Relative Error\n",
    "        relative_error = torch.norm(U_pred - U_test) / torch.norm(U_test)\n",
    "        valid_L2errors.append(relative_error.item())\n",
    "\n",
    "        print_msg = (f'[{epoch}/{n_epochs}] ' +\n",
    "                f'train_loss: {train_losses[-1]:.5f} ' +\n",
    "                f'valid_loss: {valid_losses[-1]:.5f}' +\n",
    "                f' L2_error: {valid_L2errors[-1]:.5f}')\n",
    "\n",
    "\n",
    "        print(print_msg)            \n",
    "\n",
    "\n",
    "    print('Finished Training') \n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(range(1, len(valid_losses) + 1), valid_losses, label='Validation Loss')\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('loss')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(range(1, len(valid_L2errors) + 1), valid_L2errors, label='Validation L2 Relative Error')\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('L2 Relative Error')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    # Plot the exact solution and the predicted solution for t = 0.25, 0.5, 0.75    \n",
    "    \n",
    "    U_pred = U_pred.detach().cpu().numpy()  #\n",
    "    U_tmp = U_pred.reshape(nt,xgrid)        # row-major order matches np.flatten()\n",
    "    U_tmp = U_tmp.T  \n",
    "\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    for tau, idx in zip(times_to_plot, idx_list):\n",
    "        plt.plot(x_star.flatten(), usol[:, idx], lw=2, label=fr\"$t \\approx {t_arr[idx]:.2f}$\")\n",
    "        plt.plot(x_star.flatten(), U_tmp[:, idx], '--', lw=2, label=fr\"PINN $t \\approx {t_arr[idx]:.2f}$\")\n",
    "\n",
    "    plt.xlabel(r\"$x$\")\n",
    "    plt.ylabel(r\"$u(x,t)$\")\n",
    "    plt.title(\"u vs x at selected times\")\n",
    "    plt.legend()\n",
    "    plt.grid(True, alpha=0.3)\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "    para_list = np.array(para_list) \n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(para_list, label='PINN', color='b')\n",
    "    plt.axhline(y=True_beta, color='b', linestyle='--', label='true beta')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Value\")\n",
    "    plt.title(\"Parameter Estimation\")\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    # ---------- 2‑D heat‑map ----------\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.pcolor(TT, XX,  U_tmp.T, cmap='jet')\n",
    "    plt.colorbar()\n",
    "    plt.xlabel('$t$')\n",
    "    plt.ylabel('$x$')\n",
    "    plt.title('Predicted u(x,t)')\n",
    "    plt.show()\n",
    "\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.pcolor(TT, XX, np.abs(usol.T - U_tmp.T), cmap='jet')\n",
    "    plt.colorbar()\n",
    "    plt.xlabel('$t$')\n",
    "    plt.ylabel('$x$')\n",
    "    plt.title('Absolute error of u(x,t)')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "    loss_list = np.array(loss_list)\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(loss_list[:,0], label='physics loss', color='r')\n",
    "    plt.plot(loss_list[:,1], label='initial loss', color='g')\n",
    "    plt.plot(loss_list[:,2], label='bc loss', color='b')\n",
    "    plt.plot(loss_list[:,3], label='data loss', color='purple')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Loss\")\n",
    "    plt.yscale('log')\n",
    "    plt.title(\"Loss\")\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    return model, train_losses, valid_losses, loss_list, weight_list, para_list, valid_L2errors\n",
    "\n",
    "model_PINN = PINN(2, 1, 40)\n",
    "model_PINN.to(device)\n",
    "print(model_PINN)\n",
    "\n",
    "model_PINN, train_losses, valid_losses,loss_list,weight_list, para_list, valid_L2errors = train_model_with_moo(model_PINN, n_epochs=80000)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "05277134",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('loss_list_VARI_3.npy',loss_list)\n",
    "np.save('para_list_VARI_3.npy',para_list)\n",
    "np.save('valid_losses_VARI_3.npy',valid_losses)\n",
    "np.save('weight_list_VARI_3.npy',weight_list)\n",
    "np.save('valid_L2errors_VARI_3.npy',valid_L2errors)\n",
    "torch.save(model_PINN,'VARI_3.pkl')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e16df56f",
   "metadata": {},
   "source": [
    "# R3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "348f8b3c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_model(model, n_epochs):\n",
    "    train_losses = []\n",
    "    valid_losses = []\n",
    "    valid_L2errors = []\n",
    "    para_list = []\n",
    "    loss_list = []\n",
    "\n",
    "    beta = torch.nn.Parameter(torch.tensor(beta_init),requires_grad=True)\n",
    "    # optimizer = torch.optim.Adam(model.parameters(), lr=1e-3)\n",
    "    optimizer = torch.optim.Adam([\n",
    "        {'params': model.parameters(), 'lr': 1e-3}, \n",
    "        {'params': beta, 'lr': 1e-3}])\n",
    "\n",
    "\n",
    "    alpha_k = [1.0, 1.0, 1.0, 1.0, 1.0, 1.0]  # 权重系数，初始值为1.0\n",
    "    print(f'alpha_k: {alpha_k}')\n",
    "\n",
    "\n",
    "    Nr = N_collocation  # 每次迭代时，重新采样的collocation点数\n",
    "\n",
    "    def compute_residual(X_collocation_Nr):\n",
    "        \"\"\"\n",
    "\n",
    "        \"\"\"\n",
    "        U_pred = model(X_collocation_Nr)\n",
    "\n",
    "        dudx = torch.autograd.grad(U_pred.sum(), X_collocation_Nr, create_graph=True)[0][:, 0:1]\n",
    "        dudt = torch.autograd.grad(U_pred.sum(), X_collocation_Nr, create_graph=True)[0][:, 1:2]\n",
    "        loss_physics = dudt + beta * dudx      # Convection equation residual\n",
    "        # print(f'loss_physics shape: {loss_physics.shape}')\n",
    "        # Get absolute residuals\n",
    "        loss_physics = torch.abs(loss_physics)  #\n",
    "        # loss_physics = torch.mean(loss_physics**2, dim=1, keepdim=True)  #\n",
    "        # print(f'loss_physics shape after mean: {loss_physics.shape}')\n",
    "        return loss_physics.detach().cpu().numpy()  # \n",
    "\n",
    "    \n",
    "\n",
    "    X_collocation_Nr = sample_uniform(Nr)\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.scatter(X_collocation_Nr[:, 0], X_collocation_Nr[:, 1], color='blue', label='Collocation Points')\n",
    "    plt.xlabel('x')\n",
    "    plt.ylabel('t')\n",
    "    plt.title('Initial Collocation Points')\n",
    "    plt.legend()\n",
    "    plt.grid(True)\n",
    "    plt.show()\n",
    "    X_collocation_Nr = torch.tensor(X_collocation_Nr, dtype=torch.float32, device=device, requires_grad=True)\n",
    "    # print(f\"X_collocation_Nr:  {X_collocation_Nr.requires_grad}\") # True\n",
    "\n",
    "\n",
    "\n",
    "    for epoch in range(1,n_epochs+1):\n",
    "        model.train()\n",
    "\n",
    "        ##################\n",
    "        ####R3 #\n",
    "        ##################\n",
    "\n",
    "        if epoch % 1000 == 0 and epoch > 20000:\n",
    "            # Step 1: \n",
    "            residuals = compute_residual(X_collocation_Nr)\n",
    "            print('residuals shape is', residuals.shape)\n",
    "            # Step 2: \n",
    "            tau = residuals.mean().item()\n",
    "\n",
    "            # Step 3: \n",
    "\n",
    "            retained_mask = residuals[:, 0] > tau\n",
    "  \n",
    "            retained_samples = X_collocation_Nr[retained_mask]\n",
    "            print(f'Retain samples shape: {retained_samples.shape}')\n",
    "            # retained_samples = retained_samples.detach().requires_grad_(True).to(device)  # \n",
    "            retained_samples= retained_samples.detach().numpy()\n",
    "            print(f'Number of retained samples: {len(retained_samples)}')\n",
    "        \n",
    "            # Step 4:\n",
    "            n_resample = Nr - len(retained_samples)\n",
    "            print(f'Number of points to resample: {n_resample}')\n",
    "            resampled_points = sample_uniform(n_resample)\n",
    "\n",
    "            # # Step 5: \n",
    "            # X_collocation_Nr = torch.cat((retained_samples, resampled_points), dim=0)\n",
    "            X_collocation_Nr = np.vstack((retained_samples, resampled_points))\n",
    "            # X_collocation_Nr = sample_uniform(Nr)\n",
    "            plt.figure(figsize=(12, 10))\n",
    "            plt.scatter(retained_samples[:, 0], retained_samples[:, 1], color='blue', label='Retained Points')\n",
    "            plt.scatter(resampled_points[:, 0], resampled_points[:, 1], color='red', label='Resampled Points')\n",
    "            plt.xlabel('x')\n",
    "            plt.ylabel('t')\n",
    "            plt.title(f'Collocation Points after Resampling at Epoch {epoch}')\n",
    "            plt.legend()\n",
    "            plt.grid(True)\n",
    "            plt.show()\n",
    "            X_collocation_Nr = torch.tensor(X_collocation_Nr, dtype=torch.float32, device=device, requires_grad=True)\n",
    "            \n",
    "\n",
    "\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "\n",
    "        # residual loss\n",
    "        U_pred = model(X_collocation_Nr) \n",
    "        dudx = torch.autograd.grad(U_pred.sum(), X_collocation_Nr, create_graph=True)[0][:, 0:1]\n",
    "        dudt = torch.autograd.grad(U_pred.sum(), X_collocation_Nr, create_graph=True)[0][:, 1:2]\n",
    "        loss_physics = dudt + beta * dudx      # Convection equation residual\n",
    "        loss_physics = torch.mean(loss_physics**2)\n",
    "        print(f'Epoch {epoch}, loss_physics: {loss_physics.item()}')\n",
    "\n",
    "        # Initial condition loss\n",
    "        U_pred_initial = model(Input_ic)\n",
    "        loss_initial = torch.mean((U_pred_initial - u_ic)**2)\n",
    "        print(f'Epoch {epoch}, loss_initial: {loss_initial.item()}')\n",
    "\n",
    "        # Boundary condition loss\n",
    "        U_pred_bc_lb = model(Input_bc_lb)\n",
    "        U_pred_bc_up = model(Input_bc_up)\n",
    "        loss_bc = torch.mean((U_pred_bc_lb - U_pred_bc_up)**2)\n",
    "        print(f'Epoch {epoch}, loss_bc: {loss_bc.item()}')\n",
    "\n",
    "        # Data loss\n",
    "        U_pred = model(Input_data)\n",
    "        loss_data = torch.mean((U_pred - U_data)**2)\n",
    "        print(f'Epoch {epoch}, loss_data: {loss_data.item()}')\n",
    "\n",
    "        loss = 3*  loss_physics + alpha_k[3]* loss_initial + alpha_k[4]*loss_bc + alpha_k[5]*loss_data\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        train_losses.append(loss.item())\n",
    "        para_list.append(beta.item())\n",
    "        print(f'Epoch {epoch}, beta: {beta.item()}')\n",
    "        loss_list.append([loss_physics.item(), loss_initial.item(), loss_bc.item(), loss_data.item()])\n",
    "\n",
    "        # del U_pred, dudx, dudt, d2udx2 # \n",
    "\n",
    "        # Validation loss\n",
    "        model.eval()\n",
    "        U_pred = model(Input_test)\n",
    "        loss = torch.mean((U_pred - U_test)**2)\n",
    "        valid_losses.append(loss.item())\n",
    "\n",
    "        # ✅ L2 Relative Error\n",
    "        relative_error = torch.norm(U_pred - U_test) / torch.norm(U_test)\n",
    "        valid_L2errors.append(relative_error.item())\n",
    "\n",
    "        print_msg = (f'[{epoch}/{n_epochs}] ' +\n",
    "                f'train_loss: {train_losses[-1]:.5f} ' +\n",
    "                f'valid_loss: {valid_losses[-1]:.5f}' +\n",
    "                f' L2_error: {valid_L2errors[-1]:.5f}')\n",
    "\n",
    "\n",
    "        print(print_msg)            \n",
    "\n",
    "\n",
    "    print('Finished Training') \n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(range(1, len(valid_losses) + 1), valid_losses, label='Validation Loss')\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('loss')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(range(1, len(valid_L2errors) + 1), valid_L2errors, label='Validation L2 Relative Error')\n",
    "    plt.xlabel('epochs')\n",
    "    plt.ylabel('L2 Relative Error')\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    # Plot the exact solution and the predicted solution for t = 0.25, 0.5, 0.75    \n",
    "    \n",
    "    U_pred = U_pred.detach().cpu().numpy()  #\n",
    "    U_tmp = U_pred.reshape(nt,xgrid)        # row-major order matches np.flatten()\n",
    "    U_tmp = U_tmp.T  \n",
    "\n",
    "    plt.figure(figsize=(10, 6))\n",
    "    for tau, idx in zip(times_to_plot, idx_list):\n",
    "        plt.plot(x_star.flatten(), usol[:, idx], lw=2, label=fr\"$t \\approx {t_arr[idx]:.2f}$\")\n",
    "        plt.plot(x_star.flatten(), U_tmp[:, idx], '--', lw=2, label=fr\"PINN $t \\approx {t_arr[idx]:.2f}$\")\n",
    "\n",
    "    plt.xlabel(r\"$x$\")\n",
    "    plt.ylabel(r\"$u(x,t)$\")\n",
    "    plt.title(\"u vs x at selected times\")\n",
    "    plt.legend()\n",
    "    plt.grid(True, alpha=0.3)\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "    para_list = np.array(para_list) \n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(para_list, label='PINN', color='b')\n",
    "    plt.axhline(y=True_beta, color='b', linestyle='--', label='true beta')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Value\")\n",
    "    plt.title(\"Parameter Estimation\")\n",
    "    plt.yscale('log')\n",
    "    plt.grid(True)\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    # ---------- 2‑D heat‑map ----------\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.pcolor(TT, XX,  U_tmp.T, cmap='jet')\n",
    "    plt.colorbar()\n",
    "    plt.xlabel('$t$')\n",
    "    plt.ylabel('$x$')\n",
    "    plt.title('Predicted u(x,t)')\n",
    "    plt.show()\n",
    "\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.pcolor(TT, XX, np.abs(usol.T - U_tmp.T), cmap='jet')\n",
    "    plt.colorbar()\n",
    "    plt.xlabel('$t$')\n",
    "    plt.ylabel('$x$')\n",
    "    plt.title('Absolute error of u(x,t)')\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "\n",
    "    loss_list = np.array(loss_list)\n",
    "    plt.figure(figsize=(12, 10))\n",
    "    plt.plot(loss_list[:,0], label='physics loss', color='r')\n",
    "    plt.plot(loss_list[:,1], label='initial loss', color='g')\n",
    "    plt.plot(loss_list[:,2], label='bc loss', color='b')\n",
    "    plt.plot(loss_list[:,3], label='data loss', color='purple')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Loss\")\n",
    "    plt.yscale('log')\n",
    "    plt.title(\"Loss\")\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "    \n",
    "    return model, train_losses, valid_losses, loss_list, para_list, valid_L2errors\n",
    "\n",
    "model_PINN = PINN(2, 1, 40)\n",
    "model_PINN.to(device)\n",
    "print(model_PINN)\n",
    "\n",
    "model_PINN, train_losses, valid_losses,loss_list, para_list, valid_L2errors = train_model(model_PINN, n_epochs=80000)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "df982684",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('loss_list_R3_2.npy',loss_list)\n",
    "np.save('valid_losses_R3_2.npy',valid_losses)\n",
    "np.save('para_list_R3_2.npy', para_list)\n",
    "np.save('valid_L2errors_R3_2.npy', valid_L2errors)\n",
    "torch.save(model_PINN,'R3_2.pkl')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
