{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "89f30fbc-39be-4902-ba24-25557e4f0950",
   "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",
    "\n",
    "from lib.utils import *\n",
    "from lib.ProposeModel import *\n",
    "from lib.BaselineModel import *\n",
    "\n",
    "# Generative model for noisy data based on ODE\n",
    "parser = argparse.ArgumentParser('Latent Neural Operator')\n",
    "parser.add_argument('--niters', type=int, default=2000)\n",
    "parser.add_argument('--batch_size', type=int, default=50)\n",
    "parser.add_argument('--lr',  type=float, default=1e-2, help=\"Starting learning rate.\")\n",
    "\n",
    "parser.add_argument('--input_dim', type=int, default=1, help=\"Dimensionality of the input system.\")\n",
    "parser.add_argument('--rec_dims', type=int, default=32, help=\"Dimensionality of the recognition model (NO or RNN).\")\n",
    "parser.add_argument('--latents', type=int, default=32, help=\"Size of the latent state\")\n",
    "parser.add_argument('--gru_units', type=int, default=100, help=\"Number of units per layer in each of GRU update networks\")\n",
    "parser.add_argument('--rec_len', type=int, default=20, help=\"The length of observation data\")\n",
    "parser.add_argument('--n_traj_samples', type=int, default=5, help=\"The number of trajectory samples\")\n",
    "parser.add_argument('--noise_weight', type=float, default=0.2, help=\"Noise amplitude for generated traejctories\")\n",
    "\n",
    "if 'ipykernel' in sys.modules:\n",
    "    args = parser.parse_args([])\n",
    "else:\n",
    "    args = parser.parse_args()\n",
    "    \n",
    "#experimentID = int(SystemRandom().random()*100000)+10000\n",
    "experimentID = 10000 + 0\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "file_name = 'LNO'\n",
    "ckpt_path = os.path.join(\"experiments/experiment_\" + str(experimentID) + '.ckpt')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e1546bc5-2558-464e-9464-e0aeaa819696",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dataset.shape: (3000, 100, 2)\n",
      "dataset_GT.shape (3000, 100, 2)\n",
      "test_GT.shape (600, 100, 1)\n",
      "train_size: 2400\n"
     ]
    }
   ],
   "source": [
    "# read dataset\n",
    "def read_data():\n",
    "    dataset_GT = np.load('data/period.npy')\n",
    "    dataset = dataset_GT.copy()\n",
    "    noise = (np.random.sample(dataset.shape[:-1]) - 0.5)*2\n",
    "    dataset[...,0] += args.noise_weight * noise\n",
    "    \n",
    "    train_size = int(dataset.shape[0] * 0.8)\n",
    "    train_dataset = torch.tensor(dataset[:train_size])\n",
    "    test_dataset = torch.tensor(dataset[train_size:])\n",
    "    test_GT = dataset_GT[train_size:,:,:-1]\n",
    "    \n",
    "    print(\"dataset.shape:\", dataset.shape)\n",
    "    print(\"dataset_GT.shape\", dataset_GT.shape)\n",
    "    print(\"test_GT.shape\", test_GT.shape)\n",
    "    print(\"train_size:\", train_size)\n",
    "    return(train_dataset, test_dataset, test_GT)\n",
    "\n",
    "train_dataset, test_dataset, test_GT = read_data()\n",
    "args.input_dim = train_dataset.shape[-1] - 1\n",
    "\n",
    "train_n = train_dataset.shape[0]\n",
    "test_n = test_dataset.shape[0]\n",
    "batch_size = min(args.batch_size, train_n)\n",
    "train_dataloader = DataLoader(train_dataset.to(device), batch_size = args.batch_size, shuffle=True)\n",
    "train_dataloader_iter = iter(train_dataloader)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bf42557f-1b53-42b5-8241-ec58c10e4bcb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f2c3bb73190>]"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACUgAAAGsCAYAAAAFAt/iAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdd1hTVwMG8DcEghPEWXetWveqde+9q34W96iIiqMu3IogwT3RuhX3wFH33lr3wr1H3VtZQgLJ+f6gRFBGAgk3Ce/veXys5ubmpaXk5Nz3niMTQggQERERERERERERERERERERERFZIRupAxAREREREREREREREREREREREZkKC1JERERERERERERERERERERERGS1WJAiIiIiIiIiIiIiIiIiIiIiIiKrxYIUERERERERERERERERERERERFZLRakiIiIiIiIiIiIiIiIiIiIiIjIarEgRUREREREREREREREREREREREVosFKSIiIiIiIiIiIiIiIiIiIiIislq2UgfQh1arxcuXL5ExY0bIZDKp4xARERERERERERERERERERERkcSEEAgODkauXLlgYxP/OlEWUZB6+fIl8ubNK3UMIiIiIiIiIiIiIiIiIiIiIiIyM8+ePUOePHnifdwiClIZM2YEEPXFODg4SJyGiIiIiIiIiIiIiIiIiIiIiIikFhQUhLx58+q6RfGxiIJU9LZ6Dg4OLEgREREREREREREREREREREREZFOdLcoPvFvvkdERERERERERERERERERERERGThWJAiIiIiIiIiIiIiIiIiIiIiIiKrxYIUERERERERERERERERERERERFZLRakiIiIiIiIiIiIiIiIiIiIiIjIarEgRUREREREREREREREREREREREVosFKSIiIiIiIiIiIiIiIiIiIiIislosSBERERERERERERERERERERERkdViQYqIiIiIiIiIiIiIiIiIiIiIiKwWC1JERERERERERERERERERETG5uUFKJWGPUepjHoeEREZFQtSRERERERERERERERERERExiaXA+PG6V+SUiqjjpfLTZuLiCgVspU6ABERERERERERERERERERkdXx8Ij6fdy42H+OS3Q5yts74eOSwssrqnRlyHmVSkCj4WpWRGQ1WJAiIiIiIiIiIiIiIiIiIiIyBX1KUqYsRwFfV7KK7/UTykNEZCVYkCIiIiIiIiIiIiIiIiIiIjKVhEpSpi5HJfb630qJPEREEmBBioiIiIiIiIiIiIiIiIiIyJTiKimlZBnJHFayIiKSEAtSREREREREREREREREREREphazpOTjA6jVKVtGknolKyIiCcmEEELqEIkJCgqCo6MjAgMD4eDgIHUcIiIiIiIiIiIiIiIiIiKipLG3jypHKRSASpXyr/9tGYrlKCKyYPp2iriCFBERERERERERERERERERUUpQKr+Wo9TqqD+ndClJ6pWsiIgkYCN1ACIiIiIiIiIiIiIiIiIiIqsXc6UmlSrq93Hjov4+pXl4fC1pKRQsRxGR1eMKUkRERERERERERERERERERKYU1zZ2MVdyivnnlMoj9UpWREQpiAUpIiIiIiIiIiIiIiIiIiIiU4mrHBVNipLUt3mi/5xSr09EJAEWpIiIiIiIiIiIiIiIiIiIiEwhoXJUtJQsSZnbSlZERCmEBSkiIiIiIiIiIiIiIiIiIiJj06ccFS0lSkrmtpIVEVEKYkGKiIiIiIiIiIiIiIiIiIjI2DQa/cpR0aKP02iMn8XcVrIiIkphLEgREREREREREREREREREREZm5eX4c9J6ZWj4nt9lqSIyMqwIEVERERERERERERERERERGStzGklKyIiiciEEELqEIkJCgqCo6MjAgMD4eDgIHUcIiIiIiIiIiIiIiIiIiIiIiKSmL6dIpsUzERERERERERERERERERERERERJSiWJAiIiIiIiIiIiIiIiIiIiIiIiKrxYIUEaU8Ly9AqTTsOUpl1POIiIiIiIiIiIiIiIiIiIiIDMCCFBGlPLkcGDdO/5KUUhl1vFxu2lxEREREREREREREREREFD8uhEBEFooFKSJKeR4egLe3fiWp6HKUt3fU84iIiIiIiIiIiIiIiIhSC3MrJHEhBCKyULZSByCiVCq67DRuXOw/x8RyFBEREREREREREREREaVm0YUkQL/rZTGvr5mCPtf44srCa31EJDEWpIhIOgkNoDhgIiIiIiIiIiIiIiIiotTOHAtJXAiBiCwQC1JEJK24BlAcMBERERERERERWT4vr6gVDwyZ31EqAY3GdFvCEBEREVkicywkcSEEIrIwBhWkJk2ahL///ht37txB2rRpUbVqVUyZMgVFihRJ8HmbNm2Ch4cHnjx5gsKFC2PKlClo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O++8w0lrAGlagQIFNHjwYElS7969devWrYgH7CxUAHASvr6Su7tksUT8HsvX8ldffaULFy7o+eef19ChQw0ICQAph8lk0uKiRRUgyVfS4lde+fdG0QvkW7fG/r6S95tIRBSkAACIRZs2bVSjRo2ou364AAikLdevX49aPiogIEDPP/+8wYkAwHgmk0nTp09XhgwZtGPHDs2ePdvoSACSW0CAzEOGyFfS1GzZoibLSeKkNYA0rVevXipatKhu3rwZcyliOwoVAJxEQMDjr2WL5V/HO6dPn9bo0aMlSZMmTVKmTJmMSAkAKUr2LFm0o1YtDZP0+eef6/bt248fjG26ZuT7Sqs15hPxfhOJhIIUAACxiLwA6OHhoY0bN2rx4sVGRwKQjL744gv9888/KlOmjLp27Wp0HABIMQoWLKiARyeievfuratXrxqcCECyeXTyeqirq4ZJGjt2rHLmzBlzG05aA0ij3NzcNH36dEnSt99+q927d0c8kEChAoCTiH4RPyTkX8c7NptNnTt3VmhoqBo0aKCGDRsaHBgAUgh/f1Vev16FCxfWjRs3NGDAgMePWa2xT9f09ZX8/f/9XHGVpwAHmGxOMBIjKChIXl5eunPnjjw9PY2OAwBIQ4YNGyZfX1/lyJFDZ8+eVbZs2YyOBCCJ/fjjj6pTp45cXFy0f/9+lStXzuhIAJCihIWFqVKlSjp8+LA++OADLV261OhIAJLao4uC8woVUuvz51WrVi39+OOPMplM8W7PUlIA0poOHTpo1qxZKlq0qI598IFchwx5/L2Q742Ac4rrazfax+c8/7zatm2rDBky6PTp03rxxReNywsAKdDOnTtVo0YNSdKePXtUuXJlYwMh1bG3U8QEKQAA4tG3b18VKVJEf/31l/r06WN0HABJLDg4WD4+PpKkLl26UI4CgFi4urpq1qxZMpvNWrZsmVatWmV0JABJzWrVsfffV+vz55UuXTpNnz497nKUxJ29ANKskSNH6rnnnlPjU6dilqMkpuwBzii+YmO0r+lrXbpIkvz9/SlHAUAsqlevrtatW0uSOnXqpNDQUGMDIc1ighQAAAnYs2ePqlatKknatm2batasaXAiAEnFz89PAQEByps3r86cOcOxJwDEY8CAARo5cqTy5s2r06dPy8vLy+hIAJLIzZs3VbhwYd26dUvDhw+PuSwCACCGo02a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rZOnp6d++uknVapUSWfPnjU6VtoQvdQUEhLxu5+fgvr0UdWNG+UrKUDSgQYNNHHiRMpRAAA8DV/fx+Uod/dn/llZt25dnTx5Up06dZIkBQYGqlixYtq8eXNipEUCVq1apbfeeku3b99WpUqVtGvXrvjLUQEBj//tLZaIPwMAgCRTvHhxHThwQG+++abu3r2rBg0aaPTo0XKCe/5TnH/++Ufff/+9WrdurTx58qh8+fIaPHiwDhw4IJvNplKlSmngwIH6+eef1bt/fzU9cUKfXLhgfznKz08ym5P+EwEAAHhGFKQAAECiqVu3rvbs2aMCBQro/PnzqlSpkn788UejY6VusZWafH31v86d5TlmjOoePKip2bLp9zZtVH7Nmrgv5lGOAgAgfklQkPH09NS0adO0detWFShQQJcvX1bdunXVvn173blzJxFC40l3795Vhw4d1KhRIz148EDvvPOOfvzxR2XLli3uneIoo1OSAgAgaeXIkUNbtmxRx44dZbPZ1LdvX3366acKDg42OlqKZrPZdOLECX399deqXr26nnvuOTVr1kzz5s3TjRs3lDlzZr3//vuaNWuWrly5oqNHj2rYsGGqUqWKzIMH23+sw7kkAADgZFhiDwAAJLq//vpLjRo10p49e2Q2mzVlypSo6QhIRHGciFq6dKk+/fRTffHwoQIk3erRQ9nHj4/7xBUntAAAiN+TPyuT4GfnvXv39OWXX2rSpEmSpHz58mn69OksJZOIfv75Z7Vs2VIXLlyQyWRSr169NHz4cLm7u8e9U1z/1jVrSjt2OPb/AMvPAADwVGw2m6ZMmaLPP/9cVqtVFStW1A8//KA8efIYHS3FuHfvnrZu3ar169dr/fr1unLlSozHX3/9ddWvX1/16tVT1apV4z/+kRI+3uVcEgAASEHs7RTFsb4KAADA08uRI4e2bt2qDh06aMGCBercubPOnj2rMWPGyMzI7cQRy4mo8PBwDR06VEOGDJEkHX73XQWXLq3sw4dL2bM/PmHl5xfxexJd4AUAIFWJY1qjpJg/U59RpkyZNHHiRDVt2lRt27bVb7/9pvfee08tW7bU+PHj459whHhZLBYNHjxYo0aNUnh4uF544QV99913ql69evw7xnecVKtWREHK3v8Hoj8XAABwiMlkUteuXfX666+radOm2r9/v8qXL69Vq1apbNmyRscz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",
      "text/plain": [
       "<Figure size 3000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(30,5))\n",
    "index = 5\n",
    "plt.plot(test_dataset[index,:,-1], test_GT[index,:,0], 'k-')\n",
    "plt.plot(test_dataset[index,:,-1].cpu(), test_dataset[index,:,0].cpu(), 'rx', markersize=10)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f69ff376-e6f7-4158-9f0b-dabab0457542",
   "metadata": {},
   "outputs": [],
   "source": [
    "## Training\n",
    "model = LatentNO_GRU(args, device)\n",
    "#model = LNO_Ab1(args, device)\n",
    "#model = LNO_Ab2(args, device)\n",
    "#model = LNO_Ab3(args, device)\n",
    "#model = LNO_Ab4(args, device)\n",
    "#model = LNO_Ab5(args, device)\n",
    "#model = Vanilla_DeepONet1(args, device)\n",
    "#model = Vanilla_DeepONet2(args, device)\n",
    "#model = Base_LODEGRU(args, device)\n",
    "#model = Base_GRUDecay(args, device)\n",
    "#model = Base_GRUVAE(args, device)\n",
    "#model = Base_MLAE(args, device)\n",
    "\n",
    "\n",
    "log_path = \"logs/\" + file_name + \"_\" + str(experimentID) + \".log\"\n",
    "if not os.path.exists(\"logs/\"):\n",
    "    utils.makedirs(\"logs/\")\n",
    "logger = get_logger(logpath=log_path, filepath='work/LNO_/LNO_1.0.ipynb')\n",
    "\n",
    "optimizer = optim.Adamax(model.parameters(), lr = args.lr)\n",
    "\n",
    "num_batches = len(train_dataloader)\n",
    "\n",
    "for itr in range(1, num_batches * (args.niters + 1)):\n",
    "    optimizer.zero_grad()\n",
    "    update_learning_rate(optimizer, decay_rate = 0.999, lowest = args.lr / 10)\n",
    "    \n",
    "    wait_until_kl_inc = 10\n",
    "    if itr // num_batches < wait_until_kl_inc:\n",
    "        kl_coef = 0.\n",
    "    else:\n",
    "        kl_coef = (1-0.99** (itr // num_batches - wait_until_kl_inc))\n",
    "    \n",
    "    try:\n",
    "        batch = next(train_dataloader_iter)\n",
    "    except StopIteration:\n",
    "        train_dataloader_iter = iter(train_dataloader)\n",
    "        batch = next(train_dataloader_iter)\n",
    "        \n",
    "    train_res, pred_y = model.compute_all_losses(batch, kl_coef = kl_coef)\n",
    "    train_res[\"loss\"].backward()\n",
    "    optimizer.step()\n",
    "    \n",
    "    n_iters_to_viz = 1\n",
    "    if itr % (n_iters_to_viz * num_batches) == 0:\n",
    "        with torch.no_grad():\n",
    "            model.TestInfo(experimentID, test_dataset.to(device), train_res, itr, num_batches, kl_coef, logger)\n",
    "\n",
    "        torch.save({'args': args,'state_dict': model.state_dict(),}, ckpt_path)\n",
    "\n",
    "torch.save({'args': args,'state_dict': model.state_dict(),}, ckpt_path)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "48e7c66d-ee9e-43c0-8862-07ad2b191b99",
   "metadata": {},
   "outputs": [],
   "source": [
    "## testing\n",
    "model = LatentNO_GRU(args, device)\n",
    "model.load_state_dict(torch.load('experiments/experiment_{}.ckpt'.format(experimentID))['state_dict'])\n",
    "\n",
    "batch = test_dataset[:10]\n",
    "batch_GT = test_GT[:10]\n",
    "pred_y = model.test(batch.to(device)).cpu()\n",
    "\n",
    "time_full = torch.linspace(0,5,200).unsqueeze(0).repeat(batch.shape[0],1)\n",
    "pred_full = model.test_full(batch.to(device), time_full.to(device)).cpu()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d13c41f7-bd96-431a-bc46-6da1b6c11477",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "Error(s) in loading state_dict for Base_GRUVAE:\n\tUnexpected key(s) in state_dict: \"rnn_cell_enc.decay.0.weight\", \"rnn_cell_enc.decay.0.bias\", \"rnn_cell_dec.decay.0.weight\", \"rnn_cell_dec.decay.0.bias\". \n\tsize mismatch for rnn_cell_enc.weight_ih: copying a param with shape torch.Size([96, 2]) from checkpoint, the shape in current model is torch.Size([96, 3]).\n\tsize mismatch for rnn_cell_dec.weight_ih: copying a param with shape torch.Size([96, 2]) from checkpoint, the shape in current model is torch.Size([96, 3]).",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[7], line 10\u001b[0m\n\u001b[1;32m      8\u001b[0m preds \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m      9\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;28mlen\u001b[39m(exps)):\n\u001b[0;32m---> 10\u001b[0m     \u001b[43mmodels\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload_state_dict\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mexperiments/experiment_\u001b[39;49m\u001b[38;5;132;43;01m{}\u001b[39;49;00m\u001b[38;5;124;43m.ckpt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mformat\u001b[49m\u001b[43m(\u001b[49m\u001b[43mexps\u001b[49m\u001b[43m[\u001b[49m\u001b[43mi\u001b[49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mstate_dict\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     11\u001b[0m     pred_y \u001b[38;5;241m=\u001b[39m models[i]\u001b[38;5;241m.\u001b[39mtest(batch\u001b[38;5;241m.\u001b[39mto(device))\u001b[38;5;241m.\u001b[39mcpu()\n\u001b[1;32m     12\u001b[0m     preds\u001b[38;5;241m.\u001b[39mappend(pred_y)\n",
      "File \u001b[0;32m/environment/miniconda3/lib/python3.10/site-packages/torch/nn/modules/module.py:2041\u001b[0m, in \u001b[0;36mModule.load_state_dict\u001b[0;34m(self, state_dict, strict)\u001b[0m\n\u001b[1;32m   2036\u001b[0m         error_msgs\u001b[38;5;241m.\u001b[39minsert(\n\u001b[1;32m   2037\u001b[0m             \u001b[38;5;241m0\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mMissing key(s) in state_dict: \u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m. \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(\n\u001b[1;32m   2038\u001b[0m                 \u001b[38;5;124m'\u001b[39m\u001b[38;5;124m, \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mjoin(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(k) \u001b[38;5;28;01mfor\u001b[39;00m k \u001b[38;5;129;01min\u001b[39;00m missing_keys)))\n\u001b[1;32m   2040\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(error_msgs) \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m:\n\u001b[0;32m-> 2041\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mError(s) in loading state_dict for \u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\t\u001b[39;00m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(\n\u001b[1;32m   2042\u001b[0m                        \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__class__\u001b[39m\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__name__\u001b[39m, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\t\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;241m.\u001b[39mjoin(error_msgs)))\n\u001b[1;32m   2043\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m _IncompatibleKeys(missing_keys, unexpected_keys)\n",
      "\u001b[0;31mRuntimeError\u001b[0m: Error(s) in loading state_dict for Base_GRUVAE:\n\tUnexpected key(s) in state_dict: \"rnn_cell_enc.decay.0.weight\", \"rnn_cell_enc.decay.0.bias\", \"rnn_cell_dec.decay.0.weight\", \"rnn_cell_dec.decay.0.bias\". \n\tsize mismatch for rnn_cell_enc.weight_ih: copying a param with shape torch.Size([96, 2]) from checkpoint, the shape in current model is torch.Size([96, 3]).\n\tsize mismatch for rnn_cell_dec.weight_ih: copying a param with shape torch.Size([96, 2]) from checkpoint, the shape in current model is torch.Size([96, 3])."
     ]
    }
   ],
   "source": [
    "batch = test_dataset[:10]\n",
    "batch_GT = test_GT[:10]\n",
    "\n",
    "exps = [10000, 301, 302, 302, 304, 500]\n",
    "models = [LatentNO_GRU(args, device), Vanilla_DeepONet1(args, device), Base_GRUDecay(args, device),\\\n",
    "          Base_GRUVAE(args, device), Base_MLAE(args, device), Base_LODEGRU(args, device)]\n",
    "\n",
    "preds = []\n",
    "for i in range(len(exps)):\n",
    "    models[i].load_state_dict(torch.load('experiments/experiment_{}.ckpt'.format(exps[i]))['state_dict'])\n",
    "    pred_y = models[i].test(batch.to(device)).cpu()\n",
    "    preds.append(pred_y)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be9b460c-7244-4ccc-a524-bfacab536b13",
   "metadata": {},
   "outputs": [],
   "source": [
    "index = 1\n",
    "s_GT = test_GT[index]\n",
    "s = batch[index,:,0]\n",
    "t = batch[index,:,-1]\n",
    "\n",
    "if len(pred_y.shape) == 4:\n",
    "    ps = pred_y[0,index]\n",
    "    ps_full = pred_full[0,index]\n",
    "    msei = torch.mean((torch.mean(pred_y,axis=0)-batch_GT)**2)\n",
    "else:\n",
    "    ps = pred_y[index]\n",
    "    ps_full = pred_full[index]\n",
    "    msei = torch.mean((pred_y-batch_GT)**2)\n",
    "print(msei)\n",
    "\n",
    "fig = plt.figure(figsize=(30,5))\n",
    "plt.plot(t, s, 'ko', markersize=8)\n",
    "#plt.plot(t, s_GT, 'k-')\n",
    "#plt.plot(time_full[index], ps_full, 'rx', markersize=5)\n",
    "for i in range(len(exps)):\n",
    "    pred_y = preds[i]\n",
    "    if len(pred_y.shape) == 4:\n",
    "        plt.plot(t, pred_y[0,index])\n",
    "    else:\n",
    "        plt.plot(t, pred_y[index])\n",
    "\n",
    "plt.savefig(\"results/{}.png\".format(experimentID))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "018f8175-47b3-4344-9f39-38562bb94830",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbd2d6b9-002e-4183-8daf-65bc6b032806",
   "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
