{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "# 1D Spectral Convolution\n",
    "# -----------------------------\n",
    "class SpectralConv1d(nn.Module):\n",
    "    \"\"\"\n",
    "    1D Fourier layer: FFT -> multiply low modes -> iFFT.\n",
    "    Uses full complex FFT (fft/ifft) for simplicity.\n",
    "    Input:  (B, C_in, N)\n",
    "    Output: (B, C_out, N)\n",
    "    \"\"\"\n",
    "    def __init__(self, in_channels, out_channels, modes):\n",
    "        super().__init__()\n",
    "        self.in_channels = in_channels\n",
    "        self.out_channels = out_channels\n",
    "        self.modes = modes  # number of positive/negative modes to keep\n",
    "\n",
    "        scale = 1.0 / (in_channels * out_channels)\n",
    "        # weights for positive and negative frequencies\n",
    "        self.weights_pos = nn.Parameter(\n",
    "            scale * torch.randn(in_channels, out_channels, modes, dtype=torch.cfloat)\n",
    "        )\n",
    "        self.weights_neg = nn.Parameter(\n",
    "            scale * torch.randn(in_channels, out_channels, modes, dtype=torch.cfloat)\n",
    "        )\n",
    "\n",
    "    @staticmethod\n",
    "    def compl_mul1d(input, weights):\n",
    "        \"\"\"\n",
    "        input:  (B, C_in, K)\n",
    "        weights:(C_in, C_out, K)\n",
    "        output: (B, C_out, K)\n",
    "        \"\"\"\n",
    "        return torch.einsum(\"bik, iok -> bok\", input, weights)\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        x: (B, C_in, N)\n",
    "        \"\"\"\n",
    "        B, C, N = x.shape\n",
    "        # Full complex FFT\n",
    "        x_ft = torch.fft.fft(x, dim=-1)  # (B, C_in, N)\n",
    "\n",
    "        # Allocate output in Fourier domain\n",
    "        out_ft = torch.zeros(\n",
    "            B, self.out_channels, N, dtype=torch.cfloat, device=x.device\n",
    "        )\n",
    "\n",
    "        m = min(self.modes, N // 2)  # safety\n",
    "        if m > 0:\n",
    "            # low positive modes: indices [0:m]\n",
    "            out_ft[:, :, :m] = self.compl_mul1d(\n",
    "                x_ft[:, :, :m], self.weights_pos[..., :m]\n",
    "            )\n",
    "            # low negative modes: indices [-m:]\n",
    "            out_ft[:, :, -m:] = self.compl_mul1d(\n",
    "                x_ft[:, :, -m:], self.weights_neg[..., :m]\n",
    "            )\n",
    "\n",
    "        # Back to physical space, take real part\n",
    "        x_out = torch.fft.ifft(out_ft, dim=-1).real  # (B, C_out, N)\n",
    "        return x_out\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "# Simple 1D U-Net\n",
    "# -----------------------------\n",
    "class UNet1d(nn.Module):\n",
    "    \"\"\"\n",
    "    A small 1D U-Net:\n",
    "      enc1 -> pool -> enc2 -> pool -> bottleneck -> up -> dec2 -> up -> dec1\n",
    "    Input/Output: (B, C, N) with N divisible by 4 (128 is fine).\n",
    "    \"\"\"\n",
    "    def __init__(self, channels):\n",
    "        super().__init__()\n",
    "        C = channels\n",
    "\n",
    "        # Encoder\n",
    "        self.enc1 = nn.Sequential(\n",
    "            nn.Conv1d(C, C, kernel_size=3, padding=1),\n",
    "            nn.BatchNorm1d(C),\n",
    "            nn.GELU(),\n",
    "        )\n",
    "        self.pool1 = nn.MaxPool1d(2)  # N -> N/2\n",
    "\n",
    "        self.enc2 = nn.Sequential(\n",
    "            nn.Conv1d(C, C, kernel_size=3, padding=1),\n",
    "            nn.BatchNorm1d(C),\n",
    "            nn.GELU(),\n",
    "        )\n",
    "        self.pool2 = nn.MaxPool1d(2)  # N/2 -> N/4\n",
    "\n",
    "        # Bottleneck\n",
    "        self.bottleneck = nn.Sequential(\n",
    "            nn.Conv1d(C, C, kernel_size=3, padding=1),\n",
    "            nn.BatchNorm1d(C),\n",
    "            nn.GELU(),\n",
    "        )\n",
    "\n",
    "        # Decoder\n",
    "        self.up2 = nn.ConvTranspose1d(C, C, kernel_size=2, stride=2)  # N/4 -> N/2\n",
    "        self.dec2 = nn.Sequential(\n",
    "            nn.Conv1d(2 * C, C, kernel_size=3, padding=1),\n",
    "            nn.BatchNorm1d(C),\n",
    "            nn.GELU(),\n",
    "        )\n",
    "\n",
    "        self.up1 = nn.ConvTranspose1d(C, C, kernel_size=2, stride=2)  # N/2 -> N\n",
    "        self.dec1 = nn.Sequential(\n",
    "            nn.Conv1d(2 * C, C, kernel_size=3, padding=1),\n",
    "            nn.BatchNorm1d(C),\n",
    "            nn.GELU(),\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        x: (B, C, N)\n",
    "        \"\"\"\n",
    "        # Encoder\n",
    "        x1 = self.enc1(x)        # (B, C, N)\n",
    "        p1 = self.pool1(x1)      # (B, C, N/2)\n",
    "\n",
    "        x2 = self.enc2(p1)       # (B, C, N/2)\n",
    "        p2 = self.pool2(x2)      # (B, C, N/4)\n",
    "\n",
    "        # Bottleneck\n",
    "        b = self.bottleneck(p2)  # (B, C, N/4)\n",
    "\n",
    "        # Decoder\n",
    "        u2 = self.up2(b)         # (B, C, N/2)\n",
    "        # Align shapes just in case of off-by-one (should not happen for N=128)\n",
    "        if u2.shape[-1] != x2.shape[-1]:\n",
    "            u2 = F.interpolate(u2, size=x2.shape[-1], mode=\"linear\", align_corners=False)\n",
    "        d2 = self.dec2(torch.cat([u2, x2], dim=1))  # (B, C, N/2)\n",
    "\n",
    "        u1 = self.up1(d2)        # (B, C, N)\n",
    "        if u1.shape[-1] != x1.shape[-1]:\n",
    "            u1 = F.interpolate(u1, size=x1.shape[-1], mode=\"linear\", align_corners=False)\n",
    "        d1 = self.dec1(torch.cat([u1, x1], dim=1))  # (B, C, N)\n",
    "\n",
    "        return d1\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "# Two-block 1D U-FNO\n",
    "# -----------------------------\n",
    "class UFNO1d(nn.Module):\n",
    "    \"\"\"\n",
    "    1D U-FNO with two spectral + U-Net blocks.\n",
    "    Interface compatible with your train_operator:\n",
    "      input : (B, 1, N)\n",
    "      output: (B, 1, N)\n",
    "    \"\"\"\n",
    "    def __init__(self, n_modes=64, width=64, in_channels=1, out_channels=1):\n",
    "        super().__init__()\n",
    "        self.n_modes = n_modes\n",
    "        self.width = width\n",
    "\n",
    "        # Lift channel dimension: (B, 1, N) -> (B, width, N)\n",
    "        self.fc0 = nn.Linear(in_channels, width)\n",
    "\n",
    "        # Block 1: Spectral + 1x1 conv + U-Net\n",
    "        self.spec1 = SpectralConv1d(width, width, n_modes)\n",
    "        self.w1 = nn.Conv1d(width, width, kernel_size=1)\n",
    "        self.unet1 = UNet1d(width)\n",
    "\n",
    "        # Block 2: Spectral + 1x1 conv + U-Net\n",
    "        self.spec2 = SpectralConv1d(width, width, n_modes)\n",
    "        self.w2 = nn.Conv1d(width, width, kernel_size=1)\n",
    "        self.unet2 = UNet1d(width)\n",
    "\n",
    "        # Projection back to output channels\n",
    "        self.fc1 = nn.Linear(width, width)\n",
    "        self.fc2 = nn.Linear(width, out_channels)\n",
    "\n",
    "        self.act = nn.GELU()\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        x: (B, in_channels=1, N)\n",
    "        \"\"\"\n",
    "        B, C_in, N = x.shape\n",
    "\n",
    "        # Lift to width channels with pointwise linear (across channel dim)\n",
    "        # (B, C_in, N) -> (B, N, C_in) -> (B, N, width) -> (B, width, N)\n",
    "        x = x.permute(0, 2, 1)          # (B, N, C_in)\n",
    "        x = self.fc0(x)                 # (B, N, width)\n",
    "        x = self.act(x)\n",
    "        x = x.permute(0, 2, 1)          # (B, width, N)\n",
    "\n",
    "        # ------- Block 1 -------\n",
    "        x1 = self.spec1(x)              # spectral branch\n",
    "        x2 = self.w1(x)                 # local 1x1 conv branch\n",
    "        x3 = self.unet1(x)              # U-Net branch\n",
    "        x = self.act(x1 + x2 + x3)      # (B, width, N)\n",
    "\n",
    "        # ------- Block 2 -------\n",
    "        x1 = self.spec2(x)\n",
    "        x2 = self.w2(x)\n",
    "        x3 = self.unet2(x)\n",
    "        x = self.act(x1 + x2 + x3)      # (B, width, N)\n",
    "\n",
    "        # Project back to 1 channel\n",
    "        x = x.permute(0, 2, 1)          # (B, N, width)\n",
    "        x = self.act(self.fc1(x))       # (B, N, width)\n",
    "        x = self.fc2(x)                 # (B, N, out_channels)\n",
    "        x = x.permute(0, 2, 1)          # (B, out_channels=1, N)\n",
    "\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "import torch.optim.lr_scheduler as lr_scheduler\n",
    "import matplotlib.pyplot as plt\n",
    "import time\n",
    "\n",
    "\n",
    "\n",
    "def relative_l2_loss(g_pred, Gf):\n",
    "    \"\"\"\n",
    "    Computes relative L2 error: norm(g_pred - Gf) / (norm(Gf) + 1e-8)\n",
    "    \"\"\"\n",
    "    eps = 1e-8\n",
    "    return torch.norm(g_pred - Gf) / (torch.norm(Gf) + eps)\n",
    "\n",
    "def train_operator(\n",
    "    dataset_raw, \n",
    "    model, \n",
    "    num_epochs,\n",
    "    lr,\n",
    "    device,\n",
    "    batch_size=16,\n",
    "    test_dataset_raw=None,  # (NEW) for test data\n",
    "    reduce_on='test',       # which metric to monitor: 'train' or 'test'\n",
    "    factor=0.5,             # factor to reduce LR on plateau\n",
    "    patience=5,             # epochs of no improvement\n",
    "    min_lr=1e-6,            # minimal LR\n",
    "    cooldown=0\n",
    "):\n",
    "    \"\"\"\n",
    "    Train the FNO model with:\n",
    "      1) A 'ReduceLROnPlateau' scheduler that halves LR on plateau.\n",
    "      2) An optional test dataset to compute and print test rel L2 each epoch.\n",
    "      3) Plot both train and test curves at the end.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    dataset_raw : list of dict\n",
    "        Train samples in FNO style: 'f' (1,n), 'Gf' (1,n), 'x' (n,), 'func_type'.\n",
    "    model : torch.nn.Module\n",
    "        The FNO model to train.\n",
    "    num_epochs : int\n",
    "        Number of epochs to train.\n",
    "    lr : float\n",
    "        Initial learning rate for the optimizer.\n",
    "    device : torch.device\n",
    "        CPU/CUDA device.\n",
    "    batch_size : int\n",
    "        Batch size.\n",
    "    test_dataset_raw : list of dict, optional\n",
    "        If provided, used to compute test loss each epoch.\n",
    "    reduce_on : str\n",
    "        Either 'test' or 'train' - which metric to monitor for LR schedule.\n",
    "    factor : float\n",
    "        Multiplicative factor by which LR is reduced on plateau.\n",
    "    patience : int\n",
    "        Number of epochs of no improvement before reducing LR.\n",
    "    min_lr : float\n",
    "        Lower bound on LR.\n",
    "    cooldown : int\n",
    "        Number of epochs to wait after LR is reduced before next reduce.\n",
    "    \"\"\"\n",
    "\n",
    "    model.to(device)\n",
    "\n",
    "    # 1) Prepare training dataset\n",
    "    #    We'll unify to a single resolution from first sample\n",
    "    target_n = dataset_raw[0][\"f\"].shape[-1]\n",
    "    dataset_fixed = [s for s in dataset_raw if s[\"f\"].shape[-1] == target_n]\n",
    "    if len(dataset_fixed) == 0:\n",
    "        raise ValueError(\"No samples with matching resolution found in training.\")\n",
    "\n",
    "    train_inputs = torch.stack([s[\"f\"] for s in dataset_fixed], dim=0)   # (N, 1, n)\n",
    "    train_targets = torch.stack([s[\"Gf\"] for s in dataset_fixed], dim=0) # (N, 1, n)\n",
    "    train_dataset = TensorDataset(train_inputs, train_targets)\n",
    "    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # 2) Prepare test dataset (if any)\n",
    "    test_loader = None\n",
    "    if test_dataset_raw is not None:\n",
    "        # unify resolution as well\n",
    "        test_fixed = [s for s in test_dataset_raw if s[\"f\"].shape[-1] == target_n]\n",
    "        if len(test_fixed) == 0:\n",
    "            print(\"Warning: no test samples with matching resolution found. Test dataset ignored.\")\n",
    "            test_dataset_raw = None\n",
    "        else:\n",
    "            test_inputs = torch.stack([s[\"f\"] for s in test_fixed], dim=0)\n",
    "            test_targets = torch.stack([s[\"Gf\"] for s in test_fixed], dim=0)\n",
    "            test_dataset = TensorDataset(test_inputs, test_targets)\n",
    "            test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "    # 3) Define optimizer + LR scheduler\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(\n",
    "        optimizer,\n",
    "        mode='min',     # we want to minimize loss\n",
    "        factor=factor,  \n",
    "        patience=patience,\n",
    "        threshold=1e-4,\n",
    "        cooldown=cooldown,\n",
    "        min_lr=min_lr,\n",
    "        verbose=True\n",
    "    )\n",
    "\n",
    "    train_losses = []\n",
    "    test_losses = []\n",
    "    start_time = time.time()\n",
    "\n",
    "    model.train()\n",
    "    for epoch in range(num_epochs):\n",
    "        epoch_start = time.time()\n",
    "\n",
    "        # (a) train loop\n",
    "        running_loss = 0.0\n",
    "        for batch_f, batch_Gf in train_loader:\n",
    "            batch_f = batch_f.to(device)\n",
    "            batch_Gf = batch_Gf.to(device)\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            pred_Gf = model(batch_f)  # shape (batch, 1, n)\n",
    "            loss = relative_l2_loss(pred_Gf, batch_Gf)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            running_loss += loss.item() * batch_f.size(0)\n",
    "\n",
    "        epoch_train_loss = running_loss / len(train_dataset)\n",
    "        train_losses.append(epoch_train_loss)\n",
    "\n",
    "        # (b) test loop (if provided)\n",
    "        if test_loader is not None:\n",
    "            model.eval()\n",
    "            test_running_loss = 0.0\n",
    "            with torch.no_grad():\n",
    "                for batch_f, batch_Gf in test_loader:\n",
    "                    batch_f = batch_f.to(device)\n",
    "                    batch_Gf = batch_Gf.to(device)\n",
    "                    pred_Gf = model(batch_f)\n",
    "                    test_loss = relative_l2_loss(pred_Gf, batch_Gf)\n",
    "                    test_running_loss += test_loss.item() * batch_f.size(0)\n",
    "            epoch_test_loss = test_running_loss / len(test_loader.dataset)\n",
    "            test_losses.append(epoch_test_loss)\n",
    "            model.train()\n",
    "        else:\n",
    "            epoch_test_loss = None\n",
    "\n",
    "        # (c) update LR via scheduler\n",
    "        # decide which metric to monitor: train or test\n",
    "        if reduce_on == 'test' and epoch_test_loss is not None:\n",
    "            scheduler.step(epoch_test_loss)\n",
    "        else:\n",
    "            # fallback: train\n",
    "            scheduler.step(epoch_train_loss)\n",
    "\n",
    "        # (d) print progress\n",
    "        epoch_time = time.time() - epoch_start\n",
    "        current_lr = optimizer.param_groups[0]['lr']\n",
    "        if epoch_test_loss is not None:\n",
    "            print(f\"Epoch [{epoch+1}/{num_epochs}] | \"\n",
    "                  f\"Train Loss={epoch_train_loss:.9f} | Test Loss={epoch_test_loss:.9f} | \"\n",
    "                  f\"Time={epoch_time:.2f}s | LR={current_lr:.2e}\")\n",
    "        else:\n",
    "            print(f\"Epoch [{epoch+1}/{num_epochs}] | \"\n",
    "                  f\"Train Loss={epoch_train_loss:.9f} | Time={epoch_time:.2f}s | \"\n",
    "                  f\"LR={current_lr:.2e}\")\n",
    "\n",
    "    total_time = time.time() - start_time\n",
    "    print(f\"\\nTotal training time: {total_time:.2f} seconds\")\n",
    "\n",
    "    # (e) plot train & test\n",
    "    plt.figure()\n",
    "    plt.semilogy(train_losses, label=\"Train Rel L2\")\n",
    "    if test_loader is not None:\n",
    "        plt.semilogy(test_losses, label=\"Test Rel L2\")\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Relative L2 Error\")\n",
    "    plt.legend()\n",
    "    plt.grid()\n",
    "    plt.show()\n",
    "\n",
    "    return model, train_losses, test_losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 1. Dataset conversion (same as before)\n",
    "# ------------------------------------------------------------------\n",
    "def convert_dataset_for_fno(dataset):\n",
    "    \"\"\"\n",
    "    Convert each sample in the dataset to the evaluation format:\n",
    "      - 'x': (n,)\n",
    "      - 'f': (1, n)\n",
    "      - 'Gf': (1, n)\n",
    "      - 'func_type': str\n",
    "    \"\"\"\n",
    "    new_dataset = []\n",
    "    for sample in dataset:\n",
    "        if len(sample) < 4:\n",
    "            raise ValueError(\"Each sample must have (x, f, Gf, func_type).\")\n",
    "        x, f, Gf, func_type = sample[:4]\n",
    "\n",
    "        # Force (1, n)\n",
    "        if f.ndim == 1:\n",
    "            f = f.unsqueeze(0)\n",
    "        if Gf.ndim == 1:\n",
    "            Gf = Gf.unsqueeze(0)\n",
    "\n",
    "        new_dataset.append({\n",
    "            'x': x,\n",
    "            'f': f,\n",
    "            'Gf': Gf,\n",
    "            'func_type': func_type\n",
    "        })\n",
    "    return new_dataset\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 2. Same relative L2 definition as training\n",
    "# ------------------------------------------------------------------\n",
    "def relative_l2_loss(g_pred, Gf, eps: float = 1e-8):\n",
    "    \"\"\"\n",
    "    Same as in the training loop:\n",
    "        ||g_pred - Gf|| / ( ||Gf|| + eps )\n",
    "    Works for any matching shapes.\n",
    "    \"\"\"\n",
    "    return torch.norm(g_pred - Gf) / (torch.norm(Gf) + eps)\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 3. Evaluation with *global* relative L2 per type (matches training)\n",
    "# ------------------------------------------------------------------\n",
    "def evaluate_operator(dataset, model, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Evaluate a 1D operator model (FNO, U-FNO, etc.) on a dataset.\n",
    "\n",
    "    - Feeds inputs with shape (batch=1, channels=1, n), same as training.\n",
    "    - Aggregates numerator and denominator over all samples of a given type:\n",
    "          E_type = sqrt( sum ||err_i||^2 ) / sqrt( sum ||Gf_i||^2 )\n",
    "      This is the dataset-level relative L2, consistent with your training loss\n",
    "      (just with batch_size = 1 instead of 16).\n",
    "\n",
    "    Returns:\n",
    "        type_errors: dict func_type -> relative L2 (float)\n",
    "        overall_error: single relative L2 over the whole dataset\n",
    "    \"\"\"\n",
    "    model.to(device)\n",
    "    model.eval()\n",
    "\n",
    "    eps = 1e-8\n",
    "\n",
    "    # Accumulate squared errors and squared norms\n",
    "    num_total = 0.0\n",
    "    den_total = 0.0\n",
    "    num_by_type = defaultdict(float)\n",
    "    den_by_type = defaultdict(float)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for sample in dataset:\n",
    "            func_type = sample[\"func_type\"]\n",
    "            f = sample[\"f\"]    # (1, n)\n",
    "            Gf = sample[\"Gf\"]  # (1, n)\n",
    "\n",
    "            # Make a batch dimension: (1, 1, n)\n",
    "            if f.ndim == 2:\n",
    "                f_in = f.unsqueeze(0)\n",
    "            elif f.ndim == 3:\n",
    "                f_in = f\n",
    "            else:\n",
    "                raise ValueError(f\"Unexpected f.ndim={f.ndim}, expected 2 or 3.\")\n",
    "\n",
    "            if Gf.ndim == 2:\n",
    "                Gf_in = Gf.unsqueeze(0)\n",
    "            elif Gf.ndim == 3:\n",
    "                Gf_in = Gf\n",
    "            else:\n",
    "                raise ValueError(f\"Unexpected Gf.ndim={Gf.ndim}, expected 2 or 3.\")\n",
    "\n",
    "            f_in = f_in.to(device)   # (1, 1, n)\n",
    "            Gf_in = Gf_in.to(device) # (1, 1, n)\n",
    "\n",
    "            # Forward pass\n",
    "            g_pred = model(f_in)\n",
    "\n",
    "            # Try to coerce output into same shape as Gf_in\n",
    "            if g_pred.shape != Gf_in.shape:\n",
    "                # Common 1D cases: (1, n) or (1, n, 1)\n",
    "                if g_pred.ndim == 2 and g_pred.shape[0] == Gf_in.shape[0]:\n",
    "                    # (1, n) -> (1, 1, n)\n",
    "                    g_pred = g_pred.unsqueeze(1)\n",
    "                elif g_pred.ndim == 3 and g_pred.shape[1] == 1 \\\n",
    "                     and g_pred.shape[-1] == Gf_in.shape[-1]:\n",
    "                    # already (1, 1, n) – fine\n",
    "                    pass\n",
    "                else:\n",
    "                    raise RuntimeError(\n",
    "                        f\"Shape mismatch: g_pred {g_pred.shape}, Gf_in {Gf_in.shape}\"\n",
    "                    )\n",
    "\n",
    "            # Accumulate squared errors and norms\n",
    "            diff = g_pred - Gf_in\n",
    "            num = torch.sum(diff**2).item()\n",
    "            den = torch.sum(Gf_in**2).item()\n",
    "\n",
    "            num_total += num\n",
    "            den_total += den\n",
    "            num_by_type[func_type] += num\n",
    "            den_by_type[func_type] += den\n",
    "\n",
    "    # Compute dataset-level relative L2 per type\n",
    "    type_errors = {}\n",
    "    for ttype in sorted(num_by_type.keys()):\n",
    "        n = num_by_type[ttype]\n",
    "        d = den_by_type[ttype]\n",
    "        err = (n**0.5) / (d**0.5 + eps) if d > 0 else 0.0\n",
    "        type_errors[ttype] = err\n",
    "        print(f\"Function type: {ttype:20s} | Relative L2: {err:.8f}\")\n",
    "\n",
    "    # Overall dataset-level relative L2\n",
    "    overall_error = (num_total**0.5) / (den_total**0.5 + eps) if den_total > 0 else 0.0\n",
    "    print(f\"\\nOverall relative L2 error: {overall_error:.8f}\")\n",
    "\n",
    "    return type_errors, overall_error\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 4. Plotting helper (uses same shapes & loss)\n",
    "# ------------------------------------------------------------------\n",
    "def plot_functions(dataset, model, device=torch.device(\"cpu\"), max_plots=8):\n",
    "    \"\"\"\n",
    "    Plot input f(x), target Gf(x), and model prediction for up to max_plots samples.\n",
    "    Uses the same (1,1,n) input convention and the same relative L2 definition.\n",
    "    \"\"\"\n",
    "    model.to(device)\n",
    "    model.eval()\n",
    "\n",
    "    num_samples = min(len(dataset), max_plots)\n",
    "    num_cols = 4\n",
    "    num_rows = (num_samples + num_cols - 1) // num_cols\n",
    "\n",
    "    plt.figure(figsize=(20, 5 * num_rows))\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for idx in range(num_samples):\n",
    "            sample = dataset[idx]\n",
    "            x = sample[\"x\"]    # (n,)\n",
    "            f = sample[\"f\"]    # (1, n)\n",
    "            Gf = sample[\"Gf\"]  # (1, n)\n",
    "            func_type = sample[\"func_type\"]\n",
    "\n",
    "            # (1,1,n)\n",
    "            if f.ndim == 2:\n",
    "                f_in = f.unsqueeze(0)\n",
    "            else:\n",
    "                f_in = f\n",
    "            if Gf.ndim == 2:\n",
    "                Gf_in = Gf.unsqueeze(0)\n",
    "            else:\n",
    "                Gf_in = Gf\n",
    "\n",
    "            f_in = f_in.to(device)\n",
    "            Gf_in = Gf_in.to(device)\n",
    "\n",
    "            g_pred = model(f_in)\n",
    "            if g_pred.ndim == 2:\n",
    "                g_pred = g_pred.unsqueeze(1)  # (1,1,n)\n",
    "\n",
    "            rel_err = relative_l2_loss(g_pred, Gf_in).item()\n",
    "\n",
    "            # Move to CPU and flatten to (n,)\n",
    "            x_np = x.cpu().numpy()\n",
    "            f_np = f.view(-1).cpu().numpy()\n",
    "            Gf_np = Gf.view(-1).cpu().numpy()\n",
    "            g_pred_np = g_pred.view(-1).cpu().numpy()\n",
    "\n",
    "            plt.subplot(num_rows, num_cols, idx + 1)\n",
    "            plt.plot(x_np, f_np, label=\"Input $f(x)$\", linewidth=2)\n",
    "            plt.plot(x_np, Gf_np, label=\"Target $Gf(x)$\", linestyle=\"--\", linewidth=2)\n",
    "            plt.plot(x_np, g_pred_np, label=\"Pred $g_{pred}(x)$\",\n",
    "                     linestyle=\"-.\", linewidth=2)\n",
    "            plt.xlabel(\"$x$\")\n",
    "            plt.ylabel(\"Value\")\n",
    "            plt.title(f\"{func_type}\\nSample {idx+1}, Rel-L2: {rel_err:.4f}\")\n",
    "            plt.legend()\n",
    "            plt.grid(True)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = convert_dataset_for_fno(torch.load('train_2.pt', weights_only=False))\n",
    "test_data = convert_dataset_for_fno(torch.load('test_2.pt', weights_only=False))\n",
    "sample_data = convert_dataset_for_fno(torch.load('sample_2.pt', weights_only=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "U-FNO1d params: 579,841\n"
     ]
    }
   ],
   "source": [
    "device = 'cuda:1'\n",
    "\n",
    "# 2-block U-FNO, comparable width to your 2-layer FNO (hidden_channels=64)\n",
    "ufno = UFNO1d(\n",
    "    n_modes=128,     # similar to FNO with 128 grid points (half-band)\n",
    "    width=32,       # match hidden_channels of your FNO\n",
    "    in_channels=1,\n",
    "    out_channels=1,\n",
    ").to(device)\n",
    "\n",
    "# quick parameter count comparison\n",
    "def count_params(m):\n",
    "    return sum(p.numel() for p in m.parameters() if p.requires_grad)\n",
    "\n",
    "print(f\"U-FNO1d params: {count_params(ufno):,}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jinlee/kn_mlp/kano/lib/python3.10/site-packages/torch/optim/lr_scheduler.py:62: UserWarning: The verbose parameter is deprecated. Please use get_last_lr() to access the learning rate.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/1000] | Train Loss=0.862110921 | Test Loss=0.370868351 | Time=2.20s | LR=1.00e-03\n",
      "Epoch [2/1000] | Train Loss=0.080315244 | Test Loss=0.085686297 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [3/1000] | Train Loss=0.038772353 | Test Loss=0.058149395 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [4/1000] | Train Loss=0.026133951 | Test Loss=0.083334849 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [5/1000] | Train Loss=0.023636545 | Test Loss=0.051448923 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [6/1000] | Train Loss=0.021662855 | Test Loss=0.057512947 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [7/1000] | Train Loss=0.019621045 | Test Loss=0.060121681 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [8/1000] | Train Loss=0.016832575 | Test Loss=0.056917881 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [9/1000] | Train Loss=0.016071880 | Test Loss=0.051144702 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [10/1000] | Train Loss=0.014839640 | Test Loss=0.038410049 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [11/1000] | Train Loss=0.013308537 | Test Loss=0.042638483 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [12/1000] | Train Loss=0.015011170 | Test Loss=0.089874190 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [13/1000] | Train Loss=0.012114555 | Test Loss=0.041748131 | Time=1.88s | LR=1.00e-03\n",
      "Epoch [14/1000] | Train Loss=0.013312103 | Test Loss=0.105121083 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [15/1000] | Train Loss=0.012173500 | Test Loss=0.043939256 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [16/1000] | Train Loss=0.012158663 | Test Loss=0.035028971 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [17/1000] | Train Loss=0.010250339 | Test Loss=0.043713366 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [18/1000] | Train Loss=0.011643669 | Test Loss=0.043515531 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [19/1000] | Train Loss=0.011822235 | Test Loss=0.034722786 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [20/1000] | Train Loss=0.011480564 | Test Loss=0.053897265 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [21/1000] | Train Loss=0.012198615 | Test Loss=0.047166646 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [22/1000] | Train Loss=0.013338149 | Test Loss=0.035526214 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [23/1000] | Train Loss=0.009315725 | Test Loss=0.044298854 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [24/1000] | Train Loss=0.010149604 | Test Loss=0.035886172 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [25/1000] | Train Loss=0.010402225 | Test Loss=0.081177796 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [26/1000] | Train Loss=0.009777276 | Test Loss=0.047193032 | Time=1.84s | LR=1.00e-03\n",
      "Epoch [27/1000] | Train Loss=0.010531628 | Test Loss=0.060026940 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [28/1000] | Train Loss=0.009478244 | Test Loss=0.036099339 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [29/1000] | Train Loss=0.008811180 | Test Loss=0.034379557 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [30/1000] | Train Loss=0.008046279 | Test Loss=0.045011136 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [31/1000] | Train Loss=0.009379952 | Test Loss=0.038217366 | Time=1.88s | LR=1.00e-03\n",
      "Epoch [32/1000] | Train Loss=0.009029183 | Test Loss=0.042231678 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [33/1000] | Train Loss=0.008809971 | Test Loss=0.058030939 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [34/1000] | Train Loss=0.008930892 | Test Loss=0.051404632 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [35/1000] | Train Loss=0.008561447 | Test Loss=0.034066003 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [36/1000] | Train Loss=0.008406116 | Test Loss=0.035437745 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [37/1000] | Train Loss=0.008369346 | Test Loss=0.043938633 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [38/1000] | Train Loss=0.010011837 | Test Loss=0.040756356 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [39/1000] | Train Loss=0.008368328 | Test Loss=0.048611294 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [40/1000] | Train Loss=0.007369582 | Test Loss=0.039035251 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [41/1000] | Train Loss=0.008022161 | Test Loss=0.036001296 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [42/1000] | Train Loss=0.007098935 | Test Loss=0.042893689 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [43/1000] | Train Loss=0.009005441 | Test Loss=0.037822322 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [44/1000] | Train Loss=0.007276590 | Test Loss=0.042028048 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [45/1000] | Train Loss=0.006795062 | Test Loss=0.035481478 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [46/1000] | Train Loss=0.006845221 | Test Loss=0.036612207 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [47/1000] | Train Loss=0.007869601 | Test Loss=0.039771817 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [48/1000] | Train Loss=0.006761104 | Test Loss=0.038851703 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [49/1000] | Train Loss=0.007822944 | Test Loss=0.036976111 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [50/1000] | Train Loss=0.006813321 | Test Loss=0.049552508 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [51/1000] | Train Loss=0.007571998 | Test Loss=0.042562146 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [52/1000] | Train Loss=0.006332852 | Test Loss=0.039661292 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [53/1000] | Train Loss=0.007037444 | Test Loss=0.035858233 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [54/1000] | Train Loss=0.006322289 | Test Loss=0.040773230 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [55/1000] | Train Loss=0.006688050 | Test Loss=0.036544484 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [56/1000] | Train Loss=0.008370431 | Test Loss=0.039790902 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [57/1000] | Train Loss=0.006003244 | Test Loss=0.045852050 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [58/1000] | Train Loss=0.006209563 | Test Loss=0.046955142 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [59/1000] | Train Loss=0.006311251 | Test Loss=0.042533574 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [60/1000] | Train Loss=0.006158117 | Test Loss=0.051873563 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [61/1000] | Train Loss=0.006533304 | Test Loss=0.035420560 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [62/1000] | Train Loss=0.005478798 | Test Loss=0.039654631 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [63/1000] | Train Loss=0.005625265 | Test Loss=0.042339991 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [64/1000] | Train Loss=0.005881171 | Test Loss=0.057546831 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [65/1000] | Train Loss=0.006839447 | Test Loss=0.036700177 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [66/1000] | Train Loss=0.007488587 | Test Loss=0.041790682 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [67/1000] | Train Loss=0.006003424 | Test Loss=0.041404100 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [68/1000] | Train Loss=0.006434006 | Test Loss=0.037523702 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [69/1000] | Train Loss=0.005549483 | Test Loss=0.042202762 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [70/1000] | Train Loss=0.005521965 | Test Loss=0.053811098 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [71/1000] | Train Loss=0.007156173 | Test Loss=0.036734140 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [72/1000] | Train Loss=0.005459041 | Test Loss=0.035140872 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [73/1000] | Train Loss=0.004976417 | Test Loss=0.035205284 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [74/1000] | Train Loss=0.005442799 | Test Loss=0.038244526 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [75/1000] | Train Loss=0.005210800 | Test Loss=0.037180824 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [76/1000] | Train Loss=0.006046165 | Test Loss=0.037134537 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [77/1000] | Train Loss=0.005862535 | Test Loss=0.034472568 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [78/1000] | Train Loss=0.006481464 | Test Loss=0.033128135 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [79/1000] | Train Loss=0.005356687 | Test Loss=0.036022490 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [80/1000] | Train Loss=0.005343855 | Test Loss=0.035161615 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [81/1000] | Train Loss=0.005126749 | Test Loss=0.037652900 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [82/1000] | Train Loss=0.005339768 | Test Loss=0.034346052 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [83/1000] | Train Loss=0.004801890 | Test Loss=0.039169664 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [84/1000] | Train Loss=0.005688504 | Test Loss=0.040690415 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [85/1000] | Train Loss=0.005602851 | Test Loss=0.036149701 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [86/1000] | Train Loss=0.005858655 | Test Loss=0.038438850 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [87/1000] | Train Loss=0.005283427 | Test Loss=0.037710471 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [88/1000] | Train Loss=0.005119013 | Test Loss=0.034502981 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [89/1000] | Train Loss=0.006011269 | Test Loss=0.036674551 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [90/1000] | Train Loss=0.004897190 | Test Loss=0.036632535 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [91/1000] | Train Loss=0.004603779 | Test Loss=0.039767655 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [92/1000] | Train Loss=0.005428488 | Test Loss=0.036264933 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [93/1000] | Train Loss=0.005556380 | Test Loss=0.034180686 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [94/1000] | Train Loss=0.005042208 | Test Loss=0.035304474 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [95/1000] | Train Loss=0.005491461 | Test Loss=0.036305146 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [96/1000] | Train Loss=0.005546078 | Test Loss=0.037065585 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [97/1000] | Train Loss=0.005653249 | Test Loss=0.037984172 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [98/1000] | Train Loss=0.005197995 | Test Loss=0.046055278 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [99/1000] | Train Loss=0.004699329 | Test Loss=0.037005279 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [100/1000] | Train Loss=0.004531857 | Test Loss=0.035456320 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [101/1000] | Train Loss=0.005216957 | Test Loss=0.036848091 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [102/1000] | Train Loss=0.005683268 | Test Loss=0.035709731 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [103/1000] | Train Loss=0.004773222 | Test Loss=0.035562277 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [104/1000] | Train Loss=0.004687471 | Test Loss=0.040348700 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [105/1000] | Train Loss=0.004425154 | Test Loss=0.036132659 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [106/1000] | Train Loss=0.004294029 | Test Loss=0.037129881 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [107/1000] | Train Loss=0.005763873 | Test Loss=0.036996562 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [108/1000] | Train Loss=0.005149002 | Test Loss=0.034275738 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [109/1000] | Train Loss=0.004791099 | Test Loss=0.037906759 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [110/1000] | Train Loss=0.004732669 | Test Loss=0.040176018 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [111/1000] | Train Loss=0.005593256 | Test Loss=0.036611241 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [112/1000] | Train Loss=0.004762501 | Test Loss=0.045368990 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [113/1000] | Train Loss=0.005975361 | Test Loss=0.040184671 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [114/1000] | Train Loss=0.004427250 | Test Loss=0.036357907 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [115/1000] | Train Loss=0.004241023 | Test Loss=0.032818319 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [116/1000] | Train Loss=0.004162215 | Test Loss=0.036726473 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [117/1000] | Train Loss=0.004066055 | Test Loss=0.038112718 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [118/1000] | Train Loss=0.005600018 | Test Loss=0.065451636 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [119/1000] | Train Loss=0.007921257 | Test Loss=0.037657786 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [120/1000] | Train Loss=0.003950675 | Test Loss=0.037610910 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [121/1000] | Train Loss=0.005019398 | Test Loss=0.034412059 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [122/1000] | Train Loss=0.004704236 | Test Loss=0.037708130 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [123/1000] | Train Loss=0.004477610 | Test Loss=0.039936771 | Time=1.52s | LR=1.00e-03\n",
      "Epoch [124/1000] | Train Loss=0.005855265 | Test Loss=0.041670815 | Time=1.37s | LR=1.00e-03\n",
      "Epoch [125/1000] | Train Loss=0.004850719 | Test Loss=0.037562007 | Time=1.36s | LR=1.00e-03\n",
      "Epoch [126/1000] | Train Loss=0.004251254 | Test Loss=0.039045755 | Time=1.36s | LR=1.00e-03\n",
      "Epoch [127/1000] | Train Loss=0.004322107 | Test Loss=0.036865422 | Time=1.83s | LR=1.00e-03\n",
      "Epoch [128/1000] | Train Loss=0.004368417 | Test Loss=0.037317916 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [129/1000] | Train Loss=0.004162550 | Test Loss=0.037078058 | Time=1.78s | LR=1.00e-03\n",
      "Epoch [130/1000] | Train Loss=0.006668099 | Test Loss=0.037837919 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [131/1000] | Train Loss=0.004187145 | Test Loss=0.037986123 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [132/1000] | Train Loss=0.004108677 | Test Loss=0.034040298 | Time=1.90s | LR=1.00e-03\n",
      "Epoch [133/1000] | Train Loss=0.004456087 | Test Loss=0.037762135 | Time=1.88s | LR=1.00e-03\n",
      "Epoch [134/1000] | Train Loss=0.006215374 | Test Loss=0.055771723 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [135/1000] | Train Loss=0.005588724 | Test Loss=0.037784793 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [136/1000] | Train Loss=0.003689908 | Test Loss=0.038745209 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [137/1000] | Train Loss=0.003901829 | Test Loss=0.038215492 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [138/1000] | Train Loss=0.004399997 | Test Loss=0.039480008 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [139/1000] | Train Loss=0.003798211 | Test Loss=0.037724772 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [140/1000] | Train Loss=0.003725174 | Test Loss=0.039128978 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [141/1000] | Train Loss=0.004453745 | Test Loss=0.041406687 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [142/1000] | Train Loss=0.007692162 | Test Loss=0.037398224 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [143/1000] | Train Loss=0.004796997 | Test Loss=0.043439778 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [144/1000] | Train Loss=0.007662533 | Test Loss=0.039820017 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [145/1000] | Train Loss=0.005448135 | Test Loss=0.037613484 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [146/1000] | Train Loss=0.005087041 | Test Loss=0.035717229 | Time=1.88s | LR=1.00e-03\n",
      "Epoch [147/1000] | Train Loss=0.003557661 | Test Loss=0.037661811 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [148/1000] | Train Loss=0.005562439 | Test Loss=0.036550446 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [149/1000] | Train Loss=0.003630829 | Test Loss=0.037670307 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [150/1000] | Train Loss=0.003809181 | Test Loss=0.036956001 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [151/1000] | Train Loss=0.003651682 | Test Loss=0.037022455 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [152/1000] | Train Loss=0.004856893 | Test Loss=0.039034936 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [153/1000] | Train Loss=0.004342305 | Test Loss=0.037365071 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [154/1000] | Train Loss=0.004920868 | Test Loss=0.040083677 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [155/1000] | Train Loss=0.005990246 | Test Loss=0.035758224 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [156/1000] | Train Loss=0.004114749 | Test Loss=0.040408817 | Time=1.43s | LR=1.00e-03\n",
      "Epoch [157/1000] | Train Loss=0.004045416 | Test Loss=0.038638807 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [158/1000] | Train Loss=0.003660111 | Test Loss=0.037333246 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [159/1000] | Train Loss=0.004512200 | Test Loss=0.036388645 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [160/1000] | Train Loss=0.003534141 | Test Loss=0.035861638 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [161/1000] | Train Loss=0.004749316 | Test Loss=0.044538275 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [162/1000] | Train Loss=0.005003881 | Test Loss=0.036675628 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [163/1000] | Train Loss=0.004211024 | Test Loss=0.037688415 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [164/1000] | Train Loss=0.003713072 | Test Loss=0.035541121 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [165/1000] | Train Loss=0.003860032 | Test Loss=0.036505502 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [166/1000] | Train Loss=0.004980855 | Test Loss=0.036170465 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [167/1000] | Train Loss=0.004404748 | Test Loss=0.038378352 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [168/1000] | Train Loss=0.003987364 | Test Loss=0.037603784 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [169/1000] | Train Loss=0.003625271 | Test Loss=0.036682208 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [170/1000] | Train Loss=0.004385821 | Test Loss=0.044258133 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [171/1000] | Train Loss=0.003684970 | Test Loss=0.038048646 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [172/1000] | Train Loss=0.003714893 | Test Loss=0.036817769 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [173/1000] | Train Loss=0.005046195 | Test Loss=0.036280913 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [174/1000] | Train Loss=0.005438472 | Test Loss=0.037186428 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [175/1000] | Train Loss=0.003706249 | Test Loss=0.036588788 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [176/1000] | Train Loss=0.004708397 | Test Loss=0.037398529 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [177/1000] | Train Loss=0.003619430 | Test Loss=0.035763069 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [178/1000] | Train Loss=0.003352340 | Test Loss=0.037176822 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [179/1000] | Train Loss=0.004192117 | Test Loss=0.045325225 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [180/1000] | Train Loss=0.004820498 | Test Loss=0.039825791 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [181/1000] | Train Loss=0.005078801 | Test Loss=0.035742702 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [182/1000] | Train Loss=0.003514620 | Test Loss=0.035231244 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [183/1000] | Train Loss=0.004250039 | Test Loss=0.035833624 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [184/1000] | Train Loss=0.004505971 | Test Loss=0.035104783 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [185/1000] | Train Loss=0.003525328 | Test Loss=0.036219595 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [186/1000] | Train Loss=0.003151075 | Test Loss=0.037675051 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [187/1000] | Train Loss=0.005404259 | Test Loss=0.046514146 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [188/1000] | Train Loss=0.004232219 | Test Loss=0.037844626 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [189/1000] | Train Loss=0.003957989 | Test Loss=0.036650945 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [190/1000] | Train Loss=0.006608556 | Test Loss=0.038540594 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [191/1000] | Train Loss=0.003574512 | Test Loss=0.036882551 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [192/1000] | Train Loss=0.006920179 | Test Loss=0.042553434 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [193/1000] | Train Loss=0.004863674 | Test Loss=0.038578183 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [194/1000] | Train Loss=0.003939391 | Test Loss=0.037511032 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [195/1000] | Train Loss=0.003730643 | Test Loss=0.035622774 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [196/1000] | Train Loss=0.004469916 | Test Loss=0.040655251 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [197/1000] | Train Loss=0.005069017 | Test Loss=0.036746652 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [198/1000] | Train Loss=0.003482402 | Test Loss=0.037462778 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [199/1000] | Train Loss=0.004358489 | Test Loss=0.037406257 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [200/1000] | Train Loss=0.003465440 | Test Loss=0.036301136 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [201/1000] | Train Loss=0.003656722 | Test Loss=0.036587106 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [202/1000] | Train Loss=0.003449014 | Test Loss=0.036925838 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [203/1000] | Train Loss=0.004043063 | Test Loss=0.037323966 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [204/1000] | Train Loss=0.003611061 | Test Loss=0.037494493 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [205/1000] | Train Loss=0.004319515 | Test Loss=0.041863425 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [206/1000] | Train Loss=0.003949352 | Test Loss=0.038066898 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [207/1000] | Train Loss=0.003529526 | Test Loss=0.036037732 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [208/1000] | Train Loss=0.003495678 | Test Loss=0.037280144 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [209/1000] | Train Loss=0.003719928 | Test Loss=0.037000632 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [210/1000] | Train Loss=0.005165471 | Test Loss=0.039195878 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [211/1000] | Train Loss=0.004466767 | Test Loss=0.045728730 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [212/1000] | Train Loss=0.005456303 | Test Loss=0.035538331 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [213/1000] | Train Loss=0.003874242 | Test Loss=0.040348536 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [214/1000] | Train Loss=0.003638228 | Test Loss=0.036026434 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [215/1000] | Train Loss=0.003268350 | Test Loss=0.037789725 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [216/1000] | Train Loss=0.003360112 | Test Loss=0.037354208 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [217/1000] | Train Loss=0.003412312 | Test Loss=0.035784628 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [218/1000] | Train Loss=0.002399732 | Test Loss=0.037060439 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [219/1000] | Train Loss=0.002147653 | Test Loss=0.036393290 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [220/1000] | Train Loss=0.001929175 | Test Loss=0.037046001 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [221/1000] | Train Loss=0.002142724 | Test Loss=0.036629916 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [222/1000] | Train Loss=0.002689624 | Test Loss=0.038428943 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [223/1000] | Train Loss=0.002268145 | Test Loss=0.036824335 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [224/1000] | Train Loss=0.002386071 | Test Loss=0.037272477 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [225/1000] | Train Loss=0.002093695 | Test Loss=0.036364146 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [226/1000] | Train Loss=0.002074148 | Test Loss=0.036388927 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [227/1000] | Train Loss=0.002154385 | Test Loss=0.037727454 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [228/1000] | Train Loss=0.002252588 | Test Loss=0.037637253 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [229/1000] | Train Loss=0.002727990 | Test Loss=0.038411231 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [230/1000] | Train Loss=0.002400046 | Test Loss=0.036189034 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [231/1000] | Train Loss=0.002023805 | Test Loss=0.036036971 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [232/1000] | Train Loss=0.002281433 | Test Loss=0.035978156 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [233/1000] | Train Loss=0.002068264 | Test Loss=0.036192387 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [234/1000] | Train Loss=0.002072983 | Test Loss=0.036522174 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [235/1000] | Train Loss=0.002285314 | Test Loss=0.036789636 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [236/1000] | Train Loss=0.002082996 | Test Loss=0.036396347 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [237/1000] | Train Loss=0.002508049 | Test Loss=0.037220853 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [238/1000] | Train Loss=0.001956164 | Test Loss=0.035950402 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [239/1000] | Train Loss=0.002011102 | Test Loss=0.036195661 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [240/1000] | Train Loss=0.002186509 | Test Loss=0.037610108 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [241/1000] | Train Loss=0.002167605 | Test Loss=0.036486282 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [242/1000] | Train Loss=0.002155818 | Test Loss=0.033800566 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [243/1000] | Train Loss=0.002544942 | Test Loss=0.036221845 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [244/1000] | Train Loss=0.001903700 | Test Loss=0.036300120 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [245/1000] | Train Loss=0.002674059 | Test Loss=0.036202418 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [246/1000] | Train Loss=0.002315723 | Test Loss=0.036682746 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [247/1000] | Train Loss=0.001970831 | Test Loss=0.036386128 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [248/1000] | Train Loss=0.002211644 | Test Loss=0.037738590 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [249/1000] | Train Loss=0.002744291 | Test Loss=0.037519822 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [250/1000] | Train Loss=0.002038306 | Test Loss=0.036599686 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [251/1000] | Train Loss=0.002025558 | Test Loss=0.036781344 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [252/1000] | Train Loss=0.002304173 | Test Loss=0.037784640 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [253/1000] | Train Loss=0.001939489 | Test Loss=0.036029981 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [254/1000] | Train Loss=0.002496893 | Test Loss=0.037343369 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [255/1000] | Train Loss=0.002146524 | Test Loss=0.036575611 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [256/1000] | Train Loss=0.001891305 | Test Loss=0.036525674 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [257/1000] | Train Loss=0.002175316 | Test Loss=0.035949994 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [258/1000] | Train Loss=0.002405904 | Test Loss=0.035603649 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [259/1000] | Train Loss=0.002716921 | Test Loss=0.035963794 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [260/1000] | Train Loss=0.002173197 | Test Loss=0.035681758 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [261/1000] | Train Loss=0.002272400 | Test Loss=0.035860044 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [262/1000] | Train Loss=0.001895011 | Test Loss=0.035659539 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [263/1000] | Train Loss=0.002086367 | Test Loss=0.036230143 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [264/1000] | Train Loss=0.002222448 | Test Loss=0.036506976 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [265/1000] | Train Loss=0.002217478 | Test Loss=0.036380446 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [266/1000] | Train Loss=0.002450732 | Test Loss=0.036609145 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [267/1000] | Train Loss=0.002354133 | Test Loss=0.037247693 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [268/1000] | Train Loss=0.002317704 | Test Loss=0.036058368 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [269/1000] | Train Loss=0.002271022 | Test Loss=0.037134797 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [270/1000] | Train Loss=0.002026565 | Test Loss=0.036402954 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [271/1000] | Train Loss=0.002308808 | Test Loss=0.039917697 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [272/1000] | Train Loss=0.002821837 | Test Loss=0.036206693 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [273/1000] | Train Loss=0.002035208 | Test Loss=0.037323783 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [274/1000] | Train Loss=0.002280294 | Test Loss=0.038566130 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [275/1000] | Train Loss=0.001988130 | Test Loss=0.037166957 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [276/1000] | Train Loss=0.001972487 | Test Loss=0.036331640 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [277/1000] | Train Loss=0.002022135 | Test Loss=0.036850905 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [278/1000] | Train Loss=0.002078837 | Test Loss=0.036893306 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [279/1000] | Train Loss=0.002003219 | Test Loss=0.036212825 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [280/1000] | Train Loss=0.002448427 | Test Loss=0.037586661 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [281/1000] | Train Loss=0.002371644 | Test Loss=0.036199608 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [282/1000] | Train Loss=0.002041600 | Test Loss=0.035087550 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [283/1000] | Train Loss=0.002037890 | Test Loss=0.034810949 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [284/1000] | Train Loss=0.001894020 | Test Loss=0.035548123 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [285/1000] | Train Loss=0.002219312 | Test Loss=0.037561397 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [286/1000] | Train Loss=0.002543541 | Test Loss=0.036334748 | Time=1.85s | LR=5.00e-04\n",
      "Epoch [287/1000] | Train Loss=0.002099486 | Test Loss=0.035592186 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [288/1000] | Train Loss=0.001411347 | Test Loss=0.036379782 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [289/1000] | Train Loss=0.001360641 | Test Loss=0.035843061 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [290/1000] | Train Loss=0.001419832 | Test Loss=0.036752684 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [291/1000] | Train Loss=0.001335703 | Test Loss=0.036345629 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [292/1000] | Train Loss=0.001245378 | Test Loss=0.036215213 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [293/1000] | Train Loss=0.001439672 | Test Loss=0.035790219 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [294/1000] | Train Loss=0.001378449 | Test Loss=0.036648042 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [295/1000] | Train Loss=0.001807536 | Test Loss=0.036996610 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [296/1000] | Train Loss=0.001329044 | Test Loss=0.036426196 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [297/1000] | Train Loss=0.001334856 | Test Loss=0.035932090 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [298/1000] | Train Loss=0.001378603 | Test Loss=0.036051797 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [299/1000] | Train Loss=0.001296871 | Test Loss=0.035615854 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [300/1000] | Train Loss=0.001292610 | Test Loss=0.037303421 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [301/1000] | Train Loss=0.001464388 | Test Loss=0.035432130 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [302/1000] | Train Loss=0.001487536 | Test Loss=0.035480881 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [303/1000] | Train Loss=0.001364767 | Test Loss=0.035500520 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [304/1000] | Train Loss=0.001294836 | Test Loss=0.036383891 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [305/1000] | Train Loss=0.001455786 | Test Loss=0.035715462 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [306/1000] | Train Loss=0.001280488 | Test Loss=0.036622379 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [307/1000] | Train Loss=0.001319847 | Test Loss=0.036389299 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [308/1000] | Train Loss=0.001540815 | Test Loss=0.036363496 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [309/1000] | Train Loss=0.001419883 | Test Loss=0.035579687 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [310/1000] | Train Loss=0.001375708 | Test Loss=0.035645639 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [311/1000] | Train Loss=0.001378920 | Test Loss=0.036200228 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [312/1000] | Train Loss=0.001462651 | Test Loss=0.035885774 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [313/1000] | Train Loss=0.001580067 | Test Loss=0.036199094 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [314/1000] | Train Loss=0.001336592 | Test Loss=0.037278741 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [315/1000] | Train Loss=0.001393134 | Test Loss=0.035585570 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [316/1000] | Train Loss=0.001436528 | Test Loss=0.035913074 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [317/1000] | Train Loss=0.001435611 | Test Loss=0.036944716 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [318/1000] | Train Loss=0.001252590 | Test Loss=0.036473668 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [319/1000] | Train Loss=0.001284321 | Test Loss=0.035891307 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [320/1000] | Train Loss=0.001335690 | Test Loss=0.036312506 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [321/1000] | Train Loss=0.001450538 | Test Loss=0.035845776 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [322/1000] | Train Loss=0.001304958 | Test Loss=0.035944977 | Time=1.85s | LR=2.50e-04\n",
      "Epoch [323/1000] | Train Loss=0.001470605 | Test Loss=0.036328457 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [324/1000] | Train Loss=0.001079893 | Test Loss=0.035860071 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [325/1000] | Train Loss=0.001007907 | Test Loss=0.035841454 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [326/1000] | Train Loss=0.001141202 | Test Loss=0.035987746 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [327/1000] | Train Loss=0.001070603 | Test Loss=0.035781811 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [328/1000] | Train Loss=0.001031795 | Test Loss=0.037101192 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [329/1000] | Train Loss=0.001040932 | Test Loss=0.035837410 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [330/1000] | Train Loss=0.001130536 | Test Loss=0.036571908 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [331/1000] | Train Loss=0.001016888 | Test Loss=0.036175401 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [332/1000] | Train Loss=0.001065671 | Test Loss=0.036351011 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [333/1000] | Train Loss=0.001081482 | Test Loss=0.036069395 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [334/1000] | Train Loss=0.001034103 | Test Loss=0.035742459 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [335/1000] | Train Loss=0.001026782 | Test Loss=0.036334832 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [336/1000] | Train Loss=0.001111902 | Test Loss=0.036286907 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [337/1000] | Train Loss=0.001204758 | Test Loss=0.035961918 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [338/1000] | Train Loss=0.001100669 | Test Loss=0.035816849 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [339/1000] | Train Loss=0.001178988 | Test Loss=0.036054654 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [340/1000] | Train Loss=0.001034359 | Test Loss=0.036664543 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [341/1000] | Train Loss=0.001038656 | Test Loss=0.037037895 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [342/1000] | Train Loss=0.001102318 | Test Loss=0.036043549 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [343/1000] | Train Loss=0.001087995 | Test Loss=0.036432115 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [344/1000] | Train Loss=0.001008424 | Test Loss=0.036335972 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [345/1000] | Train Loss=0.001076129 | Test Loss=0.036204103 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [346/1000] | Train Loss=0.001069608 | Test Loss=0.036177897 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [347/1000] | Train Loss=0.000997134 | Test Loss=0.036426488 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [348/1000] | Train Loss=0.001090820 | Test Loss=0.036654065 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [349/1000] | Train Loss=0.001035539 | Test Loss=0.036076180 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [350/1000] | Train Loss=0.001043631 | Test Loss=0.036471098 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [351/1000] | Train Loss=0.001063313 | Test Loss=0.036259677 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [352/1000] | Train Loss=0.001025632 | Test Loss=0.036705678 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [353/1000] | Train Loss=0.001040396 | Test Loss=0.036348297 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [354/1000] | Train Loss=0.001085365 | Test Loss=0.036884751 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [355/1000] | Train Loss=0.001009463 | Test Loss=0.036288746 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [356/1000] | Train Loss=0.001010990 | Test Loss=0.036577955 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [357/1000] | Train Loss=0.001087392 | Test Loss=0.036299132 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [358/1000] | Train Loss=0.001082734 | Test Loss=0.036238191 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [359/1000] | Train Loss=0.001141783 | Test Loss=0.036533956 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [360/1000] | Train Loss=0.001068273 | Test Loss=0.036915553 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [361/1000] | Train Loss=0.001147361 | Test Loss=0.036270196 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [362/1000] | Train Loss=0.000967023 | Test Loss=0.035817811 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [363/1000] | Train Loss=0.000983245 | Test Loss=0.036656812 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [364/1000] | Train Loss=0.001027936 | Test Loss=0.035839747 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [365/1000] | Train Loss=0.001008027 | Test Loss=0.036058622 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [366/1000] | Train Loss=0.001019258 | Test Loss=0.036261097 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [367/1000] | Train Loss=0.001193624 | Test Loss=0.035383664 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [368/1000] | Train Loss=0.001115435 | Test Loss=0.035395084 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [369/1000] | Train Loss=0.001075124 | Test Loss=0.035644322 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [370/1000] | Train Loss=0.000999834 | Test Loss=0.035776493 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [371/1000] | Train Loss=0.001031750 | Test Loss=0.036416981 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [372/1000] | Train Loss=0.001029970 | Test Loss=0.035935742 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [373/1000] | Train Loss=0.001140602 | Test Loss=0.036402071 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [374/1000] | Train Loss=0.000999674 | Test Loss=0.035454653 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [375/1000] | Train Loss=0.001002315 | Test Loss=0.036012605 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [376/1000] | Train Loss=0.001026124 | Test Loss=0.037098579 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [377/1000] | Train Loss=0.001077561 | Test Loss=0.035467650 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [378/1000] | Train Loss=0.001011656 | Test Loss=0.036225181 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [379/1000] | Train Loss=0.001006513 | Test Loss=0.036540840 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [380/1000] | Train Loss=0.001087886 | Test Loss=0.036201697 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [381/1000] | Train Loss=0.001011420 | Test Loss=0.036110251 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [382/1000] | Train Loss=0.001003587 | Test Loss=0.036320078 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [383/1000] | Train Loss=0.001067517 | Test Loss=0.036237254 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [384/1000] | Train Loss=0.000982419 | Test Loss=0.035771750 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [385/1000] | Train Loss=0.000974999 | Test Loss=0.035647763 | Time=1.87s | LR=1.25e-04\n",
      "Epoch [386/1000] | Train Loss=0.001033446 | Test Loss=0.034962604 | Time=1.87s | LR=1.25e-04\n",
      "Epoch [387/1000] | Train Loss=0.001144335 | Test Loss=0.035497248 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [388/1000] | Train Loss=0.001136836 | Test Loss=0.036086697 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [389/1000] | Train Loss=0.000983450 | Test Loss=0.036634518 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [390/1000] | Train Loss=0.001090607 | Test Loss=0.036218669 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [391/1000] | Train Loss=0.001033854 | Test Loss=0.035858773 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [392/1000] | Train Loss=0.001004153 | Test Loss=0.036191866 | Time=1.85s | LR=1.25e-04\n",
      "Epoch [393/1000] | Train Loss=0.001100329 | Test Loss=0.036728871 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [394/1000] | Train Loss=0.000867886 | Test Loss=0.036279399 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [395/1000] | Train Loss=0.000846505 | Test Loss=0.036125564 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [396/1000] | Train Loss=0.000872918 | Test Loss=0.036127113 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [397/1000] | Train Loss=0.000898700 | Test Loss=0.036102083 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [398/1000] | Train Loss=0.000887480 | Test Loss=0.036231369 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [399/1000] | Train Loss=0.000891345 | Test Loss=0.036093952 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [400/1000] | Train Loss=0.000895551 | Test Loss=0.036770439 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [401/1000] | Train Loss=0.000872960 | Test Loss=0.036113790 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [402/1000] | Train Loss=0.000916906 | Test Loss=0.035823933 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [403/1000] | Train Loss=0.000864808 | Test Loss=0.035989730 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [404/1000] | Train Loss=0.000863188 | Test Loss=0.036014217 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [405/1000] | Train Loss=0.001028477 | Test Loss=0.036196670 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [406/1000] | Train Loss=0.000843465 | Test Loss=0.036091607 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [407/1000] | Train Loss=0.000820724 | Test Loss=0.036205727 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [408/1000] | Train Loss=0.000963851 | Test Loss=0.036249500 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [409/1000] | Train Loss=0.000881321 | Test Loss=0.035716271 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [410/1000] | Train Loss=0.000893237 | Test Loss=0.036053652 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [411/1000] | Train Loss=0.000908478 | Test Loss=0.035839215 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [412/1000] | Train Loss=0.000863045 | Test Loss=0.035679549 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [413/1000] | Train Loss=0.000923478 | Test Loss=0.036439439 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [414/1000] | Train Loss=0.000896478 | Test Loss=0.035806271 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [415/1000] | Train Loss=0.000893006 | Test Loss=0.035603397 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [416/1000] | Train Loss=0.000878095 | Test Loss=0.035584045 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [417/1000] | Train Loss=0.000873101 | Test Loss=0.036190675 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [418/1000] | Train Loss=0.000924831 | Test Loss=0.035723563 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [419/1000] | Train Loss=0.000980503 | Test Loss=0.035487535 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [420/1000] | Train Loss=0.000875439 | Test Loss=0.035961737 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [421/1000] | Train Loss=0.000893836 | Test Loss=0.035770048 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [422/1000] | Train Loss=0.000882068 | Test Loss=0.036152384 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [423/1000] | Train Loss=0.000891169 | Test Loss=0.035666992 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [424/1000] | Train Loss=0.000868687 | Test Loss=0.035982272 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [425/1000] | Train Loss=0.000871434 | Test Loss=0.035967284 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [426/1000] | Train Loss=0.000857926 | Test Loss=0.036100766 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [427/1000] | Train Loss=0.000869801 | Test Loss=0.036067107 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [428/1000] | Train Loss=0.000917755 | Test Loss=0.035965156 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [429/1000] | Train Loss=0.000914569 | Test Loss=0.035815691 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [430/1000] | Train Loss=0.000874763 | Test Loss=0.035762462 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [431/1000] | Train Loss=0.000878242 | Test Loss=0.035614724 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [432/1000] | Train Loss=0.000870741 | Test Loss=0.036002354 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [433/1000] | Train Loss=0.000923087 | Test Loss=0.035218112 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [434/1000] | Train Loss=0.000907036 | Test Loss=0.035489076 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [435/1000] | Train Loss=0.000897709 | Test Loss=0.035917098 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [436/1000] | Train Loss=0.000913685 | Test Loss=0.035858536 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [437/1000] | Train Loss=0.000945642 | Test Loss=0.035681355 | Time=1.85s | LR=6.25e-05\n",
      "Epoch [438/1000] | Train Loss=0.000883216 | Test Loss=0.035779587 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [439/1000] | Train Loss=0.000803120 | Test Loss=0.035969052 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [440/1000] | Train Loss=0.000814355 | Test Loss=0.035787731 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [441/1000] | Train Loss=0.000820578 | Test Loss=0.035796488 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [442/1000] | Train Loss=0.000802400 | Test Loss=0.036037848 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [443/1000] | Train Loss=0.000853366 | Test Loss=0.036051188 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [444/1000] | Train Loss=0.000808928 | Test Loss=0.035963148 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [445/1000] | Train Loss=0.000841586 | Test Loss=0.035602747 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [446/1000] | Train Loss=0.000808547 | Test Loss=0.035613131 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [447/1000] | Train Loss=0.000875532 | Test Loss=0.035824217 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [448/1000] | Train Loss=0.000803913 | Test Loss=0.035723473 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [449/1000] | Train Loss=0.000801778 | Test Loss=0.035638842 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [450/1000] | Train Loss=0.000829346 | Test Loss=0.035349082 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [451/1000] | Train Loss=0.000911139 | Test Loss=0.035778798 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [452/1000] | Train Loss=0.000831512 | Test Loss=0.035751537 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [453/1000] | Train Loss=0.000850244 | Test Loss=0.035519699 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [454/1000] | Train Loss=0.000829179 | Test Loss=0.035991511 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [455/1000] | Train Loss=0.000792931 | Test Loss=0.035940974 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [456/1000] | Train Loss=0.000830062 | Test Loss=0.035745141 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [457/1000] | Train Loss=0.000809972 | Test Loss=0.035767066 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [458/1000] | Train Loss=0.000784497 | Test Loss=0.035708554 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [459/1000] | Train Loss=0.000812677 | Test Loss=0.035801169 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [460/1000] | Train Loss=0.000828035 | Test Loss=0.036257718 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [461/1000] | Train Loss=0.000817495 | Test Loss=0.035708593 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [462/1000] | Train Loss=0.000827635 | Test Loss=0.035817658 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [463/1000] | Train Loss=0.000920172 | Test Loss=0.035867648 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [464/1000] | Train Loss=0.000826398 | Test Loss=0.036031425 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [465/1000] | Train Loss=0.000836637 | Test Loss=0.035991571 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [466/1000] | Train Loss=0.000809598 | Test Loss=0.036080189 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [467/1000] | Train Loss=0.000829722 | Test Loss=0.035778056 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [468/1000] | Train Loss=0.000789183 | Test Loss=0.035847661 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [469/1000] | Train Loss=0.000820987 | Test Loss=0.035908935 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [470/1000] | Train Loss=0.000860101 | Test Loss=0.035786239 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [471/1000] | Train Loss=0.000844147 | Test Loss=0.036049541 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [472/1000] | Train Loss=0.000809025 | Test Loss=0.035834478 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [473/1000] | Train Loss=0.000800059 | Test Loss=0.035942973 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [474/1000] | Train Loss=0.000832618 | Test Loss=0.035745209 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [475/1000] | Train Loss=0.000841012 | Test Loss=0.035861398 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [476/1000] | Train Loss=0.000867672 | Test Loss=0.035949404 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [477/1000] | Train Loss=0.000844490 | Test Loss=0.035759942 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [478/1000] | Train Loss=0.000771315 | Test Loss=0.035951350 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [479/1000] | Train Loss=0.000797571 | Test Loss=0.035816766 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [480/1000] | Train Loss=0.000795458 | Test Loss=0.036041076 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [481/1000] | Train Loss=0.000779604 | Test Loss=0.036084057 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [482/1000] | Train Loss=0.000817632 | Test Loss=0.035810304 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [483/1000] | Train Loss=0.000807838 | Test Loss=0.035784452 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [484/1000] | Train Loss=0.000834184 | Test Loss=0.036027134 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [485/1000] | Train Loss=0.000806850 | Test Loss=0.035869051 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [486/1000] | Train Loss=0.000806438 | Test Loss=0.036058828 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [487/1000] | Train Loss=0.000835789 | Test Loss=0.035894990 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [488/1000] | Train Loss=0.000807520 | Test Loss=0.035827615 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [489/1000] | Train Loss=0.000843687 | Test Loss=0.036106744 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [490/1000] | Train Loss=0.000763785 | Test Loss=0.035880953 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [491/1000] | Train Loss=0.000795960 | Test Loss=0.035709368 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [492/1000] | Train Loss=0.000803015 | Test Loss=0.036067959 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [493/1000] | Train Loss=0.000824173 | Test Loss=0.035461456 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [494/1000] | Train Loss=0.000784414 | Test Loss=0.035855849 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [495/1000] | Train Loss=0.000796394 | Test Loss=0.035727640 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [496/1000] | Train Loss=0.000851234 | Test Loss=0.036054884 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [497/1000] | Train Loss=0.000809919 | Test Loss=0.035664148 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [498/1000] | Train Loss=0.000794519 | Test Loss=0.035904629 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [499/1000] | Train Loss=0.000791673 | Test Loss=0.035822275 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [500/1000] | Train Loss=0.000789558 | Test Loss=0.036103579 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [501/1000] | Train Loss=0.000829338 | Test Loss=0.035675313 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [502/1000] | Train Loss=0.000784365 | Test Loss=0.035856453 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [503/1000] | Train Loss=0.000791455 | Test Loss=0.035666923 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [504/1000] | Train Loss=0.000876010 | Test Loss=0.035694537 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [505/1000] | Train Loss=0.000816811 | Test Loss=0.036036017 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [506/1000] | Train Loss=0.000784444 | Test Loss=0.035647595 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [507/1000] | Train Loss=0.000880578 | Test Loss=0.035456438 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [508/1000] | Train Loss=0.000833479 | Test Loss=0.035759084 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [509/1000] | Train Loss=0.000838847 | Test Loss=0.035714371 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [510/1000] | Train Loss=0.000792310 | Test Loss=0.035869539 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [511/1000] | Train Loss=0.000817281 | Test Loss=0.035746650 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [512/1000] | Train Loss=0.000796563 | Test Loss=0.035658993 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [513/1000] | Train Loss=0.000795013 | Test Loss=0.035542890 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [514/1000] | Train Loss=0.000816053 | Test Loss=0.035693669 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [515/1000] | Train Loss=0.000817298 | Test Loss=0.035579057 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [516/1000] | Train Loss=0.000769479 | Test Loss=0.035505725 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [517/1000] | Train Loss=0.000825274 | Test Loss=0.035654433 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [518/1000] | Train Loss=0.000784806 | Test Loss=0.036079776 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [519/1000] | Train Loss=0.000785311 | Test Loss=0.035743061 | Time=1.85s | LR=3.13e-05\n",
      "Epoch [520/1000] | Train Loss=0.000848939 | Test Loss=0.035694393 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [521/1000] | Train Loss=0.000784162 | Test Loss=0.036095422 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [522/1000] | Train Loss=0.000789053 | Test Loss=0.035941713 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [523/1000] | Train Loss=0.000784790 | Test Loss=0.035760892 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [524/1000] | Train Loss=0.000824463 | Test Loss=0.035733461 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [525/1000] | Train Loss=0.000861246 | Test Loss=0.035704747 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [526/1000] | Train Loss=0.000742000 | Test Loss=0.035842199 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [527/1000] | Train Loss=0.000784996 | Test Loss=0.035866241 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [528/1000] | Train Loss=0.000718343 | Test Loss=0.035903480 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [529/1000] | Train Loss=0.000754173 | Test Loss=0.035855942 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [530/1000] | Train Loss=0.000760771 | Test Loss=0.035693306 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [531/1000] | Train Loss=0.000746744 | Test Loss=0.035697582 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [532/1000] | Train Loss=0.000755765 | Test Loss=0.036257911 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [533/1000] | Train Loss=0.000759026 | Test Loss=0.035911857 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [534/1000] | Train Loss=0.000751034 | Test Loss=0.035725452 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [535/1000] | Train Loss=0.000762674 | Test Loss=0.035855833 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [536/1000] | Train Loss=0.000784163 | Test Loss=0.035803090 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [537/1000] | Train Loss=0.000777996 | Test Loss=0.035945778 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [538/1000] | Train Loss=0.000810141 | Test Loss=0.035854336 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [539/1000] | Train Loss=0.000763719 | Test Loss=0.035664137 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [540/1000] | Train Loss=0.000761499 | Test Loss=0.035711011 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [541/1000] | Train Loss=0.000784617 | Test Loss=0.035883431 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [542/1000] | Train Loss=0.000780949 | Test Loss=0.035695357 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [543/1000] | Train Loss=0.000733816 | Test Loss=0.035935629 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [544/1000] | Train Loss=0.000754428 | Test Loss=0.036117219 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [545/1000] | Train Loss=0.000779163 | Test Loss=0.035909710 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [546/1000] | Train Loss=0.000813151 | Test Loss=0.035724996 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [547/1000] | Train Loss=0.000746481 | Test Loss=0.035826701 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [548/1000] | Train Loss=0.000748321 | Test Loss=0.035894024 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [549/1000] | Train Loss=0.000749184 | Test Loss=0.035643258 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [550/1000] | Train Loss=0.000758559 | Test Loss=0.035697775 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [551/1000] | Train Loss=0.000757194 | Test Loss=0.036121631 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [552/1000] | Train Loss=0.000788182 | Test Loss=0.036122684 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [553/1000] | Train Loss=0.000766533 | Test Loss=0.035691591 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [554/1000] | Train Loss=0.000791840 | Test Loss=0.035682173 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [555/1000] | Train Loss=0.000786944 | Test Loss=0.035626945 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [556/1000] | Train Loss=0.000753934 | Test Loss=0.035747461 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [557/1000] | Train Loss=0.000791520 | Test Loss=0.035945693 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [558/1000] | Train Loss=0.000764574 | Test Loss=0.035760950 | Time=1.85s | LR=1.56e-05\n",
      "Epoch [559/1000] | Train Loss=0.000775671 | Test Loss=0.035845552 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [560/1000] | Train Loss=0.000774508 | Test Loss=0.035555725 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [561/1000] | Train Loss=0.000748284 | Test Loss=0.035616140 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [562/1000] | Train Loss=0.000721648 | Test Loss=0.035758908 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [563/1000] | Train Loss=0.000857474 | Test Loss=0.035678383 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [564/1000] | Train Loss=0.000740760 | Test Loss=0.035656664 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [565/1000] | Train Loss=0.000772117 | Test Loss=0.035589209 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [566/1000] | Train Loss=0.000752124 | Test Loss=0.035703125 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [567/1000] | Train Loss=0.000733987 | Test Loss=0.035480060 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [568/1000] | Train Loss=0.000782459 | Test Loss=0.035504209 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [569/1000] | Train Loss=0.000745795 | Test Loss=0.035792057 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [570/1000] | Train Loss=0.000750309 | Test Loss=0.035669391 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [571/1000] | Train Loss=0.000760808 | Test Loss=0.035538840 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [572/1000] | Train Loss=0.000744318 | Test Loss=0.035846733 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [573/1000] | Train Loss=0.000728791 | Test Loss=0.035755674 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [574/1000] | Train Loss=0.000822099 | Test Loss=0.035424481 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [575/1000] | Train Loss=0.000748781 | Test Loss=0.035779973 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [576/1000] | Train Loss=0.000761113 | Test Loss=0.035620928 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [577/1000] | Train Loss=0.000753100 | Test Loss=0.035785848 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [578/1000] | Train Loss=0.000749572 | Test Loss=0.035750950 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [579/1000] | Train Loss=0.000739465 | Test Loss=0.035896973 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [580/1000] | Train Loss=0.000745352 | Test Loss=0.035936319 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [581/1000] | Train Loss=0.000757874 | Test Loss=0.035844296 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [582/1000] | Train Loss=0.000731368 | Test Loss=0.035888614 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [583/1000] | Train Loss=0.000754855 | Test Loss=0.035518446 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [584/1000] | Train Loss=0.000740285 | Test Loss=0.035786466 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [585/1000] | Train Loss=0.000753085 | Test Loss=0.036142897 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [586/1000] | Train Loss=0.000771451 | Test Loss=0.035763932 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [587/1000] | Train Loss=0.000754569 | Test Loss=0.035541173 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [588/1000] | Train Loss=0.000810507 | Test Loss=0.035503745 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [589/1000] | Train Loss=0.000808078 | Test Loss=0.035561859 | Time=1.85s | LR=7.81e-06\n",
      "Epoch [590/1000] | Train Loss=0.000720336 | Test Loss=0.035965330 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [591/1000] | Train Loss=0.000736152 | Test Loss=0.035973566 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [592/1000] | Train Loss=0.000774904 | Test Loss=0.035775709 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [593/1000] | Train Loss=0.000740481 | Test Loss=0.036079804 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [594/1000] | Train Loss=0.000778528 | Test Loss=0.035672712 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [595/1000] | Train Loss=0.000743005 | Test Loss=0.035830833 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [596/1000] | Train Loss=0.000771469 | Test Loss=0.036032725 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [597/1000] | Train Loss=0.000725920 | Test Loss=0.035903488 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [598/1000] | Train Loss=0.000718993 | Test Loss=0.035957002 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [599/1000] | Train Loss=0.000795932 | Test Loss=0.035620389 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [600/1000] | Train Loss=0.000780818 | Test Loss=0.035821783 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [601/1000] | Train Loss=0.000740267 | Test Loss=0.035786413 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [602/1000] | Train Loss=0.000747558 | Test Loss=0.035782399 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [603/1000] | Train Loss=0.000799974 | Test Loss=0.035413717 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [604/1000] | Train Loss=0.000774863 | Test Loss=0.035659745 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [605/1000] | Train Loss=0.000793129 | Test Loss=0.035697795 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [606/1000] | Train Loss=0.000728033 | Test Loss=0.035888034 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [607/1000] | Train Loss=0.000763683 | Test Loss=0.035625182 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [608/1000] | Train Loss=0.000729304 | Test Loss=0.035676308 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [609/1000] | Train Loss=0.000723147 | Test Loss=0.035823279 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [610/1000] | Train Loss=0.000761590 | Test Loss=0.035865335 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [611/1000] | Train Loss=0.000747977 | Test Loss=0.035694508 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [612/1000] | Train Loss=0.000855145 | Test Loss=0.035773063 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [613/1000] | Train Loss=0.000756016 | Test Loss=0.035670042 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [614/1000] | Train Loss=0.000744968 | Test Loss=0.035985940 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [615/1000] | Train Loss=0.000760438 | Test Loss=0.035719685 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [616/1000] | Train Loss=0.000759899 | Test Loss=0.036057201 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [617/1000] | Train Loss=0.000727695 | Test Loss=0.035797130 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [618/1000] | Train Loss=0.000743755 | Test Loss=0.035758367 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [619/1000] | Train Loss=0.000801865 | Test Loss=0.035797344 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [620/1000] | Train Loss=0.000739848 | Test Loss=0.035806351 | Time=1.85s | LR=3.91e-06\n",
      "Epoch [621/1000] | Train Loss=0.000751938 | Test Loss=0.035950473 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [622/1000] | Train Loss=0.000727723 | Test Loss=0.035872545 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [623/1000] | Train Loss=0.000712034 | Test Loss=0.035853151 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [624/1000] | Train Loss=0.000737727 | Test Loss=0.035943664 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [625/1000] | Train Loss=0.000748726 | Test Loss=0.035736918 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [626/1000] | Train Loss=0.000720876 | Test Loss=0.035479423 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [627/1000] | Train Loss=0.000735409 | Test Loss=0.035557559 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [628/1000] | Train Loss=0.000764227 | Test Loss=0.036021788 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [629/1000] | Train Loss=0.000813972 | Test Loss=0.035710536 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [630/1000] | Train Loss=0.000724331 | Test Loss=0.035632219 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [631/1000] | Train Loss=0.000751890 | Test Loss=0.035888324 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [632/1000] | Train Loss=0.000750955 | Test Loss=0.035890648 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [633/1000] | Train Loss=0.000756475 | Test Loss=0.035656814 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [634/1000] | Train Loss=0.000781029 | Test Loss=0.035790763 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [635/1000] | Train Loss=0.000743359 | Test Loss=0.035814463 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [636/1000] | Train Loss=0.000755473 | Test Loss=0.035549590 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [637/1000] | Train Loss=0.000723507 | Test Loss=0.035681330 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [638/1000] | Train Loss=0.000737928 | Test Loss=0.035666237 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [639/1000] | Train Loss=0.000730266 | Test Loss=0.035952122 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [640/1000] | Train Loss=0.000716211 | Test Loss=0.036017889 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [641/1000] | Train Loss=0.000820881 | Test Loss=0.035608627 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [642/1000] | Train Loss=0.000734958 | Test Loss=0.035761039 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [643/1000] | Train Loss=0.000720832 | Test Loss=0.035872483 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [644/1000] | Train Loss=0.000713353 | Test Loss=0.035674647 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [645/1000] | Train Loss=0.000726067 | Test Loss=0.035770447 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [646/1000] | Train Loss=0.000726677 | Test Loss=0.035735385 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [647/1000] | Train Loss=0.000721556 | Test Loss=0.035818673 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [648/1000] | Train Loss=0.000786333 | Test Loss=0.035683912 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [649/1000] | Train Loss=0.000754662 | Test Loss=0.035887068 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [650/1000] | Train Loss=0.000703327 | Test Loss=0.036057330 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [651/1000] | Train Loss=0.000778404 | Test Loss=0.035721746 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [652/1000] | Train Loss=0.000742688 | Test Loss=0.035827176 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [653/1000] | Train Loss=0.000757603 | Test Loss=0.035911622 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [654/1000] | Train Loss=0.000736124 | Test Loss=0.035642961 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [655/1000] | Train Loss=0.000758101 | Test Loss=0.035844201 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [656/1000] | Train Loss=0.000732154 | Test Loss=0.035995350 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [657/1000] | Train Loss=0.000719415 | Test Loss=0.035663260 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [658/1000] | Train Loss=0.000732016 | Test Loss=0.035707772 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [659/1000] | Train Loss=0.000730755 | Test Loss=0.035635478 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [660/1000] | Train Loss=0.000716826 | Test Loss=0.035834378 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [661/1000] | Train Loss=0.000737377 | Test Loss=0.035682329 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [662/1000] | Train Loss=0.000701379 | Test Loss=0.035560268 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [663/1000] | Train Loss=0.000726546 | Test Loss=0.035378165 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [664/1000] | Train Loss=0.000738555 | Test Loss=0.035873332 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [665/1000] | Train Loss=0.000710653 | Test Loss=0.035675030 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [666/1000] | Train Loss=0.000753870 | Test Loss=0.035689980 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [667/1000] | Train Loss=0.000722161 | Test Loss=0.035702537 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [668/1000] | Train Loss=0.000739754 | Test Loss=0.035818290 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [669/1000] | Train Loss=0.000724169 | Test Loss=0.035885085 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [670/1000] | Train Loss=0.000721275 | Test Loss=0.035828092 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [671/1000] | Train Loss=0.000812416 | Test Loss=0.035605141 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [672/1000] | Train Loss=0.000724779 | Test Loss=0.036165147 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [673/1000] | Train Loss=0.000739442 | Test Loss=0.035684387 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [674/1000] | Train Loss=0.000776946 | Test Loss=0.035753165 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [675/1000] | Train Loss=0.000776714 | Test Loss=0.036224445 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [676/1000] | Train Loss=0.000736360 | Test Loss=0.035883232 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [677/1000] | Train Loss=0.000847754 | Test Loss=0.035813345 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [678/1000] | Train Loss=0.000742486 | Test Loss=0.035717993 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [679/1000] | Train Loss=0.000729920 | Test Loss=0.035876647 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [680/1000] | Train Loss=0.000795852 | Test Loss=0.035783818 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [681/1000] | Train Loss=0.000722463 | Test Loss=0.035839205 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [682/1000] | Train Loss=0.000768209 | Test Loss=0.035881585 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [683/1000] | Train Loss=0.000746544 | Test Loss=0.035862059 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [684/1000] | Train Loss=0.000714249 | Test Loss=0.035939175 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [685/1000] | Train Loss=0.000730607 | Test Loss=0.035720944 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [686/1000] | Train Loss=0.000733655 | Test Loss=0.035580440 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [687/1000] | Train Loss=0.000772420 | Test Loss=0.035614377 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [688/1000] | Train Loss=0.000772280 | Test Loss=0.035410971 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [689/1000] | Train Loss=0.000756369 | Test Loss=0.035817426 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [690/1000] | Train Loss=0.000737998 | Test Loss=0.035968332 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [691/1000] | Train Loss=0.000740561 | Test Loss=0.035479564 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [692/1000] | Train Loss=0.000775028 | Test Loss=0.035984099 | Time=1.85s | LR=1.95e-06\n",
      "Epoch [693/1000] | Train Loss=0.000715815 | Test Loss=0.035853761 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [694/1000] | Train Loss=0.000760778 | Test Loss=0.035627610 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [695/1000] | Train Loss=0.000731051 | Test Loss=0.035600883 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [696/1000] | Train Loss=0.000775118 | Test Loss=0.035675581 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [697/1000] | Train Loss=0.000750468 | Test Loss=0.035447985 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [698/1000] | Train Loss=0.000732833 | Test Loss=0.035971940 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [699/1000] | Train Loss=0.000749574 | Test Loss=0.035452845 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [700/1000] | Train Loss=0.000720092 | Test Loss=0.035614726 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [701/1000] | Train Loss=0.000743245 | Test Loss=0.035778934 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [702/1000] | Train Loss=0.000734487 | Test Loss=0.035764455 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [703/1000] | Train Loss=0.000736486 | Test Loss=0.035574237 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [704/1000] | Train Loss=0.000719722 | Test Loss=0.035769804 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [705/1000] | Train Loss=0.000724087 | Test Loss=0.035785368 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [706/1000] | Train Loss=0.000723520 | Test Loss=0.035934873 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [707/1000] | Train Loss=0.000756831 | Test Loss=0.035818715 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [708/1000] | Train Loss=0.000739197 | Test Loss=0.035893502 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [709/1000] | Train Loss=0.000785855 | Test Loss=0.035856869 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [710/1000] | Train Loss=0.000753857 | Test Loss=0.035895840 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [711/1000] | Train Loss=0.000736486 | Test Loss=0.035828041 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [712/1000] | Train Loss=0.000751682 | Test Loss=0.035677847 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [713/1000] | Train Loss=0.000724572 | Test Loss=0.035807485 | Time=1.86s | LR=9.77e-07\n",
      "Epoch [714/1000] | Train Loss=0.000713916 | Test Loss=0.035976207 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [715/1000] | Train Loss=0.000782189 | Test Loss=0.035658027 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [716/1000] | Train Loss=0.000725455 | Test Loss=0.035686682 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [717/1000] | Train Loss=0.000750508 | Test Loss=0.035572953 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [718/1000] | Train Loss=0.000765131 | Test Loss=0.035328727 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [719/1000] | Train Loss=0.000717635 | Test Loss=0.035685484 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [720/1000] | Train Loss=0.000717590 | Test Loss=0.035875603 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [721/1000] | Train Loss=0.000707665 | Test Loss=0.035784426 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [722/1000] | Train Loss=0.000696990 | Test Loss=0.036060976 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [723/1000] | Train Loss=0.000733926 | Test Loss=0.035951046 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [724/1000] | Train Loss=0.000712065 | Test Loss=0.035667705 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [725/1000] | Train Loss=0.000780898 | Test Loss=0.035787114 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [726/1000] | Train Loss=0.000803638 | Test Loss=0.035805873 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [727/1000] | Train Loss=0.000734767 | Test Loss=0.035805180 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [728/1000] | Train Loss=0.000720611 | Test Loss=0.035922866 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [729/1000] | Train Loss=0.000729308 | Test Loss=0.035879690 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [730/1000] | Train Loss=0.000726604 | Test Loss=0.036003011 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [731/1000] | Train Loss=0.000731852 | Test Loss=0.035739398 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [732/1000] | Train Loss=0.000751486 | Test Loss=0.035969559 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [733/1000] | Train Loss=0.000706587 | Test Loss=0.035892877 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [734/1000] | Train Loss=0.000720252 | Test Loss=0.035753445 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [735/1000] | Train Loss=0.000717684 | Test Loss=0.035796243 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [736/1000] | Train Loss=0.000714219 | Test Loss=0.035839041 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [737/1000] | Train Loss=0.000821944 | Test Loss=0.035724656 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [738/1000] | Train Loss=0.000758365 | Test Loss=0.035998487 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [739/1000] | Train Loss=0.000753026 | Test Loss=0.035677439 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [740/1000] | Train Loss=0.000735685 | Test Loss=0.035893987 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [741/1000] | Train Loss=0.000744115 | Test Loss=0.036006668 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [742/1000] | Train Loss=0.000713479 | Test Loss=0.035871585 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [743/1000] | Train Loss=0.000734285 | Test Loss=0.035785760 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [744/1000] | Train Loss=0.000708077 | Test Loss=0.035803635 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [745/1000] | Train Loss=0.000717778 | Test Loss=0.035679351 | Time=1.86s | LR=9.77e-07\n",
      "Epoch [746/1000] | Train Loss=0.000711518 | Test Loss=0.035873977 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [747/1000] | Train Loss=0.000709008 | Test Loss=0.035769135 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [748/1000] | Train Loss=0.000723390 | Test Loss=0.035958579 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [749/1000] | Train Loss=0.000722226 | Test Loss=0.035703456 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [750/1000] | Train Loss=0.000703269 | Test Loss=0.035834877 | Time=1.86s | LR=9.77e-07\n",
      "Epoch [751/1000] | Train Loss=0.000702972 | Test Loss=0.036100665 | Time=1.86s | LR=9.77e-07\n",
      "Epoch [752/1000] | Train Loss=0.000737465 | Test Loss=0.035648081 | Time=1.85s | LR=9.77e-07\n",
      "Epoch [753/1000] | Train Loss=0.000735673 | Test Loss=0.035640206 | Time=1.86s | LR=4.88e-07\n",
      "Epoch [754/1000] | Train Loss=0.000718213 | Test Loss=0.035854726 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [755/1000] | Train Loss=0.000715166 | Test Loss=0.036154355 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [756/1000] | Train Loss=0.000727067 | Test Loss=0.035735595 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [757/1000] | Train Loss=0.000743285 | Test Loss=0.035827028 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [758/1000] | Train Loss=0.000722206 | Test Loss=0.035693977 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [759/1000] | Train Loss=0.000707094 | Test Loss=0.035598051 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [760/1000] | Train Loss=0.000720823 | Test Loss=0.035922848 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [761/1000] | Train Loss=0.000738814 | Test Loss=0.035585908 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [762/1000] | Train Loss=0.000731042 | Test Loss=0.035647346 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [763/1000] | Train Loss=0.000731536 | Test Loss=0.035875399 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [764/1000] | Train Loss=0.000719623 | Test Loss=0.035824016 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [765/1000] | Train Loss=0.000714722 | Test Loss=0.035538213 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [766/1000] | Train Loss=0.000712262 | Test Loss=0.035681892 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [767/1000] | Train Loss=0.000762787 | Test Loss=0.035814984 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [768/1000] | Train Loss=0.000764280 | Test Loss=0.035802959 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [769/1000] | Train Loss=0.000741807 | Test Loss=0.035646347 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [770/1000] | Train Loss=0.000721616 | Test Loss=0.035947330 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [771/1000] | Train Loss=0.000700167 | Test Loss=0.035743343 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [772/1000] | Train Loss=0.000728662 | Test Loss=0.035759838 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [773/1000] | Train Loss=0.000767615 | Test Loss=0.035696201 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [774/1000] | Train Loss=0.000724510 | Test Loss=0.035917712 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [775/1000] | Train Loss=0.000722934 | Test Loss=0.035724729 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [776/1000] | Train Loss=0.000739932 | Test Loss=0.035644912 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [777/1000] | Train Loss=0.000731106 | Test Loss=0.036005951 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [778/1000] | Train Loss=0.000730109 | Test Loss=0.035787194 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [779/1000] | Train Loss=0.000744715 | Test Loss=0.035643658 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [780/1000] | Train Loss=0.000723070 | Test Loss=0.035541728 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [781/1000] | Train Loss=0.000730516 | Test Loss=0.035811841 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [782/1000] | Train Loss=0.000746889 | Test Loss=0.035913548 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [783/1000] | Train Loss=0.000731308 | Test Loss=0.036022490 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [784/1000] | Train Loss=0.000714457 | Test Loss=0.035792185 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [785/1000] | Train Loss=0.000719099 | Test Loss=0.035725329 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [786/1000] | Train Loss=0.000731849 | Test Loss=0.035794147 | Time=1.86s | LR=2.44e-07\n",
      "Epoch [787/1000] | Train Loss=0.000718863 | Test Loss=0.035756586 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [788/1000] | Train Loss=0.000753540 | Test Loss=0.035737853 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [789/1000] | Train Loss=0.000705918 | Test Loss=0.035894876 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [790/1000] | Train Loss=0.000773888 | Test Loss=0.035738907 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [791/1000] | Train Loss=0.000725947 | Test Loss=0.035876240 | Time=1.86s | LR=2.44e-07\n",
      "Epoch [792/1000] | Train Loss=0.000732803 | Test Loss=0.035693810 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [793/1000] | Train Loss=0.000727286 | Test Loss=0.035831345 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [794/1000] | Train Loss=0.000700950 | Test Loss=0.035913606 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [795/1000] | Train Loss=0.000779714 | Test Loss=0.036006444 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [796/1000] | Train Loss=0.000706929 | Test Loss=0.036133965 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [797/1000] | Train Loss=0.000715528 | Test Loss=0.035848915 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [798/1000] | Train Loss=0.000776988 | Test Loss=0.035732761 | Time=1.86s | LR=2.44e-07\n",
      "Epoch [799/1000] | Train Loss=0.000717645 | Test Loss=0.035715464 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [800/1000] | Train Loss=0.000741745 | Test Loss=0.035775938 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [801/1000] | Train Loss=0.000725590 | Test Loss=0.035818427 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [802/1000] | Train Loss=0.000740069 | Test Loss=0.035921343 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [803/1000] | Train Loss=0.000719162 | Test Loss=0.035774793 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [804/1000] | Train Loss=0.000712200 | Test Loss=0.035595226 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [805/1000] | Train Loss=0.000746615 | Test Loss=0.035523382 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [806/1000] | Train Loss=0.000752705 | Test Loss=0.035675541 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [807/1000] | Train Loss=0.000745766 | Test Loss=0.035841768 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [808/1000] | Train Loss=0.000701006 | Test Loss=0.035949518 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [809/1000] | Train Loss=0.000730473 | Test Loss=0.035665753 | Time=1.86s | LR=2.44e-07\n",
      "Epoch [810/1000] | Train Loss=0.000718611 | Test Loss=0.035936141 | Time=1.86s | LR=2.44e-07\n",
      "Epoch [811/1000] | Train Loss=0.000730422 | Test Loss=0.035954214 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [812/1000] | Train Loss=0.000738212 | Test Loss=0.036002151 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [813/1000] | Train Loss=0.000764187 | Test Loss=0.035950046 | Time=1.86s | LR=2.44e-07\n",
      "Epoch [814/1000] | Train Loss=0.000734242 | Test Loss=0.035955081 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [815/1000] | Train Loss=0.000706312 | Test Loss=0.036194310 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [816/1000] | Train Loss=0.000758004 | Test Loss=0.035620372 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [817/1000] | Train Loss=0.000726472 | Test Loss=0.036045190 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [818/1000] | Train Loss=0.000720725 | Test Loss=0.035588906 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [819/1000] | Train Loss=0.000710273 | Test Loss=0.035576102 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [820/1000] | Train Loss=0.000743235 | Test Loss=0.036015378 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [821/1000] | Train Loss=0.000736836 | Test Loss=0.035867623 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [822/1000] | Train Loss=0.000712544 | Test Loss=0.035920273 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [823/1000] | Train Loss=0.000730421 | Test Loss=0.035457025 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [824/1000] | Train Loss=0.000745129 | Test Loss=0.035703596 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [825/1000] | Train Loss=0.000711795 | Test Loss=0.035874531 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [826/1000] | Train Loss=0.000778408 | Test Loss=0.035988695 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [827/1000] | Train Loss=0.000725892 | Test Loss=0.035866452 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [828/1000] | Train Loss=0.000716634 | Test Loss=0.035801230 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [829/1000] | Train Loss=0.000745271 | Test Loss=0.035762356 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [830/1000] | Train Loss=0.000700945 | Test Loss=0.035776565 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [831/1000] | Train Loss=0.000712365 | Test Loss=0.036019386 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [832/1000] | Train Loss=0.000730803 | Test Loss=0.035607107 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [833/1000] | Train Loss=0.000754328 | Test Loss=0.035894093 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [834/1000] | Train Loss=0.000713394 | Test Loss=0.035687706 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [835/1000] | Train Loss=0.000705757 | Test Loss=0.036133318 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [836/1000] | Train Loss=0.000691250 | Test Loss=0.035815151 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [837/1000] | Train Loss=0.000743863 | Test Loss=0.035743201 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [838/1000] | Train Loss=0.000715010 | Test Loss=0.035877645 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [839/1000] | Train Loss=0.000748479 | Test Loss=0.035657485 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [840/1000] | Train Loss=0.000727597 | Test Loss=0.035942327 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [841/1000] | Train Loss=0.000734754 | Test Loss=0.035748696 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [842/1000] | Train Loss=0.000711354 | Test Loss=0.035958215 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [843/1000] | Train Loss=0.000708061 | Test Loss=0.035826014 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [844/1000] | Train Loss=0.000734668 | Test Loss=0.035814889 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [845/1000] | Train Loss=0.000736745 | Test Loss=0.035792424 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [846/1000] | Train Loss=0.000708803 | Test Loss=0.035506210 | Time=1.86s | LR=1.22e-07\n",
      "Epoch [847/1000] | Train Loss=0.000728042 | Test Loss=0.035958120 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [848/1000] | Train Loss=0.000746183 | Test Loss=0.035828888 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [849/1000] | Train Loss=0.000716355 | Test Loss=0.035732564 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [850/1000] | Train Loss=0.000710195 | Test Loss=0.035845143 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [851/1000] | Train Loss=0.000738065 | Test Loss=0.035721825 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [852/1000] | Train Loss=0.000759327 | Test Loss=0.035558729 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [853/1000] | Train Loss=0.000743499 | Test Loss=0.035556634 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [854/1000] | Train Loss=0.000720378 | Test Loss=0.035914801 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [855/1000] | Train Loss=0.000759977 | Test Loss=0.035729920 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [856/1000] | Train Loss=0.000742742 | Test Loss=0.035634028 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [857/1000] | Train Loss=0.000719246 | Test Loss=0.035656080 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [858/1000] | Train Loss=0.000729969 | Test Loss=0.035629991 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [859/1000] | Train Loss=0.000713872 | Test Loss=0.035887718 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [860/1000] | Train Loss=0.000719609 | Test Loss=0.035799065 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [861/1000] | Train Loss=0.000744718 | Test Loss=0.035660833 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [862/1000] | Train Loss=0.000742452 | Test Loss=0.035740639 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [863/1000] | Train Loss=0.000727344 | Test Loss=0.035835744 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [864/1000] | Train Loss=0.000720473 | Test Loss=0.035755157 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [865/1000] | Train Loss=0.000731932 | Test Loss=0.035719839 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [866/1000] | Train Loss=0.000746893 | Test Loss=0.035925031 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [867/1000] | Train Loss=0.000748239 | Test Loss=0.036064682 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [868/1000] | Train Loss=0.000718279 | Test Loss=0.035990144 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [869/1000] | Train Loss=0.000726598 | Test Loss=0.035705881 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [870/1000] | Train Loss=0.000782888 | Test Loss=0.035911648 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [871/1000] | Train Loss=0.000716173 | Test Loss=0.035649312 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [872/1000] | Train Loss=0.000748124 | Test Loss=0.035735822 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [873/1000] | Train Loss=0.000742965 | Test Loss=0.036012545 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [874/1000] | Train Loss=0.000781242 | Test Loss=0.035654258 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [875/1000] | Train Loss=0.000739237 | Test Loss=0.035578259 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [876/1000] | Train Loss=0.000717516 | Test Loss=0.035865040 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [877/1000] | Train Loss=0.000724288 | Test Loss=0.035764678 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [878/1000] | Train Loss=0.000717811 | Test Loss=0.035908316 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [879/1000] | Train Loss=0.000744577 | Test Loss=0.035813183 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [880/1000] | Train Loss=0.000715619 | Test Loss=0.035762792 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [881/1000] | Train Loss=0.000721414 | Test Loss=0.035893767 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [882/1000] | Train Loss=0.000748299 | Test Loss=0.035998759 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [883/1000] | Train Loss=0.000758165 | Test Loss=0.035615125 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [884/1000] | Train Loss=0.000826240 | Test Loss=0.035735887 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [885/1000] | Train Loss=0.000747228 | Test Loss=0.035769991 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [886/1000] | Train Loss=0.000739362 | Test Loss=0.035758065 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [887/1000] | Train Loss=0.000749917 | Test Loss=0.035806233 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [888/1000] | Train Loss=0.000754216 | Test Loss=0.035552158 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [889/1000] | Train Loss=0.000742547 | Test Loss=0.035764093 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [890/1000] | Train Loss=0.000782839 | Test Loss=0.035746528 | Time=1.87s | LR=6.10e-08\n",
      "Epoch [891/1000] | Train Loss=0.000739901 | Test Loss=0.035449797 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [892/1000] | Train Loss=0.000712337 | Test Loss=0.035641718 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [893/1000] | Train Loss=0.000732703 | Test Loss=0.035727175 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [894/1000] | Train Loss=0.000718060 | Test Loss=0.035655086 | Time=1.86s | LR=6.10e-08\n",
      "Epoch [895/1000] | Train Loss=0.000694584 | Test Loss=0.035950873 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [896/1000] | Train Loss=0.000705809 | Test Loss=0.035655195 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [897/1000] | Train Loss=0.000719131 | Test Loss=0.035880149 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [898/1000] | Train Loss=0.000750636 | Test Loss=0.035785903 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [899/1000] | Train Loss=0.000711807 | Test Loss=0.035871117 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [900/1000] | Train Loss=0.000725146 | Test Loss=0.035810521 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [901/1000] | Train Loss=0.000703901 | Test Loss=0.036091137 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [902/1000] | Train Loss=0.000710021 | Test Loss=0.035856193 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [903/1000] | Train Loss=0.000728582 | Test Loss=0.035923383 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [904/1000] | Train Loss=0.000768626 | Test Loss=0.035737892 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [905/1000] | Train Loss=0.000779670 | Test Loss=0.035668492 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [906/1000] | Train Loss=0.000742463 | Test Loss=0.035713835 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [907/1000] | Train Loss=0.000798661 | Test Loss=0.035770123 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [908/1000] | Train Loss=0.000794420 | Test Loss=0.035496437 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [909/1000] | Train Loss=0.000725342 | Test Loss=0.036005517 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [910/1000] | Train Loss=0.000693410 | Test Loss=0.035426235 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [911/1000] | Train Loss=0.000705572 | Test Loss=0.035724841 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [912/1000] | Train Loss=0.000706502 | Test Loss=0.035893991 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [913/1000] | Train Loss=0.000738590 | Test Loss=0.035909310 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [914/1000] | Train Loss=0.000716950 | Test Loss=0.035847034 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [915/1000] | Train Loss=0.000720396 | Test Loss=0.035529668 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [916/1000] | Train Loss=0.000762080 | Test Loss=0.035877545 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [917/1000] | Train Loss=0.000763761 | Test Loss=0.035438696 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [918/1000] | Train Loss=0.000753141 | Test Loss=0.035609564 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [919/1000] | Train Loss=0.000710212 | Test Loss=0.035718731 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [920/1000] | Train Loss=0.000727367 | Test Loss=0.035476119 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [921/1000] | Train Loss=0.000798564 | Test Loss=0.035879274 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [922/1000] | Train Loss=0.000768031 | Test Loss=0.035880630 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [923/1000] | Train Loss=0.000749717 | Test Loss=0.035690940 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [924/1000] | Train Loss=0.000794327 | Test Loss=0.035631923 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [925/1000] | Train Loss=0.000739656 | Test Loss=0.035671538 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [926/1000] | Train Loss=0.000719656 | Test Loss=0.035771642 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [927/1000] | Train Loss=0.000735862 | Test Loss=0.035839708 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [928/1000] | Train Loss=0.000711803 | Test Loss=0.035913410 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [929/1000] | Train Loss=0.000723010 | Test Loss=0.035766113 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [930/1000] | Train Loss=0.000731461 | Test Loss=0.035552746 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [931/1000] | Train Loss=0.000772218 | Test Loss=0.035944585 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [932/1000] | Train Loss=0.000793409 | Test Loss=0.035709715 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [933/1000] | Train Loss=0.000732440 | Test Loss=0.035866325 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [934/1000] | Train Loss=0.000728682 | Test Loss=0.035667527 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [935/1000] | Train Loss=0.000728540 | Test Loss=0.035691525 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [936/1000] | Train Loss=0.000720095 | Test Loss=0.036017707 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [937/1000] | Train Loss=0.000722587 | Test Loss=0.035804366 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [938/1000] | Train Loss=0.000720999 | Test Loss=0.035844148 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [939/1000] | Train Loss=0.000705142 | Test Loss=0.035825502 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [940/1000] | Train Loss=0.000740588 | Test Loss=0.035299267 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [941/1000] | Train Loss=0.000739147 | Test Loss=0.035788361 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [942/1000] | Train Loss=0.000707449 | Test Loss=0.035710014 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [943/1000] | Train Loss=0.000728248 | Test Loss=0.035697551 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [944/1000] | Train Loss=0.000733581 | Test Loss=0.035741604 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [945/1000] | Train Loss=0.000703623 | Test Loss=0.035826117 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [946/1000] | Train Loss=0.000763249 | Test Loss=0.036012001 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [947/1000] | Train Loss=0.000767339 | Test Loss=0.035609942 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [948/1000] | Train Loss=0.000874753 | Test Loss=0.036039019 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [949/1000] | Train Loss=0.000789644 | Test Loss=0.036063897 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [950/1000] | Train Loss=0.000747853 | Test Loss=0.036006993 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [951/1000] | Train Loss=0.000753328 | Test Loss=0.035736874 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [952/1000] | Train Loss=0.000733768 | Test Loss=0.035708114 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [953/1000] | Train Loss=0.000729684 | Test Loss=0.035879318 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [954/1000] | Train Loss=0.000742033 | Test Loss=0.036032445 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [955/1000] | Train Loss=0.000802930 | Test Loss=0.035950045 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [956/1000] | Train Loss=0.000719067 | Test Loss=0.036005213 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [957/1000] | Train Loss=0.000706197 | Test Loss=0.035749846 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [958/1000] | Train Loss=0.000717191 | Test Loss=0.036153769 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [959/1000] | Train Loss=0.000707182 | Test Loss=0.035804685 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [960/1000] | Train Loss=0.000734351 | Test Loss=0.035959410 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [961/1000] | Train Loss=0.000721419 | Test Loss=0.035562520 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [962/1000] | Train Loss=0.000744946 | Test Loss=0.035748458 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [963/1000] | Train Loss=0.000718938 | Test Loss=0.035910550 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [964/1000] | Train Loss=0.000719389 | Test Loss=0.035912750 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [965/1000] | Train Loss=0.000777045 | Test Loss=0.035800506 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [966/1000] | Train Loss=0.000739928 | Test Loss=0.035773328 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [967/1000] | Train Loss=0.000846050 | Test Loss=0.035584338 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [968/1000] | Train Loss=0.000802802 | Test Loss=0.035815396 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [969/1000] | Train Loss=0.000745422 | Test Loss=0.035733740 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [970/1000] | Train Loss=0.000770737 | Test Loss=0.036111362 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [971/1000] | Train Loss=0.000750594 | Test Loss=0.035735452 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [972/1000] | Train Loss=0.000740014 | Test Loss=0.035863139 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [973/1000] | Train Loss=0.000715689 | Test Loss=0.035533410 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [974/1000] | Train Loss=0.000747472 | Test Loss=0.035581066 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [975/1000] | Train Loss=0.000817787 | Test Loss=0.035290758 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [976/1000] | Train Loss=0.000767061 | Test Loss=0.036008349 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [977/1000] | Train Loss=0.000733680 | Test Loss=0.035843077 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [978/1000] | Train Loss=0.000728580 | Test Loss=0.035684435 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [979/1000] | Train Loss=0.000742331 | Test Loss=0.035818732 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [980/1000] | Train Loss=0.000778065 | Test Loss=0.035800949 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [981/1000] | Train Loss=0.000725549 | Test Loss=0.035735856 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [982/1000] | Train Loss=0.000729471 | Test Loss=0.035582307 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [983/1000] | Train Loss=0.000725596 | Test Loss=0.035587488 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [984/1000] | Train Loss=0.000744026 | Test Loss=0.035746602 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [985/1000] | Train Loss=0.000793017 | Test Loss=0.035893797 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [986/1000] | Train Loss=0.000756320 | Test Loss=0.035730153 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [987/1000] | Train Loss=0.000754071 | Test Loss=0.035731040 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [988/1000] | Train Loss=0.000730491 | Test Loss=0.035858907 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [989/1000] | Train Loss=0.000717130 | Test Loss=0.035735698 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [990/1000] | Train Loss=0.000736435 | Test Loss=0.035856121 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [991/1000] | Train Loss=0.000724704 | Test Loss=0.035862155 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [992/1000] | Train Loss=0.000729249 | Test Loss=0.035847891 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [993/1000] | Train Loss=0.000736518 | Test Loss=0.035911703 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [994/1000] | Train Loss=0.000730159 | Test Loss=0.035703600 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [995/1000] | Train Loss=0.000695295 | Test Loss=0.035965583 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [996/1000] | Train Loss=0.000707299 | Test Loss=0.035732588 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [997/1000] | Train Loss=0.000713708 | Test Loss=0.035880894 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [998/1000] | Train Loss=0.000730520 | Test Loss=0.035752077 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [999/1000] | Train Loss=0.000736712 | Test Loss=0.035834267 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000721975 | Test Loss=0.035888673 | Time=1.85s | LR=1.53e-08\n",
      "\n",
      "Total training time: 1847.77 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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aBPkbVHPeshx7kqZxZxZtpRV6ZBZUI4u4f6mD/ovHkhw6SzLhWUavPF7Ou7qF43BHVuhUqs3Ber/nL2CxX+fwb9vjkOnsIYP6zfO++Ps8uv0Brz71wn0jw3BiM4hLvu/4ejnN7vGiIgISoUctRu6FHKZ1Rw1rhLk49ngpTo8FHK0a1X/UhP9HMxbCrMzu7mXUlFvEAQAvioPdI8Uj/vyoX4OXfNqBft64gOz3C/z1spBHVrZbBF0lKsCOA+F2MUHiIG91JgsTURERG6LgRARERG5LQZCRERE5LYYCBEREZHbYiBEREREbouBkB1JSUmIi4tD//71z9ZKRERELRMDITsSExORnp6OlJQUqYtCRERELsJAiIiIiNwWAyEiIiJyWwyEiIiIyG0xECIiIiK3xUCIiIiI3BYDISIiInJbDITs4DxCRERE1z4PqQvQXCUmJiIxMRHFxcUICgqCWq126vm1Wi3Ky8uhVquhVCqdem6qwXpuOqzrpsF6bhqs56bhyno2fm4LglDncQyE6lFSUgIAiI6OlrgkRERE1FAlJSUIDAy0u18m1BcquTmDwYBLly7B398fMpnMaedVq9WIjo5GVlYWAgICnHZessR6bjqs66bBem4arOem4cp6FgQBJSUliIqKglxuPxOILUL1kMvlaNu2rcvOHxAQwD+yJsB6bjqs66bBem4arOem4ap6rqslyIjJ0kREROS2GAgRERGR22IgJBGVSoV58+ZBpVJJXZRrGuu56bCumwbruWmwnptGc6hnJksTERGR22KLEBEREbktBkJERETkthgIERERkdtiIERERERui4GQRJKSkhAbGwsvLy8MHDgQe/fulbpILcbChQvRv39/+Pv7IywsDBMnTsSJEycsjqmsrERiYiJatWoFPz8/3HnnncjNzbU4JjMzEzfffDN8fHwQFhaGF198ETqdrimfSovy1ltvQSaT4bnnnjNtYz07z8WLF/HAAw+gVatW8Pb2Rq9evbBv3z7TfkEQMHfuXERGRsLb2xujRo3CqVOnLM5RUFCAKVOmICAgAEFBQXjsscdQWlra1E+l2dLr9Xj11VfRvn17eHt7o2PHjnjjjTcs1qJiPTfctm3bcOuttyIqKgoymQxr16612O+sOj106BCuv/56eHl5ITo6Gu+8845znoBATW7FihWCp6en8M033whHjx4VHn/8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+O9//2ux32AwCK+++qoQHh4uqFQq4aabbhJOnDhhccyVK1eE++67T/Dz8xMCAgKERx55RCgpKWnKp9GsqdVqYcaMGUJMTIzg5eUldOjQQXjllVcshmSznhtuy5YtNv8nT506VRAE59VpWlqaMGzYMEGlUglt2rQR3nrrLaeUXyYIZlNqEhEREbkR5ggRERGR22IgRERERG6LgRARERG5LQZCRERE5LYYCBEREZHbYiBEREREbouBEBEREbktBkJERETkthgIERE1kEwmw9q1a6UuBhE5AQMhImpRHn74YchkMqufcePGSV00ImqBPKQuABFRQ40bNw5Lliyx2KZSqSQqDRG1ZGwRIqIWR6VSISIiwuInODgYgNht9fnnn2P8+PHw9vZGhw4d8NNPP1k8/vDhw7jxxhvh7e2NVq1aYdq0aSgtLbU45ptvvkGPHj2gUqkQGRmJ6dOnW+zPz8/HpEmT4OPjg86dO+PXX3917ZMmIpdgIERE15xXX30Vd955J9LS0jBlyhTce++9OHbsGACgrKwMY8eORXBwMFJSUrBq1Sps2rTJItD5/PPPkZiYiGnTpuHw4cP49ddf0alTJ4trvPbaa7j77rtx6NAhTJgwAVOmTEFBQUGTPk8icgKnrGFPRNREpk6dKigUCsHX19fiZ8GCBYIgCAIA4cknn7R4zMCBA4WnnnpKEARB+O9//ysEBwcLpaWlpv1//PGHIJfLhZycHEEQBCEqKkp45ZVX7JYBgPDvf//bdL+0tFQAIPz5559Oe55E1DSYI0RELc4NN9yAzz//3GJbSEiI6fbgwYMt9g0ePBipqakAgGPHjqFPnz7w9fU17R86dCgMBgNOnDgBmUyGS5cu4aabbqqzDL179zbd9vX1RUBAAPLy8hr7lIhIIgyEiKjF8fX1teqqchZvb2+HjlMqlRb3ZTIZDAaDK4pERC7EHCEiuub8888/Vve7d+8OAOjevTvS0tJQVlZm2r9z507I5XJ07doV/v7+iI2NRXJycpOWmYikwRYhImpxqqqqkJOTY7HNw8MDoaGhAIBVq1ahX79+GDZsGJYtW4a9e/fi66+/BgBMmTIF8+bNw9SpUzF//nxcvnwZzzzzDB588EGEh4cDAObPn48nn3wSYWFhGD9+PEpKSrBz504888wzTftEicjlGAgRUYuzfv16REZGWmzr2rUrjh8/DkAc0bVixQo8/fTTiIyMxA8//IC4uDgAgI+PD/766y/MmDED/fv3h4+PD+6880588MEHpnNNnToVlZWV+PDDDzFr1iyEhoZi8uTJTfcEiajJyARBEKQuBBGRs8hkMqxZswYTJ06UuihE1AIwR4iIiIjcFgMhIiIiclvMESKiawp7+4moIdgiRERERG6LgRARERG5LQZCRERE5LYYCBEREZHbYiBEREREbouBEBEREbktBkJERETkthgIERERkdv6f0xIOoFxR9zdAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Train ONLY on Group A (train_1.pt) as requested\n",
    "ufno, train_losses, test_losses = train_operator(\n",
    "    dataset_raw      = train_data,\n",
    "    model            = ufno,\n",
    "    num_epochs       = 1000,\n",
    "    lr               = 1e-3,\n",
    "    device           = device,\n",
    "    batch_size       = 16,\n",
    "    test_dataset_raw = test_data,   # evaluates on unseen Group B during training\n",
    "    reduce_on        = 'train',\n",
    "    factor           = 0.5,\n",
    "    patience         = 30,\n",
    "    min_lr           = 1e-10,\n",
    "    cooldown         = 0\n",
    ")\n",
    "\n",
    "torch.save(ufno.state_dict(), \"ufno1d_G2.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/jinlee/kn_mlp/kano/lib/python3.10/site-packages/torch/optim/lr_scheduler.py:62: UserWarning: The verbose parameter is deprecated. Please use get_last_lr() to access the learning rate.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/1000] | Train Loss=0.001025619 | Test Loss=0.036168532 | Time=1.93s | LR=1.00e-04\n",
      "Epoch [2/1000] | Train Loss=0.000941085 | Test Loss=0.036445164 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [3/1000] | Train Loss=0.000910846 | Test Loss=0.036606579 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [4/1000] | Train Loss=0.000983122 | Test Loss=0.035674141 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [5/1000] | Train Loss=0.001030405 | Test Loss=0.036150118 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [6/1000] | Train Loss=0.000883565 | Test Loss=0.035956738 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [7/1000] | Train Loss=0.001062833 | Test Loss=0.036032397 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [8/1000] | Train Loss=0.000978728 | Test Loss=0.035666154 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [9/1000] | Train Loss=0.000894896 | Test Loss=0.036152375 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [10/1000] | Train Loss=0.000884708 | Test Loss=0.036102096 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [11/1000] | Train Loss=0.000834327 | Test Loss=0.035970522 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [12/1000] | Train Loss=0.000926516 | Test Loss=0.036005157 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [13/1000] | Train Loss=0.000905526 | Test Loss=0.035427390 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [14/1000] | Train Loss=0.000875911 | Test Loss=0.035565038 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [15/1000] | Train Loss=0.000886651 | Test Loss=0.035882389 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [16/1000] | Train Loss=0.000914172 | Test Loss=0.035791121 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [17/1000] | Train Loss=0.000965934 | Test Loss=0.035379789 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [18/1000] | Train Loss=0.000956732 | Test Loss=0.035586295 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [19/1000] | Train Loss=0.000920912 | Test Loss=0.036733740 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [20/1000] | Train Loss=0.000882502 | Test Loss=0.035791373 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [21/1000] | Train Loss=0.001035070 | Test Loss=0.035440375 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [22/1000] | Train Loss=0.000933412 | Test Loss=0.035708297 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [23/1000] | Train Loss=0.001052809 | Test Loss=0.035816140 | Time=1.87s | LR=1.00e-04\n",
      "Epoch [24/1000] | Train Loss=0.000893687 | Test Loss=0.035106721 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [25/1000] | Train Loss=0.000918506 | Test Loss=0.035459964 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [26/1000] | Train Loss=0.000876603 | Test Loss=0.036148826 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [27/1000] | Train Loss=0.000911360 | Test Loss=0.035692584 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [28/1000] | Train Loss=0.000945366 | Test Loss=0.036044735 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [29/1000] | Train Loss=0.000949932 | Test Loss=0.036022525 | Time=1.87s | LR=1.00e-04\n",
      "Epoch [30/1000] | Train Loss=0.000915772 | Test Loss=0.036035608 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [31/1000] | Train Loss=0.000948244 | Test Loss=0.035669604 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [32/1000] | Train Loss=0.000895468 | Test Loss=0.035587304 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [33/1000] | Train Loss=0.000921973 | Test Loss=0.035234392 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [34/1000] | Train Loss=0.000948397 | Test Loss=0.036114123 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [35/1000] | Train Loss=0.000936196 | Test Loss=0.035539339 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [36/1000] | Train Loss=0.000863686 | Test Loss=0.035960106 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [37/1000] | Train Loss=0.000866010 | Test Loss=0.036183804 | Time=1.87s | LR=1.00e-04\n",
      "Epoch [38/1000] | Train Loss=0.000968398 | Test Loss=0.036073063 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [39/1000] | Train Loss=0.000929906 | Test Loss=0.036660160 | Time=1.87s | LR=1.00e-04\n",
      "Epoch [40/1000] | Train Loss=0.000914756 | Test Loss=0.035482022 | Time=1.87s | LR=1.00e-04\n",
      "Epoch [41/1000] | Train Loss=0.001013658 | Test Loss=0.036893049 | Time=1.86s | LR=1.00e-04\n",
      "Epoch [42/1000] | Train Loss=0.000939524 | Test Loss=0.036282415 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [43/1000] | Train Loss=0.000814460 | Test Loss=0.035822329 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [44/1000] | Train Loss=0.000811792 | Test Loss=0.035918707 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [45/1000] | Train Loss=0.000803377 | Test Loss=0.036067762 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [46/1000] | Train Loss=0.000779511 | Test Loss=0.036319906 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [47/1000] | Train Loss=0.000774362 | Test Loss=0.036006026 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [48/1000] | Train Loss=0.000791302 | Test Loss=0.036034253 | Time=1.87s | LR=5.00e-05\n",
      "Epoch [49/1000] | Train Loss=0.000775802 | Test Loss=0.036401659 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [50/1000] | Train Loss=0.000753985 | Test Loss=0.036105367 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [51/1000] | Train Loss=0.000839005 | Test Loss=0.035902700 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [52/1000] | Train Loss=0.000906733 | Test Loss=0.035904187 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [53/1000] | Train Loss=0.000814450 | Test Loss=0.035878468 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [54/1000] | Train Loss=0.000769264 | Test Loss=0.035871538 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [55/1000] | Train Loss=0.000768270 | Test Loss=0.035729365 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [56/1000] | Train Loss=0.000824891 | Test Loss=0.035772451 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [57/1000] | Train Loss=0.000785265 | Test Loss=0.036005485 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [58/1000] | Train Loss=0.000887321 | Test Loss=0.035809901 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [59/1000] | Train Loss=0.000803425 | Test Loss=0.035123056 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [60/1000] | Train Loss=0.000844496 | Test Loss=0.035363191 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [61/1000] | Train Loss=0.000767891 | Test Loss=0.035614322 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [62/1000] | Train Loss=0.000794916 | Test Loss=0.035781930 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [63/1000] | Train Loss=0.000782099 | Test Loss=0.036039918 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [64/1000] | Train Loss=0.000802189 | Test Loss=0.035636468 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [65/1000] | Train Loss=0.000888629 | Test Loss=0.035927313 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [66/1000] | Train Loss=0.000779818 | Test Loss=0.035609979 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [67/1000] | Train Loss=0.000794469 | Test Loss=0.035489199 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [68/1000] | Train Loss=0.000832436 | Test Loss=0.035763100 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [69/1000] | Train Loss=0.000815758 | Test Loss=0.035953077 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [70/1000] | Train Loss=0.000835326 | Test Loss=0.035896600 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [71/1000] | Train Loss=0.000793422 | Test Loss=0.035965603 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [72/1000] | Train Loss=0.000858638 | Test Loss=0.035476345 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [73/1000] | Train Loss=0.000808267 | Test Loss=0.035806567 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [74/1000] | Train Loss=0.000772252 | Test Loss=0.036177200 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [75/1000] | Train Loss=0.000854642 | Test Loss=0.035392190 | Time=1.87s | LR=5.00e-05\n",
      "Epoch [76/1000] | Train Loss=0.000883738 | Test Loss=0.035909014 | Time=1.87s | LR=5.00e-05\n",
      "Epoch [77/1000] | Train Loss=0.000835848 | Test Loss=0.035548398 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [78/1000] | Train Loss=0.000803863 | Test Loss=0.035528872 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [79/1000] | Train Loss=0.000786756 | Test Loss=0.035840105 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [80/1000] | Train Loss=0.000772798 | Test Loss=0.035558576 | Time=1.86s | LR=5.00e-05\n",
      "Epoch [81/1000] | Train Loss=0.000838065 | Test Loss=0.035899739 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [82/1000] | Train Loss=0.000776559 | Test Loss=0.035507022 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [83/1000] | Train Loss=0.000794617 | Test Loss=0.035852208 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [84/1000] | Train Loss=0.000755041 | Test Loss=0.036063869 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [85/1000] | Train Loss=0.000778129 | Test Loss=0.035647342 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [86/1000] | Train Loss=0.000749485 | Test Loss=0.035529271 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [87/1000] | Train Loss=0.000717456 | Test Loss=0.035726823 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [88/1000] | Train Loss=0.000767094 | Test Loss=0.035584192 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [89/1000] | Train Loss=0.000743228 | Test Loss=0.035836901 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [90/1000] | Train Loss=0.000710592 | Test Loss=0.035987833 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [91/1000] | Train Loss=0.000826632 | Test Loss=0.035552942 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [92/1000] | Train Loss=0.000728325 | Test Loss=0.035755019 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [93/1000] | Train Loss=0.000745666 | Test Loss=0.035624266 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [94/1000] | Train Loss=0.000792015 | Test Loss=0.035629508 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [95/1000] | Train Loss=0.000733456 | Test Loss=0.035702379 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [96/1000] | Train Loss=0.000777105 | Test Loss=0.035907577 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [97/1000] | Train Loss=0.000727722 | Test Loss=0.035776299 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [98/1000] | Train Loss=0.000777847 | Test Loss=0.035474309 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [99/1000] | Train Loss=0.000738687 | Test Loss=0.035799562 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [100/1000] | Train Loss=0.000727708 | Test Loss=0.035819235 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [101/1000] | Train Loss=0.000783819 | Test Loss=0.035573693 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [102/1000] | Train Loss=0.000782130 | Test Loss=0.035837610 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [103/1000] | Train Loss=0.000737869 | Test Loss=0.035460419 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [104/1000] | Train Loss=0.000765903 | Test Loss=0.035610567 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [105/1000] | Train Loss=0.000737997 | Test Loss=0.035647129 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [106/1000] | Train Loss=0.000788894 | Test Loss=0.035714182 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [107/1000] | Train Loss=0.000734027 | Test Loss=0.035773977 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [108/1000] | Train Loss=0.000751311 | Test Loss=0.035831336 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [109/1000] | Train Loss=0.000730198 | Test Loss=0.035950125 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [110/1000] | Train Loss=0.000751149 | Test Loss=0.035860759 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [111/1000] | Train Loss=0.000728164 | Test Loss=0.035578580 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [112/1000] | Train Loss=0.000732390 | Test Loss=0.035426093 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [113/1000] | Train Loss=0.000772634 | Test Loss=0.035436586 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [114/1000] | Train Loss=0.000775981 | Test Loss=0.036154092 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [115/1000] | Train Loss=0.000765075 | Test Loss=0.036054388 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [116/1000] | Train Loss=0.000730529 | Test Loss=0.036335789 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [117/1000] | Train Loss=0.000791637 | Test Loss=0.035949258 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [118/1000] | Train Loss=0.000778213 | Test Loss=0.035735183 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [119/1000] | Train Loss=0.000843555 | Test Loss=0.035734047 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [120/1000] | Train Loss=0.000711475 | Test Loss=0.036107845 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [121/1000] | Train Loss=0.000779736 | Test Loss=0.035925319 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [122/1000] | Train Loss=0.000706638 | Test Loss=0.035739852 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [123/1000] | Train Loss=0.000700830 | Test Loss=0.035891269 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [124/1000] | Train Loss=0.000733669 | Test Loss=0.035819910 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [125/1000] | Train Loss=0.000789974 | Test Loss=0.035818648 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [126/1000] | Train Loss=0.000731290 | Test Loss=0.035805800 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [127/1000] | Train Loss=0.000727091 | Test Loss=0.035535714 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [128/1000] | Train Loss=0.000715500 | Test Loss=0.035947406 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [129/1000] | Train Loss=0.000764909 | Test Loss=0.035767863 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [130/1000] | Train Loss=0.000732629 | Test Loss=0.035731904 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [131/1000] | Train Loss=0.000725989 | Test Loss=0.035707198 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [132/1000] | Train Loss=0.000726549 | Test Loss=0.035726237 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [133/1000] | Train Loss=0.000702026 | Test Loss=0.035775163 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [134/1000] | Train Loss=0.000723231 | Test Loss=0.035559528 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [135/1000] | Train Loss=0.000713832 | Test Loss=0.035860227 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [136/1000] | Train Loss=0.000716655 | Test Loss=0.035824286 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [137/1000] | Train Loss=0.000723425 | Test Loss=0.035807935 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [138/1000] | Train Loss=0.000756880 | Test Loss=0.035815795 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [139/1000] | Train Loss=0.000698817 | Test Loss=0.035733603 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [140/1000] | Train Loss=0.000735942 | Test Loss=0.035945635 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [141/1000] | Train Loss=0.000739452 | Test Loss=0.035609008 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [142/1000] | Train Loss=0.000769118 | Test Loss=0.035816247 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [143/1000] | Train Loss=0.000714809 | Test Loss=0.035715789 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [144/1000] | Train Loss=0.000733180 | Test Loss=0.036029243 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [145/1000] | Train Loss=0.000742235 | Test Loss=0.035890064 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [146/1000] | Train Loss=0.000718941 | Test Loss=0.035598759 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [147/1000] | Train Loss=0.000730467 | Test Loss=0.035535840 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [148/1000] | Train Loss=0.000729273 | Test Loss=0.035736684 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [149/1000] | Train Loss=0.000869922 | Test Loss=0.035872321 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [150/1000] | Train Loss=0.000733505 | Test Loss=0.035925626 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [151/1000] | Train Loss=0.000786739 | Test Loss=0.035666441 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [152/1000] | Train Loss=0.000711426 | Test Loss=0.035587826 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [153/1000] | Train Loss=0.000726950 | Test Loss=0.035777675 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [154/1000] | Train Loss=0.000722909 | Test Loss=0.035923965 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [155/1000] | Train Loss=0.000736280 | Test Loss=0.035601522 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [156/1000] | Train Loss=0.000723958 | Test Loss=0.035602969 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [157/1000] | Train Loss=0.000719673 | Test Loss=0.035870935 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [158/1000] | Train Loss=0.000761273 | Test Loss=0.035694960 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [159/1000] | Train Loss=0.000736078 | Test Loss=0.035871206 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [160/1000] | Train Loss=0.000758420 | Test Loss=0.035394613 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [161/1000] | Train Loss=0.000721505 | Test Loss=0.035493445 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [162/1000] | Train Loss=0.000722272 | Test Loss=0.035730006 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [163/1000] | Train Loss=0.000738228 | Test Loss=0.035699022 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [164/1000] | Train Loss=0.000727951 | Test Loss=0.035860797 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [165/1000] | Train Loss=0.000735692 | Test Loss=0.035256488 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [166/1000] | Train Loss=0.000705990 | Test Loss=0.035829151 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [167/1000] | Train Loss=0.000714987 | Test Loss=0.035555940 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [168/1000] | Train Loss=0.000741324 | Test Loss=0.035692503 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [169/1000] | Train Loss=0.000720087 | Test Loss=0.035726322 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [170/1000] | Train Loss=0.000687163 | Test Loss=0.035616092 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [171/1000] | Train Loss=0.000716545 | Test Loss=0.035497281 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [172/1000] | Train Loss=0.000743030 | Test Loss=0.035638660 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [173/1000] | Train Loss=0.000758821 | Test Loss=0.035919150 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [174/1000] | Train Loss=0.000701686 | Test Loss=0.035491489 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [175/1000] | Train Loss=0.000714388 | Test Loss=0.035571001 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [176/1000] | Train Loss=0.000696920 | Test Loss=0.035816379 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [177/1000] | Train Loss=0.000713458 | Test Loss=0.035494596 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [178/1000] | Train Loss=0.000804190 | Test Loss=0.035451276 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [179/1000] | Train Loss=0.000715945 | Test Loss=0.035410229 | Time=1.87s | LR=1.25e-05\n",
      "Epoch [180/1000] | Train Loss=0.000777684 | Test Loss=0.035281470 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [181/1000] | Train Loss=0.000721646 | Test Loss=0.035583608 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [182/1000] | Train Loss=0.000721957 | Test Loss=0.035932678 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [183/1000] | Train Loss=0.000705366 | Test Loss=0.035602268 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [184/1000] | Train Loss=0.000709161 | Test Loss=0.035635467 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [185/1000] | Train Loss=0.000711081 | Test Loss=0.035731009 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [186/1000] | Train Loss=0.000715372 | Test Loss=0.035447557 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [187/1000] | Train Loss=0.000718792 | Test Loss=0.035349915 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [188/1000] | Train Loss=0.000725287 | Test Loss=0.035513070 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [189/1000] | Train Loss=0.000705903 | Test Loss=0.035415308 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [190/1000] | Train Loss=0.000690667 | Test Loss=0.035405374 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [191/1000] | Train Loss=0.000747469 | Test Loss=0.035540961 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [192/1000] | Train Loss=0.000771740 | Test Loss=0.035667754 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [193/1000] | Train Loss=0.000695714 | Test Loss=0.035634608 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [194/1000] | Train Loss=0.000729033 | Test Loss=0.035888062 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [195/1000] | Train Loss=0.000718557 | Test Loss=0.035836281 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [196/1000] | Train Loss=0.000746731 | Test Loss=0.035544340 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [197/1000] | Train Loss=0.000727278 | Test Loss=0.035873393 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [198/1000] | Train Loss=0.000709050 | Test Loss=0.035848778 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [199/1000] | Train Loss=0.000719218 | Test Loss=0.035604653 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [200/1000] | Train Loss=0.000687359 | Test Loss=0.035732022 | Time=1.86s | LR=1.25e-05\n",
      "Epoch [201/1000] | Train Loss=0.000719835 | Test Loss=0.035603366 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [202/1000] | Train Loss=0.000712514 | Test Loss=0.035764913 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [203/1000] | Train Loss=0.000687494 | Test Loss=0.035512309 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [204/1000] | Train Loss=0.000688589 | Test Loss=0.035701633 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [205/1000] | Train Loss=0.000757806 | Test Loss=0.035974334 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [206/1000] | Train Loss=0.000733362 | Test Loss=0.035815578 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [207/1000] | Train Loss=0.000688975 | Test Loss=0.035856367 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [208/1000] | Train Loss=0.000700678 | Test Loss=0.035685624 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [209/1000] | Train Loss=0.000724889 | Test Loss=0.035804342 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [210/1000] | Train Loss=0.000738298 | Test Loss=0.036208324 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [211/1000] | Train Loss=0.000690934 | Test Loss=0.035704952 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [212/1000] | Train Loss=0.000760013 | Test Loss=0.035692150 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [213/1000] | Train Loss=0.000735813 | Test Loss=0.035901924 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [214/1000] | Train Loss=0.000697460 | Test Loss=0.035529618 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [215/1000] | Train Loss=0.000728365 | Test Loss=0.035638054 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [216/1000] | Train Loss=0.000733981 | Test Loss=0.035715090 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [217/1000] | Train Loss=0.000701897 | Test Loss=0.035867709 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [218/1000] | Train Loss=0.000701996 | Test Loss=0.035603458 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [219/1000] | Train Loss=0.000680078 | Test Loss=0.036121278 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [220/1000] | Train Loss=0.000675627 | Test Loss=0.035529445 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [221/1000] | Train Loss=0.000695252 | Test Loss=0.035660606 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [222/1000] | Train Loss=0.000711434 | Test Loss=0.035954405 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [223/1000] | Train Loss=0.000706624 | Test Loss=0.035717630 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [224/1000] | Train Loss=0.000736302 | Test Loss=0.035610446 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [225/1000] | Train Loss=0.000720211 | Test Loss=0.035538113 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [226/1000] | Train Loss=0.000692630 | Test Loss=0.035916655 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [227/1000] | Train Loss=0.000682377 | Test Loss=0.035682612 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [228/1000] | Train Loss=0.000761713 | Test Loss=0.035378268 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [229/1000] | Train Loss=0.000676395 | Test Loss=0.035619953 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [230/1000] | Train Loss=0.000728113 | Test Loss=0.035695759 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [231/1000] | Train Loss=0.000693344 | Test Loss=0.035861846 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [232/1000] | Train Loss=0.000703282 | Test Loss=0.035740881 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [233/1000] | Train Loss=0.000774194 | Test Loss=0.035661830 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [234/1000] | Train Loss=0.000677117 | Test Loss=0.035854413 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [235/1000] | Train Loss=0.000707709 | Test Loss=0.035620159 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [236/1000] | Train Loss=0.000724831 | Test Loss=0.035923961 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [237/1000] | Train Loss=0.000724030 | Test Loss=0.035940770 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [238/1000] | Train Loss=0.000742118 | Test Loss=0.035844522 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [239/1000] | Train Loss=0.000761410 | Test Loss=0.035567529 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [240/1000] | Train Loss=0.000723871 | Test Loss=0.035724074 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [241/1000] | Train Loss=0.000713153 | Test Loss=0.035773007 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [242/1000] | Train Loss=0.000707828 | Test Loss=0.035662925 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [243/1000] | Train Loss=0.000693231 | Test Loss=0.035617612 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [244/1000] | Train Loss=0.000704121 | Test Loss=0.035586088 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [245/1000] | Train Loss=0.000704660 | Test Loss=0.035832842 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [246/1000] | Train Loss=0.000733196 | Test Loss=0.035303834 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [247/1000] | Train Loss=0.000719506 | Test Loss=0.035558292 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [248/1000] | Train Loss=0.000698887 | Test Loss=0.035983528 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [249/1000] | Train Loss=0.000712327 | Test Loss=0.035636376 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [250/1000] | Train Loss=0.000725192 | Test Loss=0.035460115 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [251/1000] | Train Loss=0.000719306 | Test Loss=0.035721857 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [252/1000] | Train Loss=0.000737193 | Test Loss=0.035559863 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [253/1000] | Train Loss=0.000699273 | Test Loss=0.035868389 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [254/1000] | Train Loss=0.000704216 | Test Loss=0.035629227 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [255/1000] | Train Loss=0.000709696 | Test Loss=0.035478705 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [256/1000] | Train Loss=0.000716661 | Test Loss=0.035769401 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [257/1000] | Train Loss=0.000700704 | Test Loss=0.035694223 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [258/1000] | Train Loss=0.000671628 | Test Loss=0.035912707 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [259/1000] | Train Loss=0.000734370 | Test Loss=0.035437435 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [260/1000] | Train Loss=0.000677699 | Test Loss=0.035597439 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [261/1000] | Train Loss=0.000692814 | Test Loss=0.035876807 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [262/1000] | Train Loss=0.000706767 | Test Loss=0.035697377 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [263/1000] | Train Loss=0.000678511 | Test Loss=0.035401262 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [264/1000] | Train Loss=0.000702582 | Test Loss=0.035514914 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [265/1000] | Train Loss=0.000709459 | Test Loss=0.035777477 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [266/1000] | Train Loss=0.000690517 | Test Loss=0.035507535 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [267/1000] | Train Loss=0.000696215 | Test Loss=0.035532584 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [268/1000] | Train Loss=0.000724074 | Test Loss=0.035693026 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [269/1000] | Train Loss=0.000710575 | Test Loss=0.035878690 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [270/1000] | Train Loss=0.000808702 | Test Loss=0.035617777 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [271/1000] | Train Loss=0.000678777 | Test Loss=0.035650471 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [272/1000] | Train Loss=0.000668965 | Test Loss=0.035641002 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [273/1000] | Train Loss=0.000700153 | Test Loss=0.035702916 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [274/1000] | Train Loss=0.000712471 | Test Loss=0.035830264 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [275/1000] | Train Loss=0.000693781 | Test Loss=0.035613704 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [276/1000] | Train Loss=0.000714910 | Test Loss=0.035837050 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [277/1000] | Train Loss=0.000682296 | Test Loss=0.035517512 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [278/1000] | Train Loss=0.000667641 | Test Loss=0.035677109 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [279/1000] | Train Loss=0.000698867 | Test Loss=0.035385396 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [280/1000] | Train Loss=0.000722530 | Test Loss=0.035571027 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [281/1000] | Train Loss=0.000669236 | Test Loss=0.035589486 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [282/1000] | Train Loss=0.000706017 | Test Loss=0.035735905 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [283/1000] | Train Loss=0.000697773 | Test Loss=0.035556089 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [284/1000] | Train Loss=0.000691191 | Test Loss=0.035547349 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [285/1000] | Train Loss=0.000693320 | Test Loss=0.035620466 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [286/1000] | Train Loss=0.000696008 | Test Loss=0.035904615 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [287/1000] | Train Loss=0.000686720 | Test Loss=0.035923249 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [288/1000] | Train Loss=0.000715981 | Test Loss=0.035612112 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [289/1000] | Train Loss=0.000695107 | Test Loss=0.035864494 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [290/1000] | Train Loss=0.000685583 | Test Loss=0.035648911 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [291/1000] | Train Loss=0.000703372 | Test Loss=0.035789191 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [292/1000] | Train Loss=0.000683763 | Test Loss=0.035641066 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [293/1000] | Train Loss=0.000711796 | Test Loss=0.035845850 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [294/1000] | Train Loss=0.000667770 | Test Loss=0.035497857 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [295/1000] | Train Loss=0.000695659 | Test Loss=0.035605372 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [296/1000] | Train Loss=0.000672151 | Test Loss=0.035710889 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [297/1000] | Train Loss=0.000668026 | Test Loss=0.035650044 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [298/1000] | Train Loss=0.000696508 | Test Loss=0.035494111 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [299/1000] | Train Loss=0.000680651 | Test Loss=0.035668242 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [300/1000] | Train Loss=0.000698297 | Test Loss=0.035718683 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [301/1000] | Train Loss=0.000707517 | Test Loss=0.035763862 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [302/1000] | Train Loss=0.000739457 | Test Loss=0.035779374 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [303/1000] | Train Loss=0.000683164 | Test Loss=0.035982816 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [304/1000] | Train Loss=0.000681265 | Test Loss=0.035855460 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [305/1000] | Train Loss=0.000751377 | Test Loss=0.035917138 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [306/1000] | Train Loss=0.000695473 | Test Loss=0.035730231 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [307/1000] | Train Loss=0.000725636 | Test Loss=0.035694472 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [308/1000] | Train Loss=0.000740215 | Test Loss=0.035799643 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [309/1000] | Train Loss=0.000711317 | Test Loss=0.035235163 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [310/1000] | Train Loss=0.000701318 | Test Loss=0.035713675 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [311/1000] | Train Loss=0.000654968 | Test Loss=0.035628907 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [312/1000] | Train Loss=0.000751425 | Test Loss=0.035622496 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [313/1000] | Train Loss=0.000726061 | Test Loss=0.035591200 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [314/1000] | Train Loss=0.000678371 | Test Loss=0.035907664 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [315/1000] | Train Loss=0.000693588 | Test Loss=0.035724931 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [316/1000] | Train Loss=0.000665209 | Test Loss=0.035494329 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [317/1000] | Train Loss=0.000701965 | Test Loss=0.035909295 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [318/1000] | Train Loss=0.000688773 | Test Loss=0.035544685 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [319/1000] | Train Loss=0.000693584 | Test Loss=0.035455455 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [320/1000] | Train Loss=0.000675290 | Test Loss=0.035767265 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [321/1000] | Train Loss=0.000702111 | Test Loss=0.035685426 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [322/1000] | Train Loss=0.000662301 | Test Loss=0.035542938 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [323/1000] | Train Loss=0.000702767 | Test Loss=0.035761133 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [324/1000] | Train Loss=0.000695324 | Test Loss=0.035752694 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [325/1000] | Train Loss=0.000729176 | Test Loss=0.035733894 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [326/1000] | Train Loss=0.000690236 | Test Loss=0.035649692 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [327/1000] | Train Loss=0.000740168 | Test Loss=0.035860568 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [328/1000] | Train Loss=0.000731983 | Test Loss=0.035698009 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [329/1000] | Train Loss=0.000685743 | Test Loss=0.035625744 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [330/1000] | Train Loss=0.000685669 | Test Loss=0.035671492 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [331/1000] | Train Loss=0.000681196 | Test Loss=0.035650519 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [332/1000] | Train Loss=0.000705552 | Test Loss=0.035804578 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [333/1000] | Train Loss=0.000703065 | Test Loss=0.035662830 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [334/1000] | Train Loss=0.000687469 | Test Loss=0.035649800 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [335/1000] | Train Loss=0.000660660 | Test Loss=0.035557938 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [336/1000] | Train Loss=0.000670249 | Test Loss=0.035891606 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [337/1000] | Train Loss=0.000745586 | Test Loss=0.035378586 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [338/1000] | Train Loss=0.000693869 | Test Loss=0.036027718 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [339/1000] | Train Loss=0.000743727 | Test Loss=0.035620695 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [340/1000] | Train Loss=0.000688274 | Test Loss=0.035544352 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [341/1000] | Train Loss=0.000679678 | Test Loss=0.035770579 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [342/1000] | Train Loss=0.000676958 | Test Loss=0.035566688 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [343/1000] | Train Loss=0.000660670 | Test Loss=0.035687182 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [344/1000] | Train Loss=0.000682139 | Test Loss=0.035612134 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [345/1000] | Train Loss=0.000679589 | Test Loss=0.035752955 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [346/1000] | Train Loss=0.000702071 | Test Loss=0.035474216 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [347/1000] | Train Loss=0.000677574 | Test Loss=0.035649508 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [348/1000] | Train Loss=0.000664285 | Test Loss=0.035836900 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [349/1000] | Train Loss=0.000731481 | Test Loss=0.035651015 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [350/1000] | Train Loss=0.000727796 | Test Loss=0.035671418 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [351/1000] | Train Loss=0.000753294 | Test Loss=0.035579240 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [352/1000] | Train Loss=0.000695471 | Test Loss=0.035803895 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [353/1000] | Train Loss=0.000681314 | Test Loss=0.035552369 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [354/1000] | Train Loss=0.000679287 | Test Loss=0.035646975 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [355/1000] | Train Loss=0.000702985 | Test Loss=0.035684646 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [356/1000] | Train Loss=0.000727310 | Test Loss=0.035582600 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [357/1000] | Train Loss=0.000700518 | Test Loss=0.035636496 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [358/1000] | Train Loss=0.000687236 | Test Loss=0.035641585 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [359/1000] | Train Loss=0.000709891 | Test Loss=0.035470733 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [360/1000] | Train Loss=0.000717505 | Test Loss=0.035474558 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [361/1000] | Train Loss=0.000694811 | Test Loss=0.035734030 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [362/1000] | Train Loss=0.000679856 | Test Loss=0.035893174 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [363/1000] | Train Loss=0.000691362 | Test Loss=0.035599534 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [364/1000] | Train Loss=0.000714421 | Test Loss=0.035504586 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [365/1000] | Train Loss=0.000658801 | Test Loss=0.035617368 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [366/1000] | Train Loss=0.000674347 | Test Loss=0.035740884 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [367/1000] | Train Loss=0.000665898 | Test Loss=0.035587408 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [368/1000] | Train Loss=0.000685581 | Test Loss=0.035927273 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [369/1000] | Train Loss=0.000705624 | Test Loss=0.035614374 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [370/1000] | Train Loss=0.000721108 | Test Loss=0.035485981 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [371/1000] | Train Loss=0.000707117 | Test Loss=0.035302673 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [372/1000] | Train Loss=0.000670395 | Test Loss=0.035560978 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [373/1000] | Train Loss=0.000703646 | Test Loss=0.035732120 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [374/1000] | Train Loss=0.000686024 | Test Loss=0.035389736 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [375/1000] | Train Loss=0.000711314 | Test Loss=0.035383937 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [376/1000] | Train Loss=0.000701546 | Test Loss=0.035696673 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [377/1000] | Train Loss=0.000668799 | Test Loss=0.035714208 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [378/1000] | Train Loss=0.000698852 | Test Loss=0.035697171 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [379/1000] | Train Loss=0.000688344 | Test Loss=0.035758579 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [380/1000] | Train Loss=0.000671892 | Test Loss=0.035817297 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [381/1000] | Train Loss=0.000693336 | Test Loss=0.035557205 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [382/1000] | Train Loss=0.000725114 | Test Loss=0.035295434 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [383/1000] | Train Loss=0.000754368 | Test Loss=0.035530702 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [384/1000] | Train Loss=0.000714195 | Test Loss=0.035667639 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [385/1000] | Train Loss=0.000683851 | Test Loss=0.035598698 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [386/1000] | Train Loss=0.000715679 | Test Loss=0.035433572 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [387/1000] | Train Loss=0.000707990 | Test Loss=0.035911129 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [388/1000] | Train Loss=0.000749387 | Test Loss=0.035669075 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [389/1000] | Train Loss=0.000696379 | Test Loss=0.035716013 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [390/1000] | Train Loss=0.000674869 | Test Loss=0.035695793 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [391/1000] | Train Loss=0.000672053 | Test Loss=0.035783800 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [392/1000] | Train Loss=0.000681315 | Test Loss=0.035668218 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [393/1000] | Train Loss=0.000676912 | Test Loss=0.035445705 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [394/1000] | Train Loss=0.000717465 | Test Loss=0.035686088 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [395/1000] | Train Loss=0.000671497 | Test Loss=0.035743076 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [396/1000] | Train Loss=0.000760402 | Test Loss=0.035578502 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [397/1000] | Train Loss=0.000670098 | Test Loss=0.035743486 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [398/1000] | Train Loss=0.000675064 | Test Loss=0.035827020 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [399/1000] | Train Loss=0.000686036 | Test Loss=0.035710562 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [400/1000] | Train Loss=0.000691505 | Test Loss=0.035590996 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [401/1000] | Train Loss=0.000696592 | Test Loss=0.035459781 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [402/1000] | Train Loss=0.000790107 | Test Loss=0.035538504 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [403/1000] | Train Loss=0.000667558 | Test Loss=0.035629205 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [404/1000] | Train Loss=0.000724195 | Test Loss=0.035561634 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [405/1000] | Train Loss=0.000676824 | Test Loss=0.035517713 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [406/1000] | Train Loss=0.000701358 | Test Loss=0.035490534 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [407/1000] | Train Loss=0.000655531 | Test Loss=0.035688054 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [408/1000] | Train Loss=0.000671331 | Test Loss=0.035678673 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [409/1000] | Train Loss=0.000683479 | Test Loss=0.035453801 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [410/1000] | Train Loss=0.000683553 | Test Loss=0.035626722 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [411/1000] | Train Loss=0.000690112 | Test Loss=0.035713630 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [412/1000] | Train Loss=0.000674368 | Test Loss=0.035963842 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [413/1000] | Train Loss=0.000789118 | Test Loss=0.035503594 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [414/1000] | Train Loss=0.000664031 | Test Loss=0.035749663 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [415/1000] | Train Loss=0.000665979 | Test Loss=0.035654007 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [416/1000] | Train Loss=0.000724223 | Test Loss=0.035939772 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [417/1000] | Train Loss=0.000682368 | Test Loss=0.035705986 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [418/1000] | Train Loss=0.000722943 | Test Loss=0.035666820 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [419/1000] | Train Loss=0.000772225 | Test Loss=0.035823991 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [420/1000] | Train Loss=0.000684262 | Test Loss=0.035766652 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [421/1000] | Train Loss=0.000727326 | Test Loss=0.035788284 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [422/1000] | Train Loss=0.000736989 | Test Loss=0.035644067 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [423/1000] | Train Loss=0.000719836 | Test Loss=0.035368815 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [424/1000] | Train Loss=0.000676340 | Test Loss=0.035678959 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [425/1000] | Train Loss=0.000690220 | Test Loss=0.035579106 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [426/1000] | Train Loss=0.000691986 | Test Loss=0.035605378 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [427/1000] | Train Loss=0.000669803 | Test Loss=0.035745793 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [428/1000] | Train Loss=0.000690018 | Test Loss=0.035695268 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [429/1000] | Train Loss=0.000674852 | Test Loss=0.035796131 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [430/1000] | Train Loss=0.000681124 | Test Loss=0.035651130 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [431/1000] | Train Loss=0.000721785 | Test Loss=0.035303045 | Time=1.83s | LR=1.95e-07\n",
      "Epoch [432/1000] | Train Loss=0.000679483 | Test Loss=0.035785391 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [433/1000] | Train Loss=0.000655351 | Test Loss=0.035681192 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [434/1000] | Train Loss=0.000678018 | Test Loss=0.035737206 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [435/1000] | Train Loss=0.000675714 | Test Loss=0.035772682 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [436/1000] | Train Loss=0.000691965 | Test Loss=0.035829113 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [437/1000] | Train Loss=0.000701312 | Test Loss=0.035698808 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [438/1000] | Train Loss=0.000682838 | Test Loss=0.035869132 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [439/1000] | Train Loss=0.000704764 | Test Loss=0.035612016 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [440/1000] | Train Loss=0.000701508 | Test Loss=0.035749704 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [441/1000] | Train Loss=0.000690920 | Test Loss=0.035441799 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [442/1000] | Train Loss=0.000706368 | Test Loss=0.035558741 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [443/1000] | Train Loss=0.000686015 | Test Loss=0.035528240 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [444/1000] | Train Loss=0.000757670 | Test Loss=0.035679332 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [445/1000] | Train Loss=0.000692351 | Test Loss=0.035635417 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [446/1000] | Train Loss=0.000663414 | Test Loss=0.035697054 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [447/1000] | Train Loss=0.000688394 | Test Loss=0.035562542 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [448/1000] | Train Loss=0.000688160 | Test Loss=0.035872509 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [449/1000] | Train Loss=0.000681576 | Test Loss=0.035579157 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [450/1000] | Train Loss=0.000689921 | Test Loss=0.035714985 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [451/1000] | Train Loss=0.000704339 | Test Loss=0.035531409 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [452/1000] | Train Loss=0.000744466 | Test Loss=0.035833159 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [453/1000] | Train Loss=0.000670492 | Test Loss=0.035682971 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [454/1000] | Train Loss=0.000674473 | Test Loss=0.035948775 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [455/1000] | Train Loss=0.000671926 | Test Loss=0.035582566 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [456/1000] | Train Loss=0.000689468 | Test Loss=0.035609704 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [457/1000] | Train Loss=0.000696401 | Test Loss=0.035453530 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [458/1000] | Train Loss=0.000697571 | Test Loss=0.035696637 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [459/1000] | Train Loss=0.000712414 | Test Loss=0.035323775 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [460/1000] | Train Loss=0.000719649 | Test Loss=0.035491126 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [461/1000] | Train Loss=0.000672336 | Test Loss=0.035529356 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [462/1000] | Train Loss=0.000756562 | Test Loss=0.035518881 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [463/1000] | Train Loss=0.000716167 | Test Loss=0.035593855 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [464/1000] | Train Loss=0.000697197 | Test Loss=0.035830947 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [465/1000] | Train Loss=0.000779443 | Test Loss=0.035301846 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [466/1000] | Train Loss=0.000657760 | Test Loss=0.035831989 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [467/1000] | Train Loss=0.000703894 | Test Loss=0.035518542 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [468/1000] | Train Loss=0.000675780 | Test Loss=0.035608187 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [469/1000] | Train Loss=0.000693178 | Test Loss=0.035865134 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [470/1000] | Train Loss=0.000668002 | Test Loss=0.035732441 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [471/1000] | Train Loss=0.000667919 | Test Loss=0.035695709 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [472/1000] | Train Loss=0.000752197 | Test Loss=0.035828470 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [473/1000] | Train Loss=0.000675889 | Test Loss=0.035505219 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [474/1000] | Train Loss=0.000706510 | Test Loss=0.035848882 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [475/1000] | Train Loss=0.000682940 | Test Loss=0.035556150 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [476/1000] | Train Loss=0.000777071 | Test Loss=0.035714942 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [477/1000] | Train Loss=0.000685736 | Test Loss=0.035569356 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [478/1000] | Train Loss=0.000698725 | Test Loss=0.035455588 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [479/1000] | Train Loss=0.000679366 | Test Loss=0.035568285 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [480/1000] | Train Loss=0.000661464 | Test Loss=0.035777259 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [481/1000] | Train Loss=0.000722343 | Test Loss=0.035981161 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [482/1000] | Train Loss=0.000667809 | Test Loss=0.035668269 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [483/1000] | Train Loss=0.000711725 | Test Loss=0.035891805 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [484/1000] | Train Loss=0.000684433 | Test Loss=0.035497756 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [485/1000] | Train Loss=0.000699615 | Test Loss=0.035666449 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [486/1000] | Train Loss=0.000662547 | Test Loss=0.035783710 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [487/1000] | Train Loss=0.000674739 | Test Loss=0.035391779 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [488/1000] | Train Loss=0.000692410 | Test Loss=0.035503100 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [489/1000] | Train Loss=0.000681621 | Test Loss=0.035480247 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [490/1000] | Train Loss=0.000697687 | Test Loss=0.035546302 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [491/1000] | Train Loss=0.000689558 | Test Loss=0.035808835 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [492/1000] | Train Loss=0.000664924 | Test Loss=0.035525936 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [493/1000] | Train Loss=0.000742389 | Test Loss=0.035552086 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [494/1000] | Train Loss=0.000681217 | Test Loss=0.035783008 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [495/1000] | Train Loss=0.000683137 | Test Loss=0.035608208 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [496/1000] | Train Loss=0.000705928 | Test Loss=0.035609225 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [497/1000] | Train Loss=0.000676019 | Test Loss=0.035629043 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [498/1000] | Train Loss=0.000677582 | Test Loss=0.035661522 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [499/1000] | Train Loss=0.000669337 | Test Loss=0.035625658 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [500/1000] | Train Loss=0.000658196 | Test Loss=0.035475069 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [501/1000] | Train Loss=0.000701222 | Test Loss=0.035588919 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [502/1000] | Train Loss=0.000748532 | Test Loss=0.035658332 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [503/1000] | Train Loss=0.000746716 | Test Loss=0.035460251 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [504/1000] | Train Loss=0.000672617 | Test Loss=0.035503551 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [505/1000] | Train Loss=0.000692039 | Test Loss=0.035774175 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [506/1000] | Train Loss=0.000703245 | Test Loss=0.035807216 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [507/1000] | Train Loss=0.000665376 | Test Loss=0.035849144 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [508/1000] | Train Loss=0.000705578 | Test Loss=0.035337295 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [509/1000] | Train Loss=0.000717842 | Test Loss=0.035735793 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [510/1000] | Train Loss=0.000657583 | Test Loss=0.035714492 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [511/1000] | Train Loss=0.000695898 | Test Loss=0.035448179 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [512/1000] | Train Loss=0.000646724 | Test Loss=0.035621060 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [513/1000] | Train Loss=0.000691006 | Test Loss=0.035619320 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [514/1000] | Train Loss=0.000691301 | Test Loss=0.035588857 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [515/1000] | Train Loss=0.000649272 | Test Loss=0.035886258 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [516/1000] | Train Loss=0.000711247 | Test Loss=0.035661910 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [517/1000] | Train Loss=0.000683522 | Test Loss=0.035823697 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [518/1000] | Train Loss=0.000679961 | Test Loss=0.035843543 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [519/1000] | Train Loss=0.000705685 | Test Loss=0.035809889 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [520/1000] | Train Loss=0.000663122 | Test Loss=0.035600655 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [521/1000] | Train Loss=0.000668270 | Test Loss=0.035599329 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [522/1000] | Train Loss=0.000691934 | Test Loss=0.035956468 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [523/1000] | Train Loss=0.000681299 | Test Loss=0.035477969 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [524/1000] | Train Loss=0.000677113 | Test Loss=0.035967966 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [525/1000] | Train Loss=0.000689025 | Test Loss=0.035617079 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [526/1000] | Train Loss=0.000708789 | Test Loss=0.035374494 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [527/1000] | Train Loss=0.000756881 | Test Loss=0.035416159 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [528/1000] | Train Loss=0.000700358 | Test Loss=0.035693995 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [529/1000] | Train Loss=0.000699650 | Test Loss=0.035654339 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [530/1000] | Train Loss=0.000725186 | Test Loss=0.035659780 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [531/1000] | Train Loss=0.000674041 | Test Loss=0.035844395 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [532/1000] | Train Loss=0.000668177 | Test Loss=0.035938717 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [533/1000] | Train Loss=0.000673269 | Test Loss=0.035784111 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [534/1000] | Train Loss=0.000725158 | Test Loss=0.035703349 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [535/1000] | Train Loss=0.000732044 | Test Loss=0.035260513 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [536/1000] | Train Loss=0.000668796 | Test Loss=0.035864848 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [537/1000] | Train Loss=0.000655424 | Test Loss=0.035549136 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [538/1000] | Train Loss=0.000734727 | Test Loss=0.035624739 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [539/1000] | Train Loss=0.000691988 | Test Loss=0.035444757 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [540/1000] | Train Loss=0.000730116 | Test Loss=0.035624267 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [541/1000] | Train Loss=0.000704355 | Test Loss=0.035538672 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [542/1000] | Train Loss=0.000692458 | Test Loss=0.035591046 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [543/1000] | Train Loss=0.000733847 | Test Loss=0.035551302 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [544/1000] | Train Loss=0.000669189 | Test Loss=0.035729656 | Time=1.80s | LR=1.22e-08\n",
      "Epoch [545/1000] | Train Loss=0.000686655 | Test Loss=0.035630302 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [546/1000] | Train Loss=0.000678336 | Test Loss=0.035331284 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [547/1000] | Train Loss=0.000679928 | Test Loss=0.035483755 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [548/1000] | Train Loss=0.000689151 | Test Loss=0.035355439 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [549/1000] | Train Loss=0.000671856 | Test Loss=0.035782401 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [550/1000] | Train Loss=0.000685009 | Test Loss=0.035610132 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [551/1000] | Train Loss=0.000688389 | Test Loss=0.035689466 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [552/1000] | Train Loss=0.000684380 | Test Loss=0.035652042 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [553/1000] | Train Loss=0.000822504 | Test Loss=0.035810169 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [554/1000] | Train Loss=0.000765153 | Test Loss=0.035294879 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [555/1000] | Train Loss=0.000720285 | Test Loss=0.035746250 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [556/1000] | Train Loss=0.000683054 | Test Loss=0.035478491 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [557/1000] | Train Loss=0.000670949 | Test Loss=0.035580737 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [558/1000] | Train Loss=0.000679508 | Test Loss=0.035721867 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [559/1000] | Train Loss=0.000687121 | Test Loss=0.035612999 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [560/1000] | Train Loss=0.000734753 | Test Loss=0.035549489 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [561/1000] | Train Loss=0.000686657 | Test Loss=0.035626354 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [562/1000] | Train Loss=0.000697041 | Test Loss=0.035782879 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [563/1000] | Train Loss=0.000770015 | Test Loss=0.035810169 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [564/1000] | Train Loss=0.000667577 | Test Loss=0.035620424 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [565/1000] | Train Loss=0.000704936 | Test Loss=0.035540818 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [566/1000] | Train Loss=0.000674081 | Test Loss=0.035798980 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [567/1000] | Train Loss=0.000673685 | Test Loss=0.035952695 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [568/1000] | Train Loss=0.000666270 | Test Loss=0.035253033 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [569/1000] | Train Loss=0.000723773 | Test Loss=0.035543267 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [570/1000] | Train Loss=0.000674848 | Test Loss=0.035583843 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [571/1000] | Train Loss=0.000688851 | Test Loss=0.035345623 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [572/1000] | Train Loss=0.000695443 | Test Loss=0.035543955 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [573/1000] | Train Loss=0.000767485 | Test Loss=0.035600449 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [574/1000] | Train Loss=0.000722924 | Test Loss=0.035584463 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [575/1000] | Train Loss=0.000663589 | Test Loss=0.035643449 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [576/1000] | Train Loss=0.000682301 | Test Loss=0.035865535 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [577/1000] | Train Loss=0.000669724 | Test Loss=0.035803652 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [578/1000] | Train Loss=0.000684525 | Test Loss=0.035578035 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [579/1000] | Train Loss=0.000702418 | Test Loss=0.035787012 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [580/1000] | Train Loss=0.000709145 | Test Loss=0.035626782 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [581/1000] | Train Loss=0.000688595 | Test Loss=0.035588909 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [582/1000] | Train Loss=0.000687503 | Test Loss=0.035791485 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [583/1000] | Train Loss=0.000698827 | Test Loss=0.035804240 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [584/1000] | Train Loss=0.000674427 | Test Loss=0.035789854 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [585/1000] | Train Loss=0.000687257 | Test Loss=0.035461036 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [586/1000] | Train Loss=0.000669772 | Test Loss=0.035639437 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [587/1000] | Train Loss=0.000757938 | Test Loss=0.035694991 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [588/1000] | Train Loss=0.000679357 | Test Loss=0.035731601 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [589/1000] | Train Loss=0.000760500 | Test Loss=0.035795567 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [590/1000] | Train Loss=0.000684242 | Test Loss=0.035941839 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [591/1000] | Train Loss=0.000709078 | Test Loss=0.035604102 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [592/1000] | Train Loss=0.000661651 | Test Loss=0.035845831 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [593/1000] | Train Loss=0.000664549 | Test Loss=0.035498381 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [594/1000] | Train Loss=0.000683375 | Test Loss=0.035440274 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [595/1000] | Train Loss=0.000725954 | Test Loss=0.035542887 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [596/1000] | Train Loss=0.000711700 | Test Loss=0.035784969 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [597/1000] | Train Loss=0.000693357 | Test Loss=0.035642971 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [598/1000] | Train Loss=0.000716390 | Test Loss=0.035711031 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [599/1000] | Train Loss=0.000701082 | Test Loss=0.035497880 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [600/1000] | Train Loss=0.000691123 | Test Loss=0.035471154 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [601/1000] | Train Loss=0.000697075 | Test Loss=0.035649426 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [602/1000] | Train Loss=0.000676605 | Test Loss=0.035712782 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [603/1000] | Train Loss=0.000719392 | Test Loss=0.035406980 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [604/1000] | Train Loss=0.000695719 | Test Loss=0.035422706 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [605/1000] | Train Loss=0.000706956 | Test Loss=0.035871530 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [606/1000] | Train Loss=0.000709417 | Test Loss=0.035428682 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [607/1000] | Train Loss=0.000717527 | Test Loss=0.035480198 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [608/1000] | Train Loss=0.000664265 | Test Loss=0.035661569 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [609/1000] | Train Loss=0.000700860 | Test Loss=0.035764133 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [610/1000] | Train Loss=0.000693696 | Test Loss=0.035609946 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [611/1000] | Train Loss=0.000652865 | Test Loss=0.036063310 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [612/1000] | Train Loss=0.000678759 | Test Loss=0.035480610 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [613/1000] | Train Loss=0.000717838 | Test Loss=0.035673974 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [614/1000] | Train Loss=0.000748909 | Test Loss=0.035267307 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [615/1000] | Train Loss=0.000667996 | Test Loss=0.035840562 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [616/1000] | Train Loss=0.000680762 | Test Loss=0.035614107 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [617/1000] | Train Loss=0.000687074 | Test Loss=0.035527077 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [618/1000] | Train Loss=0.000721573 | Test Loss=0.035572823 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [619/1000] | Train Loss=0.000746094 | Test Loss=0.035631846 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [620/1000] | Train Loss=0.000711457 | Test Loss=0.035626029 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [621/1000] | Train Loss=0.000656720 | Test Loss=0.035782079 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [622/1000] | Train Loss=0.000690813 | Test Loss=0.035541576 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [623/1000] | Train Loss=0.000714905 | Test Loss=0.035191958 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [624/1000] | Train Loss=0.000676605 | Test Loss=0.035709552 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [625/1000] | Train Loss=0.000706368 | Test Loss=0.035649782 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [626/1000] | Train Loss=0.000669828 | Test Loss=0.035801760 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [627/1000] | Train Loss=0.000698582 | Test Loss=0.035765284 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [628/1000] | Train Loss=0.000713919 | Test Loss=0.035400640 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [629/1000] | Train Loss=0.000734390 | Test Loss=0.035594855 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [630/1000] | Train Loss=0.000684539 | Test Loss=0.035525455 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [631/1000] | Train Loss=0.000681721 | Test Loss=0.035723378 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [632/1000] | Train Loss=0.000663691 | Test Loss=0.035463489 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [633/1000] | Train Loss=0.000692798 | Test Loss=0.035542648 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [634/1000] | Train Loss=0.000717405 | Test Loss=0.035668746 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [635/1000] | Train Loss=0.000708555 | Test Loss=0.035392012 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [636/1000] | Train Loss=0.000685581 | Test Loss=0.035814240 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [637/1000] | Train Loss=0.000757259 | Test Loss=0.035529682 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [638/1000] | Train Loss=0.000686285 | Test Loss=0.035533563 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [639/1000] | Train Loss=0.000697353 | Test Loss=0.035661335 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [640/1000] | Train Loss=0.000690350 | Test Loss=0.035666548 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [641/1000] | Train Loss=0.000685051 | Test Loss=0.035461084 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [642/1000] | Train Loss=0.000690126 | Test Loss=0.035532741 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [643/1000] | Train Loss=0.000701272 | Test Loss=0.035724654 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [644/1000] | Train Loss=0.000695523 | Test Loss=0.035520824 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [645/1000] | Train Loss=0.000655798 | Test Loss=0.035357685 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [646/1000] | Train Loss=0.000686742 | Test Loss=0.035661932 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [647/1000] | Train Loss=0.000699261 | Test Loss=0.035897243 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [648/1000] | Train Loss=0.000647133 | Test Loss=0.035750244 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [649/1000] | Train Loss=0.000661636 | Test Loss=0.035530532 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [650/1000] | Train Loss=0.000653999 | Test Loss=0.035801977 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [651/1000] | Train Loss=0.000677495 | Test Loss=0.035626818 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [652/1000] | Train Loss=0.000752089 | Test Loss=0.035534844 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [653/1000] | Train Loss=0.000731805 | Test Loss=0.035901929 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [654/1000] | Train Loss=0.000660429 | Test Loss=0.035598523 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [655/1000] | Train Loss=0.000692130 | Test Loss=0.035660578 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [656/1000] | Train Loss=0.000674163 | Test Loss=0.035454137 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [657/1000] | Train Loss=0.000670519 | Test Loss=0.035548354 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [658/1000] | Train Loss=0.000696145 | Test Loss=0.035643168 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [659/1000] | Train Loss=0.000700041 | Test Loss=0.035815861 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [660/1000] | Train Loss=0.000689388 | Test Loss=0.035682827 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [661/1000] | Train Loss=0.000680490 | Test Loss=0.035777906 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [662/1000] | Train Loss=0.000663898 | Test Loss=0.035571579 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [663/1000] | Train Loss=0.000702290 | Test Loss=0.035640844 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [664/1000] | Train Loss=0.000690623 | Test Loss=0.035476916 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [665/1000] | Train Loss=0.000689963 | Test Loss=0.035492146 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [666/1000] | Train Loss=0.000689488 | Test Loss=0.035680096 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [667/1000] | Train Loss=0.000662737 | Test Loss=0.035722948 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [668/1000] | Train Loss=0.000670713 | Test Loss=0.035596986 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [669/1000] | Train Loss=0.000668837 | Test Loss=0.035628569 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [670/1000] | Train Loss=0.000715256 | Test Loss=0.035762136 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [671/1000] | Train Loss=0.000696020 | Test Loss=0.035547493 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [672/1000] | Train Loss=0.000677226 | Test Loss=0.035636722 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [673/1000] | Train Loss=0.000725626 | Test Loss=0.035491015 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [674/1000] | Train Loss=0.000760628 | Test Loss=0.035707885 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [675/1000] | Train Loss=0.000717205 | Test Loss=0.035350302 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [676/1000] | Train Loss=0.000732311 | Test Loss=0.035504600 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [677/1000] | Train Loss=0.000671584 | Test Loss=0.035452522 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [678/1000] | Train Loss=0.000719103 | Test Loss=0.035546585 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [679/1000] | Train Loss=0.000658477 | Test Loss=0.035609150 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [680/1000] | Train Loss=0.000687578 | Test Loss=0.035675705 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [681/1000] | Train Loss=0.000710756 | Test Loss=0.035823562 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [682/1000] | Train Loss=0.000689204 | Test Loss=0.035843257 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [683/1000] | Train Loss=0.000703683 | Test Loss=0.035636614 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [684/1000] | Train Loss=0.000705959 | Test Loss=0.035496318 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [685/1000] | Train Loss=0.000684281 | Test Loss=0.035694829 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [686/1000] | Train Loss=0.000773249 | Test Loss=0.035418855 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [687/1000] | Train Loss=0.000704944 | Test Loss=0.035731998 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [688/1000] | Train Loss=0.000787303 | Test Loss=0.035685548 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [689/1000] | Train Loss=0.000658468 | Test Loss=0.035684314 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [690/1000] | Train Loss=0.000704665 | Test Loss=0.035871572 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [691/1000] | Train Loss=0.000662378 | Test Loss=0.035741765 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [692/1000] | Train Loss=0.000704801 | Test Loss=0.035640392 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [693/1000] | Train Loss=0.000651379 | Test Loss=0.035668237 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [694/1000] | Train Loss=0.000679996 | Test Loss=0.035575221 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [695/1000] | Train Loss=0.000688951 | Test Loss=0.035547685 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [696/1000] | Train Loss=0.000666924 | Test Loss=0.035555341 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [697/1000] | Train Loss=0.000720437 | Test Loss=0.035779559 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [698/1000] | Train Loss=0.000690121 | Test Loss=0.035496046 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [699/1000] | Train Loss=0.000677623 | Test Loss=0.035684875 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [700/1000] | Train Loss=0.000682294 | Test Loss=0.035705462 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [701/1000] | Train Loss=0.000663705 | Test Loss=0.035535620 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [702/1000] | Train Loss=0.000670708 | Test Loss=0.035421660 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [703/1000] | Train Loss=0.000694191 | Test Loss=0.035417649 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [704/1000] | Train Loss=0.000682965 | Test Loss=0.035755912 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [705/1000] | Train Loss=0.000677855 | Test Loss=0.035890894 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [706/1000] | Train Loss=0.000668421 | Test Loss=0.035909394 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [707/1000] | Train Loss=0.000762118 | Test Loss=0.035624100 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [708/1000] | Train Loss=0.000663658 | Test Loss=0.035776407 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [709/1000] | Train Loss=0.000660528 | Test Loss=0.035319685 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [710/1000] | Train Loss=0.000720904 | Test Loss=0.035644326 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [711/1000] | Train Loss=0.000715009 | Test Loss=0.035778618 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [712/1000] | Train Loss=0.000684539 | Test Loss=0.035666129 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [713/1000] | Train Loss=0.000679266 | Test Loss=0.035519334 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [714/1000] | Train Loss=0.000716852 | Test Loss=0.035322430 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [715/1000] | Train Loss=0.000699615 | Test Loss=0.035355343 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [716/1000] | Train Loss=0.000697723 | Test Loss=0.035641710 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [717/1000] | Train Loss=0.000681767 | Test Loss=0.035618904 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [718/1000] | Train Loss=0.000669178 | Test Loss=0.035835160 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [719/1000] | Train Loss=0.000670662 | Test Loss=0.035769399 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [720/1000] | Train Loss=0.000675690 | Test Loss=0.035596057 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [721/1000] | Train Loss=0.000759403 | Test Loss=0.035574115 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [722/1000] | Train Loss=0.000683927 | Test Loss=0.035623193 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [723/1000] | Train Loss=0.000695339 | Test Loss=0.035570940 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [724/1000] | Train Loss=0.000658540 | Test Loss=0.035686612 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [725/1000] | Train Loss=0.000661096 | Test Loss=0.035698502 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [726/1000] | Train Loss=0.000678569 | Test Loss=0.035716098 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [727/1000] | Train Loss=0.000761825 | Test Loss=0.035488058 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [728/1000] | Train Loss=0.000667632 | Test Loss=0.035775688 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [729/1000] | Train Loss=0.000679376 | Test Loss=0.035374118 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [730/1000] | Train Loss=0.000731883 | Test Loss=0.035661650 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [731/1000] | Train Loss=0.000695332 | Test Loss=0.035638118 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [732/1000] | Train Loss=0.000735820 | Test Loss=0.035478230 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [733/1000] | Train Loss=0.000681053 | Test Loss=0.035340613 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [734/1000] | Train Loss=0.000659541 | Test Loss=0.035734757 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [735/1000] | Train Loss=0.000709384 | Test Loss=0.035696888 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [736/1000] | Train Loss=0.000697671 | Test Loss=0.035546633 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [737/1000] | Train Loss=0.000660868 | Test Loss=0.035609989 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [738/1000] | Train Loss=0.000673031 | Test Loss=0.035612331 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [739/1000] | Train Loss=0.000666576 | Test Loss=0.035842054 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [740/1000] | Train Loss=0.000701424 | Test Loss=0.035466354 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [741/1000] | Train Loss=0.000680541 | Test Loss=0.035688249 | Time=1.80s | LR=1.22e-08\n",
      "Epoch [742/1000] | Train Loss=0.000719946 | Test Loss=0.035841365 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [743/1000] | Train Loss=0.000691890 | Test Loss=0.035665184 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [744/1000] | Train Loss=0.000690730 | Test Loss=0.035654229 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [745/1000] | Train Loss=0.000677155 | Test Loss=0.035740920 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [746/1000] | Train Loss=0.000678242 | Test Loss=0.035868579 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [747/1000] | Train Loss=0.000728489 | Test Loss=0.035533854 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [748/1000] | Train Loss=0.000691586 | Test Loss=0.035784045 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [749/1000] | Train Loss=0.000681246 | Test Loss=0.035602446 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [750/1000] | Train Loss=0.000750040 | Test Loss=0.035928012 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [751/1000] | Train Loss=0.000696909 | Test Loss=0.035556144 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [752/1000] | Train Loss=0.000661949 | Test Loss=0.035942848 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [753/1000] | Train Loss=0.000696081 | Test Loss=0.035870428 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [754/1000] | Train Loss=0.000686060 | Test Loss=0.035416439 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [755/1000] | Train Loss=0.000685375 | Test Loss=0.035699832 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [756/1000] | Train Loss=0.000780785 | Test Loss=0.035632405 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [757/1000] | Train Loss=0.000737713 | Test Loss=0.035622337 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [758/1000] | Train Loss=0.000665572 | Test Loss=0.035591783 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [759/1000] | Train Loss=0.000662679 | Test Loss=0.035781228 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [760/1000] | Train Loss=0.000685602 | Test Loss=0.035557224 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [761/1000] | Train Loss=0.000683930 | Test Loss=0.035513576 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [762/1000] | Train Loss=0.000703105 | Test Loss=0.035727577 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [763/1000] | Train Loss=0.000728858 | Test Loss=0.035640333 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [764/1000] | Train Loss=0.000655374 | Test Loss=0.035728495 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [765/1000] | Train Loss=0.000739009 | Test Loss=0.035540087 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [766/1000] | Train Loss=0.000710071 | Test Loss=0.035734499 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [767/1000] | Train Loss=0.000749454 | Test Loss=0.035467398 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [768/1000] | Train Loss=0.000667648 | Test Loss=0.035698931 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [769/1000] | Train Loss=0.000654046 | Test Loss=0.035746681 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [770/1000] | Train Loss=0.000668860 | Test Loss=0.035763209 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [771/1000] | Train Loss=0.000658090 | Test Loss=0.035575328 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [772/1000] | Train Loss=0.000681733 | Test Loss=0.035791987 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [773/1000] | Train Loss=0.000671867 | Test Loss=0.035755477 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [774/1000] | Train Loss=0.000658753 | Test Loss=0.035706740 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [775/1000] | Train Loss=0.000685626 | Test Loss=0.035562764 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [776/1000] | Train Loss=0.000674680 | Test Loss=0.035531227 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [777/1000] | Train Loss=0.000678969 | Test Loss=0.035647047 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [778/1000] | Train Loss=0.000682017 | Test Loss=0.035698425 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [779/1000] | Train Loss=0.000674755 | Test Loss=0.035643717 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [780/1000] | Train Loss=0.000689243 | Test Loss=0.035664421 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [781/1000] | Train Loss=0.000742617 | Test Loss=0.035342008 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [782/1000] | Train Loss=0.000686025 | Test Loss=0.035781877 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [783/1000] | Train Loss=0.000681590 | Test Loss=0.035864547 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [784/1000] | Train Loss=0.000713360 | Test Loss=0.035652586 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [785/1000] | Train Loss=0.000713430 | Test Loss=0.035951598 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [786/1000] | Train Loss=0.000726616 | Test Loss=0.035674658 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [787/1000] | Train Loss=0.000652265 | Test Loss=0.035756352 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [788/1000] | Train Loss=0.000681575 | Test Loss=0.035710636 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [789/1000] | Train Loss=0.000711694 | Test Loss=0.035719944 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [790/1000] | Train Loss=0.000679036 | Test Loss=0.035644708 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [791/1000] | Train Loss=0.000670309 | Test Loss=0.035540374 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [792/1000] | Train Loss=0.000716688 | Test Loss=0.035694280 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [793/1000] | Train Loss=0.000668637 | Test Loss=0.035655140 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [794/1000] | Train Loss=0.000711065 | Test Loss=0.035508641 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [795/1000] | Train Loss=0.000691758 | Test Loss=0.035690133 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [796/1000] | Train Loss=0.000700449 | Test Loss=0.035696956 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [797/1000] | Train Loss=0.000656360 | Test Loss=0.035779573 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [798/1000] | Train Loss=0.000660028 | Test Loss=0.035629496 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [799/1000] | Train Loss=0.000684621 | Test Loss=0.035653709 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [800/1000] | Train Loss=0.000707855 | Test Loss=0.035659317 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [801/1000] | Train Loss=0.000664964 | Test Loss=0.035747629 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [802/1000] | Train Loss=0.000713615 | Test Loss=0.035678734 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [803/1000] | Train Loss=0.000692731 | Test Loss=0.035540713 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [804/1000] | Train Loss=0.000674598 | Test Loss=0.035797659 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [805/1000] | Train Loss=0.000698759 | Test Loss=0.035559408 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [806/1000] | Train Loss=0.000653706 | Test Loss=0.035771425 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [807/1000] | Train Loss=0.000685876 | Test Loss=0.035660495 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [808/1000] | Train Loss=0.000664026 | Test Loss=0.035569179 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [809/1000] | Train Loss=0.000701441 | Test Loss=0.035822812 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [810/1000] | Train Loss=0.000738076 | Test Loss=0.035591041 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [811/1000] | Train Loss=0.000691150 | Test Loss=0.035927724 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [812/1000] | Train Loss=0.000680618 | Test Loss=0.035575165 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [813/1000] | Train Loss=0.000695064 | Test Loss=0.035645897 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [814/1000] | Train Loss=0.000685745 | Test Loss=0.035393052 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [815/1000] | Train Loss=0.000683656 | Test Loss=0.035748272 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [816/1000] | Train Loss=0.000751940 | Test Loss=0.035524821 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [817/1000] | Train Loss=0.000696297 | Test Loss=0.035535047 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [818/1000] | Train Loss=0.000830752 | Test Loss=0.035838584 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [819/1000] | Train Loss=0.000687531 | Test Loss=0.035796105 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [820/1000] | Train Loss=0.000699467 | Test Loss=0.035729823 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [821/1000] | Train Loss=0.000738078 | Test Loss=0.035299959 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [822/1000] | Train Loss=0.000662018 | Test Loss=0.035607356 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [823/1000] | Train Loss=0.000750328 | Test Loss=0.035732122 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [824/1000] | Train Loss=0.000675398 | Test Loss=0.035708502 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [825/1000] | Train Loss=0.000679455 | Test Loss=0.035536382 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [826/1000] | Train Loss=0.000676946 | Test Loss=0.035608325 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [827/1000] | Train Loss=0.000746583 | Test Loss=0.035561254 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [828/1000] | Train Loss=0.000670898 | Test Loss=0.035829039 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [829/1000] | Train Loss=0.000682710 | Test Loss=0.035488453 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [830/1000] | Train Loss=0.000725149 | Test Loss=0.035606482 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [831/1000] | Train Loss=0.000690152 | Test Loss=0.035627086 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [832/1000] | Train Loss=0.000642224 | Test Loss=0.035844978 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [833/1000] | Train Loss=0.000707878 | Test Loss=0.035792874 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [834/1000] | Train Loss=0.000720874 | Test Loss=0.035726465 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [835/1000] | Train Loss=0.000711500 | Test Loss=0.035783927 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [836/1000] | Train Loss=0.000661246 | Test Loss=0.035517549 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [837/1000] | Train Loss=0.000703082 | Test Loss=0.035875042 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [838/1000] | Train Loss=0.000685220 | Test Loss=0.035629703 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [839/1000] | Train Loss=0.000691798 | Test Loss=0.035467952 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [840/1000] | Train Loss=0.000688391 | Test Loss=0.035453878 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [841/1000] | Train Loss=0.000669327 | Test Loss=0.035857385 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [842/1000] | Train Loss=0.000661609 | Test Loss=0.035733129 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [843/1000] | Train Loss=0.000651141 | Test Loss=0.035645756 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [844/1000] | Train Loss=0.000671502 | Test Loss=0.035830441 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [845/1000] | Train Loss=0.000665580 | Test Loss=0.035828047 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [846/1000] | Train Loss=0.000686673 | Test Loss=0.035686626 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [847/1000] | Train Loss=0.000684763 | Test Loss=0.035553927 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [848/1000] | Train Loss=0.000697083 | Test Loss=0.035681277 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [849/1000] | Train Loss=0.000670870 | Test Loss=0.035770994 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [850/1000] | Train Loss=0.000665884 | Test Loss=0.035653331 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [851/1000] | Train Loss=0.000678124 | Test Loss=0.035624376 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [852/1000] | Train Loss=0.000689356 | Test Loss=0.035655622 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [853/1000] | Train Loss=0.000675722 | Test Loss=0.035694912 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [854/1000] | Train Loss=0.000670183 | Test Loss=0.035379949 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [855/1000] | Train Loss=0.000698829 | Test Loss=0.035641277 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [856/1000] | Train Loss=0.000679746 | Test Loss=0.035687213 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [857/1000] | Train Loss=0.000678656 | Test Loss=0.035731737 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [858/1000] | Train Loss=0.000673416 | Test Loss=0.035590548 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [859/1000] | Train Loss=0.000690331 | Test Loss=0.035774538 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [860/1000] | Train Loss=0.000684973 | Test Loss=0.035460484 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [861/1000] | Train Loss=0.000751610 | Test Loss=0.035775982 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [862/1000] | Train Loss=0.000684829 | Test Loss=0.035784053 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [863/1000] | Train Loss=0.000665184 | Test Loss=0.035774905 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [864/1000] | Train Loss=0.000703090 | Test Loss=0.035466890 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [865/1000] | Train Loss=0.000696443 | Test Loss=0.035511640 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [866/1000] | Train Loss=0.000686581 | Test Loss=0.035870714 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [867/1000] | Train Loss=0.000675024 | Test Loss=0.035835526 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [868/1000] | Train Loss=0.000704321 | Test Loss=0.035745943 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [869/1000] | Train Loss=0.000678468 | Test Loss=0.035673844 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [870/1000] | Train Loss=0.000718419 | Test Loss=0.035398651 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [871/1000] | Train Loss=0.000722059 | Test Loss=0.035749335 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [872/1000] | Train Loss=0.000701234 | Test Loss=0.035643374 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [873/1000] | Train Loss=0.000677514 | Test Loss=0.035528766 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [874/1000] | Train Loss=0.000677173 | Test Loss=0.035804329 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [875/1000] | Train Loss=0.000674606 | Test Loss=0.035545559 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [876/1000] | Train Loss=0.000695968 | Test Loss=0.035530267 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [877/1000] | Train Loss=0.000689123 | Test Loss=0.035491031 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [878/1000] | Train Loss=0.000696899 | Test Loss=0.035545366 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [879/1000] | Train Loss=0.000687106 | Test Loss=0.035876433 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [880/1000] | Train Loss=0.000687674 | Test Loss=0.035468827 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [881/1000] | Train Loss=0.000710781 | Test Loss=0.035763197 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [882/1000] | Train Loss=0.000681165 | Test Loss=0.035607255 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [883/1000] | Train Loss=0.000684931 | Test Loss=0.035740429 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [884/1000] | Train Loss=0.000682759 | Test Loss=0.035555795 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [885/1000] | Train Loss=0.000695443 | Test Loss=0.035622766 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [886/1000] | Train Loss=0.000687570 | Test Loss=0.035741411 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [887/1000] | Train Loss=0.000665086 | Test Loss=0.035403441 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [888/1000] | Train Loss=0.000719156 | Test Loss=0.035813907 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [889/1000] | Train Loss=0.000654647 | Test Loss=0.035642349 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [890/1000] | Train Loss=0.000656074 | Test Loss=0.035491927 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [891/1000] | Train Loss=0.000699243 | Test Loss=0.035581542 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [892/1000] | Train Loss=0.000675655 | Test Loss=0.035702206 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [893/1000] | Train Loss=0.000696624 | Test Loss=0.035352702 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [894/1000] | Train Loss=0.000679420 | Test Loss=0.035624009 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [895/1000] | Train Loss=0.000653606 | Test Loss=0.035836959 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [896/1000] | Train Loss=0.000687858 | Test Loss=0.035789149 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [897/1000] | Train Loss=0.000672392 | Test Loss=0.035551063 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [898/1000] | Train Loss=0.000684579 | Test Loss=0.035659217 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [899/1000] | Train Loss=0.000718532 | Test Loss=0.035824449 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [900/1000] | Train Loss=0.000683822 | Test Loss=0.035816890 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [901/1000] | Train Loss=0.000708634 | Test Loss=0.035801938 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [902/1000] | Train Loss=0.000714814 | Test Loss=0.035398350 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [903/1000] | Train Loss=0.000694963 | Test Loss=0.035558018 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [904/1000] | Train Loss=0.000666762 | Test Loss=0.035567923 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [905/1000] | Train Loss=0.000677150 | Test Loss=0.035616818 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [906/1000] | Train Loss=0.000722988 | Test Loss=0.035609975 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [907/1000] | Train Loss=0.000672164 | Test Loss=0.035812326 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [908/1000] | Train Loss=0.000796230 | Test Loss=0.036003312 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [909/1000] | Train Loss=0.000725625 | Test Loss=0.035313462 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [910/1000] | Train Loss=0.000706595 | Test Loss=0.035626764 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [911/1000] | Train Loss=0.000662120 | Test Loss=0.035594636 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [912/1000] | Train Loss=0.000761898 | Test Loss=0.035814836 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [913/1000] | Train Loss=0.000689176 | Test Loss=0.035574706 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [914/1000] | Train Loss=0.000679554 | Test Loss=0.035668221 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [915/1000] | Train Loss=0.000737335 | Test Loss=0.035738110 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [916/1000] | Train Loss=0.000683241 | Test Loss=0.035545236 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [917/1000] | Train Loss=0.000700675 | Test Loss=0.035813362 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [918/1000] | Train Loss=0.000718996 | Test Loss=0.035640655 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [919/1000] | Train Loss=0.000699975 | Test Loss=0.035467772 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [920/1000] | Train Loss=0.000694904 | Test Loss=0.035779396 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [921/1000] | Train Loss=0.000704280 | Test Loss=0.035547972 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [922/1000] | Train Loss=0.000679628 | Test Loss=0.035427759 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [923/1000] | Train Loss=0.000699573 | Test Loss=0.035783155 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [924/1000] | Train Loss=0.000712820 | Test Loss=0.035647686 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [925/1000] | Train Loss=0.000680895 | Test Loss=0.035650099 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [926/1000] | Train Loss=0.000726957 | Test Loss=0.035762642 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [927/1000] | Train Loss=0.000684458 | Test Loss=0.035708204 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [928/1000] | Train Loss=0.000677195 | Test Loss=0.035691075 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [929/1000] | Train Loss=0.000712753 | Test Loss=0.035591920 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [930/1000] | Train Loss=0.000663748 | Test Loss=0.035550211 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [931/1000] | Train Loss=0.000731190 | Test Loss=0.035860802 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [932/1000] | Train Loss=0.000687002 | Test Loss=0.035628628 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [933/1000] | Train Loss=0.000668902 | Test Loss=0.035610146 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [934/1000] | Train Loss=0.000667391 | Test Loss=0.035578259 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [935/1000] | Train Loss=0.000678109 | Test Loss=0.035728610 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [936/1000] | Train Loss=0.000677330 | Test Loss=0.035681852 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [937/1000] | Train Loss=0.000709526 | Test Loss=0.035466324 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [938/1000] | Train Loss=0.000694849 | Test Loss=0.035555770 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [939/1000] | Train Loss=0.000689251 | Test Loss=0.035616018 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [940/1000] | Train Loss=0.000672354 | Test Loss=0.035632909 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [941/1000] | Train Loss=0.000672066 | Test Loss=0.035674891 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [942/1000] | Train Loss=0.000672368 | Test Loss=0.035675890 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [943/1000] | Train Loss=0.000694973 | Test Loss=0.035692290 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [944/1000] | Train Loss=0.000665557 | Test Loss=0.035653236 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [945/1000] | Train Loss=0.000677390 | Test Loss=0.035599317 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [946/1000] | Train Loss=0.000677391 | Test Loss=0.035470630 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [947/1000] | Train Loss=0.000702921 | Test Loss=0.035936034 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [948/1000] | Train Loss=0.000689370 | Test Loss=0.035535785 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [949/1000] | Train Loss=0.000712655 | Test Loss=0.035433106 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [950/1000] | Train Loss=0.000692792 | Test Loss=0.035728320 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [951/1000] | Train Loss=0.000702874 | Test Loss=0.035650547 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [952/1000] | Train Loss=0.000682426 | Test Loss=0.035649721 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [953/1000] | Train Loss=0.000686423 | Test Loss=0.035596288 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [954/1000] | Train Loss=0.000657202 | Test Loss=0.035694643 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [955/1000] | Train Loss=0.000751447 | Test Loss=0.035610297 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [956/1000] | Train Loss=0.000680154 | Test Loss=0.035650940 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [957/1000] | Train Loss=0.000744216 | Test Loss=0.035436539 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [958/1000] | Train Loss=0.000690618 | Test Loss=0.035605383 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [959/1000] | Train Loss=0.000676471 | Test Loss=0.035326284 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [960/1000] | Train Loss=0.000675326 | Test Loss=0.035523941 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [961/1000] | Train Loss=0.000711289 | Test Loss=0.035608060 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [962/1000] | Train Loss=0.000658536 | Test Loss=0.035654747 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [963/1000] | Train Loss=0.000692056 | Test Loss=0.035886602 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [964/1000] | Train Loss=0.000678820 | Test Loss=0.035727808 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [965/1000] | Train Loss=0.000741198 | Test Loss=0.035693955 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [966/1000] | Train Loss=0.000678159 | Test Loss=0.035528865 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [967/1000] | Train Loss=0.000693512 | Test Loss=0.035456932 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [968/1000] | Train Loss=0.000673138 | Test Loss=0.035521131 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [969/1000] | Train Loss=0.000656907 | Test Loss=0.035839732 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [970/1000] | Train Loss=0.000714543 | Test Loss=0.035767973 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [971/1000] | Train Loss=0.000734505 | Test Loss=0.035587176 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [972/1000] | Train Loss=0.000686886 | Test Loss=0.035473721 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [973/1000] | Train Loss=0.000682642 | Test Loss=0.035877113 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [974/1000] | Train Loss=0.000668074 | Test Loss=0.035802726 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [975/1000] | Train Loss=0.000690132 | Test Loss=0.035608591 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [976/1000] | Train Loss=0.000714669 | Test Loss=0.035450955 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [977/1000] | Train Loss=0.000661659 | Test Loss=0.035971395 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [978/1000] | Train Loss=0.000698410 | Test Loss=0.036045380 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [979/1000] | Train Loss=0.000678072 | Test Loss=0.035660341 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [980/1000] | Train Loss=0.000726810 | Test Loss=0.035686825 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [981/1000] | Train Loss=0.000681259 | Test Loss=0.035792705 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [982/1000] | Train Loss=0.000701841 | Test Loss=0.035710605 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [983/1000] | Train Loss=0.000710916 | Test Loss=0.035595203 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [984/1000] | Train Loss=0.000784790 | Test Loss=0.035781585 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [985/1000] | Train Loss=0.000696607 | Test Loss=0.035684769 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [986/1000] | Train Loss=0.000681124 | Test Loss=0.035794240 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [987/1000] | Train Loss=0.000684378 | Test Loss=0.035513474 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [988/1000] | Train Loss=0.000688309 | Test Loss=0.035308231 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [989/1000] | Train Loss=0.000713542 | Test Loss=0.035431907 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [990/1000] | Train Loss=0.000705275 | Test Loss=0.035684543 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [991/1000] | Train Loss=0.000724746 | Test Loss=0.035707284 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [992/1000] | Train Loss=0.000682483 | Test Loss=0.035602749 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [993/1000] | Train Loss=0.000671761 | Test Loss=0.035782407 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [994/1000] | Train Loss=0.000740571 | Test Loss=0.035814761 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [995/1000] | Train Loss=0.000684597 | Test Loss=0.035417286 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [996/1000] | Train Loss=0.000732529 | Test Loss=0.035512135 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [997/1000] | Train Loss=0.000684458 | Test Loss=0.035711797 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [998/1000] | Train Loss=0.000685794 | Test Loss=0.035658190 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [999/1000] | Train Loss=0.000649103 | Test Loss=0.035479442 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000753728 | Test Loss=0.035679570 | Time=1.81s | LR=1.22e-08\n",
      "\n",
      "Total training time: 1830.13 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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xWIQIiIiIovFIEREREQWi0GIiIiILBaDEBEREVksBiEiIiKyWAxCREREZLEYhIiIiMhiMQgRERGRxWIQIiIiIovFIEREREQWi0GIiIiILBaDEBEREVksBiEiIiKyWAxCREREZLEYhIiIiMhiMQhVIiIiAiEhIQgLCzN3UYiIiMhEGIQqER4ejsTERERHR5u7KERERGQiDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGI98kEoJSUFffr0QUhICEJDQ7Fx40ZzF4mIiIjqCBtzF8DUbGxssHz5crRv3x5paWno1KkThg4dCicnJ3MXjYiIiMzskQ9Cfn5+8PPzAwD4+vrCy8sLWVlZDEJERERk/q6xgwcP4umnn4a/vz8kEgm2bNlSYZuIiAgEBQXB3t4eXbt2xcmTJx/oWKdOnYJSqURAQEANS01ERESPArO3COXn56Ndu3Z4+eWXMWLEiArr169fjxkzZuCHH35A165dsXz5cgwePBhJSUnw9vYGALRv3x4KhaLCfXft2gV/f38AQFZWFsaPH49Vq1ZVWZ7i4mIUFxerb8tkMgCAXC6HXC5/4MdZXum+jLlPqoj1XHtY17WD9Vw7WM+1w5T1rO8+JYIgCEY/+gOSSCTYvHkzhg0bpl7WtWtXhIWF4bvvvgMAqFQqBAQE4K233sKsWbP02m9xcTEGDhyIyZMn46WXXqpy2wULFuDjjz+usHzNmjVwdHTU/8EQERGR2RQUFGDs2LHIycmBq6trpduZvUWoKiUlJTh16hRmz56tXmZlZYUBAwbg2LFjeu1DEARMnDgR/fr1qzYEAcDs2bMxY8YM9W2ZTIaAgAAMGjSoyoo0lFwux+7duzFw4EBIpVKj7Ze0sZ5rD+u6drCeawfruXaYsp5Le3SqU6eDUGZmJpRKJXx8fLSW+/j44MKFC3rt48iRI1i/fj1CQ0PV44/++OMPtG3bVuf2dnZ2sLOzq7BcKpWa5M1gqv2SNtZz7WFd1w7Wc+1gPdcOU9SzvvszKAgpFAqsWbMGgwcPrhBO6qqePXtCpVKZuxhERERUBxl01piNjQ2mTJmCoqIiU5VHi5eXF6ytrZGenq61PD09Hb6+vrVSBiIiInp0GXz6fJcuXRAXF2eColRka2uLTp06Ye/eveplKpUKe/fuRbdu3WqlDERERPToMniM0JtvvokZM2YgJSUFnTp1qjAxYWhoqEH7y8vLw+XLl9W3k5OTERcXB09PTwQGBmLGjBmYMGECOnfujC5dumD58uXIz8/HpEmTDC06ERERkRaDg9ALL7wAAHj77bfVyyQSCQRBgEQigVKpNGh/MTEx6Nu3r/p26RlbEyZMwK+//orRo0fjzp07mDdvHtLS0tC+fXvs2LHjoRmjRERERHWXwUEoOTnZqAXo06cPqpvKaOrUqZg6dapRj0tERERkcBBq1KiRKcpR50RERCAiIsLgFi4iIiJ6eDzQPEJXrlzB8uXLcf78eQBASEgIpk2bhiZNmhi1cOYUHh6O8PBwyGQyuLm5mbs4REREZAIGnzW2c+dOhISE4OTJkwgNDUVoaChOnDiB1q1bY/fu3aYoIxEREZFJGNwiNGvWLEyfPh1LliypsPyDDz7AwIEDjVY4IiIiIlMyuEXo/PnzeOWVVyosf/nll5GYmGiUQhERERHVBoODUP369XVOqBgXFwdvb29jlImIiIioVhjcNTZ58mS89tpruHr1Krp37w5AvLDp0qVLta7aTkRERFTXGRyE5s6dCxcXF3z11VeYPXs2AMDf3x8LFizQmmSRiIiIqK57oKvPjx07FtOnT0dubi4AwMXFxSSFIyIiIjKlGl193sXFhSGIiIiIHloPdPX52NhYU5SlTomIiEBISAjCwsLMXRQiIiIykQe6+vy7776LmzdvGuXq83UVZ5YmIiJ69Jn96vNERERE5mL2q88TERERmYtBQUgul6Nfv374999/0apVK1OViYiIiKhWGDRYWiqVqs8YIyIiInrYGXzWWHh4OJYuXQqFQmGK8hARERHVGoPHCEVHR2Pv3r3YtWsX2rZtW+GssU2bNhmtcERERESmZHAQcnd3x3PPPWeKshARERHVKoODUGRkpCnKQURERFTr9B4jlJGRUeV6hUKBkydP1rhARERERLVF7yDk5+enFYbatm2LlJQU9e27d++iW7duxi2dGfESG0RERI8+vYOQIAhat69duwa5XF7lNg+z8PBwJCYmIjo62txFISIiIhMx+PT5qkgkEmPujoiIiMikjBqEiIiIiB4mep81JpFIkJubC3t7e/UFVvPy8iCTyQBA/T8RERHRw0LvICQIApo3b651u0OHDlq32TVGREREDxO9g9D+/ftNWQ4iIiKDqVQqlJSUGH2/crkcNjY2KCoqglKpNPr+SVSTepZKpbC2tq5xGfQOQr17967xwYiIiIylpKQEycnJUKlURt+3IAjw9fVFSkoKeztMqKb17O7uDl9f3xo9RwbPLE1ERGRugiAgNTUV1tbWCAgIgJWVcc/9UalUyMvLg7Ozs9H3TWUetJ4FQUBBQYF6fkM/P78HLgODEBERPXQUCgUKCgrg7+8PR0dHo++/tMvN3t6eQciEalLPDg4OAMQrX3h7ez9wNxmfXSIieuiUjiextbU1c0nInEpDcPkJng3BIERERA8tjt+xbMZ4/hmEiIiIyGIZFITi4+Px2Wef4fvvv0dmZqbWOplMhpdfftmohTMnXnSViIgeBkFBQVi+fLm5i4Fff/0V7u7u5i6GwfQOQrt27UKXLl2wbt06LF26FC1bttSaW6iwsBC//fabSQppDrzoKhERGZNEIqny34IFCx5ov9HR0XjttddqVLY+ffqoy2Fvb4/mzZtj8eLFRr+YukQiwZYtW3Sui4qKwrPPPgs/Pz84OTmhffv2WL16tVGPr4veQWjBggWYOXMmzp49i2vXruH999/HM888gx07dpiyfERERI+E1NRU9b/ly5fD1dVVa9nMmTPV2wqCAIVCodd+69evb5Qz5yZPnozU1FQkJSVh9uzZmDdvHn744Yca71dfR48eRWhoKP766y8kJCRg0qRJGD9+PP7991+THlfvIHTu3Dl115dEIsH777+PlStXYuTIkSYvJBER0cPO19dX/c/NzQ0SiUR9+8KFC3BxccH2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RKdOnQAAbdq0gZ2dHaZPn84QRERERA8tvYOQUqmEra2t+raNjQ2cnZ1NUigiIiKi2qB315ggCJg4cSLs7OwAAEVFRZgyZQqcnJy0ttu0aZNxS0hERERkInoHoQkTJmjdfvHFF41eGCIiIqLapHcQioyMNGU5iIiIiGrdA0+oSERERPSwYxAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEKhEREYGQkBCEhYWZuyhERERkIgxClQgPD0diYiKio6PNXRQiIiIyEQYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQkRERGSxGISIiIjIYjEIERERkcViECIiIiKLxSBEREREFotBiIiIiCwWgxARERFZLAYhIiIislgMQmZWLFfihR+PYfmeizrXK1UCihXKWi4VERGRZXjkg1B2djY6d+6M9u3bo02bNli1apW5i6RlR2IGjl/NwvI9l3Suf/LbQ+ixZB/DEBERkQnYmLsApubi4oKDBw/C0dER+fn5aNOmDUaMGIF69eqZu2gQBOByRl6l67fE3sKFtFwAwKX0PLRp4FZbRSMiIrIIj3wQsra2hqOjIwCguLgYgiBAEAQzlwrot+wQUu7ZAEhWLyuSK2EvtVbffmd9nPpviaQWC0dERGQhzN41dvDgQTz99NPw9/eHRCLBli1bKmwTERGBoKAg2Nvbo2vXrjh58qRBx8jOzka7du3QsGFDvPfee/Dy8jJS6R+cXKmqsExWJK90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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Train ONLY on Group A (train_1.pt) as requested\n",
    "ufno, train_losses, test_losses = train_operator(\n",
    "    dataset_raw      = train_data,\n",
    "    model            = ufno,\n",
    "    num_epochs       = 1000,\n",
    "    lr               = 1e-4,\n",
    "    device           = device,\n",
    "    batch_size       = 16,\n",
    "    test_dataset_raw = test_data,   # evaluates on unseen Group B during training\n",
    "    reduce_on        = 'train',\n",
    "    factor           = 0.5,\n",
    "    patience         = 30,\n",
    "    min_lr           = 1e-10,\n",
    "    cooldown         = 0\n",
    ")\n",
    "\n",
    "torch.save(ufno.state_dict(), \"ufno1d_G2.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00068362\n",
      "Function type: periodic             | Relative L2: 0.00142620\n",
      "Function type: sine_beats           | Relative L2: 0.00173522\n",
      "\n",
      "Overall relative L2 error: 0.00081427\n",
      "--------------test----------------\n",
      "Function type: gaussian_hermite     | Relative L2: 0.09020912\n",
      "Function type: sinc_pulse           | Relative L2: 0.06473228\n",
      "Function type: wave_packet          | Relative L2: 0.03097686\n",
      "\n",
      "Overall relative L2 error: 0.03399344\n",
      "--------------sample----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00070324\n",
      "Function type: periodic             | Relative L2: 0.00145992\n",
      "Function type: sine_beats           | Relative L2: 0.00477223\n",
      "\n",
      "Overall relative L2 error: 0.00144062\n"
     ]
    }
   ],
   "source": [
    "torch.save(ufno.state_dict(), \"ufno1d_G2.pth\")\n",
    "\n",
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, model = ufno, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, model = ufno, device = device)\n",
    "print('--------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, model = ufno, device = device)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "kano",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
