{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "import numpy as np\n",
    "import sys\n",
    "from neuralop.datasets.tensor_dataset import TensorDataset \n",
    "from neuralop.models import FNO\n",
    "\n",
    "from neuralop import Trainer\n",
    "from neuralop.training import OutputEncoderCallback, SimpleTensorBoardLoggerCallback\n",
    "\n",
    "from neuralop.utils import count_params\n",
    "from neuralop import LpLoss, H1Loss\n",
    "\n",
    "device = 'cuda'\n",
    "\n",
    "# data_path = '../data/zongyi/burgers_data_R10.mat'\n",
    "\n",
    "# train_loader, test_loaders, encoder= load_burgers_mat(\n",
    "#     data_path=data_path, n_train=1536, n_test=512, batch_size=32, test_batch_size=32,\n",
    "#     positional_encoding=False, encode_output=False\n",
    "#     )\n",
    "\n",
    "activate_cuda = True\n",
    "device = torch.device(\n",
    "    \"cuda\" if activate_cuda and torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "data = np.load('./data/burgers_ut.npy', allow_pickle=True)\n",
    "if isinstance(data, np.ndarray):\n",
    "    data = data.item()\n",
    "# data = torch.load('./data/burgers_ut.pt')\n",
    "# U, U_x, U_xx, U_t --stack-> [U, U_x, U_xx, U_t]: (C, Nx, Nt) --permute-> (Nx * Nt, C)\n",
    "# data_prep: U :[Nx, Nt] -> [Nt-1, 1, Nx]; target: [Nt-1, 1, Nx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "inputs = torch.tensor(data['x']).unsqueeze(1)\n",
    "target = torch.tensor(data['y']).unsqueeze(1)\n",
    "\n",
    "dataset = TensorDataset(inputs, target)\n",
    "train_loader = DataLoader(dataset, batch_size=32, shuffle=True)\n",
    "test_loaders = {'test': DataLoader(dataset, batch_size=32, shuffle=False)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 1, 1024]) torch.Size([32, 1, 1024])\n"
     ]
    }
   ],
   "source": [
    "for item in train_loader:\n",
    "    print(item['x'].shape, item['y'].shape)\n",
    "    break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([32, 1, 1024]) torch.Size([32, 1, 1024])\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "for item in train_loader:\n",
    "    break\n",
    "plt.plot(np.linspace(0, 1, item['y'].shape[2]), item['y'][0, 0, :].cpu())\n",
    "plt.plot(np.linspace(0, 1, item['x'].shape[2]), item['x'][0, 0, :].cpu())\n",
    "print(item['y'].shape, item['x'].shape)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "from neuralop.layers.quad_prod import ProductGating, ProductLayer, ProductPath\n",
    "from functools import partial\n",
    "from einops import repeat\n",
    "from neuralop.layers.spectral_convolution import SpectralConv\n",
    "from tltorch import FactorizedTensor\n",
    "\n",
    "\n",
    "class PDE_Regressor(torch.nn.Module):\n",
    "    def __init__(self, in_dim=1, out_dim=1, n_modes=21, num_prod=1, num_operators=2, kernel_size=3):\n",
    "        super(PDE_Regressor, self).__init__()\n",
    "        # self.prod = ProductGating(in_dim=in_dim+num_operators, num_prod=num_prod)\n",
    "        # self.prod = ProductLayer(in_dim=in_dim, num_prods=num_prod, out_dim=out_dim)\n",
    "        self.prod = ProductPath(in_dim=in_dim+num_operators, num_prod=num_prod)\n",
    "        self.fourier = SpectralConv(in_channels=in_dim, out_channels=num_operators, n_modes=(n_modes, ))\n",
    "        self.local = torch.nn.Conv1d(in_dim, num_operators, kernel_size=kernel_size, padding=kernel_size//2)\n",
    "        self.linear1 = torch.nn.Conv1d(in_dim+num_operators, in_dim+num_operators, kernel_size=1)\n",
    "        self.linear2 = torch.nn.Conv1d(in_dim+num_operators+num_prod, out_dim, kernel_size=1)\n",
    "        \n",
    "\n",
    "    def forward(self, x, **kwargs):\n",
    "        transformed_terms = self.fourier(x)\n",
    "        transformed_terms += self.local(x)\n",
    "        out1 = torch.cat([x, transformed_terms], dim=1)\n",
    "        out2 = self.linear1(out1)\n",
    "        out_prod = self.prod(out2)\n",
    "        out = torch.cat([out1, out_prod], dim=1)\n",
    "        out = self.linear2(out)\n",
    "        # out += x\n",
    "        return out\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def predict(self, x):\n",
    "        return self.forward(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Our FNO1D model has 227 parameters.\n"
     ]
    }
   ],
   "source": [
    "model_name = \"FNO1D\"\n",
    "# We create a tensorized FNO model.\n",
    "\n",
    "n_modes=100\n",
    "\n",
    "# model = FNO(in_channels=1, n_modes=(n_modes, ), hidden_channels=2, \n",
    "#              projection_channels=1, factorization=None, \n",
    "#              channel_mixing='prod-gating', \n",
    "#              num_prod=1,\n",
    "#              n_layers=1,\n",
    "#              fno_skip='soft-gating'\n",
    "#             #  stabilizer='tanh', rank=0.42\n",
    "#              )\n",
    "\n",
    "model = PDE_Regressor(1, 1, n_modes, 1, 2)\n",
    "\n",
    "model = model.to(device)\n",
    "# encoder = encoder.to(device)\n",
    "\n",
    "n_params = count_params(model)\n",
    "print(f'\\nOur '+model_name+f' model has {n_params} parameters.')\n",
    "\n",
    "sys.stdout.flush()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "### MODEL ###\n",
      " PDE_Regressor(\n",
      "  (prod): ProductPath()\n",
      "  (fourier): SpectralConv(\n",
      "    (weight): ModuleList(\n",
      "      (0): ComplexDenseTensor(shape=torch.Size([1, 2, 50]), rank=None)\n",
      "    )\n",
      "  )\n",
      "  (local): Conv1d(1, 2, kernel_size=(3,), stride=(1,), padding=(1,))\n",
      "  (linear1): Conv1d(3, 3, kernel_size=(1,), stride=(1,))\n",
      "  (linear2): Conv1d(4, 1, kernel_size=(1,), stride=(1,))\n",
      ")\n",
      "\n",
      "### OPTIMIZER ###\n",
      " Adam (\n",
      "Parameter Group 0\n",
      "    amsgrad: False\n",
      "    betas: (0.9, 0.999)\n",
      "    capturable: False\n",
      "    differentiable: False\n",
      "    eps: 1e-08\n",
      "    foreach: None\n",
      "    fused: None\n",
      "    initial_lr: 0.1\n",
      "    lr: 0.1\n",
      "    maximize: False\n",
      "    weight_decay: 0.0\n",
      ")\n",
      "\n",
      "### SCHEDULER ###\n",
      " <torch.optim.lr_scheduler.StepLR object at 0x74d44cf7cf70>\n",
      "\n",
      "### LOSSES ###\n",
      "\n",
      " * Train: <neuralop.training.losses.H1Loss object at 0x74d4f0e86d10>\n",
      "\n",
      " * Test: {'h1': <neuralop.training.losses.H1Loss object at 0x74d4f0e86d10>, 'l2': <neuralop.training.losses.LpLoss object at 0x74d4f0e84400>}\n"
     ]
    }
   ],
   "source": [
    "#Create the optimizer\n",
    "optimizer = torch.optim.Adam(model.parameters(), \n",
    "                                lr=0.1, \n",
    "                                weight_decay=0.)\n",
    "scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=100, gamma=0.5)\n",
    "\n",
    "# Creating the losses\n",
    "l2loss = LpLoss(d=2, p=2)\n",
    "h1loss = H1Loss(d=2)\n",
    "\n",
    "train_loss = h1loss\n",
    "eval_losses={'h1': h1loss, 'l2': l2loss}\n",
    "\n",
    "print('\\n### MODEL ###\\n', model)\n",
    "print('\\n### OPTIMIZER ###\\n', optimizer)\n",
    "print('\\n### SCHEDULER ###\\n', scheduler)\n",
    "print('\\n### LOSSES ###')\n",
    "print(f'\\n * Train: {train_loss}')\n",
    "print(f'\\n * Test: {eval_losses}')\n",
    "sys.stdout.flush()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "localtime = time.localtime(time.time())\n",
    "time_now = f\"{localtime.tm_mon}-{localtime.tm_mday}-{localtime.tm_hour}-{localtime.tm_min}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-05-22 20:39:08.185966: I tensorflow/core/util/port.cc:113] oneDNN custom operations are on. You may see slightly different numerical results due to floating-point round-off errors from different computation orders. To turn them off, set the environment variable `TF_ENABLE_ONEDNN_OPTS=0`.\n",
      "2024-05-22 20:39:08.206712: E external/local_xla/xla/stream_executor/cuda/cuda_dnn.cc:9261] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "2024-05-22 20:39:08.206735: E external/local_xla/xla/stream_executor/cuda/cuda_fft.cc:607] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "2024-05-22 20:39:08.207391: E external/local_xla/xla/stream_executor/cuda/cuda_blas.cc:1515] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "2024-05-22 20:39:08.211196: I tensorflow/core/platform/cpu_feature_guard.cc:182] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 AVX_VNNI FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2024-05-22 20:39:08.609680: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Could not find TensorRT\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "using standard method to load data to device.\n",
      "using standard method to compute loss.\n",
      "self.override_load_to_device=False\n",
      "self.overrides_loss=False\n"
     ]
    }
   ],
   "source": [
    "trainer = Trainer(model=model, n_epochs=500,\n",
    "                  device=device,\n",
    "                  callbacks=[\n",
    "                            #  OutputEncoderCallback(encoder), \n",
    "                             SimpleTensorBoardLoggerCallback(log_dir='runs/Burgers_prod_simple_'+model_name+time_now,)\n",
    "                            ],             \n",
    "                  wandb_log=False,\n",
    "                  log_test_interval=1,\n",
    "                  use_distributed=False,\n",
    "                  verbose=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training on 2048 samples\n",
      "Testing on [2048] samples         on resolutions ['test'].\n",
      "Raw outputs of size out.shape=torch.Size([32, 1, 1024])\n",
      "[0] time=0.73, avg_loss=0.0470, train_err=0.0115, test_h1=0.7629, test_l2=0.3264\n",
      "[1] time=0.08, avg_loss=0.0358, train_err=0.0087, test_h1=0.5841, test_l2=0.2057\n",
      "[2] time=0.08, avg_loss=0.0353, train_err=0.0086, test_h1=0.5599, test_l2=0.1449\n",
      "[3] time=0.09, avg_loss=0.0367, train_err=0.0090, test_h1=0.5223, test_l2=0.2074\n",
      "[4] time=0.09, avg_loss=0.0318, train_err=0.0078, test_h1=0.5098, test_l2=0.2147\n",
      "[5] time=0.09, avg_loss=0.0297, train_err=0.0073, test_h1=0.4778, test_l2=0.0787\n",
      "[6] time=0.09, avg_loss=0.0328, train_err=0.0080, test_h1=0.4506, test_l2=0.0846\n",
      "[7] time=0.09, avg_loss=0.0304, train_err=0.0074, test_h1=0.4563, test_l2=0.1225\n",
      "[8] time=0.08, avg_loss=0.0306, train_err=0.0075, test_h1=0.4474, test_l2=0.0819\n",
      "[9] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4562, test_l2=0.2140\n",
      "[10] time=0.10, avg_loss=0.0296, train_err=0.0072, test_h1=0.4332, test_l2=0.0960\n",
      "[11] time=0.08, avg_loss=0.0299, train_err=0.0073, test_h1=0.4427, test_l2=0.2127\n",
      "[12] time=0.08, avg_loss=0.0288, train_err=0.0070, test_h1=0.4559, test_l2=0.1950\n",
      "[13] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4469, test_l2=0.1382\n",
      "[14] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4398, test_l2=0.0980\n",
      "[15] time=0.08, avg_loss=0.0260, train_err=0.0063, test_h1=0.4523, test_l2=0.1648\n",
      "[16] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4415, test_l2=0.1646\n",
      "[17] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4512, test_l2=0.2780\n",
      "[18] time=0.09, avg_loss=0.0271, train_err=0.0066, test_h1=0.4589, test_l2=0.1096\n",
      "[19] time=0.08, avg_loss=0.0280, train_err=0.0068, test_h1=0.4286, test_l2=0.0837\n",
      "[20] time=0.08, avg_loss=0.0317, train_err=0.0077, test_h1=0.4414, test_l2=0.0666\n",
      "[21] time=0.09, avg_loss=0.0306, train_err=0.0075, test_h1=0.4397, test_l2=0.0673\n",
      "[22] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4324, test_l2=0.0958\n",
      "[23] time=0.08, avg_loss=0.0298, train_err=0.0073, test_h1=0.4395, test_l2=0.1241\n",
      "[24] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4391, test_l2=0.2060\n",
      "[25] time=0.08, avg_loss=0.0293, train_err=0.0071, test_h1=0.4656, test_l2=0.1375\n",
      "[26] time=0.08, avg_loss=0.0291, train_err=0.0071, test_h1=0.4561, test_l2=0.0407\n",
      "[27] time=0.08, avg_loss=0.0287, train_err=0.0070, test_h1=0.4361, test_l2=0.1043\n",
      "[28] time=0.08, avg_loss=0.0290, train_err=0.0071, test_h1=0.4601, test_l2=0.2786\n",
      "[29] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4479, test_l2=0.1646\n",
      "[30] time=0.09, avg_loss=0.0287, train_err=0.0070, test_h1=0.4427, test_l2=0.1052\n",
      "[31] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4343, test_l2=0.0804\n",
      "[32] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4366, test_l2=0.1772\n",
      "[33] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4414, test_l2=0.1512\n",
      "[34] time=0.08, avg_loss=0.0291, train_err=0.0071, test_h1=0.4275, test_l2=0.0700\n",
      "[35] time=0.08, avg_loss=0.0293, train_err=0.0072, test_h1=0.4373, test_l2=0.1285\n",
      "[36] time=0.08, avg_loss=0.0296, train_err=0.0072, test_h1=0.4418, test_l2=0.0856\n",
      "[37] time=0.09, avg_loss=0.0292, train_err=0.0071, test_h1=0.4407, test_l2=0.1540\n",
      "[38] time=0.09, avg_loss=0.0297, train_err=0.0072, test_h1=0.4286, test_l2=0.0584\n",
      "[39] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4372, test_l2=0.0877\n",
      "[40] time=0.10, avg_loss=0.0291, train_err=0.0071, test_h1=0.4333, test_l2=0.1069\n",
      "[41] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4798, test_l2=0.2880\n",
      "[42] time=0.08, avg_loss=0.0295, train_err=0.0072, test_h1=0.4537, test_l2=0.3108\n",
      "[43] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4309, test_l2=0.0593\n",
      "[44] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4438, test_l2=0.1749\n",
      "[45] time=0.08, avg_loss=0.0291, train_err=0.0071, test_h1=0.4852, test_l2=0.3000\n",
      "[46] time=0.09, avg_loss=0.0267, train_err=0.0065, test_h1=0.4323, test_l2=0.1640\n",
      "[47] time=0.08, avg_loss=0.0304, train_err=0.0074, test_h1=0.4511, test_l2=0.1646\n",
      "[48] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4406, test_l2=0.2051\n",
      "[49] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4460, test_l2=0.1820\n",
      "[50] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4586, test_l2=0.1657\n",
      "[51] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4286, test_l2=0.0990\n",
      "[52] time=0.08, avg_loss=0.0287, train_err=0.0070, test_h1=0.4432, test_l2=0.2113\n",
      "[53] time=0.08, avg_loss=0.0283, train_err=0.0069, test_h1=0.4369, test_l2=0.0507\n",
      "[54] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4298, test_l2=0.0696\n",
      "[55] time=0.08, avg_loss=0.0307, train_err=0.0075, test_h1=0.4368, test_l2=0.1240\n",
      "[56] time=0.08, avg_loss=0.0304, train_err=0.0074, test_h1=0.4329, test_l2=0.1422\n",
      "[57] time=0.09, avg_loss=0.0277, train_err=0.0068, test_h1=0.4285, test_l2=0.0953\n",
      "[58] time=0.09, avg_loss=0.0292, train_err=0.0071, test_h1=0.4389, test_l2=0.1916\n",
      "[59] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4310, test_l2=0.0898\n",
      "[60] time=0.08, avg_loss=0.0291, train_err=0.0071, test_h1=0.4609, test_l2=0.1967\n",
      "[61] time=0.08, avg_loss=0.0290, train_err=0.0071, test_h1=0.4420, test_l2=0.0763\n",
      "[62] time=0.09, avg_loss=0.0273, train_err=0.0067, test_h1=0.4473, test_l2=0.1980\n",
      "[63] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4411, test_l2=0.1228\n",
      "[64] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4297, test_l2=0.1242\n",
      "[65] time=0.08, avg_loss=0.0302, train_err=0.0074, test_h1=0.4694, test_l2=0.2513\n",
      "[66] time=0.08, avg_loss=0.0293, train_err=0.0072, test_h1=0.4724, test_l2=0.4014\n",
      "[67] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4305, test_l2=0.0281\n",
      "[68] time=0.08, avg_loss=0.0299, train_err=0.0073, test_h1=0.4345, test_l2=0.1434\n",
      "[69] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4452, test_l2=0.2744\n",
      "[70] time=0.08, avg_loss=0.0288, train_err=0.0070, test_h1=0.4349, test_l2=0.1639\n",
      "[71] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4398, test_l2=0.0538\n",
      "[72] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4426, test_l2=0.2097\n",
      "[73] time=0.08, avg_loss=0.0304, train_err=0.0074, test_h1=0.4283, test_l2=0.0975\n",
      "[74] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4341, test_l2=0.1246\n",
      "[75] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4266, test_l2=0.0685\n",
      "[76] time=0.08, avg_loss=0.0289, train_err=0.0071, test_h1=0.4534, test_l2=0.2537\n",
      "[77] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4257, test_l2=0.0330\n",
      "[78] time=0.08, avg_loss=0.0289, train_err=0.0071, test_h1=0.4541, test_l2=0.3350\n",
      "[79] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4446, test_l2=0.1773\n",
      "[80] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4365, test_l2=0.1022\n",
      "[81] time=0.08, avg_loss=0.0292, train_err=0.0071, test_h1=0.4603, test_l2=0.2117\n",
      "[82] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4281, test_l2=0.0877\n",
      "[83] time=0.08, avg_loss=0.0293, train_err=0.0072, test_h1=0.4582, test_l2=0.1409\n",
      "[84] time=0.08, avg_loss=0.0283, train_err=0.0069, test_h1=0.4340, test_l2=0.0648\n",
      "[85] time=0.08, avg_loss=0.0301, train_err=0.0073, test_h1=0.4276, test_l2=0.0554\n",
      "[86] time=0.08, avg_loss=0.0307, train_err=0.0075, test_h1=0.4605, test_l2=0.2002\n",
      "[87] time=0.08, avg_loss=0.0297, train_err=0.0072, test_h1=0.4362, test_l2=0.1340\n",
      "[88] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4302, test_l2=0.0990\n",
      "[89] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4250, test_l2=0.0551\n",
      "[90] time=0.08, avg_loss=0.0288, train_err=0.0070, test_h1=0.4462, test_l2=0.0387\n",
      "[91] time=0.08, avg_loss=0.0319, train_err=0.0078, test_h1=0.4423, test_l2=0.0920\n",
      "[92] time=0.08, avg_loss=0.0291, train_err=0.0071, test_h1=0.4416, test_l2=0.0940\n",
      "[93] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4278, test_l2=0.0470\n",
      "[94] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4326, test_l2=0.1144\n",
      "[95] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4299, test_l2=0.1345\n",
      "[96] time=0.08, avg_loss=0.0287, train_err=0.0070, test_h1=0.4382, test_l2=0.1721\n",
      "[97] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4347, test_l2=0.1277\n",
      "[98] time=0.08, avg_loss=0.0297, train_err=0.0072, test_h1=0.4290, test_l2=0.0804\n",
      "[99] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4303, test_l2=0.0938\n",
      "[100] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4271, test_l2=0.0345\n",
      "[101] time=0.08, avg_loss=0.0272, train_err=0.0067, test_h1=0.4393, test_l2=0.1159\n",
      "[102] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4283, test_l2=0.0601\n",
      "[103] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4248, test_l2=0.0415\n",
      "[104] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4370, test_l2=0.0541\n",
      "[105] time=0.12, avg_loss=0.0272, train_err=0.0066, test_h1=0.4321, test_l2=0.0418\n",
      "[106] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4362, test_l2=0.0927\n",
      "[107] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4303, test_l2=0.0878\n",
      "[108] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4255, test_l2=0.0552\n",
      "[109] time=0.09, avg_loss=0.0269, train_err=0.0066, test_h1=0.4274, test_l2=0.0238\n",
      "[110] time=0.11, avg_loss=0.0276, train_err=0.0067, test_h1=0.4257, test_l2=0.0301\n",
      "[111] time=0.08, avg_loss=0.0280, train_err=0.0068, test_h1=0.4397, test_l2=0.1511\n",
      "[112] time=0.09, avg_loss=0.0265, train_err=0.0065, test_h1=0.4256, test_l2=0.0416\n",
      "[113] time=0.09, avg_loss=0.0272, train_err=0.0066, test_h1=0.4324, test_l2=0.0642\n",
      "[114] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4326, test_l2=0.1012\n",
      "[115] time=0.11, avg_loss=0.0294, train_err=0.0072, test_h1=0.4328, test_l2=0.1057\n",
      "[116] time=0.12, avg_loss=0.0273, train_err=0.0067, test_h1=0.4419, test_l2=0.1322\n",
      "[117] time=0.09, avg_loss=0.0271, train_err=0.0066, test_h1=0.4259, test_l2=0.0548\n",
      "[118] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4260, test_l2=0.0490\n",
      "[119] time=0.11, avg_loss=0.0276, train_err=0.0067, test_h1=0.4244, test_l2=0.0335\n",
      "[120] time=0.09, avg_loss=0.0273, train_err=0.0067, test_h1=0.4313, test_l2=0.0788\n",
      "[121] time=0.08, avg_loss=0.0296, train_err=0.0072, test_h1=0.4266, test_l2=0.0633\n",
      "[122] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4253, test_l2=0.0518\n",
      "[123] time=0.08, avg_loss=0.0257, train_err=0.0063, test_h1=0.4273, test_l2=0.0435\n",
      "[124] time=0.09, avg_loss=0.0276, train_err=0.0067, test_h1=0.4338, test_l2=0.1371\n",
      "[125] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4295, test_l2=0.0872\n",
      "[126] time=0.08, avg_loss=0.0301, train_err=0.0074, test_h1=0.4242, test_l2=0.0313\n",
      "[127] time=0.08, avg_loss=0.0288, train_err=0.0070, test_h1=0.4424, test_l2=0.1426\n",
      "[128] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4246, test_l2=0.0559\n",
      "[129] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4286, test_l2=0.0865\n",
      "[130] time=0.08, avg_loss=0.0289, train_err=0.0071, test_h1=0.4335, test_l2=0.1809\n",
      "[131] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4260, test_l2=0.0494\n",
      "[132] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4271, test_l2=0.0339\n",
      "[133] time=0.13, avg_loss=0.0282, train_err=0.0069, test_h1=0.4247, test_l2=0.0248\n",
      "[134] time=0.10, avg_loss=0.0280, train_err=0.0068, test_h1=0.4307, test_l2=0.0442\n",
      "[135] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4241, test_l2=0.0214\n",
      "[136] time=0.09, avg_loss=0.0283, train_err=0.0069, test_h1=0.4301, test_l2=0.0429\n",
      "[137] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4259, test_l2=0.0384\n",
      "[138] time=0.08, avg_loss=0.0285, train_err=0.0070, test_h1=0.4249, test_l2=0.0537\n",
      "[139] time=0.08, avg_loss=0.0285, train_err=0.0070, test_h1=0.4274, test_l2=0.0240\n",
      "[140] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4265, test_l2=0.0515\n",
      "[141] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4262, test_l2=0.0415\n",
      "[142] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4284, test_l2=0.0604\n",
      "[143] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4364, test_l2=0.0325\n",
      "[144] time=0.09, avg_loss=0.0281, train_err=0.0069, test_h1=0.4290, test_l2=0.0789\n",
      "[145] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4274, test_l2=0.0662\n",
      "[146] time=0.09, avg_loss=0.0259, train_err=0.0063, test_h1=0.4275, test_l2=0.0642\n",
      "[147] time=0.08, avg_loss=0.0268, train_err=0.0066, test_h1=0.4304, test_l2=0.0500\n",
      "[148] time=0.08, avg_loss=0.0281, train_err=0.0068, test_h1=0.4288, test_l2=0.0451\n",
      "[149] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4290, test_l2=0.0733\n",
      "[150] time=0.09, avg_loss=0.0274, train_err=0.0067, test_h1=0.4262, test_l2=0.0481\n",
      "[151] time=0.08, avg_loss=0.0283, train_err=0.0069, test_h1=0.4324, test_l2=0.0367\n",
      "[152] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4281, test_l2=0.0770\n",
      "[153] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4262, test_l2=0.0693\n",
      "[154] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4306, test_l2=0.0753\n",
      "[155] time=0.09, avg_loss=0.0282, train_err=0.0069, test_h1=0.4240, test_l2=0.0329\n",
      "[156] time=0.08, avg_loss=0.0285, train_err=0.0070, test_h1=0.4243, test_l2=0.0314\n",
      "[157] time=0.08, avg_loss=0.0272, train_err=0.0067, test_h1=0.4327, test_l2=0.0738\n",
      "[158] time=0.08, avg_loss=0.0287, train_err=0.0070, test_h1=0.4264, test_l2=0.0549\n",
      "[159] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4286, test_l2=0.0716\n",
      "[160] time=0.08, avg_loss=0.0260, train_err=0.0064, test_h1=0.4264, test_l2=0.0710\n",
      "[161] time=0.10, avg_loss=0.0267, train_err=0.0065, test_h1=0.4261, test_l2=0.0543\n",
      "[162] time=0.08, avg_loss=0.0258, train_err=0.0063, test_h1=0.4264, test_l2=0.0168\n",
      "[163] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4277, test_l2=0.0556\n",
      "[164] time=0.08, avg_loss=0.0293, train_err=0.0071, test_h1=0.4306, test_l2=0.0411\n",
      "[165] time=0.08, avg_loss=0.0293, train_err=0.0071, test_h1=0.4325, test_l2=0.0934\n",
      "[166] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4406, test_l2=0.0492\n",
      "[167] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4307, test_l2=0.0394\n",
      "[168] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4274, test_l2=0.0435\n",
      "[169] time=0.08, avg_loss=0.0268, train_err=0.0066, test_h1=0.4339, test_l2=0.1596\n",
      "[170] time=0.08, avg_loss=0.0279, train_err=0.0068, test_h1=0.4277, test_l2=0.0466\n",
      "[171] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4285, test_l2=0.0890\n",
      "[172] time=0.08, avg_loss=0.0285, train_err=0.0069, test_h1=0.4319, test_l2=0.0167\n",
      "[173] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4317, test_l2=0.0447\n",
      "[174] time=0.08, avg_loss=0.0285, train_err=0.0070, test_h1=0.4285, test_l2=0.0341\n",
      "[175] time=0.08, avg_loss=0.0261, train_err=0.0064, test_h1=0.4363, test_l2=0.0961\n",
      "[176] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4276, test_l2=0.0789\n",
      "[177] time=0.08, avg_loss=0.0279, train_err=0.0068, test_h1=0.4356, test_l2=0.0701\n",
      "[178] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4286, test_l2=0.0888\n",
      "[179] time=0.09, avg_loss=0.0286, train_err=0.0070, test_h1=0.4375, test_l2=0.0510\n",
      "[180] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4295, test_l2=0.0900\n",
      "[181] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4273, test_l2=0.1101\n",
      "[182] time=0.08, avg_loss=0.0285, train_err=0.0070, test_h1=0.4351, test_l2=0.1260\n",
      "[183] time=0.11, avg_loss=0.0288, train_err=0.0070, test_h1=0.4389, test_l2=0.0871\n",
      "[184] time=0.09, avg_loss=0.0275, train_err=0.0067, test_h1=0.4276, test_l2=0.0793\n",
      "[185] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4345, test_l2=0.0468\n",
      "[186] time=0.08, avg_loss=0.0280, train_err=0.0068, test_h1=0.4260, test_l2=0.0355\n",
      "[187] time=0.11, avg_loss=0.0280, train_err=0.0068, test_h1=0.4293, test_l2=0.0603\n",
      "[188] time=0.09, avg_loss=0.0266, train_err=0.0065, test_h1=0.4537, test_l2=0.1433\n",
      "[189] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4342, test_l2=0.0982\n",
      "[190] time=0.09, avg_loss=0.0274, train_err=0.0067, test_h1=0.4249, test_l2=0.0444\n",
      "[191] time=0.09, avg_loss=0.0270, train_err=0.0066, test_h1=0.4258, test_l2=0.0305\n",
      "[192] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4304, test_l2=0.1020\n",
      "[193] time=0.08, avg_loss=0.0292, train_err=0.0071, test_h1=0.4443, test_l2=0.1621\n",
      "[194] time=0.08, avg_loss=0.0294, train_err=0.0072, test_h1=0.4250, test_l2=0.0360\n",
      "[195] time=0.09, avg_loss=0.0258, train_err=0.0063, test_h1=0.4267, test_l2=0.0206\n",
      "[196] time=0.09, avg_loss=0.0273, train_err=0.0067, test_h1=0.4322, test_l2=0.0913\n",
      "[197] time=0.10, avg_loss=0.0277, train_err=0.0068, test_h1=0.4266, test_l2=0.0334\n",
      "[198] time=0.09, avg_loss=0.0272, train_err=0.0066, test_h1=0.4407, test_l2=0.1469\n",
      "[199] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4305, test_l2=0.0375\n",
      "[200] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4233, test_l2=0.0175\n",
      "[201] time=0.09, avg_loss=0.0262, train_err=0.0064, test_h1=0.4271, test_l2=0.0201\n",
      "[202] time=0.08, avg_loss=0.0281, train_err=0.0068, test_h1=0.4265, test_l2=0.0426\n",
      "[203] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4271, test_l2=0.0706\n",
      "[204] time=0.09, avg_loss=0.0273, train_err=0.0067, test_h1=0.4245, test_l2=0.0401\n",
      "[205] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4254, test_l2=0.0201\n",
      "[206] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4236, test_l2=0.0184\n",
      "[207] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4238, test_l2=0.0221\n",
      "[208] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4331, test_l2=0.0633\n",
      "[209] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4242, test_l2=0.0172\n",
      "[210] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4264, test_l2=0.0537\n",
      "[211] time=0.08, avg_loss=0.0283, train_err=0.0069, test_h1=0.4250, test_l2=0.0484\n",
      "[212] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4247, test_l2=0.0498\n",
      "[213] time=0.09, avg_loss=0.0273, train_err=0.0067, test_h1=0.4236, test_l2=0.0202\n",
      "[214] time=0.09, avg_loss=0.0268, train_err=0.0065, test_h1=0.4242, test_l2=0.0352\n",
      "[215] time=0.09, avg_loss=0.0274, train_err=0.0067, test_h1=0.4261, test_l2=0.0663\n",
      "[216] time=0.09, avg_loss=0.0261, train_err=0.0064, test_h1=0.4253, test_l2=0.0510\n",
      "[217] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4235, test_l2=0.0173\n",
      "[218] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4245, test_l2=0.0397\n",
      "[219] time=0.08, avg_loss=0.0260, train_err=0.0063, test_h1=0.4275, test_l2=0.0151\n",
      "[220] time=0.09, avg_loss=0.0270, train_err=0.0066, test_h1=0.4259, test_l2=0.0445\n",
      "[221] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4246, test_l2=0.0315\n",
      "[222] time=0.08, avg_loss=0.0287, train_err=0.0070, test_h1=0.4276, test_l2=0.0482\n",
      "[223] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4274, test_l2=0.0242\n",
      "[224] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4241, test_l2=0.0290\n",
      "[225] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4245, test_l2=0.0348\n",
      "[226] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4254, test_l2=0.0327\n",
      "[227] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4290, test_l2=0.0482\n",
      "[228] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4274, test_l2=0.0703\n",
      "[229] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4246, test_l2=0.0241\n",
      "[230] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4306, test_l2=0.0280\n",
      "[231] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4242, test_l2=0.0250\n",
      "[232] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4242, test_l2=0.0279\n",
      "[233] time=0.10, avg_loss=0.0281, train_err=0.0068, test_h1=0.4273, test_l2=0.0468\n",
      "[234] time=0.10, avg_loss=0.0253, train_err=0.0062, test_h1=0.4268, test_l2=0.0579\n",
      "[235] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4253, test_l2=0.0797\n",
      "[236] time=0.09, avg_loss=0.0277, train_err=0.0068, test_h1=0.4301, test_l2=0.0985\n",
      "[237] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4241, test_l2=0.0149\n",
      "[238] time=0.08, avg_loss=0.0294, train_err=0.0072, test_h1=0.4272, test_l2=0.0180\n",
      "[239] time=0.11, avg_loss=0.0265, train_err=0.0065, test_h1=0.4246, test_l2=0.0354\n",
      "[240] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4243, test_l2=0.0224\n",
      "[241] time=0.09, avg_loss=0.0262, train_err=0.0064, test_h1=0.4247, test_l2=0.0270\n",
      "[242] time=0.09, avg_loss=0.0274, train_err=0.0067, test_h1=0.4246, test_l2=0.0437\n",
      "[243] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4270, test_l2=0.0705\n",
      "[244] time=0.08, avg_loss=0.0289, train_err=0.0070, test_h1=0.4289, test_l2=0.0698\n",
      "[245] time=0.08, avg_loss=0.0258, train_err=0.0063, test_h1=0.4272, test_l2=0.0704\n",
      "[246] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4270, test_l2=0.0512\n",
      "[247] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4250, test_l2=0.0290\n",
      "[248] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4307, test_l2=0.0423\n",
      "[249] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4270, test_l2=0.0702\n",
      "[250] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4257, test_l2=0.0505\n",
      "[251] time=0.09, avg_loss=0.0275, train_err=0.0067, test_h1=0.4241, test_l2=0.0303\n",
      "[252] time=0.09, avg_loss=0.0269, train_err=0.0066, test_h1=0.4246, test_l2=0.0178\n",
      "[253] time=0.09, avg_loss=0.0270, train_err=0.0066, test_h1=0.4281, test_l2=0.1305\n",
      "[254] time=0.09, avg_loss=0.0267, train_err=0.0065, test_h1=0.4336, test_l2=0.1131\n",
      "[255] time=0.09, avg_loss=0.0266, train_err=0.0065, test_h1=0.4254, test_l2=0.0469\n",
      "[256] time=0.09, avg_loss=0.0287, train_err=0.0070, test_h1=0.4265, test_l2=0.0462\n",
      "[257] time=0.11, avg_loss=0.0269, train_err=0.0066, test_h1=0.4279, test_l2=0.0213\n",
      "[258] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4299, test_l2=0.0706\n",
      "[259] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4307, test_l2=0.1183\n",
      "[260] time=0.09, avg_loss=0.0280, train_err=0.0068, test_h1=0.4266, test_l2=0.0533\n",
      "[261] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4249, test_l2=0.0204\n",
      "[262] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4239, test_l2=0.0191\n",
      "[263] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4346, test_l2=0.0479\n",
      "[264] time=0.09, avg_loss=0.0275, train_err=0.0067, test_h1=0.4237, test_l2=0.0151\n",
      "[265] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4269, test_l2=0.0166\n",
      "[266] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4255, test_l2=0.0462\n",
      "[267] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4239, test_l2=0.0257\n",
      "[268] time=0.09, avg_loss=0.0273, train_err=0.0067, test_h1=0.4255, test_l2=0.0426\n",
      "[269] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4248, test_l2=0.0193\n",
      "[270] time=0.08, avg_loss=0.0259, train_err=0.0063, test_h1=0.4272, test_l2=0.0580\n",
      "[271] time=0.08, avg_loss=0.0264, train_err=0.0064, test_h1=0.4308, test_l2=0.0541\n",
      "[272] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4303, test_l2=0.0579\n",
      "[273] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4261, test_l2=0.0673\n",
      "[274] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4244, test_l2=0.0484\n",
      "[275] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4239, test_l2=0.0347\n",
      "[276] time=0.08, avg_loss=0.0285, train_err=0.0070, test_h1=0.4243, test_l2=0.0310\n",
      "[277] time=0.09, avg_loss=0.0277, train_err=0.0068, test_h1=0.4259, test_l2=0.0626\n",
      "[278] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4256, test_l2=0.0737\n",
      "[279] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4292, test_l2=0.0886\n",
      "[280] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4258, test_l2=0.0583\n",
      "[281] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4242, test_l2=0.0272\n",
      "[282] time=0.10, avg_loss=0.0275, train_err=0.0067, test_h1=0.4248, test_l2=0.0384\n",
      "[283] time=0.09, avg_loss=0.0290, train_err=0.0071, test_h1=0.4308, test_l2=0.1012\n",
      "[284] time=0.09, avg_loss=0.0276, train_err=0.0067, test_h1=0.4273, test_l2=0.0685\n",
      "[285] time=0.08, avg_loss=0.0287, train_err=0.0070, test_h1=0.4275, test_l2=0.0716\n",
      "[286] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4241, test_l2=0.0402\n",
      "[287] time=0.10, avg_loss=0.0278, train_err=0.0068, test_h1=0.4269, test_l2=0.0492\n",
      "[288] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4244, test_l2=0.0205\n",
      "[289] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4307, test_l2=0.0533\n",
      "[290] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4257, test_l2=0.0600\n",
      "[291] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4236, test_l2=0.0145\n",
      "[292] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4290, test_l2=0.0920\n",
      "[293] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4276, test_l2=0.0614\n",
      "[294] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4258, test_l2=0.0169\n",
      "[295] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4262, test_l2=0.0303\n",
      "[296] time=0.10, avg_loss=0.0275, train_err=0.0067, test_h1=0.4298, test_l2=0.0198\n",
      "[297] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4245, test_l2=0.0277\n",
      "[298] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4299, test_l2=0.0815\n",
      "[299] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4252, test_l2=0.0182\n",
      "[300] time=0.08, avg_loss=0.0261, train_err=0.0064, test_h1=0.4235, test_l2=0.0159\n",
      "[301] time=0.08, avg_loss=0.0279, train_err=0.0068, test_h1=0.4242, test_l2=0.0281\n",
      "[302] time=0.07, avg_loss=0.0283, train_err=0.0069, test_h1=0.4251, test_l2=0.0302\n",
      "[303] time=0.09, avg_loss=0.0260, train_err=0.0064, test_h1=0.4246, test_l2=0.0339\n",
      "[304] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4239, test_l2=0.0132\n",
      "[305] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4235, test_l2=0.0132\n",
      "[306] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4245, test_l2=0.0275\n",
      "[307] time=0.08, avg_loss=0.0279, train_err=0.0068, test_h1=0.4246, test_l2=0.0255\n",
      "[308] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4271, test_l2=0.0307\n",
      "[309] time=0.08, avg_loss=0.0261, train_err=0.0064, test_h1=0.4255, test_l2=0.0236\n",
      "[310] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4249, test_l2=0.0422\n",
      "[311] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4234, test_l2=0.0214\n",
      "[312] time=0.09, avg_loss=0.0267, train_err=0.0065, test_h1=0.4250, test_l2=0.0317\n",
      "[313] time=0.09, avg_loss=0.0263, train_err=0.0064, test_h1=0.4254, test_l2=0.0120\n",
      "[314] time=0.08, avg_loss=0.0258, train_err=0.0063, test_h1=0.4234, test_l2=0.0205\n",
      "[315] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4233, test_l2=0.0225\n",
      "[316] time=0.08, avg_loss=0.0280, train_err=0.0068, test_h1=0.4236, test_l2=0.0257\n",
      "[317] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4248, test_l2=0.0470\n",
      "[318] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4235, test_l2=0.0142\n",
      "[319] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4239, test_l2=0.0287\n",
      "[320] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4234, test_l2=0.0167\n",
      "[321] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4247, test_l2=0.0466\n",
      "[322] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4237, test_l2=0.0265\n",
      "[323] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4231, test_l2=0.0117\n",
      "[324] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4234, test_l2=0.0270\n",
      "[325] time=0.08, avg_loss=0.0264, train_err=0.0065, test_h1=0.4274, test_l2=0.0229\n",
      "[326] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4237, test_l2=0.0152\n",
      "[327] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4252, test_l2=0.0494\n",
      "[328] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4234, test_l2=0.0157\n",
      "[329] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4247, test_l2=0.0398\n",
      "[330] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4236, test_l2=0.0219\n",
      "[331] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4245, test_l2=0.0246\n",
      "[332] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4265, test_l2=0.0495\n",
      "[333] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4249, test_l2=0.0239\n",
      "[334] time=0.12, avg_loss=0.0262, train_err=0.0064, test_h1=0.4246, test_l2=0.0273\n",
      "[335] time=0.08, avg_loss=0.0280, train_err=0.0068, test_h1=0.4258, test_l2=0.0256\n",
      "[336] time=0.08, avg_loss=0.0252, train_err=0.0062, test_h1=0.4239, test_l2=0.0270\n",
      "[337] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4242, test_l2=0.0294\n",
      "[338] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4242, test_l2=0.0266\n",
      "[339] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4233, test_l2=0.0159\n",
      "[340] time=0.08, avg_loss=0.0289, train_err=0.0070, test_h1=0.4246, test_l2=0.0251\n",
      "[341] time=0.08, avg_loss=0.0258, train_err=0.0063, test_h1=0.4240, test_l2=0.0271\n",
      "[342] time=0.08, avg_loss=0.0283, train_err=0.0069, test_h1=0.4255, test_l2=0.0338\n",
      "[343] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4252, test_l2=0.0142\n",
      "[344] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4243, test_l2=0.0143\n",
      "[345] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4241, test_l2=0.0274\n",
      "[346] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4244, test_l2=0.0261\n",
      "[347] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4233, test_l2=0.0205\n",
      "[348] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4241, test_l2=0.0142\n",
      "[349] time=0.08, avg_loss=0.0268, train_err=0.0066, test_h1=0.4233, test_l2=0.0304\n",
      "[350] time=0.08, avg_loss=0.0264, train_err=0.0065, test_h1=0.4232, test_l2=0.0173\n",
      "[351] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4246, test_l2=0.0426\n",
      "[352] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4262, test_l2=0.0220\n",
      "[353] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4236, test_l2=0.0203\n",
      "[354] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4235, test_l2=0.0145\n",
      "[355] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4250, test_l2=0.0486\n",
      "[356] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4246, test_l2=0.0444\n",
      "[357] time=0.09, avg_loss=0.0272, train_err=0.0066, test_h1=0.4235, test_l2=0.0125\n",
      "[358] time=0.08, avg_loss=0.0283, train_err=0.0069, test_h1=0.4243, test_l2=0.0391\n",
      "[359] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4251, test_l2=0.0239\n",
      "[360] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4251, test_l2=0.0155\n",
      "[361] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4261, test_l2=0.0199\n",
      "[362] time=0.09, avg_loss=0.0278, train_err=0.0068, test_h1=0.4243, test_l2=0.0363\n",
      "[363] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4245, test_l2=0.0226\n",
      "[364] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4253, test_l2=0.0140\n",
      "[365] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4241, test_l2=0.0178\n",
      "[366] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4259, test_l2=0.0439\n",
      "[367] time=0.09, avg_loss=0.0254, train_err=0.0062, test_h1=0.4243, test_l2=0.0342\n",
      "[368] time=0.08, avg_loss=0.0290, train_err=0.0071, test_h1=0.4237, test_l2=0.0334\n",
      "[369] time=0.08, avg_loss=0.0279, train_err=0.0068, test_h1=0.4242, test_l2=0.0326\n",
      "[370] time=0.08, avg_loss=0.0259, train_err=0.0063, test_h1=0.4240, test_l2=0.0351\n",
      "[371] time=0.08, avg_loss=0.0261, train_err=0.0064, test_h1=0.4233, test_l2=0.0147\n",
      "[372] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4234, test_l2=0.0173\n",
      "[373] time=0.08, avg_loss=0.0280, train_err=0.0068, test_h1=0.4261, test_l2=0.0208\n",
      "[374] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4269, test_l2=0.0326\n",
      "[375] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4250, test_l2=0.0172\n",
      "[376] time=0.09, avg_loss=0.0269, train_err=0.0066, test_h1=0.4244, test_l2=0.0452\n",
      "[377] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4244, test_l2=0.0380\n",
      "[378] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4235, test_l2=0.0283\n",
      "[379] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4237, test_l2=0.0326\n",
      "[380] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4232, test_l2=0.0152\n",
      "[381] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4238, test_l2=0.0209\n",
      "[382] time=0.09, avg_loss=0.0274, train_err=0.0067, test_h1=0.4241, test_l2=0.0379\n",
      "[383] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4239, test_l2=0.0215\n",
      "[384] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4235, test_l2=0.0127\n",
      "[385] time=0.08, avg_loss=0.0272, train_err=0.0067, test_h1=0.4240, test_l2=0.0171\n",
      "[386] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4252, test_l2=0.0162\n",
      "[387] time=0.10, avg_loss=0.0262, train_err=0.0064, test_h1=0.4233, test_l2=0.0184\n",
      "[388] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4234, test_l2=0.0181\n",
      "[389] time=0.09, avg_loss=0.0278, train_err=0.0068, test_h1=0.4280, test_l2=0.0542\n",
      "[390] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4248, test_l2=0.0281\n",
      "[391] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4238, test_l2=0.0252\n",
      "[392] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4232, test_l2=0.0151\n",
      "[393] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4279, test_l2=0.0166\n",
      "[394] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4239, test_l2=0.0277\n",
      "[395] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4253, test_l2=0.0374\n",
      "[396] time=0.09, avg_loss=0.0274, train_err=0.0067, test_h1=0.4235, test_l2=0.0130\n",
      "[397] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4235, test_l2=0.0162\n",
      "[398] time=0.09, avg_loss=0.0279, train_err=0.0068, test_h1=0.4250, test_l2=0.0213\n",
      "[399] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4234, test_l2=0.0189\n",
      "[400] time=0.09, avg_loss=0.0268, train_err=0.0065, test_h1=0.4233, test_l2=0.0232\n",
      "[401] time=0.08, avg_loss=0.0272, train_err=0.0066, test_h1=0.4232, test_l2=0.0147\n",
      "[402] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4231, test_l2=0.0130\n",
      "[403] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4251, test_l2=0.0162\n",
      "[404] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4235, test_l2=0.0234\n",
      "[405] time=0.08, avg_loss=0.0264, train_err=0.0064, test_h1=0.4230, test_l2=0.0129\n",
      "[406] time=0.11, avg_loss=0.0272, train_err=0.0066, test_h1=0.4271, test_l2=0.0209\n",
      "[407] time=0.09, avg_loss=0.0265, train_err=0.0065, test_h1=0.4232, test_l2=0.0136\n",
      "[408] time=0.09, avg_loss=0.0275, train_err=0.0067, test_h1=0.4245, test_l2=0.0153\n",
      "[409] time=0.09, avg_loss=0.0280, train_err=0.0068, test_h1=0.4232, test_l2=0.0177\n",
      "[410] time=0.09, avg_loss=0.0260, train_err=0.0064, test_h1=0.4233, test_l2=0.0119\n",
      "[411] time=0.08, avg_loss=0.0260, train_err=0.0064, test_h1=0.4244, test_l2=0.0118\n",
      "[412] time=0.08, avg_loss=0.0271, train_err=0.0066, test_h1=0.4251, test_l2=0.0201\n",
      "[413] time=0.09, avg_loss=0.0293, train_err=0.0072, test_h1=0.4235, test_l2=0.0117\n",
      "[414] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4232, test_l2=0.0141\n",
      "[415] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4231, test_l2=0.0151\n",
      "[416] time=0.09, avg_loss=0.0277, train_err=0.0068, test_h1=0.4241, test_l2=0.0236\n",
      "[417] time=0.09, avg_loss=0.0280, train_err=0.0068, test_h1=0.4238, test_l2=0.0174\n",
      "[418] time=0.09, avg_loss=0.0265, train_err=0.0065, test_h1=0.4246, test_l2=0.0144\n",
      "[419] time=0.09, avg_loss=0.0271, train_err=0.0066, test_h1=0.4235, test_l2=0.0131\n",
      "[420] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4231, test_l2=0.0152\n",
      "[421] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4237, test_l2=0.0316\n",
      "[422] time=0.09, avg_loss=0.0270, train_err=0.0066, test_h1=0.4232, test_l2=0.0128\n",
      "[423] time=0.08, avg_loss=0.0257, train_err=0.0063, test_h1=0.4245, test_l2=0.0135\n",
      "[424] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4232, test_l2=0.0159\n",
      "[425] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4237, test_l2=0.0117\n",
      "[426] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4234, test_l2=0.0118\n",
      "[427] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4233, test_l2=0.0137\n",
      "[428] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4246, test_l2=0.0139\n",
      "[429] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4234, test_l2=0.0254\n",
      "[430] time=0.11, avg_loss=0.0270, train_err=0.0066, test_h1=0.4231, test_l2=0.0139\n",
      "[431] time=0.08, avg_loss=0.0259, train_err=0.0063, test_h1=0.4231, test_l2=0.0150\n",
      "[432] time=0.08, avg_loss=0.0255, train_err=0.0062, test_h1=0.4242, test_l2=0.0274\n",
      "[433] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4231, test_l2=0.0140\n",
      "[434] time=0.09, avg_loss=0.0264, train_err=0.0064, test_h1=0.4232, test_l2=0.0201\n",
      "[435] time=0.09, avg_loss=0.0262, train_err=0.0064, test_h1=0.4244, test_l2=0.0183\n",
      "[436] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4232, test_l2=0.0154\n",
      "[437] time=0.08, avg_loss=0.0267, train_err=0.0065, test_h1=0.4232, test_l2=0.0262\n",
      "[438] time=0.08, avg_loss=0.0262, train_err=0.0064, test_h1=0.4230, test_l2=0.0117\n",
      "[439] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4237, test_l2=0.0128\n",
      "[440] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4234, test_l2=0.0197\n",
      "[441] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4252, test_l2=0.0199\n",
      "[442] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4233, test_l2=0.0136\n",
      "[443] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4237, test_l2=0.0152\n",
      "[444] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4255, test_l2=0.0154\n",
      "[445] time=0.08, avg_loss=0.0293, train_err=0.0072, test_h1=0.4232, test_l2=0.0176\n",
      "[446] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4232, test_l2=0.0142\n",
      "[447] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4234, test_l2=0.0252\n",
      "[448] time=0.08, avg_loss=0.0293, train_err=0.0071, test_h1=0.4235, test_l2=0.0135\n",
      "[449] time=0.08, avg_loss=0.0261, train_err=0.0064, test_h1=0.4231, test_l2=0.0140\n",
      "[450] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4233, test_l2=0.0193\n",
      "[451] time=0.11, avg_loss=0.0267, train_err=0.0065, test_h1=0.4234, test_l2=0.0137\n",
      "[452] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4247, test_l2=0.0358\n",
      "[453] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4232, test_l2=0.0154\n",
      "[454] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4237, test_l2=0.0127\n",
      "[455] time=0.10, avg_loss=0.0278, train_err=0.0068, test_h1=0.4236, test_l2=0.0143\n",
      "[456] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4232, test_l2=0.0136\n",
      "[457] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4233, test_l2=0.0123\n",
      "[458] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4235, test_l2=0.0141\n",
      "[459] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4237, test_l2=0.0184\n",
      "[460] time=0.08, avg_loss=0.0264, train_err=0.0065, test_h1=0.4234, test_l2=0.0196\n",
      "[461] time=0.09, avg_loss=0.0266, train_err=0.0065, test_h1=0.4247, test_l2=0.0137\n",
      "[462] time=0.09, avg_loss=0.0280, train_err=0.0068, test_h1=0.4238, test_l2=0.0128\n",
      "[463] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4234, test_l2=0.0151\n",
      "[464] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4254, test_l2=0.0190\n",
      "[465] time=0.08, avg_loss=0.0264, train_err=0.0065, test_h1=0.4231, test_l2=0.0154\n",
      "[466] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4252, test_l2=0.0123\n",
      "[467] time=0.09, avg_loss=0.0256, train_err=0.0062, test_h1=0.4234, test_l2=0.0171\n",
      "[468] time=0.08, avg_loss=0.0273, train_err=0.0067, test_h1=0.4254, test_l2=0.0190\n",
      "[469] time=0.08, avg_loss=0.0259, train_err=0.0063, test_h1=0.4234, test_l2=0.0199\n",
      "[470] time=0.08, avg_loss=0.0270, train_err=0.0066, test_h1=0.4233, test_l2=0.0143\n",
      "[471] time=0.08, avg_loss=0.0277, train_err=0.0068, test_h1=0.4231, test_l2=0.0145\n",
      "[472] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4235, test_l2=0.0141\n",
      "[473] time=0.08, avg_loss=0.0291, train_err=0.0071, test_h1=0.4235, test_l2=0.0180\n",
      "[474] time=0.09, avg_loss=0.0264, train_err=0.0064, test_h1=0.4237, test_l2=0.0316\n",
      "[475] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4231, test_l2=0.0145\n",
      "[476] time=0.08, avg_loss=0.0268, train_err=0.0065, test_h1=0.4234, test_l2=0.0162\n",
      "[477] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4243, test_l2=0.0177\n",
      "[478] time=0.08, avg_loss=0.0264, train_err=0.0065, test_h1=0.4231, test_l2=0.0125\n",
      "[479] time=0.08, avg_loss=0.0274, train_err=0.0067, test_h1=0.4241, test_l2=0.0184\n",
      "[480] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4238, test_l2=0.0243\n",
      "[481] time=0.08, avg_loss=0.0279, train_err=0.0068, test_h1=0.4237, test_l2=0.0168\n",
      "[482] time=0.08, avg_loss=0.0286, train_err=0.0070, test_h1=0.4232, test_l2=0.0118\n",
      "[483] time=0.08, avg_loss=0.0275, train_err=0.0067, test_h1=0.4234, test_l2=0.0152\n",
      "[484] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4231, test_l2=0.0168\n",
      "[485] time=0.08, avg_loss=0.0282, train_err=0.0069, test_h1=0.4267, test_l2=0.0127\n",
      "[486] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4232, test_l2=0.0122\n",
      "[487] time=0.09, avg_loss=0.0278, train_err=0.0068, test_h1=0.4237, test_l2=0.0123\n",
      "[488] time=0.08, avg_loss=0.0265, train_err=0.0065, test_h1=0.4239, test_l2=0.0216\n",
      "[489] time=0.08, avg_loss=0.0269, train_err=0.0066, test_h1=0.4236, test_l2=0.0164\n",
      "[490] time=0.08, avg_loss=0.0281, train_err=0.0069, test_h1=0.4242, test_l2=0.0151\n",
      "[491] time=0.10, avg_loss=0.0257, train_err=0.0063, test_h1=0.4234, test_l2=0.0135\n",
      "[492] time=0.08, avg_loss=0.0264, train_err=0.0064, test_h1=0.4231, test_l2=0.0131\n",
      "[493] time=0.08, avg_loss=0.0284, train_err=0.0069, test_h1=0.4239, test_l2=0.0135\n",
      "[494] time=0.08, avg_loss=0.0278, train_err=0.0068, test_h1=0.4230, test_l2=0.0122\n",
      "[495] time=0.08, avg_loss=0.0276, train_err=0.0067, test_h1=0.4233, test_l2=0.0164\n",
      "[496] time=0.08, avg_loss=0.0266, train_err=0.0065, test_h1=0.4233, test_l2=0.0124\n",
      "[497] time=0.08, avg_loss=0.0260, train_err=0.0063, test_h1=0.4234, test_l2=0.0126\n",
      "[498] time=0.09, avg_loss=0.0276, train_err=0.0067, test_h1=0.4233, test_l2=0.0119\n",
      "[499] time=0.08, avg_loss=0.0263, train_err=0.0064, test_h1=0.4238, test_l2=0.0322\n"
     ]
    }
   ],
   "source": [
    "trainer.train(train_loader=train_loader,\n",
    "              test_loaders=test_loaders,\n",
    "              optimizer=optimizer, \n",
    "              scheduler=scheduler, \n",
    "              regularizer=False, \n",
    "              training_loss=train_loss, \n",
    "              eval_losses=eval_losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "path = 'ckpt/Burgers/FNO_prod_simple1.pth'\n",
    "\n",
    "# Create directories if they do not exist\n",
    "dir_path = os.path.dirname(path)\n",
    "if not os.path.exists(dir_path):\n",
    "    os.makedirs(dir_path)\n",
    "\n",
    "# Save the model\n",
    "state_dict = trainer.model.state_dict()\n",
    "torch.save(state_dict, path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "path = 'ckpt/Burgers/FNO_prod_simple1.pth'\n",
    "state_dict = torch.load(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "fourier_weight = state_dict['fourier.weight.0.tensor'][0].cpu().numpy()\n",
    "n = fourier_weight.shape[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "font_size = 12"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pearson: 0.9989802171019162\n"
     ]
    }
   ],
   "source": [
    "x = np.array(range(1, n)); y = np.abs(fourier_weight[0, 1:, 1])\n",
    "k, b = np.polyfit(x[:40], y[:40], 1)\n",
    "y1 = k * x + b\n",
    "plt.xticks(fontsize=font_size)\n",
    "plt.yticks(fontsize=font_size)\n",
    "line1 = plt.plot(x, y, label='Imaginary Part of the 1st Fourier Weight')\n",
    "line2 = plt.plot(x, y1, label='Linear Regression')\n",
    "plt.legend(fontsize=font_size)\n",
    "plt.savefig(fname='./img/spec1.png' )\n",
    "plt.show()\n",
    "print(f'pearson: {np.corrcoef(y1, y)[0,1]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.026175558376938496, 0.01474321650770997)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "k, b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pearson: 0.9998679774173431\n"
     ]
    }
   ],
   "source": [
    "x = np.array(range(1, n)); y = np.abs(fourier_weight[0, 1:, 0])\n",
    "a, b, c = np.polyfit(x[:40], y[:40], 2)\n",
    "y1 = a * (np.square(x)) + b * x + c\n",
    "plt.xticks(fontsize=font_size)\n",
    "plt.yticks(fontsize=font_size)\n",
    "line1 = plt.plot(x, y, label='Real Part of the 2nd Fourier Weight')\n",
    "line2 = plt.plot(x, y1, label='Quadritic Regression')\n",
    "plt.legend(fontsize=font_size)\n",
    "plt.savefig(fname='./img/spec2')\n",
    "plt.show()\n",
    "print(f'pearson: {np.corrcoef(y1, y)[0,1]}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.0019067935686044562, 0.01474321650770997, 8.482005720341252)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "a, b, c"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "test",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
