{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "3S2qDT5piMND"
      },
      "source": [
        "# Import modules"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "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",
        "device = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
        "\n",
        "# Fix random seeds\n",
        "random.seed(0)\n",
        "np.random.seed(0)\n",
        "\n",
        "torch.manual_seed(0)\n",
        "torch.cuda.manual_seed_all(0)\n",
        "torch.cuda.manual_seed(0)\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",
      "execution_count": 40,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "8xpINGn6YLuy",
        "outputId": "26a5a4a8-3462-4f42-de1a-f2349550428d"
      },
      "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 26s (7,362 kB/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_2_0.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",
            "/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_5.so.3 is not a symbolic link\n",
            "\n",
            "/sbin/ldconfig.real: /usr/local/lib/libtbbbind.so.3 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"
          ]
        }
      ],
      "source": [
        "#Get latex commands\n",
        "!sudo apt install cm-super dvipng texlive-latex-extra texlive-latex-recommended"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "M5UgfORNH714"
      },
      "source": [
        "# Define initial parameters"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "id": "6Y640YfoH-IC"
      },
      "outputs": [],
      "source": [
        "#Space grid\n",
        "lb = 0\n",
        "rb = 1\n",
        "n_x = 256\n",
        "\n",
        "#Define data points number\n",
        "m = 400\n",
        "\n",
        "#Data oscillations (how many sin/cos waves to superpose)\n",
        "k = 10\n",
        "\n",
        "#Number of output times\n",
        "t_k = 10\n",
        "\n",
        "#Boundary conditions type  - note for now only running Dirichlet boundary conditions\n",
        "Boundary_cond = 'Dirichlet'\n",
        "#Boundary conditions if Dirichlet\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 solution to plot\n",
        "test_data = 20"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "SRFoVNZviWcP"
      },
      "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}$"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "id": "m6Lf-2T3AJNL"
      },
      "outputs": [],
      "source": [
        "#Define space and time mesh - particular to the heat equation since dt ~ dx^2\n",
        "n_t = int(2*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]"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "mqDBkvPaeSW9"
      },
      "source": [
        "# Define random initial conditions\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "ASGZJWrO6b2a"
      },
      "outputs": [],
      "source": [
        "# Random initial conditions made up of a combination of sin(pi*k*x) functions with a given Fourier Spectrum\n",
        "coef_vector = torch.ones(k).to(device)\n",
        "for i in range(3,k):\n",
        "  coef_vector[i] = 1/(i-1)\n",
        "\n",
        "def initial_cond_dirichlet(x_mesh,k,T_0,T_1):\n",
        "  coefs_rand = (torch.rand(k)-0.5).to(device)\n",
        "  coefs_actual = coef_vector*coefs_rand\n",
        "  func=torch.zeros(len(x_mesh)).to(device)\n",
        "  for i in range(1, k+1):\n",
        "    func+=coefs_actual[i-1]*torch.sin(torch.pi*i*x_mesh)\n",
        "  func += (1-xmesh)*T_0+T_1*xmesh\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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 466
        },
        "id": "8d_Df5wNr_Du",
        "outputId": "ce0bf505-082f-460c-aacd-7a81c14634ca"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$u(x,0)$')"
            ]
          },
          "metadata": {},
          "execution_count": 6
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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Eam//PKYoj179pCbm8uePXuoqqoiNzeX3Nxcjh07VrNM27ZtWbx4MQDHjh3joYceIicnh127dpGVlcWQIUO47LLLGDBggF0/hoiIiNQj9WZLkTsmT558xoUYO3e27nT+xRdf0LdvXwDy8/MpLi4GIDg4mI0bNzJv3jyOHj1KYmIi1113HVOmTNExQyIiIgL46RWt7aIrWouIiPif2n5+++XuMxERERFPUykSERERQaVIREREBFApEhEREQFUikREREQAlSIRERERwE+vU2SX01cvKCkpsTmJiIiI1Nbpz+1fugqRSpEbSktLAUhKSrI5iYiIiLirtLSUqKioc35fF290Q3V1NQcOHCAiIgKHw+Gx1y0pKSEpKYm9e/fqopBeprH2DY2zb2icfUPj7BveHGdjDKWlpSQmJhIUdO4jh7SlyA1BQUG0aNHCa68fGRmpPzgf0Vj7hsbZNzTOvqFx9g1vjfP5thCdpgOtRURERFApEhEREQFUiuoFl8tFeno6LpfL7igBT2PtGxpn39A4+4bG2TfqwzjrQGsRERERtKVIREREBFApEhEREQFUikREREQAlSIRERERQKXIZ2bNmkWrVq0ICwujR48erFmz5rzLL1q0iLZt2xIWFkZqaioZGRk+Sur/3Bnr119/nd69e9O0aVOaNm1K//79f/HfRizu/k6ftnDhQhwOB0OHDvVuwADh7jgfPXqUcePGkZCQgMvlonXr1vr/oxbcHefnn3+eNm3aEB4eTlJSEuPHj+fUqVM+Suuf/vnPfzJ48GASExNxOBx8+OGHv7hOdnY2Xbp0weVycdlllzF37lzvhjTidQsXLjROp9O8+eabZvPmzebee+810dHRpqio6KzLr1y50gQHB5sZM2aYLVu2mMcff9yEhoaaTZs2+Ti5/3F3rO+44w4za9Yss379epOXl2dGjRploqKizL59+3yc3L+4O86n7dy50zRv3tz07t3bDBkyxDdh/Zi741xWVma6detmBg0aZFasWGF27txpsrOzTW5uro+T+xd3x3n+/PnG5XKZ+fPnm507d5pPPvnEJCQkmPHjx/s4uX/JyMgwkyZNMh988IEBzOLFi8+7fEFBgWnUqJGZMGGC2bJli5k5c6YJDg42mZmZXsuoUuQD3bt3N+PGjav5uqqqyiQmJppnn332rMsPHz7c3HDDDWc816NHD/P7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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#Visualize some data point\n",
        "function_1, coefficients_1 = initial_cond_dirichlet(xmesh,k,T_0,T_1)\n",
        "function_2, coefficients_2 = initial_cond_dirichlet(xmesh,k,T_0,T_1)\n",
        "function_3, coefficients_3 = initial_cond_dirichlet(xmesh,k,T_0,T_1)\n",
        "\n",
        "plt.plot(xmesh.cpu(), function_1.cpu())\n",
        "plt.plot(xmesh.cpu(), function_2.cpu())\n",
        "plt.plot(xmesh.cpu(), function_3.cpu())\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel('$u(x,0)$')"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "lbDqB1__enf9"
      },
      "source": [
        "## Define the coeficients for the equatiion to model: $u_t = a(x)u_{xx}$\n",
        "\n",
        "Capped between max_a and epsilon 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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "id": "ELCMUhUrG_LQ"
      },
      "outputs": [],
      "source": [
        "#Define the coefficients of the equation in the same way we defined our initial data (with a random function)\n",
        "#and bound them under the stability region of the PDE\n",
        "a_x, _= initial_cond_dirichlet(xmesh,k,T_0,T_1)\n",
        "\n",
        "a_x = torch.maximum(torch.minimum(a_x+1, torch.tensor(max_a - epsilon)), torch.tensor(epsilon))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "cDZVC4F_AS-A"
      },
      "outputs": [],
      "source": [
        "#Construct the data\n",
        "initial_conditions = torch.zeros(m,len(xmesh)).to(device)\n",
        "coefficients = np.zeros((m,k))\n",
        "\n",
        "if Boundary_cond == 'Dirichlet':\n",
        "  for j in range(m):\n",
        "    function, coefs = initial_cond_dirichlet(xmesh, k, T_0, T_1)\n",
        "    initial_conditions[j] = function\n",
        "    coefficients[j] = coefs.cpu()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "NzXV4kPpk9XB",
        "outputId": "3d74aa82-fada-41a2-9616-2e174cdadce1"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tensor(0.1984)\n"
          ]
        }
      ],
      "source": [
        "# Check lam<1/2 for stability\n",
        "print(dt/(dx**2))"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "4Re-OB_Ae6kh"
      },
      "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 point.\n",
        "- sample in time, (the t-factor time step)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "id": "nsLp5Sf9AdB9"
      },
      "outputs": [],
      "source": [
        "#Define inputs and outputs of the model which are PDE intitial condition and averaged solution at t=1,..,t_k respectively\n",
        "\n",
        "#Maximum t value to generate data\n",
        "t_max = coars_max**2*t_k+1\n",
        "solutions_exact = torch.zeros((1,t_max, n_x)).to(device)\n",
        "\n",
        "filter = torch.tensor([1,-2,1]).float().to(device)\n",
        "one_filter = torch.tensor([1]).float().to(device)\n",
        "\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)).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.conv1d(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.conv1d(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_x\n",
        "  #Add to solutions tensor\n",
        "  solutions_exact = torch.cat((solutions_exact, sol.view(1,t_max,n_x)), 0)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "metadata": {
        "id": "zv79-Qq9g82g"
      },
      "outputs": [],
      "source": [
        "#Construct the data OOD from a different spectrum\n",
        "OOD_spec = torch.ones(k).to(device)\n",
        "for i in range(k-3):\n",
        "  OOD_spec[i] = 1/(8-i)\n",
        "\n",
        "def initial_cond_OOD(x_mesh,k,T_0,T_1):\n",
        "  coefs_rand = (torch.rand(k)-0.5).to(device)\n",
        "  coefs_actual = OOD_spec*coefs_rand\n",
        "  func=torch.zeros(len(x_mesh)).to(device)\n",
        "  for i in range(1, k+1):\n",
        "    func+=coefs_actual[i-1]*torch.sin(torch.pi*i*x_mesh)\n",
        "  func += (1-xmesh)*T_0+T_1*xmesh\n",
        "\n",
        "  max = torch.max(func)\n",
        "  min = torch.min(func)\n",
        "  func = 3*func/(max-min)\n",
        "  coefs_actual = 3*coefs_actual/(max-min)\n",
        "  return func, coefs_actual\n",
        "\n",
        "\n",
        "initial_conditions_OOD = torch.zeros(50,len(xmesh)).to(device)\n",
        "coefficients_OOD = torch.zeros((50,k)).to(device)\n",
        "\n",
        "if Boundary_cond == 'Dirichlet':\n",
        "  for j in range(50):\n",
        "    function, coefs = initial_cond_OOD(xmesh, k, T_0, T_1)\n",
        "    initial_conditions_OOD[j] = function\n",
        "    coefficients_OOD[j] = coefs"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 12,
      "metadata": {
        "id": "rXUhPXdcXRkI"
      },
      "outputs": [],
      "source": [
        "solutions_exact_OOD = torch.zeros((1,t_max,n_x)).to(device)\n",
        "\n",
        "for j in range(50):\n",
        "  #Create FD solution with initial condition\n",
        "  sol = torch.zeros((t_max,n_x)).to(device)\n",
        "  sol[0]=initial_conditions_OOD[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.conv1d(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.conv1d(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_x\n",
        "  #Add to solutions tensor\n",
        "  solutions_exact_OOD = torch.cat((solutions_exact_OOD, sol.view(1,t_max,n_x)), 0)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "rirnTDFfvsEG"
      },
      "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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 13,
      "metadata": {
        "id": "H6rTNem66ZYL"
      },
      "outputs": [],
      "source": [
        "#Define coarsening function\n",
        "def coarsen(sol, n_x, x_factor, Boundary_cond, T_0, T_1):\n",
        "  sol_avg = torch.zeros((10, int(n_x/x_factor))).to(device)\n",
        "  inp_avg = torch.zeros((1,int(n_x/x_factor))).to(device)\n",
        "\n",
        "  t_factor = x_factor**2\n",
        "\n",
        "  #Done as a loop, fine for 1D but for higher dimensions using pooling layers\n",
        "  for k in range(1,int(n_x/x_factor-1)):\n",
        "    for i in range(t_k):\n",
        "      sol_avg[i][k] = torch.mean(sol[t_factor*(i+1)][x_factor*k:x_factor*(k+1)])\n",
        "    inp_avg[0][k]= torch.mean(sol[0][x_factor*k:x_factor*(k+1)])\n",
        "\n",
        "  if Boundary_cond == 'Dirichlet':\n",
        "    inp_avg[0][0]=T_0\n",
        "    inp_avg[0][-1]=T_1\n",
        "    for i in range(t_k):\n",
        "      sol_avg[i][0] = T_0\n",
        "      sol_avg[i][-1] = T_1\n",
        "\n",
        "  return inp_avg, sol_avg"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 14,
      "metadata": {
        "id": "7Jhilvg5vvHW"
      },
      "outputs": [],
      "source": [
        "#Factor by which to coarsen x-grid (for easier to read code later)\n",
        "x_factor = 8\n",
        "n_x_new = int(n_x/x_factor)\n",
        "#Corresponding t_factor\n",
        "t_factor = x_factor**2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 15,
      "metadata": {
        "id": "XOA6A4minBhY"
      },
      "outputs": [],
      "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)).to(device)\n",
        "outputs = torch.zeros((1,t_k,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, Boundary_cond, T_0, T_1)\n",
        "\n",
        "  #Conactenate our input-output pair to the respective tensors\n",
        "  inputs = torch.cat((inputs, inp_avg.view(1,n_x_new)), 0)\n",
        "  outputs = torch.cat((outputs, sol_avg.view(1,t_k,n_x_new)),0)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 16,
      "metadata": {
        "id": "EXpB9-QmAvmc"
      },
      "outputs": [],
      "source": [
        "inputs_OOD = torch.zeros((1,n_x_new)).to(device)\n",
        "outputs_OOD = torch.zeros((1,t_k,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, Boundary_cond, T_0, T_1)\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)), 0)\n",
        "  outputs_OOD = torch.cat((outputs_OOD, sol_avg.view(1,t_k,n_x_new)),0)\n",
        "\n",
        "inputs_OOD = torch.unsqueeze(inputs_OOD,1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 17,
      "metadata": {
        "id": "gTB78lVYBJkC"
      },
      "outputs": [],
      "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)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "B0kFuOuesviB"
      },
      "source": [
        "# Format data into pytorch data_loaders"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 18,
      "metadata": {
        "id": "J0l3pGHzmBmM"
      },
      "outputs": [],
      "source": [
        "# Add an extra dimension to inputs for mathematical stability of matrices\n",
        "inputs = torch.unsqueeze(inputs,1)\n",
        "\n",
        "# Strip the first (zero) solution from input and output arrays (and exact solution arrays)\n",
        "if (T_0 != 0 or T_1 != 0):\n",
        "  inputs = inputs[1:][:][:]\n",
        "  outputs = outputs[1:][:][:]\n",
        "  solutions_exact = solutions_exact[1:][:][:]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 19,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "6-XTs3rsy2ZS",
        "outputId": "61942b0f-e3cc-428a-aa78-56a0dba484d9"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "torch.Size([401, 1, 32])\n",
            "torch.Size([401, 10, 32])\n"
          ]
        }
      ],
      "source": [
        "# Chek input and output sizes\n",
        "print(inputs.size())\n",
        "print(outputs.size())"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 20,
      "metadata": {
        "id": "TgPiYQFIs5J0"
      },
      "outputs": [],
      "source": [
        "# Format data into datsets and then load them as dataloaders\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), int(m*val_size), m+1-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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 21,
      "metadata": {
        "id": "2U1ROo4QgWRb"
      },
      "outputs": [],
      "source": [
        "from numpy.lib.twodim_base import vander\n",
        "from numpy.lib.shape_base import apply_over_axes\n",
        "# Defin 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, xmesh, dt):\n",
        "    \"\"\"\n",
        "      xmesh: int\n",
        "        size of coarsened grid\n",
        "      W: matrix\n",
        "        Matrix for the coarsened FD method\n",
        "    \"\"\"\n",
        "    super(IndividualLayer_PDE, self).__init__()\n",
        "\n",
        "    #Define convolution filter corresponding to the heat equation partial derivatives\n",
        "    self.filter = torch.tensor([1,-2,1]).to(device)/(dx**2).float()\n",
        "    #Define convolution filter of 1 to add the zero boundary condition\n",
        "    self.one_filter = torch.tensor([1]).to(device).float()\n",
        "    # Initialize parameters randomly in (-0.5,0.5)\n",
        "    self.coefs_a = torch.nn.Parameter(torch.rand(xmesh)-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_x = 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.conv1d(v, self.filter.unsqueeze(0).unsqueeze(0), padding = 0)\n",
        "    convolution_with_zero_pad = F.conv1d(convolution_no_pad, one_filter.unsqueeze(0).unsqueeze(0), padding = 1)\n",
        "    a_xx = convolution_with_zero_pad*a_x\n",
        "\n",
        "    y = v + dt*(a_xx)\n",
        "    return y"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 22,
      "metadata": {
        "id": "Cp2MCJ7VYJD7"
      },
      "outputs": [],
      "source": [
        "class PDE_Solver(nn.Module):\n",
        "  \"\"\"This class implements the Full Coarsened FD method\"\"\"\n",
        "\n",
        "  def __init__(self, xmesh, dt):\n",
        "    \"\"\"\n",
        "      xmesh: int\n",
        "        size of coarsened grid\n",
        "      W: matrix\n",
        "        Matrix for the coarsened FD method\n",
        "    \"\"\"\n",
        "    super(PDE_Solver, self).__init__()\n",
        "\n",
        "    # Call the individual layer class defined previously\n",
        "    self.layer = IndividualLayer_PDE(xmesh, dt)\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) t_k times to generate the next t_k time predictions in the coarsened grid\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"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "K2lqgTBNgk_-"
      },
      "source": [
        "# Define the Training and Validation for the model"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 23,
      "metadata": {
        "id": "fjo8XIWYiW0q"
      },
      "outputs": [],
      "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"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "_UgRLEbzgnKX"
      },
      "source": [
        "# Run it / Train the Model and plot learning dynamics\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 24,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "rxH7uUKOYYmP",
        "outputId": "91941997-3ff1-435d-cc54-cf4c331d3016"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch: 0\n",
            "Train Loss: 0.006022707657202294 | Train Time: 0.253\n",
            "Valid Loss: 0.005708542536012828 | Valid Time: 0.011\n",
            "Epoch: 1\n",
            "Train Loss: 0.005930281293235327 | Train Time: 0.126\n",
            "Valid Loss: 0.005516639561392367 | Valid Time: 0.014\n",
            "Epoch: 2\n",
            "Train Loss: 0.005839306076890544 | Train Time: 0.124\n",
            "Valid Loss: 0.005151366698555648 | Valid Time: 0.012\n",
            "Epoch: 3\n",
            "Train Loss: 0.005732140430298291 | Train Time: 0.126\n",
            "Valid Loss: 0.0054748940747231245 | Valid Time: 0.012\n",
            "Epoch: 4\n",
            "Train Loss: 0.005642964271828532 | Train Time: 0.116\n",
            "Valid Loss: 0.006215968751348555 | Valid Time: 0.012\n",
            "Epoch: 5\n",
            "Train Loss: 0.005547633566158383 | Train Time: 0.118\n",
            "Valid Loss: 0.005359889124520123 | Valid Time: 0.012\n",
            "Epoch: 6\n",
            "Train Loss: 0.005432847078497473 | Train Time: 0.115\n",
            "Valid Loss: 0.005246044835075736 | Valid Time: 0.012\n",
            "Epoch: 7\n",
            "Train Loss: 0.0053434639335855055 | Train Time: 0.106\n",
            "Valid Loss: 0.0055446046171709895 | Valid Time: 0.011\n",
            "Epoch: 8\n",
            "Train Loss: 0.005277574662805388 | Train Time: 0.119\n",
            "Valid Loss: 0.005378877394832671 | Valid Time: 0.011\n",
            "Epoch: 9\n",
            "Train Loss: 0.005185118986685809 | Train Time: 0.137\n",
            "Valid Loss: 0.0049655206967145205 | Valid Time: 0.014\n",
            "Epoch: 10\n",
            "Train Loss: 0.005059625867656187 | Train Time: 0.125\n",
            "Valid Loss: 0.004603444365784526 | Valid Time: 0.015\n",
            "Epoch: 11\n",
            "Train Loss: 0.004983430973401195 | Train Time: 0.176\n",
            "Valid Loss: 0.005680905422195792 | Valid Time: 0.017\n",
            "Epoch: 12\n",
            "Train Loss: 0.004891543832950686 | Train Time: 0.177\n",
            "Valid Loss: 0.004403276077937335 | Valid Time: 0.016\n",
            "Epoch: 13\n",
            "Train Loss: 0.004796508197231512 | Train Time: 0.172\n",
            "Valid Loss: 0.004520352813415229 | Valid Time: 0.017\n",
            "Epoch: 14\n",
            "Train Loss: 0.00470240899410687 | Train Time: 0.180\n",
            "Valid Loss: 0.004273819562513381 | Valid Time: 0.022\n",
            "Epoch: 15\n",
            "Train Loss: 0.00461081306352035 | Train Time: 0.178\n",
            "Valid Loss: 0.004460550961084664 | Valid Time: 0.018\n",
            "Epoch: 16\n",
            "Train Loss: 0.004517844069356981 | Train Time: 0.167\n",
            "Valid Loss: 0.004419145290739834 | Valid Time: 0.017\n",
            "Epoch: 17\n",
            "Train Loss: 0.004444138784157603 | Train Time: 0.178\n",
            "Valid Loss: 0.003957313601858914 | Valid Time: 0.017\n",
            "Epoch: 18\n",
            "Train Loss: 0.004358808840870073 | Train Time: 0.167\n",
            "Valid Loss: 0.00392589793773368 | Valid Time: 0.017\n",
            "Epoch: 19\n",
            "Train Loss: 0.00427758506205129 | Train Time: 0.170\n",
            "Valid Loss: 0.004059159837197512 | Valid Time: 0.018\n",
            "Epoch: 20\n",
            "Train Loss: 0.004212616464907401 | Train Time: 0.188\n",
            "Valid Loss: 0.0036007167655043304 | Valid Time: 0.026\n",
            "Epoch: 21\n",
            "Train Loss: 0.004122606797241851 | Train Time: 0.185\n",
            "Valid Loss: 0.003655221371445805 | Valid Time: 0.022\n",
            "Epoch: 22\n",
            "Train Loss: 0.004051610668140806 | Train Time: 0.307\n",
            "Valid Loss: 0.003503266372717917 | Valid Time: 0.056\n",
            "Epoch: 23\n",
            "Train Loss: 0.003977577692191852 | Train Time: 0.316\n",
            "Valid Loss: 0.0035970100434497 | Valid Time: 0.030\n",
            "Epoch: 24\n",
            "Train Loss: 0.003885630358892836 | Train Time: 0.246\n",
            "Valid Loss: 0.003622808784712106 | Valid Time: 0.021\n",
            "Epoch: 25\n",
            "Train Loss: 0.0038065254124567695 | Train Time: 0.219\n",
            "Valid Loss: 0.004072236071806401 | Valid Time: 0.020\n",
            "Epoch: 26\n",
            "Train Loss: 0.003736542378503241 | Train Time: 0.232\n",
            "Valid Loss: 0.003139175707474351 | Valid Time: 0.022\n",
            "Epoch: 27\n",
            "Train Loss: 0.003677589610513104 | Train Time: 0.192\n",
            "Valid Loss: 0.0032151100458577275 | Valid Time: 0.038\n",
            "Epoch: 28\n",
            "Train Loss: 0.003595218981469148 | Train Time: 0.225\n",
            "Valid Loss: 0.00336052238708362 | Valid Time: 0.021\n",
            "Epoch: 29\n",
            "Train Loss: 0.003520999459157649 | Train Time: 0.204\n",
            "Valid Loss: 0.0030377372168004513 | Valid Time: 0.021\n",
            "Epoch: 30\n",
            "Train Loss: 0.00345320045016706 | Train Time: 0.107\n",
            "Valid Loss: 0.0030442578718066216 | Valid Time: 0.011\n",
            "Epoch: 31\n",
            "Train Loss: 0.003386886251208029 | Train Time: 0.119\n",
            "Valid Loss: 0.003385700925718993 | Valid Time: 0.011\n",
            "Epoch: 32\n",
            "Train Loss: 0.0033037262159938876 | Train Time: 0.112\n",
            "Valid Loss: 0.0029269070946611464 | Valid Time: 0.012\n",
            "Epoch: 33\n",
            "Train Loss: 0.003255401125275775 | Train Time: 0.121\n",
            "Valid Loss: 0.0029846628895029426 | Valid Time: 0.015\n",
            "Epoch: 34\n",
            "Train Loss: 0.0031954626626286065 | Train Time: 0.127\n",
            "Valid Loss: 0.0034853864344768226 | Valid Time: 0.012\n",
            "Epoch: 35\n",
            "Train Loss: 0.0031202850544727163 | Train Time: 0.112\n",
            "Valid Loss: 0.00299835461191833 | Valid Time: 0.013\n",
            "Epoch: 36\n",
            "Train Loss: 0.0030521262792478267 | Train Time: 0.116\n",
            "Valid Loss: 0.002754251763690263 | Valid Time: 0.012\n",
            "Epoch: 37\n",
            "Train Loss: 0.00299544067514178 | Train Time: 0.114\n",
            "Valid Loss: 0.002988450287375599 | Valid Time: 0.011\n",
            "Epoch: 38\n",
            "Train Loss: 0.002944330219179392 | Train Time: 0.134\n",
            "Valid Loss: 0.0027015317464247346 | Valid Time: 0.011\n",
            "Epoch: 39\n",
            "Train Loss: 0.0028628153775475526 | Train Time: 0.113\n",
            "Valid Loss: 0.0028702738345600665 | Valid Time: 0.011\n",
            "Epoch: 40\n",
            "Train Loss: 0.002807931692682599 | Train Time: 0.111\n",
            "Valid Loss: 0.0025484919315204024 | Valid Time: 0.013\n",
            "Epoch: 41\n",
            "Train Loss: 0.002753935025171622 | Train Time: 0.117\n",
            "Valid Loss: 0.002286036324221641 | Valid Time: 0.012\n",
            "Epoch: 42\n",
            "Train Loss: 0.0026928133845917487 | Train Time: 0.120\n",
            "Valid Loss: 0.0029183420701883733 | Valid Time: 0.011\n",
            "Epoch: 43\n",
            "Train Loss: 0.002639211328259032 | Train Time: 0.124\n",
            "Valid Loss: 0.0023122862330637872 | Valid Time: 0.012\n",
            "Epoch: 44\n",
            "Train Loss: 0.002595443437856279 | Train Time: 0.109\n",
            "Valid Loss: 0.002446758735459298 | Valid Time: 0.012\n",
            "Epoch: 45\n",
            "Train Loss: 0.002530722315178106 | Train Time: 0.177\n",
            "Valid Loss: 0.002296469727298245 | Valid Time: 0.018\n",
            "Epoch: 46\n",
            "Train Loss: 0.0024866770193176834 | Train Time: 0.150\n",
            "Valid Loss: 0.002400242898147553 | Valid Time: 0.014\n",
            "Epoch: 47\n",
            "Train Loss: 0.0024355393773140875 | Train Time: 0.117\n",
            "Valid Loss: 0.002326304675079882 | Valid Time: 0.011\n",
            "Epoch: 48\n",
            "Train Loss: 0.0023780806896913993 | Train Time: 0.120\n",
            "Valid Loss: 0.0026823281368706375 | Valid Time: 0.011\n",
            "Epoch: 49\n",
            "Train Loss: 0.0023288915705818093 | Train Time: 0.129\n",
            "Valid Loss: 0.002012915938394144 | Valid Time: 0.011\n",
            "Epoch: 50\n",
            "Train Loss: 0.002278816659542683 | Train Time: 0.107\n",
            "Valid Loss: 0.0018885830068029463 | Valid Time: 0.012\n",
            "Epoch: 51\n",
            "Train Loss: 0.00223068837198968 | Train Time: 0.120\n",
            "Valid Loss: 0.002079985715681687 | Valid Time: 0.012\n",
            "Epoch: 52\n",
            "Train Loss: 0.0021783894197525164 | Train Time: 0.108\n",
            "Valid Loss: 0.0020505935535766184 | Valid Time: 0.011\n",
            "Epoch: 53\n",
            "Train Loss: 0.002140336192065948 | Train Time: 0.111\n",
            "Valid Loss: 0.0020705388160422444 | Valid Time: 0.011\n",
            "Epoch: 54\n",
            "Train Loss: 0.002097764873485032 | Train Time: 0.124\n",
            "Valid Loss: 0.0022429199307225645 | Valid Time: 0.011\n",
            "Epoch: 55\n",
            "Train Loss: 0.0020490746553006923 | Train Time: 0.119\n",
            "Valid Loss: 0.001981540903216228 | Valid Time: 0.012\n",
            "Epoch: 56\n",
            "Train Loss: 0.0020099417735381345 | Train Time: 0.117\n",
            "Valid Loss: 0.0019970295252278447 | Valid Time: 0.011\n",
            "Epoch: 57\n",
            "Train Loss: 0.001970625556025066 | Train Time: 0.129\n",
            "Valid Loss: 0.0020616539986804128 | Valid Time: 0.011\n",
            "Epoch: 58\n",
            "Train Loss: 0.0019310084906847852 | Train Time: 0.110\n",
            "Valid Loss: 0.0018353080376982689 | Valid Time: 0.012\n",
            "Epoch: 59\n",
            "Train Loss: 0.0019026807582888164 | Train Time: 0.118\n",
            "Valid Loss: 0.00221494966535829 | Valid Time: 0.012\n",
            "Epoch: 60\n",
            "Train Loss: 0.0018424148070871045 | Train Time: 0.122\n",
            "Valid Loss: 0.0018271383305545896 | Valid Time: 0.011\n",
            "Epoch: 61\n",
            "Train Loss: 0.0018103201934871705 | Train Time: 0.110\n",
            "Valid Loss: 0.001970746641745791 | Valid Time: 0.011\n",
            "Epoch: 62\n",
            "Train Loss: 0.0017717139685134355 | Train Time: 0.108\n",
            "Valid Loss: 0.0016185084241442382 | Valid Time: 0.011\n",
            "Epoch: 63\n",
            "Train Loss: 0.0017389908163367134 | Train Time: 0.116\n",
            "Valid Loss: 0.0016805979830678552 | Valid Time: 0.012\n",
            "Epoch: 64\n",
            "Train Loss: 0.0017051032168398563 | Train Time: 0.111\n",
            "Valid Loss: 0.0014942114939913154 | Valid Time: 0.012\n",
            "Epoch: 65\n",
            "Train Loss: 0.0016680916979614842 | Train Time: 0.128\n",
            "Valid Loss: 0.0013660762342624366 | Valid Time: 0.011\n",
            "Epoch: 66\n",
            "Train Loss: 0.0016281424200554426 | Train Time: 0.112\n",
            "Valid Loss: 0.001634913554880768 | Valid Time: 0.013\n",
            "Epoch: 67\n",
            "Train Loss: 0.0016016657893104774 | Train Time: 0.124\n",
            "Valid Loss: 0.001481025479733944 | Valid Time: 0.011\n",
            "Epoch: 68\n",
            "Train Loss: 0.0015670369244425704 | Train Time: 0.109\n",
            "Valid Loss: 0.0015086504281498492 | Valid Time: 0.011\n",
            "Epoch: 69\n",
            "Train Loss: 0.0015282345825414125 | Train Time: 0.120\n",
            "Valid Loss: 0.0017880142549984157 | Valid Time: 0.012\n",
            "Epoch: 70\n",
            "Train Loss: 0.0015035283408666913 | Train Time: 0.126\n",
            "Valid Loss: 0.0012436848774086684 | Valid Time: 0.012\n",
            "Epoch: 71\n",
            "Train Loss: 0.0014683184532546683 | Train Time: 0.114\n",
            "Valid Loss: 0.0014465359272435308 | Valid Time: 0.012\n",
            "Epoch: 72\n",
            "Train Loss: 0.0014403238096029351 | Train Time: 0.115\n",
            "Valid Loss: 0.0012048720091115683 | Valid Time: 0.012\n",
            "Epoch: 73\n",
            "Train Loss: 0.0014050335647832406 | Train Time: 0.126\n",
            "Valid Loss: 0.001365945441648364 | Valid Time: 0.011\n",
            "Epoch: 74\n",
            "Train Loss: 0.0013805321160409796 | Train Time: 0.112\n",
            "Valid Loss: 0.00129694226779975 | Valid Time: 0.012\n",
            "Epoch: 75\n",
            "Train Loss: 0.0013539078645408154 | Train Time: 0.122\n",
            "Valid Loss: 0.0012210912245791405 | Valid Time: 0.011\n",
            "Epoch: 76\n",
            "Train Loss: 0.0013265702199484956 | Train Time: 0.110\n",
            "Valid Loss: 0.0012297394569031894 | Valid Time: 0.011\n",
            "Epoch: 77\n",
            "Train Loss: 0.0013027416517663944 | Train Time: 0.118\n",
            "Valid Loss: 0.0015173848369158804 | Valid Time: 0.011\n",
            "Epoch: 78\n",
            "Train Loss: 0.0012674365731838502 | Train Time: 0.118\n",
            "Valid Loss: 0.0012331795005593449 | Valid Time: 0.011\n",
            "Epoch: 79\n",
            "Train Loss: 0.0012414529613268218 | Train Time: 0.126\n",
            "Valid Loss: 0.0012837486137868837 | Valid Time: 0.011\n",
            "Epoch: 80\n",
            "Train Loss: 0.0012220904310724062 | Train Time: 0.123\n",
            "Valid Loss: 0.0012383272405713797 | Valid Time: 0.016\n",
            "Epoch: 81\n",
            "Train Loss: 0.0011965454690844605 | Train Time: 0.113\n",
            "Valid Loss: 0.001228788067237474 | Valid Time: 0.012\n",
            "Epoch: 82\n",
            "Train Loss: 0.001171953905692422 | Train Time: 0.109\n",
            "Valid Loss: 0.0009872696100501344 | Valid Time: 0.011\n",
            "Epoch: 83\n",
            "Train Loss: 0.0011496862831623538 | Train Time: 0.113\n",
            "Valid Loss: 0.0009517580183455721 | Valid Time: 0.011\n",
            "Epoch: 84\n",
            "Train Loss: 0.001125114905574408 | Train Time: 0.109\n",
            "Valid Loss: 0.0011686231446219608 | Valid Time: 0.011\n",
            "Epoch: 85\n",
            "Train Loss: 0.001101164848813297 | Train Time: 0.113\n",
            "Valid Loss: 0.0009974791901186109 | Valid Time: 0.011\n",
            "Epoch: 86\n",
            "Train Loss: 0.001082080992330846 | Train Time: 0.109\n",
            "Valid Loss: 0.0009423929004697129 | Valid Time: 0.011\n",
            "Epoch: 87\n",
            "Train Loss: 0.0010628449657049618 | Train Time: 0.119\n",
            "Valid Loss: 0.0009073606779566035 | Valid Time: 0.013\n",
            "Epoch: 88\n",
            "Train Loss: 0.0010389474398260446 | Train Time: 0.110\n",
            "Valid Loss: 0.0008949604089139029 | Valid Time: 0.011\n",
            "Epoch: 89\n",
            "Train Loss: 0.001019960021183483 | Train Time: 0.133\n",
            "Valid Loss: 0.0008825571712804958 | Valid Time: 0.011\n",
            "Epoch: 90\n",
            "Train Loss: 0.000998187644750272 | Train Time: 0.110\n",
            "Valid Loss: 0.0008919305400922894 | Valid Time: 0.011\n",
            "Epoch: 91\n",
            "Train Loss: 0.0009829417655342503 | Train Time: 0.118\n",
            "Valid Loss: 0.0008355263562407345 | Valid Time: 0.011\n",
            "Epoch: 92\n",
            "Train Loss: 0.0009629140779572097 | Train Time: 0.109\n",
            "Valid Loss: 0.0008328303811140358 | Valid Time: 0.011\n",
            "Epoch: 93\n",
            "Train Loss: 0.0009440425446404046 | Train Time: 0.133\n",
            "Valid Loss: 0.0009129049867624417 | Valid Time: 0.019\n",
            "Epoch: 94\n",
            "Train Loss: 0.0009220762447895188 | Train Time: 0.182\n",
            "Valid Loss: 0.0008238913142122328 | Valid Time: 0.017\n",
            "Epoch: 95\n",
            "Train Loss: 0.0009066835535984291 | Train Time: 0.179\n",
            "Valid Loss: 0.0007817537989467382 | Valid Time: 0.022\n",
            "Epoch: 96\n",
            "Train Loss: 0.0008926740081637705 | Train Time: 0.164\n",
            "Valid Loss: 0.0007977233181009069 | Valid Time: 0.018\n",
            "Epoch: 97\n",
            "Train Loss: 0.0008713867619486624 | Train Time: 0.178\n",
            "Valid Loss: 0.000689916210831143 | Valid Time: 0.019\n",
            "Epoch: 98\n",
            "Train Loss: 0.0008567835014362476 | Train Time: 0.173\n",
            "Valid Loss: 0.0007631918124388903 | Valid Time: 0.020\n",
            "Epoch: 99\n",
            "Train Loss: 0.0008383594808707896 | Train Time: 0.177\n",
            "Valid Loss: 0.0007206846785265952 | Valid Time: 0.020\n",
            "Epoch: 100\n",
            "Train Loss: 0.0008227690490648934 | Train Time: 0.173\n",
            "Valid Loss: 0.0008464194979751483 | Valid Time: 0.016\n",
            "Epoch: 101\n",
            "Train Loss: 0.0008125184195753383 | Train Time: 0.184\n",
            "Valid Loss: 0.0006994608556851745 | Valid Time: 0.019\n",
            "Epoch: 102\n",
            "Train Loss: 0.000795900971800285 | Train Time: 0.174\n",
            "Valid Loss: 0.000690682150889188 | Valid Time: 0.017\n",
            "Epoch: 103\n",
            "Train Loss: 0.0007777504230800428 | Train Time: 0.175\n",
            "Valid Loss: 0.0006587764946743846 | Valid Time: 0.017\n",
            "Epoch: 104\n",
            "Train Loss: 0.000769764086917827 | Train Time: 0.181\n",
            "Valid Loss: 0.0007850240363040939 | Valid Time: 0.017\n",
            "Epoch: 105\n",
            "Train Loss: 0.0007516047488407869 | Train Time: 0.187\n",
            "Valid Loss: 0.0006624845409533009 | Valid Time: 0.019\n",
            "Epoch: 106\n",
            "Train Loss: 0.0007381452229119054 | Train Time: 0.189\n",
            "Valid Loss: 0.0006014509781380184 | Valid Time: 0.021\n",
            "Epoch: 107\n",
            "Train Loss: 0.0007268385532753248 | Train Time: 0.115\n",
            "Valid Loss: 0.0006257586064748466 | Valid Time: 0.012\n",
            "Epoch: 108\n",
            "Train Loss: 0.0007078623028447557 | Train Time: 0.114\n",
            "Valid Loss: 0.0005816835837322287 | Valid Time: 0.011\n",
            "Epoch: 109\n",
            "Train Loss: 0.000694601949745495 | Train Time: 0.116\n",
            "Valid Loss: 0.0005675510037690401 | Valid Time: 0.011\n",
            "Epoch: 110\n",
            "Train Loss: 0.000682316591816121 | Train Time: 0.126\n",
            "Valid Loss: 0.0005658190420945175 | Valid Time: 0.011\n",
            "Epoch: 111\n",
            "Train Loss: 0.0006677680281235984 | Train Time: 0.125\n",
            "Valid Loss: 0.0005334582456271164 | Valid Time: 0.012\n",
            "Epoch: 112\n",
            "Train Loss: 0.0006588516223832572 | Train Time: 0.115\n",
            "Valid Loss: 0.0006199342024046928 | Valid Time: 0.011\n",
            "Epoch: 113\n",
            "Train Loss: 0.0006503059105996631 | Train Time: 0.108\n",
            "Valid Loss: 0.0005567139814957045 | Valid Time: 0.017\n",
            "Epoch: 114\n",
            "Train Loss: 0.0006348387227932873 | Train Time: 0.121\n",
            "Valid Loss: 0.0006050117663107812 | Valid Time: 0.011\n",
            "Epoch: 115\n",
            "Train Loss: 0.0006236324154183661 | Train Time: 0.107\n",
            "Valid Loss: 0.0005625393605441786 | Valid Time: 0.011\n",
            "Epoch: 116\n",
            "Train Loss: 0.0006109558208232844 | Train Time: 0.122\n",
            "Valid Loss: 0.0005513096402864903 | Valid Time: 0.012\n",
            "Epoch: 117\n",
            "Train Loss: 0.0006053054882948728 | Train Time: 0.110\n",
            "Valid Loss: 0.0005206449277466163 | Valid Time: 0.012\n",
            "Epoch: 118\n",
            "Train Loss: 0.000593703930989202 | Train Time: 0.118\n",
            "Valid Loss: 0.0004798240915988572 | Valid Time: 0.011\n",
            "Epoch: 119\n",
            "Train Loss: 0.0005817834967992416 | Train Time: 0.114\n",
            "Valid Loss: 0.00047301920130848885 | Valid Time: 0.012\n",
            "Epoch: 120\n",
            "Train Loss: 0.0005717638414353132 | Train Time: 0.120\n",
            "Valid Loss: 0.0004562038666335866 | Valid Time: 0.011\n",
            "Epoch: 121\n",
            "Train Loss: 0.000564324442836407 | Train Time: 0.112\n",
            "Valid Loss: 0.0004966757260262966 | Valid Time: 0.019\n",
            "Epoch: 122\n",
            "Train Loss: 0.0005524105370951522 | Train Time: 0.125\n",
            "Valid Loss: 0.0004915347963105887 | Valid Time: 0.016\n",
            "Epoch: 123\n",
            "Train Loss: 0.0005423568179953451 | Train Time: 0.114\n",
            "Valid Loss: 0.0006163757279864512 | Valid Time: 0.013\n",
            "Epoch: 124\n",
            "Train Loss: 0.0005334113436555 | Train Time: 0.113\n",
            "Valid Loss: 0.0005044266654294915 | Valid Time: 0.013\n",
            "Epoch: 125\n",
            "Train Loss: 0.0005255910571002843 | Train Time: 0.111\n",
            "Valid Loss: 0.0005415367486421019 | Valid Time: 0.011\n",
            "Epoch: 126\n",
            "Train Loss: 0.0005149182076198294 | Train Time: 0.115\n",
            "Valid Loss: 0.0004221555282128975 | Valid Time: 0.011\n",
            "Epoch: 127\n",
            "Train Loss: 0.0005079068344601087 | Train Time: 0.114\n",
            "Valid Loss: 0.0004020509877591394 | Valid Time: 0.012\n",
            "Epoch: 128\n",
            "Train Loss: 0.0004972899148828889 | Train Time: 0.117\n",
            "Valid Loss: 0.00043106159137096256 | Valid Time: 0.011\n",
            "Epoch: 129\n",
            "Train Loss: 0.0004886962920672408 | Train Time: 0.121\n",
            "Valid Loss: 0.0004080176222487353 | Valid Time: 0.013\n",
            "Epoch: 130\n",
            "Train Loss: 0.00048220186114409253 | Train Time: 0.128\n",
            "Valid Loss: 0.00040167721454054117 | Valid Time: 0.011\n",
            "Epoch: 131\n",
            "Train Loss: 0.00047460957093311374 | Train Time: 0.108\n",
            "Valid Loss: 0.00039399789238814265 | Valid Time: 0.011\n",
            "Epoch: 132\n",
            "Train Loss: 0.0004656886280587825 | Train Time: 0.118\n",
            "Valid Loss: 0.0003979954562964849 | Valid Time: 0.011\n",
            "Epoch: 133\n",
            "Train Loss: 0.00045802094820445696 | Train Time: 0.112\n",
            "Valid Loss: 0.0003703336769831367 | Valid Time: 0.011\n",
            "Epoch: 134\n",
            "Train Loss: 0.000451149316320784 | Train Time: 0.129\n",
            "Valid Loss: 0.00039433554775314406 | Valid Time: 0.015\n",
            "Epoch: 135\n",
            "Train Loss: 0.0004433439569670315 | Train Time: 0.113\n",
            "Valid Loss: 0.0003454205289017409 | Valid Time: 0.012\n",
            "Epoch: 136\n",
            "Train Loss: 0.0004370217839574539 | Train Time: 0.120\n",
            "Valid Loss: 0.00036485282907960936 | Valid Time: 0.012\n",
            "Epoch: 137\n",
            "Train Loss: 0.0004297005239334938 | Train Time: 0.128\n",
            "Valid Loss: 0.0004190654362901114 | Valid Time: 0.012\n",
            "Epoch: 138\n",
            "Train Loss: 0.0004231845577075881 | Train Time: 0.112\n",
            "Valid Loss: 0.0003585121739888564 | Valid Time: 0.011\n",
            "Epoch: 139\n",
            "Train Loss: 0.00041755747760793095 | Train Time: 0.124\n",
            "Valid Loss: 0.0003973668863181956 | Valid Time: 0.012\n",
            "Epoch: 140\n",
            "Train Loss: 0.00041092050914334034 | Train Time: 0.118\n",
            "Valid Loss: 0.00033668341347947717 | Valid Time: 0.012\n",
            "Epoch: 141\n",
            "Train Loss: 0.0004028854631255136 | Train Time: 0.109\n",
            "Valid Loss: 0.0003253793984185904 | Valid Time: 0.011\n",
            "Epoch: 142\n",
            "Train Loss: 0.00039758150141048983 | Train Time: 0.119\n",
            "Valid Loss: 0.0003357448658789508 | Valid Time: 0.011\n",
            "Epoch: 143\n",
            "Train Loss: 0.0003923745534848422 | Train Time: 0.110\n",
            "Valid Loss: 0.00034774931555148214 | Valid Time: 0.011\n",
            "Epoch: 144\n",
            "Train Loss: 0.0003867798490988973 | Train Time: 0.118\n",
            "Valid Loss: 0.0003324317294755019 | Valid Time: 0.011\n",
            "Epoch: 145\n",
            "Train Loss: 0.0003798866436179531 | Train Time: 0.122\n",
            "Valid Loss: 0.0003113369384664111 | Valid Time: 0.012\n",
            "Epoch: 146\n",
            "Train Loss: 0.00037395027404847115 | Train Time: 0.135\n",
            "Valid Loss: 0.0003674807521747425 | Valid Time: 0.011\n",
            "Epoch: 147\n",
            "Train Loss: 0.0003665596534694104 | Train Time: 0.107\n",
            "Valid Loss: 0.0003162479988532141 | Valid Time: 0.012\n",
            "Epoch: 148\n",
            "Train Loss: 0.000361211775606008 | Train Time: 0.120\n",
            "Valid Loss: 0.000282471864920808 | Valid Time: 0.011\n",
            "Epoch: 149\n",
            "Train Loss: 0.00035567038790567925 | Train Time: 0.110\n",
            "Valid Loss: 0.00028878735247417353 | Valid Time: 0.011\n",
            "Epoch: 150\n",
            "Train Loss: 0.0003498528783797826 | Train Time: 0.122\n",
            "Valid Loss: 0.00029978767270222306 | Valid Time: 0.011\n",
            "Epoch: 151\n",
            "Train Loss: 0.00034596213510284493 | Train Time: 0.111\n",
            "Valid Loss: 0.0002804653158818837 | Valid Time: 0.011\n",
            "Epoch: 152\n",
            "Train Loss: 0.000341853536634804 | Train Time: 0.112\n",
            "Valid Loss: 0.0002863974223146215 | Valid Time: 0.012\n",
            "Epoch: 153\n",
            "Train Loss: 0.00033534600056315725 | Train Time: 0.121\n",
            "Valid Loss: 0.00027404998400015756 | Valid Time: 0.012\n",
            "Epoch: 154\n",
            "Train Loss: 0.00032959708876564706 | Train Time: 0.116\n",
            "Valid Loss: 0.00027880529523827136 | Valid Time: 0.011\n",
            "Epoch: 155\n",
            "Train Loss: 0.0003252754272819546 | Train Time: 0.109\n",
            "Valid Loss: 0.00034377114207018167 | Valid Time: 0.011\n",
            "Epoch: 156\n",
            "Train Loss: 0.0003211818992368583 | Train Time: 0.119\n",
            "Valid Loss: 0.0002590074327599723 | Valid Time: 0.011\n",
            "Epoch: 157\n",
            "Train Loss: 0.0003158298311877604 | Train Time: 0.112\n",
            "Valid Loss: 0.0002654132404131815 | Valid Time: 0.011\n",
            "Epoch: 158\n",
            "Train Loss: 0.000312209933518285 | Train Time: 0.127\n",
            "Valid Loss: 0.00025971850118367 | Valid Time: 0.011\n",
            "Epoch: 159\n",
            "Train Loss: 0.00030718624322234015 | Train Time: 0.110\n",
            "Valid Loss: 0.0002644947489898186 | Valid Time: 0.011\n",
            "Epoch: 160\n",
            "Train Loss: 0.00030358767559702854 | Train Time: 0.115\n",
            "Valid Loss: 0.0003006462284247391 | Valid Time: 0.011\n",
            "Epoch: 161\n",
            "Train Loss: 0.00029934645939838926 | Train Time: 0.125\n",
            "Valid Loss: 0.00024478322302456945 | Valid Time: 0.012\n",
            "Epoch: 162\n",
            "Train Loss: 0.0002949994806457605 | Train Time: 0.117\n",
            "Valid Loss: 0.0002800630063575227 | Valid Time: 0.012\n",
            "Epoch: 163\n",
            "Train Loss: 0.00029149751705852777 | Train Time: 0.112\n",
            "Valid Loss: 0.0002506255441403482 | Valid Time: 0.011\n",
            "Epoch: 164\n",
            "Train Loss: 0.0002864745949505289 | Train Time: 0.115\n",
            "Valid Loss: 0.0002477643865859136 | Valid Time: 0.012\n",
            "Epoch: 165\n",
            "Train Loss: 0.00028205269681118235 | Train Time: 0.115\n",
            "Valid Loss: 0.00022985538089415058 | Valid Time: 0.016\n",
            "Epoch: 166\n",
            "Train Loss: 0.00027873366381850486 | Train Time: 0.118\n",
            "Valid Loss: 0.0002493230058462359 | Valid Time: 0.011\n",
            "Epoch: 167\n",
            "Train Loss: 0.00027620316311520964 | Train Time: 0.110\n",
            "Valid Loss: 0.0002212651088484563 | Valid Time: 0.011\n",
            "Epoch: 168\n",
            "Train Loss: 0.00027295556624027853 | Train Time: 0.114\n",
            "Valid Loss: 0.0002244654060632456 | Valid Time: 0.015\n",
            "Epoch: 169\n",
            "Train Loss: 0.0002680221813007895 | Train Time: 0.123\n",
            "Valid Loss: 0.00023174332454800606 | Valid Time: 0.013\n",
            "Epoch: 170\n",
            "Train Loss: 0.0002629201074964122 | Train Time: 0.110\n",
            "Valid Loss: 0.00022519084814121015 | Valid Time: 0.011\n",
            "Epoch: 171\n",
            "Train Loss: 0.0002602522198637751 | Train Time: 0.111\n",
            "Valid Loss: 0.00021499250942724757 | Valid Time: 0.011\n",
            "Epoch: 172\n",
            "Train Loss: 0.0002566820897443808 | Train Time: 0.114\n",
            "Valid Loss: 0.00021447083054226823 | Valid Time: 0.012\n",
            "Epoch: 173\n",
            "Train Loss: 0.00025386101103657365 | Train Time: 0.119\n",
            "Valid Loss: 0.00023343562133959495 | Valid Time: 0.011\n",
            "Epoch: 174\n",
            "Train Loss: 0.00025031097940978055 | Train Time: 0.114\n",
            "Valid Loss: 0.00019038032405660488 | Valid Time: 0.012\n",
            "Epoch: 175\n",
            "Train Loss: 0.00024698063115417764 | Train Time: 0.113\n",
            "Valid Loss: 0.00021304155598045327 | Valid Time: 0.011\n",
            "Epoch: 176\n",
            "Train Loss: 0.00024423256246863226 | Train Time: 0.120\n",
            "Valid Loss: 0.000201535047381185 | Valid Time: 0.011\n",
            "Epoch: 177\n",
            "Train Loss: 0.0002412903536184642 | Train Time: 0.137\n",
            "Valid Loss: 0.00023308998061111197 | Valid Time: 0.014\n",
            "Epoch: 178\n",
            "Train Loss: 0.00023730144158961544 | Train Time: 0.112\n",
            "Valid Loss: 0.0002036370788118802 | Valid Time: 0.011\n",
            "Epoch: 179\n",
            "Train Loss: 0.0002350829416077192 | Train Time: 0.115\n",
            "Valid Loss: 0.00018550697132013738 | Valid Time: 0.011\n",
            "Epoch: 180\n",
            "Train Loss: 0.00023251123983707083 | Train Time: 0.117\n",
            "Valid Loss: 0.00021449522319016978 | Valid Time: 0.011\n",
            "Epoch: 181\n",
            "Train Loss: 0.0002310161454308974 | Train Time: 0.114\n",
            "Valid Loss: 0.00021619740073219873 | Valid Time: 0.011\n",
            "Epoch: 182\n",
            "Train Loss: 0.00022577060965551553 | Train Time: 0.118\n",
            "Valid Loss: 0.00017622113045945298 | Valid Time: 0.011\n",
            "Epoch: 183\n",
            "Train Loss: 0.0002230360152775814 | Train Time: 0.119\n",
            "Valid Loss: 0.0001977542633539997 | Valid Time: 0.013\n",
            "Epoch: 184\n",
            "Train Loss: 0.0002208615172237746 | Train Time: 0.165\n",
            "Valid Loss: 0.0001866213497123681 | Valid Time: 0.020\n",
            "Epoch: 185\n",
            "Train Loss: 0.00021778219793065401 | Train Time: 0.175\n",
            "Valid Loss: 0.00019302889631944709 | Valid Time: 0.016\n",
            "Epoch: 186\n",
            "Train Loss: 0.00021430988655131506 | Train Time: 0.195\n",
            "Valid Loss: 0.0001717417690088041 | Valid Time: 0.018\n",
            "Epoch: 187\n",
            "Train Loss: 0.00021230261910731266 | Train Time: 0.177\n",
            "Valid Loss: 0.00017085607032640837 | Valid Time: 0.017\n",
            "Epoch: 188\n",
            "Train Loss: 0.00020883036823330544 | Train Time: 0.178\n",
            "Valid Loss: 0.00020393133672769181 | Valid Time: 0.020\n",
            "Epoch: 189\n",
            "Train Loss: 0.00020725823598791306 | Train Time: 0.168\n",
            "Valid Loss: 0.00015673667439841665 | Valid Time: 0.020\n",
            "Epoch: 190\n",
            "Train Loss: 0.0002042812840571921 | Train Time: 0.187\n",
            "Valid Loss: 0.00016348521967302077 | Valid Time: 0.017\n",
            "Epoch: 191\n",
            "Train Loss: 0.00020439712725898348 | Train Time: 0.173\n",
            "Valid Loss: 0.00016008368402253836 | Valid Time: 0.019\n",
            "Epoch: 192\n",
            "Train Loss: 0.0001999021202975296 | Train Time: 0.181\n",
            "Valid Loss: 0.00015320649254135787 | Valid Time: 0.017\n",
            "Epoch: 193\n",
            "Train Loss: 0.00019787262059061935 | Train Time: 0.174\n",
            "Valid Loss: 0.0001669558150751982 | Valid Time: 0.018\n",
            "Epoch: 194\n",
            "Train Loss: 0.000194826200114269 | Train Time: 0.191\n",
            "Valid Loss: 0.00017162917720270343 | Valid Time: 0.016\n",
            "Epoch: 195\n",
            "Train Loss: 0.000192854498316975 | Train Time: 0.182\n",
            "Valid Loss: 0.00015912937669781968 | Valid Time: 0.025\n",
            "Epoch: 196\n",
            "Train Loss: 0.00019250672286082255 | Train Time: 0.176\n",
            "Valid Loss: 0.00015916572374408133 | Valid Time: 0.018\n",
            "Epoch: 197\n",
            "Train Loss: 0.00018809109506515883 | Train Time: 0.135\n",
            "Valid Loss: 0.0001724859575915616 | Valid Time: 0.011\n",
            "Epoch: 198\n",
            "Train Loss: 0.00018661394776580366 | Train Time: 0.112\n",
            "Valid Loss: 0.00017957167437998578 | Valid Time: 0.011\n",
            "Epoch: 199\n",
            "Train Loss: 0.0001851700864407528 | Train Time: 0.119\n",
            "Valid Loss: 0.0001843758909672033 | Valid Time: 0.013\n",
            "Epoch: 200\n",
            "Train Loss: 0.0001823244567372297 | Train Time: 0.113\n",
            "Valid Loss: 0.00015231437282636762 | Valid Time: 0.011\n",
            "Epoch: 201\n",
            "Train Loss: 0.00018052933017698755 | Train Time: 0.117\n",
            "Valid Loss: 0.00014192347225616686 | Valid Time: 0.011\n",
            "Epoch: 202\n",
            "Train Loss: 0.00017940789295703565 | Train Time: 0.127\n",
            "Valid Loss: 0.00016275215784844477 | Valid Time: 0.011\n",
            "Epoch: 203\n",
            "Train Loss: 0.0001763831379847895 | Train Time: 0.119\n",
            "Valid Loss: 0.0001417383500665892 | Valid Time: 0.012\n",
            "Epoch: 204\n",
            "Train Loss: 0.00017370011712620524 | Train Time: 0.115\n",
            "Valid Loss: 0.00014360411296365783 | Valid Time: 0.011\n",
            "Epoch: 205\n",
            "Train Loss: 0.00017196736735058948 | Train Time: 0.117\n",
            "Valid Loss: 0.00013376974675338715 | Valid Time: 0.011\n",
            "Epoch: 206\n",
            "Train Loss: 0.00017015601157541633 | Train Time: 0.114\n",
            "Valid Loss: 0.0001502024897490628 | Valid Time: 0.015\n",
            "Epoch: 207\n",
            "Train Loss: 0.0001679227448460695 | Train Time: 0.116\n",
            "Valid Loss: 0.00013268298607727047 | Valid Time: 0.011\n",
            "Epoch: 208\n",
            "Train Loss: 0.0001667085433789333 | Train Time: 0.106\n",
            "Valid Loss: 0.00016556745140405837 | Valid Time: 0.011\n",
            "Epoch: 209\n",
            "Train Loss: 0.00016481129454117954 | Train Time: 0.128\n",
            "Valid Loss: 0.00015207809701678343 | Valid Time: 0.017\n",
            "Epoch: 210\n",
            "Train Loss: 0.00016317912339122574 | Train Time: 0.106\n",
            "Valid Loss: 0.00014041228314454202 | Valid Time: 0.012\n",
            "Epoch: 211\n",
            "Train Loss: 0.00016152999389879895 | Train Time: 0.115\n",
            "Valid Loss: 0.0001504891934018815 | Valid Time: 0.011\n",
            "Epoch: 212\n",
            "Train Loss: 0.00016052838863719158 | Train Time: 0.126\n",
            "Valid Loss: 0.00012819543917430565 | Valid Time: 0.011\n",
            "Epoch: 213\n",
            "Train Loss: 0.00015749372113005897 | Train Time: 0.116\n",
            "Valid Loss: 0.0001281450895476155 | Valid Time: 0.012\n",
            "Epoch: 214\n",
            "Train Loss: 0.0001561216329144755 | Train Time: 0.109\n",
            "Valid Loss: 0.0001192191612062743 | Valid Time: 0.013\n",
            "Epoch: 215\n",
            "Train Loss: 0.0001544079419354124 | Train Time: 0.114\n",
            "Valid Loss: 0.0001353501902485732 | Valid Time: 0.011\n",
            "Epoch: 216\n",
            "Train Loss: 0.00015286745053201325 | Train Time: 0.108\n",
            "Valid Loss: 0.00012383855209918693 | Valid Time: 0.011\n",
            "Epoch: 217\n",
            "Train Loss: 0.0001515284594987813 | Train Time: 0.116\n",
            "Valid Loss: 0.00014393059609574266 | Valid Time: 0.018\n",
            "Epoch: 218\n",
            "Train Loss: 0.00015004361385332517 | Train Time: 0.107\n",
            "Valid Loss: 0.00013670599582837895 | Valid Time: 0.011\n",
            "Epoch: 219\n",
            "Train Loss: 0.00014823977261058693 | Train Time: 0.122\n",
            "Valid Loss: 0.00012748385597660672 | Valid Time: 0.011\n",
            "Epoch: 220\n",
            "Train Loss: 0.00014714241459794146 | Train Time: 0.111\n",
            "Valid Loss: 0.00012795693328371271 | Valid Time: 0.011\n",
            "Epoch: 221\n",
            "Train Loss: 0.00014489272488342402 | Train Time: 0.120\n",
            "Valid Loss: 0.00014794878370594233 | Valid Time: 0.012\n",
            "Epoch: 222\n",
            "Train Loss: 0.00014418063342179122 | Train Time: 0.108\n",
            "Valid Loss: 0.00011950137741223443 | Valid Time: 0.011\n",
            "Epoch: 223\n",
            "Train Loss: 0.00014282831091948442 | Train Time: 0.125\n",
            "Valid Loss: 0.0001221875863848254 | Valid Time: 0.012\n",
            "Epoch: 224\n",
            "Train Loss: 0.00014073575852977994 | Train Time: 0.117\n",
            "Valid Loss: 0.0001170317773357965 | Valid Time: 0.011\n",
            "Epoch: 225\n",
            "Train Loss: 0.0001391424463547178 | Train Time: 0.122\n",
            "Valid Loss: 0.00013687656428373884 | Valid Time: 0.017\n",
            "Epoch: 226\n",
            "Train Loss: 0.0001375586518981053 | Train Time: 0.110\n",
            "Valid Loss: 0.00013264639528642874 | Valid Time: 0.011\n",
            "Epoch: 227\n",
            "Train Loss: 0.00013723155701116316 | Train Time: 0.114\n",
            "Valid Loss: 0.0001344134198006941 | Valid Time: 0.011\n",
            "Epoch: 228\n",
            "Train Loss: 0.0001352491633856277 | Train Time: 0.120\n",
            "Valid Loss: 0.00011378804265405051 | Valid Time: 0.013\n",
            "Epoch: 229\n",
            "Train Loss: 0.00013480610505212098 | Train Time: 0.112\n",
            "Valid Loss: 0.00012622590838873293 | Valid Time: 0.011\n",
            "Epoch: 230\n",
            "Train Loss: 0.0001330881875075743 | Train Time: 0.111\n",
            "Valid Loss: 0.00011252833064645529 | Valid Time: 0.016\n",
            "Epoch: 231\n",
            "Train Loss: 0.0001316685329105607 | Train Time: 0.116\n",
            "Valid Loss: 0.0001078809527825797 | Valid Time: 0.011\n",
            "Epoch: 232\n",
            "Train Loss: 0.0001308645116391984 | Train Time: 0.111\n",
            "Valid Loss: 0.00011909333261428401 | Valid Time: 0.011\n",
            "Epoch: 233\n",
            "Train Loss: 0.00012890043083308754 | Train Time: 0.118\n",
            "Valid Loss: 0.0001034872966556577 | Valid Time: 0.018\n",
            "Epoch: 234\n",
            "Train Loss: 0.0001278770271854132 | Train Time: 0.113\n",
            "Valid Loss: 0.00010891724014072679 | Valid Time: 0.012\n",
            "Epoch: 235\n",
            "Train Loss: 0.00012657545257273965 | Train Time: 0.115\n",
            "Valid Loss: 0.00011145584358018823 | Valid Time: 0.011\n",
            "Epoch: 236\n",
            "Train Loss: 0.00012602986986932687 | Train Time: 0.114\n",
            "Valid Loss: 0.00011795449972851202 | Valid Time: 0.012\n",
            "Epoch: 237\n",
            "Train Loss: 0.00012492195061273187 | Train Time: 0.122\n",
            "Valid Loss: 0.00010999104779330082 | Valid Time: 0.011\n",
            "Epoch: 238\n",
            "Train Loss: 0.0001235538059661753 | Train Time: 0.111\n",
            "Valid Loss: 9.994078391173389e-05 | Valid Time: 0.012\n",
            "Epoch: 239\n",
            "Train Loss: 0.00012230937902227437 | Train Time: 0.127\n",
            "Valid Loss: 9.9934379250044e-05 | Valid Time: 0.011\n",
            "Epoch: 240\n",
            "Train Loss: 0.0001212218695926774 | Train Time: 0.113\n",
            "Valid Loss: 9.732257058203686e-05 | Valid Time: 0.011\n",
            "Epoch: 241\n",
            "Train Loss: 0.00012006990858169861 | Train Time: 0.120\n",
            "Valid Loss: 0.00010559305883361958 | Valid Time: 0.011\n",
            "Epoch: 242\n",
            "Train Loss: 0.00011883426410158311 | Train Time: 0.113\n",
            "Valid Loss: 9.740899076859932e-05 | Valid Time: 0.011\n",
            "Epoch: 243\n",
            "Train Loss: 0.00011863891344738046 | Train Time: 0.116\n",
            "Valid Loss: 9.628754014556762e-05 | Valid Time: 0.013\n",
            "Epoch: 244\n",
            "Train Loss: 0.00011725230050567341 | Train Time: 0.122\n",
            "Valid Loss: 9.170164958050009e-05 | Valid Time: 0.016\n",
            "Epoch: 245\n",
            "Train Loss: 0.00011522351690617047 | Train Time: 0.114\n",
            "Valid Loss: 9.786160080693662e-05 | Valid Time: 0.011\n",
            "Epoch: 246\n",
            "Train Loss: 0.00011460298149981291 | Train Time: 0.117\n",
            "Valid Loss: 9.291224159824196e-05 | Valid Time: 0.012\n",
            "Epoch: 247\n",
            "Train Loss: 0.00011428353709082952 | Train Time: 0.117\n",
            "Valid Loss: 8.866465577739291e-05 | Valid Time: 0.011\n",
            "Epoch: 248\n",
            "Train Loss: 0.00011304534908911017 | Train Time: 0.108\n",
            "Valid Loss: 9.017669799504802e-05 | Valid Time: 0.012\n",
            "Epoch: 249\n",
            "Train Loss: 0.0001118729242558689 | Train Time: 0.128\n",
            "Valid Loss: 8.950499614002183e-05 | Valid Time: 0.017\n",
            "Epoch: 250\n",
            "Train Loss: 0.00011031518423758251 | Train Time: 0.113\n",
            "Valid Loss: 7.92882174209808e-05 | Valid Time: 0.011\n",
            "Epoch: 251\n",
            "Train Loss: 0.00010946063144058969 | Train Time: 0.115\n",
            "Valid Loss: 8.909994903660845e-05 | Valid Time: 0.011\n",
            "Epoch: 252\n",
            "Train Loss: 0.00010888207984144653 | Train Time: 0.120\n",
            "Valid Loss: 9.408069126948249e-05 | Valid Time: 0.012\n",
            "Epoch: 253\n",
            "Train Loss: 0.00010753858001216461 | Train Time: 0.112\n",
            "Valid Loss: 8.699794125277549e-05 | Valid Time: 0.012\n",
            "Epoch: 254\n",
            "Train Loss: 0.00010769007387448495 | Train Time: 0.117\n",
            "Valid Loss: 7.766140151943546e-05 | Valid Time: 0.011\n",
            "Epoch: 255\n",
            "Train Loss: 0.00010571787654618292 | Train Time: 0.120\n",
            "Valid Loss: 9.039076576300431e-05 | Valid Time: 0.011\n",
            "Epoch: 256\n",
            "Train Loss: 0.0001054926975293232 | Train Time: 0.111\n",
            "Valid Loss: 8.181651264749235e-05 | Valid Time: 0.011\n",
            "Epoch: 257\n",
            "Train Loss: 0.00010481438182882572 | Train Time: 0.129\n",
            "Valid Loss: 8.370173418370541e-05 | Valid Time: 0.011\n",
            "Epoch: 258\n",
            "Train Loss: 0.00010362043777652281 | Train Time: 0.113\n",
            "Valid Loss: 8.941309897636529e-05 | Valid Time: 0.016\n",
            "Epoch: 259\n",
            "Train Loss: 0.00010286782459221094 | Train Time: 0.125\n",
            "Valid Loss: 8.311049896292388e-05 | Valid Time: 0.012\n",
            "Epoch: 260\n",
            "Train Loss: 0.00010171772584343623 | Train Time: 0.120\n",
            "Valid Loss: 8.260289905592799e-05 | Valid Time: 0.012\n",
            "Epoch: 261\n",
            "Train Loss: 0.00010180268069042971 | Train Time: 0.119\n",
            "Valid Loss: 8.133895607898012e-05 | Valid Time: 0.012\n",
            "Epoch: 262\n",
            "Train Loss: 0.0001001094071972674 | Train Time: 0.119\n",
            "Valid Loss: 9.437731387151871e-05 | Valid Time: 0.011\n",
            "Epoch: 263\n",
            "Train Loss: 9.907935217549828e-05 | Train Time: 0.129\n",
            "Valid Loss: 8.587056254327763e-05 | Valid Time: 0.012\n",
            "Epoch: 264\n",
            "Train Loss: 9.920387865828448e-05 | Train Time: 0.123\n",
            "Valid Loss: 7.576888128824066e-05 | Valid Time: 0.011\n",
            "Epoch: 265\n",
            "Train Loss: 9.811664992747338e-05 | Train Time: 0.134\n",
            "Valid Loss: 7.948021993797738e-05 | Valid Time: 0.012\n",
            "Epoch: 266\n",
            "Train Loss: 9.74404676143374e-05 | Train Time: 0.109\n",
            "Valid Loss: 7.767862371110823e-05 | Valid Time: 0.011\n",
            "Epoch: 267\n",
            "Train Loss: 9.625403158440206e-05 | Train Time: 0.123\n",
            "Valid Loss: 7.504177938244538e-05 | Valid Time: 0.011\n",
            "Epoch: 268\n",
            "Train Loss: 9.57510787166508e-05 | Train Time: 0.114\n",
            "Valid Loss: 8.713818351679947e-05 | Valid Time: 0.012\n",
            "Epoch: 269\n",
            "Train Loss: 9.52353906254039e-05 | Train Time: 0.122\n",
            "Valid Loss: 7.162667589000193e-05 | Valid Time: 0.011\n",
            "Epoch: 270\n",
            "Train Loss: 9.401904543138746e-05 | Train Time: 0.116\n",
            "Valid Loss: 7.610361899423879e-05 | Valid Time: 0.014\n",
            "Epoch: 271\n",
            "Train Loss: 9.332227483881932e-05 | Train Time: 0.116\n",
            "Valid Loss: 6.853444483567728e-05 | Valid Time: 0.012\n",
            "Epoch: 272\n",
            "Train Loss: 9.26439507135288e-05 | Train Time: 0.110\n",
            "Valid Loss: 7.400276990665589e-05 | Valid Time: 0.013\n",
            "Epoch: 273\n",
            "Train Loss: 9.174711579505943e-05 | Train Time: 0.136\n",
            "Valid Loss: 7.646418816875666e-05 | Valid Time: 0.011\n",
            "Epoch: 274\n",
            "Train Loss: 9.112516195991223e-05 | Train Time: 0.191\n",
            "Valid Loss: 8.567669465264771e-05 | Valid Time: 0.030\n",
            "Epoch: 275\n",
            "Train Loss: 9.110948188830854e-05 | Train Time: 0.169\n",
            "Valid Loss: 6.762270641047508e-05 | Valid Time: 0.020\n",
            "Epoch: 276\n",
            "Train Loss: 9.012053047435505e-05 | Train Time: 0.173\n",
            "Valid Loss: 6.633550401602406e-05 | Valid Time: 0.016\n",
            "Epoch: 277\n",
            "Train Loss: 8.937569911818412e-05 | Train Time: 0.166\n",
            "Valid Loss: 8.322734174726065e-05 | Valid Time: 0.017\n",
            "Epoch: 278\n",
            "Train Loss: 8.841569337834556e-05 | Train Time: 0.197\n",
            "Valid Loss: 7.128888137231115e-05 | Valid Time: 0.018\n",
            "Epoch: 279\n",
            "Train Loss: 8.797637182349143e-05 | Train Time: 0.170\n",
            "Valid Loss: 6.734665475960355e-05 | Valid Time: 0.021\n",
            "Epoch: 280\n",
            "Train Loss: 8.713321260170472e-05 | Train Time: 0.183\n",
            "Valid Loss: 6.747874249413144e-05 | Valid Time: 0.016\n",
            "Epoch: 281\n",
            "Train Loss: 8.647055993175232e-05 | Train Time: 0.170\n",
            "Valid Loss: 7.824484055163339e-05 | Valid Time: 0.017\n",
            "Epoch: 282\n",
            "Train Loss: 8.587883655165665e-05 | Train Time: 0.173\n",
            "Valid Loss: 8.123786756186746e-05 | Valid Time: 0.016\n",
            "Epoch: 283\n",
            "Train Loss: 8.519269249518402e-05 | Train Time: 0.172\n",
            "Valid Loss: 6.853814375062939e-05 | Valid Time: 0.022\n",
            "Epoch: 284\n",
            "Train Loss: 8.475714122668203e-05 | Train Time: 0.196\n",
            "Valid Loss: 7.276505675690714e-05 | Valid Time: 0.017\n",
            "Epoch: 285\n",
            "Train Loss: 8.427047482415985e-05 | Train Time: 0.173\n",
            "Valid Loss: 8.676799552631564e-05 | Valid Time: 0.020\n",
            "Epoch: 286\n",
            "Train Loss: 8.370938054500392e-05 | Train Time: 0.187\n",
            "Valid Loss: 7.093495514709502e-05 | Valid Time: 0.012\n",
            "Epoch: 287\n",
            "Train Loss: 8.30964048586075e-05 | Train Time: 0.112\n",
            "Valid Loss: 6.409767775039654e-05 | Valid Time: 0.011\n",
            "Epoch: 288\n",
            "Train Loss: 8.253721228500485e-05 | Train Time: 0.119\n",
            "Valid Loss: 7.1612601459492e-05 | Valid Time: 0.012\n",
            "Epoch: 289\n",
            "Train Loss: 8.187164578550054e-05 | Train Time: 0.108\n",
            "Valid Loss: 6.223956097528571e-05 | Valid Time: 0.012\n",
            "Epoch: 290\n",
            "Train Loss: 8.124818812479804e-05 | Train Time: 0.132\n",
            "Valid Loss: 6.890889198984951e-05 | Valid Time: 0.011\n",
            "Epoch: 291\n",
            "Train Loss: 8.068126771831885e-05 | Train Time: 0.112\n",
            "Valid Loss: 6.354358083626721e-05 | Valid Time: 0.011\n",
            "Epoch: 292\n",
            "Train Loss: 7.997905356061988e-05 | Train Time: 0.111\n",
            "Valid Loss: 7.735207873338368e-05 | Valid Time: 0.011\n",
            "Epoch: 293\n",
            "Train Loss: 7.939626639678241e-05 | Train Time: 0.109\n",
            "Valid Loss: 7.788507537043188e-05 | Valid Time: 0.017\n",
            "Epoch: 294\n",
            "Train Loss: 7.906608286583306e-05 | Train Time: 0.115\n",
            "Valid Loss: 5.934421096753795e-05 | Valid Time: 0.011\n",
            "Epoch: 295\n",
            "Train Loss: 7.873182250094894e-05 | Train Time: 0.109\n",
            "Valid Loss: 6.421464513550745e-05 | Valid Time: 0.011\n",
            "Epoch: 296\n",
            "Train Loss: 7.773269566027203e-05 | Train Time: 0.122\n",
            "Valid Loss: 7.711383841524366e-05 | Valid Time: 0.011\n",
            "Epoch: 297\n",
            "Train Loss: 7.765595115702844e-05 | Train Time: 0.111\n",
            "Valid Loss: 6.160746488603763e-05 | Valid Time: 0.013\n",
            "Epoch: 298\n",
            "Train Loss: 7.691972706724253e-05 | Train Time: 0.133\n",
            "Valid Loss: 6.209426010173047e-05 | Valid Time: 0.012\n",
            "Epoch: 299\n",
            "Train Loss: 7.651515874098742e-05 | Train Time: 0.115\n",
            "Valid Loss: 6.27087874818244e-05 | Valid Time: 0.012\n",
            "Epoch: 300\n",
            "Train Loss: 7.568279876355326e-05 | Train Time: 0.119\n",
            "Valid Loss: 6.27484887445462e-05 | Valid Time: 0.015\n",
            "Epoch: 301\n",
            "Train Loss: 7.545166724747488e-05 | Train Time: 0.113\n",
            "Valid Loss: 6.451860281231347e-05 | Valid Time: 0.011\n",
            "Epoch: 302\n",
            "Train Loss: 7.500511549695052e-05 | Train Time: 0.115\n",
            "Valid Loss: 5.65180716876057e-05 | Valid Time: 0.012\n",
            "Epoch: 303\n",
            "Train Loss: 7.437169092315201e-05 | Train Time: 0.114\n",
            "Valid Loss: 5.951420553174103e-05 | Valid Time: 0.011\n",
            "Epoch: 304\n",
            "Train Loss: 7.434135458376994e-05 | Train Time: 0.125\n",
            "Valid Loss: 8.066965347097721e-05 | Valid Time: 0.013\n",
            "Epoch: 305\n",
            "Train Loss: 7.386712719667947e-05 | Train Time: 0.113\n",
            "Valid Loss: 5.436124729385483e-05 | Valid Time: 0.011\n",
            "Epoch: 306\n",
            "Train Loss: 7.324083363576057e-05 | Train Time: 0.141\n",
            "Valid Loss: 6.121163096395321e-05 | Valid Time: 0.011\n",
            "Epoch: 307\n",
            "Train Loss: 7.247128719188225e-05 | Train Time: 0.112\n",
            "Valid Loss: 6.665296859864611e-05 | Valid Time: 0.011\n",
            "Epoch: 308\n",
            "Train Loss: 7.213637141639513e-05 | Train Time: 0.123\n",
            "Valid Loss: 5.40078572157654e-05 | Valid Time: 0.011\n",
            "Epoch: 309\n",
            "Train Loss: 7.260651335328523e-05 | Train Time: 0.115\n",
            "Valid Loss: 6.184340600157157e-05 | Valid Time: 0.011\n",
            "Epoch: 310\n",
            "Train Loss: 7.127226394674692e-05 | Train Time: 0.119\n",
            "Valid Loss: 6.480480260506738e-05 | Valid Time: 0.011\n",
            "Epoch: 311\n",
            "Train Loss: 7.097784730017578e-05 | Train Time: 0.130\n",
            "Valid Loss: 5.438134212454315e-05 | Valid Time: 0.012\n",
            "Epoch: 312\n",
            "Train Loss: 7.062199170162018e-05 | Train Time: 0.115\n",
            "Valid Loss: 5.4654649829899427e-05 | Valid Time: 0.012\n",
            "Epoch: 313\n",
            "Train Loss: 6.988557690515575e-05 | Train Time: 0.117\n",
            "Valid Loss: 5.510229766514385e-05 | Valid Time: 0.011\n",
            "Epoch: 314\n",
            "Train Loss: 6.96814617855891e-05 | Train Time: 0.130\n",
            "Valid Loss: 5.9937534388154745e-05 | Valid Time: 0.011\n",
            "Epoch: 315\n",
            "Train Loss: 6.906309327429259e-05 | Train Time: 0.112\n",
            "Valid Loss: 6.852387105027447e-05 | Valid Time: 0.011\n",
            "Epoch: 316\n",
            "Train Loss: 6.88626101978834e-05 | Train Time: 0.115\n",
            "Valid Loss: 6.251440117921447e-05 | Valid Time: 0.011\n",
            "Epoch: 317\n",
            "Train Loss: 6.82807784821642e-05 | Train Time: 0.114\n",
            "Valid Loss: 5.879871332581388e-05 | Valid Time: 0.011\n",
            "Epoch: 318\n",
            "Train Loss: 6.803996324091905e-05 | Train Time: 0.113\n",
            "Valid Loss: 5.880556273041293e-05 | Valid Time: 0.013\n",
            "Epoch: 319\n",
            "Train Loss: 6.758462692041097e-05 | Train Time: 0.118\n",
            "Valid Loss: 5.433316073322203e-05 | Valid Time: 0.012\n",
            "Epoch: 320\n",
            "Train Loss: 6.712787427731153e-05 | Train Time: 0.114\n",
            "Valid Loss: 6.087696419854183e-05 | Valid Time: 0.012\n",
            "Epoch: 321\n",
            "Train Loss: 6.719471677665991e-05 | Train Time: 0.110\n",
            "Valid Loss: 5.270366727927467e-05 | Valid Time: 0.017\n",
            "Epoch: 322\n",
            "Train Loss: 6.638609403652433e-05 | Train Time: 0.126\n",
            "Valid Loss: 5.8156207160209306e-05 | Valid Time: 0.012\n",
            "Epoch: 323\n",
            "Train Loss: 6.607872810012563e-05 | Train Time: 0.112\n",
            "Valid Loss: 5.077502646599896e-05 | Valid Time: 0.015\n",
            "Epoch: 324\n",
            "Train Loss: 6.566136481093341e-05 | Train Time: 0.115\n",
            "Valid Loss: 5.6285203754669055e-05 | Valid Time: 0.011\n",
            "Epoch: 325\n",
            "Train Loss: 6.524089832581874e-05 | Train Time: 0.110\n",
            "Valid Loss: 5.366021468944382e-05 | Valid Time: 0.011\n",
            "Epoch: 326\n",
            "Train Loss: 6.507119982607516e-05 | Train Time: 0.121\n",
            "Valid Loss: 4.994202117813984e-05 | Valid Time: 0.011\n",
            "Epoch: 327\n",
            "Train Loss: 6.458164640016069e-05 | Train Time: 0.118\n",
            "Valid Loss: 5.4939958317845594e-05 | Valid Time: 0.012\n",
            "Epoch: 328\n",
            "Train Loss: 6.432112939747687e-05 | Train Time: 0.125\n",
            "Valid Loss: 4.817140052182367e-05 | Valid Time: 0.012\n",
            "Epoch: 329\n",
            "Train Loss: 6.37218750183054e-05 | Train Time: 0.122\n",
            "Valid Loss: 5.570628218265483e-05 | Valid Time: 0.017\n",
            "Epoch: 330\n",
            "Train Loss: 6.360245376862095e-05 | Train Time: 0.121\n",
            "Valid Loss: 5.5244388022401836e-05 | Valid Time: 0.011\n",
            "Epoch: 331\n",
            "Train Loss: 6.350306648528203e-05 | Train Time: 0.116\n",
            "Valid Loss: 5.317445084074279e-05 | Valid Time: 0.011\n",
            "Epoch: 332\n",
            "Train Loss: 6.282034538392174e-05 | Train Time: 0.114\n",
            "Valid Loss: 5.118182616570266e-05 | Valid Time: 0.011\n",
            "Epoch: 333\n",
            "Train Loss: 6.26560234339099e-05 | Train Time: 0.116\n",
            "Valid Loss: 4.8888935452851e-05 | Valid Time: 0.011\n",
            "Epoch: 334\n",
            "Train Loss: 6.239571915725001e-05 | Train Time: 0.125\n",
            "Valid Loss: 6.081107585487189e-05 | Valid Time: 0.011\n",
            "Epoch: 335\n",
            "Train Loss: 6.192897145458693e-05 | Train Time: 0.115\n",
            "Valid Loss: 5.402243277785601e-05 | Valid Time: 0.011\n",
            "Epoch: 336\n",
            "Train Loss: 6.159225660284344e-05 | Train Time: 0.119\n",
            "Valid Loss: 4.8771006731840316e-05 | Valid Time: 0.012\n",
            "Epoch: 337\n",
            "Train Loss: 6.10814761450073e-05 | Train Time: 0.128\n",
            "Valid Loss: 5.4069569159764796e-05 | Valid Time: 0.018\n",
            "Epoch: 338\n",
            "Train Loss: 6.123844382512432e-05 | Train Time: 0.117\n",
            "Valid Loss: 4.785771307069808e-05 | Valid Time: 0.011\n",
            "Epoch: 339\n",
            "Train Loss: 6.0652806017682646e-05 | Train Time: 0.108\n",
            "Valid Loss: 5.2780649639316835e-05 | Valid Time: 0.012\n",
            "Epoch: 340\n",
            "Train Loss: 6.0948801547056064e-05 | Train Time: 0.117\n",
            "Valid Loss: 4.7265415560104884e-05 | Valid Time: 0.011\n",
            "Epoch: 341\n",
            "Train Loss: 6.0207754071789644e-05 | Train Time: 0.112\n",
            "Valid Loss: 4.8403494474769104e-05 | Valid Time: 0.011\n",
            "Epoch: 342\n",
            "Train Loss: 6.01416108302625e-05 | Train Time: 0.115\n",
            "Valid Loss: 4.502622095969855e-05 | Valid Time: 0.011\n",
            "Epoch: 343\n",
            "Train Loss: 5.9330554473777543e-05 | Train Time: 0.287\n",
            "Valid Loss: 4.6306176045618486e-05 | Valid Time: 0.034\n",
            "Epoch: 344\n",
            "Train Loss: 5.92544699764786e-05 | Train Time: 0.355\n",
            "Valid Loss: 4.6500522330461536e-05 | Valid Time: 0.049\n",
            "Epoch: 345\n",
            "Train Loss: 5.890247312460193e-05 | Train Time: 0.229\n",
            "Valid Loss: 4.7479327804467175e-05 | Valid Time: 0.018\n",
            "Epoch: 346\n",
            "Train Loss: 5.873242040060608e-05 | Train Time: 0.242\n",
            "Valid Loss: 4.873925081483321e-05 | Valid Time: 0.023\n",
            "Epoch: 347\n",
            "Train Loss: 5.821251838106515e-05 | Train Time: 0.312\n",
            "Valid Loss: 4.746625563711859e-05 | Valid Time: 0.021\n",
            "Epoch: 348\n",
            "Train Loss: 5.827531544798005e-05 | Train Time: 0.252\n",
            "Valid Loss: 4.487401247388334e-05 | Valid Time: 0.011\n",
            "Epoch: 349\n",
            "Train Loss: 5.790833759084834e-05 | Train Time: 0.113\n",
            "Valid Loss: 5.205174875300145e-05 | Valid Time: 0.011\n",
            "Epoch: 350\n",
            "Train Loss: 5.7455225607171946e-05 | Train Time: 0.111\n",
            "Valid Loss: 4.916099260299234e-05 | Valid Time: 0.013\n",
            "Epoch: 351\n",
            "Train Loss: 5.705384415035185e-05 | Train Time: 0.114\n",
            "Valid Loss: 4.497275222092867e-05 | Valid Time: 0.011\n",
            "Epoch: 352\n",
            "Train Loss: 5.68397159728001e-05 | Train Time: 0.113\n",
            "Valid Loss: 4.8123802116606385e-05 | Valid Time: 0.012\n",
            "Epoch: 353\n",
            "Train Loss: 5.661891133824707e-05 | Train Time: 0.126\n",
            "Valid Loss: 4.9737121116777416e-05 | Valid Time: 0.011\n",
            "Epoch: 354\n",
            "Train Loss: 5.657880051570062e-05 | Train Time: 0.118\n",
            "Valid Loss: 5.498443351825699e-05 | Valid Time: 0.011\n",
            "Epoch: 355\n",
            "Train Loss: 5.6190998293459415e-05 | Train Time: 0.149\n",
            "Valid Loss: 4.375678145152051e-05 | Valid Time: 0.019\n",
            "Epoch: 356\n",
            "Train Loss: 5.58812314825206e-05 | Train Time: 0.190\n",
            "Valid Loss: 4.453597921383334e-05 | Valid Time: 0.019\n",
            "Epoch: 357\n",
            "Train Loss: 5.551323614015832e-05 | Train Time: 0.170\n",
            "Valid Loss: 4.7753177568665706e-05 | Valid Time: 0.019\n",
            "Epoch: 358\n",
            "Train Loss: 5.539983842601558e-05 | Train Time: 0.176\n",
            "Valid Loss: 4.801361501449719e-05 | Valid Time: 0.016\n",
            "Epoch: 359\n",
            "Train Loss: 5.513315849575998e-05 | Train Time: 0.183\n",
            "Valid Loss: 5.042537577537587e-05 | Valid Time: 0.020\n",
            "Epoch: 360\n",
            "Train Loss: 5.520182343101815e-05 | Train Time: 0.166\n",
            "Valid Loss: 4.591530432662694e-05 | Valid Time: 0.016\n",
            "Epoch: 361\n",
            "Train Loss: 5.460292691407774e-05 | Train Time: 0.186\n",
            "Valid Loss: 5.098228302813368e-05 | Valid Time: 0.018\n",
            "Epoch: 362\n",
            "Train Loss: 5.45069028464097e-05 | Train Time: 0.165\n",
            "Valid Loss: 4.1599952055548783e-05 | Valid Time: 0.016\n",
            "Epoch: 363\n",
            "Train Loss: 5.406515973797803e-05 | Train Time: 0.172\n",
            "Valid Loss: 4.405160325404722e-05 | Valid Time: 0.019\n",
            "Epoch: 364\n",
            "Train Loss: 5.3866860980633646e-05 | Train Time: 0.166\n",
            "Valid Loss: 5.0317629757046234e-05 | Valid Time: 0.020\n",
            "Epoch: 365\n",
            "Train Loss: 5.377429155678807e-05 | Train Time: 0.179\n",
            "Valid Loss: 4.0270611407322576e-05 | Valid Time: 0.020\n",
            "Epoch: 366\n",
            "Train Loss: 5.330561792729177e-05 | Train Time: 0.175\n",
            "Valid Loss: 5.14824087076704e-05 | Valid Time: 0.021\n",
            "Epoch: 367\n",
            "Train Loss: 5.34206766659688e-05 | Train Time: 0.179\n",
            "Valid Loss: 5.0657952670007944e-05 | Valid Time: 0.019\n",
            "Epoch: 368\n",
            "Train Loss: 5.321471172991503e-05 | Train Time: 0.175\n",
            "Valid Loss: 4.215327089696075e-05 | Valid Time: 0.011\n",
            "Epoch: 369\n",
            "Train Loss: 5.258859872762849e-05 | Train Time: 0.119\n",
            "Valid Loss: 4.2355880395916756e-05 | Valid Time: 0.011\n",
            "Epoch: 370\n",
            "Train Loss: 5.254837436184875e-05 | Train Time: 0.109\n",
            "Valid Loss: 4.317825823818566e-05 | Valid Time: 0.012\n",
            "Epoch: 371\n",
            "Train Loss: 5.247241030079558e-05 | Train Time: 0.133\n",
            "Valid Loss: 5.7540973102732096e-05 | Valid Time: 0.011\n",
            "Epoch: 372\n",
            "Train Loss: 5.2115107935510185e-05 | Train Time: 0.114\n",
            "Valid Loss: 4.6969517825345974e-05 | Valid Time: 0.011\n",
            "Epoch: 373\n",
            "Train Loss: 5.2041687204588304e-05 | Train Time: 0.119\n",
            "Valid Loss: 4.217119112581713e-05 | Valid Time: 0.011\n",
            "Epoch: 374\n",
            "Train Loss: 5.173888731453764e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.8657164168398594e-05 | Valid Time: 0.012\n",
            "Epoch: 375\n",
            "Train Loss: 5.134798687466077e-05 | Train Time: 0.124\n",
            "Valid Loss: 4.7687924961792305e-05 | Valid Time: 0.012\n",
            "Epoch: 376\n",
            "Train Loss: 5.1352669719275777e-05 | Train Time: 0.118\n",
            "Valid Loss: 4.786385306942975e-05 | Valid Time: 0.011\n",
            "Epoch: 377\n",
            "Train Loss: 5.13939672888036e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.84086988560739e-05 | Valid Time: 0.011\n",
            "Epoch: 378\n",
            "Train Loss: 5.0851078030016074e-05 | Train Time: 0.119\n",
            "Valid Loss: 4.7013651055749506e-05 | Valid Time: 0.017\n",
            "Epoch: 379\n",
            "Train Loss: 5.077377423539905e-05 | Train Time: 0.119\n",
            "Valid Loss: 4.557310967356898e-05 | Valid Time: 0.011\n",
            "Epoch: 380\n",
            "Train Loss: 5.0617845676912876e-05 | Train Time: 0.119\n",
            "Valid Loss: 5.039089228375815e-05 | Valid Time: 0.011\n",
            "Epoch: 381\n",
            "Train Loss: 5.0275643604292876e-05 | Train Time: 0.118\n",
            "Valid Loss: 4.696524592873175e-05 | Valid Time: 0.013\n",
            "Epoch: 382\n",
            "Train Loss: 5.001194451898826e-05 | Train Time: 0.122\n",
            "Valid Loss: 4.15642562074936e-05 | Valid Time: 0.016\n",
            "Epoch: 383\n",
            "Train Loss: 5.0125567596344476e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.794669237322523e-05 | Valid Time: 0.011\n",
            "Epoch: 384\n",
            "Train Loss: 4.983821188369276e-05 | Train Time: 0.117\n",
            "Valid Loss: 4.172001627011923e-05 | Valid Time: 0.013\n",
            "Epoch: 385\n",
            "Train Loss: 4.9608525985508766e-05 | Train Time: 0.128\n",
            "Valid Loss: 3.785668241107487e-05 | Valid Time: 0.013\n",
            "Epoch: 386\n",
            "Train Loss: 4.9489684514762635e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.6844000987912295e-05 | Valid Time: 0.011\n",
            "Epoch: 387\n",
            "Train Loss: 4.93991120540733e-05 | Train Time: 0.126\n",
            "Valid Loss: 4.380225436761975e-05 | Valid Time: 0.012\n",
            "Epoch: 388\n",
            "Train Loss: 4.907007697559158e-05 | Train Time: 0.111\n",
            "Valid Loss: 4.232616902299924e-05 | Valid Time: 0.011\n",
            "Epoch: 389\n",
            "Train Loss: 4.91305091648093e-05 | Train Time: 0.130\n",
            "Valid Loss: 4.62958205389441e-05 | Valid Time: 0.014\n",
            "Epoch: 390\n",
            "Train Loss: 4.8561271557302556e-05 | Train Time: 0.113\n",
            "Valid Loss: 4.273265221854672e-05 | Valid Time: 0.012\n",
            "Epoch: 391\n",
            "Train Loss: 4.863812079604127e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.9115870094974525e-05 | Valid Time: 0.011\n",
            "Epoch: 392\n",
            "Train Loss: 4.8247860257489315e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.9659577851125505e-05 | Valid Time: 0.011\n",
            "Epoch: 393\n",
            "Train Loss: 4.8174462886220825e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.760326990231988e-05 | Valid Time: 0.011\n",
            "Epoch: 394\n",
            "Train Loss: 4.819588761356978e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.919786740880227e-05 | Valid Time: 0.012\n",
            "Epoch: 395\n",
            "Train Loss: 4.7655544461265796e-05 | Train Time: 0.116\n",
            "Valid Loss: 4.506435743678594e-05 | Valid Time: 0.011\n",
            "Epoch: 396\n",
            "Train Loss: 4.7732475075846246e-05 | Train Time: 0.109\n",
            "Valid Loss: 4.1262122977059335e-05 | Valid Time: 0.012\n",
            "Epoch: 397\n",
            "Train Loss: 4.74814595164437e-05 | Train Time: 0.118\n",
            "Valid Loss: 4.4857497414341196e-05 | Valid Time: 0.016\n",
            "Epoch: 398\n",
            "Train Loss: 4.723904758544737e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.5012976923098904e-05 | Valid Time: 0.012\n",
            "Epoch: 399\n",
            "Train Loss: 4.713217372466859e-05 | Train Time: 0.121\n",
            "Valid Loss: 4.426737632456934e-05 | Valid Time: 0.011\n",
            "Epoch: 400\n",
            "Train Loss: 4.6937708056678896e-05 | Train Time: 0.111\n",
            "Valid Loss: 4.1398681787541136e-05 | Valid Time: 0.011\n",
            "Epoch: 401\n",
            "Train Loss: 4.7002568240522556e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.713511114256107e-05 | Valid Time: 0.014\n",
            "Epoch: 402\n",
            "Train Loss: 4.6863838322583195e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.7620657167281024e-05 | Valid Time: 0.011\n",
            "Epoch: 403\n",
            "Train Loss: 4.659319108070218e-05 | Train Time: 0.111\n",
            "Valid Loss: 4.1147121919493657e-05 | Valid Time: 0.011\n",
            "Epoch: 404\n",
            "Train Loss: 4.660111191792806e-05 | Train Time: 0.114\n",
            "Valid Loss: 4.1222386244044174e-05 | Valid Time: 0.010\n",
            "Epoch: 405\n",
            "Train Loss: 4.6316022857545726e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.889726849592989e-05 | Valid Time: 0.011\n",
            "Epoch: 406\n",
            "Train Loss: 4.618556340574287e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.642981027951464e-05 | Valid Time: 0.011\n",
            "Epoch: 407\n",
            "Train Loss: 4.601586433158158e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.858219770336291e-05 | Valid Time: 0.011\n",
            "Epoch: 408\n",
            "Train Loss: 4.59858716854605e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.695447458085255e-05 | Valid Time: 0.014\n",
            "Epoch: 409\n",
            "Train Loss: 4.575319460280681e-05 | Train Time: 0.117\n",
            "Valid Loss: 4.1277107811765745e-05 | Valid Time: 0.011\n",
            "Epoch: 410\n",
            "Train Loss: 4.547407872068059e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.8345942812156864e-05 | Valid Time: 0.013\n",
            "Epoch: 411\n",
            "Train Loss: 4.549505798709824e-05 | Train Time: 0.118\n",
            "Valid Loss: 4.739747237181291e-05 | Valid Time: 0.011\n",
            "Epoch: 412\n",
            "Train Loss: 4.547706167182983e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.834512153844116e-05 | Valid Time: 0.011\n",
            "Epoch: 413\n",
            "Train Loss: 4.529861210980207e-05 | Train Time: 0.137\n",
            "Valid Loss: 4.096941302123014e-05 | Valid Time: 0.011\n",
            "Epoch: 414\n",
            "Train Loss: 4.508556651815429e-05 | Train Time: 0.111\n",
            "Valid Loss: 4.0318153878615703e-05 | Valid Time: 0.012\n",
            "Epoch: 415\n",
            "Train Loss: 4.496141752353747e-05 | Train Time: 0.126\n",
            "Valid Loss: 4.0488205740984995e-05 | Valid Time: 0.011\n",
            "Epoch: 416\n",
            "Train Loss: 4.47358841866892e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.4499420053180074e-05 | Valid Time: 0.012\n",
            "Epoch: 417\n",
            "Train Loss: 4.456324160472784e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.9317792470683344e-05 | Valid Time: 0.015\n",
            "Epoch: 418\n",
            "Train Loss: 4.463489552252117e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.748741255549248e-05 | Valid Time: 0.011\n",
            "Epoch: 419\n",
            "Train Loss: 4.4464327162897556e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.839112650894094e-05 | Valid Time: 0.012\n",
            "Epoch: 420\n",
            "Train Loss: 4.447639625332637e-05 | Train Time: 0.113\n",
            "Valid Loss: 4.1758262341318186e-05 | Valid Time: 0.012\n",
            "Epoch: 421\n",
            "Train Loss: 4.4202228118114074e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.585177319109789e-05 | Valid Time: 0.011\n",
            "Epoch: 422\n",
            "Train Loss: 4.3988677804774946e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.64347151844413e-05 | Valid Time: 0.011\n",
            "Epoch: 423\n",
            "Train Loss: 4.37317866223901e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.981166264566127e-05 | Valid Time: 0.012\n",
            "Epoch: 424\n",
            "Train Loss: 4.3952079450766755e-05 | Train Time: 0.103\n",
            "Valid Loss: 3.875672973663313e-05 | Valid Time: 0.011\n",
            "Epoch: 425\n",
            "Train Loss: 4.3727829937492255e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.819555877271341e-05 | Valid Time: 0.014\n",
            "Epoch: 426\n",
            "Train Loss: 4.38274803041407e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.5708358154806774e-05 | Valid Time: 0.011\n",
            "Epoch: 427\n",
            "Train Loss: 4.349592831874217e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.377977645868668e-05 | Valid Time: 0.011\n",
            "Epoch: 428\n",
            "Train Loss: 4.323496212141196e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.393208680790849e-05 | Valid Time: 0.012\n",
            "Epoch: 429\n",
            "Train Loss: 4.335759896141673e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.2519675869480125e-05 | Valid Time: 0.011\n",
            "Epoch: 430\n",
            "Train Loss: 4.312206453361892e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.716131686815061e-05 | Valid Time: 0.011\n",
            "Epoch: 431\n",
            "Train Loss: 4.300834284788978e-05 | Train Time: 0.123\n",
            "Valid Loss: 4.1501690247969236e-05 | Valid Time: 0.011\n",
            "Epoch: 432\n",
            "Train Loss: 4.295649494834881e-05 | Train Time: 0.111\n",
            "Valid Loss: 4.108510711375857e-05 | Valid Time: 0.015\n",
            "Epoch: 433\n",
            "Train Loss: 4.264603960205262e-05 | Train Time: 0.137\n",
            "Valid Loss: 3.53793152498838e-05 | Valid Time: 0.012\n",
            "Epoch: 434\n",
            "Train Loss: 4.2531412251073085e-05 | Train Time: 0.109\n",
            "Valid Loss: 4.025258294859668e-05 | Valid Time: 0.011\n",
            "Epoch: 435\n",
            "Train Loss: 4.264191174067826e-05 | Train Time: 0.134\n",
            "Valid Loss: 3.833233131445013e-05 | Valid Time: 0.012\n",
            "Epoch: 436\n",
            "Train Loss: 4.228461693855934e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.388505456314306e-05 | Valid Time: 0.011\n",
            "Epoch: 437\n",
            "Train Loss: 4.2398315551843935e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.702298135976889e-05 | Valid Time: 0.012\n",
            "Epoch: 438\n",
            "Train Loss: 4.222493053499707e-05 | Train Time: 0.110\n",
            "Valid Loss: 4.599665589921642e-05 | Valid Time: 0.011\n",
            "Epoch: 439\n",
            "Train Loss: 4.2262846028806e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.7244569284666795e-05 | Valid Time: 0.016\n",
            "Epoch: 440\n",
            "Train Loss: 4.2019191728047046e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.272880258009536e-05 | Valid Time: 0.012\n",
            "Epoch: 441\n",
            "Train Loss: 4.191384926487348e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.691022084240103e-05 | Valid Time: 0.012\n",
            "Epoch: 442\n",
            "Train Loss: 4.178607866235421e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.2642919450154295e-05 | Valid Time: 0.011\n",
            "Epoch: 443\n",
            "Train Loss: 4.1732468545026345e-05 | Train Time: 0.112\n",
            "Valid Loss: 4.1950509512389544e-05 | Valid Time: 0.012\n",
            "Epoch: 444\n",
            "Train Loss: 4.1681850952476164e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.728518004209036e-05 | Valid Time: 0.011\n",
            "Epoch: 445\n",
            "Train Loss: 4.1460177989823644e-05 | Train Time: 0.151\n",
            "Valid Loss: 3.8911514820938464e-05 | Valid Time: 0.018\n",
            "Epoch: 446\n",
            "Train Loss: 4.150278054064409e-05 | Train Time: 0.177\n",
            "Valid Loss: 4.166750113654416e-05 | Valid Time: 0.017\n",
            "Epoch: 447\n",
            "Train Loss: 4.148057087149937e-05 | Train Time: 0.183\n",
            "Valid Loss: 4.064171116624493e-05 | Valid Time: 0.017\n",
            "Epoch: 448\n",
            "Train Loss: 4.115429826350393e-05 | Train Time: 0.171\n",
            "Valid Loss: 3.5613183172245044e-05 | Valid Time: 0.017\n",
            "Epoch: 449\n",
            "Train Loss: 4.113311651484477e-05 | Train Time: 0.176\n",
            "Valid Loss: 3.839992359644384e-05 | Valid Time: 0.018\n",
            "Epoch: 450\n",
            "Train Loss: 4.112058587978888e-05 | Train Time: 0.170\n",
            "Valid Loss: 4.3514267872524215e-05 | Valid Time: 0.016\n",
            "Epoch: 451\n",
            "Train Loss: 4.0884275413669745e-05 | Train Time: 0.180\n",
            "Valid Loss: 3.43173969667987e-05 | Valid Time: 0.023\n",
            "Epoch: 452\n",
            "Train Loss: 4.0871029724305695e-05 | Train Time: 0.168\n",
            "Valid Loss: 3.622741041908739e-05 | Valid Time: 0.016\n",
            "Epoch: 453\n",
            "Train Loss: 4.0989752865004303e-05 | Train Time: 0.191\n",
            "Valid Loss: 4.063576488988474e-05 | Valid Time: 0.016\n",
            "Epoch: 454\n",
            "Train Loss: 4.101547528989613e-05 | Train Time: 0.171\n",
            "Valid Loss: 3.191854375472758e-05 | Valid Time: 0.017\n",
            "Epoch: 455\n",
            "Train Loss: 4.056509696008441e-05 | Train Time: 0.179\n",
            "Valid Loss: 4.41622960352106e-05 | Valid Time: 0.021\n",
            "Epoch: 456\n",
            "Train Loss: 4.0572664338948305e-05 | Train Time: 0.179\n",
            "Valid Loss: 3.619342987803975e-05 | Valid Time: 0.026\n",
            "Epoch: 457\n",
            "Train Loss: 4.0372631414548345e-05 | Train Time: 0.181\n",
            "Valid Loss: 3.125685179838911e-05 | Valid Time: 0.017\n",
            "Epoch: 458\n",
            "Train Loss: 4.037802672859183e-05 | Train Time: 0.173\n",
            "Valid Loss: 3.534550342010334e-05 | Valid Time: 0.011\n",
            "Epoch: 459\n",
            "Train Loss: 4.021521434831237e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.6174872548144776e-05 | Valid Time: 0.012\n",
            "Epoch: 460\n",
            "Train Loss: 4.022815071374154e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.4036554097838234e-05 | Valid Time: 0.011\n",
            "Epoch: 461\n",
            "Train Loss: 4.016997569890105e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.947709410567768e-05 | Valid Time: 0.011\n",
            "Epoch: 462\n",
            "Train Loss: 3.989136386831218e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.570404624042567e-05 | Valid Time: 0.012\n",
            "Epoch: 463\n",
            "Train Loss: 4.006195080077496e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.191707037331071e-05 | Valid Time: 0.011\n",
            "Epoch: 464\n",
            "Train Loss: 3.981674892297873e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.45516800734913e-05 | Valid Time: 0.012\n",
            "Epoch: 465\n",
            "Train Loss: 3.989260288730484e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.6348893445392605e-05 | Valid Time: 0.011\n",
            "Epoch: 466\n",
            "Train Loss: 3.96010436816141e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.2563405056862393e-05 | Valid Time: 0.012\n",
            "Epoch: 467\n",
            "Train Loss: 3.9951822863689524e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.5637406654132064e-05 | Valid Time: 0.011\n",
            "Epoch: 468\n",
            "Train Loss: 3.943683058375762e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.618069058575202e-05 | Valid Time: 0.011\n",
            "Epoch: 469\n",
            "Train Loss: 3.9699001717963256e-05 | Train Time: 0.117\n",
            "Valid Loss: 4.333661127020605e-05 | Valid Time: 0.011\n",
            "Epoch: 470\n",
            "Train Loss: 3.946318630417074e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.3738338515831856e-05 | Valid Time: 0.011\n",
            "Epoch: 471\n",
            "Train Loss: 3.943265150347112e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.181404917995678e-05 | Valid Time: 0.011\n",
            "Epoch: 472\n",
            "Train Loss: 3.9635650050752846e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.256127047279733e-05 | Valid Time: 0.011\n",
            "Epoch: 473\n",
            "Train Loss: 3.9168863957839726e-05 | Train Time: 0.105\n",
            "Valid Loss: 3.0149424219416687e-05 | Valid Time: 0.013\n",
            "Epoch: 474\n",
            "Train Loss: 3.915163697935273e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.07642249026685e-05 | Valid Time: 0.011\n",
            "Epoch: 475\n",
            "Train Loss: 3.906927371357788e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.4216767744510435e-05 | Valid Time: 0.011\n",
            "Epoch: 476\n",
            "Train Loss: 3.8950725100125726e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.2241792268905556e-05 | Valid Time: 0.012\n",
            "Epoch: 477\n",
            "Train Loss: 3.8882732903738016e-05 | Train Time: 0.115\n",
            "Valid Loss: 4.425736369739752e-05 | Valid Time: 0.012\n",
            "Epoch: 478\n",
            "Train Loss: 3.8783036679409345e-05 | Train Time: 0.130\n",
            "Valid Loss: 4.270501221981249e-05 | Valid Time: 0.012\n",
            "Epoch: 479\n",
            "Train Loss: 3.863871710276917e-05 | Train Time: 0.108\n",
            "Valid Loss: 3.084528771069017e-05 | Valid Time: 0.011\n",
            "Epoch: 480\n",
            "Train Loss: 3.87730852755914e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.203746018698439e-05 | Valid Time: 0.011\n",
            "Epoch: 481\n",
            "Train Loss: 3.854642579282977e-05 | Train Time: 0.105\n",
            "Valid Loss: 3.22759274240525e-05 | Valid Time: 0.011\n",
            "Epoch: 482\n",
            "Train Loss: 3.858109515644365e-05 | Train Time: 0.126\n",
            "Valid Loss: 3.2310912501998246e-05 | Valid Time: 0.011\n",
            "Epoch: 483\n",
            "Train Loss: 3.8396137729011426e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.560996947271633e-05 | Valid Time: 0.013\n",
            "Epoch: 484\n",
            "Train Loss: 3.828015590108024e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.0969755698606605e-05 | Valid Time: 0.012\n",
            "Epoch: 485\n",
            "Train Loss: 3.846411671379189e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.0503790640068473e-05 | Valid Time: 0.012\n",
            "Epoch: 486\n",
            "Train Loss: 3.825837321576393e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.667567079901346e-05 | Valid Time: 0.011\n",
            "Epoch: 487\n",
            "Train Loss: 3.8205133406384116e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.953609964606585e-05 | Valid Time: 0.014\n",
            "Epoch: 488\n",
            "Train Loss: 3.825329756517405e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.4891482755483594e-05 | Valid Time: 0.011\n",
            "Epoch: 489\n",
            "Train Loss: 3.811763771840273e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.239905800000997e-05 | Valid Time: 0.013\n",
            "Epoch: 490\n",
            "Train Loss: 3.8363372943039344e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.2452717732667224e-05 | Valid Time: 0.012\n",
            "Epoch: 491\n",
            "Train Loss: 3.8076935628563855e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.8443508401542204e-05 | Valid Time: 0.011\n",
            "Epoch: 492\n",
            "Train Loss: 3.815764524149831e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.286521950940369e-05 | Valid Time: 0.011\n",
            "Epoch: 493\n",
            "Train Loss: 3.7942194658650185e-05 | Train Time: 0.106\n",
            "Valid Loss: 3.717125628099893e-05 | Valid Time: 0.012\n",
            "Epoch: 494\n",
            "Train Loss: 3.780058968435409e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.7139262531127315e-05 | Valid Time: 0.013\n",
            "Epoch: 495\n",
            "Train Loss: 3.7766474250881734e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.4684276670304826e-05 | Valid Time: 0.011\n",
            "Epoch: 496\n",
            "Train Loss: 3.7663625813653e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.4859667721320875e-05 | Valid Time: 0.011\n",
            "Epoch: 497\n",
            "Train Loss: 3.761054109705392e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.283981914137257e-05 | Valid Time: 0.011\n",
            "Epoch: 498\n",
            "Train Loss: 3.75809229712774e-05 | Train Time: 0.132\n",
            "Valid Loss: 3.865686312565231e-05 | Valid Time: 0.012\n",
            "Epoch: 499\n",
            "Train Loss: 3.786422061430609e-05 | Train Time: 0.125\n",
            "Valid Loss: 3.771681895159418e-05 | Valid Time: 0.011\n",
            "Epoch: 500\n",
            "Train Loss: 3.7644480088554124e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.799082287514466e-05 | Valid Time: 0.012\n",
            "Epoch: 501\n",
            "Train Loss: 3.7503540002753176e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.03218730550725e-05 | Valid Time: 0.016\n",
            "Epoch: 502\n",
            "Train Loss: 3.729031471409957e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.940758870157879e-05 | Valid Time: 0.012\n",
            "Epoch: 503\n",
            "Train Loss: 3.745303719800799e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.7616426197928376e-05 | Valid Time: 0.011\n",
            "Epoch: 504\n",
            "Train Loss: 3.727680507979944e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.458100763964467e-05 | Valid Time: 0.012\n",
            "Epoch: 505\n",
            "Train Loss: 3.7201699103063314e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.203664391548955e-05 | Valid Time: 0.017\n",
            "Epoch: 506\n",
            "Train Loss: 3.715512416659438e-05 | Train Time: 0.126\n",
            "Valid Loss: 3.163215660606511e-05 | Valid Time: 0.013\n",
            "Epoch: 507\n",
            "Train Loss: 3.7055918590723245e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.8578250951104565e-05 | Valid Time: 0.011\n",
            "Epoch: 508\n",
            "Train Loss: 3.702592039189767e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.146093149553053e-05 | Valid Time: 0.015\n",
            "Epoch: 509\n",
            "Train Loss: 3.704057302169722e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.8267138077353593e-05 | Valid Time: 0.012\n",
            "Epoch: 510\n",
            "Train Loss: 3.72386847103419e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.267544434493175e-05 | Valid Time: 0.012\n",
            "Epoch: 511\n",
            "Train Loss: 3.693553815920543e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.743725756066851e-05 | Valid Time: 0.011\n",
            "Epoch: 512\n",
            "Train Loss: 3.694099608477891e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.420820848987205e-05 | Valid Time: 0.012\n",
            "Epoch: 513\n",
            "Train Loss: 3.682224249994186e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.778923246500199e-05 | Valid Time: 0.018\n",
            "Epoch: 514\n",
            "Train Loss: 3.691826742923647e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.01869308714231e-05 | Valid Time: 0.013\n",
            "Epoch: 515\n",
            "Train Loss: 3.691789721702471e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.457740331214154e-05 | Valid Time: 0.012\n",
            "Epoch: 516\n",
            "Train Loss: 3.6694277074083835e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.268153068347601e-05 | Valid Time: 0.011\n",
            "Epoch: 517\n",
            "Train Loss: 3.6681374599299344e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.19228620355716e-05 | Valid Time: 0.011\n",
            "Epoch: 518\n",
            "Train Loss: 3.653605668468548e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.40317656082334e-05 | Valid Time: 0.012\n",
            "Epoch: 519\n",
            "Train Loss: 3.671969716378953e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.331884408908081e-05 | Valid Time: 0.011\n",
            "Epoch: 520\n",
            "Train Loss: 3.67503942374912e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.9114302378729917e-05 | Valid Time: 0.011\n",
            "Epoch: 521\n",
            "Train Loss: 3.660975524230468e-05 | Train Time: 0.135\n",
            "Valid Loss: 3.5636669053928927e-05 | Valid Time: 0.011\n",
            "Epoch: 522\n",
            "Train Loss: 3.64243520667323e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.3147111480502645e-05 | Valid Time: 0.011\n",
            "Epoch: 523\n",
            "Train Loss: 3.638882576763679e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.093663463005214e-05 | Valid Time: 0.011\n",
            "Epoch: 524\n",
            "Train Loss: 3.6508886439964715e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.7057897770864656e-05 | Valid Time: 0.011\n",
            "Epoch: 525\n",
            "Train Loss: 3.638631718977673e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.3298212656518444e-05 | Valid Time: 0.011\n",
            "Epoch: 526\n",
            "Train Loss: 3.6251331613656425e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.739079875231255e-05 | Valid Time: 0.013\n",
            "Epoch: 527\n",
            "Train Loss: 3.614577259500756e-05 | Train Time: 0.108\n",
            "Valid Loss: 3.697050306072924e-05 | Valid Time: 0.011\n",
            "Epoch: 528\n",
            "Train Loss: 3.631650131290754e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.8091387321182992e-05 | Valid Time: 0.011\n",
            "Epoch: 529\n",
            "Train Loss: 3.6079322327216355e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.8871163522126153e-05 | Valid Time: 0.012\n",
            "Epoch: 530\n",
            "Train Loss: 3.6182569889014736e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.293551253591431e-05 | Valid Time: 0.011\n",
            "Epoch: 531\n",
            "Train Loss: 3.621915388258027e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.8238258664714522e-05 | Valid Time: 0.011\n",
            "Epoch: 532\n",
            "Train Loss: 3.6153288276277874e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.00704818982922e-05 | Valid Time: 0.011\n",
            "Epoch: 533\n",
            "Train Loss: 3.588972867873963e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.267935335315997e-05 | Valid Time: 0.011\n",
            "Epoch: 534\n",
            "Train Loss: 3.59566675845264e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.2323259347322164e-05 | Valid Time: 0.012\n",
            "Epoch: 535\n",
            "Train Loss: 3.597384047201271e-05 | Train Time: 0.129\n",
            "Valid Loss: 2.7289296667731833e-05 | Valid Time: 0.017\n",
            "Epoch: 536\n",
            "Train Loss: 3.576258735081769e-05 | Train Time: 0.185\n",
            "Valid Loss: 3.4389122447464615e-05 | Valid Time: 0.019\n",
            "Epoch: 537\n",
            "Train Loss: 3.5776020108881456e-05 | Train Time: 0.184\n",
            "Valid Loss: 2.8180946628708625e-05 | Valid Time: 0.018\n",
            "Epoch: 538\n",
            "Train Loss: 3.5663535623155584e-05 | Train Time: 0.169\n",
            "Valid Loss: 3.3773893846955616e-05 | Valid Time: 0.017\n",
            "Epoch: 539\n",
            "Train Loss: 3.5875436974732255e-05 | Train Time: 0.178\n",
            "Valid Loss: 3.013990499312058e-05 | Valid Time: 0.016\n",
            "Epoch: 540\n",
            "Train Loss: 3.587914091583929e-05 | Train Time: 0.165\n",
            "Valid Loss: 3.273016955063213e-05 | Valid Time: 0.017\n",
            "Epoch: 541\n",
            "Train Loss: 3.59642238579813e-05 | Train Time: 0.184\n",
            "Valid Loss: 2.8553555694088573e-05 | Valid Time: 0.018\n",
            "Epoch: 542\n",
            "Train Loss: 3.567652665400314e-05 | Train Time: 0.183\n",
            "Valid Loss: 3.1450823371415026e-05 | Valid Time: 0.024\n",
            "Epoch: 543\n",
            "Train Loss: 3.57147045609676e-05 | Train Time: 0.173\n",
            "Valid Loss: 3.006422821272281e-05 | Valid Time: 0.018\n",
            "Epoch: 544\n",
            "Train Loss: 3.569359298700491e-05 | Train Time: 0.175\n",
            "Valid Loss: 3.8185023186088074e-05 | Valid Time: 0.018\n",
            "Epoch: 545\n",
            "Train Loss: 3.5966279220271024e-05 | Train Time: 0.208\n",
            "Valid Loss: 3.4492786653572693e-05 | Valid Time: 0.022\n",
            "Epoch: 546\n",
            "Train Loss: 3.564746054364246e-05 | Train Time: 0.176\n",
            "Valid Loss: 2.8018004059049417e-05 | Valid Time: 0.021\n",
            "Epoch: 547\n",
            "Train Loss: 3.57017076902067e-05 | Train Time: 0.184\n",
            "Valid Loss: 2.7798228757092147e-05 | Valid Time: 0.019\n",
            "Epoch: 548\n",
            "Train Loss: 3.546671484256972e-05 | Train Time: 0.172\n",
            "Valid Loss: 2.935210022769752e-05 | Valid Time: 0.012\n",
            "Epoch: 549\n",
            "Train Loss: 3.539327908105119e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.175488109263824e-05 | Valid Time: 0.012\n",
            "Epoch: 550\n",
            "Train Loss: 3.5416016161386656e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.6432537651999155e-05 | Valid Time: 0.011\n",
            "Epoch: 551\n",
            "Train Loss: 3.5314782316594285e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.7175140985491453e-05 | Valid Time: 0.011\n",
            "Epoch: 552\n",
            "Train Loss: 3.541000363551766e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.644340449682204e-05 | Valid Time: 0.018\n",
            "Epoch: 553\n",
            "Train Loss: 3.5376896592328865e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.0640595923614455e-05 | Valid Time: 0.011\n",
            "Epoch: 554\n",
            "Train Loss: 3.5357049407474206e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.7731586871814216e-05 | Valid Time: 0.011\n",
            "Epoch: 555\n",
            "Train Loss: 3.5313756598043256e-05 | Train Time: 0.126\n",
            "Valid Loss: 2.8159261546534253e-05 | Valid Time: 0.012\n",
            "Epoch: 556\n",
            "Train Loss: 3.527577169542814e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.353922693349887e-05 | Valid Time: 0.012\n",
            "Epoch: 557\n",
            "Train Loss: 3.531990171866614e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.7600878638622817e-05 | Valid Time: 0.011\n",
            "Epoch: 558\n",
            "Train Loss: 3.50185018760385e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.792561417663819e-05 | Valid Time: 0.011\n",
            "Epoch: 559\n",
            "Train Loss: 3.541543571229436e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.90669190690096e-05 | Valid Time: 0.011\n",
            "Epoch: 560\n",
            "Train Loss: 3.507089633402709e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.2413182452728506e-05 | Valid Time: 0.011\n",
            "Epoch: 561\n",
            "Train Loss: 3.499539659395324e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.6281163829698926e-05 | Valid Time: 0.012\n",
            "Epoch: 562\n",
            "Train Loss: 3.518635343138349e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.7877455977431964e-05 | Valid Time: 0.011\n",
            "Epoch: 563\n",
            "Train Loss: 3.513203572717765e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.0490921290038386e-05 | Valid Time: 0.013\n",
            "Epoch: 564\n",
            "Train Loss: 3.5040779900890284e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.774891683860915e-05 | Valid Time: 0.012\n",
            "Epoch: 565\n",
            "Train Loss: 3.497352056575963e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.7555062388273655e-05 | Valid Time: 0.011\n",
            "Epoch: 566\n",
            "Train Loss: 3.5124928265424004e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.0406574751395965e-05 | Valid Time: 0.011\n",
            "Epoch: 567\n",
            "Train Loss: 3.493523237059555e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.8956925689271884e-05 | Valid Time: 0.011\n",
            "Epoch: 568\n",
            "Train Loss: 3.494849787737047e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.6495573365536984e-05 | Valid Time: 0.011\n",
            "Epoch: 569\n",
            "Train Loss: 3.483506569816535e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.0835736652079504e-05 | Valid Time: 0.012\n",
            "Epoch: 570\n",
            "Train Loss: 3.47346950117131e-05 | Train Time: 0.126\n",
            "Valid Loss: 3.46794167853659e-05 | Valid Time: 0.011\n",
            "Epoch: 571\n",
            "Train Loss: 3.4811197397893444e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.063207850573235e-05 | Valid Time: 0.012\n",
            "Epoch: 572\n",
            "Train Loss: 3.480834560545382e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.2063584967545466e-05 | Valid Time: 0.011\n",
            "Epoch: 573\n",
            "Train Loss: 3.478091333052266e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.960125402751146e-05 | Valid Time: 0.011\n",
            "Epoch: 574\n",
            "Train Loss: 3.4669819988745364e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.9471998914232245e-05 | Valid Time: 0.011\n",
            "Epoch: 575\n",
            "Train Loss: 3.4519617608901554e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.889983215936809e-05 | Valid Time: 0.011\n",
            "Epoch: 576\n",
            "Train Loss: 3.462423075306058e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.6993093570126803e-05 | Valid Time: 0.013\n",
            "Epoch: 577\n",
            "Train Loss: 3.4589342344828e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.215062497474719e-05 | Valid Time: 0.011\n",
            "Epoch: 578\n",
            "Train Loss: 3.463779179774543e-05 | Train Time: 0.122\n",
            "Valid Loss: 2.844236860255478e-05 | Valid Time: 0.011\n",
            "Epoch: 579\n",
            "Train Loss: 3.4510684264731885e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.7450995503386366e-05 | Valid Time: 0.011\n",
            "Epoch: 580\n",
            "Train Loss: 3.4556756681444024e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.6850430003833026e-05 | Valid Time: 0.012\n",
            "Epoch: 581\n",
            "Train Loss: 3.4606733415306446e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.140449871352757e-05 | Valid Time: 0.012\n",
            "Epoch: 582\n",
            "Train Loss: 3.446974618495197e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.8032240606989944e-05 | Valid Time: 0.014\n",
            "Epoch: 583\n",
            "Train Loss: 3.4618018617038615e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.7784753001469653e-05 | Valid Time: 0.016\n",
            "Epoch: 584\n",
            "Train Loss: 3.4578314960909716e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.7196206929147593e-05 | Valid Time: 0.012\n",
            "Epoch: 585\n",
            "Train Loss: 3.430857836256588e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.7909559776162496e-05 | Valid Time: 0.011\n",
            "Epoch: 586\n",
            "Train Loss: 3.459926627233232e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.3806955343607115e-05 | Valid Time: 0.012\n",
            "Epoch: 587\n",
            "Train Loss: 3.4458461461901224e-05 | Train Time: 0.122\n",
            "Valid Loss: 2.771620484054438e-05 | Valid Time: 0.011\n",
            "Epoch: 588\n",
            "Train Loss: 3.421049548610187e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.797803153953282e-05 | Valid Time: 0.011\n",
            "Epoch: 589\n",
            "Train Loss: 3.4210176109857125e-05 | Train Time: 0.110\n",
            "Valid Loss: 3.1874946671450743e-05 | Valid Time: 0.011\n",
            "Epoch: 590\n",
            "Train Loss: 3.44221590287481e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.7156248961546225e-05 | Valid Time: 0.011\n",
            "Epoch: 591\n",
            "Train Loss: 3.4215903150126046e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.170632362525794e-05 | Valid Time: 0.011\n",
            "Epoch: 592\n",
            "Train Loss: 3.426875589770804e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.9126465051376726e-05 | Valid Time: 0.011\n",
            "Epoch: 593\n",
            "Train Loss: 3.435759773358433e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.6062001981918e-05 | Valid Time: 0.012\n",
            "Epoch: 594\n",
            "Train Loss: 3.431583182215323e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.5766472390387207e-05 | Valid Time: 0.011\n",
            "Epoch: 595\n",
            "Train Loss: 3.4315588077573155e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.9878619898227043e-05 | Valid Time: 0.011\n",
            "Epoch: 596\n",
            "Train Loss: 3.410127503325624e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.139605860269512e-05 | Valid Time: 0.013\n",
            "Epoch: 597\n",
            "Train Loss: 3.418599226279184e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.8471956284192856e-05 | Valid Time: 0.011\n",
            "Epoch: 598\n",
            "Train Loss: 3.404983516175937e-05 | Train Time: 0.108\n",
            "Valid Loss: 2.9077321414661128e-05 | Valid Time: 0.011\n",
            "Epoch: 599\n",
            "Train Loss: 3.4133481102272577e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.906821100623347e-05 | Valid Time: 0.011\n",
            "Epoch: 600\n",
            "Train Loss: 3.399097754721113e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.012639808730455e-05 | Valid Time: 0.011\n",
            "Epoch: 601\n",
            "Train Loss: 3.400434683211834e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.189067911080201e-05 | Valid Time: 0.021\n",
            "Epoch: 602\n",
            "Train Loss: 3.405430633344957e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.7521342417458072e-05 | Valid Time: 0.012\n",
            "Epoch: 603\n",
            "Train Loss: 3.42522845657138e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.5703449409775203e-05 | Valid Time: 0.011\n",
            "Epoch: 604\n",
            "Train Loss: 3.396912937827629e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.4922698432637844e-05 | Valid Time: 0.014\n",
            "Epoch: 605\n",
            "Train Loss: 3.4171492140893334e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.691602205435629e-05 | Valid Time: 0.012\n",
            "Epoch: 606\n",
            "Train Loss: 3.387985921826361e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.0155477361404337e-05 | Valid Time: 0.017\n",
            "Epoch: 607\n",
            "Train Loss: 3.395337061144681e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.232215567550156e-05 | Valid Time: 0.012\n",
            "Epoch: 608\n",
            "Train Loss: 3.3931154815179886e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.081277918681735e-05 | Valid Time: 0.011\n",
            "Epoch: 609\n",
            "Train Loss: 3.3844875360955484e-05 | Train Time: 0.130\n",
            "Valid Loss: 2.9188434382376727e-05 | Valid Time: 0.012\n",
            "Epoch: 610\n",
            "Train Loss: 3.384314502335129e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.7190746095584473e-05 | Valid Time: 0.011\n",
            "Epoch: 611\n",
            "Train Loss: 3.381583069552251e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.704238045225793e-05 | Valid Time: 0.011\n",
            "Epoch: 612\n",
            "Train Loss: 3.3806989641131e-05 | Train Time: 0.107\n",
            "Valid Loss: 3.129366496068542e-05 | Valid Time: 0.011\n",
            "Epoch: 613\n",
            "Train Loss: 3.4042758622825587e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.7318719276081538e-05 | Valid Time: 0.013\n",
            "Epoch: 614\n",
            "Train Loss: 3.3831040510497255e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.06383881252259e-05 | Valid Time: 0.014\n",
            "Epoch: 615\n",
            "Train Loss: 3.3840719736058656e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.975461277150316e-05 | Valid Time: 0.011\n",
            "Epoch: 616\n",
            "Train Loss: 3.3974116472803106e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.817178458120907e-05 | Valid Time: 0.011\n",
            "Epoch: 617\n",
            "Train Loss: 3.392659872540542e-05 | Train Time: 0.125\n",
            "Valid Loss: 3.4112415960407816e-05 | Valid Time: 0.012\n",
            "Epoch: 618\n",
            "Train Loss: 3.393192089692763e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.0366654300451046e-05 | Valid Time: 0.011\n",
            "Epoch: 619\n",
            "Train Loss: 3.368612344370616e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.147478037135443e-05 | Valid Time: 0.012\n",
            "Epoch: 620\n",
            "Train Loss: 3.386447669503181e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.0336924737639492e-05 | Valid Time: 0.011\n",
            "Epoch: 621\n",
            "Train Loss: 3.390668337631627e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.885020148823969e-05 | Valid Time: 0.012\n",
            "Epoch: 622\n",
            "Train Loss: 3.367270255694166e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.9892615657445276e-05 | Valid Time: 0.012\n",
            "Epoch: 623\n",
            "Train Loss: 3.378679895448793e-05 | Train Time: 0.125\n",
            "Valid Loss: 2.9227175673440797e-05 | Valid Time: 0.012\n",
            "Epoch: 624\n",
            "Train Loss: 3.372492047722182e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.337094130984042e-05 | Valid Time: 0.011\n",
            "Epoch: 625\n",
            "Train Loss: 3.3810943166731466e-05 | Train Time: 0.130\n",
            "Valid Loss: 2.9826162062818184e-05 | Valid Time: 0.020\n",
            "Epoch: 626\n",
            "Train Loss: 3.384107453472863e-05 | Train Time: 0.182\n",
            "Valid Loss: 2.5984624699049164e-05 | Valid Time: 0.016\n",
            "Epoch: 627\n",
            "Train Loss: 3.36083958245581e-05 | Train Time: 0.175\n",
            "Valid Loss: 2.6103994741788483e-05 | Valid Time: 0.017\n",
            "Epoch: 628\n",
            "Train Loss: 3.3759400570201446e-05 | Train Time: 0.171\n",
            "Valid Loss: 2.8998795187362703e-05 | Valid Time: 0.017\n",
            "Epoch: 629\n",
            "Train Loss: 3.3597996757874315e-05 | Train Time: 0.169\n",
            "Valid Loss: 3.211452303730766e-05 | Valid Time: 0.016\n",
            "Epoch: 630\n",
            "Train Loss: 3.3553378192377035e-05 | Train Time: 0.184\n",
            "Valid Loss: 2.8844765893154545e-05 | Valid Time: 0.023\n",
            "Epoch: 631\n",
            "Train Loss: 3.365463051427229e-05 | Train Time: 0.191\n",
            "Valid Loss: 2.669869400051539e-05 | Valid Time: 0.026\n",
            "Epoch: 632\n",
            "Train Loss: 3.363099695936973e-05 | Train Time: 0.168\n",
            "Valid Loss: 2.876126336559537e-05 | Valid Time: 0.016\n",
            "Epoch: 633\n",
            "Train Loss: 3.355313550089608e-05 | Train Time: 0.178\n",
            "Valid Loss: 3.292578048785799e-05 | Valid Time: 0.018\n",
            "Epoch: 634\n",
            "Train Loss: 3.3550356946714024e-05 | Train Time: 0.169\n",
            "Valid Loss: 3.0963584777055075e-05 | Valid Time: 0.017\n",
            "Epoch: 635\n",
            "Train Loss: 3.3646718101839435e-05 | Train Time: 0.182\n",
            "Valid Loss: 2.796170656438335e-05 | Valid Time: 0.019\n",
            "Epoch: 636\n",
            "Train Loss: 3.3344606555673585e-05 | Train Time: 0.185\n",
            "Valid Loss: 3.150383918182342e-05 | Valid Time: 0.024\n",
            "Epoch: 637\n",
            "Train Loss: 3.3537698407982184e-05 | Train Time: 0.174\n",
            "Valid Loss: 2.9688347694900585e-05 | Valid Time: 0.016\n",
            "Epoch: 638\n",
            "Train Loss: 3.3527290437823944e-05 | Train Time: 0.168\n",
            "Valid Loss: 3.0579487884097034e-05 | Valid Time: 0.011\n",
            "Epoch: 639\n",
            "Train Loss: 3.333899985591415e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.0062029964028625e-05 | Valid Time: 0.010\n",
            "Epoch: 640\n",
            "Train Loss: 3.3521251488740456e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.7512135602592025e-05 | Valid Time: 0.011\n",
            "Epoch: 641\n",
            "Train Loss: 3.35844336069912e-05 | Train Time: 0.107\n",
            "Valid Loss: 3.5602796288003447e-05 | Valid Time: 0.011\n",
            "Epoch: 642\n",
            "Train Loss: 3.3469578690863655e-05 | Train Time: 0.134\n",
            "Valid Loss: 3.874663752867491e-05 | Valid Time: 0.015\n",
            "Epoch: 643\n",
            "Train Loss: 3.3476282432705996e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.6329463480578852e-05 | Valid Time: 0.012\n",
            "Epoch: 644\n",
            "Train Loss: 3.3441565296686205e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.461505639279494e-05 | Valid Time: 0.011\n",
            "Epoch: 645\n",
            "Train Loss: 3.3370506475636686e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.958750676247291e-05 | Valid Time: 0.011\n",
            "Epoch: 646\n",
            "Train Loss: 3.3379031217344546e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.592321789052221e-05 | Valid Time: 0.011\n",
            "Epoch: 647\n",
            "Train Loss: 3.354655621622346e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.1218940421240404e-05 | Valid Time: 0.011\n",
            "Epoch: 648\n",
            "Train Loss: 3.3295956535240344e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.8510866286524106e-05 | Valid Time: 0.012\n",
            "Epoch: 649\n",
            "Train Loss: 3.327648683855506e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.5564744646544568e-05 | Valid Time: 0.011\n",
            "Epoch: 650\n",
            "Train Loss: 3.337318249625816e-05 | Train Time: 0.128\n",
            "Valid Loss: 3.0212335786927724e-05 | Valid Time: 0.011\n",
            "Epoch: 651\n",
            "Train Loss: 3.3335538319079205e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.6199712010566145e-05 | Valid Time: 0.016\n",
            "Epoch: 652\n",
            "Train Loss: 3.341052673165809e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.6293825612810906e-05 | Valid Time: 0.011\n",
            "Epoch: 653\n",
            "Train Loss: 3.3262531073169634e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.8301769816607703e-05 | Valid Time: 0.011\n",
            "Epoch: 654\n",
            "Train Loss: 3.322167092272522e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.6057093464260106e-05 | Valid Time: 0.012\n",
            "Epoch: 655\n",
            "Train Loss: 3.335277994521771e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.963443557746359e-05 | Valid Time: 0.011\n",
            "Epoch: 656\n",
            "Train Loss: 3.3343112878164426e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.0232631615945138e-05 | Valid Time: 0.011\n",
            "Epoch: 657\n",
            "Train Loss: 3.3105470433120467e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.5973575702664675e-05 | Valid Time: 0.011\n",
            "Epoch: 658\n",
            "Train Loss: 3.318678375906433e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.068647129111923e-05 | Valid Time: 0.012\n",
            "Epoch: 659\n",
            "Train Loss: 3.340636852188158e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.865192482204293e-05 | Valid Time: 0.015\n",
            "Epoch: 660\n",
            "Train Loss: 3.3325686768205886e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.8709326215903275e-05 | Valid Time: 0.012\n",
            "Epoch: 661\n",
            "Train Loss: 3.318998939281109e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.760267125268001e-05 | Valid Time: 0.011\n",
            "Epoch: 662\n",
            "Train Loss: 3.315435280551595e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.4929049888887675e-05 | Valid Time: 0.011\n",
            "Epoch: 663\n",
            "Train Loss: 3.328225772604224e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.6654384530265816e-05 | Valid Time: 0.012\n",
            "Epoch: 664\n",
            "Train Loss: 3.336178490012811e-05 | Train Time: 0.122\n",
            "Valid Loss: 2.8990748432988767e-05 | Valid Time: 0.011\n",
            "Epoch: 665\n",
            "Train Loss: 3.312602424749026e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.8876939722977113e-05 | Valid Time: 0.013\n",
            "Epoch: 666\n",
            "Train Loss: 3.319237619411739e-05 | Train Time: 0.132\n",
            "Valid Loss: 3.488516631477978e-05 | Valid Time: 0.011\n",
            "Epoch: 667\n",
            "Train Loss: 3.3111926122249936e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.052819874937995e-05 | Valid Time: 0.011\n",
            "Epoch: 668\n",
            "Train Loss: 3.3233703154684535e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.8608129923668457e-05 | Valid Time: 0.011\n",
            "Epoch: 669\n",
            "Train Loss: 3.311923491740967e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.544698074620101e-05 | Valid Time: 0.011\n",
            "Epoch: 670\n",
            "Train Loss: 3.311739362145186e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.8981069135625148e-05 | Valid Time: 0.012\n",
            "Epoch: 671\n",
            "Train Loss: 3.327991764404272e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.6025257739092922e-05 | Valid Time: 0.011\n",
            "Epoch: 672\n",
            "Train Loss: 3.309938457325763e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.318691551612574e-05 | Valid Time: 0.011\n",
            "Epoch: 673\n",
            "Train Loss: 3.3114358972709036e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.6497431463212706e-05 | Valid Time: 0.012\n",
            "Epoch: 674\n",
            "Train Loss: 3.3056438999330184e-05 | Train Time: 0.129\n",
            "Valid Loss: 3.222731356800068e-05 | Valid Time: 0.011\n",
            "Epoch: 675\n",
            "Train Loss: 3.313607971664935e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.785716560538276e-05 | Valid Time: 0.011\n",
            "Epoch: 676\n",
            "Train Loss: 3.308237003358571e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.686838251975132e-05 | Valid Time: 0.014\n",
            "Epoch: 677\n",
            "Train Loss: 3.316473033153574e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.5867689146252815e-05 | Valid Time: 0.015\n",
            "Epoch: 678\n",
            "Train Loss: 3.3148647976065005e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.5417258257220965e-05 | Valid Time: 0.012\n",
            "Epoch: 679\n",
            "Train Loss: 3.3073405766596186e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.115134586550994e-05 | Valid Time: 0.012\n",
            "Epoch: 680\n",
            "Train Loss: 3.303022305389229e-05 | Train Time: 0.137\n",
            "Valid Loss: 2.5815955723373918e-05 | Valid Time: 0.014\n",
            "Epoch: 681\n",
            "Train Loss: 3.301756441942416e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.109441468041041e-05 | Valid Time: 0.021\n",
            "Epoch: 682\n",
            "Train Loss: 3.316495071646243e-05 | Train Time: 0.138\n",
            "Valid Loss: 2.7589304409048054e-05 | Valid Time: 0.012\n",
            "Epoch: 683\n",
            "Train Loss: 3.298349551378602e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.8705700515274657e-05 | Valid Time: 0.011\n",
            "Epoch: 684\n",
            "Train Loss: 3.3045901976660583e-05 | Train Time: 0.132\n",
            "Valid Loss: 3.024194256795454e-05 | Valid Time: 0.012\n",
            "Epoch: 685\n",
            "Train Loss: 3.299479861820337e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.0422445888689253e-05 | Valid Time: 0.012\n",
            "Epoch: 686\n",
            "Train Loss: 3.291190401605012e-05 | Train Time: 0.129\n",
            "Valid Loss: 3.150763905068743e-05 | Valid Time: 0.012\n",
            "Epoch: 687\n",
            "Train Loss: 3.311534371613035e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.323717464809306e-05 | Valid Time: 0.011\n",
            "Epoch: 688\n",
            "Train Loss: 3.3153040069584294e-05 | Train Time: 0.131\n",
            "Valid Loss: 3.4579467410367215e-05 | Valid Time: 0.012\n",
            "Epoch: 689\n",
            "Train Loss: 3.309289748262687e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.5072078642551787e-05 | Valid Time: 0.011\n",
            "Epoch: 690\n",
            "Train Loss: 3.2919427547695755e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.810090538536315e-05 | Valid Time: 0.011\n",
            "Epoch: 691\n",
            "Train Loss: 3.288968563490351e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.5772309527383186e-05 | Valid Time: 0.013\n",
            "Epoch: 692\n",
            "Train Loss: 3.3004737384831775e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.1171935461316025e-05 | Valid Time: 0.012\n",
            "Epoch: 693\n",
            "Train Loss: 3.303499139100926e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.8948826638952596e-05 | Valid Time: 0.011\n",
            "Epoch: 694\n",
            "Train Loss: 3.301478864159435e-05 | Train Time: 0.138\n",
            "Valid Loss: 2.9283448839123594e-05 | Valid Time: 0.014\n",
            "Epoch: 695\n",
            "Train Loss: 3.312674944984457e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.721601797224139e-05 | Valid Time: 0.012\n",
            "Epoch: 696\n",
            "Train Loss: 3.2878526996539316e-05 | Train Time: 0.130\n",
            "Valid Loss: 2.8326882329565706e-05 | Valid Time: 0.011\n",
            "Epoch: 697\n",
            "Train Loss: 3.300968781236167e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.928656112999306e-05 | Valid Time: 0.011\n",
            "Epoch: 698\n",
            "Train Loss: 3.29927582865103e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.560742879926693e-05 | Valid Time: 0.012\n",
            "Epoch: 699\n",
            "Train Loss: 3.294815417719196e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.5283613922510995e-05 | Valid Time: 0.012\n",
            "Epoch: 700\n",
            "Train Loss: 3.293072615250774e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.6652949600247666e-05 | Valid Time: 0.012\n",
            "Epoch: 701\n",
            "Train Loss: 3.272511151551857e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.516100380489661e-05 | Valid Time: 0.016\n",
            "Epoch: 702\n",
            "Train Loss: 3.2936281633355015e-05 | Train Time: 0.132\n",
            "Valid Loss: 3.706258212332614e-05 | Valid Time: 0.012\n",
            "Epoch: 703\n",
            "Train Loss: 3.301241198833419e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.6086508341904846e-05 | Valid Time: 0.012\n",
            "Epoch: 704\n",
            "Train Loss: 3.285588948193962e-05 | Train Time: 0.133\n",
            "Valid Loss: 2.9966789043101016e-05 | Valid Time: 0.011\n",
            "Epoch: 705\n",
            "Train Loss: 3.323121717058759e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.0399661227420438e-05 | Valid Time: 0.012\n",
            "Epoch: 706\n",
            "Train Loss: 3.2937138760309226e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.9636521048814757e-05 | Valid Time: 0.015\n",
            "Epoch: 707\n",
            "Train Loss: 3.2799284254954395e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.554515253905265e-05 | Valid Time: 0.011\n",
            "Epoch: 708\n",
            "Train Loss: 3.2845530720231564e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.9807677037752e-05 | Valid Time: 0.011\n",
            "Epoch: 709\n",
            "Train Loss: 3.2914697122147406e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.056985815419466e-05 | Valid Time: 0.012\n",
            "Epoch: 710\n",
            "Train Loss: 3.284386548330076e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.9011406695644837e-05 | Valid Time: 0.012\n",
            "Epoch: 711\n",
            "Train Loss: 3.289953804740339e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.9436941531457705e-05 | Valid Time: 0.012\n",
            "Epoch: 712\n",
            "Train Loss: 3.2785895535581454e-05 | Train Time: 0.131\n",
            "Valid Loss: 2.7384561235521687e-05 | Valid Time: 0.013\n",
            "Epoch: 713\n",
            "Train Loss: 3.290873265589318e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.6143871056992793e-05 | Valid Time: 0.018\n",
            "Epoch: 714\n",
            "Train Loss: 3.2665216981274026e-05 | Train Time: 0.184\n",
            "Valid Loss: 2.788669235087582e-05 | Valid Time: 0.018\n",
            "Epoch: 715\n",
            "Train Loss: 3.282309195415828e-05 | Train Time: 0.173\n",
            "Valid Loss: 2.549971600274148e-05 | Valid Time: 0.017\n",
            "Epoch: 716\n",
            "Train Loss: 3.2789864091778565e-05 | Train Time: 0.186\n",
            "Valid Loss: 3.011371154570952e-05 | Valid Time: 0.016\n",
            "Epoch: 717\n",
            "Train Loss: 3.2839081349696865e-05 | Train Time: 0.177\n",
            "Valid Loss: 2.4650128807479632e-05 | Valid Time: 0.021\n",
            "Epoch: 718\n",
            "Train Loss: 3.2821742742702265e-05 | Train Time: 0.184\n",
            "Valid Loss: 2.599155618554505e-05 | Valid Time: 0.017\n",
            "Epoch: 719\n",
            "Train Loss: 3.261029891482873e-05 | Train Time: 0.182\n",
            "Valid Loss: 2.873190578611684e-05 | Valid Time: 0.017\n",
            "Epoch: 720\n",
            "Train Loss: 3.2781165971659664e-05 | Train Time: 0.176\n",
            "Valid Loss: 3.1354923521575984e-05 | Valid Time: 0.018\n",
            "Epoch: 721\n",
            "Train Loss: 3.275119802549996e-05 | Train Time: 0.181\n",
            "Valid Loss: 2.4387493112953962e-05 | Valid Time: 0.017\n",
            "Epoch: 722\n",
            "Train Loss: 3.273945740626292e-05 | Train Time: 0.169\n",
            "Valid Loss: 2.9625764000229537e-05 | Valid Time: 0.017\n",
            "Epoch: 723\n",
            "Train Loss: 3.270015057703284e-05 | Train Time: 0.176\n",
            "Valid Loss: 2.6378459324405412e-05 | Valid Time: 0.017\n",
            "Epoch: 724\n",
            "Train Loss: 3.269305249743507e-05 | Train Time: 0.177\n",
            "Valid Loss: 3.21058460031054e-05 | Valid Time: 0.017\n",
            "Epoch: 725\n",
            "Train Loss: 3.2715844530397784e-05 | Train Time: 0.174\n",
            "Valid Loss: 3.477161544651608e-05 | Valid Time: 0.018\n",
            "Epoch: 726\n",
            "Train Loss: 3.2767154870701854e-05 | Train Time: 0.181\n",
            "Valid Loss: 2.9779866508761188e-05 | Valid Time: 0.014\n",
            "Epoch: 727\n",
            "Train Loss: 3.2880002292681876e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.8305463729338953e-05 | Valid Time: 0.012\n",
            "Epoch: 728\n",
            "Train Loss: 3.282331406233808e-05 | Train Time: 0.107\n",
            "Valid Loss: 3.104664710917859e-05 | Valid Time: 0.011\n",
            "Epoch: 729\n",
            "Train Loss: 3.261504954073309e-05 | Train Time: 0.135\n",
            "Valid Loss: 3.1478924029215705e-05 | Valid Time: 0.013\n",
            "Epoch: 730\n",
            "Train Loss: 3.271273348410001e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.5523195290588774e-05 | Valid Time: 0.012\n",
            "Epoch: 731\n",
            "Train Loss: 3.262951261268953e-05 | Train Time: 0.138\n",
            "Valid Loss: 3.091009830313851e-05 | Valid Time: 0.011\n",
            "Epoch: 732\n",
            "Train Loss: 3.251508582922581e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.5781259409995982e-05 | Valid Time: 0.011\n",
            "Epoch: 733\n",
            "Train Loss: 3.280601059055985e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.007527311638114e-05 | Valid Time: 0.011\n",
            "Epoch: 734\n",
            "Train Loss: 3.267280877289044e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.5271974664065056e-05 | Valid Time: 0.011\n",
            "Epoch: 735\n",
            "Train Loss: 3.270082992170692e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.570139781710168e-05 | Valid Time: 0.011\n",
            "Epoch: 736\n",
            "Train Loss: 3.283779235636374e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.9055147024337202e-05 | Valid Time: 0.011\n",
            "Epoch: 737\n",
            "Train Loss: 3.275388859803666e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.7854284780914895e-05 | Valid Time: 0.011\n",
            "Epoch: 738\n",
            "Train Loss: 3.2624208535325074e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.7973165288130986e-05 | Valid Time: 0.011\n",
            "Epoch: 739\n",
            "Train Loss: 3.2890005298357116e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.0262563996075187e-05 | Valid Time: 0.011\n",
            "Epoch: 740\n",
            "Train Loss: 3.26516238649339e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.522124214010546e-05 | Valid Time: 0.011\n",
            "Epoch: 741\n",
            "Train Loss: 3.256008303172788e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.005918006238062e-05 | Valid Time: 0.011\n",
            "Epoch: 742\n",
            "Train Loss: 3.249817650373045e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.6160944798903074e-05 | Valid Time: 0.011\n",
            "Epoch: 743\n",
            "Train Loss: 3.2610972898270885e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.5116723463725066e-05 | Valid Time: 0.011\n",
            "Epoch: 744\n",
            "Train Loss: 3.251490000509779e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.9214528694865294e-05 | Valid Time: 0.011\n",
            "Epoch: 745\n",
            "Train Loss: 3.265218411367019e-05 | Train Time: 0.136\n",
            "Valid Loss: 2.6215591105938074e-05 | Valid Time: 0.012\n",
            "Epoch: 746\n",
            "Train Loss: 3.279036326076541e-05 | Train Time: 0.115\n",
            "Valid Loss: 4.343019600128173e-05 | Valid Time: 0.012\n",
            "Epoch: 747\n",
            "Train Loss: 3.280577967464189e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.7553990548767615e-05 | Valid Time: 0.011\n",
            "Epoch: 748\n",
            "Train Loss: 3.2661091321834214e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.838797627191525e-05 | Valid Time: 0.012\n",
            "Epoch: 749\n",
            "Train Loss: 3.250191586726272e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.757684160314966e-05 | Valid Time: 0.011\n",
            "Epoch: 750\n",
            "Train Loss: 3.2580163525907614e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.3878086469485424e-05 | Valid Time: 0.012\n",
            "Epoch: 751\n",
            "Train Loss: 3.258291230610523e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.082356033701217e-05 | Valid Time: 0.012\n",
            "Epoch: 752\n",
            "Train Loss: 3.2670511676482614e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.706183977352339e-05 | Valid Time: 0.017\n",
            "Epoch: 753\n",
            "Train Loss: 3.243732183028968e-05 | Train Time: 0.125\n",
            "Valid Loss: 2.428581001368002e-05 | Valid Time: 0.013\n",
            "Epoch: 754\n",
            "Train Loss: 3.256391449356574e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.4457832498446805e-05 | Valid Time: 0.011\n",
            "Epoch: 755\n",
            "Train Loss: 3.259293187415766e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.452851115071098e-05 | Valid Time: 0.016\n",
            "Epoch: 756\n",
            "Train Loss: 3.269957951009641e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.3914231607923284e-05 | Valid Time: 0.011\n",
            "Epoch: 757\n",
            "Train Loss: 3.2566779114667475e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.015056972799357e-05 | Valid Time: 0.011\n",
            "Epoch: 758\n",
            "Train Loss: 3.253368097495312e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.128473326796666e-05 | Valid Time: 0.012\n",
            "Epoch: 759\n",
            "Train Loss: 3.259373356980321e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.9639706099260366e-05 | Valid Time: 0.013\n",
            "Epoch: 760\n",
            "Train Loss: 3.264009539730308e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.5163277996398392e-05 | Valid Time: 0.015\n",
            "Epoch: 761\n",
            "Train Loss: 3.26043209497584e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.0985603643785e-05 | Valid Time: 0.011\n",
            "Epoch: 762\n",
            "Train Loss: 3.258187940733287e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.618904250084597e-05 | Valid Time: 0.011\n",
            "Epoch: 763\n",
            "Train Loss: 3.2616735935382744e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.5511820922474726e-05 | Valid Time: 0.013\n",
            "Epoch: 764\n",
            "Train Loss: 3.256479957551499e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.995359227497829e-05 | Valid Time: 0.016\n",
            "Epoch: 765\n",
            "Train Loss: 3.249468557585619e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.079479256484774e-05 | Valid Time: 0.011\n",
            "Epoch: 766\n",
            "Train Loss: 3.256879522508059e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.651852673807298e-05 | Valid Time: 0.017\n",
            "Epoch: 767\n",
            "Train Loss: 3.2606003945769966e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.475416906439932e-05 | Valid Time: 0.011\n",
            "Epoch: 768\n",
            "Train Loss: 3.2593261111239704e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.2287165595334955e-05 | Valid Time: 0.011\n",
            "Epoch: 769\n",
            "Train Loss: 3.256230382631704e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.617608697619289e-05 | Valid Time: 0.011\n",
            "Epoch: 770\n",
            "Train Loss: 3.2612091576754066e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.82598316516669e-05 | Valid Time: 0.011\n",
            "Epoch: 771\n",
            "Train Loss: 3.2405977675041774e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.2519242267881054e-05 | Valid Time: 0.011\n",
            "Epoch: 772\n",
            "Train Loss: 3.278475924162194e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.8116213343309937e-05 | Valid Time: 0.011\n",
            "Epoch: 773\n",
            "Train Loss: 3.240118674416168e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.622197325763409e-05 | Valid Time: 0.011\n",
            "Epoch: 774\n",
            "Train Loss: 3.262675923715027e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.5471253795549273e-05 | Valid Time: 0.012\n",
            "Epoch: 775\n",
            "Train Loss: 3.255753031944072e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.9781607736367732e-05 | Valid Time: 0.011\n",
            "Epoch: 776\n",
            "Train Loss: 3.2474968688084595e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.231055507058045e-05 | Valid Time: 0.011\n",
            "Epoch: 777\n",
            "Train Loss: 3.245118789077663e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.9148005978640867e-05 | Valid Time: 0.012\n",
            "Epoch: 778\n",
            "Train Loss: 3.262723973756166e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.2034569812822156e-05 | Valid Time: 0.013\n",
            "Epoch: 779\n",
            "Train Loss: 3.2665685993331286e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.5413900175408344e-05 | Valid Time: 0.011\n",
            "Epoch: 780\n",
            "Train Loss: 3.261266379252591e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.573778442638286e-05 | Valid Time: 0.013\n",
            "Epoch: 781\n",
            "Train Loss: 3.262522037211487e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.9730080314038787e-05 | Valid Time: 0.014\n",
            "Epoch: 782\n",
            "Train Loss: 3.24565685571686e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.227369325031759e-05 | Valid Time: 0.012\n",
            "Epoch: 783\n",
            "Train Loss: 3.243374895215598e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.9970570722070988e-05 | Valid Time: 0.012\n",
            "Epoch: 784\n",
            "Train Loss: 3.2656882850508405e-05 | Train Time: 0.131\n",
            "Valid Loss: 2.514866446290398e-05 | Valid Time: 0.011\n",
            "Epoch: 785\n",
            "Train Loss: 3.23954822019196e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.86029962808243e-05 | Valid Time: 0.011\n",
            "Epoch: 786\n",
            "Train Loss: 3.256048636869405e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.9622362944792258e-05 | Valid Time: 0.011\n",
            "Epoch: 787\n",
            "Train Loss: 3.245403594950116e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.9231079679448158e-05 | Valid Time: 0.012\n",
            "Epoch: 788\n",
            "Train Loss: 3.250222710592329e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.9143729989300482e-05 | Valid Time: 0.012\n",
            "Epoch: 789\n",
            "Train Loss: 3.258235722712829e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.4751988348725718e-05 | Valid Time: 0.012\n",
            "Epoch: 790\n",
            "Train Loss: 3.25829425587711e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.4945739824033808e-05 | Valid Time: 0.012\n",
            "Epoch: 791\n",
            "Train Loss: 3.251561774002192e-05 | Train Time: 0.126\n",
            "Valid Loss: 2.486733296791499e-05 | Valid Time: 0.012\n",
            "Epoch: 792\n",
            "Train Loss: 3.2495934072741016e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.741076150414301e-05 | Valid Time: 0.011\n",
            "Epoch: 793\n",
            "Train Loss: 3.2409451370384836e-05 | Train Time: 0.125\n",
            "Valid Loss: 3.3456270102760755e-05 | Valid Time: 0.012\n",
            "Epoch: 794\n",
            "Train Loss: 3.2582026745474556e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.4935433657446993e-05 | Valid Time: 0.011\n",
            "Epoch: 795\n",
            "Train Loss: 3.245905856218949e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.4731365101615665e-05 | Valid Time: 0.011\n",
            "Epoch: 796\n",
            "Train Loss: 3.245201792436235e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.128891557935276e-05 | Valid Time: 0.011\n",
            "Epoch: 797\n",
            "Train Loss: 3.240604114819833e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.5189378902723547e-05 | Valid Time: 0.012\n",
            "Epoch: 798\n",
            "Train Loss: 3.243613891275967e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.7229712941334583e-05 | Valid Time: 0.012\n",
            "Epoch: 799\n",
            "Train Loss: 3.258620955947615e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.062833820877131e-05 | Valid Time: 0.012\n",
            "Epoch: 800\n",
            "Train Loss: 3.2512420626804474e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.7957246857113205e-05 | Valid Time: 0.011\n",
            "Epoch: 801\n",
            "Train Loss: 3.2328915327333994e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.294380121587892e-05 | Valid Time: 0.011\n",
            "Epoch: 802\n",
            "Train Loss: 3.2490099520624715e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.758529101105523e-05 | Valid Time: 0.012\n",
            "Epoch: 803\n",
            "Train Loss: 3.241286724101213e-05 | Train Time: 0.147\n",
            "Valid Loss: 2.943738581961952e-05 | Valid Time: 0.018\n",
            "Epoch: 804\n",
            "Train Loss: 3.2571601542785124e-05 | Train Time: 0.185\n",
            "Valid Loss: 3.4052980481646955e-05 | Valid Time: 0.029\n",
            "Epoch: 805\n",
            "Train Loss: 3.2505016478305484e-05 | Train Time: 0.170\n",
            "Valid Loss: 3.397630007384578e-05 | Valid Time: 0.017\n",
            "Epoch: 806\n",
            "Train Loss: 3.26372838141029e-05 | Train Time: 0.193\n",
            "Valid Loss: 2.510838976377272e-05 | Valid Time: 0.017\n",
            "Epoch: 807\n",
            "Train Loss: 3.2405481569616025e-05 | Train Time: 0.169\n",
            "Valid Loss: 2.7252619020146085e-05 | Valid Time: 0.019\n",
            "Epoch: 808\n",
            "Train Loss: 3.239097331013334e-05 | Train Time: 0.183\n",
            "Valid Loss: 2.950091948150657e-05 | Valid Time: 0.019\n",
            "Epoch: 809\n",
            "Train Loss: 3.242181963670239e-05 | Train Time: 0.181\n",
            "Valid Loss: 2.736379246925935e-05 | Valid Time: 0.025\n",
            "Epoch: 810\n",
            "Train Loss: 3.242658950559991e-05 | Train Time: 0.172\n",
            "Valid Loss: 2.693662054298329e-05 | Valid Time: 0.017\n",
            "Epoch: 811\n",
            "Train Loss: 3.238646470555594e-05 | Train Time: 0.175\n",
            "Valid Loss: 2.6594776954880217e-05 | Valid Time: 0.016\n",
            "Epoch: 812\n",
            "Train Loss: 3.2422350111454235e-05 | Train Time: 0.171\n",
            "Valid Loss: 2.6913618967228103e-05 | Valid Time: 0.016\n",
            "Epoch: 813\n",
            "Train Loss: 3.2611116598433765e-05 | Train Time: 0.181\n",
            "Valid Loss: 3.5390730317885755e-05 | Valid Time: 0.022\n",
            "Epoch: 814\n",
            "Train Loss: 3.2413045406237394e-05 | Train Time: 0.183\n",
            "Valid Loss: 2.802753988362383e-05 | Valid Time: 0.020\n",
            "Epoch: 815\n",
            "Train Loss: 3.248770467747052e-05 | Train Time: 0.193\n",
            "Valid Loss: 2.9035386887699133e-05 | Valid Time: 0.019\n",
            "Epoch: 816\n",
            "Train Loss: 3.245766598219665e-05 | Train Time: 0.174\n",
            "Valid Loss: 2.965586236314266e-05 | Valid Time: 0.012\n",
            "Epoch: 817\n",
            "Train Loss: 3.241433669724134e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.2512290999875404e-05 | Valid Time: 0.011\n",
            "Epoch: 818\n",
            "Train Loss: 3.250050892682722e-05 | Train Time: 0.107\n",
            "Valid Loss: 2.6022095880762208e-05 | Valid Time: 0.011\n",
            "Epoch: 819\n",
            "Train Loss: 3.240239062793798e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.4460161398565106e-05 | Valid Time: 0.011\n",
            "Epoch: 820\n",
            "Train Loss: 3.24159046661072e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.878729376083356e-05 | Valid Time: 0.012\n",
            "Epoch: 821\n",
            "Train Loss: 3.255383518607184e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.9434047064569313e-05 | Valid Time: 0.012\n",
            "Epoch: 822\n",
            "Train Loss: 3.2319157885228234e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.9626433843077393e-05 | Valid Time: 0.012\n",
            "Epoch: 823\n",
            "Train Loss: 3.238707109918132e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.6189318305114284e-05 | Valid Time: 0.011\n",
            "Epoch: 824\n",
            "Train Loss: 3.2418522479067755e-05 | Train Time: 0.135\n",
            "Valid Loss: 3.121117561022402e-05 | Valid Time: 0.011\n",
            "Epoch: 825\n",
            "Train Loss: 3.240043588448316e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.550957833591383e-05 | Valid Time: 0.011\n",
            "Epoch: 826\n",
            "Train Loss: 3.254335819005255e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.6100270133611048e-05 | Valid Time: 0.012\n",
            "Epoch: 827\n",
            "Train Loss: 3.2374031051356146e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.4596819002908887e-05 | Valid Time: 0.011\n",
            "Epoch: 828\n",
            "Train Loss: 3.2586456367617324e-05 | Train Time: 0.107\n",
            "Valid Loss: 3.418450387471239e-05 | Valid Time: 0.011\n",
            "Epoch: 829\n",
            "Train Loss: 3.245293603532972e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.894678093274706e-05 | Valid Time: 0.014\n",
            "Epoch: 830\n",
            "Train Loss: 3.235805783524962e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.3066983178287046e-05 | Valid Time: 0.013\n",
            "Epoch: 831\n",
            "Train Loss: 3.2400095924937266e-05 | Train Time: 0.125\n",
            "Valid Loss: 2.979262490043766e-05 | Valid Time: 0.011\n",
            "Epoch: 832\n",
            "Train Loss: 3.245622783173243e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.542862668837188e-05 | Valid Time: 0.011\n",
            "Epoch: 833\n",
            "Train Loss: 3.2425669575643136e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.0216079721867573e-05 | Valid Time: 0.014\n",
            "Epoch: 834\n",
            "Train Loss: 3.239429047665142e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.846974166459404e-05 | Valid Time: 0.011\n",
            "Epoch: 835\n",
            "Train Loss: 3.252540888129979e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.9045925202808576e-05 | Valid Time: 0.011\n",
            "Epoch: 836\n",
            "Train Loss: 3.2244655238556384e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.61998170572042e-05 | Valid Time: 0.011\n",
            "Epoch: 837\n",
            "Train Loss: 3.257921027972387e-05 | Train Time: 0.125\n",
            "Valid Loss: 3.28408596033114e-05 | Valid Time: 0.012\n",
            "Epoch: 838\n",
            "Train Loss: 3.2317425249953214e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.10441610054113e-05 | Valid Time: 0.012\n",
            "Epoch: 839\n",
            "Train Loss: 3.228579828972119e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.9359719721687725e-05 | Valid Time: 0.012\n",
            "Epoch: 840\n",
            "Train Loss: 3.228442265505069e-05 | Train Time: 0.116\n",
            "Valid Loss: 4.1900350424839417e-05 | Valid Time: 0.011\n",
            "Epoch: 841\n",
            "Train Loss: 3.228475428553984e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.261654228481348e-05 | Valid Time: 0.013\n",
            "Epoch: 842\n",
            "Train Loss: 3.2302988888420115e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.585191759862937e-05 | Valid Time: 0.012\n",
            "Epoch: 843\n",
            "Train Loss: 3.235442684519129e-05 | Train Time: 0.115\n",
            "Valid Loss: 2.997571118612541e-05 | Valid Time: 0.013\n",
            "Epoch: 844\n",
            "Train Loss: 3.237835191707985e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.803448023769306e-05 | Valid Time: 0.012\n",
            "Epoch: 845\n",
            "Train Loss: 3.218929879566483e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.153503212161013e-05 | Valid Time: 0.013\n",
            "Epoch: 846\n",
            "Train Loss: 3.223235389190162e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.943485560535919e-05 | Valid Time: 0.011\n",
            "Epoch: 847\n",
            "Train Loss: 3.247622245046506e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.338218630233314e-05 | Valid Time: 0.019\n",
            "Epoch: 848\n",
            "Train Loss: 3.22982195939403e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.9573692700068932e-05 | Valid Time: 0.012\n",
            "Epoch: 849\n",
            "Train Loss: 3.2506147315296785e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.958316190415644e-05 | Valid Time: 0.011\n",
            "Epoch: 850\n",
            "Train Loss: 3.237801521256762e-05 | Train Time: 0.115\n",
            "Valid Loss: 3.711278304763255e-05 | Valid Time: 0.011\n",
            "Epoch: 851\n",
            "Train Loss: 3.225963892442738e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.831573192452197e-05 | Valid Time: 0.011\n",
            "Epoch: 852\n",
            "Train Loss: 3.2341015627791515e-05 | Train Time: 0.112\n",
            "Valid Loss: 3.2614689644105965e-05 | Valid Time: 0.012\n",
            "Epoch: 853\n",
            "Train Loss: 3.23914521830279e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.463950952209416e-05 | Valid Time: 0.012\n",
            "Epoch: 854\n",
            "Train Loss: 3.2322820851205557e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.229839330742834e-05 | Valid Time: 0.011\n",
            "Epoch: 855\n",
            "Train Loss: 3.235785544874441e-05 | Train Time: 0.131\n",
            "Valid Loss: 2.428058019177115e-05 | Valid Time: 0.011\n",
            "Epoch: 856\n",
            "Train Loss: 3.221864866837246e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.9381432341324398e-05 | Valid Time: 0.011\n",
            "Epoch: 857\n",
            "Train Loss: 3.2467238174592095e-05 | Train Time: 0.128\n",
            "Valid Loss: 3.0617316497227876e-05 | Valid Time: 0.012\n",
            "Epoch: 858\n",
            "Train Loss: 3.2240510814804826e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.6572616206976818e-05 | Valid Time: 0.011\n",
            "Epoch: 859\n",
            "Train Loss: 3.2239929887031106e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.873002222258947e-05 | Valid Time: 0.011\n",
            "Epoch: 860\n",
            "Train Loss: 3.222043855394555e-05 | Train Time: 0.108\n",
            "Valid Loss: 2.9851638373656897e-05 | Valid Time: 0.011\n",
            "Epoch: 861\n",
            "Train Loss: 3.23795719802882e-05 | Train Time: 0.126\n",
            "Valid Loss: 2.6106337827513926e-05 | Valid Time: 0.011\n",
            "Epoch: 862\n",
            "Train Loss: 3.2266168330495836e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.493833130756684e-05 | Valid Time: 0.011\n",
            "Epoch: 863\n",
            "Train Loss: 3.242401860341871e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.8832622774643824e-05 | Valid Time: 0.013\n",
            "Epoch: 864\n",
            "Train Loss: 3.225787699384933e-05 | Train Time: 0.117\n",
            "Valid Loss: 4.1746370243345154e-05 | Valid Time: 0.011\n",
            "Epoch: 865\n",
            "Train Loss: 3.2566446909760616e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.9956386242702138e-05 | Valid Time: 0.011\n",
            "Epoch: 866\n",
            "Train Loss: 3.2411616542192766e-05 | Train Time: 0.114\n",
            "Valid Loss: 2.77030585493776e-05 | Valid Time: 0.011\n",
            "Epoch: 867\n",
            "Train Loss: 3.233633536805619e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.21864113175252e-05 | Valid Time: 0.011\n",
            "Epoch: 868\n",
            "Train Loss: 3.2433581605130856e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.276344386904384e-05 | Valid Time: 0.012\n",
            "Epoch: 869\n",
            "Train Loss: 3.224619544389976e-05 | Train Time: 0.116\n",
            "Valid Loss: 3.8312363813020056e-05 | Valid Time: 0.011\n",
            "Epoch: 870\n",
            "Train Loss: 3.2171104880705426e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.6263522613589885e-05 | Valid Time: 0.011\n",
            "Epoch: 871\n",
            "Train Loss: 3.2475487291537176e-05 | Train Time: 0.131\n",
            "Valid Loss: 3.398709577595582e-05 | Valid Time: 0.011\n",
            "Epoch: 872\n",
            "Train Loss: 3.2341643849289734e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.9149876354495063e-05 | Valid Time: 0.014\n",
            "Epoch: 873\n",
            "Train Loss: 3.2153501658620754e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.332449114168412e-05 | Valid Time: 0.011\n",
            "Epoch: 874\n",
            "Train Loss: 3.227366754512523e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.6711296868597856e-05 | Valid Time: 0.014\n",
            "Epoch: 875\n",
            "Train Loss: 3.229071138010017e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.6421061193104833e-05 | Valid Time: 0.012\n",
            "Epoch: 876\n",
            "Train Loss: 3.229576252220125e-05 | Train Time: 0.122\n",
            "Valid Loss: 2.500862910892465e-05 | Valid Time: 0.011\n",
            "Epoch: 877\n",
            "Train Loss: 3.228891785654827e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.6846432319871383e-05 | Valid Time: 0.012\n",
            "Epoch: 878\n",
            "Train Loss: 3.235572723114226e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.9269710921653314e-05 | Valid Time: 0.013\n",
            "Epoch: 879\n",
            "Train Loss: 3.2319832443088094e-05 | Train Time: 0.127\n",
            "Valid Loss: 3.415144010432414e-05 | Valid Time: 0.012\n",
            "Epoch: 880\n",
            "Train Loss: 3.214151375256111e-05 | Train Time: 0.108\n",
            "Valid Loss: 2.734126064751763e-05 | Valid Time: 0.012\n",
            "Epoch: 881\n",
            "Train Loss: 3.2218427230346656e-05 | Train Time: 0.124\n",
            "Valid Loss: 3.158973413519561e-05 | Valid Time: 0.013\n",
            "Epoch: 882\n",
            "Train Loss: 3.222766817519809e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.5514028948236955e-05 | Valid Time: 0.011\n",
            "Epoch: 883\n",
            "Train Loss: 3.240249019367375e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.691795179998735e-05 | Valid Time: 0.013\n",
            "Epoch: 884\n",
            "Train Loss: 3.21776808146081e-05 | Train Time: 0.114\n",
            "Valid Loss: 3.173886807417148e-05 | Valid Time: 0.011\n",
            "Epoch: 885\n",
            "Train Loss: 3.230508876808208e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.8936823127878597e-05 | Valid Time: 0.012\n",
            "Epoch: 886\n",
            "Train Loss: 3.234132504746269e-05 | Train Time: 0.109\n",
            "Valid Loss: 3.387445121916244e-05 | Valid Time: 0.016\n",
            "Epoch: 887\n",
            "Train Loss: 3.223396714403e-05 | Train Time: 0.121\n",
            "Valid Loss: 3.057579579035519e-05 | Valid Time: 0.012\n",
            "Epoch: 888\n",
            "Train Loss: 3.258853700428613e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.9686064408451784e-05 | Valid Time: 0.014\n",
            "Epoch: 889\n",
            "Train Loss: 3.2506018167049133e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.1806170227355324e-05 | Valid Time: 0.012\n",
            "Epoch: 890\n",
            "Train Loss: 3.22035782454278e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.7737460641219513e-05 | Valid Time: 0.013\n",
            "Epoch: 891\n",
            "Train Loss: 3.230928891035115e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.5370118464707048e-05 | Valid Time: 0.013\n",
            "Epoch: 892\n",
            "Train Loss: 3.240227411687987e-05 | Train Time: 0.129\n",
            "Valid Loss: 3.221704128009151e-05 | Valid Time: 0.017\n",
            "Epoch: 893\n",
            "Train Loss: 3.241516634788193e-05 | Train Time: 0.178\n",
            "Valid Loss: 2.763152633633581e-05 | Valid Time: 0.017\n",
            "Epoch: 894\n",
            "Train Loss: 3.21376310718111e-05 | Train Time: 0.183\n",
            "Valid Loss: 2.78018337667163e-05 | Valid Time: 0.021\n",
            "Epoch: 895\n",
            "Train Loss: 3.2497698109517315e-05 | Train Time: 0.173\n",
            "Valid Loss: 3.0050819987081923e-05 | Valid Time: 0.017\n",
            "Epoch: 896\n",
            "Train Loss: 3.227367788464395e-05 | Train Time: 0.176\n",
            "Valid Loss: 2.9286306471476564e-05 | Valid Time: 0.017\n",
            "Epoch: 897\n",
            "Train Loss: 3.2299379917707195e-05 | Train Time: 0.168\n",
            "Valid Loss: 2.5278225393776665e-05 | Valid Time: 0.016\n",
            "Epoch: 898\n",
            "Train Loss: 3.2299161734715054e-05 | Train Time: 0.184\n",
            "Valid Loss: 3.2965082937153056e-05 | Valid Time: 0.020\n",
            "Epoch: 899\n",
            "Train Loss: 3.240775166839165e-05 | Train Time: 0.174\n",
            "Valid Loss: 2.485003824403975e-05 | Valid Time: 0.017\n",
            "Epoch: 900\n",
            "Train Loss: 3.221352658568465e-05 | Train Time: 0.170\n",
            "Valid Loss: 3.0506582334055565e-05 | Valid Time: 0.016\n",
            "Epoch: 901\n",
            "Train Loss: 3.219878090021666e-05 | Train Time: 0.172\n",
            "Valid Loss: 3.3512479149067076e-05 | Valid Time: 0.017\n",
            "Epoch: 902\n",
            "Train Loss: 3.216193008962651e-05 | Train Time: 0.182\n",
            "Valid Loss: 2.7716829663404496e-05 | Valid Time: 0.017\n",
            "Epoch: 903\n",
            "Train Loss: 3.2203246519202366e-05 | Train Time: 0.190\n",
            "Valid Loss: 2.545127290431992e-05 | Valid Time: 0.024\n",
            "Epoch: 904\n",
            "Train Loss: 3.2281148761333165e-05 | Train Time: 0.183\n",
            "Valid Loss: 2.8666927846643375e-05 | Valid Time: 0.020\n",
            "Epoch: 905\n",
            "Train Loss: 3.2208889215804736e-05 | Train Time: 0.183\n",
            "Valid Loss: 2.9058645395707572e-05 | Valid Time: 0.011\n",
            "Epoch: 906\n",
            "Train Loss: 3.2142999388222384e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.513814047233609e-05 | Valid Time: 0.011\n",
            "Epoch: 907\n",
            "Train Loss: 3.222721093870381e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.5873054912372027e-05 | Valid Time: 0.011\n",
            "Epoch: 908\n",
            "Train Loss: 3.210579531074281e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.88174260276719e-05 | Valid Time: 0.018\n",
            "Epoch: 909\n",
            "Train Loss: 3.2434395459284515e-05 | Train Time: 0.107\n",
            "Valid Loss: 2.49454917593539e-05 | Valid Time: 0.012\n",
            "Epoch: 910\n",
            "Train Loss: 3.213978523394632e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.493130523362197e-05 | Valid Time: 0.011\n",
            "Epoch: 911\n",
            "Train Loss: 3.212349465205702e-05 | Train Time: 0.130\n",
            "Valid Loss: 2.8240978281246498e-05 | Valid Time: 0.014\n",
            "Epoch: 912\n",
            "Train Loss: 3.2230956333621995e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.3626921776885865e-05 | Valid Time: 0.011\n",
            "Epoch: 913\n",
            "Train Loss: 3.241674944308072e-05 | Train Time: 0.113\n",
            "Valid Loss: 3.392138205526862e-05 | Valid Time: 0.011\n",
            "Epoch: 914\n",
            "Train Loss: 3.233176788566389e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.4729399228817783e-05 | Valid Time: 0.011\n",
            "Epoch: 915\n",
            "Train Loss: 3.22228171219314e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.670687217687373e-05 | Valid Time: 0.012\n",
            "Epoch: 916\n",
            "Train Loss: 3.2112907750783246e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.9673896733584115e-05 | Valid Time: 0.012\n",
            "Epoch: 917\n",
            "Train Loss: 3.213129246815745e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.499959123269946e-05 | Valid Time: 0.012\n",
            "Epoch: 918\n",
            "Train Loss: 3.219573983714279e-05 | Train Time: 0.123\n",
            "Valid Loss: 2.6499836621951545e-05 | Valid Time: 0.012\n",
            "Epoch: 919\n",
            "Train Loss: 3.2318294822624394e-05 | Train Time: 0.129\n",
            "Valid Loss: 2.5078582439164165e-05 | Valid Time: 0.015\n",
            "Epoch: 920\n",
            "Train Loss: 3.221922040546289e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.7721353944798466e-05 | Valid Time: 0.012\n",
            "Epoch: 921\n",
            "Train Loss: 3.222390420744073e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.5514358640066348e-05 | Valid Time: 0.017\n",
            "Epoch: 922\n",
            "Train Loss: 3.239907212111192e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.9872589493606938e-05 | Valid Time: 0.013\n",
            "Epoch: 923\n",
            "Train Loss: 3.222946179448627e-05 | Train Time: 0.111\n",
            "Valid Loss: 3.114372339041438e-05 | Valid Time: 0.011\n",
            "Epoch: 924\n",
            "Train Loss: 3.234074287511727e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.503068708392675e-05 | Valid Time: 0.013\n",
            "Epoch: 925\n",
            "Train Loss: 3.2269247113665765e-05 | Train Time: 0.109\n",
            "Valid Loss: 2.9452030048560118e-05 | Valid Time: 0.013\n",
            "Epoch: 926\n",
            "Train Loss: 3.204875840885123e-05 | Train Time: 0.124\n",
            "Valid Loss: 2.7531291380000766e-05 | Valid Time: 0.012\n",
            "Epoch: 927\n",
            "Train Loss: 3.21191027500103e-05 | Train Time: 0.133\n",
            "Valid Loss: 2.606901034596376e-05 | Valid Time: 0.011\n",
            "Epoch: 928\n",
            "Train Loss: 3.217892174832645e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.5414686888325377e-05 | Valid Time: 0.011\n",
            "Epoch: 929\n",
            "Train Loss: 3.235285255773066e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.799791991492384e-05 | Valid Time: 0.012\n",
            "Epoch: 930\n",
            "Train Loss: 3.212731816778327e-05 | Train Time: 0.117\n",
            "Valid Loss: 3.242230013711378e-05 | Valid Time: 0.011\n",
            "Epoch: 931\n",
            "Train Loss: 3.2263757786591e-05 | Train Time: 0.112\n",
            "Valid Loss: 2.934158464995562e-05 | Valid Time: 0.011\n",
            "Epoch: 932\n",
            "Train Loss: 3.2190145200155185e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.6469477688806364e-05 | Valid Time: 0.012\n",
            "Epoch: 933\n",
            "Train Loss: 3.226767206031486e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.8092951652070042e-05 | Valid Time: 0.012\n",
            "Epoch: 934\n",
            "Train Loss: 3.221652092945174e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.646613074830384e-05 | Valid Time: 0.012\n",
            "Epoch: 935\n",
            "Train Loss: 3.226972933733027e-05 | Train Time: 0.133\n",
            "Valid Loss: 2.8257412850507535e-05 | Valid Time: 0.013\n",
            "Epoch: 936\n",
            "Train Loss: 3.226404260203708e-05 | Train Time: 0.135\n",
            "Valid Loss: 2.52006013852224e-05 | Valid Time: 0.015\n",
            "Epoch: 937\n",
            "Train Loss: 3.2242778520173343e-05 | Train Time: 0.128\n",
            "Valid Loss: 2.9309348974493332e-05 | Valid Time: 0.015\n",
            "Epoch: 938\n",
            "Train Loss: 3.234284581834034e-05 | Train Time: 0.134\n",
            "Valid Loss: 2.5862914299068507e-05 | Valid Time: 0.014\n",
            "Epoch: 939\n",
            "Train Loss: 3.2188691540412896e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.021865359187359e-05 | Valid Time: 0.013\n",
            "Epoch: 940\n",
            "Train Loss: 3.2250089900212753e-05 | Train Time: 0.136\n",
            "Valid Loss: 2.6458267711859662e-05 | Valid Time: 0.012\n",
            "Epoch: 941\n",
            "Train Loss: 3.202712344462174e-05 | Train Time: 0.131\n",
            "Valid Loss: 3.013190735146054e-05 | Valid Time: 0.015\n",
            "Epoch: 942\n",
            "Train Loss: 3.2187411450554226e-05 | Train Time: 0.136\n",
            "Valid Loss: 3.392743246877217e-05 | Valid Time: 0.012\n",
            "Epoch: 943\n",
            "Train Loss: 3.224497700820824e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.767938758552191e-05 | Valid Time: 0.017\n",
            "Epoch: 944\n",
            "Train Loss: 3.226716599831554e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.4322887838934548e-05 | Valid Time: 0.013\n",
            "Epoch: 945\n",
            "Train Loss: 3.2343130729522705e-05 | Train Time: 0.123\n",
            "Valid Loss: 3.033981602129643e-05 | Valid Time: 0.015\n",
            "Epoch: 946\n",
            "Train Loss: 3.209460862164729e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.264647648393293e-05 | Valid Time: 0.011\n",
            "Epoch: 947\n",
            "Train Loss: 3.2363794449146986e-05 | Train Time: 0.130\n",
            "Valid Loss: 2.461111421325768e-05 | Valid Time: 0.011\n",
            "Epoch: 948\n",
            "Train Loss: 3.2223319067270495e-05 | Train Time: 0.125\n",
            "Valid Loss: 3.0472298476524884e-05 | Valid Time: 0.015\n",
            "Epoch: 949\n",
            "Train Loss: 3.221390809477797e-05 | Train Time: 0.138\n",
            "Valid Loss: 3.0447260542132426e-05 | Valid Time: 0.013\n",
            "Epoch: 950\n",
            "Train Loss: 3.222318436631835e-05 | Train Time: 0.131\n",
            "Valid Loss: 3.57597209585947e-05 | Valid Time: 0.013\n",
            "Epoch: 951\n",
            "Train Loss: 3.217939765339619e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.8829408620367758e-05 | Valid Time: 0.015\n",
            "Epoch: 952\n",
            "Train Loss: 3.227847465543738e-05 | Train Time: 0.131\n",
            "Valid Loss: 2.564384294601041e-05 | Valid Time: 0.012\n",
            "Epoch: 953\n",
            "Train Loss: 3.225758461523679e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.7773714464274235e-05 | Valid Time: 0.012\n",
            "Epoch: 954\n",
            "Train Loss: 3.233760033158193e-05 | Train Time: 0.127\n",
            "Valid Loss: 2.9529192488553235e-05 | Valid Time: 0.011\n",
            "Epoch: 955\n",
            "Train Loss: 3.2349941121585866e-05 | Train Time: 0.128\n",
            "Valid Loss: 2.807458486131509e-05 | Valid Time: 0.013\n",
            "Epoch: 956\n",
            "Train Loss: 3.217852808072501e-05 | Train Time: 0.140\n",
            "Valid Loss: 3.191276755387662e-05 | Valid Time: 0.012\n",
            "Epoch: 957\n",
            "Train Loss: 3.226723071604379e-05 | Train Time: 0.117\n",
            "Valid Loss: 2.8784100322809536e-05 | Valid Time: 0.012\n",
            "Epoch: 958\n",
            "Train Loss: 3.2119999320313676e-05 | Train Time: 0.135\n",
            "Valid Loss: 2.498496860425803e-05 | Valid Time: 0.014\n",
            "Epoch: 959\n",
            "Train Loss: 3.219790299848874e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.8769758046109928e-05 | Valid Time: 0.012\n",
            "Epoch: 960\n",
            "Train Loss: 3.230560909478778e-05 | Train Time: 0.132\n",
            "Valid Loss: 2.6592964331939584e-05 | Valid Time: 0.012\n",
            "Epoch: 961\n",
            "Train Loss: 3.223921320520611e-05 | Train Time: 0.132\n",
            "Valid Loss: 2.921234681707574e-05 | Valid Time: 0.013\n",
            "Epoch: 962\n",
            "Train Loss: 3.2095308070941096e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.177070175297558e-05 | Valid Time: 0.012\n",
            "Epoch: 963\n",
            "Train Loss: 3.231022971081793e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.384950150575605e-05 | Valid Time: 0.016\n",
            "Epoch: 964\n",
            "Train Loss: 3.2161763795700514e-05 | Train Time: 0.132\n",
            "Valid Loss: 2.902940377680352e-05 | Valid Time: 0.011\n",
            "Epoch: 965\n",
            "Train Loss: 3.2427578557154015e-05 | Train Time: 0.113\n",
            "Valid Loss: 2.6425959731568582e-05 | Valid Time: 0.011\n",
            "Epoch: 966\n",
            "Train Loss: 3.223255359779088e-05 | Train Time: 0.135\n",
            "Valid Loss: 3.218975189156481e-05 | Valid Time: 0.012\n",
            "Epoch: 967\n",
            "Train Loss: 3.225934664155111e-05 | Train Time: 0.118\n",
            "Valid Loss: 2.7056324142904487e-05 | Valid Time: 0.012\n",
            "Epoch: 968\n",
            "Train Loss: 3.217222241035319e-05 | Train Time: 0.120\n",
            "Valid Loss: 2.4345557221749914e-05 | Valid Time: 0.012\n",
            "Epoch: 969\n",
            "Train Loss: 3.206110867674732e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.9333050861168886e-05 | Valid Time: 0.011\n",
            "Epoch: 970\n",
            "Train Loss: 3.2290222263423186e-05 | Train Time: 0.128\n",
            "Valid Loss: 2.4450878754578298e-05 | Valid Time: 0.012\n",
            "Epoch: 971\n",
            "Train Loss: 3.224658681383038e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.244021763748606e-05 | Valid Time: 0.011\n",
            "Epoch: 972\n",
            "Train Loss: 3.2175503962973474e-05 | Train Time: 0.126\n",
            "Valid Loss: 2.4931727693910943e-05 | Valid Time: 0.012\n",
            "Epoch: 973\n",
            "Train Loss: 3.224114104676502e-05 | Train Time: 0.111\n",
            "Valid Loss: 2.933228324764059e-05 | Valid Time: 0.013\n",
            "Epoch: 974\n",
            "Train Loss: 3.214756658340584e-05 | Train Time: 0.120\n",
            "Valid Loss: 3.0244690606195945e-05 | Valid Time: 0.013\n",
            "Epoch: 975\n",
            "Train Loss: 3.2248524229017726e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.5199959281962947e-05 | Valid Time: 0.011\n",
            "Epoch: 976\n",
            "Train Loss: 3.220881655196488e-05 | Train Time: 0.119\n",
            "Valid Loss: 3.0487698040815303e-05 | Valid Time: 0.011\n",
            "Epoch: 977\n",
            "Train Loss: 3.228887199886805e-05 | Train Time: 0.118\n",
            "Valid Loss: 3.36015477842011e-05 | Valid Time: 0.011\n",
            "Epoch: 978\n",
            "Train Loss: 3.2180493929588826e-05 | Train Time: 0.125\n",
            "Valid Loss: 2.8983837637497345e-05 | Valid Time: 0.011\n",
            "Epoch: 979\n",
            "Train Loss: 3.2225195594180965e-05 | Train Time: 0.170\n",
            "Valid Loss: 2.7592789137997897e-05 | Valid Time: 0.019\n",
            "Epoch: 980\n",
            "Train Loss: 3.220864001425645e-05 | Train Time: 0.200\n",
            "Valid Loss: 2.6537100893619936e-05 | Valid Time: 0.017\n",
            "Epoch: 981\n",
            "Train Loss: 3.2153305782182875e-05 | Train Time: 0.173\n",
            "Valid Loss: 2.8269268568692496e-05 | Valid Time: 0.017\n",
            "Epoch: 982\n",
            "Train Loss: 3.199552075353782e-05 | Train Time: 0.185\n",
            "Valid Loss: 3.047773907383089e-05 | Valid Time: 0.018\n",
            "Epoch: 983\n",
            "Train Loss: 3.2296177634730395e-05 | Train Time: 0.167\n",
            "Valid Loss: 3.220722055630176e-05 | Valid Time: 0.018\n",
            "Epoch: 984\n",
            "Train Loss: 3.2363551278984615e-05 | Train Time: 0.185\n",
            "Valid Loss: 2.996861712745158e-05 | Valid Time: 0.017\n",
            "Epoch: 985\n",
            "Train Loss: 3.232212800771537e-05 | Train Time: 0.173\n",
            "Valid Loss: 2.73923387794639e-05 | Valid Time: 0.017\n",
            "Epoch: 986\n",
            "Train Loss: 3.234937986761859e-05 | Train Time: 0.179\n",
            "Valid Loss: 2.552475734773907e-05 | Valid Time: 0.017\n",
            "Epoch: 987\n",
            "Train Loss: 3.226289654297656e-05 | Train Time: 0.169\n",
            "Valid Loss: 2.8005149033560883e-05 | Valid Time: 0.018\n",
            "Epoch: 988\n",
            "Train Loss: 3.2070552486785396e-05 | Train Time: 0.183\n",
            "Valid Loss: 2.6077918846567627e-05 | Valid Time: 0.017\n",
            "Epoch: 989\n",
            "Train Loss: 3.233115048236581e-05 | Train Time: 0.181\n",
            "Valid Loss: 2.7703620617103297e-05 | Valid Time: 0.025\n",
            "Epoch: 990\n",
            "Train Loss: 3.218656092940364e-05 | Train Time: 0.174\n",
            "Valid Loss: 2.6374241770099616e-05 | Valid Time: 0.018\n",
            "Epoch: 991\n",
            "Train Loss: 3.219343220974368e-05 | Train Time: 0.179\n",
            "Valid Loss: 2.8752381240337854e-05 | Valid Time: 0.017\n",
            "Epoch: 992\n",
            "Train Loss: 3.235291105260043e-05 | Train Time: 0.169\n",
            "Valid Loss: 2.8308392302278662e-05 | Valid Time: 0.011\n",
            "Epoch: 993\n",
            "Train Loss: 3.221093921686253e-05 | Train Time: 0.116\n",
            "Valid Loss: 2.6645621801435482e-05 | Valid Time: 0.011\n",
            "Epoch: 994\n",
            "Train Loss: 3.2297796822508406e-05 | Train Time: 0.107\n",
            "Valid Loss: 3.2064179322333075e-05 | Valid Time: 0.011\n",
            "Epoch: 995\n",
            "Train Loss: 3.23396222819084e-05 | Train Time: 0.129\n",
            "Valid Loss: 2.8157661290606484e-05 | Valid Time: 0.011\n",
            "Epoch: 996\n",
            "Train Loss: 3.224825588021256e-05 | Train Time: 0.121\n",
            "Valid Loss: 2.9897134027123684e-05 | Valid Time: 0.012\n",
            "Epoch: 997\n",
            "Train Loss: 3.224997157016524e-05 | Train Time: 0.122\n",
            "Valid Loss: 3.0493745725834742e-05 | Valid Time: 0.011\n",
            "Epoch: 998\n",
            "Train Loss: 3.2059134786035624e-05 | Train Time: 0.110\n",
            "Valid Loss: 2.553793979132024e-05 | Valid Time: 0.011\n",
            "Epoch: 999\n",
            "Train Loss: 3.2222200197314744e-05 | Train Time: 0.119\n",
            "Valid Loss: 2.708594138312037e-05 | Valid Time: 0.013\n",
            "== Test Loss: 3.203762344128336e-05 | Test Time: 0.014 ==\n"
          ]
        }
      ],
      "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",
        "model = PDE_Solver(n_x_new, dt).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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 25,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 466
        },
        "id": "sNwH-Aa0Y3lm",
        "outputId": "af1db2ef-798f-4cdf-adfd-0076d7096622"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, 'MSE')"
            ]
          },
          "metadata": {},
          "execution_count": 25
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAGwCAYAAABFFQqPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABg9ElEQVR4nO3dd3hT5dsH8O9J0r1Lacto2atsoRQQRYZMURAEERFwIENEERUciPoiDn5O6gAFRAUERURRNrJHGWWVvVqgg1K6R9rkvH+cNqNN2rSkOUnz/VxXr57znCcndw5ibp4piKIogoiIiMgJKeQOgIiIiEguTISIiIjIaTERIiIiIqfFRIiIiIicFhMhIiIiclpMhIiIiMhpMREiIiIip6WSOwB7p9VqcfPmTfj4+EAQBLnDISIiIguIooisrCzUrVsXCoX5dh8mQhW4efMmwsLC5A6DiIiIqiAhIQH169c3e52JUAV8fHwASA/S19dX5miIiIjIEpmZmQgLC9N9j5vDRMiM6OhoREdHQ6PRAAB8fX2ZCBERETmYioa1CNxrrHyZmZnw8/NDRkYGEyEiIiIHYen3N2eNERERkdNiIkREREROi2OEiIiIZKDRaFBYWCh3GA7LxcUFSqXyru/DRIiIiMiGRFFEUlIS0tPT5Q7F4fn7+yM0NPSu1vljIkRERGRDJUlQcHAwPD09uVhvFYiiiNzcXKSkpAAA6tSpU+V7MREiIiKyEY1Go0uCatWqJXc4Ds3DwwMAkJKSguDg4Cp3k3GwtBnR0dGIiIhAZGSk3KEQEVENUTImyNPTU+ZIaoaS53g3Y62YCJkxdepUxMXFISYmRu5QiIiohmF3mHVY4zkyESIiIiKnxUSIiIiInBYTISIiIpJFw4YN8fnnn8saAxMhuWm1QGG+3FEQERGZJQhCuT9z586t0n1jYmIwceJE6wZbSZw+L7flDwNJJ4CXTgHu3NSViIjsT2Jiou74119/xZw5c3Du3Dldmbe3t+5YFEVoNBqoVBWnGLVr17ZuoFXAFiGZ5Bdq8Mex68DV3UB+BnB5h9whERGRDERRRK66SJYfURQtijE0NFT34+fnB0EQdOdnz56Fj48P/v33X3Tq1Alubm7Ys2cPLl26hEceeQQhISHw9vZGZGQktm7danTf0l1jgiDg+++/x7Bhw+Dp6YlmzZph/fr11nzcZbBFSAZarYhBX+5G/K0MDHMvLhSYkxIROaO8Qg0i5myS5b3j3usPT1frpAKzZs3CggUL0LhxYwQEBCAhIQGDBg3CvHnz4ObmhuXLl2PIkCE4d+4cwsPDzd7n3Xffxccff4xPPvkEX331FcaMGYNr164hMDDQKnGWxm9fM6pzQUWFQkD/1qHwRp5BKdeUICIix/Xee+/hwQcfRJMmTRAYGIj27dvj+eefR5s2bdCsWTO8//77aNKkSYUtPOPHj8fo0aPRtGlTfPDBB8jOzsahQ4eqLW62CJkxdepUTJ06FZmZmfDz87P6/Sd0b4hdu3fpC4o4YJqIyBl5uCgR915/2d7bWjp37mx0np2djblz52LDhg1ITExEUVER8vLyEB8fX+592rVrpzv28vKCr6+vbk+x6sBESCbBf4/DBpeN+oKCLODaPuDsBqD3W4CLh3zBERGRzQiCYLXuKTl5eXkZnc+cORNbtmzBggUL0LRpU3h4eGDEiBFQq9Xl3sfFxcXoXBAEaLVaq8dbwvGfvKNyMd5nJv3mBfj//ZJ04u4H9HzN9jERERFZyd69ezF+/HgMGzYMgNRCdPXqVXmDMoFjhORS33jskf/RaP1J6gUbB0NERGRdzZo1w9q1axEbG4vjx4/jiSeeqNaWnapiIiSXOu3MX+MMMiIicnCffvopAgIC0L17dwwZMgT9+/fHPffcI3dYZQiipYsIOKmSwdIZGRnw9bXigodpV4AvO5i+1n40MOxb670XERHZhfz8fFy5cgWNGjWCu7t7xS+gcpX3PC39/mbTg1x86pi/xhYhIiIim+A3rlxcyvuXANcUIiIisgUmQnLyrSf9Hr0KuSqDtYoEJkJERES2wOnzcpq4E7hzFQiLhDawKZByBACg1ohwlTcyIiIip8AWITOqc4sNHe/aQJh0fy+/Wrrii7dyqu89iYiISIeJkBlTp05FXFwcYmJibPJ+gpt+RPuFlBxotZzMR0REVN2YCNkLd/0YIXVBPvZdui1jMERERM6BiZC9MEiE3IRC/Ho4QcZgiIiInAMTIXvhru8ac0URNp1Kwp2c8jemIyIichQPPPAAXnrpJbnDKIOJkL1oN0p3OEAZA61GjXWxN2QMiIiISDJkyBAMGDDA5LXdu3dDEAScOHHCxlFZBxMhe+FbFxj4se70ovtT2HIwFtwBhYiI5PbMM89gy5YtuH79eplrS5cuRefOndGuXTl7aNoxJkL2pNTWGv3SVuDE9QyZgiEiIpI89NBDqF27NpYtW2ZUnp2djTVr1mDo0KEYPXo06tWrB09PT7Rt2xYrV66UJ9hKYiJkT9oMNzoNELKxKoaDpomIajRRBNQ58vxY2OugUqnw1FNPYdmyZUY9FWvWrIFGo8GTTz6JTp06YcOGDTh16hQmTpyIsWPH4tChQ9X11KyGK0vbE89AoMtE4NAiAIAfcvBn7A281r8FAry41jQRUY1UmAt8UFee937jJuDqZVHVp59+Gp988gl27tyJBx54AIDULTZ8+HA0aNAAM2fO1NWdNm0aNm3ahNWrV6NLly7VEbnVsEXI3vR6A/ALBwCEuuYjV61hqxAREcmuZcuW6N69O5YsWQIAuHjxInbv3o1nnnkGGo0G77//Ptq2bYvAwEB4e3tj06ZNiI+PlznqirFFyN54BADDvgWWDUILzXkEIQPrD1/EJJ89EJr3B3xC5Y6QiIisycVTapmR670r4ZlnnsG0adMQHR2NpUuXokmTJujZsyc++ugjfPHFF/j888/Rtm1beHl54aWXXoJabf/LwDARskce/gAAASL+cXsD/6RHQvhrMxDUHHjBNlt+EBGRjQiCxd1Tchs5ciSmT5+OFStWYPny5Zg8eTIEQcDevXvxyCOP4MknnwQAaLVanD9/HhERETJHXDF2jdkjd3/dYbBwB0OU+6WT1PPyxENERATA29sbo0aNwuzZs5GYmIjx48cDAJo1a4YtW7Zg3759OHPmDJ5//nkkJyfLG6yFmAiZYZPd583xCjI6rSVk2T4GIiIiE5555hncuXMH/fv3R9260iDvt956C/fccw/69++PBx54AKGhoRg6dKi8gVpIELliX7kyMzPh5+eHjIwM+Pr6VvwCa7mwBfhlRNnyuVxXiIjIUeXn5+PKlSto1KgR3N3d5Q7H4ZX3PC39/maLkL1q9iDgWUvuKIiIiGo0JkL2zGBH+hLciJWIiMh6mAjZs6KCMkV/ciNWIiIiq2EiZM8yyyY9qw+X3fCOiIiIqoaJkD3r+67R6Q0xCHGJmTh1IwPQamQKioiI7hbnKVmHNZ4jEyF71uMlo1NvlRYAsGv3DuDDBsCez2QIioiIqsrFxQUAkJubK3MkNUPJcyx5rlXBlaXt3dg/gAPfABc2w1OpgQfyMfbsVAB5wNa5QI+X5Y6QiIgspFQq4e/vj5SUFACAp6cnBEGQOSrHI4oicnNzkZKSAn9/fyiVyirfi4mQvWvSGwhsDHyxGS7qDJxxf1ruiIiI6C6Ehkp7RpYkQ1R1/v7+uudZVUyEHIHSTe4IiIjISgRBQJ06dRAcHIzCwkK5w3FYLi4ud9USVIKJkCNQMREiIqpplEqlVb7I6e5wsLQjYCJERERULZgIOYJyusZErdaGgRAREdUsTIQcgVIFKExPDbyYeNvGwRAREdUcTIQcxdSDJou3Hb9s40CIiIhqDiZCjqJWE+De6WWKww7PR5GG3WNERERVwUTIjOjoaERERCAyMlLuUPR6vg50GGNUNFi7A/sPHwYSTwBcsp2IiKhSBJEbnpQrMzMTfn5+yMjIgK+vr9zhABe2AL+MMH1tzO9As762jYeIiMgOWfr9zRYhR9O0L9BvnulrJ9fYNhYiIiIHx0TI0QgC0P0FwMVL7kiIiIgcHhMhh2WqR5O9nERERJXBRMhR9X67TJG6SAMUZAEF2TIERERE5HiYCDmqqElAQEOjosS0TGB+feDjRoBWI09cREREDoSJkKNSKICJO42K8lOvSQcaNVCYJ0NQREREjoWJkCPz8Aca9NCdFqnz9dc0atvHQ0RE5GCYCDk6d/3aCO4wSH6YCBEREVWIiZCjc/HQHfoIBt1hTISIiIgqxETI0an0iVCwkK4vL2IiREREVBEmQo7Oxd10OVuEiIiIKsREyNGpTCdC2sICGwdCRETkeJgIOTqDMUKGzt1MtXEgREREjoeJkKMz0yJ04HyijQMhIiJyPEyEHF1IG5PFRy8nQ3N5N5B3x8YBEREROQ6V3AHQXWreHxj4CRDaBnDxgHbdFChS4tCvcCuUy/8PCG0HRD0PuPsBrYbIHS0REZFdYSLk6AQBiJqoO1W4+wMAhigPSAVJJ4A/p0rH76RL9YmIiAgAu8ZqHqWL+WtFnElGRERkiIlQTaNyM3+tMNd2cRARETkAJkI1jdLV/DXuSE9ERGSEiVBNw0SIiIjIYkyEahp2jREREVmMiVBN4+pl/trVPbaLg4iIyAEwETIjOjoaERERiIyMlDuUyvGtpzvUeoUYX9s028bBEBER2TcmQmZMnToVcXFxiImJkTuUyvGspTtUTNotYyBERET2j4lQTWPYNeYdLF8cREREDoArS9c0TfsCbn7SlhumVpHWagCF0vZxERER2SEmQjWNhz/wyhlAWTx7TFAAolZ/vSi//AHVREREToRdYzWRqxegLM5xJ2w0uiSqc4E714Ct7wJZyTIER0REZD+YCNV04VHImX1bd3riaiKw7CFgz6fA2mdlDIyIiEh+TIScgJebCrlKHwDAluPXgIx46cLVvTJGRUREJD8mQk5C6SaNCzp4/rq+sLxVqImIiJwAEyEn4SqqAQCjtX/rC5UuMkVDRERkH5gIOQkhLw0A8KjSYJuN8jZoJSIicgJMhJwZEyEiInJyTIScGbvGiIjIyTERchbP7ypbpmAiREREzo2JkLMIbVemqEDkVhtEROTcmAg5CxP7jt0pKC6LXQHs+czGAREREcmPe405E6UboCnQnabkASGiCGHdZKmgxSCgdguZgiMiIrI9tgg5E5W70WlGoRLH4/XbbyAv3bbxEBERyYyJkDNRGU+Xv095CrsPxcgUDBERkfyYCDmTUi1CAHDv6XcNzkTbxUJERGQHmAg5ExN7izUUE/QnRfk2DIaIiEh+TISciYkWoUAhW39SmGfDYIiIiOTHRMiZVDQjjIkQERE5GU6fdyYDPgK0GiC4FfDf/LLX2TVGREROhi1CzsS7NjDyR6Dpg6avs0WIiIicDBMhZ6Q03RCYd+pvGwdCREQkLyZCzkhbZLLY49p2oCDLxsEQERHJh4mQMypSm792M9ZmYRAREcmNiZAz8q1r9lLO/h9sGAgREZG8mAg5o4AGQNO+Ji8pLm21cTBERETyYSLkrHq9oT8e8BF2D9wCAFBo8lGk0coUFBERkW0xEXJW9ToBE/4FXj4NdJ2EqJYNAABuKETm4oc4aJqIiJwCEyFn1qA74FcfAODq7qkrDkzaCxz4Vq6oiIiIbIaJEElUHkan6qxbMgVCRERkO0yESKJUQRSUutNrqewaIyKimo+JEOkILvpWoSspmTJGQkREZBs1PhFKT09H586d0aFDB7Rp0waLFy+WOyT7pXLXHd7KzENCWq6MwRAREVW/Gr/7vI+PD3bt2gVPT0/k5OSgTZs2ePTRR1GrVi25Q7M/SlfdoQJarDgUj9cHtJQxICIioupV41uElEolPD2lGVEFBQUQRRGiKMoclZ0SBN2hElr8eewGtFo+KyIiqrlkT4R27dqFIUOGoG7duhAEAevWrStTJzo6Gg0bNoS7uzuioqJw6NChSr1Heno62rdvj/r16+PVV19FUFCQlaKvYQwSRDeViJsZ+Th0NU3GgIiIiKqX7IlQTk4O2rdvj+joaJPXf/31V8yYMQPvvPMOjh49ivbt26N///5ISUnR1SkZ/1P65+bNmwAAf39/HD9+HFeuXMGKFSuQnJxsk8/myBr5SjPI/oy9IXMkRERE1UcQ7aifSBAE/PHHHxg6dKiuLCoqCpGRkVi4cCEAQKvVIiwsDNOmTcOsWbMq/R5TpkxB7969MWLECJPXCwoKUFBQoDvPzMxEWFgYMjIy4OvrW+n3cyj/awlkJQIA7tS9Dx0vT4aPuwr7ZvWGj7uLzMERERFZLjMzE35+fhV+f8veIlQetVqNI0eOoG9f/QahCoUCffv2xf79+y26R3JyMrKypDVxMjIysGvXLrRo0cJs/fnz58PPz0/3ExYWdncfwpEo9GPn/QtT0bi2F7Lyi7D68HUZgyIiIqo+dp0IpaamQqPRICQkxKg8JCQESUlJFt3j2rVruO+++9C+fXvcd999mDZtGtq2bWu2/uzZs5GRkaH7SUhIuKvP4FACG+sOhfRrmNBN2n/s9yNMhIiIqGaq8dPnu3TpgtjYWIvru7m5wc3NrfoCsmfN+gFXdkrHhbkY0tQF7ykFxCVm4kxiJlrVqeFdg0RE5HTsukUoKCgISqWyzODm5ORkhIaGyhRVDRY1Cej+ou7UP+cy+rSUWuPWHmWrEBER1Tx2nQi5urqiU6dO2LZtm65Mq9Vi27Zt6Natm4yR1VBKFdDvfaDVEOk88QReCDiA313fwe5jp1Gk0cobHxERkZXJ3jWWnZ2Nixcv6s6vXLmC2NhYBAYGIjw8HDNmzMC4cePQuXNndOnSBZ9//jlycnIwYcIEGaOu4ep2BM78BWx+E20AQAE8lb8CW+J6YGDbOnJHR0REZDWyJ0KHDx9Gr169dOczZswAAIwbNw7Lli3DqFGjcOvWLcyZMwdJSUno0KEDNm7cWGYAtbVFR0cjOjoaGo2mWt/HLrUfDWx7z6jIT8jGzwevMREiIqIaxa7WEbJHlq5DUONsfRfY86nu9C9NV7ysmY6YN/siwMu1nBcSERHJr0asI0Qy6jPH6NTHww3QFmLbtn8BrRO2khERUY3ERIhMEwTAT7+YZONa7pinWoIRR5+CuPNjGQMjIiKyHiZCZF5gI91hXbd8jFL9J53sYiJEREQ1AxMhMm/wZ4C7PwBAlXtLV6wRBZkCIiIisi4mQmReUFPg2eI1nFLidMUaUUBiRp5MQREREVkPEyEzoqOjERERgcjISLlDkZd/eJkiN6EIWasmAupcGQIiIiKyHk6fr4DTTp83NNfPZHFRz9lQ9Zpl42CIiIgqxunzZD33v2ayOP7KeRsHQkREZF1MhKhiTXqbLL52m11jRETk2JgIUcXcvE0WJ2fmIzkz38bBEBERWQ8TIaqYm4/pclHE0r1XbRoKERGRNTERooq5mkmEAGyOS7JhIERERNbFRIgqZqZrTCEIuHwrB+eTs2wcEBERkXUwETKD6wgZULmZLK7vL+1C//OBa7aMhoiIyGqYCJkxdepUxMXFISYmRu5Q7ENwa0BQAgENdUXNA5UAgLVHbyC7oEimwIiIiKqOiRBZZuJ/wKxrQH19C1ktVw0a1/ZCdkER/jh2Q77YiIiIqoiJEFlG5SrNHgtsoisS1NkY27UBAGDZ3iso0mjlio6IiKhKmAhR5XSdrD/Ou4PhnerDz8MFl27lYONpziAjIiLHwkSIKsfDH3h+t3Sckwpfdxc8ESVtzPrvKSZCRETkWJgIUeV51pJ+56QAR37ECL/zaCpcx7YzycjIK5SuaQoB7udLRER2jokQVZ5noP74rxfRZNNYbHV7DfmFWqyPvQHk3QEWNAd+myBfjERERBZgIkSV5+JhsvhF5Vp8vvUC8o6tBvLSgNN/2DgwIiKiymEiRFYzw+U33M5RIzYhQ+5QiIiILMJEyAyuLF2BsevMXBARc/WOLSMhIiKqMiZCZnBl6Qo0fgBQle0iC1LlISmzQF+g1dguJiIiokpiIkRVIwhAwx5likc0U0ALQV9QmGfDoIiIiCqHiRBVXddJZYrGNc4xTIOYCBERkV1jIkRV17RvmaI6NzejZW2D3erzOXCaiIjsFxMhsq7UC+hU1113Kv74kIzBEBERlY+JEFlHrabS7/R4tAhy0RULWYkyBURERFQxJkJ0d57dDrQZDjyxGoAAFObCJeuGURWRW20QEZGdYiJEd6d+J2DEEqBWE8CnjlR2+5JRFa4rRERE9oqJEFmPd23pd3q8UfHi3ZdlCIaIiKhiTITIerxDpN+Z142Kt55JxuVb2TIEREREVD4mQmZwi40q8AouU5QvuEMUgR/2XJEhICIiovIxETKDW2xUQUnXmAFXFAEAfjtyHWk5altHREREVC4mQmQ9wRH648DGAACFWIR2db1QUKTFzweuyRQYERGRaUyEyHoihuqPDVaUnti9HgBg+f6ryC/kJqxERGQ/mAiR9ahc9ce5t3WH/VsGoq6fO1Kz1Vh37IaJFxIREcmjUonQxx9/jLw8/Saae/fuRUFBge48KysLU6ZMsV505Hh6vSn9fuhzQFACAFy0ajzdoxEA4Ps9V6DVcoFFIiKyD5VKhGbPno2srCzd+cCBA3Hjhv5f+Lm5ufjuu++sFx05nvtmAi8eAzqNB1TFm69qCjAqMgw+bipcTMnGzvO3ZA2RiIioRKUSodJbJXDrBCpDoZAGSguCPhG6uA0+7i54vEsYAGDRLi6wSERE9oFjhKj6qIp3od8wA7hzFRPubQSVQsD+y7dx6kZG+a8lIiKyASZCVH00hfrj5NOo6++BtxrG4U3Vz/juvwvyxUVERFRMVdkXfP/99/D29gYAFBUVYdmyZQgKCgIAo/FDRNAW6Y+zUwAA42++D6iAZ+Na4XxyCzQP8ZEpOCIiokomQuHh4Vi8eLHuPDQ0FD/99FOZOkQAAFdvID9dOr590ehSIDLx/e7L+HhEe9vHRUREVKxSidDVq1erKQyqkYKa6Tdg3b8QaNhDd6mn4jhePdEXrw1oiSBvN5kCJCIiZ8cxQmZw01UreOgzIKSt/nzl47rDwcpD8FKn4sttHCtERETyqVQitH//fvz9999GZcuXL0ejRo0QHByMiRMnGi2w6Mi46aoVBDYCJu8Ber9t+rKQhRUH43ElNcfGgREREUkqlQi99957OH36tO785MmTeOaZZ9C3b1/MmjULf/31F+bPn2/1IMnB3T/TZHFUQz8UaUX8sIfrChERkTwqlQjFxsaiT58+uvNVq1YhKioKixcvxowZM/Dll19i9erVVg+SaqbH2gUCAH4/cgMZuYUV1CYiIrK+SiVCd+7cQUhIiO58586dGDhwoO48MjISCQkJ1ouOarQ2QSo8FxiLd8WvsfrgJbnDISIiJ1SpRCgkJARXrlwBAKjVahw9ehRdu3bVXc/KyoKLi4t1I6Sa4bEfyxQJhbl4M/djjFTtRMbe71Gk0coQGBERObNKJUKDBg3CrFmzsHv3bsyePRuenp647777dNdPnDiBJk2aWD1IqgFaDy1bptYPkvbIT8baYzfK1iEiIqpGlUqE3n//fahUKvTs2ROLFy/GokWL4Orqqru+ZMkS9OvXz+pBUg11ZafuUADwxdYLUBexVYiIiGynUgsqBgUFYdeuXcjIyIC3tzeUSqXR9TVr1sDHh1smkIWOr9QdersqcCM9D9v/+RUDFIeAfv8HuHrJGBwRETmDSiVCTz/9tEX1lixZUqVgqIaLmgwc+xkIjwIubjW61LlBAHAGGHB0klTgFQz0mi1DkERE5EwqlQgtW7YMDRo0QMeOHSGKYnXFRDXVwA+Bfu8D298vkwi1CvVGgxRPoGTYUPo128dHREROp1KJ0OTJk7Fy5UpcuXIFEyZMwJNPPonAwMDqio1qIqULEBxRpljQqPFEl3Bgh3QuQoBg49CIiMj5VGqwdHR0NBITE/Haa6/hr7/+QlhYGEaOHIlNmzaxhYgsV69z2TJ1NkZ2DtOdxt/Jt2FARETkrCq96aqbmxtGjx6NLVu2IC4uDq1bt8aUKVPQsGFDZGdnV0eMVNMENQX6zTMuU2cjwEs/AzH2RhbyCzU2DoyIiJzNXe0+r1AoIAgCRFGERsMvLaqE7i8AHcbozwuyjC5nF2ixfP9V28ZEREROp9KJUEFBAVauXIkHH3wQzZs3x8mTJ7Fw4ULEx8fD29u7OmKkmqr1o/rjvHTAoHtVAwUW7brCViEiIqpWlUqEpkyZgjp16uDDDz/EQw89hISEBKxZswaDBg2CQnFXjUvkjJr1BXq9KR3fPArE79ddqueai9F5K7Fiyz6ZgiMiImcgiJUY5axQKBAeHo6OHTtCEMzP6Vm7dq1VgrMHmZmZ8PPzQ0ZGBnx9feUOp+ZJjgO+6Wb28jkxHAEzYxDs427DoIiIyNFZ+v1dqenzTz31VLkJUE0SHR2N6Ohojn2qbh7+5V5uIcRj7o5LmPtwa9vEQ0RETqVSLULOiC1C1UydC3xQp9wqzQpXYsfMB1A/wNNGQRERkaOz9PubA3tIXi4eFVYp0mjwxdYLNgiGiIicDRMhkpcgAPU6lVvleeXf+P3odZxJzLRRUERE5CyYCJH8nvwdGPe32cszXX6DVgRe/jUW6iKtDQMjIqKajokQyc8jAGh0H/DgeyYvKwURgV6uOJuUhY2nk2wcHBER1WRMhMh+3DsdeHhhmWJB1ODJrg0AACsPxts6KiIiqsGYCJF9KTK92eqoyDAoBGD/5dvYef6WjYMiIqKaiokQ2RefUJPF9fw98FS3hgCAuetPc6wQERFZBRMhsi/NBwKD/wdETTYuv3MVr/RrjiBvN1xJzcFPB67JEx8REdUoTITIvihVQOSzQPdpxuVftIdP2inM7NdcOt16Hmk5ahkCJCKimoSJENknhbJs2YnVeKxzGFrV8UVmfhHmbThj+7iIiKhGYSJE9sk7ROomM6Ryg1IhYN6wNhAE4Pej13Hk2h154iMiohqBiRDZJ0EAnlgF9HhZX6ZyBzRFuMczFSM61oEvcjD/nzMcOE1ERFXGRIjsm2Dwn+h/84GFnYCFnfFJXC+ccH8OyfFn8c76U/LFR0REDo2JENk333rG53euGp0+ptyFlYcScDU1x3YxERFRjcFEiOxbxyfLvRwW4AkA+O3IdVtEQ0RENQwTIbJvKjeg/wdmL7et5wsAWLT7Mq7dZqsQERFVDhMhsn/NBwCuPiYvNbm5Hq/XkXaln7v+NERRtHFwRETkyJgIkf2r1QSYFQ+0HVnmkpB5A5PvfAxfZQF2nLuFzXHJMgRIRESOiokQOQaFAug6yezlSV1DAAAf/XsWGi1bhYiIyDJMhMhx1OsEDPnC5KVxXULh467C1dQsvLI6FlomQ0REZAEmQuRYVB4mi70ENf4KW4EDbi9ge+x5LNp92caBERGRI2IiRI7FxXQihNw0NExYh2AhHUOVe7HyUDyKNFxxmoiIysdEyIzo6GhEREQgMjJS7lDIkNLFdPmyQbpDlcoF127nYvn+azYKioiIHBUTITOmTp2KuLg4xMTEyB0KGSoqqLBKvzZ1AQALNp/Dvkup1R0RERE5MCZC5FgsSIQ6N6qNJrW9kKvW4JXVxzlwmoiIzGIiRI6lSW/pd2Bjs1VUKhf88mxXAEBiRj7WH79pi8iIiMgBMREix+JdG3j9KjD1kPk6ohahfu54/v7GeE+1FE3XDcaVxFs2C5GIiBwHEyFyPB4B0qDpwf8zfV0jdZ+9dn8wnlJtQRvhCn754y+oiziLjIiIjDERIscV+azp8iI1AEB5bZeuKDbhDr7Ydt4WURERkQNhIkQ1T3GLEBKP64o8BDWW77uGrPxCmYIiIiJ7xESIHNuEjUBYV+OyIjVweCmw90tdUSNfAVkFRfhq+0UbB0hERPaMiRA5tgbdgGc2AQEN9WXn/wX+fgkQNbqix9oHAQAW7bqMg5dv2zZGIiKyW0yEqGZ46k/98Y0jZS63DXbB45FhaCAk4feV3yM1u+L1iIiIqOZjIkQ1Q0BD4L6Z5q+f+h2v9QnHTrcZ+LjwA/z401KIIhdaJCJydkyEqOYQBPPXruxE4H9v6E69buzG1/9dskFQRERkz5gIUc1xp4JNVmN/0R36IA+fbDqHq6k51RwUERHZMyZCVHMU5lpctZGPNJD6401n2UVGROTEmAhRzdHrTePzl04BPWeZrNq6lgCVQsA/J5Pw476r1R8bERHZJSZCVHOERACzEvTnPnUAV0+TVf2u78D8ntK1ef+cwdH4O7aIkIiI7AwTIapZ3H2BqTHAtKOAUgV41TZbdcSZaRjctg4KNSJ+W74Q2bu/sWGgRERkD1RyB0BkdbWb64996pitJqTH46PJ7XAmMQMfZC8AtgGI6AfUalL9MRIRkV1gixDVbL51y73sffhrbBSm6c7X7o+r7oiIiMiOMBGimq2cFiEAwJa34ZqlH1e0dH88LqZkVXNQRERkL5gIUc3m7gu0GGTmYtkFGFXaQsz58zSn1BMROQkmQlTzjV4J9HqrbLmJsUC/u85Fr2tf4KVfY6s/LiIikh0TIXIOpqbR375YpkghiHhO9Q+8Ty7Hp5vP2SAwIiKSExMhcg4hbSpVfZ7LEny14yKOXEurpoCIiMgeMBEi59C4p353+jbDLXqJKALP/HgYd3LU1RgYERHJiYkQOY8+bwNz0oDBn1ZYVesRiCa1vZCeW4h3/+LgaSKimoqJEDkXhRJw8624Wl4avm8RA6VCwLrYm/h0y3kbBEdERLbGRIicj0IB9C49i6zsVPpGh/8P84e1BQB8tf0iVh2Kt0FwRERkS0yEyDn51tcf+9QFOo4xWW1kZBhe7NMMADDnz9M4npBug+CIiMhWmAiRc3L10h+/cAi4ts90vUs78HLfZujfOgRqjRaTfj6Ca7dzbBMjERFVOyZC5JyCDDZmdfMBOk0wXe+noRC+vQ9f1NmMBrU8kZiRj6HRe5GUkW+bOImIqFoxESLnFNwSePR74Kn10nmXiebrJp+E+56P8MO4zgjydsWd3EJ8sY2Dp4mIagImQuS82j0mrS8EAC7uwJSDQNQks9WbBqjwxeMdAQArDyXgtd+Oc1o9EZGDYyJEVCK4JTDwI8DNz/T1rER0b1ILz/dsDABYffg6fjty3YYBEhGRtTERIipt2mHT5ZmJEAQBswe2wqv9WwAA3v0rDglpuTYMjoiIrImJEFFp3sGmy7MSdYeTejZBpwYByC4own0f7+CeZEREDsppEqHc3Fw0aNAAM2fOlDsUcgQtHypblnkTyEsHACgVAj4f1QH1/D0AAMO/2Y9bWQU2DJCIiKzBaRKhefPmoWvXrnKHQY7i4a/Klm15G/i4MZCfAQAIC/TEt0920l1+6KvdSMnitHoiIkfiFInQhQsXcPbsWQwcOFDuUMhReAaaLhc1QEKM7rRtfT+sfr4bAjxdkJxZgJdWxUJdpLVRkEREdLdkT4R27dqFIUOGoG7duhAEAevWrStTJzo6Gg0bNoS7uzuioqJw6NChSr3HzJkzMX/+fCtFTE5j2HeAoADqdTIu1xYanXZpFIhVE7vBw0WJfZduo/P/bUFmvnEdIiKyT7InQjk5OWjfvj2io6NNXv/1118xY8YMvPPOOzh69Cjat2+P/v37IyUlRVenQ4cOaNOmTZmfmzdv4s8//0Tz5s3RvHlzk/cvraCgAJmZmUY/5KTaPw7MvgF0ed64POdWmaotQn3w2agOAIDM/CI8++Nh5BdqbBAkERHdDUG0oxXhBEHAH3/8gaFDh+rKoqKiEBkZiYULFwIAtFotwsLCMG3aNMyaNavCe86ePRs///wzlEolsrOzUVhYiFdeeQVz5swxWX/u3Ll49913y5RnZGTA19e3ah+MHFvyaeCb7vpz/3Bg8GdAs75lqn638xLm/3sWADC4bR18ObojlIqyO9sTEVH1yszMhJ+fX4Xf37K3CJVHrVbjyJEj6NtX/4WjUCjQt29f7N+/36J7zJ8/HwkJCbh69SoWLFiA5557zmwSBEiJU0ZGhu4nISHhrj8HObiQ1tIO9SXS44FfhgPasmOBJt7fGKO7hAMANpxMxFfbL9gqSiIiqgK7ToRSU1Oh0WgQEhJiVB4SEoKkpKRqeU83Nzf4+voa/RDhue2AV6n1hbJuAupc3ZR6ABA0hZjfNgkfPtQIAPD51gv43+ZzNgyUiIgqw64TIWsbP348FixYIHcY5Ih86wCvlmrdSb0AREcBn7eVEiIA2PUJ8MsIjLr6Nqb1bgoAiN5xEf+dSwEREdkfu06EgoKCoFQqkZycbFSenJyM0NBQmaIiKpZwCMiIBwoygdTiVp/DSwAAwsWteKVfC4zoVB9aEXj+pyNYf/ymjMESEZEpdp0Iubq6olOnTti2bZuuTKvVYtu2bejWrZuMkZHTatZPf/zfB/rj5UOlFiKVm1H1D4a1RZ+WwSgo0uLFlcfw6ZbztomTiIgsInsilJ2djdjYWMTGxgIArly5gtjYWMTHxwMAZsyYgcWLF+PHH3/EmTNnMHnyZOTk5GDChAkyRk1O69FFQFhU2fL8dGBhZyDzhlGxq0qB6DH3YFBbqQXzq+0XsOMsu8mIiOyF7InQ4cOH0bFjR3Ts2BGAlPh07NhRN7Nr1KhRWLBgAebMmYMOHTogNjYWGzduLDOA2tqio6MRERGByMjIan0fcjAeAUB/CxfnTDkDHPgW7gotvh7TCWOiwiGKwMSfDmPHuRQgPQHISq74PkREVG3sah0he2TpOgTkZDa+ARwwvQhoGQM/BgIaQa0VMeVgLWw9k4xg1wIcUhS3ar6TDghca4iIyJpqxDpCRHar4xjL617aDqx4DK6rRuLrURHo0TQItQoNln/QcDsOIiK5MBEiqgp3P8vrGqwz5LpmDL4f0QBdGwXoyjYcvWTFwIiIqDKYCBFVhVslukmL8vXHl7bDfesbeKt9tq5o7tojWL7/qvViIyIiizERIqoKV2/L66qzjc9P/Q7lvzN1px6CGnP+PI1v/ivVMnQzFvj+QeDavqrHSURE5WIiRFQVChN/dZ7bDgz7rmx5fma5t3omSppa/9HGs3j/7zj9rvU/DQOuHwKWDrzbaImIyAwmQmZw+jxVyHAjVgCo1Qxo/zjgGWRcXrpFqJRxnUPwXpQWn7ssROzejXjiu73Iyi8E8tKsHDAREZXG6fMV4PR5MqsgS1pNenEv6XxOGqBQAnMrMZAaAMZvAJYN1p1e0NbD7Drf47dkg5aguRlWCJiIyHlY+v2tsmFMRDWLmw9Q7x5g9K+Ai7uUBFVFYZ7RaTPFDRy+dgdwt0KMRERULnaNEd2tFgOAxg/ozx9fUbnXF+aWKfJxYUMtEZEtMBEisraWg6XVor0t3AYm706Zoo0vdDE6H7fkEM4mlT/omoiIKo+JEFF1EASg7WOW1f1repmiet7GfzV3nr+F8UtiUKjRWiM6IiIqxkSIqLo06F7115YaNwQASZn5eHzRAWlGGRERWQUTIaLq0mJQ1V9bVGB0uvCJjvBwUeLItTt4eOFeXEnNucvgiIgIYCJkFtcRorsmCEC9TlV7bZFxi9BD7eri52e7oL/7KazImoAPv1qIrXHJVgiSiMi5cR2hCnAdIborCTHAjw8Z7zdmiWe3Ad/30Z/PvAB4BxutUdQwfwW6N6mFb57sBD8PFysFTERUM1j6/c0WIaLqFBYJzEoAur1gXN5zFjD4U/OvKz1GaEEzk9X2XbqNF1YcRXqu+i4DJSJyTkyEiKqbyhW4f6a0BUfEUOD1a0Cv2YCynFac9PiyZbs+MTqd81AEAGD3hVT0/XQXdpxNsWLQRETOgV1jFWDXGFmNKErjhkoc+xn4c2rV7zc3A6dvZmDSz0eQkCa1II3r1gAv9W2OAC/XuwyWiMixsWuMyN4YJkHA3c0qK9a6rh82v9QTj95TDwDw4/5reDh6D05cT7/rexMROQMmQkRy8QwsO3aoMrTS4ooerkosGNEeHwxrC09XJRLS8jDs631YsucK8gs1VgqWiKhmYtdYBdg1RtUqNw34aSjQqCew78vKvbZuRyBqMtB+lK4o/nYu9q14H+nJ8fiwaDQAAS/0aoqZ/VtYNWwiIntn6fc3E6EKMBEim8hLBz5qIB23GyXtP3Zhs2WvnZtR6lyaYj+44AOcFhsCAEZ2ro+PhreDULp7joiohuIYobvEBRXJplTu+uPebwE+dap2H02R7nDJyEaoVTxoevXh6xj29T4cjS+7wSsRkTNjImTG1KlTERcXh5iYGLlDIWfg4g7cOx3oOgXwDwcKcy1/7b6v9McGCzeGeAo48vaDeH1AS6gUAmIT0vHo1/vw7l+nUVTe5q2iCFzaAWTcqMIHISJyLEyEiOzFg+8BA+ZLx9mVWBNo81v6Y8MVrIuTqckPNMGWGT3RIsQHALB071VMWBaDmKtppu93abs0bumziEoET0TkmJgIEdmj8rrGQtuVLTv6E3BhC5B8Wl+Wrx871CjIC5tevh9fj7kH7i4K7L6Qise+3Y+PN55FQVGpmWVXdt1l8EREjkMldwBEZELfudLq0vH7yl7zCQWSThiXrTcxDT8vvUzRoLZ10Li2F3asXYw7Ny7g6/+GYNGuy3iqW0O8/VAraTC1QmmVj0BE5AjYIkRkj3zrAI8tNX0tqLll99j2LpCTWqa4ZagvJqe8hzdcViLK8yaKtCKW7L2CJxYfxLmkLEBgIkREzoOJEJG98qoN+IUZlzW4F7j/VeCecZbdY/VTZcuKCnSHy8e0whNR4QCA/Zdvo//nu7DmKAdJE5HzYNcYkb1SKIFpR4D0BODyDqDdSMBdWiMIQ74Ajv5Y8T2u7QWu7QMadJfOk04Bon5MkJubOz4Y1hajI8Px/oY4HLqShvg7BUDxfrBZeWr4eHDfMiKqudgiRGTPVG5AUFOgy3P6JAiQ9i3r8rxl99jxgfT79iXg23uB7+7XXytuHWpb1xsrRoZhU8QmNHDRD7Ie8L+tmP/PGdzKKgARUU3EFiEiRzXwI+DQdxXXKxn8fPNY2WuZN4GFkUDmTajc/dEi8zoMN+PIys7Cd7su48LRHRjRKwqD7u1kldCJiOwFW4SIHJUgAK7eFtQr/mvu6lX22tpngdTzgDobyLxe5vJTnYLRXEjAkqLZGLSlN9rO3YSfD1xDZn7hXQZPRGQfmAiZwS02yCG8fBpoPaz8OoJC2nrjwpZK335m73CsfUg/iywrvxBvrTuFdnM3Y+ovR5GrLirn1URE9o+brlaAm66S3dNqgPcCy6/TdQpw4OvK33vsH0DicWDrXADAd1Fbsfx4Fm6k5wEAAjxd8FjnMLzavwVclPx3FRHZD+4+byVMhMghfNkRSLsM9HgZcPcHDv8gLchobZP2Ir9WK7z22wmsP37T6NInI9qhd8tg1PJ2kwpEEdj5EVD3HqB5P+vHQkRUDiZCVsJEiBxCdoq0NUarhwGVq9RK9GG4NPbHmsb8BjR7EMi+hVS1Au9vjsefscYJUdfGgZjepzm6FR4AVj0hFc7NMHEzIqLqY+n3N9uyiWoC72Cg7QgpCQKkmWKzyw5+vmu5t4HcNGBBUwQt6YYvHu+IY28/iJf7NkfLUGlT1wOX0zB68QF8/3cV9izb+Abwz6tWDpqIyDwmQkQ1lSBYvgK1pfIzgYRD0nF2MpCbhoCDn2B67aPYOK07/nnxPgxqGwqVQkDCnTzdy15ZfRw30/PM3LRYQRZwIBo4tAjISrZu3EREZjARIqrJ6nasuE6tppbfLz8DELX683VTgF0fA39MBD4MQ0SQEl+P6YR9s3ujexP9AO7fj15H9w+3o/v8bfjgnzPIMjX9vkitP9aauK7VSt1/uWnlx1iYBxxZJq2RRERUAS6oSFST3fOUlLg06Q3k3JJmjrn7ASd/048fajsS+O8Dy+6Xn64f9wMA5//VHxfmAv++DjyyEME+7ugfEQoUj9fu1tAP+69m4GZGPhbtuoxFuy5DpRDwZNcGmNKrCYJ93IGifP29NAZJUc5t4MImKcHZMAMIaARMjzWOKy8dgAh4BEifcdt70l5tr1607HOR47l9CdAUAsEt5Y6EHBwTIaKaTKEEIp+RjgMbAWFdpOMGPaTFFDuOBdwsWJSxREYCgHLmV8T+AjyysEzxivHtcC1bib2XUvHp5vO4naNGkVbEsn1X8fOBaxjYtg7GNitCl5IXFBokRb8MN14V+84V45trioCPGkjHb6cCCTHScc4tyz8XORatFvjqHul4VgLgzoksVHVMhIicUZvhQGhbIKg5sPNDy19XUXeTYbeZwbFQVICGQbXRMMgLg9rUwdH4O9h8Ohm/Hk5AkVbEX8dv4sKJeGwsnnl/4mI82ijdoQhqbHprEEN5dwyO04GQCH1LVW4a4FnBGkvkeLQGC3lmp9h3IiSKQE4q4F1b7kjIDI4RInJGCoXUpaBQSIOeLXU9puI6GTek6ftpl/RlRXnSBq+LeiFg2yvo0yoEH41ohyvzB2H7fWcxPvgC3KHvDmu3ZRQUCzui8N2git/PsBtN1ABKV/15QZYFH4ocjqiROwLL7V4ALGgKHP+14roHF0l7/2VUw4xPMouJEJGzazHY+Lz1o8DwH6p+v88igL9eBGK+15fFfC9t8XHzKHB0ua5YuHUOjWPew9zMd7BkgFuZW7mIFuxpVmgwG62owDgx0nBPtBrJsEWovK5ae7D9/6Tff79Ucd1/X5X2/tv2XrWGRMbYNUbk7Jo9CDy9CVjSXzrv9gLg6nl39zz2s/H53i+kQc4ltFqpNSonRVcUuON1i28/4PNdCPZ1R5u6vngo+BYiSi6USYTUpl5Ojk7rgHvceVnQulmiMLf64qAy2CJE5OwEAQjvqj8PbAR41rL++xgOcv6gDnDnqjQdvwpyki+i9aUfsPy/k3h7jb677p21R5CRbfAlYkkidGELcDO2SnHYlSI18O19wG/PVO51iSeA35+T/jwchdaga8xRNkfwCpY7AjKDiZAZ3H2enM4r54AXj0mDiz0Cqve9ivKBf16TFmisgs0+/4fXXVbhLdXP8BQKdOXHr6bgr6NXdec7z9xEntrMeJKc28DVvcAvI4BFPaVutLz0KsVjF26dAZJOAKd+s/y5Jp0CvrsPOLm68gmUnAxbhOQcL5SdAhxeoh+LlnIW+O1p4NY56dywa7YyLUJkU0yEzJg6dSri4uIQE2PB4FCimsAnFAhsLB0rXcqvGxxR/nVLXNpmPOOrEjzUtwEAowLOYXbfBrpyNxTCBfovxuitcWg1ZyM6vb8Fw6N34dj79+L4l6NwO7sAWDZI+inxWWtpGn5mYtU+DwAc+RG4tq/qr78bgsH/zlPiLHvNt/fqj29bac0lUQTOb6reAb+GLUJydpP99Cjw98vAhpnS+fJHgFO/Az+PkM4Nu7hUZcfAmZV2FVgzAUg8brVQyTwmQkRk2sBP9MeD/2d8zcUTaDXk7u6vLbrrpEHQFCIiSD/UcdXTHTAoQj9d3kWQviRv56hRcP04OmpOoX3aRjzwyXbg1lnjmxXPnhN3fgz8ryWwZU7ZN7x13nhwtqGEGGmQ+NKB+rKLW4GfhgHpxStLajXAr08C/31U+Q9bEcOVuUt/NlNKfw4XD+vEcXYDsGKklFhWF8PkpzoHxCedBHZ9YryulaHkk9LvuD+l39lJ0u+M4j/vIn1rpVHyVpHkk8DptcD3D1YuXqoSJkJEZFrURGnX+FcvA5HPAr3f1l9LPQ80H2j+tYaGLTJ/LenE3cWoKQTUObpTQaOGj4t+zMjycR2x+KnOeKV3OB5pF6or3yBOM3tL4cgSICsR2PsF9l1KxcWUbCTdyQF+6AdERwLf9TT9pZZp0AJSMm7l5+HApe3AXy9J55e2A2f+snwl7/Jk3gRifgDUxa0OGoMvXUta2kovOFleIqSpRKvLlZ3645+HAz8OkZ7H8V+l51CZhMAcw0TIGvcz59se0qyvfV+WX89c95y51dI3zAQ2v122fmmGf6ZUbThrjIjK51U8cPr+mcCxn6RBtUHNgfaPS11obj7AysdNv7bDGKDePebvnZFwd7EVZAB7PtWfF+UbtRAoxSI86J+IB1f3BBrou4HCFZatOv3E4oMAgAHKQ/jWRTpG6jls2bYJfk27IrJhAARBkMpdDGbaqbONu4ayU4CCbGk8SVWUfNkrlPqy7/sCmTeknz5zjL90LRnrlF06ETIzU/DSdmDlaGDQJ9KWLZVxcav0OytR2o8OABr2ANoWdx2pc6Vn5V3JgcS27hqrqIvKcCFRQ4YtQiV/PukJQMxi6bj3W5XrMqNqwUSIiCw37m9pk9WuU6Uv5XYjgZQz+uuT9xu3ePSfZ74ryVpKup2AstPnc9OAtc9Lx9f2VvrWSoUAlbYADykOGJUv2XEK+7dJrT4RdXwhCEBEzkmUdCau+C8Wo2OfglDyAoVCWkfm3D+VjgGaIuDrKClReX6XNMsPkBIgALi8E+gD466x/PSK72tpi9BPw6Tf66dJiVDJ0gdmCWWLbhwxeN9U/fGXHaQuyRlnAN+6FcdcQqxiIqQprHj8mymKCr4qzbVKGSanJUlR6eUdqisRykuX9uZrNwpo3v/u73dxm/QPl07j7/5edoZdY0RkOf8w4OGvzG90GdAQ6PEyMOY3YPZ1afaZYUuDf7j02y/csvcLalG5+Iryjb9o1r8AqKu+uvTxt3ohNnILHlIaJ0K13PXHcYmZOH0zExlZ2bqyFf/FQshL09/nRhZwco3RPbadvomCIgu6ddKvSQOZk04YtzCU8Cnu8jPsRrFkWYLSiZDK3XQ9Q9vnAZ80qfxU+1+fNF1esqr5ld2Vu59R15iFiVDSSeCDesCO+ZV7L8A4eTrwDRDdFchKMqhgYgr/+hdNtwgZth4VVeM6V/99KA3cXjHSOvf7+VHgr+k1cgA3W4SI6O4YfoGq3KSWomYGgzxdvfTH/eYBPnWA3NvAylEV3/vxFdL/gNOvWRaLRm3VwbPeKUeBk7+UKV84sjXeqtMHhy4l41pCAm4LAWiecg4o7g0LFHKM6mtN/Jtz7s8b8aLyD6x1GYTcWm3RLMQHbioFijQi1BotUrMLMLpLOFoo09Gk+DWiRg3Bxd14enxJt5Lhl6olXWOlF+0z1zVmaNfH0u8d84FHvzNdJ3ZFBTcxte6PQVniCWkmVp+3gcYPmL5F6URIFIHzG6X/Fpv00l+7eQzY9Cbw4HvSas2aAmlvvV6zK4ixFIVBIrRxlvT7vwoSqqM/Si2mJUy1CP37KjDkC6l72dpKWgytwXCtpqwkoE57693bDjARIqK7E9hIWo3a3d94DEsJw39NBzaSNntNPm1c54k1wIrHyr42qKm0m/2PFs5QS4+vUheYWYbT6w0VFSDUzx0PH58CXNsDPLMFuB2qS4S+H9kYWKevHujtDpTKOz5z+RadFefwmLgLDa+vwPHrxq04vsjGvgvJaCLcxObi3pMOc/9F0wZhaOJ6B8UpCQ5dy0DRpVSo4+LxQHFZ2u0UHD+Xgqa1vZFXqIG/pwtqe7vpxzMVfwYjLha0CJUwNzj44raKW+AqWgBxxSgg66Y0FX2umZYtw66o5NPSGKT1xQPgn98N1GknHa96UhrE/n0foEmf8t+3vDiPr5CSJ3+DlkxLunyNusaKjw1noJ36HfCrLyVq5uRnSpvK7v6flIQM/FhatyjjurTBsDmG3XnqHCB+P9Cop+Vdg+pc4OpuoNH9xkszCKX+jmenSGUlYwkdEBMhIrp7/eeVf33ot9K/UEPbSud+YcbXAxqUfU2J+l2kdYssWRtn/8KK61hDyb/qr+2Rfv/woNGsOletcZLRIPdUmVt0Ul0GintJXuzTDDkFRcjOL0K2ugi5KVewNH0iDmub453Ccfr7oghHrt3BbSERKE6Oriam4rXFB/GkMgEPFH/HZdxJxYSlMWgtXIUaKlwQ66OWlyt8PVwgCMDlWzl40+cMnjOIJ/ZGFk7uvwo3lRI+7iq4uyhxJ1eNR018/NyCQpRuPxJFEcKFLRU8OECt0cAVkMYa6V+sP866WeE9jBKhre8YXzu5Wp8IGXb/VTTOB5C6z+IPAJ2fNk5iAGDtRODpjaZjBow/Twm1QfZbVCC1Vp5ea1ynZFVzcwniogeAFw7r9x/r/LQ0OeHOVeDZbUD9zsb1jywDIBj/o+SrTlKyOOw7aZKDJf5+GTixCuj4JPDg+/pyw/Fh6lxgQTPpeE6a8XvGrQeOrwQeiZYWabVjTISIqPp1GG187u5rfO7mK61bdPiHsmvguLgDU/YDc/2qN8bK2PY+EBZlXHbQoKuo9JeoCYJB986MB5sbX9y7B9gCdFacx/Kx7YDVUvGsfo1xtSgQvlkAipewCfMR0FDhCdd0/f38hBz4IBcb3N4AADTO/xm3c9TonLcXbijEZXRHXl6u0TfAjbRsvP2ncUudAlo8aqKhyPP8OsyfOx1LCwfA210FV6UCaTlq/OK+HxWtxf/Rv2cRf/kwWga54JXisoNXbuOKOh7Bvm7obVB3/6XbqOPnjku3sqHRiohPy0XH8AB0Es2PCxKzklGk0cJFqZC+gLOkBTIz1UDJf3W56iIoFQLcVEoUabRQKYu/3L/tIf128TTu3gUgppwxHgZeeqaY1kSXbPx+/XFRgbTnXulkvSRBMzfWKe2S9PeihEatH6N1+g99IpSXDmx+U7/PX6uH9a8pfga4fcn0e5hyYpX0+9jPwH0zDd7f4HMaLsKpzgbcDf6Orh4r/d75MTDwQ8vfVwZMhIhIHmN+B34ZLh27+0nrFtXtCPzQV964LJF5XZrxZMhgA1nLNs0s1QKgzpG+gAXjWVe13PStH8M7hEirfyfm6xKhbnn/4b85fwB7jwHbpLIARR4Ov9QW+FY6XzWuDdLVCvT74wkAgKp+DzTLdAEMhhqpoEWLEB/kF2lwJ0eNzPwiuML8eKvZWIbFmr5Iy9EnBEGFiRZMwRGxJS4ZB5CLV4qTrF9jErD2oPSBrhokXqMXHzDxeqCH8jR+NtPDs/PERYyP+RcuSgH/urqgaXG577VNujpd5/wOJbRoobiOA9pWCPB0hYeLEiXLe/6zZTN+36GCQfqB1Hxg7i9HEV1ScOo3o/d9buk+LC4dzIGvdYeF6jxk7P0RpTfaOBJ/B6t/O4EGvsAU0x8J2Ts+g3fx8S8HEzCm+HjNwYvYfOEvJOcB0zTL8WD+Zt1rUtKzUHpRgjPJOYg/nYSUrAKcTcxEkLcb+rQKRsr+FfDXpCG1jbTNyvU7eXjW8IUG/63/dyoeR6+eQ+Pa3qidEoeSRSlWbtyJsIZNUf/kQiQ1fRwluxfeTrmBcyfP48T1dGg9AiGKgLebCln5hfB2UyHE1x2pOWqM7VpOq3A1YyJERPIo+Zesm69+6na9TtIA2cv/AZ0rsfdVYGMg7bKFlQVg+nHpS+rgt5UIuBJSLFjZ2VDM98CGV4C2I4Hhi2GUJP37mv5YUyjtkfbvLOPXH/vJaBCuIGrgpk7XnXeJfcNo6v6n/YOAk4HAIf0t+reshf5j7ted38lRw6UwA/i8nLDv2Yob3d/FjTt5yMovQvg/aabHQhuoH+CBgaGhCBIygQtSWT0/N3jlKKFQmJh6X0whAFpR//nM8Ral2XuFGhG3NZ5oaiIxO+E+UXf8vPplbMqNxB0UAsVJ2I1MNZI0qbruRwAoEFXYcDIR0WaGUsVcSta93hShqAAZhYUIKhWPW0Eafj2cAF/kYIqZ12fn5sK7+NFsOnQCY1yl48e0G/FYqtRdF6dtYJSEnr2eiuBSw3m2nb6OBcePGJV9se0CrrpLg8cHHK+Fs6I0DupZM7GsP3wRzRU7sUHbDIFCFu4tTkhHx46F+pgSroIG4RdX6FZR2H0xFQ9djkJXiGhR8CMKoQIgYrnLh8iBOyYXvgRAQKivOx6MCDH9ptWMiRARycPDH5hxFlC66ltBFArgqT+l8RKlWkYgKI0H6ZYkP/0/AJoPAL4qZ+HGEmFRwFPrpe62gR9VXyJ0vKKZU6VsKO4kOrlamnln2P2Qel5/vH6a9BziS21Ncuynst0eew1WQy69ftEPfY0WmAQgrQhtsEZQgJcrkFn+1PRacctQa+BstAvykuLeUPGMvQndG2JC907SYN/PpLJX+jTEiyHBUF3cCBgsTH2p5be4eO8ChDdoCg9XJTRaETfT85B2PNeonqHOivOIeTUKOaIH/H7/Gqhg67iXQ0+gc4en0CHcH1gmlY312IcWEb0Ag5ni3l5eeKtvK12rW2lvtcsEzpu+BgAqQYsmQtlgvBRSAtuklhuQU+ayVEep0Y0nW+5qensWBYy76nxcRJQqQqiXAkEaaaxY6q1k+Hh6IjlXX6ljQD48vP2RklkAmOndHedzCO0LjgIAlqhGAgb/ibgK0t9PhaDPhkNUOVAVdyPeH6rGtiQVwoQU3K+UWgC9igpQP7g26vhVYrC+lTERIiL5+NYxXV46CQKAGXHAwi7SatJKN+DpzdKaJk37SPWDWwMpp8u+zlDHsZWbHSWHYz+Zv5Zw0HT5dRObQ5/bUP77lJ5dV5QPHF0mDcYFpK66BNNdU0b+V7zWU6OeFdctIYrG08iL1HD5oVeZasqru9DiahfgjZsAvKBUCAgL9ERYXe8ydQ3V/qoJaj/wBpC4p8JQWoZ4ouX9jY3K3AvTcf/xV43K/L088Ox9jc0mQiPOv2r6QgUa+QBXZ/WQBh5/arqOj0oLVLDkUMtAAUjXn3es66mbxaiLsUMIRgx8UFpo9ONGEGu1RNrkP1HS3zf/4RZAy+IEea7p92nvmQYUzwV4ur0XcMR0vRJdQ7RA8ZJLPzwahoK6kXDLvAYU5+kxM7vCPaBuua2B1Y0LKhKRY/AJBaYdAbpOAZ7fCXjXBpr11SdN976or+tbX/rtWWpKr6np/YC0TszwH8qWu3gZn3sEVC12R/H3y9KXpDoX+KAusGa85a+9YqaJprTNbwFrnwO+7KgvK9ms1JzdxRnCuY3SLCtLFlG0dD83U7O9TNEUVjz1vyqybgKfRhiPMSvz3hYsvFiQbXxuap+ykvtclLI54dZZ1HIxuHdB8dIHhqu1l7mHQatfVgXNbQCEVIMB1VmJcFMpjZYQ8PyuCxQ5yRXepzqxRYiIHId3bWCAmYXsDGesPL1RWgOlxSBpR/iS3cGFUv/2q3sPcPMo0Hqo1FVXWp32+m6oEUulFqi9n9/lh7Bzi3ubfhbWVGqVbez5rPz6uxcAjXvqF+H0Di2/fmUUZEoJQEUra2sKLUtIqkKdXf5O85a8r8FK5gBMr0KeHCe19KUZdKMabtBbcvx5W/PvYzgjMvVCxXEVGay3lFmcOBmuwaTOlqb8P1Bq3JsNsUXIjOjoaERERCAysqLJoERkF5r0ASKGSgvO+YcBHZ6QvtBHLNXXKb0Y3Jg1wEOfA4M/NW7t6ToVaD0MeMigr6JeJ8fYIPOBSq6aXNqdK9KKzPZm0xv644pakCrj6m7giw4Vbx2REW9+c+HyWLJiN2D9neYNVx8vkXCgeLNeg7WaDLccyUuTkqXy5N7WH6dVYjo+oG9BKj2rsjpW1q4EJkJmTJ06FXFxcYiJMdH3TkT2R+UKjPwRiHreuFyhlFqGvGqX3XzSKwjoPEFa18gwEWo9DHhsmfFKwoIgDey2No+7WGyuSe+yrSPBrSq/R5u11DazB501JJ2suE7J+KbKyk2VVp+uyKXtlt3PMOG24pYvlWJuYcqUOOMWpvP/6o9z04BvulVfTDm3pK7I8xuNy021XtkQEyEiqvkeXyHtcF56IUdDholQScuPiycQ8YjU2uQXVnYRPWsY+WPVX6t0lVq/DLn7SYmcHPzqy/O+Jdz95X1/AAhsIu2TVqL0QovNB9g2HlPUZqanZVw3XW4t2SnAmT/LLipp0bpb1YeJEBHVfIJQ8R5LbgZjjErGiwgCMHI5MHatdFzRmIjmAysfW0ibyr+mhEIlbWJryN0fuH8mMORLIPJZky+rkv4W7NruW9d671cVloxtatavcvcs3Z1aEaVL+fua+da1zqD7Z81MX7OEuUHOhq1D1eHSNtMD8C3Zt60aMREiIgKk9XP6zQPunQ7Ubm66TuenTe9ZNfhTYPZ145YAS1X2S/FlgyUCRLFs8uHhL30ZdxoH1GoKq+k2BZh6qPw6hl2JgNR151vPejFUxJLxOJUdj3LPU5Wrr3TR73VmSvsnpE16I58zX8cSwa2q/lpTyy3IyVwLlY0wESIiKtH9hfJ3Am/QDXj9GvBOOtDv//Tlkc9IX7AhrYGHSs2AmrARgCCtmD3sO5Rhas2k8vgYJD7q7LItQq4GX/SGM+l0sT4LTN5ftrw8XYs3f6hoPFPbkcbngU0q3pDXHMONPi1lyRiuyiRC3qFArzdMX4sYWn4M5hLAsEggqJk0qN8cS7r4LB2E7QiOLAXizayRZQNMhIiIKsPNW0peOj8NNLxPakUy1Plp43Eg9TsDr14Enlwr7fz9ZrJlX3QN7wMeX1m23HD379w0aVp5ibaPAV4Gaye5mRgTFd4NCIkAXjpVcQwA8HKc/jOW1/UU8QgQUGq/KKWrtEaTKYJCWh3cLAvX7Bn4icH7VdD9CVRu8HKn8YCricUb3XzN76hekgiVbBtjKKCh/lhh5uu35UPAixbM2jNMoEuvd+WIqmtpAgtwHSEioqpw9QLG/236mmH3mdJFmp1WwsUduGcssO8rfdnUQ9KMpOwUIPMGMPQb/eKPr14CPmkiHZdeBynnlrRR7cT/gPwMqdXJkKnB4SUrQPuHSferaAC4n0HLRnmJhqm1fZQq8600rt7Ao98D3/c2fd3SxQvDowzez4IWIXV2xXVK+ISYXjKh89PmE6qSP3tTiZC5pNBQVaaSu3gAhTbsXvIIMF5/qML6gWXXOQKkcXkFGdJx6STahtgiRERkbX3eARr3Asab2eai5ywgarK0TQgA1G4BdJ0M9H0HeHSR8QrYhkmUstSXcs4t6XfdjmWTIMC4a+zhhVJS5V1bXzbmt7KvsSaFi/nVvEXRuPXK0NBvYVGLUJvhxp/R1Pit0loMqrhOCc9axvFHTZKSt95vm9+qJe2K9LvTBOl3fYO16CyJT+Vu3JIXHFHxa6wx6yrIzLg4Uwy7Y185J7UymuJVG+j9lrTAaWlP/i4N6tfdU76B9kyEiIisrXZz4Kl1QMMepq+7eQMDPzRuzShPyZd3t+KxOiVfPK0eKv91wRFAi8HSHmtthhsnVYC0T9ubyUCoweDegEZS/VpNgQdMjI8Ztki6PrPUDLp2o8rWbfag+ZYDnxDpi9KUDqMrXukZkFrOjMZBmUieZsVLyyfMvCiNjQrrUvF9S5TuWgxqBrR7TGrp8jR4lqEGKzFnFk9B7zRBSoSfXCst0AkYjyszVJI0AVJyq1QBsxKkn9LbxADG7w1YJxHq9QbQY4b+vMtE83W9g/XHPqHSZzRF5QHc/6qU6Bt66xbQtK9xkqmUr4OKXWNERPZu+A/A9UP6HeNH/QKcXislN+VRugCjV5Rfx8UdmLQbiF0BnPodGLHE9CDrEu1HST+AlBAd+0lavbt+J+N6PnWB8K7AtX3G5U+uBXbMk6b3u3pJCdftiyij41jg+CogMdZ8LCo341aW0tOw+38gfZaWg6Vz79rSPmqetaQv6ZKkxZzSA9ENEzcfg67A4UuA6FK7ECgU+kS4/zyg56vmZwgafobMG9Lvkm5Nw0HRj/0IbJkDPFa8WnrnZ4DDP0jJxi6DsVKV5eIFhHeXuldLDPwYOLTIuN6QL6R93uJLbcZrqhsQkCYPlBj2nbSVyqifpcVPAaDjk8DpdUDEw1WP3QqYCBER2TtXT+OuL69aQJe7nH5dWocnpJ/KGPKlNMvOcODwg+8B+6P146fCu0kDmvd+AfT/P6kVqqnBOjujfwUWlkqiAKnV7Pmd0gadR3+UBmNn3AD2fQEknpC+/AHjVgV1jpRoxXwvzd7zMTFuydUTmH5COo5dAVzeISVUp/8wrtesHxBcvFJ21GRpZWvDdaIMly3wqy91W5rbJkMQyl8mQaGUlhq4tF1KAA31mg1c2CS1GrUeKv2UGPgR0HEMUKeDNMh6UfH4r0l7gBtHgL+mm4lHIbX+7F4gdY+GdZESxg5jgOTT0jgyU7MZO42Xfoe0kfaLK/lv0lTdVg8Dgxboz9s/Lv0YcvcDnt1iOkYbEkSxOrbTrTkyMzPh5+eHjIwM+PqWsyotERFJRNHyZQE0RcB390lbP5SYm2G+vilzi1uwBi2oWoJ4/TCwcZbUxeXiCdy5KrW+lNddk5OqH8T+9m1pxeTfngZ6vQn0fK1ycfd4GbhvprTfWXjXsuOqctOkmYbmZpqVuLQDyE7WJxxaLXDlP6krbedH0ibCnSZIXaSCILWOuZYzDX+uQctgq4eBUT/pz9MTpESzZAD93FLj0e4pldDJwNLvbyZCFWAiRERUzbRaaSuKzW9JSw8YthhZYvs8af+qCf/YdgPP85ul5KRpX+k8+5Y+ybDErk+AE2ukwcTmpuPL6eJWYNf/gAEfSK1O5X2u478CW96WkkBrrmh+F5gIWQkTISIiIsdj6fc3Z40RERGR02IiRERERE6LiRARERE5LSZCRERE5LSYCBEREZHTYiJERERETouJEBERETktJkJERETktJgIERERkdNiIkREREROi4mQGdHR0YiIiEBkZKTcoRAREVE14V5jFeBeY0RERI6He40RERERVYCJEBERETktldwB2LuSnsPMzEyZIyEiIiJLlXxvVzQCiIlQBbKysgAAYWFhMkdCRERElZWVlQU/Pz+z1zlYugJarRY3b96Ej48PBEGw2n0zMzMRFhaGhIQEDsKuZnzWtsHnbBt8zrbB52w71fWsRVFEVlYW6tatC4XC/EggtghVQKFQoH79+tV2f19fX/4lsxE+a9vgc7YNPmfb4HO2nep41uW1BJXgYGkiIiJyWkyEiIiIyGkxEZKJm5sb3nnnHbi5uckdSo3HZ20bfM62wedsG3zOtiP3s+ZgaSIiInJabBEiIiIip8VEiIiIiJwWEyEiIiJyWkyEiIiIyGkxEZJJdHQ0GjZsCHd3d0RFReHQoUNyh+Qw5s+fj8jISPj4+CA4OBhDhw7FuXPnjOrk5+dj6tSpqFWrFry9vTF8+HAkJycb1YmPj8fgwYPh6emJ4OBgvPrqqygqKrLlR3EoH374IQRBwEsvvaQr43O2nhs3buDJJ59ErVq14OHhgbZt2+Lw4cO666IoYs6cOahTpw48PDzQt29fXLhwwegeaWlpGDNmDHx9feHv749nnnkG2dnZtv4odkuj0eDtt99Go0aN4OHhgSZNmuD999832ouKz7lqdu3ahSFDhqBu3boQBAHr1q0zum6t53rixAncd999cHd3R1hYGD7++OO7D14km1u1apXo6uoqLlmyRDx9+rT43HPPif7+/mJycrLcoTmE/v37i0uXLhVPnTolxsbGioMGDRLDw8PF7OxsXZ1JkyaJYWFh4rZt28TDhw+LXbt2Fbt37667XlRUJLZp00bs27eveOzYMfGff/4Rg4KCxNmzZ8vxkezeoUOHxIYNG4rt2rUTp0+frivnc7aOtLQ0sUGDBuL48ePFgwcPipcvXxY3bdokXrx4UVfnww8/FP38/MR169aJx48fFx9++GGxUaNGYl5enq7OgAEDxPbt24sHDhwQd+/eLTZt2lQcPXq0HB/JLs2bN0+sVauW+Pfff4tXrlwR16xZI3p7e4tffPGFrg6fc9X8888/4ptvvimuXbtWBCD+8ccfRtet8VwzMjLEkJAQccyYMeKpU6fElStXih4eHuJ33313V7EzEZJBly5dxKlTp+rONRqNWLduXXH+/PkyRuW4UlJSRADizp07RVEUxfT0dNHFxUVcs2aNrs6ZM2dEAOL+/ftFUZT+0ioUCjEpKUlX55tvvhF9fX3FgoIC234AO5eVlSU2a9ZM3LJli9izZ09dIsTnbD2vv/662KNHD7PXtVqtGBoaKn7yySe6svT0dNHNzU1cuXKlKIqiGBcXJwIQY2JidHX+/fdfURAE8caNG9UXvAMZPHiw+PTTTxuVPfroo+KYMWNEUeRztpbSiZC1nuvXX38tBgQEGP2/4/XXXxdbtGhxV/Gya8zG1Go1jhw5gr59++rKFAoF+vbti/3798sYmePKyMgAAAQGBgIAjhw5gsLCQqNn3LJlS4SHh+ue8f79+9G2bVuEhITo6vTv3x+ZmZk4ffq0DaO3f1OnTsXgwYONnifA52xN69evR+fOnfHYY48hODgYHTt2xOLFi3XXr1y5gqSkJKNn7efnh6ioKKNn7e/vj86dO+vq9O3bFwqFAgcPHrTdh7Fj3bt3x7Zt23D+/HkAwPHjx7Fnzx4MHDgQAJ9zdbHWc92/fz/uv/9+uLq66ur0798f586dw507d6ocHzddtbHU1FRoNBqjLwYACAkJwdmzZ2WKynFptVq89NJLuPfee9GmTRsAQFJSElxdXeHv729UNyQkBElJSbo6pv4MSq6RZNWqVTh69ChiYmLKXONztp7Lly/jm2++wYwZM/DGG28gJiYGL774IlxdXTFu3DjdszL1LA2fdXBwsNF1lUqFwMBAPutis2bNQmZmJlq2bAmlUgmNRoN58+ZhzJgxAMDnXE2s9VyTkpLQqFGjMvcouRYQEFCl+JgIkUObOnUqTp06hT179sgdSo2TkJCA6dOnY8uWLXB3d5c7nBpNq9Wic+fO+OCDDwAAHTt2xKlTp/Dtt99i3LhxMkdXc6xevRq//PILVqxYgdatWyM2NhYvvfQS6taty+fsxNg1ZmNBQUFQKpVlZtYkJycjNDRUpqgc0wsvvIC///4bO3bsQP369XXloaGhUKvVSE9PN6pv+IxDQ0NN/hmUXCOp6yslJQX33HMPVCoVVCoVdu7ciS+//BIqlQohISF8zlZSp04dREREGJW1atUK8fHxAPTPqrz/b4SGhiIlJcXoelFREdLS0visi7366quYNWsWHn/8cbRt2xZjx47Fyy+/jPnz5wPgc64u1nqu1fX/EyZCNubq6opOnTph27ZtujKtVott27ahW7duMkbmOERRxAsvvIA//vgD27dvL9NU2qlTJ7i4uBg943PnziE+Pl73jLt164aTJ08a/cXbsmULfH19y3whOas+ffrg5MmTiI2N1f107twZY8aM0R3zOVvHvffeW2YJiPPnz6NBgwYAgEaNGiE0NNToWWdmZuLgwYNGzzo9PR1HjhzR1dm+fTu0Wi2ioqJs8CnsX25uLhQK4689pVIJrVYLgM+5uljruXbr1g27du1CYWGhrs6WLVvQokWLKneLAeD0eTmsWrVKdHNzE5ctWybGxcWJEydOFP39/Y1m1pB5kydPFv38/MT//vtPTExM1P3k5ubq6kyaNEkMDw8Xt2/fLh4+fFjs1q2b2K1bN931kmnd/fr1E2NjY8WNGzeKtWvX5rTuChjOGhNFPmdrOXTokKhSqcR58+aJFy5cEH/55RfR09NT/Pnnn3V1PvzwQ9Hf31/8888/xRMnToiPPPKIyenHHTt2FA8ePCju2bNHbNasmdNP6zY0btw4sV69errp82vXrhWDgoLE1157TVeHz7lqsrKyxGPHjonHjh0TAYiffvqpeOzYMfHatWuiKFrnuaanp4shISHi2LFjxVOnTomrVq0SPT09OX3eUX311VdieHi46OrqKnbp0kU8cOCA3CE5DAAmf5YuXaqrk5eXJ06ZMkUMCAgQPT09xWHDhomJiYlG97l69ao4cOBA0cPDQwwKChJfeeUVsbCw0MafxrGUToT4nK3nr7/+Etu0aSO6ubmJLVu2FBctWmR0XavVim+//bYYEhIiurm5iX369BHPnTtnVOf27dvi6NGjRW9vb9HX11ecMGGCmJWVZcuPYdcyMzPF6dOni+Hh4aK7u7vYuHFj8c033zSajs3nXDU7duww+f/lcePGiaJoved6/PhxsUePHqKbm5tYr1498cMPP7zr2AVRNFhSk4iIiMiJcIwQEREROS0mQkREROS0mAgRERGR02IiRERERE6LiRARERE5LSZCRERE5LSYCBEREZHTYiJERERETouJEBFRJQmCgHXr1skdBhFZARMhInIo48ePhyAIZX4GDBggd2hE5IBUcgdARFRZAwYMwNKlS43K3NzcZIqGiBwZW4SIyOG4ubkhNDTU6CcgIACA1G31zTffYODAgfDw8EDjxo3x22+/Gb3+5MmT6N27Nzw8PFCrVi1MnDgR2dnZRnWWLFmC1q1bw83NDXXq1MELL7xgdD01NRXDhg2Dp6cnmjVrhvXr11fvhyaiasFEiIhqnLfffhvDhw/H8ePHMWbMGDz++OM4c+YMACAnJwf9+/dHQEAAYmJisGbNGmzdutUo0fnmm28wdepUTJw4ESdPnsT69evRtGlTo/d49913MXLkSJw4cQKDBg3CmDFjkJaWZtPPSURWcNf71xMR2dC4ceNEpVIpenl5Gf3MmzdPFEVRBCBOmjTJ6DVRUVHi5MmTRVEUxUWLFokBAQFidna27vqGDRtEhUIhJiUliaIoinXr1hXffPNNszEAEN966y3deXZ2tghA/Pfff632OYnINjhGiIgcTq9evfDNN98YlQUGBuqOu3XrZnStW7duiI2NBQCcOXMG7du3h5eXl+76vffeC61Wi3PnzkEQBNy8eRN9+vQpN4Z27drpjr28vODr64uUlJSqfiQikgkTISJyOF5eXmW6qqzFw8PDonouLi5G54IgQKvVVkdIRFSNOEaIiGqcAwcOlDlv1aoVAKBVq1Y4fvw4cnJydNf37t0LhUKBFi1awMfHBw0bNsS2bdtsGjMRyYMtQkTkcAoKCpCUlGRUplKpEBQUBABYs2YNOnfujB49euCXX37BoUOH8MMPPwAAxowZg3feeQfjxo3D3LlzcevWLUybNg1jx45FSEgIAGDu3LmYNGkSgoODMXDgQGRlZWHv3r2YNm2abT8oEVU7JkJE5HA2btyIOnXqGJW1aNECZ8+eBSDN6Fq1ahWmTJmCOnXqYOXKlYiIiAAAeHp6YtOmTZg+fToiIyPh6emJ4cOH49NPP9Xda9y4ccjPz8dnn32GmTNnIigoCCNGjLDdByQimxFEURTlDoKIyFoEQcAff/yBoUOHyh0KETkAjhEiIiIip8VEiIiIiJwWxwgRUY3C3n4iqgy2CBEREZHTYiJERERETouJEBERETktJkJERETktJgIERERkdNiIkREREROi4kQEREROS0mQkREROS0/h+bLawcw5AdpQAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ],
      "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.xlabel('Epoch')\n",
        "plt.yscale('log')\n",
        "plt.ylabel('MSE')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 26,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "mohjVVWXY9d1",
        "outputId": "1918e8e0-8886-4c39-8640-d267f59a59d5"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Parameter containing:\n",
            "tensor([-0.2871, -1.9447, -1.3000, -1.8307, -1.7315, -1.2092, -0.5290,  0.2017,\n",
            "         0.6371,  0.8014,  0.5993,  0.2702,  0.0150, -0.1218, -0.1397, -0.1291,\n",
            "        -0.2165, -0.4464, -0.8217, -1.4153, -2.3619, -4.9654, -6.3879, -6.3834,\n",
            "        -6.3533, -6.3069, -6.4119, -4.5150, -2.9934, -2.0450, -2.3066, -0.3855],\n",
            "       requires_grad=True)\n"
          ]
        }
      ],
      "source": [
        "# Print the learned parameters and collect the coeafficients found by the model\n",
        "results_coefs_a = np.zeros(int(n_x/x_factor))\n",
        "for i, param in enumerate(model.parameters()):\n",
        "  print(param)\n",
        "  if i ==0:\n",
        "    for j in range(int(n_x/x_factor)):\n",
        "      results_coefs_a[j]=max_a*torch.sigmoid(param[j])"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "o2gtgZ_OwN1s"
      },
      "source": [
        "# Plot learned coefficients agains actual coeficients\n",
        "\n",
        "We use interpolation when comparing soltuions for more coarsened grids (i.e. we interpolate back to the original grid size)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 41,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "id": "tsDq4JmBZTiK",
        "outputId": "c0c9a618-95c8-40ff-c58f-2d8a4d8be454"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "[]"
            ]
          },
          "metadata": {},
          "execution_count": 41
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#Average the x_mesh to get approprioate x-coordinates (could used pooling but for 1D averaging is good enough)\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\n",
        "\n",
        "# Get data to interpolate - we ignore first and last two coeficients since they are not as accurate due to boundary conditions\n",
        "x_vals = x_mesh_avg[2:-2]\n",
        "y_vals = results_coefs_a[2:-2]\n",
        "\n",
        "coefs_interp = np.interp(xmesh.cpu(), x_vals.cpu(), y_vals)\n",
        "plt.rcParams['text.usetex'] = True\n",
        "\n",
        "# Plot predicted against actual coefficients\n",
        "plt.plot(xmesh.cpu(), coefs_interp)\n",
        "plt.plot(xmesh.cpu(), a_x.cpu())\n",
        "plt.scatter(x_vals.cpu(), y_vals, s=10)\n",
        "plt.xlim([x_vals[0].cpu(), x_vals[-1].cpu()])\n",
        "plt.legend(['Predicted', 'Ground truth'])\n",
        "plt.xlabel(r'$x$')\n",
        "plt.ylabel(r'$a(x)$')\n",
        "plt.plot()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "L79GlJDXxTlY"
      },
      "source": [
        "# Plot an example of a modelled solution against its fully resolved function"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 28,
      "metadata": {
        "id": "hDUsysWT7tNH"
      },
      "outputs": [],
      "source": [
        "#Plot an example solution\n",
        "test_data = 39\n",
        "sol_model_act = solutions_exact[test_data]\n",
        "\n",
        "#Sample our solution to 10 time steps\n",
        "sol_model_act_avg = torch.zeros((t_k, 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().detach().cpu().numpy()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 42,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 467
        },
        "id": "gjUbAHJv66UV",
        "outputId": "da64f7ef-6310-43be-f651-add4b407bf56"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.legend.Legend at 0x7af87a6a98a0>"
            ]
          },
          "metadata": {},
          "execution_count": 42
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#Plot our solutions to compare\n",
        "test_time = 1\n",
        "sol_interp = np.interp(xmesh.cpu(), x_mesh_avg.cpu(), sol_model_pred[test_time-1])\n",
        "\n",
        "plt.plot(xmesh.cpu(), sol_interp)\n",
        "plt.plot(xmesh.cpu(), sol_model_act_avg[test_time-1].cpu())\n",
        "plt.xlabel(r'$x$')\n",
        "plt.ylabel(r'$u(x, t_k)$')\n",
        "plt.legend(['Predicted','Ground truth'])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 30,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "uhn97u8uYr82",
        "outputId": "0c49a5ec-8103-45cd-8d48-25bdc795e0ad"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tensor(0.0057, grad_fn=<MaxBackward1>)"
            ]
          },
          "metadata": {},
          "execution_count": 30
        }
      ],
      "source": [
        "# Check the error on a specific input after passing it through the model and checking it with its output\n",
        "y = model(inputs[190].unsqueeze(0)).squeeze()[1]\n",
        "z = outputs[190][1]\n",
        "err = abs(y-z)\n",
        "torch.max(err)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "-Z3sC9wL2yOE"
      },
      "source": [
        "#Now we implement a fully connected neural net"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "XbQExbXI953a"
      },
      "source": [
        "Working with the heat equaiton $$u_t = a(x)u_{xx}$$"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "kLoxnfOaxge7"
      },
      "source": [
        "Input data - Initial conditions\n",
        "\n",
        "For now working with Dirichlet Boundary conditions\n",
        "\n",
        "Initial conditions: $$u(x,0) = (1-x)T_0 +xT_1 + \\sum_{i=1}^k c_isin(\\pi ix)$$\n",
        "\n",
        "$k = 10$ for the results presented today (note that larger $k$ values require finer grid size $n_x$ to generate good results).\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 31,
      "metadata": {
        "id": "pwj7ivxxHDB5"
      },
      "outputs": [],
      "source": [
        "# Define the Coarsened FD method as a 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 and comment out the section under #Define a simple 2-layer ReLU conv net\n",
        "# to run the fully cinnected 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, xmesh):\n",
        "    \"\"\"\n",
        "      xmesh: int\n",
        "        size of coarsened grid\n",
        "      W: matrix\n",
        "        Matrix for the coarsened FD method\n",
        "    \"\"\"\n",
        "    super(IndividualLayer_NN, self).__init__()\n",
        "\n",
        "    #Define a simple 2-layer ReLU MLP\n",
        "    # self.xmesh = xmesh\n",
        "    # self.layer1 = nn.Linear(self.xmesh, 32)\n",
        "    # self.activation = nn.ReLU()\n",
        "    # self.layer2 = nn.Linear(32, self.xmesh)\n",
        "\n",
        "    #Define a simple 2-layer ReLU conv net\n",
        "    self.xmesh = xmesh\n",
        "    self.layer1 = nn.Conv1d(1,16,3,1,1)\n",
        "    self.activation = nn.ReLU()\n",
        "    self.layer2 = nn.Conv1d(16,1,3,1,1)\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",
        "    #Linear layer 1\n",
        "    x2 = self.layer1(x)\n",
        "    #ReLU\n",
        "    x3 = self.activation(x2)\n",
        "    #Linear layer 2\n",
        "    y = self.layer2(x3)\n",
        "    return y"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 32,
      "metadata": {
        "id": "RApASrf1F6Qj"
      },
      "outputs": [],
      "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 for the t_k = 10 timesteps (manually change if t_k 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) t_k = 10 times to generate the next 10 time predictions in the coarsened grid\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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 33,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xww3qzQoGnov",
        "outputId": "65bb1fd4-1659-457d-feb7-e577904e0ba9"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Epoch: 0\n",
            "Train Loss: 0.45127833046411214 | Train Time: 0.216\n",
            "Valid Loss: 0.44292060285806656 | Valid Time: 0.012\n",
            "Epoch: 1\n",
            "Train Loss: 0.40246822175226715 | Train Time: 0.210\n",
            "Valid Loss: 0.3615000620484352 | Valid Time: 0.019\n",
            "Epoch: 2\n",
            "Train Loss: 0.33135342911670085 | Train Time: 0.199\n",
            "Valid Loss: 0.3270070031285286 | Valid Time: 0.015\n",
            "Epoch: 3\n",
            "Train Loss: 0.25832128132644455 | Train Time: 0.212\n",
            "Valid Loss: 0.23639825358986855 | Valid Time: 0.013\n",
            "Epoch: 4\n",
            "Train Loss: 0.2079348297495591 | Train Time: 0.195\n",
            "Valid Loss: 0.17822891101241112 | Valid Time: 0.015\n",
            "Epoch: 5\n",
            "Train Loss: 0.16219433671549746 | Train Time: 0.197\n",
            "Valid Loss: 0.14105955138802528 | Valid Time: 0.018\n",
            "Epoch: 6\n",
            "Train Loss: 0.109782968696795 | Train Time: 0.212\n",
            "Valid Loss: 0.07640187535434961 | Valid Time: 0.011\n",
            "Epoch: 7\n",
            "Train Loss: 0.051541535477889214 | Train Time: 0.206\n",
            "Valid Loss: 0.027678403537720442 | Valid Time: 0.013\n",
            "Epoch: 8\n",
            "Train Loss: 0.024653511219903043 | Train Time: 0.193\n",
            "Valid Loss: 0.022910647559911013 | Valid Time: 0.024\n",
            "Epoch: 9\n",
            "Train Loss: 0.01792961579600447 | Train Time: 0.200\n",
            "Valid Loss: 0.014250153908506036 | Valid Time: 0.015\n",
            "Epoch: 10\n",
            "Train Loss: 0.014258634593141707 | Train Time: 0.197\n",
            "Valid Loss: 0.011497915023937821 | Valid Time: 0.015\n",
            "Epoch: 11\n",
            "Train Loss: 0.011790271505321326 | Train Time: 0.217\n",
            "Valid Loss: 0.0102553591132164 | Valid Time: 0.012\n",
            "Epoch: 12\n",
            "Train Loss: 0.009832087708146949 | Train Time: 0.198\n",
            "Valid Loss: 0.009106859564781189 | Valid Time: 0.016\n",
            "Epoch: 13\n",
            "Train Loss: 0.008346123767918661 | Train Time: 0.197\n",
            "Valid Loss: 0.007019559969194233 | Valid Time: 0.016\n",
            "Epoch: 14\n",
            "Train Loss: 0.007403882980150611 | Train Time: 0.209\n",
            "Valid Loss: 0.006160861812531948 | Valid Time: 0.012\n",
            "Epoch: 15\n",
            "Train Loss: 0.006522680142600285 | Train Time: 0.319\n",
            "Valid Loss: 0.00538726628292352 | Valid Time: 0.019\n",
            "Epoch: 16\n",
            "Train Loss: 0.005801812794647719 | Train Time: 0.315\n",
            "Valid Loss: 0.004928487236611545 | Valid Time: 0.017\n",
            "Epoch: 17\n",
            "Train Loss: 0.005464680885013781 | Train Time: 0.305\n",
            "Valid Loss: 0.005511300405487418 | Valid Time: 0.017\n",
            "Epoch: 18\n",
            "Train Loss: 0.005182613177519096 | Train Time: 0.315\n",
            "Valid Loss: 0.004967258777469397 | Valid Time: 0.017\n",
            "Epoch: 19\n",
            "Train Loss: 0.005006365747632165 | Train Time: 0.312\n",
            "Valid Loss: 0.0044372378615662456 | Valid Time: 0.018\n",
            "Epoch: 20\n",
            "Train Loss: 0.004798620743186851 | Train Time: 0.302\n",
            "Valid Loss: 0.004352793097496033 | Valid Time: 0.017\n",
            "Epoch: 21\n",
            "Train Loss: 0.004646767788615666 | Train Time: 0.321\n",
            "Valid Loss: 0.004774741944856942 | Valid Time: 0.022\n",
            "Epoch: 22\n",
            "Train Loss: 0.004516532901968611 | Train Time: 0.328\n",
            "Valid Loss: 0.004332652606535703 | Valid Time: 0.012\n",
            "Epoch: 23\n",
            "Train Loss: 0.0044289936777204275 | Train Time: 0.204\n",
            "Valid Loss: 0.003570736473193392 | Valid Time: 0.015\n",
            "Epoch: 24\n",
            "Train Loss: 0.0044182532491456525 | Train Time: 0.188\n",
            "Valid Loss: 0.00450855540111661 | Valid Time: 0.011\n",
            "Epoch: 25\n",
            "Train Loss: 0.004329295302005975 | Train Time: 0.211\n",
            "Valid Loss: 0.0035581019474193454 | Valid Time: 0.012\n",
            "Epoch: 26\n",
            "Train Loss: 0.004237502457966146 | Train Time: 0.211\n",
            "Valid Loss: 0.0038074292824603617 | Valid Time: 0.011\n",
            "Epoch: 27\n",
            "Train Loss: 0.0041696351560715 | Train Time: 0.187\n",
            "Valid Loss: 0.004263295908458531 | Valid Time: 0.011\n",
            "Epoch: 28\n",
            "Train Loss: 0.004303724897143088 | Train Time: 0.191\n",
            "Valid Loss: 0.004104798950720578 | Valid Time: 0.011\n",
            "Epoch: 29\n",
            "Train Loss: 0.0042738408757079585 | Train Time: 0.197\n",
            "Valid Loss: 0.004150606575421989 | Valid Time: 0.019\n",
            "Epoch: 30\n",
            "Train Loss: 0.004195265876325338 | Train Time: 0.186\n",
            "Valid Loss: 0.004465116013307124 | Valid Time: 0.012\n",
            "Epoch: 31\n",
            "Train Loss: 0.004074750039236326 | Train Time: 0.212\n",
            "Valid Loss: 0.0038879788480699062 | Valid Time: 0.011\n",
            "Epoch: 32\n",
            "Train Loss: 0.0038927432370225064 | Train Time: 0.296\n",
            "Valid Loss: 0.0034728494938462973 | Valid Time: 0.017\n",
            "Epoch: 33\n",
            "Train Loss: 0.003908687736839056 | Train Time: 0.309\n",
            "Valid Loss: 0.0034361453144811094 | Valid Time: 0.017\n",
            "Epoch: 34\n",
            "Train Loss: 0.003817104697717648 | Train Time: 0.330\n",
            "Valid Loss: 0.0035145932342857122 | Valid Time: 0.018\n",
            "Epoch: 35\n",
            "Train Loss: 0.0037875754856749586 | Train Time: 0.320\n",
            "Valid Loss: 0.0035293620312586427 | Valid Time: 0.021\n",
            "Epoch: 36\n",
            "Train Loss: 0.0037829429769006217 | Train Time: 0.307\n",
            "Valid Loss: 0.0034311757190153003 | Valid Time: 0.017\n",
            "Epoch: 37\n",
            "Train Loss: 0.0037152404578304605 | Train Time: 0.313\n",
            "Valid Loss: 0.0038040715153329074 | Valid Time: 0.017\n",
            "Epoch: 38\n",
            "Train Loss: 0.003675812426464338 | Train Time: 0.319\n",
            "Valid Loss: 0.0030810018652118742 | Valid Time: 0.017\n",
            "Epoch: 39\n",
            "Train Loss: 0.003691379434282058 | Train Time: 0.337\n",
            "Valid Loss: 0.003179064311552793 | Valid Time: 0.019\n",
            "Epoch: 40\n",
            "Train Loss: 0.003566404277654855 | Train Time: 0.197\n",
            "Valid Loss: 0.0029942335095256567 | Valid Time: 0.022\n",
            "Epoch: 41\n",
            "Train Loss: 0.0036059193509189705 | Train Time: 0.193\n",
            "Valid Loss: 0.003413450380321592 | Valid Time: 0.015\n",
            "Epoch: 42\n",
            "Train Loss: 0.003756898945491565 | Train Time: 0.186\n",
            "Valid Loss: 0.0035465750843286514 | Valid Time: 0.011\n",
            "Epoch: 43\n",
            "Train Loss: 0.0036313354380820926 | Train Time: 0.194\n",
            "Valid Loss: 0.00296016811626032 | Valid Time: 0.012\n",
            "Epoch: 44\n",
            "Train Loss: 0.0036660833284258842 | Train Time: 0.194\n",
            "Valid Loss: 0.0034577311016619205 | Valid Time: 0.017\n",
            "Epoch: 45\n",
            "Train Loss: 0.003666116365868794 | Train Time: 0.209\n",
            "Valid Loss: 0.0033092417288571596 | Valid Time: 0.012\n",
            "Epoch: 46\n",
            "Train Loss: 0.003531385053831496 | Train Time: 0.189\n",
            "Valid Loss: 0.003086989338044077 | Valid Time: 0.014\n",
            "Epoch: 47\n",
            "Train Loss: 0.0035753269361234025 | Train Time: 0.197\n",
            "Valid Loss: 0.0031124078086577356 | Valid Time: 0.015\n",
            "Epoch: 48\n",
            "Train Loss: 0.0035686312169816935 | Train Time: 0.205\n",
            "Valid Loss: 0.0028459201857913285 | Valid Time: 0.015\n",
            "Epoch: 49\n",
            "Train Loss: 0.0034947615410936507 | Train Time: 0.191\n",
            "Valid Loss: 0.003873771638609469 | Valid Time: 0.014\n",
            "Epoch: 50\n",
            "Train Loss: 0.0036216918746695705 | Train Time: 0.216\n",
            "Valid Loss: 0.0029567605233751237 | Valid Time: 0.011\n",
            "Epoch: 51\n",
            "Train Loss: 0.003560620678686782 | Train Time: 0.200\n",
            "Valid Loss: 0.003200124716386199 | Valid Time: 0.016\n",
            "Epoch: 52\n",
            "Train Loss: 0.0034363642457480494 | Train Time: 0.195\n",
            "Valid Loss: 0.003481633961200714 | Valid Time: 0.017\n",
            "Epoch: 53\n",
            "Train Loss: 0.0034498858118527814 | Train Time: 0.192\n",
            "Valid Loss: 0.0029083522967994213 | Valid Time: 0.016\n",
            "Epoch: 54\n",
            "Train Loss: 0.003423550362257581 | Train Time: 0.206\n",
            "Valid Loss: 0.0030018239049240947 | Valid Time: 0.012\n",
            "Epoch: 55\n",
            "Train Loss: 0.0033997202194050737 | Train Time: 0.195\n",
            "Valid Loss: 0.002963548817206174 | Valid Time: 0.016\n",
            "Epoch: 56\n",
            "Train Loss: 0.0033600654845174992 | Train Time: 0.201\n",
            "Valid Loss: 0.002682020829524845 | Valid Time: 0.014\n",
            "Epoch: 57\n",
            "Train Loss: 0.0033243213486122457 | Train Time: 0.211\n",
            "Valid Loss: 0.0036530273500829935 | Valid Time: 0.012\n",
            "Epoch: 58\n",
            "Train Loss: 0.003327587337576245 | Train Time: 0.200\n",
            "Valid Loss: 0.003198469406925142 | Valid Time: 0.018\n",
            "Epoch: 59\n",
            "Train Loss: 0.0033918616582492463 | Train Time: 0.188\n",
            "Valid Loss: 0.002979711687657982 | Valid Time: 0.011\n",
            "Epoch: 60\n",
            "Train Loss: 0.0034724257788375803 | Train Time: 0.211\n",
            "Valid Loss: 0.0038369224639609456 | Valid Time: 0.012\n",
            "Epoch: 61\n",
            "Train Loss: 0.0034913021801529745 | Train Time: 0.188\n",
            "Valid Loss: 0.003051367588341236 | Valid Time: 0.012\n",
            "Epoch: 62\n",
            "Train Loss: 0.0033455193410382457 | Train Time: 0.197\n",
            "Valid Loss: 0.003435307356994599 | Valid Time: 0.011\n",
            "Epoch: 63\n",
            "Train Loss: 0.0033168903748063664 | Train Time: 0.201\n",
            "Valid Loss: 0.0030160563183017075 | Valid Time: 0.014\n",
            "Epoch: 64\n",
            "Train Loss: 0.003344238147531685 | Train Time: 0.195\n",
            "Valid Loss: 0.002907344955019653 | Valid Time: 0.021\n",
            "Epoch: 65\n",
            "Train Loss: 0.0032869958269752956 | Train Time: 0.198\n",
            "Valid Loss: 0.0031679916428402066 | Valid Time: 0.016\n",
            "Epoch: 66\n",
            "Train Loss: 0.0033299423705198264 | Train Time: 0.191\n",
            "Valid Loss: 0.0029250673251226544 | Valid Time: 0.018\n",
            "Epoch: 67\n",
            "Train Loss: 0.0032720460777023903 | Train Time: 0.204\n",
            "Valid Loss: 0.0031489304383285344 | Valid Time: 0.013\n",
            "Epoch: 68\n",
            "Train Loss: 0.0032328121045506314 | Train Time: 0.193\n",
            "Valid Loss: 0.002978247939608991 | Valid Time: 0.015\n",
            "Epoch: 69\n",
            "Train Loss: 0.0032330387958178393 | Train Time: 0.224\n",
            "Valid Loss: 0.0028127943514846265 | Valid Time: 0.012\n",
            "Epoch: 70\n",
            "Train Loss: 0.0033084355588806303 | Train Time: 0.204\n",
            "Valid Loss: 0.0028687590966001153 | Valid Time: 0.013\n",
            "Epoch: 71\n",
            "Train Loss: 0.0032432297073108586 | Train Time: 0.199\n",
            "Valid Loss: 0.0029323474154807627 | Valid Time: 0.015\n",
            "Epoch: 72\n",
            "Train Loss: 0.003368379327615625 | Train Time: 0.208\n",
            "Valid Loss: 0.0033089523785747588 | Valid Time: 0.013\n",
            "Epoch: 73\n",
            "Train Loss: 0.0033398716048778673 | Train Time: 0.192\n",
            "Valid Loss: 0.003240164485760033 | Valid Time: 0.016\n",
            "Epoch: 74\n",
            "Train Loss: 0.0033677524372347093 | Train Time: 0.221\n",
            "Valid Loss: 0.0030627011437900364 | Valid Time: 0.012\n",
            "Epoch: 75\n",
            "Train Loss: 0.0032362943441656077 | Train Time: 0.188\n",
            "Valid Loss: 0.0028944187215529382 | Valid Time: 0.021\n",
            "Epoch: 76\n",
            "Train Loss: 0.003137860226591951 | Train Time: 0.199\n",
            "Valid Loss: 0.0029397441539913416 | Valid Time: 0.015\n",
            "Epoch: 77\n",
            "Train Loss: 0.0031617273404998215 | Train Time: 0.198\n",
            "Valid Loss: 0.0025784873287193477 | Valid Time: 0.016\n",
            "Epoch: 78\n",
            "Train Loss: 0.0032114302616958555 | Train Time: 0.195\n",
            "Valid Loss: 0.002841305686160922 | Valid Time: 0.018\n",
            "Epoch: 79\n",
            "Train Loss: 0.003391812702542857 | Train Time: 0.214\n",
            "Valid Loss: 0.002887340437155217 | Valid Time: 0.013\n",
            "Epoch: 80\n",
            "Train Loss: 0.0031717628069025906 | Train Time: 0.211\n",
            "Valid Loss: 0.003045950725208968 | Valid Time: 0.011\n",
            "Epoch: 81\n",
            "Train Loss: 0.0032358281927085237 | Train Time: 0.208\n",
            "Valid Loss: 0.0027021276764571667 | Valid Time: 0.012\n",
            "Epoch: 82\n",
            "Train Loss: 0.0032460683540097976 | Train Time: 0.204\n",
            "Valid Loss: 0.0026904428377747536 | Valid Time: 0.013\n",
            "Epoch: 83\n",
            "Train Loss: 0.003177487830582418 | Train Time: 0.206\n",
            "Valid Loss: 0.002639124810229987 | Valid Time: 0.012\n",
            "Epoch: 84\n",
            "Train Loss: 0.0031751929292161214 | Train Time: 0.196\n",
            "Valid Loss: 0.0027478410047478974 | Valid Time: 0.016\n",
            "Epoch: 85\n",
            "Train Loss: 0.0030905979587451406 | Train Time: 0.207\n",
            "Valid Loss: 0.0026549046160653234 | Valid Time: 0.013\n",
            "Epoch: 86\n",
            "Train Loss: 0.0031188214933009525 | Train Time: 0.275\n",
            "Valid Loss: 0.003094250336289406 | Valid Time: 0.021\n",
            "Epoch: 87\n",
            "Train Loss: 0.0031323847728536316 | Train Time: 0.334\n",
            "Valid Loss: 0.0025744368322193623 | Valid Time: 0.017\n",
            "Epoch: 88\n",
            "Train Loss: 0.0032645233931314003 | Train Time: 0.310\n",
            "Valid Loss: 0.003428235766477883 | Valid Time: 0.017\n",
            "Epoch: 89\n",
            "Train Loss: 0.0031360588281562456 | Train Time: 0.330\n",
            "Valid Loss: 0.0027006808668375015 | Valid Time: 0.020\n",
            "Epoch: 90\n",
            "Train Loss: 0.003138101402376043 | Train Time: 0.312\n",
            "Valid Loss: 0.003028322651516646 | Valid Time: 0.018\n",
            "Epoch: 91\n",
            "Train Loss: 0.0033420038679124494 | Train Time: 0.309\n",
            "Valid Loss: 0.0028863208135589957 | Valid Time: 0.019\n",
            "Epoch: 92\n",
            "Train Loss: 0.0031633861485476557 | Train Time: 0.316\n",
            "Valid Loss: 0.0025463422934990376 | Valid Time: 0.017\n",
            "Epoch: 93\n",
            "Train Loss: 0.003042146857631834 | Train Time: 0.319\n",
            "Valid Loss: 0.0028924215584993362 | Valid Time: 0.022\n",
            "Epoch: 94\n",
            "Train Loss: 0.003301510293232767 | Train Time: 0.235\n",
            "Valid Loss: 0.0026944836135953665 | Valid Time: 0.011\n",
            "Epoch: 95\n",
            "Train Loss: 0.003156164023829134 | Train Time: 0.198\n",
            "Valid Loss: 0.002778085879981518 | Valid Time: 0.019\n",
            "Epoch: 96\n",
            "Train Loss: 0.003092789422034433 | Train Time: 0.201\n",
            "Valid Loss: 0.002634354226756841 | Valid Time: 0.015\n",
            "Epoch: 97\n",
            "Train Loss: 0.0031595205961677587 | Train Time: 0.199\n",
            "Valid Loss: 0.003207349800504744 | Valid Time: 0.015\n",
            "Epoch: 98\n",
            "Train Loss: 0.003193397369039686 | Train Time: 0.207\n",
            "Valid Loss: 0.0034244947601109743 | Valid Time: 0.012\n",
            "Epoch: 99\n",
            "Train Loss: 0.0033148655569867082 | Train Time: 0.209\n",
            "Valid Loss: 0.002565494301961735 | Valid Time: 0.013\n",
            "Epoch: 100\n",
            "Train Loss: 0.003027597405506592 | Train Time: 0.199\n",
            "Valid Loss: 0.0029339558095671237 | Valid Time: 0.016\n",
            "Epoch: 101\n",
            "Train Loss: 0.0031159475053611553 | Train Time: 0.199\n",
            "Valid Loss: 0.0027380702667869627 | Valid Time: 0.020\n",
            "Epoch: 102\n",
            "Train Loss: 0.003044125648509515 | Train Time: 0.193\n",
            "Valid Loss: 0.002674219198524952 | Valid Time: 0.018\n",
            "Epoch: 103\n",
            "Train Loss: 0.002994208081968521 | Train Time: 0.205\n",
            "Valid Loss: 0.002634301024954766 | Valid Time: 0.013\n",
            "Epoch: 104\n",
            "Train Loss: 0.0031297938947222733 | Train Time: 0.192\n",
            "Valid Loss: 0.0029926691786386073 | Valid Time: 0.020\n",
            "Epoch: 105\n",
            "Train Loss: 0.003082511701474064 | Train Time: 0.193\n",
            "Valid Loss: 0.002679557539522648 | Valid Time: 0.015\n",
            "Epoch: 106\n",
            "Train Loss: 0.0032986888269844806 | Train Time: 0.191\n",
            "Valid Loss: 0.0033989421790465713 | Valid Time: 0.018\n",
            "Epoch: 107\n",
            "Train Loss: 0.0034187536098455127 | Train Time: 0.191\n",
            "Valid Loss: 0.0026783329085446894 | Valid Time: 0.025\n",
            "Epoch: 108\n",
            "Train Loss: 0.003169056775636579 | Train Time: 0.196\n",
            "Valid Loss: 0.0027940767467953265 | Valid Time: 0.015\n",
            "Epoch: 109\n",
            "Train Loss: 0.003166679439968184 | Train Time: 0.197\n",
            "Valid Loss: 0.0028185671544633806 | Valid Time: 0.015\n",
            "Epoch: 110\n",
            "Train Loss: 0.0030578255506330415 | Train Time: 0.190\n",
            "Valid Loss: 0.002402248792350292 | Valid Time: 0.014\n",
            "Epoch: 111\n",
            "Train Loss: 0.0029973469086383518 | Train Time: 0.200\n",
            "Valid Loss: 0.0024391758488491178 | Valid Time: 0.015\n",
            "Epoch: 112\n",
            "Train Loss: 0.003036731094318001 | Train Time: 0.222\n",
            "Valid Loss: 0.002969249035231769 | Valid Time: 0.011\n",
            "Epoch: 113\n",
            "Train Loss: 0.003052196048788334 | Train Time: 0.196\n",
            "Valid Loss: 0.0027609762037172914 | Valid Time: 0.016\n",
            "Epoch: 114\n",
            "Train Loss: 0.0030001396631920024 | Train Time: 0.185\n",
            "Valid Loss: 0.0024754361365921795 | Valid Time: 0.013\n",
            "Epoch: 115\n",
            "Train Loss: 0.003027845198582662 | Train Time: 0.212\n",
            "Valid Loss: 0.003064802207518369 | Valid Time: 0.012\n",
            "Epoch: 116\n",
            "Train Loss: 0.0029589993952724492 | Train Time: 0.193\n",
            "Valid Loss: 0.002722481614910066 | Valid Time: 0.019\n",
            "Epoch: 117\n",
            "Train Loss: 0.0030633078667482265 | Train Time: 0.211\n",
            "Valid Loss: 0.0031631517922505736 | Valid Time: 0.012\n",
            "Epoch: 118\n",
            "Train Loss: 0.0029533905663380496 | Train Time: 0.207\n",
            "Valid Loss: 0.0026489502051845193 | Valid Time: 0.011\n",
            "Epoch: 119\n",
            "Train Loss: 0.002990939029443421 | Train Time: 0.197\n",
            "Valid Loss: 0.002813571540173143 | Valid Time: 0.018\n",
            "Epoch: 120\n",
            "Train Loss: 0.003007697823800539 | Train Time: 0.187\n",
            "Valid Loss: 0.0028293285868130624 | Valid Time: 0.011\n",
            "Epoch: 121\n",
            "Train Loss: 0.003219886878995519 | Train Time: 0.200\n",
            "Valid Loss: 0.0030703842639923096 | Valid Time: 0.011\n",
            "Epoch: 122\n",
            "Train Loss: 0.0033615317906400093 | Train Time: 0.208\n",
            "Valid Loss: 0.0026578118558973074 | Valid Time: 0.012\n",
            "Epoch: 123\n",
            "Train Loss: 0.0030738523499550005 | Train Time: 0.210\n",
            "Valid Loss: 0.002546684176195413 | Valid Time: 0.012\n",
            "Epoch: 124\n",
            "Train Loss: 0.0030018754033861975 | Train Time: 0.197\n",
            "Valid Loss: 0.002435119153233245 | Valid Time: 0.017\n",
            "Epoch: 125\n",
            "Train Loss: 0.002912202335305904 | Train Time: 0.195\n",
            "Valid Loss: 0.0025194082991220057 | Valid Time: 0.015\n",
            "Epoch: 126\n",
            "Train Loss: 0.002873820154682586 | Train Time: 0.198\n",
            "Valid Loss: 0.0024069043283816427 | Valid Time: 0.023\n",
            "Epoch: 127\n",
            "Train Loss: 0.003228620883371485 | Train Time: 0.189\n",
            "Valid Loss: 0.002977745491079986 | Valid Time: 0.013\n",
            "Epoch: 128\n",
            "Train Loss: 0.0031322468635871224 | Train Time: 0.199\n",
            "Valid Loss: 0.0025942876236513257 | Valid Time: 0.017\n",
            "Epoch: 129\n",
            "Train Loss: 0.003045736481190512 | Train Time: 0.197\n",
            "Valid Loss: 0.00281612848630175 | Valid Time: 0.015\n",
            "Epoch: 130\n",
            "Train Loss: 0.0030982893352445805 | Train Time: 0.191\n",
            "Valid Loss: 0.002790566999465227 | Valid Time: 0.015\n",
            "Epoch: 131\n",
            "Train Loss: 0.0029613273463359006 | Train Time: 0.206\n",
            "Valid Loss: 0.002253788465168327 | Valid Time: 0.012\n",
            "Epoch: 132\n",
            "Train Loss: 0.0029897579040966534 | Train Time: 0.202\n",
            "Valid Loss: 0.0031414784607477486 | Valid Time: 0.013\n",
            "Epoch: 133\n",
            "Train Loss: 0.003321149521262238 | Train Time: 0.199\n",
            "Valid Loss: 0.002804963616654277 | Valid Time: 0.016\n",
            "Epoch: 134\n",
            "Train Loss: 0.002988990114413594 | Train Time: 0.197\n",
            "Valid Loss: 0.0024769114097580314 | Valid Time: 0.015\n",
            "Epoch: 135\n",
            "Train Loss: 0.0029432541862326233 | Train Time: 0.194\n",
            "Valid Loss: 0.002760739007499069 | Valid Time: 0.015\n",
            "Epoch: 136\n",
            "Train Loss: 0.002914491281109421 | Train Time: 0.199\n",
            "Valid Loss: 0.0028267002780921757 | Valid Time: 0.017\n",
            "Epoch: 137\n",
            "Train Loss: 0.002882197241936075 | Train Time: 0.223\n",
            "Valid Loss: 0.0025288668693974614 | Valid Time: 0.013\n",
            "Epoch: 138\n",
            "Train Loss: 0.0028424940292576424 | Train Time: 0.201\n",
            "Valid Loss: 0.002518565859645605 | Valid Time: 0.018\n",
            "Epoch: 139\n",
            "Train Loss: 0.0028494230569585375 | Train Time: 0.193\n",
            "Valid Loss: 0.002739876334089786 | Valid Time: 0.018\n",
            "Epoch: 140\n",
            "Train Loss: 0.003017635636129662 | Train Time: 0.265\n",
            "Valid Loss: 0.0029244376928545535 | Valid Time: 0.019\n",
            "Epoch: 141\n",
            "Train Loss: 0.0031154399100495013 | Train Time: 0.322\n",
            "Valid Loss: 0.0023652144009247422 | Valid Time: 0.018\n",
            "Epoch: 142\n",
            "Train Loss: 0.003093151106057983 | Train Time: 0.309\n",
            "Valid Loss: 0.0032179626869037747 | Valid Time: 0.017\n",
            "Epoch: 143\n",
            "Train Loss: 0.0037406613486573883 | Train Time: 0.299\n",
            "Valid Loss: 0.004394575604237616 | Valid Time: 0.021\n",
            "Epoch: 144\n",
            "Train Loss: 0.003672564328697167 | Train Time: 0.324\n",
            "Valid Loss: 0.002884187735617161 | Valid Time: 0.017\n",
            "Epoch: 145\n",
            "Train Loss: 0.0030555438961049446 | Train Time: 0.326\n",
            "Valid Loss: 0.0028234131168574095 | Valid Time: 0.017\n",
            "Epoch: 146\n",
            "Train Loss: 0.0031052364257017247 | Train Time: 0.321\n",
            "Valid Loss: 0.0024675960885360837 | Valid Time: 0.022\n",
            "Epoch: 147\n",
            "Train Loss: 0.0028228610631470617 | Train Time: 0.329\n",
            "Valid Loss: 0.0028142291121184826 | Valid Time: 0.018\n",
            "Epoch: 148\n",
            "Train Loss: 0.0028665179362226474 | Train Time: 0.246\n",
            "Valid Loss: 0.002246184682007879 | Valid Time: 0.012\n",
            "Epoch: 149\n",
            "Train Loss: 0.002953866888817988 | Train Time: 0.193\n",
            "Valid Loss: 0.0027631635894067585 | Valid Time: 0.015\n",
            "Epoch: 150\n",
            "Train Loss: 0.0029794666916131973 | Train Time: 0.188\n",
            "Valid Loss: 0.0024709912249818444 | Valid Time: 0.011\n",
            "Epoch: 151\n",
            "Train Loss: 0.002968944989046768 | Train Time: 0.213\n",
            "Valid Loss: 0.0033757813507691026 | Valid Time: 0.011\n",
            "Epoch: 152\n",
            "Train Loss: 0.002923123991901153 | Train Time: 0.223\n",
            "Valid Loss: 0.00261608453001827 | Valid Time: 0.011\n",
            "Epoch: 153\n",
            "Train Loss: 0.0028710959993891024 | Train Time: 0.194\n",
            "Valid Loss: 0.0024944556644186378 | Valid Time: 0.016\n",
            "Epoch: 154\n",
            "Train Loss: 0.0028128347139021286 | Train Time: 0.196\n",
            "Valid Loss: 0.0024941989104263484 | Valid Time: 0.015\n",
            "Epoch: 155\n",
            "Train Loss: 0.002886459145596937 | Train Time: 0.225\n",
            "Valid Loss: 0.0025717509270180017 | Valid Time: 0.012\n",
            "Epoch: 156\n",
            "Train Loss: 0.003016569859985458 | Train Time: 0.199\n",
            "Valid Loss: 0.002441783086396754 | Valid Time: 0.017\n",
            "Epoch: 157\n",
            "Train Loss: 0.002961671837654553 | Train Time: 0.189\n",
            "Valid Loss: 0.0034943409264087677 | Valid Time: 0.011\n",
            "Epoch: 158\n",
            "Train Loss: 0.0030049913513817287 | Train Time: 0.215\n",
            "Valid Loss: 0.0023869721044320613 | Valid Time: 0.015\n",
            "Epoch: 159\n",
            "Train Loss: 0.0028740138820323503 | Train Time: 0.188\n",
            "Valid Loss: 0.002421805285848677 | Valid Time: 0.012\n",
            "Epoch: 160\n",
            "Train Loss: 0.0028939057864542854 | Train Time: 0.220\n",
            "Valid Loss: 0.002398812270257622 | Valid Time: 0.011\n",
            "Epoch: 161\n",
            "Train Loss: 0.002839978796576983 | Train Time: 0.207\n",
            "Valid Loss: 0.0024937801936175674 | Valid Time: 0.012\n",
            "Epoch: 162\n",
            "Train Loss: 0.0027930090743068015 | Train Time: 0.200\n",
            "Valid Loss: 0.0027757714269682765 | Valid Time: 0.018\n",
            "Epoch: 163\n",
            "Train Loss: 0.002774096253377042 | Train Time: 0.184\n",
            "Valid Loss: 0.0029300235328264534 | Valid Time: 0.011\n",
            "Epoch: 164\n",
            "Train Loss: 0.0028283033936627603 | Train Time: 0.199\n",
            "Valid Loss: 0.0025889863027259707 | Valid Time: 0.011\n",
            "Epoch: 165\n",
            "Train Loss: 0.0029837367443465873 | Train Time: 0.203\n",
            "Valid Loss: 0.0026124698342755437 | Valid Time: 0.013\n",
            "Epoch: 166\n",
            "Train Loss: 0.002879550937857283 | Train Time: 0.198\n",
            "Valid Loss: 0.0024200635380111635 | Valid Time: 0.015\n",
            "Epoch: 167\n",
            "Train Loss: 0.0027772936920978522 | Train Time: 0.200\n",
            "Valid Loss: 0.0023968297173269093 | Valid Time: 0.017\n",
            "Epoch: 168\n",
            "Train Loss: 0.002855260133449184 | Train Time: 0.202\n",
            "Valid Loss: 0.0028501880005933344 | Valid Time: 0.018\n",
            "Epoch: 169\n",
            "Train Loss: 0.002836914475713121 | Train Time: 0.197\n",
            "Valid Loss: 0.0026636061957105994 | Valid Time: 0.015\n",
            "Epoch: 170\n",
            "Train Loss: 0.002917125196147122 | Train Time: 0.206\n",
            "Valid Loss: 0.0025600044173188508 | Valid Time: 0.011\n",
            "Epoch: 171\n",
            "Train Loss: 0.002853503034106995 | Train Time: 0.194\n",
            "Valid Loss: 0.002767719968687743 | Valid Time: 0.015\n",
            "Epoch: 172\n",
            "Train Loss: 0.0027777922927941148 | Train Time: 0.196\n",
            "Valid Loss: 0.0023326480586547405 | Valid Time: 0.021\n",
            "Epoch: 173\n",
            "Train Loss: 0.0028423044193339976 | Train Time: 0.196\n",
            "Valid Loss: 0.002428441948723048 | Valid Time: 0.016\n",
            "Epoch: 174\n",
            "Train Loss: 0.002855472327945264 | Train Time: 0.209\n",
            "Valid Loss: 0.0023552314669359475 | Valid Time: 0.012\n",
            "Epoch: 175\n",
            "Train Loss: 0.0028505930799598758 | Train Time: 0.206\n",
            "Valid Loss: 0.002566554059740156 | Valid Time: 0.013\n",
            "Epoch: 176\n",
            "Train Loss: 0.0027818874284428986 | Train Time: 0.196\n",
            "Valid Loss: 0.002650182053912431 | Valid Time: 0.015\n",
            "Epoch: 177\n",
            "Train Loss: 0.002758283474433579 | Train Time: 0.196\n",
            "Valid Loss: 0.002375092124566436 | Valid Time: 0.015\n",
            "Epoch: 178\n",
            "Train Loss: 0.002800234691484978 | Train Time: 0.195\n",
            "Valid Loss: 0.002307742281118408 | Valid Time: 0.016\n",
            "Epoch: 179\n",
            "Train Loss: 0.0027799686588543026 | Train Time: 0.215\n",
            "Valid Loss: 0.002239464840386063 | Valid Time: 0.011\n",
            "Epoch: 180\n",
            "Train Loss: 0.0027766890554247717 | Train Time: 0.197\n",
            "Valid Loss: 0.002687441068701446 | Valid Time: 0.016\n",
            "Epoch: 181\n",
            "Train Loss: 0.0027888237596734576 | Train Time: 0.196\n",
            "Valid Loss: 0.0022463886707555503 | Valid Time: 0.015\n",
            "Epoch: 182\n",
            "Train Loss: 0.002816152305489308 | Train Time: 0.208\n",
            "Valid Loss: 0.002419053082121536 | Valid Time: 0.012\n",
            "Epoch: 183\n",
            "Train Loss: 0.002856947150767634 | Train Time: 0.193\n",
            "Valid Loss: 0.0028277082601562142 | Valid Time: 0.015\n",
            "Epoch: 184\n",
            "Train Loss: 0.0028617573215773233 | Train Time: 0.209\n",
            "Valid Loss: 0.0030614034039899707 | Valid Time: 0.011\n",
            "Epoch: 185\n",
            "Train Loss: 0.0028552047075017504 | Train Time: 0.194\n",
            "Valid Loss: 0.00349668285343796 | Valid Time: 0.018\n",
            "Epoch: 186\n",
            "Train Loss: 0.002792909912961094 | Train Time: 0.192\n",
            "Valid Loss: 0.002199087117332965 | Valid Time: 0.016\n",
            "Epoch: 187\n",
            "Train Loss: 0.002788111800327897 | Train Time: 0.196\n",
            "Valid Loss: 0.002389226807281375 | Valid Time: 0.016\n",
            "Epoch: 188\n",
            "Train Loss: 0.002802861780908547 | Train Time: 0.198\n",
            "Valid Loss: 0.002816091466229409 | Valid Time: 0.015\n",
            "Epoch: 189\n",
            "Train Loss: 0.0028311254236062892 | Train Time: 0.214\n",
            "Valid Loss: 0.0025469090905971825 | Valid Time: 0.011\n",
            "Epoch: 190\n",
            "Train Loss: 0.002768547850121793 | Train Time: 0.191\n",
            "Valid Loss: 0.0023672442766837776 | Valid Time: 0.014\n",
            "Epoch: 191\n",
            "Train Loss: 0.0027427928105584884 | Train Time: 0.195\n",
            "Valid Loss: 0.002202554256655276 | Valid Time: 0.016\n",
            "Epoch: 192\n",
            "Train Loss: 0.0028154721581622176 | Train Time: 0.192\n",
            "Valid Loss: 0.00252300756983459 | Valid Time: 0.015\n",
            "Epoch: 193\n",
            "Train Loss: 0.0029046207690905583 | Train Time: 0.201\n",
            "Valid Loss: 0.0022213685151655227 | Valid Time: 0.021\n",
            "Epoch: 194\n",
            "Train Loss: 0.002794314163589948 | Train Time: 0.239\n",
            "Valid Loss: 0.0024289246066473424 | Valid Time: 0.020\n",
            "Epoch: 195\n",
            "Train Loss: 0.002763248208027921 | Train Time: 0.318\n",
            "Valid Loss: 0.0022130259894765913 | Valid Time: 0.017\n",
            "Epoch: 196\n",
            "Train Loss: 0.0027137042856530138 | Train Time: 0.308\n",
            "Valid Loss: 0.002494195126928389 | Valid Time: 0.017\n",
            "Epoch: 197\n",
            "Train Loss: 0.0029889642089409264 | Train Time: 0.337\n",
            "Valid Loss: 0.0026781747001223266 | Valid Time: 0.017\n",
            "Epoch: 198\n",
            "Train Loss: 0.0029827272029299486 | Train Time: 0.320\n",
            "Valid Loss: 0.002764593460597098 | Valid Time: 0.017\n",
            "Epoch: 199\n",
            "Train Loss: 0.002800598863120142 | Train Time: 0.306\n",
            "Valid Loss: 0.002586162823718041 | Valid Time: 0.017\n",
            "Epoch: 200\n",
            "Train Loss: 0.002785177509251394 | Train Time: 0.330\n",
            "Valid Loss: 0.0024970031809061766 | Valid Time: 0.019\n",
            "Epoch: 201\n",
            "Train Loss: 0.002817976104683782 | Train Time: 0.320\n",
            "Valid Loss: 0.002136452414561063 | Valid Time: 0.020\n",
            "Epoch: 202\n",
            "Train Loss: 0.0030024153008860978 | Train Time: 0.220\n",
            "Valid Loss: 0.0023493420449085534 | Valid Time: 0.011\n",
            "Epoch: 203\n",
            "Train Loss: 0.0028676599705297697 | Train Time: 0.190\n",
            "Valid Loss: 0.0027821995900012553 | Valid Time: 0.014\n",
            "Epoch: 204\n",
            "Train Loss: 0.002804576468310858 | Train Time: 0.225\n",
            "Valid Loss: 0.0026223547174595296 | Valid Time: 0.011\n",
            "Epoch: 205\n",
            "Train Loss: 0.0027154212400905394 | Train Time: 0.187\n",
            "Valid Loss: 0.002550976991187781 | Valid Time: 0.012\n",
            "Epoch: 206\n",
            "Train Loss: 0.0027284869850662196 | Train Time: 0.205\n",
            "Valid Loss: 0.0021366785222198814 | Valid Time: 0.012\n",
            "Epoch: 207\n",
            "Train Loss: 0.002727897310825555 | Train Time: 0.200\n",
            "Valid Loss: 0.002217064640717581 | Valid Time: 0.016\n",
            "Epoch: 208\n",
            "Train Loss: 0.002766131411159509 | Train Time: 0.192\n",
            "Valid Loss: 0.0025848704390227795 | Valid Time: 0.015\n",
            "Epoch: 209\n",
            "Train Loss: 0.002771251908454456 | Train Time: 0.212\n",
            "Valid Loss: 0.002760219620540738 | Valid Time: 0.011\n",
            "Epoch: 210\n",
            "Train Loss: 0.0027560354578063675 | Train Time: 0.189\n",
            "Valid Loss: 0.002504868316464126 | Valid Time: 0.012\n",
            "Epoch: 211\n",
            "Train Loss: 0.0027865209665737653 | Train Time: 0.205\n",
            "Valid Loss: 0.002357599383685738 | Valid Time: 0.012\n",
            "Epoch: 212\n",
            "Train Loss: 0.0028311723328538633 | Train Time: 0.197\n",
            "Valid Loss: 0.002461177937220782 | Valid Time: 0.015\n",
            "Epoch: 213\n",
            "Train Loss: 0.002725103870034218 | Train Time: 0.203\n",
            "Valid Loss: 0.002183636010158807 | Valid Time: 0.015\n",
            "Epoch: 214\n",
            "Train Loss: 0.002732682703553062 | Train Time: 0.195\n",
            "Valid Loss: 0.002359356149099767 | Valid Time: 0.015\n",
            "Epoch: 215\n",
            "Train Loss: 0.0027663449413682286 | Train Time: 0.218\n",
            "Valid Loss: 0.002419557480607182 | Valid Time: 0.011\n",
            "Epoch: 216\n",
            "Train Loss: 0.0026587278606664193 | Train Time: 0.197\n",
            "Valid Loss: 0.0024572500260546803 | Valid Time: 0.016\n",
            "Epoch: 217\n",
            "Train Loss: 0.0027754004848630806 | Train Time: 0.193\n",
            "Valid Loss: 0.002647302928380668 | Valid Time: 0.015\n",
            "Epoch: 218\n",
            "Train Loss: 0.0029358729891675083 | Train Time: 0.216\n",
            "Valid Loss: 0.0024829554022289813 | Valid Time: 0.011\n",
            "Epoch: 219\n",
            "Train Loss: 0.002785743385749428 | Train Time: 0.207\n",
            "Valid Loss: 0.0027050930075347424 | Valid Time: 0.015\n",
            "Epoch: 220\n",
            "Train Loss: 0.0027608373937638184 | Train Time: 0.192\n",
            "Valid Loss: 0.0024005770101211965 | Valid Time: 0.015\n",
            "Epoch: 221\n",
            "Train Loss: 0.002704050024285128 | Train Time: 0.200\n",
            "Valid Loss: 0.0022844800259917974 | Valid Time: 0.015\n",
            "Epoch: 222\n",
            "Train Loss: 0.002757595165779716 | Train Time: 0.205\n",
            "Valid Loss: 0.002168086648453027 | Valid Time: 0.015\n",
            "Epoch: 223\n",
            "Train Loss: 0.003037153596156522 | Train Time: 0.223\n",
            "Valid Loss: 0.002947795786894858 | Valid Time: 0.011\n",
            "Epoch: 224\n",
            "Train Loss: 0.0030648954041106137 | Train Time: 0.189\n",
            "Valid Loss: 0.002288623829372227 | Valid Time: 0.013\n",
            "Epoch: 225\n",
            "Train Loss: 0.002690296865215427 | Train Time: 0.199\n",
            "Valid Loss: 0.002212964987847954 | Valid Time: 0.017\n",
            "Epoch: 226\n",
            "Train Loss: 0.002718883260202251 | Train Time: 0.195\n",
            "Valid Loss: 0.0026965229772031307 | Valid Time: 0.015\n",
            "Epoch: 227\n",
            "Train Loss: 0.0028293845121209558 | Train Time: 0.185\n",
            "Valid Loss: 0.0022930731647647917 | Valid Time: 0.011\n",
            "Epoch: 228\n",
            "Train Loss: 0.002688903753694735 | Train Time: 0.208\n",
            "Valid Loss: 0.00232529389904812 | Valid Time: 0.011\n",
            "Epoch: 229\n",
            "Train Loss: 0.002660744382362617 | Train Time: 0.195\n",
            "Valid Loss: 0.0020951606275048107 | Valid Time: 0.016\n",
            "Epoch: 230\n",
            "Train Loss: 0.0029463528925062796 | Train Time: 0.202\n",
            "Valid Loss: 0.0035552988410927355 | Valid Time: 0.013\n",
            "Epoch: 231\n",
            "Train Loss: 0.0029614054916524573 | Train Time: 0.188\n",
            "Valid Loss: 0.0026222452288493514 | Valid Time: 0.013\n",
            "Epoch: 232\n",
            "Train Loss: 0.0030087986838464673 | Train Time: 0.217\n",
            "Valid Loss: 0.002626114815939218 | Valid Time: 0.013\n",
            "Epoch: 233\n",
            "Train Loss: 0.002738005812524965 | Train Time: 0.193\n",
            "Valid Loss: 0.002409602573607117 | Valid Time: 0.017\n",
            "Epoch: 234\n",
            "Train Loss: 0.0028073828189486734 | Train Time: 0.193\n",
            "Valid Loss: 0.0021940495062153786 | Valid Time: 0.016\n",
            "Epoch: 235\n",
            "Train Loss: 0.002774939798799 | Train Time: 0.195\n",
            "Valid Loss: 0.0024055186077021062 | Valid Time: 0.016\n",
            "Epoch: 236\n",
            "Train Loss: 0.0027324387338012457 | Train Time: 0.198\n",
            "Valid Loss: 0.002367433247854933 | Valid Time: 0.016\n",
            "Epoch: 237\n",
            "Train Loss: 0.0027373655527634056 | Train Time: 0.213\n",
            "Valid Loss: 0.0024773216573521495 | Valid Time: 0.011\n",
            "Epoch: 238\n",
            "Train Loss: 0.0029098793594656805 | Train Time: 0.188\n",
            "Valid Loss: 0.00226764619583264 | Valid Time: 0.011\n",
            "Epoch: 239\n",
            "Train Loss: 0.0028088949008011504 | Train Time: 0.191\n",
            "Valid Loss: 0.002720719843637198 | Valid Time: 0.011\n",
            "Epoch: 240\n",
            "Train Loss: 0.0026811686050342886 | Train Time: 0.198\n",
            "Valid Loss: 0.0021315041522029787 | Valid Time: 0.011\n",
            "Epoch: 241\n",
            "Train Loss: 0.0026651473691392887 | Train Time: 0.202\n",
            "Valid Loss: 0.0022151210578158498 | Valid Time: 0.015\n",
            "Epoch: 242\n",
            "Train Loss: 0.0028664091552950835 | Train Time: 0.199\n",
            "Valid Loss: 0.0024736321647651494 | Valid Time: 0.015\n",
            "Epoch: 243\n",
            "Train Loss: 0.00269886358690105 | Train Time: 0.198\n",
            "Valid Loss: 0.0022400690359063447 | Valid Time: 0.015\n",
            "Epoch: 244\n",
            "Train Loss: 0.002901976107080516 | Train Time: 0.189\n",
            "Valid Loss: 0.0025389051297679543 | Valid Time: 0.014\n",
            "Epoch: 245\n",
            "Train Loss: 0.002782499613730531 | Train Time: 0.199\n",
            "Valid Loss: 0.0027215105365030468 | Valid Time: 0.016\n",
            "Epoch: 246\n",
            "Train Loss: 0.0028487397970533685 | Train Time: 0.201\n",
            "Valid Loss: 0.002542990230722353 | Valid Time: 0.014\n",
            "Epoch: 247\n",
            "Train Loss: 0.002816872046280064 | Train Time: 0.208\n",
            "Valid Loss: 0.0022451587137766182 | Valid Time: 0.011\n",
            "Epoch: 248\n",
            "Train Loss: 0.0027399888249898426 | Train Time: 0.231\n",
            "Valid Loss: 0.0023554965446237475 | Valid Time: 0.018\n",
            "Epoch: 249\n",
            "Train Loss: 0.0027336494654024903 | Train Time: 0.317\n",
            "Valid Loss: 0.0028900355100631714 | Valid Time: 0.017\n",
            "Epoch: 250\n",
            "Train Loss: 0.0028927983520062347 | Train Time: 0.322\n",
            "Valid Loss: 0.002328246831893921 | Valid Time: 0.017\n",
            "Epoch: 251\n",
            "Train Loss: 0.0027811867062394555 | Train Time: 0.325\n",
            "Valid Loss: 0.0025005563511513174 | Valid Time: 0.017\n",
            "Epoch: 252\n",
            "Train Loss: 0.0028172697700364025 | Train Time: 0.315\n",
            "Valid Loss: 0.002742268843576312 | Valid Time: 0.018\n",
            "Epoch: 253\n",
            "Train Loss: 0.0027042010394660266 | Train Time: 0.318\n",
            "Valid Loss: 0.002341984072700143 | Valid Time: 0.027\n",
            "Epoch: 254\n",
            "Train Loss: 0.0026700776805611034 | Train Time: 0.309\n",
            "Valid Loss: 0.0021303083340171725 | Valid Time: 0.021\n",
            "Epoch: 255\n",
            "Train Loss: 0.0026158124306484274 | Train Time: 0.327\n",
            "Valid Loss: 0.0026425891555845737 | Valid Time: 0.018\n",
            "Epoch: 256\n",
            "Train Loss: 0.0027224561628444413 | Train Time: 0.263\n",
            "Valid Loss: 0.0024809924652799964 | Valid Time: 0.011\n",
            "Epoch: 257\n",
            "Train Loss: 0.002649336048450909 | Train Time: 0.212\n",
            "Valid Loss: 0.002459609182551503 | Valid Time: 0.011\n",
            "Epoch: 258\n",
            "Train Loss: 0.0026191453768038436 | Train Time: 0.190\n",
            "Valid Loss: 0.0022677985834889114 | Valid Time: 0.013\n",
            "Epoch: 259\n",
            "Train Loss: 0.0026676541463913103 | Train Time: 0.210\n",
            "Valid Loss: 0.0024049105122685432 | Valid Time: 0.013\n",
            "Epoch: 260\n",
            "Train Loss: 0.0026664495541665113 | Train Time: 0.190\n",
            "Valid Loss: 0.0023397094919346273 | Valid Time: 0.011\n",
            "Epoch: 261\n",
            "Train Loss: 0.0026135952211916447 | Train Time: 0.191\n",
            "Valid Loss: 0.0022421152389142662 | Valid Time: 0.012\n",
            "Epoch: 262\n",
            "Train Loss: 0.0027001039982822383 | Train Time: 0.215\n",
            "Valid Loss: 0.0027444681618362665 | Valid Time: 0.012\n",
            "Epoch: 263\n",
            "Train Loss: 0.002970683118818622 | Train Time: 0.199\n",
            "Valid Loss: 0.00246643484570086 | Valid Time: 0.020\n",
            "Epoch: 264\n",
            "Train Loss: 0.0026367357932031155 | Train Time: 0.198\n",
            "Valid Loss: 0.002427580184303224 | Valid Time: 0.018\n",
            "Epoch: 265\n",
            "Train Loss: 0.002659176905198317 | Train Time: 0.194\n",
            "Valid Loss: 0.0025830629747360945 | Valid Time: 0.017\n",
            "Epoch: 266\n",
            "Train Loss: 0.0026399193356107724 | Train Time: 0.215\n",
            "Valid Loss: 0.0028442502953112125 | Valid Time: 0.012\n",
            "Epoch: 267\n",
            "Train Loss: 0.00269176496045762 | Train Time: 0.193\n",
            "Valid Loss: 0.0023650607326999307 | Valid Time: 0.014\n",
            "Epoch: 268\n",
            "Train Loss: 0.002909246145894653 | Train Time: 0.189\n",
            "Valid Loss: 0.0025554803432896733 | Valid Time: 0.015\n",
            "Epoch: 269\n",
            "Train Loss: 0.002642016784337006 | Train Time: 0.204\n",
            "Valid Loss: 0.002600384410470724 | Valid Time: 0.013\n",
            "Epoch: 270\n",
            "Train Loss: 0.002662845139734839 | Train Time: 0.193\n",
            "Valid Loss: 0.0023895474732853472 | Valid Time: 0.014\n",
            "Epoch: 271\n",
            "Train Loss: 0.0026832788349374346 | Train Time: 0.198\n",
            "Valid Loss: 0.0028543300868477672 | Valid Time: 0.016\n",
            "Epoch: 272\n",
            "Train Loss: 0.002825702779534224 | Train Time: 0.195\n",
            "Valid Loss: 0.0028403964242897928 | Valid Time: 0.015\n",
            "Epoch: 273\n",
            "Train Loss: 0.002799984276000606 | Train Time: 0.202\n",
            "Valid Loss: 0.002382013131864369 | Valid Time: 0.013\n",
            "Epoch: 274\n",
            "Train Loss: 0.002641903089457437 | Train Time: 0.188\n",
            "Valid Loss: 0.0026310134562663734 | Valid Time: 0.011\n",
            "Epoch: 275\n",
            "Train Loss: 0.002797117995980539 | Train Time: 0.196\n",
            "Valid Loss: 0.002261575253214687 | Valid Time: 0.011\n",
            "Epoch: 276\n",
            "Train Loss: 0.002571425094318233 | Train Time: 0.213\n",
            "Valid Loss: 0.002202782256063074 | Valid Time: 0.012\n",
            "Epoch: 277\n",
            "Train Loss: 0.002792735731131152 | Train Time: 0.188\n",
            "Valid Loss: 0.002811912272591144 | Valid Time: 0.011\n",
            "Epoch: 278\n",
            "Train Loss: 0.002914248598053267 | Train Time: 0.204\n",
            "Valid Loss: 0.0023898311192169785 | Valid Time: 0.016\n",
            "Epoch: 279\n",
            "Train Loss: 0.002577184638204543 | Train Time: 0.192\n",
            "Valid Loss: 0.002238249289803207 | Valid Time: 0.015\n",
            "Epoch: 280\n",
            "Train Loss: 0.0027470206719283994 | Train Time: 0.196\n",
            "Valid Loss: 0.0026096723158843815 | Valid Time: 0.016\n",
            "Epoch: 281\n",
            "Train Loss: 0.002970923473568339 | Train Time: 0.208\n",
            "Valid Loss: 0.0024757111095823348 | Valid Time: 0.011\n",
            "Epoch: 282\n",
            "Train Loss: 0.002839698113108936 | Train Time: 0.192\n",
            "Valid Loss: 0.0022684686409775168 | Valid Time: 0.013\n",
            "Epoch: 283\n",
            "Train Loss: 0.0026787252925140293 | Train Time: 0.197\n",
            "Valid Loss: 0.002650313370395452 | Valid Time: 0.017\n",
            "Epoch: 284\n",
            "Train Loss: 0.002773654206018699 | Train Time: 0.193\n",
            "Valid Loss: 0.00235126813640818 | Valid Time: 0.016\n",
            "Epoch: 285\n",
            "Train Loss: 0.002618678925117772 | Train Time: 0.192\n",
            "Valid Loss: 0.0023682572063989937 | Valid Time: 0.014\n",
            "Epoch: 286\n",
            "Train Loss: 0.002737734129799432 | Train Time: 0.209\n",
            "Valid Loss: 0.0022878250456415117 | Valid Time: 0.013\n",
            "Epoch: 287\n",
            "Train Loss: 0.002646858424046322 | Train Time: 0.198\n",
            "Valid Loss: 0.002546659845393151 | Valid Time: 0.021\n",
            "Epoch: 288\n",
            "Train Loss: 0.0028050002936077746 | Train Time: 0.198\n",
            "Valid Loss: 0.0029646114562638104 | Valid Time: 0.021\n",
            "Epoch: 289\n",
            "Train Loss: 0.002670729263244491 | Train Time: 0.186\n",
            "Valid Loss: 0.002231756050605327 | Valid Time: 0.011\n",
            "Epoch: 290\n",
            "Train Loss: 0.0026756971094169116 | Train Time: 0.209\n",
            "Valid Loss: 0.0025031538389157504 | Valid Time: 0.013\n",
            "Epoch: 291\n",
            "Train Loss: 0.002564996738280905 | Train Time: 0.192\n",
            "Valid Loss: 0.002204405318479985 | Valid Time: 0.016\n",
            "Epoch: 292\n",
            "Train Loss: 0.002605398933060075 | Train Time: 0.202\n",
            "Valid Loss: 0.0023332443088293076 | Valid Time: 0.014\n",
            "Epoch: 293\n",
            "Train Loss: 0.002661044635858975 | Train Time: 0.198\n",
            "Valid Loss: 0.0024467501207254827 | Valid Time: 0.016\n",
            "Epoch: 294\n",
            "Train Loss: 0.0026582939868890925 | Train Time: 0.197\n",
            "Valid Loss: 0.001960139547009021 | Valid Time: 0.015\n",
            "Epoch: 295\n",
            "Train Loss: 0.002542242309764812 | Train Time: 0.206\n",
            "Valid Loss: 0.002430011867545545 | Valid Time: 0.013\n",
            "Epoch: 296\n",
            "Train Loss: 0.0027763118330193194 | Train Time: 0.209\n",
            "Valid Loss: 0.0024159817839972675 | Valid Time: 0.012\n",
            "Epoch: 297\n",
            "Train Loss: 0.002666476905640019 | Train Time: 0.198\n",
            "Valid Loss: 0.0024250532733276486 | Valid Time: 0.015\n",
            "Epoch: 298\n",
            "Train Loss: 0.002620785999552984 | Train Time: 0.202\n",
            "Valid Loss: 0.0023700861784163862 | Valid Time: 0.013\n",
            "Epoch: 299\n",
            "Train Loss: 0.002815552876870099 | Train Time: 0.187\n",
            "Valid Loss: 0.002314763085450977 | Valid Time: 0.011\n",
            "Epoch: 300\n",
            "Train Loss: 0.0026507232901885323 | Train Time: 0.211\n",
            "Valid Loss: 0.002065344393486157 | Valid Time: 0.012\n",
            "Epoch: 301\n",
            "Train Loss: 0.002625468671076784 | Train Time: 0.205\n",
            "Valid Loss: 0.002231147896964103 | Valid Time: 0.014\n",
            "Epoch: 302\n",
            "Train Loss: 0.002646756824105978 | Train Time: 0.186\n",
            "Valid Loss: 0.0026105731376446784 | Valid Time: 0.012\n",
            "Epoch: 303\n",
            "Train Loss: 0.0027440175732695742 | Train Time: 0.306\n",
            "Valid Loss: 0.002466212259605527 | Valid Time: 0.017\n",
            "Epoch: 304\n",
            "Train Loss: 0.0026213593388858592 | Train Time: 0.310\n",
            "Valid Loss: 0.002765220415312797 | Valid Time: 0.017\n",
            "Epoch: 305\n",
            "Train Loss: 0.002727309634026728 | Train Time: 0.312\n",
            "Valid Loss: 0.002170480787754059 | Valid Time: 0.021\n",
            "Epoch: 306\n",
            "Train Loss: 0.002627080036817413 | Train Time: 0.311\n",
            "Valid Loss: 0.0027179705211892724 | Valid Time: 0.020\n",
            "Epoch: 307\n",
            "Train Loss: 0.002869045582452887 | Train Time: 0.313\n",
            "Valid Loss: 0.001999179716221988 | Valid Time: 0.017\n",
            "Epoch: 308\n",
            "Train Loss: 0.002820989031246618 | Train Time: 0.324\n",
            "Valid Loss: 0.0025629623560234904 | Valid Time: 0.017\n",
            "Epoch: 309\n",
            "Train Loss: 0.0027654635303310656 | Train Time: 0.326\n",
            "Valid Loss: 0.003027254599146545 | Valid Time: 0.017\n",
            "Epoch: 310\n",
            "Train Loss: 0.002833134752061022 | Train Time: 0.335\n",
            "Valid Loss: 0.0023348592803813517 | Valid Time: 0.013\n",
            "Epoch: 311\n",
            "Train Loss: 0.002915194932077276 | Train Time: 0.206\n",
            "Valid Loss: 0.003304111072793603 | Valid Time: 0.011\n",
            "Epoch: 312\n",
            "Train Loss: 0.0030517456991794078 | Train Time: 0.205\n",
            "Valid Loss: 0.002046036213869229 | Valid Time: 0.013\n",
            "Epoch: 313\n",
            "Train Loss: 0.0027401965283053486 | Train Time: 0.199\n",
            "Valid Loss: 0.0023394901654683053 | Valid Time: 0.015\n",
            "Epoch: 314\n",
            "Train Loss: 0.0026978519009916405 | Train Time: 0.193\n",
            "Valid Loss: 0.0023477092618122697 | Valid Time: 0.014\n",
            "Epoch: 315\n",
            "Train Loss: 0.00258833766106124 | Train Time: 0.210\n",
            "Valid Loss: 0.002621042018290609 | Valid Time: 0.018\n",
            "Epoch: 316\n",
            "Train Loss: 0.002584310787680902 | Train Time: 0.186\n",
            "Valid Loss: 0.0018977289146278054 | Valid Time: 0.012\n",
            "Epoch: 317\n",
            "Train Loss: 0.00261754596507863 | Train Time: 0.201\n",
            "Valid Loss: 0.0022743955196347088 | Valid Time: 0.018\n",
            "Epoch: 318\n",
            "Train Loss: 0.0027109602294666203 | Train Time: 0.192\n",
            "Valid Loss: 0.0023476873757317662 | Valid Time: 0.015\n",
            "Epoch: 319\n",
            "Train Loss: 0.0026372529345711597 | Train Time: 0.191\n",
            "Valid Loss: 0.0019694191578309983 | Valid Time: 0.018\n",
            "Epoch: 320\n",
            "Train Loss: 0.0025359350501706727 | Train Time: 0.215\n",
            "Valid Loss: 0.0022495921002700925 | Valid Time: 0.012\n",
            "Epoch: 321\n",
            "Train Loss: 0.002711782844639138 | Train Time: 0.192\n",
            "Valid Loss: 0.0030618138262070715 | Valid Time: 0.014\n",
            "Epoch: 322\n",
            "Train Loss: 0.002729916099556967 | Train Time: 0.205\n",
            "Valid Loss: 0.0021408883621916175 | Valid Time: 0.012\n",
            "Epoch: 323\n",
            "Train Loss: 0.0025225432565141666 | Train Time: 0.196\n",
            "Valid Loss: 0.0023806410026736557 | Valid Time: 0.016\n",
            "Epoch: 324\n",
            "Train Loss: 0.0025850953411703046 | Train Time: 0.205\n",
            "Valid Loss: 0.0022144322865642607 | Valid Time: 0.012\n",
            "Epoch: 325\n",
            "Train Loss: 0.0025869871820568256 | Train Time: 0.205\n",
            "Valid Loss: 0.0021507440542336553 | Valid Time: 0.013\n",
            "Epoch: 326\n",
            "Train Loss: 0.0025642139494026963 | Train Time: 0.196\n",
            "Valid Loss: 0.0020822040969505906 | Valid Time: 0.016\n",
            "Epoch: 327\n",
            "Train Loss: 0.002526854759229249 | Train Time: 0.192\n",
            "Valid Loss: 0.0024289948341902345 | Valid Time: 0.019\n",
            "Epoch: 328\n",
            "Train Loss: 0.0025397586501448564 | Train Time: 0.195\n",
            "Valid Loss: 0.002401346602709964 | Valid Time: 0.016\n",
            "Epoch: 329\n",
            "Train Loss: 0.0026210092963944924 | Train Time: 0.220\n",
            "Valid Loss: 0.0029174659866839647 | Valid Time: 0.012\n",
            "Epoch: 330\n",
            "Train Loss: 0.0027741994953861364 | Train Time: 0.191\n",
            "Valid Loss: 0.002086685912217945 | Valid Time: 0.018\n",
            "Epoch: 331\n",
            "Train Loss: 0.002747875613797652 | Train Time: 0.196\n",
            "Valid Loss: 0.0021241714130155742 | Valid Time: 0.016\n",
            "Epoch: 332\n",
            "Train Loss: 0.0025575568678935894 | Train Time: 0.198\n",
            "Valid Loss: 0.0020070875470992178 | Valid Time: 0.016\n",
            "Epoch: 333\n",
            "Train Loss: 0.002526264760251108 | Train Time: 0.192\n",
            "Valid Loss: 0.0024661062052473426 | Valid Time: 0.016\n",
            "Epoch: 334\n",
            "Train Loss: 0.0025678041856735945 | Train Time: 0.205\n",
            "Valid Loss: 0.0023338936152867973 | Valid Time: 0.012\n",
            "Epoch: 335\n",
            "Train Loss: 0.0025855058889934107 | Train Time: 0.188\n",
            "Valid Loss: 0.0023892975877970457 | Valid Time: 0.011\n",
            "Epoch: 336\n",
            "Train Loss: 0.0025690342177097734 | Train Time: 0.203\n",
            "Valid Loss: 0.002207889745477587 | Valid Time: 0.011\n",
            "Epoch: 337\n",
            "Train Loss: 0.002557854682795311 | Train Time: 0.193\n",
            "Valid Loss: 0.0020477752841543406 | Valid Time: 0.016\n",
            "Epoch: 338\n",
            "Train Loss: 0.002488597381958052 | Train Time: 0.185\n",
            "Valid Loss: 0.0021909368806518614 | Valid Time: 0.011\n",
            "Epoch: 339\n",
            "Train Loss: 0.0025465713973206127 | Train Time: 0.220\n",
            "Valid Loss: 0.0023230533115565777 | Valid Time: 0.017\n",
            "Epoch: 340\n",
            "Train Loss: 0.002517014766406072 | Train Time: 0.191\n",
            "Valid Loss: 0.0021730045846197754 | Valid Time: 0.020\n",
            "Epoch: 341\n",
            "Train Loss: 0.0025059900393611507 | Train Time: 0.192\n",
            "Valid Loss: 0.002274941885843873 | Valid Time: 0.016\n",
            "Epoch: 342\n",
            "Train Loss: 0.0025478415313716 | Train Time: 0.198\n",
            "Valid Loss: 0.001963043469004333 | Valid Time: 0.015\n",
            "Epoch: 343\n",
            "Train Loss: 0.0026148764453338166 | Train Time: 0.216\n",
            "Valid Loss: 0.002603196247946471 | Valid Time: 0.013\n",
            "Epoch: 344\n",
            "Train Loss: 0.0027243164613058694 | Train Time: 0.188\n",
            "Valid Loss: 0.0021059249411337078 | Valid Time: 0.011\n",
            "Epoch: 345\n",
            "Train Loss: 0.0025776516106960023 | Train Time: 0.198\n",
            "Valid Loss: 0.0021342821419239044 | Valid Time: 0.013\n",
            "Epoch: 346\n",
            "Train Loss: 0.0025509913010816824 | Train Time: 0.197\n",
            "Valid Loss: 0.002396184136159718 | Valid Time: 0.016\n",
            "Epoch: 347\n",
            "Train Loss: 0.002554672684422449 | Train Time: 0.224\n",
            "Valid Loss: 0.0021674857125617564 | Valid Time: 0.012\n",
            "Epoch: 348\n",
            "Train Loss: 0.0025271605210084665 | Train Time: 0.212\n",
            "Valid Loss: 0.002268778276629746 | Valid Time: 0.012\n",
            "Epoch: 349\n",
            "Train Loss: 0.0028693555168023237 | Train Time: 0.194\n",
            "Valid Loss: 0.0024014097289182246 | Valid Time: 0.017\n",
            "Epoch: 350\n",
            "Train Loss: 0.0027403882214505422 | Train Time: 0.199\n",
            "Valid Loss: 0.002363382518524304 | Valid Time: 0.015\n",
            "Epoch: 351\n",
            "Train Loss: 0.0026339505995182613 | Train Time: 0.188\n",
            "Valid Loss: 0.00217823195271194 | Valid Time: 0.022\n",
            "Epoch: 352\n",
            "Train Loss: 0.0025659604243149885 | Train Time: 0.189\n",
            "Valid Loss: 0.0019861197797581553 | Valid Time: 0.011\n",
            "Epoch: 353\n",
            "Train Loss: 0.002578584654991956 | Train Time: 0.213\n",
            "Valid Loss: 0.0021784977870993316 | Valid Time: 0.011\n",
            "Epoch: 354\n",
            "Train Loss: 0.002532097798968224 | Train Time: 0.194\n",
            "Valid Loss: 0.002425986051093787 | Valid Time: 0.016\n",
            "Epoch: 355\n",
            "Train Loss: 0.0026572269730662044 | Train Time: 0.196\n",
            "Valid Loss: 0.0023082358529791236 | Valid Time: 0.016\n",
            "Epoch: 356\n",
            "Train Loss: 0.002567255550897435 | Train Time: 0.199\n",
            "Valid Loss: 0.0022002510959282517 | Valid Time: 0.017\n",
            "Epoch: 357\n",
            "Train Loss: 0.0026413078640440575 | Train Time: 0.295\n",
            "Valid Loss: 0.0023218285641632974 | Valid Time: 0.017\n",
            "Epoch: 358\n",
            "Train Loss: 0.002549806695529505 | Train Time: 0.316\n",
            "Valid Loss: 0.002375369949731976 | Valid Time: 0.020\n",
            "Epoch: 359\n",
            "Train Loss: 0.0026684000499938663 | Train Time: 0.316\n",
            "Valid Loss: 0.0022745823371224105 | Valid Time: 0.018\n",
            "Epoch: 360\n",
            "Train Loss: 0.002738737145830926 | Train Time: 0.318\n",
            "Valid Loss: 0.0031366005423478782 | Valid Time: 0.027\n",
            "Epoch: 361\n",
            "Train Loss: 0.002661526068358829 | Train Time: 0.300\n",
            "Valid Loss: 0.0023848129203543067 | Valid Time: 0.019\n",
            "Epoch: 362\n",
            "Train Loss: 0.0025004466603461063 | Train Time: 0.307\n",
            "Valid Loss: 0.0023408273700624704 | Valid Time: 0.018\n",
            "Epoch: 363\n",
            "Train Loss: 0.0024688872324890995 | Train Time: 0.321\n",
            "Valid Loss: 0.0019381697929929942 | Valid Time: 0.017\n",
            "Epoch: 364\n",
            "Train Loss: 0.002572416082808846 | Train Time: 0.312\n",
            "Valid Loss: 0.002303103916347027 | Valid Time: 0.023\n",
            "Epoch: 365\n",
            "Train Loss: 0.002585633241228367 | Train Time: 0.228\n",
            "Valid Loss: 0.00235500221606344 | Valid Time: 0.011\n",
            "Epoch: 366\n",
            "Train Loss: 0.002491947508564121 | Train Time: 0.194\n",
            "Valid Loss: 0.0024792279000394046 | Valid Time: 0.015\n",
            "Epoch: 367\n",
            "Train Loss: 0.002601224512450005 | Train Time: 0.203\n",
            "Valid Loss: 0.002348532492760569 | Valid Time: 0.012\n",
            "Epoch: 368\n",
            "Train Loss: 0.0025263049235371383 | Train Time: 0.214\n",
            "Valid Loss: 0.002422915247734636 | Valid Time: 0.011\n",
            "Epoch: 369\n",
            "Train Loss: 0.0025452984999375125 | Train Time: 0.194\n",
            "Valid Loss: 0.001976295839995146 | Valid Time: 0.015\n",
            "Epoch: 370\n",
            "Train Loss: 0.002534869482348624 | Train Time: 0.204\n",
            "Valid Loss: 0.0020622882002498955 | Valid Time: 0.014\n",
            "Epoch: 371\n",
            "Train Loss: 0.0024949461221694946 | Train Time: 0.199\n",
            "Valid Loss: 0.002264008391648531 | Valid Time: 0.017\n",
            "Epoch: 372\n",
            "Train Loss: 0.0024619305898484433 | Train Time: 0.211\n",
            "Valid Loss: 0.002059700695099309 | Valid Time: 0.018\n",
            "Epoch: 373\n",
            "Train Loss: 0.002469397113217335 | Train Time: 0.185\n",
            "Valid Loss: 0.0023376861645374447 | Valid Time: 0.011\n",
            "Epoch: 374\n",
            "Train Loss: 0.0025183014498141253 | Train Time: 0.214\n",
            "Valid Loss: 0.0022701548878103495 | Valid Time: 0.012\n",
            "Epoch: 375\n",
            "Train Loss: 0.0026028930687492617 | Train Time: 0.192\n",
            "Valid Loss: 0.002025174006121233 | Valid Time: 0.016\n",
            "Epoch: 376\n",
            "Train Loss: 0.0026017979130541023 | Train Time: 0.201\n",
            "Valid Loss: 0.0020824147504754364 | Valid Time: 0.017\n",
            "Epoch: 377\n",
            "Train Loss: 0.002487079620263294 | Train Time: 0.210\n",
            "Valid Loss: 0.002096961427014321 | Valid Time: 0.011\n",
            "Epoch: 378\n",
            "Train Loss: 0.0024989839447172066 | Train Time: 0.199\n",
            "Valid Loss: 0.0021044376480858773 | Valid Time: 0.016\n",
            "Epoch: 379\n",
            "Train Loss: 0.002487350635132507 | Train Time: 0.192\n",
            "Valid Loss: 0.002096262265695259 | Valid Time: 0.016\n",
            "Epoch: 380\n",
            "Train Loss: 0.0026931672565344918 | Train Time: 0.192\n",
            "Valid Loss: 0.0026621028664521873 | Valid Time: 0.016\n",
            "Epoch: 381\n",
            "Train Loss: 0.002545515816707752 | Train Time: 0.192\n",
            "Valid Loss: 0.002145832229871303 | Valid Time: 0.015\n",
            "Epoch: 382\n",
            "Train Loss: 0.0025141147014341855 | Train Time: 0.214\n",
            "Valid Loss: 0.002176505309762433 | Valid Time: 0.012\n",
            "Epoch: 383\n",
            "Train Loss: 0.0024745700341698373 | Train Time: 0.218\n",
            "Valid Loss: 0.0021443204896058887 | Valid Time: 0.012\n",
            "Epoch: 384\n",
            "Train Loss: 0.0027151961234937374 | Train Time: 0.193\n",
            "Valid Loss: 0.0027317942585796118 | Valid Time: 0.016\n",
            "Epoch: 385\n",
            "Train Loss: 0.002600771460780188 | Train Time: 0.194\n",
            "Valid Loss: 0.0018885286699514836 | Valid Time: 0.016\n",
            "Epoch: 386\n",
            "Train Loss: 0.002519611116057556 | Train Time: 0.194\n",
            "Valid Loss: 0.0025308209005743265 | Valid Time: 0.016\n",
            "Epoch: 387\n",
            "Train Loss: 0.002536162354150101 | Train Time: 0.197\n",
            "Valid Loss: 0.0025226069847121835 | Valid Time: 0.021\n",
            "Epoch: 388\n",
            "Train Loss: 0.0025591832512107337 | Train Time: 0.188\n",
            "Valid Loss: 0.002105991938151419 | Valid Time: 0.014\n",
            "Epoch: 389\n",
            "Train Loss: 0.002458886402708135 | Train Time: 0.200\n",
            "Valid Loss: 0.002077953569823876 | Valid Time: 0.015\n",
            "Epoch: 390\n",
            "Train Loss: 0.0024579190832905865 | Train Time: 0.197\n",
            "Valid Loss: 0.0018410082557238638 | Valid Time: 0.017\n",
            "Epoch: 391\n",
            "Train Loss: 0.002483564649561518 | Train Time: 0.196\n",
            "Valid Loss: 0.0021633050637319684 | Valid Time: 0.020\n",
            "Epoch: 392\n",
            "Train Loss: 0.002579985762407121 | Train Time: 0.198\n",
            "Valid Loss: 0.002260664477944374 | Valid Time: 0.016\n",
            "Epoch: 393\n",
            "Train Loss: 0.002544866323373035 | Train Time: 0.198\n",
            "Valid Loss: 0.002122629201039672 | Valid Time: 0.016\n",
            "Epoch: 394\n",
            "Train Loss: 0.0025255358471584165 | Train Time: 0.201\n",
            "Valid Loss: 0.002251182042527944 | Valid Time: 0.015\n",
            "Epoch: 395\n",
            "Train Loss: 0.0025288448178846586 | Train Time: 0.199\n",
            "Valid Loss: 0.002375856856815517 | Valid Time: 0.015\n",
            "Epoch: 396\n",
            "Train Loss: 0.0024448278801221597 | Train Time: 0.208\n",
            "Valid Loss: 0.0021147634251974523 | Valid Time: 0.011\n",
            "Epoch: 397\n",
            "Train Loss: 0.002461340829828068 | Train Time: 0.195\n",
            "Valid Loss: 0.0025411545648239553 | Valid Time: 0.016\n",
            "Epoch: 398\n",
            "Train Loss: 0.0025478115023456907 | Train Time: 0.197\n",
            "Valid Loss: 0.002175772562623024 | Valid Time: 0.016\n",
            "Epoch: 399\n",
            "Train Loss: 0.002485075610150632 | Train Time: 0.196\n",
            "Valid Loss: 0.0022447213414125144 | Valid Time: 0.016\n",
            "Epoch: 400\n",
            "Train Loss: 0.0024725442605191155 | Train Time: 0.190\n",
            "Valid Loss: 0.002206194680184126 | Valid Time: 0.018\n",
            "Epoch: 401\n",
            "Train Loss: 0.002476877361339958 | Train Time: 0.200\n",
            "Valid Loss: 0.0020366331445984542 | Valid Time: 0.015\n",
            "Epoch: 402\n",
            "Train Loss: 0.0025338985846917097 | Train Time: 0.192\n",
            "Valid Loss: 0.0024678153567947447 | Valid Time: 0.014\n",
            "Epoch: 403\n",
            "Train Loss: 0.0024538496264109484 | Train Time: 0.193\n",
            "Valid Loss: 0.0021841481211595237 | Valid Time: 0.015\n",
            "Epoch: 404\n",
            "Train Loss: 0.002490408798238557 | Train Time: 0.192\n",
            "Valid Loss: 0.0023495861096307635 | Valid Time: 0.015\n",
            "Epoch: 405\n",
            "Train Loss: 0.002542555417963549 | Train Time: 0.193\n",
            "Valid Loss: 0.002453087130561471 | Valid Time: 0.014\n",
            "Epoch: 406\n",
            "Train Loss: 0.0024854300396614953 | Train Time: 0.209\n",
            "Valid Loss: 0.0020481806714087725 | Valid Time: 0.011\n",
            "Epoch: 407\n",
            "Train Loss: 0.0025303899126715565 | Train Time: 0.185\n",
            "Valid Loss: 0.0021319423976819962 | Valid Time: 0.011\n",
            "Epoch: 408\n",
            "Train Loss: 0.0025961820746919044 | Train Time: 0.192\n",
            "Valid Loss: 0.0020399815402925014 | Valid Time: 0.011\n",
            "Epoch: 409\n",
            "Train Loss: 0.002495342504086071 | Train Time: 0.196\n",
            "Valid Loss: 0.0025420374877285212 | Valid Time: 0.016\n",
            "Epoch: 410\n",
            "Train Loss: 0.002802575828115407 | Train Time: 0.191\n",
            "Valid Loss: 0.0023769079125486314 | Valid Time: 0.013\n",
            "Epoch: 411\n",
            "Train Loss: 0.0026695089243156346 | Train Time: 0.205\n",
            "Valid Loss: 0.001989079697523266 | Valid Time: 0.021\n",
            "Epoch: 412\n",
            "Train Loss: 0.002483638554909512 | Train Time: 0.312\n",
            "Valid Loss: 0.0018924044561572373 | Valid Time: 0.017\n",
            "Epoch: 413\n",
            "Train Loss: 0.002539667754286998 | Train Time: 0.312\n",
            "Valid Loss: 0.0023062757099978626 | Valid Time: 0.017\n",
            "Epoch: 414\n",
            "Train Loss: 0.0025015060704103426 | Train Time: 0.322\n",
            "Valid Loss: 0.002245381474494934 | Valid Time: 0.020\n",
            "Epoch: 415\n",
            "Train Loss: 0.0026217502737907986 | Train Time: 0.307\n",
            "Valid Loss: 0.002237895707366988 | Valid Time: 0.016\n",
            "Epoch: 416\n",
            "Train Loss: 0.002565970117422311 | Train Time: 0.319\n",
            "Valid Loss: 0.0023360665945801884 | Valid Time: 0.018\n",
            "Epoch: 417\n",
            "Train Loss: 0.002515439495542332 | Train Time: 0.304\n",
            "Valid Loss: 0.002345620858250186 | Valid Time: 0.017\n",
            "Epoch: 418\n",
            "Train Loss: 0.002485285445704664 | Train Time: 0.321\n",
            "Valid Loss: 0.0022870265529491007 | Valid Time: 0.020\n",
            "Epoch: 419\n",
            "Train Loss: 0.0025596930890491136 | Train Time: 0.301\n",
            "Valid Loss: 0.0019513018196448684 | Valid Time: 0.011\n",
            "Epoch: 420\n",
            "Train Loss: 0.0024713138853640934 | Train Time: 0.197\n",
            "Valid Loss: 0.002047550806310028 | Valid Time: 0.016\n",
            "Epoch: 421\n",
            "Train Loss: 0.002473262555309032 | Train Time: 0.213\n",
            "Valid Loss: 0.0022478823375422508 | Valid Time: 0.015\n",
            "Epoch: 422\n",
            "Train Loss: 0.0025805817414565305 | Train Time: 0.195\n",
            "Valid Loss: 0.0021272862213663757 | Valid Time: 0.017\n",
            "Epoch: 423\n",
            "Train Loss: 0.0024684768684796595 | Train Time: 0.193\n",
            "Valid Loss: 0.001977334060939029 | Valid Time: 0.017\n",
            "Epoch: 424\n",
            "Train Loss: 0.0024162500385979287 | Train Time: 0.195\n",
            "Valid Loss: 0.002245602256152779 | Valid Time: 0.016\n",
            "Epoch: 425\n",
            "Train Loss: 0.0024603030117424695 | Train Time: 0.191\n",
            "Valid Loss: 0.0023059091181494296 | Valid Time: 0.014\n",
            "Epoch: 426\n",
            "Train Loss: 0.0026438432794652486 | Train Time: 0.221\n",
            "Valid Loss: 0.0021160039177630097 | Valid Time: 0.012\n",
            "Epoch: 427\n",
            "Train Loss: 0.002546369710839108 | Train Time: 0.193\n",
            "Valid Loss: 0.0019008272211067379 | Valid Time: 0.015\n",
            "Epoch: 428\n",
            "Train Loss: 0.002422022032796552 | Train Time: 0.208\n",
            "Valid Loss: 0.0023546502634417266 | Valid Time: 0.012\n",
            "Epoch: 429\n",
            "Train Loss: 0.0024462466520306313 | Train Time: 0.189\n",
            "Valid Loss: 0.002393747796304524 | Valid Time: 0.018\n",
            "Epoch: 430\n",
            "Train Loss: 0.0024480998797930384 | Train Time: 0.190\n",
            "Valid Loss: 0.0023508378653787076 | Valid Time: 0.018\n",
            "Epoch: 431\n",
            "Train Loss: 0.0024760240002682336 | Train Time: 0.198\n",
            "Valid Loss: 0.0020471137831918895 | Valid Time: 0.016\n",
            "Epoch: 432\n",
            "Train Loss: 0.0024948361219446127 | Train Time: 0.194\n",
            "Valid Loss: 0.0019606801215559244 | Valid Time: 0.017\n",
            "Epoch: 433\n",
            "Train Loss: 0.002515597881651238 | Train Time: 0.199\n",
            "Valid Loss: 0.0022068782709538937 | Valid Time: 0.016\n",
            "Epoch: 434\n",
            "Train Loss: 0.002450436035073117 | Train Time: 0.196\n",
            "Valid Loss: 0.0020619210554286838 | Valid Time: 0.017\n",
            "Epoch: 435\n",
            "Train Loss: 0.002516520963246493 | Train Time: 0.202\n",
            "Valid Loss: 0.0020407041301950812 | Valid Time: 0.018\n",
            "Epoch: 436\n",
            "Train Loss: 0.002560592317757638 | Train Time: 0.193\n",
            "Valid Loss: 0.0022785766632296145 | Valid Time: 0.015\n",
            "Epoch: 437\n",
            "Train Loss: 0.0025838624048782023 | Train Time: 0.204\n",
            "Valid Loss: 0.0020585221354849637 | Valid Time: 0.012\n",
            "Epoch: 438\n",
            "Train Loss: 0.002531059956374137 | Train Time: 0.206\n",
            "Valid Loss: 0.00240208808099851 | Valid Time: 0.012\n",
            "Epoch: 439\n",
            "Train Loss: 0.0026988974331240904 | Train Time: 0.192\n",
            "Valid Loss: 0.002022533066337928 | Valid Time: 0.016\n",
            "Epoch: 440\n",
            "Train Loss: 0.0024693779782147 | Train Time: 0.213\n",
            "Valid Loss: 0.002051469520665705 | Valid Time: 0.012\n",
            "Epoch: 441\n",
            "Train Loss: 0.002432024271815623 | Train Time: 0.198\n",
            "Valid Loss: 0.002044808876235038 | Valid Time: 0.016\n",
            "Epoch: 442\n",
            "Train Loss: 0.0024395101078736937 | Train Time: 0.208\n",
            "Valid Loss: 0.0025666292058303952 | Valid Time: 0.012\n",
            "Epoch: 443\n",
            "Train Loss: 0.0025472732836772736 | Train Time: 0.189\n",
            "Valid Loss: 0.0023062279797159135 | Valid Time: 0.020\n",
            "Epoch: 444\n",
            "Train Loss: 0.0024524280666618757 | Train Time: 0.191\n",
            "Valid Loss: 0.001930536876898259 | Valid Time: 0.015\n",
            "Epoch: 445\n",
            "Train Loss: 0.0024508235632981126 | Train Time: 0.209\n",
            "Valid Loss: 0.00202557843294926 | Valid Time: 0.011\n",
            "Epoch: 446\n",
            "Train Loss: 0.0024911301014454742 | Train Time: 0.190\n",
            "Valid Loss: 0.0027158070006407797 | Valid Time: 0.016\n",
            "Epoch: 447\n",
            "Train Loss: 0.0027810976914081132 | Train Time: 0.194\n",
            "Valid Loss: 0.0027998091536574066 | Valid Time: 0.016\n",
            "Epoch: 448\n",
            "Train Loss: 0.002531312957504078 | Train Time: 0.190\n",
            "Valid Loss: 0.0019373121613170952 | Valid Time: 0.013\n",
            "Epoch: 449\n",
            "Train Loss: 0.002480890148466355 | Train Time: 0.187\n",
            "Valid Loss: 0.0023128135653678328 | Valid Time: 0.012\n",
            "Epoch: 450\n",
            "Train Loss: 0.0024253654747122995 | Train Time: 0.210\n",
            "Valid Loss: 0.002026906207902357 | Valid Time: 0.011\n",
            "Epoch: 451\n",
            "Train Loss: 0.0024402947777784185 | Train Time: 0.200\n",
            "Valid Loss: 0.002163569035474211 | Valid Time: 0.015\n",
            "Epoch: 452\n",
            "Train Loss: 0.002459862091774611 | Train Time: 0.200\n",
            "Valid Loss: 0.0020406902476679534 | Valid Time: 0.015\n",
            "Epoch: 453\n",
            "Train Loss: 0.0024713614931035984 | Train Time: 0.186\n",
            "Valid Loss: 0.0022653269406873733 | Valid Time: 0.011\n",
            "Epoch: 454\n",
            "Train Loss: 0.0025398568250238895 | Train Time: 0.210\n",
            "Valid Loss: 0.002282270055729896 | Valid Time: 0.014\n",
            "Epoch: 455\n",
            "Train Loss: 0.0025084482530426037 | Train Time: 0.185\n",
            "Valid Loss: 0.0020720676402561367 | Valid Time: 0.012\n",
            "Epoch: 456\n",
            "Train Loss: 0.002515873332556925 | Train Time: 0.215\n",
            "Valid Loss: 0.0022555702598765492 | Valid Time: 0.013\n",
            "Epoch: 457\n",
            "Train Loss: 0.002642902030952667 | Train Time: 0.192\n",
            "Valid Loss: 0.0020413044840097427 | Valid Time: 0.015\n",
            "Epoch: 458\n",
            "Train Loss: 0.002564064680451625 | Train Time: 0.188\n",
            "Valid Loss: 0.0022816674027126282 | Valid Time: 0.011\n",
            "Epoch: 459\n",
            "Train Loss: 0.0028366938380426482 | Train Time: 0.208\n",
            "Valid Loss: 0.002303027518792078 | Valid Time: 0.011\n",
            "Epoch: 460\n",
            "Train Loss: 0.0029345088466805848 | Train Time: 0.192\n",
            "Valid Loss: 0.0021025370806455612 | Valid Time: 0.020\n",
            "Epoch: 461\n",
            "Train Loss: 0.002459469790521421 | Train Time: 0.195\n",
            "Valid Loss: 0.0018706224800553173 | Valid Time: 0.015\n",
            "Epoch: 462\n",
            "Train Loss: 0.0024728421244378154 | Train Time: 0.192\n",
            "Valid Loss: 0.0022502380306832492 | Valid Time: 0.015\n",
            "Epoch: 463\n",
            "Train Loss: 0.0026879492767253204 | Train Time: 0.189\n",
            "Valid Loss: 0.0023333403514698148 | Valid Time: 0.013\n",
            "Epoch: 464\n",
            "Train Loss: 0.0025732449231375206 | Train Time: 0.215\n",
            "Valid Loss: 0.0023724157363176346 | Valid Time: 0.011\n",
            "Epoch: 465\n",
            "Train Loss: 0.002430297906118396 | Train Time: 0.200\n",
            "Valid Loss: 0.0019763512536883354 | Valid Time: 0.015\n",
            "Epoch: 466\n",
            "Train Loss: 0.002501625083631983 | Train Time: 0.243\n",
            "Valid Loss: 0.002545889816246927 | Valid Time: 0.021\n",
            "Epoch: 467\n",
            "Train Loss: 0.002451902004203906 | Train Time: 0.316\n",
            "Valid Loss: 0.0019310723582748324 | Valid Time: 0.018\n",
            "Epoch: 468\n",
            "Train Loss: 0.002462211677706555 | Train Time: 0.312\n",
            "Valid Loss: 0.0020955678774043918 | Valid Time: 0.017\n",
            "Epoch: 469\n",
            "Train Loss: 0.002484881196563181 | Train Time: 0.318\n",
            "Valid Loss: 0.002190352970501408 | Valid Time: 0.017\n",
            "Epoch: 470\n",
            "Train Loss: 0.002417437707711207 | Train Time: 0.321\n",
            "Valid Loss: 0.002023838635068387 | Valid Time: 0.019\n",
            "Epoch: 471\n",
            "Train Loss: 0.002452076939669879 | Train Time: 0.314\n",
            "Valid Loss: 0.0021178503811825067 | Valid Time: 0.021\n",
            "Epoch: 472\n",
            "Train Loss: 0.0024157093752077536 | Train Time: 0.318\n",
            "Valid Loss: 0.0018969620869029313 | Valid Time: 0.019\n",
            "Epoch: 473\n",
            "Train Loss: 0.0024008795949875526 | Train Time: 0.324\n",
            "Valid Loss: 0.0019902236526831985 | Valid Time: 0.019\n",
            "Epoch: 474\n",
            "Train Loss: 0.0025173405822562544 | Train Time: 0.292\n",
            "Valid Loss: 0.0030007798923179507 | Valid Time: 0.012\n",
            "Epoch: 475\n",
            "Train Loss: 0.0027957386827390444 | Train Time: 0.194\n",
            "Valid Loss: 0.002214577340055257 | Valid Time: 0.021\n",
            "Epoch: 476\n",
            "Train Loss: 0.0025279256760289796 | Train Time: 0.189\n",
            "Valid Loss: 0.001925577555084601 | Valid Time: 0.011\n",
            "Epoch: 477\n",
            "Train Loss: 0.0024920954356754295 | Train Time: 0.212\n",
            "Valid Loss: 0.0020072846673429012 | Valid Time: 0.011\n",
            "Epoch: 478\n",
            "Train Loss: 0.002537356763097801 | Train Time: 0.200\n",
            "Valid Loss: 0.0022100986388977617 | Valid Time: 0.016\n",
            "Epoch: 479\n",
            "Train Loss: 0.002495205379091203 | Train Time: 0.207\n",
            "Valid Loss: 0.0020112238125875592 | Valid Time: 0.012\n",
            "Epoch: 480\n",
            "Train Loss: 0.0024052074816274015 | Train Time: 0.199\n",
            "Valid Loss: 0.001955787622136995 | Valid Time: 0.016\n",
            "Epoch: 481\n",
            "Train Loss: 0.0024210257749808462 | Train Time: 0.195\n",
            "Valid Loss: 0.002380968304350972 | Valid Time: 0.016\n",
            "Epoch: 482\n",
            "Train Loss: 0.0024299728561584886 | Train Time: 0.211\n",
            "Valid Loss: 0.0022258020471781492 | Valid Time: 0.011\n",
            "Epoch: 483\n",
            "Train Loss: 0.0025450038221223573 | Train Time: 0.188\n",
            "Valid Loss: 0.0021317806094884872 | Valid Time: 0.016\n",
            "Epoch: 484\n",
            "Train Loss: 0.0025298619446785828 | Train Time: 0.208\n",
            "Valid Loss: 0.0022162868408486247 | Valid Time: 0.011\n",
            "Epoch: 485\n",
            "Train Loss: 0.0025416116818393533 | Train Time: 0.191\n",
            "Valid Loss: 0.0021474690292961895 | Valid Time: 0.015\n",
            "Epoch: 486\n",
            "Train Loss: 0.0024579610969675215 | Train Time: 0.193\n",
            "Valid Loss: 0.002235980558907613 | Valid Time: 0.015\n",
            "Epoch: 487\n",
            "Train Loss: 0.002415984078604532 | Train Time: 0.205\n",
            "Valid Loss: 0.002035116543993354 | Valid Time: 0.013\n",
            "Epoch: 488\n",
            "Train Loss: 0.0023734777259003174 | Train Time: 0.204\n",
            "Valid Loss: 0.0020941550901625305 | Valid Time: 0.013\n",
            "Epoch: 489\n",
            "Train Loss: 0.0024084455064056734 | Train Time: 0.200\n",
            "Valid Loss: 0.0017911918403115124 | Valid Time: 0.015\n",
            "Epoch: 490\n",
            "Train Loss: 0.0024055288369326214 | Train Time: 0.194\n",
            "Valid Loss: 0.0019042554486077279 | Valid Time: 0.018\n",
            "Epoch: 491\n",
            "Train Loss: 0.0023800340162492112 | Train Time: 0.191\n",
            "Valid Loss: 0.0020662623865064234 | Valid Time: 0.020\n",
            "Epoch: 492\n",
            "Train Loss: 0.002364301784454208 | Train Time: 0.206\n",
            "Valid Loss: 0.002142524754162878 | Valid Time: 0.012\n",
            "Epoch: 493\n",
            "Train Loss: 0.002535991370677948 | Train Time: 0.217\n",
            "Valid Loss: 0.002438593073748052 | Valid Time: 0.014\n",
            "Epoch: 494\n",
            "Train Loss: 0.002588468536391462 | Train Time: 0.199\n",
            "Valid Loss: 0.0022384391049854457 | Valid Time: 0.022\n",
            "Epoch: 495\n",
            "Train Loss: 0.002554977490370603 | Train Time: 0.198\n",
            "Valid Loss: 0.002368140674661845 | Valid Time: 0.015\n",
            "Epoch: 496\n",
            "Train Loss: 0.0024482537134501493 | Train Time: 0.199\n",
            "Valid Loss: 0.0022832423564977944 | Valid Time: 0.016\n",
            "Epoch: 497\n",
            "Train Loss: 0.0024274869907745405 | Train Time: 0.192\n",
            "Valid Loss: 0.001904132222989574 | Valid Time: 0.016\n",
            "Epoch: 498\n",
            "Train Loss: 0.002432181744983322 | Train Time: 0.219\n",
            "Valid Loss: 0.00210770865669474 | Valid Time: 0.011\n",
            "Epoch: 499\n",
            "Train Loss: 0.0024017340895768845 | Train Time: 0.194\n",
            "Valid Loss: 0.0018882401345763355 | Valid Time: 0.015\n",
            "Epoch: 500\n",
            "Train Loss: 0.002517853336604802 | Train Time: 0.200\n",
            "Valid Loss: 0.003157458209898323 | Valid Time: 0.017\n",
            "Epoch: 501\n",
            "Train Loss: 0.002881706263379831 | Train Time: 0.191\n",
            "Valid Loss: 0.0025222291005775332 | Valid Time: 0.017\n",
            "Epoch: 502\n",
            "Train Loss: 0.002594629805044908 | Train Time: 0.191\n",
            "Valid Loss: 0.002036355377640575 | Valid Time: 0.024\n",
            "Epoch: 503\n",
            "Train Loss: 0.0024814959738011424 | Train Time: 0.215\n",
            "Valid Loss: 0.0018697294872254133 | Valid Time: 0.011\n",
            "Epoch: 504\n",
            "Train Loss: 0.002406092011369765 | Train Time: 0.192\n",
            "Valid Loss: 0.0021794434869661927 | Valid Time: 0.016\n",
            "Epoch: 505\n",
            "Train Loss: 0.0024500150650151467 | Train Time: 0.188\n",
            "Valid Loss: 0.0018463609158061445 | Valid Time: 0.011\n",
            "Epoch: 506\n",
            "Train Loss: 0.0024406725945147244 | Train Time: 0.197\n",
            "Valid Loss: 0.002175718342186883 | Valid Time: 0.014\n",
            "Epoch: 507\n",
            "Train Loss: 0.002473097925662602 | Train Time: 0.214\n",
            "Valid Loss: 0.0018819774559233338 | Valid Time: 0.011\n",
            "Epoch: 508\n",
            "Train Loss: 0.002473563470534588 | Train Time: 0.191\n",
            "Valid Loss: 0.0021938002319075167 | Valid Time: 0.021\n",
            "Epoch: 509\n",
            "Train Loss: 0.0024985982117390164 | Train Time: 0.192\n",
            "Valid Loss: 0.0019648955203592777 | Valid Time: 0.016\n",
            "Epoch: 510\n",
            "Train Loss: 0.002438911598322815 | Train Time: 0.195\n",
            "Valid Loss: 0.0020190423529129475 | Valid Time: 0.016\n",
            "Epoch: 511\n",
            "Train Loss: 0.0024477506889716573 | Train Time: 0.192\n",
            "Valid Loss: 0.002331671363208443 | Valid Time: 0.016\n",
            "Epoch: 512\n",
            "Train Loss: 0.0024051840515121035 | Train Time: 0.213\n",
            "Valid Loss: 0.002039704122580588 | Valid Time: 0.014\n",
            "Epoch: 513\n",
            "Train Loss: 0.0026402660572019065 | Train Time: 0.197\n",
            "Valid Loss: 0.0023796330206096172 | Valid Time: 0.016\n",
            "Epoch: 514\n",
            "Train Loss: 0.002818683125568848 | Train Time: 0.197\n",
            "Valid Loss: 0.002076201082672924 | Valid Time: 0.016\n",
            "Epoch: 515\n",
            "Train Loss: 0.0024130055742142232 | Train Time: 0.192\n",
            "Valid Loss: 0.001915524189826101 | Valid Time: 0.015\n",
            "Epoch: 516\n",
            "Train Loss: 0.0023676330456510186 | Train Time: 0.192\n",
            "Valid Loss: 0.0020207118650432676 | Valid Time: 0.014\n",
            "Epoch: 517\n",
            "Train Loss: 0.002406309003402528 | Train Time: 0.221\n",
            "Valid Loss: 0.0020789485424757004 | Valid Time: 0.011\n",
            "Epoch: 518\n",
            "Train Loss: 0.002589160496810157 | Train Time: 0.207\n",
            "Valid Loss: 0.001952941034687683 | Valid Time: 0.012\n",
            "Epoch: 519\n",
            "Train Loss: 0.002432454714404517 | Train Time: 0.195\n",
            "Valid Loss: 0.002119083481375128 | Valid Time: 0.016\n",
            "Epoch: 520\n",
            "Train Loss: 0.002377113682757083 | Train Time: 0.228\n",
            "Valid Loss: 0.0020701312460005283 | Valid Time: 0.018\n",
            "Epoch: 521\n",
            "Train Loss: 0.0024049025470096815 | Train Time: 0.326\n",
            "Valid Loss: 0.0020582721917890012 | Valid Time: 0.019\n",
            "Epoch: 522\n",
            "Train Loss: 0.0024787188372819833 | Train Time: 0.312\n",
            "Valid Loss: 0.0021649719565175474 | Valid Time: 0.017\n",
            "Epoch: 523\n",
            "Train Loss: 0.0024576663823896333 | Train Time: 0.312\n",
            "Valid Loss: 0.0021860179549548775 | Valid Time: 0.018\n",
            "Epoch: 524\n",
            "Train Loss: 0.002407483217355452 | Train Time: 0.326\n",
            "Valid Loss: 0.0020598875416908413 | Valid Time: 0.017\n",
            "Epoch: 525\n",
            "Train Loss: 0.002526669628231933 | Train Time: 0.315\n",
            "Valid Loss: 0.002828681201208383 | Valid Time: 0.018\n",
            "Epoch: 526\n",
            "Train Loss: 0.0025950244774943904 | Train Time: 0.310\n",
            "Valid Loss: 0.002012377284700051 | Valid Time: 0.020\n",
            "Epoch: 527\n",
            "Train Loss: 0.0024116076651568476 | Train Time: 0.320\n",
            "Valid Loss: 0.0019623501284513623 | Valid Time: 0.018\n",
            "Epoch: 528\n",
            "Train Loss: 0.0023794960916826598 | Train Time: 0.272\n",
            "Valid Loss: 0.001808112661819905 | Valid Time: 0.011\n",
            "Epoch: 529\n",
            "Train Loss: 0.002457757786798634 | Train Time: 0.194\n",
            "Valid Loss: 0.0021262927330099046 | Valid Time: 0.016\n",
            "Epoch: 530\n",
            "Train Loss: 0.0023726164730951973 | Train Time: 0.201\n",
            "Valid Loss: 0.0021954156982246786 | Valid Time: 0.020\n",
            "Epoch: 531\n",
            "Train Loss: 0.002382231263541862 | Train Time: 0.196\n",
            "Valid Loss: 0.002140179567504674 | Valid Time: 0.016\n",
            "Epoch: 532\n",
            "Train Loss: 0.0023616054095327854 | Train Time: 0.200\n",
            "Valid Loss: 0.0019745262688957155 | Valid Time: 0.016\n",
            "Epoch: 533\n",
            "Train Loss: 0.002387960177944287 | Train Time: 0.194\n",
            "Valid Loss: 0.0019540228240657598 | Valid Time: 0.016\n",
            "Epoch: 534\n",
            "Train Loss: 0.0024355221907363125 | Train Time: 0.193\n",
            "Valid Loss: 0.0017003230314003304 | Valid Time: 0.015\n",
            "Epoch: 535\n",
            "Train Loss: 0.0023896769485681466 | Train Time: 0.199\n",
            "Valid Loss: 0.0021220750059001148 | Valid Time: 0.017\n",
            "Epoch: 536\n",
            "Train Loss: 0.0023632675017181194 | Train Time: 0.196\n",
            "Valid Loss: 0.0023258788860403 | Valid Time: 0.016\n",
            "Epoch: 537\n",
            "Train Loss: 0.002415815552108382 | Train Time: 0.202\n",
            "Valid Loss: 0.0020037218928337097 | Valid Time: 0.013\n",
            "Epoch: 538\n",
            "Train Loss: 0.002377340226973358 | Train Time: 0.193\n",
            "Valid Loss: 0.0020830731955356896 | Valid Time: 0.016\n",
            "Epoch: 539\n",
            "Train Loss: 0.0023857762939051576 | Train Time: 0.194\n",
            "Valid Loss: 0.0020418935746420175 | Valid Time: 0.020\n",
            "Epoch: 540\n",
            "Train Loss: 0.002364956210122297 | Train Time: 0.193\n",
            "Valid Loss: 0.0022195670753717422 | Valid Time: 0.016\n",
            "Epoch: 541\n",
            "Train Loss: 0.002378859318253633 | Train Time: 0.213\n",
            "Valid Loss: 0.0020197865087538958 | Valid Time: 0.011\n",
            "Epoch: 542\n",
            "Train Loss: 0.0024283174854262094 | Train Time: 0.199\n",
            "Valid Loss: 0.002036868332652375 | Valid Time: 0.016\n",
            "Epoch: 543\n",
            "Train Loss: 0.0023852117898824966 | Train Time: 0.188\n",
            "Valid Loss: 0.0019463220960460603 | Valid Time: 0.011\n",
            "Epoch: 544\n",
            "Train Loss: 0.0024187649404139896 | Train Time: 0.200\n",
            "Valid Loss: 0.0022604528930969536 | Valid Time: 0.018\n",
            "Epoch: 545\n",
            "Train Loss: 0.0024850372421114067 | Train Time: 0.230\n",
            "Valid Loss: 0.0024571125395596027 | Valid Time: 0.011\n",
            "Epoch: 546\n",
            "Train Loss: 0.0024619316130778507 | Train Time: 0.214\n",
            "Valid Loss: 0.0020662369788624346 | Valid Time: 0.011\n",
            "Epoch: 547\n",
            "Train Loss: 0.002516911769481866 | Train Time: 0.193\n",
            "Valid Loss: 0.0017781041678972542 | Valid Time: 0.016\n",
            "Epoch: 548\n",
            "Train Loss: 0.002479913644492626 | Train Time: 0.188\n",
            "Valid Loss: 0.0021908279741182923 | Valid Time: 0.011\n",
            "Epoch: 549\n",
            "Train Loss: 0.0024753681285993047 | Train Time: 0.200\n",
            "Valid Loss: 0.0021369972091633826 | Valid Time: 0.011\n",
            "Epoch: 550\n",
            "Train Loss: 0.002477150741278341 | Train Time: 0.218\n",
            "Valid Loss: 0.002413265436189249 | Valid Time: 0.014\n",
            "Epoch: 551\n",
            "Train Loss: 0.00247616894347103 | Train Time: 0.204\n",
            "Valid Loss: 0.0020699217857327312 | Valid Time: 0.013\n",
            "Epoch: 552\n",
            "Train Loss: 0.0024152435913780018 | Train Time: 0.194\n",
            "Valid Loss: 0.002390075591392815 | Valid Time: 0.016\n",
            "Epoch: 553\n",
            "Train Loss: 0.0023947201460894 | Train Time: 0.203\n",
            "Valid Loss: 0.0022975830652285367 | Valid Time: 0.016\n",
            "Epoch: 554\n",
            "Train Loss: 0.0024143367282752144 | Train Time: 0.192\n",
            "Valid Loss: 0.0020775703305844218 | Valid Time: 0.016\n",
            "Epoch: 555\n",
            "Train Loss: 0.0024377829579048252 | Train Time: 0.194\n",
            "Valid Loss: 0.0023298529849853367 | Valid Time: 0.021\n",
            "Epoch: 556\n",
            "Train Loss: 0.0024805874563753605 | Train Time: 0.209\n",
            "Valid Loss: 0.0020118431420996785 | Valid Time: 0.013\n",
            "Epoch: 557\n",
            "Train Loss: 0.002457413044267971 | Train Time: 0.192\n",
            "Valid Loss: 0.0018919019494205713 | Valid Time: 0.014\n",
            "Epoch: 558\n",
            "Train Loss: 0.0023992152725297367 | Train Time: 0.228\n",
            "Valid Loss: 0.0017588985210750252 | Valid Time: 0.011\n",
            "Epoch: 559\n",
            "Train Loss: 0.002363880287463728 | Train Time: 0.202\n",
            "Valid Loss: 0.0018625173543114215 | Valid Time: 0.016\n",
            "Epoch: 560\n",
            "Train Loss: 0.002609703175135349 | Train Time: 0.219\n",
            "Valid Loss: 0.002201654016971588 | Valid Time: 0.012\n",
            "Epoch: 561\n",
            "Train Loss: 0.0027523503859380356 | Train Time: 0.214\n",
            "Valid Loss: 0.002598858205601573 | Valid Time: 0.011\n",
            "Epoch: 562\n",
            "Train Loss: 0.002529372099639946 | Train Time: 0.190\n",
            "Valid Loss: 0.001776547112967819 | Valid Time: 0.015\n",
            "Epoch: 563\n",
            "Train Loss: 0.0023802651190444044 | Train Time: 0.208\n",
            "Valid Loss: 0.0021188438404351473 | Valid Time: 0.015\n",
            "Epoch: 564\n",
            "Train Loss: 0.0025400736516243533 | Train Time: 0.191\n",
            "Valid Loss: 0.0017658004362601787 | Valid Time: 0.016\n",
            "Epoch: 565\n",
            "Train Loss: 0.0023735554545725648 | Train Time: 0.205\n",
            "Valid Loss: 0.0019028955430258065 | Valid Time: 0.012\n",
            "Epoch: 566\n",
            "Train Loss: 0.002338036992832234 | Train Time: 0.197\n",
            "Valid Loss: 0.002223003306426108 | Valid Time: 0.016\n",
            "Epoch: 567\n",
            "Train Loss: 0.0023489592805210698 | Train Time: 0.213\n",
            "Valid Loss: 0.001751075265929103 | Valid Time: 0.011\n",
            "Epoch: 568\n",
            "Train Loss: 0.0023777025482176165 | Train Time: 0.185\n",
            "Valid Loss: 0.002216078690253198 | Valid Time: 0.013\n",
            "Epoch: 569\n",
            "Train Loss: 0.002528417880009664 | Train Time: 0.200\n",
            "Valid Loss: 0.0020517725497484207 | Valid Time: 0.012\n",
            "Epoch: 570\n",
            "Train Loss: 0.002441109102954598 | Train Time: 0.205\n",
            "Valid Loss: 0.0018204051593784243 | Valid Time: 0.013\n",
            "Epoch: 571\n",
            "Train Loss: 0.002400853695642007 | Train Time: 0.199\n",
            "Valid Loss: 0.0019199428497813642 | Valid Time: 0.016\n",
            "Epoch: 572\n",
            "Train Loss: 0.0024749793136786473 | Train Time: 0.196\n",
            "Valid Loss: 0.002688658656552434 | Valid Time: 0.015\n",
            "Epoch: 573\n",
            "Train Loss: 0.0024855228594357244 | Train Time: 0.205\n",
            "Valid Loss: 0.0019304314628243446 | Valid Time: 0.012\n",
            "Epoch: 574\n",
            "Train Loss: 0.002338173449970782 | Train Time: 0.236\n",
            "Valid Loss: 0.002230092417448759 | Valid Time: 0.018\n",
            "Epoch: 575\n",
            "Train Loss: 0.0023921779295625655 | Train Time: 0.315\n",
            "Valid Loss: 0.0021228491968940943 | Valid Time: 0.021\n",
            "Epoch: 576\n",
            "Train Loss: 0.0023589475251930324 | Train Time: 0.311\n",
            "Valid Loss: 0.0018173128482885659 | Valid Time: 0.018\n",
            "Epoch: 577\n",
            "Train Loss: 0.002455734402725571 | Train Time: 0.328\n",
            "Valid Loss: 0.00189894056529738 | Valid Time: 0.018\n",
            "Epoch: 578\n",
            "Train Loss: 0.002411834092957801 | Train Time: 0.322\n",
            "Valid Loss: 0.002188052225392312 | Valid Time: 0.019\n",
            "Epoch: 579\n",
            "Train Loss: 0.0023723089650861525 | Train Time: 0.312\n",
            "Valid Loss: 0.00181073002750054 | Valid Time: 0.018\n",
            "Epoch: 580\n",
            "Train Loss: 0.002472806856722424 | Train Time: 0.303\n",
            "Valid Loss: 0.0019246205920353532 | Valid Time: 0.019\n",
            "Epoch: 581\n",
            "Train Loss: 0.002474985900335014 | Train Time: 0.315\n",
            "Valid Loss: 0.002437866816762835 | Valid Time: 0.019\n",
            "Epoch: 582\n",
            "Train Loss: 0.0025464749625442843 | Train Time: 0.276\n",
            "Valid Loss: 0.001849548367317766 | Valid Time: 0.011\n",
            "Epoch: 583\n",
            "Train Loss: 0.0023607628076876466 | Train Time: 0.194\n",
            "Valid Loss: 0.0017526584560982883 | Valid Time: 0.015\n",
            "Epoch: 584\n",
            "Train Loss: 0.0024212058143396127 | Train Time: 0.192\n",
            "Valid Loss: 0.0023152606445364654 | Valid Time: 0.025\n",
            "Epoch: 585\n",
            "Train Loss: 0.0024267429681985 | Train Time: 0.196\n",
            "Valid Loss: 0.0020920209935866296 | Valid Time: 0.015\n",
            "Epoch: 586\n",
            "Train Loss: 0.0023406426066924866 | Train Time: 0.195\n",
            "Valid Loss: 0.001993195852264762 | Valid Time: 0.015\n",
            "Epoch: 587\n",
            "Train Loss: 0.0024115235826588774 | Train Time: 0.196\n",
            "Valid Loss: 0.002092101378366351 | Valid Time: 0.018\n",
            "Epoch: 588\n",
            "Train Loss: 0.0023454585676326565 | Train Time: 0.192\n",
            "Valid Loss: 0.002244014700409025 | Valid Time: 0.016\n",
            "Epoch: 589\n",
            "Train Loss: 0.002395902968649017 | Train Time: 0.212\n",
            "Valid Loss: 0.0027013621293008327 | Valid Time: 0.011\n",
            "Epoch: 590\n",
            "Train Loss: 0.002504279291698415 | Train Time: 0.194\n",
            "Valid Loss: 0.002034279255894944 | Valid Time: 0.017\n",
            "Epoch: 591\n",
            "Train Loss: 0.00262236576772442 | Train Time: 0.209\n",
            "Valid Loss: 0.0023171608336269855 | Valid Time: 0.011\n",
            "Epoch: 592\n",
            "Train Loss: 0.0024858824234749925 | Train Time: 0.192\n",
            "Valid Loss: 0.002128935797372833 | Valid Time: 0.016\n",
            "Epoch: 593\n",
            "Train Loss: 0.0025798945173032975 | Train Time: 0.197\n",
            "Valid Loss: 0.0022101672366261482 | Valid Time: 0.016\n",
            "Epoch: 594\n",
            "Train Loss: 0.002370380526898723 | Train Time: 0.208\n",
            "Valid Loss: 0.002126906008925289 | Valid Time: 0.014\n",
            "Epoch: 595\n",
            "Train Loss: 0.002330087088538628 | Train Time: 0.197\n",
            "Valid Loss: 0.0019358634599484503 | Valid Time: 0.015\n",
            "Epoch: 596\n",
            "Train Loss: 0.0024369420777810248 | Train Time: 0.193\n",
            "Valid Loss: 0.0016912580176722258 | Valid Time: 0.014\n",
            "Epoch: 597\n",
            "Train Loss: 0.0023377615848164026 | Train Time: 0.192\n",
            "Valid Loss: 0.001907764410134405 | Valid Time: 0.019\n",
            "Epoch: 598\n",
            "Train Loss: 0.00239712435531577 | Train Time: 0.193\n",
            "Valid Loss: 0.0018256914045196027 | Valid Time: 0.015\n",
            "Epoch: 599\n",
            "Train Loss: 0.002458793227560818 | Train Time: 0.202\n",
            "Valid Loss: 0.0018082151364069432 | Valid Time: 0.015\n",
            "Epoch: 600\n",
            "Train Loss: 0.0024990219696375882 | Train Time: 0.198\n",
            "Valid Loss: 0.001903693686472252 | Valid Time: 0.015\n",
            "Epoch: 601\n",
            "Train Loss: 0.002442445973620603 | Train Time: 0.196\n",
            "Valid Loss: 0.0021802751580253243 | Valid Time: 0.017\n",
            "Epoch: 602\n",
            "Train Loss: 0.0024603738657836068 | Train Time: 0.187\n",
            "Valid Loss: 0.0018782211700454354 | Valid Time: 0.012\n",
            "Epoch: 603\n",
            "Train Loss: 0.002437424067848999 | Train Time: 0.198\n",
            "Valid Loss: 0.0022837878204882145 | Valid Time: 0.011\n",
            "Epoch: 604\n",
            "Train Loss: 0.0024651724869679463 | Train Time: 0.216\n",
            "Valid Loss: 0.0019164279801771045 | Valid Time: 0.011\n",
            "Epoch: 605\n",
            "Train Loss: 0.002400496655977086 | Train Time: 0.225\n",
            "Valid Loss: 0.002162352902814746 | Valid Time: 0.011\n",
            "Epoch: 606\n",
            "Train Loss: 0.0024816807187897595 | Train Time: 0.189\n",
            "Valid Loss: 0.001985477516427636 | Valid Time: 0.011\n",
            "Epoch: 607\n",
            "Train Loss: 0.0024345834849794443 | Train Time: 0.195\n",
            "Valid Loss: 0.002266165043693036 | Valid Time: 0.017\n",
            "Epoch: 608\n",
            "Train Loss: 0.0024623288037745575 | Train Time: 0.224\n",
            "Valid Loss: 0.0022336760303005576 | Valid Time: 0.012\n",
            "Epoch: 609\n",
            "Train Loss: 0.0023902132249388254 | Train Time: 0.195\n",
            "Valid Loss: 0.0018590723921079189 | Valid Time: 0.016\n",
            "Epoch: 610\n",
            "Train Loss: 0.002411023223478543 | Train Time: 0.194\n",
            "Valid Loss: 0.0019119211356155574 | Valid Time: 0.015\n",
            "Epoch: 611\n",
            "Train Loss: 0.0024052649846692618 | Train Time: 0.196\n",
            "Valid Loss: 0.002172245876863599 | Valid Time: 0.015\n",
            "Epoch: 612\n",
            "Train Loss: 0.0023485288869491533 | Train Time: 0.205\n",
            "Valid Loss: 0.0020638337009586394 | Valid Time: 0.018\n",
            "Epoch: 613\n",
            "Train Loss: 0.0023593992595315762 | Train Time: 0.214\n",
            "Valid Loss: 0.001976261177333072 | Valid Time: 0.011\n",
            "Epoch: 614\n",
            "Train Loss: 0.002371513523700598 | Train Time: 0.208\n",
            "Valid Loss: 0.0020682241884060204 | Valid Time: 0.011\n",
            "Epoch: 615\n",
            "Train Loss: 0.0024695187243387886 | Train Time: 0.191\n",
            "Valid Loss: 0.0018277076014783233 | Valid Time: 0.018\n",
            "Epoch: 616\n",
            "Train Loss: 0.002321190464212314 | Train Time: 0.192\n",
            "Valid Loss: 0.001695653743809089 | Valid Time: 0.017\n",
            "Epoch: 617\n",
            "Train Loss: 0.002415505580996212 | Train Time: 0.199\n",
            "Valid Loss: 0.002105073712300509 | Valid Time: 0.016\n",
            "Epoch: 618\n",
            "Train Loss: 0.0024341006248601174 | Train Time: 0.218\n",
            "Valid Loss: 0.0017652197857387364 | Valid Time: 0.012\n",
            "Epoch: 619\n",
            "Train Loss: 0.002479750552753869 | Train Time: 0.207\n",
            "Valid Loss: 0.001844581012846902 | Valid Time: 0.013\n",
            "Epoch: 620\n",
            "Train Loss: 0.0023817330366000533 | Train Time: 0.193\n",
            "Valid Loss: 0.001850883854785934 | Valid Time: 0.014\n",
            "Epoch: 621\n",
            "Train Loss: 0.0024142341173597074 | Train Time: 0.196\n",
            "Valid Loss: 0.0020943251147400588 | Valid Time: 0.016\n",
            "Epoch: 622\n",
            "Train Loss: 0.002421158672261395 | Train Time: 0.189\n",
            "Valid Loss: 0.002106314495904371 | Valid Time: 0.022\n",
            "Epoch: 623\n",
            "Train Loss: 0.0025273066222373593 | Train Time: 0.210\n",
            "Valid Loss: 0.0017509213066659868 | Valid Time: 0.012\n",
            "Epoch: 624\n",
            "Train Loss: 0.0024219875616070473 | Train Time: 0.199\n",
            "Valid Loss: 0.0017770128324627876 | Valid Time: 0.015\n",
            "Epoch: 625\n",
            "Train Loss: 0.002540913906781689 | Train Time: 0.199\n",
            "Valid Loss: 0.0021951801027171314 | Valid Time: 0.017\n",
            "Epoch: 626\n",
            "Train Loss: 0.002551495183357283 | Train Time: 0.195\n",
            "Valid Loss: 0.0024462006404064596 | Valid Time: 0.015\n",
            "Epoch: 627\n",
            "Train Loss: 0.002464495905625977 | Train Time: 0.206\n",
            "Valid Loss: 0.0018918773857876658 | Valid Time: 0.014\n",
            "Epoch: 628\n",
            "Train Loss: 0.002394066694633741 | Train Time: 0.197\n",
            "Valid Loss: 0.0017124027945101261 | Valid Time: 0.026\n",
            "Epoch: 629\n",
            "Train Loss: 0.002339509597636367 | Train Time: 0.310\n",
            "Valid Loss: 0.0020052642794325948 | Valid Time: 0.022\n",
            "Epoch: 630\n",
            "Train Loss: 0.0023382739531562515 | Train Time: 0.311\n",
            "Valid Loss: 0.002048610389465466 | Valid Time: 0.017\n",
            "Epoch: 631\n",
            "Train Loss: 0.002509221698059455 | Train Time: 0.317\n",
            "Valid Loss: 0.0020309147948864847 | Valid Time: 0.018\n",
            "Epoch: 632\n",
            "Train Loss: 0.0024199410476476737 | Train Time: 0.316\n",
            "Valid Loss: 0.002112331800162792 | Valid Time: 0.019\n",
            "Epoch: 633\n",
            "Train Loss: 0.002434279849311631 | Train Time: 0.313\n",
            "Valid Loss: 0.0019516589818522334 | Valid Time: 0.017\n",
            "Epoch: 634\n",
            "Train Loss: 0.002608898261218871 | Train Time: 0.314\n",
            "Valid Loss: 0.0020232988172210753 | Valid Time: 0.017\n",
            "Epoch: 635\n",
            "Train Loss: 0.0024617076545071447 | Train Time: 0.313\n",
            "Valid Loss: 0.001837201532907784 | Valid Time: 0.017\n",
            "Epoch: 636\n",
            "Train Loss: 0.002448900645647786 | Train Time: 0.324\n",
            "Valid Loss: 0.001805792038794607 | Valid Time: 0.019\n",
            "Epoch: 637\n",
            "Train Loss: 0.0025777393755944153 | Train Time: 0.214\n",
            "Valid Loss: 0.002442561148200184 | Valid Time: 0.012\n",
            "Epoch: 638\n",
            "Train Loss: 0.0027360246872137253 | Train Time: 0.200\n",
            "Valid Loss: 0.0018123253539670259 | Valid Time: 0.017\n",
            "Epoch: 639\n",
            "Train Loss: 0.0023950238981725355 | Train Time: 0.203\n",
            "Valid Loss: 0.00190222667879425 | Valid Time: 0.014\n",
            "Epoch: 640\n",
            "Train Loss: 0.0023503034302082503 | Train Time: 0.195\n",
            "Valid Loss: 0.0020549999026115984 | Valid Time: 0.016\n",
            "Epoch: 641\n",
            "Train Loss: 0.002456772582311379 | Train Time: 0.192\n",
            "Valid Loss: 0.001967402844456956 | Valid Time: 0.014\n",
            "Epoch: 642\n",
            "Train Loss: 0.00243399180716982 | Train Time: 0.217\n",
            "Valid Loss: 0.0022679342364426702 | Valid Time: 0.011\n",
            "Epoch: 643\n",
            "Train Loss: 0.0024202062417507954 | Train Time: 0.188\n",
            "Valid Loss: 0.002511519589461386 | Valid Time: 0.015\n",
            "Epoch: 644\n",
            "Train Loss: 0.00245566331585379 | Train Time: 0.197\n",
            "Valid Loss: 0.002089876274112612 | Valid Time: 0.018\n",
            "Epoch: 645\n",
            "Train Loss: 0.0023365302231947056 | Train Time: 0.210\n",
            "Valid Loss: 0.0022926346864551306 | Valid Time: 0.013\n",
            "Epoch: 646\n",
            "Train Loss: 0.0023807082263948886 | Train Time: 0.190\n",
            "Valid Loss: 0.0022645102289970964 | Valid Time: 0.013\n",
            "Epoch: 647\n",
            "Train Loss: 0.002398913811990305 | Train Time: 0.227\n",
            "Valid Loss: 0.0017468217411078513 | Valid Time: 0.011\n",
            "Epoch: 648\n",
            "Train Loss: 0.002390592702125248 | Train Time: 0.207\n",
            "Valid Loss: 0.0018629236437845975 | Valid Time: 0.012\n",
            "Epoch: 649\n",
            "Train Loss: 0.002417770336921278 | Train Time: 0.215\n",
            "Valid Loss: 0.0023070943425409496 | Valid Time: 0.011\n",
            "Epoch: 650\n",
            "Train Loss: 0.0024839387471346478 | Train Time: 0.213\n",
            "Valid Loss: 0.002306621172465384 | Valid Time: 0.011\n",
            "Epoch: 651\n",
            "Train Loss: 0.0024145925049915127 | Train Time: 0.204\n",
            "Valid Loss: 0.0021517415007110685 | Valid Time: 0.017\n",
            "Epoch: 652\n",
            "Train Loss: 0.0025159521886196578 | Train Time: 0.191\n",
            "Valid Loss: 0.0022058748290874064 | Valid Time: 0.015\n",
            "Epoch: 653\n",
            "Train Loss: 0.0024692844476942952 | Train Time: 0.207\n",
            "Valid Loss: 0.001976009923964739 | Valid Time: 0.013\n",
            "Epoch: 654\n",
            "Train Loss: 0.0024569549561037044 | Train Time: 0.199\n",
            "Valid Loss: 0.0020473955664783716 | Valid Time: 0.017\n",
            "Epoch: 655\n",
            "Train Loss: 0.0025901219586988815 | Train Time: 0.192\n",
            "Valid Loss: 0.002317093254532665 | Valid Time: 0.017\n",
            "Epoch: 656\n",
            "Train Loss: 0.0025692345868600043 | Train Time: 0.209\n",
            "Valid Loss: 0.002533239545300603 | Valid Time: 0.011\n",
            "Epoch: 657\n",
            "Train Loss: 0.0023873351257000315 | Train Time: 0.194\n",
            "Valid Loss: 0.002348671230720356 | Valid Time: 0.015\n",
            "Epoch: 658\n",
            "Train Loss: 0.002440952205736386 | Train Time: 0.186\n",
            "Valid Loss: 0.002710504166316241 | Valid Time: 0.012\n",
            "Epoch: 659\n",
            "Train Loss: 0.0024191297370156177 | Train Time: 0.198\n",
            "Valid Loss: 0.0019832219986710697 | Valid Time: 0.011\n",
            "Epoch: 660\n",
            "Train Loss: 0.002530781307110661 | Train Time: 0.184\n",
            "Valid Loss: 0.0019513030420057476 | Valid Time: 0.016\n",
            "Epoch: 661\n",
            "Train Loss: 0.002405924410069067 | Train Time: 0.207\n",
            "Valid Loss: 0.0020009687286801636 | Valid Time: 0.011\n",
            "Epoch: 662\n",
            "Train Loss: 0.002316550872484712 | Train Time: 0.193\n",
            "Valid Loss: 0.002270807570312172 | Valid Time: 0.016\n",
            "Epoch: 663\n",
            "Train Loss: 0.0023400386501299707 | Train Time: 0.196\n",
            "Valid Loss: 0.0020962791750207543 | Valid Time: 0.015\n",
            "Epoch: 664\n",
            "Train Loss: 0.002389009453748402 | Train Time: 0.188\n",
            "Valid Loss: 0.0022470199037343264 | Valid Time: 0.013\n",
            "Epoch: 665\n",
            "Train Loss: 0.002439062693156302 | Train Time: 0.195\n",
            "Valid Loss: 0.0019522706279531121 | Valid Time: 0.011\n",
            "Epoch: 666\n",
            "Train Loss: 0.002346055943665928 | Train Time: 0.208\n",
            "Valid Loss: 0.0018151603289879858 | Valid Time: 0.011\n",
            "Epoch: 667\n",
            "Train Loss: 0.0023643398032474673 | Train Time: 0.191\n",
            "Valid Loss: 0.0018387430463917553 | Valid Time: 0.015\n",
            "Epoch: 668\n",
            "Train Loss: 0.0024289920754534634 | Train Time: 0.196\n",
            "Valid Loss: 0.0021632364368997514 | Valid Time: 0.016\n",
            "Epoch: 669\n",
            "Train Loss: 0.0024689532644850644 | Train Time: 0.191\n",
            "Valid Loss: 0.0020096927182748914 | Valid Time: 0.016\n",
            "Epoch: 670\n",
            "Train Loss: 0.002465343280499311 | Train Time: 0.198\n",
            "Valid Loss: 0.0019518793560564518 | Valid Time: 0.024\n",
            "Epoch: 671\n",
            "Train Loss: 0.0023743709439019624 | Train Time: 0.192\n",
            "Valid Loss: 0.002088093606289476 | Valid Time: 0.015\n",
            "Epoch: 672\n",
            "Train Loss: 0.002460404838386335 | Train Time: 0.199\n",
            "Valid Loss: 0.0021672592556569725 | Valid Time: 0.017\n",
            "Epoch: 673\n",
            "Train Loss: 0.0023711895643684423 | Train Time: 0.196\n",
            "Valid Loss: 0.0019991044246125966 | Valid Time: 0.016\n",
            "Epoch: 674\n",
            "Train Loss: 0.002470074570737779 | Train Time: 0.200\n",
            "Valid Loss: 0.002258638822240755 | Valid Time: 0.018\n",
            "Epoch: 675\n",
            "Train Loss: 0.0024324925861468442 | Train Time: 0.213\n",
            "Valid Loss: 0.0021198649192228913 | Valid Time: 0.013\n",
            "Epoch: 676\n",
            "Train Loss: 0.0024065283237417277 | Train Time: 0.192\n",
            "Valid Loss: 0.0018706469563767314 | Valid Time: 0.017\n",
            "Epoch: 677\n",
            "Train Loss: 0.0023821601889243253 | Train Time: 0.190\n",
            "Valid Loss: 0.001794039213564247 | Valid Time: 0.015\n",
            "Epoch: 678\n",
            "Train Loss: 0.0023783768012531495 | Train Time: 0.192\n",
            "Valid Loss: 0.0018863790319301188 | Valid Time: 0.013\n",
            "Epoch: 679\n",
            "Train Loss: 0.0023019768444723205 | Train Time: 0.190\n",
            "Valid Loss: 0.00203840242465958 | Valid Time: 0.012\n",
            "Epoch: 680\n",
            "Train Loss: 0.0024479442263806335 | Train Time: 0.221\n",
            "Valid Loss: 0.002087481552734971 | Valid Time: 0.011\n",
            "Epoch: 681\n",
            "Train Loss: 0.0024210820342168995 | Train Time: 0.189\n",
            "Valid Loss: 0.0023511816398240626 | Valid Time: 0.014\n",
            "Epoch: 682\n",
            "Train Loss: 0.00244123583022309 | Train Time: 0.195\n",
            "Valid Loss: 0.002139354415703565 | Valid Time: 0.017\n",
            "Epoch: 683\n",
            "Train Loss: 0.0023567138521588945 | Train Time: 0.241\n",
            "Valid Loss: 0.001794005569536239 | Valid Time: 0.019\n",
            "Epoch: 684\n",
            "Train Loss: 0.0023507408209537204 | Train Time: 0.327\n",
            "Valid Loss: 0.0016600913659203798 | Valid Time: 0.018\n",
            "Epoch: 685\n",
            "Train Loss: 0.0023648781750939393 | Train Time: 0.321\n",
            "Valid Loss: 0.001940005284268409 | Valid Time: 0.017\n",
            "Epoch: 686\n",
            "Train Loss: 0.002355899588253937 | Train Time: 0.306\n",
            "Valid Loss: 0.0019751438521780074 | Valid Time: 0.017\n",
            "Epoch: 687\n",
            "Train Loss: 0.0024577374876427805 | Train Time: 0.312\n",
            "Valid Loss: 0.0016931460559135303 | Valid Time: 0.017\n",
            "Epoch: 688\n",
            "Train Loss: 0.002477967609210234 | Train Time: 0.309\n",
            "Valid Loss: 0.0020141325367148966 | Valid Time: 0.016\n",
            "Epoch: 689\n",
            "Train Loss: 0.0023928142557116715 | Train Time: 0.302\n",
            "Valid Loss: 0.0019398915756028146 | Valid Time: 0.019\n",
            "Epoch: 690\n",
            "Train Loss: 0.00236550752857798 | Train Time: 0.308\n",
            "Valid Loss: 0.0020469117735046893 | Valid Time: 0.021\n",
            "Epoch: 691\n",
            "Train Loss: 0.0023384518786578588 | Train Time: 0.300\n",
            "Valid Loss: 0.002030246949288994 | Valid Time: 0.012\n",
            "Epoch: 692\n",
            "Train Loss: 0.0024111991883010455 | Train Time: 0.197\n",
            "Valid Loss: 0.0019444848003331572 | Valid Time: 0.016\n",
            "Epoch: 693\n",
            "Train Loss: 0.002457485644538936 | Train Time: 0.198\n",
            "Valid Loss: 0.002310507610673085 | Valid Time: 0.016\n",
            "Epoch: 694\n",
            "Train Loss: 0.002340808700721123 | Train Time: 0.192\n",
            "Valid Loss: 0.0018461305589880794 | Valid Time: 0.014\n",
            "Epoch: 695\n",
            "Train Loss: 0.002363623977687798 | Train Time: 0.209\n",
            "Valid Loss: 0.0018459393468219787 | Valid Time: 0.015\n",
            "Epoch: 696\n",
            "Train Loss: 0.0023499004003640855 | Train Time: 0.191\n",
            "Valid Loss: 0.0022249245666898787 | Valid Time: 0.014\n",
            "Epoch: 697\n",
            "Train Loss: 0.0024134962893042123 | Train Time: 0.192\n",
            "Valid Loss: 0.0021400980185717344 | Valid Time: 0.015\n",
            "Epoch: 698\n",
            "Train Loss: 0.0024329692762541143 | Train Time: 0.196\n",
            "Valid Loss: 0.0021149062376935035 | Valid Time: 0.016\n",
            "Epoch: 699\n",
            "Train Loss: 0.0024489235672119415 | Train Time: 0.187\n",
            "Valid Loss: 0.001876337657449767 | Valid Time: 0.011\n",
            "Epoch: 700\n",
            "Train Loss: 0.0023625481836987952 | Train Time: 0.219\n",
            "Valid Loss: 0.0022912314161658287 | Valid Time: 0.012\n",
            "Epoch: 701\n",
            "Train Loss: 0.0023720942768513374 | Train Time: 0.193\n",
            "Valid Loss: 0.002276818559039384 | Valid Time: 0.016\n",
            "Epoch: 702\n",
            "Train Loss: 0.0024893093964477118 | Train Time: 0.191\n",
            "Valid Loss: 0.001972171012312174 | Valid Time: 0.017\n",
            "Epoch: 703\n",
            "Train Loss: 0.002536561407491957 | Train Time: 0.201\n",
            "Valid Loss: 0.002254897204693407 | Valid Time: 0.017\n",
            "Epoch: 704\n",
            "Train Loss: 0.0024528913935156246 | Train Time: 0.193\n",
            "Valid Loss: 0.001963173446711153 | Valid Time: 0.018\n",
            "Epoch: 705\n",
            "Train Loss: 0.0023358933456046017 | Train Time: 0.213\n",
            "Valid Loss: 0.0017204553005285561 | Valid Time: 0.015\n",
            "Epoch: 706\n",
            "Train Loss: 0.00235128781366113 | Train Time: 0.184\n",
            "Valid Loss: 0.0018975032435264438 | Valid Time: 0.011\n",
            "Epoch: 707\n",
            "Train Loss: 0.002296972076261514 | Train Time: 0.206\n",
            "Valid Loss: 0.0017538995889481157 | Valid Time: 0.011\n",
            "Epoch: 708\n",
            "Train Loss: 0.002316726996612392 | Train Time: 0.187\n",
            "Valid Loss: 0.0019340783474035561 | Valid Time: 0.011\n",
            "Epoch: 709\n",
            "Train Loss: 0.0023159392080024667 | Train Time: 0.207\n",
            "Valid Loss: 0.0019172706815879792 | Valid Time: 0.013\n",
            "Epoch: 710\n",
            "Train Loss: 0.002365650033186141 | Train Time: 0.194\n",
            "Valid Loss: 0.0019148026185575873 | Valid Time: 0.016\n",
            "Epoch: 711\n",
            "Train Loss: 0.002350965618940168 | Train Time: 0.190\n",
            "Valid Loss: 0.002098708297125995 | Valid Time: 0.014\n",
            "Epoch: 712\n",
            "Train Loss: 0.0023342505048372245 | Train Time: 0.201\n",
            "Valid Loss: 0.0022179118532221764 | Valid Time: 0.016\n",
            "Epoch: 713\n",
            "Train Loss: 0.002409496448787027 | Train Time: 0.189\n",
            "Valid Loss: 0.0019063073268625885 | Valid Time: 0.012\n",
            "Epoch: 714\n",
            "Train Loss: 0.0024463275177894453 | Train Time: 0.206\n",
            "Valid Loss: 0.00191861143684946 | Valid Time: 0.012\n",
            "Epoch: 715\n",
            "Train Loss: 0.0023681837085046268 | Train Time: 0.196\n",
            "Valid Loss: 0.002085704851197079 | Valid Time: 0.016\n",
            "Epoch: 716\n",
            "Train Loss: 0.0023698498384634916 | Train Time: 0.186\n",
            "Valid Loss: 0.002139396092388779 | Valid Time: 0.011\n",
            "Epoch: 717\n",
            "Train Loss: 0.0023916837220129216 | Train Time: 0.202\n",
            "Valid Loss: 0.002744518656982109 | Valid Time: 0.011\n",
            "Epoch: 718\n",
            "Train Loss: 0.0024275671519143017 | Train Time: 0.194\n",
            "Valid Loss: 0.0019328068883623928 | Valid Time: 0.017\n",
            "Epoch: 719\n",
            "Train Loss: 0.0025239909729479174 | Train Time: 0.205\n",
            "Valid Loss: 0.002529076358769089 | Valid Time: 0.018\n",
            "Epoch: 720\n",
            "Train Loss: 0.0025199717339618424 | Train Time: 0.192\n",
            "Valid Loss: 0.002634176518768072 | Valid Time: 0.014\n",
            "Epoch: 721\n",
            "Train Loss: 0.0024403258667964685 | Train Time: 0.197\n",
            "Valid Loss: 0.0020083831332158297 | Valid Time: 0.016\n",
            "Epoch: 722\n",
            "Train Loss: 0.002430907830497936 | Train Time: 0.196\n",
            "Valid Loss: 0.0019080047204624861 | Valid Time: 0.017\n",
            "Epoch: 723\n",
            "Train Loss: 0.0023966817626435506 | Train Time: 0.193\n",
            "Valid Loss: 0.0017372750444337726 | Valid Time: 0.016\n",
            "Epoch: 724\n",
            "Train Loss: 0.0025180305084703783 | Train Time: 0.205\n",
            "Valid Loss: 0.0023035554913803935 | Valid Time: 0.012\n",
            "Epoch: 725\n",
            "Train Loss: 0.0023601649353574765 | Train Time: 0.184\n",
            "Valid Loss: 0.0021834536746609956 | Valid Time: 0.011\n",
            "Epoch: 726\n",
            "Train Loss: 0.0024380878128699565 | Train Time: 0.210\n",
            "Valid Loss: 0.0017608987400308251 | Valid Time: 0.011\n",
            "Epoch: 727\n",
            "Train Loss: 0.002442519070188466 | Train Time: 0.198\n",
            "Valid Loss: 0.0016830579552333802 | Valid Time: 0.017\n",
            "Epoch: 728\n",
            "Train Loss: 0.0023676640121266246 | Train Time: 0.190\n",
            "Valid Loss: 0.0019569048890843987 | Valid Time: 0.016\n",
            "Epoch: 729\n",
            "Train Loss: 0.0023262341335219773 | Train Time: 0.213\n",
            "Valid Loss: 0.0020360968192107975 | Valid Time: 0.012\n",
            "Epoch: 730\n",
            "Train Loss: 0.0023082557477449115 | Train Time: 0.200\n",
            "Valid Loss: 0.0020943933341186494 | Valid Time: 0.021\n",
            "Epoch: 731\n",
            "Train Loss: 0.002314511711071981 | Train Time: 0.187\n",
            "Valid Loss: 0.0020279202144593 | Valid Time: 0.020\n",
            "Epoch: 732\n",
            "Train Loss: 0.0024357062004702655 | Train Time: 0.189\n",
            "Valid Loss: 0.0019979238277301192 | Valid Time: 0.011\n",
            "Epoch: 733\n",
            "Train Loss: 0.0023507358947474706 | Train Time: 0.207\n",
            "Valid Loss: 0.001850536878919229 | Valid Time: 0.013\n",
            "Epoch: 734\n",
            "Train Loss: 0.002324478443417894 | Train Time: 0.196\n",
            "Valid Loss: 0.00193340569967404 | Valid Time: 0.018\n",
            "Epoch: 735\n",
            "Train Loss: 0.0023522787163720318 | Train Time: 0.186\n",
            "Valid Loss: 0.0022131633013486862 | Valid Time: 0.012\n",
            "Epoch: 736\n",
            "Train Loss: 0.0024190942364695823 | Train Time: 0.199\n",
            "Valid Loss: 0.002095920091960579 | Valid Time: 0.011\n",
            "Epoch: 737\n",
            "Train Loss: 0.002339890453425285 | Train Time: 0.211\n",
            "Valid Loss: 0.0026600189157761633 | Valid Time: 0.011\n",
            "Epoch: 738\n",
            "Train Loss: 0.0024331762872048116 | Train Time: 0.240\n",
            "Valid Loss: 0.002028435264946893 | Valid Time: 0.018\n",
            "Epoch: 739\n",
            "Train Loss: 0.002322794079143358 | Train Time: 0.319\n",
            "Valid Loss: 0.0018137727456633002 | Valid Time: 0.023\n",
            "Epoch: 740\n",
            "Train Loss: 0.0023340383838666113 | Train Time: 0.303\n",
            "Valid Loss: 0.0018413575598970056 | Valid Time: 0.017\n",
            "Epoch: 741\n",
            "Train Loss: 0.0023313241422568496 | Train Time: 0.316\n",
            "Valid Loss: 0.0017843300302047282 | Valid Time: 0.018\n",
            "Epoch: 742\n",
            "Train Loss: 0.0023663786154142336 | Train Time: 0.313\n",
            "Valid Loss: 0.0019488547695800662 | Valid Time: 0.018\n",
            "Epoch: 743\n",
            "Train Loss: 0.0024343796111153146 | Train Time: 0.316\n",
            "Valid Loss: 0.0018085855845129117 | Valid Time: 0.017\n",
            "Epoch: 744\n",
            "Train Loss: 0.0023704697623064645 | Train Time: 0.338\n",
            "Valid Loss: 0.0018544338236097246 | Valid Time: 0.019\n",
            "Epoch: 745\n",
            "Train Loss: 0.002396833506951991 | Train Time: 0.309\n",
            "Valid Loss: 0.002247679774882272 | Valid Time: 0.018\n",
            "Epoch: 746\n",
            "Train Loss: 0.0023862417223618217 | Train Time: 0.268\n",
            "Valid Loss: 0.0020190265495330095 | Valid Time: 0.012\n",
            "Epoch: 747\n",
            "Train Loss: 0.002407658992237166 | Train Time: 0.202\n",
            "Valid Loss: 0.0018154144927393645 | Valid Time: 0.015\n",
            "Epoch: 748\n",
            "Train Loss: 0.002335079112335255 | Train Time: 0.241\n",
            "Valid Loss: 0.0019904103537555784 | Valid Time: 0.013\n",
            "Epoch: 749\n",
            "Train Loss: 0.002310962109875522 | Train Time: 0.219\n",
            "Valid Loss: 0.0017482978291809559 | Valid Time: 0.012\n",
            "Epoch: 750\n",
            "Train Loss: 0.0024304696983706796 | Train Time: 0.199\n",
            "Valid Loss: 0.0016891506093088537 | Valid Time: 0.016\n",
            "Epoch: 751\n",
            "Train Loss: 0.0025394201450245945 | Train Time: 0.200\n",
            "Valid Loss: 0.002443682693410665 | Valid Time: 0.017\n",
            "Epoch: 752\n",
            "Train Loss: 0.002404929585999956 | Train Time: 0.214\n",
            "Valid Loss: 0.002131936198566109 | Valid Time: 0.011\n",
            "Epoch: 753\n",
            "Train Loss: 0.0023031124575553755 | Train Time: 0.308\n",
            "Valid Loss: 0.0019897845631930977 | Valid Time: 0.018\n",
            "Epoch: 754\n",
            "Train Loss: 0.002390627063026554 | Train Time: 0.320\n",
            "Valid Loss: 0.001883015938801691 | Valid Time: 0.017\n",
            "Epoch: 755\n",
            "Train Loss: 0.0024126799666861955 | Train Time: 0.314\n",
            "Valid Loss: 0.001998577849008143 | Valid Time: 0.017\n",
            "Epoch: 756\n",
            "Train Loss: 0.0024118316421089204 | Train Time: 0.322\n",
            "Valid Loss: 0.002165815036278218 | Valid Time: 0.017\n",
            "Epoch: 757\n",
            "Train Loss: 0.002441358948616605 | Train Time: 0.313\n",
            "Valid Loss: 0.0020453782635740936 | Valid Time: 0.017\n",
            "Epoch: 758\n",
            "Train Loss: 0.002437668172397504 | Train Time: 0.309\n",
            "Valid Loss: 0.001951287646079436 | Valid Time: 0.018\n",
            "Epoch: 759\n",
            "Train Loss: 0.0025547859871661977 | Train Time: 0.328\n",
            "Valid Loss: 0.0021058332931715995 | Valid Time: 0.020\n",
            "Epoch: 760\n",
            "Train Loss: 0.0024105336786688944 | Train Time: 0.316\n",
            "Valid Loss: 0.0019598295039031655 | Valid Time: 0.014\n",
            "Epoch: 761\n",
            "Train Loss: 0.0023917323468547118 | Train Time: 0.194\n",
            "Valid Loss: 0.00195271335542202 | Valid Time: 0.016\n",
            "Epoch: 762\n",
            "Train Loss: 0.002344793940306102 | Train Time: 0.195\n",
            "Valid Loss: 0.0022652574989479035 | Valid Time: 0.016\n",
            "Epoch: 763\n",
            "Train Loss: 0.002369332746112425 | Train Time: 0.204\n",
            "Valid Loss: 0.0018961030873470008 | Valid Time: 0.013\n",
            "Epoch: 764\n",
            "Train Loss: 0.00232902580970212 | Train Time: 0.192\n",
            "Valid Loss: 0.0017696804425213486 | Valid Time: 0.019\n",
            "Epoch: 765\n",
            "Train Loss: 0.0024134882872826175 | Train Time: 0.186\n",
            "Valid Loss: 0.0017628568748477846 | Valid Time: 0.012\n",
            "Epoch: 766\n",
            "Train Loss: 0.00231296733315838 | Train Time: 0.202\n",
            "Valid Loss: 0.002053826756309718 | Valid Time: 0.014\n",
            "Epoch: 767\n",
            "Train Loss: 0.0023608527538415635 | Train Time: 0.194\n",
            "Valid Loss: 0.0019857222796417773 | Valid Time: 0.016\n",
            "Epoch: 768\n",
            "Train Loss: 0.0023231323391787314 | Train Time: 0.198\n",
            "Valid Loss: 0.001725921785691753 | Valid Time: 0.018\n",
            "Epoch: 769\n",
            "Train Loss: 0.0024148007291124054 | Train Time: 0.204\n",
            "Valid Loss: 0.0022188801667653024 | Valid Time: 0.016\n",
            "Epoch: 770\n",
            "Train Loss: 0.002419890676576056 | Train Time: 0.193\n",
            "Valid Loss: 0.0019200084207113832 | Valid Time: 0.017\n",
            "Epoch: 771\n",
            "Train Loss: 0.00236642973399476 | Train Time: 0.195\n",
            "Valid Loss: 0.002052347408607602 | Valid Time: 0.018\n",
            "Epoch: 772\n",
            "Train Loss: 0.00244803202804178 | Train Time: 0.206\n",
            "Valid Loss: 0.0019586501584853977 | Valid Time: 0.014\n",
            "Epoch: 773\n",
            "Train Loss: 0.0026257873181939908 | Train Time: 0.193\n",
            "Valid Loss: 0.00195284080109559 | Valid Time: 0.017\n",
            "Epoch: 774\n",
            "Train Loss: 0.0023618162315534917 | Train Time: 0.186\n",
            "Valid Loss: 0.001981297362362966 | Valid Time: 0.011\n",
            "Epoch: 775\n",
            "Train Loss: 0.002588008187319103 | Train Time: 0.195\n",
            "Valid Loss: 0.0019446133228484541 | Valid Time: 0.011\n",
            "Epoch: 776\n",
            "Train Loss: 0.0024099708534777164 | Train Time: 0.210\n",
            "Valid Loss: 0.002000024192966521 | Valid Time: 0.011\n",
            "Epoch: 777\n",
            "Train Loss: 0.0023638366317180427 | Train Time: 0.208\n",
            "Valid Loss: 0.0021485009347088635 | Valid Time: 0.013\n",
            "Epoch: 778\n",
            "Train Loss: 0.0023462971010686537 | Train Time: 0.195\n",
            "Valid Loss: 0.002181801974074915 | Valid Time: 0.017\n",
            "Epoch: 779\n",
            "Train Loss: 0.002556645605517061 | Train Time: 0.214\n",
            "Valid Loss: 0.001959298300789669 | Valid Time: 0.011\n",
            "Epoch: 780\n",
            "Train Loss: 0.002388258335964852 | Train Time: 0.196\n",
            "Valid Loss: 0.0017935778596438468 | Valid Time: 0.017\n",
            "Epoch: 781\n",
            "Train Loss: 0.002375258592349526 | Train Time: 0.192\n",
            "Valid Loss: 0.0020287570368964225 | Valid Time: 0.019\n",
            "Epoch: 782\n",
            "Train Loss: 0.0023117270014297807 | Train Time: 0.196\n",
            "Valid Loss: 0.001926444994751364 | Valid Time: 0.019\n",
            "Epoch: 783\n",
            "Train Loss: 0.0024190902109502963 | Train Time: 0.195\n",
            "Valid Loss: 0.0018837714160326868 | Valid Time: 0.017\n",
            "Epoch: 784\n",
            "Train Loss: 0.0024915088740128434 | Train Time: 0.201\n",
            "Valid Loss: 0.002143849356798455 | Valid Time: 0.013\n",
            "Epoch: 785\n",
            "Train Loss: 0.00233508327265123 | Train Time: 0.193\n",
            "Valid Loss: 0.001728648116113618 | Valid Time: 0.016\n",
            "Epoch: 786\n",
            "Train Loss: 0.0023314518682462605 | Train Time: 0.191\n",
            "Valid Loss: 0.0018653144070412964 | Valid Time: 0.015\n",
            "Epoch: 787\n",
            "Train Loss: 0.0023497461561897866 | Train Time: 0.213\n",
            "Valid Loss: 0.0017906294669955969 | Valid Time: 0.011\n",
            "Epoch: 788\n",
            "Train Loss: 0.002313486233010496 | Train Time: 0.280\n",
            "Valid Loss: 0.0021940668229945004 | Valid Time: 0.018\n",
            "Epoch: 789\n",
            "Train Loss: 0.0023997338660257427 | Train Time: 0.313\n",
            "Valid Loss: 0.0019426210492383689 | Valid Time: 0.018\n",
            "Epoch: 790\n",
            "Train Loss: 0.0024636913164469755 | Train Time: 0.308\n",
            "Valid Loss: 0.002609799208585173 | Valid Time: 0.016\n",
            "Epoch: 791\n",
            "Train Loss: 0.002509143080954489 | Train Time: 0.308\n",
            "Valid Loss: 0.0019515128806233406 | Valid Time: 0.020\n",
            "Epoch: 792\n",
            "Train Loss: 0.0023673891678060357 | Train Time: 0.318\n",
            "Valid Loss: 0.0020367813121993095 | Valid Time: 0.017\n",
            "Epoch: 793\n",
            "Train Loss: 0.002504929673465851 | Train Time: 0.306\n",
            "Valid Loss: 0.002092497394187376 | Valid Time: 0.019\n",
            "Epoch: 794\n",
            "Train Loss: 0.002412770537806577 | Train Time: 0.322\n",
            "Valid Loss: 0.0019566522096283734 | Valid Time: 0.018\n",
            "Epoch: 795\n",
            "Train Loss: 0.00240630547418014 | Train Time: 0.312\n",
            "Valid Loss: 0.0019433314155321568 | Valid Time: 0.020\n",
            "Epoch: 796\n",
            "Train Loss: 0.002405575464332574 | Train Time: 0.230\n",
            "Valid Loss: 0.0019964434613939375 | Valid Time: 0.013\n",
            "Epoch: 797\n",
            "Train Loss: 0.0023140162658436517 | Train Time: 0.211\n",
            "Valid Loss: 0.0022788922942709178 | Valid Time: 0.015\n",
            "Epoch: 798\n",
            "Train Loss: 0.0023700687605397483 | Train Time: 0.201\n",
            "Valid Loss: 0.0016918199689825997 | Valid Time: 0.015\n",
            "Epoch: 799\n",
            "Train Loss: 0.0023246430608100796 | Train Time: 0.203\n",
            "Valid Loss: 0.002550717181293294 | Valid Time: 0.014\n",
            "Epoch: 800\n",
            "Train Loss: 0.0025585157318825 | Train Time: 0.193\n",
            "Valid Loss: 0.00185001379577443 | Valid Time: 0.016\n",
            "Epoch: 801\n",
            "Train Loss: 0.002476056235058135 | Train Time: 0.194\n",
            "Valid Loss: 0.0022815834381617606 | Valid Time: 0.016\n",
            "Epoch: 802\n",
            "Train Loss: 0.0025298773605180415 | Train Time: 0.208\n",
            "Valid Loss: 0.001976596307940781 | Valid Time: 0.013\n",
            "Epoch: 803\n",
            "Train Loss: 0.002612281633590005 | Train Time: 0.197\n",
            "Valid Loss: 0.0026910033193416893 | Valid Time: 0.017\n",
            "Epoch: 804\n",
            "Train Loss: 0.0027708481678641156 | Train Time: 0.190\n",
            "Valid Loss: 0.0019480595947243273 | Valid Time: 0.014\n",
            "Epoch: 805\n",
            "Train Loss: 0.002428318171663896 | Train Time: 0.198\n",
            "Valid Loss: 0.0021107794891577214 | Valid Time: 0.017\n",
            "Epoch: 806\n",
            "Train Loss: 0.0023384849528635017 | Train Time: 0.209\n",
            "Valid Loss: 0.0019726182508748025 | Valid Time: 0.011\n",
            "Epoch: 807\n",
            "Train Loss: 0.0023350631756904093 | Train Time: 0.187\n",
            "Valid Loss: 0.001924706215504557 | Valid Time: 0.012\n",
            "Epoch: 808\n",
            "Train Loss: 0.002299273018970301 | Train Time: 0.200\n",
            "Valid Loss: 0.0019002944463863969 | Valid Time: 0.012\n",
            "Epoch: 809\n",
            "Train Loss: 0.0023221522263300264 | Train Time: 0.198\n",
            "Valid Loss: 0.0019778949790634215 | Valid Time: 0.017\n",
            "Epoch: 810\n",
            "Train Loss: 0.002346186236919541 | Train Time: 0.188\n",
            "Valid Loss: 0.002023094944888726 | Valid Time: 0.012\n",
            "Epoch: 811\n",
            "Train Loss: 0.0023322400489920064 | Train Time: 0.211\n",
            "Valid Loss: 0.0021556891733780503 | Valid Time: 0.012\n",
            "Epoch: 812\n",
            "Train Loss: 0.002284865305562945 | Train Time: 0.195\n",
            "Valid Loss: 0.0018818031821865588 | Valid Time: 0.016\n",
            "Epoch: 813\n",
            "Train Loss: 0.002381575759500265 | Train Time: 0.207\n",
            "Valid Loss: 0.0019193452317267656 | Valid Time: 0.013\n",
            "Epoch: 814\n",
            "Train Loss: 0.002354393400693018 | Train Time: 0.187\n",
            "Valid Loss: 0.002218718233052641 | Valid Time: 0.011\n",
            "Epoch: 815\n",
            "Train Loss: 0.00230808114927066 | Train Time: 0.202\n",
            "Valid Loss: 0.0017456237401347607 | Valid Time: 0.011\n",
            "Epoch: 816\n",
            "Train Loss: 0.002384105151960332 | Train Time: 0.203\n",
            "Valid Loss: 0.0020355007727630436 | Valid Time: 0.013\n",
            "Epoch: 817\n",
            "Train Loss: 0.0024536027033862317 | Train Time: 0.198\n",
            "Valid Loss: 0.002055868477327749 | Valid Time: 0.018\n",
            "Epoch: 818\n",
            "Train Loss: 0.002432207454388079 | Train Time: 0.203\n",
            "Valid Loss: 0.0022047486272640526 | Valid Time: 0.019\n",
            "Epoch: 819\n",
            "Train Loss: 0.0023850004838191366 | Train Time: 0.194\n",
            "Valid Loss: 0.0017805990937631577 | Valid Time: 0.017\n",
            "Epoch: 820\n",
            "Train Loss: 0.0024450072883873395 | Train Time: 0.195\n",
            "Valid Loss: 0.0022880657925270498 | Valid Time: 0.018\n",
            "Epoch: 821\n",
            "Train Loss: 0.0024793993522364056 | Train Time: 0.209\n",
            "Valid Loss: 0.00206554084434174 | Valid Time: 0.012\n",
            "Epoch: 822\n",
            "Train Loss: 0.002370211516359919 | Train Time: 0.198\n",
            "Valid Loss: 0.002077753219055012 | Valid Time: 0.017\n",
            "Epoch: 823\n",
            "Train Loss: 0.0023001664024042455 | Train Time: 0.200\n",
            "Valid Loss: 0.0019884252396877855 | Valid Time: 0.016\n",
            "Epoch: 824\n",
            "Train Loss: 0.002294553596967537 | Train Time: 0.189\n",
            "Valid Loss: 0.0018869709747377783 | Valid Time: 0.012\n",
            "Epoch: 825\n",
            "Train Loss: 0.0023881411302442614 | Train Time: 0.207\n",
            "Valid Loss: 0.0017967508174479008 | Valid Time: 0.020\n",
            "Epoch: 826\n",
            "Train Loss: 0.0024238129477261714 | Train Time: 0.192\n",
            "Valid Loss: 0.001809764769859612 | Valid Time: 0.018\n",
            "Epoch: 827\n",
            "Train Loss: 0.002434734500160343 | Train Time: 0.204\n",
            "Valid Loss: 0.001876193651696667 | Valid Time: 0.014\n",
            "Epoch: 828\n",
            "Train Loss: 0.002442433382384479 | Train Time: 0.189\n",
            "Valid Loss: 0.001980934845050797 | Valid Time: 0.021\n",
            "Epoch: 829\n",
            "Train Loss: 0.0023012757852771564 | Train Time: 0.189\n",
            "Valid Loss: 0.0018362108967266977 | Valid Time: 0.014\n",
            "Epoch: 830\n",
            "Train Loss: 0.0023511751052482347 | Train Time: 0.211\n",
            "Valid Loss: 0.001768447196809575 | Valid Time: 0.012\n",
            "Epoch: 831\n",
            "Train Loss: 0.0023922833405729186 | Train Time: 0.186\n",
            "Valid Loss: 0.002110579254804179 | Valid Time: 0.012\n",
            "Epoch: 832\n",
            "Train Loss: 0.0023395782336592674 | Train Time: 0.202\n",
            "Valid Loss: 0.0019426717481110245 | Valid Time: 0.012\n",
            "Epoch: 833\n",
            "Train Loss: 0.00236773383068411 | Train Time: 0.193\n",
            "Valid Loss: 0.0018890193605329841 | Valid Time: 0.016\n",
            "Epoch: 834\n",
            "Train Loss: 0.0023189302117220664 | Train Time: 0.189\n",
            "Valid Loss: 0.0020756502053700387 | Valid Time: 0.017\n",
            "Epoch: 835\n",
            "Train Loss: 0.0023746498321232045 | Train Time: 0.221\n",
            "Valid Loss: 0.0020765324006788433 | Valid Time: 0.012\n",
            "Epoch: 836\n",
            "Train Loss: 0.0023879702876959193 | Train Time: 0.199\n",
            "Valid Loss: 0.0023547319578938186 | Valid Time: 0.016\n",
            "Epoch: 837\n",
            "Train Loss: 0.0024509823905598175 | Train Time: 0.192\n",
            "Valid Loss: 0.0023495274945162237 | Valid Time: 0.015\n",
            "Epoch: 838\n",
            "Train Loss: 0.0025096077557751222 | Train Time: 0.204\n",
            "Valid Loss: 0.002229070698376745 | Valid Time: 0.016\n",
            "Epoch: 839\n",
            "Train Loss: 0.002302242669669029 | Train Time: 0.200\n",
            "Valid Loss: 0.0018939567089546472 | Valid Time: 0.016\n",
            "Epoch: 840\n",
            "Train Loss: 0.002456093084459242 | Train Time: 0.211\n",
            "Valid Loss: 0.001945450931088999 | Valid Time: 0.011\n",
            "Epoch: 841\n",
            "Train Loss: 0.002302401086413547 | Train Time: 0.191\n",
            "Valid Loss: 0.001989583863178268 | Valid Time: 0.016\n",
            "Epoch: 842\n",
            "Train Loss: 0.002425775814213251 | Train Time: 0.223\n",
            "Valid Loss: 0.001793198665836826 | Valid Time: 0.019\n",
            "Epoch: 843\n",
            "Train Loss: 0.0023703164862174738 | Train Time: 0.317\n",
            "Valid Loss: 0.002053768635960296 | Valid Time: 0.017\n",
            "Epoch: 844\n",
            "Train Loss: 0.0023374270868340603 | Train Time: 0.316\n",
            "Valid Loss: 0.0017887254944071174 | Valid Time: 0.018\n",
            "Epoch: 845\n",
            "Train Loss: 0.0023883514682223137 | Train Time: 0.304\n",
            "Valid Loss: 0.002377695665927604 | Valid Time: 0.018\n",
            "Epoch: 846\n",
            "Train Loss: 0.0025005345171513526 | Train Time: 0.309\n",
            "Valid Loss: 0.002112217538524419 | Valid Time: 0.018\n",
            "Epoch: 847\n",
            "Train Loss: 0.0024244588566944003 | Train Time: 0.315\n",
            "Valid Loss: 0.0018683126545511186 | Valid Time: 0.017\n",
            "Epoch: 848\n",
            "Train Loss: 0.002384152453343727 | Train Time: 0.301\n",
            "Valid Loss: 0.001806240965379402 | Valid Time: 0.021\n",
            "Epoch: 849\n",
            "Train Loss: 0.0023545008152723312 | Train Time: 0.314\n",
            "Valid Loss: 0.002052438212558627 | Valid Time: 0.017\n",
            "Epoch: 850\n",
            "Train Loss: 0.0025221328679962377 | Train Time: 0.298\n",
            "Valid Loss: 0.002327892172615975 | Valid Time: 0.011\n",
            "Epoch: 851\n",
            "Train Loss: 0.0023661504352563306 | Train Time: 0.197\n",
            "Valid Loss: 0.002069140668027103 | Valid Time: 0.016\n",
            "Epoch: 852\n",
            "Train Loss: 0.0024027873847731634 | Train Time: 0.202\n",
            "Valid Loss: 0.002292147255502641 | Valid Time: 0.016\n",
            "Epoch: 853\n",
            "Train Loss: 0.002485306761962803 | Train Time: 0.195\n",
            "Valid Loss: 0.0021619112812913954 | Valid Time: 0.018\n",
            "Epoch: 854\n",
            "Train Loss: 0.0024591257526098112 | Train Time: 0.196\n",
            "Valid Loss: 0.0019733731169253588 | Valid Time: 0.016\n",
            "Epoch: 855\n",
            "Train Loss: 0.0025379185834409376 | Train Time: 0.206\n",
            "Valid Loss: 0.002036220714217052 | Valid Time: 0.014\n",
            "Epoch: 856\n",
            "Train Loss: 0.00247164931466901 | Train Time: 0.194\n",
            "Valid Loss: 0.002022618369664997 | Valid Time: 0.016\n",
            "Epoch: 857\n",
            "Train Loss: 0.0023060140359264457 | Train Time: 0.194\n",
            "Valid Loss: 0.0025438970187678933 | Valid Time: 0.016\n",
            "Epoch: 858\n",
            "Train Loss: 0.002695227875129173 | Train Time: 0.196\n",
            "Valid Loss: 0.00273285829462111 | Valid Time: 0.016\n",
            "Epoch: 859\n",
            "Train Loss: 0.002651701325942811 | Train Time: 0.197\n",
            "Valid Loss: 0.0019980305805802345 | Valid Time: 0.016\n",
            "Epoch: 860\n",
            "Train Loss: 0.002316908757692497 | Train Time: 0.234\n",
            "Valid Loss: 0.0019453163840807974 | Valid Time: 0.011\n",
            "Epoch: 861\n",
            "Train Loss: 0.00233005965128541 | Train Time: 0.187\n",
            "Valid Loss: 0.0019354998657945544 | Valid Time: 0.011\n",
            "Epoch: 862\n",
            "Train Loss: 0.002326224691626665 | Train Time: 0.203\n",
            "Valid Loss: 0.001967053540283814 | Valid Time: 0.011\n",
            "Epoch: 863\n",
            "Train Loss: 0.002326879723879852 | Train Time: 0.192\n",
            "Valid Loss: 0.0017431052983738482 | Valid Time: 0.017\n",
            "Epoch: 864\n",
            "Train Loss: 0.0023732134018485482 | Train Time: 0.200\n",
            "Valid Loss: 0.0020694292325060815 | Valid Time: 0.022\n",
            "Epoch: 865\n",
            "Train Loss: 0.0023335241099917575 | Train Time: 0.194\n",
            "Valid Loss: 0.0021286247647367418 | Valid Time: 0.016\n",
            "Epoch: 866\n",
            "Train Loss: 0.0023778575889178014 | Train Time: 0.212\n",
            "Valid Loss: 0.0022125270625110716 | Valid Time: 0.019\n",
            "Epoch: 867\n",
            "Train Loss: 0.0023362164593938935 | Train Time: 0.193\n",
            "Valid Loss: 0.0019386721542105079 | Valid Time: 0.016\n",
            "Epoch: 868\n",
            "Train Loss: 0.002423103126746259 | Train Time: 0.191\n",
            "Valid Loss: 0.0023470112355425954 | Valid Time: 0.016\n",
            "Epoch: 869\n",
            "Train Loss: 0.002376365971653477 | Train Time: 0.208\n",
            "Valid Loss: 0.001893088105134666 | Valid Time: 0.015\n",
            "Epoch: 870\n",
            "Train Loss: 0.0023627536751231865 | Train Time: 0.193\n",
            "Valid Loss: 0.0019947467953898013 | Valid Time: 0.016\n",
            "Epoch: 871\n",
            "Train Loss: 0.0023293323373716128 | Train Time: 0.197\n",
            "Valid Loss: 0.0016818607109598815 | Valid Time: 0.017\n",
            "Epoch: 872\n",
            "Train Loss: 0.002286308077409079 | Train Time: 0.191\n",
            "Valid Loss: 0.0019689841428771615 | Valid Time: 0.016\n",
            "Epoch: 873\n",
            "Train Loss: 0.0023791109897980563 | Train Time: 0.192\n",
            "Valid Loss: 0.001955917599843815 | Valid Time: 0.017\n",
            "Epoch: 874\n",
            "Train Loss: 0.002384549668548923 | Train Time: 0.209\n",
            "Valid Loss: 0.0022405688650906086 | Valid Time: 0.012\n",
            "Epoch: 875\n",
            "Train Loss: 0.002497771362725057 | Train Time: 0.196\n",
            "Valid Loss: 0.0022392863465938717 | Valid Time: 0.018\n",
            "Epoch: 876\n",
            "Train Loss: 0.0023551236188627386 | Train Time: 0.191\n",
            "Valid Loss: 0.0018682956870179623 | Valid Time: 0.013\n",
            "Epoch: 877\n",
            "Train Loss: 0.002348921304617665 | Train Time: 0.201\n",
            "Valid Loss: 0.0019840381282847375 | Valid Time: 0.014\n",
            "Epoch: 878\n",
            "Train Loss: 0.0023505779252828737 | Train Time: 0.187\n",
            "Valid Loss: 0.0023219201248139143 | Valid Time: 0.012\n",
            "Epoch: 879\n",
            "Train Loss: 0.0023734483769849725 | Train Time: 0.216\n",
            "Valid Loss: 0.0018318404618185014 | Valid Time: 0.012\n",
            "Epoch: 880\n",
            "Train Loss: 0.00234410827856903 | Train Time: 0.205\n",
            "Valid Loss: 0.0021226368262432516 | Valid Time: 0.015\n",
            "Epoch: 881\n",
            "Train Loss: 0.002474241773597896 | Train Time: 0.190\n",
            "Valid Loss: 0.0020530048641376197 | Valid Time: 0.013\n",
            "Epoch: 882\n",
            "Train Loss: 0.0022766465676556293 | Train Time: 0.197\n",
            "Valid Loss: 0.0017488499579485506 | Valid Time: 0.016\n",
            "Epoch: 883\n",
            "Train Loss: 0.002336484263651073 | Train Time: 0.192\n",
            "Valid Loss: 0.002061240084003657 | Valid Time: 0.015\n",
            "Epoch: 884\n",
            "Train Loss: 0.0024882039288058877 | Train Time: 0.210\n",
            "Valid Loss: 0.002322925254702568 | Valid Time: 0.020\n",
            "Epoch: 885\n",
            "Train Loss: 0.0025682969839851324 | Train Time: 0.191\n",
            "Valid Loss: 0.0019210503960493952 | Valid Time: 0.013\n",
            "Epoch: 886\n",
            "Train Loss: 0.002454907069668958 | Train Time: 0.205\n",
            "Valid Loss: 0.0023705960484221578 | Valid Time: 0.013\n",
            "Epoch: 887\n",
            "Train Loss: 0.002411473750774013 | Train Time: 0.195\n",
            "Valid Loss: 0.0017988360777962953 | Valid Time: 0.017\n",
            "Epoch: 888\n",
            "Train Loss: 0.0023083210261048456 | Train Time: 0.206\n",
            "Valid Loss: 0.0020859669893980026 | Valid Time: 0.013\n",
            "Epoch: 889\n",
            "Train Loss: 0.002281514278269912 | Train Time: 0.197\n",
            "Valid Loss: 0.0020098811655770987 | Valid Time: 0.016\n",
            "Epoch: 890\n",
            "Train Loss: 0.002370741555320197 | Train Time: 0.197\n",
            "Valid Loss: 0.0018388289608992636 | Valid Time: 0.018\n",
            "Epoch: 891\n",
            "Train Loss: 0.002456629722330131 | Train Time: 0.208\n",
            "Valid Loss: 0.0019197280053049326 | Valid Time: 0.013\n",
            "Epoch: 892\n",
            "Train Loss: 0.0025264663180630457 | Train Time: 0.197\n",
            "Valid Loss: 0.0019455676374491304 | Valid Time: 0.017\n",
            "Epoch: 893\n",
            "Train Loss: 0.0023963712094547717 | Train Time: 0.207\n",
            "Valid Loss: 0.0017410634027328342 | Valid Time: 0.012\n",
            "Epoch: 894\n",
            "Train Loss: 0.0023203124721093396 | Train Time: 0.202\n",
            "Valid Loss: 0.0020413273596204817 | Valid Time: 0.016\n",
            "Epoch: 895\n",
            "Train Loss: 0.002313393786990721 | Train Time: 0.194\n",
            "Valid Loss: 0.0018801474652718753 | Valid Time: 0.015\n",
            "Epoch: 896\n",
            "Train Loss: 0.0023194801393210105 | Train Time: 0.208\n",
            "Valid Loss: 0.002053735079243779 | Valid Time: 0.014\n",
            "Epoch: 897\n",
            "Train Loss: 0.0023330189532747396 | Train Time: 0.343\n",
            "Valid Loss: 0.0017535817751195282 | Valid Time: 0.017\n",
            "Epoch: 898\n",
            "Train Loss: 0.0023679683891762245 | Train Time: 0.310\n",
            "Valid Loss: 0.0018583608325570822 | Valid Time: 0.020\n",
            "Epoch: 899\n",
            "Train Loss: 0.0023951795332035736 | Train Time: 0.309\n",
            "Valid Loss: 0.00205625023227185 | Valid Time: 0.019\n",
            "Epoch: 900\n",
            "Train Loss: 0.0024517095206599486 | Train Time: 0.315\n",
            "Valid Loss: 0.001957547530764714 | Valid Time: 0.026\n",
            "Epoch: 901\n",
            "Train Loss: 0.002340853269408016 | Train Time: 0.307\n",
            "Valid Loss: 0.001933611201820895 | Valid Time: 0.018\n",
            "Epoch: 902\n",
            "Train Loss: 0.002367369076972337 | Train Time: 0.302\n",
            "Valid Loss: 0.002143468474969268 | Valid Time: 0.017\n",
            "Epoch: 903\n",
            "Train Loss: 0.0023365445912962683 | Train Time: 0.313\n",
            "Valid Loss: 0.0019923228537663817 | Valid Time: 0.021\n",
            "Epoch: 904\n",
            "Train Loss: 0.0023623109108915456 | Train Time: 0.328\n",
            "Valid Loss: 0.001706885581370443 | Valid Time: 0.021\n",
            "Epoch: 905\n",
            "Train Loss: 0.00228782890879206 | Train Time: 0.194\n",
            "Valid Loss: 0.0020554910297505558 | Valid Time: 0.022\n",
            "Epoch: 906\n",
            "Train Loss: 0.0023921376498612134 | Train Time: 0.191\n",
            "Valid Loss: 0.0019052801362704486 | Valid Time: 0.015\n",
            "Epoch: 907\n",
            "Train Loss: 0.0022969860706086222 | Train Time: 0.203\n",
            "Valid Loss: 0.001709180767647922 | Valid Time: 0.018\n",
            "Epoch: 908\n",
            "Train Loss: 0.002287396039862774 | Train Time: 0.213\n",
            "Valid Loss: 0.0021396531665232033 | Valid Time: 0.011\n",
            "Epoch: 909\n",
            "Train Loss: 0.0023216542567273506 | Train Time: 0.197\n",
            "Valid Loss: 0.0021608891838695854 | Valid Time: 0.018\n",
            "Epoch: 910\n",
            "Train Loss: 0.002431208892774425 | Train Time: 0.197\n",
            "Valid Loss: 0.0022309364867396653 | Valid Time: 0.018\n",
            "Epoch: 911\n",
            "Train Loss: 0.002356701904270602 | Train Time: 0.194\n",
            "Valid Loss: 0.0017745482036843896 | Valid Time: 0.018\n",
            "Epoch: 912\n",
            "Train Loss: 0.002365384747176186 | Train Time: 0.193\n",
            "Valid Loss: 0.002130664448486641 | Valid Time: 0.017\n",
            "Epoch: 913\n",
            "Train Loss: 0.0024157612167886996 | Train Time: 0.207\n",
            "Valid Loss: 0.0018762776453513652 | Valid Time: 0.016\n",
            "Epoch: 914\n",
            "Train Loss: 0.0024891794340586976 | Train Time: 0.194\n",
            "Valid Loss: 0.002779389382340014 | Valid Time: 0.018\n",
            "Epoch: 915\n",
            "Train Loss: 0.00255559199783755 | Train Time: 0.196\n",
            "Valid Loss: 0.0025793358217924833 | Valid Time: 0.016\n",
            "Epoch: 916\n",
            "Train Loss: 0.0025584925652334563 | Train Time: 0.189\n",
            "Valid Loss: 0.0021304297843016684 | Valid Time: 0.015\n",
            "Epoch: 917\n",
            "Train Loss: 0.0023855514714102213 | Train Time: 0.201\n",
            "Valid Loss: 0.0020689777738880366 | Valid Time: 0.020\n",
            "Epoch: 918\n",
            "Train Loss: 0.002356366309533386 | Train Time: 0.191\n",
            "Valid Loss: 0.0018967863288708031 | Valid Time: 0.015\n",
            "Epoch: 919\n",
            "Train Loss: 0.002358983920298909 | Train Time: 0.196\n",
            "Valid Loss: 0.0020147861796431243 | Valid Time: 0.017\n",
            "Epoch: 920\n",
            "Train Loss: 0.0023730210347199126 | Train Time: 0.193\n",
            "Valid Loss: 0.0019721733988262713 | Valid Time: 0.014\n",
            "Epoch: 921\n",
            "Train Loss: 0.0024440965713246874 | Train Time: 0.189\n",
            "Valid Loss: 0.0021011238277424127 | Valid Time: 0.013\n",
            "Epoch: 922\n",
            "Train Loss: 0.0024020993518397995 | Train Time: 0.211\n",
            "Valid Loss: 0.0018958074215333909 | Valid Time: 0.012\n",
            "Epoch: 923\n",
            "Train Loss: 0.00249497597350886 | Train Time: 0.206\n",
            "Valid Loss: 0.0019358965510036796 | Valid Time: 0.013\n",
            "Epoch: 924\n",
            "Train Loss: 0.0023132449224297154 | Train Time: 0.192\n",
            "Valid Loss: 0.0019655590294860303 | Valid Time: 0.016\n",
            "Epoch: 925\n",
            "Train Loss: 0.0023476430950196167 | Train Time: 0.197\n",
            "Valid Loss: 0.002434908354189247 | Valid Time: 0.015\n",
            "Epoch: 926\n",
            "Train Loss: 0.002485150293643145 | Train Time: 0.196\n",
            "Valid Loss: 0.0021998455049470067 | Valid Time: 0.016\n",
            "Epoch: 927\n",
            "Train Loss: 0.0023154461707331634 | Train Time: 0.215\n",
            "Valid Loss: 0.0019048733229283243 | Valid Time: 0.011\n",
            "Epoch: 928\n",
            "Train Loss: 0.002324546001067287 | Train Time: 0.190\n",
            "Valid Loss: 0.0017692643159534782 | Valid Time: 0.016\n",
            "Epoch: 929\n",
            "Train Loss: 0.002331781611581774 | Train Time: 0.189\n",
            "Valid Loss: 0.001996555074583739 | Valid Time: 0.011\n",
            "Epoch: 930\n",
            "Train Loss: 0.0024781747243220083 | Train Time: 0.207\n",
            "Valid Loss: 0.0019721402204595506 | Valid Time: 0.011\n",
            "Epoch: 931\n",
            "Train Loss: 0.0024226053654657384 | Train Time: 0.202\n",
            "Valid Loss: 0.0017796083993744105 | Valid Time: 0.016\n",
            "Epoch: 932\n",
            "Train Loss: 0.002328631229159471 | Train Time: 0.205\n",
            "Valid Loss: 0.0018816729134414345 | Valid Time: 0.016\n",
            "Epoch: 933\n",
            "Train Loss: 0.0023186812851283896 | Train Time: 0.197\n",
            "Valid Loss: 0.0018132147670257837 | Valid Time: 0.016\n",
            "Epoch: 934\n",
            "Train Loss: 0.002335198529946961 | Train Time: 0.191\n",
            "Valid Loss: 0.0019394269620534033 | Valid Time: 0.015\n",
            "Epoch: 935\n",
            "Train Loss: 0.00241164009601466 | Train Time: 0.195\n",
            "Valid Loss: 0.0022128226119093597 | Valid Time: 0.019\n",
            "Epoch: 936\n",
            "Train Loss: 0.002327771679694323 | Train Time: 0.194\n",
            "Valid Loss: 0.0017731224361341447 | Valid Time: 0.016\n",
            "Epoch: 937\n",
            "Train Loss: 0.002322996862379736 | Train Time: 0.206\n",
            "Valid Loss: 0.0018199603073298931 | Valid Time: 0.013\n",
            "Epoch: 938\n",
            "Train Loss: 0.0024584423456537096 | Train Time: 0.194\n",
            "Valid Loss: 0.0021262789668980986 | Valid Time: 0.017\n",
            "Epoch: 939\n",
            "Train Loss: 0.0023809703446826653 | Train Time: 0.203\n",
            "Valid Loss: 0.0025243762065656483 | Valid Time: 0.014\n",
            "Epoch: 940\n",
            "Train Loss: 0.0026158416692755723 | Train Time: 0.197\n",
            "Valid Loss: 0.0021328303846530616 | Valid Time: 0.017\n",
            "Epoch: 941\n",
            "Train Loss: 0.0023399328592380413 | Train Time: 0.204\n",
            "Valid Loss: 0.0019997686031274498 | Valid Time: 0.015\n",
            "Epoch: 942\n",
            "Train Loss: 0.0023079468611333716 | Train Time: 0.192\n",
            "Valid Loss: 0.0020244507177267224 | Valid Time: 0.020\n",
            "Epoch: 943\n",
            "Train Loss: 0.002436431222840359 | Train Time: 0.195\n",
            "Valid Loss: 0.002039904211414978 | Valid Time: 0.018\n",
            "Epoch: 944\n",
            "Train Loss: 0.0024025437029960906 | Train Time: 0.191\n",
            "Valid Loss: 0.0016827838844619691 | Valid Time: 0.019\n",
            "Epoch: 945\n",
            "Train Loss: 0.0023782025642791076 | Train Time: 0.194\n",
            "Valid Loss: 0.0022032257402315736 | Valid Time: 0.019\n",
            "Epoch: 946\n",
            "Train Loss: 0.002427077790918319 | Train Time: 0.211\n",
            "Valid Loss: 0.0022930697887204587 | Valid Time: 0.011\n",
            "Epoch: 947\n",
            "Train Loss: 0.0025480643196619654 | Train Time: 0.192\n",
            "Valid Loss: 0.003416682651732117 | Valid Time: 0.017\n",
            "Epoch: 948\n",
            "Train Loss: 0.00284499227755556 | Train Time: 0.194\n",
            "Valid Loss: 0.0018967142386827618 | Valid Time: 0.017\n",
            "Epoch: 949\n",
            "Train Loss: 0.0024774169034667707 | Train Time: 0.195\n",
            "Valid Loss: 0.001790498150512576 | Valid Time: 0.018\n",
            "Epoch: 950\n",
            "Train Loss: 0.0023804111099850977 | Train Time: 0.191\n",
            "Valid Loss: 0.0017223527247551829 | Valid Time: 0.014\n",
            "Epoch: 951\n",
            "Train Loss: 0.0022815375245715443 | Train Time: 0.255\n",
            "Valid Loss: 0.0017190648795804009 | Valid Time: 0.018\n",
            "Epoch: 952\n",
            "Train Loss: 0.0022729988773598484 | Train Time: 0.315\n",
            "Valid Loss: 0.0022013552370481193 | Valid Time: 0.017\n",
            "Epoch: 953\n",
            "Train Loss: 0.0024268381346605325 | Train Time: 0.307\n",
            "Valid Loss: 0.0018161848420277238 | Valid Time: 0.017\n",
            "Epoch: 954\n",
            "Train Loss: 0.0024018168547435812 | Train Time: 0.316\n",
            "Valid Loss: 0.0019243237329646945 | Valid Time: 0.017\n",
            "Epoch: 955\n",
            "Train Loss: 0.0023525129317453035 | Train Time: 0.309\n",
            "Valid Loss: 0.0016482349747093394 | Valid Time: 0.018\n",
            "Epoch: 956\n",
            "Train Loss: 0.00225240569316635 | Train Time: 0.309\n",
            "Valid Loss: 0.0018654249724932015 | Valid Time: 0.019\n",
            "Epoch: 957\n",
            "Train Loss: 0.0023165160152865084 | Train Time: 0.323\n",
            "Valid Loss: 0.0021473605593200773 | Valid Time: 0.023\n",
            "Epoch: 958\n",
            "Train Loss: 0.0024103996601249826 | Train Time: 0.319\n",
            "Valid Loss: 0.002032985124969855 | Valid Time: 0.018\n",
            "Epoch: 959\n",
            "Train Loss: 0.0024146795223810172 | Train Time: 0.285\n",
            "Valid Loss: 0.002044185035629198 | Valid Time: 0.011\n",
            "Epoch: 960\n",
            "Train Loss: 0.002349309574224447 | Train Time: 0.194\n",
            "Valid Loss: 0.0017724536592140794 | Valid Time: 0.019\n",
            "Epoch: 961\n",
            "Train Loss: 0.0024018440959288887 | Train Time: 0.218\n",
            "Valid Loss: 0.0019596222264226526 | Valid Time: 0.011\n",
            "Epoch: 962\n",
            "Train Loss: 0.0023065178508037015 | Train Time: 0.198\n",
            "Valid Loss: 0.0018191178678534925 | Valid Time: 0.019\n",
            "Epoch: 963\n",
            "Train Loss: 0.0023268200885994653 | Train Time: 0.190\n",
            "Valid Loss: 0.0018098975415341556 | Valid Time: 0.017\n",
            "Epoch: 964\n",
            "Train Loss: 0.00234333074676167 | Train Time: 0.206\n",
            "Valid Loss: 0.002094472903991118 | Valid Time: 0.015\n",
            "Epoch: 965\n",
            "Train Loss: 0.002366528509331769 | Train Time: 0.188\n",
            "Valid Loss: 0.001950546313310042 | Valid Time: 0.011\n",
            "Epoch: 966\n",
            "Train Loss: 0.0024540587328374386 | Train Time: 0.216\n",
            "Valid Loss: 0.0021508224890567362 | Valid Time: 0.011\n",
            "Epoch: 967\n",
            "Train Loss: 0.002324586875099493 | Train Time: 0.194\n",
            "Valid Loss: 0.0018616111774463207 | Valid Time: 0.018\n",
            "Epoch: 968\n",
            "Train Loss: 0.002294949666400881 | Train Time: 0.189\n",
            "Valid Loss: 0.0018099050503224134 | Valid Time: 0.014\n",
            "Epoch: 969\n",
            "Train Loss: 0.002319776594001604 | Train Time: 0.204\n",
            "Valid Loss: 0.0022625571582466364 | Valid Time: 0.014\n",
            "Epoch: 970\n",
            "Train Loss: 0.0023323846123132264 | Train Time: 0.196\n",
            "Valid Loss: 0.0019518431217875332 | Valid Time: 0.020\n",
            "Epoch: 971\n",
            "Train Loss: 0.0023792802392946263 | Train Time: 0.199\n",
            "Valid Loss: 0.002114537142915651 | Valid Time: 0.019\n",
            "Epoch: 972\n",
            "Train Loss: 0.002350580339369021 | Train Time: 0.198\n",
            "Valid Loss: 0.002206710691098124 | Valid Time: 0.017\n",
            "Epoch: 973\n",
            "Train Loss: 0.002312379705376531 | Train Time: 0.211\n",
            "Valid Loss: 0.0023309607931878418 | Valid Time: 0.012\n",
            "Epoch: 974\n",
            "Train Loss: 0.0022993864013666383 | Train Time: 0.191\n",
            "Valid Loss: 0.0019241729751229286 | Valid Time: 0.014\n",
            "Epoch: 975\n",
            "Train Loss: 0.0023431135586609968 | Train Time: 0.213\n",
            "Valid Loss: 0.0019544898241292685 | Valid Time: 0.012\n",
            "Epoch: 976\n",
            "Train Loss: 0.002389878475744473 | Train Time: 0.208\n",
            "Valid Loss: 0.0018956437706947327 | Valid Time: 0.013\n",
            "Epoch: 977\n",
            "Train Loss: 0.002467732508911898 | Train Time: 0.190\n",
            "Valid Loss: 0.001835828588809818 | Valid Time: 0.017\n",
            "Epoch: 978\n",
            "Train Loss: 0.002373327439846961 | Train Time: 0.194\n",
            "Valid Loss: 0.001845532562583685 | Valid Time: 0.015\n",
            "Epoch: 979\n",
            "Train Loss: 0.0023873975549481416 | Train Time: 0.198\n",
            "Valid Loss: 0.0019997013150714338 | Valid Time: 0.016\n",
            "Epoch: 980\n",
            "Train Loss: 0.002397586524143423 | Train Time: 0.203\n",
            "Valid Loss: 0.0018181900086347014 | Valid Time: 0.017\n",
            "Epoch: 981\n",
            "Train Loss: 0.0024348878130120667 | Train Time: 0.199\n",
            "Valid Loss: 0.0026122428535018116 | Valid Time: 0.017\n",
            "Epoch: 982\n",
            "Train Loss: 0.002432834896209993 | Train Time: 0.197\n",
            "Valid Loss: 0.002008667535847053 | Valid Time: 0.016\n",
            "Epoch: 983\n",
            "Train Loss: 0.0024313300198532247 | Train Time: 0.191\n",
            "Valid Loss: 0.0020296980219427496 | Valid Time: 0.014\n",
            "Epoch: 984\n",
            "Train Loss: 0.002399002759423303 | Train Time: 0.197\n",
            "Valid Loss: 0.0017065354331862181 | Valid Time: 0.016\n",
            "Epoch: 985\n",
            "Train Loss: 0.0024348748480214886 | Train Time: 0.199\n",
            "Valid Loss: 0.0020133995276410133 | Valid Time: 0.017\n",
            "Epoch: 986\n",
            "Train Loss: 0.002340953668432408 | Train Time: 0.187\n",
            "Valid Loss: 0.001870850333943963 | Valid Time: 0.011\n",
            "Epoch: 987\n",
            "Train Loss: 0.0023248617132929595 | Train Time: 0.199\n",
            "Valid Loss: 0.0019793719111476094 | Valid Time: 0.011\n",
            "Epoch: 988\n",
            "Train Loss: 0.002367157433917256 | Train Time: 0.192\n",
            "Valid Loss: 0.0017552238423377275 | Valid Time: 0.017\n",
            "Epoch: 989\n",
            "Train Loss: 0.0023200849291721455 | Train Time: 0.193\n",
            "Valid Loss: 0.001872073655249551 | Valid Time: 0.021\n",
            "Epoch: 990\n",
            "Train Loss: 0.0023266831780538746 | Train Time: 0.191\n",
            "Valid Loss: 0.0017700125463306904 | Valid Time: 0.014\n",
            "Epoch: 991\n",
            "Train Loss: 0.00236676642548685 | Train Time: 0.219\n",
            "Valid Loss: 0.0019289447227492929 | Valid Time: 0.013\n",
            "Epoch: 992\n",
            "Train Loss: 0.002473496936114603 | Train Time: 0.197\n",
            "Valid Loss: 0.001972503261640668 | Valid Time: 0.020\n",
            "Epoch: 993\n",
            "Train Loss: 0.0024089900115014692 | Train Time: 0.194\n",
            "Valid Loss: 0.0020030431915074587 | Valid Time: 0.017\n",
            "Epoch: 994\n",
            "Train Loss: 0.002275357065771363 | Train Time: 0.204\n",
            "Valid Loss: 0.0017280138854403049 | Valid Time: 0.016\n",
            "Epoch: 995\n",
            "Train Loss: 0.0022690044348373226 | Train Time: 0.201\n",
            "Valid Loss: 0.001789553527487442 | Valid Time: 0.016\n",
            "Epoch: 996\n",
            "Train Loss: 0.002297904832582725 | Train Time: 0.193\n",
            "Valid Loss: 0.0017688532825559378 | Valid Time: 0.015\n",
            "Epoch: 997\n",
            "Train Loss: 0.002359074540436268 | Train Time: 0.192\n",
            "Valid Loss: 0.0019533566082827747 | Valid Time: 0.018\n",
            "Epoch: 998\n",
            "Train Loss: 0.0022578558418899775 | Train Time: 0.211\n",
            "Valid Loss: 0.001834340946516022 | Valid Time: 0.011\n",
            "Epoch: 999\n",
            "Train Loss: 0.002306076256852401 | Train Time: 0.214\n",
            "Valid Loss: 0.0020291347755119205 | Valid Time: 0.014\n",
            "== Test Loss: 0.002326235524378717 | Test Time: 0.013 ==\n"
          ]
        }
      ],
      "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",
        "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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 43,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "id": "gwalIcedHbc2",
        "outputId": "cced8ed7-ed93-4b1f-ba07-80961c2f4521"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, 'log(MSE)')"
            ]
          },
          "metadata": {},
          "execution_count": 43
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "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.ylabel('log(MSE)')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 35,
      "metadata": {
        "id": "yKTWlXQNHw0I"
      },
      "outputs": [],
      "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)).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()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 46,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 467
        },
        "id": "fH5LByPFHxQF",
        "outputId": "dae22abc-991e-414f-ce41-c666da23ff06"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$u(x,t_1)$')"
            ]
          },
          "metadata": {},
          "execution_count": 46
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#Plot our solutions to compare\n",
        "test_time = 1\n",
        "sol_interp_NN = np.interp(xmesh.cpu(), x_mesh_avg.cpu(), sol_model_pred_NN[test_time-1])\n",
        "\n",
        "plt.plot(xmesh.cpu(), sol_interp)\n",
        "plt.plot(xmesh.cpu(), sol_interp_NN)\n",
        "plt.plot(xmesh.cpu(), sol_model_act_avg[test_time-1].cpu())\n",
        "plt.legend(['Predicted Ours', 'Predicted NN', 'Ground Truth'])\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel(f'$u(x,t_{test_time})$')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 37,
      "metadata": {
        "id": "tK-bxObSYnY4"
      },
      "outputs": [],
      "source": [
        "#Get the test loss on in-distribution and out-of-distribution data\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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 38,
      "metadata": {
        "id": "iAXRDc5MZD-d"
      },
      "outputs": [],
      "source": [
        "#Get pur 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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 47,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "id": "wQZX5XarBJmv",
        "outputId": "bc88e31c-8062-4527-a689-b181e928bc3f"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$u(x,t_9)$')"
            ]
          },
          "metadata": {},
          "execution_count": 47
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#Sample our solution to t_k time steps\n",
        "visual = 9\n",
        "OOD_avg = torch.zeros((t_k, 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()\n",
        "\n",
        "#Plot our solutions to compare\n",
        "test_time = 9\n",
        "OOD_interp_RCNN = np.interp(xmesh.cpu(), x_mesh_avg.cpu(), OOD_pred_RCNN[test_time-1])\n",
        "OOD_interp_NN = np.interp(xmesh.cpu(), x_mesh_avg.cpu(), OOD_pred_NN[test_time-1])\n",
        "\n",
        "plt.plot(xmesh.cpu(), OOD_interp_RCNN)\n",
        "plt.plot(xmesh.cpu(), OOD_interp_NN)\n",
        "plt.plot(xmesh.cpu(), OOD_avg[test_time-1].cpu())\n",
        "plt.legend(['Predicted Ours', 'Predicted NN','Ground Truth'], loc = 1)\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel(f'$u(x,t_{test_time})$')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 48,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "id": "_cWzAUEBeFYq",
        "outputId": "e3d8662d-8db1-461c-b7bc-6564e7abd74b"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$\\\\mathrm{E}[c_i^2]$')"
            ]
          },
          "metadata": {},
          "execution_count": 48
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#Visualize the spectrum of the coefficients\n",
        "index = np.arange(k)+1\n",
        "coefficients_mean = np.mean(coefficients**2, 0)\n",
        "coefficients_mean_OOD = np.mean((coefficients_OOD**2).cpu().numpy(), 0)\n",
        "\n",
        "plt.bar(index, coefficients_mean, 0.3)\n",
        "plt.bar(index+ 0.3, coefficients_mean_OOD, 0.3)\n",
        "plt.legend(['In-distribution', 'Out-of-distribution'], loc = 1)\n",
        "plt.xlabel('$i$')\n",
        "plt.ylabel(r'$\\mathrm{E}[c_i^2]$')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "JhQSO-ntCDdw"
      },
      "outputs": [],
      "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([256,128,64,32])\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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "GsDEpcJgCSWB"
      },
      "outputs": [],
      "source": [
        "#Graph subgrids (adjust run and model as needed)\n",
        "run = 1\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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 446
        },
        "id": "fr19echvCtoF",
        "outputId": "f0a2039e-8cc6-4a13-eae5-cb84605893e6"
      },
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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y+6dkWUZQ0NDiEQiFbcvFAohEAhU/DqiZtXVBXi9jW4FbUfp1TRWrq2gb29f3r755Xns2bUH5u7WXWaISFPV8NbIyAhkWcY3vvENSJKEqakppFIpuN1uTE1NlX9ykwnZpy80JGWxWLC0tARATZZkWc47jsfjgSiK+vNgMAiXywW73V52W7Tusbfeeqtg91hnZye6u7v15++++27RY3V0dOCWW26pKva9995DsR+JyWTCrbfeWlXs1atXsb6+XrQdu3fvrip2dXUVmUymJrG33norTCYTAGBtbQ3Xr1+vSewtt9yCjg61Zv/atWt4//33axLb3d2NzhuzAFYS+/777+PatWtFY7u6urBjx46KY69fv461tbWisbt27cLOG0VBlcRmMhmsrq4Wjd25cyd27dpVcez6+jquXr1ak9gdO3agq6sLAKAoCt57772axFbye9+q14j0ahrHnz6Of1z6R5z77Dn0mW8mPvPpeRx/+jh+b/fvIfalmJ74NNs1IpPJIJPJ5Pxbb7nlFj322rVrJa8R3d3dOb/3tYrt6urKuUaUG/v++++XvJ7s2rUr5xpRbuz169dLXk927tyZc40oNzaTyZS8nuzYsSPnGlFu7Pr6OtbW1tDZ2an/32xsw65du4wf3opGo3rtjvYmEwShYJ1PJeLxOHp6enK29fT0YHZ2Fna7HR6Pp6xjaAlPNBot+pq1tbWc//jl5WUAwO23314w/pOf/CT+9//+3/rz3t7eohfLI0eOYHJyUn++f/9+/O53vysY63Q6cxLFgwcP4je/+U3B2IMHD+L//t//qz/v7+/HpUuXCsbedddduHz5sv78T/7kT4oOS37wgx/EP/3TP+nP//RP/xQXLlwoGHvrrbfmXKAffPBB/J//838KxgLIuQidPHlSLzQv5J133tEvgD6fD0899VTR2IWFBfze7/0eAODf//t/j//23/5b0di5uTm9wP6v/uqvSk658Mtf/hIf/ehHAQCPPfYYvvnNbxaN/elPf4r+/n4AwJkzZzA8PFw09sUXX8TRG4U24XAY/+7f/buisT/5yU/wb/7NvwEAPP300/jiF79YNHZ8fBzeG90/zz//PAYGBorGfv/738cXvvAFAMDf/M3f4N/+239bNPY73/kOTp06BQC4ePEi7i9RTBQMBvHoo48CUIet77nnnqKxp0+fxl//9V8DAF57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\n"
          },
          "metadata": {}
        }
      ],
      "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()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "_EAq8TCyZbuP",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "8a80080d-7766-4d27-d1b6-643acf3503eb"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tensor(4.5911e-15, grad_fn=<DivBackward0>)\n",
            "tensor(0.0059, grad_fn=<DivBackward0>)\n"
          ]
        }
      ],
      "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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ydC79WVKcHC4",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "ad6bc797-7149-4afe-9ef1-887854b36a1f"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tensor(0., grad_fn=<DivBackward0>)\n",
            "tensor(0.0024, grad_fn=<DivBackward0>)\n"
          ]
        }
      ],
      "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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "srayceiFQ-9x",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "f85ddd3f-3f96-4ed2-ea9e-fbb5c06ac7c0"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tensor(0.1040, grad_fn=<MseLossBackward0>)"
            ]
          },
          "metadata": {},
          "execution_count": 301
        }
      ],
      "source": [
        "#Check linearity property breaks for Neural Net model\n",
        "u = modelNN(2*inputs_OOD[visual].unsqueeze(0))\n",
        "v = modelNN(inputs_OOD[visual].unsqueeze(0))\n",
        "out = u - 2*v\n",
        "\n",
        "F.mse_loss(out[0][9], torch.zeros(len(out[0][9])).to(device))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "iZQZG0ubeSvc",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "outputId": "baf768cc-ca80-4f06-e68f-7395adb331d0"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$u(x, t_9)$')"
            ]
          },
          "metadata": {},
          "execution_count": 302
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "plt.plot(x_mesh_avg.cpu(), u[0][9].detach().cpu().numpy())\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel(r'$u(x, t_9)$')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "NPaq6ADuefVQ",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "outputId": "e56391f7-369f-4be0-fc79-a0f1b42e85d6"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$u(x, t_9)$')"
            ]
          },
          "metadata": {},
          "execution_count": 303
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAj0AAAGtCAYAAAD9H8XfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABZl0lEQVR4nO3deXST950v/vcjyZZ3yfIG2AZbZgkhJGBskqbZMUnTNpMWDOk+aSaY5sx0ppOZ4DL3/ma5595xobmd2zPTaViaNt1SbIfuK2o2smIQZCFhs2wWg1chS94kS3p+f0iPbIMNXiQ92/t1DqexLexvVMf6+PvZBFEURRARERFpnEHuAxARERElA4MeIiIi0gUGPURERKQLDHqIiIhIFxj0EBERkS4w6CEiIiJdYNBDREREusCgh4iIiHTBJPcBlCQcDuPixYvIzs6GIAhyH4eIiIimQRRF+Hw+LFiwAAbD1Pc5DHrGuXjxIkpLS+U+BhEREc3C+fPnUVJSMuXHGfSMk52dDSDypOXk5Mh8GiIiIpoOr9eL0tLS2Ov4VFQR9LhcLjQ3N8Nut8PlcqGurg5Wq3XSxzqdTjgcDgBAS0sL9uzZM+VjrySltHJychj0EBERqcz1SlNUEfRs2rQJR44cARAJgLZs2YKmpqZJH+twOLBt2zYAwM6dO7Fu3brY3yUiIiL9Unz3lsvlmvC23W6P3eRcyel0oqGhIfZ2bW0tnE7nVZ+DiIiI9EfxQY/D4YDNZpvwPpvNBqfTedVjKysrsWfPntjbHo8n9vjJ+P1+eL3eCX+IiIhImxQf9EiBy5Xcbvek76+trY398759+1BTUzNlTU9DQwMsFkvsDzu3iIiItEvxQc9UpgqGxn+8ubl5ytofANi+fTv6+/tjf86fPx/nUxIREZFSKL6Q2Wq1XnWr43a7r9uRVV9fjwMHDlzzcWazGWazOQ6nJCIiIqVT/E1PTU3NpO+vqqqa8u/s3LkT9fX1sNvt8Hg8170VIiIiIu1TfNBjt9snvO1yuVBVVRW7wbmyO6u5uRmVlZWxgKexsXHac3qIiIhIuwRRFEW5D3E9LpcLu3btQnV1NVpaWrB9+/ZYILNp0yZUV1dj27ZtcLlcqKiomPB3rVYrLl++PK2v4/V6YbFY0N/fz+GEREREKjHd129VBD3JwqCHiIhIfab7+q349BYRERFRPDDoISIiIl1g0ENERKoWDIXR8PsPsedVF0ZGQ3IfhxRM8XN6iIiIruXPJ7qx65VIF+8P32rH//j4jXhgRdF1N26T/vCmh4iIVK2lbWyA7Xn3ML7y4yP4/N63caKT+xRpIgY9RESkai1nI2NJ/v3TK/G39y2G2WTAG619+Pi3D+J//uI9uAcDMp+QlIJBDxERqdZQIIjjHf0AgLuW5uPJ+5fB8eTd+MTK+QiLwI/fOod7vvkSvv96G0ZDYZlPS3Jj0ENERKp17JwHwbCIBZY0lORmAABKbRn4zucr8bO627B8fg68I0H8268/wIPfPohXT/XIfGKSE4MeIiJSrZb2SGqrqsx21cdus+fhN1+9A//+6ZWwZabiTPcAvvTsITz+XAvaegeTfVRSAAY9RESkWofPRoqYq8tyJ/240SDgc7cuxEv/eA8e+2g5TAYBjg+7cf9/vIKG338I38hoMo9LMmPQQ0REqhQMheE8O/VNz3iW9BT880M34g9fuxN3LS3AaEjErldcuPfpV3Dgg65kHJcUgEEPERGp0oeXfBgMhJCdZsKyouxp/Z3Fhdl47svVePbRKpTnZ6J3wI+/+9lRBIIsctYDBj1ERKRKLe2R1FbVolwYDNMfRCgIAu67oQh//NpdyEg1YigQwjn3UKKOSQrCoIeIiFRJque5XmprKqkmA+wFmQCA1p6BuJ2LlItBDxERqY4oijjUFqnnWVs+u6AHACoKsgAw6NELBj1ERKQ6Z/uG0DvgR6rRgJXFlll/nljQ080Wdj1g0ENERKoj1fPcXGJBWopx1p+HNz36wqCHiIhU5/A1hhLOREXhWE2PKIpzPhcpG4MeIiJSHemmZ2355EMJp6ssLxOCAPhGgugZ8MfjaKRgDHqIiEhVegf8cEXXSKxZOLebnrQUI0qjO7tY16N9DHqIiEhVpNTWsqJsWDJS5vz5Kti2rhsMeoiISFWk1Fb1HFNbEhYz6weDHiIiUpXDUtAzxyJmSUWhFPQwvaV1DHqIiEg1hgJBvH/RC2DunVuSsVk9vOnROgY9RESkGsfOeRAKi1hgSUOxNT0un1Oq6enwDGM4EIrL5yRlYtBDRESqcShWzxOfWx4AsGWmwhotiHb18rZHyxj0EBGRasRrKOF4giCMK2ZmXY+WMeghIiJVCIbCcJ6LBD3VZfHp3JLE2tZZ16NpDHqIiEgVPrjkxVAghJw0E5YWZsf1c7NtXR8Y9BARkSq0jEttGQxCXD8301v6wKCHiIhUQZrPUxXn1BYwNqvH1TOAcJiLR7WKQQ8RESmeKIqxm554DSUcrzQ3HSlGAf5gGB2e4bh/flIGBj1ERKR47X1D6B3wI9VkwM0llrh/fpPRgLI87uDSOgY9RESkeNK+rVtKLDCbjAn5Gqzr0T4GPUREpHhj9TzxT21JKgp506N1DHqIiEjxpKGEaxMZ9HAHl+Yx6CEiIkXr8fnh6h2EIACVC+PfuSVhekv7GPQQEZGiHTkbSW0tK8qGJbojKxHs0anMvQN+9A+NJuzrkHwY9BARkaKNDSVM3C0PAGSnpaAoxwwAaOXiUU1i0ENERIomdW4lYj7PlVjXo20MeoiISLEG/UEcv+gFkNygx9XLuh4tYtBDRESKdey8B6GwiGJrOhZY0xP+9bhtXdsY9BARkWKNpbYSW88jkXZwcVaPNjHoISIixWpJwlDC8aT01tm+IYyGwkn5mpQ8DHqIiEiRRkNhHD3nAZCceh4AmJeThoxUI4JhEefcQ0n5mpQ8DHqIiEiRPrzkxVAgBEt6CpZE006JZjAIsXk9rOvRHgY9RESkSLH5PItyYTAISfu6nMysXQx6iIhIkVraklvPIxkLenjTozUMeoiISHFEUcThs8nt3JIw6NEuBj1ERKQ47X1D6B0IINVkwMoSS1K/dkXhWE2PKIpJ/dqUWAx6iIhIcaTU1qoSK8wmY1K/dlleJgQB8I4E0TsQSOrXpsRi0ENERIozNp8nuaktAEhLMaI0NwMAU1xaw6CHiIgU5/DZSOdWsubzXCm2joJBj6Yw6CEiIkXp8fnR1jsIQQAqFyX/pgcYv22dbetaYpL7ANPhcrnQ3NwMu90Ol8uFuro6WK3WOT+WiIiU53A0tbWsKBuW9BRZzsAdXNqkiqBn06ZNOHLkCIBIULNlyxY0NTXN+bFERKQ80lBCuVJbANvWtUrx6S2XyzXhbbvdDofDMefHEhGRMsXm85TLGfREano6PMMYDoRkOwfFl+KDHofDAZtt4je+zWaD0+mc02OTyTMUQDjMWQ9ERNcz6A/i+EUvgOQPJRzPlpkKa0YKRBFo62Vdj1YoPujxeDyTvt/tds/psQDg9/vh9Xon/Ik3URTxtz87hoe/83osT01ERJM7es6DUFhEsTUd8y3psp1DEASmuOJIFEXc9/TL+PR/v47eAb9s51B80DOVqQKcmTy2oaEBFosl9qe0tDQ+hxunwzOMo2cv472OftQ+8yb+9vmjuOgZjvvXISLSAmk+j5y3PBK2rcePdzgIV+8gjp7zIMssXzmx4oMeq9V61U2N2+2etCNrJo8FgO3bt6O/vz/25/z58/E6dkxJbgZeeuoefHZtKQQB+NU7F3Hf/30Z33acZp6YiOgKSqjnkXDbevx0ekcAANaMFKSlJHfC9niKD3pqamomfX9VVdWcHgsAZrMZOTk5E/4kQn6WGQ0bbsav/+YOrC2zYWQ0jP9wnELNt17Bb969yN0uREQARkNhOM96AMjbuSUZm9XDm565koKeeTlpsp5D8UGP3W6f8LbL5UJVVVXs9sbpdMa6tq73WLndVGzBvq234T8/uxoLLGno8Azjb356FI/segvvd/TLfTwiVQuHRVwe5J4kNfvgohfDoyFY0lOwOBpwyEma1ePqHWAzyhx19UeCniKZgx5VzOlpampCfX09qqur0dLSMmHuTkNDA6qrq7Ft27brPlYJBEHAQ7csQM3yIux6tRXPvNKKQ+1uPPRfr+Ez1aX4x/uXIS/LLPcxiRSv2zuCo+c9OHbeg3fOe/DuhX4M+IP4xoaV+MzahXIfj2bBeS4yn2fNolwYDILMpwFKc9ORYhQwMhrGxf5hlET3cdHMKeWmRxCZW4nxer2wWCzo7+9PWKrrSh2eYXzj9yfw63cuAgCy00z4u3VL8KWPlCHVpPiLOKKkGAoE8d6FfhyLBjnHzntwKfqb45Xm5aTh1W338r8fFfrHpnfQfOQC/m7dEvz9+qVyHwcAsP5br+B09wCee2wt7l5aIPdxVOt//Pw9/OTtc/jbdUvwZAL+v53u67cqbnq0rNiajv/87Gp86SOL8G+/Po73O7z437/9ED89dA7/3ydvxL3LCuU+IlFSiaKIU10DOHb+Mo6d9+DoOQ9OdflwZXbBIABLi7KxqtSKW0qtWFlswWM/aEGndwS/PNaBTVXx78akxJLS/DcVW2Q+yZiKgiyc7h5Aa/cAg5456FLITQ+DHoWoLrPhl399B5qPnMc3/3gSrp5BfPn7Lbh3WQH+5ydvjBXUEWlZMBTG1/Ydw2/evXTVx+blpGFVqRWrFlpxS4kVN5dYkHlF6+tjd5TjG78/gWdeacXGyhJFpEhoekZGQzgTLRhesSA5N+3TUVGYCRxn2/pcSemtohx5yzcY9CiI0SDgkeqFeHDlfPzXi2fw/dfb8NLJHhw8/Soevb0MX123RLble0SJFg6L2PbCu/jNu5eQYhSwZlEuVpXmRgKdUivmWa7/G+Lnbl2I77x4Bq09g3B82IX7V8xLwskpHk51+RAMi7BlpmL+NP6/ThYOKIyPzv7IQEK5C5mZ9FagnLQU/NPHl+OPX7sL624oRDAsYu9rbbjv6Zfx/KFzCLGLgDRGFEX826+PY7+zA0aDgO98rhI/q/sIvv7gDfjYTfOmFfAAkf92Pn/bIgDAM6+0chyEirzfEZmIv2JBDgRBOTd0nNUzd6OhMPoGI0HPdP9bThQGPQpmL8jC9x6txg++XI2Kgkz0DQawff97eOg/X8Pbrj65j0cUN0//6SSee/MsBAH4v5tumdMNzWMfjTQBOM95Ytu6SfmOX4zU86xYoJx6HgCwR6cy9/j86B8elfk06tTt80MUgRSjAFtGqqxnYdCjAvcsK8QfvnYX/vmTNyI7zYQPLnnxyO63cNfOl7B9/3v43XuX4BnifBJSp+++3IrvvNQKAPjfn7oJn1pdPKfPV5iTho2VJQAitz2kDu9Hl4zeVKyceh4AyE5LidWhuJjimpXOaKdlYXaa7HV2rOlRiRSjAY/dUY6HVy3Atw6cQuPh8zjnHsK5Q+fw/KFzEARgZbEFH12cjzsX52NNWS7MJvlGfRNNx4/eOosdfzgBAPj6gzfg87cuisvnrbvLjp+1nMOLJ7pxstOHZfOy4/J5KTGCoTBOXJLSW8q66QEiKa4urx+tPYNYvVD+nWBqE+vcUkCtFoMelcnLMuP/fHoltn98OQ619eHg6V68fqYXp7oG8O6Ffrx7oR/ffbkVaSkGVJfZcOeSfHx0cT6Wz8uRPcImGu/nRy/gn3/5PgDgb+5djK/cXRG3z12en4kHb5qH373XiV2vtOJbj6yK2+em+GvtGYQ/GEaW2YRFNuUNAKwoyMIbrX0sZp4lpbSrAwx6VCvLbMJ9NxThvhuKAES+qV4/04vXTvfitTO96Pb5cfB0Lw6e7gUA5GWm4vbF+bhzST4+vboYKUZmNkk+fzreiX9seheiCDx6exn+4f74Dyv7yt0V+N17nfjlOxfx5P1LOU1XwaR6nhvnK/OXs9i2de7gmhWpXb1Q5nZ1gEGPZhTlpGFDZQk2VJZAFEWc7h6IBUBvufrQNxjAr9+5iF+/cxFvufrwrc2r5D4y6dRrp3vxNz89ilBYxMbKEvzzJ29MSLfOzSVW3F6Rhzda+7D3YBv+9S9WxP1rUHzEOrcUVs8jkXZw8aZndqS9W0q46eGv+xokCAKWFmXjsTvK8eyj1Tj2z/ejcetH8Nf3VkAQgP3ODi44JVkcOevGlh8eRiAUxsdWzMOOjSsT+pu9lDLb13Key0gV7H2Fdm5JpLb1s31DGA2FZT6N+nQqqKaHQY8OpJoMWFtuw1MP3IBPrYp0xnzj9ydkPhXpzfGL/Xj0+y0YHg3hziX5+PZnV8GU4DTrnUvysWJBDoZHQ3juzfaEfi2anXBYxIcK7dySzMtJQ0aqEcGwiHPuIbmPozpdXmUMJgQY9OjOk+uXItVowGtnenHwdI/cxyGdaO0ZwJe+dwi+kSCqy3Kx64trktJdKAhC7LbnuTfaMRQIJvxr0syccw/B5w8i1WRQ7Lodg0GIzethXc/MiKIYa1lneouSrtSWgS9+JNIW/I3fn0CY050pwS5cHsIX9r6NvsEAbirOwfcerUZGavLKCR+8aR4W2jJweWgUjS3nk/Z1aXqOR295ls/LVnSDBSczz453JIjh0RAAprdIJn9972Jkm004ftGLX71zUe7jkIZ1+0bwhb1v41L/CCoKMvHcl9ciJy25++NMRgO23GUHAOw52MaaDIWJ1fMoaLP6ZLiDa3a6o/U8lvQUpKXIPzuOQY8O2TJT8ZV7Ilf+T//pJPzBkMwnIi3yDAXwxb2H0N43hFJbOn7y+G3Iy5KnZXXTmhLkZ6WiwzOM37zLQF9JpJseJW1WnwyDntnpVNCMHoBBj2499tFyFOWYceHyMH781jm5j0Ma9NXnj+Jklw+F2Wb85K9uk/VqOy3FiEdvLwMA7HrFxUWkCiGKIo5HO0lvUmjnlqSicKymh98/0xdbQaGAGT0Agx7dSk814u9rIgPh/uvF0/COcJEexc/hdjcOnu5FilHAj/7qVizMk38w4BdvK0NmqhEnOn14+SSL+JWgy+tH32AARoOg+FUhZXmZEIRIjUrvAMcfTJeSpjEDDHp0rXZNCSoKMnF5aBS7uJiR4kha9LmxskQxL2aWjBR87taFAIDv8vtdEaR5YUsKsxRR73EtaSlGlEanejPFNX1KmtEDMOjRNZPRgPqP3QAA+N5rbbGInGguTnb64PiwG4IQWfypJH91hx0pRgGH2txwnrss93F0TypivlHh9TyS2DoKBj3T1tmvnBk9AIMe3Vt/YxHWLMrFyGgY/89xSu7jkAZIt4YP3jQPdoXNXZlnSYsN6HzmZd72yE0qYlZ6PY8kVszczbb16WJ6ixRFEARsfzBy27Ov5TzOdPtkPhGp2YXLQ/hldAxCPLemx9PWuyO3T3/6oIvf7zKTipiV3rkl4Q6umWN6ixSnqsyG9TcWISwCO/9wUu7jkIrtPdiGUFjEHYvzcXOJVe7jTGpxYTbW31gEINLJRfJwDwZwMdrZo570FoOemQiGwugdYHqLFKj+Y8tgECK//R5ud8t9HFKhvgE/ftYSGX/wxD3KvOWRSLdQvzjWgUv9wzKfRp+OR+t5yvMzkZ3kgZWzJdX0dHiGMRzgfLPr6RnwQxQBk0FAXmaq3McBwKCHohYXZmNzVSmAyHoKzqGgmXrujXaMjIZxc4kFt1fkyX2ca1qzKBdry2wYDYl49rU2uY+jS1I9j1pueYDIYFdrRgpEEWjrZV3P9cRm9GSbYTAIMp8mgkEPxXytZinSUgw4fPYyDnzQJfdxSEUG/EE89+ZZAMATd1dAEJTxA+5apNuon759Dv1DnFOVbO+rZCjheIIgMMU1A1IRc5FC6nkABj00zjxLGh77aDkAYMcfTiDIHUU0TT87dA79w6Ow52fi/hXz5D7OtNyzrAA3zMvGYCCEH799Vu7j6I5a1k9ciW3r06ek7eoSBj00wVfuqYA1IwWtPYNoPnJB7uOQCviDIew5GCkI3nq3HUaFXGNfjyAIsU6uZ19rw8goazSSxTcyGksPqS/o4bb16er0KquIGWDQQ1fISUvB39y7GADwH45TLNaj6/rl0Yvo8vpRlGPGp1YXy32cGfnkzQtQbE1H32AATQzyk+bDS5FRAfMtabItoZ2tsVk9vOm5ni6FtasDDHpoEl/8yCIUW9PR5fXj2ddZ5ElTC4VFPPNqZMjf43fYYTYpe5XAlVKMBjx+ZySl++xrbQiHWcCfDFLn1goV1fNIpFk9rt4Bfr9ch9IGEwIMemgSZpMR//hAZBnpMy+3wj3I5Xo0uQMfdMLVM4icNBM+G91rpTabqkqRbTahrXcQr5ziItJkeL9DnfU8AFCam44Uo4CR0TAuctzBNUmDCZWyYR1g0ENTePiWYiyfnwOfP4jvvHRG7uOQAomiiO9GVzn85e1lyDKbZD7R7GSZTXikOjKugTebySHd9NxUrL6bHpPRgLI8qZiZdT3X0sVCZlILg0HA16PrKX705lmcdw/JfCJSmjda+/DOhX6kpRjw6O1lch9nTv7y9jIYBODg6V6c6uJqikQaGQ3hdLQe5qZi9d30AKzrmQ7fyCgGozWhrOkhVbhrST4+ujgPgVAY//dPXE9BE0m3PI9UlaquGPVKpbaM2GqK77/eLu9hNO5Ulw+hsAhbZqqibgBmoqKQbevXI9XzZKeZkJGqnFtgBj00JUEQ8PWPLQcA/OLYxdgwMaJ3L3jw2pleGA0CHr/TLvdx4uLL0RlVPz96AZ4h1rElyvh6HjUMsZwMBxReX2d/pF1daYEtgx66ppUlFjx0ywIAwLf/fFrm05BSPPNK5Jbn4VsWoNSWIfNp4uPWchtunJ+DkdEwnj90Xu7jaNb7Ku7cknBWz/Upbbu6hEEPXddX74vM7Xn5ZDf6hzmuX+9cPQP4/fudAICtdyt7sehMCIKAL3+0DADwwzfbMcqJ5AkhTWJWaz0PANijU5l7fH7+TJxCbAUFb3pIbZYWZWNpURZGQyJ3chF2v+qCKAI1ywuxbF623MeJq4duWYD8rFRc6h/BH493yn0czQmGwjhxSUpvqfemJzstJbY1vOMy29Yno8QZPQCDHpqmj6+cDwD43XuXZD4JyamzfwQvOCOTi6WFnVqSlmLE525dBADcvp4ArT2D8AfDyDKbsEjlaVHpBkN6caeJpL1bRQqa0QMw6KFp+kQ06Dl4uofXuTr27OttGA2JWFtmw5pFNrmPkxBfuG0hUowCnOc8eOe8R+7jaIrUDHHj/BwYVLKjbSpSrQqDnskxvUWqtqQoG0sKIykuB1NcutQ/NIqfvBXZRq7FWx5JYXYaHro5Urz/fQ4rjKvYZnUV1/NIpBuMTgY9k2IhM6keU1z69qO32jEYCOGGedm4Z1mB3MdJKKl9/TfvXuJv8nGkhc4tyVh6yy/zSZQnGAqjx8eWdVK5T9wcCXpeZYpLd4YDodjQvifuqVDtfJXpWlliQXVZLoJhET+O3m7R3ITDIj7UQOeWhDU9U+sdCCAsAkaDoLjBpQx6aNqWFmVjMVNcutR05Dz6BgMoyU2P1XdpnXTb85O3z2FkNCTzadTvnHsIPn8QZpMBi6NzbtRsHoOeKcUWjWabYVRY7RaDHpoRprj0ZzQUxq5XXACArXfZYTLq48fG/TcWodiaDvdgAL86dlHu46ielNq6YV62Jr6HpM3hDHquptQiZoBBD83QWBdXL7wjTHHpwW/fvYQOzzDyMlOxqapU7uMkjclowJc+Em1ff70NoijKfCJ1GytiVn89DzD2gt47EOAgyyuMBT3KSm0BDHpohpYWZaGiIBOBUJgpLh0QRTG2cuKxO8qRlmKU+UTJ9ZnqhUhPMeJEpw9vuvrkPo6qSe3qKxaov54HAGwZqUgxRlI3UtEuRUgzepRWxAww6KEZEgQhdtvDFJf2Oc9dxolOH9JTjPhCdGifnlgyUrBxTTEAbl+fC1EU8YFUxKyBzi0AMBgEFGZHXtTZtj6R9HwUKaxdHWDQQ7PwcamL6xRTXFrX2BKZvvzxlfNhyUiR+TTyePT2SEGz48MunO3jgsnZ6PSOoG8wAKNB0NTqEil9082gZwKlrqAAGPTQLCwryoY9muL684dMcWnVoD+I37wbKeB9pFo/tTxXWlyYhbuXFkAUgefeYPv6bBzviNzyLCnM0lSKVKrrkdI5FMH0FmnK+BTXb9/lUkat+t17lzAYCKEsLwPVZblyH0dW0vb1xsPn4ePt5oxJnVs3aqSeRxKb1cOangmkgY1Mb5FmSK3rr57u4YuARjUdjqS2NlWVan4Y4fXctaQAFQWZGPAH0XzkgtzHUZ33O7RVzyOJBT286YkZ8Acx4A8CYMs6acgN87Jhz89EIBjGnz/slvs4FGeungEcanfDIAAbK0vkPo7sDAYBj0aHFf7gjXaEwmxfn4kPojc9N2mkXV0yzxKd1eNj0COR6nmyzCZkmU0yn+ZqDHpoVgRBiN32/JZdXJrTFL3NuHtpgeIWBsplY2UxctJMONs3hJdOMNCfLvdgABejNyHL52uniBkAirJZ03Ml6dZLiTN6AAY9NAdS0PPKKaa4tCQYCuOFaNCzWUfDCK8nI9WEz65dCAD4/hvcvj5dx6O3POX5mchO01YHoFSz0s2lozFK3a4uUd7d0xVcLheam5tht9vhcrlQV1cHq9U66WOdTiccDgcAoKWlBXv27JnysTR3y+dnozw/E229g3jxRDceXlUs95EoDl493YNunx+2zFSsW14k93EU5Uu3l2Hva214/UwfTnR6ccM8bRXmJoJUz6O1ImZgrGbF5w9i0B9EpgLTOcnWqeAVFIAKbno2bdqEbdu2oba2FrW1tdiyZcuUj3U4HNi2bRu2bduG6upqrFu3Lokn1Z+JXVxMcWmFNJvn06uLkWpS/I+IpCq2puOBFZFA8AccVjgt0k2P1oqYgYl1K9zBFdGl4HZ1QOFBj8vlmvC23W6P3eRcyel0oqGhIfZ2bW0tnE7nVZ+D4ktKcb18qidWsU/q1TvghyM6e4mprck9Fi1o/vnRDrgHAzKfRvliO7c0eNMDjC0e5VTmCKWntxQd9DgcDthstgnvs9lscDqdVz22srISe/bsib3t8Xhij6fEkVJckS4uDipUu18c7UAwLOKWEoumJufG05pFuVhZbIE/GMbzh87JfRxF842Moq03MsVaq0GPdKPBup6ITmlGD296Zk4KXK7kdrsnfX9tbW3sn/ft24eamppr1vT4/X54vd4Jf2hmIl1c8wBwF5faiaKIfS3nAUBX29RnShCE2LDCH77Zzg3b1/DhJR8AYL4lDXlZyuzmmavYVGbe9AAYW8nBoCeOpgqGxn+8ubkZTU1N13xcQ0MDLBZL7E9pKX/Qz0YsxXWyB4NMcanWOxf6cbp7AGaTAQ/dskDu4yjaJ26ej4JsM7q8fgb71zC2WV179TwSKb3Fmh4gFBbRHZ1OrdSaHllKzXfv3o3W1tYpP75+/frYLc2Vtzput/u6HVn19fU4cODAdR+3fft2PPnkk7G3vV4vA59ZuHF+DsryMtDeN4Q/n+jGX/AFU5UaD0dueT6+cj4s6dpqLY43symydf4/HKfwk7fOsXNxClI9z03F2kxtAWMv7gx6gL4BP0JhEQYByM9Klfs4k5Il6Kmrq5vW42pqarBr166r3l9VVTXl39m5cyfq6+tht9tjN0JTBT9msxlmszavXJNJGlT43y+34nfvXmLQo0LDgRB+fSyyXHRTFScwT8emqhL8h+MUDp91o39oVLdb6K9F6tzS8k1PbBUFa3piKb6CbDNMRmUmkpR5qii73T7hbZfLhaqqqlgQc2V3VnNzMyorK2MBT2NjI+f0JImU4nrpZDdTXCr0+/cvwecPotSWjtvK8+Q+jiossKZjcWEWwiLwemuv3MdRnJHREE53DwDQ9k0PN62PUfJ2dYmigx4AaGpqQn19PZqbm7Fr164JdToNDQ1obm4GEAmINm3ahPXr10MQBOTm5qK+vl6uY+vOigU5WJSXAX8wjBc5ol91pNTWpjWlMBj0vVx0Ju5aUgAAePVUj8wnUZ6TnT6EwiJsmamKfhGcK2ndQrdvBKKo751sXQovYgZUMJHZbrdjx44dACZ2ZwGYEADZ7Xbdf8PJSUpxffflVvzuvUsshFWRs32DeMvlhiAAG9cwtTUTdy7Nx7Ovt+Hg6V6Ioqj7bfTjjZ/Po+XnpTC6f2s0JOLy0ChsmcqsZUkGpc/oAVRw00Pq8YlxKa6hAFNcatEc3bN1x+J8FFvTZT6NutxWnodUkwEdnmG09gzKfRxFeV8H9TwAkGoyIC8a6Og9xdWl8Bk9AIMeiqMVC3Kw0JaBkVGmuNQiFBZjQQ8nMM9ceqoRa8siA1CZ4proeLRdXcv1PJJYMbNP70GP8tNbDHoobqQUF8BBhWpx8HQPLvWPwJqRgvtXcLnobNy5JB9A5LmkiNFQGB92RgYTav2mBxir6+nS+U0PC5lJd6QU14snmOJSg6bDkVueT60qhtlklPk06nTX0kgx81suN/zBkMynUYbWngEEgmFkmU1YZMuQ+zgJJ9Ww6L1tfaymR7mjYBj0UFzdVJyDUls6RkbDeOkEf/NVMvdgAH/6oBMAZ/PMxQ3zslGQbcbwaAiH2y/LfRxFON4RKWK+cUGOLroBpWJmPa+iGAoE4RuJ/KLL9BbpBlNc6vHLYx0YDYlYsSBHFymIRBEEIZbiepUpLgDAh5eiQc987dfzAGM3Pd06Dnqk1FZmqhHZacod1Mmgh+JufIprOMDrfiUav1yUBcxzd/dSaV4PhxQCQHtfpJOtojBL5pMkh1TTo+ebHunfvUjB7eoAgx5KgJXFFpTkpmN4NISXTrKLS4ne7/DiRKcPqSYDHl7FmUpzdcfiyE3Ph5e86NZ5Bw8AtPVGgp7yvEyZT5IcXEUx1rml5CJmgEEPJYAgCLHbnt8yxaVI0gTmB1bMgzVDv8PU4iUvyxxrzX7ttL5ve0JhEefdwwCARXnaL2IGxoKevkE/RkNhmU8jDzXM6AEY9FCCSHU9L37IFJfSjIyG8MtjHQCAzSxgjhuupIi46BlGIBRGqtGABToZdmnLSEWKUYAoAj0+fd72SDU9DHpIl24uGUtxvcwUl6L88XgnvCNBFFvTcXtFvtzH0Qypdf3g6V6Ew/pdiSOlthbmZcCog84tADAYBN13cI2lt5Tbrg4w6KEEGd/F9RumuBRFms2zcU2Jbl6UkqFyYS4yU43oGwzgg2j3kh5JRcxlOqnnkRRKi0d1GvSoYe8WwKCHEkiq6/nzh13oHx6V+TQEAOfdQ3jtTKTmZBOXi8ZVqsmAj1TkAdB363qsiDlfH/U8EqmAV6/7t7qY3iK9u7nEgqVFWRgZDeMXRzvkPg5hbLno7RV5KNXBpNxku2sp63rao0FPWb6+bnrG9m/pr6YnHBbRHf335k0P6ZYgCPjc2oUAgJ+8fRaiqN86ByUIj1su+kg1Z/Mkwp3RYuYjZy9j0K/PNSztfUMA9NOuLokFPTq86ekd9CMYFiEIQEEWa3pIxz5dWYK0FANOdQ3gyFmO6JfTG6196PAMIzvNhAdWzJP7OJpUlpeBUls6RkMi3nL1yX2cpAuGwjjvjgQ9+rvpiS4d1eGcpu5ou3p+lhkmo7LDCmWfjlTPkp6Ch26ODL/7ydvnZD6NvkmzeR5etQBpKVwumgiCIOi6df3C5WEEwyLMJoPih9TF2zwdDyhUw3Z1CYMeSrjP37YIQGRQ4eXBgMyn0af+oVH84XhkuSjXTiSWlOJ6VYdDCsd3bulh0eh4hTpOb8VWUDDoIQJuKbHgxvk5CATDeMF5Qe7j6NKv3ulAIBjGsqJsrCzmctFEun1xHowGAW29g7FUj16MFTHrr0heKuD1+YO6q+eKzeixKLueB2DQQ0kgCAI+f1ukoPmnb59jQbMMmqIFzJuqSiAI+voNPNly0lJQudAKQH+t61IRs97qeQAgy2xCZmokbdyls1k9TG8RXeHhVcXITDXC1TuIN3VY4Cmnk50+vHuhHyaDgE+vLpb7OLpwp07revS2aPRK0oZxvdX1aDq91d7ejm9+85u4//77UV1dHfvzwAMP4Omnn0Z7e3sCjklql2U24eHoC+5PWdCcVE3RAub7bihEnsLbSbVCmtfzxpk+BHW0gFKq6Vmk16AnWwp69HXT06WSacwAYJrJg7/+9a9DEARs3rwZTz311FUfP3r0KJ555hkIgoCGhoa4HZK04XNrF+Knb5/DH493onfAj3y+ACfcaCiMn0cHQ25iAXPSrCy2wJqRAs/QKI6d96CqzCb3kRJuNBTGhcuR7erlOkxvAWMv+noLetSU3pp20PPNb34T27dvh8UydRHk6tWrsXr1avT392P79u0MfGiCm4otuKXUinfOe9B0+AKeuKdC7iNp3osnutE3GEB+ViruWVYg93F0w2gQ8NHF+fjtu5fw6qkeXQQ9591DCIVFpKcYYzNr9Ebav6WnpaPDgRC8I5HC7UIVBD3TTm899dRT1wx4xrNYLAx4aFKfj05ofv7QOV1vok4WabnohsoSpCh8aJjW3K2z1vWx1FaGbovlpfRWt45qeqRbrfQUI3LSZpQ8kgV/ClJSffKW+chOM+HcuMWXlBg9Pj9eOtkNgMtF5XDn0nwAwLsXPPAMaX8+VVtvdP2ETlNbwFh6S083PeO3q6sh2J1z0NPW1obNmzdj8eLFyMvLQ3V1Nfbv3x+Ps5EGZaSasCFa0PyTt8/KfBpt+8XRDoTCIm4ptWJJUbbcx9Gd+ZZ0LCnMQliELgJ8vS4aHS+2ikJHQU9XrHNLHSnNOQc9L7zwAvbs2YMzZ85g9+7daGxsRF9fH/bu3RuP85EGfe7WyIRmx4fduvrhkEyiKKLpSKRri7c88pG6uA6e0kHQ06fvdnVgrGW72+vXzTwyNRUxA3EIeux2e6zWZ/369ejv78eWLVtQXl4+58ORNi2bl42qRbkIhUU0tpyX+zia9O6FfpzqGoDZZMBDtyyQ+zi6JQU9r57u0fyLYBtvelAYrekJhMK4PDQq82mSIzajRwXt6kAcgp7W1lY8/fTT2L59O7Zs2YJVq1bhm9/8Jtra2uJxPtIoaULz84fOIcSC5riTbnkeWDEPlvQUmU+jX2vLbEg1GXCpfwRnugfkPk7C+IMhXPRE2tX1uIJCkmoyIC8zFcDYDYjWxWb06OWm56mnnkJ5eTnsdjt2794NAKirq8Pjjz8+58ORdj1403xYM1JwsX8Er5zqlvs4mjIyGsKvjl0EEFk7QfJJTzXi1vJIu7qWu7jOu4cRFoHMVCMKdD5/K7Z41KeXoCfSqaaGaczAHIKeY8eOxf5548aN2Lx5cyzNNd3WdtKvtBQjaisjL8g/eYsTmuPpTx90wTsSxAJLGm6vyJf7OLp3lw5WUowvYlZDB08izZOKmXVy0yPdaGky6Nm7dy9efPFFeL1eHD58eMLHDh8+PCEQIrqez94aSXG9dLIbHdGrcZo7ae1E7ZoSGA36fgFSAql1/e22PoyMhmQ+TWJIRcx6rueRSC/+eti/FQ6L6PapZwUFMMOgJzc3F8888wwqKyuxY8cOPPHEE7EgaN26dXC5XIk6J2lQRUEWPmLPQ1gE9h3ibU88dHiGY+3RtWu4dkIJlhVloyjHjJHRMA63X5b7OAmh90Wj40lBjx5m9biHAhgNiRAEoDBbHWnNGQU9GzduRGNjI86cOYONGzeipqYmFgQtWbIEBw4cSNQ5SaM+F73t+VnLeYzqaDFjouw/cgGiCNxabsPCPP0WlCqJIAhjW9dPazPFNX4as96Nta1rP+iRUlt5mWbVTHyf9czoRx55BKtXr8bGjRsBAP39/azloRl7YMU85GWmotvnx58/7MbHbpon95FUSxRFNDsjaye4XFRZ7lySj+YjF/DqqR7808eXy32cuGvnNOaYeZZoTY8OCpnHtqur45YHmEMh8+rVqye8zYCHZiPVZIi9QP+UKa45OdTmxtm+IWSmGvHxlQweleTOJQUQBOBEp09zAzlHRkO42C+1qzPokWb1dPZrv6anU2Xt6gB3b5ECfC66hPTVUz041zck82nUq+lI5JbnEzfPR0aq8hf/6YktMxUriyO/GB7UWOv6OfcQRBHINptiM2r0TCro7Rv0az5lL3WoqWG7uoRBD8luYV4G7lwS6XB5voW3PbMx6A/id+9dAsDUllJJ3+Naa11vY7v6BLaMVJgMAkQxsvRXy6QONV3e9LS1teGRRx7B/v37sX//fni93nh9atKBz0f3cTUdPo9AUNu/HSXCb9+7hKFACOX5mahalCv3cWgS0rye1870IqyhKeRcNDqRwSDEOpm0lsq8kq7TWx6PB6IoYsOGDdiwYQNaWlri9alJB9YtL0Rhthm9AwH86YNOuY+jOs2HI6mt2jUl/G1boSoX5SIz1Qj3YADHL2rnl8KxRaPs3JJIe6i0HvR0qWzvFhDHoGf16tVobGyMvb1u3bp4fWrSgRSjAZ+pjqRlOKF5Ztp6B3Go3Q2DAGys5NoJpUoxGvCR6IRsLbWuc9Ho1Yqy9TGgUFc3PV6vF+3t7XE8CundI2sXwiAAb7r60Nqj3eWM8dYcXS5655IC1UxF1au7o9OZX9FQXc/ZaPMBg54x0n+HWh5QODIagie6SV4XQc+///u/Y/369QAiM3r27t0bt0ORPhVb03HvskIAwPNv87ZnOkJhES8c6QDA5aJqcNfSSF2P8+xlDPiDMp9m7oYDIVyKdvBwGvOYwhzt1/RI/25pKQbkpKunW3TWQU91dTVOnz4NIDKj5/HHH2fgQ3MmTWhudl7Q7J6ieHrtTC86vSOwpKegZnmR3Meh61iUl4mFtgwEwyLebO2T+zhzdtYdSW1Z0lOQy3b1mHk52q/pkaYxz8tJU1Ud4ayDnsrKSlRXV+Ppp5+OpblEUTsdCSSPe5YVYoElDZ6hUfz+/UtyH0fxpOWiD69agLQUo8ynoem4a6l2WtfZuTU5PSwd7Yq246tpRg8wh6Bn9+7d+MY3vgFRFFFbW4u8vDxUVFTE82ykQ0aDgM9EhxX+lCmua+ofGsWfPugCAGziclHVkFrXXznVo/pfFNuk9RPs3JogFvT0a/emp6tffUXMwByCHrvdjnXr1uGpp57C4cOH4XA44PF44ng00qtHqkthNAhoab+MM90saJ7Kr97pQCAYxg3zsnFTcY7cx6Fpun1xPswmA865h/BeR7/cx5kT3vRMriha0+PzBzGogdqtycQ6t1TWPDHroKempgZ79+6NDSFsbGyE2+2O28FIv4py0nBPtODzhegCTbqatHZiU1WpqnLqepdlNmH9jZH6q/3ODplPMzdt0Rk9ZSxiniA7LQWZqZF0s1breqSgp0gvNz3l5eV4/PHHkZMT+Q3TbrfDbrfH7WCkb1In0n7nBYQ0NL02Xk52+vDuhX6YDAI+tWqB3MehGdpQWQwA+PU7F1W9n4k3PVPTel2PptNb/f39153Js2XLFtx3332xt71eL1dR0Kzdd0MRcjNS0OX146CGBrnFi1TAvG55IfKyzDKfhmbqziUFyMtMRd9gQLXf34P+ILqjxaxsV79akcY7uMbSW+r6+TOtoMdiseDAgQPYv3//tD7pCy+8gMbGxtgtENFMpZoMeHhV5Lfh5iNMcY03Ggrj50ejs3lYwKxKKUYDHrolckOn1hSXtH4iNyMFlowUmU+jPEUantUjiiK6ozdYaktvTXui0JYtW3D06FFs3rwZFRUVqK6uht1uh9VqhcfjgcvlwqFDh9DW1oatW7di48aNiTw36UDtmhL84I12/OmDLvQPjfIHa9SLJ7rRNxhAfpYZ9ywrkPs4NEsbKovxgzfaceCDLnhHRpGTpq7v7/ZeTmK+lrH9W9pLb7kHAwhE07KF2RoNeoCx/Vr9/f1obGzEoUOH4PF4YLVaUVFRga1bt6K8vDxRZyWdWbEgBzfMy8aJTh9+/e5FfOG2RXIfSRGaostFN1QWw2SM2/o8SrKVxRZUFGSitWcQf3ivE5ur1XVrN7ZolEHPZMb2b2nvpkcK5PIyU5FqUtfPoFnNjrZYLNiyZUu8z0I0gSAIqF1Tgv/92w/RfOQCgx4APT4/XjrZDQDYtIZrJ9RMEARsqCzBN/94EvuPXlBf0MMi5mvSck1Pl0o7t4A4bln/85//HK9PNYHL5cLOnTvR3NyMnTt3TnsWUH19PecGacDDq4phNAg4dt6DM90+uY8jux+/dRahsIhVpVYsKcqW+zg0Rw9HO+/ecrnR4RmW+TQzI930MOiZnFTgq8Wlo2qd0QPMIej5+te/ju3bt+PFF18EAKxbty4hu7c2bdqEbdu2oba2FrW1tdO6YXI6ndi5c2fcz0LJV5Btxr3RupXmI+os+IyXoUAQz73ZDgDYcifHQ2hBSW4Gbi23AQB+cVRd399j05gZ9ExGqnXp9vpVP3n7StLeLV3d9Gzfvh12ux3PPPMMbDYbqqurceTIkXieDS6Xa8LbdrsdDodjWn+PM4O0ozbaofTzo/qe2bOv5Tw8Q6NYlJeBj900T+7jUJxIM3t+frRDNS+OvpFR9A5E6jrK8rmCYjLSpvVAKIzLQ6Mynya+pPSW2mb0AHMIeqS6HmkS8+7du1FbWxvPs8HhcMBms014n81mg9PpnPLvNDc3x/0cJK/7bijU/cye0VAYew+2AYjc8hgNnMCsFQ+unA+zyYAz3QN4v0Mds83O9kVuefKzUpGtsq6zZDGbjLBFN89rra5HrTN6gDkEPV6vF8eOHYu9vXr16riPwp+qJmeqdRdSJ9l0+f3+2BBFDlNUrvEze5p0OrPnt+9eQodnGPlZqahlAbOm5KSloEZaS3FUHd/fbb1cPzEdUvpHa3U9UnpLbRvWgTkEPdu2bcO2bduwZMkSPPHEE9i7dy+ampriebYpTRUMNTY2oqamZtqfp6GhARaLJfantFRd3RN6Ir3QHzgemdmjJ6Io4plXWgEAj95ehrQUo8wnonjbsHpsLUVQBWsp2Lk1PdKAwm6NBT3SJG41prdm1bIOAGvWrMHOnTuRk5ODF154AS6XC9u2bZvW3929ezdaW1un/Pj69etRU1MDq9V61a2O2+2e9DbH4XBg8+bNM/p32L59O5588snY216vl4GPQo2f2fOrdy/iizpqX3/lVA9OdPqQkWrEF28rk/s4lAB3LY2spegdCODg6V7ce0Oh3Ee6prFFo6znuRYpKOjs186AQn8wBPdgAIDOgp4tW7Zg//792LBhw4ynL9fV1U3rcTU1Ndi1a9dV76+qqpr08Y2NjbF/drlcaGhowCOPPILKyspJH282m2E2qy8nqUdXzuzRU9Aj3fJ8du1CTqXWKGktxQ/eaMf+ox2KD3p40zM9Uvqny6edmx5p/USqyQCrCn8ezTroAYANGzbE6xyTurIDy+VyoaqqKnbT43Q6YbVaYbfbr0prbd26FVu3bmUXl4Z8anUxvvH7E3jnvAenu3y6mFNz7LwHb7ncMBkE/NUdnHauZZ9eHVlL8afjnfCNjCq6QLg9WsjMmp5rk25CpI3kWtA5rnMr3nW8yaD4+dFNTU2or69Hc3Mzdu3aNaFuqKGhAc3NzRMe7/F4YjN6duzYcc1OL1KXyK6pyG/AzU51FHzO1a7oLc/Dq4qxwJou82kokW4uiayl8AfD+P37nXIfZ0r9w6Ox9AZveq4ttnRUQzc9UhGzGlNbwBxvepLBbrdjx44dAHBVK/pkhdNWqzVWZE3as6mqBI4Pu/BzZweeun+ZpndPuXoG8IfjkRe/rXfzxlLrxq+l+LmzA5urlFlfKKW2CrLNyDIr/iVEVkUarOmJraBQ4TRmQAU3PUTj3busELbMVHT7/Dh4plfu4yTUnoMuiCKw7oZCLNVBKo/G1lK86epT7FoKLhqdPino6Rv0Y1QFXXnTEZvGnK3OelgGPaQqkZk9kReGZg3P7On2jeCF6NqNr9xTIfNpKFnUsJaiPbp+gpOYry8vMxUmgwBRjCwL1gI1790CGPSQCo2f2eMZCsh8msT4/uvtCITCqFxoRdWiXLmPQ0mk9LUUXDQ6fQaDgMLojYhWpjJL3Vtq3LsFMOghFVqxwILl83MQCIXx63cuyn2cuPONjOLHb50FAHzl7gpVdkjQ7Cl9LYU0jZnpremJta17edOjBAx6SJWk2x4tprieP3QOvpEgKgoyUbO8SO7jUJIpfS0Fb3pmJta2roGbHlEUJ7SsqxGDHlKlT61aAJNBwDsX+nGqyyf3ceLGHwzhe69FFotuvasCBi4W1SWlrqXwDAXgia6B4Yye6Ym1rWsg6PEMjSIQjHw/Slvk1YZBD6lSXpYZ90Wn1r6godueXx67iC6vH0U5Zjy8eoHcxyGZXLmWQimk1Na8nDSkp3IH3HRIrd1aWDoq/TvYMlNhNqnz/38GPaRaUopr/9EORf02PFvhsBgbRvhXd5Sr9ocKzZ20lgKIfH8rxVhqi51b01WUHQl6ujVQ0yMFPWotYgYY9JCK3XtDIfIyU9Hj8yvqt+HZcnzYhdaeQWSnmfDZtQvlPg7J7NPRFJe0lkIJ2nq5fmKm5mnopkdap1Gk0tQWwKCHVCzFaMDDqyIvDFooaN71qgsA8IXbFil67xIlx80lFtgVtpaCi0ZnTks1PVIHmlqLmAEGPaRysZk9H6h7Zk9LuxtHzl5GqtGAL3+0TO7jkAIIghAraP65Uxkprlh6izc90yalgnwjQQwFgjKfZm6Y3iKS2Y0LcnBjdGbPr1Q8s+eZlyO1PBvXFKMwW70/UCi+pJvMt9r6cFHmtRSiKI7N6OFNz7RlmU3IiBZ9q31WT5fKZ/QADHpIA9Q+s+dUlw9/PtENQQC23MnFojSm1JaBteU2iCLwi2Py3va4BwPwjURuKhblsZB5ugRBiKWDpL1VaqX2DesAgx7SgIejM3vevdCPk53qm9mz65VILc/HVsyDvSBL5tOQ0oxPccm5lqK9L1LEvMCShrQUdhbOhDTTptun7qCni+ktIvnlZZmxbnl0Zo9TXbc9Fz3D+GX0N/itd3OxKF3twZXzkWoy4HT3AI5flG8tBYuYZ08LNz3+YAh9g5G6Saa3iGRWu6YUALDfqa6ZPc++1oZgWMRtdhtWlVrlPg4pkCU9BeultRQyFjRz/cTsFWlg/5Y0ZyjVaEBuhnq7Sxn0kCbcs0yaYOvHq6d75D7OtPQPjeL5Q+cARBaLEk1FSnH9Ssa1FFw0OnuFGti/JZ29MMes6iXIDHpIE1KMBnxqtbpm9vzorXYMBkK4YV427l5aIPdxSMHG1lL4cfCMPIM4edMze1pYOqqFGT0Agx7SEKmLy/FBd+y3UqUaGQ3hB2+0A4jc8qj5NydKvPFrKeSY2SOKItqj05jLuYJixqQBhWqeyhyb0aPieh6AQQ9pyPL5OahalItAKIzP7H4TrT0Dch9pUmf7BvFXz7WgdyCAYms6PnHzfLmPRCoQW0vxQWfSg/regQAG/EEYhEgbPc2MVNPT7fXL2oE3F7EZPbzpIVKO735hDZYWZaHL68cju97CqS7ltLAHQ2HseqUVD/y/V/H6mT6YTQb880M3IsXI/wzp+m4usWDNolyMjIbxpWffRo8veUWxUmprgTWdi3BnQWpZD4TCuDykjD1qM6WFGT0Agx7SmIJsM57fchuWz89B74Afn9n9Fj6Qsc1X8n5HPx7+zuto+P0JjIyGcXtFHv74tbvwwIp5ch+NVEIQBDzzhTVYlJeB8+5hfPkHhzDgT85aA+lmiesnZsdsMsKWmQpAvXU9TG8RKVRelhnPb7kVK4stcA8G8Lm9b+H9jn5ZzjIcCOHff/chHv7O6zh+0QtLegp21t6Mnzx+KwtCacYKss147strkZeZivc7vHjix0cQCCa+m2tsRg9TW7NVmK3uxaOxwYTZ6t2wDjDoIY2yZqTix4/fitULrfAMjeKze97C0XOXk3qG10734oH/9yp2v+pCKCzikzfPh+PJu7G5qpSFyzRrZfmZePbRaqSnGHHwdC++/sK7Ca8T4aLRuZMG+qkx6BFFcSy9xZseImWypKfgh4+tRXVZLnwjQXzxe4dwuN2d8K97eTCAf2h8B1/43ts45x7CfEsavveXVfivz1WiQOW/JZEy3FJqxX9/oRJGg4D9Rzuw848nE/r12mKdWwx6ZqsoW70DCr3DQfijN4pqXkEBMOghjctOS8EPvrwWH7HnYcAfxJeePYQ3W/sS8rVEUcQvj3Wg5luv4AXnBQgC8OjtZTjw5N1Yt7woIV+T9OveZYX4xoaVAIDvvtyK56IjEOJNFEWc5YyeOZNqYdTYti6d2ZqRovq9awx6SPMyzSY8+2g17lySj6FACF/+wSG8djq+A94uXB7Cl3/Qgr/72TH0DQawtCgLLzxxO/71L1Ygy2yK69cikmyqKsU/3r8UAPCvvz6O3713Ke5fo8fnx1AgFGlXz2VNz2xJs3q6VRz0qL1zC2DQQzqRnmrEni9V4d5lBRgZDeOx51rw0snuOX9efzCEZ19rw/3/8SpePtmDVKMB/7B+KX7z1TtRuTA3Dicnura/vncxvnjbIogi8LV9x/C2K743mVLnVkluBlJNfMmYrdjSURUGPV396t+uLuF3MOlGWooRz3xxDdbfWIRAMIytPzyCAx90zfjzdHiG8ZO3z+Lx5w5j9f86gP/1mw8wFAhhbZkNv/u7O/HVdUv44kBJIwgC/vUvVuCBFZHv68d/eBgnO+M3n4rrJ+JDzUtHtXTTw3t30hWzyYj//nwlvvazY/jte5fwxI+P4D8/uxoPrpx6KvJoKIwjZy/jpZPdePlED05eMfCwKMeMv123BJ+tXgiDgV1ZlHxGg4Bvf2Y1vrD3bRw+exmPfv8QXnjidiywps/5c8eKmPOY2poLKejpHfBjNBRW1VBSrczoARj0kA6lGA349mdWwWQU8MtjF/E3zx/Ft0JhPLyqOPaYbt8IXj7Zg5dPduPgqV74xg2BMwjA6oW5uHdZAe5ZVogb5+cw2CHZpaUYsfcvq1D7zJs40z2AR79/CE1bb4clI2VOn3dsRg9veuYiLzMVRoOAUFhE74Af8y1zD0iTZSy9pf7uUwY9pEsmowHf2rwKKUYDmo9cwN/vO4bO/hEM+oN46WQP3rtimKEtMxV3Ly3APcsKcNeSAuRGp6sSKYk1IxXPPbYWG/77dZzqGsCWHx3GDx9bO6eOG6a34sNgEFCYbcal/hF09o+oK+jxMb1FpHpGg4CdG29GilHA84fOo+H3JyZ8/OYSC+5ZVoh7lxXg5hIrjLzNIRUotqbjucfWYtN338ShNjeebDyG//xs5ay+f8NhMRb0lHMw4ZwV5aThUv+I6up6Ovsj59VCITODHtI1g0HA//nUSmSnpeDnRzuwttyGe5cV4u6lBRwkSKp1w7wc7P5SFf7y2UP43XudKMz+AP/y0I0zngTe5RvByGgYJoOAklz13EwolZQeUtNU5tFQGH2DkaBH7dOYAQY9RDAYBPzTx5fjnz6+XO6jEMXNRyry8K1HbsFXnz+KH7zRDkt6Cj6zthRF2WnTrkEba1dPh0lFhbdKNS9Hfasoun1+iCKQYhRgy1B/Wp9BDxGRRn3y5gXo9vrxv37zAb7959P49p9PI8UooNiajpLcDJTkpqMkNx2lNumfM1CQZY4FRe3Rzi3W88RHoQpn9Ug7twpnECwrGYMeIiINe+yOcoTCIn701llc9AxjNCSivW8I7X1Dkz4+1WRAiTUdxbnp6B0IAOCi0XiRbnq6VVTTI91KaSG1BTDoISLSvC132bHlLjtCYRGd3hFccA/hwuVhnL8c+d8Ll4dw3j2MS/3DCATDcPUOwhVNbQHAkqIsGU+vHUUqvunRQrs6wKCHiEg3jIZIaqvYmo5bJ/n4aCiMzv6RCQFROCzi06uLJ3k0zdQ8i/oKmaWzaqFzC2DQQ0REUSlGA0ptGSi1ZeAjyJP7OJoj1fT4RoIYCgSRkar8l+AuDa2gALh7i4iIKCmyzSZkpEYGRaplVk+nxmp6GPQQERElgSAIY3U9/epIcUnBmVbSWwx6iIiIkkQa8njePXn3nJKIohgLzpjeIiIiohmR2v/b+gav80j5eUeCGB4NAeBNDxEREc2QNOixvVf5QY9UxJyTZkJ66uyX1ioJgx4iIqIkKcvLADC24kPJYqktjRQxAwx6iIiIkka66TnbNwRRFGU+zbVpbUYPwKCHiIgoaUpzM2AQgOHRkOLb1rU2owdg0ENERJQ0qSYDSnLVkeLS2owegEEPERFRUsWKmRXewdXZr60ZPQCDHiIioqQqjxYzK72Di+ktIiIimhPppofpreRj0ENERJRE4zu4lGo0FEbvQCS9VZhjlvk08cOgh4iIKInK88ZqesJhZbat9/j8EEXAZBCQn8mgh4iIiGahJDcdJoMAfzAcSyEpjVTPU5hthsEgyHya+DHJfYDrcblcaG5uht1uh8vlQl1dHaxW65SPdzgccLlcsNvtAICampoknZSIiOj6TEYDSm0ZaOsdRHvvIBZY0+U+0lVigwk1VM8DqCDo2bRpE44cOQIgEgBt2bIFTU1Nkz7W4XCgqakJu3btgsvlwvr169Ha2prM4xIREV1XWV4k6GnrG8Tti/PlPs5V2qP1RtJMIa1QdNDjcrkmvG232+FwOKZ8/NatW2MBkt1ux4EDBxJ6PiIiotkoy88ETvYotm39dNcAAGBpYZbMJ4kvRdf0OBwO2Gy2Ce+z2WxwOp1XPdblcsHtdsNqtcLpdMLj8cRSXEREREpSHmtbV2YH15luHwBgSRGDnqTxeDyTvt/tdl/1PqfTCZvNFqv/2b17N5qbm6/5+f1+P7xe74Q/REREiVaWp9ypzKIo4nR35KZncWG2zKeJL0Wnt6YyWTDkdrvhcrlQU1MDq9WKuro65ObmXnOLbUNDA/7t3/4tgSclIiK6mnTTc65vCKGwCKOCOqQu9o9gKBBCilHAojzW9MzZ7t27r1lgvH79+ljwcuWtjpTCupLdbofVao19TPpfp9OJysrKSb/O9u3b8eSTT8be9nq9KC0tndm/DBER0QwtsKYj1WhAIBTGRc8wSm3KCS5Od0VSW2V5mUgxKjohNGOyBD11dXXTelxNTQ127dp11furqqquet9s6nfMZjPMZu0MXSIiInUwGgSU2tLR2jOI9r5BRQU9Z6KpLa3V8wAKr+m5MpBxuVyoqqqacIsjdXjZ7XZUVVXFUl/SrJ6pbnmIiIjkJKW4lNbBJXVuaa2eB1BBTU9TUxPq6+tRXV2NlpaWCTN6GhoaUF1djW3btk147Jo1a3DkyBG2rBMRkWItylNmB9dpqXNLY+3qgAqCHrvdjh07dgAAamtrJ3zsyiGFVqt10nQYERGR0kiLR5XUwTW+c4vpLSIiIoqL2OJRBaW3un1++EaCMAhj6TctYdBDREQkg7L8SPHyOfcQgqGwzKeJkOp5yvIyYTYZZT5N/DHoISIiksECSzpSTQYEwyI6PMNyHwfAWD3PYg3W8wAMeoiIiGRhMAhYFG1VlxZ8yk3L9TwAgx4iIiLZlCmsbf1MNL21RIPt6gCDHiIiItmMLR6VP+gRRRGnmN4iIiKiRFDS4tG+wQA8Q6MQBKCigEEPERERxZHUwaWE9JbUuVWam4H0VO11bgEMeoiIiGQjpbfOXx7GqMxt62c0PIlZwqCHiIhIJkXZaUhLMSAUFnHhsrxt61Ln1mKNdm4BDHqIiIhkYzAIY3U9Mqe4YtvVNdq5BTDoISIiklVZnjI6uGIzepjeIiIiokRQwuJRz1AAPT4/AKCCQQ8RERElQnm0g0vOmx4ptVVsTUeW2STbORKNQQ8REZGMlDCrJ1bErOFbHoBBDxERkayktvWOy8MIBOVpWz/dpf16HoBBDxERkawKss3ISDUiLALn3PIsHpW2q2t10aiEQQ8REZGMBEHAIpnb1s8wvUVERETJIBUzy1HX4xsZxaX+EQDA4gLtzugBGPQQERHJTs5iZumWpzDbDEtGStK/fjIx6CEiIpJZbFZPb/JremJDCTVezwMw6CEiIpKd1MElx6wePayfkDDoISIikpmU3rrYP4yR0VBSv/bprkjnltaLmAEGPURERLLLz0pFltkEUQTOJ7ltXQ87tyQMeoiIiGQmCALKZFhHMRQI4sLlYQDAkiKmt4iIiCgJ5Ojgau2OfK28zFTYMlOT9nXlwqCHiIhIAcaKmZOX3pImMeuhngdg0ENERKQIZTJMZdZTuzrAoIeIiEgRYrN6kpjeGls0qv16HoBBDxERkSJI6a1L/SMYDiSnbf2MtGiU6S0iIiJKltyMFOSkmQAAZ92Jv+0ZGQ3FtrovZnqLiIiIkkUQhNhtTzLqetp6BxEWAUt6CgqyzAn/ekrAoIeIiEghypLYwTV+KKEgCAn/ekrAoIeIiEghktnBdSa6fkIvnVsAgx4iIiLFiM3qSUIHl3TTs1gnnVsAgx4iIiLFWJQXWUVxNolBj146twAGPURERIoh3fR0ef0YCgQT9nUCwXAshcb0FhERESWdNSMV1owUAEB7AouZz/YNIhgWkWU2YV5OWsK+jtIw6CEiIlKQZCweHavn0U/nFsCgh4iISFHGFo8mMOjpGgt69IRBDxERkYIko239tM7WT0gY9BARESlIWX6kgyuR6a0zOtuuLmHQQ0REpCDlCZ7KHAyF4eqJdm7paEYPwKCHiIhIUaRVFL0DfvhGRuP++c+5hxAIhZGWYkCxNT3un1/JGPQQEREpSE5aCvIyUwEAZ/vif9szvnPLYNBP5xbAoIeIiEhxyhLYwRWr59FZagtg0ENERKQ4iezgOh1dNKq3dnWAQQ8REZHilEc7uBKxeFSPO7ckDHqIiIgURkpvxfumJxQWx7WrM71FREREMhtbRRHfQuaOy8PwB8NINRlQmquvzi2AQQ8REZHiSDc97sEA+ofj17YuTWK252fCZNRfCKC/f2MiIiKFyzKbUJBtBhDfFNdpHae2AAY9REREilSegG3rZ3RcxAww6CEiIlKkRXnRHVxxXEeh584tgEEPERGRIsU6uOJ00yOKIs5EZ/TobdGoxCT3Aa7H5XKhubkZdrsdLpcLdXV1sFqtUz7W4XDAZrPB5XKhtrYWdrs9uQcmIiKKg/I4T2W+1D+CwUAIJoOARdHUmd4oPujZtGkTjhw5AiAS1GzZsgVNTU2TPra5uRnbtm2Lvb1161bs2rUrKeckIiKKp7I41/RIqa3y/Eyk6LBzC1B4esvlck142263w+FwTPn4ffv2JfpIRERESVEWncrsGRqFZygw5893WuepLUDhQY+UqhrPZrPB6XRO+nibzYY1a9bE0lzr169PxjGJiIjiLiPVhKKcSNt6PFJcZ2Lb1fXZrg4oPOjxeDyTvt/tdk/6fintVVFRgaamJtTW1l7z8/v9fni93gl/iIiIlCKeKS69d24BCg96pjJVMORwOLBjxw7s2rULu3fvxtatW6/5eRoaGmCxWGJ/SktLE3BaIiKi2RkrZp5b27ooikxvQaZC5t27d6O1tXXKj69fvx41NTWwWq1X3eq43e5Ju7dcLhdaWlqwY8cOAEBNTQ3WrFmD+vr6KTu4tm/fjieffDL2ttfrZeBDRESKEa/Foz0+P7wjQRiEsUBKj2QJeurq6qb1uJqamkm7r6qqqq56n9PpRHV1dextu92O7du3T3krBABmsxlms3laZyEiIkq2eKW3pNTWorxMmE3GOZ9LrRSd3rryhsblcqGqqip20+N0OmMdXpWVlWhpaZnw+L6+PlRWViblrERERPE2flaPKIqz/jxSamuxjut5ABXM6WlqakJ9fT2qq6vR0tIyYUZPQ0MDqqursW3bNtjtdqxfvx47d+6MBUXXq+khIiJSMmkVhW8kCPdgAHlZs8tOsIg5QvFBj91uj9XpXNmNdeWQwpqaGtTU1CTtbERERImUlmLEAksaLvaPoL1vcO5Bj46LmAGFp7eIiIj0riwOHVxj29X1O6MHYNBDRESkaHPt4Oob8MM9GIAgABUFvOkhIiIihSqfYweXlNoqyU1Heqp+O7cABj1ERESKFrvpmWPQo/fUFsCgh4iISNHKo4tH23uHZtW2fkaaxKzzzi2AQQ8REZGileRmQBCAAX8QvQMz37Z+OrZolEEPgx4iIiIFi7StpwOYXYprrF2d6S3Fz+khIiLSu/L8THR4hvGl7x3C0qIsLCnKxrKibCydF/nfohwzBEG46u/1D42ix+cHwJsegEEPERGR4m2oLEZLuxvDoyG8c6Ef71zon/Dx7DTThCBoSVEWlhVlx26GFljSkGXmSz6fASIiIoXbUFmCv7hlAc66h3Cq04eTXT6c7hrAyS4f2noH4RsJ4vDZyzh89vKEv5eeEmlRX8zUFgAGPURERKpgMhpQUZCFioIsPLhyfuz9/mAIrp5BnOry4VSXDyc7B3Cqy4dz7iEMj4YAAKtLrTKdWlkY9BAREamY2WTE8vk5WD4/Z8L7hwJBnOkeQO+AH7dX5Mt0OmVh0ENERKRBGakm3FxilfsYisKWdSIiItIFBj1ERESkCwx6iIiISBcY9BAREZEuMOghIiIiXWDQQ0RERLrAoIeIiIh0gUEPERER6QKDHiIiItIFBj1ERESkCwx6iIiISBcY9BAREZEuMOghIiIiXeCW9XFEUQQAeL1emU9CRERE0yW9bkuv41Nh0DOOz+cDAJSWlsp8EiIiIpopn88Hi8Uy5ccF8XphkY6Ew2FcvHgR2dnZEAQhbp/X6/WitLQU58+fR05OTtw+L03E5zk5+DwnD5/r5ODznByJfJ5FUYTP58OCBQtgMExducObnnEMBgNKSkoS9vlzcnL4H1QS8HlODj7PycPnOjn4PCdHop7na93wSFjITERERLrAoIeIiIh0gUFPEpjNZvzLv/wLzGaz3EfRND7PycHnOXn4XCcHn+fkUMLzzEJmIiIi0gXe9BAREZEuMOghIiIiXWDQQ0RERLrAOT1x4nK50NzcDLvdDpfLhbq6Olit1jk/liaayXPndDrhcDgAAC0tLdizZw+f5xmY7fdpfX09tm/fzud6mmb6PDscDrhcLtjtdgBATU1Nkk6qbjP9Ge1wOGCz2eByuVBbWxt7vunanE4ntmzZgiNHjlzzcbK9DooUF5WVlbF/bm1tFWtra+PyWJpoJs/djh07Jvzz+L9L1zeb79MjR46IAMTLly8n8GTaMpPn+cCBA2JdXV3ssXa7PeHn04rZ/uwQRTH2nNO1NTU1xX4GXI9cr4NMb8WBy+Wa8Lbdbo/dMMzlsTTRTJ47p9OJhoaG2Nu1tbVwOp1XfQ6a3Gy/T8ffQND1zfR53rp1K3bs2BF77IEDBxJ6Pq2Y6fO8b9++RB9Jk2pra1FZWXndx8n5OsigJw6ka9DxbDYbnE7nnB5LE83kuausrMSePXtib3s8ntjj6fpm833a3NyM2traRB9NU2byPLtcLrjdblitVjidTng8HgaY0zTT72ebzYY1a9bE0lzr169PxjF1Q87XQQY9cSC9oF7J7XbP6bE00Uyfu/EvwPv27UNNTQ3rTKZpps+1x+PhczsLM3menU4nbDZbrA5i9+7daG5uTvAJtWGm389NTU0AgIqKCjQ1NTGYjzM5XwdZyJxAU/0fO9fH0kTXe+48Hg+am5uvW1hH1zfVc93Y2Ii6urrkHkbDJnue3W43XC5XLHivq6tDbm4uRM6XnbWpvp8dDgd27NgBl8uFrVu3AgB27dqVxJPpUzJeB3nTEwdWq/WqCFW6hp7LY2mi2T539fX1OHDgAJ/jGZjJc+1wOLB58+YknUxbZvI82+12WK3W2Mek/2Vq/Ppm8jy7XC60tLSgpqYGdXV1aG1tRWNjI+sB40jO10EGPXEwVctoVVXVnB5LE83mudu5cyfq6+tht9vh8Xh4ozZNM32uGxsbsXv3buzevRsulwsNDQ18MZ6GmTzPrN+ZvZk8z06nE9XV1bG37XY7tm/fzp8dcSTn6yCDnji48oeRy+VCVVXVhN/EpN8SrvdYmtpMnmcgUlhbWVkZC3gaGxv5PE/TTJ5r6Tdi6Q8Q6TKaTheH3s30Z0dVVVXsxVfqlOPzfH0zeZ4rKyvR0tIy4fF9fX18nmfoyiBRKa+DXDgaJy6XC7t27UJ1dTVaWlomDGfbtGkTqqursW3btus+lq5tus+zy+VCRUXFhL9rtVpx+fJlGU6tTjP5ngYiP+R2796N+vp61NXVMfCZppk8zx6PB/X19VizZg2OHDkSu8Wk65vJ8+xwOOB0OmMfr6mp4fM8DQ6HAwcOHMDOnTuxbds2VFdXx4rAlfI6yKCHiIiIdIHpLSIiItIFBj1ERESkCwx6iIiISBcY9BAREZEuMOghIiIiXWDQQ0RERLrAoIeIiIh0gUEPERER6QKDHiIiItIFBj1ERESkCwx6iIiISBdMch+AiCiRXC4XHA4HWltbsXXrVjidTi76JdIp3vQQkaY5HA7U1dVh/fr12LRpE2pra9Hc3Ay32y330YgoyXjTQ0SatnnzZgCA0+nEI488AgBobW2V80hEJBPe9BCRpkkprH379qG2thYA4PF45DsQEcmGQQ8Radbu3btRX18Pp9MJl8sFu90OAGhsbJT5ZEQkB0EURVHuQxARJYLD4YDL5YLNZoPVaoXL5QIA1NXVyXwyIpIDgx4iIiLSBaa3iIiISBcY9BAREZEuMOghIiIiXWDQQ0RERLrAoIeIiIh0gUEPERER6QKDHiIiItIFBj1ERESkCwx6iIiISBcY9BAREZEuMOghIiIiXfj/AbxproOQ7KTaAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "plt.plot(x_mesh_avg.cpu(), v[0][9].detach().cpu().numpy())\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel(r'$u(x, t_9)$')"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ass2195Bewfx",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 463
        },
        "outputId": "e8ca3c02-7885-4391-ff5d-ce449e82a0a6"
      },
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0, 0.5, '$u(x, t_9)$')"
            ]
          },
          "metadata": {},
          "execution_count": 304
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "plt.plot(x_mesh_avg.cpu(), out[0][9].detach().cpu().numpy())\n",
        "plt.xlabel('$x$')\n",
        "plt.ylabel(r'$u(x, t_9)$')"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Get number of model parameters\n",
        "total_params = sum(p.numel() for p in modelNN.parameters())\n",
        "print(f\"Number of parameters: {total_params}\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "qab5ziax6Xjq",
        "outputId": "96766a1f-d7cd-478c-aabc-803bfba492ca"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Number of parameters: 21120\n"
          ]
        }
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}