{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": 6,
   "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": 14,
   "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": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = convert_dataset_for_fno(torch.load('train_3.pt', weights_only=False))\n",
    "test_data = convert_dataset_for_fno(torch.load('test_3.pt', weights_only=False))\n",
    "sample_data = convert_dataset_for_fno(torch.load('sample_3.pt', weights_only=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "U-FNO1d params: 579,841\n"
     ]
    }
   ],
   "source": [
    "device = 'cuda:0'\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": 10,
   "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.874252094 | Test Loss=0.387410219 | Time=2.21s | LR=1.00e-03\n",
      "Epoch [2/1000] | Train Loss=0.091292413 | Test Loss=0.072754678 | Time=1.89s | LR=1.00e-03\n",
      "Epoch [3/1000] | Train Loss=0.032721453 | Test Loss=0.040402229 | Time=1.91s | LR=1.00e-03\n",
      "Epoch [4/1000] | Train Loss=0.025532618 | Test Loss=0.094530828 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [5/1000] | Train Loss=0.020441092 | Test Loss=0.044738148 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [6/1000] | Train Loss=0.017445624 | Test Loss=0.050707099 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [7/1000] | Train Loss=0.016552097 | Test Loss=0.056582508 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [8/1000] | Train Loss=0.015228006 | Test Loss=0.039909849 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [9/1000] | Train Loss=0.016490854 | Test Loss=0.097487538 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [10/1000] | Train Loss=0.015258511 | Test Loss=0.085095575 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [11/1000] | Train Loss=0.016010679 | Test Loss=0.069404145 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [12/1000] | Train Loss=0.014387837 | Test Loss=0.042403146 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [13/1000] | Train Loss=0.013042983 | Test Loss=0.042788577 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [14/1000] | Train Loss=0.011334354 | Test Loss=0.042361113 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [15/1000] | Train Loss=0.011218622 | Test Loss=0.043531891 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [16/1000] | Train Loss=0.011738029 | Test Loss=0.038749255 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [17/1000] | Train Loss=0.011743094 | Test Loss=0.074747797 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [18/1000] | Train Loss=0.011172031 | Test Loss=0.039579054 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [19/1000] | Train Loss=0.010950044 | Test Loss=0.037448306 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [20/1000] | Train Loss=0.009346643 | Test Loss=0.041303403 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [21/1000] | Train Loss=0.011407874 | Test Loss=0.041327529 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [22/1000] | Train Loss=0.010128459 | Test Loss=0.044326965 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [23/1000] | Train Loss=0.009206467 | Test Loss=0.053067148 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [24/1000] | Train Loss=0.008407820 | Test Loss=0.040450449 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [25/1000] | Train Loss=0.008295638 | Test Loss=0.046718797 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [26/1000] | Train Loss=0.009333441 | Test Loss=0.044526480 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [27/1000] | Train Loss=0.009182063 | Test Loss=0.038450923 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [28/1000] | Train Loss=0.008477867 | Test Loss=0.041542905 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [29/1000] | Train Loss=0.009397749 | Test Loss=0.046375810 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [30/1000] | Train Loss=0.008117502 | Test Loss=0.054351659 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [31/1000] | Train Loss=0.010184351 | Test Loss=0.050701339 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [32/1000] | Train Loss=0.008688462 | Test Loss=0.039976482 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [33/1000] | Train Loss=0.007802599 | Test Loss=0.039160926 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [34/1000] | Train Loss=0.007864415 | Test Loss=0.041965445 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [35/1000] | Train Loss=0.008657331 | Test Loss=0.040703377 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [36/1000] | Train Loss=0.007930723 | Test Loss=0.051071592 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [37/1000] | Train Loss=0.007417691 | Test Loss=0.038277804 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [38/1000] | Train Loss=0.007198915 | Test Loss=0.040845893 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [39/1000] | Train Loss=0.007549301 | Test Loss=0.050632798 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [40/1000] | Train Loss=0.008055134 | Test Loss=0.039081091 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [41/1000] | Train Loss=0.008226112 | Test Loss=0.038709400 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [42/1000] | Train Loss=0.007510780 | Test Loss=0.044366586 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [43/1000] | Train Loss=0.007936958 | Test Loss=0.047932489 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [44/1000] | Train Loss=0.007317404 | Test Loss=0.038186599 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [45/1000] | Train Loss=0.009040066 | Test Loss=0.038853397 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [46/1000] | Train Loss=0.007799628 | Test Loss=0.039705829 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [47/1000] | Train Loss=0.007710641 | Test Loss=0.040686833 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [48/1000] | Train Loss=0.007920072 | Test Loss=0.036122254 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [49/1000] | Train Loss=0.007182226 | Test Loss=0.041448743 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [50/1000] | Train Loss=0.005811291 | Test Loss=0.036299641 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [51/1000] | Train Loss=0.006455171 | Test Loss=0.041312817 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [52/1000] | Train Loss=0.006497012 | Test Loss=0.039107218 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [53/1000] | Train Loss=0.006461080 | Test Loss=0.040298119 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [54/1000] | Train Loss=0.006545717 | Test Loss=0.034734416 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [55/1000] | Train Loss=0.006125402 | Test Loss=0.036482926 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [56/1000] | Train Loss=0.007023619 | Test Loss=0.050989475 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [57/1000] | Train Loss=0.007689587 | Test Loss=0.050029044 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [58/1000] | Train Loss=0.007301069 | Test Loss=0.042165380 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [59/1000] | Train Loss=0.006605819 | Test Loss=0.039890962 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [60/1000] | Train Loss=0.007116289 | Test Loss=0.037276192 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [61/1000] | Train Loss=0.007557191 | Test Loss=0.038211054 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [62/1000] | Train Loss=0.006405346 | Test Loss=0.035915904 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [63/1000] | Train Loss=0.006491077 | Test Loss=0.040017257 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [64/1000] | Train Loss=0.005619918 | Test Loss=0.037277521 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [65/1000] | Train Loss=0.006491432 | Test Loss=0.043103907 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [66/1000] | Train Loss=0.006271366 | Test Loss=0.043366434 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [67/1000] | Train Loss=0.005753778 | Test Loss=0.042113406 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [68/1000] | Train Loss=0.006028379 | Test Loss=0.045140079 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [69/1000] | Train Loss=0.006528861 | Test Loss=0.035563480 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [70/1000] | Train Loss=0.006248339 | Test Loss=0.053219574 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [71/1000] | Train Loss=0.005627691 | Test Loss=0.038221516 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [72/1000] | Train Loss=0.007439280 | Test Loss=0.037677108 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [73/1000] | Train Loss=0.008678681 | Test Loss=0.035897425 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [74/1000] | Train Loss=0.005164925 | Test Loss=0.036096855 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [75/1000] | Train Loss=0.006115852 | Test Loss=0.037090757 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [76/1000] | Train Loss=0.005399312 | Test Loss=0.036668474 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [77/1000] | Train Loss=0.005815813 | Test Loss=0.038792959 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [78/1000] | Train Loss=0.005590354 | Test Loss=0.036041465 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [79/1000] | Train Loss=0.005153232 | Test Loss=0.034571959 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [80/1000] | Train Loss=0.005197653 | Test Loss=0.035831816 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [81/1000] | Train Loss=0.004788594 | Test Loss=0.036357220 | Time=1.88s | LR=1.00e-03\n",
      "Epoch [82/1000] | Train Loss=0.008052644 | Test Loss=0.040098067 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [83/1000] | Train Loss=0.005386752 | Test Loss=0.035145460 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [84/1000] | Train Loss=0.005073990 | Test Loss=0.036324582 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [85/1000] | Train Loss=0.005304426 | Test Loss=0.036233960 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [86/1000] | Train Loss=0.004842085 | Test Loss=0.035931168 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [87/1000] | Train Loss=0.004424059 | Test Loss=0.035225470 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [88/1000] | Train Loss=0.005769107 | Test Loss=0.035075417 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [89/1000] | Train Loss=0.005483635 | Test Loss=0.032843764 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [90/1000] | Train Loss=0.005347642 | Test Loss=0.031530690 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [91/1000] | Train Loss=0.006065317 | Test Loss=0.035762570 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [92/1000] | Train Loss=0.005653005 | Test Loss=0.031058009 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [93/1000] | Train Loss=0.005361772 | Test Loss=0.033995107 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [94/1000] | Train Loss=0.005989379 | Test Loss=0.032446821 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [95/1000] | Train Loss=0.005498996 | Test Loss=0.038657218 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [96/1000] | Train Loss=0.007068727 | Test Loss=0.033173913 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [97/1000] | Train Loss=0.005374075 | Test Loss=0.032704144 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [98/1000] | Train Loss=0.006319383 | Test Loss=0.032647652 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [99/1000] | Train Loss=0.005470770 | Test Loss=0.033883860 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [100/1000] | Train Loss=0.005094595 | Test Loss=0.032718939 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [101/1000] | Train Loss=0.004996947 | Test Loss=0.037898045 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [102/1000] | Train Loss=0.004360996 | Test Loss=0.033894955 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [103/1000] | Train Loss=0.005752605 | Test Loss=0.032797868 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [104/1000] | Train Loss=0.005934273 | Test Loss=0.032289807 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [105/1000] | Train Loss=0.005096207 | Test Loss=0.034267287 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [106/1000] | Train Loss=0.006841511 | Test Loss=0.033925067 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [107/1000] | Train Loss=0.004510292 | Test Loss=0.033675542 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [108/1000] | Train Loss=0.004658234 | Test Loss=0.033258403 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [109/1000] | Train Loss=0.006134161 | Test Loss=0.035642753 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [110/1000] | Train Loss=0.004856697 | Test Loss=0.034585060 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [111/1000] | Train Loss=0.005210311 | Test Loss=0.034352696 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [112/1000] | Train Loss=0.004389680 | Test Loss=0.032103421 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [113/1000] | Train Loss=0.004939416 | Test Loss=0.032138789 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [114/1000] | Train Loss=0.005931438 | Test Loss=0.036813665 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [115/1000] | Train Loss=0.006570630 | Test Loss=0.033829818 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [116/1000] | Train Loss=0.005185048 | Test Loss=0.032284997 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [117/1000] | Train Loss=0.004706957 | Test Loss=0.032409403 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [118/1000] | Train Loss=0.005989355 | Test Loss=0.033758933 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [119/1000] | Train Loss=0.004670860 | Test Loss=0.039659569 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [120/1000] | Train Loss=0.004595678 | Test Loss=0.032499333 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [121/1000] | Train Loss=0.004727192 | Test Loss=0.038360235 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [122/1000] | Train Loss=0.004783947 | Test Loss=0.034801701 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [123/1000] | Train Loss=0.005595530 | Test Loss=0.033187818 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [124/1000] | Train Loss=0.005068016 | Test Loss=0.036374581 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [125/1000] | Train Loss=0.004484084 | Test Loss=0.033269536 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [126/1000] | Train Loss=0.006223523 | Test Loss=0.033913506 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [127/1000] | Train Loss=0.004213999 | Test Loss=0.034263975 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [128/1000] | Train Loss=0.005444713 | Test Loss=0.032067066 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [129/1000] | Train Loss=0.004019463 | Test Loss=0.032535247 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [130/1000] | Train Loss=0.005238626 | Test Loss=0.032214904 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [131/1000] | Train Loss=0.005224512 | Test Loss=0.032544967 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [132/1000] | Train Loss=0.004673709 | Test Loss=0.032354558 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [133/1000] | Train Loss=0.003964500 | Test Loss=0.031339364 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [134/1000] | Train Loss=0.004631923 | Test Loss=0.033714842 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [135/1000] | Train Loss=0.005102045 | Test Loss=0.033687957 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [136/1000] | Train Loss=0.005077956 | Test Loss=0.031546478 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [137/1000] | Train Loss=0.004267505 | Test Loss=0.032627509 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [138/1000] | Train Loss=0.005137719 | Test Loss=0.032463974 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [139/1000] | Train Loss=0.005993591 | Test Loss=0.038368272 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [140/1000] | Train Loss=0.008731616 | Test Loss=0.049344743 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [141/1000] | Train Loss=0.005125132 | Test Loss=0.032111919 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [142/1000] | Train Loss=0.005403555 | Test Loss=0.040070293 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [143/1000] | Train Loss=0.004611743 | Test Loss=0.033605180 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [144/1000] | Train Loss=0.004332609 | Test Loss=0.037021246 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [145/1000] | Train Loss=0.004583374 | Test Loss=0.032333550 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [146/1000] | Train Loss=0.004942182 | Test Loss=0.035332826 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [147/1000] | Train Loss=0.003994460 | Test Loss=0.032301853 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [148/1000] | Train Loss=0.006162674 | Test Loss=0.036447259 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [149/1000] | Train Loss=0.004818274 | Test Loss=0.036095792 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [150/1000] | Train Loss=0.005411174 | Test Loss=0.032547158 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [151/1000] | Train Loss=0.004612292 | Test Loss=0.032551730 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [152/1000] | Train Loss=0.004233593 | Test Loss=0.038297624 | Time=1.88s | LR=1.00e-03\n",
      "Epoch [153/1000] | Train Loss=0.005124195 | Test Loss=0.030877825 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [154/1000] | Train Loss=0.004516052 | Test Loss=0.032821431 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [155/1000] | Train Loss=0.004585361 | Test Loss=0.032818011 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [156/1000] | Train Loss=0.004989133 | Test Loss=0.032095402 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [157/1000] | Train Loss=0.005301473 | Test Loss=0.034237208 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [158/1000] | Train Loss=0.004703102 | Test Loss=0.031731586 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [159/1000] | Train Loss=0.004190934 | Test Loss=0.032974576 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [160/1000] | Train Loss=0.004480355 | Test Loss=0.031897200 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [161/1000] | Train Loss=0.004004498 | Test Loss=0.034204909 | Time=1.87s | LR=1.00e-03\n",
      "Epoch [162/1000] | Train Loss=0.004761743 | Test Loss=0.034269526 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [163/1000] | Train Loss=0.004435579 | Test Loss=0.034088678 | Time=1.86s | LR=1.00e-03\n",
      "Epoch [164/1000] | Train Loss=0.005938609 | Test Loss=0.030421031 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [165/1000] | Train Loss=0.002505720 | Test Loss=0.031506318 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [166/1000] | Train Loss=0.002790428 | Test Loss=0.031451163 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [167/1000] | Train Loss=0.002529511 | Test Loss=0.031130003 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [168/1000] | Train Loss=0.002298023 | Test Loss=0.031636171 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [169/1000] | Train Loss=0.002768308 | Test Loss=0.032135914 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [170/1000] | Train Loss=0.002441912 | Test Loss=0.031717086 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [171/1000] | Train Loss=0.002773296 | Test Loss=0.034129744 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [172/1000] | Train Loss=0.003144114 | Test Loss=0.031694341 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [173/1000] | Train Loss=0.003000555 | Test Loss=0.030720864 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [174/1000] | Train Loss=0.003033976 | Test Loss=0.031894389 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [175/1000] | Train Loss=0.003201312 | Test Loss=0.031024906 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [176/1000] | Train Loss=0.002498499 | Test Loss=0.031517883 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [177/1000] | Train Loss=0.003286719 | Test Loss=0.031226572 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [178/1000] | Train Loss=0.002623293 | Test Loss=0.030347571 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [179/1000] | Train Loss=0.002282039 | Test Loss=0.030716168 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [180/1000] | Train Loss=0.003602625 | Test Loss=0.030833128 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [181/1000] | Train Loss=0.002800219 | Test Loss=0.031655142 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [182/1000] | Train Loss=0.003417828 | Test Loss=0.030778500 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [183/1000] | Train Loss=0.002126018 | Test Loss=0.031699933 | Time=1.88s | LR=5.00e-04\n",
      "Epoch [184/1000] | Train Loss=0.002789511 | Test Loss=0.031650555 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [185/1000] | Train Loss=0.002193189 | Test Loss=0.031419300 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [186/1000] | Train Loss=0.002658816 | Test Loss=0.031463323 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [187/1000] | Train Loss=0.002265021 | Test Loss=0.031325617 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [188/1000] | Train Loss=0.002495548 | Test Loss=0.031366511 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [189/1000] | Train Loss=0.004015234 | Test Loss=0.031623227 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [190/1000] | Train Loss=0.002401717 | Test Loss=0.030847689 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [191/1000] | Train Loss=0.002517238 | Test Loss=0.031658154 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [192/1000] | Train Loss=0.002101972 | Test Loss=0.031044758 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [193/1000] | Train Loss=0.002680913 | Test Loss=0.031391397 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [194/1000] | Train Loss=0.002146269 | Test Loss=0.031220339 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [195/1000] | Train Loss=0.002523313 | Test Loss=0.032029912 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [196/1000] | Train Loss=0.002627811 | Test Loss=0.031530504 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [197/1000] | Train Loss=0.002803305 | Test Loss=0.031985965 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [198/1000] | Train Loss=0.002282088 | Test Loss=0.030864640 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [199/1000] | Train Loss=0.002293305 | Test Loss=0.032447180 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [200/1000] | Train Loss=0.002582360 | Test Loss=0.031148009 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [201/1000] | Train Loss=0.002577540 | Test Loss=0.031612577 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [202/1000] | Train Loss=0.003069769 | Test Loss=0.032257752 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [203/1000] | Train Loss=0.002683391 | Test Loss=0.031709868 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [204/1000] | Train Loss=0.002730561 | Test Loss=0.031493777 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [205/1000] | Train Loss=0.002906267 | Test Loss=0.030926917 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [206/1000] | Train Loss=0.002607297 | Test Loss=0.030550621 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [207/1000] | Train Loss=0.003020532 | Test Loss=0.030563117 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [208/1000] | Train Loss=0.002272655 | Test Loss=0.031443936 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [209/1000] | Train Loss=0.002571617 | Test Loss=0.031143233 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [210/1000] | Train Loss=0.002472260 | Test Loss=0.030504676 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [211/1000] | Train Loss=0.002302006 | Test Loss=0.031133590 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [212/1000] | Train Loss=0.002801241 | Test Loss=0.030625756 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [213/1000] | Train Loss=0.002122198 | Test Loss=0.032418530 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [214/1000] | Train Loss=0.002496278 | Test Loss=0.030667474 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [215/1000] | Train Loss=0.002310425 | Test Loss=0.030416003 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [216/1000] | Train Loss=0.003070559 | Test Loss=0.030058360 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [217/1000] | Train Loss=0.002103895 | Test Loss=0.030156481 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [218/1000] | Train Loss=0.002331824 | Test Loss=0.030171167 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [219/1000] | Train Loss=0.003209558 | Test Loss=0.031240161 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [220/1000] | Train Loss=0.002307098 | Test Loss=0.029827393 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [221/1000] | Train Loss=0.002426358 | Test Loss=0.031792080 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [222/1000] | Train Loss=0.002237937 | Test Loss=0.030315032 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [223/1000] | Train Loss=0.001942188 | Test Loss=0.031254688 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [224/1000] | Train Loss=0.001987920 | Test Loss=0.031493371 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [225/1000] | Train Loss=0.002793380 | Test Loss=0.032181434 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [226/1000] | Train Loss=0.003129227 | Test Loss=0.030435539 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [227/1000] | Train Loss=0.002980947 | Test Loss=0.030973549 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [228/1000] | Train Loss=0.002331932 | Test Loss=0.030306117 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [229/1000] | Train Loss=0.002449205 | Test Loss=0.032719382 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [230/1000] | Train Loss=0.002227417 | Test Loss=0.030151639 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [231/1000] | Train Loss=0.002271843 | Test Loss=0.030232235 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [232/1000] | Train Loss=0.002275412 | Test Loss=0.033663265 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [233/1000] | Train Loss=0.003795723 | Test Loss=0.033559937 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [234/1000] | Train Loss=0.003850429 | Test Loss=0.030932868 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [235/1000] | Train Loss=0.002641048 | Test Loss=0.031465706 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [236/1000] | Train Loss=0.002431265 | Test Loss=0.030903074 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [237/1000] | Train Loss=0.003501397 | Test Loss=0.030643473 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [238/1000] | Train Loss=0.002177418 | Test Loss=0.030470706 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [239/1000] | Train Loss=0.002129649 | Test Loss=0.031042936 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [240/1000] | Train Loss=0.002052995 | Test Loss=0.030277271 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [241/1000] | Train Loss=0.002043540 | Test Loss=0.030541883 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [242/1000] | Train Loss=0.003268440 | Test Loss=0.030990705 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [243/1000] | Train Loss=0.002576542 | Test Loss=0.030977105 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [244/1000] | Train Loss=0.003308297 | Test Loss=0.030484333 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [245/1000] | Train Loss=0.002270558 | Test Loss=0.030603864 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [246/1000] | Train Loss=0.002628575 | Test Loss=0.030848856 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [247/1000] | Train Loss=0.004034247 | Test Loss=0.031759135 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [248/1000] | Train Loss=0.003048405 | Test Loss=0.030777590 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [249/1000] | Train Loss=0.002474307 | Test Loss=0.031236939 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [250/1000] | Train Loss=0.002173249 | Test Loss=0.031260803 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [251/1000] | Train Loss=0.002524268 | Test Loss=0.031683978 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [252/1000] | Train Loss=0.002491048 | Test Loss=0.031983931 | Time=1.87s | LR=5.00e-04\n",
      "Epoch [253/1000] | Train Loss=0.002141138 | Test Loss=0.031625754 | Time=1.86s | LR=5.00e-04\n",
      "Epoch [254/1000] | Train Loss=0.002412103 | Test Loss=0.029993499 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [255/1000] | Train Loss=0.001409274 | Test Loss=0.030647670 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [256/1000] | Train Loss=0.001516501 | Test Loss=0.030650177 | Time=1.88s | LR=2.50e-04\n",
      "Epoch [257/1000] | Train Loss=0.001391632 | Test Loss=0.030560933 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [258/1000] | Train Loss=0.001571844 | Test Loss=0.030872284 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [259/1000] | Train Loss=0.001707850 | Test Loss=0.030147221 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [260/1000] | Train Loss=0.001616943 | Test Loss=0.030391017 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [261/1000] | Train Loss=0.001706077 | Test Loss=0.029897212 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [262/1000] | Train Loss=0.001673427 | Test Loss=0.029859944 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [263/1000] | Train Loss=0.001535854 | Test Loss=0.029751002 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [264/1000] | Train Loss=0.001757886 | Test Loss=0.030887373 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [265/1000] | Train Loss=0.001638367 | Test Loss=0.030228644 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [266/1000] | Train Loss=0.001429483 | Test Loss=0.030742301 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [267/1000] | Train Loss=0.001773825 | Test Loss=0.030527754 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [268/1000] | Train Loss=0.001997708 | Test Loss=0.030113380 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [269/1000] | Train Loss=0.001434405 | Test Loss=0.030532659 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [270/1000] | Train Loss=0.001765333 | Test Loss=0.030333589 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [271/1000] | Train Loss=0.001384241 | Test Loss=0.030385026 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [272/1000] | Train Loss=0.001565907 | Test Loss=0.030557101 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [273/1000] | Train Loss=0.001477741 | Test Loss=0.030029424 | Time=1.88s | LR=2.50e-04\n",
      "Epoch [274/1000] | Train Loss=0.001761341 | Test Loss=0.030663133 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [275/1000] | Train Loss=0.001585656 | Test Loss=0.030055279 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [276/1000] | Train Loss=0.001489228 | Test Loss=0.030517741 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [277/1000] | Train Loss=0.001403484 | Test Loss=0.030091896 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [278/1000] | Train Loss=0.001659321 | Test Loss=0.030558702 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [279/1000] | Train Loss=0.001438741 | Test Loss=0.030162192 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [280/1000] | Train Loss=0.001453850 | Test Loss=0.030322059 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [281/1000] | Train Loss=0.001615566 | Test Loss=0.030078506 | Time=1.88s | LR=2.50e-04\n",
      "Epoch [282/1000] | Train Loss=0.001775259 | Test Loss=0.029339548 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [283/1000] | Train Loss=0.001583499 | Test Loss=0.029680302 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [284/1000] | Train Loss=0.001482380 | Test Loss=0.030235838 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [285/1000] | Train Loss=0.001609174 | Test Loss=0.030170471 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [286/1000] | Train Loss=0.002090757 | Test Loss=0.030184531 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [287/1000] | Train Loss=0.001525096 | Test Loss=0.029696489 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [288/1000] | Train Loss=0.001431709 | Test Loss=0.030191584 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [289/1000] | Train Loss=0.001906474 | Test Loss=0.029816706 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [290/1000] | Train Loss=0.001372679 | Test Loss=0.030201339 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [291/1000] | Train Loss=0.001513530 | Test Loss=0.030602001 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [292/1000] | Train Loss=0.001795582 | Test Loss=0.031367201 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [293/1000] | Train Loss=0.001815891 | Test Loss=0.030586444 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [294/1000] | Train Loss=0.001446350 | Test Loss=0.030179808 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [295/1000] | Train Loss=0.001393364 | Test Loss=0.030554793 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [296/1000] | Train Loss=0.001524574 | Test Loss=0.029506692 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [297/1000] | Train Loss=0.001573716 | Test Loss=0.030512344 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [298/1000] | Train Loss=0.001408664 | Test Loss=0.030053878 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [299/1000] | Train Loss=0.001558303 | Test Loss=0.030003489 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [300/1000] | Train Loss=0.001637118 | Test Loss=0.029852178 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [301/1000] | Train Loss=0.001523364 | Test Loss=0.029314749 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [302/1000] | Train Loss=0.001556310 | Test Loss=0.029840450 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [303/1000] | Train Loss=0.001679029 | Test Loss=0.035058742 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [304/1000] | Train Loss=0.001846919 | Test Loss=0.029578523 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [305/1000] | Train Loss=0.001546367 | Test Loss=0.029342676 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [306/1000] | Train Loss=0.001508908 | Test Loss=0.030007603 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [307/1000] | Train Loss=0.001416442 | Test Loss=0.029970178 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [308/1000] | Train Loss=0.001334236 | Test Loss=0.029548208 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [309/1000] | Train Loss=0.001480491 | Test Loss=0.029927477 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [310/1000] | Train Loss=0.001466077 | Test Loss=0.029822137 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [311/1000] | Train Loss=0.001380513 | Test Loss=0.029437793 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [312/1000] | Train Loss=0.001500488 | Test Loss=0.029626086 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [313/1000] | Train Loss=0.001329662 | Test Loss=0.030131507 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [314/1000] | Train Loss=0.001439677 | Test Loss=0.029534037 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [315/1000] | Train Loss=0.001467161 | Test Loss=0.030026261 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [316/1000] | Train Loss=0.001580220 | Test Loss=0.029093464 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [317/1000] | Train Loss=0.001680710 | Test Loss=0.029863946 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [318/1000] | Train Loss=0.001458271 | Test Loss=0.030041743 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [319/1000] | Train Loss=0.001569830 | Test Loss=0.029631946 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [320/1000] | Train Loss=0.001430600 | Test Loss=0.029951261 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [321/1000] | Train Loss=0.001581698 | Test Loss=0.029912707 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [322/1000] | Train Loss=0.001622520 | Test Loss=0.030249851 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [323/1000] | Train Loss=0.001427286 | Test Loss=0.029814819 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [324/1000] | Train Loss=0.001388259 | Test Loss=0.029817153 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [325/1000] | Train Loss=0.001442719 | Test Loss=0.029721088 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [326/1000] | Train Loss=0.001447372 | Test Loss=0.029599236 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [327/1000] | Train Loss=0.001396270 | Test Loss=0.029567857 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [328/1000] | Train Loss=0.001476773 | Test Loss=0.029920272 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [329/1000] | Train Loss=0.001646039 | Test Loss=0.029813226 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [330/1000] | Train Loss=0.001591854 | Test Loss=0.029610773 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [331/1000] | Train Loss=0.001527866 | Test Loss=0.030180505 | Time=1.91s | LR=2.50e-04\n",
      "Epoch [332/1000] | Train Loss=0.001514853 | Test Loss=0.029630841 | Time=1.99s | LR=2.50e-04\n",
      "Epoch [333/1000] | Train Loss=0.001290317 | Test Loss=0.029635116 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [334/1000] | Train Loss=0.001564711 | Test Loss=0.029939298 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [335/1000] | Train Loss=0.001567641 | Test Loss=0.029517516 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [336/1000] | Train Loss=0.001474546 | Test Loss=0.029514182 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [337/1000] | Train Loss=0.001542544 | Test Loss=0.029785296 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [338/1000] | Train Loss=0.001532569 | Test Loss=0.030094921 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [339/1000] | Train Loss=0.001518773 | Test Loss=0.030648484 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [340/1000] | Train Loss=0.002125143 | Test Loss=0.029545136 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [341/1000] | Train Loss=0.001358571 | Test Loss=0.029748335 | Time=1.98s | LR=2.50e-04\n",
      "Epoch [342/1000] | Train Loss=0.001342597 | Test Loss=0.029746645 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [343/1000] | Train Loss=0.001375138 | Test Loss=0.029646588 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [344/1000] | Train Loss=0.001431134 | Test Loss=0.030162999 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [345/1000] | Train Loss=0.001329042 | Test Loss=0.030430600 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [346/1000] | Train Loss=0.001505835 | Test Loss=0.029568027 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [347/1000] | Train Loss=0.001305721 | Test Loss=0.029937581 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [348/1000] | Train Loss=0.001747249 | Test Loss=0.030069431 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [349/1000] | Train Loss=0.001396883 | Test Loss=0.029918897 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [350/1000] | Train Loss=0.001372452 | Test Loss=0.029433830 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [351/1000] | Train Loss=0.001605297 | Test Loss=0.030037906 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [352/1000] | Train Loss=0.001841976 | Test Loss=0.029745229 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [353/1000] | Train Loss=0.001427196 | Test Loss=0.029378285 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [354/1000] | Train Loss=0.001397112 | Test Loss=0.029498286 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [355/1000] | Train Loss=0.001638899 | Test Loss=0.030332657 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [356/1000] | Train Loss=0.001482469 | Test Loss=0.029429998 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [357/1000] | Train Loss=0.001624646 | Test Loss=0.029541499 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [358/1000] | Train Loss=0.001312371 | Test Loss=0.029166744 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [359/1000] | Train Loss=0.001279201 | Test Loss=0.029441916 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [360/1000] | Train Loss=0.001274771 | Test Loss=0.030086501 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [361/1000] | Train Loss=0.001405405 | Test Loss=0.029911658 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [362/1000] | Train Loss=0.001374983 | Test Loss=0.029372222 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [363/1000] | Train Loss=0.001362877 | Test Loss=0.029602781 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [364/1000] | Train Loss=0.001487950 | Test Loss=0.029387808 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [365/1000] | Train Loss=0.001536892 | Test Loss=0.029370100 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [366/1000] | Train Loss=0.001438969 | Test Loss=0.029730370 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [367/1000] | Train Loss=0.001489862 | Test Loss=0.029723793 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [368/1000] | Train Loss=0.001642915 | Test Loss=0.029313264 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [369/1000] | Train Loss=0.001899870 | Test Loss=0.029627785 | Time=1.89s | LR=2.50e-04\n",
      "Epoch [370/1000] | Train Loss=0.001453688 | Test Loss=0.029258828 | Time=1.91s | LR=2.50e-04\n",
      "Epoch [371/1000] | Train Loss=0.002156943 | Test Loss=0.028795366 | Time=1.91s | LR=2.50e-04\n",
      "Epoch [372/1000] | Train Loss=0.001374421 | Test Loss=0.029915560 | Time=1.91s | LR=2.50e-04\n",
      "Epoch [373/1000] | Train Loss=0.001375592 | Test Loss=0.029157024 | Time=1.88s | LR=2.50e-04\n",
      "Epoch [374/1000] | Train Loss=0.001291036 | Test Loss=0.029784782 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [375/1000] | Train Loss=0.001409363 | Test Loss=0.029287082 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [376/1000] | Train Loss=0.001432311 | Test Loss=0.029500609 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [377/1000] | Train Loss=0.001346577 | Test Loss=0.029860776 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [378/1000] | Train Loss=0.001308280 | Test Loss=0.029160579 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [379/1000] | Train Loss=0.001400598 | Test Loss=0.029944354 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [380/1000] | Train Loss=0.001924946 | Test Loss=0.029147598 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [381/1000] | Train Loss=0.001455893 | Test Loss=0.029664869 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [382/1000] | Train Loss=0.001357951 | Test Loss=0.029680031 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [383/1000] | Train Loss=0.001401069 | Test Loss=0.029565715 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [384/1000] | Train Loss=0.001435312 | Test Loss=0.029671077 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [385/1000] | Train Loss=0.001235112 | Test Loss=0.029101708 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [386/1000] | Train Loss=0.001474451 | Test Loss=0.029745740 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [387/1000] | Train Loss=0.001749253 | Test Loss=0.029074047 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [388/1000] | Train Loss=0.001462565 | Test Loss=0.029518219 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [389/1000] | Train Loss=0.001293405 | Test Loss=0.029591122 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [390/1000] | Train Loss=0.001257764 | Test Loss=0.029117038 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [391/1000] | Train Loss=0.001452614 | Test Loss=0.029799544 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [392/1000] | Train Loss=0.001586298 | Test Loss=0.029348354 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [393/1000] | Train Loss=0.001360151 | Test Loss=0.029497206 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [394/1000] | Train Loss=0.001271032 | Test Loss=0.029530662 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [395/1000] | Train Loss=0.001353998 | Test Loss=0.029275437 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [396/1000] | Train Loss=0.001804696 | Test Loss=0.029418093 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [397/1000] | Train Loss=0.001361250 | Test Loss=0.029005459 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [398/1000] | Train Loss=0.001274052 | Test Loss=0.029992476 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [399/1000] | Train Loss=0.001548285 | Test Loss=0.029628710 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [400/1000] | Train Loss=0.001494738 | Test Loss=0.029527870 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [401/1000] | Train Loss=0.001254675 | Test Loss=0.029341740 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [402/1000] | Train Loss=0.001743284 | Test Loss=0.029512942 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [403/1000] | Train Loss=0.001476788 | Test Loss=0.029517186 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [404/1000] | Train Loss=0.001253677 | Test Loss=0.029464676 | Time=1.89s | LR=2.50e-04\n",
      "Epoch [405/1000] | Train Loss=0.001414685 | Test Loss=0.029321011 | Time=1.91s | LR=2.50e-04\n",
      "Epoch [406/1000] | Train Loss=0.001828583 | Test Loss=0.029530791 | Time=1.91s | LR=2.50e-04\n",
      "Epoch [407/1000] | Train Loss=0.001263263 | Test Loss=0.029632347 | Time=1.90s | LR=2.50e-04\n",
      "Epoch [408/1000] | Train Loss=0.001454877 | Test Loss=0.029738964 | Time=1.87s | LR=2.50e-04\n",
      "Epoch [409/1000] | Train Loss=0.001676966 | Test Loss=0.030765771 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [410/1000] | Train Loss=0.001562969 | Test Loss=0.028778583 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [411/1000] | Train Loss=0.001529011 | Test Loss=0.029121969 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [412/1000] | Train Loss=0.001489236 | Test Loss=0.029305087 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [413/1000] | Train Loss=0.001389274 | Test Loss=0.029740916 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [414/1000] | Train Loss=0.001361892 | Test Loss=0.029380277 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [415/1000] | Train Loss=0.001341684 | Test Loss=0.029225221 | Time=1.86s | LR=2.50e-04\n",
      "Epoch [416/1000] | Train Loss=0.001238363 | Test Loss=0.029537070 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [417/1000] | Train Loss=0.001076930 | Test Loss=0.029507768 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [418/1000] | Train Loss=0.001048541 | Test Loss=0.029276605 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [419/1000] | Train Loss=0.001010529 | Test Loss=0.029348519 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [420/1000] | Train Loss=0.000977756 | Test Loss=0.028868426 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [421/1000] | Train Loss=0.001201348 | Test Loss=0.028730898 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [422/1000] | Train Loss=0.001124546 | Test Loss=0.029117442 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [423/1000] | Train Loss=0.001031697 | Test Loss=0.028955079 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [424/1000] | Train Loss=0.001009648 | Test Loss=0.028778627 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [425/1000] | Train Loss=0.001048361 | Test Loss=0.029072118 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [426/1000] | Train Loss=0.001025658 | Test Loss=0.029166154 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [427/1000] | Train Loss=0.001136217 | Test Loss=0.029597725 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [428/1000] | Train Loss=0.001054668 | Test Loss=0.029612744 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [429/1000] | Train Loss=0.001048869 | Test Loss=0.029028762 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [430/1000] | Train Loss=0.000972268 | Test Loss=0.028822934 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [431/1000] | Train Loss=0.001062191 | Test Loss=0.029076708 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [432/1000] | Train Loss=0.001032157 | Test Loss=0.029069794 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [433/1000] | Train Loss=0.001008419 | Test Loss=0.029426851 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [434/1000] | Train Loss=0.001011903 | Test Loss=0.029570898 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [435/1000] | Train Loss=0.000998173 | Test Loss=0.028954300 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [436/1000] | Train Loss=0.000967301 | Test Loss=0.029443644 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [437/1000] | Train Loss=0.001060048 | Test Loss=0.028927004 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [438/1000] | Train Loss=0.001038705 | Test Loss=0.029346328 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [439/1000] | Train Loss=0.001150696 | Test Loss=0.029359697 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [440/1000] | Train Loss=0.001279969 | Test Loss=0.029003198 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [441/1000] | Train Loss=0.001088187 | Test Loss=0.029374048 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [442/1000] | Train Loss=0.001066361 | Test Loss=0.029310746 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [443/1000] | Train Loss=0.001103582 | Test Loss=0.029134559 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [444/1000] | Train Loss=0.001042238 | Test Loss=0.029154465 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [445/1000] | Train Loss=0.001018553 | Test Loss=0.028929393 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [446/1000] | Train Loss=0.001082136 | Test Loss=0.028974405 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [447/1000] | Train Loss=0.001115310 | Test Loss=0.029110630 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [448/1000] | Train Loss=0.001023311 | Test Loss=0.029086823 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [449/1000] | Train Loss=0.000986549 | Test Loss=0.028642631 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [450/1000] | Train Loss=0.001037690 | Test Loss=0.029591921 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [451/1000] | Train Loss=0.001124292 | Test Loss=0.028895222 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [452/1000] | Train Loss=0.000983401 | Test Loss=0.029221059 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [453/1000] | Train Loss=0.001139046 | Test Loss=0.029170216 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [454/1000] | Train Loss=0.001033048 | Test Loss=0.029513134 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [455/1000] | Train Loss=0.001144261 | Test Loss=0.029194046 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [456/1000] | Train Loss=0.001069968 | Test Loss=0.029368170 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [457/1000] | Train Loss=0.001037245 | Test Loss=0.028973950 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [458/1000] | Train Loss=0.001140908 | Test Loss=0.029180140 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [459/1000] | Train Loss=0.001058337 | Test Loss=0.029295154 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [460/1000] | Train Loss=0.001078244 | Test Loss=0.029527846 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [461/1000] | Train Loss=0.001050661 | Test Loss=0.029189153 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [462/1000] | Train Loss=0.000999434 | Test Loss=0.029099831 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [463/1000] | Train Loss=0.000988378 | Test Loss=0.029055949 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [464/1000] | Train Loss=0.001036986 | Test Loss=0.028981726 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [465/1000] | Train Loss=0.001058967 | Test Loss=0.029419601 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [466/1000] | Train Loss=0.001111967 | Test Loss=0.029038220 | Time=1.86s | LR=1.25e-04\n",
      "Epoch [467/1000] | Train Loss=0.001151089 | Test Loss=0.029086958 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [468/1000] | Train Loss=0.000951405 | Test Loss=0.029061553 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [469/1000] | Train Loss=0.000958005 | Test Loss=0.029079715 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [470/1000] | Train Loss=0.000866707 | Test Loss=0.028837779 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [471/1000] | Train Loss=0.000828409 | Test Loss=0.028979933 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [472/1000] | Train Loss=0.000807329 | Test Loss=0.029113267 | Time=1.87s | LR=6.25e-05\n",
      "Epoch [473/1000] | Train Loss=0.000872025 | Test Loss=0.029045573 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [474/1000] | Train Loss=0.000947394 | Test Loss=0.029065568 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [475/1000] | Train Loss=0.000893922 | Test Loss=0.028881284 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [476/1000] | Train Loss=0.000850781 | Test Loss=0.029235956 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [477/1000] | Train Loss=0.000834744 | Test Loss=0.029192958 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [478/1000] | Train Loss=0.000825851 | Test Loss=0.028886720 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [479/1000] | Train Loss=0.000848502 | Test Loss=0.029029451 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [480/1000] | Train Loss=0.000886279 | Test Loss=0.029392651 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [481/1000] | Train Loss=0.000859395 | Test Loss=0.029559879 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [482/1000] | Train Loss=0.000874206 | Test Loss=0.028540200 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [483/1000] | Train Loss=0.000869712 | Test Loss=0.028937015 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [484/1000] | Train Loss=0.000821072 | Test Loss=0.028724695 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [485/1000] | Train Loss=0.000858104 | Test Loss=0.028807991 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [486/1000] | Train Loss=0.000878609 | Test Loss=0.028715571 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [487/1000] | Train Loss=0.001188377 | Test Loss=0.029048268 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [488/1000] | Train Loss=0.000954418 | Test Loss=0.029242423 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [489/1000] | Train Loss=0.000921060 | Test Loss=0.029038125 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [490/1000] | Train Loss=0.000895135 | Test Loss=0.028850434 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [491/1000] | Train Loss=0.000879281 | Test Loss=0.028859290 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [492/1000] | Train Loss=0.000883832 | Test Loss=0.029043130 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [493/1000] | Train Loss=0.000858547 | Test Loss=0.028839301 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [494/1000] | Train Loss=0.000890860 | Test Loss=0.028974269 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [495/1000] | Train Loss=0.000876548 | Test Loss=0.029004587 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [496/1000] | Train Loss=0.000829842 | Test Loss=0.028699017 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [497/1000] | Train Loss=0.000843386 | Test Loss=0.029242813 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [498/1000] | Train Loss=0.000878666 | Test Loss=0.028539280 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [499/1000] | Train Loss=0.000881391 | Test Loss=0.029158181 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [500/1000] | Train Loss=0.000882066 | Test Loss=0.028887400 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [501/1000] | Train Loss=0.000855320 | Test Loss=0.029283958 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [502/1000] | Train Loss=0.000926746 | Test Loss=0.028783540 | Time=1.86s | LR=6.25e-05\n",
      "Epoch [503/1000] | Train Loss=0.000835481 | Test Loss=0.029187574 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [504/1000] | Train Loss=0.000866947 | Test Loss=0.028800179 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [505/1000] | Train Loss=0.000775473 | Test Loss=0.028778760 | Time=1.87s | LR=3.13e-05\n",
      "Epoch [506/1000] | Train Loss=0.000805944 | Test Loss=0.029287967 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [507/1000] | Train Loss=0.000789255 | Test Loss=0.029109975 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [508/1000] | Train Loss=0.000878459 | Test Loss=0.028713847 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [509/1000] | Train Loss=0.000831302 | Test Loss=0.029381075 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [510/1000] | Train Loss=0.000761097 | Test Loss=0.028817332 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [511/1000] | Train Loss=0.000783497 | Test Loss=0.029302878 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [512/1000] | Train Loss=0.000822376 | Test Loss=0.029142013 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [513/1000] | Train Loss=0.000951463 | Test Loss=0.029338078 | Time=1.87s | LR=3.13e-05\n",
      "Epoch [514/1000] | Train Loss=0.000792072 | Test Loss=0.028627768 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [515/1000] | Train Loss=0.000786411 | Test Loss=0.029031275 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [516/1000] | Train Loss=0.000773316 | Test Loss=0.028963780 | Time=1.87s | LR=3.13e-05\n",
      "Epoch [517/1000] | Train Loss=0.000822935 | Test Loss=0.029409993 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [518/1000] | Train Loss=0.000867135 | Test Loss=0.029419835 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [519/1000] | Train Loss=0.000872189 | Test Loss=0.028786270 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [520/1000] | Train Loss=0.000798532 | Test Loss=0.029311297 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [521/1000] | Train Loss=0.000843968 | Test Loss=0.028644880 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [522/1000] | Train Loss=0.000806104 | Test Loss=0.028840439 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [523/1000] | Train Loss=0.000818985 | Test Loss=0.028908848 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [524/1000] | Train Loss=0.000862409 | Test Loss=0.028892848 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [525/1000] | Train Loss=0.000794319 | Test Loss=0.028871423 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [526/1000] | Train Loss=0.000816035 | Test Loss=0.028888324 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [527/1000] | Train Loss=0.000772192 | Test Loss=0.028680188 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [528/1000] | Train Loss=0.000773364 | Test Loss=0.029227044 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [529/1000] | Train Loss=0.000832492 | Test Loss=0.028812081 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [530/1000] | Train Loss=0.000840715 | Test Loss=0.028952442 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [531/1000] | Train Loss=0.000850565 | Test Loss=0.029388642 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [532/1000] | Train Loss=0.000790262 | Test Loss=0.028644482 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [533/1000] | Train Loss=0.000811367 | Test Loss=0.028544744 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [534/1000] | Train Loss=0.000848809 | Test Loss=0.028838906 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [535/1000] | Train Loss=0.000859760 | Test Loss=0.029826267 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [536/1000] | Train Loss=0.000802000 | Test Loss=0.028787343 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [537/1000] | Train Loss=0.000773657 | Test Loss=0.029182763 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [538/1000] | Train Loss=0.000777373 | Test Loss=0.028677678 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [539/1000] | Train Loss=0.000769888 | Test Loss=0.028709293 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [540/1000] | Train Loss=0.000834310 | Test Loss=0.028846210 | Time=1.86s | LR=3.13e-05\n",
      "Epoch [541/1000] | Train Loss=0.000787087 | Test Loss=0.029284013 | Time=1.87s | LR=1.56e-05\n",
      "Epoch [542/1000] | Train Loss=0.000748400 | Test Loss=0.028853113 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [543/1000] | Train Loss=0.000783801 | Test Loss=0.028964777 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [544/1000] | Train Loss=0.000756520 | Test Loss=0.029457458 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [545/1000] | Train Loss=0.000748825 | Test Loss=0.029091016 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [546/1000] | Train Loss=0.000738841 | Test Loss=0.028945383 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [547/1000] | Train Loss=0.000810169 | Test Loss=0.028995584 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [548/1000] | Train Loss=0.000749178 | Test Loss=0.028884769 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [549/1000] | Train Loss=0.000782223 | Test Loss=0.028851120 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [550/1000] | Train Loss=0.000762746 | Test Loss=0.029412733 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [551/1000] | Train Loss=0.000797805 | Test Loss=0.029035014 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [552/1000] | Train Loss=0.000858263 | Test Loss=0.029009000 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [553/1000] | Train Loss=0.000806290 | Test Loss=0.028891533 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [554/1000] | Train Loss=0.000773767 | Test Loss=0.028798338 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [555/1000] | Train Loss=0.000799292 | Test Loss=0.029174900 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [556/1000] | Train Loss=0.000778396 | Test Loss=0.029102278 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [557/1000] | Train Loss=0.000843045 | Test Loss=0.028725267 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [558/1000] | Train Loss=0.000740125 | Test Loss=0.029525749 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [559/1000] | Train Loss=0.000783396 | Test Loss=0.029253780 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [560/1000] | Train Loss=0.000788336 | Test Loss=0.029091013 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [561/1000] | Train Loss=0.000746703 | Test Loss=0.029360312 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [562/1000] | Train Loss=0.000807430 | Test Loss=0.029796506 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [563/1000] | Train Loss=0.000778688 | Test Loss=0.028619618 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [564/1000] | Train Loss=0.000738897 | Test Loss=0.029020589 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [565/1000] | Train Loss=0.000761334 | Test Loss=0.029062420 | Time=1.87s | LR=1.56e-05\n",
      "Epoch [566/1000] | Train Loss=0.000739415 | Test Loss=0.029105893 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [567/1000] | Train Loss=0.000827543 | Test Loss=0.028988552 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [568/1000] | Train Loss=0.000782467 | Test Loss=0.029100377 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [569/1000] | Train Loss=0.000748015 | Test Loss=0.029684485 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [570/1000] | Train Loss=0.000767831 | Test Loss=0.028801156 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [571/1000] | Train Loss=0.000804521 | Test Loss=0.029124233 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [572/1000] | Train Loss=0.000785515 | Test Loss=0.028862782 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [573/1000] | Train Loss=0.000737248 | Test Loss=0.028933131 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [574/1000] | Train Loss=0.000755468 | Test Loss=0.029103091 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [575/1000] | Train Loss=0.000772874 | Test Loss=0.028579582 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [576/1000] | Train Loss=0.000795429 | Test Loss=0.029488924 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [577/1000] | Train Loss=0.000773881 | Test Loss=0.028862030 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [578/1000] | Train Loss=0.000734160 | Test Loss=0.029232263 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [579/1000] | Train Loss=0.000749988 | Test Loss=0.028669974 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [580/1000] | Train Loss=0.000795622 | Test Loss=0.028811758 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [581/1000] | Train Loss=0.000770848 | Test Loss=0.028989296 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [582/1000] | Train Loss=0.000762145 | Test Loss=0.029007048 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [583/1000] | Train Loss=0.000765569 | Test Loss=0.028713727 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [584/1000] | Train Loss=0.000784066 | Test Loss=0.029201979 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [585/1000] | Train Loss=0.000781668 | Test Loss=0.028502939 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [586/1000] | Train Loss=0.000744967 | Test Loss=0.029136452 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [587/1000] | Train Loss=0.000751235 | Test Loss=0.029018608 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [588/1000] | Train Loss=0.000815591 | Test Loss=0.028757991 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [589/1000] | Train Loss=0.000752261 | Test Loss=0.029218141 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [590/1000] | Train Loss=0.000745900 | Test Loss=0.029177478 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [591/1000] | Train Loss=0.000897414 | Test Loss=0.028749469 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [592/1000] | Train Loss=0.000779758 | Test Loss=0.028739683 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [593/1000] | Train Loss=0.000739434 | Test Loss=0.028928856 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [594/1000] | Train Loss=0.000748848 | Test Loss=0.029144783 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [595/1000] | Train Loss=0.000734375 | Test Loss=0.029200229 | Time=1.87s | LR=1.56e-05\n",
      "Epoch [596/1000] | Train Loss=0.000744944 | Test Loss=0.028873324 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [597/1000] | Train Loss=0.000732715 | Test Loss=0.028883631 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [598/1000] | Train Loss=0.000748645 | Test Loss=0.028776829 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [599/1000] | Train Loss=0.000750681 | Test Loss=0.028740514 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [600/1000] | Train Loss=0.000857493 | Test Loss=0.028850773 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [601/1000] | Train Loss=0.000833558 | Test Loss=0.028949396 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [602/1000] | Train Loss=0.000760849 | Test Loss=0.029413429 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [603/1000] | Train Loss=0.000720149 | Test Loss=0.028790058 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [604/1000] | Train Loss=0.000799747 | Test Loss=0.029455486 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [605/1000] | Train Loss=0.000741100 | Test Loss=0.029349294 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [606/1000] | Train Loss=0.000769370 | Test Loss=0.029221870 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [607/1000] | Train Loss=0.000726628 | Test Loss=0.029320609 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [608/1000] | Train Loss=0.000784700 | Test Loss=0.028937177 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [609/1000] | Train Loss=0.000774579 | Test Loss=0.029137058 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [610/1000] | Train Loss=0.000751471 | Test Loss=0.028632823 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [611/1000] | Train Loss=0.000764355 | Test Loss=0.029230794 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [612/1000] | Train Loss=0.000761081 | Test Loss=0.028913718 | Time=1.87s | LR=1.56e-05\n",
      "Epoch [613/1000] | Train Loss=0.000758147 | Test Loss=0.029100657 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [614/1000] | Train Loss=0.000762120 | Test Loss=0.029230982 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [615/1000] | Train Loss=0.000744360 | Test Loss=0.029208192 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [616/1000] | Train Loss=0.000779743 | Test Loss=0.029000834 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [617/1000] | Train Loss=0.000770038 | Test Loss=0.029524753 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [618/1000] | Train Loss=0.000781019 | Test Loss=0.028821697 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [619/1000] | Train Loss=0.000742414 | Test Loss=0.029589153 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [620/1000] | Train Loss=0.000737702 | Test Loss=0.028881333 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [621/1000] | Train Loss=0.000741094 | Test Loss=0.029410271 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [622/1000] | Train Loss=0.000756468 | Test Loss=0.029209743 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [623/1000] | Train Loss=0.000738629 | Test Loss=0.029070194 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [624/1000] | Train Loss=0.000786799 | Test Loss=0.028956049 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [625/1000] | Train Loss=0.000749536 | Test Loss=0.029605097 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [626/1000] | Train Loss=0.000729639 | Test Loss=0.029903495 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [627/1000] | Train Loss=0.000775327 | Test Loss=0.028937270 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [628/1000] | Train Loss=0.000773734 | Test Loss=0.028948077 | Time=1.87s | LR=1.56e-05\n",
      "Epoch [629/1000] | Train Loss=0.000767970 | Test Loss=0.028969307 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [630/1000] | Train Loss=0.000758564 | Test Loss=0.028715970 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [631/1000] | Train Loss=0.000765466 | Test Loss=0.028881982 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [632/1000] | Train Loss=0.000836554 | Test Loss=0.029079070 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [633/1000] | Train Loss=0.000758434 | Test Loss=0.028880753 | Time=1.86s | LR=1.56e-05\n",
      "Epoch [634/1000] | Train Loss=0.000845131 | Test Loss=0.028890989 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [635/1000] | Train Loss=0.000714069 | Test Loss=0.029106147 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [636/1000] | Train Loss=0.000730903 | Test Loss=0.029257341 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [637/1000] | Train Loss=0.000740956 | Test Loss=0.028834958 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [638/1000] | Train Loss=0.000879382 | Test Loss=0.029357023 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [639/1000] | Train Loss=0.000786391 | Test Loss=0.028797166 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [640/1000] | Train Loss=0.000703272 | Test Loss=0.028979824 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [641/1000] | Train Loss=0.000728018 | Test Loss=0.028680943 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [642/1000] | Train Loss=0.000726535 | Test Loss=0.028886860 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [643/1000] | Train Loss=0.000716824 | Test Loss=0.029277847 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [644/1000] | Train Loss=0.000724306 | Test Loss=0.029043909 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [645/1000] | Train Loss=0.000755698 | Test Loss=0.029708164 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [646/1000] | Train Loss=0.000792827 | Test Loss=0.028663801 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [647/1000] | Train Loss=0.000799059 | Test Loss=0.029123509 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [648/1000] | Train Loss=0.000730999 | Test Loss=0.029407873 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [649/1000] | Train Loss=0.000735006 | Test Loss=0.028623561 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [650/1000] | Train Loss=0.000771997 | Test Loss=0.028799921 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [651/1000] | Train Loss=0.000748969 | Test Loss=0.029063967 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [652/1000] | Train Loss=0.000775412 | Test Loss=0.028736451 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [653/1000] | Train Loss=0.000719638 | Test Loss=0.029368218 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [654/1000] | Train Loss=0.000710980 | Test Loss=0.028940787 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [655/1000] | Train Loss=0.000722670 | Test Loss=0.028884184 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [656/1000] | Train Loss=0.000692328 | Test Loss=0.028878280 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [657/1000] | Train Loss=0.000707072 | Test Loss=0.029073683 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [658/1000] | Train Loss=0.000760018 | Test Loss=0.028783445 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [659/1000] | Train Loss=0.000716632 | Test Loss=0.029399838 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [660/1000] | Train Loss=0.000808411 | Test Loss=0.029229807 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [661/1000] | Train Loss=0.000719992 | Test Loss=0.028982958 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [662/1000] | Train Loss=0.000718655 | Test Loss=0.030194034 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [663/1000] | Train Loss=0.000728183 | Test Loss=0.029132133 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [664/1000] | Train Loss=0.000719244 | Test Loss=0.029133943 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [665/1000] | Train Loss=0.000723812 | Test Loss=0.029207949 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [666/1000] | Train Loss=0.000734639 | Test Loss=0.028967362 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [667/1000] | Train Loss=0.000733797 | Test Loss=0.028993396 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [668/1000] | Train Loss=0.000710523 | Test Loss=0.029083871 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [669/1000] | Train Loss=0.000762954 | Test Loss=0.028873168 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [670/1000] | Train Loss=0.000747849 | Test Loss=0.028805415 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [671/1000] | Train Loss=0.000778974 | Test Loss=0.028693385 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [672/1000] | Train Loss=0.000719720 | Test Loss=0.028947645 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [673/1000] | Train Loss=0.000720582 | Test Loss=0.028489080 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [674/1000] | Train Loss=0.000773013 | Test Loss=0.029474443 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [675/1000] | Train Loss=0.000798582 | Test Loss=0.029071665 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [676/1000] | Train Loss=0.000764321 | Test Loss=0.028742085 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [677/1000] | Train Loss=0.000711672 | Test Loss=0.028923199 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [678/1000] | Train Loss=0.000728019 | Test Loss=0.028978761 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [679/1000] | Train Loss=0.000718900 | Test Loss=0.028902257 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [680/1000] | Train Loss=0.000768517 | Test Loss=0.028859655 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [681/1000] | Train Loss=0.000775313 | Test Loss=0.028636931 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [682/1000] | Train Loss=0.000791997 | Test Loss=0.029647701 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [683/1000] | Train Loss=0.000756481 | Test Loss=0.029352321 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [684/1000] | Train Loss=0.000744804 | Test Loss=0.028817114 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [685/1000] | Train Loss=0.000769680 | Test Loss=0.029598012 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [686/1000] | Train Loss=0.000727722 | Test Loss=0.029127143 | Time=1.86s | LR=7.81e-06\n",
      "Epoch [687/1000] | Train Loss=0.000705193 | Test Loss=0.028834237 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [688/1000] | Train Loss=0.000711326 | Test Loss=0.028731193 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [689/1000] | Train Loss=0.000764893 | Test Loss=0.029313880 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [690/1000] | Train Loss=0.000734049 | Test Loss=0.029006710 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [691/1000] | Train Loss=0.000710396 | Test Loss=0.029301034 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [692/1000] | Train Loss=0.000747786 | Test Loss=0.028851464 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [693/1000] | Train Loss=0.000737952 | Test Loss=0.028760524 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [694/1000] | Train Loss=0.000724908 | Test Loss=0.028664040 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [695/1000] | Train Loss=0.000729859 | Test Loss=0.028803245 | Time=1.86s | LR=3.91e-06\n",
      "Epoch [696/1000] | Train Loss=0.000742598 | Test Loss=0.028598447 | Time=1.81s | LR=3.91e-06\n",
      "Epoch [697/1000] | Train Loss=0.000746086 | Test Loss=0.029018107 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [698/1000] | Train Loss=0.000709368 | Test Loss=0.028841214 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [699/1000] | Train Loss=0.000705397 | Test Loss=0.029293600 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [700/1000] | Train Loss=0.000718181 | Test Loss=0.029671309 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [701/1000] | Train Loss=0.000725047 | Test Loss=0.029162626 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [702/1000] | Train Loss=0.000730668 | Test Loss=0.028593785 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [703/1000] | Train Loss=0.000712080 | Test Loss=0.029205852 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [704/1000] | Train Loss=0.000718374 | Test Loss=0.028956596 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [705/1000] | Train Loss=0.000735357 | Test Loss=0.029025333 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [706/1000] | Train Loss=0.000715084 | Test Loss=0.028813203 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [707/1000] | Train Loss=0.000797970 | Test Loss=0.028592282 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [708/1000] | Train Loss=0.000722471 | Test Loss=0.028752623 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [709/1000] | Train Loss=0.000755513 | Test Loss=0.028697980 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [710/1000] | Train Loss=0.000742709 | Test Loss=0.028583712 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [711/1000] | Train Loss=0.000718410 | Test Loss=0.028970231 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [712/1000] | Train Loss=0.000796608 | Test Loss=0.028818955 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [713/1000] | Train Loss=0.000749743 | Test Loss=0.028760826 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [714/1000] | Train Loss=0.000792643 | Test Loss=0.028871984 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [715/1000] | Train Loss=0.000714059 | Test Loss=0.029036480 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [716/1000] | Train Loss=0.000701720 | Test Loss=0.028511537 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [717/1000] | Train Loss=0.000706108 | Test Loss=0.028752552 | Time=1.80s | LR=3.91e-06\n",
      "Epoch [718/1000] | Train Loss=0.000701475 | Test Loss=0.028790840 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [719/1000] | Train Loss=0.000768070 | Test Loss=0.029549769 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [720/1000] | Train Loss=0.000736768 | Test Loss=0.029173276 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [721/1000] | Train Loss=0.000700907 | Test Loss=0.029331044 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [722/1000] | Train Loss=0.000716027 | Test Loss=0.029317156 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [723/1000] | Train Loss=0.000714186 | Test Loss=0.028656645 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [724/1000] | Train Loss=0.000729857 | Test Loss=0.029281356 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [725/1000] | Train Loss=0.000715577 | Test Loss=0.028913294 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [726/1000] | Train Loss=0.000715394 | Test Loss=0.029114940 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [727/1000] | Train Loss=0.000745962 | Test Loss=0.028633342 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [728/1000] | Train Loss=0.000736483 | Test Loss=0.029074329 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [729/1000] | Train Loss=0.000716503 | Test Loss=0.029100467 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [730/1000] | Train Loss=0.000750946 | Test Loss=0.029170151 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [731/1000] | Train Loss=0.000796660 | Test Loss=0.030064253 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [732/1000] | Train Loss=0.000723578 | Test Loss=0.028926219 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [733/1000] | Train Loss=0.000712130 | Test Loss=0.028828219 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [734/1000] | Train Loss=0.000724497 | Test Loss=0.029098965 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [735/1000] | Train Loss=0.000707799 | Test Loss=0.028754863 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [736/1000] | Train Loss=0.000697089 | Test Loss=0.028551352 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [737/1000] | Train Loss=0.000745960 | Test Loss=0.029075253 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [738/1000] | Train Loss=0.000688414 | Test Loss=0.028983889 | Time=1.82s | LR=1.95e-06\n",
      "Epoch [739/1000] | Train Loss=0.000836926 | Test Loss=0.028723062 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [740/1000] | Train Loss=0.000703864 | Test Loss=0.029152026 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [741/1000] | Train Loss=0.000733432 | Test Loss=0.029231897 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [742/1000] | Train Loss=0.000729258 | Test Loss=0.028683384 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [743/1000] | Train Loss=0.000726778 | Test Loss=0.028680441 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [744/1000] | Train Loss=0.000712742 | Test Loss=0.029088367 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [745/1000] | Train Loss=0.000688900 | Test Loss=0.028719040 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [746/1000] | Train Loss=0.000696002 | Test Loss=0.028777034 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [747/1000] | Train Loss=0.000734226 | Test Loss=0.028498819 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [748/1000] | Train Loss=0.000745607 | Test Loss=0.028910067 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [749/1000] | Train Loss=0.000749458 | Test Loss=0.028853732 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [750/1000] | Train Loss=0.000723856 | Test Loss=0.028771054 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [751/1000] | Train Loss=0.000705124 | Test Loss=0.029044177 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [752/1000] | Train Loss=0.000715285 | Test Loss=0.029083505 | Time=1.70s | LR=1.95e-06\n",
      "Epoch [753/1000] | Train Loss=0.000733958 | Test Loss=0.029040733 | Time=1.89s | LR=1.95e-06\n",
      "Epoch [754/1000] | Train Loss=0.000725072 | Test Loss=0.028587798 | Time=2.05s | LR=1.95e-06\n",
      "Epoch [755/1000] | Train Loss=0.000743141 | Test Loss=0.029073992 | Time=1.98s | LR=1.95e-06\n",
      "Epoch [756/1000] | Train Loss=0.000721370 | Test Loss=0.028774588 | Time=1.89s | LR=1.95e-06\n",
      "Epoch [757/1000] | Train Loss=0.000822954 | Test Loss=0.028827266 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [758/1000] | Train Loss=0.000729306 | Test Loss=0.029545704 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [759/1000] | Train Loss=0.000744992 | Test Loss=0.028566054 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [760/1000] | Train Loss=0.000701985 | Test Loss=0.029149193 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [761/1000] | Train Loss=0.000736458 | Test Loss=0.028663567 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [762/1000] | Train Loss=0.000704768 | Test Loss=0.029051713 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [763/1000] | Train Loss=0.000759968 | Test Loss=0.028854485 | Time=1.86s | LR=1.95e-06\n",
      "Epoch [764/1000] | Train Loss=0.000732949 | Test Loss=0.028917937 | Time=1.83s | LR=1.95e-06\n",
      "Epoch [765/1000] | Train Loss=0.000783915 | Test Loss=0.029372991 | Time=1.81s | LR=1.95e-06\n",
      "Epoch [766/1000] | Train Loss=0.000713557 | Test Loss=0.029082854 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [767/1000] | Train Loss=0.000749106 | Test Loss=0.029050030 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [768/1000] | Train Loss=0.000776952 | Test Loss=0.028995535 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [769/1000] | Train Loss=0.000700885 | Test Loss=0.029148780 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [770/1000] | Train Loss=0.000722246 | Test Loss=0.028845974 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [771/1000] | Train Loss=0.000686049 | Test Loss=0.028972200 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [772/1000] | Train Loss=0.000716294 | Test Loss=0.029075228 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [773/1000] | Train Loss=0.000686071 | Test Loss=0.028906258 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [774/1000] | Train Loss=0.000755901 | Test Loss=0.028690426 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [775/1000] | Train Loss=0.000723047 | Test Loss=0.029052164 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [776/1000] | Train Loss=0.000705916 | Test Loss=0.028805682 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [777/1000] | Train Loss=0.000765909 | Test Loss=0.028763887 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [778/1000] | Train Loss=0.000703817 | Test Loss=0.028579063 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [779/1000] | Train Loss=0.000705406 | Test Loss=0.028705095 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [780/1000] | Train Loss=0.000693052 | Test Loss=0.028511114 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [781/1000] | Train Loss=0.000716856 | Test Loss=0.028758706 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [782/1000] | Train Loss=0.000699580 | Test Loss=0.028687391 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [783/1000] | Train Loss=0.000748119 | Test Loss=0.028938035 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [784/1000] | Train Loss=0.000697334 | Test Loss=0.028978076 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [785/1000] | Train Loss=0.000719612 | Test Loss=0.028707194 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [786/1000] | Train Loss=0.000761018 | Test Loss=0.028652700 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [787/1000] | Train Loss=0.000700199 | Test Loss=0.029787509 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [788/1000] | Train Loss=0.000727521 | Test Loss=0.028797650 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [789/1000] | Train Loss=0.000732044 | Test Loss=0.029231480 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [790/1000] | Train Loss=0.000704352 | Test Loss=0.028682452 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [791/1000] | Train Loss=0.000708659 | Test Loss=0.028765254 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [792/1000] | Train Loss=0.000698592 | Test Loss=0.029044299 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [793/1000] | Train Loss=0.000721016 | Test Loss=0.029951098 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [794/1000] | Train Loss=0.000707426 | Test Loss=0.029271223 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [795/1000] | Train Loss=0.000691658 | Test Loss=0.028873139 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [796/1000] | Train Loss=0.000748716 | Test Loss=0.028998792 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [797/1000] | Train Loss=0.000700538 | Test Loss=0.028946962 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [798/1000] | Train Loss=0.000717018 | Test Loss=0.029005763 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [799/1000] | Train Loss=0.000822280 | Test Loss=0.028647679 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [800/1000] | Train Loss=0.000689590 | Test Loss=0.029409797 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [801/1000] | Train Loss=0.000709281 | Test Loss=0.028968476 | Time=1.80s | LR=9.77e-07\n",
      "Epoch [802/1000] | Train Loss=0.000696398 | Test Loss=0.029003640 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [803/1000] | Train Loss=0.000700230 | Test Loss=0.028725173 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [804/1000] | Train Loss=0.000711985 | Test Loss=0.029513290 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [805/1000] | Train Loss=0.000689406 | Test Loss=0.028630095 | Time=1.70s | LR=4.88e-07\n",
      "Epoch [806/1000] | Train Loss=0.000733745 | Test Loss=0.028706516 | Time=2.03s | LR=4.88e-07\n",
      "Epoch [807/1000] | Train Loss=0.000702679 | Test Loss=0.029090461 | Time=2.02s | LR=4.88e-07\n",
      "Epoch [808/1000] | Train Loss=0.000715938 | Test Loss=0.028944830 | Time=1.99s | LR=4.88e-07\n",
      "Epoch [809/1000] | Train Loss=0.000677112 | Test Loss=0.028842947 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [810/1000] | Train Loss=0.000727917 | Test Loss=0.028819002 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [811/1000] | Train Loss=0.000717475 | Test Loss=0.028522516 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [812/1000] | Train Loss=0.000705298 | Test Loss=0.028805679 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [813/1000] | Train Loss=0.000719746 | Test Loss=0.029053704 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [814/1000] | Train Loss=0.000776755 | Test Loss=0.028651898 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [815/1000] | Train Loss=0.000681780 | Test Loss=0.028898119 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [816/1000] | Train Loss=0.000702665 | Test Loss=0.028899108 | Time=1.81s | LR=4.88e-07\n",
      "Epoch [817/1000] | Train Loss=0.000705817 | Test Loss=0.028844435 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [818/1000] | Train Loss=0.000717580 | Test Loss=0.029008266 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [819/1000] | Train Loss=0.000705760 | Test Loss=0.029024951 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [820/1000] | Train Loss=0.000701867 | Test Loss=0.028748875 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [821/1000] | Train Loss=0.000747397 | Test Loss=0.029317883 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [822/1000] | Train Loss=0.000696450 | Test Loss=0.028927262 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [823/1000] | Train Loss=0.000743265 | Test Loss=0.028823410 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [824/1000] | Train Loss=0.000721113 | Test Loss=0.029218422 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [825/1000] | Train Loss=0.000698472 | Test Loss=0.028897709 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [826/1000] | Train Loss=0.000718896 | Test Loss=0.029086706 | Time=1.80s | LR=4.88e-07\n",
      "Epoch [827/1000] | Train Loss=0.000765335 | Test Loss=0.028731454 | Time=1.92s | LR=4.88e-07\n",
      "Epoch [828/1000] | Train Loss=0.000746756 | Test Loss=0.028736885 | Time=1.84s | LR=4.88e-07\n",
      "Epoch [829/1000] | Train Loss=0.000717161 | Test Loss=0.028919057 | Time=1.74s | LR=4.88e-07\n",
      "Epoch [830/1000] | Train Loss=0.000693772 | Test Loss=0.028732138 | Time=1.87s | LR=4.88e-07\n",
      "Epoch [831/1000] | Train Loss=0.000698409 | Test Loss=0.029093057 | Time=1.87s | LR=4.88e-07\n",
      "Epoch [832/1000] | Train Loss=0.000706035 | Test Loss=0.028965695 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [833/1000] | Train Loss=0.000719763 | Test Loss=0.028862657 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [834/1000] | Train Loss=0.000716022 | Test Loss=0.028853820 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [835/1000] | Train Loss=0.000703118 | Test Loss=0.029474934 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [836/1000] | Train Loss=0.000694735 | Test Loss=0.029119832 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [837/1000] | Train Loss=0.000711009 | Test Loss=0.029301600 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [838/1000] | Train Loss=0.000746521 | Test Loss=0.028837299 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [839/1000] | Train Loss=0.000762688 | Test Loss=0.028650566 | Time=1.85s | LR=4.88e-07\n",
      "Epoch [840/1000] | Train Loss=0.000706008 | Test Loss=0.028725771 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [841/1000] | Train Loss=0.000736870 | Test Loss=0.029065994 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [842/1000] | Train Loss=0.000712653 | Test Loss=0.028407928 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [843/1000] | Train Loss=0.000711335 | Test Loss=0.028839880 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [844/1000] | Train Loss=0.000737783 | Test Loss=0.028847002 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [845/1000] | Train Loss=0.000712234 | Test Loss=0.028920400 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [846/1000] | Train Loss=0.000709518 | Test Loss=0.028756864 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [847/1000] | Train Loss=0.000716053 | Test Loss=0.028798579 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [848/1000] | Train Loss=0.000747024 | Test Loss=0.028814104 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [849/1000] | Train Loss=0.000728439 | Test Loss=0.028961762 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [850/1000] | Train Loss=0.000688167 | Test Loss=0.029006363 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [851/1000] | Train Loss=0.000711806 | Test Loss=0.028965088 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [852/1000] | Train Loss=0.000697786 | Test Loss=0.028953832 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [853/1000] | Train Loss=0.000696055 | Test Loss=0.029482251 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [854/1000] | Train Loss=0.000772526 | Test Loss=0.028997662 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [855/1000] | Train Loss=0.000735171 | Test Loss=0.028728676 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [856/1000] | Train Loss=0.000714116 | Test Loss=0.029300409 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [857/1000] | Train Loss=0.000708924 | Test Loss=0.029049638 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [858/1000] | Train Loss=0.000787661 | Test Loss=0.029546202 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [859/1000] | Train Loss=0.000729497 | Test Loss=0.029038580 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [860/1000] | Train Loss=0.000753904 | Test Loss=0.029005506 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [861/1000] | Train Loss=0.000704212 | Test Loss=0.029070111 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [862/1000] | Train Loss=0.000723876 | Test Loss=0.029371657 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [863/1000] | Train Loss=0.000785796 | Test Loss=0.029700684 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [864/1000] | Train Loss=0.000702133 | Test Loss=0.029014118 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [865/1000] | Train Loss=0.000709113 | Test Loss=0.028568402 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [866/1000] | Train Loss=0.000703127 | Test Loss=0.028622730 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [867/1000] | Train Loss=0.000753343 | Test Loss=0.028875759 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [868/1000] | Train Loss=0.000698081 | Test Loss=0.029266079 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [869/1000] | Train Loss=0.000700384 | Test Loss=0.028795573 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [870/1000] | Train Loss=0.000761510 | Test Loss=0.028713122 | Time=1.85s | LR=2.44e-07\n",
      "Epoch [871/1000] | Train Loss=0.000765364 | Test Loss=0.028756259 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [872/1000] | Train Loss=0.000702477 | Test Loss=0.028724971 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [873/1000] | Train Loss=0.000728014 | Test Loss=0.028732578 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [874/1000] | Train Loss=0.000709606 | Test Loss=0.029006364 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [875/1000] | Train Loss=0.000704378 | Test Loss=0.029073349 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [876/1000] | Train Loss=0.000706678 | Test Loss=0.029122115 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [877/1000] | Train Loss=0.000786726 | Test Loss=0.029155742 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [878/1000] | Train Loss=0.000740813 | Test Loss=0.029730971 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [879/1000] | Train Loss=0.000752611 | Test Loss=0.029262827 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [880/1000] | Train Loss=0.000731295 | Test Loss=0.029181298 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [881/1000] | Train Loss=0.000745378 | Test Loss=0.028593183 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [882/1000] | Train Loss=0.000681572 | Test Loss=0.029459135 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [883/1000] | Train Loss=0.000845937 | Test Loss=0.028667542 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [884/1000] | Train Loss=0.000718771 | Test Loss=0.029006935 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [885/1000] | Train Loss=0.000699402 | Test Loss=0.028736736 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [886/1000] | Train Loss=0.000698314 | Test Loss=0.028956094 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [887/1000] | Train Loss=0.000704473 | Test Loss=0.028886743 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [888/1000] | Train Loss=0.000691232 | Test Loss=0.028882408 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [889/1000] | Train Loss=0.000693016 | Test Loss=0.028783415 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [890/1000] | Train Loss=0.000718010 | Test Loss=0.029238272 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [891/1000] | Train Loss=0.000684677 | Test Loss=0.028931408 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [892/1000] | Train Loss=0.000783150 | Test Loss=0.028871164 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [893/1000] | Train Loss=0.000684091 | Test Loss=0.029466628 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [894/1000] | Train Loss=0.000808392 | Test Loss=0.028785106 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [895/1000] | Train Loss=0.000742359 | Test Loss=0.028719789 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [896/1000] | Train Loss=0.000746632 | Test Loss=0.028891679 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [897/1000] | Train Loss=0.000729579 | Test Loss=0.028849631 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [898/1000] | Train Loss=0.000716306 | Test Loss=0.029243007 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [899/1000] | Train Loss=0.000763847 | Test Loss=0.029190799 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [900/1000] | Train Loss=0.000710617 | Test Loss=0.028674566 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [901/1000] | Train Loss=0.000734285 | Test Loss=0.029000994 | Time=1.85s | LR=1.22e-07\n",
      "Epoch [902/1000] | Train Loss=0.000723136 | Test Loss=0.028601248 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [903/1000] | Train Loss=0.000703302 | Test Loss=0.029029924 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [904/1000] | Train Loss=0.000745802 | Test Loss=0.029330581 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [905/1000] | Train Loss=0.000728819 | Test Loss=0.028643740 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [906/1000] | Train Loss=0.000698723 | Test Loss=0.029496271 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [907/1000] | Train Loss=0.000705941 | Test Loss=0.029015758 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [908/1000] | Train Loss=0.000693462 | Test Loss=0.028804918 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [909/1000] | Train Loss=0.000690169 | Test Loss=0.028911617 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [910/1000] | Train Loss=0.000697681 | Test Loss=0.028954602 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [911/1000] | Train Loss=0.000761735 | Test Loss=0.029094023 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [912/1000] | Train Loss=0.000683874 | Test Loss=0.028720234 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [913/1000] | Train Loss=0.000790492 | Test Loss=0.028732381 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [914/1000] | Train Loss=0.000712504 | Test Loss=0.028789929 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [915/1000] | Train Loss=0.000690849 | Test Loss=0.028677090 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [916/1000] | Train Loss=0.000700600 | Test Loss=0.028712222 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [917/1000] | Train Loss=0.000767522 | Test Loss=0.029339933 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [918/1000] | Train Loss=0.000689805 | Test Loss=0.028801193 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [919/1000] | Train Loss=0.000704067 | Test Loss=0.029000428 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [920/1000] | Train Loss=0.000697543 | Test Loss=0.029127365 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [921/1000] | Train Loss=0.000720240 | Test Loss=0.029273743 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [922/1000] | Train Loss=0.000759947 | Test Loss=0.029327994 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [923/1000] | Train Loss=0.000732821 | Test Loss=0.028872973 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [924/1000] | Train Loss=0.000695300 | Test Loss=0.028920718 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [925/1000] | Train Loss=0.000719328 | Test Loss=0.029128133 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [926/1000] | Train Loss=0.000740082 | Test Loss=0.029206857 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [927/1000] | Train Loss=0.000738712 | Test Loss=0.028969028 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [928/1000] | Train Loss=0.000709093 | Test Loss=0.028966428 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [929/1000] | Train Loss=0.000759220 | Test Loss=0.029213719 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [930/1000] | Train Loss=0.000707354 | Test Loss=0.029058785 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [931/1000] | Train Loss=0.000752028 | Test Loss=0.028847165 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [932/1000] | Train Loss=0.000772172 | Test Loss=0.029489351 | Time=1.85s | LR=6.10e-08\n",
      "Epoch [933/1000] | Train Loss=0.000724098 | Test Loss=0.029071062 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [934/1000] | Train Loss=0.000725644 | Test Loss=0.029103599 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [935/1000] | Train Loss=0.000738546 | Test Loss=0.029244614 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [936/1000] | Train Loss=0.000761575 | Test Loss=0.029109297 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [937/1000] | Train Loss=0.000729024 | Test Loss=0.028447786 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [938/1000] | Train Loss=0.000719046 | Test Loss=0.029562745 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [939/1000] | Train Loss=0.000726942 | Test Loss=0.028649977 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [940/1000] | Train Loss=0.000699562 | Test Loss=0.028649734 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [941/1000] | Train Loss=0.000729032 | Test Loss=0.028919711 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [942/1000] | Train Loss=0.000677018 | Test Loss=0.028990215 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [943/1000] | Train Loss=0.000730216 | Test Loss=0.028931381 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [944/1000] | Train Loss=0.000797899 | Test Loss=0.028517455 | Time=1.86s | LR=3.05e-08\n",
      "Epoch [945/1000] | Train Loss=0.000748526 | Test Loss=0.028626074 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [946/1000] | Train Loss=0.000694648 | Test Loss=0.028874596 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [947/1000] | Train Loss=0.000726633 | Test Loss=0.029032842 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [948/1000] | Train Loss=0.000699910 | Test Loss=0.029341998 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [949/1000] | Train Loss=0.000717325 | Test Loss=0.028866314 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [950/1000] | Train Loss=0.000718837 | Test Loss=0.028999251 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [951/1000] | Train Loss=0.000696198 | Test Loss=0.029322336 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [952/1000] | Train Loss=0.000815208 | Test Loss=0.028946172 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [953/1000] | Train Loss=0.000727977 | Test Loss=0.028891342 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [954/1000] | Train Loss=0.000741434 | Test Loss=0.028659185 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [955/1000] | Train Loss=0.000701494 | Test Loss=0.029026081 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [956/1000] | Train Loss=0.000719473 | Test Loss=0.028850125 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [957/1000] | Train Loss=0.000699686 | Test Loss=0.028710915 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [958/1000] | Train Loss=0.000720567 | Test Loss=0.028961952 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [959/1000] | Train Loss=0.000690387 | Test Loss=0.028842530 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [960/1000] | Train Loss=0.000692536 | Test Loss=0.028687844 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [961/1000] | Train Loss=0.000698391 | Test Loss=0.029066508 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [962/1000] | Train Loss=0.000705487 | Test Loss=0.028754211 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [963/1000] | Train Loss=0.000816827 | Test Loss=0.028892692 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [964/1000] | Train Loss=0.000778557 | Test Loss=0.029076075 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [965/1000] | Train Loss=0.000707636 | Test Loss=0.028702471 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [966/1000] | Train Loss=0.000705793 | Test Loss=0.029037257 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [967/1000] | Train Loss=0.000715946 | Test Loss=0.029000890 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [968/1000] | Train Loss=0.000702261 | Test Loss=0.028811725 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [969/1000] | Train Loss=0.000702692 | Test Loss=0.028687863 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [970/1000] | Train Loss=0.000710975 | Test Loss=0.028787980 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [971/1000] | Train Loss=0.000706301 | Test Loss=0.028646851 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [972/1000] | Train Loss=0.000685486 | Test Loss=0.028760904 | Time=1.85s | LR=3.05e-08\n",
      "Epoch [973/1000] | Train Loss=0.000695660 | Test Loss=0.028705398 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [974/1000] | Train Loss=0.000712181 | Test Loss=0.028884110 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [975/1000] | Train Loss=0.000792474 | Test Loss=0.028721492 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [976/1000] | Train Loss=0.000694425 | Test Loss=0.029003774 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [977/1000] | Train Loss=0.000714023 | Test Loss=0.028981967 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [978/1000] | Train Loss=0.000692131 | Test Loss=0.028887001 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [979/1000] | Train Loss=0.000744659 | Test Loss=0.028903803 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [980/1000] | Train Loss=0.000702574 | Test Loss=0.028603463 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [981/1000] | Train Loss=0.000783619 | Test Loss=0.028756061 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [982/1000] | Train Loss=0.000679697 | Test Loss=0.028665929 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [983/1000] | Train Loss=0.000689507 | Test Loss=0.028865114 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [984/1000] | Train Loss=0.000710548 | Test Loss=0.028755608 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [985/1000] | Train Loss=0.000725858 | Test Loss=0.028626433 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [986/1000] | Train Loss=0.000696224 | Test Loss=0.028935472 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [987/1000] | Train Loss=0.000701769 | Test Loss=0.028861374 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [988/1000] | Train Loss=0.000724682 | Test Loss=0.028872304 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [989/1000] | Train Loss=0.000702197 | Test Loss=0.029149295 | Time=1.85s | LR=1.53e-08\n",
      "Epoch [990/1000] | Train Loss=0.000697701 | Test Loss=0.028569896 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [991/1000] | Train Loss=0.000719710 | Test Loss=0.028888465 | Time=1.86s | LR=1.53e-08\n",
      "Epoch [992/1000] | Train Loss=0.000711402 | Test Loss=0.029676819 | Time=1.88s | LR=1.53e-08\n",
      "Epoch [993/1000] | Train Loss=0.000774626 | Test Loss=0.029224147 | Time=1.83s | LR=1.53e-08\n",
      "Epoch [994/1000] | Train Loss=0.000699029 | Test Loss=0.029221049 | Time=1.80s | LR=1.53e-08\n",
      "Epoch [995/1000] | Train Loss=0.000720812 | Test Loss=0.029435801 | Time=1.80s | LR=1.53e-08\n",
      "Epoch [996/1000] | Train Loss=0.000685929 | Test Loss=0.029004586 | Time=1.80s | LR=1.53e-08\n",
      "Epoch [997/1000] | Train Loss=0.000702755 | Test Loss=0.028850901 | Time=1.80s | LR=1.53e-08\n",
      "Epoch [998/1000] | Train Loss=0.000710702 | Test Loss=0.028579265 | Time=1.80s | LR=1.53e-08\n",
      "Epoch [999/1000] | Train Loss=0.000682419 | Test Loss=0.028810099 | Time=1.80s | LR=1.53e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000709539 | Test Loss=0.028859367 | Time=1.80s | LR=1.53e-08\n",
      "\n",
      "Total training time: 1856.25 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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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-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_G3.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/1000] | Train Loss=0.001164839 | Test Loss=0.029092091 | Time=1.54s | LR=1.00e-04\n",
      "Epoch [2/1000] | Train Loss=0.001084226 | Test Loss=0.029041471 | Time=1.47s | LR=1.00e-04\n",
      "Epoch [3/1000] | Train Loss=0.000884832 | Test Loss=0.028740517 | Time=1.47s | LR=1.00e-04\n",
      "Epoch [4/1000] | Train Loss=0.000877442 | Test Loss=0.029206663 | Time=1.47s | LR=1.00e-04\n",
      "Epoch [5/1000] | Train Loss=0.001077220 | Test Loss=0.029815392 | Time=1.47s | LR=1.00e-04\n",
      "Epoch [6/1000] | Train Loss=0.000910991 | Test Loss=0.029302381 | Time=1.47s | LR=1.00e-04\n",
      "Epoch [7/1000] | Train Loss=0.000940889 | Test Loss=0.029148652 | Time=1.50s | LR=1.00e-04\n",
      "Epoch [8/1000] | Train Loss=0.000927915 | Test Loss=0.029214608 | Time=1.00s | LR=1.00e-04\n",
      "Epoch [9/1000] | Train Loss=0.000935765 | Test Loss=0.030174309 | Time=1.17s | LR=1.00e-04\n",
      "Epoch [10/1000] | Train Loss=0.000914350 | Test Loss=0.029024710 | Time=1.64s | LR=1.00e-04\n",
      "Epoch [11/1000] | Train Loss=0.000888785 | Test Loss=0.028839733 | Time=1.85s | LR=1.00e-04\n",
      "Epoch [12/1000] | Train Loss=0.000986397 | Test Loss=0.028824359 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [13/1000] | Train Loss=0.000931982 | Test Loss=0.028986136 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [14/1000] | Train Loss=0.001010486 | Test Loss=0.029153541 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [15/1000] | Train Loss=0.000913081 | Test Loss=0.028711862 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [16/1000] | Train Loss=0.000874947 | Test Loss=0.029016650 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [17/1000] | Train Loss=0.001047171 | Test Loss=0.028894625 | Time=1.83s | LR=1.00e-04\n",
      "Epoch [18/1000] | Train Loss=0.000860709 | Test Loss=0.028578104 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [19/1000] | Train Loss=0.000821859 | Test Loss=0.028969971 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [20/1000] | Train Loss=0.000877737 | Test Loss=0.028895269 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [21/1000] | Train Loss=0.000936901 | Test Loss=0.029010848 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [22/1000] | Train Loss=0.000944090 | Test Loss=0.028580564 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [23/1000] | Train Loss=0.000915762 | Test Loss=0.028744723 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [24/1000] | Train Loss=0.000961072 | Test Loss=0.028964520 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [25/1000] | Train Loss=0.000912926 | Test Loss=0.029424233 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [26/1000] | Train Loss=0.000911769 | Test Loss=0.029302975 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [27/1000] | Train Loss=0.000930634 | Test Loss=0.029090921 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [28/1000] | Train Loss=0.000953555 | Test Loss=0.029663775 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [29/1000] | Train Loss=0.000864252 | Test Loss=0.029338171 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [30/1000] | Train Loss=0.000968617 | Test Loss=0.028959344 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [31/1000] | Train Loss=0.000950877 | Test Loss=0.028600622 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [32/1000] | Train Loss=0.000868351 | Test Loss=0.029489165 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [33/1000] | Train Loss=0.000904984 | Test Loss=0.028969168 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [34/1000] | Train Loss=0.001027801 | Test Loss=0.029133697 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [35/1000] | Train Loss=0.000943711 | Test Loss=0.029016953 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [36/1000] | Train Loss=0.000929083 | Test Loss=0.029136311 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [37/1000] | Train Loss=0.000889935 | Test Loss=0.029224176 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [38/1000] | Train Loss=0.000859085 | Test Loss=0.029550102 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [39/1000] | Train Loss=0.000928438 | Test Loss=0.029113797 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [40/1000] | Train Loss=0.001025584 | Test Loss=0.029111404 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [41/1000] | Train Loss=0.000935198 | Test Loss=0.029156716 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [42/1000] | Train Loss=0.000919453 | Test Loss=0.028730818 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [43/1000] | Train Loss=0.000877942 | Test Loss=0.028948386 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [44/1000] | Train Loss=0.000895545 | Test Loss=0.029029808 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [45/1000] | Train Loss=0.000954416 | Test Loss=0.028875085 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [46/1000] | Train Loss=0.001142557 | Test Loss=0.028904504 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [47/1000] | Train Loss=0.001050530 | Test Loss=0.030439131 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [48/1000] | Train Loss=0.000907058 | Test Loss=0.028644779 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [49/1000] | Train Loss=0.000909774 | Test Loss=0.029378960 | Time=1.81s | LR=1.00e-04\n",
      "Epoch [50/1000] | Train Loss=0.000899419 | Test Loss=0.029224155 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [51/1000] | Train Loss=0.000874065 | Test Loss=0.028939445 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [52/1000] | Train Loss=0.000825894 | Test Loss=0.028590402 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [53/1000] | Train Loss=0.000779416 | Test Loss=0.028832586 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [54/1000] | Train Loss=0.000792588 | Test Loss=0.029398516 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [55/1000] | Train Loss=0.000836642 | Test Loss=0.029577163 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [56/1000] | Train Loss=0.000825460 | Test Loss=0.028693544 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [57/1000] | Train Loss=0.000785095 | Test Loss=0.029201059 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [58/1000] | Train Loss=0.000780973 | Test Loss=0.028975691 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [59/1000] | Train Loss=0.000853176 | Test Loss=0.029015248 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [60/1000] | Train Loss=0.000860861 | Test Loss=0.028893390 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [61/1000] | Train Loss=0.000769268 | Test Loss=0.028895018 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [62/1000] | Train Loss=0.000802826 | Test Loss=0.029572403 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [63/1000] | Train Loss=0.000810432 | Test Loss=0.028796888 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [64/1000] | Train Loss=0.000850503 | Test Loss=0.028913865 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [65/1000] | Train Loss=0.000828177 | Test Loss=0.028818958 | Time=1.83s | LR=5.00e-05\n",
      "Epoch [66/1000] | Train Loss=0.000769378 | Test Loss=0.029178825 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [67/1000] | Train Loss=0.000849388 | Test Loss=0.029230190 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [68/1000] | Train Loss=0.000793539 | Test Loss=0.028655617 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [69/1000] | Train Loss=0.000798030 | Test Loss=0.028642269 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [70/1000] | Train Loss=0.000816408 | Test Loss=0.028948314 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [71/1000] | Train Loss=0.000816467 | Test Loss=0.029168085 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [72/1000] | Train Loss=0.000889316 | Test Loss=0.029115366 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [73/1000] | Train Loss=0.000809140 | Test Loss=0.028916344 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [74/1000] | Train Loss=0.000865028 | Test Loss=0.028819722 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [75/1000] | Train Loss=0.000775008 | Test Loss=0.028755774 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [76/1000] | Train Loss=0.000864665 | Test Loss=0.029065489 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [77/1000] | Train Loss=0.000764833 | Test Loss=0.029282557 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [78/1000] | Train Loss=0.000814039 | Test Loss=0.028624093 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [79/1000] | Train Loss=0.000770475 | Test Loss=0.028690165 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [80/1000] | Train Loss=0.000777472 | Test Loss=0.029006011 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [81/1000] | Train Loss=0.000787420 | Test Loss=0.028996624 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [82/1000] | Train Loss=0.000850912 | Test Loss=0.028744189 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [83/1000] | Train Loss=0.000778684 | Test Loss=0.028813030 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [84/1000] | Train Loss=0.000881303 | Test Loss=0.028978310 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [85/1000] | Train Loss=0.000868660 | Test Loss=0.028370258 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [86/1000] | Train Loss=0.000770904 | Test Loss=0.028730838 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [87/1000] | Train Loss=0.000825910 | Test Loss=0.028725707 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [88/1000] | Train Loss=0.000782286 | Test Loss=0.028866338 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [89/1000] | Train Loss=0.000772124 | Test Loss=0.028962638 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [90/1000] | Train Loss=0.000796434 | Test Loss=0.028875185 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [91/1000] | Train Loss=0.000766817 | Test Loss=0.028497676 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [92/1000] | Train Loss=0.000810344 | Test Loss=0.028574972 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [93/1000] | Train Loss=0.000778654 | Test Loss=0.028867038 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [94/1000] | Train Loss=0.000826699 | Test Loss=0.028785072 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [95/1000] | Train Loss=0.000833263 | Test Loss=0.028922072 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [96/1000] | Train Loss=0.000754503 | Test Loss=0.028814440 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [97/1000] | Train Loss=0.000768801 | Test Loss=0.029128124 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [98/1000] | Train Loss=0.000820326 | Test Loss=0.028751305 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [99/1000] | Train Loss=0.000780832 | Test Loss=0.029121171 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [100/1000] | Train Loss=0.000765644 | Test Loss=0.028350084 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [101/1000] | Train Loss=0.000800033 | Test Loss=0.029192293 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [102/1000] | Train Loss=0.000803397 | Test Loss=0.028842175 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [103/1000] | Train Loss=0.000819790 | Test Loss=0.028664436 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [104/1000] | Train Loss=0.000790677 | Test Loss=0.028981647 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [105/1000] | Train Loss=0.000778530 | Test Loss=0.029009960 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [106/1000] | Train Loss=0.000799516 | Test Loss=0.028715093 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [107/1000] | Train Loss=0.000826179 | Test Loss=0.028502010 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [108/1000] | Train Loss=0.000797987 | Test Loss=0.028867374 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [109/1000] | Train Loss=0.000786332 | Test Loss=0.029075025 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [110/1000] | Train Loss=0.000826491 | Test Loss=0.028737869 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [111/1000] | Train Loss=0.000850504 | Test Loss=0.029376815 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [112/1000] | Train Loss=0.000817821 | Test Loss=0.029024703 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [113/1000] | Train Loss=0.000761081 | Test Loss=0.028904404 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [114/1000] | Train Loss=0.000826331 | Test Loss=0.028988039 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [115/1000] | Train Loss=0.000769295 | Test Loss=0.028752494 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [116/1000] | Train Loss=0.000741765 | Test Loss=0.028757034 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [117/1000] | Train Loss=0.000905169 | Test Loss=0.028683713 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [118/1000] | Train Loss=0.000837551 | Test Loss=0.028974272 | Time=1.83s | LR=5.00e-05\n",
      "Epoch [119/1000] | Train Loss=0.000742496 | Test Loss=0.028856090 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [120/1000] | Train Loss=0.000835192 | Test Loss=0.028506225 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [121/1000] | Train Loss=0.000796997 | Test Loss=0.028843817 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [122/1000] | Train Loss=0.000760912 | Test Loss=0.028455948 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [123/1000] | Train Loss=0.000802999 | Test Loss=0.028459458 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [124/1000] | Train Loss=0.000766406 | Test Loss=0.028825675 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [125/1000] | Train Loss=0.000885071 | Test Loss=0.028634694 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [126/1000] | Train Loss=0.000841560 | Test Loss=0.028705460 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [127/1000] | Train Loss=0.000793560 | Test Loss=0.029150787 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [128/1000] | Train Loss=0.000999410 | Test Loss=0.029197745 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [129/1000] | Train Loss=0.000785000 | Test Loss=0.029004352 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [130/1000] | Train Loss=0.000802388 | Test Loss=0.028419970 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [131/1000] | Train Loss=0.000754100 | Test Loss=0.029273485 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [132/1000] | Train Loss=0.000773738 | Test Loss=0.028822970 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [133/1000] | Train Loss=0.000719533 | Test Loss=0.028746013 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [134/1000] | Train Loss=0.000764817 | Test Loss=0.028757770 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [135/1000] | Train Loss=0.000907604 | Test Loss=0.028653361 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [136/1000] | Train Loss=0.000778018 | Test Loss=0.028296320 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [137/1000] | Train Loss=0.000756789 | Test Loss=0.029169666 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [138/1000] | Train Loss=0.000927429 | Test Loss=0.028842369 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [139/1000] | Train Loss=0.000852468 | Test Loss=0.028695038 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [140/1000] | Train Loss=0.000762247 | Test Loss=0.029013565 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [141/1000] | Train Loss=0.000761600 | Test Loss=0.028405325 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [142/1000] | Train Loss=0.000793538 | Test Loss=0.029035152 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [143/1000] | Train Loss=0.000769468 | Test Loss=0.028882466 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [144/1000] | Train Loss=0.000778484 | Test Loss=0.028964200 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [145/1000] | Train Loss=0.000790621 | Test Loss=0.029348030 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [146/1000] | Train Loss=0.000808196 | Test Loss=0.029383482 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [147/1000] | Train Loss=0.000744633 | Test Loss=0.029113359 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [148/1000] | Train Loss=0.000960346 | Test Loss=0.028684272 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [149/1000] | Train Loss=0.000762696 | Test Loss=0.029100571 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [150/1000] | Train Loss=0.000778613 | Test Loss=0.029036714 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [151/1000] | Train Loss=0.000775359 | Test Loss=0.028745204 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [152/1000] | Train Loss=0.000752967 | Test Loss=0.029143880 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [153/1000] | Train Loss=0.000821780 | Test Loss=0.028506803 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [154/1000] | Train Loss=0.000805942 | Test Loss=0.028624360 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [155/1000] | Train Loss=0.000775586 | Test Loss=0.030118584 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [156/1000] | Train Loss=0.000871928 | Test Loss=0.029337286 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [157/1000] | Train Loss=0.000801610 | Test Loss=0.028914851 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [158/1000] | Train Loss=0.000754152 | Test Loss=0.028741269 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [159/1000] | Train Loss=0.000780716 | Test Loss=0.028945967 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [160/1000] | Train Loss=0.000786688 | Test Loss=0.028363338 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [161/1000] | Train Loss=0.000778139 | Test Loss=0.028827290 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [162/1000] | Train Loss=0.000766030 | Test Loss=0.028823401 | Time=1.82s | LR=5.00e-05\n",
      "Epoch [163/1000] | Train Loss=0.000844118 | Test Loss=0.028731734 | Time=1.81s | LR=5.00e-05\n",
      "Epoch [164/1000] | Train Loss=0.000764901 | Test Loss=0.028904599 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [165/1000] | Train Loss=0.000729938 | Test Loss=0.028694236 | Time=1.81s | LR=2.50e-05\n",
      "Epoch [166/1000] | Train Loss=0.000743606 | Test Loss=0.029219556 | Time=1.81s | LR=2.50e-05\n",
      "Epoch [167/1000] | Train Loss=0.000708113 | Test Loss=0.029255767 | Time=1.81s | LR=2.50e-05\n",
      "Epoch [168/1000] | Train Loss=0.000725884 | Test Loss=0.029272112 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [169/1000] | Train Loss=0.000718648 | Test Loss=0.028531921 | Time=1.81s | LR=2.50e-05\n",
      "Epoch [170/1000] | Train Loss=0.000688702 | Test Loss=0.028830166 | Time=1.85s | LR=2.50e-05\n",
      "Epoch [171/1000] | Train Loss=0.000775596 | Test Loss=0.028919097 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [172/1000] | Train Loss=0.000704406 | Test Loss=0.028830409 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [173/1000] | Train Loss=0.000693570 | Test Loss=0.028578845 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [174/1000] | Train Loss=0.000741081 | Test Loss=0.028826353 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [175/1000] | Train Loss=0.000737542 | Test Loss=0.028764537 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [176/1000] | Train Loss=0.000763266 | Test Loss=0.028667337 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [177/1000] | Train Loss=0.000704681 | Test Loss=0.028574410 | Time=1.88s | LR=2.50e-05\n",
      "Epoch [178/1000] | Train Loss=0.000749993 | Test Loss=0.029419058 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [179/1000] | Train Loss=0.000706313 | Test Loss=0.028650365 | Time=1.87s | LR=2.50e-05\n",
      "Epoch [180/1000] | Train Loss=0.000761157 | Test Loss=0.028799469 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [181/1000] | Train Loss=0.000745280 | Test Loss=0.029324921 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [182/1000] | Train Loss=0.000719101 | Test Loss=0.028303386 | Time=1.86s | LR=2.50e-05\n",
      "Epoch [183/1000] | Train Loss=0.000716405 | Test Loss=0.029054193 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [184/1000] | Train Loss=0.000739683 | Test Loss=0.028708394 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [185/1000] | Train Loss=0.000726063 | Test Loss=0.028450782 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [186/1000] | Train Loss=0.000707748 | Test Loss=0.028657874 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [187/1000] | Train Loss=0.000708129 | Test Loss=0.028812128 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [188/1000] | Train Loss=0.000728525 | Test Loss=0.028805052 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [189/1000] | Train Loss=0.000731025 | Test Loss=0.029041346 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [190/1000] | Train Loss=0.000761728 | Test Loss=0.028550701 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [191/1000] | Train Loss=0.000744638 | Test Loss=0.028877648 | Time=1.81s | LR=2.50e-05\n",
      "Epoch [192/1000] | Train Loss=0.000864302 | Test Loss=0.028956273 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [193/1000] | Train Loss=0.000690283 | Test Loss=0.028893797 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [194/1000] | Train Loss=0.000721481 | Test Loss=0.028567019 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [195/1000] | Train Loss=0.000694221 | Test Loss=0.028940521 | Time=1.83s | LR=2.50e-05\n",
      "Epoch [196/1000] | Train Loss=0.000704896 | Test Loss=0.028990465 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [197/1000] | Train Loss=0.000705009 | Test Loss=0.028878430 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [198/1000] | Train Loss=0.000719388 | Test Loss=0.028780077 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [199/1000] | Train Loss=0.000713613 | Test Loss=0.028993391 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [200/1000] | Train Loss=0.000727297 | Test Loss=0.029371565 | Time=1.82s | LR=2.50e-05\n",
      "Epoch [201/1000] | Train Loss=0.000751087 | Test Loss=0.028950049 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [202/1000] | Train Loss=0.000710406 | Test Loss=0.029124267 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [203/1000] | Train Loss=0.000694081 | Test Loss=0.028515402 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [204/1000] | Train Loss=0.000708398 | Test Loss=0.029024417 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [205/1000] | Train Loss=0.000708901 | Test Loss=0.028520556 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [206/1000] | Train Loss=0.000690619 | Test Loss=0.028808548 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [207/1000] | Train Loss=0.000673352 | Test Loss=0.028885744 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [208/1000] | Train Loss=0.000698869 | Test Loss=0.028910283 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [209/1000] | Train Loss=0.000689150 | Test Loss=0.028801309 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [210/1000] | Train Loss=0.000718208 | Test Loss=0.029152038 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [211/1000] | Train Loss=0.000805470 | Test Loss=0.028856505 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [212/1000] | Train Loss=0.000707424 | Test Loss=0.028947985 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [213/1000] | Train Loss=0.000685260 | Test Loss=0.028747789 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [214/1000] | Train Loss=0.000720105 | Test Loss=0.028366318 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [215/1000] | Train Loss=0.000691759 | Test Loss=0.028647007 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [216/1000] | Train Loss=0.000699008 | Test Loss=0.028627110 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [217/1000] | Train Loss=0.000677383 | Test Loss=0.028937904 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [218/1000] | Train Loss=0.000729141 | Test Loss=0.029223275 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [219/1000] | Train Loss=0.000705875 | Test Loss=0.028755529 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [220/1000] | Train Loss=0.000715569 | Test Loss=0.029781064 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [221/1000] | Train Loss=0.000682513 | Test Loss=0.028814590 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [222/1000] | Train Loss=0.000716470 | Test Loss=0.028770751 | Time=1.83s | LR=1.25e-05\n",
      "Epoch [223/1000] | Train Loss=0.000708366 | Test Loss=0.028732039 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [224/1000] | Train Loss=0.000725028 | Test Loss=0.029023826 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [225/1000] | Train Loss=0.000765833 | Test Loss=0.028608650 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [226/1000] | Train Loss=0.000658819 | Test Loss=0.028941372 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [227/1000] | Train Loss=0.000737185 | Test Loss=0.028990811 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [228/1000] | Train Loss=0.000710394 | Test Loss=0.028605341 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [229/1000] | Train Loss=0.000663253 | Test Loss=0.029433870 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [230/1000] | Train Loss=0.000725066 | Test Loss=0.028989379 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [231/1000] | Train Loss=0.000661826 | Test Loss=0.028800382 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [232/1000] | Train Loss=0.000693342 | Test Loss=0.029027129 | Time=1.83s | LR=1.25e-05\n",
      "Epoch [233/1000] | Train Loss=0.000707943 | Test Loss=0.028806655 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [234/1000] | Train Loss=0.000733928 | Test Loss=0.029005965 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [235/1000] | Train Loss=0.000696677 | Test Loss=0.028629821 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [236/1000] | Train Loss=0.000779943 | Test Loss=0.028453663 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [237/1000] | Train Loss=0.000743308 | Test Loss=0.029130113 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [238/1000] | Train Loss=0.000690992 | Test Loss=0.028695171 | Time=1.83s | LR=1.25e-05\n",
      "Epoch [239/1000] | Train Loss=0.000697819 | Test Loss=0.029270724 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [240/1000] | Train Loss=0.000711674 | Test Loss=0.028919308 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [241/1000] | Train Loss=0.000749843 | Test Loss=0.028990965 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [242/1000] | Train Loss=0.000696524 | Test Loss=0.028953248 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [243/1000] | Train Loss=0.000657640 | Test Loss=0.028829655 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [244/1000] | Train Loss=0.000674188 | Test Loss=0.028793983 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [245/1000] | Train Loss=0.000719942 | Test Loss=0.029132583 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [246/1000] | Train Loss=0.000695239 | Test Loss=0.028773159 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [247/1000] | Train Loss=0.000714188 | Test Loss=0.028695485 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [248/1000] | Train Loss=0.000693254 | Test Loss=0.028551708 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [249/1000] | Train Loss=0.000715413 | Test Loss=0.028788154 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [250/1000] | Train Loss=0.000687861 | Test Loss=0.028641777 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [251/1000] | Train Loss=0.000706120 | Test Loss=0.028401767 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [252/1000] | Train Loss=0.000675269 | Test Loss=0.028627487 | Time=1.83s | LR=1.25e-05\n",
      "Epoch [253/1000] | Train Loss=0.000692668 | Test Loss=0.028977057 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [254/1000] | Train Loss=0.000680120 | Test Loss=0.029348973 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [255/1000] | Train Loss=0.000669100 | Test Loss=0.029024448 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [256/1000] | Train Loss=0.000705312 | Test Loss=0.028763210 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [257/1000] | Train Loss=0.000745362 | Test Loss=0.029509858 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [258/1000] | Train Loss=0.000667294 | Test Loss=0.028937310 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [259/1000] | Train Loss=0.000722220 | Test Loss=0.029416633 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [260/1000] | Train Loss=0.000682004 | Test Loss=0.029048430 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [261/1000] | Train Loss=0.000731380 | Test Loss=0.029232007 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [262/1000] | Train Loss=0.000735094 | Test Loss=0.028990225 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [263/1000] | Train Loss=0.000669550 | Test Loss=0.029600547 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [264/1000] | Train Loss=0.000703190 | Test Loss=0.029362029 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [265/1000] | Train Loss=0.000698158 | Test Loss=0.029204071 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [266/1000] | Train Loss=0.000670264 | Test Loss=0.028802824 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [267/1000] | Train Loss=0.000741253 | Test Loss=0.028866683 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [268/1000] | Train Loss=0.000667953 | Test Loss=0.028928132 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [269/1000] | Train Loss=0.000774847 | Test Loss=0.028622637 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [270/1000] | Train Loss=0.000667215 | Test Loss=0.028704385 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [271/1000] | Train Loss=0.000690837 | Test Loss=0.029277133 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [272/1000] | Train Loss=0.000688573 | Test Loss=0.028725084 | Time=1.81s | LR=1.25e-05\n",
      "Epoch [273/1000] | Train Loss=0.000688597 | Test Loss=0.028491072 | Time=1.82s | LR=1.25e-05\n",
      "Epoch [274/1000] | Train Loss=0.000697198 | Test Loss=0.028767629 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [275/1000] | Train Loss=0.000663543 | Test Loss=0.028890075 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [276/1000] | Train Loss=0.000671404 | Test Loss=0.028702390 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [277/1000] | Train Loss=0.000765497 | Test Loss=0.028776673 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [278/1000] | Train Loss=0.000664928 | Test Loss=0.028982751 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [279/1000] | Train Loss=0.000695638 | Test Loss=0.029003898 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [280/1000] | Train Loss=0.000664421 | Test Loss=0.029135381 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [281/1000] | Train Loss=0.000657984 | Test Loss=0.028610546 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [282/1000] | Train Loss=0.000675276 | Test Loss=0.029073713 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [283/1000] | Train Loss=0.000687424 | Test Loss=0.028883564 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [284/1000] | Train Loss=0.000692739 | Test Loss=0.028966982 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [285/1000] | Train Loss=0.000657526 | Test Loss=0.028791099 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [286/1000] | Train Loss=0.000732799 | Test Loss=0.028493132 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [287/1000] | Train Loss=0.000736094 | Test Loss=0.029004317 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [288/1000] | Train Loss=0.000710250 | Test Loss=0.028963490 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [289/1000] | Train Loss=0.000693085 | Test Loss=0.029696525 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [290/1000] | Train Loss=0.000666800 | Test Loss=0.029071862 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [291/1000] | Train Loss=0.000655243 | Test Loss=0.028653353 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [292/1000] | Train Loss=0.000666632 | Test Loss=0.029061795 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [293/1000] | Train Loss=0.000651500 | Test Loss=0.028742505 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [294/1000] | Train Loss=0.000708804 | Test Loss=0.029486284 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [295/1000] | Train Loss=0.000718397 | Test Loss=0.029199914 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [296/1000] | Train Loss=0.000708532 | Test Loss=0.028588911 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [297/1000] | Train Loss=0.000742235 | Test Loss=0.028725805 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [298/1000] | Train Loss=0.000669805 | Test Loss=0.029207321 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [299/1000] | Train Loss=0.000656284 | Test Loss=0.029127009 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [300/1000] | Train Loss=0.000661187 | Test Loss=0.029615144 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [301/1000] | Train Loss=0.000703461 | Test Loss=0.028986199 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [302/1000] | Train Loss=0.000693777 | Test Loss=0.028725439 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [303/1000] | Train Loss=0.000634839 | Test Loss=0.028608343 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [304/1000] | Train Loss=0.000685996 | Test Loss=0.028751055 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [305/1000] | Train Loss=0.000648046 | Test Loss=0.029014929 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [306/1000] | Train Loss=0.000708696 | Test Loss=0.028820044 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [307/1000] | Train Loss=0.000665377 | Test Loss=0.028932759 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [308/1000] | Train Loss=0.000667392 | Test Loss=0.029006733 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [309/1000] | Train Loss=0.000656424 | Test Loss=0.029248560 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [310/1000] | Train Loss=0.000702025 | Test Loss=0.029226540 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [311/1000] | Train Loss=0.000758703 | Test Loss=0.028442661 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [312/1000] | Train Loss=0.000664268 | Test Loss=0.028805185 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [313/1000] | Train Loss=0.000642442 | Test Loss=0.029079016 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [314/1000] | Train Loss=0.000709545 | Test Loss=0.028832033 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [315/1000] | Train Loss=0.000781944 | Test Loss=0.029568398 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [316/1000] | Train Loss=0.000664684 | Test Loss=0.028681653 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [317/1000] | Train Loss=0.000756304 | Test Loss=0.028724331 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [318/1000] | Train Loss=0.000732488 | Test Loss=0.028861171 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [319/1000] | Train Loss=0.000670858 | Test Loss=0.028774458 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [320/1000] | Train Loss=0.000648056 | Test Loss=0.028856689 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [321/1000] | Train Loss=0.000677183 | Test Loss=0.029564072 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [322/1000] | Train Loss=0.000687215 | Test Loss=0.028822505 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [323/1000] | Train Loss=0.000714063 | Test Loss=0.028855465 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [324/1000] | Train Loss=0.000673986 | Test Loss=0.028669523 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [325/1000] | Train Loss=0.000682343 | Test Loss=0.028553486 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [326/1000] | Train Loss=0.000675133 | Test Loss=0.029259656 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [327/1000] | Train Loss=0.000669338 | Test Loss=0.028972357 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [328/1000] | Train Loss=0.000681239 | Test Loss=0.028647801 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [329/1000] | Train Loss=0.000705322 | Test Loss=0.028865156 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [330/1000] | Train Loss=0.000656264 | Test Loss=0.028948040 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [331/1000] | Train Loss=0.000663464 | Test Loss=0.028499623 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [332/1000] | Train Loss=0.000685868 | Test Loss=0.028717725 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [333/1000] | Train Loss=0.000676892 | Test Loss=0.028869659 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [334/1000] | Train Loss=0.000667366 | Test Loss=0.029240710 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [335/1000] | Train Loss=0.000651278 | Test Loss=0.029061564 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [336/1000] | Train Loss=0.000666460 | Test Loss=0.028736342 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [337/1000] | Train Loss=0.000715114 | Test Loss=0.028443049 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [338/1000] | Train Loss=0.000663659 | Test Loss=0.028733701 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [339/1000] | Train Loss=0.000681388 | Test Loss=0.029229946 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [340/1000] | Train Loss=0.000640140 | Test Loss=0.029285727 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [341/1000] | Train Loss=0.000675084 | Test Loss=0.029866506 | Time=1.81s | LR=3.13e-06\n",
      "Epoch [342/1000] | Train Loss=0.000672581 | Test Loss=0.028948996 | Time=1.81s | LR=3.13e-06\n",
      "Epoch [343/1000] | Train Loss=0.000661605 | Test Loss=0.028771746 | Time=1.81s | LR=3.13e-06\n",
      "Epoch [344/1000] | Train Loss=0.000704435 | Test Loss=0.028665067 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [345/1000] | Train Loss=0.000678210 | Test Loss=0.029372992 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [346/1000] | Train Loss=0.000735407 | Test Loss=0.028422866 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [347/1000] | Train Loss=0.000667104 | Test Loss=0.029020683 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [348/1000] | Train Loss=0.000651150 | Test Loss=0.029257669 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [349/1000] | Train Loss=0.000693197 | Test Loss=0.028517354 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [350/1000] | Train Loss=0.000649536 | Test Loss=0.028639256 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [351/1000] | Train Loss=0.000705443 | Test Loss=0.029078948 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [352/1000] | Train Loss=0.000675091 | Test Loss=0.028853118 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [353/1000] | Train Loss=0.000661340 | Test Loss=0.028827895 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [354/1000] | Train Loss=0.000657586 | Test Loss=0.028779434 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [355/1000] | Train Loss=0.000664108 | Test Loss=0.029289374 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [356/1000] | Train Loss=0.000656004 | Test Loss=0.028759160 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [357/1000] | Train Loss=0.000686605 | Test Loss=0.029447828 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [358/1000] | Train Loss=0.000714505 | Test Loss=0.029236115 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [359/1000] | Train Loss=0.000668794 | Test Loss=0.028933088 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [360/1000] | Train Loss=0.000686413 | Test Loss=0.028574642 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [361/1000] | Train Loss=0.000705257 | Test Loss=0.028862764 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [362/1000] | Train Loss=0.000665236 | Test Loss=0.028946522 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [363/1000] | Train Loss=0.000674980 | Test Loss=0.028807606 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [364/1000] | Train Loss=0.000681068 | Test Loss=0.028761282 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [365/1000] | Train Loss=0.000638362 | Test Loss=0.028705529 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [366/1000] | Train Loss=0.000645360 | Test Loss=0.028603292 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [367/1000] | Train Loss=0.000688623 | Test Loss=0.028732674 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [368/1000] | Train Loss=0.000679223 | Test Loss=0.028683011 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [369/1000] | Train Loss=0.000648996 | Test Loss=0.028826673 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [370/1000] | Train Loss=0.000655454 | Test Loss=0.028638139 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [371/1000] | Train Loss=0.000662322 | Test Loss=0.028789382 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [372/1000] | Train Loss=0.000643317 | Test Loss=0.028928714 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [373/1000] | Train Loss=0.000713523 | Test Loss=0.028956864 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [374/1000] | Train Loss=0.000643949 | Test Loss=0.029540801 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [375/1000] | Train Loss=0.000659675 | Test Loss=0.029074658 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [376/1000] | Train Loss=0.000677412 | Test Loss=0.029099544 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [377/1000] | Train Loss=0.000629867 | Test Loss=0.028694877 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [378/1000] | Train Loss=0.000653310 | Test Loss=0.028469517 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [379/1000] | Train Loss=0.000661266 | Test Loss=0.028907448 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [380/1000] | Train Loss=0.000660129 | Test Loss=0.029071208 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [381/1000] | Train Loss=0.000654466 | Test Loss=0.028678584 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [382/1000] | Train Loss=0.000653139 | Test Loss=0.028977049 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [383/1000] | Train Loss=0.000675376 | Test Loss=0.028594834 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [384/1000] | Train Loss=0.000669445 | Test Loss=0.028712200 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [385/1000] | Train Loss=0.000646380 | Test Loss=0.028869913 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [386/1000] | Train Loss=0.000634974 | Test Loss=0.028972776 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [387/1000] | Train Loss=0.000662367 | Test Loss=0.029046511 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [388/1000] | Train Loss=0.000651339 | Test Loss=0.028825230 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [389/1000] | Train Loss=0.000685647 | Test Loss=0.028544750 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [390/1000] | Train Loss=0.000670524 | Test Loss=0.028910664 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [391/1000] | Train Loss=0.000646830 | Test Loss=0.028943074 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [392/1000] | Train Loss=0.000663998 | Test Loss=0.028654244 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [393/1000] | Train Loss=0.000654208 | Test Loss=0.028779242 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [394/1000] | Train Loss=0.000716788 | Test Loss=0.028739408 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [395/1000] | Train Loss=0.000669109 | Test Loss=0.029770777 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [396/1000] | Train Loss=0.000682856 | Test Loss=0.029187981 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [397/1000] | Train Loss=0.000699145 | Test Loss=0.029018365 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [398/1000] | Train Loss=0.000743890 | Test Loss=0.029332355 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [399/1000] | Train Loss=0.000676527 | Test Loss=0.028878042 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [400/1000] | Train Loss=0.000669253 | Test Loss=0.029422289 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [401/1000] | Train Loss=0.000643204 | Test Loss=0.028664462 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [402/1000] | Train Loss=0.000665772 | Test Loss=0.028727990 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [403/1000] | Train Loss=0.000687929 | Test Loss=0.029321530 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [404/1000] | Train Loss=0.000653816 | Test Loss=0.028466602 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [405/1000] | Train Loss=0.000701600 | Test Loss=0.029510685 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [406/1000] | Train Loss=0.000802749 | Test Loss=0.029072689 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [407/1000] | Train Loss=0.000682655 | Test Loss=0.029014752 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [408/1000] | Train Loss=0.000684203 | Test Loss=0.028815644 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [409/1000] | Train Loss=0.000668127 | Test Loss=0.028796844 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [410/1000] | Train Loss=0.000639192 | Test Loss=0.028630596 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [411/1000] | Train Loss=0.000642641 | Test Loss=0.028618811 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [412/1000] | Train Loss=0.000659641 | Test Loss=0.028864359 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [413/1000] | Train Loss=0.000655864 | Test Loss=0.028641139 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [414/1000] | Train Loss=0.000665530 | Test Loss=0.029352949 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [415/1000] | Train Loss=0.000671707 | Test Loss=0.028806679 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [416/1000] | Train Loss=0.000676667 | Test Loss=0.028437642 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [417/1000] | Train Loss=0.000678069 | Test Loss=0.028872242 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [418/1000] | Train Loss=0.000638612 | Test Loss=0.028922704 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [419/1000] | Train Loss=0.000659807 | Test Loss=0.028773486 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [420/1000] | Train Loss=0.000638259 | Test Loss=0.029179109 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [421/1000] | Train Loss=0.000650410 | Test Loss=0.029474764 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [422/1000] | Train Loss=0.000677721 | Test Loss=0.028961998 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [423/1000] | Train Loss=0.000666748 | Test Loss=0.028947141 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [424/1000] | Train Loss=0.000636674 | Test Loss=0.029019100 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [425/1000] | Train Loss=0.000663769 | Test Loss=0.028839653 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [426/1000] | Train Loss=0.000645448 | Test Loss=0.028956864 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [427/1000] | Train Loss=0.000658827 | Test Loss=0.028774276 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [428/1000] | Train Loss=0.000655221 | Test Loss=0.028844707 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [429/1000] | Train Loss=0.000655475 | Test Loss=0.029341394 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [430/1000] | Train Loss=0.000643323 | Test Loss=0.028627743 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [431/1000] | Train Loss=0.000678397 | Test Loss=0.028734444 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [432/1000] | Train Loss=0.000640479 | Test Loss=0.028581838 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [433/1000] | Train Loss=0.000679289 | Test Loss=0.029041195 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [434/1000] | Train Loss=0.000641146 | Test Loss=0.028764767 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [435/1000] | Train Loss=0.000647575 | Test Loss=0.028714112 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [436/1000] | Train Loss=0.000633836 | Test Loss=0.029039843 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [437/1000] | Train Loss=0.000651519 | Test Loss=0.029192375 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [438/1000] | Train Loss=0.000666194 | Test Loss=0.028614132 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [439/1000] | Train Loss=0.000652332 | Test Loss=0.029282577 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [440/1000] | Train Loss=0.000685041 | Test Loss=0.029035456 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [441/1000] | Train Loss=0.000677889 | Test Loss=0.029066155 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [442/1000] | Train Loss=0.000642846 | Test Loss=0.028863366 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [443/1000] | Train Loss=0.000663211 | Test Loss=0.028954266 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [444/1000] | Train Loss=0.000657137 | Test Loss=0.029040645 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [445/1000] | Train Loss=0.000723442 | Test Loss=0.028630452 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [446/1000] | Train Loss=0.000676262 | Test Loss=0.028778738 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [447/1000] | Train Loss=0.000651445 | Test Loss=0.029100626 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [448/1000] | Train Loss=0.000656078 | Test Loss=0.028937732 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [449/1000] | Train Loss=0.000644267 | Test Loss=0.029231713 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [450/1000] | Train Loss=0.000664992 | Test Loss=0.028839104 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [451/1000] | Train Loss=0.000650468 | Test Loss=0.028661275 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [452/1000] | Train Loss=0.000676381 | Test Loss=0.028646235 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [453/1000] | Train Loss=0.000686690 | Test Loss=0.028791465 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [454/1000] | Train Loss=0.000697703 | Test Loss=0.029205306 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [455/1000] | Train Loss=0.000645497 | Test Loss=0.028732620 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [456/1000] | Train Loss=0.000652114 | Test Loss=0.029280721 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [457/1000] | Train Loss=0.000667621 | Test Loss=0.028710847 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [458/1000] | Train Loss=0.000655358 | Test Loss=0.028551176 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [459/1000] | Train Loss=0.000635797 | Test Loss=0.028553882 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [460/1000] | Train Loss=0.000657726 | Test Loss=0.028981967 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [461/1000] | Train Loss=0.000688304 | Test Loss=0.028844731 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [462/1000] | Train Loss=0.000736498 | Test Loss=0.029121224 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [463/1000] | Train Loss=0.000659896 | Test Loss=0.028663029 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [464/1000] | Train Loss=0.000652723 | Test Loss=0.028921632 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [465/1000] | Train Loss=0.000676894 | Test Loss=0.028936976 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [466/1000] | Train Loss=0.000660177 | Test Loss=0.028998457 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [467/1000] | Train Loss=0.000662418 | Test Loss=0.028736767 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [468/1000] | Train Loss=0.000661968 | Test Loss=0.028799668 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [469/1000] | Train Loss=0.000651432 | Test Loss=0.029235485 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [470/1000] | Train Loss=0.000673818 | Test Loss=0.029002740 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [471/1000] | Train Loss=0.000669203 | Test Loss=0.028731296 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [472/1000] | Train Loss=0.000699759 | Test Loss=0.028795215 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [473/1000] | Train Loss=0.000687018 | Test Loss=0.028876666 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [474/1000] | Train Loss=0.000683081 | Test Loss=0.028594623 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [475/1000] | Train Loss=0.000696678 | Test Loss=0.028971735 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [476/1000] | Train Loss=0.000701250 | Test Loss=0.029026900 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [477/1000] | Train Loss=0.000659977 | Test Loss=0.029438413 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [478/1000] | Train Loss=0.000678179 | Test Loss=0.028744478 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [479/1000] | Train Loss=0.000652778 | Test Loss=0.029063131 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [480/1000] | Train Loss=0.000671602 | Test Loss=0.029227520 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [481/1000] | Train Loss=0.000653437 | Test Loss=0.028848529 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [482/1000] | Train Loss=0.000691773 | Test Loss=0.028713219 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [483/1000] | Train Loss=0.000647316 | Test Loss=0.028677111 | Time=1.81s | LR=1.95e-07\n",
      "Epoch [484/1000] | Train Loss=0.000649149 | Test Loss=0.028897050 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [485/1000] | Train Loss=0.000662032 | Test Loss=0.028908537 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [486/1000] | Train Loss=0.000662609 | Test Loss=0.028806018 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [487/1000] | Train Loss=0.000659628 | Test Loss=0.028502079 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [488/1000] | Train Loss=0.000649513 | Test Loss=0.028954310 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [489/1000] | Train Loss=0.000651946 | Test Loss=0.028648669 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [490/1000] | Train Loss=0.000644519 | Test Loss=0.029001305 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [491/1000] | Train Loss=0.000641106 | Test Loss=0.028933173 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [492/1000] | Train Loss=0.000687489 | Test Loss=0.029455326 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [493/1000] | Train Loss=0.000669152 | Test Loss=0.028782525 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [494/1000] | Train Loss=0.000700496 | Test Loss=0.029037803 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [495/1000] | Train Loss=0.000665387 | Test Loss=0.028623469 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [496/1000] | Train Loss=0.000656802 | Test Loss=0.029354555 | Time=1.83s | LR=1.95e-07\n",
      "Epoch [497/1000] | Train Loss=0.000638288 | Test Loss=0.029113932 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [498/1000] | Train Loss=0.000660424 | Test Loss=0.028738711 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [499/1000] | Train Loss=0.000653879 | Test Loss=0.028793394 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [500/1000] | Train Loss=0.000683295 | Test Loss=0.029614133 | Time=1.82s | LR=1.95e-07\n",
      "Epoch [501/1000] | Train Loss=0.000642970 | Test Loss=0.028729188 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [502/1000] | Train Loss=0.000661067 | Test Loss=0.028754600 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [503/1000] | Train Loss=0.000669305 | Test Loss=0.028696778 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [504/1000] | Train Loss=0.000671901 | Test Loss=0.028870878 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [505/1000] | Train Loss=0.000652974 | Test Loss=0.028986808 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [506/1000] | Train Loss=0.000673751 | Test Loss=0.029163119 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [507/1000] | Train Loss=0.000758783 | Test Loss=0.029006822 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [508/1000] | Train Loss=0.000659413 | Test Loss=0.029073390 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [509/1000] | Train Loss=0.000683150 | Test Loss=0.028876858 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [510/1000] | Train Loss=0.000651015 | Test Loss=0.028897708 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [511/1000] | Train Loss=0.000664527 | Test Loss=0.028601520 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [512/1000] | Train Loss=0.000660658 | Test Loss=0.028988369 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [513/1000] | Train Loss=0.000653272 | Test Loss=0.029567527 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [514/1000] | Train Loss=0.000672498 | Test Loss=0.028658985 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [515/1000] | Train Loss=0.000637225 | Test Loss=0.028834974 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [516/1000] | Train Loss=0.000727944 | Test Loss=0.028630820 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [517/1000] | Train Loss=0.000636139 | Test Loss=0.029094222 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [518/1000] | Train Loss=0.000639493 | Test Loss=0.028751676 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [519/1000] | Train Loss=0.000634094 | Test Loss=0.028879530 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [520/1000] | Train Loss=0.000656026 | Test Loss=0.028975162 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [521/1000] | Train Loss=0.000679392 | Test Loss=0.028547442 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [522/1000] | Train Loss=0.000676979 | Test Loss=0.028640136 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [523/1000] | Train Loss=0.000666091 | Test Loss=0.029128594 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [524/1000] | Train Loss=0.000628236 | Test Loss=0.028682061 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [525/1000] | Train Loss=0.000658121 | Test Loss=0.028458835 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [526/1000] | Train Loss=0.000668748 | Test Loss=0.029038610 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [527/1000] | Train Loss=0.000645681 | Test Loss=0.028616252 | Time=1.81s | LR=9.77e-08\n",
      "Epoch [528/1000] | Train Loss=0.000646783 | Test Loss=0.029105938 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [529/1000] | Train Loss=0.000673532 | Test Loss=0.028648409 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [530/1000] | Train Loss=0.000700420 | Test Loss=0.028625850 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [531/1000] | Train Loss=0.000655632 | Test Loss=0.029041561 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [532/1000] | Train Loss=0.000654544 | Test Loss=0.028766648 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [533/1000] | Train Loss=0.000620523 | Test Loss=0.028907638 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [534/1000] | Train Loss=0.000669192 | Test Loss=0.029322024 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [535/1000] | Train Loss=0.000645557 | Test Loss=0.028845334 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [536/1000] | Train Loss=0.000636830 | Test Loss=0.028808553 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [537/1000] | Train Loss=0.000702283 | Test Loss=0.029662417 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [538/1000] | Train Loss=0.000643462 | Test Loss=0.028431942 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [539/1000] | Train Loss=0.000714837 | Test Loss=0.029085672 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [540/1000] | Train Loss=0.000721788 | Test Loss=0.028510753 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [541/1000] | Train Loss=0.000669704 | Test Loss=0.028928924 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [542/1000] | Train Loss=0.000677649 | Test Loss=0.028362477 | Time=1.82s | LR=9.77e-08\n",
      "Epoch [543/1000] | Train Loss=0.000656628 | Test Loss=0.029258528 | Time=1.83s | LR=9.77e-08\n",
      "Epoch [544/1000] | Train Loss=0.000718129 | Test Loss=0.028653504 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [545/1000] | Train Loss=0.000637822 | Test Loss=0.028797335 | Time=1.68s | LR=9.77e-08\n",
      "Epoch [546/1000] | Train Loss=0.000609648 | Test Loss=0.029352632 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [547/1000] | Train Loss=0.000627676 | Test Loss=0.029053776 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [548/1000] | Train Loss=0.000695012 | Test Loss=0.029031281 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [549/1000] | Train Loss=0.000682653 | Test Loss=0.028921063 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [550/1000] | Train Loss=0.000637537 | Test Loss=0.029057916 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [551/1000] | Train Loss=0.000642178 | Test Loss=0.028897635 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [552/1000] | Train Loss=0.000669675 | Test Loss=0.029080485 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [553/1000] | Train Loss=0.000643321 | Test Loss=0.029116164 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [554/1000] | Train Loss=0.000718586 | Test Loss=0.029229065 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [555/1000] | Train Loss=0.000645453 | Test Loss=0.029212150 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [556/1000] | Train Loss=0.000657724 | Test Loss=0.028478889 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [557/1000] | Train Loss=0.000640022 | Test Loss=0.028601304 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [558/1000] | Train Loss=0.000649819 | Test Loss=0.029268360 | Time=1.63s | LR=9.77e-08\n",
      "Epoch [559/1000] | Train Loss=0.000683627 | Test Loss=0.029546614 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [560/1000] | Train Loss=0.000665288 | Test Loss=0.028530103 | Time=1.78s | LR=9.77e-08\n",
      "Epoch [561/1000] | Train Loss=0.000721374 | Test Loss=0.028806385 | Time=1.77s | LR=9.77e-08\n",
      "Epoch [562/1000] | Train Loss=0.000635932 | Test Loss=0.028545858 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [563/1000] | Train Loss=0.000650165 | Test Loss=0.028956908 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [564/1000] | Train Loss=0.000625052 | Test Loss=0.028839675 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [565/1000] | Train Loss=0.000638844 | Test Loss=0.028974017 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [566/1000] | Train Loss=0.000640131 | Test Loss=0.028858842 | Time=1.00s | LR=9.77e-08\n",
      "Epoch [567/1000] | Train Loss=0.000645127 | Test Loss=0.028881634 | Time=1.00s | LR=9.77e-08\n",
      "Epoch [568/1000] | Train Loss=0.000668867 | Test Loss=0.028781233 | Time=1.65s | LR=9.77e-08\n",
      "Epoch [569/1000] | Train Loss=0.000659887 | Test Loss=0.029101333 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [570/1000] | Train Loss=0.000658285 | Test Loss=0.028898096 | Time=1.00s | LR=9.77e-08\n",
      "Epoch [571/1000] | Train Loss=0.000658057 | Test Loss=0.028676635 | Time=1.00s | LR=9.77e-08\n",
      "Epoch [572/1000] | Train Loss=0.000647417 | Test Loss=0.028758819 | Time=1.68s | LR=9.77e-08\n",
      "Epoch [573/1000] | Train Loss=0.000635483 | Test Loss=0.029155634 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [574/1000] | Train Loss=0.000646892 | Test Loss=0.029060801 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [575/1000] | Train Loss=0.000695836 | Test Loss=0.028857158 | Time=1.55s | LR=9.77e-08\n",
      "Epoch [576/1000] | Train Loss=0.000668097 | Test Loss=0.029183089 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [577/1000] | Train Loss=0.000643359 | Test Loss=0.029142174 | Time=1.76s | LR=4.88e-08\n",
      "Epoch [578/1000] | Train Loss=0.000659851 | Test Loss=0.028796622 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [579/1000] | Train Loss=0.000644134 | Test Loss=0.029335345 | Time=1.34s | LR=4.88e-08\n",
      "Epoch [580/1000] | Train Loss=0.000653252 | Test Loss=0.028813769 | Time=1.00s | LR=4.88e-08\n",
      "Epoch [581/1000] | Train Loss=0.000647761 | Test Loss=0.029007742 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [582/1000] | Train Loss=0.000662952 | Test Loss=0.028588370 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [583/1000] | Train Loss=0.000665338 | Test Loss=0.028667753 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [584/1000] | Train Loss=0.000667813 | Test Loss=0.028823895 | Time=1.00s | LR=4.88e-08\n",
      "Epoch [585/1000] | Train Loss=0.000660418 | Test Loss=0.029716462 | Time=1.58s | LR=4.88e-08\n",
      "Epoch [586/1000] | Train Loss=0.000649560 | Test Loss=0.028896189 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [587/1000] | Train Loss=0.000638001 | Test Loss=0.028685207 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [588/1000] | Train Loss=0.000729589 | Test Loss=0.029388347 | Time=1.78s | LR=4.88e-08\n",
      "Epoch [589/1000] | Train Loss=0.000641117 | Test Loss=0.028903811 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [590/1000] | Train Loss=0.000649404 | Test Loss=0.028471707 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [591/1000] | Train Loss=0.000728359 | Test Loss=0.029400959 | Time=1.75s | LR=4.88e-08\n",
      "Epoch [592/1000] | Train Loss=0.000635346 | Test Loss=0.028596353 | Time=1.74s | LR=4.88e-08\n",
      "Epoch [593/1000] | Train Loss=0.000654331 | Test Loss=0.028625371 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [594/1000] | Train Loss=0.000727844 | Test Loss=0.029099327 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [595/1000] | Train Loss=0.000649016 | Test Loss=0.029621944 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [596/1000] | Train Loss=0.000644695 | Test Loss=0.028583083 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [597/1000] | Train Loss=0.000653516 | Test Loss=0.029198383 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [598/1000] | Train Loss=0.000624118 | Test Loss=0.028860444 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [599/1000] | Train Loss=0.000639337 | Test Loss=0.028996315 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [600/1000] | Train Loss=0.000650268 | Test Loss=0.028851717 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [601/1000] | Train Loss=0.000632866 | Test Loss=0.028640059 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [602/1000] | Train Loss=0.000647700 | Test Loss=0.028688899 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [603/1000] | Train Loss=0.000692651 | Test Loss=0.029027676 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [604/1000] | Train Loss=0.000662198 | Test Loss=0.028682183 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [605/1000] | Train Loss=0.000667283 | Test Loss=0.028451278 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [606/1000] | Train Loss=0.000648717 | Test Loss=0.028395494 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [607/1000] | Train Loss=0.000647586 | Test Loss=0.028679874 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [608/1000] | Train Loss=0.000713443 | Test Loss=0.028942084 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [609/1000] | Train Loss=0.000629835 | Test Loss=0.029281424 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [610/1000] | Train Loss=0.000654542 | Test Loss=0.028570169 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [611/1000] | Train Loss=0.000660022 | Test Loss=0.028949436 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [612/1000] | Train Loss=0.000653668 | Test Loss=0.029008402 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [613/1000] | Train Loss=0.000665475 | Test Loss=0.028538809 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [614/1000] | Train Loss=0.000647013 | Test Loss=0.028895476 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [615/1000] | Train Loss=0.000696936 | Test Loss=0.029045662 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [616/1000] | Train Loss=0.000717464 | Test Loss=0.028705787 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [617/1000] | Train Loss=0.000698105 | Test Loss=0.029075052 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [618/1000] | Train Loss=0.000656371 | Test Loss=0.029009143 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [619/1000] | Train Loss=0.000718490 | Test Loss=0.028642269 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [620/1000] | Train Loss=0.000662008 | Test Loss=0.029625149 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [621/1000] | Train Loss=0.000661295 | Test Loss=0.029409303 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [622/1000] | Train Loss=0.000657688 | Test Loss=0.028942992 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [623/1000] | Train Loss=0.000642735 | Test Loss=0.028713249 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [624/1000] | Train Loss=0.000642600 | Test Loss=0.028486142 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [625/1000] | Train Loss=0.000648921 | Test Loss=0.029130073 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [626/1000] | Train Loss=0.000692799 | Test Loss=0.028872628 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [627/1000] | Train Loss=0.000646315 | Test Loss=0.028729981 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [628/1000] | Train Loss=0.000648134 | Test Loss=0.028859718 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [629/1000] | Train Loss=0.000637220 | Test Loss=0.028636774 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [630/1000] | Train Loss=0.000660290 | Test Loss=0.029250109 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [631/1000] | Train Loss=0.000662140 | Test Loss=0.029328230 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [632/1000] | Train Loss=0.000623725 | Test Loss=0.028935542 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [633/1000] | Train Loss=0.000659171 | Test Loss=0.028936282 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [634/1000] | Train Loss=0.000670294 | Test Loss=0.028904969 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [635/1000] | Train Loss=0.000679363 | Test Loss=0.028968342 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [636/1000] | Train Loss=0.000668480 | Test Loss=0.028625659 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [637/1000] | Train Loss=0.000643465 | Test Loss=0.028889204 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [638/1000] | Train Loss=0.000642317 | Test Loss=0.028571811 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [639/1000] | Train Loss=0.000651727 | Test Loss=0.028962112 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [640/1000] | Train Loss=0.000642350 | Test Loss=0.029134390 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [641/1000] | Train Loss=0.000660072 | Test Loss=0.028635948 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [642/1000] | Train Loss=0.000642832 | Test Loss=0.029000998 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [643/1000] | Train Loss=0.000632632 | Test Loss=0.028848850 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [644/1000] | Train Loss=0.000649396 | Test Loss=0.028991815 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [645/1000] | Train Loss=0.000802306 | Test Loss=0.028639576 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [646/1000] | Train Loss=0.000735187 | Test Loss=0.029443198 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [647/1000] | Train Loss=0.000648924 | Test Loss=0.029480282 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [648/1000] | Train Loss=0.000727847 | Test Loss=0.028831104 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [649/1000] | Train Loss=0.000628761 | Test Loss=0.028626333 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [650/1000] | Train Loss=0.000665069 | Test Loss=0.028944671 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [651/1000] | Train Loss=0.000665107 | Test Loss=0.029118436 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [652/1000] | Train Loss=0.000652535 | Test Loss=0.028953236 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [653/1000] | Train Loss=0.000656567 | Test Loss=0.028883185 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [654/1000] | Train Loss=0.000685255 | Test Loss=0.029120759 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [655/1000] | Train Loss=0.000618479 | Test Loss=0.028700144 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [656/1000] | Train Loss=0.000641497 | Test Loss=0.029119118 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [657/1000] | Train Loss=0.000660187 | Test Loss=0.029404615 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [658/1000] | Train Loss=0.000653628 | Test Loss=0.028637841 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [659/1000] | Train Loss=0.000652190 | Test Loss=0.028835443 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [660/1000] | Train Loss=0.000650650 | Test Loss=0.028909219 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [661/1000] | Train Loss=0.000669498 | Test Loss=0.029202416 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [662/1000] | Train Loss=0.000653670 | Test Loss=0.029390023 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [663/1000] | Train Loss=0.000656530 | Test Loss=0.029247248 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [664/1000] | Train Loss=0.000648565 | Test Loss=0.029483916 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [665/1000] | Train Loss=0.000686769 | Test Loss=0.028990540 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [666/1000] | Train Loss=0.000653376 | Test Loss=0.029458275 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [667/1000] | Train Loss=0.000661330 | Test Loss=0.028345414 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [668/1000] | Train Loss=0.000675548 | Test Loss=0.028777846 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [669/1000] | Train Loss=0.000652281 | Test Loss=0.028558757 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [670/1000] | Train Loss=0.000659781 | Test Loss=0.029055734 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [671/1000] | Train Loss=0.000689858 | Test Loss=0.028686019 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [672/1000] | Train Loss=0.000684690 | Test Loss=0.028619069 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [673/1000] | Train Loss=0.000648308 | Test Loss=0.028724318 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [674/1000] | Train Loss=0.000661525 | Test Loss=0.028724892 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [675/1000] | Train Loss=0.000663290 | Test Loss=0.028797841 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [676/1000] | Train Loss=0.000731267 | Test Loss=0.029234440 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [677/1000] | Train Loss=0.000730960 | Test Loss=0.029255724 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [678/1000] | Train Loss=0.000630945 | Test Loss=0.028736191 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [679/1000] | Train Loss=0.000638463 | Test Loss=0.029058011 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [680/1000] | Train Loss=0.000671923 | Test Loss=0.029241930 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [681/1000] | Train Loss=0.000653382 | Test Loss=0.029176614 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [682/1000] | Train Loss=0.000649466 | Test Loss=0.028984179 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [683/1000] | Train Loss=0.000635316 | Test Loss=0.029436506 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [684/1000] | Train Loss=0.000660793 | Test Loss=0.029351150 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [685/1000] | Train Loss=0.000630374 | Test Loss=0.028708178 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [686/1000] | Train Loss=0.000694524 | Test Loss=0.029093177 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [687/1000] | Train Loss=0.000641013 | Test Loss=0.028731271 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [688/1000] | Train Loss=0.000669220 | Test Loss=0.028437424 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [689/1000] | Train Loss=0.000671842 | Test Loss=0.029224516 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [690/1000] | Train Loss=0.000660853 | Test Loss=0.028576301 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [691/1000] | Train Loss=0.000682285 | Test Loss=0.028710090 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [692/1000] | Train Loss=0.000624608 | Test Loss=0.029225785 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [693/1000] | Train Loss=0.000724863 | Test Loss=0.028915919 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [694/1000] | Train Loss=0.000651128 | Test Loss=0.028644942 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [695/1000] | Train Loss=0.000632926 | Test Loss=0.028786598 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [696/1000] | Train Loss=0.000653368 | Test Loss=0.028983891 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [697/1000] | Train Loss=0.000652761 | Test Loss=0.029178809 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [698/1000] | Train Loss=0.000667367 | Test Loss=0.029107383 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [699/1000] | Train Loss=0.000687351 | Test Loss=0.029347567 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [700/1000] | Train Loss=0.000719321 | Test Loss=0.029137824 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [701/1000] | Train Loss=0.000638161 | Test Loss=0.028974797 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [702/1000] | Train Loss=0.000640861 | Test Loss=0.028613852 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [703/1000] | Train Loss=0.000716858 | Test Loss=0.028433982 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [704/1000] | Train Loss=0.000646054 | Test Loss=0.029184105 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [705/1000] | Train Loss=0.000655460 | Test Loss=0.028543084 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [706/1000] | Train Loss=0.000642404 | Test Loss=0.028688650 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [707/1000] | Train Loss=0.000647794 | Test Loss=0.029250541 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [708/1000] | Train Loss=0.000685549 | Test Loss=0.028808775 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [709/1000] | Train Loss=0.000667405 | Test Loss=0.028715621 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [710/1000] | Train Loss=0.000670094 | Test Loss=0.028692344 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [711/1000] | Train Loss=0.000656722 | Test Loss=0.029083349 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [712/1000] | Train Loss=0.000650347 | Test Loss=0.028881233 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [713/1000] | Train Loss=0.000675900 | Test Loss=0.029017828 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [714/1000] | Train Loss=0.000662678 | Test Loss=0.028666932 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [715/1000] | Train Loss=0.000648173 | Test Loss=0.029117909 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [716/1000] | Train Loss=0.000653399 | Test Loss=0.028923835 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [717/1000] | Train Loss=0.000648557 | Test Loss=0.028644819 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [718/1000] | Train Loss=0.000654178 | Test Loss=0.029264742 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [719/1000] | Train Loss=0.000649148 | Test Loss=0.029228220 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [720/1000] | Train Loss=0.000669411 | Test Loss=0.028660585 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [721/1000] | Train Loss=0.000652891 | Test Loss=0.028656390 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [722/1000] | Train Loss=0.000667343 | Test Loss=0.028956824 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [723/1000] | Train Loss=0.000649985 | Test Loss=0.028779083 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [724/1000] | Train Loss=0.000686007 | Test Loss=0.028119052 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [725/1000] | Train Loss=0.000689510 | Test Loss=0.028849841 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [726/1000] | Train Loss=0.000761953 | Test Loss=0.028852934 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [727/1000] | Train Loss=0.000645354 | Test Loss=0.028546597 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [728/1000] | Train Loss=0.000639830 | Test Loss=0.029155241 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [729/1000] | Train Loss=0.000650847 | Test Loss=0.028691665 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [730/1000] | Train Loss=0.000675470 | Test Loss=0.028969295 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [731/1000] | Train Loss=0.000663167 | Test Loss=0.029251354 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [732/1000] | Train Loss=0.000644198 | Test Loss=0.029012668 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [733/1000] | Train Loss=0.000662312 | Test Loss=0.028852574 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [734/1000] | Train Loss=0.000668500 | Test Loss=0.029223518 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [735/1000] | Train Loss=0.000648981 | Test Loss=0.028617469 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [736/1000] | Train Loss=0.000667933 | Test Loss=0.029125223 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [737/1000] | Train Loss=0.000650942 | Test Loss=0.028892184 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [738/1000] | Train Loss=0.000624681 | Test Loss=0.029132643 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [739/1000] | Train Loss=0.000675415 | Test Loss=0.028634067 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [740/1000] | Train Loss=0.000706419 | Test Loss=0.029311358 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [741/1000] | Train Loss=0.000662667 | Test Loss=0.029404448 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [742/1000] | Train Loss=0.000632610 | Test Loss=0.029027153 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [743/1000] | Train Loss=0.000649351 | Test Loss=0.028683943 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [744/1000] | Train Loss=0.000657820 | Test Loss=0.028697675 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [745/1000] | Train Loss=0.000661215 | Test Loss=0.028498446 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [746/1000] | Train Loss=0.000642814 | Test Loss=0.029189378 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [747/1000] | Train Loss=0.000669013 | Test Loss=0.028842409 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [748/1000] | Train Loss=0.000634715 | Test Loss=0.029133191 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [749/1000] | Train Loss=0.000654726 | Test Loss=0.028857588 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [750/1000] | Train Loss=0.000732642 | Test Loss=0.028767382 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [751/1000] | Train Loss=0.000680463 | Test Loss=0.028755901 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [752/1000] | Train Loss=0.000684867 | Test Loss=0.028426510 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [753/1000] | Train Loss=0.000630264 | Test Loss=0.028640795 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [754/1000] | Train Loss=0.000667447 | Test Loss=0.028591489 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [755/1000] | Train Loss=0.000651208 | Test Loss=0.029055288 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [756/1000] | Train Loss=0.000644453 | Test Loss=0.028725561 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [757/1000] | Train Loss=0.000718390 | Test Loss=0.029158345 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [758/1000] | Train Loss=0.000631329 | Test Loss=0.028827677 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [759/1000] | Train Loss=0.000642177 | Test Loss=0.029050565 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [760/1000] | Train Loss=0.000656996 | Test Loss=0.028506722 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [761/1000] | Train Loss=0.000637948 | Test Loss=0.029635489 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [762/1000] | Train Loss=0.000633232 | Test Loss=0.028915748 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [763/1000] | Train Loss=0.000665906 | Test Loss=0.028604350 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [764/1000] | Train Loss=0.000643085 | Test Loss=0.029829377 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [765/1000] | Train Loss=0.000652311 | Test Loss=0.028531627 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [766/1000] | Train Loss=0.000655055 | Test Loss=0.029124070 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [767/1000] | Train Loss=0.000718260 | Test Loss=0.029402689 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [768/1000] | Train Loss=0.000652421 | Test Loss=0.028662806 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [769/1000] | Train Loss=0.000637581 | Test Loss=0.028919434 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [770/1000] | Train Loss=0.000655835 | Test Loss=0.028797343 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [771/1000] | Train Loss=0.000642916 | Test Loss=0.029599672 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [772/1000] | Train Loss=0.000722765 | Test Loss=0.028771181 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [773/1000] | Train Loss=0.000674768 | Test Loss=0.029059984 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [774/1000] | Train Loss=0.000683721 | Test Loss=0.029368260 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [775/1000] | Train Loss=0.000650476 | Test Loss=0.028921986 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [776/1000] | Train Loss=0.000697631 | Test Loss=0.028853911 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [777/1000] | Train Loss=0.000658848 | Test Loss=0.029106909 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [778/1000] | Train Loss=0.000644392 | Test Loss=0.029042032 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [779/1000] | Train Loss=0.000674283 | Test Loss=0.029085805 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [780/1000] | Train Loss=0.000676457 | Test Loss=0.028778983 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [781/1000] | Train Loss=0.000667181 | Test Loss=0.029690806 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [782/1000] | Train Loss=0.000638171 | Test Loss=0.028829145 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [783/1000] | Train Loss=0.000622009 | Test Loss=0.028347165 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [784/1000] | Train Loss=0.000674701 | Test Loss=0.029015756 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [785/1000] | Train Loss=0.000681064 | Test Loss=0.029207794 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [786/1000] | Train Loss=0.000641177 | Test Loss=0.028850549 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [787/1000] | Train Loss=0.000646866 | Test Loss=0.028737731 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [788/1000] | Train Loss=0.000638394 | Test Loss=0.029055085 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [789/1000] | Train Loss=0.000646991 | Test Loss=0.028872855 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [790/1000] | Train Loss=0.000638738 | Test Loss=0.029209339 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [791/1000] | Train Loss=0.000666670 | Test Loss=0.029239891 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [792/1000] | Train Loss=0.000720440 | Test Loss=0.029247775 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [793/1000] | Train Loss=0.000742914 | Test Loss=0.028924832 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [794/1000] | Train Loss=0.000666784 | Test Loss=0.028902009 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [795/1000] | Train Loss=0.000654863 | Test Loss=0.028943491 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [796/1000] | Train Loss=0.000651554 | Test Loss=0.029091147 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [797/1000] | Train Loss=0.000651361 | Test Loss=0.028703357 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [798/1000] | Train Loss=0.000662561 | Test Loss=0.028726616 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [799/1000] | Train Loss=0.000679651 | Test Loss=0.029067847 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [800/1000] | Train Loss=0.000645870 | Test Loss=0.029336124 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [801/1000] | Train Loss=0.000633346 | Test Loss=0.028936823 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [802/1000] | Train Loss=0.000732293 | Test Loss=0.028771224 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [803/1000] | Train Loss=0.000694955 | Test Loss=0.029530050 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [804/1000] | Train Loss=0.000667297 | Test Loss=0.028721073 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [805/1000] | Train Loss=0.000657191 | Test Loss=0.029413273 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [806/1000] | Train Loss=0.000680444 | Test Loss=0.028916333 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [807/1000] | Train Loss=0.000652122 | Test Loss=0.029257380 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [808/1000] | Train Loss=0.000662450 | Test Loss=0.028681212 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [809/1000] | Train Loss=0.000650044 | Test Loss=0.029113243 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [810/1000] | Train Loss=0.000654679 | Test Loss=0.028623353 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [811/1000] | Train Loss=0.000648538 | Test Loss=0.028629039 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [812/1000] | Train Loss=0.000658797 | Test Loss=0.028612201 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [813/1000] | Train Loss=0.000649638 | Test Loss=0.029028434 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [814/1000] | Train Loss=0.000648726 | Test Loss=0.028921271 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [815/1000] | Train Loss=0.000646357 | Test Loss=0.029270090 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [816/1000] | Train Loss=0.000703229 | Test Loss=0.028813481 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [817/1000] | Train Loss=0.000669261 | Test Loss=0.028572463 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [818/1000] | Train Loss=0.000662291 | Test Loss=0.029033277 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [819/1000] | Train Loss=0.000696813 | Test Loss=0.028800897 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [820/1000] | Train Loss=0.000640893 | Test Loss=0.029227864 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [821/1000] | Train Loss=0.000693679 | Test Loss=0.028907173 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [822/1000] | Train Loss=0.000644532 | Test Loss=0.028818372 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [823/1000] | Train Loss=0.000644915 | Test Loss=0.028795190 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [824/1000] | Train Loss=0.000652633 | Test Loss=0.028662183 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [825/1000] | Train Loss=0.000660164 | Test Loss=0.029016865 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [826/1000] | Train Loss=0.000662590 | Test Loss=0.028575029 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [827/1000] | Train Loss=0.000648026 | Test Loss=0.028638727 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [828/1000] | Train Loss=0.000665574 | Test Loss=0.029322059 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [829/1000] | Train Loss=0.000638461 | Test Loss=0.028996183 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [830/1000] | Train Loss=0.000655178 | Test Loss=0.028910433 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [831/1000] | Train Loss=0.000657787 | Test Loss=0.028689057 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [832/1000] | Train Loss=0.000646862 | Test Loss=0.028545041 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [833/1000] | Train Loss=0.000663769 | Test Loss=0.028421172 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [834/1000] | Train Loss=0.000664607 | Test Loss=0.028942250 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [835/1000] | Train Loss=0.000668617 | Test Loss=0.028847357 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [836/1000] | Train Loss=0.000646571 | Test Loss=0.028900927 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [837/1000] | Train Loss=0.000660367 | Test Loss=0.029332075 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [838/1000] | Train Loss=0.000719936 | Test Loss=0.028633212 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [839/1000] | Train Loss=0.000656078 | Test Loss=0.028930672 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [840/1000] | Train Loss=0.000688914 | Test Loss=0.028880363 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [841/1000] | Train Loss=0.000677975 | Test Loss=0.029237143 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [842/1000] | Train Loss=0.000676296 | Test Loss=0.028843332 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [843/1000] | Train Loss=0.000787770 | Test Loss=0.028956837 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [844/1000] | Train Loss=0.000669428 | Test Loss=0.028876116 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [845/1000] | Train Loss=0.000661278 | Test Loss=0.029176414 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [846/1000] | Train Loss=0.000697067 | Test Loss=0.028990967 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [847/1000] | Train Loss=0.000668455 | Test Loss=0.029037406 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [848/1000] | Train Loss=0.000635264 | Test Loss=0.028943089 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [849/1000] | Train Loss=0.000643452 | Test Loss=0.028731716 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [850/1000] | Train Loss=0.000658693 | Test Loss=0.029898719 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [851/1000] | Train Loss=0.000657928 | Test Loss=0.029327567 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [852/1000] | Train Loss=0.000664617 | Test Loss=0.028617471 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [853/1000] | Train Loss=0.000638157 | Test Loss=0.028646712 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [854/1000] | Train Loss=0.000669305 | Test Loss=0.028452090 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [855/1000] | Train Loss=0.000685617 | Test Loss=0.029153741 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [856/1000] | Train Loss=0.000666347 | Test Loss=0.028622963 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [857/1000] | Train Loss=0.000654594 | Test Loss=0.029238082 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [858/1000] | Train Loss=0.000640793 | Test Loss=0.028607053 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [859/1000] | Train Loss=0.000641657 | Test Loss=0.028816431 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [860/1000] | Train Loss=0.000742507 | Test Loss=0.029161700 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [861/1000] | Train Loss=0.000728083 | Test Loss=0.029080065 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [862/1000] | Train Loss=0.000654838 | Test Loss=0.028993050 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [863/1000] | Train Loss=0.000654308 | Test Loss=0.028807662 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [864/1000] | Train Loss=0.000679518 | Test Loss=0.029175568 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [865/1000] | Train Loss=0.000654557 | Test Loss=0.028880367 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [866/1000] | Train Loss=0.000650210 | Test Loss=0.029058783 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [867/1000] | Train Loss=0.000653247 | Test Loss=0.029273871 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [868/1000] | Train Loss=0.000650262 | Test Loss=0.029168562 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [869/1000] | Train Loss=0.000658727 | Test Loss=0.028553462 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [870/1000] | Train Loss=0.000652932 | Test Loss=0.028722795 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [871/1000] | Train Loss=0.000693793 | Test Loss=0.028355408 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [872/1000] | Train Loss=0.000646571 | Test Loss=0.028844891 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [873/1000] | Train Loss=0.000687071 | Test Loss=0.028718647 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [874/1000] | Train Loss=0.000673339 | Test Loss=0.029080714 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [875/1000] | Train Loss=0.000629775 | Test Loss=0.028639532 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [876/1000] | Train Loss=0.000628384 | Test Loss=0.028748226 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [877/1000] | Train Loss=0.000713228 | Test Loss=0.028775959 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [878/1000] | Train Loss=0.000644753 | Test Loss=0.028849720 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [879/1000] | Train Loss=0.000669976 | Test Loss=0.028993077 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [880/1000] | Train Loss=0.000645633 | Test Loss=0.028646127 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [881/1000] | Train Loss=0.000648884 | Test Loss=0.028978876 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [882/1000] | Train Loss=0.000652671 | Test Loss=0.028915464 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [883/1000] | Train Loss=0.000675133 | Test Loss=0.029133474 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [884/1000] | Train Loss=0.000695604 | Test Loss=0.028888216 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [885/1000] | Train Loss=0.000651052 | Test Loss=0.029114494 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [886/1000] | Train Loss=0.000676254 | Test Loss=0.029469228 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [887/1000] | Train Loss=0.000721788 | Test Loss=0.028454610 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [888/1000] | Train Loss=0.000713721 | Test Loss=0.028837690 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [889/1000] | Train Loss=0.000754707 | Test Loss=0.029408756 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [890/1000] | Train Loss=0.000659145 | Test Loss=0.029579545 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [891/1000] | Train Loss=0.000658919 | Test Loss=0.028632789 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [892/1000] | Train Loss=0.000697927 | Test Loss=0.028848003 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [893/1000] | Train Loss=0.000653371 | Test Loss=0.029016811 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [894/1000] | Train Loss=0.000705321 | Test Loss=0.028904301 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [895/1000] | Train Loss=0.000702641 | Test Loss=0.029459646 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [896/1000] | Train Loss=0.000689367 | Test Loss=0.028700011 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [897/1000] | Train Loss=0.000655481 | Test Loss=0.029144188 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [898/1000] | Train Loss=0.000668039 | Test Loss=0.029697360 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [899/1000] | Train Loss=0.000678138 | Test Loss=0.028913464 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [900/1000] | Train Loss=0.000641714 | Test Loss=0.028779290 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [901/1000] | Train Loss=0.000636185 | Test Loss=0.028694921 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [902/1000] | Train Loss=0.000764281 | Test Loss=0.028578982 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [903/1000] | Train Loss=0.000694361 | Test Loss=0.029232624 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [904/1000] | Train Loss=0.000666764 | Test Loss=0.028462371 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [905/1000] | Train Loss=0.000651825 | Test Loss=0.028830332 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [906/1000] | Train Loss=0.000646917 | Test Loss=0.028833371 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [907/1000] | Train Loss=0.000706580 | Test Loss=0.029179581 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [908/1000] | Train Loss=0.000635585 | Test Loss=0.028918202 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [909/1000] | Train Loss=0.000672424 | Test Loss=0.028716453 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [910/1000] | Train Loss=0.000665731 | Test Loss=0.029062663 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [911/1000] | Train Loss=0.000675637 | Test Loss=0.029261500 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [912/1000] | Train Loss=0.000645990 | Test Loss=0.028967201 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [913/1000] | Train Loss=0.000642047 | Test Loss=0.028993593 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [914/1000] | Train Loss=0.000653748 | Test Loss=0.029288812 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [915/1000] | Train Loss=0.000663663 | Test Loss=0.028569506 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [916/1000] | Train Loss=0.000633395 | Test Loss=0.029121105 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [917/1000] | Train Loss=0.000693271 | Test Loss=0.028997974 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [918/1000] | Train Loss=0.000761759 | Test Loss=0.029523711 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [919/1000] | Train Loss=0.000678245 | Test Loss=0.029030552 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [920/1000] | Train Loss=0.000674068 | Test Loss=0.028813029 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [921/1000] | Train Loss=0.000646502 | Test Loss=0.029029724 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [922/1000] | Train Loss=0.000628048 | Test Loss=0.028637917 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [923/1000] | Train Loss=0.000643379 | Test Loss=0.029038053 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [924/1000] | Train Loss=0.000651113 | Test Loss=0.029266255 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [925/1000] | Train Loss=0.000637163 | Test Loss=0.028702886 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [926/1000] | Train Loss=0.000645679 | Test Loss=0.028939120 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [927/1000] | Train Loss=0.000672671 | Test Loss=0.029949234 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [928/1000] | Train Loss=0.000655425 | Test Loss=0.028503567 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [929/1000] | Train Loss=0.000657853 | Test Loss=0.028868114 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [930/1000] | Train Loss=0.000644678 | Test Loss=0.029302906 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [931/1000] | Train Loss=0.000646042 | Test Loss=0.028537977 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [932/1000] | Train Loss=0.000644526 | Test Loss=0.028789035 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [933/1000] | Train Loss=0.000672729 | Test Loss=0.028572820 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [934/1000] | Train Loss=0.000672392 | Test Loss=0.028701158 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [935/1000] | Train Loss=0.000699771 | Test Loss=0.028595199 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [936/1000] | Train Loss=0.000664813 | Test Loss=0.029085757 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [937/1000] | Train Loss=0.000646193 | Test Loss=0.029250223 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [938/1000] | Train Loss=0.000675897 | Test Loss=0.029415343 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [939/1000] | Train Loss=0.000655119 | Test Loss=0.028534952 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [940/1000] | Train Loss=0.000734455 | Test Loss=0.029024957 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [941/1000] | Train Loss=0.000665329 | Test Loss=0.029224570 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [942/1000] | Train Loss=0.000680677 | Test Loss=0.028417458 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [943/1000] | Train Loss=0.000632647 | Test Loss=0.028915995 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [944/1000] | Train Loss=0.000650275 | Test Loss=0.029257901 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [945/1000] | Train Loss=0.000637756 | Test Loss=0.028681415 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [946/1000] | Train Loss=0.000685691 | Test Loss=0.029291788 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [947/1000] | Train Loss=0.000686585 | Test Loss=0.028300757 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [948/1000] | Train Loss=0.000636749 | Test Loss=0.028937552 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [949/1000] | Train Loss=0.000668014 | Test Loss=0.028719999 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [950/1000] | Train Loss=0.000635248 | Test Loss=0.029074553 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [951/1000] | Train Loss=0.000661700 | Test Loss=0.028979993 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [952/1000] | Train Loss=0.000645518 | Test Loss=0.028738877 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [953/1000] | Train Loss=0.000641495 | Test Loss=0.028675930 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [954/1000] | Train Loss=0.000672352 | Test Loss=0.029071336 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [955/1000] | Train Loss=0.000658753 | Test Loss=0.028684260 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [956/1000] | Train Loss=0.000679355 | Test Loss=0.028965261 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [957/1000] | Train Loss=0.000658207 | Test Loss=0.029428011 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [958/1000] | Train Loss=0.000642135 | Test Loss=0.029504630 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [959/1000] | Train Loss=0.000696594 | Test Loss=0.028630662 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [960/1000] | Train Loss=0.000630305 | Test Loss=0.028885543 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [961/1000] | Train Loss=0.000672092 | Test Loss=0.028879155 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [962/1000] | Train Loss=0.000690556 | Test Loss=0.028933213 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [963/1000] | Train Loss=0.000658995 | Test Loss=0.028932108 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [964/1000] | Train Loss=0.000671016 | Test Loss=0.028504765 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [965/1000] | Train Loss=0.000646950 | Test Loss=0.028302255 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [966/1000] | Train Loss=0.000665921 | Test Loss=0.028572789 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [967/1000] | Train Loss=0.000653279 | Test Loss=0.028965300 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [968/1000] | Train Loss=0.000644226 | Test Loss=0.028821392 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [969/1000] | Train Loss=0.000704545 | Test Loss=0.029640079 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [970/1000] | Train Loss=0.000706760 | Test Loss=0.029271651 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [971/1000] | Train Loss=0.000702465 | Test Loss=0.028728982 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [972/1000] | Train Loss=0.000714174 | Test Loss=0.029360070 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [973/1000] | Train Loss=0.000699946 | Test Loss=0.029214461 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [974/1000] | Train Loss=0.000722722 | Test Loss=0.028957674 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [975/1000] | Train Loss=0.000652830 | Test Loss=0.028770817 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [976/1000] | Train Loss=0.000672921 | Test Loss=0.028635034 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [977/1000] | Train Loss=0.000637521 | Test Loss=0.029084272 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [978/1000] | Train Loss=0.000644968 | Test Loss=0.028984666 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [979/1000] | Train Loss=0.000643286 | Test Loss=0.028624371 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [980/1000] | Train Loss=0.000657542 | Test Loss=0.028878340 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [981/1000] | Train Loss=0.000650811 | Test Loss=0.028662907 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [982/1000] | Train Loss=0.000648445 | Test Loss=0.028548768 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [983/1000] | Train Loss=0.000655567 | Test Loss=0.028926277 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [984/1000] | Train Loss=0.000671422 | Test Loss=0.028899365 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [985/1000] | Train Loss=0.000655748 | Test Loss=0.028939822 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [986/1000] | Train Loss=0.000651637 | Test Loss=0.028738021 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [987/1000] | Train Loss=0.000767627 | Test Loss=0.029931525 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [988/1000] | Train Loss=0.000685722 | Test Loss=0.029307457 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [989/1000] | Train Loss=0.000663851 | Test Loss=0.028935459 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [990/1000] | Train Loss=0.000676297 | Test Loss=0.028863904 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [991/1000] | Train Loss=0.000680681 | Test Loss=0.028662741 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [992/1000] | Train Loss=0.000657591 | Test Loss=0.028674705 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [993/1000] | Train Loss=0.000705383 | Test Loss=0.028277988 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [994/1000] | Train Loss=0.000636343 | Test Loss=0.028417455 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [995/1000] | Train Loss=0.000680333 | Test Loss=0.029027560 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [996/1000] | Train Loss=0.000732534 | Test Loss=0.029407505 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [997/1000] | Train Loss=0.000664372 | Test Loss=0.028622899 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [998/1000] | Train Loss=0.000627938 | Test Loss=0.028762773 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [999/1000] | Train Loss=0.000645018 | Test Loss=0.028726685 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000685874 | Test Loss=0.029050149 | Time=1.82s | LR=1.22e-08\n",
      "\n",
      "Total training time: 1802.26 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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OoMgIiIiemwZHQgplUo4ODhoXtvb26NKlSoWSRQRERFRZTC6akwQBLzwwgtwdHQEABQUFGDKlClwdXXV2W7jxo3mTSERERGRhRgdCI0fP17n9XPPPWf2xBARERFVJqMDocjISEumg4iIiKjSPfSAikRERESPOwZCREREZLMYCBEREZHNYiBERERENouBEBEREdksBkJERERksxgIERERkc1iIFSKiIgIhIaGok2bNtZOChEREVkIA6FSTJ06FXFxcYiKirJ2UoiIiMhCGAgRERGRzWIgRERERDaLgRARERHZLAZCREREZLMYCBEREZHNYiBERERENouBEBEREdksBkJERERksxgIERERkc1iIEREREQ2i4EQERER2SwGQkRERGSzGAgRERGRzWIgRERERDaLgRARERHZLAZCREREZLMYCBEREZHNYiBERERENouBEBEREdksBkJERERksxgIERERkc1iIEREREQ2i4EQERER2SwGQkRERGSzGAgRERGRzWIgRERERDaLgRARERHZLAZCREREZLMYCBEREZHNYiBERERENouBEBEREdksBkJERERksxgIERERkc1iIEREREQ2i4EQERER2SwGQkRERGSzGAgRERGRzWIgRERERDaLgRARERHZLAZCREREZLMYCBEREZHNYiBERERENouBEBEREdksBkJW8sqaaCyJlSIlq8DaSSEiIrJZDISsJDopAzdyJEjLKTLbPosUKrPti4iIyBYwELISTxcZACAjX26W/a2PSkKTeTuw72KqWfZHRERkCxgIWYmniwMAIDPPPIHQW3+eRZFShYk/R5llf0RERLaAgZCVeDqLJUL3zVQipKYSzLo7IiKiJxoDISvRVI2ZqUSIiIiITMdAyEo0JUJ5RRAEFuMQERFZAwMhK/F4EAj9fDQRk345aeXUEBER2SYGQlbiKCvO+t0XUlkqREREZAVPfCCUkZGB1q1bo0WLFmjSpAlWrlxp7SQBAGRS3ayXK4sDocsp2fhq92XkFiqM3p/UTmK2tBEREdkKe2snwNLc3Nxw4MABuLi4IDc3F02aNMGwYcNQtWpVq6bLoUQgVKhQwsFeXNbnywMAxPZD859ubNT+ZFIJlOwyRkREZJInvkRIKpXCxcUFAFBYWAhBEB6Jaih10KNWaGBU6DNJGXrLBEHAhMgTePb7o8jMl+Oln09i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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_G3.pth\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00965139\n",
      "Function type: periodic             | Relative L2: 0.00405260\n",
      "Function type: sine_beats           | Relative L2: 0.00356705\n",
      "\n",
      "Overall relative L2 error: 0.00927050\n",
      "--------------test----------------\n",
      "Function type: gaussian_hermite     | Relative L2: 0.07955373\n",
      "Function type: sinc_pulse           | Relative L2: 0.04706684\n",
      "Function type: wave_packet          | Relative L2: 0.02710439\n",
      "\n",
      "Overall relative L2 error: 0.02924690\n",
      "--------------sample----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00930281\n",
      "Function type: periodic             | Relative L2: 0.00401635\n",
      "Function type: sine_beats           | Relative L2: 0.00560201\n",
      "\n",
      "Overall relative L2 error: 0.00901850\n"
     ]
    }
   ],
   "source": [
    "torch.save(ufno.state_dict(), \"ufno1d_G3.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
}
