{
 "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": 3,
   "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": 4,
   "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": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = convert_dataset_for_fno(torch.load('train_2.pt', weights_only=False))\n",
    "test_data = convert_dataset_for_fno(torch.load('test_2.pt', weights_only=False))\n",
    "sample_data = convert_dataset_for_fno(torch.load('sample_2.pt', weights_only=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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:0'\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": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:0\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.273884984 | Test Loss=0.089891354 | Time=2.06s | LR=1.00e-03\n",
      "Epoch [2/1000] | Train Loss=0.043727175 | Test Loss=0.040908604 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [3/1000] | Train Loss=0.033324121 | Test Loss=0.056041273 | Time=1.76s | LR=1.00e-03\n",
      "Epoch [4/1000] | Train Loss=0.040286544 | Test Loss=0.059565036 | Time=1.69s | LR=1.00e-03\n",
      "Epoch [5/1000] | Train Loss=0.035907667 | Test Loss=0.034558517 | Time=1.67s | LR=1.00e-03\n",
      "Epoch [6/1000] | Train Loss=0.035218050 | Test Loss=0.031827692 | Time=1.65s | LR=1.00e-03\n",
      "Epoch [7/1000] | Train Loss=0.031022328 | Test Loss=0.026245229 | Time=1.81s | LR=1.00e-03\n",
      "Epoch [8/1000] | Train Loss=0.035663591 | Test Loss=0.049081399 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [9/1000] | Train Loss=0.035891791 | Test Loss=0.063174899 | Time=1.84s | LR=1.00e-03\n",
      "Epoch [10/1000] | Train Loss=0.032931362 | Test Loss=0.044975027 | Time=1.80s | LR=1.00e-03\n",
      "Epoch [11/1000] | Train Loss=0.035944969 | Test Loss=0.073454139 | Time=1.82s | LR=1.00e-03\n",
      "Epoch [12/1000] | Train Loss=0.037150533 | Test Loss=0.059079590 | Time=1.77s | LR=1.00e-03\n",
      "Epoch [13/1000] | Train Loss=0.033880205 | Test Loss=0.023060092 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [14/1000] | Train Loss=0.033655865 | Test Loss=0.080030572 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [15/1000] | Train Loss=0.026287170 | Test Loss=0.041567136 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [16/1000] | Train Loss=0.027220433 | Test Loss=0.019393762 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [17/1000] | Train Loss=0.030717339 | Test Loss=0.019046096 | Time=1.33s | LR=1.00e-03\n",
      "Epoch [18/1000] | Train Loss=0.020625862 | Test Loss=0.024703342 | Time=1.52s | LR=1.00e-03\n",
      "Epoch [19/1000] | Train Loss=0.028063361 | Test Loss=0.027509057 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [20/1000] | Train Loss=0.025619589 | Test Loss=0.036293050 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [21/1000] | Train Loss=0.025885616 | Test Loss=0.057200858 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [22/1000] | Train Loss=0.046894221 | Test Loss=0.037090154 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [23/1000] | Train Loss=0.036829536 | Test Loss=0.075885958 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [24/1000] | Train Loss=0.037031386 | Test Loss=0.042114417 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [25/1000] | Train Loss=0.032954968 | Test Loss=0.038054555 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [26/1000] | Train Loss=0.030959077 | Test Loss=0.033888585 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [27/1000] | Train Loss=0.032580529 | Test Loss=0.037784276 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [28/1000] | Train Loss=0.030329702 | Test Loss=0.045132239 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [29/1000] | Train Loss=0.019997011 | Test Loss=0.022906225 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [30/1000] | Train Loss=0.029314131 | Test Loss=0.022812747 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [31/1000] | Train Loss=0.032984507 | Test Loss=0.037249661 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [32/1000] | Train Loss=0.024247977 | Test Loss=0.018282163 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [33/1000] | Train Loss=0.024257811 | Test Loss=0.028109808 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [34/1000] | Train Loss=0.025961683 | Test Loss=0.077871493 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [35/1000] | Train Loss=0.024479819 | Test Loss=0.033000588 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [36/1000] | Train Loss=0.035200146 | Test Loss=0.020375301 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [37/1000] | Train Loss=0.022444957 | Test Loss=0.042166720 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [38/1000] | Train Loss=0.020726364 | Test Loss=0.016577804 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [39/1000] | Train Loss=0.026368991 | Test Loss=0.031447627 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [40/1000] | Train Loss=0.027447334 | Test Loss=0.025261198 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [41/1000] | Train Loss=0.026740027 | Test Loss=0.044752824 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [42/1000] | Train Loss=0.032231119 | Test Loss=0.015635987 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [43/1000] | Train Loss=0.024053922 | Test Loss=0.048630699 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [44/1000] | Train Loss=0.025994820 | Test Loss=0.020554309 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [45/1000] | Train Loss=0.039797371 | Test Loss=0.029469210 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [46/1000] | Train Loss=0.023286944 | Test Loss=0.040956023 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [47/1000] | Train Loss=0.021478805 | Test Loss=0.028852764 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [48/1000] | Train Loss=0.029925169 | Test Loss=0.028678683 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [49/1000] | Train Loss=0.021987204 | Test Loss=0.011839861 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [50/1000] | Train Loss=0.023271943 | Test Loss=0.029062456 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [51/1000] | Train Loss=0.026127608 | Test Loss=0.064986084 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [52/1000] | Train Loss=0.025503872 | Test Loss=0.039991986 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [53/1000] | Train Loss=0.028981373 | Test Loss=0.023127945 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [54/1000] | Train Loss=0.019315002 | Test Loss=0.026365768 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [55/1000] | Train Loss=0.021514243 | Test Loss=0.036926099 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [56/1000] | Train Loss=0.030247541 | Test Loss=0.026947394 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [57/1000] | Train Loss=0.021468633 | Test Loss=0.014594667 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [58/1000] | Train Loss=0.020691818 | Test Loss=0.015848959 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [59/1000] | Train Loss=0.019309351 | Test Loss=0.027754242 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [60/1000] | Train Loss=0.019155280 | Test Loss=0.021771994 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [61/1000] | Train Loss=0.017414235 | Test Loss=0.036402078 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [62/1000] | Train Loss=0.020975339 | Test Loss=0.032184417 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [63/1000] | Train Loss=0.022045957 | Test Loss=0.039468556 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [64/1000] | Train Loss=0.018148412 | Test Loss=0.012732065 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [65/1000] | Train Loss=0.017816447 | Test Loss=0.064909151 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [66/1000] | Train Loss=0.018865486 | Test Loss=0.011995012 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [67/1000] | Train Loss=0.021365915 | Test Loss=0.024217041 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [68/1000] | Train Loss=0.017193332 | Test Loss=0.016291861 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [69/1000] | Train Loss=0.027914361 | Test Loss=0.014938087 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [70/1000] | Train Loss=0.021425062 | Test Loss=0.019782403 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [71/1000] | Train Loss=0.020569353 | Test Loss=0.024787222 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [72/1000] | Train Loss=0.020124356 | Test Loss=0.017783835 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [73/1000] | Train Loss=0.023547428 | Test Loss=0.028190734 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [74/1000] | Train Loss=0.019941827 | Test Loss=0.034569497 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [75/1000] | Train Loss=0.025302409 | Test Loss=0.017606399 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [76/1000] | Train Loss=0.028703220 | Test Loss=0.022460815 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [77/1000] | Train Loss=0.021713144 | Test Loss=0.020178843 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [78/1000] | Train Loss=0.019497196 | Test Loss=0.017352179 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [79/1000] | Train Loss=0.018491246 | Test Loss=0.023399758 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [80/1000] | Train Loss=0.017624149 | Test Loss=0.021060345 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [81/1000] | Train Loss=0.020472205 | Test Loss=0.017157253 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [82/1000] | Train Loss=0.018002523 | Test Loss=0.021786418 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [83/1000] | Train Loss=0.020494279 | Test Loss=0.014270357 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [84/1000] | Train Loss=0.031662188 | Test Loss=0.029668249 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [85/1000] | Train Loss=0.017565115 | Test Loss=0.028157482 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [86/1000] | Train Loss=0.015165406 | Test Loss=0.019806562 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [87/1000] | Train Loss=0.023148712 | Test Loss=0.028523339 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [88/1000] | Train Loss=0.026644911 | Test Loss=0.018080467 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [89/1000] | Train Loss=0.023895647 | Test Loss=0.015387434 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [90/1000] | Train Loss=0.021010329 | Test Loss=0.012873498 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [91/1000] | Train Loss=0.018985905 | Test Loss=0.019399360 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [92/1000] | Train Loss=0.017528562 | Test Loss=0.021907964 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [93/1000] | Train Loss=0.016954090 | Test Loss=0.022723988 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [94/1000] | Train Loss=0.015102874 | Test Loss=0.013755849 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [95/1000] | Train Loss=0.023920544 | Test Loss=0.041527846 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [96/1000] | Train Loss=0.019219816 | Test Loss=0.026181598 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [97/1000] | Train Loss=0.016977938 | Test Loss=0.014128569 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [98/1000] | Train Loss=0.017537928 | Test Loss=0.022281245 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [99/1000] | Train Loss=0.017314179 | Test Loss=0.018280930 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [100/1000] | Train Loss=0.016747999 | Test Loss=0.013803051 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [101/1000] | Train Loss=0.016985914 | Test Loss=0.012721449 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [102/1000] | Train Loss=0.016250740 | Test Loss=0.014976164 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [103/1000] | Train Loss=0.020477177 | Test Loss=0.026218593 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [104/1000] | Train Loss=0.016728927 | Test Loss=0.023957116 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [105/1000] | Train Loss=0.018379778 | Test Loss=0.013727259 | Time=1.75s | LR=1.00e-03\n",
      "Epoch [106/1000] | Train Loss=0.011138174 | Test Loss=0.008942988 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [107/1000] | Train Loss=0.015070899 | Test Loss=0.014336763 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [108/1000] | Train Loss=0.016651721 | Test Loss=0.020368466 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [109/1000] | Train Loss=0.018151786 | Test Loss=0.026982178 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [110/1000] | Train Loss=0.016885682 | Test Loss=0.015578503 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [111/1000] | Train Loss=0.011929098 | Test Loss=0.010740741 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [112/1000] | Train Loss=0.020395371 | Test Loss=0.008606588 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [113/1000] | Train Loss=0.016654246 | Test Loss=0.011170220 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [114/1000] | Train Loss=0.019258968 | Test Loss=0.029274523 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [115/1000] | Train Loss=0.015778168 | Test Loss=0.019655720 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [116/1000] | Train Loss=0.019054349 | Test Loss=0.041883875 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [117/1000] | Train Loss=0.029337620 | Test Loss=0.021477001 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [118/1000] | Train Loss=0.017117311 | Test Loss=0.017274162 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [119/1000] | Train Loss=0.013483518 | Test Loss=0.012982782 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [120/1000] | Train Loss=0.014898085 | Test Loss=0.008759400 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [121/1000] | Train Loss=0.016391474 | Test Loss=0.007883019 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [122/1000] | Train Loss=0.018529884 | Test Loss=0.019572199 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [123/1000] | Train Loss=0.017280107 | Test Loss=0.025128506 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [124/1000] | Train Loss=0.020037072 | Test Loss=0.016337940 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [125/1000] | Train Loss=0.023502810 | Test Loss=0.011331455 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [126/1000] | Train Loss=0.017733742 | Test Loss=0.017678272 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [127/1000] | Train Loss=0.013050061 | Test Loss=0.022610379 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [128/1000] | Train Loss=0.013268878 | Test Loss=0.011726792 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [129/1000] | Train Loss=0.016648379 | Test Loss=0.038193835 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [130/1000] | Train Loss=0.015587928 | Test Loss=0.012735601 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [131/1000] | Train Loss=0.013654519 | Test Loss=0.016187051 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [132/1000] | Train Loss=0.017960194 | Test Loss=0.023937944 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [133/1000] | Train Loss=0.020827998 | Test Loss=0.008668534 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [134/1000] | Train Loss=0.015231697 | Test Loss=0.011224629 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [135/1000] | Train Loss=0.014832419 | Test Loss=0.029127726 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [136/1000] | Train Loss=0.014176656 | Test Loss=0.030703510 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [137/1000] | Train Loss=0.013420384 | Test Loss=0.016495604 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [138/1000] | Train Loss=0.015703482 | Test Loss=0.011819843 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [139/1000] | Train Loss=0.013229861 | Test Loss=0.032355692 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [140/1000] | Train Loss=0.014739401 | Test Loss=0.013479548 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [141/1000] | Train Loss=0.015545126 | Test Loss=0.012318261 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [142/1000] | Train Loss=0.015219280 | Test Loss=0.008588313 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [143/1000] | Train Loss=0.014978423 | Test Loss=0.017081878 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [144/1000] | Train Loss=0.014531669 | Test Loss=0.010658863 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [145/1000] | Train Loss=0.011939242 | Test Loss=0.017595088 | Time=1.74s | LR=1.00e-03\n",
      "Epoch [146/1000] | Train Loss=0.014824141 | Test Loss=0.020645753 | Time=1.73s | LR=1.00e-03\n",
      "Epoch [147/1000] | Train Loss=0.014569809 | Test Loss=0.019197807 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [148/1000] | Train Loss=0.007989389 | Test Loss=0.009748935 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [149/1000] | Train Loss=0.010462959 | Test Loss=0.009016244 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [150/1000] | Train Loss=0.006335203 | Test Loss=0.006719057 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [151/1000] | Train Loss=0.009425890 | Test Loss=0.005415539 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [152/1000] | Train Loss=0.007873197 | Test Loss=0.009201687 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [153/1000] | Train Loss=0.005924167 | Test Loss=0.015569104 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [154/1000] | Train Loss=0.006989746 | Test Loss=0.010185720 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [155/1000] | Train Loss=0.007401684 | Test Loss=0.006002637 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [156/1000] | Train Loss=0.007235037 | Test Loss=0.014166619 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [157/1000] | Train Loss=0.007422633 | Test Loss=0.008185559 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [158/1000] | Train Loss=0.008214299 | Test Loss=0.009097059 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [159/1000] | Train Loss=0.007860596 | Test Loss=0.008230551 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [160/1000] | Train Loss=0.007404346 | Test Loss=0.005413352 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [161/1000] | Train Loss=0.007200684 | Test Loss=0.009965664 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [162/1000] | Train Loss=0.006188268 | Test Loss=0.013237907 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [163/1000] | Train Loss=0.006786552 | Test Loss=0.011558377 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [164/1000] | Train Loss=0.007450354 | Test Loss=0.009768201 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [165/1000] | Train Loss=0.006710940 | Test Loss=0.004996586 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [166/1000] | Train Loss=0.006310446 | Test Loss=0.011675637 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [167/1000] | Train Loss=0.007535798 | Test Loss=0.009033610 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [168/1000] | Train Loss=0.006980155 | Test Loss=0.006174415 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [169/1000] | Train Loss=0.005890747 | Test Loss=0.007163012 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [170/1000] | Train Loss=0.006656020 | Test Loss=0.005239160 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [171/1000] | Train Loss=0.007327633 | Test Loss=0.009693224 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [172/1000] | Train Loss=0.007152875 | Test Loss=0.007580934 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [173/1000] | Train Loss=0.007554853 | Test Loss=0.006206316 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [174/1000] | Train Loss=0.006954444 | Test Loss=0.011689017 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [175/1000] | Train Loss=0.005832519 | Test Loss=0.004469822 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [176/1000] | Train Loss=0.006857874 | Test Loss=0.008204270 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [177/1000] | Train Loss=0.006151927 | Test Loss=0.009974657 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [178/1000] | Train Loss=0.007554421 | Test Loss=0.015232030 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [179/1000] | Train Loss=0.006724211 | Test Loss=0.005811449 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [180/1000] | Train Loss=0.006610231 | Test Loss=0.022711152 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [181/1000] | Train Loss=0.011275289 | Test Loss=0.010745152 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [182/1000] | Train Loss=0.007711157 | Test Loss=0.009931898 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [183/1000] | Train Loss=0.007168329 | Test Loss=0.005971933 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [184/1000] | Train Loss=0.007411083 | Test Loss=0.005832391 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [185/1000] | Train Loss=0.006750036 | Test Loss=0.009262629 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [186/1000] | Train Loss=0.006272899 | Test Loss=0.006221357 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [187/1000] | Train Loss=0.007375297 | Test Loss=0.008013415 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [188/1000] | Train Loss=0.006758392 | Test Loss=0.006149245 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [189/1000] | Train Loss=0.005675767 | Test Loss=0.006197557 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [190/1000] | Train Loss=0.008338874 | Test Loss=0.007868710 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [191/1000] | Train Loss=0.007245186 | Test Loss=0.007954675 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [192/1000] | Train Loss=0.005930753 | Test Loss=0.013176384 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [193/1000] | Train Loss=0.007283932 | Test Loss=0.007914465 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [194/1000] | Train Loss=0.007284603 | Test Loss=0.007450415 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [195/1000] | Train Loss=0.006910810 | Test Loss=0.008539035 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [196/1000] | Train Loss=0.008760866 | Test Loss=0.022202954 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [197/1000] | Train Loss=0.006714548 | Test Loss=0.007401377 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [198/1000] | Train Loss=0.011125306 | Test Loss=0.013923119 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [199/1000] | Train Loss=0.009854507 | Test Loss=0.006151405 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [200/1000] | Train Loss=0.008004936 | Test Loss=0.009127371 | Time=1.75s | LR=5.00e-04\n",
      "Epoch [201/1000] | Train Loss=0.007453290 | Test Loss=0.007278926 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [202/1000] | Train Loss=0.006337008 | Test Loss=0.008927793 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [203/1000] | Train Loss=0.005597017 | Test Loss=0.006991236 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [204/1000] | Train Loss=0.007090214 | Test Loss=0.005835317 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [205/1000] | Train Loss=0.006789569 | Test Loss=0.009206355 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [206/1000] | Train Loss=0.006769556 | Test Loss=0.004109920 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [207/1000] | Train Loss=0.006185674 | Test Loss=0.006400328 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [208/1000] | Train Loss=0.007153215 | Test Loss=0.011308036 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [209/1000] | Train Loss=0.009831403 | Test Loss=0.016725728 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [210/1000] | Train Loss=0.008293363 | Test Loss=0.008807638 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [211/1000] | Train Loss=0.005816569 | Test Loss=0.005932134 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [212/1000] | Train Loss=0.006509702 | Test Loss=0.006154042 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [213/1000] | Train Loss=0.007045505 | Test Loss=0.020547606 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [214/1000] | Train Loss=0.007726366 | Test Loss=0.005890074 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [215/1000] | Train Loss=0.007479198 | Test Loss=0.009667397 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [216/1000] | Train Loss=0.006218410 | Test Loss=0.006418179 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [217/1000] | Train Loss=0.007199778 | Test Loss=0.006965627 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [218/1000] | Train Loss=0.006849132 | Test Loss=0.010871178 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [219/1000] | Train Loss=0.007211663 | Test Loss=0.009519806 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [220/1000] | Train Loss=0.007394181 | Test Loss=0.010185934 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [221/1000] | Train Loss=0.004759125 | Test Loss=0.008505184 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [222/1000] | Train Loss=0.007258513 | Test Loss=0.007962113 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [223/1000] | Train Loss=0.006706544 | Test Loss=0.006037956 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [224/1000] | Train Loss=0.008294670 | Test Loss=0.011852033 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [225/1000] | Train Loss=0.009279357 | Test Loss=0.015525777 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [226/1000] | Train Loss=0.006724323 | Test Loss=0.006244882 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [227/1000] | Train Loss=0.006361849 | Test Loss=0.010735688 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [228/1000] | Train Loss=0.006695765 | Test Loss=0.009057428 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [229/1000] | Train Loss=0.006061569 | Test Loss=0.015855262 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [230/1000] | Train Loss=0.007409686 | Test Loss=0.011670814 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [231/1000] | Train Loss=0.007046109 | Test Loss=0.010128460 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [232/1000] | Train Loss=0.006878931 | Test Loss=0.010160251 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [233/1000] | Train Loss=0.007571429 | Test Loss=0.018072829 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [234/1000] | Train Loss=0.012649198 | Test Loss=0.013362539 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [235/1000] | Train Loss=0.011213375 | Test Loss=0.009574683 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [236/1000] | Train Loss=0.007316247 | Test Loss=0.008746331 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [237/1000] | Train Loss=0.008818892 | Test Loss=0.004386439 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [238/1000] | Train Loss=0.006312114 | Test Loss=0.012176693 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [239/1000] | Train Loss=0.007334722 | Test Loss=0.013490198 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [240/1000] | Train Loss=0.008291376 | Test Loss=0.014767255 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [241/1000] | Train Loss=0.009025159 | Test Loss=0.012074410 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [242/1000] | Train Loss=0.008311653 | Test Loss=0.007309599 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [243/1000] | Train Loss=0.005980120 | Test Loss=0.008978740 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [244/1000] | Train Loss=0.006247433 | Test Loss=0.008360324 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [245/1000] | Train Loss=0.005589866 | Test Loss=0.006406325 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [246/1000] | Train Loss=0.010950794 | Test Loss=0.011917522 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [247/1000] | Train Loss=0.012419950 | Test Loss=0.007882159 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [248/1000] | Train Loss=0.007875452 | Test Loss=0.005684789 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [249/1000] | Train Loss=0.011935186 | Test Loss=0.016032505 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [250/1000] | Train Loss=0.011939274 | Test Loss=0.010882594 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [251/1000] | Train Loss=0.006022877 | Test Loss=0.009401472 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [252/1000] | Train Loss=0.006034347 | Test Loss=0.006897898 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [253/1000] | Train Loss=0.006013203 | Test Loss=0.004430769 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [254/1000] | Train Loss=0.005294554 | Test Loss=0.005185862 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [255/1000] | Train Loss=0.006576198 | Test Loss=0.006804124 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [256/1000] | Train Loss=0.006815175 | Test Loss=0.005358938 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [257/1000] | Train Loss=0.011636574 | Test Loss=0.023594643 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [258/1000] | Train Loss=0.007089705 | Test Loss=0.006389990 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [259/1000] | Train Loss=0.006010133 | Test Loss=0.004172188 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [260/1000] | Train Loss=0.006899397 | Test Loss=0.007147539 | Time=1.73s | LR=5.00e-04\n",
      "Epoch [261/1000] | Train Loss=0.006155894 | Test Loss=0.015374236 | Time=1.74s | LR=5.00e-04\n",
      "Epoch [262/1000] | Train Loss=0.007023624 | Test Loss=0.009258645 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [263/1000] | Train Loss=0.005642618 | Test Loss=0.007076775 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [264/1000] | Train Loss=0.003075887 | Test Loss=0.004390276 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [265/1000] | Train Loss=0.003270793 | Test Loss=0.005017607 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [266/1000] | Train Loss=0.003720451 | Test Loss=0.007790603 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [267/1000] | Train Loss=0.004240580 | Test Loss=0.003312841 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [268/1000] | Train Loss=0.003217122 | Test Loss=0.004067666 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [269/1000] | Train Loss=0.003286234 | Test Loss=0.005760380 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [270/1000] | Train Loss=0.003339964 | Test Loss=0.006561893 | Time=1.72s | LR=2.50e-04\n",
      "Epoch [271/1000] | Train Loss=0.003423354 | Test Loss=0.003973445 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [272/1000] | Train Loss=0.002734271 | Test Loss=0.003572400 | Time=1.75s | LR=2.50e-04\n",
      "Epoch [273/1000] | Train Loss=0.003210736 | Test Loss=0.005742428 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [274/1000] | Train Loss=0.003507175 | Test Loss=0.006084534 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [275/1000] | Train Loss=0.003753809 | Test Loss=0.005869850 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [276/1000] | Train Loss=0.003059793 | Test Loss=0.005813856 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [277/1000] | Train Loss=0.003465716 | Test Loss=0.004529220 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [278/1000] | Train Loss=0.003287676 | Test Loss=0.004884039 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [279/1000] | Train Loss=0.003216587 | Test Loss=0.005467149 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [280/1000] | Train Loss=0.003273204 | Test Loss=0.005383024 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [281/1000] | Train Loss=0.003285797 | Test Loss=0.004756182 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [282/1000] | Train Loss=0.003053130 | Test Loss=0.005424040 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [283/1000] | Train Loss=0.003540260 | Test Loss=0.005676795 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [284/1000] | Train Loss=0.002827061 | Test Loss=0.003569408 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [285/1000] | Train Loss=0.003351883 | Test Loss=0.005589446 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [286/1000] | Train Loss=0.003464638 | Test Loss=0.004880449 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [287/1000] | Train Loss=0.003385592 | Test Loss=0.005023103 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [288/1000] | Train Loss=0.003345146 | Test Loss=0.007230745 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [289/1000] | Train Loss=0.002670820 | Test Loss=0.005456642 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [290/1000] | Train Loss=0.002924043 | Test Loss=0.003814378 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [291/1000] | Train Loss=0.002690049 | Test Loss=0.003887737 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [292/1000] | Train Loss=0.003434367 | Test Loss=0.004917985 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [293/1000] | Train Loss=0.003042483 | Test Loss=0.004196185 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [294/1000] | Train Loss=0.004568489 | Test Loss=0.004626597 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [295/1000] | Train Loss=0.004709864 | Test Loss=0.004640775 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [296/1000] | Train Loss=0.002830985 | Test Loss=0.005916934 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [297/1000] | Train Loss=0.006143026 | Test Loss=0.005737157 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [298/1000] | Train Loss=0.003123822 | Test Loss=0.004941967 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [299/1000] | Train Loss=0.003470181 | Test Loss=0.004207566 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [300/1000] | Train Loss=0.002930596 | Test Loss=0.003720196 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [301/1000] | Train Loss=0.003118265 | Test Loss=0.005109861 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [302/1000] | Train Loss=0.002921357 | Test Loss=0.003702638 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [303/1000] | Train Loss=0.004927954 | Test Loss=0.011411453 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [304/1000] | Train Loss=0.004469569 | Test Loss=0.006332781 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [305/1000] | Train Loss=0.002914834 | Test Loss=0.004370451 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [306/1000] | Train Loss=0.004176074 | Test Loss=0.007739803 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [307/1000] | Train Loss=0.004123423 | Test Loss=0.005233642 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [308/1000] | Train Loss=0.003284310 | Test Loss=0.007201464 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [309/1000] | Train Loss=0.003376328 | Test Loss=0.004070539 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [310/1000] | Train Loss=0.003284347 | Test Loss=0.003395054 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [311/1000] | Train Loss=0.003494632 | Test Loss=0.004735156 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [312/1000] | Train Loss=0.003232142 | Test Loss=0.005066939 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [313/1000] | Train Loss=0.003260377 | Test Loss=0.004855287 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [314/1000] | Train Loss=0.003129718 | Test Loss=0.004164719 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [315/1000] | Train Loss=0.003321318 | Test Loss=0.005888460 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [316/1000] | Train Loss=0.003427544 | Test Loss=0.005486730 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [317/1000] | Train Loss=0.005503155 | Test Loss=0.009404738 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [318/1000] | Train Loss=0.004088846 | Test Loss=0.005665815 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [319/1000] | Train Loss=0.003361441 | Test Loss=0.006038738 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [320/1000] | Train Loss=0.002674598 | Test Loss=0.004389706 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [321/1000] | Train Loss=0.003229908 | Test Loss=0.003744646 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [322/1000] | Train Loss=0.002775845 | Test Loss=0.003523755 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [323/1000] | Train Loss=0.002536498 | Test Loss=0.004241706 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [324/1000] | Train Loss=0.003319170 | Test Loss=0.003702271 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [325/1000] | Train Loss=0.005824703 | Test Loss=0.005103409 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [326/1000] | Train Loss=0.002846020 | Test Loss=0.006163491 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [327/1000] | Train Loss=0.003368908 | Test Loss=0.003818193 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [328/1000] | Train Loss=0.003411399 | Test Loss=0.003205162 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [329/1000] | Train Loss=0.003409411 | Test Loss=0.005118939 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [330/1000] | Train Loss=0.004692290 | Test Loss=0.006394088 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [331/1000] | Train Loss=0.006023125 | Test Loss=0.006905265 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [332/1000] | Train Loss=0.006071973 | Test Loss=0.004791465 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [333/1000] | Train Loss=0.004248901 | Test Loss=0.004459480 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [334/1000] | Train Loss=0.002905885 | Test Loss=0.003329969 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [335/1000] | Train Loss=0.003583853 | Test Loss=0.009557290 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [336/1000] | Train Loss=0.003233461 | Test Loss=0.004651082 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [337/1000] | Train Loss=0.003159209 | Test Loss=0.004495435 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [338/1000] | Train Loss=0.004450654 | Test Loss=0.005456385 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [339/1000] | Train Loss=0.006101682 | Test Loss=0.006360235 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [340/1000] | Train Loss=0.004279132 | Test Loss=0.004919551 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [341/1000] | Train Loss=0.003113054 | Test Loss=0.003330137 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [342/1000] | Train Loss=0.002922912 | Test Loss=0.005729764 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [343/1000] | Train Loss=0.003187918 | Test Loss=0.003623398 | Time=1.74s | LR=2.50e-04\n",
      "Epoch [344/1000] | Train Loss=0.002958730 | Test Loss=0.004092333 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [345/1000] | Train Loss=0.003040872 | Test Loss=0.003655599 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [346/1000] | Train Loss=0.003008591 | Test Loss=0.003831367 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [347/1000] | Train Loss=0.003282200 | Test Loss=0.003738111 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [348/1000] | Train Loss=0.003226746 | Test Loss=0.003239581 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [349/1000] | Train Loss=0.003070230 | Test Loss=0.003351661 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [350/1000] | Train Loss=0.003618450 | Test Loss=0.003705906 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [351/1000] | Train Loss=0.005941204 | Test Loss=0.009895555 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [352/1000] | Train Loss=0.004935755 | Test Loss=0.003800669 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [353/1000] | Train Loss=0.002982756 | Test Loss=0.006979567 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [354/1000] | Train Loss=0.003107006 | Test Loss=0.005403868 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [355/1000] | Train Loss=0.003456041 | Test Loss=0.006190275 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [356/1000] | Train Loss=0.003619205 | Test Loss=0.004121721 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [357/1000] | Train Loss=0.002956908 | Test Loss=0.004822244 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [358/1000] | Train Loss=0.003312681 | Test Loss=0.005628152 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [359/1000] | Train Loss=0.002823907 | Test Loss=0.006245584 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [360/1000] | Train Loss=0.003207922 | Test Loss=0.004944059 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [361/1000] | Train Loss=0.004239089 | Test Loss=0.003947279 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [362/1000] | Train Loss=0.003519927 | Test Loss=0.004076145 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [363/1000] | Train Loss=0.003222213 | Test Loss=0.005091840 | Time=1.73s | LR=2.50e-04\n",
      "Epoch [364/1000] | Train Loss=0.003084031 | Test Loss=0.003458364 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [365/1000] | Train Loss=0.001469080 | Test Loss=0.002734912 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [366/1000] | Train Loss=0.001506954 | Test Loss=0.002971214 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [367/1000] | Train Loss=0.001568978 | Test Loss=0.003752154 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [368/1000] | Train Loss=0.001707986 | Test Loss=0.002860120 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [369/1000] | Train Loss=0.001445052 | Test Loss=0.002807214 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [370/1000] | Train Loss=0.001422382 | Test Loss=0.003111321 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [371/1000] | Train Loss=0.002613663 | Test Loss=0.003442483 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [372/1000] | Train Loss=0.001868312 | Test Loss=0.002923764 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [373/1000] | Train Loss=0.001735088 | Test Loss=0.003284626 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [374/1000] | Train Loss=0.001523804 | Test Loss=0.003794988 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [375/1000] | Train Loss=0.001601917 | Test Loss=0.003151217 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [376/1000] | Train Loss=0.001440483 | Test Loss=0.002646163 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [377/1000] | Train Loss=0.001995089 | Test Loss=0.002871457 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [378/1000] | Train Loss=0.002495842 | Test Loss=0.004699749 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [379/1000] | Train Loss=0.003028141 | Test Loss=0.004466616 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [380/1000] | Train Loss=0.001939423 | Test Loss=0.002966050 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [381/1000] | Train Loss=0.001459134 | Test Loss=0.003264229 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [382/1000] | Train Loss=0.002066535 | Test Loss=0.005450510 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [383/1000] | Train Loss=0.003032881 | Test Loss=0.003687052 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [384/1000] | Train Loss=0.001901322 | Test Loss=0.002689734 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [385/1000] | Train Loss=0.001462069 | Test Loss=0.002662235 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [386/1000] | Train Loss=0.001519566 | Test Loss=0.002662142 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [387/1000] | Train Loss=0.000965636 | Test Loss=0.003179850 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [388/1000] | Train Loss=0.001697313 | Test Loss=0.002666039 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [389/1000] | Train Loss=0.001603356 | Test Loss=0.004187637 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [390/1000] | Train Loss=0.001597410 | Test Loss=0.004107781 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [391/1000] | Train Loss=0.003189066 | Test Loss=0.003823291 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [392/1000] | Train Loss=0.002797394 | Test Loss=0.004224647 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [393/1000] | Train Loss=0.001599125 | Test Loss=0.003483374 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [394/1000] | Train Loss=0.001396157 | Test Loss=0.002441448 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [395/1000] | Train Loss=0.002067378 | Test Loss=0.002840870 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [396/1000] | Train Loss=0.001674662 | Test Loss=0.002750208 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [397/1000] | Train Loss=0.001613909 | Test Loss=0.003058650 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [398/1000] | Train Loss=0.001704074 | Test Loss=0.002949301 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [399/1000] | Train Loss=0.001642043 | Test Loss=0.002902049 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [400/1000] | Train Loss=0.001518669 | Test Loss=0.002831533 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [401/1000] | Train Loss=0.001674644 | Test Loss=0.003146188 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [402/1000] | Train Loss=0.001719922 | Test Loss=0.003189830 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [403/1000] | Train Loss=0.001687802 | Test Loss=0.003341337 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [404/1000] | Train Loss=0.001295501 | Test Loss=0.002729449 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [405/1000] | Train Loss=0.001500379 | Test Loss=0.003118492 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [406/1000] | Train Loss=0.001629481 | Test Loss=0.003968463 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [407/1000] | Train Loss=0.001644669 | Test Loss=0.002724318 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [408/1000] | Train Loss=0.001507342 | Test Loss=0.002426114 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [409/1000] | Train Loss=0.001597265 | Test Loss=0.002938863 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [410/1000] | Train Loss=0.001603110 | Test Loss=0.003177977 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [411/1000] | Train Loss=0.001685226 | Test Loss=0.002918604 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [412/1000] | Train Loss=0.001664291 | Test Loss=0.002911931 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [413/1000] | Train Loss=0.001931969 | Test Loss=0.002543947 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [414/1000] | Train Loss=0.001243316 | Test Loss=0.002548162 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [415/1000] | Train Loss=0.001449141 | Test Loss=0.003114044 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [416/1000] | Train Loss=0.001663667 | Test Loss=0.002508477 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [417/1000] | Train Loss=0.001685818 | Test Loss=0.003354109 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [418/1000] | Train Loss=0.001657550 | Test Loss=0.003823552 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [419/1000] | Train Loss=0.001736577 | Test Loss=0.003029377 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [420/1000] | Train Loss=0.001539826 | Test Loss=0.003332208 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [421/1000] | Train Loss=0.001704109 | Test Loss=0.002635107 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [422/1000] | Train Loss=0.001279023 | Test Loss=0.003070102 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [423/1000] | Train Loss=0.001626394 | Test Loss=0.002429423 | Time=1.73s | LR=1.25e-04\n",
      "Epoch [424/1000] | Train Loss=0.001439130 | Test Loss=0.004198421 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [425/1000] | Train Loss=0.001498772 | Test Loss=0.003571544 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [426/1000] | Train Loss=0.002234250 | Test Loss=0.003930327 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [427/1000] | Train Loss=0.001811894 | Test Loss=0.002468637 | Time=1.74s | LR=1.25e-04\n",
      "Epoch [428/1000] | Train Loss=0.001705708 | Test Loss=0.003353078 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [429/1000] | Train Loss=0.000947590 | Test Loss=0.002564483 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [430/1000] | Train Loss=0.000767327 | Test Loss=0.002430041 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [431/1000] | Train Loss=0.000849284 | Test Loss=0.002624258 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [432/1000] | Train Loss=0.000604852 | Test Loss=0.002436738 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [433/1000] | Train Loss=0.000654623 | Test Loss=0.002588006 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [434/1000] | Train Loss=0.000852598 | Test Loss=0.002598173 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [435/1000] | Train Loss=0.000730421 | Test Loss=0.002502168 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [436/1000] | Train Loss=0.000730932 | Test Loss=0.002455619 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [437/1000] | Train Loss=0.000821595 | Test Loss=0.002637339 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [438/1000] | Train Loss=0.000582448 | Test Loss=0.002412431 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [439/1000] | Train Loss=0.000960745 | Test Loss=0.002301233 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [440/1000] | Train Loss=0.000822577 | Test Loss=0.002644542 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [441/1000] | Train Loss=0.000939552 | Test Loss=0.002490597 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [442/1000] | Train Loss=0.000878404 | Test Loss=0.002351891 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [443/1000] | Train Loss=0.001006962 | Test Loss=0.003063109 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [444/1000] | Train Loss=0.000884604 | Test Loss=0.002300061 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [445/1000] | Train Loss=0.000695492 | Test Loss=0.002451176 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [446/1000] | Train Loss=0.000875051 | Test Loss=0.002495416 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [447/1000] | Train Loss=0.000845335 | Test Loss=0.002244946 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [448/1000] | Train Loss=0.000939139 | Test Loss=0.002500901 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [449/1000] | Train Loss=0.000819751 | Test Loss=0.002293831 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [450/1000] | Train Loss=0.000801597 | Test Loss=0.002701044 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [451/1000] | Train Loss=0.001302582 | Test Loss=0.002519197 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [452/1000] | Train Loss=0.001564336 | Test Loss=0.003031789 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [453/1000] | Train Loss=0.000809223 | Test Loss=0.003292213 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [454/1000] | Train Loss=0.000588762 | Test Loss=0.002452891 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [455/1000] | Train Loss=0.000884760 | Test Loss=0.002483397 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [456/1000] | Train Loss=0.000721974 | Test Loss=0.002523774 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [457/1000] | Train Loss=0.000650616 | Test Loss=0.002299111 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [458/1000] | Train Loss=0.000935101 | Test Loss=0.002366098 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [459/1000] | Train Loss=0.000918363 | Test Loss=0.002722662 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [460/1000] | Train Loss=0.000820761 | Test Loss=0.002523139 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [461/1000] | Train Loss=0.001052852 | Test Loss=0.003171882 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [462/1000] | Train Loss=0.001149454 | Test Loss=0.002732193 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [463/1000] | Train Loss=0.000892201 | Test Loss=0.002736438 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [464/1000] | Train Loss=0.000674410 | Test Loss=0.002344842 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [465/1000] | Train Loss=0.000836183 | Test Loss=0.002371473 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [466/1000] | Train Loss=0.000960769 | Test Loss=0.002440788 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [467/1000] | Train Loss=0.000701160 | Test Loss=0.002238097 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [468/1000] | Train Loss=0.000912377 | Test Loss=0.002651746 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [469/1000] | Train Loss=0.000832060 | Test Loss=0.002305743 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [470/1000] | Train Loss=0.000666338 | Test Loss=0.002515709 | Time=1.75s | LR=6.25e-05\n",
      "Epoch [471/1000] | Train Loss=0.000695135 | Test Loss=0.002404528 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [472/1000] | Train Loss=0.000558222 | Test Loss=0.002283043 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [473/1000] | Train Loss=0.000950828 | Test Loss=0.002414664 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [474/1000] | Train Loss=0.000896756 | Test Loss=0.002383470 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [475/1000] | Train Loss=0.000894717 | Test Loss=0.002366948 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [476/1000] | Train Loss=0.000545441 | Test Loss=0.002255792 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [477/1000] | Train Loss=0.000630221 | Test Loss=0.002279481 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [478/1000] | Train Loss=0.000862082 | Test Loss=0.002212443 | Time=1.75s | LR=6.25e-05\n",
      "Epoch [479/1000] | Train Loss=0.000708644 | Test Loss=0.002541057 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [480/1000] | Train Loss=0.000889654 | Test Loss=0.002320567 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [481/1000] | Train Loss=0.000914372 | Test Loss=0.002286060 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [482/1000] | Train Loss=0.000568212 | Test Loss=0.002445310 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [483/1000] | Train Loss=0.000810149 | Test Loss=0.002848358 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [484/1000] | Train Loss=0.000895188 | Test Loss=0.002306128 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [485/1000] | Train Loss=0.000867770 | Test Loss=0.002147497 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [486/1000] | Train Loss=0.000672355 | Test Loss=0.002865472 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [487/1000] | Train Loss=0.000975651 | Test Loss=0.002622998 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [488/1000] | Train Loss=0.000757044 | Test Loss=0.002741896 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [489/1000] | Train Loss=0.000791713 | Test Loss=0.002343728 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [490/1000] | Train Loss=0.000849461 | Test Loss=0.002185397 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [491/1000] | Train Loss=0.000872678 | Test Loss=0.002412284 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [492/1000] | Train Loss=0.000931777 | Test Loss=0.002381238 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [493/1000] | Train Loss=0.000772315 | Test Loss=0.002905841 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [494/1000] | Train Loss=0.000882815 | Test Loss=0.002376665 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [495/1000] | Train Loss=0.000682787 | Test Loss=0.002310994 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [496/1000] | Train Loss=0.000844572 | Test Loss=0.002232757 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [497/1000] | Train Loss=0.000914101 | Test Loss=0.002373378 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [498/1000] | Train Loss=0.000630805 | Test Loss=0.002878556 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [499/1000] | Train Loss=0.000816494 | Test Loss=0.002195116 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [500/1000] | Train Loss=0.000944565 | Test Loss=0.002833726 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [501/1000] | Train Loss=0.000890896 | Test Loss=0.002405878 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [502/1000] | Train Loss=0.000892866 | Test Loss=0.002616041 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [503/1000] | Train Loss=0.000918411 | Test Loss=0.002406341 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [504/1000] | Train Loss=0.000816019 | Test Loss=0.002176602 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [505/1000] | Train Loss=0.000844413 | Test Loss=0.002361822 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [506/1000] | Train Loss=0.000877618 | Test Loss=0.002322281 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [507/1000] | Train Loss=0.000491370 | Test Loss=0.002237558 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [508/1000] | Train Loss=0.000884987 | Test Loss=0.002271588 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [509/1000] | Train Loss=0.000825538 | Test Loss=0.002964177 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [510/1000] | Train Loss=0.000761115 | Test Loss=0.002286673 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [511/1000] | Train Loss=0.000877382 | Test Loss=0.002414711 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [512/1000] | Train Loss=0.000911965 | Test Loss=0.002174200 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [513/1000] | Train Loss=0.000741392 | Test Loss=0.002236007 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [514/1000] | Train Loss=0.000647242 | Test Loss=0.002227043 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [515/1000] | Train Loss=0.000652467 | Test Loss=0.002212257 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [516/1000] | Train Loss=0.000595828 | Test Loss=0.002281990 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [517/1000] | Train Loss=0.000933908 | Test Loss=0.002664460 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [518/1000] | Train Loss=0.000953548 | Test Loss=0.002209938 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [519/1000] | Train Loss=0.000873922 | Test Loss=0.002310340 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [520/1000] | Train Loss=0.000731587 | Test Loss=0.002261511 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [521/1000] | Train Loss=0.000787047 | Test Loss=0.002182216 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [522/1000] | Train Loss=0.000667615 | Test Loss=0.002474434 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [523/1000] | Train Loss=0.000583449 | Test Loss=0.002316687 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [524/1000] | Train Loss=0.000581610 | Test Loss=0.002177652 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [525/1000] | Train Loss=0.000763667 | Test Loss=0.002128412 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [526/1000] | Train Loss=0.000940720 | Test Loss=0.002521982 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [527/1000] | Train Loss=0.000955355 | Test Loss=0.002474070 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [528/1000] | Train Loss=0.000890095 | Test Loss=0.002219136 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [529/1000] | Train Loss=0.000809775 | Test Loss=0.002558023 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [530/1000] | Train Loss=0.000667705 | Test Loss=0.002297326 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [531/1000] | Train Loss=0.000721100 | Test Loss=0.002119734 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [532/1000] | Train Loss=0.000838743 | Test Loss=0.002232587 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [533/1000] | Train Loss=0.000655072 | Test Loss=0.002217520 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [534/1000] | Train Loss=0.000583326 | Test Loss=0.002206185 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [535/1000] | Train Loss=0.000684741 | Test Loss=0.002320432 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [536/1000] | Train Loss=0.000972138 | Test Loss=0.002586093 | Time=1.76s | LR=6.25e-05\n",
      "Epoch [537/1000] | Train Loss=0.000696439 | Test Loss=0.002251129 | Time=1.74s | LR=6.25e-05\n",
      "Epoch [538/1000] | Train Loss=0.000805301 | Test Loss=0.002248591 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [539/1000] | Train Loss=0.000920863 | Test Loss=0.002172055 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [540/1000] | Train Loss=0.000788327 | Test Loss=0.002222992 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [541/1000] | Train Loss=0.000954753 | Test Loss=0.002131053 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [542/1000] | Train Loss=0.000894481 | Test Loss=0.002287452 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [543/1000] | Train Loss=0.000872492 | Test Loss=0.002292971 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [544/1000] | Train Loss=0.000723882 | Test Loss=0.002370084 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [545/1000] | Train Loss=0.000647545 | Test Loss=0.002169014 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [546/1000] | Train Loss=0.000768342 | Test Loss=0.002509348 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [547/1000] | Train Loss=0.000944361 | Test Loss=0.002283500 | Time=1.73s | LR=6.25e-05\n",
      "Epoch [548/1000] | Train Loss=0.000662609 | Test Loss=0.002152404 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [549/1000] | Train Loss=0.000418891 | Test Loss=0.002056237 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [550/1000] | Train Loss=0.000476807 | Test Loss=0.002088643 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [551/1000] | Train Loss=0.000479977 | Test Loss=0.002121456 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [552/1000] | Train Loss=0.000365525 | Test Loss=0.002145455 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [553/1000] | Train Loss=0.000449375 | Test Loss=0.002091386 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [554/1000] | Train Loss=0.000491496 | Test Loss=0.002099185 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [555/1000] | Train Loss=0.000395492 | Test Loss=0.002105737 | Time=1.73s | LR=3.13e-05\n",
      "Epoch [556/1000] | Train Loss=0.000480615 | Test Loss=0.002133168 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [557/1000] | Train Loss=0.000503251 | Test Loss=0.002183014 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [558/1000] | Train Loss=0.000425714 | Test Loss=0.002113661 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [559/1000] | Train Loss=0.000471887 | Test Loss=0.002064453 | Time=1.73s | LR=3.13e-05\n",
      "Epoch [560/1000] | Train Loss=0.000534066 | Test Loss=0.002106142 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [561/1000] | Train Loss=0.000423049 | Test Loss=0.002245815 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [562/1000] | Train Loss=0.000496370 | Test Loss=0.002100446 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [563/1000] | Train Loss=0.000366721 | Test Loss=0.002100298 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [564/1000] | Train Loss=0.000449968 | Test Loss=0.002063617 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [565/1000] | Train Loss=0.000371386 | Test Loss=0.002065952 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [566/1000] | Train Loss=0.000539266 | Test Loss=0.002083514 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [567/1000] | Train Loss=0.000392982 | Test Loss=0.002205793 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [568/1000] | Train Loss=0.000587791 | Test Loss=0.002049289 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [569/1000] | Train Loss=0.000530873 | Test Loss=0.002243152 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [570/1000] | Train Loss=0.000553325 | Test Loss=0.002262727 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [571/1000] | Train Loss=0.000445564 | Test Loss=0.002247956 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [572/1000] | Train Loss=0.000494451 | Test Loss=0.002059953 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [573/1000] | Train Loss=0.000535293 | Test Loss=0.002253424 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [574/1000] | Train Loss=0.000433920 | Test Loss=0.002130717 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [575/1000] | Train Loss=0.000420781 | Test Loss=0.002048069 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [576/1000] | Train Loss=0.000397377 | Test Loss=0.002070559 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [577/1000] | Train Loss=0.000521038 | Test Loss=0.002056330 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [578/1000] | Train Loss=0.000499403 | Test Loss=0.001986096 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [579/1000] | Train Loss=0.000571694 | Test Loss=0.002087336 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [580/1000] | Train Loss=0.000535817 | Test Loss=0.002075862 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [581/1000] | Train Loss=0.000444118 | Test Loss=0.002108243 | Time=1.73s | LR=3.13e-05\n",
      "Epoch [582/1000] | Train Loss=0.000501816 | Test Loss=0.002049542 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [583/1000] | Train Loss=0.000407388 | Test Loss=0.002231393 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [584/1000] | Train Loss=0.000563529 | Test Loss=0.002027440 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [585/1000] | Train Loss=0.000527099 | Test Loss=0.002316972 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [586/1000] | Train Loss=0.000529211 | Test Loss=0.002049800 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [587/1000] | Train Loss=0.000369689 | Test Loss=0.002067147 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [588/1000] | Train Loss=0.000470962 | Test Loss=0.002055055 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [589/1000] | Train Loss=0.000386740 | Test Loss=0.002394111 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [590/1000] | Train Loss=0.000465782 | Test Loss=0.002059403 | Time=1.73s | LR=3.13e-05\n",
      "Epoch [591/1000] | Train Loss=0.000572701 | Test Loss=0.002181547 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [592/1000] | Train Loss=0.000417358 | Test Loss=0.002055598 | Time=1.72s | LR=3.13e-05\n",
      "Epoch [593/1000] | Train Loss=0.000382895 | Test Loss=0.002149100 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [594/1000] | Train Loss=0.000338890 | Test Loss=0.002046624 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [595/1000] | Train Loss=0.000317933 | Test Loss=0.002094236 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [596/1000] | Train Loss=0.000334313 | Test Loss=0.002090323 | Time=1.73s | LR=1.56e-05\n",
      "Epoch [597/1000] | Train Loss=0.000315971 | Test Loss=0.002043219 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [598/1000] | Train Loss=0.000318708 | Test Loss=0.002041323 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [599/1000] | Train Loss=0.000324194 | Test Loss=0.002040153 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [600/1000] | Train Loss=0.000319550 | Test Loss=0.002033504 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [601/1000] | Train Loss=0.000326525 | Test Loss=0.002032696 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [602/1000] | Train Loss=0.000331804 | Test Loss=0.002054990 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [603/1000] | Train Loss=0.000378588 | Test Loss=0.002052402 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [604/1000] | Train Loss=0.000362368 | Test Loss=0.002066739 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [605/1000] | Train Loss=0.000324919 | Test Loss=0.002061286 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [606/1000] | Train Loss=0.000347978 | Test Loss=0.002069543 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [607/1000] | Train Loss=0.000354997 | Test Loss=0.002042212 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [608/1000] | Train Loss=0.000417306 | Test Loss=0.002203316 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [609/1000] | Train Loss=0.000390940 | Test Loss=0.001995567 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [610/1000] | Train Loss=0.000387374 | Test Loss=0.002079500 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [611/1000] | Train Loss=0.000327019 | Test Loss=0.001995642 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [612/1000] | Train Loss=0.000326317 | Test Loss=0.002053887 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [613/1000] | Train Loss=0.000336327 | Test Loss=0.001995671 | Time=1.73s | LR=1.56e-05\n",
      "Epoch [614/1000] | Train Loss=0.000335379 | Test Loss=0.002067930 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [615/1000] | Train Loss=0.000347234 | Test Loss=0.001986631 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [616/1000] | Train Loss=0.000354271 | Test Loss=0.002024156 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [617/1000] | Train Loss=0.000370820 | Test Loss=0.002029251 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [618/1000] | Train Loss=0.000363614 | Test Loss=0.001978901 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [619/1000] | Train Loss=0.000347648 | Test Loss=0.002030140 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [620/1000] | Train Loss=0.000329848 | Test Loss=0.002039064 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [621/1000] | Train Loss=0.000323070 | Test Loss=0.001987953 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [622/1000] | Train Loss=0.000343555 | Test Loss=0.002014630 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [623/1000] | Train Loss=0.000383603 | Test Loss=0.002034356 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [624/1000] | Train Loss=0.000339776 | Test Loss=0.002031307 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [625/1000] | Train Loss=0.000344831 | Test Loss=0.001995392 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [626/1000] | Train Loss=0.000360413 | Test Loss=0.002194975 | Time=1.73s | LR=1.56e-05\n",
      "Epoch [627/1000] | Train Loss=0.000370517 | Test Loss=0.002057002 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [628/1000] | Train Loss=0.000338397 | Test Loss=0.001994156 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [629/1000] | Train Loss=0.000370734 | Test Loss=0.001971377 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [630/1000] | Train Loss=0.000357641 | Test Loss=0.002027690 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [631/1000] | Train Loss=0.000363274 | Test Loss=0.002084622 | Time=1.73s | LR=1.56e-05\n",
      "Epoch [632/1000] | Train Loss=0.000394310 | Test Loss=0.002041538 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [633/1000] | Train Loss=0.000340573 | Test Loss=0.002004239 | Time=1.73s | LR=1.56e-05\n",
      "Epoch [634/1000] | Train Loss=0.000353439 | Test Loss=0.001993059 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [635/1000] | Train Loss=0.000342012 | Test Loss=0.001995283 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [636/1000] | Train Loss=0.000375134 | Test Loss=0.002027651 | Time=1.73s | LR=1.56e-05\n",
      "Epoch [637/1000] | Train Loss=0.000329102 | Test Loss=0.002013080 | Time=1.72s | LR=1.56e-05\n",
      "Epoch [638/1000] | Train Loss=0.000358228 | Test Loss=0.001986411 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [639/1000] | Train Loss=0.000305655 | Test Loss=0.002017469 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [640/1000] | Train Loss=0.000308095 | Test Loss=0.002017853 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [641/1000] | Train Loss=0.000309794 | Test Loss=0.002013234 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [642/1000] | Train Loss=0.000308755 | Test Loss=0.001995525 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [643/1000] | Train Loss=0.000309542 | Test Loss=0.001990026 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [644/1000] | Train Loss=0.000302264 | Test Loss=0.001969352 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [645/1000] | Train Loss=0.000311231 | Test Loss=0.001997535 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [646/1000] | Train Loss=0.000314188 | Test Loss=0.001990282 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [647/1000] | Train Loss=0.000321659 | Test Loss=0.002001783 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [648/1000] | Train Loss=0.000305830 | Test Loss=0.001966945 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [649/1000] | Train Loss=0.000302360 | Test Loss=0.001989176 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [650/1000] | Train Loss=0.000318714 | Test Loss=0.002006234 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [651/1000] | Train Loss=0.000311047 | Test Loss=0.002005376 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [652/1000] | Train Loss=0.000304257 | Test Loss=0.001973862 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [653/1000] | Train Loss=0.000309254 | Test Loss=0.002001744 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [654/1000] | Train Loss=0.000322675 | Test Loss=0.001978862 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [655/1000] | Train Loss=0.000308358 | Test Loss=0.001984608 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [656/1000] | Train Loss=0.000317986 | Test Loss=0.001950259 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [657/1000] | Train Loss=0.000313377 | Test Loss=0.001965302 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [658/1000] | Train Loss=0.000312074 | Test Loss=0.001976994 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [659/1000] | Train Loss=0.000317223 | Test Loss=0.001963469 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [660/1000] | Train Loss=0.000311746 | Test Loss=0.001936396 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [661/1000] | Train Loss=0.000312040 | Test Loss=0.001991756 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [662/1000] | Train Loss=0.000307074 | Test Loss=0.001997476 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [663/1000] | Train Loss=0.000326885 | Test Loss=0.001977454 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [664/1000] | Train Loss=0.000313415 | Test Loss=0.001991198 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [665/1000] | Train Loss=0.000304775 | Test Loss=0.001957042 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [666/1000] | Train Loss=0.000319691 | Test Loss=0.001971713 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [667/1000] | Train Loss=0.000311861 | Test Loss=0.001962445 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [668/1000] | Train Loss=0.000305030 | Test Loss=0.002009840 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [669/1000] | Train Loss=0.000308520 | Test Loss=0.001993532 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [670/1000] | Train Loss=0.000308682 | Test Loss=0.002000815 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [671/1000] | Train Loss=0.000321414 | Test Loss=0.001950214 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [672/1000] | Train Loss=0.000312139 | Test Loss=0.001947888 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [673/1000] | Train Loss=0.000316053 | Test Loss=0.001964586 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [674/1000] | Train Loss=0.000318412 | Test Loss=0.001974087 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [675/1000] | Train Loss=0.000309631 | Test Loss=0.001942203 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [676/1000] | Train Loss=0.000311273 | Test Loss=0.002042035 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [677/1000] | Train Loss=0.000328117 | Test Loss=0.002009602 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [678/1000] | Train Loss=0.000309944 | Test Loss=0.002001031 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [679/1000] | Train Loss=0.000306113 | Test Loss=0.002015706 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [680/1000] | Train Loss=0.000303519 | Test Loss=0.001969619 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [681/1000] | Train Loss=0.000298469 | Test Loss=0.001967089 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [682/1000] | Train Loss=0.000316916 | Test Loss=0.001978981 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [683/1000] | Train Loss=0.000332254 | Test Loss=0.001948989 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [684/1000] | Train Loss=0.000319333 | Test Loss=0.001964512 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [685/1000] | Train Loss=0.000305446 | Test Loss=0.001944014 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [686/1000] | Train Loss=0.000305766 | Test Loss=0.001982747 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [687/1000] | Train Loss=0.000301498 | Test Loss=0.001987013 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [688/1000] | Train Loss=0.000303030 | Test Loss=0.001979250 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [689/1000] | Train Loss=0.000315070 | Test Loss=0.001989077 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [690/1000] | Train Loss=0.000309330 | Test Loss=0.001953186 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [691/1000] | Train Loss=0.000301093 | Test Loss=0.001976491 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [692/1000] | Train Loss=0.000308293 | Test Loss=0.001964945 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [693/1000] | Train Loss=0.000299792 | Test Loss=0.001980704 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [694/1000] | Train Loss=0.000309358 | Test Loss=0.001968421 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [695/1000] | Train Loss=0.000298439 | Test Loss=0.001944088 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [696/1000] | Train Loss=0.000345137 | Test Loss=0.001936403 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [697/1000] | Train Loss=0.000312105 | Test Loss=0.001985357 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [698/1000] | Train Loss=0.000304036 | Test Loss=0.001967941 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [699/1000] | Train Loss=0.000304702 | Test Loss=0.001948457 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [700/1000] | Train Loss=0.000301601 | Test Loss=0.001975826 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [701/1000] | Train Loss=0.000307802 | Test Loss=0.001979111 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [702/1000] | Train Loss=0.000319730 | Test Loss=0.001980352 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [703/1000] | Train Loss=0.000306241 | Test Loss=0.001954728 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [704/1000] | Train Loss=0.000322073 | Test Loss=0.001971574 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [705/1000] | Train Loss=0.000305975 | Test Loss=0.001970488 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [706/1000] | Train Loss=0.000318747 | Test Loss=0.001942802 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [707/1000] | Train Loss=0.000318229 | Test Loss=0.001926920 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [708/1000] | Train Loss=0.000304427 | Test Loss=0.001989738 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [709/1000] | Train Loss=0.000304938 | Test Loss=0.001969738 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [710/1000] | Train Loss=0.000304154 | Test Loss=0.001953092 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [711/1000] | Train Loss=0.000314846 | Test Loss=0.001958597 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [712/1000] | Train Loss=0.000309379 | Test Loss=0.001975020 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [713/1000] | Train Loss=0.000318300 | Test Loss=0.001947969 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [714/1000] | Train Loss=0.000299719 | Test Loss=0.001941453 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [715/1000] | Train Loss=0.000297025 | Test Loss=0.001955344 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [716/1000] | Train Loss=0.000305664 | Test Loss=0.001961393 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [717/1000] | Train Loss=0.000294276 | Test Loss=0.001956663 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [718/1000] | Train Loss=0.000297475 | Test Loss=0.001945804 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [719/1000] | Train Loss=0.000302289 | Test Loss=0.001962528 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [720/1000] | Train Loss=0.000320515 | Test Loss=0.001969838 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [721/1000] | Train Loss=0.000313033 | Test Loss=0.001933202 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [722/1000] | Train Loss=0.000308877 | Test Loss=0.001979899 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [723/1000] | Train Loss=0.000298898 | Test Loss=0.001956693 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [724/1000] | Train Loss=0.000311778 | Test Loss=0.002022081 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [725/1000] | Train Loss=0.000329829 | Test Loss=0.001930421 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [726/1000] | Train Loss=0.000308506 | Test Loss=0.001938626 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [727/1000] | Train Loss=0.000305019 | Test Loss=0.002004266 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [728/1000] | Train Loss=0.000303030 | Test Loss=0.001989992 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [729/1000] | Train Loss=0.000300049 | Test Loss=0.001970568 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [730/1000] | Train Loss=0.000304420 | Test Loss=0.001969123 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [731/1000] | Train Loss=0.000303160 | Test Loss=0.001945979 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [732/1000] | Train Loss=0.000306426 | Test Loss=0.001962535 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [733/1000] | Train Loss=0.000310811 | Test Loss=0.001932440 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [734/1000] | Train Loss=0.000308742 | Test Loss=0.001933667 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [735/1000] | Train Loss=0.000304918 | Test Loss=0.001962038 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [736/1000] | Train Loss=0.000302005 | Test Loss=0.001958882 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [737/1000] | Train Loss=0.000300945 | Test Loss=0.001936338 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [738/1000] | Train Loss=0.000309336 | Test Loss=0.001966759 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [739/1000] | Train Loss=0.000305571 | Test Loss=0.001991943 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [740/1000] | Train Loss=0.000308596 | Test Loss=0.001937604 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [741/1000] | Train Loss=0.000312762 | Test Loss=0.001939710 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [742/1000] | Train Loss=0.000312001 | Test Loss=0.001920611 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [743/1000] | Train Loss=0.000300070 | Test Loss=0.001956403 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [744/1000] | Train Loss=0.000304466 | Test Loss=0.001961697 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [745/1000] | Train Loss=0.000304549 | Test Loss=0.001938631 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [746/1000] | Train Loss=0.000302251 | Test Loss=0.001968723 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [747/1000] | Train Loss=0.000302256 | Test Loss=0.001972537 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [748/1000] | Train Loss=0.000310818 | Test Loss=0.001970572 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [749/1000] | Train Loss=0.000307250 | Test Loss=0.001934276 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [750/1000] | Train Loss=0.000317102 | Test Loss=0.001975799 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [751/1000] | Train Loss=0.000308246 | Test Loss=0.001936296 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [752/1000] | Train Loss=0.000297141 | Test Loss=0.001947550 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [753/1000] | Train Loss=0.000319061 | Test Loss=0.001936923 | Time=1.73s | LR=7.81e-06\n",
      "Epoch [754/1000] | Train Loss=0.000300781 | Test Loss=0.001958231 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [755/1000] | Train Loss=0.000313077 | Test Loss=0.001942101 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [756/1000] | Train Loss=0.000318528 | Test Loss=0.001965301 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [757/1000] | Train Loss=0.000314926 | Test Loss=0.002012132 | Time=1.72s | LR=7.81e-06\n",
      "Epoch [758/1000] | Train Loss=0.000301169 | Test Loss=0.001966147 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [759/1000] | Train Loss=0.000294017 | Test Loss=0.001952877 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [760/1000] | Train Loss=0.000294813 | Test Loss=0.001932641 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [761/1000] | Train Loss=0.000294078 | Test Loss=0.001931984 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [762/1000] | Train Loss=0.000296958 | Test Loss=0.001941615 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [763/1000] | Train Loss=0.000298433 | Test Loss=0.001951028 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [764/1000] | Train Loss=0.000293324 | Test Loss=0.001937108 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [765/1000] | Train Loss=0.000290291 | Test Loss=0.001922333 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [766/1000] | Train Loss=0.000300367 | Test Loss=0.001904597 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [767/1000] | Train Loss=0.000290615 | Test Loss=0.001930969 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [768/1000] | Train Loss=0.000293925 | Test Loss=0.001932201 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [769/1000] | Train Loss=0.000298806 | Test Loss=0.001965538 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [770/1000] | Train Loss=0.000294487 | Test Loss=0.001927594 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [771/1000] | Train Loss=0.000290537 | Test Loss=0.001913064 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [772/1000] | Train Loss=0.000294929 | Test Loss=0.001935559 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [773/1000] | Train Loss=0.000293009 | Test Loss=0.001917399 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [774/1000] | Train Loss=0.000292818 | Test Loss=0.001970875 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [775/1000] | Train Loss=0.000298061 | Test Loss=0.001925829 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [776/1000] | Train Loss=0.000296435 | Test Loss=0.001927868 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [777/1000] | Train Loss=0.000295994 | Test Loss=0.001938010 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [778/1000] | Train Loss=0.000290386 | Test Loss=0.001928457 | Time=1.72s | LR=3.91e-06\n",
      "Epoch [779/1000] | Train Loss=0.000293075 | Test Loss=0.001954739 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [780/1000] | Train Loss=0.000294762 | Test Loss=0.001943899 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [781/1000] | Train Loss=0.000294466 | Test Loss=0.001962164 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [782/1000] | Train Loss=0.000290886 | Test Loss=0.001937588 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [783/1000] | Train Loss=0.000290818 | Test Loss=0.001912548 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [784/1000] | Train Loss=0.000304363 | Test Loss=0.001938884 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [785/1000] | Train Loss=0.000290495 | Test Loss=0.001940213 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [786/1000] | Train Loss=0.000294377 | Test Loss=0.001949921 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [787/1000] | Train Loss=0.000297157 | Test Loss=0.001939393 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [788/1000] | Train Loss=0.000290438 | Test Loss=0.001914072 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [789/1000] | Train Loss=0.000293722 | Test Loss=0.001932444 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [790/1000] | Train Loss=0.000294066 | Test Loss=0.001951026 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [791/1000] | Train Loss=0.000299773 | Test Loss=0.001932303 | Time=1.73s | LR=3.91e-06\n",
      "Epoch [792/1000] | Train Loss=0.000293927 | Test Loss=0.001926479 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [793/1000] | Train Loss=0.000295415 | Test Loss=0.001944564 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [794/1000] | Train Loss=0.000295510 | Test Loss=0.001918126 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [795/1000] | Train Loss=0.000299669 | Test Loss=0.001916149 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [796/1000] | Train Loss=0.000294570 | Test Loss=0.001942732 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [797/1000] | Train Loss=0.000301010 | Test Loss=0.001945208 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [798/1000] | Train Loss=0.000296655 | Test Loss=0.001939499 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [799/1000] | Train Loss=0.000292755 | Test Loss=0.001930762 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [800/1000] | Train Loss=0.000301651 | Test Loss=0.001936751 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [801/1000] | Train Loss=0.000289696 | Test Loss=0.001959585 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [802/1000] | Train Loss=0.000294844 | Test Loss=0.001951348 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [803/1000] | Train Loss=0.000296991 | Test Loss=0.001931998 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [804/1000] | Train Loss=0.000291715 | Test Loss=0.001947198 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [805/1000] | Train Loss=0.000299061 | Test Loss=0.001926263 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [806/1000] | Train Loss=0.000288857 | Test Loss=0.001980945 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [807/1000] | Train Loss=0.000302164 | Test Loss=0.001908237 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [808/1000] | Train Loss=0.000291198 | Test Loss=0.001929628 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [809/1000] | Train Loss=0.000288462 | Test Loss=0.001946236 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [810/1000] | Train Loss=0.000287986 | Test Loss=0.001916882 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [811/1000] | Train Loss=0.000289322 | Test Loss=0.001938365 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [812/1000] | Train Loss=0.000295086 | Test Loss=0.001905065 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [813/1000] | Train Loss=0.000296712 | Test Loss=0.001882881 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [814/1000] | Train Loss=0.000289543 | Test Loss=0.001940348 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [815/1000] | Train Loss=0.000289874 | Test Loss=0.001925815 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [816/1000] | Train Loss=0.000300826 | Test Loss=0.001919789 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [817/1000] | Train Loss=0.000292301 | Test Loss=0.001940904 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [818/1000] | Train Loss=0.000294129 | Test Loss=0.001904814 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [819/1000] | Train Loss=0.000293952 | Test Loss=0.001896376 | Time=1.75s | LR=3.91e-06\n",
      "Epoch [820/1000] | Train Loss=0.000294434 | Test Loss=0.001918620 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [821/1000] | Train Loss=0.000286501 | Test Loss=0.001943667 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [822/1000] | Train Loss=0.000289778 | Test Loss=0.001905573 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [823/1000] | Train Loss=0.000293166 | Test Loss=0.001913850 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [824/1000] | Train Loss=0.000296502 | Test Loss=0.001925569 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [825/1000] | Train Loss=0.000290595 | Test Loss=0.001965639 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [826/1000] | Train Loss=0.000294889 | Test Loss=0.001926613 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [827/1000] | Train Loss=0.000295927 | Test Loss=0.001903855 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [828/1000] | Train Loss=0.000291401 | Test Loss=0.001943075 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [829/1000] | Train Loss=0.000290339 | Test Loss=0.001903999 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [830/1000] | Train Loss=0.000297903 | Test Loss=0.001909150 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [831/1000] | Train Loss=0.000287290 | Test Loss=0.001898057 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [832/1000] | Train Loss=0.000289219 | Test Loss=0.001935902 | Time=1.75s | LR=3.91e-06\n",
      "Epoch [833/1000] | Train Loss=0.000286642 | Test Loss=0.001909707 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [834/1000] | Train Loss=0.000295489 | Test Loss=0.001922225 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [835/1000] | Train Loss=0.000287410 | Test Loss=0.001941257 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [836/1000] | Train Loss=0.000289480 | Test Loss=0.001919618 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [837/1000] | Train Loss=0.000288891 | Test Loss=0.001949274 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [838/1000] | Train Loss=0.000290764 | Test Loss=0.001932290 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [839/1000] | Train Loss=0.000295030 | Test Loss=0.001930786 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [840/1000] | Train Loss=0.000287681 | Test Loss=0.001910725 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [841/1000] | Train Loss=0.000295674 | Test Loss=0.001884649 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [842/1000] | Train Loss=0.000291368 | Test Loss=0.001889074 | Time=1.75s | LR=3.91e-06\n",
      "Epoch [843/1000] | Train Loss=0.000291635 | Test Loss=0.001909309 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [844/1000] | Train Loss=0.000290013 | Test Loss=0.001898036 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [845/1000] | Train Loss=0.000288943 | Test Loss=0.001895393 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [846/1000] | Train Loss=0.000304531 | Test Loss=0.001932233 | Time=1.74s | LR=3.91e-06\n",
      "Epoch [847/1000] | Train Loss=0.000288747 | Test Loss=0.001951079 | Time=1.70s | LR=3.91e-06\n",
      "Epoch [848/1000] | Train Loss=0.000289649 | Test Loss=0.001894950 | Time=1.67s | LR=3.91e-06\n",
      "Epoch [849/1000] | Train Loss=0.000300227 | Test Loss=0.001900880 | Time=1.67s | LR=3.91e-06\n",
      "Epoch [850/1000] | Train Loss=0.000288890 | Test Loss=0.001918415 | Time=1.67s | LR=3.91e-06\n",
      "Epoch [851/1000] | Train Loss=0.000295865 | Test Loss=0.001908967 | Time=1.65s | LR=3.91e-06\n",
      "Epoch [852/1000] | Train Loss=0.000292744 | Test Loss=0.001926556 | Time=1.62s | LR=3.91e-06\n",
      "Epoch [853/1000] | Train Loss=0.000289639 | Test Loss=0.001935230 | Time=1.69s | LR=3.91e-06\n",
      "Epoch [854/1000] | Train Loss=0.000286998 | Test Loss=0.001913362 | Time=1.68s | LR=3.91e-06\n",
      "Epoch [855/1000] | Train Loss=0.000291826 | Test Loss=0.001927279 | Time=1.50s | LR=3.91e-06\n",
      "Epoch [856/1000] | Train Loss=0.000303183 | Test Loss=0.001915713 | Time=1.27s | LR=3.91e-06\n",
      "Epoch [857/1000] | Train Loss=0.000292303 | Test Loss=0.001911494 | Time=1.77s | LR=3.91e-06\n",
      "Epoch [858/1000] | Train Loss=0.000288040 | Test Loss=0.001913072 | Time=1.77s | LR=3.91e-06\n",
      "Epoch [859/1000] | Train Loss=0.000293670 | Test Loss=0.001910402 | Time=1.77s | LR=3.91e-06\n",
      "Epoch [860/1000] | Train Loss=0.000286699 | Test Loss=0.001899580 | Time=1.77s | LR=3.91e-06\n",
      "Epoch [861/1000] | Train Loss=0.000290490 | Test Loss=0.001929425 | Time=1.76s | LR=3.91e-06\n",
      "Epoch [862/1000] | Train Loss=0.000293038 | Test Loss=0.001908455 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [863/1000] | Train Loss=0.000286221 | Test Loss=0.001905240 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [864/1000] | Train Loss=0.000288081 | Test Loss=0.001934466 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [865/1000] | Train Loss=0.000286226 | Test Loss=0.001888265 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [866/1000] | Train Loss=0.000286182 | Test Loss=0.001925859 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [867/1000] | Train Loss=0.000289497 | Test Loss=0.001931896 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [868/1000] | Train Loss=0.000287888 | Test Loss=0.001927288 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [869/1000] | Train Loss=0.000289295 | Test Loss=0.001927437 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [870/1000] | Train Loss=0.000285133 | Test Loss=0.001911528 | Time=1.75s | LR=1.95e-06\n",
      "Epoch [871/1000] | Train Loss=0.000287952 | Test Loss=0.001893253 | Time=1.62s | LR=1.95e-06\n",
      "Epoch [872/1000] | Train Loss=0.000292259 | Test Loss=0.001916560 | Time=1.63s | LR=1.95e-06\n",
      "Epoch [873/1000] | Train Loss=0.000289062 | Test Loss=0.001927126 | Time=1.49s | LR=1.95e-06\n",
      "Epoch [874/1000] | Train Loss=0.000286061 | Test Loss=0.001927442 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [875/1000] | Train Loss=0.000287651 | Test Loss=0.001928370 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [876/1000] | Train Loss=0.000284999 | Test Loss=0.001898825 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [877/1000] | Train Loss=0.000284909 | Test Loss=0.001907616 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [878/1000] | Train Loss=0.000284184 | Test Loss=0.001912497 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [879/1000] | Train Loss=0.000284091 | Test Loss=0.001900365 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [880/1000] | Train Loss=0.000282211 | Test Loss=0.001899681 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [881/1000] | Train Loss=0.000284528 | Test Loss=0.001906944 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [882/1000] | Train Loss=0.000288305 | Test Loss=0.001912119 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [883/1000] | Train Loss=0.000289705 | Test Loss=0.001909411 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [884/1000] | Train Loss=0.000290911 | Test Loss=0.001895801 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [885/1000] | Train Loss=0.000291456 | Test Loss=0.001908678 | Time=0.96s | LR=1.95e-06\n",
      "Epoch [886/1000] | Train Loss=0.000287005 | Test Loss=0.001908478 | Time=1.11s | LR=1.95e-06\n",
      "Epoch [887/1000] | Train Loss=0.000287262 | Test Loss=0.001908606 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [888/1000] | Train Loss=0.000290162 | Test Loss=0.001919487 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [889/1000] | Train Loss=0.000283783 | Test Loss=0.001920092 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [890/1000] | Train Loss=0.000285356 | Test Loss=0.001903268 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [891/1000] | Train Loss=0.000287786 | Test Loss=0.001904831 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [892/1000] | Train Loss=0.000286529 | Test Loss=0.001892508 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [893/1000] | Train Loss=0.000289043 | Test Loss=0.001910667 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [894/1000] | Train Loss=0.000286431 | Test Loss=0.001903909 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [895/1000] | Train Loss=0.000288636 | Test Loss=0.001912712 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [896/1000] | Train Loss=0.000289467 | Test Loss=0.001897118 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [897/1000] | Train Loss=0.000282078 | Test Loss=0.001898451 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [898/1000] | Train Loss=0.000287306 | Test Loss=0.001894858 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [899/1000] | Train Loss=0.000285991 | Test Loss=0.001893337 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [900/1000] | Train Loss=0.000285187 | Test Loss=0.001905845 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [901/1000] | Train Loss=0.000283407 | Test Loss=0.001894169 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [902/1000] | Train Loss=0.000288341 | Test Loss=0.001890536 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [903/1000] | Train Loss=0.000286576 | Test Loss=0.001902293 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [904/1000] | Train Loss=0.000283803 | Test Loss=0.001894718 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [905/1000] | Train Loss=0.000291567 | Test Loss=0.001886036 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [906/1000] | Train Loss=0.000289619 | Test Loss=0.001872754 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [907/1000] | Train Loss=0.000284684 | Test Loss=0.001878452 | Time=1.68s | LR=1.95e-06\n",
      "Epoch [908/1000] | Train Loss=0.000288890 | Test Loss=0.001913693 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [909/1000] | Train Loss=0.000289722 | Test Loss=0.001879280 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [910/1000] | Train Loss=0.000288545 | Test Loss=0.001905642 | Time=1.70s | LR=1.95e-06\n",
      "Epoch [911/1000] | Train Loss=0.000289871 | Test Loss=0.001904523 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [912/1000] | Train Loss=0.000284508 | Test Loss=0.001906970 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [913/1000] | Train Loss=0.000285451 | Test Loss=0.001895801 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [914/1000] | Train Loss=0.000288227 | Test Loss=0.001899929 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [915/1000] | Train Loss=0.000285520 | Test Loss=0.001899134 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [916/1000] | Train Loss=0.000281816 | Test Loss=0.001894283 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [917/1000] | Train Loss=0.000282399 | Test Loss=0.001903076 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [918/1000] | Train Loss=0.000289656 | Test Loss=0.001887763 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [919/1000] | Train Loss=0.000284503 | Test Loss=0.001900392 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [920/1000] | Train Loss=0.000290480 | Test Loss=0.001903701 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [921/1000] | Train Loss=0.000284584 | Test Loss=0.001910196 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [922/1000] | Train Loss=0.000284731 | Test Loss=0.001894109 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [923/1000] | Train Loss=0.000284207 | Test Loss=0.001897095 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [924/1000] | Train Loss=0.000283235 | Test Loss=0.001901274 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [925/1000] | Train Loss=0.000284071 | Test Loss=0.001898769 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [926/1000] | Train Loss=0.000287077 | Test Loss=0.001901186 | Time=1.68s | LR=1.95e-06\n",
      "Epoch [927/1000] | Train Loss=0.000284513 | Test Loss=0.001915318 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [928/1000] | Train Loss=0.000282662 | Test Loss=0.001896672 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [929/1000] | Train Loss=0.000286191 | Test Loss=0.001900726 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [930/1000] | Train Loss=0.000280834 | Test Loss=0.001892832 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [931/1000] | Train Loss=0.000284295 | Test Loss=0.001896086 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [932/1000] | Train Loss=0.000287621 | Test Loss=0.001896283 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [933/1000] | Train Loss=0.000285095 | Test Loss=0.001903579 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [934/1000] | Train Loss=0.000284463 | Test Loss=0.001899294 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [935/1000] | Train Loss=0.000283040 | Test Loss=0.001896680 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [936/1000] | Train Loss=0.000288449 | Test Loss=0.001893120 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [937/1000] | Train Loss=0.000287175 | Test Loss=0.001905591 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [938/1000] | Train Loss=0.000284557 | Test Loss=0.001912195 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [939/1000] | Train Loss=0.000288630 | Test Loss=0.001892567 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [940/1000] | Train Loss=0.000287643 | Test Loss=0.001888897 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [941/1000] | Train Loss=0.000288419 | Test Loss=0.001882435 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [942/1000] | Train Loss=0.000287744 | Test Loss=0.001890925 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [943/1000] | Train Loss=0.000286525 | Test Loss=0.001896600 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [944/1000] | Train Loss=0.000284745 | Test Loss=0.001895624 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [945/1000] | Train Loss=0.000287922 | Test Loss=0.001882173 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [946/1000] | Train Loss=0.000285826 | Test Loss=0.001899327 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [947/1000] | Train Loss=0.000289314 | Test Loss=0.001883405 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [948/1000] | Train Loss=0.000285804 | Test Loss=0.001887087 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [949/1000] | Train Loss=0.000283942 | Test Loss=0.001913670 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [950/1000] | Train Loss=0.000287274 | Test Loss=0.001884553 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [951/1000] | Train Loss=0.000288300 | Test Loss=0.001893492 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [952/1000] | Train Loss=0.000285981 | Test Loss=0.001909371 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [953/1000] | Train Loss=0.000293648 | Test Loss=0.001900639 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [954/1000] | Train Loss=0.000283221 | Test Loss=0.001904483 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [955/1000] | Train Loss=0.000282912 | Test Loss=0.001898064 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [956/1000] | Train Loss=0.000287668 | Test Loss=0.001898002 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [957/1000] | Train Loss=0.000286322 | Test Loss=0.001890399 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [958/1000] | Train Loss=0.000283010 | Test Loss=0.001888607 | Time=1.68s | LR=1.95e-06\n",
      "Epoch [959/1000] | Train Loss=0.000283323 | Test Loss=0.001890280 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [960/1000] | Train Loss=0.000289320 | Test Loss=0.001907223 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [961/1000] | Train Loss=0.000285613 | Test Loss=0.001900778 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [962/1000] | Train Loss=0.000287058 | Test Loss=0.001895753 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [963/1000] | Train Loss=0.000284355 | Test Loss=0.001905685 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [964/1000] | Train Loss=0.000287010 | Test Loss=0.001910907 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [965/1000] | Train Loss=0.000286473 | Test Loss=0.001897223 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [966/1000] | Train Loss=0.000289082 | Test Loss=0.001905484 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [967/1000] | Train Loss=0.000285705 | Test Loss=0.001898170 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [968/1000] | Train Loss=0.000290318 | Test Loss=0.001880647 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [969/1000] | Train Loss=0.000283569 | Test Loss=0.001899979 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [970/1000] | Train Loss=0.000284574 | Test Loss=0.001904504 | Time=1.69s | LR=1.95e-06\n",
      "Epoch [971/1000] | Train Loss=0.000283869 | Test Loss=0.001917475 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [972/1000] | Train Loss=0.000283086 | Test Loss=0.001897766 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [973/1000] | Train Loss=0.000286260 | Test Loss=0.001895617 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [974/1000] | Train Loss=0.000282849 | Test Loss=0.001886020 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [975/1000] | Train Loss=0.000284873 | Test Loss=0.001903276 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [976/1000] | Train Loss=0.000282676 | Test Loss=0.001897882 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [977/1000] | Train Loss=0.000281722 | Test Loss=0.001896720 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [978/1000] | Train Loss=0.000284076 | Test Loss=0.001897669 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [979/1000] | Train Loss=0.000282086 | Test Loss=0.001896944 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [980/1000] | Train Loss=0.000283456 | Test Loss=0.001898604 | Time=1.68s | LR=9.77e-07\n",
      "Epoch [981/1000] | Train Loss=0.000282499 | Test Loss=0.001891181 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [982/1000] | Train Loss=0.000284877 | Test Loss=0.001894017 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [983/1000] | Train Loss=0.000284430 | Test Loss=0.001901750 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [984/1000] | Train Loss=0.000283171 | Test Loss=0.001901612 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [985/1000] | Train Loss=0.000286064 | Test Loss=0.001917184 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [986/1000] | Train Loss=0.000281251 | Test Loss=0.001914957 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [987/1000] | Train Loss=0.000281774 | Test Loss=0.001910046 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [988/1000] | Train Loss=0.000287860 | Test Loss=0.001895933 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [989/1000] | Train Loss=0.000283508 | Test Loss=0.001893947 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [990/1000] | Train Loss=0.000282792 | Test Loss=0.001907964 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [991/1000] | Train Loss=0.000285949 | Test Loss=0.001882720 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [992/1000] | Train Loss=0.000283766 | Test Loss=0.001895853 | Time=1.68s | LR=9.77e-07\n",
      "Epoch [993/1000] | Train Loss=0.000287336 | Test Loss=0.001902277 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [994/1000] | Train Loss=0.000283414 | Test Loss=0.001890230 | Time=1.68s | LR=9.77e-07\n",
      "Epoch [995/1000] | Train Loss=0.000282511 | Test Loss=0.001892494 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [996/1000] | Train Loss=0.000284165 | Test Loss=0.001897884 | Time=1.68s | LR=9.77e-07\n",
      "Epoch [997/1000] | Train Loss=0.000287239 | Test Loss=0.001888232 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [998/1000] | Train Loss=0.000282730 | Test Loss=0.001894722 | Time=1.68s | LR=9.77e-07\n",
      "Epoch [999/1000] | Train Loss=0.000279546 | Test Loss=0.001884441 | Time=1.69s | LR=9.77e-07\n",
      "Epoch [1000/1000] | Train Loss=0.000281802 | Test Loss=0.001884977 | Time=1.69s | LR=9.77e-07\n",
      "\n",
      "Total training time: 1715.84 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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kydMmCCKYuCe6Y4dO8QrrrhC1Ol0YoMGDcRXX301IPUXRFE2pSYRERFRHcI+QkRERFRnMRAiIiKiOouBEBEREdVZDISIiIiozmIgRERERHUWAyEiIiKqsxgIERERUZ3FQIiIiIjqLAZCRER+EgQBS5YsCXU1iCgAGAgRUa1y1113QRAEp69hw4aFumpEVAtpQl0BIiJ/DRs2DHPnzlXs0+l0IaoNEdVmzAgRUa2j0+mQmpqq+EpISAAgNVt98MEHuPbaaxEREYHmzZvj+++/V5y/a9cuXH311YiIiEC9evUwceJEFBcXK8p89tln6NChA3Q6HdLS0jBp0iTF8fPnz2P06NGIjIxEq1at8NNPPwX3TRNRUDAQIqJLzrPPPosbb7wRO3bswPjx43HLLbdg3759AICSkhIMHToUCQkJ2Lx5MxYuXIiVK1cqAp0PPvgAGRkZmDhxInbt2oWffvoJLVu2VNzj+eefx7hx47Bz504MHz4c48ePR15eXrW+TyIKgICsYU9EVE0mTJggqtVqMSoqSvH18ssvi6IoigDEBx54QHFO7969xQcffFAURVH8+OOPxYSEBLG4uNh2/NdffxVVKpWYnZ0tiqIopqeni88884zbOgAQ//Of/9i2i4uLRQDib7/9FrD3SUTVg32EiKjWueqqq/DBBx8o9iUmJtpe9+nTR3GsT58+2L59OwBg37596NKlC6KiomzH+/XrB4vFggMHDkAQBJw5cwbXXHONxzp07tzZ9joqKgqxsbHIzc2t7FsiohBhIEREtU5UVJRTU1WgRERE+FROq9UqtgVBgMViCUaViCiI2EeIiC45GzdudNpu164dAKBdu3bYsWMHSkpKbMfXr18PlUqFNm3aICYmBk2bNsWqVauqtc5EFBrMCBFRraPX65Gdna3Yp9FokJSUBABYuHAhevTogSuuuALz5s3Dpk2b8L///Q8AMH78eDz33HOYMGECZs6ciXPnzuHhhx/GHXfcgZSUFADAzJkz8cADDyA5ORnXXnstioqKsH79ejz88MPV+0aJKOgYCBFRrbNs2TKkpaUp9rVp0wb79+8HII3omj9/Ph566CGkpaXh22+/Rfv27QEAkZGR+P333zF58mT07NkTkZGRuPHGG/Hmm2/arjVhwgSUl5fjrbfewtSpU5GUlISxY8dW3xskomojiKIohroSRESBIggCFi9ejFGjRoW6KkRUC7CPEBEREdVZDISIiIiozmIfISK6pLC1n4j8wYwQERER1VkMhIiIiKjOYiBEREREdRYDISIiIqqzGAgRERFRncVAiIiIiOosBkJERERUZzEQIiIiojrr/wF0pDAb4SROLQAAAABJRU5ErkJggg==",
      "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_G2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda:0\n",
      "Epoch [1/1000] | Train Loss=0.002433660 | Test Loss=0.002481378 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [2/1000] | Train Loss=0.001351090 | Test Loss=0.002016941 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [3/1000] | Train Loss=0.001416413 | Test Loss=0.003042242 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [4/1000] | Train Loss=0.002480192 | Test Loss=0.002179809 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [5/1000] | Train Loss=0.001859541 | Test Loss=0.002108471 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [6/1000] | Train Loss=0.001260901 | Test Loss=0.002254121 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [7/1000] | Train Loss=0.001071000 | Test Loss=0.001986887 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [8/1000] | Train Loss=0.001725556 | Test Loss=0.002981864 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [9/1000] | Train Loss=0.002023789 | Test Loss=0.001916247 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [10/1000] | Train Loss=0.001293080 | Test Loss=0.002288095 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [11/1000] | Train Loss=0.002151465 | Test Loss=0.004719229 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [12/1000] | Train Loss=0.002403285 | Test Loss=0.002435911 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [13/1000] | Train Loss=0.001283592 | Test Loss=0.002531091 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [14/1000] | Train Loss=0.001151288 | Test Loss=0.002157514 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [15/1000] | Train Loss=0.001302844 | Test Loss=0.003195172 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [16/1000] | Train Loss=0.001214988 | Test Loss=0.002544958 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [17/1000] | Train Loss=0.001310022 | Test Loss=0.002197697 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [18/1000] | Train Loss=0.001117111 | Test Loss=0.002615163 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [19/1000] | Train Loss=0.001274644 | Test Loss=0.002580918 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [20/1000] | Train Loss=0.001014660 | Test Loss=0.002229835 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [21/1000] | Train Loss=0.001411922 | Test Loss=0.002149892 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [22/1000] | Train Loss=0.001301388 | Test Loss=0.002153912 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [23/1000] | Train Loss=0.001262113 | Test Loss=0.002666735 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [24/1000] | Train Loss=0.001261393 | Test Loss=0.002647112 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [25/1000] | Train Loss=0.001039226 | Test Loss=0.002380561 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [26/1000] | Train Loss=0.001369941 | Test Loss=0.002271965 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [27/1000] | Train Loss=0.001055889 | Test Loss=0.002200535 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [28/1000] | Train Loss=0.001171401 | Test Loss=0.002451763 | Time=1.70s | LR=1.00e-04\n",
      "Epoch [29/1000] | Train Loss=0.001267950 | Test Loss=0.002363702 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [30/1000] | Train Loss=0.001304038 | Test Loss=0.002473627 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [31/1000] | Train Loss=0.001218419 | Test Loss=0.001949073 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [32/1000] | Train Loss=0.001365668 | Test Loss=0.003524278 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [33/1000] | Train Loss=0.001346879 | Test Loss=0.002281577 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [34/1000] | Train Loss=0.002505541 | Test Loss=0.003405624 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [35/1000] | Train Loss=0.002477622 | Test Loss=0.002421019 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [36/1000] | Train Loss=0.001289882 | Test Loss=0.002210287 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [37/1000] | Train Loss=0.001404603 | Test Loss=0.002162969 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [38/1000] | Train Loss=0.001011315 | Test Loss=0.002170812 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [39/1000] | Train Loss=0.001354331 | Test Loss=0.002891805 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [40/1000] | Train Loss=0.001070389 | Test Loss=0.003690511 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [41/1000] | Train Loss=0.001379867 | Test Loss=0.002042616 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [42/1000] | Train Loss=0.001029242 | Test Loss=0.002298341 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [43/1000] | Train Loss=0.001360793 | Test Loss=0.002867820 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [44/1000] | Train Loss=0.001299407 | Test Loss=0.002669897 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [45/1000] | Train Loss=0.001192199 | Test Loss=0.002858480 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [46/1000] | Train Loss=0.001196711 | Test Loss=0.002297979 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [47/1000] | Train Loss=0.001354323 | Test Loss=0.002941396 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [48/1000] | Train Loss=0.001432006 | Test Loss=0.002661278 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [49/1000] | Train Loss=0.001056104 | Test Loss=0.002668075 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [50/1000] | Train Loss=0.001918170 | Test Loss=0.004034314 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [51/1000] | Train Loss=0.001709352 | Test Loss=0.002948113 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [52/1000] | Train Loss=0.001346305 | Test Loss=0.003215517 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [53/1000] | Train Loss=0.001017398 | Test Loss=0.002625225 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [54/1000] | Train Loss=0.001321556 | Test Loss=0.002643390 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [55/1000] | Train Loss=0.001300252 | Test Loss=0.002516930 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [56/1000] | Train Loss=0.001087086 | Test Loss=0.002267900 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [57/1000] | Train Loss=0.001334500 | Test Loss=0.002167298 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [58/1000] | Train Loss=0.001790794 | Test Loss=0.002330359 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [59/1000] | Train Loss=0.001374035 | Test Loss=0.002257814 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [60/1000] | Train Loss=0.001193444 | Test Loss=0.002096261 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [61/1000] | Train Loss=0.001382512 | Test Loss=0.002361584 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [62/1000] | Train Loss=0.001733618 | Test Loss=0.003524500 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [63/1000] | Train Loss=0.001459080 | Test Loss=0.002409094 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [64/1000] | Train Loss=0.001267211 | Test Loss=0.002540840 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [65/1000] | Train Loss=0.001351743 | Test Loss=0.002468283 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [66/1000] | Train Loss=0.001330250 | Test Loss=0.002788170 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [67/1000] | Train Loss=0.001756670 | Test Loss=0.002867160 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [68/1000] | Train Loss=0.001897901 | Test Loss=0.001999917 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [69/1000] | Train Loss=0.001275966 | Test Loss=0.002523165 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [70/1000] | Train Loss=0.001085468 | Test Loss=0.002223688 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [71/1000] | Train Loss=0.001312963 | Test Loss=0.002236330 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [72/1000] | Train Loss=0.001372515 | Test Loss=0.002095142 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [73/1000] | Train Loss=0.001296464 | Test Loss=0.002720555 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [74/1000] | Train Loss=0.001106150 | Test Loss=0.002157798 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [75/1000] | Train Loss=0.001049214 | Test Loss=0.002111869 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [76/1000] | Train Loss=0.001342768 | Test Loss=0.003169610 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [77/1000] | Train Loss=0.001313538 | Test Loss=0.002510797 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [78/1000] | Train Loss=0.001092800 | Test Loss=0.002324608 | Time=1.69s | LR=1.00e-04\n",
      "Epoch [79/1000] | Train Loss=0.001329001 | Test Loss=0.002335789 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [80/1000] | Train Loss=0.000604269 | Test Loss=0.001971085 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [81/1000] | Train Loss=0.000563208 | Test Loss=0.001944675 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [82/1000] | Train Loss=0.000708810 | Test Loss=0.001966772 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [83/1000] | Train Loss=0.000465711 | Test Loss=0.002003601 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [84/1000] | Train Loss=0.000676443 | Test Loss=0.001983025 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [85/1000] | Train Loss=0.000951456 | Test Loss=0.002664937 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [86/1000] | Train Loss=0.000535632 | Test Loss=0.002388752 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [87/1000] | Train Loss=0.000645242 | Test Loss=0.001986105 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [88/1000] | Train Loss=0.000566988 | Test Loss=0.001972832 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [89/1000] | Train Loss=0.000525660 | Test Loss=0.002526501 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [90/1000] | Train Loss=0.000714884 | Test Loss=0.002488166 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [91/1000] | Train Loss=0.000687832 | Test Loss=0.002086712 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [92/1000] | Train Loss=0.000446950 | Test Loss=0.002244392 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [93/1000] | Train Loss=0.000813902 | Test Loss=0.001897297 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [94/1000] | Train Loss=0.000584383 | Test Loss=0.001927841 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [95/1000] | Train Loss=0.000762318 | Test Loss=0.002244797 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [96/1000] | Train Loss=0.000621413 | Test Loss=0.001921781 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [97/1000] | Train Loss=0.000662244 | Test Loss=0.001980602 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [98/1000] | Train Loss=0.000776741 | Test Loss=0.001991319 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [99/1000] | Train Loss=0.000736261 | Test Loss=0.002029818 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [100/1000] | Train Loss=0.000610443 | Test Loss=0.002026923 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [101/1000] | Train Loss=0.000565646 | Test Loss=0.002484111 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [102/1000] | Train Loss=0.000660631 | Test Loss=0.002010372 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [103/1000] | Train Loss=0.000674237 | Test Loss=0.002236653 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [104/1000] | Train Loss=0.000786511 | Test Loss=0.002138880 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [105/1000] | Train Loss=0.000583641 | Test Loss=0.001955306 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [106/1000] | Train Loss=0.000531343 | Test Loss=0.001911662 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [107/1000] | Train Loss=0.000629603 | Test Loss=0.001942843 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [108/1000] | Train Loss=0.000521054 | Test Loss=0.001982020 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [109/1000] | Train Loss=0.000782260 | Test Loss=0.001948962 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [110/1000] | Train Loss=0.000773633 | Test Loss=0.001922915 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [111/1000] | Train Loss=0.000665433 | Test Loss=0.002046486 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [112/1000] | Train Loss=0.000622992 | Test Loss=0.002162151 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [113/1000] | Train Loss=0.000774888 | Test Loss=0.001992415 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [114/1000] | Train Loss=0.000727376 | Test Loss=0.002417554 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [115/1000] | Train Loss=0.000422554 | Test Loss=0.002109003 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [116/1000] | Train Loss=0.000600027 | Test Loss=0.002103071 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [117/1000] | Train Loss=0.000482924 | Test Loss=0.002254364 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [118/1000] | Train Loss=0.000656991 | Test Loss=0.001991494 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [119/1000] | Train Loss=0.000670337 | Test Loss=0.001883503 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [120/1000] | Train Loss=0.000758249 | Test Loss=0.002058508 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [121/1000] | Train Loss=0.000764022 | Test Loss=0.002429374 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [122/1000] | Train Loss=0.000650791 | Test Loss=0.001911269 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [123/1000] | Train Loss=0.000730125 | Test Loss=0.002001715 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [124/1000] | Train Loss=0.000748345 | Test Loss=0.002152999 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [125/1000] | Train Loss=0.000704848 | Test Loss=0.001922601 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [126/1000] | Train Loss=0.000755212 | Test Loss=0.002034335 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [127/1000] | Train Loss=0.000691861 | Test Loss=0.002228551 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [128/1000] | Train Loss=0.000724731 | Test Loss=0.002099936 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [129/1000] | Train Loss=0.000706821 | Test Loss=0.002240247 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [130/1000] | Train Loss=0.000641626 | Test Loss=0.002373900 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [131/1000] | Train Loss=0.000699526 | Test Loss=0.002352524 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [132/1000] | Train Loss=0.000627419 | Test Loss=0.002102341 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [133/1000] | Train Loss=0.000400051 | Test Loss=0.002070601 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [134/1000] | Train Loss=0.000523227 | Test Loss=0.002049910 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [135/1000] | Train Loss=0.000689234 | Test Loss=0.002049583 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [136/1000] | Train Loss=0.000625232 | Test Loss=0.002058264 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [137/1000] | Train Loss=0.000543721 | Test Loss=0.002243179 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [138/1000] | Train Loss=0.000732990 | Test Loss=0.002474891 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [139/1000] | Train Loss=0.000544464 | Test Loss=0.001951531 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [140/1000] | Train Loss=0.000627701 | Test Loss=0.001929455 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [141/1000] | Train Loss=0.000744030 | Test Loss=0.001988603 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [142/1000] | Train Loss=0.000500079 | Test Loss=0.001890932 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [143/1000] | Train Loss=0.000682464 | Test Loss=0.001973703 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [144/1000] | Train Loss=0.000742054 | Test Loss=0.002117373 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [145/1000] | Train Loss=0.000659061 | Test Loss=0.002312003 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [146/1000] | Train Loss=0.000701684 | Test Loss=0.002291606 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [147/1000] | Train Loss=0.000717657 | Test Loss=0.001990360 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [148/1000] | Train Loss=0.000743050 | Test Loss=0.002499792 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [149/1000] | Train Loss=0.000728884 | Test Loss=0.002221949 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [150/1000] | Train Loss=0.000785824 | Test Loss=0.002602811 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [151/1000] | Train Loss=0.001309253 | Test Loss=0.001993474 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [152/1000] | Train Loss=0.001275696 | Test Loss=0.002349359 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [153/1000] | Train Loss=0.000698896 | Test Loss=0.001936445 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [154/1000] | Train Loss=0.000447426 | Test Loss=0.002256447 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [155/1000] | Train Loss=0.000632875 | Test Loss=0.002024449 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [156/1000] | Train Loss=0.000606088 | Test Loss=0.002282351 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [157/1000] | Train Loss=0.000750189 | Test Loss=0.002078106 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [158/1000] | Train Loss=0.000650407 | Test Loss=0.002014826 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [159/1000] | Train Loss=0.000586496 | Test Loss=0.001934769 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [160/1000] | Train Loss=0.000736822 | Test Loss=0.002104510 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [161/1000] | Train Loss=0.000730070 | Test Loss=0.002017130 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [162/1000] | Train Loss=0.000719785 | Test Loss=0.002280375 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [163/1000] | Train Loss=0.000603838 | Test Loss=0.002189643 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [164/1000] | Train Loss=0.000717250 | Test Loss=0.002108008 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [165/1000] | Train Loss=0.000676941 | Test Loss=0.001935630 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [166/1000] | Train Loss=0.000712524 | Test Loss=0.002291544 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [167/1000] | Train Loss=0.000595655 | Test Loss=0.002134263 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [168/1000] | Train Loss=0.000668761 | Test Loss=0.001918963 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [169/1000] | Train Loss=0.000743595 | Test Loss=0.001880055 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [170/1000] | Train Loss=0.000756323 | Test Loss=0.002313748 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [171/1000] | Train Loss=0.000640898 | Test Loss=0.002143871 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [172/1000] | Train Loss=0.000714391 | Test Loss=0.001884233 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [173/1000] | Train Loss=0.000642665 | Test Loss=0.001859014 | Time=1.69s | LR=5.00e-05\n",
      "Epoch [174/1000] | Train Loss=0.000674774 | Test Loss=0.001926845 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [175/1000] | Train Loss=0.000331468 | Test Loss=0.001929895 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [176/1000] | Train Loss=0.000360383 | Test Loss=0.002053711 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [177/1000] | Train Loss=0.000367076 | Test Loss=0.001890810 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [178/1000] | Train Loss=0.000341329 | Test Loss=0.001945208 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [179/1000] | Train Loss=0.000328308 | Test Loss=0.001997994 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [180/1000] | Train Loss=0.000336114 | Test Loss=0.001929452 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [181/1000] | Train Loss=0.000414121 | Test Loss=0.001999960 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [182/1000] | Train Loss=0.000362783 | Test Loss=0.001924007 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [183/1000] | Train Loss=0.000359187 | Test Loss=0.001902374 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [184/1000] | Train Loss=0.000377410 | Test Loss=0.001985581 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [185/1000] | Train Loss=0.000376120 | Test Loss=0.002063175 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [186/1000] | Train Loss=0.000411834 | Test Loss=0.001893171 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [187/1000] | Train Loss=0.000388593 | Test Loss=0.002212804 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [188/1000] | Train Loss=0.000461187 | Test Loss=0.001911022 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [189/1000] | Train Loss=0.000410866 | Test Loss=0.001890797 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [190/1000] | Train Loss=0.000339263 | Test Loss=0.001960775 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [191/1000] | Train Loss=0.000351066 | Test Loss=0.001924097 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [192/1000] | Train Loss=0.000377713 | Test Loss=0.001894505 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [193/1000] | Train Loss=0.000433641 | Test Loss=0.001871655 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [194/1000] | Train Loss=0.000462988 | Test Loss=0.002069369 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [195/1000] | Train Loss=0.000432984 | Test Loss=0.001909920 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [196/1000] | Train Loss=0.000371224 | Test Loss=0.001911797 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [197/1000] | Train Loss=0.000411638 | Test Loss=0.001946712 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [198/1000] | Train Loss=0.000334166 | Test Loss=0.001948424 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [199/1000] | Train Loss=0.000452262 | Test Loss=0.001908650 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [200/1000] | Train Loss=0.000368709 | Test Loss=0.001927747 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [201/1000] | Train Loss=0.000334791 | Test Loss=0.002048478 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [202/1000] | Train Loss=0.000374233 | Test Loss=0.001945218 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [203/1000] | Train Loss=0.000416976 | Test Loss=0.002071757 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [204/1000] | Train Loss=0.000435541 | Test Loss=0.001897519 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [205/1000] | Train Loss=0.000380739 | Test Loss=0.001861046 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [206/1000] | Train Loss=0.000368542 | Test Loss=0.002087058 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [207/1000] | Train Loss=0.000368629 | Test Loss=0.001932872 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [208/1000] | Train Loss=0.000407870 | Test Loss=0.001883812 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [209/1000] | Train Loss=0.000419884 | Test Loss=0.002066548 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [210/1000] | Train Loss=0.000403839 | Test Loss=0.001893070 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [211/1000] | Train Loss=0.000498254 | Test Loss=0.001864787 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [212/1000] | Train Loss=0.000416165 | Test Loss=0.001930641 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [213/1000] | Train Loss=0.000370363 | Test Loss=0.001872312 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [214/1000] | Train Loss=0.000437380 | Test Loss=0.001921281 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [215/1000] | Train Loss=0.000445771 | Test Loss=0.002044891 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [216/1000] | Train Loss=0.000412886 | Test Loss=0.001872167 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [217/1000] | Train Loss=0.000468455 | Test Loss=0.001854886 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [218/1000] | Train Loss=0.000448517 | Test Loss=0.002033520 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [219/1000] | Train Loss=0.000394889 | Test Loss=0.001977435 | Time=1.69s | LR=2.50e-05\n",
      "Epoch [220/1000] | Train Loss=0.000363678 | Test Loss=0.001848336 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [221/1000] | Train Loss=0.000290089 | Test Loss=0.001925566 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [222/1000] | Train Loss=0.000299426 | Test Loss=0.001929731 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [223/1000] | Train Loss=0.000297381 | Test Loss=0.001890809 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [224/1000] | Train Loss=0.000303762 | Test Loss=0.001871593 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [225/1000] | Train Loss=0.000309385 | Test Loss=0.001942244 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [226/1000] | Train Loss=0.000300085 | Test Loss=0.001895804 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [227/1000] | Train Loss=0.000319047 | Test Loss=0.001904937 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [228/1000] | Train Loss=0.000295392 | Test Loss=0.001879533 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [229/1000] | Train Loss=0.000316796 | Test Loss=0.001945207 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [230/1000] | Train Loss=0.000292191 | Test Loss=0.001869754 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [231/1000] | Train Loss=0.000307901 | Test Loss=0.001830269 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [232/1000] | Train Loss=0.000323069 | Test Loss=0.001844600 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [233/1000] | Train Loss=0.000301752 | Test Loss=0.001897564 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [234/1000] | Train Loss=0.000300815 | Test Loss=0.001847683 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [235/1000] | Train Loss=0.000309679 | Test Loss=0.001874894 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [236/1000] | Train Loss=0.000309447 | Test Loss=0.001875929 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [237/1000] | Train Loss=0.000297742 | Test Loss=0.001855980 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [238/1000] | Train Loss=0.000319362 | Test Loss=0.001911179 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [239/1000] | Train Loss=0.000287950 | Test Loss=0.001934960 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [240/1000] | Train Loss=0.000324293 | Test Loss=0.001914177 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [241/1000] | Train Loss=0.000311974 | Test Loss=0.001936427 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [242/1000] | Train Loss=0.000300632 | Test Loss=0.001891292 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [243/1000] | Train Loss=0.000317358 | Test Loss=0.001940609 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [244/1000] | Train Loss=0.000325218 | Test Loss=0.001883807 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [245/1000] | Train Loss=0.000297054 | Test Loss=0.001852276 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [246/1000] | Train Loss=0.000305157 | Test Loss=0.001899200 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [247/1000] | Train Loss=0.000314306 | Test Loss=0.001914638 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [248/1000] | Train Loss=0.000293572 | Test Loss=0.001882928 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [249/1000] | Train Loss=0.000346167 | Test Loss=0.001899160 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [250/1000] | Train Loss=0.000290397 | Test Loss=0.001880900 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [251/1000] | Train Loss=0.000326778 | Test Loss=0.001908548 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [252/1000] | Train Loss=0.000294364 | Test Loss=0.001865351 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [253/1000] | Train Loss=0.000318853 | Test Loss=0.001963220 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [254/1000] | Train Loss=0.000316181 | Test Loss=0.001962536 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [255/1000] | Train Loss=0.000309355 | Test Loss=0.001888973 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [256/1000] | Train Loss=0.000349057 | Test Loss=0.001925905 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [257/1000] | Train Loss=0.000319298 | Test Loss=0.001895243 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [258/1000] | Train Loss=0.000306302 | Test Loss=0.001838322 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [259/1000] | Train Loss=0.000296834 | Test Loss=0.001875111 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [260/1000] | Train Loss=0.000304010 | Test Loss=0.001886166 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [261/1000] | Train Loss=0.000337700 | Test Loss=0.001915986 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [262/1000] | Train Loss=0.000305028 | Test Loss=0.001824753 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [263/1000] | Train Loss=0.000339170 | Test Loss=0.001954214 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [264/1000] | Train Loss=0.000309171 | Test Loss=0.001865802 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [265/1000] | Train Loss=0.000288291 | Test Loss=0.001864293 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [266/1000] | Train Loss=0.000296923 | Test Loss=0.001834272 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [267/1000] | Train Loss=0.000319504 | Test Loss=0.001916359 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [268/1000] | Train Loss=0.000328946 | Test Loss=0.001932629 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [269/1000] | Train Loss=0.000307670 | Test Loss=0.001948345 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [270/1000] | Train Loss=0.000299598 | Test Loss=0.001859060 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [271/1000] | Train Loss=0.000290022 | Test Loss=0.001881554 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [272/1000] | Train Loss=0.000312536 | Test Loss=0.001920819 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [273/1000] | Train Loss=0.000302431 | Test Loss=0.001899457 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [274/1000] | Train Loss=0.000288310 | Test Loss=0.001920925 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [275/1000] | Train Loss=0.000304487 | Test Loss=0.001905946 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [276/1000] | Train Loss=0.000355706 | Test Loss=0.001824240 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [277/1000] | Train Loss=0.000313256 | Test Loss=0.001941651 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [278/1000] | Train Loss=0.000306552 | Test Loss=0.001972775 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [279/1000] | Train Loss=0.000312657 | Test Loss=0.001863576 | Time=1.69s | LR=1.25e-05\n",
      "Epoch [280/1000] | Train Loss=0.000294805 | Test Loss=0.001881361 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [281/1000] | Train Loss=0.000276692 | Test Loss=0.001853589 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [282/1000] | Train Loss=0.000285533 | Test Loss=0.001864967 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [283/1000] | Train Loss=0.000281007 | Test Loss=0.001885782 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [284/1000] | Train Loss=0.000278912 | Test Loss=0.001870357 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [285/1000] | Train Loss=0.000293661 | Test Loss=0.001880434 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [286/1000] | Train Loss=0.000288868 | Test Loss=0.001895588 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [287/1000] | Train Loss=0.000285314 | Test Loss=0.001842262 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [288/1000] | Train Loss=0.000282480 | Test Loss=0.001882931 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [289/1000] | Train Loss=0.000289550 | Test Loss=0.001849579 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [290/1000] | Train Loss=0.000282664 | Test Loss=0.001839874 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [291/1000] | Train Loss=0.000280672 | Test Loss=0.001852845 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [292/1000] | Train Loss=0.000290907 | Test Loss=0.001861345 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [293/1000] | Train Loss=0.000288573 | Test Loss=0.001854303 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [294/1000] | Train Loss=0.000285434 | Test Loss=0.001865077 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [295/1000] | Train Loss=0.000290803 | Test Loss=0.001861478 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [296/1000] | Train Loss=0.000281738 | Test Loss=0.001842425 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [297/1000] | Train Loss=0.000285765 | Test Loss=0.001863113 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [298/1000] | Train Loss=0.000283061 | Test Loss=0.001844833 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [299/1000] | Train Loss=0.000290412 | Test Loss=0.001860480 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [300/1000] | Train Loss=0.000294988 | Test Loss=0.001896240 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [301/1000] | Train Loss=0.000289015 | Test Loss=0.001868334 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [302/1000] | Train Loss=0.000280473 | Test Loss=0.001872769 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [303/1000] | Train Loss=0.000291813 | Test Loss=0.001869624 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [304/1000] | Train Loss=0.000291685 | Test Loss=0.001858352 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [305/1000] | Train Loss=0.000287569 | Test Loss=0.001906251 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [306/1000] | Train Loss=0.000287601 | Test Loss=0.001867948 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [307/1000] | Train Loss=0.000289026 | Test Loss=0.001879450 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [308/1000] | Train Loss=0.000289685 | Test Loss=0.001872199 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [309/1000] | Train Loss=0.000295583 | Test Loss=0.001845098 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [310/1000] | Train Loss=0.000287293 | Test Loss=0.001869199 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [311/1000] | Train Loss=0.000285255 | Test Loss=0.001891482 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [312/1000] | Train Loss=0.000286909 | Test Loss=0.001850181 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [313/1000] | Train Loss=0.000290160 | Test Loss=0.001837596 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [314/1000] | Train Loss=0.000282253 | Test Loss=0.001831268 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [315/1000] | Train Loss=0.000289168 | Test Loss=0.001868613 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [316/1000] | Train Loss=0.000282908 | Test Loss=0.001827041 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [317/1000] | Train Loss=0.000282577 | Test Loss=0.001828150 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [318/1000] | Train Loss=0.000287944 | Test Loss=0.001845542 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [319/1000] | Train Loss=0.000282733 | Test Loss=0.001823530 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [320/1000] | Train Loss=0.000282606 | Test Loss=0.001850993 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [321/1000] | Train Loss=0.000287472 | Test Loss=0.001881802 | Time=1.69s | LR=6.25e-06\n",
      "Epoch [322/1000] | Train Loss=0.000296897 | Test Loss=0.001835788 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [323/1000] | Train Loss=0.000272963 | Test Loss=0.001841402 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [324/1000] | Train Loss=0.000273703 | Test Loss=0.001843768 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [325/1000] | Train Loss=0.000276226 | Test Loss=0.001837033 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [326/1000] | Train Loss=0.000271717 | Test Loss=0.001826535 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [327/1000] | Train Loss=0.000276293 | Test Loss=0.001847039 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [328/1000] | Train Loss=0.000278991 | Test Loss=0.001826240 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [329/1000] | Train Loss=0.000276525 | Test Loss=0.001862879 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [330/1000] | Train Loss=0.000271440 | Test Loss=0.001832819 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [331/1000] | Train Loss=0.000276708 | Test Loss=0.001847315 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [332/1000] | Train Loss=0.000276814 | Test Loss=0.001827513 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [333/1000] | Train Loss=0.000275635 | Test Loss=0.001839262 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [334/1000] | Train Loss=0.000281478 | Test Loss=0.001841079 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [335/1000] | Train Loss=0.000279085 | Test Loss=0.001858880 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [336/1000] | Train Loss=0.000276295 | Test Loss=0.001832935 | Time=1.70s | LR=3.13e-06\n",
      "Epoch [337/1000] | Train Loss=0.000279590 | Test Loss=0.001860541 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [338/1000] | Train Loss=0.000276116 | Test Loss=0.001885361 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [339/1000] | Train Loss=0.000282580 | Test Loss=0.001841290 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [340/1000] | Train Loss=0.000286494 | Test Loss=0.001856061 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [341/1000] | Train Loss=0.000274773 | Test Loss=0.001841412 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [342/1000] | Train Loss=0.000278044 | Test Loss=0.001857178 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [343/1000] | Train Loss=0.000278552 | Test Loss=0.001870461 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [344/1000] | Train Loss=0.000283898 | Test Loss=0.001828349 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [345/1000] | Train Loss=0.000280694 | Test Loss=0.001880743 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [346/1000] | Train Loss=0.000279515 | Test Loss=0.001810207 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [347/1000] | Train Loss=0.000282037 | Test Loss=0.001838246 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [348/1000] | Train Loss=0.000279166 | Test Loss=0.001846715 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [349/1000] | Train Loss=0.000272692 | Test Loss=0.001844551 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [350/1000] | Train Loss=0.000277086 | Test Loss=0.001849166 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [351/1000] | Train Loss=0.000274634 | Test Loss=0.001848823 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [352/1000] | Train Loss=0.000281147 | Test Loss=0.001843636 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [353/1000] | Train Loss=0.000277636 | Test Loss=0.001863054 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [354/1000] | Train Loss=0.000278103 | Test Loss=0.001843490 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [355/1000] | Train Loss=0.000277468 | Test Loss=0.001826830 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [356/1000] | Train Loss=0.000281557 | Test Loss=0.001839372 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [357/1000] | Train Loss=0.000281256 | Test Loss=0.001820115 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [358/1000] | Train Loss=0.000274788 | Test Loss=0.001851843 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [359/1000] | Train Loss=0.000274813 | Test Loss=0.001835951 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [360/1000] | Train Loss=0.000277268 | Test Loss=0.001830563 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [361/1000] | Train Loss=0.000280076 | Test Loss=0.001839370 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [362/1000] | Train Loss=0.000280466 | Test Loss=0.001843672 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [363/1000] | Train Loss=0.000283424 | Test Loss=0.001848716 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [364/1000] | Train Loss=0.000279521 | Test Loss=0.001850005 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [365/1000] | Train Loss=0.000273188 | Test Loss=0.001829279 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [366/1000] | Train Loss=0.000276499 | Test Loss=0.001839272 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [367/1000] | Train Loss=0.000278232 | Test Loss=0.001854594 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [368/1000] | Train Loss=0.000277957 | Test Loss=0.001831617 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [369/1000] | Train Loss=0.000275697 | Test Loss=0.001819437 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [370/1000] | Train Loss=0.000283539 | Test Loss=0.001836176 | Time=1.69s | LR=3.13e-06\n",
      "Epoch [371/1000] | Train Loss=0.000276747 | Test Loss=0.001825604 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [372/1000] | Train Loss=0.000273335 | Test Loss=0.001838516 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [373/1000] | Train Loss=0.000273274 | Test Loss=0.001841386 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [374/1000] | Train Loss=0.000275014 | Test Loss=0.001841076 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [375/1000] | Train Loss=0.000272137 | Test Loss=0.001827290 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [376/1000] | Train Loss=0.000272553 | Test Loss=0.001822063 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [377/1000] | Train Loss=0.000280039 | Test Loss=0.001826123 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [378/1000] | Train Loss=0.000277633 | Test Loss=0.001837391 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [379/1000] | Train Loss=0.000273449 | Test Loss=0.001837010 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [380/1000] | Train Loss=0.000271842 | Test Loss=0.001827670 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [381/1000] | Train Loss=0.000271434 | Test Loss=0.001837712 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [382/1000] | Train Loss=0.000276023 | Test Loss=0.001814954 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [383/1000] | Train Loss=0.000272831 | Test Loss=0.001818664 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [384/1000] | Train Loss=0.000273508 | Test Loss=0.001843889 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [385/1000] | Train Loss=0.000274814 | Test Loss=0.001839255 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [386/1000] | Train Loss=0.000274610 | Test Loss=0.001842987 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [387/1000] | Train Loss=0.000274803 | Test Loss=0.001825311 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [388/1000] | Train Loss=0.000272793 | Test Loss=0.001845166 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [389/1000] | Train Loss=0.000275396 | Test Loss=0.001823401 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [390/1000] | Train Loss=0.000271817 | Test Loss=0.001824026 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [391/1000] | Train Loss=0.000280372 | Test Loss=0.001841768 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [392/1000] | Train Loss=0.000275633 | Test Loss=0.001852153 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [393/1000] | Train Loss=0.000273371 | Test Loss=0.001831504 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [394/1000] | Train Loss=0.000272952 | Test Loss=0.001810672 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [395/1000] | Train Loss=0.000278126 | Test Loss=0.001834470 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [396/1000] | Train Loss=0.000271396 | Test Loss=0.001821211 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [397/1000] | Train Loss=0.000275628 | Test Loss=0.001836622 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [398/1000] | Train Loss=0.000272512 | Test Loss=0.001835435 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [399/1000] | Train Loss=0.000276853 | Test Loss=0.001832996 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [400/1000] | Train Loss=0.000275025 | Test Loss=0.001842644 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [401/1000] | Train Loss=0.000274775 | Test Loss=0.001838262 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [402/1000] | Train Loss=0.000274920 | Test Loss=0.001848639 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [403/1000] | Train Loss=0.000273276 | Test Loss=0.001821548 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [404/1000] | Train Loss=0.000273412 | Test Loss=0.001844265 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [405/1000] | Train Loss=0.000272645 | Test Loss=0.001827550 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [406/1000] | Train Loss=0.000274389 | Test Loss=0.001833936 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [407/1000] | Train Loss=0.000271392 | Test Loss=0.001826922 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [408/1000] | Train Loss=0.000274585 | Test Loss=0.001842446 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [409/1000] | Train Loss=0.000275125 | Test Loss=0.001850368 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [410/1000] | Train Loss=0.000273323 | Test Loss=0.001832919 | Time=1.70s | LR=1.56e-06\n",
      "Epoch [411/1000] | Train Loss=0.000278067 | Test Loss=0.001850724 | Time=1.70s | LR=1.56e-06\n",
      "Epoch [412/1000] | Train Loss=0.000273466 | Test Loss=0.001842617 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [413/1000] | Train Loss=0.000275637 | Test Loss=0.001850602 | Time=1.70s | LR=1.56e-06\n",
      "Epoch [414/1000] | Train Loss=0.000274278 | Test Loss=0.001822486 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [415/1000] | Train Loss=0.000274601 | Test Loss=0.001834439 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [416/1000] | Train Loss=0.000273705 | Test Loss=0.001832783 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [417/1000] | Train Loss=0.000276147 | Test Loss=0.001855711 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [418/1000] | Train Loss=0.000272633 | Test Loss=0.001850076 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [419/1000] | Train Loss=0.000270680 | Test Loss=0.001833216 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [420/1000] | Train Loss=0.000277884 | Test Loss=0.001848715 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [421/1000] | Train Loss=0.000274665 | Test Loss=0.001837863 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [422/1000] | Train Loss=0.000277052 | Test Loss=0.001826293 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [423/1000] | Train Loss=0.000277863 | Test Loss=0.001831897 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [424/1000] | Train Loss=0.000274385 | Test Loss=0.001840764 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [425/1000] | Train Loss=0.000269394 | Test Loss=0.001841978 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [426/1000] | Train Loss=0.000272513 | Test Loss=0.001843833 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [427/1000] | Train Loss=0.000271192 | Test Loss=0.001843436 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [428/1000] | Train Loss=0.000273121 | Test Loss=0.001849926 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [429/1000] | Train Loss=0.000270734 | Test Loss=0.001819041 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [430/1000] | Train Loss=0.000275515 | Test Loss=0.001833412 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [431/1000] | Train Loss=0.000269109 | Test Loss=0.001831760 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [432/1000] | Train Loss=0.000272956 | Test Loss=0.001830900 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [433/1000] | Train Loss=0.000275113 | Test Loss=0.001842600 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [434/1000] | Train Loss=0.000273062 | Test Loss=0.001822474 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [435/1000] | Train Loss=0.000271734 | Test Loss=0.001839381 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [436/1000] | Train Loss=0.000271452 | Test Loss=0.001835446 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [437/1000] | Train Loss=0.000273724 | Test Loss=0.001825904 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [438/1000] | Train Loss=0.000283935 | Test Loss=0.001827605 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [439/1000] | Train Loss=0.000273803 | Test Loss=0.001854495 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [440/1000] | Train Loss=0.000273796 | Test Loss=0.001824285 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [441/1000] | Train Loss=0.000269510 | Test Loss=0.001831185 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [442/1000] | Train Loss=0.000274226 | Test Loss=0.001833698 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [443/1000] | Train Loss=0.000274042 | Test Loss=0.001832627 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [444/1000] | Train Loss=0.000275802 | Test Loss=0.001827227 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [445/1000] | Train Loss=0.000270458 | Test Loss=0.001844154 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [446/1000] | Train Loss=0.000276658 | Test Loss=0.001849190 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [447/1000] | Train Loss=0.000269785 | Test Loss=0.001831804 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [448/1000] | Train Loss=0.000273993 | Test Loss=0.001842337 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [449/1000] | Train Loss=0.000275263 | Test Loss=0.001834787 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [450/1000] | Train Loss=0.000275691 | Test Loss=0.001830742 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [451/1000] | Train Loss=0.000274557 | Test Loss=0.001860233 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [452/1000] | Train Loss=0.000269971 | Test Loss=0.001815166 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [453/1000] | Train Loss=0.000269283 | Test Loss=0.001828228 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [454/1000] | Train Loss=0.000271510 | Test Loss=0.001835368 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [455/1000] | Train Loss=0.000271701 | Test Loss=0.001846885 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [456/1000] | Train Loss=0.000273467 | Test Loss=0.001844473 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [457/1000] | Train Loss=0.000273992 | Test Loss=0.001851445 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [458/1000] | Train Loss=0.000273416 | Test Loss=0.001824568 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [459/1000] | Train Loss=0.000275936 | Test Loss=0.001815447 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [460/1000] | Train Loss=0.000271728 | Test Loss=0.001813745 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [461/1000] | Train Loss=0.000275645 | Test Loss=0.001841064 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [462/1000] | Train Loss=0.000271392 | Test Loss=0.001829205 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [463/1000] | Train Loss=0.000274798 | Test Loss=0.001847339 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [464/1000] | Train Loss=0.000273117 | Test Loss=0.001840476 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [465/1000] | Train Loss=0.000274951 | Test Loss=0.001818477 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [466/1000] | Train Loss=0.000278606 | Test Loss=0.001810396 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [467/1000] | Train Loss=0.000278296 | Test Loss=0.001841008 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [468/1000] | Train Loss=0.000272267 | Test Loss=0.001846793 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [469/1000] | Train Loss=0.000269431 | Test Loss=0.001826195 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [470/1000] | Train Loss=0.000273414 | Test Loss=0.001836789 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [471/1000] | Train Loss=0.000273501 | Test Loss=0.001810642 | Time=1.69s | LR=1.56e-06\n",
      "Epoch [472/1000] | Train Loss=0.000275884 | Test Loss=0.001822191 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [473/1000] | Train Loss=0.000275849 | Test Loss=0.001820489 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [474/1000] | Train Loss=0.000272937 | Test Loss=0.001837769 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [475/1000] | Train Loss=0.000272863 | Test Loss=0.001841626 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [476/1000] | Train Loss=0.000272766 | Test Loss=0.001817510 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [477/1000] | Train Loss=0.000273951 | Test Loss=0.001833181 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [478/1000] | Train Loss=0.000269452 | Test Loss=0.001821434 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [479/1000] | Train Loss=0.000271720 | Test Loss=0.001826195 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [480/1000] | Train Loss=0.000268339 | Test Loss=0.001824352 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [481/1000] | Train Loss=0.000271575 | Test Loss=0.001830602 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [482/1000] | Train Loss=0.000272805 | Test Loss=0.001828674 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [483/1000] | Train Loss=0.000270098 | Test Loss=0.001834306 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [484/1000] | Train Loss=0.000272116 | Test Loss=0.001821972 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [485/1000] | Train Loss=0.000271572 | Test Loss=0.001820053 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [486/1000] | Train Loss=0.000271552 | Test Loss=0.001819785 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [487/1000] | Train Loss=0.000269875 | Test Loss=0.001833574 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [488/1000] | Train Loss=0.000272843 | Test Loss=0.001819785 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [489/1000] | Train Loss=0.000266981 | Test Loss=0.001820574 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [490/1000] | Train Loss=0.000269910 | Test Loss=0.001824186 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [491/1000] | Train Loss=0.000269684 | Test Loss=0.001819213 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [492/1000] | Train Loss=0.000270204 | Test Loss=0.001837901 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [493/1000] | Train Loss=0.000275108 | Test Loss=0.001818205 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [494/1000] | Train Loss=0.000273577 | Test Loss=0.001829645 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [495/1000] | Train Loss=0.000273587 | Test Loss=0.001822580 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [496/1000] | Train Loss=0.000273880 | Test Loss=0.001830663 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [497/1000] | Train Loss=0.000271738 | Test Loss=0.001809003 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [498/1000] | Train Loss=0.000273220 | Test Loss=0.001817992 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [499/1000] | Train Loss=0.000271540 | Test Loss=0.001810940 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [500/1000] | Train Loss=0.000271629 | Test Loss=0.001819631 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [501/1000] | Train Loss=0.000271649 | Test Loss=0.001831848 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [502/1000] | Train Loss=0.000272132 | Test Loss=0.001823781 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [503/1000] | Train Loss=0.000268150 | Test Loss=0.001823109 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [504/1000] | Train Loss=0.000270053 | Test Loss=0.001819668 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [505/1000] | Train Loss=0.000271087 | Test Loss=0.001820992 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [506/1000] | Train Loss=0.000274562 | Test Loss=0.001817454 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [507/1000] | Train Loss=0.000271816 | Test Loss=0.001804308 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [508/1000] | Train Loss=0.000273449 | Test Loss=0.001814457 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [509/1000] | Train Loss=0.000268819 | Test Loss=0.001818223 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [510/1000] | Train Loss=0.000269172 | Test Loss=0.001813478 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [511/1000] | Train Loss=0.000271191 | Test Loss=0.001816315 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [512/1000] | Train Loss=0.000268768 | Test Loss=0.001827129 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [513/1000] | Train Loss=0.000268758 | Test Loss=0.001803998 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [514/1000] | Train Loss=0.000272428 | Test Loss=0.001816260 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [515/1000] | Train Loss=0.000272233 | Test Loss=0.001804419 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [516/1000] | Train Loss=0.000274575 | Test Loss=0.001827761 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [517/1000] | Train Loss=0.000277284 | Test Loss=0.001812876 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [518/1000] | Train Loss=0.000269550 | Test Loss=0.001817022 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [519/1000] | Train Loss=0.000269474 | Test Loss=0.001819226 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [520/1000] | Train Loss=0.000276005 | Test Loss=0.001828170 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [521/1000] | Train Loss=0.000268879 | Test Loss=0.001824829 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [522/1000] | Train Loss=0.000272189 | Test Loss=0.001813369 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [523/1000] | Train Loss=0.000271365 | Test Loss=0.001829155 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [524/1000] | Train Loss=0.000270680 | Test Loss=0.001826994 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [525/1000] | Train Loss=0.000269164 | Test Loss=0.001829257 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [526/1000] | Train Loss=0.000272234 | Test Loss=0.001818395 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [527/1000] | Train Loss=0.000269667 | Test Loss=0.001818745 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [528/1000] | Train Loss=0.000272037 | Test Loss=0.001826685 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [529/1000] | Train Loss=0.000272116 | Test Loss=0.001827309 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [530/1000] | Train Loss=0.000266145 | Test Loss=0.001828285 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [531/1000] | Train Loss=0.000272962 | Test Loss=0.001839112 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [532/1000] | Train Loss=0.000274607 | Test Loss=0.001818026 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [533/1000] | Train Loss=0.000275921 | Test Loss=0.001822435 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [534/1000] | Train Loss=0.000270707 | Test Loss=0.001829094 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [535/1000] | Train Loss=0.000268566 | Test Loss=0.001825705 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [536/1000] | Train Loss=0.000270036 | Test Loss=0.001829944 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [537/1000] | Train Loss=0.000276718 | Test Loss=0.001816136 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [538/1000] | Train Loss=0.000269332 | Test Loss=0.001830260 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [539/1000] | Train Loss=0.000268842 | Test Loss=0.001835640 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [540/1000] | Train Loss=0.000269688 | Test Loss=0.001834354 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [541/1000] | Train Loss=0.000272904 | Test Loss=0.001826279 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [542/1000] | Train Loss=0.000268037 | Test Loss=0.001856624 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [543/1000] | Train Loss=0.000274366 | Test Loss=0.001833757 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [544/1000] | Train Loss=0.000273741 | Test Loss=0.001841437 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [545/1000] | Train Loss=0.000273010 | Test Loss=0.001844883 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [546/1000] | Train Loss=0.000271753 | Test Loss=0.001830208 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [547/1000] | Train Loss=0.000271734 | Test Loss=0.001833837 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [548/1000] | Train Loss=0.000270698 | Test Loss=0.001826373 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [549/1000] | Train Loss=0.000268832 | Test Loss=0.001830583 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [550/1000] | Train Loss=0.000272360 | Test Loss=0.001833440 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [551/1000] | Train Loss=0.000271353 | Test Loss=0.001830979 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [552/1000] | Train Loss=0.000268248 | Test Loss=0.001833616 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [553/1000] | Train Loss=0.000272848 | Test Loss=0.001841584 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [554/1000] | Train Loss=0.000270401 | Test Loss=0.001827482 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [555/1000] | Train Loss=0.000271134 | Test Loss=0.001830054 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [556/1000] | Train Loss=0.000268823 | Test Loss=0.001838714 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [557/1000] | Train Loss=0.000269456 | Test Loss=0.001829292 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [558/1000] | Train Loss=0.000270616 | Test Loss=0.001829788 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [559/1000] | Train Loss=0.000272135 | Test Loss=0.001838481 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [560/1000] | Train Loss=0.000273584 | Test Loss=0.001835294 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [561/1000] | Train Loss=0.000274500 | Test Loss=0.001847117 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [562/1000] | Train Loss=0.000271748 | Test Loss=0.001828679 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [563/1000] | Train Loss=0.000273106 | Test Loss=0.001841350 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [564/1000] | Train Loss=0.000268671 | Test Loss=0.001835787 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [565/1000] | Train Loss=0.000268773 | Test Loss=0.001824976 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [566/1000] | Train Loss=0.000272881 | Test Loss=0.001840697 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [567/1000] | Train Loss=0.000271179 | Test Loss=0.001850525 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [568/1000] | Train Loss=0.000274104 | Test Loss=0.001827854 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [569/1000] | Train Loss=0.000270520 | Test Loss=0.001828667 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [570/1000] | Train Loss=0.000268996 | Test Loss=0.001845987 | Time=1.69s | LR=7.81e-07\n",
      "Epoch [571/1000] | Train Loss=0.000271807 | Test Loss=0.001830091 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [572/1000] | Train Loss=0.000272534 | Test Loss=0.001820527 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [573/1000] | Train Loss=0.000270178 | Test Loss=0.001832059 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [574/1000] | Train Loss=0.000267405 | Test Loss=0.001835094 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [575/1000] | Train Loss=0.000271417 | Test Loss=0.001838394 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [576/1000] | Train Loss=0.000271331 | Test Loss=0.001834285 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [577/1000] | Train Loss=0.000271463 | Test Loss=0.001824595 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [578/1000] | Train Loss=0.000267629 | Test Loss=0.001826403 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [579/1000] | Train Loss=0.000273027 | Test Loss=0.001824369 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [580/1000] | Train Loss=0.000272104 | Test Loss=0.001833226 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [581/1000] | Train Loss=0.000268711 | Test Loss=0.001834023 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [582/1000] | Train Loss=0.000269157 | Test Loss=0.001818004 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [583/1000] | Train Loss=0.000265841 | Test Loss=0.001831040 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [584/1000] | Train Loss=0.000266493 | Test Loss=0.001831064 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [585/1000] | Train Loss=0.000272537 | Test Loss=0.001819925 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [586/1000] | Train Loss=0.000269026 | Test Loss=0.001825633 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [587/1000] | Train Loss=0.000265892 | Test Loss=0.001833766 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [588/1000] | Train Loss=0.000273824 | Test Loss=0.001819253 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [589/1000] | Train Loss=0.000267628 | Test Loss=0.001828393 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [590/1000] | Train Loss=0.000268066 | Test Loss=0.001834283 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [591/1000] | Train Loss=0.000269167 | Test Loss=0.001832756 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [592/1000] | Train Loss=0.000268680 | Test Loss=0.001818987 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [593/1000] | Train Loss=0.000265729 | Test Loss=0.001834279 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [594/1000] | Train Loss=0.000269148 | Test Loss=0.001822170 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [595/1000] | Train Loss=0.000270832 | Test Loss=0.001827549 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [596/1000] | Train Loss=0.000271351 | Test Loss=0.001830458 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [597/1000] | Train Loss=0.000271109 | Test Loss=0.001816748 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [598/1000] | Train Loss=0.000272480 | Test Loss=0.001833548 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [599/1000] | Train Loss=0.000271586 | Test Loss=0.001820221 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [600/1000] | Train Loss=0.000271179 | Test Loss=0.001815261 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [601/1000] | Train Loss=0.000273474 | Test Loss=0.001821965 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [602/1000] | Train Loss=0.000269531 | Test Loss=0.001834123 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [603/1000] | Train Loss=0.000274793 | Test Loss=0.001820816 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [604/1000] | Train Loss=0.000268512 | Test Loss=0.001832763 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [605/1000] | Train Loss=0.000271200 | Test Loss=0.001834883 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [606/1000] | Train Loss=0.000268286 | Test Loss=0.001826755 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [607/1000] | Train Loss=0.000272301 | Test Loss=0.001832244 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [608/1000] | Train Loss=0.000271699 | Test Loss=0.001817707 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [609/1000] | Train Loss=0.000272077 | Test Loss=0.001828375 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [610/1000] | Train Loss=0.000270172 | Test Loss=0.001834303 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [611/1000] | Train Loss=0.000270941 | Test Loss=0.001826373 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [612/1000] | Train Loss=0.000277274 | Test Loss=0.001824618 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [613/1000] | Train Loss=0.000270807 | Test Loss=0.001838817 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [614/1000] | Train Loss=0.000267099 | Test Loss=0.001829011 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [615/1000] | Train Loss=0.000266534 | Test Loss=0.001831032 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [616/1000] | Train Loss=0.000268907 | Test Loss=0.001825873 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [617/1000] | Train Loss=0.000267927 | Test Loss=0.001837609 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [618/1000] | Train Loss=0.000267212 | Test Loss=0.001836655 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [619/1000] | Train Loss=0.000268431 | Test Loss=0.001820238 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [620/1000] | Train Loss=0.000268324 | Test Loss=0.001823107 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [621/1000] | Train Loss=0.000267455 | Test Loss=0.001848147 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [622/1000] | Train Loss=0.000268752 | Test Loss=0.001825053 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [623/1000] | Train Loss=0.000270217 | Test Loss=0.001826015 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [624/1000] | Train Loss=0.000274208 | Test Loss=0.001833670 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [625/1000] | Train Loss=0.000271911 | Test Loss=0.001832102 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [626/1000] | Train Loss=0.000272549 | Test Loss=0.001827086 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [627/1000] | Train Loss=0.000272760 | Test Loss=0.001820410 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [628/1000] | Train Loss=0.000268856 | Test Loss=0.001818128 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [629/1000] | Train Loss=0.000269843 | Test Loss=0.001821193 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [630/1000] | Train Loss=0.000273551 | Test Loss=0.001821844 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [631/1000] | Train Loss=0.000270313 | Test Loss=0.001824620 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [632/1000] | Train Loss=0.000269898 | Test Loss=0.001826917 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [633/1000] | Train Loss=0.000269143 | Test Loss=0.001822141 | Time=1.69s | LR=3.91e-07\n",
      "Epoch [634/1000] | Train Loss=0.000271974 | Test Loss=0.001833116 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [635/1000] | Train Loss=0.000268527 | Test Loss=0.001822811 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [636/1000] | Train Loss=0.000268962 | Test Loss=0.001831961 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [637/1000] | Train Loss=0.000269615 | Test Loss=0.001823363 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [638/1000] | Train Loss=0.000271875 | Test Loss=0.001826668 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [639/1000] | Train Loss=0.000268457 | Test Loss=0.001824386 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [640/1000] | Train Loss=0.000267326 | Test Loss=0.001813050 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [641/1000] | Train Loss=0.000267322 | Test Loss=0.001821358 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [642/1000] | Train Loss=0.000271250 | Test Loss=0.001828792 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [643/1000] | Train Loss=0.000265468 | Test Loss=0.001823687 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [644/1000] | Train Loss=0.000267995 | Test Loss=0.001824562 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [645/1000] | Train Loss=0.000269513 | Test Loss=0.001828639 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [646/1000] | Train Loss=0.000273257 | Test Loss=0.001829615 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [647/1000] | Train Loss=0.000271088 | Test Loss=0.001829276 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [648/1000] | Train Loss=0.000270440 | Test Loss=0.001820352 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [649/1000] | Train Loss=0.000268810 | Test Loss=0.001816699 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [650/1000] | Train Loss=0.000269105 | Test Loss=0.001816980 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [651/1000] | Train Loss=0.000267525 | Test Loss=0.001822259 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [652/1000] | Train Loss=0.000267905 | Test Loss=0.001823843 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [653/1000] | Train Loss=0.000271392 | Test Loss=0.001823221 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [654/1000] | Train Loss=0.000267676 | Test Loss=0.001819474 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [655/1000] | Train Loss=0.000266957 | Test Loss=0.001819696 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [656/1000] | Train Loss=0.000268688 | Test Loss=0.001828460 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [657/1000] | Train Loss=0.000270852 | Test Loss=0.001817418 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [658/1000] | Train Loss=0.000267922 | Test Loss=0.001811642 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [659/1000] | Train Loss=0.000268052 | Test Loss=0.001818982 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [660/1000] | Train Loss=0.000267840 | Test Loss=0.001816113 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [661/1000] | Train Loss=0.000268321 | Test Loss=0.001824219 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [662/1000] | Train Loss=0.000271870 | Test Loss=0.001821111 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [663/1000] | Train Loss=0.000268745 | Test Loss=0.001819142 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [664/1000] | Train Loss=0.000273516 | Test Loss=0.001815698 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [665/1000] | Train Loss=0.000272691 | Test Loss=0.001826557 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [666/1000] | Train Loss=0.000269046 | Test Loss=0.001827306 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [667/1000] | Train Loss=0.000267769 | Test Loss=0.001826350 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [668/1000] | Train Loss=0.000266907 | Test Loss=0.001823198 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [669/1000] | Train Loss=0.000266466 | Test Loss=0.001820583 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [670/1000] | Train Loss=0.000268430 | Test Loss=0.001825504 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [671/1000] | Train Loss=0.000267419 | Test Loss=0.001822355 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [672/1000] | Train Loss=0.000269340 | Test Loss=0.001816872 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [673/1000] | Train Loss=0.000269842 | Test Loss=0.001817371 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [674/1000] | Train Loss=0.000268208 | Test Loss=0.001823398 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [675/1000] | Train Loss=0.000269315 | Test Loss=0.001812529 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [676/1000] | Train Loss=0.000270756 | Test Loss=0.001818824 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [677/1000] | Train Loss=0.000272100 | Test Loss=0.001820952 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [678/1000] | Train Loss=0.000269702 | Test Loss=0.001814990 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [679/1000] | Train Loss=0.000266510 | Test Loss=0.001822567 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [680/1000] | Train Loss=0.000268178 | Test Loss=0.001825281 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [681/1000] | Train Loss=0.000270530 | Test Loss=0.001813633 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [682/1000] | Train Loss=0.000269407 | Test Loss=0.001817114 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [683/1000] | Train Loss=0.000268533 | Test Loss=0.001817572 | Time=1.69s | LR=1.95e-07\n",
      "Epoch [684/1000] | Train Loss=0.000265519 | Test Loss=0.001814482 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [685/1000] | Train Loss=0.000264754 | Test Loss=0.001814992 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [686/1000] | Train Loss=0.000269940 | Test Loss=0.001818112 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [687/1000] | Train Loss=0.000268816 | Test Loss=0.001819117 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [688/1000] | Train Loss=0.000267445 | Test Loss=0.001812181 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [689/1000] | Train Loss=0.000267374 | Test Loss=0.001820702 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [690/1000] | Train Loss=0.000267894 | Test Loss=0.001814422 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [691/1000] | Train Loss=0.000269505 | Test Loss=0.001814312 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [692/1000] | Train Loss=0.000267374 | Test Loss=0.001814864 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [693/1000] | Train Loss=0.000269600 | Test Loss=0.001817457 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [694/1000] | Train Loss=0.000267508 | Test Loss=0.001816187 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [695/1000] | Train Loss=0.000268072 | Test Loss=0.001813964 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [696/1000] | Train Loss=0.000268214 | Test Loss=0.001818486 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [697/1000] | Train Loss=0.000268850 | Test Loss=0.001812492 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [698/1000] | Train Loss=0.000270510 | Test Loss=0.001813970 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [699/1000] | Train Loss=0.000268065 | Test Loss=0.001817331 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [700/1000] | Train Loss=0.000273156 | Test Loss=0.001815677 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [701/1000] | Train Loss=0.000270001 | Test Loss=0.001812475 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [702/1000] | Train Loss=0.000265492 | Test Loss=0.001821622 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [703/1000] | Train Loss=0.000273701 | Test Loss=0.001817746 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [704/1000] | Train Loss=0.000269658 | Test Loss=0.001815011 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [705/1000] | Train Loss=0.000267155 | Test Loss=0.001821310 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [706/1000] | Train Loss=0.000268378 | Test Loss=0.001817854 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [707/1000] | Train Loss=0.000266020 | Test Loss=0.001826614 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [708/1000] | Train Loss=0.000271768 | Test Loss=0.001820012 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [709/1000] | Train Loss=0.000266455 | Test Loss=0.001827773 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [710/1000] | Train Loss=0.000271398 | Test Loss=0.001821851 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [711/1000] | Train Loss=0.000271621 | Test Loss=0.001825932 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [712/1000] | Train Loss=0.000266255 | Test Loss=0.001821836 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [713/1000] | Train Loss=0.000271030 | Test Loss=0.001824901 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [714/1000] | Train Loss=0.000265958 | Test Loss=0.001825887 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [715/1000] | Train Loss=0.000269436 | Test Loss=0.001820487 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [716/1000] | Train Loss=0.000268832 | Test Loss=0.001822557 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [717/1000] | Train Loss=0.000269727 | Test Loss=0.001823881 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [718/1000] | Train Loss=0.000265844 | Test Loss=0.001818286 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [719/1000] | Train Loss=0.000266498 | Test Loss=0.001823654 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [720/1000] | Train Loss=0.000268179 | Test Loss=0.001826944 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [721/1000] | Train Loss=0.000269786 | Test Loss=0.001823671 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [722/1000] | Train Loss=0.000266661 | Test Loss=0.001819221 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [723/1000] | Train Loss=0.000265193 | Test Loss=0.001825105 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [724/1000] | Train Loss=0.000271861 | Test Loss=0.001825246 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [725/1000] | Train Loss=0.000271231 | Test Loss=0.001822047 | Time=1.69s | LR=9.77e-08\n",
      "Epoch [726/1000] | Train Loss=0.000267941 | Test Loss=0.001824984 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [727/1000] | Train Loss=0.000269958 | Test Loss=0.001817124 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [728/1000] | Train Loss=0.000269586 | Test Loss=0.001820041 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [729/1000] | Train Loss=0.000269112 | Test Loss=0.001819285 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [730/1000] | Train Loss=0.000271413 | Test Loss=0.001819647 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [731/1000] | Train Loss=0.000270637 | Test Loss=0.001817218 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [732/1000] | Train Loss=0.000267564 | Test Loss=0.001818711 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [733/1000] | Train Loss=0.000269700 | Test Loss=0.001822494 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [734/1000] | Train Loss=0.000268844 | Test Loss=0.001819263 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [735/1000] | Train Loss=0.000267270 | Test Loss=0.001820717 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [736/1000] | Train Loss=0.000267253 | Test Loss=0.001819000 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [737/1000] | Train Loss=0.000266785 | Test Loss=0.001816650 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [738/1000] | Train Loss=0.000270754 | Test Loss=0.001816336 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [739/1000] | Train Loss=0.000267120 | Test Loss=0.001818148 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [740/1000] | Train Loss=0.000268856 | Test Loss=0.001817342 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [741/1000] | Train Loss=0.000268178 | Test Loss=0.001817359 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [742/1000] | Train Loss=0.000269001 | Test Loss=0.001813757 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [743/1000] | Train Loss=0.000266195 | Test Loss=0.001817151 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [744/1000] | Train Loss=0.000269352 | Test Loss=0.001817445 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [745/1000] | Train Loss=0.000267478 | Test Loss=0.001820835 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [746/1000] | Train Loss=0.000268317 | Test Loss=0.001816758 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [747/1000] | Train Loss=0.000266653 | Test Loss=0.001814573 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [748/1000] | Train Loss=0.000274604 | Test Loss=0.001817456 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [749/1000] | Train Loss=0.000268330 | Test Loss=0.001819289 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [750/1000] | Train Loss=0.000266774 | Test Loss=0.001815028 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [751/1000] | Train Loss=0.000269006 | Test Loss=0.001820905 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [752/1000] | Train Loss=0.000270810 | Test Loss=0.001815632 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [753/1000] | Train Loss=0.000270382 | Test Loss=0.001815830 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [754/1000] | Train Loss=0.000270218 | Test Loss=0.001816453 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [755/1000] | Train Loss=0.000268755 | Test Loss=0.001813169 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [756/1000] | Train Loss=0.000269539 | Test Loss=0.001813332 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [757/1000] | Train Loss=0.000267185 | Test Loss=0.001811921 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [758/1000] | Train Loss=0.000266089 | Test Loss=0.001815789 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [759/1000] | Train Loss=0.000267291 | Test Loss=0.001809719 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [760/1000] | Train Loss=0.000266594 | Test Loss=0.001812769 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [761/1000] | Train Loss=0.000269922 | Test Loss=0.001813953 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [762/1000] | Train Loss=0.000268774 | Test Loss=0.001815208 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [763/1000] | Train Loss=0.000272364 | Test Loss=0.001815222 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [764/1000] | Train Loss=0.000268792 | Test Loss=0.001810410 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [765/1000] | Train Loss=0.000270419 | Test Loss=0.001814756 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [766/1000] | Train Loss=0.000269954 | Test Loss=0.001817148 | Time=1.69s | LR=4.88e-08\n",
      "Epoch [767/1000] | Train Loss=0.000268262 | Test Loss=0.001816965 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [768/1000] | Train Loss=0.000267435 | Test Loss=0.001816078 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [769/1000] | Train Loss=0.000269123 | Test Loss=0.001819793 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [770/1000] | Train Loss=0.000274002 | Test Loss=0.001815190 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [771/1000] | Train Loss=0.000267133 | Test Loss=0.001813513 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [772/1000] | Train Loss=0.000269962 | Test Loss=0.001814994 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [773/1000] | Train Loss=0.000269484 | Test Loss=0.001812862 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [774/1000] | Train Loss=0.000267792 | Test Loss=0.001815634 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [775/1000] | Train Loss=0.000268767 | Test Loss=0.001817838 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [776/1000] | Train Loss=0.000272353 | Test Loss=0.001818492 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [777/1000] | Train Loss=0.000269858 | Test Loss=0.001818040 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [778/1000] | Train Loss=0.000269568 | Test Loss=0.001816274 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [779/1000] | Train Loss=0.000270881 | Test Loss=0.001815214 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [780/1000] | Train Loss=0.000271934 | Test Loss=0.001815939 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [781/1000] | Train Loss=0.000268423 | Test Loss=0.001815909 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [782/1000] | Train Loss=0.000268789 | Test Loss=0.001817612 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [783/1000] | Train Loss=0.000271803 | Test Loss=0.001819236 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [784/1000] | Train Loss=0.000268695 | Test Loss=0.001816910 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [785/1000] | Train Loss=0.000272507 | Test Loss=0.001820265 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [786/1000] | Train Loss=0.000265603 | Test Loss=0.001814889 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [787/1000] | Train Loss=0.000266987 | Test Loss=0.001818291 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [788/1000] | Train Loss=0.000273471 | Test Loss=0.001816292 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [789/1000] | Train Loss=0.000266154 | Test Loss=0.001817196 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [790/1000] | Train Loss=0.000267099 | Test Loss=0.001816115 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [791/1000] | Train Loss=0.000266148 | Test Loss=0.001816343 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [792/1000] | Train Loss=0.000269061 | Test Loss=0.001816745 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [793/1000] | Train Loss=0.000271246 | Test Loss=0.001818372 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [794/1000] | Train Loss=0.000267391 | Test Loss=0.001814529 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [795/1000] | Train Loss=0.000267002 | Test Loss=0.001812792 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [796/1000] | Train Loss=0.000267164 | Test Loss=0.001815784 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [797/1000] | Train Loss=0.000273594 | Test Loss=0.001810424 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [798/1000] | Train Loss=0.000270145 | Test Loss=0.001811730 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [799/1000] | Train Loss=0.000268427 | Test Loss=0.001814192 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [800/1000] | Train Loss=0.000270088 | Test Loss=0.001815710 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [801/1000] | Train Loss=0.000267178 | Test Loss=0.001815490 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [802/1000] | Train Loss=0.000265493 | Test Loss=0.001813192 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [803/1000] | Train Loss=0.000266863 | Test Loss=0.001818090 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [804/1000] | Train Loss=0.000269222 | Test Loss=0.001814321 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [805/1000] | Train Loss=0.000268419 | Test Loss=0.001815664 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [806/1000] | Train Loss=0.000271596 | Test Loss=0.001813862 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [807/1000] | Train Loss=0.000273603 | Test Loss=0.001814261 | Time=1.69s | LR=2.44e-08\n",
      "Epoch [808/1000] | Train Loss=0.000278612 | Test Loss=0.001813261 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [809/1000] | Train Loss=0.000269292 | Test Loss=0.001812314 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [810/1000] | Train Loss=0.000271496 | Test Loss=0.001811293 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [811/1000] | Train Loss=0.000266603 | Test Loss=0.001813910 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [812/1000] | Train Loss=0.000270519 | Test Loss=0.001815036 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [813/1000] | Train Loss=0.000266673 | Test Loss=0.001812833 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [814/1000] | Train Loss=0.000269706 | Test Loss=0.001813830 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [815/1000] | Train Loss=0.000265649 | Test Loss=0.001811543 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [816/1000] | Train Loss=0.000267025 | Test Loss=0.001812429 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [817/1000] | Train Loss=0.000267880 | Test Loss=0.001812334 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [818/1000] | Train Loss=0.000269600 | Test Loss=0.001811028 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [819/1000] | Train Loss=0.000269615 | Test Loss=0.001811542 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [820/1000] | Train Loss=0.000265949 | Test Loss=0.001814589 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [821/1000] | Train Loss=0.000270813 | Test Loss=0.001811777 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [822/1000] | Train Loss=0.000267344 | Test Loss=0.001814217 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [823/1000] | Train Loss=0.000268724 | Test Loss=0.001810656 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [824/1000] | Train Loss=0.000272946 | Test Loss=0.001813726 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [825/1000] | Train Loss=0.000267289 | Test Loss=0.001812445 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [826/1000] | Train Loss=0.000267327 | Test Loss=0.001810430 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [827/1000] | Train Loss=0.000272177 | Test Loss=0.001811762 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [828/1000] | Train Loss=0.000268813 | Test Loss=0.001812751 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [829/1000] | Train Loss=0.000269561 | Test Loss=0.001812475 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [830/1000] | Train Loss=0.000268153 | Test Loss=0.001809258 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [831/1000] | Train Loss=0.000268767 | Test Loss=0.001811166 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [832/1000] | Train Loss=0.000270562 | Test Loss=0.001812008 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [833/1000] | Train Loss=0.000266289 | Test Loss=0.001813558 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [834/1000] | Train Loss=0.000268265 | Test Loss=0.001812923 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [835/1000] | Train Loss=0.000267032 | Test Loss=0.001812413 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [836/1000] | Train Loss=0.000268335 | Test Loss=0.001814311 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [837/1000] | Train Loss=0.000273159 | Test Loss=0.001811993 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [838/1000] | Train Loss=0.000269355 | Test Loss=0.001813701 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [839/1000] | Train Loss=0.000270108 | Test Loss=0.001811693 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [840/1000] | Train Loss=0.000272116 | Test Loss=0.001812537 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [841/1000] | Train Loss=0.000267805 | Test Loss=0.001809844 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [842/1000] | Train Loss=0.000266514 | Test Loss=0.001812583 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [843/1000] | Train Loss=0.000277274 | Test Loss=0.001814036 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [844/1000] | Train Loss=0.000271625 | Test Loss=0.001811820 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [845/1000] | Train Loss=0.000271185 | Test Loss=0.001812501 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [846/1000] | Train Loss=0.000267931 | Test Loss=0.001812691 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [847/1000] | Train Loss=0.000267622 | Test Loss=0.001814156 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [848/1000] | Train Loss=0.000269336 | Test Loss=0.001814395 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [849/1000] | Train Loss=0.000270211 | Test Loss=0.001814203 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [850/1000] | Train Loss=0.000266002 | Test Loss=0.001813752 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [851/1000] | Train Loss=0.000266038 | Test Loss=0.001811185 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [852/1000] | Train Loss=0.000269173 | Test Loss=0.001812674 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [853/1000] | Train Loss=0.000267643 | Test Loss=0.001811584 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [854/1000] | Train Loss=0.000269050 | Test Loss=0.001811123 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [855/1000] | Train Loss=0.000265112 | Test Loss=0.001812666 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [856/1000] | Train Loss=0.000264657 | Test Loss=0.001812883 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [857/1000] | Train Loss=0.000269368 | Test Loss=0.001811454 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [858/1000] | Train Loss=0.000265924 | Test Loss=0.001812407 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [859/1000] | Train Loss=0.000268050 | Test Loss=0.001814917 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [860/1000] | Train Loss=0.000266963 | Test Loss=0.001811985 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [861/1000] | Train Loss=0.000271069 | Test Loss=0.001812825 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [862/1000] | Train Loss=0.000272259 | Test Loss=0.001813353 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [863/1000] | Train Loss=0.000270066 | Test Loss=0.001815025 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [864/1000] | Train Loss=0.000266932 | Test Loss=0.001816403 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [865/1000] | Train Loss=0.000271301 | Test Loss=0.001812106 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [866/1000] | Train Loss=0.000266964 | Test Loss=0.001812002 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [867/1000] | Train Loss=0.000264724 | Test Loss=0.001811679 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [868/1000] | Train Loss=0.000268948 | Test Loss=0.001812947 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [869/1000] | Train Loss=0.000267722 | Test Loss=0.001812832 | Time=1.70s | LR=1.22e-08\n",
      "Epoch [870/1000] | Train Loss=0.000268002 | Test Loss=0.001813941 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [871/1000] | Train Loss=0.000268910 | Test Loss=0.001814761 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [872/1000] | Train Loss=0.000268112 | Test Loss=0.001814193 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [873/1000] | Train Loss=0.000270853 | Test Loss=0.001814968 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [874/1000] | Train Loss=0.000267022 | Test Loss=0.001813108 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [875/1000] | Train Loss=0.000271841 | Test Loss=0.001814006 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [876/1000] | Train Loss=0.000268574 | Test Loss=0.001812416 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [877/1000] | Train Loss=0.000268689 | Test Loss=0.001811978 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [878/1000] | Train Loss=0.000267898 | Test Loss=0.001813138 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [879/1000] | Train Loss=0.000268284 | Test Loss=0.001810980 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [880/1000] | Train Loss=0.000268467 | Test Loss=0.001811599 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [881/1000] | Train Loss=0.000265625 | Test Loss=0.001812354 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [882/1000] | Train Loss=0.000268735 | Test Loss=0.001812266 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [883/1000] | Train Loss=0.000271290 | Test Loss=0.001808608 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [884/1000] | Train Loss=0.000265802 | Test Loss=0.001810209 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [885/1000] | Train Loss=0.000267504 | Test Loss=0.001806743 | Time=1.74s | LR=1.22e-08\n",
      "Epoch [886/1000] | Train Loss=0.000270690 | Test Loss=0.001810399 | Time=1.73s | LR=1.22e-08\n",
      "Epoch [887/1000] | Train Loss=0.000269112 | Test Loss=0.001810881 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [888/1000] | Train Loss=0.000269268 | Test Loss=0.001811649 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [889/1000] | Train Loss=0.000273111 | Test Loss=0.001810229 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [890/1000] | Train Loss=0.000266093 | Test Loss=0.001810393 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [891/1000] | Train Loss=0.000268407 | Test Loss=0.001810528 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [892/1000] | Train Loss=0.000268882 | Test Loss=0.001811472 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [893/1000] | Train Loss=0.000265373 | Test Loss=0.001810188 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [894/1000] | Train Loss=0.000266075 | Test Loss=0.001808866 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [895/1000] | Train Loss=0.000268338 | Test Loss=0.001807881 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [896/1000] | Train Loss=0.000272710 | Test Loss=0.001809668 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [897/1000] | Train Loss=0.000267048 | Test Loss=0.001810854 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [898/1000] | Train Loss=0.000268965 | Test Loss=0.001809795 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [899/1000] | Train Loss=0.000268808 | Test Loss=0.001808948 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [900/1000] | Train Loss=0.000266833 | Test Loss=0.001811754 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [901/1000] | Train Loss=0.000271490 | Test Loss=0.001810485 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [902/1000] | Train Loss=0.000267239 | Test Loss=0.001810964 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [903/1000] | Train Loss=0.000269573 | Test Loss=0.001810068 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [904/1000] | Train Loss=0.000272184 | Test Loss=0.001808238 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [905/1000] | Train Loss=0.000267151 | Test Loss=0.001808588 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [906/1000] | Train Loss=0.000271155 | Test Loss=0.001808978 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [907/1000] | Train Loss=0.000269494 | Test Loss=0.001809262 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [908/1000] | Train Loss=0.000268640 | Test Loss=0.001809819 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [909/1000] | Train Loss=0.000268196 | Test Loss=0.001809236 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [910/1000] | Train Loss=0.000265645 | Test Loss=0.001810088 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [911/1000] | Train Loss=0.000271883 | Test Loss=0.001810783 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [912/1000] | Train Loss=0.000267911 | Test Loss=0.001809963 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [913/1000] | Train Loss=0.000270919 | Test Loss=0.001807879 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [914/1000] | Train Loss=0.000276594 | Test Loss=0.001810867 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [915/1000] | Train Loss=0.000266633 | Test Loss=0.001808445 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [916/1000] | Train Loss=0.000269259 | Test Loss=0.001809668 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [917/1000] | Train Loss=0.000265693 | Test Loss=0.001809477 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [918/1000] | Train Loss=0.000266377 | Test Loss=0.001808108 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [919/1000] | Train Loss=0.000267310 | Test Loss=0.001808971 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [920/1000] | Train Loss=0.000267019 | Test Loss=0.001807315 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [921/1000] | Train Loss=0.000266783 | Test Loss=0.001806719 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [922/1000] | Train Loss=0.000267758 | Test Loss=0.001808457 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [923/1000] | Train Loss=0.000269291 | Test Loss=0.001808145 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [924/1000] | Train Loss=0.000271238 | Test Loss=0.001807611 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [925/1000] | Train Loss=0.000266422 | Test Loss=0.001809190 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [926/1000] | Train Loss=0.000269042 | Test Loss=0.001807017 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [927/1000] | Train Loss=0.000268324 | Test Loss=0.001807819 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [928/1000] | Train Loss=0.000268685 | Test Loss=0.001807599 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [929/1000] | Train Loss=0.000264680 | Test Loss=0.001807137 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [930/1000] | Train Loss=0.000268518 | Test Loss=0.001806094 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [931/1000] | Train Loss=0.000266206 | Test Loss=0.001809145 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [932/1000] | Train Loss=0.000267007 | Test Loss=0.001808795 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [933/1000] | Train Loss=0.000266295 | Test Loss=0.001806942 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [934/1000] | Train Loss=0.000269581 | Test Loss=0.001807486 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [935/1000] | Train Loss=0.000264461 | Test Loss=0.001808040 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [936/1000] | Train Loss=0.000271654 | Test Loss=0.001808306 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [937/1000] | Train Loss=0.000269330 | Test Loss=0.001807582 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [938/1000] | Train Loss=0.000269746 | Test Loss=0.001809664 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [939/1000] | Train Loss=0.000269297 | Test Loss=0.001809913 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [940/1000] | Train Loss=0.000271493 | Test Loss=0.001808387 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [941/1000] | Train Loss=0.000269181 | Test Loss=0.001810306 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [942/1000] | Train Loss=0.000263621 | Test Loss=0.001810488 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [943/1000] | Train Loss=0.000266143 | Test Loss=0.001811558 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [944/1000] | Train Loss=0.000269211 | Test Loss=0.001809144 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [945/1000] | Train Loss=0.000266699 | Test Loss=0.001810936 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [946/1000] | Train Loss=0.000264604 | Test Loss=0.001810400 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [947/1000] | Train Loss=0.000269433 | Test Loss=0.001809300 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [948/1000] | Train Loss=0.000266841 | Test Loss=0.001809332 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [949/1000] | Train Loss=0.000270091 | Test Loss=0.001813023 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [950/1000] | Train Loss=0.000266981 | Test Loss=0.001809865 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [951/1000] | Train Loss=0.000267438 | Test Loss=0.001806849 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [952/1000] | Train Loss=0.000268999 | Test Loss=0.001811124 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [953/1000] | Train Loss=0.000268373 | Test Loss=0.001808445 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [954/1000] | Train Loss=0.000268554 | Test Loss=0.001808181 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [955/1000] | Train Loss=0.000267831 | Test Loss=0.001809081 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [956/1000] | Train Loss=0.000272283 | Test Loss=0.001809746 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [957/1000] | Train Loss=0.000268213 | Test Loss=0.001809399 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [958/1000] | Train Loss=0.000268071 | Test Loss=0.001807791 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [959/1000] | Train Loss=0.000268127 | Test Loss=0.001809289 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [960/1000] | Train Loss=0.000267893 | Test Loss=0.001809412 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [961/1000] | Train Loss=0.000271924 | Test Loss=0.001808066 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [962/1000] | Train Loss=0.000268183 | Test Loss=0.001810335 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [963/1000] | Train Loss=0.000271851 | Test Loss=0.001811350 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [964/1000] | Train Loss=0.000269247 | Test Loss=0.001810397 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [965/1000] | Train Loss=0.000266820 | Test Loss=0.001809484 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [966/1000] | Train Loss=0.000267849 | Test Loss=0.001809468 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [967/1000] | Train Loss=0.000268240 | Test Loss=0.001812485 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [968/1000] | Train Loss=0.000269929 | Test Loss=0.001810392 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [969/1000] | Train Loss=0.000269845 | Test Loss=0.001811310 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [970/1000] | Train Loss=0.000266832 | Test Loss=0.001810791 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [971/1000] | Train Loss=0.000269103 | Test Loss=0.001808234 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [972/1000] | Train Loss=0.000269501 | Test Loss=0.001809585 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [973/1000] | Train Loss=0.000266818 | Test Loss=0.001810334 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [974/1000] | Train Loss=0.000267160 | Test Loss=0.001809372 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [975/1000] | Train Loss=0.000268054 | Test Loss=0.001809262 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [976/1000] | Train Loss=0.000265827 | Test Loss=0.001809787 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [977/1000] | Train Loss=0.000267730 | Test Loss=0.001812141 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [978/1000] | Train Loss=0.000267745 | Test Loss=0.001810343 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [979/1000] | Train Loss=0.000270219 | Test Loss=0.001808667 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [980/1000] | Train Loss=0.000269654 | Test Loss=0.001809954 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [981/1000] | Train Loss=0.000267495 | Test Loss=0.001811639 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [982/1000] | Train Loss=0.000265801 | Test Loss=0.001810314 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [983/1000] | Train Loss=0.000268853 | Test Loss=0.001810656 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [984/1000] | Train Loss=0.000270282 | Test Loss=0.001809672 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [985/1000] | Train Loss=0.000268843 | Test Loss=0.001809969 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [986/1000] | Train Loss=0.000268765 | Test Loss=0.001810393 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [987/1000] | Train Loss=0.000266436 | Test Loss=0.001810751 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [988/1000] | Train Loss=0.000268896 | Test Loss=0.001810387 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [989/1000] | Train Loss=0.000267158 | Test Loss=0.001810240 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [990/1000] | Train Loss=0.000267983 | Test Loss=0.001811011 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [991/1000] | Train Loss=0.000266874 | Test Loss=0.001809846 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [992/1000] | Train Loss=0.000268977 | Test Loss=0.001811014 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [993/1000] | Train Loss=0.000266772 | Test Loss=0.001813180 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [994/1000] | Train Loss=0.000265641 | Test Loss=0.001811353 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [995/1000] | Train Loss=0.000267117 | Test Loss=0.001809140 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [996/1000] | Train Loss=0.000265633 | Test Loss=0.001808752 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [997/1000] | Train Loss=0.000268470 | Test Loss=0.001809092 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [998/1000] | Train Loss=0.000268849 | Test Loss=0.001808063 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [999/1000] | Train Loss=0.000268630 | Test Loss=0.001811857 | Time=1.69s | LR=1.22e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000270682 | Test Loss=0.001811425 | Time=1.69s | LR=1.22e-08\n",
      "\n",
      "Total training time: 1690.46 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_G2.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00009786\n",
      "Function type: periodic             | Relative L2: 0.00021957\n",
      "Function type: sine_beats           | Relative L2: 0.00027065\n",
      "\n",
      "Overall relative L2 error: 0.00012026\n",
      "--------------test----------------\n",
      "Function type: gaussian_hermite     | Relative L2: 0.00259001\n",
      "Function type: sinc_pulse           | Relative L2: 0.00249376\n",
      "Function type: wave_packet          | Relative L2: 0.00160692\n",
      "\n",
      "Overall relative L2 error: 0.00164742\n",
      "-------------sample----------------\n",
      "Function type: chirped_cosine       | Relative L2: 0.00010955\n",
      "Function type: periodic             | Relative L2: 0.00022560\n",
      "Function type: sine_beats           | Relative L2: 0.00029623\n",
      "\n",
      "Overall relative L2 error: 0.00013434\n"
     ]
    }
   ],
   "source": [
    "device = 'cuda:0'\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
}
