{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from neuralop.layers.embeddings import GridEmbeddingND  # adjust the import path as needed\n",
    "\n",
    "def convert_dataset_for_fno(dataset):\n",
    "    \"\"\"\n",
    "    (Unchanged) Convert each sample in the dataset to the FNO 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 at least 4 elements: (x, f, Gf, func_type).\")\n",
    "        x, f, Gf, func_type = sample[:4]\n",
    "        if f.ndim == 1: f = f.unsqueeze(0)\n",
    "        if Gf.ndim == 1: Gf = Gf.unsqueeze(0)\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",
    "def adjust_input_shape(f, Gf):\n",
    "    \"\"\"\n",
    "    Ensure that input tensors f and Gf have shape (batch, channels, spatial_dim).\n",
    "    If they are of shape (batch, spatial_dim) or (channels, spatial_dim),\n",
    "    add an extra dimension.\n",
    "    \"\"\"\n",
    "    # If f has 2 dimensions, assume it is (channels, n) and unsqueeze batch dimension.\n",
    "    if f.ndim == 2:\n",
    "        f = f.unsqueeze(0)  # now (1, channels, n)\n",
    "    if f.ndim == 2:\n",
    "        f = f.unsqueeze(1)\n",
    "    if f.ndim == 2:\n",
    "        f = f.unsqueeze(0)\n",
    "    \n",
    "    if Gf.ndim == 2:\n",
    "        Gf = Gf.unsqueeze(0)\n",
    "    if Gf.ndim == 2:\n",
    "        Gf = Gf.unsqueeze(1)\n",
    "    if Gf.ndim == 2:\n",
    "        Gf = Gf.unsqueeze(0)\n",
    "    \n",
    "    return f, Gf\n",
    "\n",
    "def adjust_positional_embedding_to_1d(operator):\n",
    "    \"\"\"\n",
    "    If the operator has a GridEmbeddingND positional embedding that is not 1D,\n",
    "    adjust it so that it expects 1D inputs.\n",
    "    \"\"\"\n",
    "    if hasattr(operator, \"positional_embedding\") and operator.positional_embedding is not None:\n",
    "        emb = operator.positional_embedding\n",
    "        if isinstance(emb, GridEmbeddingND):\n",
    "            if emb.dim != 1:\n",
    "                print(\"Adjusting positional_embedding to 1D.\")\n",
    "                emb.dim = 1\n",
    "                emb.grid_boundaries = [[-torch.pi, torch.pi]]  # one pair for 1D\n",
    "    return operator\n",
    "\n",
    "def relative_l2_error(pred, target):\n",
    "    \"\"\"\n",
    "    Compute relative L2 error: norm(pred - target) / norm(target), with small epsilon\n",
    "    to avoid division by zero.\n",
    "    \"\"\"\n",
    "    eps = 1e-8\n",
    "    return torch.norm(pred - target) / (torch.norm(target) + eps)\n",
    "\n",
    "def evaluate_operator(dataset, operator, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Evaluate the operator (e.g. a 1D FNO model) on the dataset and compute\n",
    "    average relative L2 errors.\n",
    "\n",
    "    Instead of printing each sample's loss, we gather the relative L2 errors by \n",
    "    function type, then print:\n",
    "      - average error per function type\n",
    "      - overall average error.\n",
    "      \n",
    "    Args:\n",
    "        dataset: An iterable of dictionaries with keys (\"x\", \"f\", \"Gf\", \"func_type\").\n",
    "        operator: The operator (model) that maps f to Gf.\n",
    "        device: The torch.device to use.\n",
    "    \n",
    "    Returns:\n",
    "        type_errors: a dict mapping function_type -> list of relative L2 errors\n",
    "        overall_avg_error: overall average across all samples\n",
    "    \"\"\"\n",
    "    operator.to(device)\n",
    "    operator = adjust_positional_embedding_to_1d(operator)\n",
    "    \n",
    "    # We'll accumulate errors in a dictionary keyed by func_type\n",
    "    type_errors = {}\n",
    "    all_errors = []\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for sample in dataset:\n",
    "            func_type = sample[\"func_type\"]\n",
    "            x = sample[\"x\"]\n",
    "            f = sample[\"f\"]\n",
    "            Gf = sample[\"Gf\"]\n",
    "            \n",
    "            # Adjust shape\n",
    "            f, Gf = adjust_input_shape(f, Gf)\n",
    "            f = f.to(device)\n",
    "            Gf = Gf.to(device)\n",
    "\n",
    "            g_pred = operator(f)  # shape same as f => (batch, channels, n)\n",
    "            \n",
    "            # compute relative L2\n",
    "            err = relative_l2_error(g_pred, Gf).item()\n",
    "            all_errors.append(err)\n",
    "            \n",
    "            if func_type not in type_errors:\n",
    "                type_errors[func_type] = []\n",
    "            type_errors[func_type].append(err)\n",
    "\n",
    "    # compute averages\n",
    "    overall_avg_error = float(sum(all_errors) / len(all_errors)) if len(all_errors) > 0 else 0.0\n",
    "\n",
    "    # Print average per type\n",
    "    for ttype, errs in type_errors.items():\n",
    "        avg_err = sum(errs)/len(errs)\n",
    "        print(f\"Function type: {ttype}, Average Rel L2 error: {avg_err:.8f}\")\n",
    "\n",
    "    # Print overall\n",
    "    print(f\"\\nOverall average relative L2 error: {overall_avg_error:.8f}\")\n",
    "\n",
    "    return type_errors, overall_avg_error\n",
    "\n",
    "def plot_functions(dataset, operator, device=torch.device(\"cpu\")):\n",
    "    \"\"\"\n",
    "    Plot the input function, target output, and the operator's inferred output \n",
    "    for each sample. Display relative L2 error in the subplot title.\n",
    "    \n",
    "    Args:\n",
    "        dataset: An iterable of dictionaries with keys (\"x\", \"f\", \"Gf\", \"func_type\").\n",
    "        operator: The operator (model) that maps f to Gf.\n",
    "        device: The torch.device to use.\n",
    "    \"\"\"\n",
    "    num_samples = len(dataset)\n",
    "    num_cols = 4\n",
    "    num_rows = (num_samples + num_cols - 1) // num_cols  # 4 plots per row\n",
    "    \n",
    "    operator.to(device)\n",
    "    operator = adjust_positional_embedding_to_1d(operator)\n",
    "    \n",
    "    plt.figure(figsize=(20, 5 * num_rows))\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        for idx, sample in enumerate(dataset):\n",
    "            x = sample[\"x\"]           # (n,)\n",
    "            f = sample[\"f\"]\n",
    "            Gf = sample[\"Gf\"]\n",
    "            func_type = sample[\"func_type\"]\n",
    "\n",
    "            # Adjust shape\n",
    "            f, Gf = adjust_input_shape(f, Gf)\n",
    "            f_dev = f.to(device)\n",
    "            Gf_dev = Gf.to(device)\n",
    "\n",
    "            g_pred = operator(f_dev)   # (1,1,n) typically\n",
    "\n",
    "            # compute relative L2\n",
    "            rel_err = relative_l2_error(g_pred, Gf_dev).item()\n",
    "\n",
    "            # For plotting, move CPU\n",
    "            x_np = x.cpu().numpy()\n",
    "            f_np = f.squeeze(0).squeeze(0).cpu().numpy()\n",
    "            Gf_np = Gf.squeeze(0).squeeze(0).cpu().numpy()\n",
    "            g_pred_np = g_pred.squeeze(0).squeeze(0).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)$\", linestyle=\"-.\", linewidth=2)\n",
    "            plt.xlabel(\"$x$\")\n",
    "            plt.ylabel(\"Function Value\")\n",
    "            plt.title(f\"{func_type}\\nSample {idx+1}, Rel-L2: {rel_err:.4f}\")\n",
    "            plt.legend()\n",
    "            plt.grid()\n",
    "    \n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data = convert_dataset_for_fno(torch.load('train_3.pt', weights_only=False))\n",
    "test_data = convert_dataset_for_fno(torch.load('test_3.pt', weights_only=False))\n",
    "sample_data = convert_dataset_for_fno(torch.load('sample_3.pt', weights_only=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FNO1d params:  566,401\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",
    "# 1D grid embedding over [-π, π]\n",
    "pos_emb = GridEmbeddingND(\n",
    "    in_channels=1,\n",
    "    dim=1,\n",
    "    grid_boundaries=[[-torch.pi, torch.pi]]\n",
    ")\n",
    "\n",
    "# 1) FNO1d (keeps all 64 modes)\n",
    "fno = FNO1d(\n",
    "    n_modes_height=128,\n",
    "    hidden_channels=64,\n",
    "    in_channels=1,\n",
    "    out_channels=1,\n",
    "    positional_embedding=pos_emb,\n",
    "    n_layers=2,\n",
    ").to(device)\n",
    "\n",
    "#fno.load_state_dict(torch.load('fno_3.pth', weights_only=False))\n",
    "# print parameter counts\n",
    "def count_params(m):\n",
    "    return sum(p.numel() for p in m.parameters() if p.requires_grad)\n",
    "\n",
    "print(f\"FNO1d params:  {count_params(fno):,}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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.473135378 | Test Loss=0.095763074 | Time=1.29s | LR=1.00e-03\n",
      "Epoch [2/1000] | Train Loss=0.034213020 | Test Loss=0.035522728 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [3/1000] | Train Loss=0.021972958 | Test Loss=0.022092761 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [4/1000] | Train Loss=0.014993257 | Test Loss=0.021896085 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [5/1000] | Train Loss=0.018028963 | Test Loss=0.022029100 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [6/1000] | Train Loss=0.016471554 | Test Loss=0.018917670 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [7/1000] | Train Loss=0.015439967 | Test Loss=0.018654938 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [8/1000] | Train Loss=0.014734156 | Test Loss=0.017253151 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [9/1000] | Train Loss=0.012747968 | Test Loss=0.017904281 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [10/1000] | Train Loss=0.013512973 | Test Loss=0.018839306 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [11/1000] | Train Loss=0.013721845 | Test Loss=0.014135262 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [12/1000] | Train Loss=0.016264801 | Test Loss=0.018287086 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [13/1000] | Train Loss=0.012733905 | Test Loss=0.013105498 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [14/1000] | Train Loss=0.012641485 | Test Loss=0.023333462 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [15/1000] | Train Loss=0.014157810 | Test Loss=0.014667110 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [16/1000] | Train Loss=0.013529504 | Test Loss=0.015558503 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [17/1000] | Train Loss=0.011502910 | Test Loss=0.026407947 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [18/1000] | Train Loss=0.012541783 | Test Loss=0.014604669 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [19/1000] | Train Loss=0.012961174 | Test Loss=0.019256128 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [20/1000] | Train Loss=0.015744680 | Test Loss=0.014698803 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [21/1000] | Train Loss=0.015922496 | Test Loss=0.013595346 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [22/1000] | Train Loss=0.012577965 | Test Loss=0.011672427 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [23/1000] | Train Loss=0.011869620 | Test Loss=0.013808903 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [24/1000] | Train Loss=0.011357781 | Test Loss=0.011139606 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [25/1000] | Train Loss=0.009752134 | Test Loss=0.013135811 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [26/1000] | Train Loss=0.013950028 | Test Loss=0.013379912 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [27/1000] | Train Loss=0.012009310 | Test Loss=0.018179656 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [28/1000] | Train Loss=0.011058288 | Test Loss=0.012220228 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [29/1000] | Train Loss=0.012935283 | Test Loss=0.016450993 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [30/1000] | Train Loss=0.009743196 | Test Loss=0.015981783 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [31/1000] | Train Loss=0.012921288 | Test Loss=0.010853949 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [32/1000] | Train Loss=0.009236830 | Test Loss=0.012758483 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [33/1000] | Train Loss=0.010317746 | Test Loss=0.014731831 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [34/1000] | Train Loss=0.012232149 | Test Loss=0.010322424 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [35/1000] | Train Loss=0.013139367 | Test Loss=0.022165175 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [36/1000] | Train Loss=0.012546264 | Test Loss=0.015076143 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [37/1000] | Train Loss=0.011582202 | Test Loss=0.013128517 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [38/1000] | Train Loss=0.012409510 | Test Loss=0.017402375 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [39/1000] | Train Loss=0.011516404 | Test Loss=0.015585345 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [40/1000] | Train Loss=0.009557763 | Test Loss=0.012510295 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [41/1000] | Train Loss=0.010903722 | Test Loss=0.012773633 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [42/1000] | Train Loss=0.009085085 | Test Loss=0.011205897 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [43/1000] | Train Loss=0.009845010 | Test Loss=0.012685452 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [44/1000] | Train Loss=0.009480562 | Test Loss=0.021456767 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [45/1000] | Train Loss=0.010568434 | Test Loss=0.016844227 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [46/1000] | Train Loss=0.010836653 | Test Loss=0.015523835 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [47/1000] | Train Loss=0.014504417 | Test Loss=0.017915294 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [48/1000] | Train Loss=0.009270354 | Test Loss=0.010823267 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [49/1000] | Train Loss=0.010969634 | Test Loss=0.010682720 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [50/1000] | Train Loss=0.010058701 | Test Loss=0.017155560 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [51/1000] | Train Loss=0.010355205 | Test Loss=0.010079695 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [52/1000] | Train Loss=0.013219437 | Test Loss=0.014364182 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [53/1000] | Train Loss=0.010328752 | Test Loss=0.013727197 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [54/1000] | Train Loss=0.011099412 | Test Loss=0.013004968 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [55/1000] | Train Loss=0.011279052 | Test Loss=0.013414851 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [56/1000] | Train Loss=0.011949165 | Test Loss=0.011192006 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [57/1000] | Train Loss=0.009227298 | Test Loss=0.011335545 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [58/1000] | Train Loss=0.008788798 | Test Loss=0.017185279 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [59/1000] | Train Loss=0.010165462 | Test Loss=0.010171075 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [60/1000] | Train Loss=0.010669276 | Test Loss=0.049990845 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [61/1000] | Train Loss=0.009962855 | Test Loss=0.015249278 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [62/1000] | Train Loss=0.011402500 | Test Loss=0.011206050 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [63/1000] | Train Loss=0.012591986 | Test Loss=0.014684746 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [64/1000] | Train Loss=0.010808468 | Test Loss=0.012142853 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [65/1000] | Train Loss=0.008994156 | Test Loss=0.013244761 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [66/1000] | Train Loss=0.009033504 | Test Loss=0.009876550 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [67/1000] | Train Loss=0.011497563 | Test Loss=0.014993603 | Time=1.06s | LR=1.00e-03\n",
      "Epoch [68/1000] | Train Loss=0.009944770 | Test Loss=0.021541463 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [69/1000] | Train Loss=0.010473755 | Test Loss=0.011794875 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [70/1000] | Train Loss=0.010596698 | Test Loss=0.014191842 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [71/1000] | Train Loss=0.010563771 | Test Loss=0.017441805 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [72/1000] | Train Loss=0.011351713 | Test Loss=0.013754534 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [73/1000] | Train Loss=0.011298694 | Test Loss=0.010978772 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [74/1000] | Train Loss=0.008766870 | Test Loss=0.014908536 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [75/1000] | Train Loss=0.010994109 | Test Loss=0.016276534 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [76/1000] | Train Loss=0.009338638 | Test Loss=0.010755710 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [77/1000] | Train Loss=0.008598620 | Test Loss=0.013460755 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [78/1000] | Train Loss=0.010284442 | Test Loss=0.012825914 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [79/1000] | Train Loss=0.009969052 | Test Loss=0.010409586 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [80/1000] | Train Loss=0.007805274 | Test Loss=0.010269221 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [81/1000] | Train Loss=0.008710476 | Test Loss=0.014120412 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [82/1000] | Train Loss=0.010117808 | Test Loss=0.012486515 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [83/1000] | Train Loss=0.008783939 | Test Loss=0.015264143 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [84/1000] | Train Loss=0.008901128 | Test Loss=0.015368964 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [85/1000] | Train Loss=0.010277882 | Test Loss=0.012377703 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [86/1000] | Train Loss=0.011052398 | Test Loss=0.017587960 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [87/1000] | Train Loss=0.008563287 | Test Loss=0.012811998 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [88/1000] | Train Loss=0.009517359 | Test Loss=0.012579005 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [89/1000] | Train Loss=0.007878476 | Test Loss=0.011518257 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [90/1000] | Train Loss=0.008960742 | Test Loss=0.008517677 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [91/1000] | Train Loss=0.008572521 | Test Loss=0.009758612 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [92/1000] | Train Loss=0.010170521 | Test Loss=0.022186503 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [93/1000] | Train Loss=0.008834817 | Test Loss=0.008814393 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [94/1000] | Train Loss=0.010159995 | Test Loss=0.010035065 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [95/1000] | Train Loss=0.007062855 | Test Loss=0.009600913 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [96/1000] | Train Loss=0.009069246 | Test Loss=0.016127727 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [97/1000] | Train Loss=0.008942037 | Test Loss=0.011762476 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [98/1000] | Train Loss=0.007694984 | Test Loss=0.008706145 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [99/1000] | Train Loss=0.008664247 | Test Loss=0.011668444 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [100/1000] | Train Loss=0.009071372 | Test Loss=0.008182704 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [101/1000] | Train Loss=0.010336700 | Test Loss=0.014463960 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [102/1000] | Train Loss=0.007256012 | Test Loss=0.010045629 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [103/1000] | Train Loss=0.006463571 | Test Loss=0.010775366 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [104/1000] | Train Loss=0.009620326 | Test Loss=0.013887219 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [105/1000] | Train Loss=0.011180034 | Test Loss=0.011178548 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [106/1000] | Train Loss=0.008315796 | Test Loss=0.018733665 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [107/1000] | Train Loss=0.010508970 | Test Loss=0.012516440 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [108/1000] | Train Loss=0.010250042 | Test Loss=0.023251439 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [109/1000] | Train Loss=0.011246881 | Test Loss=0.013813546 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [110/1000] | Train Loss=0.009766055 | Test Loss=0.012350620 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [111/1000] | Train Loss=0.008315613 | Test Loss=0.008998634 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [112/1000] | Train Loss=0.008461255 | Test Loss=0.011122314 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [113/1000] | Train Loss=0.010281258 | Test Loss=0.010708927 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [114/1000] | Train Loss=0.009178736 | Test Loss=0.010589019 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [115/1000] | Train Loss=0.008262207 | Test Loss=0.014383959 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [116/1000] | Train Loss=0.009398856 | Test Loss=0.024168086 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [117/1000] | Train Loss=0.011044747 | Test Loss=0.012669409 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [118/1000] | Train Loss=0.009149814 | Test Loss=0.008998122 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [119/1000] | Train Loss=0.008654982 | Test Loss=0.010834195 | Time=1.01s | LR=1.00e-03\n",
      "Epoch [120/1000] | Train Loss=0.008124476 | Test Loss=0.012998194 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [121/1000] | Train Loss=0.010460036 | Test Loss=0.011383903 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [122/1000] | Train Loss=0.008858726 | Test Loss=0.011544028 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [123/1000] | Train Loss=0.009409061 | Test Loss=0.015651769 | Time=1.00s | LR=1.00e-03\n",
      "Epoch [124/1000] | Train Loss=0.007426481 | Test Loss=0.013734165 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [125/1000] | Train Loss=0.004712628 | Test Loss=0.009522453 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [126/1000] | Train Loss=0.004161114 | Test Loss=0.007189860 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [127/1000] | Train Loss=0.003862694 | Test Loss=0.008263794 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [128/1000] | Train Loss=0.005593625 | Test Loss=0.010267504 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [129/1000] | Train Loss=0.004469063 | Test Loss=0.007724977 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [130/1000] | Train Loss=0.004112589 | Test Loss=0.006992921 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [131/1000] | Train Loss=0.003250688 | Test Loss=0.006778397 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [132/1000] | Train Loss=0.003932161 | Test Loss=0.009393256 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [133/1000] | Train Loss=0.004706811 | Test Loss=0.007289160 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [134/1000] | Train Loss=0.005053643 | Test Loss=0.008206718 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [135/1000] | Train Loss=0.004597940 | Test Loss=0.012553345 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [136/1000] | Train Loss=0.004224685 | Test Loss=0.007178491 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [137/1000] | Train Loss=0.004059299 | Test Loss=0.007584777 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [138/1000] | Train Loss=0.004252417 | Test Loss=0.009213776 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [139/1000] | Train Loss=0.003682680 | Test Loss=0.007244473 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [140/1000] | Train Loss=0.004146326 | Test Loss=0.008166640 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [141/1000] | Train Loss=0.004968004 | Test Loss=0.010373274 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [142/1000] | Train Loss=0.006536389 | Test Loss=0.009561283 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [143/1000] | Train Loss=0.004953846 | Test Loss=0.009605070 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [144/1000] | Train Loss=0.004090445 | Test Loss=0.007121947 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [145/1000] | Train Loss=0.004034678 | Test Loss=0.006981548 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [146/1000] | Train Loss=0.004309875 | Test Loss=0.007560950 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [147/1000] | Train Loss=0.004289263 | Test Loss=0.009147432 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [148/1000] | Train Loss=0.005228248 | Test Loss=0.006892144 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [149/1000] | Train Loss=0.004697610 | Test Loss=0.007061395 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [150/1000] | Train Loss=0.004752822 | Test Loss=0.007049559 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [151/1000] | Train Loss=0.003962565 | Test Loss=0.006912923 | Time=1.00s | LR=5.00e-04\n",
      "Epoch [152/1000] | Train Loss=0.003756433 | Test Loss=0.007028485 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [153/1000] | Train Loss=0.002063308 | Test Loss=0.006552629 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [154/1000] | Train Loss=0.002409171 | Test Loss=0.006468957 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [155/1000] | Train Loss=0.002023284 | Test Loss=0.006651683 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [156/1000] | Train Loss=0.002543234 | Test Loss=0.007705169 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [157/1000] | Train Loss=0.002804672 | Test Loss=0.009453579 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [158/1000] | Train Loss=0.002093562 | Test Loss=0.006478569 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [159/1000] | Train Loss=0.002348016 | Test Loss=0.007223094 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [160/1000] | Train Loss=0.002391307 | Test Loss=0.006527923 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [161/1000] | Train Loss=0.002275178 | Test Loss=0.006724873 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [162/1000] | Train Loss=0.002379378 | Test Loss=0.006228361 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [163/1000] | Train Loss=0.002576055 | Test Loss=0.006311932 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [164/1000] | Train Loss=0.002030134 | Test Loss=0.006515072 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [165/1000] | Train Loss=0.002132111 | Test Loss=0.006864890 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [166/1000] | Train Loss=0.001848664 | Test Loss=0.006380229 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [167/1000] | Train Loss=0.002040936 | Test Loss=0.007181387 | Time=1.01s | LR=2.50e-04\n",
      "Epoch [168/1000] | Train Loss=0.002419047 | Test Loss=0.006088785 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [169/1000] | Train Loss=0.002252083 | Test Loss=0.006153839 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [170/1000] | Train Loss=0.002204407 | Test Loss=0.007017652 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [171/1000] | Train Loss=0.002849913 | Test Loss=0.007004221 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [172/1000] | Train Loss=0.002457973 | Test Loss=0.006552566 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [173/1000] | Train Loss=0.002754972 | Test Loss=0.006167056 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [174/1000] | Train Loss=0.002390576 | Test Loss=0.006269404 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [175/1000] | Train Loss=0.002550971 | Test Loss=0.006534867 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [176/1000] | Train Loss=0.002441528 | Test Loss=0.006241849 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [177/1000] | Train Loss=0.001695084 | Test Loss=0.006422770 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [178/1000] | Train Loss=0.001873386 | Test Loss=0.006284852 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [179/1000] | Train Loss=0.002266665 | Test Loss=0.006414352 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [180/1000] | Train Loss=0.002477363 | Test Loss=0.007160582 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [181/1000] | Train Loss=0.002028782 | Test Loss=0.007182477 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [182/1000] | Train Loss=0.002058979 | Test Loss=0.006136763 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [183/1000] | Train Loss=0.002260922 | Test Loss=0.006331033 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [184/1000] | Train Loss=0.001993772 | Test Loss=0.006967919 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [185/1000] | Train Loss=0.002342268 | Test Loss=0.006449887 | Time=1.01s | LR=2.50e-04\n",
      "Epoch [186/1000] | Train Loss=0.002263964 | Test Loss=0.006495200 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [187/1000] | Train Loss=0.002961963 | Test Loss=0.009990266 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [188/1000] | Train Loss=0.002214323 | Test Loss=0.006700060 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [189/1000] | Train Loss=0.002051061 | Test Loss=0.006159889 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [190/1000] | Train Loss=0.002406229 | Test Loss=0.007803255 | Time=1.01s | LR=2.50e-04\n",
      "Epoch [191/1000] | Train Loss=0.001814566 | Test Loss=0.006271411 | Time=1.01s | LR=2.50e-04\n",
      "Epoch [192/1000] | Train Loss=0.001897115 | Test Loss=0.006492349 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [193/1000] | Train Loss=0.002411178 | Test Loss=0.005845471 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [194/1000] | Train Loss=0.002315623 | Test Loss=0.006639578 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [195/1000] | Train Loss=0.002231904 | Test Loss=0.006317866 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [196/1000] | Train Loss=0.002248746 | Test Loss=0.005921769 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [197/1000] | Train Loss=0.002570762 | Test Loss=0.006169876 | Time=1.00s | LR=2.50e-04\n",
      "Epoch [198/1000] | Train Loss=0.002220083 | Test Loss=0.006751656 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [199/1000] | Train Loss=0.001190090 | Test Loss=0.006151422 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [200/1000] | Train Loss=0.001331966 | Test Loss=0.006134015 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [201/1000] | Train Loss=0.001239898 | Test Loss=0.005766945 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [202/1000] | Train Loss=0.001300424 | Test Loss=0.006266115 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [203/1000] | Train Loss=0.001145620 | Test Loss=0.005881225 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [204/1000] | Train Loss=0.001003163 | Test Loss=0.005852083 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [205/1000] | Train Loss=0.001157079 | Test Loss=0.005891392 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [206/1000] | Train Loss=0.001076633 | Test Loss=0.005961252 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [207/1000] | Train Loss=0.000993353 | Test Loss=0.005913857 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [208/1000] | Train Loss=0.001263318 | Test Loss=0.005815139 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [209/1000] | Train Loss=0.001432805 | Test Loss=0.006902102 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [210/1000] | Train Loss=0.001272501 | Test Loss=0.005871724 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [211/1000] | Train Loss=0.001075064 | Test Loss=0.005921722 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [212/1000] | Train Loss=0.001129705 | Test Loss=0.005981813 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [213/1000] | Train Loss=0.001299918 | Test Loss=0.005763569 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [214/1000] | Train Loss=0.001349924 | Test Loss=0.006304560 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [215/1000] | Train Loss=0.001205021 | Test Loss=0.005881138 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [216/1000] | Train Loss=0.001441746 | Test Loss=0.006106197 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [217/1000] | Train Loss=0.001248894 | Test Loss=0.005671660 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [218/1000] | Train Loss=0.001266796 | Test Loss=0.005934731 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [219/1000] | Train Loss=0.001228964 | Test Loss=0.005672010 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [220/1000] | Train Loss=0.001337922 | Test Loss=0.005582551 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [221/1000] | Train Loss=0.001268606 | Test Loss=0.005814138 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [222/1000] | Train Loss=0.001087999 | Test Loss=0.005659264 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [223/1000] | Train Loss=0.001131675 | Test Loss=0.006017967 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [224/1000] | Train Loss=0.001231038 | Test Loss=0.005697833 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [225/1000] | Train Loss=0.001304920 | Test Loss=0.005876011 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [226/1000] | Train Loss=0.001267529 | Test Loss=0.005690366 | Time=1.00s | LR=1.25e-04\n",
      "Epoch [227/1000] | Train Loss=0.001362094 | Test Loss=0.005997920 | Time=1.01s | LR=1.25e-04\n",
      "Epoch [228/1000] | Train Loss=0.001226913 | Test Loss=0.005800396 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [229/1000] | Train Loss=0.000706695 | Test Loss=0.005782675 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [230/1000] | Train Loss=0.000674391 | Test Loss=0.005768018 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [231/1000] | Train Loss=0.000735917 | Test Loss=0.005951132 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [232/1000] | Train Loss=0.000705816 | Test Loss=0.005773867 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [233/1000] | Train Loss=0.000743870 | Test Loss=0.005758337 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [234/1000] | Train Loss=0.000746553 | Test Loss=0.005683108 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [235/1000] | Train Loss=0.000774821 | Test Loss=0.005858037 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [236/1000] | Train Loss=0.000712456 | Test Loss=0.005718234 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [237/1000] | Train Loss=0.000726067 | Test Loss=0.005747955 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [238/1000] | Train Loss=0.000793004 | Test Loss=0.005688478 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [239/1000] | Train Loss=0.000770703 | Test Loss=0.005635346 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [240/1000] | Train Loss=0.000779579 | Test Loss=0.005625334 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [241/1000] | Train Loss=0.000774617 | Test Loss=0.005719533 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [242/1000] | Train Loss=0.000837263 | Test Loss=0.005745970 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [243/1000] | Train Loss=0.000783904 | Test Loss=0.005714726 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [244/1000] | Train Loss=0.000887987 | Test Loss=0.005626508 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [245/1000] | Train Loss=0.000841832 | Test Loss=0.005569447 | Time=1.01s | LR=6.25e-05\n",
      "Epoch [246/1000] | Train Loss=0.000687680 | Test Loss=0.005601345 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [247/1000] | Train Loss=0.000890770 | Test Loss=0.005852660 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [248/1000] | Train Loss=0.000748882 | Test Loss=0.005660197 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [249/1000] | Train Loss=0.000815896 | Test Loss=0.005639392 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [250/1000] | Train Loss=0.000700766 | Test Loss=0.005564412 | Time=1.00s | LR=6.25e-05\n",
      "Epoch [251/1000] | Train Loss=0.000681022 | Test Loss=0.005586663 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [252/1000] | Train Loss=0.000597459 | Test Loss=0.005658207 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [253/1000] | Train Loss=0.000566336 | Test Loss=0.005605665 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [254/1000] | Train Loss=0.000561388 | Test Loss=0.005612289 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [255/1000] | Train Loss=0.000606621 | Test Loss=0.005685710 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [256/1000] | Train Loss=0.000608110 | Test Loss=0.005713143 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [257/1000] | Train Loss=0.000577852 | Test Loss=0.005528532 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [258/1000] | Train Loss=0.000586503 | Test Loss=0.005660008 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [259/1000] | Train Loss=0.000626553 | Test Loss=0.005570099 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [260/1000] | Train Loss=0.000595278 | Test Loss=0.005572361 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [261/1000] | Train Loss=0.000565956 | Test Loss=0.005650837 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [262/1000] | Train Loss=0.000621186 | Test Loss=0.005642617 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [263/1000] | Train Loss=0.000589540 | Test Loss=0.005615019 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [264/1000] | Train Loss=0.000590859 | Test Loss=0.005516559 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [265/1000] | Train Loss=0.000578919 | Test Loss=0.005590629 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [266/1000] | Train Loss=0.000579891 | Test Loss=0.005540184 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [267/1000] | Train Loss=0.000585228 | Test Loss=0.005549967 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [268/1000] | Train Loss=0.000597084 | Test Loss=0.005564648 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [269/1000] | Train Loss=0.000583483 | Test Loss=0.005540882 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [270/1000] | Train Loss=0.000649664 | Test Loss=0.005586513 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [271/1000] | Train Loss=0.000582663 | Test Loss=0.005580640 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [272/1000] | Train Loss=0.000601206 | Test Loss=0.005660140 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [273/1000] | Train Loss=0.000628342 | Test Loss=0.005613693 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [274/1000] | Train Loss=0.000614681 | Test Loss=0.005483411 | Time=1.00s | LR=3.13e-05\n",
      "Epoch [275/1000] | Train Loss=0.000592673 | Test Loss=0.005623025 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [276/1000] | Train Loss=0.000542740 | Test Loss=0.005523360 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [277/1000] | Train Loss=0.000527650 | Test Loss=0.005547091 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [278/1000] | Train Loss=0.000523504 | Test Loss=0.005562183 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [279/1000] | Train Loss=0.000528460 | Test Loss=0.005502732 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [280/1000] | Train Loss=0.000533251 | Test Loss=0.005509395 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [281/1000] | Train Loss=0.000525150 | Test Loss=0.005539483 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [282/1000] | Train Loss=0.000538861 | Test Loss=0.005558070 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [283/1000] | Train Loss=0.000531194 | Test Loss=0.005525490 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [284/1000] | Train Loss=0.000552118 | Test Loss=0.005492023 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [285/1000] | Train Loss=0.000522214 | Test Loss=0.005497224 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [286/1000] | Train Loss=0.000532707 | Test Loss=0.005525635 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [287/1000] | Train Loss=0.000548933 | Test Loss=0.005525453 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [288/1000] | Train Loss=0.000545934 | Test Loss=0.005526494 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [289/1000] | Train Loss=0.000524810 | Test Loss=0.005515220 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [290/1000] | Train Loss=0.000529210 | Test Loss=0.005510237 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [291/1000] | Train Loss=0.000521912 | Test Loss=0.005490432 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [292/1000] | Train Loss=0.000525512 | Test Loss=0.005492695 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [293/1000] | Train Loss=0.000526636 | Test Loss=0.005542817 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [294/1000] | Train Loss=0.000527124 | Test Loss=0.005543147 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [295/1000] | Train Loss=0.000530912 | Test Loss=0.005486692 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [296/1000] | Train Loss=0.000533984 | Test Loss=0.005505980 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [297/1000] | Train Loss=0.000545574 | Test Loss=0.005474536 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [298/1000] | Train Loss=0.000515747 | Test Loss=0.005524682 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [299/1000] | Train Loss=0.000516226 | Test Loss=0.005509312 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [300/1000] | Train Loss=0.000527533 | Test Loss=0.005471721 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [301/1000] | Train Loss=0.000521425 | Test Loss=0.005448822 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [302/1000] | Train Loss=0.000530569 | Test Loss=0.005520854 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [303/1000] | Train Loss=0.000533328 | Test Loss=0.005471645 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [304/1000] | Train Loss=0.000521785 | Test Loss=0.005487870 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [305/1000] | Train Loss=0.000527028 | Test Loss=0.005485008 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [306/1000] | Train Loss=0.000521169 | Test Loss=0.005495757 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [307/1000] | Train Loss=0.000525110 | Test Loss=0.005437279 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [308/1000] | Train Loss=0.000528858 | Test Loss=0.005482329 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [309/1000] | Train Loss=0.000518216 | Test Loss=0.005439446 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [310/1000] | Train Loss=0.000533768 | Test Loss=0.005455237 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [311/1000] | Train Loss=0.000552335 | Test Loss=0.005471077 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [312/1000] | Train Loss=0.000521962 | Test Loss=0.005463270 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [313/1000] | Train Loss=0.000516616 | Test Loss=0.005485133 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [314/1000] | Train Loss=0.000519755 | Test Loss=0.005483040 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [315/1000] | Train Loss=0.000509671 | Test Loss=0.005450510 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [316/1000] | Train Loss=0.000507127 | Test Loss=0.005442987 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [317/1000] | Train Loss=0.000511248 | Test Loss=0.005443325 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [318/1000] | Train Loss=0.000515614 | Test Loss=0.005410574 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [319/1000] | Train Loss=0.000513562 | Test Loss=0.005447662 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [320/1000] | Train Loss=0.000517184 | Test Loss=0.005506541 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [321/1000] | Train Loss=0.000513245 | Test Loss=0.005433553 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [322/1000] | Train Loss=0.000555728 | Test Loss=0.005455450 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [323/1000] | Train Loss=0.000510231 | Test Loss=0.005405707 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [324/1000] | Train Loss=0.000512650 | Test Loss=0.005428920 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [325/1000] | Train Loss=0.000515810 | Test Loss=0.005555175 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [326/1000] | Train Loss=0.000506448 | Test Loss=0.005504255 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [327/1000] | Train Loss=0.000516133 | Test Loss=0.005466718 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [328/1000] | Train Loss=0.000510335 | Test Loss=0.005429163 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [329/1000] | Train Loss=0.000509385 | Test Loss=0.005471533 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [330/1000] | Train Loss=0.000511848 | Test Loss=0.005432668 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [331/1000] | Train Loss=0.000524235 | Test Loss=0.005364122 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [332/1000] | Train Loss=0.000531243 | Test Loss=0.005408964 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [333/1000] | Train Loss=0.000521337 | Test Loss=0.005415394 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [334/1000] | Train Loss=0.000506090 | Test Loss=0.005445483 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [335/1000] | Train Loss=0.000514408 | Test Loss=0.005433850 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [336/1000] | Train Loss=0.000517904 | Test Loss=0.005427273 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [337/1000] | Train Loss=0.000536325 | Test Loss=0.005377669 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [338/1000] | Train Loss=0.000503374 | Test Loss=0.005415757 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [339/1000] | Train Loss=0.000509151 | Test Loss=0.005401555 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [340/1000] | Train Loss=0.000516033 | Test Loss=0.005405789 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [341/1000] | Train Loss=0.000507514 | Test Loss=0.005385793 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [342/1000] | Train Loss=0.000502937 | Test Loss=0.005415403 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [343/1000] | Train Loss=0.000516235 | Test Loss=0.005400899 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [344/1000] | Train Loss=0.000506354 | Test Loss=0.005410325 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [345/1000] | Train Loss=0.000505131 | Test Loss=0.005425628 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [346/1000] | Train Loss=0.000502638 | Test Loss=0.005420081 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [347/1000] | Train Loss=0.000512513 | Test Loss=0.005426833 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [348/1000] | Train Loss=0.000512397 | Test Loss=0.005406256 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [349/1000] | Train Loss=0.000501327 | Test Loss=0.005388074 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [350/1000] | Train Loss=0.000497681 | Test Loss=0.005383371 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [351/1000] | Train Loss=0.000497487 | Test Loss=0.005416439 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [352/1000] | Train Loss=0.000501353 | Test Loss=0.005386152 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [353/1000] | Train Loss=0.000502432 | Test Loss=0.005399111 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [354/1000] | Train Loss=0.000502538 | Test Loss=0.005431055 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [355/1000] | Train Loss=0.000509263 | Test Loss=0.005431690 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [356/1000] | Train Loss=0.000509123 | Test Loss=0.005404996 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [357/1000] | Train Loss=0.000510022 | Test Loss=0.005377695 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [358/1000] | Train Loss=0.000491847 | Test Loss=0.005428742 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [359/1000] | Train Loss=0.000500175 | Test Loss=0.005387092 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [360/1000] | Train Loss=0.000510247 | Test Loss=0.005402780 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [361/1000] | Train Loss=0.000507359 | Test Loss=0.005376636 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [362/1000] | Train Loss=0.000508786 | Test Loss=0.005403130 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [363/1000] | Train Loss=0.000497263 | Test Loss=0.005369907 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [364/1000] | Train Loss=0.000498221 | Test Loss=0.005400807 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [365/1000] | Train Loss=0.000494303 | Test Loss=0.005374395 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [366/1000] | Train Loss=0.000507139 | Test Loss=0.005392275 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [367/1000] | Train Loss=0.000501760 | Test Loss=0.005436708 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [368/1000] | Train Loss=0.000497294 | Test Loss=0.005373213 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [369/1000] | Train Loss=0.000492854 | Test Loss=0.005388405 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [370/1000] | Train Loss=0.000500639 | Test Loss=0.005330075 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [371/1000] | Train Loss=0.000504953 | Test Loss=0.005390038 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [372/1000] | Train Loss=0.000489666 | Test Loss=0.005391761 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [373/1000] | Train Loss=0.000507739 | Test Loss=0.005369379 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [374/1000] | Train Loss=0.000491677 | Test Loss=0.005402344 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [375/1000] | Train Loss=0.000495886 | Test Loss=0.005367789 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [376/1000] | Train Loss=0.000492317 | Test Loss=0.005350502 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [377/1000] | Train Loss=0.000484259 | Test Loss=0.005357094 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [378/1000] | Train Loss=0.000497031 | Test Loss=0.005348727 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [379/1000] | Train Loss=0.000505647 | Test Loss=0.005388295 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [380/1000] | Train Loss=0.000512704 | Test Loss=0.005323781 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [381/1000] | Train Loss=0.000537062 | Test Loss=0.005341404 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [382/1000] | Train Loss=0.000500452 | Test Loss=0.005349166 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [383/1000] | Train Loss=0.000482764 | Test Loss=0.005325110 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [384/1000] | Train Loss=0.000492954 | Test Loss=0.005331732 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [385/1000] | Train Loss=0.000488352 | Test Loss=0.005372857 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [386/1000] | Train Loss=0.000479853 | Test Loss=0.005341632 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [387/1000] | Train Loss=0.000485936 | Test Loss=0.005281179 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [388/1000] | Train Loss=0.000494139 | Test Loss=0.005375686 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [389/1000] | Train Loss=0.000503709 | Test Loss=0.005362083 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [390/1000] | Train Loss=0.000485851 | Test Loss=0.005316587 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [391/1000] | Train Loss=0.000484789 | Test Loss=0.005317670 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [392/1000] | Train Loss=0.000485417 | Test Loss=0.005320155 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [393/1000] | Train Loss=0.000482532 | Test Loss=0.005339622 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [394/1000] | Train Loss=0.000487095 | Test Loss=0.005346760 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [395/1000] | Train Loss=0.000480134 | Test Loss=0.005302064 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [396/1000] | Train Loss=0.000484725 | Test Loss=0.005326687 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [397/1000] | Train Loss=0.000486279 | Test Loss=0.005307755 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [398/1000] | Train Loss=0.000485799 | Test Loss=0.005323346 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [399/1000] | Train Loss=0.000481615 | Test Loss=0.005338143 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [400/1000] | Train Loss=0.000494503 | Test Loss=0.005351657 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [401/1000] | Train Loss=0.000483326 | Test Loss=0.005289026 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [402/1000] | Train Loss=0.000484162 | Test Loss=0.005289997 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [403/1000] | Train Loss=0.000489163 | Test Loss=0.005338166 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [404/1000] | Train Loss=0.000475882 | Test Loss=0.005363079 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [405/1000] | Train Loss=0.000488084 | Test Loss=0.005265918 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [406/1000] | Train Loss=0.000478331 | Test Loss=0.005269516 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [407/1000] | Train Loss=0.000495200 | Test Loss=0.005348946 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [408/1000] | Train Loss=0.000491527 | Test Loss=0.005302406 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [409/1000] | Train Loss=0.000483814 | Test Loss=0.005291127 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [410/1000] | Train Loss=0.000505654 | Test Loss=0.005340046 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [411/1000] | Train Loss=0.000506047 | Test Loss=0.005251035 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [412/1000] | Train Loss=0.000476433 | Test Loss=0.005333871 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [413/1000] | Train Loss=0.000491627 | Test Loss=0.005328789 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [414/1000] | Train Loss=0.000471695 | Test Loss=0.005306161 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [415/1000] | Train Loss=0.000478063 | Test Loss=0.005293964 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [416/1000] | Train Loss=0.000491684 | Test Loss=0.005326132 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [417/1000] | Train Loss=0.000481243 | Test Loss=0.005308231 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [418/1000] | Train Loss=0.000476178 | Test Loss=0.005257259 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [419/1000] | Train Loss=0.000462166 | Test Loss=0.005312279 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [420/1000] | Train Loss=0.000475525 | Test Loss=0.005373630 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [421/1000] | Train Loss=0.000482979 | Test Loss=0.005264329 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [422/1000] | Train Loss=0.000478380 | Test Loss=0.005306771 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [423/1000] | Train Loss=0.000478877 | Test Loss=0.005329798 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [424/1000] | Train Loss=0.000483919 | Test Loss=0.005318829 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [425/1000] | Train Loss=0.000483379 | Test Loss=0.005294051 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [426/1000] | Train Loss=0.000474295 | Test Loss=0.005278261 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [427/1000] | Train Loss=0.000473318 | Test Loss=0.005256841 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [428/1000] | Train Loss=0.000485570 | Test Loss=0.005238663 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [429/1000] | Train Loss=0.000462552 | Test Loss=0.005299501 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [430/1000] | Train Loss=0.000473487 | Test Loss=0.005299413 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [431/1000] | Train Loss=0.000487575 | Test Loss=0.005241092 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [432/1000] | Train Loss=0.000480876 | Test Loss=0.005283254 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [433/1000] | Train Loss=0.000472404 | Test Loss=0.005291046 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [434/1000] | Train Loss=0.000471156 | Test Loss=0.005300820 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [435/1000] | Train Loss=0.000475962 | Test Loss=0.005298258 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [436/1000] | Train Loss=0.000467271 | Test Loss=0.005244618 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [437/1000] | Train Loss=0.000468573 | Test Loss=0.005269016 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [438/1000] | Train Loss=0.000484800 | Test Loss=0.005311879 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [439/1000] | Train Loss=0.000466348 | Test Loss=0.005261351 | Time=1.00s | LR=1.56e-05\n",
      "Epoch [440/1000] | Train Loss=0.000472626 | Test Loss=0.005293607 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [441/1000] | Train Loss=0.000458326 | Test Loss=0.005274769 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [442/1000] | Train Loss=0.000443082 | Test Loss=0.005289863 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [443/1000] | Train Loss=0.000442589 | Test Loss=0.005294427 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [444/1000] | Train Loss=0.000443145 | Test Loss=0.005256983 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [445/1000] | Train Loss=0.000443635 | Test Loss=0.005264756 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [446/1000] | Train Loss=0.000445902 | Test Loss=0.005264907 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [447/1000] | Train Loss=0.000448552 | Test Loss=0.005284749 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [448/1000] | Train Loss=0.000446212 | Test Loss=0.005232911 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [449/1000] | Train Loss=0.000457433 | Test Loss=0.005260298 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [450/1000] | Train Loss=0.000448768 | Test Loss=0.005257887 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [451/1000] | Train Loss=0.000446702 | Test Loss=0.005253567 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [452/1000] | Train Loss=0.000445435 | Test Loss=0.005265325 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [453/1000] | Train Loss=0.000445859 | Test Loss=0.005257476 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [454/1000] | Train Loss=0.000445262 | Test Loss=0.005297380 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [455/1000] | Train Loss=0.000455007 | Test Loss=0.005239999 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [456/1000] | Train Loss=0.000446913 | Test Loss=0.005263053 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [457/1000] | Train Loss=0.000448681 | Test Loss=0.005238480 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [458/1000] | Train Loss=0.000447843 | Test Loss=0.005249668 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [459/1000] | Train Loss=0.000455731 | Test Loss=0.005286339 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [460/1000] | Train Loss=0.000453804 | Test Loss=0.005267376 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [461/1000] | Train Loss=0.000444239 | Test Loss=0.005262108 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [462/1000] | Train Loss=0.000453200 | Test Loss=0.005248634 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [463/1000] | Train Loss=0.000442092 | Test Loss=0.005257821 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [464/1000] | Train Loss=0.000444035 | Test Loss=0.005288193 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [465/1000] | Train Loss=0.000447444 | Test Loss=0.005237343 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [466/1000] | Train Loss=0.000442486 | Test Loss=0.005267070 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [467/1000] | Train Loss=0.000444162 | Test Loss=0.005256494 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [468/1000] | Train Loss=0.000440778 | Test Loss=0.005250595 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [469/1000] | Train Loss=0.000454648 | Test Loss=0.005236967 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [470/1000] | Train Loss=0.000442591 | Test Loss=0.005233456 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [471/1000] | Train Loss=0.000445568 | Test Loss=0.005277376 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [472/1000] | Train Loss=0.000449650 | Test Loss=0.005264230 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [473/1000] | Train Loss=0.000447411 | Test Loss=0.005265158 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [474/1000] | Train Loss=0.000438679 | Test Loss=0.005236287 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [475/1000] | Train Loss=0.000441814 | Test Loss=0.005217102 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [476/1000] | Train Loss=0.000449691 | Test Loss=0.005257147 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [477/1000] | Train Loss=0.000450095 | Test Loss=0.005218680 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [478/1000] | Train Loss=0.000450943 | Test Loss=0.005233786 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [479/1000] | Train Loss=0.000447485 | Test Loss=0.005218797 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [480/1000] | Train Loss=0.000448808 | Test Loss=0.005263968 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [481/1000] | Train Loss=0.000439510 | Test Loss=0.005235042 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [482/1000] | Train Loss=0.000449583 | Test Loss=0.005240907 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [483/1000] | Train Loss=0.000446935 | Test Loss=0.005246831 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [484/1000] | Train Loss=0.000449333 | Test Loss=0.005240434 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [485/1000] | Train Loss=0.000444955 | Test Loss=0.005276608 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [486/1000] | Train Loss=0.000443326 | Test Loss=0.005229539 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [487/1000] | Train Loss=0.000434488 | Test Loss=0.005224408 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [488/1000] | Train Loss=0.000448689 | Test Loss=0.005200650 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [489/1000] | Train Loss=0.000442529 | Test Loss=0.005229496 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [490/1000] | Train Loss=0.000443533 | Test Loss=0.005208655 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [491/1000] | Train Loss=0.000439482 | Test Loss=0.005236603 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [492/1000] | Train Loss=0.000442053 | Test Loss=0.005256541 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [493/1000] | Train Loss=0.000444491 | Test Loss=0.005271396 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [494/1000] | Train Loss=0.000442081 | Test Loss=0.005239046 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [495/1000] | Train Loss=0.000454722 | Test Loss=0.005237539 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [496/1000] | Train Loss=0.000439025 | Test Loss=0.005211273 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [497/1000] | Train Loss=0.000447109 | Test Loss=0.005252555 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [498/1000] | Train Loss=0.000450827 | Test Loss=0.005199343 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [499/1000] | Train Loss=0.000441775 | Test Loss=0.005234409 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [500/1000] | Train Loss=0.000436968 | Test Loss=0.005224153 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [501/1000] | Train Loss=0.000443165 | Test Loss=0.005217015 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [502/1000] | Train Loss=0.000438749 | Test Loss=0.005252620 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [503/1000] | Train Loss=0.000444981 | Test Loss=0.005212287 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [504/1000] | Train Loss=0.000445496 | Test Loss=0.005246681 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [505/1000] | Train Loss=0.000446534 | Test Loss=0.005206324 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [506/1000] | Train Loss=0.000445701 | Test Loss=0.005220019 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [507/1000] | Train Loss=0.000445568 | Test Loss=0.005243007 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [508/1000] | Train Loss=0.000433683 | Test Loss=0.005219698 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [509/1000] | Train Loss=0.000443920 | Test Loss=0.005224234 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [510/1000] | Train Loss=0.000452183 | Test Loss=0.005186474 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [511/1000] | Train Loss=0.000436823 | Test Loss=0.005211576 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [512/1000] | Train Loss=0.000441811 | Test Loss=0.005222515 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [513/1000] | Train Loss=0.000444219 | Test Loss=0.005261078 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [514/1000] | Train Loss=0.000441697 | Test Loss=0.005220926 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [515/1000] | Train Loss=0.000446627 | Test Loss=0.005223798 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [516/1000] | Train Loss=0.000434005 | Test Loss=0.005221359 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [517/1000] | Train Loss=0.000437315 | Test Loss=0.005257513 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [518/1000] | Train Loss=0.000440281 | Test Loss=0.005188961 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [519/1000] | Train Loss=0.000439968 | Test Loss=0.005240960 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [520/1000] | Train Loss=0.000436831 | Test Loss=0.005200246 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [521/1000] | Train Loss=0.000428887 | Test Loss=0.005225586 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [522/1000] | Train Loss=0.000437568 | Test Loss=0.005198994 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [523/1000] | Train Loss=0.000432293 | Test Loss=0.005182214 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [524/1000] | Train Loss=0.000443240 | Test Loss=0.005211919 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [525/1000] | Train Loss=0.000440456 | Test Loss=0.005208709 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [526/1000] | Train Loss=0.000442714 | Test Loss=0.005229719 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [527/1000] | Train Loss=0.000432509 | Test Loss=0.005207993 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [528/1000] | Train Loss=0.000441433 | Test Loss=0.005227409 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [529/1000] | Train Loss=0.000439299 | Test Loss=0.005195651 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [530/1000] | Train Loss=0.000435295 | Test Loss=0.005192699 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [531/1000] | Train Loss=0.000427906 | Test Loss=0.005182113 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [532/1000] | Train Loss=0.000435846 | Test Loss=0.005203837 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [533/1000] | Train Loss=0.000437441 | Test Loss=0.005205867 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [534/1000] | Train Loss=0.000439048 | Test Loss=0.005198602 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [535/1000] | Train Loss=0.000431101 | Test Loss=0.005198065 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [536/1000] | Train Loss=0.000437032 | Test Loss=0.005184273 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [537/1000] | Train Loss=0.000429292 | Test Loss=0.005202872 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [538/1000] | Train Loss=0.000429379 | Test Loss=0.005188701 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [539/1000] | Train Loss=0.000433653 | Test Loss=0.005174636 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [540/1000] | Train Loss=0.000437434 | Test Loss=0.005179016 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [541/1000] | Train Loss=0.000430542 | Test Loss=0.005183500 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [542/1000] | Train Loss=0.000432753 | Test Loss=0.005217358 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [543/1000] | Train Loss=0.000431487 | Test Loss=0.005159239 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [544/1000] | Train Loss=0.000432116 | Test Loss=0.005208214 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [545/1000] | Train Loss=0.000436589 | Test Loss=0.005200213 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [546/1000] | Train Loss=0.000434060 | Test Loss=0.005210108 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [547/1000] | Train Loss=0.000434647 | Test Loss=0.005190543 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [548/1000] | Train Loss=0.000432955 | Test Loss=0.005252782 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [549/1000] | Train Loss=0.000442097 | Test Loss=0.005205730 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [550/1000] | Train Loss=0.000445224 | Test Loss=0.005236048 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [551/1000] | Train Loss=0.000456349 | Test Loss=0.005206640 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [552/1000] | Train Loss=0.000427753 | Test Loss=0.005230918 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [553/1000] | Train Loss=0.000427243 | Test Loss=0.005172200 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [554/1000] | Train Loss=0.000426078 | Test Loss=0.005182127 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [555/1000] | Train Loss=0.000435490 | Test Loss=0.005190146 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [556/1000] | Train Loss=0.000434573 | Test Loss=0.005162829 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [557/1000] | Train Loss=0.000428539 | Test Loss=0.005198074 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [558/1000] | Train Loss=0.000424571 | Test Loss=0.005144078 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [559/1000] | Train Loss=0.000440608 | Test Loss=0.005196692 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [560/1000] | Train Loss=0.000427988 | Test Loss=0.005169834 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [561/1000] | Train Loss=0.000431994 | Test Loss=0.005209405 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [562/1000] | Train Loss=0.000437966 | Test Loss=0.005185441 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [563/1000] | Train Loss=0.000428620 | Test Loss=0.005198615 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [564/1000] | Train Loss=0.000434241 | Test Loss=0.005209801 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [565/1000] | Train Loss=0.000433040 | Test Loss=0.005192000 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [566/1000] | Train Loss=0.000435896 | Test Loss=0.005183524 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [567/1000] | Train Loss=0.000428922 | Test Loss=0.005182344 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [568/1000] | Train Loss=0.000427418 | Test Loss=0.005165444 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [569/1000] | Train Loss=0.000432109 | Test Loss=0.005211927 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [570/1000] | Train Loss=0.000434001 | Test Loss=0.005186345 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [571/1000] | Train Loss=0.000425363 | Test Loss=0.005197773 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [572/1000] | Train Loss=0.000421459 | Test Loss=0.005170583 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [573/1000] | Train Loss=0.000423797 | Test Loss=0.005178376 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [574/1000] | Train Loss=0.000424886 | Test Loss=0.005147149 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [575/1000] | Train Loss=0.000425225 | Test Loss=0.005184638 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [576/1000] | Train Loss=0.000428774 | Test Loss=0.005147959 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [577/1000] | Train Loss=0.000433314 | Test Loss=0.005195487 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [578/1000] | Train Loss=0.000427887 | Test Loss=0.005161630 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [579/1000] | Train Loss=0.000418220 | Test Loss=0.005187340 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [580/1000] | Train Loss=0.000436299 | Test Loss=0.005173285 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [581/1000] | Train Loss=0.000435300 | Test Loss=0.005198808 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [582/1000] | Train Loss=0.000435314 | Test Loss=0.005171764 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [583/1000] | Train Loss=0.000422325 | Test Loss=0.005183301 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [584/1000] | Train Loss=0.000426293 | Test Loss=0.005195939 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [585/1000] | Train Loss=0.000420604 | Test Loss=0.005193022 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [586/1000] | Train Loss=0.000423182 | Test Loss=0.005164281 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [587/1000] | Train Loss=0.000426571 | Test Loss=0.005188939 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [588/1000] | Train Loss=0.000428493 | Test Loss=0.005199312 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [589/1000] | Train Loss=0.000434118 | Test Loss=0.005150096 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [590/1000] | Train Loss=0.000424422 | Test Loss=0.005193173 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [591/1000] | Train Loss=0.000424428 | Test Loss=0.005165164 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [592/1000] | Train Loss=0.000426184 | Test Loss=0.005178307 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [593/1000] | Train Loss=0.000426084 | Test Loss=0.005158816 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [594/1000] | Train Loss=0.000418311 | Test Loss=0.005156586 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [595/1000] | Train Loss=0.000432577 | Test Loss=0.005149011 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [596/1000] | Train Loss=0.000429329 | Test Loss=0.005146548 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [597/1000] | Train Loss=0.000425881 | Test Loss=0.005182957 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [598/1000] | Train Loss=0.000436481 | Test Loss=0.005161586 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [599/1000] | Train Loss=0.000438992 | Test Loss=0.005149647 | Time=1.00s | LR=7.81e-06\n",
      "Epoch [600/1000] | Train Loss=0.000427786 | Test Loss=0.005125577 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [601/1000] | Train Loss=0.000419162 | Test Loss=0.005147869 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [602/1000] | Train Loss=0.000417323 | Test Loss=0.005145695 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [603/1000] | Train Loss=0.000411702 | Test Loss=0.005148790 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [604/1000] | Train Loss=0.000408834 | Test Loss=0.005154609 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [605/1000] | Train Loss=0.000419431 | Test Loss=0.005125253 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [606/1000] | Train Loss=0.000412939 | Test Loss=0.005155933 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [607/1000] | Train Loss=0.000409484 | Test Loss=0.005137685 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [608/1000] | Train Loss=0.000411307 | Test Loss=0.005149441 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [609/1000] | Train Loss=0.000411965 | Test Loss=0.005156299 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [610/1000] | Train Loss=0.000415025 | Test Loss=0.005149714 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [611/1000] | Train Loss=0.000419047 | Test Loss=0.005140064 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [612/1000] | Train Loss=0.000422037 | Test Loss=0.005135842 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [613/1000] | Train Loss=0.000415949 | Test Loss=0.005128757 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [614/1000] | Train Loss=0.000418051 | Test Loss=0.005132090 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [615/1000] | Train Loss=0.000415805 | Test Loss=0.005140677 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [616/1000] | Train Loss=0.000414276 | Test Loss=0.005154678 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [617/1000] | Train Loss=0.000414447 | Test Loss=0.005140088 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [618/1000] | Train Loss=0.000414110 | Test Loss=0.005148998 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [619/1000] | Train Loss=0.000410212 | Test Loss=0.005126522 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [620/1000] | Train Loss=0.000414070 | Test Loss=0.005140269 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [621/1000] | Train Loss=0.000414925 | Test Loss=0.005166430 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [622/1000] | Train Loss=0.000412293 | Test Loss=0.005147750 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [623/1000] | Train Loss=0.000411388 | Test Loss=0.005166229 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [624/1000] | Train Loss=0.000415747 | Test Loss=0.005129211 | Time=1.00s | LR=3.91e-06\n",
      "Epoch [625/1000] | Train Loss=0.000415957 | Test Loss=0.005140868 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [626/1000] | Train Loss=0.000405400 | Test Loss=0.005157323 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [627/1000] | Train Loss=0.000409520 | Test Loss=0.005137048 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [628/1000] | Train Loss=0.000405928 | Test Loss=0.005137637 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [629/1000] | Train Loss=0.000404546 | Test Loss=0.005150225 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [630/1000] | Train Loss=0.000404141 | Test Loss=0.005139045 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [631/1000] | Train Loss=0.000407398 | Test Loss=0.005129175 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [632/1000] | Train Loss=0.000407254 | Test Loss=0.005135055 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [633/1000] | Train Loss=0.000415876 | Test Loss=0.005143728 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [634/1000] | Train Loss=0.000406261 | Test Loss=0.005137708 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [635/1000] | Train Loss=0.000411372 | Test Loss=0.005131045 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [636/1000] | Train Loss=0.000407945 | Test Loss=0.005135363 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [637/1000] | Train Loss=0.000415322 | Test Loss=0.005137428 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [638/1000] | Train Loss=0.000404183 | Test Loss=0.005121904 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [639/1000] | Train Loss=0.000410467 | Test Loss=0.005137643 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [640/1000] | Train Loss=0.000412860 | Test Loss=0.005137779 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [641/1000] | Train Loss=0.000405075 | Test Loss=0.005149435 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [642/1000] | Train Loss=0.000412083 | Test Loss=0.005150917 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [643/1000] | Train Loss=0.000409446 | Test Loss=0.005145980 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [644/1000] | Train Loss=0.000409716 | Test Loss=0.005137404 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [645/1000] | Train Loss=0.000406889 | Test Loss=0.005136354 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [646/1000] | Train Loss=0.000414841 | Test Loss=0.005146890 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [647/1000] | Train Loss=0.000408024 | Test Loss=0.005132459 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [648/1000] | Train Loss=0.000405556 | Test Loss=0.005132563 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [649/1000] | Train Loss=0.000409948 | Test Loss=0.005136017 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [650/1000] | Train Loss=0.000407496 | Test Loss=0.005129517 | Time=1.00s | LR=1.95e-06\n",
      "Epoch [651/1000] | Train Loss=0.000404751 | Test Loss=0.005126685 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [652/1000] | Train Loss=0.000406458 | Test Loss=0.005136870 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [653/1000] | Train Loss=0.000404721 | Test Loss=0.005131976 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [654/1000] | Train Loss=0.000407196 | Test Loss=0.005151528 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [655/1000] | Train Loss=0.000408828 | Test Loss=0.005139786 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [656/1000] | Train Loss=0.000402771 | Test Loss=0.005138705 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [657/1000] | Train Loss=0.000406725 | Test Loss=0.005118595 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [658/1000] | Train Loss=0.000407739 | Test Loss=0.005130597 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [659/1000] | Train Loss=0.000402354 | Test Loss=0.005129065 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [660/1000] | Train Loss=0.000405954 | Test Loss=0.005124324 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [661/1000] | Train Loss=0.000404669 | Test Loss=0.005138521 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [662/1000] | Train Loss=0.000409774 | Test Loss=0.005129844 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [663/1000] | Train Loss=0.000407389 | Test Loss=0.005130603 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [664/1000] | Train Loss=0.000398603 | Test Loss=0.005144196 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [665/1000] | Train Loss=0.000405361 | Test Loss=0.005125013 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [666/1000] | Train Loss=0.000402812 | Test Loss=0.005134228 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [667/1000] | Train Loss=0.000402925 | Test Loss=0.005134986 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [668/1000] | Train Loss=0.000401463 | Test Loss=0.005131812 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [669/1000] | Train Loss=0.000404627 | Test Loss=0.005141655 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [670/1000] | Train Loss=0.000401846 | Test Loss=0.005127591 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [671/1000] | Train Loss=0.000408496 | Test Loss=0.005134913 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [672/1000] | Train Loss=0.000402714 | Test Loss=0.005123302 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [673/1000] | Train Loss=0.000407532 | Test Loss=0.005126009 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [674/1000] | Train Loss=0.000407675 | Test Loss=0.005128861 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [675/1000] | Train Loss=0.000400097 | Test Loss=0.005126893 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [676/1000] | Train Loss=0.000409729 | Test Loss=0.005134497 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [677/1000] | Train Loss=0.000401266 | Test Loss=0.005138653 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [678/1000] | Train Loss=0.000406487 | Test Loss=0.005142397 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [679/1000] | Train Loss=0.000408015 | Test Loss=0.005136061 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [680/1000] | Train Loss=0.000407893 | Test Loss=0.005143158 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [681/1000] | Train Loss=0.000403376 | Test Loss=0.005134421 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [682/1000] | Train Loss=0.000402744 | Test Loss=0.005130359 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [683/1000] | Train Loss=0.000405600 | Test Loss=0.005129052 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [684/1000] | Train Loss=0.000407663 | Test Loss=0.005131633 | Time=1.00s | LR=9.77e-07\n",
      "Epoch [685/1000] | Train Loss=0.000399710 | Test Loss=0.005141516 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [686/1000] | Train Loss=0.000402297 | Test Loss=0.005129987 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [687/1000] | Train Loss=0.000409422 | Test Loss=0.005134680 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [688/1000] | Train Loss=0.000405503 | Test Loss=0.005135780 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [689/1000] | Train Loss=0.000405761 | Test Loss=0.005132492 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [690/1000] | Train Loss=0.000400667 | Test Loss=0.005130456 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [691/1000] | Train Loss=0.000406237 | Test Loss=0.005128189 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [692/1000] | Train Loss=0.000400514 | Test Loss=0.005135674 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [693/1000] | Train Loss=0.000404785 | Test Loss=0.005131216 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [694/1000] | Train Loss=0.000400681 | Test Loss=0.005139366 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [695/1000] | Train Loss=0.000405976 | Test Loss=0.005129679 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [696/1000] | Train Loss=0.000407449 | Test Loss=0.005132169 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [697/1000] | Train Loss=0.000404801 | Test Loss=0.005128534 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [698/1000] | Train Loss=0.000406053 | Test Loss=0.005126522 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [699/1000] | Train Loss=0.000404439 | Test Loss=0.005124753 | Time=1.01s | LR=4.88e-07\n",
      "Epoch [700/1000] | Train Loss=0.000405536 | Test Loss=0.005128708 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [701/1000] | Train Loss=0.000408151 | Test Loss=0.005128731 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [702/1000] | Train Loss=0.000402252 | Test Loss=0.005123026 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [703/1000] | Train Loss=0.000399747 | Test Loss=0.005132506 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [704/1000] | Train Loss=0.000407305 | Test Loss=0.005123942 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [705/1000] | Train Loss=0.000402549 | Test Loss=0.005126408 | Time=1.00s | LR=4.88e-07\n",
      "Epoch [706/1000] | Train Loss=0.000399687 | Test Loss=0.005132310 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [707/1000] | Train Loss=0.000397836 | Test Loss=0.005125225 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [708/1000] | Train Loss=0.000405263 | Test Loss=0.005122688 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [709/1000] | Train Loss=0.000400248 | Test Loss=0.005124433 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [710/1000] | Train Loss=0.000397710 | Test Loss=0.005126050 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [711/1000] | Train Loss=0.000400791 | Test Loss=0.005128150 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [712/1000] | Train Loss=0.000399669 | Test Loss=0.005124832 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [713/1000] | Train Loss=0.000402589 | Test Loss=0.005127136 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [714/1000] | Train Loss=0.000399455 | Test Loss=0.005128054 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [715/1000] | Train Loss=0.000401010 | Test Loss=0.005129194 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [716/1000] | Train Loss=0.000396816 | Test Loss=0.005128623 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [717/1000] | Train Loss=0.000401556 | Test Loss=0.005123339 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [718/1000] | Train Loss=0.000406592 | Test Loss=0.005134636 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [719/1000] | Train Loss=0.000407498 | Test Loss=0.005127102 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [720/1000] | Train Loss=0.000400040 | Test Loss=0.005128736 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [721/1000] | Train Loss=0.000399650 | Test Loss=0.005124522 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [722/1000] | Train Loss=0.000404312 | Test Loss=0.005127719 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [723/1000] | Train Loss=0.000404072 | Test Loss=0.005131028 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [724/1000] | Train Loss=0.000400316 | Test Loss=0.005125670 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [725/1000] | Train Loss=0.000401595 | Test Loss=0.005124731 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [726/1000] | Train Loss=0.000399331 | Test Loss=0.005127836 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [727/1000] | Train Loss=0.000402259 | Test Loss=0.005127637 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [728/1000] | Train Loss=0.000407106 | Test Loss=0.005120680 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [729/1000] | Train Loss=0.000403404 | Test Loss=0.005129229 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [730/1000] | Train Loss=0.000405851 | Test Loss=0.005120151 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [731/1000] | Train Loss=0.000399162 | Test Loss=0.005123081 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [732/1000] | Train Loss=0.000405299 | Test Loss=0.005132238 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [733/1000] | Train Loss=0.000402689 | Test Loss=0.005127485 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [734/1000] | Train Loss=0.000400252 | Test Loss=0.005127181 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [735/1000] | Train Loss=0.000404284 | Test Loss=0.005128534 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [736/1000] | Train Loss=0.000397809 | Test Loss=0.005133592 | Time=1.00s | LR=2.44e-07\n",
      "Epoch [737/1000] | Train Loss=0.000401212 | Test Loss=0.005131669 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [738/1000] | Train Loss=0.000403963 | Test Loss=0.005127110 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [739/1000] | Train Loss=0.000400705 | Test Loss=0.005125133 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [740/1000] | Train Loss=0.000400139 | Test Loss=0.005124833 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [741/1000] | Train Loss=0.000401983 | Test Loss=0.005130009 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [742/1000] | Train Loss=0.000402591 | Test Loss=0.005131551 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [743/1000] | Train Loss=0.000404524 | Test Loss=0.005129292 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [744/1000] | Train Loss=0.000398950 | Test Loss=0.005128547 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [745/1000] | Train Loss=0.000402451 | Test Loss=0.005131311 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [746/1000] | Train Loss=0.000400397 | Test Loss=0.005128738 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [747/1000] | Train Loss=0.000399035 | Test Loss=0.005126402 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [748/1000] | Train Loss=0.000399550 | Test Loss=0.005126762 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [749/1000] | Train Loss=0.000397989 | Test Loss=0.005122502 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [750/1000] | Train Loss=0.000406985 | Test Loss=0.005126509 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [751/1000] | Train Loss=0.000404456 | Test Loss=0.005127588 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [752/1000] | Train Loss=0.000403787 | Test Loss=0.005128780 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [753/1000] | Train Loss=0.000405186 | Test Loss=0.005132411 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [754/1000] | Train Loss=0.000405853 | Test Loss=0.005127235 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [755/1000] | Train Loss=0.000403449 | Test Loss=0.005126057 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [756/1000] | Train Loss=0.000401480 | Test Loss=0.005131354 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [757/1000] | Train Loss=0.000398262 | Test Loss=0.005120255 | Time=1.00s | LR=1.22e-07\n",
      "Epoch [758/1000] | Train Loss=0.000404617 | Test Loss=0.005126925 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [759/1000] | Train Loss=0.000399262 | Test Loss=0.005128552 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [760/1000] | Train Loss=0.000402067 | Test Loss=0.005133096 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [761/1000] | Train Loss=0.000405502 | Test Loss=0.005124203 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [762/1000] | Train Loss=0.000402222 | Test Loss=0.005127493 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [763/1000] | Train Loss=0.000401421 | Test Loss=0.005131800 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [764/1000] | Train Loss=0.000409212 | Test Loss=0.005126791 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [765/1000] | Train Loss=0.000407450 | Test Loss=0.005132907 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [766/1000] | Train Loss=0.000401227 | Test Loss=0.005130333 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [767/1000] | Train Loss=0.000404326 | Test Loss=0.005131065 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [768/1000] | Train Loss=0.000402900 | Test Loss=0.005129318 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [769/1000] | Train Loss=0.000403908 | Test Loss=0.005127885 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [770/1000] | Train Loss=0.000397179 | Test Loss=0.005133876 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [771/1000] | Train Loss=0.000400381 | Test Loss=0.005127880 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [772/1000] | Train Loss=0.000404130 | Test Loss=0.005129200 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [773/1000] | Train Loss=0.000410177 | Test Loss=0.005126885 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [774/1000] | Train Loss=0.000403651 | Test Loss=0.005129565 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [775/1000] | Train Loss=0.000405865 | Test Loss=0.005129327 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [776/1000] | Train Loss=0.000403660 | Test Loss=0.005123992 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [777/1000] | Train Loss=0.000401583 | Test Loss=0.005128902 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [778/1000] | Train Loss=0.000402994 | Test Loss=0.005124763 | Time=1.00s | LR=6.10e-08\n",
      "Epoch [779/1000] | Train Loss=0.000400143 | Test Loss=0.005126838 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [780/1000] | Train Loss=0.000397620 | Test Loss=0.005128558 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [781/1000] | Train Loss=0.000400633 | Test Loss=0.005131233 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [782/1000] | Train Loss=0.000402499 | Test Loss=0.005133544 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [783/1000] | Train Loss=0.000401569 | Test Loss=0.005126529 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [784/1000] | Train Loss=0.000401742 | Test Loss=0.005132292 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [785/1000] | Train Loss=0.000400710 | Test Loss=0.005126159 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [786/1000] | Train Loss=0.000405665 | Test Loss=0.005125186 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [787/1000] | Train Loss=0.000403227 | Test Loss=0.005126878 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [788/1000] | Train Loss=0.000403905 | Test Loss=0.005126570 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [789/1000] | Train Loss=0.000400241 | Test Loss=0.005125819 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [790/1000] | Train Loss=0.000403791 | Test Loss=0.005131409 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [791/1000] | Train Loss=0.000403119 | Test Loss=0.005123175 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [792/1000] | Train Loss=0.000401059 | Test Loss=0.005126292 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [793/1000] | Train Loss=0.000401000 | Test Loss=0.005122009 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [794/1000] | Train Loss=0.000398822 | Test Loss=0.005126964 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [795/1000] | Train Loss=0.000403371 | Test Loss=0.005131120 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [796/1000] | Train Loss=0.000400318 | Test Loss=0.005129267 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [797/1000] | Train Loss=0.000396297 | Test Loss=0.005130688 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [798/1000] | Train Loss=0.000402402 | Test Loss=0.005125430 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [799/1000] | Train Loss=0.000400737 | Test Loss=0.005123209 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [800/1000] | Train Loss=0.000408326 | Test Loss=0.005125094 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [801/1000] | Train Loss=0.000401483 | Test Loss=0.005126162 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [802/1000] | Train Loss=0.000402102 | Test Loss=0.005125350 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [803/1000] | Train Loss=0.000400932 | Test Loss=0.005132838 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [804/1000] | Train Loss=0.000401021 | Test Loss=0.005130865 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [805/1000] | Train Loss=0.000395831 | Test Loss=0.005126827 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [806/1000] | Train Loss=0.000403489 | Test Loss=0.005130329 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [807/1000] | Train Loss=0.000401913 | Test Loss=0.005132098 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [808/1000] | Train Loss=0.000401509 | Test Loss=0.005128111 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [809/1000] | Train Loss=0.000396562 | Test Loss=0.005129306 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [810/1000] | Train Loss=0.000401201 | Test Loss=0.005128472 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [811/1000] | Train Loss=0.000404093 | Test Loss=0.005130357 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [812/1000] | Train Loss=0.000403172 | Test Loss=0.005129660 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [813/1000] | Train Loss=0.000407305 | Test Loss=0.005133344 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [814/1000] | Train Loss=0.000398645 | Test Loss=0.005135610 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [815/1000] | Train Loss=0.000398921 | Test Loss=0.005129422 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [816/1000] | Train Loss=0.000401906 | Test Loss=0.005129045 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [817/1000] | Train Loss=0.000396394 | Test Loss=0.005127055 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [818/1000] | Train Loss=0.000406652 | Test Loss=0.005130383 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [819/1000] | Train Loss=0.000396523 | Test Loss=0.005129044 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [820/1000] | Train Loss=0.000403062 | Test Loss=0.005132405 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [821/1000] | Train Loss=0.000400080 | Test Loss=0.005132205 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [822/1000] | Train Loss=0.000399322 | Test Loss=0.005129657 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [823/1000] | Train Loss=0.000397127 | Test Loss=0.005131567 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [824/1000] | Train Loss=0.000409491 | Test Loss=0.005130162 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [825/1000] | Train Loss=0.000400774 | Test Loss=0.005128213 | Time=1.00s | LR=3.05e-08\n",
      "Epoch [826/1000] | Train Loss=0.000401225 | Test Loss=0.005124844 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [827/1000] | Train Loss=0.000397982 | Test Loss=0.005133197 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [828/1000] | Train Loss=0.000400727 | Test Loss=0.005131864 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [829/1000] | Train Loss=0.000406058 | Test Loss=0.005130778 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [830/1000] | Train Loss=0.000397527 | Test Loss=0.005130943 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [831/1000] | Train Loss=0.000399411 | Test Loss=0.005130467 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [832/1000] | Train Loss=0.000400427 | Test Loss=0.005130859 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [833/1000] | Train Loss=0.000400489 | Test Loss=0.005130781 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [834/1000] | Train Loss=0.000403019 | Test Loss=0.005128493 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [835/1000] | Train Loss=0.000407878 | Test Loss=0.005131420 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [836/1000] | Train Loss=0.000401166 | Test Loss=0.005130499 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [837/1000] | Train Loss=0.000405372 | Test Loss=0.005129716 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [838/1000] | Train Loss=0.000402547 | Test Loss=0.005130670 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [839/1000] | Train Loss=0.000400248 | Test Loss=0.005131756 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [840/1000] | Train Loss=0.000400748 | Test Loss=0.005131444 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [841/1000] | Train Loss=0.000403043 | Test Loss=0.005130547 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [842/1000] | Train Loss=0.000400327 | Test Loss=0.005130325 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [843/1000] | Train Loss=0.000399776 | Test Loss=0.005130373 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [844/1000] | Train Loss=0.000401784 | Test Loss=0.005130883 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [845/1000] | Train Loss=0.000406259 | Test Loss=0.005131080 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [846/1000] | Train Loss=0.000397164 | Test Loss=0.005131402 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [847/1000] | Train Loss=0.000395887 | Test Loss=0.005130708 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [848/1000] | Train Loss=0.000401140 | Test Loss=0.005131101 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [849/1000] | Train Loss=0.000399818 | Test Loss=0.005128069 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [850/1000] | Train Loss=0.000401461 | Test Loss=0.005129317 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [851/1000] | Train Loss=0.000399449 | Test Loss=0.005129176 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [852/1000] | Train Loss=0.000402931 | Test Loss=0.005131172 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [853/1000] | Train Loss=0.000400213 | Test Loss=0.005129864 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [854/1000] | Train Loss=0.000402480 | Test Loss=0.005130835 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [855/1000] | Train Loss=0.000400762 | Test Loss=0.005130283 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [856/1000] | Train Loss=0.000399685 | Test Loss=0.005130579 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [857/1000] | Train Loss=0.000403194 | Test Loss=0.005129917 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [858/1000] | Train Loss=0.000399067 | Test Loss=0.005129997 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [859/1000] | Train Loss=0.000401380 | Test Loss=0.005132567 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [860/1000] | Train Loss=0.000397817 | Test Loss=0.005130658 | Time=1.01s | LR=1.53e-08\n",
      "Epoch [861/1000] | Train Loss=0.000397399 | Test Loss=0.005130482 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [862/1000] | Train Loss=0.000402963 | Test Loss=0.005132015 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [863/1000] | Train Loss=0.000400639 | Test Loss=0.005130014 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [864/1000] | Train Loss=0.000398949 | Test Loss=0.005130716 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [865/1000] | Train Loss=0.000413668 | Test Loss=0.005129419 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [866/1000] | Train Loss=0.000407967 | Test Loss=0.005130829 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [867/1000] | Train Loss=0.000404783 | Test Loss=0.005130213 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [868/1000] | Train Loss=0.000400506 | Test Loss=0.005131445 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [869/1000] | Train Loss=0.000404229 | Test Loss=0.005131143 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [870/1000] | Train Loss=0.000400255 | Test Loss=0.005130105 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [871/1000] | Train Loss=0.000405584 | Test Loss=0.005130106 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [872/1000] | Train Loss=0.000397405 | Test Loss=0.005130892 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [873/1000] | Train Loss=0.000399155 | Test Loss=0.005129654 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [874/1000] | Train Loss=0.000403053 | Test Loss=0.005128885 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [875/1000] | Train Loss=0.000399976 | Test Loss=0.005128756 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [876/1000] | Train Loss=0.000398421 | Test Loss=0.005131360 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [877/1000] | Train Loss=0.000409597 | Test Loss=0.005127099 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [878/1000] | Train Loss=0.000398873 | Test Loss=0.005128103 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [879/1000] | Train Loss=0.000404244 | Test Loss=0.005127415 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [880/1000] | Train Loss=0.000401270 | Test Loss=0.005127165 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [881/1000] | Train Loss=0.000400973 | Test Loss=0.005127318 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [882/1000] | Train Loss=0.000400694 | Test Loss=0.005127993 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [883/1000] | Train Loss=0.000398825 | Test Loss=0.005127197 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [884/1000] | Train Loss=0.000395223 | Test Loss=0.005128584 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [885/1000] | Train Loss=0.000400165 | Test Loss=0.005128047 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [886/1000] | Train Loss=0.000410097 | Test Loss=0.005129711 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [887/1000] | Train Loss=0.000395659 | Test Loss=0.005128125 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [888/1000] | Train Loss=0.000403572 | Test Loss=0.005130280 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [889/1000] | Train Loss=0.000401606 | Test Loss=0.005128197 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [890/1000] | Train Loss=0.000402633 | Test Loss=0.005127695 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [891/1000] | Train Loss=0.000396154 | Test Loss=0.005127762 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [892/1000] | Train Loss=0.000400946 | Test Loss=0.005128466 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [893/1000] | Train Loss=0.000399748 | Test Loss=0.005127713 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [894/1000] | Train Loss=0.000402452 | Test Loss=0.005127912 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [895/1000] | Train Loss=0.000400991 | Test Loss=0.005127564 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [896/1000] | Train Loss=0.000402860 | Test Loss=0.005128172 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [897/1000] | Train Loss=0.000406596 | Test Loss=0.005127801 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [898/1000] | Train Loss=0.000398548 | Test Loss=0.005127987 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [899/1000] | Train Loss=0.000403322 | Test Loss=0.005127369 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [900/1000] | Train Loss=0.000395622 | Test Loss=0.005128406 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [901/1000] | Train Loss=0.000404477 | Test Loss=0.005129329 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [902/1000] | Train Loss=0.000401835 | Test Loss=0.005128148 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [903/1000] | Train Loss=0.000402205 | Test Loss=0.005130040 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [904/1000] | Train Loss=0.000404419 | Test Loss=0.005130430 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [905/1000] | Train Loss=0.000398798 | Test Loss=0.005128020 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [906/1000] | Train Loss=0.000406807 | Test Loss=0.005128034 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [907/1000] | Train Loss=0.000397936 | Test Loss=0.005127402 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [908/1000] | Train Loss=0.000404618 | Test Loss=0.005128349 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [909/1000] | Train Loss=0.000402269 | Test Loss=0.005129928 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [910/1000] | Train Loss=0.000405188 | Test Loss=0.005131603 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [911/1000] | Train Loss=0.000398702 | Test Loss=0.005132583 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [912/1000] | Train Loss=0.000396095 | Test Loss=0.005128665 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [913/1000] | Train Loss=0.000401895 | Test Loss=0.005131645 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [914/1000] | Train Loss=0.000398950 | Test Loss=0.005128802 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [915/1000] | Train Loss=0.000409554 | Test Loss=0.005128168 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [916/1000] | Train Loss=0.000401601 | Test Loss=0.005129046 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [917/1000] | Train Loss=0.000398123 | Test Loss=0.005129644 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [918/1000] | Train Loss=0.000400672 | Test Loss=0.005130264 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [919/1000] | Train Loss=0.000400649 | Test Loss=0.005129578 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [920/1000] | Train Loss=0.000399756 | Test Loss=0.005129767 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [921/1000] | Train Loss=0.000406220 | Test Loss=0.005128856 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [922/1000] | Train Loss=0.000401884 | Test Loss=0.005130767 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [923/1000] | Train Loss=0.000400389 | Test Loss=0.005129967 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [924/1000] | Train Loss=0.000397968 | Test Loss=0.005129533 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [925/1000] | Train Loss=0.000403515 | Test Loss=0.005129322 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [926/1000] | Train Loss=0.000402678 | Test Loss=0.005129351 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [927/1000] | Train Loss=0.000395514 | Test Loss=0.005128958 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [928/1000] | Train Loss=0.000397562 | Test Loss=0.005130207 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [929/1000] | Train Loss=0.000404802 | Test Loss=0.005129498 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [930/1000] | Train Loss=0.000399597 | Test Loss=0.005128911 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [931/1000] | Train Loss=0.000400654 | Test Loss=0.005130290 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [932/1000] | Train Loss=0.000400843 | Test Loss=0.005129757 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [933/1000] | Train Loss=0.000399876 | Test Loss=0.005131581 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [934/1000] | Train Loss=0.000397938 | Test Loss=0.005132203 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [935/1000] | Train Loss=0.000398677 | Test Loss=0.005131261 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [936/1000] | Train Loss=0.000396934 | Test Loss=0.005131794 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [937/1000] | Train Loss=0.000398993 | Test Loss=0.005131707 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [938/1000] | Train Loss=0.000404507 | Test Loss=0.005132197 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [939/1000] | Train Loss=0.000403425 | Test Loss=0.005131281 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [940/1000] | Train Loss=0.000403114 | Test Loss=0.005130066 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [941/1000] | Train Loss=0.000398350 | Test Loss=0.005132632 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [942/1000] | Train Loss=0.000403755 | Test Loss=0.005131571 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [943/1000] | Train Loss=0.000399663 | Test Loss=0.005131293 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [944/1000] | Train Loss=0.000402856 | Test Loss=0.005130521 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [945/1000] | Train Loss=0.000396525 | Test Loss=0.005130601 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [946/1000] | Train Loss=0.000404064 | Test Loss=0.005131156 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [947/1000] | Train Loss=0.000406164 | Test Loss=0.005133512 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [948/1000] | Train Loss=0.000401519 | Test Loss=0.005131117 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [949/1000] | Train Loss=0.000402179 | Test Loss=0.005131469 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [950/1000] | Train Loss=0.000398229 | Test Loss=0.005131581 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [951/1000] | Train Loss=0.000399331 | Test Loss=0.005133357 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [952/1000] | Train Loss=0.000398343 | Test Loss=0.005130344 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [953/1000] | Train Loss=0.000402259 | Test Loss=0.005129933 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [954/1000] | Train Loss=0.000401341 | Test Loss=0.005132738 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [955/1000] | Train Loss=0.000398030 | Test Loss=0.005129110 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [956/1000] | Train Loss=0.000404229 | Test Loss=0.005132166 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [957/1000] | Train Loss=0.000402667 | Test Loss=0.005130636 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [958/1000] | Train Loss=0.000406004 | Test Loss=0.005131480 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [959/1000] | Train Loss=0.000397896 | Test Loss=0.005129545 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [960/1000] | Train Loss=0.000402274 | Test Loss=0.005130757 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [961/1000] | Train Loss=0.000401619 | Test Loss=0.005131640 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [962/1000] | Train Loss=0.000398870 | Test Loss=0.005130287 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [963/1000] | Train Loss=0.000402652 | Test Loss=0.005131157 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [964/1000] | Train Loss=0.000402237 | Test Loss=0.005130751 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [965/1000] | Train Loss=0.000400433 | Test Loss=0.005131211 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [966/1000] | Train Loss=0.000405906 | Test Loss=0.005131532 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [967/1000] | Train Loss=0.000404324 | Test Loss=0.005131608 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [968/1000] | Train Loss=0.000409491 | Test Loss=0.005131900 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [969/1000] | Train Loss=0.000397716 | Test Loss=0.005131690 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [970/1000] | Train Loss=0.000405011 | Test Loss=0.005129184 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [971/1000] | Train Loss=0.000398953 | Test Loss=0.005129283 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [972/1000] | Train Loss=0.000406674 | Test Loss=0.005129242 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [973/1000] | Train Loss=0.000396947 | Test Loss=0.005128868 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [974/1000] | Train Loss=0.000399833 | Test Loss=0.005130235 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [975/1000] | Train Loss=0.000397754 | Test Loss=0.005129619 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [976/1000] | Train Loss=0.000404827 | Test Loss=0.005130398 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [977/1000] | Train Loss=0.000401527 | Test Loss=0.005131296 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [978/1000] | Train Loss=0.000403093 | Test Loss=0.005132021 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [979/1000] | Train Loss=0.000402438 | Test Loss=0.005132051 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [980/1000] | Train Loss=0.000401323 | Test Loss=0.005132481 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [981/1000] | Train Loss=0.000401577 | Test Loss=0.005131214 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [982/1000] | Train Loss=0.000397932 | Test Loss=0.005129305 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [983/1000] | Train Loss=0.000396484 | Test Loss=0.005128564 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [984/1000] | Train Loss=0.000400452 | Test Loss=0.005129784 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [985/1000] | Train Loss=0.000410301 | Test Loss=0.005131736 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [986/1000] | Train Loss=0.000398761 | Test Loss=0.005130072 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [987/1000] | Train Loss=0.000397475 | Test Loss=0.005130402 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [988/1000] | Train Loss=0.000405356 | Test Loss=0.005131064 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [989/1000] | Train Loss=0.000402028 | Test Loss=0.005129951 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [990/1000] | Train Loss=0.000406125 | Test Loss=0.005129702 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [991/1000] | Train Loss=0.000399700 | Test Loss=0.005130521 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [992/1000] | Train Loss=0.000401632 | Test Loss=0.005132602 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [993/1000] | Train Loss=0.000402179 | Test Loss=0.005131692 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [994/1000] | Train Loss=0.000401092 | Test Loss=0.005130901 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [995/1000] | Train Loss=0.000406265 | Test Loss=0.005129788 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [996/1000] | Train Loss=0.000398359 | Test Loss=0.005130506 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [997/1000] | Train Loss=0.000401904 | Test Loss=0.005130242 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [998/1000] | Train Loss=0.000406249 | Test Loss=0.005130646 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [999/1000] | Train Loss=0.000399058 | Test Loss=0.005131538 | Time=1.00s | LR=1.53e-08\n",
      "Epoch [1000/1000] | Train Loss=0.000401246 | Test Loss=0.005130415 | Time=1.00s | LR=1.53e-08\n",
      "\n",
      "Total training time: 1002.31 seconds\n"
     ]
    },
    {
     "data": {
      "image/png": "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97/2a15++WUxJCRE/Pbbb8X9+/eLN954o9MpyAMHDhR37Ngh/vHHH2K3bt3a9LTummbOnCl26NDBPn1+zZo1Ynh4uPjkk0/ar2E9N1xRUZG4d+9ece/evSIAcdmyZeLevXvFM2fOiKLomTotKCgQIyMjxbvuuks8ePCguGrVKlGn03H6fEv2f//3f2JcXJyo0WjEoUOHitu3b5e7SC0GAKdfK1assF9TVlYmPvzww2JoaKio0+nEqVOnillZWQ73OX36tDhp0iTR399fDA8PFx9//HHRbDb7+NO0LDWDEOvZc/73v/+Jffr0EbVardizZ0/xvffeczhvs9nEZ555RoyMjBS1Wq04btw48ejRow7XXLp0Sbz99tvFwMBAUa/Xi7NmzRKLiop8+TGaNYPBIM6dO1eMi4sT/fz8xM6dO4tPP/20w5Rs1nPDbd682el/k2fOnCmKoufqdN++feKoUaNErVYrdujQQXz55Zc9Un5BFKstqUlERETUhnCMEBEREbVZDEJERETUZjEIERERUZvFIERERERtFoMQERERtVkMQkRERNRmMQgRERFRm8UgRERERG0WgxARUQMJgoC1a9fKXQwi8gAGISJqUe655x4IglDra+LEiXIXjYhaIJXcBSAiaqiJEydixYoVDse0Wq1MpSGilowtQkTU4mi1WkRFRTl8hYaGApC6rd5++21MmjQJ/v7+6Ny5M7766iuH1x84cABjx46Fv78/2rVrhwceeADFxcUO13z44Yfo3bs3tFotoqOjMXv2bIfzeXl5mDp1KnQ6Hbp164bvvvvOux+aiLyCQYiIWp1nnnkG06ZNw759+zBjxgzcdtttOHz4MACgpKQEEyZMQGhoKFJTU7F69Wr8/PPPDkHn7bffRnJyMh544AEcOHAA3333Hbp27erwHs899xxuueUW7N+/H5MnT8aMGTOQn5/v089JRB7gkT3siYh8ZObMmaJSqRQDAgIcvl588UVRFEURgPjggw86vGbYsGHiQw89JIqiKL733ntiaGioWFxcbD+/bt06UaFQiNnZ2aIoimJMTIz49NNPuywDAPEf//iH/XlxcbEIQPzhhx889jmJyDc4RoiIWpyrr74ab7/9tsOxsLAw++Phw4c7nBs+fDjS0tIAAIcPH0b//v0REBBgPz9y5EjYbDYcPXoUgiDgwoULGDduXJ1l6Nevn/1xQEAA9Ho9cnNzG/uRiEgmDEJE1OIEBATU6qryFH9/f7euU6vVDs8FQYDNZvNGkYjIizhGiIhane3bt9d63qtXLwBAr169sG/fPpSUlNjPb926FQqFAj169EBQUBDi4+OxadMmn5aZiOTBFiEianFMJhOys7MdjqlUKoSHhwMAVq9ejcGDB2PUqFFYuXIldu7cif/85z8AgBkzZuDZZ5/FzJkzsXjxYly8eBGPPPII7rrrLkRGRgIAFi9ejAcffBARERGYNGkSioqKsHXrVjzyyCO+/aBE5HUMQkTU4vz444+Ijo52ONajRw8cOXIEgDSja9WqVXj44YcRHR2Nzz//HImJiQAAnU6Hn376CXPnzsWQIUOg0+kwbdo0LFu2zH6vmTNnwmg04vXXX8f8+fMRHh6O6dOn++4DEpHPCKIoinIXgojIUwRBwDfffIMpU6bIXRQiagE4RoiIiIjaLAYhIiIiarM4RoiIWhX29hNRQ7BFiIiIiNosBiEiIiJqsxiEiIiIqM1iECIiIqI2i0GIiIiI2iwGISIiImqzGISIiIiozWIQIiIiojbr/wFb5167pwFlJQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(device)\n",
    "\n",
    "train_operator(\n",
    "    dataset_raw = train_data, \n",
    "    model = fno, \n",
    "    num_epochs = 1000,\n",
    "    lr = 0.001,\n",
    "    device = device,\n",
    "    batch_size = 16,\n",
    "    test_dataset_raw = test_data,  # (NEW) for test data\n",
    "    reduce_on='train',       # which metric to monitor: 'train' or 'test'\n",
    "    factor=0.5,             # factor to reduce LR on plateau\n",
    "    patience=20,             # epochs of no improvement\n",
    "    min_lr=1e-10,            # minimal LR\n",
    "    cooldown=0\n",
    ")\n",
    "\n",
    "\n",
    "torch.save(fno.state_dict(), 'fno_3.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------train----------------\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Function type: chirped_cosine, Average Rel L2 error: 0.00029363\n",
      "Function type: sine_beats, Average Rel L2 error: 0.00120699\n",
      "Function type: periodic, Average Rel L2 error: 0.00190618\n",
      "\n",
      "Overall average relative L2 error: 0.00113632\n",
      "--------------test----------------\n",
      "Function type: sinc_pulse, Average Rel L2 error: 0.01165068\n",
      "Function type: gaussian_hermite, Average Rel L2 error: 0.00833317\n",
      "Function type: wave_packet, Average Rel L2 error: 0.00413562\n",
      "\n",
      "Overall average relative L2 error: 0.00813788\n",
      "-------------sample----------------\n",
      "Function type: periodic, Average Rel L2 error: 0.00203312\n",
      "Function type: chirped_cosine, Average Rel L2 error: 0.00041351\n",
      "Function type: sine_beats, Average Rel L2 error: 0.00131568\n",
      "\n",
      "Overall average relative L2 error: 0.00125236\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, operator = fno, device = device)\n",
    "print('--------------test----------------')\n",
    "loss = evaluate_operator(dataset = test_data, operator = fno, device = device)\n",
    "print('-------------sample----------------')\n",
    "loss = evaluate_operator(dataset = sample_data, operator = fno, device = device)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "device='cuda:0'\n",
    "plot_functions(dataset=unseen_data, operator=operator, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_functions(dataset=zeroshot_data, operator=operator, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_functions(dataset=test_data, operator=operator, device=device)"
   ]
  }
 ],
 "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
}
