{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "gpuType": "T4"
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "accelerator": "GPU"
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "# Import modules"
      ],
      "metadata": {
        "id": "3S2qDT5piMND"
      }
    },
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "DY1Hifqg7ZFd"
      },
      "outputs": [],
      "source": [
        "# Import modules\n",
        "import matplotlib.pyplot as plt\n",
        "import numpy as np\n",
        "import random\n",
        "import time\n",
        "\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "import torch.nn.init as init\n",
        "import torch.optim as optim\n",
        "import torchvision\n",
        "import torchvision.transforms as transforms\n",
        "from torch.utils.data import TensorDataset, DataLoader\n",
        "from scipy.sparse import diags\n",
        "device = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
        "\n",
        "# Fix random seeds\n",
        "random.seed(1)\n",
        "np.random.seed(1)\n",
        "\n",
        "torch.manual_seed(1)\n",
        "torch.cuda.manual_seed_all(1)\n",
        "torch.cuda.manual_seed(1)\n",
        "torch.backends.cudnn.deterministic = True\n",
        "torch.backends.cudnn.benchmark = False\n",
        "\n",
        "# Ativate GPU if needed\n",
        "device = 'cuda' if torch.cuda.is_available() else 'cpu'"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Get latex commands\n",
        "!sudo apt install cm-super dvipng texlive-latex-extra texlive-latex-recommended"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "FJeuMZEIOljT",
        "outputId": "a86eff1a-bda8-4b9f-fa1e-6c8d6c5b61eb"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Reading package lists... Done\n",
            "Building dependency tree... Done\n",
            "Reading state information... Done\n",
            "The following additional packages will be installed:\n",
            "  cm-super-minimal dvisvgm fonts-droid-fallback fonts-lato fonts-lmodern\n",
            "  fonts-noto-mono fonts-texgyre fonts-urw-base35 ghostscript\n",
            "  libapache-pom-java libcommons-logging-java libcommons-parent-java\n",
            "  libfontbox-java libfontenc1 libgs9 libgs9-common libidn12 libijs-0.35\n",
            "  libjbig2dec0 libkpathsea6 libpdfbox-java libptexenc1 libruby3.0 libsynctex2\n",
            "  libteckit0 libtexlua53 libtexluajit2 libwoff1 libzzip-0-13 lmodern\n",
            "  pfb2t1c2pfb poppler-data preview-latex-style rake ruby ruby-net-telnet\n",
            "  ruby-rubygems ruby-webrick ruby-xmlrpc ruby3.0 rubygems-integration t1utils\n",
            "  tex-common tex-gyre texlive-base texlive-binaries texlive-fonts-recommended\n",
            "  texlive-latex-base texlive-pictures texlive-plain-generic tipa\n",
            "  xfonts-encodings xfonts-utils\n",
            "Suggested packages:\n",
            "  fonts-noto fonts-freefont-otf | fonts-freefont-ttf ghostscript-x\n",
            "  libavalon-framework-java libcommons-logging-java-doc\n",
            "  libexcalibur-logkit-java liblog4j1.2-java poppler-utils\n",
            "  fonts-japanese-mincho | fonts-ipafont-mincho fonts-japanese-gothic\n",
            "  | fonts-ipafont-gothic fonts-arphic-ukai fonts-arphic-uming fonts-nanum ri\n",
            "  ruby-dev bundler debhelper perl-tk xpdf | pdf-viewer xzdec\n",
            "  texlive-fonts-recommended-doc texlive-latex-base-doc python3-pygments\n",
            "  icc-profiles libfile-which-perl libspreadsheet-parseexcel-perl\n",
            "  texlive-latex-extra-doc texlive-latex-recommended-doc texlive-luatex\n",
            "  texlive-pstricks dot2tex prerex texlive-pictures-doc vprerex\n",
            "  default-jre-headless tipa-doc\n",
            "The following NEW packages will be installed:\n",
            "  cm-super cm-super-minimal dvipng dvisvgm fonts-droid-fallback fonts-lato\n",
            "  fonts-lmodern fonts-noto-mono fonts-texgyre fonts-urw-base35 ghostscript\n",
            "  libapache-pom-java libcommons-logging-java libcommons-parent-java\n",
            "  libfontbox-java libfontenc1 libgs9 libgs9-common libidn12 libijs-0.35\n",
            "  libjbig2dec0 libkpathsea6 libpdfbox-java libptexenc1 libruby3.0 libsynctex2\n",
            "  libteckit0 libtexlua53 libtexluajit2 libwoff1 libzzip-0-13 lmodern\n",
            "  pfb2t1c2pfb poppler-data preview-latex-style rake ruby ruby-net-telnet\n",
            "  ruby-rubygems ruby-webrick ruby-xmlrpc ruby3.0 rubygems-integration t1utils\n",
            "  tex-common tex-gyre texlive-base texlive-binaries texlive-fonts-recommended\n",
            "  texlive-latex-base texlive-latex-extra texlive-latex-recommended\n",
            "  texlive-pictures texlive-plain-generic tipa xfonts-encodings xfonts-utils\n",
            "0 upgraded, 57 newly installed, 0 to remove and 18 not upgraded.\n",
            "Need to get 195 MB of archives.\n",
            "After this operation, 613 MB of additional disk space will be used.\n",
            "Get:1 http://archive.ubuntu.com/ubuntu jammy/main amd64 fonts-droid-fallback all 1:6.0.1r16-1.1build1 [1,805 kB]\n",
            "Get:2 http://archive.ubuntu.com/ubuntu jammy/main amd64 fonts-lato all 2.0-2.1 [2,696 kB]\n",
            "Get:3 http://archive.ubuntu.com/ubuntu jammy/main amd64 poppler-data all 0.4.11-1 [2,171 kB]\n",
            "Get:4 http://archive.ubuntu.com/ubuntu jammy/universe amd64 tex-common all 6.17 [33.7 kB]\n",
            "Get:5 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libkpathsea6 amd64 2021.20210626.59705-1ubuntu0.1 [60.3 kB]\n",
            "Get:6 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libptexenc1 amd64 2021.20210626.59705-1ubuntu0.1 [39.1 kB]\n",
            "Get:7 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libsynctex2 amd64 2021.20210626.59705-1ubuntu0.1 [55.5 kB]\n",
            "Get:8 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libtexlua53 amd64 2021.20210626.59705-1ubuntu0.1 [120 kB]\n",
            "Get:9 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libtexluajit2 amd64 2021.20210626.59705-1ubuntu0.1 [267 kB]\n",
            "Get:10 http://archive.ubuntu.com/ubuntu jammy/main amd64 t1utils amd64 1.41-4build2 [61.3 kB]\n",
            "Get:11 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libteckit0 amd64 2.5.11+ds1-1 [421 kB]\n",
            "Get:12 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libzzip-0-13 amd64 0.13.72+dfsg.1-1.1 [27.0 kB]\n",
            "Get:13 http://archive.ubuntu.com/ubuntu jammy-updates/universe amd64 texlive-binaries amd64 2021.20210626.59705-1ubuntu0.1 [9,848 kB]\n",
            "Get:14 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-base all 2021.20220204-1 [21.0 MB]\n",
            "Get:15 http://archive.ubuntu.com/ubuntu jammy/universe amd64 fonts-lmodern all 2.004.5-6.1 [4,532 kB]\n",
            "Get:16 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-latex-base all 2021.20220204-1 [1,128 kB]\n",
            "Get:17 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-latex-recommended all 2021.20220204-1 [14.4 MB]\n",
            "Get:18 http://archive.ubuntu.com/ubuntu jammy/universe amd64 cm-super-minimal all 0.3.4-17 [5,777 kB]\n",
            "Get:19 http://archive.ubuntu.com/ubuntu jammy/universe amd64 pfb2t1c2pfb amd64 0.3-11 [9,342 B]\n",
            "Get:20 http://archive.ubuntu.com/ubuntu jammy/universe amd64 cm-super all 0.3.4-17 [20.2 MB]\n",
            "Get:21 http://archive.ubuntu.com/ubuntu jammy/main amd64 fonts-urw-base35 all 20200910-1 [6,367 kB]\n",
            "Get:22 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libgs9-common all 9.55.0~dfsg1-0ubuntu5.4 [752 kB]\n",
            "Get:23 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libidn12 amd64 1.38-4ubuntu1 [60.0 kB]\n",
            "Get:24 http://archive.ubuntu.com/ubuntu jammy/main amd64 libijs-0.35 amd64 0.35-15build2 [16.5 kB]\n",
            "Get:25 http://archive.ubuntu.com/ubuntu jammy/main amd64 libjbig2dec0 amd64 0.19-3build2 [64.7 kB]\n",
            "Get:26 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libgs9 amd64 9.55.0~dfsg1-0ubuntu5.4 [5,032 kB]\n",
            "Get:27 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 ghostscript amd64 9.55.0~dfsg1-0ubuntu5.4 [49.4 kB]\n",
            "Get:28 http://archive.ubuntu.com/ubuntu jammy/universe amd64 dvipng amd64 1.15-1.1 [78.9 kB]\n",
            "Get:29 http://archive.ubuntu.com/ubuntu jammy/main amd64 libwoff1 amd64 1.0.2-1build4 [45.2 kB]\n",
            "Get:30 http://archive.ubuntu.com/ubuntu jammy/universe amd64 dvisvgm amd64 2.13.1-1 [1,221 kB]\n",
            "Get:31 http://archive.ubuntu.com/ubuntu jammy/main amd64 fonts-noto-mono all 20201225-1build1 [397 kB]\n",
            "Get:32 http://archive.ubuntu.com/ubuntu jammy/universe amd64 fonts-texgyre all 20180621-3.1 [10.2 MB]\n",
            "Get:33 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libapache-pom-java all 18-1 [4,720 B]\n",
            "Get:34 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libcommons-parent-java all 43-1 [10.8 kB]\n",
            "Get:35 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libcommons-logging-java all 1.2-2 [60.3 kB]\n",
            "Get:36 http://archive.ubuntu.com/ubuntu jammy/main amd64 libfontenc1 amd64 1:1.1.4-1build3 [14.7 kB]\n",
            "Get:37 http://archive.ubuntu.com/ubuntu jammy/main amd64 rubygems-integration all 1.18 [5,336 B]\n",
            "Get:38 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 ruby3.0 amd64 3.0.2-7ubuntu2.4 [50.1 kB]\n",
            "Get:39 http://archive.ubuntu.com/ubuntu jammy/main amd64 ruby-rubygems all 3.3.5-2 [228 kB]\n",
            "Get:40 http://archive.ubuntu.com/ubuntu jammy/main amd64 ruby amd64 1:3.0~exp1 [5,100 B]\n",
            "Get:41 http://archive.ubuntu.com/ubuntu jammy/main amd64 rake all 13.0.6-2 [61.7 kB]\n",
            "Get:42 http://archive.ubuntu.com/ubuntu jammy/main amd64 ruby-net-telnet all 0.1.1-2 [12.6 kB]\n",
            "Get:43 http://archive.ubuntu.com/ubuntu jammy/universe amd64 ruby-webrick all 1.7.0-3 [51.8 kB]\n",
            "Get:44 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 ruby-xmlrpc all 0.3.2-1ubuntu0.1 [24.9 kB]\n",
            "Get:45 http://archive.ubuntu.com/ubuntu jammy-updates/main amd64 libruby3.0 amd64 3.0.2-7ubuntu2.4 [5,113 kB]\n",
            "Get:46 http://archive.ubuntu.com/ubuntu jammy/main amd64 xfonts-encodings all 1:1.0.5-0ubuntu2 [578 kB]\n",
            "Get:47 http://archive.ubuntu.com/ubuntu jammy/main amd64 xfonts-utils amd64 1:7.7+6build2 [94.6 kB]\n",
            "Get:48 http://archive.ubuntu.com/ubuntu jammy/universe amd64 lmodern all 2.004.5-6.1 [9,471 kB]\n",
            "Get:49 http://archive.ubuntu.com/ubuntu jammy/universe amd64 preview-latex-style all 12.2-1ubuntu1 [185 kB]\n",
            "Get:50 http://archive.ubuntu.com/ubuntu jammy/universe amd64 tex-gyre all 20180621-3.1 [6,209 kB]\n",
            "Get:51 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-fonts-recommended all 2021.20220204-1 [4,972 kB]\n",
            "Get:52 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libfontbox-java all 1:1.8.16-2 [207 kB]\n",
            "Get:53 http://archive.ubuntu.com/ubuntu jammy/universe amd64 libpdfbox-java all 1:1.8.16-2 [5,199 kB]\n",
            "Get:54 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-pictures all 2021.20220204-1 [8,720 kB]\n",
            "Get:55 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-latex-extra all 2021.20220204-1 [13.9 MB]\n",
            "Get:56 http://archive.ubuntu.com/ubuntu jammy/universe amd64 texlive-plain-generic all 2021.20220204-1 [27.5 MB]\n",
            "Get:57 http://archive.ubuntu.com/ubuntu jammy/universe amd64 tipa all 2:1.3-21 [2,967 kB]\n",
            "Fetched 195 MB in 17s (11.3 MB/s)\n",
            "debconf: unable to initialize frontend: Dialog\n",
            "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 78, <> line 57.)\n",
            "debconf: falling back to frontend: Readline\n",
            "debconf: unable to initialize frontend: Readline\n",
            "debconf: (This frontend requires a controlling tty.)\n",
            "debconf: falling back to frontend: Teletype\n",
            "dpkg-preconfigure: unable to re-open stdin: \n",
            "Selecting previously unselected package fonts-droid-fallback.\n",
            "(Reading database ... 120895 files and directories currently installed.)\n",
            "Preparing to unpack .../00-fonts-droid-fallback_1%3a6.0.1r16-1.1build1_all.deb ...\n",
            "Unpacking fonts-droid-fallback (1:6.0.1r16-1.1build1) ...\n",
            "Selecting previously unselected package fonts-lato.\n",
            "Preparing to unpack .../01-fonts-lato_2.0-2.1_all.deb ...\n",
            "Unpacking fonts-lato (2.0-2.1) ...\n",
            "Selecting previously unselected package poppler-data.\n",
            "Preparing to unpack .../02-poppler-data_0.4.11-1_all.deb ...\n",
            "Unpacking poppler-data (0.4.11-1) ...\n",
            "Selecting previously unselected package tex-common.\n",
            "Preparing to unpack .../03-tex-common_6.17_all.deb ...\n",
            "Unpacking tex-common (6.17) ...\n",
            "Selecting previously unselected package libkpathsea6:amd64.\n",
            "Preparing to unpack .../04-libkpathsea6_2021.20210626.59705-1ubuntu0.1_amd64.deb ...\n",
            "Unpacking libkpathsea6:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Selecting previously unselected package libptexenc1:amd64.\n",
            "Preparing to unpack .../05-libptexenc1_2021.20210626.59705-1ubuntu0.1_amd64.deb ...\n",
            "Unpacking libptexenc1:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Selecting previously unselected package libsynctex2:amd64.\n",
            "Preparing to unpack .../06-libsynctex2_2021.20210626.59705-1ubuntu0.1_amd64.deb ...\n",
            "Unpacking libsynctex2:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Selecting previously unselected package libtexlua53:amd64.\n",
            "Preparing to unpack .../07-libtexlua53_2021.20210626.59705-1ubuntu0.1_amd64.deb ...\n",
            "Unpacking libtexlua53:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Selecting previously unselected package libtexluajit2:amd64.\n",
            "Preparing to unpack .../08-libtexluajit2_2021.20210626.59705-1ubuntu0.1_amd64.deb ...\n",
            "Unpacking libtexluajit2:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Selecting previously unselected package t1utils.\n",
            "Preparing to unpack .../09-t1utils_1.41-4build2_amd64.deb ...\n",
            "Unpacking t1utils (1.41-4build2) ...\n",
            "Selecting previously unselected package libteckit0:amd64.\n",
            "Preparing to unpack .../10-libteckit0_2.5.11+ds1-1_amd64.deb ...\n",
            "Unpacking libteckit0:amd64 (2.5.11+ds1-1) ...\n",
            "Selecting previously unselected package libzzip-0-13:amd64.\n",
            "Preparing to unpack .../11-libzzip-0-13_0.13.72+dfsg.1-1.1_amd64.deb ...\n",
            "Unpacking libzzip-0-13:amd64 (0.13.72+dfsg.1-1.1) ...\n",
            "Selecting previously unselected package texlive-binaries.\n",
            "Preparing to unpack .../12-texlive-binaries_2021.20210626.59705-1ubuntu0.1_amd64.deb ...\n",
            "Unpacking texlive-binaries (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Selecting previously unselected package texlive-base.\n",
            "Preparing to unpack .../13-texlive-base_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-base (2021.20220204-1) ...\n",
            "Selecting previously unselected package fonts-lmodern.\n",
            "Preparing to unpack .../14-fonts-lmodern_2.004.5-6.1_all.deb ...\n",
            "Unpacking fonts-lmodern (2.004.5-6.1) ...\n",
            "Selecting previously unselected package texlive-latex-base.\n",
            "Preparing to unpack .../15-texlive-latex-base_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-latex-base (2021.20220204-1) ...\n",
            "Selecting previously unselected package texlive-latex-recommended.\n",
            "Preparing to unpack .../16-texlive-latex-recommended_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-latex-recommended (2021.20220204-1) ...\n",
            "Selecting previously unselected package cm-super-minimal.\n",
            "Preparing to unpack .../17-cm-super-minimal_0.3.4-17_all.deb ...\n",
            "Unpacking cm-super-minimal (0.3.4-17) ...\n",
            "Selecting previously unselected package pfb2t1c2pfb.\n",
            "Preparing to unpack .../18-pfb2t1c2pfb_0.3-11_amd64.deb ...\n",
            "Unpacking pfb2t1c2pfb (0.3-11) ...\n",
            "Selecting previously unselected package cm-super.\n",
            "Preparing to unpack .../19-cm-super_0.3.4-17_all.deb ...\n",
            "Unpacking cm-super (0.3.4-17) ...\n",
            "Selecting previously unselected package fonts-urw-base35.\n",
            "Preparing to unpack .../20-fonts-urw-base35_20200910-1_all.deb ...\n",
            "Unpacking fonts-urw-base35 (20200910-1) ...\n",
            "Selecting previously unselected package libgs9-common.\n",
            "Preparing to unpack .../21-libgs9-common_9.55.0~dfsg1-0ubuntu5.4_all.deb ...\n",
            "Unpacking libgs9-common (9.55.0~dfsg1-0ubuntu5.4) ...\n",
            "Selecting previously unselected package libidn12:amd64.\n",
            "Preparing to unpack .../22-libidn12_1.38-4ubuntu1_amd64.deb ...\n",
            "Unpacking libidn12:amd64 (1.38-4ubuntu1) ...\n",
            "Selecting previously unselected package libijs-0.35:amd64.\n",
            "Preparing to unpack .../23-libijs-0.35_0.35-15build2_amd64.deb ...\n",
            "Unpacking libijs-0.35:amd64 (0.35-15build2) ...\n",
            "Selecting previously unselected package libjbig2dec0:amd64.\n",
            "Preparing to unpack .../24-libjbig2dec0_0.19-3build2_amd64.deb ...\n",
            "Unpacking libjbig2dec0:amd64 (0.19-3build2) ...\n",
            "Selecting previously unselected package libgs9:amd64.\n",
            "Preparing to unpack .../25-libgs9_9.55.0~dfsg1-0ubuntu5.4_amd64.deb ...\n",
            "Unpacking libgs9:amd64 (9.55.0~dfsg1-0ubuntu5.4) ...\n",
            "Selecting previously unselected package ghostscript.\n",
            "Preparing to unpack .../26-ghostscript_9.55.0~dfsg1-0ubuntu5.4_amd64.deb ...\n",
            "Unpacking ghostscript (9.55.0~dfsg1-0ubuntu5.4) ...\n",
            "Selecting previously unselected package dvipng.\n",
            "Preparing to unpack .../27-dvipng_1.15-1.1_amd64.deb ...\n",
            "Unpacking dvipng (1.15-1.1) ...\n",
            "Selecting previously unselected package libwoff1:amd64.\n",
            "Preparing to unpack .../28-libwoff1_1.0.2-1build4_amd64.deb ...\n",
            "Unpacking libwoff1:amd64 (1.0.2-1build4) ...\n",
            "Selecting previously unselected package dvisvgm.\n",
            "Preparing to unpack .../29-dvisvgm_2.13.1-1_amd64.deb ...\n",
            "Unpacking dvisvgm (2.13.1-1) ...\n",
            "Selecting previously unselected package fonts-noto-mono.\n",
            "Preparing to unpack .../30-fonts-noto-mono_20201225-1build1_all.deb ...\n",
            "Unpacking fonts-noto-mono (20201225-1build1) ...\n",
            "Selecting previously unselected package fonts-texgyre.\n",
            "Preparing to unpack .../31-fonts-texgyre_20180621-3.1_all.deb ...\n",
            "Unpacking fonts-texgyre (20180621-3.1) ...\n",
            "Selecting previously unselected package libapache-pom-java.\n",
            "Preparing to unpack .../32-libapache-pom-java_18-1_all.deb ...\n",
            "Unpacking libapache-pom-java (18-1) ...\n",
            "Selecting previously unselected package libcommons-parent-java.\n",
            "Preparing to unpack .../33-libcommons-parent-java_43-1_all.deb ...\n",
            "Unpacking libcommons-parent-java (43-1) ...\n",
            "Selecting previously unselected package libcommons-logging-java.\n",
            "Preparing to unpack .../34-libcommons-logging-java_1.2-2_all.deb ...\n",
            "Unpacking libcommons-logging-java (1.2-2) ...\n",
            "Selecting previously unselected package libfontenc1:amd64.\n",
            "Preparing to unpack .../35-libfontenc1_1%3a1.1.4-1build3_amd64.deb ...\n",
            "Unpacking libfontenc1:amd64 (1:1.1.4-1build3) ...\n",
            "Selecting previously unselected package rubygems-integration.\n",
            "Preparing to unpack .../36-rubygems-integration_1.18_all.deb ...\n",
            "Unpacking rubygems-integration (1.18) ...\n",
            "Selecting previously unselected package ruby3.0.\n",
            "Preparing to unpack .../37-ruby3.0_3.0.2-7ubuntu2.4_amd64.deb ...\n",
            "Unpacking ruby3.0 (3.0.2-7ubuntu2.4) ...\n",
            "Selecting previously unselected package ruby-rubygems.\n",
            "Preparing to unpack .../38-ruby-rubygems_3.3.5-2_all.deb ...\n",
            "Unpacking ruby-rubygems (3.3.5-2) ...\n",
            "Selecting previously unselected package ruby.\n",
            "Preparing to unpack .../39-ruby_1%3a3.0~exp1_amd64.deb ...\n",
            "Unpacking ruby (1:3.0~exp1) ...\n",
            "Selecting previously unselected package rake.\n",
            "Preparing to unpack .../40-rake_13.0.6-2_all.deb ...\n",
            "Unpacking rake (13.0.6-2) ...\n",
            "Selecting previously unselected package ruby-net-telnet.\n",
            "Preparing to unpack .../41-ruby-net-telnet_0.1.1-2_all.deb ...\n",
            "Unpacking ruby-net-telnet (0.1.1-2) ...\n",
            "Selecting previously unselected package ruby-webrick.\n",
            "Preparing to unpack .../42-ruby-webrick_1.7.0-3_all.deb ...\n",
            "Unpacking ruby-webrick (1.7.0-3) ...\n",
            "Selecting previously unselected package ruby-xmlrpc.\n",
            "Preparing to unpack .../43-ruby-xmlrpc_0.3.2-1ubuntu0.1_all.deb ...\n",
            "Unpacking ruby-xmlrpc (0.3.2-1ubuntu0.1) ...\n",
            "Selecting previously unselected package libruby3.0:amd64.\n",
            "Preparing to unpack .../44-libruby3.0_3.0.2-7ubuntu2.4_amd64.deb ...\n",
            "Unpacking libruby3.0:amd64 (3.0.2-7ubuntu2.4) ...\n",
            "Selecting previously unselected package xfonts-encodings.\n",
            "Preparing to unpack .../45-xfonts-encodings_1%3a1.0.5-0ubuntu2_all.deb ...\n",
            "Unpacking xfonts-encodings (1:1.0.5-0ubuntu2) ...\n",
            "Selecting previously unselected package xfonts-utils.\n",
            "Preparing to unpack .../46-xfonts-utils_1%3a7.7+6build2_amd64.deb ...\n",
            "Unpacking xfonts-utils (1:7.7+6build2) ...\n",
            "Selecting previously unselected package lmodern.\n",
            "Preparing to unpack .../47-lmodern_2.004.5-6.1_all.deb ...\n",
            "Unpacking lmodern (2.004.5-6.1) ...\n",
            "Selecting previously unselected package preview-latex-style.\n",
            "Preparing to unpack .../48-preview-latex-style_12.2-1ubuntu1_all.deb ...\n",
            "Unpacking preview-latex-style (12.2-1ubuntu1) ...\n",
            "Selecting previously unselected package tex-gyre.\n",
            "Preparing to unpack .../49-tex-gyre_20180621-3.1_all.deb ...\n",
            "Unpacking tex-gyre (20180621-3.1) ...\n",
            "Selecting previously unselected package texlive-fonts-recommended.\n",
            "Preparing to unpack .../50-texlive-fonts-recommended_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-fonts-recommended (2021.20220204-1) ...\n",
            "Selecting previously unselected package libfontbox-java.\n",
            "Preparing to unpack .../51-libfontbox-java_1%3a1.8.16-2_all.deb ...\n",
            "Unpacking libfontbox-java (1:1.8.16-2) ...\n",
            "Selecting previously unselected package libpdfbox-java.\n",
            "Preparing to unpack .../52-libpdfbox-java_1%3a1.8.16-2_all.deb ...\n",
            "Unpacking libpdfbox-java (1:1.8.16-2) ...\n",
            "Selecting previously unselected package texlive-pictures.\n",
            "Preparing to unpack .../53-texlive-pictures_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-pictures (2021.20220204-1) ...\n",
            "Selecting previously unselected package texlive-latex-extra.\n",
            "Preparing to unpack .../54-texlive-latex-extra_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-latex-extra (2021.20220204-1) ...\n",
            "Selecting previously unselected package texlive-plain-generic.\n",
            "Preparing to unpack .../55-texlive-plain-generic_2021.20220204-1_all.deb ...\n",
            "Unpacking texlive-plain-generic (2021.20220204-1) ...\n",
            "Selecting previously unselected package tipa.\n",
            "Preparing to unpack .../56-tipa_2%3a1.3-21_all.deb ...\n",
            "Unpacking tipa (2:1.3-21) ...\n",
            "Setting up pfb2t1c2pfb (0.3-11) ...\n",
            "Setting up fonts-lato (2.0-2.1) ...\n",
            "Setting up fonts-noto-mono (20201225-1build1) ...\n",
            "Setting up libwoff1:amd64 (1.0.2-1build4) ...\n",
            "Setting up libtexlua53:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Setting up libijs-0.35:amd64 (0.35-15build2) ...\n",
            "Setting up libtexluajit2:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Setting up libfontbox-java (1:1.8.16-2) ...\n",
            "Setting up rubygems-integration (1.18) ...\n",
            "Setting up libzzip-0-13:amd64 (0.13.72+dfsg.1-1.1) ...\n",
            "Setting up fonts-urw-base35 (20200910-1) ...\n",
            "Setting up poppler-data (0.4.11-1) ...\n",
            "Setting up tex-common (6.17) ...\n",
            "debconf: unable to initialize frontend: Dialog\n",
            "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 78.)\n",
            "debconf: falling back to frontend: Readline\n",
            "update-language: texlive-base not installed and configured, doing nothing!\n",
            "Setting up libfontenc1:amd64 (1:1.1.4-1build3) ...\n",
            "Setting up libjbig2dec0:amd64 (0.19-3build2) ...\n",
            "Setting up libteckit0:amd64 (2.5.11+ds1-1) ...\n",
            "Setting up libapache-pom-java (18-1) ...\n",
            "Setting up ruby-net-telnet (0.1.1-2) ...\n",
            "Setting up xfonts-encodings (1:1.0.5-0ubuntu2) ...\n",
            "Setting up t1utils (1.41-4build2) ...\n",
            "Setting up libidn12:amd64 (1.38-4ubuntu1) ...\n",
            "Setting up fonts-texgyre (20180621-3.1) ...\n",
            "Setting up libkpathsea6:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Setting up ruby-webrick (1.7.0-3) ...\n",
            "Setting up fonts-lmodern (2.004.5-6.1) ...\n",
            "Setting up fonts-droid-fallback (1:6.0.1r16-1.1build1) ...\n",
            "Setting up ruby-xmlrpc (0.3.2-1ubuntu0.1) ...\n",
            "Setting up libsynctex2:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Setting up libgs9-common (9.55.0~dfsg1-0ubuntu5.4) ...\n",
            "Setting up libpdfbox-java (1:1.8.16-2) ...\n",
            "Setting up libgs9:amd64 (9.55.0~dfsg1-0ubuntu5.4) ...\n",
            "Setting up preview-latex-style (12.2-1ubuntu1) ...\n",
            "Setting up libcommons-parent-java (43-1) ...\n",
            "Setting up dvisvgm (2.13.1-1) ...\n",
            "Setting up libcommons-logging-java (1.2-2) ...\n",
            "Setting up ghostscript (9.55.0~dfsg1-0ubuntu5.4) ...\n",
            "Setting up xfonts-utils (1:7.7+6build2) ...\n",
            "Setting up libptexenc1:amd64 (2021.20210626.59705-1ubuntu0.1) ...\n",
            "Setting up texlive-binaries (2021.20210626.59705-1ubuntu0.1) ...\n",
            "update-alternatives: using /usr/bin/xdvi-xaw to provide /usr/bin/xdvi.bin (xdvi.bin) in auto mode\n",
            "update-alternatives: using /usr/bin/bibtex.original to provide /usr/bin/bibtex (bibtex) in auto mode\n",
            "Setting up lmodern (2.004.5-6.1) ...\n",
            "Setting up texlive-base (2021.20220204-1) ...\n",
            "/usr/bin/ucfr\n",
            "/usr/bin/ucfr\n",
            "/usr/bin/ucfr\n",
            "/usr/bin/ucfr\n",
            "mktexlsr: Updating /var/lib/texmf/ls-R-TEXLIVEDIST... \n",
            "mktexlsr: Updating /var/lib/texmf/ls-R-TEXMFMAIN... \n",
            "mktexlsr: Updating /var/lib/texmf/ls-R... \n",
            "mktexlsr: Done.\n",
            "tl-paper: setting paper size for dvips to a4: /var/lib/texmf/dvips/config/config-paper.ps\n",
            "tl-paper: setting paper size for dvipdfmx to a4: /var/lib/texmf/dvipdfmx/dvipdfmx-paper.cfg\n",
            "tl-paper: setting paper size for xdvi to a4: /var/lib/texmf/xdvi/XDvi-paper\n",
            "tl-paper: setting paper size for pdftex to a4: /var/lib/texmf/tex/generic/tex-ini-files/pdftexconfig.tex\n",
            "debconf: unable to initialize frontend: Dialog\n",
            "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 78.)\n",
            "debconf: falling back to frontend: Readline\n",
            "Setting up tex-gyre (20180621-3.1) ...\n",
            "Setting up dvipng (1.15-1.1) ...\n",
            "Setting up texlive-plain-generic (2021.20220204-1) ...\n",
            "Setting up texlive-latex-base (2021.20220204-1) ...\n",
            "Setting up texlive-latex-recommended (2021.20220204-1) ...\n",
            "Setting up texlive-pictures (2021.20220204-1) ...\n",
            "Setting up texlive-fonts-recommended (2021.20220204-1) ...\n",
            "Setting up tipa (2:1.3-21) ...\n",
            "Setting up cm-super-minimal (0.3.4-17) ...\n",
            "Setting up texlive-latex-extra (2021.20220204-1) ...\n",
            "Setting up cm-super (0.3.4-17) ...\n",
            "Creating fonts. This may take some time... done.\n",
            "Setting up rake (13.0.6-2) ...\n",
            "Setting up libruby3.0:amd64 (3.0.2-7ubuntu2.4) ...\n",
            "Setting up ruby3.0 (3.0.2-7ubuntu2.4) ...\n",
            "Setting up ruby (1:3.0~exp1) ...\n",
            "Setting up ruby-rubygems (3.3.5-2) ...\n",
            "Processing triggers for man-db (2.10.2-1) ...\n",
            "Processing triggers for fontconfig (2.13.1-4.2ubuntu5) ...\n",
            "Processing triggers for libc-bin (2.35-0ubuntu3.1) ...\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbbbind.so.3 is not a symbolic link\n",
            "\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbbmalloc_proxy.so.2 is not a symbolic link\n",
            "\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbbbind_2_0.so.3 is not a symbolic link\n",
            "\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbbbind_2_5.so.3 is not a symbolic link\n",
            "\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbb.so.12 is not a symbolic link\n",
            "\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbbmalloc.so.2 is not a symbolic link\n",
            "\n",
            "Processing triggers for tex-common (6.17) ...\n",
            "debconf: unable to initialize frontend: Dialog\n",
            "debconf: (No usable dialog-like program is installed, so the dialog based frontend cannot be used. at /usr/share/perl5/Debconf/FrontEnd/Dialog.pm line 78.)\n",
            "debconf: falling back to frontend: Readline\n",
            "Running updmap-sys. This may take some time... done.\n",
            "Running mktexlsr /var/lib/texmf ... done.\n",
            "Building format(s) --all.\n",
            "\tThis may take some time... done.\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plt.rcParams['text.usetex'] = True"
      ],
      "metadata": {
        "id": "5boMYFa4sGM-"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Define initial parameters"
      ],
      "metadata": {
        "id": "M5UgfORNH714"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Space grid (same for all dimension), nleft bound, right bound, and number of points\n",
        "lb = 0\n",
        "rb = 1\n",
        "n_x = 64\n",
        "\n",
        "#Define data points number\n",
        "m = 200\n",
        "\n",
        "#Data oscillations (how many sin/cos waves to superpose) and initial coeficient bound\n",
        "c_1 = 20\n",
        "k = 4\n",
        "\n",
        "#Number of output times\n",
        "t_k = 10\n",
        "\n",
        "#Boundary conditions type (inactive for now - Dirichlet zero boundaries in place)\n",
        "Boundary_cond = 'Dirichlet'\n",
        "#Boundary conditions if Dirichlet (inactive for now - Dirichlet zero boundaries in place)\n",
        "T_0 = 0\n",
        "T_1 = 0\n",
        "\n",
        "#Coefficients cap\n",
        "max_a = 2.5\n",
        "#Epsilon value (for coefficient and model parameter caps)\n",
        "epsilon = 0.0001\n",
        "\n",
        "#Maximum coarsening factor for experiments\n",
        "coars_max = 8\n",
        "\n",
        "#Optimization parameters: regularization, batch size, train-val-test percentage split\n",
        "batch_s = 16\n",
        "train_size = 0.75\n",
        "val_size = 0.125\n",
        "\n",
        "#Example soltution to plot\n",
        "test_data = 19"
      ],
      "metadata": {
        "id": "6Y640YfoH-IC"
      },
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Define mesh, particular to the heat equation: $dt \\sim dx^2$\n",
        "\n",
        "We pick $n_t = 2\\cdot dimension \\cdot max(a(x,y))\\cdot n_x^2$ and this will ensure stability of the Finite Differences algorithm since $\\frac{a(x,y)d_t}{d_x^2} \\leq \\frac{max(a(x,y))d_t}{d_x^2} = \\frac{1}{2\\cdot dimension}$"
      ],
      "metadata": {
        "id": "SRFoVNZviWcP"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Define space and time mesh\n",
        "n_t = int(4*max_a*n_x*n_x)\n",
        "\n",
        "xmesh = torch.linspace(lb, rb, n_x).to(device)\n",
        "tmesh = torch.linspace(0, 1, n_t).to(device)\n",
        "\n",
        "dx = xmesh[1]-xmesh[0]\n",
        "dt = tmesh[1]-tmesh[0]"
      ],
      "metadata": {
        "id": "m6Lf-2T3AJNL"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Define random initial conditions\n",
        "\n",
        "Made up of a superposition of k (hyperparameter defined above) sin waves\n",
        "\n",
        "\n"
      ],
      "metadata": {
        "id": "mqDBkvPaeSW9"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Random initial conditions made up of a combination of sin(pi*k*x) functions - decaying as 1/k\n",
        "x1, x2 = np.meshgrid(xmesh.cpu(), xmesh.cpu())\n",
        "def sin_xy(x,y,i,j):\n",
        "  return np.sin(np.pi*i*x)*np.sin(np.pi*j*y)\n",
        "\n",
        "coef_vector = torch.ones((k,k)).to(device)\n",
        "for i in range(k):\n",
        "  for j in range(k):\n",
        "    if ((i<=1) and (j<=1)):\n",
        "      coef_vector[i][j] = 1\n",
        "    else:\n",
        "      coef_vector[i][j] = 0\n",
        "\n",
        "def initial_cond_dirichlet(x_mesh,k):\n",
        "  coefs_rand = (torch.rand((k,k))-0.5).to(device)\n",
        "  coefs_actual = coef_vector*coefs_rand\n",
        "  func=torch.zeros((len(x_mesh),len(x_mesh))).to(device)\n",
        "  for i in range(1, k+1):\n",
        "    for j in range(1,k+1):\n",
        "      func+=(coefs_actual[i-1][j-1]*torch.tensor(sin_xy(x1,x2,i,j)).to(device))\n",
        "\n",
        "  max = torch.max(func)\n",
        "  min = torch.min(func)\n",
        "  func = 2*func/(max-min)\n",
        "  coefs_actual = 2*coefs_actual/(max-min)\n",
        "  return func, coefs_actual"
      ],
      "metadata": {
        "id": "ASGZJWrO6b2a"
      },
      "execution_count": 6,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Define the coeficients for the equatiion to model: $u_t = a(x,y)(u_{xx}+u_{yy})$\n",
        "\n",
        "Capped between max_a and zero to ensure stability (hyperparameters defined above). The epsilon value just ensures the caps are not attained so that the model can learn the parameters exactly\n",
        "\n",
        "\n",
        "\n"
      ],
      "metadata": {
        "id": "lbDqB1__enf9"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Define 2D grid and return evaluated coefficient values\n",
        "a_xy = initial_cond_dirichlet(xmesh,k)[0].to(device)+0.75\n",
        "a_xy = torch.maximum(torch.minimum(a_xy, torch.tensor(max_a - epsilon)), torch.tensor(epsilon))\n",
        "\n",
        "#Visualize the coefficients (also an example of initial conditions)\n",
        "plt.imshow(a_xy.cpu(), cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "ELCMUhUrG_LQ",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "65de1dcb-4421-4dbd-eee3-3eed6fc62bcf"
      },
      "execution_count": 7,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgAAAAGyCAYAAACSknwZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA8O0lEQVR4nO3dT29jyZnv+Z9crlTaVZZO0XPvFHo63ehTr8AU9QacTPRicDc2Zb8CSduB0RCdm8mquxEkeDG7bmW+ghSJ3gxm00n4Dchiv4CGjns6gUHNnS6Kksu3K+tWJmeRFluU4pH4iHH4R/H9AEImg8FgnMN/cSKeiFgaDAYDAQCApHxv1hUAAADTRwMAAIAE0QAAACBBNAAAAEgQDQAAABJEAwAAgATRAAAAIEE0AAAASBANAAAAEjSTBkC329Xa2tqt+Yqi0P7+vtrttvb399Xv98uvHAAACVia9lLA7XZbeZ5rbW1Ntz312tqajo+PJb1vDDSbTbVarWlUEwCAe23qDYDhEy8t3dgAKIpCGxsbwwaAJH3yySc6PT2dRvUAALjX5jYGoNPpqFKpjKRVKhV1u90Z1QgAgPvj+7OugMUa7+/1esH0N2/e6M2bN8Pb7969U6/X049//GMtLS2VUUUAQIkGg4H++Mc/6i/+4i/0ve+Vd736zTff6Ntvv524nAcPHujhw4cRajQdc9sAsFgNg93dXX3xxRfTrQwAoHSvX7/WX/7lX5ZS9jfffKO//uu/1pdffjlxWZ9++qn+8Ic/LEwjYG4bAFmWXbva7/V6yrIsmP/p06f69a9/Pbx9dnamn/zkJ/o/JX1UYj0BAOX4k6T/IulHP/pRac/x7bff6ssvv9Tr13/QysrKncs5Pz/Xo0d/rW+//ZYGwKTq9boODg6upddqtWD+5eVlLS8vX0v/SNLHsSsHAJiaaQzjrqz8UCsrP5yghO+i1WVaZhoEeLU7v9vtqigKSVKe5yP3FUWhWq1m9gAAAIDxTb0HoNPp6NWrV5Lej9uvr6+r0WiM3N7Z2ZEktVotNZtNra+v6+joiDUAAAAl+U6TXcUvXg/AzNYBKNv5+blWV1f1O10fAnhrPMZKD3nnrE+ZZcd4zjJ94Mzv6ZaKVbZVTig9RhlWOZ68ZT+npcyyy+yS9NYlxucnxveEVYb3e8xTTowyJOl/TFj215J+pvcxXZOMz9/k4rfi7Oz/njgGYHX1r0qta2xzuw4AAAAoz9wGAQIAMD1vNVk3/rz0uY6PBgAAAAnGADAEAABAgugBAAAgwR6AJBsAnihUbzSstZq0p2yLty4xyvZGTod4I9gtHzrKsNJDZdwkVI63bCv9QYQyPGVb+c1zaL1w1pNOe8rETfnL4v3Qlhk2H8or6a3xnNZ3U6iYb3xPaaaHyrHKjjX76e7SawAwBAAAQIKS7AEAAGDUW00Wyc8sAAAAFhDTAAEASFB6MQA0AC4Jtd+8QS+eIECrjDKX+CxT2cvYhmLPvMFxluv7SNq8QYDWxqChdE9eSXrgDdTzPKn3gEL5PdGIUrlrNXt5Ine9H07PF4gnwk7SB0b6D6z0N9fTPjKe809GVf67kR7ijGlEiWgAAABADwAAAClKrwHANEAAABJEDwAAAMwCAAAgRekNASTZALACcz2R+la0fyCg1szvnQVg5Y8xCyDGUsDeWQCeFWWlcPC5t81tle1ZhtQ6Hivg3RPZ/5GR9wNrmoL1gB868lsVtMrwHFCZaxhL4Rcj1vLAoTdXjKV9b0r3rJ1rheRbX0JW/j9eT/rAyPujr40yDKHTMu3Vm2FLsgEAAMAoegAAAEhQeg0AZgEAAJAgegAAAEiwB4AGAAAAU54G2O121el0JElHR0d68eKFsiwL5i2KQu12W3meqygKbW1tDfPedN9taABcEorU90b7WwG7oXI8MwYkOwDZkz/WTFXPEuzetfOtQPBQ3a2A9Bj7DFi8ZVjpoYD8D6zI+x85063ZAaH83ue0TrpnhoE1q8E7CyDGG9HimQVgfQitLwRrFkBoUX2rjED0viRXtL8k1yYbS0YRHxmzA0KHaVVv9qbbA9DpdLSzsyNJ2t/f1+PHj3V8fBzMu7GxMbyvKAptbm6q1Wrdet9tiAEAAGCKut2udnd3h7cbjYa63a6KoriW92panufDnoOb7hsHDQAAAIY9AJP8jadarerFixfD2/1+X5JUqVSu5e10OtfSK5XKcAjBum8cDAEAABBpCOD8/HwkdXl5WcvL18e8Go3G8P8vX75UvV4Pjt1fNA6u6vV6N943DnoAAACI5NGjR1pdXR3+Xe7qD+n3+2q322OP219+3F3uu4weAAAAIvUAvH79WisrK8PU0NX/Zc1mU69evTIj97Msu3ZF3+v1lGXZjfeNI8kGgBUJH2MvACs9FNzrWQ78LnWZl1kA3sBuz7r8Fm+kvvWcoWPyBpmbMxVC3wveiPzMmR4qxzvDwDPzIMZ+ApJvisUs9gLwTP+Rwl8IVro3qr9vpHs33wgxvoQ+MKY0fRjIP797AcSZBriysjLSALjJ/v6+ms2m8jwfXrVf/fGu1+s6ODi49tharaY8z837xsEQAAAAU9Zut1WtVoc//oeHh8Mf/8szAvI8H3lcURSq1WrKsuzG+8aRZA8AAACj3mqyPtLxH1sUhTY2NkbSsizT1taWJGl3d1fr6+vDdQJarZaazabW19d1dHQ0Ei9w0323WRoMBoOxcy+Q8/Nzra6u6neSPr5yn9Wj5ul9s3r8rHSGAK6zeiQ9vcPeXXK96+asOsqwOv1CZUjSD0KVj9XVb6UzBDC++zYEYKWfBdK+MvJaweVG+nngS+v/cxTxtaSfSTo7Oxu7W93r4rfi7Oz/0MrKDyYo59+1uvq/lVrX2BgCAAAgQUkOAViNeE+D37oa9ywR7O1FsJ7Tkz6LHgDvlb6njtZzes+VR6yljYMnwHvVnRnpVrfDjx15vV0aoR4A73LCVo+B5+SWuRSwt9vO0yUoha/2rSv90JW75O9FCZ0X60PoPP4PA3Wc3yBANgMCACBB090MaB7QAAAAIMEeAGIAAABIED0AAAAk2ANAAwAAABoAaQuFcFjTeL1Bv55ZAFaAsDcAOXQ8nmWQJV9Adazldy0xZh5Yxx8jfMcMsvZMg/AuYOCJ9pek67uNhtOkctcYsI7Tu26AZx0A74Bn6APnXQfAs+iIFI747xt5vdH+ltAxeb+cjJkKDwKzALzVQ3loAAAAQA8AAAApSm8aILMAAABIED0AAADoO022TiFDAAAALCAaAEnwRMJ79wLwzBqwAmpjzDCQwnW36ucV+ph4NmyT/CNmnue0Xh/PPhCeetyU7toMwYqC9+4RYM0OCEX8e2YM3JSeBdJi7Cgo2RHvS6HNAKzMXqEvdOPT9q3xzoqxk5+15aU3nN6zvr+33sYp/yAwyPyBd/rP1KTXACAGAACABCXZAwAAwKj0ZgHQAAAAQN9psk5xhgAAAMACoAcAAIAEewBoAFzi2QvAGu15Y6SHAm29y4dbZXv2ArCi471CH5NQPLbkj8n27ClglR0j2t9ifUWYXx2eWQDWAVnR8StGeuZIt6L6/5OR7pkFYNXjB9a7xXqAle45idbXnfXF7ZgF8OBrI/3fwukfGXOAQlUvM9pfCk9HijVLI1D371lfZDOXXgOAIQAAABJEDwAAAHqryfoImQUAAMACSm8aIEMAAAAkiB4AAAD0naSlCR+/WJJsAMzLXgBW9L432t9KD9WxzL0ArHMSY81/KRwMbR27dZzePQI83HsBeKY1WHsEePcOyMZMuynds3fA960pA586n9Ta3ODjQFqZewEY0f5mehZOtmYH/Kf/53qa1U/r/XKyNh8JvVesaH/vvgSh9LmeBUADAACAxKTXACAGAACABNEDAABAgj0ANAAAANBbTdYAWLxpgDQALgm9fN5VNT3pVl5vsJ8n3RMAKdljRKGAtzKD/STfOYwVkBg6L1a9zSBA6w7PKrbeJYKt9FDAV2bkteL3rPTv/+dA4l8amf9nI/1/MtJDwX5WunWyzFfIEIpWsz5tfSPdqrdRx9DvTxYIDJT8XyB/NNJDgaRWcKljyV9JwVPufRVQnpk0AIqiULvdVp7nKopCW1tbyrLMzNvpdFSpVFQUhRqNhvI8n26FAQD33KRd+AwBjGVjY0PHx8eS3v/Ab25uqtVqBfO2223t7OwMb29vb+vg4GAq9QQApCK9BsDUZwEURTFyO89zdTodM//Lly/LrhIAAMmZegPgojv/skqlom63G8xfqVS0trY2HAp48uRJMN+bN290fn4+8gcAwHi+i/C3WKbeAOj3+8H0Xq8XTL8YGvjss8/UarXUaDSC+XZ3d7W6ujr8e/ToUZT6AgBScLEZ0F3/mAVwZ1bDoNPpaG9vT0VRaHt7W5KCMQBPnz7Vr3/96+Ht8/NzdyMg9PJ5o8k9swa8y9jGmAVgRftb9bYidkMtx7JnAYQCkL2vgzfdw2xNe5ZJ9Ry85F8iOJRuLRtspZvL+4Yi/v8XI6+1FLA1CyDGUsDW15115eZZCtgZ7e/56v2+Ub8f/Tcj3SjHSg/NGPHORnHMDmD1ufe63a42NzeH8XCWdruter0uSdeC5S96zqvVqoqiUL/fV7VaHbsOU38tsiy7drXf6/WCswCKotDR0ZHq9bq2trZ0cnKiw8PDa3EEkrS8vKyVlZWRPwAAxjO9IYB2uy1J5tD3ZRsbG/rkk0/0ySefaGlpSUtLS9rf35f0/mJ4bW1NS0tL2t7eds+Qm3oD4KIlc1WtVruW1u12tb6+Pryd57mePn1q9hYAAHA302sANBqNsa7U+/2+Wq2WBoPB8G9vb284M25tbU2np6c6PT3Vq1evzOn0lqk3AK62UIqiUK1WG1a82+0Or/Cr1aqOjo5G8n/11VeuLg4AAG43n0GAl+Pe2u32tTi4LMvcP/wXZhID0Gq11Gw2tb6+rqOjo5E1AHZ3d7W+vq6dnR3lea4nT55of39/eIAXcQAAAMybqzPQlpeXtbxs7aN8s8s/7P1+X71eb+Qiut/vD4cTjo6O3MMAM2kA5Hmuvb09SbrWmrm6IFC9XjeHDQAAiOM7SYMJHv8+lPhq8PmzZ8/0+eefT1Due81mc/i7eeHyKroXF8wnJydjlzk3swCmyYqEj1GGNWsgFNnvXcfeOwvAs3Z+jFkA1jmxyvAev+ccWnXxzoLwWPJsnGClPzDylrlHgDVj4GPrgKxI/R878lqzAEJlSPaGBaH0eZoF4F35PvRpNp7z438Lp39kvMut90To9Y+w5v+N6XPprSZrALw/769fvx4JQr/r1f9l/X5fnU7nWld/URTDIfGLpfWLohi7FyDJBgAAAGUoYxba73//++AUwMePH+v09HQk/epCezdhSiYAAHob4c/v6qy2y4Hwl9Ou/rBfHkqX3q+Z02g0XAGB9AAAAKDvNNk18fiDy51OR69evZL0H4HvF/FwlwPhL7varZ9lmWq12jBI/uTkxNxUz0IDAACAKboIbr8a1CddD4SXdK0xcKFarU40LZ4GAAAAU+wBmBc0AC4JvXzWqI61Xr9ndoBn34C7pIfiia3n9M5qsIKBQ6yPlFWGdW4957DMNf/NwGbPlAkr3bNvwE3pnr0DrOhwV+S9FI7498wYuCm/le5ZyN77dRf6BMUq23onhiL+z4y8WTj5h+GN1VwzSaz3lTVLxTE7YH4nBqTXACAIEACABNEDAACA3mqyq/hJ1hCYDRoAAADoO0lLEzyeBgAAAAsovQYAMQAAACSIHoBbeEeEPFH23qj+GLMGvLMAYoi1F4DnHHqPp9T4Xc866d79BLyzA0JR3FZ0uLm+/aojv5U3M9KtaH9POWXuBWCVbb1AVtnWngJZIM15Dh8aswCsJelD75UI0f6SFuwSM70eABoAAAAM3k32G754v/+L1T4DAABx0AMAAMA7TTYWuHjrANEAAABggg39/uPxC4YGwCWh188bNOdZgta7XK03ODCU7i0jxrKdVtxQjHPrPYexgjqjCJ1cb7CfN1grlG6u62wFAVqBcKH8VhlWurUuceYop8ylgC1WsN+fjHTPeXG+DtbhW++VUHqJwX7zuxRwemgAAABADwAAAAlKMAaAWQAAACSIHgAAABgCAAAgQQkOASTZAIjRUIsRwR5jJoHkWw7XW2/Pe9oaT7LKiDGrIdY59LwnojX0QyfMGyLtXTo4lL5khYdbXw9WmHko3ZP3LukxZgFYEfyer0drxoD3eELr9TrLWDLeFB8an5ZQdut9FeP9Nq/eabIP9wI2AIgBAAAgQUn2AAAAMIIYAAAAEpRgDABDAAAAJIgeAAAAGALANJUZkW+V742at3gC2L1lx1jHfwF7424WK5ra1ednfT140mOUMavnDEX2e2dGhKL6b8pf5vF8G0727EmxSFH9Xgk2ABgCAAAgQfQAAACQYBAgDQAAABgCAAAAKaAHAACAgSbrxh/Eqsj00ACILEYEe6znDKXH6qXyHE+scxLjeGLs4RDNAo4Zli/1r6QSj/8+R/DHkOAQQOqfNgAAkmwAEAMAAECC6AEAAIBpgAAAJCjBIQAaAJg7MRrSZX4WzbI90ZixyvBGL7pO7neR0mM8Z6z80y4jRnqM+inO+xDRdLtdbW5u6vj4+NZ8klStVlUUhfr9vqrVqiSpKAq1223lea6iKLS1taUsy8auAw0AAACm2ANw8aN98eN+k4ODAz1//lySVK/X1Wq1hvdtbGwMGxBFUWhzc3Pk/tvQAAAAYIoxAI1GY+y8a2trOj09laSRq/uiKEby5XmuTqczfiXELAAAAOZalmXXuvY7nY4qlcpIWqVSGatX4QI9AAAAvNNkQwB/7gE4Pz8fSV5eXtbysrUt9O36/b7a7bYk6ejoSNvb28rzXP1+P5i/1+uNXTYNAAAAIg0BPHr0aCT52bNn+vzzz+9c7OXAvjzP9eTJE52cnJj5rYZBCA2AKZmXsRZrNVCCfsM83wcDI/OS9QDP2sbeaH9P+uDbcN6lGBHs3xh5Y6U/dOT1ft2FyrHKts6J9ULEmAXgTC9zlgqGXr9+rZWVleHtSa7+pfdj/RdR/xfR/kVRKMuya1f7vV7PNQtgXn6XAACYnbcR/iStrKyM/E3SAOh2u3r8+PG19Eqlonq9HnxMrVYbu3waAAAARGoAeF3tsu92u8MI/zzPtbe3N7yv0+mo0WgoyzLleT7yuKIoVKvVWAcAAACXKU4D7HQ6evXqlSRpd3dX6+vrw6mBF7d3dnaUZZlqtZr29/eVZZlOTk5G5vm3Wi01m02tr6/r6OjItQaARAMAAICpqtfrqtfrI1f3F67+iFer1WEMwFWXewg8awtcoAEAAAB7AWBSVpT9pHklO2DDKieU7u3hssr2BI/EOs4YvMH0njKiPKmV1wjUd88a+B9jpknSAyvi/WtHuievJH1spIei/aXwV5gVHR9jFoD3eKx069z+yZHXSP/OePGt90Qo3ZNXijPDYNYSbAAQBAgAQILoAQAAYKDJggAHsSoyPTQAAABgCAAAAKSAHgAAAKa4DsC8oAFwR97I9lB+q/vFG+3vyR+rl8pzPBZvfu85jyHGcv0fWFH2ofQYUf2SHTgemk1g5X1gRbCHItWlcMS7J+9N6Z7lVK2ZBNbXnWdN/RjnRJL6jvzOc2W9J6yZJKF0qwzv+9NRxMwxBAAAAFJADwAAAAn2ANAAAACAGIDpKIpC7XZ7uLfx1tbWjTsYdTodFUUx3P3I2gYRAIA7oQdgOjY2NnR8fCzpfWNgc3PT3MWo0+mo1Wrp4OBARVHoyZMnOjk5mWZ1AQC4d6beALjY5/hCnufqdDpm/u3t7WFjIc/z4RaKk/CsnV/mev2eetwlPVQXbxmWWRzPvLMuAD7wrJPujeq30q1y3jjKWOkbd3gi260yPjLSrTX/LaFIfeuAYuwFEDqBkvRvRnrfSC9xJoV1+FbVQ+8Va8ZAibMDZu6dJruKX6Rj/bOpzwLodDqqVCojaZVKRd1u91reoijU6/WUZZm63a76/f5wGAAAgGjeRfhbMFNvAPT7/WB6r9e7ltbtdlWpVIbxAs+fP1e73Q4+/s2bNzo/Px/5AwAAYXMzCyDUMOj1eiqKQvV6XVmWaWtrS5988okGg+u7Luzu7uqLL76YQk0BAPdOgkGAU+8ByLLs2tX+RTf/VXmeK8uy4X0X/4aGC54+faqzs7Ph3+vXr2NXHQBwXyU4BDD1HoB6va6Dg4Nr6bVa7VqaZ7x/eXlZy8ue5UInE2O5XquMD53PaeX3NEi9791QXax6eI9nFkGNnhgmK68VH/XA8wBvUJ+V34obC6Vbeb81IsEeWAFvWSDNymsF+3mX6w2dAO9SwJZQ2d6lfa3j96RbZRvp3oDRULp3OWFHcOACXijfW1PvAbj6o14UhWq12sjV/cVMgTzPVavVhsMDF2sBVKvVaVYZAHDfvY3wt2BmEgPQarXUbDa1vr6uo6OjkTUAdnd3tb6+rp2dnZG8a2trOj4+jjINEACAEQnGAMykAZDnufb29iRJjUZj5L6rCwJlWRYcMgAAAHc3N7MAAACYGfYCAAAgQQmuBEgD4BbeSPUYywxb6VY0vRl9bqSHxJgFUOYSxlb+qUexyj5X5neH9QKF0r3R/tbyrlb+/z5mmmTPDnDNArBm5sSIyJfCEf/eWQDWDAPPMsN9I/0rI906h6H8Rt5/N96J1uvpmQXgnY3iWe56XiXYAzCL708AADBj9AAAAMAsAAAAEpRgA4AhAAAAEkQPAAAACQYB0gC4JEZku9WlEmPtfCuq3wrM9fD2XoWO33s8VnqM9f09r8NNQufFHfDsmQXgXcfditT3RPb/0chrpT80FoT/wZeBRO9XjGfNfyl8QH0jr7cuoSkW3lkAVvr/a6SHIv6NWQDe183zXvG8Z29KD/wozu3vJEMAAAAgBfQAAACQYA8ADQAAAAaabHxiEKsi08MQAAAACaIBAADA2wh/Dt1uV2tra2Pl29/f1/7+vjY2NtTv90fu63a7kqSiKIb/H1eSQwCetea90f6eCH4rqt8bNf/QSPfwtgRjzALwHr9nlkaZrF5CczaGZ31/7ywA7+yAUIT4R0bevpFuvtC962nmN4wV7W9tbvC1kZ4F0qxPRJl7AVj1s/YCCM2YMNLPjXdcjGh/KXxI3v0EvHsEzKMpTgNst9vK83ysH+xOp6OdnR1J0v7+vh4/fqzj42NJ0sHBgZ4/fy5JqtfrarVarirTAwAAwBR7ABqNhqrV6q35ut2udnd3Rx7X7XZVFIUkaW1tTaenpzo9PdWrV6+UZdn4lVCiPQAAAMy7arWqFy9eDG9fdP9XKpVhmvdH/zIaAAAARJoGeH5+PpK8vLys5WVrW+zbNRqN4f9fvnyper0+/NHv9/tqt9uSpKOjI21vbyvP87HLpgEAAECkGIBHjx6NJD979kyff/75BAW/d/FjfzH+L0lbW1vDxkCe53ry5IlOTk7GLpMGwC08AYM3pYfipmIt+etptFr1m8VSwN5AylB6jGWDb+JZCtj67hgYL9ySZylgb2CXFSAWCvj7oZHXumjxrOGcBQIDJemBd8lfK8juLJBmVdz7dReqizdIsW+kG8v7fh14Qa0irHTvEsGh95A32M9YHTqUf5HiAu/i9evXWllZGd6e5Or/smazeW2cvyiKYSxBnucqikJFUYzdC0ADAACASEMAKysrIw2AGPb399VsNpXn+TAOoCgKPX78WKenpyN5L8cH3IZZAAAAvNNkMwDuOHxweV6/pJEof+n9lMFqtTr88T88PFSWZcrzXHt7e8N8nU5HjUbDFRRIDwAAAFPU6XT06tUrSdLu7q7W19eHwX4Xt3d2dlQUhTY2NkYem2XZcOy/Vqtpf39fWZbp5OTEvQ4ADQAAAKa4EFC9Xle9Xh+5gr9w+Uc8z3MNBvYmA9Vqdaz1BCw0AAAAYDfAtJW5FHCMqPkYS/7GmgUQ4p3VYB2Pld9zDstcItg6V45AaEnSA89SwN5ofyuyPzQLIMYLYbFO1o/Ow+kfe5b8laSPA2nW15r36y7CUsAD4zg9kfp9I6833bN0sHfpaccUpUkushEXDQAAAKY4BDAvaAAAAMAQwHh+85vfaGlpSU+ePNHPfvaz2HUCAGC6EmwA3GkdgKdPnyrPc/393/+9KpWK/uZv/ka//e1v9S//8i+RqwcAAMpwpx6A1dVVbW5uanNzU9L7hQt+85vf6B//8R/12Wef6e/+7u+iVhIAgFIRAzCe8/Nz/f73vx92/1erVW1vb+sXv/iF/umf/km//e1v9bd/+7dRKxqTJ4jZ6iLxBkh79gKwgrKtHiZPz5MVrGvVxcM7qyHGHgFWXu8eDpbQZ9r6nFvpUWYBePcIsCK+Q28u7wvk4T0p3xgPeGjsKRBK/7716keYBfCdUT/v7A3rdQttbdA38lrp3r0AQulW/byzAKz0eXSxEuAkj18wd2oA7OzsqNfraXt7W/V6XWtrazo+PtYvfvEL/fSnPx1ZxhAAAMyfO8UArK2t6fDwUP/8z/+ser2u09NT7ezs6OzsTLVaTUtLS7HrCQBAeSbZB2DSAMIZuVMPwObmpv7hH/5BP//5z/WLX/xi5L4XL17opz/9aZTKAQAwFQnGANx5N8Cf//znwXR+/AEAmH8sBAQAwFtNcEmsdIYA7qvQax9rL4BQujWTwAqc9e4F4NnbIAbvjIkYewRYxzNPewFY6R+FXug3RmYrmty7R4BnFoB344hQuvVmtqLMQ3sVSPbeBqE3xYdGX+z3rFfCECrGOh6raO8sAM9eAKEZAzflN7YlCNbFqrdzlsogcA7n9neSIQAAAJACegAAAGAIAACABNEAAAAgQQNNNo4/iFWR6SEGAACABNEDcIknat6KYPfMAvDuBeAVqrv1nDECWL2zAJaNdM8eAd79BLyzA0K9elZPn3fZ+7eBOz6wosOtKHjvSQylxzgpki9q3joeK/rc+lB4PlgxjtN6kWPt4RA6/r6R10q3ZgfMYC+AUPLc9pS/lTTJIrZze2A2GgAAACTYAGAIAACABNEDAABAggsB0QAAACDBIYAkGwCe5X2tMRJvwFsohslqMHpWWr1J6Di9AWwe3uWRvUsEe+LXvEs4e3iD/TzxYR9Zma3gOO/J9ax3HSPa0ToeKwjQs4Sx5Ftj2/vih47TOifeF98TBOgJ3pP8wYGh5/QuBWwshRw6LQt4oXxvJdkAAABgBEMAAAAkKMEhAGYBAACQIHoAAAB4p8mu4hkCAABgAb3TZEMANADuHytA2rPSqpUeaylgTyR8rBkGnnp4A9U9+WOt+mrxLAVsBEK7AsR/+Cacd8mKGo8xC8DifbOEDsiKGrfe5Fa6teSx500RQ6xZAFZ66PU/N/J6Zwd4yvHMUpDC9Zbv8zNzk1Zsbg/MRgwAAAAJogcAAIAEewBoAAAAkGAMAEMAAAAkiB4AAACmPATQ7Xa1ubmp4+PjG/MVRaF2u608z1UUhba2tpRl2a33jYMGwCWhyHHvWvNWeihYOVaP0bzPAihzJoV3zf8YswOs1827R0Ao3Qqy/si6I8amB7EOqMxZAGW+KTy858SaGuKZBeCNyI8xa8C5F8DAOH7rtMylKQ4BXPxod7vdW/NubGwMGwlFUWhzc1OtVuvW+8ZBAwAAgClqNBpj5SuKYuR2nufqdDq33jcuYgAAALhYCfCufyUEAXY6HVUqlZG0SqWibrd7433jmkkDoCgK7e/vq91ua39/X/1+f6zHNZvNsfMCADC2SX78L/4knZ+fj/y9eWOskjQG6/eu1+vdeN+4ZtIA2NjY0M7OjhqNhhqNhjY3N299TLfb1f7+/hRqBwDA3Tx69Eirq6vDv93d3ejPcdOFsOcieeoxAHcdtyiKQnmel1UtAEDKJu3C//PjX79+rZWVlWHy8rK1jvXtsiy7dkXf6/WUZdmN941r6g2Am8YtqtVq8DHtdluNRkPNZjNKHTwR4lZebwS7Z01sb0S+J8reG5XrqYs3+Nq7F4BnP4UyA8HL3AvAPHajkAdWhHiMNf+9BxSqixVN7o32t/KHXuhZ7AVg/XjEeFNY59A7O8DKH0p37mFgZV+4vQAGEzz+z++BlZWVkQbAJOr1ug4ODq6l12o15Xlu3jeuqTcAvOMW/X5/rBbNmzdvRsZazs+tuTAAAFwRqQHgdfU3rtvtKssy5Xl+rde7KArVarVhD4B137jmZhaA1TA4PDxUvV6/9fG7u7sj4y6PHj2KXEMAACbX6XSGPdq7u7tqt9vD+67ebrVaajabarfbOjg4GJnnf9N941gaDAaTtHncnj9/roODg5HVjz755BO1Wq1rP/SdTmekRfPZZ5/p+Pg42MIJ9QA8evRIv5P08ZW8np4zK6/V5eVZP8O7U6hnQRkp3NV234YAvOvJ/NCZ/0eBtI+cZVudgaGyQ2k3pT+whhc9BcU6oFBdrLIZAgibxRBAaCEga9Ggfjj5341A91AxRhE6C6R9Lelnks7OzqJ1q191fn6u1dVVnf1YWpngkvj8nbT6Vbl1jW3qQwA3jWmEHB4eDv9fFIV2d3f1q1/96lq8wPLy8kTBFgCAhL3TZEMAU72UjmPqDYCbxjSk0fGPqz0C29vb2t7eLm02QKjxF2t52xjBMN66hMr3LoVr1dFTjndZ3hirvnqP08ofurCLdREYSrd6f8xzaFx5mccfqqS3a8lKD12lxwoCtNJD3Uix1oH2fEDL7AHwBF1K4eWEb8ofukw38g6Msj1vlQXcNO/emkkMwE3jFlfHP6T38QEXawDs7e25VjoCAOBW7yL8LZipxwBMy8W4jicGwDP85h2/98QAxLogKzMGYF56AKw4AusC0xok8gxVW0Pj3qH0MofjP/AcaKwDCp2sMjf9kegBCCmzB+Dr8Yuw0j15pxoD8LG0MsFmQOcDafXrxYoBmJtZAAAAYHrYDRAAgLeabDvgBexLpwEAAMA70QBIQYzxa0+0/03pHt559qFhSaveZcaveIdkPesGWMcTaxg4xDpX1mtsDeGGhmq9sxqsYd2HxjjwA8+0Bs84teSLAfCO9XvWfC5zHWiLNwbAyu+JAYgRiCS5lnD2xi0t1FLACUqyAQAAwAiGAAAASBANAAAAEjTQQv6IT4JpgAAAJIgeAABA8t5qsgDFRQxupAFwSSh42FppzgritQKQrXI8rEhbqxsnlN87e8ESOn5vd1KMfRa8ZcSYBWDxzg4IBYjH6pIzZ6ME3hQPQ9uwSVryRPtLvu0aPSv7Sb5pHfM0C8A7LSj0ofXOAogwa+Bb43hirF46ryvmptgAYAgAAIAE0QMAAEjepPv5zGvPxk1oAAAAkscQAAAASAI9AACA5DEEkLhQ8LDVrePdIyAGK7jZisD1HE+ZewTEmh3gmQXgfR08swNiBHZbzxlrloJVl9DradXP2k/gQyN9KXTSjTXlo6z5b6XHesOFxJguc1M5oRfD+8Yy0gdGeiiy3xvtb215sEjd4gwBAACAJNADAABI3jtNdhXPEAAAAAuIGAAAABJEDAAAAEhCkj0AVqvH0xoqc015z9r+N+UPdUnFCmKOIUawtmeJ+Ls8p4d1br2zNzxle/N79oewIsHNZfwDhX9oHKQZ1B/jBfV+OD1vCu8HIsIHzoret6piReR7Jg14o/2t/DG+g6YlxR6AJBsAAABclmIMAEMAAAAkiB4AAEDyGAIAACBBKQ4B0AC4RaxgP8+bw/ucVv5Qi9QK4IrRerWOMdY4k2fpXG8smYc32G8WVwaegC8zqM9It85tKL/3dfjQeBN94PgAlfnae8UIuvUuPT1Hqw+7Al0xfTQAAADJYyVAAAASlGIMALMAAABIED0AAIDkEQQIAECCpj0EUBSF2u228jxXURTa2tpSlmXBvO12W/V6XZKu5el2u5KkarWqoijU7/dVrVbHqgMNgEtCUcLeVp0nv2cJ37vkD70hrTepFQk+T63aGEs1l7lEcJljgN5IcM+MBCtS+42R7lk6ONbr4Ingn8Uy0F6ez1WsZaBjfE94Zxh4yp61aTcANjY2dHx8LOl9Y2Bzc1OtVsvMe9Xe3p52dnZ0cHCg58+fS5Lq9bpZRggNAAAApqgoipHbeZ6r0+kE8/b7fbVaLTUajWHa/v6+dnZ2JElra2s6PT2VdL134Dbz1CgGAGAm3kX4G1en01GlUhlJq1Qqw+78qy7/+Lfb7ZHb0vsffu+Pv0QPAAAA0YYAzs/PR9KXl5e1vLw8ktbv94Nl9Hq9a2mXf9j7/b56vZ7yPB9Ja7fbkqSjoyNtb2+P3H8TGgAAAETy6NGjkdvPnj3T559/PtZjrYbBhWazqb29vZG0y8GDeZ7ryZMnOjk5Gev5aAAAAJI30GRBz4M///v69WutrKwM069e/Uvvr+qvXu33er0bu/H7/b46nc61PEVRDKP+L2YUFEUxVi8ADYBbxAqSiFFOjFkD3vXQ5zVi94L3eGYR9OI5h96ofu+MkVD53kj9b410TxllzgIoc++JspW5J0eM54wxC2BexRoCWFlZGWkAhNTrdR0cHFxLr9Vq5mN+//vfB6cAPn78eBgEeOFqfIGFIEAAAKbo6tV5URSq1WrDH/hut3ttpkC32732w57n+ciQQKfTUaPRGDsgkB4AAEDypr0OQKvVUrPZ1Pr6uo6Ojkbm7+/u7mp9fX041e/C1YZDlmWq1Wra399XlmU6OTlxrQOwNBgMBrdnWzzn5+daXV3V7yR9fOU+qwvTsxVnjK4wawGWGFuIWuWU2T04C2UPAYTKj7XdbIyyvV3poUV8ylw0iSEAn5SHAEJlfy3pZ5LOzs5u7Va/q4vfiv9L0kcTlPMnSf+ryq1rbAwBAACQIIYAAADJS3E74CQbALPo2vPwrON+U/5Q9463e9Ba930R3+w3ifGeiLEuf9nPGWOvijKHBmLkjzHMk7pYn+952kvkNjQAAABIUIrbARMDAABAgugBAAAk750m68ZfxB4AGgAAgOQxBAAAAJJAD8AdlRk57I2ytlqeoXK8XVxW/hgtx0VsMd/FPEX7hxafKjNqfhZ7NcT6bM5TXcq0CHWcBmYBAACQoBQbAAwBAACQIHoAAADJSzEIkAYAACB5KQ4B0AC4xBMM4wm8s8QI6pN8b7wyA768HwBv8NEifsC8YgVpWmIEhlq7WI77fHcxLwF59+14pDifq3k6t3eVYgOAGAAAABJEDwAAIHkDTTaOP4hVkSmiAQAASB5DAAAAIAn0AAAAksc0QIxtUbtOvDMJPPm958T7gYkRwW6ZRffdLL4wpv2cnhkDUrmfq1lEqpcZ7e99La26hN77sSLyZx3Z78EQAAAASMJMegCKolC73Vae5yqKQltbW8qyLJi32+2q0+lIko6OjvTixQszLwAAd5FiD8BMGgAbGxs6Pj6W9L4xsLm5qVarFczb6XS0s7MjSdrf39fjx4+HjwUAIIYUYwCmPgRQFMXI7TzPh1f4V3W7Xe3u7g5vNxoNdbvda2UAAACfqTcAOp2OKpXKSFqlUlG3272Wt1qt6sWLF8Pb/X5/mB8AgFjeRvhbNFMfArj4Eb+q1+sF0xuNxvD/L1++VL1eD8YAvHnzRm/evBnePj8/n6ieF2KtVz+L6OYy35AxIvJnUW/vbAdPGbMwT3WJoczjsWYkzOK1t54zlG51LceYuXNTfk9eT/f3vM4MeKfJXl+GACZgNQwu399ut81Ygd3dXa2urg7/Hj16VEItAQD30bsIf4tm6g2ALMuuXe33er1bI/ubzaZevXpl5nv69KnOzs6Gf69fv45UYwAA7p+pNwDq9XowvVarmY/Z399Xs9lUnufq9/vB3oLl5WWtrKyM/AEAMI4UYwCm3gDI83zkdlEUqtVqwyv7q1H+7XZb1Wp1+ON/eHjIOgAAgKhSHAKYyToArVZLzWZT6+vrOjo6GhnX393d1fr6unZ2dlQUhTY2NkYem2WZtra2pl1lAADulaXBYLCI2xjf6vz8XKurq/qdpI/HfMy0u3DKfr4YLVJPHWO1gD3P6T2H3jrOS11ivVfKvEqZly7QMqPMvV2mVl085XhmDNzEes5QOd56e/J7judrST+TdHZ2Vtqw7sVvxf8u6eEE5Xwj6b+q3LrGxmZAAIDkpbgU8NxMAwQAANNDDwAAIHkp7gVAAwAAkLwUVwKkAXDJtJcEjRWsNIvlh+ed95xYH17PksezWNrYMu0A0HkqO3XzutQuRhVFoXa7rTzPVRSFtra2zCnuF3vlVKtVFUWhfr+varXqLucqGgAAgORNOwhwY2NjuLV9URTa3Nw0l7o/ODjQ8+fPJb1fTO9yPk85V9EAAAAkb5oxAFe3tM/zXJ1Ox8y/tram09NTSRq5uveWc1XKvcQAAEia7lLAnU7n2rb2lUpl2NUfkmXZta79u5RzGT0AAABEcnUr+uXlZS0vL4+kWbvfXt0o73L+drstSTo6OtL29vZweXxPOVfRAAAAJC/WEMDVreifPXumzz//fKwyrB/0y4F9eZ7ryZMnOjk5cZdzFQ2AOyoz0tYbTBKjLrOYSRAjUr/siGfPc3pnB4z7fHd5Tu9sh7LMItq/zM+P9zX2nu9pz0Qq2yKNMccKAnz9+vXIUsBXr/6l9935V6/Se72eGb1fFMUw6v8i2r8oCnc5Vy3S6wMAwFy7ui19qAFQr9eDj63VatfSut2uHj9+fC29Uqm4ygmhBwAAkLxpTgPM83zkdlEUqtVqwyv3brerLMuU57nyPNfe3t4wb6fTUaPRCAYFXi3nNjQAAADJG2iyITLvtrqtVkvNZlPr6+s6Ojoambu/u7ur9fV17ezsKMsy1Wo17e/vK8synZycjOS9qZzbsB3wHFqEcdOQMrfa9ZbvLdvKP+3nXORzWFYZZYsRR1Lm1ryxtiAua8teqwxJ+nDCsqe5HfCWpAcTlPOtpOdiO2AAABZKitsB0wCYQ2XvERDjOUNlL0JE6TxF6ofE2KvgpucMlV/m8czT/gizWCN/ET4TeC/FBgDvTwAAEkQPAAAgedPcC2Be0AAAACQvxSEAGgAAgOSl2ANADAAAAAmiB+AeK3Nd8Rhlx4h4j7WHQYzZAbMQI4I/1syDcZ/PW8aslFnHMtce8M7Vj2ERXs/bMAQAAECC3mmyH3GGAAAAwEKgBwAAkLwUgwBpAAAAkvdWk3WJL2IMAEMAAAAkiB4ASIqzF4C37BizA2KVHcMsnrNMs9jbYJ7EeN1i7BJYdoR9qPxZzCSYtRR7AGgAAACSl2IMwH1u0AEAAAM9AACA5DEEAABAglIcAqABgDvxLMvrKeOmckKt8xhL4VplW+XP07Kn3uOM8brFCOybp3MYg/fK0XP8MQIJbyrnvr0Wd8VKgAAAIAn0AAAAkvdW0tKEj180NAAAAMlLMQaAIQAAABJEDwAAIHkMAQBzwBPZnkoX1jzNavDMMPCaxZdomVHwsSL4Y5Ttye+dSXAfPocpNgDuw+sGAACc6AEAACQvxSBAGgAAgOQxBAAAAJJADwAAIHkDTdaNP4hVkSmiAYBovJHqMcovex37MiPEPXsbWGLsBWDxzjCI4UNnfs/5mqfuzjL3ArCUOcOg7HKmYdLvqUUcAqABAABIXooNgHlqFAMAgCmhBwAAkLx3mmwWANMAAQBYQCkOAdAAAABgyoqiULvdVp7nKopCW1tbyrIsmLfb7arT6UiSjo6O9OLFi2HebrcrSapWqyqKQv1+X9Vqdaw60ABA6cqcHRBrHft5CYaZp+NZpAjuRVPm+y3G6+at3314r0y7B2BjY0PHx8eS3jcGNjc31Wq1gnk7nY52dnYkSfv7+3r8+PHwsQcHB3r+/LkkqV6vm2WEzMv3HgAAM/Muwt+4iqIYuZ3n+fAK/6put6vd3d3h7UajoW63OyxjbW1Np6enOj091atXr8xehBAaAAAATFGn01GlUhlJq1Qqw+78y6rVql68eDG83e/3h/kvZFnm+uG/wBAAACB5k0bxXzz+/Px8JH15eVnLy8sjaRc/4lf1er1geqPRGP7/5cuXqtfrwx/8fr+vdrst6X18wPb2tvI8H6vONAAAAMmL1QB49OjRSPqzZ8/0+eefj1WG1TC4fH+73R6O/0saCR7M81xPnjzRycnJWM9HAwAzEyvgrcznjFF2mdODZjGGt4jznWdlEcZYpx3Adx8CBm/y+vVrraysDG9fvfqX3nfZX73a7/V6t3bjN5vNa+P8RVEMo/4vZhQURTFWL8AivD8BACjV2wh/krSysjLyF2oA1Ov1YB1qtZpZv/39fTWbTeV5rn6/r36/r263q8ePH1/LezW+wEIDAACQvFgNgHFcvTovikK1Wm1kbv/lmQLtdlvVanX44394eKgsy5Tnufb29ob5Op2OGo3G2AGBS4PBYBF3MbzV+fm5VldX9TtJH8+6MohiEVfakha33haGAMa3CFdY8zwE8LWkn0k6Ozsb6VaP6eK34j9rstfrnaT/pvHrWhSFDg4OtL6+rqOjIz19+nT4w72xsaH19XXt7OyoKAp99tlnI4/Nskynp6eS/mORoCzLdHJyMtIguA0NACyMRf0hXdR6W2gAjI8GwGTPd58bAPOAIEAAQPLeSprkangRG8Y0ALAwFjV6eFHrDaTknSZrACxiV/pMGgCeTRA8eQEAwHhm0gDwbILgyQsAwF28k7Q0wePpARiDZxMET14AAO7qrdJrAEw9SNWzCYInLwAAGN/UewA8myB48r5580Zv3rwZ3j47O5Mk/clfRQDAHLj4/p7GbPUUewDmZhbAbZsg3JZ3d3dXX3zxxbX0/zJBnQAAs/fVV19pdXW1lLIfPHigTz/9VF9++eXEZX366ad68OBBhFpNx9QbAJ5NEDx5nz59ql//+tfD2/1+X3/1V3+lf/3Xfy3tjXMfnJ+f69GjR9c2sMAoztN4OE/j4TyN5+zsTD/5yU/GXtv+Lh4+fKg//OEP+vbbbycu68GDB3r48GGEWk3H1BsA9XpdBwcH19JDmyB48ob2XJak1dVVPmBjuNi4AjfjPI2H8zQeztN4vve9csPVHj58uFA/3LFMPQjQswnCbXkBAMDdzCQGoNVqqdlsDjdBuDyvf3d3d7gJwm15AQDA3cykAXB5C8NGozFy39Uf+Jvy3mR5eVnPnj0LDgvgP3CexsN5Gg/naTycp/Fwnsp1b3cDBAAAtkXYrRIAAERGAwAAgATRAAAAIEFzsxLgXbCt8Hg8x97tdocbLh0dHenFixecp1s0m009ffqU82TodDoqimI4rbder0+pprPl/X662PukKAo1Go1r06Dvq263q83NzeGur5aUv8NLM1hg1Wp1+P+Tk5NBo9GIkve+8Rz73t7eyP8vP/a+u8t75Pj4eCBpcHp6WmLN5ovnPL169WqwtbU1zJvneen1mxd3/dwNBoPhObvvWq3W8DN0m5S/w8uysA2Ak5OTaz9OWZZNnPe+8Rz78fHxyH0nJycDSYOTk5NS6zgP7voeabVagzzPk2kAeM/T1XOTwntpMPCfp6t5U2kAXLitAZDyd3iZFjYGgG2Fx+M59mq1qhcvXgxvX2y6VOY63PPiLu+RdrvtWpviPvCcp6Iohnt3dLtd9fv9ZLq1ve+nSqWitbW14VDAkydPplHNhZHyd3iZFrYBUNa2wveN99gv/6C9fPlS9Xo9iXE273nq9/tJnJerPOep2+2qUqkMx22fP3+udrtdcg3ng/f9dLEA2meffaZWq5Vcw/I2KX+Hl2mhgwBDJt1WOBW3HXu/31e73b41MOe+s87T4eGhtra2pluZORY6T71eT0VRDBuRW1tb+uSTT6ayt/u8st5PnU5He3t7KopC29vbkhTcCA2jUv4Oj2FhewDK2lb4vrnrsTebTb169SqJcyT5zlOn09Evf/nLKdVsvnjOU57nyrJseN/lDb/uO895KopCR0dHqtfr2tra0snJiQ4PD4eboiHt7/AyLWwDwJpKZG0rPG7e++Yux76/v69ms6k8z9Xv95NoZXvP0+HhoZ4/f67nz5+rKArt7u4m8cPmOU+pjPeHeM5Tt9vV+vr68Hae53r69GkSn7txpfwdXqaFbQCwrfB4POdJeh/YVq1Whz/+h4eHnCeNnqeLK7WLP0na3t5WtVqdap1nwfu5q9Vqwx+yi7UAOE+j56larero6Ggk/1dffZXEebrsaoOH7/DyLfRmQEVR6ODgYLhV8OXFWDY2Nka2Fb4p73037nkqikKfffbZyGOzLNPp6ekMaj19nveT9P4L6/nz52o2m9ra2kqmEeA5T/1+X81mU2trazo+Ph72LKXAc546nY663e7w/nq9nsR56nQ6evXqlfb397Wzs6P19fVhACTf4eVb6AYAAAC4m4UdAgAAAHdHAwAAgATRAAAAIEE0AAAASBANAAAAEkQDAACABNEAAAAgQTQAAABIEA0AAAASRAMAAIAE0QAAACBB3591BQD4FEWhTqejk5MTbW9vq9vtsjkKADd6AIAF0+l0tLW1pSdPnmhjY0ONRkPtdlu9Xm/WVQOwQOgBABbML3/5S0nv90v/1a9+JUk6OTmZZZUALCB6AIAFc9HN//Lly+He6f1+f3YVArCQaAAAC+T58+dqNpvqdrsqikJ5nkuSDg8PZ1wzAItmaTAYDGZdCQDj6XQ6KopClUpFWZapKApJ0tbW1oxrBmDR0AAAACBBDAEAAJAgGgAAACSIBgAAAAmiAQAAQIJoAAAAkCAaAAAAJIgGAAAACaIBAABAgmgAAACQIBoAAAAkiAYAAAAJ+v8BXq7GKyVhVv8AAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Construct the data of initial conditions\n",
        "coefficients = torch.zeros((m, k, k)).to(device)\n",
        "initial_conditions = torch.zeros(m, n_x, n_x).to(device)\n",
        "for j in range(m):\n",
        "  function, coefs = initial_cond_dirichlet(xmesh, k)\n",
        "  initial_conditions[j]= function\n",
        "  coefficients[j] = coefs"
      ],
      "metadata": {
        "id": "cDZVC4F_AS-A"
      },
      "execution_count": 8,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Fully resolved finite difference method, later coarsened\n",
        "- first run the fully resolved FD method\n",
        "- then averaged down to coarse mesh\n",
        "- average in space x-factor adjacent grid points\n",
        "- sample in time, (the t-factor time step)\n"
      ],
      "metadata": {
        "id": "4Re-OB_Ae6kh"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Define inputs and outputs of neural net which are PDE intitial condition and averaged solution at t=1,..,t_k respectively\n",
        "\n",
        "#Maximum time value to generate data for\n",
        "t_max = coars_max**2*t_k+1\n",
        "solutions_exact = torch.zeros((1, t_max, n_x, n_x)).to(device)\n",
        "\n",
        "filter = torch.tensor([[0,1,0],[1,-4,1],[0,1,0]]).float().to(device)\n",
        "one_filter = torch.tensor([[1]]).float().to(device)\n",
        "#Loop over all initial conditions (data points)\n",
        "for j in range(m):\n",
        "  #Create FD solution with initial condition\n",
        "  sol = torch.zeros((t_max, n_x, n_x)).to(device)\n",
        "  sol[0]=initial_conditions[j]\n",
        "\n",
        "  #Solve forward in time (full grid) using finite differences\n",
        "  for i in range(1, t_max):\n",
        "    # Performs convolution corresponding to numerical FD step\n",
        "    convolution_no_pad = F.conv2d(sol[i-1].unsqueeze(0), filter.unsqueeze(0).unsqueeze(0), padding = 0)/(dx**2)\n",
        "    # Adds boundary zero condition (hacky way to add ZERO boundary condition)\n",
        "    convolution_with_zero_pad = F.conv2d(convolution_no_pad, one_filter.unsqueeze(0).unsqueeze(0), padding = 1).squeeze(0)\n",
        "    # time step\n",
        "    sol[i] = sol[i-1] + dt*(convolution_with_zero_pad)*a_xy\n",
        "\n",
        "  #Add to solutions tensor\n",
        "  solutions_exact = torch.cat((solutions_exact, sol.view(1, t_max, n_x, n_x)), 0)"
      ],
      "metadata": {
        "id": "nsLp5Sf9AdB9"
      },
      "execution_count": 9,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Construct the OOD data from a different spectrum\n",
        "OOD_spec = torch.ones((k,k)).to(device)\n",
        "for i in range(k):\n",
        "  for j in range(k):\n",
        "    if ((i>=2) and (j>=2)):\n",
        "      OOD_spec[i][j] = 1\n",
        "    else:\n",
        "      # OOD_spec[i][j] = 1/(np.sqrt((3-i)**2+(3-j)**2))\n",
        "      OOD_spec[i][j] = 0\n",
        "\n",
        "def initial_cond_OOD(x_mesh,k):\n",
        "  coefs_rand = (torch.rand((k,k))-0.5).to(device)\n",
        "  coefs_actual = OOD_spec*coefs_rand\n",
        "  func=torch.zeros((len(x_mesh),len(x_mesh))).to(device)\n",
        "  for i in range(1, k+1):\n",
        "    for j in range(1,k+1):\n",
        "      func+=(coefs_actual[i-1][j-1]*torch.tensor(sin_xy(x1,x2,i,j)).to(device))\n",
        "\n",
        "  max = torch.max(func)\n",
        "  min = torch.min(func)\n",
        "  func = 2*func/(max-min)\n",
        "  coefs_actual = 2*coefs_actual/(max-min)\n",
        "  return func, coefs_actual\n",
        "\n",
        "coefficients_OOD = torch.zeros((50, k, k)).to(device)\n",
        "initial_conditions_OOD = torch.zeros(50, n_x, n_x).to(device)\n",
        "for j in range(50):\n",
        "  function, coefs = initial_cond_OOD(xmesh, k)\n",
        "  initial_conditions_OOD[j]= function\n",
        "  coefficients_OOD[j] = coefs"
      ],
      "metadata": {
        "id": "qHD9sWx5uJKJ"
      },
      "execution_count": 10,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Define an out of distribution data point (i.e. 2 oscillations instead of 4)\n",
        "solutions_exact_OOD = torch.zeros((1,t_max,n_x,n_x)).to(device)\n",
        "\n",
        "for j in range(50):\n",
        "  sol = torch.zeros((t_max,n_x,n_x)).to(device)\n",
        "  sol[0]=initial_conditions_OOD[j]\n",
        "\n",
        "  for i in range(1, t_max):\n",
        "    convolution_no_pad = F.conv2d(sol[i-1].unsqueeze(0), filter.unsqueeze(0).unsqueeze(0), padding = 0)/(dx**2)\n",
        "    convolution_with_zero_pad = F.conv2d(convolution_no_pad, one_filter.unsqueeze(0).unsqueeze(0), padding = 1).squeeze(0)\n",
        "    sol[i] = sol[i-1] + dt*(convolution_with_zero_pad)*a_xy\n",
        "\n",
        "  solutions_exact_OOD = torch.cat((solutions_exact_OOD, sol.view(1,t_max,n_x,n_x)), 0)"
      ],
      "metadata": {
        "id": "rXUhPXdcXRkI"
      },
      "execution_count": 11,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "##Coarsening:\n",
        "\n",
        "Coarsen the space grid by x_factor defined below and sample solutions at the t_factor which corresponds to $x\\_factor^2$ for stability"
      ],
      "metadata": {
        "id": "rirnTDFfvsEG"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Factor by which to coarsen x-grid and new number of grid points (for easier to read code later)\n",
        "x_factor = 4\n",
        "n_x_new = int(n_x/x_factor)\n",
        "#Corresponding t_factor\n",
        "t_factor = x_factor**2"
      ],
      "metadata": {
        "id": "7Jhilvg5vvHW"
      },
      "execution_count": 12,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from traitlets.config.application import T\n",
        "#Define the coarsening function using pooling layers and ensuring the Dirichlet zero boundary conditions\n",
        "def coarsen(sol, n_x, x_factor):\n",
        "  sol_avg = torch.zeros((t_k, n_x_new, n_x_new)).to(device)\n",
        "\n",
        "  #For each output average pool the values and then add the boundary conditions\n",
        "  for t in range(t_k):\n",
        "    sol_avg[t] = F.avg_pool2d(sol[t_factor*(t+1)].unsqueeze(0),x_factor)\n",
        "    for i in range(n_x_new):\n",
        "      sol_avg[t][i][0] = 0\n",
        "      sol_avg[t][i][-1] = 0\n",
        "    sol_avg[t][0] = torch.zeros(n_x_new)\n",
        "    sol_avg[t][-1] = torch.zeros(n_x_new)\n",
        "\n",
        "  #For the iput average pool the values and then add the boundary conditions\n",
        "  inp_avg = F.avg_pool2d(sol[0].unsqueeze(0),x_factor)\n",
        "  for i in range(n_x_new):\n",
        "    inp_avg[0][i][0] = 0\n",
        "    inp_avg[0][i][-1] = 0\n",
        "  inp_avg[0][0] = torch.zeros(n_x_new)\n",
        "  inp_avg[0][-1] = torch.zeros(n_x_new)\n",
        "\n",
        "  return inp_avg, sol_avg\n"
      ],
      "metadata": {
        "id": "SKk7fml1b8wq"
      },
      "execution_count": 13,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Define the inputs and outputs of the model (inputs are the initial conditons coarsened and\n",
        "#outputs are the outputs at the sampled times coarsened in space too)\n",
        "inputs = torch.zeros((1, n_x_new, n_x_new)).to(device)\n",
        "outputs = torch.zeros((1, t_k, n_x_new, n_x_new)).to(device)\n",
        "\n",
        "for j in range(1, m+1):\n",
        "  # Coarsen the solution\n",
        "  inp_avg, sol_avg = coarsen(solutions_exact[j], n_x, x_factor)\n",
        "\n",
        "  #Conactenate our input-output pair to the respective tensors\n",
        "  inputs = torch.cat((inputs, inp_avg.view(1, n_x_new, n_x_new)), 0)\n",
        "  outputs = torch.cat((outputs, sol_avg.view(1, t_k, n_x_new, n_x_new)),0)"
      ],
      "metadata": {
        "id": "RQjhaHuudzsA"
      },
      "execution_count": 14,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Format data into pytorch data_loaders"
      ],
      "metadata": {
        "id": "B0kFuOuesviB"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Add an extra dimension to inputs for mathematical stability of matrices\n",
        "inputs = torch.unsqueeze(inputs,1)"
      ],
      "metadata": {
        "id": "J0l3pGHzmBmM"
      },
      "execution_count": 15,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Chek input and output sizes\n",
        "print(inputs.size())\n",
        "print(outputs.size())"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "6-XTs3rsy2ZS",
        "outputId": "4c5f3b46-b74d-4fff-d367-1091e89f9216"
      },
      "execution_count": 16,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "torch.Size([201, 1, 16, 16])\n",
            "torch.Size([201, 10, 16, 16])\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Format data into datsets and then load them as dataloaders with batch size 16 (this can change)\n",
        "Data_heat = TensorDataset(inputs, outputs)\n",
        "\n",
        "Data_heat_train, Data_heat_val, Data_heat_test = torch.utils.data.random_split(Data_heat,\n",
        " [int(m*train_size)+1, int(m*val_size), m-int(m*train_size)-int(m*val_size)])\n",
        "\n",
        "Heat_DataLoader_train = DataLoader(Data_heat_train, batch_size=batch_s, shuffle=True)\n",
        "Heat_DataLoader_val = DataLoader(Data_heat_val, batch_size=batch_s, shuffle=True)\n",
        "Heat_DataLoader_test = DataLoader(Data_heat_test, batch_size=batch_s, shuffle=True)"
      ],
      "metadata": {
        "id": "TgPiYQFIs5J0"
      },
      "execution_count": 17,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Define inputs and outputs\n",
        "inputs_OOD = torch.zeros((1,n_x_new, n_x_new)).to(device)\n",
        "outputs_OOD = torch.zeros((1,t_k,n_x_new, n_x_new)).to(device)\n",
        "\n",
        "for j in range(50):\n",
        "  # Coarsen the solution\n",
        "  inp_avg, sol_avg = coarsen(solutions_exact_OOD[j], n_x, x_factor)\n",
        "\n",
        "  #Conactenate our input-output pair to the respective tensors\n",
        "  inputs_OOD = torch.cat((inputs_OOD, inp_avg.view(1,n_x_new,n_x_new)), 0)\n",
        "  outputs_OOD = torch.cat((outputs_OOD, sol_avg.view(1,t_k,n_x_new,n_x_new)),0)\n",
        "\n",
        "inputs_OOD = torch.unsqueeze(inputs_OOD,1)"
      ],
      "metadata": {
        "id": "igq161ifzQJd"
      },
      "execution_count": 18,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Format data into datsets and then load them as dataloaders\n",
        "Data_heat_OOD = TensorDataset(inputs_OOD, outputs_OOD)\n",
        "Heat_DataLoader_OOD = DataLoader(Data_heat_OOD, batch_size=batch_s, shuffle=True)"
      ],
      "metadata": {
        "id": "ZtSYfAlbzeya"
      },
      "execution_count": 19,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from numpy.lib.twodim_base import vander\n",
        "from numpy.lib.shape_base import apply_over_axes\n",
        "# Define the Coarsened FD method as a neural net\n",
        "class IndividualLayer_PDE(nn.Module):\n",
        "  \"\"\"This class implements an individual layer of the coarsened grid FD method\"\"\"\n",
        "\n",
        "  def __init__(self, grid_size):\n",
        "    \"\"\"\n",
        "      grid_size: int\n",
        "        size of coarsened grid\n",
        "    \"\"\"\n",
        "    super(IndividualLayer_PDE, self).__init__()\n",
        "\n",
        "    #Define convolution filter corresponding to the heat equation partial derivatives\n",
        "    self.filter = torch.tensor([[0,1,0],[1,-4,1],[0,1,0]]).float().to(device)/(dx**2)\n",
        "    #Define convolution filter of 1 to add the zero boundary condition\n",
        "    self.one_filter = torch.tensor([[1]]).float().to(device)\n",
        "\n",
        "    # Initialize parameters randomly in (-0.5, 0.5)\n",
        "    self.coefs_a = torch.nn.Parameter(torch.rand(grid_size, grid_size)-0.5)\n",
        "\n",
        "  def forward(self, v):\n",
        "    \"\"\"\n",
        "      x: Tensor\n",
        "        Coarsened inputs at a given time\n",
        "\n",
        "      Outputs: Returns the predicted coarsened outputs at the next time\n",
        "    \"\"\"\n",
        "    # Bound coeficients between zero and max_a for stability\n",
        "    a_xy_pred = max_a*torch.sigmoid(self.coefs_a)\n",
        "\n",
        "    # Implement the FD method on the coarsened grid (to learn parameters through back-propagation) - same as when generating the non-coarsened data\n",
        "    convolution_no_pad = F.conv2d(v, self.filter.unsqueeze(0).unsqueeze(0), padding = 0)\n",
        "    convolution_with_zero_pad = F.conv2d(convolution_no_pad, one_filter.unsqueeze(0).unsqueeze(0), padding = 1)\n",
        "    a_xx_yy = convolution_with_zero_pad*a_xy_pred\n",
        "\n",
        "    y = v + dt*(a_xx_yy)\n",
        "    return y"
      ],
      "metadata": {
        "id": "2U1ROo4QgWRb"
      },
      "execution_count": 20,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from math import nextafter\n",
        "class PDE_Solver(nn.Module):\n",
        "  \"\"\"This class implements the Full Coarsened FD method\"\"\"\n",
        "\n",
        "  def __init__(self, grid_size):\n",
        "    \"\"\"\n",
        "      grid_size: int\n",
        "        size of coarsened grid\n",
        "    \"\"\"\n",
        "    super(PDE_Solver, self).__init__()\n",
        "\n",
        "    # Call the individual layer class defined previously\n",
        "    self.layer = IndividualLayer_PDE(grid_size)\n",
        "\n",
        "  def forward(self, x):\n",
        "    \"\"\"\n",
        "      x: Tensor\n",
        "        Coarsened inputs to the network at time 0\n",
        "\n",
        "      Outputs: Returns the coarsened outputs at the next t_k times\n",
        "    \"\"\"\n",
        "\n",
        "    # Call the individual layer (FD method) t_k times to generate the next t_k time predictions in the coarsened grid\n",
        "    # and concatenate the new value to the output tensor\n",
        "    prev = x\n",
        "    next = self.layer(prev)\n",
        "    y = next\n",
        "    prev = next\n",
        "\n",
        "    for i in range(t_k-1):\n",
        "      next = self.layer(prev)\n",
        "      y = torch.cat((y,next),1)\n",
        "      prev = next\n",
        "\n",
        "    return y"
      ],
      "metadata": {
        "id": "Cp2MCJ7VYJD7"
      },
      "execution_count": 21,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Define the Training and Validation for the model"
      ],
      "metadata": {
        "id": "K2lqgTBNgk_-"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Define one training epoch through the train and valudate functions\n",
        "# Each call to train and validate runs a training and validation epoch\n",
        "# This is generic code that serves to train and validate any ML model with Pytorch\n",
        "def train(model, dataloader, optimizer, criterion):\n",
        "    train_loss = 0.\n",
        "    model.train()\n",
        "    start = time.time()\n",
        "\n",
        "    for source, target in dataloader:\n",
        "        source, target = source.to(device), target.to(device)\n",
        "\n",
        "        optimizer.zero_grad()\n",
        "        output = model(source)\n",
        "        loss = criterion(output, target)\n",
        "        loss.backward()\n",
        "        optimizer.step()\n",
        "        train_loss += loss.item()\n",
        "\n",
        "    end = time.time()\n",
        "    train_loss /= len(dataloader)\n",
        "    train_time = end - start\n",
        "    return train_loss, train_time\n",
        "\n",
        "def validate(model, dataloader, criterion):\n",
        "    val_loss = 0.\n",
        "    model.eval()\n",
        "    start = time.time()\n",
        "\n",
        "    for source, target in dataloader:\n",
        "        source, target = source.to(device), target.to(device)\n",
        "\n",
        "        output = model(source)\n",
        "        loss = criterion(output, target)\n",
        "        val_loss += loss.item()\n",
        "\n",
        "    end = time.time()\n",
        "    val_loss /= len(dataloader)\n",
        "    val_time = end - start\n",
        "    return val_loss, val_time"
      ],
      "metadata": {
        "id": "fjo8XIWYiW0q"
      },
      "execution_count": 22,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Run it / Train the Model and plot learning dynamics\n"
      ],
      "metadata": {
        "id": "_UgRLEbzgnKX"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Define the model as the PDE_Solver class and feed in the coarsed grid size\n",
        "# Optimize with Adam and our loss is the L_2 loss\n",
        "model = PDE_Solver(n_x_new).to(device)\n",
        "optimizer = optim.Adam(model.parameters(), weight_decay = 0)\n",
        "criterion = torch.nn.MSELoss()\n",
        "\n",
        "# Collect the results of the training and validation\n",
        "results = {\n",
        "    \"train_losses\": [],\n",
        "    \"train_times\":  [],\n",
        "    \"valid_losses\": [],\n",
        "    \"valid_times\":  [],\n",
        "    \"test_loss\":    0.,\n",
        "    \"test_time\":    0.\n",
        "}\n",
        "\n",
        "if __name__ == \"__main__\":\n",
        "    torch.cuda.empty_cache()\n",
        "    n_epochs = 1000\n",
        "\n",
        "    for epoch in range(n_epochs):\n",
        "        train_loss, train_time = train(model, Heat_DataLoader_train, optimizer, criterion)\n",
        "        valid_loss, valid_time = validate(model, Heat_DataLoader_val, criterion)\n",
        "\n",
        "        print(f\"Epoch: {epoch}\")\n",
        "        print(f\"Train Loss: {train_loss} | Train Time: {train_time:.3f}\")\n",
        "        print(f\"Valid Loss: {valid_loss} | Valid Time: {valid_time:.3f}\")\n",
        "\n",
        "        results[\"train_losses\"].append(train_loss)\n",
        "        results[\"train_times\"].append(train_time)\n",
        "        results[\"valid_losses\"].append(valid_loss)\n",
        "        results[\"valid_times\"].append(valid_time)\n",
        "\n",
        "    test_loss, test_time = validate(model, Heat_DataLoader_test, criterion)\n",
        "    print(f\"== Test Loss: {test_loss} | Test Time: {test_time:.3f} ==\")\n",
        "    results[\"test_loss\"] = test_loss\n",
        "    results[\"test_time\"] = test_time"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "rxH7uUKOYYmP",
        "outputId": "a571408e-3b60-4c8f-95e0-377130f391bc"
      },
      "execution_count": 23,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch: 0\n",
            "Train Loss: 0.0014681975590065122 | Train Time: 0.121\n",
            "Valid Loss: 0.0013314955867826939 | Valid Time: 0.005\n",
            "Epoch: 1\n",
            "Train Loss: 0.001466098427772522 | Train Time: 0.041\n",
            "Valid Loss: 0.0013648492749780416 | Valid Time: 0.004\n",
            "Epoch: 2\n",
            "Train Loss: 0.0014384965412318706 | Train Time: 0.046\n",
            "Valid Loss: 0.001337785564828664 | Valid Time: 0.005\n",
            "Epoch: 3\n",
            "Train Loss: 0.0014257390750572086 | Train Time: 0.041\n",
            "Valid Loss: 0.0012997403973713517 | Valid Time: 0.004\n",
            "Epoch: 4\n",
            "Train Loss: 0.0014044129638932645 | Train Time: 0.040\n",
            "Valid Loss: 0.0013104808749631047 | Valid Time: 0.004\n",
            "Epoch: 5\n",
            "Train Loss: 0.001374528557062149 | Train Time: 0.045\n",
            "Valid Loss: 0.0012611884740181267 | Valid Time: 0.008\n",
            "Epoch: 6\n",
            "Train Loss: 0.0013747020740993321 | Train Time: 0.044\n",
            "Valid Loss: 0.0012383091379888356 | Valid Time: 0.005\n",
            "Epoch: 7\n",
            "Train Loss: 0.0013448342331685125 | Train Time: 0.041\n",
            "Valid Loss: 0.0012375605292618275 | Valid Time: 0.004\n",
            "Epoch: 8\n",
            "Train Loss: 0.0013320277561433614 | Train Time: 0.040\n",
            "Valid Loss: 0.0012064471957273781 | Valid Time: 0.004\n",
            "Epoch: 9\n",
            "Train Loss: 0.0012770209345035256 | Train Time: 0.044\n",
            "Valid Loss: 0.001210321206599474 | Valid Time: 0.004\n",
            "Epoch: 10\n",
            "Train Loss: 0.0012740971054881812 | Train Time: 0.046\n",
            "Valid Loss: 0.001147006289102137 | Valid Time: 0.004\n",
            "Epoch: 11\n",
            "Train Loss: 0.0012474238872528076 | Train Time: 0.041\n",
            "Valid Loss: 0.001164353161584586 | Valid Time: 0.004\n",
            "Epoch: 12\n",
            "Train Loss: 0.0012472301488742233 | Train Time: 0.042\n",
            "Valid Loss: 0.0011464605922810733 | Valid Time: 0.006\n",
            "Epoch: 13\n",
            "Train Loss: 0.001217851834371686 | Train Time: 0.042\n",
            "Valid Loss: 0.0010864291689358652 | Valid Time: 0.004\n",
            "Epoch: 14\n",
            "Train Loss: 0.001210860547143966 | Train Time: 0.042\n",
            "Valid Loss: 0.0010781984310597181 | Valid Time: 0.004\n",
            "Epoch: 15\n",
            "Train Loss: 0.0011721039074473083 | Train Time: 0.055\n",
            "Valid Loss: 0.0010616881190799177 | Valid Time: 0.006\n",
            "Epoch: 16\n",
            "Train Loss: 0.0011694254353642464 | Train Time: 0.041\n",
            "Valid Loss: 0.0010466723470017314 | Valid Time: 0.004\n",
            "Epoch: 17\n",
            "Train Loss: 0.0011481581372208894 | Train Time: 0.041\n",
            "Valid Loss: 0.001089402416255325 | Valid Time: 0.004\n",
            "Epoch: 18\n",
            "Train Loss: 0.0011166633281391113 | Train Time: 0.043\n",
            "Valid Loss: 0.00102705362951383 | Valid Time: 0.004\n",
            "Epoch: 19\n",
            "Train Loss: 0.0011146289063617588 | Train Time: 0.047\n",
            "Valid Loss: 0.000991454959148541 | Valid Time: 0.004\n",
            "Epoch: 20\n",
            "Train Loss: 0.0011009582900442182 | Train Time: 0.043\n",
            "Valid Loss: 0.0009795290825422853 | Valid Time: 0.004\n",
            "Epoch: 21\n",
            "Train Loss: 0.0010691844334360212 | Train Time: 0.040\n",
            "Valid Loss: 0.0010008284007199109 | Valid Time: 0.004\n",
            "Epoch: 22\n",
            "Train Loss: 0.001059779548086226 | Train Time: 0.044\n",
            "Valid Loss: 0.0009736349456943572 | Valid Time: 0.008\n",
            "Epoch: 23\n",
            "Train Loss: 0.0010410346614662558 | Train Time: 0.039\n",
            "Valid Loss: 0.0009432310180272907 | Valid Time: 0.004\n",
            "Epoch: 24\n",
            "Train Loss: 0.0010370517615228892 | Train Time: 0.042\n",
            "Valid Loss: 0.0009091440588235855 | Valid Time: 0.004\n",
            "Epoch: 25\n",
            "Train Loss: 0.0009936946211382748 | Train Time: 0.045\n",
            "Valid Loss: 0.0009221675572916865 | Valid Time: 0.004\n",
            "Epoch: 26\n",
            "Train Loss: 0.000991471210727468 | Train Time: 0.045\n",
            "Valid Loss: 0.0008892134937923402 | Valid Time: 0.004\n",
            "Epoch: 27\n",
            "Train Loss: 0.0009820170467719435 | Train Time: 0.047\n",
            "Valid Loss: 0.0009076243150047958 | Valid Time: 0.004\n",
            "Epoch: 28\n",
            "Train Loss: 0.000961945200106129 | Train Time: 0.041\n",
            "Valid Loss: 0.0008644809131510556 | Valid Time: 0.004\n",
            "Epoch: 29\n",
            "Train Loss: 0.0009565520682372153 | Train Time: 0.043\n",
            "Valid Loss: 0.0008632739190943539 | Valid Time: 0.004\n",
            "Epoch: 30\n",
            "Train Loss: 0.0009304123697802425 | Train Time: 0.044\n",
            "Valid Loss: 0.0008349223935510963 | Valid Time: 0.004\n",
            "Epoch: 31\n",
            "Train Loss: 0.0009192311379592865 | Train Time: 0.041\n",
            "Valid Loss: 0.0008342041401192546 | Valid Time: 0.004\n",
            "Epoch: 32\n",
            "Train Loss: 0.0009139519708696753 | Train Time: 0.041\n",
            "Valid Loss: 0.0008125543536152691 | Valid Time: 0.006\n",
            "Epoch: 33\n",
            "Train Loss: 0.0009013091737870127 | Train Time: 0.042\n",
            "Valid Loss: 0.0007995031483005732 | Valid Time: 0.004\n",
            "Epoch: 34\n",
            "Train Loss: 0.0008868931385222822 | Train Time: 0.045\n",
            "Valid Loss: 0.0007939746719785035 | Valid Time: 0.004\n",
            "Epoch: 35\n",
            "Train Loss: 0.0008738922595512121 | Train Time: 0.046\n",
            "Valid Loss: 0.0007802965119481087 | Valid Time: 0.004\n",
            "Epoch: 36\n",
            "Train Loss: 0.00084409064729698 | Train Time: 0.051\n",
            "Valid Loss: 0.0007693290535826236 | Valid Time: 0.004\n",
            "Epoch: 37\n",
            "Train Loss: 0.0008211236097849905 | Train Time: 0.045\n",
            "Valid Loss: 0.0007665574958082289 | Valid Time: 0.006\n",
            "Epoch: 38\n",
            "Train Loss: 0.0008193198242224753 | Train Time: 0.041\n",
            "Valid Loss: 0.0007671524654142559 | Valid Time: 0.006\n",
            "Epoch: 39\n",
            "Train Loss: 0.0008107626752462238 | Train Time: 0.067\n",
            "Valid Loss: 0.0007348000071942806 | Valid Time: 0.007\n",
            "Epoch: 40\n",
            "Train Loss: 0.0007942503259982913 | Train Time: 0.058\n",
            "Valid Loss: 0.0007067148399073631 | Valid Time: 0.005\n",
            "Epoch: 41\n",
            "Train Loss: 0.0007811475661583245 | Train Time: 0.058\n",
            "Valid Loss: 0.0006763201381545514 | Valid Time: 0.007\n",
            "Epoch: 42\n",
            "Train Loss: 0.0007615675160195679 | Train Time: 0.058\n",
            "Valid Loss: 0.0007043813529890031 | Valid Time: 0.005\n",
            "Epoch: 43\n",
            "Train Loss: 0.0007542558247223497 | Train Time: 0.059\n",
            "Valid Loss: 0.0006754216155968606 | Valid Time: 0.007\n",
            "Epoch: 44\n",
            "Train Loss: 0.0007433297811076045 | Train Time: 0.056\n",
            "Valid Loss: 0.0006644267123192549 | Valid Time: 0.005\n",
            "Epoch: 45\n",
            "Train Loss: 0.0007362630101852119 | Train Time: 0.054\n",
            "Valid Loss: 0.0006383829168044031 | Valid Time: 0.005\n",
            "Epoch: 46\n",
            "Train Loss: 0.0007167136122006923 | Train Time: 0.056\n",
            "Valid Loss: 0.0006617609469685704 | Valid Time: 0.005\n",
            "Epoch: 47\n",
            "Train Loss: 0.0007141182839404791 | Train Time: 0.064\n",
            "Valid Loss: 0.0006509342056233436 | Valid Time: 0.005\n",
            "Epoch: 48\n",
            "Train Loss: 0.0006993344461079687 | Train Time: 0.053\n",
            "Valid Loss: 0.0006187181279528886 | Valid Time: 0.005\n",
            "Epoch: 49\n",
            "Train Loss: 0.0006884707603603601 | Train Time: 0.054\n",
            "Valid Loss: 0.0006292212347034365 | Valid Time: 0.006\n",
            "Epoch: 50\n",
            "Train Loss: 0.0006709213950671256 | Train Time: 0.055\n",
            "Valid Loss: 0.0006061104068066925 | Valid Time: 0.005\n",
            "Epoch: 51\n",
            "Train Loss: 0.0006693272152915597 | Train Time: 0.062\n",
            "Valid Loss: 0.000585229485295713 | Valid Time: 0.005\n",
            "Epoch: 52\n",
            "Train Loss: 0.0006508554972242564 | Train Time: 0.060\n",
            "Valid Loss: 0.000588612660067156 | Valid Time: 0.005\n",
            "Epoch: 53\n",
            "Train Loss: 0.0006428587483242154 | Train Time: 0.067\n",
            "Valid Loss: 0.0005547096079681069 | Valid Time: 0.005\n",
            "Epoch: 54\n",
            "Train Loss: 0.0006331406300887465 | Train Time: 0.066\n",
            "Valid Loss: 0.0005801156221423298 | Valid Time: 0.005\n",
            "Epoch: 55\n",
            "Train Loss: 0.000630200217710808 | Train Time: 0.062\n",
            "Valid Loss: 0.000577360886381939 | Valid Time: 0.005\n",
            "Epoch: 56\n",
            "Train Loss: 0.0006117079057730735 | Train Time: 0.056\n",
            "Valid Loss: 0.000558706815354526 | Valid Time: 0.005\n",
            "Epoch: 57\n",
            "Train Loss: 0.0005963805015198886 | Train Time: 0.056\n",
            "Valid Loss: 0.000533329788595438 | Valid Time: 0.005\n",
            "Epoch: 58\n",
            "Train Loss: 0.0006022870074957609 | Train Time: 0.059\n",
            "Valid Loss: 0.0005072532076155767 | Valid Time: 0.005\n",
            "Epoch: 59\n",
            "Train Loss: 0.0005889107414986938 | Train Time: 0.055\n",
            "Valid Loss: 0.0005323717196006328 | Valid Time: 0.006\n",
            "Epoch: 60\n",
            "Train Loss: 0.0005743983667343855 | Train Time: 0.056\n",
            "Valid Loss: 0.0005152270896360278 | Valid Time: 0.005\n",
            "Epoch: 61\n",
            "Train Loss: 0.0005615778849460184 | Train Time: 0.067\n",
            "Valid Loss: 0.0005194560071686283 | Valid Time: 0.005\n",
            "Epoch: 62\n",
            "Train Loss: 0.0005605068377917633 | Train Time: 0.059\n",
            "Valid Loss: 0.0005084067379357293 | Valid Time: 0.008\n",
            "Epoch: 63\n",
            "Train Loss: 0.0005470970936585218 | Train Time: 0.060\n",
            "Valid Loss: 0.000481845490867272 | Valid Time: 0.005\n",
            "Epoch: 64\n",
            "Train Loss: 0.0005483070912305265 | Train Time: 0.053\n",
            "Valid Loss: 0.0004960999358445406 | Valid Time: 0.005\n",
            "Epoch: 65\n",
            "Train Loss: 0.0005311870336299762 | Train Time: 0.054\n",
            "Valid Loss: 0.0004654249787563458 | Valid Time: 0.006\n",
            "Epoch: 66\n",
            "Train Loss: 0.0005178374645765871 | Train Time: 0.062\n",
            "Valid Loss: 0.00045619944285135716 | Valid Time: 0.005\n",
            "Epoch: 67\n",
            "Train Loss: 0.000519698709831573 | Train Time: 0.057\n",
            "Valid Loss: 0.00046322237176354975 | Valid Time: 0.005\n",
            "Epoch: 68\n",
            "Train Loss: 0.0005040542542701587 | Train Time: 0.062\n",
            "Valid Loss: 0.00042882018897216767 | Valid Time: 0.007\n",
            "Epoch: 69\n",
            "Train Loss: 0.0004989347886294127 | Train Time: 0.058\n",
            "Valid Loss: 0.00044340419117361307 | Valid Time: 0.005\n",
            "Epoch: 70\n",
            "Train Loss: 0.0004926813446218148 | Train Time: 0.063\n",
            "Valid Loss: 0.000449300860054791 | Valid Time: 0.005\n",
            "Epoch: 71\n",
            "Train Loss: 0.0004857572144828737 | Train Time: 0.058\n",
            "Valid Loss: 0.0004241252754582092 | Valid Time: 0.005\n",
            "Epoch: 72\n",
            "Train Loss: 0.0004754890309413895 | Train Time: 0.068\n",
            "Valid Loss: 0.00042582991591189057 | Valid Time: 0.007\n",
            "Epoch: 73\n",
            "Train Loss: 0.00046837747213430704 | Train Time: 0.061\n",
            "Valid Loss: 0.00040285568684339523 | Valid Time: 0.006\n",
            "Epoch: 74\n",
            "Train Loss: 0.0004570904595311731 | Train Time: 0.063\n",
            "Valid Loss: 0.00039974297396838665 | Valid Time: 0.004\n",
            "Epoch: 75\n",
            "Train Loss: 0.00045243976928759365 | Train Time: 0.042\n",
            "Valid Loss: 0.0004027276299893856 | Valid Time: 0.004\n",
            "Epoch: 76\n",
            "Train Loss: 0.000448993276222609 | Train Time: 0.045\n",
            "Valid Loss: 0.0003885592595906928 | Valid Time: 0.005\n",
            "Epoch: 77\n",
            "Train Loss: 0.0004468560277018696 | Train Time: 0.044\n",
            "Valid Loss: 0.00038400504854507744 | Valid Time: 0.004\n",
            "Epoch: 78\n",
            "Train Loss: 0.0004294278129236773 | Train Time: 0.041\n",
            "Valid Loss: 0.0003856069379253313 | Valid Time: 0.004\n",
            "Epoch: 79\n",
            "Train Loss: 0.00042848840821534394 | Train Time: 0.043\n",
            "Valid Loss: 0.00037534383591264486 | Valid Time: 0.004\n",
            "Epoch: 80\n",
            "Train Loss: 0.00041872492292895915 | Train Time: 0.041\n",
            "Valid Loss: 0.0003661443915916607 | Valid Time: 0.004\n",
            "Epoch: 81\n",
            "Train Loss: 0.00041466800321359186 | Train Time: 0.048\n",
            "Valid Loss: 0.00036316955811344087 | Valid Time: 0.004\n",
            "Epoch: 82\n",
            "Train Loss: 0.000407792255282402 | Train Time: 0.041\n",
            "Valid Loss: 0.00037599168717861176 | Valid Time: 0.004\n",
            "Epoch: 83\n",
            "Train Loss: 0.00039682059723418207 | Train Time: 0.044\n",
            "Valid Loss: 0.0003399618581170216 | Valid Time: 0.004\n",
            "Epoch: 84\n",
            "Train Loss: 0.00039155663980636744 | Train Time: 0.050\n",
            "Valid Loss: 0.00033343285031151026 | Valid Time: 0.004\n",
            "Epoch: 85\n",
            "Train Loss: 0.000382340548094362 | Train Time: 0.057\n",
            "Valid Loss: 0.0003442642482696101 | Valid Time: 0.004\n",
            "Epoch: 86\n",
            "Train Loss: 0.00038396992604248224 | Train Time: 0.053\n",
            "Valid Loss: 0.00032411330903414637 | Valid Time: 0.004\n",
            "Epoch: 87\n",
            "Train Loss: 0.00037364409654401244 | Train Time: 0.040\n",
            "Valid Loss: 0.00032318018202204257 | Valid Time: 0.004\n",
            "Epoch: 88\n",
            "Train Loss: 0.00037138578190933915 | Train Time: 0.043\n",
            "Valid Loss: 0.0003414646052988246 | Valid Time: 0.004\n",
            "Epoch: 89\n",
            "Train Loss: 0.000359493721043691 | Train Time: 0.048\n",
            "Valid Loss: 0.00032242972520180047 | Valid Time: 0.006\n",
            "Epoch: 90\n",
            "Train Loss: 0.0003608625673223287 | Train Time: 0.047\n",
            "Valid Loss: 0.0003177323524141684 | Valid Time: 0.006\n",
            "Epoch: 91\n",
            "Train Loss: 0.00035067918070126326 | Train Time: 0.041\n",
            "Valid Loss: 0.0003010789369000122 | Valid Time: 0.004\n",
            "Epoch: 92\n",
            "Train Loss: 0.0003427612187806517 | Train Time: 0.041\n",
            "Valid Loss: 0.0002985579631058499 | Valid Time: 0.004\n",
            "Epoch: 93\n",
            "Train Loss: 0.00033949994249269364 | Train Time: 0.040\n",
            "Valid Loss: 0.0003013668319908902 | Valid Time: 0.004\n",
            "Epoch: 94\n",
            "Train Loss: 0.00033802219259086995 | Train Time: 0.046\n",
            "Valid Loss: 0.000292587632429786 | Valid Time: 0.004\n",
            "Epoch: 95\n",
            "Train Loss: 0.0003286397608462721 | Train Time: 0.047\n",
            "Valid Loss: 0.00028174179897177964 | Valid Time: 0.004\n",
            "Epoch: 96\n",
            "Train Loss: 0.0003192719945218414 | Train Time: 0.040\n",
            "Valid Loss: 0.0002828908618539572 | Valid Time: 0.004\n",
            "Epoch: 97\n",
            "Train Loss: 0.00031975658203009516 | Train Time: 0.041\n",
            "Valid Loss: 0.00027548547950573266 | Valid Time: 0.004\n",
            "Epoch: 98\n",
            "Train Loss: 0.00031607000564690677 | Train Time: 0.042\n",
            "Valid Loss: 0.0002790753642329946 | Valid Time: 0.004\n",
            "Epoch: 99\n",
            "Train Loss: 0.00031119708437472583 | Train Time: 0.050\n",
            "Valid Loss: 0.00027836652589030564 | Valid Time: 0.004\n",
            "Epoch: 100\n",
            "Train Loss: 0.0003035456029465422 | Train Time: 0.040\n",
            "Valid Loss: 0.00025907652161549777 | Valid Time: 0.004\n",
            "Epoch: 101\n",
            "Train Loss: 0.00029946660506539045 | Train Time: 0.042\n",
            "Valid Loss: 0.0002590165677247569 | Valid Time: 0.004\n",
            "Epoch: 102\n",
            "Train Loss: 0.00029364097281359136 | Train Time: 0.043\n",
            "Valid Loss: 0.0002535867752158083 | Valid Time: 0.004\n",
            "Epoch: 103\n",
            "Train Loss: 0.0002877345599699765 | Train Time: 0.042\n",
            "Valid Loss: 0.0002489535108907148 | Valid Time: 0.004\n",
            "Epoch: 104\n",
            "Train Loss: 0.00028527252143248914 | Train Time: 0.043\n",
            "Valid Loss: 0.00024372806365136057 | Valid Time: 0.004\n",
            "Epoch: 105\n",
            "Train Loss: 0.00027955929981544615 | Train Time: 0.041\n",
            "Valid Loss: 0.0002467981757945381 | Valid Time: 0.004\n",
            "Epoch: 106\n",
            "Train Loss: 0.00027605573122855274 | Train Time: 0.043\n",
            "Valid Loss: 0.0002412169342278503 | Valid Time: 0.004\n",
            "Epoch: 107\n",
            "Train Loss: 0.00027370039751986044 | Train Time: 0.050\n",
            "Valid Loss: 0.00023772894201101735 | Valid Time: 0.004\n",
            "Epoch: 108\n",
            "Train Loss: 0.0002726433056523092 | Train Time: 0.042\n",
            "Valid Loss: 0.00022767761402064934 | Valid Time: 0.006\n",
            "Epoch: 109\n",
            "Train Loss: 0.00026527893787715585 | Train Time: 0.049\n",
            "Valid Loss: 0.00022178787912707776 | Valid Time: 0.004\n",
            "Epoch: 110\n",
            "Train Loss: 0.00025910788972396406 | Train Time: 0.041\n",
            "Valid Loss: 0.0002188536018365994 | Valid Time: 0.005\n",
            "Epoch: 111\n",
            "Train Loss: 0.00025469672109466044 | Train Time: 0.042\n",
            "Valid Loss: 0.00022202184482011944 | Valid Time: 0.004\n",
            "Epoch: 112\n",
            "Train Loss: 0.00025292517384514215 | Train Time: 0.046\n",
            "Valid Loss: 0.00021341845422284678 | Valid Time: 0.004\n",
            "Epoch: 113\n",
            "Train Loss: 0.0002443684745230712 | Train Time: 0.041\n",
            "Valid Loss: 0.00020858419156866148 | Valid Time: 0.004\n",
            "Epoch: 114\n",
            "Train Loss: 0.00024090675724437461 | Train Time: 0.045\n",
            "Valid Loss: 0.00021277267660479993 | Valid Time: 0.004\n",
            "Epoch: 115\n",
            "Train Loss: 0.0002429707412375137 | Train Time: 0.050\n",
            "Valid Loss: 0.0002141943186870776 | Valid Time: 0.004\n",
            "Epoch: 116\n",
            "Train Loss: 0.0002330563496798277 | Train Time: 0.039\n",
            "Valid Loss: 0.00020542534912237898 | Valid Time: 0.004\n",
            "Epoch: 117\n",
            "Train Loss: 0.00023007579729892314 | Train Time: 0.039\n",
            "Valid Loss: 0.0001962214955710806 | Valid Time: 0.004\n",
            "Epoch: 118\n",
            "Train Loss: 0.00022697564272675664 | Train Time: 0.041\n",
            "Valid Loss: 0.00019418717420194298 | Valid Time: 0.004\n",
            "Epoch: 119\n",
            "Train Loss: 0.0002246711024781689 | Train Time: 0.050\n",
            "Valid Loss: 0.00019395671552047133 | Valid Time: 0.004\n",
            "Epoch: 120\n",
            "Train Loss: 0.000224509222607594 | Train Time: 0.043\n",
            "Valid Loss: 0.00019141238590236753 | Valid Time: 0.004\n",
            "Epoch: 121\n",
            "Train Loss: 0.00021930856310063972 | Train Time: 0.041\n",
            "Valid Loss: 0.00018324815027881414 | Valid Time: 0.004\n",
            "Epoch: 122\n",
            "Train Loss: 0.00021590420365100727 | Train Time: 0.048\n",
            "Valid Loss: 0.0001799809469957836 | Valid Time: 0.004\n",
            "Epoch: 123\n",
            "Train Loss: 0.00020996205712435766 | Train Time: 0.041\n",
            "Valid Loss: 0.00018003866716753691 | Valid Time: 0.004\n",
            "Epoch: 124\n",
            "Train Loss: 0.0002082999999402091 | Train Time: 0.044\n",
            "Valid Loss: 0.00018147054652217776 | Valid Time: 0.004\n",
            "Epoch: 125\n",
            "Train Loss: 0.0002056115641607903 | Train Time: 0.044\n",
            "Valid Loss: 0.00017606119945412502 | Valid Time: 0.004\n",
            "Epoch: 126\n",
            "Train Loss: 0.00020310295949457213 | Train Time: 0.041\n",
            "Valid Loss: 0.00017789706180337816 | Valid Time: 0.004\n",
            "Epoch: 127\n",
            "Train Loss: 0.00019478433241602034 | Train Time: 0.042\n",
            "Valid Loss: 0.0001724689282127656 | Valid Time: 0.004\n",
            "Epoch: 128\n",
            "Train Loss: 0.00019514812593115493 | Train Time: 0.055\n",
            "Valid Loss: 0.00017101964476751164 | Valid Time: 0.004\n",
            "Epoch: 129\n",
            "Train Loss: 0.00019584826222853735 | Train Time: 0.045\n",
            "Valid Loss: 0.00016322111332556233 | Valid Time: 0.004\n",
            "Epoch: 130\n",
            "Train Loss: 0.0001892218613647856 | Train Time: 0.040\n",
            "Valid Loss: 0.00016126833361340687 | Valid Time: 0.004\n",
            "Epoch: 131\n",
            "Train Loss: 0.00018894028471549973 | Train Time: 0.042\n",
            "Valid Loss: 0.00015179852925939485 | Valid Time: 0.006\n",
            "Epoch: 132\n",
            "Train Loss: 0.00018290691514266655 | Train Time: 0.042\n",
            "Valid Loss: 0.0001581192118464969 | Valid Time: 0.004\n",
            "Epoch: 133\n",
            "Train Loss: 0.00018316033529117704 | Train Time: 0.044\n",
            "Valid Loss: 0.00015116707800189033 | Valid Time: 0.004\n",
            "Epoch: 134\n",
            "Train Loss: 0.00017796852043829858 | Train Time: 0.045\n",
            "Valid Loss: 0.00015228673873934895 | Valid Time: 0.004\n",
            "Epoch: 135\n",
            "Train Loss: 0.0001762868181685917 | Train Time: 0.065\n",
            "Valid Loss: 0.00015047829219838604 | Valid Time: 0.005\n",
            "Epoch: 136\n",
            "Train Loss: 0.0001747427522786893 | Train Time: 0.047\n",
            "Valid Loss: 0.00014624852337874472 | Valid Time: 0.004\n",
            "Epoch: 137\n",
            "Train Loss: 0.0001715354490443133 | Train Time: 0.044\n",
            "Valid Loss: 0.00015061512385727838 | Valid Time: 0.004\n",
            "Epoch: 138\n",
            "Train Loss: 0.00016757106059230864 | Train Time: 0.049\n",
            "Valid Loss: 0.0001466089452151209 | Valid Time: 0.004\n",
            "Epoch: 139\n",
            "Train Loss: 0.0001615858949662652 | Train Time: 0.040\n",
            "Valid Loss: 0.00014058167289476842 | Valid Time: 0.004\n",
            "Epoch: 140\n",
            "Train Loss: 0.0001589010513271205 | Train Time: 0.041\n",
            "Valid Loss: 0.00014226872008293867 | Valid Time: 0.004\n",
            "Epoch: 141\n",
            "Train Loss: 0.00015715603512944654 | Train Time: 0.046\n",
            "Valid Loss: 0.0001374894054606557 | Valid Time: 0.004\n",
            "Epoch: 142\n",
            "Train Loss: 0.00015809717733645813 | Train Time: 0.041\n",
            "Valid Loss: 0.000135516602313146 | Valid Time: 0.004\n",
            "Epoch: 143\n",
            "Train Loss: 0.00015285569679690525 | Train Time: 0.046\n",
            "Valid Loss: 0.00013013973511988297 | Valid Time: 0.004\n",
            "Epoch: 144\n",
            "Train Loss: 0.00015017966288723982 | Train Time: 0.045\n",
            "Valid Loss: 0.00013015520380577073 | Valid Time: 0.004\n",
            "Epoch: 145\n",
            "Train Loss: 0.00015180422851699405 | Train Time: 0.042\n",
            "Valid Loss: 0.0001308787141169887 | Valid Time: 0.004\n",
            "Epoch: 146\n",
            "Train Loss: 0.00014596110850106925 | Train Time: 0.044\n",
            "Valid Loss: 0.00012562741176225245 | Valid Time: 0.004\n",
            "Epoch: 147\n",
            "Train Loss: 0.00014309377584140748 | Train Time: 0.041\n",
            "Valid Loss: 0.0001229709741892293 | Valid Time: 0.004\n",
            "Epoch: 148\n",
            "Train Loss: 0.0001434529069229029 | Train Time: 0.045\n",
            "Valid Loss: 0.0001206885717692785 | Valid Time: 0.004\n",
            "Epoch: 149\n",
            "Train Loss: 0.0001423599343979731 | Train Time: 0.048\n",
            "Valid Loss: 0.00011654746776912361 | Valid Time: 0.004\n",
            "Epoch: 150\n",
            "Train Loss: 0.0001371500111417845 | Train Time: 0.040\n",
            "Valid Loss: 0.00011894014460267499 | Valid Time: 0.004\n",
            "Epoch: 151\n",
            "Train Loss: 0.00013388772495090962 | Train Time: 0.041\n",
            "Valid Loss: 0.0001148833725892473 | Valid Time: 0.004\n",
            "Epoch: 152\n",
            "Train Loss: 0.0001366265249089338 | Train Time: 0.046\n",
            "Valid Loss: 0.00011412662934162654 | Valid Time: 0.004\n",
            "Epoch: 153\n",
            "Train Loss: 0.0001326676254393533 | Train Time: 0.044\n",
            "Valid Loss: 0.00011006991917383857 | Valid Time: 0.004\n",
            "Epoch: 154\n",
            "Train Loss: 0.0001295500602282118 | Train Time: 0.042\n",
            "Valid Loss: 0.00011281434126431122 | Valid Time: 0.004\n",
            "Epoch: 155\n",
            "Train Loss: 0.00012942273606313391 | Train Time: 0.046\n",
            "Valid Loss: 0.00010978015052387491 | Valid Time: 0.004\n",
            "Epoch: 156\n",
            "Train Loss: 0.0001272940782655496 | Train Time: 0.044\n",
            "Valid Loss: 0.00010554755499470048 | Valid Time: 0.004\n",
            "Epoch: 157\n",
            "Train Loss: 0.0001233083698025439 | Train Time: 0.044\n",
            "Valid Loss: 0.00010826491416082717 | Valid Time: 0.004\n",
            "Epoch: 158\n",
            "Train Loss: 0.0001219550620589871 | Train Time: 0.045\n",
            "Valid Loss: 0.00010735319665400311 | Valid Time: 0.004\n",
            "Epoch: 159\n",
            "Train Loss: 0.00012117579608457163 | Train Time: 0.047\n",
            "Valid Loss: 0.00010260510316584259 | Valid Time: 0.004\n",
            "Epoch: 160\n",
            "Train Loss: 0.00011940961921936832 | Train Time: 0.041\n",
            "Valid Loss: 9.8319687822368e-05 | Valid Time: 0.004\n",
            "Epoch: 161\n",
            "Train Loss: 0.00011541541971382685 | Train Time: 0.041\n",
            "Valid Loss: 9.673416207078844e-05 | Valid Time: 0.004\n",
            "Epoch: 162\n",
            "Train Loss: 0.00011405931509216316 | Train Time: 0.046\n",
            "Valid Loss: 9.495634003542364e-05 | Valid Time: 0.004\n",
            "Epoch: 163\n",
            "Train Loss: 0.00011344478189130313 | Train Time: 0.044\n",
            "Valid Loss: 9.582333950675093e-05 | Valid Time: 0.004\n",
            "Epoch: 164\n",
            "Train Loss: 0.00011099774710601195 | Train Time: 0.042\n",
            "Valid Loss: 9.310267705586739e-05 | Valid Time: 0.004\n",
            "Epoch: 165\n",
            "Train Loss: 0.00011061955447075889 | Train Time: 0.046\n",
            "Valid Loss: 9.404274169355631e-05 | Valid Time: 0.004\n",
            "Epoch: 166\n",
            "Train Loss: 0.00010876940286834725 | Train Time: 0.041\n",
            "Valid Loss: 9.248896094504744e-05 | Valid Time: 0.004\n",
            "Epoch: 167\n",
            "Train Loss: 0.00010728080524131655 | Train Time: 0.041\n",
            "Valid Loss: 8.923645145841874e-05 | Valid Time: 0.004\n",
            "Epoch: 168\n",
            "Train Loss: 0.00010534211032791063 | Train Time: 0.044\n",
            "Valid Loss: 8.89614166226238e-05 | Valid Time: 0.004\n",
            "Epoch: 169\n",
            "Train Loss: 0.00010345523769501596 | Train Time: 0.042\n",
            "Valid Loss: 8.703456842340529e-05 | Valid Time: 0.004\n",
            "Epoch: 170\n",
            "Train Loss: 0.00010174076160183177 | Train Time: 0.055\n",
            "Valid Loss: 8.318798791151494e-05 | Valid Time: 0.005\n",
            "Epoch: 171\n",
            "Train Loss: 0.00010119369544554502 | Train Time: 0.039\n",
            "Valid Loss: 8.21687099232804e-05 | Valid Time: 0.004\n",
            "Epoch: 172\n",
            "Train Loss: 9.78340998699423e-05 | Train Time: 0.042\n",
            "Valid Loss: 8.247709774877876e-05 | Valid Time: 0.004\n",
            "Epoch: 173\n",
            "Train Loss: 9.733215047162958e-05 | Train Time: 0.053\n",
            "Valid Loss: 8.871694808476605e-05 | Valid Time: 0.005\n",
            "Epoch: 174\n",
            "Train Loss: 9.694299224065617e-05 | Train Time: 0.045\n",
            "Valid Loss: 8.036840517888777e-05 | Valid Time: 0.004\n",
            "Epoch: 175\n",
            "Train Loss: 9.467288982705213e-05 | Train Time: 0.047\n",
            "Valid Loss: 7.892752182669938e-05 | Valid Time: 0.004\n",
            "Epoch: 176\n",
            "Train Loss: 9.460346846026368e-05 | Train Time: 0.043\n",
            "Valid Loss: 7.922760414658114e-05 | Valid Time: 0.004\n",
            "Epoch: 177\n",
            "Train Loss: 9.20163671253249e-05 | Train Time: 0.044\n",
            "Valid Loss: 7.68720346968621e-05 | Valid Time: 0.004\n",
            "Epoch: 178\n",
            "Train Loss: 9.055833943421021e-05 | Train Time: 0.043\n",
            "Valid Loss: 7.741983426967636e-05 | Valid Time: 0.004\n",
            "Epoch: 179\n",
            "Train Loss: 8.910593096516095e-05 | Train Time: 0.041\n",
            "Valid Loss: 7.363141776295379e-05 | Valid Time: 0.004\n",
            "Epoch: 180\n",
            "Train Loss: 8.776283211773262e-05 | Train Time: 0.047\n",
            "Valid Loss: 7.683200601604767e-05 | Valid Time: 0.004\n",
            "Epoch: 181\n",
            "Train Loss: 8.674275522935204e-05 | Train Time: 0.043\n",
            "Valid Loss: 7.343702964135446e-05 | Valid Time: 0.004\n",
            "Epoch: 182\n",
            "Train Loss: 8.546372846467421e-05 | Train Time: 0.042\n",
            "Valid Loss: 6.935098645044491e-05 | Valid Time: 0.004\n",
            "Epoch: 183\n",
            "Train Loss: 8.35879414808005e-05 | Train Time: 0.044\n",
            "Valid Loss: 7.001481571933255e-05 | Valid Time: 0.004\n",
            "Epoch: 184\n",
            "Train Loss: 8.399250727961772e-05 | Train Time: 0.042\n",
            "Valid Loss: 6.843410665169358e-05 | Valid Time: 0.004\n",
            "Epoch: 185\n",
            "Train Loss: 8.112784926197491e-05 | Train Time: 0.047\n",
            "Valid Loss: 6.933838449185714e-05 | Valid Time: 0.004\n",
            "Epoch: 186\n",
            "Train Loss: 8.049127500271424e-05 | Train Time: 0.041\n",
            "Valid Loss: 6.781781848985702e-05 | Valid Time: 0.004\n",
            "Epoch: 187\n",
            "Train Loss: 7.751276971248444e-05 | Train Time: 0.040\n",
            "Valid Loss: 6.726227729814127e-05 | Valid Time: 0.004\n",
            "Epoch: 188\n",
            "Train Loss: 7.775822305120528e-05 | Train Time: 0.050\n",
            "Valid Loss: 6.541273614857346e-05 | Valid Time: 0.004\n",
            "Epoch: 189\n",
            "Train Loss: 7.636500959051773e-05 | Train Time: 0.041\n",
            "Valid Loss: 6.587514326383825e-05 | Valid Time: 0.004\n",
            "Epoch: 190\n",
            "Train Loss: 7.449938311765436e-05 | Train Time: 0.041\n",
            "Valid Loss: 6.441656478273217e-05 | Valid Time: 0.004\n",
            "Epoch: 191\n",
            "Train Loss: 7.429130273521878e-05 | Train Time: 0.053\n",
            "Valid Loss: 6.253342144191265e-05 | Valid Time: 0.004\n",
            "Epoch: 192\n",
            "Train Loss: 7.36241643608082e-05 | Train Time: 0.042\n",
            "Valid Loss: 6.359221333696041e-05 | Valid Time: 0.004\n",
            "Epoch: 193\n",
            "Train Loss: 7.209641444205772e-05 | Train Time: 0.049\n",
            "Valid Loss: 6.143071732367389e-05 | Valid Time: 0.004\n",
            "Epoch: 194\n",
            "Train Loss: 7.103500684024766e-05 | Train Time: 0.047\n",
            "Valid Loss: 6.043785651854705e-05 | Valid Time: 0.004\n",
            "Epoch: 195\n",
            "Train Loss: 7.02909139363328e-05 | Train Time: 0.052\n",
            "Valid Loss: 5.988173325022217e-05 | Valid Time: 0.004\n",
            "Epoch: 196\n",
            "Train Loss: 6.957913101359736e-05 | Train Time: 0.044\n",
            "Valid Loss: 6.0241440223762766e-05 | Valid Time: 0.004\n",
            "Epoch: 197\n",
            "Train Loss: 6.806617639085744e-05 | Train Time: 0.044\n",
            "Valid Loss: 5.8965921198250726e-05 | Valid Time: 0.008\n",
            "Epoch: 198\n",
            "Train Loss: 6.72799094900256e-05 | Train Time: 0.047\n",
            "Valid Loss: 5.5214788517332636e-05 | Valid Time: 0.005\n",
            "Epoch: 199\n",
            "Train Loss: 6.740229000570252e-05 | Train Time: 0.044\n",
            "Valid Loss: 5.463043453346472e-05 | Valid Time: 0.004\n",
            "Epoch: 200\n",
            "Train Loss: 6.495685483969283e-05 | Train Time: 0.045\n",
            "Valid Loss: 5.44298454769887e-05 | Valid Time: 0.004\n",
            "Epoch: 201\n",
            "Train Loss: 6.480248775915242e-05 | Train Time: 0.046\n",
            "Valid Loss: 5.54550551896682e-05 | Valid Time: 0.007\n",
            "Epoch: 202\n",
            "Train Loss: 6.341616317513399e-05 | Train Time: 0.045\n",
            "Valid Loss: 5.248296474746894e-05 | Valid Time: 0.004\n",
            "Epoch: 203\n",
            "Train Loss: 6.232712330529466e-05 | Train Time: 0.043\n",
            "Valid Loss: 5.318168223311659e-05 | Valid Time: 0.004\n",
            "Epoch: 204\n",
            "Train Loss: 6.159963850222993e-05 | Train Time: 0.044\n",
            "Valid Loss: 5.151006917003542e-05 | Valid Time: 0.005\n",
            "Epoch: 205\n",
            "Train Loss: 6.132879061624408e-05 | Train Time: 0.043\n",
            "Valid Loss: 4.90991569677135e-05 | Valid Time: 0.004\n",
            "Epoch: 206\n",
            "Train Loss: 6.130228211986832e-05 | Train Time: 0.046\n",
            "Valid Loss: 5.0491156798671e-05 | Valid Time: 0.004\n",
            "Epoch: 207\n",
            "Train Loss: 5.929895633016713e-05 | Train Time: 0.041\n",
            "Valid Loss: 4.838739005208481e-05 | Valid Time: 0.004\n",
            "Epoch: 208\n",
            "Train Loss: 5.824930412927643e-05 | Train Time: 0.048\n",
            "Valid Loss: 4.7127872676355764e-05 | Valid Time: 0.004\n",
            "Epoch: 209\n",
            "Train Loss: 5.7814770116237924e-05 | Train Time: 0.042\n",
            "Valid Loss: 4.777175126946531e-05 | Valid Time: 0.004\n",
            "Epoch: 210\n",
            "Train Loss: 5.634435947285965e-05 | Train Time: 0.042\n",
            "Valid Loss: 4.8095049351104535e-05 | Valid Time: 0.004\n",
            "Epoch: 211\n",
            "Train Loss: 5.567217413045e-05 | Train Time: 0.060\n",
            "Valid Loss: 4.534901927399915e-05 | Valid Time: 0.004\n",
            "Epoch: 212\n",
            "Train Loss: 5.474792269524187e-05 | Train Time: 0.043\n",
            "Valid Loss: 4.703802915173583e-05 | Valid Time: 0.004\n",
            "Epoch: 213\n",
            "Train Loss: 5.5242876260308546e-05 | Train Time: 0.043\n",
            "Valid Loss: 4.337969949119724e-05 | Valid Time: 0.004\n",
            "Epoch: 214\n",
            "Train Loss: 5.420947782113217e-05 | Train Time: 0.043\n",
            "Valid Loss: 4.3485442802193575e-05 | Valid Time: 0.004\n",
            "Epoch: 215\n",
            "Train Loss: 5.2624311865656634e-05 | Train Time: 0.041\n",
            "Valid Loss: 4.314090438128915e-05 | Valid Time: 0.004\n",
            "Epoch: 216\n",
            "Train Loss: 5.178610445000231e-05 | Train Time: 0.043\n",
            "Valid Loss: 4.205059849482495e-05 | Valid Time: 0.004\n",
            "Epoch: 217\n",
            "Train Loss: 5.053134955232963e-05 | Train Time: 0.042\n",
            "Valid Loss: 4.392422488308512e-05 | Valid Time: 0.004\n",
            "Epoch: 218\n",
            "Train Loss: 5.145161194377579e-05 | Train Time: 0.040\n",
            "Valid Loss: 4.0465147321810946e-05 | Valid Time: 0.004\n",
            "Epoch: 219\n",
            "Train Loss: 4.9482374743092804e-05 | Train Time: 0.048\n",
            "Valid Loss: 4.16665970988106e-05 | Valid Time: 0.004\n",
            "Epoch: 220\n",
            "Train Loss: 4.892592223768588e-05 | Train Time: 0.044\n",
            "Valid Loss: 4.016609818791039e-05 | Valid Time: 0.004\n",
            "Epoch: 221\n",
            "Train Loss: 5.0459435442462564e-05 | Train Time: 0.050\n",
            "Valid Loss: 4.0901568354456685e-05 | Valid Time: 0.004\n",
            "Epoch: 222\n",
            "Train Loss: 4.834011197090149e-05 | Train Time: 0.043\n",
            "Valid Loss: 4.032758442917839e-05 | Valid Time: 0.004\n",
            "Epoch: 223\n",
            "Train Loss: 4.6231083615566604e-05 | Train Time: 0.046\n",
            "Valid Loss: 3.8316400605253875e-05 | Valid Time: 0.004\n",
            "Epoch: 224\n",
            "Train Loss: 4.7194325088639746e-05 | Train Time: 0.040\n",
            "Valid Loss: 3.8782349292887375e-05 | Valid Time: 0.004\n",
            "Epoch: 225\n",
            "Train Loss: 4.5131960723665544e-05 | Train Time: 0.040\n",
            "Valid Loss: 4.005464325018693e-05 | Valid Time: 0.004\n",
            "Epoch: 226\n",
            "Train Loss: 4.5089671402820386e-05 | Train Time: 0.044\n",
            "Valid Loss: 3.815140371443704e-05 | Valid Time: 0.004\n",
            "Epoch: 227\n",
            "Train Loss: 4.417614254634827e-05 | Train Time: 0.040\n",
            "Valid Loss: 3.6248387914383784e-05 | Valid Time: 0.004\n",
            "Epoch: 228\n",
            "Train Loss: 4.323317298258189e-05 | Train Time: 0.040\n",
            "Valid Loss: 3.478126109257573e-05 | Valid Time: 0.004\n",
            "Epoch: 229\n",
            "Train Loss: 4.340235464042053e-05 | Train Time: 0.046\n",
            "Valid Loss: 3.755209945666138e-05 | Valid Time: 0.004\n",
            "Epoch: 230\n",
            "Train Loss: 4.2542243681964466e-05 | Train Time: 0.042\n",
            "Valid Loss: 3.645746437541675e-05 | Valid Time: 0.004\n",
            "Epoch: 231\n",
            "Train Loss: 4.214357541059144e-05 | Train Time: 0.046\n",
            "Valid Loss: 3.546274274413008e-05 | Valid Time: 0.004\n",
            "Epoch: 232\n",
            "Train Loss: 4.173436645942275e-05 | Train Time: 0.050\n",
            "Valid Loss: 3.401657704671379e-05 | Valid Time: 0.004\n",
            "Epoch: 233\n",
            "Train Loss: 4.054278088005958e-05 | Train Time: 0.042\n",
            "Valid Loss: 3.300763819424901e-05 | Valid Time: 0.004\n",
            "Epoch: 234\n",
            "Train Loss: 4.0387443004874515e-05 | Train Time: 0.041\n",
            "Valid Loss: 3.264216684328858e-05 | Valid Time: 0.004\n",
            "Epoch: 235\n",
            "Train Loss: 4.019045809400268e-05 | Train Time: 0.039\n",
            "Valid Loss: 3.241511330998037e-05 | Valid Time: 0.004\n",
            "Epoch: 236\n",
            "Train Loss: 3.887202910846099e-05 | Train Time: 0.049\n",
            "Valid Loss: 3.233410097891465e-05 | Valid Time: 0.004\n",
            "Epoch: 237\n",
            "Train Loss: 3.8332904659910126e-05 | Train Time: 0.040\n",
            "Valid Loss: 3.246026699343929e-05 | Valid Time: 0.004\n",
            "Epoch: 238\n",
            "Train Loss: 3.877943418046925e-05 | Train Time: 0.041\n",
            "Valid Loss: 3.1369529096991755e-05 | Valid Time: 0.004\n",
            "Epoch: 239\n",
            "Train Loss: 3.7757785321446136e-05 | Train Time: 0.044\n",
            "Valid Loss: 3.1322068025474437e-05 | Valid Time: 0.004\n",
            "Epoch: 240\n",
            "Train Loss: 3.6994100446463564e-05 | Train Time: 0.040\n",
            "Valid Loss: 2.9541821277234703e-05 | Valid Time: 0.004\n",
            "Epoch: 241\n",
            "Train Loss: 3.6444057514017913e-05 | Train Time: 0.045\n",
            "Valid Loss: 2.9083248591632582e-05 | Valid Time: 0.004\n",
            "Epoch: 242\n",
            "Train Loss: 3.6255232589610384e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.925708940892946e-05 | Valid Time: 0.004\n",
            "Epoch: 243\n",
            "Train Loss: 3.593506899051136e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.8852126888523344e-05 | Valid Time: 0.004\n",
            "Epoch: 244\n",
            "Train Loss: 3.5450273571768776e-05 | Train Time: 0.044\n",
            "Valid Loss: 2.937296812888235e-05 | Valid Time: 0.004\n",
            "Epoch: 245\n",
            "Train Loss: 3.489327009447152e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.7406111257732846e-05 | Valid Time: 0.004\n",
            "Epoch: 246\n",
            "Train Loss: 3.404384569876129e-05 | Train Time: 0.045\n",
            "Valid Loss: 2.8308547371125314e-05 | Valid Time: 0.004\n",
            "Epoch: 247\n",
            "Train Loss: 3.364228814461967e-05 | Train Time: 0.040\n",
            "Valid Loss: 2.7231647436565254e-05 | Valid Time: 0.004\n",
            "Epoch: 248\n",
            "Train Loss: 3.330843028379604e-05 | Train Time: 0.040\n",
            "Valid Loss: 2.7525873520062305e-05 | Valid Time: 0.004\n",
            "Epoch: 249\n",
            "Train Loss: 3.308912528154906e-05 | Train Time: 0.045\n",
            "Valid Loss: 2.673264407349052e-05 | Valid Time: 0.004\n",
            "Epoch: 250\n",
            "Train Loss: 3.23296257192851e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.6075975256389938e-05 | Valid Time: 0.004\n",
            "Epoch: 251\n",
            "Train Loss: 3.258862288930686e-05 | Train Time: 0.044\n",
            "Valid Loss: 2.505622433091048e-05 | Valid Time: 0.004\n",
            "Epoch: 252\n",
            "Train Loss: 3.183318167430116e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.5661168365331832e-05 | Valid Time: 0.004\n",
            "Epoch: 253\n",
            "Train Loss: 3.183598091709428e-05 | Train Time: 0.044\n",
            "Valid Loss: 2.548253360146191e-05 | Valid Time: 0.006\n",
            "Epoch: 254\n",
            "Train Loss: 3.0409107057494112e-05 | Train Time: 0.049\n",
            "Valid Loss: 2.550375029386487e-05 | Valid Time: 0.004\n",
            "Epoch: 255\n",
            "Train Loss: 3.0121696727292147e-05 | Train Time: 0.042\n",
            "Valid Loss: 2.5434060262341518e-05 | Valid Time: 0.004\n",
            "Epoch: 256\n",
            "Train Loss: 3.0484050330414903e-05 | Train Time: 0.046\n",
            "Valid Loss: 2.41873831328121e-05 | Valid Time: 0.004\n",
            "Epoch: 257\n",
            "Train Loss: 3.034958936041221e-05 | Train Time: 0.042\n",
            "Valid Loss: 2.4584312086517457e-05 | Valid Time: 0.004\n",
            "Epoch: 258\n",
            "Train Loss: 2.9022297712799628e-05 | Train Time: 0.042\n",
            "Valid Loss: 2.359956670261454e-05 | Valid Time: 0.004\n",
            "Epoch: 259\n",
            "Train Loss: 2.8722776187350972e-05 | Train Time: 0.051\n",
            "Valid Loss: 2.2859367163619027e-05 | Valid Time: 0.004\n",
            "Epoch: 260\n",
            "Train Loss: 2.830871053447481e-05 | Train Time: 0.048\n",
            "Valid Loss: 2.216778648289619e-05 | Valid Time: 0.004\n",
            "Epoch: 261\n",
            "Train Loss: 2.8593406568688806e-05 | Train Time: 0.040\n",
            "Valid Loss: 2.2252601411310025e-05 | Valid Time: 0.004\n",
            "Epoch: 262\n",
            "Train Loss: 2.7675667115545367e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.3497291294916067e-05 | Valid Time: 0.004\n",
            "Epoch: 263\n",
            "Train Loss: 2.760048137133708e-05 | Train Time: 0.046\n",
            "Valid Loss: 2.274804501212202e-05 | Valid Time: 0.004\n",
            "Epoch: 264\n",
            "Train Loss: 2.6727403565018903e-05 | Train Time: 0.044\n",
            "Valid Loss: 2.183395736210514e-05 | Valid Time: 0.004\n",
            "Epoch: 265\n",
            "Train Loss: 2.6565194821159822e-05 | Train Time: 0.045\n",
            "Valid Loss: 2.1455085516208783e-05 | Valid Time: 0.004\n",
            "Epoch: 266\n",
            "Train Loss: 2.6264884036208967e-05 | Train Time: 0.041\n",
            "Valid Loss: 2.1513155843422282e-05 | Valid Time: 0.004\n",
            "Epoch: 267\n",
            "Train Loss: 2.660226764419349e-05 | Train Time: 0.044\n",
            "Valid Loss: 2.072790084639564e-05 | Valid Time: 0.005\n",
            "Epoch: 268\n",
            "Train Loss: 2.5432366055611055e-05 | Train Time: 0.044\n",
            "Valid Loss: 2.1578787709586322e-05 | Valid Time: 0.004\n",
            "Epoch: 269\n",
            "Train Loss: 2.494018135621445e-05 | Train Time: 0.040\n",
            "Valid Loss: 2.0826714717259165e-05 | Valid Time: 0.004\n",
            "Epoch: 270\n",
            "Train Loss: 2.5919954532582777e-05 | Train Time: 0.044\n",
            "Valid Loss: 1.9506028365867678e-05 | Valid Time: 0.004\n",
            "Epoch: 271\n",
            "Train Loss: 2.4967319041024895e-05 | Train Time: 0.041\n",
            "Valid Loss: 1.993838850467e-05 | Valid Time: 0.004\n",
            "Epoch: 272\n",
            "Train Loss: 2.403182443231344e-05 | Train Time: 0.042\n",
            "Valid Loss: 2.0484908418438863e-05 | Valid Time: 0.005\n",
            "Epoch: 273\n",
            "Train Loss: 2.3906404021545313e-05 | Train Time: 0.041\n",
            "Valid Loss: 1.8824452126864344e-05 | Valid Time: 0.004\n",
            "Epoch: 274\n",
            "Train Loss: 2.3478977709601168e-05 | Train Time: 0.041\n",
            "Valid Loss: 1.9084040104644373e-05 | Valid Time: 0.004\n",
            "Epoch: 275\n",
            "Train Loss: 2.3560210502182598e-05 | Train Time: 0.052\n",
            "Valid Loss: 1.8732293938228395e-05 | Valid Time: 0.004\n",
            "Epoch: 276\n",
            "Train Loss: 2.336346369702369e-05 | Train Time: 0.039\n",
            "Valid Loss: 1.8283149984199554e-05 | Valid Time: 0.004\n",
            "Epoch: 277\n",
            "Train Loss: 2.312921260454459e-05 | Train Time: 0.039\n",
            "Valid Loss: 1.8130057469534222e-05 | Valid Time: 0.005\n",
            "Epoch: 278\n",
            "Train Loss: 2.2710750636179e-05 | Train Time: 0.040\n",
            "Valid Loss: 1.831379358918639e-05 | Valid Time: 0.004\n",
            "Epoch: 279\n",
            "Train Loss: 2.230648351542186e-05 | Train Time: 0.039\n",
            "Valid Loss: 1.8341465874982532e-05 | Valid Time: 0.004\n",
            "Epoch: 280\n",
            "Train Loss: 2.211196697317064e-05 | Train Time: 0.069\n",
            "Valid Loss: 1.836141018429771e-05 | Valid Time: 0.005\n",
            "Epoch: 281\n",
            "Train Loss: 2.212843555753352e-05 | Train Time: 0.056\n",
            "Valid Loss: 1.728383358567953e-05 | Valid Time: 0.005\n",
            "Epoch: 282\n",
            "Train Loss: 2.17055556277046e-05 | Train Time: 0.056\n",
            "Valid Loss: 1.7851581105787773e-05 | Valid Time: 0.005\n",
            "Epoch: 283\n",
            "Train Loss: 2.155891816073563e-05 | Train Time: 0.055\n",
            "Valid Loss: 1.7587454749445897e-05 | Valid Time: 0.005\n",
            "Epoch: 284\n",
            "Train Loss: 2.1285275761329103e-05 | Train Time: 0.062\n",
            "Valid Loss: 1.7402804587618448e-05 | Valid Time: 0.007\n",
            "Epoch: 285\n",
            "Train Loss: 2.054861006399733e-05 | Train Time: 0.063\n",
            "Valid Loss: 1.610750587133225e-05 | Valid Time: 0.006\n",
            "Epoch: 286\n",
            "Train Loss: 2.0572904486471088e-05 | Train Time: 0.061\n",
            "Valid Loss: 1.6653223610774148e-05 | Valid Time: 0.006\n",
            "Epoch: 287\n",
            "Train Loss: 2.006211943808012e-05 | Train Time: 0.069\n",
            "Valid Loss: 1.688677912170533e-05 | Valid Time: 0.007\n",
            "Epoch: 288\n",
            "Train Loss: 1.977394385903608e-05 | Train Time: 0.055\n",
            "Valid Loss: 1.598121252754936e-05 | Valid Time: 0.006\n",
            "Epoch: 289\n",
            "Train Loss: 1.9526184041751547e-05 | Train Time: 0.068\n",
            "Valid Loss: 1.604369435881381e-05 | Valid Time: 0.010\n",
            "Epoch: 290\n",
            "Train Loss: 2.0083020717720502e-05 | Train Time: 0.072\n",
            "Valid Loss: 1.5420845102198655e-05 | Valid Time: 0.006\n",
            "Epoch: 291\n",
            "Train Loss: 1.9316912221256645e-05 | Train Time: 0.070\n",
            "Valid Loss: 1.5762263956276e-05 | Valid Time: 0.005\n",
            "Epoch: 292\n",
            "Train Loss: 1.878417033367441e-05 | Train Time: 0.056\n",
            "Valid Loss: 1.5282200820365688e-05 | Valid Time: 0.005\n",
            "Epoch: 293\n",
            "Train Loss: 1.9400762903387657e-05 | Train Time: 0.054\n",
            "Valid Loss: 1.5273474218702177e-05 | Valid Time: 0.011\n",
            "Epoch: 294\n",
            "Train Loss: 1.885033516373369e-05 | Train Time: 0.054\n",
            "Valid Loss: 1.5002792224549921e-05 | Valid Time: 0.009\n",
            "Epoch: 295\n",
            "Train Loss: 1.8272970555699432e-05 | Train Time: 0.054\n",
            "Valid Loss: 1.435978401786997e-05 | Valid Time: 0.005\n",
            "Epoch: 296\n",
            "Train Loss: 1.8077006279781928e-05 | Train Time: 0.059\n",
            "Valid Loss: 1.4503422789857723e-05 | Valid Time: 0.006\n",
            "Epoch: 297\n",
            "Train Loss: 1.7887087960843927e-05 | Train Time: 0.058\n",
            "Valid Loss: 1.3921779100201093e-05 | Valid Time: 0.005\n",
            "Epoch: 298\n",
            "Train Loss: 1.741321939334739e-05 | Train Time: 0.054\n",
            "Valid Loss: 1.4002208445162978e-05 | Valid Time: 0.005\n",
            "Epoch: 299\n",
            "Train Loss: 1.7772115370462416e-05 | Train Time: 0.058\n",
            "Valid Loss: 1.3791044693789445e-05 | Valid Time: 0.005\n",
            "Epoch: 300\n",
            "Train Loss: 1.7440246210753685e-05 | Train Time: 0.053\n",
            "Valid Loss: 1.4376952549355337e-05 | Valid Time: 0.005\n",
            "Epoch: 301\n",
            "Train Loss: 1.7379350902047007e-05 | Train Time: 0.063\n",
            "Valid Loss: 1.4293436834122986e-05 | Valid Time: 0.005\n",
            "Epoch: 302\n",
            "Train Loss: 1.7178071539092342e-05 | Train Time: 0.052\n",
            "Valid Loss: 1.3936088635091437e-05 | Valid Time: 0.007\n",
            "Epoch: 303\n",
            "Train Loss: 1.718143385005533e-05 | Train Time: 0.057\n",
            "Valid Loss: 1.3612980637844885e-05 | Valid Time: 0.005\n",
            "Epoch: 304\n",
            "Train Loss: 1.6403032168454958e-05 | Train Time: 0.054\n",
            "Valid Loss: 1.331500288870302e-05 | Valid Time: 0.005\n",
            "Epoch: 305\n",
            "Train Loss: 1.6618378504063e-05 | Train Time: 0.055\n",
            "Valid Loss: 1.324045479123015e-05 | Valid Time: 0.006\n",
            "Epoch: 306\n",
            "Train Loss: 1.5975937458279077e-05 | Train Time: 0.064\n",
            "Valid Loss: 1.259403097719769e-05 | Valid Time: 0.005\n",
            "Epoch: 307\n",
            "Train Loss: 1.5912164872133872e-05 | Train Time: 0.061\n",
            "Valid Loss: 1.2614911156560993e-05 | Valid Time: 0.005\n",
            "Epoch: 308\n",
            "Train Loss: 1.6116057486215142e-05 | Train Time: 0.063\n",
            "Valid Loss: 1.2203771802887786e-05 | Valid Time: 0.006\n",
            "Epoch: 309\n",
            "Train Loss: 1.5669120784878032e-05 | Train Time: 0.067\n",
            "Valid Loss: 1.2216224604344461e-05 | Valid Time: 0.005\n",
            "Epoch: 310\n",
            "Train Loss: 1.5660659664717967e-05 | Train Time: 0.056\n",
            "Valid Loss: 1.210869595524855e-05 | Valid Time: 0.005\n",
            "Epoch: 311\n",
            "Train Loss: 1.539897857583128e-05 | Train Time: 0.062\n",
            "Valid Loss: 1.1848279427795205e-05 | Valid Time: 0.005\n",
            "Epoch: 312\n",
            "Train Loss: 1.5022918523754924e-05 | Train Time: 0.063\n",
            "Valid Loss: 1.2286873698030831e-05 | Valid Time: 0.012\n",
            "Epoch: 313\n",
            "Train Loss: 1.4663798356195912e-05 | Train Time: 0.060\n",
            "Valid Loss: 1.201619852508884e-05 | Valid Time: 0.006\n",
            "Epoch: 314\n",
            "Train Loss: 1.5029499081720132e-05 | Train Time: 0.060\n",
            "Valid Loss: 1.2275169865461066e-05 | Valid Time: 0.004\n",
            "Epoch: 315\n",
            "Train Loss: 1.4545118028763682e-05 | Train Time: 0.040\n",
            "Valid Loss: 1.1265462489973288e-05 | Valid Time: 0.004\n",
            "Epoch: 316\n",
            "Train Loss: 1.462666714360239e-05 | Train Time: 0.050\n",
            "Valid Loss: 1.1582427760004066e-05 | Valid Time: 0.005\n",
            "Epoch: 317\n",
            "Train Loss: 1.4668704352516215e-05 | Train Time: 0.041\n",
            "Valid Loss: 1.0776632279885234e-05 | Valid Time: 0.004\n",
            "Epoch: 318\n",
            "Train Loss: 1.4710347568325232e-05 | Train Time: 0.041\n",
            "Valid Loss: 1.1145766620757058e-05 | Valid Time: 0.004\n",
            "Epoch: 319\n",
            "Train Loss: 1.4129919873084872e-05 | Train Time: 0.046\n",
            "Valid Loss: 1.104858665712527e-05 | Valid Time: 0.004\n",
            "Epoch: 320\n",
            "Train Loss: 1.387845559293055e-05 | Train Time: 0.040\n",
            "Valid Loss: 1.122499907069141e-05 | Valid Time: 0.004\n",
            "Epoch: 321\n",
            "Train Loss: 1.4132454180071363e-05 | Train Time: 0.044\n",
            "Valid Loss: 1.0868713161471533e-05 | Valid Time: 0.004\n",
            "Epoch: 322\n",
            "Train Loss: 1.429357789675123e-05 | Train Time: 0.043\n",
            "Valid Loss: 1.0998770903825061e-05 | Valid Time: 0.004\n",
            "Epoch: 323\n",
            "Train Loss: 1.3477463107847143e-05 | Train Time: 0.044\n",
            "Valid Loss: 1.0794521585921757e-05 | Valid Time: 0.004\n",
            "Epoch: 324\n",
            "Train Loss: 1.3301379112817813e-05 | Train Time: 0.044\n",
            "Valid Loss: 1.0952981938316952e-05 | Valid Time: 0.004\n",
            "Epoch: 325\n",
            "Train Loss: 1.3350020162761212e-05 | Train Time: 0.045\n",
            "Valid Loss: 1.0576834483799757e-05 | Valid Time: 0.004\n",
            "Epoch: 326\n",
            "Train Loss: 1.2961016454937636e-05 | Train Time: 0.053\n",
            "Valid Loss: 1.0792290595418308e-05 | Valid Time: 0.004\n",
            "Epoch: 327\n",
            "Train Loss: 1.3039205168752232e-05 | Train Time: 0.040\n",
            "Valid Loss: 1.0416118584544165e-05 | Valid Time: 0.004\n",
            "Epoch: 328\n",
            "Train Loss: 1.3014509022468701e-05 | Train Time: 0.041\n",
            "Valid Loss: 9.85979340839549e-06 | Valid Time: 0.004\n",
            "Epoch: 329\n",
            "Train Loss: 1.2985531247977633e-05 | Train Time: 0.044\n",
            "Valid Loss: 9.929445241141366e-06 | Valid Time: 0.004\n",
            "Epoch: 330\n",
            "Train Loss: 1.2625121144083096e-05 | Train Time: 0.040\n",
            "Valid Loss: 9.891764875646913e-06 | Valid Time: 0.004\n",
            "Epoch: 331\n",
            "Train Loss: 1.232813274327782e-05 | Train Time: 0.045\n",
            "Valid Loss: 9.568044788466068e-06 | Valid Time: 0.004\n",
            "Epoch: 332\n",
            "Train Loss: 1.2297157263674308e-05 | Train Time: 0.040\n",
            "Valid Loss: 9.921348464558832e-06 | Valid Time: 0.004\n",
            "Epoch: 333\n",
            "Train Loss: 1.209040283356444e-05 | Train Time: 0.040\n",
            "Valid Loss: 9.736384527059272e-06 | Valid Time: 0.004\n",
            "Epoch: 334\n",
            "Train Loss: 1.2335929341134033e-05 | Train Time: 0.044\n",
            "Valid Loss: 9.561066690366715e-06 | Valid Time: 0.004\n",
            "Epoch: 335\n",
            "Train Loss: 1.2127387071814155e-05 | Train Time: 0.043\n",
            "Valid Loss: 9.50058210946736e-06 | Valid Time: 0.004\n",
            "Epoch: 336\n",
            "Train Loss: 1.1991370502073551e-05 | Train Time: 0.046\n",
            "Valid Loss: 9.440001576876966e-06 | Valid Time: 0.006\n",
            "Epoch: 337\n",
            "Train Loss: 1.1963114639002015e-05 | Train Time: 0.041\n",
            "Valid Loss: 9.390004834131105e-06 | Valid Time: 0.004\n",
            "Epoch: 338\n",
            "Train Loss: 1.1895916213688906e-05 | Train Time: 0.041\n",
            "Valid Loss: 9.524772394797765e-06 | Valid Time: 0.004\n",
            "Epoch: 339\n",
            "Train Loss: 1.1627140611381038e-05 | Train Time: 0.046\n",
            "Valid Loss: 9.10435937839793e-06 | Valid Time: 0.004\n",
            "Epoch: 340\n",
            "Train Loss: 1.1655564321699785e-05 | Train Time: 0.039\n",
            "Valid Loss: 9.053958365257131e-06 | Valid Time: 0.004\n",
            "Epoch: 341\n",
            "Train Loss: 1.1204644124518381e-05 | Train Time: 0.044\n",
            "Valid Loss: 8.6472182374564e-06 | Valid Time: 0.004\n",
            "Epoch: 342\n",
            "Train Loss: 1.1093641478510109e-05 | Train Time: 0.047\n",
            "Valid Loss: 8.80990819496219e-06 | Valid Time: 0.004\n",
            "Epoch: 343\n",
            "Train Loss: 1.1385756988602224e-05 | Train Time: 0.041\n",
            "Valid Loss: 8.747960691835033e-06 | Valid Time: 0.004\n",
            "Epoch: 344\n",
            "Train Loss: 1.0937387833109824e-05 | Train Time: 0.044\n",
            "Valid Loss: 8.471197816106724e-06 | Valid Time: 0.004\n",
            "Epoch: 345\n",
            "Train Loss: 1.1107292402812164e-05 | Train Time: 0.047\n",
            "Valid Loss: 8.30897306514089e-06 | Valid Time: 0.004\n",
            "Epoch: 346\n",
            "Train Loss: 1.0770474818855292e-05 | Train Time: 0.046\n",
            "Valid Loss: 8.630169759271666e-06 | Valid Time: 0.004\n",
            "Epoch: 347\n",
            "Train Loss: 1.0880876925511983e-05 | Train Time: 0.049\n",
            "Valid Loss: 8.55037114888546e-06 | Valid Time: 0.004\n",
            "Epoch: 348\n",
            "Train Loss: 1.0759592532849637e-05 | Train Time: 0.044\n",
            "Valid Loss: 8.541681836504722e-06 | Valid Time: 0.004\n",
            "Epoch: 349\n",
            "Train Loss: 1.0535163073654986e-05 | Train Time: 0.040\n",
            "Valid Loss: 8.387877187487902e-06 | Valid Time: 0.004\n",
            "Epoch: 350\n",
            "Train Loss: 1.0389073850092245e-05 | Train Time: 0.040\n",
            "Valid Loss: 7.816087872924982e-06 | Valid Time: 0.004\n",
            "Epoch: 351\n",
            "Train Loss: 1.0253252912661993e-05 | Train Time: 0.044\n",
            "Valid Loss: 8.194552265194943e-06 | Valid Time: 0.004\n",
            "Epoch: 352\n",
            "Train Loss: 1.0403361557109747e-05 | Train Time: 0.042\n",
            "Valid Loss: 8.254388376371935e-06 | Valid Time: 0.004\n",
            "Epoch: 353\n",
            "Train Loss: 1.0354265941714403e-05 | Train Time: 0.039\n",
            "Valid Loss: 8.115960099530639e-06 | Valid Time: 0.004\n",
            "Epoch: 354\n",
            "Train Loss: 1.0048158128483919e-05 | Train Time: 0.044\n",
            "Valid Loss: 7.82729557613493e-06 | Valid Time: 0.004\n",
            "Epoch: 355\n",
            "Train Loss: 9.846850025496678e-06 | Train Time: 0.040\n",
            "Valid Loss: 7.982377155713039e-06 | Valid Time: 0.004\n",
            "Epoch: 356\n",
            "Train Loss: 9.906656805469538e-06 | Train Time: 0.043\n",
            "Valid Loss: 8.152519740178832e-06 | Valid Time: 0.004\n",
            "Epoch: 357\n",
            "Train Loss: 9.8460915069154e-06 | Train Time: 0.040\n",
            "Valid Loss: 8.024205044421251e-06 | Valid Time: 0.004\n",
            "Epoch: 358\n",
            "Train Loss: 9.765855156729231e-06 | Train Time: 0.040\n",
            "Valid Loss: 7.453237003574031e-06 | Valid Time: 0.004\n",
            "Epoch: 359\n",
            "Train Loss: 9.8351596534485e-06 | Train Time: 0.044\n",
            "Valid Loss: 7.437472959281877e-06 | Valid Time: 0.004\n",
            "Epoch: 360\n",
            "Train Loss: 9.731375303090318e-06 | Train Time: 0.039\n",
            "Valid Loss: 7.316718892980134e-06 | Valid Time: 0.004\n",
            "Epoch: 361\n",
            "Train Loss: 9.580081041349331e-06 | Train Time: 0.046\n",
            "Valid Loss: 7.442199603246991e-06 | Valid Time: 0.004\n",
            "Epoch: 362\n",
            "Train Loss: 9.446330068385578e-06 | Train Time: 0.042\n",
            "Valid Loss: 7.76598881202517e-06 | Valid Time: 0.004\n",
            "Epoch: 363\n",
            "Train Loss: 9.655108169681625e-06 | Train Time: 0.040\n",
            "Valid Loss: 7.460394726876984e-06 | Valid Time: 0.004\n",
            "Epoch: 364\n",
            "Train Loss: 9.318214461018215e-06 | Train Time: 0.041\n",
            "Valid Loss: 7.3233684361184714e-06 | Valid Time: 0.004\n",
            "Epoch: 365\n",
            "Train Loss: 9.294927758674021e-06 | Train Time: 0.042\n",
            "Valid Loss: 7.1877138907439075e-06 | Valid Time: 0.004\n",
            "Epoch: 366\n",
            "Train Loss: 9.41752423386788e-06 | Train Time: 0.047\n",
            "Valid Loss: 7.1244658101932146e-06 | Valid Time: 0.004\n",
            "Epoch: 367\n",
            "Train Loss: 9.301203635914135e-06 | Train Time: 0.044\n",
            "Valid Loss: 7.369850663963007e-06 | Valid Time: 0.004\n",
            "Epoch: 368\n",
            "Train Loss: 9.077858385353465e-06 | Train Time: 0.042\n",
            "Valid Loss: 6.960188557059155e-06 | Valid Time: 0.004\n",
            "Epoch: 369\n",
            "Train Loss: 9.142655244431808e-06 | Train Time: 0.053\n",
            "Valid Loss: 7.134323823265731e-06 | Valid Time: 0.004\n",
            "Epoch: 370\n",
            "Train Loss: 9.144388968707062e-06 | Train Time: 0.048\n",
            "Valid Loss: 7.253049943756196e-06 | Valid Time: 0.008\n",
            "Epoch: 371\n",
            "Train Loss: 9.015838031700696e-06 | Train Time: 0.046\n",
            "Valid Loss: 6.691183671136969e-06 | Valid Time: 0.004\n",
            "Epoch: 372\n",
            "Train Loss: 8.901034652808448e-06 | Train Time: 0.046\n",
            "Valid Loss: 7.090881126714521e-06 | Valid Time: 0.004\n",
            "Epoch: 373\n",
            "Train Loss: 8.942093927544192e-06 | Train Time: 0.052\n",
            "Valid Loss: 7.203303312053322e-06 | Valid Time: 0.004\n",
            "Epoch: 374\n",
            "Train Loss: 8.80899469848373e-06 | Train Time: 0.048\n",
            "Valid Loss: 6.916055554029299e-06 | Valid Time: 0.004\n",
            "Epoch: 375\n",
            "Train Loss: 8.612859255663352e-06 | Train Time: 0.041\n",
            "Valid Loss: 6.644829454671708e-06 | Valid Time: 0.004\n",
            "Epoch: 376\n",
            "Train Loss: 8.66874315761379e-06 | Train Time: 0.042\n",
            "Valid Loss: 6.952396006454364e-06 | Valid Time: 0.004\n",
            "Epoch: 377\n",
            "Train Loss: 8.561314098187723e-06 | Train Time: 0.046\n",
            "Valid Loss: 6.787609208913636e-06 | Valid Time: 0.004\n",
            "Epoch: 378\n",
            "Train Loss: 8.468689884466585e-06 | Train Time: 0.045\n",
            "Valid Loss: 6.761750000805478e-06 | Valid Time: 0.004\n",
            "Epoch: 379\n",
            "Train Loss: 8.746184039409855e-06 | Train Time: 0.050\n",
            "Valid Loss: 6.724848617523094e-06 | Valid Time: 0.004\n",
            "Epoch: 380\n",
            "Train Loss: 8.316247158290934e-06 | Train Time: 0.042\n",
            "Valid Loss: 6.543179324580706e-06 | Valid Time: 0.004\n",
            "Epoch: 381\n",
            "Train Loss: 8.372717775273487e-06 | Train Time: 0.048\n",
            "Valid Loss: 6.636654688918497e-06 | Valid Time: 0.004\n",
            "Epoch: 382\n",
            "Train Loss: 8.387991965719265e-06 | Train Time: 0.044\n",
            "Valid Loss: 6.4977118654496735e-06 | Valid Time: 0.004\n",
            "Epoch: 383\n",
            "Train Loss: 8.296324722323334e-06 | Train Time: 0.042\n",
            "Valid Loss: 6.507286570922588e-06 | Valid Time: 0.004\n",
            "Epoch: 384\n",
            "Train Loss: 8.169384773282218e-06 | Train Time: 0.046\n",
            "Valid Loss: 6.434795068344101e-06 | Valid Time: 0.004\n",
            "Epoch: 385\n",
            "Train Loss: 8.186733202819596e-06 | Train Time: 0.047\n",
            "Valid Loss: 6.15202657172631e-06 | Valid Time: 0.004\n",
            "Epoch: 386\n",
            "Train Loss: 8.08120048532146e-06 | Train Time: 0.048\n",
            "Valid Loss: 6.499074061139254e-06 | Valid Time: 0.004\n",
            "Epoch: 387\n",
            "Train Loss: 8.108013571472838e-06 | Train Time: 0.043\n",
            "Valid Loss: 6.080903631300316e-06 | Valid Time: 0.004\n",
            "Epoch: 388\n",
            "Train Loss: 8.22483189040213e-06 | Train Time: 0.043\n",
            "Valid Loss: 5.808291234643548e-06 | Valid Time: 0.004\n",
            "Epoch: 389\n",
            "Train Loss: 7.947850826894865e-06 | Train Time: 0.055\n",
            "Valid Loss: 6.036580316504114e-06 | Valid Time: 0.004\n",
            "Epoch: 390\n",
            "Train Loss: 7.980588770806208e-06 | Train Time: 0.044\n",
            "Valid Loss: 5.9297194638929795e-06 | Valid Time: 0.004\n",
            "Epoch: 391\n",
            "Train Loss: 7.815787648723927e-06 | Train Time: 0.041\n",
            "Valid Loss: 6.224313437996898e-06 | Valid Time: 0.004\n",
            "Epoch: 392\n",
            "Train Loss: 7.857335640437669e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.784316954304813e-06 | Valid Time: 0.004\n",
            "Epoch: 393\n",
            "Train Loss: 7.780852729410982e-06 | Train Time: 0.040\n",
            "Valid Loss: 5.929795634074253e-06 | Valid Time: 0.004\n",
            "Epoch: 394\n",
            "Train Loss: 7.654971204829053e-06 | Train Time: 0.045\n",
            "Valid Loss: 6.149310365799465e-06 | Valid Time: 0.004\n",
            "Epoch: 395\n",
            "Train Loss: 7.765954615024384e-06 | Train Time: 0.040\n",
            "Valid Loss: 6.2721326230530394e-06 | Valid Time: 0.004\n",
            "Epoch: 396\n",
            "Train Loss: 7.894835789556964e-06 | Train Time: 0.040\n",
            "Valid Loss: 5.910795835006866e-06 | Valid Time: 0.004\n",
            "Epoch: 397\n",
            "Train Loss: 7.837383418518584e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.574963552135159e-06 | Valid Time: 0.004\n",
            "Epoch: 398\n",
            "Train Loss: 7.73079532336851e-06 | Train Time: 0.042\n",
            "Valid Loss: 5.919233672102564e-06 | Valid Time: 0.004\n",
            "Epoch: 399\n",
            "Train Loss: 7.48627803659474e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.828793973705615e-06 | Valid Time: 0.004\n",
            "Epoch: 400\n",
            "Train Loss: 7.509154011131614e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.781339268651209e-06 | Valid Time: 0.004\n",
            "Epoch: 401\n",
            "Train Loss: 7.311520403163741e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.8426280702406075e-06 | Valid Time: 0.004\n",
            "Epoch: 402\n",
            "Train Loss: 7.500252331738011e-06 | Train Time: 0.042\n",
            "Valid Loss: 6.118492819950916e-06 | Valid Time: 0.004\n",
            "Epoch: 403\n",
            "Train Loss: 7.3694873208296485e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.647345460602082e-06 | Valid Time: 0.004\n",
            "Epoch: 404\n",
            "Train Loss: 7.372954632955952e-06 | Train Time: 0.047\n",
            "Valid Loss: 5.57777275389526e-06 | Valid Time: 0.004\n",
            "Epoch: 405\n",
            "Train Loss: 7.2303031629417095e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.760820840805536e-06 | Valid Time: 0.005\n",
            "Epoch: 406\n",
            "Train Loss: 7.354904573730891e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.827625955134863e-06 | Valid Time: 0.004\n",
            "Epoch: 407\n",
            "Train Loss: 7.124404601199785e-06 | Train Time: 0.042\n",
            "Valid Loss: 5.427595397122786e-06 | Valid Time: 0.004\n",
            "Epoch: 408\n",
            "Train Loss: 7.181276350820553e-06 | Train Time: 0.039\n",
            "Valid Loss: 5.8907880884362385e-06 | Valid Time: 0.004\n",
            "Epoch: 409\n",
            "Train Loss: 7.167813964770175e-06 | Train Time: 0.044\n",
            "Valid Loss: 5.583613756243722e-06 | Valid Time: 0.004\n",
            "Epoch: 410\n",
            "Train Loss: 6.989298253756715e-06 | Train Time: 0.049\n",
            "Valid Loss: 5.394029130911804e-06 | Valid Time: 0.004\n",
            "Epoch: 411\n",
            "Train Loss: 7.209344948932994e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.469656116474653e-06 | Valid Time: 0.004\n",
            "Epoch: 412\n",
            "Train Loss: 7.039502588668256e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.660966053255834e-06 | Valid Time: 0.004\n",
            "Epoch: 413\n",
            "Train Loss: 7.059980680423905e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.318374405760551e-06 | Valid Time: 0.004\n",
            "Epoch: 414\n",
            "Train Loss: 7.090112103469437e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.634559329337208e-06 | Valid Time: 0.004\n",
            "Epoch: 415\n",
            "Train Loss: 6.955130766073126e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.405820274972939e-06 | Valid Time: 0.004\n",
            "Epoch: 416\n",
            "Train Loss: 7.089252630976262e-06 | Train Time: 0.044\n",
            "Valid Loss: 5.143133648743969e-06 | Valid Time: 0.004\n",
            "Epoch: 417\n",
            "Train Loss: 6.777102134947199e-06 | Train Time: 0.054\n",
            "Valid Loss: 5.538158802664839e-06 | Valid Time: 0.004\n",
            "Epoch: 418\n",
            "Train Loss: 6.891480688864249e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.294196171234944e-06 | Valid Time: 0.008\n",
            "Epoch: 419\n",
            "Train Loss: 6.971695756874396e-06 | Train Time: 0.044\n",
            "Valid Loss: 5.656279199683922e-06 | Valid Time: 0.004\n",
            "Epoch: 420\n",
            "Train Loss: 6.931188363523688e-06 | Train Time: 0.042\n",
            "Valid Loss: 5.130249064677628e-06 | Valid Time: 0.004\n",
            "Epoch: 421\n",
            "Train Loss: 6.711538708259468e-06 | Train Time: 0.043\n",
            "Valid Loss: 5.449313221106422e-06 | Valid Time: 0.006\n",
            "Epoch: 422\n",
            "Train Loss: 7.001602489253855e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.333949729902088e-06 | Valid Time: 0.004\n",
            "Epoch: 423\n",
            "Train Loss: 6.785758296246059e-06 | Train Time: 0.051\n",
            "Valid Loss: 5.0266285143152345e-06 | Valid Time: 0.004\n",
            "Epoch: 424\n",
            "Train Loss: 6.780305102438433e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.3438436680153245e-06 | Valid Time: 0.004\n",
            "Epoch: 425\n",
            "Train Loss: 6.8291795287223065e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.016224122300628e-06 | Valid Time: 0.004\n",
            "Epoch: 426\n",
            "Train Loss: 6.5835618443088604e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.366656523619895e-06 | Valid Time: 0.004\n",
            "Epoch: 427\n",
            "Train Loss: 6.591910005226964e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.848554794989468e-06 | Valid Time: 0.004\n",
            "Epoch: 428\n",
            "Train Loss: 6.685751168333809e-06 | Train Time: 0.046\n",
            "Valid Loss: 5.226917437539669e-06 | Valid Time: 0.004\n",
            "Epoch: 429\n",
            "Train Loss: 6.460939493990736e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.083650648884941e-06 | Valid Time: 0.004\n",
            "Epoch: 430\n",
            "Train Loss: 6.579216005775379e-06 | Train Time: 0.043\n",
            "Valid Loss: 5.098690053273458e-06 | Valid Time: 0.006\n",
            "Epoch: 431\n",
            "Train Loss: 6.710429806844331e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.86487283524184e-06 | Valid Time: 0.004\n",
            "Epoch: 432\n",
            "Train Loss: 6.670918310192064e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.946655963067315e-06 | Valid Time: 0.004\n",
            "Epoch: 433\n",
            "Train Loss: 6.499452183561516e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.115352450957289e-06 | Valid Time: 0.004\n",
            "Epoch: 434\n",
            "Train Loss: 6.455547600126011e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.287261956254952e-06 | Valid Time: 0.004\n",
            "Epoch: 435\n",
            "Train Loss: 6.612757852053619e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.814687372345361e-06 | Valid Time: 0.004\n",
            "Epoch: 436\n",
            "Train Loss: 6.5188553890038746e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.119644356454955e-06 | Valid Time: 0.004\n",
            "Epoch: 437\n",
            "Train Loss: 6.2535079450753985e-06 | Train Time: 0.040\n",
            "Valid Loss: 5.066106950835092e-06 | Valid Time: 0.004\n",
            "Epoch: 438\n",
            "Train Loss: 6.580268973266357e-06 | Train Time: 0.045\n",
            "Valid Loss: 5.14865382683638e-06 | Valid Time: 0.004\n",
            "Epoch: 439\n",
            "Train Loss: 6.669127287750598e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.793308335138136e-06 | Valid Time: 0.004\n",
            "Epoch: 440\n",
            "Train Loss: 6.456945857280516e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.913006932838471e-06 | Valid Time: 0.004\n",
            "Epoch: 441\n",
            "Train Loss: 6.549654199261568e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.869111990046804e-06 | Valid Time: 0.004\n",
            "Epoch: 442\n",
            "Train Loss: 6.390907401510049e-06 | Train Time: 0.042\n",
            "Valid Loss: 5.133785862199147e-06 | Valid Time: 0.004\n",
            "Epoch: 443\n",
            "Train Loss: 6.247587089092122e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.843018359679263e-06 | Valid Time: 0.004\n",
            "Epoch: 444\n",
            "Train Loss: 6.515794348160853e-06 | Train Time: 0.040\n",
            "Valid Loss: 5.076421075500548e-06 | Valid Time: 0.006\n",
            "Epoch: 445\n",
            "Train Loss: 6.311818196991226e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.997254336558399e-06 | Valid Time: 0.004\n",
            "Epoch: 446\n",
            "Train Loss: 6.09252720096265e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.980572839485831e-06 | Valid Time: 0.004\n",
            "Epoch: 447\n",
            "Train Loss: 6.311508559520007e-06 | Train Time: 0.042\n",
            "Valid Loss: 5.132441401656251e-06 | Valid Time: 0.005\n",
            "Epoch: 448\n",
            "Train Loss: 6.271411712077679e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.9799566568253795e-06 | Valid Time: 0.004\n",
            "Epoch: 449\n",
            "Train Loss: 6.325644972093869e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.8905214953265386e-06 | Valid Time: 0.004\n",
            "Epoch: 450\n",
            "Train Loss: 6.126975722509087e-06 | Train Time: 0.041\n",
            "Valid Loss: 5.0838464176194975e-06 | Valid Time: 0.005\n",
            "Epoch: 451\n",
            "Train Loss: 6.160924885989516e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.58067870567902e-06 | Valid Time: 0.004\n",
            "Epoch: 452\n",
            "Train Loss: 6.153577169243363e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.563227207654563e-06 | Valid Time: 0.004\n",
            "Epoch: 453\n",
            "Train Loss: 5.96669337937783e-06 | Train Time: 0.047\n",
            "Valid Loss: 5.030061402067076e-06 | Valid Time: 0.004\n",
            "Epoch: 454\n",
            "Train Loss: 6.187167764437618e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.9470459089207e-06 | Valid Time: 0.004\n",
            "Epoch: 455\n",
            "Train Loss: 6.192921136971563e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.89138415105117e-06 | Valid Time: 0.004\n",
            "Epoch: 456\n",
            "Train Loss: 6.011535560901393e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.717715455626603e-06 | Valid Time: 0.004\n",
            "Epoch: 457\n",
            "Train Loss: 6.108990100983647e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.56026941719756e-06 | Valid Time: 0.004\n",
            "Epoch: 458\n",
            "Train Loss: 6.175327644086792e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.54620317213994e-06 | Valid Time: 0.004\n",
            "Epoch: 459\n",
            "Train Loss: 6.187052258610493e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.811380222236039e-06 | Valid Time: 0.004\n",
            "Epoch: 460\n",
            "Train Loss: 6.048172190276091e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.712148893304402e-06 | Valid Time: 0.004\n",
            "Epoch: 461\n",
            "Train Loss: 5.985967641208845e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.809948450201773e-06 | Valid Time: 0.004\n",
            "Epoch: 462\n",
            "Train Loss: 5.8431139905223976e-06 | Train Time: 0.040\n",
            "Valid Loss: 5.06227240748558e-06 | Valid Time: 0.004\n",
            "Epoch: 463\n",
            "Train Loss: 6.00259259044833e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.811930921277963e-06 | Valid Time: 0.004\n",
            "Epoch: 464\n",
            "Train Loss: 5.891044384043198e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.41070710621716e-06 | Valid Time: 0.004\n",
            "Epoch: 465\n",
            "Train Loss: 6.043406301614596e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.674347337640938e-06 | Valid Time: 0.004\n",
            "Epoch: 466\n",
            "Train Loss: 5.870472386959591e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.901106422039447e-06 | Valid Time: 0.004\n",
            "Epoch: 467\n",
            "Train Loss: 5.917771022723173e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.527134933596244e-06 | Valid Time: 0.005\n",
            "Epoch: 468\n",
            "Train Loss: 5.890628062843461e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.616369551513344e-06 | Valid Time: 0.004\n",
            "Epoch: 469\n",
            "Train Loss: 5.873083455298911e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.488543254410615e-06 | Valid Time: 0.004\n",
            "Epoch: 470\n",
            "Train Loss: 5.752220408794528e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.305621132516535e-06 | Valid Time: 0.004\n",
            "Epoch: 471\n",
            "Train Loss: 6.093615343161218e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.4619325763051165e-06 | Valid Time: 0.004\n",
            "Epoch: 472\n",
            "Train Loss: 5.875405281585699e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.647503374144435e-06 | Valid Time: 0.004\n",
            "Epoch: 473\n",
            "Train Loss: 5.980093192192726e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.470887461138773e-06 | Valid Time: 0.004\n",
            "Epoch: 474\n",
            "Train Loss: 5.7871214721672e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.510459120865562e-06 | Valid Time: 0.004\n",
            "Epoch: 475\n",
            "Train Loss: 5.780989386039437e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.794763526660972e-06 | Valid Time: 0.004\n",
            "Epoch: 476\n",
            "Train Loss: 6.042375662218546e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.429512500792043e-06 | Valid Time: 0.006\n",
            "Epoch: 477\n",
            "Train Loss: 5.837965386490396e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.544849844023702e-06 | Valid Time: 0.004\n",
            "Epoch: 478\n",
            "Train Loss: 5.884857364435447e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.541877387964632e-06 | Valid Time: 0.004\n",
            "Epoch: 479\n",
            "Train Loss: 6.076798717913334e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.879775929111929e-06 | Valid Time: 0.004\n",
            "Epoch: 480\n",
            "Train Loss: 5.881416245756554e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.313576482672943e-06 | Valid Time: 0.004\n",
            "Epoch: 481\n",
            "Train Loss: 5.824253139508073e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.18713852923247e-06 | Valid Time: 0.004\n",
            "Epoch: 482\n",
            "Train Loss: 6.078668047848623e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.627426051229122e-06 | Valid Time: 0.004\n",
            "Epoch: 483\n",
            "Train Loss: 5.779614139100886e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.594907068167231e-06 | Valid Time: 0.004\n",
            "Epoch: 484\n",
            "Train Loss: 5.603160411737918e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.699704959421069e-06 | Valid Time: 0.004\n",
            "Epoch: 485\n",
            "Train Loss: 5.630762757391494e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.684321538661607e-06 | Valid Time: 0.004\n",
            "Epoch: 486\n",
            "Train Loss: 5.7427714182267666e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.452113216757425e-06 | Valid Time: 0.004\n",
            "Epoch: 487\n",
            "Train Loss: 5.9222219988441795e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.314306238484278e-06 | Valid Time: 0.004\n",
            "Epoch: 488\n",
            "Train Loss: 5.676005230270675e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.6498619212798076e-06 | Valid Time: 0.004\n",
            "Epoch: 489\n",
            "Train Loss: 5.686678105121246e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.3169138734810986e-06 | Valid Time: 0.004\n",
            "Epoch: 490\n",
            "Train Loss: 5.73774109398073e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.3450093016872415e-06 | Valid Time: 0.004\n",
            "Epoch: 491\n",
            "Train Loss: 5.801061297461274e-06 | Train Time: 0.054\n",
            "Valid Loss: 4.6251916501205415e-06 | Valid Time: 0.004\n",
            "Epoch: 492\n",
            "Train Loss: 5.669263009622227e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.603017487170291e-06 | Valid Time: 0.004\n",
            "Epoch: 493\n",
            "Train Loss: 5.584099494626571e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.3968684622086585e-06 | Valid Time: 0.005\n",
            "Epoch: 494\n",
            "Train Loss: 5.578484729085176e-06 | Train Time: 0.057\n",
            "Valid Loss: 4.254171699358267e-06 | Valid Time: 0.004\n",
            "Epoch: 495\n",
            "Train Loss: 5.8416283991391534e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.423880909598665e-06 | Valid Time: 0.004\n",
            "Epoch: 496\n",
            "Train Loss: 5.688251349056372e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.365443828646676e-06 | Valid Time: 0.004\n",
            "Epoch: 497\n",
            "Train Loss: 5.5914681979629675e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.55987424174964e-06 | Valid Time: 0.004\n",
            "Epoch: 498\n",
            "Train Loss: 5.824137679155683e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.4490795971796615e-06 | Valid Time: 0.004\n",
            "Epoch: 499\n",
            "Train Loss: 5.519132423614792e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.426698978932109e-06 | Valid Time: 0.004\n",
            "Epoch: 500\n",
            "Train Loss: 5.539538528864796e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.513624162427732e-06 | Valid Time: 0.004\n",
            "Epoch: 501\n",
            "Train Loss: 5.652803292832687e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.337830205258797e-06 | Valid Time: 0.004\n",
            "Epoch: 502\n",
            "Train Loss: 5.819155421704636e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.235368805893813e-06 | Valid Time: 0.004\n",
            "Epoch: 503\n",
            "Train Loss: 5.8017441915581005e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.207846473036625e-06 | Valid Time: 0.004\n",
            "Epoch: 504\n",
            "Train Loss: 5.6399304412479975e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.319981371736503e-06 | Valid Time: 0.004\n",
            "Epoch: 505\n",
            "Train Loss: 5.755945994678768e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.64545780687331e-06 | Valid Time: 0.005\n",
            "Epoch: 506\n",
            "Train Loss: 5.591050830844324e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.48425976173894e-06 | Valid Time: 0.004\n",
            "Epoch: 507\n",
            "Train Loss: 5.609526078842464e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.1801706629485125e-06 | Valid Time: 0.004\n",
            "Epoch: 508\n",
            "Train Loss: 5.628225471809855e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.73958641578065e-06 | Valid Time: 0.004\n",
            "Epoch: 509\n",
            "Train Loss: 5.519258502317826e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.275561650501913e-06 | Valid Time: 0.006\n",
            "Epoch: 510\n",
            "Train Loss: 5.5110182529460875e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.304839421820361e-06 | Valid Time: 0.005\n",
            "Epoch: 511\n",
            "Train Loss: 5.621219497697894e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.32910837844247e-06 | Valid Time: 0.004\n",
            "Epoch: 512\n",
            "Train Loss: 5.566665504375124e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.239700501784682e-06 | Valid Time: 0.004\n",
            "Epoch: 513\n",
            "Train Loss: 5.611943333860836e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.155192186772183e-06 | Valid Time: 0.004\n",
            "Epoch: 514\n",
            "Train Loss: 5.521281082110363e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.266919177098316e-06 | Valid Time: 0.004\n",
            "Epoch: 515\n",
            "Train Loss: 5.527897269530513e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.5487128090826445e-06 | Valid Time: 0.004\n",
            "Epoch: 516\n",
            "Train Loss: 5.396182473305089e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.115816750527301e-06 | Valid Time: 0.004\n",
            "Epoch: 517\n",
            "Train Loss: 5.402734291237721e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.370815531729022e-06 | Valid Time: 0.004\n",
            "Epoch: 518\n",
            "Train Loss: 5.623855440717307e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.421226321937866e-06 | Valid Time: 0.006\n",
            "Epoch: 519\n",
            "Train Loss: 5.451538800116395e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.5314558292375295e-06 | Valid Time: 0.005\n",
            "Epoch: 520\n",
            "Train Loss: 5.5729361974954376e-06 | Train Time: 0.067\n",
            "Valid Loss: 4.109459496248746e-06 | Valid Time: 0.007\n",
            "Epoch: 521\n",
            "Train Loss: 5.485669316840358e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.35736910731066e-06 | Valid Time: 0.005\n",
            "Epoch: 522\n",
            "Train Loss: 5.436896799437818e-06 | Train Time: 0.057\n",
            "Valid Loss: 4.5589241608468e-06 | Valid Time: 0.007\n",
            "Epoch: 523\n",
            "Train Loss: 5.4847524097567655e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.608362928593124e-06 | Valid Time: 0.005\n",
            "Epoch: 524\n",
            "Train Loss: 5.443198506327462e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.224413714837283e-06 | Valid Time: 0.006\n",
            "Epoch: 525\n",
            "Train Loss: 5.400917370934622e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.339608267400763e-06 | Valid Time: 0.005\n",
            "Epoch: 526\n",
            "Train Loss: 5.36486252258328e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.196281452095718e-06 | Valid Time: 0.006\n",
            "Epoch: 527\n",
            "Train Loss: 5.5099936616898045e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.2691165162977995e-06 | Valid Time: 0.005\n",
            "Epoch: 528\n",
            "Train Loss: 5.384258884078008e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.282561121726758e-06 | Valid Time: 0.006\n",
            "Epoch: 529\n",
            "Train Loss: 5.48112011529156e-06 | Train Time: 0.057\n",
            "Valid Loss: 4.16928003232897e-06 | Valid Time: 0.005\n",
            "Epoch: 530\n",
            "Train Loss: 5.4686511703039285e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.373998990558903e-06 | Valid Time: 0.005\n",
            "Epoch: 531\n",
            "Train Loss: 5.522075002772908e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.0828325609254534e-06 | Valid Time: 0.006\n",
            "Epoch: 532\n",
            "Train Loss: 5.4757863608756455e-06 | Train Time: 0.061\n",
            "Valid Loss: 4.071204216415936e-06 | Valid Time: 0.005\n",
            "Epoch: 533\n",
            "Train Loss: 5.419191938926815e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.427019348440808e-06 | Valid Time: 0.005\n",
            "Epoch: 534\n",
            "Train Loss: 5.456544568005484e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.385905640447163e-06 | Valid Time: 0.005\n",
            "Epoch: 535\n",
            "Train Loss: 5.446241016215936e-06 | Train Time: 0.057\n",
            "Valid Loss: 4.625661517820845e-06 | Valid Time: 0.005\n",
            "Epoch: 536\n",
            "Train Loss: 5.331390570972871e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.1700873225636315e-06 | Valid Time: 0.006\n",
            "Epoch: 537\n",
            "Train Loss: 5.421727632892726e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.093075403943658e-06 | Valid Time: 0.005\n",
            "Epoch: 538\n",
            "Train Loss: 5.390448268371983e-06 | Train Time: 0.057\n",
            "Valid Loss: 4.075798074154591e-06 | Valid Time: 0.005\n",
            "Epoch: 539\n",
            "Train Loss: 5.382306790124858e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.315759497330873e-06 | Valid Time: 0.005\n",
            "Epoch: 540\n",
            "Train Loss: 5.427973337646108e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.368848067315412e-06 | Valid Time: 0.005\n",
            "Epoch: 541\n",
            "Train Loss: 5.40320215804968e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.262375114194583e-06 | Valid Time: 0.005\n",
            "Epoch: 542\n",
            "Train Loss: 5.4458430895465424e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.187863851257134e-06 | Valid Time: 0.005\n",
            "Epoch: 543\n",
            "Train Loss: 5.558825159823755e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.302029537939234e-06 | Valid Time: 0.005\n",
            "Epoch: 544\n",
            "Train Loss: 5.3943751026963586e-06 | Train Time: 0.069\n",
            "Valid Loss: 4.033682785120618e-06 | Valid Time: 0.005\n",
            "Epoch: 545\n",
            "Train Loss: 5.529180680241552e-06 | Train Time: 0.054\n",
            "Valid Loss: 4.213227839500178e-06 | Valid Time: 0.005\n",
            "Epoch: 546\n",
            "Train Loss: 5.489699037752871e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.182186785328668e-06 | Valid Time: 0.005\n",
            "Epoch: 547\n",
            "Train Loss: 5.361477496990119e-06 | Train Time: 0.064\n",
            "Valid Loss: 4.067175950694946e-06 | Valid Time: 0.008\n",
            "Epoch: 548\n",
            "Train Loss: 5.391281570155116e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.278185997463879e-06 | Valid Time: 0.005\n",
            "Epoch: 549\n",
            "Train Loss: 5.293317303767253e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.2049393869092455e-06 | Valid Time: 0.006\n",
            "Epoch: 550\n",
            "Train Loss: 5.2895718454237795e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.205033519610879e-06 | Valid Time: 0.005\n",
            "Epoch: 551\n",
            "Train Loss: 5.483814061335579e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.2645888242986985e-06 | Valid Time: 0.005\n",
            "Epoch: 552\n",
            "Train Loss: 5.585398616858583e-06 | Train Time: 0.057\n",
            "Valid Loss: 4.396529789119086e-06 | Valid Time: 0.005\n",
            "Epoch: 553\n",
            "Train Loss: 5.311821200848499e-06 | Train Time: 0.063\n",
            "Valid Loss: 4.346528839960229e-06 | Valid Time: 0.006\n",
            "Epoch: 554\n",
            "Train Loss: 5.403535260484204e-06 | Train Time: 0.062\n",
            "Valid Loss: 4.179808456683531e-06 | Valid Time: 0.010\n",
            "Epoch: 555\n",
            "Train Loss: 5.376338299356575e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.402712079354387e-06 | Valid Time: 0.004\n",
            "Epoch: 556\n",
            "Train Loss: 5.439418055175338e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.155510850978317e-06 | Valid Time: 0.004\n",
            "Epoch: 557\n",
            "Train Loss: 5.28399452832673e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.052098461215792e-06 | Valid Time: 0.004\n",
            "Epoch: 558\n",
            "Train Loss: 5.5584615665793535e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.0827810607879655e-06 | Valid Time: 0.004\n",
            "Epoch: 559\n",
            "Train Loss: 5.28962314092496e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.0370766782871215e-06 | Valid Time: 0.004\n",
            "Epoch: 560\n",
            "Train Loss: 5.295796268001141e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.023479732495616e-06 | Valid Time: 0.004\n",
            "Epoch: 561\n",
            "Train Loss: 5.328828910933225e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.400372858981427e-06 | Valid Time: 0.005\n",
            "Epoch: 562\n",
            "Train Loss: 5.296704944157682e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.030154741485603e-06 | Valid Time: 0.004\n",
            "Epoch: 563\n",
            "Train Loss: 5.554102381211124e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.399506792651664e-06 | Valid Time: 0.004\n",
            "Epoch: 564\n",
            "Train Loss: 5.397681752583594e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.434508696249395e-06 | Valid Time: 0.004\n",
            "Epoch: 565\n",
            "Train Loss: 5.398828625402529e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1537152810633415e-06 | Valid Time: 0.008\n",
            "Epoch: 566\n",
            "Train Loss: 5.422160438683932e-06 | Train Time: 0.047\n",
            "Valid Loss: 3.888387595907261e-06 | Valid Time: 0.004\n",
            "Epoch: 567\n",
            "Train Loss: 5.576723924605176e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.09274298363016e-06 | Valid Time: 0.004\n",
            "Epoch: 568\n",
            "Train Loss: 5.53126353679545e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.126872909182566e-06 | Valid Time: 0.004\n",
            "Epoch: 569\n",
            "Train Loss: 5.584879500020179e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1655441691546e-06 | Valid Time: 0.006\n",
            "Epoch: 570\n",
            "Train Loss: 5.578038326348178e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.510342364483222e-06 | Valid Time: 0.004\n",
            "Epoch: 571\n",
            "Train Loss: 5.399341716838535e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.542526994555374e-06 | Valid Time: 0.004\n",
            "Epoch: 572\n",
            "Train Loss: 5.2772489198105175e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.419364813657012e-06 | Valid Time: 0.004\n",
            "Epoch: 573\n",
            "Train Loss: 5.433832029666519e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.4137349277662e-06 | Valid Time: 0.004\n",
            "Epoch: 574\n",
            "Train Loss: 5.353779124561698e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.190353138255887e-06 | Valid Time: 0.004\n",
            "Epoch: 575\n",
            "Train Loss: 5.306798902893206e-06 | Train Time: 0.047\n",
            "Valid Loss: 3.948322842006746e-06 | Valid Time: 0.004\n",
            "Epoch: 576\n",
            "Train Loss: 5.311070299285347e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.331543550506467e-06 | Valid Time: 0.004\n",
            "Epoch: 577\n",
            "Train Loss: 5.3784878673468485e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.978019208261685e-06 | Valid Time: 0.004\n",
            "Epoch: 578\n",
            "Train Loss: 5.4794450306872026e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.207333404337987e-06 | Valid Time: 0.005\n",
            "Epoch: 579\n",
            "Train Loss: 5.5527343874928196e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.289232947485289e-06 | Valid Time: 0.004\n",
            "Epoch: 580\n",
            "Train Loss: 5.330740827957925e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.439384383658762e-06 | Valid Time: 0.004\n",
            "Epoch: 581\n",
            "Train Loss: 5.557368581321498e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.203374828648521e-06 | Valid Time: 0.004\n",
            "Epoch: 582\n",
            "Train Loss: 5.323077584762359e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.226196551826433e-06 | Valid Time: 0.004\n",
            "Epoch: 583\n",
            "Train Loss: 5.408884862845298e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.041739089188923e-06 | Valid Time: 0.004\n",
            "Epoch: 584\n",
            "Train Loss: 5.41107656317763e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.049534823025169e-06 | Valid Time: 0.004\n",
            "Epoch: 585\n",
            "Train Loss: 5.335615719559428e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.032180413560127e-06 | Valid Time: 0.006\n",
            "Epoch: 586\n",
            "Train Loss: 5.246810837888916e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.04806178266881e-06 | Valid Time: 0.004\n",
            "Epoch: 587\n",
            "Train Loss: 5.302343765833939e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.261509502612171e-06 | Valid Time: 0.004\n",
            "Epoch: 588\n",
            "Train Loss: 5.316311717251665e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.407423261909571e-06 | Valid Time: 0.004\n",
            "Epoch: 589\n",
            "Train Loss: 5.290435910865199e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.434695370036934e-06 | Valid Time: 0.004\n",
            "Epoch: 590\n",
            "Train Loss: 5.3411005410453075e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.228615580359474e-06 | Valid Time: 0.004\n",
            "Epoch: 591\n",
            "Train Loss: 5.420472120931663e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.0132149479177315e-06 | Valid Time: 0.004\n",
            "Epoch: 592\n",
            "Train Loss: 5.404769217420835e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.27728627983015e-06 | Valid Time: 0.004\n",
            "Epoch: 593\n",
            "Train Loss: 5.305458898874349e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.234580046613701e-06 | Valid Time: 0.004\n",
            "Epoch: 594\n",
            "Train Loss: 5.3537506119027965e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.055460635754571e-06 | Valid Time: 0.004\n",
            "Epoch: 595\n",
            "Train Loss: 5.3035168775750204e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.082854957232485e-06 | Valid Time: 0.005\n",
            "Epoch: 596\n",
            "Train Loss: 5.346249918147805e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.2946244320773985e-06 | Valid Time: 0.004\n",
            "Epoch: 597\n",
            "Train Loss: 5.361810485737805e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.10943835049693e-06 | Valid Time: 0.004\n",
            "Epoch: 598\n",
            "Train Loss: 5.300666043694946e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.404852347761334e-06 | Valid Time: 0.004\n",
            "Epoch: 599\n",
            "Train Loss: 5.382888116400864e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.060445121467637e-06 | Valid Time: 0.004\n",
            "Epoch: 600\n",
            "Train Loss: 5.431228896668472e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.176980837655719e-06 | Valid Time: 0.004\n",
            "Epoch: 601\n",
            "Train Loss: 5.362178580980981e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.215604576529586e-06 | Valid Time: 0.004\n",
            "Epoch: 602\n",
            "Train Loss: 5.293821641316754e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.020058099740709e-06 | Valid Time: 0.004\n",
            "Epoch: 603\n",
            "Train Loss: 5.395924426920829e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.2654517073970055e-06 | Valid Time: 0.004\n",
            "Epoch: 604\n",
            "Train Loss: 5.277431000649813e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.028704893244139e-06 | Valid Time: 0.004\n",
            "Epoch: 605\n",
            "Train Loss: 5.267519873086712e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.368793156572792e-06 | Valid Time: 0.004\n",
            "Epoch: 606\n",
            "Train Loss: 5.322894548953627e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.078907522853115e-06 | Valid Time: 0.004\n",
            "Epoch: 607\n",
            "Train Loss: 5.272749945106625e-06 | Train Time: 0.040\n",
            "Valid Loss: 3.895622967320378e-06 | Valid Time: 0.004\n",
            "Epoch: 608\n",
            "Train Loss: 5.241200392447354e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.2482947719690856e-06 | Valid Time: 0.004\n",
            "Epoch: 609\n",
            "Train Loss: 5.50229781310918e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.244125420882483e-06 | Valid Time: 0.004\n",
            "Epoch: 610\n",
            "Train Loss: 5.217819511926791e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.082884174749779e-06 | Valid Time: 0.005\n",
            "Epoch: 611\n",
            "Train Loss: 5.258880651126674e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.497742452258535e-06 | Valid Time: 0.004\n",
            "Epoch: 612\n",
            "Train Loss: 5.323635173226649e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.093081543032895e-06 | Valid Time: 0.004\n",
            "Epoch: 613\n",
            "Train Loss: 5.361819535210088e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.171742148173507e-06 | Valid Time: 0.004\n",
            "Epoch: 614\n",
            "Train Loss: 5.22211241786863e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.234593461660552e-06 | Valid Time: 0.004\n",
            "Epoch: 615\n",
            "Train Loss: 5.2688676987600045e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.434958441379422e-06 | Valid Time: 0.004\n",
            "Epoch: 616\n",
            "Train Loss: 5.3406391543830974e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.177455593890045e-06 | Valid Time: 0.004\n",
            "Epoch: 617\n",
            "Train Loss: 5.21542067417613e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.118690412724391e-06 | Valid Time: 0.005\n",
            "Epoch: 618\n",
            "Train Loss: 5.335799846761801e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.235353117110208e-06 | Valid Time: 0.004\n",
            "Epoch: 619\n",
            "Train Loss: 5.472341854328988e-06 | Train Time: 0.040\n",
            "Valid Loss: 3.954037879339012e-06 | Valid Time: 0.004\n",
            "Epoch: 620\n",
            "Train Loss: 5.254366988083347e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.331462378104334e-06 | Valid Time: 0.004\n",
            "Epoch: 621\n",
            "Train Loss: 5.26189378433628e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.330176352596027e-06 | Valid Time: 0.004\n",
            "Epoch: 622\n",
            "Train Loss: 5.2238456873965335e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.358306455287675e-06 | Valid Time: 0.004\n",
            "Epoch: 623\n",
            "Train Loss: 5.3900115744909275e-06 | Train Time: 0.044\n",
            "Valid Loss: 3.883841600327287e-06 | Valid Time: 0.004\n",
            "Epoch: 624\n",
            "Train Loss: 5.3915254738967635e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.209660801279824e-06 | Valid Time: 0.004\n",
            "Epoch: 625\n",
            "Train Loss: 5.3627860552296625e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.225526254231227e-06 | Valid Time: 0.004\n",
            "Epoch: 626\n",
            "Train Loss: 5.391271406551823e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.343084242464101e-06 | Valid Time: 0.004\n",
            "Epoch: 627\n",
            "Train Loss: 5.31507539562881e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.010544216725975e-06 | Valid Time: 0.004\n",
            "Epoch: 628\n",
            "Train Loss: 5.254518100628047e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.369890461930481e-06 | Valid Time: 0.004\n",
            "Epoch: 629\n",
            "Train Loss: 5.461671867124096e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.1792281990638e-06 | Valid Time: 0.007\n",
            "Epoch: 630\n",
            "Train Loss: 5.29845196979295e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.216228035147651e-06 | Valid Time: 0.006\n",
            "Epoch: 631\n",
            "Train Loss: 5.277618970467301e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.15930594499514e-06 | Valid Time: 0.004\n",
            "Epoch: 632\n",
            "Train Loss: 5.594982894763234e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.1269781831942964e-06 | Valid Time: 0.004\n",
            "Epoch: 633\n",
            "Train Loss: 5.228755185271439e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.05871003295033e-06 | Valid Time: 0.004\n",
            "Epoch: 634\n",
            "Train Loss: 5.4032145271776246e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.194984740024665e-06 | Valid Time: 0.004\n",
            "Epoch: 635\n",
            "Train Loss: 5.344403507479001e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.345049205767282e-06 | Valid Time: 0.004\n",
            "Epoch: 636\n",
            "Train Loss: 5.285010911393329e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.193943823338486e-06 | Valid Time: 0.004\n",
            "Epoch: 637\n",
            "Train Loss: 5.756931386713404e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.147033223489416e-06 | Valid Time: 0.004\n",
            "Epoch: 638\n",
            "Train Loss: 5.5294358844548695e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.161747710895725e-06 | Valid Time: 0.004\n",
            "Epoch: 639\n",
            "Train Loss: 5.360288650990697e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.116803893339238e-06 | Valid Time: 0.004\n",
            "Epoch: 640\n",
            "Train Loss: 5.4885078952793265e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.173737124801846e-06 | Valid Time: 0.004\n",
            "Epoch: 641\n",
            "Train Loss: 5.2549880592778205e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.1189293824572815e-06 | Valid Time: 0.004\n",
            "Epoch: 642\n",
            "Train Loss: 5.215869396124617e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.969431645600707e-06 | Valid Time: 0.004\n",
            "Epoch: 643\n",
            "Train Loss: 5.239104143583972e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.337887844485522e-06 | Valid Time: 0.004\n",
            "Epoch: 644\n",
            "Train Loss: 5.3477715027838714e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.030934064758185e-06 | Valid Time: 0.004\n",
            "Epoch: 645\n",
            "Train Loss: 5.398562962000142e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.084248530489276e-06 | Valid Time: 0.004\n",
            "Epoch: 646\n",
            "Train Loss: 5.3669588623961316e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.199258228254621e-06 | Valid Time: 0.004\n",
            "Epoch: 647\n",
            "Train Loss: 5.428901977211353e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.442995191311638e-06 | Valid Time: 0.004\n",
            "Epoch: 648\n",
            "Train Loss: 5.470958217301813e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.208701739116805e-06 | Valid Time: 0.004\n",
            "Epoch: 649\n",
            "Train Loss: 5.23544792940811e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.351448410488956e-06 | Valid Time: 0.004\n",
            "Epoch: 650\n",
            "Train Loss: 5.286580994834367e-06 | Train Time: 0.040\n",
            "Valid Loss: 3.992910137640138e-06 | Valid Time: 0.004\n",
            "Epoch: 651\n",
            "Train Loss: 5.249564446785371e-06 | Train Time: 0.049\n",
            "Valid Loss: 3.9449071209674e-06 | Valid Time: 0.004\n",
            "Epoch: 652\n",
            "Train Loss: 5.430619034996198e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.283757220946427e-06 | Valid Time: 0.004\n",
            "Epoch: 653\n",
            "Train Loss: 5.422363392426632e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.328792215346766e-06 | Valid Time: 0.004\n",
            "Epoch: 654\n",
            "Train Loss: 5.2626766319008315e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.023832957500417e-06 | Valid Time: 0.004\n",
            "Epoch: 655\n",
            "Train Loss: 5.320294553712301e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.173099796389579e-06 | Valid Time: 0.004\n",
            "Epoch: 656\n",
            "Train Loss: 5.219557101554528e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.2233618842146825e-06 | Valid Time: 0.004\n",
            "Epoch: 657\n",
            "Train Loss: 5.303989496496797e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.231152388456394e-06 | Valid Time: 0.004\n",
            "Epoch: 658\n",
            "Train Loss: 5.389740499595063e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.272632168067503e-06 | Valid Time: 0.004\n",
            "Epoch: 659\n",
            "Train Loss: 5.463632305691135e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1704315663082525e-06 | Valid Time: 0.004\n",
            "Epoch: 660\n",
            "Train Loss: 5.427567111837562e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.205968025416951e-06 | Valid Time: 0.004\n",
            "Epoch: 661\n",
            "Train Loss: 5.350669971448951e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.360764023658703e-06 | Valid Time: 0.004\n",
            "Epoch: 662\n",
            "Train Loss: 5.330160365701886e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.0398589362666826e-06 | Valid Time: 0.004\n",
            "Epoch: 663\n",
            "Train Loss: 5.2067965725655085e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.06859385293501e-06 | Valid Time: 0.004\n",
            "Epoch: 664\n",
            "Train Loss: 5.37503744908463e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.234563220961718e-06 | Valid Time: 0.004\n",
            "Epoch: 665\n",
            "Train Loss: 5.336376329978521e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.0115128285833634e-06 | Valid Time: 0.004\n",
            "Epoch: 666\n",
            "Train Loss: 5.2556451237251165e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.2802935240615625e-06 | Valid Time: 0.004\n",
            "Epoch: 667\n",
            "Train Loss: 5.22770833413233e-06 | Train Time: 0.044\n",
            "Valid Loss: 3.888627816195367e-06 | Valid Time: 0.004\n",
            "Epoch: 668\n",
            "Train Loss: 5.3872934131504735e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.027666022921039e-06 | Valid Time: 0.004\n",
            "Epoch: 669\n",
            "Train Loss: 5.3502172931985115e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.190189656583243e-06 | Valid Time: 0.004\n",
            "Epoch: 670\n",
            "Train Loss: 5.254046618574648e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.090184120286722e-06 | Valid Time: 0.004\n",
            "Epoch: 671\n",
            "Train Loss: 5.164944195712451e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.118363449379103e-06 | Valid Time: 0.004\n",
            "Epoch: 672\n",
            "Train Loss: 5.395664356910857e-06 | Train Time: 0.047\n",
            "Valid Loss: 3.981201757596864e-06 | Valid Time: 0.004\n",
            "Epoch: 673\n",
            "Train Loss: 5.401894350143266e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.0666046743353945e-06 | Valid Time: 0.004\n",
            "Epoch: 674\n",
            "Train Loss: 5.296351901051821e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.421988933245302e-06 | Valid Time: 0.004\n",
            "Epoch: 675\n",
            "Train Loss: 5.354985069061513e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.195786459604278e-06 | Valid Time: 0.004\n",
            "Epoch: 676\n",
            "Train Loss: 5.275107105262577e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.939979933420545e-06 | Valid Time: 0.004\n",
            "Epoch: 677\n",
            "Train Loss: 5.417347279035312e-06 | Train Time: 0.040\n",
            "Valid Loss: 3.997203407379857e-06 | Valid Time: 0.005\n",
            "Epoch: 678\n",
            "Train Loss: 5.396177152761084e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.275608944226406e-06 | Valid Time: 0.004\n",
            "Epoch: 679\n",
            "Train Loss: 5.269125927043205e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.534320851234952e-06 | Valid Time: 0.004\n",
            "Epoch: 680\n",
            "Train Loss: 5.258255669104983e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.299793431528087e-06 | Valid Time: 0.004\n",
            "Epoch: 681\n",
            "Train Loss: 5.258027749732719e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.183411419944605e-06 | Valid Time: 0.004\n",
            "Epoch: 682\n",
            "Train Loss: 5.3480508540815205e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.033469508613052e-06 | Valid Time: 0.004\n",
            "Epoch: 683\n",
            "Train Loss: 5.392897469391755e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.2437352476554224e-06 | Valid Time: 0.004\n",
            "Epoch: 684\n",
            "Train Loss: 5.206326773077308e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.9359063066513045e-06 | Valid Time: 0.004\n",
            "Epoch: 685\n",
            "Train Loss: 5.325354504748248e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.471881652534648e-06 | Valid Time: 0.004\n",
            "Epoch: 686\n",
            "Train Loss: 5.426768643701507e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.074556727573508e-06 | Valid Time: 0.004\n",
            "Epoch: 687\n",
            "Train Loss: 5.219265358391567e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.124371571379015e-06 | Valid Time: 0.004\n",
            "Epoch: 688\n",
            "Train Loss: 5.245074817139539e-06 | Train Time: 0.067\n",
            "Valid Loss: 4.155700707997312e-06 | Valid Time: 0.004\n",
            "Epoch: 689\n",
            "Train Loss: 5.199168344915961e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.934601750188449e-06 | Valid Time: 0.004\n",
            "Epoch: 690\n",
            "Train Loss: 5.208514062360337e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.114749117434258e-06 | Valid Time: 0.004\n",
            "Epoch: 691\n",
            "Train Loss: 5.422764093054866e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.204961896903114e-06 | Valid Time: 0.004\n",
            "Epoch: 692\n",
            "Train Loss: 5.627690097753657e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.307791755309154e-06 | Valid Time: 0.004\n",
            "Epoch: 693\n",
            "Train Loss: 5.2166504019623975e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.171174623479601e-06 | Valid Time: 0.004\n",
            "Epoch: 694\n",
            "Train Loss: 5.524747143681452e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.842401497422543e-06 | Valid Time: 0.006\n",
            "Epoch: 695\n",
            "Train Loss: 5.3657684929930834e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.16821922044619e-06 | Valid Time: 0.004\n",
            "Epoch: 696\n",
            "Train Loss: 5.349031061996356e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.1630303257989e-06 | Valid Time: 0.004\n",
            "Epoch: 697\n",
            "Train Loss: 5.31842636064539e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.061631784679776e-06 | Valid Time: 0.004\n",
            "Epoch: 698\n",
            "Train Loss: 5.344962437447975e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.325612621869368e-06 | Valid Time: 0.004\n",
            "Epoch: 699\n",
            "Train Loss: 5.235385765445244e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.102867251276621e-06 | Valid Time: 0.004\n",
            "Epoch: 700\n",
            "Train Loss: 5.275834837448201e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.126246949454071e-06 | Valid Time: 0.004\n",
            "Epoch: 701\n",
            "Train Loss: 5.473611554407398e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.116499212614144e-06 | Valid Time: 0.004\n",
            "Epoch: 702\n",
            "Train Loss: 5.263087814455503e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.119402092328528e-06 | Valid Time: 0.004\n",
            "Epoch: 703\n",
            "Train Loss: 5.372059467845247e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.2652895899664145e-06 | Valid Time: 0.005\n",
            "Epoch: 704\n",
            "Train Loss: 5.209207051848352e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.275867240721709e-06 | Valid Time: 0.005\n",
            "Epoch: 705\n",
            "Train Loss: 5.212440555624198e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.169580734014744e-06 | Valid Time: 0.005\n",
            "Epoch: 706\n",
            "Train Loss: 5.2560788390110245e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.188668071947177e-06 | Valid Time: 0.004\n",
            "Epoch: 707\n",
            "Train Loss: 5.3151634801906765e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.266857899892784e-06 | Valid Time: 0.004\n",
            "Epoch: 708\n",
            "Train Loss: 5.372841678763507e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.182852990197716e-06 | Valid Time: 0.004\n",
            "Epoch: 709\n",
            "Train Loss: 5.22623456618021e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.198908754915465e-06 | Valid Time: 0.004\n",
            "Epoch: 710\n",
            "Train Loss: 5.21963254414004e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.1013338432094315e-06 | Valid Time: 0.005\n",
            "Epoch: 711\n",
            "Train Loss: 5.225941299613623e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.192689402771066e-06 | Valid Time: 0.004\n",
            "Epoch: 712\n",
            "Train Loss: 5.411203528637998e-06 | Train Time: 0.054\n",
            "Valid Loss: 4.18947229263722e-06 | Valid Time: 0.004\n",
            "Epoch: 713\n",
            "Train Loss: 5.29279252532433e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.057549176650355e-06 | Valid Time: 0.005\n",
            "Epoch: 714\n",
            "Train Loss: 5.266211314847169e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.0710935991228325e-06 | Valid Time: 0.004\n",
            "Epoch: 715\n",
            "Train Loss: 5.343958105186175e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.3924391093241866e-06 | Valid Time: 0.004\n",
            "Epoch: 716\n",
            "Train Loss: 5.4007748985895885e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.3400948470662115e-06 | Valid Time: 0.004\n",
            "Epoch: 717\n",
            "Train Loss: 5.311100721883122e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.138885287829908e-06 | Valid Time: 0.004\n",
            "Epoch: 718\n",
            "Train Loss: 5.163906962479814e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.227790896038641e-06 | Valid Time: 0.004\n",
            "Epoch: 719\n",
            "Train Loss: 5.317287650541402e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.365969175523787e-06 | Valid Time: 0.006\n",
            "Epoch: 720\n",
            "Train Loss: 5.285402494337177e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.095479425814119e-06 | Valid Time: 0.007\n",
            "Epoch: 721\n",
            "Train Loss: 5.29174958501244e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.028268449474126e-06 | Valid Time: 0.005\n",
            "Epoch: 722\n",
            "Train Loss: 5.4600220664724475e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.147862227910082e-06 | Valid Time: 0.004\n",
            "Epoch: 723\n",
            "Train Loss: 5.261872888695507e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.063641654283856e-06 | Valid Time: 0.004\n",
            "Epoch: 724\n",
            "Train Loss: 5.54053310679592e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.362778213362617e-06 | Valid Time: 0.009\n",
            "Epoch: 725\n",
            "Train Loss: 5.508693584488356e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.474026241041429e-06 | Valid Time: 0.004\n",
            "Epoch: 726\n",
            "Train Loss: 5.395054358814377e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.014284968434367e-06 | Valid Time: 0.004\n",
            "Epoch: 727\n",
            "Train Loss: 5.266722678243241e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.242171598889399e-06 | Valid Time: 0.004\n",
            "Epoch: 728\n",
            "Train Loss: 5.593505670731247e-06 | Train Time: 0.045\n",
            "Valid Loss: 3.984976046922384e-06 | Valid Time: 0.004\n",
            "Epoch: 729\n",
            "Train Loss: 5.338393748388626e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.221051312924828e-06 | Valid Time: 0.005\n",
            "Epoch: 730\n",
            "Train Loss: 5.404076159720717e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.153029976805556e-06 | Valid Time: 0.004\n",
            "Epoch: 731\n",
            "Train Loss: 5.228475765761687e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1201831209036754e-06 | Valid Time: 0.004\n",
            "Epoch: 732\n",
            "Train Loss: 5.366130289985449e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.113071099709487e-06 | Valid Time: 0.004\n",
            "Epoch: 733\n",
            "Train Loss: 5.188663772059954e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.203875050734496e-06 | Valid Time: 0.004\n",
            "Epoch: 734\n",
            "Train Loss: 5.40598757652333e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.11012297263369e-06 | Valid Time: 0.004\n",
            "Epoch: 735\n",
            "Train Loss: 5.3597378382619356e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.204562628729036e-06 | Valid Time: 0.004\n",
            "Epoch: 736\n",
            "Train Loss: 5.276456113278982e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.885951173288049e-06 | Valid Time: 0.004\n",
            "Epoch: 737\n",
            "Train Loss: 5.158392582416127e-06 | Train Time: 0.047\n",
            "Valid Loss: 3.765958240364853e-06 | Valid Time: 0.004\n",
            "Epoch: 738\n",
            "Train Loss: 5.442560450319434e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.494495442486368e-06 | Valid Time: 0.004\n",
            "Epoch: 739\n",
            "Train Loss: 5.273111241876904e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.079435029780143e-06 | Valid Time: 0.004\n",
            "Epoch: 740\n",
            "Train Loss: 5.413244366536674e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.114757530260249e-06 | Valid Time: 0.004\n",
            "Epoch: 741\n",
            "Train Loss: 5.20305522968556e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.223512860335177e-06 | Valid Time: 0.006\n",
            "Epoch: 742\n",
            "Train Loss: 5.480359914145083e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.255923613527557e-06 | Valid Time: 0.004\n",
            "Epoch: 743\n",
            "Train Loss: 5.5112478094088145e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.000350031674316e-06 | Valid Time: 0.004\n",
            "Epoch: 744\n",
            "Train Loss: 5.183726921131893e-06 | Train Time: 0.045\n",
            "Valid Loss: 3.985295847996895e-06 | Valid Time: 0.004\n",
            "Epoch: 745\n",
            "Train Loss: 5.293903382153076e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.97620215153438e-06 | Valid Time: 0.004\n",
            "Epoch: 746\n",
            "Train Loss: 5.555872371587612e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.220979462843388e-06 | Valid Time: 0.006\n",
            "Epoch: 747\n",
            "Train Loss: 5.312713415150938e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.117781372769969e-06 | Valid Time: 0.004\n",
            "Epoch: 748\n",
            "Train Loss: 5.358019166123995e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.945499884139281e-06 | Valid Time: 0.004\n",
            "Epoch: 749\n",
            "Train Loss: 5.380782886277302e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.078394340467639e-06 | Valid Time: 0.004\n",
            "Epoch: 750\n",
            "Train Loss: 5.263464458948874e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.019991138193291e-06 | Valid Time: 0.005\n",
            "Epoch: 751\n",
            "Train Loss: 5.180743551136402e-06 | Train Time: 0.082\n",
            "Valid Loss: 4.0307148765350576e-06 | Valid Time: 0.007\n",
            "Epoch: 752\n",
            "Train Loss: 5.372777832235443e-06 | Train Time: 0.089\n",
            "Valid Loss: 4.315628530093818e-06 | Valid Time: 0.009\n",
            "Epoch: 753\n",
            "Train Loss: 5.4042150850364125e-06 | Train Time: 0.054\n",
            "Valid Loss: 4.29563579018577e-06 | Valid Time: 0.004\n",
            "Epoch: 754\n",
            "Train Loss: 5.174404373065045e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.304911385588639e-06 | Valid Time: 0.004\n",
            "Epoch: 755\n",
            "Train Loss: 5.257199245534139e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.99088867197861e-06 | Valid Time: 0.004\n",
            "Epoch: 756\n",
            "Train Loss: 5.165187144484662e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.122852487853379e-06 | Valid Time: 0.006\n",
            "Epoch: 757\n",
            "Train Loss: 5.165393508832494e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.107423137611477e-06 | Valid Time: 0.004\n",
            "Epoch: 758\n",
            "Train Loss: 5.3211515478324145e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.233800609654281e-06 | Valid Time: 0.007\n",
            "Epoch: 759\n",
            "Train Loss: 5.3914307045488385e-06 | Train Time: 0.061\n",
            "Valid Loss: 3.8453591741927085e-06 | Valid Time: 0.007\n",
            "Epoch: 760\n",
            "Train Loss: 5.450800972539582e-06 | Train Time: 0.067\n",
            "Valid Loss: 4.038800398120657e-06 | Valid Time: 0.007\n",
            "Epoch: 761\n",
            "Train Loss: 5.354660925149801e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.154389671384706e-06 | Valid Time: 0.007\n",
            "Epoch: 762\n",
            "Train Loss: 5.488393594532681e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.324602400629374e-06 | Valid Time: 0.005\n",
            "Epoch: 763\n",
            "Train Loss: 5.39841807949415e-06 | Train Time: 0.060\n",
            "Valid Loss: 3.847582888738543e-06 | Valid Time: 0.006\n",
            "Epoch: 764\n",
            "Train Loss: 5.340484585758532e-06 | Train Time: 0.061\n",
            "Valid Loss: 4.240801445121178e-06 | Valid Time: 0.005\n",
            "Epoch: 765\n",
            "Train Loss: 5.273478836897993e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.109870360480272e-06 | Valid Time: 0.005\n",
            "Epoch: 766\n",
            "Train Loss: 5.655443646901403e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.217357400193578e-06 | Valid Time: 0.005\n",
            "Epoch: 767\n",
            "Train Loss: 5.181483197702619e-06 | Train Time: 0.057\n",
            "Valid Loss: 3.924868792637426e-06 | Valid Time: 0.006\n",
            "Epoch: 768\n",
            "Train Loss: 5.2676213272206954e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.324018618717673e-06 | Valid Time: 0.006\n",
            "Epoch: 769\n",
            "Train Loss: 5.334577531357354e-06 | Train Time: 0.068\n",
            "Valid Loss: 4.214972022964503e-06 | Valid Time: 0.005\n",
            "Epoch: 770\n",
            "Train Loss: 5.4056336011854e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.154308044235222e-06 | Valid Time: 0.005\n",
            "Epoch: 771\n",
            "Train Loss: 5.160471732779115e-06 | Train Time: 0.054\n",
            "Valid Loss: 4.280094458408712e-06 | Valid Time: 0.006\n",
            "Epoch: 772\n",
            "Train Loss: 5.263880825623346e-06 | Train Time: 0.061\n",
            "Valid Loss: 4.155994020038634e-06 | Valid Time: 0.006\n",
            "Epoch: 773\n",
            "Train Loss: 5.305451531967265e-06 | Train Time: 0.059\n",
            "Valid Loss: 4.28928626661218e-06 | Valid Time: 0.006\n",
            "Epoch: 774\n",
            "Train Loss: 5.174766579330026e-06 | Train Time: 0.059\n",
            "Valid Loss: 3.9766325699019944e-06 | Valid Time: 0.006\n",
            "Epoch: 775\n",
            "Train Loss: 5.56017971575784e-06 | Train Time: 0.058\n",
            "Valid Loss: 4.238013843860244e-06 | Valid Time: 0.006\n",
            "Epoch: 776\n",
            "Train Loss: 5.367857784221996e-06 | Train Time: 0.060\n",
            "Valid Loss: 3.800202193815494e-06 | Valid Time: 0.006\n",
            "Epoch: 777\n",
            "Train Loss: 5.2190104497640276e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.163235189480474e-06 | Valid Time: 0.005\n",
            "Epoch: 778\n",
            "Train Loss: 5.126297742208407e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.117561957173166e-06 | Valid Time: 0.005\n",
            "Epoch: 779\n",
            "Train Loss: 5.271531722428335e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.262815537003917e-06 | Valid Time: 0.005\n",
            "Epoch: 780\n",
            "Train Loss: 5.290372632771323e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.130253728362732e-06 | Valid Time: 0.005\n",
            "Epoch: 781\n",
            "Train Loss: 5.5661864735157e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.479085305320041e-06 | Valid Time: 0.006\n",
            "Epoch: 782\n",
            "Train Loss: 5.248350726105855e-06 | Train Time: 0.064\n",
            "Valid Loss: 4.284997885406483e-06 | Valid Time: 0.006\n",
            "Epoch: 783\n",
            "Train Loss: 5.358051112125395e-06 | Train Time: 0.061\n",
            "Valid Loss: 4.195357178105041e-06 | Valid Time: 0.009\n",
            "Epoch: 784\n",
            "Train Loss: 5.5349604508592165e-06 | Train Time: 0.062\n",
            "Valid Loss: 4.072060164617142e-06 | Valid Time: 0.006\n",
            "Epoch: 785\n",
            "Train Loss: 5.4055611144576686e-06 | Train Time: 0.071\n",
            "Valid Loss: 4.454393547348445e-06 | Valid Time: 0.008\n",
            "Epoch: 786\n",
            "Train Loss: 5.216857812229137e-06 | Train Time: 0.067\n",
            "Valid Loss: 4.031982598462491e-06 | Valid Time: 0.007\n",
            "Epoch: 787\n",
            "Train Loss: 5.51065018044028e-06 | Train Time: 0.067\n",
            "Valid Loss: 4.03104706947488e-06 | Valid Time: 0.007\n",
            "Epoch: 788\n",
            "Train Loss: 5.291375941851584e-06 | Train Time: 0.059\n",
            "Valid Loss: 3.969859449171054e-06 | Valid Time: 0.006\n",
            "Epoch: 789\n",
            "Train Loss: 5.430438795883674e-06 | Train Time: 0.067\n",
            "Valid Loss: 4.000971784989815e-06 | Valid Time: 0.008\n",
            "Epoch: 790\n",
            "Train Loss: 5.335353216651129e-06 | Train Time: 0.075\n",
            "Valid Loss: 4.113080649403855e-06 | Valid Time: 0.006\n",
            "Epoch: 791\n",
            "Train Loss: 5.278142111819761e-06 | Train Time: 0.062\n",
            "Valid Loss: 4.20606238549226e-06 | Valid Time: 0.007\n",
            "Epoch: 792\n",
            "Train Loss: 5.3790518222740505e-06 | Train Time: 0.064\n",
            "Valid Loss: 3.888873493451683e-06 | Valid Time: 0.007\n",
            "Epoch: 793\n",
            "Train Loss: 5.1636110811159595e-06 | Train Time: 0.070\n",
            "Valid Loss: 4.139358907195856e-06 | Valid Time: 0.006\n",
            "Epoch: 794\n",
            "Train Loss: 5.263329080662516e-06 | Train Time: 0.062\n",
            "Valid Loss: 4.158601086601266e-06 | Valid Time: 0.007\n",
            "Epoch: 795\n",
            "Train Loss: 5.160835917195072e-06 | Train Time: 0.064\n",
            "Valid Loss: 4.32409660788835e-06 | Valid Time: 0.004\n",
            "Epoch: 796\n",
            "Train Loss: 5.399876613410015e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.029057095067401e-06 | Valid Time: 0.004\n",
            "Epoch: 797\n",
            "Train Loss: 5.238692619968788e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.175276899331948e-06 | Valid Time: 0.004\n",
            "Epoch: 798\n",
            "Train Loss: 5.294382003739884e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.091384653293062e-06 | Valid Time: 0.004\n",
            "Epoch: 799\n",
            "Train Loss: 5.417595457402058e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.21546064899303e-06 | Valid Time: 0.004\n",
            "Epoch: 800\n",
            "Train Loss: 5.377501906878024e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.047328843626019e-06 | Valid Time: 0.007\n",
            "Epoch: 801\n",
            "Train Loss: 5.2134912266410535e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.2712633785413345e-06 | Valid Time: 0.004\n",
            "Epoch: 802\n",
            "Train Loss: 5.24685663094715e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.3072062680948875e-06 | Valid Time: 0.004\n",
            "Epoch: 803\n",
            "Train Loss: 5.3420173571794296e-06 | Train Time: 0.040\n",
            "Valid Loss: 3.967035127061536e-06 | Valid Time: 0.004\n",
            "Epoch: 804\n",
            "Train Loss: 5.25305893006589e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.199355316814035e-06 | Valid Time: 0.004\n",
            "Epoch: 805\n",
            "Train Loss: 5.235786943558196e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.074113803653745e-06 | Valid Time: 0.004\n",
            "Epoch: 806\n",
            "Train Loss: 5.342334816305083e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.015131025880692e-06 | Valid Time: 0.004\n",
            "Epoch: 807\n",
            "Train Loss: 5.17938044595212e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.1713888094818685e-06 | Valid Time: 0.004\n",
            "Epoch: 808\n",
            "Train Loss: 5.207425260778109e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.114158400625456e-06 | Valid Time: 0.004\n",
            "Epoch: 809\n",
            "Train Loss: 5.184218321119261e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.965853011322906e-06 | Valid Time: 0.004\n",
            "Epoch: 810\n",
            "Train Loss: 5.4156097803570445e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.061542085764813e-06 | Valid Time: 0.004\n",
            "Epoch: 811\n",
            "Train Loss: 5.398943085310748e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.124882252654061e-06 | Valid Time: 0.004\n",
            "Epoch: 812\n",
            "Train Loss: 5.252919982012827e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.30081172453356e-06 | Valid Time: 0.004\n",
            "Epoch: 813\n",
            "Train Loss: 5.396436540650029e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.23976598540321e-06 | Valid Time: 0.004\n",
            "Epoch: 814\n",
            "Train Loss: 5.2341307764436355e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.3383306547184475e-06 | Valid Time: 0.004\n",
            "Epoch: 815\n",
            "Train Loss: 5.425454537544283e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.28620057846274e-06 | Valid Time: 0.004\n",
            "Epoch: 816\n",
            "Train Loss: 5.374038846639451e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.265765142008604e-06 | Valid Time: 0.004\n",
            "Epoch: 817\n",
            "Train Loss: 5.213840131546021e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.350099175098876e-06 | Valid Time: 0.004\n",
            "Epoch: 818\n",
            "Train Loss: 5.259606541585526e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.9764361190464115e-06 | Valid Time: 0.004\n",
            "Epoch: 819\n",
            "Train Loss: 5.308435402184841e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.176630227448186e-06 | Valid Time: 0.004\n",
            "Epoch: 820\n",
            "Train Loss: 5.359567694540601e-06 | Train Time: 0.053\n",
            "Valid Loss: 4.5139028088669875e-06 | Valid Time: 0.004\n",
            "Epoch: 821\n",
            "Train Loss: 5.2628567345891495e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.281914016246446e-06 | Valid Time: 0.004\n",
            "Epoch: 822\n",
            "Train Loss: 5.3833051197216266e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.296360771149921e-06 | Valid Time: 0.006\n",
            "Epoch: 823\n",
            "Train Loss: 5.350542642190703e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.027097588732431e-06 | Valid Time: 0.004\n",
            "Epoch: 824\n",
            "Train Loss: 5.291322713674162e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.8058658446971094e-06 | Valid Time: 0.004\n",
            "Epoch: 825\n",
            "Train Loss: 5.19092302511126e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.424959229254455e-06 | Valid Time: 0.004\n",
            "Epoch: 826\n",
            "Train Loss: 5.334600677997514e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.244881438353332e-06 | Valid Time: 0.004\n",
            "Epoch: 827\n",
            "Train Loss: 5.149129219716997e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.280291818758997e-06 | Valid Time: 0.004\n",
            "Epoch: 828\n",
            "Train Loss: 5.318376406648895e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.041363354190253e-06 | Valid Time: 0.004\n",
            "Epoch: 829\n",
            "Train Loss: 5.232267085375497e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.992151164311508e-06 | Valid Time: 0.006\n",
            "Epoch: 830\n",
            "Train Loss: 5.355304188014997e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.098911176697584e-06 | Valid Time: 0.004\n",
            "Epoch: 831\n",
            "Train Loss: 5.443875670607667e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.223288442517514e-06 | Valid Time: 0.004\n",
            "Epoch: 832\n",
            "Train Loss: 5.382787458074745e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.11468863603659e-06 | Valid Time: 0.005\n",
            "Epoch: 833\n",
            "Train Loss: 5.234147602095618e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.238048404658912e-06 | Valid Time: 0.004\n",
            "Epoch: 834\n",
            "Train Loss: 5.290950548442197e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.903724859810609e-06 | Valid Time: 0.004\n",
            "Epoch: 835\n",
            "Train Loss: 5.2231718655093575e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.108482244191691e-06 | Valid Time: 0.004\n",
            "Epoch: 836\n",
            "Train Loss: 5.2093110525675e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.457548470782058e-06 | Valid Time: 0.004\n",
            "Epoch: 837\n",
            "Train Loss: 5.1955317985630245e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.247112428856781e-06 | Valid Time: 0.004\n",
            "Epoch: 838\n",
            "Train Loss: 5.451236415865424e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.16109128309472e-06 | Valid Time: 0.006\n",
            "Epoch: 839\n",
            "Train Loss: 5.17426442456781e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.158330057180137e-06 | Valid Time: 0.004\n",
            "Epoch: 840\n",
            "Train Loss: 5.325612960405124e-06 | Train Time: 0.047\n",
            "Valid Loss: 3.966600957028277e-06 | Valid Time: 0.004\n",
            "Epoch: 841\n",
            "Train Loss: 5.376888202590635e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.2344208850408904e-06 | Valid Time: 0.004\n",
            "Epoch: 842\n",
            "Train Loss: 5.292479409035878e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.050683060086158e-06 | Valid Time: 0.005\n",
            "Epoch: 843\n",
            "Train Loss: 5.206287892178807e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.16822717852483e-06 | Valid Time: 0.004\n",
            "Epoch: 844\n",
            "Train Loss: 5.33477052613307e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.040886551592848e-06 | Valid Time: 0.004\n",
            "Epoch: 845\n",
            "Train Loss: 5.2408069677767346e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.2399422000016784e-06 | Valid Time: 0.004\n",
            "Epoch: 846\n",
            "Train Loss: 5.256162739897263e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.312351393309655e-06 | Valid Time: 0.004\n",
            "Epoch: 847\n",
            "Train Loss: 5.1955391427327415e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.36953075677593e-06 | Valid Time: 0.004\n",
            "Epoch: 848\n",
            "Train Loss: 5.265571621748677e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.109550673092599e-06 | Valid Time: 0.004\n",
            "Epoch: 849\n",
            "Train Loss: 5.26603585058183e-06 | Train Time: 0.049\n",
            "Valid Loss: 3.9484419858126785e-06 | Valid Time: 0.004\n",
            "Epoch: 850\n",
            "Train Loss: 5.369431050894491e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.351112011136138e-06 | Valid Time: 0.004\n",
            "Epoch: 851\n",
            "Train Loss: 5.121936669638671e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.883173690155672e-06 | Valid Time: 0.004\n",
            "Epoch: 852\n",
            "Train Loss: 5.1737426247200345e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.171851969658746e-06 | Valid Time: 0.005\n",
            "Epoch: 853\n",
            "Train Loss: 5.210293988966441e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.896243242706987e-06 | Valid Time: 0.004\n",
            "Epoch: 854\n",
            "Train Loss: 5.202100146561861e-06 | Train Time: 0.040\n",
            "Valid Loss: 3.847236598630843e-06 | Valid Time: 0.004\n",
            "Epoch: 855\n",
            "Train Loss: 5.250709955362254e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.29300018822687e-06 | Valid Time: 0.004\n",
            "Epoch: 856\n",
            "Train Loss: 5.232487774264883e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.207424126434489e-06 | Valid Time: 0.004\n",
            "Epoch: 857\n",
            "Train Loss: 5.242887095846527e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.0820480080583366e-06 | Valid Time: 0.004\n",
            "Epoch: 858\n",
            "Train Loss: 5.444953353617166e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.048708888149122e-06 | Valid Time: 0.004\n",
            "Epoch: 859\n",
            "Train Loss: 5.2725312798429515e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.980693691119086e-06 | Valid Time: 0.006\n",
            "Epoch: 860\n",
            "Train Loss: 5.2475395705187115e-06 | Train Time: 0.052\n",
            "Valid Loss: 4.327677743276581e-06 | Valid Time: 0.004\n",
            "Epoch: 861\n",
            "Train Loss: 5.227801716500835e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.3106379052915145e-06 | Valid Time: 0.006\n",
            "Epoch: 862\n",
            "Train Loss: 5.153291112947045e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.9739760495649534e-06 | Valid Time: 0.004\n",
            "Epoch: 863\n",
            "Train Loss: 5.307385299602174e-06 | Train Time: 0.062\n",
            "Valid Loss: 4.234882226228365e-06 | Valid Time: 0.004\n",
            "Epoch: 864\n",
            "Train Loss: 5.261015257929103e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.41751967628079e-06 | Valid Time: 0.004\n",
            "Epoch: 865\n",
            "Train Loss: 5.170278473087819e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.042281716465368e-06 | Valid Time: 0.004\n",
            "Epoch: 866\n",
            "Train Loss: 5.305596232574317e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.8062190697019105e-06 | Valid Time: 0.004\n",
            "Epoch: 867\n",
            "Train Loss: 5.171854036234436e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.410495762385835e-06 | Valid Time: 0.004\n",
            "Epoch: 868\n",
            "Train Loss: 5.4358189345293795e-06 | Train Time: 0.056\n",
            "Valid Loss: 3.8635652117591235e-06 | Valid Time: 0.004\n",
            "Epoch: 869\n",
            "Train Loss: 5.30862614596117e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.323775669945462e-06 | Valid Time: 0.004\n",
            "Epoch: 870\n",
            "Train Loss: 5.285183874548238e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.011050805274863e-06 | Valid Time: 0.004\n",
            "Epoch: 871\n",
            "Train Loss: 5.303509215082158e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.918564743798925e-06 | Valid Time: 0.004\n",
            "Epoch: 872\n",
            "Train Loss: 5.3263926929503215e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.196673671685858e-06 | Valid Time: 0.004\n",
            "Epoch: 873\n",
            "Train Loss: 5.293250796967186e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.1399994188395794e-06 | Valid Time: 0.004\n",
            "Epoch: 874\n",
            "Train Loss: 5.283267728373175e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.438910991666489e-06 | Valid Time: 0.004\n",
            "Epoch: 875\n",
            "Train Loss: 5.170967870071763e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.889565505232895e-06 | Valid Time: 0.004\n",
            "Epoch: 876\n",
            "Train Loss: 5.348137847249745e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.034744733871776e-06 | Valid Time: 0.007\n",
            "Epoch: 877\n",
            "Train Loss: 5.281961307446181e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.178283461442334e-06 | Valid Time: 0.005\n",
            "Epoch: 878\n",
            "Train Loss: 5.348739705368644e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.246109710948076e-06 | Valid Time: 0.005\n",
            "Epoch: 879\n",
            "Train Loss: 5.21537706390518e-06 | Train Time: 0.045\n",
            "Valid Loss: 3.9812051682019955e-06 | Valid Time: 0.004\n",
            "Epoch: 880\n",
            "Train Loss: 5.408421520769479e-06 | Train Time: 0.044\n",
            "Valid Loss: 3.9922849737195065e-06 | Valid Time: 0.004\n",
            "Epoch: 881\n",
            "Train Loss: 5.348502736524097e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.943842102671624e-06 | Valid Time: 0.004\n",
            "Epoch: 882\n",
            "Train Loss: 5.323118170963426e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.122847713006195e-06 | Valid Time: 0.004\n",
            "Epoch: 883\n",
            "Train Loss: 5.3890494427832895e-06 | Train Time: 0.055\n",
            "Valid Loss: 4.132364665565547e-06 | Valid Time: 0.004\n",
            "Epoch: 884\n",
            "Train Loss: 5.262073796075129e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.8722478166164365e-06 | Valid Time: 0.004\n",
            "Epoch: 885\n",
            "Train Loss: 5.3528901389654495e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.253649649399449e-06 | Valid Time: 0.004\n",
            "Epoch: 886\n",
            "Train Loss: 5.223684956945362e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.425655902196013e-06 | Valid Time: 0.005\n",
            "Epoch: 887\n",
            "Train Loss: 5.205801903684914e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.195951078145299e-06 | Valid Time: 0.006\n",
            "Epoch: 888\n",
            "Train Loss: 5.2761014103452904e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.209730832371861e-06 | Valid Time: 0.004\n",
            "Epoch: 889\n",
            "Train Loss: 5.295959022078023e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.065457005708595e-06 | Valid Time: 0.005\n",
            "Epoch: 890\n",
            "Train Loss: 5.261349497232004e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1755217807804e-06 | Valid Time: 0.004\n",
            "Epoch: 891\n",
            "Train Loss: 5.189729563426226e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.152149358560564e-06 | Valid Time: 0.004\n",
            "Epoch: 892\n",
            "Train Loss: 5.389981242842623e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.0840907331585186e-06 | Valid Time: 0.004\n",
            "Epoch: 893\n",
            "Train Loss: 5.401764701673528e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.30216095992364e-06 | Valid Time: 0.005\n",
            "Epoch: 894\n",
            "Train Loss: 5.2770243200939145e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.340891450738127e-06 | Valid Time: 0.004\n",
            "Epoch: 895\n",
            "Train Loss: 5.377742263590335e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.943855972465826e-06 | Valid Time: 0.004\n",
            "Epoch: 896\n",
            "Train Loss: 5.362981710277381e-06 | Train Time: 0.048\n",
            "Valid Loss: 3.942308580917597e-06 | Valid Time: 0.004\n",
            "Epoch: 897\n",
            "Train Loss: 5.2179923613948634e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.4039044269084116e-06 | Valid Time: 0.004\n",
            "Epoch: 898\n",
            "Train Loss: 5.28338287040242e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1982007132901344e-06 | Valid Time: 0.004\n",
            "Epoch: 899\n",
            "Train Loss: 5.241950202616863e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.238369001541287e-06 | Valid Time: 0.004\n",
            "Epoch: 900\n",
            "Train Loss: 5.213224289946083e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.253207862348063e-06 | Valid Time: 0.004\n",
            "Epoch: 901\n",
            "Train Loss: 5.225697850619326e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.021161885248148e-06 | Valid Time: 0.004\n",
            "Epoch: 902\n",
            "Train Loss: 5.417071429292264e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.030102104479738e-06 | Valid Time: 0.004\n",
            "Epoch: 903\n",
            "Train Loss: 5.3937568509354605e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.347835897533514e-06 | Valid Time: 0.007\n",
            "Epoch: 904\n",
            "Train Loss: 5.327842291080742e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.154195721639553e-06 | Valid Time: 0.004\n",
            "Epoch: 905\n",
            "Train Loss: 5.16965301358141e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.005605433121673e-06 | Valid Time: 0.004\n",
            "Epoch: 906\n",
            "Train Loss: 5.392347657107166e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.000747708232666e-06 | Valid Time: 0.004\n",
            "Epoch: 907\n",
            "Train Loss: 5.284887993184384e-06 | Train Time: 0.046\n",
            "Valid Loss: 3.941154204767372e-06 | Valid Time: 0.004\n",
            "Epoch: 908\n",
            "Train Loss: 5.2299946901257496e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.177371465630131e-06 | Valid Time: 0.004\n",
            "Epoch: 909\n",
            "Train Loss: 5.179619802220259e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.985310286225285e-06 | Valid Time: 0.004\n",
            "Epoch: 910\n",
            "Train Loss: 5.34830021479138e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.1787886857491685e-06 | Valid Time: 0.004\n",
            "Epoch: 911\n",
            "Train Loss: 5.314762665875605e-06 | Train Time: 0.050\n",
            "Valid Loss: 3.981273948738817e-06 | Valid Time: 0.004\n",
            "Epoch: 912\n",
            "Train Loss: 5.373203498493239e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.239822146701044e-06 | Valid Time: 0.004\n",
            "Epoch: 913\n",
            "Train Loss: 5.1639030516525965e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.019189191240002e-06 | Valid Time: 0.004\n",
            "Epoch: 914\n",
            "Train Loss: 5.3955717248754805e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.194713028482511e-06 | Valid Time: 0.004\n",
            "Epoch: 915\n",
            "Train Loss: 5.487699013428937e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.18564809478994e-06 | Valid Time: 0.004\n",
            "Epoch: 916\n",
            "Train Loss: 5.191644913793425e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.353180770522158e-06 | Valid Time: 0.004\n",
            "Epoch: 917\n",
            "Train Loss: 5.322353467818175e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.121781785215717e-06 | Valid Time: 0.004\n",
            "Epoch: 918\n",
            "Train Loss: 5.166041955817491e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.056111492900527e-06 | Valid Time: 0.006\n",
            "Epoch: 919\n",
            "Train Loss: 5.238048993305711e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.96733878460509e-06 | Valid Time: 0.004\n",
            "Epoch: 920\n",
            "Train Loss: 5.322794822859578e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.870764089697332e-06 | Valid Time: 0.004\n",
            "Epoch: 921\n",
            "Train Loss: 5.228434088166978e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.125281066080788e-06 | Valid Time: 0.004\n",
            "Epoch: 922\n",
            "Train Loss: 5.2322585361253e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.2268225115549285e-06 | Valid Time: 0.004\n",
            "Epoch: 923\n",
            "Train Loss: 5.227462088441825e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.094266614629305e-06 | Valid Time: 0.004\n",
            "Epoch: 924\n",
            "Train Loss: 5.476924366121239e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.101992317373515e-06 | Valid Time: 0.004\n",
            "Epoch: 925\n",
            "Train Loss: 5.295089295032085e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.11541464018228e-06 | Valid Time: 0.004\n",
            "Epoch: 926\n",
            "Train Loss: 5.54236057723756e-06 | Train Time: 0.050\n",
            "Valid Loss: 4.395203404783388e-06 | Valid Time: 0.006\n",
            "Epoch: 927\n",
            "Train Loss: 5.424426672107075e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.997462499683024e-06 | Valid Time: 0.004\n",
            "Epoch: 928\n",
            "Train Loss: 5.2630540039899644e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.142502120885183e-06 | Valid Time: 0.004\n",
            "Epoch: 929\n",
            "Train Loss: 5.308064851305972e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.2895004526144476e-06 | Valid Time: 0.004\n",
            "Epoch: 930\n",
            "Train Loss: 5.311765949045366e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.264264021003328e-06 | Valid Time: 0.004\n",
            "Epoch: 931\n",
            "Train Loss: 5.22230880051211e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.216611841911799e-06 | Valid Time: 0.004\n",
            "Epoch: 932\n",
            "Train Loss: 5.290287253956194e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.287310389372578e-06 | Valid Time: 0.004\n",
            "Epoch: 933\n",
            "Train Loss: 5.246077967058227e-06 | Train Time: 0.045\n",
            "Valid Loss: 3.973374646193406e-06 | Valid Time: 0.004\n",
            "Epoch: 934\n",
            "Train Loss: 5.311875770530605e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.185445959592471e-06 | Valid Time: 0.004\n",
            "Epoch: 935\n",
            "Train Loss: 5.396949882197078e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.106496817257721e-06 | Valid Time: 0.004\n",
            "Epoch: 936\n",
            "Train Loss: 5.388883823798096e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.163739731666283e-06 | Valid Time: 0.004\n",
            "Epoch: 937\n",
            "Train Loss: 5.2918485835107275e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.15316299040569e-06 | Valid Time: 0.004\n",
            "Epoch: 938\n",
            "Train Loss: 5.302290833242296e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.963125209338614e-06 | Valid Time: 0.004\n",
            "Epoch: 939\n",
            "Train Loss: 5.2442921742112954e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.333571496317745e-06 | Valid Time: 0.004\n",
            "Epoch: 940\n",
            "Train Loss: 5.263816046863212e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.1156888528348645e-06 | Valid Time: 0.004\n",
            "Epoch: 941\n",
            "Train Loss: 5.450414755614475e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.1691080241434975e-06 | Valid Time: 0.004\n",
            "Epoch: 942\n",
            "Train Loss: 5.2051568900424176e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.152230076215346e-06 | Valid Time: 0.004\n",
            "Epoch: 943\n",
            "Train Loss: 5.295865730658989e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.9588397839906975e-06 | Valid Time: 0.004\n",
            "Epoch: 944\n",
            "Train Loss: 5.2236647889003505e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.414708087097097e-06 | Valid Time: 0.004\n",
            "Epoch: 945\n",
            "Train Loss: 5.38229899120779e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.112847818760201e-06 | Valid Time: 0.004\n",
            "Epoch: 946\n",
            "Train Loss: 5.454695633488882e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.1222879190172534e-06 | Valid Time: 0.004\n",
            "Epoch: 947\n",
            "Train Loss: 5.252488517726306e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.068983798788395e-06 | Valid Time: 0.004\n",
            "Epoch: 948\n",
            "Train Loss: 5.298364294503699e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.3865514953722595e-06 | Valid Time: 0.004\n",
            "Epoch: 949\n",
            "Train Loss: 5.303372790876892e-06 | Train Time: 0.042\n",
            "Valid Loss: 3.989194851783395e-06 | Valid Time: 0.006\n",
            "Epoch: 950\n",
            "Train Loss: 5.358091880225402e-06 | Train Time: 0.051\n",
            "Valid Loss: 3.995461156591773e-06 | Valid Time: 0.004\n",
            "Epoch: 951\n",
            "Train Loss: 5.264825358608505e-06 | Train Time: 0.047\n",
            "Valid Loss: 3.842863861791557e-06 | Valid Time: 0.004\n",
            "Epoch: 952\n",
            "Train Loss: 5.344242435967317e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.239208919898374e-06 | Valid Time: 0.004\n",
            "Epoch: 953\n",
            "Train Loss: 5.305268678057473e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.156024488111143e-06 | Valid Time: 0.004\n",
            "Epoch: 954\n",
            "Train Loss: 5.1502982159945535e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.09093468078936e-06 | Valid Time: 0.005\n",
            "Epoch: 955\n",
            "Train Loss: 5.375928731155e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.262022798684484e-06 | Valid Time: 0.004\n",
            "Epoch: 956\n",
            "Train Loss: 5.540480606214259e-06 | Train Time: 0.047\n",
            "Valid Loss: 4.155662509219837e-06 | Valid Time: 0.004\n",
            "Epoch: 957\n",
            "Train Loss: 5.2065140380364024e-06 | Train Time: 0.041\n",
            "Valid Loss: 3.982066118624061e-06 | Valid Time: 0.006\n",
            "Epoch: 958\n",
            "Train Loss: 5.229639145909459e-06 | Train Time: 0.044\n",
            "Valid Loss: 3.96323866880266e-06 | Valid Time: 0.004\n",
            "Epoch: 959\n",
            "Train Loss: 5.235122534941183e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.0461263779434375e-06 | Valid Time: 0.004\n",
            "Epoch: 960\n",
            "Train Loss: 5.275200805954228e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.224560825605295e-06 | Valid Time: 0.004\n",
            "Epoch: 961\n",
            "Train Loss: 5.36221007223503e-06 | Train Time: 0.051\n",
            "Valid Loss: 4.458289254216652e-06 | Valid Time: 0.004\n",
            "Epoch: 962\n",
            "Train Loss: 5.275742023513885e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.145723323745187e-06 | Valid Time: 0.004\n",
            "Epoch: 963\n",
            "Train Loss: 5.362322008295451e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.233251956975437e-06 | Valid Time: 0.004\n",
            "Epoch: 964\n",
            "Train Loss: 5.190362253415515e-06 | Train Time: 0.043\n",
            "Valid Loss: 4.0700583667785395e-06 | Valid Time: 0.007\n",
            "Epoch: 965\n",
            "Train Loss: 5.216026329435408e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.369614430288493e-06 | Valid Time: 0.004\n",
            "Epoch: 966\n",
            "Train Loss: 5.259300269244704e-06 | Train Time: 0.056\n",
            "Valid Loss: 4.058998229083954e-06 | Valid Time: 0.004\n",
            "Epoch: 967\n",
            "Train Loss: 5.210449899095693e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.011768396594562e-06 | Valid Time: 0.004\n",
            "Epoch: 968\n",
            "Train Loss: 5.519432374967437e-06 | Train Time: 0.049\n",
            "Valid Loss: 3.874529170388996e-06 | Valid Time: 0.004\n",
            "Epoch: 969\n",
            "Train Loss: 5.391139438870596e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.154007228862611e-06 | Valid Time: 0.004\n",
            "Epoch: 970\n",
            "Train Loss: 5.321446724337875e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.916318632946059e-06 | Valid Time: 0.004\n",
            "Epoch: 971\n",
            "Train Loss: 5.398604412221175e-06 | Train Time: 0.044\n",
            "Valid Loss: 4.223386213197955e-06 | Valid Time: 0.004\n",
            "Epoch: 972\n",
            "Train Loss: 5.3361489790404445e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.103375204067561e-06 | Valid Time: 0.004\n",
            "Epoch: 973\n",
            "Train Loss: 5.235991739027668e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.0974832700158e-06 | Valid Time: 0.004\n",
            "Epoch: 974\n",
            "Train Loss: 5.293787899063318e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.016880893686903e-06 | Valid Time: 0.004\n",
            "Epoch: 975\n",
            "Train Loss: 5.346035550246597e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.4803550736105535e-06 | Valid Time: 0.004\n",
            "Epoch: 976\n",
            "Train Loss: 5.536365574698721e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.150867880525766e-06 | Valid Time: 0.004\n",
            "Epoch: 977\n",
            "Train Loss: 5.2704746849485675e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.115072670174413e-06 | Valid Time: 0.004\n",
            "Epoch: 978\n",
            "Train Loss: 5.142452482687076e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.215060926071601e-06 | Valid Time: 0.004\n",
            "Epoch: 979\n",
            "Train Loss: 5.296272729538032e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.204126071272185e-06 | Valid Time: 0.004\n",
            "Epoch: 980\n",
            "Train Loss: 5.1717889618885234e-06 | Train Time: 0.038\n",
            "Valid Loss: 4.225794327794574e-06 | Valid Time: 0.004\n",
            "Epoch: 981\n",
            "Train Loss: 5.3387944262794916e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.307552785576263e-06 | Valid Time: 0.006\n",
            "Epoch: 982\n",
            "Train Loss: 5.273961255625181e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.145431830693269e-06 | Valid Time: 0.004\n",
            "Epoch: 983\n",
            "Train Loss: 5.22136242580018e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.058540071127936e-06 | Valid Time: 0.004\n",
            "Epoch: 984\n",
            "Train Loss: 5.259692852632725e-06 | Train Time: 0.039\n",
            "Valid Loss: 4.376452011456422e-06 | Valid Time: 0.004\n",
            "Epoch: 985\n",
            "Train Loss: 5.440868903860974e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.329449097895122e-06 | Valid Time: 0.004\n",
            "Epoch: 986\n",
            "Train Loss: 5.152133826413774e-06 | Train Time: 0.046\n",
            "Valid Loss: 4.078040319654974e-06 | Valid Time: 0.004\n",
            "Epoch: 987\n",
            "Train Loss: 5.226710754868691e-06 | Train Time: 0.048\n",
            "Valid Loss: 3.957765898121579e-06 | Valid Time: 0.004\n",
            "Epoch: 988\n",
            "Train Loss: 5.29327567164728e-06 | Train Time: 0.041\n",
            "Valid Loss: 4.0289506841872935e-06 | Valid Time: 0.004\n",
            "Epoch: 989\n",
            "Train Loss: 5.491611341312819e-06 | Train Time: 0.040\n",
            "Valid Loss: 4.044405386594008e-06 | Valid Time: 0.004\n",
            "Epoch: 990\n",
            "Train Loss: 5.18793760875269e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.077736548424582e-06 | Valid Time: 0.004\n",
            "Epoch: 991\n",
            "Train Loss: 5.222229606260953e-06 | Train Time: 0.049\n",
            "Valid Loss: 4.083293106305064e-06 | Valid Time: 0.004\n",
            "Epoch: 992\n",
            "Train Loss: 5.178537526262516e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.116025820621871e-06 | Valid Time: 0.004\n",
            "Epoch: 993\n",
            "Train Loss: 5.24913039043895e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.306517894292483e-06 | Valid Time: 0.004\n",
            "Epoch: 994\n",
            "Train Loss: 5.209218443269492e-06 | Train Time: 0.042\n",
            "Valid Loss: 4.23524920734053e-06 | Valid Time: 0.004\n",
            "Epoch: 995\n",
            "Train Loss: 5.292149580782279e-06 | Train Time: 0.048\n",
            "Valid Loss: 4.154878297413234e-06 | Valid Time: 0.004\n",
            "Epoch: 996\n",
            "Train Loss: 5.184500901123102e-06 | Train Time: 0.045\n",
            "Valid Loss: 4.10061738875811e-06 | Valid Time: 0.004\n",
            "Epoch: 997\n",
            "Train Loss: 5.250135336609673e-06 | Train Time: 0.043\n",
            "Valid Loss: 3.8927228160900995e-06 | Valid Time: 0.004\n",
            "Epoch: 998\n",
            "Train Loss: 5.253968265606091e-06 | Train Time: 0.060\n",
            "Valid Loss: 4.011210648968699e-06 | Valid Time: 0.007\n",
            "Epoch: 999\n",
            "Train Loss: 5.293546428219997e-06 | Train Time: 0.069\n",
            "Valid Loss: 4.3047257349826396e-06 | Valid Time: 0.006\n",
            "== Test Loss: 7.746633173155715e-06 | Test Time: 0.006 ==\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Plot the training and validation losses\n",
        "plt.plot(results[\"train_losses\"])\n",
        "plt.plot(results[\"valid_losses\"])\n",
        "plt.legend(['Train', 'Val'])\n",
        "plt.yscale('log')\n",
        "plt.xlabel('Epoch')\n",
        "plt.ylabel('MSE')"
      ],
      "metadata": {
        "id": "sNwH-Aa0Y3lm",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "outputId": "f4fb631a-779a-4af9-8416-ade6f7347bbd"
      },
      "execution_count": 24,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, 'MSE')"
            ]
          },
          "metadata": {},
          "execution_count": 24
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Print the learned parameters and collect the coeafficients found by the model\n",
        "results_coefs_a = np.zeros((n_x_new,n_x_new))\n",
        "for i, param in enumerate(model.parameters()):\n",
        "  print(param)\n",
        "  if i ==0:\n",
        "    for j1 in range(n_x_new):\n",
        "      for j2 in range(n_x_new):\n",
        "        results_coefs_a[j1][j2]=max_a*torch.sigmoid(param[j1][j2])"
      ],
      "metadata": {
        "id": "mohjVVWXY9d1",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "786f7d68-b4a4-42f2-dd0f-5473e1ea1ea7"
      },
      "execution_count": 25,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Parameter containing:\n",
            "tensor([[ 1.8966e-01,  1.6924e-01, -4.2880e-01, -4.4946e-01,  7.9088e-02,\n",
            "         -1.1232e-01, -2.2391e-01, -2.1724e-01, -3.3403e-01,  2.1455e-01,\n",
            "         -4.0554e-01, -2.5077e-01,  2.6328e-01,  2.1109e-01, -1.8200e-01,\n",
            "         -4.7831e-01],\n",
            "        [ 2.4172e-01, -2.2490e+00, -1.7751e+00, -1.7933e+00, -1.8264e+00,\n",
            "         -1.8821e+00, -1.9766e+00, -2.1146e+00, -2.1679e+00, -2.0786e+00,\n",
            "         -2.0007e+00, -1.9531e+00, -1.9145e+00, -1.8757e+00, -2.3201e+00,\n",
            "         -1.0592e-01],\n",
            "        [ 2.2931e-01, -1.7877e+00, -8.5436e-01, -8.7438e-01, -8.9588e-01,\n",
            "         -9.2320e-01, -9.5481e-01, -9.9329e-01, -1.0260e+00, -1.0410e+00,\n",
            "         -1.0491e+00, -1.0422e+00, -1.0180e+00, -9.7218e-01, -1.8440e+00,\n",
            "         -3.9358e-01],\n",
            "        [ 1.4194e-01, -1.8345e+00, -9.1702e-01, -9.4877e-01, -9.6942e-01,\n",
            "         -9.8441e-01, -9.9268e-01, -9.9376e-01, -9.8739e-01, -9.7678e-01,\n",
            "         -9.6245e-01, -9.4452e-01, -9.2444e-01, -8.9460e-01, -1.8085e+00,\n",
            "          4.1187e-01],\n",
            "        [-1.7471e-02, -1.9169e+00, -1.0192e+00, -1.0656e+00, -1.0745e+00,\n",
            "         -1.0521e+00, -1.0032e+00, -9.3457e-01, -8.5364e-01, -7.8502e-01,\n",
            "         -7.3555e-01, -7.0671e-01, -7.0218e-01, -7.1062e-01, -1.7327e+00,\n",
            "         -2.4689e-03],\n",
            "        [ 4.7290e-01, -2.0464e+00, -1.1697e+00, -1.2363e+00, -1.2213e+00,\n",
            "         -1.1346e+00, -9.9665e-01, -8.2910e-01, -6.4782e-01, -5.0626e-01,\n",
            "         -4.1406e-01, -3.7313e-01, -3.8970e-01, -4.4907e-01, -1.6395e+00,\n",
            "          1.0380e-01],\n",
            "        [ 5.5305e-03, -2.2387e+00, -1.3692e+00, -1.4625e+00, -1.4081e+00,\n",
            "         -1.2279e+00, -9.7760e-01, -6.9732e-01, -3.9592e-01, -1.7351e-01,\n",
            "         -3.1607e-02,  2.4453e-02, -1.8673e-02, -1.4521e-01, -1.5637e+00,\n",
            "          4.4816e-01],\n",
            "        [-1.7850e-01, -2.4762e+00, -1.6180e+00, -1.7465e+00, -1.6318e+00,\n",
            "         -1.3278e+00, -9.5402e-01, -5.4742e-01, -8.9391e-02,  2.1152e-01,\n",
            "          4.1355e-01,  4.8718e-01,  4.0563e-01,  1.7512e-01, -1.5030e+00,\n",
            "          4.7623e-01],\n",
            "        [ 4.3134e-02, -2.6211e+00, -1.8889e+00, -2.0716e+00, -1.8692e+00,\n",
            "         -1.4160e+00, -9.0989e-01, -3.7651e-01,  2.0295e-01,  6.1252e-01,\n",
            "          8.9008e-01,  1.0075e+00,  8.5128e-01,  5.2194e-01, -1.3618e+00,\n",
            "          3.7428e-01],\n",
            "        [-1.3685e-01, -2.6382e+00, -2.1164e+00, -2.3592e+00, -2.0555e+00,\n",
            "         -1.4676e+00, -8.6109e-01, -2.5973e-01,  3.7767e-01,  8.9906e-01,\n",
            "          1.3123e+00,  1.3860e+00,  1.2473e+00,  8.0491e-01, -1.1599e+00,\n",
            "          4.4385e-01],\n",
            "        [ 2.9112e-01, -2.6149e+00, -2.2319e+00, -2.5042e+00, -2.1341e+00,\n",
            "         -1.4769e+00, -8.2588e-01, -1.9274e-01,  4.7263e-01,  1.0759e+00,\n",
            "          1.4612e+00,  1.7643e+00,  1.3862e+00,  9.6294e-01, -1.0236e+00,\n",
            "         -3.0194e-01],\n",
            "        [-6.3367e-03, -2.5476e+00, -2.1711e+00, -2.4122e+00, -2.0629e+00,\n",
            "         -1.4361e+00, -8.0257e-01, -1.8278e-01,  4.6896e-01,  1.0291e+00,\n",
            "          1.5190e+00,  1.5579e+00,  1.4199e+00,  9.0903e-01, -9.7635e-01,\n",
            "          3.5118e-01],\n",
            "        [ 1.4137e-01, -2.4241e+00, -1.9469e+00, -2.1176e+00, -1.8568e+00,\n",
            "         -1.3470e+00, -7.9249e-01, -2.3757e-01,  3.3400e-01,  8.3011e-01,\n",
            "          1.1514e+00,  1.3011e+00,  1.0874e+00,  7.1770e-01, -1.0096e+00,\n",
            "         -4.4820e-01],\n",
            "        [ 2.5278e-01, -2.2600e+00, -1.6320e+00, -1.7356e+00, -1.5705e+00,\n",
            "         -1.2128e+00, -7.8516e-01, -3.5486e-01,  9.7621e-02,  4.9668e-01,\n",
            "          7.4422e-01,  8.0272e-01,  6.7943e-01,  3.9660e-01, -1.1108e+00,\n",
            "          1.4974e-01],\n",
            "        [-3.4475e-01, -2.5735e+00, -2.2157e+00, -2.2671e+00, -2.2090e+00,\n",
            "         -2.0700e+00, -1.9185e+00, -1.7957e+00, -1.5991e+00, -1.3118e+00,\n",
            "         -1.1089e+00, -1.0226e+00, -1.0306e+00, -1.1169e+00, -1.7649e+00,\n",
            "          4.1888e-01],\n",
            "        [-2.5276e-01, -4.9774e-01, -1.9560e-01, -2.8333e-01,  2.8603e-01,\n",
            "          1.5278e-01, -4.7611e-01, -3.5286e-01, -4.5000e-01,  1.6376e-01,\n",
            "          1.2584e-01,  3.7810e-02, -1.4154e-01,  4.3672e-01,  3.8339e-01,\n",
            "         -4.5187e-01]], device='cuda:0', requires_grad=True)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Plot learned coefficients agains actual coeficients\n",
        "\n",
        "We use interpolation when comparing soltuions for more coarsened grids"
      ],
      "metadata": {
        "id": "o2gtgZ_OwN1s"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Visualize actual coefficients again\n",
        "plt.imshow(a_xy.cpu()[2*x_factor:-2*x_factor,2*x_factor:-2*x_factor], cmap='hot', origin='lower',\n",
        "           extent=[2*x_factor*dx.cpu(), (n_x-2*x_factor-1)*dx.cpu(), 2*x_factor*dx.cpu(), (n_x-2*x_factor-1)*dx.cpu()])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "6teJGeB4CqQX",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 446
        },
        "outputId": "6d783295-5597-485d-fb64-c53d6476e40c"
      },
      "execution_count": 26,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import scipy\n",
        "#Get the averaged mesh values in one dimension (since it is a rectangular grid it is the same in all dimensions)\n",
        "x_mesh_avg = torch.zeros(n_x_new).to(device)\n",
        "for i in range(n_x_new):\n",
        "  x_mesh_avg[i] = torch.mean(xmesh[x_factor*i:x_factor*(i+1)])\n",
        "x_mesh_avg[0]=0\n",
        "x_mesh_avg[-1]=1"
      ],
      "metadata": {
        "id": "4DP4LW9BXjf0"
      },
      "execution_count": 27,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Interpolate the results to the fine grid using linear interpolation (excluding last two coeficients due to boundary condition redundancy)\n",
        "interp2d_coefs = scipy.interpolate.RegularGridInterpolator((x_mesh_avg[2:-2].cpu(), x_mesh_avg[2:-2].cpu()),\n",
        "                                                           results_coefs_a[2:-2, 2:-2], bounds_error=False, fill_value=None)\n",
        "interpolated_coefs = interp2d_coefs((x2, x1))"
      ],
      "metadata": {
        "id": "oepmwPRgXkqI"
      },
      "execution_count": 28,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Viasualize the learned coefficients\n",
        "plt.imshow(interpolated_coefs[2*x_factor:-2*x_factor,2*x_factor:-2*x_factor], cmap='hot', origin='lower',\n",
        "           extent=[2*x_factor*dx.cpu(), (n_x-2*x_factor-1)*dx.cpu(), 2*x_factor*dx.cpu(), (n_x-2*x_factor-1)*dx.cpu()])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "MO7jifJiCrm8",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 446
        },
        "outputId": "273a5e1a-ffb2-4b7e-cd50-4e5fa048bcbf"
      },
      "execution_count": 29,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot the difference between the actual and learned coeffcients\n",
        "plt.imshow(a_xy.cpu()[2*x_factor:-2*x_factor,2*x_factor:-2*x_factor]-interpolated_coefs[2*x_factor:-2*x_factor,2*x_factor:-2*x_factor], cmap='hot', origin='lower',\n",
        "           extent=[2*x_factor*dx.cpu(), (n_x-2*x_factor-1)*dx.cpu(), 2*x_factor*dx.cpu(), (n_x-2*x_factor-1)*dx.cpu()])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "lYcVRuEYH8Z4",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 446
        },
        "outputId": "cf06247c-0b66-41bf-bb56-8e43f2e217e7"
      },
      "execution_count": 30,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Plot an example of a modelled solution against its fully resolved function\n",
        "\n",
        "Again interpolating to the fine grid for the modelled solution"
      ],
      "metadata": {
        "id": "L79GlJDXxTlY"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Plot an example solution\n",
        "sol_model_act = solutions_exact[test_data]\n",
        "\n",
        "#Sample our solution to t_k time steps\n",
        "sol_model_act_avg = torch.zeros((t_k, n_x, n_x)).to(device)\n",
        "for i in range (t_k):\n",
        "  sol_model_act_avg[i] = sol_model_act[t_factor*(i+1)]\n",
        "\n",
        "#Our modelled solution is just the output of the netweork to this coarsened input\n",
        "sol_model_pred = model(inputs[test_data].unsqueeze(0)).squeeze(0).detach().cpu().numpy()"
      ],
      "metadata": {
        "id": "hDUsysWT7tNH"
      },
      "execution_count": 31,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Interpolate our solution to the fine grid\n",
        "test_time = 0\n",
        "interp2d_sol = scipy.interpolate.RegularGridInterpolator((x_mesh_avg.cpu(), x_mesh_avg.cpu()),\n",
        "                                                         sol_model_pred[test_time], bounds_error=False, fill_value=None)\n",
        "interpolated_sol = interp2d_sol((x2, x1))"
      ],
      "metadata": {
        "id": "Obi4veKRPTnH"
      },
      "execution_count": 32,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare - modelled solution at first predicted time\n",
        "plt.imshow(interpolated_sol, cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "gjUbAHJv66UV",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "f65649d2-94fa-4445-bbdc-47f8a18fa3b5"
      },
      "execution_count": 33,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare - actual solution at first predicted time\n",
        "plt.imshow(sol_model_act_avg[test_time].cpu(), cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "Ozha6WPGQMEo",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "e8e39b98-1fc9-4baf-d2de-c7a9b3d585dd"
      },
      "execution_count": 34,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare - difference in solutions at first predicted time\n",
        "plt.imshow(sol_model_act_avg[test_time].cpu()-interpolated_sol, cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "jtHW9d8hQWOY",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "5cbded6d-2ec0-4252-fb16-0e1d6cfb2ef4"
      },
      "execution_count": 35,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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3W7bO++8c04tGy+R85SmqSVJ0v+3o5vFXXaR85RlmW1tbVmtVrOVlRXb2dmxzc3N/oZ6KPdn+Lh4ZjsLavqV2ur6tGUvm7Mc+8bGhtXrdUvT1Lrdbil679HztLm5abdv37bbt29blmXWaDRK8Uswcp7Kkp/giZynTqdj8/Pz/e/TNLX19fVSvO9Oq8yf4ePime0ssNX16UTOk9njpL3Z2dl+R2Fzc5PzZIPn6clfgE++zMxWV1dtdnb2XNt8EaLvu7m5uf4vvSdrLXCeBs/T7OysbW1tDZT/8MMPS3GejjreOeIzfLw80xtJZVlmt27d6m9ffXRhnKWlpYGtrvPKXnanPU9Zltlbb7018LNJktj9+/cvoNXnL3I/mT3+cLt9+7bV63VbWVkpTYchcp663a7V63W7ceOGbW9v90esyiByntrttnU6nf6/12q1Upyndrtt9+7ds42NDVtbW7P5+fl+cief4ePlme4sAACA0XtmH0MAAIDzQWcBAADkorMAAABy0VkAAAC56CwAAIBcdBYAAEAuOgsAACAXnQUAAJCLzgIAAMhFZwEAAOSiswAAAHI9f9ENABCTZZm1223b2dmx1dVV63Q6bKwDYKQYWQCeMe1221ZWVmxhYcGWlpZscXHRWq2W7e3tXXTTAFxSjCwAz5h33nnHzMw6nY69++67Zma2s7NzkU0CcMkxsgA8Y548arh7964tLi6amVm32724BgG49OgsAM+Q27dvW71et06nY1mWWZqmZma2ubl5wS0DcJlN9Hq93kU3AsDptNtty7LMqtWqJUliWZaZmdnKysoFtwzAZUZnAQAA5OIxBAAAyEVnAQAA5KKzAAAActFZAAAAuegsAACAXHQWAABALjoLAAAgF50FAACQi84CAADIRWcBAADkorMAAABy/f804ukmrb6G5gAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Maximum discrepancy between solutions at first predicted time\n",
        "F.mse_loss(sol_model_act_avg[0],torch.tensor(interpolated_sol).to(device))\n"
      ],
      "metadata": {
        "id": "rT3wWNzIQbQf",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "512fb021-ff40-481d-9464-462940aff3ed"
      },
      "execution_count": 36,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tensor(0.0002, device='cuda:0', dtype=torch.float64)"
            ]
          },
          "metadata": {},
          "execution_count": 36
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Now we train a fuly connected neural net"
      ],
      "metadata": {
        "id": "193R_YU_M26W"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Working with the heat equaiton $$u_t = a(x,y)(u_{xx}+u_{yy})$$"
      ],
      "metadata": {
        "id": "XbQExbXI953a"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "Input data - Initial conditions\n",
        "\n",
        "For now working with Zero-Dirichlet Boundary conditions\n",
        "\n",
        "Initial conditions: $$u((x,y),0) = \\sum_{i=1}^k \\sum_{j=1}^kc_{ij}sin(\\pi ix)\\cdot sin(\\pi jy)$$\n",
        "\n",
        "$k = 2$ for the results presented today (note that larger $k$ values require finer grid size $n_x$ to generate good results).\n"
      ],
      "metadata": {
        "id": "kLoxnfOaxge7"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Define the Coarsened FD method as a fully connected neural net\n",
        "# Option 1: run the coede as is for the Convolutional neural netword\n",
        "# Option 2: uncomment the section under #Define a simple 2-layer ReLU MLP, the comment # x = self.flatten(x) and the comment\n",
        "# # y = y.view(-1, 1, self.grid_size, self.grid_size), and comment out the section under #Define a simple 2-layer ReLU conv net\n",
        "# to run the fully connected network\n",
        "class IndividualLayer_NN(nn.Module):\n",
        "  \"\"\"This class implements an individual layer of the coarsened grid FD method\"\"\"\n",
        "\n",
        "  def __init__(self, grid_size):\n",
        "    \"\"\"\n",
        "      grid_size: int\n",
        "        size of coarsened grid\n",
        "    \"\"\"\n",
        "    super(IndividualLayer_NN, self).__init__()\n",
        "\n",
        "    self.grid_size = grid_size\n",
        "    #Neural net is a simple fully-connected two-layer neural net with ReLU activation (i.e. we first flatten the inputs from a 2D array to a 1D array)\n",
        "    self.layer1 = nn.Conv2d(1, 16, 3, 1, 1)\n",
        "    self.activation = nn.ReLU()\n",
        "    self.layer2 = nn.Conv2d(16, 1, 3, 1, 1)\n",
        "\n",
        "    #Define a simple 2-layer ReLU MLP\n",
        "    # self.flatten = nn.Flatten()\n",
        "    # self.layer1 = nn.Linear(self.grid_size**2, 32)\n",
        "    # self.activation = nn.ReLU()\n",
        "    # self.layer2 = nn.Linear(32, self.grid_size**2)\n",
        "\n",
        "\n",
        "  def forward(self, x):\n",
        "    \"\"\"\n",
        "      x: Tensor\n",
        "        Coarsened inputs at a given time\n",
        "\n",
        "      Outputs: Returns the predicted coarsened outputs at the next time\n",
        "    \"\"\"\n",
        "    # x = self.flatten(x)\n",
        "    #Conv layer 1\n",
        "    x2 = self.layer1(x)\n",
        "    #ReLU\n",
        "    x3 = self.activation(x2)\n",
        "    #Conv layer 2\n",
        "    y = self.layer2(x3)\n",
        "    #Re-shape to 2D array\n",
        "    # y = y.view(-1, 1, self.grid_size, self.grid_size)\n",
        "    return y"
      ],
      "metadata": {
        "id": "pwj7ivxxHDB5"
      },
      "execution_count": 37,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "class NN_Solver(nn.Module):\n",
        "  \"\"\"This class implements the Full Coarsened FD method\"\"\"\n",
        "\n",
        "  def __init__(self, xmesh):\n",
        "    \"\"\"\n",
        "      xmesh: int\n",
        "        size of coarsened grid\n",
        "      W: matrix\n",
        "        Matrix for the coarsened FD method\n",
        "    \"\"\"\n",
        "    super(NN_Solver, self).__init__()\n",
        "\n",
        "    # Call the individual layer class defined previously - currently t_k = 10, change manually if this changes\n",
        "    self.layer1 = IndividualLayer_NN(xmesh)\n",
        "    self.layer2 = IndividualLayer_NN(xmesh)\n",
        "    self.layer3 = IndividualLayer_NN(xmesh)\n",
        "    self.layer4 = IndividualLayer_NN(xmesh)\n",
        "    self.layer5 = IndividualLayer_NN(xmesh)\n",
        "    self.layer6 = IndividualLayer_NN(xmesh)\n",
        "    self.layer7 = IndividualLayer_NN(xmesh)\n",
        "    self.layer8 = IndividualLayer_NN(xmesh)\n",
        "    self.layer9 = IndividualLayer_NN(xmesh)\n",
        "    self.layer10 = IndividualLayer_NN(xmesh)\n",
        "\n",
        "  def forward(self, x):\n",
        "    \"\"\"\n",
        "      x: Tensor\n",
        "        Coarsened inputs to the network at time 0\n",
        "\n",
        "      Outputs: Returns the coarsened outputs at the next 10 times\n",
        "    \"\"\"\n",
        "\n",
        "    # Call the individual layer (FD method) 10 times to generate the next t_k = 10 time predictions in the coarsened grid (as before need to clean up)\n",
        "    x1=self.layer1(x)\n",
        "    x2=self.layer2(x1)\n",
        "    x3=self.layer3(x2)\n",
        "    x4=self.layer4(x3)\n",
        "    x5=self.layer5(x4)\n",
        "    x6=self.layer6(x5)\n",
        "    x7=self.layer7(x6)\n",
        "    x8=self.layer8(x7)\n",
        "    x9=self.layer9(x8)\n",
        "    x10=self.layer10(x9)\n",
        "\n",
        "    # Concatenate the outputs to check with the original coarsened outputs\n",
        "    y = torch.cat((x1,x2,x3,x4,x5,x6,x7,x8,x9,x10),1)\n",
        "    return y"
      ],
      "metadata": {
        "id": "RApASrf1F6Qj"
      },
      "execution_count": 38,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Define the model as the PDE_Solver class and feed in the coarsed grid size and average W matrix\n",
        "# Optimize with Adam and our loss is the L_2 loss\n",
        "# Note that a regularization of 0.0001 is used when the grid reslution is 64 x 64 to prevent the model from blowing up\n",
        "modelNN = NN_Solver(n_x_new).to(device)\n",
        "optimizer = optim.Adam(modelNN.parameters(), weight_decay=0)\n",
        "criterion = torch.nn.MSELoss()\n",
        "\n",
        "# Collect the results of the training and validation\n",
        "resultsNN = {\n",
        "    \"train_losses\": [],\n",
        "    \"train_times\":  [],\n",
        "    \"valid_losses\": [],\n",
        "    \"valid_times\":  [],\n",
        "    \"test_loss\":    0.,\n",
        "    \"test_time\":    0.\n",
        "}\n",
        "\n",
        "if __name__ == \"__main__\":\n",
        "    torch.cuda.empty_cache()\n",
        "    n_epochs = 1000\n",
        "\n",
        "    for epoch in range(n_epochs):\n",
        "        train_loss, train_time = train(modelNN, Heat_DataLoader_train, optimizer, criterion)\n",
        "        valid_loss, valid_time = validate(modelNN, Heat_DataLoader_val, criterion)\n",
        "\n",
        "        print(f\"Epoch: {epoch}\")\n",
        "        print(f\"Train Loss: {train_loss} | Train Time: {train_time:.3f}\")\n",
        "        print(f\"Valid Loss: {valid_loss} | Valid Time: {valid_time:.3f}\")\n",
        "\n",
        "        resultsNN[\"train_losses\"].append(train_loss)\n",
        "        resultsNN[\"train_times\"].append(train_time)\n",
        "        resultsNN[\"valid_losses\"].append(valid_loss)\n",
        "        resultsNN[\"valid_times\"].append(valid_time)\n",
        "\n",
        "    test_loss, test_time = validate(modelNN, Heat_DataLoader_test, criterion)\n",
        "    print(f\"== Test Loss: {test_loss} | Test Time: {test_time:.3f} ==\")\n",
        "    resultsNN[\"test_loss\"] = test_loss\n",
        "    resultsNN[\"test_time\"] = test_time"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xww3qzQoGnov",
        "outputId": "5f175d72-d8e4-48b1-b10f-91f2414f89e2"
      },
      "execution_count": 39,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch: 0\n",
            "Train Loss: 0.21334052532911302 | Train Time: 0.713\n",
            "Valid Loss: 0.1937059611082077 | Valid Time: 0.006\n",
            "Epoch: 1\n",
            "Train Loss: 0.2002529978752136 | Train Time: 0.047\n",
            "Valid Loss: 0.18066152185201645 | Valid Time: 0.005\n",
            "Epoch: 2\n",
            "Train Loss: 0.1810422882437706 | Train Time: 0.045\n",
            "Valid Loss: 0.1501479670405388 | Valid Time: 0.003\n",
            "Epoch: 3\n",
            "Train Loss: 0.14859593585133551 | Train Time: 0.045\n",
            "Valid Loss: 0.12296437844634056 | Valid Time: 0.003\n",
            "Epoch: 4\n",
            "Train Loss: 0.11999903097748757 | Train Time: 0.045\n",
            "Valid Loss: 0.09341994673013687 | Valid Time: 0.007\n",
            "Epoch: 5\n",
            "Train Loss: 0.08591308668255807 | Train Time: 0.049\n",
            "Valid Loss: 0.06585198268294334 | Valid Time: 0.004\n",
            "Epoch: 6\n",
            "Train Loss: 0.059178796410560605 | Train Time: 0.047\n",
            "Valid Loss: 0.04552324861288071 | Valid Time: 0.004\n",
            "Epoch: 7\n",
            "Train Loss: 0.03616045340895653 | Train Time: 0.053\n",
            "Valid Loss: 0.022329294122755527 | Valid Time: 0.005\n",
            "Epoch: 8\n",
            "Train Loss: 0.017854676768183707 | Train Time: 0.058\n",
            "Valid Loss: 0.014365755021572113 | Valid Time: 0.003\n",
            "Epoch: 9\n",
            "Train Loss: 0.01302077891305089 | Train Time: 0.050\n",
            "Valid Loss: 0.011932314839214087 | Valid Time: 0.003\n",
            "Epoch: 10\n",
            "Train Loss: 0.01125474963337183 | Train Time: 0.052\n",
            "Valid Loss: 0.01140668848529458 | Valid Time: 0.005\n",
            "Epoch: 11\n",
            "Train Loss: 0.0103270523250103 | Train Time: 0.049\n",
            "Valid Loss: 0.008369538467377424 | Valid Time: 0.004\n",
            "Epoch: 12\n",
            "Train Loss: 0.008324507856741548 | Train Time: 0.051\n",
            "Valid Loss: 0.0069106160663068295 | Valid Time: 0.003\n",
            "Epoch: 13\n",
            "Train Loss: 0.007130816811695695 | Train Time: 0.054\n",
            "Valid Loss: 0.006456674542278051 | Valid Time: 0.003\n",
            "Epoch: 14\n",
            "Train Loss: 0.006364362826570868 | Train Time: 0.047\n",
            "Valid Loss: 0.005606199381873012 | Valid Time: 0.004\n",
            "Epoch: 15\n",
            "Train Loss: 0.005798347014933825 | Train Time: 0.049\n",
            "Valid Loss: 0.005212497198954225 | Valid Time: 0.003\n",
            "Epoch: 16\n",
            "Train Loss: 0.005412634089589119 | Train Time: 0.056\n",
            "Valid Loss: 0.004944040672853589 | Valid Time: 0.003\n",
            "Epoch: 17\n",
            "Train Loss: 0.00509122614748776 | Train Time: 0.047\n",
            "Valid Loss: 0.004481376381590962 | Valid Time: 0.004\n",
            "Epoch: 18\n",
            "Train Loss: 0.004680845513939857 | Train Time: 0.047\n",
            "Valid Loss: 0.004561553243547678 | Valid Time: 0.003\n",
            "Epoch: 19\n",
            "Train Loss: 0.004446784360334277 | Train Time: 0.050\n",
            "Valid Loss: 0.004063747124746442 | Valid Time: 0.004\n",
            "Epoch: 20\n",
            "Train Loss: 0.00405048718675971 | Train Time: 0.052\n",
            "Valid Loss: 0.003735824255272746 | Valid Time: 0.003\n",
            "Epoch: 21\n",
            "Train Loss: 0.003920011315494775 | Train Time: 0.046\n",
            "Valid Loss: 0.0035919342190027237 | Valid Time: 0.003\n",
            "Epoch: 22\n",
            "Train Loss: 0.003769122576341033 | Train Time: 0.047\n",
            "Valid Loss: 0.0036173765547573566 | Valid Time: 0.005\n",
            "Epoch: 23\n",
            "Train Loss: 0.00363794497679919 | Train Time: 0.051\n",
            "Valid Loss: 0.00349799869582057 | Valid Time: 0.003\n",
            "Epoch: 24\n",
            "Train Loss: 0.003532504849135876 | Train Time: 0.049\n",
            "Valid Loss: 0.0031477691372856498 | Valid Time: 0.003\n",
            "Epoch: 25\n",
            "Train Loss: 0.0032952120760455727 | Train Time: 0.051\n",
            "Valid Loss: 0.003070988808758557 | Valid Time: 0.005\n",
            "Epoch: 26\n",
            "Train Loss: 0.003273529023863375 | Train Time: 0.066\n",
            "Valid Loss: 0.003432933473959565 | Valid Time: 0.004\n",
            "Epoch: 27\n",
            "Train Loss: 0.0032892955001443624 | Train Time: 0.047\n",
            "Valid Loss: 0.003023962606675923 | Valid Time: 0.004\n",
            "Epoch: 28\n",
            "Train Loss: 0.0031634542159736157 | Train Time: 0.053\n",
            "Valid Loss: 0.0029177257092669606 | Valid Time: 0.003\n",
            "Epoch: 29\n",
            "Train Loss: 0.002959426469169557 | Train Time: 0.051\n",
            "Valid Loss: 0.0029268877115100622 | Valid Time: 0.004\n",
            "Epoch: 30\n",
            "Train Loss: 0.0030463001690804957 | Train Time: 0.054\n",
            "Valid Loss: 0.0031933403806760907 | Valid Time: 0.003\n",
            "Epoch: 31\n",
            "Train Loss: 0.0028654685709625484 | Train Time: 0.047\n",
            "Valid Loss: 0.002758495509624481 | Valid Time: 0.004\n",
            "Epoch: 32\n",
            "Train Loss: 0.002784790424630046 | Train Time: 0.049\n",
            "Valid Loss: 0.0028836721321567893 | Valid Time: 0.004\n",
            "Epoch: 33\n",
            "Train Loss: 0.002879312448203564 | Train Time: 0.048\n",
            "Valid Loss: 0.0033539937576279044 | Valid Time: 0.004\n",
            "Epoch: 34\n",
            "Train Loss: 0.0033244512276723983 | Train Time: 0.046\n",
            "Valid Loss: 0.0031010020757094026 | Valid Time: 0.006\n",
            "Epoch: 35\n",
            "Train Loss: 0.0029582097893580796 | Train Time: 0.047\n",
            "Valid Loss: 0.0030594912823289633 | Valid Time: 0.003\n",
            "Epoch: 36\n",
            "Train Loss: 0.002717837272211909 | Train Time: 0.049\n",
            "Valid Loss: 0.002413460984826088 | Valid Time: 0.006\n",
            "Epoch: 37\n",
            "Train Loss: 0.0025921839289367197 | Train Time: 0.047\n",
            "Valid Loss: 0.0024609850952401757 | Valid Time: 0.003\n",
            "Epoch: 38\n",
            "Train Loss: 0.0026046992279589176 | Train Time: 0.048\n",
            "Valid Loss: 0.0024370956234633923 | Valid Time: 0.003\n",
            "Epoch: 39\n",
            "Train Loss: 0.00251043641474098 | Train Time: 0.050\n",
            "Valid Loss: 0.0022960128262639046 | Valid Time: 0.003\n",
            "Epoch: 40\n",
            "Train Loss: 0.0024337113834917547 | Train Time: 0.049\n",
            "Valid Loss: 0.0026415908941999078 | Valid Time: 0.004\n",
            "Epoch: 41\n",
            "Train Loss: 0.002560572139918804 | Train Time: 0.044\n",
            "Valid Loss: 0.0024137379368767142 | Valid Time: 0.003\n",
            "Epoch: 42\n",
            "Train Loss: 0.0024320862721651793 | Train Time: 0.050\n",
            "Valid Loss: 0.0022662212140858173 | Valid Time: 0.003\n",
            "Epoch: 43\n",
            "Train Loss: 0.002433388447389007 | Train Time: 0.045\n",
            "Valid Loss: 0.0024519332218915224 | Valid Time: 0.003\n",
            "Epoch: 44\n",
            "Train Loss: 0.0025821087416261434 | Train Time: 0.056\n",
            "Valid Loss: 0.0029122537234798074 | Valid Time: 0.003\n",
            "Epoch: 45\n",
            "Train Loss: 0.002660163398832083 | Train Time: 0.053\n",
            "Valid Loss: 0.0024344539269804955 | Valid Time: 0.003\n",
            "Epoch: 46\n",
            "Train Loss: 0.002467604773119092 | Train Time: 0.055\n",
            "Valid Loss: 0.0022793737007305026 | Valid Time: 0.003\n",
            "Epoch: 47\n",
            "Train Loss: 0.002310961531475186 | Train Time: 0.045\n",
            "Valid Loss: 0.002597432234324515 | Valid Time: 0.003\n",
            "Epoch: 48\n",
            "Train Loss: 0.002455815300345421 | Train Time: 0.052\n",
            "Valid Loss: 0.002143687568604946 | Valid Time: 0.003\n",
            "Epoch: 49\n",
            "Train Loss: 0.002244758792221546 | Train Time: 0.046\n",
            "Valid Loss: 0.00211806851439178 | Valid Time: 0.003\n",
            "Epoch: 50\n",
            "Train Loss: 0.002181977708823979 | Train Time: 0.044\n",
            "Valid Loss: 0.0020881472155451775 | Valid Time: 0.004\n",
            "Epoch: 51\n",
            "Train Loss: 0.0021715425187721848 | Train Time: 0.044\n",
            "Valid Loss: 0.0020783323561772704 | Valid Time: 0.003\n",
            "Epoch: 52\n",
            "Train Loss: 0.0022574176080524923 | Train Time: 0.049\n",
            "Valid Loss: 0.002442968194372952 | Valid Time: 0.003\n",
            "Epoch: 53\n",
            "Train Loss: 0.0023978368146345018 | Train Time: 0.049\n",
            "Valid Loss: 0.0025860692840069532 | Valid Time: 0.004\n",
            "Epoch: 54\n",
            "Train Loss: 0.002425872697494924 | Train Time: 0.046\n",
            "Valid Loss: 0.0022315012756735086 | Valid Time: 0.003\n",
            "Epoch: 55\n",
            "Train Loss: 0.0024163366295397283 | Train Time: 0.050\n",
            "Valid Loss: 0.0023038507206365466 | Valid Time: 0.003\n",
            "Epoch: 56\n",
            "Train Loss: 0.002246814593672752 | Train Time: 0.050\n",
            "Valid Loss: 0.002041342784650624 | Valid Time: 0.003\n",
            "Epoch: 57\n",
            "Train Loss: 0.0022524185478687286 | Train Time: 0.048\n",
            "Valid Loss: 0.0019791784579865634 | Valid Time: 0.003\n",
            "Epoch: 58\n",
            "Train Loss: 0.0020525846048258245 | Train Time: 0.045\n",
            "Valid Loss: 0.0019252494676038623 | Valid Time: 0.003\n",
            "Epoch: 59\n",
            "Train Loss: 0.002074300404638052 | Train Time: 0.053\n",
            "Valid Loss: 0.002018397208303213 | Valid Time: 0.003\n",
            "Epoch: 60\n",
            "Train Loss: 0.002060859720222652 | Train Time: 0.051\n",
            "Valid Loss: 0.0023632552474737167 | Valid Time: 0.004\n",
            "Epoch: 61\n",
            "Train Loss: 0.0024200235260650516 | Train Time: 0.046\n",
            "Valid Loss: 0.002598541905172169 | Valid Time: 0.005\n",
            "Epoch: 62\n",
            "Train Loss: 0.002434097370132804 | Train Time: 0.049\n",
            "Valid Loss: 0.002246297663077712 | Valid Time: 0.006\n",
            "Epoch: 63\n",
            "Train Loss: 0.0022496363963000476 | Train Time: 0.048\n",
            "Valid Loss: 0.002318970742635429 | Valid Time: 0.003\n",
            "Epoch: 64\n",
            "Train Loss: 0.002177587721962482 | Train Time: 0.057\n",
            "Valid Loss: 0.0019804907497018576 | Valid Time: 0.004\n",
            "Epoch: 65\n",
            "Train Loss: 0.00221024650381878 | Train Time: 0.051\n",
            "Valid Loss: 0.0021179753239266574 | Valid Time: 0.003\n",
            "Epoch: 66\n",
            "Train Loss: 0.001987017854116857 | Train Time: 0.055\n",
            "Valid Loss: 0.001914567721541971 | Valid Time: 0.003\n",
            "Epoch: 67\n",
            "Train Loss: 0.0019581022672355173 | Train Time: 0.045\n",
            "Valid Loss: 0.0018845012527890503 | Valid Time: 0.003\n",
            "Epoch: 68\n",
            "Train Loss: 0.0019470132538117468 | Train Time: 0.056\n",
            "Valid Loss: 0.0017745348741300404 | Valid Time: 0.005\n",
            "Epoch: 69\n",
            "Train Loss: 0.0018441613879986106 | Train Time: 0.051\n",
            "Valid Loss: 0.0018365035648457706 | Valid Time: 0.003\n",
            "Epoch: 70\n",
            "Train Loss: 0.002222006570082158 | Train Time: 0.046\n",
            "Valid Loss: 0.0020305513753555715 | Valid Time: 0.004\n",
            "Epoch: 71\n",
            "Train Loss: 0.002143465122207999 | Train Time: 0.046\n",
            "Valid Loss: 0.0027011403581127524 | Valid Time: 0.004\n",
            "Epoch: 72\n",
            "Train Loss: 0.002359465626068413 | Train Time: 0.049\n",
            "Valid Loss: 0.0019110466237179935 | Valid Time: 0.004\n",
            "Epoch: 73\n",
            "Train Loss: 0.0023074800265021622 | Train Time: 0.046\n",
            "Valid Loss: 0.0021103628678247333 | Valid Time: 0.003\n",
            "Epoch: 74\n",
            "Train Loss: 0.002634766849223524 | Train Time: 0.049\n",
            "Valid Loss: 0.0019276307430118322 | Valid Time: 0.003\n",
            "Epoch: 75\n",
            "Train Loss: 0.002064242260530591 | Train Time: 0.051\n",
            "Valid Loss: 0.0019398799049668014 | Valid Time: 0.004\n",
            "Epoch: 76\n",
            "Train Loss: 0.0021276906714774667 | Train Time: 0.054\n",
            "Valid Loss: 0.00179126305738464 | Valid Time: 0.003\n",
            "Epoch: 77\n",
            "Train Loss: 0.0018600390991196035 | Train Time: 0.047\n",
            "Valid Loss: 0.0017826788243837655 | Valid Time: 0.003\n",
            "Epoch: 78\n",
            "Train Loss: 0.0017911687144078314 | Train Time: 0.045\n",
            "Valid Loss: 0.001780315418727696 | Valid Time: 0.003\n",
            "Epoch: 79\n",
            "Train Loss: 0.0018710707896389066 | Train Time: 0.052\n",
            "Valid Loss: 0.0020065430435352027 | Valid Time: 0.004\n",
            "Epoch: 80\n",
            "Train Loss: 0.0020733176497742534 | Train Time: 0.048\n",
            "Valid Loss: 0.0025631716707721353 | Valid Time: 0.003\n",
            "Epoch: 81\n",
            "Train Loss: 0.002111814299132675 | Train Time: 0.047\n",
            "Valid Loss: 0.0025060410844162107 | Valid Time: 0.006\n",
            "Epoch: 82\n",
            "Train Loss: 0.0025976435863412917 | Train Time: 0.051\n",
            "Valid Loss: 0.0019064118387177587 | Valid Time: 0.004\n",
            "Epoch: 83\n",
            "Train Loss: 0.002091750083491206 | Train Time: 0.069\n",
            "Valid Loss: 0.0021543516777455807 | Valid Time: 0.006\n",
            "Epoch: 84\n",
            "Train Loss: 0.002102104597724974 | Train Time: 0.073\n",
            "Valid Loss: 0.0020984243601560593 | Valid Time: 0.005\n",
            "Epoch: 85\n",
            "Train Loss: 0.002108422957826406 | Train Time: 0.066\n",
            "Valid Loss: 0.0019782413728535175 | Valid Time: 0.007\n",
            "Epoch: 86\n",
            "Train Loss: 0.0018864591023884715 | Train Time: 0.071\n",
            "Valid Loss: 0.0017318797181360424 | Valid Time: 0.005\n",
            "Epoch: 87\n",
            "Train Loss: 0.0017844997579231857 | Train Time: 0.075\n",
            "Valid Loss: 0.0016263932338915765 | Valid Time: 0.006\n",
            "Epoch: 88\n",
            "Train Loss: 0.0016792582347989083 | Train Time: 0.069\n",
            "Valid Loss: 0.001626588054932654 | Valid Time: 0.005\n",
            "Epoch: 89\n",
            "Train Loss: 0.0016511797555722296 | Train Time: 0.069\n",
            "Valid Loss: 0.0017239436856471002 | Valid Time: 0.005\n",
            "Epoch: 90\n",
            "Train Loss: 0.00167582998983562 | Train Time: 0.075\n",
            "Valid Loss: 0.0018414237420074642 | Valid Time: 0.005\n",
            "Epoch: 91\n",
            "Train Loss: 0.001756606576964259 | Train Time: 0.067\n",
            "Valid Loss: 0.0017054950003512204 | Valid Time: 0.005\n",
            "Epoch: 92\n",
            "Train Loss: 0.0017953396774828434 | Train Time: 0.069\n",
            "Valid Loss: 0.0020071640028618276 | Valid Time: 0.005\n",
            "Epoch: 93\n",
            "Train Loss: 0.0017310647759586572 | Train Time: 0.075\n",
            "Valid Loss: 0.0015901931910775602 | Valid Time: 0.005\n",
            "Epoch: 94\n",
            "Train Loss: 0.0016949808807112277 | Train Time: 0.073\n",
            "Valid Loss: 0.0015788035816513002 | Valid Time: 0.005\n",
            "Epoch: 95\n",
            "Train Loss: 0.0017478970810770988 | Train Time: 0.069\n",
            "Valid Loss: 0.0015023688902147114 | Valid Time: 0.005\n",
            "Epoch: 96\n",
            "Train Loss: 0.0017158491304144264 | Train Time: 0.081\n",
            "Valid Loss: 0.001600929768756032 | Valid Time: 0.008\n",
            "Epoch: 97\n",
            "Train Loss: 0.0016480445628985763 | Train Time: 0.074\n",
            "Valid Loss: 0.0015410547493956983 | Valid Time: 0.005\n",
            "Epoch: 98\n",
            "Train Loss: 0.0016188048524782062 | Train Time: 0.075\n",
            "Valid Loss: 0.0015977000584825873 | Valid Time: 0.005\n",
            "Epoch: 99\n",
            "Train Loss: 0.0016711550415493548 | Train Time: 0.069\n",
            "Valid Loss: 0.0016139912186190486 | Valid Time: 0.005\n",
            "Epoch: 100\n",
            "Train Loss: 0.0017994302092120052 | Train Time: 0.064\n",
            "Valid Loss: 0.001656432170420885 | Valid Time: 0.004\n",
            "Epoch: 101\n",
            "Train Loss: 0.0018482524319551885 | Train Time: 0.069\n",
            "Valid Loss: 0.0019864660571329296 | Valid Time: 0.005\n",
            "Epoch: 102\n",
            "Train Loss: 0.0019130360684357583 | Train Time: 0.074\n",
            "Valid Loss: 0.002195494365878403 | Valid Time: 0.005\n",
            "Epoch: 103\n",
            "Train Loss: 0.0023378119338303806 | Train Time: 0.083\n",
            "Valid Loss: 0.0027437369571998715 | Valid Time: 0.005\n",
            "Epoch: 104\n",
            "Train Loss: 0.0018289947998709976 | Train Time: 0.072\n",
            "Valid Loss: 0.0018261376535519958 | Valid Time: 0.005\n",
            "Epoch: 105\n",
            "Train Loss: 0.001826031832024455 | Train Time: 0.070\n",
            "Valid Loss: 0.001822498976252973 | Valid Time: 0.005\n",
            "Epoch: 106\n",
            "Train Loss: 0.0016703915665857495 | Train Time: 0.067\n",
            "Valid Loss: 0.0015442419098690152 | Valid Time: 0.005\n",
            "Epoch: 107\n",
            "Train Loss: 0.0018427512957714498 | Train Time: 0.071\n",
            "Valid Loss: 0.0018318523652851582 | Valid Time: 0.006\n",
            "Epoch: 108\n",
            "Train Loss: 0.0017115590628236533 | Train Time: 0.077\n",
            "Valid Loss: 0.0021727046696469188 | Valid Time: 0.006\n",
            "Epoch: 109\n",
            "Train Loss: 0.001965516887139529 | Train Time: 0.070\n",
            "Valid Loss: 0.001754154043737799 | Valid Time: 0.005\n",
            "Epoch: 110\n",
            "Train Loss: 0.0017281645443290472 | Train Time: 0.084\n",
            "Valid Loss: 0.0016349072684533894 | Valid Time: 0.005\n",
            "Epoch: 111\n",
            "Train Loss: 0.001548832841217518 | Train Time: 0.068\n",
            "Valid Loss: 0.001653877377975732 | Valid Time: 0.006\n",
            "Epoch: 112\n",
            "Train Loss: 0.0015463016577996313 | Train Time: 0.069\n",
            "Valid Loss: 0.001514943956863135 | Valid Time: 0.005\n",
            "Epoch: 113\n",
            "Train Loss: 0.0017021818086504937 | Train Time: 0.073\n",
            "Valid Loss: 0.001816219068132341 | Valid Time: 0.006\n",
            "Epoch: 114\n",
            "Train Loss: 0.0016954304999671876 | Train Time: 0.080\n",
            "Valid Loss: 0.0014682714245282114 | Valid Time: 0.006\n",
            "Epoch: 115\n",
            "Train Loss: 0.0015596371027640997 | Train Time: 0.063\n",
            "Valid Loss: 0.0015693360473960638 | Valid Time: 0.004\n",
            "Epoch: 116\n",
            "Train Loss: 0.0015508152660913765 | Train Time: 0.047\n",
            "Valid Loss: 0.0015703474055044353 | Valid Time: 0.004\n",
            "Epoch: 117\n",
            "Train Loss: 0.0017172905383631587 | Train Time: 0.048\n",
            "Valid Loss: 0.0017423417302779853 | Valid Time: 0.003\n",
            "Epoch: 118\n",
            "Train Loss: 0.0018919388065114617 | Train Time: 0.050\n",
            "Valid Loss: 0.001504895684774965 | Valid Time: 0.003\n",
            "Epoch: 119\n",
            "Train Loss: 0.0017539511434733867 | Train Time: 0.046\n",
            "Valid Loss: 0.0014121585409156978 | Valid Time: 0.003\n",
            "Epoch: 120\n",
            "Train Loss: 0.0015422823955304921 | Train Time: 0.045\n",
            "Valid Loss: 0.001591127598658204 | Valid Time: 0.004\n",
            "Epoch: 121\n",
            "Train Loss: 0.0016018955502659082 | Train Time: 0.045\n",
            "Valid Loss: 0.0019484289805404842 | Valid Time: 0.003\n",
            "Epoch: 122\n",
            "Train Loss: 0.0017067837878130376 | Train Time: 0.053\n",
            "Valid Loss: 0.001570293854456395 | Valid Time: 0.006\n",
            "Epoch: 123\n",
            "Train Loss: 0.0016753197880461812 | Train Time: 0.064\n",
            "Valid Loss: 0.001424335001502186 | Valid Time: 0.004\n",
            "Epoch: 124\n",
            "Train Loss: 0.0014596338500268758 | Train Time: 0.052\n",
            "Valid Loss: 0.001472675008699298 | Valid Time: 0.004\n",
            "Epoch: 125\n",
            "Train Loss: 0.0015271475189365447 | Train Time: 0.051\n",
            "Valid Loss: 0.0016217007650993764 | Valid Time: 0.004\n",
            "Epoch: 126\n",
            "Train Loss: 0.0015456008492037653 | Train Time: 0.059\n",
            "Valid Loss: 0.0015215461025945842 | Valid Time: 0.003\n",
            "Epoch: 127\n",
            "Train Loss: 0.0015759259345941245 | Train Time: 0.049\n",
            "Valid Loss: 0.0017118191462941468 | Valid Time: 0.005\n",
            "Epoch: 128\n",
            "Train Loss: 0.0016053348896093666 | Train Time: 0.049\n",
            "Valid Loss: 0.0017033618059940636 | Valid Time: 0.003\n",
            "Epoch: 129\n",
            "Train Loss: 0.0018490540678612888 | Train Time: 0.047\n",
            "Valid Loss: 0.002023862674832344 | Valid Time: 0.003\n",
            "Epoch: 130\n",
            "Train Loss: 0.0018130495911464096 | Train Time: 0.048\n",
            "Valid Loss: 0.0017530282493680716 | Valid Time: 0.003\n",
            "Epoch: 131\n",
            "Train Loss: 0.0016342472052201628 | Train Time: 0.050\n",
            "Valid Loss: 0.001537077536340803 | Valid Time: 0.003\n",
            "Epoch: 132\n",
            "Train Loss: 0.0014196387841366232 | Train Time: 0.046\n",
            "Valid Loss: 0.001427099050488323 | Valid Time: 0.003\n",
            "Epoch: 133\n",
            "Train Loss: 0.0014145188382826746 | Train Time: 0.045\n",
            "Valid Loss: 0.0013835689751431346 | Valid Time: 0.005\n",
            "Epoch: 134\n",
            "Train Loss: 0.0014801177429035306 | Train Time: 0.047\n",
            "Valid Loss: 0.0014358835760504007 | Valid Time: 0.006\n",
            "Epoch: 135\n",
            "Train Loss: 0.0015368466963991522 | Train Time: 0.045\n",
            "Valid Loss: 0.0016844134079292417 | Valid Time: 0.003\n",
            "Epoch: 136\n",
            "Train Loss: 0.001570888445712626 | Train Time: 0.046\n",
            "Valid Loss: 0.0014976994134485722 | Valid Time: 0.004\n",
            "Epoch: 137\n",
            "Train Loss: 0.001458544353954494 | Train Time: 0.053\n",
            "Valid Loss: 0.001454738201573491 | Valid Time: 0.003\n",
            "Epoch: 138\n",
            "Train Loss: 0.0014521325938403606 | Train Time: 0.050\n",
            "Valid Loss: 0.0015228301635943353 | Valid Time: 0.004\n",
            "Epoch: 139\n",
            "Train Loss: 0.0014763438724912704 | Train Time: 0.049\n",
            "Valid Loss: 0.001610401552170515 | Valid Time: 0.004\n",
            "Epoch: 140\n",
            "Train Loss: 0.0014731127303093672 | Train Time: 0.048\n",
            "Valid Loss: 0.0013779912842437625 | Valid Time: 0.003\n",
            "Epoch: 141\n",
            "Train Loss: 0.0013997256872244179 | Train Time: 0.052\n",
            "Valid Loss: 0.001266979263164103 | Valid Time: 0.003\n",
            "Epoch: 142\n",
            "Train Loss: 0.0013468428747728466 | Train Time: 0.052\n",
            "Valid Loss: 0.0014800929930061102 | Valid Time: 0.003\n",
            "Epoch: 143\n",
            "Train Loss: 0.0014057251974008977 | Train Time: 0.051\n",
            "Valid Loss: 0.0013776322593912482 | Valid Time: 0.005\n",
            "Epoch: 144\n",
            "Train Loss: 0.001730201137252152 | Train Time: 0.047\n",
            "Valid Loss: 0.0015487875789403915 | Valid Time: 0.003\n",
            "Epoch: 145\n",
            "Train Loss: 0.001866954122669995 | Train Time: 0.056\n",
            "Valid Loss: 0.0015699896030128002 | Valid Time: 0.004\n",
            "Epoch: 146\n",
            "Train Loss: 0.0016552859684452414 | Train Time: 0.054\n",
            "Valid Loss: 0.0014708517701365054 | Valid Time: 0.003\n",
            "Epoch: 147\n",
            "Train Loss: 0.0014089846750721335 | Train Time: 0.046\n",
            "Valid Loss: 0.001279350253753364 | Valid Time: 0.004\n",
            "Epoch: 148\n",
            "Train Loss: 0.001351982867345214 | Train Time: 0.048\n",
            "Valid Loss: 0.001533258764538914 | Valid Time: 0.004\n",
            "Epoch: 149\n",
            "Train Loss: 0.0013898935983888804 | Train Time: 0.052\n",
            "Valid Loss: 0.001387840835377574 | Valid Time: 0.003\n",
            "Epoch: 150\n",
            "Train Loss: 0.0014326737844385206 | Train Time: 0.050\n",
            "Valid Loss: 0.0014193904935382307 | Valid Time: 0.004\n",
            "Epoch: 151\n",
            "Train Loss: 0.0017412044340744614 | Train Time: 0.047\n",
            "Valid Loss: 0.001596685964614153 | Valid Time: 0.003\n",
            "Epoch: 152\n",
            "Train Loss: 0.001590071723330766 | Train Time: 0.049\n",
            "Valid Loss: 0.0015281697851605713 | Valid Time: 0.003\n",
            "Epoch: 153\n",
            "Train Loss: 0.0019651900161989032 | Train Time: 0.045\n",
            "Valid Loss: 0.0016759285354055464 | Valid Time: 0.003\n",
            "Epoch: 154\n",
            "Train Loss: 0.0020575403585098686 | Train Time: 0.047\n",
            "Valid Loss: 0.001440135296434164 | Valid Time: 0.006\n",
            "Epoch: 155\n",
            "Train Loss: 0.0014019535621628166 | Train Time: 0.053\n",
            "Valid Loss: 0.0013492903672158718 | Valid Time: 0.004\n",
            "Epoch: 156\n",
            "Train Loss: 0.001364064193330705 | Train Time: 0.047\n",
            "Valid Loss: 0.0013359038275666535 | Valid Time: 0.003\n",
            "Epoch: 157\n",
            "Train Loss: 0.001419045589864254 | Train Time: 0.046\n",
            "Valid Loss: 0.0015454769018106163 | Valid Time: 0.004\n",
            "Epoch: 158\n",
            "Train Loss: 0.001413139665964991 | Train Time: 0.051\n",
            "Valid Loss: 0.0011714851134456694 | Valid Time: 0.004\n",
            "Epoch: 159\n",
            "Train Loss: 0.0013454252504743636 | Train Time: 0.051\n",
            "Valid Loss: 0.001444555353373289 | Valid Time: 0.003\n",
            "Epoch: 160\n",
            "Train Loss: 0.0013289127848111093 | Train Time: 0.045\n",
            "Valid Loss: 0.0012010288191959262 | Valid Time: 0.003\n",
            "Epoch: 161\n",
            "Train Loss: 0.0014388343202881514 | Train Time: 0.047\n",
            "Valid Loss: 0.0014002129319123924 | Valid Time: 0.004\n",
            "Epoch: 162\n",
            "Train Loss: 0.0014773953822441398 | Train Time: 0.054\n",
            "Valid Loss: 0.0012298583169467747 | Valid Time: 0.003\n",
            "Epoch: 163\n",
            "Train Loss: 0.0018889400060288608 | Train Time: 0.046\n",
            "Valid Loss: 0.0016089114942587912 | Valid Time: 0.004\n",
            "Epoch: 164\n",
            "Train Loss: 0.001423977769445628 | Train Time: 0.052\n",
            "Valid Loss: 0.0012931993114762008 | Valid Time: 0.003\n",
            "Epoch: 165\n",
            "Train Loss: 0.0013628292363137007 | Train Time: 0.052\n",
            "Valid Loss: 0.001423444482497871 | Valid Time: 0.003\n",
            "Epoch: 166\n",
            "Train Loss: 0.0012990970280952752 | Train Time: 0.052\n",
            "Valid Loss: 0.0013068401021882892 | Valid Time: 0.003\n",
            "Epoch: 167\n",
            "Train Loss: 0.0013450460392050445 | Train Time: 0.047\n",
            "Valid Loss: 0.0011547785252332687 | Valid Time: 0.003\n",
            "Epoch: 168\n",
            "Train Loss: 0.0012399494764395059 | Train Time: 0.044\n",
            "Valid Loss: 0.0013649915345013142 | Valid Time: 0.003\n",
            "Epoch: 169\n",
            "Train Loss: 0.001309267827309668 | Train Time: 0.048\n",
            "Valid Loss: 0.001249450899194926 | Valid Time: 0.003\n",
            "Epoch: 170\n",
            "Train Loss: 0.0012211301364004612 | Train Time: 0.046\n",
            "Valid Loss: 0.0012819483526982367 | Valid Time: 0.008\n",
            "Epoch: 171\n",
            "Train Loss: 0.0012564191478304566 | Train Time: 0.052\n",
            "Valid Loss: 0.00113794015487656 | Valid Time: 0.003\n",
            "Epoch: 172\n",
            "Train Loss: 0.0012447747343685479 | Train Time: 0.047\n",
            "Valid Loss: 0.0012941411114297807 | Valid Time: 0.003\n",
            "Epoch: 173\n",
            "Train Loss: 0.0012130942428484558 | Train Time: 0.051\n",
            "Valid Loss: 0.0011191765661351383 | Valid Time: 0.003\n",
            "Epoch: 174\n",
            "Train Loss: 0.0012218039366416634 | Train Time: 0.050\n",
            "Valid Loss: 0.0012574660358950496 | Valid Time: 0.003\n",
            "Epoch: 175\n",
            "Train Loss: 0.0012510207132436335 | Train Time: 0.045\n",
            "Valid Loss: 0.0011485590948723257 | Valid Time: 0.004\n",
            "Epoch: 176\n",
            "Train Loss: 0.001436485955491662 | Train Time: 0.045\n",
            "Valid Loss: 0.0017788390978239477 | Valid Time: 0.003\n",
            "Epoch: 177\n",
            "Train Loss: 0.0016092973877675832 | Train Time: 0.052\n",
            "Valid Loss: 0.0011412578169256449 | Valid Time: 0.004\n",
            "Epoch: 178\n",
            "Train Loss: 0.0013084579026326538 | Train Time: 0.048\n",
            "Valid Loss: 0.001182139152660966 | Valid Time: 0.005\n",
            "Epoch: 179\n",
            "Train Loss: 0.0012718223268166184 | Train Time: 0.045\n",
            "Valid Loss: 0.0014671127428300679 | Valid Time: 0.003\n",
            "Epoch: 180\n",
            "Train Loss: 0.0014387170551344753 | Train Time: 0.047\n",
            "Valid Loss: 0.0010541654482949525 | Valid Time: 0.003\n",
            "Epoch: 181\n",
            "Train Loss: 0.0014091248158365488 | Train Time: 0.051\n",
            "Valid Loss: 0.001441782049369067 | Valid Time: 0.003\n",
            "Epoch: 182\n",
            "Train Loss: 0.001413977169431746 | Train Time: 0.045\n",
            "Valid Loss: 0.0012144208885729313 | Valid Time: 0.006\n",
            "Epoch: 183\n",
            "Train Loss: 0.0012527979561127722 | Train Time: 0.048\n",
            "Valid Loss: 0.0011199998552910984 | Valid Time: 0.006\n",
            "Epoch: 184\n",
            "Train Loss: 0.001203447673469782 | Train Time: 0.045\n",
            "Valid Loss: 0.0010649906762409955 | Valid Time: 0.003\n",
            "Epoch: 185\n",
            "Train Loss: 0.0012297095614485442 | Train Time: 0.049\n",
            "Valid Loss: 0.0013148100697435439 | Valid Time: 0.003\n",
            "Epoch: 186\n",
            "Train Loss: 0.001244936801958829 | Train Time: 0.047\n",
            "Valid Loss: 0.001064400770701468 | Valid Time: 0.004\n",
            "Epoch: 187\n",
            "Train Loss: 0.0011618575023021548 | Train Time: 0.045\n",
            "Valid Loss: 0.001065824122633785 | Valid Time: 0.003\n",
            "Epoch: 188\n",
            "Train Loss: 0.001198501663748175 | Train Time: 0.044\n",
            "Valid Loss: 0.0014073889469727874 | Valid Time: 0.003\n",
            "Epoch: 189\n",
            "Train Loss: 0.0012649041833356022 | Train Time: 0.049\n",
            "Valid Loss: 0.00111513226875104 | Valid Time: 0.005\n",
            "Epoch: 190\n",
            "Train Loss: 0.001210151705890894 | Train Time: 0.051\n",
            "Valid Loss: 0.0013400345342233777 | Valid Time: 0.006\n",
            "Epoch: 191\n",
            "Train Loss: 0.0016470524831674993 | Train Time: 0.047\n",
            "Valid Loss: 0.0014747756067663431 | Valid Time: 0.003\n",
            "Epoch: 192\n",
            "Train Loss: 0.0015096947259735315 | Train Time: 0.052\n",
            "Valid Loss: 0.0021487020421773195 | Valid Time: 0.003\n",
            "Epoch: 193\n",
            "Train Loss: 0.0018156122299842537 | Train Time: 0.048\n",
            "Valid Loss: 0.0016990348231047392 | Valid Time: 0.004\n",
            "Epoch: 194\n",
            "Train Loss: 0.0015573189361020924 | Train Time: 0.056\n",
            "Valid Loss: 0.0014372907462529838 | Valid Time: 0.004\n",
            "Epoch: 195\n",
            "Train Loss: 0.0012937454972416162 | Train Time: 0.050\n",
            "Valid Loss: 0.0010747112683020532 | Valid Time: 0.004\n",
            "Epoch: 196\n",
            "Train Loss: 0.0011345163569785655 | Train Time: 0.056\n",
            "Valid Loss: 0.001090375881176442 | Valid Time: 0.004\n",
            "Epoch: 197\n",
            "Train Loss: 0.0011728523357305675 | Train Time: 0.047\n",
            "Valid Loss: 0.0010727260378189385 | Valid Time: 0.004\n",
            "Epoch: 198\n",
            "Train Loss: 0.0012398465885780751 | Train Time: 0.051\n",
            "Valid Loss: 0.0010087343398481607 | Valid Time: 0.003\n",
            "Epoch: 199\n",
            "Train Loss: 0.0011727752396836876 | Train Time: 0.049\n",
            "Valid Loss: 0.0012747677974402905 | Valid Time: 0.004\n",
            "Epoch: 200\n",
            "Train Loss: 0.001444720389554277 | Train Time: 0.049\n",
            "Valid Loss: 0.0012583189527504146 | Valid Time: 0.003\n",
            "Epoch: 201\n",
            "Train Loss: 0.0015935529489070177 | Train Time: 0.047\n",
            "Valid Loss: 0.001712835335638374 | Valid Time: 0.003\n",
            "Epoch: 202\n",
            "Train Loss: 0.0014666140312328934 | Train Time: 0.058\n",
            "Valid Loss: 0.0012258377973921597 | Valid Time: 0.006\n",
            "Epoch: 203\n",
            "Train Loss: 0.0017231677891686558 | Train Time: 0.047\n",
            "Valid Loss: 0.0012713357573375106 | Valid Time: 0.004\n",
            "Epoch: 204\n",
            "Train Loss: 0.0017844516900368036 | Train Time: 0.046\n",
            "Valid Loss: 0.002036211604718119 | Valid Time: 0.003\n",
            "Epoch: 205\n",
            "Train Loss: 0.0014803890022449195 | Train Time: 0.048\n",
            "Valid Loss: 0.0014885279233567417 | Valid Time: 0.003\n",
            "Epoch: 206\n",
            "Train Loss: 0.0013658487587235868 | Train Time: 0.051\n",
            "Valid Loss: 0.0013891768758185208 | Valid Time: 0.004\n",
            "Epoch: 207\n",
            "Train Loss: 0.0014327850774861872 | Train Time: 0.046\n",
            "Valid Loss: 0.0011359680793248117 | Valid Time: 0.003\n",
            "Epoch: 208\n",
            "Train Loss: 0.001483990828273818 | Train Time: 0.052\n",
            "Valid Loss: 0.0022702434798702598 | Valid Time: 0.003\n",
            "Epoch: 209\n",
            "Train Loss: 0.001630736602237448 | Train Time: 0.046\n",
            "Valid Loss: 0.0016296739340759814 | Valid Time: 0.003\n",
            "Epoch: 210\n",
            "Train Loss: 0.0015309872571378947 | Train Time: 0.050\n",
            "Valid Loss: 0.0009690797014627606 | Valid Time: 0.004\n",
            "Epoch: 211\n",
            "Train Loss: 0.0012455916788894684 | Train Time: 0.052\n",
            "Valid Loss: 0.0009756301005836576 | Valid Time: 0.003\n",
            "Epoch: 212\n",
            "Train Loss: 0.0011693346546962856 | Train Time: 0.044\n",
            "Valid Loss: 0.0010970711591653526 | Valid Time: 0.004\n",
            "Epoch: 213\n",
            "Train Loss: 0.001097673160256818 | Train Time: 0.045\n",
            "Valid Loss: 0.001035387598676607 | Valid Time: 0.003\n",
            "Epoch: 214\n",
            "Train Loss: 0.001020317105576396 | Train Time: 0.051\n",
            "Valid Loss: 0.0009561618498992175 | Valid Time: 0.004\n",
            "Epoch: 215\n",
            "Train Loss: 0.0010617392719723285 | Train Time: 0.048\n",
            "Valid Loss: 0.0011135242821183056 | Valid Time: 0.003\n",
            "Epoch: 216\n",
            "Train Loss: 0.0011006778455339371 | Train Time: 0.045\n",
            "Valid Loss: 0.0009731650352478027 | Valid Time: 0.003\n",
            "Epoch: 217\n",
            "Train Loss: 0.0010495216061826794 | Train Time: 0.052\n",
            "Valid Loss: 0.0012424307060427964 | Valid Time: 0.003\n",
            "Epoch: 218\n",
            "Train Loss: 0.001144846307579428 | Train Time: 0.050\n",
            "Valid Loss: 0.0011495117796584964 | Valid Time: 0.005\n",
            "Epoch: 219\n",
            "Train Loss: 0.001316398219205439 | Train Time: 0.047\n",
            "Valid Loss: 0.0011812798329629004 | Valid Time: 0.003\n",
            "Epoch: 220\n",
            "Train Loss: 0.001150654279626906 | Train Time: 0.045\n",
            "Valid Loss: 0.0010972580057568848 | Valid Time: 0.004\n",
            "Epoch: 221\n",
            "Train Loss: 0.0011872727889567613 | Train Time: 0.054\n",
            "Valid Loss: 0.001052195206284523 | Valid Time: 0.004\n",
            "Epoch: 222\n",
            "Train Loss: 0.0010902827081736178 | Train Time: 0.061\n",
            "Valid Loss: 0.0009214868769049644 | Valid Time: 0.006\n",
            "Epoch: 223\n",
            "Train Loss: 0.001019223459297791 | Train Time: 0.046\n",
            "Valid Loss: 0.0010339475120417774 | Valid Time: 0.003\n",
            "Epoch: 224\n",
            "Train Loss: 0.0010582527960650624 | Train Time: 0.044\n",
            "Valid Loss: 0.0009822703141253442 | Valid Time: 0.006\n",
            "Epoch: 225\n",
            "Train Loss: 0.0010008452169131487 | Train Time: 0.049\n",
            "Valid Loss: 0.001112869766075164 | Valid Time: 0.003\n",
            "Epoch: 226\n",
            "Train Loss: 0.0011006366112269461 | Train Time: 0.047\n",
            "Valid Loss: 0.001073672843631357 | Valid Time: 0.004\n",
            "Epoch: 227\n",
            "Train Loss: 0.0010788899380713701 | Train Time: 0.053\n",
            "Valid Loss: 0.0009971745894290507 | Valid Time: 0.003\n",
            "Epoch: 228\n",
            "Train Loss: 0.0010232900851406157 | Train Time: 0.045\n",
            "Valid Loss: 0.0010370589443482459 | Valid Time: 0.003\n",
            "Epoch: 229\n",
            "Train Loss: 0.0011368575564119966 | Train Time: 0.047\n",
            "Valid Loss: 0.001406955358106643 | Valid Time: 0.003\n",
            "Epoch: 230\n",
            "Train Loss: 0.001031997421523556 | Train Time: 0.055\n",
            "Valid Loss: 0.0012190615525469184 | Valid Time: 0.003\n",
            "Epoch: 231\n",
            "Train Loss: 0.0011707825120538472 | Train Time: 0.045\n",
            "Valid Loss: 0.0009769513853825629 | Valid Time: 0.003\n",
            "Epoch: 232\n",
            "Train Loss: 0.0012861010152846574 | Train Time: 0.045\n",
            "Valid Loss: 0.0012203327496536076 | Valid Time: 0.003\n",
            "Epoch: 233\n",
            "Train Loss: 0.0013059009797871113 | Train Time: 0.050\n",
            "Valid Loss: 0.0008784543606452644 | Valid Time: 0.003\n",
            "Epoch: 234\n",
            "Train Loss: 0.0010034336475655437 | Train Time: 0.053\n",
            "Valid Loss: 0.000981389166554436 | Valid Time: 0.004\n",
            "Epoch: 235\n",
            "Train Loss: 0.0011352623580023647 | Train Time: 0.044\n",
            "Valid Loss: 0.0012356506194919348 | Valid Time: 0.004\n",
            "Epoch: 236\n",
            "Train Loss: 0.0010354283207561822 | Train Time: 0.045\n",
            "Valid Loss: 0.0010273554944433272 | Valid Time: 0.003\n",
            "Epoch: 237\n",
            "Train Loss: 0.0010580871428828686 | Train Time: 0.050\n",
            "Valid Loss: 0.0008722939237486571 | Valid Time: 0.003\n",
            "Epoch: 238\n",
            "Train Loss: 0.0009210029558744282 | Train Time: 0.046\n",
            "Valid Loss: 0.000843406975036487 | Valid Time: 0.003\n",
            "Epoch: 239\n",
            "Train Loss: 0.0009872996655758471 | Train Time: 0.048\n",
            "Valid Loss: 0.0009430515638086945 | Valid Time: 0.004\n",
            "Epoch: 240\n",
            "Train Loss: 0.0012257803755346686 | Train Time: 0.046\n",
            "Valid Loss: 0.0010220238764304668 | Valid Time: 0.005\n",
            "Epoch: 241\n",
            "Train Loss: 0.0013076221453957259 | Train Time: 0.062\n",
            "Valid Loss: 0.001359212095849216 | Valid Time: 0.003\n",
            "Epoch: 242\n",
            "Train Loss: 0.0011579277808777988 | Train Time: 0.050\n",
            "Valid Loss: 0.0008949342009145766 | Valid Time: 0.003\n",
            "Epoch: 243\n",
            "Train Loss: 0.000990313570946455 | Train Time: 0.046\n",
            "Valid Loss: 0.000887915026396513 | Valid Time: 0.003\n",
            "Epoch: 244\n",
            "Train Loss: 0.0009638095158152282 | Train Time: 0.048\n",
            "Valid Loss: 0.0009159422188531607 | Valid Time: 0.003\n",
            "Epoch: 245\n",
            "Train Loss: 0.0009828744863625617 | Train Time: 0.045\n",
            "Valid Loss: 0.0009956547582987696 | Valid Time: 0.004\n",
            "Epoch: 246\n",
            "Train Loss: 0.0010316491301637144 | Train Time: 0.046\n",
            "Valid Loss: 0.0008638883009552956 | Valid Time: 0.005\n",
            "Epoch: 247\n",
            "Train Loss: 0.0009722338698338717 | Train Time: 0.053\n",
            "Valid Loss: 0.0010351759265176952 | Valid Time: 0.003\n",
            "Epoch: 248\n",
            "Train Loss: 0.000923822371987626 | Train Time: 0.044\n",
            "Valid Loss: 0.001119317952543497 | Valid Time: 0.003\n",
            "Epoch: 249\n",
            "Train Loss: 0.0010325869254302234 | Train Time: 0.047\n",
            "Valid Loss: 0.0008891828474588692 | Valid Time: 0.003\n",
            "Epoch: 250\n",
            "Train Loss: 0.0011499571206513791 | Train Time: 0.044\n",
            "Valid Loss: 0.001196696946863085 | Valid Time: 0.007\n",
            "Epoch: 251\n",
            "Train Loss: 0.0010234286368358881 | Train Time: 0.048\n",
            "Valid Loss: 0.000985417194897309 | Valid Time: 0.003\n",
            "Epoch: 252\n",
            "Train Loss: 0.001032672793371603 | Train Time: 0.052\n",
            "Valid Loss: 0.0010803057230077684 | Valid Time: 0.003\n",
            "Epoch: 253\n",
            "Train Loss: 0.0009499318897724151 | Train Time: 0.046\n",
            "Valid Loss: 0.0009024912724271417 | Valid Time: 0.003\n",
            "Epoch: 254\n",
            "Train Loss: 0.0009443785238545388 | Train Time: 0.049\n",
            "Valid Loss: 0.0009830996277742088 | Valid Time: 0.003\n",
            "Epoch: 255\n",
            "Train Loss: 0.0009998677647672593 | Train Time: 0.052\n",
            "Valid Loss: 0.001197889563627541 | Valid Time: 0.003\n",
            "Epoch: 256\n",
            "Train Loss: 0.0011425014352425932 | Train Time: 0.047\n",
            "Valid Loss: 0.0008521915297023952 | Valid Time: 0.004\n",
            "Epoch: 257\n",
            "Train Loss: 0.0009711659979075194 | Train Time: 0.046\n",
            "Valid Loss: 0.0008877005602698773 | Valid Time: 0.003\n",
            "Epoch: 258\n",
            "Train Loss: 0.0009971632855013013 | Train Time: 0.054\n",
            "Valid Loss: 0.0011299409379716963 | Valid Time: 0.003\n",
            "Epoch: 259\n",
            "Train Loss: 0.000978442165069282 | Train Time: 0.045\n",
            "Valid Loss: 0.0008419690420851111 | Valid Time: 0.003\n",
            "Epoch: 260\n",
            "Train Loss: 0.000901319709373638 | Train Time: 0.053\n",
            "Valid Loss: 0.0008346882532350719 | Valid Time: 0.006\n",
            "Epoch: 261\n",
            "Train Loss: 0.0008884993963874877 | Train Time: 0.050\n",
            "Valid Loss: 0.0009160526096820831 | Valid Time: 0.003\n",
            "Epoch: 262\n",
            "Train Loss: 0.0009301630139816553 | Train Time: 0.049\n",
            "Valid Loss: 0.0008449539018329233 | Valid Time: 0.003\n",
            "Epoch: 263\n",
            "Train Loss: 0.0008900535875000059 | Train Time: 0.046\n",
            "Valid Loss: 0.001118950662203133 | Valid Time: 0.003\n",
            "Epoch: 264\n",
            "Train Loss: 0.0008969940594397485 | Train Time: 0.044\n",
            "Valid Loss: 0.0008373874006792903 | Valid Time: 0.004\n",
            "Epoch: 265\n",
            "Train Loss: 0.000998399656964466 | Train Time: 0.051\n",
            "Valid Loss: 0.0011845898698084056 | Valid Time: 0.003\n",
            "Epoch: 266\n",
            "Train Loss: 0.0010181099642068148 | Train Time: 0.045\n",
            "Valid Loss: 0.000955301831709221 | Valid Time: 0.007\n",
            "Epoch: 267\n",
            "Train Loss: 0.001068070891778916 | Train Time: 0.053\n",
            "Valid Loss: 0.0009323185076937079 | Valid Time: 0.003\n",
            "Epoch: 268\n",
            "Train Loss: 0.001191326614934951 | Train Time: 0.047\n",
            "Valid Loss: 0.0008686489309184253 | Valid Time: 0.004\n",
            "Epoch: 269\n",
            "Train Loss: 0.001550347334705293 | Train Time: 0.044\n",
            "Valid Loss: 0.0013418614980764687 | Valid Time: 0.003\n",
            "Epoch: 270\n",
            "Train Loss: 0.0015420195821207016 | Train Time: 0.045\n",
            "Valid Loss: 0.0015380714321509004 | Valid Time: 0.005\n",
            "Epoch: 271\n",
            "Train Loss: 0.0016089480486698449 | Train Time: 0.052\n",
            "Valid Loss: 0.0011318748584017158 | Valid Time: 0.003\n",
            "Epoch: 272\n",
            "Train Loss: 0.0010105007968377322 | Train Time: 0.047\n",
            "Valid Loss: 0.000871294061653316 | Valid Time: 0.003\n",
            "Epoch: 273\n",
            "Train Loss: 0.0008940072904806585 | Train Time: 0.050\n",
            "Valid Loss: 0.0010600157547742128 | Valid Time: 0.004\n",
            "Epoch: 274\n",
            "Train Loss: 0.0009731145051773638 | Train Time: 0.051\n",
            "Valid Loss: 0.0008860857342369854 | Valid Time: 0.003\n",
            "Epoch: 275\n",
            "Train Loss: 0.0009650172491092235 | Train Time: 0.045\n",
            "Valid Loss: 0.0010538813367020339 | Valid Time: 0.003\n",
            "Epoch: 276\n",
            "Train Loss: 0.0009833413234446198 | Train Time: 0.043\n",
            "Valid Loss: 0.0008579373243264854 | Valid Time: 0.005\n",
            "Epoch: 277\n",
            "Train Loss: 0.0009334957227110863 | Train Time: 0.047\n",
            "Valid Loss: 0.000902443309314549 | Valid Time: 0.003\n",
            "Epoch: 278\n",
            "Train Loss: 0.001161697937641293 | Train Time: 0.043\n",
            "Valid Loss: 0.001209912879858166 | Valid Time: 0.003\n",
            "Epoch: 279\n",
            "Train Loss: 0.0013476857275236398 | Train Time: 0.055\n",
            "Valid Loss: 0.0013069494161754847 | Valid Time: 0.004\n",
            "Epoch: 280\n",
            "Train Loss: 0.0012081048334948719 | Train Time: 0.055\n",
            "Valid Loss: 0.0009549079986754805 | Valid Time: 0.003\n",
            "Epoch: 281\n",
            "Train Loss: 0.0012024344759993255 | Train Time: 0.045\n",
            "Valid Loss: 0.0021251743310131133 | Valid Time: 0.003\n",
            "Epoch: 282\n",
            "Train Loss: 0.0017066713015083223 | Train Time: 0.045\n",
            "Valid Loss: 0.0014644889743067324 | Valid Time: 0.003\n",
            "Epoch: 283\n",
            "Train Loss: 0.001293684501433745 | Train Time: 0.050\n",
            "Valid Loss: 0.0015693073510192335 | Valid Time: 0.003\n",
            "Epoch: 284\n",
            "Train Loss: 0.0012345816066954285 | Train Time: 0.046\n",
            "Valid Loss: 0.0011446630815044045 | Valid Time: 0.003\n",
            "Epoch: 285\n",
            "Train Loss: 0.0011646457016468049 | Train Time: 0.044\n",
            "Valid Loss: 0.0009063554171007127 | Valid Time: 0.003\n",
            "Epoch: 286\n",
            "Train Loss: 0.0009515363955870271 | Train Time: 0.048\n",
            "Valid Loss: 0.0008527305035386235 | Valid Time: 0.003\n",
            "Epoch: 287\n",
            "Train Loss: 0.0009862355247605592 | Train Time: 0.046\n",
            "Valid Loss: 0.0008638330909889191 | Valid Time: 0.003\n",
            "Epoch: 288\n",
            "Train Loss: 0.0009138138266280293 | Train Time: 0.054\n",
            "Valid Loss: 0.0008952653734013438 | Valid Time: 0.005\n",
            "Epoch: 289\n",
            "Train Loss: 0.0009211976022925228 | Train Time: 0.054\n",
            "Valid Loss: 0.0011192121310159564 | Valid Time: 0.003\n",
            "Epoch: 290\n",
            "Train Loss: 0.0009146619820967316 | Train Time: 0.045\n",
            "Valid Loss: 0.001274558249861002 | Valid Time: 0.003\n",
            "Epoch: 291\n",
            "Train Loss: 0.0010777988645713776 | Train Time: 0.051\n",
            "Valid Loss: 0.001019653951516375 | Valid Time: 0.003\n",
            "Epoch: 292\n",
            "Train Loss: 0.0009613900387194007 | Train Time: 0.049\n",
            "Valid Loss: 0.0008085357258096337 | Valid Time: 0.003\n",
            "Epoch: 293\n",
            "Train Loss: 0.0009282762883231043 | Train Time: 0.044\n",
            "Valid Loss: 0.0008404053805861622 | Valid Time: 0.003\n",
            "Epoch: 294\n",
            "Train Loss: 0.0011396089976187795 | Train Time: 0.045\n",
            "Valid Loss: 0.001080289832316339 | Valid Time: 0.003\n",
            "Epoch: 295\n",
            "Train Loss: 0.0009430814010556787 | Train Time: 0.046\n",
            "Valid Loss: 0.0010557693312875926 | Valid Time: 0.003\n",
            "Epoch: 296\n",
            "Train Loss: 0.0010191906127147376 | Train Time: 0.048\n",
            "Valid Loss: 0.000932280148845166 | Valid Time: 0.003\n",
            "Epoch: 297\n",
            "Train Loss: 0.0009506572561804206 | Train Time: 0.047\n",
            "Valid Loss: 0.0010672809439711273 | Valid Time: 0.004\n",
            "Epoch: 298\n",
            "Train Loss: 0.000940335396444425 | Train Time: 0.052\n",
            "Valid Loss: 0.0009134817228186876 | Valid Time: 0.003\n",
            "Epoch: 299\n",
            "Train Loss: 0.0009649108804296702 | Train Time: 0.055\n",
            "Valid Loss: 0.0014191229129210114 | Valid Time: 0.004\n",
            "Epoch: 300\n",
            "Train Loss: 0.0015191953454632312 | Train Time: 0.049\n",
            "Valid Loss: 0.001194348733406514 | Valid Time: 0.003\n",
            "Epoch: 301\n",
            "Train Loss: 0.0016411730088293553 | Train Time: 0.051\n",
            "Valid Loss: 0.00134690961567685 | Valid Time: 0.004\n",
            "Epoch: 302\n",
            "Train Loss: 0.0009945700876414776 | Train Time: 0.046\n",
            "Valid Loss: 0.000859631021739915 | Valid Time: 0.007\n",
            "Epoch: 303\n",
            "Train Loss: 0.0009403165138792246 | Train Time: 0.072\n",
            "Valid Loss: 0.0010940899373963475 | Valid Time: 0.006\n",
            "Epoch: 304\n",
            "Train Loss: 0.0009552687464747578 | Train Time: 0.070\n",
            "Valid Loss: 0.0008786949620116502 | Valid Time: 0.006\n",
            "Epoch: 305\n",
            "Train Loss: 0.0009926197293680162 | Train Time: 0.068\n",
            "Valid Loss: 0.0008756981987971812 | Valid Time: 0.006\n",
            "Epoch: 306\n",
            "Train Loss: 0.0012774312461260706 | Train Time: 0.066\n",
            "Valid Loss: 0.0011615139083005488 | Valid Time: 0.005\n",
            "Epoch: 307\n",
            "Train Loss: 0.0018629196099936962 | Train Time: 0.077\n",
            "Valid Loss: 0.0013825593632645905 | Valid Time: 0.005\n",
            "Epoch: 308\n",
            "Train Loss: 0.0015051069029141217 | Train Time: 0.065\n",
            "Valid Loss: 0.001817078737076372 | Valid Time: 0.005\n",
            "Epoch: 309\n",
            "Train Loss: 0.0013050094246864318 | Train Time: 0.080\n",
            "Valid Loss: 0.0010296414548065513 | Valid Time: 0.006\n",
            "Epoch: 310\n",
            "Train Loss: 0.0010385421919636428 | Train Time: 0.074\n",
            "Valid Loss: 0.0010050485143437982 | Valid Time: 0.005\n",
            "Epoch: 311\n",
            "Train Loss: 0.0009368405444547534 | Train Time: 0.065\n",
            "Valid Loss: 0.0008245720528066158 | Valid Time: 0.005\n",
            "Epoch: 312\n",
            "Train Loss: 0.0009252595948055387 | Train Time: 0.067\n",
            "Valid Loss: 0.0008654180273879319 | Valid Time: 0.005\n",
            "Epoch: 313\n",
            "Train Loss: 0.0008190506778191775 | Train Time: 0.078\n",
            "Valid Loss: 0.0007795068377163261 | Valid Time: 0.006\n",
            "Epoch: 314\n",
            "Train Loss: 0.0008239374787081033 | Train Time: 0.070\n",
            "Valid Loss: 0.0008003510301932693 | Valid Time: 0.005\n",
            "Epoch: 315\n",
            "Train Loss: 0.0008494864800013602 | Train Time: 0.067\n",
            "Valid Loss: 0.0008220818126574159 | Valid Time: 0.005\n",
            "Epoch: 316\n",
            "Train Loss: 0.000896959425881505 | Train Time: 0.070\n",
            "Valid Loss: 0.0009088947845157236 | Valid Time: 0.005\n",
            "Epoch: 317\n",
            "Train Loss: 0.0009362135548144579 | Train Time: 0.072\n",
            "Valid Loss: 0.0009219007624778897 | Valid Time: 0.007\n",
            "Epoch: 318\n",
            "Train Loss: 0.0011531485593877732 | Train Time: 0.066\n",
            "Valid Loss: 0.0013509173295460641 | Valid Time: 0.005\n",
            "Epoch: 319\n",
            "Train Loss: 0.0013580970233306288 | Train Time: 0.071\n",
            "Valid Loss: 0.0021402963902801275 | Valid Time: 0.005\n",
            "Epoch: 320\n",
            "Train Loss: 0.0016193286224734037 | Train Time: 0.065\n",
            "Valid Loss: 0.0009705575357656926 | Valid Time: 0.005\n",
            "Epoch: 321\n",
            "Train Loss: 0.00125370800960809 | Train Time: 0.070\n",
            "Valid Loss: 0.0007790048839524388 | Valid Time: 0.004\n",
            "Epoch: 322\n",
            "Train Loss: 0.0008356841746717692 | Train Time: 0.069\n",
            "Valid Loss: 0.0008833433967083693 | Valid Time: 0.005\n",
            "Epoch: 323\n",
            "Train Loss: 0.000786305801011622 | Train Time: 0.066\n",
            "Valid Loss: 0.0007662524294573814 | Valid Time: 0.005\n",
            "Epoch: 324\n",
            "Train Loss: 0.0008749471744522452 | Train Time: 0.062\n",
            "Valid Loss: 0.000730729108909145 | Valid Time: 0.005\n",
            "Epoch: 325\n",
            "Train Loss: 0.0008676151221152395 | Train Time: 0.071\n",
            "Valid Loss: 0.0008043495763558894 | Valid Time: 0.005\n",
            "Epoch: 326\n",
            "Train Loss: 0.0009532326948828995 | Train Time: 0.076\n",
            "Valid Loss: 0.0007899257179815322 | Valid Time: 0.005\n",
            "Epoch: 327\n",
            "Train Loss: 0.0009005269734188914 | Train Time: 0.081\n",
            "Valid Loss: 0.0011059482349082828 | Valid Time: 0.005\n",
            "Epoch: 328\n",
            "Train Loss: 0.0011033274116925896 | Train Time: 0.073\n",
            "Valid Loss: 0.0008761264325585216 | Valid Time: 0.006\n",
            "Epoch: 329\n",
            "Train Loss: 0.0009617376839742064 | Train Time: 0.068\n",
            "Valid Loss: 0.001137866172939539 | Valid Time: 0.005\n",
            "Epoch: 330\n",
            "Train Loss: 0.0010615004401188343 | Train Time: 0.064\n",
            "Valid Loss: 0.0014912053011357784 | Valid Time: 0.007\n",
            "Epoch: 331\n",
            "Train Loss: 0.0011812336975708603 | Train Time: 0.082\n",
            "Valid Loss: 0.0008173748792614788 | Valid Time: 0.006\n",
            "Epoch: 332\n",
            "Train Loss: 0.001073797809658572 | Train Time: 0.073\n",
            "Valid Loss: 0.0009714586194604635 | Valid Time: 0.005\n",
            "Epoch: 333\n",
            "Train Loss: 0.0009321117773652077 | Train Time: 0.071\n",
            "Valid Loss: 0.0010074915771838278 | Valid Time: 0.007\n",
            "Epoch: 334\n",
            "Train Loss: 0.0009282447339501232 | Train Time: 0.055\n",
            "Valid Loss: 0.000806978961918503 | Valid Time: 0.003\n",
            "Epoch: 335\n",
            "Train Loss: 0.0008968134061433375 | Train Time: 0.045\n",
            "Valid Loss: 0.0008430948364548385 | Valid Time: 0.003\n",
            "Epoch: 336\n",
            "Train Loss: 0.0008458998112473637 | Train Time: 0.044\n",
            "Valid Loss: 0.0007530278817284852 | Valid Time: 0.003\n",
            "Epoch: 337\n",
            "Train Loss: 0.0008133567636832595 | Train Time: 0.047\n",
            "Valid Loss: 0.0007841296901460737 | Valid Time: 0.003\n",
            "Epoch: 338\n",
            "Train Loss: 0.0007903848425485193 | Train Time: 0.046\n",
            "Valid Loss: 0.0007674511289224029 | Valid Time: 0.003\n",
            "Epoch: 339\n",
            "Train Loss: 0.0007827580790035427 | Train Time: 0.049\n",
            "Valid Loss: 0.000871731317602098 | Valid Time: 0.004\n",
            "Epoch: 340\n",
            "Train Loss: 0.0008436703879851848 | Train Time: 0.047\n",
            "Valid Loss: 0.0009378745453432202 | Valid Time: 0.003\n",
            "Epoch: 341\n",
            "Train Loss: 0.000906371750170365 | Train Time: 0.050\n",
            "Valid Loss: 0.0008734168950468302 | Valid Time: 0.003\n",
            "Epoch: 342\n",
            "Train Loss: 0.0008193541376385838 | Train Time: 0.044\n",
            "Valid Loss: 0.0007923357770778239 | Valid Time: 0.003\n",
            "Epoch: 343\n",
            "Train Loss: 0.0008563930459786206 | Train Time: 0.047\n",
            "Valid Loss: 0.0008041590044740587 | Valid Time: 0.009\n",
            "Epoch: 344\n",
            "Train Loss: 0.0008620492299087346 | Train Time: 0.054\n",
            "Valid Loss: 0.0007646094309166074 | Valid Time: 0.003\n",
            "Epoch: 345\n",
            "Train Loss: 0.000817910925252363 | Train Time: 0.045\n",
            "Valid Loss: 0.0008216174610424787 | Valid Time: 0.003\n",
            "Epoch: 346\n",
            "Train Loss: 0.0008134605188388378 | Train Time: 0.043\n",
            "Valid Loss: 0.0008084678556770086 | Valid Time: 0.003\n",
            "Epoch: 347\n",
            "Train Loss: 0.0008247574674896896 | Train Time: 0.054\n",
            "Valid Loss: 0.0007130545272957534 | Valid Time: 0.003\n",
            "Epoch: 348\n",
            "Train Loss: 0.0007816218072548509 | Train Time: 0.047\n",
            "Valid Loss: 0.0007226047455333173 | Valid Time: 0.004\n",
            "Epoch: 349\n",
            "Train Loss: 0.0007904812518972903 | Train Time: 0.045\n",
            "Valid Loss: 0.0007624072604812682 | Valid Time: 0.003\n",
            "Epoch: 350\n",
            "Train Loss: 0.0008226497448049486 | Train Time: 0.050\n",
            "Valid Loss: 0.0007324287435039878 | Valid Time: 0.003\n",
            "Epoch: 351\n",
            "Train Loss: 0.0007959987153299153 | Train Time: 0.046\n",
            "Valid Loss: 0.0008276380249299109 | Valid Time: 0.007\n",
            "Epoch: 352\n",
            "Train Loss: 0.0009742397465743125 | Train Time: 0.045\n",
            "Valid Loss: 0.0008672991825733334 | Valid Time: 0.004\n",
            "Epoch: 353\n",
            "Train Loss: 0.0010719493846409022 | Train Time: 0.044\n",
            "Valid Loss: 0.0011254741111770272 | Valid Time: 0.003\n",
            "Epoch: 354\n",
            "Train Loss: 0.0010223427263554186 | Train Time: 0.050\n",
            "Valid Loss: 0.0009209932468365878 | Valid Time: 0.003\n",
            "Epoch: 355\n",
            "Train Loss: 0.0009135268104728311 | Train Time: 0.046\n",
            "Valid Loss: 0.001060135691659525 | Valid Time: 0.005\n",
            "Epoch: 356\n",
            "Train Loss: 0.0011683123419061303 | Train Time: 0.044\n",
            "Valid Loss: 0.0008034689235500991 | Valid Time: 0.003\n",
            "Epoch: 357\n",
            "Train Loss: 0.001147594762733206 | Train Time: 0.046\n",
            "Valid Loss: 0.0011322822538204491 | Valid Time: 0.003\n",
            "Epoch: 358\n",
            "Train Loss: 0.0010473570844624191 | Train Time: 0.049\n",
            "Valid Loss: 0.000730732484953478 | Valid Time: 0.003\n",
            "Epoch: 359\n",
            "Train Loss: 0.0008687643276061863 | Train Time: 0.045\n",
            "Valid Loss: 0.0010174854251090437 | Valid Time: 0.004\n",
            "Epoch: 360\n",
            "Train Loss: 0.001096481952117756 | Train Time: 0.049\n",
            "Valid Loss: 0.000990585220279172 | Valid Time: 0.004\n",
            "Epoch: 361\n",
            "Train Loss: 0.0011770380544476212 | Train Time: 0.045\n",
            "Valid Loss: 0.0009418631962034851 | Valid Time: 0.003\n",
            "Epoch: 362\n",
            "Train Loss: 0.000989258533809334 | Train Time: 0.053\n",
            "Valid Loss: 0.0009891580848488957 | Valid Time: 0.004\n",
            "Epoch: 363\n",
            "Train Loss: 0.0010876222688239068 | Train Time: 0.059\n",
            "Valid Loss: 0.0015833138022571802 | Valid Time: 0.003\n",
            "Epoch: 364\n",
            "Train Loss: 0.0010797301132697613 | Train Time: 0.045\n",
            "Valid Loss: 0.0008784675446804613 | Valid Time: 0.004\n",
            "Epoch: 365\n",
            "Train Loss: 0.0009169630706310272 | Train Time: 0.051\n",
            "Valid Loss: 0.0011072649504058063 | Valid Time: 0.003\n",
            "Epoch: 366\n",
            "Train Loss: 0.0011778791376855224 | Train Time: 0.049\n",
            "Valid Loss: 0.0009335892973467708 | Valid Time: 0.003\n",
            "Epoch: 367\n",
            "Train Loss: 0.0009873522736597805 | Train Time: 0.051\n",
            "Valid Loss: 0.0007705889875069261 | Valid Time: 0.003\n",
            "Epoch: 368\n",
            "Train Loss: 0.000860546063631773 | Train Time: 0.044\n",
            "Valid Loss: 0.0014150216593407094 | Valid Time: 0.003\n",
            "Epoch: 369\n",
            "Train Loss: 0.0011236914317123592 | Train Time: 0.045\n",
            "Valid Loss: 0.0007277809199877083 | Valid Time: 0.003\n",
            "Epoch: 370\n",
            "Train Loss: 0.0009334759146440774 | Train Time: 0.045\n",
            "Valid Loss: 0.0010391782561782748 | Valid Time: 0.003\n",
            "Epoch: 371\n",
            "Train Loss: 0.000980419054394588 | Train Time: 0.049\n",
            "Valid Loss: 0.0007147724973037839 | Valid Time: 0.003\n",
            "Epoch: 372\n",
            "Train Loss: 0.0009357725211884826 | Train Time: 0.051\n",
            "Valid Loss: 0.0007847703818697482 | Valid Time: 0.004\n",
            "Epoch: 373\n",
            "Train Loss: 0.0008618028892669827 | Train Time: 0.046\n",
            "Valid Loss: 0.0008594040991738439 | Valid Time: 0.003\n",
            "Epoch: 374\n",
            "Train Loss: 0.0010182233061641454 | Train Time: 0.048\n",
            "Valid Loss: 0.0007325435290113091 | Valid Time: 0.003\n",
            "Epoch: 375\n",
            "Train Loss: 0.0008639406703878194 | Train Time: 0.045\n",
            "Valid Loss: 0.0009608188993297517 | Valid Time: 0.003\n",
            "Epoch: 376\n",
            "Train Loss: 0.0009933730238117278 | Train Time: 0.044\n",
            "Valid Loss: 0.0008472471672575921 | Valid Time: 0.004\n",
            "Epoch: 377\n",
            "Train Loss: 0.0008209867868572473 | Train Time: 0.049\n",
            "Valid Loss: 0.0009161063935607672 | Valid Time: 0.003\n",
            "Epoch: 378\n",
            "Train Loss: 0.0008253100619185716 | Train Time: 0.045\n",
            "Valid Loss: 0.0006900399457663298 | Valid Time: 0.004\n",
            "Epoch: 379\n",
            "Train Loss: 0.0008545581076759845 | Train Time: 0.053\n",
            "Valid Loss: 0.0007484131201636046 | Valid Time: 0.003\n",
            "Epoch: 380\n",
            "Train Loss: 0.0007972696679644286 | Train Time: 0.045\n",
            "Valid Loss: 0.0007451679557561874 | Valid Time: 0.003\n",
            "Epoch: 381\n",
            "Train Loss: 0.0008607206284068525 | Train Time: 0.044\n",
            "Valid Loss: 0.0007666799065191299 | Valid Time: 0.007\n",
            "Epoch: 382\n",
            "Train Loss: 0.0007971204060595483 | Train Time: 0.048\n",
            "Valid Loss: 0.0007871036068536341 | Valid Time: 0.005\n",
            "Epoch: 383\n",
            "Train Loss: 0.0009120621019974351 | Train Time: 0.054\n",
            "Valid Loss: 0.000841306580696255 | Valid Time: 0.004\n",
            "Epoch: 384\n",
            "Train Loss: 0.0008153987233527005 | Train Time: 0.047\n",
            "Valid Loss: 0.000867968745296821 | Valid Time: 0.004\n",
            "Epoch: 385\n",
            "Train Loss: 0.0010033158643636853 | Train Time: 0.061\n",
            "Valid Loss: 0.0012472913949750364 | Valid Time: 0.003\n",
            "Epoch: 386\n",
            "Train Loss: 0.0008679066610056907 | Train Time: 0.050\n",
            "Valid Loss: 0.0008322038629557937 | Valid Time: 0.003\n",
            "Epoch: 387\n",
            "Train Loss: 0.0007925411977339536 | Train Time: 0.051\n",
            "Valid Loss: 0.0007018024334684014 | Valid Time: 0.004\n",
            "Epoch: 388\n",
            "Train Loss: 0.0008075178426224739 | Train Time: 0.046\n",
            "Valid Loss: 0.0008626615162938833 | Valid Time: 0.004\n",
            "Epoch: 389\n",
            "Train Loss: 0.0010189671360421927 | Train Time: 0.048\n",
            "Valid Loss: 0.0008540993731003255 | Valid Time: 0.003\n",
            "Epoch: 390\n",
            "Train Loss: 0.0011330942972563208 | Train Time: 0.046\n",
            "Valid Loss: 0.0009880847646854818 | Valid Time: 0.003\n",
            "Epoch: 391\n",
            "Train Loss: 0.0008226806006859988 | Train Time: 0.046\n",
            "Valid Loss: 0.0011387101258151233 | Valid Time: 0.004\n",
            "Epoch: 392\n",
            "Train Loss: 0.0008765909355133772 | Train Time: 0.046\n",
            "Valid Loss: 0.0007447173993568867 | Valid Time: 0.005\n",
            "Epoch: 393\n",
            "Train Loss: 0.000808954582316801 | Train Time: 0.046\n",
            "Valid Loss: 0.0006994790164753795 | Valid Time: 0.005\n",
            "Epoch: 394\n",
            "Train Loss: 0.000933824258390814 | Train Time: 0.045\n",
            "Valid Loss: 0.0009030830697156489 | Valid Time: 0.003\n",
            "Epoch: 395\n",
            "Train Loss: 0.0008827229961752891 | Train Time: 0.045\n",
            "Valid Loss: 0.0007219550316222012 | Valid Time: 0.003\n",
            "Epoch: 396\n",
            "Train Loss: 0.0008210188709199429 | Train Time: 0.049\n",
            "Valid Loss: 0.0007945576217025518 | Valid Time: 0.003\n",
            "Epoch: 397\n",
            "Train Loss: 0.0008353555342182517 | Train Time: 0.061\n",
            "Valid Loss: 0.0007932921580504626 | Valid Time: 0.003\n",
            "Epoch: 398\n",
            "Train Loss: 0.0009997363784350454 | Train Time: 0.050\n",
            "Valid Loss: 0.001603513432200998 | Valid Time: 0.006\n",
            "Epoch: 399\n",
            "Train Loss: 0.0014073621248826384 | Train Time: 0.074\n",
            "Valid Loss: 0.0008217543654609472 | Valid Time: 0.006\n",
            "Epoch: 400\n",
            "Train Loss: 0.0009000029996968806 | Train Time: 0.084\n",
            "Valid Loss: 0.0007218375394586474 | Valid Time: 0.010\n",
            "Epoch: 401\n",
            "Train Loss: 0.0007652411179151386 | Train Time: 0.080\n",
            "Valid Loss: 0.0007317287381738424 | Valid Time: 0.007\n",
            "Epoch: 402\n",
            "Train Loss: 0.0008173684938810766 | Train Time: 0.083\n",
            "Valid Loss: 0.0007273997471202165 | Valid Time: 0.006\n",
            "Epoch: 403\n",
            "Train Loss: 0.0008655042562168092 | Train Time: 0.058\n",
            "Valid Loss: 0.0007515163160860538 | Valid Time: 0.004\n",
            "Epoch: 404\n",
            "Train Loss: 0.0008548849727958441 | Train Time: 0.044\n",
            "Valid Loss: 0.0011855912161991 | Valid Time: 0.004\n",
            "Epoch: 405\n",
            "Train Loss: 0.0010311589867342263 | Train Time: 0.052\n",
            "Valid Loss: 0.0007957270427141339 | Valid Time: 0.003\n",
            "Epoch: 406\n",
            "Train Loss: 0.0007814765383955091 | Train Time: 0.047\n",
            "Valid Loss: 0.0009228639828506857 | Valid Time: 0.003\n",
            "Epoch: 407\n",
            "Train Loss: 0.0008599841734394431 | Train Time: 0.053\n",
            "Valid Loss: 0.0017020012601278722 | Valid Time: 0.004\n",
            "Epoch: 408\n",
            "Train Loss: 0.001373146497644484 | Train Time: 0.051\n",
            "Valid Loss: 0.0008318052277900279 | Valid Time: 0.003\n",
            "Epoch: 409\n",
            "Train Loss: 0.0011212498764507472 | Train Time: 0.046\n",
            "Valid Loss: 0.0011320487246848643 | Valid Time: 0.003\n",
            "Epoch: 410\n",
            "Train Loss: 0.0008815025852527469 | Train Time: 0.044\n",
            "Valid Loss: 0.0007140254019759595 | Valid Time: 0.003\n",
            "Epoch: 411\n",
            "Train Loss: 0.0007314443646464497 | Train Time: 0.044\n",
            "Valid Loss: 0.0007519884675275534 | Valid Time: 0.005\n",
            "Epoch: 412\n",
            "Train Loss: 0.0007587901025544852 | Train Time: 0.046\n",
            "Valid Loss: 0.0007438028114847839 | Valid Time: 0.004\n",
            "Epoch: 413\n",
            "Train Loss: 0.0009596356714610011 | Train Time: 0.049\n",
            "Valid Loss: 0.0010492157307453454 | Valid Time: 0.003\n",
            "Epoch: 414\n",
            "Train Loss: 0.0009944292134605349 | Train Time: 0.046\n",
            "Valid Loss: 0.0008521013660356402 | Valid Time: 0.003\n",
            "Epoch: 415\n",
            "Train Loss: 0.0008387223526369781 | Train Time: 0.045\n",
            "Valid Loss: 0.0008182718011084944 | Valid Time: 0.003\n",
            "Epoch: 416\n",
            "Train Loss: 0.0008200212381780147 | Train Time: 0.054\n",
            "Valid Loss: 0.0008251733961515129 | Valid Time: 0.003\n",
            "Epoch: 417\n",
            "Train Loss: 0.001012532110325992 | Train Time: 0.045\n",
            "Valid Loss: 0.0008068435126915574 | Valid Time: 0.003\n",
            "Epoch: 418\n",
            "Train Loss: 0.0008988387882709504 | Train Time: 0.048\n",
            "Valid Loss: 0.0007232427888084203 | Valid Time: 0.005\n",
            "Epoch: 419\n",
            "Train Loss: 0.0007600908109452575 | Train Time: 0.054\n",
            "Valid Loss: 0.0007249411137308925 | Valid Time: 0.003\n",
            "Epoch: 420\n",
            "Train Loss: 0.0007552314666099847 | Train Time: 0.045\n",
            "Valid Loss: 0.0006799400434829295 | Valid Time: 0.003\n",
            "Epoch: 421\n",
            "Train Loss: 0.0007702213595621287 | Train Time: 0.046\n",
            "Valid Loss: 0.0008487010491080582 | Valid Time: 0.005\n",
            "Epoch: 422\n",
            "Train Loss: 0.0009068480401765555 | Train Time: 0.046\n",
            "Valid Loss: 0.00086421929881908 | Valid Time: 0.003\n",
            "Epoch: 423\n",
            "Train Loss: 0.0009309963148552925 | Train Time: 0.044\n",
            "Valid Loss: 0.0007958016649354249 | Valid Time: 0.003\n",
            "Epoch: 424\n",
            "Train Loss: 0.0008002015936654061 | Train Time: 0.047\n",
            "Valid Loss: 0.0008697579905856401 | Valid Time: 0.005\n",
            "Epoch: 425\n",
            "Train Loss: 0.0008477482595480978 | Train Time: 0.046\n",
            "Valid Loss: 0.0008557615801692009 | Valid Time: 0.003\n",
            "Epoch: 426\n",
            "Train Loss: 0.0007689337187912315 | Train Time: 0.045\n",
            "Valid Loss: 0.0009987422090489417 | Valid Time: 0.003\n",
            "Epoch: 427\n",
            "Train Loss: 0.0008921197848394513 | Train Time: 0.043\n",
            "Valid Loss: 0.0010210031759925187 | Valid Time: 0.004\n",
            "Epoch: 428\n",
            "Train Loss: 0.0010134231066331266 | Train Time: 0.048\n",
            "Valid Loss: 0.0007491555879823864 | Valid Time: 0.003\n",
            "Epoch: 429\n",
            "Train Loss: 0.0007996688713319599 | Train Time: 0.047\n",
            "Valid Loss: 0.0006954374839551747 | Valid Time: 0.003\n",
            "Epoch: 430\n",
            "Train Loss: 0.0008753164496738463 | Train Time: 0.043\n",
            "Valid Loss: 0.0007400177419185638 | Valid Time: 0.003\n",
            "Epoch: 431\n",
            "Train Loss: 0.0009003189508803189 | Train Time: 0.049\n",
            "Valid Loss: 0.0010471302666701376 | Valid Time: 0.003\n",
            "Epoch: 432\n",
            "Train Loss: 0.0013170003483537584 | Train Time: 0.043\n",
            "Valid Loss: 0.001287961786147207 | Valid Time: 0.003\n",
            "Epoch: 433\n",
            "Train Loss: 0.0016067721007857472 | Train Time: 0.048\n",
            "Valid Loss: 0.0009758906380739063 | Valid Time: 0.003\n",
            "Epoch: 434\n",
            "Train Loss: 0.0013036904041655363 | Train Time: 0.053\n",
            "Valid Loss: 0.001231340633239597 | Valid Time: 0.004\n",
            "Epoch: 435\n",
            "Train Loss: 0.001418506627669558 | Train Time: 0.045\n",
            "Valid Loss: 0.0029069161973893642 | Valid Time: 0.003\n",
            "Epoch: 436\n",
            "Train Loss: 0.0016681095701642334 | Train Time: 0.044\n",
            "Valid Loss: 0.0018053519888781011 | Valid Time: 0.003\n",
            "Epoch: 437\n",
            "Train Loss: 0.0015003120061010122 | Train Time: 0.050\n",
            "Valid Loss: 0.0008996502438094467 | Valid Time: 0.003\n",
            "Epoch: 438\n",
            "Train Loss: 0.0011987581092398614 | Train Time: 0.051\n",
            "Valid Loss: 0.0008296516316477209 | Valid Time: 0.008\n",
            "Epoch: 439\n",
            "Train Loss: 0.0010797036113217473 | Train Time: 0.046\n",
            "Valid Loss: 0.0007845133950468153 | Valid Time: 0.003\n",
            "Epoch: 440\n",
            "Train Loss: 0.0009372884407639504 | Train Time: 0.049\n",
            "Valid Loss: 0.0007045681122690439 | Valid Time: 0.003\n",
            "Epoch: 441\n",
            "Train Loss: 0.0007605020480696111 | Train Time: 0.046\n",
            "Valid Loss: 0.0008462859550490975 | Valid Time: 0.003\n",
            "Epoch: 442\n",
            "Train Loss: 0.0008733408234547823 | Train Time: 0.045\n",
            "Valid Loss: 0.000818791042547673 | Valid Time: 0.006\n",
            "Epoch: 443\n",
            "Train Loss: 0.000914701953297481 | Train Time: 0.052\n",
            "Valid Loss: 0.0010100283834617585 | Valid Time: 0.003\n",
            "Epoch: 444\n",
            "Train Loss: 0.0008458874421194196 | Train Time: 0.046\n",
            "Valid Loss: 0.0006671228911727667 | Valid Time: 0.003\n",
            "Epoch: 445\n",
            "Train Loss: 0.0008960215782281011 | Train Time: 0.047\n",
            "Valid Loss: 0.0010904001537710428 | Valid Time: 0.005\n",
            "Epoch: 446\n",
            "Train Loss: 0.0008708325447514653 | Train Time: 0.050\n",
            "Valid Loss: 0.0008098783728200942 | Valid Time: 0.003\n",
            "Epoch: 447\n",
            "Train Loss: 0.0009270064474549145 | Train Time: 0.046\n",
            "Valid Loss: 0.0007812772237230092 | Valid Time: 0.003\n",
            "Epoch: 448\n",
            "Train Loss: 0.0007846700609661639 | Train Time: 0.044\n",
            "Valid Loss: 0.0007203738787211478 | Valid Time: 0.003\n",
            "Epoch: 449\n",
            "Train Loss: 0.000776089122518897 | Train Time: 0.043\n",
            "Valid Loss: 0.0007146465359255672 | Valid Time: 0.003\n",
            "Epoch: 450\n",
            "Train Loss: 0.000805694522568956 | Train Time: 0.048\n",
            "Valid Loss: 0.0006520343595184386 | Valid Time: 0.003\n",
            "Epoch: 451\n",
            "Train Loss: 0.0007716736290603876 | Train Time: 0.052\n",
            "Valid Loss: 0.0006587797251995653 | Valid Time: 0.003\n",
            "Epoch: 452\n",
            "Train Loss: 0.0008578107284847647 | Train Time: 0.048\n",
            "Valid Loss: 0.0007932180596981198 | Valid Time: 0.003\n",
            "Epoch: 453\n",
            "Train Loss: 0.0008720219484530389 | Train Time: 0.054\n",
            "Valid Loss: 0.0007067879196256399 | Valid Time: 0.003\n",
            "Epoch: 454\n",
            "Train Loss: 0.0007241108920425177 | Train Time: 0.044\n",
            "Valid Loss: 0.0007748664647806436 | Valid Time: 0.003\n",
            "Epoch: 455\n",
            "Train Loss: 0.0007715813990216702 | Train Time: 0.050\n",
            "Valid Loss: 0.0007548875000793487 | Valid Time: 0.003\n",
            "Epoch: 456\n",
            "Train Loss: 0.0008184476406313479 | Train Time: 0.049\n",
            "Valid Loss: 0.0006898724241182208 | Valid Time: 0.003\n",
            "Epoch: 457\n",
            "Train Loss: 0.0007676609442569315 | Train Time: 0.046\n",
            "Valid Loss: 0.0007311023946385831 | Valid Time: 0.003\n",
            "Epoch: 458\n",
            "Train Loss: 0.0008197095477953554 | Train Time: 0.052\n",
            "Valid Loss: 0.0006962970364838839 | Valid Time: 0.003\n",
            "Epoch: 459\n",
            "Train Loss: 0.0007977226458024233 | Train Time: 0.054\n",
            "Valid Loss: 0.0007108311983756721 | Valid Time: 0.003\n",
            "Epoch: 460\n",
            "Train Loss: 0.0007669211307074874 | Train Time: 0.045\n",
            "Valid Loss: 0.0007156464562285691 | Valid Time: 0.003\n",
            "Epoch: 461\n",
            "Train Loss: 0.0007360230956692249 | Train Time: 0.047\n",
            "Valid Loss: 0.0007607029401697218 | Valid Time: 0.003\n",
            "Epoch: 462\n",
            "Train Loss: 0.0007700269168708473 | Train Time: 0.053\n",
            "Valid Loss: 0.0007514734170399606 | Valid Time: 0.003\n",
            "Epoch: 463\n",
            "Train Loss: 0.001048889511730522 | Train Time: 0.058\n",
            "Valid Loss: 0.0008790181600488722 | Valid Time: 0.004\n",
            "Epoch: 464\n",
            "Train Loss: 0.0011982584197539835 | Train Time: 0.071\n",
            "Valid Loss: 0.0012151303817518055 | Valid Time: 0.004\n",
            "Epoch: 465\n",
            "Train Loss: 0.0009554272051900625 | Train Time: 0.051\n",
            "Valid Loss: 0.0011065172730013728 | Valid Time: 0.003\n",
            "Epoch: 466\n",
            "Train Loss: 0.0013161263428628444 | Train Time: 0.046\n",
            "Valid Loss: 0.0010150871821679175 | Valid Time: 0.003\n",
            "Epoch: 467\n",
            "Train Loss: 0.0009135570144280791 | Train Time: 0.049\n",
            "Valid Loss: 0.0008873962797224522 | Valid Time: 0.003\n",
            "Epoch: 468\n",
            "Train Loss: 0.0009354415291454643 | Train Time: 0.045\n",
            "Valid Loss: 0.0008277223096229136 | Valid Time: 0.003\n",
            "Epoch: 469\n",
            "Train Loss: 0.0008464240469038487 | Train Time: 0.045\n",
            "Valid Loss: 0.0007585397106595337 | Valid Time: 0.004\n",
            "Epoch: 470\n",
            "Train Loss: 0.0007693042571190745 | Train Time: 0.045\n",
            "Valid Loss: 0.0006986655644141138 | Valid Time: 0.003\n",
            "Epoch: 471\n",
            "Train Loss: 0.0007592464215122163 | Train Time: 0.045\n",
            "Valid Loss: 0.000717748946044594 | Valid Time: 0.003\n",
            "Epoch: 472\n",
            "Train Loss: 0.0008417964680120348 | Train Time: 0.050\n",
            "Valid Loss: 0.000887401110958308 | Valid Time: 0.004\n",
            "Epoch: 473\n",
            "Train Loss: 0.0007594747119583189 | Train Time: 0.047\n",
            "Valid Loss: 0.0006583515205420554 | Valid Time: 0.003\n",
            "Epoch: 474\n",
            "Train Loss: 0.0007405926298815757 | Train Time: 0.051\n",
            "Valid Loss: 0.0006964823405724019 | Valid Time: 0.003\n",
            "Epoch: 475\n",
            "Train Loss: 0.000802378571825102 | Train Time: 0.044\n",
            "Valid Loss: 0.000762520357966423 | Valid Time: 0.003\n",
            "Epoch: 476\n",
            "Train Loss: 0.000805768120335415 | Train Time: 0.044\n",
            "Valid Loss: 0.0007761053566355258 | Valid Time: 0.004\n",
            "Epoch: 477\n",
            "Train Loss: 0.0008821857511065901 | Train Time: 0.058\n",
            "Valid Loss: 0.0006854196544736624 | Valid Time: 0.003\n",
            "Epoch: 478\n",
            "Train Loss: 0.000763635424664244 | Train Time: 0.046\n",
            "Valid Loss: 0.0007025893719401211 | Valid Time: 0.003\n",
            "Epoch: 479\n",
            "Train Loss: 0.000720058917067945 | Train Time: 0.044\n",
            "Valid Loss: 0.0006720699311699718 | Valid Time: 0.003\n",
            "Epoch: 480\n",
            "Train Loss: 0.0007451477751601488 | Train Time: 0.054\n",
            "Valid Loss: 0.0007840978214517236 | Valid Time: 0.003\n",
            "Epoch: 481\n",
            "Train Loss: 0.0008273173589259386 | Train Time: 0.045\n",
            "Valid Loss: 0.000890866038389504 | Valid Time: 0.004\n",
            "Epoch: 482\n",
            "Train Loss: 0.0010851800616364926 | Train Time: 0.044\n",
            "Valid Loss: 0.0007559666410088539 | Valid Time: 0.003\n",
            "Epoch: 483\n",
            "Train Loss: 0.0008866013842634857 | Train Time: 0.050\n",
            "Valid Loss: 0.0009482920286245644 | Valid Time: 0.003\n",
            "Epoch: 484\n",
            "Train Loss: 0.0008925752248615026 | Train Time: 0.047\n",
            "Valid Loss: 0.0008267071680165827 | Valid Time: 0.005\n",
            "Epoch: 485\n",
            "Train Loss: 0.0007878165401052683 | Train Time: 0.046\n",
            "Valid Loss: 0.0007282746082637459 | Valid Time: 0.003\n",
            "Epoch: 486\n",
            "Train Loss: 0.000989864463917911 | Train Time: 0.044\n",
            "Valid Loss: 0.0017296402947977185 | Valid Time: 0.003\n",
            "Epoch: 487\n",
            "Train Loss: 0.001674017496407032 | Train Time: 0.048\n",
            "Valid Loss: 0.0015156638692133129 | Valid Time: 0.003\n",
            "Epoch: 488\n",
            "Train Loss: 0.001193678448908031 | Train Time: 0.045\n",
            "Valid Loss: 0.001278820855077356 | Valid Time: 0.003\n",
            "Epoch: 489\n",
            "Train Loss: 0.0009955301939044148 | Train Time: 0.050\n",
            "Valid Loss: 0.0008976435055956244 | Valid Time: 0.004\n",
            "Epoch: 490\n",
            "Train Loss: 0.0009419960901141166 | Train Time: 0.046\n",
            "Valid Loss: 0.0007501606596633792 | Valid Time: 0.003\n",
            "Epoch: 491\n",
            "Train Loss: 0.0009154418134130537 | Train Time: 0.055\n",
            "Valid Loss: 0.0006493946420960128 | Valid Time: 0.003\n",
            "Epoch: 492\n",
            "Train Loss: 0.000939066067803651 | Train Time: 0.045\n",
            "Valid Loss: 0.0007448512478731573 | Valid Time: 0.003\n",
            "Epoch: 493\n",
            "Train Loss: 0.0007887628977186978 | Train Time: 0.052\n",
            "Valid Loss: 0.0008171199297066778 | Valid Time: 0.004\n",
            "Epoch: 494\n",
            "Train Loss: 0.0008336685772519558 | Train Time: 0.055\n",
            "Valid Loss: 0.001056098029948771 | Valid Time: 0.003\n",
            "Epoch: 495\n",
            "Train Loss: 0.0008626544498838484 | Train Time: 0.045\n",
            "Valid Loss: 0.0014304653741419315 | Valid Time: 0.003\n",
            "Epoch: 496\n",
            "Train Loss: 0.000892093707807362 | Train Time: 0.055\n",
            "Valid Loss: 0.0009236863406840712 | Valid Time: 0.004\n",
            "Epoch: 497\n",
            "Train Loss: 0.00079927112092264 | Train Time: 0.061\n",
            "Valid Loss: 0.0008623421599622816 | Valid Time: 0.003\n",
            "Epoch: 498\n",
            "Train Loss: 0.0007445316645316779 | Train Time: 0.047\n",
            "Valid Loss: 0.0006983386992942542 | Valid Time: 0.004\n",
            "Epoch: 499\n",
            "Train Loss: 0.0007141849433537573 | Train Time: 0.046\n",
            "Valid Loss: 0.0008960767008829862 | Valid Time: 0.003\n",
            "Epoch: 500\n",
            "Train Loss: 0.0008936792903114111 | Train Time: 0.046\n",
            "Valid Loss: 0.0008915419457480311 | Valid Time: 0.004\n",
            "Epoch: 501\n",
            "Train Loss: 0.000852977397153154 | Train Time: 0.047\n",
            "Valid Loss: 0.0006456466799136251 | Valid Time: 0.009\n",
            "Epoch: 502\n",
            "Train Loss: 0.0007591020548716187 | Train Time: 0.053\n",
            "Valid Loss: 0.000741421856218949 | Valid Time: 0.003\n",
            "Epoch: 503\n",
            "Train Loss: 0.0007148830336518586 | Train Time: 0.047\n",
            "Valid Loss: 0.0006827251054346561 | Valid Time: 0.003\n",
            "Epoch: 504\n",
            "Train Loss: 0.0007438835978973657 | Train Time: 0.047\n",
            "Valid Loss: 0.000701853190548718 | Valid Time: 0.003\n",
            "Epoch: 505\n",
            "Train Loss: 0.0007249359972774982 | Train Time: 0.048\n",
            "Valid Loss: 0.0006743485573679209 | Valid Time: 0.003\n",
            "Epoch: 506\n",
            "Train Loss: 0.0007097587280441075 | Train Time: 0.051\n",
            "Valid Loss: 0.000666035950416699 | Valid Time: 0.003\n",
            "Epoch: 507\n",
            "Train Loss: 0.0006868955853860826 | Train Time: 0.047\n",
            "Valid Loss: 0.0006818608962930739 | Valid Time: 0.004\n",
            "Epoch: 508\n",
            "Train Loss: 0.0007210696523543448 | Train Time: 0.054\n",
            "Valid Loss: 0.0007675777014810592 | Valid Time: 0.004\n",
            "Epoch: 509\n",
            "Train Loss: 0.0008010894060134887 | Train Time: 0.058\n",
            "Valid Loss: 0.0006930530653335154 | Valid Time: 0.005\n",
            "Epoch: 510\n",
            "Train Loss: 0.000705885433126241 | Train Time: 0.046\n",
            "Valid Loss: 0.0006675792101304978 | Valid Time: 0.003\n",
            "Epoch: 511\n",
            "Train Loss: 0.0007327531930059195 | Train Time: 0.044\n",
            "Valid Loss: 0.0007419800094794482 | Valid Time: 0.003\n",
            "Epoch: 512\n",
            "Train Loss: 0.000802732672309503 | Train Time: 0.050\n",
            "Valid Loss: 0.0006844078307040036 | Valid Time: 0.003\n",
            "Epoch: 513\n",
            "Train Loss: 0.0008847298682667315 | Train Time: 0.045\n",
            "Valid Loss: 0.0007788321818225086 | Valid Time: 0.006\n",
            "Epoch: 514\n",
            "Train Loss: 0.0007896838418673724 | Train Time: 0.046\n",
            "Valid Loss: 0.0007762750319670886 | Valid Time: 0.003\n",
            "Epoch: 515\n",
            "Train Loss: 0.0008039524487685412 | Train Time: 0.056\n",
            "Valid Loss: 0.0007066694088280201 | Valid Time: 0.003\n",
            "Epoch: 516\n",
            "Train Loss: 0.0007300337543711066 | Train Time: 0.049\n",
            "Valid Loss: 0.0007198532111942768 | Valid Time: 0.003\n",
            "Epoch: 517\n",
            "Train Loss: 0.0008177469251677393 | Train Time: 0.051\n",
            "Valid Loss: 0.0007698017288930714 | Valid Time: 0.004\n",
            "Epoch: 518\n",
            "Train Loss: 0.0007976333843544125 | Train Time: 0.048\n",
            "Valid Loss: 0.0006710082234349102 | Valid Time: 0.004\n",
            "Epoch: 519\n",
            "Train Loss: 0.0008438956749159843 | Train Time: 0.046\n",
            "Valid Loss: 0.0006342014530673623 | Valid Time: 0.003\n",
            "Epoch: 520\n",
            "Train Loss: 0.0009314916154835373 | Train Time: 0.055\n",
            "Valid Loss: 0.000644068670226261 | Valid Time: 0.007\n",
            "Epoch: 521\n",
            "Train Loss: 0.000739411759423092 | Train Time: 0.078\n",
            "Valid Loss: 0.0007012731512077153 | Valid Time: 0.005\n",
            "Epoch: 522\n",
            "Train Loss: 0.0006836275628302246 | Train Time: 0.068\n",
            "Valid Loss: 0.0006877920823171735 | Valid Time: 0.005\n",
            "Epoch: 523\n",
            "Train Loss: 0.0007678322435822338 | Train Time: 0.069\n",
            "Valid Loss: 0.0007267341716215014 | Valid Time: 0.004\n",
            "Epoch: 524\n",
            "Train Loss: 0.0009314347611507401 | Train Time: 0.069\n",
            "Valid Loss: 0.0011257347068749368 | Valid Time: 0.007\n",
            "Epoch: 525\n",
            "Train Loss: 0.001034995197551325 | Train Time: 0.067\n",
            "Valid Loss: 0.0010480535274837166 | Valid Time: 0.005\n",
            "Epoch: 526\n",
            "Train Loss: 0.0010242211865261197 | Train Time: 0.063\n",
            "Valid Loss: 0.0009119040623772889 | Valid Time: 0.005\n",
            "Epoch: 527\n",
            "Train Loss: 0.0009413322550244629 | Train Time: 0.076\n",
            "Valid Loss: 0.0007191605982370675 | Valid Time: 0.005\n",
            "Epoch: 528\n",
            "Train Loss: 0.0007444324146490544 | Train Time: 0.065\n",
            "Valid Loss: 0.0006934097618795931 | Valid Time: 0.005\n",
            "Epoch: 529\n",
            "Train Loss: 0.0007430406112689525 | Train Time: 0.064\n",
            "Valid Loss: 0.001235516247106716 | Valid Time: 0.005\n",
            "Epoch: 530\n",
            "Train Loss: 0.0009824005363043397 | Train Time: 0.078\n",
            "Valid Loss: 0.0011288847017567605 | Valid Time: 0.005\n",
            "Epoch: 531\n",
            "Train Loss: 0.0008461555233225226 | Train Time: 0.067\n",
            "Valid Loss: 0.0010252594074700028 | Valid Time: 0.005\n",
            "Epoch: 532\n",
            "Train Loss: 0.0008344436879269779 | Train Time: 0.064\n",
            "Valid Loss: 0.0007232467760331929 | Valid Time: 0.005\n",
            "Epoch: 533\n",
            "Train Loss: 0.0008091453113593161 | Train Time: 0.069\n",
            "Valid Loss: 0.0009193493460770696 | Valid Time: 0.005\n",
            "Epoch: 534\n",
            "Train Loss: 0.0009876665251795202 | Train Time: 0.067\n",
            "Valid Loss: 0.0010572386672720313 | Valid Time: 0.005\n",
            "Epoch: 535\n",
            "Train Loss: 0.0009118096146266908 | Train Time: 0.072\n",
            "Valid Loss: 0.0008160305733326823 | Valid Time: 0.005\n",
            "Epoch: 536\n",
            "Train Loss: 0.0008659755578264595 | Train Time: 0.069\n",
            "Valid Loss: 0.0006417670520022511 | Valid Time: 0.005\n",
            "Epoch: 537\n",
            "Train Loss: 0.0007752359844744206 | Train Time: 0.064\n",
            "Valid Loss: 0.0006315792270470411 | Valid Time: 0.005\n",
            "Epoch: 538\n",
            "Train Loss: 0.0007267629902344197 | Train Time: 0.068\n",
            "Valid Loss: 0.0007097086927387863 | Valid Time: 0.005\n",
            "Epoch: 539\n",
            "Train Loss: 0.0007586666673887521 | Train Time: 0.074\n",
            "Valid Loss: 0.0006897503626532853 | Valid Time: 0.005\n",
            "Epoch: 540\n",
            "Train Loss: 0.0007514511293265968 | Train Time: 0.063\n",
            "Valid Loss: 0.0007182807894423604 | Valid Time: 0.005\n",
            "Epoch: 541\n",
            "Train Loss: 0.0008071410818956792 | Train Time: 0.066\n",
            "Valid Loss: 0.0007889956177677959 | Valid Time: 0.005\n",
            "Epoch: 542\n",
            "Train Loss: 0.0007155804603826254 | Train Time: 0.068\n",
            "Valid Loss: 0.0007658594695385545 | Valid Time: 0.005\n",
            "Epoch: 543\n",
            "Train Loss: 0.0007739446184132249 | Train Time: 0.064\n",
            "Valid Loss: 0.0007871336711104959 | Valid Time: 0.007\n",
            "Epoch: 544\n",
            "Train Loss: 0.0007731342921033502 | Train Time: 0.069\n",
            "Valid Loss: 0.0006422773585654795 | Valid Time: 0.007\n",
            "Epoch: 545\n",
            "Train Loss: 0.0007264485000632703 | Train Time: 0.078\n",
            "Valid Loss: 0.0008024905400816351 | Valid Time: 0.005\n",
            "Epoch: 546\n",
            "Train Loss: 0.0009464396920520812 | Train Time: 0.064\n",
            "Valid Loss: 0.0009568120876792818 | Valid Time: 0.005\n",
            "Epoch: 547\n",
            "Train Loss: 0.0007786781236063689 | Train Time: 0.075\n",
            "Valid Loss: 0.0007996796339284629 | Valid Time: 0.005\n",
            "Epoch: 548\n",
            "Train Loss: 0.0007957257854286581 | Train Time: 0.073\n",
            "Valid Loss: 0.0008527747995685786 | Valid Time: 0.005\n",
            "Epoch: 549\n",
            "Train Loss: 0.0008959091559518128 | Train Time: 0.067\n",
            "Valid Loss: 0.000694919639499858 | Valid Time: 0.006\n",
            "Epoch: 550\n",
            "Train Loss: 0.0007921610842458904 | Train Time: 0.069\n",
            "Valid Loss: 0.0006593072903342545 | Valid Time: 0.005\n",
            "Epoch: 551\n",
            "Train Loss: 0.000819195609074086 | Train Time: 0.079\n",
            "Valid Loss: 0.0007487478142138571 | Valid Time: 0.006\n",
            "Epoch: 552\n",
            "Train Loss: 0.001276244391920045 | Train Time: 0.053\n",
            "Valid Loss: 0.0019571284647099674 | Valid Time: 0.003\n",
            "Epoch: 553\n",
            "Train Loss: 0.0012325844261795282 | Train Time: 0.046\n",
            "Valid Loss: 0.0009689816215541214 | Valid Time: 0.003\n",
            "Epoch: 554\n",
            "Train Loss: 0.0010267912002746016 | Train Time: 0.045\n",
            "Valid Loss: 0.0010497020557522774 | Valid Time: 0.003\n",
            "Epoch: 555\n",
            "Train Loss: 0.001128347119083628 | Train Time: 0.046\n",
            "Valid Loss: 0.0012828352046199143 | Valid Time: 0.006\n",
            "Epoch: 556\n",
            "Train Loss: 0.0010613665042910724 | Train Time: 0.054\n",
            "Valid Loss: 0.0007726170297246426 | Valid Time: 0.004\n",
            "Epoch: 557\n",
            "Train Loss: 0.0009312481386587023 | Train Time: 0.045\n",
            "Valid Loss: 0.0010013723804149777 | Valid Time: 0.003\n",
            "Epoch: 558\n",
            "Train Loss: 0.0010461112076882273 | Train Time: 0.046\n",
            "Valid Loss: 0.000955380906816572 | Valid Time: 0.003\n",
            "Epoch: 559\n",
            "Train Loss: 0.0010152791626751422 | Train Time: 0.047\n",
            "Valid Loss: 0.0006709048175252974 | Valid Time: 0.008\n",
            "Epoch: 560\n",
            "Train Loss: 0.0007587101426906884 | Train Time: 0.054\n",
            "Valid Loss: 0.0009376817615702748 | Valid Time: 0.006\n",
            "Epoch: 561\n",
            "Train Loss: 0.0008151630114298314 | Train Time: 0.047\n",
            "Valid Loss: 0.0007261194696184248 | Valid Time: 0.003\n",
            "Epoch: 562\n",
            "Train Loss: 0.0007062669843435288 | Train Time: 0.049\n",
            "Valid Loss: 0.0006629744602832943 | Valid Time: 0.004\n",
            "Epoch: 563\n",
            "Train Loss: 0.0009417111694347113 | Train Time: 0.050\n",
            "Valid Loss: 0.0008765707607381046 | Valid Time: 0.003\n",
            "Epoch: 564\n",
            "Train Loss: 0.0009451238787733018 | Train Time: 0.047\n",
            "Valid Loss: 0.000678110693115741 | Valid Time: 0.003\n",
            "Epoch: 565\n",
            "Train Loss: 0.0007718562439549715 | Train Time: 0.046\n",
            "Valid Loss: 0.0006640174542553723 | Valid Time: 0.003\n",
            "Epoch: 566\n",
            "Train Loss: 0.0008419148274697363 | Train Time: 0.051\n",
            "Valid Loss: 0.0009137153683695942 | Valid Time: 0.003\n",
            "Epoch: 567\n",
            "Train Loss: 0.0008762654731981456 | Train Time: 0.045\n",
            "Valid Loss: 0.0007915537571534514 | Valid Time: 0.008\n",
            "Epoch: 568\n",
            "Train Loss: 0.0007232568343169988 | Train Time: 0.045\n",
            "Valid Loss: 0.0006302196125034243 | Valid Time: 0.003\n",
            "Epoch: 569\n",
            "Train Loss: 0.0007268796733114868 | Train Time: 0.045\n",
            "Valid Loss: 0.0006992133567109704 | Valid Time: 0.003\n",
            "Epoch: 570\n",
            "Train Loss: 0.0007315390044823289 | Train Time: 0.051\n",
            "Valid Loss: 0.0007288941997103393 | Valid Time: 0.003\n",
            "Epoch: 571\n",
            "Train Loss: 0.0007586533029098064 | Train Time: 0.045\n",
            "Valid Loss: 0.0008098160906229168 | Valid Time: 0.007\n",
            "Epoch: 572\n",
            "Train Loss: 0.0009022008627653122 | Train Time: 0.048\n",
            "Valid Loss: 0.001115579390898347 | Valid Time: 0.004\n",
            "Epoch: 573\n",
            "Train Loss: 0.001052824780344963 | Train Time: 0.046\n",
            "Valid Loss: 0.001179885701276362 | Valid Time: 0.003\n",
            "Epoch: 574\n",
            "Train Loss: 0.0011560581624507904 | Train Time: 0.050\n",
            "Valid Loss: 0.000968178384937346 | Valid Time: 0.003\n",
            "Epoch: 575\n",
            "Train Loss: 0.000938942632637918 | Train Time: 0.044\n",
            "Valid Loss: 0.000788274162914604 | Valid Time: 0.005\n",
            "Epoch: 576\n",
            "Train Loss: 0.000956834142562002 | Train Time: 0.046\n",
            "Valid Loss: 0.0008304707007482648 | Valid Time: 0.003\n",
            "Epoch: 577\n",
            "Train Loss: 0.0007705597497988492 | Train Time: 0.049\n",
            "Valid Loss: 0.0006234466563910246 | Valid Time: 0.004\n",
            "Epoch: 578\n",
            "Train Loss: 0.0006906382797751576 | Train Time: 0.045\n",
            "Valid Loss: 0.000672066758852452 | Valid Time: 0.003\n",
            "Epoch: 579\n",
            "Train Loss: 0.0006730148248607293 | Train Time: 0.044\n",
            "Valid Loss: 0.0006387920875567943 | Valid Time: 0.007\n",
            "Epoch: 580\n",
            "Train Loss: 0.0007535212440416217 | Train Time: 0.059\n",
            "Valid Loss: 0.0008819032518658787 | Valid Time: 0.004\n",
            "Epoch: 581\n",
            "Train Loss: 0.0008681205159518868 | Train Time: 0.046\n",
            "Valid Loss: 0.0006892978271935135 | Valid Time: 0.003\n",
            "Epoch: 582\n",
            "Train Loss: 0.0008232162508647889 | Train Time: 0.047\n",
            "Valid Loss: 0.0006253948668017983 | Valid Time: 0.003\n",
            "Epoch: 583\n",
            "Train Loss: 0.0007200483931228518 | Train Time: 0.056\n",
            "Valid Loss: 0.0006523369811475277 | Valid Time: 0.003\n",
            "Epoch: 584\n",
            "Train Loss: 0.0009665854158811271 | Train Time: 0.047\n",
            "Valid Loss: 0.0007350184314418584 | Valid Time: 0.003\n",
            "Epoch: 585\n",
            "Train Loss: 0.0007402414863463491 | Train Time: 0.047\n",
            "Valid Loss: 0.0007543417741544545 | Valid Time: 0.003\n",
            "Epoch: 586\n",
            "Train Loss: 0.000718742044409737 | Train Time: 0.048\n",
            "Valid Loss: 0.0007271644426509738 | Valid Time: 0.004\n",
            "Epoch: 587\n",
            "Train Loss: 0.0008384622517041862 | Train Time: 0.043\n",
            "Valid Loss: 0.00088839465752244 | Valid Time: 0.007\n",
            "Epoch: 588\n",
            "Train Loss: 0.0009016816737130284 | Train Time: 0.044\n",
            "Valid Loss: 0.0010632475023157895 | Valid Time: 0.004\n",
            "Epoch: 589\n",
            "Train Loss: 0.0009215925063472241 | Train Time: 0.046\n",
            "Valid Loss: 0.0008045653230510652 | Valid Time: 0.003\n",
            "Epoch: 590\n",
            "Train Loss: 0.001025493536144495 | Train Time: 0.050\n",
            "Valid Loss: 0.0008483694982714951 | Valid Time: 0.003\n",
            "Epoch: 591\n",
            "Train Loss: 0.0009132299572229385 | Train Time: 0.046\n",
            "Valid Loss: 0.0006473847024608403 | Valid Time: 0.006\n",
            "Epoch: 592\n",
            "Train Loss: 0.0008202317752875387 | Train Time: 0.045\n",
            "Valid Loss: 0.0006760899268556386 | Valid Time: 0.003\n",
            "Epoch: 593\n",
            "Train Loss: 0.0007249005371704698 | Train Time: 0.046\n",
            "Valid Loss: 0.0006253074679989368 | Valid Time: 0.005\n",
            "Epoch: 594\n",
            "Train Loss: 0.0006577246094821021 | Train Time: 0.045\n",
            "Valid Loss: 0.0006157683965284377 | Valid Time: 0.003\n",
            "Epoch: 595\n",
            "Train Loss: 0.0006942826614249498 | Train Time: 0.044\n",
            "Valid Loss: 0.0007626815931871533 | Valid Time: 0.003\n",
            "Epoch: 596\n",
            "Train Loss: 0.0007339688134379684 | Train Time: 0.057\n",
            "Valid Loss: 0.0009855282260105014 | Valid Time: 0.005\n",
            "Epoch: 597\n",
            "Train Loss: 0.0011359002906829118 | Train Time: 0.046\n",
            "Valid Loss: 0.0017286394140683115 | Valid Time: 0.003\n",
            "Epoch: 598\n",
            "Train Loss: 0.0015215642168186605 | Train Time: 0.046\n",
            "Valid Loss: 0.0008511853811796755 | Valid Time: 0.003\n",
            "Epoch: 599\n",
            "Train Loss: 0.0013911628280766307 | Train Time: 0.055\n",
            "Valid Loss: 0.001527139451354742 | Valid Time: 0.003\n",
            "Epoch: 600\n",
            "Train Loss: 0.001265164284268394 | Train Time: 0.049\n",
            "Valid Loss: 0.0008407667628489435 | Valid Time: 0.003\n",
            "Epoch: 601\n",
            "Train Loss: 0.0008825752825941891 | Train Time: 0.046\n",
            "Valid Loss: 0.0009418525150977075 | Valid Time: 0.003\n",
            "Epoch: 602\n",
            "Train Loss: 0.0008715151343494654 | Train Time: 0.046\n",
            "Valid Loss: 0.000879293802427128 | Valid Time: 0.003\n",
            "Epoch: 603\n",
            "Train Loss: 0.0007765230315271765 | Train Time: 0.049\n",
            "Valid Loss: 0.0006512668041978031 | Valid Time: 0.003\n",
            "Epoch: 604\n",
            "Train Loss: 0.0009715665772091597 | Train Time: 0.046\n",
            "Valid Loss: 0.0009680597577244043 | Valid Time: 0.005\n",
            "Epoch: 605\n",
            "Train Loss: 0.0012625527684576809 | Train Time: 0.047\n",
            "Valid Loss: 0.0011248983209952712 | Valid Time: 0.004\n",
            "Epoch: 606\n",
            "Train Loss: 0.000932767172344029 | Train Time: 0.044\n",
            "Valid Loss: 0.0007036002934910357 | Valid Time: 0.003\n",
            "Epoch: 607\n",
            "Train Loss: 0.0007727452146355062 | Train Time: 0.050\n",
            "Valid Loss: 0.0008043693087529391 | Valid Time: 0.003\n",
            "Epoch: 608\n",
            "Train Loss: 0.000709415745222941 | Train Time: 0.047\n",
            "Valid Loss: 0.000714663794497028 | Valid Time: 0.005\n",
            "Epoch: 609\n",
            "Train Loss: 0.0007580074539873749 | Train Time: 0.049\n",
            "Valid Loss: 0.0008573199447710067 | Valid Time: 0.003\n",
            "Epoch: 610\n",
            "Train Loss: 0.0007868944376241416 | Train Time: 0.044\n",
            "Valid Loss: 0.0006161276251077652 | Valid Time: 0.003\n",
            "Epoch: 611\n",
            "Train Loss: 0.0006933811120688916 | Train Time: 0.052\n",
            "Valid Loss: 0.0008100891718640924 | Valid Time: 0.003\n",
            "Epoch: 612\n",
            "Train Loss: 0.0011606195766944438 | Train Time: 0.051\n",
            "Valid Loss: 0.0010922154760919511 | Valid Time: 0.004\n",
            "Epoch: 613\n",
            "Train Loss: 0.0018030848819762467 | Train Time: 0.047\n",
            "Valid Loss: 0.0013956750044599175 | Valid Time: 0.006\n",
            "Epoch: 614\n",
            "Train Loss: 0.001258836651686579 | Train Time: 0.044\n",
            "Valid Loss: 0.0006782207929063588 | Valid Time: 0.003\n",
            "Epoch: 615\n",
            "Train Loss: 0.0008990320086013526 | Train Time: 0.045\n",
            "Valid Loss: 0.0006909315998200327 | Valid Time: 0.003\n",
            "Epoch: 616\n",
            "Train Loss: 0.0008014443446882069 | Train Time: 0.050\n",
            "Valid Loss: 0.0006391440401785076 | Valid Time: 0.008\n",
            "Epoch: 617\n",
            "Train Loss: 0.0006882747809868305 | Train Time: 0.045\n",
            "Valid Loss: 0.0006362414569593966 | Valid Time: 0.003\n",
            "Epoch: 618\n",
            "Train Loss: 0.0007598642492666841 | Train Time: 0.045\n",
            "Valid Loss: 0.001211803697515279 | Valid Time: 0.003\n",
            "Epoch: 619\n",
            "Train Loss: 0.000921294663567096 | Train Time: 0.059\n",
            "Valid Loss: 0.0006874093669466674 | Valid Time: 0.003\n",
            "Epoch: 620\n",
            "Train Loss: 0.0007129531470127404 | Train Time: 0.048\n",
            "Valid Loss: 0.0008954806253314018 | Valid Time: 0.003\n",
            "Epoch: 621\n",
            "Train Loss: 0.0007803142303600908 | Train Time: 0.054\n",
            "Valid Loss: 0.0006698622601106763 | Valid Time: 0.004\n",
            "Epoch: 622\n",
            "Train Loss: 0.000910301087424159 | Train Time: 0.049\n",
            "Valid Loss: 0.0007964330434333533 | Valid Time: 0.003\n",
            "Epoch: 623\n",
            "Train Loss: 0.0008246446261182428 | Train Time: 0.048\n",
            "Valid Loss: 0.0007246275781653821 | Valid Time: 0.003\n",
            "Epoch: 624\n",
            "Train Loss: 0.0007593785354401916 | Train Time: 0.050\n",
            "Valid Loss: 0.0007592046167701483 | Valid Time: 0.004\n",
            "Epoch: 625\n",
            "Train Loss: 0.0007010711473412812 | Train Time: 0.044\n",
            "Valid Loss: 0.000635970471194014 | Valid Time: 0.003\n",
            "Epoch: 626\n",
            "Train Loss: 0.0007165330549469218 | Train Time: 0.043\n",
            "Valid Loss: 0.0007328075007535517 | Valid Time: 0.003\n",
            "Epoch: 627\n",
            "Train Loss: 0.0007859122939407826 | Train Time: 0.045\n",
            "Valid Loss: 0.0008458269294351339 | Valid Time: 0.003\n",
            "Epoch: 628\n",
            "Train Loss: 0.0008266509044915438 | Train Time: 0.044\n",
            "Valid Loss: 0.0009763750713318586 | Valid Time: 0.003\n",
            "Epoch: 629\n",
            "Train Loss: 0.0008498464419972151 | Train Time: 0.047\n",
            "Valid Loss: 0.0009103099000640213 | Valid Time: 0.003\n",
            "Epoch: 630\n",
            "Train Loss: 0.0008863597584422677 | Train Time: 0.049\n",
            "Valid Loss: 0.0008331204589921981 | Valid Time: 0.003\n",
            "Epoch: 631\n",
            "Train Loss: 0.0007794876641128212 | Train Time: 0.045\n",
            "Valid Loss: 0.0008973499352578074 | Valid Time: 0.003\n",
            "Epoch: 632\n",
            "Train Loss: 0.0006842195289209485 | Train Time: 0.046\n",
            "Valid Loss: 0.0008406816923525184 | Valid Time: 0.003\n",
            "Epoch: 633\n",
            "Train Loss: 0.0007241928949952125 | Train Time: 0.049\n",
            "Valid Loss: 0.000755655113607645 | Valid Time: 0.007\n",
            "Epoch: 634\n",
            "Train Loss: 0.0007376743713393807 | Train Time: 0.044\n",
            "Valid Loss: 0.000652797578368336 | Valid Time: 0.003\n",
            "Epoch: 635\n",
            "Train Loss: 0.0007070690218824894 | Train Time: 0.046\n",
            "Valid Loss: 0.0006404254818335176 | Valid Time: 0.003\n",
            "Epoch: 636\n",
            "Train Loss: 0.0007488721166737378 | Train Time: 0.051\n",
            "Valid Loss: 0.0008693905256222934 | Valid Time: 0.003\n",
            "Epoch: 637\n",
            "Train Loss: 0.0007868611079175025 | Train Time: 0.045\n",
            "Valid Loss: 0.0006136928568594158 | Valid Time: 0.006\n",
            "Epoch: 638\n",
            "Train Loss: 0.0007917393348179757 | Train Time: 0.052\n",
            "Valid Loss: 0.0011756802559830248 | Valid Time: 0.003\n",
            "Epoch: 639\n",
            "Train Loss: 0.0009062889963388443 | Train Time: 0.048\n",
            "Valid Loss: 0.000881222280440852 | Valid Time: 0.003\n",
            "Epoch: 640\n",
            "Train Loss: 0.0008273440704215318 | Train Time: 0.044\n",
            "Valid Loss: 0.0009427825571037829 | Valid Time: 0.004\n",
            "Epoch: 641\n",
            "Train Loss: 0.0010618608095683158 | Train Time: 0.055\n",
            "Valid Loss: 0.0014294494176283479 | Valid Time: 0.003\n",
            "Epoch: 642\n",
            "Train Loss: 0.0008715196396224201 | Train Time: 0.046\n",
            "Valid Loss: 0.0009200607019010931 | Valid Time: 0.003\n",
            "Epoch: 643\n",
            "Train Loss: 0.00098829920461867 | Train Time: 0.056\n",
            "Valid Loss: 0.0013740102003794163 | Valid Time: 0.004\n",
            "Epoch: 644\n",
            "Train Loss: 0.0011605775216594338 | Train Time: 0.051\n",
            "Valid Loss: 0.0008571905782446265 | Valid Time: 0.003\n",
            "Epoch: 645\n",
            "Train Loss: 0.0009317274380009621 | Train Time: 0.049\n",
            "Valid Loss: 0.0010264540323987603 | Valid Time: 0.003\n",
            "Epoch: 646\n",
            "Train Loss: 0.0010007403208874166 | Train Time: 0.045\n",
            "Valid Loss: 0.0008191824017558247 | Valid Time: 0.003\n",
            "Epoch: 647\n",
            "Train Loss: 0.0008807327714748681 | Train Time: 0.044\n",
            "Valid Loss: 0.0011241357424296439 | Valid Time: 0.005\n",
            "Epoch: 648\n",
            "Train Loss: 0.000839310185983777 | Train Time: 0.048\n",
            "Valid Loss: 0.000689242035150528 | Valid Time: 0.003\n",
            "Epoch: 649\n",
            "Train Loss: 0.0008995961281470955 | Train Time: 0.045\n",
            "Valid Loss: 0.0009250159782823175 | Valid Time: 0.004\n",
            "Epoch: 650\n",
            "Train Loss: 0.0009539648017380387 | Train Time: 0.046\n",
            "Valid Loss: 0.001102815440390259 | Valid Time: 0.003\n",
            "Epoch: 651\n",
            "Train Loss: 0.0008975925098638982 | Train Time: 0.048\n",
            "Valid Loss: 0.0012215448077768087 | Valid Time: 0.003\n",
            "Epoch: 652\n",
            "Train Loss: 0.000995794718619436 | Train Time: 0.044\n",
            "Valid Loss: 0.0012201565550640225 | Valid Time: 0.003\n",
            "Epoch: 653\n",
            "Train Loss: 0.0011280028324108572 | Train Time: 0.046\n",
            "Valid Loss: 0.0009713920007925481 | Valid Time: 0.003\n",
            "Epoch: 654\n",
            "Train Loss: 0.0007843561732443049 | Train Time: 0.052\n",
            "Valid Loss: 0.0006681237719021738 | Valid Time: 0.004\n",
            "Epoch: 655\n",
            "Train Loss: 0.0007189070922322572 | Train Time: 0.046\n",
            "Valid Loss: 0.0008320454799104482 | Valid Time: 0.003\n",
            "Epoch: 656\n",
            "Train Loss: 0.0008739642682485283 | Train Time: 0.045\n",
            "Valid Loss: 0.0011869263835251331 | Valid Time: 0.003\n",
            "Epoch: 657\n",
            "Train Loss: 0.0008708808920346201 | Train Time: 0.055\n",
            "Valid Loss: 0.0012335479841567576 | Valid Time: 0.003\n",
            "Epoch: 658\n",
            "Train Loss: 0.0009599190554581583 | Train Time: 0.055\n",
            "Valid Loss: 0.001361470902338624 | Valid Time: 0.003\n",
            "Epoch: 659\n",
            "Train Loss: 0.0012365587579552084 | Train Time: 0.045\n",
            "Valid Loss: 0.0006853523082099855 | Valid Time: 0.003\n",
            "Epoch: 660\n",
            "Train Loss: 0.0009042354242410511 | Train Time: 0.045\n",
            "Valid Loss: 0.0006623877270612866 | Valid Time: 0.004\n",
            "Epoch: 661\n",
            "Train Loss: 0.0006585243565496058 | Train Time: 0.056\n",
            "Valid Loss: 0.0006128056847956032 | Valid Time: 0.003\n",
            "Epoch: 662\n",
            "Train Loss: 0.0006403132865671068 | Train Time: 0.043\n",
            "Valid Loss: 0.0006420104764401913 | Valid Time: 0.003\n",
            "Epoch: 663\n",
            "Train Loss: 0.0006675467535387725 | Train Time: 0.045\n",
            "Valid Loss: 0.0006279245426412672 | Valid Time: 0.003\n",
            "Epoch: 664\n",
            "Train Loss: 0.0006712368805892766 | Train Time: 0.049\n",
            "Valid Loss: 0.0006585998926311731 | Valid Time: 0.003\n",
            "Epoch: 665\n",
            "Train Loss: 0.000734737969469279 | Train Time: 0.046\n",
            "Valid Loss: 0.0009032145026139915 | Valid Time: 0.003\n",
            "Epoch: 666\n",
            "Train Loss: 0.00071517025353387 | Train Time: 0.050\n",
            "Valid Loss: 0.0007339065487030894 | Valid Time: 0.004\n",
            "Epoch: 667\n",
            "Train Loss: 0.0007373424334218726 | Train Time: 0.046\n",
            "Valid Loss: 0.0009652315638959408 | Valid Time: 0.003\n",
            "Epoch: 668\n",
            "Train Loss: 0.0007046620885375887 | Train Time: 0.049\n",
            "Valid Loss: 0.0006496468558907509 | Valid Time: 0.003\n",
            "Epoch: 669\n",
            "Train Loss: 0.00066006796550937 | Train Time: 0.045\n",
            "Valid Loss: 0.0006623898807447404 | Valid Time: 0.003\n",
            "Epoch: 670\n",
            "Train Loss: 0.0007188929797848686 | Train Time: 0.045\n",
            "Valid Loss: 0.0007431220728904009 | Valid Time: 0.003\n",
            "Epoch: 671\n",
            "Train Loss: 0.0006653309799730777 | Train Time: 0.059\n",
            "Valid Loss: 0.0006501931056845933 | Valid Time: 0.003\n",
            "Epoch: 672\n",
            "Train Loss: 0.0007547773362603039 | Train Time: 0.046\n",
            "Valid Loss: 0.0007002393831498921 | Valid Time: 0.003\n",
            "Epoch: 673\n",
            "Train Loss: 0.0007733344391454011 | Train Time: 0.046\n",
            "Valid Loss: 0.0006240405200514942 | Valid Time: 0.003\n",
            "Epoch: 674\n",
            "Train Loss: 0.0007013968075625599 | Train Time: 0.046\n",
            "Valid Loss: 0.0007611668843310326 | Valid Time: 0.004\n",
            "Epoch: 675\n",
            "Train Loss: 0.0006703715946059674 | Train Time: 0.045\n",
            "Valid Loss: 0.0007081892108544707 | Valid Time: 0.003\n",
            "Epoch: 676\n",
            "Train Loss: 0.0007506508787628263 | Train Time: 0.051\n",
            "Valid Loss: 0.0007259857666213065 | Valid Time: 0.004\n",
            "Epoch: 677\n",
            "Train Loss: 0.0007772418553940952 | Train Time: 0.053\n",
            "Valid Loss: 0.0007413935381919146 | Valid Time: 0.003\n",
            "Epoch: 678\n",
            "Train Loss: 0.000804344384232536 | Train Time: 0.049\n",
            "Valid Loss: 0.0008511375053785741 | Valid Time: 0.003\n",
            "Epoch: 679\n",
            "Train Loss: 0.0010544431861490011 | Train Time: 0.046\n",
            "Valid Loss: 0.0013277072575874627 | Valid Time: 0.004\n",
            "Epoch: 680\n",
            "Train Loss: 0.0009742900787387043 | Train Time: 0.050\n",
            "Valid Loss: 0.001027918915497139 | Valid Time: 0.004\n",
            "Epoch: 681\n",
            "Train Loss: 0.0009609120723325759 | Train Time: 0.044\n",
            "Valid Loss: 0.0009903258178383112 | Valid Time: 0.003\n",
            "Epoch: 682\n",
            "Train Loss: 0.0010005557036492974 | Train Time: 0.045\n",
            "Valid Loss: 0.0006625753740081564 | Valid Time: 0.003\n",
            "Epoch: 683\n",
            "Train Loss: 0.0008397182042244822 | Train Time: 0.050\n",
            "Valid Loss: 0.0006059771403670311 | Valid Time: 0.003\n",
            "Epoch: 684\n",
            "Train Loss: 0.000640581437619403 | Train Time: 0.048\n",
            "Valid Loss: 0.0007119524525478482 | Valid Time: 0.007\n",
            "Epoch: 685\n",
            "Train Loss: 0.0006815186236053706 | Train Time: 0.047\n",
            "Valid Loss: 0.0007297270931303501 | Valid Time: 0.004\n",
            "Epoch: 686\n",
            "Train Loss: 0.0007798715902026743 | Train Time: 0.046\n",
            "Valid Loss: 0.0005983240553177893 | Valid Time: 0.003\n",
            "Epoch: 687\n",
            "Train Loss: 0.0007355367648415268 | Train Time: 0.051\n",
            "Valid Loss: 0.0007317860436160117 | Valid Time: 0.003\n",
            "Epoch: 688\n",
            "Train Loss: 0.0009257281839381903 | Train Time: 0.051\n",
            "Valid Loss: 0.0005974691011942923 | Valid Time: 0.005\n",
            "Epoch: 689\n",
            "Train Loss: 0.0008866497257258743 | Train Time: 0.045\n",
            "Valid Loss: 0.0013278702972456813 | Valid Time: 0.004\n",
            "Epoch: 690\n",
            "Train Loss: 0.0017344082531053572 | Train Time: 0.043\n",
            "Valid Loss: 0.0012400440755300224 | Valid Time: 0.003\n",
            "Epoch: 691\n",
            "Train Loss: 0.0010540187184233218 | Train Time: 0.051\n",
            "Valid Loss: 0.001105140254367143 | Valid Time: 0.003\n",
            "Epoch: 692\n",
            "Train Loss: 0.00094226393266581 | Train Time: 0.046\n",
            "Valid Loss: 0.0006821792339906096 | Valid Time: 0.006\n",
            "Epoch: 693\n",
            "Train Loss: 0.0009232557960785926 | Train Time: 0.045\n",
            "Valid Loss: 0.0011527013557497412 | Valid Time: 0.004\n",
            "Epoch: 694\n",
            "Train Loss: 0.0009759606327861547 | Train Time: 0.045\n",
            "Valid Loss: 0.0007682401919737458 | Valid Time: 0.003\n",
            "Epoch: 695\n",
            "Train Loss: 0.0009058630908839405 | Train Time: 0.045\n",
            "Valid Loss: 0.0007490785501431674 | Valid Time: 0.003\n",
            "Epoch: 696\n",
            "Train Loss: 0.0007553383940830827 | Train Time: 0.048\n",
            "Valid Loss: 0.0006660458166152239 | Valid Time: 0.003\n",
            "Epoch: 697\n",
            "Train Loss: 0.0007917271665064618 | Train Time: 0.055\n",
            "Valid Loss: 0.0006388212495949119 | Valid Time: 0.003\n",
            "Epoch: 698\n",
            "Train Loss: 0.0006913828430697322 | Train Time: 0.045\n",
            "Valid Loss: 0.0009171972633339465 | Valid Time: 0.005\n",
            "Epoch: 699\n",
            "Train Loss: 0.0007907704450190068 | Train Time: 0.049\n",
            "Valid Loss: 0.0007509169518016279 | Valid Time: 0.003\n",
            "Epoch: 700\n",
            "Train Loss: 0.0007115265587344765 | Train Time: 0.049\n",
            "Valid Loss: 0.0006508060323540121 | Valid Time: 0.003\n",
            "Epoch: 701\n",
            "Train Loss: 0.0006906346825417131 | Train Time: 0.044\n",
            "Valid Loss: 0.0006841212452854961 | Valid Time: 0.003\n",
            "Epoch: 702\n",
            "Train Loss: 0.0006992053356952965 | Train Time: 0.051\n",
            "Valid Loss: 0.000716190435923636 | Valid Time: 0.003\n",
            "Epoch: 703\n",
            "Train Loss: 0.0007250113820191472 | Train Time: 0.044\n",
            "Valid Loss: 0.000678070675348863 | Valid Time: 0.003\n",
            "Epoch: 704\n",
            "Train Loss: 0.0007030634325928987 | Train Time: 0.046\n",
            "Valid Loss: 0.0008819930080790073 | Valid Time: 0.004\n",
            "Epoch: 705\n",
            "Train Loss: 0.000778444396564737 | Train Time: 0.055\n",
            "Valid Loss: 0.0006598602049052715 | Valid Time: 0.003\n",
            "Epoch: 706\n",
            "Train Loss: 0.0007855223841033876 | Train Time: 0.046\n",
            "Valid Loss: 0.0008481986005790532 | Valid Time: 0.003\n",
            "Epoch: 707\n",
            "Train Loss: 0.0007433011429384351 | Train Time: 0.046\n",
            "Valid Loss: 0.0005939261754974723 | Valid Time: 0.003\n",
            "Epoch: 708\n",
            "Train Loss: 0.0007269600406289101 | Train Time: 0.053\n",
            "Valid Loss: 0.0006574679573532194 | Valid Time: 0.004\n",
            "Epoch: 709\n",
            "Train Loss: 0.0007006178726442158 | Train Time: 0.045\n",
            "Valid Loss: 0.000630597147392109 | Valid Time: 0.003\n",
            "Epoch: 710\n",
            "Train Loss: 0.0007124436146114021 | Train Time: 0.043\n",
            "Valid Loss: 0.0006914080295246094 | Valid Time: 0.003\n",
            "Epoch: 711\n",
            "Train Loss: 0.0007521437481045723 | Train Time: 0.045\n",
            "Valid Loss: 0.0007246299937833101 | Valid Time: 0.003\n",
            "Epoch: 712\n",
            "Train Loss: 0.0009138020395766944 | Train Time: 0.049\n",
            "Valid Loss: 0.0007365202764049172 | Valid Time: 0.003\n",
            "Epoch: 713\n",
            "Train Loss: 0.0008990379341412335 | Train Time: 0.049\n",
            "Valid Loss: 0.0006721350946463645 | Valid Time: 0.003\n",
            "Epoch: 714\n",
            "Train Loss: 0.0010233068198431284 | Train Time: 0.049\n",
            "Valid Loss: 0.0008003278635442257 | Valid Time: 0.004\n",
            "Epoch: 715\n",
            "Train Loss: 0.000952891306951642 | Train Time: 0.044\n",
            "Valid Loss: 0.0007274854287970811 | Valid Time: 0.003\n",
            "Epoch: 716\n",
            "Train Loss: 0.0007876643096096814 | Train Time: 0.049\n",
            "Valid Loss: 0.0010509258136153221 | Valid Time: 0.006\n",
            "Epoch: 717\n",
            "Train Loss: 0.0007480895379558206 | Train Time: 0.057\n",
            "Valid Loss: 0.0006414870440494269 | Valid Time: 0.003\n",
            "Epoch: 718\n",
            "Train Loss: 0.0007639781746547669 | Train Time: 0.046\n",
            "Valid Loss: 0.0008210507512558252 | Valid Time: 0.003\n",
            "Epoch: 719\n",
            "Train Loss: 0.0007918808376416564 | Train Time: 0.044\n",
            "Valid Loss: 0.0006361536798067391 | Valid Time: 0.003\n",
            "Epoch: 720\n",
            "Train Loss: 0.0006669549329672009 | Train Time: 0.049\n",
            "Valid Loss: 0.00102184820570983 | Valid Time: 0.003\n",
            "Epoch: 721\n",
            "Train Loss: 0.0007857500168029219 | Train Time: 0.044\n",
            "Valid Loss: 0.0006239923532120883 | Valid Time: 0.004\n",
            "Epoch: 722\n",
            "Train Loss: 0.0006905392045155167 | Train Time: 0.050\n",
            "Valid Loss: 0.0008054198115132749 | Valid Time: 0.004\n",
            "Epoch: 723\n",
            "Train Loss: 0.0009002578153740615 | Train Time: 0.045\n",
            "Valid Loss: 0.0011911066249012947 | Valid Time: 0.003\n",
            "Epoch: 724\n",
            "Train Loss: 0.0010500839096494019 | Train Time: 0.050\n",
            "Valid Loss: 0.0007032386492937803 | Valid Time: 0.003\n",
            "Epoch: 725\n",
            "Train Loss: 0.0007853661489207297 | Train Time: 0.044\n",
            "Valid Loss: 0.0008140531426761299 | Valid Time: 0.003\n",
            "Epoch: 726\n",
            "Train Loss: 0.0007333281275350601 | Train Time: 0.050\n",
            "Valid Loss: 0.0010539282229728997 | Valid Time: 0.003\n",
            "Epoch: 727\n",
            "Train Loss: 0.0011665006109979003 | Train Time: 0.052\n",
            "Valid Loss: 0.0016378227737732232 | Valid Time: 0.003\n",
            "Epoch: 728\n",
            "Train Loss: 0.0012077360413968563 | Train Time: 0.045\n",
            "Valid Loss: 0.0007760725566186011 | Valid Time: 0.003\n",
            "Epoch: 729\n",
            "Train Loss: 0.001089947286527604 | Train Time: 0.045\n",
            "Valid Loss: 0.0006355904624797404 | Valid Time: 0.003\n",
            "Epoch: 730\n",
            "Train Loss: 0.0008064436202403158 | Train Time: 0.058\n",
            "Valid Loss: 0.0006564190844073892 | Valid Time: 0.003\n",
            "Epoch: 731\n",
            "Train Loss: 0.0008469361870083958 | Train Time: 0.045\n",
            "Valid Loss: 0.0005903525452595204 | Valid Time: 0.003\n",
            "Epoch: 732\n",
            "Train Loss: 0.000930634920950979 | Train Time: 0.045\n",
            "Valid Loss: 0.0006827202159911394 | Valid Time: 0.003\n",
            "Epoch: 733\n",
            "Train Loss: 0.0009573032555636018 | Train Time: 0.051\n",
            "Valid Loss: 0.0012131411349400878 | Valid Time: 0.003\n",
            "Epoch: 734\n",
            "Train Loss: 0.0013280497689265758 | Train Time: 0.044\n",
            "Valid Loss: 0.0007562048267573118 | Valid Time: 0.005\n",
            "Epoch: 735\n",
            "Train Loss: 0.0012173401191830635 | Train Time: 0.046\n",
            "Valid Loss: 0.0008930771145969629 | Valid Time: 0.004\n",
            "Epoch: 736\n",
            "Train Loss: 0.0008711926115211099 | Train Time: 0.056\n",
            "Valid Loss: 0.0006142485653981566 | Valid Time: 0.005\n",
            "Epoch: 737\n",
            "Train Loss: 0.0007047384162433446 | Train Time: 0.056\n",
            "Valid Loss: 0.0007144625706132501 | Valid Time: 0.003\n",
            "Epoch: 738\n",
            "Train Loss: 0.0006628702394664288 | Train Time: 0.052\n",
            "Valid Loss: 0.0007042174111120403 | Valid Time: 0.003\n",
            "Epoch: 739\n",
            "Train Loss: 0.000743096403311938 | Train Time: 0.047\n",
            "Valid Loss: 0.0007735781837254763 | Valid Time: 0.004\n",
            "Epoch: 740\n",
            "Train Loss: 0.0012699119106400758 | Train Time: 0.046\n",
            "Valid Loss: 0.0019858379382640123 | Valid Time: 0.005\n",
            "Epoch: 741\n",
            "Train Loss: 0.0011325986532028764 | Train Time: 0.046\n",
            "Valid Loss: 0.0007760464795865119 | Valid Time: 0.003\n",
            "Epoch: 742\n",
            "Train Loss: 0.001023914397228509 | Train Time: 0.046\n",
            "Valid Loss: 0.0007220915285870433 | Valid Time: 0.007\n",
            "Epoch: 743\n",
            "Train Loss: 0.0006994567636866122 | Train Time: 0.082\n",
            "Valid Loss: 0.000810445926617831 | Valid Time: 0.006\n",
            "Epoch: 744\n",
            "Train Loss: 0.0006890996766742319 | Train Time: 0.066\n",
            "Valid Loss: 0.0006794533401262015 | Valid Time: 0.006\n",
            "Epoch: 745\n",
            "Train Loss: 0.0006937988742720336 | Train Time: 0.071\n",
            "Valid Loss: 0.0007812684634700418 | Valid Time: 0.006\n",
            "Epoch: 746\n",
            "Train Loss: 0.0007507108559366316 | Train Time: 0.064\n",
            "Valid Loss: 0.0006530508981086314 | Valid Time: 0.005\n",
            "Epoch: 747\n",
            "Train Loss: 0.000874746113549918 | Train Time: 0.068\n",
            "Valid Loss: 0.0006156317831482738 | Valid Time: 0.005\n",
            "Epoch: 748\n",
            "Train Loss: 0.000698836863739416 | Train Time: 0.070\n",
            "Valid Loss: 0.0006190654530655593 | Valid Time: 0.005\n",
            "Epoch: 749\n",
            "Train Loss: 0.000669863383518532 | Train Time: 0.062\n",
            "Valid Loss: 0.0006643148954026401 | Valid Time: 0.004\n",
            "Epoch: 750\n",
            "Train Loss: 0.0007035739137791098 | Train Time: 0.062\n",
            "Valid Loss: 0.000716936425305903 | Valid Time: 0.004\n",
            "Epoch: 751\n",
            "Train Loss: 0.0008006371092051268 | Train Time: 0.068\n",
            "Valid Loss: 0.0007686957542318851 | Valid Time: 0.005\n",
            "Epoch: 752\n",
            "Train Loss: 0.0007079167175106704 | Train Time: 0.066\n",
            "Valid Loss: 0.0005963123694527894 | Valid Time: 0.005\n",
            "Epoch: 753\n",
            "Train Loss: 0.000639621407026425 | Train Time: 0.062\n",
            "Valid Loss: 0.000598523358348757 | Valid Time: 0.005\n",
            "Epoch: 754\n",
            "Train Loss: 0.000814478361280635 | Train Time: 0.070\n",
            "Valid Loss: 0.0007898040057625622 | Valid Time: 0.005\n",
            "Epoch: 755\n",
            "Train Loss: 0.0008200720301829278 | Train Time: 0.063\n",
            "Valid Loss: 0.0008764937520027161 | Valid Time: 0.004\n",
            "Epoch: 756\n",
            "Train Loss: 0.0008692917646840215 | Train Time: 0.063\n",
            "Valid Loss: 0.0009117989975493401 | Valid Time: 0.007\n",
            "Epoch: 757\n",
            "Train Loss: 0.0010937654471490533 | Train Time: 0.075\n",
            "Valid Loss: 0.0009339214884676039 | Valid Time: 0.006\n",
            "Epoch: 758\n",
            "Train Loss: 0.0007964360411278903 | Train Time: 0.071\n",
            "Valid Loss: 0.0007758346910122782 | Valid Time: 0.005\n",
            "Epoch: 759\n",
            "Train Loss: 0.0007625140657182783 | Train Time: 0.065\n",
            "Valid Loss: 0.000748185528209433 | Valid Time: 0.005\n",
            "Epoch: 760\n",
            "Train Loss: 0.0008046547300182283 | Train Time: 0.070\n",
            "Valid Loss: 0.0007654853397980332 | Valid Time: 0.006\n",
            "Epoch: 761\n",
            "Train Loss: 0.0008815900073386729 | Train Time: 0.064\n",
            "Valid Loss: 0.000997028750134632 | Valid Time: 0.005\n",
            "Epoch: 762\n",
            "Train Loss: 0.0009550051589030772 | Train Time: 0.062\n",
            "Valid Loss: 0.0008749490370973945 | Valid Time: 0.005\n",
            "Epoch: 763\n",
            "Train Loss: 0.0008996049466077239 | Train Time: 0.071\n",
            "Valid Loss: 0.0008607113850302994 | Valid Time: 0.007\n",
            "Epoch: 764\n",
            "Train Loss: 0.001418073457898572 | Train Time: 0.061\n",
            "Valid Loss: 0.0014228990767151117 | Valid Time: 0.005\n",
            "Epoch: 765\n",
            "Train Loss: 0.0009969607228413225 | Train Time: 0.064\n",
            "Valid Loss: 0.0008526000019628555 | Valid Time: 0.005\n",
            "Epoch: 766\n",
            "Train Loss: 0.00086140051134862 | Train Time: 0.081\n",
            "Valid Loss: 0.0011205982300452888 | Valid Time: 0.005\n",
            "Epoch: 767\n",
            "Train Loss: 0.0010654543584678322 | Train Time: 0.068\n",
            "Valid Loss: 0.0009570041438564658 | Valid Time: 0.005\n",
            "Epoch: 768\n",
            "Train Loss: 0.0008639886393211782 | Train Time: 0.069\n",
            "Valid Loss: 0.0007368000224232674 | Valid Time: 0.004\n",
            "Epoch: 769\n",
            "Train Loss: 0.0009623916819691658 | Train Time: 0.068\n",
            "Valid Loss: 0.0006743027188349515 | Valid Time: 0.006\n",
            "Epoch: 770\n",
            "Train Loss: 0.0010924850823357702 | Train Time: 0.076\n",
            "Valid Loss: 0.0013454155414365232 | Valid Time: 0.005\n",
            "Epoch: 771\n",
            "Train Loss: 0.0013269165123347194 | Train Time: 0.066\n",
            "Valid Loss: 0.000929993053432554 | Valid Time: 0.005\n",
            "Epoch: 772\n",
            "Train Loss: 0.0008668721420690417 | Train Time: 0.070\n",
            "Valid Loss: 0.000739934213925153 | Valid Time: 0.005\n",
            "Epoch: 773\n",
            "Train Loss: 0.0006984932697378099 | Train Time: 0.070\n",
            "Valid Loss: 0.0006241305381990969 | Valid Time: 0.005\n",
            "Epoch: 774\n",
            "Train Loss: 0.0006815311906393617 | Train Time: 0.071\n",
            "Valid Loss: 0.0006941709434613585 | Valid Time: 0.006\n",
            "Epoch: 775\n",
            "Train Loss: 0.000676925532752648 | Train Time: 0.054\n",
            "Valid Loss: 0.0006242689269129187 | Valid Time: 0.003\n",
            "Epoch: 776\n",
            "Train Loss: 0.0007102863164618611 | Train Time: 0.044\n",
            "Valid Loss: 0.0008570292266085744 | Valid Time: 0.003\n",
            "Epoch: 777\n",
            "Train Loss: 0.0007389289501588791 | Train Time: 0.045\n",
            "Valid Loss: 0.0006741317338310182 | Valid Time: 0.003\n",
            "Epoch: 778\n",
            "Train Loss: 0.0006706592219416052 | Train Time: 0.047\n",
            "Valid Loss: 0.0006991302070673555 | Valid Time: 0.003\n",
            "Epoch: 779\n",
            "Train Loss: 0.0006600879540201276 | Train Time: 0.044\n",
            "Valid Loss: 0.0007779186416883022 | Valid Time: 0.003\n",
            "Epoch: 780\n",
            "Train Loss: 0.0007230489078210667 | Train Time: 0.052\n",
            "Valid Loss: 0.0009047065977938473 | Valid Time: 0.003\n",
            "Epoch: 781\n",
            "Train Loss: 0.000806367868790403 | Train Time: 0.045\n",
            "Valid Loss: 0.0007119131623767316 | Valid Time: 0.003\n",
            "Epoch: 782\n",
            "Train Loss: 0.0006617150735110045 | Train Time: 0.056\n",
            "Valid Loss: 0.000634323398116976 | Valid Time: 0.004\n",
            "Epoch: 783\n",
            "Train Loss: 0.0006906562251970172 | Train Time: 0.045\n",
            "Valid Loss: 0.000652780756354332 | Valid Time: 0.003\n",
            "Epoch: 784\n",
            "Train Loss: 0.0006506451143650338 | Train Time: 0.054\n",
            "Valid Loss: 0.000639352307189256 | Valid Time: 0.004\n",
            "Epoch: 785\n",
            "Train Loss: 0.0006436740281060338 | Train Time: 0.046\n",
            "Valid Loss: 0.0006603533111047 | Valid Time: 0.003\n",
            "Epoch: 786\n",
            "Train Loss: 0.0007710007310379296 | Train Time: 0.046\n",
            "Valid Loss: 0.0008879932574927807 | Valid Time: 0.003\n",
            "Epoch: 787\n",
            "Train Loss: 0.000921726378146559 | Train Time: 0.049\n",
            "Valid Loss: 0.0006842766306363046 | Valid Time: 0.003\n",
            "Epoch: 788\n",
            "Train Loss: 0.0008068292227108032 | Train Time: 0.045\n",
            "Valid Loss: 0.0007929347630124539 | Valid Time: 0.003\n",
            "Epoch: 789\n",
            "Train Loss: 0.0007168595679104328 | Train Time: 0.050\n",
            "Valid Loss: 0.0007133163453545421 | Valid Time: 0.004\n",
            "Epoch: 790\n",
            "Train Loss: 0.000695742096286267 | Train Time: 0.044\n",
            "Valid Loss: 0.0007981729868333787 | Valid Time: 0.003\n",
            "Epoch: 791\n",
            "Train Loss: 0.0006865612987894565 | Train Time: 0.050\n",
            "Valid Loss: 0.0006964924687054008 | Valid Time: 0.003\n",
            "Epoch: 792\n",
            "Train Loss: 0.0006875241233501583 | Train Time: 0.043\n",
            "Valid Loss: 0.0008547471661586314 | Valid Time: 0.003\n",
            "Epoch: 793\n",
            "Train Loss: 0.0008460392127744853 | Train Time: 0.052\n",
            "Valid Loss: 0.0005896013462916017 | Valid Time: 0.003\n",
            "Epoch: 794\n",
            "Train Loss: 0.0007259412086568773 | Train Time: 0.049\n",
            "Valid Loss: 0.0008686727960593998 | Valid Time: 0.003\n",
            "Epoch: 795\n",
            "Train Loss: 0.0007902718964032829 | Train Time: 0.046\n",
            "Valid Loss: 0.0006222394003998488 | Valid Time: 0.003\n",
            "Epoch: 796\n",
            "Train Loss: 0.0006676233548205346 | Train Time: 0.045\n",
            "Valid Loss: 0.0006119049503467977 | Valid Time: 0.003\n",
            "Epoch: 797\n",
            "Train Loss: 0.0007487690367270261 | Train Time: 0.045\n",
            "Valid Loss: 0.0006939302256796509 | Valid Time: 0.005\n",
            "Epoch: 798\n",
            "Train Loss: 0.0008072004944551736 | Train Time: 0.054\n",
            "Valid Loss: 0.0007178246742114425 | Valid Time: 0.003\n",
            "Epoch: 799\n",
            "Train Loss: 0.0006296661362284794 | Train Time: 0.046\n",
            "Valid Loss: 0.0005776750767836347 | Valid Time: 0.003\n",
            "Epoch: 800\n",
            "Train Loss: 0.000779419663012959 | Train Time: 0.045\n",
            "Valid Loss: 0.0006600020569749177 | Valid Time: 0.003\n",
            "Epoch: 801\n",
            "Train Loss: 0.0008378130209166556 | Train Time: 0.062\n",
            "Valid Loss: 0.0009624373633414507 | Valid Time: 0.003\n",
            "Epoch: 802\n",
            "Train Loss: 0.0008460086712148041 | Train Time: 0.044\n",
            "Valid Loss: 0.0010925946407951415 | Valid Time: 0.003\n",
            "Epoch: 803\n",
            "Train Loss: 0.0009189484757371247 | Train Time: 0.044\n",
            "Valid Loss: 0.0006916495331097394 | Valid Time: 0.003\n",
            "Epoch: 804\n",
            "Train Loss: 0.0008467105799354613 | Train Time: 0.051\n",
            "Valid Loss: 0.0006237445923034102 | Valid Time: 0.003\n",
            "Epoch: 805\n",
            "Train Loss: 0.0006763507262803614 | Train Time: 0.043\n",
            "Valid Loss: 0.0006913127435836941 | Valid Time: 0.003\n",
            "Epoch: 806\n",
            "Train Loss: 0.0006782800453947857 | Train Time: 0.048\n",
            "Valid Loss: 0.0006263517425395548 | Valid Time: 0.003\n",
            "Epoch: 807\n",
            "Train Loss: 0.0006909299467224628 | Train Time: 0.044\n",
            "Valid Loss: 0.0006808437028666958 | Valid Time: 0.004\n",
            "Epoch: 808\n",
            "Train Loss: 0.0006543947733007371 | Train Time: 0.047\n",
            "Valid Loss: 0.0007008036191109568 | Valid Time: 0.003\n",
            "Epoch: 809\n",
            "Train Loss: 0.0006771948654204607 | Train Time: 0.046\n",
            "Valid Loss: 0.00061226193793118 | Valid Time: 0.003\n",
            "Epoch: 810\n",
            "Train Loss: 0.000717257522046566 | Train Time: 0.050\n",
            "Valid Loss: 0.0006951043615117669 | Valid Time: 0.003\n",
            "Epoch: 811\n",
            "Train Loss: 0.000742219021776691 | Train Time: 0.051\n",
            "Valid Loss: 0.0008171056106220931 | Valid Time: 0.003\n",
            "Epoch: 812\n",
            "Train Loss: 0.0008267637167591602 | Train Time: 0.046\n",
            "Valid Loss: 0.0007945889083202928 | Valid Time: 0.003\n",
            "Epoch: 813\n",
            "Train Loss: 0.000920769659569487 | Train Time: 0.046\n",
            "Valid Loss: 0.0006027664639987051 | Valid Time: 0.004\n",
            "Epoch: 814\n",
            "Train Loss: 0.0009027230204083026 | Train Time: 0.056\n",
            "Valid Loss: 0.001205016567837447 | Valid Time: 0.003\n",
            "Epoch: 815\n",
            "Train Loss: 0.001368684828048572 | Train Time: 0.045\n",
            "Valid Loss: 0.0008264967473223805 | Valid Time: 0.003\n",
            "Epoch: 816\n",
            "Train Loss: 0.0010473520786035806 | Train Time: 0.048\n",
            "Valid Loss: 0.0012967032962478697 | Valid Time: 0.003\n",
            "Epoch: 817\n",
            "Train Loss: 0.0009388332080561667 | Train Time: 0.045\n",
            "Valid Loss: 0.0007444513612426817 | Valid Time: 0.004\n",
            "Epoch: 818\n",
            "Train Loss: 0.0007443927286658436 | Train Time: 0.044\n",
            "Valid Loss: 0.00083133127191104 | Valid Time: 0.003\n",
            "Epoch: 819\n",
            "Train Loss: 0.0007991837919689715 | Train Time: 0.049\n",
            "Valid Loss: 0.0008082512649707496 | Valid Time: 0.003\n",
            "Epoch: 820\n",
            "Train Loss: 0.0008683684398420155 | Train Time: 0.049\n",
            "Valid Loss: 0.0007184311980381608 | Valid Time: 0.003\n",
            "Epoch: 821\n",
            "Train Loss: 0.0008278180204797537 | Train Time: 0.053\n",
            "Valid Loss: 0.0007975657936185598 | Valid Time: 0.004\n",
            "Epoch: 822\n",
            "Train Loss: 0.0009747661417350173 | Train Time: 0.044\n",
            "Valid Loss: 0.0006722818070556968 | Valid Time: 0.003\n",
            "Epoch: 823\n",
            "Train Loss: 0.0007086671772412956 | Train Time: 0.056\n",
            "Valid Loss: 0.0007062264485284686 | Valid Time: 0.007\n",
            "Epoch: 824\n",
            "Train Loss: 0.000646818766836077 | Train Time: 0.056\n",
            "Valid Loss: 0.000729580206098035 | Valid Time: 0.003\n",
            "Epoch: 825\n",
            "Train Loss: 0.0006798747694119811 | Train Time: 0.047\n",
            "Valid Loss: 0.000964520761044696 | Valid Time: 0.004\n",
            "Epoch: 826\n",
            "Train Loss: 0.0007649613311514258 | Train Time: 0.044\n",
            "Valid Loss: 0.0007093425956554711 | Valid Time: 0.003\n",
            "Epoch: 827\n",
            "Train Loss: 0.0007821998558938503 | Train Time: 0.047\n",
            "Valid Loss: 0.0006165372324176133 | Valid Time: 0.003\n",
            "Epoch: 828\n",
            "Train Loss: 0.0007543611689470708 | Train Time: 0.048\n",
            "Valid Loss: 0.0005968140903860331 | Valid Time: 0.003\n",
            "Epoch: 829\n",
            "Train Loss: 0.0006875769817270338 | Train Time: 0.044\n",
            "Valid Loss: 0.0006125073414295912 | Valid Time: 0.004\n",
            "Epoch: 830\n",
            "Train Loss: 0.0008075844496488571 | Train Time: 0.044\n",
            "Valid Loss: 0.0007655124645680189 | Valid Time: 0.003\n",
            "Epoch: 831\n",
            "Train Loss: 0.0007306781073566527 | Train Time: 0.053\n",
            "Valid Loss: 0.0007049306004773825 | Valid Time: 0.006\n",
            "Epoch: 832\n",
            "Train Loss: 0.0007220766274258494 | Train Time: 0.044\n",
            "Valid Loss: 0.0008118055120576173 | Valid Time: 0.003\n",
            "Epoch: 833\n",
            "Train Loss: 0.0006575380451977253 | Train Time: 0.045\n",
            "Valid Loss: 0.0006741392717231065 | Valid Time: 0.003\n",
            "Epoch: 834\n",
            "Train Loss: 0.0006518785026855767 | Train Time: 0.047\n",
            "Valid Loss: 0.0006004188908264041 | Valid Time: 0.003\n",
            "Epoch: 835\n",
            "Train Loss: 0.0007283805753104389 | Train Time: 0.044\n",
            "Valid Loss: 0.000717905058991164 | Valid Time: 0.003\n",
            "Epoch: 836\n",
            "Train Loss: 0.0007037408300675452 | Train Time: 0.050\n",
            "Valid Loss: 0.000770470331190154 | Valid Time: 0.003\n",
            "Epoch: 837\n",
            "Train Loss: 0.0007592496927827597 | Train Time: 0.047\n",
            "Valid Loss: 0.0006449445500038564 | Valid Time: 0.003\n",
            "Epoch: 838\n",
            "Train Loss: 0.0008148319786414504 | Train Time: 0.051\n",
            "Valid Loss: 0.0006335276993922889 | Valid Time: 0.004\n",
            "Epoch: 839\n",
            "Train Loss: 0.0006499816721770912 | Train Time: 0.044\n",
            "Valid Loss: 0.0006300199893303216 | Valid Time: 0.003\n",
            "Epoch: 840\n",
            "Train Loss: 0.0006368439237121493 | Train Time: 0.052\n",
            "Valid Loss: 0.0005722368077840656 | Valid Time: 0.006\n",
            "Epoch: 841\n",
            "Train Loss: 0.0008016967272851616 | Train Time: 0.045\n",
            "Valid Loss: 0.0006859739660285413 | Valid Time: 0.003\n",
            "Epoch: 842\n",
            "Train Loss: 0.0008656078018248082 | Train Time: 0.044\n",
            "Valid Loss: 0.0008906637376639992 | Valid Time: 0.003\n",
            "Epoch: 843\n",
            "Train Loss: 0.0007609145774040371 | Train Time: 0.048\n",
            "Valid Loss: 0.0006593725411221385 | Valid Time: 0.003\n",
            "Epoch: 844\n",
            "Train Loss: 0.0006841539579909295 | Train Time: 0.045\n",
            "Valid Loss: 0.0007202838023658842 | Valid Time: 0.003\n",
            "Epoch: 845\n",
            "Train Loss: 0.0006861073488835245 | Train Time: 0.048\n",
            "Valid Loss: 0.0006593117723241448 | Valid Time: 0.003\n",
            "Epoch: 846\n",
            "Train Loss: 0.0006625860318308696 | Train Time: 0.050\n",
            "Valid Loss: 0.0006170534470584244 | Valid Time: 0.003\n",
            "Epoch: 847\n",
            "Train Loss: 0.0006793688604375348 | Train Time: 0.047\n",
            "Valid Loss: 0.0006738420925103128 | Valid Time: 0.003\n",
            "Epoch: 848\n",
            "Train Loss: 0.000859657023102045 | Train Time: 0.048\n",
            "Valid Loss: 0.001194568583741784 | Valid Time: 0.004\n",
            "Epoch: 849\n",
            "Train Loss: 0.0009827825473621488 | Train Time: 0.053\n",
            "Valid Loss: 0.0009257369965780526 | Valid Time: 0.004\n",
            "Epoch: 850\n",
            "Train Loss: 0.0006829879595898092 | Train Time: 0.048\n",
            "Valid Loss: 0.0006713303446304053 | Valid Time: 0.003\n",
            "Epoch: 851\n",
            "Train Loss: 0.0006460704142227768 | Train Time: 0.043\n",
            "Valid Loss: 0.0006212801381479949 | Valid Time: 0.003\n",
            "Epoch: 852\n",
            "Train Loss: 0.000668417225824669 | Train Time: 0.049\n",
            "Valid Loss: 0.0006476632552221417 | Valid Time: 0.003\n",
            "Epoch: 853\n",
            "Train Loss: 0.0006693839706713334 | Train Time: 0.044\n",
            "Valid Loss: 0.0007280447171069682 | Valid Time: 0.004\n",
            "Epoch: 854\n",
            "Train Loss: 0.000672826383379288 | Train Time: 0.049\n",
            "Valid Loss: 0.0006526019133161753 | Valid Time: 0.004\n",
            "Epoch: 855\n",
            "Train Loss: 0.000725877910736017 | Train Time: 0.046\n",
            "Valid Loss: 0.0009608352847862989 | Valid Time: 0.003\n",
            "Epoch: 856\n",
            "Train Loss: 0.0010287750221323222 | Train Time: 0.050\n",
            "Valid Loss: 0.0010272689105477184 | Valid Time: 0.003\n",
            "Epoch: 857\n",
            "Train Loss: 0.0008535782573744655 | Train Time: 0.050\n",
            "Valid Loss: 0.0011392731685191393 | Valid Time: 0.006\n",
            "Epoch: 858\n",
            "Train Loss: 0.0008268060570117086 | Train Time: 0.045\n",
            "Valid Loss: 0.0005842908867634833 | Valid Time: 0.003\n",
            "Epoch: 859\n",
            "Train Loss: 0.0006397610355634243 | Train Time: 0.046\n",
            "Valid Loss: 0.0006500618328573182 | Valid Time: 0.004\n",
            "Epoch: 860\n",
            "Train Loss: 0.0006546197517309337 | Train Time: 0.063\n",
            "Valid Loss: 0.0006147253297967836 | Valid Time: 0.004\n",
            "Epoch: 861\n",
            "Train Loss: 0.0006509542174171657 | Train Time: 0.052\n",
            "Valid Loss: 0.000628627632977441 | Valid Time: 0.004\n",
            "Epoch: 862\n",
            "Train Loss: 0.0007319912256207317 | Train Time: 0.044\n",
            "Valid Loss: 0.0007130383746698499 | Valid Time: 0.003\n",
            "Epoch: 863\n",
            "Train Loss: 0.0006611517339479179 | Train Time: 0.046\n",
            "Valid Loss: 0.0007288716151379049 | Valid Time: 0.003\n",
            "Epoch: 864\n",
            "Train Loss: 0.0006647170230280608 | Train Time: 0.052\n",
            "Valid Loss: 0.0007138930086512119 | Valid Time: 0.004\n",
            "Epoch: 865\n",
            "Train Loss: 0.0007679438742343337 | Train Time: 0.049\n",
            "Valid Loss: 0.0007967464334797114 | Valid Time: 0.006\n",
            "Epoch: 866\n",
            "Train Loss: 0.0007263974519446492 | Train Time: 0.050\n",
            "Valid Loss: 0.0010915354068856686 | Valid Time: 0.003\n",
            "Epoch: 867\n",
            "Train Loss: 0.0009438545384909958 | Train Time: 0.045\n",
            "Valid Loss: 0.0011036577634513378 | Valid Time: 0.003\n",
            "Epoch: 868\n",
            "Train Loss: 0.0010432407376356422 | Train Time: 0.044\n",
            "Valid Loss: 0.0007747778145130724 | Valid Time: 0.003\n",
            "Epoch: 869\n",
            "Train Loss: 0.0011395751440431922 | Train Time: 0.044\n",
            "Valid Loss: 0.0008060001709964126 | Valid Time: 0.003\n",
            "Epoch: 870\n",
            "Train Loss: 0.0009388108795974403 | Train Time: 0.052\n",
            "Valid Loss: 0.0010008881508838385 | Valid Time: 0.003\n",
            "Epoch: 871\n",
            "Train Loss: 0.0009702616895083338 | Train Time: 0.045\n",
            "Valid Loss: 0.0009903583268169314 | Valid Time: 0.003\n",
            "Epoch: 872\n",
            "Train Loss: 0.0009224968787748366 | Train Time: 0.045\n",
            "Valid Loss: 0.0006964970380067825 | Valid Time: 0.005\n",
            "Epoch: 873\n",
            "Train Loss: 0.0009486611001193523 | Train Time: 0.046\n",
            "Valid Loss: 0.0008711305854376405 | Valid Time: 0.003\n",
            "Epoch: 874\n",
            "Train Loss: 0.0009678969217929989 | Train Time: 0.043\n",
            "Valid Loss: 0.0007205028960015625 | Valid Time: 0.003\n",
            "Epoch: 875\n",
            "Train Loss: 0.0007647355610970408 | Train Time: 0.050\n",
            "Valid Loss: 0.0008247124205809087 | Valid Time: 0.003\n",
            "Epoch: 876\n",
            "Train Loss: 0.0007220009167212993 | Train Time: 0.047\n",
            "Valid Loss: 0.0008768507977947593 | Valid Time: 0.003\n",
            "Epoch: 877\n",
            "Train Loss: 0.0007025173399597406 | Train Time: 0.050\n",
            "Valid Loss: 0.0007575247727800161 | Valid Time: 0.003\n",
            "Epoch: 878\n",
            "Train Loss: 0.000732406839961186 | Train Time: 0.044\n",
            "Valid Loss: 0.0006357202073559165 | Valid Time: 0.003\n",
            "Epoch: 879\n",
            "Train Loss: 0.0007388209400232881 | Train Time: 0.044\n",
            "Valid Loss: 0.0007632507476955652 | Valid Time: 0.005\n",
            "Epoch: 880\n",
            "Train Loss: 0.0007780089101288468 | Train Time: 0.060\n",
            "Valid Loss: 0.0006065198103897274 | Valid Time: 0.003\n",
            "Epoch: 881\n",
            "Train Loss: 0.000752174062654376 | Train Time: 0.048\n",
            "Valid Loss: 0.0006617990438826382 | Valid Time: 0.004\n",
            "Epoch: 882\n",
            "Train Loss: 0.0008674060431076214 | Train Time: 0.043\n",
            "Valid Loss: 0.0008859962981659919 | Valid Time: 0.003\n",
            "Epoch: 883\n",
            "Train Loss: 0.0008254335669334977 | Train Time: 0.046\n",
            "Valid Loss: 0.0009074557165149599 | Valid Time: 0.006\n",
            "Epoch: 884\n",
            "Train Loss: 0.0008793073007836938 | Train Time: 0.050\n",
            "Valid Loss: 0.0009196702449116856 | Valid Time: 0.003\n",
            "Epoch: 885\n",
            "Train Loss: 0.0008203279285226017 | Train Time: 0.044\n",
            "Valid Loss: 0.00071884342469275 | Valid Time: 0.003\n",
            "Epoch: 886\n",
            "Train Loss: 0.0007705989526584744 | Train Time: 0.045\n",
            "Valid Loss: 0.0007775364501867443 | Valid Time: 0.003\n",
            "Epoch: 887\n",
            "Train Loss: 0.0006966830522287637 | Train Time: 0.046\n",
            "Valid Loss: 0.0005848881555721164 | Valid Time: 0.007\n",
            "Epoch: 888\n",
            "Train Loss: 0.0006682195875328034 | Train Time: 0.046\n",
            "Valid Loss: 0.0007188314048107713 | Valid Time: 0.003\n",
            "Epoch: 889\n",
            "Train Loss: 0.0006697846809402108 | Train Time: 0.045\n",
            "Valid Loss: 0.0006546178483404219 | Valid Time: 0.003\n",
            "Epoch: 890\n",
            "Train Loss: 0.0006474267080193386 | Train Time: 0.048\n",
            "Valid Loss: 0.0006297713553067297 | Valid Time: 0.003\n",
            "Epoch: 891\n",
            "Train Loss: 0.00065824119374156 | Train Time: 0.045\n",
            "Valid Loss: 0.0006308408919721842 | Valid Time: 0.007\n",
            "Epoch: 892\n",
            "Train Loss: 0.0006384792795870453 | Train Time: 0.045\n",
            "Valid Loss: 0.0006416479882318527 | Valid Time: 0.004\n",
            "Epoch: 893\n",
            "Train Loss: 0.0007480734260752797 | Train Time: 0.044\n",
            "Valid Loss: 0.0008969494665507227 | Valid Time: 0.003\n",
            "Epoch: 894\n",
            "Train Loss: 0.0007433811551891267 | Train Time: 0.049\n",
            "Valid Loss: 0.0011185045004822314 | Valid Time: 0.003\n",
            "Epoch: 895\n",
            "Train Loss: 0.0008237059460952878 | Train Time: 0.045\n",
            "Valid Loss: 0.0007247538305819035 | Valid Time: 0.005\n",
            "Epoch: 896\n",
            "Train Loss: 0.0007036852359306068 | Train Time: 0.052\n",
            "Valid Loss: 0.0006071733660064638 | Valid Time: 0.003\n",
            "Epoch: 897\n",
            "Train Loss: 0.000705442315666005 | Train Time: 0.043\n",
            "Valid Loss: 0.0006105873617343605 | Valid Time: 0.003\n",
            "Epoch: 898\n",
            "Train Loss: 0.0006543546973261982 | Train Time: 0.050\n",
            "Valid Loss: 0.0006225527031347156 | Valid Time: 0.003\n",
            "Epoch: 899\n",
            "Train Loss: 0.0006447401654440909 | Train Time: 0.053\n",
            "Valid Loss: 0.0008623078756500036 | Valid Time: 0.006\n",
            "Epoch: 900\n",
            "Train Loss: 0.0006908275216119363 | Train Time: 0.044\n",
            "Valid Loss: 0.0006181640492286533 | Valid Time: 0.003\n",
            "Epoch: 901\n",
            "Train Loss: 0.000879938475554809 | Train Time: 0.050\n",
            "Valid Loss: 0.0011673209082800895 | Valid Time: 0.004\n",
            "Epoch: 902\n",
            "Train Loss: 0.0009925701247993856 | Train Time: 0.044\n",
            "Valid Loss: 0.0007594194321427494 | Valid Time: 0.003\n",
            "Epoch: 903\n",
            "Train Loss: 0.0008948581060394644 | Train Time: 0.045\n",
            "Valid Loss: 0.0009208736300934106 | Valid Time: 0.004\n",
            "Epoch: 904\n",
            "Train Loss: 0.0008404185646213591 | Train Time: 0.054\n",
            "Valid Loss: 0.000696181581588462 | Valid Time: 0.003\n",
            "Epoch: 905\n",
            "Train Loss: 0.0007078205933794379 | Train Time: 0.044\n",
            "Valid Loss: 0.0006625227979384363 | Valid Time: 0.003\n",
            "Epoch: 906\n",
            "Train Loss: 0.000647082703653723 | Train Time: 0.045\n",
            "Valid Loss: 0.0006534206913784146 | Valid Time: 0.003\n",
            "Epoch: 907\n",
            "Train Loss: 0.0006896036386024207 | Train Time: 0.059\n",
            "Valid Loss: 0.0006100840400904417 | Valid Time: 0.004\n",
            "Epoch: 908\n",
            "Train Loss: 0.0006168322055600583 | Train Time: 0.045\n",
            "Valid Loss: 0.0006041592569090426 | Valid Time: 0.003\n",
            "Epoch: 909\n",
            "Train Loss: 0.0006347875110805035 | Train Time: 0.045\n",
            "Valid Loss: 0.0006011910154484212 | Valid Time: 0.003\n",
            "Epoch: 910\n",
            "Train Loss: 0.000712411809945479 | Train Time: 0.050\n",
            "Valid Loss: 0.0007080693612806499 | Valid Time: 0.003\n",
            "Epoch: 911\n",
            "Train Loss: 0.0008019583474379033 | Train Time: 0.046\n",
            "Valid Loss: 0.0006725044513586909 | Valid Time: 0.005\n",
            "Epoch: 912\n",
            "Train Loss: 0.000674601792707108 | Train Time: 0.047\n",
            "Valid Loss: 0.0006487660866696388 | Valid Time: 0.004\n",
            "Epoch: 913\n",
            "Train Loss: 0.0006504114950075746 | Train Time: 0.045\n",
            "Valid Loss: 0.0006340351246763021 | Valid Time: 0.003\n",
            "Epoch: 914\n",
            "Train Loss: 0.0006878939893795177 | Train Time: 0.049\n",
            "Valid Loss: 0.0005964674055576324 | Valid Time: 0.003\n",
            "Epoch: 915\n",
            "Train Loss: 0.0006019364984240383 | Train Time: 0.048\n",
            "Valid Loss: 0.0005930264596827328 | Valid Time: 0.008\n",
            "Epoch: 916\n",
            "Train Loss: 0.0006497122696600855 | Train Time: 0.045\n",
            "Valid Loss: 0.0009279500227421522 | Valid Time: 0.003\n",
            "Epoch: 917\n",
            "Train Loss: 0.0007254537486005574 | Train Time: 0.044\n",
            "Valid Loss: 0.0006031488592270762 | Valid Time: 0.003\n",
            "Epoch: 918\n",
            "Train Loss: 0.000731400668155402 | Train Time: 0.048\n",
            "Valid Loss: 0.0009307655855081975 | Valid Time: 0.003\n",
            "Epoch: 919\n",
            "Train Loss: 0.0006964797532418743 | Train Time: 0.060\n",
            "Valid Loss: 0.0005816315242554992 | Valid Time: 0.005\n",
            "Epoch: 920\n",
            "Train Loss: 0.0006392562499968335 | Train Time: 0.046\n",
            "Valid Loss: 0.0007598373922519386 | Valid Time: 0.003\n",
            "Epoch: 921\n",
            "Train Loss: 0.0006270089419558644 | Train Time: 0.047\n",
            "Valid Loss: 0.0006174879672471434 | Valid Time: 0.003\n",
            "Epoch: 922\n",
            "Train Loss: 0.0006441752950195224 | Train Time: 0.050\n",
            "Valid Loss: 0.0007028233085293323 | Valid Time: 0.003\n",
            "Epoch: 923\n",
            "Train Loss: 0.0006475468369899317 | Train Time: 0.046\n",
            "Valid Loss: 0.0007305263716261834 | Valid Time: 0.007\n",
            "Epoch: 924\n",
            "Train Loss: 0.0006510915816761553 | Train Time: 0.047\n",
            "Valid Loss: 0.0006788846221752465 | Valid Time: 0.004\n",
            "Epoch: 925\n",
            "Train Loss: 0.0006576143729034811 | Train Time: 0.052\n",
            "Valid Loss: 0.0005685383657692 | Valid Time: 0.003\n",
            "Epoch: 926\n",
            "Train Loss: 0.0006729723332682625 | Train Time: 0.045\n",
            "Valid Loss: 0.0006689140282105654 | Valid Time: 0.005\n",
            "Epoch: 927\n",
            "Train Loss: 0.0006540774600580334 | Train Time: 0.050\n",
            "Valid Loss: 0.0006004830211168155 | Valid Time: 0.004\n",
            "Epoch: 928\n",
            "Train Loss: 0.0006044370122253895 | Train Time: 0.044\n",
            "Valid Loss: 0.0005992595106363297 | Valid Time: 0.003\n",
            "Epoch: 929\n",
            "Train Loss: 0.0006153414433356375 | Train Time: 0.044\n",
            "Valid Loss: 0.0006246411649044603 | Valid Time: 0.003\n",
            "Epoch: 930\n",
            "Train Loss: 0.0005931794759817422 | Train Time: 0.044\n",
            "Valid Loss: 0.0005818162462674081 | Valid Time: 0.003\n",
            "Epoch: 931\n",
            "Train Loss: 0.0006980257399845869 | Train Time: 0.046\n",
            "Valid Loss: 0.0008417794015258551 | Valid Time: 0.005\n",
            "Epoch: 932\n",
            "Train Loss: 0.0007758983818348497 | Train Time: 0.049\n",
            "Valid Loss: 0.0005474219651659951 | Valid Time: 0.003\n",
            "Epoch: 933\n",
            "Train Loss: 0.0006082248408347368 | Train Time: 0.045\n",
            "Valid Loss: 0.000582551903789863 | Valid Time: 0.003\n",
            "Epoch: 934\n",
            "Train Loss: 0.0007775743579259142 | Train Time: 0.053\n",
            "Valid Loss: 0.0010542659438215196 | Valid Time: 0.003\n",
            "Epoch: 935\n",
            "Train Loss: 0.0007269791152793914 | Train Time: 0.044\n",
            "Valid Loss: 0.0005909556348342448 | Valid Time: 0.003\n",
            "Epoch: 936\n",
            "Train Loss: 0.000681368785444647 | Train Time: 0.046\n",
            "Valid Loss: 0.0007061930082272738 | Valid Time: 0.006\n",
            "Epoch: 937\n",
            "Train Loss: 0.0006493896478787064 | Train Time: 0.050\n",
            "Valid Loss: 0.0005948346515651792 | Valid Time: 0.003\n",
            "Epoch: 938\n",
            "Train Loss: 0.0006302284367848187 | Train Time: 0.055\n",
            "Valid Loss: 0.0006438371492549777 | Valid Time: 0.003\n",
            "Epoch: 939\n",
            "Train Loss: 0.0006734201073413715 | Train Time: 0.046\n",
            "Valid Loss: 0.0007438858156092465 | Valid Time: 0.003\n",
            "Epoch: 940\n",
            "Train Loss: 0.0007797984464559704 | Train Time: 0.053\n",
            "Valid Loss: 0.0007057537441141903 | Valid Time: 0.003\n",
            "Epoch: 941\n",
            "Train Loss: 0.0006598378473427147 | Train Time: 0.046\n",
            "Valid Loss: 0.0006494602130260319 | Valid Time: 0.004\n",
            "Epoch: 942\n",
            "Train Loss: 0.0007810869079548866 | Train Time: 0.047\n",
            "Valid Loss: 0.000782246352173388 | Valid Time: 0.003\n",
            "Epoch: 943\n",
            "Train Loss: 0.000900204514618963 | Train Time: 0.049\n",
            "Valid Loss: 0.0008871746540535241 | Valid Time: 0.003\n",
            "Epoch: 944\n",
            "Train Loss: 0.0007325851533096283 | Train Time: 0.044\n",
            "Valid Loss: 0.0008644756744615734 | Valid Time: 0.007\n",
            "Epoch: 945\n",
            "Train Loss: 0.0009079381823539733 | Train Time: 0.045\n",
            "Valid Loss: 0.0006686999986413866 | Valid Time: 0.004\n",
            "Epoch: 946\n",
            "Train Loss: 0.0007349806517595425 | Train Time: 0.053\n",
            "Valid Loss: 0.0010972869640681893 | Valid Time: 0.004\n",
            "Epoch: 947\n",
            "Train Loss: 0.0009037539013661445 | Train Time: 0.046\n",
            "Valid Loss: 0.0006048396462574601 | Valid Time: 0.003\n",
            "Epoch: 948\n",
            "Train Loss: 0.0006935821962542832 | Train Time: 0.048\n",
            "Valid Loss: 0.0005791049334220588 | Valid Time: 0.008\n",
            "Epoch: 949\n",
            "Train Loss: 0.0007984757656231522 | Train Time: 0.048\n",
            "Valid Loss: 0.0005992140795569867 | Valid Time: 0.003\n",
            "Epoch: 950\n",
            "Train Loss: 0.0006556326727150009 | Train Time: 0.046\n",
            "Valid Loss: 0.0006085640634410083 | Valid Time: 0.003\n",
            "Epoch: 951\n",
            "Train Loss: 0.0007678202237002552 | Train Time: 0.044\n",
            "Valid Loss: 0.0007098799396771938 | Valid Time: 0.005\n",
            "Epoch: 952\n",
            "Train Loss: 0.0007143441005609929 | Train Time: 0.055\n",
            "Valid Loss: 0.0008792485168669373 | Valid Time: 0.003\n",
            "Epoch: 953\n",
            "Train Loss: 0.001335414597997442 | Train Time: 0.048\n",
            "Valid Loss: 0.0008977374818641692 | Valid Time: 0.003\n",
            "Epoch: 954\n",
            "Train Loss: 0.0019420146301854402 | Train Time: 0.045\n",
            "Valid Loss: 0.0013878316967748106 | Valid Time: 0.003\n",
            "Epoch: 955\n",
            "Train Loss: 0.00142166308069136 | Train Time: 0.052\n",
            "Valid Loss: 0.000830053526442498 | Valid Time: 0.003\n",
            "Epoch: 956\n",
            "Train Loss: 0.0009596906835213304 | Train Time: 0.049\n",
            "Valid Loss: 0.0011721051996573806 | Valid Time: 0.004\n",
            "Epoch: 957\n",
            "Train Loss: 0.0008015421510208399 | Train Time: 0.050\n",
            "Valid Loss: 0.0007195073994807899 | Valid Time: 0.006\n",
            "Epoch: 958\n",
            "Train Loss: 0.0008353687764611096 | Train Time: 0.050\n",
            "Valid Loss: 0.0011423444957472384 | Valid Time: 0.003\n",
            "Epoch: 959\n",
            "Train Loss: 0.0008756436523981393 | Train Time: 0.044\n",
            "Valid Loss: 0.0010758559801615775 | Valid Time: 0.003\n",
            "Epoch: 960\n",
            "Train Loss: 0.0009167287265881896 | Train Time: 0.049\n",
            "Valid Loss: 0.0010494377056602389 | Valid Time: 0.004\n",
            "Epoch: 961\n",
            "Train Loss: 0.0009723715891595929 | Train Time: 0.050\n",
            "Valid Loss: 0.001167386886663735 | Valid Time: 0.003\n",
            "Epoch: 962\n",
            "Train Loss: 0.0008919376181438565 | Train Time: 0.044\n",
            "Valid Loss: 0.0006557847082149237 | Valid Time: 0.003\n",
            "Epoch: 963\n",
            "Train Loss: 0.0009781166503671558 | Train Time: 0.044\n",
            "Valid Loss: 0.001303634897340089 | Valid Time: 0.003\n",
            "Epoch: 964\n",
            "Train Loss: 0.0012732701899949462 | Train Time: 0.046\n",
            "Valid Loss: 0.0007534691831097007 | Valid Time: 0.006\n",
            "Epoch: 965\n",
            "Train Loss: 0.0008566892065573484 | Train Time: 0.050\n",
            "Valid Loss: 0.0009648582490626723 | Valid Time: 0.003\n",
            "Epoch: 966\n",
            "Train Loss: 0.0008217273454647512 | Train Time: 0.073\n",
            "Valid Loss: 0.0007455718296114355 | Valid Time: 0.006\n",
            "Epoch: 967\n",
            "Train Loss: 0.0008344446046976373 | Train Time: 0.068\n",
            "Valid Loss: 0.0010902272770181298 | Valid Time: 0.005\n",
            "Epoch: 968\n",
            "Train Loss: 0.001283227140083909 | Train Time: 0.065\n",
            "Valid Loss: 0.0011848980793729424 | Valid Time: 0.005\n",
            "Epoch: 969\n",
            "Train Loss: 0.0011595962452702225 | Train Time: 0.068\n",
            "Valid Loss: 0.0014404628309421241 | Valid Time: 0.005\n",
            "Epoch: 970\n",
            "Train Loss: 0.0009677948546595871 | Train Time: 0.075\n",
            "Valid Loss: 0.0006698523066006601 | Valid Time: 0.005\n",
            "Epoch: 971\n",
            "Train Loss: 0.0006936746096471325 | Train Time: 0.064\n",
            "Valid Loss: 0.0007379151356872171 | Valid Time: 0.005\n",
            "Epoch: 972\n",
            "Train Loss: 0.0007389270642306656 | Train Time: 0.062\n",
            "Valid Loss: 0.0007717531989328563 | Valid Time: 0.005\n",
            "Epoch: 973\n",
            "Train Loss: 0.000802715084864758 | Train Time: 0.071\n",
            "Valid Loss: 0.0009624825324863195 | Valid Time: 0.006\n",
            "Epoch: 974\n",
            "Train Loss: 0.0007563563704025 | Train Time: 0.072\n",
            "Valid Loss: 0.0007242347346618772 | Valid Time: 0.005\n",
            "Epoch: 975\n",
            "Train Loss: 0.0007580208650324494 | Train Time: 0.066\n",
            "Valid Loss: 0.0006502737815026194 | Valid Time: 0.005\n",
            "Epoch: 976\n",
            "Train Loss: 0.0008841208880767226 | Train Time: 0.070\n",
            "Valid Loss: 0.000808699696790427 | Valid Time: 0.005\n",
            "Epoch: 977\n",
            "Train Loss: 0.0008826570061501116 | Train Time: 0.072\n",
            "Valid Loss: 0.0006951887044124305 | Valid Time: 0.005\n",
            "Epoch: 978\n",
            "Train Loss: 0.0007225777313578874 | Train Time: 0.066\n",
            "Valid Loss: 0.0006054889527149498 | Valid Time: 0.005\n",
            "Epoch: 979\n",
            "Train Loss: 0.000647161208325997 | Train Time: 0.073\n",
            "Valid Loss: 0.0007115034968592227 | Valid Time: 0.005\n",
            "Epoch: 980\n",
            "Train Loss: 0.0006789663806557655 | Train Time: 0.067\n",
            "Valid Loss: 0.0007947006088215858 | Valid Time: 0.005\n",
            "Epoch: 981\n",
            "Train Loss: 0.0007874446746427566 | Train Time: 0.069\n",
            "Valid Loss: 0.0006659206701442599 | Valid Time: 0.006\n",
            "Epoch: 982\n",
            "Train Loss: 0.0007442946371156722 | Train Time: 0.067\n",
            "Valid Loss: 0.0009332386835012585 | Valid Time: 0.005\n",
            "Epoch: 983\n",
            "Train Loss: 0.0008096895442577079 | Train Time: 0.067\n",
            "Valid Loss: 0.0009201350912917405 | Valid Time: 0.005\n",
            "Epoch: 984\n",
            "Train Loss: 0.0008078069164184854 | Train Time: 0.063\n",
            "Valid Loss: 0.0008024279668461531 | Valid Time: 0.005\n",
            "Epoch: 985\n",
            "Train Loss: 0.0007133591279853135 | Train Time: 0.064\n",
            "Valid Loss: 0.0007679872796870768 | Valid Time: 0.005\n",
            "Epoch: 986\n",
            "Train Loss: 0.0007493285054806619 | Train Time: 0.062\n",
            "Valid Loss: 0.0006989794201217592 | Valid Time: 0.007\n",
            "Epoch: 987\n",
            "Train Loss: 0.000631384557345882 | Train Time: 0.064\n",
            "Valid Loss: 0.0006339654501061887 | Valid Time: 0.005\n",
            "Epoch: 988\n",
            "Train Loss: 0.000687744707101956 | Train Time: 0.081\n",
            "Valid Loss: 0.0006471380474977195 | Valid Time: 0.005\n",
            "Epoch: 989\n",
            "Train Loss: 0.0006191817112267018 | Train Time: 0.065\n",
            "Valid Loss: 0.0007110863807611167 | Valid Time: 0.005\n",
            "Epoch: 990\n",
            "Train Loss: 0.0006901209068018943 | Train Time: 0.063\n",
            "Valid Loss: 0.0006316942162811756 | Valid Time: 0.005\n",
            "Epoch: 991\n",
            "Train Loss: 0.0006762530945707112 | Train Time: 0.084\n",
            "Valid Loss: 0.0006770217150915414 | Valid Time: 0.005\n",
            "Epoch: 992\n",
            "Train Loss: 0.0007168205338530242 | Train Time: 0.062\n",
            "Valid Loss: 0.0006457261915784329 | Valid Time: 0.005\n",
            "Epoch: 993\n",
            "Train Loss: 0.0006782136333640665 | Train Time: 0.071\n",
            "Valid Loss: 0.0007065254612825811 | Valid Time: 0.005\n",
            "Epoch: 994\n",
            "Train Loss: 0.0006359399121720344 | Train Time: 0.074\n",
            "Valid Loss: 0.0006124532374087721 | Valid Time: 0.005\n",
            "Epoch: 995\n",
            "Train Loss: 0.0006935063167475164 | Train Time: 0.067\n",
            "Valid Loss: 0.0005824741820106283 | Valid Time: 0.012\n",
            "Epoch: 996\n",
            "Train Loss: 0.0006504720891825855 | Train Time: 0.084\n",
            "Valid Loss: 0.0006660074577666819 | Valid Time: 0.006\n",
            "Epoch: 997\n",
            "Train Loss: 0.0006117895711213351 | Train Time: 0.073\n",
            "Valid Loss: 0.0006178310432005674 | Valid Time: 0.005\n",
            "Epoch: 998\n",
            "Train Loss: 0.00062271089409478 | Train Time: 0.066\n",
            "Valid Loss: 0.0006055589765310287 | Valid Time: 0.003\n",
            "Epoch: 999\n",
            "Train Loss: 0.0005985645984765142 | Train Time: 0.046\n",
            "Valid Loss: 0.0006082635081838816 | Valid Time: 0.003\n",
            "== Test Loss: 0.0007932149746920913 | Test Time: 0.004 ==\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Plot the training and validation losses\n",
        "plt.plot(resultsNN[\"train_losses\"])\n",
        "plt.plot(resultsNN[\"valid_losses\"])\n",
        "plt.legend(['Train', 'Val'])\n",
        "plt.xlabel('Epoch')\n",
        "plt.yscale('log')\n",
        "plt.ylabel('MSE')"
      ],
      "metadata": {
        "id": "gwalIcedHbc2",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "outputId": "d989dcc9-6685-4a1d-f7a1-240b8792e3c1"
      },
      "execution_count": 40,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, 'MSE')"
            ]
          },
          "metadata": {},
          "execution_count": 40
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Plot an example solution\n",
        "sol_model_act = solutions_exact[test_data]\n",
        "\n",
        "#Sample our solution to t_k time steps\n",
        "sol_model_act_avg = torch.zeros((t_k, n_x, n_x)).to(device)\n",
        "for i in range (t_k):\n",
        "  sol_model_act_avg[i] = sol_model_act[t_factor*(i+1)]\n",
        "\n",
        "#Our modelled solution is just the output of the netweork to this coarsened input\n",
        "sol_model_pred_NN = modelNN(inputs[test_data].unsqueeze(0)).squeeze().detach().cpu().numpy()"
      ],
      "metadata": {
        "id": "yKTWlXQNHw0I"
      },
      "execution_count": 41,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Interpolate our solution to the fine grid\n",
        "test_time = 0\n",
        "interp2d_solNN = scipy.interpolate.RegularGridInterpolator((x_mesh_avg.cpu(), x_mesh_avg.cpu()),\n",
        "                                                       sol_model_pred_NN[test_time], bounds_error=False, fill_value=None)\n",
        "interpolated_solNN = interp2d_solNN((x2, x1))"
      ],
      "metadata": {
        "id": "JckDw_1UOM_h"
      },
      "execution_count": 42,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare - modelled solution at first predicted time\n",
        "plt.imshow(interpolated_solNN, cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "cRI_1-odODg4",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "77101c10-5d12-476a-e05b-5997da8ce918"
      },
      "execution_count": 43,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgsAAAGyCAYAAABqcofuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABBxklEQVR4nO3dT29jR5rv+Z/KrlS6XKaOWd1zjbpQNeb4YhazmqKoN9BJofdVlGsxa0nAxawKDbFyNrY3V5CmcIELDNAt5XoWThL9Ajr5DlQ6PatZTEOnG607F9W32xQlV5Wd2c7kLLJEi1I8IT7i4R+R3w8g2IoMBQ/PIQ+DEc8TsdTr9XoCAAAwfG/aBwAAAGYbnQUAABBFZwEAAETRWQAAAFF0FgAAQBSdBQAAEEVnAQAARNFZAAAAUXQWAABA1FQ6C1mWaW1t7c56eZ7r4OBArVZLBwcH6na74z84AAAwYGnSyz23Wi2laaq1tTXd9dBra2s6OTmR9Lbj0Gg01Gw2J3GYAADgjybeWeg/8NJStLOQ57k2Nzf7nQVJ+vDDD3V+fj6JwwMAAH80szEL7XZb5XJ5oKxcLivLsikdEQAAi+ndaR+AxYpP6HQ6wfKXL1/q5cuX/d/fvHmjTqejH/3oR1paWhrHIQIAxqjX6+mrr77Sj3/8Y33ve+P7bvvNN9/o1atXI7fz6NEjPX78eKi6eZ73p+XzPNf29raSJAnWbbVaqtVqknSrztUX6EqlojzP1e12ValU7v0cTL0pueuh9/f3e7VabaAsTdNes9kM1v/00097kvjhhx9++Jmzn7Ozs8I+e276+uuvex999FEhx/nRRx/1vv7666Eet1Kp9P//9PS0V6/Xzbqhx9rf3+/1er3e9vZ2v6xWq/XOz89HOh+WmR1ZSJLk1ihCp9Mxe15Pnz7VL3/5y/7vFxcX+slPfqKz/0MqvTfkg76+58Hel/fx3ozlKOImfU5mzTvTPoA/mqUJw2mck3E+5iy9xsf5PIt4DVn3IOsc/pujbu920eU30upn0gcffHDnod3Xq1ev9Nvf/lZnZ/+gUql073YuLy+1uvo/6tWrV3eOLuR5PvB7mqZqt9vBut1uV81mU/V6vV92cHCg3d1dSW8TAa5i+azPxyLMbGehVqvp8PDwVnm1Wg3WX15e1vLy8q3y0nt0FkYySzfSaaCzcBudhfGZt85C6BPGqhu5v01iKrlU+oFKpR+M0MK3Q9eMxeSFphCudxRardbA79J4OwlXptpZ6Ha7A08yyzIlSaI0TZWm6UDdPM9VrVYnclIAALiPy8vLgd9DX2Q9MXnXP/O63a46nc7A52O321Wr1ZIkHR8fa2dn59bnZxEm3llot9t68eKFJGlvb0/r6+v9XtLV71fDK81mU41GQ+vr6zo+PmaNBQDAmHwrz+hA+O+l1dXVgdJPP/1Un3322VAt3LXwYKPR0P7+/kDZ9cDINE21sbGh09PToR7PY+KdhVqtplqtdusJS7rVGUjTtF/v5rDLSKxhsFC5d+jfM8TmOY77HIun7VlSxFCsNeTqbTt0zotqO9SO1YZVbh3LoxGP4z6PGarvbcMyK9NBXtOYaiziPe6JQYiVh66blXQQamOiiWzFdBbOzs4GYh9C0+PemDzpbUei3W7fqpPneX/q4iqzIs/zwkcXZmkmFACAB61UKg38hDoLV2mQN1kxeZL0m9/8Jpg2+eTJk1t1b8ZDFGFmAxwBAJic1xptZGH4IZ27YvKux+9dybLsVifg+ui79Haav16vjyW2j84CAAAFTUMMKxaTdzN+78rNTkaSJKpWqzo4OFCSJDo9PR1bbN/U9oYYt8vLS62srOji/wykThKzMNtmKWYhVJ+YheHrE7PgMyvv8aJiFkLljpiFy6+llcbbdXNGWQMhpv9ZcfH/qlS6/3oOl5dfaWXlfxrrsU4TIwsAAEx4ZOGhmf/Owmvd7iV7vrlbPeYiRgXG2Xas/qh1LUV9+/N8Gy3qm3gRx17Et3/vSMH3Cyi3jtvbdqgdT91Y+TivWxGKGkEIfev2vr+LuE9Y96ZvjHLPdfAc30SvL52FGLIhAABA1PyPLAAAcKfQMLT37+cXnQUAACaYOvkQ0VkAAICYhajF7CxYgT6e7VS9KUShwCVvgKNV3xO4VFQgVhHRLt4gt1CwnDfwzQq486QaWqxjsR4zVN86jtuLwL1l7YTraceqa7XtCXz0nm9vUGXILO1QWcT9Y5xpjJLv3mSdWyvw0XMPsh4TM2ExOwsAAAxgZCGGzgIAAHQWokidBAAAUYwsAABANkQUnQUAAJiGiFrMzoJnmVTvsqeeiOOXjrqxtj1RxOPcpKqozYGKWE7YEz0fE3pO3qwHi+f5WJkJVvn7jvpWpoWnDavc+3yWvKkZoVvYOG9r1geCt9y4gbwKvBG99wPr3uS5Z/3BqOvluad63muYuMXsLAAAMICRhRg6CwAA0FmIYpAHAABEMbIAAAAjC1F0FgAAIHUyav47C6FdRz17KXgzEDyRyN6MCm99z7rs3mwIzwRWEXtAWOXeaHsvT8aCpw1v296shx846nvqxuq/G/qHHxqVveVFZEMUsWmE9QZyZj3od+HiR4HyR1Yb3XBxKKNCkn5vNBNq3nuqrNMSyuTwZDuNc5+PWxhZiCFmAQAARM3/yAIAAHdiZCGGzgIAAHQWopiGAAAAUYwsAADAyEIUnYXrQlkF1rrs3vXXPdkQRaztLoUzHKznM0vZENZeBaFtA8aZ9SCFI7eL2EdDCp9D714X3iyJD4Ysk6T3rIv8J0Z5EiizshtWjHJvloQnG8JbHrr5W2/CgrIhgikLVl3jnDzqhsu/fxku/8poPsS6f1hbeoTKPfeDiWZDkDoZwzQEAACIYmQBAIDgojzev59fdBYAACBmIYppCAAAELWYIwueJY/HudzzHwpoI1Yeep6epa5j9UPdTG8wkhW0Zx1L6Jx7R/6sY/Rc56JGG0PH4gkUk+xgUGtJ5lC5O5DRU25FWibO8iICHK2TZQl9U7QuvvfN2TXKQ8GM1nE7AzaXjOofBAIfradpBdS+NMpD8Zoz+xWVkYWYxewsAAAwgGyIGDoLAAAwshA1swNCAABgNjCyAAAAIwtRdBYAAKCzELWYnQUrDiVUbkXJW8ueerIkrEDpUARxrL4Viex5PkVlFYRYk11WhL83EjvEOj7rWKzMjFAgupUh4skcscqtutZz95YHkxO8WQ//zihPHG2E6kr+ZaBDtzDryXtvd6Gbv3dZZ6vcej7dQJn3+TifZyhL4n1jaWjr6ViZXaH31USXcEZRFrOzAADAAEYWYugsAABA6mQUnQUAACYsz3O1Wi2laao8z7W9va0kSYJ1syyTJFUqFeV5rm63q0ql4m5nFHQWAADQtxotoMI3KrG5uamTkxNJbz/wt7a21Gw2g3UPDw91dHQkSarVagP1PO2Mgs4CAAAT7CzkeT7we5qmarfbZv21tTWdn59L0sCogbedUcx/Z+GNbkepe/ZH8OxTIPmCor0B1N69JDz7Gnj3jAi9p7xLfFkZCNZ2AqFjtI7bes9bjzkre0NYx2eVu7IeJC2VAoWJUbmIvSGsulbWg3UsVvZA6AQ8hGwI6xhD6TcFZT2Yxx4ofxTao0LSY+MNZ70+QxlPM5sNUUxn4fJyMJNkeXlZy8uD17XdbqtcLg+UlctlZVnWn164KTS1cJ927osVHAEAKMjq6qpWVlb6P3t7e7fqdLvd4N92Op1gebfbVavVUqvVUqPR6I8oeNsZxfyPLAAAcKdisiHOzs5UKn03gndzVCHG+vC/HrSYpqk2NjZ0enrqbmcUdBYAANC3Gm2w/W1Ho1QqDXQWQpIkufXtv9PpmFkMeZ73pxWush7yPHe3MwqmIQAAmKBarRYsr1art8qyLNOTJ09ulZfLZVc7o2JkAQCAgkYWhpGm6cDveZ6rWq32RwSyLFOSJErTVGmaan9/v1+33W6rXq8rSZJbIwg32ykSnYXrQoG+nij5WHlo/wbvXg/egGtPJL913JYi9obwZjJ42vYGoVvPP3SM48yGKGpPC6s8mFVgZRp4MxZC5VYb3j0jrGMMzQd7N8ywhF5EjowCSfZGL+NUxI3FON/fN/aMsF5vnv1PPHXHYnKdBUlqNptqNBpaX1/X8fHxwNoIe3t7Wl9f1+7urpIkUbVa1cHBgZIk0enp6UDdWDtFWur1er2xtDxll5eXWllZ0cWvpdJ7N/7xK+OPQuVdR11vuXUfsVIkvRtMzXpnwdpI6gdGeeheb9W1UgcTo/wDR33r8+9HRrmnfjlQFiv/U+exLP04UPiRUfnfG+VW/VAHwDqQRe8s/KujvGvU/dIo/61R/s+Ox/yv4aq/MzoL/2I0HSp31L38Wlr5j9LFxcWdcQD31f+suPhfVSpZN6Vh2nmllZX/a6zHOk2MLAAAoNcabdiQvSEAAJhzbCQVQzYEAACIYmQBAAB9K2lpxL+fX3QWrvOMIll1PeVW3VdGuTcDI9S+tw2L51x5l1u3IqtD7VgB3lacknVuvddz1LoW61x5y5esE+DZS8FbHooq9ezpEKtvRYmGbmFFBTiG6lvRxN4PCk9qkzd40rPvhFXf+Gjwvg4fFDoLMXQWAACgsxBFzAIAAIhiZAEAAEYWougsAACg1xqtszDfqZOL2VkoImjNWqrYEyjnWWI4Vr+IAEfv8/RMYFltWKzYL89ysN4gUc/19D4fi+ccugPLrLd2qNwT+Cb5gha9bVhLb1r1iwhwtM5V6IVotWG9aC2epZetb6y/M8qtc2WVXwTKjOdZVAAuHpypdBbyPFer1epvtXl9r+5Q3Xa7rXK5rDzPVa/Xb23CAQDAaEadRmAaonCbm5s6OTmR9LYzsLW1ZW5+0Wq1tLu72/99Z2dHh4eHEzlOAMCioLMQM/FsiDzPB35P01Ttdtus/8UXX4z7kAAAQMTEOwtXUwrXlctlZVkWrF8ul7W2ttafjtjY2AjWe/nypS4vLwd+AAAYzrcF/MyviXcWut1usLzT6QTLr6YnPv74YzWbTdXr9WC9vb09rays9H9WV1cLOV4AwCK42kjqvj9kQ0yE1Ylot9va399Xnufa2dmRpGDMwtOnT/XLX/6y//vl5aW/w+CJfLdeF56MBavtopYkDj2mMxuiZxzj0jizIawI6tCxe+rGjsU656H647wnWOfVW26+tYtY7tnKnghF2xeV9VBEBsY4l3v2tu1Z7tmq68lukHznxahrLcVuvQ5D708yJB6kiXcWkiS5NYrQ6XSC2RB5nuv4+Fj7+/uSpFqtprW1NTUajVsZEcvLy1petm5iAADEfCupN8Lfz/fIwsSnIWq1WrC8Wq3eKsuyTOvr6/3f0zTV06dPzVEIAADuh5iFmIl3Fm6OCOR5rmq12h9ZyLKsnzFRqVR0fHw8UP/LL79UpVKZyLECABYFnYWYqcQsNJtNNRoNra+v6/j4eGCNhb29Pa2vr2t3d1dpmmpjY0MHBwf9zsRV3AIAAJiMqXQW0jTtxyHczG64uThTrVYzpy4AACgGMQsxM5MNsZDGue9ErDzAynowt4ZwZDiYW7NYk2Ce81LUOZw7nre2Zx8Jb/k42y7qMT28e0N4MzM82R1FnUPSE956rdE6C0VtGjObJh6zAAAAHhZGFgAAYGQhis4CAAD6VqMNts93Z4FpCAAAEMXIAgAAjCxE0VmYRTM03uM5FNd+ERgzzwIxVt0iyotaqMZ7LOMyjYV3xn0OZ0Tos3ain790FmK4vQMAgChGFgAA0GuNNjowSibF7KOzAACAvlVkCbkh0FkAAGDO0VmIIWYBAABEMbIwz0JLvj+EgF2Wqh8jT8aCVV7EBhvjzG7wtm3dBmclo8T7mF6h62m0XcReLDO7PwsjCzF0FgAA6L0Z7fN+vvsKTEMAAIA4RhYAAHij0aZpH8IU7wjoLAAA8FqjxVM4/zbPc7VaLaVpqjzPtb29rSRJgnWzLFO73ZYkHR8f69mzZ/26WZZJkiqVivI8V7fbVaVSue+zMNFZmCZvIJ9V3yqflZ6u97gfqnEGblnX0rzG01ge2RM86T1Z0wiIHNfjjdusLI2NmM3NTZ2cnEh623HY2tpSs9kM1m2329rd3ZUkHRwc6MmTJ/2/PTw81NHRkSSpVquZbYyKmAUAAF4X8DOkPM8Hfk/TtD9ycFOWZdrb2+v/Xq/XlWVZv421tTWdn5/r/PxcL168MEcnRkVnAQCANwX8DKndbqtcLg+Ulcvl/pTCdZVKRc+ePev/3u12+/WvJEkytk7CFaYhAAAoyOXl5cDvy8vLWl5eHii7+sC/qdPpBMvr9Xr//7/44gvVarV+56Db7arVakl6G8+ws7OjNE3vefQ2OgsAABQU4Li6ujpQ/Omnn+qzzz4bqgmrE3H931utVj9eQdJAYGSaptrY2NDp6emwRz00OgsAABSUOnl2dqZSqdQvvjmqIL2dNrg5itDpdO6cSmg0GrfiEvI872c/XGVW5Hle+OjCYnYWPNH5VlSHN8J/0m1L4V6y8ZhL33e0EXvMEOt5FlH+yNnGODMzvG2EbkyeZXNj5frGKA9FxL806v7OWf5+oOyHRl3r+Ky2i+DNBgjV95xXyX8OQ+1bj+ktt47R8Zj/ZjTheX3OSpbWTW802sjCH59XqVQa6CyE1Go1HR4e3iqvVqvm3xwcHKjRaChN0/4IRJ7nevLkic7Pzwfq3oyHKAIBjgAATNDNb/15nqtarQ6snXA9Y6LVaqlSqfQ7Cs+fP1eSJErTVPv7+/167XZb9Xp9LMGOizmyAADAdRNelKnZbKrRaGh9fV3Hx8cD6yPs7e1pfX1du7u7yvNcm5ubA3+bJEk/VqFarerg4EBJkuj09HRs6yzQWQAAYMLLPV8fFbie7SBp4AM/TVP1evYuVZVKZSwrNt7ENAQAAIhiZAEAgAlPQzw0899Z+J6GHz8JRbNbEe5Wm1ZWQajcUzdWbr1IQ8doPR8rytl6zGEfL/aYVrmV4fA4UFbUOfRc53HuaeHNerCu27fGmOi7oSj8rtFIKLshVj90gYq6xXiyJ0LHESu3ePa68GZDfGmUd4csk6QL52Na7YTqO7MhrHLP0HzoNT7JD2A6C1FMQwAAgKj5H1kAAOAuEw5wfGjoLAAAwDREFNMQAAAgipEFAAB6Gm0qwV4KYS4sZmfBM55iRb57o+pD9a2of6vciji2eOp79peI1Q+xzrf1PG/vu/KWJ6PEu2eEN5OjCJ7ob28UulUezIawouetaHsrq2CctxMrG8KTgWG9sCyhi+HNhrCOu+so92ROxMp/b5Q7XhOvjCY8WTyzOlzPNETUYnYWAAC4js5CFDELAAAgipEFAABInYyiswAAANMQUXQWrgtNyngD3zyBj1bbVhxWES9G6zGLWO7ZuzS2d7nnULl3WWer7SKum8X6xhG6nlZdq9wKODPjAf9wu2zJuzyw9QKdRoBj6DG9AZhW+TiXe/YElXYLattRbi0X7g2ofUgBjoiiswAAACMLUXQWAAAgZiGKbAgAABDFyAIAAG802lTCnI8s0FkAAIBpiKjF7CxYUfihcm/Wg1UeCtD29mK9L8bQsRSR9WDxLo3sOVdWfauupw3Jl8kxziWgrevjzXqwykMr/v7wX6OHNLzQC9p7gFb5D43y0MWwbmvWi8JiZTh46r40yrtGuWc5buu6FbA8dCBpRlIxy47P+YfqvFrMzgIAANeRDRFFZwEAADoLUXQWAAAgZiGK1EkAABDFyAIAAExDRNFZuC4UWO3dY8AKuPYMURWVVRB68VpRy0UMoXnHqYrYv8GbDVFE9oQnm0aybyKha+HNerDOlRXNHmRc/Pf/e7h8yYr8Dx2kZw8EyY7Yt7IhitgbwsO7N4R14azzEqofSmGR7HNlZUkY5b8LXH/rIa1y62mGXuPW+2Ha+0jQWYhiGgIAAEQxsgAAQE+jjbD2ijqQ2URnAQAApiGimIYAAABRjCwAAMA6C1GL2Vnw7ANQxB4QFmtcx1tuLT/viS4e5wvdOu4i9t0YZ9aDFM42KGo8LnTOrWwV6xpb0emW0PW3rr11LO93wuWPQhH+XaMRK7shMco9GQ7LjrpeVtaD9cay6nuyIaxUg264uHcZLrdeK18FyqxsGut16MmGmNUPVaYhopiGAAAAUYs5sgAAwHWMLETRWQAAgJiFqKl0FvI8V6vVUpqmyvNc29vbSpLErN9ut5XnudI0lSTVarUJHSkAYCEwshA1lc7C5uamTk5OJL3tOGxtbanZbAbrttttNZtNHR4eKs9zbWxs6PT0dJKHCwDAQpt4ZyHP84Hf0zRVu9026+/s7PQ7Fmma6sWLF74HfEe3o+6tsM5QRLw1tDTOISfv3gPW/gDzlg3hyUwoKhvCszeEl2fvDmvPiCJClK3XhHefiseBP3hsZE5Y5UvWvgaebIhp7A3hre/YM6JnXAjrtWJlPVgZDqH6nrqxYwkd+qx+A3+j0Y6NaYhitdttlcvlgbJyuawsy1SpVAbK8zxXp9NRkiTKskxpmvanIgAAKMyEYxY80/Gxut5p/fuaeGeh2+0Gyzud2980sixTuVxWq9VSrVbT0dGR0jRVvV6/Vffly5d6+fK7JODLSyPXGACAKfNMx8fqetoZxcxkQ4Q6EZ1OR3meq1arKUkSbW9v68MPP1Svd3vHjr29PX3++ecTOFIAwNyZYICjZzo+Vtc7rT+KiS/KlCTJrVGEq6mGm9I0VZIk/X+7+m+WZbfqPn36VBcXF/2fs7Ozog8dADCv3hTwM6TYdLynrqedUU18ZKFWq+nw8PBWebVavVXmiU9YXl7W8rK1zOuQQoFrVuBbEUE6VqCcFVhmHYsVXOQ5RuuFbrVRRJCfJ9DUekxPMKRkrwRs1Q89preLbZ3D0HWzzqsVD+cNwA09phUPaAW5eYJE3QGlxoM+MspD18IbIGxdzyIC1jzX3qpv1bXKrdeKp9wKZPQuOx46Rk+Q9QMMGrw5BR76bPJMx8fqetoZ1cRHFm52API8V7VaHRg1uBpaSdNU1Wq1f0Ku1lq4GQgJAMBIXhfwI2l1dVUrKyv9n729vaEPwfrw99b1tDOsqcQsNJtNNRoNra+v6/j4eCAYY29vT+vr69rd3R2ou7a2ppOTE3/qJAAAdykoZuHs7EylUqlfHBrx9kzHx+p62hnVVDoLaZpqf39fkm5lNtyM4kySJDhtAQDArCmVSgOdhRDPdHysbpqmQ7czqpnJhgAAYGomuM7CMNPxSZIE1xa6XvfmCMLNdopEZwEAgAmv4Hif6fhQ3di/FWmpF1q0YA5cXl5qZWVFF/9ZKr134x89keJWZoKnDasdq42iHjPEejNMYwnWIqLWvUtGe7MnQvW9bXuOsYg2vO14z4kni8VzXiX/8wzxLi8+Tt7l1UP1vZlKVtaDJ6vCasO6NxXRdqDu5dfSyl9KFxcXdw7t31f/s+I/SSUre2eYdr6RVv738R7rNE08GwIAADwsTEMAAMAW1VF0FgAAoLMQxTQEAACIYmQBAIAJb1H90NBZuC40zmJFc1tDTp5IcasNKyK3iEyGh/CC9ox3FbUPgCc6v6io+tB18+7FYUWhT+McevbRGOdjWqaRDWEpYsi6iH0nrPpFZWp5XuPTxjREFNMQAAAgipEFAAAYWYiiswAAQE+jTdPO5fKG32EaAgAARDGyAAAA0xBRi9lZsMZTQuXWsJRnrXppvBkL44ysnnXeCHdv/SLG3orIYvHs/xHjeW2Nc9xxGtdhlrIhxnks3tfbrGRITTtzgtTJqMXsLAAAcB0jC1HELAAAgChGFgAAYGQhis4CAADELETRWbiuiKV9ZymIatLG3bMeZ/tFvNG9AWSegC5PG0U9psV7LA9VEe/lcS5TPY1J5CKW456l54Oh0VkAAIBpiCg6CwAAvNFoH/hzPg3BwA8AAIhiZAEAAAIco+gsAABAzELUYnYWrGjcULk3mtkT6VvUkrfTWDrWo6jlqz3teJe8tZZTDtW3jsMqf+V4TOs4PMfnbcc6Pm/Wg+dcFZWBMSu8702r/qMR68Z4jtH7mI+Ncs+y+EyKz7TF7CwAAHAd0xBRdBYAAGAaIupenYVf/epXWlpa0sbGhv78z/+86GMCAGCy6CxE3WuW6OnTp0rTVH/913+tcrmsv/iLv9Cvf/1r/eM//mPBhwcAAKbtXiMLKysr2tra0tbWliQpyzL96le/0t/+7d/q448/1l/91V8VepAAAIwVMQtR9+osXF5e6je/+U1/CqJSqWhnZ0c///nP9Xd/93f69a9/rb/8y78s9EAnIjTOYkX/WmMyVvRvEVHO08iG8Cgqwt0TnV9ENoBkn8NQ/W+Mut4sDk/bRZUXkYHhye7wZkN4sz5GrRszzv0brPd46P7hzTSwjsWq77nv/cAot8556Ni9985JYQXHqHt1FnZ3d9XpdLSzs6Naraa1tTWdnJzo5z//uX76058qz/OijxMAAEzJvWIW1tbW9Pz5c/393/+9arWazs/Ptbu7q4uLC1WrVS0tLRV9nAAAjM/rAn7m2L1GFra2tvQ3f/M3+tnPfqaf//znA//27Nkz/fSnPy3k4AAAmAhiFqLuvWbWz372s2A5HQUAAOYLizIBAPBaoy05zTTEAxcaWrIifUNRxFaErrc8FBXsyZyI1fdEbRe1/ronM8FSRCaDN2LfkyUghY/Rew6ttkPH8gej7u8dbcTaCdUvIqPCql9Utoon08S7L4gl9L7yZh557gdW+bKzDe/9I1T+vlG3iHM4q8P1TENEsXUHAACImv+RBQAA7sI0RBSdBQAA6CxE0VkAAKCn0eIOekUdyKA8z9VqtZSmqfI81/b2tpIkCdbNskztdluSdHx8rGfPnvXrZlkm6e2Ky3meq9vtqlKpDH0cdBYAAJhRm5ubOjk5kfS247C1taVmsxms2263tbu7K0k6ODjQkydP+n97eHioo6MjSVKtVjPbsMx/Z+F7uj205FmbvIhoZqudItqIlYeMcx8J794Inj0GrHJPZP59WO2HeKPwPXtDeLMkvnLUf2nUtY7Fk5nhvT5G/dfGayh0ar0vQ0voNmG9fcxy615jvcdDey9YmQne+4cnq8Lzupd896ZZHa5/LWmUxYfH8Lxubp2Qpml/5OCmLMu0t7fX7yzU63U1Gg3lea40TbW2tqbz83NJMkcmYua/swAAwF0K6ixcXl4OFC8vL2t52eqpxbXbbZXL5YGycrmsLMtuTSFUKhU9e/as/3u32+3Xv3KfTsIVUicBACjI6uqqVlZW+j97e3v3buvqA/+mTqcTLK/X6/3//+KLL1Sr1fodhG63q1arpVar1R9x8GBkAQCAghZlOjs7U6lU6hffd1QhxupEXP/3VqvVj1eQNBAYmaapNjY2dHp6OvRj0lkAAKCgaYhSqTTQWQg5OjqKflBvbGz0RwVujiJ0Op07pxMajYZevHgxUC/P8/7UxVVmxVU8wzDoLFxXxHLP41zG1Rv46Fmu1jshVcQyu94lfz1LFVvPxxv9FjoWb5Co5/l7l6m2Ah89AY5FtCGpFwiU9K4kbcVaemJhZynA8fvGg35gnPP3A+XvWNcnFAwp2fcJK1DSOukh1r3GupdZjxlSxPLaD8T29vZQ9Wq1mg4PD2+VV6tV828ODg7UaDSUpml/BCLPcz158qQf4HjlZjxEDDELAAC8KeCnYDe/9ed5rmq1OrB2wvXYg1arpUql0u8oPH/+XEmSKE1T7e/v9+u1223V63VXwCMjCwAAzGDqpCQ1m001Gg2tr6/r+Ph4YH2Evb09ra+va3d3V3mea3Nzc+BvkyTpxypUq1UdHBwoSRKdnp6yzgIAAPPi+qjA9WwHSQMf+Gmaqtezl5GsVCquFRtvorMAAMAbjTY6MOdbVNNZAADgjUabhqCzMIfM0OVA2SOjrjdjwbOMqzey2JMNsWTFtHpfCt/eLuo51uSV/EsBe5bjtq6xNwOjiAhtz3LXRS29bJVfBMouA2WSer8Ll3uSJ7yHbbXtyYbwri5u8SRHWS8J63bwgaPcypywypesLAnrYoQe1LtMted9ZV2g0GNOMgR/1JiDWV3GuiBkQwAAgKjFHFkAAOA6Rhai6CwAAEDMQhTTEAAAIIqRBQAAmIaIWszOgmeBd+8eEJ5MBitq2cp6eGSlZvzQKA9dXuuSW0/IEsiGWAqUSdK7Rhi2Vf59I8w7dC2sa2kNCVrn1puZ4eHZrGDce0N0bxe9NtoIVI02HSq3sh6c20649owYZzaEJ5FKst9ViVG+Eijz7q9hZUm8Z73GQyfMeqLW+8c6GM8H6LT3hmAaIoppCAAAELWYIwsAAFw36sgAIwvFy/NcBwcHarVaOjg46G+jeZdGozF0XQAAhva6gJ85NpXOwubmpnZ3d1Wv11Wv17W1tXXn32RZpoODgwkcHQAAuG7i0xDX996W3u6U1W63h/q7m3t7AwBQCKYhoibeWWi32yqXywNl5XJZWZaZ22e2Wi3V63U1Gg3/A76j2xG11nhKqNwKcy4iS8Kd9fAnRvmMZEMEy2LlxuYD73bD5e8bmxiEWEOCnn0npHA0tnc8zjqWUHi+NyvDuclCL1DeNZrwloe2nfBmQ1jl1tMPnS7PPhIxRewNYSU8Wcfiye7wJNnEHvS90Em3bgeeCyE9rGyI15LsHZ7vRmehWFbMQafTMesnSXJnuy9fvtTLl98lWF1eOj5YAACLjc5C1MykTlqdiOfPn6tWq93593t7e1pZWen/rK6uFnyEAAAspol3FpIkuTWK0Ol0gqMH7XZbn3zyyVDtPn36VBcXF/2fs7OzIg4XALAI3hTwM8cmPg1Rq9V0eHh4q7xarQbrP3/+vP//eZ5rb29Pv/jFL27FNywvL2t52Vo+EQCAiDcabRpilL99ACbeWbiZ0ZDnuarVan9kIcsyJUmiNE1vTT/s7OxoZ2dn9KwIz3LPRa3vGip/ZA3sJEa5FcholYce1OpQWS8FqzwU6WRFM1kBjs6XX2gp1sdGbIoVcGVdH08gq+f1ExP6JmIdd0GBj6G4R28QYiiQUQoHPjpWnY7W9yx57D2FFk+8sxWSbAU4eoMWi2Ddbd4JnJhH1ovCG+AYKp/z9Qjm1VRiFprNphqNhlqtlg4PD9VsNvv/tre3p1arNVC/2+3211jY399XlmUTPV4AwJxjGiJqqdfrzeXgyeXlpVZWVnTxX6TSezf+MTH+6INAmVU3tOOLt+0fWn01K0XSavyhjiwYqZOepL1vjZEF6ytqOOlG+tJR/1+Mulb5b43yfx5j20b93wd2ZPI89Vh5N1DGyELYj4zy8pBlsTa8t6ZQ+SOrEStu3Cr/8WhtXH4trfxv0sXFhUqlkvGHo+l/VvxQKo2wkdRlT1r53XiPdZpmJhsCAADMJjaSAgDgtUbbonoux+i/Q2cBAIA3orMQQWfhutCEpHeS0pMN4c5uSIxya93o0IO6DjAiFIdgzSwXlA0Rauddo+3HxnrH3uvpyYbwCoV4eLMejPq9QGyCFI4J8MYVWOWh2IciMiokO2Mj9PS9p9DiufTWyyoUquTlTb4xsx4c5T8y3j5jXe4ZM43OAgAATENE0VkAAIDOQhSdBQAAepr7D/xRkDoJAACiGFkAACy81xotHnPeYzkXs7PgCRf2hj9b5e+Gwu292RBW1kNilE86G8LKerBCqK2Xn9WO4zGtbAjv3hCh6+8dj7OWgQ2VW3ccZ4i/FcweyiqwMha8WRKhDAerrrfcOpbQaSkqYD/0jvW+7b0ZGKGXm9V2EVkPVvuJcbLesZ7QK6Pc8xoPPaEJjn3TWYhjGgIAAEQt5sgCAADXjLoX1JzvI0VnAQAApiHimIYAAABRjCwAABYe0xBxdBbu4g1/tvYYCIbhe7MhvOWzkg3hfZlZIdehcuO4l4wL8X0jbNtznb3h5h7WWKYzS8IKTg+dQetsWxkVVnkR+05Ye0ZY7YSep/V8jO0yTJ6tYqxy67J53oXed6xV/gOj3POaeN9KKZmDvSFmdRoiz3O1Wi2laao8z7W9va0kSYJ1syyTJFUqFeV5rm63q0ql4m4nhM4CAAAzanNzUycnJ5LefuBvbW2p2WwG6x4eHuro6EiSVKvVBup52gmhswAAWHhvNNrowDimIfI8H/g9TVO1222z/trams7PzyVpYNTA204IAY4AgIX3poCforXbbZXL5YGycrncn24ISZLk1vTCfdq5iZEFAMDCKypm4fLycqB8eXlZy8vL92qz2+0Gyzudjlm/1WpJko6Pj7Wzs6M0Td3thNBZAACgIKurqwO/f/rpp/rss88KfQzrw/960GKaptrY2NDp6am7nRA6C9d5JmWsyHezjVCMsnX6rfIi4qLHmQ1hxVBbbVvZE1b90HlxnsN3jDwBTybDOCfvrLFMZzaEFZweat6q68mosMpDe1FIdmaCVd/zmEXtDRHKcLCSnTxbi0h2Ronn+Xifp6e++Q3bm63zgPIJixpZODs7U6lU6peHRhWOjo6iH+IbGxuq1WpKkuTWt/9Op2NmMeR53s9+uMp6yPPc3U4InQUAwMIrap2FUqk00FkI2d7eHqrNWq2mw8PDW+XVavVWWZZlevLkST/A8Uq5XHa1Y6GzAADADErTdOD3PM9VrVb7IwJZlilJEqVpqjRNtb+/36/bbrdVr9eDAY832xkGnQUAwMKb1UWZms2mGo2G1tfXdXx8PLA2wt7entbX17W7u6skSVStVnVwcKAkSXR6ejpQN9bOMJZ6vV6vsGc1Qy4vL7WysqKL/yKV3rvxj+Xgn0h/Gij7kaNurO13/4dA4Z8Yla3yf2eUJ0b5rMQsWLEJvzPK/9Uo/2dH3d+Giy+N2eJ/cTRjNK3/apSfGeX/zVH3//M95n83Jq5DZ9B6OlZ5qA0pfAq/NOpaKzVa9YuY459GzMIHRvlHRnnoHW7VtW5B3ltTqP5qoEySStatKTXKPw6U/Yfh27j8Wlr5j9LFxcWdQ/v3dfVZ8X/Lvl7D+ErS/6LxHus0LebIQhHBbFb5u+Y/BMqsD2grzcYbEFnEY1o8J9HqLFi3dU+ApycYUv7rGXqa7uBWQ+hTyhsoZtS3qnuWRy6ivKi2PYGP3gA/61yFOgBW295loKdxDj0rNVt1zZPlmex/QEGP+M5idhYAALhmFldwnCV0FgAAC29WYxZmBcs9AwCAKEYWAAALr6h1FuYVnQUAwMJjGiKOzsJ1nsh3MxnAE8k/zmWdrXLrwL2ZFlbMtYf3+YSO3bvcs6NpqZiJuiLaMO5EPePrjLVUsyfy3ZtVECr3LutspUha5aHnaT2m9xUbatubOmnV9zx/q66V5jfWbAjrheVdBjok9Fqe4Nd1OgtxxCwAAIAoRhYAAAuPmIU4OgsAgIXHNEQc0xAAACCKkQUAwMLrabSphLncZOkaOgtT5T39RewN4W3DcyzWHhBFvcw87RT0mJ4MmRni2UqioO0oJt62FI7aLyIw32K1YQ3RFvH8izpXUxkm97wopoxpiDimIQAAQBQjCwCAhcfIQhydBQDAwiN1Mo5pCAAAEMXIAgBg4TENEUdnYWJCmQJW9oCnDW+5FcrvzWTwHLv3eRbRTlGP6eDNkhhjpoU1ZOh5SE8b427b2nvBkz1gteGpb7VhlY9zyxEUi85CHJ0FAMDCI2Yhjg4uAACIYmQBALDw3mi0qYR5H1mgswAAWHhMQ8QxDQEAAKIWc2ShiMXtzfGqIqLwpxDJb/Ici3cQz5vdMWrdKSkiw8FoY8no7r9jfM0JNVNE1oO37aKyCkLlnsyJWNuebAhvFof33HpMZeuSIr5WT3kfCbIh4hazswAAwDV0FuKYhgAAAFGMLAAAFh4BjnF0FgAAC49piDg6CxMzK8s9e5dvnsZyz1Z9z9vRaMMbsDrOO0BoEtCaGHRGIVoBjqFmvEsSe8qLCvDzBC1al8xqw+JZvtpqu4hzWNRcsec6j3V+ekY/VeksxBGzAAAAohhZAAAsvJ5GizvoFXUgM4rOAgBg4TENEcc0BAAAiGJkAQCw8EidjJv/zsKoY0vWK8Aq/9b4h3dD0fnfGI1Y5VaWgFW/CNZjvnTULep5ejJKjPJZekd7wu2dYfjf/7dw+aNA2WOjaW/5+4Ey6wpbbfzAKPcs1WydKuOUmELDrqHzJ9nZEKFzItnPP9S+9ZjeY/Ek1JhLRntTZzxY7nmmMQ0BAACipjKykOe5Wq2W0jRVnufa3t5WkiTBulmWqd1uS5KOj4/17Nkzsy4AAPfByELcVDoLm5ubOjk5kfS247C1taVmsxms2263tbu7K0k6ODjQkydP+n8LAEARZjVmwfPlutVqqVarSdKtOlmWSZIqlYryPFe321WlUhn6OCY+DZHn+cDvaZr2Rw5uyrJMe3t7/d/r9bqyLLvVBgAA82hzc1O7u7uq1+uq1+va2tqK1v3www/14YcfamlpSUtLSzo4OJAkHR4eam1tTUtLS9rZ2VGapq7jmHhnod1uq1wuD5SVy+V+r+e6SqWiZ8+e9X/vdrv9+gAAFOV1AT9F83y57na7ajab6vV6/Z/9/f3+yPza2prOz891fn6uFy9euKfzJz4NcfWBf1On0wmW1+v1/v9/8cUXqtVqwSf58uVLvXz5XYT+5eWl/+BC40jWK8AKrbbK3w3FhVux4r83yn9nlFsKyB4opG3reVrPx1Nu1TUe03s9Pa8JiyeC3Apld6YmPP5DuDyUbWBlIFiR/B8Y5aFTaJ0q75CtdVpCOTmvjLrenKFQtoH17crKTLDOrXUOQ+VFZat4ys19NLybfYR4MswmmL30RuNJnBtF7Mt1aArh+udlq9Ua+F26PTXhMTOpk1Yn4vq/t1otM15hb29Pn3/++RiODAAw74qKWbj5RXV5eVnLy8v3atPz5fp6R6Db7arT6QxMNVx9hkpvkwW8UxETn4ZIkuTWE+10Onf2eBqNRnTo5OnTp7q4uOj/nJ2dFXTEAAAMZ3V1VSsrK/2f63F3Rbnry3Wj0dAnn3wyULa9vd2Pe/jFL36hjY0N12NOfGShVqvp8PDwVnm1WjX/5uDgQI1GQ2ma9k/SzU7DKL03AMBiKyp18uzsTKVSqV8e+lw6OjrS6emp2dbGxkZ/yt375brb7ardbt+qk+d5f+riKrMiz/OhRxcm3lm4eWB5nqtarfafWJZlSpKkX6/VaqlSqfQ7Cs+fP9f29vakDxsAMMeKmoYolUoDnYWQYT/D7vPl+je/+U0wbfLJkyc6Pz8fKPckC0wlZqHZbKrRaGh9fV3Hx8cDayzs7e1pfX1du7u7yvNcm5ubA3+bJAmdBQDA3PN+ub4qu9kJSNNU+/v7/d/b7bbq9bor4HEqnYXrB34zWvN6xyFNU/V6Y9gl3Oo+hsagrLpWyLUVVf9eKGrfik/+oVG+KNkQVjaII6PE2qPDuj7W+KNnXNKKAPKE0FvR5s5yT4aDN+vBujqebAjvcK/19EOPab3axrk3hHWJrXNrfe/0ZKtYk65FZENYddkbIv734zDsl+vrbnYykiRRtVrVwcGBkiTR6empuRCiZWayIQAAmJZZ7SwM++X6ys2Ow5VKpeJasfEmNpICAABRjCwAABberO4NMSvoLAAAFt4sruA4S+gsXBe62lYgozfwMRRwF1wCWrID/8ywI+tBhyyLlRfRtndZa895Mc6VdzluT9CrlycozIqgc0atLRnRb8uB9ZGtADrvUsXeAEIPT4Cj9RYMLQ0d41mN27rE3uDRULnVhlU+U8s9j7oM9Bji23E/dBYAAAtvVgMcZwWdBQDAwiNmIY7OAgBg4TGyEEfqJAAAiGJkAQCw8JiGiJv/zsI7uh2R61mDtqjlnkMB/j/0Zj14L1co/tvKNBhnpoV1wq3n3x2+/rfGhbCepve6ha6/d7zREynuXe7Zs66zpFLgJWFlCXgTR0IKWr1afzDKPdkQ3myN0OWxhmK92RCeTBMrcyJxtBErDx3LknWA1m3CmyURwnLPM41pCAAAEDX/IwsAANyBkYU4OgsAgIXX02hxB/O+fhTTEAAAIIqRBQDAwmMaIo7Owl2sV4B374FQdP4jY9DrUTd6SLdZWQih0GXrkk9j3wlnNkTv8naZlfVglVvXxwqh92TIeIUiyK2ocu+C/0Y0+zuB81K2Ug2cQofu3dfAKvdcTm82hPUW9ySrWEH/zsvj2hsiMcrLzvJSaHzZSp3wbkgROmEzOp5NZyFuRi8bAACYFYwsAAAWHosyxdFZAAAsPKYh4ugsAAAWHiMLccQsAACAKEYWrvOsTe7JepDCUcG/tw7EiOc2sySsbIPQ5S1q34kisiGMkxXKepDC58ubDeHNkgiVe8cbPRsKeLMhvOkDga8/j4yqVpaE9XRCh2gdnhVs/5VR7rls3resJxvCynrwnBPJt2eE9xyuGOUfWgeZOBovYs8Iz34RE8Q0RBydBQDAwnuj0T7wmYYAAAALjZEFAMDCI8Axjs4CAGDhvdZoQ+3zHrPANAQAAIia/5GFdzR89G1oHMkbQu3Nkggxj9ebJRG6vNYl95YXkA3RM56PlSUSOofWvgZFZD1Ivq8L3nHIUFfdSk3wbjLgyIawPDK+SvypsaVHKGrfupTWZUuM8nHuDWEJvQ293668W3qEzqF1ic39NayMGitNIpT5kDgfdE6yIRhZsM1/ZwEAgDsQsxDHNAQAAIhiZAEAsPCYhoijswAAWHhMQ8TNf2chtIandVVDXUNvwKIneMc6Dqvcitx6ZPzB9wJ/8I7RiHcd29BDWl3rooJBQ+VW3ZfOtj2Bj967gnVuQ8GMRUTESfYxhq6nFRC3HC5eMh7z/UA04/vGdXhtnG/vKt2et6z1MvScKm9sXhGrd79jNWJFPlpLNXvWjU6cbXuWgZ7RyW9WcIyb0csGAABmxfyPLAAAcIfXkpZG/Pt5RmcBALDwiFmIYxoCAABEMbIAAFh4szwNkWWZtra2dHJyEq2X57larZbSNFWe59re3laSJHf+2zDmv7MQyobwROdb4c9WtH3sOIZ5PCmS9WCUW9HSRaxXaz3/0PPxjsN51+UNhcQXkVERO5bQ87ReP9a5ta5PqNzIQDCj0C2eY7Gi5K0Id0+miZV8Y7TxvlH/fU+KgyfbKVbf816x3ieeay+FsweKSKmQfOtGF5VpETpG6z4WOocTXBp6VjsLVx/wWZbdWXdzc7PfocjzXFtbW2o2m3f+2zDmv7MAAMADVa/Xh6qX5/nA72maqt1u3/lvwyJmAQCw8N4U8DNN7XZb5XJ5oKxcLivLsui/DYuRBQDAwitqGuLy8nKgfHl5WcvL1vxicbrdbrC80+lE/21YjCwAAFCQ1dVVrays9H/29vamejxWR+Guf7uJkQUAwMLrabSphN4f/3t2dqZSqdQvD40qHB0d6fT01GxrY2NDtVrN9fhJktwaKeh0OkqSJPpvw1rMzoIVWe1RxD4IVpRzEVkPUjGL23v2hrB4o9A9WRKePR1ibXv2jPCGPVvnPBQpXlRItSeC3jpXVuS7JwPFuy9IERs7eN+bFs97xbu3iue9X0RGRaw81I4308IaZQ+1bR33lI361rv6+1KpNNBZCNne3h7x0W6r1Wo6PDy8VV6tVpWmqflvw1rMzgIAANcU1VkYp263OzAakGWZkiRRmqZK03Sgbp7nqlar/ZEF69+GRWcBAIAZ1W639eLFC0nS3t6e1tfX++mUV7/v7u5KkprNphqNhtbX13V8fDywjkLs34ax1Ov1endXe3guLy+1srKii/8sld678Y+eYX7P0J23PtMQYbM+DeFd8MmziFFgm+do239w1i9iYSumIYavu+jTEKF2HAs4XX4jrfxKuri4uHNo/76uPiv+Z422BtRrSf+Pxnus08TIAgBg4T2EaYhpInUSAABEzf/IQmhprSK6gN6hztDwotVV864z7xk7m6XuoXcNf09mgnc426pfxLJsRezTYF1ja8rKM4VgTc14p4lC9b3XwfveLGI6zFLEvgTWtbeum2fq0Ds94WmnqClST9uh5z7KKklOjCzEzX9nAQCAO7zRaH2TaS/3PG6z9D0TAADMIEYWAAALb9SRgXkfWaCzAABYeHQW4ua/s/Baw0eeeCJUvIFyoVx7b4BjEZNGRQRtjVsROfUWb1BlqNxqo4hz67321rFYefKh5+NdB6OI94ll1u+43veg9zURqu+9T3iPxfOcvG2E6j+EexBumf/OAgAAd3it7zaDuo9Z7+eOis4CAGDh0VmIo7MAAFh4xCzEkToJAACiGFkAACw8piHi5r+z0NPwV9ET+T7uqOhZadsyjTGpcb4bx7lWq3V9QuXWcVi7+hWRsTBLxrnEchGm8V6zHrOoa1xEO+N6b07wfL/RaJ2Fudy++ZqpdBbyPFer1VKapsrzXNvb20qSZOS6AACgeFPpLGxuburk5ETS287A1taWms3myHUBALiPUfeGYGShYHmeD/yepqna7fbIdQEAuK/XorMQM/GZ53a7rXK5PFBWLpeVZdlIdQEAwHhMfGSh2+0Gyzudzkh1X758qZcvv1tT+eLiQpJ0+U2gAU/3saillwlwHN1DDXD0GPfy1bOOAMfhH3MBAhyv7t+93vi/tzOyEDcz2RBWx2DYunt7e/r8889vla9+dv9jAgBM35dffqmVlZWxtP3o0SN99NFH+u1vfztyWx999JEePXpUwFHNnol3FpIkuTUy0Ol0ghkOnrpPnz7VL3/5y/7v3W5Xf/Znf6Z/+qd/GtuLbB5cXl5qdXVVZ2dnKpVK0z6cmcV5Gg7naTicp+FcXFzoJz/5ya3p6CI9fvxY//AP/6BXr16N3NajR4/0+LG1i9vDNvHOQq1W0+Hh4a3yarU6Ut3l5WUtL99ORl9ZWeHNOIRSqcR5GgLnaTicp+Fwnobzve+Nd97z8ePHc/shX5SJzzynaTrwe57nqlar/dGCLMv6WRB31QUAAOM3lZiFZrOpRqOh9fV1HR8fD6ybsLe3p/X1de3u7t5ZFwAAjN9UOgtpmmp/f1+SVK/XB/7tZmcgVjdmeXlZn376aXBqAt/hPA2H8zQcztNwOE/D4TzNjqXeJHJSAADAg8UW1QAAIIrOAgAAiKKzAAAAomZmBcf7YKvr4Xiee5Zl/c26jo+P9ezZM87THRqNhp4+fcp5MrTbbeV53k+FrtVqEzrS6fLen672wsnzXPV6/Vbq+LzKskxbW1v93YUti3wPnwm9B6xSqfT///T0tFev1wupO288z31/f3/g/6//7by7z2vk5OSkJ6l3fn4+xiObLZ7z9OLFi9729na/bpqmYz++WXHf912v1+ufs3nXbDb776G7LPI9fBY82M7C6enprQ+yJElGrjtvPM/95ORk4N9OT097knqnp6djPcZZcN/XSLPZ7KVpujCdBe95unluFuG11Ov5z9PNuovSWbhyV2dhke/hs+LBxiyw1fVwPM+9Uqno2bNn/d+vNuwa57rss+I+r5FWq+Va+2MeeM5Tnuf9vVyyLFO3212YoXXv66lcLmttba0/HbGxsTGJw3wwFvkePisebGdhXFtdzxvvc7/+4ffFF1+oVqstxLyg9zx1u92FOC83ec5TlmUql8v9eeajoyO1Wq0xH+Fs8L6erhaj+/jjj9VsNheuE3qXRb6Hz4oHHeAYMupW14virufe7XbVarXuDDqad9Z5ev78uba3tyd7MDMsdJ46nY7yPO93OLe3t/Xhhx+qt8DrwFmvp3a7rf39feV5rp2dHUkKbqKHQYt8D5+0BzuyMK6trufNfZ97o9HQixcvFuIcSb7z1G639cknn0zoyGaL5zylaaokSfr/dn2zuHnnOU95nuv4+Fi1Wk3b29s6PT3V8+fP+xvqYbHv4bPiwXYWrPQra6vrYevOm/s894ODAzUaDaVpqm63uxC9d+95ev78uY6OjnR0dKQ8z7W3t7cQH4Ke87Qo8QkhnvOUZZnW19f7v6dpqqdPny7E+25Yi3wPnxUPtrPAVtfD8Zwn6W3QXqVS6XcUnj9/znnS4Hm6+gZ49SNJOzs7qlQqEz3mafC+76rVav9D72qtBc7T4HmqVCo6Pj4eqP/ll18uxHm67mbniHv4bHnQG0nlea7Dw8P+9tXXF8bZ3Nwc2Oo6VnfeDXue8jzXxx9/PPC3SZLo/Px8Ckc9eZ7Xk/T25nZ0dKRGo6Ht7e2F6TB4zlO321Wj0dDa2ppOTk76I1aLwHOe2u22sizr/3utVluI89Rut/XixQsdHBxod3dX6+vr/eBO7uGz5UF3FgAAwPg92GkIAAAwGXQWAABAFJ0FAAAQRWcBAABE0VkAAABRdBYAAEAUnQUAABBFZwEAAETRWQAAAFF0FgAAQBSdBQAAEPXutA8AgE+e52q32zo9PdXOzo6yLGNjHQBjxcgC8MC0221tb29rY2NDm5ubqtfrarVa6nQ60z40AHOKkQXggfnkk08kSVmW6Re/+IUk6fT0dJqHBGDOMbIAPDBXUw1ffPGF6vW6JKnb7U7vgADMPToLwANydHSkRqOhLMuU57nSNJUkPX/+fMpHBmCeLfV6vd60DwLAcNrttvI8V7lcVpIkyvNckrS9vT3lIwMwz+gsAACAKKYhAABAFJ0FAAAQRWcBAABE0VkAAABRdBYAAEAUnQUAABBFZwEAAETRWQAAAFF0FgAAQBSdBQAAEEVnAQAARP3/Ztk3uyJo2roAAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare - exact solution at first predicted time\n",
        "plt.imshow(sol_model_act_avg.cpu()[test_time], cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "W_R2MjRMOD6m",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "b9b6e7e1-9286-4642-bb2a-f607a651a3fb"
      },
      "execution_count": 44,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare - dufference at first predicted time\n",
        "plt.imshow(sol_model_act_avg[test_time].cpu()-interpolated_solNN, cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "TetDbHkyOE9t",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "0f8c7a5a-6aa3-4d92-e117-383dd0807d88"
      },
      "execution_count": 45,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Maximum discrepancy between solutions at first predicted time\n",
        "F.mse_loss(sol_model_act_avg[0], torch.tensor(interpolated_solNN).to(device))"
      ],
      "metadata": {
        "id": "S5aMtGJvn7hK",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "d7c7e2fa-bf94-4d79-d6ae-d49a1f85c980"
      },
      "execution_count": 46,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tensor(0.0003, device='cuda:0', dtype=torch.float64)"
            ]
          },
          "metadata": {},
          "execution_count": 46
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Get OOD losses\n",
        "test_loss_OOD, test_time_OOD = validate(model, Heat_DataLoader_OOD, criterion)\n",
        "test_loss_OOD_NN, test_time_OOD_NN = validate(modelNN, Heat_DataLoader_OOD, criterion)"
      ],
      "metadata": {
        "id": "R9DHyQfpzjyv"
      },
      "execution_count": 47,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Get normalization constants\n",
        "u_avg_OOD = torch.mean(outputs_OOD)\n",
        "u_stdev_OOD = torch.mean((outputs_OOD - u_avg_OOD)**2)\n",
        "\n",
        "u_avg = torch.mean(outputs)\n",
        "u_stdev = torch.mean((outputs - u_avg)**2)"
      ],
      "metadata": {
        "id": "IfeVZwNTGnzk"
      },
      "execution_count": 48,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Graph subgrids - note that this was done accros several runs, and the code needs to be uncommented and commented as needed\n",
        "#to avoid overwriting the arrays and depending on the neural network model being run\n",
        "factors = np.array([4096,1024,216,64])\n",
        "losses_PDE_train = np.ones(4)\n",
        "losses_PDE = np.ones(4)\n",
        "losses_PDE_OOD = np.ones(4)\n",
        "losses_NN_train = np.ones(4)\n",
        "losses_NN = np.ones(4)\n",
        "losses_NN_OOD = np.ones(4)\n",
        "losses_Conv_train = np.ones(4)\n",
        "losses_Conv = np.ones(4)\n",
        "losses_Conv_OOD = np.ones(4)"
      ],
      "metadata": {
        "id": "cK-aEzPZ1WMC"
      },
      "execution_count": 49,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Graph subgrids (adjust run and model as needed)\n",
        "run = 3\n",
        "losses_PDE_train[run-1] = (results[\"train_losses\"][-1]/u_stdev)**0.5\n",
        "losses_PDE[run-1] = (results[\"test_loss\"]/u_stdev)**0.5\n",
        "losses_PDE_OOD[run-1] = (test_loss_OOD/u_stdev_OOD)**0.5\n",
        "# losses_NN_train[run-1] = (resultsNN[\"train_losses\"][-1]/u_stdev)**0.5\n",
        "# losses_NN[run-1] = (resultsNN[\"test_loss\"]/u_stdev)**0.5\n",
        "# losses_NN_OOD[run-1] = (test_loss_OOD_NN/u_stdev_OOD)**0.5\n",
        "losses_Conv_train[run-1] = (resultsNN[\"train_losses\"][-1]/u_stdev)**0.5\n",
        "losses_Conv[run-1] = (resultsNN[\"test_loss\"]/u_stdev)**0.5\n",
        "losses_Conv_OOD[run-1] = (test_loss_OOD_NN/u_stdev_OOD)**0.5"
      ],
      "metadata": {
        "id": "6rDzdoJD1WYd"
      },
      "execution_count": 50,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import matplotlib"
      ],
      "metadata": {
        "id": "VotsNs2xWlKv"
      },
      "execution_count": 51,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "#Graph subgrids\n",
        "import matplotlib.ticker as mticker\n",
        "plt.rc('axes.formatter', useoffset=False)\n",
        "\n",
        "plt.scatter(factors, losses_PDE_train, c = 'green')\n",
        "plt.scatter(factors, losses_PDE, c = 'green', marker = '^')\n",
        "plt.scatter(factors, losses_PDE_OOD, c = 'green', marker = 'x')\n",
        "plt.scatter(factors, losses_NN_train, c = 'red')\n",
        "plt.scatter(factors, losses_NN, c = 'red', marker = '^')\n",
        "plt.scatter(factors, losses_NN_OOD, c = 'red', marker = 'x')\n",
        "plt.scatter(factors, losses_Conv_train, c = 'blue')\n",
        "plt.scatter(factors, losses_Conv, c = 'blue', marker = '^')\n",
        "plt.scatter(factors, losses_Conv_OOD, c = 'blue', marker = 'x')\n",
        "plt.legend(['Ours train', 'Ours test', 'Ours OOD', 'FCN train', 'FCN test', 'FCN OOD', 'ConvN train', 'ConvN test', 'ConvN OOD'], loc = 4)\n",
        "\n",
        "plt.xlabel('Data dimension')\n",
        "plt.ylabel('Relative error (\\%)')\n",
        "plt.yscale('log')\n",
        "plt.xscale('log', base = 2)\n",
        "ax = plt.gca()\n",
        "ax.xaxis.set_major_formatter(mticker.ScalarFormatter())\n",
        "plt.gca().invert_xaxis()\n",
        "\n",
        "plt.axhline(y = 0.1, color = 'black', linestyle = '--')\n",
        "plt.axhline(y = 0.01, color = 'black', linestyle = '--')\n",
        "\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "sdRqByY81W1U",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 446
        },
        "outputId": "9b6bac7b-3248-404a-9ba6-6762b7a0603c"
      },
      "execution_count": 52,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Sample our solution to t_k time steps\n",
        "visual = 27\n",
        "OOD_avg = torch.zeros((t_k, n_x, n_x)).to(device)\n",
        "for i in range (t_k):\n",
        "  OOD_avg[i] = solutions_exact_OOD[visual][t_factor*(i+1)]\n",
        "\n",
        "#Our modelled solution is just the output of the netweork to this coarsened input for both models\n",
        "OOD_pred_RCNN = model(inputs_OOD[visual+1].unsqueeze(0)).squeeze().detach().cpu().numpy()\n",
        "OOD_pred_NN = modelNN(inputs_OOD[visual+1].unsqueeze(0)).squeeze().detach().cpu().numpy()"
      ],
      "metadata": {
        "id": "i29JW3WUzrkR"
      },
      "execution_count": 53,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "test_time = 7\n",
        "#Plot our solutions to compare - actual solution at first predicted time\n",
        "plt.imshow(OOD_avg[test_time].cpu(), cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "u0fo88C_Uoq-",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "085a9404-1bea-4bb5-fb48-e3c38105c298"
      },
      "execution_count": 54,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Plot our solutions to compare\n",
        "interp2d_ood = scipy.interpolate.RegularGridInterpolator((x_mesh_avg.cpu(), x_mesh_avg.cpu()),\n",
        "                                                         OOD_pred_RCNN[test_time], bounds_error=False, fill_value=None)\n",
        "interpolated_ood = interp2d_ood((x2, x1))\n",
        "\n",
        "#Plot our solutions to compare - predicted solution at first predicted time\n",
        "plt.imshow(interpolated_ood, cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "9GHqTk7D0FDZ",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "2a0e5b04-7a42-4829-971d-8e0626058dbf"
      },
      "execution_count": 55,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Interpolate our solution to the fine grid\n",
        "interp2d_oodNN = scipy.interpolate.RegularGridInterpolator((x_mesh_avg.cpu(), x_mesh_avg.cpu()),\n",
        "                                                          OOD_pred_NN[test_time], bounds_error=False, fill_value=None)\n",
        "interpolated_oodNN = interp2d_oodNN((x2, x1))\n",
        "\n",
        "#Plot our solutions to compare - predicted solution at first predicted time\n",
        "plt.imshow(interpolated_oodNN, cmap='hot', origin='lower', extent=[0, 1, 0, 1])\n",
        "plt.colorbar()\n",
        "plt.xlabel(\"$x$\")\n",
        "plt.ylabel(\"$y$\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "1w9Sb828VHPm",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 451
        },
        "outputId": "c8121ddc-28ea-4340-c093-7a298ac4dcfd"
      },
      "execution_count": 56,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgQAAAGyCAYAAACbedxjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABAZUlEQVR4nO3dz3Nj13n/+Q/VclM/SQiKxyon7UyuNrObMZvcziJGTzazGZuU/gKSe1WKcK8cr1hkeZ+w+x8YEajMcqrS2MxsZsEQqdlOvn2dbzpJKV9HEJq2E3Vb3ZxFp2GBfD4kH+ICJIH3q4ol8fThxcH9QR6c8zznzB0fHx8LAADMtDeuugEAAODq0SEAAAB0CAAAAB0CAAAgOgQAAEB0CAAAgOgQAAAA0SEAAACiQwAAAHRFHYJut6u7d++eW68sS+3u7qrdbmt3d1f9fn/8jQMAYAbNTXrp4na7raIodPfuXZ330nfv3tXh4aGkV52DZrOpVqs1iWYCADBTJt4hGLzw3NyZHYKyLLW2tjboEEjSBx98oK+++moSzQMAYKZc2xiCTqejer0+VFav19Xtdq+oRQAATK83r7oBjosX6PV6YfmzZ8/07NmzwfcvX75Ur9fThx9+qLm5uXE0EQAwRsfHx/r1r3+t73//+3rjjfF9fv3666/1/PnzkY9z+/ZtvfXWWxW06Gpc2w6B4zoK29vb+vnPfz7ZxgAAxu7Jkyf6oz/6o7Ec++uvv9af/Mmf6Isvvhj5WB999JF++ctf3thOwbXtENRqtVOjAb1eT7VaLax///59ffbZZ4Pvnz59qh/84Ad68j9LCyffpXvX0TV01zVzDEn6TlDmOrxRXUm6lSx/Ycoz3DGeXbBMkr5OHEOSfpc4zjemruvsu3PlZOtHMh9sXF1X7tqXuYey7zHbxlHrSrk2urrZ13yZrB9xz48rj+5n147s8+3qR8ev6tgXfT1TfvSNdOf/lt5///1kgy7u+fPn+uKLL/TkyS+1sLBw6eMcHR3pzp0/0fPnz+kQVK3RaGhvb+9U+fLyclh/fn5e8/Pzp8oX3gw6BO6XZVSeqStJtxPlN7lDEHExoolfAJW1xR37uncIsn/MrlOHIHMcOgSxaHbTtSP7flz96PhVHfuiryed+XxPYtp3YeEdLSy8M8IR3KeTm+NKgwpPDv93u12VZSlJKopi6N/KstTy8rIdIQAAAJc38RGCTqejR48eSXo177+ysqLV1dWh77e2tiRJrVZLzWZTKysrOjg4YA0CAMCYfKPRPuXf/BGCK1uHYNyOjo60uLiop/+rtHBy+NRNR0WjRa7uu6bc1c/EJ2SnKTKyw3Vu/r8flP3a1H1qyo+S9aPjR+2QfLtdfIKLOahifjXDDXe7e8WVn549eyWausreh5n62XvZHdtNxVXxmlVMCznuXnH3YVTf1XXPcuZedvWzvycy7ydx7KPfSYv/56uYsFHm988y+Fvx9L+OHEOwuPjHY23ruF3bdQgAAMDkXNugQgAAJueFRhv2H+fQ4WTQIQAAgBgCpgwAAAAjBAAAiBGCWegQvKPT0cU1U3cxKPvQ1K2bcnfsKPugqshxJ4rmzUQDSz5zIFrl81fntmiYi4Z2rxllDri6fVP+W1P+73Hx8+AcugSGrOiUu2D6d91YnltHxQU5R/Vdxow7dqZ+djEtdwIybXHPiWt3FQstOdmo/Kg8U1fyz1Um86aq18wc+8rHq+kQXPklAAAAV2/6RwgAADjXC42WKUCWAQAAU4C0QzoEAAAQQzADHYL3dDpQKQoelKSPgrLvmrrfM+Wufi0oywZzvZndiSuIIvrGrBvqAo7cMsJR4KMLwnJBRC4g0IkCl9wxTIDjkXn7fXOY6O27U1XFjrEupq5u2l37Ta78VnQL1cyLuufEvdEoIskFyLp7JRsQGAXruuXDM8uKZ2V2EpRyAX7ZIMHsNuRReWYL8rPKo+Nk6o5/k0N8y/R3CAAAOBcjBHQIAACgQ0DaIQAAYIQAAACRZUCHAAAAMWUwCx2Cd3Q6crlm6kYZAt83de+Yclf/zegfXEP+wJS7dZSdINT8TbN273smLP29/2KOHaz166KHk5kAVhSFfBRX/cpEd7uXdOX/GpS51Y9dQHlm9VqXR+KuvEtqceX14LItZJezdhkCUbR+JiNByi9dHGVC1Exdt9x4NhMiU9e9/yoi/t2N6LIMMst2u/adXAb+NXc9XVsu6njEn0fK9HcIAAA4FyMEdAgAAKBDQJYBAABghAAAADFCQIcAAACRdjgLHYIoy8BFG0eh2S6b4AdutuV/MuUfB2XR5gmSjyl39Z1+UOY2J4jqntGWP/y/Tpe5jQK+NId269O7iO0g8vnYJEe4rIF/SZY/Ccr6pq7LMnBL0Uf1XTC9u/IugcMFlEfB4y9MFPsHfXMQF5UfNd6dFCdzbCnenyDzfEu5+9A99uPMMoiyACS/N4O7Kdw+EdE5d8fITjJnMjWiczXRLANGCIghAAAAdAgAAPj9CMEoXxdXlqV2d3fVbre1u7urfr9/oZ9rNpsXrps1/VMGAACca7JTBmtrazo8PJT0qnOwvr6uVqt15s90u13t7u7q/v37l27lWRghAABggsqyHPq+KAp1Op0L/VxRFONqFh0CAACqmjI4Ojoa+nr27PT6zZ1OR/X6cPRrvV5Xt9u1rWu321pdXR3tLZ5j+qcM5nU6itZFFUdRuzV34P/elEfZBJL0PwRl3zN1XUy5q+8uYxTe/2+mbt+Uu2Gwx6eLav8YV3Xn262L7iKTg4h1F6ztArP7pjyzx0HP1HXZBG4596i+Cxx3wfruVLlTG10K95o10/A5t7Z+JqPA7VngIuHdPbRwwTLJP8vu2NHHpUzUvOSzDDL3vnvNbGZDZlMNl+3hrn2m/Np+DK0m7fDOneHUtJ/97Gf6i7/4i6EyFwPQ68W/Xfr9vmq12ghtu5jp7xAAADAhT5480cLC73ul8/Oul3ua6yjs7+9rY2Nj1Kadiw4BAAB6odEWF3r1swsLC0MdgkitVjs1GtDr9cJRgE6no08++WSEdl0cHQIAACaYZdBoNLS3t3eqfHl5Oay/v78/+P+yLLW9va1PP/1US0tL+WaegQ4BAAATdDJToCxLLS8vD0YIut2uarWaiqJQo9EYqru5uanNzc2xZBvMZofABbVEgT4uuEbvmfKaKY+WAP6DRN2z6rvLGPVYXS/WlbsTELx/FyiVLXfXJxGMlImfOqs8Ck50q7pmVqN1r+na4QYgj0y5W703aks2RvBW5vnJXnt3u7nyaHrWTdlm25INIByXbJCgu3CZ8uzIuTt2dJzsctYTM9l1CFqtlprNplZWVnRwcDC0BsH29rZWVla0tbU1KOv3+3rw4IEkaWdnR5ubm4wQAABQvclublQUhXZ2diTpVDphtEBRrVbT1tbWUCehanQIAABgc6PrmxEKAAAmhxECAAAYIaBDAAAAHYJZ6BDc0ulo4cx6ry4COZ1lEJW7ui6bYJxZBi4W3r3PIOzbLUebjeKuILo7G2jt3v1vL1gm+eWSXf3oNV07aqbcZRO414wyCkZZimVIdN2qyiZ4J1E/e2xXXsWJqezkJo5dRXn2GJgK098hAADgXIwQ0CEAAGDCaYfXEVkGAACAEQIAAF6NDowSwMSUAQAAU4AOwfR3CN7Q6YkRd82jKPk5F978rilfNOW1oCy7Z4ErdzJx7C4u3b3PxF4G2ewDN5FVQfbBc1Oe2YfA7WXgzqCrH2UluH0F+sljPzPl0ftJz3y66xBdt3HvZRCVu/vNlc+Zf3gz8Qv+2OSvVLFufxV7E1T1mpPOYJjotDwdAmIIAADADIwQAABwLrIM6BAAAKBvNNqgOVMGAABgCjBCAAAAIwQz0CF4qdMRs6lIWRd/7i5+Jr47E9t+1ms6Uf3ssbPlk5WNCc5unxCVV/WaVRzD/frKlGePbf8hCtYf434VaXaK19zLUeaAO0Z2kwyXTpL5NeFSZqpIpXHtc+WZ83Jtp9rpEDBlAAAAZmCEAACAc73QaMMX13bo48LoEAAAQNohUwYAAIARAgAA9Gp0YG7En7/Zpr9D8Dudjmh20bbR4vK/MeHD7/2zOcg/mfJoT4BxR/Z/EZR9magrSf9qyv/tdJFbzD8bae0itoPIdBesnl0S//1Eudutoorl+V076qa8Zsoz78e1by67N0VGdk38TFS+uw/n3Wsm9iHIttslHR2Z8uh30Dg3z3Dl2Wc584xn9mCoYl+GC6NDMP0dAgAAzkWHgBgCAADACAEAAIwQ0CEAAECvAkFG6RDc/LTD6e8Q/E6nJ0ZcAEwU6OMCdN5zQXguqPC9oCwbPOhuOBdaFwUEBsGAtu5Z9YNyF7SUXXo14ZaZ9Jo3wUjvmOO48igIz72dbCBjFGbq2lFVUGHmNW0QXna95EgVwYOuPBM0fNZrZoIKs+3OBAS6dlcVVBgdp4rgQSl+xjOBmRMNKsSVdAjKslS73VZRFCrLUhsbG6rVarZup9NRvV5XWZZaXV1VURSTbTAAYMqNOuTPlMGlrK2t6fDwUNKrP/jr6+tqtVph3Xa7ra2trcH3m5ub2tvbm0g7AQCzgg7BxLMMyrIc+r4oCnU6HVv/888/H3eTAACYeRPvELwe/v+2er2ubrcb1q/X67p79+5g6uDevXthvWfPnuno6GjoCwCAi/mmgq+bbeIdgn6/H5b3er2w/PVUwscff6xWq6XV1dWw3vb2thYXFwdfd+7cqaS9AIBZ8Hpzo8t+kWVQGddR6HQ62tnZUVmW2tzclKQwhuD+/fv67LPPBt8fHR296hRksgwyy4Z+aEYgbv9X8wNRrHlVSxe7yxhlCLili7PZB/3TRVUtXeyeq6j7apbXfcssGRtF2Us+Kr8WlGUDyl2WQVQ/047LlGeWLrZLFLtyl+wScdHj7uS68ug6u2j67FLMUYR8tt1XkWVQRf0qsglc/Zv/d3NqTbxDUKvVTo0G9Hq9MMugLEsdHBxoZ2dHktRoNHT37l01m81TmQbz8/Oan3d5UgAAnOUbSccj/PzN7+lMfMqg0WiE5cvLy6fKut2uVlZWBt8XRaH79+/b0QQAAC6HGIKJdwhOfrIvy1LLy8uDEYJutzvIRFhaWtLBwcFQ/S+//FJLS0sTaSsAYFbQIbiSGIJWq6Vms6mVlRUdHBwMrUGwvb2tlZUVbW1tqSgK3bt3T7u7u4MOw+s4AgAAUJ0r6RAURTGICziZNXBygaJGo2GnGQAAqAYxBNcmy2Bsvtbpa+wyB/pB2a9MXRexfOf/i8vf/E1Q6CL4v2fK/9mUu8vYv2CZJD015f8lLv5vQbh1nDnqXzK7tnzEXId3TZaBi+L/0JRHTXSXPhsgHwVmuywIl0T7fVP+kSn/blD2ttvMYNGUu/pRuoLLPHCTle53ajZaP8O1Jbpw2cwY1+7MfgPZbILsuYqeFZc14LIsMvsTZPaOmOheBi80Wofg5m+8MPEYAgAAcP1M/wgBAADnYoSADgEAAPpGow2a3/wOAVMGAACAEQIAABghmIUOwX/odKSri/B1GQURFynrIn/r/3K67P2gTJLeczflH5hydxmjzIaoTNJzczO7c/LkgmVnHcNdB3duo4h1E5ZfM2/TBWA70ZWIIvWlfAB6VO6yIFzWgMsy+ENTfqseFEZlkn+jrn5qowQju1dA9Ly5E+4i553oNbNr/Gf2TZHiTIBsNkG2LZk9G6rIrLu2fzfpEDBlAAAAZmCEAACAc73QaJ/yR8lQuB7oEAAAoG8kzY3w83QIAACYAnQIiCEAAAAzMELwtU5PC7ll+yPZbIIvTflCUObWhH/XzGO989/icrdefBQ9nF1wv2/Ko20YvjB1XZaBO3YmFcBEsd96Ly7/rsk+cPsTRIfPZipkuCwDF/C/4O6hTIZALdmYTP15U9fds9k9AaJ7/Lap67JanOg1zR4Ztn3Z8sxeBtm0lmz9KrjrPGrdsWCEYPo7BAAAnOf45Wh/029+f4ApAwAAwAgBAACvppZHyTq8+esS0SEAAEAvNFo8xThjMSZk+jsE/y4fTHNSFKDkggd7ptwFeUXRaW5Z12y5m/iJeqyZdXSl3Pt3AZXuXPVNuQu4it6nO9/m/dw2gUv/nXmf7wf3jvsg4C6Di5WKym+5IDwXJPhhsn4U+GeDW025uw+j47hozaqCCiPunnUy9/44gwddfRdUOM7lhZ3s9YzamJmonoI/sjfJ9HcIAAA4DyMEdAgAACCGgCwDAAAgRggAAGDKQHQIAABgykCz0CH4Wqd7bu7CRdG8bpljF23rJmGi5VQzdS/zmlXcoC5DIzpXbmlYFyXtloF1Pe0oktlFwrtz6OpHGSaS3nZtjLjrkyl37auZ8kVT7pYdjo6fbbc7t1VEj2czBKL7M5tJk1mO2N3L2SyDzGu6Y2SeEyl3fbK/gzLZB65uZJKful+O+HpT0CEghgAAAMzACAEAAOchhoAOAQAAk44hKMtS7XZbRVGoLEttbGyoVquFdbvdrjqdjiTp4OBADx8+tHVHQYcAAIAJW1tb0+HhoaRXnYP19XW1Wq2wbqfT0dbWliRpd3dXP/rRjwY/WyViCAAAeFHB1wWVZTn0fVEUgxGAk7rdrra3twffr66uqtvtnjpGFaZ/hOCboMxFzmfW/neqmEdyUcJV1M8uuO/eTxX7JGQ3BcjsB1GVqO1VRWBn3k9V+w1kIryzonPlnjUXOe/qZ8rHud+Aq5vNPnD3fpTtctG9WF5zz3ImEyB7/2T3X7loOyYZuT/BGIJOp6N6vT5UVq/X1e12tbS0NFS+tLSkhw8fDr7v9/uD+lWb/g4BAAATcnR0NPT9/Py85ueHdy17/Uf9pF4v3gludXV18P+ff/65Go3GWGIImDIAAOBlBV+S7ty5o8XFxcHXt4f7z+M6Ct/+93a7bWMNRsUIAQAAFU0ZPHnyRAsLC4Pik6MDklSr1U6NBvR6vXM/9TebTT169GgsowMSIwQAAFRmYWFh6CvqEDQajfBnl5eX7XF3d3fVbDZVFIX6/f65owmXQYcAAIBjjTZdcHzxlyqKYuj7siy1vLw8+OR/Moug3W5raWlp0BnY399nHYJL+Z1OX6hMtHE2GjpTPxt9nx3OiiKCs+vQZ9azz+7NcLrj/Eomwjkb3VzFuv1VRVpH5VXsh3BWeXRvuXvZ7O9g61eRZZDd9yKq7/ZDcMfO1Hd1sxkM2Wc/wz1XmeyYbLZLFdlVUTsmufrfhFcqbLVaajabWllZ0cHBwVBcwPb2tlZWVrS1taWyLLW2tjb0s7VaTRsbGyM0Njb9HQIAAM4z4Q5BURTa2dmRNJxFIGmoc1AUhY6PE8MPI2DKAAAAMEIAAMCk9zK4jugQAADAbocz0CGIggpdYNBRUPZrU9eUPzfBT1F8UlWrujqZmDUXQ+RWxr0VBS69byq78gVTngnCqyVfM7sEcFQ/e7IyAVrZZauzopurimA7d2x307pjuOftqSmPnllX1x078f6fm/fjDpF9ZjPss2xe1N2Gc9F9mAkcPUt0P2cCmMd5AnHK9HcIAAA4DyMEdAgAACCGgCwDAAAgRggAAHj1CX+UYf8pGCGgQwAAAFMGM9AheCFp7kSZC+MPopOP4+2pZYr1pSmPApyrCOI+SxT0ng2yd8H69SCb4gP3QLjIeRf27ET1bQNNuatfS5RXkang6rtJvKpSUqKbzr2mu57uNaP6bvljd/O7DIF+otw9nOYYvzXvM5OQkTklZ4kuhXt8MqtTn+XtqPHZpcwzWQlT8IdzWk1/hwAAgPOQZUCHAAAAOgR0CAAAIIZApB0CAAAxQgAAAFMGmtUOgQsJDkKI+6bqr0z5F6Y8CnxObpMQLtsu+SjkKKC+lqgrSd9NvKZbQz2MYj7LbVOeyTKomXKXffBhor57zSqyDJxseLuL4o8unDtGdvww+oWYzY5w77OfKDd1j8yQrnveMlszuLfj/ka4W9wF8Y9atzLj3mvjKtEhYMoAAADM6ggBAADfdqzRAgNP7qp7A9EhAACAKQOmDAAAACMEAACwDoFmoUMQ7WBlQoVfBOvzu6XVXZbBv5jyKPugimXbzxIFyLusARdk70bBoghnF3z/tgvNdty4VZRl4CL1a6bcvdHvmfLohLlju7bcdjHl0YG+iau+bxbodyHy7iWjC+r2lHDHcDJZBi4LIpt6EzxELpvAbXHgEhuipru347ZsqML8GI9tXUU2wVXve8CUAVMGAABgFkYIAAA4DyMEdAgAACCG4Io6BGVZqt1uqygKlWWpjY0N1Wo1W7/T6agsSxVFIUlqNBoTaikAYCYwQnA1HYK1tTUdHh5KetU5WF9fV6vVCut2Oh21Wi3t7e2pLEvdu3dPjx8/nmRzAQCYehPvEJRlOfR9URTqdDq2/ubm5qDzUBSFHj16NHojTEhwFG3cN4fIZhn8c+IYLhra1XcBwVHgvAvWdkHfzkJQ5qK1P3Sh2W6IzS3SntnLwO1Z4NIsXPkfBmW33cFrpvy9RH2TZTBndslY+Ke4/A1zk0fF/bhqOuQ4us5ukX9Xnswy+G3wmn1zCFfuXjIT9O4+HGaD9aP6Yx+JriKjYBr2OIgy0rI/f8NNPMug0+moXh/+hVqv19Xtdk/VLctSvV5PtVpN3W5X/X5/MG0AAEBlXlbwdcNNvEPQ7/fD8l7v9Ofibrerer0+iDd48OCB2u12+PPPnj3T0dHR0BcAALiYa5NlEHUUer2eyrJUo9FQrVbTxsaGPvjgAx0fn95FYnt7Wz//+c8n0FIAwNQhqHDyIwS1Wu3UaMDraYGTiqJQrVYb/Nvr/0bTC/fv39fTp08HX0+ePKm66QCAacWUweRHCBqNhvb29k6VLy8vnyrLxAvMz89rfv6Ci3yaCxfFRLlAOReI1DflUaCgCx404WPpoMKot+dWo3Wr7rr3H8WEZVcott1R18jo8r5j6ro3tGjK3ZLGYQDhR6ZyLfmiUbBhNgqvHxffNndXdLO4G8j9gnMXOrPWb/JtHpuo16i6O3RmiWIn+yEwe4tH8bSZGNvLlIcv4Cq7xrg3Gt1brI97bU380pz8I1+WpZaXl4c+/b/ORCiKQsvLy4PphNdrESwtLU2yyQCAafeigq8b7kpiCFqtlprNplZWVnRwcDC0BsH29rZWVla0tbU1VPfu3bs6PDysJu0QAIBvI4bgajoERVFoZ2dHkrS6ujr0bycXKKrVauEUAwAAqM61yTIAAODKsJcBHQIAAFipcFY7BOaiZ+4FVzdTngnWPqs8EwyebbcTRaPa1UuzYdKZ+i6bwGUfpEOwo0wAtxSxy3Jxj1nm8TNLGrtys3JxKiw/c4zssZPlmWci+3s5E1mdDbJ3t1Xmts3e4m+7xrhlvqMXcLdy9vmJTpj7RXEl6zafeK0ZHyEgAQQAAMzoCAEAAN9GlgEdAgAA6BAwZQAAAMQIAQAABBVqFjoELyXNXbzqRcokPzqUifjPZhO4wGwXtJvJMnAyAcEuAtv+QxWLtFcVDX3bDZZFGQUu7jv7otHjl30kTZZB5uaqKBOgkiwD0273dqL7uaqR2+j2zOxBIOW32ogSAVzdW+7ez6YlRPWzGUCZcpuOdMWYMmDKAAAAzMIIAQAA52GEgA4BAAA61mhxAMdVNeTqMGUAAAAYIQAAgCmDWe0QJC5cNpsgU98tFV/VXgZRW8aZGWODh90/uJDtTLC+q5sN71YtUe72MshkE5xVHknuZZC5iVzdZ6b8CvYyyCQlZO/xzO2Zvd1cfbetQFQ+5263qvbxiI7jsgbcycrUv67j0qQdzmiHAACAb2OE4Nr21QAAwAQxQgAAACMEdAgAACCGYFY7BCYwJpo/qWKlTleeXejWlbs4n0wMXhXlbiXV9DKobiIreqOVLYOaCdpzdV3om3vMouP0Td3fxMXPTWjqb81hovJ/T9SVqgkqNL88j5O/VDPPrLsNnSjWLhur6uq/7RoZRRUuJl+0iofZrkOeNOqkNJPaEzWbHQIAAL6NKQM6BAAA6KVG+6M+BVMGDMgAAABGCAAAIKiQDgEAAMQQaBY6BG/o9MSIiaDNROW7pUdrpvzXQVkVSxFLPiD4uxcsk6R6srwWlNlVgV36QXZ51Ig7Ke7kuqj394/i8rl/SzQmK3r83Ov9U1z8pan+1JT3grK+qRvdtGeVR0sdu+vg1u023NxmJnMgk7wixc+4e+7fdgfPrFEsxQ+Wq+seuGyaRVQ/m73jnsNR10+fS7YDI5n+DgEAAOdhyoAOAQAATBlcskPw05/+VHNzc7p3757+9E//tOo2AQAwWXQILpd2eP/+fRVFob/6q79SvV7Xn/3Zn+kXv/iF/uEf/qHi5gEAgEm41AjB4uKi1tfXtb6+Lknqdrv66U9/qr/5m7/Rxx9/rL/8y7+stJEAAIzVhGMIyrJUu91WURQqy1IbGxuq1Woj1x3FpToER0dH+tu//dvBdMHS0pI2Nzf1k5/8RH/3d3+nX/ziF/rzP//zSht6aW/odMTs7bhqFITrAnmzWQbRcvFVxaC4oOKPgjKXZeDKa6Y8ev+3q4hulnIRzi6KPZtl4Mrf7geFbi+DKpgsg6/M3RJlDUg++6AflGWzCTJ7H2RTaQzzyIYye3tI/jZciI7tNieomXL3i8LtTxC9qDuGa4t7Q+4kZvYtyGaNRPXdtY+OMcml8ya8UuHa2poODw8lvfqDv76+rlarNXLdUVyqQ7C1taVer6fNzU01Gg3dvXtXh4eH+slPfqIf/vCHKsuy6nYCADAVTv6NLIpCnU5n5LqjulT/6+7du9rf39ff//3fq9Fo6KuvvtLW1paePn2q5eVlzc2RPAoAuEFeVPB1QZ1OR/X68Cov9Xpd3W53pLqjutQIwfr6uv76r/9aP/7xj/WTn/xk6N8ePnyoH/7wh5U0DgCAiagohuDoaHiRs/n5ec3PD6/O1u/3w0P0eqfnADN1R3XpGZof//jHYTmdAQDArLpz544WFxcHX9vb2xf+WffHf9S6F8XCRAAAvNBoQYz/OWXw5MkTLSz8Pjr05OiAJNVqtVOf8Hu9Xpg5kKk7qunvENzS6bBjE1V7O7gZ3jFDSNksgygAOxvQml2LPcoccHsTfGjKa6Y8fP8u6tmFd7uo58xDWdVeBtEFkqS3gmG5OXcQl32QyEr4TTKboF9BuavrsgzcuYpOiztVyZu/ir0MHHeMuSgToGYqu3KXTeDqRw+Wq1tV9k7meXPXM9rHwtXP3BOTXA64oimDhYWFoQ5BpNFoaG9v71T58vLySHVHNcmkDgAAZl5RFEPfl2Wp5eXlwaf+brc7yC44r26Vpn+EAACA81Q0ZXBRrVZLzWZTKysrOjg4GFpXYHt7WysrK9ra2jq3bpXoEAAAMOEOQVEU2tnZkSStrq4O/dvJP/hn1a0SHQIAAI41WgzBcVUNuTrEEAAAgBkYIfiOTr9LF50bRMnXfhNXdcu5u2DbiNsnwQXru8wGF1T8/QuWSfG+B2fV/zDqStZMZddwdx1cNHQ0JOeyCVwkfBX7J9w2Vz+b8RDVd5H9X5jyX5nyf03U75u62T0Ooujx5DDqnPmIctt8crsV1c9G07sHMcoQyKbjVJFlUNXzk0lTctct85w4medkklkGLySNssjuFGx/PP0dAgAAzkOHgCkDAADACAEAAJUtTHST0SEAAIApgxnoEGSCCoPVJhdMlOALFyhmRIGCbhnhaMlhycdyuTi5KFDwe4m6kvRhJmLRHbxmyl30pHvNiLsOLuoze5woONG1zx0jU+4usgserKL8S1M3Ezzoyt2nJhecZs6tjWWL6rslsRPBxJLiB7Rm6rpgQxdU6AIFowDHbFBhVjRx7O5Zdz0zgYKZoEcmtSdq+jsEAACchykDOgQAADBlwIAMAAAQIwQAALwa8h/lUz5TBgAATIGXGm3KgA7BDfCmTkciu6jiKCLY9Bg/6Mflt01WQi0oc6vruiBuFzjvgo2jbAWXwXArm/IQ1XfHqJlyt2RsJsvAnSwXIf/clGdPbubYro2ZLIOeKXfZBC5zIDpOdolid66i95P9xJVdWjq6Pu75dteylih397jLMnAZAq6NmSyDzHOS5e5Z90fPZSVEbaxiCeVxGPW1iCEAAADTYPpHCAAAOA8jBHQIAAAghoApAwAAIEYIAABgykCz0CG4pdPRqy66PXNBTcTyuyYy+90opcBE5r4wQ08u8NcFT9+KsiYyWQOSj8COIp9dNHSwR8SZ9d1a9NH1yexBIPmTmBkrc0ODLsvAZJ6EbXGR/ZmsgbPKj4Iy177sOcxkGbjz7a69i6jP3IfuuXf7DUSZA9nnxJXPm/Koje4Bd+ck+4cpup9dVkcmm0CKr6e7xtn9R6rGlAFTBgAAYBZGCAAAOM+on/AZIbicsiy1u7urdrut3d1d9fv9C/1cs9m8cF0AAC7sRQVfN9yVdAjW1ta0tbWl1dVVra6uan19/dyf6Xa72t3dnUDrAACYPROfMijLcuj7oijU6XQu9HNFUYyrWQCAWcaUweQ7BJ1OR/X6cKhuvV5Xt9vV0tJS+DPtdlurq6tqNpv5F/yOTkfAugjfKBreRcS6iOWaKY8is80Q0y1T/q674VyEb9SWbJR0Zl14Fw2djZJ2oghnFwnvZB/aTGaDi77PlLtI636yPLMPgcuOcO8zcw7d85Mdm3T3UCbLoJY4hqtf1bHdvZ95rjJ7Apwlusez2SHZ8ovWneQY9gtJxyP8PB2CPBcD0OvFeVL9fl+1Wu3c4z579kzPnv0+f+roKMqvAgAgQIfg+qQduo7C/v6+Go3GuT+/vb2txcXFwdedO3cqbiEAANNr4h2CWq12ajSg1+uFowCdTkeffPLJhY57//59PX36dPD15MmTKpoLAJgFLyv4uuEmPmXQaDS0t7d3qnx5eTmsv7+/P/j/siy1vb2tTz/99FS8wfz8vObnXXAAAABneKnRpgxG+dlrYuIdgpOZAmVZanl5eTBC0O12VavVVBTFqamCzc1NbW5u5rINoqWLXZBOFADlgupc0E2ml1hV3qoLUIoCH7PLuro+VhS45IKZsuNQLsgt4oLw3Ll1gXKuPGpLZunes+pH5dllhN37zy47nJEJIMssaXtWffccRoHA7h6vojz7nLj348rHGVjnnomo3P0eq6r8onWn4FP3TXIlMQStVkvNZlPtdlt7e3tqtVqDf9ve3la73R6q3+/3B2sQ7OzsqNvtTrS9AIApx5SB5o6Pj6dgoOO0o6MjLS4u6un/Ji2c7I1nPt1netXuGM6sjxC4+pnz4s43IwS5tozLTR4hqCXqug2S3HOVGTlwI5pO9pmIyt192DflLs01Knd1g2MfPZcW/3fp6dOnWlhwu6SNZvC34j1pYYTNjY6OpcXfjLet43ZtsgwAAMDVYXMjAABeaLTtj6dgrJ0OAQAAL0WH4KobMHbR0sVu/i6a087Of1cRaZ9derSKZVCzy6Nm4i3cnGZ2ydyoPDufn51bj+bos6/p3mc0T+vqZl/TlUfXKHsvVzH/nS13MQSZpYvdtG4mtiCzlPdZ5VUtOxypIu7J3YfZY2eWRcaVm/4OAQAA52HKgA4BAAB0COgQAADw6g/6FPxRHwVphwAAgBECAABeaLR4x2mIlZz+DsEbuvheBuOMko6O7cZn3Cpurn4mayKbBZHJEHCrm7kI+WyWQZQh4Fbqc6uhuSyDzEprmZUHpVwmwDhXxpTi6+zut+y9Et2HLirfreCXWZFQymUCZFfpjI6TPUbm2Rw3d69E92EVexPcMHQImDIAAACahRECAADOMer+RNMweEKHAAAw85gyYMoAAACIEQIAAJgy0Cx0CN7Q6XEQF/kbRRBno6FdFHKUfZBZE17KZx9UwUXIR9H32T0LMlHPUpxR0Dd1XfnTZP3ofbpMBfN+js37yWwHkQ34n3P/EN2Hrm42CyZ6Vtzzk9k/4Kzy6PhVPJuuvKrsgMz4cjbzJLu/RWaPkCr2H7mmY+tMGTBlAAAANAsjBAAAnOOlRvuUz5QBAABTgBgCOgQAABBDIGIIAACAZmGE4JYuvpdBVO4ikxdNec2UR9HQLpsgsx+C5COfo4hgN67lurdur4AoejgZfW8jljP7DfRN3V6y3BznP4L37wKwqxgyzAb2ZxNSUpWryBCoVXCMs8qjZ8VlGWT3H8lkFGQzAZxM6omL7K8i+8A9m+73QWYfj0y7JzgOzwjBLHQIAAA4BzEETBkAAAAxQgAAAFMGokMAAABTBpqFDkEUVOgisaJgJBfMVDPldVO+EJTNm7ouyCm7dHEU6JNd1tQFVkXHTkWynfGaLkApCip0SxG74MFfxcVHpi3RYVzznMy8nLv0Lr7P+Y757RQuaZwNbs08E9nnJxtUGLU9G5TryjPcvZytnwkEvoqgwkzwoDuOa1/0Pqfhr+wNMv0dAgAAzsFKhXQIAAAghkBkGQAAADFCAAAAQYWiQwAAAFMGmoUOwRs6PTHiooqjUG4X3eyyCb5rymtBWXYpVVfuREsAuyjhZ6bc3eVRW9wEVDbq2bUxej99U/fLuNhlE5jkA30RlLlTlQ1ijxI4ssHq6QD56EXdQVwWjFsaOLN0cXbp70zmQHaJb1ee+Q1fRWS/VE1mkMsQyCwhns1scK8Z1b+mH6Wva4egLEu1220VRaGyLLWxsaFarRbW7Xa76nQ6kqSDgwM9fPjQ1o1Mf4cAAIAbam1tTYeHh5JedQ7W19fVarXCup1OR1tbW5Kk3d1d/ehHPxr87EUQVAgAmHkvK/iqWlmWQ98XRTEYATip2+1qe3t78P3q6qq63e6pY5yFDgEAYOa9qOCrap1OR/X68Px0vV5Xt9s9VXdpaUkPHz4cfN/v9wf1L4opAwAAKnJ0dDT0/fz8vObnXUDO2V7/UT+p14uXYl1dXR38/+eff65Go5GKIWCEAAAw84412nTB8X8e586dO1pcXBx8fXsYvyquo/Dtf2+32zbWwJnNEQK35n5mXXS3uHy0Z4EUR2C7Y8y5MO73TLmr/m+ny24lZ7rc+890JbMRyy7L4N+Dsmh/A0n/YVIB+ubQbuuDaKsE17xsckj0maGKZfUlaS6zP0H2Xs7c49m9CVy5O4lRhkBVH3OiMeAqouyl+F6W4psru39ANuMhqu+e2Ukfe4K5fFVlGTx58kQLC79/SKLRgQcPHujx48f2WPfu3Rt8uj85GtDr9c791N9sNvXo0aPU6IA0qx0CAADGYGFhYahDENnY2LjQsRqNhvb29k6VLy8v25/Z3d1Vs9lUURSDkYSLdgyYMgAAzLzrGFRYFMXQ92VZanl5efAH/mQWQbvd1tLS0qAzsL+/zzoEAABkXNeli1utlprNplZWVnRwcDAUF7C9va2VlRVtbW2pLEutra0N/WytVrvwaIREhwAAgGurKArt7OxIGs4ikDTUOSiKQsfHxxoFHQIAwMy7rksXTxIdgm/LrPOeXf89ipKec+kOLpvAlX9z8Re9ZcKbs+u5R+Nj2chkF5ntNgtIRGBnEhXOqh9tn+ACql1ATiZA3t1W7k5xCQKp/QayEf+ZfQhc3exrVpF+kc12icrdjZItdzdidMO5utk9CzLPsjMNf/UMOgR0CAAAuLYxBJNElgEAAGCEAACAlxpt2H8aRgjoEAAAZh5TBkwZAAAAzeoIgesGReUu+j4bDv5m9A8uayC7Kn4iy+A7LmS5Atl1zl2X2kVPBxHbx+btVJFN4Oq7t+OujjstmSwDl7xyy/2ASz+IyqvIJnD13bEz+yFIuSwYd4GyMsfOZA2cVf8oKMvezE4myyD7UdFdn8xeE+4YE0KWwax2CAAA+BY6BEwZAAAAMUIAAABBhaJDAAAAUwaiQzCsirVk7RKrUchZdoni7NLFvzldNGdmiW4l+7fR3e+eiGywYWIZ2GyQYCZ4UPLxXJEqYtncbeUCFm20YRVLF7vAv1qiPLtEsQuGdJObmZNexf2ZveF+XUG5q5tdurgK2aXco3J3k0cm+FeWDgExBAAAQIwQAACgY402uDLaxsPXAx0CAMDMY8qAKQMAACBGCAAAIO1QdAgur5LxIZcdUNVxgvJjc9tmI5Yzy7q6cveaieNkV0XONjFzmbMrskaZA9lFq1NLFEtx9kEmI+Gs+tFrZt+QfaNGFb+FM1kG2aWIq8g+6Ju62aWLM7LZBNnrNq5jjIApA6YMAACArmiEoCxLtdttFUWhsiy1sbGhWq0W1u12u+p0OpKkg4MDPXz40NYFAOAyGCG4og7B2tqaDg8PJb3qHKyvr6vVaoV1O52Otra2JEm7u7v60Y9+NPhZAACqQAzBFUwZlGU59H1RFIMRgJO63a62t7cH36+urqrb7Z46BgAAGM3EOwSdTkf1en2orF6vq9vtnqq7tLSkhw8fDr7v9/uD+gAAVOVFBV833cSnDF7/UT+p1+uF5aurq4P///zzz9VoNMIYgmfPnunZs2eD74+Ojl79TzQOlAlBz4alu/K3o5Bgd/qDPQjO5MKNg+O4qOdnpjyxr0Bl5yqR2ZBdnt5F/GeDqjN13XYDUbmrO+ci+7Pl48wEiE6AOynuQriPKJlsF1c3e49Hz8q49zLoX7BMqmbzDGec2QTu2kfXbYLj8C812h91pgwq5DoK3/73drttYw22t7e1uLg4+Lpz584YWgkAmEYvK/i66SbeIajVaqdGA3q93rmZA81mU48ePbL17t+/r6dPnw6+njx5UlGLAQCYfhPvEDQajbB8eXnZ/szu7q6azaaKolC/3w9HE+bn57WwsDD0BQDARRBDcAUdgqIohr4vy1LLy8uDT/4nswja7baWlpYGnYH9/X3WIQAAVIopgytah6DVaqnZbGplZUUHBwdDcQHb29taWVnR1taWyrLU2tra0M/WajVtbGxMuskAAEy1K+kQFEWhnZ0dScNZBJKGOgdFUej4eMRdpqOxHLeGfjTmk11v30UhvxMc6M1sNkFizwJJ+iZYYD0bJZ3JSnDHzp7DbOpAQna/gduJY1cRrO+2ILAHqWIvA1fXpTxkUjLcCaxqbDL6WObuN1eeyT5wexa4cpdNcJSo746R3cvA3eQRd42z6TtRuXvuo9ec4Dg8KxWyuREAAHQIdI3SDgEAwNVhhAAAMPPYy4AOAQAArFSoWegQRBNDVSxdXEWw4VvmIDbY0AUVmuiiTFCUC1DKBFxlAy0rWNK4qocws5JuNgAxEw942wVzuaWI3cGvYuniqDwbxZlZ1lbKLV2cvT+jchdkmwkSPKu8f8EyScfu2TTmMtfCBZS66+POS/SamTW+p2Fi/gaZ/g4BAADnIKiQDgEAAMQQiA4BAACMEIi0QwAAIEYIAABgykCz0CGIrrIb24mikDMRyJKPto0ia90d9B2TfeCyElz0dJRR4NqXzT6Iyl3dTIT4WYLxLDfE5QKZXYC8C9iOgvKziQCZVYRtdHc2m8DVjxrv3lA2E2DUulJ+2eqoPJu94sqjm6KqYycyb1w2gTuEvWzuOQzK7WVz2VXuvo1eM9GOSf6VZcqAKQMAAKBZGCEAAOAcjBDQIQAAQMcabYZixH15rwWmDAAAACMEAAAwZTALHYJox4rM/gQulNdF5bs1yqOwXXdsFyGe3ROgH5Rl11Z3WQlRW7IR4o4btwo2C8jsEyDlApwdF5RfM+Xvm/K3o/fpGu7K3QYKrpFReWYjh6yqfktmoviz+4xk2jjuzTMCbg8CmzUwTlU8QNcUHQKmDAAAgGZhhAAAgHOwMBEdAgAAmDIQHQIAABghEDEEAABAszBCEHX7MmuXZ/cscGvLR1HFLhLcvaar795PlDmQzSbI7HHg2uG6ztm18oP3n13i38nsieCaVzPlLssg/AfXcLdWvCvP7E9Q1ceCcY6ZZrIMsntnVJUdc01kt48Yq+gcZs43exlM1PR3CAAAOEeUoZ79+ZuOKQMAAMAIAQAABBXSIQAAQC802pD5NMQQMGUAAABmYIQg6va5tc6j8ijzQMrvZRCNJ2XWm5f8uvXu/WSyDKrYy6CKteKlVJbBnImyf9dct2xiQ3TKXS/aZRPcdpkA0f4Ebs8Cl07h7glXHjW+qrD0KsZM3TEy+xNk9zLI3Lfj/hiYuD5V7WXAp8JXGCGYhQ4BAADnIIaAziEAABAjBAAAMGUgOgQAADBloFnoEETdPhdEFAXKuaC67JKxmaDCRFCdJP9+ora7YMhM8KB7TdeOLPc+o8A6E4TnYuq+Y4IN3UtGl9kd+113EBdtGC1TnA0edK+Z4T7aZJ4Tx33kygYyZtriAoGzQa9V/IbPrIktxdfZ1B3rEsXZ32+Z32WZyN4J/pVlpUJiCAAAgOgQAAAw2NxolK9xKMtSu7u7arfb2t3dVb/fv9DPNZvNC9d9bfqnDAAAOMd1jSFYW1vT4eGhpFedg/X1dbVarTN/ptvtand3V/fv30+9FiMEAABcQ2VZDn1fFIU6nc6Ffq4oivTr0SEAAMy86zhl0Ol0VK/Xh8rq9bq63a79mXa7rdXV1Uu93vRPGUTjQC7aOIpOdlH52QyB6DWzx3DdNzdWFWUOuAhx9z5deRUZBdmI5SgCP4rUl+y5mjPHftu8n7eCe8Idw2YTZJYjdsfOdt0zmQPunnBtcctcR8fOtjvz/EjxPV5FxoyU+w3v2u2yRjLLKGezQKrg2u2eN3ePZzJpqsiYGcELSXMj/rwkHR0dDZXPz89rft6lbZzNxQD0ej1bv1arXeq1JEYIAACozJ07d7S4uDj42t7ervw1XEdhf39fjUbj0sed/hECAADOUVVQ4ZMnT7SwsDAoj0YHHjx4oMePH9tj3bt3T41GQ7Va7dRoQK/XC0cBOp2OPvnkk0u1/TU6BACAmVfVlMHCwsJQhyCysbFxoWM2Gg3t7e2dKl9eXg7r7+/vD/6/LEttb2/r008/1dLS0oVejw4BAADX0MlMgbIstby8PBgh6Ha7qtVqKori1FTB5uamNjc3U9kGxBAAAGbesX4/bXCZr+MxtavVaqnZbKrdbmtvb29oDYLt7W212+2h+v1+X7u7u5KknZ2dMzMSTpo7Pj4e1/u4UkdHR1pcXNTT/0VaOBm96kZzoihxFzmeWZ9eiqNws+u8u3IXhRxFVbtIa7f+u4vYjrIPXF0XlZ45tjtOVRHlmXJ33TKR1q5+FVHcUi7joarXdPstRLIfRcaZSePqV7EXyDifq6qyDKJr4a5lFdkHLuA+qHv0O2nx/5CePn167jD8Zb3+W/E/arT9IV5I+n813raOG1MGAICZN+o6AtOw/TFTBgAAgBECAABearQsg2nY/pgOAQBg5jFlwJQBAADQLIwQRMtPPTd1o2jjca4hn92zIJtlEEU4Z9675COZo+O4dmSzJtya5i6SOeKipN37d+N9Uf3suvWZyGxXN3sfuusWXedsaLW7zpksA8e9z0wWiLuXs/d4ZgzYvXd3DHedI9lzMkqo/GuZ/UTOKo8yCjLHmOBHVkYIZqFDAADAOYghYMoAAACIEQIAAEb+hD8NIwR0CAAAM48OwSx0CL4JyjIBV1mZZYSzwT/Z+lFAXBVL90rx+8w+ES5wKROd485Jpt1nlWfeUzYQK6rvjpEN2HPtjs6LWxo3EyArxdeiqknJzPtxgaNV3RMR9z7d9XSic1hFkGCWa3cVwYaZY0/lwvrX1/R3CAAAOMcLjdb/YIQAAIApQIeADgEAAMQQiLRDAAAgRggAAGDKQLPQIXih08tPjTObYJwR2Nmli6M7tKoo+yrW6cwuARzVdxHLVbU785RnI80zEeVVLaGdqVvVUtTjFLWxqns5c+2ryhiKrnM2U6EK2SwDlwUT1c9k3UxwDPulRusQTENCxJV0CMqyVLvdVlEUKstSGxsbqtVqI9cFAACXcyUdgrW1NR0eHkp69Qd/fX1drVZr5LoAAFzGqHsZMEJwCWVZDn1fFIU6nc7IdQEAuKxodjljGjoEE88y6HQ6qtfrQ2X1el3dbnekugAA4PImPkLQ7/fD8l6vN1LdZ8+e6dmzZ4Pvnz59Kkk6ipYudt3AKCAwGyzkuljTFlSYCbjKBnNlAjbH2e5s/ez1jI7tXq+KY7tyd2z3kWfaggoz5dmg1Gxbonv8JoSvu9+p0T2UuN+O/nMZ6uPj8X/+ZoTgGmUZuD/+F627vb2tn//856fK7/w/IzQKAHDlvvzySy0uLo7l2Ldv39ZHH32kL774YuRjffTRR7p9O7vxyPUx8Q5BrVY79Qm/1+uFmQOZuvfv39dnn302+L7f7+uP//iP9Y//+I9ju5GmwdHRke7cuaMnT55oYWHhqptzbXGeLobzdDGcp4t5+vSpfvCDH5yaOq7SW2+9pV/+8pd6/tztinVxt2/f1ltvubzK62/iHYJGo6G9vb1T5cvLyyPVnZ+f1/z8/KnyxcVFHrgLWFhY4DxdAOfpYjhPF8N5upg33hhvuNtbb711o/+QV2XiQYVFUQx9X5allpeXB5/6u93uILvgvLoAAKAaVxJD0Gq11Gw2tbKyooODg6F1Bba3t7WysqKtra1z6wIAgGpcSYegKArt7OxIklZXV4f+7eQf/LPqnmV+fl4/+9nPwmkE/B7n6WI4TxfDeboYztPFcJ4ma+54EvkcAADgWmP7YwAAQIcAAADQIQAAALpGKxVeBtsoX0zmvXe73cEGUgcHB3r48CHn6RzNZlP379/nPBmdTkdlWQ7SiBuNxoRaerWyv59e791SlqVWV1dPpV1Pq263q/X19cGuts4s/w6fmOMbbGlpafD/jx8/Pl5dXa2k7rTJvPednZ2h///2z067y9wjh4eHx5KOv/rqqzG27HrJnKdHjx4db2xsDOoWRTH29l0Xl33ujo+PB+ds2rVarcEzdJ5Z/h0+KTe2Q/D48eNTf6xqtdrIdadN5r0fHh4O/dvjx4+PJR0/fvx4rG28Di57j7RareOiKGamQ5A9TyfPzSzcS8fH+fN0su6sdAheO69DMMu/wyfpxsYQsI3yxWTe+9LSkh4+fDj4/vUmUuNcR/y6uMw90m63U2tjTIPMeSrLcrD3SLfbVb/fn5lh8Oz9VK/Xdffu3cHUwb179ybRzBtjln+HT9KN7RCMaxvlaZN979/+A/f555+r0WjMxDxd9jz1+/2ZOC8nZc5Tt9tVvV4fzPs+ePBA7XZ7zC28HrL30+sF2T7++GO1Wq2Z62ieZ5Z/h0/SjQ4qjIy6jfKsOO+99/t9tdvtcwN9pp07T/v7+9rY2JhsY66x6Dz1ej2VZTnoVG5sbOiDDz6YyN7215W7nzqdjnZ2dlSWpTY3NyUp3NgNw2b5d/g43NgRgnFtozxtLvvem82mHj16NBPnSMqdp06no08++WRCLbteMuepKArVarXBv317A7NplzlPZVnq4OBAjUZDGxsbevz4sfb39webvGG2f4dP0o3tELjUJbeN8kXrTpvLvPfd3V01m00VRaF+vz8TvfDsedrf39eDBw/04MEDlWWp7e3tmfhDlzlPsxIvEMmcp263q5WVlcH3RVHo/v37M/HcXdQs/w6fpBvbIWAb5YvJnCfpVaDc0tLSoDOwv7/PedLweXr9Se71lyRtbm5qaWlpom2+Ctnnbnl5efCH7fVaBJyn4fO0tLSkg4ODofpffvnlTJynbzvZAeJ3+OTd6M2NyrLU3t7eYGvkby8Os7a2NrSN8ll1p91Fz1NZlvr444+HfrZWq+mrr766glZPXuZ+kl79Anvw4IGazaY2NjZmplOQOU/9fl/NZlN3797V4eHhYORpFmTOU6fTUbfbHfx7o9GYifPU6XT06NEj7e7uamtrSysrK4OASn6HT96N7hAAAIBq3NgpAwAAUB06BAAAgA4BAACgQwAAAESHAAAAiA4BAAAQHQIAACA6BAAAQHQIAACA6BAAAADRIQAAAJLevOoGAMgpy1KdTkePHz/W5uamut0um70AGBkjBMAN0+l0tLGxoXv37mltbU2rq6tqt9vq9XpX3TQANxgjBMAN88knn0h6tV/8p59+Kkl6/PjxVTYJwBRghAC4YV5PC3z++eeDveP7/f7VNQjAVKBDANwgDx48ULPZVLfbVVmWKopCkrS/v3/FLQNw080dHx8fX3UjAFxMp9NRWZaq1+uq1Woqy1KStLGxccUtA3DT0SEAAABMGQAAADoEAABAdAgAAIDoEAAAANEhAAAAokMAAABEhwAAAIgOAQAAEB0CAAAgOgQAAEB0CAAAgKT/H6VJmByGQ9vTAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Visualize the decay of the coefficients\n",
        "coefficient_mean = torch.mean(coefficients**2,0)\n",
        "plt.imshow(coefficient_mean.cpu(), cmap='hot', origin='lower', extent=[0.5, 4.5, 0.5, 4.5])\n",
        "plt.colorbar()"
      ],
      "metadata": {
        "id": "_cWzAUEBeFYq",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 450
        },
        "outputId": "f0c2030e-2654-42a9-aca6-1003c0f75ecf"
      },
      "execution_count": 57,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.colorbar.Colorbar at 0x7a19e339ee60>"
            ]
          },
          "metadata": {},
          "execution_count": 57
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Visualize the decay of the coefficients\n",
        "coefficient_mean_OOD = torch.mean(coefficients_OOD**2,0)\n",
        "plt.imshow(coefficient_mean_OOD.cpu(), cmap='hot', origin='lower', extent=[0.5, 4.5, 0.5, 4.5])\n",
        "plt.colorbar()"
      ],
      "metadata": {
        "id": "L-zqIRZRB4zV",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 450
        },
        "outputId": "2c56db0c-c4f6-4a88-a186-36769b38f166"
      },
      "execution_count": 58,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.colorbar.Colorbar at 0x7a19e3277190>"
            ]
          },
          "metadata": {},
          "execution_count": 58
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Invariance loss PDE\n",
        "Loss_PDE = 0\n",
        "counter = 0\n",
        "for i in range(40):\n",
        "  u = model(inputs[i].unsqueeze(0))\n",
        "  for j in range(40):\n",
        "    v = model(inputs[j].unsqueeze(0))\n",
        "    sum_model = model(inputs[i].unsqueeze(0)+inputs[j].unsqueeze(0))\n",
        "    sum_orig = u+v\n",
        "\n",
        "    Loss_PDE += F.mse_loss(sum_model, sum_orig)\n",
        "    counter += 1\n",
        "\n",
        "Loss_PDE = Loss_PDE/counter\n",
        "print(Loss_PDE)\n",
        "\n",
        "#Invariance loss NN\n",
        "Loss_NN = 0\n",
        "counter = 0\n",
        "for i in range(40):\n",
        "  u = modelNN(inputs[i].unsqueeze(0))\n",
        "  for j in range(40):\n",
        "    v = modelNN(inputs[j].unsqueeze(0))\n",
        "    sum_model = modelNN(inputs[i].unsqueeze(0)+inputs[j].unsqueeze(0))\n",
        "    sum_orig = u+v\n",
        "\n",
        "    Loss_NN += F.mse_loss(sum_model, sum_orig)\n",
        "    counter += 1\n",
        "\n",
        "Loss_NN = Loss_NN/counter\n",
        "print(Loss_NN)"
      ],
      "metadata": {
        "id": "dIy6AsPauBcW",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "14445e4f-9691-42f5-af77-e3aef1ed78c9"
      },
      "execution_count": 59,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tensor(1.6736e-15, device='cuda:0', grad_fn=<DivBackward0>)\n",
            "tensor(0.0008, device='cuda:0', grad_fn=<DivBackward0>)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#SemiGroup loss PDE\n",
        "Loss_PDE_S = 0\n",
        "counter = 0\n",
        "for i in range(m):\n",
        "  u = model(inputs[i].unsqueeze(0)).squeeze(0)\n",
        "  u_4 = [4]\n",
        "  u_9_new = model(u[4].unsqueeze(0).unsqueeze(0)).squeeze(0)[4]\n",
        "  u_9 = u[9]\n",
        "\n",
        "  Loss_PDE_S += F.mse_loss(u_9_new, u_9)\n",
        "  counter += 1\n",
        "\n",
        "Loss_PDE_S = Loss_PDE_S/counter\n",
        "print(Loss_PDE_S)\n",
        "\n",
        "#SemiGroup loss NN\n",
        "Loss_NN_S = 0\n",
        "counter = 0\n",
        "for i in range(m):\n",
        "  u = modelNN(inputs[i].unsqueeze(0)).squeeze(0)\n",
        "  u_4 = u[4]\n",
        "  u_9_new = modelNN(u[4].unsqueeze(0).unsqueeze(0)).squeeze(0)[4]\n",
        "  u_9 = u[9]\n",
        "\n",
        "  Loss_NN_S += F.mse_loss(u_9_new, u_9)\n",
        "  counter += 1\n",
        "\n",
        "Loss_NN_S = Loss_NN_S/counter\n",
        "print(Loss_NN_S)"
      ],
      "metadata": {
        "id": "yyKv1dioue3p",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "44a6db7f-f6f5-4224-e06c-40e95dffd1d7"
      },
      "execution_count": 60,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tensor(0., device='cuda:0', grad_fn=<DivBackward0>)\n",
            "tensor(0.0002, device='cuda:0', grad_fn=<DivBackward0>)\n"
          ]
        }
      ]
    }
  ]
}