{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3507cf0a-9052-49ba-a0fd-9922fba275e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import torch\n",
    "import numpy as np\n",
    "import scipy.io\n",
    "import h5py\n",
    "import argparse\n",
    "from random import SystemRandom\n",
    "\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.distributions.normal import Normal\n",
    "from torch.distributions import kl_divergence\n",
    "\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "\n",
    "from lib.utils import *\n",
    "from lib.functions import DeepONet1, GRU_unit, Decoder\n",
    "from lib.ProposeModel import *\n",
    "from lib.BaselineModel import *\n",
    "from torch.multiprocessing import Pool\n",
    "\n",
    "matplotlib.font_manager.fontManager.addfont('lib/fonts/times.ttf')\n",
    "\n",
    "# set random seed\n",
    "seed_value = 0\n",
    "np.random.seed(seed_value)\n",
    "random.seed(seed_value)\n",
    "torch.manual_seed(seed_value)\n",
    "if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed_all(seed_value) \n",
    "    torch.backends.cudnn.deterministic = True \n",
    "    torch.backends.cudnn.benchmark = False "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d450541b-7da8-42a3-937d-b565255324bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "s.shape: torch.Size([5000, 100, 64])\n",
      "s_data_tr.shape: torch.Size([4950, 20, 64])\n",
      "t_data_tr.shape: torch.Size([4950, 20])\n",
      "u_data_tr.shape: torch.Size([4950, 64])\n",
      "Ntr: 4950\n"
     ]
    }
   ],
   "source": [
    "experimentID = 600\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "checkpoint = torch.load(\"experiments/experiment_\" + str(experimentID) + '.ckpt')\n",
    "args = checkpoint['args']\n",
    "\n",
    "def read_data():\n",
    "    reader = MatReader(\"data/dataset/data_\" + args.data_version + \".mat\")\n",
    "    Xs = reader.read_field('Xs').permute(0,2,1)\n",
    "    ts = reader.read_field('ts').repeat(Xs.shape[0],1)\n",
    "    xs = reader.read_field('xs')[0]\n",
    "    try:\n",
    "        us = reader.read_field('us')\n",
    "    except:\n",
    "        us = torch.zeros((Xs.shape[0],Xs.shape[2])) \n",
    "    noise = (torch.tensor(np.random.sample(Xs.shape)).float() - 0.5) * 2.0\n",
    "    #noise = torch.tensor(np.random.randn(*Xs.shape)).float()\n",
    "    Xs_noise = Xs + args.noise_weight * noise\n",
    "    \n",
    "    n = 5000\n",
    "    T = 100\n",
    "    s_GT = Xs[:n,:T,:]\n",
    "    s = Xs_noise[:n,:T,:]\n",
    "    us = us[:n]\n",
    "    ts = ts[:n,:T]\n",
    "    \n",
    "    observed_points = int(T*args.obs_ratio)\n",
    "    s_mask = torch.zeros(n, observed_points, len(xs))\n",
    "    t_mask = torch.zeros(n, observed_points)\n",
    "    s_GT_mask = torch.zeros(n, observed_points, len(xs))\n",
    "    mask = np.zeros((n, T), dtype=int)\n",
    "    for i in range(n):\n",
    "        observed_indices = np.random.choice(np.arange(1,T), observed_points-1, replace=False)\n",
    "        sorted_indices = np.sort(observed_indices)\n",
    "        mask[i, 0] = 1\n",
    "        mask[i, observed_indices] = 1\n",
    "        s_mask[i,0] = s[i,0]\n",
    "        s_mask[i,1:] = s[i,sorted_indices]\n",
    "        s_GT_mask[i,0] = s_GT[i,0]\n",
    "        s_GT_mask[i,1:] = s_GT[i,sorted_indices]\n",
    "        t_mask[i,0] = ts[i,0]\n",
    "        t_mask[i,1:] = ts[i,sorted_indices]\n",
    "    mask = torch.tensor(mask)\n",
    "    \n",
    "    Ntr = int(n * 0.99)\n",
    "\n",
    "    s_data_tr = s_mask[:Ntr]; t_data_tr = t_mask[:Ntr]; u_data_tr = us[:Ntr] \n",
    "    s_data_te = s_mask[Ntr:]; t_data_te = t_mask[Ntr:]; u_data_te = us[Ntr:] \n",
    "    test_GT_mask = s_GT_mask[Ntr:]; test_GT = s_GT[Ntr:]; test_noise = s[Ntr:]\n",
    "\n",
    "    print(\"s.shape:\", s.shape)\n",
    "    print(\"s_data_tr.shape:\", s_data_tr.shape)\n",
    "    print(\"t_data_tr.shape:\", t_data_tr.shape)\n",
    "    print(\"u_data_tr.shape:\", u_data_tr.shape)\n",
    "    print(\"Ntr:\", Ntr)\n",
    "    \n",
    "    return(Ntr, s_data_te, t_data_te, u_data_te, xs, ts, mask, test_GT_mask, test_GT, test_noise)\n",
    "\n",
    "Ntr, s_data_te, t_data_te, u_data_te, xs, ts, mask, test_GT_mask, test_GT, test_noise = read_data()\n",
    "args.input_dim = len(xs)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "313ee08b-a675-4528-9fef-1f6665bb2c6c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "###############################################\n",
      "600error: tensor(0.0070)\n",
      "600error_mask: tensor(0.0079)\n",
      "error: tensor(0.0070) +- tensor(0.0169)\n"
     ]
    },
    {
     "data": {
      "image/png": "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y2pF80iQ2aVfTzf7M7OWlws/mtmyV7aywiib2S39DETuQnNXVd1dKzfs0q+X53L6v6kEjwT2zzvmNZps0778poy4JzM3lhzWhK8UtF6FU5YaljGVrb1teMsMXbeB+3VAc590/x27XisNdpDsNrSzvGZb94FNbn4+KL/zZXCbuW4D20axfdKL8klw79V6LjN3GfseYP4OouwzRlYMfI5K/994m5J5W4uyuZEJAADYbdu2TS677DLp1KmTbNu2TebOnZv3kcu33367/POf/5RPPvlELrroIjn88MPTnywAAEAzRu4CAABID9kLAAAAe3AjEwAAjkr5mO3zzz9fvvWtb8m3vvUtueuuu2TSpEly4436E+8ee+wxeeihh+T3v/+9bNmyRYYOHSp/+9vfpF27diWaNQAAQNOVKnuRuwAAQGvDNS8AAID0mE/8LAcfffSRTJ06VTp37iyVlZVy9dVXB59K/C9PP/20fPnLXxYRkcrKSnnvvfekV69eIiJyzTXXSG1traxbt06mTZsmNTVu33xVflsGAIAyp3wv1p+o1q5dKw888ICccMIJIiJywgknyC9+8QvZsmWLVm/u3LlyyimniIhIhw4dpKamRhYsWBDfBgAAAEgRuQsAACAdXPMCAABIj/L92H7iMnLkSDn//PPluuuuk+rqarnlllsK1n3ggQdkyZIlsmTJEvnLX/7SeBPTL3/5S/noo4/k2muvlalTp8qoUaMkZ/laZlPRr2jHjh3ywgsvyNatW4vtCgCAVqmurk42b96s/dTV1QXqPfHEE9K9e3dp06aNiIj06NFDqqur5bnnnmusk81mZdmyZdqdzQMGDJBly5Yl/0KQCrIXAABNR+6CC3IXAADFIXvBBdkLAIDSevbZZ2XlypVyxBFHiMjum8vnzp0rSqlA3TfeeEM+/PBDGTx4sBx//PHy+c9/vnHdddddJ6eeeqqIiBx44IGydetWWbp0qdNcIt/I9NJLL8khhxwiffv2ld/97nciIrJ06VI54IADZNSoUXL88cfLU0895TQ4AADNkcrE+zN79mzp1KmT9jN79uzAuGvWrJGuXbtqy9q3by9r165tLG/cuFF27typ1TProHkgewEAsBu5C0kjdwEAsBvXvJAGshcAALvF+USmqDeQh1m6dGngpvHVq1fLihUrAnXnz58vixYtkt69e8ull14qu3bt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ffZRmzdvdurn6aefVnfccYeqqalxDhdt27ZVr7/+euP4vXv3jtQum81qJ99nnnlGbd++vXH95Zdfrk488cTI7ZVS6vHHH1fHH3+8yuVyBdsVGueZZ55R++23X+Py5557TvXt2zfQl22e9913n/rzn/9cMFgUav/xxx+ryspKVVtb2zj+0KFD876GHTt2aPP63Oc+p5YuXRp5GxZqr1S0bbiHud+47o+F9ruo+2O+ei7742233abmzJnTeGBWym0/zNdeqejbMF89l20YNk6UbViofdRt+P7772vl1atXq9NOOy3yNizU3vbabHN12YZhrzXKNizUPso2vP3229VRRx3VWH7nnXdUVVWVevDBB7XXPWrUKDV27NjI7bdu3aruvvtuddZZZ+WdM4CmK4fcpRTZK+3sRe4K7yPq/ljq3FWobnPJXuWQuwrNlexF9gKS0pyzF7lLb881r8ety6O055rXblzzavm5K6wPsheQjOacu5Qie5nt07rmFdaHUtHPeaXOXYXqcs1rN655tfzsRe5qecriq+WeeOIJ6d69u7Rp00ZERHr06CHV1dXy3HPPRe5j27Zt8sADD8i5557bpDmcdtppMmbMGNmyZYvMnz9fbrnllkjtfF/fhF/4whdkn332aSx/6lOfkr59+0ZuLyIyYcIEGTRokFx44YVywgknyDPPPBOoU2icpUuXSk1NTePyAQMGyOrVq2XFihWR57l27Vp57bXX5Otf/3rBeRdq36NHDxk6dKice+65smvXLlm4cKFcf/31efto06aNeJ4nIrt/f4cddph89atfjbwNC7UXibYN97Qz9xuX/bHQfhd1fyxUz2V/XLBggUyePFl69eold999t4i47Yf52otE34b56rlsw0LjRN2GhdpH3Ybmdlm0aJGceuqpkbdhofZhczPlm6vLNiz0WqNuw0Lto2zDzZs3y5o1axrL++23n9TX10ufPn0a359h269Q+1deeUUuu+wy2X///eXcc8+Vb37zm/Lmm2+Gvg4A0ZRD7hIhe6Wdvchd4XWj7o+lzl2F6jaX7FUOuavQXMleZC8gKc05e5G79PZc8wpfHrU917y45tVacldYH2QvIBnNOXeJkL3M9mld8wrrQyTaNix17gqryzUvrnm1luxF7mqBSn0nlVJKXXfddWrw4MHasr59+6q77rorch9Tp05VH330kVJKNeku6S1btqivfvWr6uCDD1a33XabU1spcBexUkqdeeaZ6vnnn4/c/p///KfyPE/94x//UErt3jYdOnRQH3/8cWgfe8YZO3asOuWUUxqXNzQ0KBFRTz75ZKT2Sil1ySWXNN4dGvbaCrX/4IMP1Gc+8xl1yCGHqD/96U/Wtk8//bQaNmyYGjVqVOBOXbPvKO1dtmG+/cZlfyy030XdHwvVc90fN23apKZNm6Y8z1MPPvhgYL1tG5rto27DQvWibsOwcaJsw7D2TX1Pn3TSSeqTTz4JLI/yXt67vct+mG+uLvthodcadT8s1D7KNnzxxReV7/tqwYIFSiml/vKXvygRUX//+9+1escff7xas2ZN5PZz5sxR3bp1UytXrlRKKTV27FhVU1Ojdu7cmXceAKIrh9ylFNmrVNmrNeeusLou+2OpcpdSLS97lSJ3KUX2InsB6Wru2YvcxTWvvduHLY/anmteXPNqLbkrrA+yF5CM5p67lCJ7me3TvOaVr4+o27DUuSusLte8uObVWrIXuavlKYsnMnme13gX4B719fVSWVkZqf3DDz8sRx11lPTs2bPJc9i5c6ecccYZcvrpp8v48ePl0UcfbXJfe7z77rvSpUsXOfLIIyO3efXVV6Vr165y2GGHiYjIBRdcILlcTn73u99FGsfclvX19SIiodty7/a//OUv5YwzztDuDrUxX+e2bdvkiiuukC9+8Yvy/e9/X/7xj3+Etu/Xr5+cc8458thjj8mPf/zj0L6jtI+6DQvtN1H3x0Lto+6PYfVc98dOnTrJ9OnTZcqUKTJv3jxtXZRtaLaPug0L1VNKRdqGhdovWLAg0jYMm2dT3tO1tbUiItK5c2dtedT38t7tXd7L+ebqclzM197luFhoW0XZhkOGDJEFCxbIT3/6U/nRj34kv/nNb6SiokL69+/fWOcvf/mLHH/88dKnT5/I7SsrK+WAAw5o/IuPiRMnyqpVq2TZsmXW1wMgXDnkLhGyV6myV2vNXba6LvtjqXKXSMvKXqXKXSJkL7IXkK6Wmr3IXVzzCsM1r/LKXSJc8ypF7grrg+wFJKOl5i4Rslca17zy9RFlG5Y6d9nqcs2La16tJXuRu1qg0t5Htds999yjDj74YG1Z27Zt1bJlyyK1P/7441W3bt0af3zfVx07dlTXXntt5DkMHz688c7Iq666SnXv3l1t3bo1UlvJcxdxNptVl112WeP3TUZtf99996nOnTtr6w8//HB1zTXX5G1rjjNr1iw1fPjwxvUfffSREhG1atWqSO0HDBigbUsRUV26dGm8e9HWvr6+Xn3lK19RDQ0NSimlzjvvPDVo0CDrNlBKqV/96lfqkEMOKdh31PZRt2Gh/WbGjBmR9sdC7UUk0v4Ytt82dX/88MMP1cCBAxvLrttwT/uo27BQvauvvjrSNizUvqKiItI2DJtnU7bhvffeq376059qy1y24d7tXd7L+eY6f/78yMfFfO1djouFtlVTtuHIkSO1v9LYtm2buvzyyyN9d+/e7a+99lp1+OGHa+s6d+6s7r333kj9ACisHHKXUmSvUmev1pa7wvpoavZKO3cp1bKyV6lyl1Jkr3ztyV5Acpp79iJ3cc2La156veaYu5Timtfe7UuVu/bug+wFJKO55y6lyF7lcM1r7z6ibMNS566wPrjmxTWv1py9yF3NX1ncyLR27VrVrl07VVdXp5RSas2aNapt27aRD4gff/yxev/99xt/+vbtq+6//35VW1sbqf26detUr169Gsu5XE7169dPLV++PFL7fMHihhtuKPhI2bD2r7/+uhIRtW7dusb1Rx11lFq0aFHetuY4zz77rOrXr19j+emnn9bKtvYffPCBti1FRD3zzDN5H8OYr/3y5cvVF77whcby9u3bVdu2bbXXU8jLL7+svva1rxXsO2r7qNuw0H6zcuXKSPtjWPso+2Oh9qtWrWry/vjxxx+r008/vcnbcE/7qNuwUL1f//rXkbZhWPso27BQ+zvvvLNJ2/B73/teYHu5bMO920fdhoWOP08++WSkbVio/XPPPRdpG4Yd/1y34csvv6zatWunXn31VaXU7mB21VVXqc2bN4dvuDztFy9erNq3b68Fku7du6uXXnopUl8ACit17lKK7FUO2au15a6wPpqavdLOXUq1rOxVitylFNmrUHuyF5Cc5p69yF1c8+KaV/PPXUpxzWvv9qXIXWYfZC8gGc09dylF9iqHa1579xFlG5Y6d4X1wTUvrnm11uxF7moZyuKr5Xr37i0jRoxofITXI488ImPHjg085qyQHj16SN++fRt/MpmM9OjRQzp27BipfdeuXaVNmzayZs2axmXdunWTAQMGWNsqpbT/iojceOONcvDBB0t9fb2sWLFCfvnLX8rbb78dqf3AgQPlhBNOkIULF4qIyKZNm6ShoUFOOumkQNt843Tr1k26dOkib731lojs3pYTJkzIO3a+9lu3btW2pYhIr169pG3btpHaK6Xkgw8+kO3btzfWO+igg6R79+6B9jt37pTnn3++sfynP/1JLr744sjbsFD7qNuw0H5TU1MTaX8Max9lfyzUvm/fvpH3x/Xr18v8+fMlm82KUkpuuukmufrqqyNvw0Lto27DQvXOPPPMSNswrH2UbVio/RlnnOH8nq6vr5cNGzZojyN0eS+b7aNuw0LHnyFDhkTahoXaH3zwwZG2Ydjxz2Ubbtq0Sc477zy566675JBDDhGllEyZMkWOO+442bBhg7zzzjty/fXXy5YtWyK1/9rXviYHHHCA/PnPfxYRkbfeeksGDx4sgwcPztseQHSlzl0iZK9SZK/WnrvC+oiavUqdu0RaTvYqVe4SIXsVak/2ApLTnLMXuYtrXlzzav65S4RrXqXOXfn6IHsByWjOuUuE7FWqa15hfUTZhqXOXWF9cM2La16tMXuRu1qQ5O+VimbdunXqvPPOUzNnzlSXXHJJ412BTVFTU6Mef/xxpzYvvvii+uEPf6huvfVWddVVV6knnnjC2mbLli3qZz/7mRIRNW3aNLVu3To1b948JSLaT6FHHeZrr9TubXH66aerG2+8UV1yySXqtddeC7QNG+ftt99W5557rpo+fbqaNm1a3kesRZ2n5Ln729Z+6dKlaty4cer2229XU6dOVf/4xz/yvv4XX3xR9ezZU33xi19UP/7xj9X999/vNLdC7aNuQ9Pe+01T9sdC+13U/XHvelH3xxUrVqh+/fqpgQMHqh/84AfqlVdeUUpF34aF2u/ZBlG2YaF6UbdhlHHCtmGh9q7v6cWLF6vZs2c3ll3ey/naR31tYXONug2jvNawbViofZR+P/jgA3X33Xer8ePHqxdeeKFx+YQJEwLbb8SIEZHbK6XUO++8o7773e+qefPmqYsvvlitXbs27/wBuCt17lKK7JV29iJ3hfcRZX8sh9wVVrc5Za9S5q6wuZK9yF5AUppj9iJ3cc2rUPsoy8Pqcc2r8LaJ2p5rXrpyzV1hfShF9gKS0hxzl1Jkr1Je8wrrI+o23Fupc5dZl2tehbdN1PZc89KVa/Yid7U8nlJ73doLAAAAAAAAAAAAAAAAACVQFl8tBwAAAAAAAAAAAAAAAKB140YmAAAAAAAAAAAAAAAAACXHjUwAAAAAAAAAAAAAAAAASo4bmQAAAAAAAAAAAAAAAACUHDcyAQAAAAAAAAAAAAAAACg5bmQCAAAAAAAAAAAAAAAAUHLcyAQAAAAAAAAAAAAAAACg5LiRCQAAAAAAAAAAAAAAAEDJcSMTAAAAAAAAAAAAAAAAgJLjRiYAAAAAAAAAAAAAAAAAJceNTAAAAAAAAAAAAAAAAABKjhuZAAAAAAAAAAAAAAAAAJTc/weLt8F3PG2ahAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 3000x500 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#expIDs = [600, 601, 602, 603, 604, 605, 606, 607, 608, 609, 610, 611]\n",
    "expIDs = [600]\n",
    "\n",
    "for ei in range(len(expIDs)):\n",
    "    experimentID = expIDs[ei]\n",
    "    device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "    checkpoint = torch.load(\"experiments/experiment_\" + str(experimentID) + '.ckpt')\n",
    "    args = checkpoint['args']\n",
    "    \n",
    "    if experimentID == 600:\n",
    "        model = RLNO(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 601:\n",
    "        model = DeepONet(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 602:\n",
    "        model = GRUVAE(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 603:\n",
    "        model = GRUDecay(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 604:\n",
    "        model = MLAE_LD(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])   \n",
    "    elif experimentID == 605:\n",
    "        model = LNODE(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 606:\n",
    "        model = Base_PDENET(args, device, xs)\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 607:\n",
    "        model = RLNO_MI(args, device, u_data_te.shape[-1])\n",
    "        model.load_state_dict(checkpoint['state_dict'])\n",
    "    elif experimentID == 608:\n",
    "        model = MIONet(args, device, u_data_te.shape[-1])\n",
    "        model.load_state_dict(checkpoint['state_dict'])    \n",
    "    elif experimentID == 609:\n",
    "        model = LNO_Ab1(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict'])     \n",
    "    elif experimentID == 610:\n",
    "        model = LNO_Ab2(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict']) \n",
    "    elif experimentID == 611:\n",
    "        model = LNO_Ab3(args, device)\n",
    "        model.load_state_dict(checkpoint['state_dict']) \n",
    "        \n",
    "    ## testing\n",
    "    batch_mask = [s_data_te.to(device), t_data_te.to(device), u_data_te.to(device)]\n",
    "    pred_y_mask = model.test(batch_mask).cpu()\n",
    "\n",
    "    if experimentID in [600,609,610,611]:\n",
    "        batch = [s_data_te.to(device), t_data_te.to(device), u_data_te.to(device)]\n",
    "        pred_y = model.test_full(batch, ts[Ntr:].to(device)).cpu()\n",
    "    else:\n",
    "        batch = [test_noise.to(device), ts[Ntr:].to(device), u_data_te.to(device)]\n",
    "        pred_y = model.test(batch).cpu()\n",
    "\n",
    "    index = 4\n",
    "    s = test_noise[index].t().cpu()\n",
    "    s_GT = test_GT[index].t().cpu()\n",
    "    s_mask = s * mask[index].unsqueeze(-1).repeat(1,len(xs)).t()\n",
    "    print(\"###############################################\")\n",
    "    if len(pred_y.shape) == 4:\n",
    "        error = torch.mean((torch.mean(pred_y,axis=0)-test_GT)**2, (1,2))\n",
    "        print(str(experimentID) + \"error:\", torch.mean((torch.mean(pred_y,axis=0)-test_GT)**2))\n",
    "        #print(\"error_before:\", torch.mean((torch.mean(pred_y,axis=0)-test_GT)[:args.rec_len]**2))\n",
    "        #print(\"error_later:\", torch.mean((torch.mean(pred_y,axis=0)-test_GT)[args.rec_len:]**2))\n",
    "        print(str(experimentID) + \"error_mask:\", torch.mean((torch.mean(pred_y_mask,axis=0)-test_GT_mask)**2))\n",
    "        sp = pred_y[0,index].t().cpu().detach().numpy()\n",
    "    else:\n",
    "        error = torch.mean((pred_y-test_GT)**2, (1,2))\n",
    "        print(str(experimentID) + \"error:\", torch.mean((pred_y-test_GT)**2))\n",
    "        #print(\"error_before:\", torch.mean((pred_y-test_GT)[:args.rec_len]**2))\n",
    "        #print(\"error_later:\", torch.mean((pred_y-test_GT)[args.rec_len:]**2))\n",
    "        print(str(experimentID) + \"error_mask:\", torch.mean((pred_y_mask-test_GT_mask)**2))\n",
    "        sp = pred_y[index].t().cpu().detach().numpy()\n",
    "    print(\"error:\",torch.mean(error), \"+-\", torch.std(error)*2)\n",
    "\n",
    "    fig = plt.figure(figsize=(30,5))\n",
    "    ms = 10; ls = 10\n",
    "    font1 = {'family':'Times New Roman', 'weight':'normal','size':ls}\n",
    "    plt.rcParams['font.family'] = 'Times New Roman'\n",
    "    #cmap='viridis'\n",
    "    \n",
    "    ax0 = fig.add_subplot(1,4,1)\n",
    "    data = pd.DataFrame(s_mask)\n",
    "    data.replace(0, np.nan, inplace=True)\n",
    "    s_max = s_GT.max(); s_min = s_GT.min()\n",
    "    #s_max = 0.6; s_min = -1.6\n",
    "    cmap = sns.heatmap(data, center=s.mean(), vmax=s_max, vmin=s_min)\n",
    "    plt.tick_params(labelsize=ls)\n",
    "\n",
    "    ax1 = fig.add_subplot(1,4,2)\n",
    "    data = pd.DataFrame(s_GT)\n",
    "    cmap = sns.heatmap(data, center=s.mean(), vmax=s_max, vmin=s_min)\n",
    "    plt.tick_params(labelsize=ls)\n",
    "\n",
    "    ax2 = fig.add_subplot(1,4,3)\n",
    "    data = pd.DataFrame(sp)\n",
    "    cmap = sns.heatmap(data, center=s.mean(), vmax=s_max, vmin=s_min)\n",
    "    plt.tick_params(labelsize=ls)\n",
    "\n",
    "    ax3 = fig.add_subplot(1,4,4)\n",
    "    data = pd.DataFrame(sp-s_GT.numpy())\n",
    "    cmap = sns.heatmap(data, center=0, vmax=1, vmin=-1)\n",
    "    plt.tick_params(labelsize=ls)\n",
    "    \n",
    "    plt.savefig(\"results/{}.pdf\".format(experimentID))   \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5145d89-c7b8-442d-b1d6-e1ed6cb95005",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27f5210f-1546-4102-a7cc-92331b7ea9cc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b837277-b029-41ea-98ac-26e82917fe45",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45a5295a-bb6d-4dc8-9ad6-f0bffa7a0f8b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "524ea6d3-feb2-4b91-926a-a4113afd9429",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([20000, 64, 100])\n"
     ]
    }
   ],
   "source": [
    "reader = MatReader(\"data/dataset/data_dr.mat\")\n",
    "Xs = reader.read_field('Xs')\n",
    "print(Xs.shape)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d41c9255-a01a-441a-ad19-99dd05abb2fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "ind = 6\n",
    "s = Xs[ind]\n",
    "print(torch.sum((s - Xs[5])**2))\n",
    "fig = plt.figure(figsize=(15,3))\n",
    "ax0 = fig.add_subplot(1,3,1)\n",
    "data = pd.DataFrame(Xs[ind,:,:])\n",
    "data.replace(0, np.nan, inplace=True)\n",
    "cmap = sns.heatmap(data,center=s.mean())\n",
    "\n",
    "ax1 = fig.add_subplot(1,3,2)\n",
    "plt.plot(Xs[ind,0])\n",
    "\n",
    "ax2 = fig.add_subplot(1,3,3)\n",
    "plt.plot(Xs[ind,:,0])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8da8ef2b-138f-48a9-bfbb-9f37408e00f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "us = reader.read_field('us')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2fb58036-710e-4f20-a305-4596c402a932",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3483a00-040d-4016-baa5-0d175d91be27",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ab3cc0a-349c-4f50-9732-4fa5acb5ef0b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6c794df8-7d20-4cc9-bb85-2a47a83462d0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b04516d6-de76-4ae9-812f-60ba0dfe6743",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
