{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "# ---------------------------------------------------------\n",
    "# 1D MLP block used in AM-FNO\n",
    "# ---------------------------------------------------------\n",
    "class MLP1d(nn.Module):\n",
    "    def __init__(self, in_channels, out_channels, mid_channels, dropout: float = 0.0):\n",
    "        \"\"\"\n",
    "        Simple 1D MLP implemented as 1x1 convolutions:\n",
    "        input:  (B, C_in, N)\n",
    "        output: (B, C_out, N)\n",
    "        \"\"\"\n",
    "        super().__init__()\n",
    "        self.linear1 = nn.Conv1d(in_channels, mid_channels, kernel_size=1)\n",
    "        self.linear2 = nn.Conv1d(mid_channels, out_channels, kernel_size=1)\n",
    "        self.act = nn.GELU()\n",
    "        self.dropout = dropout\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.linear1(x)\n",
    "        x = self.act(x)\n",
    "        if self.dropout > 0:\n",
    "            x = F.dropout(x, p=self.dropout, training=self.training)\n",
    "        x = self.linear2(x)\n",
    "        return x\n",
    "\n",
    "\n",
    "# ---------------------------------------------------------\n",
    "# Amortized spectral convolution (1D, MLP-based)\n",
    "# ---------------------------------------------------------\n",
    "class SpectralConv1dMLP(nn.Module):\n",
    "    \"\"\"\n",
    "    Amortized Fourier layer in 1D.\n",
    "    - Learns a complex-valued kernel in Fourier space from a low-dimensional\n",
    "      frequency embedding Tx via small MLPs (mlpxr, mlpxi).\n",
    "    - input:  (B, C_in, N)\n",
    "    - output: (B, C_out, N)\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, in_channels, out_channels, n_basis: int, dropout: float = 0.0):\n",
    "        super().__init__()\n",
    "        self.in_channels = in_channels\n",
    "        self.out_channels = out_channels\n",
    "        self.n_basis = n_basis\n",
    "\n",
    "        # MLPs that map frequency features Tx -> real/imag parts of the kernel\n",
    "        # Tx will have shape (1, n_basis, N_fft_modes)\n",
    "        self.mlpxr = MLP1d(n_basis, in_channels * out_channels, 2 * n_basis, dropout=dropout)\n",
    "        self.mlpxi = MLP1d(n_basis, in_channels * out_channels, 2 * n_basis, dropout=dropout)\n",
    "\n",
    "    @staticmethod\n",
    "    def compl_mul1d(input_ft, weights):\n",
    "        \"\"\"\n",
    "        input_ft: (B, C_in, K)\n",
    "        weights:  (C_in, C_out, K)\n",
    "        returns:  (B, C_out, K)\n",
    "        \"\"\"\n",
    "        return torch.einsum(\"bix, iox -> box\", input_ft, weights)\n",
    "\n",
    "    def _build_Tx(self, N: int, device, dtype):\n",
    "        \"\"\"\n",
    "        Build the Chebyshev-like frequency embedding Tx used by mlpxr/mlpxi.\n",
    "        N is the *spatial* length; the rfft has K = N//2 + 1 modes.\n",
    "        Tx shape: (1, n_basis, K)\n",
    "        \"\"\"\n",
    "        K = N // 2 + 1\n",
    "        # frequencies in [0, 0.5], shape (1, K)\n",
    "        gridx = torch.fft.rfftfreq(N, d=1.0, device=device).unsqueeze(0).to(dtype)\n",
    "        # Chebyshev grades\n",
    "        grade = torch.arange(1, self.n_basis + 1, device=device, dtype=dtype).view(self.n_basis, 1)\n",
    "        # Tx_{k,j} = cos(k * arccos(ω_j))\n",
    "        Tx = torch.cos(grade @ torch.acos(gridx))  # (n_basis, K)\n",
    "        Tx = Tx.unsqueeze(0)                       # (1, n_basis, K)\n",
    "        return Tx\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        x: (B, C_in, N)\n",
    "        \"\"\"\n",
    "        B, C_in, N = x.shape\n",
    "        device, dtype = x.device, x.dtype\n",
    "\n",
    "        # Build frequency embedding Tx\n",
    "        Tx = self._build_Tx(N, device, dtype)      # (1, n_basis, K)\n",
    "        Tx = Tx.to(device=device, dtype=dtype)\n",
    "\n",
    "        # Generate real/imag parts of kernel via MLPs\n",
    "        xr = self.mlpxr(Tx)                        # (1, C_in*C_out, K)\n",
    "        xi = self.mlpxi(Tx)                        # (1, C_in*C_out, K)\n",
    "\n",
    "        K = N // 2 + 1\n",
    "        xr = xr.view(self.in_channels, self.out_channels, K)\n",
    "        xi = xi.view(self.in_channels, self.out_channels, K)\n",
    "        kernel = xr + 1j * xi                      # (C_in, C_out, K)\n",
    "\n",
    "        # FFT, multiply, inverse FFT\n",
    "        x_ft = torch.fft.rfft(x)                   # (B, C_in, K)\n",
    "        out_ft = self.compl_mul1d(x_ft, kernel)    # (B, C_out, K)\n",
    "        x_out = torch.fft.irfft(out_ft, n=N)       # (B, C_out, N)\n",
    "        return x_out\n",
    "\n",
    "\n",
    "# ---------------------------------------------------------\n",
    "# 1D AM-FNO (AMFNO1d) model\n",
    "# ---------------------------------------------------------\n",
    "class AMFNO1d(nn.Module):\n",
    "    \"\"\"\n",
    "    1D AM-FNO for your G_1, G_2, G_3 benchmarks.\n",
    "\n",
    "    Expected I/O:\n",
    "      - input:  (B, 1, N)   (your f samples)\n",
    "      - output: (B, 1, N)   (prediction of Gf)\n",
    "\n",
    "    Architecture:\n",
    "      - lift:  Linear([u(x), x] -> width)\n",
    "      - 4 amortized spectral conv blocks + local MLPs with residual\n",
    "      - final MLP to 1 channel\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(\n",
    "        self,\n",
    "        width: int,\n",
    "        n_basis: int = 16,\n",
    "        padding: int = 0,\n",
    "        in_channels: int = 1,\n",
    "        out_channels: int = 1,\n",
    "        mlp_dropout: float = 0.0,\n",
    "    ):\n",
    "        super().__init__()\n",
    "\n",
    "        self.width = width\n",
    "        self.padding = padding\n",
    "        self.n_basis = n_basis\n",
    "        self.in_channels = in_channels\n",
    "        self.out_channels = out_channels\n",
    "\n",
    "        # Lift input: concatenate u(x) and coordinate x, then project to width\n",
    "        # input_dim = in_channels + 1 (for the coordinate x)\n",
    "        self.p = nn.Linear(in_channels + 1, width)\n",
    "\n",
    "        # 4 amortized spectral conv layers\n",
    "        self.conv0 = SpectralConv1dMLP(width, width, n_basis, dropout=mlp_dropout)\n",
    "        self.conv1 = SpectralConv1dMLP(width, width, n_basis, dropout=mlp_dropout)\n",
    "        self.conv2 = SpectralConv1dMLP(width, width, n_basis, dropout=mlp_dropout)\n",
    "        self.conv3 = SpectralConv1dMLP(width, width, n_basis, dropout=mlp_dropout)\n",
    "\n",
    "        # 4 local channel-wise MLPs\n",
    "        self.mlp0 = MLP1d(width, width, 4 * width, dropout=mlp_dropout)\n",
    "        self.mlp1 = MLP1d(width, width, 4 * width, dropout=mlp_dropout)\n",
    "        self.mlp2 = MLP1d(width, width, 4 * width, dropout=mlp_dropout)\n",
    "        self.mlp3 = MLP1d(width, width, 4 * width, dropout=mlp_dropout)\n",
    "\n",
    "        # Final projection back to out_channels=1\n",
    "        self.q = MLP1d(width, out_channels, 4 * width, dropout=mlp_dropout)\n",
    "\n",
    "    def get_grid(self, shape, device):\n",
    "        \"\"\"\n",
    "        Generate 1D coordinate grid x in [-π, π) per batch.\n",
    "        shape: input shape (B, C, N)\n",
    "        returns: (B, N, 1)\n",
    "        \"\"\"\n",
    "        batch_size, _, N = shape\n",
    "        x = torch.linspace(-torch.pi, torch.pi, N + 1, device=device)[:-1]  # periodic grid\n",
    "        x = x.view(1, N, 1).repeat(batch_size, 1, 1)\n",
    "        return x\n",
    "\n",
    "    def forward(self, u):\n",
    "        \"\"\"\n",
    "        u: (B, 1, N)\n",
    "        returns: (B, 1, N)\n",
    "        \"\"\"\n",
    "        B, C, N = u.shape\n",
    "        device = u.device\n",
    "\n",
    "        # Build spatial grid and form input [u(x), x]\n",
    "        grid = self.get_grid(u.shape, device)           # (B, N, 1)\n",
    "        x = u.permute(0, 2, 1)                          # (B, N, 1)\n",
    "        x = torch.cat((x, grid), dim=-1)                # (B, N, in_channels+1)\n",
    "\n",
    "        # Lift to width channels\n",
    "        x = self.p(x)                                   # (B, N, width)\n",
    "        x = x.permute(0, 2, 1).contiguous()             # (B, width, N)\n",
    "\n",
    "        # Optional padding in spatial dimension (usually padding=0 for your setup)\n",
    "        if self.padding > 0:\n",
    "            x = F.pad(x, (0, self.padding))             # pad last dimension\n",
    "\n",
    "        # Block 0\n",
    "        x1 = self.conv0(x)\n",
    "        x1 = self.mlp0(x1)\n",
    "        x = x + x1\n",
    "        x = F.gelu(x)\n",
    "\n",
    "        # Block 1\n",
    "        x1 = self.conv1(x)\n",
    "        x1 = self.mlp1(x1)\n",
    "        x = x + x1\n",
    "        x = F.gelu(x)\n",
    "\n",
    "        # Block 2\n",
    "        x1 = self.conv2(x)\n",
    "        x1 = self.mlp2(x1)\n",
    "        x = x + x1\n",
    "        x = F.gelu(x)\n",
    "\n",
    "        # Block 3\n",
    "        x1 = self.conv3(x)\n",
    "        x1 = self.mlp3(x1)\n",
    "        x = x + x1\n",
    "        # last block often left without activation; you can add F.gelu(x) if desired\n",
    "\n",
    "        # Remove padding if any\n",
    "        if self.padding > 0:\n",
    "            x = x[..., :-self.padding]\n",
    "\n",
    "        # Final projection to 1 channel\n",
    "        x = self.q(x)                                   # (B, out_channels, N) with out_channels=1\n",
    "\n",
    "        # Return in (B, 1, N) format\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "import torch.optim.lr_scheduler as lr_scheduler\n",
    "import matplotlib.pyplot as plt\n",
    "import time\n",
    "\n",
    "\n",
    "\n",
    "def relative_l2_loss(g_pred, Gf):\n",
    "    \"\"\"\n",
    "    Computes relative L2 error: norm(g_pred - Gf) / (norm(Gf) + 1e-8)\n",
    "    \"\"\"\n",
    "    eps = 1e-8\n",
    "    return torch.norm(g_pred - Gf) / (torch.norm(Gf) + eps)\n",
    "\n",
    "def train_operator(\n",
    "    dataset_raw, \n",
    "    model, \n",
    "    num_epochs,\n",
    "    lr,\n",
    "    device,\n",
    "    batch_size=16,\n",
    "    test_dataset_raw=None,  # (NEW) for test data\n",
    "    reduce_on='test',       # which metric to monitor: 'train' or 'test'\n",
    "    factor=0.5,             # factor to reduce LR on plateau\n",
    "    patience=5,             # epochs of no improvement\n",
    "    min_lr=1e-6,            # minimal LR\n",
    "    cooldown=0\n",
    "):\n",
    "    \"\"\"\n",
    "    Train the FNO model with:\n",
    "      1) A 'ReduceLROnPlateau' scheduler that halves LR on plateau.\n",
    "      2) An optional test dataset to compute and print test rel L2 each epoch.\n",
    "      3) Plot both train and test curves at the end.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    dataset_raw : list of dict\n",
    "        Train samples in FNO style: 'f' (1,n), 'Gf' (1,n), 'x' (n,), 'func_type'.\n",
    "    model : torch.nn.Module\n",
    "        The FNO model to train.\n",
    "    num_epochs : int\n",
    "        Number of epochs to train.\n",
    "    lr : float\n",
    "        Initial learning rate for the optimizer.\n",
    "    device : torch.device\n",
    "        CPU/CUDA device.\n",
    "    batch_size : int\n",
    "        Batch size.\n",
    "    test_dataset_raw : list of dict, optional\n",
    "        If provided, used to compute test loss each epoch.\n",
    "    reduce_on : str\n",
    "        Either 'test' or 'train' - which metric to monitor for LR schedule.\n",
    "    factor : float\n",
    "        Multiplicative factor by which LR is reduced on plateau.\n",
    "    patience : int\n",
    "        Number of epochs of no improvement before reducing LR.\n",
    "    min_lr : float\n",
    "        Lower bound on LR.\n",
    "    cooldown : int\n",
    "        Number of epochs to wait after LR is reduced before next reduce.\n",
    "    \"\"\"\n",
    "\n",
    "    model.to(device)\n",
    "\n",
    "    # 1) Prepare training dataset\n",
    "    #    We'll unify to a single resolution from first sample\n",
    "    target_n = dataset_raw[0][\"f\"].shape[-1]\n",
    "    dataset_fixed = [s for s in dataset_raw if s[\"f\"].shape[-1] == target_n]\n",
    "    if len(dataset_fixed) == 0:\n",
    "        raise ValueError(\"No samples with matching resolution found in training.\")\n",
    "\n",
    "    train_inputs = torch.stack([s[\"f\"] for s in dataset_fixed], dim=0)   # (N, 1, n)\n",
    "    train_targets = torch.stack([s[\"Gf\"] for s in dataset_fixed], dim=0) # (N, 1, n)\n",
    "    train_dataset = TensorDataset(train_inputs, train_targets)\n",
    "    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    # 2) Prepare test dataset (if any)\n",
    "    test_loader = None\n",
    "    if test_dataset_raw is not None:\n",
    "        # unify resolution as well\n",
    "        test_fixed = [s for s in test_dataset_raw if s[\"f\"].shape[-1] == target_n]\n",
    "        if len(test_fixed) == 0:\n",
    "            print(\"Warning: no test samples with matching resolution found. Test dataset ignored.\")\n",
    "            test_dataset_raw = None\n",
    "        else:\n",
    "            test_inputs = torch.stack([s[\"f\"] for s in test_fixed], dim=0)\n",
    "            test_targets = torch.stack([s[\"Gf\"] for s in test_fixed], dim=0)\n",
    "            test_dataset = TensorDataset(test_inputs, test_targets)\n",
    "            test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "    # 3) Define optimizer + LR scheduler\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(\n",
    "        optimizer,\n",
    "        mode='min',     # we want to minimize loss\n",
    "        factor=factor,  \n",
    "        patience=patience,\n",
    "        threshold=1e-4,\n",
    "        cooldown=cooldown,\n",
    "        min_lr=min_lr,\n",
    "        verbose=True\n",
    "    )\n",
    "\n",
    "    train_losses = []\n",
    "    test_losses = []\n",
    "    start_time = time.time()\n",
    "\n",
    "    model.train()\n",
    "    for epoch in range(num_epochs):\n",
    "        epoch_start = time.time()\n",
    "\n",
    "        # (a) train loop\n",
    "        running_loss = 0.0\n",
    "        for batch_f, batch_Gf in train_loader:\n",
    "            batch_f = batch_f.to(device)\n",
    "            batch_Gf = batch_Gf.to(device)\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            pred_Gf = model(batch_f)  # shape (batch, 1, n)\n",
    "            loss = relative_l2_loss(pred_Gf, batch_Gf)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            running_loss += loss.item() * batch_f.size(0)\n",
    "\n",
    "        epoch_train_loss = running_loss / len(train_dataset)\n",
    "        train_losses.append(epoch_train_loss)\n",
    "\n",
    "        # (b) test loop (if provided)\n",
    "        if test_loader is not None:\n",
    "            model.eval()\n",
    "            test_running_loss = 0.0\n",
    "            with torch.no_grad():\n",
    "                for batch_f, batch_Gf in test_loader:\n",
    "                    batch_f = batch_f.to(device)\n",
    "                    batch_Gf = batch_Gf.to(device)\n",
    "                    pred_Gf = model(batch_f)\n",
    "                    test_loss = relative_l2_loss(pred_Gf, batch_Gf)\n",
    "                    test_running_loss += test_loss.item() * batch_f.size(0)\n",
    "            epoch_test_loss = test_running_loss / len(test_loader.dataset)\n",
    "            test_losses.append(epoch_test_loss)\n",
    "            model.train()\n",
    "        else:\n",
    "            epoch_test_loss = None\n",
    "\n",
    "        # (c) update LR via scheduler\n",
    "        # decide which metric to monitor: train or test\n",
    "        if reduce_on == 'test' and epoch_test_loss is not None:\n",
    "            scheduler.step(epoch_test_loss)\n",
    "        else:\n",
    "            # fallback: train\n",
    "            scheduler.step(epoch_train_loss)\n",
    "\n",
    "        # (d) print progress\n",
    "        epoch_time = time.time() - epoch_start\n",
    "        current_lr = optimizer.param_groups[0]['lr']\n",
    "        if epoch_test_loss is not None:\n",
    "            print(f\"Epoch [{epoch+1}/{num_epochs}] | \"\n",
    "                  f\"Train Loss={epoch_train_loss:.9f} | Test Loss={epoch_test_loss:.9f} | \"\n",
    "                  f\"Time={epoch_time:.2f}s | LR={current_lr:.2e}\")\n",
    "        else:\n",
    "            print(f\"Epoch [{epoch+1}/{num_epochs}] | \"\n",
    "                  f\"Train Loss={epoch_train_loss:.9f} | Time={epoch_time:.2f}s | \"\n",
    "                  f\"LR={current_lr:.2e}\")\n",
    "\n",
    "    total_time = time.time() - start_time\n",
    "    print(f\"\\nTotal training time: {total_time:.2f} seconds\")\n",
    "\n",
    "    # (e) plot train & test\n",
    "    plt.figure()\n",
    "    plt.semilogy(train_losses, label=\"Train Rel L2\")\n",
    "    if test_loader is not None:\n",
    "        plt.semilogy(test_losses, label=\"Test Rel L2\")\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Relative L2 Error\")\n",
    "    plt.legend()\n",
    "    plt.grid()\n",
    "    plt.show()\n",
    "\n",
    "    return model, train_losses, test_losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 1. Dataset conversion (same as before)\n",
    "# ------------------------------------------------------------------\n",
    "def convert_dataset_for_fno(dataset):\n",
    "    \"\"\"\n",
    "    Convert each sample in the dataset to the evaluation format:\n",
    "      - 'x': (n,)\n",
    "      - 'f': (1, n)\n",
    "      - 'Gf': (1, n)\n",
    "      - 'func_type': str\n",
    "    \"\"\"\n",
    "    new_dataset = []\n",
    "    for sample in dataset:\n",
    "        if len(sample) < 4:\n",
    "            raise ValueError(\"Each sample must have (x, f, Gf, func_type).\")\n",
    "        x, f, Gf, func_type = sample[:4]\n",
    "\n",
    "        # Force (1, n)\n",
    "        if f.ndim == 1:\n",
    "            f = f.unsqueeze(0)\n",
    "        if Gf.ndim == 1:\n",
    "            Gf = Gf.unsqueeze(0)\n",
    "\n",
    "        new_dataset.append({\n",
    "            'x': x,\n",
    "            'f': f,\n",
    "            'Gf': Gf,\n",
    "            'func_type': func_type\n",
    "        })\n",
    "    return new_dataset\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 2. Same relative L2 definition as training\n",
    "# ------------------------------------------------------------------\n",
    "def relative_l2_loss(g_pred, Gf, eps: float = 1e-8):\n",
    "    \"\"\"\n",
    "    Same as in the training loop:\n",
    "        ||g_pred - Gf|| / ( ||Gf|| + eps )\n",
    "    Works for any matching shapes.\n",
    "    \"\"\"\n",
    "    return torch.norm(g_pred - Gf) / (torch.norm(Gf) + eps)\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 3. Evaluation with *global* relative L2 per type (matches training)\n",
    "# ------------------------------------------------------------------\n",
    "def evaluate_operator(dataset, model, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Evaluate a 1D operator model (FNO, U-FNO, etc.) on a dataset.\n",
    "\n",
    "    - Feeds inputs with shape (batch=1, channels=1, n), same as training.\n",
    "    - Aggregates numerator and denominator over all samples of a given type:\n",
    "          E_type = sqrt( sum ||err_i||^2 ) / sqrt( sum ||Gf_i||^2 )\n",
    "      This is the dataset-level relative L2, consistent with your training loss\n",
    "      (just with batch_size = 1 instead of 16).\n",
    "\n",
    "    Returns:\n",
    "        type_errors: dict func_type -> relative L2 (float)\n",
    "        overall_error: single relative L2 over the whole dataset\n",
    "    \"\"\"\n",
    "    model.to(device)\n",
    "    model.eval()\n",
    "\n",
    "    eps = 1e-8\n",
    "\n",
    "    # Accumulate squared errors and squared norms\n",
    "    num_total = 0.0\n",
    "    den_total = 0.0\n",
    "    num_by_type = defaultdict(float)\n",
    "    den_by_type = defaultdict(float)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for sample in dataset:\n",
    "            func_type = sample[\"func_type\"]\n",
    "            f = sample[\"f\"]    # (1, n)\n",
    "            Gf = sample[\"Gf\"]  # (1, n)\n",
    "\n",
    "            # Make a batch dimension: (1, 1, n)\n",
    "            if f.ndim == 2:\n",
    "                f_in = f.unsqueeze(0)\n",
    "            elif f.ndim == 3:\n",
    "                f_in = f\n",
    "            else:\n",
    "                raise ValueError(f\"Unexpected f.ndim={f.ndim}, expected 2 or 3.\")\n",
    "\n",
    "            if Gf.ndim == 2:\n",
    "                Gf_in = Gf.unsqueeze(0)\n",
    "            elif Gf.ndim == 3:\n",
    "                Gf_in = Gf\n",
    "            else:\n",
    "                raise ValueError(f\"Unexpected Gf.ndim={Gf.ndim}, expected 2 or 3.\")\n",
    "\n",
    "            f_in = f_in.to(device)   # (1, 1, n)\n",
    "            Gf_in = Gf_in.to(device) # (1, 1, n)\n",
    "\n",
    "            # Forward pass\n",
    "            g_pred = model(f_in)\n",
    "\n",
    "            # Try to coerce output into same shape as Gf_in\n",
    "            if g_pred.shape != Gf_in.shape:\n",
    "                # Common 1D cases: (1, n) or (1, n, 1)\n",
    "                if g_pred.ndim == 2 and g_pred.shape[0] == Gf_in.shape[0]:\n",
    "                    # (1, n) -> (1, 1, n)\n",
    "                    g_pred = g_pred.unsqueeze(1)\n",
    "                elif g_pred.ndim == 3 and g_pred.shape[1] == 1 \\\n",
    "                     and g_pred.shape[-1] == Gf_in.shape[-1]:\n",
    "                    # already (1, 1, n) – fine\n",
    "                    pass\n",
    "                else:\n",
    "                    raise RuntimeError(\n",
    "                        f\"Shape mismatch: g_pred {g_pred.shape}, Gf_in {Gf_in.shape}\"\n",
    "                    )\n",
    "\n",
    "            # Accumulate squared errors and norms\n",
    "            diff = g_pred - Gf_in\n",
    "            num = torch.sum(diff**2).item()\n",
    "            den = torch.sum(Gf_in**2).item()\n",
    "\n",
    "            num_total += num\n",
    "            den_total += den\n",
    "            num_by_type[func_type] += num\n",
    "            den_by_type[func_type] += den\n",
    "\n",
    "    # Compute dataset-level relative L2 per type\n",
    "    type_errors = {}\n",
    "    for ttype in sorted(num_by_type.keys()):\n",
    "        n = num_by_type[ttype]\n",
    "        d = den_by_type[ttype]\n",
    "        err = (n**0.5) / (d**0.5 + eps) if d > 0 else 0.0\n",
    "        type_errors[ttype] = err\n",
    "        print(f\"Function type: {ttype:20s} | Relative L2: {err:.8f}\")\n",
    "\n",
    "    # Overall dataset-level relative L2\n",
    "    overall_error = (num_total**0.5) / (den_total**0.5 + eps) if den_total > 0 else 0.0\n",
    "    print(f\"\\nOverall relative L2 error: {overall_error:.8f}\")\n",
    "\n",
    "    return type_errors, overall_error\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------\n",
    "# 4. Plotting helper (uses same shapes & loss)\n",
    "# ------------------------------------------------------------------\n",
    "def plot_functions(dataset, model, device=torch.device(\"cpu\"), max_plots=8):\n",
    "    \"\"\"\n",
    "    Plot input f(x), target Gf(x), and model prediction for up to max_plots samples.\n",
    "    Uses the same (1,1,n) input convention and the same relative L2 definition.\n",
    "    \"\"\"\n",
    "    model.to(device)\n",
    "    model.eval()\n",
    "\n",
    "    num_samples = min(len(dataset), max_plots)\n",
    "    num_cols = 4\n",
    "    num_rows = (num_samples + num_cols - 1) // num_cols\n",
    "\n",
    "    plt.figure(figsize=(20, 5 * num_rows))\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for idx in range(num_samples):\n",
    "            sample = dataset[idx]\n",
    "            x = sample[\"x\"]    # (n,)\n",
    "            f = sample[\"f\"]    # (1, n)\n",
    "            Gf = sample[\"Gf\"]  # (1, n)\n",
    "            func_type = sample[\"func_type\"]\n",
    "\n",
    "            # (1,1,n)\n",
    "            if f.ndim == 2:\n",
    "                f_in = f.unsqueeze(0)\n",
    "            else:\n",
    "                f_in = f\n",
    "            if Gf.ndim == 2:\n",
    "                Gf_in = Gf.unsqueeze(0)\n",
    "            else:\n",
    "                Gf_in = Gf\n",
    "\n",
    "            f_in = f_in.to(device)\n",
    "            Gf_in = Gf_in.to(device)\n",
    "\n",
    "            g_pred = model(f_in)\n",
    "            if g_pred.ndim == 2:\n",
    "                g_pred = g_pred.unsqueeze(1)  # (1,1,n)\n",
    "\n",
    "            rel_err = relative_l2_loss(g_pred, Gf_in).item()\n",
    "\n",
    "            # Move to CPU and flatten to (n,)\n",
    "            x_np = x.cpu().numpy()\n",
    "            f_np = f.view(-1).cpu().numpy()\n",
    "            Gf_np = Gf.view(-1).cpu().numpy()\n",
    "            g_pred_np = g_pred.view(-1).cpu().numpy()\n",
    "\n",
    "            plt.subplot(num_rows, num_cols, idx + 1)\n",
    "            plt.plot(x_np, f_np, label=\"Input $f(x)$\", linewidth=2)\n",
    "            plt.plot(x_np, Gf_np, label=\"Target $Gf(x)$\", linestyle=\"--\", linewidth=2)\n",
    "            plt.plot(x_np, g_pred_np, label=\"Pred $g_{pred}(x)$\",\n",
    "                     linestyle=\"-.\", linewidth=2)\n",
    "            plt.xlabel(\"$x$\")\n",
    "            plt.ylabel(\"Value\")\n",
    "            plt.title(f\"{func_type}\\nSample {idx+1}, Rel-L2: {rel_err:.4f}\")\n",
    "            plt.legend()\n",
    "            plt.grid(True)\n",
    "\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = convert_dataset_for_fno(torch.load('train_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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AMFNO1d params: 547,729\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "from neuralop.models import FNO1d\n",
    "from neuralop.layers.embeddings import GridEmbeddingND\n",
    "\n",
    "\n",
    "# device\n",
    "device = 'cuda:1'\n",
    "# AMFNO model: choose width & n_basis comparable to your 2-layer FNO (64 hidden, 128 modes)\n",
    "amfno = AMFNO1d(\n",
    "    width=48,\n",
    "    n_basis=12,         # #Chebyshev-like basis in frequency embedding\n",
    "    padding=0,\n",
    "    in_channels=1,\n",
    "    out_channels=1,\n",
    "    mlp_dropout=0.0,\n",
    ").to(device)\n",
    "\n",
    "# Optional: parameter count\n",
    "def count_params(m):\n",
    "    return sum(p.numel() for p in m.parameters() if p.requires_grad)\n",
    "print(f\"AMFNO1d params: {count_params(amfno):,}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n"
     ]
    },
    {
     "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.286321641 | Test Loss=0.044191527 | Time=1.98s | LR=1.00e-03\n",
      "Epoch [2/1000] | Train Loss=0.049260058 | Test Loss=0.083464422 | Time=1.69s | LR=1.00e-03\n",
      "Epoch [3/1000] | Train Loss=0.050010887 | Test Loss=0.038502580 | Time=1.69s | LR=1.00e-03\n",
      "Epoch [4/1000] | Train Loss=0.043989524 | Test Loss=0.104565120 | Time=1.69s | LR=1.00e-03\n",
      "Epoch [5/1000] | Train Loss=0.045799947 | Test Loss=0.030977814 | Time=1.71s | LR=1.00e-03\n",
      "Epoch [6/1000] | Train Loss=0.030598759 | Test Loss=0.020386922 | Time=1.79s | LR=1.00e-03\n",
      "Epoch [7/1000] | Train Loss=0.028933001 | Test Loss=0.024046360 | Time=1.36s | LR=1.00e-03\n",
      "Epoch [8/1000] | Train Loss=0.028498358 | Test Loss=0.036491234 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [9/1000] | Train Loss=0.035136399 | Test Loss=0.059516872 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [10/1000] | Train Loss=0.034757489 | Test Loss=0.025690305 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [11/1000] | Train Loss=0.024921818 | Test Loss=0.035553168 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [12/1000] | Train Loss=0.029438545 | Test Loss=0.026953488 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [13/1000] | Train Loss=0.028154641 | Test Loss=0.022959080 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [14/1000] | Train Loss=0.026662254 | Test Loss=0.023606858 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [15/1000] | Train Loss=0.023444871 | Test Loss=0.028801391 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [16/1000] | Train Loss=0.026779027 | Test Loss=0.019425216 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [17/1000] | Train Loss=0.032506680 | Test Loss=0.027078299 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [18/1000] | Train Loss=0.029249592 | Test Loss=0.024656185 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [19/1000] | Train Loss=0.024159416 | Test Loss=0.021239211 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [20/1000] | Train Loss=0.023676153 | Test Loss=0.051329618 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [21/1000] | Train Loss=0.028895415 | Test Loss=0.036913850 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [22/1000] | Train Loss=0.022005572 | Test Loss=0.023381725 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [23/1000] | Train Loss=0.022534386 | Test Loss=0.017666276 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [24/1000] | Train Loss=0.026411426 | Test Loss=0.027271644 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [25/1000] | Train Loss=0.028199531 | Test Loss=0.036552098 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [26/1000] | Train Loss=0.040598384 | Test Loss=0.018888872 | Time=1.63s | LR=1.00e-03\n",
      "Epoch [27/1000] | Train Loss=0.021306022 | Test Loss=0.024635903 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [28/1000] | Train Loss=0.032087805 | Test Loss=0.031222798 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [29/1000] | Train Loss=0.029980783 | Test Loss=0.063451846 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [30/1000] | Train Loss=0.027421822 | Test Loss=0.017570290 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [31/1000] | Train Loss=0.018634630 | Test Loss=0.020952654 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [32/1000] | Train Loss=0.035106904 | Test Loss=0.052340715 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [33/1000] | Train Loss=0.026900571 | Test Loss=0.046543280 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [34/1000] | Train Loss=0.023271625 | Test Loss=0.026472964 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [35/1000] | Train Loss=0.027527432 | Test Loss=0.029012890 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [36/1000] | Train Loss=0.025469348 | Test Loss=0.033017781 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [37/1000] | Train Loss=0.020400035 | Test Loss=0.022901535 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [38/1000] | Train Loss=0.022423178 | Test Loss=0.023138505 | Time=1.71s | LR=1.00e-03\n",
      "Epoch [39/1000] | Train Loss=0.020690542 | Test Loss=0.027729676 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [40/1000] | Train Loss=0.024976188 | Test Loss=0.025806608 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [41/1000] | Train Loss=0.019844205 | Test Loss=0.065669642 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [42/1000] | Train Loss=0.028660533 | Test Loss=0.031062770 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [43/1000] | Train Loss=0.020040778 | Test Loss=0.033105531 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [44/1000] | Train Loss=0.032296024 | Test Loss=0.060397533 | Time=1.58s | LR=1.00e-03\n",
      "Epoch [45/1000] | Train Loss=0.027476157 | Test Loss=0.014827017 | Time=1.67s | LR=1.00e-03\n",
      "Epoch [46/1000] | Train Loss=0.033682367 | Test Loss=0.027219445 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [47/1000] | Train Loss=0.023547051 | Test Loss=0.037024910 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [48/1000] | Train Loss=0.022472488 | Test Loss=0.028318854 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [49/1000] | Train Loss=0.019937076 | Test Loss=0.026808482 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [50/1000] | Train Loss=0.019466308 | Test Loss=0.051708649 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [51/1000] | Train Loss=0.038193156 | Test Loss=0.033200696 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [52/1000] | Train Loss=0.022068934 | Test Loss=0.025051217 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [53/1000] | Train Loss=0.021515422 | Test Loss=0.016924898 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [54/1000] | Train Loss=0.020327656 | Test Loss=0.017215120 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [55/1000] | Train Loss=0.031737543 | Test Loss=0.025852801 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [56/1000] | Train Loss=0.025415994 | Test Loss=0.025347431 | Time=1.64s | LR=1.00e-03\n",
      "Epoch [57/1000] | Train Loss=0.018390979 | Test Loss=0.019829101 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [58/1000] | Train Loss=0.031776875 | Test Loss=0.044618657 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [59/1000] | Train Loss=0.039391323 | Test Loss=0.014310582 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [60/1000] | Train Loss=0.024021650 | Test Loss=0.016034992 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [61/1000] | Train Loss=0.018613383 | Test Loss=0.020869233 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [62/1000] | Train Loss=0.020951319 | Test Loss=0.020688273 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [63/1000] | Train Loss=0.017870479 | Test Loss=0.023805745 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [64/1000] | Train Loss=0.016894424 | Test Loss=0.023000332 | Time=1.72s | LR=1.00e-03\n",
      "Epoch [65/1000] | Train Loss=0.022549824 | Test Loss=0.031749858 | Time=1.83s | LR=1.00e-03\n",
      "Epoch [66/1000] | Train Loss=0.021583718 | Test Loss=0.012195684 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [67/1000] | Train Loss=0.014631060 | Test Loss=0.010667902 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [68/1000] | Train Loss=0.023732395 | Test Loss=0.023913170 | Time=1.79s | LR=1.00e-03\n",
      "Epoch [69/1000] | Train Loss=0.023158810 | Test Loss=0.030860372 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [70/1000] | Train Loss=0.031874003 | Test Loss=0.029922354 | Time=1.78s | LR=1.00e-03\n",
      "Epoch [71/1000] | Train Loss=0.022245338 | Test Loss=0.024350789 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [72/1000] | Train Loss=0.021229764 | Test Loss=0.018462920 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [73/1000] | Train Loss=0.015135599 | Test Loss=0.012129271 | Time=1.85s | LR=1.00e-03\n",
      "Epoch [74/1000] | Train Loss=0.017593756 | Test Loss=0.020098493 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [75/1000] | Train Loss=0.025589645 | Test Loss=0.016876508 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [76/1000] | Train Loss=0.014716155 | Test Loss=0.010421320 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [77/1000] | Train Loss=0.023476948 | Test Loss=0.032705409 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [78/1000] | Train Loss=0.016443718 | Test Loss=0.028265370 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [79/1000] | Train Loss=0.021861652 | Test Loss=0.073799379 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [80/1000] | Train Loss=0.023831376 | Test Loss=0.015900472 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [81/1000] | Train Loss=0.023905101 | Test Loss=0.015139786 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [82/1000] | Train Loss=0.017025760 | Test Loss=0.012026656 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [83/1000] | Train Loss=0.015798437 | Test Loss=0.020750548 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [84/1000] | Train Loss=0.016950501 | Test Loss=0.028231430 | Time=1.84s | LR=1.00e-03\n",
      "Epoch [85/1000] | Train Loss=0.024194096 | Test Loss=0.011018839 | Time=1.83s | LR=1.00e-03\n",
      "Epoch [86/1000] | Train Loss=0.018193213 | Test Loss=0.013732928 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [87/1000] | Train Loss=0.016779652 | Test Loss=0.016689505 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [88/1000] | Train Loss=0.018723049 | Test Loss=0.013779929 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [89/1000] | Train Loss=0.017200490 | Test Loss=0.015772834 | Time=1.78s | LR=1.00e-03\n",
      "Epoch [90/1000] | Train Loss=0.023845984 | Test Loss=0.017576328 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [91/1000] | Train Loss=0.025053129 | Test Loss=0.016535178 | Time=1.72s | LR=1.00e-03\n",
      "Epoch [92/1000] | Train Loss=0.017470750 | Test Loss=0.015328557 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [93/1000] | Train Loss=0.015795735 | Test Loss=0.027493582 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [94/1000] | Train Loss=0.020162104 | Test Loss=0.050045011 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [95/1000] | Train Loss=0.027104003 | Test Loss=0.022771450 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [96/1000] | Train Loss=0.015964200 | Test Loss=0.023204472 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [97/1000] | Train Loss=0.022243856 | Test Loss=0.021614029 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [98/1000] | Train Loss=0.016859436 | Test Loss=0.014490484 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [99/1000] | Train Loss=0.021974719 | Test Loss=0.051521123 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [100/1000] | Train Loss=0.014846944 | Test Loss=0.009875755 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [101/1000] | Train Loss=0.016064169 | Test Loss=0.014650204 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [102/1000] | Train Loss=0.023585076 | Test Loss=0.037385628 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [103/1000] | Train Loss=0.014721341 | Test Loss=0.021590664 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [104/1000] | Train Loss=0.015664910 | Test Loss=0.035309284 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [105/1000] | Train Loss=0.017300628 | Test Loss=0.014192342 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [106/1000] | Train Loss=0.022454511 | Test Loss=0.017171880 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [107/1000] | Train Loss=0.013530774 | Test Loss=0.025218476 | Time=1.79s | LR=1.00e-03\n",
      "Epoch [108/1000] | Train Loss=0.014868569 | Test Loss=0.010239879 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [109/1000] | Train Loss=0.020663920 | Test Loss=0.015976788 | Time=1.71s | LR=1.00e-03\n",
      "Epoch [110/1000] | Train Loss=0.023690615 | Test Loss=0.011051419 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [111/1000] | Train Loss=0.014599033 | Test Loss=0.012777318 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [112/1000] | Train Loss=0.018154190 | Test Loss=0.016501982 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [113/1000] | Train Loss=0.025828299 | Test Loss=0.020361761 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [114/1000] | Train Loss=0.025293433 | Test Loss=0.012202368 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [115/1000] | Train Loss=0.013610672 | Test Loss=0.017584160 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [116/1000] | Train Loss=0.014138807 | Test Loss=0.026146063 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [117/1000] | Train Loss=0.020057485 | Test Loss=0.035322176 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [118/1000] | Train Loss=0.016040401 | Test Loss=0.020322786 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [119/1000] | Train Loss=0.016842839 | Test Loss=0.020033114 | Time=1.70s | LR=1.00e-03\n",
      "Epoch [120/1000] | Train Loss=0.027132475 | Test Loss=0.036445652 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [121/1000] | Train Loss=0.016648687 | Test Loss=0.018802919 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [122/1000] | Train Loss=0.022036496 | Test Loss=0.014410821 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [123/1000] | Train Loss=0.024882249 | Test Loss=0.023883609 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [124/1000] | Train Loss=0.023296508 | Test Loss=0.017240746 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [125/1000] | Train Loss=0.015397506 | Test Loss=0.016990841 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [126/1000] | Train Loss=0.014380482 | Test Loss=0.011651464 | Time=1.79s | LR=1.00e-03\n",
      "Epoch [127/1000] | Train Loss=0.012116173 | Test Loss=0.013631743 | Time=1.68s | LR=1.00e-03\n",
      "Epoch [128/1000] | Train Loss=0.014415020 | Test Loss=0.031064336 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [129/1000] | Train Loss=0.023300636 | Test Loss=0.012197589 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [130/1000] | Train Loss=0.024623399 | Test Loss=0.010372832 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [131/1000] | Train Loss=0.014093699 | Test Loss=0.018989619 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [132/1000] | Train Loss=0.023875406 | Test Loss=0.013557786 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [133/1000] | Train Loss=0.019133084 | Test Loss=0.010642661 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [134/1000] | Train Loss=0.017177297 | Test Loss=0.034722236 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [135/1000] | Train Loss=0.017959512 | Test Loss=0.014263117 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [136/1000] | Train Loss=0.012855386 | Test Loss=0.014463738 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [137/1000] | Train Loss=0.016536507 | Test Loss=0.010780150 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [138/1000] | Train Loss=0.013978913 | Test Loss=0.025497833 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [139/1000] | Train Loss=0.014899983 | Test Loss=0.016620519 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [140/1000] | Train Loss=0.017229106 | Test Loss=0.009183191 | Time=1.65s | LR=1.00e-03\n",
      "Epoch [141/1000] | Train Loss=0.017775477 | Test Loss=0.012487877 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [142/1000] | Train Loss=0.015258681 | Test Loss=0.021552090 | Time=1.79s | LR=1.00e-03\n",
      "Epoch [143/1000] | Train Loss=0.013136732 | Test Loss=0.014182012 | Time=1.78s | LR=1.00e-03\n",
      "Epoch [144/1000] | Train Loss=0.014373159 | Test Loss=0.012827940 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [145/1000] | Train Loss=0.012744490 | Test Loss=0.013052632 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [146/1000] | Train Loss=0.013579930 | Test Loss=0.011859368 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [147/1000] | Train Loss=0.015032002 | Test Loss=0.009871467 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [148/1000] | Train Loss=0.014436917 | Test Loss=0.035125303 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [149/1000] | Train Loss=0.019574842 | Test Loss=0.014465917 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [150/1000] | Train Loss=0.016246093 | Test Loss=0.019358379 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [151/1000] | Train Loss=0.012797174 | Test Loss=0.011700120 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [152/1000] | Train Loss=0.012319692 | Test Loss=0.017025892 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [153/1000] | Train Loss=0.013105163 | Test Loss=0.037310640 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [154/1000] | Train Loss=0.015937931 | Test Loss=0.012521866 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [155/1000] | Train Loss=0.013679239 | Test Loss=0.015255251 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [156/1000] | Train Loss=0.020771852 | Test Loss=0.013660915 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [157/1000] | Train Loss=0.021249762 | Test Loss=0.019196767 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [158/1000] | Train Loss=0.015843426 | Test Loss=0.016719114 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [159/1000] | Train Loss=0.013006811 | Test Loss=0.007055372 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [160/1000] | Train Loss=0.015680274 | Test Loss=0.018998266 | Time=1.72s | LR=1.00e-03\n",
      "Epoch [161/1000] | Train Loss=0.012210768 | Test Loss=0.009702132 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [162/1000] | Train Loss=0.010454313 | Test Loss=0.018517655 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [163/1000] | Train Loss=0.011807802 | Test Loss=0.012092944 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [164/1000] | Train Loss=0.014235598 | Test Loss=0.011066155 | Time=1.62s | LR=1.00e-03\n",
      "Epoch [165/1000] | Train Loss=0.021740604 | Test Loss=0.024392795 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [166/1000] | Train Loss=0.013378515 | Test Loss=0.014516368 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [167/1000] | Train Loss=0.011665452 | Test Loss=0.017099380 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [168/1000] | Train Loss=0.012766481 | Test Loss=0.015301677 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [169/1000] | Train Loss=0.015107603 | Test Loss=0.009434779 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [170/1000] | Train Loss=0.009315505 | Test Loss=0.021999629 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [171/1000] | Train Loss=0.012702054 | Test Loss=0.007737099 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [172/1000] | Train Loss=0.013995299 | Test Loss=0.013206258 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [173/1000] | Train Loss=0.011916973 | Test Loss=0.017574128 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [174/1000] | Train Loss=0.015218516 | Test Loss=0.012057918 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [175/1000] | Train Loss=0.010550761 | Test Loss=0.020623040 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [176/1000] | Train Loss=0.020854627 | Test Loss=0.037892735 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [177/1000] | Train Loss=0.013688298 | Test Loss=0.017669543 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [178/1000] | Train Loss=0.014154352 | Test Loss=0.017234593 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [179/1000] | Train Loss=0.011533509 | Test Loss=0.017657225 | Time=1.60s | LR=1.00e-03\n",
      "Epoch [180/1000] | Train Loss=0.020050955 | Test Loss=0.023764076 | Time=1.79s | LR=1.00e-03\n",
      "Epoch [181/1000] | Train Loss=0.020884520 | Test Loss=0.008311835 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [182/1000] | Train Loss=0.017774845 | Test Loss=0.015125889 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [183/1000] | Train Loss=0.010737523 | Test Loss=0.009104400 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [184/1000] | Train Loss=0.010575741 | Test Loss=0.013168866 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [185/1000] | Train Loss=0.016427081 | Test Loss=0.017364398 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [186/1000] | Train Loss=0.012394348 | Test Loss=0.023523842 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [187/1000] | Train Loss=0.014757471 | Test Loss=0.030786187 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [188/1000] | Train Loss=0.020584452 | Test Loss=0.025604134 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [189/1000] | Train Loss=0.017829664 | Test Loss=0.006780781 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [190/1000] | Train Loss=0.009295526 | Test Loss=0.019060050 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [191/1000] | Train Loss=0.015806454 | Test Loss=0.008798435 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [192/1000] | Train Loss=0.010121709 | Test Loss=0.009646257 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [193/1000] | Train Loss=0.014981583 | Test Loss=0.024063332 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [194/1000] | Train Loss=0.016246052 | Test Loss=0.010319642 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [195/1000] | Train Loss=0.014825736 | Test Loss=0.019797101 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [196/1000] | Train Loss=0.011445136 | Test Loss=0.013273343 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [197/1000] | Train Loss=0.014176919 | Test Loss=0.008295156 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [198/1000] | Train Loss=0.015456608 | Test Loss=0.012235371 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [199/1000] | Train Loss=0.010592930 | Test Loss=0.008813516 | Time=1.65s | LR=1.00e-03\n",
      "Epoch [200/1000] | Train Loss=0.010656401 | Test Loss=0.028178163 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [201/1000] | Train Loss=0.015798726 | Test Loss=0.016801234 | Time=1.67s | LR=1.00e-03\n",
      "Epoch [202/1000] | Train Loss=0.009234674 | Test Loss=0.009090753 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [203/1000] | Train Loss=0.008153973 | Test Loss=0.013887029 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [204/1000] | Train Loss=0.010168195 | Test Loss=0.017379817 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [205/1000] | Train Loss=0.011916126 | Test Loss=0.019972793 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [206/1000] | Train Loss=0.011494529 | Test Loss=0.028922875 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [207/1000] | Train Loss=0.017309712 | Test Loss=0.012422063 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [208/1000] | Train Loss=0.010602325 | Test Loss=0.010120640 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [209/1000] | Train Loss=0.015008785 | Test Loss=0.015378133 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [210/1000] | Train Loss=0.009540380 | Test Loss=0.011865717 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [211/1000] | Train Loss=0.010044513 | Test Loss=0.009120913 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [212/1000] | Train Loss=0.014609052 | Test Loss=0.009658461 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [213/1000] | Train Loss=0.010449588 | Test Loss=0.014534015 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [214/1000] | Train Loss=0.009387262 | Test Loss=0.006456372 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [215/1000] | Train Loss=0.009040630 | Test Loss=0.012277640 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [216/1000] | Train Loss=0.008985227 | Test Loss=0.011055193 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [217/1000] | Train Loss=0.009899203 | Test Loss=0.011491880 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [218/1000] | Train Loss=0.009983163 | Test Loss=0.008966735 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [219/1000] | Train Loss=0.009506866 | Test Loss=0.012910188 | Time=1.67s | LR=1.00e-03\n",
      "Epoch [220/1000] | Train Loss=0.010662508 | Test Loss=0.016918881 | Time=1.63s | LR=1.00e-03\n",
      "Epoch [221/1000] | Train Loss=0.013031515 | Test Loss=0.008284952 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [222/1000] | Train Loss=0.010293285 | Test Loss=0.018586449 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [223/1000] | Train Loss=0.008725396 | Test Loss=0.009077109 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [224/1000] | Train Loss=0.009811476 | Test Loss=0.009899091 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [225/1000] | Train Loss=0.010123812 | Test Loss=0.012349967 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [226/1000] | Train Loss=0.010354900 | Test Loss=0.005515075 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [227/1000] | Train Loss=0.013796168 | Test Loss=0.023704638 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [228/1000] | Train Loss=0.014510186 | Test Loss=0.008930883 | Time=1.58s | LR=1.00e-03\n",
      "Epoch [229/1000] | Train Loss=0.010039835 | Test Loss=0.014190253 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [230/1000] | Train Loss=0.009574046 | Test Loss=0.013398019 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [231/1000] | Train Loss=0.009683912 | Test Loss=0.010740340 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [232/1000] | Train Loss=0.014319896 | Test Loss=0.012330639 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [233/1000] | Train Loss=0.014597493 | Test Loss=0.015419357 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [234/1000] | Train Loss=0.010571083 | Test Loss=0.005998607 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [235/1000] | Train Loss=0.013035742 | Test Loss=0.019205687 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [236/1000] | Train Loss=0.011255915 | Test Loss=0.007476071 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [237/1000] | Train Loss=0.014853228 | Test Loss=0.009798053 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [238/1000] | Train Loss=0.010133093 | Test Loss=0.007524387 | Time=1.59s | LR=1.00e-03\n",
      "Epoch [239/1000] | Train Loss=0.009915308 | Test Loss=0.011216426 | Time=1.44s | LR=1.00e-03\n",
      "Epoch [240/1000] | Train Loss=0.008451843 | Test Loss=0.006826894 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [241/1000] | Train Loss=0.010811124 | Test Loss=0.019705206 | Time=1.78s | LR=1.00e-03\n",
      "Epoch [242/1000] | Train Loss=0.018744766 | Test Loss=0.028739230 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [243/1000] | Train Loss=0.019345279 | Test Loss=0.023248717 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [244/1000] | Train Loss=0.010940438 | Test Loss=0.007139184 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [245/1000] | Train Loss=0.004651311 | Test Loss=0.006738756 | Time=1.80s | LR=5.00e-04\n",
      "Epoch [246/1000] | Train Loss=0.004952674 | Test Loss=0.005485796 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [247/1000] | Train Loss=0.004820728 | Test Loss=0.005753783 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [248/1000] | Train Loss=0.004111154 | Test Loss=0.006552751 | Time=1.80s | LR=5.00e-04\n",
      "Epoch [249/1000] | Train Loss=0.006638076 | Test Loss=0.017585233 | Time=1.80s | LR=5.00e-04\n",
      "Epoch [250/1000] | Train Loss=0.008102331 | Test Loss=0.008338084 | Time=1.78s | LR=5.00e-04\n",
      "Epoch [251/1000] | Train Loss=0.003869395 | Test Loss=0.008228407 | Time=1.76s | LR=5.00e-04\n",
      "Epoch [252/1000] | Train Loss=0.006107310 | Test Loss=0.010701233 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [253/1000] | Train Loss=0.005571680 | Test Loss=0.008951404 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [254/1000] | Train Loss=0.004923180 | Test Loss=0.006443322 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [255/1000] | Train Loss=0.005034020 | Test Loss=0.007950306 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [256/1000] | Train Loss=0.003838269 | Test Loss=0.007927450 | Time=1.61s | LR=5.00e-04\n",
      "Epoch [257/1000] | Train Loss=0.004949025 | Test Loss=0.007828483 | Time=1.59s | LR=5.00e-04\n",
      "Epoch [258/1000] | Train Loss=0.003602091 | Test Loss=0.005110211 | Time=1.78s | LR=5.00e-04\n",
      "Epoch [259/1000] | Train Loss=0.004661274 | Test Loss=0.005732413 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [260/1000] | Train Loss=0.004354290 | Test Loss=0.006506987 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [261/1000] | Train Loss=0.004757305 | Test Loss=0.010369515 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [262/1000] | Train Loss=0.007664856 | Test Loss=0.007498787 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [263/1000] | Train Loss=0.005053780 | Test Loss=0.011978223 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [264/1000] | Train Loss=0.005347833 | Test Loss=0.006716546 | Time=1.81s | LR=5.00e-04\n",
      "Epoch [265/1000] | Train Loss=0.004856655 | Test Loss=0.006201205 | Time=1.80s | LR=5.00e-04\n",
      "Epoch [266/1000] | Train Loss=0.004256435 | Test Loss=0.004861069 | Time=1.80s | LR=5.00e-04\n",
      "Epoch [267/1000] | Train Loss=0.005767566 | Test Loss=0.007679269 | Time=1.79s | LR=5.00e-04\n",
      "Epoch [268/1000] | Train Loss=0.008114210 | Test Loss=0.007712509 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [269/1000] | Train Loss=0.008273947 | Test Loss=0.008184503 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [270/1000] | Train Loss=0.007911842 | Test Loss=0.008211769 | Time=1.78s | LR=5.00e-04\n",
      "Epoch [271/1000] | Train Loss=0.004614591 | Test Loss=0.007125329 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [272/1000] | Train Loss=0.004992995 | Test Loss=0.006666105 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [273/1000] | Train Loss=0.004695534 | Test Loss=0.006026357 | Time=1.59s | LR=5.00e-04\n",
      "Epoch [274/1000] | Train Loss=0.004309446 | Test Loss=0.005533183 | Time=1.59s | LR=5.00e-04\n",
      "Epoch [275/1000] | Train Loss=0.003934974 | Test Loss=0.005057023 | Time=1.59s | LR=5.00e-04\n",
      "Epoch [276/1000] | Train Loss=0.005328283 | Test Loss=0.006108774 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [277/1000] | Train Loss=0.004852713 | Test Loss=0.007050169 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [278/1000] | Train Loss=0.004797000 | Test Loss=0.009593302 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [279/1000] | Train Loss=0.005001409 | Test Loss=0.005674952 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [280/1000] | Train Loss=0.004980199 | Test Loss=0.007516134 | Time=1.76s | LR=5.00e-04\n",
      "Epoch [281/1000] | Train Loss=0.004838164 | Test Loss=0.005294175 | Time=1.81s | LR=5.00e-04\n",
      "Epoch [282/1000] | Train Loss=0.005159906 | Test Loss=0.004771134 | Time=1.79s | LR=5.00e-04\n",
      "Epoch [283/1000] | Train Loss=0.005399353 | Test Loss=0.006813499 | Time=1.79s | LR=5.00e-04\n",
      "Epoch [284/1000] | Train Loss=0.004104132 | Test Loss=0.004912550 | Time=1.78s | LR=5.00e-04\n",
      "Epoch [285/1000] | Train Loss=0.003938031 | Test Loss=0.004747078 | Time=1.78s | LR=5.00e-04\n",
      "Epoch [286/1000] | Train Loss=0.004535353 | Test Loss=0.006276592 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [287/1000] | Train Loss=0.004887426 | Test Loss=0.006878133 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [288/1000] | Train Loss=0.004570683 | Test Loss=0.006727584 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [289/1000] | Train Loss=0.004790989 | Test Loss=0.006987091 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [290/1000] | Train Loss=0.004190181 | Test Loss=0.005570428 | Time=1.61s | LR=5.00e-04\n",
      "Epoch [291/1000] | Train Loss=0.006108760 | Test Loss=0.012869818 | Time=1.59s | LR=5.00e-04\n",
      "Epoch [292/1000] | Train Loss=0.009093952 | Test Loss=0.008446228 | Time=1.59s | LR=5.00e-04\n",
      "Epoch [293/1000] | Train Loss=0.007298711 | Test Loss=0.010078445 | Time=1.60s | LR=5.00e-04\n",
      "Epoch [294/1000] | Train Loss=0.007073690 | Test Loss=0.014322596 | Time=1.70s | LR=5.00e-04\n",
      "Epoch [295/1000] | Train Loss=0.005855039 | Test Loss=0.008821521 | Time=1.82s | LR=5.00e-04\n",
      "Epoch [296/1000] | Train Loss=0.007335057 | Test Loss=0.005544430 | Time=1.81s | LR=5.00e-04\n",
      "Epoch [297/1000] | Train Loss=0.007981779 | Test Loss=0.016018535 | Time=1.77s | LR=5.00e-04\n",
      "Epoch [298/1000] | Train Loss=0.007136343 | Test Loss=0.015172978 | Time=1.80s | LR=5.00e-04\n",
      "Epoch [299/1000] | Train Loss=0.007523652 | Test Loss=0.004468164 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [300/1000] | Train Loss=0.001935575 | Test Loss=0.004661603 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [301/1000] | Train Loss=0.002215147 | Test Loss=0.004906749 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [302/1000] | Train Loss=0.002205084 | Test Loss=0.004398832 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [303/1000] | Train Loss=0.002337400 | Test Loss=0.005015539 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [304/1000] | Train Loss=0.001839723 | Test Loss=0.006412080 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [305/1000] | Train Loss=0.003479043 | Test Loss=0.005130875 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [306/1000] | Train Loss=0.002238937 | Test Loss=0.004790126 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [307/1000] | Train Loss=0.001995295 | Test Loss=0.004682370 | Time=1.65s | LR=2.50e-04\n",
      "Epoch [308/1000] | Train Loss=0.002356057 | Test Loss=0.004561868 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [309/1000] | Train Loss=0.002361238 | Test Loss=0.006208621 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [310/1000] | Train Loss=0.002540573 | Test Loss=0.004379115 | Time=1.60s | LR=2.50e-04\n",
      "Epoch [311/1000] | Train Loss=0.002529034 | Test Loss=0.004329353 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [312/1000] | Train Loss=0.002154304 | Test Loss=0.004599692 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [313/1000] | Train Loss=0.002650811 | Test Loss=0.004871121 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [314/1000] | Train Loss=0.003337140 | Test Loss=0.004828154 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [315/1000] | Train Loss=0.003225535 | Test Loss=0.005628781 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [316/1000] | Train Loss=0.003321780 | Test Loss=0.005981723 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [317/1000] | Train Loss=0.002035020 | Test Loss=0.004428983 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [318/1000] | Train Loss=0.002509685 | Test Loss=0.004437572 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [319/1000] | Train Loss=0.002517852 | Test Loss=0.004967369 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [320/1000] | Train Loss=0.002378296 | Test Loss=0.004823300 | Time=1.76s | LR=2.50e-04\n",
      "Epoch [321/1000] | Train Loss=0.003266126 | Test Loss=0.005496332 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [322/1000] | Train Loss=0.004547771 | Test Loss=0.008116354 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [323/1000] | Train Loss=0.004425282 | Test Loss=0.008184951 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [324/1000] | Train Loss=0.003685424 | Test Loss=0.005429763 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [325/1000] | Train Loss=0.002490175 | Test Loss=0.004436566 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [326/1000] | Train Loss=0.002358598 | Test Loss=0.004296576 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [327/1000] | Train Loss=0.002566951 | Test Loss=0.005455723 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [328/1000] | Train Loss=0.002555611 | Test Loss=0.005825796 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [329/1000] | Train Loss=0.002308327 | Test Loss=0.004882907 | Time=1.60s | LR=2.50e-04\n",
      "Epoch [330/1000] | Train Loss=0.003075807 | Test Loss=0.006515483 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [331/1000] | Train Loss=0.004539238 | Test Loss=0.004940712 | Time=1.68s | LR=2.50e-04\n",
      "Epoch [332/1000] | Train Loss=0.005389344 | Test Loss=0.004886448 | Time=1.76s | LR=2.50e-04\n",
      "Epoch [333/1000] | Train Loss=0.002554405 | Test Loss=0.005091384 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [334/1000] | Train Loss=0.002460880 | Test Loss=0.005085692 | Time=1.81s | LR=2.50e-04\n",
      "Epoch [335/1000] | Train Loss=0.002436109 | Test Loss=0.004447679 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [336/1000] | Train Loss=0.002716991 | Test Loss=0.004224158 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [337/1000] | Train Loss=0.002748584 | Test Loss=0.008979656 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [338/1000] | Train Loss=0.004530673 | Test Loss=0.005465327 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [339/1000] | Train Loss=0.002595369 | Test Loss=0.004442082 | Time=1.83s | LR=2.50e-04\n",
      "Epoch [340/1000] | Train Loss=0.002419281 | Test Loss=0.004457318 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [341/1000] | Train Loss=0.002519995 | Test Loss=0.004527700 | Time=1.82s | LR=2.50e-04\n",
      "Epoch [342/1000] | Train Loss=0.002273848 | Test Loss=0.004357913 | Time=1.62s | LR=2.50e-04\n",
      "Epoch [343/1000] | Train Loss=0.002471091 | Test Loss=0.004262357 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [344/1000] | Train Loss=0.002242549 | Test Loss=0.004305383 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [345/1000] | Train Loss=0.002033445 | Test Loss=0.004164132 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [346/1000] | Train Loss=0.001168695 | Test Loss=0.004793173 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [347/1000] | Train Loss=0.001152206 | Test Loss=0.004116571 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [348/1000] | Train Loss=0.001196921 | Test Loss=0.004635724 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [349/1000] | Train Loss=0.000970812 | Test Loss=0.004060778 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [350/1000] | Train Loss=0.000995356 | Test Loss=0.004151147 | Time=1.71s | LR=1.25e-04\n",
      "Epoch [351/1000] | Train Loss=0.001280656 | Test Loss=0.004060220 | Time=1.83s | LR=1.25e-04\n",
      "Epoch [352/1000] | Train Loss=0.001267635 | Test Loss=0.004369719 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [353/1000] | Train Loss=0.001129107 | Test Loss=0.004374504 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [354/1000] | Train Loss=0.001656477 | Test Loss=0.004418362 | Time=1.81s | LR=1.25e-04\n",
      "Epoch [355/1000] | Train Loss=0.001218244 | Test Loss=0.004021831 | Time=1.78s | LR=1.25e-04\n",
      "Epoch [356/1000] | Train Loss=0.001265531 | Test Loss=0.003960659 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [357/1000] | Train Loss=0.001165155 | Test Loss=0.004539403 | Time=1.78s | LR=1.25e-04\n",
      "Epoch [358/1000] | Train Loss=0.001211996 | Test Loss=0.004469794 | Time=1.77s | LR=1.25e-04\n",
      "Epoch [359/1000] | Train Loss=0.001704641 | Test Loss=0.004339864 | Time=1.77s | LR=1.25e-04\n",
      "Epoch [360/1000] | Train Loss=0.001496744 | Test Loss=0.004010826 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [361/1000] | Train Loss=0.001209549 | Test Loss=0.004281523 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [362/1000] | Train Loss=0.001131935 | Test Loss=0.004270575 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [363/1000] | Train Loss=0.001030986 | Test Loss=0.004080498 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [364/1000] | Train Loss=0.001643044 | Test Loss=0.004047329 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [365/1000] | Train Loss=0.002323779 | Test Loss=0.004387712 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [366/1000] | Train Loss=0.001797392 | Test Loss=0.004381192 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [367/1000] | Train Loss=0.002043901 | Test Loss=0.004725376 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [368/1000] | Train Loss=0.002198511 | Test Loss=0.003970881 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [369/1000] | Train Loss=0.001216820 | Test Loss=0.003922125 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [370/1000] | Train Loss=0.001260287 | Test Loss=0.004533096 | Time=1.83s | LR=1.25e-04\n",
      "Epoch [371/1000] | Train Loss=0.002160160 | Test Loss=0.003883773 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [372/1000] | Train Loss=0.001082141 | Test Loss=0.003911163 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [373/1000] | Train Loss=0.001255242 | Test Loss=0.003959359 | Time=1.77s | LR=1.25e-04\n",
      "Epoch [374/1000] | Train Loss=0.001183984 | Test Loss=0.003959202 | Time=1.81s | LR=1.25e-04\n",
      "Epoch [375/1000] | Train Loss=0.001033170 | Test Loss=0.003918951 | Time=1.81s | LR=1.25e-04\n",
      "Epoch [376/1000] | Train Loss=0.000845718 | Test Loss=0.003964726 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [377/1000] | Train Loss=0.001062122 | Test Loss=0.004244553 | Time=1.71s | LR=1.25e-04\n",
      "Epoch [378/1000] | Train Loss=0.001224326 | Test Loss=0.003920684 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [379/1000] | Train Loss=0.001717178 | Test Loss=0.004576565 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [380/1000] | Train Loss=0.002306726 | Test Loss=0.005763690 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [381/1000] | Train Loss=0.001750017 | Test Loss=0.003802255 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [382/1000] | Train Loss=0.001187276 | Test Loss=0.004476613 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [383/1000] | Train Loss=0.001260431 | Test Loss=0.004279447 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [384/1000] | Train Loss=0.001228685 | Test Loss=0.003890966 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [385/1000] | Train Loss=0.001298870 | Test Loss=0.004330422 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [386/1000] | Train Loss=0.000925459 | Test Loss=0.003876874 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [387/1000] | Train Loss=0.001229409 | Test Loss=0.004187929 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [388/1000] | Train Loss=0.001200225 | Test Loss=0.004499081 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [389/1000] | Train Loss=0.001197943 | Test Loss=0.004186841 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [390/1000] | Train Loss=0.001213427 | Test Loss=0.004128042 | Time=1.83s | LR=1.25e-04\n",
      "Epoch [391/1000] | Train Loss=0.001613426 | Test Loss=0.003839786 | Time=1.77s | LR=1.25e-04\n",
      "Epoch [392/1000] | Train Loss=0.001215231 | Test Loss=0.003837968 | Time=1.81s | LR=1.25e-04\n",
      "Epoch [393/1000] | Train Loss=0.001231510 | Test Loss=0.004087323 | Time=1.80s | LR=1.25e-04\n",
      "Epoch [394/1000] | Train Loss=0.001143299 | Test Loss=0.004342484 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [395/1000] | Train Loss=0.001222715 | Test Loss=0.003956354 | Time=1.69s | LR=1.25e-04\n",
      "Epoch [396/1000] | Train Loss=0.001227424 | Test Loss=0.004481652 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [397/1000] | Train Loss=0.001149895 | Test Loss=0.004665480 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [398/1000] | Train Loss=0.001264758 | Test Loss=0.004070353 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [399/1000] | Train Loss=0.001198743 | Test Loss=0.003749491 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [400/1000] | Train Loss=0.002057917 | Test Loss=0.004349941 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [401/1000] | Train Loss=0.001340445 | Test Loss=0.003802870 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [402/1000] | Train Loss=0.001191823 | Test Loss=0.004026041 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [403/1000] | Train Loss=0.001122306 | Test Loss=0.004129493 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [404/1000] | Train Loss=0.001197432 | Test Loss=0.003788827 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [405/1000] | Train Loss=0.001097157 | Test Loss=0.003974406 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [406/1000] | Train Loss=0.001495739 | Test Loss=0.004074366 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [407/1000] | Train Loss=0.001733241 | Test Loss=0.003740175 | Time=1.71s | LR=1.25e-04\n",
      "Epoch [408/1000] | Train Loss=0.001134854 | Test Loss=0.003788834 | Time=1.82s | LR=1.25e-04\n",
      "Epoch [409/1000] | Train Loss=0.001241364 | Test Loss=0.003728888 | Time=1.76s | LR=1.25e-04\n",
      "Epoch [410/1000] | Train Loss=0.001262343 | Test Loss=0.004714339 | Time=1.81s | LR=1.25e-04\n",
      "Epoch [411/1000] | Train Loss=0.001061974 | Test Loss=0.003775587 | Time=1.80s | LR=1.25e-04\n",
      "Epoch [412/1000] | Train Loss=0.000893998 | Test Loss=0.003669407 | Time=1.80s | LR=1.25e-04\n",
      "Epoch [413/1000] | Train Loss=0.001338508 | Test Loss=0.003977425 | Time=1.71s | LR=1.25e-04\n",
      "Epoch [414/1000] | Train Loss=0.001262235 | Test Loss=0.003746547 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [415/1000] | Train Loss=0.001178333 | Test Loss=0.003616849 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [416/1000] | Train Loss=0.001128844 | Test Loss=0.003782973 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [417/1000] | Train Loss=0.001039446 | Test Loss=0.004457309 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [418/1000] | Train Loss=0.001167209 | Test Loss=0.003641703 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [419/1000] | Train Loss=0.001085392 | Test Loss=0.003656979 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [420/1000] | Train Loss=0.000549257 | Test Loss=0.003675401 | Time=1.60s | LR=6.25e-05\n",
      "Epoch [421/1000] | Train Loss=0.000537867 | Test Loss=0.003779553 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [422/1000] | Train Loss=0.000465883 | Test Loss=0.003640270 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [423/1000] | Train Loss=0.000613402 | Test Loss=0.003744281 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [424/1000] | Train Loss=0.000629723 | Test Loss=0.003924222 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [425/1000] | Train Loss=0.000606939 | Test Loss=0.004044276 | Time=1.60s | LR=6.25e-05\n",
      "Epoch [426/1000] | Train Loss=0.000646267 | Test Loss=0.003868679 | Time=1.64s | LR=6.25e-05\n",
      "Epoch [427/1000] | Train Loss=0.000789748 | Test Loss=0.003804572 | Time=1.77s | LR=6.25e-05\n",
      "Epoch [428/1000] | Train Loss=0.000605876 | Test Loss=0.003589114 | Time=1.80s | LR=6.25e-05\n",
      "Epoch [429/1000] | Train Loss=0.001136047 | Test Loss=0.004098436 | Time=1.79s | LR=6.25e-05\n",
      "Epoch [430/1000] | Train Loss=0.001004283 | Test Loss=0.003706855 | Time=1.78s | LR=6.25e-05\n",
      "Epoch [431/1000] | Train Loss=0.000539734 | Test Loss=0.003668349 | Time=1.76s | LR=6.25e-05\n",
      "Epoch [432/1000] | Train Loss=0.000669386 | Test Loss=0.003950489 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [433/1000] | Train Loss=0.000666752 | Test Loss=0.003610770 | Time=1.64s | LR=6.25e-05\n",
      "Epoch [434/1000] | Train Loss=0.000526075 | Test Loss=0.003670713 | Time=1.50s | LR=6.25e-05\n",
      "Epoch [435/1000] | Train Loss=0.000380783 | Test Loss=0.003669574 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [436/1000] | Train Loss=0.000555832 | Test Loss=0.003512530 | Time=1.54s | LR=6.25e-05\n",
      "Epoch [437/1000] | Train Loss=0.000691365 | Test Loss=0.003814942 | Time=1.44s | LR=6.25e-05\n",
      "Epoch [438/1000] | Train Loss=0.000653752 | Test Loss=0.003565136 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [439/1000] | Train Loss=0.001056466 | Test Loss=0.003616820 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [440/1000] | Train Loss=0.000711589 | Test Loss=0.003575674 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [441/1000] | Train Loss=0.000673160 | Test Loss=0.003723137 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [442/1000] | Train Loss=0.000604785 | Test Loss=0.004038100 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [443/1000] | Train Loss=0.000659817 | Test Loss=0.003570701 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [444/1000] | Train Loss=0.000626875 | Test Loss=0.003619097 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [445/1000] | Train Loss=0.000676454 | Test Loss=0.003739202 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [446/1000] | Train Loss=0.000602221 | Test Loss=0.003593367 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [447/1000] | Train Loss=0.000625140 | Test Loss=0.003676071 | Time=1.37s | LR=6.25e-05\n",
      "Epoch [448/1000] | Train Loss=0.000616669 | Test Loss=0.003583700 | Time=1.38s | LR=6.25e-05\n",
      "Epoch [449/1000] | Train Loss=0.000590315 | Test Loss=0.003537383 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [450/1000] | Train Loss=0.000698412 | Test Loss=0.003544952 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [451/1000] | Train Loss=0.000675939 | Test Loss=0.003718324 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [452/1000] | Train Loss=0.000615533 | Test Loss=0.003705815 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [453/1000] | Train Loss=0.000577118 | Test Loss=0.003620925 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [454/1000] | Train Loss=0.000577632 | Test Loss=0.003573737 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [455/1000] | Train Loss=0.000557073 | Test Loss=0.003551363 | Time=1.55s | LR=6.25e-05\n",
      "Epoch [456/1000] | Train Loss=0.000609396 | Test Loss=0.003577698 | Time=1.43s | LR=6.25e-05\n",
      "Epoch [457/1000] | Train Loss=0.000573123 | Test Loss=0.003764247 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [458/1000] | Train Loss=0.000680732 | Test Loss=0.003716639 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [459/1000] | Train Loss=0.000636730 | Test Loss=0.003964466 | Time=1.53s | LR=6.25e-05\n",
      "Epoch [460/1000] | Train Loss=0.001217533 | Test Loss=0.004039395 | Time=1.48s | LR=6.25e-05\n",
      "Epoch [461/1000] | Train Loss=0.000912238 | Test Loss=0.003684255 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [462/1000] | Train Loss=0.000543323 | Test Loss=0.003560395 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [463/1000] | Train Loss=0.000599201 | Test Loss=0.003524375 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [464/1000] | Train Loss=0.000474169 | Test Loss=0.003459058 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [465/1000] | Train Loss=0.000637131 | Test Loss=0.003474300 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [466/1000] | Train Loss=0.000682912 | Test Loss=0.004189744 | Time=1.40s | LR=6.25e-05\n",
      "Epoch [467/1000] | Train Loss=0.000689209 | Test Loss=0.003790117 | Time=1.54s | LR=6.25e-05\n",
      "Epoch [468/1000] | Train Loss=0.000621140 | Test Loss=0.003634372 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [469/1000] | Train Loss=0.000584799 | Test Loss=0.003530157 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [470/1000] | Train Loss=0.000572113 | Test Loss=0.003856287 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [471/1000] | Train Loss=0.000594916 | Test Loss=0.003536086 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [472/1000] | Train Loss=0.000483739 | Test Loss=0.003531272 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [473/1000] | Train Loss=0.000582835 | Test Loss=0.003468145 | Time=1.36s | LR=6.25e-05\n",
      "Epoch [474/1000] | Train Loss=0.000665343 | Test Loss=0.003493989 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [475/1000] | Train Loss=0.000489138 | Test Loss=0.003484456 | Time=1.35s | LR=6.25e-05\n",
      "Epoch [476/1000] | Train Loss=0.000661172 | Test Loss=0.003491877 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [477/1000] | Train Loss=0.000358638 | Test Loss=0.003468296 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [478/1000] | Train Loss=0.000338608 | Test Loss=0.003554649 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [479/1000] | Train Loss=0.000277409 | Test Loss=0.003588553 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [480/1000] | Train Loss=0.000308663 | Test Loss=0.003604530 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [481/1000] | Train Loss=0.000297405 | Test Loss=0.003559268 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [482/1000] | Train Loss=0.000334079 | Test Loss=0.003612948 | Time=1.41s | LR=3.13e-05\n",
      "Epoch [483/1000] | Train Loss=0.000324161 | Test Loss=0.003545059 | Time=1.56s | LR=3.13e-05\n",
      "Epoch [484/1000] | Train Loss=0.000310002 | Test Loss=0.003581685 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [485/1000] | Train Loss=0.000321895 | Test Loss=0.003562005 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [486/1000] | Train Loss=0.000377614 | Test Loss=0.003614629 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [487/1000] | Train Loss=0.000340453 | Test Loss=0.003600099 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [488/1000] | Train Loss=0.000352555 | Test Loss=0.003556921 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [489/1000] | Train Loss=0.000332298 | Test Loss=0.003573860 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [490/1000] | Train Loss=0.000350540 | Test Loss=0.003543055 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [491/1000] | Train Loss=0.000324963 | Test Loss=0.003500245 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [492/1000] | Train Loss=0.000288383 | Test Loss=0.003513202 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [493/1000] | Train Loss=0.000387784 | Test Loss=0.003496737 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [494/1000] | Train Loss=0.000371757 | Test Loss=0.003480112 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [495/1000] | Train Loss=0.000301391 | Test Loss=0.003480822 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [496/1000] | Train Loss=0.000388420 | Test Loss=0.003706707 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [497/1000] | Train Loss=0.000365141 | Test Loss=0.003665376 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [498/1000] | Train Loss=0.000353157 | Test Loss=0.003482803 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [499/1000] | Train Loss=0.000311058 | Test Loss=0.003489333 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [500/1000] | Train Loss=0.000342875 | Test Loss=0.003538122 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [501/1000] | Train Loss=0.000431627 | Test Loss=0.003626823 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [502/1000] | Train Loss=0.000343787 | Test Loss=0.003447834 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [503/1000] | Train Loss=0.000393868 | Test Loss=0.003517063 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [504/1000] | Train Loss=0.000347169 | Test Loss=0.003418081 | Time=1.64s | LR=3.13e-05\n",
      "Epoch [505/1000] | Train Loss=0.000352897 | Test Loss=0.003555359 | Time=1.50s | LR=3.13e-05\n",
      "Epoch [506/1000] | Train Loss=0.000323387 | Test Loss=0.003497020 | Time=1.60s | LR=3.13e-05\n",
      "Epoch [507/1000] | Train Loss=0.000392709 | Test Loss=0.003431140 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [508/1000] | Train Loss=0.000306462 | Test Loss=0.003475500 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [509/1000] | Train Loss=0.000366026 | Test Loss=0.003528359 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [510/1000] | Train Loss=0.000367427 | Test Loss=0.003520956 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [511/1000] | Train Loss=0.000258259 | Test Loss=0.003489189 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [512/1000] | Train Loss=0.000274278 | Test Loss=0.003608412 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [513/1000] | Train Loss=0.000393697 | Test Loss=0.003463332 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [514/1000] | Train Loss=0.000466842 | Test Loss=0.003464280 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [515/1000] | Train Loss=0.000396050 | Test Loss=0.003617412 | Time=1.42s | LR=3.13e-05\n",
      "Epoch [516/1000] | Train Loss=0.000483975 | Test Loss=0.003454047 | Time=1.65s | LR=3.13e-05\n",
      "Epoch [517/1000] | Train Loss=0.000306806 | Test Loss=0.003480337 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [518/1000] | Train Loss=0.000361526 | Test Loss=0.003462585 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [519/1000] | Train Loss=0.000622375 | Test Loss=0.003413177 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [520/1000] | Train Loss=0.000391247 | Test Loss=0.003415363 | Time=1.35s | LR=3.13e-05\n",
      "Epoch [521/1000] | Train Loss=0.000323266 | Test Loss=0.003597447 | Time=1.63s | LR=3.13e-05\n",
      "Epoch [522/1000] | Train Loss=0.000298184 | Test Loss=0.003412976 | Time=1.49s | LR=3.13e-05\n",
      "Epoch [523/1000] | Train Loss=0.000317321 | Test Loss=0.003438607 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [524/1000] | Train Loss=0.000319051 | Test Loss=0.003462737 | Time=1.56s | LR=3.13e-05\n",
      "Epoch [525/1000] | Train Loss=0.000374996 | Test Loss=0.003378580 | Time=1.42s | LR=3.13e-05\n",
      "Epoch [526/1000] | Train Loss=0.000310850 | Test Loss=0.003421450 | Time=1.45s | LR=3.13e-05\n",
      "Epoch [527/1000] | Train Loss=0.000365074 | Test Loss=0.003437713 | Time=1.65s | LR=3.13e-05\n",
      "Epoch [528/1000] | Train Loss=0.000309428 | Test Loss=0.003402923 | Time=1.58s | LR=3.13e-05\n",
      "Epoch [529/1000] | Train Loss=0.000402742 | Test Loss=0.003396095 | Time=1.41s | LR=3.13e-05\n",
      "Epoch [530/1000] | Train Loss=0.000346612 | Test Loss=0.003545167 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [531/1000] | Train Loss=0.000329631 | Test Loss=0.003685151 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [532/1000] | Train Loss=0.000339878 | Test Loss=0.003437938 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [533/1000] | Train Loss=0.000337356 | Test Loss=0.003388795 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [534/1000] | Train Loss=0.000405169 | Test Loss=0.003519111 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [535/1000] | Train Loss=0.000330812 | Test Loss=0.003349961 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [536/1000] | Train Loss=0.000382390 | Test Loss=0.003380717 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [537/1000] | Train Loss=0.000287324 | Test Loss=0.003415739 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [538/1000] | Train Loss=0.000370633 | Test Loss=0.003518124 | Time=1.37s | LR=3.13e-05\n",
      "Epoch [539/1000] | Train Loss=0.000314632 | Test Loss=0.003397007 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [540/1000] | Train Loss=0.000393214 | Test Loss=0.003352358 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [541/1000] | Train Loss=0.000393434 | Test Loss=0.003381516 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [542/1000] | Train Loss=0.000279964 | Test Loss=0.003495914 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [543/1000] | Train Loss=0.000281394 | Test Loss=0.003463560 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [544/1000] | Train Loss=0.000387307 | Test Loss=0.003474979 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [545/1000] | Train Loss=0.000390958 | Test Loss=0.003399985 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [546/1000] | Train Loss=0.000353703 | Test Loss=0.003499862 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [547/1000] | Train Loss=0.000407739 | Test Loss=0.003484821 | Time=1.59s | LR=3.13e-05\n",
      "Epoch [548/1000] | Train Loss=0.000341673 | Test Loss=0.003350054 | Time=1.39s | LR=3.13e-05\n",
      "Epoch [549/1000] | Train Loss=0.000361866 | Test Loss=0.003473771 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [550/1000] | Train Loss=0.000362559 | Test Loss=0.003455856 | Time=1.36s | LR=3.13e-05\n",
      "Epoch [551/1000] | Train Loss=0.000365792 | Test Loss=0.003472274 | Time=1.53s | LR=3.13e-05\n",
      "Epoch [552/1000] | Train Loss=0.000371890 | Test Loss=0.003348368 | Time=1.45s | LR=1.56e-05\n",
      "Epoch [553/1000] | Train Loss=0.000230008 | Test Loss=0.003383310 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [554/1000] | Train Loss=0.000222005 | Test Loss=0.003416515 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [555/1000] | Train Loss=0.000223148 | Test Loss=0.003374420 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [556/1000] | Train Loss=0.000235525 | Test Loss=0.003401802 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [557/1000] | Train Loss=0.000240200 | Test Loss=0.003363329 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [558/1000] | Train Loss=0.000238973 | Test Loss=0.003394892 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [559/1000] | Train Loss=0.000232533 | Test Loss=0.003415301 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [560/1000] | Train Loss=0.000245757 | Test Loss=0.003384563 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [561/1000] | Train Loss=0.000255440 | Test Loss=0.003389647 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [562/1000] | Train Loss=0.000256026 | Test Loss=0.003395406 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [563/1000] | Train Loss=0.000229108 | Test Loss=0.003375190 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [564/1000] | Train Loss=0.000288588 | Test Loss=0.003392379 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [565/1000] | Train Loss=0.000234125 | Test Loss=0.003373067 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [566/1000] | Train Loss=0.000272886 | Test Loss=0.003402011 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [567/1000] | Train Loss=0.000264655 | Test Loss=0.003428921 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [568/1000] | Train Loss=0.000231129 | Test Loss=0.003395159 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [569/1000] | Train Loss=0.000231728 | Test Loss=0.003346373 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [570/1000] | Train Loss=0.000264103 | Test Loss=0.003382215 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [571/1000] | Train Loss=0.000250705 | Test Loss=0.003362463 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [572/1000] | Train Loss=0.000230620 | Test Loss=0.003440412 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [573/1000] | Train Loss=0.000260461 | Test Loss=0.003352632 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [574/1000] | Train Loss=0.000267592 | Test Loss=0.003398859 | Time=1.39s | LR=1.56e-05\n",
      "Epoch [575/1000] | Train Loss=0.000280291 | Test Loss=0.003328528 | Time=1.58s | LR=1.56e-05\n",
      "Epoch [576/1000] | Train Loss=0.000230215 | Test Loss=0.003366344 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [577/1000] | Train Loss=0.000272499 | Test Loss=0.003349008 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [578/1000] | Train Loss=0.000237285 | Test Loss=0.003399077 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [579/1000] | Train Loss=0.000227243 | Test Loss=0.003391878 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [580/1000] | Train Loss=0.000253271 | Test Loss=0.003362102 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [581/1000] | Train Loss=0.000233990 | Test Loss=0.003385320 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [582/1000] | Train Loss=0.000233451 | Test Loss=0.003363958 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [583/1000] | Train Loss=0.000244974 | Test Loss=0.003452742 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [584/1000] | Train Loss=0.000267995 | Test Loss=0.003425711 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [585/1000] | Train Loss=0.000259795 | Test Loss=0.003382839 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [586/1000] | Train Loss=0.000255706 | Test Loss=0.003340278 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [587/1000] | Train Loss=0.000256110 | Test Loss=0.003350447 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [588/1000] | Train Loss=0.000230312 | Test Loss=0.003382233 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [589/1000] | Train Loss=0.000229736 | Test Loss=0.003368825 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [590/1000] | Train Loss=0.000421055 | Test Loss=0.003397709 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [591/1000] | Train Loss=0.000301201 | Test Loss=0.003416841 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [592/1000] | Train Loss=0.000233991 | Test Loss=0.003326104 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [593/1000] | Train Loss=0.000266549 | Test Loss=0.003351182 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [594/1000] | Train Loss=0.000224918 | Test Loss=0.003343144 | Time=1.36s | LR=1.56e-05\n",
      "Epoch [595/1000] | Train Loss=0.000227758 | Test Loss=0.003370036 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [596/1000] | Train Loss=0.000213555 | Test Loss=0.003352375 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [597/1000] | Train Loss=0.000211186 | Test Loss=0.003356866 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [598/1000] | Train Loss=0.000210053 | Test Loss=0.003361600 | Time=1.59s | LR=7.81e-06\n",
      "Epoch [599/1000] | Train Loss=0.000216398 | Test Loss=0.003338917 | Time=1.40s | LR=7.81e-06\n",
      "Epoch [600/1000] | Train Loss=0.000214938 | Test Loss=0.003349560 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [601/1000] | Train Loss=0.000214019 | Test Loss=0.003362640 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [602/1000] | Train Loss=0.000214648 | Test Loss=0.003334695 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [603/1000] | Train Loss=0.000231142 | Test Loss=0.003343926 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [604/1000] | Train Loss=0.000222407 | Test Loss=0.003339018 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [605/1000] | Train Loss=0.000222961 | Test Loss=0.003345521 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [606/1000] | Train Loss=0.000217656 | Test Loss=0.003317799 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [607/1000] | Train Loss=0.000217930 | Test Loss=0.003338882 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [608/1000] | Train Loss=0.000219412 | Test Loss=0.003367080 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [609/1000] | Train Loss=0.000213795 | Test Loss=0.003341729 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [610/1000] | Train Loss=0.000212092 | Test Loss=0.003360368 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [611/1000] | Train Loss=0.000218818 | Test Loss=0.003374372 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [612/1000] | Train Loss=0.000218496 | Test Loss=0.003353539 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [613/1000] | Train Loss=0.000218658 | Test Loss=0.003338963 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [614/1000] | Train Loss=0.000221167 | Test Loss=0.003334275 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [615/1000] | Train Loss=0.000214720 | Test Loss=0.003359551 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [616/1000] | Train Loss=0.000230747 | Test Loss=0.003353884 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [617/1000] | Train Loss=0.000219508 | Test Loss=0.003368140 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [618/1000] | Train Loss=0.000221568 | Test Loss=0.003360862 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [619/1000] | Train Loss=0.000211620 | Test Loss=0.003324649 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [620/1000] | Train Loss=0.000216650 | Test Loss=0.003344871 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [621/1000] | Train Loss=0.000218518 | Test Loss=0.003363817 | Time=1.49s | LR=7.81e-06\n",
      "Epoch [622/1000] | Train Loss=0.000212027 | Test Loss=0.003367066 | Time=1.49s | LR=7.81e-06\n",
      "Epoch [623/1000] | Train Loss=0.000213604 | Test Loss=0.003378316 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [624/1000] | Train Loss=0.000235795 | Test Loss=0.003334516 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [625/1000] | Train Loss=0.000212414 | Test Loss=0.003368193 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [626/1000] | Train Loss=0.000220869 | Test Loss=0.003327916 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [627/1000] | Train Loss=0.000215934 | Test Loss=0.003399183 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [628/1000] | Train Loss=0.000221322 | Test Loss=0.003336046 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [629/1000] | Train Loss=0.000214213 | Test Loss=0.003335948 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [630/1000] | Train Loss=0.000215222 | Test Loss=0.003354793 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [631/1000] | Train Loss=0.000213648 | Test Loss=0.003365338 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [632/1000] | Train Loss=0.000220457 | Test Loss=0.003313592 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [633/1000] | Train Loss=0.000225945 | Test Loss=0.003347327 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [634/1000] | Train Loss=0.000212160 | Test Loss=0.003336137 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [635/1000] | Train Loss=0.000216998 | Test Loss=0.003338126 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [636/1000] | Train Loss=0.000210044 | Test Loss=0.003354810 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [637/1000] | Train Loss=0.000213196 | Test Loss=0.003367583 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [638/1000] | Train Loss=0.000218527 | Test Loss=0.003327474 | Time=1.36s | LR=7.81e-06\n",
      "Epoch [639/1000] | Train Loss=0.000220695 | Test Loss=0.003346018 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [640/1000] | Train Loss=0.000203672 | Test Loss=0.003327104 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [641/1000] | Train Loss=0.000204953 | Test Loss=0.003341408 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [642/1000] | Train Loss=0.000208998 | Test Loss=0.003335881 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [643/1000] | Train Loss=0.000205290 | Test Loss=0.003326448 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [644/1000] | Train Loss=0.000207512 | Test Loss=0.003332323 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [645/1000] | Train Loss=0.000205773 | Test Loss=0.003340375 | Time=1.64s | LR=3.91e-06\n",
      "Epoch [646/1000] | Train Loss=0.000204800 | Test Loss=0.003325133 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [647/1000] | Train Loss=0.000207011 | Test Loss=0.003335239 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [648/1000] | Train Loss=0.000210420 | Test Loss=0.003338992 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [649/1000] | Train Loss=0.000205246 | Test Loss=0.003339615 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [650/1000] | Train Loss=0.000205055 | Test Loss=0.003346080 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [651/1000] | Train Loss=0.000208166 | Test Loss=0.003329869 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [652/1000] | Train Loss=0.000203193 | Test Loss=0.003318851 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [653/1000] | Train Loss=0.000208358 | Test Loss=0.003346598 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [654/1000] | Train Loss=0.000206485 | Test Loss=0.003338385 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [655/1000] | Train Loss=0.000205337 | Test Loss=0.003319001 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [656/1000] | Train Loss=0.000210192 | Test Loss=0.003335430 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [657/1000] | Train Loss=0.000207884 | Test Loss=0.003325784 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [658/1000] | Train Loss=0.000208247 | Test Loss=0.003339145 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [659/1000] | Train Loss=0.000202507 | Test Loss=0.003335764 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [660/1000] | Train Loss=0.000204213 | Test Loss=0.003307598 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [661/1000] | Train Loss=0.000205706 | Test Loss=0.003339180 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [662/1000] | Train Loss=0.000205090 | Test Loss=0.003314880 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [663/1000] | Train Loss=0.000204312 | Test Loss=0.003339201 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [664/1000] | Train Loss=0.000207251 | Test Loss=0.003339382 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [665/1000] | Train Loss=0.000204497 | Test Loss=0.003338781 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [666/1000] | Train Loss=0.000208760 | Test Loss=0.003301746 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [667/1000] | Train Loss=0.000208044 | Test Loss=0.003336674 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [668/1000] | Train Loss=0.000211482 | Test Loss=0.003317502 | Time=1.55s | LR=3.91e-06\n",
      "Epoch [669/1000] | Train Loss=0.000201945 | Test Loss=0.003334619 | Time=1.43s | LR=3.91e-06\n",
      "Epoch [670/1000] | Train Loss=0.000205383 | Test Loss=0.003306363 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [671/1000] | Train Loss=0.000207033 | Test Loss=0.003325767 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [672/1000] | Train Loss=0.000205832 | Test Loss=0.003337006 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [673/1000] | Train Loss=0.000206551 | Test Loss=0.003320929 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [674/1000] | Train Loss=0.000204762 | Test Loss=0.003320612 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [675/1000] | Train Loss=0.000205713 | Test Loss=0.003343677 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [676/1000] | Train Loss=0.000203759 | Test Loss=0.003310303 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [677/1000] | Train Loss=0.000203936 | Test Loss=0.003314763 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [678/1000] | Train Loss=0.000209373 | Test Loss=0.003336367 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [679/1000] | Train Loss=0.000209489 | Test Loss=0.003332639 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [680/1000] | Train Loss=0.000207168 | Test Loss=0.003323076 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [681/1000] | Train Loss=0.000204227 | Test Loss=0.003317717 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [682/1000] | Train Loss=0.000202502 | Test Loss=0.003322644 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [683/1000] | Train Loss=0.000207973 | Test Loss=0.003313838 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [684/1000] | Train Loss=0.000209742 | Test Loss=0.003313557 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [685/1000] | Train Loss=0.000207089 | Test Loss=0.003323447 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [686/1000] | Train Loss=0.000206777 | Test Loss=0.003319289 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [687/1000] | Train Loss=0.000204596 | Test Loss=0.003317307 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [688/1000] | Train Loss=0.000205558 | Test Loss=0.003302506 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [689/1000] | Train Loss=0.000203879 | Test Loss=0.003306698 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [690/1000] | Train Loss=0.000204861 | Test Loss=0.003333751 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [691/1000] | Train Loss=0.000209200 | Test Loss=0.003317095 | Time=1.44s | LR=3.91e-06\n",
      "Epoch [692/1000] | Train Loss=0.000206182 | Test Loss=0.003326968 | Time=1.54s | LR=3.91e-06\n",
      "Epoch [693/1000] | Train Loss=0.000201201 | Test Loss=0.003313205 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [694/1000] | Train Loss=0.000210107 | Test Loss=0.003303285 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [695/1000] | Train Loss=0.000207370 | Test Loss=0.003296423 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [696/1000] | Train Loss=0.000207846 | Test Loss=0.003318019 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [697/1000] | Train Loss=0.000205648 | Test Loss=0.003313250 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [698/1000] | Train Loss=0.000202802 | Test Loss=0.003322047 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [699/1000] | Train Loss=0.000206106 | Test Loss=0.003303726 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [700/1000] | Train Loss=0.000207386 | Test Loss=0.003317468 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [701/1000] | Train Loss=0.000203778 | Test Loss=0.003308429 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [702/1000] | Train Loss=0.000200736 | Test Loss=0.003307767 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [703/1000] | Train Loss=0.000203483 | Test Loss=0.003316907 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [704/1000] | Train Loss=0.000201277 | Test Loss=0.003295538 | Time=1.47s | LR=3.91e-06\n",
      "Epoch [705/1000] | Train Loss=0.000204568 | Test Loss=0.003304698 | Time=1.56s | LR=3.91e-06\n",
      "Epoch [706/1000] | Train Loss=0.000212762 | Test Loss=0.003301323 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [707/1000] | Train Loss=0.000206200 | Test Loss=0.003299554 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [708/1000] | Train Loss=0.000204944 | Test Loss=0.003306618 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [709/1000] | Train Loss=0.000212110 | Test Loss=0.003294296 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [710/1000] | Train Loss=0.000203124 | Test Loss=0.003293667 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [711/1000] | Train Loss=0.000201083 | Test Loss=0.003308974 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [712/1000] | Train Loss=0.000200270 | Test Loss=0.003291118 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [713/1000] | Train Loss=0.000202856 | Test Loss=0.003298152 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [714/1000] | Train Loss=0.000203000 | Test Loss=0.003302818 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [715/1000] | Train Loss=0.000202736 | Test Loss=0.003295851 | Time=1.62s | LR=3.91e-06\n",
      "Epoch [716/1000] | Train Loss=0.000209202 | Test Loss=0.003316606 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [717/1000] | Train Loss=0.000205875 | Test Loss=0.003287264 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [718/1000] | Train Loss=0.000202187 | Test Loss=0.003300121 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [719/1000] | Train Loss=0.000205746 | Test Loss=0.003300729 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [720/1000] | Train Loss=0.000205491 | Test Loss=0.003308410 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [721/1000] | Train Loss=0.000204310 | Test Loss=0.003288148 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [722/1000] | Train Loss=0.000203524 | Test Loss=0.003309959 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [723/1000] | Train Loss=0.000202323 | Test Loss=0.003282229 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [724/1000] | Train Loss=0.000207658 | Test Loss=0.003305157 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [725/1000] | Train Loss=0.000199247 | Test Loss=0.003293624 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [726/1000] | Train Loss=0.000202763 | Test Loss=0.003285557 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [727/1000] | Train Loss=0.000203135 | Test Loss=0.003309706 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [728/1000] | Train Loss=0.000203374 | Test Loss=0.003298111 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [729/1000] | Train Loss=0.000200350 | Test Loss=0.003297223 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [730/1000] | Train Loss=0.000204585 | Test Loss=0.003307189 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [731/1000] | Train Loss=0.000201116 | Test Loss=0.003298597 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [732/1000] | Train Loss=0.000204756 | Test Loss=0.003297404 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [733/1000] | Train Loss=0.000202482 | Test Loss=0.003297319 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [734/1000] | Train Loss=0.000205143 | Test Loss=0.003297009 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [735/1000] | Train Loss=0.000202714 | Test Loss=0.003317391 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [736/1000] | Train Loss=0.000203843 | Test Loss=0.003294116 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [737/1000] | Train Loss=0.000206231 | Test Loss=0.003293355 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [738/1000] | Train Loss=0.000202374 | Test Loss=0.003292698 | Time=1.57s | LR=3.91e-06\n",
      "Epoch [739/1000] | Train Loss=0.000201436 | Test Loss=0.003303785 | Time=1.42s | LR=3.91e-06\n",
      "Epoch [740/1000] | Train Loss=0.000201834 | Test Loss=0.003279864 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [741/1000] | Train Loss=0.000206454 | Test Loss=0.003305823 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [742/1000] | Train Loss=0.000200301 | Test Loss=0.003302766 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [743/1000] | Train Loss=0.000203508 | Test Loss=0.003291848 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [744/1000] | Train Loss=0.000212902 | Test Loss=0.003321834 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [745/1000] | Train Loss=0.000205655 | Test Loss=0.003306963 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [746/1000] | Train Loss=0.000205230 | Test Loss=0.003290260 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [747/1000] | Train Loss=0.000203363 | Test Loss=0.003301629 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [748/1000] | Train Loss=0.000202193 | Test Loss=0.003297759 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [749/1000] | Train Loss=0.000201369 | Test Loss=0.003299011 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [750/1000] | Train Loss=0.000203651 | Test Loss=0.003277735 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [751/1000] | Train Loss=0.000201773 | Test Loss=0.003297623 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [752/1000] | Train Loss=0.000203003 | Test Loss=0.003305303 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [753/1000] | Train Loss=0.000201506 | Test Loss=0.003310373 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [754/1000] | Train Loss=0.000198808 | Test Loss=0.003284529 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [755/1000] | Train Loss=0.000208061 | Test Loss=0.003280737 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [756/1000] | Train Loss=0.000202755 | Test Loss=0.003279875 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [757/1000] | Train Loss=0.000205149 | Test Loss=0.003282523 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [758/1000] | Train Loss=0.000202476 | Test Loss=0.003307652 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [759/1000] | Train Loss=0.000198877 | Test Loss=0.003298140 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [760/1000] | Train Loss=0.000202281 | Test Loss=0.003270829 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [761/1000] | Train Loss=0.000201535 | Test Loss=0.003298097 | Time=1.45s | LR=3.91e-06\n",
      "Epoch [762/1000] | Train Loss=0.000205837 | Test Loss=0.003282140 | Time=1.52s | LR=3.91e-06\n",
      "Epoch [763/1000] | Train Loss=0.000202186 | Test Loss=0.003289445 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [764/1000] | Train Loss=0.000200341 | Test Loss=0.003302345 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [765/1000] | Train Loss=0.000200894 | Test Loss=0.003282374 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [766/1000] | Train Loss=0.000204196 | Test Loss=0.003296852 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [767/1000] | Train Loss=0.000200510 | Test Loss=0.003301057 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [768/1000] | Train Loss=0.000203905 | Test Loss=0.003301816 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [769/1000] | Train Loss=0.000202876 | Test Loss=0.003281832 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [770/1000] | Train Loss=0.000205254 | Test Loss=0.003288716 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [771/1000] | Train Loss=0.000200922 | Test Loss=0.003270726 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [772/1000] | Train Loss=0.000200241 | Test Loss=0.003257940 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [773/1000] | Train Loss=0.000208279 | Test Loss=0.003271560 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [774/1000] | Train Loss=0.000201605 | Test Loss=0.003276515 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [775/1000] | Train Loss=0.000199282 | Test Loss=0.003289040 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [776/1000] | Train Loss=0.000202456 | Test Loss=0.003273057 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [777/1000] | Train Loss=0.000199189 | Test Loss=0.003293107 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [778/1000] | Train Loss=0.000200813 | Test Loss=0.003283452 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [779/1000] | Train Loss=0.000199931 | Test Loss=0.003285655 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [780/1000] | Train Loss=0.000200739 | Test Loss=0.003314555 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [781/1000] | Train Loss=0.000204835 | Test Loss=0.003271863 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [782/1000] | Train Loss=0.000200504 | Test Loss=0.003282861 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [783/1000] | Train Loss=0.000200298 | Test Loss=0.003286381 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [784/1000] | Train Loss=0.000201558 | Test Loss=0.003283720 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [785/1000] | Train Loss=0.000198485 | Test Loss=0.003280161 | Time=1.62s | LR=3.91e-06\n",
      "Epoch [786/1000] | Train Loss=0.000203257 | Test Loss=0.003294820 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [787/1000] | Train Loss=0.000198460 | Test Loss=0.003290974 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [788/1000] | Train Loss=0.000204111 | Test Loss=0.003282736 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [789/1000] | Train Loss=0.000201971 | Test Loss=0.003279520 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [790/1000] | Train Loss=0.000205736 | Test Loss=0.003317384 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [791/1000] | Train Loss=0.000204272 | Test Loss=0.003288500 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [792/1000] | Train Loss=0.000198935 | Test Loss=0.003290619 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [793/1000] | Train Loss=0.000202676 | Test Loss=0.003283493 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [794/1000] | Train Loss=0.000199718 | Test Loss=0.003270405 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [795/1000] | Train Loss=0.000207325 | Test Loss=0.003287696 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [796/1000] | Train Loss=0.000196832 | Test Loss=0.003298685 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [797/1000] | Train Loss=0.000203180 | Test Loss=0.003280805 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [798/1000] | Train Loss=0.000197653 | Test Loss=0.003295686 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [799/1000] | Train Loss=0.000201566 | Test Loss=0.003287389 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [800/1000] | Train Loss=0.000196200 | Test Loss=0.003268785 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [801/1000] | Train Loss=0.000200855 | Test Loss=0.003259319 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [802/1000] | Train Loss=0.000200807 | Test Loss=0.003307662 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [803/1000] | Train Loss=0.000198887 | Test Loss=0.003286303 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [804/1000] | Train Loss=0.000198671 | Test Loss=0.003284117 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [805/1000] | Train Loss=0.000199832 | Test Loss=0.003251865 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [806/1000] | Train Loss=0.000199820 | Test Loss=0.003259479 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [807/1000] | Train Loss=0.000205486 | Test Loss=0.003279897 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [808/1000] | Train Loss=0.000199881 | Test Loss=0.003284926 | Time=1.53s | LR=3.91e-06\n",
      "Epoch [809/1000] | Train Loss=0.000199439 | Test Loss=0.003262786 | Time=1.46s | LR=3.91e-06\n",
      "Epoch [810/1000] | Train Loss=0.000197161 | Test Loss=0.003286177 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [811/1000] | Train Loss=0.000198212 | Test Loss=0.003282114 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [812/1000] | Train Loss=0.000203952 | Test Loss=0.003279916 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [813/1000] | Train Loss=0.000202926 | Test Loss=0.003290739 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [814/1000] | Train Loss=0.000198025 | Test Loss=0.003278348 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [815/1000] | Train Loss=0.000203933 | Test Loss=0.003277815 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [816/1000] | Train Loss=0.000199207 | Test Loss=0.003262984 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [817/1000] | Train Loss=0.000197599 | Test Loss=0.003283253 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [818/1000] | Train Loss=0.000197744 | Test Loss=0.003241904 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [819/1000] | Train Loss=0.000199177 | Test Loss=0.003284768 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [820/1000] | Train Loss=0.000200657 | Test Loss=0.003260872 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [821/1000] | Train Loss=0.000196665 | Test Loss=0.003271955 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [822/1000] | Train Loss=0.000199231 | Test Loss=0.003290888 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [823/1000] | Train Loss=0.000203647 | Test Loss=0.003278426 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [824/1000] | Train Loss=0.000200144 | Test Loss=0.003269702 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [825/1000] | Train Loss=0.000197258 | Test Loss=0.003272732 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [826/1000] | Train Loss=0.000205865 | Test Loss=0.003294399 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [827/1000] | Train Loss=0.000199227 | Test Loss=0.003281530 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [828/1000] | Train Loss=0.000195499 | Test Loss=0.003268258 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [829/1000] | Train Loss=0.000199273 | Test Loss=0.003289642 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [830/1000] | Train Loss=0.000200819 | Test Loss=0.003254931 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [831/1000] | Train Loss=0.000203267 | Test Loss=0.003266151 | Time=1.39s | LR=3.91e-06\n",
      "Epoch [832/1000] | Train Loss=0.000200523 | Test Loss=0.003270111 | Time=1.58s | LR=3.91e-06\n",
      "Epoch [833/1000] | Train Loss=0.000199410 | Test Loss=0.003267042 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [834/1000] | Train Loss=0.000196038 | Test Loss=0.003268884 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [835/1000] | Train Loss=0.000195439 | Test Loss=0.003264177 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [836/1000] | Train Loss=0.000205616 | Test Loss=0.003264882 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [837/1000] | Train Loss=0.000199662 | Test Loss=0.003264465 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [838/1000] | Train Loss=0.000196830 | Test Loss=0.003271080 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [839/1000] | Train Loss=0.000197061 | Test Loss=0.003255914 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [840/1000] | Train Loss=0.000200509 | Test Loss=0.003257024 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [841/1000] | Train Loss=0.000198066 | Test Loss=0.003264914 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [842/1000] | Train Loss=0.000199986 | Test Loss=0.003287230 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [843/1000] | Train Loss=0.000196973 | Test Loss=0.003250439 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [844/1000] | Train Loss=0.000199107 | Test Loss=0.003281315 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [845/1000] | Train Loss=0.000196537 | Test Loss=0.003238244 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [846/1000] | Train Loss=0.000201783 | Test Loss=0.003274635 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [847/1000] | Train Loss=0.000197457 | Test Loss=0.003271997 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [848/1000] | Train Loss=0.000199383 | Test Loss=0.003263315 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [849/1000] | Train Loss=0.000201701 | Test Loss=0.003267056 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [850/1000] | Train Loss=0.000198038 | Test Loss=0.003251867 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [851/1000] | Train Loss=0.000198724 | Test Loss=0.003284009 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [852/1000] | Train Loss=0.000196679 | Test Loss=0.003269030 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [853/1000] | Train Loss=0.000198293 | Test Loss=0.003259973 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [854/1000] | Train Loss=0.000199574 | Test Loss=0.003278740 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [855/1000] | Train Loss=0.000198235 | Test Loss=0.003280262 | Time=1.59s | LR=3.91e-06\n",
      "Epoch [856/1000] | Train Loss=0.000199248 | Test Loss=0.003264193 | Time=1.40s | LR=3.91e-06\n",
      "Epoch [857/1000] | Train Loss=0.000198503 | Test Loss=0.003259433 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [858/1000] | Train Loss=0.000199029 | Test Loss=0.003257496 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [859/1000] | Train Loss=0.000199490 | Test Loss=0.003272021 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [860/1000] | Train Loss=0.000197119 | Test Loss=0.003252502 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [861/1000] | Train Loss=0.000203743 | Test Loss=0.003283649 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [862/1000] | Train Loss=0.000199243 | Test Loss=0.003257535 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [863/1000] | Train Loss=0.000198729 | Test Loss=0.003267034 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [864/1000] | Train Loss=0.000196973 | Test Loss=0.003255217 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [865/1000] | Train Loss=0.000197698 | Test Loss=0.003256603 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [866/1000] | Train Loss=0.000196374 | Test Loss=0.003247640 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [867/1000] | Train Loss=0.000201954 | Test Loss=0.003272729 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [868/1000] | Train Loss=0.000197586 | Test Loss=0.003252718 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [869/1000] | Train Loss=0.000196662 | Test Loss=0.003266038 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [870/1000] | Train Loss=0.000197076 | Test Loss=0.003251057 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [871/1000] | Train Loss=0.000194183 | Test Loss=0.003269831 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [872/1000] | Train Loss=0.000201381 | Test Loss=0.003255630 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [873/1000] | Train Loss=0.000196314 | Test Loss=0.003261839 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [874/1000] | Train Loss=0.000203118 | Test Loss=0.003250504 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [875/1000] | Train Loss=0.000202935 | Test Loss=0.003248034 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [876/1000] | Train Loss=0.000199061 | Test Loss=0.003264779 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [877/1000] | Train Loss=0.000194020 | Test Loss=0.003244225 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [878/1000] | Train Loss=0.000196838 | Test Loss=0.003264287 | Time=1.49s | LR=3.91e-06\n",
      "Epoch [879/1000] | Train Loss=0.000197369 | Test Loss=0.003236431 | Time=1.50s | LR=3.91e-06\n",
      "Epoch [880/1000] | Train Loss=0.000196058 | Test Loss=0.003253084 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [881/1000] | Train Loss=0.000197274 | Test Loss=0.003243130 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [882/1000] | Train Loss=0.000202404 | Test Loss=0.003232541 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [883/1000] | Train Loss=0.000197364 | Test Loss=0.003263010 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [884/1000] | Train Loss=0.000197118 | Test Loss=0.003271654 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [885/1000] | Train Loss=0.000194787 | Test Loss=0.003240973 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [886/1000] | Train Loss=0.000200142 | Test Loss=0.003243065 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [887/1000] | Train Loss=0.000193445 | Test Loss=0.003244684 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [888/1000] | Train Loss=0.000197693 | Test Loss=0.003225202 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [889/1000] | Train Loss=0.000199921 | Test Loss=0.003238820 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [890/1000] | Train Loss=0.000196899 | Test Loss=0.003251472 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [891/1000] | Train Loss=0.000197019 | Test Loss=0.003237043 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [892/1000] | Train Loss=0.000195910 | Test Loss=0.003244106 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [893/1000] | Train Loss=0.000195871 | Test Loss=0.003239861 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [894/1000] | Train Loss=0.000193212 | Test Loss=0.003239634 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [895/1000] | Train Loss=0.000192709 | Test Loss=0.003252970 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [896/1000] | Train Loss=0.000198710 | Test Loss=0.003236956 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [897/1000] | Train Loss=0.000197854 | Test Loss=0.003244574 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [898/1000] | Train Loss=0.000194008 | Test Loss=0.003228570 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [899/1000] | Train Loss=0.000195138 | Test Loss=0.003243866 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [900/1000] | Train Loss=0.000198470 | Test Loss=0.003239529 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [901/1000] | Train Loss=0.000197403 | Test Loss=0.003246364 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [902/1000] | Train Loss=0.000196754 | Test Loss=0.003242333 | Time=1.64s | LR=3.91e-06\n",
      "Epoch [903/1000] | Train Loss=0.000196302 | Test Loss=0.003224851 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [904/1000] | Train Loss=0.000199267 | Test Loss=0.003245918 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [905/1000] | Train Loss=0.000196554 | Test Loss=0.003232384 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [906/1000] | Train Loss=0.000198196 | Test Loss=0.003227424 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [907/1000] | Train Loss=0.000202768 | Test Loss=0.003219013 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [908/1000] | Train Loss=0.000204531 | Test Loss=0.003236495 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [909/1000] | Train Loss=0.000196375 | Test Loss=0.003237423 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [910/1000] | Train Loss=0.000195827 | Test Loss=0.003230436 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [911/1000] | Train Loss=0.000197367 | Test Loss=0.003248157 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [912/1000] | Train Loss=0.000194385 | Test Loss=0.003243243 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [913/1000] | Train Loss=0.000199441 | Test Loss=0.003226482 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [914/1000] | Train Loss=0.000195154 | Test Loss=0.003222984 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [915/1000] | Train Loss=0.000196795 | Test Loss=0.003224583 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [916/1000] | Train Loss=0.000197265 | Test Loss=0.003231318 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [917/1000] | Train Loss=0.000199281 | Test Loss=0.003228857 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [918/1000] | Train Loss=0.000194455 | Test Loss=0.003219773 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [919/1000] | Train Loss=0.000195645 | Test Loss=0.003223399 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [920/1000] | Train Loss=0.000197561 | Test Loss=0.003237764 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [921/1000] | Train Loss=0.000199733 | Test Loss=0.003234328 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [922/1000] | Train Loss=0.000195763 | Test Loss=0.003237977 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [923/1000] | Train Loss=0.000197147 | Test Loss=0.003201342 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [924/1000] | Train Loss=0.000197385 | Test Loss=0.003239901 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [925/1000] | Train Loss=0.000196679 | Test Loss=0.003230429 | Time=1.55s | LR=3.91e-06\n",
      "Epoch [926/1000] | Train Loss=0.000194919 | Test Loss=0.003208272 | Time=1.43s | LR=3.91e-06\n",
      "Epoch [927/1000] | Train Loss=0.000194247 | Test Loss=0.003238561 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [928/1000] | Train Loss=0.000199332 | Test Loss=0.003216471 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [929/1000] | Train Loss=0.000198261 | Test Loss=0.003223131 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [930/1000] | Train Loss=0.000196519 | Test Loss=0.003241655 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [931/1000] | Train Loss=0.000195602 | Test Loss=0.003246094 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [932/1000] | Train Loss=0.000196274 | Test Loss=0.003216364 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [933/1000] | Train Loss=0.000198299 | Test Loss=0.003209416 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [934/1000] | Train Loss=0.000198385 | Test Loss=0.003226853 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [935/1000] | Train Loss=0.000193550 | Test Loss=0.003228984 | Time=1.36s | LR=3.91e-06\n",
      "Epoch [936/1000] | Train Loss=0.000201053 | Test Loss=0.003215495 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [937/1000] | Train Loss=0.000190733 | Test Loss=0.003225285 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [938/1000] | Train Loss=0.000191545 | Test Loss=0.003223676 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [939/1000] | Train Loss=0.000191032 | Test Loss=0.003213588 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [940/1000] | Train Loss=0.000191606 | Test Loss=0.003219081 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [941/1000] | Train Loss=0.000192755 | Test Loss=0.003228611 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [942/1000] | Train Loss=0.000193250 | Test Loss=0.003217950 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [943/1000] | Train Loss=0.000194467 | Test Loss=0.003229836 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [944/1000] | Train Loss=0.000194933 | Test Loss=0.003220807 | Time=1.51s | LR=1.95e-06\n",
      "Epoch [945/1000] | Train Loss=0.000190955 | Test Loss=0.003216053 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [946/1000] | Train Loss=0.000194173 | Test Loss=0.003213054 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [947/1000] | Train Loss=0.000192419 | Test Loss=0.003236068 | Time=1.36s | LR=1.95e-06\n",
      "Epoch [948/1000] | Train Loss=0.000191873 | Test Loss=0.003210621 | Time=1.50s | LR=1.95e-06\n",
      "Epoch [949/1000] | Train Loss=0.000190551 | Test Loss=0.003220222 | Time=1.63s | LR=1.95e-06\n",
      "Epoch [950/1000] | Train Loss=0.000189911 | Test Loss=0.003230472 | Time=1.62s | LR=1.95e-06\n",
      "Epoch [951/1000] | Train Loss=0.000192107 | Test Loss=0.003231285 | Time=1.73s | LR=1.95e-06\n",
      "Epoch [952/1000] | Train Loss=0.000191018 | Test Loss=0.003222441 | Time=1.76s | LR=1.95e-06\n",
      "Epoch [953/1000] | Train Loss=0.000191524 | Test Loss=0.003225442 | Time=1.55s | LR=1.95e-06\n",
      "Epoch [954/1000] | Train Loss=0.000190737 | Test Loss=0.003219477 | Time=1.66s | LR=1.95e-06\n",
      "Epoch [955/1000] | Train Loss=0.000191951 | Test Loss=0.003221775 | Time=1.78s | LR=1.95e-06\n",
      "Epoch [956/1000] | Train Loss=0.000190366 | Test Loss=0.003230849 | Time=1.59s | LR=1.95e-06\n",
      "Epoch [957/1000] | Train Loss=0.000189432 | Test Loss=0.003208422 | Time=1.72s | LR=1.95e-06\n",
      "Epoch [958/1000] | Train Loss=0.000195050 | Test Loss=0.003213867 | Time=1.77s | LR=1.95e-06\n",
      "Epoch [959/1000] | Train Loss=0.000191908 | Test Loss=0.003223799 | Time=1.54s | LR=1.95e-06\n",
      "Epoch [960/1000] | Train Loss=0.000189680 | Test Loss=0.003232546 | Time=1.65s | LR=1.95e-06\n",
      "Epoch [961/1000] | Train Loss=0.000193582 | Test Loss=0.003230445 | Time=1.78s | LR=1.95e-06\n",
      "Epoch [962/1000] | Train Loss=0.000191805 | Test Loss=0.003214969 | Time=1.57s | LR=1.95e-06\n",
      "Epoch [963/1000] | Train Loss=0.000192822 | Test Loss=0.003204867 | Time=1.71s | LR=1.95e-06\n",
      "Epoch [964/1000] | Train Loss=0.000195679 | Test Loss=0.003204196 | Time=1.76s | LR=1.95e-06\n",
      "Epoch [965/1000] | Train Loss=0.000193041 | Test Loss=0.003216142 | Time=1.79s | LR=1.95e-06\n",
      "Epoch [966/1000] | Train Loss=0.000191377 | Test Loss=0.003216826 | Time=1.58s | LR=1.95e-06\n",
      "Epoch [967/1000] | Train Loss=0.000190655 | Test Loss=0.003220019 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [968/1000] | Train Loss=0.000191615 | Test Loss=0.003213787 | Time=1.68s | LR=1.95e-06\n",
      "Epoch [969/1000] | Train Loss=0.000192168 | Test Loss=0.003216176 | Time=1.61s | LR=1.95e-06\n",
      "Epoch [970/1000] | Train Loss=0.000190068 | Test Loss=0.003213926 | Time=1.73s | LR=1.95e-06\n",
      "Epoch [971/1000] | Train Loss=0.000192719 | Test Loss=0.003213102 | Time=1.77s | LR=1.95e-06\n",
      "Epoch [972/1000] | Train Loss=0.000191280 | Test Loss=0.003225988 | Time=1.54s | LR=1.95e-06\n",
      "Epoch [973/1000] | Train Loss=0.000192198 | Test Loss=0.003202758 | Time=1.80s | LR=1.95e-06\n",
      "Epoch [974/1000] | Train Loss=0.000191835 | Test Loss=0.003227425 | Time=1.68s | LR=1.95e-06\n",
      "Epoch [975/1000] | Train Loss=0.000191263 | Test Loss=0.003205924 | Time=1.57s | LR=1.95e-06\n",
      "Epoch [976/1000] | Train Loss=0.000191909 | Test Loss=0.003203831 | Time=1.70s | LR=1.95e-06\n",
      "Epoch [977/1000] | Train Loss=0.000194244 | Test Loss=0.003209476 | Time=1.76s | LR=1.95e-06\n",
      "Epoch [978/1000] | Train Loss=0.000190389 | Test Loss=0.003205509 | Time=1.78s | LR=1.95e-06\n",
      "Epoch [979/1000] | Train Loss=0.000190596 | Test Loss=0.003212288 | Time=1.78s | LR=1.95e-06\n",
      "Epoch [980/1000] | Train Loss=0.000192107 | Test Loss=0.003209248 | Time=1.64s | LR=1.95e-06\n",
      "Epoch [981/1000] | Train Loss=0.000191495 | Test Loss=0.003199608 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [982/1000] | Train Loss=0.000190781 | Test Loss=0.003225010 | Time=1.59s | LR=1.95e-06\n",
      "Epoch [983/1000] | Train Loss=0.000189832 | Test Loss=0.003209598 | Time=1.72s | LR=1.95e-06\n",
      "Epoch [984/1000] | Train Loss=0.000190497 | Test Loss=0.003220180 | Time=1.77s | LR=1.95e-06\n",
      "Epoch [985/1000] | Train Loss=0.000192469 | Test Loss=0.003208173 | Time=1.76s | LR=1.95e-06\n",
      "Epoch [986/1000] | Train Loss=0.000190256 | Test Loss=0.003210176 | Time=1.73s | LR=1.95e-06\n",
      "Epoch [987/1000] | Train Loss=0.000191867 | Test Loss=0.003205848 | Time=1.66s | LR=1.95e-06\n",
      "Epoch [988/1000] | Train Loss=0.000191135 | Test Loss=0.003204556 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [989/1000] | Train Loss=0.000190067 | Test Loss=0.003203763 | Time=1.62s | LR=1.95e-06\n",
      "Epoch [990/1000] | Train Loss=0.000192093 | Test Loss=0.003207646 | Time=1.73s | LR=1.95e-06\n",
      "Epoch [991/1000] | Train Loss=0.000192501 | Test Loss=0.003201663 | Time=1.77s | LR=1.95e-06\n",
      "Epoch [992/1000] | Train Loss=0.000189390 | Test Loss=0.003197348 | Time=1.55s | LR=1.95e-06\n",
      "Epoch [993/1000] | Train Loss=0.000189108 | Test Loss=0.003207685 | Time=1.66s | LR=1.95e-06\n",
      "Epoch [994/1000] | Train Loss=0.000191233 | Test Loss=0.003205851 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [995/1000] | Train Loss=0.000191023 | Test Loss=0.003217510 | Time=1.61s | LR=1.95e-06\n",
      "Epoch [996/1000] | Train Loss=0.000190774 | Test Loss=0.003210530 | Time=1.73s | LR=1.95e-06\n",
      "Epoch [997/1000] | Train Loss=0.000191966 | Test Loss=0.003206639 | Time=1.77s | LR=1.95e-06\n",
      "Epoch [998/1000] | Train Loss=0.000191344 | Test Loss=0.003211166 | Time=1.54s | LR=1.95e-06\n",
      "Epoch [999/1000] | Train Loss=0.000191004 | Test Loss=0.003211516 | Time=1.66s | LR=1.95e-06\n",
      "Epoch [1000/1000] | Train Loss=0.000192879 | Test Loss=0.003203643 | Time=1.69s | LR=1.95e-06\n",
      "\n",
      "Total training time: 1524.08 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAGwCAYAAABFFQqPAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAghNJREFUeJzt3Xd4FHXiBvB3tqY3QhqE3jvSBBFQaaKcgFhRsZxYgqL88NTzVNCzngW9i+XUw8qhKKCnqBRBqvRqKNJ7QgjpyWZ3Z35/THZ3Zvsmu9mU9/M8edidtt+dhOybbxUkSZJARERE1ARpwl0AIiIionBhECIiIqImi0GIiIiImiwGISIiImqyGISIiIioyWIQIiIioiaLQYiIiIiaLF24C1DfiaKIM2fOIDY2FoIghLs4RERE5AdJklBSUoKMjAxoNJ7rfRiEfDhz5gwyMzPDXQwiIiKqgZMnT6Jly5Ye9zMI+RAbGwtAvpFxcXFBu67ZbMayZcswevRo6PX6oF2X1Hif6w7vdd3gfa4bvM91I5T3ubi4GJmZmfbPcU8YhDzIzs5GdnY2rFYrACAuLi7oQSgqKgpxcXH8TxZCvM91h/e6bvA+1w3e57pRF/fZV7cWdpb2ICsrCzk5OdiyZUu4i0JEREQhwiBERERETRaDEBERETVZ7CNEREQNliiKqKqqCvp1zWYzdDodKisr7X1FKfhqc5/1ej20Wm2ty8AgREREDVJVVRWOHj0KURSDfm1JkpCWloaTJ09yDrkQqu19TkhIQFpaWq2+RwxCRETU4EiShLNnz0Kr1SIzM9PrhHk1IYoiSktLERMTE/Rrk0NN77MkSSgvL0deXh4AID09vcZlYBAiIqIGx2KxoLy8HBkZGYiKigr69W1NbhEREQxCIVSb+xwZGQkAyMvLQ0pKSo2byfjdJSKiBsfWn8RgMIS5JBROthBsNptrfA0GISIiarDYf6dpC8b3n0GIiIiImiwGISIiImqyGISIiIgasDZt2mDu3LnhLgY+/vhjJCQkhLsYAWMQ8iA7OxvdunXDgAEDQnL9s0WVuFAJVFmCP/8FERHVP4IgeP2aPXt2ja67ZcsWTJs2rVZlGzFihL0cERER6NSpE1566SVIklSr6zoTBAFLlixxu2/16tW47rrrkJ6ejujoaPTp0wdffPFFUF/fHQ6f9yArKwtZWVkoLi5GfHx80K8/4d2NKCjTYdBlZeje0hj06xMRUf1y9uxZ++Mvv/wSzzzzDA4cOGDfFhMTY38sSRKsVit0Ot8f082bNw9K+e69914899xzMJlM+OWXXzBt2jQkJCTggQceCMr1fdmwYQN69eqFxx9/HKmpqfj+++9xxx13ID4+Htdee23IXpc1QmGiqe7pHuSwTUTUJEmShPIqS1C/Kqqsfh3nb61JWlqa/Ss+Ph6CINif79+/H7Gxsfjxxx/Rr18/GI1GrFu3DocPH8Z1112H1NRUxMTEYMCAAVixYoXqus5NY4Ig4MMPP8TEiRMRFRWFjh074rvvvvNZvqioKKSlpaF169a466670KtXLyxfvty+32QyYdasWWjRogWio6MxaNAgrF692q/37o+//vWveP755zFkyBC0b98eM2bMwNixY7Fo0aKgvYY7rBEKE9uAP5FBiIio1irMVnR75uewvHbOc2MQZQjOx+kTTzyB1157De3atUNiYiJOnjyJcePG4YUXXoDRaMSnn36K8ePH48CBA2jVqpXH68yZMwevvvoq/vGPf+Cf//wnpkyZguPHjyMpKclnGSRJwrp167B//3507NjRvn369OnIycnBggULkJGRgcWLF2Ps2LHYs2eP6rhgKioqQteuXUNybRvWCIWJbe4DCUxCREQke+655zBq1Ci0b98eSUlJ6N27N+677z706NEDHTt2xPPPP4/27dv7rOG58847ccstt6BDhw548cUXUVpais2bN3s955133kFMTAyMRiOGDRsGURTx8MMPAwBOnDiBefPmYeHChbj88svRvn17zJo1C0OHDsW8efOC9v6VvvrqK2zZsgV33XVXSK5vwxqhMLHNAcWmMSKi2ovUa5Hz3JigXU8URZQUlyA2Ltbn0g+R+tqvgG7Tv39/1fPS0lLMnj0bP/zwA86ePQuLxYKKigqcOHHC63V69eplfxwdHY24uDj7ulyeTJkyBU899RQuXryIZ599FkOGDMGQIUMAAHv27IHVakWnTp1U55hMJjRr1iyQt+iXVatW4a677sIHH3yA7t27B/36SgxCYWJrGmMQIiKqPUEQgtY8BchByGLQIsqgq9O1xqKjo1XPZ82aheXLl+O1115Dhw4dEBkZicmTJ6OqqsrrdfR6veq5IAgQRe+jlOPj49GhQwcAcm1Mhw4dcOmll2LkyJEoLS2F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FV1SIAjA9uMXUWG2YuHWU2jXPBqnLlbAYpWQV1KJrulxeGlST2w4fAHrD+XjbFEleraIR6fUWBzMLUFxhdk+vcOpixVonRSFvBITSirNSIo2YHT3NETrNYi+sA9twrgmHoMQERFRA+YuBNVEhF6LB0aop3zoXj11g7epIFo3i8YtA1vV6DXlpt59NTo3WLjEBhERETVZDEJERETUZDEIERERUZPFIERERERNFoMQERERNVkMQkRERNRkMQgRERFRk8UgRERERE0WgxARERE1WQxCRERE1GQxCBEREVGTxSBERERETRaDEBERETVZDEJERETUZOnCXYD6TpIkAEBxcXFQr2s2m1FeXo7i4mLo9fqgXpsceJ/rDu913eB9rhu8z3UjlPfZ9rlt+xz3hEHIh5KSEgBAZmZmmEtCREREgSopKUF8fLzH/YLkKyo1caIo4syZM4iNjYUgCEG7bnFxMTIzM3Hy5EnExcUF7bqkxvtcd3iv6wbvc93gfa4bobzPkiShpKQEGRkZ0Gg89wRijZAPGo0GLVu2DNn14+Li+J+sDvA+1x3e67rB+1w3eJ/rRqjus7eaIBt2liYiIqImi0GIiIiImiwGoTAxGo149tlnYTQaw12URo33ue7wXtcN3ue6wftcN+rDfWZnaSIiImqyWCNERERETRaDEBERETVZDEJERETUZDEIERERUZPFIBQm2dnZaNOmDSIiIjBo0CBs3rw53EVqMF566SUMGDAAsbGxSElJwYQJE3DgwAHVMZWVlcjKykKzZs0QExOD66+/Hrm5uapjTpw4gWuuuQZRUVFISUnBY489BovFUpdvpUF5+eWXIQgCHnnkEfs23ufgOX36NG677TY0a9YMkZGR6NmzJ7Zu3WrfL0kSnnnmGaSnpyMyMhIjR47EH3/8obpGQUEBpkyZgri4OCQkJOCee+5BaWlpXb+VestqteLpp59G27ZtERkZifbt2+P5559XrUXF+xy4NWvWYPz48cjIyIAgCFiyZIlqf7Du6e7du3H55ZcjIiICmZmZePXVV4PzBiSqcwsWLJAMBoP0n//8R/r999+le++9V0pISJByc3PDXbQGYcyYMdK8efOkvXv3Sjt37pTGjRsntWrVSiotLbUfc//990uZmZnSypUrpa1bt0qXXnqpNGTIEPt+i8Ui9ejRQxo5cqS0Y8cOaenSpVJy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tWolRURESO3atZOeeuop1ZBs3ufArVq1yu3v5KlTp0qSFLx7umvXLmno0KGS0WiUWrRoIb388stBKb8gSYopNYmIiIiaEPYRIiIioiaLQYiIiIiaLAYhIiIiarIYhIiIiKjJYhAiIiKiJotBiIiIiJosBiEiIiJqshiEiIiIqMliECIiCpAgCFiyZEm4i0FEQcAgREQNyp133glBEFy+xo4dG+6iEVEDpAt3AYiIAjV27FjMmzdPtc1oNIapNETUkLFGiIgaHKPRiLS0NNVXYmIiALnZ6t1338XVV1+NyMhItGvXDl9//bXq/D179uDKK69EZGQkmjVrhmnTpqG0tFR1zH/+8x90794dRqMR6enpmD59ump/fn4+Jk6ciKioKHTs2BHfffddaN80EYUEgxARNTpPP/00rr/+euzatQtTpkzBzTffjH379gEAysrKMGbMGCQmJmLLli1YuHAhVqxYoQo67777LrKysjBt2jTs2bMH3333HTp06KB6jTlz5uDGG2/E7t27MW7cOEyZMgUFBQV1+j6JKAiCsoY9EVEdmTp1qqTVaqXo6GjV1wsvvCBJkiQBkO6//37VOYMGDZIeeOABSZIk6d///reUmJgolZaW2vf/8MMPkkajkc6dOydJkiRlZGRITz31lMcyAJD+9re/2Z+XlpZKAKQff/wxaO+TiOoG+wgRUYNzxRVX4N1331VtS0pKsj8ePHiwat/gwYOxc+dOAMC+ffvQu3dvREdH2/dfdtllEEURBw4cgCAIOHPmDK666iqvZejVq5f9cXR0NOLi4pCXl1fTt0REYcIgREQNTnR0tEtTVbBERkb6dZxer1c9FwQBoiiGokhEFELsI0REjc5vv/3m8rxr164AgK5du2LXrl0oKyuz71+/fj00Gg06d+6M2NhYtGnTBitXrqzTMhNReLBGiIgaHJPJhHPnzqm26XQ6JCcnAwAWLlyI/v37Y+jQofjiiy+wefNmfPTRRwCAKVOm4Nlnn8XUqVMxe/ZsnD9/Hg899BBuv/12pKamAgBmz56N+++/HykpKbj66qtRUlKC9evX46GHHqrbN0pEIccgREQNzk8//YT09HTVts6dO2P//v0A5BFdCxYswIMPPoj09HT897//Rbdu3QAAUVFR+PnnnzFjxgwMGDAAUVFRuP766/HGG2/YrzV16lRUVlbizTffxKxZs5CcnIzJkyfX3RskojojSJIkhbsQRETBIggCFi9ejAkTJoS7KETUALCPEBERETVZDEJERETUZLGPEBE1KmztJ6JAsEaIiIiImiwGISIiImqyGISIiIioyWIQIiIioiaLQYiIiIiaLAYhIiIiarIYhIiIiKjJYhAiIiKiJuv/AfBt0YuCI6FdAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "# Train using your existing training loop\n",
    "amfno, train_losses, test_losses = train_operator(\n",
    "    dataset_raw      = train_data,\n",
    "    model            = amfno,\n",
    "    num_epochs       = 1000,\n",
    "    lr               = 1e-3,\n",
    "    device           = device,\n",
    "    batch_size       = 16,\n",
    "    test_dataset_raw = test_data,\n",
    "    reduce_on        = 'train',\n",
    "    factor           = 0.5,\n",
    "    patience         = 40,\n",
    "    min_lr           = 1e-10,\n",
    "    cooldown         = 0,\n",
    ")\n",
    "\n",
    "torch.save(amfno.state_dict(), 'amfno_G3.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:1\n",
      "Epoch [1/1000] | Train Loss=0.001471047 | Test Loss=0.003864494 | Time=1.72s | LR=1.00e-04\n",
      "Epoch [2/1000] | Train Loss=0.001014428 | Test Loss=0.003330327 | Time=1.66s | LR=1.00e-04\n",
      "Epoch [3/1000] | Train Loss=0.001044314 | Test Loss=0.003593302 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [4/1000] | Train Loss=0.000935935 | Test Loss=0.003256663 | Time=1.76s | LR=1.00e-04\n",
      "Epoch [5/1000] | Train Loss=0.001028633 | Test Loss=0.003153278 | Time=1.72s | LR=1.00e-04\n",
      "Epoch [6/1000] | Train Loss=0.000871805 | Test Loss=0.003390359 | Time=1.62s | LR=1.00e-04\n",
      "Epoch [7/1000] | Train Loss=0.001212891 | Test Loss=0.003832836 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [8/1000] | Train Loss=0.000856439 | Test Loss=0.003153542 | Time=1.66s | LR=1.00e-04\n",
      "Epoch [9/1000] | Train Loss=0.000829287 | Test Loss=0.003243313 | Time=1.68s | LR=1.00e-04\n",
      "Epoch [10/1000] | Train Loss=0.000968813 | Test Loss=0.003184589 | Time=1.76s | LR=1.00e-04\n",
      "Epoch [11/1000] | Train Loss=0.001198133 | Test Loss=0.003147172 | Time=1.78s | LR=1.00e-04\n",
      "Epoch [12/1000] | Train Loss=0.000908978 | Test Loss=0.003382616 | Time=1.58s | LR=1.00e-04\n",
      "Epoch [13/1000] | Train Loss=0.000899215 | Test Loss=0.003131995 | Time=1.67s | LR=1.00e-04\n",
      "Epoch [14/1000] | Train Loss=0.001021891 | Test Loss=0.003825868 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [15/1000] | Train Loss=0.000966993 | Test Loss=0.003210152 | Time=1.61s | LR=1.00e-04\n",
      "Epoch [16/1000] | Train Loss=0.001650625 | Test Loss=0.003091778 | Time=1.73s | LR=1.00e-04\n",
      "Epoch [17/1000] | Train Loss=0.001850072 | Test Loss=0.003422911 | Time=1.78s | LR=1.00e-04\n",
      "Epoch [18/1000] | Train Loss=0.001862319 | Test Loss=0.003595828 | Time=1.54s | LR=1.00e-04\n",
      "Epoch [19/1000] | Train Loss=0.001096525 | Test Loss=0.003339975 | Time=1.66s | LR=1.00e-04\n",
      "Epoch [20/1000] | Train Loss=0.000793003 | Test Loss=0.003123346 | Time=1.78s | LR=1.00e-04\n",
      "Epoch [21/1000] | Train Loss=0.000832329 | Test Loss=0.003500609 | Time=1.58s | LR=1.00e-04\n",
      "Epoch [22/1000] | Train Loss=0.001008801 | Test Loss=0.003039401 | Time=1.71s | LR=1.00e-04\n",
      "Epoch [23/1000] | Train Loss=0.000990961 | Test Loss=0.003188257 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [24/1000] | Train Loss=0.000952709 | Test Loss=0.003108534 | Time=1.79s | LR=1.00e-04\n",
      "Epoch [25/1000] | Train Loss=0.001564961 | Test Loss=0.003558377 | Time=1.58s | LR=1.00e-04\n",
      "Epoch [26/1000] | Train Loss=0.001133269 | Test Loss=0.003793152 | Time=1.80s | LR=1.00e-04\n",
      "Epoch [27/1000] | Train Loss=0.000818465 | Test Loss=0.003236045 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [28/1000] | Train Loss=0.001433731 | Test Loss=0.003082606 | Time=1.61s | LR=1.00e-04\n",
      "Epoch [29/1000] | Train Loss=0.001383422 | Test Loss=0.003192587 | Time=1.73s | LR=1.00e-04\n",
      "Epoch [30/1000] | Train Loss=0.001034104 | Test Loss=0.003151480 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [31/1000] | Train Loss=0.000721745 | Test Loss=0.003573723 | Time=1.54s | LR=1.00e-04\n",
      "Epoch [32/1000] | Train Loss=0.001059457 | Test Loss=0.003839078 | Time=1.80s | LR=1.00e-04\n",
      "Epoch [33/1000] | Train Loss=0.001087411 | Test Loss=0.003158693 | Time=1.68s | LR=1.00e-04\n",
      "Epoch [34/1000] | Train Loss=0.001250276 | Test Loss=0.004304367 | Time=1.72s | LR=1.00e-04\n",
      "Epoch [35/1000] | Train Loss=0.001842167 | Test Loss=0.004073295 | Time=1.65s | LR=1.00e-04\n",
      "Epoch [36/1000] | Train Loss=0.001050200 | Test Loss=0.003324936 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [37/1000] | Train Loss=0.000898608 | Test Loss=0.003541541 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [38/1000] | Train Loss=0.000997993 | Test Loss=0.003456410 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [39/1000] | Train Loss=0.000982854 | Test Loss=0.003183083 | Time=1.62s | LR=1.00e-04\n",
      "Epoch [40/1000] | Train Loss=0.000961945 | Test Loss=0.003426538 | Time=1.68s | LR=1.00e-04\n",
      "Epoch [41/1000] | Train Loss=0.001001625 | Test Loss=0.003051339 | Time=1.58s | LR=1.00e-04\n",
      "Epoch [42/1000] | Train Loss=0.001679059 | Test Loss=0.003992974 | Time=1.71s | LR=1.00e-04\n",
      "Epoch [43/1000] | Train Loss=0.001798573 | Test Loss=0.003197695 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [44/1000] | Train Loss=0.001763789 | Test Loss=0.003788860 | Time=1.79s | LR=1.00e-04\n",
      "Epoch [45/1000] | Train Loss=0.001060649 | Test Loss=0.003336970 | Time=1.58s | LR=1.00e-04\n",
      "Epoch [46/1000] | Train Loss=0.000812618 | Test Loss=0.003249034 | Time=1.67s | LR=1.00e-04\n",
      "Epoch [47/1000] | Train Loss=0.000812049 | Test Loss=0.003756408 | Time=1.71s | LR=1.00e-04\n",
      "Epoch [48/1000] | Train Loss=0.000897791 | Test Loss=0.003525902 | Time=1.64s | LR=1.00e-04\n",
      "Epoch [49/1000] | Train Loss=0.000877154 | Test Loss=0.003888787 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [50/1000] | Train Loss=0.000983306 | Test Loss=0.003108733 | Time=1.76s | LR=1.00e-04\n",
      "Epoch [51/1000] | Train Loss=0.001569925 | Test Loss=0.004383959 | Time=1.55s | LR=1.00e-04\n",
      "Epoch [52/1000] | Train Loss=0.001827528 | Test Loss=0.004266092 | Time=1.67s | LR=1.00e-04\n",
      "Epoch [53/1000] | Train Loss=0.001264225 | Test Loss=0.003489695 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [54/1000] | Train Loss=0.001001007 | Test Loss=0.003630096 | Time=1.62s | LR=1.00e-04\n",
      "Epoch [55/1000] | Train Loss=0.001035525 | Test Loss=0.003284239 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [56/1000] | Train Loss=0.000958644 | Test Loss=0.003281076 | Time=1.78s | LR=1.00e-04\n",
      "Epoch [57/1000] | Train Loss=0.000978949 | Test Loss=0.003405180 | Time=1.54s | LR=1.00e-04\n",
      "Epoch [58/1000] | Train Loss=0.000897146 | Test Loss=0.003120711 | Time=1.66s | LR=1.00e-04\n",
      "Epoch [59/1000] | Train Loss=0.000839548 | Test Loss=0.003156515 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [60/1000] | Train Loss=0.001195643 | Test Loss=0.003479866 | Time=1.61s | LR=1.00e-04\n",
      "Epoch [61/1000] | Train Loss=0.001483668 | Test Loss=0.003092197 | Time=1.73s | LR=1.00e-04\n",
      "Epoch [62/1000] | Train Loss=0.000974065 | Test Loss=0.003094022 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [63/1000] | Train Loss=0.001018383 | Test Loss=0.003165095 | Time=1.78s | LR=1.00e-04\n",
      "Epoch [64/1000] | Train Loss=0.000937607 | Test Loss=0.003070619 | Time=1.59s | LR=1.00e-04\n",
      "Epoch [65/1000] | Train Loss=0.000970057 | Test Loss=0.004060047 | Time=1.68s | LR=1.00e-04\n",
      "Epoch [66/1000] | Train Loss=0.000880650 | Test Loss=0.003155918 | Time=1.71s | LR=1.00e-04\n",
      "Epoch [67/1000] | Train Loss=0.000950561 | Test Loss=0.003090495 | Time=1.66s | LR=1.00e-04\n",
      "Epoch [68/1000] | Train Loss=0.000972150 | Test Loss=0.003269760 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [69/1000] | Train Loss=0.001325260 | Test Loss=0.003123859 | Time=1.76s | LR=1.00e-04\n",
      "Epoch [70/1000] | Train Loss=0.000892434 | Test Loss=0.003116635 | Time=1.56s | LR=1.00e-04\n",
      "Epoch [71/1000] | Train Loss=0.000890376 | Test Loss=0.003052715 | Time=1.66s | LR=1.00e-04\n",
      "Epoch [72/1000] | Train Loss=0.000920738 | Test Loss=0.003370786 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [73/1000] | Train Loss=0.000452169 | Test Loss=0.003079461 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [74/1000] | Train Loss=0.000421613 | Test Loss=0.003084445 | Time=1.73s | LR=5.00e-05\n",
      "Epoch [75/1000] | Train Loss=0.000456337 | Test Loss=0.003109758 | Time=1.73s | LR=5.00e-05\n",
      "Epoch [76/1000] | Train Loss=0.000410795 | Test Loss=0.003065369 | Time=1.55s | LR=5.00e-05\n",
      "Epoch [77/1000] | Train Loss=0.000502224 | Test Loss=0.003247123 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [78/1000] | Train Loss=0.000426994 | Test Loss=0.003266070 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [79/1000] | Train Loss=0.000512872 | Test Loss=0.003328034 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [80/1000] | Train Loss=0.000384909 | Test Loss=0.003115957 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [81/1000] | Train Loss=0.000497582 | Test Loss=0.003083237 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [82/1000] | Train Loss=0.000464839 | Test Loss=0.003133419 | Time=1.59s | LR=5.00e-05\n",
      "Epoch [83/1000] | Train Loss=0.000410277 | Test Loss=0.003118397 | Time=1.70s | LR=5.00e-05\n",
      "Epoch [84/1000] | Train Loss=0.000454097 | Test Loss=0.003220202 | Time=1.76s | LR=5.00e-05\n",
      "Epoch [85/1000] | Train Loss=0.000342546 | Test Loss=0.003309185 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [86/1000] | Train Loss=0.000343480 | Test Loss=0.003213219 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [87/1000] | Train Loss=0.000351543 | Test Loss=0.003140940 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [88/1000] | Train Loss=0.000537341 | Test Loss=0.003427079 | Time=1.59s | LR=5.00e-05\n",
      "Epoch [89/1000] | Train Loss=0.000567076 | Test Loss=0.003165684 | Time=1.67s | LR=5.00e-05\n",
      "Epoch [90/1000] | Train Loss=0.000517517 | Test Loss=0.003353082 | Time=1.70s | LR=5.00e-05\n",
      "Epoch [91/1000] | Train Loss=0.000801251 | Test Loss=0.003357433 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [92/1000] | Train Loss=0.000638268 | Test Loss=0.003383571 | Time=1.67s | LR=5.00e-05\n",
      "Epoch [93/1000] | Train Loss=0.000540256 | Test Loss=0.003324640 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [94/1000] | Train Loss=0.000473553 | Test Loss=0.003183773 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [95/1000] | Train Loss=0.000403062 | Test Loss=0.003117155 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [96/1000] | Train Loss=0.000307891 | Test Loss=0.003183186 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [97/1000] | Train Loss=0.000374618 | Test Loss=0.003202308 | Time=1.61s | LR=5.00e-05\n",
      "Epoch [98/1000] | Train Loss=0.000483372 | Test Loss=0.003052160 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [99/1000] | Train Loss=0.000560748 | Test Loss=0.003449556 | Time=1.54s | LR=5.00e-05\n",
      "Epoch [100/1000] | Train Loss=0.000475176 | Test Loss=0.003045488 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [101/1000] | Train Loss=0.000520232 | Test Loss=0.003240493 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [102/1000] | Train Loss=0.000950778 | Test Loss=0.003505142 | Time=1.55s | LR=5.00e-05\n",
      "Epoch [103/1000] | Train Loss=0.000658822 | Test Loss=0.003103593 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [104/1000] | Train Loss=0.000515594 | Test Loss=0.003275784 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [105/1000] | Train Loss=0.000481655 | Test Loss=0.003174987 | Time=1.58s | LR=5.00e-05\n",
      "Epoch [106/1000] | Train Loss=0.000292814 | Test Loss=0.003139155 | Time=1.67s | LR=5.00e-05\n",
      "Epoch [107/1000] | Train Loss=0.000304695 | Test Loss=0.003281381 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [108/1000] | Train Loss=0.000504814 | Test Loss=0.003291273 | Time=1.59s | LR=5.00e-05\n",
      "Epoch [109/1000] | Train Loss=0.000569103 | Test Loss=0.003107779 | Time=1.67s | LR=5.00e-05\n",
      "Epoch [110/1000] | Train Loss=0.000549254 | Test Loss=0.003237281 | Time=1.70s | LR=5.00e-05\n",
      "Epoch [111/1000] | Train Loss=0.000522475 | Test Loss=0.003112663 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [112/1000] | Train Loss=0.000645618 | Test Loss=0.003073187 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [113/1000] | Train Loss=0.000733331 | Test Loss=0.003376579 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [114/1000] | Train Loss=0.000434739 | Test Loss=0.003256135 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [115/1000] | Train Loss=0.000442707 | Test Loss=0.003245735 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [116/1000] | Train Loss=0.000512760 | Test Loss=0.003116086 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [117/1000] | Train Loss=0.000348047 | Test Loss=0.003386864 | Time=1.60s | LR=5.00e-05\n",
      "Epoch [118/1000] | Train Loss=0.000496406 | Test Loss=0.003130301 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [119/1000] | Train Loss=0.000475928 | Test Loss=0.003282615 | Time=1.54s | LR=5.00e-05\n",
      "Epoch [120/1000] | Train Loss=0.000524908 | Test Loss=0.003112092 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [121/1000] | Train Loss=0.000431821 | Test Loss=0.003125066 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [122/1000] | Train Loss=0.000404237 | Test Loss=0.003146250 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [123/1000] | Train Loss=0.000481870 | Test Loss=0.003067558 | Time=1.65s | LR=5.00e-05\n",
      "Epoch [124/1000] | Train Loss=0.000444288 | Test Loss=0.003054470 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [125/1000] | Train Loss=0.000448615 | Test Loss=0.003228675 | Time=1.56s | LR=5.00e-05\n",
      "Epoch [126/1000] | Train Loss=0.000378886 | Test Loss=0.003211941 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [127/1000] | Train Loss=0.000470376 | Test Loss=0.003062296 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [128/1000] | Train Loss=0.000530743 | Test Loss=0.003075196 | Time=1.71s | LR=5.00e-05\n",
      "Epoch [129/1000] | Train Loss=0.000535207 | Test Loss=0.003285609 | Time=1.65s | LR=5.00e-05\n",
      "Epoch [130/1000] | Train Loss=0.000478162 | Test Loss=0.003295258 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [131/1000] | Train Loss=0.000495475 | Test Loss=0.003172956 | Time=1.57s | LR=5.00e-05\n",
      "Epoch [132/1000] | Train Loss=0.000474094 | Test Loss=0.003131270 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [133/1000] | Train Loss=0.000510146 | Test Loss=0.003094716 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [134/1000] | Train Loss=0.000488012 | Test Loss=0.003020468 | Time=1.72s | LR=5.00e-05\n",
      "Epoch [135/1000] | Train Loss=0.000477947 | Test Loss=0.003353902 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [136/1000] | Train Loss=0.000507960 | Test Loss=0.003047113 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [137/1000] | Train Loss=0.000460927 | Test Loss=0.003195630 | Time=1.58s | LR=5.00e-05\n",
      "Epoch [138/1000] | Train Loss=0.000497041 | Test Loss=0.003079773 | Time=1.67s | LR=5.00e-05\n",
      "Epoch [139/1000] | Train Loss=0.000486397 | Test Loss=0.003083823 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [140/1000] | Train Loss=0.000464660 | Test Loss=0.003072938 | Time=1.72s | LR=5.00e-05\n",
      "Epoch [141/1000] | Train Loss=0.000469052 | Test Loss=0.003084375 | Time=1.66s | LR=5.00e-05\n",
      "Epoch [142/1000] | Train Loss=0.000497922 | Test Loss=0.003085133 | Time=1.68s | LR=5.00e-05\n",
      "Epoch [143/1000] | Train Loss=0.000472446 | Test Loss=0.003081672 | Time=1.57s | LR=5.00e-05\n",
      "Epoch [144/1000] | Train Loss=0.000496816 | Test Loss=0.003125381 | Time=1.67s | LR=5.00e-05\n",
      "Epoch [145/1000] | Train Loss=0.000545801 | Test Loss=0.003099791 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [146/1000] | Train Loss=0.000492266 | Test Loss=0.003057304 | Time=1.72s | LR=5.00e-05\n",
      "Epoch [147/1000] | Train Loss=0.000565616 | Test Loss=0.003350408 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [148/1000] | Train Loss=0.000405595 | Test Loss=0.003151921 | Time=1.68s | LR=2.50e-05\n",
      "Epoch [149/1000] | Train Loss=0.000220435 | Test Loss=0.003145779 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [150/1000] | Train Loss=0.000234872 | Test Loss=0.003134873 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [151/1000] | Train Loss=0.000261082 | Test Loss=0.003143120 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [152/1000] | Train Loss=0.000271632 | Test Loss=0.003103214 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [153/1000] | Train Loss=0.000272904 | Test Loss=0.003183690 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [154/1000] | Train Loss=0.000248945 | Test Loss=0.003169309 | Time=1.68s | LR=2.50e-05\n",
      "Epoch [155/1000] | Train Loss=0.000275311 | Test Loss=0.003085892 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [156/1000] | Train Loss=0.000304762 | Test Loss=0.003206722 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [157/1000] | Train Loss=0.000244182 | Test Loss=0.003087912 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [158/1000] | Train Loss=0.000238975 | Test Loss=0.003179593 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [159/1000] | Train Loss=0.000273364 | Test Loss=0.003162998 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [160/1000] | Train Loss=0.000311284 | Test Loss=0.003205787 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [161/1000] | Train Loss=0.000309524 | Test Loss=0.003054828 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [162/1000] | Train Loss=0.000290382 | Test Loss=0.003261423 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [163/1000] | Train Loss=0.000232425 | Test Loss=0.003083047 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [164/1000] | Train Loss=0.000285043 | Test Loss=0.003100656 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [165/1000] | Train Loss=0.000272467 | Test Loss=0.003107500 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [166/1000] | Train Loss=0.000287033 | Test Loss=0.003197905 | Time=1.68s | LR=2.50e-05\n",
      "Epoch [167/1000] | Train Loss=0.000291610 | Test Loss=0.003196341 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [168/1000] | Train Loss=0.000256498 | Test Loss=0.003124547 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [169/1000] | Train Loss=0.000280255 | Test Loss=0.003151969 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [170/1000] | Train Loss=0.000282236 | Test Loss=0.003101774 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [171/1000] | Train Loss=0.000282071 | Test Loss=0.003150373 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [172/1000] | Train Loss=0.000253951 | Test Loss=0.003089710 | Time=1.68s | LR=2.50e-05\n",
      "Epoch [173/1000] | Train Loss=0.000249545 | Test Loss=0.003074424 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [174/1000] | Train Loss=0.000310704 | Test Loss=0.003079188 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [175/1000] | Train Loss=0.000281162 | Test Loss=0.003115386 | Time=1.70s | LR=2.50e-05\n",
      "Epoch [176/1000] | Train Loss=0.000292189 | Test Loss=0.003113031 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [177/1000] | Train Loss=0.000225764 | Test Loss=0.003108440 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [178/1000] | Train Loss=0.000274330 | Test Loss=0.003159434 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [179/1000] | Train Loss=0.000253644 | Test Loss=0.003078778 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [180/1000] | Train Loss=0.000309561 | Test Loss=0.003075020 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [181/1000] | Train Loss=0.000351397 | Test Loss=0.003053677 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [182/1000] | Train Loss=0.000340517 | Test Loss=0.003261804 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [183/1000] | Train Loss=0.000296066 | Test Loss=0.003160993 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [184/1000] | Train Loss=0.000293831 | Test Loss=0.003076947 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [185/1000] | Train Loss=0.000314178 | Test Loss=0.003065658 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [186/1000] | Train Loss=0.000265648 | Test Loss=0.003144953 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [187/1000] | Train Loss=0.000211126 | Test Loss=0.003081960 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [188/1000] | Train Loss=0.000296961 | Test Loss=0.003111984 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [189/1000] | Train Loss=0.000234151 | Test Loss=0.003100871 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [190/1000] | Train Loss=0.000254087 | Test Loss=0.003184351 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [191/1000] | Train Loss=0.000278835 | Test Loss=0.003145771 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [192/1000] | Train Loss=0.000291740 | Test Loss=0.003068084 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [193/1000] | Train Loss=0.000285636 | Test Loss=0.003112058 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [194/1000] | Train Loss=0.000325395 | Test Loss=0.003047774 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [195/1000] | Train Loss=0.000294093 | Test Loss=0.003100064 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [196/1000] | Train Loss=0.000252972 | Test Loss=0.003050499 | Time=1.70s | LR=2.50e-05\n",
      "Epoch [197/1000] | Train Loss=0.000345229 | Test Loss=0.003048429 | Time=1.57s | LR=2.50e-05\n",
      "Epoch [198/1000] | Train Loss=0.000300814 | Test Loss=0.003103784 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [199/1000] | Train Loss=0.000287656 | Test Loss=0.003051799 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [200/1000] | Train Loss=0.000330618 | Test Loss=0.003089555 | Time=1.71s | LR=2.50e-05\n",
      "Epoch [201/1000] | Train Loss=0.000313193 | Test Loss=0.003067178 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [202/1000] | Train Loss=0.000238711 | Test Loss=0.003039453 | Time=1.68s | LR=2.50e-05\n",
      "Epoch [203/1000] | Train Loss=0.000387358 | Test Loss=0.003207946 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [204/1000] | Train Loss=0.000374283 | Test Loss=0.003027552 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [205/1000] | Train Loss=0.000314831 | Test Loss=0.003213127 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [206/1000] | Train Loss=0.000222984 | Test Loss=0.003187510 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [207/1000] | Train Loss=0.000272265 | Test Loss=0.003073262 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [208/1000] | Train Loss=0.000302013 | Test Loss=0.003100517 | Time=1.68s | LR=2.50e-05\n",
      "Epoch [209/1000] | Train Loss=0.000226712 | Test Loss=0.003099675 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [210/1000] | Train Loss=0.000269544 | Test Loss=0.003069584 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [211/1000] | Train Loss=0.000243064 | Test Loss=0.003049859 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [212/1000] | Train Loss=0.000320861 | Test Loss=0.003151146 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [213/1000] | Train Loss=0.000227783 | Test Loss=0.003068266 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [214/1000] | Train Loss=0.000237530 | Test Loss=0.003059375 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [215/1000] | Train Loss=0.000246486 | Test Loss=0.003204526 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [216/1000] | Train Loss=0.000283491 | Test Loss=0.003076285 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [217/1000] | Train Loss=0.000267680 | Test Loss=0.003024041 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [218/1000] | Train Loss=0.000233903 | Test Loss=0.003111261 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [219/1000] | Train Loss=0.000225887 | Test Loss=0.003094801 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [220/1000] | Train Loss=0.000220758 | Test Loss=0.003143165 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [221/1000] | Train Loss=0.000254025 | Test Loss=0.003191473 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [222/1000] | Train Loss=0.000332549 | Test Loss=0.003118563 | Time=1.67s | LR=2.50e-05\n",
      "Epoch [223/1000] | Train Loss=0.000307156 | Test Loss=0.003121251 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [224/1000] | Train Loss=0.000275481 | Test Loss=0.003038445 | Time=1.72s | LR=2.50e-05\n",
      "Epoch [225/1000] | Train Loss=0.000330237 | Test Loss=0.003089289 | Time=1.66s | LR=2.50e-05\n",
      "Epoch [226/1000] | Train Loss=0.000318160 | Test Loss=0.003031017 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [227/1000] | Train Loss=0.000285555 | Test Loss=0.003061566 | Time=1.58s | LR=2.50e-05\n",
      "Epoch [228/1000] | Train Loss=0.000271248 | Test Loss=0.003045616 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [229/1000] | Train Loss=0.000190026 | Test Loss=0.003073154 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [230/1000] | Train Loss=0.000189952 | Test Loss=0.003062202 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [231/1000] | Train Loss=0.000196004 | Test Loss=0.003053126 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [232/1000] | Train Loss=0.000193415 | Test Loss=0.003115678 | Time=1.68s | LR=1.25e-05\n",
      "Epoch [233/1000] | Train Loss=0.000194101 | Test Loss=0.003065312 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [234/1000] | Train Loss=0.000193673 | Test Loss=0.003109071 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [235/1000] | Train Loss=0.000193806 | Test Loss=0.003065532 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [236/1000] | Train Loss=0.000195898 | Test Loss=0.003058592 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [237/1000] | Train Loss=0.000212692 | Test Loss=0.003076494 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [238/1000] | Train Loss=0.000215693 | Test Loss=0.003070688 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [239/1000] | Train Loss=0.000195011 | Test Loss=0.003074615 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [240/1000] | Train Loss=0.000206942 | Test Loss=0.003075846 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [241/1000] | Train Loss=0.000193206 | Test Loss=0.003052734 | Time=1.70s | LR=1.25e-05\n",
      "Epoch [242/1000] | Train Loss=0.000205532 | Test Loss=0.003070712 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [243/1000] | Train Loss=0.000208845 | Test Loss=0.003052384 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [244/1000] | Train Loss=0.000211978 | Test Loss=0.003112264 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [245/1000] | Train Loss=0.000201044 | Test Loss=0.003055391 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [246/1000] | Train Loss=0.000218844 | Test Loss=0.003069172 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [247/1000] | Train Loss=0.000205320 | Test Loss=0.003108476 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [248/1000] | Train Loss=0.000213455 | Test Loss=0.003131603 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [249/1000] | Train Loss=0.000213967 | Test Loss=0.003005963 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [250/1000] | Train Loss=0.000241984 | Test Loss=0.003046326 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [251/1000] | Train Loss=0.000204261 | Test Loss=0.003076949 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [252/1000] | Train Loss=0.000207923 | Test Loss=0.003112959 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [253/1000] | Train Loss=0.000200132 | Test Loss=0.003079909 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [254/1000] | Train Loss=0.000194766 | Test Loss=0.003082060 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [255/1000] | Train Loss=0.000189706 | Test Loss=0.003054197 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [256/1000] | Train Loss=0.000221067 | Test Loss=0.003105371 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [257/1000] | Train Loss=0.000210943 | Test Loss=0.003075079 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [258/1000] | Train Loss=0.000207664 | Test Loss=0.003055349 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [259/1000] | Train Loss=0.000204355 | Test Loss=0.003088344 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [260/1000] | Train Loss=0.000220856 | Test Loss=0.003060853 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [261/1000] | Train Loss=0.000241440 | Test Loss=0.003036822 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [262/1000] | Train Loss=0.000207489 | Test Loss=0.003106468 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [263/1000] | Train Loss=0.000218968 | Test Loss=0.003062326 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [264/1000] | Train Loss=0.000185924 | Test Loss=0.003048141 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [265/1000] | Train Loss=0.000189438 | Test Loss=0.003039651 | Time=1.70s | LR=1.25e-05\n",
      "Epoch [266/1000] | Train Loss=0.000241807 | Test Loss=0.003055182 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [267/1000] | Train Loss=0.000210006 | Test Loss=0.003073888 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [268/1000] | Train Loss=0.000205688 | Test Loss=0.003027322 | Time=1.68s | LR=1.25e-05\n",
      "Epoch [269/1000] | Train Loss=0.000233154 | Test Loss=0.003083770 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [270/1000] | Train Loss=0.000212701 | Test Loss=0.003026119 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [271/1000] | Train Loss=0.000200413 | Test Loss=0.003078077 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [272/1000] | Train Loss=0.000197469 | Test Loss=0.003067186 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [273/1000] | Train Loss=0.000193027 | Test Loss=0.003047734 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [274/1000] | Train Loss=0.000208335 | Test Loss=0.003077521 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [275/1000] | Train Loss=0.000195002 | Test Loss=0.003055331 | Time=1.56s | LR=1.25e-05\n",
      "Epoch [276/1000] | Train Loss=0.000184277 | Test Loss=0.003029865 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [277/1000] | Train Loss=0.000193951 | Test Loss=0.003086220 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [278/1000] | Train Loss=0.000190275 | Test Loss=0.003030233 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [279/1000] | Train Loss=0.000202591 | Test Loss=0.003048120 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [280/1000] | Train Loss=0.000216153 | Test Loss=0.003041423 | Time=1.68s | LR=1.25e-05\n",
      "Epoch [281/1000] | Train Loss=0.000222005 | Test Loss=0.003039201 | Time=1.57s | LR=1.25e-05\n",
      "Epoch [282/1000] | Train Loss=0.000211466 | Test Loss=0.003081945 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [283/1000] | Train Loss=0.000213572 | Test Loss=0.003015761 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [284/1000] | Train Loss=0.000220258 | Test Loss=0.003058423 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [285/1000] | Train Loss=0.000205480 | Test Loss=0.003051414 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [286/1000] | Train Loss=0.000216080 | Test Loss=0.003094207 | Time=1.68s | LR=1.25e-05\n",
      "Epoch [287/1000] | Train Loss=0.000207428 | Test Loss=0.003058446 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [288/1000] | Train Loss=0.000231326 | Test Loss=0.003078020 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [289/1000] | Train Loss=0.000226671 | Test Loss=0.003044737 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [290/1000] | Train Loss=0.000191371 | Test Loss=0.003069153 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [291/1000] | Train Loss=0.000195487 | Test Loss=0.003080576 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [292/1000] | Train Loss=0.000198194 | Test Loss=0.003124480 | Time=1.70s | LR=1.25e-05\n",
      "Epoch [293/1000] | Train Loss=0.000215836 | Test Loss=0.003077287 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [294/1000] | Train Loss=0.000222415 | Test Loss=0.003004482 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [295/1000] | Train Loss=0.000213934 | Test Loss=0.003101845 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [296/1000] | Train Loss=0.000208502 | Test Loss=0.003035947 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [297/1000] | Train Loss=0.000194530 | Test Loss=0.003036020 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [298/1000] | Train Loss=0.000191230 | Test Loss=0.003006677 | Time=1.68s | LR=1.25e-05\n",
      "Epoch [299/1000] | Train Loss=0.000206954 | Test Loss=0.003043436 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [300/1000] | Train Loss=0.000210448 | Test Loss=0.003048489 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [301/1000] | Train Loss=0.000206703 | Test Loss=0.003063199 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [302/1000] | Train Loss=0.000202940 | Test Loss=0.003060536 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [303/1000] | Train Loss=0.000208007 | Test Loss=0.003059748 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [304/1000] | Train Loss=0.000231926 | Test Loss=0.003057111 | Time=1.68s | LR=1.25e-05\n",
      "Epoch [305/1000] | Train Loss=0.000206481 | Test Loss=0.003060494 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [306/1000] | Train Loss=0.000187920 | Test Loss=0.003023476 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [307/1000] | Train Loss=0.000214569 | Test Loss=0.003024664 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [308/1000] | Train Loss=0.000208648 | Test Loss=0.003029802 | Time=1.72s | LR=1.25e-05\n",
      "Epoch [309/1000] | Train Loss=0.000189556 | Test Loss=0.003024473 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [310/1000] | Train Loss=0.000199399 | Test Loss=0.003059651 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [311/1000] | Train Loss=0.000202676 | Test Loss=0.003034615 | Time=1.58s | LR=1.25e-05\n",
      "Epoch [312/1000] | Train Loss=0.000192171 | Test Loss=0.003025210 | Time=1.67s | LR=1.25e-05\n",
      "Epoch [313/1000] | Train Loss=0.000191496 | Test Loss=0.003020554 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [314/1000] | Train Loss=0.000196623 | Test Loss=0.003025847 | Time=1.71s | LR=1.25e-05\n",
      "Epoch [315/1000] | Train Loss=0.000228862 | Test Loss=0.003072654 | Time=1.66s | LR=1.25e-05\n",
      "Epoch [316/1000] | Train Loss=0.000192183 | Test Loss=0.003026186 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [317/1000] | Train Loss=0.000212677 | Test Loss=0.003031138 | Time=1.58s | LR=6.25e-06\n",
      "Epoch [318/1000] | Train Loss=0.000174783 | Test Loss=0.003042847 | Time=1.67s | LR=6.25e-06\n",
      "Epoch [319/1000] | Train Loss=0.000175410 | Test Loss=0.003038484 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [320/1000] | Train Loss=0.000177082 | Test Loss=0.003039913 | Time=1.71s | LR=6.25e-06\n",
      "Epoch [321/1000] | Train Loss=0.000179165 | Test Loss=0.003037766 | Time=1.66s | LR=6.25e-06\n",
      "Epoch [322/1000] | Train Loss=0.000176464 | Test Loss=0.003037936 | Time=1.68s | LR=6.25e-06\n",
      "Epoch [323/1000] | Train Loss=0.000179811 | Test Loss=0.003044504 | Time=1.58s | LR=6.25e-06\n",
      "Epoch [324/1000] | Train Loss=0.000181375 | Test Loss=0.003038656 | Time=1.67s | LR=6.25e-06\n",
      "Epoch [325/1000] | Train Loss=0.000181653 | Test Loss=0.003048512 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [326/1000] | Train Loss=0.000183860 | Test Loss=0.003033103 | Time=1.71s | LR=6.25e-06\n",
      "Epoch [327/1000] | Train Loss=0.000179366 | Test Loss=0.003062651 | Time=1.66s | LR=6.25e-06\n",
      "Epoch [328/1000] | Train Loss=0.000180511 | Test Loss=0.003043652 | Time=1.68s | LR=6.25e-06\n",
      "Epoch [329/1000] | Train Loss=0.000177481 | Test Loss=0.003058691 | Time=1.58s | LR=6.25e-06\n",
      "Epoch [330/1000] | Train Loss=0.000186412 | Test Loss=0.003046177 | Time=1.68s | LR=6.25e-06\n",
      "Epoch [331/1000] | Train Loss=0.000181027 | Test Loss=0.003024873 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [332/1000] | Train Loss=0.000189243 | Test Loss=0.003026671 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [333/1000] | Train Loss=0.000178450 | Test Loss=0.003034794 | Time=1.84s | LR=6.25e-06\n",
      "Epoch [334/1000] | Train Loss=0.000178073 | Test Loss=0.003018204 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [335/1000] | Train Loss=0.000183913 | Test Loss=0.003024440 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [336/1000] | Train Loss=0.000186726 | Test Loss=0.003024668 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [337/1000] | Train Loss=0.000183124 | Test Loss=0.003032318 | Time=1.78s | LR=6.25e-06\n",
      "Epoch [338/1000] | Train Loss=0.000185335 | Test Loss=0.003072860 | Time=1.84s | LR=6.25e-06\n",
      "Epoch [339/1000] | Train Loss=0.000190193 | Test Loss=0.003026000 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [340/1000] | Train Loss=0.000193444 | Test Loss=0.003054591 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [341/1000] | Train Loss=0.000183698 | Test Loss=0.003024034 | Time=1.82s | LR=6.25e-06\n",
      "Epoch [342/1000] | Train Loss=0.000180623 | Test Loss=0.003041183 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [343/1000] | Train Loss=0.000184972 | Test Loss=0.003040082 | Time=1.81s | LR=6.25e-06\n",
      "Epoch [344/1000] | Train Loss=0.000181730 | Test Loss=0.003010525 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [345/1000] | Train Loss=0.000187512 | Test Loss=0.003035483 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [346/1000] | Train Loss=0.000186346 | Test Loss=0.003077194 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [347/1000] | Train Loss=0.000184493 | Test Loss=0.003030382 | Time=1.85s | LR=6.25e-06\n",
      "Epoch [348/1000] | Train Loss=0.000184182 | Test Loss=0.003018588 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [349/1000] | Train Loss=0.000186498 | Test Loss=0.003035248 | Time=1.84s | LR=6.25e-06\n",
      "Epoch [350/1000] | Train Loss=0.000187085 | Test Loss=0.003049006 | Time=1.85s | LR=6.25e-06\n",
      "Epoch [351/1000] | Train Loss=0.000183191 | Test Loss=0.003050336 | Time=1.86s | LR=6.25e-06\n",
      "Epoch [352/1000] | Train Loss=0.000192440 | Test Loss=0.003029228 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [353/1000] | Train Loss=0.000180454 | Test Loss=0.003038138 | Time=1.88s | LR=6.25e-06\n",
      "Epoch [354/1000] | Train Loss=0.000181400 | Test Loss=0.003031726 | Time=1.88s | LR=6.25e-06\n",
      "Epoch [355/1000] | Train Loss=0.000176852 | Test Loss=0.003023191 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [356/1000] | Train Loss=0.000187285 | Test Loss=0.003030638 | Time=1.87s | LR=6.25e-06\n",
      "Epoch [357/1000] | Train Loss=0.000180625 | Test Loss=0.003034629 | Time=1.84s | LR=6.25e-06\n",
      "Epoch [358/1000] | Train Loss=0.000179786 | Test Loss=0.003030048 | Time=1.83s | LR=6.25e-06\n",
      "Epoch [359/1000] | Train Loss=0.000180735 | Test Loss=0.003050997 | Time=1.79s | LR=3.13e-06\n",
      "Epoch [360/1000] | Train Loss=0.000175383 | Test Loss=0.003030969 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [361/1000] | Train Loss=0.000178419 | Test Loss=0.003029530 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [362/1000] | Train Loss=0.000178043 | Test Loss=0.003030412 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [363/1000] | Train Loss=0.000172277 | Test Loss=0.003051305 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [364/1000] | Train Loss=0.000171449 | Test Loss=0.003045107 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [365/1000] | Train Loss=0.000178363 | Test Loss=0.003049198 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [366/1000] | Train Loss=0.000177157 | Test Loss=0.003036659 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [367/1000] | Train Loss=0.000175393 | Test Loss=0.003048855 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [368/1000] | Train Loss=0.000175951 | Test Loss=0.003039521 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [369/1000] | Train Loss=0.000174545 | Test Loss=0.003037119 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [370/1000] | Train Loss=0.000176390 | Test Loss=0.003022479 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [371/1000] | Train Loss=0.000176012 | Test Loss=0.003017433 | Time=1.85s | LR=3.13e-06\n",
      "Epoch [372/1000] | Train Loss=0.000176016 | Test Loss=0.003027995 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [373/1000] | Train Loss=0.000173485 | Test Loss=0.003031316 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [374/1000] | Train Loss=0.000172792 | Test Loss=0.003028470 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [375/1000] | Train Loss=0.000173456 | Test Loss=0.003024027 | Time=1.79s | LR=3.13e-06\n",
      "Epoch [376/1000] | Train Loss=0.000174533 | Test Loss=0.003027387 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [377/1000] | Train Loss=0.000175018 | Test Loss=0.003028012 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [378/1000] | Train Loss=0.000173036 | Test Loss=0.003031390 | Time=1.83s | LR=3.13e-06\n",
      "Epoch [379/1000] | Train Loss=0.000171132 | Test Loss=0.003038439 | Time=1.83s | LR=3.13e-06\n",
      "Epoch [380/1000] | Train Loss=0.000174751 | Test Loss=0.003017821 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [381/1000] | Train Loss=0.000173925 | Test Loss=0.003039964 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [382/1000] | Train Loss=0.000173323 | Test Loss=0.003046244 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [383/1000] | Train Loss=0.000175465 | Test Loss=0.003024210 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [384/1000] | Train Loss=0.000175113 | Test Loss=0.003045356 | Time=1.85s | LR=3.13e-06\n",
      "Epoch [385/1000] | Train Loss=0.000183419 | Test Loss=0.003047074 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [386/1000] | Train Loss=0.000175694 | Test Loss=0.003032515 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [387/1000] | Train Loss=0.000175144 | Test Loss=0.003046477 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [388/1000] | Train Loss=0.000175464 | Test Loss=0.003029979 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [389/1000] | Train Loss=0.000176722 | Test Loss=0.003045042 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [390/1000] | Train Loss=0.000171723 | Test Loss=0.003029192 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [391/1000] | Train Loss=0.000174524 | Test Loss=0.003026417 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [392/1000] | Train Loss=0.000178002 | Test Loss=0.003037211 | Time=1.83s | LR=3.13e-06\n",
      "Epoch [393/1000] | Train Loss=0.000176081 | Test Loss=0.003040840 | Time=1.83s | LR=3.13e-06\n",
      "Epoch [394/1000] | Train Loss=0.000175746 | Test Loss=0.003052206 | Time=1.83s | LR=3.13e-06\n",
      "Epoch [395/1000] | Train Loss=0.000172405 | Test Loss=0.003025903 | Time=1.82s | LR=3.13e-06\n",
      "Epoch [396/1000] | Train Loss=0.000173237 | Test Loss=0.003034176 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [397/1000] | Train Loss=0.000173993 | Test Loss=0.003024618 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [398/1000] | Train Loss=0.000176128 | Test Loss=0.003035901 | Time=1.85s | LR=3.13e-06\n",
      "Epoch [399/1000] | Train Loss=0.000172704 | Test Loss=0.003026595 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [400/1000] | Train Loss=0.000174295 | Test Loss=0.003034467 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [401/1000] | Train Loss=0.000173372 | Test Loss=0.003027771 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [402/1000] | Train Loss=0.000178177 | Test Loss=0.003035022 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [403/1000] | Train Loss=0.000176018 | Test Loss=0.003017950 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [404/1000] | Train Loss=0.000171858 | Test Loss=0.003037425 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [405/1000] | Train Loss=0.000175827 | Test Loss=0.003027893 | Time=1.85s | LR=3.13e-06\n",
      "Epoch [406/1000] | Train Loss=0.000175219 | Test Loss=0.003045560 | Time=1.86s | LR=3.13e-06\n",
      "Epoch [407/1000] | Train Loss=0.000175187 | Test Loss=0.003050024 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [408/1000] | Train Loss=0.000174709 | Test Loss=0.003027777 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [409/1000] | Train Loss=0.000174812 | Test Loss=0.003039631 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [410/1000] | Train Loss=0.000173908 | Test Loss=0.003042064 | Time=1.81s | LR=3.13e-06\n",
      "Epoch [411/1000] | Train Loss=0.000173468 | Test Loss=0.003039457 | Time=1.84s | LR=3.13e-06\n",
      "Epoch [412/1000] | Train Loss=0.000176469 | Test Loss=0.003039387 | Time=1.85s | LR=3.13e-06\n",
      "Epoch [413/1000] | Train Loss=0.000175701 | Test Loss=0.003016683 | Time=1.88s | LR=3.13e-06\n",
      "Epoch [414/1000] | Train Loss=0.000173066 | Test Loss=0.003027158 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [415/1000] | Train Loss=0.000174493 | Test Loss=0.003030645 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [416/1000] | Train Loss=0.000175284 | Test Loss=0.003021685 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [417/1000] | Train Loss=0.000172604 | Test Loss=0.003037224 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [418/1000] | Train Loss=0.000175229 | Test Loss=0.003052212 | Time=1.87s | LR=3.13e-06\n",
      "Epoch [419/1000] | Train Loss=0.000175343 | Test Loss=0.003027422 | Time=1.85s | LR=3.13e-06\n",
      "Epoch [420/1000] | Train Loss=0.000173506 | Test Loss=0.003054185 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [421/1000] | Train Loss=0.000169983 | Test Loss=0.003034237 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [422/1000] | Train Loss=0.000170522 | Test Loss=0.003037237 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [423/1000] | Train Loss=0.000171949 | Test Loss=0.003030378 | Time=1.88s | LR=1.56e-06\n",
      "Epoch [424/1000] | Train Loss=0.000168898 | Test Loss=0.003033822 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [425/1000] | Train Loss=0.000170858 | Test Loss=0.003033687 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [426/1000] | Train Loss=0.000169793 | Test Loss=0.003037724 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [427/1000] | Train Loss=0.000167981 | Test Loss=0.003030015 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [428/1000] | Train Loss=0.000170722 | Test Loss=0.003040217 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [429/1000] | Train Loss=0.000171711 | Test Loss=0.003033657 | Time=1.88s | LR=1.56e-06\n",
      "Epoch [430/1000] | Train Loss=0.000172310 | Test Loss=0.003027247 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [431/1000] | Train Loss=0.000167257 | Test Loss=0.003030230 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [432/1000] | Train Loss=0.000168883 | Test Loss=0.003032331 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [433/1000] | Train Loss=0.000169825 | Test Loss=0.003033171 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [434/1000] | Train Loss=0.000169705 | Test Loss=0.003032228 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [435/1000] | Train Loss=0.000170494 | Test Loss=0.003026543 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [436/1000] | Train Loss=0.000171929 | Test Loss=0.003038808 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [437/1000] | Train Loss=0.000168924 | Test Loss=0.003029086 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [438/1000] | Train Loss=0.000171042 | Test Loss=0.003027189 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [439/1000] | Train Loss=0.000170325 | Test Loss=0.003029832 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [440/1000] | Train Loss=0.000170149 | Test Loss=0.003029854 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [441/1000] | Train Loss=0.000168454 | Test Loss=0.003033533 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [442/1000] | Train Loss=0.000170775 | Test Loss=0.003036118 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [443/1000] | Train Loss=0.000170499 | Test Loss=0.003037014 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [444/1000] | Train Loss=0.000171053 | Test Loss=0.003035757 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [445/1000] | Train Loss=0.000169299 | Test Loss=0.003038427 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [446/1000] | Train Loss=0.000169357 | Test Loss=0.003031270 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [447/1000] | Train Loss=0.000170452 | Test Loss=0.003035642 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [448/1000] | Train Loss=0.000171975 | Test Loss=0.003035760 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [449/1000] | Train Loss=0.000170225 | Test Loss=0.003037169 | Time=1.85s | LR=1.56e-06\n",
      "Epoch [450/1000] | Train Loss=0.000169311 | Test Loss=0.003034987 | Time=1.86s | LR=1.56e-06\n",
      "Epoch [451/1000] | Train Loss=0.000168360 | Test Loss=0.003031248 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [452/1000] | Train Loss=0.000168745 | Test Loss=0.003031717 | Time=1.88s | LR=1.56e-06\n",
      "Epoch [453/1000] | Train Loss=0.000171505 | Test Loss=0.003046466 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [454/1000] | Train Loss=0.000169203 | Test Loss=0.003030527 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [455/1000] | Train Loss=0.000170062 | Test Loss=0.003024647 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [456/1000] | Train Loss=0.000170718 | Test Loss=0.003032606 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [457/1000] | Train Loss=0.000170347 | Test Loss=0.003032244 | Time=1.85s | LR=1.56e-06\n",
      "Epoch [458/1000] | Train Loss=0.000169391 | Test Loss=0.003029325 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [459/1000] | Train Loss=0.000170428 | Test Loss=0.003039005 | Time=1.87s | LR=1.56e-06\n",
      "Epoch [460/1000] | Train Loss=0.000170856 | Test Loss=0.003033250 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [461/1000] | Train Loss=0.000171760 | Test Loss=0.003034594 | Time=1.78s | LR=1.56e-06\n",
      "Epoch [462/1000] | Train Loss=0.000170931 | Test Loss=0.003029357 | Time=1.83s | LR=1.56e-06\n",
      "Epoch [463/1000] | Train Loss=0.000169324 | Test Loss=0.003028513 | Time=1.83s | LR=1.56e-06\n",
      "Epoch [464/1000] | Train Loss=0.000169832 | Test Loss=0.003029117 | Time=1.83s | LR=1.56e-06\n",
      "Epoch [465/1000] | Train Loss=0.000169971 | Test Loss=0.003028063 | Time=1.83s | LR=1.56e-06\n",
      "Epoch [466/1000] | Train Loss=0.000172079 | Test Loss=0.003028999 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [467/1000] | Train Loss=0.000170703 | Test Loss=0.003026888 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [468/1000] | Train Loss=0.000168640 | Test Loss=0.003027111 | Time=1.84s | LR=1.56e-06\n",
      "Epoch [469/1000] | Train Loss=0.000168447 | Test Loss=0.003029577 | Time=1.81s | LR=1.56e-06\n",
      "Epoch [470/1000] | Train Loss=0.000170150 | Test Loss=0.003024625 | Time=1.83s | LR=1.56e-06\n",
      "Epoch [471/1000] | Train Loss=0.000169792 | Test Loss=0.003027583 | Time=1.82s | LR=1.56e-06\n",
      "Epoch [472/1000] | Train Loss=0.000169939 | Test Loss=0.003031588 | Time=1.79s | LR=7.81e-07\n",
      "Epoch [473/1000] | Train Loss=0.000167902 | Test Loss=0.003028563 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [474/1000] | Train Loss=0.000168240 | Test Loss=0.003028081 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [475/1000] | Train Loss=0.000169957 | Test Loss=0.003032340 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [476/1000] | Train Loss=0.000168635 | Test Loss=0.003037086 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [477/1000] | Train Loss=0.000166958 | Test Loss=0.003026504 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [478/1000] | Train Loss=0.000168764 | Test Loss=0.003031653 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [479/1000] | Train Loss=0.000168276 | Test Loss=0.003028185 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [480/1000] | Train Loss=0.000169260 | Test Loss=0.003027514 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [481/1000] | Train Loss=0.000169694 | Test Loss=0.003029795 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [482/1000] | Train Loss=0.000166754 | Test Loss=0.003024750 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [483/1000] | Train Loss=0.000168876 | Test Loss=0.003028984 | Time=1.78s | LR=7.81e-07\n",
      "Epoch [484/1000] | Train Loss=0.000167378 | Test Loss=0.003029525 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [485/1000] | Train Loss=0.000166593 | Test Loss=0.003025307 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [486/1000] | Train Loss=0.000170251 | Test Loss=0.003025708 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [487/1000] | Train Loss=0.000166602 | Test Loss=0.003026284 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [488/1000] | Train Loss=0.000168341 | Test Loss=0.003035252 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [489/1000] | Train Loss=0.000170198 | Test Loss=0.003021285 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [490/1000] | Train Loss=0.000167517 | Test Loss=0.003029194 | Time=1.80s | LR=7.81e-07\n",
      "Epoch [491/1000] | Train Loss=0.000169320 | Test Loss=0.003035088 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [492/1000] | Train Loss=0.000170768 | Test Loss=0.003018865 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [493/1000] | Train Loss=0.000169794 | Test Loss=0.003024087 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [494/1000] | Train Loss=0.000168576 | Test Loss=0.003022735 | Time=1.88s | LR=7.81e-07\n",
      "Epoch [495/1000] | Train Loss=0.000167847 | Test Loss=0.003028075 | Time=1.88s | LR=7.81e-07\n",
      "Epoch [496/1000] | Train Loss=0.000168499 | Test Loss=0.003021713 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [497/1000] | Train Loss=0.000168419 | Test Loss=0.003026864 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [498/1000] | Train Loss=0.000171895 | Test Loss=0.003029277 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [499/1000] | Train Loss=0.000168585 | Test Loss=0.003022330 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [500/1000] | Train Loss=0.000168322 | Test Loss=0.003019334 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [501/1000] | Train Loss=0.000168872 | Test Loss=0.003016991 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [502/1000] | Train Loss=0.000167632 | Test Loss=0.003026209 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [503/1000] | Train Loss=0.000168563 | Test Loss=0.003023264 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [504/1000] | Train Loss=0.000169065 | Test Loss=0.003014648 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [505/1000] | Train Loss=0.000169080 | Test Loss=0.003023592 | Time=1.79s | LR=7.81e-07\n",
      "Epoch [506/1000] | Train Loss=0.000170118 | Test Loss=0.003016139 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [507/1000] | Train Loss=0.000169770 | Test Loss=0.003026708 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [508/1000] | Train Loss=0.000167531 | Test Loss=0.003018336 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [509/1000] | Train Loss=0.000168611 | Test Loss=0.003016455 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [510/1000] | Train Loss=0.000168838 | Test Loss=0.003017061 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [511/1000] | Train Loss=0.000170028 | Test Loss=0.003025497 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [512/1000] | Train Loss=0.000167698 | Test Loss=0.003028471 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [513/1000] | Train Loss=0.000168874 | Test Loss=0.003011178 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [514/1000] | Train Loss=0.000167610 | Test Loss=0.003011258 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [515/1000] | Train Loss=0.000167961 | Test Loss=0.003019797 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [516/1000] | Train Loss=0.000166557 | Test Loss=0.003021278 | Time=1.80s | LR=7.81e-07\n",
      "Epoch [517/1000] | Train Loss=0.000166937 | Test Loss=0.003022694 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [518/1000] | Train Loss=0.000168606 | Test Loss=0.003022593 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [519/1000] | Train Loss=0.000171099 | Test Loss=0.003022530 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [520/1000] | Train Loss=0.000166585 | Test Loss=0.003019951 | Time=1.80s | LR=7.81e-07\n",
      "Epoch [521/1000] | Train Loss=0.000169800 | Test Loss=0.003021081 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [522/1000] | Train Loss=0.000168189 | Test Loss=0.003016309 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [523/1000] | Train Loss=0.000168989 | Test Loss=0.003018182 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [524/1000] | Train Loss=0.000167628 | Test Loss=0.003017392 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [525/1000] | Train Loss=0.000167558 | Test Loss=0.003008846 | Time=1.81s | LR=7.81e-07\n",
      "Epoch [526/1000] | Train Loss=0.000168273 | Test Loss=0.003019325 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [527/1000] | Train Loss=0.000170353 | Test Loss=0.003033295 | Time=1.88s | LR=7.81e-07\n",
      "Epoch [528/1000] | Train Loss=0.000167851 | Test Loss=0.003012115 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [529/1000] | Train Loss=0.000169154 | Test Loss=0.003017900 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [530/1000] | Train Loss=0.000169358 | Test Loss=0.003018841 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [531/1000] | Train Loss=0.000168422 | Test Loss=0.003017822 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [532/1000] | Train Loss=0.000168383 | Test Loss=0.003017232 | Time=1.79s | LR=7.81e-07\n",
      "Epoch [533/1000] | Train Loss=0.000168510 | Test Loss=0.003019830 | Time=1.84s | LR=7.81e-07\n",
      "Epoch [534/1000] | Train Loss=0.000169156 | Test Loss=0.003016179 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [535/1000] | Train Loss=0.000168212 | Test Loss=0.003012401 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [536/1000] | Train Loss=0.000168298 | Test Loss=0.003029565 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [537/1000] | Train Loss=0.000169508 | Test Loss=0.003011317 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [538/1000] | Train Loss=0.000166696 | Test Loss=0.003011643 | Time=1.80s | LR=7.81e-07\n",
      "Epoch [539/1000] | Train Loss=0.000169580 | Test Loss=0.003018046 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [540/1000] | Train Loss=0.000170368 | Test Loss=0.003017887 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [541/1000] | Train Loss=0.000169207 | Test Loss=0.003011739 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [542/1000] | Train Loss=0.000168500 | Test Loss=0.003018063 | Time=1.85s | LR=7.81e-07\n",
      "Epoch [543/1000] | Train Loss=0.000168024 | Test Loss=0.003018141 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [544/1000] | Train Loss=0.000167132 | Test Loss=0.003014073 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [545/1000] | Train Loss=0.000166620 | Test Loss=0.003008547 | Time=1.85s | LR=7.81e-07\n",
      "Epoch [546/1000] | Train Loss=0.000168821 | Test Loss=0.003016382 | Time=1.86s | LR=7.81e-07\n",
      "Epoch [547/1000] | Train Loss=0.000168829 | Test Loss=0.003004058 | Time=1.87s | LR=7.81e-07\n",
      "Epoch [548/1000] | Train Loss=0.000169994 | Test Loss=0.003012387 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [549/1000] | Train Loss=0.000169607 | Test Loss=0.003011413 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [550/1000] | Train Loss=0.000167619 | Test Loss=0.003012868 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [551/1000] | Train Loss=0.000169628 | Test Loss=0.003017535 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [552/1000] | Train Loss=0.000168367 | Test Loss=0.003013526 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [553/1000] | Train Loss=0.000170410 | Test Loss=0.003011633 | Time=1.83s | LR=7.81e-07\n",
      "Epoch [554/1000] | Train Loss=0.000168791 | Test Loss=0.003022510 | Time=1.79s | LR=7.81e-07\n",
      "Epoch [555/1000] | Train Loss=0.000168508 | Test Loss=0.003016501 | Time=1.82s | LR=7.81e-07\n",
      "Epoch [556/1000] | Train Loss=0.000168924 | Test Loss=0.003013559 | Time=1.79s | LR=7.81e-07\n",
      "Epoch [557/1000] | Train Loss=0.000168077 | Test Loss=0.003014095 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [558/1000] | Train Loss=0.000168252 | Test Loss=0.003016068 | Time=1.83s | LR=3.91e-07\n",
      "Epoch [559/1000] | Train Loss=0.000167609 | Test Loss=0.003016488 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [560/1000] | Train Loss=0.000167211 | Test Loss=0.003012940 | Time=1.88s | LR=3.91e-07\n",
      "Epoch [561/1000] | Train Loss=0.000166302 | Test Loss=0.003015261 | Time=1.88s | LR=3.91e-07\n",
      "Epoch [562/1000] | Train Loss=0.000167577 | Test Loss=0.003017012 | Time=1.88s | LR=3.91e-07\n",
      "Epoch [563/1000] | Train Loss=0.000167660 | Test Loss=0.003015826 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [564/1000] | Train Loss=0.000166860 | Test Loss=0.003015599 | Time=1.85s | LR=3.91e-07\n",
      "Epoch [565/1000] | Train Loss=0.000169469 | Test Loss=0.003011619 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [566/1000] | Train Loss=0.000168003 | Test Loss=0.003017597 | Time=1.83s | LR=3.91e-07\n",
      "Epoch [567/1000] | Train Loss=0.000167327 | Test Loss=0.003015325 | Time=1.83s | LR=3.91e-07\n",
      "Epoch [568/1000] | Train Loss=0.000166979 | Test Loss=0.003010690 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [569/1000] | Train Loss=0.000167485 | Test Loss=0.003012788 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [570/1000] | Train Loss=0.000168147 | Test Loss=0.003015052 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [571/1000] | Train Loss=0.000167786 | Test Loss=0.003016908 | Time=1.83s | LR=3.91e-07\n",
      "Epoch [572/1000] | Train Loss=0.000169511 | Test Loss=0.003011953 | Time=1.83s | LR=3.91e-07\n",
      "Epoch [573/1000] | Train Loss=0.000169107 | Test Loss=0.003013926 | Time=1.75s | LR=3.91e-07\n",
      "Epoch [574/1000] | Train Loss=0.000166912 | Test Loss=0.003018584 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [575/1000] | Train Loss=0.000166234 | Test Loss=0.003006877 | Time=1.61s | LR=3.91e-07\n",
      "Epoch [576/1000] | Train Loss=0.000166939 | Test Loss=0.003013750 | Time=1.71s | LR=3.91e-07\n",
      "Epoch [577/1000] | Train Loss=0.000167144 | Test Loss=0.003014598 | Time=1.68s | LR=3.91e-07\n",
      "Epoch [578/1000] | Train Loss=0.000167249 | Test Loss=0.003013971 | Time=1.61s | LR=3.91e-07\n",
      "Epoch [579/1000] | Train Loss=0.000168123 | Test Loss=0.003014694 | Time=1.68s | LR=3.91e-07\n",
      "Epoch [580/1000] | Train Loss=0.000169221 | Test Loss=0.003012156 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [581/1000] | Train Loss=0.000168654 | Test Loss=0.003019605 | Time=1.61s | LR=3.91e-07\n",
      "Epoch [582/1000] | Train Loss=0.000167397 | Test Loss=0.003007392 | Time=1.71s | LR=3.91e-07\n",
      "Epoch [583/1000] | Train Loss=0.000167401 | Test Loss=0.003014844 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [584/1000] | Train Loss=0.000167154 | Test Loss=0.003017367 | Time=1.61s | LR=3.91e-07\n",
      "Epoch [585/1000] | Train Loss=0.000167721 | Test Loss=0.003011668 | Time=1.68s | LR=3.91e-07\n",
      "Epoch [586/1000] | Train Loss=0.000166940 | Test Loss=0.003015843 | Time=1.70s | LR=3.91e-07\n",
      "Epoch [587/1000] | Train Loss=0.000168590 | Test Loss=0.003018290 | Time=1.61s | LR=3.91e-07\n",
      "Epoch [588/1000] | Train Loss=0.000166472 | Test Loss=0.003018341 | Time=1.75s | LR=3.91e-07\n",
      "Epoch [589/1000] | Train Loss=0.000167524 | Test Loss=0.003017975 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [590/1000] | Train Loss=0.000167199 | Test Loss=0.003014050 | Time=1.85s | LR=3.91e-07\n",
      "Epoch [591/1000] | Train Loss=0.000169329 | Test Loss=0.003007208 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [592/1000] | Train Loss=0.000166990 | Test Loss=0.003009918 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [593/1000] | Train Loss=0.000167629 | Test Loss=0.003012530 | Time=1.91s | LR=3.91e-07\n",
      "Epoch [594/1000] | Train Loss=0.000168392 | Test Loss=0.003012011 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [595/1000] | Train Loss=0.000167960 | Test Loss=0.003018513 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [596/1000] | Train Loss=0.000166273 | Test Loss=0.003013282 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [597/1000] | Train Loss=0.000167812 | Test Loss=0.003020252 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [598/1000] | Train Loss=0.000167409 | Test Loss=0.003013688 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [599/1000] | Train Loss=0.000168270 | Test Loss=0.003014887 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [600/1000] | Train Loss=0.000167312 | Test Loss=0.003010607 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [601/1000] | Train Loss=0.000167850 | Test Loss=0.003021097 | Time=1.88s | LR=3.91e-07\n",
      "Epoch [602/1000] | Train Loss=0.000166772 | Test Loss=0.003018141 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [603/1000] | Train Loss=0.000168959 | Test Loss=0.003013999 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [604/1000] | Train Loss=0.000167763 | Test Loss=0.003015888 | Time=1.75s | LR=3.91e-07\n",
      "Epoch [605/1000] | Train Loss=0.000168116 | Test Loss=0.003014241 | Time=1.80s | LR=3.91e-07\n",
      "Epoch [606/1000] | Train Loss=0.000166516 | Test Loss=0.003012893 | Time=1.85s | LR=3.91e-07\n",
      "Epoch [607/1000] | Train Loss=0.000166165 | Test Loss=0.003013510 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [608/1000] | Train Loss=0.000169850 | Test Loss=0.003011670 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [609/1000] | Train Loss=0.000167136 | Test Loss=0.003011449 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [610/1000] | Train Loss=0.000166351 | Test Loss=0.003017718 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [611/1000] | Train Loss=0.000167372 | Test Loss=0.003006826 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [612/1000] | Train Loss=0.000168931 | Test Loss=0.003016014 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [613/1000] | Train Loss=0.000167929 | Test Loss=0.003011111 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [614/1000] | Train Loss=0.000167396 | Test Loss=0.003008153 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [615/1000] | Train Loss=0.000168112 | Test Loss=0.003009334 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [616/1000] | Train Loss=0.000165267 | Test Loss=0.003009115 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [617/1000] | Train Loss=0.000169184 | Test Loss=0.003016516 | Time=1.89s | LR=3.91e-07\n",
      "Epoch [618/1000] | Train Loss=0.000166625 | Test Loss=0.003008751 | Time=1.90s | LR=3.91e-07\n",
      "Epoch [619/1000] | Train Loss=0.000167702 | Test Loss=0.003012953 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [620/1000] | Train Loss=0.000166483 | Test Loss=0.003009129 | Time=1.75s | LR=3.91e-07\n",
      "Epoch [621/1000] | Train Loss=0.000166658 | Test Loss=0.003009684 | Time=1.80s | LR=3.91e-07\n",
      "Epoch [622/1000] | Train Loss=0.000166750 | Test Loss=0.003008588 | Time=1.85s | LR=3.91e-07\n",
      "Epoch [623/1000] | Train Loss=0.000167480 | Test Loss=0.003014520 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [624/1000] | Train Loss=0.000166115 | Test Loss=0.003013830 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [625/1000] | Train Loss=0.000166738 | Test Loss=0.003019719 | Time=1.91s | LR=3.91e-07\n",
      "Epoch [626/1000] | Train Loss=0.000169376 | Test Loss=0.003014158 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [627/1000] | Train Loss=0.000167789 | Test Loss=0.003019220 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [628/1000] | Train Loss=0.000165910 | Test Loss=0.003010691 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [629/1000] | Train Loss=0.000166299 | Test Loss=0.003019428 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [630/1000] | Train Loss=0.000165295 | Test Loss=0.003016521 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [631/1000] | Train Loss=0.000170700 | Test Loss=0.003000847 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [632/1000] | Train Loss=0.000166844 | Test Loss=0.003015963 | Time=1.87s | LR=3.91e-07\n",
      "Epoch [633/1000] | Train Loss=0.000166903 | Test Loss=0.003008326 | Time=1.88s | LR=3.91e-07\n",
      "Epoch [634/1000] | Train Loss=0.000166704 | Test Loss=0.003014214 | Time=1.89s | LR=3.91e-07\n",
      "Epoch [635/1000] | Train Loss=0.000166220 | Test Loss=0.003015835 | Time=1.91s | LR=3.91e-07\n",
      "Epoch [636/1000] | Train Loss=0.000168185 | Test Loss=0.003015032 | Time=1.75s | LR=3.91e-07\n",
      "Epoch [637/1000] | Train Loss=0.000168121 | Test Loss=0.003012893 | Time=1.81s | LR=3.91e-07\n",
      "Epoch [638/1000] | Train Loss=0.000166108 | Test Loss=0.003017057 | Time=1.85s | LR=3.91e-07\n",
      "Epoch [639/1000] | Train Loss=0.000168451 | Test Loss=0.003019534 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [640/1000] | Train Loss=0.000167573 | Test Loss=0.003012351 | Time=1.84s | LR=3.91e-07\n",
      "Epoch [641/1000] | Train Loss=0.000168461 | Test Loss=0.003014622 | Time=1.90s | LR=3.91e-07\n",
      "Epoch [642/1000] | Train Loss=0.000166421 | Test Loss=0.003011803 | Time=1.91s | LR=3.91e-07\n",
      "Epoch [643/1000] | Train Loss=0.000167387 | Test Loss=0.003013401 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [644/1000] | Train Loss=0.000168057 | Test Loss=0.003016356 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [645/1000] | Train Loss=0.000167489 | Test Loss=0.003013745 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [646/1000] | Train Loss=0.000168455 | Test Loss=0.003016969 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [647/1000] | Train Loss=0.000167330 | Test Loss=0.003012601 | Time=1.92s | LR=3.91e-07\n",
      "Epoch [648/1000] | Train Loss=0.000166964 | Test Loss=0.003016533 | Time=1.86s | LR=3.91e-07\n",
      "Epoch [649/1000] | Train Loss=0.000167522 | Test Loss=0.003015949 | Time=1.88s | LR=3.91e-07\n",
      "Epoch [650/1000] | Train Loss=0.000166575 | Test Loss=0.003009758 | Time=1.89s | LR=3.91e-07\n",
      "Epoch [651/1000] | Train Loss=0.000168532 | Test Loss=0.003006478 | Time=1.90s | LR=3.91e-07\n",
      "Epoch [652/1000] | Train Loss=0.000167506 | Test Loss=0.003017741 | Time=1.85s | LR=3.91e-07\n",
      "Epoch [653/1000] | Train Loss=0.000166929 | Test Loss=0.003012973 | Time=1.82s | LR=3.91e-07\n",
      "Epoch [654/1000] | Train Loss=0.000167145 | Test Loss=0.003016390 | Time=1.70s | LR=3.91e-07\n",
      "Epoch [655/1000] | Train Loss=0.000165798 | Test Loss=0.003011921 | Time=1.59s | LR=3.91e-07\n",
      "Epoch [656/1000] | Train Loss=0.000166514 | Test Loss=0.003009560 | Time=1.68s | LR=3.91e-07\n",
      "Epoch [657/1000] | Train Loss=0.000167497 | Test Loss=0.003012388 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [658/1000] | Train Loss=0.000165792 | Test Loss=0.003010300 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [659/1000] | Train Loss=0.000167777 | Test Loss=0.003009205 | Time=1.65s | LR=1.95e-07\n",
      "Epoch [660/1000] | Train Loss=0.000165603 | Test Loss=0.003010579 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [661/1000] | Train Loss=0.000169205 | Test Loss=0.003011680 | Time=1.57s | LR=1.95e-07\n",
      "Epoch [662/1000] | Train Loss=0.000166096 | Test Loss=0.003006541 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [663/1000] | Train Loss=0.000166441 | Test Loss=0.003012182 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [664/1000] | Train Loss=0.000165822 | Test Loss=0.003009187 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [665/1000] | Train Loss=0.000165212 | Test Loss=0.003014617 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [666/1000] | Train Loss=0.000166613 | Test Loss=0.003012125 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [667/1000] | Train Loss=0.000166010 | Test Loss=0.003007937 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [668/1000] | Train Loss=0.000166676 | Test Loss=0.003006536 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [669/1000] | Train Loss=0.000165537 | Test Loss=0.003009119 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [670/1000] | Train Loss=0.000166887 | Test Loss=0.003009208 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [671/1000] | Train Loss=0.000169092 | Test Loss=0.003003432 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [672/1000] | Train Loss=0.000167761 | Test Loss=0.003006257 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [673/1000] | Train Loss=0.000167812 | Test Loss=0.003012559 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [674/1000] | Train Loss=0.000166363 | Test Loss=0.003010015 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [675/1000] | Train Loss=0.000166204 | Test Loss=0.003007977 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [676/1000] | Train Loss=0.000165741 | Test Loss=0.003013421 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [677/1000] | Train Loss=0.000165356 | Test Loss=0.003009547 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [678/1000] | Train Loss=0.000165105 | Test Loss=0.003011336 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [679/1000] | Train Loss=0.000166192 | Test Loss=0.003011598 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [680/1000] | Train Loss=0.000166517 | Test Loss=0.003008319 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [681/1000] | Train Loss=0.000167167 | Test Loss=0.003008067 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [682/1000] | Train Loss=0.000166501 | Test Loss=0.003011921 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [683/1000] | Train Loss=0.000166377 | Test Loss=0.003011635 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [684/1000] | Train Loss=0.000166118 | Test Loss=0.003008166 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [685/1000] | Train Loss=0.000167376 | Test Loss=0.003009171 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [686/1000] | Train Loss=0.000165472 | Test Loss=0.003008501 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [687/1000] | Train Loss=0.000167261 | Test Loss=0.003007850 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [688/1000] | Train Loss=0.000167490 | Test Loss=0.003010891 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [689/1000] | Train Loss=0.000166231 | Test Loss=0.003009966 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [690/1000] | Train Loss=0.000166683 | Test Loss=0.003010151 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [691/1000] | Train Loss=0.000164952 | Test Loss=0.003006892 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [692/1000] | Train Loss=0.000167111 | Test Loss=0.003012021 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [693/1000] | Train Loss=0.000166057 | Test Loss=0.003011540 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [694/1000] | Train Loss=0.000165060 | Test Loss=0.003011825 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [695/1000] | Train Loss=0.000167283 | Test Loss=0.003009010 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [696/1000] | Train Loss=0.000168394 | Test Loss=0.003013991 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [697/1000] | Train Loss=0.000165486 | Test Loss=0.003008898 | Time=1.57s | LR=1.95e-07\n",
      "Epoch [698/1000] | Train Loss=0.000165552 | Test Loss=0.003010452 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [699/1000] | Train Loss=0.000166662 | Test Loss=0.003005264 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [700/1000] | Train Loss=0.000166074 | Test Loss=0.003009809 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [701/1000] | Train Loss=0.000166253 | Test Loss=0.003006826 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [702/1000] | Train Loss=0.000165544 | Test Loss=0.003014633 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [703/1000] | Train Loss=0.000167173 | Test Loss=0.003009014 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [704/1000] | Train Loss=0.000165520 | Test Loss=0.003008971 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [705/1000] | Train Loss=0.000167009 | Test Loss=0.003009450 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [706/1000] | Train Loss=0.000166829 | Test Loss=0.003004201 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [707/1000] | Train Loss=0.000165392 | Test Loss=0.003008797 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [708/1000] | Train Loss=0.000165715 | Test Loss=0.003008890 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [709/1000] | Train Loss=0.000167249 | Test Loss=0.003007463 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [710/1000] | Train Loss=0.000167010 | Test Loss=0.003008507 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [711/1000] | Train Loss=0.000165564 | Test Loss=0.003008077 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [712/1000] | Train Loss=0.000166247 | Test Loss=0.003008480 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [713/1000] | Train Loss=0.000166952 | Test Loss=0.003006307 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [714/1000] | Train Loss=0.000164648 | Test Loss=0.003003736 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [715/1000] | Train Loss=0.000166308 | Test Loss=0.003009109 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [716/1000] | Train Loss=0.000166991 | Test Loss=0.003007265 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [717/1000] | Train Loss=0.000164861 | Test Loss=0.003011095 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [718/1000] | Train Loss=0.000167313 | Test Loss=0.003004600 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [719/1000] | Train Loss=0.000166423 | Test Loss=0.003010725 | Time=1.72s | LR=1.95e-07\n",
      "Epoch [720/1000] | Train Loss=0.000166415 | Test Loss=0.003007142 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [721/1000] | Train Loss=0.000166110 | Test Loss=0.003008594 | Time=1.57s | LR=1.95e-07\n",
      "Epoch [722/1000] | Train Loss=0.000166049 | Test Loss=0.003007566 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [723/1000] | Train Loss=0.000167317 | Test Loss=0.003012389 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [724/1000] | Train Loss=0.000167745 | Test Loss=0.003010039 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [725/1000] | Train Loss=0.000165723 | Test Loss=0.003011305 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [726/1000] | Train Loss=0.000165744 | Test Loss=0.003008723 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [727/1000] | Train Loss=0.000166899 | Test Loss=0.003013044 | Time=1.57s | LR=1.95e-07\n",
      "Epoch [728/1000] | Train Loss=0.000166154 | Test Loss=0.003009962 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [729/1000] | Train Loss=0.000167757 | Test Loss=0.003010666 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [730/1000] | Train Loss=0.000165368 | Test Loss=0.003013344 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [731/1000] | Train Loss=0.000166835 | Test Loss=0.003006311 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [732/1000] | Train Loss=0.000165886 | Test Loss=0.003004293 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [733/1000] | Train Loss=0.000167341 | Test Loss=0.003005321 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [734/1000] | Train Loss=0.000166830 | Test Loss=0.003006878 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [735/1000] | Train Loss=0.000169094 | Test Loss=0.003011915 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [736/1000] | Train Loss=0.000166982 | Test Loss=0.003005934 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [737/1000] | Train Loss=0.000167105 | Test Loss=0.003009199 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [738/1000] | Train Loss=0.000168514 | Test Loss=0.003006841 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [739/1000] | Train Loss=0.000165562 | Test Loss=0.003006209 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [740/1000] | Train Loss=0.000166874 | Test Loss=0.003000246 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [741/1000] | Train Loss=0.000167919 | Test Loss=0.003008527 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [742/1000] | Train Loss=0.000168030 | Test Loss=0.003007003 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [743/1000] | Train Loss=0.000168989 | Test Loss=0.003008542 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [744/1000] | Train Loss=0.000166862 | Test Loss=0.003009002 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [745/1000] | Train Loss=0.000166842 | Test Loss=0.003014262 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [746/1000] | Train Loss=0.000168692 | Test Loss=0.003008000 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [747/1000] | Train Loss=0.000168792 | Test Loss=0.003007762 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [748/1000] | Train Loss=0.000166331 | Test Loss=0.003004602 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [749/1000] | Train Loss=0.000166818 | Test Loss=0.003006364 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [750/1000] | Train Loss=0.000166172 | Test Loss=0.003007329 | Time=1.68s | LR=1.95e-07\n",
      "Epoch [751/1000] | Train Loss=0.000166589 | Test Loss=0.003010670 | Time=1.58s | LR=1.95e-07\n",
      "Epoch [752/1000] | Train Loss=0.000167382 | Test Loss=0.003007207 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [753/1000] | Train Loss=0.000165984 | Test Loss=0.003007267 | Time=1.70s | LR=1.95e-07\n",
      "Epoch [754/1000] | Train Loss=0.000166562 | Test Loss=0.003014036 | Time=1.71s | LR=1.95e-07\n",
      "Epoch [755/1000] | Train Loss=0.000167380 | Test Loss=0.003008632 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [756/1000] | Train Loss=0.000166791 | Test Loss=0.003004054 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [757/1000] | Train Loss=0.000166072 | Test Loss=0.003008733 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [758/1000] | Train Loss=0.000168379 | Test Loss=0.003007953 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [759/1000] | Train Loss=0.000165781 | Test Loss=0.003004879 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [760/1000] | Train Loss=0.000166547 | Test Loss=0.003004939 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [761/1000] | Train Loss=0.000165905 | Test Loss=0.003008622 | Time=1.70s | LR=9.77e-08\n",
      "Epoch [762/1000] | Train Loss=0.000167945 | Test Loss=0.003003581 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [763/1000] | Train Loss=0.000166200 | Test Loss=0.003008437 | Time=1.54s | LR=9.77e-08\n",
      "Epoch [764/1000] | Train Loss=0.000167177 | Test Loss=0.003004559 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [765/1000] | Train Loss=0.000166778 | Test Loss=0.003007974 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [766/1000] | Train Loss=0.000166499 | Test Loss=0.003007620 | Time=1.72s | LR=9.77e-08\n",
      "Epoch [767/1000] | Train Loss=0.000166392 | Test Loss=0.003008976 | Time=1.68s | LR=9.77e-08\n",
      "Epoch [768/1000] | Train Loss=0.000165796 | Test Loss=0.003005884 | Time=1.72s | LR=9.77e-08\n",
      "Epoch [769/1000] | Train Loss=0.000164991 | Test Loss=0.003006479 | Time=1.54s | LR=9.77e-08\n",
      "Epoch [770/1000] | Train Loss=0.000166366 | Test Loss=0.003005721 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [771/1000] | Train Loss=0.000164936 | Test Loss=0.003004286 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [772/1000] | Train Loss=0.000165307 | Test Loss=0.003005836 | Time=1.72s | LR=9.77e-08\n",
      "Epoch [773/1000] | Train Loss=0.000165389 | Test Loss=0.003004287 | Time=1.68s | LR=9.77e-08\n",
      "Epoch [774/1000] | Train Loss=0.000165422 | Test Loss=0.003003412 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [775/1000] | Train Loss=0.000165705 | Test Loss=0.003006172 | Time=1.78s | LR=9.77e-08\n",
      "Epoch [776/1000] | Train Loss=0.000167805 | Test Loss=0.003006583 | Time=1.58s | LR=9.77e-08\n",
      "Epoch [777/1000] | Train Loss=0.000166527 | Test Loss=0.003006889 | Time=1.67s | LR=9.77e-08\n",
      "Epoch [778/1000] | Train Loss=0.000168112 | Test Loss=0.003009276 | Time=1.71s | LR=9.77e-08\n",
      "Epoch [779/1000] | Train Loss=0.000164472 | Test Loss=0.003006131 | Time=1.63s | LR=9.77e-08\n",
      "Epoch [780/1000] | Train Loss=0.000167338 | Test Loss=0.003006420 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [781/1000] | Train Loss=0.000166334 | Test Loss=0.003005549 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [782/1000] | Train Loss=0.000166884 | Test Loss=0.003008723 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [783/1000] | Train Loss=0.000166585 | Test Loss=0.003007412 | Time=1.67s | LR=9.77e-08\n",
      "Epoch [784/1000] | Train Loss=0.000166545 | Test Loss=0.003004448 | Time=1.70s | LR=9.77e-08\n",
      "Epoch [785/1000] | Train Loss=0.000166356 | Test Loss=0.003010582 | Time=1.61s | LR=9.77e-08\n",
      "Epoch [786/1000] | Train Loss=0.000165393 | Test Loss=0.003005089 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [787/1000] | Train Loss=0.000165552 | Test Loss=0.003009197 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [788/1000] | Train Loss=0.000166926 | Test Loss=0.003006361 | Time=1.57s | LR=9.77e-08\n",
      "Epoch [789/1000] | Train Loss=0.000165446 | Test Loss=0.003011381 | Time=1.67s | LR=9.77e-08\n",
      "Epoch [790/1000] | Train Loss=0.000166347 | Test Loss=0.003007967 | Time=1.70s | LR=9.77e-08\n",
      "Epoch [791/1000] | Train Loss=0.000165282 | Test Loss=0.003003974 | Time=1.62s | LR=9.77e-08\n",
      "Epoch [792/1000] | Train Loss=0.000167920 | Test Loss=0.003010483 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [793/1000] | Train Loss=0.000165705 | Test Loss=0.003008678 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [794/1000] | Train Loss=0.000165764 | Test Loss=0.003003530 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [795/1000] | Train Loss=0.000165849 | Test Loss=0.003005325 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [796/1000] | Train Loss=0.000166746 | Test Loss=0.003003211 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [797/1000] | Train Loss=0.000167383 | Test Loss=0.003005332 | Time=1.61s | LR=9.77e-08\n",
      "Epoch [798/1000] | Train Loss=0.000166028 | Test Loss=0.003009645 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [799/1000] | Train Loss=0.000165320 | Test Loss=0.003006282 | Time=1.76s | LR=9.77e-08\n",
      "Epoch [800/1000] | Train Loss=0.000164825 | Test Loss=0.003006864 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [801/1000] | Train Loss=0.000166913 | Test Loss=0.003005979 | Time=1.67s | LR=9.77e-08\n",
      "Epoch [802/1000] | Train Loss=0.000164758 | Test Loss=0.003004820 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [803/1000] | Train Loss=0.000165065 | Test Loss=0.003008065 | Time=1.61s | LR=9.77e-08\n",
      "Epoch [804/1000] | Train Loss=0.000165647 | Test Loss=0.003008845 | Time=1.72s | LR=9.77e-08\n",
      "Epoch [805/1000] | Train Loss=0.000167284 | Test Loss=0.003005876 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [806/1000] | Train Loss=0.000165343 | Test Loss=0.003007073 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [807/1000] | Train Loss=0.000166006 | Test Loss=0.003006394 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [808/1000] | Train Loss=0.000166528 | Test Loss=0.003005060 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [809/1000] | Train Loss=0.000165984 | Test Loss=0.003004838 | Time=1.61s | LR=9.77e-08\n",
      "Epoch [810/1000] | Train Loss=0.000166529 | Test Loss=0.003005369 | Time=1.73s | LR=9.77e-08\n",
      "Epoch [811/1000] | Train Loss=0.000165683 | Test Loss=0.003005228 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [812/1000] | Train Loss=0.000168052 | Test Loss=0.003007423 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [813/1000] | Train Loss=0.000165810 | Test Loss=0.003005698 | Time=1.66s | LR=9.77e-08\n",
      "Epoch [814/1000] | Train Loss=0.000166093 | Test Loss=0.003010343 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [815/1000] | Train Loss=0.000166055 | Test Loss=0.003009171 | Time=1.72s | LR=9.77e-08\n",
      "Epoch [816/1000] | Train Loss=0.000168317 | Test Loss=0.003008114 | Time=1.70s | LR=9.77e-08\n",
      "Epoch [817/1000] | Train Loss=0.000165331 | Test Loss=0.003003553 | Time=1.75s | LR=9.77e-08\n",
      "Epoch [818/1000] | Train Loss=0.000165946 | Test Loss=0.003008706 | Time=1.79s | LR=9.77e-08\n",
      "Epoch [819/1000] | Train Loss=0.000166448 | Test Loss=0.003007578 | Time=1.59s | LR=9.77e-08\n",
      "Epoch [820/1000] | Train Loss=0.000165088 | Test Loss=0.003007208 | Time=1.67s | LR=4.88e-08\n",
      "Epoch [821/1000] | Train Loss=0.000165207 | Test Loss=0.003006458 | Time=1.71s | LR=4.88e-08\n",
      "Epoch [822/1000] | Train Loss=0.000164684 | Test Loss=0.003006453 | Time=1.63s | LR=4.88e-08\n",
      "Epoch [823/1000] | Train Loss=0.000167836 | Test Loss=0.003008284 | Time=1.74s | LR=4.88e-08\n",
      "Epoch [824/1000] | Train Loss=0.000166025 | Test Loss=0.003007036 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [825/1000] | Train Loss=0.000167698 | Test Loss=0.003006846 | Time=1.85s | LR=4.88e-08\n",
      "Epoch [826/1000] | Train Loss=0.000166856 | Test Loss=0.003007109 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [827/1000] | Train Loss=0.000167722 | Test Loss=0.003007767 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [828/1000] | Train Loss=0.000165757 | Test Loss=0.003007448 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [829/1000] | Train Loss=0.000165268 | Test Loss=0.003007289 | Time=1.82s | LR=4.88e-08\n",
      "Epoch [830/1000] | Train Loss=0.000165299 | Test Loss=0.003005524 | Time=1.82s | LR=4.88e-08\n",
      "Epoch [831/1000] | Train Loss=0.000165706 | Test Loss=0.003003083 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [832/1000] | Train Loss=0.000166186 | Test Loss=0.003004995 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [833/1000] | Train Loss=0.000165921 | Test Loss=0.003006541 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [834/1000] | Train Loss=0.000165093 | Test Loss=0.003008851 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [835/1000] | Train Loss=0.000166761 | Test Loss=0.003009429 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [836/1000] | Train Loss=0.000165363 | Test Loss=0.003008136 | Time=1.85s | LR=4.88e-08\n",
      "Epoch [837/1000] | Train Loss=0.000165582 | Test Loss=0.003005093 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [838/1000] | Train Loss=0.000167027 | Test Loss=0.003007530 | Time=1.86s | LR=4.88e-08\n",
      "Epoch [839/1000] | Train Loss=0.000165573 | Test Loss=0.003007362 | Time=1.86s | LR=4.88e-08\n",
      "Epoch [840/1000] | Train Loss=0.000165936 | Test Loss=0.003006760 | Time=1.86s | LR=4.88e-08\n",
      "Epoch [841/1000] | Train Loss=0.000166740 | Test Loss=0.003005827 | Time=1.86s | LR=4.88e-08\n",
      "Epoch [842/1000] | Train Loss=0.000165823 | Test Loss=0.003006451 | Time=1.82s | LR=4.88e-08\n",
      "Epoch [843/1000] | Train Loss=0.000167553 | Test Loss=0.003004461 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [844/1000] | Train Loss=0.000166079 | Test Loss=0.003007644 | Time=1.82s | LR=4.88e-08\n",
      "Epoch [845/1000] | Train Loss=0.000165668 | Test Loss=0.003008643 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [846/1000] | Train Loss=0.000165030 | Test Loss=0.003006638 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [847/1000] | Train Loss=0.000167153 | Test Loss=0.003005194 | Time=1.82s | LR=4.88e-08\n",
      "Epoch [848/1000] | Train Loss=0.000166921 | Test Loss=0.003005323 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [849/1000] | Train Loss=0.000166330 | Test Loss=0.003006468 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [850/1000] | Train Loss=0.000168024 | Test Loss=0.003005573 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [851/1000] | Train Loss=0.000167977 | Test Loss=0.003006097 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [852/1000] | Train Loss=0.000166126 | Test Loss=0.003006354 | Time=1.86s | LR=4.88e-08\n",
      "Epoch [853/1000] | Train Loss=0.000166580 | Test Loss=0.003004673 | Time=1.86s | LR=4.88e-08\n",
      "Epoch [854/1000] | Train Loss=0.000166951 | Test Loss=0.003006907 | Time=1.85s | LR=4.88e-08\n",
      "Epoch [855/1000] | Train Loss=0.000166315 | Test Loss=0.003010502 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [856/1000] | Train Loss=0.000167845 | Test Loss=0.003003360 | Time=1.81s | LR=4.88e-08\n",
      "Epoch [857/1000] | Train Loss=0.000166959 | Test Loss=0.003004119 | Time=1.83s | LR=4.88e-08\n",
      "Epoch [858/1000] | Train Loss=0.000168702 | Test Loss=0.003006965 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [859/1000] | Train Loss=0.000167435 | Test Loss=0.003008535 | Time=1.84s | LR=4.88e-08\n",
      "Epoch [860/1000] | Train Loss=0.000166603 | Test Loss=0.003002135 | Time=1.87s | LR=4.88e-08\n",
      "Epoch [861/1000] | Train Loss=0.000166629 | Test Loss=0.003006447 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [862/1000] | Train Loss=0.000167103 | Test Loss=0.003004553 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [863/1000] | Train Loss=0.000165443 | Test Loss=0.003005633 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [864/1000] | Train Loss=0.000166467 | Test Loss=0.003006578 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [865/1000] | Train Loss=0.000166214 | Test Loss=0.003005936 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [866/1000] | Train Loss=0.000165028 | Test Loss=0.003004459 | Time=1.82s | LR=2.44e-08\n",
      "Epoch [867/1000] | Train Loss=0.000167412 | Test Loss=0.003007220 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [868/1000] | Train Loss=0.000166699 | Test Loss=0.003005667 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [869/1000] | Train Loss=0.000165394 | Test Loss=0.003006298 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [870/1000] | Train Loss=0.000166756 | Test Loss=0.003006479 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [871/1000] | Train Loss=0.000164983 | Test Loss=0.003005872 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [872/1000] | Train Loss=0.000168695 | Test Loss=0.003004285 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [873/1000] | Train Loss=0.000167105 | Test Loss=0.003008527 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [874/1000] | Train Loss=0.000166315 | Test Loss=0.003005193 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [875/1000] | Train Loss=0.000166414 | Test Loss=0.003005978 | Time=1.85s | LR=2.44e-08\n",
      "Epoch [876/1000] | Train Loss=0.000167324 | Test Loss=0.003003618 | Time=1.86s | LR=2.44e-08\n",
      "Epoch [877/1000] | Train Loss=0.000165321 | Test Loss=0.003004641 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [878/1000] | Train Loss=0.000165051 | Test Loss=0.003004545 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [879/1000] | Train Loss=0.000165282 | Test Loss=0.003004378 | Time=1.82s | LR=2.44e-08\n",
      "Epoch [880/1000] | Train Loss=0.000166319 | Test Loss=0.003004320 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [881/1000] | Train Loss=0.000165815 | Test Loss=0.003003612 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [882/1000] | Train Loss=0.000165236 | Test Loss=0.003004454 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [883/1000] | Train Loss=0.000166158 | Test Loss=0.003003756 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [884/1000] | Train Loss=0.000165563 | Test Loss=0.003004070 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [885/1000] | Train Loss=0.000167791 | Test Loss=0.003008918 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [886/1000] | Train Loss=0.000165345 | Test Loss=0.003002744 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [887/1000] | Train Loss=0.000165348 | Test Loss=0.003003458 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [888/1000] | Train Loss=0.000165457 | Test Loss=0.003004252 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [889/1000] | Train Loss=0.000166781 | Test Loss=0.003004462 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [890/1000] | Train Loss=0.000166149 | Test Loss=0.003004746 | Time=1.82s | LR=2.44e-08\n",
      "Epoch [891/1000] | Train Loss=0.000165203 | Test Loss=0.003004253 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [892/1000] | Train Loss=0.000166595 | Test Loss=0.003006637 | Time=1.81s | LR=2.44e-08\n",
      "Epoch [893/1000] | Train Loss=0.000165573 | Test Loss=0.003005024 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [894/1000] | Train Loss=0.000165236 | Test Loss=0.003006557 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [895/1000] | Train Loss=0.000165754 | Test Loss=0.003005591 | Time=1.87s | LR=2.44e-08\n",
      "Epoch [896/1000] | Train Loss=0.000166216 | Test Loss=0.003004408 | Time=1.82s | LR=2.44e-08\n",
      "Epoch [897/1000] | Train Loss=0.000165763 | Test Loss=0.003005213 | Time=1.84s | LR=2.44e-08\n",
      "Epoch [898/1000] | Train Loss=0.000166563 | Test Loss=0.003006312 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [899/1000] | Train Loss=0.000166817 | Test Loss=0.003004168 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [900/1000] | Train Loss=0.000166408 | Test Loss=0.003004159 | Time=1.83s | LR=2.44e-08\n",
      "Epoch [901/1000] | Train Loss=0.000165391 | Test Loss=0.003007170 | Time=1.86s | LR=2.44e-08\n",
      "Epoch [902/1000] | Train Loss=0.000167430 | Test Loss=0.003004391 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [903/1000] | Train Loss=0.000166276 | Test Loss=0.003005947 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [904/1000] | Train Loss=0.000165645 | Test Loss=0.003004854 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [905/1000] | Train Loss=0.000165457 | Test Loss=0.003004446 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [906/1000] | Train Loss=0.000165462 | Test Loss=0.003003904 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [907/1000] | Train Loss=0.000165046 | Test Loss=0.003004256 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [908/1000] | Train Loss=0.000164349 | Test Loss=0.003005245 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [909/1000] | Train Loss=0.000165468 | Test Loss=0.003005304 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [910/1000] | Train Loss=0.000166190 | Test Loss=0.003004597 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [911/1000] | Train Loss=0.000163856 | Test Loss=0.003005148 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [912/1000] | Train Loss=0.000165783 | Test Loss=0.003005147 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [913/1000] | Train Loss=0.000165595 | Test Loss=0.003004758 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [914/1000] | Train Loss=0.000164836 | Test Loss=0.003004887 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [915/1000] | Train Loss=0.000166644 | Test Loss=0.003005466 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [916/1000] | Train Loss=0.000166222 | Test Loss=0.003005442 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [917/1000] | Train Loss=0.000168025 | Test Loss=0.003006089 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [918/1000] | Train Loss=0.000166151 | Test Loss=0.003005078 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [919/1000] | Train Loss=0.000168490 | Test Loss=0.003005099 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [920/1000] | Train Loss=0.000166898 | Test Loss=0.003005150 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [921/1000] | Train Loss=0.000164912 | Test Loss=0.003005383 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [922/1000] | Train Loss=0.000167405 | Test Loss=0.003004389 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [923/1000] | Train Loss=0.000166948 | Test Loss=0.003005248 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [924/1000] | Train Loss=0.000167146 | Test Loss=0.003004791 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [925/1000] | Train Loss=0.000165860 | Test Loss=0.003005590 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [926/1000] | Train Loss=0.000166145 | Test Loss=0.003005533 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [927/1000] | Train Loss=0.000165519 | Test Loss=0.003005324 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [928/1000] | Train Loss=0.000168331 | Test Loss=0.003006005 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [929/1000] | Train Loss=0.000166284 | Test Loss=0.003005190 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [930/1000] | Train Loss=0.000167271 | Test Loss=0.003005237 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [931/1000] | Train Loss=0.000167450 | Test Loss=0.003005744 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [932/1000] | Train Loss=0.000166809 | Test Loss=0.003005351 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [933/1000] | Train Loss=0.000166076 | Test Loss=0.003003776 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [934/1000] | Train Loss=0.000165241 | Test Loss=0.003005380 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [935/1000] | Train Loss=0.000166036 | Test Loss=0.003006044 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [936/1000] | Train Loss=0.000166002 | Test Loss=0.003005101 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [937/1000] | Train Loss=0.000166431 | Test Loss=0.003005100 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [938/1000] | Train Loss=0.000166324 | Test Loss=0.003005161 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [939/1000] | Train Loss=0.000167315 | Test Loss=0.003004401 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [940/1000] | Train Loss=0.000164742 | Test Loss=0.003005220 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [941/1000] | Train Loss=0.000167047 | Test Loss=0.003004945 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [942/1000] | Train Loss=0.000166900 | Test Loss=0.003005202 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [943/1000] | Train Loss=0.000166519 | Test Loss=0.003004901 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [944/1000] | Train Loss=0.000166024 | Test Loss=0.003004261 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [945/1000] | Train Loss=0.000166935 | Test Loss=0.003004590 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [946/1000] | Train Loss=0.000165635 | Test Loss=0.003005484 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [947/1000] | Train Loss=0.000165940 | Test Loss=0.003005173 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [948/1000] | Train Loss=0.000165594 | Test Loss=0.003004504 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [949/1000] | Train Loss=0.000165509 | Test Loss=0.003004701 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [950/1000] | Train Loss=0.000166379 | Test Loss=0.003004461 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [951/1000] | Train Loss=0.000166312 | Test Loss=0.003004615 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [952/1000] | Train Loss=0.000166006 | Test Loss=0.003004091 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [953/1000] | Train Loss=0.000164479 | Test Loss=0.003004491 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [954/1000] | Train Loss=0.000165957 | Test Loss=0.003004880 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [955/1000] | Train Loss=0.000166916 | Test Loss=0.003005162 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [956/1000] | Train Loss=0.000167711 | Test Loss=0.003004834 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [957/1000] | Train Loss=0.000164529 | Test Loss=0.003004439 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [958/1000] | Train Loss=0.000166730 | Test Loss=0.003004793 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [959/1000] | Train Loss=0.000166992 | Test Loss=0.003004717 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [960/1000] | Train Loss=0.000166781 | Test Loss=0.003004093 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [961/1000] | Train Loss=0.000165773 | Test Loss=0.003004163 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [962/1000] | Train Loss=0.000165069 | Test Loss=0.003004613 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [963/1000] | Train Loss=0.000164654 | Test Loss=0.003004552 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [964/1000] | Train Loss=0.000165140 | Test Loss=0.003004666 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [965/1000] | Train Loss=0.000166350 | Test Loss=0.003004588 | Time=1.82s | LR=1.22e-08\n",
      "Epoch [966/1000] | Train Loss=0.000166472 | Test Loss=0.003005082 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [967/1000] | Train Loss=0.000168242 | Test Loss=0.003004496 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [968/1000] | Train Loss=0.000165496 | Test Loss=0.003004553 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [969/1000] | Train Loss=0.000165657 | Test Loss=0.003004685 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [970/1000] | Train Loss=0.000164166 | Test Loss=0.003005096 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [971/1000] | Train Loss=0.000166382 | Test Loss=0.003005921 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [972/1000] | Train Loss=0.000165891 | Test Loss=0.003005041 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [973/1000] | Train Loss=0.000167415 | Test Loss=0.003005229 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [974/1000] | Train Loss=0.000164649 | Test Loss=0.003004922 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [975/1000] | Train Loss=0.000165791 | Test Loss=0.003005375 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [976/1000] | Train Loss=0.000164412 | Test Loss=0.003004755 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [977/1000] | Train Loss=0.000165324 | Test Loss=0.003005127 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [978/1000] | Train Loss=0.000166359 | Test Loss=0.003005002 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [979/1000] | Train Loss=0.000166901 | Test Loss=0.003004565 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [980/1000] | Train Loss=0.000165305 | Test Loss=0.003006130 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [981/1000] | Train Loss=0.000167063 | Test Loss=0.003005521 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [982/1000] | Train Loss=0.000165759 | Test Loss=0.003004474 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [983/1000] | Train Loss=0.000165330 | Test Loss=0.003005523 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [984/1000] | Train Loss=0.000167327 | Test Loss=0.003004715 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [985/1000] | Train Loss=0.000165920 | Test Loss=0.003004681 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [986/1000] | Train Loss=0.000167029 | Test Loss=0.003004851 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [987/1000] | Train Loss=0.000167085 | Test Loss=0.003005307 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [988/1000] | Train Loss=0.000164507 | Test Loss=0.003005317 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [989/1000] | Train Loss=0.000167971 | Test Loss=0.003005187 | Time=1.84s | LR=1.22e-08\n",
      "Epoch [990/1000] | Train Loss=0.000165107 | Test Loss=0.003005550 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [991/1000] | Train Loss=0.000165189 | Test Loss=0.003003787 | Time=1.86s | LR=1.22e-08\n",
      "Epoch [992/1000] | Train Loss=0.000167089 | Test Loss=0.003006607 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [993/1000] | Train Loss=0.000165981 | Test Loss=0.003004108 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [994/1000] | Train Loss=0.000165127 | Test Loss=0.003004008 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [995/1000] | Train Loss=0.000166637 | Test Loss=0.003004613 | Time=1.87s | LR=1.22e-08\n",
      "Epoch [996/1000] | Train Loss=0.000164945 | Test Loss=0.003005020 | Time=1.83s | LR=1.22e-08\n",
      "Epoch [997/1000] | Train Loss=0.000166041 | Test Loss=0.003006935 | Time=1.85s | LR=1.22e-08\n",
      "Epoch [998/1000] | Train Loss=0.000165738 | Test Loss=0.003005168 | Time=1.81s | LR=1.22e-08\n",
      "Epoch [999/1000] | Train Loss=0.000165294 | Test Loss=0.003004491 | Time=1.79s | LR=1.22e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000166309 | Test Loss=0.003003244 | Time=1.82s | LR=1.22e-08\n",
      "\n",
      "Total training time: 1756.11 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAGwCAYAAABFFQqPAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAb5lJREFUeJzt3Xd4FOXaBvB7tmTTO0kIJPQiHemggIqCKAKKWFBBPXLUqCgH2/GoWLD3T44eUbGLomAFBSkighCQHnqvCRDSy5Z5vz8mW2ZbdpNNNsnev+viIjs7O/vuBMjN8zZJCCFAREREFII0wW4AERERUbAwCBEREVHIYhAiIiKikMUgRERERCGLQYiIiIhCFoMQERERhSwGISIiIgpZumA3oKGTZRknTpxATEwMJEkKdnOIiIjIB0IIFBcXIz09HRqN57oPg1A1Tpw4gYyMjGA3g4iIiGrg6NGjaNmypcfnGYSqERMTA0C5kbGxsQG7rslkwpIlS3DZZZdBr9cH7Lqkxvtcf3iv6wfvc/3gfa4fdXmfi4qKkJGRYfs57gmDUDWs3WGxsbEBD0KRkZGIjY3lX7I6xPtcf3iv6wfvc/3gfa4f9XGfqxvWwsHSHsyePRtdunRBv379gt0UIiIiqiMMQh5kZWUhJycH2dnZwW4KERER1REGISIiIgpZHCNERESNlizLMBqNAb+uyWSCTqdDRUUFLBZLwK9PitrcZ71eD61WW+s2MAgREVGjZDQacfDgQciyHPBrCyGQlpaGo0ePcg25OlTb+xwfH4+0tLRafY8YhIiIqNERQuDkyZPQarXIyMjwumBeTciyjJKSEkRHRwf82mRX0/sshEBZWRny8vIAAM2bN69xGxiEiIio0TGbzSgrK0N6ejoiIyMDfn1rl1t4eDiDUB2qzX2OiIgAAOTl5SElJaXG3WT87hIRUaNjHU8SFhYW5JZQMFlDsMlkqvE1GISIiKjR4vid0BaI7z+DEBEREYUsBiEiIiIKWQxCREREjVjr1q3xxhtvBLsZ+OijjxAfHx/sZviNQagpMpYFuwVEROREkiSvv2bOnFmj62ZnZ2Pq1Km1atvw4cNt7QgPD0fHjh3x/PPPQwhRq+s6kyQJ3333ndvnVq5cibFjx6J58+aIiopCr1698Pnnnwf0/d3h9PmmJncH8N5FwPm3AFe8EuzWEBFRlZMnT9q+/uqrr/DEE09g9+7dtmPR0dG2r4UQsFgs0Omq/zHdrFmzgLTvjjvuwNNPP43KykosX74cU6dORXx8PO66666AXL86a9asQY8ePfDwww8jNTUVP/30E2655RbExcXhyiuvrLP3ZUWoMSrLB0rPuH9u/RzAUglkz6nfNhERBZEQAmVGc0B/lRstPp3na9UkLS3N9isuLg6SJNke79q1CzExMVi8eDH69OkDg8GA1atXY//+/Rg7dixSU1MRHR2Nfv364bffflNd17lrTJIkvP/++xg/fjwiIyPRoUMH/PDDD9W2LzIyEmlpaWjVqhVuvfVW9OjRA0uXLrU9X1lZiRkzZqBFixaIiorCgAEDsHLlSp8+uy/+/e9/45lnnsHgwYPRrl07TJs2DaNGjcKCBQsC9h7usCLU2Mgy8FIb5et/nwTCnBYSi8+0f22uBHSG+msbEVGQlJss6PLEr0F575ynRyIyLDA/Th955BG88soraNu2LRISEnD06FGMHj0as2bNgsFgwCeffIIxY8Zg9+7dyMzM9Hidp556Ci+99BJefvll/N///R8mTZqEw4cPIzExsdo2CCGwevVq7Nq1Cx06dLAdv+eee5CTk4N58+YhPT0dCxcuxKhRo7Bt2zbVeYFUWFiI8847r06ubcWKUGNjcdhcMH+/6/NRDiXS/IN13x4iIgqYp59+GpdeeinatWuHxMRE9OzZE//85z/RrVs3dOjQAc888wzatWtXbYVnypQpuOGGG9C+fXs899xzKCkpwfr1672+5r///S+io6NhMBgwdOhQyLKM++67DwBw5MgRzJ07F/Pnz8eFF16Idu3aYcaMGbjgggswd+7cgH1+R19//TWys7Nx66231sn1rVgRamyEw+685QXenzeV1nlziIgaggi9FjlPjwzY9WRZRnFRMWJiY6rd+iFCX/sd0K369u2relxSUoKZM2fi559/xsmTJ2E2m1FeXo4jR454vU6PHj1sX0dFRSE2Nta2L5cnkyZNwmOPPYZz587hySefxODBgzF48GAAwLZt22CxWNCxY0fVayorK5GUlOTPR/TJihUrcOutt2LOnDno2rVrwK/viEGosZHN9q8rCtw87xCELDVfcpyIqDGRJClg3VOAEoTMYVpEhunqda+xqKgo1eMZM2Zg6dKleOWVV9C+fXtERERgwoQJMBqNHq6g0Ov1qseS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Lb755hvV67dt24aLL74YERERSEpKwtSpU1FSUqI658MPP0TXrl1hMBjQvHlz3HPPParnz5w5g/HjxyMyMhIdOnTADz/8ULcfmojqBIMQETU5jz/+OK655hps2bIFkyZNwvXXX4+dO3cCAEpLSzFy5EgkJCQgOzsb8+fPx2+//aYKOu+88w6ysrIwdepUbNu2DT/88APat2+veo+nnnoKEydOxNatWzF69GhMmjQJ+fn59fo5iSgAArKHPRFRPZk8ebLQarUiKipK9WvWrFlCCCEAiDvvvFP1mgEDBoi77rpLCCHEe++9JxISEkRJSYnt+Z9//lloNBpx6tQpIYQQ6enp4rHHHvPYBgDiP//5j+1xSUmJACAWL14csM9JRPWDY4SIqNG56KKL8M4776iOJSYm2r4eNGiQ6rlBgwZh8+bNAICdO3eiZ8+eiIqKsj0/ZMgQyLKM3bt3Q5IknDhxApdcconXNvTo0cP2dVRUFGJjY5GXl1fTj0REQcIgRESNTlRUlEtXVaBERET4dJ5er1c9liQJsizXRZOIqA5xjBARNTl//fWXy+PzzjsPAHDeeedhy5YtKC0ttT3/559/QqPRoFOnToiJiUHr1q2xbNmyem0zEQUHK0JE1OhUVlbi1KlTqmM6nQ7JyckAgPnz56Nv37644IIL8Pnnn2P9+vX44IMPAACTJk3Ck08+icmTJ2PmzJk4ffo07r33Xtx8881ITU0FAMycORN33nknUlJScPnll6O4uBh//vkn7r333vr9oERU5xiEiKjR+eWXX9C8eXPVsU6dOmHXrl0AlBld8+bNw913343mzZvjyy+/RJcuXQAAkZGR+PXXXzFt2jT069cPkZGRuOaaa/Daa6/ZrjV58mRUVFTg9ddfx4wZM5CcnIwJEybU3wckonojCSFEsBtBRBQokiRh4cKFGDduXLCbQkSNAMcIERERUchiECIiIqKQxTFCRNSksLefiPzBihARERGFLAYhIiIiClkMQkRERBSyGISIiIgoZDEIERERUchiECIiIqKQxSBEREREIYtBiIiIiELW/wNRb837sCm4cAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "# Train using your existing training loop\n",
    "amfno, train_losses, test_losses = train_operator(\n",
    "    dataset_raw      = train_data,\n",
    "    model            = amfno,\n",
    "    num_epochs       = 1000,\n",
    "    lr               = 1e-4,\n",
    "    device           = device,\n",
    "    batch_size       = 16,\n",
    "    test_dataset_raw = test_data,\n",
    "    reduce_on        = 'train',\n",
    "    factor           = 0.5,\n",
    "    patience         = 40,\n",
    "    min_lr           = 1e-10,\n",
    "    cooldown         = 0,\n",
    ")\n",
    "\n",
    "torch.save(amfno.state_dict(), 'amfno_G3.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00008978\n",
      "Function type: periodic             | Relative L2: 0.00022289\n",
      "Function type: sine_beats           | Relative L2: 0.00027141\n",
      "\n",
      "Overall relative L2 error: 0.00011613\n",
      "--------------test----------------\n",
      "Function type: gaussian_hermite     | Relative L2: 0.00739472\n",
      "Function type: sinc_pulse           | Relative L2: 0.00821456\n",
      "Function type: wave_packet          | Relative L2: 0.00272214\n",
      "\n",
      "Overall relative L2 error: 0.00297887\n",
      "-------------sample----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00012986\n",
      "Function type: periodic             | Relative L2: 0.00024126\n",
      "Function type: sine_beats           | Relative L2: 0.00033244\n",
      "\n",
      "Overall relative L2 error: 0.00015450\n"
     ]
    }
   ],
   "source": [
    "device = 'cuda:1'\n",
    "# Loss in train loop is batch-wise average loss. Metric is sample-wise average loss.\n",
    "print('--------------train----------------')\n",
    "loss = evaluate_operator(dataset = train_data, model = amfno, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, model = amfno, device = device)\n",
    "print('-------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, model = amfno, 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
}
