{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e994a234",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker\n",
    "import numpy as np\n",
    "from net.network import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f6477cd1",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_element=[24]\n",
    "folder=['pretrained']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f0d2290b",
   "metadata": {},
   "outputs": [],
   "source": [
    "idx=0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c5158b5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mesh=np.load('mesh_1DP2/ne{}.npz'.format(num_element[idx]))\n",
    "NUM_ELEMENT, NUM_PTS, p, c, gfl = mesh['ne'], mesh['ng'], mesh['p'], mesh['c'], mesh['gfl']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1e019c0e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array(24), array(49))"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "NUM_ELEMENT, NUM_PTS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "84aa0687",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import Dataset, DataLoader\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "652d60ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "NUM_DATA=3000\n",
    "BATCH_SIZE=NUM_DATA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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])\n",
    "        with open(f'data/P2/{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": 9,
   "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": 10,
   "id": "4601ceea",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_FEM = NetA(1, 32, NUM_PTS, kernel_size=5, padding=2, blocks=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "df9bf212",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "PATH=os.path.join('train', \"P2\", f'3000N'+str(num_element[idx]),folder[idx])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ac718744",
   "metadata": {},
   "outputs": [],
   "source": [
    "state_dict=torch.load(PATH+'/model.pt', map_location=torch.device('cpu'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "18a38b78",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_FEM.load_state_dict(state_dict['model_state_dict'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "id": "4638e973-0ce5-4d22-ac1e-2345940efff9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1560\n",
      "Error:0.0005716184969060123\n"
     ]
    },
    {
     "data": {
      "image/png": "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PH/++Sfjx4/n4MGDORJ3XtAyzSIiIiIiIiKSIR999FGK+x9++CGRkZGptteoUSNbz/Pnn38yYcIEmjVrRmhoaLbOlVdUYBERERERERGRDOnZs2eK+7/88guRkZGptl/r4sWLbr9ktaYIiYiIiIiIiOSlf//N+telS+mf97//MneuXNKsWTNq1qzJ5s2badq0Kf7+/owZMwYwpxiNHz8+1TGhoaH07t0bgAULFtClSxcAmjdvnu60o/Xr13PHHXdgtVqpXLkyH374Ya7llBEawSIiIiIiIiKSl0qVyvqxs2bBwIFpP1ajhllkySjDyHocN3D69Gnuu+8+Hn74YXr27Enp0qUzfGzTpk15+umneeONNxgzZkzydKOrpx3t3buXhx56iL59+9KrVy/ef/99evfuTYMGDbj11ltzPJ+MUIFFRERERERERHJUVFQU77zzDv3798/0sZUrV6ZJkya88cYbtGrVimbNmqXaZ8+ePaxbt44mTZoA0LVrVypUqMD8+fOZPn16dsPPEk0REhEREcmnpkyZgsViYciQIc4ORUREJAVfX1/69OmTa+e/5ZZbkosrAEFBQVSrVo39+/fn2nPeiAosIiIiIvnQ77//zpw5c6hdu7azQxEREUmlXLly+Pj45Nr5K1asmGpbsWLFOHv2bK49541oipCIiIhIPnP+/Hl69OjBu+++y4svvujscEREJLNOncr6sYULp//Y7t252lclM/z8/DK1f2JiYqb29/T0THO74cT8VWARERERyWcGDhzI/fffz7333nvDAktcXBxxcXHJ92NjYwGw2+3Y7fbrHpv0+I32y4/cNTd3zQvcNzd3zQvcN7eM5mW32zEMA4fDgcPhSPlgiRLZC+La8yUpXjxb50kqTiTFnRFJx6S1f1rbkkaZXP1YfHw8J06cSPG8V583rfNcL8Zrt1+bl2EY2O32NIs02fl5VYFFREREJB9ZsmQJW7Zs4ffff8/Q/pMnT2bChAmptq9evRp/f/8MnSMyMjJTMeYn7pqbu+YF7pubu+YF7pvbjfLy8vKiTJkynD9/nvj4+DyKKmecO3cuw/sm5ZZUwAdISEggMTExxbYkoaGhrFmzJsVjc+fOJTExEbvdnrzdYrEAcOLEiVTncTgcJCQkpNqekJCQKpZr84qPj+fSpUusW7cuef+rXbx48YY5p0cFFhEREZF84siRIwwePJjIyEisVmuGjhk9ejTDhg1Lvh8bG0uFChVo3bo1RYsWve6xdrudyMhIWrVqhbe3d7ZidzXumpu75gXum5u75gXum1tG87LZbBw5coTChQtn+P9sZzMMg3PnzlGkSJHkAseNJPVZufpvipeXF56enmn+nenXrx8DBgzgf//7H/feey87duxg9erVlCxZEm9v7+RjGjVqhKenJ7NmzSI+Ph5fX19atGhBqVKl8PDwwMvLK9X5vby8UsVybV5xcXH4+fnRtGnTNF+X9IozGaECi4iIiEg+sXnzZk6dOkX9+vWTtyUmJrJu3TpmzZpFXFxcquHOvr6++Pr6pjqXt7d3ht/wZGbf/MZdc3PXvMB9c3PXvMB9c7tRXomJiVgsFjw8PPDwyB/ryyRNrUmKOyOSCjFp7Z/Wtv79+3Po0CHmzZvHt99+S5MmTYiMjKRly5Ypnrds2bK88847TJ48mX79+pGYmMiPP/5ImTJlbhjjtduvzctisaT7+mXnZ7XAFVhCQ0M5dOhQqu0DBgxg9uzZqbYvWLAg1dJSvr6+2Gy2XItRRETElZ09C5nsQyc5pGXLluzcuTPFtj59+lC9enWeffbZdBv+iYiI5JZZs2Yxa9asFNvWrFmT7v4eHh5MmTKFKVOmpNh+8ODBVPs+9thjPPbYY6m2p7XvjZ43LxS4Asvvv/+eojvxH3/8QatWrejSpUu6xxQtWpQ9e/Yk38/oUCkRERF38/ffcP/9XlSvXpMOHZwdTcFTpEgRatasmWJboUKFKFGiRKrtIiIikrcKXIElKCgoxf0pU6ZQpUoV7rnnnnSPsVgsycOQRERECqo1a6BTJzh71kJMTDBnzkDp0s6OSkRERMQ1FLgCy9Xi4+NZuHAhw4YNu+6olPPnzxMSEoLD4aB+/fq8/PLL3Hrrrdc9d3aWRMwId1zyzN1yUj6uTfm4NuXjehYssDBggCcJCRbuuCORAQPWUaRIU3Iqpfz8vXE2Zw+HFhEREVOBLrBEREQQHR1N7969092nWrVqvP/++9SuXZuYmBimT59Oo0aN2LVrF+XLl0/3uJxYEjEj3HHJM3fLSfm4NuXj2pSP8zkc8NFHt7B8eVUAGjc+ylNPbcXX15Gj+WRnSUQRERERV1CgCyzz5s3jvvvuo2zZsunu07BhQxo2bJh8v1GjRtSoUYM5c+YwadKkdI/LzpKIGeGOS565W07Kx7UpH9emfFzDxYvQu7cnERFmJ/4xYxIZN640iYktczyf7CyJKCIiIuIKCmyB5dChQ3z33Xd8/vnnmTrO29ubevXqsXfv3uvulxNLImY0nvx0sZ4R7paT8nFtyse1KR/nOX4cHngANm8GHx+YNw969vQEPJOnBeVkPvnl+yIiIiKSnvyxGHcumD9/PqVKleL+++/P1HGJiYns3LmT4ODgXIpMRETEubZtgzvvNIsrJUvC999Dz57OjkpERETEtRXIAovD4WD+/Pn06tULL6+Ug3geffRRRo8enXx/4sSJrF69mv3797NlyxZ69uzJoUOH0lyLW0REJL9buRIaN4ajR6F6dfj1V/O+iIiIiFxfgZwi9N1333H48GH+97//pXrs8OHDeHhcqTudPXuWfv36ERUVRbFixWjQoAEbNmzglltuycuQRUREct3GjeYyzPHx0LIlfPopBAY6OyoRERGR/KFAFlhat26NYRhpPnbtUoevv/46r7/+eh5EJSIi4jxHjsCDD5rFlY4dYdkyUFsUERERkYwrkFOERERE5IqLFyEsDE6ehNq1YeFCFVdEREREMksFFhERkQLMMKB3b9iyxWxo+8UXULiws6MSERERyX9UYBERESnAJk26Mh3o888hNNTZEYmIiEh+smvXLnr27Em5cuXw9fWlbNmy9OjRg127djk7tDynAouIiEgB9dln8MIL5u2334YmTZwbj4iIiOQvn3/+OfXr1+f777+nT58+vPXWW/Tt25cff/yR+vXrs3z5cmeHmKcKZJNbERGRgm7bNnj0UfP24MHQt69TwxEREZF8Zt++fTzyyCNUrlyZdevWERQUlPzY4MGDadKkCY888gg7duygcuXK2Xouh8NBfHw8Vqs1u2HnKo1gERERKWBOnTJXCrp4EVq1gunTnR2RiIiI5DfTpk3j4sWLzJ07N0VxBaBkyZLMmTOHCxcu8MorrwDQu3dvQtOYizx+/HgsFkuKbRaLhUGDBvHxxx9z66234uvry6pVqwBYsmQJDRo0oEiRIhQtWpRatWoxc+bM3EkykzSCRUREpACJi4NOneDwYbj5ZvjkE/DS1YCIiEi+Eh0Nhw5BSAgEBjonhi+//JLQ0FCapDPHuGnTpoSGhrJy5cosnf+HH35g6dKlDBo0iJIlSxIaGkpkZCTh4eG0bNmSqVOnArB7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zahYsSLTp0/n33//JSoqiqioqBT7VK9end9++w2Affv2MWnSJDZv3szBgwdZsWIFjz76KE2bNqV27drOSsWljR0LN90Ex4/D6NHOjkauNnMm/PcfVK0Kjz7q7GhERERERETch1uMYMmoyMhI9u7dy969eylfvnyKxwzDAMx55Xv27Elutufj48N3333HjBkzuHDhAhUqVKBz5848//zzeR5/fuHnB3PnQosW8Pbb0KMH3H23s6OSs2chqZ/zhAngVaB++0VERERERHJXgXqL1bt37xv2agkNDU0utgBUqFCBtWvX5nJk7qd5c+jbF+bNg379YOtWTUdxtunTISYGataEbt2cHY2IiIiIiIh7KVBThCRvTZsGpUvD7t1X+n6Ic5w6ZU4PApg0CbLQekhERERERESuQ2+zJNcUK2auWAPw8stmoUWcY8oUuHABbrsNOnZ0djQiIiIiIiLuRwUWyVVdukD79hAfb04VcjicHVHBc+wYvPWWefvFF8FicW48IiIiIiIi7kgFFslVFov55r5wYfj5Z7PpreStSZMgLg6aNIHWrZ0djYiIiIiIiHtSgUVyXYUKMHWqeXvUKDh0yLnxFCS7dsF775m3NXpFREREREQk96jAInniiSegcWM4f968fdVCTZJLDAOGDYPERHjwQWja1NkRiYiIiIiIuC8VWCRPeHiYIyl8fWHVKli40NkRub9vvoHVq8HbG155xdnRiIiIiIiIuDcVWCTPVKsG48ebt4cMgZMnnRmNe7Pb4ZlnzNuDB8NNNzk3HhEREREREXenAovkqWeegXr14MwZePppZ0fjvt55B/76C4KC4PnnnR2NiIiIiIiI+1OBRfKUtzfMmweenrB0KUREODsi93PmDLzwgnl74kQICHBuPCIiknMOHjxI3759qVSpEn5+flSpUoUXXniB+Ph4Z4cmIiJS4KnAInmuXj0YOdK8PWAAREc7NRy3M3EinD0LNWvCY485OxoREclJf/31Fw6Hgzlz5rBr1y5ef/113nnnHcaMGePs0ERERAo8L2cHIAXTuHHw2Wfw998wYgS8+66zI3IPf/0Fs2ebt197Dbz0Gy4i4lbatm1L27Ztk+9XrlyZPXv28PbbbzN9+nQnRiYiIiJ6+yVOYbWaU4WaNDFXF3r4YS0jnBOGD4eEBGjfHlq1cnY0IiKSF2JiYihevHi6j8fFxREXF5d8PzY2FgC73Y7dbr/uuZMev9F++ZG75uaueYH75uaueYH75uaueYH75paZvLKTuwos4jSNG8PAgeaIi8cfhy1bnB1R/rZ6NaxcaY5a0YeYIiIFw969e3nzzTevO3pl8uTJTJgwIdX21atX4+/vn6HniYyMzHKMrs5dc3PXvMB9c3PXvMB9c3PXvMB9c8tIXhcvXszy+VVgEaeaPBlWrID9+2HCBA/uucfZEeVPCQkwbJh5e9Agc0lsERHJP0aNGsXUqVOvu8/u3bupXr168v1jx47Rtm1bunTpQr9+/dI9bvTo0QxL+iOBOYKlQoUKtG7dmqJFi173Oe12O5GRkbRq1Qpvb+8MZpM/uGtu7poXuG9u7poXuG9u7poXuG9umckraaRnVqjAIk5VpAjMmQPt2sHMmR4EBxejXTtnR5X/vPce7NoFxYub/W1ERCR/eeaZZ+jdu/d196lcuXLy7ePHj9O8eXMaNWrE3Llzr3ucr68vvr6+qbZ7e3tn+OI5M/vmN+6am7vmBe6bm7vmBe6bm7vmBe6bW0byyk7eKrCI0913HzzyCHz0kYUZM+rTrx8EBjo7qvwjOhrGjjVvT5gAxYo5NRwREcmCoKAggoKCMrTvsWPHaN68OQ0aNGD+/Pl4eGhRSBEREVegv8jiEmbOhPLlDY4fL8yIEfqxzIwXX4T//oPq1aF/f2dHIyIiuenYsWM0a9aMihUrMn36dP7991+ioqKIiopydmgiIiIFnkawiEsoVgzefz+RNm08ee89T9q3h44dnR2V69u7F954w7z92mvghqP4RETkKpGRkezdu5e9e/dSvnz5FI8ZhuGkqERERAQ0gkVcSLNmBh077gWgb184ccLJAbk4hwP69QO7Hdq0MadaiYiIe+vduzeGYaT5JSIiIs6lAou4lB49/qJOHYPTp6FPH7OIIGl7+21Yswb8/c2lrkVERERERMR5VGARl+Lt7eDDDxOwWuHbb2HWLGdH5Jr274eRI83bU6dClSrOjUdERERERKSgK3AFltDQUCwWS4qvKVOmXPcYm83GwIEDKVGiBIULF6Zz586cPHkyjyIueGrUgOnTzdsjR8Iffzg3HlfjcJijey5ehGbNYMAAZ0ckIiIiIiIiBa7AAjBx4kROnDiR/PXUU09dd/+hQ4fy5ZdfsmzZMtauXcvx48fp1KlTHkVbMA0YAO3aQVwc9Ohh/ium2bNh3TooVAjmzQOtzikiIiIiIuJ8BXIVoSJFilCmTJkM7RsTE8O8efNYtGgRLVq0AGD+/PnUqFGDX375hbvuuis3Qy2wLBZ4/32oVQt27IAxY+DVV50dlfPt3QvPPmvefuUVqFzZufGIiIiIiIiIqUAWWKZMmcKkSZOoWLEi3bt3Z+jQoXh5pf2t2Lx5M3a7nXvvvTd5W/Xq1alYsSIbN25Mt8ASFxdH3FXDLmJjYwGw2+3Y7fZs55B0jpw4l6u4NqfixWHuXAsPPujFa6/BvfcmcO+9+WeVhJx+jRwO6N3bk0uXPGjWzEHfvonk5cvvbj9zyse1KR/Xlhv5uMv3RkRERAquAldgefrpp6lfvz7Fixdnw4YNjB49mhMnTvDaa6+luX9UVBQ+Pj4EBgam2F66dGmioqLSfZ7JkyczYcKEVNtXr16Nv79/tnK4WmRkZI6dy1VcnZPFAm3b1mbVqkr07GlnxowfKVo0f12E59RrtGJFZX7+uRZWawLh4T+watWlHDlvZrnbz5zycW3Kx7XlZD4XL17MsXOJiIiIOINbFFhGjRrF1KlTr7vP7t27qV69OsOGDUveVrt2bXx8fOjfvz+TJ0/G19c3x2IaPXp0iueKjY2lQoUKtG7dmqJFi2b7/Ha7ncjISFq1aoW3t3e2z+cK0supWTO44w6Dv//24/PP2/LJJ4lYLM6LM6Ny8jX6+29YvNj8dZ0+3UKfPs1zIsRMcbefOeXj2pSPa8uNfJJGeoqIiIjkV25RYHnmmWfo3bv3dfepnE6zijvvvJOEhAQOHjxItWrVUj1epkwZ4uPjiY6OTjGK5eTJk9ft4+Lr65tmwcbb2ztHL65z+nyu4NqcAgJg0SK46y6IiPDgjTc8GD7ciQFmUnZfo8REePxxuHQJ7r0XBgzwxGLxzMEIM8fdfuaUj2tTPq4tJ/Nxp++LiIiIFExuUWAJCgoiKCgoS8du27YNDw8PSpUqlebjDRo0wNvbm++//57OnTsDsGfPHg4fPkzDhg2zHLNkToMGZpPbwYPNpZtvvhkeeMDZUeWNmTNhwwYoUgTee498MXpHRERERESkoClQC7xu3LiRGTNmsH37dvbv38/HH3/M0KFD6dmzJ8WKFQPg2LFjVK9end9++w2AgIAA+vbty7Bhw/jxxx/ZvHkzffr0oWHDhlpBKI899RT07w+GAd27w/btzo4o9+3ZA889Z95+9VUICXFuPCIiIiIiIpI2txjBklG+vr4sWbKE8ePHExcXR6VKlRg6dGiKXil2u509e/akaLb3+uuv4+HhQefOnYmLi6NNmza89dZbzkihQLNY4M03zaWKv/8eOnSA336DDK64ne/Y7dCnD9hs0Lo1PPaYsyMSERERERGR9BSoAkv9+vX55ZdfrrtPaGgohpFyKWCr1crs2bOZPXt2boYnGeDtDcuWmf1Y/v4bOnaENWvAz8/ZkeUsw4ABA2DjRnNq0LvvamqQiIiIiIiIKytQU4TEPRQrBl99Zf7722/wv/+ZBQl3MmWK2W/FwwM+/hgqVnR2RCIiIiIiInI9KrBIvlS1Knz+OXh5wZIlMHGisyPKOYsXw5gx5u2ZM82pUCIiIiIiIuLaVGCRfKtZM3j7bfP2+PHwySfOjCZnrF8PSSuODx0KgwY5NRwRERERERHJIBVYJF977DF45hnzdu/e5pSh/Cqpp0x8PDz4IEyb5uyIREREREREJKNUYJF8b+pUaN/eXG3ngQfgyBFnR5R5//4L7drBmTNwxx2wcCF4ejo7KhEREREREckoFVgk3/P0hEWLoHZtOHkS2rSBw4edHVXGXbpkjlzZtw9CQ2HFCvD3d3ZUIiIiIiIikhkqsIhbKFIEvvwSypeH3bvNZZy3bXN2VDfmcECvXuZyzIGB8PXXULq0s6OS/7d3/8FRlfcexz+bkCxECBESCCkBDFCCEgyWSyS1hFsoIFS5lbEiDBJLoVDQtlAkqQLyq4BSvdWhrddB4N6qFBwEavkREChqIygG1BAZQkEQSKygSSAaEnjuH+muu+Z3NslunrxfM5nxnH3OOc9nT5Z8/c7ZcwAAAACgrmiwwBrdupU3Kvr1ky5ckIYMkXbv9vesqpeeLm3aJIWESK++KvXt6+8ZAQAAAADqgwYLrNK1q/TGG9J//qdUVFR+X5P//V9/z6oiY6T//m/piSfKl9esKX8qEgAAAACgeaLBAutEREg7dkgTJkhlZeVfwVm2rLypEQiuXCl/4tGvflW+vGiRNGmSX6cEAAAAAPARDRZYyemU/u//pLS08uXHHpOmTy9vuPhTTo6UlFR+VU1QkLR8uTR/vn/nBAAAAADwHQ0WWMvVwFi9uvy//+d/pP/6r/IrSPzh5Zel//gPKTtbio6W9u4tbwA5HP6ZDwAAAACg4dBggfV+/nNp82apdWvpb38rv9fJxx833fG/+qp8DhMmlDd3vv/98iccpaQ03RwAAAAAAI2LBgtahLFjy68Y6dhRevddqXdvaeZM6dy5xj1uXl6YUlJa6Y9/LF9+7DEpI4NHMQMAAACAbWiwoMUYPLj8Mc7DhkmlpdIf/iD17Fl+s9n8/IY/3tatDs2ePVRZWQ517Fh+490lS6Tg4IY/FgAAAADAv2iwoEXp3Vvas0fat0+64w6ppKT8cclxcdK8edLFi77t/8wZ6amnpNtvl+69t5WKi0N0++3XlZUljRrVIBEAAAAAAAGIBgtapKFDpQMHpF27pEGDpOJi6YknpB49yp/q88UXtd/X2bPS00+XXyHTvbs0Z4508KAUFGR099252rPnmmJjGykIAAAAACAgtPL3BAB/cTikESOkH/yg/Oa3CxZIWVnS0qXSb38rdeokdelS8Scmpvy1Q4ekjRvLv3bkuc8hQ6R775XuvrtM772XrdDQ7v4LCQAAAABoEjRY0OI5HNIPfyiNHi1t2SItXCh9+KGUl1f+k5VV8/bf+155U2XcuPImjFR+nxcAAAAAQMtAgwX4t6Ag6Z57pB/9qLyxcuHC1z/nz3sv5+WVfx3I1VSJifH37AEAAAAA/kSDBfgGh+PrrwMBAAAAAFAb3OQWAAAAAADARzRYAAAAAAAAfNSiGiz79++Xw+Go9Oedd96pcruhQ4dWGD99+vQmnDkAAAAAAAhkLeoeLMnJybpw4YLXuvnz5+v111/XwIEDq9126tSpWrx4sXs5LCysUeYIAAAAAACanxbVYAkNDVV0dLR7ubS0VFu3btVDDz0kh8NR7bZhYWFe2wIAAAAAALi0qAbLN23btk0XL17Ugw8+WOPYF198UX/+858VHR2tu+66S/Pnz6/2KpaSkhKVlJS4lwsLCyWVN3VKS0t9nrtrHw2xr0BhWybyBDbyBDbyBLbGyGPLewMAAFquFt1gWbNmjUaOHKmuXbtWO27ChAnq3r27YmJi9P7772vevHk6fvy4Nm/eXOU2y5cv16JFiyqsz8jIaNCvF+3evbvB9hUobMtEnsBGnsBGnsDWkHmKi4sbbF8AAAD+YEWDJS0tTStXrqx2TE5OjuLj493Ln3zyiXbt2qWNGzfWuP9p06a5/zshIUFdunTRsGHDdPLkSfXs2bPSbdLT0zV79mz3cmFhoWJjYzVixAiFh4fXeMyalJaWavfu3frBD36gkJAQn/cXCGzLRJ7ARp7ARp7A1hh5XFd6AgAANFdWNFjmzJmj1NTUasfExcV5La9du1YdO3bU3XffXefjJSUlSZJyc3OrbLA4nU45nc4K60NCQhq0uG7o/QUC2zKRJ7CRJ7CRJ7A1ZB6b3hcAANAyWdFgiYqKUlRUVK3HG2O0du1aPfDAA/Uq6I4cOSJJ6tKlS523BQAAaAglJSVKSkrS0aNHlZWVpcTERH9PCQCAFi3I3xPwh7179+rUqVP66U9/WuG1c+fOKT4+XocOHZIknTx5UkuWLNHhw4d1+vRpbdu2TQ888ICGDBmi/v37N/XUAQAAJEmPPPKIYmJi/D0NAADwby2ywbJmzRolJyd73ZPFpbS0VMePH3ffbC80NFR79uzRiBEjFB8frzlz5mjcuHH661//2tTTBgAAkCTt2LFDGRkZWrVqlb+nAgAA/s2KrwjV1UsvvVTlaz169JAxxr0cGxurv//9700xLQAAgBrl5+dr6tSp2rJlS62eTFhSUqKSkhL3suuGwqWlpTU+Htu2R4x7sjWbrbkke7PZmkuyN5utuSR7s9Ully/ZW2SDBQAAoDkyxig1NVXTp0/XwIEDdfr06Rq3Wb58uRYtWlRhfUZGRq0aNJJ9jxj3ZGs2W3NJ9mazNZdkbzZbc0n2ZqtNLte3WeqDBgsAAICfpaWlaeXKldWOycnJUUZGhoqKipSenl7rfaenp2v27Nnu5cLCQsXGxmrEiBEKDw+vdlvbHjHuydZstuaS7M1may7J3my25pLszVaXXK4rPeuDBgsAAICfzZkzR6mpqdWOiYuL0969e5WZmSmn0+n12sCBAzVx4kStX7++wnZOp7PCeKluj9m27RHjnmzNZmsuyd5stuaS7M1may7J3my1yeVLbhosAAAAfhYVFaWoqKgaxz3zzDNaunSpe/n8+fMaOXKk/vKXvygpKakxpwgAAGpAgwUAAKCZ6Natm9dy27ZtJUk9e/ZU165d/TElAADwby3yMc0AAAAAAAANiStYAAAAmqkePXrIGOPvaQAAAHEFCwAAAAAAgM9osAAAAAAAAPiIBgsAAAAAAICPaLAAAAAAAAD4iAYLAAAAAACAj2iwAAAAAAAA+IgGCwAAAAAAgI9osAAAAAAAAPiIBgsAAAAAAICPaLAAAAAAAAD4iAYLAAAAAACAj2iwAAAAAAAA+IgGCwAAAAAAgI9osAAAAAAAAPiIBgsAAAAAAICPaLAAAAAAAAD4yKoGy7Jly5ScnKywsDBFRERUOubMmTMaM2aMwsLC1KlTJ82dO1dlZWXV7vfSpUuaOHGiwsPDFRERoSlTpujy5cuNkAAAAAAAADRHVjVYrl69qnvvvVczZsyo9PVr165pzJgxunr1qv7xj39o/fr1WrdunRYsWFDtfidOnKjs7Gzt3r1br732mg4cOKBp06Y1RgQAAAAAANAMtfL3BBrSokWLJEnr1q2r9PWMjAwdO3ZMe/bsUefOnZWYmKglS5Zo3rx5evzxxxUaGlphm5ycHO3cuVPvvPOOBg4cKEl69tlnNXr0aK1atUoxMTGNlgcAAAAAADQPVjVYapKZmamEhAR17tzZvW7kyJGaMWOGsrOzNWDAgEq3iYiIcDdXJGn48OEKCgrSwYMH9aMf/ajSY5WUlKikpMS9XFBQIKn860alpaU+ZyktLVVxcbEuXryokJAQn/cXCGzLRJ7ARp7ARp7A1hh5ioqKJEnGmAbZH6rmeo8LCwtrHOs614WFhVb87nqyNZutuSR7s9maS7I3m625JHuz1SWX6+9jfWqSFtVgycvL82quSHIv5+XlVblNp06dvNa1atVKHTp0qHIbSVq+fLn7ihpPN910U12nDQBAi1FUVKT27dv7expWczWzYmNj/TwTAAACV31qkoBvsKSlpWnlypXVjsnJyVF8fHwTzah20tPTNXv2bPfy9evXdenSJXXs2FEOh8Pn/RcWFio2NlZnz55VeHi4z/sLBLZlIk9gI09gI09ga4w8xhgVFRXx1dsmEBMTo7Nnz6pdu3Y11iS2/e56sjWbrbkke7PZmkuyN5utuSR7s9Ully81ScA3WObMmaPU1NRqx8TFxdVqX9HR0Tp06JDXuvz8fPdrVW3z6aefeq0rKyvTpUuXqtxGkpxOp5xOp9e6qp5s5Ivw8HCrfvEl+zKRJ7CRJ7CRJ7A1dB6uXGkaQUFB6tq1a522se1315Ot2WzNJdmbzdZckr3ZbM0l2ZuttrnqW5MEfIMlKipKUVFRDbKvwYMHa9myZfr000/dX/vZvXu3wsPDdfPNN1e5zRdffKHDhw/rO9/5jiRp7969un79upKSkhpkXgAAAAAAoHmz6jHNZ86c0ZEjR3TmzBldu3ZNR44c0ZEjR3T58mVJ0ogRI3TzzTdr0qRJOnr0qHbt2qXHHntMM2fOdF9tcujQIcXHx+vcuXOSpL59+2rUqFGaOnWqDh06pLfeekuzZs3S+PHjuYwZAAAAAABIagZXsNTFggULtH79evey66lA+/bt09ChQxUcHKzXXntNM2bM0ODBg3XDDTdo8uTJWrx4sXub4uJiHT9+3OtJPy+++KJmzZqlYcOGKSgoSOPGjdMzzzzTdMEq4XQ6tXDhwgpfQ2rObMtEnsBGnsBGnsBmWx5UzeZzbWs2W3NJ9mazNZdkbzZbc0n2ZmuqXA7D8xABAAAAAAB8YtVXhAAAAAAAAPyBBgsAAAAAAICPaLAAAAAAAAD4iAYLAAAAAACAj2iwBLBly5YpOTlZYWFhioiIqNU2xhgtWLBAXbp0UZs2bTR8+HCdOHHCa8ylS5c0ceJEhYeHKyIiQlOmTHE/yrox1fW4p0+flsPhqPRn06ZN7nGVvb5hw4aAyyNJQ4cOrTDX6dOne405c+aMxowZo7CwMHXq1Elz585VWVlZY0aRVPc8ly5d0kMPPaQ+ffqoTZs26tatmx5++GEVFBR4jWuq87N69Wr16NFDrVu3VlJSkg4dOlTt+E2bNik+Pl6tW7dWQkKCtm/f7vV6bT5LjakueZ5//nl973vf04033qgbb7xRw4cPrzA+NTW1wnkYNWpUY8dwq0uedevWVZhr69atvcY0p/NT2efe4XBozJgx7jH+PD8HDhzQXXfdpZiYGDkcDm3ZsqXGbfbv36/bbrtNTqdTvXr10rp16yqMqetnEv5hW63hyxwCve5wsa3+8NTcaxFPttUlLrbVJ55sq1VcbKpZXAK6djEIWAsWLDBPPfWUmT17tmnfvn2ttlmxYoVp37692bJlizl69Ki5++67zU033WS+/PJL95hRo0aZW2+91bz99tvmjTfeML169TL3339/I6X4Wl2PW1ZWZi5cuOD1s2jRItO2bVtTVFTkHifJrF271mucZ95AyWOMMSkpKWbq1Klecy0oKHC/XlZWZvr162eGDx9usrKyzPbt201kZKRJT09v7Dh1zvPBBx+Ye+65x2zbts3k5uaa119/3fTu3duMGzfOa1xTnJ8NGzaY0NBQ88ILL5js7GwzdepUExERYfLz8ysd/9Zbb5ng4GDzxBNPmGPHjpnHHnvMhISEmA8++MA9pjafpcZS1zwTJkwwq1evNllZWSYnJ8ekpqaa9u3bm08++cQ9ZvLkyWbUqFFe5+HSpUuNnqU+edauXWvCw8O95pqXl+c1pjmdn4sXL3pl+fDDD01wcLBZu3ate4w/z8/27dvNo48+ajZv3mwkmVdffbXa8f/85z9NWFiYmT17tjl27Jh59tlnTXBwsNm5c6d7TF3fI/iPbbWGJ9vqDhfb6g9PzbkW8WRbXeJiW33iybZaxcW2msUlkGsXGizNwNq1a2tV9Fy/ft1ER0ebJ5980r3uiy++ME6n07z88svGGGOOHTtmJJl33nnHPWbHjh3G4XCYc+fONfjcXRrquImJieYnP/mJ17rafKgaWn3zpKSkmF/84hdVvr59+3YTFBTk9Q/0H//4RxMeHm5KSkoaZO6Vaajzs3HjRhMaGmpKS0vd65ri/AwaNMjMnDnTvXzt2jUTExNjli9fXun4H//4x2bMmDFe65KSkszPfvYzY0ztPkuNqa55vqmsrMy0a9fOrF+/3r1u8uTJZuzYsQ091Vqpa56a/s1r7ufn6aefNu3atTOXL192r/Pn+fFUm8/rI488Ym655Ravdffdd58ZOXKke9nX9whNz4Zaw5NtdYeLbfWHp+Zei3iyrS5xsa0+8WRbreJic83iEmi1C18RssipU6eUl5en4cOHu9e1b99eSUlJyszMlCRlZmYqIiJCAwcOdI8ZPny4goKCdPDgwUabW0Mc9/Dhwzpy5IimTJlS4bWZM2cqMjJSgwYN0gsvvKDyz1rj8SXPiy++qMjISPXr10/p6ekqLi722m9CQoI6d+7sXjdy5EgVFhYqOzu74YN4HLchfi8KCgoUHh6uVq1aea1vzPNz9epVHT582Ov3PigoSMOHD3f/3n9TZmam13ip/H12ja/NZ6mx1CfPNxUXF6u0tFQdOnTwWr9//3516tRJffr00YwZM3Tx4sUGnXtl6pvn8uXL6t69u2JjYzV27Fiv3//mfn7WrFmj8ePH64YbbvBa74/zUx81fX4a4j1C4ArkWsOTbXWHi231h6fmXIt4sq0ucbGtPvFkW63iQs3ytaasXVrVPATNRV5eniR5/XF0Lbtey8vLU6dOnbxeb9WqlTp06OAe01hz8/W4a9asUd++fZWcnOy1fvHixfr+97+vsLAwZWRk6Oc//7kuX76shx9+uMHm/031zTNhwgR1795dMTExev/99zVv3jwdP35cmzdvdu+3svPneq2xNMT5+eyzz7RkyRJNmzbNa31jn5/PPvtM165dq/R9++ijjyrdpqr32fNz4lpX1ZjGUp883zRv3jzFxMR4/ZEYNWqU7rnnHt100006efKkfvOb3+jOO+9UZmamgoODGzSDp/rk6dOnj1544QX1799fBQUFWrVqlZKTk5Wdna2uXbs26/Nz6NAhffjhh1qzZo3Xen+dn/qo6vNTWFioL7/8Up9//rnPv8MIXIFca3xznjbVHS621R+emnMt8s052FSXuNhWn3iyrVZxoWb5WlPWLjRYmlhaWppWrlxZ7ZicnBzFx8c30Yx8U9s8vvryyy/10ksvaf78+RVe81w3YMAAXblyRU8++WS9/mg2dh7PP/gJCQnq0qWLhg0bppMnT6pnz5713m9Vmur8FBYWasyYMbr55pv1+OOPe73WkOcHNVuxYoU2bNig/fv3e91sbfz48e7/TkhIUP/+/dWzZ0/t379fw4YN88dUqzR48GANHjzYvZycnKy+ffvqueee05IlS/w4M9+tWbNGCQkJGjRokNf65nR+EPhsqzU82VZ3uNhWf3iiFoFkR33iyeZaxYWapX5osDSxOXPmKDU1tdoxcXFx9dp3dHS0JCk/P19dunRxr8/Pz1diYqJ7zKeffuq1XVlZmS5duuTevi5qm8fX477yyisqLi7WAw88UOPYpKQkLVmyRCUlJXI6nTWO99RUeTznKkm5ubnq2bOnoqOjK9ytOj8/X5IC9vwUFRVp1KhRateunV599VWFhIRUO96X81OZyMhIBQcHu98nl/z8/CrnHh0dXe342nyWGkt98risWrVKK1as0J49e9S/f/9qx8bFxSkyMlK5ubmN+sfQlzwuISEhGjBggHJzcyU13/Nz5coVbdiwQYsXL67xOE11fuqjqs9PeHi42rRpo+DgYJ/POXxjW63hyba6w8W2+sNTS6hFPNlWl7jYVp94sq1WcaFm+VqT1i51umML/KKuN55btWqVe11BQUGlN55799133WN27drVZDe5re9xU1JSKtwRvipLly41N954Y73nWhsN9T6++eabRpI5evSoMebrm8x53q36ueeeM+Hh4earr75quADfUN88BQUF5vbbbzcpKSnmypUrtTpWY5yfQYMGmVmzZrmXr127Zr71rW9VezO5H/7wh17rBg8eXOFmctV9lhpTXfMYY8zKlStNeHi4yczMrNUxzp49axwOh9m6davP861JffJ4KisrM3369DG/+tWvjDHN8/wYU/5vudPpNJ999lmNx2jK8+NJtbxRXL9+/bzW3X///RVuFOfLOUfTs6HW8GRb3eFiW/3hqbnXIp5sq0tcbKtPPNlWq7jYXLO4BFrtQoMlgH388ccmKyvL/YjArKwsk5WV5fWowD59+pjNmze7l1esWGEiIiLM1q1bzfvvv2/Gjh1b6aMTBwwYYA4ePGjefPNN07t37yZ7THN1x/3kk09Mnz59zMGDB722O3HihHE4HGbHjh0V9rlt2zbz/PPPmw8++MCcOHHC/OEPfzBhYWFmwYIFAZcnNzfXLF682Lz77rvm1KlTZuvWrSYuLs4MGTLEvY3rMYkjRowwR44cMTt37jRRUVFN9pjmuuQpKCgwSUlJJiEhweTm5no9qq2srMwY03TnZ8OGDcbpdJp169aZY8eOmWnTppmIiAj30xAmTZpk0tLS3OPfeust06pVK7Nq1SqTk5NjFi5cWOnjEGv6LDWWuuZZsWKFCQ0NNa+88orXeXD9W1FUVGR+/etfm8zMTHPq1CmzZ88ec9ttt5nevXs3SeFc1zyLFi0yu3btMidPnjSHDx8248ePN61btzbZ2dlemZvL+XG54447zH333Vdhvb/PT1FRkfvviyTz1FNPmaysLPPxxx8bY4xJS0szkyZNco93Pepw7ty5Jicnx6xevbrSRx1W9x4hcNhWa3iyre5wsa3+8CVbINUinmyrS+qbK9DrE1+yBXqtUt9cLoFas3jOI1BrFxosAWzy5MlGUoWfffv2ucdI8nou+fXr1838+fNN586djdPpNMOGDTPHjx/32u/FixfN/fffb9q2bWvCw8PNgw8+6FVINZaajnvq1KkK+YwxJj093cTGxppr165V2OeOHTtMYmKiadu2rbnhhhvMrbfeav70pz9VOrah1TXPmTNnzJAhQ0yHDh2M0+k0vXr1MnPnzjUFBQVe+z19+rS58847TZs2bUxkZKSZM2eO16MGAyXPvn37Kv39lGROnTpljGna8/Pss8+abt26mdDQUDNo0CDz9ttvu19LSUkxkydP9hq/ceNG8+1vf9uEhoaaW265xfztb3/zer02n6XGVJc83bt3r/Q8LFy40BhjTHFxsRkxYoSJiooyISEhpnv37mbq1KlN+j+7dcnzy1/+0j22c+fOZvTo0ea9997z2l9zOj/GGPPRRx8ZSSYjI6PCvvx9fqr6LLsyTJ482aSkpFTYJjEx0YSGhpq4uDivv0Mu1b1HCBy21Rp1mUNzqztcbKs/PDX3WsSTbXWJi231iSfbahUXm2oWl0CuXRzGNNFz5QAAAAAAACwV5O8JAAAAAAAANHc0WAAAAAAAAHxEgwUAAAAAAMBHNFgAAAAAAAB8RIMFAAAAAADARzRYAAAAAAAAfESDBQAAAAAAwEc0WAAAAAAAAHxEgwUAAAAAAMBHNFgAAAAAAAB8RIMFAAAAAADARzRYAAAAAAAAfESDBUCLMHHiRDkcDi1durTCa5mZmQoLC1PHjh310Ucf+WF2AACgJaEuAezkMMYYf08CABrbyZMn1bdvX7Vt21anTp1S+/btJUknTpxQcnKyrly5oj179ig5OdnPMwUAALajLgHsxBUsAFqEnj17asqUKfr888/19NNPS5L+9a9/6c4779Tnn3+ul19+mSIGAAA0CeoSwE5cwQKgxTh//rx69eql0NBQZWdna9y4cTp48KCee+45TZs2zd/TAwAALQh1CWAfrmAB0GLExMRo1qxZKigoUGJiog4ePKj58+dTxAAAgCZHXQLYhytYALQoFy5cUNeuXXX9+nWlpqZq7dq1/p4SAABooahLALtwBQuAFsMYo9mzZ+v69euSpFatWvl5RgAAoKWiLgHsQ4MFQIsxd+5cbdiwQaNHj1aXLl20bt06nThxwt/TAgAALRB1CWAfGiwAWoTf//73+t3vfqdBgwZp06ZNSktLU1lZmebPn+/vqQEAgBaGugSwE/dgAWC9TZs26b777lNcXJwyMzMVFRWlr776Sr169dL58+f13nvvKTEx0d/TBAAALQB1CWAvrmABYLUDBw5o0qRJioyM1M6dOxUVFSVJat26tdLT02WM0aOPPurnWQIAgJaAugSwG1ewALDWsWPH9N3vfldXr17V3r17lZSU5PX61atX1atXL509e1ZvvPGG7rjjDj/NFAAA2I66BLAfDRYAAAAAAAAf8RUhAAAAAAAAH9FgAQAAAAAA8BENFgAAAAAAAB/RYAEAAAAAAPARDRYAAAAAAAAf0WABAAAAAADwEQ0WAAAAAAAAH9FgAQAAAAAA8BENFgAAAAAAAB/RYAEAAAAAAPARDRYAAAAAAAAf0WABAAAAAADw0f8D5yFz8ANWcMQAAAAASUVORK5CYII=",
      "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",
    "error=rel_L2_error(output_u.squeeze().detach(),u.squeeze())\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[p.argsort()],f.squeeze()[p.argsort()], c='b')\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.1,1.1)\n",
    "ax.set_ylim(-10,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)$ (Rel. $L^2$ error={0:.4f})'.format(error),fontsize=15)\n",
    "ax.plot(p[p.argsort()],u.squeeze()[p.argsort()], label='Truth', c='r', linewidth=3, linestyle='dashed')\n",
    "ax.plot(p[p.argsort()],output_u.squeeze().detach()[p.argsort()], label=r'Ours', c='b', marker='o', markersize=2.9, linewidth=0.5)\n",
    "ax.legend(fontsize=12)\n",
    "ax.grid()\n",
    "ax.set_xlim(-1.05,1.05)\n",
    "ax.set_ylim(-5,5)\n",
    "ax.set_xlabel(r'$x$',fontsize=15)\n",
    "ax.set_ylabel(r'$u(x)$',fontsize=15)\n",
    "\n",
    "print(\"Error:{}\".format(error))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
