{
 "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": 17,
   "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_1.pt', weights_only=False))\n",
    "test_data = convert_dataset_for_fno(torch.load('test_1.pt', weights_only=False))\n",
    "sample_data = convert_dataset_for_fno(torch.load('sample_1.pt', weights_only=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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": 15,
   "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.266525039 | Test Loss=0.054160775 | Time=2.07s | LR=1.00e-03\n",
      "Epoch [2/1000] | Train Loss=0.043466537 | Test Loss=0.051781216 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [3/1000] | Train Loss=0.035854715 | Test Loss=0.053829927 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [4/1000] | Train Loss=0.040421011 | Test Loss=0.061679487 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [5/1000] | Train Loss=0.025496266 | Test Loss=0.041362009 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [6/1000] | Train Loss=0.030957782 | Test Loss=0.032291836 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [7/1000] | Train Loss=0.032532311 | Test Loss=0.031911088 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [8/1000] | Train Loss=0.030562431 | Test Loss=0.027641340 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [9/1000] | Train Loss=0.037037490 | Test Loss=0.060756691 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [10/1000] | Train Loss=0.040908906 | Test Loss=0.042570423 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [11/1000] | Train Loss=0.034592819 | Test Loss=0.032617169 | Time=1.78s | LR=1.00e-03\n",
      "Epoch [12/1000] | Train Loss=0.035808913 | Test Loss=0.068587878 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [13/1000] | Train Loss=0.025010809 | Test Loss=0.090217058 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [14/1000] | Train Loss=0.033750426 | Test Loss=0.094315946 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [15/1000] | Train Loss=0.035051145 | Test Loss=0.034071117 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [16/1000] | Train Loss=0.031691222 | Test Loss=0.027979151 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [17/1000] | Train Loss=0.046698726 | Test Loss=0.034048707 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [18/1000] | Train Loss=0.041500809 | Test Loss=0.029793572 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [19/1000] | Train Loss=0.027673229 | Test Loss=0.032727655 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [20/1000] | Train Loss=0.023849761 | Test Loss=0.027635408 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [21/1000] | Train Loss=0.024697157 | Test Loss=0.088345346 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [22/1000] | Train Loss=0.029586693 | Test Loss=0.030650646 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [23/1000] | Train Loss=0.036058590 | Test Loss=0.023609918 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [24/1000] | Train Loss=0.036918551 | Test Loss=0.023146531 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [25/1000] | Train Loss=0.026837093 | Test Loss=0.033029239 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [26/1000] | Train Loss=0.028098163 | Test Loss=0.043396774 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [27/1000] | Train Loss=0.025760813 | Test Loss=0.039160514 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [28/1000] | Train Loss=0.026572989 | Test Loss=0.023014243 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [29/1000] | Train Loss=0.024860939 | Test Loss=0.043145145 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [30/1000] | Train Loss=0.022065661 | Test Loss=0.022544173 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [31/1000] | Train Loss=0.025069465 | Test Loss=0.025200254 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [32/1000] | Train Loss=0.036676091 | Test Loss=0.125286870 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [33/1000] | Train Loss=0.044120829 | Test Loss=0.025487398 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [34/1000] | Train Loss=0.022899990 | Test Loss=0.025565438 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [35/1000] | Train Loss=0.023802394 | Test Loss=0.024223816 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [36/1000] | Train Loss=0.031873188 | Test Loss=0.021903587 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [37/1000] | Train Loss=0.025184965 | Test Loss=0.034315296 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [38/1000] | Train Loss=0.020524679 | Test Loss=0.025886342 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [39/1000] | Train Loss=0.024336025 | Test Loss=0.025808947 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [40/1000] | Train Loss=0.023576965 | Test Loss=0.026439687 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [41/1000] | Train Loss=0.023910767 | Test Loss=0.037580041 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [42/1000] | Train Loss=0.032790812 | Test Loss=0.038128335 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [43/1000] | Train Loss=0.021966993 | Test Loss=0.043514363 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [44/1000] | Train Loss=0.025478384 | Test Loss=0.022542664 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [45/1000] | Train Loss=0.027888702 | Test Loss=0.035293067 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [46/1000] | Train Loss=0.027259378 | Test Loss=0.023321068 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [47/1000] | Train Loss=0.022042355 | Test Loss=0.026485163 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [48/1000] | Train Loss=0.023166459 | Test Loss=0.024203819 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [49/1000] | Train Loss=0.023965951 | Test Loss=0.022508032 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [50/1000] | Train Loss=0.028412291 | Test Loss=0.019304280 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [51/1000] | Train Loss=0.022328756 | Test Loss=0.027747786 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [52/1000] | Train Loss=0.025861391 | Test Loss=0.018483035 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [53/1000] | Train Loss=0.025405057 | Test Loss=0.017844256 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [54/1000] | Train Loss=0.030721369 | Test Loss=0.020488614 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [55/1000] | Train Loss=0.025614326 | Test Loss=0.032461683 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [56/1000] | Train Loss=0.024358935 | Test Loss=0.026859790 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [57/1000] | Train Loss=0.022473436 | Test Loss=0.028437707 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [58/1000] | Train Loss=0.024049541 | Test Loss=0.031785150 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [59/1000] | Train Loss=0.027414249 | Test Loss=0.033455791 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [60/1000] | Train Loss=0.024917412 | Test Loss=0.018594131 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [61/1000] | Train Loss=0.021744178 | Test Loss=0.017561700 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [62/1000] | Train Loss=0.025352076 | Test Loss=0.026537116 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [63/1000] | Train Loss=0.020624461 | Test Loss=0.020042347 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [64/1000] | Train Loss=0.028584883 | Test Loss=0.029551291 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [65/1000] | Train Loss=0.028751494 | Test Loss=0.021556377 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [66/1000] | Train Loss=0.021495802 | Test Loss=0.020165600 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [67/1000] | Train Loss=0.032344281 | Test Loss=0.048894673 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [68/1000] | Train Loss=0.022529003 | Test Loss=0.026492016 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [69/1000] | Train Loss=0.021877307 | Test Loss=0.022121733 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [70/1000] | Train Loss=0.029823353 | Test Loss=0.064341739 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [71/1000] | Train Loss=0.021570626 | Test Loss=0.038643275 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [72/1000] | Train Loss=0.030194258 | Test Loss=0.021691506 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [73/1000] | Train Loss=0.018183585 | Test Loss=0.021259167 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [74/1000] | Train Loss=0.021402334 | Test Loss=0.031487740 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [75/1000] | Train Loss=0.020683424 | Test Loss=0.023893520 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [76/1000] | Train Loss=0.017755734 | Test Loss=0.030036467 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [77/1000] | Train Loss=0.022873539 | Test Loss=0.028618542 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [78/1000] | Train Loss=0.021912487 | Test Loss=0.022675021 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [79/1000] | Train Loss=0.018543617 | Test Loss=0.015856653 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [80/1000] | Train Loss=0.021502262 | Test Loss=0.022110820 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [81/1000] | Train Loss=0.028549458 | Test Loss=0.031127485 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [82/1000] | Train Loss=0.024972230 | Test Loss=0.017586095 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [83/1000] | Train Loss=0.021246998 | Test Loss=0.015398590 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [84/1000] | Train Loss=0.020483681 | Test Loss=0.031045410 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [85/1000] | Train Loss=0.018919718 | Test Loss=0.014664881 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [86/1000] | Train Loss=0.017168713 | Test Loss=0.034762334 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [87/1000] | Train Loss=0.018331765 | Test Loss=0.026787381 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [88/1000] | Train Loss=0.015303859 | Test Loss=0.015298582 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [89/1000] | Train Loss=0.022159221 | Test Loss=0.059748277 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [90/1000] | Train Loss=0.019854443 | Test Loss=0.030870301 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [91/1000] | Train Loss=0.022154164 | Test Loss=0.026920802 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [92/1000] | Train Loss=0.019355914 | Test Loss=0.054017458 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [93/1000] | Train Loss=0.026022357 | Test Loss=0.030624495 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [94/1000] | Train Loss=0.022476719 | Test Loss=0.057217089 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [95/1000] | Train Loss=0.024811686 | Test Loss=0.018179308 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [96/1000] | Train Loss=0.024088656 | Test Loss=0.034484034 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [97/1000] | Train Loss=0.028415787 | Test Loss=0.032822176 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [98/1000] | Train Loss=0.018338321 | Test Loss=0.017641567 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [99/1000] | Train Loss=0.020552427 | Test Loss=0.031593023 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [100/1000] | Train Loss=0.019042617 | Test Loss=0.026281913 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [101/1000] | Train Loss=0.018603476 | Test Loss=0.027107974 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [102/1000] | Train Loss=0.016652621 | Test Loss=0.019000689 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [103/1000] | Train Loss=0.025692975 | Test Loss=0.026124251 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [104/1000] | Train Loss=0.014497071 | Test Loss=0.023553906 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [105/1000] | Train Loss=0.020811896 | Test Loss=0.022354015 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [106/1000] | Train Loss=0.016566628 | Test Loss=0.015718163 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [107/1000] | Train Loss=0.025349645 | Test Loss=0.028087661 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [108/1000] | Train Loss=0.016025440 | Test Loss=0.020721098 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [109/1000] | Train Loss=0.020941011 | Test Loss=0.016498471 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [110/1000] | Train Loss=0.023859773 | Test Loss=0.010437593 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [111/1000] | Train Loss=0.022176223 | Test Loss=0.021449060 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [112/1000] | Train Loss=0.016121032 | Test Loss=0.017736273 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [113/1000] | Train Loss=0.014679226 | Test Loss=0.012873839 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [114/1000] | Train Loss=0.025022453 | Test Loss=0.025009983 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [115/1000] | Train Loss=0.016243416 | Test Loss=0.012569266 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [116/1000] | Train Loss=0.022902768 | Test Loss=0.027600728 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [117/1000] | Train Loss=0.015866072 | Test Loss=0.025943553 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [118/1000] | Train Loss=0.026824574 | Test Loss=0.026040474 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [119/1000] | Train Loss=0.023921958 | Test Loss=0.028020019 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [120/1000] | Train Loss=0.018303274 | Test Loss=0.028005406 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [121/1000] | Train Loss=0.015220334 | Test Loss=0.009003773 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [122/1000] | Train Loss=0.018289025 | Test Loss=0.015067289 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [123/1000] | Train Loss=0.029532048 | Test Loss=0.020980901 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [124/1000] | Train Loss=0.015733004 | Test Loss=0.013259011 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [125/1000] | Train Loss=0.020468592 | Test Loss=0.017589458 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [126/1000] | Train Loss=0.016636781 | Test Loss=0.012093867 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [127/1000] | Train Loss=0.014059169 | Test Loss=0.018186438 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [128/1000] | Train Loss=0.016090471 | Test Loss=0.023707143 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [129/1000] | Train Loss=0.020593218 | Test Loss=0.020804937 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [130/1000] | Train Loss=0.018812640 | Test Loss=0.019618854 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [131/1000] | Train Loss=0.015862547 | Test Loss=0.018768648 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [132/1000] | Train Loss=0.021483354 | Test Loss=0.009687782 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [133/1000] | Train Loss=0.013631722 | Test Loss=0.015984681 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [134/1000] | Train Loss=0.014924814 | Test Loss=0.011638134 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [135/1000] | Train Loss=0.019952892 | Test Loss=0.017785842 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [136/1000] | Train Loss=0.017230943 | Test Loss=0.028956036 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [137/1000] | Train Loss=0.019980691 | Test Loss=0.023578433 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [138/1000] | Train Loss=0.024262342 | Test Loss=0.028266833 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [139/1000] | Train Loss=0.016042657 | Test Loss=0.014885841 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [140/1000] | Train Loss=0.023778490 | Test Loss=0.048976548 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [141/1000] | Train Loss=0.026859166 | Test Loss=0.038147906 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [142/1000] | Train Loss=0.019981633 | Test Loss=0.025093197 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [143/1000] | Train Loss=0.019164261 | Test Loss=0.011962893 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [144/1000] | Train Loss=0.014482483 | Test Loss=0.018221454 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [145/1000] | Train Loss=0.024589149 | Test Loss=0.068013942 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [146/1000] | Train Loss=0.016152176 | Test Loss=0.019935076 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [147/1000] | Train Loss=0.016840583 | Test Loss=0.025020188 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [148/1000] | Train Loss=0.014682999 | Test Loss=0.013575434 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [149/1000] | Train Loss=0.018671286 | Test Loss=0.018986494 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [150/1000] | Train Loss=0.020723589 | Test Loss=0.014456112 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [151/1000] | Train Loss=0.019957529 | Test Loss=0.025544670 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [152/1000] | Train Loss=0.021707330 | Test Loss=0.032640987 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [153/1000] | Train Loss=0.020837699 | Test Loss=0.020528810 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [154/1000] | Train Loss=0.012863326 | Test Loss=0.011456770 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [155/1000] | Train Loss=0.025678405 | Test Loss=0.012528943 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [156/1000] | Train Loss=0.019388155 | Test Loss=0.021732101 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [157/1000] | Train Loss=0.016829143 | Test Loss=0.015404103 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [158/1000] | Train Loss=0.017492117 | Test Loss=0.013333614 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [159/1000] | Train Loss=0.019554342 | Test Loss=0.019012913 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [160/1000] | Train Loss=0.016373132 | Test Loss=0.025525791 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [161/1000] | Train Loss=0.013989102 | Test Loss=0.016249059 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [162/1000] | Train Loss=0.012596671 | Test Loss=0.023790845 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [163/1000] | Train Loss=0.014366941 | Test Loss=0.019522120 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [164/1000] | Train Loss=0.014003218 | Test Loss=0.011273491 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [165/1000] | Train Loss=0.016679890 | Test Loss=0.023277674 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [166/1000] | Train Loss=0.013859514 | Test Loss=0.012088387 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [167/1000] | Train Loss=0.013696084 | Test Loss=0.025841369 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [168/1000] | Train Loss=0.017573065 | Test Loss=0.013186405 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [169/1000] | Train Loss=0.018783006 | Test Loss=0.018670085 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [170/1000] | Train Loss=0.013228616 | Test Loss=0.015734778 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [171/1000] | Train Loss=0.013653526 | Test Loss=0.024220064 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [172/1000] | Train Loss=0.012318601 | Test Loss=0.011168185 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [173/1000] | Train Loss=0.012278062 | Test Loss=0.015714510 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [174/1000] | Train Loss=0.016555401 | Test Loss=0.015944052 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [175/1000] | Train Loss=0.011417657 | Test Loss=0.027348144 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [176/1000] | Train Loss=0.012322265 | Test Loss=0.016058313 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [177/1000] | Train Loss=0.013891392 | Test Loss=0.014489371 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [178/1000] | Train Loss=0.012683415 | Test Loss=0.014481520 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [179/1000] | Train Loss=0.013318485 | Test Loss=0.018680581 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [180/1000] | Train Loss=0.016045420 | Test Loss=0.028259135 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [181/1000] | Train Loss=0.013229515 | Test Loss=0.010311893 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [182/1000] | Train Loss=0.013576174 | Test Loss=0.022915496 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [183/1000] | Train Loss=0.011962140 | Test Loss=0.014446117 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [184/1000] | Train Loss=0.014662589 | Test Loss=0.010909868 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [185/1000] | Train Loss=0.016043897 | Test Loss=0.020138215 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [186/1000] | Train Loss=0.016725618 | Test Loss=0.011649042 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [187/1000] | Train Loss=0.015752687 | Test Loss=0.014213937 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [188/1000] | Train Loss=0.017147668 | Test Loss=0.009378160 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [189/1000] | Train Loss=0.011285582 | Test Loss=0.014780688 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [190/1000] | Train Loss=0.019067082 | Test Loss=0.018569602 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [191/1000] | Train Loss=0.013209853 | Test Loss=0.023485514 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [192/1000] | Train Loss=0.014927530 | Test Loss=0.011138028 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [193/1000] | Train Loss=0.011477380 | Test Loss=0.014599356 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [194/1000] | Train Loss=0.012299683 | Test Loss=0.012689912 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [195/1000] | Train Loss=0.016513185 | Test Loss=0.012172749 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [196/1000] | Train Loss=0.015607937 | Test Loss=0.018434810 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [197/1000] | Train Loss=0.010943624 | Test Loss=0.011621362 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [198/1000] | Train Loss=0.016013550 | Test Loss=0.042396330 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [199/1000] | Train Loss=0.014057272 | Test Loss=0.011071744 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [200/1000] | Train Loss=0.011820277 | Test Loss=0.013472809 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [201/1000] | Train Loss=0.012942745 | Test Loss=0.012493788 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [202/1000] | Train Loss=0.014019715 | Test Loss=0.013569021 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [203/1000] | Train Loss=0.011200625 | Test Loss=0.011576365 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [204/1000] | Train Loss=0.011728060 | Test Loss=0.030733465 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [205/1000] | Train Loss=0.012765777 | Test Loss=0.017972355 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [206/1000] | Train Loss=0.018657634 | Test Loss=0.017454464 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [207/1000] | Train Loss=0.011238682 | Test Loss=0.010365685 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [208/1000] | Train Loss=0.016626970 | Test Loss=0.017668052 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [209/1000] | Train Loss=0.009398361 | Test Loss=0.017442330 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [210/1000] | Train Loss=0.010004940 | Test Loss=0.012522974 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [211/1000] | Train Loss=0.012703930 | Test Loss=0.014212372 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [212/1000] | Train Loss=0.011886147 | Test Loss=0.021341114 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [213/1000] | Train Loss=0.019810160 | Test Loss=0.035566294 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [214/1000] | Train Loss=0.014151171 | Test Loss=0.022945159 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [215/1000] | Train Loss=0.010302872 | Test Loss=0.007156504 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [216/1000] | Train Loss=0.010695633 | Test Loss=0.013084447 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [217/1000] | Train Loss=0.012272404 | Test Loss=0.022605464 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [218/1000] | Train Loss=0.019174810 | Test Loss=0.017099638 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [219/1000] | Train Loss=0.012301667 | Test Loss=0.012544944 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [220/1000] | Train Loss=0.011741663 | Test Loss=0.014851729 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [221/1000] | Train Loss=0.015311983 | Test Loss=0.028778642 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [222/1000] | Train Loss=0.015482635 | Test Loss=0.016256413 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [223/1000] | Train Loss=0.011711351 | Test Loss=0.007831209 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [224/1000] | Train Loss=0.012269233 | Test Loss=0.014295102 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [225/1000] | Train Loss=0.011898630 | Test Loss=0.008758478 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [226/1000] | Train Loss=0.010805181 | Test Loss=0.027600317 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [227/1000] | Train Loss=0.010463012 | Test Loss=0.014450023 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [228/1000] | Train Loss=0.020779622 | Test Loss=0.014866154 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [229/1000] | Train Loss=0.017012037 | Test Loss=0.012798672 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [230/1000] | Train Loss=0.013241216 | Test Loss=0.023624746 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [231/1000] | Train Loss=0.016255709 | Test Loss=0.016990117 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [232/1000] | Train Loss=0.019481620 | Test Loss=0.011288096 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [233/1000] | Train Loss=0.009103365 | Test Loss=0.009985451 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [234/1000] | Train Loss=0.014582576 | Test Loss=0.007314552 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [235/1000] | Train Loss=0.011564350 | Test Loss=0.030999749 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [236/1000] | Train Loss=0.013731596 | Test Loss=0.011592288 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [237/1000] | Train Loss=0.017991862 | Test Loss=0.030719687 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [238/1000] | Train Loss=0.016743573 | Test Loss=0.008960932 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [239/1000] | Train Loss=0.011693795 | Test Loss=0.009631597 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [240/1000] | Train Loss=0.009867914 | Test Loss=0.017224992 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [241/1000] | Train Loss=0.013702458 | Test Loss=0.011389333 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [242/1000] | Train Loss=0.014592764 | Test Loss=0.012037805 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [243/1000] | Train Loss=0.013939825 | Test Loss=0.014236589 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [244/1000] | Train Loss=0.021277415 | Test Loss=0.023949626 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [245/1000] | Train Loss=0.018971145 | Test Loss=0.018183354 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [246/1000] | Train Loss=0.012841956 | Test Loss=0.014726450 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [247/1000] | Train Loss=0.011857314 | Test Loss=0.017586223 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [248/1000] | Train Loss=0.010755365 | Test Loss=0.010328647 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [249/1000] | Train Loss=0.010677993 | Test Loss=0.009411084 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [250/1000] | Train Loss=0.011496228 | Test Loss=0.011893309 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [251/1000] | Train Loss=0.014259804 | Test Loss=0.019975812 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [252/1000] | Train Loss=0.015076777 | Test Loss=0.012924666 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [253/1000] | Train Loss=0.018807595 | Test Loss=0.018369167 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [254/1000] | Train Loss=0.016873951 | Test Loss=0.014267724 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [255/1000] | Train Loss=0.013153960 | Test Loss=0.019652665 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [256/1000] | Train Loss=0.011539761 | Test Loss=0.009283642 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [257/1000] | Train Loss=0.010228969 | Test Loss=0.012509440 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [258/1000] | Train Loss=0.011021347 | Test Loss=0.009702395 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [259/1000] | Train Loss=0.009164105 | Test Loss=0.015208224 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [260/1000] | Train Loss=0.019262506 | Test Loss=0.027805458 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [261/1000] | Train Loss=0.011254374 | Test Loss=0.009703068 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [262/1000] | Train Loss=0.013851878 | Test Loss=0.013369643 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [263/1000] | Train Loss=0.018320272 | Test Loss=0.012724984 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [264/1000] | Train Loss=0.018309029 | Test Loss=0.023113679 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [265/1000] | Train Loss=0.016770206 | Test Loss=0.014457238 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [266/1000] | Train Loss=0.009085078 | Test Loss=0.017864522 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [267/1000] | Train Loss=0.010890136 | Test Loss=0.007885649 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [268/1000] | Train Loss=0.009613043 | Test Loss=0.011876413 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [269/1000] | Train Loss=0.013025497 | Test Loss=0.021070679 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [270/1000] | Train Loss=0.016649347 | Test Loss=0.016820715 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [271/1000] | Train Loss=0.013291234 | Test Loss=0.008554668 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [272/1000] | Train Loss=0.010902783 | Test Loss=0.006084222 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [273/1000] | Train Loss=0.010185123 | Test Loss=0.014690627 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [274/1000] | Train Loss=0.009641969 | Test Loss=0.011088374 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [275/1000] | Train Loss=0.009625478 | Test Loss=0.009356827 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [276/1000] | Train Loss=0.010230880 | Test Loss=0.016252239 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [277/1000] | Train Loss=0.011888334 | Test Loss=0.011547531 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [278/1000] | Train Loss=0.009705495 | Test Loss=0.011084736 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [279/1000] | Train Loss=0.016595173 | Test Loss=0.023899402 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [280/1000] | Train Loss=0.013316280 | Test Loss=0.018620378 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [281/1000] | Train Loss=0.011276535 | Test Loss=0.025615087 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [282/1000] | Train Loss=0.018218954 | Test Loss=0.018757500 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [283/1000] | Train Loss=0.017753918 | Test Loss=0.012416191 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [284/1000] | Train Loss=0.010630872 | Test Loss=0.016568170 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [285/1000] | Train Loss=0.009032334 | Test Loss=0.012911113 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [286/1000] | Train Loss=0.012309058 | Test Loss=0.010513501 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [287/1000] | Train Loss=0.017146906 | Test Loss=0.020572638 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [288/1000] | Train Loss=0.016279946 | Test Loss=0.008558775 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [289/1000] | Train Loss=0.010918388 | Test Loss=0.014498623 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [290/1000] | Train Loss=0.008693502 | Test Loss=0.014794343 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [291/1000] | Train Loss=0.009420410 | Test Loss=0.007331136 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [292/1000] | Train Loss=0.009482604 | Test Loss=0.008627938 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [293/1000] | Train Loss=0.007341600 | Test Loss=0.008687610 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [294/1000] | Train Loss=0.009845887 | Test Loss=0.010822117 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [295/1000] | Train Loss=0.009744347 | Test Loss=0.012430349 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [296/1000] | Train Loss=0.008479609 | Test Loss=0.012079640 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [297/1000] | Train Loss=0.015210192 | Test Loss=0.022002774 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [298/1000] | Train Loss=0.012338564 | Test Loss=0.008939974 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [299/1000] | Train Loss=0.009133758 | Test Loss=0.010777856 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [300/1000] | Train Loss=0.009222348 | Test Loss=0.010817748 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [301/1000] | Train Loss=0.009927454 | Test Loss=0.009167260 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [302/1000] | Train Loss=0.009609479 | Test Loss=0.009425658 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [303/1000] | Train Loss=0.010022485 | Test Loss=0.011290524 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [304/1000] | Train Loss=0.009521017 | Test Loss=0.012366186 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [305/1000] | Train Loss=0.008763771 | Test Loss=0.011373192 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [306/1000] | Train Loss=0.010527010 | Test Loss=0.013104460 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [307/1000] | Train Loss=0.009782709 | Test Loss=0.007901439 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [308/1000] | Train Loss=0.009465323 | Test Loss=0.010667282 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [309/1000] | Train Loss=0.009455806 | Test Loss=0.015029862 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [310/1000] | Train Loss=0.009162359 | Test Loss=0.017694687 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [311/1000] | Train Loss=0.017613876 | Test Loss=0.015491990 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [312/1000] | Train Loss=0.010952957 | Test Loss=0.006358646 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [313/1000] | Train Loss=0.013490994 | Test Loss=0.009417631 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [314/1000] | Train Loss=0.014134864 | Test Loss=0.011325239 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [315/1000] | Train Loss=0.009432529 | Test Loss=0.009238111 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [316/1000] | Train Loss=0.015364906 | Test Loss=0.026199703 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [317/1000] | Train Loss=0.009314810 | Test Loss=0.010286713 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [318/1000] | Train Loss=0.008991662 | Test Loss=0.013395727 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [319/1000] | Train Loss=0.008870453 | Test Loss=0.010474912 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [320/1000] | Train Loss=0.008744190 | Test Loss=0.014536294 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [321/1000] | Train Loss=0.008520773 | Test Loss=0.012428107 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [322/1000] | Train Loss=0.008764836 | Test Loss=0.009499582 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [323/1000] | Train Loss=0.008921870 | Test Loss=0.007774676 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [324/1000] | Train Loss=0.011102506 | Test Loss=0.018320277 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [325/1000] | Train Loss=0.009333735 | Test Loss=0.012910582 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [326/1000] | Train Loss=0.009242968 | Test Loss=0.006533052 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [327/1000] | Train Loss=0.010879598 | Test Loss=0.009696774 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [328/1000] | Train Loss=0.014917574 | Test Loss=0.014627767 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [329/1000] | Train Loss=0.009503248 | Test Loss=0.008616369 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [330/1000] | Train Loss=0.009247919 | Test Loss=0.006225658 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [331/1000] | Train Loss=0.007872209 | Test Loss=0.010382233 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [332/1000] | Train Loss=0.008378119 | Test Loss=0.008976297 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [333/1000] | Train Loss=0.011586035 | Test Loss=0.007982522 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [334/1000] | Train Loss=0.009181417 | Test Loss=0.012890389 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [335/1000] | Train Loss=0.004701715 | Test Loss=0.006342310 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [336/1000] | Train Loss=0.004241744 | Test Loss=0.004496752 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [337/1000] | Train Loss=0.004471859 | Test Loss=0.008957844 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [338/1000] | Train Loss=0.005762499 | Test Loss=0.014029236 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [339/1000] | Train Loss=0.005275587 | Test Loss=0.005341084 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [340/1000] | Train Loss=0.003981831 | Test Loss=0.006477991 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [341/1000] | Train Loss=0.007039780 | Test Loss=0.007953568 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [342/1000] | Train Loss=0.004959349 | Test Loss=0.006242447 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [343/1000] | Train Loss=0.003622693 | Test Loss=0.006508162 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [344/1000] | Train Loss=0.005218294 | Test Loss=0.005804589 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [345/1000] | Train Loss=0.004481136 | Test Loss=0.006326436 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [346/1000] | Train Loss=0.004166514 | Test Loss=0.007931964 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [347/1000] | Train Loss=0.007838540 | Test Loss=0.005875957 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [348/1000] | Train Loss=0.008139148 | Test Loss=0.005798869 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [349/1000] | Train Loss=0.005781833 | Test Loss=0.004766968 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [350/1000] | Train Loss=0.004686735 | Test Loss=0.004838295 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [351/1000] | Train Loss=0.003760682 | Test Loss=0.006345362 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [352/1000] | Train Loss=0.007012732 | Test Loss=0.011135997 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [353/1000] | Train Loss=0.008531423 | Test Loss=0.005889510 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [354/1000] | Train Loss=0.006331427 | Test Loss=0.007495457 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [355/1000] | Train Loss=0.004021224 | Test Loss=0.007201142 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [356/1000] | Train Loss=0.004085010 | Test Loss=0.006096342 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [357/1000] | Train Loss=0.004504520 | Test Loss=0.005246382 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [358/1000] | Train Loss=0.003967486 | Test Loss=0.008550886 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [359/1000] | Train Loss=0.003620548 | Test Loss=0.004566664 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [360/1000] | Train Loss=0.004807374 | Test Loss=0.013750302 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [361/1000] | Train Loss=0.006582161 | Test Loss=0.006751219 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [362/1000] | Train Loss=0.004491534 | Test Loss=0.015696750 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [363/1000] | Train Loss=0.007502472 | Test Loss=0.006872016 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [364/1000] | Train Loss=0.004246935 | Test Loss=0.005039851 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [365/1000] | Train Loss=0.004252905 | Test Loss=0.009874324 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [366/1000] | Train Loss=0.004612194 | Test Loss=0.007177815 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [367/1000] | Train Loss=0.004642437 | Test Loss=0.005052521 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [368/1000] | Train Loss=0.004452814 | Test Loss=0.005504101 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [369/1000] | Train Loss=0.004512247 | Test Loss=0.008243367 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [370/1000] | Train Loss=0.004625775 | Test Loss=0.007944841 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [371/1000] | Train Loss=0.004047882 | Test Loss=0.005372127 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [372/1000] | Train Loss=0.004503760 | Test Loss=0.006602138 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [373/1000] | Train Loss=0.004808613 | Test Loss=0.011174339 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [374/1000] | Train Loss=0.005257469 | Test Loss=0.009212745 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [375/1000] | Train Loss=0.005963623 | Test Loss=0.009954894 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [376/1000] | Train Loss=0.004207735 | Test Loss=0.004851714 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [377/1000] | Train Loss=0.005560302 | Test Loss=0.011829005 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [378/1000] | Train Loss=0.008416895 | Test Loss=0.013975021 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [379/1000] | Train Loss=0.008377806 | Test Loss=0.006032475 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [380/1000] | Train Loss=0.005834665 | Test Loss=0.009372950 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [381/1000] | Train Loss=0.004576501 | Test Loss=0.006529834 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [382/1000] | Train Loss=0.007283845 | Test Loss=0.010115398 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [383/1000] | Train Loss=0.006230178 | Test Loss=0.006047355 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [384/1000] | Train Loss=0.004314241 | Test Loss=0.013378096 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [385/1000] | Train Loss=0.006680234 | Test Loss=0.009524902 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [386/1000] | Train Loss=0.008355625 | Test Loss=0.012542950 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [387/1000] | Train Loss=0.006696109 | Test Loss=0.009508974 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [388/1000] | Train Loss=0.004997284 | Test Loss=0.006409443 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [389/1000] | Train Loss=0.004605532 | Test Loss=0.005700191 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [390/1000] | Train Loss=0.004185574 | Test Loss=0.005118712 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [391/1000] | Train Loss=0.004598627 | Test Loss=0.004771007 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [392/1000] | Train Loss=0.004351826 | Test Loss=0.009360618 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [393/1000] | Train Loss=0.004284459 | Test Loss=0.004552181 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [394/1000] | Train Loss=0.004318860 | Test Loss=0.005093337 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [395/1000] | Train Loss=0.004061176 | Test Loss=0.006477156 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [396/1000] | Train Loss=0.004623842 | Test Loss=0.005261155 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [397/1000] | Train Loss=0.004726048 | Test Loss=0.007906620 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [398/1000] | Train Loss=0.004516333 | Test Loss=0.004871672 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [399/1000] | Train Loss=0.004052978 | Test Loss=0.004245427 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [400/1000] | Train Loss=0.004387276 | Test Loss=0.005327480 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [401/1000] | Train Loss=0.002150950 | Test Loss=0.004208511 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [402/1000] | Train Loss=0.003552845 | Test Loss=0.004628076 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [403/1000] | Train Loss=0.004150490 | Test Loss=0.008844222 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [404/1000] | Train Loss=0.002740892 | Test Loss=0.004048132 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [405/1000] | Train Loss=0.002178908 | Test Loss=0.003986118 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [406/1000] | Train Loss=0.002076996 | Test Loss=0.004343875 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [407/1000] | Train Loss=0.002075568 | Test Loss=0.004125311 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [408/1000] | Train Loss=0.002019440 | Test Loss=0.004651686 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [409/1000] | Train Loss=0.002326311 | Test Loss=0.005039501 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [410/1000] | Train Loss=0.002185492 | Test Loss=0.003819501 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [411/1000] | Train Loss=0.002115718 | Test Loss=0.005660504 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [412/1000] | Train Loss=0.004244252 | Test Loss=0.004896734 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [413/1000] | Train Loss=0.004203842 | Test Loss=0.008825634 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [414/1000] | Train Loss=0.004119732 | Test Loss=0.005142969 | Time=1.75s | LR=2.50e-04\n",
      "Epoch [415/1000] | Train Loss=0.003549912 | Test Loss=0.003870024 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [416/1000] | Train Loss=0.002066442 | Test Loss=0.004883172 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [417/1000] | Train Loss=0.002236808 | Test Loss=0.004275779 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [418/1000] | Train Loss=0.001977999 | Test Loss=0.004122447 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [419/1000] | Train Loss=0.002295779 | Test Loss=0.004743311 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [420/1000] | Train Loss=0.002186817 | Test Loss=0.003988259 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [421/1000] | Train Loss=0.003633593 | Test Loss=0.006388079 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [422/1000] | Train Loss=0.004142863 | Test Loss=0.007801166 | Time=1.75s | LR=2.50e-04\n",
      "Epoch [423/1000] | Train Loss=0.004034434 | Test Loss=0.006355257 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [424/1000] | Train Loss=0.002399841 | Test Loss=0.003622408 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [425/1000] | Train Loss=0.002039459 | Test Loss=0.003867399 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [426/1000] | Train Loss=0.001772660 | Test Loss=0.004102933 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [427/1000] | Train Loss=0.002095919 | Test Loss=0.005082530 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [428/1000] | Train Loss=0.002254544 | Test Loss=0.003908939 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [429/1000] | Train Loss=0.002418965 | Test Loss=0.004779618 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [430/1000] | Train Loss=0.002265838 | Test Loss=0.003916336 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [431/1000] | Train Loss=0.002375311 | Test Loss=0.004326783 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [432/1000] | Train Loss=0.002105397 | Test Loss=0.004050179 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [433/1000] | Train Loss=0.003229092 | Test Loss=0.004132536 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [434/1000] | Train Loss=0.004180789 | Test Loss=0.005974101 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [435/1000] | Train Loss=0.002696053 | Test Loss=0.004018225 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [436/1000] | Train Loss=0.002389038 | Test Loss=0.005223646 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [437/1000] | Train Loss=0.002534358 | Test Loss=0.005090205 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [438/1000] | Train Loss=0.004088764 | Test Loss=0.003463724 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [439/1000] | Train Loss=0.002632739 | Test Loss=0.004792039 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [440/1000] | Train Loss=0.004110329 | Test Loss=0.006520206 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [441/1000] | Train Loss=0.003298728 | Test Loss=0.004615467 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [442/1000] | Train Loss=0.002269811 | Test Loss=0.003774881 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [443/1000] | Train Loss=0.002229599 | Test Loss=0.003367838 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [444/1000] | Train Loss=0.002231220 | Test Loss=0.004105235 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [445/1000] | Train Loss=0.001818886 | Test Loss=0.003698739 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [446/1000] | Train Loss=0.002849059 | Test Loss=0.004184689 | Time=1.75s | LR=2.50e-04\n",
      "Epoch [447/1000] | Train Loss=0.002416497 | Test Loss=0.003918345 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [448/1000] | Train Loss=0.002360369 | Test Loss=0.004444379 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [449/1000] | Train Loss=0.002103506 | Test Loss=0.005201032 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [450/1000] | Train Loss=0.003574449 | Test Loss=0.006207930 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [451/1000] | Train Loss=0.002583352 | Test Loss=0.004108292 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [452/1000] | Train Loss=0.003601064 | Test Loss=0.005585980 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [453/1000] | Train Loss=0.004054212 | Test Loss=0.005623641 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [454/1000] | Train Loss=0.001959054 | Test Loss=0.003793203 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [455/1000] | Train Loss=0.002239338 | Test Loss=0.004949379 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [456/1000] | Train Loss=0.001829383 | Test Loss=0.003765470 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [457/1000] | Train Loss=0.001995145 | Test Loss=0.004189489 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [458/1000] | Train Loss=0.002165082 | Test Loss=0.003587414 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [459/1000] | Train Loss=0.001967172 | Test Loss=0.003589378 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [460/1000] | Train Loss=0.001951136 | Test Loss=0.003441079 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [461/1000] | Train Loss=0.001431240 | Test Loss=0.003773765 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [462/1000] | Train Loss=0.002123537 | Test Loss=0.003935929 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [463/1000] | Train Loss=0.002450612 | Test Loss=0.005547515 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [464/1000] | Train Loss=0.004219946 | Test Loss=0.004516038 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [465/1000] | Train Loss=0.003847157 | Test Loss=0.003513783 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [466/1000] | Train Loss=0.002016246 | Test Loss=0.004207803 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [467/1000] | Train Loss=0.002233720 | Test Loss=0.003740071 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [468/1000] | Train Loss=0.002275360 | Test Loss=0.003675575 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [469/1000] | Train Loss=0.002143857 | Test Loss=0.003615690 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [470/1000] | Train Loss=0.001837565 | Test Loss=0.003703143 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [471/1000] | Train Loss=0.002230785 | Test Loss=0.004768103 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [472/1000] | Train Loss=0.002329565 | Test Loss=0.003877891 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [473/1000] | Train Loss=0.001902217 | Test Loss=0.003946216 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [474/1000] | Train Loss=0.002256233 | Test Loss=0.004194008 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [475/1000] | Train Loss=0.002139127 | Test Loss=0.003673710 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [476/1000] | Train Loss=0.002297262 | Test Loss=0.004764724 | Time=1.76s | LR=2.50e-04\n",
      "Epoch [477/1000] | Train Loss=0.003175461 | Test Loss=0.004069107 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [478/1000] | Train Loss=0.002423260 | Test Loss=0.005065344 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [479/1000] | Train Loss=0.002937234 | Test Loss=0.003980032 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [480/1000] | Train Loss=0.002241365 | Test Loss=0.004446703 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [481/1000] | Train Loss=0.002119086 | Test Loss=0.004669378 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [482/1000] | Train Loss=0.002008406 | Test Loss=0.003641809 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [483/1000] | Train Loss=0.001891496 | Test Loss=0.003857636 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [484/1000] | Train Loss=0.002052221 | Test Loss=0.003424069 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [485/1000] | Train Loss=0.003547924 | Test Loss=0.005694513 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [486/1000] | Train Loss=0.003920453 | Test Loss=0.004012813 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [487/1000] | Train Loss=0.002809337 | Test Loss=0.004219524 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [488/1000] | Train Loss=0.002188107 | Test Loss=0.003754204 | Time=1.58s | LR=2.50e-04\n",
      "Epoch [489/1000] | Train Loss=0.002270022 | Test Loss=0.003651424 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [490/1000] | Train Loss=0.003476291 | Test Loss=0.004052641 | Time=1.57s | LR=2.50e-04\n",
      "Epoch [491/1000] | Train Loss=0.003579898 | Test Loss=0.003872292 | Time=1.59s | LR=2.50e-04\n",
      "Epoch [492/1000] | Train Loss=0.002181526 | Test Loss=0.003782429 | Time=1.57s | LR=2.50e-04\n",
      "Epoch [493/1000] | Train Loss=0.002306245 | Test Loss=0.004594655 | Time=1.57s | LR=2.50e-04\n",
      "Epoch [494/1000] | Train Loss=0.002196680 | Test Loss=0.004942677 | Time=1.57s | LR=2.50e-04\n",
      "Epoch [495/1000] | Train Loss=0.002156105 | Test Loss=0.004236967 | Time=1.76s | LR=2.50e-04\n",
      "Epoch [496/1000] | Train Loss=0.002238377 | Test Loss=0.005102194 | Time=1.78s | LR=2.50e-04\n",
      "Epoch [497/1000] | Train Loss=0.002117575 | Test Loss=0.003609601 | Time=1.77s | LR=2.50e-04\n",
      "Epoch [498/1000] | Train Loss=0.002232330 | Test Loss=0.004655112 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [499/1000] | Train Loss=0.002474361 | Test Loss=0.003667535 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [500/1000] | Train Loss=0.002054229 | Test Loss=0.003955094 | Time=1.79s | LR=2.50e-04\n",
      "Epoch [501/1000] | Train Loss=0.002326117 | Test Loss=0.003717021 | Time=1.80s | LR=2.50e-04\n",
      "Epoch [502/1000] | Train Loss=0.002236640 | Test Loss=0.005218715 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [503/1000] | Train Loss=0.001451045 | Test Loss=0.003813005 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [504/1000] | Train Loss=0.001076406 | Test Loss=0.003394412 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [505/1000] | Train Loss=0.001164924 | Test Loss=0.003762794 | Time=1.65s | LR=1.25e-04\n",
      "Epoch [506/1000] | Train Loss=0.001097714 | Test Loss=0.003268641 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [507/1000] | Train Loss=0.000946997 | Test Loss=0.003359114 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [508/1000] | Train Loss=0.000811540 | Test Loss=0.003454879 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [509/1000] | Train Loss=0.001032950 | Test Loss=0.003481389 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [510/1000] | Train Loss=0.000972839 | Test Loss=0.003963119 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [511/1000] | Train Loss=0.001046334 | Test Loss=0.003358218 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [512/1000] | Train Loss=0.001062257 | Test Loss=0.003744766 | Time=1.58s | LR=1.25e-04\n",
      "Epoch [513/1000] | Train Loss=0.001082468 | Test Loss=0.004242412 | Time=1.58s | LR=1.25e-04\n",
      "Epoch [514/1000] | Train Loss=0.001175181 | Test Loss=0.003280898 | Time=1.76s | LR=1.25e-04\n",
      "Epoch [515/1000] | Train Loss=0.000988483 | Test Loss=0.003282864 | Time=1.80s | LR=1.25e-04\n",
      "Epoch [516/1000] | Train Loss=0.001130694 | Test Loss=0.003183448 | Time=1.76s | LR=1.25e-04\n",
      "Epoch [517/1000] | Train Loss=0.001223314 | Test Loss=0.003760931 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [518/1000] | Train Loss=0.001063069 | Test Loss=0.003207101 | Time=1.80s | LR=1.25e-04\n",
      "Epoch [519/1000] | Train Loss=0.001187734 | Test Loss=0.003654809 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [520/1000] | Train Loss=0.001699070 | Test Loss=0.004631222 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [521/1000] | Train Loss=0.001604512 | Test Loss=0.004328198 | Time=1.80s | LR=1.25e-04\n",
      "Epoch [522/1000] | Train Loss=0.001194575 | Test Loss=0.003469045 | Time=1.79s | LR=1.25e-04\n",
      "Epoch [523/1000] | Train Loss=0.001288739 | Test Loss=0.003207007 | Time=1.61s | LR=1.25e-04\n",
      "Epoch [524/1000] | Train Loss=0.001173529 | Test Loss=0.003972588 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [525/1000] | Train Loss=0.001231617 | Test Loss=0.003347648 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [526/1000] | Train Loss=0.001077918 | Test Loss=0.003156350 | Time=1.58s | LR=1.25e-04\n",
      "Epoch [527/1000] | Train Loss=0.001196019 | Test Loss=0.003570117 | Time=1.58s | LR=1.25e-04\n",
      "Epoch [528/1000] | Train Loss=0.001169827 | Test Loss=0.003831342 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [529/1000] | Train Loss=0.001153254 | Test Loss=0.003228392 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [530/1000] | Train Loss=0.001021233 | Test Loss=0.003293255 | Time=1.60s | LR=1.25e-04\n",
      "Epoch [531/1000] | Train Loss=0.001200663 | Test Loss=0.003294388 | Time=1.58s | LR=1.25e-04\n",
      "Epoch [532/1000] | Train Loss=0.001012944 | Test Loss=0.003230095 | Time=1.59s | LR=1.25e-04\n",
      "Epoch [533/1000] | Train Loss=0.001143278 | Test Loss=0.003619195 | Time=1.75s | LR=1.25e-04\n",
      "Epoch [534/1000] | Train Loss=0.001174540 | Test Loss=0.003545471 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [535/1000] | Train Loss=0.001025905 | Test Loss=0.003472419 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [536/1000] | Train Loss=0.001164190 | Test Loss=0.003647404 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [537/1000] | Train Loss=0.001043252 | Test Loss=0.003386316 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [538/1000] | Train Loss=0.001055898 | Test Loss=0.003264012 | Time=1.75s | LR=1.25e-04\n",
      "Epoch [539/1000] | Train Loss=0.001630634 | Test Loss=0.003403468 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [540/1000] | Train Loss=0.001475578 | Test Loss=0.003242438 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [541/1000] | Train Loss=0.001092591 | Test Loss=0.003336753 | Time=1.58s | LR=1.25e-04\n",
      "Epoch [542/1000] | Train Loss=0.001145607 | Test Loss=0.003635313 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [543/1000] | Train Loss=0.001168549 | Test Loss=0.003174931 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [544/1000] | Train Loss=0.001187749 | Test Loss=0.003188684 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [545/1000] | Train Loss=0.001085811 | Test Loss=0.003079372 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [546/1000] | Train Loss=0.001609154 | Test Loss=0.003141697 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [547/1000] | Train Loss=0.001973066 | Test Loss=0.003082671 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [548/1000] | Train Loss=0.000919380 | Test Loss=0.003820446 | Time=1.57s | LR=1.25e-04\n",
      "Epoch [549/1000] | Train Loss=0.001262068 | Test Loss=0.003792689 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [550/1000] | Train Loss=0.000573774 | Test Loss=0.003214558 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [551/1000] | Train Loss=0.000470247 | Test Loss=0.003048150 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [552/1000] | Train Loss=0.000532840 | Test Loss=0.003067530 | Time=1.66s | LR=6.25e-05\n",
      "Epoch [553/1000] | Train Loss=0.000620588 | Test Loss=0.003060882 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [554/1000] | Train Loss=0.000513187 | Test Loss=0.003371942 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [555/1000] | Train Loss=0.000624028 | Test Loss=0.003185830 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [556/1000] | Train Loss=0.000614030 | Test Loss=0.003004618 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [557/1000] | Train Loss=0.000552604 | Test Loss=0.003000513 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [558/1000] | Train Loss=0.000480866 | Test Loss=0.003041496 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [559/1000] | Train Loss=0.000665283 | Test Loss=0.003028127 | Time=1.65s | LR=6.25e-05\n",
      "Epoch [560/1000] | Train Loss=0.000577287 | Test Loss=0.003250608 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [561/1000] | Train Loss=0.000497039 | Test Loss=0.003132959 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [562/1000] | Train Loss=0.000532182 | Test Loss=0.003044802 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [563/1000] | Train Loss=0.000492629 | Test Loss=0.003001417 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [564/1000] | Train Loss=0.000631244 | Test Loss=0.003167992 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [565/1000] | Train Loss=0.000911463 | Test Loss=0.003230454 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [566/1000] | Train Loss=0.001135753 | Test Loss=0.003203031 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [567/1000] | Train Loss=0.000544995 | Test Loss=0.003152086 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [568/1000] | Train Loss=0.000458304 | Test Loss=0.003005426 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [569/1000] | Train Loss=0.000489446 | Test Loss=0.003027386 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [570/1000] | Train Loss=0.000564619 | Test Loss=0.003006195 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [571/1000] | Train Loss=0.000642169 | Test Loss=0.002964457 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [572/1000] | Train Loss=0.000599276 | Test Loss=0.003135866 | Time=1.72s | LR=6.25e-05\n",
      "Epoch [573/1000] | Train Loss=0.000631705 | Test Loss=0.003069613 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [574/1000] | Train Loss=0.000677961 | Test Loss=0.002989756 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [575/1000] | Train Loss=0.000595132 | Test Loss=0.003083263 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [576/1000] | Train Loss=0.000578993 | Test Loss=0.002944652 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [577/1000] | Train Loss=0.000582511 | Test Loss=0.003149575 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [578/1000] | Train Loss=0.000645904 | Test Loss=0.003078690 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [579/1000] | Train Loss=0.000365924 | Test Loss=0.003100824 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [580/1000] | Train Loss=0.000562043 | Test Loss=0.002935888 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [581/1000] | Train Loss=0.000619823 | Test Loss=0.002892033 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [582/1000] | Train Loss=0.000542023 | Test Loss=0.002979539 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [583/1000] | Train Loss=0.000562206 | Test Loss=0.003163321 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [584/1000] | Train Loss=0.000611302 | Test Loss=0.003235726 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [585/1000] | Train Loss=0.000505557 | Test Loss=0.003295264 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [586/1000] | Train Loss=0.000620407 | Test Loss=0.002910887 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [587/1000] | Train Loss=0.000496998 | Test Loss=0.003116393 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [588/1000] | Train Loss=0.000659004 | Test Loss=0.003025910 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [589/1000] | Train Loss=0.000565282 | Test Loss=0.003052689 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [590/1000] | Train Loss=0.000686019 | Test Loss=0.002986233 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [591/1000] | Train Loss=0.000561327 | Test Loss=0.002992984 | Time=1.59s | LR=6.25e-05\n",
      "Epoch [592/1000] | Train Loss=0.000568353 | Test Loss=0.002842824 | Time=1.75s | LR=6.25e-05\n",
      "Epoch [593/1000] | Train Loss=0.000672159 | Test Loss=0.002880762 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [594/1000] | Train Loss=0.000659426 | Test Loss=0.002961374 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [595/1000] | Train Loss=0.000672542 | Test Loss=0.002893981 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [596/1000] | Train Loss=0.000648001 | Test Loss=0.002931828 | Time=1.67s | LR=6.25e-05\n",
      "Epoch [597/1000] | Train Loss=0.000630578 | Test Loss=0.002945541 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [598/1000] | Train Loss=0.000616294 | Test Loss=0.002852914 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [599/1000] | Train Loss=0.000568352 | Test Loss=0.002926136 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [600/1000] | Train Loss=0.000555036 | Test Loss=0.003190892 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [601/1000] | Train Loss=0.000631517 | Test Loss=0.002900448 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [602/1000] | Train Loss=0.000471722 | Test Loss=0.003151028 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [603/1000] | Train Loss=0.000533030 | Test Loss=0.002936265 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [604/1000] | Train Loss=0.000544363 | Test Loss=0.002859926 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [605/1000] | Train Loss=0.000594090 | Test Loss=0.002897187 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [606/1000] | Train Loss=0.000646241 | Test Loss=0.002900882 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [607/1000] | Train Loss=0.000566487 | Test Loss=0.002985808 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [608/1000] | Train Loss=0.000971487 | Test Loss=0.003502887 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [609/1000] | Train Loss=0.001157939 | Test Loss=0.002919907 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [610/1000] | Train Loss=0.000633419 | Test Loss=0.002903501 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [611/1000] | Train Loss=0.000620293 | Test Loss=0.002944086 | Time=1.61s | LR=6.25e-05\n",
      "Epoch [612/1000] | Train Loss=0.000600224 | Test Loss=0.002896559 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [613/1000] | Train Loss=0.000571583 | Test Loss=0.002880918 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [614/1000] | Train Loss=0.000547323 | Test Loss=0.002997770 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [615/1000] | Train Loss=0.000535329 | Test Loss=0.002871206 | Time=1.62s | LR=6.25e-05\n",
      "Epoch [616/1000] | Train Loss=0.000542230 | Test Loss=0.002869200 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [617/1000] | Train Loss=0.000643004 | Test Loss=0.002933698 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [618/1000] | Train Loss=0.000688753 | Test Loss=0.002913047 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [619/1000] | Train Loss=0.000619424 | Test Loss=0.002947097 | Time=1.57s | LR=6.25e-05\n",
      "Epoch [620/1000] | Train Loss=0.000620506 | Test Loss=0.003015820 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [621/1000] | Train Loss=0.000299842 | Test Loss=0.002920875 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [622/1000] | Train Loss=0.000290859 | Test Loss=0.002836431 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [623/1000] | Train Loss=0.000363769 | Test Loss=0.002822665 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [624/1000] | Train Loss=0.000319491 | Test Loss=0.002906613 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [625/1000] | Train Loss=0.000278264 | Test Loss=0.002878891 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [626/1000] | Train Loss=0.000369309 | Test Loss=0.002908712 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [627/1000] | Train Loss=0.000306422 | Test Loss=0.002996875 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [628/1000] | Train Loss=0.000348946 | Test Loss=0.002860069 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [629/1000] | Train Loss=0.000350084 | Test Loss=0.002868138 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [630/1000] | Train Loss=0.000366671 | Test Loss=0.002963146 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [631/1000] | Train Loss=0.000307948 | Test Loss=0.002883609 | Time=1.61s | LR=3.13e-05\n",
      "Epoch [632/1000] | Train Loss=0.000296263 | Test Loss=0.002873665 | Time=1.74s | LR=3.13e-05\n",
      "Epoch [633/1000] | Train Loss=0.000363458 | Test Loss=0.002798008 | Time=1.75s | LR=3.13e-05\n",
      "Epoch [634/1000] | Train Loss=0.000418064 | Test Loss=0.002811653 | Time=1.60s | LR=3.13e-05\n",
      "Epoch [635/1000] | Train Loss=0.000309302 | Test Loss=0.002834171 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [636/1000] | Train Loss=0.000353543 | Test Loss=0.002892326 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [637/1000] | Train Loss=0.000378635 | Test Loss=0.002879077 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [638/1000] | Train Loss=0.000328118 | Test Loss=0.003029910 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [639/1000] | Train Loss=0.000338717 | Test Loss=0.002794196 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [640/1000] | Train Loss=0.000389891 | Test Loss=0.002908273 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [641/1000] | Train Loss=0.000398937 | Test Loss=0.002814474 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [642/1000] | Train Loss=0.000394033 | Test Loss=0.002766386 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [643/1000] | Train Loss=0.000289386 | Test Loss=0.002817549 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [644/1000] | Train Loss=0.000320711 | Test Loss=0.002828540 | Time=1.57s | LR=3.13e-05\n",
      "Epoch [645/1000] | Train Loss=0.000409332 | Test Loss=0.002795126 | Time=1.67s | LR=3.13e-05\n",
      "Epoch [646/1000] | Train Loss=0.000307368 | Test Loss=0.002829642 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [647/1000] | Train Loss=0.000299744 | Test Loss=0.002837391 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [648/1000] | Train Loss=0.000288847 | Test Loss=0.002857828 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [649/1000] | Train Loss=0.000331509 | Test Loss=0.002803117 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [650/1000] | Train Loss=0.000434182 | Test Loss=0.002720740 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [651/1000] | Train Loss=0.000335164 | Test Loss=0.002736963 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [652/1000] | Train Loss=0.000428619 | Test Loss=0.002819031 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [653/1000] | Train Loss=0.000337313 | Test Loss=0.002720970 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [654/1000] | Train Loss=0.000361074 | Test Loss=0.002711722 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [655/1000] | Train Loss=0.000360826 | Test Loss=0.002876815 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [656/1000] | Train Loss=0.000417432 | Test Loss=0.002748180 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [657/1000] | Train Loss=0.000308896 | Test Loss=0.002819902 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [658/1000] | Train Loss=0.000404781 | Test Loss=0.002708571 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [659/1000] | Train Loss=0.000389898 | Test Loss=0.002698769 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [660/1000] | Train Loss=0.000333681 | Test Loss=0.002809304 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [661/1000] | Train Loss=0.000347207 | Test Loss=0.002770100 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [662/1000] | Train Loss=0.000267643 | Test Loss=0.002739662 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [663/1000] | Train Loss=0.000309390 | Test Loss=0.002701519 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [664/1000] | Train Loss=0.000412245 | Test Loss=0.002721236 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [665/1000] | Train Loss=0.000373594 | Test Loss=0.002733912 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [666/1000] | Train Loss=0.000407855 | Test Loss=0.002820531 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [667/1000] | Train Loss=0.000356483 | Test Loss=0.002851914 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [668/1000] | Train Loss=0.000341690 | Test Loss=0.002759058 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [669/1000] | Train Loss=0.000310257 | Test Loss=0.002747996 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [670/1000] | Train Loss=0.000273099 | Test Loss=0.002756146 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [671/1000] | Train Loss=0.000293916 | Test Loss=0.002765307 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [672/1000] | Train Loss=0.000364575 | Test Loss=0.002793410 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [673/1000] | Train Loss=0.000277833 | Test Loss=0.002730803 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [674/1000] | Train Loss=0.000273970 | Test Loss=0.002711601 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [675/1000] | Train Loss=0.000291972 | Test Loss=0.002685932 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [676/1000] | Train Loss=0.000386284 | Test Loss=0.002697317 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [677/1000] | Train Loss=0.000282580 | Test Loss=0.002716940 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [678/1000] | Train Loss=0.000369579 | Test Loss=0.002659520 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [679/1000] | Train Loss=0.000366068 | Test Loss=0.002710631 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [680/1000] | Train Loss=0.000395171 | Test Loss=0.002662943 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [681/1000] | Train Loss=0.000375844 | Test Loss=0.002844682 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [682/1000] | Train Loss=0.000395992 | Test Loss=0.002703823 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [683/1000] | Train Loss=0.000318179 | Test Loss=0.002695409 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [684/1000] | Train Loss=0.000299294 | Test Loss=0.002712341 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [685/1000] | Train Loss=0.000396333 | Test Loss=0.002698366 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [686/1000] | Train Loss=0.000285713 | Test Loss=0.002703906 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [687/1000] | Train Loss=0.000270488 | Test Loss=0.002709378 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [688/1000] | Train Loss=0.000279825 | Test Loss=0.002748446 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [689/1000] | Train Loss=0.000349612 | Test Loss=0.002617528 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [690/1000] | Train Loss=0.000424491 | Test Loss=0.002726588 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [691/1000] | Train Loss=0.000295362 | Test Loss=0.002690802 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [692/1000] | Train Loss=0.000350803 | Test Loss=0.002745046 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [693/1000] | Train Loss=0.000345168 | Test Loss=0.002666069 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [694/1000] | Train Loss=0.000364024 | Test Loss=0.002660875 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [695/1000] | Train Loss=0.000347541 | Test Loss=0.002706892 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [696/1000] | Train Loss=0.000303604 | Test Loss=0.002757179 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [697/1000] | Train Loss=0.000370458 | Test Loss=0.002812298 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [698/1000] | Train Loss=0.000376427 | Test Loss=0.002776525 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [699/1000] | Train Loss=0.000285518 | Test Loss=0.002689688 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [700/1000] | Train Loss=0.000344922 | Test Loss=0.002825113 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [701/1000] | Train Loss=0.000369466 | Test Loss=0.002696602 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [702/1000] | Train Loss=0.000376219 | Test Loss=0.002622614 | Time=1.69s | LR=3.13e-05\n",
      "Epoch [703/1000] | Train Loss=0.000375203 | Test Loss=0.002609823 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [704/1000] | Train Loss=0.000270324 | Test Loss=0.002635345 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [705/1000] | Train Loss=0.000252202 | Test Loss=0.002659509 | Time=1.70s | LR=1.56e-05\n",
      "Epoch [706/1000] | Train Loss=0.000242632 | Test Loss=0.002639650 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [707/1000] | Train Loss=0.000243582 | Test Loss=0.002641526 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [708/1000] | Train Loss=0.000243214 | Test Loss=0.002661161 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [709/1000] | Train Loss=0.000237939 | Test Loss=0.002670958 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [710/1000] | Train Loss=0.000245199 | Test Loss=0.002641961 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [711/1000] | Train Loss=0.000257632 | Test Loss=0.002638423 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [712/1000] | Train Loss=0.000244131 | Test Loss=0.002659312 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [713/1000] | Train Loss=0.000252159 | Test Loss=0.002641692 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [714/1000] | Train Loss=0.000263047 | Test Loss=0.002665570 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [715/1000] | Train Loss=0.000238502 | Test Loss=0.002666028 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [716/1000] | Train Loss=0.000284628 | Test Loss=0.002638903 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [717/1000] | Train Loss=0.000270817 | Test Loss=0.002641532 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [718/1000] | Train Loss=0.000265490 | Test Loss=0.002609845 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [719/1000] | Train Loss=0.000277534 | Test Loss=0.002633225 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [720/1000] | Train Loss=0.000260073 | Test Loss=0.002680415 | Time=1.70s | LR=1.56e-05\n",
      "Epoch [721/1000] | Train Loss=0.000250186 | Test Loss=0.002652777 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [722/1000] | Train Loss=0.000246481 | Test Loss=0.002630243 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [723/1000] | Train Loss=0.000248304 | Test Loss=0.002604543 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [724/1000] | Train Loss=0.000251449 | Test Loss=0.002608118 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [725/1000] | Train Loss=0.000247650 | Test Loss=0.002602186 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [726/1000] | Train Loss=0.000266103 | Test Loss=0.002663729 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [727/1000] | Train Loss=0.000255664 | Test Loss=0.002589511 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [728/1000] | Train Loss=0.000241552 | Test Loss=0.002607982 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [729/1000] | Train Loss=0.000254013 | Test Loss=0.002590569 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [730/1000] | Train Loss=0.000250674 | Test Loss=0.002601899 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [731/1000] | Train Loss=0.000262780 | Test Loss=0.002601472 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [732/1000] | Train Loss=0.000293423 | Test Loss=0.002605780 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [733/1000] | Train Loss=0.000240465 | Test Loss=0.002593925 | Time=1.71s | LR=1.56e-05\n",
      "Epoch [734/1000] | Train Loss=0.000261582 | Test Loss=0.002601453 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [735/1000] | Train Loss=0.000272319 | Test Loss=0.002571469 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [736/1000] | Train Loss=0.000252560 | Test Loss=0.002622405 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [737/1000] | Train Loss=0.000260244 | Test Loss=0.002604323 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [738/1000] | Train Loss=0.000272164 | Test Loss=0.002576269 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [739/1000] | Train Loss=0.000285006 | Test Loss=0.002585658 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [740/1000] | Train Loss=0.000236563 | Test Loss=0.002609416 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [741/1000] | Train Loss=0.000255003 | Test Loss=0.002579865 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [742/1000] | Train Loss=0.000253317 | Test Loss=0.002577109 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [743/1000] | Train Loss=0.000270942 | Test Loss=0.002586473 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [744/1000] | Train Loss=0.000239211 | Test Loss=0.002568997 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [745/1000] | Train Loss=0.000259290 | Test Loss=0.002577145 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [746/1000] | Train Loss=0.000247126 | Test Loss=0.002583073 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [747/1000] | Train Loss=0.000267653 | Test Loss=0.002566928 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [748/1000] | Train Loss=0.000247139 | Test Loss=0.002588705 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [749/1000] | Train Loss=0.000238979 | Test Loss=0.002582213 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [750/1000] | Train Loss=0.000240897 | Test Loss=0.002577061 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [751/1000] | Train Loss=0.000261547 | Test Loss=0.002601411 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [752/1000] | Train Loss=0.000246468 | Test Loss=0.002605399 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [753/1000] | Train Loss=0.000261601 | Test Loss=0.002547415 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [754/1000] | Train Loss=0.000263458 | Test Loss=0.002585553 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [755/1000] | Train Loss=0.000267274 | Test Loss=0.002646404 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [756/1000] | Train Loss=0.000270175 | Test Loss=0.002547437 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [757/1000] | Train Loss=0.000260210 | Test Loss=0.002599083 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [758/1000] | Train Loss=0.000257423 | Test Loss=0.002577224 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [759/1000] | Train Loss=0.000276222 | Test Loss=0.002578351 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [760/1000] | Train Loss=0.000261588 | Test Loss=0.002552929 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [761/1000] | Train Loss=0.000243596 | Test Loss=0.002598180 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [762/1000] | Train Loss=0.000267683 | Test Loss=0.002621567 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [763/1000] | Train Loss=0.000241191 | Test Loss=0.002589279 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [764/1000] | Train Loss=0.000247602 | Test Loss=0.002598362 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [765/1000] | Train Loss=0.000246882 | Test Loss=0.002573635 | Time=1.71s | LR=1.56e-05\n",
      "Epoch [766/1000] | Train Loss=0.000276487 | Test Loss=0.002617226 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [767/1000] | Train Loss=0.000256247 | Test Loss=0.002545720 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [768/1000] | Train Loss=0.000253805 | Test Loss=0.002575997 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [769/1000] | Train Loss=0.000275783 | Test Loss=0.002555346 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [770/1000] | Train Loss=0.000252269 | Test Loss=0.002566074 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [771/1000] | Train Loss=0.000259554 | Test Loss=0.002562213 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [772/1000] | Train Loss=0.000247702 | Test Loss=0.002562931 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [773/1000] | Train Loss=0.000276091 | Test Loss=0.002616460 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [774/1000] | Train Loss=0.000276033 | Test Loss=0.002541030 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [775/1000] | Train Loss=0.000250146 | Test Loss=0.002557320 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [776/1000] | Train Loss=0.000236655 | Test Loss=0.002535966 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [777/1000] | Train Loss=0.000261642 | Test Loss=0.002569523 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [778/1000] | Train Loss=0.000242813 | Test Loss=0.002516888 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [779/1000] | Train Loss=0.000264703 | Test Loss=0.002510308 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [780/1000] | Train Loss=0.000254057 | Test Loss=0.002546897 | Time=1.69s | LR=1.56e-05\n",
      "Epoch [781/1000] | Train Loss=0.000264191 | Test Loss=0.002531708 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [782/1000] | Train Loss=0.000230427 | Test Loss=0.002532481 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [783/1000] | Train Loss=0.000229771 | Test Loss=0.002540083 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [784/1000] | Train Loss=0.000229419 | Test Loss=0.002523639 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [785/1000] | Train Loss=0.000229351 | Test Loss=0.002534277 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [786/1000] | Train Loss=0.000226923 | Test Loss=0.002545280 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [787/1000] | Train Loss=0.000228789 | Test Loss=0.002540288 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [788/1000] | Train Loss=0.000226590 | Test Loss=0.002552768 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [789/1000] | Train Loss=0.000223165 | Test Loss=0.002538548 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [790/1000] | Train Loss=0.000225835 | Test Loss=0.002534494 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [791/1000] | Train Loss=0.000222014 | Test Loss=0.002544462 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [792/1000] | Train Loss=0.000227522 | Test Loss=0.002544017 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [793/1000] | Train Loss=0.000231756 | Test Loss=0.002534756 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [794/1000] | Train Loss=0.000228844 | Test Loss=0.002536144 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [795/1000] | Train Loss=0.000230084 | Test Loss=0.002560637 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [796/1000] | Train Loss=0.000231844 | Test Loss=0.002516800 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [797/1000] | Train Loss=0.000229511 | Test Loss=0.002522280 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [798/1000] | Train Loss=0.000233500 | Test Loss=0.002532053 | Time=1.70s | LR=7.81e-06\n",
      "Epoch [799/1000] | Train Loss=0.000228075 | Test Loss=0.002518777 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [800/1000] | Train Loss=0.000231439 | Test Loss=0.002542245 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [801/1000] | Train Loss=0.000229483 | Test Loss=0.002511480 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [802/1000] | Train Loss=0.000230424 | Test Loss=0.002504774 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [803/1000] | Train Loss=0.000227764 | Test Loss=0.002531399 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [804/1000] | Train Loss=0.000229493 | Test Loss=0.002522576 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [805/1000] | Train Loss=0.000234048 | Test Loss=0.002527400 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [806/1000] | Train Loss=0.000227939 | Test Loss=0.002518707 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [807/1000] | Train Loss=0.000231153 | Test Loss=0.002513791 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [808/1000] | Train Loss=0.000236210 | Test Loss=0.002529979 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [809/1000] | Train Loss=0.000224973 | Test Loss=0.002540292 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [810/1000] | Train Loss=0.000226302 | Test Loss=0.002509783 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [811/1000] | Train Loss=0.000230312 | Test Loss=0.002508275 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [812/1000] | Train Loss=0.000226897 | Test Loss=0.002505191 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [813/1000] | Train Loss=0.000225363 | Test Loss=0.002537327 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [814/1000] | Train Loss=0.000230660 | Test Loss=0.002521303 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [815/1000] | Train Loss=0.000225862 | Test Loss=0.002504324 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [816/1000] | Train Loss=0.000239845 | Test Loss=0.002499562 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [817/1000] | Train Loss=0.000224297 | Test Loss=0.002514469 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [818/1000] | Train Loss=0.000233404 | Test Loss=0.002493626 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [819/1000] | Train Loss=0.000233223 | Test Loss=0.002513143 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [820/1000] | Train Loss=0.000228582 | Test Loss=0.002492675 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [821/1000] | Train Loss=0.000222868 | Test Loss=0.002499268 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [822/1000] | Train Loss=0.000224226 | Test Loss=0.002514852 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [823/1000] | Train Loss=0.000225435 | Test Loss=0.002498404 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [824/1000] | Train Loss=0.000240133 | Test Loss=0.002515586 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [825/1000] | Train Loss=0.000223738 | Test Loss=0.002488918 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [826/1000] | Train Loss=0.000226036 | Test Loss=0.002517862 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [827/1000] | Train Loss=0.000226387 | Test Loss=0.002513466 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [828/1000] | Train Loss=0.000229372 | Test Loss=0.002500223 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [829/1000] | Train Loss=0.000231452 | Test Loss=0.002497300 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [830/1000] | Train Loss=0.000231351 | Test Loss=0.002511843 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [831/1000] | Train Loss=0.000230412 | Test Loss=0.002504860 | Time=1.69s | LR=7.81e-06\n",
      "Epoch [832/1000] | Train Loss=0.000227916 | Test Loss=0.002477862 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [833/1000] | Train Loss=0.000221430 | Test Loss=0.002488644 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [834/1000] | Train Loss=0.000219587 | Test Loss=0.002500498 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [835/1000] | Train Loss=0.000219814 | Test Loss=0.002496601 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [836/1000] | Train Loss=0.000221485 | Test Loss=0.002485790 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [837/1000] | Train Loss=0.000220795 | Test Loss=0.002502456 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [838/1000] | Train Loss=0.000217773 | Test Loss=0.002488734 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [839/1000] | Train Loss=0.000214215 | Test Loss=0.002495076 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [840/1000] | Train Loss=0.000222891 | Test Loss=0.002492628 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [841/1000] | Train Loss=0.000219401 | Test Loss=0.002492772 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [842/1000] | Train Loss=0.000221570 | Test Loss=0.002496642 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [843/1000] | Train Loss=0.000220685 | Test Loss=0.002491421 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [844/1000] | Train Loss=0.000217477 | Test Loss=0.002487952 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [845/1000] | Train Loss=0.000218562 | Test Loss=0.002488119 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [846/1000] | Train Loss=0.000217314 | Test Loss=0.002493854 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [847/1000] | Train Loss=0.000221990 | Test Loss=0.002481931 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [848/1000] | Train Loss=0.000220646 | Test Loss=0.002480303 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [849/1000] | Train Loss=0.000219191 | Test Loss=0.002482438 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [850/1000] | Train Loss=0.000222915 | Test Loss=0.002485249 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [851/1000] | Train Loss=0.000221557 | Test Loss=0.002483369 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [852/1000] | Train Loss=0.000217777 | Test Loss=0.002478377 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [853/1000] | Train Loss=0.000217944 | Test Loss=0.002483856 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [854/1000] | Train Loss=0.000217528 | Test Loss=0.002500510 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [855/1000] | Train Loss=0.000218543 | Test Loss=0.002471417 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [856/1000] | Train Loss=0.000220561 | Test Loss=0.002483649 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [857/1000] | Train Loss=0.000217573 | Test Loss=0.002476769 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [858/1000] | Train Loss=0.000218350 | Test Loss=0.002487287 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [859/1000] | Train Loss=0.000217319 | Test Loss=0.002473653 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [860/1000] | Train Loss=0.000217683 | Test Loss=0.002474442 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [861/1000] | Train Loss=0.000214904 | Test Loss=0.002470841 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [862/1000] | Train Loss=0.000221347 | Test Loss=0.002477555 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [863/1000] | Train Loss=0.000225093 | Test Loss=0.002473736 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [864/1000] | Train Loss=0.000221117 | Test Loss=0.002484123 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [865/1000] | Train Loss=0.000224705 | Test Loss=0.002470934 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [866/1000] | Train Loss=0.000219645 | Test Loss=0.002472607 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [867/1000] | Train Loss=0.000221980 | Test Loss=0.002468722 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [868/1000] | Train Loss=0.000218748 | Test Loss=0.002484569 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [869/1000] | Train Loss=0.000220968 | Test Loss=0.002489280 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [870/1000] | Train Loss=0.000215874 | Test Loss=0.002482401 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [871/1000] | Train Loss=0.000222368 | Test Loss=0.002477089 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [872/1000] | Train Loss=0.000216084 | Test Loss=0.002472067 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [873/1000] | Train Loss=0.000218717 | Test Loss=0.002466970 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [874/1000] | Train Loss=0.000219054 | Test Loss=0.002464679 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [875/1000] | Train Loss=0.000218407 | Test Loss=0.002466692 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [876/1000] | Train Loss=0.000222397 | Test Loss=0.002467886 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [877/1000] | Train Loss=0.000215318 | Test Loss=0.002477108 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [878/1000] | Train Loss=0.000217076 | Test Loss=0.002476318 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [879/1000] | Train Loss=0.000219417 | Test Loss=0.002462346 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [880/1000] | Train Loss=0.000221236 | Test Loss=0.002458753 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [881/1000] | Train Loss=0.000211334 | Test Loss=0.002462691 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [882/1000] | Train Loss=0.000213402 | Test Loss=0.002472294 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [883/1000] | Train Loss=0.000214943 | Test Loss=0.002463273 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [884/1000] | Train Loss=0.000214542 | Test Loss=0.002455603 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [885/1000] | Train Loss=0.000213701 | Test Loss=0.002462807 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [886/1000] | Train Loss=0.000215469 | Test Loss=0.002464865 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [887/1000] | Train Loss=0.000211009 | Test Loss=0.002461654 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [888/1000] | Train Loss=0.000217354 | Test Loss=0.002459433 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [889/1000] | Train Loss=0.000212832 | Test Loss=0.002463664 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [890/1000] | Train Loss=0.000214075 | Test Loss=0.002457005 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [891/1000] | Train Loss=0.000214094 | Test Loss=0.002453300 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [892/1000] | Train Loss=0.000213774 | Test Loss=0.002463307 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [893/1000] | Train Loss=0.000212602 | Test Loss=0.002456162 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [894/1000] | Train Loss=0.000213590 | Test Loss=0.002460151 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [895/1000] | Train Loss=0.000216866 | Test Loss=0.002455655 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [896/1000] | Train Loss=0.000213291 | Test Loss=0.002461961 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [897/1000] | Train Loss=0.000216014 | Test Loss=0.002462872 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [898/1000] | Train Loss=0.000219202 | Test Loss=0.002456742 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [899/1000] | Train Loss=0.000212732 | Test Loss=0.002465271 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [900/1000] | Train Loss=0.000213961 | Test Loss=0.002458376 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [901/1000] | Train Loss=0.000212808 | Test Loss=0.002455117 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [902/1000] | Train Loss=0.000215389 | Test Loss=0.002461591 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [903/1000] | Train Loss=0.000214851 | Test Loss=0.002458483 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [904/1000] | Train Loss=0.000211711 | Test Loss=0.002448534 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [905/1000] | Train Loss=0.000214251 | Test Loss=0.002456355 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [906/1000] | Train Loss=0.000214759 | Test Loss=0.002449665 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [907/1000] | Train Loss=0.000215670 | Test Loss=0.002459429 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [908/1000] | Train Loss=0.000215830 | Test Loss=0.002454417 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [909/1000] | Train Loss=0.000215280 | Test Loss=0.002464786 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [910/1000] | Train Loss=0.000214601 | Test Loss=0.002456368 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [911/1000] | Train Loss=0.000215610 | Test Loss=0.002452338 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [912/1000] | Train Loss=0.000215281 | Test Loss=0.002454548 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [913/1000] | Train Loss=0.000216910 | Test Loss=0.002457147 | Time=1.70s | LR=1.95e-06\n",
      "Epoch [914/1000] | Train Loss=0.000213455 | Test Loss=0.002453128 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [915/1000] | Train Loss=0.000213245 | Test Loss=0.002457817 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [916/1000] | Train Loss=0.000211947 | Test Loss=0.002447503 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [917/1000] | Train Loss=0.000214475 | Test Loss=0.002454226 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [918/1000] | Train Loss=0.000212625 | Test Loss=0.002446644 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [919/1000] | Train Loss=0.000216011 | Test Loss=0.002454971 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [920/1000] | Train Loss=0.000215698 | Test Loss=0.002450379 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [921/1000] | Train Loss=0.000216845 | Test Loss=0.002451363 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [922/1000] | Train Loss=0.000215051 | Test Loss=0.002459378 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [923/1000] | Train Loss=0.000216834 | Test Loss=0.002452651 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [924/1000] | Train Loss=0.000214878 | Test Loss=0.002450531 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [925/1000] | Train Loss=0.000218050 | Test Loss=0.002452515 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [926/1000] | Train Loss=0.000213501 | Test Loss=0.002454620 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [927/1000] | Train Loss=0.000215914 | Test Loss=0.002445666 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [928/1000] | Train Loss=0.000215013 | Test Loss=0.002450525 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [929/1000] | Train Loss=0.000212098 | Test Loss=0.002449883 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [930/1000] | Train Loss=0.000213479 | Test Loss=0.002453185 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [931/1000] | Train Loss=0.000212006 | Test Loss=0.002455541 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [932/1000] | Train Loss=0.000212144 | Test Loss=0.002454785 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [933/1000] | Train Loss=0.000214176 | Test Loss=0.002458791 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [934/1000] | Train Loss=0.000213841 | Test Loss=0.002455824 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [935/1000] | Train Loss=0.000212555 | Test Loss=0.002458354 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [936/1000] | Train Loss=0.000216586 | Test Loss=0.002453557 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [937/1000] | Train Loss=0.000210723 | Test Loss=0.002449438 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [938/1000] | Train Loss=0.000210551 | Test Loss=0.002452652 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [939/1000] | Train Loss=0.000210153 | Test Loss=0.002454416 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [940/1000] | Train Loss=0.000212565 | Test Loss=0.002449457 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [941/1000] | Train Loss=0.000212133 | Test Loss=0.002454720 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [942/1000] | Train Loss=0.000212112 | Test Loss=0.002456693 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [943/1000] | Train Loss=0.000211050 | Test Loss=0.002452602 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [944/1000] | Train Loss=0.000211470 | Test Loss=0.002448453 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [945/1000] | Train Loss=0.000211659 | Test Loss=0.002451034 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [946/1000] | Train Loss=0.000213248 | Test Loss=0.002458894 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [947/1000] | Train Loss=0.000213605 | Test Loss=0.002451313 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [948/1000] | Train Loss=0.000211075 | Test Loss=0.002456360 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [949/1000] | Train Loss=0.000211132 | Test Loss=0.002448240 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [950/1000] | Train Loss=0.000211613 | Test Loss=0.002455722 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [951/1000] | Train Loss=0.000212233 | Test Loss=0.002445812 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [952/1000] | Train Loss=0.000212991 | Test Loss=0.002450045 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [953/1000] | Train Loss=0.000210914 | Test Loss=0.002447202 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [954/1000] | Train Loss=0.000212134 | Test Loss=0.002458519 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [955/1000] | Train Loss=0.000214968 | Test Loss=0.002451924 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [956/1000] | Train Loss=0.000211733 | Test Loss=0.002456261 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [957/1000] | Train Loss=0.000212456 | Test Loss=0.002454370 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [958/1000] | Train Loss=0.000212750 | Test Loss=0.002451783 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [959/1000] | Train Loss=0.000213146 | Test Loss=0.002457272 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [960/1000] | Train Loss=0.000212054 | Test Loss=0.002449115 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [961/1000] | Train Loss=0.000212092 | Test Loss=0.002451748 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [962/1000] | Train Loss=0.000210207 | Test Loss=0.002446970 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [963/1000] | Train Loss=0.000214016 | Test Loss=0.002453915 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [964/1000] | Train Loss=0.000212694 | Test Loss=0.002450564 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [965/1000] | Train Loss=0.000211277 | Test Loss=0.002455606 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [966/1000] | Train Loss=0.000211337 | Test Loss=0.002451804 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [967/1000] | Train Loss=0.000211965 | Test Loss=0.002445233 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [968/1000] | Train Loss=0.000212546 | Test Loss=0.002445071 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [969/1000] | Train Loss=0.000212781 | Test Loss=0.002447539 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [970/1000] | Train Loss=0.000216316 | Test Loss=0.002454708 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [971/1000] | Train Loss=0.000213355 | Test Loss=0.002452769 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [972/1000] | Train Loss=0.000209738 | Test Loss=0.002453359 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [973/1000] | Train Loss=0.000213876 | Test Loss=0.002445258 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [974/1000] | Train Loss=0.000211482 | Test Loss=0.002452524 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [975/1000] | Train Loss=0.000211999 | Test Loss=0.002456208 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [976/1000] | Train Loss=0.000210545 | Test Loss=0.002452953 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [977/1000] | Train Loss=0.000213824 | Test Loss=0.002443613 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [978/1000] | Train Loss=0.000214927 | Test Loss=0.002447359 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [979/1000] | Train Loss=0.000213897 | Test Loss=0.002455781 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [980/1000] | Train Loss=0.000212584 | Test Loss=0.002451438 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [981/1000] | Train Loss=0.000212444 | Test Loss=0.002449420 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [982/1000] | Train Loss=0.000213953 | Test Loss=0.002462604 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [983/1000] | Train Loss=0.000213706 | Test Loss=0.002451458 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [984/1000] | Train Loss=0.000212499 | Test Loss=0.002451927 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [985/1000] | Train Loss=0.000213433 | Test Loss=0.002448094 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [986/1000] | Train Loss=0.000211788 | Test Loss=0.002448906 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [987/1000] | Train Loss=0.000210693 | Test Loss=0.002447213 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [988/1000] | Train Loss=0.000214412 | Test Loss=0.002451447 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [989/1000] | Train Loss=0.000213481 | Test Loss=0.002449657 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [990/1000] | Train Loss=0.000216421 | Test Loss=0.002451214 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [991/1000] | Train Loss=0.000214437 | Test Loss=0.002451138 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [992/1000] | Train Loss=0.000211961 | Test Loss=0.002451163 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [993/1000] | Train Loss=0.000211628 | Test Loss=0.002453280 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [994/1000] | Train Loss=0.000211296 | Test Loss=0.002448538 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [995/1000] | Train Loss=0.000210046 | Test Loss=0.002444259 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [996/1000] | Train Loss=0.000212063 | Test Loss=0.002449793 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [997/1000] | Train Loss=0.000210445 | Test Loss=0.002446878 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [998/1000] | Train Loss=0.000210358 | Test Loss=0.002448142 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [999/1000] | Train Loss=0.000210037 | Test Loss=0.002441993 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [1000/1000] | Train Loss=0.000212141 | Test Loss=0.002451026 | Time=1.69s | LR=9.77e-07\n",
      "\n",
      "Total training time: 1707.91 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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zjvv4M477wxo20oYCIUIh8aIiMiTjRs34q677sLYsWMBSBmi48ePB/2+MTExmDZtGmbMmIGdO3eic+fOMJlMOH/+PPr16xe0+65duxbXXnstXnvtNb+XBPAWa4RChENjRETkSYsWLbB48WJkZmZi165duO222zxmdgLl//7v/3Do0CH8+OOPaNmyJSZMmIA777wTixcvxrFjx7BlyxbMmTMHv//+u0/tHjt2DJmZmdavPXv2oKioCGvWrME111yDhx9+GDfccAOys7ORnZ2Ny5cvB+k7lDAQChHLrDFmhIiIyJW3334biYmJ6N27N0aPHo3hw4ejS5cuFXLvWrVq4c4778SsWbNgNpsxf/583HnnnXjsscfQqlUrjBkzBlu3bnU7e03J9OnT0blzZ3Tu3Bldu3ZF//79sXPnTnz55ZcoLi7GnDlzUK9ePevXuHHjgvQdSgQx0MtGVjP5+fmIj49HXl4e4uLiAtZu39dW4/SVEnx/fw/0aBqYxbDImcFgwNKlSzFq1CinMXMKLD7risHnLNHpdDh27BiaNGmCiIiIgLdvNpuRn5+PuLi4Cq0Rqmn8fc7u/hx4+/Obv7shorKOjYW0G0RERDUaA6EQsawszaExIiKi0GEgFCICV5YmIiIKOQZCIWLdYoOREBERUcgwEHIhIyMD6enp6N69e5DuwKExIiKiUGMg5MKUKVOQlZWFrVu3BqV9rixNREQUegyEQoRDY0RERKHHQChEOGuMiIgo9BgIhQhnjRERUVV01113YcyYMaHuRsAwEAoRy6arTAgREdUMgiC4/Zo1a5ZfbS9ZssSnPsTFxaF79+74+eefy31fJWvXroUgCMjNzVU8P2/ePPTr1w+JiYmoXbs2xowZgy1btgS0D75gIBQitk1XGQkREdUE586ds37NnTsXcXFxdsdmzJhRIf2YP38+zp07h23btqFPnz4YP3489uzZUyH3BqRA6dZbb8WaNWuwceNG1K9fHyNGjMCZM2cqrA9yDIRChENjREQ1S0pKivUrPj4egiDYHVu4cCHatGmDiIgItG7dGh9++KH1s6WlpZg6dSrq1auHiIgINGrUCHPmzAEANG7cGAAwduxYCIJgfe9KQkICUlJS0LJlS7z88sswGo1Ys2aN9fypU6dw0003ISEhAbVq1cL111+P48ePB+w5LFiwAA8++CA6deqE1q1b47333oPZbMaqVasCdg9faEJyV4JKYLE0EVHAiCJgKA5ce2az1F6pGvC0Gag2yu81URYsWIDnn38eH3zwATp37oydO3fivvvuQ3R0NCZOnIj33nsPv/zyC77//ns0bNgQp06dwqlTpwAAW7duRVJSEubPn48RI0ZArVZ7dU+j0YjPPvsMABAWFgZA2tR3+PDh6NWrF9avXw+NRoP//Oc/GDFiBHbv3m29LpCKi4thMBhQq1atgLftDQZCISJw+jwRUeAYioFXUgPWnApAgrcXP30WCIv2634vvPAC3nrrLYwbNw4A0KRJE2RlZeGTTz7BxIkTcfLkSbRo0QJ9+/aFIAho1KiR9bN169YFYMv0eHLrrbdCrVajpKQEZrMZjRs3xk033QQA+O6772A2m/Hpp59aa1nnz5+PhIQErF27FsOGDfPr+1Qya9YspKamYsiQIQFv2xsMhEKEQ2NERAQARUVFOHLkCO655x7cd9991uNGoxHx8fEApJlaQ4cORatWrTBixAhce+215Q5K3nnnHQwZMgRHjx7Fo48+ivfee8+ajdm1axcOHz6M2NhYu8/odDocOXKknN+ha6+99hoWL16MNWvWICIiIuDte4OBUIhY1hESzQyFiIj8po2SMjMBYjabkV9QgLjYWKi8GRrzQ2FhIQBpNlXPnj3tzlmGubp06YJjx45h2bJlWLlyJW666SYMGTIEP/zwg8/3S0lJQfPmzdG8eXPMnz8fo0aNQlZWFpKSklBYWIiuXbtiwYIFTp+zZJ4C5c0338Rrr72Gn376CR06dAho275gIBQizAgREQWQIPg9PGXHbAa0JqlNT4GQn5KTk5GamoqjR49iwoQJLq+Li4vDzTffjJtvvhnjx4/HiBEjcPnyZdSqVQtarRYmk8nne/fo0QNdu3bF7Nmz8e6776JLly747rvvkJSUhLi4OH++Lbdef/11zJ49G8uWLUN6enrQ7uMNBkIhouI6QkREVObFF1/Eww8/jPj4eIwYMQJ6vR7btm3DlStXMH36dLz99tuoV68eOnfuDJVKhUWLFiElJQUJCQkApJljq1atQp8+fRAeHo7ExESv7/3II49g7NixeOKJJzBhwgS88cYbuP766/HSSy+hQYMGOHHiBBYvXownnngCDRo08LrdPXv22A2xCYKAjh074rXXXsPzzz+Pb775Bo0bN0ZOTg6K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",
      "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_G1.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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.002324824 | Test Loss=0.002549602 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [2/1000] | Train Loss=0.000882261 | Test Loss=0.002668301 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [3/1000] | Train Loss=0.000844815 | Test Loss=0.002491185 | Time=1.70s | LR=1.00e-04\n",
      "Epoch [4/1000] | Train Loss=0.000861996 | Test Loss=0.002753285 | Time=1.70s | LR=1.00e-04\n",
      "Epoch [5/1000] | Train Loss=0.000915377 | Test Loss=0.002589551 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [6/1000] | Train Loss=0.000835128 | Test Loss=0.002499687 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [7/1000] | Train Loss=0.001623218 | Test Loss=0.002882803 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [8/1000] | Train Loss=0.001617549 | Test Loss=0.003324619 | Time=1.70s | LR=1.00e-04\n",
      "Epoch [9/1000] | Train Loss=0.001464495 | Test Loss=0.002572210 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [10/1000] | Train Loss=0.000771280 | Test Loss=0.002539402 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [11/1000] | Train Loss=0.000799110 | Test Loss=0.002625337 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [12/1000] | Train Loss=0.000865684 | Test Loss=0.003054371 | Time=1.73s | LR=1.00e-04\n",
      "Epoch [13/1000] | Train Loss=0.000915794 | Test Loss=0.002603168 | Time=0.97s | LR=1.00e-04\n",
      "Epoch [14/1000] | Train Loss=0.000955114 | Test Loss=0.002647630 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [15/1000] | Train Loss=0.001120465 | Test Loss=0.003746760 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [16/1000] | Train Loss=0.001726855 | Test Loss=0.003120934 | Time=1.61s | LR=1.00e-04\n",
      "Epoch [17/1000] | Train Loss=0.001686545 | Test Loss=0.002926648 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [18/1000] | Train Loss=0.000940158 | Test Loss=0.002783280 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [19/1000] | Train Loss=0.000928029 | Test Loss=0.002712798 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [20/1000] | Train Loss=0.000824262 | Test Loss=0.002812556 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [21/1000] | Train Loss=0.001697170 | Test Loss=0.003836309 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [22/1000] | Train Loss=0.001686171 | Test Loss=0.003202784 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [23/1000] | Train Loss=0.001657240 | Test Loss=0.002634076 | Time=0.98s | LR=1.00e-04\n",
      "Epoch [24/1000] | Train Loss=0.001002657 | Test Loss=0.002678422 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [25/1000] | Train Loss=0.000931448 | Test Loss=0.003201825 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [26/1000] | Train Loss=0.000898954 | Test Loss=0.002603110 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [27/1000] | Train Loss=0.000918804 | Test Loss=0.002721502 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [28/1000] | Train Loss=0.000923422 | Test Loss=0.002642803 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [29/1000] | Train Loss=0.001237966 | Test Loss=0.002866875 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [30/1000] | Train Loss=0.001676155 | Test Loss=0.002746585 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [31/1000] | Train Loss=0.001489587 | Test Loss=0.002544526 | Time=0.97s | LR=1.00e-04\n",
      "Epoch [32/1000] | Train Loss=0.000820745 | Test Loss=0.002706125 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [33/1000] | Train Loss=0.000680594 | Test Loss=0.002891349 | Time=0.96s | LR=1.00e-04\n",
      "Epoch [34/1000] | Train Loss=0.000744598 | Test Loss=0.002638336 | Time=1.40s | LR=1.00e-04\n",
      "Epoch [35/1000] | Train Loss=0.000887140 | Test Loss=0.002627982 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [36/1000] | Train Loss=0.001631380 | Test Loss=0.002854653 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [37/1000] | Train Loss=0.001346776 | Test Loss=0.002626005 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [38/1000] | Train Loss=0.000736844 | Test Loss=0.002767912 | Time=1.30s | LR=1.00e-04\n",
      "Epoch [39/1000] | Train Loss=0.000903778 | Test Loss=0.002594465 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [40/1000] | Train Loss=0.000939905 | Test Loss=0.002656558 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [41/1000] | Train Loss=0.000834116 | Test Loss=0.002601539 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [42/1000] | Train Loss=0.000917837 | Test Loss=0.002683290 | Time=1.76s | LR=1.00e-04\n",
      "Epoch [43/1000] | Train Loss=0.000923573 | Test Loss=0.002875669 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [44/1000] | Train Loss=0.000907155 | Test Loss=0.002637813 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [45/1000] | Train Loss=0.000763304 | Test Loss=0.002737026 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [46/1000] | Train Loss=0.000863055 | Test Loss=0.002753231 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [47/1000] | Train Loss=0.001736082 | Test Loss=0.002981662 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [48/1000] | Train Loss=0.001669361 | Test Loss=0.002849198 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [49/1000] | Train Loss=0.001681538 | Test Loss=0.004007238 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [50/1000] | Train Loss=0.001664965 | Test Loss=0.003449840 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [51/1000] | Train Loss=0.001630876 | Test Loss=0.002548700 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [52/1000] | Train Loss=0.001666560 | Test Loss=0.003216893 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [53/1000] | Train Loss=0.000639945 | Test Loss=0.002927232 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [54/1000] | Train Loss=0.000913433 | Test Loss=0.002817459 | Time=1.73s | LR=1.00e-04\n",
      "Epoch [55/1000] | Train Loss=0.000823325 | Test Loss=0.002848299 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [56/1000] | Train Loss=0.000844880 | Test Loss=0.002843751 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [57/1000] | Train Loss=0.000851469 | Test Loss=0.002782536 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [58/1000] | Train Loss=0.000842580 | Test Loss=0.002793336 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [59/1000] | Train Loss=0.001051760 | Test Loss=0.003290737 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [60/1000] | Train Loss=0.001513132 | Test Loss=0.002731185 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [61/1000] | Train Loss=0.000867833 | Test Loss=0.002688659 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [62/1000] | Train Loss=0.000903669 | Test Loss=0.002970576 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [63/1000] | Train Loss=0.000843753 | Test Loss=0.002602240 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [64/1000] | Train Loss=0.001053975 | Test Loss=0.002675050 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [65/1000] | Train Loss=0.000923122 | Test Loss=0.002817705 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [66/1000] | Train Loss=0.000753951 | Test Loss=0.002638149 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [67/1000] | Train Loss=0.000937655 | Test Loss=0.002608321 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [68/1000] | Train Loss=0.000805733 | Test Loss=0.002761820 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [69/1000] | Train Loss=0.000779010 | Test Loss=0.002620304 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [70/1000] | Train Loss=0.000942424 | Test Loss=0.002649384 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [71/1000] | Train Loss=0.000883063 | Test Loss=0.002720819 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [72/1000] | Train Loss=0.001096929 | Test Loss=0.003121502 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [73/1000] | Train Loss=0.001682562 | Test Loss=0.002942869 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [74/1000] | Train Loss=0.000988533 | Test Loss=0.002782893 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [75/1000] | Train Loss=0.000923097 | Test Loss=0.002721622 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [76/1000] | Train Loss=0.000893189 | Test Loss=0.002802197 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [77/1000] | Train Loss=0.000907918 | Test Loss=0.002706112 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [78/1000] | Train Loss=0.000916288 | Test Loss=0.002727490 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [79/1000] | Train Loss=0.000815666 | Test Loss=0.002733202 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [80/1000] | Train Loss=0.000931081 | Test Loss=0.002680273 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [81/1000] | Train Loss=0.000896645 | Test Loss=0.002591332 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [82/1000] | Train Loss=0.000884347 | Test Loss=0.002769559 | Time=1.74s | LR=1.00e-04\n",
      "Epoch [83/1000] | Train Loss=0.000905160 | Test Loss=0.002664089 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [84/1000] | Train Loss=0.000849202 | Test Loss=0.002719775 | Time=1.75s | LR=1.00e-04\n",
      "Epoch [85/1000] | Train Loss=0.000914092 | Test Loss=0.002911242 | Time=1.35s | LR=1.00e-04\n",
      "Epoch [86/1000] | Train Loss=0.000890751 | Test Loss=0.002820994 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [87/1000] | Train Loss=0.000735875 | Test Loss=0.002681800 | Time=1.77s | LR=1.00e-04\n",
      "Epoch [88/1000] | Train Loss=0.000832914 | Test Loss=0.002624995 | Time=1.71s | LR=1.00e-04\n",
      "Epoch [89/1000] | Train Loss=0.000935566 | Test Loss=0.002699953 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [90/1000] | Train Loss=0.000856635 | Test Loss=0.002753733 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [91/1000] | Train Loss=0.000870032 | Test Loss=0.002687458 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [92/1000] | Train Loss=0.000874326 | Test Loss=0.002675200 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [93/1000] | Train Loss=0.000912141 | Test Loss=0.002925375 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [94/1000] | Train Loss=0.000963891 | Test Loss=0.002686914 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [95/1000] | Train Loss=0.000339324 | Test Loss=0.002597724 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [96/1000] | Train Loss=0.000416157 | Test Loss=0.002681586 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [97/1000] | Train Loss=0.000622510 | Test Loss=0.002656873 | Time=1.70s | LR=5.00e-05\n",
      "Epoch [98/1000] | Train Loss=0.000371083 | Test Loss=0.002574727 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [99/1000] | Train Loss=0.000398610 | Test Loss=0.002626057 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [100/1000] | Train Loss=0.000434423 | Test Loss=0.002599697 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [101/1000] | Train Loss=0.000476272 | Test Loss=0.002694514 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [102/1000] | Train Loss=0.000486842 | Test Loss=0.002691243 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [103/1000] | Train Loss=0.000384093 | Test Loss=0.002513606 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [104/1000] | Train Loss=0.000538552 | Test Loss=0.002546887 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [105/1000] | Train Loss=0.000380230 | Test Loss=0.002571132 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [106/1000] | Train Loss=0.000384509 | Test Loss=0.002554682 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [107/1000] | Train Loss=0.000469644 | Test Loss=0.002685485 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [108/1000] | Train Loss=0.000445877 | Test Loss=0.002497921 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [109/1000] | Train Loss=0.000462715 | Test Loss=0.002525278 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [110/1000] | Train Loss=0.000444192 | Test Loss=0.002528340 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [111/1000] | Train Loss=0.000487146 | Test Loss=0.002542129 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [112/1000] | Train Loss=0.000467096 | Test Loss=0.002547264 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [113/1000] | Train Loss=0.000401724 | Test Loss=0.002567071 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [114/1000] | Train Loss=0.000429021 | Test Loss=0.002589690 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [115/1000] | Train Loss=0.000487986 | Test Loss=0.002503097 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [116/1000] | Train Loss=0.000520564 | Test Loss=0.002581824 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [117/1000] | Train Loss=0.000499100 | Test Loss=0.002556963 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [118/1000] | Train Loss=0.000515883 | Test Loss=0.002507085 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [119/1000] | Train Loss=0.000466816 | Test Loss=0.002522972 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [120/1000] | Train Loss=0.000389721 | Test Loss=0.002692169 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [121/1000] | Train Loss=0.000432705 | Test Loss=0.002550060 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [122/1000] | Train Loss=0.000462703 | Test Loss=0.002481543 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [123/1000] | Train Loss=0.000596906 | Test Loss=0.002483185 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [124/1000] | Train Loss=0.000343770 | Test Loss=0.002518669 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [125/1000] | Train Loss=0.000325084 | Test Loss=0.002713526 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [126/1000] | Train Loss=0.000472142 | Test Loss=0.002506822 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [127/1000] | Train Loss=0.000391137 | Test Loss=0.002489135 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [128/1000] | Train Loss=0.000475426 | Test Loss=0.002518335 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [129/1000] | Train Loss=0.000444337 | Test Loss=0.002652517 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [130/1000] | Train Loss=0.000707349 | Test Loss=0.002645743 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [131/1000] | Train Loss=0.000488789 | Test Loss=0.002531163 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [132/1000] | Train Loss=0.000473254 | Test Loss=0.002443575 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [133/1000] | Train Loss=0.000462248 | Test Loss=0.002477939 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [134/1000] | Train Loss=0.000372481 | Test Loss=0.002462781 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [135/1000] | Train Loss=0.000421602 | Test Loss=0.002543405 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [136/1000] | Train Loss=0.000347172 | Test Loss=0.002722654 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [137/1000] | Train Loss=0.000510841 | Test Loss=0.002529483 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [138/1000] | Train Loss=0.000512392 | Test Loss=0.002564815 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [139/1000] | Train Loss=0.000485752 | Test Loss=0.002742719 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [140/1000] | Train Loss=0.000363071 | Test Loss=0.002454214 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [141/1000] | Train Loss=0.000507605 | Test Loss=0.002465686 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [142/1000] | Train Loss=0.000415331 | Test Loss=0.002460457 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [143/1000] | Train Loss=0.000404646 | Test Loss=0.002641315 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [144/1000] | Train Loss=0.000525993 | Test Loss=0.002444164 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [145/1000] | Train Loss=0.000398908 | Test Loss=0.002460709 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [146/1000] | Train Loss=0.000468986 | Test Loss=0.002488192 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [147/1000] | Train Loss=0.000477456 | Test Loss=0.002694038 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [148/1000] | Train Loss=0.000533169 | Test Loss=0.002425964 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [149/1000] | Train Loss=0.000471124 | Test Loss=0.002464447 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [150/1000] | Train Loss=0.000407134 | Test Loss=0.002620613 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [151/1000] | Train Loss=0.000515639 | Test Loss=0.002422968 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [152/1000] | Train Loss=0.000376283 | Test Loss=0.002492412 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [153/1000] | Train Loss=0.000396857 | Test Loss=0.002464094 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [154/1000] | Train Loss=0.000302810 | Test Loss=0.002468073 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [155/1000] | Train Loss=0.000472052 | Test Loss=0.002452000 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [156/1000] | Train Loss=0.000540662 | Test Loss=0.002429943 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [157/1000] | Train Loss=0.000542601 | Test Loss=0.002489062 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [158/1000] | Train Loss=0.000477314 | Test Loss=0.002508718 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [159/1000] | Train Loss=0.000308411 | Test Loss=0.002487060 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [160/1000] | Train Loss=0.000492959 | Test Loss=0.002516126 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [161/1000] | Train Loss=0.000498023 | Test Loss=0.002737559 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [162/1000] | Train Loss=0.000508735 | Test Loss=0.002574777 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [163/1000] | Train Loss=0.000329508 | Test Loss=0.002442134 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [164/1000] | Train Loss=0.000468558 | Test Loss=0.002640506 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [165/1000] | Train Loss=0.000475785 | Test Loss=0.002434136 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [166/1000] | Train Loss=0.000515360 | Test Loss=0.002503806 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [167/1000] | Train Loss=0.000847129 | Test Loss=0.002625231 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [168/1000] | Train Loss=0.000943083 | Test Loss=0.002863391 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [169/1000] | Train Loss=0.000615118 | Test Loss=0.002457228 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [170/1000] | Train Loss=0.000499681 | Test Loss=0.002453930 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [171/1000] | Train Loss=0.000472073 | Test Loss=0.002558522 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [172/1000] | Train Loss=0.000371320 | Test Loss=0.002413576 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [173/1000] | Train Loss=0.000406431 | Test Loss=0.002473261 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [174/1000] | Train Loss=0.000438525 | Test Loss=0.002518498 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [175/1000] | Train Loss=0.000313102 | Test Loss=0.002461061 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [176/1000] | Train Loss=0.000315317 | Test Loss=0.002500171 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [177/1000] | Train Loss=0.000624035 | Test Loss=0.003069106 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [178/1000] | Train Loss=0.000955033 | Test Loss=0.002528520 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [179/1000] | Train Loss=0.000398749 | Test Loss=0.002487524 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [180/1000] | Train Loss=0.000314698 | Test Loss=0.002469861 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [181/1000] | Train Loss=0.000365080 | Test Loss=0.002402993 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [182/1000] | Train Loss=0.000677263 | Test Loss=0.002457438 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [183/1000] | Train Loss=0.000476263 | Test Loss=0.002540816 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [184/1000] | Train Loss=0.000526301 | Test Loss=0.002436487 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [185/1000] | Train Loss=0.000443926 | Test Loss=0.002454811 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [186/1000] | Train Loss=0.000516968 | Test Loss=0.002439421 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [187/1000] | Train Loss=0.000454709 | Test Loss=0.002468508 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [188/1000] | Train Loss=0.000341489 | Test Loss=0.002412089 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [189/1000] | Train Loss=0.000516545 | Test Loss=0.002422121 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [190/1000] | Train Loss=0.000515357 | Test Loss=0.002545311 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [191/1000] | Train Loss=0.000433661 | Test Loss=0.002404730 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [192/1000] | Train Loss=0.000283632 | Test Loss=0.002464437 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [193/1000] | Train Loss=0.000418267 | Test Loss=0.002429199 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [194/1000] | Train Loss=0.000450704 | Test Loss=0.002385803 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [195/1000] | Train Loss=0.000479349 | Test Loss=0.002398567 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [196/1000] | Train Loss=0.000488799 | Test Loss=0.002414253 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [197/1000] | Train Loss=0.000331064 | Test Loss=0.002409288 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [198/1000] | Train Loss=0.000473670 | Test Loss=0.002491680 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [199/1000] | Train Loss=0.000480451 | Test Loss=0.002645967 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [200/1000] | Train Loss=0.000575324 | Test Loss=0.002446833 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [201/1000] | Train Loss=0.000536940 | Test Loss=0.002420238 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [202/1000] | Train Loss=0.000765960 | Test Loss=0.002505371 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [203/1000] | Train Loss=0.000481277 | Test Loss=0.002422255 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [204/1000] | Train Loss=0.000461651 | Test Loss=0.002476094 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [205/1000] | Train Loss=0.000498902 | Test Loss=0.002406335 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [206/1000] | Train Loss=0.000502209 | Test Loss=0.002493109 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [207/1000] | Train Loss=0.000466911 | Test Loss=0.002407051 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [208/1000] | Train Loss=0.000474980 | Test Loss=0.002435448 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [209/1000] | Train Loss=0.000480455 | Test Loss=0.002430167 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [210/1000] | Train Loss=0.000519416 | Test Loss=0.002390042 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [211/1000] | Train Loss=0.000290987 | Test Loss=0.002472037 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [212/1000] | Train Loss=0.000296747 | Test Loss=0.002377519 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [213/1000] | Train Loss=0.000482701 | Test Loss=0.002443709 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [214/1000] | Train Loss=0.000530381 | Test Loss=0.002421613 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [215/1000] | Train Loss=0.000516574 | Test Loss=0.002427214 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [216/1000] | Train Loss=0.000505179 | Test Loss=0.002397796 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [217/1000] | Train Loss=0.000448622 | Test Loss=0.002566501 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [218/1000] | Train Loss=0.000375833 | Test Loss=0.002375821 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [219/1000] | Train Loss=0.000472555 | Test Loss=0.002388189 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [220/1000] | Train Loss=0.000465593 | Test Loss=0.002580080 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [221/1000] | Train Loss=0.000507659 | Test Loss=0.002505543 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [222/1000] | Train Loss=0.000389104 | Test Loss=0.002412455 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [223/1000] | Train Loss=0.000365260 | Test Loss=0.002424672 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [224/1000] | Train Loss=0.000419730 | Test Loss=0.002434821 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [225/1000] | Train Loss=0.000606336 | Test Loss=0.002425686 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [226/1000] | Train Loss=0.000938795 | Test Loss=0.002419553 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [227/1000] | Train Loss=0.000433985 | Test Loss=0.002457266 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [228/1000] | Train Loss=0.000500218 | Test Loss=0.002402374 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [229/1000] | Train Loss=0.000446504 | Test Loss=0.002389972 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [230/1000] | Train Loss=0.000437153 | Test Loss=0.002432721 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [231/1000] | Train Loss=0.000471091 | Test Loss=0.002344421 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [232/1000] | Train Loss=0.000397012 | Test Loss=0.002448315 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [233/1000] | Train Loss=0.000360384 | Test Loss=0.002402571 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [234/1000] | Train Loss=0.000249938 | Test Loss=0.002367355 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [235/1000] | Train Loss=0.000247052 | Test Loss=0.002343321 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [236/1000] | Train Loss=0.000301494 | Test Loss=0.002397862 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [237/1000] | Train Loss=0.000236045 | Test Loss=0.002389661 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [238/1000] | Train Loss=0.000271836 | Test Loss=0.002381751 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [239/1000] | Train Loss=0.000253457 | Test Loss=0.002338941 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [240/1000] | Train Loss=0.000230442 | Test Loss=0.002359699 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [241/1000] | Train Loss=0.000274658 | Test Loss=0.002377011 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [242/1000] | Train Loss=0.000309288 | Test Loss=0.002353050 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [243/1000] | Train Loss=0.000273679 | Test Loss=0.002420642 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [244/1000] | Train Loss=0.000341226 | Test Loss=0.002349443 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [245/1000] | Train Loss=0.000287647 | Test Loss=0.002407214 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [246/1000] | Train Loss=0.000305097 | Test Loss=0.002356098 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [247/1000] | Train Loss=0.000287993 | Test Loss=0.002376280 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [248/1000] | Train Loss=0.000294713 | Test Loss=0.002349144 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [249/1000] | Train Loss=0.000310820 | Test Loss=0.002326258 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [250/1000] | Train Loss=0.000273823 | Test Loss=0.002389324 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [251/1000] | Train Loss=0.000325679 | Test Loss=0.002348678 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [252/1000] | Train Loss=0.000323688 | Test Loss=0.002367113 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [253/1000] | Train Loss=0.000259298 | Test Loss=0.002336072 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [254/1000] | Train Loss=0.000255678 | Test Loss=0.002409752 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [255/1000] | Train Loss=0.000283118 | Test Loss=0.002334524 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [256/1000] | Train Loss=0.000326473 | Test Loss=0.002349444 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [257/1000] | Train Loss=0.000308138 | Test Loss=0.002347033 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [258/1000] | Train Loss=0.000303433 | Test Loss=0.002299516 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [259/1000] | Train Loss=0.000276868 | Test Loss=0.002414300 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [260/1000] | Train Loss=0.000308314 | Test Loss=0.002329448 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [261/1000] | Train Loss=0.000257963 | Test Loss=0.002351849 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [262/1000] | Train Loss=0.000271392 | Test Loss=0.002373953 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [263/1000] | Train Loss=0.000232775 | Test Loss=0.002350008 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [264/1000] | Train Loss=0.000272853 | Test Loss=0.002334715 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [265/1000] | Train Loss=0.000304093 | Test Loss=0.002345142 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [266/1000] | Train Loss=0.000270146 | Test Loss=0.002353136 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [267/1000] | Train Loss=0.000335969 | Test Loss=0.002365103 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [268/1000] | Train Loss=0.000287348 | Test Loss=0.002341025 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [269/1000] | Train Loss=0.000231829 | Test Loss=0.002312476 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [270/1000] | Train Loss=0.000268865 | Test Loss=0.002327811 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [271/1000] | Train Loss=0.000298945 | Test Loss=0.002392725 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [272/1000] | Train Loss=0.000266564 | Test Loss=0.002343377 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [273/1000] | Train Loss=0.000301624 | Test Loss=0.002326068 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [274/1000] | Train Loss=0.000332840 | Test Loss=0.002311607 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [275/1000] | Train Loss=0.000304485 | Test Loss=0.002384230 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [276/1000] | Train Loss=0.000269340 | Test Loss=0.002326168 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [277/1000] | Train Loss=0.000332333 | Test Loss=0.002360005 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [278/1000] | Train Loss=0.000285271 | Test Loss=0.002321680 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [279/1000] | Train Loss=0.000269279 | Test Loss=0.002337148 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [280/1000] | Train Loss=0.000308176 | Test Loss=0.002304933 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [281/1000] | Train Loss=0.000284327 | Test Loss=0.002315567 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [282/1000] | Train Loss=0.000212322 | Test Loss=0.002306714 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [283/1000] | Train Loss=0.000208309 | Test Loss=0.002297643 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [284/1000] | Train Loss=0.000208125 | Test Loss=0.002322668 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [285/1000] | Train Loss=0.000211635 | Test Loss=0.002305649 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [286/1000] | Train Loss=0.000205969 | Test Loss=0.002318258 | Time=1.70s | LR=1.25e-05\n",
      "Epoch [287/1000] | Train Loss=0.000211015 | Test Loss=0.002311192 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [288/1000] | Train Loss=0.000218766 | Test Loss=0.002314096 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [289/1000] | Train Loss=0.000215457 | Test Loss=0.002306704 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [290/1000] | Train Loss=0.000214378 | Test Loss=0.002303755 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [291/1000] | Train Loss=0.000234631 | Test Loss=0.002301904 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [292/1000] | Train Loss=0.000241981 | Test Loss=0.002289302 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [293/1000] | Train Loss=0.000213264 | Test Loss=0.002307609 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [294/1000] | Train Loss=0.000219962 | Test Loss=0.002282603 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [295/1000] | Train Loss=0.000215032 | Test Loss=0.002292473 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [296/1000] | Train Loss=0.000227355 | Test Loss=0.002324577 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [297/1000] | Train Loss=0.000225420 | Test Loss=0.002275491 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [298/1000] | Train Loss=0.000226165 | Test Loss=0.002323315 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [299/1000] | Train Loss=0.000234854 | Test Loss=0.002321189 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [300/1000] | Train Loss=0.000226005 | Test Loss=0.002315922 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [301/1000] | Train Loss=0.000226612 | Test Loss=0.002308222 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [302/1000] | Train Loss=0.000219882 | Test Loss=0.002277536 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [303/1000] | Train Loss=0.000241353 | Test Loss=0.002302144 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [304/1000] | Train Loss=0.000220790 | Test Loss=0.002291419 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [305/1000] | Train Loss=0.000241485 | Test Loss=0.002306102 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [306/1000] | Train Loss=0.000229183 | Test Loss=0.002314995 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [307/1000] | Train Loss=0.000227779 | Test Loss=0.002314283 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [308/1000] | Train Loss=0.000233444 | Test Loss=0.002295883 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [309/1000] | Train Loss=0.000233367 | Test Loss=0.002306579 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [310/1000] | Train Loss=0.000258901 | Test Loss=0.002316886 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [311/1000] | Train Loss=0.000220172 | Test Loss=0.002266203 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [312/1000] | Train Loss=0.000220926 | Test Loss=0.002287600 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [313/1000] | Train Loss=0.000214205 | Test Loss=0.002279487 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [314/1000] | Train Loss=0.000217371 | Test Loss=0.002271655 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [315/1000] | Train Loss=0.000219278 | Test Loss=0.002317235 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [316/1000] | Train Loss=0.000220712 | Test Loss=0.002303174 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [317/1000] | Train Loss=0.000219470 | Test Loss=0.002272808 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [318/1000] | Train Loss=0.000213655 | Test Loss=0.002294432 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [319/1000] | Train Loss=0.000224215 | Test Loss=0.002300720 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [320/1000] | Train Loss=0.000223879 | Test Loss=0.002280160 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [321/1000] | Train Loss=0.000232665 | Test Loss=0.002289222 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [322/1000] | Train Loss=0.000222863 | Test Loss=0.002293857 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [323/1000] | Train Loss=0.000242531 | Test Loss=0.002290490 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [324/1000] | Train Loss=0.000218725 | Test Loss=0.002295489 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [325/1000] | Train Loss=0.000223092 | Test Loss=0.002291103 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [326/1000] | Train Loss=0.000219153 | Test Loss=0.002291533 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [327/1000] | Train Loss=0.000222574 | Test Loss=0.002268840 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [328/1000] | Train Loss=0.000200779 | Test Loss=0.002279324 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [329/1000] | Train Loss=0.000201771 | Test Loss=0.002267694 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [330/1000] | Train Loss=0.000205703 | Test Loss=0.002279457 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [331/1000] | Train Loss=0.000203325 | Test Loss=0.002273423 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [332/1000] | Train Loss=0.000206214 | Test Loss=0.002282646 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [333/1000] | Train Loss=0.000207298 | Test Loss=0.002286152 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [334/1000] | Train Loss=0.000203536 | Test Loss=0.002285081 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [335/1000] | Train Loss=0.000207708 | Test Loss=0.002276852 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [336/1000] | Train Loss=0.000203684 | Test Loss=0.002288631 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [337/1000] | Train Loss=0.000205338 | Test Loss=0.002276901 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [338/1000] | Train Loss=0.000203626 | Test Loss=0.002275054 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [339/1000] | Train Loss=0.000201259 | Test Loss=0.002278239 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [340/1000] | Train Loss=0.000199079 | Test Loss=0.002272064 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [341/1000] | Train Loss=0.000205997 | Test Loss=0.002278516 | Time=1.70s | LR=6.25e-06\n",
      "Epoch [342/1000] | Train Loss=0.000206126 | Test Loss=0.002265677 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [343/1000] | Train Loss=0.000206055 | Test Loss=0.002273179 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [344/1000] | Train Loss=0.000203862 | Test Loss=0.002266947 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [345/1000] | Train Loss=0.000200767 | Test Loss=0.002278948 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [346/1000] | Train Loss=0.000203353 | Test Loss=0.002271711 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [347/1000] | Train Loss=0.000203338 | Test Loss=0.002273687 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [348/1000] | Train Loss=0.000203960 | Test Loss=0.002264559 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [349/1000] | Train Loss=0.000206484 | Test Loss=0.002272481 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [350/1000] | Train Loss=0.000211387 | Test Loss=0.002269582 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [351/1000] | Train Loss=0.000205626 | Test Loss=0.002263516 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [352/1000] | Train Loss=0.000202292 | Test Loss=0.002267420 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [353/1000] | Train Loss=0.000206941 | Test Loss=0.002285738 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [354/1000] | Train Loss=0.000203267 | Test Loss=0.002284645 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [355/1000] | Train Loss=0.000207462 | Test Loss=0.002257537 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [356/1000] | Train Loss=0.000206813 | Test Loss=0.002267872 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [357/1000] | Train Loss=0.000212907 | Test Loss=0.002273832 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [358/1000] | Train Loss=0.000222293 | Test Loss=0.002266504 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [359/1000] | Train Loss=0.000204053 | Test Loss=0.002259971 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [360/1000] | Train Loss=0.000204220 | Test Loss=0.002275437 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [361/1000] | Train Loss=0.000207785 | Test Loss=0.002253076 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [362/1000] | Train Loss=0.000204319 | Test Loss=0.002256586 | Time=1.72s | LR=6.25e-06\n",
      "Epoch [363/1000] | Train Loss=0.000199568 | Test Loss=0.002268804 | Time=1.72s | LR=6.25e-06\n",
      "Epoch [364/1000] | Train Loss=0.000206376 | Test Loss=0.002277214 | Time=1.70s | LR=6.25e-06\n",
      "Epoch [365/1000] | Train Loss=0.000206593 | Test Loss=0.002259207 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [366/1000] | Train Loss=0.000210802 | Test Loss=0.002265828 | Time=1.70s | LR=6.25e-06\n",
      "Epoch [367/1000] | Train Loss=0.000204481 | Test Loss=0.002262706 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [368/1000] | Train Loss=0.000202310 | Test Loss=0.002275458 | Time=1.65s | LR=6.25e-06\n",
      "Epoch [369/1000] | Train Loss=0.000207594 | Test Loss=0.002254356 | Time=1.53s | LR=6.25e-06\n",
      "Epoch [370/1000] | Train Loss=0.000211630 | Test Loss=0.002263606 | Time=1.34s | LR=6.25e-06\n",
      "Epoch [371/1000] | Train Loss=0.000203800 | Test Loss=0.002255372 | Time=1.17s | LR=6.25e-06\n",
      "Epoch [372/1000] | Train Loss=0.000210357 | Test Loss=0.002251816 | Time=1.24s | LR=6.25e-06\n",
      "Epoch [373/1000] | Train Loss=0.000205207 | Test Loss=0.002248248 | Time=1.08s | LR=6.25e-06\n",
      "Epoch [374/1000] | Train Loss=0.000206864 | Test Loss=0.002269780 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [375/1000] | Train Loss=0.000209659 | Test Loss=0.002264122 | Time=1.27s | LR=6.25e-06\n",
      "Epoch [376/1000] | Train Loss=0.000202847 | Test Loss=0.002252714 | Time=1.16s | LR=6.25e-06\n",
      "Epoch [377/1000] | Train Loss=0.000207366 | Test Loss=0.002266127 | Time=1.24s | LR=6.25e-06\n",
      "Epoch [378/1000] | Train Loss=0.000205793 | Test Loss=0.002248270 | Time=1.07s | LR=6.25e-06\n",
      "Epoch [379/1000] | Train Loss=0.000197512 | Test Loss=0.002245238 | Time=1.24s | LR=6.25e-06\n",
      "Epoch [380/1000] | Train Loss=0.000201014 | Test Loss=0.002256041 | Time=1.10s | LR=6.25e-06\n",
      "Epoch [381/1000] | Train Loss=0.000212148 | Test Loss=0.002241147 | Time=1.21s | LR=6.25e-06\n",
      "Epoch [382/1000] | Train Loss=0.000201269 | Test Loss=0.002255201 | Time=1.31s | LR=6.25e-06\n",
      "Epoch [383/1000] | Train Loss=0.000208579 | Test Loss=0.002266733 | Time=1.18s | LR=6.25e-06\n",
      "Epoch [384/1000] | Train Loss=0.000205487 | Test Loss=0.002231099 | Time=1.24s | LR=6.25e-06\n",
      "Epoch [385/1000] | Train Loss=0.000201677 | Test Loss=0.002262574 | Time=1.10s | LR=6.25e-06\n",
      "Epoch [386/1000] | Train Loss=0.000214850 | Test Loss=0.002244761 | Time=1.20s | LR=6.25e-06\n",
      "Epoch [387/1000] | Train Loss=0.000209503 | Test Loss=0.002264856 | Time=1.19s | LR=6.25e-06\n",
      "Epoch [388/1000] | Train Loss=0.000202076 | Test Loss=0.002249340 | Time=1.22s | LR=6.25e-06\n",
      "Epoch [389/1000] | Train Loss=0.000199114 | Test Loss=0.002241138 | Time=1.24s | LR=6.25e-06\n",
      "Epoch [390/1000] | Train Loss=0.000201174 | Test Loss=0.002260101 | Time=1.12s | LR=6.25e-06\n",
      "Epoch [391/1000] | Train Loss=0.000206980 | Test Loss=0.002252459 | Time=1.21s | LR=6.25e-06\n",
      "Epoch [392/1000] | Train Loss=0.000198655 | Test Loss=0.002239364 | Time=1.18s | LR=6.25e-06\n",
      "Epoch [393/1000] | Train Loss=0.000201810 | Test Loss=0.002249671 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [394/1000] | Train Loss=0.000202063 | Test Loss=0.002248532 | Time=1.24s | LR=6.25e-06\n",
      "Epoch [395/1000] | Train Loss=0.000207866 | Test Loss=0.002238954 | Time=1.11s | LR=6.25e-06\n",
      "Epoch [396/1000] | Train Loss=0.000203644 | Test Loss=0.002237504 | Time=1.22s | LR=6.25e-06\n",
      "Epoch [397/1000] | Train Loss=0.000202550 | Test Loss=0.002250359 | Time=1.28s | LR=6.25e-06\n",
      "Epoch [398/1000] | Train Loss=0.000205724 | Test Loss=0.002230921 | Time=1.08s | LR=6.25e-06\n",
      "Epoch [399/1000] | Train Loss=0.000210540 | Test Loss=0.002239978 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [400/1000] | Train Loss=0.000201271 | Test Loss=0.002237771 | Time=1.10s | LR=6.25e-06\n",
      "Epoch [401/1000] | Train Loss=0.000203215 | Test Loss=0.002233868 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [402/1000] | Train Loss=0.000198952 | Test Loss=0.002238116 | Time=1.26s | LR=6.25e-06\n",
      "Epoch [403/1000] | Train Loss=0.000209962 | Test Loss=0.002243216 | Time=1.10s | LR=6.25e-06\n",
      "Epoch [404/1000] | Train Loss=0.000200612 | Test Loss=0.002236179 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [405/1000] | Train Loss=0.000204049 | Test Loss=0.002239606 | Time=1.09s | LR=6.25e-06\n",
      "Epoch [406/1000] | Train Loss=0.000202228 | Test Loss=0.002232231 | Time=1.22s | LR=6.25e-06\n",
      "Epoch [407/1000] | Train Loss=0.000206138 | Test Loss=0.002228661 | Time=1.14s | LR=6.25e-06\n",
      "Epoch [408/1000] | Train Loss=0.000205187 | Test Loss=0.002224971 | Time=1.14s | LR=6.25e-06\n",
      "Epoch [409/1000] | Train Loss=0.000205912 | Test Loss=0.002239732 | Time=1.41s | LR=6.25e-06\n",
      "Epoch [410/1000] | Train Loss=0.000205640 | Test Loss=0.002233481 | Time=1.36s | LR=6.25e-06\n",
      "Epoch [411/1000] | Train Loss=0.000205064 | Test Loss=0.002225666 | Time=1.17s | LR=6.25e-06\n",
      "Epoch [412/1000] | Train Loss=0.000210183 | Test Loss=0.002251540 | Time=1.21s | LR=6.25e-06\n",
      "Epoch [413/1000] | Train Loss=0.000216853 | Test Loss=0.002210714 | Time=1.08s | LR=6.25e-06\n",
      "Epoch [414/1000] | Train Loss=0.000205983 | Test Loss=0.002222717 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [415/1000] | Train Loss=0.000208572 | Test Loss=0.002241634 | Time=1.11s | LR=6.25e-06\n",
      "Epoch [416/1000] | Train Loss=0.000206253 | Test Loss=0.002229926 | Time=1.21s | LR=6.25e-06\n",
      "Epoch [417/1000] | Train Loss=0.000199741 | Test Loss=0.002240821 | Time=1.16s | LR=6.25e-06\n",
      "Epoch [418/1000] | Train Loss=0.000212348 | Test Loss=0.002217985 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [419/1000] | Train Loss=0.000202222 | Test Loss=0.002226797 | Time=1.25s | LR=6.25e-06\n",
      "Epoch [420/1000] | Train Loss=0.000203356 | Test Loss=0.002225671 | Time=1.15s | LR=3.13e-06\n",
      "Epoch [421/1000] | Train Loss=0.000201399 | Test Loss=0.002222805 | Time=1.41s | LR=3.13e-06\n",
      "Epoch [422/1000] | Train Loss=0.000193727 | Test Loss=0.002228341 | Time=1.48s | LR=3.13e-06\n",
      "Epoch [423/1000] | Train Loss=0.000198107 | Test Loss=0.002213771 | Time=1.65s | LR=3.13e-06\n",
      "Epoch [424/1000] | Train Loss=0.000198984 | Test Loss=0.002225839 | Time=1.51s | LR=3.13e-06\n",
      "Epoch [425/1000] | Train Loss=0.000194105 | Test Loss=0.002225677 | Time=1.44s | LR=3.13e-06\n",
      "Epoch [426/1000] | Train Loss=0.000199516 | Test Loss=0.002226952 | Time=1.39s | LR=3.13e-06\n",
      "Epoch [427/1000] | Train Loss=0.000195209 | Test Loss=0.002225859 | Time=1.43s | LR=3.13e-06\n",
      "Epoch [428/1000] | Train Loss=0.000194364 | Test Loss=0.002226001 | Time=1.13s | LR=3.13e-06\n",
      "Epoch [429/1000] | Train Loss=0.000200757 | Test Loss=0.002226500 | Time=1.40s | LR=3.13e-06\n",
      "Epoch [430/1000] | Train Loss=0.000198122 | Test Loss=0.002215824 | Time=1.16s | LR=3.13e-06\n",
      "Epoch [431/1000] | Train Loss=0.000195909 | Test Loss=0.002214370 | Time=1.21s | LR=3.13e-06\n",
      "Epoch [432/1000] | Train Loss=0.000196433 | Test Loss=0.002212487 | Time=1.18s | LR=3.13e-06\n",
      "Epoch [433/1000] | Train Loss=0.000195422 | Test Loss=0.002217943 | Time=1.25s | LR=3.13e-06\n",
      "Epoch [434/1000] | Train Loss=0.000195076 | Test Loss=0.002211475 | Time=1.43s | LR=3.13e-06\n",
      "Epoch [435/1000] | Train Loss=0.000196724 | Test Loss=0.002216101 | Time=1.15s | LR=3.13e-06\n",
      "Epoch [436/1000] | Train Loss=0.000196334 | Test Loss=0.002219608 | Time=1.15s | LR=3.13e-06\n",
      "Epoch [437/1000] | Train Loss=0.000195910 | Test Loss=0.002219536 | Time=1.23s | LR=3.13e-06\n",
      "Epoch [438/1000] | Train Loss=0.000195370 | Test Loss=0.002221743 | Time=1.26s | LR=3.13e-06\n",
      "Epoch [439/1000] | Train Loss=0.000197704 | Test Loss=0.002216071 | Time=1.23s | LR=3.13e-06\n",
      "Epoch [440/1000] | Train Loss=0.000195287 | Test Loss=0.002215408 | Time=1.12s | LR=3.13e-06\n",
      "Epoch [441/1000] | Train Loss=0.000198355 | Test Loss=0.002221960 | Time=1.16s | LR=3.13e-06\n",
      "Epoch [442/1000] | Train Loss=0.000195949 | Test Loss=0.002214560 | Time=1.22s | LR=3.13e-06\n",
      "Epoch [443/1000] | Train Loss=0.000201294 | Test Loss=0.002217838 | Time=1.08s | LR=3.13e-06\n",
      "Epoch [444/1000] | Train Loss=0.000198300 | Test Loss=0.002220297 | Time=1.24s | LR=3.13e-06\n",
      "Epoch [445/1000] | Train Loss=0.000198454 | Test Loss=0.002214646 | Time=1.11s | LR=3.13e-06\n",
      "Epoch [446/1000] | Train Loss=0.000195434 | Test Loss=0.002220061 | Time=1.21s | LR=3.13e-06\n",
      "Epoch [447/1000] | Train Loss=0.000200165 | Test Loss=0.002221786 | Time=1.16s | LR=3.13e-06\n",
      "Epoch [448/1000] | Train Loss=0.000197061 | Test Loss=0.002217179 | Time=1.23s | LR=3.13e-06\n",
      "Epoch [449/1000] | Train Loss=0.000198694 | Test Loss=0.002215258 | Time=1.25s | LR=3.13e-06\n",
      "Epoch [450/1000] | Train Loss=0.000196843 | Test Loss=0.002219432 | Time=1.09s | LR=3.13e-06\n",
      "Epoch [451/1000] | Train Loss=0.000199813 | Test Loss=0.002220378 | Time=1.25s | LR=3.13e-06\n",
      "Epoch [452/1000] | Train Loss=0.000201481 | Test Loss=0.002211463 | Time=1.26s | LR=3.13e-06\n",
      "Epoch [453/1000] | Train Loss=0.000199104 | Test Loss=0.002208966 | Time=1.09s | LR=3.13e-06\n",
      "Epoch [454/1000] | Train Loss=0.000201007 | Test Loss=0.002213054 | Time=1.25s | LR=3.13e-06\n",
      "Epoch [455/1000] | Train Loss=0.000198685 | Test Loss=0.002212975 | Time=1.08s | LR=3.13e-06\n",
      "Epoch [456/1000] | Train Loss=0.000199960 | Test Loss=0.002222782 | Time=1.30s | LR=3.13e-06\n",
      "Epoch [457/1000] | Train Loss=0.000197399 | Test Loss=0.002204951 | Time=1.26s | LR=3.13e-06\n",
      "Epoch [458/1000] | Train Loss=0.000195246 | Test Loss=0.002219942 | Time=1.09s | LR=3.13e-06\n",
      "Epoch [459/1000] | Train Loss=0.000196800 | Test Loss=0.002215057 | Time=1.26s | LR=3.13e-06\n",
      "Epoch [460/1000] | Train Loss=0.000195823 | Test Loss=0.002203559 | Time=1.12s | LR=3.13e-06\n",
      "Epoch [461/1000] | Train Loss=0.000198205 | Test Loss=0.002208620 | Time=1.37s | LR=3.13e-06\n",
      "Epoch [462/1000] | Train Loss=0.000194559 | Test Loss=0.002216834 | Time=1.55s | LR=3.13e-06\n",
      "Epoch [463/1000] | Train Loss=0.000200613 | Test Loss=0.002209065 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [464/1000] | Train Loss=0.000195433 | Test Loss=0.002204714 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [465/1000] | Train Loss=0.000191303 | Test Loss=0.002208774 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [466/1000] | Train Loss=0.000192245 | Test Loss=0.002206788 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [467/1000] | Train Loss=0.000194494 | Test Loss=0.002211890 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [468/1000] | Train Loss=0.000194554 | Test Loss=0.002212193 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [469/1000] | Train Loss=0.000192369 | Test Loss=0.002205677 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [470/1000] | Train Loss=0.000197274 | Test Loss=0.002205066 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [471/1000] | Train Loss=0.000193993 | Test Loss=0.002210570 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [472/1000] | Train Loss=0.000193506 | Test Loss=0.002205815 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [473/1000] | Train Loss=0.000191993 | Test Loss=0.002208533 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [474/1000] | Train Loss=0.000197199 | Test Loss=0.002206381 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [475/1000] | Train Loss=0.000193684 | Test Loss=0.002213387 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [476/1000] | Train Loss=0.000194921 | Test Loss=0.002212023 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [477/1000] | Train Loss=0.000192566 | Test Loss=0.002209206 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [478/1000] | Train Loss=0.000193626 | Test Loss=0.002201930 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [479/1000] | Train Loss=0.000192524 | Test Loss=0.002211610 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [480/1000] | Train Loss=0.000193431 | Test Loss=0.002212454 | Time=1.74s | LR=1.56e-06\n",
      "Epoch [481/1000] | Train Loss=0.000193779 | Test Loss=0.002210394 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [482/1000] | Train Loss=0.000194900 | Test Loss=0.002210691 | Time=1.65s | LR=1.56e-06\n",
      "Epoch [483/1000] | Train Loss=0.000193029 | Test Loss=0.002206451 | Time=1.71s | LR=1.56e-06\n",
      "Epoch [484/1000] | Train Loss=0.000192999 | Test Loss=0.002206712 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [485/1000] | Train Loss=0.000194765 | Test Loss=0.002218832 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [486/1000] | Train Loss=0.000193063 | Test Loss=0.002213992 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [487/1000] | Train Loss=0.000194431 | Test Loss=0.002210855 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [488/1000] | Train Loss=0.000194034 | Test Loss=0.002211183 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [489/1000] | Train Loss=0.000193005 | Test Loss=0.002209718 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [490/1000] | Train Loss=0.000194435 | Test Loss=0.002215570 | Time=1.50s | LR=1.56e-06\n",
      "Epoch [491/1000] | Train Loss=0.000192936 | Test Loss=0.002205170 | Time=1.45s | LR=1.56e-06\n",
      "Epoch [492/1000] | Train Loss=0.000193513 | Test Loss=0.002209120 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [493/1000] | Train Loss=0.000192302 | Test Loss=0.002208735 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [494/1000] | Train Loss=0.000193959 | Test Loss=0.002199479 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [495/1000] | Train Loss=0.000192295 | Test Loss=0.002202837 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [496/1000] | Train Loss=0.000193371 | Test Loss=0.002204736 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [497/1000] | Train Loss=0.000193835 | Test Loss=0.002204683 | Time=1.52s | LR=1.56e-06\n",
      "Epoch [498/1000] | Train Loss=0.000195011 | Test Loss=0.002203670 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [499/1000] | Train Loss=0.000194638 | Test Loss=0.002208866 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [500/1000] | Train Loss=0.000193857 | Test Loss=0.002207716 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [501/1000] | Train Loss=0.000194011 | Test Loss=0.002209074 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [502/1000] | Train Loss=0.000193710 | Test Loss=0.002203279 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [503/1000] | Train Loss=0.000193469 | Test Loss=0.002203297 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [504/1000] | Train Loss=0.000194601 | Test Loss=0.002202276 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [505/1000] | Train Loss=0.000194241 | Test Loss=0.002210995 | Time=0.97s | LR=1.56e-06\n",
      "Epoch [506/1000] | Train Loss=0.000194098 | Test Loss=0.002206631 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [507/1000] | Train Loss=0.000191484 | Test Loss=0.002203156 | Time=1.47s | LR=7.81e-07\n",
      "Epoch [508/1000] | Train Loss=0.000193496 | Test Loss=0.002203489 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [509/1000] | Train Loss=0.000192602 | Test Loss=0.002202904 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [510/1000] | Train Loss=0.000192280 | Test Loss=0.002200415 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [511/1000] | Train Loss=0.000195220 | Test Loss=0.002205654 | Time=1.44s | LR=7.81e-07\n",
      "Epoch [512/1000] | Train Loss=0.000194859 | Test Loss=0.002201690 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [513/1000] | Train Loss=0.000193387 | Test Loss=0.002203468 | Time=1.70s | LR=7.81e-07\n",
      "Epoch [514/1000] | Train Loss=0.000193004 | Test Loss=0.002208618 | Time=1.75s | LR=7.81e-07\n",
      "Epoch [515/1000] | Train Loss=0.000193478 | Test Loss=0.002202178 | Time=1.70s | LR=7.81e-07\n",
      "Epoch [516/1000] | Train Loss=0.000191673 | Test Loss=0.002202537 | Time=1.51s | LR=7.81e-07\n",
      "Epoch [517/1000] | Train Loss=0.000193526 | Test Loss=0.002202047 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [518/1000] | Train Loss=0.000191792 | Test Loss=0.002203234 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [519/1000] | Train Loss=0.000192773 | Test Loss=0.002202789 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [520/1000] | Train Loss=0.000194065 | Test Loss=0.002207030 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [521/1000] | Train Loss=0.000193272 | Test Loss=0.002204563 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [522/1000] | Train Loss=0.000192684 | Test Loss=0.002201949 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [523/1000] | Train Loss=0.000192723 | Test Loss=0.002206733 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [524/1000] | Train Loss=0.000195197 | Test Loss=0.002195892 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [525/1000] | Train Loss=0.000193288 | Test Loss=0.002205484 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [526/1000] | Train Loss=0.000191724 | Test Loss=0.002199891 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [527/1000] | Train Loss=0.000191453 | Test Loss=0.002201802 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [528/1000] | Train Loss=0.000192351 | Test Loss=0.002206284 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [529/1000] | Train Loss=0.000194775 | Test Loss=0.002201483 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [530/1000] | Train Loss=0.000193165 | Test Loss=0.002198874 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [531/1000] | Train Loss=0.000192944 | Test Loss=0.002203795 | Time=1.57s | LR=7.81e-07\n",
      "Epoch [532/1000] | Train Loss=0.000191055 | Test Loss=0.002202818 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [533/1000] | Train Loss=0.000198130 | Test Loss=0.002199452 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [534/1000] | Train Loss=0.000192864 | Test Loss=0.002205514 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [535/1000] | Train Loss=0.000191745 | Test Loss=0.002201967 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [536/1000] | Train Loss=0.000192110 | Test Loss=0.002197864 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [537/1000] | Train Loss=0.000192456 | Test Loss=0.002201901 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [538/1000] | Train Loss=0.000191564 | Test Loss=0.002204028 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [539/1000] | Train Loss=0.000192741 | Test Loss=0.002197625 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [540/1000] | Train Loss=0.000193322 | Test Loss=0.002202565 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [541/1000] | Train Loss=0.000192276 | Test Loss=0.002198570 | Time=1.54s | LR=7.81e-07\n",
      "Epoch [542/1000] | Train Loss=0.000192643 | Test Loss=0.002208456 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [543/1000] | Train Loss=0.000192386 | Test Loss=0.002206397 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [544/1000] | Train Loss=0.000193487 | Test Loss=0.002201155 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [545/1000] | Train Loss=0.000193462 | Test Loss=0.002203111 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [546/1000] | Train Loss=0.000194619 | Test Loss=0.002205836 | Time=0.97s | LR=7.81e-07\n",
      "Epoch [547/1000] | Train Loss=0.000190927 | Test Loss=0.002207059 | Time=1.42s | LR=7.81e-07\n",
      "Epoch [548/1000] | Train Loss=0.000191213 | Test Loss=0.002207931 | Time=1.48s | LR=7.81e-07\n",
      "Epoch [549/1000] | Train Loss=0.000190511 | Test Loss=0.002207376 | Time=1.46s | LR=7.81e-07\n",
      "Epoch [550/1000] | Train Loss=0.000191663 | Test Loss=0.002203869 | Time=1.43s | LR=7.81e-07\n",
      "Epoch [551/1000] | Train Loss=0.000193631 | Test Loss=0.002206756 | Time=1.38s | LR=7.81e-07\n",
      "Epoch [552/1000] | Train Loss=0.000192798 | Test Loss=0.002204179 | Time=1.45s | LR=7.81e-07\n",
      "Epoch [553/1000] | Train Loss=0.000194784 | Test Loss=0.002202411 | Time=1.44s | LR=7.81e-07\n",
      "Epoch [554/1000] | Train Loss=0.000194970 | Test Loss=0.002202390 | Time=1.38s | LR=7.81e-07\n",
      "Epoch [555/1000] | Train Loss=0.000192384 | Test Loss=0.002199846 | Time=1.30s | LR=7.81e-07\n",
      "Epoch [556/1000] | Train Loss=0.000192852 | Test Loss=0.002199038 | Time=1.42s | LR=7.81e-07\n",
      "Epoch [557/1000] | Train Loss=0.000192680 | Test Loss=0.002194648 | Time=1.41s | LR=7.81e-07\n",
      "Epoch [558/1000] | Train Loss=0.000193557 | Test Loss=0.002203223 | Time=1.31s | LR=7.81e-07\n",
      "Epoch [559/1000] | Train Loss=0.000191880 | Test Loss=0.002203087 | Time=1.37s | LR=7.81e-07\n",
      "Epoch [560/1000] | Train Loss=0.000190903 | Test Loss=0.002199163 | Time=1.52s | LR=7.81e-07\n",
      "Epoch [561/1000] | Train Loss=0.000194275 | Test Loss=0.002200709 | Time=1.66s | LR=7.81e-07\n",
      "Epoch [562/1000] | Train Loss=0.000193185 | Test Loss=0.002197131 | Time=1.50s | LR=7.81e-07\n",
      "Epoch [563/1000] | Train Loss=0.000193153 | Test Loss=0.002197184 | Time=1.63s | LR=7.81e-07\n",
      "Epoch [564/1000] | Train Loss=0.000190804 | Test Loss=0.002198666 | Time=1.63s | LR=7.81e-07\n",
      "Epoch [565/1000] | Train Loss=0.000192223 | Test Loss=0.002200400 | Time=1.54s | LR=7.81e-07\n",
      "Epoch [566/1000] | Train Loss=0.000192675 | Test Loss=0.002196874 | Time=1.50s | LR=7.81e-07\n",
      "Epoch [567/1000] | Train Loss=0.000191695 | Test Loss=0.002201594 | Time=1.65s | LR=7.81e-07\n",
      "Epoch [568/1000] | Train Loss=0.000192798 | Test Loss=0.002200866 | Time=1.54s | LR=7.81e-07\n",
      "Epoch [569/1000] | Train Loss=0.000189660 | Test Loss=0.002201294 | Time=1.56s | LR=7.81e-07\n",
      "Epoch [570/1000] | Train Loss=0.000191174 | Test Loss=0.002198429 | Time=1.38s | LR=7.81e-07\n",
      "Epoch [571/1000] | Train Loss=0.000190781 | Test Loss=0.002199643 | Time=1.48s | LR=7.81e-07\n",
      "Epoch [572/1000] | Train Loss=0.000193271 | Test Loss=0.002203859 | Time=1.38s | LR=7.81e-07\n",
      "Epoch [573/1000] | Train Loss=0.000192443 | Test Loss=0.002196441 | Time=1.40s | LR=7.81e-07\n",
      "Epoch [574/1000] | Train Loss=0.000191097 | Test Loss=0.002202989 | Time=1.33s | LR=7.81e-07\n",
      "Epoch [575/1000] | Train Loss=0.000192712 | Test Loss=0.002197899 | Time=1.35s | LR=7.81e-07\n",
      "Epoch [576/1000] | Train Loss=0.000192476 | Test Loss=0.002198621 | Time=1.42s | LR=7.81e-07\n",
      "Epoch [577/1000] | Train Loss=0.000192480 | Test Loss=0.002199263 | Time=1.37s | LR=7.81e-07\n",
      "Epoch [578/1000] | Train Loss=0.000192115 | Test Loss=0.002193129 | Time=1.45s | LR=7.81e-07\n",
      "Epoch [579/1000] | Train Loss=0.000192085 | Test Loss=0.002194152 | Time=1.46s | LR=7.81e-07\n",
      "Epoch [580/1000] | Train Loss=0.000192475 | Test Loss=0.002199927 | Time=1.37s | LR=7.81e-07\n",
      "Epoch [581/1000] | Train Loss=0.000192441 | Test Loss=0.002196028 | Time=1.28s | LR=7.81e-07\n",
      "Epoch [582/1000] | Train Loss=0.000192743 | Test Loss=0.002197714 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [583/1000] | Train Loss=0.000191604 | Test Loss=0.002193700 | Time=1.65s | LR=7.81e-07\n",
      "Epoch [584/1000] | Train Loss=0.000190878 | Test Loss=0.002196824 | Time=1.49s | LR=7.81e-07\n",
      "Epoch [585/1000] | Train Loss=0.000191473 | Test Loss=0.002196573 | Time=1.48s | LR=7.81e-07\n",
      "Epoch [586/1000] | Train Loss=0.000193366 | Test Loss=0.002195824 | Time=1.52s | LR=7.81e-07\n",
      "Epoch [587/1000] | Train Loss=0.000192047 | Test Loss=0.002195707 | Time=1.62s | LR=7.81e-07\n",
      "Epoch [588/1000] | Train Loss=0.000191290 | Test Loss=0.002190154 | Time=1.52s | LR=7.81e-07\n",
      "Epoch [589/1000] | Train Loss=0.000191929 | Test Loss=0.002198166 | Time=1.48s | LR=7.81e-07\n",
      "Epoch [590/1000] | Train Loss=0.000194051 | Test Loss=0.002193457 | Time=1.39s | LR=7.81e-07\n",
      "Epoch [591/1000] | Train Loss=0.000192338 | Test Loss=0.002196282 | Time=1.45s | LR=7.81e-07\n",
      "Epoch [592/1000] | Train Loss=0.000194730 | Test Loss=0.002193789 | Time=1.38s | LR=7.81e-07\n",
      "Epoch [593/1000] | Train Loss=0.000192034 | Test Loss=0.002192380 | Time=1.38s | LR=7.81e-07\n",
      "Epoch [594/1000] | Train Loss=0.000193509 | Test Loss=0.002200883 | Time=1.43s | LR=7.81e-07\n",
      "Epoch [595/1000] | Train Loss=0.000191743 | Test Loss=0.002195371 | Time=1.39s | LR=7.81e-07\n",
      "Epoch [596/1000] | Train Loss=0.000191621 | Test Loss=0.002202539 | Time=1.31s | LR=7.81e-07\n",
      "Epoch [597/1000] | Train Loss=0.000193360 | Test Loss=0.002194781 | Time=1.48s | LR=7.81e-07\n",
      "Epoch [598/1000] | Train Loss=0.000191619 | Test Loss=0.002196681 | Time=1.46s | LR=7.81e-07\n",
      "Epoch [599/1000] | Train Loss=0.000190465 | Test Loss=0.002196159 | Time=1.35s | LR=7.81e-07\n",
      "Epoch [600/1000] | Train Loss=0.000191954 | Test Loss=0.002201416 | Time=1.31s | LR=7.81e-07\n",
      "Epoch [601/1000] | Train Loss=0.000192903 | Test Loss=0.002198881 | Time=1.55s | LR=7.81e-07\n",
      "Epoch [602/1000] | Train Loss=0.000192396 | Test Loss=0.002198702 | Time=1.46s | LR=7.81e-07\n",
      "Epoch [603/1000] | Train Loss=0.000192396 | Test Loss=0.002198904 | Time=1.30s | LR=7.81e-07\n",
      "Epoch [604/1000] | Train Loss=0.000192398 | Test Loss=0.002198925 | Time=1.63s | LR=7.81e-07\n",
      "Epoch [605/1000] | Train Loss=0.000191686 | Test Loss=0.002199517 | Time=1.65s | LR=7.81e-07\n",
      "Epoch [606/1000] | Train Loss=0.000190831 | Test Loss=0.002199553 | Time=1.50s | LR=7.81e-07\n",
      "Epoch [607/1000] | Train Loss=0.000191281 | Test Loss=0.002195054 | Time=1.49s | LR=7.81e-07\n",
      "Epoch [608/1000] | Train Loss=0.000192871 | Test Loss=0.002196514 | Time=1.51s | LR=7.81e-07\n",
      "Epoch [609/1000] | Train Loss=0.000190811 | Test Loss=0.002203485 | Time=1.64s | LR=7.81e-07\n",
      "Epoch [610/1000] | Train Loss=0.000191219 | Test Loss=0.002202300 | Time=1.51s | LR=3.91e-07\n",
      "Epoch [611/1000] | Train Loss=0.000191863 | Test Loss=0.002202219 | Time=1.33s | LR=3.91e-07\n",
      "Epoch [612/1000] | Train Loss=0.000190895 | Test Loss=0.002201596 | Time=1.45s | LR=3.91e-07\n",
      "Epoch [613/1000] | Train Loss=0.000191811 | Test Loss=0.002201311 | Time=1.46s | LR=3.91e-07\n",
      "Epoch [614/1000] | Train Loss=0.000192488 | Test Loss=0.002199061 | Time=1.36s | LR=3.91e-07\n",
      "Epoch [615/1000] | Train Loss=0.000191062 | Test Loss=0.002200595 | Time=1.29s | LR=3.91e-07\n",
      "Epoch [616/1000] | Train Loss=0.000189752 | Test Loss=0.002196813 | Time=1.45s | LR=3.91e-07\n",
      "Epoch [617/1000] | Train Loss=0.000190049 | Test Loss=0.002200943 | Time=1.37s | LR=3.91e-07\n",
      "Epoch [618/1000] | Train Loss=0.000190236 | Test Loss=0.002202286 | Time=1.28s | LR=3.91e-07\n",
      "Epoch [619/1000] | Train Loss=0.000191124 | Test Loss=0.002202197 | Time=1.44s | LR=3.91e-07\n",
      "Epoch [620/1000] | Train Loss=0.000189878 | Test Loss=0.002200418 | Time=1.37s | LR=3.91e-07\n",
      "Epoch [621/1000] | Train Loss=0.000189419 | Test Loss=0.002197984 | Time=1.28s | LR=3.91e-07\n",
      "Epoch [622/1000] | Train Loss=0.000193697 | Test Loss=0.002202565 | Time=1.42s | LR=3.91e-07\n",
      "Epoch [623/1000] | Train Loss=0.000192578 | Test Loss=0.002201083 | Time=1.39s | LR=3.91e-07\n",
      "Epoch [624/1000] | Train Loss=0.000192421 | Test Loss=0.002198620 | Time=1.42s | LR=3.91e-07\n",
      "Epoch [625/1000] | Train Loss=0.000189578 | Test Loss=0.002202847 | Time=1.34s | LR=3.91e-07\n",
      "Epoch [626/1000] | Train Loss=0.000192772 | Test Loss=0.002199972 | Time=1.52s | LR=3.91e-07\n",
      "Epoch [627/1000] | Train Loss=0.000190060 | Test Loss=0.002199173 | Time=1.66s | LR=3.91e-07\n",
      "Epoch [628/1000] | Train Loss=0.000190488 | Test Loss=0.002198559 | Time=1.66s | LR=3.91e-07\n",
      "Epoch [629/1000] | Train Loss=0.000189893 | Test Loss=0.002196011 | Time=1.47s | LR=3.91e-07\n",
      "Epoch [630/1000] | Train Loss=0.000192518 | Test Loss=0.002200497 | Time=1.61s | LR=3.91e-07\n",
      "Epoch [631/1000] | Train Loss=0.000192990 | Test Loss=0.002199885 | Time=1.54s | LR=3.91e-07\n",
      "Epoch [632/1000] | Train Loss=0.000191930 | Test Loss=0.002200410 | Time=1.50s | LR=3.91e-07\n",
      "Epoch [633/1000] | Train Loss=0.000192297 | Test Loss=0.002198853 | Time=1.29s | LR=3.91e-07\n",
      "Epoch [634/1000] | Train Loss=0.000192926 | Test Loss=0.002202451 | Time=1.45s | LR=3.91e-07\n",
      "Epoch [635/1000] | Train Loss=0.000191397 | Test Loss=0.002198618 | Time=1.36s | LR=3.91e-07\n",
      "Epoch [636/1000] | Train Loss=0.000192998 | Test Loss=0.002197074 | Time=1.28s | LR=3.91e-07\n",
      "Epoch [637/1000] | Train Loss=0.000192258 | Test Loss=0.002202870 | Time=1.44s | LR=3.91e-07\n",
      "Epoch [638/1000] | Train Loss=0.000192718 | Test Loss=0.002199917 | Time=1.37s | LR=3.91e-07\n",
      "Epoch [639/1000] | Train Loss=0.000190624 | Test Loss=0.002201396 | Time=1.29s | LR=3.91e-07\n",
      "Epoch [640/1000] | Train Loss=0.000191412 | Test Loss=0.002192644 | Time=1.42s | LR=3.91e-07\n",
      "Epoch [641/1000] | Train Loss=0.000191279 | Test Loss=0.002195068 | Time=1.37s | LR=3.91e-07\n",
      "Epoch [642/1000] | Train Loss=0.000191002 | Test Loss=0.002198441 | Time=1.29s | LR=3.91e-07\n",
      "Epoch [643/1000] | Train Loss=0.000190864 | Test Loss=0.002193147 | Time=1.48s | LR=3.91e-07\n",
      "Epoch [644/1000] | Train Loss=0.000190079 | Test Loss=0.002201239 | Time=1.45s | LR=3.91e-07\n",
      "Epoch [645/1000] | Train Loss=0.000194846 | Test Loss=0.002201821 | Time=1.35s | LR=3.91e-07\n",
      "Epoch [646/1000] | Train Loss=0.000192292 | Test Loss=0.002202116 | Time=1.31s | LR=3.91e-07\n",
      "Epoch [647/1000] | Train Loss=0.000193308 | Test Loss=0.002198926 | Time=1.42s | LR=3.91e-07\n",
      "Epoch [648/1000] | Train Loss=0.000191433 | Test Loss=0.002196503 | Time=1.37s | LR=3.91e-07\n",
      "Epoch [649/1000] | Train Loss=0.000190307 | Test Loss=0.002199498 | Time=1.65s | LR=3.91e-07\n",
      "Epoch [650/1000] | Train Loss=0.000193707 | Test Loss=0.002199514 | Time=1.54s | LR=3.91e-07\n",
      "Epoch [651/1000] | Train Loss=0.000190939 | Test Loss=0.002201613 | Time=1.58s | LR=3.91e-07\n",
      "Epoch [652/1000] | Train Loss=0.000190513 | Test Loss=0.002200098 | Time=1.47s | LR=3.91e-07\n",
      "Epoch [653/1000] | Train Loss=0.000193138 | Test Loss=0.002195083 | Time=1.32s | LR=3.91e-07\n",
      "Epoch [654/1000] | Train Loss=0.000191042 | Test Loss=0.002204052 | Time=1.49s | LR=3.91e-07\n",
      "Epoch [655/1000] | Train Loss=0.000190548 | Test Loss=0.002200145 | Time=1.45s | LR=3.91e-07\n",
      "Epoch [656/1000] | Train Loss=0.000191902 | Test Loss=0.002195582 | Time=1.32s | LR=3.91e-07\n",
      "Epoch [657/1000] | Train Loss=0.000191403 | Test Loss=0.002200201 | Time=1.32s | LR=3.91e-07\n",
      "Epoch [658/1000] | Train Loss=0.000190969 | Test Loss=0.002195548 | Time=1.41s | LR=3.91e-07\n",
      "Epoch [659/1000] | Train Loss=0.000189526 | Test Loss=0.002195263 | Time=1.35s | LR=3.91e-07\n",
      "Epoch [660/1000] | Train Loss=0.000190404 | Test Loss=0.002197849 | Time=1.31s | LR=3.91e-07\n",
      "Epoch [661/1000] | Train Loss=0.000191692 | Test Loss=0.002201183 | Time=1.43s | LR=3.91e-07\n",
      "Epoch [662/1000] | Train Loss=0.000191812 | Test Loss=0.002200741 | Time=1.35s | LR=1.95e-07\n",
      "Epoch [663/1000] | Train Loss=0.000188974 | Test Loss=0.002202413 | Time=1.30s | LR=1.95e-07\n",
      "Epoch [664/1000] | Train Loss=0.000190951 | Test Loss=0.002198318 | Time=1.43s | LR=1.95e-07\n",
      "Epoch [665/1000] | Train Loss=0.000189469 | Test Loss=0.002199421 | Time=1.36s | LR=1.95e-07\n",
      "Epoch [666/1000] | Train Loss=0.000190222 | Test Loss=0.002200361 | Time=1.45s | LR=1.95e-07\n",
      "Epoch [667/1000] | Train Loss=0.000190318 | Test Loss=0.002203401 | Time=1.41s | LR=1.95e-07\n",
      "Epoch [668/1000] | Train Loss=0.000189916 | Test Loss=0.002198719 | Time=1.37s | LR=1.95e-07\n",
      "Epoch [669/1000] | Train Loss=0.000192016 | Test Loss=0.002195925 | Time=1.29s | LR=1.95e-07\n",
      "Epoch [670/1000] | Train Loss=0.000190798 | Test Loss=0.002200021 | Time=1.38s | LR=1.95e-07\n",
      "Epoch [671/1000] | Train Loss=0.000192702 | Test Loss=0.002197793 | Time=1.49s | LR=1.95e-07\n",
      "Epoch [672/1000] | Train Loss=0.000191081 | Test Loss=0.002197794 | Time=1.66s | LR=1.95e-07\n",
      "Epoch [673/1000] | Train Loss=0.000190338 | Test Loss=0.002203843 | Time=1.65s | LR=1.95e-07\n",
      "Epoch [674/1000] | Train Loss=0.000190427 | Test Loss=0.002199245 | Time=1.42s | LR=1.95e-07\n",
      "Epoch [675/1000] | Train Loss=0.000189537 | Test Loss=0.002201110 | Time=1.42s | LR=1.95e-07\n",
      "Epoch [676/1000] | Train Loss=0.000194219 | Test Loss=0.002200429 | Time=1.35s | LR=1.95e-07\n",
      "Epoch [677/1000] | Train Loss=0.000191753 | Test Loss=0.002198995 | Time=1.45s | LR=1.95e-07\n",
      "Epoch [678/1000] | Train Loss=0.000189117 | Test Loss=0.002202294 | Time=1.44s | LR=1.95e-07\n",
      "Epoch [679/1000] | Train Loss=0.000191133 | Test Loss=0.002200871 | Time=1.35s | LR=1.95e-07\n",
      "Epoch [680/1000] | Train Loss=0.000193055 | Test Loss=0.002201105 | Time=1.27s | LR=1.95e-07\n",
      "Epoch [681/1000] | Train Loss=0.000190305 | Test Loss=0.002195824 | Time=1.43s | LR=1.95e-07\n",
      "Epoch [682/1000] | Train Loss=0.000191267 | Test Loss=0.002199468 | Time=1.38s | LR=1.95e-07\n",
      "Epoch [683/1000] | Train Loss=0.000190376 | Test Loss=0.002199911 | Time=1.27s | LR=1.95e-07\n",
      "Epoch [684/1000] | Train Loss=0.000190642 | Test Loss=0.002199283 | Time=1.40s | LR=1.95e-07\n",
      "Epoch [685/1000] | Train Loss=0.000191159 | Test Loss=0.002193331 | Time=1.38s | LR=1.95e-07\n",
      "Epoch [686/1000] | Train Loss=0.000191078 | Test Loss=0.002198268 | Time=1.29s | LR=1.95e-07\n",
      "Epoch [687/1000] | Train Loss=0.000191420 | Test Loss=0.002197269 | Time=1.38s | LR=1.95e-07\n",
      "Epoch [688/1000] | Train Loss=0.000190061 | Test Loss=0.002196975 | Time=1.39s | LR=1.95e-07\n",
      "Epoch [689/1000] | Train Loss=0.000189912 | Test Loss=0.002195847 | Time=1.50s | LR=1.95e-07\n",
      "Epoch [690/1000] | Train Loss=0.000190207 | Test Loss=0.002195887 | Time=1.31s | LR=1.95e-07\n",
      "Epoch [691/1000] | Train Loss=0.000190322 | Test Loss=0.002194076 | Time=1.41s | LR=1.95e-07\n",
      "Epoch [692/1000] | Train Loss=0.000191109 | Test Loss=0.002197027 | Time=1.35s | LR=1.95e-07\n",
      "Epoch [693/1000] | Train Loss=0.000189627 | Test Loss=0.002198003 | Time=1.30s | LR=1.95e-07\n",
      "Epoch [694/1000] | Train Loss=0.000189341 | Test Loss=0.002196597 | Time=1.57s | LR=1.95e-07\n",
      "Epoch [695/1000] | Train Loss=0.000189230 | Test Loss=0.002197737 | Time=1.67s | LR=1.95e-07\n",
      "Epoch [696/1000] | Train Loss=0.000189866 | Test Loss=0.002194376 | Time=1.33s | LR=1.95e-07\n",
      "Epoch [697/1000] | Train Loss=0.000189945 | Test Loss=0.002193495 | Time=1.32s | LR=1.95e-07\n",
      "Epoch [698/1000] | Train Loss=0.000189739 | Test Loss=0.002190173 | Time=1.41s | LR=1.95e-07\n",
      "Epoch [699/1000] | Train Loss=0.000189043 | Test Loss=0.002197786 | Time=1.32s | LR=1.95e-07\n",
      "Epoch [700/1000] | Train Loss=0.000190301 | Test Loss=0.002198506 | Time=1.44s | LR=1.95e-07\n",
      "Epoch [701/1000] | Train Loss=0.000190831 | Test Loss=0.002196343 | Time=1.44s | LR=1.95e-07\n",
      "Epoch [702/1000] | Train Loss=0.000189031 | Test Loss=0.002197070 | Time=1.35s | LR=1.95e-07\n",
      "Epoch [703/1000] | Train Loss=0.000192176 | Test Loss=0.002190658 | Time=1.28s | LR=1.95e-07\n",
      "Epoch [704/1000] | Train Loss=0.000191399 | Test Loss=0.002196810 | Time=1.44s | LR=9.77e-08\n",
      "Epoch [705/1000] | Train Loss=0.000189832 | Test Loss=0.002194666 | Time=1.34s | LR=9.77e-08\n",
      "Epoch [706/1000] | Train Loss=0.000189606 | Test Loss=0.002196495 | Time=1.27s | LR=9.77e-08\n",
      "Epoch [707/1000] | Train Loss=0.000191646 | Test Loss=0.002193242 | Time=1.43s | LR=9.77e-08\n",
      "Epoch [708/1000] | Train Loss=0.000192578 | Test Loss=0.002193724 | Time=1.37s | LR=9.77e-08\n",
      "Epoch [709/1000] | Train Loss=0.000192205 | Test Loss=0.002193151 | Time=1.28s | LR=9.77e-08\n",
      "Epoch [710/1000] | Train Loss=0.000192577 | Test Loss=0.002196266 | Time=1.41s | LR=9.77e-08\n",
      "Epoch [711/1000] | Train Loss=0.000189825 | Test Loss=0.002194938 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [712/1000] | Train Loss=0.000188776 | Test Loss=0.002191720 | Time=1.48s | LR=9.77e-08\n",
      "Epoch [713/1000] | Train Loss=0.000191668 | Test Loss=0.002196810 | Time=1.33s | LR=9.77e-08\n",
      "Epoch [714/1000] | Train Loss=0.000189342 | Test Loss=0.002192930 | Time=1.40s | LR=9.77e-08\n",
      "Epoch [715/1000] | Train Loss=0.000192028 | Test Loss=0.002194790 | Time=1.33s | LR=9.77e-08\n",
      "Epoch [716/1000] | Train Loss=0.000193234 | Test Loss=0.002194947 | Time=1.32s | LR=9.77e-08\n",
      "Epoch [717/1000] | Train Loss=0.000190143 | Test Loss=0.002196189 | Time=1.51s | LR=9.77e-08\n",
      "Epoch [718/1000] | Train Loss=0.000189901 | Test Loss=0.002195459 | Time=1.55s | LR=9.77e-08\n",
      "Epoch [719/1000] | Train Loss=0.000191013 | Test Loss=0.002196788 | Time=1.27s | LR=9.77e-08\n",
      "Epoch [720/1000] | Train Loss=0.000189447 | Test Loss=0.002193740 | Time=1.43s | LR=9.77e-08\n",
      "Epoch [721/1000] | Train Loss=0.000189240 | Test Loss=0.002191923 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [722/1000] | Train Loss=0.000191101 | Test Loss=0.002195284 | Time=1.26s | LR=9.77e-08\n",
      "Epoch [723/1000] | Train Loss=0.000192209 | Test Loss=0.002194266 | Time=1.50s | LR=9.77e-08\n",
      "Epoch [724/1000] | Train Loss=0.000192578 | Test Loss=0.002197200 | Time=1.46s | LR=9.77e-08\n",
      "Epoch [725/1000] | Train Loss=0.000193450 | Test Loss=0.002195322 | Time=1.64s | LR=9.77e-08\n",
      "Epoch [726/1000] | Train Loss=0.000191488 | Test Loss=0.002196625 | Time=1.48s | LR=9.77e-08\n",
      "Epoch [727/1000] | Train Loss=0.000190697 | Test Loss=0.002197547 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [728/1000] | Train Loss=0.000192486 | Test Loss=0.002196513 | Time=1.50s | LR=9.77e-08\n",
      "Epoch [729/1000] | Train Loss=0.000189676 | Test Loss=0.002194996 | Time=1.42s | LR=9.77e-08\n",
      "Epoch [730/1000] | Train Loss=0.000192465 | Test Loss=0.002195328 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [731/1000] | Train Loss=0.000190257 | Test Loss=0.002194887 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [732/1000] | Train Loss=0.000189094 | Test Loss=0.002195363 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [733/1000] | Train Loss=0.000191008 | Test Loss=0.002192977 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [734/1000] | Train Loss=0.000190859 | Test Loss=0.002194002 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [735/1000] | Train Loss=0.000191009 | Test Loss=0.002192490 | Time=1.32s | LR=9.77e-08\n",
      "Epoch [736/1000] | Train Loss=0.000190846 | Test Loss=0.002196901 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [737/1000] | Train Loss=0.000191031 | Test Loss=0.002197340 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [738/1000] | Train Loss=0.000192445 | Test Loss=0.002195249 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [739/1000] | Train Loss=0.000188695 | Test Loss=0.002195381 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [740/1000] | Train Loss=0.000189840 | Test Loss=0.002194328 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [741/1000] | Train Loss=0.000189780 | Test Loss=0.002195119 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [742/1000] | Train Loss=0.000192333 | Test Loss=0.002193865 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [743/1000] | Train Loss=0.000189754 | Test Loss=0.002196141 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [744/1000] | Train Loss=0.000193458 | Test Loss=0.002197646 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [745/1000] | Train Loss=0.000191633 | Test Loss=0.002198097 | Time=1.25s | LR=9.77e-08\n",
      "Epoch [746/1000] | Train Loss=0.000190530 | Test Loss=0.002197744 | Time=1.22s | LR=9.77e-08\n",
      "Epoch [747/1000] | Train Loss=0.000189935 | Test Loss=0.002195451 | Time=1.29s | LR=9.77e-08\n",
      "Epoch [748/1000] | Train Loss=0.000189782 | Test Loss=0.002200046 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [749/1000] | Train Loss=0.000190982 | Test Loss=0.002196647 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [750/1000] | Train Loss=0.000190722 | Test Loss=0.002198536 | Time=1.21s | LR=9.77e-08\n",
      "Epoch [751/1000] | Train Loss=0.000189744 | Test Loss=0.002194059 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [752/1000] | Train Loss=0.000190600 | Test Loss=0.002197864 | Time=1.25s | LR=9.77e-08\n",
      "Epoch [753/1000] | Train Loss=0.000190832 | Test Loss=0.002196085 | Time=1.62s | LR=9.77e-08\n",
      "Epoch [754/1000] | Train Loss=0.000192133 | Test Loss=0.002197050 | Time=1.27s | LR=9.77e-08\n",
      "Epoch [755/1000] | Train Loss=0.000190634 | Test Loss=0.002197657 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [756/1000] | Train Loss=0.000193462 | Test Loss=0.002197400 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [757/1000] | Train Loss=0.000191965 | Test Loss=0.002196961 | Time=1.28s | LR=9.77e-08\n",
      "Epoch [758/1000] | Train Loss=0.000189379 | Test Loss=0.002199369 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [759/1000] | Train Loss=0.000190408 | Test Loss=0.002199866 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [760/1000] | Train Loss=0.000189786 | Test Loss=0.002197579 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [761/1000] | Train Loss=0.000190502 | Test Loss=0.002197932 | Time=1.26s | LR=9.77e-08\n",
      "Epoch [762/1000] | Train Loss=0.000192321 | Test Loss=0.002199352 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [763/1000] | Train Loss=0.000190011 | Test Loss=0.002196501 | Time=1.21s | LR=9.77e-08\n",
      "Epoch [764/1000] | Train Loss=0.000193684 | Test Loss=0.002197509 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [765/1000] | Train Loss=0.000190243 | Test Loss=0.002198171 | Time=1.25s | LR=9.77e-08\n",
      "Epoch [766/1000] | Train Loss=0.000191405 | Test Loss=0.002195893 | Time=1.23s | LR=9.77e-08\n",
      "Epoch [767/1000] | Train Loss=0.000193705 | Test Loss=0.002194920 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [768/1000] | Train Loss=0.000189963 | Test Loss=0.002196272 | Time=1.27s | LR=9.77e-08\n",
      "Epoch [769/1000] | Train Loss=0.000191327 | Test Loss=0.002196358 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [770/1000] | Train Loss=0.000190141 | Test Loss=0.002195531 | Time=1.22s | LR=9.77e-08\n",
      "Epoch [771/1000] | Train Loss=0.000192865 | Test Loss=0.002196837 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [772/1000] | Train Loss=0.000190954 | Test Loss=0.002195993 | Time=1.26s | LR=9.77e-08\n",
      "Epoch [773/1000] | Train Loss=0.000191344 | Test Loss=0.002195027 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [774/1000] | Train Loss=0.000189139 | Test Loss=0.002197664 | Time=1.21s | LR=9.77e-08\n",
      "Epoch [775/1000] | Train Loss=0.000193389 | Test Loss=0.002196675 | Time=1.30s | LR=9.77e-08\n",
      "Epoch [776/1000] | Train Loss=0.000190878 | Test Loss=0.002194426 | Time=1.25s | LR=9.77e-08\n",
      "Epoch [777/1000] | Train Loss=0.000193455 | Test Loss=0.002196371 | Time=1.33s | LR=9.77e-08\n",
      "Epoch [778/1000] | Train Loss=0.000190200 | Test Loss=0.002196589 | Time=1.52s | LR=9.77e-08\n",
      "Epoch [779/1000] | Train Loss=0.000190643 | Test Loss=0.002194085 | Time=1.25s | LR=9.77e-08\n",
      "Epoch [780/1000] | Train Loss=0.000188570 | Test Loss=0.002193265 | Time=1.22s | LR=9.77e-08\n",
      "Epoch [781/1000] | Train Loss=0.000190647 | Test Loss=0.002195558 | Time=1.29s | LR=9.77e-08\n",
      "Epoch [782/1000] | Train Loss=0.000191821 | Test Loss=0.002195148 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [783/1000] | Train Loss=0.000190319 | Test Loss=0.002194850 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [784/1000] | Train Loss=0.000190196 | Test Loss=0.002195876 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [785/1000] | Train Loss=0.000189412 | Test Loss=0.002196337 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [786/1000] | Train Loss=0.000190212 | Test Loss=0.002195851 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [787/1000] | Train Loss=0.000188747 | Test Loss=0.002195736 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [788/1000] | Train Loss=0.000191214 | Test Loss=0.002194941 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [789/1000] | Train Loss=0.000189849 | Test Loss=0.002196712 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [790/1000] | Train Loss=0.000190172 | Test Loss=0.002195920 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [791/1000] | Train Loss=0.000189581 | Test Loss=0.002196846 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [792/1000] | Train Loss=0.000190399 | Test Loss=0.002194767 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [793/1000] | Train Loss=0.000191315 | Test Loss=0.002194336 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [794/1000] | Train Loss=0.000191627 | Test Loss=0.002193417 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [795/1000] | Train Loss=0.000190684 | Test Loss=0.002192420 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [796/1000] | Train Loss=0.000193550 | Test Loss=0.002193600 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [797/1000] | Train Loss=0.000190258 | Test Loss=0.002194332 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [798/1000] | Train Loss=0.000190141 | Test Loss=0.002195279 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [799/1000] | Train Loss=0.000188518 | Test Loss=0.002193939 | Time=1.49s | LR=9.77e-08\n",
      "Epoch [800/1000] | Train Loss=0.000189525 | Test Loss=0.002190583 | Time=1.57s | LR=9.77e-08\n",
      "Epoch [801/1000] | Train Loss=0.000191738 | Test Loss=0.002192196 | Time=1.56s | LR=9.77e-08\n",
      "Epoch [802/1000] | Train Loss=0.000189217 | Test Loss=0.002190692 | Time=1.40s | LR=9.77e-08\n",
      "Epoch [803/1000] | Train Loss=0.000190050 | Test Loss=0.002193746 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [804/1000] | Train Loss=0.000193043 | Test Loss=0.002193506 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [805/1000] | Train Loss=0.000189609 | Test Loss=0.002191377 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [806/1000] | Train Loss=0.000188675 | Test Loss=0.002192893 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [807/1000] | Train Loss=0.000189859 | Test Loss=0.002191370 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [808/1000] | Train Loss=0.000189327 | Test Loss=0.002193359 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [809/1000] | Train Loss=0.000190922 | Test Loss=0.002191615 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [810/1000] | Train Loss=0.000193284 | Test Loss=0.002192126 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [811/1000] | Train Loss=0.000188486 | Test Loss=0.002193161 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [812/1000] | Train Loss=0.000192369 | Test Loss=0.002194655 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [813/1000] | Train Loss=0.000189110 | Test Loss=0.002195278 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [814/1000] | Train Loss=0.000193262 | Test Loss=0.002193116 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [815/1000] | Train Loss=0.000189937 | Test Loss=0.002193543 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [816/1000] | Train Loss=0.000190946 | Test Loss=0.002196254 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [817/1000] | Train Loss=0.000191713 | Test Loss=0.002195411 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [818/1000] | Train Loss=0.000188497 | Test Loss=0.002195973 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [819/1000] | Train Loss=0.000191772 | Test Loss=0.002194717 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [820/1000] | Train Loss=0.000190934 | Test Loss=0.002193070 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [821/1000] | Train Loss=0.000189107 | Test Loss=0.002193876 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [822/1000] | Train Loss=0.000189860 | Test Loss=0.002192430 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [823/1000] | Train Loss=0.000191500 | Test Loss=0.002193262 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [824/1000] | Train Loss=0.000189311 | Test Loss=0.002196643 | Time=1.48s | LR=9.77e-08\n",
      "Epoch [825/1000] | Train Loss=0.000190134 | Test Loss=0.002195498 | Time=1.48s | LR=9.77e-08\n",
      "Epoch [826/1000] | Train Loss=0.000190092 | Test Loss=0.002196433 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [827/1000] | Train Loss=0.000190548 | Test Loss=0.002195365 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [828/1000] | Train Loss=0.000190459 | Test Loss=0.002194072 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [829/1000] | Train Loss=0.000188889 | Test Loss=0.002195237 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [830/1000] | Train Loss=0.000189617 | Test Loss=0.002194160 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [831/1000] | Train Loss=0.000189880 | Test Loss=0.002195658 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [832/1000] | Train Loss=0.000191965 | Test Loss=0.002195532 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [833/1000] | Train Loss=0.000188932 | Test Loss=0.002193885 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [834/1000] | Train Loss=0.000191591 | Test Loss=0.002194001 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [835/1000] | Train Loss=0.000189718 | Test Loss=0.002193451 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [836/1000] | Train Loss=0.000190530 | Test Loss=0.002197425 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [837/1000] | Train Loss=0.000191517 | Test Loss=0.002195540 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [838/1000] | Train Loss=0.000189286 | Test Loss=0.002193087 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [839/1000] | Train Loss=0.000188394 | Test Loss=0.002191479 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [840/1000] | Train Loss=0.000189860 | Test Loss=0.002193708 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [841/1000] | Train Loss=0.000189167 | Test Loss=0.002195271 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [842/1000] | Train Loss=0.000188782 | Test Loss=0.002194204 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [843/1000] | Train Loss=0.000190114 | Test Loss=0.002193728 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [844/1000] | Train Loss=0.000189156 | Test Loss=0.002193949 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [845/1000] | Train Loss=0.000189935 | Test Loss=0.002193507 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [846/1000] | Train Loss=0.000192221 | Test Loss=0.002193112 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [847/1000] | Train Loss=0.000190044 | Test Loss=0.002194575 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [848/1000] | Train Loss=0.000188328 | Test Loss=0.002194451 | Time=1.61s | LR=9.77e-08\n",
      "Epoch [849/1000] | Train Loss=0.000187426 | Test Loss=0.002194105 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [850/1000] | Train Loss=0.000191316 | Test Loss=0.002195843 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [851/1000] | Train Loss=0.000190342 | Test Loss=0.002195545 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [852/1000] | Train Loss=0.000189314 | Test Loss=0.002191514 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [853/1000] | Train Loss=0.000192536 | Test Loss=0.002191661 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [854/1000] | Train Loss=0.000192077 | Test Loss=0.002193961 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [855/1000] | Train Loss=0.000190209 | Test Loss=0.002196550 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [856/1000] | Train Loss=0.000191094 | Test Loss=0.002193994 | Time=1.50s | LR=9.77e-08\n",
      "Epoch [857/1000] | Train Loss=0.000189444 | Test Loss=0.002194641 | Time=1.50s | LR=9.77e-08\n",
      "Epoch [858/1000] | Train Loss=0.000188513 | Test Loss=0.002195256 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [859/1000] | Train Loss=0.000189485 | Test Loss=0.002197147 | Time=1.37s | LR=9.77e-08\n",
      "Epoch [860/1000] | Train Loss=0.000190297 | Test Loss=0.002195806 | Time=1.37s | LR=9.77e-08\n",
      "Epoch [861/1000] | Train Loss=0.000189485 | Test Loss=0.002195494 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [862/1000] | Train Loss=0.000190671 | Test Loss=0.002194771 | Time=1.21s | LR=9.77e-08\n",
      "Epoch [863/1000] | Train Loss=0.000188625 | Test Loss=0.002193344 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [864/1000] | Train Loss=0.000190802 | Test Loss=0.002197837 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [865/1000] | Train Loss=0.000188953 | Test Loss=0.002195254 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [866/1000] | Train Loss=0.000191302 | Test Loss=0.002195112 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [867/1000] | Train Loss=0.000191347 | Test Loss=0.002194850 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [868/1000] | Train Loss=0.000190901 | Test Loss=0.002196020 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [869/1000] | Train Loss=0.000188814 | Test Loss=0.002192296 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [870/1000] | Train Loss=0.000189773 | Test Loss=0.002198282 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [871/1000] | Train Loss=0.000189829 | Test Loss=0.002197230 | Time=1.54s | LR=9.77e-08\n",
      "Epoch [872/1000] | Train Loss=0.000190413 | Test Loss=0.002197543 | Time=1.42s | LR=9.77e-08\n",
      "Epoch [873/1000] | Train Loss=0.000188825 | Test Loss=0.002194737 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [874/1000] | Train Loss=0.000187838 | Test Loss=0.002196208 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [875/1000] | Train Loss=0.000190447 | Test Loss=0.002197231 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [876/1000] | Train Loss=0.000190194 | Test Loss=0.002193578 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [877/1000] | Train Loss=0.000192099 | Test Loss=0.002195118 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [878/1000] | Train Loss=0.000192002 | Test Loss=0.002197584 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [879/1000] | Train Loss=0.000192013 | Test Loss=0.002194888 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [880/1000] | Train Loss=0.000190918 | Test Loss=0.002195472 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [881/1000] | Train Loss=0.000190644 | Test Loss=0.002195642 | Time=1.37s | LR=9.77e-08\n",
      "Epoch [882/1000] | Train Loss=0.000188487 | Test Loss=0.002195282 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [883/1000] | Train Loss=0.000189962 | Test Loss=0.002195866 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [884/1000] | Train Loss=0.000191195 | Test Loss=0.002194403 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [885/1000] | Train Loss=0.000190874 | Test Loss=0.002193920 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [886/1000] | Train Loss=0.000190503 | Test Loss=0.002196898 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [887/1000] | Train Loss=0.000188570 | Test Loss=0.002197772 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [888/1000] | Train Loss=0.000192542 | Test Loss=0.002193709 | Time=1.36s | LR=9.77e-08\n",
      "Epoch [889/1000] | Train Loss=0.000188591 | Test Loss=0.002193945 | Time=1.35s | LR=9.77e-08\n",
      "Epoch [890/1000] | Train Loss=0.000189322 | Test Loss=0.002194574 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [891/1000] | Train Loss=0.000192238 | Test Loss=0.002195153 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [892/1000] | Train Loss=0.000189813 | Test Loss=0.002195705 | Time=1.37s | LR=4.88e-08\n",
      "Epoch [893/1000] | Train Loss=0.000188107 | Test Loss=0.002195380 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [894/1000] | Train Loss=0.000190962 | Test Loss=0.002193079 | Time=1.46s | LR=4.88e-08\n",
      "Epoch [895/1000] | Train Loss=0.000191484 | Test Loss=0.002195413 | Time=1.49s | LR=4.88e-08\n",
      "Epoch [896/1000] | Train Loss=0.000188895 | Test Loss=0.002193714 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [897/1000] | Train Loss=0.000189595 | Test Loss=0.002193369 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [898/1000] | Train Loss=0.000191121 | Test Loss=0.002196056 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [899/1000] | Train Loss=0.000190042 | Test Loss=0.002197059 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [900/1000] | Train Loss=0.000189690 | Test Loss=0.002197696 | Time=1.21s | LR=4.88e-08\n",
      "Epoch [901/1000] | Train Loss=0.000190670 | Test Loss=0.002194766 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [902/1000] | Train Loss=0.000188722 | Test Loss=0.002195983 | Time=1.35s | LR=4.88e-08\n",
      "Epoch [903/1000] | Train Loss=0.000189702 | Test Loss=0.002196158 | Time=1.28s | LR=4.88e-08\n",
      "Epoch [904/1000] | Train Loss=0.000191066 | Test Loss=0.002193602 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [905/1000] | Train Loss=0.000190469 | Test Loss=0.002195760 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [906/1000] | Train Loss=0.000191768 | Test Loss=0.002193589 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [907/1000] | Train Loss=0.000190614 | Test Loss=0.002198254 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [908/1000] | Train Loss=0.000190710 | Test Loss=0.002196216 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [909/1000] | Train Loss=0.000191875 | Test Loss=0.002194733 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [910/1000] | Train Loss=0.000189600 | Test Loss=0.002195891 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [911/1000] | Train Loss=0.000190173 | Test Loss=0.002195305 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [912/1000] | Train Loss=0.000190165 | Test Loss=0.002195892 | Time=1.37s | LR=4.88e-08\n",
      "Epoch [913/1000] | Train Loss=0.000190389 | Test Loss=0.002196986 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [914/1000] | Train Loss=0.000190438 | Test Loss=0.002195042 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [915/1000] | Train Loss=0.000191167 | Test Loss=0.002195408 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [916/1000] | Train Loss=0.000191009 | Test Loss=0.002197395 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [917/1000] | Train Loss=0.000192241 | Test Loss=0.002197643 | Time=1.49s | LR=4.88e-08\n",
      "Epoch [918/1000] | Train Loss=0.000192423 | Test Loss=0.002193144 | Time=1.62s | LR=4.88e-08\n",
      "Epoch [919/1000] | Train Loss=0.000191503 | Test Loss=0.002194780 | Time=1.38s | LR=4.88e-08\n",
      "Epoch [920/1000] | Train Loss=0.000188541 | Test Loss=0.002196558 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [921/1000] | Train Loss=0.000190410 | Test Loss=0.002194925 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [922/1000] | Train Loss=0.000189659 | Test Loss=0.002194799 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [923/1000] | Train Loss=0.000191682 | Test Loss=0.002193816 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [924/1000] | Train Loss=0.000190317 | Test Loss=0.002195499 | Time=1.35s | LR=4.88e-08\n",
      "Epoch [925/1000] | Train Loss=0.000189846 | Test Loss=0.002198753 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [926/1000] | Train Loss=0.000189970 | Test Loss=0.002197063 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [927/1000] | Train Loss=0.000190363 | Test Loss=0.002199034 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [928/1000] | Train Loss=0.000190906 | Test Loss=0.002200373 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [929/1000] | Train Loss=0.000189312 | Test Loss=0.002198043 | Time=1.36s | LR=4.88e-08\n",
      "Epoch [930/1000] | Train Loss=0.000190956 | Test Loss=0.002196893 | Time=1.21s | LR=4.88e-08\n",
      "Epoch [931/1000] | Train Loss=0.000189232 | Test Loss=0.002198635 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [932/1000] | Train Loss=0.000189680 | Test Loss=0.002198891 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [933/1000] | Train Loss=0.000190775 | Test Loss=0.002201199 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [934/1000] | Train Loss=0.000190914 | Test Loss=0.002198064 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [935/1000] | Train Loss=0.000189405 | Test Loss=0.002199156 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [936/1000] | Train Loss=0.000189876 | Test Loss=0.002198743 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [937/1000] | Train Loss=0.000191110 | Test Loss=0.002196525 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [938/1000] | Train Loss=0.000193475 | Test Loss=0.002198616 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [939/1000] | Train Loss=0.000192234 | Test Loss=0.002197480 | Time=1.21s | LR=2.44e-08\n",
      "Epoch [940/1000] | Train Loss=0.000190501 | Test Loss=0.002196877 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [941/1000] | Train Loss=0.000189937 | Test Loss=0.002197812 | Time=1.44s | LR=2.44e-08\n",
      "Epoch [942/1000] | Train Loss=0.000190992 | Test Loss=0.002198559 | Time=1.52s | LR=2.44e-08\n",
      "Epoch [943/1000] | Train Loss=0.000190381 | Test Loss=0.002197797 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [944/1000] | Train Loss=0.000193132 | Test Loss=0.002198545 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [945/1000] | Train Loss=0.000192971 | Test Loss=0.002195202 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [946/1000] | Train Loss=0.000190518 | Test Loss=0.002196654 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [947/1000] | Train Loss=0.000187850 | Test Loss=0.002198399 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [948/1000] | Train Loss=0.000188431 | Test Loss=0.002197555 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [949/1000] | Train Loss=0.000192954 | Test Loss=0.002195885 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [950/1000] | Train Loss=0.000189529 | Test Loss=0.002198363 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [951/1000] | Train Loss=0.000189481 | Test Loss=0.002198908 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [952/1000] | Train Loss=0.000191297 | Test Loss=0.002196827 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [953/1000] | Train Loss=0.000192367 | Test Loss=0.002197181 | Time=1.35s | LR=2.44e-08\n",
      "Epoch [954/1000] | Train Loss=0.000188838 | Test Loss=0.002197391 | Time=1.21s | LR=2.44e-08\n",
      "Epoch [955/1000] | Train Loss=0.000192160 | Test Loss=0.002197761 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [956/1000] | Train Loss=0.000190429 | Test Loss=0.002196516 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [957/1000] | Train Loss=0.000189946 | Test Loss=0.002196981 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [958/1000] | Train Loss=0.000190360 | Test Loss=0.002198153 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [959/1000] | Train Loss=0.000190248 | Test Loss=0.002199107 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [960/1000] | Train Loss=0.000190403 | Test Loss=0.002198601 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [961/1000] | Train Loss=0.000190273 | Test Loss=0.002197649 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [962/1000] | Train Loss=0.000189977 | Test Loss=0.002198310 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [963/1000] | Train Loss=0.000188451 | Test Loss=0.002197982 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [964/1000] | Train Loss=0.000190321 | Test Loss=0.002198564 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [965/1000] | Train Loss=0.000189913 | Test Loss=0.002199153 | Time=1.55s | LR=2.44e-08\n",
      "Epoch [966/1000] | Train Loss=0.000190463 | Test Loss=0.002199076 | Time=1.41s | LR=2.44e-08\n",
      "Epoch [967/1000] | Train Loss=0.000189485 | Test Loss=0.002198073 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [968/1000] | Train Loss=0.000192239 | Test Loss=0.002198856 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [969/1000] | Train Loss=0.000191369 | Test Loss=0.002197803 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [970/1000] | Train Loss=0.000192917 | Test Loss=0.002197095 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [971/1000] | Train Loss=0.000193260 | Test Loss=0.002197247 | Time=1.36s | LR=2.44e-08\n",
      "Epoch [972/1000] | Train Loss=0.000190611 | Test Loss=0.002196214 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [973/1000] | Train Loss=0.000189684 | Test Loss=0.002196319 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [974/1000] | Train Loss=0.000190780 | Test Loss=0.002197023 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [975/1000] | Train Loss=0.000190363 | Test Loss=0.002195633 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [976/1000] | Train Loss=0.000192969 | Test Loss=0.002197266 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [977/1000] | Train Loss=0.000190194 | Test Loss=0.002196766 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [978/1000] | Train Loss=0.000189270 | Test Loss=0.002197584 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [979/1000] | Train Loss=0.000189899 | Test Loss=0.002197705 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [980/1000] | Train Loss=0.000190339 | Test Loss=0.002199029 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [981/1000] | Train Loss=0.000188371 | Test Loss=0.002197036 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [982/1000] | Train Loss=0.000190085 | Test Loss=0.002197616 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [983/1000] | Train Loss=0.000190856 | Test Loss=0.002198651 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [984/1000] | Train Loss=0.000190915 | Test Loss=0.002196933 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [985/1000] | Train Loss=0.000190713 | Test Loss=0.002197476 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [986/1000] | Train Loss=0.000191368 | Test Loss=0.002197734 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [987/1000] | Train Loss=0.000191286 | Test Loss=0.002197417 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [988/1000] | Train Loss=0.000193487 | Test Loss=0.002196591 | Time=1.47s | LR=1.22e-08\n",
      "Epoch [989/1000] | Train Loss=0.000189777 | Test Loss=0.002197746 | Time=1.49s | LR=1.22e-08\n",
      "Epoch [990/1000] | Train Loss=0.000188376 | Test Loss=0.002195958 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [991/1000] | Train Loss=0.000190838 | Test Loss=0.002198138 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [992/1000] | Train Loss=0.000191462 | Test Loss=0.002196756 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [993/1000] | Train Loss=0.000191431 | Test Loss=0.002197652 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [994/1000] | Train Loss=0.000193133 | Test Loss=0.002197771 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [995/1000] | Train Loss=0.000189458 | Test Loss=0.002197914 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [996/1000] | Train Loss=0.000189322 | Test Loss=0.002196061 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [997/1000] | Train Loss=0.000191013 | Test Loss=0.002195882 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [998/1000] | Train Loss=0.000192259 | Test Loss=0.002195542 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [999/1000] | Train Loss=0.000193281 | Test Loss=0.002195904 | Time=1.36s | LR=1.22e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000191767 | Test Loss=0.002197496 | Time=1.36s | LR=1.22e-08\n",
      "\n",
      "Total training time: 1442.85 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "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_G1.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00008317\n",
      "Function type: periodic             | Relative L2: 0.00021067\n",
      "Function type: sine_beats           | Relative L2: 0.00026015\n",
      "\n",
      "Overall relative L2 error: 0.00010791\n",
      "--------------test----------------\n",
      "Function type: gaussian_hermite     | Relative L2: 0.00292159\n",
      "Function type: sinc_pulse           | Relative L2: 0.00309909\n",
      "Function type: wave_packet          | Relative L2: 0.00205724\n",
      "\n",
      "Overall relative L2 error: 0.00208966\n",
      "-------------sample----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00010315\n",
      "Function type: periodic             | Relative L2: 0.00021371\n",
      "Function type: sine_beats           | Relative L2: 0.00029950\n",
      "\n",
      "Overall relative L2 error: 0.00012822\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
}
