{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "ce6a2779",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker\n",
    "import numpy as np\n",
    "from net.network import *"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5d90476c",
   "metadata": {},
   "source": [
    "# Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "id": "f6477cd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "bdry=['bdrylayer']\n",
    "num_element=[32]\n",
    "folder=['FCNN_epochs50000_20241111T191729']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f37aa310",
   "metadata": {},
   "source": [
    "### Data load"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "id": "d2dc349a",
   "metadata": {},
   "outputs": [],
   "source": [
    "EPS=[0.00001]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "f0d2290b",
   "metadata": {},
   "outputs": [],
   "source": [
    "idx=0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "c5158b5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mesh=np.load('mesh_1DP1/ne{}_{}.npz'.format(num_element[idx],bdry[idx]))\n",
    "NUM_ELEMENT, NUM_PTS, p, c, gfl = mesh['ne'], mesh['ng'], mesh['p'], mesh['c'], mesh['gfl']\n",
    "NUM_PTS+=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "id": "1e019c0e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array(32), array(34))"
      ]
     },
     "execution_count": 138,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "NUM_ELEMENT, NUM_PTS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "id": "84aa0687",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import Dataset, DataLoader\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "652d60ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "NUM_DATA=3000\n",
    "BATCH_SIZE=NUM_DATA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "1484481b",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Dataset(Dataset):\n",
    "    def __init__(self, mesh, kind='train'):\n",
    "        self.pickle_file = f'3000N'+str(num_element[idx])+f'_{bdry[idx]}'\n",
    "        with open(f'data/P1/{kind}/' + self.pickle_file + '.pkl', 'rb') as f:\n",
    "            self.data = pickle.load(f)\n",
    "        self.load_vector = mesh[f'{kind}_load_vectors']\n",
    "    def __getitem__(self, idx):\n",
    "        coeff_u = torch.FloatTensor(self.data[idx,0]).unsqueeze(0)\n",
    "        f_value = torch.FloatTensor(self.data[idx,1]).unsqueeze(0)\n",
    "        coeff_f = torch.FloatTensor(self.data[idx,2])\n",
    "        load_vec_f = torch.FloatTensor(self.load_vector[idx])\n",
    "        return {'coeff_u': coeff_u, 'f_value': f_value, 'coeff_f': coeff_f, 'load_vec_f' : load_vec_f}\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.data)\n",
    "\n",
    "lg_dataset = Dataset(mesh, kind='train')\n",
    "trainloader = DataLoader(lg_dataset, batch_size=BATCH_SIZE, shuffle=True)\n",
    "lg_dataset = Dataset(mesh, kind='validate')\n",
    "validateloader = DataLoader(lg_dataset, batch_size=BATCH_SIZE, shuffle=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "a129fd99",
   "metadata": {},
   "outputs": [],
   "source": [
    "for validate_data in validateloader:\n",
    "    coeff_u = validate_data['coeff_u']\n",
    "    data_f = validate_data['f_value']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "1ff007c0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3000, 1, 33])"
      ]
     },
     "execution_count": 143,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "coeff_u.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "id": "d2465112",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([3000, 1, 33])"
      ]
     },
     "execution_count": 144,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_f.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "id": "4601ceea",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_FEM = FCNN('silu',1, 32, NUM_PTS, kernel_size=5, padding=2, blocks=4, is_bdrylyaer=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "id": "df9bf212",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "PATH=os.path.join('train', \"P1\", f'3000N'+str(num_element[idx])+f'_{bdry[idx]}',folder[idx])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "id": "ac718744",
   "metadata": {},
   "outputs": [],
   "source": [
    "state_dict=torch.load(PATH+'/model.pt', map_location=torch.device('cpu'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "18a38b78",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_FEM.load_state_dict(state_dict['model_state_dict'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "id": "4ba16908",
   "metadata": {},
   "outputs": [],
   "source": [
    "def rel_L2_error(pred, true):\n",
    "    return (torch.sum((true-pred)**2, axis=-1)/torch.sum((true)**2, axis=-1))**0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "2a70bb25",
   "metadata": {},
   "outputs": [],
   "source": [
    "def reconstruct(eps,coeff_u):\n",
    "    def phi_cor(x,eps=eps):\n",
    "        return torch.e**(-(1+x)/eps)-(1-(x+1)*(1-torch.e**(-2/eps))/2)\n",
    "    return coeff_u[...,:-1]+coeff_u[...,[-1]]*phi_cor(torch.tensor(p))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "9e3d7f27",
   "metadata": {},
   "outputs": [],
   "source": [
    "STIFF=mesh['stiff']\n",
    "CONV=mesh['convection']\n",
    "validate_load_vectors=mesh['validate_load_vectors']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "5935fb87",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1073\n",
      "Error:0.0036394645740084977\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABNIAAAHECAYAAAD8uAfyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACqu0lEQVR4nOzdd3hU5bYG8HdPTe+dBEgoIQkl9N6rdBEFLIgK9mPhIF7UoygesaBiOXYFK4KCdJSOIDV0CAFCSyekkJ5JJrPvH5MZCCSQwMzsPTPv73nmuSeTPZkVb9jf7LXXt5YgiqIIIiIiIiIiIiIiuiGF1AEQERERERERERHZAybSiIiIiIiIiIiI6oGJNCIiIiIiIiIionpgIo2IiIiIiIiIiKgemEgjIiIiIiIiIiKqBybSiIiIiIiIiIiI6oGJNCIiIiIiIiIionpgIo2IiIiIiIiIiKgemEgjIiIiIiIiIiKqBybSiIiIiIiIiIiI6oGJNCIiIiIiIiIionpgIo2IiIiIiIiI7NL777+PSZMm4eGHH4aPjw9iY2ORnJx80+8R3Som0shpLFy4EIIgICEhQepQAAA7d+7E7Nmzcfny5Qa9rri4GNOmTUOjRo2gUqkQFRUFAHjjjTcQGxsLg8FghWjr59tvv0WjRo1QUlIiWQxERNa0e/du3H333QgNDYVGo0FISAjGjx+PXbt23fLPvNX1QK7vx/WIiByd6brC9FCpVAgPD8dDDz2E9PR0m8Qwe/ZsCIJwXUznz59v0M+50Zpwqz/T1o4ePYrt27dj2rRpyMvLQ4cOHfD111/f9HtX49pFDcFEGpFEdu7ciddff73BFzLTp0/H0qVL8f7772P79u1YvXo1MjIy8O677+KNN96AQiHdP+sHH3wQ7u7uePfddyWLgYjIWj755BP07NkTaWlpePfdd7Fx40bMmzcP6enp6NWrFz799NNb+rm3uh7cKmu+H9cjInImCxYswK5du7BhwwZMmzYNixYtQu/evSVJhIwYMQK7du1CaGhog153ozXhVn+mrR09ehSzZ89G9+7doVAo0KxZM4iieNPvmXDtooZiIo3IjlRUVGDRokWYOnUqJk6ciO7duyM2NhYfffQRfHx8MG7cOEnjU6lUeOyxx/DRRx+htLRU0liIiCzpn3/+wXPPPYfhw4dj+/bteOCBB9CnTx/cf//92L59O4YPH45nn30W//zzj9ShSorrERE5k9atW6Nbt27o378/XnvtNcycORPnzp3D8uXL63yNtc5JgYGB6NatG7Rarax/pqVVVVUhMTERw4cPNz93/PhxtGrV6obfuxrXLmooJtLIaZnKoY8fP45JkybB29sbwcHBePjhh1FQUFDrsQcPHsS4cePg5eUFb29v3H///bh06VKNY6dMmYKmTZvW+X6m//3CCy8AACIjI81l4Vu3bq0z3oceegharRbFxcV47733IAgCunXrhoqKCnz77be49957a9xByczMhIeHByZOnFjj56xevRpqtRovv/xyvf9bjRs3DuHh4dc9r9frER8fj8GDB5ufu++++1BYWIhff/213j+fiEju5s6dC0EQ8Pnnn0OlUtX4nkqlwmeffQZBEPD222+bn7fEelDf9ac+71Wf96tLUFAQnnzyyeue79Kli/kCpa71CLDcmsT1iIjkrFu3bgCACxcuALhyDj5w4ADGjx8PX19fNGvWDABw+vRp3HvvvQgKCoJWq0VMTAz+97//1fpz16xZg/j4eGi1WkRGRmLevHnXHVPXNsykpCRMmjQJwcHB0Gq1aNy4MSZPngydTnfTNaG2n7ljxw4MHDgQnp6ecHNzQ48ePbBmzZoa79mQ66y61GfdAYDk5GR4enoiLCzM/NyRI0fQtm3bG37PhNdSdCuYSCOnd9ddd6Fly5ZYunQp/u///g+//PILnn/++VqPvfPOO9G8eXP8/vvvmD17NpYvX46hQ4eisrKyQe85depU/Otf/wIALFu2DLt27cKuXbvQoUOHOl/z4osvYtasWQCAlStXYteuXfjxxx+xZ88e5Obmon///jWODw0NxcyZM7FkyRLs378fALB161bcfffdeOKJJ/Df//633vH26dMH6enp5g8FJh988AGSkpLw2WefmZ8LCQlBq1atrltQiYjsVVVVFbZs2YJOnTrV+kEYACIiItCxY0ds3rwZVVVV9f7Z9V0PpFx/Lly4gEuXLl13jF6vx5EjR8zP17UeAZZbk7geEZGcmZrYBwYG1nh+3LhxaN68OX777Td88cUXSExMROfOnXHs2DG8//77WL16NUaMGIFnnnkGr7/+eo3Xbtq0CWPGjIGnpyd+/fVXvPfee1iyZAkWLFhw03gOHz6Mzp07Y/fu3XjjjTewbt06zJ07FzqdDhUVFQ1e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ISEheOmllzBjxowb/qyUlBR8+umn6NWrV73fn4iIHMftrEdA3WsS1yMiIrIWXktRQ3FrJxERERERERERUT1YdWrn33//jVGjRiEsLAyCIGD58uU1vi+KImbPno2wsDC4urqiX79+OH78+E1/7tKlSxEbGwutVovY2Fj88ccfVvoNiIjIEVlrfSIiIgK4zhAROTKrJtJKSkrQrl27OvcZv/vuu/jggw/w6aefYt++fQgJCcHgwYPrHLcLALt27cKECRPwwAMP4PDhw3jggQdwzz33YM+ePdb6NYiIyMFYY30iIiIy4TpDROS4bLa1UxAE/PHHHxg7diwA412YsLAwPPfcc3jxxRcBADqdDsHBwXjnnXfw2GOP1fpzJkyYgMLCQqxbt8783LBhw+Dr64tFixZZ/fcgIiLHYqn1iYiIqDZcZ4iIHItkwwbOnTuHrKwsDBkyxPycVqtF3759sXPnzjoXkF27duH555+v8dzQoUMxf/78Ot9Lp9NBp9OZvzYYDMjLy4O/vz8EQbi9X4SIiCCKIoqKihAWFtbg5uJyc6vrE9caIiLrcpS1husMEZE81XedkSyRlpWVBQAIDg6u8XxwcDAuXLhww9fV9hrTz6vN3Llz8frrr99GtEREVB+pqakIDw+XOozbcqvrE9caIiLbsPe1husMEZG83WydkSyRZnLt3RNRFG96R6Whr5k1axamT59u/rqgoACNGzdGamoqvLy8biFqIiK6WmFhISIiIuDp6Sl1KBbDtYaISF4cba3hOkNEJC/1XWckS6SFhIQAMN6RCQ0NNT+fnZ193d2Za193bfXZzV6j1Wqh1Wqve97Ly4uLDhGRBTnC1pJbXZ+41hAR2Ya9rzVcZ4iI5O1m64xkzQUiIyMREhKCDRs2mJ+rqKjAtm3b0KNHjzpf17179xqvAYD169ff8DVERET1davrExERUX1wnSEism9WrUgrLi5GcnKy+etz587h0KFD8PPzQ+PGjfHcc8/hrbfeQosWLdCiRQu89dZbcHNzw7333mt+zeTJk9GoUSPMnTsXAPDss8+iT58+eOeddzBmzBisWLECGzduxI4dO6z5qxARkQOxxPpERERUF64zRESOy6qJtISEBPTv39/8tWlP/4MPPoiFCxdi5syZKCsrw5NPPon8/Hx07doV69evr7EfNSUlpca0hB49euDXX3/FK6+8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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_idx=np.random.randint(3000)\n",
    "plot_idx=1073\n",
    "print(plot_idx)\n",
    "f = data_f[[plot_idx]]#.cuda()\n",
    "u = coeff_u[[plot_idx]]\n",
    "output_u=model_FEM(f)\n",
    "predict_u=reconstruct(EPS[idx],output_u)\n",
    "\n",
    "fig=plt.figure(figsize=(15,5))\n",
    "ax=plt.subplot(1,3,1)\n",
    "ax.set_title(r'Input $f(x,y)$')\n",
    "ax.plot(p,f.squeeze())\n",
    "ax.set_ylim(-10,10)\n",
    "\n",
    "ax=plt.subplot(1,3,2)\n",
    "ax.set_title(r'Output $u(x,y)$')\n",
    "ax.plot(p,u.squeeze())\n",
    "ax.set_ylim(-3,10)\n",
    "\n",
    "ax=plt.subplot(1,3,3)\n",
    "ax.set_title(r'Prediction $u^{nn}(x,y)$')\n",
    "ax.plot(p,predict_u.squeeze().detach())\n",
    "#ax.plot(p,reconstruct(EPS, torch.tensor(np.linalg.solve(np.float64(EPS*STIFF+CONV), validate_load_vectors[plot_idx]))))\n",
    "ax.set_ylim(-3,10)\n",
    "print(\"Error:{}\".format(rel_L2_error(predict_u.squeeze().detach(),u.squeeze())))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "id": "1a200c56",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1083\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-1.1, 1.1)"
      ]
     },
     "execution_count": 162,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABBYAAAFTCAYAAACNj4/SAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACQ0ElEQVR4nOzdd1zV5fvH8ddhD+E4UREcaJrmyFGmppDmztJvU83RsmFLfy0bpi0bZja1qWZqVqaWKakVmDly58pSHICDND0HQeAA5/fHx3MSARU8cA7wfj4ePOR8zufc57o46vlwnfu+bpPdbrcjIiIiIiIiIlIMXu4OQERERERERETKLhUWRERERERERKTYVFgQERERERERkWJTYUFEREREREREik2FBREREREREREpNhUWRERERERERKTYVFgQERERERERkWJTYUFEREREREREik2FBREREREREREpNhUWRERERERERKTYVFgQERERERERkWJTYUHEhUwmEyaTyd1hlLrc3Fxef/11WrZsSVBQECaTiYYNGwIwfvx4vL292bFjx0U9x6FDhwgMDGTkyJGuCFlEREQ8hCuuFXSdIOJeJrvdbnd3ECLlhaOoUFb+We3bt48GDRoQHR1NXFxcscd5+umnmTBhAuHh4Vx99dUEBgbSokULbr/9dho1akTfvn358ssvLzreRx55hA8++IBt27bRpEmTix5PRERE3OvIkSMuu1bQdYKI+6iwIOJCFbGwcOrUKWrUqIG/vz9///03VatWdd73yCOP8M4777B582ZatWp10fEmJydTt25dbrrpJubOnXvR44mIiIh7ufJaQdcJIu6jpRAiclFWrVpFWloa119/fZ6iQnp6OjNmzKBly5YuKSoA1KlTh2uuuYb58+dz5MgRl4wpIiIi7uHqawVdJ4i4jwoLIiVs3759mEwmYmJiOHXqFE899RT16tXD39+fRo0a8dprr+Wb4XDmY6xWK4888giRkZEEBATQtGlT3nrrLXJzc/M8Ji4uDpPJxPDhwwuMY/jw4ZhMJufMhHHjxtGgQQMA4uPjnf0hzjXGmX755RdMJhPXXnstANOnT3c+/vnnn+frr7/GYrEwePDgQscYNGgQJpOJl19+Od99K1euJCAggLCwMPbs2ZPnMTabjenTp583RhERESkdM2fOxGQy8dxzzxV4f9++fTGZTGzf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IiJS/nna+0+ZXwohIiIiFdOtt97KsWPHeOGFFzh06BDNmzdn8eLF1KtXr9RiMAeYiR0cS2pWKhGhEXk6aEeaI4kfHk+IXwjmAHOpxSQiIuWfp73/qLAgIiIiZdYDDzzAAw884NYYzAHmQi/cSmv/cBERqXg86f1HSyFEREREREREpNhUWBARERERERGRYlNhQURERERERESKTYUFERERERERESm2Um/eaLfbAbBarS4Zz2azkZ6ejtVqxdfX1yVjupPy8XzlLSfl49mUj2criXwc74+O90spOa6+JgH9Hfd0ysezKR/Ppnw8m7uvSUq9sJCamgpAZGRkaT+1iIhImZGamorZrC0KS5KuSURERM7vQq5JTPZS/kgkNzeXgwcPEhISgslkuujxrFYrkZGRJCYmEhoa6oII3Uv5eL7ylpPy8WzKx7OVRD52u53U1FTCw8Px8tKKxZLk6msS0N9xT6d8PJvy8WzKx7O5+5qk1GcseHl5ERHh+j01Q0NDy8VfCAfl4/nKW07Kx7MpH8/m6nw0U6F0lNQ1CejvuKdTPp5N+Xg25ePZ3HVNoo9CRERERERERKTYVFgQERERERERkWIr84UFf39/nn/+efz9/d0diksoH89X3nJSPp5N+Xi28paPXLzy9ndC+Xg25ePZlI9nUz6uVerNG0VERERERESk/CjzMxZERERERERExH1UWBARERERERGRYlNhQURERERERESKTYUFERERERERESk2FRZEREREREREpNjKRGHh5ZdfpmPHjgQFBVG5cuULeozdbmfcuHGEh4cTGBhITEwM27dvz3NOZmYmDz30ENWrVyc4OJjrr7+epKSkEsggr+PHjzNkyBDMZjNms5khQ4Zw4sSJcz7GZDIV+PXGG284z4mJicl3/2233VbC2RQvn+HDh+eL9aqrrspzTll5fWw2G08++SQtWrQgODiY8PBwhg4dysGDB/OcV1qvzwcffECDBg0ICAigbdu2/Prrr+c8Pz4+nrZt2xIQEEBUVBRTp07Nd868efNo1qwZ/v7+NGvWjPnz57s87sIUJZ9vv/2W7t27U6NGDUJDQ+nQoQM//vhjnnOmT59e4L+ljIyMkk4FKFo+cXFxBcb6559/5jmvrLw+Bf27N5lMXHbZZc5z3Pn6rFixgn79+hEeHo7JZGLBggXnfYyn//sR19M1ia5JPPn10TVJydN1ia5LSuP1KZPXJPYyYOzYsfZJkybZR48ebTebzRf0mFdffdUeEhJinzdvnn3r1q32W2+91V67dm271Wp1nnPffffZ69SpY1+2bJl948aN9muuucbeqlUre3Z2dgllYujVq5e9efPm9lWrVtlXrVplb968uf26664752MOHTqU5+uzzz6zm0wm+549e5znREdH2++555485504caJEc7Hbi5fPsGHD/r+9u41tqmzjAH5ta7sNHJMJo9WFYgiuCJhsTDbEbHEsYyREiMaBTtIQQsSEOIzGjBjD9oVsCWrU4AtkDKJMFoTFD1MSjZsxrry4VRwpb2odRB1zBLC+sFX79wNPDztrO9qztjvnyf+XkHDuXpxzX1w97ZV7cB9UVVWp5nrlyhVVjFHqc+3aNVRUVKCtrQ1nz56Fy+VCcXExFi9erIpLRn0OHjwIs9mMPXv2wOPxoLa2FlOnTkV/f3/Y+B9//BFTpkxBbW0tPB4P9uzZA7PZjI8++kiJ6e7uRlpaGnbs2IEzZ85gx44dMJlMOHbsWFznHo98amtr0dTUhBMnTuD8+fPYtm0bzGYzent7lZiWlhZMmzYt5J5Khljz6ezshIjg3LlzqrmOvgeMVJ9r166p8rh06RJycnKwfft2JWYy6/PJJ5/g5ZdfxuHDhyEiaG9vHzde7/cPJQZ7EvYkeq4Pe5LEYl/CviRZ9TFiT2KIhYWglpaWqL7EA4EArFYrGhsblbEbN24gOzsb7777LoCbbySz2YyDBw8qMT///DNSU1Nx9OjRuM89yOPxQERUBXS5XBARnD17NurzrF69GuXl5aqxsrIy1NbWxmuqUdGaj9PpxOrVqyO+bvT6nDhxAiKi+iBLRn2WLFmCzZs3q8YcDgfq6urCxr/00ktwOByqsWeeeQYlJSXKcXV1NaqqqlQxK1aswLp16+I068hizSec+++/Hw0NDcpxtJ8jiRBrPsEv8KtXr0Y8p5Hr097ejpSUFPz000/K2GTWZ7RovsT1fv9QYrEnuYU9SWKwJ9HfZyr7EvYlk8EoPYkh/itErLxerwwMDEhlZaUylp6eLmVlZdLd3S0iIj09PeL3+1Uxd999tyxcuFCJSQSXyyXZ2dlSXFysjJWUlEh2dnbU1718+bJ0dHTIxo0bQ147cOCAzJgxQxYsWCAvvvii+Hy+uM09nInk09XVJbm5uXLffffJpk2bZHBwUHnNyPUREbl+/bqkpKSE/DPZRNZnZGREenp6VH9nIiKVlZUR5+5yuULiV6xYId988434/f5xYxJZBxFt+YwVCATE5/NJTk6OavyPP/4Qu90ueXl5smrVKnG73XGbdyQTyaegoEBsNpssX75cOjs7Va8ZuT7Nzc1SUVEhdrtdNT4Z9dFCz/cP6Qd7EvYkWrEn0ddnKvuSW9iX6K8v0cP9Y4rLWXRmYGBARERmzZqlGp81a5b09/crMRaLRaZPnx4SE/zziZpbbm5uyHhubm7U192/f79kZWXJY489phqvqamRe++9V6xWq5w+fVq2bdsmp06dks8++ywucw9Haz4rV66UJ554Qux2u3i9XnnllVekvLxcenp6JD093dD1uXHjhtTV1clTTz0l06ZNU8YTXZ+hoSH5999/w77vI819YGAgbPw///wjQ0NDYrPZIsYksg4i2vIZ69VXX5U///xTqqurlTGHwyH79u2TRYsWye+//y5vvPGGLFu2TE6dOiXz5s2Law6jacnHZrPJ7t27ZfHixTI8PCzvv/++LF++XLq6uqS0tFREItdQ7/X59ddf5dNPP5XW1lbV+GTVRws93z+kH+xJ2JNoxZ5EX5+p7EvYl+i5L9HD/TNpCwv19fXS0NAwbszJkyelqKhI8zVSUlJUxwBCxsaKJiacaPMJN69Yr7t3716pqamRjIwM1fimTZuU3y9cuFDmzZsnRUVF0tvbK4WFhVGdOyjR+axdu1Y116KiIrHb7dLR0RHSnMRy3kiSVR+/3y/r1q2TQCAgb7/9tuq1eNZnPLG+78PFjx3Xci/Fi9Zrf/jhh1JfXy8ff/yxqjErKSlRbcq1bNkyKSwslLfeekvefPPN+E08gljyyc/Pl/z8fOV46dKlcunSJdm5c6fyBR7rOeNN67X37dsnd955p6xZs0Y1Ptn1iZXe7x+KDnsS7ddlT6Lf+rAnSQz2JexL9NqXTPb9M2kLC1u2bLnt7rNz5szRdG6r1SoiN1dubDabMj44OKis0litVhkZGZGrV6+qVqAHBwfloYceivma0ebz3XffyeXLl0Ne++2330JWkML56quv5Ny5c9LW1nbb2MLCQjGbzXLhwoWYvySSlU+QzWYTu90uFy5cEBFj1sfv90t1dbV4vV754osvVD8ZCGci9QlnxowZkpaWFrLqOPp9P5bVag0bbzKZ5K677ho3Jpb6aqEln6C2tjbZuHGjHDp0SCoqKsaNTU1NlQcffFB57yXKRPIZraSkRD744APl2Ij1ASB79+6V9evXi8ViGTc2WfXRQs/3D8WGPYkaexL2JBP1/9aTiLAviYR9iT7o4v6Jy04NSRLrRklNTU3K2PDwcNiNktra2pSYX375JWkb8Rw/flwZO3bsWNQb8TidzpCdfSPp6+uDiODLL7/UPN/bmWg+QUNDQ0hPT8f+/fsBGK8+IyMjWLNmDRYsWIDBwcGorpWI+ixZsgTPPvusamz+/PnjbpQ0f/581djmzZtDNnpZuXKlKqaqqippm/DEkg8AtLa2IiMj47ab3AQFAgEUFRVhw4YNE5lqVLTkM9bjjz+ORx55RDk2Wn2AW5s/9fX13fYayazPaBLlRkl6vn8osdiTsCfRa33YkyQO+5JQ7EsSzyg9iSEWFvr7++F2u9HQ0IA77rgDbrcbbrcbPp9PicnPz8eRI0eU48bGRmRnZ+PIkSPo6+vDk08+GfbRTnl5efj888/R29uL8vLypD066IEHHoDL5YLL5cKiRYtCHh00Nh8AuH79OqZMmYJ33nkn5Jzff/89GhoacPLkSXi9XnR0dMDhcKCgoEB3+fh8Przwwgvo7u6G1+tFZ2cnli5dinvuuceQ9fH7/Xj00UeRl5eHb7/9VvUomuHhYQDJq0/wMTvNzc3weDzYunUrpk6dquxuW1dXh/Xr1yvxwUfTPP/88/B4PGhubg55NM3XX3+NtLQ0NDY24syZM2hsbEz6Y4Oizae1tRUmkwm7du2K+Ait+vp6HD16FD/88APcbjc2bNgAk8mkatz0ks/rr7+O9vZ2nD9/HqdPn0ZdXR1EBIcPH1ZijFSfoKeffhrFxcVhzzmZ9fH5fMr3i4jgtddeg9vtVnZSN9r9Q4nBnuQm9iT6rA97ksRiX8K+JFn1MWJPYoiFBafTCREJ+dXZ2anEiAhaWlqU40AggO3bt8NqtSI9PR2lpaUhq1B///03tmzZgpycHGRmZmLVqlW4ePFiwvO5cuUKampqkJWVhaysLNTU1IQ8tmVsPgDw3nvvITMzM+xzhi9evIjS0lLk5OTAYrFg7ty5eO6550Kew5wIsebz119/obKyEjNnzoTZbMbs2bPhdDpD/u6NUh+v1xv2/Tn6PZrM+uzatQt2ux0WiwWFhYWqnz44nU6UlZWp4ru6ulBQUACLxYI5c+aEbRIPHTqE/Px8mM1mOBwO1RdIosWST1lZWdg6OJ1OJWbr1q2YPXs2LBYLZs6cicrKSnR3d+syn6amJsydOxcZGRmYPn06Hn74YXR0dISc0yj1AW7+5C8zMxO7d+8Oe77JrE/wJxaR3j9GvH8o/tiT3MSeRJ/1YU+SeOxL2Jckoz5G7ElSgP/t6kBEREREREREFKPUyZ4AERERERERERkXFxaIiIiIiIiISDMuLBARERERERGRZlxYICIiIiIiIiLNuLBARERERERERJpxYYGIiIiIiIiINOPCAhERERERERFpxoUFIiIiIiIiItKMCwtEREREREREpBkXFoiIiIiIiIhIMy4sEBEREREREZFm/wE7vIS+oGblCQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1300x350 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_idx=np.random.randint(3000)\n",
    "# plot_idx=1073\n",
    "print(plot_idx)\n",
    "f = data_f[[plot_idx]]#.cuda()\n",
    "u = coeff_u[[plot_idx]]\n",
    "output_u=model_FEM(f)\n",
    "predict_u=reconstruct(EPS[idx],output_u)\n",
    "\n",
    "fig=plt.figure(figsize=(13,3.5))\n",
    "ax=plt.subplot(1,2,1)\n",
    "ax.set_title(r'Input $f(x)$',fontsize=15)\n",
    "ax.plot(p,f.squeeze(), c='b')\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.1,1.1)\n",
    "# ax.set_ylim(-1,10)\n",
    "\n",
    "ax=plt.subplot(1,2,2)\n",
    "ax.set_title(r'$u(x)$',fontsize=15)\n",
    "ax.plot(p,u.squeeze(), label='Truth', c='r')\n",
    "ax.scatter(p,predict_u.squeeze().detach(), label=r'Ours $\\hat{u}(x)$', c='green', marker='x')\n",
    "ax.legend(fontsize=15)\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.1,1.1)\n",
    "# ax.set_ylim(-1,10)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ccdc9702",
   "metadata": {},
   "source": [
    "## PIDeepONet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "id": "7872291a",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'DeepONet' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[117], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m#d_t, w_t, d_b, w_b, act, NUM_PTS, 1, 1\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m model_pideeponet \u001b[38;5;241m=\u001b[39m \u001b[43mDeepONet\u001b[49m(\u001b[38;5;241m2\u001b[39m,\u001b[38;5;241m100\u001b[39m,\u001b[38;5;241m2\u001b[39m,\u001b[38;5;241m100\u001b[39m,\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtanh\u001b[39m\u001b[38;5;124m'\u001b[39m,NUM_PTS\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'DeepONet' is not defined"
     ]
    }
   ],
   "source": [
    "#d_t, w_t, d_b, w_b, act, NUM_PTS, 1, 1\n",
    "model_pideeponet = DeepONet(2,100,2,100,'tanh',NUM_PTS-1,1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "94805fad",
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH_pideeponet=os.path.join('train', \"deeponet\", f'3000N'+str(num_element[idx])+f'_{bdry[idx]}','DeepONet_epochs500000_20230507T154559')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "1d1bbd80",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/DeepONet_epochs500000_20230507T154559/model.pt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[57], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m state_dict\u001b[38;5;241m=\u001b[39m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[43mPATH_pideeponet\u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43m/model.pt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmap_location\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdevice\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mcpu\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:997\u001b[0m, in \u001b[0;36mload\u001b[0;34m(f, map_location, pickle_module, weights_only, mmap, **pickle_load_args)\u001b[0m\n\u001b[1;32m    994\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m pickle_load_args\u001b[38;5;241m.\u001b[39mkeys():\n\u001b[1;32m    995\u001b[0m     pickle_load_args[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m--> 997\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[43m_open_file_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m opened_file:\n\u001b[1;32m    998\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_zipfile(opened_file):\n\u001b[1;32m    999\u001b[0m         \u001b[38;5;66;03m# The zipfile reader is going to advance the current file position.\u001b[39;00m\n\u001b[1;32m   1000\u001b[0m         \u001b[38;5;66;03m# If we want to actually tail call to torch.jit.load, we need to\u001b[39;00m\n\u001b[1;32m   1001\u001b[0m         \u001b[38;5;66;03m# reset back to the original position.\u001b[39;00m\n\u001b[1;32m   1002\u001b[0m         orig_position \u001b[38;5;241m=\u001b[39m opened_file\u001b[38;5;241m.\u001b[39mtell()\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:444\u001b[0m, in \u001b[0;36m_open_file_like\u001b[0;34m(name_or_buffer, mode)\u001b[0m\n\u001b[1;32m    442\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_open_file_like\u001b[39m(name_or_buffer, mode):\n\u001b[1;32m    443\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_path(name_or_buffer):\n\u001b[0;32m--> 444\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_open_file\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    445\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    446\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mw\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01min\u001b[39;00m mode:\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:425\u001b[0m, in \u001b[0;36m_open_file.__init__\u001b[0;34m(self, name, mode)\u001b[0m\n\u001b[1;32m    424\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, name, mode):\n\u001b[0;32m--> 425\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39m\u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m)\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/DeepONet_epochs500000_20230507T154559/model.pt'"
     ]
    }
   ],
   "source": [
    "state_dict=torch.load(PATH_pideeponet+'/model.pt', map_location=torch.device('cpu'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "00a2da54",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'model_pideeponet' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[58], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mmodel_pideeponet\u001b[49m\u001b[38;5;241m.\u001b[39mload_state_dict(state_dict[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmodel_state_dict\u001b[39m\u001b[38;5;124m'\u001b[39m])\n",
      "\u001b[0;31mNameError\u001b[0m: name 'model_pideeponet' is not defined"
     ]
    }
   ],
   "source": [
    "model_pideeponet.load_state_dict(state_dict['model_state_dict'])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "23012eb7",
   "metadata": {},
   "source": [
    "## PINN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "2dd3212f",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'PINN' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[59], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m#d_t, w_t, d_b, w_b, act, NUM_PTS, 1, 1\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m model_pinn1 \u001b[38;5;241m=\u001b[39m \u001b[43mPINN\u001b[49m(\u001b[38;5;241m2\u001b[39m,\u001b[38;5;241m100\u001b[39m,\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtanh\u001b[39m\u001b[38;5;124m'\u001b[39m,\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n\u001b[1;32m      3\u001b[0m model_pinn2 \u001b[38;5;241m=\u001b[39m PINN(\u001b[38;5;241m2\u001b[39m,\u001b[38;5;241m100\u001b[39m,\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtanh\u001b[39m\u001b[38;5;124m'\u001b[39m,\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'PINN' is not defined"
     ]
    }
   ],
   "source": [
    "#d_t, w_t, d_b, w_b, act, NUM_PTS, 1, 1\n",
    "model_pinn1 = PINN(2,100,'tanh',1,1)\n",
    "model_pinn2 = PINN(2,100,'tanh',1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "d4035fb7",
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH_pinn1=os.path.join('train', \"deeponet\", f'3000N'+str(num_element[idx])+f'_{bdry[idx]}','PINN_epochs500000_20230507T220857')\n",
    "PATH_pinn2=os.path.join('train', \"deeponet\", f'3000N'+str(num_element[idx])+f'_{bdry[idx]}','PINN_epochs500000_20230507T212830')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "458cdb33",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/PINN_epochs500000_20230507T220857/model.pt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[61], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m state_dict\u001b[38;5;241m=\u001b[39m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[43mPATH_pinn1\u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43m/model.pt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmap_location\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdevice\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mcpu\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      2\u001b[0m model_pinn1\u001b[38;5;241m.\u001b[39mload_state_dict(state_dict[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmodel_state_dict\u001b[39m\u001b[38;5;124m'\u001b[39m])\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:997\u001b[0m, in \u001b[0;36mload\u001b[0;34m(f, map_location, pickle_module, weights_only, mmap, **pickle_load_args)\u001b[0m\n\u001b[1;32m    994\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m pickle_load_args\u001b[38;5;241m.\u001b[39mkeys():\n\u001b[1;32m    995\u001b[0m     pickle_load_args[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m--> 997\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[43m_open_file_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m opened_file:\n\u001b[1;32m    998\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_zipfile(opened_file):\n\u001b[1;32m    999\u001b[0m         \u001b[38;5;66;03m# The zipfile reader is going to advance the current file position.\u001b[39;00m\n\u001b[1;32m   1000\u001b[0m         \u001b[38;5;66;03m# If we want to actually tail call to torch.jit.load, we need to\u001b[39;00m\n\u001b[1;32m   1001\u001b[0m         \u001b[38;5;66;03m# reset back to the original position.\u001b[39;00m\n\u001b[1;32m   1002\u001b[0m         orig_position \u001b[38;5;241m=\u001b[39m opened_file\u001b[38;5;241m.\u001b[39mtell()\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:444\u001b[0m, in \u001b[0;36m_open_file_like\u001b[0;34m(name_or_buffer, mode)\u001b[0m\n\u001b[1;32m    442\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_open_file_like\u001b[39m(name_or_buffer, mode):\n\u001b[1;32m    443\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_path(name_or_buffer):\n\u001b[0;32m--> 444\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_open_file\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    445\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    446\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mw\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01min\u001b[39;00m mode:\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:425\u001b[0m, in \u001b[0;36m_open_file.__init__\u001b[0;34m(self, name, mode)\u001b[0m\n\u001b[1;32m    424\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, name, mode):\n\u001b[0;32m--> 425\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39m\u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m)\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/PINN_epochs500000_20230507T220857/model.pt'"
     ]
    }
   ],
   "source": [
    "state_dict=torch.load(PATH_pinn1+'/model.pt', map_location=torch.device('cpu'))\n",
    "model_pinn1.load_state_dict(state_dict['model_state_dict'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "58c471f8",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/PINN_epochs500000_20230507T212830/model.pt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[62], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m state_dict\u001b[38;5;241m=\u001b[39m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[43mPATH_pinn2\u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43m/model.pt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmap_location\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdevice\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mcpu\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      2\u001b[0m model_pinn2\u001b[38;5;241m.\u001b[39mload_state_dict(state_dict[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmodel_state_dict\u001b[39m\u001b[38;5;124m'\u001b[39m])\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:997\u001b[0m, in \u001b[0;36mload\u001b[0;34m(f, map_location, pickle_module, weights_only, mmap, **pickle_load_args)\u001b[0m\n\u001b[1;32m    994\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m pickle_load_args\u001b[38;5;241m.\u001b[39mkeys():\n\u001b[1;32m    995\u001b[0m     pickle_load_args[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m--> 997\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[43m_open_file_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m opened_file:\n\u001b[1;32m    998\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_zipfile(opened_file):\n\u001b[1;32m    999\u001b[0m         \u001b[38;5;66;03m# The zipfile reader is going to advance the current file position.\u001b[39;00m\n\u001b[1;32m   1000\u001b[0m         \u001b[38;5;66;03m# If we want to actually tail call to torch.jit.load, we need to\u001b[39;00m\n\u001b[1;32m   1001\u001b[0m         \u001b[38;5;66;03m# reset back to the original position.\u001b[39;00m\n\u001b[1;32m   1002\u001b[0m         orig_position \u001b[38;5;241m=\u001b[39m opened_file\u001b[38;5;241m.\u001b[39mtell()\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:444\u001b[0m, in \u001b[0;36m_open_file_like\u001b[0;34m(name_or_buffer, mode)\u001b[0m\n\u001b[1;32m    442\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_open_file_like\u001b[39m(name_or_buffer, mode):\n\u001b[1;32m    443\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_path(name_or_buffer):\n\u001b[0;32m--> 444\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_open_file\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    445\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    446\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mw\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01min\u001b[39;00m mode:\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:425\u001b[0m, in \u001b[0;36m_open_file.__init__\u001b[0;34m(self, name, mode)\u001b[0m\n\u001b[1;32m    424\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, name, mode):\n\u001b[0;32m--> 425\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39m\u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m)\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/PINN_epochs500000_20230507T212830/model.pt'"
     ]
    }
   ],
   "source": [
    "state_dict=torch.load(PATH_pinn2+'/model.pt', map_location=torch.device('cpu'))\n",
    "model_pinn2.load_state_dict(state_dict['model_state_dict'])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "27b12cb6",
   "metadata": {},
   "source": [
    "## DeepONet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "ca5f2c7a",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'DeepONet' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[63], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;66;03m#d_t, w_t, d_b, w_b, act, NUM_PTS, 1, 1\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m model_deeponet \u001b[38;5;241m=\u001b[39m \u001b[43mDeepONet\u001b[49m(\u001b[38;5;241m2\u001b[39m,\u001b[38;5;241m100\u001b[39m,\u001b[38;5;241m2\u001b[39m,\u001b[38;5;241m100\u001b[39m,\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtanh\u001b[39m\u001b[38;5;124m'\u001b[39m,NUM_PTS\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'DeepONet' is not defined"
     ]
    }
   ],
   "source": [
    "#d_t, w_t, d_b, w_b, act, NUM_PTS, 1, 1\n",
    "model_deeponet = DeepONet(2,100,2,100,'tanh',NUM_PTS-1,1,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "98648ffd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "PATH_deeponet=os.path.join('train', \"deeponet\", f'3000N'+str(num_element[idx])+f'_{bdry[idx]}','DeepONet_epochs500000_20230427T093504')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "1948867e",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/DeepONet_epochs500000_20230427T093504/model.pt'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[65], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m state_dict\u001b[38;5;241m=\u001b[39m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[43mPATH_deeponet\u001b[49m\u001b[38;5;241;43m+\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43m/model.pt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmap_location\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdevice\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mcpu\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:997\u001b[0m, in \u001b[0;36mload\u001b[0;34m(f, map_location, pickle_module, weights_only, mmap, **pickle_load_args)\u001b[0m\n\u001b[1;32m    994\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m pickle_load_args\u001b[38;5;241m.\u001b[39mkeys():\n\u001b[1;32m    995\u001b[0m     pickle_load_args[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mencoding\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m--> 997\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[43m_open_file_like\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mas\u001b[39;00m opened_file:\n\u001b[1;32m    998\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_zipfile(opened_file):\n\u001b[1;32m    999\u001b[0m         \u001b[38;5;66;03m# The zipfile reader is going to advance the current file position.\u001b[39;00m\n\u001b[1;32m   1000\u001b[0m         \u001b[38;5;66;03m# If we want to actually tail call to torch.jit.load, we need to\u001b[39;00m\n\u001b[1;32m   1001\u001b[0m         \u001b[38;5;66;03m# reset back to the original position.\u001b[39;00m\n\u001b[1;32m   1002\u001b[0m         orig_position \u001b[38;5;241m=\u001b[39m opened_file\u001b[38;5;241m.\u001b[39mtell()\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:444\u001b[0m, in \u001b[0;36m_open_file_like\u001b[0;34m(name_or_buffer, mode)\u001b[0m\n\u001b[1;32m    442\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_open_file_like\u001b[39m(name_or_buffer, mode):\n\u001b[1;32m    443\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m _is_path(name_or_buffer):\n\u001b[0;32m--> 444\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_open_file\u001b[49m\u001b[43m(\u001b[49m\u001b[43mname_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    445\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    446\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mw\u001b[39m\u001b[38;5;124m'\u001b[39m \u001b[38;5;129;01min\u001b[39;00m mode:\n",
      "File \u001b[0;32m~/anaconda3/envs/operator/lib/python3.12/site-packages/torch/serialization.py:425\u001b[0m, in \u001b[0;36m_open_file.__init__\u001b[0;34m(self, name, mode)\u001b[0m\n\u001b[1;32m    424\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28mself\u001b[39m, name, mode):\n\u001b[0;32m--> 425\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39m\u001b[38;5;21m__init__\u001b[39m(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mname\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m)\u001b[49m)\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'train/deeponet/3000N32_bdrylayer/DeepONet_epochs500000_20230427T093504/model.pt'"
     ]
    }
   ],
   "source": [
    "state_dict=torch.load(PATH_deeponet+'/model.pt', map_location=torch.device('cpu'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "9aed17b3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'model_deeponet' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[66], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mmodel_deeponet\u001b[49m\u001b[38;5;241m.\u001b[39mload_state_dict(state_dict[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmodel_state_dict\u001b[39m\u001b[38;5;124m'\u001b[39m])\n",
      "\u001b[0;31mNameError\u001b[0m: name 'model_deeponet' is not defined"
     ]
    }
   ],
   "source": [
    "model_deeponet.load_state_dict(state_dict['model_state_dict'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "9c1fde13",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'model_pideeponet' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[67], line 8\u001b[0m\n\u001b[1;32m      6\u001b[0m output_u\u001b[38;5;241m=\u001b[39mmodel_FEM(f)\n\u001b[1;32m      7\u001b[0m predict_u\u001b[38;5;241m=\u001b[39mreconstruct(EPS[idx],output_u)\n\u001b[0;32m----> 8\u001b[0m predict_u_pidon\u001b[38;5;241m=\u001b[39m\u001b[43mmodel_pideeponet\u001b[49m(torch\u001b[38;5;241m.\u001b[39mFloatTensor(p)\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m),f)\n\u001b[1;32m      9\u001b[0m predict_u_pinn1\u001b[38;5;241m=\u001b[39mmodel_pinn1(torch\u001b[38;5;241m.\u001b[39mFloatTensor(p)\u001b[38;5;241m.\u001b[39mreshape(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m,\u001b[38;5;241m1\u001b[39m))\n\u001b[1;32m     10\u001b[0m \u001b[38;5;66;03m#predict_u_pinn2=model_pinn2(torch.FloatTensor(p).reshape(-1,1))\u001b[39;00m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'model_pideeponet' is not defined"
     ]
    }
   ],
   "source": [
    "plot_idx=np.random.randint(3000)\n",
    "plot_idx=1073\n",
    "#print(plot_idx)\n",
    "f = data_f[[plot_idx]]#.cuda()\n",
    "u = coeff_u[[plot_idx]]\n",
    "output_u=model_FEM(f)\n",
    "predict_u=reconstruct(EPS[idx],output_u)\n",
    "predict_u_pidon=model_pideeponet(torch.FloatTensor(p).reshape(-1,1),f)\n",
    "predict_u_pinn1=model_pinn1(torch.FloatTensor(p).reshape(-1,1))\n",
    "#predict_u_pinn2=model_pinn2(torch.FloatTensor(p).reshape(-1,1))\n",
    "predict_u_don=model_deeponet(torch.FloatTensor(p).reshape(-1,1),f)\n",
    "\n",
    "\n",
    "fig=plt.figure(figsize=(13,3.5))\n",
    "ax=plt.subplot(1,2,1)\n",
    "ax.set_title(r'Input $f(x)$',fontsize=15)\n",
    "ax.plot(p,f.squeeze(), c='b')\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.1,1.1)\n",
    "ax.set_ylim(-1,10)\n",
    "ax.set_xlabel(r'$x$',fontsize=15)\n",
    "ax.set_ylabel(r'$f(x)$',fontsize=15)\n",
    "\n",
    "ax=plt.subplot(1,2,2)\n",
    "ax.set_title(r'$u(x)$',fontsize=15)\n",
    "ax.plot(p,u.squeeze(), label='Truth', c='r', linewidth=3, linestyle='dashed')\n",
    "ax.plot(p,predict_u_pidon.squeeze().detach(), label=r'PIDeepONet', c='magenta', marker='v', markersize=4, linewidth=0.5)\n",
    "ax.plot(p,predict_u_pinn1.squeeze().detach(), label=r'PINN', c='g', marker='x', markersize=4, linewidth=0.5)\n",
    "#ax.plot(p,predict_u_pinn2.squeeze().detach(), label=r'PINN2', c='g', marker='^', markersize=4, linewidth=0.5)\n",
    "ax.plot(p,predict_u_don.squeeze().detach(), label=r'DeepONet', c='saddlebrown', marker='*', markersize=4, linewidth=0.5)\n",
    "ax.plot(p,predict_u.squeeze().detach(), label=r'Ours', c='b', marker='o', markersize=4, linewidth=0.5)\n",
    "ax.legend(fontsize=11)\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.05,1.05)\n",
    "ax.set_ylim(-6,12)\n",
    "ax.set_xlabel(r'$x$',fontsize=15)\n",
    "ax.set_ylabel(r'$u(x)$',fontsize=15)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "314e36ed",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'predict_u_don' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[68], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m rel_L2_error(\u001b[43mpredict_u_don\u001b[49m\u001b[38;5;241m.\u001b[39msqueeze()\u001b[38;5;241m.\u001b[39mdetach(), u\u001b[38;5;241m.\u001b[39msqueeze())\n",
      "\u001b[0;31mNameError\u001b[0m: name 'predict_u_don' is not defined"
     ]
    }
   ],
   "source": [
    "rel_L2_error(predict_u_don.squeeze().detach(), u.squeeze())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "9e0b70fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.1, 9.53)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAANoAAAEWCAYAAAAAQImgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA4bklEQVR4nO2deVyU1f7H38Owb4KACAKCCbK575aplWtZZpZbWrZdu5WZv/abe+a91k2ra2WrbbaYppVmmrlkpmmpMSqouYGgCMq+DTPn98czoMCAMzAbznm/XvPS5zzPPM/3DPOZc873fM/3qIQQAolEYlVc7G2AROIMSKFJJDZACk0isQFSaBKJDZBCk0hsgBSaRGIDpNAkEhvgaq8H6/V6MjMz8fPzQ6VS2csMiRMghKCwsJDw8HBcXOzTtthNaJmZmURGRtrr8RInJD09nYiICLs8225C8/PzA5TK+/v72/TZWq2WjRs3MmTIENzc3Gz6bGN8+y1MmlT/+U8+gVtvbfpzHK3etuLChQvExMRUf+fsgd2EVtVd9Pf3t4vQvL298ff3t/sXTqeD556r/7xKBc8/D+PHg1rdtGc5Ur1tiVarBbDrEEU6Q+zML79ARkb954WA9HTlOknzRQrNzmRlmXjdiTLrGiKxKlJodiYszLTrXP9xv9J//PZbqKiwrlESiyOFZmf694eICGUsZgwVekLIZo12OLd/cRdf3vYZZaFt4cEHYcsWZZAncXik0OyMWg2vvab8v7bYVOgBeJupfMYkPmQK+bTgjrz3ePi9buy+4VlERCQ88QTs2aMM6CQOiRSaAzB6NHz9NYSG1iyPaFnK110WMFr9LQAB5PMQ77KOW3ic11jDKIac/YhFS9zI7HUb7NplB+slpmA3976kJqNHK63btm3Qs6cyduvf3we1eiacnworV8Lnn8OOHQDEk8ZCnkeHCz9xE097/4+SRX0YN16Zc/P0tHOFJDWQLZoDcfiwIrjx42HgwMvmzUJC4J//VHz8J0/Cf/4DnTsDoEbPUDby6SO7eP8DFRcuKPd45JHLepPffQdLl0J2tp1qJkHYifz8fAGI/Px8mz+7oqJCrFmzRlRUVNj82Q0xcaIQFy6Y8YZDh4SYOVOIa64R4s8/a5w6eFCIp58WYvBgIV5u96bIIlTo1WpxtmtXoX3/fSHs8Lnbi5ycHLt916qQLZojsHkzzJ/PxcNnCcw9ZronMSEB5s2Do0ehS5capxITlYZv/TsZJB3/jhm8yhjdl/yyrx26+x9WBoR33gmrV0OZnKOzNlJojsDatWhnzcP1z90QGwuTJ5v3fpWq3vkB11VfMpwfWMFE3uVBsmnFKNbwWNki/vj6OOKOOxTRTZkCmzZBZaUFKiSpjRSaI5CSwjHaE8tR5TghwXL37tVLGfR5e9OSi/yTt/iBEUzlbb5gHEP5kVcL7ufc8vUwZAi0aQPTpsFvv9WYLtDpYOtWxR+zdaucvjMbe/VZ5RjNgF4vRFCQ+Iox4kPuEQKE+OYbyz+nsFBoP/pIZPXoIfSurspzQGhRi+8ZIcaxQozhK7GaUaIcN+V8dLQQ2dli1SohIiKq3yJAOV61yvJmWgM5RpMonsDcXDQkk4xGKUtOtvxzfH0R48ez+4UXqExPh2XLYOBAXFV6bmY9nzOBt5nKGdpwK9/yOEvYp+rG6u3BjBlTN/D5zBkYM0YZ4kmujBSavUlJAeAQiSRyCLy8oF076z4zKAgeekgJ4UpPh//+F7p3J4gLPMpSNjCcB3iPj1s/xYSJKqMBJ0qZYPp02Y00BSk0e6NRWrFSvPCmFJKSwJbL7du0gRkzYO9eSEuDOXOgQwc6ouG2RyIpL6//rUKolCU8szZBUZHNTG6OSKHZG42GUjzxxOBit0a30VTi4mD2bGXm/NAhslzamPS2rJc+UDyXEyfCunVgWGgpuYQUmr1JSeEwCSRwWDnu2NG+9oAyVZCQYPISnreZyscld5C3Yh3ccguEhyuhKb/+KgOdDUih2RO9Hg4etL4jpJGYsoQnktOs5nZc0PMQ7zCaVXyQM5LcN7+A665Txpv/+hccOmRb4x0MKTR7cvIkFBfXFJojtGgGGlzCoxKAiiVdPyZIXcDdfMZXjGU59+JFKf/kTUbxDe+evInzL72jjD27dIFXXlF+YJwMKTR7YnCEHCGOOI5Ay5bQurWdjapJ1RKeNrWGaxERKr5epWL0ny9AZia88Qb07Ys/hYznC75kHJ9yNy3IZxqvcytreetAX85+ttm2zh4HQS6TsScGoVXiihuVSrfRAZPJjh4Nt92mLB7IyqpawnPZ6oJWreDRR5XX8eOwYgV89hm+qancxUruYiUleLGBYTypXkz+SBg6VLlvePhlDxLCIetvCZzvp8WRSEkhH3/8KVCOHajbWBu1Wlm6U2cJT23atYMXXlDGZH/+Cf/3fxAejjeljHZZy6ffB7ByJURGKmn2br4ZliyB9NNCCRerirm8yibnZItmTzQaDpLkkI6QJqNSQdeuyus//4Ht22HfPmjdGk+UFvK226C8HH76CWY9ksO5vXO5ce9m7lj+INGty2HcOJgwAXr0aPYtnRSavRDKL3hKXgzJZ/dBJQ7dojUJtRoGDVJetfDwUFq1m396iQqW8jM38CIvkHE2gkFLtjBmyTiuiXNVBDdhgrK64TJ0uga6tA6EFJq9UKng/ffRPAaDH6sE/TGIjra3VfZBr4eVK3FHyzB+ZBg/osWVbQxgEU9z6khbrp+znTFzbiauZ4AyMT52LKt3tubxx2vGYUZEKJ7S0aPtVhujSKHZmRMnILq9K7jE29sU++HiAr//Dl98oThS/vgDNyq5ic3cxGYqUfML/XmNxzm6J5br9uwgYPpCprMEZTr8UreyKtj5668dS2zSGWJHqhadOKG3uy7h4ZdiLg8fhpkz4ZprAHBFxyC2spRH+YHh9Gc7/+LFOiKDS4EojhbsLP/EdiQ72+GmzRyD+PhLKRp27YLHHlOmEFCSEamAIvyoLbIqHHG/ArOFVlRUxPz580lOTsbX15eQkBCuvfZaPv30U2vYd1Wj0VxdjkaLo1JB797w+utKn3DDBpg0iSyPGJPefjRVB48+imrLFisbemXMGqPp9XqGDh3Krl27uPfee5k2bRrFxcV88sknTJo0iSNHjjBv3jxr2XrVIYVmBq6uyiz30KGETSiD4Vd+y6dL8/lJ05+RSz+yvn1Xwpzl2Dt37hSAmD59eo3ykpIS0bp1axEaGmryvZw6lcGffwrRr594IH67yJz/nhDbttnksXavt4WorFRSKahUNdMrVL1UKiEiI4WonPKAyCZYLOLB5pXKID8/H4DwGnEz4OXlRWBgIN7e3haS/1XOvn2wcyeZqQW0nvmAsmGFxGQaDnZW/l3yihb1mlWEkMM/eNe2BhrBrK5jr1698Pf3Z9GiRURHR9OnTx+Kiop45513SEtL48MPP6z3veXl5ZRftly3oEAJO9JqtdU7MtqKqufZ+rlVuPz1FypUqBCoAH1iIjob2GLveluSkSPhiy9UzJih5syZS2pr00bw3//qGDm0BN2zz6JauVLxZNoZlRDmrczbsmULDz74IH///Xd1WUBAAJ988gm33HJLve+bM2cOc+fOrVO+YsUKp2sJ+86eTcmBPF7mKZbyKKljx5I2fry9zWqW6HRw6FAQFy96EhhYRmJibp3IEHH8OLfPmEF+fr7Nt3Guwmyh7d+/nwULFhAdHU2/fv3Iy8vjrbfeQqPRsGrVKoYPNz5KNdaiRUZGkpOTY5c9rDdt2sTgwYPtspeza1QU6852J51IHuZtKj//XElkamXsXW97kZubS1hYmF2FZlbXMSUlhb59+7JkyRL+8Y9/VJdPmDCBLl26cN9993Hy5Ek8PDzqvNfDw8NouZubm93+6HZ5dk4OnD2LhmSuQ9kZxrVLF7ChHfb8zO2BI9TVLGfI4sWLKSsr484776xR7uHhwahRozh79iypqakWNfCqw7AGTUMySRxUomrbt7ezURJrY5bQzpw5AxgfTFeVVcrc7Q1jEFoeAQSSp6T/dpUhp1c7ZgktMTERgOXLl9coLywsZOXKlfj4+JCUlGQx465KNBq0uKLGEIh3tS6NkdTArJ/S6dOn8/HHH/Pcc8+RkpLCddddx8WLF3n//fc5ffo0r7zyCp5yq8mGqb2hhQwNcQrMElrbtm05cOAACxcuZPPmzaxevRq1Wk2XLl1YsGABY8eOtZadVwdCgEaDhiFX56pqSb2YPTiIiIhg6dKl1rDl6ic9HQoK0JDMSL5TymTX0SmQy2RsicERUr2hhb+/siRYctUjhWZLam9o4aDp5SSWRwrNlqSk1NzQQnYbnQY5gWNLJkwg1bUnCTsqoSJKOkKcCCk0WzJ8OCnnh5M8DBg7Tu604kTIrqONqbGqWo7PnAYpNBtz5EidHKASJ0AKzcZoteDubm8rJLZGCs2G5OdDixb2tkJiD6TQbEVREQcPSkejsyK9jragtBQCAtC0eJLkGG8oKIGnn1Y2HpQ4BbJFswWHD4NOR8qFNiT/sVzZxsjIanPJ1YsUmi0whF6dIIZoTiqb9fn42NcmiU2RQrMFGg0C0OOCC0IO1JwQKTRbkJJCNq1ozVnlWMY4Oh1SaLZAo0FDMh1JUY5li+Z0SKFZm7w8yMhAQ/KlVdWyRXM6pNCszWXp5ZLRKPkbG4jBOntkH18+NYqzR/bZykKJDZBCszYGoWURpozROnRoMAbr4KavSD+wg0M/rbSVhRIbICesrU1KimGPSsP+lEa6jfnn0inNz0WlUpG27RsAUreuJmnwWIQQeLUIokVopA2NllgaKTRro9Fwmijacko5NuIIeXdS1zplJXk5fPLIjdXHT27MsZqJEusju47WpDq9XHKD6eVGPPMWLup6fvNUKkLaJbFxyQwOfL+crLQ/qawos6LREmsgWzRrkpUFFy7U2NDCWNcx8cY7CYqKq9GCVTHpfz/Rqn0ninKyOHd0P8d3b+T3L16jUluOT2ArWrXvROvYzgTHJOLuJaNNHBUpNGtymcfxHyxTwq7atjXtvSpVdaoDlUqFX0g4fiHhtO83ovqS4gvnOHfsL07t287eVW+hLS/Byy+QVu07ERrbmVbXdMTDx8/i1ZKYjxSaNam9oUVSL3Ax3lv3DgjBw7cF7t5+9Bk3nb82fEbh+TN4B4TUe3uflqG06zWYdr0GV5eV5OeSfSyFzMN72f/dB1SUFOHh40er9p0IiklCV1bU6OqcPbKPbe/OZcCDs2kdV3dcKakfKTRrMmUKlZ27o34iEvo+pAQT14NfSDhJg8fRcdjdhMQk0Onme9BpK3B1Ny/K37tFENHdBxLdfWB1WVlRPtl/p5CVto/zv/zImgNr8fD2o9U1yYS270Sr9p3wCaxf0FVcPvUghWYeUmjWJDCQo+EDiB0CvLLsipdfzPib4LYdAKW7aK7I6sPTtwVRna8jLLE3Zz2iGDFiBKKynPPHD3Lu6F+kbv2GkvwcXN09CYlJVMQX2xnfoNYUZGfIqQcLIIVmZWpkvWqAitIiXD28UNXTtbQ07l6+tEnqTZuk3tVl2vJSck4c5tzR/RzbtYGi3LOc+P2nOu8tycuVUw9mIoVmZTQaGDnyytdlHtpLeGIP6xvUAG4eXoTFdyMsvlt1mWbjF/z46uMIve6yKw1OGhc1Q55YbGMrmydSaFbm0CF45pkrX5eh+Y1reg+1vkFmkjxkHCExCUanHjrffA/Hd/3Ike3fEtimHeEJPQhL7Il/qwhUMmdlDaTQrExpKXh7X/m67GMp9J34pPUNagpVUw6GfzsOm0hobGeEEFw88zeZh/by+xdLKMg+g7u3D607dCM8oSehsZ1wdXfuDSql0KzFrl2Uegbi6RHLlQJwKivKUalUqF3dbGObmXgHhOAd2Aq/kDZ0GjaxztSDSqWiZUR7Wka0J3nIOADKiws5m/Ynp/dtZ8/K/6GrrKBlRHvCE3sSntATv5Bwe1bJ5kihWYv77iP1sAcJ6rug61fw6qswaJDRS88dPeDQ7nK/kHAe+mQfajd3VCqVSVMPHj5+tO02gLbdBgAg9HouZBwj89Aedn66iKKcs3j4+BEW353whJ60at8RtdvVm1lWCs0alJfDkSNoGE+ybj/s3w8N7O2dkfIbbTr2sZl5jeFyUTVm6kHl4kJQVBxBUXF0HDYRUOb3slL/4Pien9j9xRJ0Oi1BUR0MrV4PfINam3Tv5jCR3iih5efn8+9//5vVq1dz6tQpvL29iY+P56mnnuL222+3tI3Nj9RUJb0cHbmHj5SypKR6L89K/YNutz9kI+McB0/fFsT0uIGYHjcASquXcyqNrMN72LH8JYovZOPp24KwhB6EJ/YgpF2y0e51c5hIN1to6enpDBo0iAsXLjBlyhQSExMpKSkhNTWV06dPW8PG5och9OoIccRyVIlv9Pc3eqlep0NXWYGbh5ctLXRIVC4uhMQkKJExIyYDUFpwkazUvRzbuYHfPn0FIfQERycQEBaNf2gUXv6BzWIi3WyhTZo0ieLiYg4cOEBkpONUxKEwCE2LG+5oG5yxzjl5iJCYRFtZ1uzw8g+sEc+p1+nIOXmYjx8eWOdaR17DZ1YYwi+//MK2bdt45plniIyMpLKykuLiYmvZ1nxJSSEff1qQrxw3kIwnI2UXER372siw5o+LWk2ra5IbXsOHitDYzvzywYsc3rKKC6eP2tRGY5jVoq1fvx6Adu3aMXr0aL777jsqKytp27YtTz75JI8++mi97y0vL6e8vLz6uKCgAACtVotWq22M7Y2m6nnWeq6rRsNBkqoXe1bGxyPqeVaGZhdxA263yWdg7XrbktjrR9EivB2fP153kn/8axto2bYDF9OPkXPyEEd+/toOFtbELKGlpqYC8MADDxATE8P777+PSqXizTff5LHHHuPixYvMnDnT6HsXLlzI3Llz65Rv3LgRb1NmdK3Apk2bLH5P15ISbj51Cg1DqoX2S14eBYYfqcsRQpB58m82b//V4nY0hDXqbQ/KzhvSQ6BCCQtT/t3x6694HskwnPOhJLy7Xey7HJUQpm+kfNNNN7F582aio6NJTU3Fw7BRQ0VFBYmJiWRmZnLmzBkCAwPrvNdYixYZGUlOTg7+9TgKrIVWq2XTpk0MHjwYNzfLThKrdu3C9frrmcZrTGcJMerTVOblGd3U4uKZ4xz47gMGTn3RojbUhzXrbQ8KczL5Yvow/ILDSRo6gYM/rqAwJ5NxSzbgF3xpQjw3N5ewsDDy8/Nt/l2rwqwWzctL8YxNmDChWmQA7u7uTJw4kXnz5rF7926GDRtW570eHh413lOFm5ub3f7oVnm2odWv2tBCFRePm6+v0UvPHd5DVOd+Nq+/PT9zS9IyrC0PfbK/eiK968j7jE6kO0JdzXKGREREABAWFlbnXFXZhQsXLGBWMyYlBQHoUCsbWjTkCNHsIiLZsSeqHR1Xd4/qAGZLruGzNGYJrU8f5UuRnp5e51zVHFpoaKgFzGrGaDQ1N7RowLVffPE8Pi2d/PNyEswS2m233Ya/vz8ff/wx+fn51eWFhYV89NFHBAYG0revk7uqTUgvB1CYk4VfsGkhRpLmj1ljtICAABYvXsz9999Pr169eOCBB1CpVLz//vtkZWWxfPlyu3kQHYJz5+D8+Zo7x9TTdTyT8httkp38R8mJMHvd/H333ce3335LSEgIc+fOZfbs2YSEhLBu3TomT55sDRubDydPgpfXpRbNywtiYoxemp7yGxEOHkgssRyNCioeOXIkI01Zn+9s9O4NhYVk3VRG68eCIec8qNVGL80/e5oWrU3M8Shp9shlMhZGuKjBxwfV6PpXMZQWXMDLL0Au93ciZO59C3Pq1JWTEZ85uJs2yb0bvkhyVSGFZmFMSS+XIR0hTocUmoUxRWi5p45UJ0qVOAdSaBbmSkKzdaJUiWMgnSGWYv16OHKEvGMTCSzXgQhV0rLVIuvwH4Qn2D+aXGJb5M+qpfj0UyqfeBL17p0QFgZPGs/RmKH5jYiO/WxsnMTeSKFZCo2GY7RXcoQAtG9v9LJzR/+iVfv6A40lVydSaJZAq4XUVFLo2GCMo05b4dCJUiXWQwrNEhw5AlrtFYOJzx09QGhcF9vaJnEIpNAsgSHr1SESSeQQtGkDRlaZp6f8JtefOSlSaJbAILRSvPCmtF7//tnUPwiLlx5HZ0QKzRKkpFCKJ56UKcdGlsbodToqteW4eTrxMiInRgrNEmg0pBJPAoeVYyMtWs7JwwRHJ9jYMImjIIXWVIqL4fjxmo4QIy1ahkYmSnVmpNCayqFDIMQl175KBQl1W64zml019ouWOBdSaE2l9oYW7dsrK6svQwhBeXEhnr4t7GGhxAGQQmsqKUpukOoNLYx0G/MyjxPYxnhKA4lzIIXWVDSamhtaGHGEyI0sJFJoTaXWhhZGhSYTpTo9UmhNoaICevZEEzyoQY9j8YVsmSjVyZHr0ZqCuzusXYtmGtz0YDGUHqwTtV+Yk2XyXsySqxcpNAtw4gREJ/mAS686587I/I0SZNexyQgBej3Ul5lATlRLQAqtyWRnQ0P7euRlnZKJUiVSaE2loWQ8pQUX8fRrIROlSqTQmopGU/8WaJkHd9MmSY7PJFJojWfrVhg6FM37u0g++CXs31/nErmRhaQKKbTGsmcPbNxIVkoOrZ8YB//8Z51Lck+lEdw23g7GSRwNKbTGYthCF0AFdfqPFaXFuHp4ykSpEkAKrfFoNJyiLW05pRzX8ohkybQFksuQQmsMOh0cOtRg1quMlN+IlIlSJQak0BrDsWNQXt6g0M4dPUCr2E52ME7iiEihNQbDYs9qoYWGQkhI9WmZKFVSmyYLraSkhHbt2qFSqZg6daolbHJ8DIs98wggkLw6jpBzRw8QGtvZDoZJHJUmC23WrFmcP3/eErY0HzQaKlGjRqcc1x6faWSiVElNmiS0ffv2sWTJEubMmWMhc5oJtTe0qO1xPPwHYQk97GCYxFFptNB0Oh0PPvggQ4cO5Y477rCkTY5NaSkcPVpvejmh11NZIROlSmrS6PVoS5Ys4dChQ6xcudKk68vLyykvL68+LigoAECr1aLVahtrRqOoel6jnpuSgpteTwodGcl3yn1iY5UdZYDzJw7RMqqDzetkCk2qdzPGEerbKKGdOnWK2bNnM3PmTGJiYjh58uQV37Nw4ULmzp1bp3zjxo14e9vn13/Tpk1mvydiyxa6o2xo8TSLKA4N5aft26vP5/21GVf/YNavX29BSy1LY+rdnCkpKbG3CY0T2sMPP0zbtm15sp5dLY3x3HPPMWPGjOrjgoICIiMjGTJkCP7+/o0xo9FotVo2bdrE4MGDcXMzzwXvYhBVCd74UIK+5w2MGDGi+vwPKd8xaNLDePoFWNJki9CUejdncnNz7W2C+UJbsWIFP/zwA9u2bTPrj+Xh4YGHh0edcjc3N7v90Rv17MOHKcUTL0oBcOnUCRfDPYQQVJQU4tcypKE72B17fub2wBHqapbQKioqeOKJJ7jllluIioqq7jJmZGQAUFhYyMmTJwkMDKRFi6s0K+/dd5Pq25+E3cVQGFjDEZKXeYKA8Gj72SZxWMwSWklJCdnZ2Xz//fd8//33dc6vWLGCFStWsHDhQp599lmLGelQTJiARgfJdwB3TVYShhiQ+UEk9WGW0Hx8fPjmm2/qlGdnZ/OPf/yDoUOHMnXqVJKSkixmoCOi0cDkySgbWqjV1eUZKb/Rf8q/7GeYxGExS2hubm6MGjWqTnlVFzI6Otro+auNtDSIja1bXnwhW+ZwlBhFBhU3Aq1WyZ16OUW5WfgGyWzEEuNYJIFqdHQ0QogrX3gVkJ8Pxvw8GSm7aCPjGyX1IFs0UxECKio4eNB4erkMzS4ipSNEUg8yJbipZGVB27ZoQv5FcntfEOXwf/8Hnp4A5GWepEVYtH1tlDgsskUzFY0GKivRZLUk+Zc3YeHC6oGaTJQquRJSaKZiWFV9ghiiOQlJSdUJ95VEqXJ/akn9SKGZimFVtUCFC6JGRIjcaFByJaTQTEWj4RytaEW2cnyZRyTnZCrB0Ql2MkzSHJBCMwWdDg4eNJr1SiZKlZiC/HaYwokTUFpqdFX1WZkoVWICUmimcFl6uY6kQHAwtGoFVG1kIefPJA0jhWYKBkdIFmG05qzSmhlc+dnH/iK0vUyUKmkYKTRT0GhqbmhhGJ/ptBUIIVC7udf3TokEkEIzDY2G00TV2dDi3LG/ZKJUiUlIoV2J8nJISyOFjnUcIcpGFnJ8JrkyUmhXIi0NdLqaHkfDwtasVJkoVWIaUmhXovaGFm3bgr+/IVFqmUyUKjEJKbQrUXtDC8P4LOdUqtw2V2IycpnMlXjsMSp7X4v6+TjoOgF6K8HDGSlyIwuJ6UihXYnwcI7FhxM7Anjls+riMwd3k/DoIvvZJWlWyK6jCWg0NVdVCyEoK8x3yGzEEsdECs0EagstP+ukTJQqMQspNBM4eBASLlsFI9efScxFCs0ESkrAx+fScUbKb0R0lEKTmI4UWkP8/julRzPw9KyZSq8o9xy+QWF2MkrSHJFex4YYOZLU7HASPSZA/2/hjTcoimyNT8tW9rZM0syQLVp9ZGdDdrYSEVK+F3bsAB8fuZGFpFFIodVH7dArT09o105OVEsahRRafRiEdoQ4YjkKiYmgVpOXeZKA8Bg7Gydpbkih1YchxrECd9zRQseOlBXm4enrLxOlSsxGCq0+NBry8cefAuU4OZkzB3cTLhOlShqBFJox9HrQaDhIUo3FnnIjC0ljkUIzxunTUFR0KesVQHIyOScOy0SpkkYhhWaM2h7HgAC0LQNwdfeQiVIljUJ+a4xhcIRUb2jRsSNZaX8SliATpUoahxSaMQwtWvWGFsnJhvkzOT6TNA6zhHbkyBFmzZpFnz59CAkJwc/Pjy5durBgwQKKi4utZaPt0WjIJqTGhhbnjh6QqeUkjcYsoX3wwQe8+uqrxMTEMHPmTF5++WU6dOjACy+8QL9+/SgtLbWWnbZDq4XDh2ukl9MlJshEqZImYVZQ8ZgxY3j22WcJCAioLps6dSqxsbEsWLCADz74gEceecTSNtqWo0dBq62RXi7bC9maSZqEWS1ajx49aoisirvuuguAFIMToVlz/Di4uFxy7YeHk3H6oAwkljQJiyyTOXPmDACtWtW/fKS8vJzy8vLq44ICJeJCq9Wi1WotYYbJVD3P6HOHDoWLF8kcoSd4ippKbQUZB3eSNGySze20NA3W+yrGEerbZKHpdDrmzZuHq6srEydOrPe6hQsXMnfu3DrlGzduxNvbPklIN23aZLRcCMgu78364CCE0JO1N51NP2+1rXFWpL56X62UlJTY24SmC23atGns2rWLF198kQ4dOtR73XPPPceMGTOqjwsKCoiMjGTIkCH4+/s31Qyz0Gq1bNq0icGDB+Pm5lbn/KlT0KOHCyNGjCDn5GEOn72O/iNG2NRGa3Clel+t5Obm2tuEpgnthRde4M033+SBBx7g+eefb/BaDw8PPDw86pS7ubnZ7Y9e37PT0qBTJ3BzU3P28F7adr72qvpi2vMztweOUNdGT1jPmTOHBQsWMHnyZJYtW3ZVLR1JSbmUXu7MwV0yYl/SZBoltLlz5zJ37lzuvvtuPvzwQ1yusvg/jUbZMKYqUaqXf6BVnzdn6xzmb5tv9Nz8bfOZs3WOVZ8vsT5mK2TevHnMmTOHiRMnsnz58qtLZGvXwnvvcfHERVq6FZJ/9hQBYW2t/li1Ss2srbPqiG3+tvnM2joLtUptdRsk1sWsMdrSpUuZPXs2UVFRDB48mM8//7zG+dDQUAYPHmxRA23Km29SuXEzroSA/ygypk8i4tZRVn/szAEzAZi1dVb1cZXI5g2cV31e0nwxS2h79uwB4PTp09x77711zg8YMKB5C02j4RjtlRwhQIb2ItfaaKL6crHN3z4frV7L3IFzpciuEswS2vLly1m+fLmVTLEzFy5AZiYa7qgOvSpS6/ELtl2i1MmdJzN762y0ei0uKhf2ZO7h5hU34+vuS1zLOOKC4ugQ3IG4oDgCPANsZpek6cgEqlVcttjzFr6n2McDn3Drj8+qOFNwhkEfDUIgcFe7U6GroFd4L2YOmElRRRFHc4+SlpvGD0d/4LXdr5FXlgdAmG8YHYI6VIuwXWA73NUy+NnRkEKrwiC0gyTxFC+TkRRFROdrbfLos0Vn6f9hf07knagek1WN0UDpVnYN60rXsK413ieE4GzRWY7kHiEtN43tp7ZzPO84FboK3FzcaBfYroYIgz2CzbZtztY5qFVqo13Y+dvmoxM65gyc06h6OxNSaFUYAqJL8MaHEjJa+9LNBhtZnC8+T7/3+9UQGRh3kNRGpVIR5hdGmF8YA6IH1Din1Wk5fvE4ablp/JH1BytSVpBZmEl2djafr/mc+JD4ahHGBcXh5+Fn1L4qj2htGy531kiujBRaFRoNpXjiSRkAF71cCAhvZ9VHXii9wPhV4xnWfhhhvmF1xFR1rBM6s+/tpnajQ3AHOgRfCovTarWsX7+ea2+4lhMFJ0jLTWNt2lqO5B6hsKIQFSoi/COUFtAgwuf6PwdIj2hTkUIDJYo4JYVU4knkEGWuKjyCQ60a7ZJXlse4r8fx8uCX63QJL8caX+QWni3o6deTnm161ijXCz2ZhZmk5aSRlpvGpuObOJF3Ap1eR0JwQg2PqBSZeTiP0NKB84b/V0KLv1vAPpRP4Fw25PtWL/Y8E+BKm+4D6r9XEyksL2Tc1+NYcMOCBkVma1xULkT4RxDhH8GN7W6sca6ssgz/hf5o9VpUqCjWFqPJ1pDcKrmeu0kuxzmEVg70BM4ph264MZCBl10QCuxBw2dM5kPOtPIhvv9wq5hSXFHMuFXjmDVgVp0WxZF5+deX0eq11R7Ri2UXeeePd0jNSWVwu8GM7zieCP8Ie5vpsFxF8VMN4A5EUX9tVXognSNcQyxHOR/qT3BMosXNKNWWMn7VeJ7u9zT9IvtZ/P7W4vIxWfkL5cwbOI93/niHEO8Q1k1YR3KrZJ7f/DwjPx/J+3++Xz31ILmEc7RoKmA+MKye88IFmImWx1C5aHH1b4GL2rLxheWV5UxYPYFpvafV8RA6MsYcH8Y8osNjh1NUUcTa1LVMWTsFD7UH45LHMbz9cDxc6y6PcjacQ2gAQ1C6j38Clzvx1IDHQfJLduHHvWS1cKV1lGXTflfoKrj7m7t5sNuD3NTuJove29rohM6o48OYR9TX3ZeJnSYysdNEzhWd48uDXzLqy1FE+UcxsdNErou6DheVc3SiaqMSQogrX2Z5CgoKaNGiBfn5+bZbYf0jxls19X/YqdvKFroxqN1ioue8SvikqRZ5ZKW+kknfTGJc0jhui7/NIvdsLFXu/REjRth0MeSR3COsSFnBjtM76NWmFxM7TiSpVZLNnp+bm0twcLBtv2u1cJ4WDapbNfGnQKVTIdQCVQcd6FzQ/L2AjpWCc36b6e06GkqAJqYy0el13Lf2PkbHj7a7yOxJXFAccwbOQQjB7jO7eXvv26TlpjHkmiGMTx5PG/829jbR6jiX0AxjNdUwZX5MpVPBq64w9Ck002DQ2LOkvNsSdVYrmAhUAn2Bm4DuKN1ME9ELPQ999xBDrxnKnUl3WrwqzRGVSkWfiD70ieiDVqdl0/FNPLv5WfLL8rk9/nZGJ4ymhWcLe5tpFZxLaABDQN9dj8sfLsq/Q5Qxw4kT4B2YSegN18NkYAZQAewCvgfmAD7AQBThxaEI1whCCB5Z9wjXRl3LxE71ZwZzZtzUboyIHcGI2BEUlheyJnUN96y5By83L8YnK9EyV1NwtPMJTQX6F/UUPViE94ve1YNzISDz4M6aG1m4A9cbXgD5wDZgKZAGhKOI7kagNYb7CB7f8DidW3fmvq732aRKzR0/Dz8mdZ7EpM6TOFt0li81X3Lr57cSExDDxE4T6RfZr9k7UZxPaIC4UbDlf1sYcaOSQi47G1q1gszDf9D5lin1v7EFcKvhBXAG2Aw8DZwDkSh4usPTtE9oz9QeZjhTLo9aMUYrwEnmglv7tubxPo/zeJ/HSctJ47OUz5izdQ692/Tm7k53kxCieISb26oCpxRabVJSIClJT+WFUty9fEx/YxuUbuZkQMDMlTNpdbIV096YBouAXigtXi+gPidfragVo7QGTgJONh3VIbgD8wbNQwjBroxdLN2zlKMXjjL0mqEUa4t5ZecrQPNYVSCFhrIULTIkgyC/uEbfY/72+Xi29uSpu55SCrTAXuAnYCGKSK5H6WYmcWl8VxW1ch7QG7mxCxBpuM5JUalU9I3sS9/Ivmh1Wn78+0f+zPqTDkEdmLV1FuW6cl684UWHXlXg1EJTff89fPYZmhPPkzBoNRH9rmnUfRb9uqj6j12NG4rHsmrIVwT8AnwIHARCUER3Ew1HregN56+etJlNwk3txi1xt3BL3C0Ulhdy75p7WfDLAhbuWIhe6Jl1/SyHExk4S6xjPah27IBVq8j6M5OKDa/RZvlKs++xZNcSckpymD/IeF7GanyB4cB/gQ3AKyit3GzD/1tR96+hRulWDjHbLKfAz8OPVWNX4a52Ry/0uKpc2Zu1lylrp7Dh2Aa0OvtvblGFc7dohw5RFRZT5q7Cq6N5S1be2vMWJy6eYMmwJeavXQsFxhteAqWlu7/WNTpgHrI1a4D52+ZToauoXlXQp00f7ulyD19qvmTxrsXEBMQwvI11VmKYg3O3aAcPcpooWqtP06JUDx07mvzeD/Z9QEp2SuNEVscQYApK61U1Ke6CIsb/Ag+jzOXZf1MUh8LYqoJZW2fx0f6PeOrap/jx7h+Z0XcGu87ssrepztuiuRYVoUpPR8MIwnwOE5GnvZRw/wp8+ten7EzfyTsj37HcKuzaKwz0wEfAUOAYsA54F0WINwE3A7ZL0uVwmLqqIC4ojif7Psm/+bfdbAUnFpp/ejqgpJcLCNxHRI6AuCt7Hb86+BUb/97Ih7d9aPlJ1KoVBnuoOTZrDzxueBWieDLnA6eBbiii64tT/TXNWVXgCDjRn6Ym/qdOAZBCR270/wI/vw7g3rAPfU3qGtakruHj2z9G7WKFfPgq4CVgmuFfY42lH3C74aVHScewznB9EDACpVVsaXnzHImGJqMd0evotELzO30agBxVIK31udCx4RXP64+uZ0XKCj4b/RmuLlb82G4CDpl4rQtKsHN3w/E54AfgnygtX3+U1i4Z6VCxM04rNP9Tp6hEjdZNT8TFygbHZ5v+3sR7f77H53d8jpva/pva1UsocK/hVQHsQPFmaoD2oBqqwqXcqf1fdsM5hSYE/qdPc4z2BPkcVxwh9Xgct53cxhu/v8GXY75sXkvy3YEbDC+Ao6D6VkWPr3qgXqFWnCw3o0SlNISMw7QIzim0s2dxLyxEQzIhfocJuKg32qL9evpXFu1cxFdjvsLLzcsOhlqQWNBP0/N7+98Z0X8ELltdYC6QgeJQuQXoQ801dzIO02I4pdBUBw8CsF/VkWvcNqPy8YHo6BrX/H7md+Zvn8/KO1fi425GoHFzwA8YbXjpUfKorANeBIJRHCpDgUBkHKaFcE6hGTa02OeWxPNlryv76F62c+m+rH288PMLrLxzZb056a8aXIAehhfAWRSHysMo8ZkdUaYbjCHjME3GKUfGVS3aBVdfYvPza3QbU86l8PRPT/PFmC+u2mX1DdIaJUrlS+AbYByKk6U2Mg7TLJxSaFUbWgi3coKLdNWOkNScVKb/OJ0Vo1fQ0usqn4gyBXdgMEqESm10KGO6DJta1Gxxyq6juPtuNqMhMvsULmUekJzM0dyj/HPdP1lxxwpCfELsbaJjUTsnphrohLK+bg6K2LqjOFR6Y1YSI2ehUS3a559/Tvfu3fHy8iI4OJjx48dzyhBp4ejodLA6YBj/zh+Ce0ICuvwiTnRpy0PfP8Qnt39Ca9/W9jbR8aiKw6yKatKhLGYdA7yPMqa7HdiIIrZJwBfARZtb6rCY3aL973//47HHHuPaa69l8eLF5OTksGTJErZv386ePXsIDw+3hp1NZs7WOaT9ksSOd+4kIyMeiOfXY7ClXSW6oa8y4a4uTpFfsNHUF4cJys91T8MLIAtFfFNRHCoDUObsEnFex4kwg5ycHOHr6yu6desmtFptdfmePXuESqUS999/v8n3ys/PF4DIz883x4RGM+7Z5QJ0AvRCyXlV9dIJ0Ilxzy63iR32pKKiQqxZs0ZUVFQ07gabhBAJhn9Npcxw/XQhxGAhxCNCiPVCiNLGmdAYcnJybPpdM4ZZXce1a9dSVFTEtGnTcHW91Bj26NGD66+/nq+++oqKigoL/xQ0HZ0OflhclfO+9k+q8hFsWHwjOscK+HY8quIwzdk+wMNw/WKUruU0IBW4C7gDWIZTOFTM6jr+/vvvAPTrVzcAt1+/fmzbto3U1FQ6depU53x5eTnl5eXVxwUFBYCSD16rte6S823bVOSXN9QtdCGvPIItWyoZMMAuWxHYhKrP2dqfd4PEAI8aXgWg+kmFywsukAmim0CMEIhe4soOlXQgp4HzIVSHhtm1vgbMEtqZM2cAiIioG9xWVZaRkWFUaAsXLmTu3Ll1yjdu3Ii3dxOT3F+B7dvbcGlGtn5++GE/xcVnrGqLI7Bp0yZ7m3AJT6qX/AT8HUDom6EEPhFIhX8F57qfI7trNlrfmkJx0bow+MHBeOZ51nvbsoAyNr27Cb2bnpIS+y9NN0toVQZ7eNQNbPP09KxxTW2ee+45ZsyYUX2cn59PVFQUffv2xc/P2tEXKl59teCKV11/fTuuuy7GyrbYD61Wy5YtWxg0aJBNd5MxmetRJssB17OutPupHe1XtocSEH0F+iF66KCcL4suo/xAOSpR17siVAIRLeg3sB+o4MKFC0q5fTZOAswUWlXLU15ejpdXzSDb0tLSGtfUxsPDo4ZAq7qOMTGO88UeNcreFkjqZRNKoiJTEMB+lO7jZeTm5tKihX2ifcwSWps2yjgnIyOD2NjYGuca6lYaIzw8nPT0dPz8/CyXd8NECgoKiIyMJD093W77ZdkDZ613Ve+pZUv7RfuYJbSePXuybNkydu7cWUdoO3fuxNfXl/j4eJPu5eLiYrIorYW/v79TfeGqcNZ6u7jYL+LQrCffdttteHt78/rrr1NZWVldvnfvXrZv385dd92F+xXybkgkzohZLVpwcDAvvfQS06dPZ+DAgUyaNImcnBwWL15MaGgo8+Y51sYCEonD0JhZ7k8//VR07dpVeHp6ipYtW4qxY8eK48ePW3gu3XqUlZWJ2bNni7KyMnubYlNkve1Xb7ttFi+ROBPOuR5NIrExUmgSiQ2QQpNIbIAUmkRiA6TQJBIb4BRCW7ZsGRMnTiQ+Ph4XF5dGh3wdO3aMMWPGEBQUhLe3N71792b16tUWttaybNy4kf79++Pr60tAQAC33HILKSkpJr9fCMHbb79N165d8fLyIiAggGHDhrFrl/33HGuIptYb4Pvvv2fQoEGEhobi4+NDfHw8zzzzDOfPN5S6uR7sNrFgQ9q2bSt8fX1F//79RUREhGhMtU+cOCGCg4NFUFCQmD9/vnjrrbfEtddeKwDx4YcfWt5oC7B27Vrh4uIikpOTxeuvvy5efvllERUVJfz8/MRff/1l0j2mTp0qADFw4EDx+uuvi3//+9+iXbt2wt3dXWzZssW6FWgklqj322+/LQDRvXt38eqrr4ply5aJKVOmCJVKJeLi4kRpqXlLxJ1CaCdOnBA6nU4IIcTNN9/cKKGNGzdOqFQqsWfPnuqyiooK0bVrVxEYGCgKCgosZq8l0Gq1IjIyUkRERNRYwn/q1Cnh4+MjbrzxxiveY//+/QIQw4YNE3q9vrr84sWLIjQ0VMTGxlZ/ro6CJeothBBxcXEiLCysjqAef/xxAYgffvjBLLucousYHR3dpIDS4uJi1qxZw4ABA+jR49ICUjc3N6ZNm8bFixdZt26dJUy1GNu3byc9PZ0HHnigRgBxVFQUY8aM4eeffyYzM7PBe2zZsgWAe+65p0Z3OyAggNtuu42jR4/y66+/WqcCjcQS9QYl4j8wMLB6nWUVVcmnzF2s7BRCayopKSmUlZXVm8IBLqV5cBSulHZCCMHevXsbvEdZWRlg/EtVVbZ79+6mmmpRLFFvgJtuuolDhw7x5JNPkpqaSnp6Ol999RWLFi1iyJAhXHfddWbZJYVmAqamcHAkLGFzYmIiAD///HONciEE27ZtA+C0YUNHR8FSf6vXX3+d22+/ncWLF5OQkEBUVBRjx47lzjvvZN26dWb3kJpNpuKKigpeeuklk6+/9957ia61Q0xjaUoKh6bS2Hpbwubhw4cTHx/Pm2++SXh4OKNHj6akpIRXX30VjWGjkKux3lXXxsbGMnr0aEaOHImPjw8//fQT7777LqWlpSxfvtxk26CZCc1Ycp/6GDhwoMWEdnkKh9pcKYVDU2lsvS1hs5ubGxs2bGDy5Mk888wzPPPMMwAkJSWxcOFCnnzySastILVnvfV6PUOHDkWn0/Hrr79Wj0/vuOMOwsLCmD17NqNHj+bWW2812b5m03X09fVFKF5Sk14DBw602LMvT+FQG3NTOJhLY+ttKZvbtm3Ltm3bOHXqFNu2bUOj0aDRaKpzxpi6ot5c7FnvHTt2sGPHDsaMGVNnznXs2LHAJUeRqTQbodmTjh074uHhwc6dO+ucqyrr2bNnnXP2pMqe+mxWqVR07969zrn6iIqK4vrrrycpKQmA9evX4+LiwtChQy1jsIWwRL2rBGksH2RV2eUZBkzCrMmAq4ArzaOdP39eHD58WOTl5dUov+uuu4RKpRJ79+6tLtNqtaJbt24iICDArummjaHVakWbNm3qnU+64YYbalxfX72NsXbtWgGIe+65x9JmNxlL1Ltq/rBTp0510qc/8cQTAhAff/yxWXY5hdC+/fZbMX/+fDF//nzRoUMHAVQfz58/v8a1s2fPNhrt8ffff4ugoCARFBQkXnzxRfH2229XR4a89957NqyN6axevVqoVCqRnJws3njjDfHKK69UR8kcOHCgxrX11fu+++4TU6ZMEa+99pp45513xOTJk4VarRY9e/Y0SZT2wBL1vuOOO6rFtmjRIrF06VIxatQoAYhu3bqJ8vJys2xyCqHdc889AiXbn9HX5dT3wQshRFpamhg9erQICAgQnp6eokePHmLlypU2qkXj2LBhg+jXr5/w9vYW/v7+YsSIEWL//v11rquv3m+//bbo2rWr8Pf3F56eniI5OVksWLBAlJSU2KgGjaOp9a6oqBDLli0TvXr1EkFBQcLNzU20b99ePPXUU42KApKpDCQSGyCdIRKJDZBCk0hsgBSaRGIDpNAkEhsghSaR2AApNInEBkihSSQ2QApNIrEBUmgSiQ2QQpNIbIAUmkRiA6TQJBIb8P9pRl6jX08+jwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 200x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig=plt.figure(figsize=(2,3))\n",
    "ax=plt.subplot(1,1,1)\n",
    "#ax.set_title(r'$u(x)$',fontsize=15)\n",
    "ax.plot(p,u.squeeze(), label='Truth', c='r', linewidth=3, linestyle='dashed')\n",
    "ax.plot(p,predict_u_pidon.squeeze().detach(), label=r'PIDeepONet $\\hat{u}(x)$', c='magenta', marker='v', markersize=6, linewidth=0.5)\n",
    "ax.plot(p,predict_u_pinn1.squeeze().detach(), label=r'PINN1 $\\hat{u}(x)$', c='g', marker='x', markersize=6, linewidth=0.5)\n",
    "#ax.plot(p,predict_u_pinn2.squeeze().detach(), label=r'PINN2 $\\hat{u}(x)$', c='g', marker='^', markersize=6, linewidth=0.5)\n",
    "ax.plot(p,predict_u_don.squeeze().detach(), label=r'DeepONet $\\hat{u}(x)$', c='saddlebrown', marker='*', markersize=6, linewidth=0.5)\n",
    "ax.plot(p,predict_u.squeeze().detach(), label=r'Ours $\\hat{u}(x)$', c='b', marker='o', markersize=6, linewidth=0.5)\n",
    "#ax.legend(fontsize=11)\n",
    "plt.xticks(fontsize=13)\n",
    "plt.yticks(fontsize=13)\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.05,-0.8)\n",
    "ax.set_ylim(-0.1,9.53)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6a597abc",
   "metadata": {},
   "source": [
    "## Plot 5 times for PINN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "e86c558a",
   "metadata": {},
   "outputs": [],
   "source": [
    "paths=[\n",
    "    'PINN_epochs500000_20230513T185237',\n",
    "    'PINN_epochs500000_20230514T001821',\n",
    "    'PINN_epochs500000_20230507T212830',\n",
    "    'PINN_epochs500000_20230514T001903',\n",
    "    'PINN_epochs500000_20230514T001916'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "cda7ba04",
   "metadata": {},
   "outputs": [],
   "source": [
    "models=[]\n",
    "for idx_pinn in range(5):\n",
    "    model_pinn = PINN(2,100,'tanh',1,1)\n",
    "    PATH_pinn=os.path.join('train', \"deeponet\", f'3000N'+str(num_element[idx])+f'_{bdry[idx]}',paths[idx_pinn])\n",
    "    state_dict=torch.load(PATH_pinn+'/model.pt', map_location=torch.device('cpu'))\n",
    "    model_pinn.load_state_dict(state_dict['model_state_dict'])\n",
    "    models.append(model_pinn)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "88265626",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, '$u(x)$')"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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eT0ov/32GwBdunQp2ubn5wdAVlZWhefWNI2HH3646Pfi4lK1ryt7YGK/jmi4JEARjU5mZmbRVOvV/Qu+Opo0acLhw4d54oknSvwDXN/OWdfOnz8PUOYMs3WlJu9jZGQkR44c4eTJk7Ru3brU6wkJCVW+fnR0NIcOHeKvv/5y2KzDkZGRHD58mOPHj5c5XHPy5ElAHwZzlD/++AOgzAqnnTt3kpiYSHR0dImezNDQUADS09MrPPfDDz/Mhx9+yMiRI/n1119ZuXIls2bNKvN3U5z98xcSElKtexH1j+SgiEbnP//5D7m5ufTq1Yt+/fo57DpXX301ULsTiDninGVxdXUFqHDdoppISUkpynno3r17rZ67OmryPtrzUj788MNSrx05cqSoV64613/ttdcq3bemv4sBAwYAsHr16lKvmUymovuw7+cI9kkMLw0GNE0rGo65NHgJDQ0lPDyckydPlpun9PLLLxMfH0+fPn1Yu3Yts2fPxmKxMGfOnErbdOjQIdzd3WW6+0ZAAhTRaBw7dozbbruNN998Ey8vL958802HXm/atGmEhITwzDPPsGLFilITXOXm5rJq1aqif8Sddc6yBAcHYzQaOXr0aNFwSFVt27aNH374oVTbTpw4wU033URubi6jRo0qN8+hLtTkfZwyZQqurq6sWrWqRGJpfn4+DzzwADabrcrX/8c//kFwcDDr1q1j6dKlpa6/ZcuWoqGImv4u7r77bjw8PHjvvfdYv3590XabzcZjjz3G6dOn6dWrF3379q3yOavLHpjY5zUBKCgo4KGHHipqU1m9KwMGDMBisRQNERX3wQcfMGPGDFq1asW6devw8PBg+vTphIeHs3bt2gon2Tt69ChpaWn07t27zHlzRAPjrPIhIWqCC6WlkyZN0iZNmqRNmDBBGz16tNa+ffuiMtDWrVuXWXpqP762yow1TdN++uknLTAwsOi8N9xwg3bzzTdrPXv21Ly8vDSgxJpAVSkpre1zzp07VwO0FStWlNhuLynt2LGjNmHCBO3uu+/W3nrrrXLbZbdixQoN0CIiIrRBgwZpt912m3bllVdq7u7uRedLTk6u9DzF2X+vVeWI91HTLpYnGwwGbejQodptt92mRUZGak2aNNFGjBhR5TJjTdO077//XvPx8dEArWXLltrYsWO1ESNGaM2bNy/1earK76Ks67zzzjua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iIhUgs9BISIiItVhgkJERESqwwSFiIiIVIcJChEREakOExQiIiJSHSYoREREpDpMUIiIiEh1mKAQERGR6jBBISIiItVhgkJERESqwwSFiIiIVIcJChF5lKKiIvj5+WHmzJl25Z999hn0ej2effbZLmoZEXUmJihE5FFCQ0Px9NNP46OPPsKuXbsAAFlZWZg+fToee+wxLFu2rItbSESdgbsZE5HHqaqqwpAhQzB06FD89a9/xeTJk/Gb3/wGq1atgqIoXd08IuoETFCIyCOtWbMGDz30EHx9fXHHHXcgPT0dWq22q5tFRJ2Et3iIyCPddNNNAABFUZCWlsbkhKibYYJCRB5nz549mDZtGsaOHYvKykqsXr26q5tERJ2Mt3iIyKMcPnwY48ePR3x8PD799FNMnz4dO3bswNGjR2Eymbq6eUTUSTiCQkQe48SJE0hOTkZUVBQ2bNgAvV6PFStWoLS0FMuXL+/q5hFRJ+IIChF5hKKiIowbNw4mkwmZmZkICAiwvffII4/gvffew6FDh9C/f/+uayQRdRomKERERKQ6vMVDREREqsMEhYiIiFSHCQoRERGpDhMUIiIiUh0mKERERKQ6TFCIiIhIdZigEBERkeowQSEiIiLVYYJCREREqsMEhYiIiFSHCQoRERGpzv8HNhsD3LVFkr0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_idx=np.random.randint(3000)\n",
    "plot_idx=1073\n",
    "f = data_f[[plot_idx]]#.cuda()\n",
    "u = coeff_u[[plot_idx]]\n",
    "colors=['tomato', 'olivedrab','turquoise','blue','violet']\n",
    "predicts=[]\n",
    "for idx_pinn in range(5):\n",
    "    predict_u_pinn=models[idx_pinn](torch.FloatTensor(p).reshape(-1,1))\n",
    "    predicts.append(predict_u_pinn)\n",
    "\n",
    "fig=plt.figure(figsize=(6,4))\n",
    "ax=plt.subplot(1,1,1)\n",
    "ax.set_title(r'Different 5 Prediction $u(x)$',fontsize=15)\n",
    "ax.plot(p,u.squeeze(), label='Truth', c='r', linewidth=1, linestyle='dashed')\n",
    "for idx_pinn in range(5):\n",
    "    ax.plot(p,predicts[idx_pinn].squeeze().detach(), label=f'PINN{str(idx_pinn)}', c=colors[idx_pinn], marker='x', markersize=4, linewidth=0.5)\n",
    "ax.legend(fontsize=11)\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.05,1.05)\n",
    "ax.set_ylim(-12,12)\n",
    "ax.set_xlabel(r'$x$',fontsize=12)\n",
    "ax.set_ylabel(r'$u(x)$',fontsize=12)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "53940060",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "990718ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61e97b55",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "operator",
   "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.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
