{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:0\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.optim as optim\n",
    "import torch.optim.lr_scheduler as lr_scheduler\n",
    "\n",
    "from src.models import *\n",
    "from src.utils import *\n",
    "from src.utils_data import *\n",
    "import argparse\n",
    "import time\n",
    "import logging\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")\n",
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "graph_type = 'WS'\n",
    "graph_size = 50\n",
    "num_unroll = 20\n",
    "\n",
    "logging.basicConfig(filename='logs/L2G_{}_m{}_x{}.log'.format(graph_type, graph_size, num_unroll),\n",
    "                    filemode='w',\n",
    "                    format='%(asctime)s - %(message)s',\n",
    "                    datefmt='%d-%b-%y %H:%M:%S',\n",
    "                    level=logging.INFO)\n",
    "\n",
    "console = logging.StreamHandler()\n",
    "console.setLevel(logging.INFO)\n",
    "formatter = logging.Formatter('%(asctime)s | %(message)s', datefmt='%d-%b-%y %H:%M:%S')\n",
    "console.setFormatter(formatter)\n",
    "logging.getLogger().addHandler(console)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "graph_type = 'WS'\n",
    "edge_type = 'lognormal'\n",
    "graph_size = 50\n",
    "\n",
    "graph_hyper = {'k': 5,\n",
    "               'p': 0.2}\n",
    "\n",
    "\n",
    "data = generate_WS_parallel(num_samples=8064,\n",
    "                            num_signals=3000,\n",
    "                            num_nodes=graph_size,\n",
    "                            graph_hyper=graph_hyper,\n",
    "                            weighted=edge_type,\n",
    "                            weight_scale=True)\n",
    "\n",
    "\n",
    "with open('data/dataset_{}_{}nodes.pickle'.format(graph_type, graph_size), 'wb') as handle:\n",
    "    pickle.dump(data, handle, protocol=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loading data at  data/dataset_WS_50nodes.pickle\n",
      "successfully loading: train 6400, val 1600, test 64, batch 32\n"
     ]
    }
   ],
   "source": [
    "batch_size = 32\n",
    "\n",
    "data_dir = 'data/dataset_{}_{}nodes.pickle'.format(graph_type, graph_size)\n",
    "train_loader, val_loader, test_loader = data_loading(data_dir, batch_size=batch_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "for _, W in test_loader:\n",
    "    eg = torch_sqaureform_to_matrix(W, device='cpu')\n",
    "\n",
    "plt.figure()\n",
    "sns.heatmap(eg[4])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "04-Jun-21 11:31:29 | learn2graph(\n",
      "  (vae): TopoDiffVAE(\n",
      "    (enc): GraphEnc(\n",
      "      (conv1): GraphConvLayer()\n",
      "      (conv2): GraphConvLayer()\n",
      "      (fc1): Linear(in_features=64, out_features=32, bias=True)\n",
      "      (fc2): Linear(in_features=32, out_features=16, bias=True)\n",
      "    )\n",
      "    (f_mean): Sequential(\n",
      "      (0): Linear(in_features=16, out_features=16, bias=True)\n",
      "    )\n",
      "    (f_var): Sequential(\n",
      "      (0): Linear(in_features=16, out_features=16, bias=True)\n",
      "    )\n",
      "    (dec): Sequential(\n",
      "      (0): Linear(in_features=1241, out_features=1633, bias=True)\n",
      "      (1): Tanh()\n",
      "      (2): Linear(in_features=1633, out_features=1225, bias=True)\n",
      "    )\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "num_unroll = 20\n",
    "graph_size = 50\n",
    "n_hid = 32\n",
    "n_latent = 16\n",
    "n_nodeFeat = 1\n",
    "n_graphFeat = 16\n",
    "\n",
    "lr = 1e-02\n",
    "lr_decay = 0.95\n",
    "\n",
    "net = learn2graph(num_unroll, graph_size, n_hid,\n",
    "                  n_latent, n_nodeFeat, n_graphFeat).to(device)\n",
    "\n",
    "optimizer = optim.Adam(net.parameters(), lr=lr)\n",
    "scheduler = lr_scheduler.ExponentialLR(optimizer, lr_decay)\n",
    "\n",
    "logging.info(net)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "04-Jun-21 11:31:59 | Epoch 0001 | lr: 0.00902500 | Time(s): 30.2504\n",
      "04-Jun-21 11:31:59 | == train Loss <unroll: 293.2162 | vae : 1196304220.8786 | kl : 1196301420.3438>\n",
      "04-Jun-21 11:31:59 | == gmse <train: 265.0365 | val: 0.6475> \n",
      "04-Jun-21 11:32:29 | Epoch 0002 | lr: 0.00857375 | Time(s): 30.1442\n",
      "04-Jun-21 11:32:29 | == train Loss <unroll: 33.6657 | vae : 3.2337 | kl : 0.0081>\n",
      "04-Jun-21 11:32:29 | == gmse <train: 1.4905 | val: 0.5639> \n",
      "04-Jun-21 11:32:59 | Epoch 0003 | lr: 0.00814506 | Time(s): 30.1208\n",
      "04-Jun-21 11:32:59 | == train Loss <unroll: 26.2211 | vae : 3.7908 | kl : 0.0079>\n",
      "04-Jun-21 11:32:59 | == gmse <train: 1.0757 | val: 0.6086> \n",
      "04-Jun-21 11:33:29 | Epoch 0004 | lr: 0.00773781 | Time(s): 30.0819\n",
      "04-Jun-21 11:33:29 | == train Loss <unroll: 21.8958 | vae : 4.5856 | kl : 0.0077>\n",
      "04-Jun-21 11:33:29 | == gmse <train: 0.9735 | val: 0.6034> \n",
      "04-Jun-21 11:33:59 | Epoch 0005 | lr: 0.00735092 | Time(s): 30.0788\n",
      "04-Jun-21 11:33:59 | == train Loss <unroll: 18.7120 | vae : 6.3110 | kl : 0.0074>\n",
      "04-Jun-21 11:33:59 | == gmse <train: 1.0008 | val: 0.7405> \n",
      "04-Jun-21 11:34:29 | Epoch 0006 | lr: 0.00698337 | Time(s): 30.0895\n",
      "04-Jun-21 11:34:29 | == train Loss <unroll: 16.9451 | vae : 10.1764 | kl : 0.0071>\n",
      "04-Jun-21 11:34:29 | == gmse <train: 1.2590 | val: 0.9805> \n",
      "04-Jun-21 11:34:59 | Epoch 0007 | lr: 0.00663420 | Time(s): 30.0516\n",
      "04-Jun-21 11:34:59 | == train Loss <unroll: 15.2084 | vae : 17.3656 | kl : 0.0069>\n",
      "04-Jun-21 11:34:59 | == gmse <train: 1.8049 | val: 1.7118> \n",
      "04-Jun-21 11:35:29 | Epoch 0008 | lr: 0.00630249 | Time(s): 30.0421\n",
      "04-Jun-21 11:35:29 | == train Loss <unroll: 14.1498 | vae : 25.8545 | kl : 0.0067>\n",
      "04-Jun-21 11:35:29 | == gmse <train: 2.4321 | val: 2.0015> \n",
      "04-Jun-21 11:35:59 | Epoch 0009 | lr: 0.00598737 | Time(s): 30.0294\n",
      "04-Jun-21 11:35:59 | == train Loss <unroll: 13.2069 | vae : 31.5170 | kl : 0.0064>\n",
      "04-Jun-21 11:35:59 | == gmse <train: 2.7835 | val: 2.7919> \n",
      "04-Jun-21 11:36:29 | Epoch 0010 | lr: 0.00568800 | Time(s): 30.0215\n",
      "04-Jun-21 11:36:29 | == train Loss <unroll: 12.3297 | vae : 34.9053 | kl : 0.0061>\n",
      "04-Jun-21 11:36:29 | == gmse <train: 2.9200 | val: 2.1923> \n",
      "04-Jun-21 11:36:59 | Epoch 0011 | lr: 0.00540360 | Time(s): 30.0136\n",
      "04-Jun-21 11:36:59 | == train Loss <unroll: 11.5069 | vae : 37.0054 | kl : 0.0058>\n",
      "04-Jun-21 11:36:59 | == gmse <train: 2.9357 | val: 2.7941> \n",
      "04-Jun-21 11:37:29 | Epoch 0012 | lr: 0.00513342 | Time(s): 30.0085\n",
      "04-Jun-21 11:37:29 | == train Loss <unroll: 10.3005 | vae : 36.3894 | kl : 0.0055>\n",
      "04-Jun-21 11:37:29 | == gmse <train: 2.7597 | val: 2.2855> \n",
      "04-Jun-21 11:37:59 | Epoch 0013 | lr: 0.00487675 | Time(s): 30.0025\n",
      "04-Jun-21 11:37:59 | == train Loss <unroll: 10.5843 | vae : 35.7628 | kl : 0.0053>\n",
      "04-Jun-21 11:37:59 | == gmse <train: 2.6650 | val: 2.3674> \n",
      "04-Jun-21 11:38:29 | Epoch 0014 | lr: 0.00463291 | Time(s): 29.9983\n",
      "04-Jun-21 11:38:29 | == train Loss <unroll: 9.3043 | vae : 33.5255 | kl : 0.0050>\n",
      "04-Jun-21 11:38:29 | == gmse <train: 2.3839 | val: 2.1159> \n",
      "04-Jun-21 11:38:59 | Epoch 0015 | lr: 0.00440127 | Time(s): 29.9948\n",
      "04-Jun-21 11:38:59 | == train Loss <unroll: 7.4115 | vae : 30.9318 | kl : 0.0048>\n",
      "04-Jun-21 11:38:59 | == gmse <train: 2.0796 | val: 1.9852> \n",
      "04-Jun-21 11:39:29 | Epoch 0016 | lr: 0.00418120 | Time(s): 30.0102\n",
      "04-Jun-21 11:39:29 | == train Loss <unroll: 6.6917 | vae : 28.7482 | kl : 0.0046>\n",
      "04-Jun-21 11:39:29 | == gmse <train: 1.8720 | val: 1.7729> \n",
      "04-Jun-21 11:39:59 | Epoch 0017 | lr: 0.00397214 | Time(s): 30.0162\n",
      "04-Jun-21 11:39:59 | == train Loss <unroll: 6.1999 | vae : 26.6255 | kl : 0.0043>\n",
      "04-Jun-21 11:39:59 | == gmse <train: 1.6912 | val: 1.6102> \n",
      "04-Jun-21 11:40:29 | Epoch 0018 | lr: 0.00377354 | Time(s): 30.0134\n",
      "04-Jun-21 11:40:29 | == train Loss <unroll: 5.8382 | vae : 25.1298 | kl : 0.0041>\n",
      "04-Jun-21 11:40:29 | == gmse <train: 1.5562 | val: 1.4399> \n",
      "04-Jun-21 11:40:59 | Epoch 0019 | lr: 0.00358486 | Time(s): 30.0029\n",
      "04-Jun-21 11:40:59 | == train Loss <unroll: 5.4945 | vae : 22.9848 | kl : 0.0039>\n",
      "04-Jun-21 11:40:59 | == gmse <train: 1.4046 | val: 1.3590> \n",
      "04-Jun-21 11:41:29 | Epoch 0020 | lr: 0.00340562 | Time(s): 30.0090\n",
      "04-Jun-21 11:41:59 | Epoch 0021 | lr: 0.00323534 | Time(s): 30.0042\n",
      "04-Jun-21 11:41:59 | == train Loss <unroll: 4.9609 | vae : 19.6908 | kl : 0.0036>\n",
      "04-Jun-21 11:41:59 | == gmse <train: 1.1857 | val: 1.1361> \n",
      "04-Jun-21 11:43:59 | Epoch 0025 | lr: 0.00263520 | Time(s): 30.0006\n",
      "04-Jun-21 11:43:59 | == train Loss <unroll: 4.2220 | vae : 14.7988 | kl : 0.0031>\n",
      "04-Jun-21 11:43:59 | == gmse <train: 0.9279 | val: 0.8702> \n",
      "04-Jun-21 11:44:29 | Epoch 0026 | lr: 0.00250344 | Time(s): 30.0009\n",
      "04-Jun-21 11:44:29 | == train Loss <unroll: 4.0915 | vae : 13.9958 | kl : 0.0030>\n",
      "04-Jun-21 11:44:29 | == gmse <train: 0.8916 | val: 0.8445> \n",
      "04-Jun-21 11:44:59 | Epoch 0027 | lr: 0.00237827 | Time(s): 30.0001\n",
      "04-Jun-21 11:44:59 | == train Loss <unroll: 3.9761 | vae : 13.0488 | kl : 0.0029>\n",
      "04-Jun-21 11:44:59 | == gmse <train: 0.8567 | val: 0.7697> \n",
      "04-Jun-21 11:45:29 | Epoch 0028 | lr: 0.00225936 | Time(s): 29.9996\n",
      "04-Jun-21 11:45:29 | == train Loss <unroll: 3.8760 | vae : 12.2816 | kl : 0.0028>\n",
      "04-Jun-21 11:45:29 | == gmse <train: 0.8293 | val: 0.8027> \n",
      "04-Jun-21 11:45:59 | Epoch 0029 | lr: 0.00214639 | Time(s): 29.9998\n",
      "04-Jun-21 11:45:59 | == train Loss <unroll: 3.7911 | vae : 11.4998 | kl : 0.0028>\n",
      "04-Jun-21 11:45:59 | == gmse <train: 0.8043 | val: 0.7803> \n",
      "04-Jun-21 11:46:29 | Epoch 0030 | lr: 0.00203907 | Time(s): 29.9947\n",
      "04-Jun-21 11:46:29 | == train Loss <unroll: 3.7155 | vae : 10.9565 | kl : 0.0027>\n",
      "04-Jun-21 11:46:29 | == gmse <train: 0.7859 | val: 0.7094> \n",
      "04-Jun-21 11:46:59 | Epoch 0031 | lr: 0.00193711 | Time(s): 29.9947\n",
      "04-Jun-21 11:46:59 | == train Loss <unroll: 3.6469 | vae : 10.1929 | kl : 0.0026>\n",
      "04-Jun-21 11:46:59 | == gmse <train: 0.7642 | val: 0.7283> \n",
      "04-Jun-21 11:47:29 | Epoch 0032 | lr: 0.00184026 | Time(s): 29.9960\n",
      "04-Jun-21 11:47:29 | == train Loss <unroll: 7.0184 | vae : 9.6117 | kl : 0.0026>\n",
      "04-Jun-21 11:47:29 | == gmse <train: 0.7704 | val: 1.7540> \n",
      "04-Jun-21 11:47:59 | Epoch 0033 | lr: 0.00174825 | Time(s): 29.9984\n",
      "04-Jun-21 11:47:59 | == train Loss <unroll: 20.6907 | vae : 9.2357 | kl : 0.0025>\n",
      "04-Jun-21 11:47:59 | == gmse <train: 0.8554 | val: 0.7062> \n",
      "04-Jun-21 11:48:29 | Epoch 0034 | lr: 0.00166083 | Time(s): 30.0035\n",
      "04-Jun-21 11:48:29 | == train Loss <unroll: 4.7404 | vae : 8.6370 | kl : 0.0025>\n",
      "04-Jun-21 11:48:29 | == gmse <train: 0.7623 | val: 0.7184> \n",
      "04-Jun-21 11:48:59 | Epoch 0035 | lr: 0.00157779 | Time(s): 30.0078\n",
      "04-Jun-21 11:48:59 | == train Loss <unroll: 4.3245 | vae : 8.2726 | kl : 0.0025>\n",
      "04-Jun-21 11:48:59 | == gmse <train: 0.7528 | val: 0.6855> \n",
      "04-Jun-21 11:49:29 | Epoch 0036 | lr: 0.00149890 | Time(s): 30.0126\n",
      "04-Jun-21 11:49:29 | == train Loss <unroll: 4.1100 | vae : 7.8362 | kl : 0.0024>\n",
      "04-Jun-21 11:49:29 | == gmse <train: 0.7381 | val: 0.6750> \n",
      "04-Jun-21 11:50:00 | Epoch 0037 | lr: 0.00142396 | Time(s): 30.0177\n",
      "04-Jun-21 11:50:00 | == train Loss <unroll: 3.9832 | vae : 7.5042 | kl : 0.0024>\n",
      "04-Jun-21 11:50:00 | == gmse <train: 0.7230 | val: 0.6936> \n",
      "04-Jun-21 11:50:30 | Epoch 0038 | lr: 0.00135276 | Time(s): 30.0219\n",
      "04-Jun-21 11:50:30 | == train Loss <unroll: 3.8961 | vae : 7.1082 | kl : 0.0024>\n",
      "04-Jun-21 11:50:30 | == gmse <train: 0.7063 | val: 0.6852> \n",
      "04-Jun-21 11:51:00 | Epoch 0039 | lr: 0.00128512 | Time(s): 30.0268\n",
      "04-Jun-21 11:51:00 | == train Loss <unroll: 3.8305 | vae : 6.8298 | kl : 0.0023>\n",
      "04-Jun-21 11:51:00 | == gmse <train: 0.6940 | val: 0.6655> \n",
      "04-Jun-21 11:51:30 | Epoch 0040 | lr: 0.00122087 | Time(s): 30.0295\n",
      "04-Jun-21 11:51:30 | == train Loss <unroll: 3.7721 | vae : 6.5951 | kl : 0.0023>\n",
      "04-Jun-21 11:51:30 | == gmse <train: 0.6847 | val: 0.6727> \n",
      "04-Jun-21 11:52:00 | Epoch 0041 | lr: 0.00115982 | Time(s): 30.0321\n",
      "04-Jun-21 11:52:00 | == train Loss <unroll: 3.6602 | vae : 6.2149 | kl : 0.0023>\n",
      "04-Jun-21 11:52:00 | == gmse <train: 0.6904 | val: 0.6760> \n",
      "04-Jun-21 11:52:30 | Epoch 0042 | lr: 0.00110183 | Time(s): 30.0349\n",
      "04-Jun-21 11:52:30 | == train Loss <unroll: 3.4517 | vae : 5.9919 | kl : 0.0023>\n",
      "04-Jun-21 11:52:30 | == gmse <train: 0.6976 | val: 0.6829> \n",
      "04-Jun-21 11:53:01 | Epoch 0043 | lr: 0.00104674 | Time(s): 30.0372\n",
      "04-Jun-21 11:53:01 | == train Loss <unroll: 3.2872 | vae : 5.8009 | kl : 0.0023>\n",
      "04-Jun-21 11:53:01 | == gmse <train: 0.6881 | val: 0.6640> \n",
      "04-Jun-21 11:53:31 | Epoch 0044 | lr: 0.00099440 | Time(s): 30.0397\n",
      "04-Jun-21 11:53:31 | == train Loss <unroll: 3.1547 | vae : 5.6249 | kl : 0.0022>\n",
      "04-Jun-21 11:53:31 | == gmse <train: 0.6772 | val: 0.6343> \n",
      "04-Jun-21 11:54:01 | Epoch 0045 | lr: 0.00094468 | Time(s): 30.0436\n",
      "04-Jun-21 11:54:01 | == train Loss <unroll: 3.0435 | vae : 5.3756 | kl : 0.0022>\n",
      "04-Jun-21 11:54:01 | == gmse <train: 0.6629 | val: 0.6243> \n",
      "04-Jun-21 11:54:31 | Epoch 0046 | lr: 0.00089745 | Time(s): 30.0489\n",
      "04-Jun-21 11:54:31 | == train Loss <unroll: 2.9509 | vae : 5.1993 | kl : 0.0022>\n",
      "04-Jun-21 11:54:31 | == gmse <train: 0.6502 | val: 0.6423> \n",
      "04-Jun-21 11:55:01 | Epoch 0047 | lr: 0.00085258 | Time(s): 30.0447\n",
      "04-Jun-21 11:55:01 | == train Loss <unroll: 2.8681 | vae : 4.9743 | kl : 0.0022>\n",
      "04-Jun-21 11:55:01 | == gmse <train: 0.6356 | val: 0.6313> \n",
      "04-Jun-21 11:55:31 | Epoch 0048 | lr: 0.00080995 | Time(s): 30.0401\n",
      "04-Jun-21 11:55:31 | == train Loss <unroll: 2.7836 | vae : 4.8383 | kl : 0.0022>\n",
      "04-Jun-21 11:55:31 | == gmse <train: 0.6189 | val: 0.5397> \n",
      "04-Jun-21 11:56:01 | Epoch 0049 | lr: 0.00076945 | Time(s): 30.0354\n",
      "04-Jun-21 11:56:01 | == train Loss <unroll: 2.3708 | vae : 4.7017 | kl : 0.0022>\n",
      "04-Jun-21 11:56:01 | == gmse <train: 0.4968 | val: 0.3841> \n",
      "04-Jun-21 11:56:30 | Epoch 0050 | lr: 0.00073098 | Time(s): 30.0313\n",
      "04-Jun-21 11:56:30 | == train Loss <unroll: 1.9740 | vae : 4.5385 | kl : 0.0022>\n",
      "04-Jun-21 11:56:30 | == gmse <train: 0.4250 | val: 0.3257> \n",
      "04-Jun-21 11:57:00 | Epoch 0051 | lr: 0.00069443 | Time(s): 30.0300\n",
      "04-Jun-21 11:57:00 | == train Loss <unroll: 1.8043 | vae : 4.3938 | kl : 0.0022>\n",
      "04-Jun-21 11:57:00 | == gmse <train: 0.4028 | val: 0.3111> \n",
      "04-Jun-21 11:57:30 | Epoch 0052 | lr: 0.00065971 | Time(s): 30.0290\n",
      "04-Jun-21 11:57:30 | == train Loss <unroll: 1.7029 | vae : 4.2768 | kl : 0.0021>\n",
      "04-Jun-21 11:57:30 | == gmse <train: 0.3879 | val: 0.2813> \n",
      "04-Jun-21 11:58:00 | Epoch 0053 | lr: 0.00062672 | Time(s): 30.0280\n",
      "04-Jun-21 11:58:00 | == train Loss <unroll: 1.6347 | vae : 4.1660 | kl : 0.0021>\n",
      "04-Jun-21 11:58:00 | == gmse <train: 0.3727 | val: 0.2669> \n",
      "04-Jun-21 11:58:30 | Epoch 0054 | lr: 0.00059539 | Time(s): 30.0272\n",
      "04-Jun-21 11:58:30 | == train Loss <unroll: 1.5844 | vae : 4.0195 | kl : 0.0021>\n",
      "04-Jun-21 11:58:30 | == gmse <train: 0.3561 | val: 0.2620> \n",
      "04-Jun-21 11:59:00 | Epoch 0055 | lr: 0.00056562 | Time(s): 30.0263\n",
      "04-Jun-21 11:59:00 | == train Loss <unroll: 1.5515 | vae : 3.9638 | kl : 0.0021>\n",
      "04-Jun-21 11:59:00 | == gmse <train: 0.3443 | val: 0.2622> \n",
      "04-Jun-21 11:59:30 | Epoch 0056 | lr: 0.00053734 | Time(s): 30.0254\n",
      "04-Jun-21 11:59:30 | == train Loss <unroll: 1.5185 | vae : 3.8498 | kl : 0.0021>\n",
      "04-Jun-21 11:59:30 | == gmse <train: 0.3304 | val: 0.2466> \n",
      "04-Jun-21 12:00:00 | Epoch 0057 | lr: 0.00051047 | Time(s): 30.0233\n",
      "04-Jun-21 12:00:00 | == train Loss <unroll: 1.5533 | vae : 3.7897 | kl : 0.0021>\n",
      "04-Jun-21 12:00:00 | == gmse <train: 0.3221 | val: 0.2461> \n",
      "04-Jun-21 12:00:30 | Epoch 0058 | lr: 0.00048495 | Time(s): 30.0200\n",
      "04-Jun-21 12:00:30 | == train Loss <unroll: 1.4784 | vae : 3.6997 | kl : 0.0021>\n",
      "04-Jun-21 12:00:30 | == gmse <train: 0.3074 | val: 0.2395> \n",
      "04-Jun-21 12:01:00 | Epoch 0059 | lr: 0.00046070 | Time(s): 30.0170\n",
      "04-Jun-21 12:01:00 | == train Loss <unroll: 1.4643 | vae : 3.6381 | kl : 0.0021>\n",
      "04-Jun-21 12:01:00 | == gmse <train: 0.2979 | val: 0.2219> \n",
      "04-Jun-21 12:01:30 | Epoch 0060 | lr: 0.00043766 | Time(s): 30.0139\n",
      "04-Jun-21 12:01:30 | == train Loss <unroll: 1.4423 | vae : 3.5477 | kl : 0.0021>\n",
      "04-Jun-21 12:01:30 | == gmse <train: 0.2867 | val: 0.2281> \n",
      "04-Jun-21 12:02:00 | Epoch 0061 | lr: 0.00041578 | Time(s): 30.0129\n",
      "04-Jun-21 12:02:00 | == train Loss <unroll: 1.4285 | vae : 3.4965 | kl : 0.0021>\n",
      "04-Jun-21 12:02:00 | == gmse <train: 0.2777 | val: 0.2140> \n",
      "04-Jun-21 12:02:30 | Epoch 0062 | lr: 0.00039499 | Time(s): 30.0142\n",
      "04-Jun-21 12:02:30 | == train Loss <unroll: 1.4200 | vae : 3.4277 | kl : 0.0020>\n",
      "04-Jun-21 12:02:30 | == gmse <train: 0.2687 | val: 0.2120> \n",
      "04-Jun-21 12:03:00 | Epoch 0063 | lr: 0.00037524 | Time(s): 30.0154\n",
      "04-Jun-21 12:03:00 | == train Loss <unroll: 1.4163 | vae : 3.3852 | kl : 0.0020>\n",
      "04-Jun-21 12:03:00 | == gmse <train: 0.2613 | val: 0.2103> \n",
      "04-Jun-21 12:03:30 | Epoch 0064 | lr: 0.00035648 | Time(s): 30.0125\n",
      "04-Jun-21 12:03:30 | == train Loss <unroll: 1.3896 | vae : 3.3181 | kl : 0.0020>\n",
      "04-Jun-21 12:03:30 | == gmse <train: 0.2505 | val: 0.1959> \n",
      "04-Jun-21 12:04:00 | Epoch 0065 | lr: 0.00033866 | Time(s): 30.0123\n",
      "04-Jun-21 12:04:00 | == train Loss <unroll: 1.3911 | vae : 3.2583 | kl : 0.0020>\n",
      "04-Jun-21 12:04:00 | == gmse <train: 0.2434 | val: 0.1943> \n",
      "04-Jun-21 12:04:30 | Epoch 0066 | lr: 0.00032172 | Time(s): 30.0130\n",
      "04-Jun-21 12:04:30 | == train Loss <unroll: 1.3654 | vae : 3.2095 | kl : 0.0020>\n",
      "04-Jun-21 12:04:30 | == gmse <train: 0.2338 | val: 0.1859> \n",
      "04-Jun-21 12:05:00 | Epoch 0067 | lr: 0.00030564 | Time(s): 30.0120\n",
      "04-Jun-21 12:05:00 | == train Loss <unroll: 1.3541 | vae : 3.1683 | kl : 0.0020>\n",
      "04-Jun-21 12:05:00 | == gmse <train: 0.2263 | val: 0.1884> \n",
      "04-Jun-21 12:05:30 | Epoch 0068 | lr: 0.00029035 | Time(s): 30.0113\n",
      "04-Jun-21 12:05:30 | == train Loss <unroll: 1.3439 | vae : 3.1279 | kl : 0.0020>\n",
      "04-Jun-21 12:05:30 | == gmse <train: 0.2187 | val: 0.1827> \n",
      "04-Jun-21 12:06:00 | Epoch 0069 | lr: 0.00027584 | Time(s): 30.0136\n",
      "04-Jun-21 12:06:00 | == train Loss <unroll: 1.3322 | vae : 3.0768 | kl : 0.0020>\n",
      "04-Jun-21 12:06:00 | == gmse <train: 0.2109 | val: 0.1728> \n",
      "04-Jun-21 12:06:30 | Epoch 0070 | lr: 0.00026205 | Time(s): 30.0106\n",
      "04-Jun-21 12:06:30 | == train Loss <unroll: 1.3262 | vae : 3.0408 | kl : 0.0019>\n",
      "04-Jun-21 12:06:30 | == gmse <train: 0.2043 | val: 0.1689> \n",
      "04-Jun-21 12:06:59 | Epoch 0071 | lr: 0.00024894 | Time(s): 30.0063\n",
      "04-Jun-21 12:06:59 | == train Loss <unroll: 1.3127 | vae : 3.0093 | kl : 0.0019>\n",
      "04-Jun-21 12:06:59 | == gmse <train: 0.1967 | val: 0.1648> \n",
      "04-Jun-21 12:07:29 | Epoch 0072 | lr: 0.00023650 | Time(s): 30.0041\n",
      "04-Jun-21 12:07:29 | == train Loss <unroll: 1.3006 | vae : 2.9677 | kl : 0.0019>\n",
      "04-Jun-21 12:07:29 | == gmse <train: 0.1895 | val: 0.1623> \n",
      "04-Jun-21 12:07:59 | Epoch 0073 | lr: 0.00022467 | Time(s): 30.0016\n",
      "04-Jun-21 12:07:59 | == train Loss <unroll: 1.3032 | vae : 2.9389 | kl : 0.0019>\n",
      "04-Jun-21 12:07:59 | == gmse <train: 0.1841 | val: 0.1672> \n",
      "04-Jun-21 12:08:29 | Epoch 0074 | lr: 0.00021344 | Time(s): 29.9998\n",
      "04-Jun-21 12:08:29 | == train Loss <unroll: 1.2813 | vae : 2.9143 | kl : 0.0019>\n",
      "04-Jun-21 12:08:29 | == gmse <train: 0.1762 | val: 0.1467> \n",
      "04-Jun-21 12:08:59 | Epoch 0075 | lr: 0.00020277 | Time(s): 30.0010\n",
      "04-Jun-21 12:08:59 | == train Loss <unroll: 1.2737 | vae : 2.8776 | kl : 0.0018>\n",
      "04-Jun-21 12:08:59 | == gmse <train: 0.1699 | val: 0.1431> \n",
      "04-Jun-21 12:09:29 | Epoch 0076 | lr: 0.00019263 | Time(s): 30.0029\n",
      "04-Jun-21 12:09:29 | == train Loss <unroll: 1.2579 | vae : 2.8505 | kl : 0.0018>\n",
      "04-Jun-21 12:09:29 | == gmse <train: 0.1633 | val: 0.1365> \n",
      "04-Jun-21 12:09:59 | Epoch 0077 | lr: 0.00018300 | Time(s): 30.0053\n",
      "04-Jun-21 12:09:59 | == train Loss <unroll: 1.2475 | vae : 2.8240 | kl : 0.0018>\n",
      "04-Jun-21 12:09:59 | == gmse <train: 0.1578 | val: 0.1372> \n",
      "04-Jun-21 12:10:30 | Epoch 0078 | lr: 0.00017385 | Time(s): 30.0075\n",
      "04-Jun-21 12:10:30 | == train Loss <unroll: 1.2327 | vae : 2.7982 | kl : 0.0018>\n",
      "04-Jun-21 12:10:30 | == gmse <train: 0.1525 | val: 0.1288> \n",
      "04-Jun-21 12:11:00 | Epoch 0079 | lr: 0.00016515 | Time(s): 30.0093\n",
      "04-Jun-21 12:11:00 | == train Loss <unroll: 1.2225 | vae : 2.7792 | kl : 0.0018>\n",
      "04-Jun-21 12:11:00 | == gmse <train: 0.1483 | val: 0.1241> \n",
      "04-Jun-21 12:11:30 | Epoch 0080 | lr: 0.00015690 | Time(s): 30.0112\n",
      "04-Jun-21 12:11:30 | == train Loss <unroll: 1.2134 | vae : 2.7498 | kl : 0.0017>\n",
      "04-Jun-21 12:11:30 | == gmse <train: 0.1443 | val: 0.1251> \n",
      "04-Jun-21 12:12:00 | Epoch 0081 | lr: 0.00014905 | Time(s): 30.0118\n",
      "04-Jun-21 12:12:00 | == train Loss <unroll: 1.2081 | vae : 2.7312 | kl : 0.0017>\n",
      "04-Jun-21 12:12:00 | == gmse <train: 0.1412 | val: 0.1243> \n",
      "04-Jun-21 12:12:30 | Epoch 0082 | lr: 0.00014160 | Time(s): 30.0119\n",
      "04-Jun-21 12:12:30 | == train Loss <unroll: 1.2020 | vae : 2.7037 | kl : 0.0017>\n",
      "04-Jun-21 12:12:30 | == gmse <train: 0.1381 | val: 0.1207> \n",
      "04-Jun-21 12:13:00 | Epoch 0083 | lr: 0.00013452 | Time(s): 30.0114\n",
      "04-Jun-21 12:13:00 | == train Loss <unroll: 1.1971 | vae : 2.6928 | kl : 0.0017>\n",
      "04-Jun-21 12:13:00 | == gmse <train: 0.1355 | val: 0.1180> \n",
      "04-Jun-21 12:13:30 | Epoch 0084 | lr: 0.00012779 | Time(s): 30.0108\n",
      "04-Jun-21 12:13:30 | == train Loss <unroll: 1.1922 | vae : 2.6739 | kl : 0.0016>\n",
      "04-Jun-21 12:13:30 | == gmse <train: 0.1332 | val: 0.1129> \n",
      "04-Jun-21 12:14:00 | Epoch 0085 | lr: 0.00012140 | Time(s): 30.0104\n",
      "04-Jun-21 12:14:00 | == train Loss <unroll: 1.1888 | vae : 2.6510 | kl : 0.0016>\n",
      "04-Jun-21 12:14:00 | == gmse <train: 0.1312 | val: 0.1126> \n",
      "04-Jun-21 12:14:30 | Epoch 0086 | lr: 0.00011533 | Time(s): 30.0101\n",
      "04-Jun-21 12:14:30 | == train Loss <unroll: 1.1845 | vae : 2.6350 | kl : 0.0016>\n",
      "04-Jun-21 12:14:30 | == gmse <train: 0.1293 | val: 0.1135> \n",
      "04-Jun-21 12:15:00 | Epoch 0087 | lr: 0.00010957 | Time(s): 30.0100\n",
      "04-Jun-21 12:15:00 | == train Loss <unroll: 1.1814 | vae : 2.6201 | kl : 0.0016>\n",
      "04-Jun-21 12:15:00 | == gmse <train: 0.1278 | val: 0.1113> \n",
      "04-Jun-21 12:15:30 | Epoch 0088 | lr: 0.00010409 | Time(s): 30.0096\n",
      "04-Jun-21 12:15:30 | == train Loss <unroll: 1.1765 | vae : 2.6022 | kl : 0.0015>\n",
      "04-Jun-21 12:15:30 | == gmse <train: 0.1260 | val: 0.1082> \n",
      "04-Jun-21 12:16:00 | Epoch 0089 | lr: 0.00009888 | Time(s): 30.0089\n",
      "04-Jun-21 12:16:00 | == train Loss <unroll: 1.1727 | vae : 2.5938 | kl : 0.0015>\n",
      "04-Jun-21 12:16:00 | == gmse <train: 0.1244 | val: 0.1082> \n",
      "04-Jun-21 12:16:30 | Epoch 0090 | lr: 0.00009394 | Time(s): 30.0074\n",
      "04-Jun-21 12:16:30 | == train Loss <unroll: 1.1694 | vae : 2.5678 | kl : 0.0015>\n",
      "04-Jun-21 12:16:30 | == gmse <train: 0.1232 | val: 0.1055> \n",
      "04-Jun-21 12:17:00 | Epoch 0091 | lr: 0.00008924 | Time(s): 30.0078\n",
      "04-Jun-21 12:17:00 | == train Loss <unroll: 1.1654 | vae : 2.5636 | kl : 0.0014>\n",
      "04-Jun-21 12:17:00 | == gmse <train: 0.1218 | val: 0.1043> \n",
      "04-Jun-21 12:17:30 | Epoch 0092 | lr: 0.00008478 | Time(s): 30.0071\n",
      "04-Jun-21 12:17:30 | == train Loss <unroll: 1.1617 | vae : 2.5476 | kl : 0.0014>\n",
      "04-Jun-21 12:17:30 | == gmse <train: 0.1206 | val: 0.1050> \n",
      "04-Jun-21 12:18:00 | Epoch 0093 | lr: 0.00008054 | Time(s): 30.0071\n",
      "04-Jun-21 12:18:00 | == train Loss <unroll: 1.1591 | vae : 2.5370 | kl : 0.0014>\n",
      "04-Jun-21 12:18:00 | == gmse <train: 0.1196 | val: 0.1016> \n",
      "04-Jun-21 12:18:30 | Epoch 0094 | lr: 0.00007651 | Time(s): 30.0066\n",
      "04-Jun-21 12:18:30 | == train Loss <unroll: 1.1547 | vae : 2.5164 | kl : 0.0013>\n",
      "04-Jun-21 12:18:30 | == gmse <train: 0.1183 | val: 0.1021> \n",
      "04-Jun-21 12:19:00 | Epoch 0095 | lr: 0.00007269 | Time(s): 30.0066\n",
      "04-Jun-21 12:19:00 | == train Loss <unroll: 1.1517 | vae : 2.5150 | kl : 0.0013>\n",
      "04-Jun-21 12:19:00 | == gmse <train: 0.1173 | val: 0.1021> \n",
      "04-Jun-21 12:19:30 | Epoch 0096 | lr: 0.00006905 | Time(s): 30.0068\n",
      "04-Jun-21 12:19:30 | == train Loss <unroll: 1.1481 | vae : 2.5019 | kl : 0.0013>\n",
      "04-Jun-21 12:19:30 | == gmse <train: 0.1162 | val: 0.1011> \n",
      "04-Jun-21 12:20:00 | Epoch 0097 | lr: 0.00006560 | Time(s): 30.0067\n",
      "04-Jun-21 12:20:00 | == train Loss <unroll: 1.1448 | vae : 2.4968 | kl : 0.0012>\n",
      "04-Jun-21 12:20:00 | == gmse <train: 0.1153 | val: 0.1011> \n",
      "04-Jun-21 12:20:30 | Epoch 0098 | lr: 0.00006232 | Time(s): 30.0069\n",
      "04-Jun-21 12:20:30 | == train Loss <unroll: 1.1415 | vae : 2.4850 | kl : 0.0012>\n",
      "04-Jun-21 12:20:30 | == gmse <train: 0.1142 | val: 0.1006> \n",
      "04-Jun-21 12:21:00 | Epoch 0099 | lr: 0.00005921 | Time(s): 30.0079\n",
      "04-Jun-21 12:21:00 | == train Loss <unroll: 1.1387 | vae : 2.4743 | kl : 0.0012>\n",
      "04-Jun-21 12:21:00 | == gmse <train: 0.1133 | val: 0.1008> \n",
      "04-Jun-21 12:21:30 | Epoch 0100 | lr: 0.00005625 | Time(s): 30.0088\n",
      "04-Jun-21 12:21:30 | == train Loss <unroll: 1.1360 | vae : 2.4644 | kl : 0.0011>\n",
      "04-Jun-21 12:21:30 | == gmse <train: 0.1125 | val: 0.1003> \n",
      "04-Jun-21 12:22:00 | Epoch 0101 | lr: 0.00005343 | Time(s): 30.0098\n",
      "04-Jun-21 12:22:00 | == train Loss <unroll: 1.1331 | vae : 2.4573 | kl : 0.0011>\n",
      "04-Jun-21 12:22:00 | == gmse <train: 0.1116 | val: 0.0981> \n",
      "04-Jun-21 12:22:30 | Epoch 0102 | lr: 0.00005076 | Time(s): 30.0109\n",
      "04-Jun-21 12:22:30 | == train Loss <unroll: 1.1308 | vae : 2.4463 | kl : 0.0011>\n",
      "04-Jun-21 12:22:30 | == gmse <train: 0.1109 | val: 0.0990> \n",
      "04-Jun-21 12:23:00 | Epoch 0103 | lr: 0.00004822 | Time(s): 30.0118\n",
      "04-Jun-21 12:23:00 | == train Loss <unroll: 1.1285 | vae : 2.4371 | kl : 0.0010>\n",
      "04-Jun-21 12:23:00 | == gmse <train: 0.1101 | val: 0.0987> \n",
      "04-Jun-21 12:23:30 | Epoch 0104 | lr: 0.00004581 | Time(s): 30.0129\n",
      "04-Jun-21 12:23:30 | == train Loss <unroll: 1.1263 | vae : 2.4284 | kl : 0.0010>\n",
      "04-Jun-21 12:23:30 | == gmse <train: 0.1094 | val: 0.0975> \n",
      "04-Jun-21 12:24:01 | Epoch 0105 | lr: 0.00004352 | Time(s): 30.0148\n",
      "04-Jun-21 12:24:01 | == train Loss <unroll: 1.1248 | vae : 2.4226 | kl : 0.0009>\n",
      "04-Jun-21 12:24:01 | == gmse <train: 0.1089 | val: 0.0971> \n",
      "04-Jun-21 12:24:31 | Epoch 0106 | lr: 0.00004135 | Time(s): 30.0155\n",
      "04-Jun-21 12:24:31 | == train Loss <unroll: 1.1230 | vae : 2.4139 | kl : 0.0009>\n",
      "04-Jun-21 12:24:31 | == gmse <train: 0.1083 | val: 0.0974> \n",
      "04-Jun-21 12:25:01 | Epoch 0107 | lr: 0.00003928 | Time(s): 30.0160\n",
      "04-Jun-21 12:25:01 | == train Loss <unroll: 1.1216 | vae : 2.4050 | kl : 0.0009>\n",
      "04-Jun-21 12:25:01 | == gmse <train: 0.1078 | val: 0.0985> \n",
      "04-Jun-21 12:25:31 | Epoch 0108 | lr: 0.00003731 | Time(s): 30.0166\n",
      "04-Jun-21 12:25:31 | == train Loss <unroll: 1.1203 | vae : 2.4004 | kl : 0.0008>\n",
      "04-Jun-21 12:25:31 | == gmse <train: 0.1073 | val: 0.0978> \n",
      "04-Jun-21 12:26:01 | Epoch 0109 | lr: 0.00003545 | Time(s): 30.0173\n",
      "04-Jun-21 12:26:01 | == train Loss <unroll: 1.1197 | vae : 2.3981 | kl : 0.0008>\n",
      "04-Jun-21 12:26:01 | == gmse <train: 0.1071 | val: 0.0984> \n",
      "04-Jun-21 12:26:31 | Epoch 0110 | lr: 0.00003368 | Time(s): 30.0179\n",
      "04-Jun-21 12:26:31 | == train Loss <unroll: 1.1182 | vae : 2.3901 | kl : 0.0007>\n",
      "04-Jun-21 12:26:31 | == gmse <train: 0.1065 | val: 0.0970> \n",
      "04-Jun-21 12:27:01 | Epoch 0111 | lr: 0.00003199 | Time(s): 30.0188\n",
      "04-Jun-21 12:27:01 | == train Loss <unroll: 1.1173 | vae : 2.3868 | kl : 0.0007>\n",
      "04-Jun-21 12:27:01 | == gmse <train: 0.1062 | val: 0.0979> \n",
      "04-Jun-21 12:27:31 | Epoch 0112 | lr: 0.00003039 | Time(s): 30.0195\n",
      "04-Jun-21 12:27:31 | == train Loss <unroll: 1.1166 | vae : 2.3754 | kl : 0.0007>\n",
      "04-Jun-21 12:27:31 | == gmse <train: 0.1059 | val: 0.0950> \n",
      "04-Jun-21 12:28:01 | Epoch 0113 | lr: 0.00002887 | Time(s): 30.0204\n",
      "04-Jun-21 12:28:01 | == train Loss <unroll: 1.1159 | vae : 2.3729 | kl : 0.0006>\n",
      "04-Jun-21 12:28:01 | == gmse <train: 0.1056 | val: 0.0964> \n",
      "04-Jun-21 12:28:32 | Epoch 0114 | lr: 0.00002743 | Time(s): 30.0211\n",
      "04-Jun-21 12:28:32 | == train Loss <unroll: 1.1155 | vae : 2.3686 | kl : 0.0006>\n",
      "04-Jun-21 12:28:32 | == gmse <train: 0.1054 | val: 0.0970> \n",
      "04-Jun-21 12:29:02 | Epoch 0115 | lr: 0.00002606 | Time(s): 30.0218\n",
      "04-Jun-21 12:29:02 | == train Loss <unroll: 1.1146 | vae : 2.3608 | kl : 0.0006>\n",
      "04-Jun-21 12:29:02 | == gmse <train: 0.1050 | val: 0.0980> \n",
      "04-Jun-21 12:29:32 | Epoch 0116 | lr: 0.00002475 | Time(s): 30.0225\n",
      "04-Jun-21 12:29:32 | == train Loss <unroll: 1.1142 | vae : 2.3559 | kl : 0.0005>\n",
      "04-Jun-21 12:29:32 | == gmse <train: 0.1048 | val: 0.0962> \n",
      "04-Jun-21 12:30:02 | Epoch 0117 | lr: 0.00002352 | Time(s): 30.0236\n",
      "04-Jun-21 12:30:02 | == train Loss <unroll: 1.1138 | vae : 2.3519 | kl : 0.0005>\n",
      "04-Jun-21 12:30:02 | == gmse <train: 0.1047 | val: 0.0956> \n",
      "04-Jun-21 12:30:32 | Epoch 0118 | lr: 0.00002234 | Time(s): 30.0242\n",
      "04-Jun-21 12:30:32 | == train Loss <unroll: 1.1133 | vae : 2.3476 | kl : 0.0005>\n",
      "04-Jun-21 12:30:32 | == gmse <train: 0.1044 | val: 0.0968> \n",
      "04-Jun-21 12:31:02 | Epoch 0119 | lr: 0.00002122 | Time(s): 30.0250\n",
      "04-Jun-21 12:31:02 | == train Loss <unroll: 1.1132 | vae : 2.3435 | kl : 0.0004>\n",
      "04-Jun-21 12:31:02 | == gmse <train: 0.1043 | val: 0.0941> \n",
      "04-Jun-21 12:31:32 | Epoch 0120 | lr: 0.00002016 | Time(s): 30.0257\n",
      "04-Jun-21 12:31:32 | == train Loss <unroll: 1.1125 | vae : 2.3376 | kl : 0.0004>\n",
      "04-Jun-21 12:31:32 | == gmse <train: 0.1040 | val: 0.0965> \n",
      "04-Jun-21 12:32:02 | Epoch 0121 | lr: 0.00001915 | Time(s): 30.0263\n",
      "04-Jun-21 12:32:02 | == train Loss <unroll: 1.1126 | vae : 2.3372 | kl : 0.0004>\n",
      "04-Jun-21 12:32:02 | == gmse <train: 0.1040 | val: 0.0953> \n",
      "04-Jun-21 12:32:32 | Epoch 0122 | lr: 0.00001820 | Time(s): 30.0270\n",
      "04-Jun-21 12:32:32 | == train Loss <unroll: 1.1117 | vae : 2.3319 | kl : 0.0004>\n",
      "04-Jun-21 12:32:32 | == gmse <train: 0.1037 | val: 0.0948> \n",
      "04-Jun-21 12:33:02 | Epoch 0123 | lr: 0.00001729 | Time(s): 30.0273\n",
      "04-Jun-21 12:33:02 | == train Loss <unroll: 1.1115 | vae : 2.3275 | kl : 0.0003>\n",
      "04-Jun-21 12:33:02 | == gmse <train: 0.1036 | val: 0.0956> \n",
      "04-Jun-21 12:33:32 | Epoch 0124 | lr: 0.00001642 | Time(s): 30.0261\n",
      "04-Jun-21 12:33:32 | == train Loss <unroll: 1.1113 | vae : 2.3238 | kl : 0.0003>\n",
      "04-Jun-21 12:33:32 | == gmse <train: 0.1034 | val: 0.0964> \n",
      "04-Jun-21 12:34:02 | Epoch 0125 | lr: 0.00001560 | Time(s): 30.0265\n",
      "04-Jun-21 12:34:02 | == train Loss <unroll: 1.1111 | vae : 2.3209 | kl : 0.0003>\n",
      "04-Jun-21 12:34:02 | == gmse <train: 0.1033 | val: 0.0941> \n",
      "04-Jun-21 12:34:32 | Epoch 0126 | lr: 0.00001482 | Time(s): 30.0260\n",
      "04-Jun-21 12:34:32 | == train Loss <unroll: 1.1107 | vae : 2.3185 | kl : 0.0003>\n",
      "04-Jun-21 12:34:32 | == gmse <train: 0.1031 | val: 0.0953> \n",
      "04-Jun-21 12:35:02 | Epoch 0127 | lr: 0.00001408 | Time(s): 30.0260\n",
      "04-Jun-21 12:35:02 | == train Loss <unroll: 1.1106 | vae : 2.3155 | kl : 0.0002>\n",
      "04-Jun-21 12:35:02 | == gmse <train: 0.1031 | val: 0.0939> \n",
      "04-Jun-21 12:35:32 | Epoch 0128 | lr: 0.00001338 | Time(s): 30.0251\n",
      "04-Jun-21 12:35:32 | == train Loss <unroll: 1.1103 | vae : 2.3131 | kl : 0.0002>\n",
      "04-Jun-21 12:35:32 | == gmse <train: 0.1030 | val: 0.0944> \n",
      "04-Jun-21 12:36:02 | Epoch 0129 | lr: 0.00001271 | Time(s): 30.0235\n",
      "04-Jun-21 12:36:02 | == train Loss <unroll: 1.1102 | vae : 2.3096 | kl : 0.0002>\n",
      "04-Jun-21 12:36:02 | == gmse <train: 0.1029 | val: 0.0964> \n",
      "04-Jun-21 12:36:32 | Epoch 0130 | lr: 0.00001207 | Time(s): 30.0213\n",
      "04-Jun-21 12:36:32 | == train Loss <unroll: 1.1099 | vae : 2.3066 | kl : 0.0002>\n",
      "04-Jun-21 12:36:32 | == gmse <train: 0.1028 | val: 0.0956> \n",
      "04-Jun-21 12:37:02 | Epoch 0131 | lr: 0.00001147 | Time(s): 30.0192\n",
      "04-Jun-21 12:37:02 | == train Loss <unroll: 1.1097 | vae : 2.3027 | kl : 0.0002>\n",
      "04-Jun-21 12:37:02 | == gmse <train: 0.1027 | val: 0.0950> \n",
      "04-Jun-21 12:37:32 | Epoch 0132 | lr: 0.00001090 | Time(s): 30.0196\n",
      "04-Jun-21 12:37:32 | == train Loss <unroll: 1.1095 | vae : 2.3002 | kl : 0.0002>\n",
      "04-Jun-21 12:37:32 | == gmse <train: 0.1026 | val: 0.0952> \n",
      "04-Jun-21 12:38:02 | Epoch 0133 | lr: 0.00001035 | Time(s): 30.0200\n",
      "04-Jun-21 12:38:02 | == train Loss <unroll: 1.1095 | vae : 2.2988 | kl : 0.0001>\n",
      "04-Jun-21 12:38:02 | == gmse <train: 0.1026 | val: 0.0947> \n",
      "04-Jun-21 12:38:32 | Epoch 0134 | lr: 0.00000983 | Time(s): 30.0210\n",
      "04-Jun-21 12:38:32 | == train Loss <unroll: 1.1092 | vae : 2.2960 | kl : 0.0001>\n",
      "04-Jun-21 12:38:32 | == gmse <train: 0.1024 | val: 0.0941> \n",
      "04-Jun-21 12:39:02 | Epoch 0135 | lr: 0.00000934 | Time(s): 30.0219\n",
      "04-Jun-21 12:39:02 | == train Loss <unroll: 1.1092 | vae : 2.2941 | kl : 0.0001>\n",
      "04-Jun-21 12:39:02 | == gmse <train: 0.1024 | val: 0.0943> \n",
      "04-Jun-21 12:39:32 | Epoch 0136 | lr: 0.00000887 | Time(s): 30.0211\n",
      "04-Jun-21 12:39:32 | == train Loss <unroll: 1.1089 | vae : 2.2916 | kl : 0.0001>\n",
      "04-Jun-21 12:39:32 | == gmse <train: 0.1023 | val: 0.0945> \n",
      "04-Jun-21 12:40:02 | Epoch 0137 | lr: 0.00000843 | Time(s): 30.0214\n",
      "04-Jun-21 12:40:02 | == train Loss <unroll: 1.1088 | vae : 2.2902 | kl : 0.0001>\n",
      "04-Jun-21 12:40:02 | == gmse <train: 0.1022 | val: 0.0937> \n",
      "04-Jun-21 12:40:32 | Epoch 0138 | lr: 0.00000801 | Time(s): 30.0210\n",
      "04-Jun-21 12:40:32 | == train Loss <unroll: 1.1088 | vae : 2.2877 | kl : 0.0001>\n",
      "04-Jun-21 12:40:32 | == gmse <train: 0.1022 | val: 0.0948> \n",
      "04-Jun-21 12:41:02 | Epoch 0139 | lr: 0.00000761 | Time(s): 30.0213\n",
      "04-Jun-21 12:41:02 | == train Loss <unroll: 1.1086 | vae : 2.2852 | kl : 0.0001>\n",
      "04-Jun-21 12:41:02 | == gmse <train: 0.1021 | val: 0.0953> \n",
      "04-Jun-21 12:41:32 | Epoch 0140 | lr: 0.00000723 | Time(s): 30.0215\n",
      "04-Jun-21 12:41:32 | == train Loss <unroll: 1.1085 | vae : 2.2845 | kl : 0.0001>\n",
      "04-Jun-21 12:41:32 | == gmse <train: 0.1021 | val: 0.0948> \n",
      "04-Jun-21 12:42:02 | Epoch 0141 | lr: 0.00000687 | Time(s): 30.0220\n",
      "04-Jun-21 12:42:02 | == train Loss <unroll: 1.1084 | vae : 2.2816 | kl : 0.0001>\n",
      "04-Jun-21 12:42:02 | == gmse <train: 0.1021 | val: 0.0955> \n",
      "04-Jun-21 12:42:32 | Epoch 0142 | lr: 0.00000652 | Time(s): 30.0221\n",
      "04-Jun-21 12:42:32 | == train Loss <unroll: 1.1082 | vae : 2.2812 | kl : 0.0001>\n",
      "04-Jun-21 12:42:32 | == gmse <train: 0.1020 | val: 0.0935> \n",
      "04-Jun-21 12:43:02 | Epoch 0143 | lr: 0.00000620 | Time(s): 30.0223\n",
      "04-Jun-21 12:43:02 | == train Loss <unroll: 1.1082 | vae : 2.2789 | kl : 0.0001>\n",
      "04-Jun-21 12:43:02 | == gmse <train: 0.1019 | val: 0.0944> \n",
      "04-Jun-21 12:43:32 | Epoch 0144 | lr: 0.00000589 | Time(s): 30.0214\n",
      "04-Jun-21 12:43:32 | == train Loss <unroll: 1.1081 | vae : 2.2773 | kl : 0.0001>\n",
      "04-Jun-21 12:43:32 | == gmse <train: 0.1019 | val: 0.0949> \n",
      "04-Jun-21 12:44:02 | Epoch 0145 | lr: 0.00000559 | Time(s): 30.0206\n",
      "04-Jun-21 12:44:02 | == train Loss <unroll: 1.1080 | vae : 2.2763 | kl : 0.0000>\n",
      "04-Jun-21 12:44:02 | == gmse <train: 0.1018 | val: 0.0938> \n",
      "04-Jun-21 12:44:32 | Epoch 0146 | lr: 0.00000531 | Time(s): 30.0206\n",
      "04-Jun-21 12:44:32 | == train Loss <unroll: 1.1079 | vae : 2.2741 | kl : 0.0000>\n",
      "04-Jun-21 12:44:32 | == gmse <train: 0.1018 | val: 0.0944> \n",
      "04-Jun-21 12:45:02 | Epoch 0147 | lr: 0.00000505 | Time(s): 30.0215\n",
      "04-Jun-21 12:45:02 | == train Loss <unroll: 1.1078 | vae : 2.2731 | kl : 0.0000>\n",
      "04-Jun-21 12:45:02 | == gmse <train: 0.1017 | val: 0.0947> \n",
      "04-Jun-21 12:45:32 | Epoch 0148 | lr: 0.00000480 | Time(s): 30.0220\n",
      "04-Jun-21 12:45:32 | == train Loss <unroll: 1.1077 | vae : 2.2715 | kl : 0.0000>\n",
      "04-Jun-21 12:45:32 | == gmse <train: 0.1017 | val: 0.0946> \n",
      "04-Jun-21 12:46:03 | Epoch 0149 | lr: 0.00000456 | Time(s): 30.0232\n",
      "04-Jun-21 12:46:03 | == train Loss <unroll: 1.1076 | vae : 2.2701 | kl : 0.0000>\n",
      "04-Jun-21 12:46:03 | == gmse <train: 0.1017 | val: 0.0943> \n",
      "04-Jun-21 12:46:33 | Epoch 0150 | lr: 0.00000433 | Time(s): 30.0246\n",
      "04-Jun-21 12:46:33 | == train Loss <unroll: 1.1076 | vae : 2.2693 | kl : 0.0000>\n",
      "04-Jun-21 12:46:33 | == gmse <train: 0.1017 | val: 0.0943> \n",
      "04-Jun-21 12:47:03 | Epoch 0151 | lr: 0.00000411 | Time(s): 30.0254\n",
      "04-Jun-21 12:47:03 | == train Loss <unroll: 1.1076 | vae : 2.2678 | kl : 0.0000>\n",
      "04-Jun-21 12:47:03 | == gmse <train: 0.1016 | val: 0.0941> \n",
      "04-Jun-21 12:47:33 | Epoch 0152 | lr: 0.00000391 | Time(s): 30.0255\n",
      "04-Jun-21 12:47:33 | == train Loss <unroll: 1.1075 | vae : 2.2667 | kl : 0.0000>\n",
      "04-Jun-21 12:47:33 | == gmse <train: 0.1016 | val: 0.0934> \n",
      "04-Jun-21 12:48:03 | Epoch 0153 | lr: 0.00000371 | Time(s): 30.0259\n",
      "04-Jun-21 12:48:03 | == train Loss <unroll: 1.1074 | vae : 2.2660 | kl : 0.0000>\n",
      "04-Jun-21 12:48:03 | == gmse <train: 0.1016 | val: 0.0946> \n",
      "04-Jun-21 12:48:33 | Epoch 0154 | lr: 0.00000352 | Time(s): 30.0255\n",
      "04-Jun-21 12:48:33 | == train Loss <unroll: 1.1074 | vae : 2.2651 | kl : 0.0000>\n",
      "04-Jun-21 12:48:33 | == gmse <train: 0.1016 | val: 0.0945> \n",
      "04-Jun-21 12:49:03 | Epoch 0155 | lr: 0.00000335 | Time(s): 30.0253\n",
      "04-Jun-21 12:49:03 | == train Loss <unroll: 1.1074 | vae : 2.2634 | kl : 0.0000>\n",
      "04-Jun-21 12:49:03 | == gmse <train: 0.1015 | val: 0.0943> \n",
      "04-Jun-21 12:49:33 | Epoch 0156 | lr: 0.00000318 | Time(s): 30.0242\n",
      "04-Jun-21 12:49:33 | == train Loss <unroll: 1.1073 | vae : 2.2633 | kl : 0.0000>\n",
      "04-Jun-21 12:49:33 | == gmse <train: 0.1015 | val: 0.0938> \n",
      "04-Jun-21 12:50:03 | Epoch 0157 | lr: 0.00000302 | Time(s): 30.0232\n",
      "04-Jun-21 12:50:03 | == train Loss <unroll: 1.1072 | vae : 2.2618 | kl : 0.0000>\n",
      "04-Jun-21 12:50:03 | == gmse <train: 0.1015 | val: 0.0941> \n",
      "04-Jun-21 12:50:33 | Epoch 0158 | lr: 0.00000287 | Time(s): 30.0221\n",
      "04-Jun-21 12:50:33 | == train Loss <unroll: 1.1072 | vae : 2.2611 | kl : 0.0000>\n",
      "04-Jun-21 12:50:33 | == gmse <train: 0.1015 | val: 0.0942> \n",
      "04-Jun-21 12:51:03 | Epoch 0159 | lr: 0.00000273 | Time(s): 30.0233\n",
      "04-Jun-21 12:51:03 | == train Loss <unroll: 1.1071 | vae : 2.2599 | kl : 0.0000>\n",
      "04-Jun-21 12:51:03 | == gmse <train: 0.1014 | val: 0.0941> \n",
      "04-Jun-21 12:51:33 | Epoch 0160 | lr: 0.00000259 | Time(s): 30.0244\n",
      "04-Jun-21 12:51:33 | == train Loss <unroll: 1.1071 | vae : 2.2596 | kl : 0.0000>\n",
      "04-Jun-21 12:51:33 | == gmse <train: 0.1014 | val: 0.0944> \n",
      "04-Jun-21 12:52:03 | Epoch 0161 | lr: 0.00000246 | Time(s): 30.0254\n",
      "04-Jun-21 12:52:03 | == train Loss <unroll: 1.1071 | vae : 2.2584 | kl : 0.0000>\n",
      "04-Jun-21 12:52:03 | == gmse <train: 0.1014 | val: 0.0935> \n",
      "04-Jun-21 12:52:34 | Epoch 0162 | lr: 0.00000234 | Time(s): 30.0264\n",
      "04-Jun-21 12:52:34 | == train Loss <unroll: 1.1070 | vae : 2.2577 | kl : 0.0000>\n",
      "04-Jun-21 12:52:34 | == gmse <train: 0.1014 | val: 0.0934> \n",
      "04-Jun-21 12:53:04 | Epoch 0163 | lr: 0.00000222 | Time(s): 30.0274\n",
      "04-Jun-21 12:53:04 | == train Loss <unroll: 1.1070 | vae : 2.2568 | kl : 0.0000>\n",
      "04-Jun-21 12:53:04 | == gmse <train: 0.1014 | val: 0.0947> \n",
      "04-Jun-21 12:53:34 | Epoch 0164 | lr: 0.00000211 | Time(s): 30.0282\n",
      "04-Jun-21 12:53:34 | == train Loss <unroll: 1.1070 | vae : 2.2563 | kl : 0.0000>\n",
      "04-Jun-21 12:53:34 | == gmse <train: 0.1014 | val: 0.0940> \n",
      "04-Jun-21 12:54:04 | Epoch 0165 | lr: 0.00000201 | Time(s): 30.0288\n",
      "04-Jun-21 12:54:04 | == train Loss <unroll: 1.1069 | vae : 2.2557 | kl : 0.0000>\n",
      "04-Jun-21 12:54:04 | == gmse <train: 0.1013 | val: 0.0936> \n",
      "04-Jun-21 12:54:34 | Epoch 0166 | lr: 0.00000190 | Time(s): 30.0301\n",
      "04-Jun-21 12:54:34 | == train Loss <unroll: 1.1069 | vae : 2.2554 | kl : 0.0000>\n",
      "04-Jun-21 12:54:34 | == gmse <train: 0.1013 | val: 0.0935> \n",
      "04-Jun-21 12:55:04 | Epoch 0167 | lr: 0.00000181 | Time(s): 30.0305\n",
      "04-Jun-21 12:55:04 | == train Loss <unroll: 1.1069 | vae : 2.2545 | kl : 0.0000>\n",
      "04-Jun-21 12:55:04 | == gmse <train: 0.1013 | val: 0.0936> \n",
      "04-Jun-21 12:55:34 | Epoch 0168 | lr: 0.00000172 | Time(s): 30.0298\n",
      "04-Jun-21 12:55:34 | == train Loss <unroll: 1.1068 | vae : 2.2542 | kl : 0.0000>\n",
      "04-Jun-21 12:55:34 | == gmse <train: 0.1013 | val: 0.0948> \n",
      "04-Jun-21 12:56:04 | Epoch 0169 | lr: 0.00000163 | Time(s): 30.0303\n",
      "04-Jun-21 12:56:04 | == train Loss <unroll: 1.1068 | vae : 2.2535 | kl : 0.0000>\n",
      "04-Jun-21 12:56:04 | == gmse <train: 0.1013 | val: 0.0942> \n",
      "04-Jun-21 12:56:34 | Epoch 0170 | lr: 0.00000155 | Time(s): 30.0302\n",
      "04-Jun-21 12:56:34 | == train Loss <unroll: 1.1068 | vae : 2.2530 | kl : 0.0000>\n",
      "04-Jun-21 12:56:34 | == gmse <train: 0.1013 | val: 0.0937> \n",
      "04-Jun-21 12:57:04 | Epoch 0171 | lr: 0.00000147 | Time(s): 30.0304\n",
      "04-Jun-21 12:57:04 | == train Loss <unroll: 1.1067 | vae : 2.2524 | kl : 0.0000>\n",
      "04-Jun-21 12:57:04 | == gmse <train: 0.1013 | val: 0.0945> \n",
      "04-Jun-21 12:57:35 | Epoch 0172 | lr: 0.00000140 | Time(s): 30.0306\n",
      "04-Jun-21 12:57:35 | == train Loss <unroll: 1.1068 | vae : 2.2521 | kl : 0.0000>\n",
      "04-Jun-21 12:57:35 | == gmse <train: 0.1013 | val: 0.0944> \n",
      "04-Jun-21 12:58:05 | Epoch 0173 | lr: 0.00000133 | Time(s): 30.0307\n",
      "04-Jun-21 12:58:05 | == train Loss <unroll: 1.1067 | vae : 2.2517 | kl : 0.0000>\n",
      "04-Jun-21 12:58:05 | == gmse <train: 0.1012 | val: 0.0935> \n",
      "04-Jun-21 12:58:35 | Epoch 0174 | lr: 0.00000126 | Time(s): 30.0309\n",
      "04-Jun-21 12:58:35 | == train Loss <unroll: 1.1067 | vae : 2.2511 | kl : 0.0000>\n",
      "04-Jun-21 12:58:35 | == gmse <train: 0.1012 | val: 0.0937> \n",
      "04-Jun-21 12:59:05 | Epoch 0175 | lr: 0.00000120 | Time(s): 30.0311\n",
      "04-Jun-21 12:59:05 | == train Loss <unroll: 1.1067 | vae : 2.2507 | kl : 0.0000>\n",
      "04-Jun-21 12:59:05 | == gmse <train: 0.1012 | val: 0.0935> \n",
      "04-Jun-21 12:59:35 | Epoch 0176 | lr: 0.00000114 | Time(s): 30.0312\n",
      "04-Jun-21 12:59:35 | == train Loss <unroll: 1.1067 | vae : 2.2502 | kl : 0.0000>\n",
      "04-Jun-21 12:59:35 | == gmse <train: 0.1012 | val: 0.0938> \n",
      "04-Jun-21 13:00:05 | Epoch 0177 | lr: 0.00000108 | Time(s): 30.0318\n",
      "04-Jun-21 13:00:05 | == train Loss <unroll: 1.1066 | vae : 2.2499 | kl : 0.0000>\n",
      "04-Jun-21 13:00:05 | == gmse <train: 0.1012 | val: 0.0941> \n",
      "04-Jun-21 13:00:35 | Epoch 0178 | lr: 0.00000103 | Time(s): 30.0327\n",
      "04-Jun-21 13:00:35 | == train Loss <unroll: 1.1066 | vae : 2.2494 | kl : 0.0000>\n",
      "04-Jun-21 13:00:35 | == gmse <train: 0.1012 | val: 0.0939> \n",
      "04-Jun-21 13:01:05 | Epoch 0179 | lr: 0.00000098 | Time(s): 30.0337\n",
      "04-Jun-21 13:01:05 | == train Loss <unroll: 1.1066 | vae : 2.2493 | kl : 0.0000>\n",
      "04-Jun-21 13:01:05 | == gmse <train: 0.1012 | val: 0.0942> \n",
      "04-Jun-21 13:01:36 | Epoch 0180 | lr: 0.00000093 | Time(s): 30.0346\n",
      "04-Jun-21 13:01:36 | == train Loss <unroll: 1.1066 | vae : 2.2489 | kl : 0.0000>\n",
      "04-Jun-21 13:01:36 | == gmse <train: 0.1012 | val: 0.0938> \n",
      "04-Jun-21 13:02:06 | Epoch 0181 | lr: 0.00000088 | Time(s): 30.0355\n",
      "04-Jun-21 13:02:06 | == train Loss <unroll: 1.1066 | vae : 2.2486 | kl : 0.0000>\n",
      "04-Jun-21 13:02:06 | == gmse <train: 0.1012 | val: 0.0940> \n",
      "04-Jun-21 13:02:36 | Epoch 0182 | lr: 0.00000084 | Time(s): 30.0364\n",
      "04-Jun-21 13:02:36 | == train Loss <unroll: 1.1066 | vae : 2.2483 | kl : 0.0000>\n",
      "04-Jun-21 13:02:36 | == gmse <train: 0.1012 | val: 0.0940> \n",
      "04-Jun-21 13:03:06 | Epoch 0183 | lr: 0.00000080 | Time(s): 30.0366\n",
      "04-Jun-21 13:03:06 | == train Loss <unroll: 1.1066 | vae : 2.2480 | kl : 0.0000>\n",
      "04-Jun-21 13:03:06 | == gmse <train: 0.1012 | val: 0.0937> \n",
      "04-Jun-21 13:03:36 | Epoch 0184 | lr: 0.00000076 | Time(s): 30.0365\n",
      "04-Jun-21 13:03:36 | == train Loss <unroll: 1.1065 | vae : 2.2475 | kl : 0.0000>\n",
      "04-Jun-21 13:03:36 | == gmse <train: 0.1012 | val: 0.0936> \n",
      "04-Jun-21 13:04:06 | Epoch 0185 | lr: 0.00000072 | Time(s): 30.0369\n",
      "04-Jun-21 13:04:06 | == train Loss <unroll: 1.1065 | vae : 2.2475 | kl : 0.0000>\n",
      "04-Jun-21 13:04:06 | == gmse <train: 0.1012 | val: 0.0938> \n",
      "04-Jun-21 13:04:36 | Epoch 0186 | lr: 0.00000068 | Time(s): 30.0370\n",
      "04-Jun-21 13:04:36 | == train Loss <unroll: 1.1065 | vae : 2.2473 | kl : 0.0000>\n",
      "04-Jun-21 13:04:36 | == gmse <train: 0.1012 | val: 0.0940> \n",
      "04-Jun-21 13:05:06 | Epoch 0187 | lr: 0.00000065 | Time(s): 30.0368\n",
      "04-Jun-21 13:05:06 | == train Loss <unroll: 1.1065 | vae : 2.2471 | kl : 0.0000>\n",
      "04-Jun-21 13:05:06 | == gmse <train: 0.1012 | val: 0.0935> \n",
      "04-Jun-21 13:05:36 | Epoch 0188 | lr: 0.00000062 | Time(s): 30.0368\n",
      "04-Jun-21 13:05:36 | == train Loss <unroll: 1.1065 | vae : 2.2468 | kl : 0.0000>\n",
      "04-Jun-21 13:05:36 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:06:06 | Epoch 0189 | lr: 0.00000059 | Time(s): 30.0373\n",
      "04-Jun-21 13:06:06 | == train Loss <unroll: 1.1065 | vae : 2.2465 | kl : 0.0000>\n",
      "04-Jun-21 13:06:06 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:06:36 | Epoch 0190 | lr: 0.00000056 | Time(s): 30.0376\n",
      "04-Jun-21 13:06:36 | == train Loss <unroll: 1.1065 | vae : 2.2463 | kl : 0.0000>\n",
      "04-Jun-21 13:06:36 | == gmse <train: 0.1011 | val: 0.0936> \n",
      "04-Jun-21 13:07:07 | Epoch 0191 | lr: 0.00000053 | Time(s): 30.0377\n",
      "04-Jun-21 13:07:07 | == train Loss <unroll: 1.1065 | vae : 2.2461 | kl : 0.0000>\n",
      "04-Jun-21 13:07:07 | == gmse <train: 0.1011 | val: 0.0941> \n",
      "04-Jun-21 13:07:37 | Epoch 0192 | lr: 0.00000050 | Time(s): 30.0374\n",
      "04-Jun-21 13:07:37 | == train Loss <unroll: 1.1065 | vae : 2.2460 | kl : 0.0000>\n",
      "04-Jun-21 13:07:37 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:08:06 | Epoch 0193 | lr: 0.00000048 | Time(s): 30.0369\n",
      "04-Jun-21 13:08:06 | == train Loss <unroll: 1.1064 | vae : 2.2459 | kl : 0.0000>\n",
      "04-Jun-21 13:08:06 | == gmse <train: 0.1011 | val: 0.0940> \n",
      "04-Jun-21 13:08:36 | Epoch 0194 | lr: 0.00000045 | Time(s): 30.0365\n",
      "04-Jun-21 13:08:36 | == train Loss <unroll: 1.1065 | vae : 2.2456 | kl : 0.0000>\n",
      "04-Jun-21 13:08:36 | == gmse <train: 0.1011 | val: 0.0935> \n",
      "04-Jun-21 13:09:06 | Epoch 0195 | lr: 0.00000043 | Time(s): 30.0360\n",
      "04-Jun-21 13:09:06 | == train Loss <unroll: 1.1064 | vae : 2.2454 | kl : 0.0000>\n",
      "04-Jun-21 13:09:06 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:09:36 | Epoch 0196 | lr: 0.00000041 | Time(s): 30.0350\n",
      "04-Jun-21 13:09:36 | == train Loss <unroll: 1.1064 | vae : 2.2453 | kl : 0.0000>\n",
      "04-Jun-21 13:09:36 | == gmse <train: 0.1011 | val: 0.0940> \n",
      "04-Jun-21 13:10:06 | Epoch 0197 | lr: 0.00000039 | Time(s): 30.0347\n",
      "04-Jun-21 13:10:06 | == train Loss <unroll: 1.1064 | vae : 2.2451 | kl : 0.0000>\n",
      "04-Jun-21 13:10:06 | == gmse <train: 0.1011 | val: 0.0936> \n",
      "04-Jun-21 13:10:36 | Epoch 0198 | lr: 0.00000037 | Time(s): 30.0343\n",
      "04-Jun-21 13:10:36 | == train Loss <unroll: 1.1064 | vae : 2.2450 | kl : 0.0000>\n",
      "04-Jun-21 13:10:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:11:06 | Epoch 0199 | lr: 0.00000035 | Time(s): 30.0335\n",
      "04-Jun-21 13:11:06 | == train Loss <unroll: 1.1064 | vae : 2.2448 | kl : 0.0000>\n",
      "04-Jun-21 13:11:06 | == gmse <train: 0.1011 | val: 0.0939> \n",
      "04-Jun-21 13:11:36 | Epoch 0200 | lr: 0.00000033 | Time(s): 30.0326\n",
      "04-Jun-21 13:11:36 | == train Loss <unroll: 1.1064 | vae : 2.2448 | kl : 0.0000>\n",
      "04-Jun-21 13:11:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:12:06 | Epoch 0201 | lr: 0.00000032 | Time(s): 30.0319\n",
      "04-Jun-21 13:12:06 | == train Loss <unroll: 1.1064 | vae : 2.2446 | kl : 0.0000>\n",
      "04-Jun-21 13:12:06 | == gmse <train: 0.1011 | val: 0.0939> \n",
      "04-Jun-21 13:12:36 | Epoch 0202 | lr: 0.00000030 | Time(s): 30.0310\n",
      "04-Jun-21 13:12:36 | == train Loss <unroll: 1.1064 | vae : 2.2444 | kl : 0.0000>\n",
      "04-Jun-21 13:12:36 | == gmse <train: 0.1011 | val: 0.0939> \n",
      "04-Jun-21 13:13:05 | Epoch 0203 | lr: 0.00000029 | Time(s): 30.0300\n",
      "04-Jun-21 13:13:05 | == train Loss <unroll: 1.1064 | vae : 2.2444 | kl : 0.0000>\n",
      "04-Jun-21 13:13:05 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:13:35 | Epoch 0204 | lr: 0.00000027 | Time(s): 30.0290\n",
      "04-Jun-21 13:13:35 | == train Loss <unroll: 1.1064 | vae : 2.2443 | kl : 0.0000>\n",
      "04-Jun-21 13:13:35 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:14:05 | Epoch 0205 | lr: 0.00000026 | Time(s): 30.0281\n",
      "04-Jun-21 13:14:05 | == train Loss <unroll: 1.1064 | vae : 2.2443 | kl : 0.0000>\n",
      "04-Jun-21 13:14:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:14:35 | Epoch 0206 | lr: 0.00000024 | Time(s): 30.0270\n",
      "04-Jun-21 13:14:35 | == train Loss <unroll: 1.1064 | vae : 2.2441 | kl : 0.0000>\n",
      "04-Jun-21 13:14:35 | == gmse <train: 0.1011 | val: 0.0941> \n",
      "04-Jun-21 13:15:05 | Epoch 0207 | lr: 0.00000023 | Time(s): 30.0265\n",
      "04-Jun-21 13:15:05 | == train Loss <unroll: 1.1064 | vae : 2.2440 | kl : 0.0000>\n",
      "04-Jun-21 13:15:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:15:35 | Epoch 0208 | lr: 0.00000022 | Time(s): 30.0263\n",
      "04-Jun-21 13:15:35 | == train Loss <unroll: 1.1064 | vae : 2.2439 | kl : 0.0000>\n",
      "04-Jun-21 13:15:35 | == gmse <train: 0.1011 | val: 0.0936> \n",
      "04-Jun-21 13:16:05 | Epoch 0209 | lr: 0.00000021 | Time(s): 30.0255\n",
      "04-Jun-21 13:16:05 | == train Loss <unroll: 1.1064 | vae : 2.2438 | kl : 0.0000>\n",
      "04-Jun-21 13:16:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:16:35 | Epoch 0210 | lr: 0.00000020 | Time(s): 30.0246\n",
      "04-Jun-21 13:16:35 | == train Loss <unroll: 1.1064 | vae : 2.2437 | kl : 0.0000>\n",
      "04-Jun-21 13:16:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:17:04 | Epoch 0211 | lr: 0.00000019 | Time(s): 30.0239\n",
      "04-Jun-21 13:17:04 | == train Loss <unroll: 1.1064 | vae : 2.2436 | kl : 0.0000>\n",
      "04-Jun-21 13:17:04 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:17:34 | Epoch 0212 | lr: 0.00000018 | Time(s): 30.0238\n",
      "04-Jun-21 13:17:34 | == train Loss <unroll: 1.1064 | vae : 2.2436 | kl : 0.0000>\n",
      "04-Jun-21 13:17:34 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:18:04 | Epoch 0213 | lr: 0.00000017 | Time(s): 30.0232\n",
      "04-Jun-21 13:18:04 | == train Loss <unroll: 1.1064 | vae : 2.2435 | kl : 0.0000>\n",
      "04-Jun-21 13:18:04 | == gmse <train: 0.1011 | val: 0.0940> \n",
      "04-Jun-21 13:18:34 | Epoch 0214 | lr: 0.00000016 | Time(s): 30.0218\n",
      "04-Jun-21 13:18:34 | == train Loss <unroll: 1.1064 | vae : 2.2435 | kl : 0.0000>\n",
      "04-Jun-21 13:18:34 | == gmse <train: 0.1011 | val: 0.0939> \n",
      "04-Jun-21 13:19:04 | Epoch 0215 | lr: 0.00000015 | Time(s): 30.0209\n",
      "04-Jun-21 13:19:04 | == train Loss <unroll: 1.1064 | vae : 2.2434 | kl : 0.0000>\n",
      "04-Jun-21 13:19:04 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:19:34 | Epoch 0216 | lr: 0.00000015 | Time(s): 30.0200\n",
      "04-Jun-21 13:19:34 | == train Loss <unroll: 1.1063 | vae : 2.2433 | kl : 0.0000>\n",
      "04-Jun-21 13:19:34 | == gmse <train: 0.1011 | val: 0.0936> \n",
      "04-Jun-21 13:20:03 | Epoch 0217 | lr: 0.00000014 | Time(s): 30.0187\n",
      "04-Jun-21 13:20:03 | == train Loss <unroll: 1.1064 | vae : 2.2433 | kl : 0.0000>\n",
      "04-Jun-21 13:20:03 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:20:33 | Epoch 0218 | lr: 0.00000013 | Time(s): 30.0173\n",
      "04-Jun-21 13:20:33 | == train Loss <unroll: 1.1063 | vae : 2.2432 | kl : 0.0000>\n",
      "04-Jun-21 13:20:33 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:21:04 | Epoch 0219 | lr: 0.00000013 | Time(s): 30.0186\n",
      "04-Jun-21 13:21:04 | == train Loss <unroll: 1.1063 | vae : 2.2431 | kl : 0.0000>\n",
      "04-Jun-21 13:21:04 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:21:33 | Epoch 0220 | lr: 0.00000012 | Time(s): 30.0184\n",
      "04-Jun-21 13:21:33 | == train Loss <unroll: 1.1063 | vae : 2.2431 | kl : 0.0000>\n",
      "04-Jun-21 13:21:33 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:22:03 | Epoch 0221 | lr: 0.00000011 | Time(s): 30.0180\n",
      "04-Jun-21 13:22:03 | == train Loss <unroll: 1.1063 | vae : 2.2431 | kl : 0.0000>\n",
      "04-Jun-21 13:22:03 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:22:33 | Epoch 0222 | lr: 0.00000011 | Time(s): 30.0178\n",
      "04-Jun-21 13:22:33 | == train Loss <unroll: 1.1063 | vae : 2.2430 | kl : 0.0000>\n",
      "04-Jun-21 13:22:33 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:23:03 | Epoch 0223 | lr: 0.00000010 | Time(s): 30.0176\n",
      "04-Jun-21 13:23:03 | == train Loss <unroll: 1.1063 | vae : 2.2430 | kl : 0.0000>\n",
      "04-Jun-21 13:23:03 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:23:33 | Epoch 0224 | lr: 0.00000010 | Time(s): 30.0176\n",
      "04-Jun-21 13:23:33 | == train Loss <unroll: 1.1063 | vae : 2.2429 | kl : 0.0000>\n",
      "04-Jun-21 13:23:33 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:24:04 | Epoch 0225 | lr: 0.00000009 | Time(s): 30.0183\n",
      "04-Jun-21 13:24:04 | == train Loss <unroll: 1.1063 | vae : 2.2428 | kl : 0.0000>\n",
      "04-Jun-21 13:24:04 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:24:34 | Epoch 0226 | lr: 0.00000009 | Time(s): 30.0190\n",
      "04-Jun-21 13:24:34 | == train Loss <unroll: 1.1063 | vae : 2.2429 | kl : 0.0000>\n",
      "04-Jun-21 13:24:34 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:25:04 | Epoch 0227 | lr: 0.00000008 | Time(s): 30.0199\n",
      "04-Jun-21 13:25:04 | == train Loss <unroll: 1.1063 | vae : 2.2428 | kl : 0.0000>\n",
      "04-Jun-21 13:25:04 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:25:34 | Epoch 0228 | lr: 0.00000008 | Time(s): 30.0205\n",
      "04-Jun-21 13:25:34 | == train Loss <unroll: 1.1063 | vae : 2.2428 | kl : 0.0000>\n",
      "04-Jun-21 13:25:34 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:26:04 | Epoch 0229 | lr: 0.00000008 | Time(s): 30.0210\n",
      "04-Jun-21 13:26:04 | == train Loss <unroll: 1.1063 | vae : 2.2427 | kl : 0.0000>\n",
      "04-Jun-21 13:26:04 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:26:34 | Epoch 0230 | lr: 0.00000007 | Time(s): 30.0219\n",
      "04-Jun-21 13:26:34 | == train Loss <unroll: 1.1063 | vae : 2.2427 | kl : 0.0000>\n",
      "04-Jun-21 13:26:34 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:27:05 | Epoch 0231 | lr: 0.00000007 | Time(s): 30.0221\n",
      "04-Jun-21 13:27:05 | == train Loss <unroll: 1.1063 | vae : 2.2427 | kl : 0.0000>\n",
      "04-Jun-21 13:27:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:27:35 | Epoch 0232 | lr: 0.00000006 | Time(s): 30.0219\n",
      "04-Jun-21 13:27:35 | == train Loss <unroll: 1.1063 | vae : 2.2427 | kl : 0.0000>\n",
      "04-Jun-21 13:27:35 | == gmse <train: 0.1011 | val: 0.0936> \n",
      "04-Jun-21 13:28:05 | Epoch 0233 | lr: 0.00000006 | Time(s): 30.0218\n",
      "04-Jun-21 13:28:05 | == train Loss <unroll: 1.1063 | vae : 2.2426 | kl : 0.0000>\n",
      "04-Jun-21 13:28:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:28:35 | Epoch 0234 | lr: 0.00000006 | Time(s): 30.0218\n",
      "04-Jun-21 13:28:35 | == train Loss <unroll: 1.1063 | vae : 2.2426 | kl : 0.0000>\n",
      "04-Jun-21 13:28:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:29:05 | Epoch 0235 | lr: 0.00000006 | Time(s): 30.0218\n",
      "04-Jun-21 13:29:05 | == train Loss <unroll: 1.1063 | vae : 2.2425 | kl : 0.0000>\n",
      "04-Jun-21 13:29:05 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:29:35 | Epoch 0236 | lr: 0.00000005 | Time(s): 30.0218\n",
      "04-Jun-21 13:29:35 | == train Loss <unroll: 1.1063 | vae : 2.2426 | kl : 0.0000>\n",
      "04-Jun-21 13:29:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:30:05 | Epoch 0237 | lr: 0.00000005 | Time(s): 30.0226\n",
      "04-Jun-21 13:30:05 | == train Loss <unroll: 1.1063 | vae : 2.2425 | kl : 0.0000>\n",
      "04-Jun-21 13:30:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:30:35 | Epoch 0238 | lr: 0.00000005 | Time(s): 30.0232\n",
      "04-Jun-21 13:30:35 | == train Loss <unroll: 1.1063 | vae : 2.2425 | kl : 0.0000>\n",
      "04-Jun-21 13:30:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:31:05 | Epoch 0239 | lr: 0.00000005 | Time(s): 30.0240\n",
      "04-Jun-21 13:31:05 | == train Loss <unroll: 1.1063 | vae : 2.2425 | kl : 0.0000>\n",
      "04-Jun-21 13:31:05 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:31:35 | Epoch 0240 | lr: 0.00000004 | Time(s): 30.0237\n",
      "04-Jun-21 13:31:35 | == train Loss <unroll: 1.1063 | vae : 2.2425 | kl : 0.0000>\n",
      "04-Jun-21 13:31:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:32:05 | Epoch 0241 | lr: 0.00000004 | Time(s): 30.0236\n",
      "04-Jun-21 13:32:05 | == train Loss <unroll: 1.1063 | vae : 2.2424 | kl : 0.0000>\n",
      "04-Jun-21 13:32:05 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:32:35 | Epoch 0242 | lr: 0.00000004 | Time(s): 30.0234\n",
      "04-Jun-21 13:32:35 | == train Loss <unroll: 1.1063 | vae : 2.2424 | kl : 0.0000>\n",
      "04-Jun-21 13:32:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:33:05 | Epoch 0243 | lr: 0.00000004 | Time(s): 30.0232\n",
      "04-Jun-21 13:33:05 | == train Loss <unroll: 1.1063 | vae : 2.2424 | kl : 0.0000>\n",
      "04-Jun-21 13:33:05 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:33:35 | Epoch 0244 | lr: 0.00000003 | Time(s): 30.0231\n",
      "04-Jun-21 13:33:35 | == train Loss <unroll: 1.1063 | vae : 2.2424 | kl : 0.0000>\n",
      "04-Jun-21 13:33:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:34:05 | Epoch 0245 | lr: 0.00000003 | Time(s): 30.0234\n",
      "04-Jun-21 13:34:05 | == train Loss <unroll: 1.1063 | vae : 2.2423 | kl : 0.0000>\n",
      "04-Jun-21 13:34:05 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:34:35 | Epoch 0246 | lr: 0.00000003 | Time(s): 30.0238\n",
      "04-Jun-21 13:34:35 | == train Loss <unroll: 1.1063 | vae : 2.2423 | kl : 0.0000>\n",
      "04-Jun-21 13:34:35 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:35:05 | Epoch 0247 | lr: 0.00000003 | Time(s): 30.0240\n",
      "04-Jun-21 13:35:05 | == train Loss <unroll: 1.1063 | vae : 2.2423 | kl : 0.0000>\n",
      "04-Jun-21 13:35:05 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:35:36 | Epoch 0248 | lr: 0.00000003 | Time(s): 30.0243\n",
      "04-Jun-21 13:35:36 | == train Loss <unroll: 1.1063 | vae : 2.2423 | kl : 0.0000>\n",
      "04-Jun-21 13:35:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:36:06 | Epoch 0249 | lr: 0.00000003 | Time(s): 30.0248\n",
      "04-Jun-21 13:36:06 | == train Loss <unroll: 1.1063 | vae : 2.2423 | kl : 0.0000>\n",
      "04-Jun-21 13:36:06 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:36:36 | Epoch 0250 | lr: 0.00000003 | Time(s): 30.0256\n",
      "04-Jun-21 13:36:36 | == train Loss <unroll: 1.1063 | vae : 2.2423 | kl : 0.0000>\n",
      "04-Jun-21 13:36:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:37:06 | Epoch 0251 | lr: 0.00000002 | Time(s): 30.0255\n",
      "04-Jun-21 13:37:06 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:37:06 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:37:36 | Epoch 0252 | lr: 0.00000002 | Time(s): 30.0255\n",
      "04-Jun-21 13:37:36 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:37:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:38:06 | Epoch 0253 | lr: 0.00000002 | Time(s): 30.0254\n",
      "04-Jun-21 13:38:06 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:38:06 | == gmse <train: 0.1011 | val: 0.0937> \n",
      "04-Jun-21 13:38:36 | Epoch 0254 | lr: 0.00000002 | Time(s): 30.0253\n",
      "04-Jun-21 13:38:36 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:38:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:39:06 | Epoch 0255 | lr: 0.00000002 | Time(s): 30.0260\n",
      "04-Jun-21 13:39:06 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:39:06 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:39:36 | Epoch 0256 | lr: 0.00000002 | Time(s): 30.0268\n",
      "04-Jun-21 13:39:36 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:39:36 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:40:07 | Epoch 0257 | lr: 0.00000002 | Time(s): 30.0275\n",
      "04-Jun-21 13:40:07 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:40:07 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:40:37 | Epoch 0258 | lr: 0.00000002 | Time(s): 30.0282\n",
      "04-Jun-21 13:40:37 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:40:37 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:41:07 | Epoch 0259 | lr: 0.00000002 | Time(s): 30.0286\n",
      "04-Jun-21 13:41:07 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:41:07 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:41:37 | Epoch 0260 | lr: 0.00000002 | Time(s): 30.0291\n",
      "04-Jun-21 13:41:37 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:41:37 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:42:07 | Epoch 0261 | lr: 0.00000001 | Time(s): 30.0289\n",
      "04-Jun-21 13:42:07 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:42:07 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:42:37 | Epoch 0262 | lr: 0.00000001 | Time(s): 30.0290\n",
      "04-Jun-21 13:42:37 | == train Loss <unroll: 1.1063 | vae : 2.2422 | kl : 0.0000>\n",
      "04-Jun-21 13:42:37 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:43:07 | Epoch 0263 | lr: 0.00000001 | Time(s): 30.0297\n",
      "04-Jun-21 13:43:07 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:43:07 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:43:37 | Epoch 0264 | lr: 0.00000001 | Time(s): 30.0300\n",
      "04-Jun-21 13:43:37 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:43:37 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:44:08 | Epoch 0265 | lr: 0.00000001 | Time(s): 30.0307\n",
      "04-Jun-21 13:44:08 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:44:08 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:44:38 | Epoch 0266 | lr: 0.00000001 | Time(s): 30.0317\n",
      "04-Jun-21 13:44:38 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:44:38 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:45:08 | Epoch 0267 | lr: 0.00000001 | Time(s): 30.0319\n",
      "04-Jun-21 13:45:08 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:45:08 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:45:38 | Epoch 0268 | lr: 0.00000001 | Time(s): 30.0320\n",
      "04-Jun-21 13:45:38 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:45:38 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:46:08 | Epoch 0269 | lr: 0.00000001 | Time(s): 30.0322\n",
      "04-Jun-21 13:46:08 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:46:08 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:46:38 | Epoch 0270 | lr: 0.00000001 | Time(s): 30.0326\n",
      "04-Jun-21 13:46:38 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:46:38 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:47:08 | Epoch 0271 | lr: 0.00000001 | Time(s): 30.0327\n",
      "04-Jun-21 13:47:08 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:47:08 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:47:39 | Epoch 0272 | lr: 0.00000001 | Time(s): 30.0329\n",
      "04-Jun-21 13:47:39 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:47:39 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:48:09 | Epoch 0273 | lr: 0.00000001 | Time(s): 30.0328\n",
      "04-Jun-21 13:48:09 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:48:09 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:48:39 | Epoch 0274 | lr: 0.00000001 | Time(s): 30.0331\n",
      "04-Jun-21 13:48:39 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:48:39 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:49:09 | Epoch 0275 | lr: 0.00000001 | Time(s): 30.0335\n",
      "04-Jun-21 13:49:09 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:49:09 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:49:39 | Epoch 0276 | lr: 0.00000001 | Time(s): 30.0338\n",
      "04-Jun-21 13:49:39 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:49:39 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:50:09 | Epoch 0277 | lr: 0.00000001 | Time(s): 30.0340\n",
      "04-Jun-21 13:50:09 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:50:09 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:50:39 | Epoch 0278 | lr: 0.00000001 | Time(s): 30.0345\n",
      "04-Jun-21 13:50:39 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:50:39 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:51:09 | Epoch 0279 | lr: 0.00000001 | Time(s): 30.0346\n",
      "04-Jun-21 13:51:09 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:51:09 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:51:39 | Epoch 0280 | lr: 0.00000001 | Time(s): 30.0346\n",
      "04-Jun-21 13:51:39 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:51:39 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:52:09 | Epoch 0281 | lr: 0.00000001 | Time(s): 30.0346\n",
      "04-Jun-21 13:52:09 | == train Loss <unroll: 1.1063 | vae : 2.2421 | kl : 0.0000>\n",
      "04-Jun-21 13:52:09 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:52:39 | Epoch 0282 | lr: 0.00000000 | Time(s): 30.0346\n",
      "04-Jun-21 13:52:39 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:52:39 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:53:09 | Epoch 0283 | lr: 0.00000000 | Time(s): 30.0347\n",
      "04-Jun-21 13:53:09 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:53:09 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:53:40 | Epoch 0284 | lr: 0.00000000 | Time(s): 30.0354\n",
      "04-Jun-21 13:53:40 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:53:40 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:54:10 | Epoch 0285 | lr: 0.00000000 | Time(s): 30.0357\n",
      "04-Jun-21 13:54:10 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:54:10 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:54:40 | Epoch 0286 | lr: 0.00000000 | Time(s): 30.0360\n",
      "04-Jun-21 13:54:40 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:54:40 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:55:10 | Epoch 0287 | lr: 0.00000000 | Time(s): 30.0363\n",
      "04-Jun-21 13:55:10 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:55:10 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:55:40 | Epoch 0288 | lr: 0.00000000 | Time(s): 30.0366\n",
      "04-Jun-21 13:55:40 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:55:40 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:56:10 | Epoch 0289 | lr: 0.00000000 | Time(s): 30.0369\n",
      "04-Jun-21 13:56:10 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:56:10 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:56:40 | Epoch 0290 | lr: 0.00000000 | Time(s): 30.0372\n",
      "04-Jun-21 13:56:40 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:56:40 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:57:10 | Epoch 0291 | lr: 0.00000000 | Time(s): 30.0373\n",
      "04-Jun-21 13:57:10 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:57:10 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:57:41 | Epoch 0292 | lr: 0.00000000 | Time(s): 30.0375\n",
      "04-Jun-21 13:57:41 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:57:41 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:58:11 | Epoch 0293 | lr: 0.00000000 | Time(s): 30.0376\n",
      "04-Jun-21 13:58:11 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:58:11 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:58:41 | Epoch 0294 | lr: 0.00000000 | Time(s): 30.0377\n",
      "04-Jun-21 13:58:41 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:58:41 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:59:11 | Epoch 0295 | lr: 0.00000000 | Time(s): 30.0378\n",
      "04-Jun-21 13:59:11 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:59:11 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 13:59:41 | Epoch 0296 | lr: 0.00000000 | Time(s): 30.0377\n",
      "04-Jun-21 13:59:41 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 13:59:41 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 14:00:11 | Epoch 0297 | lr: 0.00000000 | Time(s): 30.0382\n",
      "04-Jun-21 14:00:11 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 14:00:11 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 14:00:41 | Epoch 0298 | lr: 0.00000000 | Time(s): 30.0381\n",
      "04-Jun-21 14:00:41 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 14:00:41 | == gmse <train: 0.1011 | val: 0.0938> \n",
      "04-Jun-21 14:01:11 | Epoch 0299 | lr: 0.00000000 | Time(s): 30.0379\n",
      "04-Jun-21 14:01:11 | == train Loss <unroll: 1.1063 | vae : 2.2420 | kl : 0.0000>\n",
      "04-Jun-21 14:01:11 | == gmse <train: 0.1011 | val: 0.0938> \n"
     ]
    }
   ],
   "source": [
    "# Training:\n",
    "n_epochs = 300\n",
    "\n",
    "dur = []\n",
    "\n",
    "epoch_train_gmse = []\n",
    "epoch_val_gmse = []\n",
    "\n",
    "for epoch in range(n_epochs):\n",
    "\n",
    "    train_unrolling_loss, train_vae_loss, train_kl_loss, train_gmse, val_gmse = [], [], [], [], []\n",
    "\n",
    "    t0 = time.time()\n",
    "\n",
    "    net.train()\n",
    "    for z, w_gt_batch in train_loader:\n",
    "        z = z.to(device)\n",
    "        w_gt_batch = w_gt_batch.to(device)\n",
    "        this_batch_size = w_gt_batch.size()[0]\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "        w_list, vae_loss, vae_kl, _ = net.forward(z, w_gt_batch, threshold=1e-04, kl_hyper=1)\n",
    "\n",
    "        unrolling_loss = torch.mean(\n",
    "            torch.stack([acc_loss(w_list[i, :, :], w_gt_batch[i, :], dn=0.9) for i in range(batch_size)])\n",
    "        )\n",
    "\n",
    "        loss = unrolling_loss + vae_loss\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        w_pred = w_list[:, num_unroll - 1, :]\n",
    "        gmse = gmse_loss_batch_mean(w_pred, w_gt_batch)\n",
    "\n",
    "        train_gmse.append(gmse.item())\n",
    "        train_unrolling_loss.append(unrolling_loss.item())\n",
    "        train_vae_loss.append(vae_loss.item())\n",
    "        train_kl_loss.append(vae_kl.item())\n",
    "\n",
    "    scheduler.step()\n",
    "\n",
    "    net.eval()\n",
    "    for z, w_gt_batch in val_loader:\n",
    "        z = z.to(device)\n",
    "        w_gt_batch = w_gt_batch.to(device)\n",
    "\n",
    "        w_list = net.validation(z, threshold=1e-04)\n",
    "        w_pred = torch.clamp(w_list[:, num_unroll - 1, :], min=0)\n",
    "        loss = gmse_loss_batch_mean(w_pred, w_gt_batch)\n",
    "        val_gmse.append(loss.item())\n",
    "\n",
    "    dur.append(time.time() - t0)\n",
    "\n",
    "    logging.info(\"Epoch {:04d} | lr: {:04.8f} | Time(s): {:.4f}\".format(epoch + 1, scheduler.get_lr()[0], np.mean(dur)))\n",
    "    logging.info(\"== train Loss <unroll: {:04.4f} | vae : {:04.4f} | kl : {:04.4f}>\".format(np.mean(train_unrolling_loss),\n",
    "                                                                                  np.mean(train_vae_loss),\n",
    "                                                                                  np.mean(train_kl_loss)))\n",
    "    logging.info(\"== gmse <train: {:04.4f} | val: {:04.4f}> \".format(np.mean(train_gmse), np.mean(val_gmse)))\n",
    "\n",
    "    epoch_train_gmse.append(np.mean(train_gmse))\n",
    "    epoch_val_gmse.append(np.mean(val_gmse))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "04-Jun-21 14:34:17 | model saved at: saved_model/L2G_WS50_unroll20.pt\n"
     ]
    }
   ],
   "source": [
    "# save trained model\n",
    "\n",
    "save_path = 'saved_model/L2G_{}{}_unroll{}.pt'.format(graph_type,\n",
    "                                                      graph_size,\n",
    "                                                      num_unroll)\n",
    "\n",
    "torch.save({'net_state_dict': net.state_dict(),\n",
    "            'optimiser_state_dict': optimizer.state_dict()\n",
    "            }, save_path)\n",
    "\n",
    "\n",
    "logging.info('model saved at: {}'.format(save_path))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Test / Inference"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "04-Jun-21 14:40:11 | GMSE: 0.09289076179265976 +- 0.0029431590516546023\n",
      "04-Jun-21 14:40:11 | aps: 0.9963036197528777 +- 0.0007225115197087517\n",
      "04-Jun-21 14:40:11 | auc: 0.9992655555555555 +- 0.00039366530730706285\n",
      "04-Jun-21 14:40:11 | layerwise test loss :[1.4559345, 0.89995754, 0.23471525, 0.14071073, 0.1402622, 0.17302305, 0.14294592, 0.12140663, 0.15670082, 0.14045528, 0.10375355, 0.0888529, 0.09007615, 0.0938451, 0.08667662, 0.086669095, 0.086669095, 0.086669095, 0.08666909, 0.10030652]\n"
     ]
    }
   ],
   "source": [
    "for z, w_gt_batch in test_loader:\n",
    "    test_loss = []\n",
    "\n",
    "    z = z.to(device)\n",
    "    w_gt_batch = w_gt_batch.to(device)\n",
    "    this_batch_size = w_gt_batch.size()[0]\n",
    "\n",
    "    adj_batch = w_gt_batch.clone()\n",
    "    adj_batch[adj_batch > 0] = 1\n",
    "\n",
    "    w_list = net.validation(z, threshold=1e-04)\n",
    "    w_pred = torch.clamp(w_list[:, num_unroll - 1, :], min=0)\n",
    "\n",
    "    loss_mean = gmse_loss_batch_mean(w_pred, w_gt_batch)\n",
    "    loss_pred = gmse_loss_batch(w_pred, w_gt_batch)\n",
    "\n",
    "    layer_loss_batch = torch.stack([layerwise_gmse_loss(w_list[i, :, :], w_gt_batch[i, :]) for i in range(batch_size)])\n",
    "\n",
    "\n",
    "loss_all_data = loss_pred.detach().cpu().numpy()\n",
    "final_pred_loss, final_pred_loss_ci, _, _ = mean_confidence_interval(loss_all_data, 0.95)\n",
    "logging.info('GMSE: {} +- {}'.format(final_pred_loss, final_pred_loss_ci))\n",
    "\n",
    "aps_auc = binary_metrics_batch(adj_batch, w_pred, device)\n",
    "logging.info('aps: {} +- {}'.format(aps_auc['aps_mean'], aps_auc['aps_ci']))\n",
    "logging.info('auc: {} +- {}'.format(aps_auc['auc_mean'], aps_auc['auc_ci']))\n",
    "\n",
    "layer_loss_mean = [mean_confidence_interval(layer_loss_batch[:,i].detach().cpu().numpy(), confidence=0.95)[0] for i in range(num_unroll)]\n",
    "layer_loss_mean_ci = [mean_confidence_interval(layer_loss_batch[:,i].detach().cpu().numpy(), confidence=0.95)[1] for i in range(num_unroll)]\n",
    "logging.info('layerwise test loss :{}'.format(layer_loss_mean))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# layerwisse loss\n",
    "\n",
    "plt.figure()\n",
    "plt.plot(np.arange(1,21,1), layer_loss_mean)\n",
    "plt.xticks(np.arange(1,21,1))\n",
    "plt.ylabel('GMSE')\n",
    "plt.xlabel('number of unrolls/iterations')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "04-Jun-21 14:40:16 | results saved at: saved_results/L2G_WS50_unroll20.pt\n"
     ]
    }
   ],
   "source": [
    "result = {\n",
    "    'epoch_train_gmse': epoch_train_gmse,\n",
    "    'epoch_val_gmse': epoch_train_gmse,\n",
    "    'pred_gmse_mean': final_pred_loss,\n",
    "    'pred_gmse_mean_ci': final_pred_loss_ci,\n",
    "    'auc_mean': aps_auc['auc_mean'],\n",
    "    'auc_ci': aps_auc['auc_ci'],\n",
    "    'aps_mean': aps_auc['aps_mean'],\n",
    "    'aps_ci': aps_auc['aps_ci'],\n",
    "    'layerwise_gmse_mean': layer_loss_mean,\n",
    "    'layerwise_gmse_mean_ci ': layer_loss_mean_ci\n",
    "}\n",
    "\n",
    "\n",
    "result_path = 'saved_results/L2G_{}{}_unroll{}.pt'.format(graph_type,\n",
    "                                                          graph_size,\n",
    "                                                          num_unroll)\n",
    "\n",
    "\n",
    "with open(result_path, 'wb') as handle:\n",
    "    pickle.dump(result, handle, protocol=4)\n",
    "\n",
    "logging.info('results saved at: {}'.format(result_path))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from scipy.spatial.distance import squareform\n",
    "idx = 50\n",
    "W = squareform(w_pred[idx,:].detach().cpu().numpy())\n",
    "W[W <= 1e-01] = 0\n",
    "plt.figure()\n",
    "sns.heatmap(W, cmap = 'pink_r', vmax = 0.305)\n",
    "plt.title('prediction')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from scipy.spatial.distance import squareform\n",
    "\n",
    "plt.figure()\n",
    "sns.heatmap(squareform(w_gt_batch[idx,:].detach().cpu().numpy()), cmap = 'pink_r', vmin = 0, vmax = 0.305)\n",
    "plt.title('groundtruth')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
